moodle/theme/index.php
tjhunt b70094743a themes: MDL-19077 change how the theme is initialised and CSS is served.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F

$THEME is now initialised at the same time as $OUTPUT. Old functions like
theme_setup are deprecated in favour of methods on $PAGE. There is a new
theme_config class in outputlib.php that deals with loading the theme config.php file.

CSS used to be served by themes styles.php files calling a function in weblib.php.
Now it works by each theme's styles.php file doing
$themename = basename(dirname(__FILE__));
require_once(dirname(__FILE__) . '/../../theme/styles.php');
which is less code to be copied into each theme. (Old-style styles.php files still
work thanks to some code in deprecatedlib.php.)

Admin UI for choosing a theme cleaned up.

A couple of theme-specific hard-coded hacks like $THEME->cssconstants and
$THEME->CSSEdit have been replaced by a more generic $THEME->customcssoutputfunction
hook. See examples at the end of outputlib.php

Also:
* Fix setting the theme in the URL, which seems to have been broken since 1.9.
* Fix up errors on a few pages caused by the new initialisation order.
* MDL-19097 moodle_page::set_course should not set $COURSE unless it is $PAGE.
* httpsrequired() from moodlelib.php moved to $PAGE->https_required().
* Move has_started() method to the renderer base class.
* Further fixes to display of early errors.
* Remove print_header/footer_old from weblib. I did not mean to commit them before.
2009-07-01 05:54:26 +00:00

145 lines
4.7 KiB
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/>.
/**
* This page prvides the Administration -> ... -> Theme selector UI.
*/
require_once(dirname(__FILE__) . '/../config.php');
require_once($CFG->libdir . '/adminlib.php');
$choose = optional_param('choose', '', PARAM_FILE);
admin_externalpage_setup('themeselector');
unset($SESSION->theme);
if ($choose and confirm_sesskey()) {
// The user has chosen one theme from the list of all themes, show a
// 'You have chosen a new theme' confirmation page.
if (!is_dir($CFG->themedir .'/'. $choose)) {
print_error('themenotinstall');
}
set_config('theme', $choose);
admin_externalpage_print_header();
print_heading(get_string('themesaved'));
$readmehtml = $CFG->themedir . '/' . $choose . '/README.html';
$readmetxt = $CFG->themedir . '/' . $choose . '/README.txt';
if (is_readable($readmehtml)) {
print_box_start();
readfile($readmehtml);
print_box_end();
} else if (is_readable($readmetxt)) {
print_box_start();
$text = file_get_contents($readmetxt);
echo format_text($text, FORMAT_MOODLE);
print_box_end();
}
print_continue($CFG->wwwroot . '/' . $CFG->admin . '/index.php');
admin_externalpage_print_footer();
exit;
}
// Otherwise, show a list of themes.
admin_externalpage_print_header('themeselector');
print_heading(get_string('themes'));
$table = new stdClass;
$table->id = 'adminthemeselector';
$table->head = array(get_string('theme'), get_string('info'));
$themes = get_plugin_list('theme');
$sesskey = sesskey();
foreach ($themes as $themename => $themedir) {
// Load the theme config.
try {
$theme = theme_config::load($themename);
} catch (coding_exception $e) {
// Bad theme, just skip it for now.
continue;
}
// Build the table row, and also a list of items to go in the second cell.
$row = array();
$infoitems = array();
// Preview link.
$infoitems['preview'] = '<a href="preview.php?preview=' . $themename . '">' . get_string('preview') . '</a>';
// First cell (a preview) and also a link to the screenshot, if there is one.
$screenshotpath = '';
if (file_exists($theme->dir . '/screenshot.png')) {
$screenshotpath = $themename . '/screenshot.png';
} else if (file_exists($theme->dir . '/screenshot.jpg')) {
$screenshotpath = $themename . '/screenshot.jpg';
}
if ($screenshotpath) {
$infoitems['screenshot'] = '<a href="' . $CFG->themewww .'/'. $screenshotpath . '">' .
get_string('screenshot') . '</a>';
}
// Link to the themes's readme.
$readmeurl = '';
if (file_exists($theme->dir . '/README.html')) {
$readmeurl = $CFG->themewww .'/'. $themename .'/README.html';
} else if (file_exists($theme->dir . '/README.txt')) {
$readmeurl = $CFG->themewww .'/'. $themename .'/README.txt';
}
if ($readmeurl) {
$infoitems['readme'] = link_to_popup_window($readmeurl, $themename, get_string('info'), 400, 500, '', 'none', true);
}
// Contents of the first screenshot/preview cell.
if ($screenshotpath) {
$row[] = '<object type="text/html" data="' . $CFG->themewww .'/' . $screenshotpath .
'" height="200" width="400">' . $themename . '</object>';
} else {
$row[] = '<object type="text/html" data="preview.php?preview=' . $themename .
'" height="200" width="400">' . $themename . '</object>';
}
// Contents of the second cell.
$infocell = $OUTPUT->heading($themename, 3);
if ($infoitems) {
$infocell .= "<ul>\n<li>" . implode("</li>\n<li>", $infoitems) . "</li>\n</ul>\n";
}
if ($themename != $CFG->theme) {
$infocell .= print_single_button('index.php', array('choose' => $themename, 'sesskey' => $sesskey),
get_string('choose'), 'get', null, true);
}
$row[] = $infocell;
$table->data[$themename] = $row;
if ($themename == $CFG->theme) {
$table->rowclass[$themename] = 'selectedtheme';
}
}
print_table($table);
admin_externalpage_print_footer();
?>