X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=inc%2Flibs%2Ftheme_functions.php;h=5fbcfb2edd6f6ef4d396a519eedb2ebbf284ed98;hb=023d240bd9154811e5ebca23892ed06fefc72c08;hp=a39bdff3a81aa7d0332a7545cec06f6a34cc06b7;hpb=56156f6c4392510cdbe0eb4f2ccefc23b43e2672;p=mailer.git diff --git a/inc/libs/theme_functions.php b/inc/libs/theme_functions.php index a39bdff3a8..5fbcfb2edd 100644 --- a/inc/libs/theme_functions.php +++ b/inc/libs/theme_functions.php @@ -1,19 +1,23 @@ array(), // Unix name from filesystem 'theme_name' => array() // Title ); + // Only activated themes for the user + $add = " WHERE `theme_active`='Y'"; + + // Is there admin? + if (isAdmin()) { + // Then display all themes + $add = ''; + } // END - if + + // Select all themes we want + $result = SQL_QUERY('SELECT + `theme_path`, + `theme_name` +FROM + `{?_MYSQL_PREFIX?}_themes` +' . $add . ' +ORDER BY + `theme_name` ASC', __FUNCTION__, __LINE__); + // Load all themes - while(list($theme) = SQL_FETCHROW($result)) { - // Load it's theme.php file - $INC = sprintf("%stheme/%s/theme.php", PATH, SQL_ESCAPE($theme)); - if (FILE_READABLE($INC)) { + while ($row = SQL_FETCHARRAY($result)) { + // Construct relative include file name + $inc = sprintf("theme/%s/theme.php", secureString($row['theme_path'])); + + // Load it's theme.php file if found + if (isIncludeReadable($inc)) { // And save all data in array - require($INC); - $THEMES['theme_unix'][] = $theme; - $THEMES['theme_name'][] = $THEME_NAME; + loadInclude($inc); + array_push($themesArray['theme_unix'], $row['theme_path']); + array_push($themesArray['theme_name'], $row['theme_name']); } // END - if } // END - while - // Sort whole array by title - array_pk_sort($THEMES, array("theme_name")); + // Free the result + SQL_FREERESULT($result); // Construct selection form for the box template - $OUT = ""; - foreach ($THEMES['theme_unix'] as $key => $theme) { - $OUT .= " \n"; + // @TODO Can't this be rewritten to an API function? + $OUT = ''; + foreach ($themesArray['theme_unix'] as $key => $theme) { + $OUT .= ' '; } // END - foreach + // Remember content + $content = array( + 'form_action' => $formAction, + 'selection' => $OUT + ); + + // Load template + $out = loadTemplate('theme_select_form', TRUE, $content); + // Return generated selection - define('__THEME_SELECTION_OPTIONS', $OUT); - $OUT = LOAD_TEMPLATE("theme_select_form", true); - return $OUT; + return $out; } // Get version from name -function THEME_GET_VERSION ($name) { - global $cacheArray; - - // Is the extension "theme" installed? - if (!EXT_IS_ACTIVE("theme")) { +function getThemeVersion ($name) { + // Is the extension 'theme' installed? + if (!isExtensionActive('theme')) { // Then abort here - return "!.!"; + return '!.!'; } // END - if - // Default version "number" - $cver = "?.?"; + // Default version 'number' + $cver = '?.?'; // Is the cache entry there? - if (isset($cacheArray['themes']['theme_ver'][$name])) { + if (isset($GLOBALS['cache_array']['themes']['theme_version'][$name])) { // Get the version from cache - $cver = $cacheArray['themes']['theme_ver'][$name]; + $cver = $GLOBALS['cache_array']['themes']['theme_version'][$name]; // Count up - incrementConfigEntry('cache_hits'); - } elseif (GET_EXT_VERSION("cache") != "0.1.8") { + incrementStatsEntry('cache_hits'); + } 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", - array($name), __FILE__, __LINE__); + $result = SQL_QUERY_ESC("SELECT `theme_ver` FROM `{?_MYSQL_PREFIX?}_themes` WHERE `theme_path`='%s' LIMIT 1", + array($name), __FUNCTION__, __LINE__); // Entry found? if (SQL_NUMROWS($result) == 1) { @@ -118,36 +151,34 @@ function THEME_GET_VERSION ($name) { return $cver; } -// Checks wether a theme is found in db -function THEME_CHECK_EXIST ($name) { +// Checks whether a theme is found in db +function ifThemeExists ($name) { // Get theme and is it not nul? - return (THEME_GET_ID($name) > 0); + return (((isExtensionActive('theme')) || (getModule() == 'admin')) && (getThemeId($name) > 0)); } // Checks if a theme is active -function THEME_IS_ACTIVE ($name) { - global $cacheArray; - - // Is the extension "theme" installed? - if (!EXT_IS_ACTIVE("theme")) { +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($cacheArray['themes']['theme_active'][$name])) { + if (isset($GLOBALS['cache_array']['themes']['theme_active'][$name])) { // Get the version from cache - $active = ($cacheArray['themes']['theme_active'][$name] == "Y"); + $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 (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", - array($name), __FILE__, __LINE__); + $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? $active = (SQL_NUMROWS($result) == 1); @@ -161,29 +192,27 @@ function THEME_IS_ACTIVE ($name) { } // Gets current human-readable theme name -function GET_CURR_THEME_NAME () { - global $cacheArray; - - // Is the extension "theme" installed? - if (!EXT_IS_ACTIVE("theme")) { +function getCurrentThemeName () { + // Is the extension 'theme' installed? + if (!isExtensionActive('theme')) { // Then abort here - return "default"; + return 'default'; } // END - if // Get the Uni* name - $name = GET_CURR_THEME(); + $name = getCurrentTheme(); // Is the cache entry there? - if (isset($cacheArray['themes']['theme_name'][$name])) { + if (isset($GLOBALS['cache_array']['themes']['theme_name'][$name])) { // Get the version from cache - $name = $cacheArray['themes']['theme_name'][$name]; + $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 (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", - array($name), __FILE__, __LINE__); + $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 list($name) = SQL_FETCHROW($result); @@ -196,22 +225,83 @@ function GET_CURR_THEME_NAME () { return $name; } -// Initialize variables -$currTheme = GET_CURR_THEME(); +// Get current theme name +function getActualTheme () { + // The default theme is 'default'... ;-) + $ret = 'default'; -// Check if new theme is selcted -if ((!empty($_POST['new_theme'])) && ($_POST['new_theme'] != $currTheme)) { - // Set new theme for guests - $newTheme = $_POST['new_theme']; + // Load default theme if not empty from configuration + if ((isConfigEntrySet('default_theme')) && (getConfig('default_theme') != '')) { + $ret = getConfig('default_theme'); + } // END - if - // Change to new theme - set_session('mxchange_theme', $newTheme); + 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')) && (isIncludeReadable($theme))) { + // Set cookie from URL data + setMailerTheme(getRequestElement('theme')); + } elseif (isIncludeReadable(sprintf("theme/%s/theme.php", postRequestElement('theme')))) { + // Set cookie from posted data + setMailerTheme(postRequestElement('theme')); + } + + // Set return value + $ret = getSession('mailer_theme'); + } else { + // Invalid design, reset cookie + setMailerTheme($ret); + } - // Remove current from array and set new - $theme = sprintf("%stheme/%s/theme.php", PATH, $currTheme); - unset($INC_POOL[array_search($theme, $INC_POOL)]); - $INC_POOL[] = sprintf("%stheme/%s/theme.php", PATH, $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 = 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; +} -// +// [EOF] ?>
".print_r($GLOBALS['cache_array']['themes'], TRUE)."