X-Git-Url: https://git.mxchange.org/?p=mailer.git;a=blobdiff_plain;f=inc%2Flibs%2Ftheme_functions.php;h=2fb7de3b7f8a9b8d1a36c7c8bd45c2767fed3609;hp=44363a8c7cc42d1f8ebb72afc8e975ae7d4d5f09;hb=4b32c7be676d4a191c869a5745f2890240852fb0;hpb=3f51c40f4fede87228216f9285b745a339e3891d diff --git a/inc/libs/theme_functions.php b/inc/libs/theme_functions.php index 44363a8c7c..2fb7de3b7f 100644 --- a/inc/libs/theme_functions.php +++ b/inc/libs/theme_functions.php @@ -1,10 +1,10 @@ array() // Title ); + // Only activated themes for the user + $add = " WHERE `theme_active`='Y'"; + + // Do we have admin? + if (isAdmin()) $add = ''; + + // Select all themes we want + $result = SQL_QUERY("SELECT + `theme_path`, `theme_name` +FROM + `{?_MYSQL_PREFIX?}_themes` +".$add." +ORDER BY + `theme_name` ASC", __FILE__, __LINE__); + // Load all themes while ($content = SQL_FETCHARRAY($result)) { - // Load it's theme.php file - $INC = sprintf("theme/%s/theme.php", SQL_ESCAPE($content['theme_path'])); - if (isIncludeReadable($INC)) { + // Construct relative include file name + $inc = sprintf("theme/%s/theme.php", secureString($content['theme_path'])); + + // Load it's theme.php file if found + if (isIncludeReadable($inc)) { // And save all data in array - loadInclude($INC); + loadInclude($inc); $themesArray['theme_unix'][] = $content['theme_path']; $themesArray['theme_name'][] = $GLOBALS['theme_data']['name']; } // END - if } // END - while - // Sort whole array by title - array_pk_sort($themesArray, array('theme_name')); + // Free the result + SQL_FREERESULT($result); // Construct selection form for the box template $OUT = ''; @@ -85,13 +106,13 @@ function generateThemeSelectionBox ($mod, $act, $wht, $result) { ); // Return generated selection - return LOAD_TEMPLATE('theme_select_form', true, $content); + return loadTemplate('theme_select_form', true, $content); } // Get version from name -function THEME_GET_VERSION ($name) { +function getThemeVersion ($name) { // Is the extension 'theme' installed? - if (!EXT_IS_ACTIVE('theme')) { + if (!isExtensionActive('theme')) { // Then abort here return '!.!'; } // END - if @@ -105,10 +126,10 @@ function THEME_GET_VERSION ($name) { $cver = $GLOBALS['cache_array']['themes']['theme_ver'][$name]; // Count up - incrementConfigEntry('cache_hits'); - } elseif (GET_EXT_VERSION('cache') != '0.1.8') { + incrementStatsEntry('cache_hits'); + } elseif (getExtensionVersion('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 = SQL_QUERY_ESC("SELECT `theme_ver` FROM `{?_MYSQL_PREFIX?}_themes` WHERE `theme_path`='%s' LIMIT 1", array($name), __FUNCTION__, __LINE__); // Entry found? @@ -128,13 +149,13 @@ function THEME_GET_VERSION ($name) { // Checks wether a theme is found in db function ifThemeExists ($name) { // Get theme and is it not nul? - return (getThemeId($name) > 0); + return ((isExtensionActive('theme')) && (getThemeId($name) > 0)); } // Checks if a theme is active function isThemeActive ($name) { // Is the extension 'theme' installed? - if (!EXT_IS_ACTIVE('theme')) { + if (!isExtensionActive('theme')) { // Then abort here return false; } // END - if @@ -148,10 +169,10 @@ function isThemeActive ($name) { $active = ($GLOBALS['cache_array']['themes']['theme_active'][$name] == 'Y'); // Count up - incrementConfigEntry('cache_hits'); - } elseif (GET_EXT_VERSION('cache') != '0.1.8') { + incrementStatsEntry('cache_hits'); + } elseif (getExtensionVersion('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 = SQL_QUERY_ESC("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? @@ -168,7 +189,7 @@ function isThemeActive ($name) { // Gets current human-readable theme name function getCurrentThemeName () { // Is the extension 'theme' installed? - if (!EXT_IS_ACTIVE('theme')) { + if (!isExtensionActive('theme')) { // Then abort here return 'default'; } // END - if @@ -182,10 +203,10 @@ function getCurrentThemeName () { $name = $GLOBALS['cache_array']['themes']['theme_name'][$name]; // Count up - incrementConfigEntry('cache_hits'); - } elseif (GET_EXT_VERSION('cache') != '0.1.8') { + incrementStatsEntry('cache_hits'); + } elseif (getExtensionVersion('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 = SQL_QUERY_ESC("SELECT `theme_name` FROM `{?_MYSQL_PREFIX?}_themes` WHERE `theme_path`='%s' AND `theme_active`='Y' LIMIT 1", array($name), __FUNCTION__, __LINE__); // Load theme name @@ -199,22 +220,123 @@ function getCurrentThemeName () { return $name; } -// Initialize variables -$GLOBALS['curr_theme'] = getCurrentTheme(); +// Get current theme name +function getActualTheme () { + // The default theme is 'default'... ;-) + $ret = 'default'; + + // Load default theme if not empty from configuration + if ((isConfigEntrySet('default_theme')) && (getConfig('default_theme') != '')) $ret = getConfig('default_theme'); + + if (!isSessionVariableSet('mxchange_theme')) { + // Set default theme + setTheme($ret); + } elseif ((isSessionVariableSet('mxchange_theme')) && (isExtensionInstalledAndNewer('sql_patches', '0.1.4'))) { + //die("
".print_r($GLOBALS['cache_array']['themes'], true)."
"); + // Get theme from cookie + $ret = getSession('mxchange_theme'); + + // Is it valid? + if ((!isExtensionActive('theme')) || (getThemeId($ret) == '0')) { + // Fix it to default + $ret = 'default'; + } // END - if + } elseif ((!isInstalled()) && ((isInstalling()) || (getOutputMode() == true)) && ((isGetRequestParameterSet('theme')) || (isPostRequestParameterSet('theme')))) { + // Prepare filename for checking + $themeFile = sprintf("theme/%s/theme.php", getRequestParameter('theme')); + + // Installation mode active + if ((isGetRequestParameterSet('theme')) && (isIncludeReadable($theme))) { + // Set cookie from URL data + setTheme(getRequestParameter('theme')); + } elseif (isIncludeReadable(sprintf("theme/%s/theme.php", secureString(postRequestParameter('theme'))))) { + // Set cookie from posted data + setTheme(secureString(postRequestParameter('theme'))); + } + + // Set return value + $ret = getSession('mxchange_theme'); + } else { + // Invalid design, reset cookie + setTheme($ret); + } -// Check if new theme is selcted -if ((REQUEST_ISSET_POST('new_theme')) && (REQUEST_POST('new_theme') != $GLOBALS['curr_theme'])) { - // Set new theme for guests - $newTheme = REQUEST_POST('new_theme'); + // Return theme value + return $ret; +} - // Change to new theme +// Setter for theme in session +function setTheme ($newTheme) { setSession('mxchange_theme', $newTheme); +} - // Remove current from array and set new - $theme = sprintf("%stheme/%s/theme.php", constant('PATH'), $GLOBALS['curr_theme']); - REMOVE_INC_FROM_POOL($theme); - ADD_INC_TO_POOL(sprintf("%stheme/%s/theme.php", constant('PATH'), $newTheme)); -} // END - if +// 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 = SQL_QUERY_ESC("SELECT `id` FROM `{?_MYSQL_PREFIX?}_themes` WHERE `theme_path`='%s' LIMIT 1", + array($name), __FUNCTION__, __LINE__); + + // Entry found? + if (SQL_NUMROWS($result) == 1) { + // Fetch data + list($id) = SQL_FETCHROW($result); + } // END - if + + // Free result + SQL_FREERESULT($result); + } + + // Return id + return $id; +} + +/////////////////////////////////////////////////////////////////////////////// +// Only filter functions +/////////////////////////////////////////////////////////////////////////////// + +// Filter for generic handling of theme change +function FILTER_HANDLE_THEME_CHANGE () { + // Check if new theme is selcted + if ((isPostRequestParameterSet('new_theme')) && (postRequestParameter('new_theme') != getCurrentTheme())) { + // Set new theme for guests + $newTheme = postRequestParameter('new_theme'); + + // Change to new theme + setTheme($newTheme); + + // Remove current from array + removeIncludeFromPool('theme', sprintf("theme/%s/theme.php", getCurrentTheme())); + + // Add new theme + addIncludeToPool('theme', sprintf("theme/%s/theme.php", $newTheme)); + + // Redirect to same URL + redirectToRequestUri(); + } // END - if +} + +// Filter for settings theme from user profile, must be executed only if FILTER_FETCH_USER_DATA() ran before +function FILTER_SET_USERS_THEME () { + // Is the user data valid? + if (!isMember()) { + // Do only run for logged in members + debug_report_bug('Please only run this filter for logged in users.'); + } // END - if + + // Change to new theme + setTheme(getUserData('curr_theme')); +} // [EOF] ?>