mirror of
https://github.com/moodle/moodle.git
synced 2025-03-09 10:19:56 +01:00
This commit implements the qbank api so that any plugin can implement its own question bank. This api currently works parallely with the moodle core classes and the added qbank in the core, means the moment a plugin is installed, that object is replaced with the object from the plugin instead of core, which means the api has flexibility till the plugins are integrated and the plugins can be integrated in any order. All the old classes are still there and not deprecated as there is a different tracker for the changes to the quiz and another tracker for class deprecation and class renaming. Core question units tests are pointing to the new api structure but the classes are pointing to the location related to the plugin availability. Co-Authored-By: Luca Bösch <luca.boesch@bfh.ch> Co-Authored-By: Guillermo Gomez Arias <guillermogomez@catalyst-au.net> one more array fix
55 lines
2.1 KiB
PHP
55 lines
2.1 KiB
PHP
<?php
|
|
// 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/>.
|
|
|
|
/**
|
|
* Interface to indicate that a question bank column can go in the action menu.
|
|
*
|
|
* @package core_question
|
|
* @copyright 2019 Tim Hunt
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
*/
|
|
|
|
namespace core_question\local\bank;
|
|
|
|
/**
|
|
* Interface to indicate that a question bank column can go in the action menu.
|
|
*
|
|
* If a question bank column implements this interface, and if the {@see edit_menu_column}
|
|
* is present in the question bank view, then the 'column' will be shown as an entry in the
|
|
* edit menu instead of as a separate column.
|
|
*
|
|
* Probably most columns that want to implement this will be subclasses of
|
|
* {@see action_column_base}, and most such columns should probably implement
|
|
* this interface.
|
|
*
|
|
* If your column is a simple action, you can probably save duplicated code by
|
|
* using the base class action_column_menuable as an easy way to implement both
|
|
* action_column_base and this interface.
|
|
*
|
|
* @copyright 2019 Tim Hunt
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
*/
|
|
interface menuable_action {
|
|
|
|
/**
|
|
* Return the appropriate action menu link, or null if it does not apply to this question.
|
|
*
|
|
* @param \stdClass $question data about the question being displayed in this row.
|
|
* @return \action_menu_link|null the action, if applicable to this question.
|
|
*/
|
|
public function get_action_menu_link(\stdClass $question): ?\action_menu_link;
|
|
}
|