2016-03-28 16:29:05 +02:00
|
|
|
<?php
|
2018-01-15 03:22:39 +01:00
|
|
|
/**
|
|
|
|
* @file view/theme/frio/style.php
|
|
|
|
*/
|
2019-02-18 14:21:13 +01:00
|
|
|
|
2017-10-23 20:26:31 +02:00
|
|
|
use Friendica\Core\Config;
|
2017-10-23 15:16:23 +02:00
|
|
|
use Friendica\Core\PConfig;
|
2019-04-01 03:50:00 +02:00
|
|
|
use Friendica\Util\Strings;
|
2016-03-28 16:29:05 +02:00
|
|
|
|
2018-01-15 03:22:39 +01:00
|
|
|
require_once 'view/theme/frio/php/PHPColors/Color.php';
|
|
|
|
|
2019-04-01 03:50:00 +02:00
|
|
|
$scheme = '';
|
2018-04-25 02:12:43 +02:00
|
|
|
$schemecss = '';
|
2017-10-23 15:16:23 +02:00
|
|
|
$schemecssfile = false;
|
|
|
|
$scheme_modified = 0;
|
|
|
|
|
2018-01-01 21:05:09 +01:00
|
|
|
if ($a->module !== 'install') {
|
2017-10-23 15:16:23 +02:00
|
|
|
// Get the UID of the profile owner.
|
2019-01-12 08:21:12 +01:00
|
|
|
$uid = defaults($_REQUEST, 'puid', 0);
|
2017-10-23 15:16:23 +02:00
|
|
|
if ($uid) {
|
|
|
|
PConfig::load($uid, 'frio');
|
|
|
|
|
|
|
|
// Load the profile owners pconfig.
|
2018-04-26 10:22:04 +02:00
|
|
|
$scheme = PConfig::get($uid, 'frio', 'scheme', PConfig::get($uid, 'frio', 'schema'));
|
2018-04-25 02:12:43 +02:00
|
|
|
$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');
|
2018-04-25 02:37:04 +02:00
|
|
|
$background_color = PConfig::get($uid, 'frio', 'background_color');
|
2018-04-25 02:12:43 +02:00
|
|
|
$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');
|
2017-10-23 15:16:23 +02:00
|
|
|
|
|
|
|
// 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());
|
|
|
|
}
|
2019-07-14 10:34:42 +02:00
|
|
|
} 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());
|
|
|
|
}
|
2016-03-28 16:29:05 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Now load the scheme. If a value is changed above, we'll keep the settings
|
2018-04-25 02:26:14 +02:00
|
|
|
// If not, we'll keep those defined by the scheme
|
|
|
|
// Setting $scheme to '' wasn't working for some reason, so we'll check it's
|
2016-03-28 16:29:05 +02:00
|
|
|
// not --- like the mobile theme does instead.
|
2018-04-25 02:26:14 +02:00
|
|
|
// Allow layouts to over-ride the scheme.
|
2018-11-30 15:06:22 +01:00
|
|
|
if (!empty($_REQUEST['scheme'])) {
|
2018-04-25 02:26:14 +02:00
|
|
|
$scheme = $_REQUEST['scheme'];
|
2016-03-28 16:29:05 +02:00
|
|
|
}
|
2017-10-23 22:14:35 +02:00
|
|
|
|
2019-04-01 03:50:00 +02:00
|
|
|
$scheme = Strings::sanitizeFilePathItem($scheme);
|
2017-10-23 22:14:35 +02:00
|
|
|
|
2018-04-25 02:26:14 +02:00
|
|
|
if (($scheme) && ($scheme != '---')) {
|
|
|
|
if (file_exists('view/theme/frio/scheme/' . $scheme . '.php')) {
|
|
|
|
$schemefile = 'view/theme/frio/scheme/' . $scheme . '.php';
|
2017-10-23 15:16:23 +02:00
|
|
|
require_once $schemefile;
|
2016-03-28 16:29:05 +02:00
|
|
|
}
|
2018-04-25 02:26:14 +02:00
|
|
|
if (file_exists('view/theme/frio/scheme/' . $scheme . '.css')) {
|
|
|
|
$schemecssfile = 'view/theme/frio/scheme/' . $scheme . '.css';
|
2016-03-28 16:29:05 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-04-25 02:26:14 +02:00
|
|
|
// If we haven't got a scheme, load the default. We shouldn't touch this - we
|
2016-03-28 16:29:05 +02:00
|
|
|
// should leave it for admins to define for themselves.
|
2018-04-25 02:26:14 +02:00
|
|
|
// default.php and default.css MUST be symlinks to existing scheme files.
|
|
|
|
if (!$scheme) {
|
|
|
|
if (file_exists('view/theme/frio/scheme/default.php')) {
|
|
|
|
$schemefile = 'view/theme/frio/scheme/default.php';
|
2017-10-23 15:16:23 +02:00
|
|
|
require_once $schemefile;
|
2016-03-28 16:29:05 +02:00
|
|
|
}
|
2018-04-25 02:26:14 +02:00
|
|
|
if (file_exists('view/theme/frio/scheme/default.css')) {
|
|
|
|
$schemecssfile = 'view/theme/frio/scheme/default.css';
|
2016-03-28 16:29:05 +02:00
|
|
|
}
|
|
|
|
}
|
2019-07-14 10:34:42 +02:00
|
|
|
//If no scheme was set default to login theme.
|
|
|
|
$nav_bg = (empty($nav_bg) ? Config::get('frio', 'nav_bg') : $nav_bg);
|
|
|
|
$nav_icon_color = (empty($nav_icon_color) ? Config::get('frio', 'nav_icon_color') : $nav_icon_color);
|
|
|
|
$link_color = (empty($link_color) ? Config::get('frio', 'link_color') : $link_color);
|
|
|
|
$background_color = (empty($background_color) ? Config::get('frio', 'background_color') : $background_color);
|
|
|
|
$background_image = (empty($background_image) ? Config::get('frio', 'background_image') : $background_image);
|
|
|
|
|
|
|
|
//If login theme unset default to master default
|
|
|
|
//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.png' : $background_image);
|
|
|
|
$modified = (empty($modified) ? time() : $modified);
|
|
|
|
|
2018-01-17 16:33:27 +01:00
|
|
|
|
|
|
|
// 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)) {
|
2018-04-25 02:05:20 +02:00
|
|
|
$login_bg_image = 'img/login_bg.jpg';
|
2018-01-17 16:33:27 +01:00
|
|
|
}
|
2018-04-25 02:12:43 +02:00
|
|
|
$login_bg_color = (empty($login_bg_color) ? '#ededed' : $login_bg_color);
|
2018-08-02 07:21:01 +02:00
|
|
|
$login_bg_image = (empty($login_bg_image) ? '' : $login_bg_image);
|
2018-01-17 16:33:27 +01:00
|
|
|
|
2018-04-25 02:12:43 +02:00
|
|
|
$contentbg_transp = ((isset($contentbg_transp) && $contentbg_transp != '') ? $contentbg_transp : 100);
|
2017-10-23 15:16:23 +02:00
|
|
|
|
|
|
|
// Calculate some colors in dependance of existing colors.
|
2016-03-28 16:29:05 +02:00
|
|
|
// Some colors are calculated to don't have too many selection
|
2017-10-23 15:16:23 +02:00
|
|
|
// fields in the theme settings.
|
2018-01-01 21:05:09 +01:00
|
|
|
if (!isset($menu_background_hover_color)) {
|
2016-03-28 16:29:05 +02:00
|
|
|
$mbhc = new Color($nav_bg);
|
|
|
|
$mcolor = $mbhc->getHex();
|
|
|
|
|
2017-10-23 15:16:23 +02:00
|
|
|
if ($mbhc->isLight($mcolor, 75)) {
|
2016-03-28 16:29:05 +02:00
|
|
|
$menu_is = 'light';
|
|
|
|
$menu_background_hover_color = '#' . $mbhc->darken(5);
|
|
|
|
} else {
|
|
|
|
$menu_is = 'dark';
|
|
|
|
$menu_background_hover_color = '#' . $mbhc->lighten(5);
|
|
|
|
}
|
|
|
|
}
|
2018-01-01 21:05:09 +01:00
|
|
|
if (!isset($nav_icon_hover_color)) {
|
2016-03-28 16:29:05 +02:00
|
|
|
$nihc = new Color($nav_bg);
|
|
|
|
|
2017-10-23 15:16:23 +02:00
|
|
|
if ($nihc->isLight()) {
|
2016-03-28 16:29:05 +02:00
|
|
|
$nav_icon_hover_color = '#' . $nihc->darken(10);
|
2017-10-23 15:16:23 +02:00
|
|
|
} else {
|
2016-03-28 16:29:05 +02:00
|
|
|
$nav_icon_hover_color = '#' . $nihc->lighten(10);
|
2017-10-23 15:16:23 +02:00
|
|
|
}
|
2016-03-28 16:29:05 +02:00
|
|
|
}
|
2018-01-01 21:05:09 +01:00
|
|
|
if (!isset($link_hover_color)) {
|
2016-03-28 16:29:05 +02:00
|
|
|
$lhc = new Color($link_color);
|
|
|
|
$lcolor = $lhc->getHex();
|
|
|
|
|
2017-10-23 15:16:23 +02:00
|
|
|
if ($lhc->isLight($lcolor, 75)) {
|
2016-03-28 16:29:05 +02:00
|
|
|
$link_hover_color = '#' . $lhc->darken(5);
|
|
|
|
} else {
|
|
|
|
$link_hover_color = '#' . $lhc->lighten(5);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-10-23 15:16:23 +02:00
|
|
|
// Convert $bg_image_options into css.
|
2018-01-01 21:05:09 +01:00
|
|
|
if (!isset($bg_image_option)) {
|
|
|
|
$bg_image_option = null;
|
|
|
|
}
|
2018-04-25 02:42:23 +02:00
|
|
|
|
2016-03-28 16:29:05 +02:00
|
|
|
switch ($bg_image_option) {
|
2018-04-25 02:12:43 +02:00
|
|
|
case 'stretch':
|
|
|
|
$background_size_img = '100%';
|
2018-04-25 02:42:23 +02:00
|
|
|
$background_repeat = 'no-repeat';
|
2016-03-28 16:29:05 +02:00
|
|
|
break;
|
2018-04-25 02:12:43 +02:00
|
|
|
case 'cover':
|
|
|
|
$background_size_img = 'cover';
|
2018-04-25 02:42:23 +02:00
|
|
|
$background_repeat = 'no-repeat';
|
2016-03-28 16:29:05 +02:00
|
|
|
break;
|
2018-04-25 02:12:43 +02:00
|
|
|
case 'repeat':
|
|
|
|
$background_size_img = 'auto';
|
2018-04-25 02:42:23 +02:00
|
|
|
$background_repeat = 'repeat';
|
2016-03-28 16:29:05 +02:00
|
|
|
break;
|
2018-04-25 02:12:43 +02:00
|
|
|
case 'contain':
|
|
|
|
$background_size_img = 'contain';
|
2018-04-25 02:42:23 +02:00
|
|
|
$background_repeat = 'repeat';
|
2016-03-28 16:29:05 +02:00
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
2018-04-25 02:12:43 +02:00
|
|
|
$background_size_img = 'auto';
|
2018-04-25 02:42:23 +02:00
|
|
|
$background_repeat = 'no-repeat';
|
2016-03-28 16:29:05 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2017-10-23 15:16:23 +02:00
|
|
|
// Convert transparency level from percentage to opacity value.
|
2016-03-28 16:29:05 +02:00
|
|
|
$contentbg_transp = $contentbg_transp / 100;
|
|
|
|
|
2018-04-25 02:05:20 +02:00
|
|
|
$options = [
|
2017-10-23 15:16:23 +02:00
|
|
|
'$nav_bg' => $nav_bg,
|
|
|
|
'$nav_icon_color' => $nav_icon_color,
|
|
|
|
'$nav_icon_hover_color' => $nav_icon_hover_color,
|
|
|
|
'$link_color' => $link_color,
|
|
|
|
'$link_hover_color' => $link_hover_color,
|
|
|
|
'$menu_background_hover_color' => $menu_background_hover_color,
|
|
|
|
'$btn_primary_color' => $nav_icon_color,
|
|
|
|
'$btn_primary_hover_color' => $menu_background_hover_color,
|
2018-04-25 02:37:04 +02:00
|
|
|
'$background_color' => $background_color,
|
2017-10-23 15:16:23 +02:00
|
|
|
'$contentbg_transp' => $contentbg_transp,
|
|
|
|
'$background_image' => $background_image,
|
|
|
|
'$background_size_img' => $background_size_img,
|
2018-04-25 02:42:23 +02:00
|
|
|
'$background_repeat' => $background_repeat,
|
2018-01-14 21:53:37 +01:00
|
|
|
'$login_bg_image' => $login_bg_image,
|
2018-01-17 16:33:27 +01:00
|
|
|
'$login_bg_color' => $login_bg_color
|
2018-01-15 14:05:12 +01:00
|
|
|
];
|
2017-10-23 15:16:23 +02:00
|
|
|
|
|
|
|
$css_tpl = file_get_contents('view/theme/frio/css/style.css');
|
|
|
|
|
|
|
|
// Get the content of the scheme css file and the time of the last file change.
|
|
|
|
if ($schemecssfile) {
|
|
|
|
$css_tpl .= file_get_contents($schemecssfile);
|
|
|
|
$scheme_modified = filemtime($schemecssfile);
|
|
|
|
}
|
2016-03-28 16:29:05 +02:00
|
|
|
|
2017-10-23 15:16:23 +02:00
|
|
|
// We need to check which is the most recent css data.
|
|
|
|
// We will use this time later to decide if we load the cached or fresh css data.
|
|
|
|
if ($scheme_modified > $modified) {
|
|
|
|
$modified = $scheme_modified;
|
2016-03-28 16:29:05 +02:00
|
|
|
}
|
2017-10-23 15:16:23 +02:00
|
|
|
// Apply the settings to the css template.
|
|
|
|
$css = str_replace(array_keys($options), array_values($options), $css_tpl);
|
2016-03-28 16:29:05 +02:00
|
|
|
|
2017-10-23 15:16:23 +02:00
|
|
|
$modified = gmdate('r', $modified);
|
|
|
|
|
|
|
|
$etag = md5($css);
|
|
|
|
|
|
|
|
// Set a header for caching.
|
|
|
|
header('Cache-Control: public');
|
2018-04-25 02:05:20 +02:00
|
|
|
header('ETag: "' . $etag . '"');
|
|
|
|
header('Last-Modified: ' . $modified);
|
2017-10-23 15:16:23 +02:00
|
|
|
|
|
|
|
// Only send the CSS file if it was changed.
|
2018-08-14 21:37:44 +02:00
|
|
|
/// @todo Check if this works at all (possibly clients are sending only the one or the other header) - compare with mod/photo.php
|
|
|
|
if (isset($_SERVER['HTTP_IF_MODIFIED_SINCE']) && isset($_SERVER['HTTP_IF_NONE_MATCH'])) {
|
2017-10-23 15:16:23 +02:00
|
|
|
$cached_modified = gmdate('r', strtotime($_SERVER['HTTP_IF_MODIFIED_SINCE']));
|
2018-04-25 02:12:43 +02:00
|
|
|
$cached_etag = str_replace(['"', '-gzip'], ['', ''],
|
2017-10-23 15:16:23 +02:00
|
|
|
stripslashes($_SERVER['HTTP_IF_NONE_MATCH']));
|
|
|
|
|
|
|
|
if (($cached_modified == $modified) && ($cached_etag == $etag)) {
|
|
|
|
header('HTTP/1.1 304 Not Modified');
|
|
|
|
exit();
|
|
|
|
}
|
2016-03-28 16:29:05 +02:00
|
|
|
}
|
2017-10-23 15:16:23 +02:00
|
|
|
|
|
|
|
echo $css;
|