Current Path : /home/ncdcgo/ele.ncdc.go.ug/h5p/js/ |
Current File : /home/ncdcgo/ele.ncdc.go.ug/h5p/js/embed.js |
// This file is part of Moodle - http://moodle.org/ // // Moodle is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // Moodle is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with Moodle. If not, see <http://www.gnu.org/licenses/>. /* global H5PEmbedCommunicator:true */ /** * When embedded the communicator helps talk to the parent page. * This is a copy of the H5P.communicator, which we need to communicate in this context * * @type {H5PEmbedCommunicator} * @module core_h5p * @copyright 2019 Joubel AS <contact@joubel.com> * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ H5PEmbedCommunicator = (function() { /** * @class * @private */ function Communicator() { var self = this; // Maps actions to functions. var actionHandlers = {}; // Register message listener. window.addEventListener('message', function receiveMessage(event) { if (window.parent !== event.source || event.data.context !== 'h5p') { return; // Only handle messages from parent and in the correct context. } if (actionHandlers[event.data.action] !== undefined) { actionHandlers[event.data.action](event.data); } }, false); /** * Register action listener. * * @param {string} action What you are waiting for * @param {function} handler What you want done */ self.on = function(action, handler) { actionHandlers[action] = handler; }; /** * Send a message to the all mighty father. * * @param {string} action * @param {Object} [data] payload */ self.send = function(action, data) { if (data === undefined) { data = {}; } data.context = 'h5p'; data.action = action; // Parent origin can be anything. window.parent.postMessage(data, '*'); }; /** * Send a xAPI statement to LMS. * * @param {string} component * @param {Object} statements */ self.post = function(component, statements) { require(['core/ajax'], function(ajax) { var data = { component: component, requestjson: JSON.stringify(statements) }; ajax.call([ { methodname: 'core_xapi_statement_post', args: data } ]); }); }; } return (window.postMessage && window.addEventListener ? new Communicator() : undefined); })(); document.onreadystatechange = function() { // Wait for instances to be initialize. if (document.readyState !== 'complete') { return; } // Check for H5P iFrame. var iFrame = document.querySelector('.h5p-iframe'); if (!iFrame || !iFrame.contentWindow) { return; } var H5P = iFrame.contentWindow.H5P; // Check for H5P instances. if (!H5P || !H5P.instances || !H5P.instances[0]) { return; } var resizeDelay; var instance = H5P.instances[0]; var parentIsFriendly = false; // Handle that the resizer is loaded after the iframe. H5PEmbedCommunicator.on('ready', function() { H5PEmbedCommunicator.send('hello'); }); // Handle hello message from our parent window. H5PEmbedCommunicator.on('hello', function() { // Initial setup/handshake is done. parentIsFriendly = true; // Hide scrollbars for correct size. iFrame.contentDocument.body.style.overflow = 'hidden'; document.body.classList.add('h5p-resizing'); // Content need to be resized to fit the new iframe size. H5P.trigger(instance, 'resize'); }); // When resize has been prepared tell parent window to resize. H5PEmbedCommunicator.on('resizePrepared', function() { H5PEmbedCommunicator.send('resize', { scrollHeight: iFrame.contentDocument.body.scrollHeight }); }); H5PEmbedCommunicator.on('resize', function() { H5P.trigger(instance, 'resize'); }); H5P.on(instance, 'resize', function() { if (H5P.isFullscreen) { return; // Skip iframe resize. } // Use a delay to make sure iframe is resized to the correct size. clearTimeout(resizeDelay); resizeDelay = setTimeout(function() { // Only resize if the iframe can be resized. if (parentIsFriendly) { H5PEmbedCommunicator.send('prepareResize', { scrollHeight: iFrame.contentDocument.body.scrollHeight, clientHeight: iFrame.contentDocument.body.clientHeight } ); } else { H5PEmbedCommunicator.send('hello'); } }, 0); }); // Get emitted xAPI data. H5P.externalDispatcher.on('xAPI', function(event) { var moodlecomponent = H5P.getMoodleComponent(); if (moodlecomponent == undefined) { return; } // Skip malformed events. var hasStatement = event && event.data && event.data.statement; if (!hasStatement) { return; } var statement = event.data.statement; var validVerb = statement.verb && statement.verb.id; if (!validVerb) { return; } var isCompleted = statement.verb.id === 'http://adlnet.gov/expapi/verbs/answered' || statement.verb.id === 'http://adlnet.gov/expapi/verbs/completed'; var isChild = statement.context && statement.context.contextActivities && statement.context.contextActivities.parent && statement.context.contextActivities.parent[0] && statement.context.contextActivities.parent[0].id; if (isCompleted && !isChild) { var statements = H5P.getXAPIStatements(this.contentId, statement); H5PEmbedCommunicator.post(moodlecomponent, statements); } }); // Trigger initial resize for instance. H5P.trigger(instance, 'resize'); };