Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 4.2.x will end 22 April 2024 (12 months).
  • Bug fixes for security issues in 4.2.x will end 7 October 2024 (18 months).
  • PHP version: minimum PHP 8.0.0 Note: minimum PHP version has increased since Moodle 4.1. PHP 8.1.x is supported too.
<?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/>.

/**
 * Action to delete (or hide) a question, or restore a previously hidden question.
 *
 * @package   qbank_deletequestion
 * @copyright 2009 Tim Hunt
 * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

namespace qbank_deletequestion;

use core_question\local\bank\question_version_status;
use core_question\local\bank\menu_action_column_base;

/**
 * Action to delete (or hide) a question, or restore a previously hidden question.
 *
 * @package   qbank_deletequestion
 * @copyright 2009 Tim Hunt
 * @author    2021 Safat Shahin <safatshahin@catalyst-au.net>
 * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
class delete_action_column extends menu_action_column_base {

    /**
     * @var string $strdelete
     */
    protected $strdelete;

    /**
     * @var string $strrestore
     */
    protected $strrestore;

    /**
     * Contains the url of the delete question page.
     * @var \moodle_url|string
     */
    public $deletequestionurl;

    /**
     * Array of the return parameters.
     * @var array $returnparams
     */
    protected $returnparams;

    public function init(): void {
        parent::init();
        $this->strdelete = get_string('delete');
        $this->strrestore = get_string('restore');
        $this->deletequestionurl = new \moodle_url('/question/bank/deletequestion/delete.php');
        if (!empty($this->qbank->cm->id)) {
            $this->returnparams['cmid'] = $this->qbank->cm->id;
        }
        if (!empty($this->qbank->course->id)) {
            $this->returnparams['courseid'] = $this->qbank->course->id;
        }
        if (!empty($this->qbank->returnurl)) {
            $this->returnparams['returnurl'] = $this->qbank->returnurl;
        }
    }

    public function get_name(): string {
        return 'deleteaction';
    }

    protected function get_url_icon_and_label(\stdClass $question): array {
        if (!question_has_capability_on($question, 'edit')) {
            return [null, null, null];
        }
        if ($question->status === question_version_status::QUESTION_STATUS_HIDDEN) {
            $hiddenparams = array(
                    'unhide' => $question->id,
                    'sesskey' => sesskey());
            $hiddenparams = array_merge($hiddenparams, $this->returnparams);
            $url = new \moodle_url($this->deletequestionurl, $hiddenparams);
            return [$url, 't/restore', $this->strrestore];
        } else {
            $deleteparams = array(
                    'deleteselected' => $question->id,
                    'q' . $question->id => 1,
                    'sesskey' => sesskey());
            $deleteparams = array_merge($deleteparams, $this->returnparams);
> if ($this->qbank->base_url()->get_param('deleteall')) { $url = new \moodle_url($this->deletequestionurl, $deleteparams); > $deleteparams['deleteall'] = 1; return [$url, 't/delete', $this->strdelete]; > }
} } public function get_required_fields(): array { $required = parent::get_required_fields(); return $required; } }