This document describes any breaking changes in the Peaks.js API and provides advice on how to migrate your code to the updated API.
The peaks.ready
event has been removed in Peaks.js v4.0.0. Instead of using this event, applications must now pass a callback function to Peaks.init()
. This enables error handling, which is only possible using the callback function.
// Before
const peaks = Peaks.init(options);
peaks.on('peaks.ready', function() {
// etc
});
// After
Peaks.init(options, function(err, peaks) {
if (err) {
// Handle errors here.
return;
}
// etc
});
Peaks.js v3.0.0 introduces a number of changes, described in the following sections.
The segment customization options have been moved under a new segmentOptions
object in the call to Peaks.init()
, and some options have been renamed:
// Before
Peaks.init({
// Include other options as needed
segmentStartMarkerColor: '#888',
segmentEndMarkerColor: '#888',
segmentColor: '#800'
}, function(err, peaks) {
// ...
});
// After
Peaks.init({
// Include other options as needed
segmentOptions: {
startMarkerColor: '#888',
endMarkerColor: '#888',
waveformColor: '#800'
}
}, function(err, peaks) {
// ...
});
The following options have also been moved, so you will need to update your code as shown below.
containers
(usezoomview.container
oroverview.container
instead)overviewWaveformColor
(useoverview.waveformColor
instead)overviewHighlightOffset
(useoverview.highlightOffset
instead)overviewHighlightColor
(useoverview.highlightColor
instead)zoomWaveformColor
(usezoomview.waveformColor
instead)
// Before
Peaks.init({
containers: {
zoomview: document.getElementById('zoomview-container'),
overview: document.getElementById('overview-container')
},
zoomWaveformColor: '#00e180',
overviewWaveformColor: '#cccccc',
overviewHighlightOffset: 11,
overviewHighlightColor: '#aaaaaa'
// Include other options as needed
}, function(err, peaks) {
// ...
});
// After
Peaks.init({
zoomview: {
container: document.getElementById('zoomview-container'),
waveformColor: '#00e180'
},
overview: {
container: document.getElementById('overview-container'),
waveformColor: '#cccccc',
highlightOffset: 11,
highlightColor: '#aaaaaa'
}
// Include other options as needed
}, function(err, peaks) {
// ...
});
The randomizeSegmentColor
option has been removed. This option was true
by default in earlier versions. Instead of using this option, set the color
attribute when calling segments.add()
.
The Marker API for creating custom point and segment markers has changed. In earlier versions, updating a point or segment's attributes would cause the corresponding marker to be destroyed and then constructed again. Markers are no longer re-created on update. There is now a new update()
method, which you should use to update a custom point or segment marker when any of its attributes have been updated. The timeUpdated()
method has been removed, as the update()
method provides the same functionality.
// Before
class CustomSegmentMarker {
constructor(options) {
this._options = options;
}
init(group) {
this._group = group;
// Create Konva.js objects to render the marker
this.fitToView();
this.bindEventHandlers();
}
bindEventHandlers() {
// etc
}
fitToView() {
// etc
}
timeUpdated(time) {
this._label.setText(this._options.layer.formatTime(time));
}
}
// After
class CustomSegmentMarker {
constructor(options) {
this._options = options;
}
init(group) {
this._group = group;
// Create Konva.js objects to render the marker.
//
// See demo/custom-markers/custom-point-marker.js
// and demo/custom-markers/custom-segment-marker.js
// for complete examples.
this.fitToView();
this.bindEventHandlers();
}
bindEventHandlers() {
// etc
}
fitToView() {
// etc
}
update(options) {
if (options.startTime !== undefined && this._options.startMarker) {
console.log('Updated segment start marker time', options.startTime);
}
if (options.endTime !== undefined && !this._options.startMarker) {
console.log('Updated segment end marker time', options.endTime);
}
if (options.labelText !== undefined) {
console.log('Updated label text', options.labelText);
}
if (options.editable !== undefined) {
// Show or hide Konva.js objects as needed
}
}
}
These events now receive an event
object:
Before:
peaks.on('points.add', function(points) {
points.forEach(function(point) {
console.log(point);
});
});
peaks.on('segments.remove', function(segments) {
segments.forEach(function(segment) {
console.log(segment);
});
});
After:
peaks.on('points.add', function(event) {
event.points.forEach(function(point) {
console.log(point);
});
});
peaks.on('segments.remove', function(event) {
event.segments.forEach(function(segment) {
console.log(segment);
});
});
Cue events (points.enter
, segments.enter
, segments.exit
) now receive an event
object that contains the point or segment, together with time
, the current playback position.
Before:
peaks.on('segments.enter', function(segment) {
console.log(segment);
});
After:
peaks.on('segments.enter', function(event) {
console.log(event.segment);
console.log(event.time);
});
The zoom.update
event now receives an event
object:
Before:
peaks.on('zoom.update', function(currentZoom, previousZoom) {
console.log(currentZoom, previousZoom);
});
After:
peaks.on('zoom.update', function(event) {
console.log(event.currentZoom);
console.log(event.previousZoom);
});
Before v3.0.0, Peaks.js would listen for window resize
events and update the waveform views if the container elements changed size.
This feature has been removed, because the container elements can change size for other reasons than resizing the window.
We recommend that you use a ResizeObserver. Please refer to the fitToContainer()
documentation for example code.
Peaks.js v2.0.0 changes how custom player objects should be initialized. To allow for initialization that may involve asynchronous operations, your custom player object's init
function must now return a Promise
that resolves when the player has been initialized.
If your application does not use a custom player object, i.e., the player
option when calling Peaks.init()
, then updating to v2.0.0 does not require you to make any changes.
class CustomPlayer {
init(eventEmitter) {
this.eventEmitter = eventEmitter;
this.state = 'paused';
this.interval = null;
// Initialize the external player
this.externalPlayer = new MediaPlayer();
// Returning a promise is now required
return Promise.resolve();
},
// ... other player methods, as shown in customizing.md
};
const options = {
// Add other options, as needed.
player: player
};
Peaks.init(options, function(err, instance) {
// Use the Peaks.js instance here
});
Peaks.js v1.0.0 changes a number of event handlers to also expose the MouseEvent or PointerEvent, so that applications can, for example, check the keyboard state during click
and other events. This is a breaking API change and so you will need to update your code, as shown below.
overview.click
,overview.dblclick
,zoomview.click
,zoomview.dblclick
// Before
peaks.on('zoomview.click', function(time) {
console.log(time);
});
// After
peaks.on('zoomview.click', function(event) {
console.log(event.time);
console.log(event.evt.ctrlKey);
console.log(event.evt.shiftKey);
});
points.dragstart
,points.dragmove
,points.dragend
points.mouseenter
,points.mouseleave
points.click
,points.dblclick
// Before
peaks.on('points.click', function(point) {
console.log(point);
});
// After
peaks.on('points.click', function(event) {
console.log(event.point);
console.log(event.evt.ctrlKey);
console.log(event.evt.shiftKey);
});
segments.dragstart
,segments.dragged
,segments.dragend
// Before
peaks.on('segments.dragged', function(segment, startMarker) {
console.log(segment);
console.log(startMarker);
});
// After
peaks.on('segments.dragged', function(event) {
console.log(event.segment);
console.log(event.startMarker);
console.log(event.evt.ctrlKey);
console.log(event.evt.shiftKey);
});
segments.mouseenter
,segments.mouseleave
segments.click
,segments.dblclick
// Before
peaks.on('segments.click', function(segment) {
console.log(segment);
});
// After
peaks.on('segments.click', function(event) {
console.log(event.segment);
console.log(event.evt.ctrlKey);
console.log(event.evt.shiftKey);
});