X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=inc%2Fmodules%2Fadmin%2Fwhat-config_points.php;h=b50f23eb2c40ce206061e3b55e4fbbf1b3325b57;hb=5e7d3d73ba4bbf6221739746e250406ad5f80736;hp=8307ed99a081e2d0f9d72bcc1bc36d7f740787ff;hpb=143e78d4231adddd9e706cbf55ec5dd8c1651890;p=mailer.git
diff --git a/inc/modules/admin/what-config_points.php b/inc/modules/admin/what-config_points.php
index 8307ed99a0..b50f23eb2c 100644
--- a/inc/modules/admin/what-config_points.php
+++ b/inc/modules/admin/what-config_points.php
@@ -1,7 +1,7 @@
$value) {
- // Secure ID
- $id = bigintval($id);
-
- // Update entry
- $result = SQL_QUERY_ESC("UPDATE "._MYSQL_PREFIX."_refdepths SET level='%s', percents='%s' WHERE id=%s LIMIT 1",
- array(bigintval($value), $_POST['perc'][$id], $id), __FILE__, __LINE__);
- }
- $TEXT = REF_DEPTHS_SAVED;
+ case 'ref':
+ switch (getRequestElement('do')) {
+ case 'add':
+ addSql("INSERT INTO `{?_MYSQL_PREFIX?}_refdepths` (`level`, `percents`) VALUES ('".bigintval(postRequestElement('level'))."','".bigintval(postRequestElement('percents'))."')");
+ break;
+
+ case 'edit': // Change entries
+ foreach (postRequestElement('level') as $id => $value) {
+ // Secure id
+ $id = bigintval($id);
+
+ // Revert german commata
+ setPostRequestElement('percents', array($id => convertCommaToDot(postRequestElement('percents', $id))));
+
+ // Update entry
+ SQL_QUERY_ESC("UPDATE `{?_MYSQL_PREFIX?}_refdepths` SET `level`=%s,`percents`=%s WHERE `id`=%s LIMIT 1",
+ array(bigintval($value), convertCommaToDot(postRequestElement('percents', $id)), $id), __FILE__, __LINE__);
+ } // END - foreach
+ $message = '{--ADMIN_REFERRAL_DEPTHS_SAVED--}';
+ break;
+
+ case 'delete':
+ foreach (postRequestElement('id') as $id => $value) {
+ SQL_QUERY_ESC("DELETE LOW_PRIORITY FROM `{?_MYSQL_PREFIX?}_refdepths` WHERE `id`=%s LIMIT 1",
+ array(bigintval($id)), __FILE__, __LINE__);
+ } // END - foreach
+ $message = '{--ADMIN_REFERRAL_DEPTHS_DELETED--}';
+ break;
+ } // END - switch
+
+ // Update cache file
+ rebuildCache('refdepths', 'refdepths');
break;
- case "del":
- foreach ($_POST['id'] as $id => $value) {
- $result = SQL_QUERY_ESC("DELETE LOW_PRIORITY FROM "._MYSQL_PREFIX."_refdepths WHERE id=%s LIMIT 1",
- array(bigintval($id)), __FILE__, __LINE__);
+ case 'settings':
+ $REF = bigintval(postRequestElement('ref_payout'));
+ updateConfiguration(
+ array('allow_direct_pay', 'ref_payout'),
+ array(postRequestElement('allow_direct_pay'), $REF)
+ );
+ if ((getRefPayout() == '0') && (postRequestElement('ref_payout') > 0)) {
+ // Update account's ref_payout for "must-confirm"
+ addSql(sprintf("UPDATE
+ `{?_MYSQL_PREFIX?}_user_data`
+SET
+ `ref_payout`=(%s - `mails_confirmed`)
+WHERE
+ `mails_confirmed` < %s", $REF, $REF));
+ } elseif ((getRefPayout() > 0) && (postRequestElement('ref_payout') == '0')) {
+ // Update account's ref_payout for "not-must-confirm"
+ addSql("UPDATE `{?_MYSQL_PREFIX?}_user_data` SET `ref_payout`=0 WHERE `ref_payout` > 0");
+ // @TODO Rewrite these two lines for new user_points columns (e.g. locked_order_points) with a filter
+ addSql("UPDATE `{?_MYSQL_PREFIX?}_user_points` SET `points`=`points`+`locked_points` WHERE `locked_points` > 0");
+ addSql("UPDATE `{?_MYSQL_PREFIX?}_user_points` SET `locked_points`=0 WHERE `locked_points` > 0");
}
- $TEXT = REF_DEPTHS_DELETED;
break;
- }
+ } // END - switch
- // Update cache file
- if (GET_EXT_VERSION("cache") >= "0.1.2") {
- if ($cacheInstance->cache_file("refdepths", true)) $cacheInstance->cache_destroy();
- }
- break;
+ // Is there an array?
+ if ((getRequestElement('sub') != 'points') && (isSqlsValid())) {
+ // Default is failed-message
+ $message = '{--SETTINGS_NOT_SAVED--}';
- case "settings":
- $REF = bigintval($_POST['ref_payout']);
- $SQL[] = sprintf("UPDATE "._MYSQL_PREFIX."_config SET
-allow_direct_pay='%s',
-reg_points_mode='%s',
-ref_payout='%s'
-WHERE config=0 LIMIT 1",
- $_POST['allow_direct_pay'],
- $_POST['reg_points_mode'],
- $REF
- );
- if (($_CONFIG['ref_payout'] == 0) && ($_POST['ref_payout'] > 0))
- {
- // Update account's ref_payout for "must-confirm"
- $SQL[] = sprintf("UPDATE "._MYSQL_PREFIX."_user_data SET ref_payout=(%s - mails_confirmed)
-WHERE mails_confirmed < %s", $REF, $REF);
- }
- elseif (($_CONFIG['ref_payout'] > 0) && ($_POST['ref_payout'] == 0))
- {
- // Update account's ref_payout for "not-must-confirm"
- $SQL[] = "UPDATE "._MYSQL_PREFIX."_user_data SET ref_payout=0 WHERE ref_payout > 0";
- $SQL[] = "UPDATE "._MYSQL_PREFIX."_user_points SET points=points+locked_points WHERE locked_points>0";
- $SQL[] = "UPDATE "._MYSQL_PREFIX."_user_points SET locked_points=0 WHERE locked_points>0";
- }
- break;
- }
- if ((isset($SQL)) && (is_array($SQL)) && (!empty($SQL[0])))
- {
- if (strpos($SQL[0], "INSERT") > -1)
- {
- $result = SQL_QUERY_ESC("SELECT id FROM "._MYSQL_PREFIX."_refdepths WHERE level='%s' LIMIT 1",
- array(bigintval($_POST['lvl'])), __FILE__, __LINE__);
- SQL_FREERESULT($result);
- }
- if (count($SQL) > 0)
- {
+ if (countSqls() > 0) {
// Run all SQL commands
- foreach ($SQL as $s)
- {
- $result = SQL_QUERY($s, __FILE__, __LINE__);
- }
+ runFilterChain('run_sqls');
- $content = "".SETTINGS_SAVED."";
+ // Entry saved...
+ $message = '{--SETTINGS_SAVED--}';
// Destroy config cache file here...
- REBUILD_CACHE("config", "config");
- }
- else
- {
- $content = "".SETTINGS_NOT_SAVED."";
- }
- unset($SQL);
- LOAD_TEMPLATE("admin_settings_saved", false, $content);
- }
- elseif (isset($TEXT))
- {
- LOAD_TEMPLATE("admin_settings_saved", false, $TEXT);
- }
-}
- elseif ($_GET['sub'] == "settings")
-{
+ rebuildCache('config', 'config');
+ } // END - if
+
+ // Remove SQL queries
+ unsetSqls();
+ } // END - if
+
+ // Shall we display a message?
+ if (!empty($message)) {
+ // When do so...
+ displayMessage($message);
+ } // END - if
+} elseif (getRequestElement('sub') == 'settings') {
// Setup some settings like direct pay and so on
// Including new add-mode for one-time referral bonus
- switch ($_CONFIG['allow_direct_pay'])
- {
- case 'Y':
- define('__DIRECT_Y', " checked");
- define('__DIRECT_N', "");
- break;
-
- case 'N':
- define('__DIRECT_Y', "");
- define('__DIRECT_N', " checked");
- break;
- }
-
- // One-time referral bonus add-mode
- switch ($_CONFIG['reg_points_mode'])
- {
- case "ref" : define('__MODE_REF', " checked"); define('__MODE_DIRECT', ""); break;
- case "direct": define('__MODE_REF', ""); define('__MODE_DIRECT', " checked"); break;
- }
-
- // Referral payout value
- define('__REF_PAYOUT', round($_CONFIG['ref_payout']));
+ foreach (array('allow_direct_pay') as $entry) {
+ $content[$entry . '_y'] = '';
+ $content[$entry . '_n'] = '';
+ $content[$entry . '_' . strtolower(getConfig($entry))] = ' checked="checked"';
+ } // END - foreach
// Load template
- LOAD_TEMPLATE("admin_config_point_settings");
-}
- elseif ($_GET['sub'] == "ref")
-{
- if ((isset($_POST['del'])) && ((SELECTION_COUNT($_POST['sel']) > 0) || (isset($_POST['sel'][0]))))
- {
+ loadTemplate('admin_config_point_settings', FALSE, $content);
+} elseif (getRequestElement('sub') == 'ref') {
+ // 12 3 32 2 3321
+ if ((isFormSent('delete')) && (ifPostContainsSelections())) {
// Delete entries
- $SW = 2; $OUT = "";
- foreach ($_POST['sel'] as $id => $value)
- {
- $result = SQL_QUERY_ESC("SELECT level, percents FROM "._MYSQL_PREFIX."_refdepths WHERE id=%s LIMIT 1",
- array(bigintval($id)), __FILE__, __LINE__);
- list($lvl, $perc) = SQL_FETCHROW($result);
+ $OUT = '';
+ foreach (postRequestElement('sel') as $id => $value) {
+ $result = SQL_QUERY_ESC("SELECT `id`, `level`, `percents` FROM `{?_MYSQL_PREFIX?}_refdepths` WHERE `id`=%s LIMIT 1",
+ array(bigintval($id)), __FILE__, __LINE__);
+ $content = SQL_FETCHARRAY($result);
SQL_FREERESULT($result);
- // Prepare data for the row template
- $content = array(
- 'sw' => $SW,
- 'id' => $id,
- 'lvl' => $lvl,
- 'per' => $perc,
- );
-
// Load row template and switch color
- $OUT .= LOAD_TEMPLATE("admin_points_del_row", true, $content);
- $SW = 3 - $SW;
- }
- define('__LEVEL_ROWS', $OUT);
+ $OUT .= loadTemplate('admin_delete_reflevel_row', TRUE, $content);
+ } // END - foreach
// Load main template
- LOAD_TEMPLATE("admin_points_del");
- }
- elseif ((isset($_POST['edit'])) && ((SELECTION_COUNT($_POST['sel']) > 0) || (isset($_POST['sel'][0]))))
- {
+ loadTemplate('admin_delete_reflevel', FALSE, $OUT);
+ } elseif ((isFormSent('edit')) && (ifPostContainsSelections())) {
// Edit entries
- $SW = 2; $OUT = "";
- foreach ($_POST['sel'] as $id => $value)
- {
- $result = SQL_QUERY_ESC("SELECT level, percents FROM "._MYSQL_PREFIX."_refdepths WHERE id=%s LIMIT 1",
- array(bigintval($id)), __FILE__, __LINE__);
- list($lvl, $perc) = SQL_FETCHROW($result);
+ $OUT = '';
+ foreach (postRequestElement('sel') as $id => $value) {
+ $result = SQL_QUERY_ESC("SELECT `id`, `level`, `percents` FROM `{?_MYSQL_PREFIX?}_refdepths` WHERE `id`=%s LIMIT 1",
+ array(bigintval($id)), __FILE__, __LINE__);
+ $content = SQL_FETCHARRAY($result);
SQL_FREERESULT($result);
- // Prepare data for the row template
- $content = array(
- 'sw' => $SW,
- 'id' => $id,
- 'lvl' => $lvl,
- 'per' => $perc,
- );
-
// Load row template and switch color
- $OUT .= LOAD_TEMPLATE("admin_points_edit_row", true, $content);
- $SW = 3 - $SW;
- }
- define('__LEVEL_ROWS', $OUT);
+ $OUT .= loadTemplate('admin_edit_reflevel_row', TRUE, $content);
+ } // END - foreach
// Load main template
- LOAD_TEMPLATE("admin_points_edit");
- }
- else
- {
+ loadTemplate('admin_edit_reflevel', FALSE, $OUT);
+ } else {
// Referral levels
- $result = SQL_QUERY("SELECT id, level, percents FROM "._MYSQL_PREFIX."_refdepths ORDER BY level", __FILE__, __LINE__);
- if (SQL_NUMROWS($result) > 0)
- {
+ $result = SQL_QUERY("SELECT `id`, `level`, `percents` FROM `{?_MYSQL_PREFIX?}_refdepths` ORDER BY `level` ASC", __FILE__, __LINE__);
+ if (!SQL_HASZERONUMS($result)) {
// Make referral levels editable and deletable
- $SW = 2; $OUT = "";
+ $OUT = '';
// List already existing categories for editing
- while (list($id, $lvl, $perc) = SQL_FETCHROW($result))
- {
- // Prepare data for the row template
- $content = array(
- 'sw' => $SW,
- 'id' => $id,
- 'lvl' => $lvl,
- 'per' => $perc,
- );
-
+ while ($content = SQL_FETCHARRAY($result)) {
// Load row template and switch color
- $OUT .= LOAD_TEMPLATE("admin_points_row", true, $content);
- $SW = 3 - $SW;
- }
+ $OUT .= loadTemplate('admin_list_reflevel_row', TRUE, $content);
+ } // END - while
// Free memory
SQL_FREERESULT($result);
- define('__LEVEL_ROWS', $OUT);
// Load main template
- LOAD_TEMPLATE("admin_points");
+ loadTemplate('admin_list_reflevel', FALSE, $OUT);
}
// Form for adding new referral levels
- LOAD_TEMPLATE("admin_add_reflvl");
+ loadTemplate('admin_add_reflevel');
}
-}
- elseif ($_GET['sub'] == "points")
-{
- // First points for registration and other fixed points including new add-mode for one-time referral bonus...
- define('P_REG_VALUE', $_CONFIG['points_register']);
- define('P_REF_VALUE', $_CONFIG['points_ref']);
-
- // Load templates
- LOAD_TEMPLATE("admin_config_sub_points");
-}
- else
-{
+} elseif (getRequestElement('sub') == 'points') {
+ // Load template
+ loadTemplate('admin_config_sub_points');
+} else {
// Display selection box
- LOAD_TEMPLATE("admin_config_points");
+ loadTemplate('admin_config_points');
}
-//
+// [EOF]
?>