2015-02-16 16:47:04 +01:00
|
|
|
var H5P = H5P || {};
|
|
|
|
|
|
|
|
// Create object where external code may register and listen for H5P Events
|
2015-02-17 10:57:21 +01:00
|
|
|
H5P.externalDispatcher = new H5P.EventDispatcher();
|
2015-02-16 16:47:04 +01:00
|
|
|
|
2015-03-22 20:38:33 +01:00
|
|
|
if (H5P.isFramed && H5P.externalEmbed !== true) {
|
2015-04-07 19:33:21 +02:00
|
|
|
H5P.externalDispatcher.on('*', window.top.H5P.externalDispatcher.trigger);
|
2015-02-18 10:59:47 +01:00
|
|
|
}
|
|
|
|
|
2015-02-16 16:47:04 +01:00
|
|
|
// EventDispatcher extensions
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Helper function for triggering xAPI added to the EventDispatcher
|
2015-02-20 10:26:33 +01:00
|
|
|
*
|
2015-02-16 16:47:04 +01:00
|
|
|
* @param {string} verb - the short id of the verb we want to trigger
|
|
|
|
* @param {oject} extra - extra properties for the xAPI statement
|
|
|
|
*/
|
|
|
|
H5P.EventDispatcher.prototype.triggerXAPI = function(verb, extra) {
|
|
|
|
this.trigger(this.createXAPIEventTemplate(verb, extra));
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Helper function to create event templates added to the EventDispatcher
|
2015-02-20 10:26:33 +01:00
|
|
|
*
|
2015-02-16 16:47:04 +01:00
|
|
|
* Will in the future be used to add representations of the questions to the
|
|
|
|
* statements.
|
2015-02-20 10:26:33 +01:00
|
|
|
*
|
2015-02-16 16:47:04 +01:00
|
|
|
* @param {string} verb - verb id in short form
|
|
|
|
* @param {object} extra - Extra values to be added to the statement
|
|
|
|
* @returns {Function} - XAPIEvent object
|
|
|
|
*/
|
|
|
|
H5P.EventDispatcher.prototype.createXAPIEventTemplate = function(verb, extra) {
|
|
|
|
var event = new H5P.XAPIEvent();
|
|
|
|
|
|
|
|
event.setActor();
|
|
|
|
event.setVerb(verb);
|
|
|
|
if (extra !== undefined) {
|
|
|
|
for (var i in extra) {
|
|
|
|
event.data.statement[i] = extra[i];
|
|
|
|
}
|
|
|
|
}
|
2015-03-22 12:43:07 +01:00
|
|
|
if (!('object' in event.data.statement)) {
|
2015-02-16 16:47:04 +01:00
|
|
|
event.setObject(this);
|
2015-03-22 12:43:07 +01:00
|
|
|
}
|
|
|
|
if (!('context' in event.data.statement)) {
|
|
|
|
event.setContext(this);
|
2015-02-16 16:47:04 +01:00
|
|
|
}
|
|
|
|
return event;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Helper function to create xAPI completed events
|
|
|
|
*
|
|
|
|
* @param {int} score - will be set as the 'raw' value of the score object
|
|
|
|
* @param {int} maxScore - will be set as the "max" value of the score object
|
|
|
|
*/
|
|
|
|
H5P.EventDispatcher.prototype.triggerXAPICompleted = function(score, maxScore) {
|
|
|
|
var event = this.createXAPIEventTemplate('completed');
|
|
|
|
event.setScoredResult(score, maxScore);
|
|
|
|
this.trigger(event);
|
2015-02-20 10:26:33 +01:00
|
|
|
};
|
2015-02-16 16:47:04 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Internal H5P function listening for xAPI completed events and stores scores
|
2015-02-20 10:26:33 +01:00
|
|
|
*
|
2015-02-16 16:47:04 +01:00
|
|
|
* @param {function} event - xAPI event
|
|
|
|
*/
|
|
|
|
H5P.xAPICompletedListener = function(event) {
|
2015-03-22 20:38:57 +01:00
|
|
|
if (event.getVerb() === 'completed' && !event.getVerifiedStatementValue(['context', 'contextActivities', 'parent'])) {
|
|
|
|
var score = event.getScore();
|
|
|
|
var maxScore = event.getMaxScore();
|
|
|
|
var contentId = event.getVerifiedStatementValue(['object', 'definition', 'extensions', 'http://h5p.org/x-api/h5p-local-content-id']);
|
|
|
|
H5P.setFinished(contentId, score, maxScore);
|
2015-02-16 16:47:04 +01:00
|
|
|
}
|
2015-02-20 10:26:33 +01:00
|
|
|
};
|