Fixed caching from not outputing JS if only CSS is enabled.

This commit is contained in:
green-ponies (jgen) 2011-09-25 14:00:56 -04:00
parent 97d137f365
commit 944f3bdf3d
2 changed files with 29 additions and 7 deletions

View file

@ -273,7 +273,7 @@ class Page {
{ {
global $config; global $config;
if (!$config->get_bool("autocache_css") || !$config->get_bool("autocache_js")) { if (!$config->get_bool("autocache_css") && !$config->get_bool("autocache_js")) {
return false; // caching disabled return false; // caching disabled
} }
@ -283,7 +283,7 @@ class Page {
// Create directory if needed. // Create directory if needed.
if(!file_exists($cache_location)) { if(!file_exists($cache_location)) {
if (is_writeable($cache_location) && !mkdir($cache_location, 0750, true)) { if (!mkdir($cache_location, 0750, true)) {
return false; // failed to create directory return false; // failed to create directory
} }
} }
@ -342,6 +342,17 @@ class Page {
} }
// tell the client where to get the css cache file // tell the client where to get the css cache file
$this->add_html_header('<link rel="stylesheet" href="'.$data_href.'/'.$cache_location.$md5sum.'.css'.'" type="text/css">'); $this->add_html_header('<link rel="stylesheet" href="'.$data_href.'/'.$cache_location.$md5sum.'.css'.'" type="text/css">');
} else {
// Caching of CSS disabled.
foreach(glob("lib/*.css") as $css) {
$this->add_html_header("<link rel='stylesheet' href='$data_href/$css' type='text/css'>");
}
$css_files = glob("ext/*/style.css");
if($css_files) {
foreach($css_files as $css_file) {
$this->add_html_header("<link rel='stylesheet' href='$data_href/$css_file' type='text/css'>");
}
}
} }
@ -380,6 +391,17 @@ class Page {
} }
// tell the client where to get the js cache file // tell the client where to get the js cache file
$this->add_html_header('<script src="'.$data_href.'/'.$cache_location.$md5sum.'.js'.'" type="text/javascript"></script>'); $this->add_html_header('<script src="'.$data_href.'/'.$cache_location.$md5sum.'.js'.'" type="text/javascript"></script>');
} else {
// Caching of Javascript disabled.
foreach(glob("lib/*.js") as $js) {
$this->add_html_header("<script src='$data_href/$js' type='text/javascript'></script>");
}
$js_files = glob("ext/*/script.js");
if($js_files) {
foreach($js_files as $js_file) {
$this->add_html_header("<script src='$data_href/$js_file' type='text/javascript'></script>");
}
}
} }
return true; return true;

View file

@ -287,11 +287,11 @@ class Setup extends SimpleExtension {
$sb->add_text_option("api_recaptcha_pubkey", "<br>Public key: "); $sb->add_text_option("api_recaptcha_pubkey", "<br>Public key: ");
$event->panel->add_block($sb); $event->panel->add_block($sb);
$sb = new SetupBlock("Automatic CSS and JavaScript Caching"); $sb = new SetupBlock("Automatic CSS & JS Caching");
$sb->add_text_option("autocache_location", "<br>Location: "); $sb->add_text_option("autocache_location", "Location: ");
$sb->add_label("<br>Needs to be writeable by the webserver"); $sb->add_label("<br><i>Needs to be writeable by the webserver.</i>");
$sb->add_bool_option("autocache_css", "<br>Enable automatic caching of CSS: "); $sb->add_bool_option("autocache_css", "<br>Automatic caching of CSS: ");
$sb->add_bool_option("autocache_js", "<br>Enable automatic caching of JS: "); $sb->add_bool_option("autocache_js", "<br>Automatic caching of JS: ");
$sb->add_bool_option("autocache_min_css", "<br>Minimize CSS files: "); $sb->add_bool_option("autocache_min_css", "<br>Minimize CSS files: ");
$sb->add_bool_option("autocache_min_js", "<br>Minimize JS files: "); $sb->add_bool_option("autocache_min_js", "<br>Minimize JS files: ");
$event->panel->add_block($sb); $event->panel->add_block($sb);