v7.3.0

Listening for events

Bryntums widgets and classes trigger events to notify you of changes. Listening for these events is a crucial part of writing an application that uses Bryntum Calendar. You have plenty of options for doing this in a way that suites your application, as detailed below.

Where to find information on events

In the API docs events are listed at the bottom of each class documentation page, see for example Calendar events. You can get there quickly by clicking on the red "e" icon found at the top of each class (if it is grayed out the class triggers no events). Please note that you can click on an event to expand its description and reveal any parameters it is triggered with.

How to listen for events

To catch triggered events you have to add a listener to the object that triggers them. If you for example want to know when a user clicks on event in the Calendar, then you should add a listener (listen) for the eventClick event available on Calendar. This can be achieved in multiple ways:

Setting up listeners during construction

You can add listeners when constructing a new instance of a class by specifying the listeners config:

const calendar = new Calendar({
    // other configs...

    listeners : {
        eventclick : myEventClickFn
    }
});

Because of how JavaScripts this-object works you might want to specify what you expect as this in your listener function:

const calendar = new Calendar({
    listeners : {
        eventClick : () => {
            console.log('clicked');
        }
    }
});

When specifying a thisObj it is also possible to resolve the function to call by specifying its name as a string:

const calendar = new Calendar({
    listeners : {
        eventclick : 'myEventClickFn',
        thisObj    : this
    }
});

It is possible to add multiple listeners in one go:

const calendar = new Calendar({
    listeners : {
        eventclick    : 'myEventClickFn',
        eventdblclick : 'myEventDblClickFn',
        thisObj       : this
    }
});

Thanks to ES6 syntax for member functions you can also specify the function inline in the config in a nice way:

const calendar = new Calendar({
    listeners : {
        eventclick() {

        }
    }
});

Adding listeners after construction

You can add listeners to an existing instance using addListener or on. Both work the same way, on is a bit shorter to type:

calendar.on('eventclick', () => console.log('click'));
calendar.addListener('eventDblClick', () => console.log('dblclick'));

If you need to specify a thisObj it is possible as the third argument:

calendar.on('eventclick', this.onEventClick, this);

You can also pass multiple listeners as a config object in the same way as when specifying them during construction:

calendar.on({
    eventclick    : 'onEventClick',
    eventdblclick : 'onEventDblClick',
    thisObj       : this
});

Using "on" functions

Bryntum Calendar also supports directly calling functions that match the "on[EventName]" pattern. We recommend using the approaches above, but this way of defining listeners can be convenient for small widgets:

const calendar = new Calendar({
    onEventClick() {
        console.log('Event click');
    }
});

You can also assign on the fly:

calendar.onEventClick = () => console.log('Event click');

The listener functions

All listener functions are called with a single argument when an event is triggered. This argument is an object that has at least one property source, which is the object that triggered the event. Most events populate the object with more information, see API docs to find out what. For example eventclick has the following:

calendar.on({
    eventclick(event) {
        // The eventclick event has the properties for the event
        // Check API docs for available properties for a certain event 
    }
});

Additional options

The listener config object has some useful properties such as once and prio:

  • once allows you to specify a listener that will unregister itself after the first call. See addListener for more details.
calendar.on({
    eventclick() {
        // Only called on the first click
    },
    // Call once and then unregister
    once : true
});
  • prio lets you specify a listeners priority, which is used to determine the order in which listeners are called. See addListener for more details.
store.on({
    load() {
        // Called before normal load listeners
    },
    // Higher prio is called prior to lower
    prio : 100
});

It is possible to catch all events triggered by an object using a catchAll function:

calendar.on({
    catchAll(event) {
        // Any event triggered on Calendar will pass through here
    }
});

Preventing events

By returning false from a listener for an event documented as preventable the action that would otherwise be executed after the event is prevented. These events names are usually prefixed with before.

Sample code:

onBeforeEventEdit(event) {
    if (someCondition) {
       return false;
    } 
}

You can see more such events by typing onBefore in the search bar.

Frameworks integration

Check Angular, React and Vue framework integration guides for the details.

Contents