141344d8e1823827d18f08f1999519c214ce5f09
[mailer.git] / inc / modules / member / what-points.php
1 <?php
2 /************************************************************************
3  * MXChange v0.2.1                                    Start: 10/19/2003 *
4  * ===============                              Last change: 11/12/2004 *
5  *                                                                      *
6  * -------------------------------------------------------------------- *
7  * File              : what-points.php                                  *
8  * -------------------------------------------------------------------- *
9  * Short description : All your collected points...                     *
10  * -------------------------------------------------------------------- *
11  * Kurzbeschreibung  : Alle Ihrer gesammelten Punkte                    *
12  * -------------------------------------------------------------------- *
13  *                                                                      *
14  * -------------------------------------------------------------------- *
15  * Copyright (c) 2003 - 2008 by Roland Haeder                           *
16  * For more information visit: http://www.mxchange.org                  *
17  *                                                                      *
18  * This program is free software; you can redistribute it and/or modify *
19  * it under the terms of the GNU General Public License as published by *
20  * the Free Software Foundation; either version 2 of the License, or    *
21  * (at your option) any later version.                                  *
22  *                                                                      *
23  * This program is distributed in the hope that it will be useful,      *
24  * but WITHOUT ANY WARRANTY; without even the implied warranty of       *
25  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the        *
26  * GNU General Public License for more details.                         *
27  *                                                                      *
28  * You should have received a copy of the GNU General Public License    *
29  * along with this program; if not, write to the Free Software          *
30  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,               *
31  * MA  02110-1301  USA                                                  *
32  ************************************************************************/
33
34 // Some security stuff...
35 if (ereg(basename(__FILE__), $_SERVER['PHP_SELF']))
36 {
37         $INC = substr(dirname(__FILE__), 0, strpos(dirname(__FILE__), "/inc") + 4) . "/security.php";
38         require($INC);
39 }
40  elseif (!IS_LOGGED_IN())
41 {
42         LOAD_URL(URL."/modules.php?module=index");
43 }
44
45 // Add description as navigation point
46 ADD_DESCR("member", basename(__FILE__));
47
48 OPEN_TABLE("100%", "member_content member_content_align", "");
49 $result_depths = SQL_QUERY("SELECT level, percents FROM "._MYSQL_PREFIX."_refdepths ORDER BY level", __FILE__, __LINE__);
50 $depths = SQL_NUMROWS($result_depths);
51
52 // Add many more rows for the login/turbo/ref/order bonus
53 if (!EXT_IS_ACTIVE("bonus")) $depths += 1;
54 if (GET_EXT_VERSION("bonus") >= "0.2.2") $depths += 6;
55 if (GET_EXT_VERSION("bonus") >= "0.4.4") $depths += 4;
56
57 // Remember row count in constant
58 define('__ROWS_VALUE', ($depths*2+15));
59
60 // Init some vars...
61 $TPTS = "0"; $TREF = "0"; $TLOCK = "0"; $OUT = "";
62
63 // Load ref levels
64 while (list($lvl, $per) = SQL_FETCHROW($result_depths))
65 {
66         // Initialize ref-count
67         $REFS = "0";
68
69         // Load referral points
70         $result_points = SQL_QUERY_ESC("SELECT points, locked_points FROM "._MYSQL_PREFIX."_user_points WHERE userid=%d AND ref_depth=%d LIMIT 1", array($GLOBALS['userid'], bigintval($lvl)), __FILE__, __LINE__);
71         if (SQL_NUMROWS($result_points) == 1)
72         {
73                 list($POINTS, $LOCKED) = SQL_FETCHROW($result_points);
74                 SQL_FREERESULT($result_points);
75                 // Also count locked points
76                 $TPTS += $POINTS; $TLOCK += $LOCKED;
77         }
78          else
79         {
80                 $POINTS = "0.00000"; $LOCKED = "0.00000";
81         }
82
83         // Load referral counts
84         $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__);
85         if (SQL_NUMROWS($result_refs) == 1)
86         {
87                 list($REFS) = SQL_FETCHROW($result_refs);
88                 SQL_FREERESULT($result_refs);
89                 $TREF += $REFS;
90         }
91          else
92         {
93                 $REFS = "0";
94         }
95
96         // Transfer data to array for template
97         $content = array(
98                 'lvl'    => $lvl,
99                 'per'    => $per,
100                 'points' => TRANSLATE_COMMA($POINTS),
101                 'refs'   => $REFS,
102         );
103
104         // Output row
105         $OUT .= LOAD_TEMPLATE("member_points_row", true, $content);
106 }
107
108 // Free memory
109 SQL_FREERESULT($result_depths);
110
111 // Put rows to constant for the main template
112 define('__REF_LEVEL_ROWS', $OUT);
113
114 $result = SQL_QUERY_ESC("SELECT used_points, ref_payout FROM "._MYSQL_PREFIX."_user_data WHERE userid=%d LIMIT 1",
115  array($GLOBALS['userid']), __FILE__, __LINE__);
116 list($USED, $PAY) = SQL_FETCHROW($result);
117 SQL_FREERESULT($result);
118
119 // Initialize variables
120 $CONFIRMED = "---"; $SENT = "---"; $RECEIVED = "---";
121
122 // Only user >= v0.1.2: Fetch confirmed mails counter
123 if (GET_EXT_VERSION("user") >= "0.1.2")
124 {
125         $ADD = "";
126         if (GET_EXT_VERSION("user") >= "0.1.4")
127         {
128                 $ADD = ", emails_sent, emails_received";
129         }
130         $result = SQL_QUERY_ESC("SELECT mails_confirmed".$ADD." FROM "._MYSQL_PREFIX."_user_data WHERE userid=%d LIMIT 1", array($GLOBALS['userid']), __FILE__, __LINE__);
131         list($CONFIRMED, $SENT, $RECEIVED) = SQL_FETCHROW($result);
132         SQL_FREERESULT($result);
133
134         // Please update the user extension if you see 3 dashes
135         if (empty($SENT))     $SENT     = "---";
136         if (empty($RECEIVED)) $RECEIVED = "---";
137 }
138  else
139 {
140         // Please update!
141         $CONFIRMED = "---";
142 }
143
144 // If TLOCK is 0 add 3 zeros for floating
145 if ($TLOCK == "0") $TLOCK = "0.00000";
146
147 // Remember several values in constants
148 define('__USED_VALUE' , TRANSLATE_COMMA($USED));
149 define('__TPTS_VALUE' , TRANSLATE_COMMA($TPTS - $USED));
150 define('__TREF_VALUE' , $TREF);
151 define('__TLOCK_VALUE', TRANSLATE_COMMA($TLOCK));
152
153 // Fixes a bug when there is no bonus extension installed
154 if (GET_EXT_VERSION("bonus") < "0.4.4") $CONFIG['bonus_active'] = "X";
155
156 // Display login bonus and turbo-click bonus
157 if ((GET_EXT_VERSION("bonus") >= "0.2.2") && (EXT_IS_ACTIVE("bonus")) && ($CONFIG['bonus_active'] == 'Y'))
158 {
159         $ADD = ", 0, 0, 0";
160         if (GET_EXT_VERSION("bonus") >= "0.4.4") $ADD = ", bonus_ref, bonus_order, bonus_stats";
161
162         // Load data
163         $result = SQL_QUERY_ESC("SELECT login_bonus, turbo_bonus".$ADD." FROM "._MYSQL_PREFIX."_user_data WHERE userid=%d LIMIT 1",
164          array($GLOBALS['userid']), __FILE__, __LINE__);
165
166         // We don't add this points now. This will be done after each month
167         list($login, $turbo, $ref, $order, $stats) = SQL_FETCHROW($result);
168         SQL_FREERESULT($result);
169
170         // Prepare constants
171         define('__TURBO_VALUE',  TRANSLATE_COMMA($turbo));
172         define('__LOGIN_VALUE',  TRANSLATE_COMMA($login));
173
174         if (GET_EXT_VERSION("bonus") >= "0.4.4")
175         {
176                 // Add referral, stats and order bonys
177                 define('__REF_VALUE'  ,  TRANSLATE_COMMA($ref));
178                 define('__ORDER_VALUE',  TRANSLATE_COMMA($order));
179                 define('__STATS_VALUE',  TRANSLATE_COMMA($stats));
180         }
181
182         // Total bonus points
183         define('__TTOTAL_VALUE', TRANSLATE_COMMA($turbo + $login + $ref + $order + $stats));
184
185         // Output rows
186         define('__SPECIAL_ROWS', LOAD_TEMPLATE("member_points_bonus_rows", true));
187 }
188  elseif ($CONFIG['bonus_active'] == 'N')
189 {
190         // Bonus active rallye deactivated
191         define('__SPECIAL_ROWS', LOAD_TEMPLATE("member_points_bonus_disabled", true));
192 }
193  elseif ((IS_ADMIN()) && (GET_EXT_VERSION("bonus") < "0.2.2") && (EXT_IS_ACTIVE("bonus")))
194 {
195         // Please upgrade your bonus extension to v0.2.2 or newer!
196         define('__SPECIAL_ROWS', LOAD_TEMPLATE("member_points_upgrade"));
197 }
198  else
199 {
200         // Members shall see no special rows here
201         define('__SPECIAL_ROWS', "");
202 }
203
204 // Remeber values for the final template
205 define('__PAY_VALUE'      , $PAY);
206 define('__CONFIRMED_VALUE', $CONFIRMED);
207 define('__RECEIVE_VALUE'  , $RECEIVED);
208 define('__SENT_VALUE'     , $SENT);
209
210 // Load final template
211 if (EXT_IS_ACTIVE("user")) {
212         // Load template when required extension is there
213         LOAD_TEMPLATE("member_points");
214 } elseif (IS_ADMIN()) {
215         // Missing extension
216         ADD_FATAL(sprintf(EXTENSION_PROBLEM_NOT_INSTALLED, "user"));
217 } else {
218         // Message for user
219         LOAD_TEMPLATE("admin_settings_saved", false, PROBLEM_POINTS_OVERVIEW_UNAVAILABLE);
220 }
221
222 if (EXT_IS_ACTIVE("payout"))
223 {
224         // Payput extension is installed and active so we can check if the user has enougth points
225         PAYOUT_OUTPUT_PAYOUT_LIST(str_replace(",", ".", ($TPTS - $USED)));
226 }
227 if (EXT_IS_ACTIVE("wernis"))
228 {
229         // Payput extension is installed and active so we can check if the user has enougth points
230         WERNIS_OUTPUT_WERNIS_LIST(str_replace(",", ".", ($TPTS - $USED)));
231 }
232 CLOSE_TABLE();
233 //
234 ?>