9a4d1dabf1a9f5b8605c2590e82bdbec2f62e018
[moodle.git] / theme / index.php
1 <?php
3 // This file is part of Moodle - http://moodle.org/
4 //
5 // Moodle is free software: you can redistribute it and/or modify
6 // it under the terms of the GNU General Public License as published by
7 // the Free Software Foundation, either version 3 of the License, or
8 // (at your option) any later version.
9 //
10 // Moodle is distributed in the hope that it will be useful,
11 // but WITHOUT ANY WARRANTY; without even the implied warranty of
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 // GNU General Public License for more details.
14 //
15 // You should have received a copy of the GNU General Public License
16 // along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
18 /**
19  * This page prvides the Administration -> ... -> Theme selector UI.
20  */
22 require_once(dirname(__FILE__) . '/../config.php');
23 require_once($CFG->libdir . '/adminlib.php');
25 $choose = optional_param('choose', '', PARAM_SAFEDIR);
26 $reset  = optional_param('reset', 0, PARAM_BOOL);
27 $device = optional_param('device', '', PARAM_TEXT);
29 admin_externalpage_setup('themeselector');
31 unset($SESSION->theme);
33 if ($reset and confirm_sesskey()) {
34     theme_reset_all_caches();
36 } else if ($choose && $device && confirm_sesskey()) {
38     $chosentheme = $choose;
39     $heading = get_string('themesaved');
40  
41     $theme = theme_config::load($chosentheme);
42     $themename = get_device_cfg_var_name($device);
44     set_config($themename, $theme->name);
46     // Create a new page for the display of the themes readme.
47     // This ensures that the readme page is shown using the new theme.
48     $confirmpage = new moodle_page();
49     $confirmpage->set_context($PAGE->context);
50     $confirmpage->set_url($PAGE->url);
51     $confirmpage->set_pagelayout($PAGE->pagelayout);
52     $confirmpage->set_pagetype($PAGE->pagetype);
53     $confirmpage->set_title($PAGE->title);
54     $confirmpage->set_heading($PAGE->heading);
56     // Get the core renderer for the new theme.
57     $output = $confirmpage->get_renderer('core');
59     echo $output->header();
60     echo $output->heading($heading);
61     echo $output->box_start();
62     echo format_text(get_string('choosereadme', 'theme_'.$theme->name), FORMAT_MOODLE);
63     echo $output->box_end();
64     echo $output->continue_button($CFG->wwwroot . '/' . $CFG->admin . '/index.php');
65     echo $output->footer();
66     exit;
67 }
69 // Otherwise, show either a list of devices, or is enabledevicedetection set to no or a
70 // device is specified show a list of themes.
72 echo $OUTPUT->header('themeselector');
73 echo $OUTPUT->heading(get_string('themes'));
75 echo $OUTPUT->single_button(new moodle_url('index.php', array('sesskey'=>sesskey(), 'reset'=>1)), get_string('themeresetcaches', 'admin'));
77 if ($CFG->enabledevicedetection && empty($device)) {
78     $table = new html_table();
79     $table->id = 'devicethemeselector';
80     $table->head = array(get_string('devicetype', 'admin'), get_string('theme'), get_string('info'));
82     $devices = get_device_type_list();
84     foreach ($devices as $device) {
85         $row = array();
86         $row[] = $device;
88         $themename = get_selected_theme_for_device_type($device);
90         if (!$themename && $device == 'default') {
91             $themename = theme_config::DEFAULT_THEME;
92         }
94         if ($themename) {
95             $strthemename = get_string('pluginname', 'theme_'.$themename);
96             // link to the screenshot, now mandatory - the image path is hardcoded because we need image from other themes, not the current one
97             $screenshotpath = new moodle_url('/theme/image.php', array('theme'=>$themename, 'image'=>'screenshot', 'component'=>'theme'));
98             // Contents of the first screenshot/preview cell.
99             $row[] = html_writer::empty_tag('img', array('src'=>$screenshotpath, 'alt'=>$strthemename));
100         } else {
101             $row[] = get_string('themenoselected', 'admin');
102         }
104         $select = new single_button(new moodle_url('/theme/index.php', array('device' => $device, 'sesskey' => sesskey())), get_string('themeselect', 'admin'), 'get');
106         $row[] = $OUTPUT->render($select);
108         $table->data[$device] = $row;
109     }
111     echo html_writer::table($table);
112     echo $OUTPUT->footer();
114     exit;
117 //if $CFG->enabledevicedetection is set to no, then this will return the default device type.
118 if (empty($device)) {
119     $device = get_device_type();
122 $table = new html_table();
123 $table->id = 'adminthemeselector';
124 $table->head = array(get_string('theme'), get_string('info'));
126 $themes = get_plugin_list('theme');
128 foreach ($themes as $themename => $themedir) {
129     // Load the theme config.
130     try {
131         $theme = theme_config::load($themename);
132     } catch (Exception $e) {
133         // Bad theme, just skip it for now.
134         continue;
135     }
137     if ($themename !== $theme->name) {
138         //obsoleted or broken theme, just skip for now
139         continue;
140     }
141     if (!$CFG->themedesignermode && $theme->hidefromselector) {
142         // The theme doesn't want to be shown in the theme selector and as theme
143         // designer mode is switched off we will respect that decision.
144         continue;
145     }
146     $strthemename = get_string('pluginname', 'theme_'.$themename);
148     // Build the table row, and also a list of items to go in the second cell.
149     $row = array();
150     $infoitems = array();
151     $rowclasses = array();
153     // Set up bools whether this theme is chosen either main or legacy
154     $ischosentheme = ($themename == get_selected_theme_for_device_type($device));
156     if ($ischosentheme) {
157         // Is the chosen main theme
158         $rowclasses[] = 'selectedtheme';
159     }
161     // link to the screenshot, now mandatory - the image path is hardcoded because we need image from other themes, not the current one
162     $screenshotpath = new moodle_url('/theme/image.php', array('theme'=>$themename, 'image'=>'screenshot', 'component'=>'theme'));
163     // Contents of the first screenshot/preview cell.
164     $row[] = html_writer::empty_tag('img', array('src'=>$screenshotpath, 'alt'=>$strthemename));
165     // Contents of the second cell.
166     $infocell = $OUTPUT->heading($strthemename, 3);
168     // Button to choose this as the main theme
169     $maintheme = new single_button(new moodle_url('/theme/index.php', array('device' => $device, 'choose' => $themename, 'sesskey' => sesskey())), get_string('usetheme'), 'get');
170     $maintheme->disabled = $ischosentheme;
171     $infocell .= $OUTPUT->render($maintheme);
173     $row[] = $infocell;
175     $table->data[$themename] = $row;
176     $table->rowclasses[$themename] = join(' ', $rowclasses);
179 echo html_writer::table($table);
181 echo $OUTPUT->footer();