]> git.mxchange.org Git - friendica.git/blobdiff - view/theme/frio/style.php
Merge pull request #7538 from vinzv/7536-frio-show-notification-icon-in-mobile-view
[friendica.git] / view / theme / frio / style.php
index 7570ae0e5774b13ba52de1b78f39921ffea624ef..c39e672dfa4dd74781ecc1c9d23e54496861dc10 100644 (file)
@@ -2,60 +2,53 @@
 /**
  * @file view/theme/frio/style.php
  */
+
 use Friendica\Core\Config;
 use Friendica\Core\PConfig;
-use Friendica\Model\Profile;
+use Friendica\Util\Strings;
 
 require_once 'view/theme/frio/php/PHPColors/Color.php';
 
+$scheme = '';
 $schemecss = '';
 $schemecssfile = false;
 $scheme_modified = 0;
 
-if ($a->module !== 'install') {
-       // Get the UID of the profile owner.
-       $uid = Profile::getThemeUid();
-       if ($uid) {
-               PConfig::load($uid, 'frio');
-
-               // Load the profile owners pconfig.
-               $scheme           = PConfig::get($uid, 'frio', 'scheme', PConfig::get($uid, 'frio', 'schema'));
-               $nav_bg           = PConfig::get($uid, 'frio', 'nav_bg');
-               $nav_icon_color   = PConfig::get($uid, 'frio', 'nav_icon_color');
-               $link_color       = PConfig::get($uid, 'frio', 'link_color');
-               $background_color = PConfig::get($uid, 'frio', 'background_color');
-               $contentbg_transp = PConfig::get($uid, 'frio', 'contentbg_transp');
-               $background_image = PConfig::get($uid, 'frio', 'background_image');
-               $bg_image_option  = PConfig::get($uid, 'frio', 'bg_image_option');
-               $modified         = PConfig::get($uid, 'frio', 'css_modified');
-
-               // There is maybe the case that the user did never modify the theme settings.
-               // In this case we store the present time.
-               if (empty($modified)) {
-                       PConfig::set($uid, 'frio', 'css_modified', time());
-               }
-       } else {
-               Config::load('frio');
-
-               // Load frios system config.
-               $scheme           = Config::get('frio', 'scheme', Config::get('frio', 'schema'));
-               $nav_bg           = Config::get('frio', 'nav_bg');
-               $nav_icon_color   = Config::get('frio', 'nav_icon_color');
-               $link_color       = Config::get('frio', 'link_color');
-               $background_color = Config::get('frio', 'background_color');
-               $contentbg_transp = Config::get('frio', 'contentbg_transp');
-               $background_image = Config::get('frio', 'background_image');
-               $bg_image_option  = Config::get('frio', 'bg_image_option');
-               $login_bg_image   = Config::get('frio', 'login_bg_image');
-               $login_bg_color   = Config::get('frio', 'login_bg_color');
-               $modified         = Config::get('frio', 'css_modified');
-
-               // There is maybe the case that the user did never modify the theme settings.
-               // In this case we store the present time.
-               if (empty($modified)) {
-                       Config::set('frio', 'css_modified', time());
-               }
-       }
+Config::load('frio');
+
+// Default to hard-coded values for empty settings
+$scheme           = Config::get('frio', 'scheme', Config::get('frio', 'schema'));
+$nav_bg           = Config::get('frio', 'nav_bg')           ?: '#708fa0';
+$nav_icon_color   = Config::get('frio', 'nav_icon_color')   ?: '#ffffff';
+$link_color       = Config::get('frio', 'link_color')       ?: '#6fdbe8';
+$background_color = Config::get('frio', 'background_color') ?: '#ededed';
+$contentbg_transp = Config::get('frio', 'contentbg_transp') ?: '';
+$background_image = Config::get('frio', 'background_image') ?: 'img/none.png';
+$bg_image_option  = Config::get('frio', 'bg_image_option')  ?: '';
+$login_bg_image   = Config::get('frio', 'login_bg_image')   ?: '';
+$login_bg_color   = Config::get('frio', 'login_bg_color')   ?: '';
+$modified         = Config::get('frio', 'css_modified')     ?: time();
+
+if (!$login_bg_image && !$login_bg_color) {
+       $login_bg_image = 'img/login_bg.jpg';
+}
+$login_bg_color = $login_bg_color ?: '#ededed';
+
+// Get the UID of the profile owner.
+$uid = $_REQUEST['puid'] ?? 0;
+if ($uid) {
+       PConfig::load($uid, 'frio');
+
+       // Only override display settings that have actually been set
+       $scheme           = PConfig::get($uid, 'frio', 'scheme', PConfig::get($uid, 'frio', 'schema')) ?: $scheme;
+       $nav_bg           = PConfig::get($uid, 'frio', 'nav_bg')           ?: $nav_bg;
+       $nav_icon_color   = PConfig::get($uid, 'frio', 'nav_icon_color')   ?: $nav_icon_color;
+       $link_color       = PConfig::get($uid, 'frio', 'link_color')       ?: $link_color;
+       $background_color = PConfig::get($uid, 'frio', 'background_color') ?: $background_color;
+       $contentbg_transp = PConfig::get($uid, 'frio', 'contentbg_transp') ?: $contentbg_transp;
+       $background_image = PConfig::get($uid, 'frio', 'background_image') ?: $background_image;
+       $bg_image_option  = PConfig::get($uid, 'frio', 'bg_image_option')  ?: $bg_image_option;
+       $modified         = PConfig::get($uid, 'frio', 'css_modified')     ?: $modified;
 }
 
 // Now load the scheme.  If a value is changed above, we'll keep the settings
@@ -67,9 +60,7 @@ if (!empty($_REQUEST['scheme'])) {
        $scheme = $_REQUEST['scheme'];
 }
 
-// Sanitize the data.
-$scheme = !empty($scheme) ? basename($scheme) : '';
-
+$scheme = Strings::sanitizeFilePathItem($scheme);
 
 if (($scheme) && ($scheme != '---')) {
        if (file_exists('view/theme/frio/scheme/' . $scheme . '.php')) {
@@ -94,24 +85,6 @@ if (!$scheme) {
        }
 }
 
-//Set some defaults - we have to do this after pulling owner settings, and we have to check for each setting
-//individually.  If we don't, we'll have problems if a user has set one, but not all options.
-$nav_bg           = (empty($nav_bg)           ? '#708fa0'      : $nav_bg);
-$nav_icon_color   = (empty($nav_icon_color)   ? '#fff'         : $nav_icon_color);
-$link_color       = (empty($link_color)       ? '#6fdbe8'      : $link_color);
-$background_color = (empty($background_color) ? '#ededed'      : $background_color);
-// The background image can not be empty. So we use a dummy jpg if no image was set.
-$background_image = (empty($background_image) ? 'img/none.jpg' : $background_image);
-$modified         = (empty($modified)         ? time()         : $modified);
-
-
-// set a default login bg image if no custom image and no custom bg color are set.
-if (empty($login_bg_image) && empty($login_bg_color)) {
-       $login_bg_image = 'img/login_bg.jpg';
-}
-$login_bg_color   = (empty($login_bg_color)   ? '#ededed'      : $login_bg_color);
-$login_bg_image   = (empty($login_bg_image)   ? ''             : $login_bg_image);
-
 $contentbg_transp = ((isset($contentbg_transp) && $contentbg_transp != '') ? $contentbg_transp : 100);
 
 // Calculate some colors in dependance of existing colors.