aboutsummaryrefslogtreecommitdiffstats
path: root/admin/include/themes.class.php
diff options
context:
space:
mode:
Diffstat (limited to 'admin/include/themes.class.php')
-rw-r--r--admin/include/themes.class.php25
1 files changed, 24 insertions, 1 deletions
diff --git a/admin/include/themes.class.php b/admin/include/themes.class.php
index b30c25add..505785b73 100644
--- a/admin/include/themes.class.php
+++ b/admin/include/themes.class.php
@@ -48,6 +48,8 @@ class themes
*/
function perform_action($action, $theme_id)
{
+ global $conf;
+
if (isset($this->db_themes_by_id[$theme_id]))
{
$crt_db_theme = $this->db_themes_by_id[$theme_id];
@@ -86,6 +88,12 @@ class themes
break;
}
+ if ($this->fs_themes[$theme_id]['mobile'] and !empty($conf['mobile_theme']))
+ {
+ array_push($errors, l10n('You can activate only one mobile theme.'));
+ break;
+ }
+
if (file_exists($file_to_include))
{
include($file_to_include);
@@ -105,6 +113,11 @@ INSERT INTO '.THEMES_TABLE.'
\''.$this->fs_themes[$theme_id]['name'].'\')
;';
pwg_query($query);
+
+ if ($this->fs_themes[$theme_id]['mobile'])
+ {
+ conf_update_param('mobile_theme', $theme_id);
+ }
}
break;
@@ -164,6 +177,11 @@ DELETE
WHERE id= \''.$theme_id.'\'
;';
pwg_query($query);
+
+ if ($this->fs_themes[$theme_id]['mobile'])
+ {
+ conf_update_param('mobile_theme', '');
+ }
break;
case 'delete':
@@ -325,6 +343,7 @@ SELECT
'uri' => '',
'description' => '',
'author' => '',
+ 'mobile' => false,
);
$theme_data = implode( '', file($path.'/themeconf.inc.php') );
@@ -365,10 +384,14 @@ SELECT
{
$theme['parent'] = $val[1];
}
- if (preg_match('/["\']activable["\'].*?(true|false)/', $theme_data, $val))
+ if (preg_match('/["\']activable["\'].*?(true|false)/i', $theme_data, $val))
{
$theme['activable'] = get_boolean($val[1]);
}
+ if (preg_match('/["\']mobile["\'].*?(true|false)/i', $theme_data, $val))
+ {
+ $theme['mobile'] = get_boolean($val[1]);
+ }
// screenshot
$screenshot_path = $path.'/screenshot.png';