source: trunk/includes/global.php@ 438

Last change on this file since 438 was 438, checked in by george, 15 years ago
  • Přidáno: V horní uživatelské liště zobratovat rychlé odkazy na přeložené, rozpracované a nedpřeložené.
File size: 14.0 KB
Line 
1<?php
2
3$ScriptStartTime = GetMicrotime();
4
5if(isset($_SERVER['REMOTE_ADDR'])) session_start();
6
7// SQL injection hack protection
8foreach($_POST as $Index => $Item)
9{
10 if(is_array($_POST[$Index]))
11 foreach($_POST[$Index] as $Index2 => $Item2) $_POST[$Index][$Index2] = addslashes($Item2);
12 else $_POST[$Index] = addslashes($_POST[$Index]);
13}
14foreach($_GET as $Index => $Item) $_GET[$Index] = addslashes($_GET[$Index]);
15
16include_once(dirname(__FILE__).'/config.php');
17include_once(dirname(__FILE__).'/error.php');
18include_once(dirname(__FILE__).'/databaseconection.php');
19include_once(dirname(__FILE__).'/global_function.php');
20include_once(dirname(__FILE__).'/rss.php');
21include_once(dirname(__FILE__).'/system.php');
22include_once(dirname(__FILE__).'/user.php');
23
24$Database = new Database($Config['Database']['Host'], $Config['Database']['User'], $Config['Database']['Password']);
25$Database->SQLCommand('SET NAMES '.$Config['Database']['Charset']);
26$Database->SelectDatabase($Config['Database']['Database']);
27
28$TranslationTree = GetTranslationTree();
29$LanguageList = GetLanguageList();
30
31$System = new System();
32$System->Init();
33$User = new User();
34
35function GetMicrotime()
36{
37 list($Usec, $Sec) = explode(' ', microtime());
38 return ((float)$Usec + (float)$Sec);
39}
40
41function ShowShoutbox()
42{
43 global $Database, $Config, $User, $System;
44
45 echo('<strong><a href="'.$System->Link('/action.php?action=ShoutBoxView').'">Kecátko:</a></strong>');
46 if($User->Licence(LICENCE_USER))
47 echo(' <a href="'.$System->Link('/action.php?action=shoutbox').'">Vložit</a>');
48 echo('<div class="box"><table>');
49 $ID = $Database->SQLCommand('SELECT * FROM `ShoutBox` ORDER BY `ID` DESC LIMIT 30');
50 while($Line = mysql_fetch_assoc($ID))
51 echo('<tr><td><strong>'.$Line['User'].'</strong>: '.htmlspecialchars($Line['Text']).'</td></tr>');
52 echo('</table></div>');
53}
54
55function ShowTopBar()
56{
57 global $Config, $Database, $User, $System;
58
59 echo('<div class="Menu">');
60 echo('<span class="MenuItem"></span>');
61 if($User->Licence(LICENCE_USER))
62 {
63 $DbResult = $Database->SQLCommand('SELECT `Id`, `Name` FROM `Team` WHERE `Id`='.$User->Team);
64 $Team = mysql_fetch_assoc($DbResult);
65
66 //echo('<span class="MenuItem">Moje překlady: <a href="">Dokončené</a> <a href="">Rozpracované</a> <a href="">Exporty</a> Tým: <a href="">'.$Team['name'].'</a></span>');
67 echo('<span class="MenuItem2">'.$User->Name.' <a href="'.$System->Link('/?action=logout').'">Odhlášení</a> <a href="'.$System->Link('/Options.php').'">Nastavení</a>');
68 echo(' <a title="Vámi přeložené texty" href="'.$System->Link('/TranslationList.php?user='.$User->Id.'&amp;group=0&amp;state=2&amp;text=&amp;entry=').'">Přeložené</a>');
69 echo(' <a title="Vaše rozpracované text" href="'.$System->Link('/TranslationList.php?user='.$User->Id.'&amp;group=0&amp;state=3&amp;text=&amp;entry=').'">Rozpracované</a>');
70 echo(' <a title="Nikým nepřeložené texty" href="'.$System->Link('/TranslationList.php?user=0&amp;group=0&amp;state=1&amp;text=&amp;entry=').'">Nepřeložené</a>');
71 echo('</span>');
72 } else
73 {
74 echo('<span class="MenuItem2"><form action="?action=login" method="post"> Jméno: <input type="text" name="LoginUser" size="8 " /> Heslo: <td><input type="password" name="LoginPass" size="8" /> <input type="submit" value="Přihlásit" /></form> &nbsp; <a href="'.$System->Link('/registrace.php').'">Registrace</a></span>');
75 }
76 echo('</div>');
77}
78
79function ShowLoginBox()
80{
81 global $User;
82
83 if($User->Licence(LICENCE_USER))
84 {
85 // echo 'Jste přihlášen jako: <b>'.$User->Id.'</b> <a href="index.php?Logout">Odhlásit</a>';
86 } else
87 {
88 echo('<strong>Přihlášení:</strong>
89 <form action="" method="post">
90 <table>
91 <tr>
92 <td><input type="text" name="LoginUser" size="13" /></td>
93 </tr>
94 <tr>
95 <td><input type="password" name="LoginPass" size="13" /></td>
96 </tr>
97 <tr>
98 <th><input type="submit" value="Přihlásit" /></th>
99 </tr>
100 </table>
101 </form>');
102 }
103}
104
105function ShowSearchBox()
106{
107 global $System;
108
109 echo('<strong>Hledání:</strong>'.
110 '<form action="'.$System->Link('/action.php').'" method="get"><div>'.
111 '<input type="hidden" name="action" value="search" />'.
112 '<table>'.
113 '<tr>'.
114 '<td><input type="text" name="search" size="13" /></td>'.
115 '</tr>'.
116 '<tr>'.
117 '<th><input type="submit" value="Hledat" /></th>'.
118 '</tr>'.
119 '</table></div>'.
120 '</form>');
121}
122
123function ShowMainMenu()
124{
125 global $TranslationTree, $Config, $User, $System;
126
127 $Menu = array
128 (
129 $System->Link('/') => array(LICENCE_ANONYMOUS, 'Hlavní stránka', 'Domů'),
130 'http://www.heroesoffantasy.cz/forum/viewforum.php?f=22' => array(LICENCE_ANONYMOUS, 'Diskuze na téma překládání', 'Fórum projektu'),
131 $System->Link('/dictionary.php') => array(LICENCE_ANONYMOUS, 'Slovník WoW výrazů', 'Slovníček'),
132 $System->Link('/statistic.php') => array(LICENCE_ANONYMOUS, 'Stav dokončení překládů', 'Stav dokončení'),
133 $System->Link('/userlist.php?action=nofilter') => array(LICENCE_ANONYMOUS, 'Seznam registrovaných uživatelů', 'Překladatelé'),
134 $System->Link('/team.php?search=') => array(LICENCE_ANONYMOUS, 'Seznam překladatelských týmů', 'Týmy'),
135 $System->Link('/export/') => array(LICENCE_ANONYMOUS, 'Zde si můžete stáhnout přeložené texty', 'Exporty'),
136 $System->Link('/download.php') => array(LICENCE_ANONYMOUS, 'Stahování různých pomocných souborů a programů', 'Soubory'),
137 $System->Link('/info.php') => array(LICENCE_ANONYMOUS, 'Informace k překladu hry', 'Informace'),
138 $System->Link('/TranslationList.php?action=grouplist') => array(LICENCE_ANONYMOUS, 'Informace o překladových skupinách', 'Zdroje dat'),
139 $System->Link('/banners.php') => array(LICENCE_ANONYMOUS, 'Informace k propagaci tohoto projektu', 'Propagace'),
140 $System->Link('/promotion.php') => array(LICENCE_ANONYMOUS, 'Prezentace a motivace překladu', 'Prezentace'),
141 $System->Link('/version.php') => array(LICENCE_ANONYMOUS, 'Seznam verzí herního klienta', 'Verze hry'),
142 $System->Link('/aowow/') => array(LICENCE_ANONYMOUS, 'Vyhledávací databáze podobná WoWHead s překlady', 'AoWoW'),
143 $System->Link('/server.php') => array(LICENCE_ANONYMOUS, 'Pomocný WoW server pro překladatele', 'Test server'),
144'http://embed.mibbit.com/?server=game.zdechov.net%3A6667&amp;channel=%23wowpreklad&amp;forcePrompt=true&amp;charset=utf-8' => array(LICENCE_ANONYMOUS, 'IRC chat pro překladatele', 'Chat'),
145 $System->Link('/admin.php') => array(LICENCE_ADMIN, 'Volby pro správu', 'Administrace'),
146 );
147
148 echo('<strong>Hlavní menu:</strong>'.
149 '<div class="verticalmenu"><ul>');
150 foreach($Menu as $MenuTarget => $MenuItem)
151 {
152 if(isset($MenuItem[3])) $OnClick = ' onclick="'.$MenuItem[3].'"';
153 else $OnClick = '';
154 if($User->Licence($MenuItem[0])) echo('<li><a class="verticalmenua" title="'.$MenuItem[1].'" href="'.$MenuTarget.'"'.$OnClick.'>'.$MenuItem[2].'</a></li>');
155 }
156 echo('</ul></div>');
157}
158
159function ShowTranslatedMenu()
160{
161 global $TranslationTree, $Config, $Database, $User, $System;
162
163 echo('<strong>Překladové skupiny:</strong><br /><div id="TranslationMenu">');
164 foreach($TranslationTree as $Group)
165 {
166 echo('<div id="menuitem-group'.$Group['Id'].'" onmousemove="show(\'group'.$Group['Id'].'\')" onmouseout="hide(\'group'.$Group['Id'].'\')">'.
167 '<a href="'.$System->Link('/TranslationList.php?group='.$Group['Id'].'&amp;action=filter').'">'.$Group['Name'].'</a></div>'.
168 '<div id="group'.$Group['Id'].'" class="hidden-menu-item" onmousemove="show(\'group'.$Group['Id'].'\')" onmouseout="hide(\'group'.$Group['Id'].'\')">');
169 echo('&nbsp;<a title="Zde můžete začít překládat" href="'.$System->Link('/TranslationList.php?group='.$Group['Id'].'&amp;state=1&amp;user=0&amp;entry=&amp;text=').'">Nepřeložené</a><br />'.
170 '&nbsp;<a title="Přeložené texty, můžete zde hlasovat, nebo opravovat překlady" href="'.$System->Link('/TranslationList.php?group='.$Group['Id'].'&amp;state=2&amp;user=0&amp;entry=&amp;text=').'">Přeložené</a><br />');
171 if($User->Licence(LICENCE_USER))
172 {
173 echo('&nbsp;<a title="Nedokončené překlady" href="'.$System->Link('/TranslationList.php?group='.$Group['Id'].'&amp;state=3').'">Rozepsané</a><br />
174 &nbsp;<a title="Všechny překlady, které jste přeložil" href="'.$System->Link('/TranslationList.php?group='.$Group['Id'].'&amp;state=1&amp;user='.$User->Id).'&amp;entry=&amp;text=">Vlastní</a><br />');
175 }
176 echo('&nbsp;<a title="Sestavit speciální filtr" href="'.$System->Link('/TranslationList.php?group='.$Group['Id'].'&amp;action=filter').'">Filtr</a><br />');
177 echo('</div>');
178 }
179 echo ('</div>');
180}
181
182function ShowOnlineUserList()
183{
184 global $Database, $Moderators, $User;
185
186 echo('Online překladatelé:<br />');
187 $ID = $Database->SQLCommand('SELECT `Name`, `GM`, `ID` FROM `User` WHERE `LastLogin` >= NOW() - 300 AND ((`LastLogout` < `LastLogin`) OR (ISNULL(`LastLogout`)))');
188 while($DbUser = mysql_fetch_assoc($ID))
189 {
190 if($User->Licence(LICENCE_MODERATOR)) $Name = '<a href="user.php?user='.$DbUser['ID'].'">'.$DbUser['Name'].'</a>';
191 else $Name = $DbUser['Name'];
192 $TextGM = '';
193 echo('<strong>'.$Name.'</strong>'.$TextGM.'<br />');
194 }
195}
196
197function ShowPage()
198{
199 global $User, $Config, $Database, $RSSChannels, $PageFooterRequested, $System;
200
201 echo('<?xml version="1.0" encoding="'.$Config['Web']['Charset'].'"?>
202 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
203<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="cz">'.
204'<head>'.
205'<meta http-equiv="content-type" content="application/xhtml+xml; charset='.$Config['Web']['Charset'].'" />'.
206'<meta name="keywords" content="wow, quest, questy, questů, preklad, mangos, překlad, překládání, přeložený, přeložení, čeština, world of warcraft, open source, free, addon" />'.
207'<meta name="description" content="'.$Config['Web']['Title'].'" />'.
208'<meta name="robots" content="all" />'.
209'<link rel="stylesheet" href="'.$System->Link('/style/style.css').'" type="text/css" media="all" />'.
210'<script type="text/javascript" src="'.$System->Link('/style/global.js').'"></script>'.
211'<link rel="shortcut icon" href="'.$System->Link('/images/favicon.ico').'" />');
212 if(isset($RSSChannels))
213 foreach($RSSChannels as $Channel)
214 echo(' <link rel="alternate" title="'.$Channel['Title'].'" href="'.$Channel['URL'].'" type="application/rss+xml" />');
215 echo('<title>'.$Config['Web']['Title'].'</title>
216</head>
217<body>');
218/*
219echo('<table id="bannertable"><tr>'.
220 '<td id="banner1"></td>'.
221 '<td id="banner"><div id="bannertitle">'.$Config['Web']['Title'].'</div></td>'.
222 '<td id="banner2"></td></tr>'.
223'</table>');
224*/
225
226 if(array_key_exists('action', $_GET))
227 {
228 if($_GET['action'] == 'login')
229 {
230 $User->Login($_POST['LoginUser'], $_POST['LoginPass']);
231 if($User->Role == LICENCE_ANONYMOUS) echo('<script> alert("Jméno nebo heslo bylo zadáno špatně!"); </script>');
232 } else
233 if($_GET['action'] == 'logout')
234 {
235 if($User->Role != LICENCE_ANONYMOUS)
236 {
237 $User->Logout();
238 WriteLog('Odhlášení', LOG_TYPE_USER);
239 }
240 }
241 }
242 ShowTopBar();
243
244 echo('<table class="page"><tr><td class="menu">');
245 ShowMainMenu();
246 ShowOnlineUserList();
247 echo('<br />');
248 ShowSearchBox();
249 echo('</td><td id="border-left"></td><td class="content">');
250 $PageFooterRequested = true;
251}
252
253$UnitNames = array('B', 'kB', 'MB', 'GB', 'TB', 'PB', 'EB');
254
255function HumanSize($Value)
256{
257 global $UnitNames;
258
259 $UnitIndex = 0;
260 while($Value > 1024)
261 {
262 $Value = round($Value / 1024, 3);
263 $UnitIndex++;
264 }
265 return($Value.' '.$UnitNames[$UnitIndex]);
266}
267
268function ShowFooter()
269{
270 global $Database, $Config, $ScriptStartTime, $PageFooterRequested, $User;
271
272 if(isset($PageFooterRequested))
273 {
274 $ScriptGenerateDuration = round(GetMicrotime() - $ScriptStartTime, 2);
275
276 echo('</td>');
277 echo('<td class="menu2">');
278 ShowTranslatedMenu();
279 echo('<br />');
280 ShowShoutBox();
281 echo('</td>'.
282 '</tr><tr>'.
283 '<td colspan="4" class="page-bottom">Autoři: maron, chronos &nbsp; <a href="http://wowpreklad.zdechov.net/trac/wowpreklad/browser/trunk">Zdrojové soubory</a> &nbsp; '.
284 '<a href="http://wowpreklad.zdechov.net/trac/wowpreklad/log/trunk?verbose=on">Novinky</a> &nbsp; '.
285 '<a href="http://counter.cnw.cz/"><img src="http://counter.cnw.cz/monika.cgi?wowpreklad&amp;5&amp;000000&amp;FFFFFF&amp;on" alt="CNW:Counter" /></a>
286 <script type="text/javascript">
287 <!--
288 document.write("<a href=\"http://counter.cnw.cz\" target=\"_parent\"><img src=\"http://counter.cnw.cz/trackit.cgi?wowpreklad&t3&" + escape(top.document.referrer) + "\" alt=\"CNW:Tracker\" border=\"0\" width=\"1\" height=\"1\"><\/a>");
289 // -->
290 </script>');
291
292 echo('</td></tr>');
293 if($Config['Web']['ShowRuntimeInfo'] == true) echo('<tr><td colspan="3" style="text-align: center;">Doba generování: '.$ScriptGenerateDuration.' s / '.ini_get('max_execution_time').' s &nbsp;&nbsp; Použitá paměť: '.HumanSize(memory_get_peak_usage(FALSE)).' / '.ini_get('memory_limit').'B &nbsp;&nbsp; <a href="http://validator.w3.org/check?uri='.htmlentities('http://'.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'].'?'.$_SERVER['QUERY_STRING']).'">HTML validator</a></td></tr>');
294 echo('</table>'.
295 '</body>'.
296 '</html>');
297 $Database->Disconnect();
298 $User->Store();
299 }
300}
301
302function GetQueryStringArray($QueryString)
303{
304 $Result = array();
305 $Parts = explode('&', $QueryString);
306 foreach($Parts as $Part)
307 {
308 if($Part != '')
309 {
310 if(!strpos($Part, '=')) $Part .= '=';
311 $Item = explode('=', $Part);
312 $Result[$Item[0]] = $Item[1];
313 }
314 }
315 return($Result);
316}
317
318function SetQueryStringArray($QueryStringArray)
319{
320 $Parts = array();
321 foreach($QueryStringArray as $Index => $Item)
322 {
323 $Parts[] = $Index.'='.$Item;
324 }
325 return(implode('&', $Parts));
326}
327
328?>
Note: See TracBrowser for help on using the repository browser.