X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;ds=sidebyside;f=inc%2Flibs%2Ftheme_functions.php;h=9fc37f2872ce444e10442f1d655fad44b77d2416;hb=e9da1508b2a3ccbf63adc999981674740a47e074;hp=e53451b33b9bb211df4c20a7037f50cd3990aa0e;hpb=aaf81b8f35512782d34f78c1a0dac8b42d745393;p=mailer.git diff --git a/inc/libs/theme_functions.php b/inc/libs/theme_functions.php index e53451b33b..9fc37f2872 100644 --- a/inc/libs/theme_functions.php +++ b/inc/libs/theme_functions.php @@ -1,10 +1,10 @@ $theme) { - $OUT .= " '; } // END - foreach // Remember content @@ -100,8 +104,11 @@ function generateThemeSelectionBox () { 'selection' => $OUT ); + // Load template + $out = loadTemplate('theme_select_form', TRUE, $content); + // Return generated selection - return loadTemplate('theme_select_form', true, $content); + return $out; } // Get version from name @@ -116,35 +123,35 @@ function getThemeVersion ($name) { $cver = '?.?'; // Is the cache entry there? - if (isset($GLOBALS['cache_array']['themes']['theme_ver'][$name])) { + if (isset($GLOBALS['cache_array']['themes']['theme_version'][$name])) { // Get the version from cache - $cver = $GLOBALS['cache_array']['themes']['theme_ver'][$name]; + $cver = $GLOBALS['cache_array']['themes']['theme_version'][$name]; // Count up incrementStatsEntry('cache_hits'); - } elseif (getExtensionVersion('cache') != '0.1.8') { + } elseif (isExtensionInstalledAndNewer('cache', '0.1.8')) { // Load version from database - $result = SQL_QUERY_ESC("SELECT `theme_ver` FROM `{?_MYSQL_PREFIX?}_themes` WHERE `theme_path`='%s' LIMIT 1", + $result = sqlQueryEscaped("SELECT `theme_ver` FROM `{?_MYSQL_PREFIX?}_themes` WHERE `theme_path`='%s' LIMIT 1", array($name), __FUNCTION__, __LINE__); // Entry found? - if (SQL_NUMROWS($result) == 1) { + if (sqlNumRows($result) == 1) { // Fetch data - list($cver) = SQL_FETCHROW($result); + list($cver) = sqlFetchRow($result); } // END - if // Free result - SQL_FREERESULT($result); + sqlFreeResult($result); } // Return version return $cver; } -// Checks wether a theme is found in db +// Checks whether a theme is found in db function ifThemeExists ($name) { // Get theme and is it not nul? - return (getThemeId($name) > 0); + return (((isExtensionActive('theme')) || (getModule() == 'admin')) && (isValidId(getThemeId($name)))); } // Checks if a theme is active @@ -152,11 +159,11 @@ function isThemeActive ($name) { // Is the extension 'theme' installed? if (!isExtensionActive('theme')) { // Then abort here - return false; + return FALSE; } // END - if // Default is nothing active - $active = false; + $active = FALSE; // Is the cache entry there? if (isset($GLOBALS['cache_array']['themes']['theme_active'][$name])) { @@ -165,16 +172,16 @@ function isThemeActive ($name) { // Count up incrementStatsEntry('cache_hits'); - } elseif (getExtensionVersion('cache') != '0.1.8') { + } elseif (isExtensionInstalledAndNewer('cache', '0.1.8')) { // Check if current theme is already imported or not - $result = SQL_QUERY_ESC("SELECT `theme_active` FROM `{?_MYSQL_PREFIX?}_themes` WHERE `theme_path`='%s' AND `theme_active`='Y' LIMIT 1", + $result = sqlQueryEscaped("SELECT `theme_active` FROM `{?_MYSQL_PREFIX?}_themes` WHERE `theme_path`='%s' AND `theme_active`='Y' LIMIT 1", array($name), __FUNCTION__, __LINE__); // Is the theme active and installed? - $active = (SQL_NUMROWS($result) == 1); + $active = (sqlNumRows($result) == 1); // Free result - SQL_FREERESULT($result); + sqlFreeResult($result); } // Return result @@ -199,37 +206,99 @@ function getCurrentThemeName () { // Count up incrementStatsEntry('cache_hits'); - } elseif (getExtensionVersion('cache') != '0.1.8') { + } elseif (isExtensionInstalledAndNewer('cache', '0.1.8')) { // Check if current theme is already imported or not - $result = SQL_QUERY_ESC("SELECT `theme_name` FROM `{?_MYSQL_PREFIX?}_themes` WHERE `theme_path`='%s' AND `theme_active`='Y' LIMIT 1", + $result = sqlQueryEscaped("SELECT `theme_name` FROM `{?_MYSQL_PREFIX?}_themes` WHERE `theme_path`='%s' AND `theme_active`='Y' LIMIT 1", array($name), __FUNCTION__, __LINE__); // Load theme name - list($name) = SQL_FETCHROW($result); + list($name) = sqlFetchRow($result); // Free result - SQL_FREERESULT($result); + sqlFreeResult($result); } // Return name return $name; } -// @TODO Move this code block into a filter and register it with 'init' -// Check if new theme is selcted -if ((isPostRequestElementSet('new_theme')) && (postRequestElement('new_theme') != getCurrentTheme())) { - // Set new theme for guests - $newTheme = postRequestElement('new_theme'); +// Get current theme name +function getActualTheme () { + // The default theme is 'default'... ;-) + $ret = 'default'; - // Change to new theme - setTheme($newTheme); + // Load default theme if not empty from configuration + if ((isConfigEntrySet('default_theme')) && (getConfig('default_theme') != '')) { + $ret = getConfig('default_theme'); + } // END - if - // Remove current from array - removeIncludeFromPool('theme', sprintf("theme/%s/theme.php", getCurrentTheme())); + if (!isMailerThemeSet()) { + // Set default theme + setMailerTheme($ret); + } elseif ((isMailerThemeSet()) && (isExtensionInstalledAndNewer('sql_patches', '0.1.4'))) { + //die("
".print_r($GLOBALS['cache_array']['themes'], TRUE)."
"); + // Get theme from cookie + $ret = getSession('mailer_theme'); + + // Is it valid? + if ((!isExtensionActive('theme')) || (getThemeId($ret) == '0')) { + // Fix it to default + $ret = 'default'; + } // END - if + } elseif ((!isInstalled()) && ((isInstalling()) || (isHtmlOutputMode())) && ((isGetRequestElementSet('theme')) || (isPostRequestElementSet('theme')))) { + // Prepare filename for checking + $themeFile = sprintf('theme/%s/theme.php', getRequestElement('theme')); + + // Installation mode active + if ((isGetRequestElementSet('theme')) && (isThemeReadable(getRequestElement('theme')))) { + // Set cookie from URL data + setMailerTheme(getRequestElement('theme')); + } elseif ((isPostRequestElementSet('theme')) && (isThemeReadable(postRequestElement('theme')))) { + // Set cookie from posted data + setMailerTheme(postRequestElement('theme')); + } + + // Set return value + $ret = getSession('mailer_theme'); + } else { + // Invalid design, reset cookie + setMailerTheme($ret); + } - // Add new theme - addIncludeToPool('theme', sprintf("theme/%s/theme.php", $newTheme)); -} // END - if + // Return theme value + return $ret; +} + +// Get id from theme +function getThemeId ($name) { + // Default id + $id = '0'; + + // Is the cache entry there? + if (isset($GLOBALS['cache_array']['themes']['id'][$name])) { + // Get the version from cache + $id = $GLOBALS['cache_array']['themes']['id'][$name]; + + // Count up + incrementStatsEntry('cache_hits'); + } elseif (isExtensionInstalledAndNewer('cache', '0.1.8')) { + // Check if current theme is already imported or not + $result = sqlQueryEscaped("SELECT `id` FROM `{?_MYSQL_PREFIX?}_themes` WHERE `theme_path`='%s' LIMIT 1", + array($name), __FUNCTION__, __LINE__); + + // Entry found? + if (sqlNumRows($result) == 1) { + // Fetch data + list($id) = sqlFetchRow($result); + } // END - if + + // Free result + sqlFreeResult($result); + } + + // Return id + return $id; +} // [EOF] ?>