Actions

You can listen to an action that occurs in embedded cal link as follows. You can think of them as DOM events. We are avoiding the term “events” to not confuse it with Cal Events.

<script>
  Cal("on", {
    action: "ANY_ACTION_NAME",
    callback: (e)=>{
      // `data` is properties for the event.
      // `type` is the name of the action(You can also call it type of the action.) This would be same as "ANY_ACTION_NAME" except when ANY_ACTION_NAME="*" which listens to all the events.
      // `namespace` tells you the Cal namespace for which the event is fired/
      const {data, type, namespace} = e.detail;
    }
  })
</script>

Following are the list of supported actions.

ActionDescriptionProperties
eventTypeSelectedWhen user chooses an event-type from the listing.eventType: object // Event Type that has been selected
bookingSuccessfulWhen the booking is successfully done. It might not be confirmed.confirmed: boolean // Whether confirmation from organizer is pending or not
eventType: object // Event Type that has been booked
date: string // Date of Event
duration: number // Duration of booked Event
organizer: object // Organizer details like name, timezone, email
linkReadyTells that the link is ready to be shown now.None
linkFailedFired if link fails to load.code: number // Error Code
msg: string // Human Readable message
data: object // More details to debug the error
__iframeReadyIt is fired when the embedded iframe is ready to communicate with parent snippet. This is mostly for internal use by Embed Snippet.None
__windowLoadCompleteTells that window load for iframe is complete.None
__dimensionChangedTells that dimensions of the content inside the iframe changed.iframeWidth: number
iframeHeight: number
Actions that start with __ are internal.

To get more details on how Embed actually works, you can refer to this Embed Flowchart.