- booking URL to manage where people land after booking after one of your users.
- reschedule URL to your page for rescheduling a booking.
- cancel URL to your page for cancelling a booking.
Booking URL
After a person books one of your users, that person should see the successful booking.
- Pass my-app.com/bookingsas the redirectURI.
- In your app, create my-app.com/bookings/[bookingUid]page where bookingUid will become path parameter.
- When a booking occurs, booker will be re-directed to the redirectURI with booking UID as the bookingUid parameter aka my-app.com/bookings/[bookingUid].
- In the my-app.com/bookings/[bookingUid] route create a page that imports useBookinghook, then extract bookingUid from URL parameter, and uses the hook to display booking information. BecauseuseBookinghook can return individual booking or an array of recurring bookings, you need to handle single booking and array of bookings cases separately:
Reschedule URL
- Pass my-app.com/bookings/rescheduleas the redirectURI.
- When “Reschedule” is clicked, user will be re-directed to the redirectURI with rescheduled and eventTypeSlug query parameters my-app.com/reschedule?rescheduleUid=buiaE8jHmNAxLrqitahCeL&eventTypeSlug=thirty-minutes
- In the my-app.com/reschedule route create a page that extracts rescheduleUidandeventTypeSlugfrom the query parameters and passes the to theBookeratom:
Cancel URL
- Pass my-app.com/bookings/cancelas the cancelURI.
- In your app, create my-app.com/bookings/cancel/[bookingUid]page where bookingUid will become path parameter.
- In the page of my-app.com/cancel/[bookingUid] import useCancelBooking from atoms and get access to the cancel mutation import from “@calcom/atoms”;
- Create a cancel button that invokes mutation returned by the “useCancelBooking”. You have to pass id of the booking which you can get by fetching booking using “useBooking” hook by uid from the query params. Provide a suitable “cancellationReason”.
Because useBookinghook can return individual booking or an array of recurring bookings, you need to handle single booking and array of bookings cases separately: