Ignore:
Timestamp:
Jun 19, 2013, 5:53:35 PM (11 years ago)
Author:
chronos
Message:
  • Opraveno: Nezobrazovat překládaný text v formuláři pro nepřihlášené uživatele.
File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/Modules/Translation/Form.php

    r550 r552  
    1717                return $Text;
    1818        }       
    19        
     19
    2020        function Show()
    21   {
    22         global $System, $Config, $User, $TranslationTree;
    23         $Output = '';
    24 
    25 $GroupId = LoadGroupIdParameter();
    26 $Table = $TranslationTree[$GroupId]['TablePrefix'];
    27 if(array_key_exists('action', $_GET)) $Action = $_GET['action'];
    28   else $Action = '';
    29 
    30 if(array_key_exists('ID', $_GET))
    31 {
    32   $TextID = $_GET['ID'] * 1; 
    33 
    34   $DbResult = $System->Database->query('SELECT * FROM `'.$Table.'` WHERE `ID` = '.$TextID);
    35   $Line = $DbResult->fetch_assoc();
    36   if(!$Line)
    37   {
    38     $Output .= ShowMessage('Překlad nenalezen.', MESSAGE_CRITICAL);
    39   } else
    40   {
    41    
    42   $DbResult = $System->Database->query('SELECT * FROM `'.$Table.'` WHERE (`Language` = '.$Config['OriginalLanguage'].') AND (`Entry` = '.$Line['Entry'].') AND (`VersionEnd` = '.$Line['VersionEnd'].') LIMIT 1');
    43   $LineAJ = $DbResult->fetch_assoc();
    44   if(!$LineAJ)
    45   {
    46     $Output .= ShowMessage('Anglický originál k překladu nenalezen.', MESSAGE_CRITICAL);
    47   } else
    48   {
    49  
    50   if($Line['User'] != '')
    51   {
    52     $IDUser = $System->Database->query('SELECT * FROM `User` WHERE `ID` = '.$Line['User']);
    53     $LineUser = $IDUser->fetch_array();
    54   } else
    55     $LineUser = array('Name' => '');
    56  
    57   $Output .= 'Skupina: <strong>'.$TranslationTree[$GroupId]['Name'].'</strong><br />';
    58      
    59   if(($Line['Language'] <> 0) and ($LineUser['Name'] <> ''))
    60     $Output .= 'Přeložil: <strong>'.$LineUser['Name'].'</strong> dne '.HumanDate($Line['ModifyTime']).'<br />';
    61   if(($Line['Take'] <> 0) and ($Line['Take'] <> $Line['ID']))
    62   {
    63     $DbResult = $System->Database->query('SELECT `Language`,`VersionStart`,`VersionEnd` FROM `'.$Table.'` WHERE `ID` = '.$Line['Take']);
    64     $Language = $DbResult->fetch_assoc();
    65     // echo $Language['Language'].'  '.$Line['Take'];
    66    
    67     $DbResult = $System->Database->query('SELECT `Name` FROM `Language` WHERE `Id` ='.$Language['Language']);
    68     $Lang = $DbResult->fetch_assoc();
    69    
    70     $Output .= 'Původní text: <strong>'.
    71       ' ID <a href="form.php?group='.$GroupId.'&amp;ID='.$Line['Take'].'">'.$Line['Take'].'</a></strong>'.
    72       ' ('.$Lang['Name'].')'.
    73       ' <br />';
    74   }
    75   $Output .= 'Text: ';
    76   if($Line['Language'] <> 0)
    77   {
    78     if($Line['Complete'] == 1) $Output .= ' <b>Hotov</b>';
    79       else $Output .= ' <b> Uložen v rozepsaných</b> ';
    80   } else $Output .= ' <b>Anglická, původní verze</b> ';
    81 
    82   $Output .= '<br />'.
    83     'Verze: <b>'.GetVersionWOW($Line['VersionStart']).' - '.GetVersionWOW($Line['VersionEnd']).'</b>'.
    84     '<br />';
    85    
    86   $DbResult = $System->Database->query('SELECT COUNT(*) FROM `'.$Table.'` WHERE (`Entry` = '.$Line['Entry'].') AND (`Language` <> '.$Config['OriginalLanguage'].') AND (`Complete` = 1)');
    87   $Version = $DbResult->fetch_row();
    88   $Version = $Version[0];
    89   if($Version > 0)
    90   {
    91     $Output .= '<form action="comparison.php" method="get"><a href="TranslationList.php?group='.$GroupId.'&amp;user=0&amp;state=2&amp;entry='.$Line['Entry'].'&amp;text=">Počet verzí: <strong>'.$Version.'</strong></a> 
    92       <input type="hidden" name="group" value="'.$GroupId.'" />
    93       <input type="hidden" name="entry" value="'.$Line['Entry'].'" />
    94       <input type="hidden" name="ID2" value="'.$TextID.'" />
    95       <select onchange="this.form.submit();" name="ID1">
    96       <option value="-1">Vyberte text k porovnání</option>
    97       <option value="-1">Zobrazit/porovnat všechny</option>';
    98     $DataID = $System->Database->query('SELECT *, (SELECT `User`.`Name` AS `UserName` FROM `User` WHERE `User`.`ID` = `'.$Table.'`.`User`) AS `UserName` FROM `'.$Table.'` WHERE (`Entry` = '.$Line['Entry'].') AND (`ID` <> '.$Line['ID'].') AND (`Complete` = 1)'); 
    99     while($Version = $DataID->fetch_array())
    100     {     
    101       if($Version['ID'] == $Line['Take']) $Output .= '<option value="'.$Version['ID'].'">'.$Version['ID'].' - '.$Version['User'].' (převzato)</option>';   
    102       else
    103       {
    104         if($Version['Language'] == 0) $Version['UserName'] = 'Předloha';
    105         $Output .= '<option value="'.$Version['ID'].'">'.$Version['ID'].' - '.
    106         $Version['UserName'].' ('.GetVersionWOW($Version['VersionStart']).' - '.
    107         GetVersionWOW($Version['VersionEnd']).')</option>';
    108       }
    109     }
    110     $Output .= '</select></form>';   
    111   } else
    112   {
    113     $Output .= '<a href="TranslationList.php?group='.$GroupId.'&amp;user=0&amp;state=2&amp;entry='.$Line['Entry'].'&amp;text=">Počet verzí: <strong>'.$Version.'</strong></a>';
    114   }
    115 
    116   // Special characters: $B - New line, $N - Name, $C - profession
    117   $Output .= '<form action="save.php?group='.$GroupId.'" method="post"><div>';
    118   if($User->Licence(LICENCE_USER))
    119   {
    120     if(($GroupId < 4) or ($GroupId == 10) or ($GroupId == 11))
    121       $Output .= '<a href="dictionary.php?action=group&amp;group='.$GroupId.'&amp;ID='.$LineAJ['ID'].'" target="_blank"  title="Zobrazit přeložené názvy věci, postav, a herních objektů k tomuto překladu">Vyhledat v názvech</a>';
    122     $Output .= ' <input type="submit" value="Uložit do rozepsaných" name="save" title="Klikněte na uložit pro pozdější dokončení překladu" />'.
    123       '<input type="submit" value="Dokončeno" name="End" title="Klikněte na Dokončeno jesli jsou všechny texty hotové a chcete již publikovat" /> ';
    124     FollowingTran($TextID, $Table, $GroupId, true);
    125     FollowingTran($TextID, $Table, $GroupId);
    126   }
    127 
    128   if($TranslationTree[$GroupId]['WowheadName'] != '')
    129     $WowheadLink = '<a href="http://www.wowhead.com/?'.$TranslationTree[$GroupId]['WowheadName'].'='.$LineAJ['Entry'].'">'.$LineAJ['Entry'].'</a>';
    130     else $WowheadLink = $LineAJ['Entry'];
    131  
    132   $Output .= '<input type="hidden" name="entry" value="'.$LineAJ['Entry'].'" />
    133     <input type="hidden" name="user" value="'.$User->Id.'" />
    134     <input type="hidden" name="ID" value="'.$TextID.'" />
    135     <table class="BaseTable">
    136       <tr>
    137         <th>Číslo textu: '.$WowheadLink.'</th>
    138         <th>Nepřeložené</th>
    139         <th>Přeložené</th>
    140       </tr>
    141       <tr>
    142         <th>Jazyk</th>
    143         <td>Anglický</td>
    144         <td>
    145           Přeloženo do:';
    146   if($Line['Language'] <> 0) $Language = $Line['Language'];
    147   else if($User->Id != 0)
    148   {
    149     $Language = $User->Language;
    150   } else $Language = 0;
    151   $Output .= WriteLanguages($Language).
    152     '</td></tr>';
    153 
    154   // Difference highlighting
    155   $Text = '';
    156   foreach($TranslationTree[$GroupId]['Items'] as $Index => $TextItem)
    157     if($TextItem['Visible'] == 1)
    158       $Text = $Text.' '.$LineAJ[$TextItem['Column']];
    159 
    160   if(($GroupId < 4) or ($GroupId == 10) or ($GroupId == 11)) {
    161   //<span class="edit">barvou.</span>
    162     $names = GetTranslatNames($Text,0,array('Dictionary' => 'Text','TextCreature' => 'name'));
    163   } else {
    164     $names = GetTranslatNames($Text,0,array('Dictionary' => 'Text'));
    165   }
    166 
    167   foreach($TranslationTree[$GroupId]['Items'] as $Index => $TextItem)
    168   if($TextItem['Visible'] == 1)
    169   {         
    170     if(($LineAJ[$TextItem['Column']] <> '') or ($Line[$TextItem['Column']] <> '')) 
    171     {
    172       if ($TextItem['Name'] == 'Text' AND (($Table == 'global_strings') OR ($Table == 'glue_strings')))
    173         $Output .= '<tr><th>'.$LineAJ['ShortCut'].'</th>';
    174         else $Output .= '<tr><th>'.$TextItem['Name'].'</th>';
    175       $Output .= '<td>'.str_replace("\n", '<br/>', $this->ColorNames(htmlspecialchars($LineAJ[$TextItem['Column']]),$names)).'</td>
    176       <td><textarea rows="8" cols="40" onkeydown="ResizeTextArea(this)" class="textedit" id="'.$TextItem['Column'].'" name="'.$TextItem['Column'].'">'.htmlspecialchars($Line[$TextItem['Column']]).'</textarea></td></tr>';
    177     }
    178   } else
    179   {
    180     $Output .= '<input id="'.$TextItem['Column'].'" name="'.$TextItem['Column'].'" type="hidden" value="'.htmlspecialchars($Line[$TextItem['Column']]).'" />';
    181   }
    182   $Output .= '</table></div></form>';
    183   }
    184   }
    185 } else $Output = ShowMessage('Nebylo zadáno ID.', MESSAGE_CRITICAL);
    186 return($Output);
    187   }
     21        {
     22                global $System, $Config, $User, $TranslationTree;
     23                $Output = '';
     24       
     25                $GroupId = LoadGroupIdParameter();
     26                $Table = $TranslationTree[$GroupId]['TablePrefix'];
     27                if(array_key_exists('action', $_GET)) $Action = $_GET['action'];
     28                else $Action = '';
     29       
     30                if(array_key_exists('ID', $_GET))
     31                {
     32                        $TextID = $_GET['ID'] * 1;
     33       
     34                        $DbResult = $System->Database->query('SELECT * FROM `'.$Table.'` WHERE `ID` = '.$TextID);
     35                        $Line = $DbResult->fetch_assoc();
     36                        if(!$Line)
     37                        {
     38                                $Output .= ShowMessage('Překlad nenalezen.', MESSAGE_CRITICAL);
     39                        } else
     40                        {
     41       
     42                                $DbResult = $System->Database->query('SELECT * FROM `'.$Table.'` WHERE (`Language` = '.$Config['OriginalLanguage'].') AND (`Entry` = '.$Line['Entry'].') AND (`VersionEnd` = '.$Line['VersionEnd'].') LIMIT 1');
     43                                $LineAJ = $DbResult->fetch_assoc();
     44                                if(!$LineAJ)
     45                                {
     46                                        $Output .= ShowMessage('Anglický originál k překladu nenalezen.', MESSAGE_CRITICAL);
     47                                } else
     48                                {
     49       
     50                                        if($Line['User'] != '')
     51                                        {
     52                                                $IDUser = $System->Database->query('SELECT * FROM `User` WHERE `ID` = '.$Line['User']);
     53                                                $LineUser = $IDUser->fetch_array();
     54                                        } else
     55                                                $LineUser = array('Name' => '');
     56       
     57                                        $Output .= 'Skupina: <strong>'.$TranslationTree[$GroupId]['Name'].'</strong><br />';
     58       
     59                                        if(($Line['Language'] <> 0) and ($LineUser['Name'] <> ''))
     60                                                $Output .= 'Přeložil: <strong>'.$LineUser['Name'].'</strong> dne '.HumanDate($Line['ModifyTime']).'<br />';
     61                                        if(($Line['Take'] <> 0) and ($Line['Take'] <> $Line['ID']))
     62                                        {
     63                                                $DbResult = $System->Database->query('SELECT `Language`,`VersionStart`,`VersionEnd` FROM `'.$Table.'` WHERE `ID` = '.$Line['Take']);
     64                                                $Language = $DbResult->fetch_assoc();
     65                                                // echo $Language['Language'].'  '.$Line['Take'];
     66       
     67                                                $DbResult = $System->Database->query('SELECT `Name` FROM `Language` WHERE `Id` ='.$Language['Language']);
     68                                                $Lang = $DbResult->fetch_assoc();
     69       
     70                                                $Output .= 'Původní text: <strong>'.
     71                                                                ' ID <a href="form.php?group='.$GroupId.'&amp;ID='.$Line['Take'].'">'.$Line['Take'].'</a></strong>'.
     72                                                                ' ('.$Lang['Name'].')'.
     73                                                                ' <br />';
     74                                        }
     75                                        $Output .= 'Text: ';
     76                                        if($Line['Language'] <> 0)
     77                                        {
     78                                                if($Line['Complete'] == 1) $Output .= ' <b>Hotov</b>';
     79                                                else $Output .= ' <b> Uložen v rozepsaných</b> ';
     80                                        } else $Output .= ' <b>Anglická, původní verze</b> ';
     81       
     82                                        $Output .= '<br />'.
     83                                                        'Verze: <b>'.GetVersionWOW($Line['VersionStart']).' - '.GetVersionWOW($Line['VersionEnd']).'</b>'.
     84                                                        '<br />';
     85                                         
     86                                        $DbResult = $System->Database->query('SELECT COUNT(*) FROM `'.$Table.'` WHERE (`Entry` = '.$Line['Entry'].') AND (`Language` <> '.$Config['OriginalLanguage'].') AND (`Complete` = 1)');
     87                                        $Version = $DbResult->fetch_row();
     88                                        $Version = $Version[0];
     89                                        if($Version > 0)
     90                                        {
     91                                                $Output .= '<form action="comparison.php" method="get"><a href="TranslationList.php?group='.$GroupId.'&amp;user=0&amp;state=2&amp;entry='.$Line['Entry'].'&amp;text=">Počet verzí: <strong>'.$Version.'</strong></a>
     92                                                <input type="hidden" name="group" value="'.$GroupId.'" />
     93                                                <input type="hidden" name="entry" value="'.$Line['Entry'].'" />
     94                                                <input type="hidden" name="ID2" value="'.$TextID.'" />
     95                                                <select onchange="this.form.submit();" name="ID1">
     96                                                <option value="-1">Vyberte text k porovnání</option>
     97                                                <option value="-1">Zobrazit/porovnat všechny</option>';
     98                                                $DataID = $System->Database->query('SELECT *, (SELECT `User`.`Name` AS `UserName` FROM `User` WHERE `User`.`ID` = `'.$Table.'`.`User`) AS `UserName` FROM `'.$Table.'` WHERE (`Entry` = '.$Line['Entry'].') AND (`ID` <> '.$Line['ID'].') AND (`Complete` = 1)');
     99                                                while($Version = $DataID->fetch_array())
     100                                                {
     101                                                        if($Version['ID'] == $Line['Take']) $Output .= '<option value="'.$Version['ID'].'">'.$Version['ID'].' - '.$Version['User'].' (převzato)</option>';
     102                                                        else
     103                                                        {
     104                                                                if($Version['Language'] == 0) $Version['UserName'] = 'Předloha';
     105                                                                $Output .= '<option value="'.$Version['ID'].'">'.$Version['ID'].' - '.
     106                                                                                $Version['UserName'].' ('.GetVersionWOW($Version['VersionStart']).' - '.
     107                                                                                GetVersionWOW($Version['VersionEnd']).')</option>';
     108                                                        }
     109                                                }
     110                                                $Output .= '</select></form>';
     111                                        } else
     112                                        {
     113                                                $Output .= '<a href="TranslationList.php?group='.$GroupId.'&amp;user=0&amp;state=2&amp;entry='.$Line['Entry'].'&amp;text=">Počet verzí: <strong>'.$Version.'</strong></a>';
     114                                        }
     115       
     116                                        // Special characters: $B - New line, $N - Name, $C - profession                                       
     117                                        if($User->Licence(LICENCE_USER))
     118                                        {
     119                                                $Output .= '<form action="save.php?group='.$GroupId.'" method="post"><div>';
     120                                                if(($GroupId < 4) or ($GroupId == 10) or ($GroupId == 11))
     121                                                        $Output .= '<a href="dictionary.php?action=group&amp;group='.$GroupId.'&amp;ID='.$LineAJ['ID'].'" target="_blank"  title="Zobrazit přeložené názvy věci, postav, a herních objektů k tomuto překladu">Vyhledat v názvech</a>';
     122                                                $Output .= ' <input type="submit" value="Uložit do rozepsaných" name="save" title="Klikněte na uložit pro pozdější dokončení překladu" />'.
     123                                                                '<input type="submit" value="Dokončeno" name="End" title="Klikněte na Dokončeno jesli jsou všechny texty hotové a chcete již publikovat" /> ';
     124                                                FollowingTran($TextID, $Table, $GroupId, true);
     125                                                FollowingTran($TextID, $Table, $GroupId);
     126                                        }
     127       
     128                                        if($TranslationTree[$GroupId]['WowheadName'] != '')
     129                                                $WowheadLink = '<a href="http://www.wowhead.com/?'.$TranslationTree[$GroupId]['WowheadName'].'='.$LineAJ['Entry'].'">'.$LineAJ['Entry'].'</a>';
     130                                        else $WowheadLink = $LineAJ['Entry'];
     131       
     132                                        $Output .= '<input type="hidden" name="entry" value="'.$LineAJ['Entry'].'" />
     133                                        <input type="hidden" name="user" value="'.$User->Id.'" />
     134                                        <input type="hidden" name="ID" value="'.$TextID.'" />
     135                                        <table class="BaseTable">
     136                                        <tr>
     137                                        <th>Číslo textu: '.$WowheadLink.'</th>
     138                                        <th>Nepřeložené</th>
     139                                        <th>Přeložené</th>
     140                                        </tr>
     141                                        <tr>
     142                                        <th>Jazyk</th>
     143                                        <td>Anglický</td>
     144                                        <td>';
     145                                        if($Line['Language'] <> 0) $Language = $Line['Language'];
     146                                        else if($User->Id != 0)
     147                                        {
     148                                                $Language = $User->Language;
     149                                        } else $Language = 0;
     150                                        if($User->Licence(LICENCE_USER)) $Output .= WriteLanguages($Language);
     151                                          else {                                       
     152                  $DbResult3 = $System->Database->select('Language', '`Id`, `Name`', '`Enabled` = 1');
     153                  if($DbResult3->num_rows > 0)
     154                  {
     155                        $Language = $DbResult3->fetch_assoc();
     156                        $Output .= $Language['Name'];
     157                  }
     158                                          }
     159                                       
     160                                        $Output .= '</td></tr>';
     161       
     162                                        // Difference highlighting
     163                                        $Text = '';
     164                                        foreach($TranslationTree[$GroupId]['Items'] as $Index => $TextItem)
     165                                                if($TextItem['Visible'] == 1)
     166                                                $Text = $Text.' '.$LineAJ[$TextItem['Column']];
     167       
     168                                        if(($GroupId < 4) or ($GroupId == 10) or ($GroupId == 11)) {
     169                                                //<span class="edit">barvou.</span>
     170                                                $names = GetTranslatNames($Text,0,array('Dictionary' => 'Text','TextCreature' => 'name'));
     171                                        } else {
     172                                                $names = GetTranslatNames($Text,0,array('Dictionary' => 'Text'));
     173                                        }
     174       
     175                                        foreach($TranslationTree[$GroupId]['Items'] as $Index => $TextItem)
     176                                                if($TextItem['Visible'] == 1)
     177                                                {
     178                                                        if(($LineAJ[$TextItem['Column']] <> '') or ($Line[$TextItem['Column']] <> ''))
     179                                                        {
     180                                                                if ($TextItem['Name'] == 'Text' AND (($Table == 'global_strings') OR ($Table == 'glue_strings')))
     181                                                                        $Output .= '<tr><th>'.$LineAJ['ShortCut'].'</th>';
     182                                                                else $Output .= '<tr><th>'.$TextItem['Name'].'</th>';
     183                                                                $Output .= '<td>'.str_replace("\n", '<br/>', $this->ColorNames(htmlspecialchars($LineAJ[$TextItem['Column']]),$names)).'</td>
     184                                                                <td>';
     185                                                                if($User->Licence(LICENCE_USER)) $Output .= '<textarea rows="8" cols="40" onkeydown="ResizeTextArea(this)" class="textedit" id="'.$TextItem['Column'].'" name="'.$TextItem['Column'].'">';
     186                                                                $Output .=  htmlspecialchars($Line[$TextItem['Column']]);
     187                                                                if($User->Licence(LICENCE_USER)) $Output .= '</textarea></td></tr>';
     188                                                        }
     189                                                } else
     190                                                {
     191                                                        $Output .= '<input id="'.$TextItem['Column'].'" name="'.$TextItem['Column'].'" type="hidden" value="'.htmlspecialchars($Line[$TextItem['Column']]).'" />';
     192                                                }
     193                                                $Output .= '</table></div>';
     194                                                if($User->Licence(LICENCE_USER)) $Output .= '</form>';
     195                                }
     196                        }
     197                } else $Output = ShowMessage('Nebylo zadáno ID.', MESSAGE_CRITICAL);
     198                return($Output);
     199        }       
    188200}
Note: See TracChangeset for help on using the changeset viewer.