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 Scheduler Pro. 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 Scheduler Pro 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 an event bar in the scheduler, then you should add a listener (listen) for the eventclick event on SchedulerPro. 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 schedulerPro = new SchedulerPro({
// other configs...
listeners : {
eventclick : myCellClickFn
}
});
Because of how JavaScripts this-object works you might want to specify what you expect as this in your listener function:
const schedulerPro = new SchedulerPro({
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 schedulerPro = new SchedulerPro({
listeners : {
eventclick : 'myEventClickFn',
thisObj : this
}
});
It is possible to add multiple listeners in one go:
const schedulerPro = new SchedulerPro({
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 schedulerPro = new SchedulerPro({
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:
schedulerPro.on('eventclick', () => console.log('click'));
schedulerPro.addListener('cellDblClick', () => console.log('dblclick'));
If you need to specify a thisObj it is possible as the third argument:
schedulerPro.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:
schedulerPro.on({
click : 'onClick',
dblclick : 'onDblClick',
thisObj : this
});
Using "on" functions
Bryntum Scheduler Pro also supports directly calling functions that match the on[EventName] pattern. We recommend using the approaches mentioned above, but this way of defining listeners can be convenient for small widgets:
const button = new Button({
onClick() {
console.log('click');
}
});
You can also assign on the fly:
schedulerPro.onEventClick = () => console.log('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:
schedulerPro.on({
eventclick(event) {
// The eventclick event has the following properties:
// source - Triggering object
// eventRecord - Clicked events record
// event - The browser click event
}
});
This single argument approach is a great fit for ES6 destructuring, allowing syntax such as this:
schedulerPro.on({
eventclick({ eventRecord }) {
// Only interested in the record, leave the others out
}
});
Additional options
The listener config object has some useful properties such as once and prio:
onceallows you to specify a listener that will unregister itself after the first call. See addListener for more details.
schedulerPro.on({
eventclick() {
// Only called on the first click
},
// Call once and then unregister
once : true
});
priolets you specify a listeners priority, which is used to determine the order in which listeners are called. See addListener for more details.
resourceStore.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:
schedulerPro.on({
catchAll(event) {
// Any event triggered on scheduler 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.