require version information in all additional themes
This commit is contained in:
parent
9b46c8e5e7
commit
f6cbe9a5a0
|
@ -571,7 +571,8 @@ class Pref_Prefs extends Handler_Protected {
|
|||
|
||||
} else if ($pref_name == "USER_CSS_THEME") {
|
||||
|
||||
$themes = array_map("basename", glob("themes/*.css"));
|
||||
$themes = array_filter(array_map("basename", glob("themes/*.css")),
|
||||
"theme_valid");
|
||||
|
||||
print_select($pref_name, $value, $themes,
|
||||
'dojoType="dijit.form.Select"');
|
||||
|
|
|
@ -17,7 +17,10 @@
|
|||
$params["default_view_order_by"] = get_pref("_DEFAULT_VIEW_ORDER_BY");
|
||||
$params["bw_limit"] = (int) $_SESSION["bw_limit"];
|
||||
$params["label_base_index"] = (int) LABEL_BASE_INDEX;
|
||||
$params["theme"] = get_pref("USER_CSS_THEME", false, false);
|
||||
|
||||
$theme = get_pref( "USER_CSS_THEME", false, false);
|
||||
$params["theme"] = theme_valid("$theme") ? $theme : "";
|
||||
|
||||
$params["plugins"] = implode(", ", PluginHost::getInstance()->get_plugin_names());
|
||||
|
||||
$params["php_platform"] = PHP_OS;
|
||||
|
@ -2422,4 +2425,21 @@
|
|||
return LABEL_BASE_INDEX - 1 + abs($feed);
|
||||
}
|
||||
|
||||
function theme_valid($file) {
|
||||
if ($file == "default.css") return true; // needed for array_filter
|
||||
$file = "themes/" . basename($file);
|
||||
|
||||
if (file_exists($file) && is_readable($file)) {
|
||||
$fh = fopen($file, "r");
|
||||
|
||||
if ($fh) {
|
||||
$header = fgets($fh);
|
||||
fclose($fh);
|
||||
|
||||
return strpos($header, "supports-version:" . VERSION_STATIC) !== FALSE;
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
?>
|
||||
|
|
|
@ -65,7 +65,7 @@
|
|||
|
||||
<?php if ($_SESSION["uid"]) {
|
||||
$theme = get_pref( "USER_CSS_THEME", $_SESSION["uid"], false);
|
||||
if ($theme && file_exists("themes/$theme")) {
|
||||
if ($theme && theme_valid("$theme")) {
|
||||
echo stylesheet_tag("themes/$theme");
|
||||
} else {
|
||||
echo stylesheet_tag("themes/default.css");
|
||||
|
|
|
@ -41,7 +41,7 @@
|
|||
|
||||
<?php if ($_SESSION["uid"]) {
|
||||
$theme = get_pref( "USER_CSS_THEME", $_SESSION["uid"], false);
|
||||
if ($theme && file_exists("themes/$theme")) {
|
||||
if ($theme && theme_valid("$theme")) {
|
||||
echo stylesheet_tag("themes/$theme");
|
||||
} else {
|
||||
echo stylesheet_tag("themes/default.css");
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
/* supports-version:1.15 */
|
||||
@import "default.css";
|
||||
|
||||
body#ttrssMain #feeds-holder {
|
||||
|
|
Loading…
Reference in New Issue