X-Git-Url: https://git.mxchange.org/?p=mailer.git;a=blobdiff_plain;f=inc%2Flibs%2Fregister_functions.php;h=efc9e4b2efd22617d60547a6505b5b68abe0accb;hp=69fc4a82ddc504fcdc4c19fd89301abc62bac59d;hb=05c5310de0991ba52c441670a315b89ee4f9db12;hpb=4001187f22197f55e5a1f211fc8defcc180f7c32 diff --git a/inc/libs/register_functions.php b/inc/libs/register_functions.php index 69fc4a82dd..efc9e4b2ef 100644 --- a/inc/libs/register_functions.php +++ b/inc/libs/register_functions.php @@ -1,7 +1,7 @@  (*)"; - // @TODO Rewrite these constants - $eval = "define('MUST_".strtoupper($content['field_name'])."', \"".$value."\");"; - eval($eval); - } // END - while - - // Free memory - SQL_FREERESULT($result); - - // Also fill other constants - define('MUST_GENDER', "
 (*)
"); - define('MUST_ADDY' , "
 (*)
"); - define('MUST_BIRTH' , "
 (*)
"); - define('MUST_MARKER', "
 (*)
"); + die(); } // -function REGISTER_CHECK_REQUIRED_FIELDS (&$array) { - $ret = false; +function ifRequiredRegisterFieldsAreSet (&$array) { + // By default all is fine + $ret = true; foreach ($array as $key => $value) { - $result = SQL_QUERY("SELECT field_required FROM `{!_MYSQL_PREFIX!}_must_register` WHERE field_name='".$key."' LIMIT 1", + // Check all fields that must register + $result = SQL_QUERY("SELECT `id` FROM `{?_MYSQL_PREFIX?}_must_register` WHERE `field_name`='".$key."' AND `field_required`='Y' LIMIT 1", __FUNCTION__, __LINE__); if (SQL_NUMROWS($result) == 1) { - // "Must-line" found - list($chk) = SQL_FETCHROW($result); - // Check if extension country is not found (you have to enter the 2-chars long country code) or // if extensions is present check if country code was selected // 01 2 21 12 3 32 234 5 54 4 43 34 4 4 5 5432 2 3 3210 - $country = ((!EXT_IS_ACTIVE("country")) || ((EXT_IS_ACTIVE("country")) && (((empty($value)) && ($key == "cntry")) || (($key == "country_code") && (!empty($value)))) && (!empty($array['country_code'])))); - if ((empty($value)) && ($chk == "Y") && (!$country)) - { + $country = ((!isExtensionActive('country')) || ((isExtensionActive('country')) && (((empty($value)) && ($key == 'cntry')) || (($key == 'country_code') && (!empty($value)))) && (!empty($array['country_code'])))); + if ((empty($value)) && ($country === false)) { // Required field not set - $array[$key] = "!"; - $ret = true; - } - } + $array[$key] = '!'; + $ret = false; + } // END - if + } // END - if // Free result SQL_FREERESULT($result); - } - return $ret; -} - -// -function REGISTER_OUTPUT_REQUIRE_CHECK (&$array) { - $result = SQL_QUERY("SELECT field_name, field_required FROM `{!_MYSQL_PREFIX!}_must_register` ORDER BY `id`", __FUNCTION__, __LINE__); - while ($content = SQL_FETCHARRAY($result)) { - if (($array[$content['field_name']] == "!") && ($content['field_required'] == "Y")) { - // Empty entry found - $array[$content['field_name']] = ""; - $OUT = constant('REGISTER_'.strtoupper($content['field_name']).'_REQUIRED'); - OUTPUT_HTML("
".$OUT."
"); - } // END - if - } // END - while + } // END - foreach - // Free memory - SQL_FREERESULT($result); + // Return result + return $ret; } -// -function REGISTER_ADD_CATEGORY_TABLE ($MODE, $return=false) { - $OUT = ""; +// Generates a 'category table' for the registration form +function registerGenerateCategoryTable ($mode, $return=false) { + $OUT = ''; // Guests are mostly not interested in how many members has // choosen an individual category $AND = "WHERE `visible`='Y' "; // Admins are allowed to see every category... - if (IS_ADMIN()) $AND = ""; + if (isAdmin()) $AND = ''; // Look for categories - $result = SQL_QUERY("SELECT id, cat, visible FROM `{!_MYSQL_PREFIX!}_cats` ".$AND." ORDER BY `sort`", + $result = SQL_QUERY("SELECT `id`, `cat`, `visible` FROM `{?_MYSQL_PREFIX?}_cats` ".$AND." ORDER BY `sort` ASC", __FUNCTION__, __LINE__); if (SQL_NUMROWS($result) > 0) { @@ -124,29 +89,24 @@ function REGISTER_ADD_CATEGORY_TABLE ($MODE, $return=false) { $SW = 2; $OUT .= "\n"; while ($content = SQL_FETCHARRAY($result)) { - // Is the array element not set? - if (!REQUEST_ISSET_POST('cat', $content['id'])) { - // Then set it - REQUEST_SET_POST(array('cat', $content['id']), ""); - } // END - if - // Prepare array for the template $content = array( 'sw' => $SW, 'cat' => $content['cat'], - 'def_y' => "", - 'def_n' => "", + 'def_y' => '', + 'def_n' => '', 'id' => $content['id'], ); - if ((REQUEST_POST('cat', $content['id']) == "Y") || ((getConfig('register_default') == "Y") && (!REQUEST_ISSET_POST('cat', $content['id'])))) { - $content['def_y'] = " checked=\"checked\""; + // Mark categories + if ((postRequestElement('cat', $content['id']) == 'Y') || ((getConfig('register_default') == 'Y') && (!isPostRequestElementSet('cat', $content['id'])))) { + $content['def_y'] = ' checked="checked"'; } else { - $content['def_n'] = " checked=\"checked\""; + $content['def_n'] = ' checked="checked"'; } // Load template and switch color - $OUT .= LOAD_TEMPLATE("guest_cat_row", true, $content); + $OUT .= loadTemplate('guest_cat_row', true, $content); $SW = 3 - $SW; } $OUT .= "
\n"; @@ -155,7 +115,7 @@ function REGISTER_ADD_CATEGORY_TABLE ($MODE, $return=false) { SQL_FREERESULT($result); } else { // No categories setted up so far... - $OUT .= LOAD_TEMPLATE("admin_settings_saved", true, getMessage('NO_CATEGORIES_VISIBLE')); + $OUT .= loadTemplate('admin_settings_saved', true, getMessage('NO_CATEGORIES_VISIBLE')); } if ($return === true) { @@ -163,8 +123,41 @@ function REGISTER_ADD_CATEGORY_TABLE ($MODE, $return=false) { return $OUT; } else { // Output directly (default) - OUTPUT_HTML($OUT); + outputHtml($OUT); + } +} + +// Outputs a 'failed message' +function registerOutputFailedMessage ($messageId, $extra='') { + if (empty($messageId)) { + outputHtml('
' . $extra . '
'); + } else { + outputHtml('
{--' . $messageId . '--}' . $extra . '
'); } } + +// Run a filter for must-fillout fields +function FILTER_REGISTER_MUST_FILLOUT ($content) { + // Get all fields for output + $result = SQL_QUERY("SELECT `field_name`, `field_required` FROM `{?_MYSQL_PREFIX?}_must_register` ORDER BY `id` ASC", + __FUNCTION__, __LINE__); + + // Walk through all entries + while ($row = SQL_FETCHARRAY($result)) { + // Must the user fill out this element? + $value = ''; + if ($row['field_required'] == 'Y') $value = " (*)"; + + // Add it + $content['must_fillout_'.strtolower($row['field_name']).''] = $value; + } // END - while + + // Free memory + SQL_FREERESULT($result); + + // Return it + return $content; +} + // ?>