See Release Notes
Long Term Support Release
<?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/>. /** * This page provides the Administration -> ... -> Theme selector UI. * * @package core * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ require_once(__DIR__ . '/../config.php'); require_once($CFG->libdir . '/adminlib.php'); $choose = optional_param('choose', '', PARAM_PLUGIN); $reset = optional_param('reset', 0, PARAM_BOOL);< $device = optional_param('device', '', PARAM_TEXT); < $unsettheme = optional_param('unsettheme', 0, PARAM_BOOL);$confirmation = optional_param('confirmation', 0, PARAM_BOOL); admin_externalpage_setup('themeselector');< if (!empty($device)) { < // Make sure the device requested is valid. < $devices = core_useragent::get_device_type_list(); < if (!in_array($device, $devices)) { < // The provided device isn't a valid device throw an error. < throw new \moodle_exception('invaliddevicetype'); < } < } <unset($SESSION->theme); $PAGE->set_primary_active_tab('siteadminnode'); $PAGE->navbar->add(get_string('themeselector', 'admin'), $PAGE->url);> // Clear theme cache.if ($reset and confirm_sesskey()) { theme_reset_all_caches();< } else if ($choose && $confirmation) {> }< $theme = theme_config::load($choose); < echo $OUTPUT->header(); < echo $OUTPUT->heading(get_string('themesaved')); < echo $OUTPUT->box_start(); < echo format_text(get_string('choosereadme', 'theme_'.$theme->name), FORMAT_MOODLE); < echo $OUTPUT->box_end(); < echo $OUTPUT->continue_button($CFG->wwwroot . '/theme/index.php'); < echo $OUTPUT->footer(); < exit;> $definedinconfig = array_key_exists('theme', $CFG->config_php_settings); > if ($definedinconfig) { > $forcedthemename = get_string('pluginname', 'theme_'.$CFG->theme); > // Show a notification that the theme is defined in config.php. > \core\notification::info(get_string('themedefinedinconfigphp', 'admin', $forcedthemename)); > } > > // Change theme. > if (!$definedinconfig && !empty($choose) && confirm_sesskey()) {< } else if ($choose && $device && !theme_is_device_locked($device) && !$unsettheme && confirm_sesskey()) {// Load the theme to make sure it is valid. $theme = theme_config::load($choose);< // Get the config argument for the chosen device. < $themename = core_useragent::get_device_type_cfg_var_name($device); < set_config($themename, $theme->name); < < $urlconfirm = new moodle_url('/theme/index.php', array('confirmation' => 1, 'choose' => $choose)); < redirect($urlconfirm); < } else if ($device && !theme_is_device_locked($device) && $unsettheme && confirm_sesskey() && ($device != 'default')) { < // Unset the theme and continue. < unset_config(core_useragent::get_device_type_cfg_var_name($device)); < $device = ''; < } < < // Otherwise, show either a list of devices, or is enabledevicedetection set to no or a < // device is specified show a list of themes. < < $table = new html_table(); < $table->data = array(); < $heading = ''; < if (!empty($CFG->enabledevicedetection) && empty($device)) { < $heading = get_string('selectdevice', 'admin'); < // Display a list of devices that a user can select a theme for. < < $strthemenotselected = get_string('themenoselected', 'admin'); < $strthemeselect = get_string('themeselect', 'admin'); < < // Display the device selection screen. < $table->id = 'admindeviceselector'; < $table->head = array(get_string('devicetype', 'admin'), get_string('currenttheme', 'admin'), get_string('info')); < < $devices = core_useragent::get_device_type_list(); < foreach ($devices as $thedevice) { < < $headingthemename = ''; // To output the picked theme name when needed. < $themename = core_useragent::get_device_type_theme($thedevice); < if (!$themename && $thedevice == 'default') { < $themename = theme_config::DEFAULT_THEME; < } < $themelocked = theme_is_device_locked($thedevice); < < $screenshotcell = $strthemenotselected; < $unsetthemebutton = ''; < if ($themename) { < // Check the theme exists. < $themename = clean_param($themename, PARAM_THEME); < if (empty($themename)) { < // Likely the theme has been deleted. < unset_config(core_useragent::get_device_type_cfg_var_name($thedevice));> if ($theme instanceof \theme_config) { > set_config('theme', $theme->name); > $notifytype = 'success'; > $notifymessage = get_string('themesaved');} else {< $strthemename = get_string('pluginname', 'theme_'.$themename); < // Link to the screenshot, now mandatory - the image path is hardcoded because we need image from other themes, < // not the current one. < $screenshoturl = new moodle_url('/theme/image.php', < array('theme' => $themename, 'image' => 'screenshot', 'component' => 'theme')); < // Contents of the screenshot/preview cell. < $screenshotcell = html_writer::empty_tag('img', array('class' => 'img-fluid', < 'src' => $screenshoturl, 'alt' => $strthemename)); < // Show the name of the picked theme. < $headingthemename = $OUTPUT->heading($strthemename, 3); < } < // If not default device then show option to unset theme. < if ($thedevice != 'default' && !$themelocked) { < $unsetthemestr = get_string('unsettheme', 'admin'); < $unsetthemeurl = new moodle_url('/theme/index.php', < array('device' => $thedevice, 'sesskey' => sesskey(), 'unsettheme' => true)); < $unsetthemebutton = new single_button($unsetthemeurl, $unsetthemestr, 'get'); < $unsetthemebutton = $OUTPUT->render($unsetthemebutton); < }> $notifytype = 'error'; > $notifymessage = get_string('error');}< $deviceurl = new moodle_url('/theme/index.php', array('device' => $thedevice, 'sesskey' => sesskey())); < < $select = ''; < if (!$themelocked) { < $select = $OUTPUT->render(new single_button($deviceurl, $strthemeselect, 'get')); < } < < $lockwarning = ''; < if ($themelocked) { < $lockwarning = html_writer::div(get_string('configoverride', 'admin'), 'alert alert-info'); < } < < $table->data[] = array( < $OUTPUT->heading(ucfirst($thedevice), 3), < $screenshotcell, < $headingthemename . $lockwarning . $select . $unsetthemebutton < ); < } < } else { < // Either a device has been selected of $CFG->enabledevicedetection is off so display a list < // of themes to select. < $heading = get_string('selecttheme', 'admin', $device); < if (empty($device)) { < // If $CFG->enabledevicedetection is off this will return 'default'. < $device = core_useragent::get_device_type();> // Redirect with notification. > redirect(new moodle_url('/theme/index.php'), $notifymessage, null, $notifytype);}< $themelocked = theme_is_device_locked($device);> $table = new html_table(); > $table->data = [];$table->id = 'adminthemeselector';< $table->head = array(get_string('theme'), get_string('info'));> $table->head = [get_string('theme'), get_string('info')]; > $table->align = ['left', 'left'];< $themes = array(); < if ($themelocked) { < $heading = get_string('currenttheme', 'admin'); < $themename = theme_get_locked_theme_for_device($device); < $themedirectory = core_component::get_plugin_directory('theme', $themename); < $themes[$themename] = $themedirectory; < } else {$themes = core_component::get_plugin_list('theme');< }> // Loop through available themes.foreach ($themes as $themename => $themedir) {< // Load the theme config.try { $theme = theme_config::load($themename); } catch (Exception $e) { // Bad theme, just skip it for now. continue; } if ($themename !== $theme->name) { // Obsoleted or broken theme, just skip for now. continue; } if (empty($CFG->themedesignermode) && $theme->hidefromselector) { // The theme doesn't want to be shown in the theme selector and as theme // designer mode is switched off we will respect that decision. continue; }< $strthemename = get_string('pluginname', 'theme_'.$themename); < < // Build the table row, and also a list of items to go in the second cell. < $row = array(); < $infoitems = array(); < $rowclasses = array();< // Set up bools whether this theme is chosen either main or legacy. < $ischosentheme = ($themename == core_useragent::get_device_type_theme($device));> // Build the table rows. > $row = []; > $rowclasses = []; > $strthemename = get_string('pluginname', 'theme_'.$themename);< if ($ischosentheme) { < // Is the chosen main theme. < $rowclasses[] = 'selectedtheme'; < }> // Screenshot/preview cell. > $screenshotpath = new moodle_url('/theme/image.php', ['theme' => $themename, 'image' => 'screenshot', 'component' => 'theme']); > $row[] = html_writer::empty_tag('img', ['class' => 'img-fluid', 'src' => $screenshotpath, 'alt' => $strthemename]);< // Link to the screenshot, now mandatory - the image path is hardcoded because we need image from other themes, < // not the current one. < $screenshotpath = new moodle_url('/theme/image.php', < array('theme' => $themename, 'image' => 'screenshot', 'component' => 'theme')); < // Contents of the first screenshot/preview cell. < $row[] = html_writer::empty_tag('img', array('class' => 'img-fluid', < 'src' => $screenshotpath, 'alt' => $strthemename)); < // Contents of the second cell.> // Info cell.$infocell = $OUTPUT->heading($strthemename, 3);< if ($themelocked) {> // Is this the current theme? > if ($themename == $CFG->theme) { > $rowclasses[] = 'selectedtheme'; > if ($definedinconfig) {$infocell .= html_writer::div(get_string('configoverride', 'admin'), 'alert alert-info'); }< < // Button to choose this as the main theme or unset this theme for devices other then default. < if (!$themelocked) { < if (($ischosentheme) && ($device != 'default')) { < $unsetthemestr = get_string('unsettheme', 'admin'); < $unsetthemeurl = new moodle_url('/theme/index.php', < array('device' => $device, 'unsettheme' => true, 'sesskey' => sesskey())); < $unsetbutton = new single_button($unsetthemeurl, $unsetthemestr, 'get'); < $infocell .= $OUTPUT->render($unsetbutton); < } else if ((!$ischosentheme)) {> } else if (!$definedinconfig) { > // Button to choose this as the main theme.$setthemestr = get_string('usetheme');< $setthemeurl = new moodle_url('/theme/index.php', < array('device' => $device, 'choose' => $themename, 'sesskey' => sesskey())); < $setthemebutton = new single_button($setthemeurl, $setthemestr, 'get'); < $infocell .= $OUTPUT->render($setthemebutton); < }> $setthemeurl = new moodle_url('/theme/index.php', ['choose' => $themename, 'sesskey' => sesskey()]); > $setthemebutton = new single_button($setthemeurl, $setthemestr, 'post'); > $infocell .= html_writer::div($OUTPUT->render($setthemebutton), 'mt-2');}<$row[] = $infocell; $table->data[$themename] = $row; $table->rowclasses[$themename] = join(' ', $rowclasses);> $table->responsive = false;}< } < echo $OUTPUT->header('themeselector'); < echo $OUTPUT->heading($heading);< $params = array('sesskey' => sesskey(), 'reset' => 1); < if (!empty($device)) { < $params['device'] = $device; < } < echo $OUTPUT->single_button(new moodle_url('index.php', $params), get_string('themeresetcaches', 'admin'));> // Show heading. > echo $OUTPUT->header(); > echo $OUTPUT->heading(get_string('themeselector', 'admin'));< echo html_writer::table($table);> // Reset theme caches button. > $reseturl = new moodle_url('index.php', ['sesskey' => sesskey(), 'reset' => 1]); > echo $OUTPUT->single_button($reseturl, get_string('themeresetcaches', 'admin'), 'post');> // Render main table. echo $OUTPUT->footer(); > echo html_writer::table($table);