From f9ea9adb1ba634b074304cbe2830b478c2507f45 Mon Sep 17 00:00:00 2001 From: Andrew Downes Date: Tue, 20 Oct 2015 11:13:08 +0100 Subject: [PATCH 1/2] Add support for result.success & completion --- js/h5p-x-api-event.js | 40 +++++++++++++++++++++++++++++++--------- 1 file changed, 31 insertions(+), 9 deletions(-) diff --git a/js/h5p-x-api-event.js b/js/h5p-x-api-event.js index 98b287a1..1653b0c3 100644 --- a/js/h5p-x-api-event.js +++ b/js/h5p-x-api-event.js @@ -18,18 +18,40 @@ H5P.XAPIEvent.prototype.constructor = H5P.XAPIEvent; * * @param {number} score * @param {number} maxScore + * @param {object} instance + * @param {boolean} completion + * @param {boolean} success */ -H5P.XAPIEvent.prototype.setScoredResult = function (score, maxScore, instance) { - this.data.statement.result = { - 'score': { - 'min': 0, - 'max': maxScore, - 'raw': score +H5P.XAPIEvent.prototype.setScoredResult = function (score, maxScore, instance, completion, success) { + this.data.statement.result = {}; + + if (typeof score !== 'undefined') { + if (typeof maxScore === 'undefined') { + this.data.statement.result.score = {'raw': score}; } - }; - if (maxScore > 0) { - this.data.statement.result.score.scaled = Math.round(score / maxScore * 10000) / 10000; + else { + this.data.statement.result.score = { + 'min': 0, + 'max': maxScore, + 'raw': score + }; + if (maxScore > 0) { + this.data.statement.result.score.scaled = Math.round(score / maxScore * 10000) / 10000; + } + } + } + + if (typeof completion === 'undefined') { + this.data.statement.result.completion = true; + } + else { + this.data.statement.result.completion = completion; + } + + if (typeof success !== 'undefined') { + this.data.statement.result.success = success; } + if (instance && instance.activityStartTime) { var duration = Math.round((Date.now() - instance.activityStartTime ) / 10) / 100; // xAPI spec allows a precision of 0.01 seconds From 76a02867aa9a26acd0a0cb83086d6da4a32b4de3 Mon Sep 17 00:00:00 2001 From: Andrew Downes Date: Tue, 20 Oct 2015 11:29:01 +0100 Subject: [PATCH 2/2] Update triggerXAPICompleted and triggerXAPIScored Added support for completion and success. --- js/h5p-x-api.js | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/js/h5p-x-api.js b/js/h5p-x-api.js index e287c1a3..aeec7b64 100644 --- a/js/h5p-x-api.js +++ b/js/h5p-x-api.js @@ -65,9 +65,16 @@ H5P.EventDispatcher.prototype.createXAPIEventTemplate = function (verb, extra) { * Will be set as the 'raw' value of the score object * @param {number} maxScore * will be set as the "max" value of the score object + * @param {boolean} success + * will be set as the "success" value of the result object */ -H5P.EventDispatcher.prototype.triggerXAPICompleted = function (score, maxScore) { - this.triggerXAPIScored(score, maxScore, 'completed'); +H5P.EventDispatcher.prototype.triggerXAPICompleted = function (score, maxScore, success) { + var verb = 'completed'; + if (typeof success !== 'undefined') { + if (success) {verb = "passed";} + else {verb = "failed";} + } + this.triggerXAPIScored(score, maxScore, verb, true, success); }; /** @@ -80,9 +87,9 @@ H5P.EventDispatcher.prototype.triggerXAPICompleted = function (score, maxScore) * @param {string} verb * Short form of adl verb */ -H5P.EventDispatcher.prototype.triggerXAPIScored = function (score, maxScore, verb) { +H5P.EventDispatcher.prototype.triggerXAPIScored = function (score, maxScore, verb, completion, success) { var event = this.createXAPIEventTemplate(verb); - event.setScoredResult(score, maxScore, this); + event.setScoredResult(score, maxScore, this, completion, success); this.trigger(event); };