X7ROOT File Manager
Current Path:
/home/cbholdings/pasukulu/blocks/classes/external
home
/
cbholdings
/
pasukulu
/
blocks
/
classes
/
external
/
📁
..
📄
fetch_addable_blocks.php
(5.25 KB)
Editing: fetch_addable_blocks.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/>. namespace core_block\external; use core_external\external_api; use core_external\external_function_parameters; use core_external\external_multiple_structure; use core_external\external_single_structure; use core_external\external_value; /** * This is the external method used for fetching the addable blocks in a given page. * * @package core_block * @since Moodle 3.11 * @copyright 2020 Mihail Geshoski <mihail@moodle.com> * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class fetch_addable_blocks extends external_api { /** * Describes the parameters for execute. * * @return external_function_parameters */ public static function execute_parameters(): external_function_parameters { return new external_function_parameters( [ 'pagecontextid' => new external_value(PARAM_INT, 'The context ID of the page.'), 'pagetype' => new external_value(PARAM_ALPHANUMEXT, 'The type of the page.'), 'pagelayout' => new external_value(PARAM_ALPHA, 'The layout of the page.'), 'subpage' => new external_value(PARAM_TEXT, 'The subpage identifier', VALUE_DEFAULT, ''), 'pagehash' => new external_value(PARAM_ALPHANUMEXT, 'Page hash', VALUE_DEFAULT, ''), ] ); } /** * Fetch the addable blocks in a given page. * * @param int $pagecontextid The context ID of the page * @param string $pagetype The type of the page * @param string $pagelayout The layout of the page * @param string $subpage The subpage identifier * @param string $pagehash Page hash that can be provided instead of all parameters above * @return array The blocks list */ public static function execute(int $pagecontextid, string $pagetype, string $pagelayout, string $subpage = '', string $pagehash = ''): array { global $PAGE; $params = self::validate_parameters(self::execute_parameters(), [ 'pagecontextid' => $pagecontextid, 'pagetype' => $pagetype, 'pagelayout' => $pagelayout, 'subpage' => $subpage, 'pagehash' => $pagehash, ] ); if ($params['pagehash']) { // If pagehash is specified, all other parameters are ignored, all information // about the page is stored in the session. $page = \moodle_page::retrieve_edited_page($params['pagehash'], MUST_EXIST); self::validate_context($page->context); } else { // For backward-compatibility and Mobile App instead of pagehash // we can specify context, pagelayout, pagetype and subtype. $context = \context::instance_by_id($params['pagecontextid']); // Validate the context. This will also set the context in $PAGE. self::validate_context($context); // We need to manually set the page layout and page type. $PAGE->set_pagelayout($params['pagelayout']); $PAGE->set_pagetype($params['pagetype']); $PAGE->set_subpage($params['subpage']); $page = $PAGE; } // Firstly, we need to load all currently existing page blocks to later determine which blocks are addable. $page->blocks->load_blocks(false); $page->blocks->create_all_block_instances(); $addableblocks = $page->blocks->get_addable_blocks(); return array_map(function($block) use ($page) { $classname = \block_manager::get_block_edit_form_class($block->name); return [ 'name' => $block->name, 'title' => get_string('pluginname', "block_{$block->name}"), 'blockform' => $classname::display_form_when_adding() ? $classname : null, ]; }, $addableblocks); } /** * Describes the execute return value. * * @return external_multiple_structure */ public static function execute_returns(): external_multiple_structure { return new external_multiple_structure( new external_single_structure( [ 'name' => new external_value(PARAM_PLUGIN, 'The name of the block.'), 'title' => new external_value(PARAM_RAW, 'The title of the block.'), 'blockform' => new external_value(PARAM_RAW, 'If this block type has a form when it is being added then the classname of the form') ] ), 'List of addable blocks in a given page.' ); } }
Upload File
Create Folder