Endpoint | Description | ||
---|---|---|---|
GET /appointments/status/{status} | Returns an array of appointments with specified status. | ||
GET /appointments/{appointmentId} | Returns a JSON object for specified appointment. | ||
GET /appointments/resource/{resourceId/{statusList} | Returns all appointments that include specified resource. | ||
GET /appointments/recurringappointments/{recurringApptId} | Returns a list of appointment objects that were part of the recurring appointment series that specified appointment is part of as determined by the value set in its recurringAppointmentId. | ||
GET /appointments/{appointmentId}/checkWaitList | Checks the waitlist of specified appointment before updating appointment object. | ||
GET /appointments/report | Returns an array of all appointments on a business' account. | ||
POST /appointments | Creates a new appointment on a business' account. Request body/payload: Must pass a full appointment object. | ||
PUT /appointments/{appointmentId} | Updates an existing appointment. Request body/payload: Must pass an appointment with the desired changes made. | ||
PUT /appointments/{appointmentId}/cancel/{sendStaffEmail}/{sendClientEmail} | Sets an appointment to a substatus of CANCEL and alters boolean flag accordingly to notify the client via email. Effectively cancels an appointment with the option to send an email to the staff and the client. Request body/payload: Must pass an appointment object with substatus set to CANCEL. | ||
PUT /appointments/{appointmentId}/noshow/{sendClientEmail} | Sets an appointment to a substatus of NO_SHOW and alters boolean flag accordingly to notify the client via email. Request body/payload: Must pass an appointment object with substatus set to NO_SHOW. This endpoint also requires a JSON POST body of an empty string for the Reason property of the appointment:
| ||
PUT /appointments/{appointmentId}/completed/{sendClientEmail} | Sets an appointment to a substatus of COMPLETED and alters boolean flag accordingly to send a thank you email to the client. Request body/payload: Must pass an appointment object with substatus set to COMPLETED. This endpoint also requires a JSON POST body of an empty string for the Reason property of the appointment:
|
To aid with page load time, we have included pageNumber and pageSize parameters for server side pagination. The pageSize parameter will be the number of items shown per page.
Parameter | Type | Endpoints to be used with | Description |
---|---|---|---|
clientId | integer | GET /appointments/report | Displays unique numeric ID of client of appointment to be returned following a GET report call. |
classScheduleId | integer | GET /appointments/report | Displays unique numeric ID of client of appointment to be returned following a GET report call. |
endDate | string | GET /appointments/report | Displays the end date of appointments to be returned following a GET report call, formatted as YYYY-MM-DD. |
excludeTimeOff | boolean | GET /appointments/report | If TRUE then the GET report call does not return appointments that are set for reasons of reasonType PERSONAL; if FALSE then it does return appointments that are set for reasons of reasonType PERSONAL. |
onlyTimeOff | integer | GET /appointments/report | Can be set to 0 or 1; if set to 0 then reads as essentially false; if set to 1 then only appointments that are set for reasons that are of reasonType PERSONAL will return. |
order_field | string | GET /appointments/report | Displays the field that appointments returned following a GET report call should be ordered by. |
order_mode | string | GET /appointments/report | Displays the mode ('asc'ending or 'desc'ending) in which appointments returned following a GET report call should appear. |
pageNumber | integer | GET /appointments/report | Works with the pageSize parameter to determine how appointments get returned following a GET report call. The pageNumber value represents the number of pages on which the class sessions that get returned appear. |
pageSize | integer | GET /appointments/report | Works with the pageNumber parameter to determine how appointments gets returned following a GET report call. The pageSize value represents the number of class sessions appearing on each page of class sessions that gets returned. |
staffIdList | integer | GET /appointments/report | Displays a comma-separated list of unique numeric IDs of staff of appointments to be returned following a GET report call. |
startDate | string | GET /appointments/report | Displays the start date of appointments to be returned following a GET report call, formatted as YYYY-MM-DD. |
locationIdList | integer | GET /appointments/report | Displays a comma-separated list of locationIds connected to the appointments you want returned following a GET report call. |
statusList | string | GET /appointments/report | Displays a comma-separated list of statuses of the appointments you want returned following a GET report call. Has acceptable values of OPEN, CLOSED, INPROGRESS, COMPLETED, READ_ONLY, PENDING, PENDING_CONFIRMATION, PENDING_WAITLIST, CHECKEDIN, CANCELLED, and CONFIRMED. |
waitListIds | string | PUT /appointments/{appointmentId} | Displays a comma-separated list of waitListIds to be invited to claim the spot of a cancelled appointment. |
override | integer | POST /appointments | Can be set to 0 or 1; if set to 0 then staff for specified appointment is free during that time slot; if set to 1 you are overriding the staff's work schedule and effectively double booking him or her. |
Code Block | ||||||||
---|---|---|---|---|---|---|---|---|
| ||||||||
{ "additionalStaffIdList": null, "appointmentDateTimeClient": "Thursday, Jul 26, 2018 at 8:00 AM FNT", "appointmentDateTimeStaff": "Thursday, Jul 26, 2018 at 8:00 AM FNT", "blockStaffIdList": [], "blockedStaffList": [], "businessId": 43111, "calendarId": 16902079, "cancelReason": null, "cancelUser": null, "changeReason": "", "classScheduleId": null, "client": {Client object for client of appointment-see clients API page}, "clientConfirmedDate": 1532371154462, "clientConfirmed": true, "clientEndDate": "2018-07-25", "clientEndTime": 900, "clientReminderHours": 1, "clientRescheduleCount": 0, "clientStartDate": "2018-07-26", "clientStartTime": 800, "color": "#668CD9", "completedReason": null, "coordinatorStaff": null, "coupon": null, "couponId": null, "createddate": "2018-06-21 14:45:52", "createduser": "JoeSchmo", "customFieldDesc": "Comments : Boo!", "date": "2018-07-26", "dateCheckedIn": null, "dateCompleted": null, "discount": null, "endDate": "2018-07-26", "endTime": 930, "fields": {Scheduler fields object for fields of fields of appointment-see scheduler fields API page}, "invitationUUId": null, "jobRequisitionId": null, "location": {Location object for location of appointment-see locations API page}, "locationGroup": {Location group object for location group of appointment-see groups API page}, "locationSuperGroup": null, "modifieddate": null, "modifieduser": null, "noPrefSelected": null, "noShowReason": null, "note": "", "packageSoldId": null, "price": null, "reason": {Reason object for service of appointment-see services API page}, "reasonGroup": {Reason group object for reason group of appointment-see groups API page}, "recall": null, "recallDate": null, "recallStatus": null, "recurringAppointmentId": 101096, "remindClientSmsHrs": 2, "remindStaffSmsHours": 4, "resource": {Resource object for resource of appointment-see resources API page}, "seats": 1, "sendConfirmationToClient": false, "sendConfirmationToStaff": false, "staff": {Staff object for staff of appointment-see staff API page}, "staffReminderHours": 3, "staffRescheduleCount": 9, "startDate": "2018-07-26", "startTime": 945, "status": "OPEN", "subStatus": "CONFIRMED", "transactionFee": null, "waitlistId": null } |
Code Block | ||||||||
---|---|---|---|---|---|---|---|---|
| ||||||||
{ "additionalStaffIdList": null, "address": null, "appointmentDateTimeClient": "Thursday, Jun 28, 2018 at 8:00 AM FNT", "appointmentDateTimeStaff": "Thursday, Jun 28, 2018 at 8:00 AM FNT", "blockStaffIdList": [], "blockedStaffList": null, "businessId": 43111, "calendarId": 16902075, "cancelReason": null, "cancelUser": null, "changeReason": "", "classScheduleId": null, "classroom": null, "client": {Client object for client of appointment-see clients API page}, "clientConfirmedDate": 1532371154462, "clientConfirmed": true, "clientEndDate": "2018-06-28", "clientEndTime": 900, "clientReminderHours": 0, "clientRescheduleCount": 0, "clientStartDate": "2018-06-28", "clientStartTime": 800, "color": "#668CD9", "completedReason": null, "coordinatorStaff": {Staff object for coordinator staff of appointment-see staff API page}, "coupon": null, "couponId": null, "createddate": "2018-06-21 14:45:51", "createduser": "JoeSchmo", "customFieldDesc": "". "date": "2018-06-28", "dateCheckedIn": null, "dateCompleted": 1530785153340, "discount": null, "endDate": "2018-06-28", "endTime": 900, "fields": null, "invitationUUId": null, "jobRequisitionId": null, "location": {Location object for location of appointment-see locations API page}, "locationGroup": {Location group object for location group of appointment-see groups API page}, "locationSuperGroup": null, "modifieddate": null, "modifieduser": null, "noPrefSelected": null, "noShowReason": null, "note": "", "packageSoldId": null, "price": null, "reason": {Reason object for service of appointment-see services API page}, "reasonGroup": {Reason group object for reason group of appointment-see groups API page}, "recall": null, "recallDate": null, "recallStatus": null, "recurringAppointmentId": 101096, "remindClientSmsHrs": 0, "remindStaffSmsHours": 0, "resource": {Resource object for resource of appointment-see resources API page}, "seats": 1, "sendConfirmationToClient": true, "sendConfirmationToStaff": false, "staff": {Staff object for staff of appointment-see staff API page}, "staffReminderHours": 0, "staffRescheduleCount": 0, "startDate": "2018-06-28", "startTime": 800, "status": "COMPLETED", "subStatus": "COMPLETED", "transactionFee": null, "waitlistId": null } |
Code Block | ||||||||
---|---|---|---|---|---|---|---|---|
| ||||||||
[{ "additionalStaffIdList": null, "address": null, "appointmentDateTimeClient": "Thursday, Jul 26, 2018 at 12:00 PM FNT", "appointmentDateTimeStaff": "Thursday, Jul 26, 2018 at 12:00 PM FNT", "blockStaffIdList": [], "blockedStaffList": [], "businessId": 43111, "calendarId": 17246703, "cancelReason": "", "cancelUser": "JoeSchmo", "changeReason": "", "classScheduleId": null, "client": null, "clientConfirmedDate": 1532371154462, "clientConfirmed": false, "clientEndDate": "2018-07-26", "clientEndTime": 1330, "clientReminderHours": 0, "clientRescheduleCount": 0, "clientStartDate": "2018-07-26", "clientStartTime": 1200, "color": null, "completedReason": "", "coordinatorStaff": {Staff object for coordinator staff of appointment-see staff API page}, "coupon": null, "couponId": null, "createddate": "2018-07-24 16:10:52", "createduser": "JoeSchmo", "customFieldDesc": "". "date": "2018-07-26", "dateCheckedIn": null, "dateCompleted": 1530785153340, "dateStarted": 1532525579100, "discount": null, "endDate": "2018-07-26", "endTime": 1325, "fields": {Scheduler field object for field of appointment-see scheduler fields API page}, "invitationUUId": null, "jobRequisitionId": null, "location": {Location object for location of appointment-see locations API page}, "locationGroup": {Location group object for location group of appointment-see groups API page}, "locationSuperGroup": null, "modifieddate": null, "modifieduser": null, "noPrefSelected": null, "noShowReason": "", "note": "", "packageSoldId": null, "price": 8, "reason": {Reason object for service of appointment-see services API page}, "reasonGroup": null, "recall": null, "recallDate": null, "recallStatus": null, "recurringAppointmentId": null, "remindClientSmsHrs": 1, "remindStaffSmsHours": 0, "resource": {Resource object for resource of appointment-see resources API page}, "seats": 1, "sendConfirmationToClient": false, "sendConfirmationToStaff": false, "staff": {Staff object for staff of appointment-see staff API page}, "staffReminderHours": 0, "staffRescheduleCount": 6, "startDate": "2018-07-26", "startTime": 1115, "status": "COMPLETED", "subStatus": "INPROGRESS", "transactionFee": null, "waitlistId": null }] |
Code Block | ||||||||
---|---|---|---|---|---|---|---|---|
| ||||||||
{ "classScheduleId": null, "client": {Client object for client of appointment-see clients API page}, "clientEndDate": "2018-07-26", "clientEndTime": 1330, "clientReminderHours": 0, "clientStartDate": "2018-07-26", "clientStartTime": 1200, "coordinatorStaff": {Staff object for coordinator staff of appointment-see staff API page}, "duration": 90, "endDate": "2018-07-26", "endTime": 1325, "fields": {Scheduler fields object for fields of fields of appointment-see scheduler fields API page}, "invalidDates": false, "location": {Location object for location of appointment-see locations API page}, "locationGroup": {Location group object for location group of appointment-see groups API page}, "note": "", "price": 8, "reason": {Reason object for service of appointment-see services API page}, "reasonGroup": {Reason group object for reason group of appointment-see groups API page}, "remindClientSmsHours": 1, "remindStaffSmsHours": 0, "resource": {Resource object for resource of appointment-see resources API page}, "resourceId": 2556, "sendConfirmationToClient": false, "sendConfirmationToStaff": false, "staff": {Staff object for staff of appointment-see staff API page}, "staffReminderHours": 0, "startDate": "2018-07-26", "status": "OPEN" } |
Code Block | ||||||||
---|---|---|---|---|---|---|---|---|
| ||||||||
{ "additionalStaffIdList": null, "address": null, "appointmentDateTimeClient": "Thursday, Aug 2, 2018 at 8:00 AM FNT", "appointmentDateTimeStaff": "Thursday, Aug 2, 2018 at 8:00 AM FNT", "blockStaffIdList": [], "blockedStaffList": [], "businessId": 43111, "calendarId": 16902080, "cancelReason": null, "cancelUser": null, "changeReason": "", "classScheduleId": null, "client": {Client object for client of appointment-see clients API page}, "clientConfirmedDate": 1532371154462, "clientConfirmed": false, "clientEndDate": "2018-08-02", "clientEndTime": 900, "clientReminderHours": 0, "clientRescheduleCount": 0, "clientStartDate": "2018-08-02", "clientStartTime": 800, "color": "#668CD9", "completedReason": null, "coordinatorStaff": null, "coupon": null, "couponId": null, "createddate": "2018-06-21 14:45:52", "createduser": "JoeSchmo", "customFieldDesc": "", "date": "2018-08-02", "dateCheckedIn": null, "dateCompleted": null, "discount": null, "endDate": "2018-08-02", "endTime": 930, "fields": {Scheduler fields object for fields of fields of appointment-see scheduler fields API page}, "invitationUUId": null, "jobRequisitionId": null, "location": {Location object for location of appointment-see locations API page}, "locationGroup": {Location group object for location group of appointment-see groups API page}, "locationSuperGroup": null, "modifieddate": null, "modifieduser": null, "noPrefSelected": null, "noShowReason": null, "note": "", "packageSoldId": null, "price": null, "reason": {Reason object for service of appointment-see services API page}, "reasonGroup": {Reason group object for reason group of appointment-see groups API page}, "recall": null, "recallDate": null, "recallStatus": null, "recurringAppointmentId": 101096, "remindClientSmsHrs": 2, "remindStaffSmsHours": 4, "resource": {Resource object for resource of appointment-see resources API page}, "seats": 1, "sendConfirmationToClient": false, "sendConfirmationToStaff": false, "staff": {Staff object for staff of appointment-see staff API page}, "staffReminderHours": 3, "staffRescheduleCount": 9, "startDate": "2018-08-02", "startTime": 945, "status": "OPEN", "subStatus": "CONFIRMED", "transactionFee": null, "waitlistId": null } |
Code Block | ||||||||
---|---|---|---|---|---|---|---|---|
| ||||||||
{ "additionalStaffIdList": null, "address": null, "appointmentDateTimeClient": "Thursday, Jul 26, 2018 at 12:00 PM FNT", "appointmentDateTimeStaff": "Thursday, Jul 26, 2018 at 12:00 PM FNT", "blockStaffIdList": [], "blockedStaffList": [], "businessId": 43111, "calendarId": 1726703, "cancelReason": null, "cancelUser": null, "changeReason": "", "classScheduleId": null, "client": {Client object for client of appointment-see clients API page}, "clientConfirmedDate": 1532478709843, "clientConfirmed": false, "clientEndDate": "2018-07-26", "clientEndTime": 1330, "clientReminderHours": 0, "clientRescheduleCount": 0, "clientStartDate": "2018-07-26", "clientStartTime": 1200, "color": null, "completedReason": "", "coordinatorStaff": {Staff object for coordinator staff of appointment-see staff API page}, "coupon": null, "couponId": null, "createddate": "2018-07-24 16:10:52", "createduser": "JoeSchmo", "customFieldDesc": "", "date": "2018-07-26", "dateCheckedIn": 1532525743459, "dateCompleted": 1532526150687, "dateStarted": 1532525579100, "discount": null, "endDate": "2018-07-26", "endTime": 930, "fields": {Scheduler fields object for fields of fields of appointment-see scheduler fields API page}, "invitationUUId": null, "jobRequisitionId": null, "location": {Location object for location of appointment-see locations API page}, "locationGroup": {Location group object for location group of appointment-see groups API page}, "locationSuperGroup": null, "modifieddate": null, "modifieduser": null, "noPrefSelected": null, "noShowReason": null, "note": "", "packageSoldId": null, "price": null, "reason": {Reason object for service of appointment-see services API page}, "reasonGroup": {Reason group object for reason group of appointment-see groups API page}, "recall": null, "recallDate": null, "recallStatus": null, "recurringAppointmentId": 101096, "remindClientSmsHrs": 2, "remindStaffSmsHours": 4, "resource": {Resource object for resource of appointment-see resources API page}, "seats": 1, "sendConfirmationToClient": false, "sendConfirmationToStaff": false, "staff": {Staff object for staff of appointment-see staff API page}, "staffReminderHours": 3, "staffRescheduleCount": 9, "startDate": "2018-08-02", "startTime": 945, "status": "OPEN", "subStatus": "CONFIRMED", "transactionFee": null, "waitlistId": null } |
To add an appointment to the TimeTap database, you'll need to POST a filled out Appointment JSON object to the "/appointments" endpoint appended to one of the URI prefixes listed on the Introduction page.
A general outline of the steps goes as follows:
- Model the Appointment JSON object in your chosen language/platform
- Fill in the required values (listed below)
- Convert model object to JSON format
- Send filled-in Appointment JSON object via POST request to "/appointments" endpoint
A successful POST will receive a response Appointment JSON object mirroring the object you posted. An unsuccessful POST will receive standard HTML error codes.
For more information on adding appointments via the appointments API, see our Webhooks guide.
Please note: for date and time properties, you do not need to do time zone conversion between the client and the staff. Pass the dates and times as you want them set in the staff's time zone and the backend will take care of converting them for the client's timezone in the messages that are sent to the client
Properties/Objects
In the process of saving the appointment you can make a call to
GET schedulerFieldList/reason/{reasonId}
passing the id of the selected reason. The returned array will have a list of all fields that are compatible with the reason selected in the booking process. If you loop through those fields, any field objects whose "mode" property is set to "APPT" (meaning appointment fields) and not assigned to "CLIENT" can be passed into this fields array property as the appointment's custom fields. The objects that fill the array need to have the schedulerPreferenceFieldDefnId property filled in, the value filled in, as well as the businessId
This is the start time of the appointment for the client. Should have military time format
Formatting examples:
- an appointment that starts at 12:15am should be passed as 15
- an appointment that starts at 11:30am should be passed as 1130
- an appointment that starts at 2:45pm should be passed as 1445 and so on
This is the start time of the appointment for the staff. Should be formatted the same as the clientStartTime defined above. Generally this is calculated based on the bufferBefore property set on the selected service/reason. So if an appointment is set to start for the client at 2:00pm but the selected service has a 15 minute bufferBefore value set then the startTime should get set as 1345 (1:45pm)
Please note: You can create an appointment by passing the appointment object with this value set to null. If you do this, the backend will automatically set the property based off the selected reason's bufferBefore value. If the bufferBefore value is null, then the startTime will be set to the same value as the clientStartTime
This is the end time of the appointment for the staff. Should be formatted the same as the clientStartTime defined above. Generally this is calculated based on the bufferAfter property set on the selected service/reason. So if an appointment is set to end for the client at 2:00pm but the selected service has a 15 minute bufferAfter value set then the endTime should get set as 1415 (2:15pm)
Please note: You can create an appointment by passing the appointment object with this value set to null. If you do this, the backend will automatically set the property based off the selected reason's bufferAfter value. If the bufferAfter value is null, then the endTime will be set to the same value as the clientEndTime.
This is the number of hours before the appointment that you want the reminder email to be sent to the client. If you do not want to send an email reminder to the client, set the value to 0. Otherwise, set it to the hour value.
Formatting examples
- If you want the email to go out 12 hours before the start time of the appointment, set the value to 12
- If you want the email to go out 1 day before the start time of the appointment, set the value to 24 (1 day = 24 hours)
- If you want the email to go out 1.5 days before the start time of the appointment, set the value to 36
Accepted values:
- OPEN
- PENDING_CONFIRMATION (if need to get staff confirmation that they can take the appointment before it is set to OPEN)
If you have added resources to your account to use, you can make a call while creating the appointment to
GET resource/location/{locationId}/reason/{reasonId}
Where you pass the locationId of the selected location from the location object and the reasonId of the selected reason from the reason object. This is mostly for service based appointments because class based appointments will have the resource tied to the class session already.
You'll receive a list of resources associated with the location and reason as a return from that GET call and if you want to tie one to the appointment you can set the resource property of the appointment to that selected resource. Make sure to include at least the resourceId in the passed object.
To check whether the selected resource is available during the date and time that you are trying to put it in for, make a call to
GET resource/{resourceId}/isBusy/{apptDate}/{startTime}/{endTime}
Pass the resourceId of the selected resource, the date of the appointment (formatted as YYYY-MM-DD), the start time of the appointment (either the clientStartTime or startTime, whichever is earlier) and the end time of the appointment (either the clientEndTime or the endTime, whichever is later). That will return false if the resource is available and true if the resource is busy (meaning it is already in use for another appointment or a class session).
Property name | Type | Description |
---|---|---|
additionalStaffIdListbusinessId | array | Displays staffIds for any additional staff members you add to the appointment so they cannot otherwise be booked for this time slot. |
appointmentDateTimeClient | string | Displays the date and time of the appointment as the client sees them. |
address | string | Displays the address entered during appointment creation f appointment is set to a location of locationType VARIABLE. |
appointmentDateTimeStaff | string | Displays the date and time of the appointment as the staff sees them. Can be different from client's view if staff has time blocked off between appointments or if staff is in a different timezone than client. |
blockStaffIdList | array | Displays staffIds for any additional staff members you have added so they cannot be otherwise booked for this time slot. Whatever IDs are added to the additionalStaffIdList are automatically added to the blockStaffIdList. The blockStaffIdList is used to automatically block off staff across child accounts in our enterprise set up model. |
blockedStaffList | array | Displays full staff objects for any additional staff members you have added in the blockStaffIdList or additionalStaffIdList. |
businessId | integer | Provides unique numerical ID for the business that offers specified appointment. (Required) |
calendarId | integer | Provides unique numerical ID of specified appointment. (Required) |
cancelReason | string | Displays any reason given for cancelling specified appointment. |
cancelUser | string | Displays as username of staff who cancelled specified appointment or as "WebClient" if client cancelled their own appointment. If appointment is marked as COMPLETED, username of the staff person who marked the appointment as completed displays here. |
changeReason | string | Displays any reason given for changing specified appointment. |
classScheduleId | integer | If specified appointment is an instance of a class schedule, this field will contain the unique numerical ID for that class schedule. |
client | object | Displays the object of client who is connected to specified appointment. |
clientConfirmDate | integer | Displays the date in milliseconds elapsed since January 1 1970 UTC format that client was marked as confirmed for appointment. |
clientConfirmed | boolean | Flag for whether or not the client has confirmed the appointment. This can be done by checking the checkbox on the appointment profile, marking the status as confirmed, or the client clicking the confirm button on the reminder email. |
clientEndDate | string | Displays as date specified appointment is set to end without buffer displayed as YYYY-MM-DD. |
clientEndTime | integer | Displays as time specified appointment is set to end without buffer displayed in military format. |
clientReminderHours | integer | Displays the number of hours before the appointment that an email reminder will be sent to the client. |
clientRescheduleCount | integer | Displays the number of times client has rescheduled specified appointment. |
clientStartDate | string | Displays as date specified appointment is set to begin without buffer displayed as YYYY-MM-DD. |
clientStartTime | integer | Displays as time specified appointment is set to begin without buffer displayed in military format. |
color | string | Displays any color chosen to override specified appointment on the backoffice calendar. |
completedReason | string | Displays any note the staff may have entered while marking the appointment as completed. Can be injected into completed email template sent to client with tag %COMPLETED_NOTE%. |
coordinatorStaff | object | Displays staff object for the staff member that was the coordinator staff for this appointment. The coordinator staff's schedule is not blocked. |
coupon | object | If client enters a coupon while booking through the scheduler, the object of the coupon they entered will display here. |
couponId | integer | Provides unique numeric ID that is stored on the coupon object. |
createddate | string | Displays as date specified appointment was created in milliseconds elapsed since January 1, 1970 00:00:00 UTC form. (Required) |
createduser | string | Displays as username of the user who created specified appointment. If client booked appointment from scheduler would display as "WebClient". (Required) |
customFieldDesc | string | Displays the label and value properties of any scheduler preference field objects that have the mode property set to APPT so that users can inject these into email templates with 1 centralized tag which is %CUSTOM_FIELDS%. |
date | string | Provides string representation of the date specified appointment is taking place displayed as YYYY-MM-DD. If using startDate, endDate, clientStartDate, and clientEndDate are not filled for some reason, this is used for scheduling purposes. (Required) |
dateCheckedIn | integer | Displays as date the client checked in to specified appointment. |
dateCompleted | integer | Displays as date specified appointment was completed. |
dateStarted | integer | Displays as date specified appointment was marked as substatus of INPROGRESS. |
discount | integer | If coupon was applied, this displays as the total dollar value that was taken off the price of the service/class booked for. |
endDate | string | Provides the date that specified appointment ends with buffer time alloted displayed as YYYY-MM-DD. (Required) |
endTime | integer | Provides the end time of the appointment accounting for any buffer on the reason displayed in military format. (Required) |
fields | array | Displays an array of any custom field objects that were assigned to the appointment. For more information, please see the schedulerFieldList API page. |
invitationUUId | string | If you invite a client to book with you from the clients menu (selecting a client and clicking to send email) and in the invitation template that you send out you have the tag %BOOK_INVITATION_URL%, then when the client clicks the link after receiving the invitation they will be directed to a scheduling landing page with the invitationUUId attached at the end of it. If the client books, we set the invitationUUId from the invitation sent out to the appointment object. This allows us to map the lifecycle of an invitation campaign as shown under Messaging > Monitor Campaigns so we can know if an invitation that was sent out resulted in a booked appointment |
jobRequisitionId | integer | Provides unique numeric ID of specified appointment's job requisition number. |
location | object | Displays the location object assigned to specified appointment. (Required) |
locationGroup | object | If you assign the appointment to a specific location group, then this would be the object of that location group. |
locationSuperGroup | object | If you assign the location group of specified appointment to a specific location super group, then this would be the object of that location super group. |
modifieddate | integer | Displays as date specified appointment was last modified in milliseconds elapsed since January 1, 1970 00:00:00 UTC form. |
modifieduser | string | Displays as username of user who last modified specified appointment. If client was last to modify then it would be displayed as "WebClient". |
noPrefSelected | boolean | Displays if no preference has been selected for specified appointment. |
noShowReason | string | Displays as reason given for a no show. |
note | string | Displays as note added to appointment profile in default comments field. |
packageSoldId | integer | Displays as unique numerical ID of package used to redeem appointment against. |
price | string | Displays as price set for specified appointment after adjusting for any coupons that may have been used. |
reason | object | Displays the reason object connected to specified appointment. |
reasonGroup | object | If you assign the reason of specified appointment to a specific reason group, then this would be the object of that reason group. |
recall | object | If a recall campaign has been set up that impacts this appointment, then the object of the recall campaign that the appointment is a part of shows here. |
recallDate | integer | Displays as goal date for appointment's recall appointment as determined by the recall object that the appointment is set to. Shows as milliseconds elapsed since January 1, 1970 00:00:00 UTC form. |
recallStatus | string | Displays as status of recall of specified appointment if applicable. |
recurringAppointmentId | integer | If appointment is part of a repeating appointment series, then this provides unique numerical ID of repeating appointment series. |
remindClientSmsHours | integer | Displays the number of hours before the appointment that an SMS reminder will be sent to the client. |
remindStaffSmsHours | integer | Displays the number of hours before the appointment that an SMS reminder will be sent to the staff. |
resource | object | Displays any resource object connected to specified appointment. |
seats | integer | Provides number of seats for specified appointment. Only applicable for reasonType of CLASS where if this number is greater than 1 it would take up as many attendees slots as this number indicates in the class schedule. |
sendConfirmationToClient | boolean | Flag for whether or not a confirmation email should be sent to client on appointment POST/PUT. If set to TRUE then when appointment is created the confirmation will send out and when appointment is update the appointment changed email will send. |
sendConfirmationToStaff | boolean | Flag for whether or not a confirmation/update email should be sent to staff on appointment POST/PUT. If set to TRUE then when appointment is created the confirmation will send out and when appointment is update the appointment changed email will send out |
staff | object | Displays the staff object for staff member connected to specified appointment. (Required) |
staffReminderHours | integer | Displays the number of hours before the appointment that an email reminder will be sent to the staff. |
staffRescheduleCount | integer | Displays the number of times staf has rescheduled specified appointment. |
startDate | string | Provides the date specified appointment starts with buffer displayed as YYYY-MM-DD. (Required) |
startTime | integer | Displays the time specified appointment starts displayed in military format. (Required) |
status | string | Displays the status of specified appointment. Possible values include PENDING, OPEN, NO_SHOW, COMPLETED, CANCELLED, DELETED. |
subStatus | string | Displays the substatus of specified appointment. Substatuses can be customized on Business and Enterprise level accounts, but default substatus values include: PENDING, PENDING_CONFIRMATION, PENDING_WAITLIST, OPEN, CONFIRMED, CHECKEDIN, INPROGRESS, COMPLETED, NO_SHOW, CANCELLED, DELETED, |
transactionFee | string | Displays as fee added to transaction added for specified appointment. |
waitListId | integer | If appointment was created by claiming a seat from a waitlist registration, this provides the unique numerical id of the waitlist registration the appointment was claimed from. |
integer | Provides unique numeric ID of the business offering availability. (Required) | |
color | string | |
createdDate | string | |
createdUser | string | |
description | string | |
endDate | string | |
endTime | integer | |
modifiedDate | string | |
modifiedUser | string | |
reason | object | |
recurringAppointmentId | integer | |
staff | object | |
startDate | string | |
startTime | integer | |
status | string | |
timeOffId | integer |