themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
<?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/>.
|
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
/**
|
|
|
|
* Functions for generating the HTML that Moodle should output.
|
|
|
|
*
|
|
|
|
* Please see http://docs.moodle.org/en/Developement:How_Moodle_outputs_HTML
|
|
|
|
* for an overview.
|
|
|
|
*
|
|
|
|
* @package moodlecore
|
|
|
|
* @copyright 2009 Tim Hunt
|
|
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
|
|
*/
|
|
|
|
|
2009-08-10 06:22:04 +00:00
|
|
|
require_once($CFG->libdir.'/outputcomponents.php');
|
|
|
|
require_once($CFG->libdir.'/outputactions.php');
|
|
|
|
require_once($CFG->libdir.'/outputfactories.php');
|
|
|
|
require_once($CFG->libdir.'/outputrenderers.php');
|
2010-02-07 08:45:21 +00:00
|
|
|
require_once($CFG->libdir.'/outputrequirementslib.php');
|
2009-08-10 06:22:04 +00:00
|
|
|
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* Invalidate all server and client side caches.
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function theme_reset_all_caches() {
|
|
|
|
global $CFG;
|
|
|
|
require_once("$CFG->libdir/filelib.php");
|
|
|
|
|
|
|
|
set_config('themerev', empty($CFG->themerev) ? 1 : $CFG->themerev+1);
|
|
|
|
fulldelete("$CFG->dataroot/cache/theme");
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Enable or disable theme designer mode.
|
|
|
|
* @param bool $state
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function theme_set_designer_mod($state) {
|
|
|
|
theme_reset_all_caches();
|
|
|
|
set_config('themedesignermode', (int)!empty($state));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns current theme revision number.
|
|
|
|
* @return int
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
*/
|
2009-12-16 18:00:58 +00:00
|
|
|
function theme_get_revision() {
|
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
if (empty($CFG->themedesignermode)) {
|
|
|
|
if (empty($CFG->themerev)) {
|
|
|
|
return -1;
|
|
|
|
} else {
|
|
|
|
return $CFG->themerev;
|
|
|
|
}
|
|
|
|
|
|
|
|
} else {
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
|
|
|
|
/**
|
2009-07-07 05:05:06 +00:00
|
|
|
* This class represents the configuration variables of a Moodle theme.
|
|
|
|
*
|
|
|
|
* All the variables with access: public below (with a few exceptions that are marked)
|
|
|
|
* are the properties you can set in your theme's config.php file.
|
|
|
|
*
|
|
|
|
* There are also some methods and protected variables that are part of the inner
|
|
|
|
* workings of Moodle's themes system. If you are just editing a theme's config.php
|
2009-07-23 02:33:58 +00:00
|
|
|
* file, you can just ignore those, and the following information for developers.
|
2009-07-02 08:49:25 +00:00
|
|
|
*
|
|
|
|
* Normally, to create an instance of this class, you should use the
|
|
|
|
* {@link theme_config::load()} factory method to load a themes config.php file.
|
2009-07-23 02:33:58 +00:00
|
|
|
* However, normally you don't need to bother, because moodle_page (that is, $PAGE)
|
2009-07-07 05:05:06 +00:00
|
|
|
* will create one for you, accessible as $PAGE->theme.
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
*
|
|
|
|
* @copyright 2009 Tim Hunt
|
|
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
|
|
* @since Moodle 2.0
|
|
|
|
*/
|
2009-07-02 08:49:25 +00:00
|
|
|
class theme_config {
|
2010-01-12 17:21:52 +00:00
|
|
|
/**
|
|
|
|
* @var string default theme, used when requested theme not found
|
|
|
|
*/
|
2010-03-25 06:38:21 +00:00
|
|
|
const DEFAULT_THEME = 'standard';
|
2010-01-12 17:21:52 +00:00
|
|
|
|
2009-07-02 08:49:25 +00:00
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* You can base your theme on other themes by linking to the other theme as
|
|
|
|
* parents. This lets you use the CSS and layouts from the other themes
|
|
|
|
* (see {@link $layouts}).
|
2009-07-07 05:05:06 +00:00
|
|
|
* That makes it easy to create a new theme that is similar to another one
|
|
|
|
* but with a few changes. In this theme's CSS you only need to override
|
|
|
|
* those rules you want to change.
|
|
|
|
*
|
2009-12-16 18:00:58 +00:00
|
|
|
* @var array
|
2009-07-07 05:05:06 +00:00
|
|
|
*/
|
2009-12-16 18:00:58 +00:00
|
|
|
public $parents;
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
|
2009-07-07 05:05:06 +00:00
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* The names of all the stylesheets from this theme that you would
|
|
|
|
* like included, in order. Give the names of the files without .css.
|
2009-07-07 05:05:06 +00:00
|
|
|
*
|
2009-12-16 18:00:58 +00:00
|
|
|
* @var array
|
2009-07-07 05:05:06 +00:00
|
|
|
*/
|
2009-12-16 18:00:58 +00:00
|
|
|
public $sheets = array();
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
|
2009-07-07 05:05:06 +00:00
|
|
|
/**
|
2010-01-11 10:02:14 +00:00
|
|
|
* The names of all the stylesheets from parents that should be excluded.
|
2009-12-16 18:00:58 +00:00
|
|
|
* true value may be used to specify all parents or all themes from one parent.
|
|
|
|
* If no value specified value from parent theme used.
|
2009-07-07 05:05:06 +00:00
|
|
|
*
|
2009-12-16 18:00:58 +00:00
|
|
|
* @var array or arrays, true means all, null means use value from parent
|
2009-07-07 05:05:06 +00:00
|
|
|
*/
|
2009-12-16 18:00:58 +00:00
|
|
|
public $parents_exclude_sheets = null;
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
|
2009-07-07 05:05:06 +00:00
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* List of plugin sheets to be excluded.
|
|
|
|
* If no value specified value from parent theme used.
|
|
|
|
*
|
|
|
|
* @var array of full plugin names, null means use value from parent
|
2009-07-07 05:05:06 +00:00
|
|
|
*/
|
2009-12-16 18:00:58 +00:00
|
|
|
public $plugins_exclude_sheets = null;
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
|
2009-07-07 05:05:06 +00:00
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* List of style sheets that are included in the text editor bodies.
|
|
|
|
* Sheets from parent themes are used automatically and can not be excluded.
|
2009-07-07 05:05:06 +00:00
|
|
|
*
|
2009-12-16 18:00:58 +00:00
|
|
|
* @var array
|
2009-07-07 05:05:06 +00:00
|
|
|
*/
|
2009-12-16 18:00:58 +00:00
|
|
|
public $editor_sheets = array();
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
|
2009-12-20 21:50:46 +00:00
|
|
|
/**
|
|
|
|
* The names of all the javascript files this theme that you would
|
2010-01-05 23:22:16 +00:00
|
|
|
* like included from head, in order. Give the names of the files without .js.
|
2009-12-20 21:50:46 +00:00
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
public $javascripts = array();
|
|
|
|
|
2010-01-05 23:22:16 +00:00
|
|
|
/**
|
|
|
|
* The names of all the javascript files this theme that you would
|
|
|
|
* like included from footer, in order. Give the names of the files without .js.
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
public $javascripts_footer = array();
|
2010-04-15 14:43:25 +00:00
|
|
|
|
2009-12-20 21:50:46 +00:00
|
|
|
/**
|
2010-01-11 10:03:16 +00:00
|
|
|
* The names of all the javascript files from parents that should be excluded.
|
2009-12-20 21:50:46 +00:00
|
|
|
* true value may be used to specify all parents or all themes from one parent.
|
|
|
|
* If no value specified value from parent theme used.
|
|
|
|
*
|
|
|
|
* @var array or arrays, true means all, null means use value from parent
|
|
|
|
*/
|
|
|
|
public $parents_exclude_javascripts = null;
|
|
|
|
|
2009-07-07 05:05:06 +00:00
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* Which file to use for each page layout.
|
2009-07-07 05:05:06 +00:00
|
|
|
*
|
2009-12-16 18:00:58 +00:00
|
|
|
* This is an array of arrays. The keys of the outer array are the different layouts.
|
|
|
|
* Pages in Moodle are using several different layouts like 'normal', 'course', 'home',
|
|
|
|
* 'popup', 'form', .... The most reliable way to get a complete list is to look at
|
|
|
|
* {@link http://cvs.moodle.org/moodle/theme/base/config.php?view=markup the base theme config.php file}.
|
2009-07-09 07:35:03 +00:00
|
|
|
* That file also has a good example of how to set this setting.
|
2009-07-07 05:05:06 +00:00
|
|
|
*
|
2009-12-16 18:00:58 +00:00
|
|
|
* For each layout, the value in the outer array is an array that describes
|
2009-07-09 07:35:03 +00:00
|
|
|
* how you want that type of page to look. For example
|
|
|
|
* <pre>
|
|
|
|
* $THEME->layouts = array(
|
2010-01-11 10:04:39 +00:00
|
|
|
* // Most pages - if we encounter an unknown or a missing page type, this one is used.
|
2009-12-27 12:02:04 +00:00
|
|
|
* 'standard' => array(
|
2009-12-16 18:00:58 +00:00
|
|
|
* 'theme' = 'mytheme',
|
|
|
|
* 'file' => 'normal.php',
|
2009-07-09 07:35:03 +00:00
|
|
|
* 'regions' => array('side-pre', 'side-post'),
|
|
|
|
* 'defaultregion' => 'side-post'
|
|
|
|
* ),
|
|
|
|
* // The site home page.
|
|
|
|
* 'home' => array(
|
2009-12-16 18:00:58 +00:00
|
|
|
* 'theme' = 'mytheme',
|
|
|
|
* 'file' => 'home.php',
|
2009-07-09 07:35:03 +00:00
|
|
|
* 'regions' => array('side-pre', 'side-post'),
|
|
|
|
* 'defaultregion' => 'side-post'
|
|
|
|
* ),
|
|
|
|
* // ...
|
|
|
|
* );
|
|
|
|
* </pre>
|
2009-07-07 05:05:06 +00:00
|
|
|
*
|
2009-12-16 18:00:58 +00:00
|
|
|
* 'theme' name of the theme where is the layout located
|
|
|
|
* 'file' is the layout file to use for this type of page.
|
|
|
|
* layout files are stored in layout subfolder
|
2009-07-09 07:35:03 +00:00
|
|
|
* 'regions' This lists the regions on the page where blocks may appear. For
|
|
|
|
* each region you list here, your layout file must include a call to
|
|
|
|
* <pre>
|
|
|
|
* echo $OUTPUT->blocks_for_region($regionname);
|
|
|
|
* </pre>
|
|
|
|
* or equivalent so that the blocks are actually visible.
|
2009-07-07 05:05:06 +00:00
|
|
|
*
|
2009-07-09 07:35:03 +00:00
|
|
|
* 'defaultregion' If the list of regions is non-empty, then you must pick
|
|
|
|
* one of the one of them as 'default'. This has two meanings. First, this is
|
|
|
|
* where new blocks are added. Second, if there are any blocks associated with
|
2009-07-23 02:33:58 +00:00
|
|
|
* the page, but in non-existent regions, they appear here. (Imaging, for example,
|
2009-07-09 07:35:03 +00:00
|
|
|
* that someone added blocks using a different theme that used different region
|
|
|
|
* names, and then switched to this theme.)
|
2009-07-07 05:05:06 +00:00
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
2009-07-09 07:35:03 +00:00
|
|
|
public $layouts = array();
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
|
2009-07-07 05:05:06 +00:00
|
|
|
/**
|
|
|
|
* With this you can control the colours of the big MP3 player
|
|
|
|
* that is used for MP3 resources.
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
2009-07-02 08:49:25 +00:00
|
|
|
public $resource_mp3player_colors = 'bgColour=000000&btnColour=ffffff&btnBorderColour=cccccc&iconColour=000000&iconOverColour=00cc00&trackColour=cccccc&handleColour=ffffff&loaderColour=ffffff&font=Arial&fontColour=3333FF&buffer=10&waitForPlay=no&autoPlay=yes';
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
|
2009-07-07 05:05:06 +00:00
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* With this you can control the colours of the small MP3 player
|
|
|
|
* that is used elsewhere.
|
|
|
|
*
|
2009-07-07 05:05:06 +00:00
|
|
|
* @var string
|
|
|
|
*/
|
2009-07-02 08:49:25 +00:00
|
|
|
public $filter_mediaplugin_colors = 'bgColour=000000&btnColour=ffffff&btnBorderColour=cccccc&iconColour=000000&iconOverColour=00cc00&trackColour=cccccc&handleColour=ffffff&loaderColour=ffffff&waitForPlay=yes';
|
|
|
|
|
2009-07-07 05:05:06 +00:00
|
|
|
/**
|
|
|
|
* Name of the renderer factory class to use.
|
|
|
|
*
|
|
|
|
* This is an advanced feature. Moodle output is generated by 'renderers',
|
|
|
|
* you can customise the HTML that is output by writing custom renderers,
|
|
|
|
* and then you need to specify 'renderer factory' so that Moodle can find
|
|
|
|
* your renderers.
|
|
|
|
*
|
|
|
|
* There are some renderer factories supplied with Moodle. Please follow these
|
|
|
|
* links to see what they do.
|
|
|
|
* <ul>
|
|
|
|
* <li>{@link standard_renderer_factory} - the default.</li>
|
|
|
|
* <li>{@link theme_overridden_renderer_factory} - use this if you want to write
|
2009-12-16 18:00:58 +00:00
|
|
|
* your own custom renderers in a lib.php file in this theme (or the parent theme).</li>
|
2009-07-07 05:05:06 +00:00
|
|
|
* </ul>
|
|
|
|
*
|
|
|
|
* @var string name of a class implementing the {@link renderer_factory} interface.
|
|
|
|
*/
|
2009-07-02 08:49:25 +00:00
|
|
|
public $rendererfactory = 'standard_renderer_factory';
|
|
|
|
|
2009-07-07 05:05:06 +00:00
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* Function to do custom CSS post-processing.
|
2009-07-07 05:05:06 +00:00
|
|
|
*
|
2009-12-16 18:00:58 +00:00
|
|
|
* This is an advanced feature. If you want to do custom post-processing on the
|
|
|
|
* CSS before it is output (for example, to replace certain variable names
|
|
|
|
* with particular values) you can give the name of a function here.
|
2009-07-07 05:05:06 +00:00
|
|
|
*
|
2009-12-16 18:00:58 +00:00
|
|
|
* @var string the name of a function.
|
2009-07-07 05:05:06 +00:00
|
|
|
*/
|
2009-12-16 18:00:58 +00:00
|
|
|
public $csspostprocess = null;
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
|
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* Accessibility: Right arrow-like character is
|
|
|
|
* used in the breadcrumb trail, course navigation menu
|
|
|
|
* (previous/next activity), calendar, and search forum block.
|
|
|
|
* If the theme does not set characters, appropriate defaults
|
|
|
|
* are set automatically. Please DO NOT
|
|
|
|
* use < > » - these are confusing for blind users.
|
2009-07-07 05:05:06 +00:00
|
|
|
*
|
2009-12-16 18:00:58 +00:00
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
public $rarrow = null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Accessibility: Right arrow-like character is
|
|
|
|
* used in the breadcrumb trail, course navigation menu
|
|
|
|
* (previous/next activity), calendar, and search forum block.
|
|
|
|
* If the theme does not set characters, appropriate defaults
|
|
|
|
* are set automatically. Please DO NOT
|
|
|
|
* use < > » - these are confusing for blind users.
|
2009-07-02 08:49:25 +00:00
|
|
|
*
|
2009-12-16 18:00:58 +00:00
|
|
|
* @var string
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
*/
|
2009-12-16 18:00:58 +00:00
|
|
|
public $larrow = null;
|
|
|
|
|
|
|
|
|
|
|
|
//==Following properties are not configurable from theme config.php==
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
|
2009-07-07 05:05:06 +00:00
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* The name of this theme. Set automatically when this theme is
|
|
|
|
* loaded. This can not be set in theme config.php
|
|
|
|
* @var string
|
2009-07-07 05:05:06 +00:00
|
|
|
*/
|
2009-12-16 18:00:58 +00:00
|
|
|
public $name;
|
2009-07-07 05:05:06 +00:00
|
|
|
|
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* the folder where this themes files are stored. This is set
|
|
|
|
* automatically. This can not be set in theme config.php
|
|
|
|
* @var string
|
2009-07-07 05:05:06 +00:00
|
|
|
*/
|
2009-12-16 18:00:58 +00:00
|
|
|
public $dir;
|
2009-07-07 05:05:06 +00:00
|
|
|
|
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* Theme settings stored in config_plugins table.
|
|
|
|
* This can not be set in theme config.php
|
|
|
|
* @var object
|
|
|
|
*/
|
|
|
|
public $setting = null;
|
|
|
|
|
2010-01-14 06:56:12 +00:00
|
|
|
/**
|
|
|
|
* If set to true and the theme enables the dock then blocks will be able
|
|
|
|
* to be moved to the special dock
|
|
|
|
* @var bool
|
|
|
|
*/
|
|
|
|
public $enable_dock = false;
|
|
|
|
|
2010-04-28 03:32:16 +00:00
|
|
|
/**
|
|
|
|
* If set to true then this theme will not be shown in the theme selector unless
|
|
|
|
* theme designer mode is turned on.
|
|
|
|
* @var bool
|
|
|
|
*/
|
|
|
|
public $hidefromselector = false;
|
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
/**
|
|
|
|
* Instance of the renderer_factory implementation
|
2009-07-07 05:05:06 +00:00
|
|
|
* we are using. Implementation detail.
|
2009-12-16 18:00:58 +00:00
|
|
|
* @var renderer_factory
|
2009-07-07 05:05:06 +00:00
|
|
|
*/
|
|
|
|
protected $rf = null;
|
|
|
|
|
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* List of parent config objects.
|
|
|
|
* @var array list of parent configs
|
|
|
|
**/
|
|
|
|
protected $parent_configs = array();
|
2009-07-07 05:05:06 +00:00
|
|
|
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
/**
|
2009-07-02 08:49:25 +00:00
|
|
|
* Load the config.php file for a particular theme, and return an instance
|
|
|
|
* of this class. (That is, this is a factory method.)
|
|
|
|
*
|
|
|
|
* @param string $themename the name of the theme.
|
|
|
|
* @return theme_config an instance of this class.
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
*/
|
2009-07-02 08:49:25 +00:00
|
|
|
public static function load($themename) {
|
|
|
|
global $CFG;
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
// load theme settings from db
|
|
|
|
try {
|
|
|
|
$settings = get_config('theme_'.$themename);
|
|
|
|
} catch (dml_exception $e) {
|
2009-12-17 20:11:39 +00:00
|
|
|
// most probably moodle tables not created yet
|
2009-12-16 18:00:58 +00:00
|
|
|
$settings = new object();
|
|
|
|
}
|
2009-07-02 08:49:25 +00:00
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
if ($config = theme_config::find_theme_config($themename, $settings)) {
|
|
|
|
return new theme_config($config);
|
2010-01-12 17:21:52 +00:00
|
|
|
|
|
|
|
} else if ($themename == theme_config::DEFAULT_THEME) {
|
|
|
|
throw new coding_exception('Default theme '.theme_config::DEFAULT_THEME.' not available or broken!');
|
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
} else {
|
|
|
|
// bad luck, the requested theme has some problems - admin see details in theme config
|
2010-01-12 17:21:52 +00:00
|
|
|
return new theme_config(theme_config::find_theme_config(theme_config::DEFAULT_THEME, $settings));
|
2009-12-16 18:00:58 +00:00
|
|
|
}
|
|
|
|
}
|
2009-07-02 08:49:25 +00:00
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
/**
|
|
|
|
* Theme diagnostic code. It is very problematic to send debug output
|
|
|
|
* to the actual CSS file, instead this functions is supposed to
|
2010-01-11 10:06:56 +00:00
|
|
|
* diagnose given theme and highlights all potential problems.
|
2009-12-16 18:00:58 +00:00
|
|
|
* This information should be available from the theme selection page
|
|
|
|
* or some other debug page for theme designers.
|
|
|
|
*
|
|
|
|
* @param string $themename
|
|
|
|
* @return array description of problems
|
|
|
|
*/
|
|
|
|
public static function diagnose($themename) {
|
2009-12-17 20:06:35 +00:00
|
|
|
//TODO: MDL-21108
|
2009-12-16 18:00:58 +00:00
|
|
|
return array();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Private constructor, can be called only from the factory method.
|
|
|
|
* @param stdClass $config
|
|
|
|
*/
|
|
|
|
private function __construct($config) {
|
|
|
|
global $CFG; //needed for included lib.php files
|
|
|
|
|
|
|
|
$this->settings = $config->settings;
|
|
|
|
$this->name = $config->name;
|
|
|
|
$this->dir = $config->dir;
|
|
|
|
|
|
|
|
if ($this->name != 'base') {
|
|
|
|
$baseconfig = theme_config::find_theme_config('base', $this->settings);
|
|
|
|
} else {
|
|
|
|
$baseconfig = $config;
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
}
|
2009-07-02 08:49:25 +00:00
|
|
|
|
2010-01-13 03:00:11 +00:00
|
|
|
$configurable = array('parents', 'sheets', 'parents_exclude_sheets', 'plugins_exclude_sheets', 'javascripts', 'javascripts_footer',
|
2010-01-14 06:56:12 +00:00
|
|
|
'parents_exclude_javascripts', 'layouts', 'resource_mp3player_colors', 'enable_dock',
|
2010-04-28 03:32:16 +00:00
|
|
|
'filter_mediaplugin_colors', 'rendererfactory', 'csspostprocess', 'editor_sheets', 'rarrow', 'larrow', 'hidefromselector');
|
2009-07-02 08:49:25 +00:00
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
foreach ($config as $key=>$value) {
|
|
|
|
if (in_array($key, $configurable)) {
|
|
|
|
$this->$key = $value;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// verify all parents and load configs and renderers
|
|
|
|
foreach ($this->parents as $parent) {
|
|
|
|
if ($parent == 'base') {
|
|
|
|
$parent_config = $baseconfig;
|
|
|
|
} else if (!$parent_config = theme_config::find_theme_config($parent, $this->settings)) {
|
|
|
|
// this is not good - better exclude faulty parents
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$libfile = $parent_config->dir.'/lib.php';
|
|
|
|
if (is_readable($libfile)) {
|
|
|
|
// theme may store various function here
|
|
|
|
include_once($libfile);
|
|
|
|
}
|
|
|
|
$renderersfile = $parent_config->dir.'/renderers.php';
|
|
|
|
if (is_readable($renderersfile)) {
|
|
|
|
// may contain core and plugin renderers and renderer factory
|
|
|
|
include_once($renderersfile);
|
|
|
|
}
|
|
|
|
$this->parent_configs[$parent] = $parent_config;
|
|
|
|
$rendererfile = $parent_config->dir.'/renderers.php';
|
|
|
|
if (is_readable($rendererfile)) {
|
|
|
|
// may contain core and plugin renderers and renderer factory
|
|
|
|
include_once($rendererfile);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$libfile = $this->dir.'/lib.php';
|
|
|
|
if (is_readable($libfile)) {
|
|
|
|
// theme may store various function here
|
|
|
|
include_once($libfile);
|
|
|
|
}
|
|
|
|
$rendererfile = $this->dir.'/renderers.php';
|
|
|
|
if (is_readable($rendererfile)) {
|
|
|
|
// may contain core and plugin renderers and renderer factory
|
|
|
|
include_once($rendererfile);
|
|
|
|
}
|
2010-04-15 14:43:25 +00:00
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
// cascade all layouts properly
|
|
|
|
foreach ($baseconfig->layouts as $layout=>$value) {
|
|
|
|
if (!isset($this->layouts[$layout])) {
|
|
|
|
foreach ($this->parent_configs as $parent_config) {
|
|
|
|
if (isset($parent_config->layouts[$layout])) {
|
|
|
|
$this->layouts[$layout] = $parent_config->layouts[$layout];
|
|
|
|
continue 2;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$this->layouts[$layout] = $value;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//fix arrows if needed
|
|
|
|
$this->check_theme_arrows();
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
}
|
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
/*
|
|
|
|
* Checks if arrows $THEME->rarrow, $THEME->larrow have been set (theme/-/config.php).
|
|
|
|
* If not it applies sensible defaults.
|
|
|
|
*
|
|
|
|
* Accessibility: right and left arrow Unicode characters for breadcrumb, calendar,
|
|
|
|
* search forum block, etc. Important: these are 'silent' in a screen-reader
|
|
|
|
* (unlike > »), and must be accompanied by text.
|
2009-06-26 09:06:16 +00:00
|
|
|
*/
|
2009-12-16 18:00:58 +00:00
|
|
|
private function check_theme_arrows() {
|
|
|
|
if (!isset($this->rarrow) and !isset($this->larrow)) {
|
|
|
|
// Default, looks good in Win XP/IE 6, Win/Firefox 1.5, Win/Netscape 8...
|
|
|
|
// Also OK in Win 9x/2K/IE 5.x
|
|
|
|
$this->rarrow = '►';
|
|
|
|
$this->larrow = '◄';
|
|
|
|
if (empty($_SERVER['HTTP_USER_AGENT'])) {
|
|
|
|
$uagent = '';
|
2009-07-02 08:49:25 +00:00
|
|
|
} else {
|
2009-12-16 18:00:58 +00:00
|
|
|
$uagent = $_SERVER['HTTP_USER_AGENT'];
|
|
|
|
}
|
|
|
|
if (false !== strpos($uagent, 'Opera')
|
|
|
|
|| false !== strpos($uagent, 'Mac')) {
|
|
|
|
// Looks good in Win XP/Mac/Opera 8/9, Mac/Firefox 2, Camino, Safari.
|
|
|
|
// Not broken in Mac/IE 5, Mac/Netscape 7 (?).
|
|
|
|
$this->rarrow = '▶';
|
|
|
|
$this->larrow = '◀';
|
|
|
|
}
|
|
|
|
elseif (false !== strpos($uagent, 'Konqueror')) {
|
|
|
|
$this->rarrow = '→';
|
|
|
|
$this->larrow = '←';
|
|
|
|
}
|
|
|
|
elseif (isset($_SERVER['HTTP_ACCEPT_CHARSET'])
|
|
|
|
&& false === stripos($_SERVER['HTTP_ACCEPT_CHARSET'], 'utf-8')) {
|
|
|
|
// (Win/IE 5 doesn't set ACCEPT_CHARSET, but handles Unicode.)
|
|
|
|
// To be safe, non-Unicode browsers!
|
|
|
|
$this->rarrow = '>';
|
|
|
|
$this->larrow = '<';
|
|
|
|
}
|
|
|
|
|
|
|
|
/// RTL support - in RTL languages, swap r and l arrows
|
|
|
|
if (right_to_left()) {
|
|
|
|
$t = $this->rarrow;
|
|
|
|
$this->rarrow = $this->larrow;
|
|
|
|
$this->larrow = $t;
|
2009-07-02 08:49:25 +00:00
|
|
|
}
|
|
|
|
}
|
2009-12-16 18:00:58 +00:00
|
|
|
}
|
2009-07-02 08:49:25 +00:00
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
/**
|
|
|
|
* Returns output renderer prefixes, these are used when looking
|
|
|
|
* for the overriden renderers in themes.
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function renderer_prefixes() {
|
|
|
|
global $CFG; // just in case the included files need it
|
|
|
|
|
2009-12-29 12:23:39 +00:00
|
|
|
$prefixes = array('theme_'.$this->name);
|
2009-12-16 18:00:58 +00:00
|
|
|
|
|
|
|
foreach ($this->parent_configs as $parent) {
|
|
|
|
$prefixes[] = 'theme_'.$parent->name;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $prefixes;
|
2009-06-26 09:06:16 +00:00
|
|
|
}
|
|
|
|
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* Returns the stylesheet URL of this editor content
|
|
|
|
* @param bool $encoded false means use & and true use & in URLs
|
|
|
|
* @return string
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
*/
|
2009-12-16 18:00:58 +00:00
|
|
|
public function editor_css_url($encoded=true) {
|
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
$rev = theme_get_revision();
|
|
|
|
|
|
|
|
if ($rev > -1) {
|
|
|
|
$params = array('theme'=>$this->name,'rev'=>$rev, 'type'=>'editor');
|
|
|
|
return new moodle_url($CFG->httpswwwroot.'/theme/styles.php', $params);
|
|
|
|
} else {
|
|
|
|
$params = array('theme'=>$this->name, 'type'=>'editor');
|
|
|
|
return new moodle_url($CFG->httpswwwroot.'/theme/styles_debug.php', $params);
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* Returns the content of the CSS to be used in editor content
|
|
|
|
* @return string
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
*/
|
2009-12-16 18:00:58 +00:00
|
|
|
public function editor_css_content() {
|
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
$css = '';
|
|
|
|
|
|
|
|
// first editor plugins
|
|
|
|
$plugins = get_plugin_list('editor');
|
|
|
|
foreach ($plugins as $plugin=>$fulldir) {
|
|
|
|
$sheetfile = "$fulldir/editor_styles.css";
|
|
|
|
if (is_readable($sheetfile)) {
|
|
|
|
$css .= "/*** Editor $plugin content CSS ***/\n\n" . file_get_contents($sheetfile) . "\n\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// then parent themes
|
|
|
|
foreach (array_reverse($this->parent_configs) as $parent_config) { // base first, the immediate parent last
|
|
|
|
if (empty($parent_config->editor_sheets)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
foreach ($parent_config->editor_sheets as $sheet) {
|
|
|
|
$sheetfile = "$parent_config->dir/$sheet.css";
|
|
|
|
if (is_readable($sheetfile)) {
|
|
|
|
$css .= "/*** Parent theme $parent/$sheet ***/\n\n" . file_get_contents($sheetfile) . "\n\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// finally this theme
|
|
|
|
if (!empty($this->editor_sheets)) {
|
|
|
|
foreach ($this->editor_sheets as $sheet) {
|
|
|
|
$sheetfile = "$this->dir/$sheet.css";
|
|
|
|
if (is_readable($sheetfile)) {
|
|
|
|
$css .= "/*** Theme $sheet ***/\n\n" . file_get_contents($sheetfile) . "\n\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->post_process($css);
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* Get the stylesheet URL of this theme
|
|
|
|
* @param bool $encoded false means use & and true use & in URLs
|
2009-12-20 21:50:46 +00:00
|
|
|
* @return array of moodle_url
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
*/
|
2010-01-05 00:33:15 +00:00
|
|
|
public function css_urls(moodle_page $page) {
|
2009-12-16 18:00:58 +00:00
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
$rev = theme_get_revision();
|
|
|
|
|
2010-01-05 00:33:15 +00:00
|
|
|
$urls = array();
|
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
if ($rev > -1) {
|
|
|
|
if (check_browser_version('MSIE', 5) and !check_browser_version('MSIE', 8)) {
|
2010-05-10 07:47:52 +00:00
|
|
|
// We need to split the CSS files for IE
|
|
|
|
$urls[] = new moodle_url($CFG->httpswwwroot.'/theme/styles.php', array('theme'=>$this->name,'rev'=>$rev, 'type'=>'plugins'));
|
|
|
|
$urls[] = new moodle_url($CFG->httpswwwroot.'/theme/styles.php', array('theme'=>$this->name,'rev'=>$rev, 'type'=>'parents'));
|
|
|
|
$urls[] = new moodle_url($CFG->httpswwwroot.'/theme/styles.php', array('theme'=>$this->name,'rev'=>$rev, 'type'=>'theme'));
|
|
|
|
} else {
|
|
|
|
$urls[] = new moodle_url($CFG->httpswwwroot.'/theme/styles.php', array('theme'=>$this->name,'rev'=>$rev));
|
2009-12-16 18:00:58 +00:00
|
|
|
}
|
|
|
|
} else {
|
2009-12-29 12:04:31 +00:00
|
|
|
// find out the current CSS and cache it now for 5 seconds
|
|
|
|
// the point is to construct the CSS only once and pass it through the
|
|
|
|
// dataroot to the script that actually serves the sheets
|
2009-12-29 12:14:42 +00:00
|
|
|
if (!defined('THEME_DESIGNER_CACHE_LIFETIME')) {
|
|
|
|
define('THEME_DESIGNER_CACHE_LIFETIME', 4); // this can be also set in config.php
|
|
|
|
}
|
2009-12-29 12:04:31 +00:00
|
|
|
$candidatesheet = "$CFG->dataroot/cache/theme/$this->name/designer.ser";
|
|
|
|
if (!file_exists($candidatesheet)) {
|
|
|
|
$css = $this->css_content();
|
|
|
|
check_dir_exists(dirname($candidatesheet), true, true);
|
|
|
|
file_put_contents($candidatesheet, serialize($css));
|
|
|
|
|
2009-12-29 12:14:42 +00:00
|
|
|
} else if (filemtime($candidatesheet) > time() - THEME_DESIGNER_CACHE_LIFETIME) {
|
2009-12-29 12:04:31 +00:00
|
|
|
if ($css = file_get_contents($candidatesheet)) {
|
|
|
|
$css = unserialize($css);
|
|
|
|
} else {
|
|
|
|
unlink($candidatesheet);
|
|
|
|
$css = $this->css_content();
|
|
|
|
}
|
|
|
|
|
|
|
|
} else {
|
|
|
|
unlink($candidatesheet);
|
|
|
|
$css = $this->css_content();
|
|
|
|
file_put_contents($candidatesheet, serialize($css));
|
|
|
|
}
|
|
|
|
|
2010-01-05 17:29:43 +00:00
|
|
|
$baseurl = $CFG->httpswwwroot.'/theme/styles_debug.php';
|
2010-02-08 16:50:12 +00:00
|
|
|
|
|
|
|
if (check_browser_version('MSIE', 5)) {
|
|
|
|
// lalala, IE does not allow more than 31 linked CSS files from main document
|
2010-04-15 14:43:25 +00:00
|
|
|
$urls[] = new moodle_url($CFG->httpswwwroot.'/theme/styles_debug.php', array('theme'=>$this->name, 'type'=>'ie', 'subtype'=>'plugins'));
|
|
|
|
$urls[] = new moodle_url($CFG->httpswwwroot.'/theme/styles_debug.php', array('theme'=>$this->name, 'type'=>'ie', 'subtype'=>'parents'));
|
|
|
|
$urls[] = new moodle_url($CFG->httpswwwroot.'/theme/styles_debug.php', array('theme'=>$this->name, 'type'=>'ie', 'subtype'=>'theme'));
|
2010-02-08 16:50:12 +00:00
|
|
|
|
|
|
|
} else {
|
|
|
|
foreach ($css['plugins'] as $plugin=>$unused) {
|
|
|
|
$urls[] = new moodle_url($baseurl, array('theme'=>$this->name,'type'=>'plugin', 'subtype'=>$plugin));
|
|
|
|
}
|
|
|
|
foreach ($css['parents'] as $parent=>$sheets) {
|
|
|
|
foreach ($sheets as $sheet=>$unused2) {
|
|
|
|
$urls[] = new moodle_url($baseurl, array('theme'=>$this->name,'type'=>'parent', 'subtype'=>$parent, 'sheet'=>$sheet));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
foreach ($css['theme'] as $sheet=>$unused) {
|
|
|
|
$urls[] = new moodle_url($baseurl, array('sheet'=>$sheet, 'theme'=>$this->name, 'type'=>'theme')); // sheet first in order to make long urls easier to read
|
2009-12-16 18:00:58 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2010-01-05 00:33:15 +00:00
|
|
|
|
|
|
|
return $urls;
|
themes: MDL-19077 implement the renderer_factory instrastructure.
This is part of http://docs.moodle.org/en/Development:Theme_engines_for_Moodle%3F
The concept is that all the print_... functions in weblib get replaced by methods
on a moodle_core_renderer class. Then, the theme can choose whether to
use the standard moodle_core_renderer class, or another implemenatation of
its own choosing, to generate different HTML.
Also, becuase Moodle is modular, we may need a moodle_mod_forum_renderer
and so on.
In order for the theme to be able to choose which renderers get created, we
introduce the concept of a renderer factory, as in the factory design pattern.
The theme will choose which factory should be used, and that then creates
the renderer objects based on the module name.
This commit includes 4 types of factory:
* standard_renderer_factory
* custom_corners_renderer_factory
* theme_overridden_renderer_factory
* template_renderer_factory
All this with unit tests and PHP doc comments.
Note, this new code is not actually used yet. Still todo:
1. actually define the moodle_core_renderer class, and deprecate a lot of weblib functions.
2. make theme_setup initialise everything, so it is used.
2009-06-18 10:43:13 +00:00
|
|
|
}
|
2009-06-26 09:06:16 +00:00
|
|
|
|
2009-07-02 08:49:25 +00:00
|
|
|
/**
|
2010-05-19 02:15:16 +00:00
|
|
|
* Returns an array of organised CSS files required for this output
|
|
|
|
* @return array
|
2009-07-02 08:49:25 +00:00
|
|
|
*/
|
2010-05-19 02:15:16 +00:00
|
|
|
public function css_files() {
|
|
|
|
$cssfiles = array('plugins'=>array(), 'parents'=>array(), 'theme'=>array());
|
2009-12-16 18:00:58 +00:00
|
|
|
|
2009-12-25 10:52:02 +00:00
|
|
|
// get all plugin sheets
|
2010-05-19 02:15:16 +00:00
|
|
|
$excludes = $this->resolve_excludes('plugins_exclude_sheets');
|
2009-12-16 18:00:58 +00:00
|
|
|
if ($excludes !== true) {
|
|
|
|
foreach (get_plugin_types() as $type=>$unused) {
|
2010-05-19 02:15:16 +00:00
|
|
|
if ($type === 'theme' || (!empty($excludes[$type]) and $excludes[$type] === true)) {
|
2009-12-16 18:00:58 +00:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$plugins = get_plugin_list($type);
|
|
|
|
foreach ($plugins as $plugin=>$fulldir) {
|
|
|
|
if (!empty($excludes[$type]) and is_array($excludes[$type])
|
|
|
|
and in_array($plugin, $excludes[$type])) {
|
|
|
|
continue;
|
|
|
|
}
|
2010-02-18 08:47:47 +00:00
|
|
|
|
|
|
|
$plugincontent = '';
|
2009-12-16 18:00:58 +00:00
|
|
|
$sheetfile = "$fulldir/styles.css";
|
|
|
|
if (is_readable($sheetfile)) {
|
2010-05-19 02:15:16 +00:00
|
|
|
$cssfiles['plugins'][$type.'_'.$plugin] = $sheetfile;
|
2010-02-18 08:47:47 +00:00
|
|
|
}
|
|
|
|
$sheetthemefile = "$fulldir/styles_{$this->name}.css";
|
|
|
|
if (is_readable($sheetthemefile)) {
|
2010-05-19 02:15:16 +00:00
|
|
|
$cssfiles['plugins'][$type.'_'.$plugin.'_'.$this->name] = $sheetthemefile;
|
2010-02-18 08:47:47 +00:00
|
|
|
}
|
2009-12-16 18:00:58 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2009-06-26 09:06:16 +00:00
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
// find out wanted parent sheets
|
2010-05-19 02:15:16 +00:00
|
|
|
$excludes = $this->resolve_excludes('parents_exclude_sheets');
|
2009-12-16 18:00:58 +00:00
|
|
|
if ($excludes !== true) {
|
|
|
|
foreach (array_reverse($this->parent_configs) as $parent_config) { // base first, the immediate parent last
|
|
|
|
$parent = $parent_config->name;
|
2010-05-19 02:15:16 +00:00
|
|
|
if (empty($parent_config->sheets) || (!empty($excludes[$parent]) and $excludes[$parent] === true)) {
|
2009-12-16 18:00:58 +00:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
foreach ($parent_config->sheets as $sheet) {
|
|
|
|
if (!empty($excludes[$parent]) and is_array($excludes[$parent])
|
|
|
|
and in_array($sheet, $excludes[$parent])) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$sheetfile = "$parent_config->dir/style/$sheet.css";
|
|
|
|
if (is_readable($sheetfile)) {
|
2010-05-19 02:15:16 +00:00
|
|
|
$cssfiles['parents'][$parent][$sheet] = $sheetfile;
|
2009-12-16 18:00:58 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2009-06-26 09:06:16 +00:00
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
// current theme sheets
|
|
|
|
if (is_array($this->sheets)) {
|
|
|
|
foreach ($this->sheets as $sheet) {
|
|
|
|
$sheetfile = "$this->dir/style/$sheet.css";
|
|
|
|
if (is_readable($sheetfile)) {
|
2010-05-19 02:15:16 +00:00
|
|
|
$cssfiles['theme'][$sheet] = $sheetfile;
|
2009-12-16 18:00:58 +00:00
|
|
|
}
|
2009-07-02 08:49:25 +00:00
|
|
|
}
|
2009-12-16 18:00:58 +00:00
|
|
|
}
|
|
|
|
|
2010-05-19 02:15:16 +00:00
|
|
|
return $cssfiles;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the content of the one huge CSS merged from all style sheets.
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function css_content() {
|
|
|
|
$css = $this->css_files_get_contents($this->css_files(), array());
|
2009-12-16 18:00:58 +00:00
|
|
|
return $css;
|
|
|
|
}
|
2009-06-26 09:06:16 +00:00
|
|
|
|
2010-05-19 02:15:16 +00:00
|
|
|
/**
|
|
|
|
* Given an array of file paths or a single file path loads the contents of
|
|
|
|
* the CSS file, processes it then returns it in the same structure it was given.
|
|
|
|
*
|
|
|
|
* Can be used recursively on the results of {@see css_files}
|
|
|
|
*
|
|
|
|
* @param array|string $file An array of file paths or a single file path
|
|
|
|
* @param array $keys An array of previous array keys [recusive addition]
|
|
|
|
* @return The converted array or the contents of the single file ($file type)
|
|
|
|
*/
|
|
|
|
protected function css_files_get_contents($file, array $keys) {
|
|
|
|
if (is_array($file)) {
|
|
|
|
foreach ($file as $key=>$f) {
|
|
|
|
$file[$key] = $this->css_files_get_contents($f, array_merge($keys, array($key)));
|
|
|
|
}
|
|
|
|
return $file;
|
|
|
|
} else {
|
|
|
|
$comment = '/** Path: '.implode(' ', $keys).' **/'."\n";
|
|
|
|
return $comment.$this->post_process(file_get_contents($file));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-12-20 23:06:57 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the javascript URL of this theme
|
2010-02-07 13:08:46 +00:00
|
|
|
* @param bool $inhead true means haed url, false means footer
|
2009-12-20 23:06:57 +00:00
|
|
|
* @return moodle_url
|
|
|
|
*/
|
2010-02-07 13:08:46 +00:00
|
|
|
public function javascript_url($inhead) {
|
2009-12-20 23:06:57 +00:00
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
$rev = theme_get_revision();
|
|
|
|
$params = array('theme'=>$this->name,'rev'=>$rev);
|
2010-02-07 13:08:46 +00:00
|
|
|
$params['type'] = $inhead ? 'head' : 'footer';
|
|
|
|
|
|
|
|
return new moodle_url($CFG->httpswwwroot.'/theme/javascript.php', $params);
|
2009-12-20 23:06:57 +00:00
|
|
|
}
|
|
|
|
|
2010-05-19 02:15:16 +00:00
|
|
|
public function javascript_files($type) {
|
|
|
|
if ($type === 'footer') {
|
|
|
|
$type = 'javascripts_footer';
|
|
|
|
} else {
|
2010-05-19 02:22:17 +00:00
|
|
|
$type = 'javascripts';
|
2010-05-19 02:15:16 +00:00
|
|
|
}
|
2010-01-05 23:22:16 +00:00
|
|
|
|
2009-12-23 17:18:46 +00:00
|
|
|
$js = array();
|
|
|
|
// find out wanted parent javascripts
|
2010-05-19 02:15:16 +00:00
|
|
|
$excludes = $this->resolve_excludes('parents_exclude_javascripts');
|
2009-12-23 17:18:46 +00:00
|
|
|
if ($excludes !== true) {
|
|
|
|
foreach (array_reverse($this->parent_configs) as $parent_config) { // base first, the immediate parent last
|
|
|
|
$parent = $parent_config->name;
|
2010-01-05 23:22:16 +00:00
|
|
|
if (empty($parent_config->$type)) {
|
2009-12-23 17:18:46 +00:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (!empty($excludes[$parent]) and $excludes[$parent] === true) {
|
|
|
|
continue;
|
|
|
|
}
|
2010-01-05 23:22:16 +00:00
|
|
|
foreach ($parent_config->$type as $javascript) {
|
2009-12-23 17:18:46 +00:00
|
|
|
if (!empty($excludes[$parent]) and is_array($excludes[$parent])
|
|
|
|
and in_array($javascript, $excludes[$parent])) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$javascriptfile = "$parent_config->dir/javascript/$javascript.js";
|
|
|
|
if (is_readable($javascriptfile)) {
|
2010-05-19 02:15:16 +00:00
|
|
|
$js[] = $javascriptfile;
|
2009-12-23 17:18:46 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// current theme javascripts
|
2010-01-05 23:22:16 +00:00
|
|
|
if (is_array($this->$type)) {
|
|
|
|
foreach ($this->$type as $javascript) {
|
2009-12-23 17:18:46 +00:00
|
|
|
$javascriptfile = "$this->dir/javascript/$javascript.js";
|
|
|
|
if (is_readable($javascriptfile)) {
|
2010-05-19 02:15:16 +00:00
|
|
|
$js[] = $javascriptfile;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $js;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Resolves an exclude setting to the theme's setting is applicable or the
|
|
|
|
* setting of its closest parent.
|
|
|
|
*
|
|
|
|
* @param string $variable The name of the setting the exclude setting to resolve
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
protected function resolve_excludes($variable, $default=null) {
|
|
|
|
$setting = $default;
|
|
|
|
if (is_array($this->{$variable}) or $this->{$variable} === true) {
|
|
|
|
$setting = $this->{$variable};
|
|
|
|
} else {
|
|
|
|
foreach ($this->parent_configs as $parent_config) { // the immediate parent first, base last
|
|
|
|
if (!isset($parent_config->{$variable})) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (is_array($parent_config->{$variable}) or $parent_config->{$variable} === true) {
|
|
|
|
$setting = $parent_config->{$variable};
|
|
|
|
break;
|
2009-12-23 17:18:46 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2010-05-19 02:15:16 +00:00
|
|
|
return $setting;
|
|
|
|
}
|
2009-12-23 17:18:46 +00:00
|
|
|
|
2010-05-19 02:15:16 +00:00
|
|
|
/**
|
|
|
|
* Returns the content of the one huge javascript file merged from all theme javascript files.
|
|
|
|
* @param bool $inhead
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function javascript_content($type) {
|
|
|
|
$jsfiles = $this->javascript_files($type);
|
|
|
|
$js = '';
|
|
|
|
foreach ($jsfiles as $jsfile) {
|
|
|
|
$js .= file_get_contents($jsfile)."\n";
|
|
|
|
}
|
|
|
|
return $js;
|
2009-12-20 23:06:57 +00:00
|
|
|
}
|
|
|
|
|
2010-05-19 02:15:16 +00:00
|
|
|
public function post_process($css) {
|
2010-01-05 21:45:08 +00:00
|
|
|
global $CFG;
|
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
// now resolve all image locations
|
|
|
|
if (preg_match_all('/\[\[pix:([a-z_]+\|)?([^\]]+)\]\]/', $css, $matches, PREG_SET_ORDER)) {
|
|
|
|
$replaced = array();
|
|
|
|
foreach ($matches as $match) {
|
|
|
|
if (isset($replaced[$match[0]])) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$replaced[$match[0]] = true;
|
|
|
|
$imagename = $match[2];
|
|
|
|
$component = rtrim($match[1], '|');
|
2010-01-17 09:50:55 +00:00
|
|
|
$imageurl = $this->pix_url($imagename, $component)->out(false);
|
2010-01-05 21:45:08 +00:00
|
|
|
// we do not need full url because the image.php is always in the same dir
|
|
|
|
$imageurl = str_replace("$CFG->httpswwwroot/theme/", '', $imageurl);
|
|
|
|
$css = str_replace($match[0], $imageurl, $css);
|
2009-07-02 08:49:25 +00:00
|
|
|
}
|
2009-06-26 09:06:16 +00:00
|
|
|
}
|
2009-06-30 07:57:41 +00:00
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
// now resolve all theme settings or do any other postprocessing
|
|
|
|
$csspostprocess = $this->csspostprocess;
|
|
|
|
if (function_exists($csspostprocess)) {
|
|
|
|
$css = $csspostprocess($css, $this);
|
2009-07-07 05:05:06 +00:00
|
|
|
}
|
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
return $css;
|
2009-07-02 08:49:25 +00:00
|
|
|
}
|
2009-06-30 07:57:41 +00:00
|
|
|
|
2009-07-02 08:49:25 +00:00
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* Return the URL for an image
|
|
|
|
*
|
|
|
|
* @param string $imagename the name of the icon.
|
|
|
|
* @param string $component, specification of one plugin like in get_string()
|
|
|
|
* @return moodle_url
|
2009-07-07 05:05:06 +00:00
|
|
|
*/
|
2009-12-16 20:33:37 +00:00
|
|
|
public function pix_url($imagename, $component) {
|
2009-07-07 05:05:06 +00:00
|
|
|
global $CFG;
|
2009-12-16 18:00:58 +00:00
|
|
|
|
|
|
|
$params = array('theme'=>$this->name, 'image'=>$imagename);
|
|
|
|
|
|
|
|
$rev = theme_get_revision();
|
|
|
|
if ($rev != -1) {
|
|
|
|
$params['rev'] = $rev;
|
|
|
|
}
|
|
|
|
if (!empty($component) and $component !== 'moodle'and $component !== 'core') {
|
|
|
|
$params['component'] = $component;
|
2009-07-07 05:05:06 +00:00
|
|
|
}
|
2009-12-16 18:00:58 +00:00
|
|
|
|
|
|
|
return new moodle_url("$CFG->httpswwwroot/theme/image.php", $params);
|
2009-07-07 05:05:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* Resolves the real image location.
|
|
|
|
* @param string $image name of image, may contain relative path
|
|
|
|
* @param string $component
|
|
|
|
* @return string full file path
|
2009-07-07 05:05:06 +00:00
|
|
|
*/
|
2009-12-16 18:00:58 +00:00
|
|
|
public function resolve_image_location($image, $component) {
|
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
if ($component === 'moodle' or $component === 'core' or empty($component)) {
|
|
|
|
if ($imagefile = $this->image_exists("$this->dir/pix_core/$image")) {
|
|
|
|
return $imagefile;
|
|
|
|
}
|
|
|
|
foreach (array_reverse($this->parent_configs) as $parent_config) { // base first, the immediate parent last
|
|
|
|
if ($imagefile = $this->image_exists("$parent_config->dir/pix_core/$image")) {
|
|
|
|
return $imagefile;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($imagefile = $this->image_exists("$CFG->dirroot/pix/$image")) {
|
|
|
|
return $imagefile;
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
|
|
|
|
} else if ($component === 'theme') { //exception
|
|
|
|
if ($image === 'favicon') {
|
|
|
|
return "$this->dir/pix/favicon.ico";
|
|
|
|
}
|
|
|
|
if ($imagefile = $this->image_exists("$this->dir/pix/$image")) {
|
|
|
|
return $imagefile;
|
|
|
|
}
|
|
|
|
foreach (array_reverse($this->parent_configs) as $parent_config) { // base first, the immediate parent last
|
|
|
|
if ($imagefile = $this->image_exists("$parent_config->dir/pix/$image")) {
|
|
|
|
return $imagefile;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
|
|
|
|
} else {
|
|
|
|
if (strpos($component, '_') === false) {
|
|
|
|
$component = 'mod_'.$component;
|
|
|
|
}
|
|
|
|
list($type, $plugin) = explode('_', $component, 2);
|
|
|
|
|
|
|
|
if ($imagefile = $this->image_exists("$this->dir/pix_plugins/$type/$plugin/$image")) {
|
|
|
|
return $imagefile;
|
|
|
|
}
|
|
|
|
foreach (array_reverse($this->parent_configs) as $parent_config) { // base first, the immediate parent last
|
|
|
|
if ($imagefile = $this->image_exists("$parent_config->dir/pix_plugins/$type/$plugin/$image")) {
|
|
|
|
return $imagefile;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$dir = get_plugin_directory($type, $plugin);
|
|
|
|
if ($imagefile = $this->image_exists("$dir/pix/$image")) {
|
|
|
|
return $imagefile;
|
|
|
|
}
|
|
|
|
return null;
|
2009-07-07 05:05:06 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-07-09 07:35:03 +00:00
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* Checks if file with any image extension exists.
|
|
|
|
* @param string $filepath
|
|
|
|
* @return string image name with extension
|
2009-07-09 07:35:03 +00:00
|
|
|
*/
|
2009-12-16 18:00:58 +00:00
|
|
|
private static function image_exists($filepath) {
|
|
|
|
if (file_exists("$filepath.gif")) {
|
|
|
|
return "$filepath.gif";
|
|
|
|
} else if (file_exists("$filepath.png")) {
|
|
|
|
return "$filepath.png";
|
|
|
|
} else if (file_exists("$filepath.jpg")) {
|
|
|
|
return "$filepath.jpg";
|
|
|
|
} else if (file_exists("$filepath.jpeg")) {
|
|
|
|
return "$filepath.jpeg";
|
2009-07-09 07:35:03 +00:00
|
|
|
} else {
|
2009-12-16 18:00:58 +00:00
|
|
|
return false;
|
2009-07-09 07:35:03 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-07-07 05:05:06 +00:00
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* Loads the theme config from config.php file.
|
|
|
|
* @param string $themename
|
|
|
|
* @param object $settings from config_plugins table
|
|
|
|
* @return object
|
2009-07-07 05:05:06 +00:00
|
|
|
*/
|
2009-12-16 18:00:58 +00:00
|
|
|
private static function find_theme_config($themename, $settings) {
|
|
|
|
// We have to use the variable name $THEME (upper case) because that
|
|
|
|
// is what is used in theme config.php files.
|
2009-07-07 05:05:06 +00:00
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
if (!$dir = theme_config::find_theme_location($themename)) {
|
|
|
|
return null;
|
2009-07-07 05:05:06 +00:00
|
|
|
}
|
2009-12-16 22:22:37 +00:00
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
$THEME = new object();
|
|
|
|
$THEME->name = $themename;
|
|
|
|
$THEME->dir = $dir;
|
|
|
|
$THEME->settings = $settings;
|
|
|
|
|
|
|
|
global $CFG; // just in case somebody tries to use $CFG in theme config
|
|
|
|
include("$THEME->dir/config.php");
|
|
|
|
|
|
|
|
// verify the theme configuration is OK
|
|
|
|
if (!is_array($THEME->parents)) {
|
|
|
|
// parents option is mandatory now
|
|
|
|
return null;
|
2009-07-07 05:05:06 +00:00
|
|
|
}
|
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
return $THEME;
|
2009-07-07 05:05:06 +00:00
|
|
|
}
|
|
|
|
|
2009-07-09 07:35:03 +00:00
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* Finds the theme location and verifies the theme has all needed files
|
|
|
|
* and is not obsoleted.
|
|
|
|
* @param string $themename
|
|
|
|
* @return string full dir path or null if not found
|
2009-07-09 07:35:03 +00:00
|
|
|
*/
|
2009-12-16 18:00:58 +00:00
|
|
|
private static function find_theme_location($themename) {
|
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
if (file_exists("$CFG->dirroot/theme/$themename/config.php")) {
|
|
|
|
$dir = "$CFG->dirroot/theme/$themename";
|
2009-07-09 07:35:03 +00:00
|
|
|
|
2009-09-30 16:24:05 +00:00
|
|
|
} else {
|
2009-12-16 18:00:58 +00:00
|
|
|
return null;
|
2009-07-09 07:35:03 +00:00
|
|
|
}
|
2009-12-16 18:00:58 +00:00
|
|
|
|
|
|
|
if (file_exists("$dir/styles.php")) {
|
|
|
|
//legacy theme - needs to be upgraded - upgrade info is displayed on the admin settings page
|
|
|
|
return null;
|
|
|
|
}
|
2009-12-16 22:22:37 +00:00
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
return $dir;
|
2009-07-09 07:35:03 +00:00
|
|
|
}
|
|
|
|
|
2009-07-16 10:50:19 +00:00
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* Get the renderer for a part of Moodle for this theme.
|
|
|
|
* @param moodle_page $page the page we are rendering
|
2009-12-17 13:45:54 +00:00
|
|
|
* @param string $module the name of part of moodle. E.g. 'core', 'quiz', 'qtype_multichoice'.
|
2009-12-16 18:00:58 +00:00
|
|
|
* @param string $subtype optional subtype such as 'news' resulting to 'mod_forum_news'
|
2009-12-17 22:43:27 +00:00
|
|
|
* @param string $target one of rendering target constants
|
2009-12-16 18:00:58 +00:00
|
|
|
* @return renderer_base the requested renderer.
|
2009-07-16 10:50:19 +00:00
|
|
|
*/
|
2009-12-17 22:43:27 +00:00
|
|
|
public function get_renderer(moodle_page $page, $component, $subtype = null, $target = null) {
|
2009-12-16 18:00:58 +00:00
|
|
|
if (is_null($this->rf)) {
|
2009-12-17 22:43:27 +00:00
|
|
|
$classname = $this->rendererfactory;
|
2009-12-16 18:00:58 +00:00
|
|
|
$this->rf = new $classname($this);
|
2009-07-16 10:50:19 +00:00
|
|
|
}
|
2009-12-16 18:00:58 +00:00
|
|
|
|
2009-12-17 22:43:27 +00:00
|
|
|
return $this->rf->get_renderer($page, $component, $subtype, $target);
|
2009-07-16 10:50:19 +00:00
|
|
|
}
|
|
|
|
|
2009-07-07 05:05:06 +00:00
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* Get the information from {@link $layouts} for this type of page.
|
|
|
|
* @param string $pagelayout the the page layout name.
|
|
|
|
* @return array the appropriate part of {@link $layouts}.
|
2009-07-07 05:05:06 +00:00
|
|
|
*/
|
2009-12-16 18:00:58 +00:00
|
|
|
protected function layout_info_for_page($pagelayout) {
|
|
|
|
if (array_key_exists($pagelayout, $this->layouts)) {
|
|
|
|
return $this->layouts[$pagelayout];
|
|
|
|
} else {
|
2009-12-27 12:02:04 +00:00
|
|
|
debugging('Invalid page layout specified: ' . $pagelayout);
|
|
|
|
return $this->layouts['standard'];
|
2009-07-07 05:05:06 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* Given the settings of this theme, and the page pagelayout, return the
|
|
|
|
* full path of the page layout file to use.
|
|
|
|
*
|
|
|
|
* Used by {@link core_renderer::header()}.
|
|
|
|
*
|
|
|
|
* @param string $pagelayout the the page layout name.
|
|
|
|
* @return string Full path to the lyout file to use
|
2009-07-02 08:49:25 +00:00
|
|
|
*/
|
2009-12-16 18:00:58 +00:00
|
|
|
public function layout_file($pagelayout) {
|
2009-07-02 08:49:25 +00:00
|
|
|
global $CFG;
|
2009-07-07 05:05:06 +00:00
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
$layoutinfo = $this->layout_info_for_page($pagelayout);
|
|
|
|
$layoutfile = $layoutinfo['file'];
|
2009-07-07 05:05:06 +00:00
|
|
|
|
2010-04-15 06:37:55 +00:00
|
|
|
if (array_key_exists('theme', $layoutinfo)) {
|
|
|
|
$themes = array($layoutinfo['theme']);
|
|
|
|
} else {
|
|
|
|
$themes = array_merge(array($this->name),$this->parents);
|
|
|
|
}
|
2010-04-15 14:43:25 +00:00
|
|
|
|
2010-04-15 06:37:55 +00:00
|
|
|
foreach ($themes as $theme) {
|
|
|
|
if ($dir = $this->find_theme_location($theme)) {
|
|
|
|
$path = "$dir/layout/$layoutfile";
|
|
|
|
|
|
|
|
// Check the template exists, return general base theme template if not.
|
|
|
|
if (is_readable($path)) {
|
|
|
|
return $path;
|
|
|
|
}
|
2009-12-16 18:00:58 +00:00
|
|
|
}
|
2009-06-26 09:06:16 +00:00
|
|
|
}
|
|
|
|
|
2009-12-27 12:02:04 +00:00
|
|
|
debugging('Can not find layout file for: ' . $pagelayout);
|
2009-12-16 18:00:58 +00:00
|
|
|
// fallback to standard normal layout
|
|
|
|
return "$CFG->dirroot/theme/base/layout/general.php";
|
|
|
|
}
|
2009-07-02 08:49:25 +00:00
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
/**
|
|
|
|
* Returns auxiliary page layout options specified in layout configuration array.
|
|
|
|
* @param string $pagelayout
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function pagelayout_options($pagelayout) {
|
|
|
|
$info = $this->layout_info_for_page($pagelayout);
|
|
|
|
if (!empty($info['options'])) {
|
|
|
|
return $info['options'];
|
2009-06-26 09:06:16 +00:00
|
|
|
}
|
2009-12-16 18:00:58 +00:00
|
|
|
return array();
|
|
|
|
}
|
2009-06-26 09:06:16 +00:00
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
/**
|
|
|
|
* Inform a block_manager about the block regions this theme wants on this
|
|
|
|
* page layout.
|
|
|
|
* @param string $pagelayout the general type of the page.
|
|
|
|
* @param block_manager $blockmanager the block_manger to set up.
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function setup_blocks($pagelayout, $blockmanager) {
|
|
|
|
$layoutinfo = $this->layout_info_for_page($pagelayout);
|
|
|
|
if (!empty($layoutinfo['regions'])) {
|
|
|
|
$blockmanager->add_regions($layoutinfo['regions']);
|
|
|
|
$blockmanager->set_default_region($layoutinfo['defaultregion']);
|
2009-07-02 08:49:25 +00:00
|
|
|
}
|
2009-06-26 09:06:16 +00:00
|
|
|
}
|
|
|
|
|
2010-01-21 11:07:15 +00:00
|
|
|
protected function get_region_name($region, $theme) {
|
|
|
|
$regionstring = get_string('region-' . $region, 'theme_' . $theme);
|
|
|
|
// A name exists in this theme, so use it
|
|
|
|
if (substr($regionstring, 0, 1) != '[') {
|
|
|
|
return $regionstring;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Otherwise, try to find one elsewhere
|
|
|
|
// Check parents, if any
|
|
|
|
foreach ($this->parents as $parentthemename) {
|
|
|
|
$regionstring = get_string('region-' . $region, 'theme_' . $parentthemename);
|
|
|
|
if (substr($regionstring, 0, 1) != '[') {
|
|
|
|
return $regionstring;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Last resort, try the base theme for names
|
|
|
|
return get_string('region-' . $region, 'theme_base');
|
|
|
|
}
|
|
|
|
|
2009-07-02 08:49:25 +00:00
|
|
|
/**
|
2009-12-16 18:00:58 +00:00
|
|
|
* Get the list of all block regions known to this theme in all templates.
|
|
|
|
* @return array internal region name => human readable name.
|
2009-07-02 08:49:25 +00:00
|
|
|
*/
|
2009-12-16 18:00:58 +00:00
|
|
|
public function get_all_block_regions() {
|
|
|
|
$regions = array();
|
|
|
|
foreach ($this->layouts as $layoutinfo) {
|
|
|
|
foreach ($layoutinfo['regions'] as $region) {
|
2010-04-21 07:05:39 +00:00
|
|
|
$regions[$region] = $this->get_region_name($region, $this->name);
|
2009-07-02 08:49:25 +00:00
|
|
|
}
|
2009-06-26 09:06:16 +00:00
|
|
|
}
|
2009-12-16 18:00:58 +00:00
|
|
|
return $regions;
|
2009-06-26 09:06:16 +00:00
|
|
|
}
|
2009-07-02 08:49:25 +00:00
|
|
|
}
|
2009-06-26 09:06:16 +00:00
|
|
|
|
2009-12-16 18:00:58 +00:00
|
|
|
|
2009-07-02 08:49:25 +00:00
|
|
|
/**
|
2009-08-10 06:22:04 +00:00
|
|
|
* This class keeps track of which HTML tags are currently open.
|
|
|
|
*
|
|
|
|
* This makes it much easier to always generate well formed XHTML output, even
|
|
|
|
* if execution terminates abruptly. Any time you output some opening HTML
|
|
|
|
* without the matching closing HTML, you should push the necessary close tags
|
|
|
|
* onto the stack.
|
2009-07-02 08:49:25 +00:00
|
|
|
*
|
|
|
|
* @copyright 2009 Tim Hunt
|
|
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
|
|
* @since Moodle 2.0
|
|
|
|
*/
|
2009-08-10 06:22:04 +00:00
|
|
|
class xhtml_container_stack {
|
|
|
|
/** @var array stores the list of open containers. */
|
|
|
|
protected $opencontainers = array();
|
2009-07-23 02:33:58 +00:00
|
|
|
/**
|
2009-08-10 06:22:04 +00:00
|
|
|
* @var array in developer debug mode, stores a stack trace of all opens and
|
|
|
|
* closes, so we can output helpful error messages when there is a mismatch.
|
2009-07-23 02:33:58 +00:00
|
|
|
*/
|
2009-08-10 06:22:04 +00:00
|
|
|
protected $log = array();
|
2009-07-23 02:33:58 +00:00
|
|
|
/**
|
2009-08-10 06:22:04 +00:00
|
|
|
* Store whether we are developer debug mode. We need this in several places
|
|
|
|
* including in the destructor where we may no thave access to $CFG.
|
|
|
|
* @var boolean
|
2009-07-23 02:33:58 +00:00
|
|
|
*/
|
2009-08-10 06:22:04 +00:00
|
|
|
protected $isdebugging;
|
2009-06-26 09:06:16 +00:00
|
|
|
|
2009-08-10 06:22:04 +00:00
|
|
|
public function __construct() {
|
|
|
|
$this->isdebugging = debugging('', DEBUG_DEVELOPER);
|
2009-07-02 08:49:25 +00:00
|
|
|
}
|
2009-06-26 09:06:16 +00:00
|
|
|
|
2009-07-23 02:33:58 +00:00
|
|
|
/**
|
2009-08-10 06:22:04 +00:00
|
|
|
* Push the close HTML for a recently opened container onto the stack.
|
|
|
|
* @param string $type The type of container. This is checked when {@link pop()}
|
|
|
|
* is called and must match, otherwise a developer debug warning is output.
|
|
|
|
* @param string $closehtml The HTML required to close the container.
|
|
|
|
* @return void
|
2009-07-23 02:33:58 +00:00
|
|
|
*/
|
2009-08-10 06:22:04 +00:00
|
|
|
public function push($type, $closehtml) {
|
|
|
|
$container = new stdClass;
|
|
|
|
$container->type = $type;
|
|
|
|
$container->closehtml = $closehtml;
|
|
|
|
if ($this->isdebugging) {
|
|
|
|
$this->log('Open', $type);
|
2009-07-02 09:28:19 +00:00
|
|
|
}
|
2009-08-10 06:22:04 +00:00
|
|
|
array_push($this->opencontainers, $container);
|
2009-07-02 08:49:25 +00:00
|
|
|
}
|
2009-06-26 09:06:16 +00:00
|
|
|
|
2009-07-23 02:33:58 +00:00
|
|
|
/**
|
2009-08-10 06:22:04 +00:00
|
|
|
* Pop the HTML for the next closing container from the stack. The $type
|
|
|
|
* must match the type passed when the container was opened, otherwise a
|
|
|
|
* warning will be output.
|
|
|
|
* @param string $type The type of container.
|
|
|
|
* @return string the HTML required to close the container.
|
2009-07-23 02:33:58 +00:00
|
|
|
*/
|
2009-08-10 06:22:04 +00:00
|
|
|
public function pop($type) {
|
|
|
|
if (empty($this->opencontainers)) {
|
|
|
|
debugging('<p>There are no more open containers. This suggests there is a nesting problem.</p>' .
|
|
|
|
$this->output_log(), DEBUG_DEVELOPER);
|
|
|
|
return;
|
2009-07-02 09:28:19 +00:00
|
|
|
}
|
2009-07-02 08:49:25 +00:00
|
|
|
|
2009-08-10 06:22:04 +00:00
|
|
|
$container = array_pop($this->opencontainers);
|
|
|
|
if ($container->type != $type) {
|
|
|
|
debugging('<p>The type of container to be closed (' . $container->type .
|
|
|
|
') does not match the type of the next open container (' . $type .
|
|
|
|
'). This suggests there is a nesting problem.</p>' .
|
|
|
|
$this->output_log(), DEBUG_DEVELOPER);
|
2009-07-02 08:49:25 +00:00
|
|
|
}
|
2009-08-10 06:22:04 +00:00
|
|
|
if ($this->isdebugging) {
|
|
|
|
$this->log('Close', $type);
|
2009-06-29 07:19:05 +00:00
|
|
|
}
|
2009-08-10 06:22:04 +00:00
|
|
|
return $container->closehtml;
|
2009-07-02 08:49:25 +00:00
|
|
|
}
|
2009-06-29 07:19:05 +00:00
|
|
|
|
2009-07-23 02:33:58 +00:00
|
|
|
/**
|
2009-08-10 06:22:04 +00:00
|
|
|
* Close all but the last open container. This is useful in places like error
|
|
|
|
* handling, where you want to close all the open containers (apart from <body>)
|
|
|
|
* before outputting the error message.
|
|
|
|
* @param bool $shouldbenone assert that the stack should be empty now - causes a
|
|
|
|
* developer debug warning if it isn't.
|
|
|
|
* @return string the HTML required to close any open containers inside <body>.
|
2009-07-23 02:33:58 +00:00
|
|
|
*/
|
2009-08-10 06:22:04 +00:00
|
|
|
public function pop_all_but_last($shouldbenone = false) {
|
|
|
|
if ($shouldbenone && count($this->opencontainers) != 1) {
|
|
|
|
debugging('<p>Some HTML tags were opened in the body of the page but not closed.</p>' .
|
|
|
|
$this->output_log(), DEBUG_DEVELOPER);
|
|
|
|
}
|
|
|
|
$output = '';
|
|
|
|
while (count($this->opencontainers) > 1) {
|
|
|
|
$container = array_pop($this->opencontainers);
|
|
|
|
$output .= $container->closehtml;
|
2009-06-29 07:19:05 +00:00
|
|
|
}
|
2009-08-10 06:22:04 +00:00
|
|
|
return $output;
|
2009-06-29 07:19:05 +00:00
|
|
|
}
|
2009-06-26 09:06:16 +00:00
|
|
|
|
2009-07-02 08:49:25 +00:00
|
|
|
/**
|
2009-08-10 06:22:04 +00:00
|
|
|
* You can call this function if you want to throw away an instance of this
|
|
|
|
* class without properly emptying the stack (for example, in a unit test).
|
|
|
|
* Calling this method stops the destruct method from outputting a developer
|
|
|
|
* debug warning. After calling this method, the instance can no longer be used.
|
|
|
|
* @return void
|
2009-07-02 08:49:25 +00:00
|
|
|
*/
|
2009-08-10 06:22:04 +00:00
|
|
|
public function discard() {
|
|
|
|
$this->opencontainers = null;
|
2009-07-02 08:49:25 +00:00
|
|
|
}
|
2009-08-10 06:22:04 +00:00
|
|
|
|
2009-07-23 02:33:58 +00:00
|
|
|
/**
|
2009-08-10 06:22:04 +00:00
|
|
|
* Adds an entry to the log.
|
|
|
|
* @param string $action The name of the action
|
|
|
|
* @param string $type The type of action
|
|
|
|
* @return void
|
2009-07-23 02:33:58 +00:00
|
|
|
*/
|
2009-08-10 06:22:04 +00:00
|
|
|
protected function log($action, $type) {
|
|
|
|
$this->log[] = '<li>' . $action . ' ' . $type . ' at:' .
|
|
|
|
format_backtrace(debug_backtrace()) . '</li>';
|
2009-07-02 08:49:25 +00:00
|
|
|
}
|
2009-06-26 09:06:16 +00:00
|
|
|
|
2009-07-23 02:33:58 +00:00
|
|
|
/**
|
2009-08-10 06:22:04 +00:00
|
|
|
* Outputs the log's contents as a HTML list.
|
|
|
|
* @return string HTML list of the log
|
2009-07-23 02:33:58 +00:00
|
|
|
*/
|
2009-08-10 06:22:04 +00:00
|
|
|
protected function output_log() {
|
|
|
|
return '<ul>' . implode("\n", $this->log) . '</ul>';
|
2009-06-26 09:06:16 +00:00
|
|
|
}
|
|
|
|
}
|