AutorÃa | Ultima modificación | Ver Log |
<?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/>.namespace qbank_viewquestionname;use core\output\datafilter;/*** Filter condition for filtering on the question name** @package qbank_viewquestionname* @copyright 2024 onwards Catalyst IT EU {@link https://catalyst-eu.net}* @author Mark Johnson <mark.johnson@catalyst-eu.net>* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later*/class question_name_condition extends \core_question\local\bank\condition {#[\Override]public function get_title() {return get_string('questionnamecondition', 'qbank_viewquestionname');}#[\Override]public static function get_condition_key() {return 'questionname';}#[\Override]public function get_filter_class() {return 'core/datafilter/filtertypes/keyword';}/*** Return an SQL condition and parameters for filtering on q.name.** This will search for the terms provided anywhere in the name.** @param array $filter* @return array*/public static function build_query_from_filter(array $filter): array {global $DB;$conditions = [];$params = [];$notlike = $filter['jointype'] === datafilter::JOINTYPE_NONE;foreach ($filter['values'] as $key => $value) {$params["questionname{$key}"] = "%{$value}%";$conditions[] = $DB->sql_like('q.name', ":questionname{$key}", casesensitive: false, notlike: $notlike);}$delimiter = $filter['jointype'] === datafilter::JOINTYPE_ANY ? ' OR ' : ' AND ';return [implode($delimiter, $conditions),$params,];}}