Changeset 290 for trunk


Ignore:
Timestamp:
Dec 27, 2009, 1:08:48 PM (15 years ago)
Author:
george
Message:
  • Upraveno: Kompletně přepracováno rozhraní pro export textů. Nyní systém přímo uchovává exporty překladatelů a nespoléhává se na serializovaný řetězec nastavení exportu. Nově lze své exporty vytvářet, upravovat a mazat. Exporty své či ostatních lze prohlížet a stahovat. Nově lze u exportů lépe vybrat překladatelé, jazyky, překladové skupiny, formáty a verze.
  • Upraveno: Přidána třída Module a System pro podporu předávání parametrů objektům. Nově bude používána třída mysqli namísto třídy Database používající starý procedurální přístup.
  • Upraveno: Do hlavního menu přidán opět odkaz Exporty, který umožní přístup k seznamu dostupných exportů.
  • Přidáno: Funkce pro jednoduché zobrazování a ovládání záložek.
  • Upraveno: Propagační bannery byly z hlavní stránky přesunuty do sekce Propagace.
Location:
trunk
Files:
11 edited

Legend:

Unmodified
Added
Removed
  • trunk/banners.php

    r188 r290  
    44
    55ShowPage();
     6
     7$Banner = '<a href="'.$Config['Web']['BaseURL'].'"><img src="'.$Config['Web']['BaseURL'].'banners/baner_468_60.jpg" '.
     8  'alt="baner_'.$Config['Web']['BaseURL'].'" title="Otevřený projekt překládání celé hry World of Warcraft" '.
     9  'class="banner" height="60" width="468" /></a>';
     10 
     11$BannerSmall = '<a href="'.$Config['Web']['BaseURL'].'"><img src="'.$Config['Web']['BaseURL'].'banners/baner_88_31.jpg" '.
     12  'alt="baner_'.$Config['Web']['BaseURL'].'" title="Otevřený projekt překládání celé hry World of Warcraft" '.
     13  'class="banner" height="31" width="88" /></a>';
     14
     15echo('<strong>Bannery:</strong><br />');
     16 
     17echo($Banner.' &nbsp;&nbsp;<textarea rows="2" cols="30">'.htmlspecialchars($Banner).'</textarea><br />');
     18echo($BannerSmall.' &nbsp;&nbsp;<textarea rows="2" cols="30">'.htmlspecialchars($BannerSmall).'</textarea><br />');
    619 
    720$ID = $Database->SQLCommand('SELECT * FROM `banner` WHERE `Show`=1 AND `DateLast` > (NOW() - INTERVAL 3 MONTH)');
    821 
    9 echo('<strong>Servery odkazující na nás:</strong> <br />
     22echo('<br/><strong>Servery odkazující na nás:</strong> <br />
    1023<div style="font-size: 10px;">Seznam je automaticky aktualizován a zobrazeny jsou servery s aktivní bannerem mladším než tři měsíce.</div><br />');
    1124while($Line = mysql_fetch_assoc($ID))
    1225{
    13   echo('<a href="'.$Line['LastURL'].'">'.$Line['Web'].'</a> '.$Line['Description'].' <br />');         
     26  echo('<a href="'.$Line['LastURL'].'">'.$Line['Web'].'</a> '.$Line['Description'].' <br />');   
    1427}
    1528 
  • trunk/download.php

    r282 r290  
    7171} else
    7272{
    73   echo('<br /><h3><a href="export/">Export textů</a> - Export podle vlastního výběru do SQL, XML, LUA nebo Addonu</h3>'.
    74     '<br />Exportovat podle zálohovaného nastavení:<form action="export" method="get"><div>'.
    75     '<input name="action" value="output" type="hidden" />'.
    76     '<textarea name="ExportSetting" rows="10" cols="40"></textarea>'.
    77     '<input type="submit" value="Exportovat" /></div></form><br /><br />');
    7873
    79 if (Licence(LICENCE_USER))
     74if(Licence(LICENCE_USER))
    8075
    8176  $ID = $Database->SQLCommand('SELECT * FROM tasks WHERE User = '.$_SESSION['UserID'].' ORDER BY Date DESC LIMIT 10');
  • trunk/export/cmd.php

    r265 r290  
    11<?php
    22
    3 ini_set("memory_limit","100M");
     3ini_set('memory_limit', '100M');
    44
    55if(!isset($_SERVER['REMOTE_ADDR']))
     
    1010    {
    1111      $index = substr($parameter,0,strpos($parameter, '='));
    12           $parameter = substr($parameter,strpos($parameter, '=')+1);
    13           //echo ($index.'  ----  '.$parameter);
     12    $parameter = substr($parameter,strpos($parameter, '=')+1);
     13    //echo ($index.'  ----  '.$parameter);
    1414      $_GET[$index] = $parameter;
    1515    }
    16   }     
     16  } 
    1717}
    1818
     
    2929  foreach($FileList as $FileName)
    3030  {
    31         if(file_exists($Path.$FileName) and ($FileName != '.') and ($FileName != '..'))
    32           {
     31    if(file_exists($Path.$FileName) and ($FileName != '.') and ($FileName != '..'))
     32    {
    3333      //echo($Path.$FileName.'<br />');
    34             if(is_dir($Path.$FileName)) CreateZipFromDir($Zip, $Path.$FileName.'/', $ZipPath.$FileName.'/');
    35         else $Zip->addFile(file_get_contents($Path.$FileName), $ZipPath.$FileName);     
    36           }         
     34      if(is_dir($Path.$FileName)) CreateZipFromDir($Zip, $Path.$FileName.'/', $ZipPath.$FileName.'/');
     35        else $Zip->addFile(file_get_contents($Path.$FileName), $ZipPath.$FileName); 
     36    }         
    3737  }
    3838}
     
    4444    {
    4545      $ExportSetting = unserialize($Line['ExportSetting']);
    46           $_SESSION['User'] = $Line['UserName'];
    47           $_SESSION['UserID'] = $Line['User'];         
     46    $_SESSION['User'] = $Line['UserName'];
     47    $_SESSION['UserID'] = $Line['User'];   
    4848
    4949        if(function_exists('gzcompress'))
    5050        {
    5151          $TempDir = $Config['Web']['TempFolder'].$_SESSION['User'].'/dbc/';
    52               echo('Generování dbc souborů.. ');
     52        echo('Generování dbc souborů.. ');
    5353          ExportToDBC($ExportSetting);
    5454          $SaveFilename = $Config['Web']['TempFolder'].$_SESSION['User'].'/CzWoW_DBC.zip';         
    5555          $Zip = new zipfile();
    56           CreateZipFromDir($Zip, $TempDir, 'DBFilesClient/');
    57               $Buffer = $Zip->file();
     56        CreateZipFromDir($Zip, $TempDir, 'DBFilesClient/');
     57          $Buffer = $Zip->file();
    5858          file_put_contents($SaveFilename, $Buffer);
    59                   echo('Hotovo');
     59        echo('Hotovo');
    6060        } else echo('Funkce pro tvorbu Zip souboru není podporována!');
    6161    }
     
    6464
    6565
    66 //      WriteLog('Generování dbc úloh', 2);
     66//  WriteLog('Generování dbc úloh', 2);
    6767?>
  • trunk/export/export.php

    r264 r290  
    11<?php
    22
    3 function ExportToMangosSQL($Setting)
     3include_once('../includes/system.php');
     4
     5class Export extends Module
    46{
    5   global $Database, $Config, $TranslationTree, $LanguageList;
    6  
    7   $AnoNe = array('Ne', 'Ano');
    8   if($_SESSION['UserID'] != '')
    9   {
    10     $DbResult = $Database->SQLCommand('SELECT user FROM `user` WHERE ID='.$_SESSION['UserID']);
    11     $User = mysql_fetch_assoc($DbResult);
    12   } else $User = array('user' => 'Neznámý');
    13 
    14   $WhereLang = '';
    15   foreach($LanguageList as $Language)
    16     if($Language['Enabled'] == 1)
    17       if(isset($Setting['language'.$Language['Id']]))  $WhereLang .= ' OR (Language = '.$Language['Id'].')';
    18   if($WhereLang == '') $WhereLang = 1;
    19     else $WhereLang = '('.substr($WhereLang, 4).')';
    20 
    21   $SelectedUsers = ''; 
    22   foreach($Setting['users-selection'] as $Item)
    23     $SelectedUsers .= ','.$Item;
    24   $SelectedUsers = substr($SelectedUsers, 1);
    25 
    26   if($SelectedUsers == '') $Where = 0;
    27     else $Where = 'ID IN ('.$SelectedUsers.')';
    28  
    29   $UserNames = '';
    30   $DbResult = $Database->SQLCommand('SELECT user FROM `user` WHERE '.$Where);
    31   while($DbRow = mysql_fetch_assoc($DbResult))
    32     $UserNames .= ','.$DbRow['user'];
    33   $UserNames = substr($UserNames, 1);   
     7  var $Id;
     8  var $AnoNe = array('Ne', 'Ano');
     9  var $WhereLang;
     10  var $WhereUsers;
     11  var $SelectedUsers;
     12  var $UserNames;
     13  var $User;
     14  var $ClientVersion;
     15 
     16  function LoadFilters()
     17  { 
     18    $DbResult = $this->Database->query('SELECT * FROM `Export` WHERE Id='.$this->Id);
     19    $this->Export = $DbResult->fetch_assoc();
     20
     21    // Filter selected languages
     22    $this->WhereLang = '';
     23    $DbResult = $this->Database->query('SELECT * FROM `ExportLanguage` WHERE Export='.$this->Id.' ORDER BY Sequence');
     24    while($Language = $DbResult->fetch_assoc())
     25      $this->WhereLang .= ' OR (Language = '.$Language['Language'].')';
     26    if($this->WhereLang == '') $WhereLang = 1;
     27      else $this->WhereLang = '('.substr($this->WhereLang, 4).')';
     28
     29    // Filter selected users
     30    $this->SelectedUsers = ''; 
     31    $DbResult = $this->Database->query('SELECT * FROM `ExportUser` WHERE Export='.$this->Id.' ORDER BY Sequence');
     32    while($User = $DbResult->fetch_assoc())
     33      $this->SelectedUsers .= ','.$User['User'];
     34    $this->SelectedUsers = substr($this->SelectedUsers, 1);
     35
     36    if($this->SelectedUsers == '') $Where = 0;
     37      else $Where = 'ID IN ('.$this->SelectedUsers.')';
     38 
     39    $this->UserNames = '';
     40    $DbResult = $this->Database->query('SELECT user FROM `user` WHERE '.$Where);
     41    while($DbRow = $DbResult->fetch_assoc())
     42      $this->UserNames .= ','.$DbRow['user'];
     43    $this->UserNames = substr($this->UserNames, 1);   
    3444   
    35   if($SelectedUsers == '') $WhereUsers = 1;
    36     else $WhereUsers = '(User IN ('.$SelectedUsers.'))';
    37 
    38   $Buffer =
    39   "-- Generováno projektem wowpreklad.zdechov.net\n".
    40   "-- ===========================================\n".
    41   "--\n".
    42   "-- Web projektu: ".$Config['Web']['BaseURL']."\n".
    43   "-- Datum exportu: ".date("j.n.Y  H:i:s")."\n".
    44   "-- Znaková sada: ".$Config['Database']['Charset']." / ".$Config['Web']['Charset']."\n".
    45   "-- Diakritika: ".$AnoNe[$Setting['Diacritics']]."\n".
    46   "-- Vygeneroval uživatel: ".$User['user']."\n".
    47   "-- Vzato od uživatelů: ".$UserNames."\n".
    48   "-- Generované tabulky: ";
    49   foreach($TranslationTree as $Group)
    50     if($Group['MangosTable'] != '')
    51       if(in_array($Group['Id'], $Setting['groups']))
    52         $Buffer .= $Group['MangosTable'].', ';
    53   $Buffer .= "\n\n"; 
    54 
    55   foreach($TranslationTree as $Group)
    56   if(in_array($Group['Id'], $Setting['groups']))
    57   {
    58         if($Group['MangosTable'] != '')
    59         {
    60       $Query = 'SELECT * FROM (SELECT * FROM '.$Group['TablePrefix'].' WHERE (Complete = 1) AND VersionStart <= '.GetBuildNumber($Setting['Version']).' AND VersionEnd >= '.GetBuildNumber($Setting['Version']).' AND '.$WhereLang.' AND '.$WhereUsers.' ORDER BY FIELD(User, '.$SelectedUsers.')) AS T GROUP BY T.entry';     
     45    if($this->SelectedUsers == '') $WhereUsers = 1;
     46      else $this->WhereUsers = '(User IN ('.$this->SelectedUsers.'))';
     47
     48    if($_SESSION['UserID'] != '')
     49    {
     50      $DbResult = $this->Database->query('SELECT user FROM `user` WHERE ID='.$_SESSION['UserID']);
     51      $this->User = $DbResult->fetch_assoc();
     52    } else $this->User = array('user' => 'Neznámý');
     53
     54    $DbResult = $this->Database->query('SELECT `BuildNumber` FROM `wow_client_version` WHERE `Id`='.$this->Export['ClientVersion']);
     55    $DbRow = $DbResult->fetch_assoc();
     56    $this->ClientVersion = $DbRow['BuildNumber'];
     57  }
     58
     59  function ExportToMangosSQL()
     60  {
     61    global $TranslationTree, $LanguageList;
     62 
     63    $this->LoadFilters();
     64   
     65    $Buffer =
     66      "-- Generováno projektem wowpreklad.zdechov.net\n".
     67      "-- ===========================================\n".
     68      "--\n".
     69      "-- Web projektu: ".$this->Config['Web']['BaseURL']."\n".
     70      "-- Datum exportu: ".date("j.n.Y  H:i:s")."\n".
     71      "-- Znaková sada: ".$this->Config['Database']['Charset']." / ".$this->Config['Web']['Charset']."\n".
     72      "-- Diakritika: ".$this->AnoNe[$this->Export['WithDiacritic']]."\n".
     73      "-- Vygeneroval uživatel: ".$this->User['user']."\n".
     74      "-- Vzato od uživatelů: ".$this->UserNames."\n".
     75      "-- Generované tabulky: ";
     76   
     77    $DbResult = $this->Database->query('SELECT `group`.* FROM `ExportGroup` JOIN `group` ON `group`.`Id` = `ExportGroup`.`Group` WHERE `ExportGroup`.`Export`='.$this->Id);
     78    while($Group = $DbResult->fetch_assoc())
     79    {
     80       $Buffer .= $Group['MangosTable'].', ';
     81    }
     82    $Buffer .= "\n\n"; 
     83
     84    $DbResult = $this->Database->query('SELECT `group`.* FROM `ExportGroup` JOIN `group` ON `group`.`Id` = `ExportGroup`.`Group` WHERE `ExportGroup`.`Export`='.$this->Id);
     85    while($Group = $DbResult->fetch_assoc())
     86    {
     87      if($Group['MangosTable'] != '')
     88      {
     89        $Query = 'SELECT * FROM (SELECT * FROM '.$Group['TablePrefix'].' WHERE (Complete = 1) AND VersionStart <= '.$this->ClientVersion.' AND VersionEnd >= '.$this->ClientVersion.' AND '.$this->WhereLang.' AND '.$this->WhereUsers.' ORDER BY FIELD(User, '.$this->SelectedUsers.')) AS T GROUP BY T.entry'; 
     90        //echo($Query);
     91        $Buffer .= "\n\n-- ".$Group['Name']."\n\n";
     92        $DbResult2 = $this->Database->query($Query);
     93        while($Line = $DbResult2->fetch_array())
     94        {
     95          $Values = '';
     96          foreach($TranslationTree[$Group['Id']]['Items'] as $GroupItem)
     97          {
     98            if($GroupItem['MangosColumn'] == '') $GroupItem['MangosColumn'] = $GroupItem['Column'];
     99            $Values .= ', `'.$GroupItem['MangosColumn'].'`="'.addslashes($Line[$GroupItem['Column']]).'"';
     100          }
     101          $Values = substr($Values, 2);
     102          $Buffer .= 'UPDATE `'.$Group['MangosTable'].'` SET '.$Values.' WHERE `'.$Group['MangosTableIndex'].'` = '.$Line['entry'].';'."\n";
     103        }     
     104      }
     105    }
     106    if($this->Export['WithDiacritic'] != 1) $Buffer = utf2ascii($Buffer);
     107    return($Buffer);
     108  }
     109 
     110  function ExportToAoWoWSQL()
     111  {
     112    global $Config, $TranslationTree, $AoWoWconf, $LanguageList;
     113 
     114    require_once('../aowow/configs/config.php');
     115 
     116    $Buffer = $this->ExportToMangosSQL();
     117 
     118    $this->LoadFilters();
     119
     120    // Data to aowow
     121
     122    $Database2 = new mysqli($this->Config['Database']['Host'], $this->Config['Database']['User'], $this->Config['Database']['Password'], $this->Config['Database']['Database']);
     123    $Database2->query('SET NAMES '.$this->Config['Database']['Charset']);
     124    $Database2->select_db($AoWoWconf['mangos']['db']);   
     125    $AoWoWTables = array('aowow_resistances' => 'Id', 'aowow_spelldispeltype' => 'Id', 'aowow_skill' => 'skillID');
     126    foreach($AoWoWTables as $AoWoWTable => $IndexColum)
     127    {
     128      $Buffer .= '--'.$AoWoWTable.', ';
     129      $Buffer .= "\n\n"; 
     130      $Query = 'SELECT name,'.$IndexColum.' FROM '.$AoWoWTable;
     131      $DbResult = $Database2->query($Query);
     132      while($Line = $DbResult->fetch_assoc())
     133      {
     134        $Ori_text = $Line['name'];
     135        $DbResult2 = $Datbase2->query('SELECT text as en,
     136        (SELECT text FROM '.$Config['Database']['Database'].'.global_strings as tabletran
     137         WHERE tableen.entry = tabletran.entry AND (Complete = 1) AND '.$WhereLang.'
     138          AND '.$WhereUsers.' ORDER BY FIELD(User, '.$SelectedUsers.') LIMIT 1) as tran
     139         FROM '.$Config['Database']['Database'].'.global_strings as tableen WHERE
     140          text = "'.addslashes($Ori_text).'" LIMIT 1');
     141        $Tran = $DbResult2->fetch_assoc();
     142        //echo ($Line['name'].'='.$Tran['tran']);
     143        if($Tran['tran'] == '')
     144        {
     145          $DbResult2 = $Database2->query('SELECT OptionText as en,
     146          (SELECT OptionText FROM '.$this->Config['Database']['Database'].'.npc_option as tabletran
     147           WHERE tableen.entry = tabletran.entry AND (Complete = 1) AND '.$this->WhereLang.'
     148            AND '.$this->WhereUsers.' ORDER BY FIELD(User, '.$this->SelectedUsers.') LIMIT 1) as tran
     149          FROM '.$this->Config['Database']['Database'].'.npc_option as tableen WHERE
     150            OptionText = "'.addslashes($Ori_text).'" LIMIT 1');
     151          $Tran = $DbResult2->fetch_assoc();
     152        }
     153       
     154        if($Tran['tran'] <> '')
     155          $Buffer .= 'UPDATE `'.$AoWoWTable.'` SET name = "'.addslashes($Tran['tran']).'" WHERE '.$IndexColum.' = '.$Line[$IndexColum].' ;'."\n";
     156      }
     157      $Buffer .= "\n\n"; 
     158    }
     159    if($this->Export['WithDiacritic'] != 1) $Buffer = utf2ascii($Buffer);
     160    return($Buffer);
     161  } 
     162 
     163 
     164  function ExportToXML()
     165  {
     166    global $TranslationTree, $LanguageList;
     167 
     168    $this->LoadFilters($this->Id);
     169
     170    $Buffer = '<?xml version="1.0" encoding="utf-8"?>'."\n".
     171    "<document>\n".
     172    "  <meta>\n".
     173    "    <projecturl>".$this->Config['Web']['BaseURL']."</projecturl>\n".
     174    "    <time>".date('r')."</time>\n".
     175    "    <diacritics mode=".'"'.$this->Export['WithDiacritic'].'"'." />\n".
     176    "    <author>".$this->User['user']."</author>\n".
     177    "    <contributors>\n";
     178    foreach(explode(',', $this->UserNames) as $UserName)
     179      $Buffer .= "      <user>".$UserName."</user>\n";
     180    $Buffer .=
     181    "    </contributors>\n".
     182    "  </meta>\n".
     183    "  <translation>\n";
     184
     185    $DbResult = $this->Database->query('SELECT `group`.* FROM `ExportGroup` JOIN `group` ON `group`.`Id` = `ExportGroup`.`Group` WHERE `ExportGroup`.`Export`='.$this->Id);
     186    while($Group = $DbResult->fetch_assoc())
     187    {
     188      if($Group['MangosTable'] == '')
     189      {
     190        $Group['MangosTable'] = $Group['TablePrefix'];
     191        $Group['MangosTableIndex'] = 'entry';
     192      }
     193      $Query = 'SELECT *,(SELECT user FROM user WHERE user.ID=T.User) as UserName FROM (SELECT * FROM '.$Group['TablePrefix'].' WHERE (Complete = 1) AND VersionStart <= '.$this->ClientVersion.' AND VersionEnd >= '.$this->ClientVersion.' AND '.$this->WhereLang.' AND '.$this->WhereUsers.' ORDER BY FIELD(User, '.$this->SelectedUsers.')) AS T GROUP BY T.entry';
    61194      //echo($Query);
    62       $Buffer .= "\n\n-- ".$Group['Name']."\n\n";
    63       $ID = $Database->SQLCommand($Query);
    64       while($Line = mysql_fetch_array($ID))
    65       {
    66             $Values = '';
    67             foreach($Group['Items'] as $GroupItem)
    68             {
    69               if($GroupItem['MangosColumn'] == '') $GroupItem['MangosColumn'] = $GroupItem['Column'];
    70               $Values .= ', `'.$GroupItem['MangosColumn'].'`="'.addslashes($Line[$GroupItem['Column']]).'"';
    71             }
    72         $Values = substr($Values, 2);
    73         $Buffer .= 'UPDATE `'.$Group['MangosTable'].'` SET '.$Values.' WHERE `'.$Group['MangosTableIndex'].'` = '.$Line['entry'].';'."\n";
    74       }
    75     }   
     195      $Buffer .= '    <group id="'.$Group['Id'].'" name="'.$Group['TablePrefix'].'">'."\n";
     196      $DbResult2 = $this->Database->query($Query);
     197      while($Line = $DbResult2->fetch_assoc())
     198      {
     199        $Buffer .= '      <item id="'.$Line['entry'].'" user="'.$Line['UserName'].'">'."\n";
     200        $Values = '';
     201        foreach($TranslationTree[$Group['Id']]['Items'] as $GroupItem)
     202        {
     203          if($GroupItem['MangosColumn'] == '') $GroupItem['MangosColumn'] = $GroupItem['Column'];
     204          if($Line[$GroupItem['Column']] != '')
     205          $Buffer .= '        <text index="'.$GroupItem['Id'].'" name="'.$GroupItem['Column'].'">'.addslashes($Line[$GroupItem['Column']]).'</text>'."\n";
     206        }
     207        $Buffer .= "      </item>\n";
     208      }   
     209      $Buffer .= "    </group>\n";
     210    }
     211    if($this->Export['WithDiacritic'] != 1) $Buffer = utf2ascii($Buffer);
     212    $Buffer .= "  </translation>\n".
     213  "</document>";
     214    return($Buffer);
     215  }     
     216
     217  function ExportToDBC()
     218  {
     219    global $TranslationTree, $LanguageList;
     220 
     221    $this->LoadFilters();
     222
     223    $TempDir = $this->Config['Web']['TempFolder'].$_SESSION['User'].'/dbc/';
     224    if(!file_exists($TempDir)) mkdir($TempDir, 0777, true);
     225
     226 
     227    foreach($TranslationTree as $Group)
     228    if(in_array($Group['Id'], $Setting['groups']) and ($Group['DBCFileName'] != ''))
     229    {
     230      echo($Group['Name'].'... ');
     231      $DBCFile = new DBCFile();
     232      $DBCFile->OpenFile('../source/'.$Setting['Version'].'/dbc/'.$Group['DBCFileName'].'.dbc', GetDBCColumns($Setting['Version'],$Group['DBCFileName']));
     233      $DBCFile2 = new DBCFile();
     234      $DBCFile2->CreateFile($TempDir.$Group['DBCFileName'].'.dbc', GetDBCColumns($Setting['Version'],$Group['DBCFileName']));
     235      $Count = $DBCFile->GetRecordCount();
     236      //if($Group['DBCFileName'] == 'Spell') $Count = 1000;
     237      $Line = $DBCFile->GetLine(0);
     238      $DBCFile2->SetRecordCount($Count);   
     239      for($I = 0; $I < $Count; $I++)
     240      {
     241        $Line = $DBCFile->GetLine($I);
     242        $Query = 'SELECT * FROM (SELECT * FROM '.$Group['TablePrefix'].' WHERE (Complete = 1) AND '.$WhereLang.' AND '.$WhereUsers.' AND (entry='.$Line[0].')  AND VersionStart <= '.GetBuildNumber($Setting['Version']).' AND VersionEnd >= '.GetBuildNumber($Setting['Version']).' ORDER BY FIELD(User, '.$SelectedUsers.')) AS T GROUP BY T.entry';       
     243        $DbResult = $this->Database->query($Query);
     244        if($DbResult->num_rows > 0)
     245        {
     246          $DbRow = $DbResult->fetch_assoc();
     247          //  if($Setting['Diacritics'] != 1) $Buffer = utf2ascii($Buffer);
     248
     249          foreach($Group['Items'] as $GroupItem)
     250            if(GetDBCColumnIndex($Setting['Version'],$Group['DBCFileName'],$GroupItem['Column']) != '')
     251          $Line[GetDBCColumnIndex($this->Export['ClientVersion'],$Group['DBCFileName'],$GroupItem['Column'])] = $DbRow[$GroupItem['Column']];
     252          //print_r($Line);
     253        }
     254        $DBCFile2->SetLine($I, $Line);
     255        echo('.');
     256      }
     257      $DBCFile2->Commit();
     258      echo('Hotovo <br />');
     259    }
    76260  }
    77   if($Setting['Diacritics'] != 1) $Buffer = utf2ascii($Buffer);
    78   return($Buffer);
    79 }
    80  
    81 function ExportToAoWoWSQL($Setting)
    82 {
    83   global $Database, $Config, $TranslationTree, $AoWoWconf, $LanguageList;
    84  
    85         require_once('../aowow/configs/config.php');
    86        
    87   $Buffer = ExportToMangosSQL($Setting);
     261
     262  function ExportToLua()
     263  {
     264    global $TranslationTree, $LanguageList;
     265 
     266    $this->LoadFilters();
     267
     268    $TempDir = $this->Config['Web']['TempFolder'].$_SESSION['User'].'/lua/';
     269    if(!file_exists($TempDir)) mkdir($TempDir, 0777, true);
     270 
     271    $DbResult = $this->Database->query('SELECT `group`.* FROM `ExportGroup` JOIN `group` ON `group`.`Id` = `ExportGroup`.`Group` WHERE `ExportGroup`.`Export`='.$this->Id.' AND `group`.`LuaFileName` != ""');
     272    while($Group = $DbResult->fetch_assoc())
     273    {
     274      echo($Group['Name'].'... ');
     275      $File = new FileStream();
     276      $File->OpenFile('../source/'.$this->ClientVersion.'/lua/'.$Group['LuaFileName'].'.lua');
     277      $File2 = new FileStream();
     278      $File2->CreateFile($TempDir.''.$Group['LuaFileName'].'.lua');
    88279 
    89   $AnoNe = array('Ne', 'Ano');
    90   if($_SESSION['UserID'] != '')
    91   {
    92     $DbResult = $Database->SQLCommand('SELECT user FROM `user` WHERE ID='.$_SESSION['UserID']);
    93     $User = mysql_fetch_assoc($DbResult);
    94   } else $User = array('user' => 'Neznámý');
    95 
    96   $WhereLang = '';
    97   foreach($LanguageList as $Language)
    98     if($Language['Enabled'] == 1)
    99       if(isset($Setting['language'.$Language['Id']]))  $WhereLang .= ' OR (Language = '.$Language['Id'].')';
    100   if($WhereLang == '') $WhereLang = 1;
    101     else $WhereLang = '('.substr($WhereLang, 4).')';
    102 
    103   $SelectedUsers = ''; 
    104   foreach($Setting['users-selection'] as $Item)
    105     $SelectedUsers .= ','.$Item;
    106   $SelectedUsers = substr($SelectedUsers, 1);
    107 
    108   if($SelectedUsers == '') $Where = 0;
    109     else $Where = 'ID IN ('.$SelectedUsers.')';
    110  
    111   $UserNames = '';
    112   $DbResult = $Database->SQLCommand('SELECT user FROM `user` WHERE '.$Where);
    113   while($DbRow = mysql_fetch_assoc($DbResult))
    114     $UserNames .= ','.$DbRow['user'];
    115   $UserNames = substr($UserNames, 1);   
    116    
    117   if($SelectedUsers == '') $WhereUsers = 1;
    118     else $WhereUsers = '(User IN ('.$SelectedUsers.'))';
    119 
    120         // Data to aowow
    121 
    122         $Database->SelectDatabase($AoWoWconf['mangos']['db']);   
    123         $Database->SQLCommand('SET NAMES '.$Config['Database']['Charset']);
    124   $AoWoWTables = array('aowow_resistances' => 'Id', 'aowow_spelldispeltype' => 'Id', 'aowow_skill' => 'skillID');
    125         foreach($AoWoWTables as $AoWoWTable => $IndexColum)
    126   {
    127         $Buffer .= '--'.$AoWoWTable.', ';
    128     $Buffer .= "\n\n"; 
    129           $Query = 'SELECT name,'.$IndexColum.' FROM '.$AoWoWTable;
    130     $ID = $Database->SQLCommand($Query);
    131                 while($Line = mysql_fetch_assoc($ID))
    132     {
    133                         $Ori_text = $Line['name'];
    134                 $Tran = mysql_fetch_assoc($Database->SQLCommand('SELECT text as en,
    135                 (SELECT text FROM '.$Config['Database']['Database'].'.global_strings as tabletran
    136                  WHERE tableen.entry = tabletran.entry AND (Complete = 1) AND '.$WhereLang.'
    137                   AND '.$WhereUsers.' ORDER BY FIELD(User, '.$SelectedUsers.') LIMIT 1) as tran
    138                  FROM '.$Config['Database']['Database'].'.global_strings as tableen WHERE
    139                   text = "'.addslashes($Ori_text).'" LIMIT 1'));
    140                         //echo ($Line['name'].'='.$Tran['tran']);
    141                         if ($Tran['tran'] == '')
    142       {
    143                         $Tran = mysql_fetch_assoc($Database->SQLCommand('SELECT OptionText as en,
    144                         (SELECT OptionText FROM '.$Config['Database']['Database'].'.npc_option as tabletran
    145                          WHERE tableen.entry = tabletran.entry AND (Complete = 1) AND '.$WhereLang.'
    146                           AND '.$WhereUsers.' ORDER BY FIELD(User, '.$SelectedUsers.') LIMIT 1) as tran
    147                         FROM '.$Config['Database']['Database'].'.npc_option as tableen WHERE
    148                         OptionText = "'.addslashes($Ori_text).'" LIMIT 1'));
    149       }
    150                   if ($Tran['tran'] <> '')
    151                           $Buffer .= 'UPDATE `'.$AoWoWTable.'` SET name = "'.addslashes($Tran['tran']).'" WHERE '.$IndexColum.' = '.$Line[$IndexColum].' ;'."\n";
    152     }
    153         $Buffer .= "\n\n"; 
    154         }
    155         if($Setting['Diacritics'] != 1) $Buffer = utf2ascii($Buffer);
    156         return($Buffer);
    157 
    158  
    159  
    160 function ExportToXML($Setting)
    161 {
    162   global $Database, $Config, $TranslationTree, $LanguageList;
    163  
    164   $AnoNe = array('Ne', 'Ano');
    165   if($_SESSION['UserID'] != '')
    166   {
    167     $DbResult = $Database->SQLCommand('SELECT user FROM `user` WHERE ID='.$_SESSION['UserID']);
    168     $User = mysql_fetch_assoc($DbResult);
    169   } else $User = array('user' => 'Neznámý');
    170 
    171   $WhereLang = '';
    172   foreach($LanguageList as $Language)
    173     if($Language['Enabled'] == 1)
    174       if(isset($Setting['language'.$Language['Id']]))  $WhereLang .= ' OR (Language = '.$Language['Id'].')';
    175   if($WhereLang == '') $WhereLang = 1;
    176     else $WhereLang = '('.substr($WhereLang, 4).')';
    177 
    178   $SelectedUsers = ''; 
    179   foreach($Setting['users-selection'] as $Item)
    180     $SelectedUsers .= ','.$Item;
    181   $SelectedUsers = substr($SelectedUsers, 1);
    182 
    183   if($SelectedUsers == '') $Where = 0;
    184     else $Where = 'ID IN ('.$SelectedUsers.')';
    185  
    186   $UserNames = '';
    187   $DbResult = $Database->SQLCommand('SELECT user FROM `user` WHERE '.$Where);
    188   while($DbRow = mysql_fetch_assoc($DbResult))
    189     $UserNames .= ','.$DbRow['user'];
    190   $UserNames = substr($UserNames, 1);   
    191    
    192   if($SelectedUsers == '') $WhereUsers = 1;
    193     else $WhereUsers = '(User IN ('.$SelectedUsers.'))';
    194 
    195   $Buffer = '<?xml version="1.0" encoding="utf-8"?>'."\n".
    196   "<document>\n".
    197   "  <meta>\n".
    198   "    <projecturl>".$Config['Web']['BaseURL']."</projecturl>\n".
    199   "    <time>".date('r')."</time>\n".
    200   "    <diacritics mode=".'"'.$Setting['Diacritics'].'"'." />\n".
    201   "    <author>".$User['user']."</author>\n".
    202   "    <contributors>\n";
    203   foreach(explode(',', $UserNames) as $UserName)
    204     $Buffer .= "      <user>".$UserName."</user>\n";
    205   $Buffer .=
    206   "    </contributors>\n".
    207   "  </meta>\n".
    208   "  <translation>\n";
    209 
    210   foreach($TranslationTree as $Group)
    211   if(in_array($Group['Id'], $Setting['groups']))
    212   {
    213         if($Group['MangosTable'] == '')
    214         {
    215           $Group['MangosTable'] = $Group['TablePrefix'];
    216           $Group['MangosTableIndex'] = 'entry';
    217         }
    218     $Query = 'SELECT *,(SELECT user FROM user WHERE user.ID=T.User) as UserName FROM (SELECT * FROM '.$Group['TablePrefix'].' WHERE (Complete = 1) AND VersionStart <= '.GetBuildNumber($Setting['Version']).' AND VersionEnd >= '.GetBuildNumber($Setting['Version']).' AND '.$WhereLang.' AND '.$WhereUsers.' ORDER BY FIELD(User, '.$SelectedUsers.')) AS T GROUP BY T.entry';       
    219     //echo($Query);
    220     $Buffer .= '    <group id="'.$Group['Id'].'" name="'.$Group['TablePrefix'].'">'."\n";
    221     $ID = $Database->SQLCommand($Query);
    222     while($Line = mysql_fetch_array($ID))
    223     {
    224       $Buffer .= '      <item id="'.$Line['entry'].'" user="'.$Line['UserName'].'">'."\n";
    225           $Values = '';
    226           foreach($Group['Items'] as $GroupItem)
    227           {
    228             if($GroupItem['MangosColumn'] == '') $GroupItem['MangosColumn'] = $GroupItem['Column'];
    229                 if($Line[$GroupItem['Column']] != '')
    230                   $Buffer .= '        <text index="'.$GroupItem['Id'].'" name="'.$GroupItem['Column'].'">'.addslashes($Line[$GroupItem['Column']]).'</text>'."\n";
    231           }
    232           $Buffer .= "      </item>\n";
    233     }   
    234         $Buffer .= "    </group>\n";
    235   }
    236   if($Setting['Diacritics'] != 1) $Buffer = utf2ascii($Buffer);
    237   $Buffer .= "  </translation>\n".
    238   "</document>";
    239   return($Buffer);
    240 }     
    241 
    242 function ExportToDBC($Setting)
    243 {
    244   global $Database, $Config, $TranslationTree, $LanguageList;
    245  
    246   $TempDir = $Config['Web']['TempFolder'].$_SESSION['User'].'/dbc/';
    247   if(!file_exists($TempDir)) mkdir($TempDir, 0777, true);
    248  
    249   if($_SESSION['UserID'] != '')
    250   {
    251     $DbResult = $Database->SQLCommand('SELECT user FROM `user` WHERE ID='.$_SESSION['UserID']);
    252     $User = mysql_fetch_assoc($DbResult);
    253   } else $User = array('user' => 'Neznámý');
    254 
    255   $WhereLang = '';
    256   foreach($LanguageList as $Language)
    257     if($Language['Enabled'] == 1)
    258       if(isset($Setting['language'.$Language['Id']]))  $WhereLang .= ' OR (Language = '.$Language['Id'].')';
    259   if($WhereLang == '') $WhereLang = 1;
    260     else $WhereLang = '('.substr($WhereLang, 4).')';
    261 
    262   $SelectedUsers = ''; 
    263   foreach($Setting['users-selection'] as $Item)
    264     $SelectedUsers .= ','.$Item;
    265   $SelectedUsers = substr($SelectedUsers, 1);
    266 
    267   if($SelectedUsers == '') $Where = 0;
    268     else $Where = 'ID IN ('.$SelectedUsers.')';
    269  
    270   $UserNames = '';
    271   $DbResult = $Database->SQLCommand('SELECT user FROM `user` WHERE '.$Where);
    272   while($DbRow = mysql_fetch_assoc($DbResult))
    273     $UserNames .= ','.$DbRow['user'];
    274   $UserNames = substr($UserNames, 1);   
    275    
    276   if($SelectedUsers == '') $WhereUsers = 1;
    277     else $WhereUsers = '(User IN ('.$SelectedUsers.'))';
    278  
    279   foreach($TranslationTree as $Group)
    280   if(in_array($Group['Id'], $Setting['groups']) and ($Group['DBCFileName'] != ''))
    281   {
    282         echo($Group['Name'].'... ');
    283             $DBCFile = new DBCFile();
    284             $DBCFile->OpenFile('../source/'.$Setting['Version'].'/dbc/'.$Group['DBCFileName'].'.dbc', GetDBCColumns($Setting['Version'],$Group['DBCFileName']));
    285             $DBCFile2 = new DBCFile();
    286             $DBCFile2->CreateFile($TempDir.$Group['DBCFileName'].'.dbc', GetDBCColumns($Setting['Version'],$Group['DBCFileName']));
    287                 $Count = $DBCFile->GetRecordCount();
    288         //if($Group['DBCFileName'] == 'Spell') $Count = 1000;
    289                 $Line = $DBCFile->GetLine(0);
    290             $DBCFile2->SetRecordCount($Count);   
    291             for($I = 0; $I < $Count; $I++)
    292             {
    293               $Line = $DBCFile->GetLine($I);
    294                   $Query = 'SELECT * FROM (SELECT * FROM '.$Group['TablePrefix'].' WHERE (Complete = 1) AND '.$WhereLang.' AND '.$WhereUsers.' AND (entry='.$Line[0].')  AND VersionStart <= '.GetBuildNumber($Setting['Version']).' AND VersionEnd >= '.GetBuildNumber($Setting['Version']).' ORDER BY FIELD(User, '.$SelectedUsers.')) AS T GROUP BY T.entry';       
    295                   $DbResult = $Database->SQLCommand($Query);
    296                   if(mysql_num_rows($DbResult) > 0)
    297                   {
    298                     $DbRow = mysql_fetch_assoc($DbResult);
    299                 //  if($Setting['Diacritics'] != 1) $Buffer = utf2ascii($Buffer);
    300 
    301                 foreach($Group['Items'] as $GroupItem)
    302                       if(GetDBCColumnIndex($Setting['Version'],$Group['DBCFileName'],$GroupItem['Column']) != '')
    303                         $Line[GetDBCColumnIndex($Setting['Version'],$Group['DBCFileName'],$GroupItem['Column'])] = $DbRow[$GroupItem['Column']];
    304                   //print_r($Line);
    305                   }
    306               $DBCFile2->SetLine($I, $Line);
    307                   echo('.');
    308             }
    309     $DBCFile2->Commit();
    310     echo('Hotovo <br />');
     280      while(!$File->EOF())
     281      {
     282        $Line = $File->ReadLine();
     283        if(strpos($Line, '=') !== false)
     284        {
     285          $LineParts = explode(';', $Line);
     286          $LineParts2 = explode('=', $LineParts[0]);
     287          $Value['ShortCut'] = trim($LineParts2[0]);
     288          $Value['Text'] = substr(trim($LineParts2[1]), 1, -1);
     289          $Value['Comment'] = addslashes(substr(trim($LineParts[1]), 3));
     290
     291          $Query = 'SELECT * FROM (SELECT * FROM '.$Group['TablePrefix'].' WHERE (Complete = 1) AND '.$this->WhereLang.' AND '.$this->WhereUsers.' AND (ShortCut="'.$Value['ShortCut'].'") AND VersionStart <= '.$this->ClientVersion.' AND VersionEnd >= '.$this->ClientVersion.' ORDER BY FIELD(User, '.$this->SelectedUsers.')) AS T GROUP BY T.entry';
     292          //echo($Query);
     293          $DbResult2 = $this->Database->query($Query);
     294          if($DbResult2->num_rows > 0)
     295          {
     296            $DbRow = $DbResult2->fetch_assoc();
     297            $Value['Text'] = $DbRow['Text'];
     298            $Value['Comment'] = $DbRow['Comment'];
     299            //echo('.');
     300          }
     301          $NewLine = $Value['ShortCut'].' = "'.$Value['Text'].'";';
     302          if($Value['Comment'] != '') $NewLine .= ' -- '.$Value['Comment'];
     303          $NewLine .= "\n";
     304          $File2->WriteLine($NewLine);
     305        } else $File2->WriteLine($Line."\n");
     306      }
     307      echo('Hotovo <br />');
     308    }
    311309  }
    312310}
    313311
    314 function ExportToLua($Setting)
    315 {
    316   global $Database, $Config, $TranslationTree, $LanguageList;
    317  
    318   $TempDir = $Config['Web']['TempFolder'].$_SESSION['User'].'/lua/';
    319   if(!file_exists($TempDir)) mkdir($TempDir, 0777, true);
    320  
    321   if($_SESSION['UserID'] != '')
    322   {
    323     $DbResult = $Database->SQLCommand('SELECT user FROM `user` WHERE ID='.$_SESSION['UserID']);
    324     $User = mysql_fetch_assoc($DbResult);
    325   } else $User = array('user' => 'Neznámý');
    326 
    327   $WhereLang = '';
    328   foreach($LanguageList as $Language)
    329     if($Language['Enabled'] == 1)
    330       if(isset($Setting['language'.$Language['Id']]))  $WhereLang .= ' OR (Language = '.$Language['Id'].')';
    331   if($WhereLang == '') $WhereLang = 1;
    332     else $WhereLang = '('.substr($WhereLang, 4).')';
    333 
    334   $SelectedUsers = ''; 
    335   foreach($Setting['users-selection'] as $Item)
    336     $SelectedUsers .= ','.$Item;
    337   $SelectedUsers = substr($SelectedUsers, 1);
    338 
    339   if($SelectedUsers == '') $Where = 0;
    340     else $Where = 'ID IN ('.$SelectedUsers.')';
    341  
    342   $UserNames = '';
    343   $DbResult = $Database->SQLCommand('SELECT user FROM `user` WHERE '.$Where);
    344   while($DbRow = mysql_fetch_assoc($DbResult))
    345     $UserNames .= ','.$DbRow['user'];
    346   $UserNames = substr($UserNames, 1);   
    347    
    348   if($SelectedUsers == '') $WhereUsers = 1;
    349     else $WhereUsers = '(User IN ('.$SelectedUsers.'))';
    350  
    351   foreach($TranslationTree as $Group)
    352   if(in_array($Group['Id'], $Setting['groups']) and ($Group['LuaFileName'] != ''))
    353   {
    354         echo($Group['Name'].'... ');
    355     $File = new FileStream();
    356     $File->OpenFile('../source/'.$Setting['Version'].'/lua/'.$Group['LuaFileName'].'.lua');
    357     $File2 = new FileStream();
    358     $File2->CreateFile($TempDir.''.$Group['LuaFileName'].'.lua');
    359 
    360     while(!$File->EOF())
    361         {
    362           $Line = $File->ReadLine();
    363           if(strpos($Line, '=') !== false)
    364           {
    365                 $LineParts = explode(';', $Line);
    366         $LineParts2 = explode('=', $LineParts[0]);
    367                 $Value['ShortCut'] = trim($LineParts2[0]);
    368                 $Value['Text'] = substr(trim($LineParts2[1]), 1, -1);
    369                 $Value['Comment'] = addslashes(substr(trim($LineParts[1]), 3));
    370 
    371             $Query = 'SELECT * FROM (SELECT * FROM '.$Group['TablePrefix'].' WHERE (Complete = 1) AND '.$WhereLang.' AND '.$WhereUsers.' AND (ShortCut="'.$Value['ShortCut'].'") AND VersionStart <= '.GetBuildNumber($Setting['Version']).' AND VersionEnd >= '.GetBuildNumber($Setting['Version']).' ORDER BY FIELD(User, '.$SelectedUsers.')) AS T GROUP BY T.entry';
    372                 //echo($Query);
    373             $DbResult = $Database->SQLCommand($Query);
    374             if(mysql_num_rows($DbResult) > 0)
    375             {
    376               $DbRow = mysql_fetch_assoc($DbResult);
    377                   $Value['Text'] = $DbRow['Text'];
    378                   $Value['Comment'] = $DbRow['Comment'];
    379               //echo('.');
    380                 }
    381                 $NewLine = $Value['ShortCut'].' = "'.$Value['Text'].'";';
    382                 if($Value['Comment'] != '') $NewLine .= ' -- '.$Value['Comment'];
    383                 $NewLine .= "\n";
    384                 $File2->WriteLine($NewLine);
    385           } else $File2->WriteLine($Line."\n");
    386         }
    387     echo('Hotovo <br />');
    388   }
    389 }
    390 
    391312?>
  • trunk/export/index.php

    r286 r290  
    33session_start();
    44
    5 // příkaz:
    6 
    7 //php index.php "action=result" 'ExportSetting=a:10:{s:11:"users-order";s:838:",459,1,2,499,304,462,407,379,58,400,392,119,281,590,277,159,192,588,503,586,131,195,288,208,537,426,337,146,30,122,598,399,596,28,8,319,174,33,165,188,269,18,84,331,578,591,147,579,592,289,303,567,243,502,144,285,161,568,351,163,547,262,256,141,536,301,318,214,486,172,154,466,446,335,127,563,76,293,173,325,580,290,153,543,23,196,509,552,237,389,317,177,52,594,416,539,473,573,17,5,139,452,148,362,210,346,35,553,71,68,394,143,369,515,448,140,445,32,171,211,347,226,152,403,245,217,27,7,268,549,86,81,348,370,476,132,562,307,575,583,291,555,548,16,474,182,556,535,320,252,359,264,338,533,405,577,250,221,582,197,230,72,242,213,409,472,186,554,523,492,378,413,512,581,352,518,485,602,601,604,603,606,607,595,609,617,614,618,616,613,622,624,638,641,643,626,627,648,639,652,642,650,26,156,640,633,635,653,637,654,636,284,531,585,629,651,647";s:15:"users-selection";a:44:{i:0;s:3:"459";i:1;s:1:"1";i:2;s:1:"2";i:3;s:3:"499";i:4;s:3:"304";i:5;s:3:"462";i:6;s:3:"407";i:7;s:3:"379";i:8;s:3:"400";i:9;s:3:"281";i:10;s:3:"277";i:11;s:3:"159";i:12;s:3:"588";i:13;s:3:"503";i:14;s:3:"586";i:15;s:3:"131";i:16;s:3:"195";i:17;s:3:"288";i:18;s:3:"208";i:19;s:3:"537";i:20;s:3:"426";i:21;s:3:"337";i:22;s:3:"122";i:23;s:3:"319";i:24;s:3:"174";i:25;s:3:"165";i:26;s:3:"188";i:27;s:3:"269";i:28;s:2:"18";i:29;s:3:"331";i:30;s:3:"578";i:31;s:3:"579";i:32;s:3:"592";i:33;s:3:"567";i:34;s:3:"568";i:35;s:3:"446";i:36;s:3:"580";i:37;s:3:"362";i:38;s:3:"549";i:39;s:3:"562";i:40;s:3:"556";i:41;s:3:"618";i:42;s:3:"613";i:43;s:3:"622";}s:6:"groups";a:18:{i:0;s:1:"1";i:1;s:1:"2";i:2;s:1:"3";i:3;s:1:"4";i:4;s:1:"5";i:5;s:1:"6";i:6;s:1:"7";i:7;s:1:"8";i:8;s:2:"10";i:9;s:2:"11";i:10;s:2:"12";i:11;s:2:"13";i:12;s:2:"14";i:13;s:2:"15";i:14;s:2:"16";i:15;s:2:"17";i:16;s:2:"18";i:17;s:2:"19";}s:10:"Diacritics";b:1;s:11:"language-cz";b:1;s:11:"language-sk";b:1;s:14:"language-other";b:0;s:6:"Export";s:11:"AoWoWImport";s:9:"language1";b:0;s:9:"language2";b:0;}'
    8 
    9 // Load commandline parameters
    10 if(!array_key_exists('REMOTE_ADDR', $_SERVER))
    11 {
    12   foreach($_SERVER['argv'] as $parameter)
    13   {
    14     if(strpos($parameter, '=') !== false)
     5include_once('../includes/global.php');
     6include_once('export_output.php');
     7
     8function ExportList()
     9{
     10  global $Database;
     11 
     12  echo('<a href="?Action=ViewList">Všechny</a>');
     13  if(Licence(LICENCE_USER))
     14  {
     15    echo(' <a href="?Action=ViewList&amp;Filter=Others">Ostatních</a>');
     16    echo(' <a href="?Action=ViewList&amp;Filter=My">Moje</a>');
     17  }
     18 
     19  $Filter = '';
     20  if(array_key_exists('Filter', $_GET))
     21  {
     22    if($_GET['Filter'] == 'My') $Filter = ' WHERE `Export`.`User` = '.$_SESSION['UserID'];
     23    if($_GET['Filter'] == 'Others') $Filter = ' WHERE `Export`.`User` != '.$_SESSION['UserID'];
     24  }
     25 
     26  $DbResult = $Database->SQLCommand('SELECT COUNT(*) FROM `Export` '.$Filter);
     27  $DbRow = mysql_fetch_row($DbResult);
     28  $PageList = GetPageList($DbRow[0]);   
     29
     30  echo('<h3>Seznam exportů</h3>');
     31  echo($PageList['Output']);
     32
     33  $TableColumns = array(
     34    array('Name' => 'TimeCreate', 'Title' => 'Čas vytvoření'),
     35    array('Name' => 'UserName', 'Title' => 'Překladatel'),
     36    array('Name' => 'Title', 'Title' => 'Popis'),
     37    array('Name' => 'UsedCount', 'Title' => 'Počet stažení'),
     38    array('Name' => 'UserCount', 'Title' => 'Překladatelů'),
     39    array('Name' => 'GroupCount', 'Title' => 'Překladových skupin'),
     40    array('Name' => '', 'Title' => 'Akce'),
     41  ); 
     42  $Order = GetOrderTableHeader($TableColumns, 'TimeCreate');
     43  echo('<table class="BaseTable">');
     44  echo($Order['Output']);
     45
     46  $DbResult = $Database->SQLCommand('SELECT `user`.`user` AS `UserName`, `Export`.*, (SELECT COUNT(*) FROM ExportGroup WHERE ExportGroup.Export=Export.Id) AS GroupCount, (SELECT COUNT(*) FROM ExportUser WHERE ExportUser.Export=Export.Id) AS UserCount FROM `Export` LEFT JOIN `user` ON `user`.`ID`=`Export`.`User` '.$Filter.$Order['SQL'].$PageList['SQLLimit']);
     47  while($Export = mysql_fetch_assoc($DbResult))
     48  {
     49    $Action = '<a href="?Action=View&amp;ExportId='.$Export['Id'].'">Zobrazit</a>';
     50    if($Export['User'] == $_SESSION['UserID']) $Action .= ' <a href="?Action=Delete&amp;ExportId='.$Export['Id'].'"><div onclick="return confirmAction(\'Opravdu smazat položku?\');">Smazat</div></a>';
     51    echo('<tr><td>'.$Export['TimeCreate'].'</td><td>'.$Export['UserName'].'</td><td>'.$Export['Title'].'</td><td>'.$Export['UsedCount'].'</td><td>'.$Export['UserCount'].'</td><td>'.$Export['GroupCount'].'</td><td>'.$Action.'</td></tr>');
     52  }
     53  echo('</table>');
     54  echo($PageList['Output']);
     55   
     56  if(Licence(LICENCE_USER)) echo('<br/><div style="text-align: center;"><a href="?Action=Create">Vytvořit nový export</a></div>');
     57}
     58
     59function ExportCreate()
     60{
     61  if(Licence(LICENCE_USER))
     62  {   
     63    echo('<form action="?Action=CreateFinish" method="post">'.
     64      '<fieldset><legend>Vytvoření nového exportu</legend>'.
     65      '<table><tr><td>Titulek:</td><td><input type="text" name="Title" /></td></tr>'.
     66      '<tr><td colspan="2"><input type="submit" value="Vytvořit" /></td></tr>'.
     67      '</table></fieldset></form>');
     68  } else echo('Nemáte oprávnění');
     69}
     70
     71function ExportCreateFinish()
     72{
     73  global $Database;
     74 
     75  if(Licence(LICENCE_USER))
     76  {   
     77    if(array_key_exists('Title', $_POST))
    1578    {
    16       $index = substr($parameter,0,strpos($parameter, '='));
    17       $parameter = substr($parameter,strpos($parameter, '=')+1);
    18       //echo ($index.'  ----  '.$parameter);
    19       $_GET[$index] = $parameter;
     79      $Database->SQLCommand('INSERT INTO `Export` (`Title`, `User`, `TimeCreate`) VALUES ("'.$_POST['Title'].'", '.$_SESSION['UserID'].', NOW())');
     80      $ExportId = mysql_insert_id();
     81      echo('Nový export vytvořen.<br/>Přímý odkaz na tento export: <a href="?Action=View&amp;ExportId='.$ExportId.'">zde</a><br/><br/>');
     82      $_GET['Filter'] = 'my';
     83      ExportList();
     84    } else echo('Chybí údaje formuláře');
     85  } else echo('Nemáte oprávnění');
     86}
     87
     88function ExportDelete()
     89{
     90  global $Database;
     91 
     92  if(Licence(LICENCE_USER))
     93  {   
     94    if(array_key_exists('ExportId', $_GET))
     95    {
     96      $Database->SQLCommand('DELETE FROM Export WHERE Id='.$_GET['ExportId']);
     97      echo('Export smazán.<br/><br/>');
     98      $_GET['Filter'] = 'my';
     99      ExportList();
     100    } else echo('Nebylo zadáno Id');
     101  } else echo('Nemáte oprávnění');
     102}
     103
     104function ExportViewTranslators()
     105{
     106  global $Database, $TranslationTree, $Config;
     107
     108  $DisabledInput = array(false => ' disabled="disabled"', true => '');
     109  if(array_key_exists('ExportId', $_GET))
     110  {
     111    $DbRows = $Database->SQLCommand('SELECT * FROM Export WHERE Id='.$_GET['ExportId']);
     112    if(mysql_num_rows($DbRows) > 0)
     113    {   
     114      $Export = mysql_fetch_assoc($DbRows);
     115      if(Licence(LICENCE_USER) and ($_SESSION['UserID'] == $Export['User'])) $Editable = true;
     116        else $Editable = false;
     117       
     118       
     119  if(array_key_exists('Operation', $_GET))
     120  {
     121    if($_GET['Operation'] == 'Save')
     122    {
     123      //print_r($_POST);
     124      // Update user selection page
     125      foreach($_POST as $Index => $Value)
     126      {
     127        if(substr($Index, 0, 3) == 'seq')
     128        {
     129          $UserId = substr($Index, 3) * 1;
     130          if(array_key_exists('sel'.$UserId, $_POST)) $Selected = true;
     131            else $Selected = false;
     132          $Condition = ' WHERE Export='.$_GET['ExportId'].' AND User='.$UserId;
     133          $DbResult = $Database->SQLCommand('SELECT * FROM ExportUser '.$Condition);
     134          if(mysql_num_rows($DbResult) > 0)
     135          {
     136            if(!$Selected) $Database->SQLCommand('DELETE FROM ExportUser '.$Condition);
     137              else $Database->SQLCommand('UPDATE ExportUser SET Sequence='.$Value.$Condition);
     138          } else
     139          {
     140            if($Selected) $Database->SQLCommand('INSERT INTO ExportUser (Export, User, Sequence) VALUES ('.$_GET['ExportId'].', '.$UserId.', '.$Value.')');
     141          }         
     142        }
     143      }
     144     
     145      // Recalculate sequence number
     146      $Database->SQLCommand('SET @I = 0');
     147      $Database->SQLCommand('UPDATE ExportUser SET Sequence = (@I := @I + 1) WHERE Export='.$_GET['ExportId'].' ORDER BY Sequence;');
    20148    }
    21   }
    22 }
    23 
    24 if(!array_key_exists('ExportSetting', $_SESSION))
    25   if(array_key_exists('ExportSetting', $_COOKIE))
    26     $_SESSION['ExportSetting'] = $_COOKIE['ExportSetting'];
    27   else $_SESSION['ExportSetting'] = '';
    28  
    29 setcookie('ExportSetting', $_SESSION['ExportSetting'], time() + 60 * 60 * 24 * 100);
    30 include('../includes/global.php');
    31 include('../includes/zip.lib.php');
    32 include('export.php');   
    33 include('create_addon.php');
    34 include('../includes/dbc.php');
    35 
    36 ShowPage();
    37 
    38 function CheckBox($Name, $Checked = false, $Id = '', $Class = '')
    39 {
    40   if($Id) $Id = ' id="'.$Id.'"'; else $Id = '';
    41   if($Class) $Class = ' class="'.$Class.'"'; else $Class = '';
    42   if($Checked) $Checked = ' checked="checked"'; else $Checked = '';
    43   return('<input type="checkbox" value="checked" name="'.$Name.'"'.$Checked.$Id.$Class.' />');
    44 }
    45 
    46 function RadioButton($Name, $Value, $Checked = false, $onclick = '')
    47 {
    48   if($Checked) $Checked = ' checked="checked"'; else $Checked = '';
    49   return('<input onclick="'.$onclick.'" type="radio" name="'.$Name.'" value="'.$Value.'"'.$Checked.' />');
    50 }
    51 
    52 function SelectOption($Name, $Text, $Selected = false)
    53 {
    54   if($Selected) $Selected = ' selected="selected"'; else $Selected = '';
    55   return('<option value="'.$Name.'"'.$Selected.'>'.$Text.'</option>');
    56 }
    57 
    58 function GetVersions($out)
    59 {
    60   global $Database,$TranslationTree,$Config;
    61   $result = 'null';
    62   if ($out == 'VerseCZ') $out = 'Addon';
    63   if (($out == 'XMLCompressed') or ($out == 'XMLDirect'))  $out = 'sources';
    64   if (($out == 'MangosSQLCompressed') or ($out == 'MangosSQLDirect') or ($out == 'AoWoWSQLCompressed') or ($out == 'AoWoWSQLDirect') or ($out == 'AoWoWImport'))  $out = 'sql';
    65   switch($out)
    66   {
    67     case 'Addon':
    68       $Addon_verses = scandir('files', 1);
    69       unset($Addon_verses[count($Addon_verses) - 1]);
    70       unset($Addon_verses[count($Addon_verses) - 1]);
    71       unset($Addon_verses[count($Addon_verses) - 1]);
    72     $result = '[';
    73     foreach($Addon_verses as $version) {
    74       $result .= "'".$version."',";
     149  }
     150
     151  $Columns = '';
     152  $Joins = '';
     153  foreach($TranslationTree as $Group)
     154    if($Group['TablePrefix'] != '')
     155    {
     156      $Columns .= 'COALESCE(T'.$Group['Id'].'.Count, 0) + ';
     157      $Joins .= ' LEFT JOIN (SELECT User, COUNT(User) as Count FROM `'.$Group['TablePrefix'].'` WHERE (Complete = 1) AND (Language <> 0) GROUP BY User) as T'.$Group['Id'].' ON user.ID=T'.$Group['Id'].'.User';
     158    }
     159  $Query = 'SELECT (@I := @I + 1) AS Sequence2, ExportUser.Sequence, T.ID, T.TranslatedCount, T.user, T.XP FROM (SELECT user.ID, user.user, user.XP, ('.substr($Columns, 0, -3).') as TranslatedCount FROM `user`'.$Joins.') AS T';
     160  $Query .=' LEFT JOIN ExportUser ON ExportUser.Export = '.$_GET['ExportId'].' AND ExportUser.User=T.ID';
     161  $Query .=' WHERE T.TranslatedCount > 0 ORDER BY COALESCE(Sequence, 100)';
     162
     163  $DbResult = $Database->SQLCommand('SELECT COUNT(*) FROM ('.$Query.') AS X');
     164  $DbRow = mysql_fetch_row($DbResult);
     165  $PageList = GetPageList($DbRow[0]);   
     166 
     167  $TableColumns = array(
     168    array('Name' => 'user', 'Title' => 'Jméno'),
     169    array('Name' => 'TranslatedCount', 'Title' => 'Překladů'),
     170    array('Name' => 'XP', 'Title' => 'Úroveň'),
     171    array('Name' => '', 'Title' => 'Výběr'),
     172    array('Name' => 'Sequence2', 'Title' => 'Pořadí'),
     173  ); 
     174  $Order = GetOrderTableHeader($TableColumns, 'TranslatedCount');
     175  echo('<form action="?Action=View&amp;ExportId='.$_GET['ExportId'].'&amp;Operation=Save" method="post">');
     176  echo('<h3>Překladatelé</h3>');
     177  echo('<input type="submit" value="Uložit výběr" '.$DisabledInput[$Editable].'/><br />'.
     178   'Zvolte ze seznamu uživatele, od kterých chcete načítat překlady a upravte jejich pořadí.<br />'.
     179    'Pořadí řádků je dáno číselnou hodnotou, kterou lze změnit na požadované pořadí. Řádky se stejným pořadovým číslem budou přečíslovány vzestupně.');
     180
     181  echo($PageList['Output']);
     182  echo('<table class="BaseTable">');
     183  echo($Order['Output']);
     184
     185  $Query = 'SELECT * FROM ('.$Query.') AS TX '.$Order['SQL'].$PageList['SQLLimit'];
     186  $Database->SQLCommand('SET @I = 0');
     187  $DbResult = $Database->SQLCommand($Query);
     188  while($User = mysql_fetch_assoc($DbResult))
     189  {
     190    $Checked = $User['Sequence'] != '';
     191    $Selection = CheckBox('sel'.$User['ID'], $Checked, '', 'CheckBox', !$Editable);
     192    $Sequence = '<input type="text" name="seq'.$User['ID'].'" style="text-align: center; width: 40px;" value="'.$User['Sequence2'].'"'.$DisabledInput[$Editable].'/>';
     193    echo('<tr>
     194    <td><a href="'.$Config['Web']['BaseURL'].'/TranslationList.php?user='.$User['ID'].'&amp;action=userall" title="Zobrazit všechny jeho přeložené texty">'.$User['user'].'</a></td>
     195    <td>'.$User['TranslatedCount'].'</td>
     196      <td><img src="'.$Config['Web']['TempFolder'].$User['user'].'/level.png" alt="Úroveň uživatele" /></td>
     197    <td>'.$Selection.'</td><td>'.$Sequence.'</td></tr>');
     198  }
     199  echo('</table>');
     200  echo('</form>');
     201  echo($PageList['Output']);
     202    } else echo('Položka nenalezena');
     203  } else echo('Nebylo zadáno Id');
     204}
     205
     206function ExportViewGeneral()
     207{
     208  global $Database;
     209 
     210  $DisabledInput = array(false => ' disabled="disabled"', true => '');
     211  $DisabledTextArea = array(false => ' readonly="yes"', true => '');
     212  echo('<h3>Obecná nastavení</h3>');
     213  if(array_key_exists('ExportId', $_GET))
     214  {
     215    $DbRows = $Database->SQLCommand('SELECT * FROM Export WHERE Id='.$_GET['ExportId']);
     216    if(mysql_num_rows($DbRows) > 0)
     217    {   
     218      $Export = mysql_fetch_assoc($DbRows);
     219      if(Licence(LICENCE_USER) and ($_SESSION['UserID'] == $Export['User'])) $Editable = true;
     220        else $Editable = false;
     221      if($Export['WithDiacritic'] == 1) $WithDiacritic = ' checked="checked"'; else $WithDiacritic = '';
     222      echo('<form action="?Action=ModifyFinish&amp;ExportId='.$Export['Id'].'" method="post">'.
     223        '<table>'.
     224        '<tr><td colspan="2"><input type="submit" value="Uložit" '.$DisabledInput[$Editable].'/></td></tr>'.
     225'<tr><td>Označení:</td><td><input type="text" style="width: 400px" name="Title" value="'.$Export['Title'].'"'.$DisabledInput[$Editable].'/></td></tr>'.
     226        '<tr><td>Popis:</td><td><textarea name="Description" cols="54" rows="10"'.$DisabledTextArea[$Editable].'></textarea></td></tr>'.
     227        '<tr><td>Včetně háčků a čárek</td><td><input type="checkbox" name="WithDiacritic" '.$WithDiacritic.''.$DisabledInput[$Editable].'/></td></tr>'.
     228      '</table></fieldset></form>');
     229    } else echo('Položka nenalezena');
     230  } else echo('Nebylo zadáno Id');
     231}
     232
     233function ExportViewLanguages()
     234{
     235  global $Database, $TranslationTree, $Config;
     236
     237  $DisabledInput = array(false => ' disabled="disabled"', true => '');
     238  if(array_key_exists('ExportId', $_GET))
     239  {
     240    $DbRows = $Database->SQLCommand('SELECT * FROM Export WHERE Id='.$_GET['ExportId']);
     241    if(mysql_num_rows($DbRows) > 0)
     242    {   
     243      $Export = mysql_fetch_assoc($DbRows);
     244      if(Licence(LICENCE_USER) and ($_SESSION['UserID'] == $Export['User'])) $Editable = true;
     245        else $Editable = false;
     246       
     247  if(array_key_exists('Operation', $_GET))
     248  {
     249    if($_GET['Operation'] == 'Save')
     250    {
     251      //print_r($_POST);
     252      // Update user selection page
     253      foreach($_POST as $Index => $Value)
     254      {
     255        if(substr($Index, 0, 3) == 'seq')
     256        {
     257          $LanguageId = substr($Index, 3) * 1;
     258          if(array_key_exists('sel'.$LanguageId, $_POST)) $Selected = true;
     259            else $Selected = false;
     260          $Condition = ' WHERE Export='.$_GET['ExportId'].' AND Language='.$LanguageId;
     261          $DbResult = $Database->SQLCommand('SELECT * FROM ExportLanguage '.$Condition);
     262          if(mysql_num_rows($DbResult) > 0)
     263          {
     264            if(!$Selected) $Database->SQLCommand('DELETE FROM ExportLanguage '.$Condition);
     265              else $Database->SQLCommand('UPDATE ExportLanguage SET Sequence='.$Value.$Condition);
     266          } else
     267          {
     268            if($Selected) $Database->SQLCommand('INSERT INTO ExportLanguage (Export, Language, Sequence) VALUES ('.$_GET['ExportId'].', '.$LanguageId.', '.$Value.')');
     269          }         
     270        }
    75271      }
    76     $result = substr($result,0,strlen($result)-1);
    77     $result .= "]";
    78   break;
    79     case 'sources':
    80       $dirs = scandir('../source', 1);
    81       unset($dirs[count($dirs) - 1]);
    82       unset($dirs[count($dirs) - 1]);
    83       unset($dirs[count($dirs) - 1]);
    84     $result = '[';
    85     foreach($dirs as $dir) {
    86       $result .= "'".$dir."',";
    87       }
    88     $result = substr($result,0,strlen($result)-1);
    89     $result .= "]";
    90   break;
    91     case 'sql':
    92       $dirs = scandir('../source', 1);
    93       unset($dirs[count($dirs) - 1]);
    94       unset($dirs[count($dirs) - 1]);
    95       unset($dirs[count($dirs) - 1]);
    96     $result = '[';
    97     foreach($dirs as $dir) {
    98     if ($TranslationTree[1]['LastVersion'] >= GetBuildNumber($dir))
    99         $result .= "'".$dir."',";
    100       }
    101     if ($result <> '[') $result = substr($result,0,strlen($result)-1);
    102     $result .= "]";
    103   break;
    104     case 'DBC':
    105       $sql = 'SELECT Version FROM wow_client_version WHERE DBCColumns_GameTips <> "" AND DBCColumns_Spell <> "" ORDER BY BuildNumber DESC';
    106       $ID = $Database->SQLCommand($sql);
    107     $result = '[';
    108       while($Line = mysql_fetch_assoc($ID))
     272     
     273      // Recalculate sequence number
     274      $Database->SQLCommand('SET @I = 0');
     275      $Database->SQLCommand('UPDATE ExportLanguage SET Sequence = (@I := @I + 1) WHERE Export='.$_GET['ExportId'].' ORDER BY Sequence;');
     276    }
     277  }
     278
     279  $Query = 'SELECT (@I := @I + 1) AS Sequence2, Sequence, language.Id, Name FROM language';
     280  $Query .=' LEFT JOIN ExportLanguage ON ExportLanguage.Export = '.$_GET['ExportId'].' AND ExportLanguage.Language=language.Id';
     281  $Query .=' WHERE language.Enabled = 1 ORDER BY COALESCE(Sequence, 100)';
     282
     283  $DbResult = $Database->SQLCommand('SELECT COUNT(*) FROM ('.$Query.') AS X');
     284  $DbRow = mysql_fetch_row($DbResult);
     285  $PageList = GetPageList($DbRow[0]);   
     286 
     287  $TableColumns = array(
     288    array('Name' => 'Name', 'Title' => 'Název'),
     289    array('Name' => '', 'Title' => 'Výběr'),
     290    array('Name' => 'Sequence2', 'Title' => 'Pořadí'),
     291  ); 
     292  $Order = GetOrderTableHeader($TableColumns, 'Name');
     293  echo('<form action="?Action=View&amp;ExportId='.$_GET['ExportId'].'&amp;Operation=Save" method="post">');
     294  echo('<h3>Jazyky</h3>');
     295  echo('<input type="submit" value="Uložit výběr" '.$DisabledInput[$Editable].'/><br />'.
     296   'Zvolte ze seznamu dostupných jazyků, ze kterých chcete sestavit překlady a upravte jejich pořadí.<br />'.
     297    'Pořadí řádků je dáno číselnou hodnotou, kterou lze změnit na požadované pořadí. Řádky se stejným pořadovým číslem budou přečíslovány vzestupně.');
     298
     299  echo($PageList['Output']);
     300  echo('<table class="BaseTable">');
     301  echo($Order['Output']);
     302
     303  $Query = 'SELECT * FROM ('.$Query.') AS TX '.$Order['SQL'].$PageList['SQLLimit'];
     304  $Database->SQLCommand('SET @I = 0');
     305  $DbResult = $Database->SQLCommand($Query);
     306  while($Langugage = mysql_fetch_assoc($DbResult))
     307  {
     308    $Checked = $Langugage['Sequence'] != '';
     309    $Selection = CheckBox('sel'.$Langugage['Id'], $Checked, '', 'CheckBox', !$Editable);
     310    $Sequence = '<input type="text" name="seq'.$Langugage['Id'].'" style="text-align: center; width: 40px;" value="'.$Langugage['Sequence2'].'"'.$DisabledInput[$Editable].'/>';
     311    echo('<tr>
     312    <td>'.$Langugage['Name'].'</a></td>
     313    <td>'.$Selection.'</td><td>'.$Sequence.'</td></tr>');
     314  }
     315  echo('</table>');
     316  echo('</form>');
     317  echo($PageList['Output']);
     318    } else echo('Položka nenalezena');
     319  } else echo('Nebylo zadáno Id');
     320}
     321
     322function ExportViewGroups()
     323{
     324  global $Database, $TranslationTree, $Config;
     325
     326  $DisabledInput = array(false => ' disabled="disabled"', true => '');
     327  if(array_key_exists('ExportId', $_GET))
     328  {
     329    $DbRows = $Database->SQLCommand('SELECT * FROM Export WHERE Id='.$_GET['ExportId']);
     330    if(mysql_num_rows($DbRows) > 0)
     331    {   
     332      $Export = mysql_fetch_assoc($DbRows);
     333      if(Licence(LICENCE_USER) and ($_SESSION['UserID'] == $Export['User'])) $Editable = true;
     334        else $Editable = false;
     335       
     336  if(array_key_exists('Operation', $_GET))
     337  {
     338    if($_GET['Operation'] == 'Save')
     339    {
     340      //print_r($_POST);
     341      // Update user selection page
     342      foreach($_POST as $Index => $Value)
    109343      {
    110       $result .= "'".$Line['Version']."',";
    111       }
    112     $result = substr($result,0,strlen($result)-1);
    113     $result .= "]";
    114   break;
    115     case 'Lua':
    116       $dirs = scandir('../source', 1);
    117     $result = '[';
    118     foreach($dirs as $dir) {
    119     $ok = true;
    120         foreach($TranslationTree as $Group)
     344        if(substr($Index, 0, 3) == 'seq')
    121345        {
    122           if(($Group['LuaFileName'] != '') and ($Group['TablePrefix'] != ''))
     346          $GroupId = substr($Index, 3) * 1;
     347          if(array_key_exists('sel'.$GroupId, $_POST)) $Selected = true;
     348            else $Selected = false;
     349          $Condition = ' WHERE `Export`='.$_GET['ExportId'].' AND `Group`='.$GroupId;
     350          $DbResult = $Database->SQLCommand('SELECT * FROM `ExportGroup` '.$Condition);
     351          if(mysql_num_rows($DbResult) > 0)
    123352          {
    124         if ((file_exists('../source/'.$dir.'/lua/'.$Group['LuaFileName'].'.lua') == false))
    125         $ok = false;
     353            if(!$Selected) $Database->SQLCommand('DELETE FROM `ExportGroup` '.$Condition);
     354          } else
     355          {
     356            if($Selected) $Database->SQLCommand('INSERT INTO `ExportGroup` (`Export`, `Group`) VALUES ('.$_GET['ExportId'].', '.$GroupId.')');
     357          }         
     358        }
    126359      }
    127360    }
    128     if ($ok) $result .= "'".$dir."',";
    129       }
    130     $result = substr($result,0,strlen($result)-1);
    131     $result .= "]";
    132   break;
    133   }
    134   return($result);
    135 }
    136 
    137 function WriteOption($str,$Selected)
    138 {
    139   if ($str <> 'null')
    140   {
    141     $str = substr($str, 2, strlen($str) - 4);
    142     $versions = explode("','", $str);
    143     foreach($versions as $version)
    144     {
    145       echo('<option value="'.$version.'"');
    146       if($Selected == $version) echo(' selected="selected"');
    147       echo('>'.$version.'</option>');
    148     }
    149   }
    150 }
    151 
    152 function WriteSetting($ExportSetting)
    153 {
    154   echo('<textarea rows="10" cols="100">'.serialize($ExportSetting).'</textarea><br />'.
    155   'Odkaz ke stažení s vlastním nastavením: '.
    156   '<a href="?action=output&amp;ExportSetting='.htmlspecialchars(serialize($ExportSetting)).'">Odkaz vlastního exportu</a><br />'.
    157   'I když se nastavení ukládá, pro jistotu si jej můžete uložit nebo poslat příteli.');
    158 }
    159 
    160 if(array_key_exists('ExportSetting', $_GET))
    161 {
    162   $ExportSetting = unserialize(stripcslashes(stripcslashes($_GET['ExportSetting'])));
    163 } else
    164 {
    165   if(array_key_exists('UserID', $_SESSION) and ($_SESSION['UserID'] != ''))
    166   {
    167     $DbResult = $Database->SQLCommand('SELECT ExportSetting FROM user WHERE ID='.$_SESSION['UserID']);
    168     $DbRow = mysql_fetch_assoc($DbResult);
    169     $ExportSetting = unserialize($DbRow['ExportSetting']);
    170 
    171     //print_r($_POST);
    172   } else $ExportSetting = unserialize($_SESSION['ExportSetting']);
    173 }
    174 if(!isset($ExportSetting['users-selection'])) $ExportSetting['users-selection'] = array();
    175 if(!isset($ExportSetting['Diacritics'])) $ExportSetting['Diacritics'] = 1;
    176 foreach($LanguageList as $Language)
    177   if($Language['Enabled'] == 1)
    178     if(!isset($ExportSetting['language'.$Language['Id']])) $ExportSetting['language'.$Language['Id']] = 1;
    179 if(!isset($ExportSetting['users-order'])) $ExportSetting['users-order'] = '';
    180 if(!isset($ExportSetting['Export'])) $ExportSetting['Export'] = 'Addon';
    181 if(!isset($ExportSetting['Version'])) $ExportSetting['Version'] = $Config['Web']['GameVersion'];
    182 if(!isset($ExportSetting['groups'])) $ExportSetting['groups'] = array();
    183 
    184 function CreateZipFromDir(&$Zip, $Path, $ZipPath)
    185 {
    186   //echo($Path.'<br />');
    187   $FileList = scandir($Path);
    188   foreach($FileList as $FileName)
    189   {
    190     if(file_exists($Path.$FileName) and ($FileName != '.') and ($FileName != '..'))
    191     {
    192       //echo($Path.$FileName.'<br />');
    193       if(is_dir($Path.$FileName)) CreateZipFromDir($Zip, $Path.$FileName.'/', $ZipPath.$FileName.'/');
    194         else $Zip->addFile(file_get_contents($Path.$FileName), $ZipPath.$FileName);
    195     }         
    196   }
    197 }
    198 
    199 if(!array_key_exists('action', $_GET)) $_GET['action'] = '';
    200 switch($_GET['action'])
    201 {
    202   case 'result':
    203     if (array_key_exists('Version',$_POST)) $ExportSetting['Version'] = $_POST['Version'];
    204     if (array_key_exists('Export',$_POST)) $ExportSetting['Export'] = $_POST['Export'];
    205     switch($ExportSetting['Export'])
    206     {
    207       case 'MangosSQLCompressed':
    208         if(function_exists('gzcompress'))
    209         {
    210           $TempDir = $Config['Web']['TempFolder'].$_SESSION['User'].'/';
    211           if(!file_exists($TempDir)) mkdir($TempDir, 0777, true);
    212           $SaveFilename = $TempDir.'CzWoW_SQL.zip';
    213           $SQLFilename = 'CzWoW_SQL.sql';       
    214           $BufferZip = ExportToMangosSQL($ExportSetting);
    215           $ZipFile = new zipfile();
    216           $ZipFile->addFile($BufferZip, $SQLFilename);
    217           $Buffer = $ZipFile->file();
    218           file_put_contents($SaveFilename, $Buffer);
    219         } else echo('Funkce pro tvorbu Zip souboru není podporována!');
    220         echo('<script type="text/javascript" language="JavaScript" charset="utf-8">'.
    221           'setTimeout("parent.location.href=\''.$SaveFilename.'\'", 3000)'.
    222           '</script>');
    223      
    224         echo('Pokud nezačalo stahování, soubor by mělo jít stáhnout pomocí tohoto odkazu: '.
    225           '<a href="'.$SaveFilename.'">'.$SQLFilename.'</a><br />'.
    226           'Pokud se vám zdá, že filtr na export nefunguje, vymažte si vyrovnávací paměť prohlížeče a zkuste stáhnout soubor znovu.');
    227         break;
    228       case 'MangosSQLDirect':
    229         echo('Vygenerovaný SQL kód: <br /><pre class="SQLCode">');
    230         echo(htmlspecialchars(ExportToMangosSQL($ExportSetting)));
    231         echo('</pre>');
    232         break;
    233       case 'AoWoWSQLCompressed':
    234         if(function_exists('gzcompress'))
    235         {
    236           $TempDir = $Config['Web']['TempFolder'].$_SESSION['User'].'/';
    237           if(!file_exists($TempDir)) mkdir($TempDir, 0777, true);
    238           $SaveFilename = $TempDir.'CzAoWoW_SQL.zip';
    239           $SQLFilename = 'CzAoWoW_SQL.sql';       
    240           $BufferZip = ExportToAoWoWSQL($ExportSetting);
    241           $ZipFile = new zipfile();
    242           $ZipFile->addFile($BufferZip, $SQLFilename);
    243           $Buffer = $ZipFile->file();
    244           file_put_contents($SaveFilename, $Buffer);
    245         } else echo('Funkce pro tvorbu Zip souboru není podporována!');
    246         echo('<script type="text/javascript" language="JavaScript" charset="utf-8">'.
    247           'setTimeout("parent.location.href=\''.$SaveFilename.'\'", 3000)'.
    248           '</script>');
    249      
    250         echo('Pokud nezačalo stahování, soubor by mělo jít stáhnout pomocí tohoto odkazu: '.
    251           '<a href="'.$SaveFilename.'">'.$SQLFilename.'</a><br />'.
    252           'Pokud se vám zdá, že filtr na export nefunguje, vymažte si vyrovnávací paměť prohlížeče a zkuste stáhnout soubor znovu.');
    253         break;
    254       case 'AoWoWSQLDirect':
    255         echo('Vygenerovaný SQL kód: <br /><pre class="SQLCode">');
    256         echo(htmlspecialchars(ExportToAoWoWSQL($ExportSetting)));
    257         echo('</pre>');
    258         break;
    259       case 'AoWoWImport':
    260         require_once('../aowow/configs/config.php');
    261       echo('<div style="font-size: xx-small;">');
    262         echo('Gewneruji SQL kód ');
    263         $AoWoWSQL = ExportToAoWoWSQL($ExportSetting);
    264         echo('<strong>Hotovo</strong><br />');
    265 
    266         $Database->SelectDatabase($AoWoWconf['mangos']['db']);   
    267         $Database->SQLCommand('SET NAMES '.$Config['Database']['Charset']);
     361  }
     362
     363  $Query = 'SELECT `group`.*, `ExportGroup`.`Id` AS `ExportGroupId` FROM `group` LEFT JOIN `ExportGroup` ON `ExportGroup`.`Export`='.$_GET['ExportId'].' AND `Group`=`group`.`Id`';
     364
     365  $DbResult = $Database->SQLCommand('SELECT COUNT(*) FROM ('.$Query.') AS X');
     366  $DbRow = mysql_fetch_row($DbResult);
     367  $PageList = GetPageList($DbRow[0]);   
     368 
     369  $TableColumns = array(
     370    array('Name' => 'Name', 'Title' => 'Jméno'),
     371    array('Name' => 'MangosTable', 'Title' => 'Tabulka MaNGOSu'),
     372    array('Name' => 'DBCFileName', 'Title' => 'DBC soubor'),
     373    array('Name' => 'LuaFileName', 'Title' => 'Lua soubor'),
     374    array('Name' => '', 'Title' => 'Výběr'),
     375  ); 
     376  $Order = GetOrderTableHeader($TableColumns, 'Name');
     377  echo('<form action="?Action=View&amp;ExportId='.$_GET['ExportId'].'&amp;Operation=Save" method="post">');
     378  echo('<h3>Překladové skupiny</h3>');
     379  echo('<input type="submit" value="Uložit výběr" '.$DisabledInput[$Editable].'/><br />'.
     380   'Zvolte ze překladových skupin, ze kterých chcete načítat překlady.<br />');
     381
     382  echo($PageList['Output']);
     383  echo('<table class="BaseTable">');
     384  echo($Order['Output']);
     385
     386  $Query = 'SELECT * FROM ('.$Query.') AS TX '.$Order['SQL'].$PageList['SQLLimit'];
     387  $DbResult = $Database->SQLCommand($Query);
     388  while($Group = mysql_fetch_assoc($DbResult))
     389  {
     390    $Checked = $Group['ExportGroupId'] != '';
     391    $Selection = CheckBox('sel'.$Group['Id'], $Checked, '', 'CheckBox', !$Editable);
     392    echo('<tr>'.
     393    '<td>'.$Group['Name'].'</td>'.
     394    '<td>'.$Group['MangosTable'].'</td>'.
     395    '<td>'.$Group['DBCFileName'].'</td>'.
     396    '<td>'.$Group['LuaFileName'].'</td>'.
     397    '<td>'.$Selection.'<input type="hidden" name="seq'.$Group['Id'].'"/></td></tr>');
     398  }
     399  echo('</table>');
     400  echo('</form>');
     401  echo($PageList['Output']);
     402    } else echo('Položka nenalezena');
     403  } else echo('Nebylo zadáno Id');
     404}
     405
     406function ExportViewOutputFormat()
     407{
     408  global $Database;
     409 
     410  $DisabledInput = array(false => ' disabled="disabled"', true => '');
     411  if(array_key_exists('ExportId', $_GET))
     412  {
     413    $DbRows = $Database->SQLCommand('SELECT * FROM Export WHERE Id='.$_GET['ExportId']);
     414    if(mysql_num_rows($DbRows) > 0)
     415    {   
     416      $Export = mysql_fetch_assoc($DbRows);
     417      if(Licence(LICENCE_USER) and ($_SESSION['UserID'] == $Export['User'])) $Editable = true;
     418        else $Editable = false;
     419 
     420  if(array_key_exists('OutputType', $_POST))
     421  {
     422    $Database->SQLCommand('UPDATE Export SET OutputType='.$_POST['OutputType'].' WHERE Id='.$_GET['ExportId']);
     423  }
     424
     425  $DbResult = $Database->SQLCommand('SELECT * FROM Export WHERE Id='.$_GET['ExportId']);
     426  $Export = mysql_fetch_assoc($DbResult);
     427 
     428  echo('<h3>Formát generovaného výstupu</h3>');
     429  echo('<form action="?Action=View&amp;ExportId='.$_GET['ExportId'].'&amp;Operation=Save" method="post">');
     430  echo('<input type="submit" value="Uložit" '.$DisabledInput[$Editable].'/><br/>');
     431  $DbResult = $Database->SQLCommand('SELECT * FROM ExportOutputType ORDER BY Name');
     432  while($ExportFormat = mysql_fetch_assoc($DbResult))
     433  {
     434    echo(RadioButton('OutputType', $ExportFormat['Id'], $Export['OutputType'] == $ExportFormat['Id'], '', !$Editable).' '.$ExportFormat['Name'].'<br/>');
     435  }
     436  echo('</form>');
     437    } else echo('Položka nenalezena');
     438  } else echo('Nebylo zadáno Id');
     439}
     440
     441function ExportViewVersion()
     442{
     443  global $Database, $Config;
     444
     445  $DisabledInput = array(false => ' disabled="disabled"', true => '');
     446  if(array_key_exists('ExportId', $_GET))
     447  {
     448    $DbRows = $Database->SQLCommand('SELECT * FROM Export WHERE Id='.$_GET['ExportId']);
     449    if(mysql_num_rows($DbRows) > 0)
     450    {   
     451      $Export = mysql_fetch_assoc($DbRows);
     452      if(Licence(LICENCE_USER) and ($_SESSION['UserID'] == $Export['User'])) $Editable = true;
     453        else $Editable = false;
    268454       
    269         echo('Aktualizuji aktuality ');
    270         $Database->SQLCommand("UPDATE `aowow_news` SET `text_loc0` = 'Poslední aktualizace dat ".Date ("d. n. Y, H:i:s")." ', `text_loc8` = 'Poslední aktualizace dat ".Date ("d. n. Y, H:i:s")." ' WHERE `aowow_news`.`id` =3");
    271         echo('<strong>Hotovo</strong><br />');
    272 
    273         echo('Mažu dočasné soubory ');
    274         $files = scandir('../aowow/cache/mangos');
    275         foreach($files as $file)
    276         {
    277           $end = substr($file, strlen($file) - 3);
    278           if($end == 'aww') unlink('../aowow/cache/mangos/'.$file);
    279         }
    280         $files = scandir('../aowow/cache/templates/wowhead');
    281         foreach($files as $file)
    282         {
    283           $end = substr($file, strlen($file) - 3);
    284           if ($end == 'php') unlink('../aowow/cache/templates/wowhead/'.$file);
    285         }
    286         echo ('<strong>Hotovo</strong><br />');
    287 
    288         echo('Importuji do AoWoW ');
    289         $BufferArray = explode(";\n", $AoWoWSQL);
    290         foreach($BufferArray as $Line)
    291         {
    292           if($Line <> '') $Database->SQLCommand($Line);
    293           echo('. ');
    294         }   
    295         echo('<strong>Hotovo</strong><br />');
    296    
    297         // TODO   aowow_itemenchantmet, aowow_char_titles, aowow_factions, aowow_itemset, aowow_spelldispeltype, aowow_spellmechanic, aowow_spellrange, aowow_zones
    298        
    299         $Database->SelectDatabase($Config['Database']['Database']);   
    300         $Database->SQLCommand('SET NAMES '.$Config['Database']['Charset']);
    301     echo('</div>');
    302         WriteLog('Plnění AoWoW databáze překladem', 4);
    303         break;
    304       case 'XMLCompressed':
    305         if(function_exists('gzcompress'))
    306         {
    307           $TempDir = $Config['Web']['TempFolder'].$_SESSION['User'].'/';
    308           if(!file_exists($TempDir)) mkdir($TempDir, 0777, true);
    309           $SaveFilename = $TempDir.'CzWoW_XML.zip';
    310           $SQLFilename = 'CzWoW_XML.sql';       
    311           $BufferZip = ExportToXML($ExportSetting);
    312           $ZipFile = new zipfile();
    313           $ZipFile->addFile($BufferZip, $SQLFilename);
    314           $Buffer = $ZipFile->file();
    315           file_put_contents($SaveFilename, $Buffer);
    316         } else echo('Funkce pro tvorbu Zip souboru není podporována!');
    317         echo('<script type="text/javascript" language="JavaScript" charset="utf-8">'.
    318           'setTimeout("parent.location.href=\''.$SaveFilename.'\'", 3000)'.
    319           '</script>');
    320      
    321         echo('Pokud nezačalo stahování, soubor by mělo jít stáhnout pomocí tohoto odkazu: '.
    322           '<a href="'.$SaveFilename.'">CzWoW_SQL.zip</a><br />'.
    323           'Pokud se vám zdá, že filtr na export nefunguje, vymažte si vyrovnávací paměť prohlížeče a zkuste stáhnout soubor znovu.');
    324         break;
    325     case 'XMLDirect':
    326         echo('Vygenerované XML: <br /><pre class="SQLCode">');
    327         echo(htmlspecialchars(ExportToXML($ExportSetting)));
    328         echo('</pre>');
    329         break;
    330     /*case 'Server':
    331       if(Licence(LICENCE_ADMIN))
    332     {
    333       $Buffer = ExportToMangosSQL($ExportSetting);
    334           $Database->SelectDatabase($Config['Database']['DatabaseMangos']);   
    335           $BufferArray = explode("\n", $Buffer);
    336       echo('Přenášení dat do serveru...<br />');
    337           foreach($BufferArray as $Line)
    338           {
    339       $Database->SQLCommand($Line);
    340       echo('.');
    341       }
    342           echo("<br />Hotovo<br />");
    343     } else echo('Nemáte oprávnění.');
    344       break;*/
    345     case 'Addon':
    346       if(function_exists('gzcompress')) {
    347               $TempDir = $Config['Web']['TempFolder'].$_SESSION['User'].'/CzWoW-'.$ExportSetting['Version'].'/';
    348             echo('Generování addonu...'.$ExportSetting['Export'].'<br />');
    349               MakeAddon($ExportSetting);
    350               $SaveFilename = $Config['Web']['TempFolder'].$_SESSION['User'].'/CzWoW_Addon-'.$ExportSetting['Version'].'.zip';         
    351               $Zip = new zipfile();
    352           CreateZipFromDir($Zip, $TempDir, 'CzWoW/');
    353               $Zip->addFile(file_get_contents('files/'.$ExportSetting['Version'].'/CzWoW/OptionsFrame.xml'), 'CzWoW/OptionsFrame.xml');
    354               $Zip->addFile(file_get_contents('files/'.$ExportSetting['Version'].'/CzWoW/CzWoW.xml'), 'CzWoW/CzWoW.xml');
    355           $Zip->addFile(file_get_contents('files/'.$ExportSetting['Version'].'/CzWoW/CzWoW.toc'), 'CzWoW/CzWoW.toc');
    356               $Zip->addFile(file_get_contents('files/'.$ExportSetting['Version'].'/CzWoW/CzWoW.lua'), 'CzWoW/CzWoW.lua');
    357           $Zip->addFile(file_get_contents('files/'.$ExportSetting['Version'].'/CzWoW/GameMenuFrame.xml'), 'CzWoW/GameMenuFrame.xml');
    358           $Zip->addFile(file_get_contents('files/'.$ExportSetting['Version'].'/CzWoW/Localization.lua'), 'CzWoW/Localization.lua');
    359           $Buffer = $Zip->file();
    360               file_put_contents($SaveFilename, $Buffer);
    361             echo('Hotovo<br /><br />');
    362           } else echo('Funkce pro tvorbu Zip souboru není podporována!');
    363             echo('<script type="text/javascript" language="JavaScript" charset="utf-8">'.
    364               'setTimeout("parent.location.href=\''.$SaveFilename.'\'", 3000)'.
    365               '</script>');
    366      
    367             echo('Pokud nezačalo stahování, soubor by mělo jít stáhnout pomocí tohoto odkazu: '.
    368               '<a href="'.$SaveFilename.'">CzWoW_Addon-'.$ExportSetting['Version'].'.zip</a><br />'.
    369               'Pokud se vám zdá, že filtr na export nefunguje, vymažte si vyrovnávací paměť prohlížeče a zkuste stáhnout soubor znovu.');
    370         echo('<br /><strong>Použití ve hře</strong><br />Menu addonu ve hře vyvoláte povelem /czwow.');
    371       break;
    372     case 'VerseCZ':
    373         if(function_exists('gzcompress'))
    374         {
    375           $Line = mysql_fetch_assoc($Database->SQLCommand('SELECT verse FROM verseclient ORDER BY DATE DESC LIMIT 1'));
    376           $TempDir = $Config['Web']['TempFolder'].'Addon/CzWoW/';
    377         echo('Generování addonu...<br />');
    378           MakeAddon($ExportSetting);
    379           MakeReadme($ExportSetting);
    380 
    381           $SaveFilename = $Config['Web']['TempFolder'].'Addon/CzWoW_'.$Line['verse'].'.zip';         
    382           $Zip = new zipfile();
    383       CreateZipFromDir($Zip, $TempDir, 'Interface/AddOns/CzWoW/');
    384           //addon
    385           $Zip->addFile(file_get_contents('files/'.$ExportSetting['Version'].'/CzWoW/OptionsFrame.xml'), 'Interface/AddOns/CzWoW/OptionsFrame.xml'); 
    386           $Zip->addFile(file_get_contents('files/'.$ExportSetting['Version'].'/CzWoW/CzWoW.xml'), 'Interface/AddOns/CzWoW/CzWoW.xml'); 
    387       $Zip->addFile(file_get_contents('files/'.$ExportSetting['Version'].'/CzWoW/CzWoW.toc'), 'Interface/AddOns/CzWoW/CzWoW.toc'); 
    388           $Zip->addFile(file_get_contents('files/'.$ExportSetting['Version'].'/CzWoW/CzWoW.lua'), 'Interface/AddOns/CzWoW/CzWoW.lua'); 
    389       $Zip->addFile(file_get_contents('files/'.$ExportSetting['Version'].'/CzWoW/GameMenuFrame.xml'), 'Interface/AddOns/CzWoW/GameMenuFrame.xml'); 
    390       $Zip->addFile(file_get_contents('files/'.$ExportSetting['Version'].'/CzWoW/Localization.lua'), 'Interface/AddOns/CzWoW/Localization.lua'); 
    391       //fonty
    392           $Zip->addFile(file_get_contents('files/'.$ExportSetting['Version'].'/Fonts/FRIZQT__.ttf'), 'Fonts/FRIZQT__.ttf');
    393           $Zip->addFile(file_get_contents('files/'.$ExportSetting['Version'].'/Fonts/MORPHEUS.ttf'), 'Fonts/MORPHEUS.ttf');
    394           $Zip->addFile(file_get_contents('files/'.$ExportSetting['Version'].'/Fonts/SKURRI.ttf'), 'Fonts/SKURRI.ttf');
    395           //readme
    396           $Zip->addFile(file_get_contents($Config['Web']['TempFolder'].'Addon/CzWoW/CZWOW-Readme.txt'), 'CZWOW-Readme.txt'); 
    397                
    398       $Buffer = $Zip->file();
    399           file_put_contents($SaveFilename, $Buffer);
    400              WriteLog('Vytvořena verze češtiny pro clienta '.$Line['verse'], 4);
    401 
    402         echo('Hotovo<br /><br />');
    403         } else echo('Funkce pro tvorbu Zip souboru není podporována!');
    404              
    405         echo('Odkaz ke stažení: '.
    406           '<a href="'.$SaveFilename.'">'.$SaveFilename.'</a><br />');
    407       break;
    408     case 'DBC':
    409    
    410       echo('<br /><br /><br />U dbc souborů export textů funguje jinak, protože generování je náročné na výpočet provádí se přes noc kdy je server nejmíň vytížen. Nyní jste zadali úlohu, která se provede v noci. Zítra si můžete stáhnout vygenerovaný soubor v sekci <a href="../download.php">Stahování</a>.<br /><br />Dbc soubory je nutné zabalit do souboru patch-enGB-5.MPQ uvnitř složky "DBFilesClient" a hru spouštět přes wowme.exe. Zabalit to můžete pomocí programu <a href="../download/mpqediten32.zip">Ladik\'s MPQ Editor</a>. Stav vygenerování můžete sledovat na stránce <a href="../download.php">Stahování</a>, kde si také můžete zítra stáhnout soubor.<br /><br />');
    411    
    412           //TODO: pouze jedna aktivní úloha na uživatele
    413         $sql = 'SELECT * FROM tasks WHERE Active = 1 AND User = '.$_SESSION['UserID'];
    414         $ID = $Database->SQLCommand($sql);
    415     if (mysql_num_rows($ID) > 0)
    416     {
    417       echo ('Nemůžete zadat stejný požadavek dvakrát za den. Bylo pouze aktualizováno nastavení exportu!');
    418           $Database->SQLCommand('UPDATE `wowpreklad`.`tasks` SET `ExportSetting` = "'.addslashes(serialize($ExportSetting)).'" WHERE Active = 1 AND User = '.$_SESSION['UserID']);
    419       } else {
    420           $Database->SQLCommand('INSERT INTO `wowpreklad`.`tasks` (`User` ,`ExportSetting` ,`Date` ) VALUES ("'.$_SESSION['UserID'].'", "'.addslashes(serialize($ExportSetting)).'", NOW( ))');
    421     }
    422     WriteLog('Zadání úlohy pro vygenerování dbc souboru', 2);
    423      
    424    
    425     /*
    426         if(function_exists('gzcompress'))
    427         {
    428           $TempDir = $Config['Web']['TempFolder'].$_SESSION['User'].'/dbc/';
    429         echo('Generování dbc souborů...<br />');
    430           ExportToDBC($ExportSetting);
    431           $SaveFilename = $Config['Web']['TempFolder'].$_SESSION['User'].'/CzWoW_DBC.zip';         
    432           $Zip = new zipfile();
    433         CreateZipFromDir($Zip, $TempDir, 'DBCClientFiles/');
    434           $Buffer = $Zip->file();
    435           file_put_contents($SaveFilename, $Buffer);
    436         echo('Hotovo<br /><br />');
    437         } else echo('Funkce pro tvorbu Zip souboru není podporována!');
    438         echo('<script type="text/javascript" language="JavaScript" charset="utf-8">'.
    439           'setTimeout("parent.location.href=\''.$SaveFilename.'\'", 3000)'.
    440           '</script>');
    441      
    442         echo('Pokud nezačalo stahování, soubor by mělo jít stáhnout pomocí tohoto odkazu: '.
    443           '<a href="'.$SaveFilename.'">CzWoW_DBC.zip</a><br />'.
    444           'Pokud se vám zdá, že filtr na export nefunguje, vymažte si vyrovnávací paměť prohlížeče a zkuste stáhnout soubor znovu.');
    445     echo('<br /><br /><strong>Použití ve hře</strong><br />Ze souborů vytvořte MPQ archív a nahrajte ho do hry do podsložky Data/enUS jako patch-enUS-5.MPQ. Hru spusťte pomocí programu WoWMe.exe (WoW Model Editor Fix).');
    446     */
    447    
    448       break;
    449     case 'Lua':
    450         if(function_exists('gzcompress'))
    451         {
    452           $TempDir = $Config['Web']['TempFolder'].$_SESSION['User'].'/lua/';
    453         echo('Generování lua souborů...<br />');
    454           ExportToLUA($ExportSetting);
    455           $SaveFilename = $Config['Web']['TempFolder'].$_SESSION['User'].'/CzWoW_Lua.zip';         
    456           $Zip = new zipfile();
    457         CreateZipFromDir($Zip, $TempDir, '');
    458           $Buffer = $Zip->file();
    459           file_put_contents($SaveFilename, $Buffer);
    460         echo('Hotovo<br /><br />');
    461         } else echo('Funkce pro tvorbu Zip souboru není podporována!');
    462         echo('<script type="text/javascript" language="JavaScript" charset="utf-8">'.
    463           'setTimeout("parent.location.href=\''.$SaveFilename.'\'", 3000)'.
    464           '</script>');
    465      
    466         echo('Pokud nezačalo stahování, soubor by mělo jít stáhnout pomocí tohoto odkazu: '.
    467           '<a href="'.$SaveFilename.'">CzWoW_Lua.zip</a><br />'.
    468           'Pokud se vám zdá, že filtr na export nefunguje, vymažte si vyrovnávací paměť prohlížeče a zkuste stáhnout soubor znovu.');
    469     echo('<br /><br /><strong>Použití ve hře</strong><br />Ze souborů vytvořte MPQ archív a nahrajte ho do hry do podsložky Data/enUS jako patch-enUS-5.MPQ. Hru spusťte pomocí programu WoWMe.exe (WoW Model Editor Fix).');
    470       break;
    471   }     
    472     //statistika výstupu
    473     if ($ExportSetting['Export'] <> 'AoWoWSQLDirect' and $ExportSetting['Export'] <> 'XMLDirect' and $ExportSetting['Export'] <> 'AoWoWImport' and $ExportSetting['Export'] <> 'MangosSQLDirect') {
    474       echo '<br /><br />';
    475           foreach($TranslationTree as $Group)
    476           if($Group['TablePrefix'] != '' and (in_array($Group['Id'], $ExportSetting['groups'])))
    477           echo('<div class="state-image"><img alt="'.$Group['TablePrefix'].'" src="../img_statistic.php?group='.$Group['Id'].'&amp;user='.$_SESSION['UserID'].'" title="statistika překladů '.$Group['Name'].'"/></div>');
    478         }
    479    
    480   WriteLog('Generování SQL výstupu: Typ exportu: <strong>'.$ExportSetting['Export'].'</strong>, Diakritika: <strong>'.$ExportSetting['Diacritics'].'</strong>', 2);
    481     break;
    482   case 'output':
    483     if(array_key_exists('groups', $_POST)) $ExportSetting['groups'] = $_POST['groups'];
    484     $ExportSetting['Diacritics'] = array_key_exists('Diacritics', $_POST);
    485     foreach($LanguageList as $Language)
    486       if($Language['Enabled'] == 1)
    487         $ExportSetting['language'.$Language['Id']] = array_key_exists('language'.$Language['Id'], $_POST);
    488    
    489     if(array_key_exists('ExportSetting', $_GET))
    490       $ExportSetting = unserialize(stripcslashes(stripcslashes($_GET['ExportSetting'])));
    491 
    492     echo('<strong>Krok 3. - Typ výstupu</strong><br /><br />');
    493     echo('<form action="?action=result" method="post"><div>'.
    494       '<table><tr><td>'.
    495       '<fieldset><legend>Forma výstupu</legend>'.
    496       RadioButton('Export', 'MangosSQLDirect', $ExportSetting['Export'] == 'MangosSQLDirect', 'UpdateVersion('.GetVersions('MangosSQLDirect').',\''.$ExportSetting['Version'].'\')').'MaNGOS SQL - přímo zobrazit<br />'.
    497     RadioButton('Export', 'MangosSQLCompressed', $ExportSetting['Export'] == 'MangosSQLCompressed', 'UpdateVersion('.GetVersions('MangosSQLCompressed').',\''.$ExportSetting['Version'].'\')').'MaNGOS SQL - komprimovaný soubor<br />'.
    498     RadioButton('Export', 'AoWoWSQLDirect', $ExportSetting['Export'] == 'AoWoWSQLDirect', 'UpdateVersion('.GetVersions('AoWoWSQLDirect').',\''.$ExportSetting['Version'].'\')').'AoWoW SQL - přímo zobrazit<br />'.
    499     RadioButton('Export', 'AoWoWSQLCompressed', $ExportSetting['Export'] == 'AoWoWSQLCompressed', 'UpdateVersion('.GetVersions('AoWoWSQLCompressed').',\''.$ExportSetting['Version'].'\')').'AoWoW SQL - komprimovaný soubor<br />'.
    500       RadioButton('Export', 'XMLDirect', $ExportSetting['Export'] == 'XMLDirect', 'UpdateVersion('.GetVersions('XMLDirect').',\''.$ExportSetting['Version'].'\')').'XML - přímo zobrazit<br />'.
    501     RadioButton('Export', 'XMLCompressed', $ExportSetting['Export'] == 'XMLCompressed', 'UpdateVersion('.GetVersions('XMLCompressed').',\''.$ExportSetting['Version'].'\')').'XML - komprimovaný soubor<br />'.
    502     RadioButton('Export', 'Addon', $ExportSetting['Export'] == 'Addon', 'UpdateVersion('.GetVersions('Addon').',\''.$ExportSetting['Version'].'\')').'Addon - komprimovaný soubor<br />'.
    503     RadioButton('Export', 'Lua', $ExportSetting['Export'] == 'Lua', 'UpdateVersion('.GetVersions('Lua').',\''.$ExportSetting['Version'].'\')').'Lua skripty - komprimovaný soubor<br />');
    504       if(Licence(LICENCE_USER)) {
    505           echo(RadioButton('Export', 'DBC', $ExportSetting['Export'] == 'DBC', 'UpdateVersion('.GetVersions('DBC').',\''.$ExportSetting['Version'].'\')').'DBC - komprimovaný soubor (pouze přihlášení)<br />');
    506     } else {
    507       echo ('  <span style="padding: 20px"> Pro export do souborů dbc musíte být přihlášen</span>');
    508     }
    509       if(Licence(LICENCE_ADMIN)) {
    510        //   echo(RadioButton('Export', 'DBC', $ExportSetting['Export'] == 'DBC', 'UpdateVersion('.GetVersions('DBC').',\''.$ExportSetting['Version'].'\')').'DBC - komprimovaný soubor (pouze admin)<br />');
    511           echo(RadioButton('Export', 'AoWoWImport', $ExportSetting['Export'] == 'AoWoWImport', 'UpdateVersion('.GetVersions('AoWoWImport').',\''.$ExportSetting['Version'].'\')').'Importovat do AoWoW (pouze admin)<br />');
    512         echo(RadioButton('Export', 'VerseCZ', $ExportSetting['Export'] == 'VerseCZ', 'UpdateVersion('.GetVersions('VerseCZ').',\''.$ExportSetting['Version'].'\')').'Vytvoření verze češtiny <a href="../download.php?createverse" Title="Před konečným exportováním napište popis k verzi" Target="_NEW">Popis k verzi</a> (pouze admin)<br />');
    513       }
    514     //echo('
    515     echo('</fieldset>');
    516     echo('<fieldset><legend>Dostupné verze výstupu</legend>');
    517   echo('<select id="Version" size="5" name="Version">');
    518   WriteOption(GetVersions($ExportSetting['Export']),$ExportSetting['Version']);
    519     echo('</select></fieldset>');
    520   echo('</td>');
    521   echo('<td class="Description">Zvolte způsob, jakým mají být získána výstupní data. V případě přímého zobrazení může být do vašeho prohlížeče přenášeno vysoké množství dat, což může vést k jeho přetížení.<br /><br />Poté zvolte pro kterou verzi hry mají být data získána. Pokud verze není přesná zvolte nejbližší.<br /><br />Addon je potřeba nakopírovat do složky klienta Interface/AddOns a ve hře lze zpřístupnit jeho možnosti pomocí příkazu /czwow.<br />');
    522   echo('</td></tr></table>');
    523   echo('<br /><input type="submit" value="Dokončit" />');
    524   echo('</div></form><br />');
    525   echo('<fieldset><legend>Nastavení exportu pro zálohování</legend>');
    526   WriteSetting($ExportSetting);   
    527   echo ('</fieldset>');
    528   break;
    529   case 'parameters':
    530     $ExportSetting['users-order'] = $_POST['users-order'];
    531     $ExportSetting['users-selection'] = array();
    532     $UsersList = explode(',', $_POST['users-order']);
    533   foreach($UsersList as $Index => $Item)
    534   {
    535     if(array_key_exists('user_'.$Item, $_POST)) $ExportSetting['users-selection'][] = $Item;
    536   }
    537   //if(array_key_exists('users', $_POST)) $ExportSetting['users'] = $_POST['users'];
    538     echo('<strong>Krok 2. - Volba parametrů</strong><br /><br />');
    539     echo('<form action="?action=output" method="post"><div>');
    540   echo('<table><tr><td>');
    541     echo('<fieldset><legend>Jazyk</legend>'.
    542       CheckBox('Diacritics', $ExportSetting['Diacritics'] == 'checked').'Včetně diakritiky<br /><br />'); 
    543     //echo('<input type="checkbox" name="Use" checked="true">Přidat výchovýběr databáze.<br />');
    544 
    545     foreach($LanguageList as $Language)
    546     if($Language['Enabled'] == 1)
    547       echo(CheckBox('language'.$Language['Id'], $ExportSetting['language'.$Language['Id']] == 'checked').$Language['Name'].'<br />');
    548      
    549     echo('</fieldset><br /></td><td class="Description">Pro správné zobrazení českých znaků ve hře je nutné používat upravené <a href="download/ceske_fonty_do_wow.zip">počeštěné fonty</a>.<br />Vyberte jaké jazyky se mají uvažovat při exportu.</td></tr><tr><td><fieldset><legend>Skupiny textů</legend>');
    550     echo('<select name="groups[]" size="15" multiple="multiple">');
    551     foreach($TranslationTree as $Group)
    552       if($Group['TablePrefix'] != '')
    553         echo(SelectOption($Group['Id'], $Group['Name'].' ('.$Group['TablePrefix'].')', in_array($Group['Id'], $ExportSetting['groups'])));
    554 
    555   echo('</select></fieldset><br /></td><td class="Description">Vyberte skupiny textů, z kterých bude sestaven export. Přidržením CTRL nebo SHIFT můžete provádět výběr více položek.</td></tr></table><input type="submit" value="Pokračovat" />');
    556   echo('</div></form>');
    557     break;
    558   default:
    559     echo('<strong>Krok 1. - Výběr překladatelů</strong><br /><br />');
    560   echo('<script type="text/javascript" src="'.$Config['Web']['BaseURL'].'style/jquery.js"></script>
    561 <script type="text/javascript" src="'.$Config['Web']['BaseURL'].'style/jquery-ui.js"></script>
    562 <script type="text/javascript">
    563 $(document).ready(function()
    564 {
    565   $("#users-table").sortable({ items: "tr", sort: SortComplete }); 
    566   $("#users-order").val($("#users-table").sortable(\'toArray\'));
    567 });
    568 
    569 function SortComplete()
    570 {
    571   $("#users-order").val($("#users-table").sortable(\'toArray\'));
    572 }
    573 </script>');
    574     echo('<form id="ListUser" action="?action=parameters" method="post"><div>');
    575 
    576     $Columns = '';
    577     $Joins = '';
    578 
    579   //řezení podle odkazu
    580     if(array_key_exists('Order', $_GET)) $order = $_GET['Order'];
    581     else  $order = 'T.TranslatedCount';
    582     if(array_key_exists('Desc', $_GET)) $desc = $_GET['Desc'];
    583     else  $desc = '';
    584     if($desc == '') $desc = 'DESC'; else $desc = '';
    585    
    586     foreach($TranslationTree as $Group)
    587       if($Group['TablePrefix'] != '')
    588       {
    589       $Columns .= 'COALESCE(T'.$Group['Id'].'.Count, 0) + ';
    590         $Joins .= ' LEFT JOIN (SELECT User, COUNT(User) as Count FROM `'.$Group['TablePrefix'].'` WHERE (Complete = 1) AND (Language <> 0) GROUP BY User) as T'.$Group['Id'].' ON user.ID=T'.$Group['Id'].'.User';
    591       }
    592     $Query = 'SELECT T.ID, T.TranslatedCount, T.user, T.XP FROM (SELECT user.ID, user.user, user.XP, ('.substr($Columns, 0, -3).') as TranslatedCount FROM `user`'.$Joins.') AS T WHERE T.TranslatedCount > 0 ORDER BY '.$order.' '.$desc;
    593     $ID = $Database->SQLCommand($Query);
    594 
    595   // Rebuild user order list
    596   $Users = array();
    597   while($Line = mysql_fetch_assoc($ID)) {
    598      $Users[$Line['ID']] = $Line;
    599      $UsersOrder[] = $Line['ID'];
    600   }
    601   //řazení podle posledního použitého
    602   if(!array_key_exists('Order', $_GET)) {
    603     $UsersOrder = explode(',', $ExportSetting['users-order']);
    604     foreach($Users as $User)
    605         if(!in_array($User['ID'], $UsersOrder)) $UsersOrder[] = $User['ID'];
    606     foreach($UsersOrder as $Index => $UserId)
    607         if(!array_key_exists($UserId, $Users)) unset($UsersOrder[$Index]);
    608   }
    609   $ExportSetting['users-order'] = implode(',', $UsersOrder);
    610 
    611   if(array_key_exists('team', $_GET)) {
    612     $ExportSetting['users-selection'] = array();
    613     $Query = 'SELECT ID FROM user WHERE team = '.$_GET['team'];
    614         $ID = $Database->SQLCommand($Query);
    615         while($LineTeam = mysql_fetch_assoc($ID))
    616       $ExportSetting['users-selection'][] = $LineTeam['ID'];
    617   }
    618 
    619 
    620   echo(' <input type="submit" value="Pokračovat" /> <span onclick="CheckAll()">'.CheckBox('CheckAll', False, 'CheckAll').' Zatrhnout vše</span> ');
    621  
    622   echo('<table><tr><td>'.
    623   '<table class="BaseTable" id="users-table"><tr>
    624   <th><a href="?Order=user&amp;Desc='.$desc.'">Jméno</a></th>
    625   <th><a href="?Order=T.TranslatedCount&amp;Desc='.$desc.'" title="Počet přeložených textů">Překladů</a></th>
    626     <th><a href="?Order=XP&amp;Desc='.$desc.'">Úroveň</a></th>
    627   <th></th></tr>');
    628   //print_r($UsersOrder);   
    629   // Show ordered user list 
    630     foreach($UsersOrder as $UserId)
    631     echo('<tr id="'.$UserId.'">
    632     <td><a href="'.$Config['Web']['BaseURL'].'/TranslationList.php?user='.$UserId.'&amp;action=userall" title="Zobrazit všechny jeho přeložené texty">'.$Users[$UserId]['user'].'</a></td>
    633     <td>'.$Users[$UserId]['TranslatedCount'].'</td>
    634       <td><img src="'.$Config['Web']['TempFolder'].$Users[$UserId]['user'].'/level.png" alt="Úroveň uživatele" /></td>
    635     <td>'.CheckBox('user_'.$UserId, in_array($UserId, $ExportSetting['users-selection']), '', 'CheckBox').'</td></tr>');
    636     echo('</table></td><td class="Description">Zvolte ze seznamu uživatele, od kterých chcete načítat překlady a upravte jejich pořadí, takže od uživatelů výše budou brány překlady přednostně.<br />'.
    637     'Řádky v tabulce můžete přesouvat metodou uchop a táhni.'.
    638       '</td></tr></table>'.
    639     '<div><input name="users-order" id="users-order" size="100" type="hidden" /><br />');
    640   echo('<input type="submit" value="Pokračovat" /></div>');
    641   echo('</div></form>');
    642     break;
    643 }
    644 
    645 if(array_key_exists('UserID', $_SESSION) and ($_SESSION['UserID'] != ''))
    646   $Database->SQLCommand('UPDATE user SET ExportSetting = "'.addslashes(serialize($ExportSetting)).'" WHERE ID='.$_SESSION['UserID']);
    647   else $_SESSION['ExportSetting'] = serialize($ExportSetting);
    648        
    649 //print_r($ExportSetting);
    650 
    651 ShowFooter();     
     455  if(array_key_exists('ClientVersion', $_POST))
     456  {
     457    $Database->SQLCommand('UPDATE Export SET ClientVersion='.$_POST['ClientVersion'].' WHERE Id='.$_GET['ExportId']);
     458  }
     459
     460  $DbResult = $Database->SQLCommand('SELECT * FROM Export WHERE Id='.$_GET['ExportId']);
     461  $Export = mysql_fetch_assoc($DbResult);
     462
     463  $Query = 'SELECT wow_client_version.* FROM ExportVersion LEFT JOIN wow_client_version ON wow_client_version.Id=ExportVersion.ClientVersion WHERE ExportType='.$Export['OutputType'];
     464
     465  $DbResult = $Database->SQLCommand('SELECT COUNT(*) FROM ('.$Query.') AS X');
     466  $DbRow = mysql_fetch_row($DbResult);
     467  $PageList = GetPageList($DbRow[0]);   
     468 
     469  $TableColumns = array(
     470    array('Name' => 'Version', 'Title' => 'Verze'),
     471    array('Name' => 'BuildNumber', 'Title' => 'Sestavení'),
     472    array('Name' => 'ReleaseDate', 'Title' => 'Datum uvolnění'),
     473    array('Name' => 'Title', 'Title' => 'Titutek'),
     474    array('Name' => '', 'Title' => 'Výběr'),
     475  );
     476  $Order = GetOrderTableHeader($TableColumns, 'BuildNumber');
     477  echo('<form action="?Action=View&amp;ExportId='.$_GET['ExportId'].'" method="post">');
     478  echo('<h3>Verze klienta</h3>');
     479
     480  echo('<input type="submit" value="Uložit výběr" '.$DisabledInput[$Editable].'/><br />
     481   Vyberte pro jakou verzi herního klienta se budou texty exportovat.<br />');
     482  echo($PageList['Output']);
     483  echo('<table class="BaseTable">');
     484  echo($Order['Output']);
     485
     486  $Query = 'SELECT * FROM ('.$Query.') AS TX '.$Order['SQL'].$PageList['SQLLimit'];
     487  $DbResult = $Database->SQLCommand($Query);
     488  while($Version = mysql_fetch_assoc($DbResult))
     489  {
     490    echo('<tr><td><a href="http://www.wowwiki.com/Patch_'.$Version['Version'].'">'.$Version['Version'].'</a></td><td>'.$Version['BuildNumber'].'</td><td>'.HumanDate($Version['ReleaseDate']).'</td><td>'.$Version['Title'].'</td><td>'.RadioButton('ClientVersion', $Version['Id'], $Export['ClientVersion'] == $Version['Id'], '', !$Editable
     491    ).'</td></tr>');
     492
     493  }
     494  echo('</table>');
     495  echo('</form>');
     496  echo($PageList['Output']);
     497    } else echo('Položka nenalezena');
     498  } else echo('Nebylo zadáno Id');
     499}
     500
     501function ExportViewOutput()
     502{
     503  global $Database;
     504 
     505  $DbResult = $Database->SQLCommand('SELECT * FROM Export WHERE Id='.$_GET['ExportId']);
     506  $Export = mysql_fetch_assoc($DbResult);
     507  ExportOutput($Export['Id'], $Export['OutputType']);
     508}
     509
     510function ExportView()
     511{
     512  global $Database;
     513
     514  $DbResult = $Database->SQLCommand('SELECT * FROM Export WHERE Id='.$_GET['ExportId']);
     515  $Export = mysql_fetch_assoc($DbResult);
     516  $DbResult = $Database->SQLCommand('SELECT * FROM user WHERE ID='.$Export['User']);
     517  $User = mysql_fetch_assoc($DbResult);
     518  echo('Export <strong><a href="?Action=View&amp;Tab=6&amp;ExportId='.$Export['Id'].'">'.$_GET['ExportId'].'</a></strong> překladatele <strong>'.$User['user'].'</strong> s označením <strong>'.$Export['Title'].'</strong>');
     519  ShowTabs(array('Obecné', 'Překladatelé', 'Překlady', 'Jazyky', 'Formát', 'Verze', 'Výstup'));
     520  echo('<div id="content">');
     521  if($_SESSION['Tab'] == 0) ExportViewGeneral();
     522  else if($_SESSION['Tab'] == 1) ExportViewTranslators();
     523  else if($_SESSION['Tab'] == 2) ExportViewGroups();
     524  else if($_SESSION['Tab'] == 3) ExportViewLanguages();
     525  else if($_SESSION['Tab'] == 4) ExportViewOutputFormat();
     526  else if($_SESSION['Tab'] == 5) ExportViewVersion();
     527  else if($_SESSION['Tab'] == 6) ExportViewOutput();
     528 
     529  echo('</div>');
     530}
     531
     532ShowPage();
     533
     534if(array_key_exists('Action', $_GET))
     535{
     536  if($_GET['Action'] == 'Create') ExportCreate();
     537  else if($_GET['Action'] == 'CreateFinish') ExportCreateFinish();
     538  else if($_GET['Action'] == 'View') ExportView();
     539  else if($_GET['Action'] == 'Delete') ExportDelete();
     540  else ExportList();
     541} else ExportList();
     542
     543ShowFooter();
     544
    652545?>
  • trunk/includes/error.php

    r289 r290  
    3737    {
    3838      //print_r($Item);
    39       if(array_key_exists('line', $Item))
    40         $Error .= ' '.$Item['file'].'('.$Item['line'].")\t".$Item['function'];
    41       else $Error .= ' '.$Item['file']."\t".$Item['function'];
     39      if(!array_key_exists('line', $Item)) $Item['line'] = '';
     40      if(!array_key_exists('file', $Item)) $Item['file'] = '';
     41      if(!array_key_exists('function', $Item)) $Item['function'] = '';
     42      $Error .= ' '.$Item['file'].'('.$Item['line'].")\t".$Item['function'];
    4243      $Arguments = '';
    4344      if(array_key_exists('args', $Item) and is_array($Item['args']))
  • trunk/includes/global.php

    r289 r290  
    1919include('global_function.php');
    2020include('rss.php');
     21include_once('system.php');
    2122
    2223$Database = new Database($Config['Database']['Host'], $Config['Database']['User'], $Config['Database']['Password']);
     
    2627$TranslationTree = GetTranslationTree();
    2728$LanguageList = GetLanguageList();
     29
     30$System = new System();
     31$System->Init();
    2832
    2933function GetMicrotime()
     
    96100    $Config['Web']['BaseURL'].'index.php' => array(LICENCE_ANONYMOUS, 'Hlavní stránka', 'Domů'),
    97101    'http://wow.zdechov.net/forum/viewforum.php?f=22' => array(LICENCE_ANONYMOUS, 'Diskuze na téma překládání', 'Fórum projektu'),
    98     $Config['Web']['BaseURL'].'dictionary.php' => array(LICENCE_ANONYMOUS, 'Slovník WoW výrazů', 'Slovník'),
    99     $Config['Web']['BaseURL'].'banners.php' => array(LICENCE_ANONYMOUS, 'Weby odkazující na tento projekt bennerem', 'Odkazují na nás'),
     102    $Config['Web']['BaseURL'].'dictionary.php' => array(LICENCE_ANONYMOUS, 'Slovník WoW výrazů', 'Slovníček'),
    100103    $Config['Web']['BaseURL'].'statistic.php' => array(LICENCE_ANONYMOUS, 'Stav dokončení překládů', 'Stav dokončení'),
    101104    $Config['Web']['BaseURL'].'userlist.php?action=nofilter' => array(LICENCE_ANONYMOUS, 'Seznam registrovaných uživatelů', 'Překladatelé'),
    102105    $Config['Web']['BaseURL'].'team.php?search=' => array(LICENCE_ANONYMOUS, 'Seznam překladatelských týmů', 'Týmy'),
    103     $Config['Web']['BaseURL'].'download.php' => array(LICENCE_ANONYMOUS, 'Zde si můžete stáhnout přeložené texty', 'Stahování'),
     106    $Config['Web']['BaseURL'].'export/' => array(LICENCE_ANONYMOUS, 'Zde si můžete stáhnout přeložené texty', 'Exporty'),
     107    $Config['Web']['BaseURL'].'download.php' => array(LICENCE_ANONYMOUS, 'Stahování různých pomocných souborů a programů', 'Soubory'),
    104108    $Config['Web']['BaseURL'].'info.php' => array(LICENCE_ANONYMOUS, 'Informace k překladu hry', 'Informace'),
    105109    $Config['Web']['BaseURL'].'registrace.php' => array(LICENCE_ANONYMOUS, 'Registrace uživatele pro překládání', 'Registrace'),
    106110    $Config['Web']['BaseURL'].'TranslationList.php?action=grouplist' => array(LICENCE_ANONYMOUS, 'Informace o překladových skupinách', 'Zdroje dat'),
     111    $Config['Web']['BaseURL'].'banners.php' => array(LICENCE_ANONYMOUS, 'Informace k propagaci tohoto projektu', 'Propagace'),
    107112    $Config['Web']['BaseURL'].'version.php' => array(LICENCE_ANONYMOUS, 'Seznam verzí herního klienta', 'Verze hry'),
    108113    $Config['Web']['BaseURL'].'aowow' => array(LICENCE_ANONYMOUS, 'Vyhledávací databáze podobná WoWHead s překlady', 'AoWoW'),
     
    175180    if(Licence(LICENCE_MODERATOR)) $Name = '<a href="user.php?user='.$Line['ID'].'">'.$Line['user'].'</a>';
    176181    else $Name = $Line['user'];
    177     if($Line['GM'] <> 0) $TextGM = '<small>('.$Moderators[$Line['GM']].')</small>';
    178     else $TextGM = '';
     182    //if($Line['GM'] <> 0) $TextGM = '<small>('.$Moderators[$Line['GM']].')</small>';
     183    //else
     184    $TextGM = '';
    179185    echo('<strong>'.$Name.'</strong>'.$TextGM.'<br />');
    180186  }
  • trunk/includes/global_function.php

    r289 r290  
    6262    if($PagesMin < ($CurrentPage - $Around))
    6363    {
    64       $Result.= ' .. ';
     64      $Result.= ' ... ';
    6565      $PagesMin = $CurrentPage - $Around;
    6666    }
     
    7373      }
    7474    }
    75     if($PagesMax < ($PageCount - 1)) $Result .= ' .. ';
     75    if($PagesMax < ($PageCount - 1)) $Result .= ' ... ';
    7676    if($CurrentPage < ($PageCount - 1))
    7777    {
     
    374374}
    375375
    376 
    377376function GetBuildNumber($Version)
    378377{
     
    459458}
    460459
     460function LoadCommandLineParameters()
     461{
     462  if(!array_key_exists('REMOTE_ADDR', $_SERVER))
     463  {
     464    foreach($_SERVER['argv'] as $Parameter)
     465    {
     466      if(strpos($Parameter, '=') !== false)
     467      {
     468        $Index = substr($Parameter, 0, strpos($Parameter, '='));
     469        $Parameter = substr($Parameter, strpos($Parameter, '=') + 1);
     470        //echo($Index.'  ----  '.$Parameter);
     471        $_GET[$Index] = $Parameter;
     472      }
     473    }
     474  }
     475}
     476
     477function ShowTabs($Tabs)
     478{
     479  $QueryItems = GetQueryStringArray($_SERVER['QUERY_STRING']);
     480 
     481  if(array_key_exists('Tab', $_GET)) $_SESSION['Tab'] = $_GET['Tab'];
     482  if(!array_key_exists('Tab', $_SESSION)) $_SESSION['Tab'] = 0;
     483  if(($_SESSION['Tab'] < 0) or ($_SESSION['Tab'] > (count($Tabs) - 1))) $_SESSION['Tab'] = 0;
     484  echo('<div id="header">');
     485  echo('<ul>');
     486  foreach($Tabs as $Index => $Tab)
     487  {
     488    $QueryItems['Tab'] = $Index;
     489    if($Index == $_SESSION['Tab']) $Selected = ' id="selected"';
     490      else $Selected = '';
     491    echo('<li'.$Selected.'><a href="?'.SetQueryStringArray($QueryItems).'">'.$Tab.'</a></li>');
     492  }
     493  echo('</ul></div>');
     494}
     495
     496function CheckBox($Name, $Checked = false, $Id = '', $Class = '', $Disabled = false)
     497{
     498  if($Id) $Id = ' id="'.$Id.'"'; else $Id = '';
     499  if($Class) $Class = ' class="'.$Class.'"'; else $Class = '';
     500  if($Checked) $Checked = ' checked="checked"'; else $Checked = '';
     501  if($Disabled) $Disabled = ' disabled="disabled"'; else $Disabled = '';
     502  return('<input type="checkbox" value="checked" name="'.$Name.'"'.$Checked.$Disabled.$Id.$Class.' />');
     503}
     504
     505function RadioButton($Name, $Value, $Checked = false, $OnClick = '', $Disabled = false)
     506{
     507  if($Checked) $Checked = ' checked="checked"'; else $Checked = '';
     508  if($OnClick != '') $OnClick = ' onclick="'.$OnClick.'"'; else $OnClick = '';
     509  if($Disabled) $Disabled = ' disabled="disabled"'; else $Disabled = '';
     510  return('<input type="radio" name="'.$Name.'" value="'.$Value.'"'.$Checked.$Disabled.$OnClick.'/>');
     511}
     512
     513function SelectOption($Name, $Text, $Selected = false)
     514{
     515  if($Selected) $Selected = ' selected="selected"'; else $Selected = '';
     516  return('<option value="'.$Name.'"'.$Selected.'>'.$Text.'</option>');
     517}
     518
     519
    461520?>
  • trunk/index.php

    r282 r290  
    116116  );
    117117  ShowPage();
    118   $Banner = '<a href="'.$Config['Web']['BaseURL'].'"><img src="'.$Config['Web']['BaseURL'].'banners/baner_468_60.jpg" '.
    119     'alt="baner_'.$Config['Web']['BaseURL'].'" title="Otevřený projekt překládání celé hry World of Warcraft" '.
    120     'class="banner" height="60" width="468" /></a>';
    121  
    122   $BannerSmall = '<a href="'.$Config['Web']['BaseURL'].'"><img src="'.$Config['Web']['BaseURL'].'banners/baner_88_31.jpg" '.
    123     'alt="baner_'.$Config['Web']['BaseURL'].'" title="Otevřený projekt překládání celé hry World of Warcraft" '.
    124     'class="banner" height="31" width="88" /></a>';
    125  
    126   echo('<strong>Bannery:</strong><br />');
    127  
    128   echo($Banner.' &nbsp;&nbsp;<textarea rows="2" cols="30">'.htmlspecialchars($Banner).'</textarea><br />');
    129   echo($BannerSmall.' &nbsp;&nbsp;<textarea rows="2" cols="30">'.htmlspecialchars($BannerSmall).'</textarea><br />');
    130118 
    131119  echo('<br />'. 
  • trunk/style/style.css

    r286 r290  
    33  font-size: 14px;
    44  font-family: Verdana, Arial, SunSans-Regular, Sans-Serif;
    5   color: #564b47;
     5  color: #362b27;
    66  padding: 0px;
    77  margin: 0px;
     
    2121a:visited
    2222{
    23   color:#c43300;
     23  color: #c43300;
    2424}
    2525
    2626a:hover
    2727{
    28   color: #c43300;
     28  color: #c3300;
    2929}
    3030
     
    345345  text-align: center;
    346346}
     347
     348#header ul
     349{
     350  list-style: none;
     351  padding: 0;
     352  margin: 0;
     353}
     354   
     355#header li
     356{
     357  float: left;
     358  border: 1px solid #bbb;
     359  border-bottom-width: 0;
     360  margin: 0;
     361}
     362   
     363#header a
     364{
     365  text-decoration: none;
     366  display: block;
     367  background: #eee;
     368  padding: 0.24em 1em;
     369  color: #c00;
     370  text-align: center;
     371}
     372 
     373#header a:hover
     374{
     375  background: #fdd;
     376}
     377 
     378#header #selected
     379{
     380  border-color: black;
     381}
     382 
     383#header #selected a
     384{
     385  position: relative;
     386  top: 1px;
     387  background: white;
     388  color: black;
     389  font-weight: bold;
     390}
     391 
     392#content
     393{
     394  border: 1px solid black;
     395  clear: both;
     396  padding: 5px;
     397}
     398   
  • trunk/user.php

    r127 r290  
    2525 
    2626if(array_key_exists('user', $_GET) and Licence(LICENCE_MODERATOR))
    27 {
    28  
     27
    2928  $Query = 'SELECT *, (';
    3029  foreach($TranslationTree as $Group)
    3130    if($Group['TablePrefix'] != '')
    32           $Query .= '(SELECT count(*) FROM `'.$Group['TablePrefix'].'` WHERE User = '.$_GET['user'].' AND User <> 0 AND Complete = 1) + ';
     31    $Query .= '(SELECT count(*) FROM `'.$Group['TablePrefix'].'` WHERE User = '.$_GET['user'].' AND User <> 0 AND Complete = 1) + ';
    3332  $Query .= '0) as NumberTranslate FROM `user` WHERE ID = '.$_GET['user'];
    3433  $LineUser = mysql_fetch_array($Database->SQLCommand($Query));
     
    3635  echo('ID: <strong>'.$_GET['user'].'</strong><br />');
    3736  echo('Jméno: <strong>'.$LineUser['user'].'</strong><br />');
    38   echo('Výchozí jazyk: <strong>'.$LineUser['Language'].'</strong><br />');
     37  echo('Výchozí jazyk: <strong>'.$LanguageList[$LineUser['Language']]['Name'].'</strong><br />');
    3938  echo('Poslední připojení: <strong>'.$LineUser['LastLogin'].'</strong><br />');
    4039  echo('Poslední IP: <strong>'.$LineUser['LastIP'].'</strong><br />');
Note: See TracChangeset for help on using the changeset viewer.