X-Git-Url: https://git.mxchange.org/?p=mailer.git;a=blobdiff_plain;f=inc%2Fmodules%2Fmember%2Fwhat-points.php;h=38065edd7bf3815c9847cfdaca24c3b4a8e0c9ef;hp=aee76fd6923991f7f1c4cb18ab6db162aa95382a;hb=3c0aa23a47aa3b10cdd296d1b0baa28708dc2080;hpb=e1653405d28923c78b2e292125306ccf61138f24 diff --git a/inc/modules/member/what-points.php b/inc/modules/member/what-points.php index aee76fd692..38065edd7b 100644 --- a/inc/modules/member/what-points.php +++ b/inc/modules/member/what-points.php @@ -1,7 +1,7 @@ = "0.2.2") $depths += 6; -if (GET_EXT_VERSION("bonus") >= "0.4.4") $depths += 4; +// @TODO Should we rewrite this to a filter? +if (!isExtensionActive('bonus')) $depths += 1; +if (isExtensionInstalledAndNewer('bonus', '0.2.2')) $depths += 6; +if (isExtensionInstalledAndNewer('bonus', '0.4.4')) $depths += 4; // Remember row count in constant -define('__ROWS_VALUE', ($depths*2+15)); +$content['rowspan'] = ($depths*2+15); // Init some vars... -$TPTS = "0"; $TREF = "0"; $TLOCK = "0"; $OUT = ""; +$totalPoints = '0'; +$totalReferals = '0'; +$totalLocked = '0'; +$OUT = ''; // Load ref levels -while (list($lvl, $per) = SQL_FETCHROW($result_depths)) -{ - // Initialize ref-count - $REFS = "0"; - - // Load referral points - $result_points = SQL_QUERY_ESC("SELECT points, locked_points FROM "._MYSQL_PREFIX."_user_points WHERE userid=%d AND ref_depth='%s' LIMIT 1", array($GLOBALS['userid'], bigintval($lvl)), __FILE__, __LINE__); - if (SQL_NUMROWS($result_points) == 1) - { - list($POINTS, $LOCKED) = SQL_FETCHROW($result_points); - SQL_FREERESULT($result_points); - // Also count locked points - $TPTS += $POINTS; $TLOCK += $LOCKED; - } - else - { - $POINTS = "0.00000"; $LOCKED = "0.00000"; - } - - // Load referral counts - $result_refs = SQL_QUERY_ESC("SELECT counter FROM "._MYSQL_PREFIX."_refsystem WHERE userid=%d AND level='%s' LIMIT 1", array($GLOBALS['userid'], bigintval($lvl)), __FILE__, __LINE__); - if (SQL_NUMROWS($result_refs) == 1) - { - list($REFS) = SQL_FETCHROW($result_refs); - SQL_FREERESULT($result_refs); - $TREF += $REFS; - } - else - { - $REFS = "0"; - } - - // Transfer data to array for template - $content = array( - 'lvl' => $lvl, - 'per' => $per, - 'points' => TRANSLATE_COMMA($POINTS), - 'refs' => $REFS, - ); +while ($data = SQL_FETCHARRAY($result_depths)) { + // Merge it together + $content = merge_array($content, $data); + + // Initialize array elements + $content['counter'] = '0'; + $content['points'] = '0.00000'; + $content['locked_points'] = '0.00000'; + + // Load referal points + $result_points = SQL_QUERY_ESC("SELECT `points`, `locked_points` FROM `{?_MYSQL_PREFIX?}_user_points` WHERE `userid`=%s AND `ref_depth`='%s' LIMIT 1", + array( + getMemberId(), + bigintval($content['level']) + ), __FILE__, __LINE__); + + // Do we have an entry? + if (SQL_NUMROWS($result_points) == 1) { + // Load data + $content = merge_array($content, SQL_FETCHARRAY($result_points)); + + // Add both points + $totalPoints += $content['points']; + $totalLocked += $content['locked_points']; + } // END - if + + // Free result + SQL_FREERESULT($result_points); + + // Load referal counts + $result_refs = SQL_QUERY_ESC("SELECT `counter` FROM `{?_MYSQL_PREFIX?}_refsystem` WHERE `userid`=%s AND `level`='%s' LIMIT 1", + array( + getMemberId(), + bigintval($content['level']) + ), __FILE__, __LINE__); + + // Do we have an entry? + if (SQL_NUMROWS($result_refs) == 1) { + // Load data + $content = merge_array($content, SQL_FETCHARRAY($result_refs)); + + // Add them to total refs + $totalReferals += $content['counter']; + } // END - if + + // Free result + SQL_FREERESULT($result_refs); // Output row - $OUT .= LOAD_TEMPLATE("member_points_row", true, $content); -} + $OUT .= loadTemplate('member_points_row', true, $content); +} // END - while // Free memory SQL_FREERESULT($result_depths); // Put rows to constant for the main template -define('__REF_LEVEL_ROWS', $OUT); - -$result = SQL_QUERY_ESC("SELECT used_points, ref_payout FROM "._MYSQL_PREFIX."_user_data WHERE userid=%d LIMIT 1", - array($GLOBALS['userid']), __FILE__, __LINE__); -list($USED, $PAY) = SQL_FETCHROW($result); -SQL_FREERESULT($result); +$content['rows'] = $OUT; // Initialize variables -$CONFIRMED = "---"; $SENT = "---"; $RECEIVED = "---"; +$CONFIRMED = '---'; +$SENT = '---'; +$RECEIVED = '---'; // Only user >= v0.1.2: Fetch confirmed mails counter -if (GET_EXT_VERSION("user") >= "0.1.2") -{ - $ADD = ""; - if (GET_EXT_VERSION("user") >= "0.1.4") - { - $ADD = ", emails_sent, emails_received"; - } - $result = SQL_QUERY_ESC("SELECT mails_confirmed".$ADD." FROM "._MYSQL_PREFIX."_user_data WHERE userid=%d LIMIT 1", array($GLOBALS['userid']), __FILE__, __LINE__); - list($CONFIRMED, $SENT, $RECEIVED) = SQL_FETCHROW($result); - SQL_FREERESULT($result); +if (isExtensionInstalledAndNewer('user', '0.1.2')) { + $add = ''; + $CONFIRMED = getUserData('mails_confirmed'); + + if (isExtensionInstalledAndNewer('user', '0.1.4')) { + $SENT = getUserData('emails_sent'); + $RECEIVED = getUserData('emails_received'); + } // END - if // Please update the user extension if you see 3 dashes - if (empty($SENT)) $SENT = "---"; - if (empty($RECEIVED)) $RECEIVED = "---"; -} - else -{ + if (empty($SENT)) $SENT = '---'; + if (empty($RECEIVED)) $RECEIVED = '---'; +} else { // Please update! - $CONFIRMED = "---"; + $CONFIRMED = '---'; } // If TLOCK is 0 add 3 zeros for floating -if ($TLOCK == "0") $TLOCK = "0.00000"; +if ($totalLocked == '0') $totalLocked = '0.00000'; // Remember several values in constants -define('__USED_VALUE' , TRANSLATE_COMMA($USED)); -define('__TPTS_VALUE' , TRANSLATE_COMMA($TPTS - $USED)); -define('__TREF_VALUE' , $TREF); -define('__TLOCK_VALUE', TRANSLATE_COMMA($TLOCK)); +$content['sum'] = ($totalPoints - getUserData('used_points')); +$content['tref'] = $totalReferals; +$content['tlock'] = $totalLocked; // Fixes a bug when there is no bonus extension installed -if (GET_EXT_VERSION("bonus") < "0.4.4") $CONFIG['bonus_active'] = "X"; +if (isExtensionInstalledAndOlder('bonus', '0.4.4')) setConfigEntry('bonus_active', 'X'); + +// Members shall see no special rows here +$content['special_rows'] = ''; // Display login bonus and turbo-click bonus -if ((GET_EXT_VERSION("bonus") >= "0.2.2") && (EXT_IS_ACTIVE("bonus")) && ($CONFIG['bonus_active'] == 'Y')) -{ - $ADD = ", 0, 0, 0"; - if (GET_EXT_VERSION("bonus") >= "0.4.4") $ADD = ", bonus_ref, bonus_order, bonus_stats"; - - // Load data - $result = SQL_QUERY_ESC("SELECT login_bonus, turbo_bonus".$ADD." FROM "._MYSQL_PREFIX."_user_data WHERE userid=%d LIMIT 1", - array($GLOBALS['userid']), __FILE__, __LINE__); - - // We don't add this points now. This will be done after each month - list($login, $turbo, $ref, $order, $stats) = SQL_FETCHROW($result); - SQL_FREERESULT($result); - - // Prepare constants - define('__TURBO_VALUE', TRANSLATE_COMMA($turbo)); - define('__LOGIN_VALUE', TRANSLATE_COMMA($login)); - - if (GET_EXT_VERSION("bonus") >= "0.4.4") - { - // Add referral, stats and order bonys - define('__REF_VALUE' , TRANSLATE_COMMA($ref)); - define('__ORDER_VALUE', TRANSLATE_COMMA($order)); - define('__STATS_VALUE', TRANSLATE_COMMA($stats)); - } +if ((isExtensionInstalledAndNewer('bonus', '0.2.2')) && (isExtensionActive('bonus')) && (getConfig('bonus_active') == 'Y')) { + // Fetch some data and init others (to avoid a notice here) + $content['login'] = getUserData('login_bonus'); + $content['turbo'] = getUserData('turbo_bonus'); + + // Get more data if ext-bonus is newer + if (isExtensionInstalledAndNewer('bonus', '0.4.4')) { + $content['ref'] = getUserData('bonus_ref'); + $content['order'] = getUserData('bonus_order'); + $content['stats'] = getUserData('bonus_stats'); + } // END - if // Total bonus points - define('__TTOTAL_VALUE', TRANSLATE_COMMA($turbo + $login + $ref + $order + $stats)); + $content['ttotal'] = $content['turbo'] + $content['login'] + $content['ref'] + $content['order'] + $content['stats']; // Output rows - define('__SPECIAL_ROWS', LOAD_TEMPLATE("member_points_bonus_rows", true)); -} - elseif ($CONFIG['bonus_active'] == 'N') -{ + $content['special_rows'] = loadTemplate('member_points_bonus_rows', true, $content); +} elseif ((isExtensionActive('bonus')) && (getConfig('bonus_active') != 'Y')) { // Bonus active rallye deactivated - define('__SPECIAL_ROWS', LOAD_TEMPLATE("member_points_bonus_disabled", true)); -} - elseif ((IS_ADMIN()) && (GET_EXT_VERSION("bonus") < "0.2.2") && (EXT_IS_ACTIVE("bonus"))) -{ + $content['special_rows'] = loadTemplate('member_points_bonus_disabled', true); +} elseif ((isAdmin()) && (isExtensionOlder('bonus', '0.2.2')) && (isExtensionActive('bonus'))) { // Please upgrade your bonus extension to v0.2.2 or newer! - define('__SPECIAL_ROWS', LOAD_TEMPLATE("member_points_upgrade")); -} - else -{ - // Members shall see no special rows here - define('__SPECIAL_ROWS', ""); + $content['special_rows'] = loadTemplate('member_points_upgrade'); } // Remeber values for the final template -define('__PAY_VALUE' , $PAY); -define('__CONFIRMED_VALUE', $CONFIRMED); -define('__RECEIVE_VALUE' , $RECEIVED); -define('__SENT_VALUE' , $SENT); +$content['receive'] = $RECEIVED; +$content['confirmed'] = $CONFIRMED; +$content['sent'] = $SENT; // Load final template -if (EXT_IS_ACTIVE("user")) { +if (isExtensionActive('user')) { // Load template when required extension is there - LOAD_TEMPLATE("member_points"); -} elseif (IS_ADMIN()) { + loadTemplate('member_points', false, $content); +} elseif (isAdmin()) { // Missing extension - ADD_FATAL(sprintf(EXTENSION_PROBLEM_NOT_INSTALLED, "user")); + loadTemplate('admin_settings_saved', false, generateExtensionInactiveNotInstalledMessage('user')); } else { // Message for user - LOAD_TEMPLATE("admin_settings_saved", false, PROBLEM_POINTS_OVERVIEW_UNAVAILABLE); + loadTemplate('admin_settings_saved', false, getMessage('PROBLEM_POINTS_OVERVIEW_UNAVAILABLE')); } -if (EXT_IS_ACTIVE("payout")) -{ +if (isExtensionActive('payout')) { // Payput extension is installed and active so we can check if the user has enougth points - PAYOUT_OUTPUT_PAYOUT_LIST(str_replace(",", ".", ($TPTS - $USED))); -} -if (EXT_IS_ACTIVE("wernis")) -{ - // Payput extension is installed and active so we can check if the user has enougth points - WERNIS_OUTPUT_WERNIS_LIST(str_replace(",", ".", ($TPTS - $USED))); -} -CLOSE_TABLE(); -// + outputPayoutList(convertCommaToDot(($totalPoints - getUserData('used_points')))); +} // END - if + +// [EOF] ?>