Contact Us

If you still have questions or prefer to get help directly from an agent, please submit a request.
We’ll get back to you as soon as possible.

Please fill out the contact form below and we will reply as soon as possible.

  • Sirvoy home
  • Login
  • Contact
English (US)
US English (US)
FR French
DE German
ES Spanish
NL Dutch
SE Swedish
FI Finnish
NO Norwegian
DA Danish
  • Home
  • Booking Engines
  • Tracking

Using a Custom JavaScript Callback to Track Events in the Booking Engine and the Review Booking Form

Written by johana

Updated at December 22nd, 2024

Contact Us

If you still have questions or prefer to get help directly from an agent, please submit a request.
We’ll get back to you as soon as possible.

Please fill out the contact form below and we will reply as soon as possible.

  • Getting Started
    Setup Guides Import Bookings
  • About Sirvoy
    General Technical Security & Backups
  • Rooms & Room Types
    Rooms & Room Types Categorizing Room Types Offer Add-Ons or Extras
  • Bookings
    Modify Booking View Bookings Message Templates & Automated Messaging Communication Scheduling Housekeeping and Tasks
  • Rates & Restrictions
    Rates & Discounts Restrictions Promotion & Coupon Codes
  • Booking Engines
    Website Builder Installing on Your Website Adjusting the Booking Engine Design & CSS Input Fields Guest portal Tracking
  • Channel Manager
    Setting Up New Channels Mapping Your Room Types General Rates & Availability Updates Overbookings
  • Financials
    Setting Up a Payment Solution Managing Payments Invoices & Receipts Accounting Taxes & Surcharges
  • My Account
    Customize Your Account Subscription Statistics Export & API
+ More

Table of Contents

Before You Start Tracking Events in the Booking Engine Adding a JavaScript Callback Events Fired in the Booking Engine Flow: Tracking Events in the Review Booking Form Adding a JavaScript Callback Events Fired in the Review Booking Form Flow: Before You Go

 

Adding a custom JavaScript callback to a booking engine embedded on your website enables you to track events.

Note: This requires some basic knowledge of JavaScript callbacks. Consult your web developer if you need any assistance.

 Before You Start

  • Add a custom script to your webpage.

Tracking Events in the Booking Engine

Adding a JavaScript Callback

  1. In Sirvoy, go to Settings -> Booking engines.
  2. Click the three dots adjacent to the booking engine you want.
  3. In the drop-down list, click “How to Install.”
  4. Click “Advanced.”
  5. In “JavaScript callback function”, fill in the name of the function to call.
  6. Copy the code from “Copy this code.”
  7. Add the code to your webpage to install the booking engine.

Your function is now called for each step the guest takes in the booking engine.

Events Fired in the Booking Engine Flow:

  • page_code_required – Fires when the form to enter a coupon code is displayed (if that is required for your booking engine).
  • page_search – Fires when the search form is displayed. Extra data: “user_data” (arrivalDate, departureDate, totalAdults, category)
  • page_results – Fires when the search results page is displayed. Extra data: “user_data” (same as page_search)
  • page_details – Fires when the guest details input form is displayed. Extra data: “user_data” (same as page_search)
  • page_pending – Fires before the confirmation step, after returning from a payment provider or, if you don’t use a payment provider, after the page_details event. Extra data: “booking” (JSON representation of the booking)
  • page_confirmation – Fires on the confirmation step, after returning from a payment provider or, if you don’t use a payment provider, after the page_details event. Extra data: “booking” (JSON representation of the booking)
  • booking_completed – Fires when a booking is completed on the confirmation page. Extra data: “booking” (JSON representation of the booking)
Tip: After the last event in the booking engine flow has completed, all booking details will be available under the key “booking” in the JSON representation of the booking.
Note: The event “booking_completed” is guaranteed to fire only once per booking. Other events, such as “page_confirmation” and “page_pending” may fire multiple times if the guest is making optional payments. Every time the guest is redirected back from the payment provider, these events will fire again.
Note: When a custom image gallery is used on the search results page, the events “gallery_init” and “gallery_open” will also fire.

Tracking Events in the Review Booking Form

Adding a JavaScript Callback

  1. In Sirvoy, go to Settings -> Guest portal -> Install, and click “Advanced.”
  2. Fill in the name of the function you want to call in the field “JavaScript callback function.”
  3. Copy the code from “Copy this code.”
  4. Add the code to your webpage to install the review booking form.

Your function is now called for each step the guest takes in the review booking form.

Events Fired in the Review Booking Form Flow:

  • page_review_search – Fires when the review search form is displayed.
  • page_review_booking – Fires when the review booking page is displayed. Extra data: “booking” (JSON representation of the booking)
  • page_review_pending – Fires after an optional payment is made through the review form. After this event the page displays the review booking form again and the “page_review_booking” event is fired again. Extra data: “booking” (JSON representation of the booking)
Tip: All details of an existing booking are available under the key “booking” in the JSON representation of the booking.

Before You Go

Explore the available events and their associated data with the code below by printing out all the events in the web developer console:
 


      <script>
         function customEventHandler(data) {
            console.log("Got Sirvoy custom JS event: " + data.event);
            console.dir(data);
        }
      </script>
event tracking javascript callback

Was this article helpful?

Yes
No
Spot something odd? Let us know.

Related Articles

  • Controlling the Triggering of Third-party Tracking in the Booking Engine and the Review Booking Form
  • How to Set Up Google Ads Conversions and Tag Manager
  • Setting up Google Analytics Event Tracking for the Booking Engine and the Review Booking Form

Need a hand with Sirvoy?

You're in the right place.

  • Sirvoy
  • Login
  • Contact

    ©2025 Sirvoy . All Rights reserved.

    Expand