moodle/question/qengine.js

195 lines
7.4 KiB
JavaScript

// 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/>.
/**
* JavaScript required by the question engine.
*
* @package moodlecore
* @subpackage questionengine
* @copyright 2008 The Open University
* @deprecated since Moodle 4.0
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
M.core_scroll_manager = M.core_scroll_manager || {};
// TODO Remove the scroll manager and deprecation layer in 4.6 MDL-76685.
/* eslint-disable */
var loadedPromise = new Promise(function(resolve) {
require(['core/scroll_manager'], function(ScrollManager) {
var transitionLayer = {};
var deprecatedNotice = function(functionName, newFunctionName) {
window.console.error(
"The " + functionName + " function has been deprecated. " +
"Please use core/scroll_manager::" + newFunctionName + "() instead"
);
};
transitionLayer.save_scroll_pos = function(Y, element) {
deprecatedNotice('save_scroll_pos', 'saveScrollPos');
ScrollManager.saveScrollPos(element);
};
transitionLayer.scroll_to_saved_pos = function() {
deprecatedNotice('scroll_to_saved_pos', 'scrollToSavedPosition');
ScrollManager.scrollToSavedPosition();
};
M.core_scroll_manager = transitionLayer;
resolve(transitionLayer);
});
});
var callPromisedFunction = function(functionName, args) {
loadedPromise.then(function(transitionLayer) {
transitionLayer[functionName].apply(null, args);
});
};
if (!M.core_scroll_manager.save_scroll_pos) {
// Note: This object is short lived.
// It only lives until the new scroll manager is loaded, at which point it is replaced.
/**
* In the form that contains the element, set the value of the form field with
* name scrollpos to the current scroll position. If there is no element with
* that name, it creates a hidden form field with that name within the form.
* @deprecated since Moodle 4.0
* @see core/scroll_manager
* @param element the element in the form. Should be something that can be
* passed to Y.one.
*/
M.core_scroll_manager.save_scroll_pos = function(Y, element) {
callPromisedFunction(M.core_scroll_manager.save_scroll_pos, [Y, element]);
};
/**
* Event handler that can be used on a link. Assumes that the link already
* contains at least one URL parameter.
* @deprecated since Moodle 4.0
* @see core/scroll_manager
*/
M.core_scroll_manager.save_scroll_action = function() {
Y.log("The scroll_to_saved_pos function has been deprecated. " +
"Please use initLinksScrollPos in core/scroll_manager instead.", 'moodle-core-notification', 'warn');
};
/**
* If there is a parameter like scrollpos=123 in the URL, scroll to that saved position.
* @deprecated since Moodle 4.0
* @see core/scroll_manager
* @todo Final deprecation on Moodle 4.4 MDL-72438
*/
M.core_scroll_manager.scroll_to_saved_pos = function(Y) {
callPromisedFunction(M.core_scroll_manager.scroll_to_saved_pos, Y);
};
}
/* eslint-enable */
M.core_question_engine = M.core_question_engine || {};
/**
* Flag used by M.core_question_engine.prevent_repeat_submission.
*/
M.core_question_engine.questionformalreadysubmitted = false;
/**
* Initialise a question submit button. This saves the scroll position and
* sets the fragment on the form submit URL so the page reloads in the right place.
* @deprecated since Moodle 4.0
* @see core_question/question_engine
* @param button the id of the button in the HTML.
*/
M.core_question_engine.init_submit_button = function(Y, button) {
Y.log("The core_question_engine.init_submit_button function has been deprecated. " +
"Please use initSubmitButton in core_question/question_engine instead.", 'moodle-core-notification', 'warn');
require(['core_form/submit'], function(submit) {
submit.init(button);
});
var totalQuestionsInPage = document.querySelectorAll('div.que').length;
var buttonel = document.getElementById(button);
var outeruniqueid = buttonel.closest('.que').id;
Y.on('click', function(e) {
M.core_scroll_manager.save_scroll_pos(Y, button);
if (totalQuestionsInPage > 1) {
// Only change the form action if the page have more than one question.
buttonel.form.action = buttonel.form.action + '#' + outeruniqueid;
}
}, buttonel);
}
/**
* Initialise a form that contains questions printed using print_question.
* This has the effect of:
* 1. Turning off browser autocomlete.
* 2. Stopping enter from submitting the form (or toggling the next flag) unless
* keyboard focus is on the submit button or the flag.
* 3. Removes any '.questionflagsavebutton's, since we have JavaScript to toggle
* the flags using ajax.
* 4. Scroll to the position indicated by scrollpos= in the URL, if it is there.
* 5. Prevent the user from repeatedly submitting the form.
* @param Y the Yahoo object. Needs to have the DOM and Event modules loaded.
* @param form something that can be passed to Y.one, to find the form element.
* @deprecated since Moodle 4.0
* @see core_question/question_engine
* @todo Final deprecation on Moodle 4.4 MDL-72438
*/
M.core_question_engine.init_form = function(Y, form) {
Y.log("The core_question_engine.init_form function has been deprecated. " +
"Please use init_form in core_question/question_engine instead.", 'moodle-core-notification', 'warn');
Y.one(form).setAttribute('autocomplete', 'off');
Y.on('submit', M.core_question_engine.prevent_repeat_submission, form, form, Y);
Y.on('key', function (e) {
if (!e.target.test('a') && !e.target.test('input[type=submit]') &&
!e.target.test('input[type=img]') && !e.target.test('textarea') && !e.target.test('[contenteditable=true]')) {
e.preventDefault();
}
}, form, 'press:13');
Y.one(form).all('.questionflagsavebutton').remove();
M.core_scroll_manager.scroll_to_saved_pos(Y);
}
/**
* Event handler to stop a question form being submitted more than once.
* @param e the form submit event.
* @param form the form element.
* @deprecated since Moodle 4.0
* @see core_question/question_engine
* @todo Final deprecation on Moodle 4.4 MDL-72438
*/
M.core_question_engine.prevent_repeat_submission = function(e, Y) {
Y.log("The prevent_repeat_submission function has been deprecated. " +
"Please use preventRepeatSubmission in core_question/question_engine instead.", 'moodle-core-notification', 'warn');
if (M.core_question_engine.questionformalreadysubmitted) {
e.halt();
return;
}
setTimeout(function() {
Y.all('input[type=submit]').set('disabled', true);
}, 0);
M.core_question_engine.questionformalreadysubmitted = true;
}