Search moodle.org's
Developer Documentation

See Release Notes
Long Term Support Release

  • Bug fixes for general core bugs in 4.1.x will end 13 November 2023 (12 months).
  • Bug fixes for security issues in 4.1.x will end 10 November 2025 (36 months).
  • PHP version: minimum PHP 7.4.0 Note: minimum PHP version has increased since Moodle 4.0. PHP 8.0.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/>.

/**
 * classic config.
 *
 * @package   theme_classic
 * @copyright 2018 Bas Brands
 * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

// This line protects the file from being accessed by a URL directly.
defined('MOODLE_INTERNAL') || die();

$THEME->name = 'classic';

$THEME->sheets = [];

$THEME->layouts = [
    // Most backwards compatible layout without the blocks - this is the layout used by default.
    'base' => array(
        'file' => 'columns.php',
        'regions' => array(),
    ),
    // Standard layout with blocks, this is recommended for most pages with general information.
    'standard' => array(
        'file' => 'columns.php',
        'regions' => array('side-pre', 'side-post'),
        'defaultregion' => 'side-pre',
    ),
    // Main course page.
    'course' => array(
        'file' => 'columns.php',
        'regions' => array('side-pre', 'side-post'),
        'defaultregion' => 'side-pre',
        'options' => array('langmenu' => true),
    ),
    'coursecategory' => array(
        'file' => 'columns.php',
        'regions' => array('side-pre'),
        'defaultregion' => 'side-pre',
    ),
    // Part of course, typical for modules - default page layout if $cm specified in require_login().
    'incourse' => array(
        'file' => 'columns.php',
< 'regions' => array('side-pre'),
> 'regions' => array('side-pre', 'side-post'),
'defaultregion' => 'side-pre', ), // The site home page. 'frontpage' => array( 'file' => 'columns.php', 'regions' => array('side-pre', 'side-post'), 'defaultregion' => 'side-pre', 'options' => array('nofullheader' => true), ), // Server administration scripts. 'admin' => array( 'file' => 'columns.php', 'regions' => array('side-pre'), 'defaultregion' => 'side-pre', ),
> // My courses page. // My dashboard page. > 'mycourses' => array( 'mydashboard' => array( > 'file' => 'columns.php', 'file' => 'columns.php', > 'regions' => ['side-pre', 'side-post'], 'regions' => array('side-pre', 'side-post'), > 'defaultregion' => 'side-pre', 'defaultregion' => 'side-pre', > ),
< 'options' => array('nonavbar' => true, 'langmenu' => true, 'nocontextheader' => true),
> 'options' => array('langmenu' => true),
), // My public page. 'mypublic' => array( 'file' => 'columns.php', 'regions' => array('side-pre'), 'defaultregion' => 'side-pre', ), 'login' => array( 'theme' => 'boost', 'file' => 'login.php', 'regions' => array(), 'options' => array('langmenu' => true), ), // Pages that appear in pop-up windows - no navigation, no blocks, no header. 'popup' => array( 'file' => 'contentonly.php', 'regions' => array(),
< 'options' => array('nofooter' => true, 'nonavbar' => true),
> 'options' => array( > 'nofooter' => true, > 'nonavbar' => true, > 'activityheader' => [ > 'notitle' => true, > 'nocompletion' => true, > 'nodescription' => true > ] > ),
), // No blocks and minimal footer - used for legacy frame layouts only! 'frametop' => array( 'file' => 'contentonly.php', 'regions' => array(),
< 'options' => array('nofooter' => true, 'nocoursefooter' => true),
> 'options' => array( > 'nofooter' => true, > 'nocoursefooter' => true, > 'activityheader' => [ > 'nocompletion' => true > ]),
), // Embeded pages, like iframe/object embeded in moodleform - it needs as much space as possible. 'embedded' => array( 'theme' => 'boost', 'file' => 'embedded.php', 'regions' => array() ), // Used during upgrade and install, and for the 'This site is undergoing maintenance' message. // This must not have any blocks, links, or API calls that would lead to database or cache interaction. // Please be extremely careful if you are modifying this layout. 'maintenance' => array( 'theme' => 'boost', 'file' => 'maintenance.php', 'regions' => array(), ), // Should display the content and basic headers only. 'print' => array( 'file' => 'contentonly.php', 'regions' => array(),
< 'options' => array('nofooter' => true, 'nonavbar' => false),
> 'options' => array('nofooter' => true, 'nonavbar' => false, 'noactivityheader' => true),
), // The pagelayout used when a redirection is occuring. 'redirect' => array( 'theme' => 'boost', 'file' => 'embedded.php', 'regions' => array(), ), // The pagelayout used for reports. 'report' => array( 'file' => 'columns.php', 'regions' => array('side-pre'), 'defaultregion' => 'side-pre', ), // The pagelayout used for safebrowser and securewindow. 'secure' => array( 'file' => 'secure.php', 'regions' => array('side-pre'), 'defaultregion' => 'side-pre' ) ]; $THEME->editor_sheets = []; $THEME->parents = ['boost']; $THEME->enable_dock = false; $THEME->extrascsscallback = 'theme_classic_get_extra_scss'; $THEME->prescsscallback = 'theme_classic_get_pre_scss'; $THEME->precompiledcsscallback = 'theme_classic_get_precompiled_css'; $THEME->yuicssmodules = array(); $THEME->rendererfactory = 'theme_overridden_renderer_factory'; $THEME->scss = function($theme) { return theme_classic_get_main_scss_content($theme); }; $THEME->usefallback = true; $THEME->iconsystem = '\\theme_classic\\output\\icon_system_fontawesome';
> $THEME->haseditswitch = false;