Theme Events

This section is intended for experienced developers who wish to add custom functionalities to the theme based on merchant requirements.

Important: We are not responsible for any issues that may arise from modifying the JavaScript files. Proceed with caution when making changes, as we do not provide support for custom modifications.

1. Events that you can listen and run custom functionalities based on your requirements


on:QuantityChange

The on:QuantityChange event is dispatched whenever the quantity input field's value changes. The event provides the new quantity through the quantity property.

How to Use the Event:

To use the on:QuantityChange event, you can listen for the event and execute your custom logic. Here’s an example of how to do this:

document.addEventListener('on:QuantityChange', function(event) {
    const quantity = event.detail.quantity;
    
    // Custom functionality here
    console.log('Quantity changed to:', quantity);
    

});

✅ action:showDrawer

The action:showDrawer event is dispatched to indicate that a specific drawer, identified by drawerType , should be shown. In this example, the drawer type is set to cart-drawer .

How to Use the Event:

To use the action:showDrawer event, you can listen for the event and implement custom functionality based on the drawer type. Here’s an example:

document.addEventListener('action:showDrawer', function(event) {
    const drawerType = event.detail.drawerType;

    // Custom functionality here
    console.log('Drawer type:', drawerType);
    
    // Example: Customize the content based on the drawer type
    if (drawerType === 'cart-drawer') {
        // Custom logic for the cart drawer
       // Add custom content or manipulate the drawer as needed
    }
});

✅ action:hideDrawer

The action:hideDrawer event is dispatched to signal that a specific drawer, identified by drawerType , should be hidden. In this example, the drawer type is set to cart-drawer .

How to Use the Event:

To use the action:hideDrawer event, you can listen for the event and implement custom functionality based on the drawer type. Here’s an example:

document.addEventListener('action:hideDrawer', function(event) {
    const drawerType = event.detail.drawerType;

    // Custom functionality here
    console.log('Hiding drawer of type:', drawerType);
    
    // Example: Perform actions when the pick-up availability drawer is hidden
    if (drawerType === 'cart-drawer) {
        // Custom logic for when the cart drawer is hidden
   // Additional actions, such as resetting UI elements or stopping certain processes
    }
});

2. Events that you can fire and theme will run functionalities for you


action:cart:updateCartandShowCart


This event is used to show cart drawer based on the previous call you make to to add any new item to cart. You can dispatch this event to refresh the cart if the cart drawer is already open and perform additional actions if needed.


How to Use the Event:

document.dispatchEvent(new CustomEvent(_EVENT_HELPER.updateAndShowCart, { detail: {}}));
Did this answer your question? Thanks for the feedback There was a problem submitting your feedback. Please try again later.

Still need help? Contact Us Contact Us