Zeile 9 | Zeile 9 |
---|
function import_theme_xml($xml, $options=array()) { global $mybb, $db;
|
function import_theme_xml($xml, $options=array()) { global $mybb, $db;
|
require_once MYBB_ROOT."inc/class_xml.php";
| require_once MYBB_ROOT."inc/class_xml.php";
|
$parser = new XMLParser($xml); $tree = $parser->get_tree();
| $parser = new XMLParser($xml); $tree = $parser->get_tree();
|
Zeile 19 | Zeile 19 |
---|
{ return -1; }
|
{ return -1; }
|
|
|
$theme = $tree['theme'];
|
$theme = $tree['theme'];
|
|
|
// Do we have MyBB 1.2 template's we're importing? $css_120 = "";
|
// Do we have MyBB 1.2 template's we're importing? $css_120 = "";
|
|
|
if(is_array($theme['cssbits'])) { $cssbits = kill_tags($theme['cssbits']);
|
if(is_array($theme['cssbits'])) { $cssbits = kill_tags($theme['cssbits']);
|
|
|
foreach($cssbits as $name => $values) { $css_120 .= "{$name} {\n";
| foreach($cssbits as $name => $values) { $css_120 .= "{$name} {\n";
|
Zeile 37 | Zeile 37 |
---|
if(is_array($value)) { $property = str_replace('_', ':', $property);
|
if(is_array($value)) { $property = str_replace('_', ':', $property);
|
|
|
$css_120 .= "}\n{$name} {$property} {\n"; foreach($value as $property2 => $value2) {
| $css_120 .= "}\n{$name} {$property} {\n"; foreach($value as $property2 => $value2) {
|
Zeile 52 | Zeile 52 |
---|
$css_120 .= "}\n"; } }
|
$css_120 .= "}\n"; } }
|
|
|
if(is_array($theme['themebits'])) { $themebits = kill_tags($theme['themebits']);
|
if(is_array($theme['themebits'])) { $themebits = kill_tags($theme['themebits']);
|
|
|
$theme['properties']['tag'] = 'properties';
|
$theme['properties']['tag'] = 'properties';
|
|
|
foreach($themebits as $name => $value) { if($name == "extracss") { $css_120 .= $value;
|
foreach($themebits as $name => $value) { if($name == "extracss") { $css_120 .= $value;
|
continue; }
| continue; }
|
$theme['properties'][$name] = $value; } }
|
$theme['properties'][$name] = $value; } }
|
|
|
if($css_120) { $css_120 = upgrade_css_120_to_140($css_120);
| if($css_120) { $css_120 = upgrade_css_120_to_140($css_120);
|
Zeile 78 | Zeile 78 |
---|
$theme['stylesheets']['stylesheet'][0]['tag'] = 'stylesheet'; $theme['stylesheets']['stylesheet'][0]['attributes'] = array('name' => 'global.css', 'version' => $mybb->version_code); $theme['stylesheets']['stylesheet'][0]['value'] = $css_120;
|
$theme['stylesheets']['stylesheet'][0]['tag'] = 'stylesheet'; $theme['stylesheets']['stylesheet'][0]['attributes'] = array('name' => 'global.css', 'version' => $mybb->version_code); $theme['stylesheets']['stylesheet'][0]['value'] = $css_120;
|
|
|
unset($theme['cssbits']); unset($theme['themebits']); }
|
unset($theme['cssbits']); unset($theme['themebits']); }
|
|
|
if(is_array($theme['properties']))
|
if(is_array($theme['properties']))
|
{
| {
|
foreach($theme['properties'] as $property => $value) { if($property == "tag" || $property == "value") { continue; }
|
foreach($theme['properties'] as $property => $value) { if($property == "tag" || $property == "value") { continue; }
|
|
|
$properties[$property] = $value['value']; } }
|
$properties[$property] = $value['value']; } }
|
|
|
if(empty($mybb->input['name'])) { $name = $theme['attributes']['name'];
| if(empty($mybb->input['name'])) { $name = $theme['attributes']['name'];
|
Zeile 118 | Zeile 118 |
---|
}
if($mybb->version_code != $version && $options['version_compat'] != 1)
|
}
if($mybb->version_code != $version && $options['version_compat'] != 1)
|
{
| {
|
return -2; }
|
return -2; }
|
|
|
// Do we have any templates to insert? if(!empty($theme['templates']['template']) && !$options['no_templates'])
|
// Do we have any templates to insert? if(!empty($theme['templates']['template']) && !$options['no_templates'])
|
{ if($options['templateset']) {
| { if($options['templateset']) {
|
$sid = $options['templateset'];
|
$sid = $options['templateset'];
|
} else {
| } else {
|
$sid = $db->insert_query("templatesets", array('title' => $db->escape_string($name)." Templates")); }
|
$sid = $db->insert_query("templatesets", array('title' => $db->escape_string($name)." Templates")); }
|
|
|
$templates = $theme['templates']['template']; if(is_array($templates)) {
| $templates = $theme['templates']['template']; if(is_array($templates)) {
|
Zeile 141 | Zeile 141 |
---|
if(array_key_exists("attributes", $templates)) { $templates = array($templates);
|
if(array_key_exists("attributes", $templates)) { $templates = array($templates);
|
} }
| } }
$security_check = false; $templatecache = array();
|
foreach($templates as $template) {
|
foreach($templates as $template) {
|
// PostgreSQL causes apache to stop sending content sometimes and
| if(check_template($template['value'])) { $security_check = true; break; }
$templatecache[] = array( "title" => $db->escape_string($template['attributes']['name']), "template" => $db->escape_string($template['value']), "sid" => $db->escape_string($sid), "version" => $db->escape_string($template['attributes']['version']), "dateline" => TIME_NOW ); }
if($security_check == true) { return -4; }
foreach($templatecache as $template) { // PostgreSQL causes apache to stop sending content sometimes and
|
// causes the page to stop loading during many queries all at one time if($db->engine == "pgsql") { echo " "; flush(); }
|
// causes the page to stop loading during many queries all at one time if($db->engine == "pgsql") { echo " "; flush(); }
|
$new_template = array( "title" => $db->escape_string($template['attributes']['name']), "template" => $db->escape_string($template['value']), "sid" => $db->escape_string($sid), "version" => $db->escape_string($template['attributes']['version']), "dateline" => TIME_NOW ); $db->insert_query("templates", $new_template);
| $db->insert_query("templates", $template);
|
}
|
}
|
|
|
$properties['templateset'] = $sid; }
| $properties['templateset'] = $sid; }
|
Zeile 190 | Zeile 207 |
---|
// Trick the system into thinking we have a good array =P $theme['stylesheets']['stylesheet'] = array($theme['stylesheets']['stylesheet']); }
|
// Trick the system into thinking we have a good array =P $theme['stylesheets']['stylesheet'] = array($theme['stylesheets']['stylesheet']); }
|
|
|
foreach($theme['stylesheets']['stylesheet'] as $stylesheet) {
|
foreach($theme['stylesheets']['stylesheet'] as $stylesheet) {
|
| if(substr($stylesheet['attributes']['name'], -4) != ".css") { continue; }
|
if(!$stylesheet['attributes']['lastmodified']) { $stylesheet['attributes']['lastmodified'] = TIME_NOW; }
|
if(!$stylesheet['attributes']['lastmodified']) { $stylesheet['attributes']['lastmodified'] = TIME_NOW; }
|
|
|
$new_stylesheet = array( "name" => $db->escape_string($stylesheet['attributes']['name']), "tid" => $theme_id,
| $new_stylesheet = array( "name" => $db->escape_string($stylesheet['attributes']['name']), "tid" => $theme_id,
|
Zeile 213 | Zeile 235 |
---|
{ $css_url = $cached; }
|
{ $css_url = $cached; }
|
|
|
$attachedto = $stylesheet['attributes']['attachedto']; if(!$attachedto) { $attachedto = "global"; }
|
$attachedto = $stylesheet['attributes']['attachedto']; if(!$attachedto) { $attachedto = "global"; }
|
|
|
// private.php?compose,folders|usercp.php,global|global $attachedto = explode("|", $attachedto); foreach($attachedto as $attached_file)
| // private.php?compose,folders|usercp.php,global|global $attachedto = explode("|", $attachedto); foreach($attachedto as $attached_file)
|
Zeile 230 | Zeile 252 |
---|
{ $attached_actions = array("global"); }
|
{ $attached_actions = array("global"); }
|
|
|
foreach($attached_actions as $action) { $theme_stylesheets[$attached_file][$action][] = $css_url;
| foreach($attached_actions as $action) { $theme_stylesheets[$attached_file][$action][] = $css_url;
|
Zeile 243 | Zeile 265 |
---|
); $db->update_query("themes", $updated_theme, "tid='{$theme_id}'"); }
|
); $db->update_query("themes", $updated_theme, "tid='{$theme_id}'"); }
|
|
|
update_theme_stylesheet_list($theme_id);
// And done?
| update_theme_stylesheet_list($theme_id);
// And done?
|
Zeile 259 | Zeile 281 |
---|
*/ function parse_theme_variables($string, $variables=array()) {
|
*/ function parse_theme_variables($string, $variables=array()) {
|
foreach(array_keys($variables) as $variable)
| foreach(array_keys($variables) as $variable)
|
{ $find[] = "{{$variable}}"; $replace[] = $variables[$variable];
| { $find[] = "{{$variable}}"; $replace[] = $variables[$variable];
|
Zeile 286 | Zeile 308 |
---|
{ $theme_directory = "cache/themes"; $filename = $tid."_".$filename;
|
{ $theme_directory = "cache/themes"; $filename = $tid."_".$filename;
|
}
| }
|
// Does our theme directory exist? Try and create it. elseif(!is_dir(MYBB_ROOT."cache/themes/theme{$tid}")) {
| // Does our theme directory exist? Try and create it. elseif(!is_dir(MYBB_ROOT."cache/themes/theme{$tid}")) {
|
Zeile 301 | Zeile 323 |
---|
$fp = @fopen(MYBB_ROOT."cache/themes/theme{$tid}/index.html", "w"); @fwrite($fp, ""); @fclose($fp);
|
$fp = @fopen(MYBB_ROOT."cache/themes/theme{$tid}/index.html", "w"); @fwrite($fp, ""); @fclose($fp);
|
|
|
$theme_directory = "cache/themes/theme{$tid}"; } }
| $theme_directory = "cache/themes/theme{$tid}"; } }
|
Zeile 315 | Zeile 337 |
---|
"theme" => $theme_directory ); $stylesheet = parse_theme_variables($stylesheet, $theme_vars);
|
"theme" => $theme_directory ); $stylesheet = parse_theme_variables($stylesheet, $theme_vars);
|
$stylesheet = preg_replace("#url\((\"|'|)(.*)\\1\)#e", "fix_css_urls('$2')", $stylesheet);
| $stylesheet = preg_replace_callback("#url\((\"|'|)(.*)\\1\)#", create_function('$matches', 'return fix_css_urls($matches[2]);'), $stylesheet);
|
$fp = @fopen(MYBB_ROOT."{$theme_directory}/{$filename}", "wb"); if(!$fp)
|
$fp = @fopen(MYBB_ROOT."{$theme_directory}/{$filename}", "wb"); if(!$fp)
|
{
| {
|
return false; }
|
return false; }
|
|
|
@fwrite($fp, $stylesheet); @fclose($fp); return "{$theme_directory}/{$filename}"; }
|
@fwrite($fp, $stylesheet); @fclose($fp); return "{$theme_directory}/{$filename}"; }
|
|
|
function resync_stylesheet($stylesheet) { global $db;
|
function resync_stylesheet($stylesheet) { global $db;
|
|
|
// Try and fix any missing cache file names if(!$stylesheet['cachefile'] && $stylesheet['name']) {
|
// Try and fix any missing cache file names if(!$stylesheet['cachefile'] && $stylesheet['name']) {
|
$stylesheet['cachefile'] = $stylesheet['name']; $db->update_query("themestylesheets", array('cachefile' => $db->escape_string($stylesheet['name'])), "sid='{$stylesheet['sid']}'", 1);
| $stylesheet['cachefile'] = $stylesheet['name']; $db->update_query("themestylesheets", array('cachefile' => $db->escape_string($stylesheet['name'])), "sid='{$stylesheet['sid']}'");
|
}
|
}
|
|
|
// Still don't have the cache file name or is it not a flat file? Return false if(!$stylesheet['cachefile'] || strpos($stylesheet['cachefile'], 'css.php') !== false)
|
// Still don't have the cache file name or is it not a flat file? Return false if(!$stylesheet['cachefile'] || strpos($stylesheet['cachefile'], 'css.php') !== false)
|
{
| {
|
return false; }
|
return false; }
|
|
|
if(!file_exists(MYBB_ROOT."cache/themes/theme{$stylesheet['tid']}/{$stylesheet['name']}") && !file_exists(MYBB_ROOT."cache/themes/{$stylesheet['tid']}_{$stylesheet['name']}")) { if(cache_stylesheet($stylesheet['tid'], $stylesheet['cachefile'], $stylesheet['stylesheet']) !== false) {
|
if(!file_exists(MYBB_ROOT."cache/themes/theme{$stylesheet['tid']}/{$stylesheet['name']}") && !file_exists(MYBB_ROOT."cache/themes/{$stylesheet['tid']}_{$stylesheet['name']}")) { if(cache_stylesheet($stylesheet['tid'], $stylesheet['cachefile'], $stylesheet['stylesheet']) !== false) {
|
$db->update_query("themestylesheets", array('cachefile' => $db->escape_string($stylesheet['name'])), "sid='{$stylesheet['sid']}'", 1);
| $db->update_query("themestylesheets", array('cachefile' => $db->escape_string($stylesheet['name'])), "sid='{$stylesheet['sid']}'");
|
update_theme_stylesheet_list($stylesheet['tid']);
|
update_theme_stylesheet_list($stylesheet['tid']);
|
|
|
if($stylesheet['sid'] != 1) {
|
if($stylesheet['sid'] != 1) {
|
$db->update_query("themestylesheets", array('lastmodified' => TIME_NOW), "sid='{$stylesheet['sid']}'", 1);
| $db->update_query("themestylesheets", array('lastmodified' => TIME_NOW), "sid='{$stylesheet['sid']}'");
|
} }
|
} }
|
|
|
return true; } else if($stylesheet['sid'] != 1 && @filemtime(MYBB_ROOT."cache/themes/theme{$stylesheet['tid']}/{$stylesheet['name']}") > $stylesheet['lastmodified'])
| return true; } else if($stylesheet['sid'] != 1 && @filemtime(MYBB_ROOT."cache/themes/theme{$stylesheet['tid']}/{$stylesheet['name']}") > $stylesheet['lastmodified'])
|
Zeile 367 | Zeile 389 |
---|
$db->update_query("themestylesheets", array('stylesheet' => $db->escape_string($contents), 'lastmodified' => TIME_NOW), "sid='{$stylesheet['sid']}'", 1); return true; }
|
$db->update_query("themestylesheets", array('stylesheet' => $db->escape_string($contents), 'lastmodified' => TIME_NOW), "sid='{$stylesheet['sid']}'", 1); return true; }
|
|
|
return false; }
function fix_css_urls($url) {
|
return false; }
function fix_css_urls($url) {
|
if(!preg_match("#^(https?://|/)#i", $url) && strpos($url, "../../../") === false)
| if(!preg_match("#^([a-z0-9]+\:|/)#i", $url) && strpos($url, "../../../") === false)
|
{ return "url(../../../{$url})"; }
| { return "url(../../../{$url})"; }
|
Zeile 425 | Zeile 447 |
---|
{ continue; }
|
{ continue; }
|
|
|
$properties[$property] = $value; if($parent_properties['inherited'][$property])
|
$properties[$property] = $value; if($parent_properties['inherited'][$property])
|
{
| {
|
$properties['inherited'][$property] = $parent_properties['inherited'][$property];
|
$properties['inherited'][$property] = $parent_properties['inherited'][$property];
|
}
| }
|
else { $properties['inherited'][$property] = $parent;
|
else { $properties['inherited'][$property] = $parent;
|
} }
| } }
|
$inherited_properties = true; } }
|
$inherited_properties = true; } }
|
|
|
if(count($stylesheets) == 0) { $parent_stylesheets = unserialize($parent_theme['stylesheets']);
| if(count($stylesheets) == 0) { $parent_stylesheets = unserialize($parent_theme['stylesheets']);
|
Zeile 451 | Zeile 473 |
---|
{ continue; }
|
{ continue; }
|
|
|
foreach($value as $action => $sheets) { foreach($sheets as $stylesheet)
| foreach($value as $action => $sheets) { foreach($sheets as $stylesheet)
|
Zeile 470 | Zeile 492 |
---|
} } $inherited_stylesheets = true;
|
} } $inherited_stylesheets = true;
|
}
| }
|
} }
| } }
|
Zeile 514 | Zeile 536 |
---|
$stripped_css = preg_replace('#(?<!\\")\}#', "\n}\n", $css);
// Fetch out classes and comments
|
$stripped_css = preg_replace('#(?<!\\")\}#', "\n}\n", $css);
// Fetch out classes and comments
|
preg_match_all('#(\/\*(.|[\r\n])*?\*\/)?([a-z0-9a+\\\[\]\-\"=_:>\*\.\#\,\s\(\)\|~\^]+)(\s*)\{(.*?)\}\n#msi', $stripped_css, $matches, PREG_PATTERN_ORDER);
| preg_match_all('#(\/\*(.|[\r\n])*?\*\/)?([a-z0-9a+\\\[\]\-\"=_:>\*\.\#\,\s\(\)\|~|@\^]+)(\s*)\{(.*?)\}\n#msi', $stripped_css, $matches, PREG_PATTERN_ORDER);
|
$total = count($matches[1]);
for($i=0; $i < $total; $i++)
| $total = count($matches[1]);
for($i=0; $i < $total; $i++)
|
Zeile 524 | Zeile 546 |
---|
$class_name = trim($class_name); $comments = $matches[1][$i]; preg_match_all("#Name:(.*)#i", $comments, $name_match);
|
$class_name = trim($class_name); $comments = $matches[1][$i]; preg_match_all("#Name:(.*)#i", $comments, $name_match);
|
if($name_match[count($name_match)-1][0])
| if(isset($name_match[count($name_match)-1][0]))
|
{ $name = trim($name_match[count($name_match)-1][0]); } preg_match_all("#Description:(.*)#i", $comments, $description_match);
|
{ $name = trim($name_match[count($name_match)-1][0]); } preg_match_all("#Description:(.*)#i", $comments, $description_match);
|
if($description_match[count($description_match)-1][0])
| if(isset($description_match[count($description_match)-1][0]))
|
{ $description = trim($description_match[count($description_match)-1][0]); } $class_id = md5($class_name);
|
{ $description = trim($description_match[count($description_match)-1][0]); } $class_id = md5($class_name);
|
if($already_parsed[$class_id])
| if(isset($already_parsed[$class_id]))
|
{ $already_parsed[$class_id]++; $class_id .= "_".$already_parsed[$class_id];
| { $already_parsed[$class_id]++; $class_id .= "_".$already_parsed[$class_id];
|
Zeile 554 | Zeile 576 |
---|
function get_selectors_as_options($css, $selected_item="") { $select = "";
|
function get_selectors_as_options($css, $selected_item="") { $select = "";
|
|
|
if(!is_array($css))
|
if(!is_array($css))
|
{
| {
|
$css = css_to_array($css); }
|
$css = css_to_array($css); }
|
|
|
$selected = false;
|
$selected = false;
|
|
|
if(is_array($css)) { uasort($css, "css_selectors_sort_cmp");
|
if(is_array($css)) { uasort($css, "css_selectors_sort_cmp");
|
|
|
foreach($css as $id => $css_array) { if(!$css_array['name']) { $css_array['name'] = $css_array['class_name']; }
|
foreach($css as $id => $css_array) { if(!$css_array['name']) { $css_array['name'] = $css_array['class_name']; }
|
|
|
if($selected_item == $id || (!$selected_item && !$selected))
|
if($selected_item == $id || (!$selected_item && !$selected))
|
{
| {
|
$select .= "<option value=\"{$id}\" selected=\"selected\">{$css_array['name']}</option>\n"; $selected = true; }
| $select .= "<option value=\"{$id}\" selected=\"selected\">{$css_array['name']}</option>\n"; $selected = true; }
|
Zeile 590 | Zeile 612 |
---|
function css_selectors_sort_cmp($a, $b) { if(!$a['name'])
|
function css_selectors_sort_cmp($a, $b) { if(!$a['name'])
|
{
| {
|
$a['name'] = $a['class_name'];
|
$a['name'] = $a['class_name'];
|
}
| }
|
if(!$b['name'])
|
if(!$b['name'])
|
{
| {
|
$b['name'] = $b['class_name'];
|
$b['name'] = $b['class_name'];
|
}
| }
|
return strcmp($a['name'], $b['name']); }
| return strcmp($a['name'], $b['name']); }
|
Zeile 607 | Zeile 629 |
---|
{ $css = css_to_array($css); }
|
{ $css = css_to_array($css); }
|
|
|
if(!isset($css[$id])) { return false;
| if(!isset($css[$id])) { return false;
|
Zeile 627 | Zeile 649 |
---|
{ return; }
|
{ return; }
|
|
|
$values = explode(";", $values); foreach($values as $value) {
| $values = explode(";", $values); foreach($values as $value) {
|
Zeile 679 | Zeile 701 |
---|
{ $parsed_css = css_to_array($css); }
|
{ $parsed_css = css_to_array($css); }
|
|
|
if(!$class_id) { $class_id = $parsed_css[$selector]['class_name']; }
|
if(!$class_id) { $class_id = $parsed_css[$selector]['class_name']; }
|
|
|
// The specified class ID cannot be found, add CSS to end of file if(!$css || !$parsed_css[$selector]) {
| // The specified class ID cannot be found, add CSS to end of file if(!$css || !$parsed_css[$selector]) {
|
Zeile 695 | Zeile 717 |
---|
{ $css = str_replace(array("\r\n", "\n", "\r"), "\n", $css); $css = preg_replace('#(?<!\\")\}#', "}\n", $css);
|
{ $css = str_replace(array("\r\n", "\n", "\r"), "\n", $css); $css = preg_replace('#(?<!\\")\}#', "}\n", $css);
|
$css = preg_replace("#\s*([a-z0-9a+\\\[\]\-\"=_:>\*\.\#\,\s\(\)\|~\^]+)(\s*)\{(\n*)#isu", "\n$1 {\n", $css);
| $css = preg_replace("#^(?!@)\s*([a-z0-9a+\\\[\]\-\"=_:>\*\.\#\,\s\(\)\|~\^]+)(\s*)\{(\n*)#isu", "\n$1 {\n", $css);
|
$css = preg_replace("#\s{1,}\{#", " {", $css); $existing_block = $parsed_css[$selector];
|
$css = preg_replace("#\s{1,}\{#", " {", $css); $existing_block = $parsed_css[$selector];
|
|
|
$break = strrpos($selector, "_"); if($break !== false)
|
$break = strrpos($selector, "_"); if($break !== false)
|
{
| {
|
$actual_occurance = intval(substr($selector, ($break+1)));
|
$actual_occurance = intval(substr($selector, ($break+1)));
|
}
| }
|
if(!$actual_occurance) { $actual_occurance = 1; }
|
if(!$actual_occurance) { $actual_occurance = 1; }
|
|
|
$occurance = 1; $pos = 0; do
| $occurance = 1; $pos = 0; do
|
Zeile 733 | Zeile 755 |
---|
} $css = preg_replace("#{\n*#s", "{\n", $css); $css = preg_replace("#\s*\}\s*#", "\n}\n\n", $css);
|
} $css = preg_replace("#{\n*#s", "{\n", $css); $css = preg_replace("#\s*\}\s*#", "\n}\n\n", $css);
|
return $css;
| return $css;
|
}
function copy_stylesheet_to_theme($stylesheet, $tid) { global $db;
|
}
function copy_stylesheet_to_theme($stylesheet, $tid) { global $db;
|
|
|
$stylesheet['tid'] = $tid; unset($stylesheet['sid']);
|
$stylesheet['tid'] = $tid; unset($stylesheet['sid']);
|
| $new_stylesheet = array();
|
foreach($stylesheet as $key => $value)
|
foreach($stylesheet as $key => $value)
|
{ $stylesheet[$db->escape_string($key)] = $db->escape_string($value);
| { if(!is_numeric($key)) { $new_stylesheet[$db->escape_string($key)] = $db->escape_string($value); }
|
}
|
}
|
$sid = $db->insert_query("themestylesheets", $stylesheet);
| $sid = $db->insert_query("themestylesheets", $new_stylesheet);
|
return $sid; }
|
return $sid; }
|
|
|
function update_theme_stylesheet_list($tid) { global $db;
|
function update_theme_stylesheet_list($tid) { global $db;
|
|
|
$stylesheets = array();
|
$stylesheets = array();
|
|
|
$child_list = make_child_theme_list($tid); $parent_list = make_parent_theme_list($tid);
|
$child_list = make_child_theme_list($tid); $parent_list = make_parent_theme_list($tid);
|
|
|
if(!is_array($parent_list)) { return false; }
|
if(!is_array($parent_list)) { return false; }
|
|
|
$tid_list = implode(',', $parent_list);
|
$tid_list = implode(',', $parent_list);
|
|
|
// Get our list of stylesheets $query = $db->simple_select("themestylesheets", "sid,cachefile,attachedto,tid,lastmodified,name", "tid IN ({$tid_list})", array('order_by' => 'tid', 'order_dir' => 'desc')); while($stylesheet = $db->fetch_array($query))
| // Get our list of stylesheets $query = $db->simple_select("themestylesheets", "sid,cachefile,attachedto,tid,lastmodified,name", "tid IN ({$tid_list})", array('order_by' => 'tid', 'order_dir' => 'desc')); while($stylesheet = $db->fetch_array($query))
|
Zeile 779 | Zeile 805 |
---|
{ $stylesheet['inherited'] = $stylesheet['tid']; }
|
{ $stylesheet['inherited'] = $stylesheet['tid']; }
|
|
|
$stylesheets[$stylesheet['name']] = $stylesheet;
|
$stylesheets[$stylesheet['name']] = $stylesheet;
|
}
| }
|
}
|
}
|
|
|
foreach($stylesheets as $name => $stylesheet) { $sid = $stylesheet['sid']; $css_url = "css.php?stylesheet={$sid}";
|
foreach($stylesheets as $name => $stylesheet) { $sid = $stylesheet['sid']; $css_url = "css.php?stylesheet={$sid}";
|
|
|
foreach($parent_list as $theme_id) { if(file_exists(MYBB_ROOT."cache/themes/theme{$theme_id}/{$stylesheet['name']}") && filemtime(MYBB_ROOT."cache/themes/theme{$theme_id}/{$stylesheet['name']}") >= $stylesheet['lastmodified'])
| foreach($parent_list as $theme_id) { if(file_exists(MYBB_ROOT."cache/themes/theme{$theme_id}/{$stylesheet['name']}") && filemtime(MYBB_ROOT."cache/themes/theme{$theme_id}/{$stylesheet['name']}") >= $stylesheet['lastmodified'])
|
Zeile 797 | Zeile 823 |
---|
break; } }
|
break; } }
|
|
|
$attachedto = $stylesheet['attachedto']; if(!$attachedto) {
| $attachedto = $stylesheet['attachedto']; if(!$attachedto) {
|
Zeile 814 | Zeile 840 |
---|
$attached_actions = explode(",", $attached_file[1]); $attached_file = $attached_file[0]; }
|
$attached_actions = explode(",", $attached_file[1]); $attached_file = $attached_file[0]; }
|
|
|
if(count($attached_actions) == 0)
|
if(count($attached_actions) == 0)
|
{
| {
|
$attached_actions = array("global"); }
|
$attached_actions = array("global"); }
|
|
|
foreach($attached_actions as $action) { $theme_stylesheets[$attached_file][$action][] = $css_url;
|
foreach($attached_actions as $action) { $theme_stylesheets[$attached_file][$action][] = $css_url;
|
|
|
if($stylesheet['inherited']) { $theme_stylesheets['inherited']["{$attached_file}_{$action}"][$css_url] = $stylesheet['inherited'];
| if($stylesheet['inherited']) { $theme_stylesheets['inherited']["{$attached_file}_{$action}"][$css_url] = $stylesheet['inherited'];
|
Zeile 837 | Zeile 863 |
---|
"stylesheets" => $db->escape_string(serialize($theme_stylesheets)) ); $db->update_query("themes", $updated_theme, "tid='{$tid}'");
|
"stylesheets" => $db->escape_string(serialize($theme_stylesheets)) ); $db->update_query("themes", $updated_theme, "tid='{$tid}'");
|
|
|
// Do we have any children themes that need updating too? if(count($child_list) > 0) {
| // Do we have any children themes that need updating too? if(count($child_list) > 0) {
|
Zeile 846 | Zeile 872 |
---|
update_theme_stylesheet_list($id); } }
|
update_theme_stylesheet_list($id); } }
|
|
|
return true; }
function make_parent_theme_list($tid) { static $themes_by_parent;
|
return true; }
function make_parent_theme_list($tid) { static $themes_by_parent;
|
|
|
$themes = array(); if(!is_array($themes_by_parent))
|
$themes = array(); if(!is_array($themes_by_parent))
|
{
| {
|
$theme_cache = cache_themes(); foreach($theme_cache as $key => $theme) {
| $theme_cache = cache_themes(); foreach($theme_cache as $key => $theme) {
|
Zeile 864 | Zeile 890 |
---|
{ continue; }
|
{ continue; }
|
|
|
$themes_by_parent[$theme['tid']][$theme['pid']] = $theme;
|
$themes_by_parent[$theme['tid']][$theme['pid']] = $theme;
|
} } if(!is_array($themes_by_parent[$tid])) { return false; }
| } }
if(!isset($themes_by_parent[$tid])) { return false; }
|
reset($themes_by_parent); reset($themes_by_parent[$tid]);
|
reset($themes_by_parent); reset($themes_by_parent[$tid]);
|
|
|
$themes = array();
|
$themes = array();
|
|
|
foreach($themes_by_parent[$tid] as $key => $theme) { $themes[] = $theme['tid']; $parents = make_parent_theme_list($theme['pid']);
|
foreach($themes_by_parent[$tid] as $key => $theme) { $themes[] = $theme['tid']; $parents = make_parent_theme_list($theme['pid']);
|
|
|
if(is_array($parents)) { $themes = array_merge($themes, $parents); } }
|
if(is_array($parents)) { $themes = array_merge($themes, $parents); } }
|
|
|
return $themes; }
function make_child_theme_list($tid) { static $themes_by_child;
|
return $themes; }
function make_child_theme_list($tid) { static $themes_by_child;
|
|
|
$themes = array(); if(!is_array($themes_by_child)) {
| $themes = array(); if(!is_array($themes_by_child)) {
|
Zeile 907 | Zeile 933 |
---|
{ continue; }
|
{ continue; }
|
|
|
$themes_by_child[$theme['pid']][$theme['tid']] = $theme; } }
|
$themes_by_child[$theme['pid']][$theme['tid']] = $theme; } }
|
|
|
if(!is_array($themes_by_child[$tid])) { return; }
|
if(!is_array($themes_by_child[$tid])) { return; }
|
|
|
$themes = array();
|
$themes = array();
|
|
|
foreach($themes_by_child[$tid] as $theme) { $themes[] = $theme['tid']; $children = make_child_theme_list($theme['tid']);
|
foreach($themes_by_child[$tid] as $theme) { $themes[] = $theme['tid']; $children = make_child_theme_list($theme['tid']);
|
|
|
if(is_array($children)) { $themes = array_merge($themes, $children); } }
|
if(is_array($children)) { $themes = array_merge($themes, $children); } }
|
return $themes; }
| return $themes; }
|
function cache_themes() { global $db, $theme_cache;
|
function cache_themes() { global $db, $theme_cache;
|
|
|
if(empty($theme_cache) || !is_array($theme_cache)) { $query = $db->simple_select("themes", "*", "", array('order_by' => "pid, name"));
| if(empty($theme_cache) || !is_array($theme_cache)) { $query = $db->simple_select("themes", "*", "", array('order_by' => "pid, name"));
|
Zeile 945 | Zeile 971 |
---|
$theme['properties'] = unserialize($theme['properties']); $theme['stylesheets'] = unserialize($theme['stylesheets']); $theme_cache[$theme['tid']] = $theme;
|
$theme['properties'] = unserialize($theme['properties']); $theme['stylesheets'] = unserialize($theme['stylesheets']); $theme_cache[$theme['tid']] = $theme;
|
|
|
if($theme['def'] == 1) { $theme_cache['default'] = $theme['tid'];
|
if($theme['def'] == 1) { $theme_cache['default'] = $theme['tid'];
|
}
| }
|
}
|
}
|
}
| }
|
// Do we have no themes assigned as default? if(!$theme_cache['default']) { $theme_cache['default'] = 1; }
|
// Do we have no themes assigned as default? if(!$theme_cache['default']) { $theme_cache['default'] = 1; }
|
|
|
return $theme_cache; }
function build_theme_list($parent=0, $depth=0) { global $mybb, $db, $table, $lang, $page; // Global $table is bad, but it will have to do for now
|
return $theme_cache; }
function build_theme_list($parent=0, $depth=0) { global $mybb, $db, $table, $lang, $page; // Global $table is bad, but it will have to do for now
|
static $theme_cache;
| static $theme_cache;
|
$padding = $depth*20; // Padding
if(!is_array($theme_cache))
|
$padding = $depth*20; // Padding
if(!is_array($theme_cache))
|
{
| {
|
$themes = cache_themes(); $query = $db->query(" SELECT style, COUNT(uid) AS users
| $themes = cache_themes(); $query = $db->query(" SELECT style, COUNT(uid) AS users
|
Zeile 982 | Zeile 1008 |
---|
if($user_themes['style'] == 0) { $user_themes['style'] = $themes['default'];
|
if($user_themes['style'] == 0) { $user_themes['style'] = $themes['default'];
|
}
| }
|
if($themes[$user_themes['style']]['users'] > 0)
|
if($themes[$user_themes['style']]['users'] > 0)
|
{
| {
|
$themes[$user_themes['style']]['users'] += intval($user_themes['users']);
|
$themes[$user_themes['style']]['users'] += intval($user_themes['users']);
|
}
| }
|
else
|
else
|
{
| {
|
$themes[$user_themes['style']]['users'] = intval($user_themes['users']);
|
$themes[$user_themes['style']]['users'] = intval($user_themes['users']);
|
} }
// Restrucure the theme array to something we can "loop-de-loop" with foreach($themes as $key => $theme) { if($key == "default") {
| } }
// Restrucure the theme array to something we can "loop-de-loop" with foreach($themes as $key => $theme) { if($key == "default") {
|
continue; }
|
continue; }
|
|
|
$theme_cache[$theme['pid']][$theme['tid']] = $theme; } $theme_cache['num_themes'] = count($themes); unset($themes);
|
$theme_cache[$theme['pid']][$theme['tid']] = $theme; } $theme_cache['num_themes'] = count($themes); unset($themes);
|
}
| }
|
if(!is_array($theme_cache[$parent])) {
| if(!is_array($theme_cache[$parent])) {
|
Zeile 1014 | Zeile 1040 |
---|
}
foreach($theme_cache[$parent] as $theme)
|
}
foreach($theme_cache[$parent] as $theme)
|
{
| {
|
$popup = new PopupMenu("theme_{$theme['tid']}", $lang->options); if($theme['tid'] > 1) { $popup->add_item($lang->edit_theme, "index.php?module=style-themes&action=edit&tid={$theme['tid']}");
|
$popup = new PopupMenu("theme_{$theme['tid']}", $lang->options); if($theme['tid'] > 1) { $popup->add_item($lang->edit_theme, "index.php?module=style-themes&action=edit&tid={$theme['tid']}");
|
$theme['name'] = "<a href=\"index.php?module=style-themes&action=edit&tid={$theme['tid']}\">{$theme['name']}</a>";
| $theme['name'] = "<a href=\"index.php?module=style-themes&action=edit&tid={$theme['tid']}\">".htmlspecialchars_uni($theme['name'])."</a>";
|
// We must have at least the master and 1 other active theme if($theme_cache['num_themes'] > 2)
|
// We must have at least the master and 1 other active theme if($theme_cache['num_themes'] > 2)
|
{
| {
|
$popup->add_item($lang->delete_theme, "index.php?module=style-themes&action=delete&tid={$theme['tid']}&my_post_key={$mybb->post_code}", "return AdminCP.deleteConfirmation(this, '{$lang->confirm_theme_deletion}')");
|
$popup->add_item($lang->delete_theme, "index.php?module=style-themes&action=delete&tid={$theme['tid']}&my_post_key={$mybb->post_code}", "return AdminCP.deleteConfirmation(this, '{$lang->confirm_theme_deletion}')");
|
}
| }
|
if($theme['def'] != 1) { $popup->add_item($lang->set_as_default, "index.php?module=style-themes&action=set_default&tid={$theme['tid']}&my_post_key={$mybb->post_code}"); $set_default = "<a href=\"index.php?module=style-themes&action=set_default&tid={$theme['tid']}&my_post_key={$mybb->post_code}\"><img src=\"styles/{$page->style}/images/icons/make_default.gif\" alt=\"{$lang->set_as_default}\" style=\"vertical-align: middle;\" title=\"{$lang->set_as_default}\" /></a>"; } else
|
if($theme['def'] != 1) { $popup->add_item($lang->set_as_default, "index.php?module=style-themes&action=set_default&tid={$theme['tid']}&my_post_key={$mybb->post_code}"); $set_default = "<a href=\"index.php?module=style-themes&action=set_default&tid={$theme['tid']}&my_post_key={$mybb->post_code}\"><img src=\"styles/{$page->style}/images/icons/make_default.gif\" alt=\"{$lang->set_as_default}\" style=\"vertical-align: middle;\" title=\"{$lang->set_as_default}\" /></a>"; } else
|
{
| {
|
$set_default = "<img src=\"styles/{$page->style}/images/icons/default.gif\" alt=\"{$lang->default_theme}\" style=\"vertical-align: middle;\" title=\"{$lang->default_theme}\" />"; } $popup->add_item($lang->force_on_users, "index.php?module=style-themes&action=force&tid={$theme['tid']}&my_post_key={$mybb->post_code}", "return AdminCP.deleteConfirmation(this, '{$lang->confirm_theme_forced}')");
| $set_default = "<img src=\"styles/{$page->style}/images/icons/default.gif\" alt=\"{$lang->default_theme}\" style=\"vertical-align: middle;\" title=\"{$lang->default_theme}\" />"; } $popup->add_item($lang->force_on_users, "index.php?module=style-themes&action=force&tid={$theme['tid']}&my_post_key={$mybb->post_code}", "return AdminCP.deleteConfirmation(this, '{$lang->confirm_theme_forced}')");
|
Zeile 1043 | Zeile 1069 |
---|
$table->construct_cell(my_number_format($theme['users']), array("class" => "align_center")); $table->construct_cell($popup->fetch(), array("class" => "align_center")); $table->construct_row();
|
$table->construct_cell(my_number_format($theme['users']), array("class" => "align_center")); $table->construct_cell($popup->fetch(), array("class" => "align_center")); $table->construct_row();
|
|
|
// Fetch & build any child themes build_theme_list($theme['tid'], ++$depth); }
| // Fetch & build any child themes build_theme_list($theme['tid'], ++$depth); }
|
Zeile 1065 | Zeile 1091 |
---|
{ continue; }
|
{ continue; }
|
|
|
$theme_cache[$theme['pid']][$theme['tid']] = $theme; } unset($theme);
| $theme_cache[$theme['pid']][$theme['tid']] = $theme; } unset($theme);
|
Zeile 1082 | Zeile 1108 |
---|
{ continue; }
|
{ continue; }
|
|
|
$list[$theme['tid']] = str_repeat("--", $depth).$theme['name']; // Fetch & build any child themes build_theme_array($ignoretid, $theme['tid'], $depth+1);
|
$list[$theme['tid']] = str_repeat("--", $depth).$theme['name']; // Fetch & build any child themes build_theme_array($ignoretid, $theme['tid'], $depth+1);
|
}
| }
|
if(!$parent) { return $list;
| if(!$parent) { return $list;
|
Zeile 1098 | Zeile 1124 |
---|
{ // Update our CSS to the new stuff in 1.4 $parsed_css = css_to_array($css);
|
{ // Update our CSS to the new stuff in 1.4 $parsed_css = css_to_array($css);
|
|
|
if(!is_array($parsed_css)) { return ""; }
|
if(!is_array($parsed_css)) { return ""; }
|
|
|
foreach($parsed_css as $class_id => $array) { $parsed_css[$class_id]['values'] = str_replace('#eea8a1', '#ffdde0', $array['values']); $parsed_css[$class_id]['values'] = str_replace('font-family: Verdana;', 'font-family: Verdana, Arial, Sans-Serif;', $array['values']);
|
foreach($parsed_css as $class_id => $array) { $parsed_css[$class_id]['values'] = str_replace('#eea8a1', '#ffdde0', $array['values']); $parsed_css[$class_id]['values'] = str_replace('font-family: Verdana;', 'font-family: Verdana, Arial, Sans-Serif;', $array['values']);
|
|
|
switch($array['class_name']) { case '.bottommenu':
| switch($array['class_name']) { case '.bottommenu':
|
Zeile 1136 | Zeile 1162 |
---|
unset($parsed_css[$class_id]); break; default:
|
unset($parsed_css[$class_id]); break; default:
|
}
| }
|
}
|
}
|
|
|
$to_add = array( md5('.trow_selected td') => array("class_name" => '.trow_selected td', "values" => 'background: #FFFBD9;'), md5('blockquote') => array("class_name" => 'blockquote', "values" => "border: 1px solid #ccc;\n\tmargin: 0;\n\tbackground: #fff;\n\tpadding: 4px;"),
| $to_add = array( md5('.trow_selected td') => array("class_name" => '.trow_selected td', "values" => 'background: #FFFBD9;'), md5('blockquote') => array("class_name" => 'blockquote', "values" => "border: 1px solid #ccc;\n\tmargin: 0;\n\tbackground: #fff;\n\tpadding: 4px;"),
|
Zeile 1159 | Zeile 1185 |
---|
md5('.moderate_warning') => array("class_name" => '.moderate_warning', "values" => "color: #F3611B;"), md5('.low_warning') => array("class_name" => '.low_warning', "values" => "color: #AE5700;"), md5('div.error') => array("class_name" => 'div.error', "values" => "padding: 5px 10px;\n\tborder-top: 2px solid #FFD324;\n\tborder-bottom: 2px solid #FFD324;\n\tbackground: #FFF6BF;\n\tfont-size: 12px;"),
|
md5('.moderate_warning') => array("class_name" => '.moderate_warning', "values" => "color: #F3611B;"), md5('.low_warning') => array("class_name" => '.low_warning', "values" => "color: #AE5700;"), md5('div.error') => array("class_name" => 'div.error', "values" => "padding: 5px 10px;\n\tborder-top: 2px solid #FFD324;\n\tborder-bottom: 2px solid #FFD324;\n\tbackground: #FFF6BF;\n\tfont-size: 12px;"),
|
md5('div.error p') => array("class_name" => 'div.error p', "values" => "margin: 0;\n\tcolor: #000;\n\tfont-weight: normal;"),
| md5('div.error p') => array("class_name" => 'div.error p', "values" => "margin: 0;\n\tcolor: #000;\n\tfont-weight: normal;"),
|
md5('div.error p em') => array("class_name" => 'div.error p em', "values" => "font-style: normal;\n\tfont-weight: bold;\n\tpadding-left: 24px;\n\tdisplay: block;\n\tcolor: #C00;\n\tbackground: url({$mybb->settings['bburl']}/images/error.gif) no-repeat 0;"), md5('div.error.ul') => array("class_name" => 'div.error.ul', "values" => "margin-left: 24px;"), md5('.online') => array("class_name" => '.online', "values" => "color: #15A018;"),
| md5('div.error p em') => array("class_name" => 'div.error p em', "values" => "font-style: normal;\n\tfont-weight: bold;\n\tpadding-left: 24px;\n\tdisplay: block;\n\tcolor: #C00;\n\tbackground: url({$mybb->settings['bburl']}/images/error.gif) no-repeat 0;"), md5('div.error.ul') => array("class_name" => 'div.error.ul', "values" => "margin-left: 24px;"), md5('.online') => array("class_name" => '.online', "values" => "color: #15A018;"),
|
Zeile 1187 | Zeile 1213 |
---|
md5('.validation_success') => array("class_name" => '.validation_success', "values" => "background: url(images/valid.gif) no-repeat center left;\n\tcolor: #00b200;\n\tmargin: 5px 0;\n\tpadding: 5px;\n\tfont-weight: bold;\n\tfont-size: 11px;\n\tpadding-left: 22px;"), md5('.validation_loading') => array("class_name" => '.validation_loading', "values" => "background: url(images/spinner.gif) no-repeat center left;\n\tcolor: #555;\n\tmargin: 5px 0;\n\tpadding: 5px;\n\tfont-weight: bold;\n\tfont-size: 11px;\n\tpadding-left: 22px;"), );
|
md5('.validation_success') => array("class_name" => '.validation_success', "values" => "background: url(images/valid.gif) no-repeat center left;\n\tcolor: #00b200;\n\tmargin: 5px 0;\n\tpadding: 5px;\n\tfont-weight: bold;\n\tfont-size: 11px;\n\tpadding-left: 22px;"), md5('.validation_loading') => array("class_name" => '.validation_loading', "values" => "background: url(images/spinner.gif) no-repeat center left;\n\tcolor: #555;\n\tmargin: 5px 0;\n\tpadding: 5px;\n\tfont-weight: bold;\n\tfont-size: 11px;\n\tpadding-left: 22px;"), );
|
|
|
foreach($to_add as $class_id => $array) { if($already_parsed[$class_id])
|
foreach($to_add as $class_id => $array) { if($already_parsed[$class_id])
|
{
| {
|
$already_parsed[$class_id]++; $class_id .= "_".$already_parsed[$class_id];
|
$already_parsed[$class_id]++; $class_id .= "_".$already_parsed[$class_id];
|
}
| }
|
else { $already_parsed[$class_id] = 1; }
|
else { $already_parsed[$class_id] = 1; }
|
|
|
$array['name'] = ""; $array['description'] = "";
|
$array['name'] = ""; $array['description'] = "";
|
|
|
$parsed_css[$class_id] = $array; }
|
$parsed_css[$class_id] = $array; }
|
|
|
$css = ""; foreach($parsed_css as $class_id => $array) {
| $css = ""; foreach($parsed_css as $class_id => $array) {
|
Zeile 1215 | Zeile 1241 |
---|
if($array['name']) { $array['css'] .= "Name: {$array['name']}";
|
if($array['name']) { $array['css'] .= "Name: {$array['name']}";
|
|
|
if($array['description']) { $array['css'] .= "\n"; }
|
if($array['description']) { $array['css'] .= "\n"; }
|
}
| }
|
if($array['description']) { $array['css'] .= "Description: {$array['description']}"; }
|
if($array['description']) { $array['css'] .= "Description: {$array['description']}"; }
|
|
|
$array['css'] .= " */\n"; }
|
$array['css'] .= " */\n"; }
|
|
|
$css .= "{$array['class_name']} {\n\t{$array['values']}\n}\n"; }
|
$css .= "{$array['class_name']} {\n\t{$array['values']}\n}\n"; }
|
|
|
return $css; } ?>
| return $css; } ?>
|