Files
moodle/question/yui/build/moodle-question-qbankmanager/moodle-question-qbankmanager-debug.js
Colin Chambers e1a2d0d92d MDL-43089 quiz: improved interface for building quizzes
This commit is actually the joint work of Mahmoud Kassaei, Colin
Chambers and Tim Hunt from The Open University. We could only use one
persons name for the commit, and this time Colin gets the credit/blame.

The goal of this work was to increase usability, and also clean up
the page enough that it will be possible to add new features in future.

Display of mod/quiz/edit.php is now entirely generated by
mod_quiz\output\edit_renderer. This uses a helper class
mod_quiz\structure to provide details of the structure of the quiz, and
mod_quiz\repaginate to alter that structure. (Acutally, there are still
some modification methods on mod_quiz\structure. Expect that to be
cleaned up in future.)

The new code uses much more ajax, and there are new scripts
mod/quiz/edit_rest.php and mod/quiz/repaginate.php to handle this.
(Again, don't be surprised if those two scripts get merged in future.)
Also questionbank.ajax.php (which may, in future, be made more generic,
and moved into the core question bank code.)

Most of the new JavaScript code has intentionally copied the way things
are done when editing activities on the course page.

As a result of this, mod/quiz/editlib.php is now much shorter than it
was. (In future, expect the remaining code in here to move into
mod/quiz/classes.)
2014-10-02 17:22:23 +01:00

109 lines
2.9 KiB
JavaScript

YUI.add('moodle-question-qbankmanager', function (Y, NAME) {
// 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/>.
/*
* Question Bank Management.
*
* @package question
* @copyright 2014 Andrew Nicols
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
/**
* Questionbank Management.
*
* @module moodle-question-qbankmanager
*/
/**
* Question Bank Management.
*
* @class M.question.qbankmanager
*/
var manager = {
/**
* A reference to the header checkbox.
*
* @property _header
* @type Node
* @private
*/
_header: null,
/**
* The ID of the first checkbox on the page.
*
* @property _firstCheckbox
* @type Node
* @private
*/
_firstCheckbox: null,
/**
* Set up the Question Bank Manager.
*
* @method init
*/
init: function() {
// Find the header checkbox, and set the initial values.
this._header = Y.one('#qbheadercheckbox');
if (!this._header) {
return;
}
this._header.setAttrs({
disabled: false,
title: M.util.get_string('selectall', 'moodle')
});
this._header.on('click', this._headerClick, this);
// Store the first checkbox details.
var table = this._header.ancestor('table');
this._firstCheckbox = table.one('tbody tr td.checkbox input');
},
/**
* Handle toggling of the header checkbox.
*
* @method _headerClick
* @private
*/
_headerClick: function() {
// Get the list of questions we affect.
var categoryQuestions = Y.one('#categoryquestions')
.all('[type=checkbox],[type=radio]');
// We base the state of all of the questions on the state of the first.
if (this._firstCheckbox.get('checked')) {
categoryQuestions.set('checked', false);
this._header.setAttribute('title', M.util.get_string('selectall', 'moodle'));
} else {
categoryQuestions.set('checked', true);
this._header.setAttribute('title', M.util.get_string('deselectall', 'moodle'));
}
this._header.set('checked', false);
}
};
M.question = M.question || {};
M.question.qbankmanager = M.question.qbankmanager || manager;
}, '@VERSION@', {"requires": ["node", "selector-css3"]});