#163785 by Eaton, dvessel and quicksketch: theme .info files should be able to override core and module CSS files based on file basenames

6.x
Gábor Hojtsy 2007-10-05 14:50:25 +00:00
parent 821221cc14
commit 74a431e79a
7 changed files with 109 additions and 68 deletions

View File

@ -987,6 +987,7 @@ function drupal_maintenance_theme() {
unicode_check();
drupal_add_css(drupal_get_path('module', 'system') .'/defaults.css', 'module');
drupal_add_css(drupal_get_path('module', 'system') .'/system.css', 'module');
drupal_add_css(drupal_get_path('module', 'system') .'/system-menus.css', 'module');
$theme = '';
// Special case registry of theme functions used by the installer

View File

@ -1495,10 +1495,20 @@ function drupal_add_link($attributes) {
/**
* Adds a CSS file to the stylesheet queue.
*
* Themes may replace module-defined CSS files by adding a stylesheet with the
* same filename. For example, themes/garland/system-menus.css would replace
* modules/system/system-menus.css. This allows themes to override complete
* CSS files, rather than specific selectors, when necessary.
*
* @param $path
* (optional) The path to the CSS file relative to the base_path(), e.g.,
* /modules/devel/devel.css.
*
* Modules should always prefix the names of their CSS files with the module
* name, for example: system-menus.css rather than simply menus.css. Themes
* can override module-supplied CSS files based on their filenames, and this
* prefixing helps prevent confusing name collisions for theme developers.
*
* If the direction of the current language is right-to-left (Hebrew,
* Arabic, etc.), the function will also look for an RTL CSS file and append
* it to the list. The name of this file should have an '-rtl.css' suffix.
@ -1506,6 +1516,10 @@ function drupal_add_link($attributes) {
* file added to the list, if exists in the same directory. This CSS file
* should contain overrides for properties which should be reversed or
* otherwise different in a right-to-left display.
*
* If the original CSS file is being overridden by a theme, the theme is
* responsible for supplying an accompanying RTL CSS file to replace the
* module's.
* @param $type
* (optional) The type of stylesheet that is being added. Types are: module
* or theme.
@ -1548,6 +1562,30 @@ function drupal_add_css($path = NULL, $type = 'module', $media = 'all', $preproc
if (!isset($css[$media])) {
$css[$media] = array('module' => array(), 'theme' => array());
}
// If a theme is adding the current stylesheet, check for any existing CSS files
// with the same name. If they exist, remove them and allow the theme's own CSS
// file to replace it.
if ($type == 'theme') {
foreach ($css[$media]['module'] as $old_path => $old_preprocess) {
// Match by style sheet name.
if (basename($path) == basename($old_path)) {
unset($css[$media]['module'][$old_path]);
// If the current language is RTL and the CSS file had an RTL variant,
// pull out the original. The theme must provide it's own RTL style.
if (defined('LANGUAGE_RTL') && $language->direction == LANGUAGE_RTL) {
$rtl_old_path = str_replace('.css', '-rtl.css', $old_path);
if (isset($css[$media]['module'][$rtl_old_path])) {
unset($css[$media]['module'][$rtl_old_path]);
}
}
// Set the preprocess state of the current module, then exit the search loop.
$preprocess = $old_preprocess;
break;
}
}
}
$css[$media][$type][$path] = $preprocess;
// If the current language is RTL, add the CSS file with RTL overrides.

View File

@ -0,0 +1,18 @@
/* $Id$ */
ul.menu {
text-align:right;
}
ul.menu li {
margin: 0 0.5em 0 0;
}
li.expanded {
padding: 0.2em 0 0 0.5em;
}
li.collapsed {
list-style-image: url(../../misc/menu-collapsed-rtl.png);
padding: 0.2em 0 0 0.5em;
}
li.leaf {
padding: 0.2em 0 0 0.5em;
}

View File

@ -0,0 +1,50 @@
/* $Id$ */
ul.menu {
list-style: none;
border: none;
text-align:left; /* LTR */
}
ul.menu li {
margin: 0 0 0 0.5em; /* LTR */
}
li.expanded {
list-style-type: circle;
list-style-image: url(../../misc/menu-expanded.png);
padding: 0.2em 0.5em 0 0; /* LTR */
margin: 0;
}
li.collapsed {
list-style-type: disc;
list-style-image: url(../../misc/menu-collapsed.png); /* LTR */
padding: 0.2em 0.5em 0 0; /* LTR */
margin: 0;
}
li.leaf {
list-style-type: square;
list-style-image: url(../../misc/menu-leaf.png);
padding: 0.2em 0.5em 0 0; /* LTR */
margin: 0;
}
li a.active {
color: #000;
}
td.menu-disabled {
background: #ccc;
}
ul.links {
margin: 0;
padding: 0;
}
ul.links.inline {
display: inline;
}
ul.links li {
display: inline;
list-style-type: none;
padding: 0 0.5em;
}
.block ul {
margin: 0;
padding: 0 0 0.25em 1em; /* LTR */
}

View File

@ -21,22 +21,7 @@ dl.multiselect dt, dl.multiselect dd {
float: right;
margin: 0 0 0 1em;
}
ul.menu {
text-align:right;
}
ul.menu li {
margin: 0 0.5em 0 0;
}
li.expanded {
padding: 0.2em 0 0 0.5em;
}
li.collapsed {
list-style-image: url(../../misc/menu-collapsed-rtl.png);
padding: 0.2em 0 0 0.5em;
}
li.leaf {
padding: 0.2em 0 0 0.5em;
}
.block ul {
padding: 0 1em 0.25em 0;
}

View File

@ -181,58 +181,6 @@ dl.multiselect .form-item {
display: inline;
}
/*
** Menus
*/
ul.menu {
list-style: none;
border: none;
text-align:left; /* LTR */
}
ul.menu li {
margin: 0 0 0 0.5em; /* LTR */
}
li.expanded {
list-style-type: circle;
list-style-image: url(../../misc/menu-expanded.png);
padding: 0.2em 0.5em 0 0; /* LTR */
margin: 0;
}
li.collapsed {
list-style-type: disc;
list-style-image: url(../../misc/menu-collapsed.png); /* LTR */
padding: 0.2em 0.5em 0 0; /* LTR */
margin: 0;
}
li.leaf {
list-style-type: square;
list-style-image: url(../../misc/menu-leaf.png);
padding: 0.2em 0.5em 0 0; /* LTR */
margin: 0;
}
li a.active {
color: #000;
}
td.menu-disabled {
background: #ccc;
}
ul.links {
margin: 0;
padding: 0;
}
ul.links.inline {
display: inline;
}
ul.links li {
display: inline;
list-style-type: none;
padding: 0 0.5em;
}
.block ul {
margin: 0;
padding: 0 0 0.25em 1em; /* LTR */
}
/*
** Tab navigation
*/

View File

@ -451,6 +451,7 @@ function system_init() {
// Add the CSS for this module.
drupal_add_css(drupal_get_path('module', 'system') .'/defaults.css', 'module');
drupal_add_css(drupal_get_path('module', 'system') .'/system.css', 'module');
drupal_add_css(drupal_get_path('module', 'system') .'/system-menus.css', 'module');
}
/**