Changeset 847


Ignore:
Timestamp:
May 1, 2017, 4:52:01 PM (8 years ago)
Author:
chronos
Message:
  • Added: Yearly complete report for finance Trade summary.
File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/Modules/Finance/Trade.php

    r810 r847  
    6868  }
    6969
    70   function Show()
    71   {
    72     if(!$this->System->User->CheckPermission('Finance', 'TradingStatus'))
    73       return('Nemáte oprávnění');
    74 
    75     $Finance = &$this->System->Modules['Finance'];
    76 
    77     $Output = '';
    78     if(!array_key_exists('table', $_GET)) $_GET['table'] = '';
    79     switch($_GET['table'])
    80     {
    81       case 'AnnualBalance':
    82         $Output = '<table style="font-size: smaller;" class="WideTable">';
    83         $Output .= '<tr><th colspan="3">Účetní období</th><th colspan="5">Na konci</th><th colspan="6">Během</th></tr>'.
     70  function ShowAnnualBalance()
     71  {
     72    $Output = '<table style="font-size: smaller;" class="WideTable">';
     73    $Output .= '<tr><th colspan="3">Účetní období</th><th colspan="5">Na konci</th><th colspan="6">Během</th></tr>'.
    8474      '<tr><th>Rok</th><th>Od</th><th>Do</th><th>Příjmy</th><th>Výdaje</th><th>Pohledávky</th><th>Závazky</th><th>Drobný majetek</th><th>Příjmy</th><th>Výdaje</th><th>Pohledávky</th><th>Závazky</th><th>Drobný majetek</th><th>Základ daně</th></tr>';
    8575
    86         $this->StartEvidence = mktime(0, 0, 0, 12, 1, 2007);
    87         $StartYear = date('Y', $this->StartEvidence);
    88         $EndYear = date('Y', time());
    89         for($Year = $StartYear; $Year <= $EndYear; $Year++)
     76    $this->StartEvidence = mktime(0, 0, 0, 12, 1, 2007);
     77    $StartYear = date('Y', $this->StartEvidence);
     78    $EndYear = date('Y', time());
     79    for($Year = $StartYear; $Year <= $EndYear; $Year++)
     80    {
     81      $EndTime = mktime(0, 0, 0, 12, 31, $Year);
     82      //$Year = date('Y', $EndTime);
     83      $StartTime = mktime(0, 0, 0, 1, 1, $Year);
     84      if($StartTime < $this->StartEvidence) $StartTime = $this->StartEvidence;
     85
     86      $Balance = $this->GetTimePeriodBalance($StartTime, $EndTime);
     87
     88      $Output .= '<tr><td>'.$Year.'</td><td>'.date(HumanDate(TimeToMysqlDateTime($StartTime))).'</td><td>'.date(HumanDate(TimeToMysqlDateTime($EndTime))).'</td>';
     89      $Output .= '<td>'.round($Balance['Income']['End']).'</td>';
     90      $Output .= '<td>'.round($Balance['Spend']['End']).'</td>';
     91      $Output .= '<td>'.round($Balance['Claims']['End']).'</td>';
     92      $Output .= '<td>'.round($Balance['Liabilities']['End']).'</td>';
     93      $Output .= '<td>'.round($Balance['SmallAssets']['End']).'</td>';
     94
     95      $Output .= '<td>'.round($Balance['Income']['End'] - $Balance['Income']['Start']).'</td>';
     96      $Output .= '<td>'.round($Balance['Spend']['End'] - $Balance['Spend']['Start']).'</td>';
     97      $Output .= '<td>'.round($Balance['Claims']['End'] - $Balance['Claims']['Start']).'</td>';
     98      $Output .= '<td>'.round($Balance['Liabilities']['End'] - $Balance['Liabilities']['Start']).'</td>';
     99      $Output .= '<td>'.round($Balance['SmallAssets']['End'] - $Balance['SmallAssets']['Start']).'</td>';
     100      $Output .= '<td>'.round(($Balance['Income']['End'] - $Balance['Income']['Start']) - ($Balance['Spend']['End'] - $Balance['Spend']['Start'])).'</td></tr>';
     101    }
     102    $Output .= '</table>';
     103    return $Output;
     104  }
     105
     106  function ShowMonthlyBalance()
     107  {
     108    $Output = '<table class="WideTable" style="font-size: smaller;">';
     109    $Output .= '<tr><th colspan="4">Účetní období</th><th colspan="5">Na konci</th><th colspan="6">Během</th></tr>'.
     110      '<tr><th>Rok</th><th>Měsíc</th></th><th>Od</th><th>Do</th><th>Příjmy</th><th>Výdaje</th><th>Pohledávky</th><th>Závazky</th><th>Drobný majetek</th><th>Příjmy</th><th>Výdaje</th><th>Pohledávky</th><th>Závazky</th><th>Drobný majetek</th><th>Základ daně</th></tr>';
     111
     112    $this->StartEvidence = mktime(0, 0, 0, 12, 1, 2007);
     113    $StartYear = date('Y', $this->StartEvidence);
     114    $EndYear = date('Y', time());
     115    for($Year = $StartYear; $Year <= $EndYear; $Year++)
     116    {
     117      for($Month = 1; $Month <= 12; $Month++)
     118      {
     119        $EndTime = mktime(0, 0, 0, $Month, 31, $Year);
     120        //$Year = date('Y', $EndTime);
     121        $StartTime = mktime(0, 0, 0, $Month, 1, $Year);
     122        if(($StartTime < time()) and ($EndTime > $this->StartEvidence))
    90123        {
    91           $EndTime = mktime(0, 0, 0, 12, 31, $Year);
    92           //$Year = date('Y', $EndTime);
    93           $StartTime = mktime(0, 0, 0, 1, 1, $Year);
    94124          if($StartTime < $this->StartEvidence) $StartTime = $this->StartEvidence;
    95125
    96       $Balance = $this->GetTimePeriodBalance($StartTime, $EndTime);
    97 
    98           $Output .= '<tr><td>'.$Year.'</td><td>'.date(HumanDate(TimeToMysqlDateTime($StartTime))).'</td><td>'.date(HumanDate(TimeToMysqlDateTime($EndTime))).'</td>';
     126          $Balance = $this->GetTimePeriodBalance($StartTime, $EndTime);
     127
     128          $Output .= '<tr><td>'.$Year.'</td><td>'.$Month.'</td><td>'.date(HumanDate(TimeToMysqlDateTime($StartTime))).'</td><td>'.date(HumanDate(TimeToMysqlDateTime($EndTime))).'</td>';
    99129          $Output .= '<td>'.round($Balance['Income']['End']).'</td>';
    100130          $Output .= '<td>'.round($Balance['Spend']['End']).'</td>';
     
    110140          $Output .= '<td>'.round(($Balance['Income']['End'] - $Balance['Income']['Start']) - ($Balance['Spend']['End'] - $Balance['Spend']['Start'])).'</td></tr>';
    111141        }
    112         $Output .= '</table>';
     142      }
     143    }
     144    $Output .= '</table>';
     145    return $Output;
     146  }
     147
     148  function ShowIncomes()
     149  {
     150    $Table = array('Ne', 'Ano');
     151    $DbResult = $this->Database->select('FinanceYear', '*', 'Id='.$_GET['year']);
     152    $Year = $DbResult->fetch_assoc();
     153
     154    $Total = 0;
     155    $TotalTax = array(0, 0);
     156    $TotalCash = array(0, 0);
     157    $Output = '<strong>Příjmy za rok '.$Year['Year'].'</strong>';
     158    $Output .= '<table style="font-size: smaller;" class="WideTable">';
     159    $Output .= '<tr><th>Čas</th><th>Kód</th><th>Subjekt</th><th>Text</th><th>Hodnota [Kč]</th><th>Daňový</th><th>Hotovost</th></tr>';
     160    $DbResult = $this->Database->query('SELECT `FinanceOperation`.*, `DocumentLineCode`.`Name` AS `BillName`, `Subject`.`Name` AS `Name` FROM `FinanceOperation` '.
     161      'LEFT JOIN `Subject` ON `Subject`.`Id` = `FinanceOperation`.`Subject` '.
     162      'LEFT JOIN `FinanceOperationGroup` ON `FinanceOperationGroup`.`Id` = `FinanceOperation`.`Group` '.
     163      'LEFT JOIN `DocumentLineCode` ON `DocumentLineCode`.`Id` = `FinanceOperation`.`BillCode` '.
     164      'WHERE (`ValueSign` = 1) AND (`FinanceOperation`.`Time` >= "'.$Year['DateStart'].'") '.
     165      'AND (`FinanceOperation`.`Time` <= "'.$Year['DateEnd'].'") ORDER BY `Time`');
     166    while($Row = $DbResult->fetch_array())
     167    {
     168      $Row['Time'] = explode(' ', $Row['Time']);
     169      $Row['Time'] = $Row['Time'][0];
     170      $Output .= '<tr><td>'.HumanDate($Row['Time']).'</td><td>'.$Row['BillName'].
     171      '</td><td>'.$Row['Name'].'</td><td>'.$Row['Text'].'</td><td>'.$Row['Value'].
     172      '</td><td>'.$Table[$Row['Taxable']].'</td><td>'.$Table[$Row['Cash']].'</td></tr>';
     173      $Total += $Row['Value'];
     174      $TotalTax[$Row['Taxable']] += $Row['Value'];
     175      $TotalCash[$Row['Cash']] += $Row['Value'];
     176    }
     177    $Output .= '</table><br/>';
     178    $Output .= '<strong>Souhrn</strong><br/>';
     179    $Output .= 'Celkem: '.$Total.' Kč<br/>';
     180    $Output .= '  Daňové: '.$TotalTax[1].' Kč<br/>';
     181    $Output .= '  Nedaňové: '.$TotalTax[0].' Kč<br/>';
     182    $Output .= '  Hotovostní: '.$TotalCash[1].' Kč<br/>';
     183    $Output .= '  Bezhotovostní: '.$TotalCash[0].' Kč<br/>';
     184    return $Output;
     185  }
     186
     187  function ShowExpenses()
     188  {
     189    $Table = array('Ne', 'Ano');
     190    $DbResult = $this->Database->select('FinanceYear', '*', 'Id='.$_GET['year']);
     191    $Year = $DbResult->fetch_assoc();
     192
     193    $Total = 0;
     194    $TotalTax = array(0, 0);
     195    $TotalCash = array(0, 0);
     196    $Output = '<strong>Výdaje za rok '.$Year['Year'].'</strong>';
     197    $Output .= '<table style="font-size: smaller;" class="WideTable">';
     198    $Output .= '<tr><th>Čas</th><th>Kód</th><th>Subjekt</th><th>Text</th><th>Hodnota [Kč]</th><th>Daňový</th><th>Hotovost</th></tr>';
     199    $DbResult = $this->Database->query('SELECT `FinanceOperation`.*, `DocumentLineCode`.`Name` AS `BillName`, '.
     200      '`Subject`.`Name` AS `SubjectName`, `FinanceOperationGroup`.`ValueSign` AS `ValueSign` FROM `FinanceOperation` '.
     201      'LEFT JOIN `Subject` ON `Subject`.`Id` = `FinanceOperation`.`Subject` '.
     202      'LEFT JOIN `FinanceOperationGroup` ON `FinanceOperationGroup`.`Id` = `FinanceOperation`.`Group` '.
     203      'LEFT JOIN `DocumentLineCode` ON `DocumentLineCode`.`Id` = `FinanceOperation`.`BillCode` '.
     204      'WHERE (`FinanceOperationGroup`.`ValueSign` = -1) AND (`FinanceOperation`.`Time` >= "'.$Year['DateStart'].'") '.
     205      'AND (`FinanceOperation`.`Time` <= "'.$Year['DateEnd'].'") ORDER BY `Time`');
     206    while($Row = $DbResult->fetch_array())
     207    {
     208      $Row['Time'] = explode(' ', $Row['Time']);
     209      $Row['Time'] = $Row['Time'][0];
     210      $Row['Value'] = $Row['Value'] * $Row['ValueSign'];
     211      $Output .= '<tr><td>'.HumanDate($Row['Time']).'</td><td>'.$Row['BillName'].
     212      '</td><td>'.$Row['SubjectName'].'</td><td>'.$Row['Text'].'</td><td>'.$Row['Value'].
     213      '</td><td>'.$Table[$Row['Taxable']].'</td><td>'.$Table[$Row['Cash']].'</td></tr>';
     214      $Total += $Row['Value'];
     215      $TotalTax[$Row['Taxable']] += $Row['Value'];
     216      $TotalCash[$Row['Cash']] += $Row['Value'];
     217    }
     218    $Output .= '</table><br/>';
     219    $Output .= '<strong>Souhrn</strong><br/>';
     220    $Output .= 'Celkem: '.$Total.' Kč<br/>';
     221    $Output .= '  Daňové: '.$TotalTax[1].' Kč<br/>';
     222    $Output .= '  Nedaňové: '.$TotalTax[0].' Kč<br/>';
     223    $Output .= '  Hotovostní: '.$TotalCash[1].' Kč<br/>';
     224    $Output .= '  Bezhotovostní: '.$TotalCash[0].' Kč<br/>';
     225    return $Output;
     226  }
     227
     228  function ShowClaims()
     229  {
     230    $Table = array('Ne', 'Ano');
     231    $DbResult = $this->Database->select('FinanceYear', '*', 'Id='.$_GET['year']);
     232    $Year = $DbResult->fetch_assoc();
     233
     234    $Total = 0;
     235    $Output = '<strong>Pohledávky za rok '.$Year['Year'].'</strong>';
     236    $Output .= '<table style="font-size: smaller;" class="WideTable">';
     237    $Output .= '<tr><th>Čas vystavení</th><th>Kód</th><th>Subjekt</th><th>Text</th><th>Hodnota [Kč]</th></tr>';
     238    $DbResult = $this->Database->query('SELECT `FinanceInvoice`.*, '.
     239      '`DocumentLineCode`.`Name` AS `BillName`, `Subject`.`Name` AS `SubjectName`, '.
     240      '(SELECT GROUP_CONCAT(`Description` SEPARATOR ",") '.
     241      'FROM `FinanceInvoiceItem` WHERE `FinanceInvoiceItem`.`FinanceInvoice` = `FinanceInvoice`.`Id`) AS `Text` FROM `FinanceInvoice`'.
     242      'LEFT JOIN `Subject` ON `Subject`.`Id` = `FinanceInvoice`.`Subject` '.
     243      'LEFT JOIN `FinanceInvoiceGroup` ON `FinanceInvoiceGroup`.`Id` = `FinanceInvoice`.`Group` '.
     244      'LEFT JOIN `DocumentLineCode` ON `DocumentLineCode`.`Id` = `FinanceInvoice`.`BillCode` '.
     245      'WHERE (`FinanceInvoiceGroup`.`ValueSign` = 1) AND (`FinanceInvoice`.`Time` >= "'.$Year['DateStart'].
     246      '") AND (`FinanceInvoice`.`Time` <= "'.$Year['DateEnd'].'") ORDER BY `Time`');
     247    while($Row = $DbResult->fetch_array())
     248    {
     249      if($Row['TimePayment'] == '0000-00-00 00:00:00') $Row['TimePayment'] = '&nbsp;';
     250      $Output .= '<tr><td>'.HumanDate($Row['Time']).'</td><td>'.$Row['BillName'].
     251      '</td><td>'.$Row['SubjectName'].'</td><td>'.$Row['Text'].'</td><td>'.$Row['Value'].'</td></tr>';
     252      $Total += $Row['Value'];
     253    }
     254    $Output .= '</table><br/>';
     255    $Output .= 'Celkem: '.$Total.' Kč<br/>';
     256    return $Output;
     257  }
     258
     259  function ShowLiabilities()
     260  {
     261    $Table = array('Ne', 'Ano');
     262    $DbResult = $this->Database->select('FinanceYear', '*', 'Id='.$_GET['year']);
     263    $Year = $DbResult->fetch_assoc();
     264
     265    $Total = 0;
     266    $Output = '<strong>Závazky za rok '.$Year['Year'].'</strong>';
     267    $Output .= '<table style="font-size: smaller;" class="WideTable">';
     268    $Output .= '<tr><th>Čas vystavení</th><th>Kód</th><th>Subjekt</th><th>Text</th><th>Hodnota [Kč]</th></tr>';
     269    $DbResult = $this->Database->query('SELECT *, `DocumentLineCode`.`Name` AS `BillName`, `Subject`.`Name` AS `SubjectName`, '.
     270      '(SELECT GROUP_CONCAT(Description SEPARATOR ",") '.
     271      'FROM `FinanceInvoiceItem` WHERE `FinanceInvoiceItem`.`FinanceInvoice` = `FinanceInvoice`.`Id`) AS `Text` '.
     272      'FROM `FinanceInvoice` '.
     273      'LEFT JOIN `Subject` ON `Subject`.`Id` = `FinanceInvoice`.`Subject` '.
     274      'LEFT JOIN `FinanceInvoiceGroup` ON `FinanceInvoiceGroup`.`Id` = `FinanceInvoice`.`Group` '.
     275      'LEFT JOIN `DocumentLineCode` ON `DocumentLineCode`.`Id` = `FinanceInvoice`.`BillCode` '.
     276      'WHERE (`FinanceInvoiceGroup`.`ValueSign` = -1) AND (`FinanceInvoice`.`Time` >= "'.$Year['DateStart'].
     277      '") AND (FinanceInvoice.Time <= "'.$Year['DateEnd'].'") ORDER BY Time');
     278    while($Row = $DbResult->fetch_array())
     279    {
     280      if($Row['TimePayment'] == '0000-00-00 00:00:00') $Row['TimePayment'] = '&nbsp;';
     281      $Row['Value'] = $Row['Value'] * $Row['ValueSign'];
     282      $Output .= '<tr><td>'.HumanDate($Row['Time']).'</td><td>'.$Row['BillName'].
     283      '</td><td>'.$Row['SubjectName'].'</td><td>'.$Row['Text'].'</td><td>'.$Row['Value'].'</td></tr>';
     284      $Total += $Row['Value'];
     285    }
     286    $Output .= '</table><br/>';
     287    $Output .= 'Celkem: '.$Total.' Kč<br/>';
     288    return $Output;
     289  }
     290
     291  function ShowSubjectList()
     292  {
     293    $Output = '<strong>Seznam subjektů</strong>';
     294    $Output .= '<table style="font-size: smaller;" class="WideTable">';
     295    $Output .= '<tr><th>Jméno</th><th>Závazky [Kč]</th><th>Pohledávky [Kč]</th><th>Příjmy [Kč]</th><th>Výdaje [Kč]</th><th>Stav účtu</th><th>Starý systém</th></tr>';
     296    $DbResult = $this->Database->query('SELECT Id, Name, 0 AS Cash, '.
     297      '(SELECT SUM(T1.Value) FROM FinanceInvoice AS T1 '.
     298      'LEFT JOIN `FinanceInvoiceGroup` ON `FinanceInvoiceGroup`.`Id` = `T1`.`Group` '.
     299      'WHERE (T1.Subject = Subject.Id) AND (`FinanceInvoiceGroup`.ValueSign = 1)) AS `Claims`, '.
     300      '(SELECT SUM(T2.Value) FROM FinanceInvoice AS T2 '.
     301      'LEFT JOIN `FinanceInvoiceGroup` ON `FinanceInvoiceGroup`.`Id` = `T2`.`Group` '.
     302      'WHERE (T2.Subject = Subject.Id) AND (`FinanceInvoiceGroup`.`ValueSign` = 1) AND (TimePayment IS NULL)) AS `OpenedClaims`, '.
     303      '(SELECT -SUM(T3.Value) FROM FinanceInvoice AS T3 '.
     304      'LEFT JOIN `FinanceInvoiceGroup` ON `FinanceInvoiceGroup`.`Id` = `T3`.`Group` '.
     305      'WHERE (T3.Subject = Subject.Id) AND (`FinanceInvoiceGroup`.`ValueSign` = -1)) AS `Liabilities`, '.
     306      '(SELECT -SUM(T4.Value) FROM FinanceInvoice AS T4 '.
     307      'LEFT JOIN `FinanceInvoiceGroup` ON `FinanceInvoiceGroup`.`Id` = `T4`.`Group` '.
     308      'WHERE (T4.Subject = Subject.Id) AND (`FinanceInvoiceGroup`.`ValueSign` = -1) AND (`TimePayment` IS NULL)) AS `OpenedLiabilities`, '.
     309      '(SELECT SUM(T5.Value) FROM FinanceOperation AS T5 '.
     310      'LEFT JOIN `FinanceOperationGroup` ON `FinanceOperationGroup`.`Id` = `T5`.`Group` '.
     311      'WHERE (T5.Subject = Subject.Id) AND (`FinanceOperationGroup`.`ValueSign` = 1)) AS `Gains`, '.
     312      '(SELECT SUM(T6.Value) FROM FinanceOperation AS T6 '.
     313      'LEFT JOIN `FinanceOperationGroup` ON `FinanceOperationGroup`.`Id` = `T6`.`Group` '.
     314      'WHERE (T6.Subject = Subject.Id) AND (`FinanceOperationGroup`.`ValueSign` = -1)) AS `Spends` '.
     315      'FROM Subject ORDER BY Name');
     316    while($Row = $DbResult->fetch_assoc())
     317    {
     318      $Output .= '<tr><td style="text-align: left;"><a href="?table=SubjectAccount&Id='.$Row['Id'].'">'.$Row['Name'].'</a></td><td>'.$Row['Liabilities'].' / '.$Row['OpenedLiabilities'].'</td><td>'.$Row['Claims'].' / '.$Row['OpenedClaims'].'</td><td>'.$Row['Gains'].'</td><td>'.$Row['Spends'].'</td><td>'.($Row['Gains'] - $Row['Spends'] - $Row['Claims'] + $Row['Liabilities']).'</td><td>'.$Row['Cash'].'</td></tr>';
     319    }
     320    $Output .= '</table>';
     321    return $Output;
     322  }
     323
     324  function ShowSmallAssets()
     325  {
     326    $Output = '<strong>Drobný majetek</strong>';
     327    $Output .= '<table style="font-size: smaller;" border="1" cellspacing="0" cellpadding="3">';
     328    $Output .= '<tr><th>Název</th><th>Hodnota [Kč]</th><th>Datum zakoupení</th><th>Datum vyřezení</th></tr>';
     329    $DbResult = $this->Database->query('SELECT Product.Name AS Name, StockSerialNumber.SellPrice AS Price, StockSerialNumber.TimeEnlistment AS TimeEnlistment, StockSerialNumber.TimeElimination AS TimeElimination '.
     330      'FROM StockSerialNumber JOIN Product ON Product.Id = StockSerialNumber.Product '.
     331      'WHERE (TimeElimination IS NOT NULL)');
     332    while($Row = $DbResult->fetch_array())
     333    {
     334      $Output .= '<tr><td>'.$Row['Name'].'</td><td>'.$Row['Price'].'</td><td>'.$Row['TimeEnlistment'].'</td><td>'.$Row['TimeElimination'].'</td></tr>';
     335    }
     336    $Output .= '</table>';
     337    return $Output;
     338  }
     339
     340  function ShowSubjectAccount()
     341  {
     342    $Output = '<table style="width: 100%"><tr><td style="vertical-align: top;">';
     343    $Output .= '<strong>Výpis příjmů/výdajů</strong>';
     344    $Output .= '<table style="font-size: smaller;" border="1" cellspacing="0" cellpadding="3">';
     345    $Output .= '<tr><th>Datum</th><th>Název</th><th>Hodnota [Kč]</th><th>Doklad</th></tr>';
     346    $DbResult = $this->Database->query('SELECT `FinanceOperation`.*, `DocumentLineCode`.`Name` AS `BillName` '.
     347      'FROM `FinanceOperation` '.
     348      'LEFT JOIN `DocumentLineCode` ON `DocumentLineCode`.`Id` = `FinanceOperation`.`BillCode` '.
     349      'LEFT JOIN `FinanceOperationGroup` ON `FinanceOperationGroup`.`Id` = `FinanceOperation`.`Group` '.
     350      'WHERE `Subject`='.$_GET['Id'].' ORDER BY `Time`');
     351    while($Row = $DbResult->fetch_array())
     352    {
     353      $Output .= '<tr><td>'.HumanDate($Row['Time']).'</td><td>'.$Row['Text'].
     354      '</td><td>'.$Row['Value'].'</td><td>'.$Row['BillName'].'</td></tr>';
     355    }
     356    $Output .= '</table></td><td style="vertical-align: top;">';
     357
     358    $Output .= '<strong>Výpis závazků/pohledávek</strong>';
     359    $Output .= '<table style="font-size: smaller;" border="1" cellspacing="0" cellpadding="3">';
     360    $Output .= '<tr><th>Datum vytvoření</th><th>Datum zaplacení</th><th>Název</th><th>Hodnota [Kč]</th><th>Doklad</th></tr>';
     361    $DbResult = $this->Database->query('SELECT `FinanceInvoice`.*, (SELECT GROUP_CONCAT(Description SEPARATOR ",") '.
     362      'FROM FinanceInvoiceItem WHERE `FinanceInvoiceItem`.`FinanceInvoice` = `FinanceInvoice`.`Id`) AS `Text`, `DocumentLineCode`.`Name` AS `BillName` '.
     363      'FROM `FinanceInvoice` '.
     364      'LEFT JOIN `DocumentLineCode` ON `DocumentLineCode`.`Id` = `FinanceInvoice`.`BillCode` '.
     365      'WHERE `Subject`='.$_GET['Id'].' ORDER BY `Time`');
     366    while($Row = $DbResult->fetch_array())
     367    {
     368      $Output .= '<tr><td>'.HumanDate($Row['Time']).'</td><td>'.HumanDate($Row['TimePayment']).
     369      '</td><td>'.$Row['Text'].'</td><td>'.round($Row['Value'], $Finance->Rounding).'</td><td>'.$Row['BillName'].'</td></tr>';
     370    }
     371    $Output .= '</table></td></tr></table>';
     372
     373    /*$Output .= '<strong>Výpis záloh</strong>';
     374     $Output .= '<table style="font-size: smaller;" border="1" cellspacing="0" cellpadding="3">';
     375     $Output .= '<tr><th>Datum vytvoření</th><th>Datum zaplacení</th><th>Název</th><th>Hodnota [Kč]</th></tr>';
     376     $DbResult = $this->Database->select('FinanceAdvances', '*', 'Subject='.$_GET['Id']);
     377     while($Row = $DbResult->fetch_array())
     378     {
     379     $Output .= '<tr><td>'.$Row['Time'].'</td><td>'.$Row['TimePass'].'</td><td>'.$Row['ValueSign'].'</td><td>'.($Row['Value']).'</td><td>'.$Row['CashFlowId'].'</td></tr>';
     380     }
     381     $Output .= '</table>';*/
     382
     383    $DbResult = $this->Database->query('SELECT Id, 0 AS Cash, (SELECT SUM(FinanceInvoice.Value * FinanceInvoice.ValueSign) '.
     384      'FROM FinanceInvoice WHERE (FinanceInvoice.Subject = Subject.Id) AND '.
     385      '(FinanceInvoice.ValueSign = 1)) as Claims, (SELECT SUM(FinanceInvoice.Value * FinanceInvoice.ValueSign) '.
     386      'FROM FinanceInvoice WHERE (FinanceInvoice.Subject = Subject.Id) AND ('.
     387      'FinanceInvoice.ValueSign = 1) AND (TimePayment IS NULL)) as OpenedClaims, '.
     388      '(SELECT SUM(FinanceInvoice.Value * FinanceInvoice.ValueSign) FROM FinanceInvoice '.
     389      'WHERE (FinanceInvoice.Subject = Subject.Id) AND (FinanceInvoice.ValueSign = -1)) AS '.
     390      'Liabilities, (SELECT SUM(FinanceInvoice.Value) FROM FinanceInvoice '.
     391      'WHERE (FinanceInvoice.Subject = Subject.Id) AND (FinanceInvoice.ValueSign = -1) '.
     392      'AND (TimePayment IS NULL)) AS OpenedLiabilities, '.
     393      '(SELECT SUM(FinanceOperation.Value*FinanceOperation.ValueSign) '.
     394      'FROM FinanceOperation WHERE FinanceOperation.Subject = Subject.Id AND FinanceOperation.ValueSign = 1) '.
     395      'AS Gains, (SELECT SUM(FinanceOperation.Value*FinanceOperation.ValueSign) FROM FinanceOperation WHERE '.
     396      'FinanceOperation.Subject = Subject.Id AND FinanceOperation.ValueSign = -1) as Spends '.
     397      'FROM Subject WHERE Id='.$_GET['Id']);
     398    $Row = $DbResult->fetch_array();
     399    $Output .= 'Stav placení: '.(-$Row['OpenedClaims'] + Abs($Row['OpenedLiabilities']));
     400    return $Output;
     401  }
     402
     403  function ShowDefault()
     404  {
     405    $Output = '<strong>Celkové přehledy</strong><br/>';
     406    $Output .= '<a href="?table=AnnualBalance">Účetní závěrka</a><br />';
     407    $Output .= '<a href="?table=MonthlyBalance">Měsíční přehledy</a><br />';
     408    $Output .= '<a href="?table=SubjectList">Seznam subjektů</a><br />';
     409    $Output .= '<a href="?table=SmallAssets">Drobný majetek</a><br />';
     410    $Output .= '<br/>';
     411    $Output .= '<strong>Roční přehledy</strong><br/>';
     412    $Output .= $this->ShowFinanceYears();
     413    if(array_key_exists('year', $_GET))
     414    {
     415      $Year = $_GET['year'] * 1;
     416      $Output .= '<a href="?table=Incomes&amp;year='.$Year.'">Příjmy</a><br />';
     417      $Output .= '<a href="?table=Expenses&amp;year='.$Year.'">Výdaje</a><br />';
     418      $Output .= '<a href="?table=Claims&amp;year='.$Year.'">Pohledávky</a><br />';
     419      $Output .= '<a href="?table=Liabilities&amp;year='.$Year.'">Závazky</a><br />';
     420      $Output .= '<a href="?table=Advantages&amp;year='.$Year.'">Zálohy</a><br />';
     421      $Output .= '<a href="?table=YearReport&amp;year='.$Year.'">Souhrný přehled</a><br />';
     422    }
     423    return $Output;
     424  }
     425
     426  function Show()
     427  {
     428    if(!$this->System->User->CheckPermission('Finance', 'TradingStatus'))
     429      return('Nemáte oprávnění');
     430
     431    $Finance = &$this->System->Modules['Finance'];
     432
     433    $Output = '';
     434    if(!array_key_exists('table', $_GET)) $_GET['table'] = '';
     435    switch($_GET['table'])
     436    {
     437      case 'AnnualBalance':
     438        $Output = $this->ShowAnnualBalance();
    113439        break;
    114440      case 'MonthlyBalance':
    115         $Output = '<table class="WideTable" style="font-size: smaller;">';
    116         $Output .= '<tr><th colspan="4">Účetní období</th><th colspan="5">Na konci</th><th colspan="6">Během</th></tr>'.
    117       '<tr><th>Rok</th><th>Měsíc</th></th><th>Od</th><th>Do</th><th>Příjmy</th><th>Výdaje</th><th>Pohledávky</th><th>Závazky</th><th>Drobný majetek</th><th>Příjmy</th><th>Výdaje</th><th>Pohledávky</th><th>Závazky</th><th>Drobný majetek</th><th>Základ daně</th></tr>';
    118 
    119         $this->StartEvidence = mktime(0, 0, 0, 12, 1, 2007);
    120         $StartYear = date('Y', $this->StartEvidence);
    121         $EndYear = date('Y', time());
    122         for($Year = $StartYear; $Year <= $EndYear; $Year++)
    123         {
    124           for($Month = 1; $Month <= 12; $Month++)
    125           {
    126             $EndTime = mktime(0, 0, 0, $Month, 31, $Year);
    127             //$Year = date('Y', $EndTime);
    128             $StartTime = mktime(0, 0, 0, $Month, 1, $Year);
    129             if(($StartTime < time()) and ($EndTime > $this->StartEvidence))
    130       {
    131         if($StartTime < $this->StartEvidence) $StartTime = $this->StartEvidence;
    132 
    133           $Balance = $this->GetTimePeriodBalance($StartTime, $EndTime);
    134 
    135               $Output .= '<tr><td>'.$Year.'</td><td>'.$Month.'</td><td>'.date(HumanDate(TimeToMysqlDateTime($StartTime))).'</td><td>'.date(HumanDate(TimeToMysqlDateTime($EndTime))).'</td>';
    136               $Output .= '<td>'.round($Balance['Income']['End']).'</td>';
    137               $Output .= '<td>'.round($Balance['Spend']['End']).'</td>';
    138               $Output .= '<td>'.round($Balance['Claims']['End']).'</td>';
    139               $Output .= '<td>'.round($Balance['Liabilities']['End']).'</td>';
    140               $Output .= '<td>'.round($Balance['SmallAssets']['End']).'</td>';
    141 
    142               $Output .= '<td>'.round($Balance['Income']['End'] - $Balance['Income']['Start']).'</td>';
    143               $Output .= '<td>'.round($Balance['Spend']['End'] - $Balance['Spend']['Start']).'</td>';
    144               $Output .= '<td>'.round($Balance['Claims']['End'] - $Balance['Claims']['Start']).'</td>';
    145               $Output .= '<td>'.round($Balance['Liabilities']['End'] - $Balance['Liabilities']['Start']).'</td>';
    146               $Output .= '<td>'.round($Balance['SmallAssets']['End'] - $Balance['SmallAssets']['Start']).'</td>';
    147               $Output .= '<td>'.round(($Balance['Income']['End'] - $Balance['Income']['Start']) - ($Balance['Spend']['End'] - $Balance['Spend']['Start'])).'</td></tr>';
    148         }
    149       }
    150         }
    151         $Output .= '</table>';
     441        $Output = $this->ShowMonthlyBalance();
     442        break;
     443      case 'YearReport':
     444        $Output .= $this->ShowIncomes().'<hr>';
     445        $Output .= $this->ShowExpenses().'<hr>';
     446        $Output .= $this->ShowClaims().'<hr>';
     447        $Output .= $this->ShowLiabilities().'<hr>';
    152448        break;
    153449      case 'Incomes':
    154         $Table = array('Ne', 'Ano');
    155         $DbResult = $this->Database->select('FinanceYear', '*', 'Id='.$_GET['year']);
    156         $Year = $DbResult->fetch_assoc();
    157 
    158         $Total = 0;
    159         $TotalTax = array(0, 0);
    160         $TotalCash = array(0, 0);
    161         $Output .= '<strong>Příjmy za rok '.$Year['Year'].'</strong>';
    162         $Output .= '<table style="font-size: smaller;" class="WideTable">';
    163         $Output .= '<tr><th>Čas</th><th>Kód</th><th>Subjekt</th><th>Text</th><th>Hodnota [Kč]</th><th>Daňový</th><th>Hotovost</th></tr>';
    164         $DbResult = $this->Database->query('SELECT `FinanceOperation`.*, `DocumentLineCode`.`Name` AS `BillName`, `Subject`.`Name` AS `Name` FROM `FinanceOperation` '.
    165           'LEFT JOIN `Subject` ON `Subject`.`Id` = `FinanceOperation`.`Subject` '.
    166           'LEFT JOIN `FinanceOperationGroup` ON `FinanceOperationGroup`.`Id` = `FinanceOperation`.`Group` '.
    167           'LEFT JOIN `DocumentLineCode` ON `DocumentLineCode`.`Id` = `FinanceOperation`.`BillCode` '.
    168           'WHERE (`ValueSign` = 1) AND (`FinanceOperation`.`Time` >= "'.$Year['DateStart'].'") '.
    169           'AND (`FinanceOperation`.`Time` <= "'.$Year['DateEnd'].'") ORDER BY `Time`');
    170         while($Row = $DbResult->fetch_array())
    171         {
    172           $Row['Time'] = explode(' ', $Row['Time']);
    173           $Row['Time'] = $Row['Time'][0];
    174           $Output .= '<tr><td>'.HumanDate($Row['Time']).'</td><td>'.$Row['BillName'].
    175             '</td><td>'.$Row['Name'].'</td><td>'.$Row['Text'].'</td><td>'.$Row['Value'].
    176             '</td><td>'.$Table[$Row['Taxable']].'</td><td>'.$Table[$Row['Cash']].'</td></tr>';
    177           $Total += $Row['Value'];
    178           $TotalTax[$Row['Taxable']] += $Row['Value'];
    179           $TotalCash[$Row['Cash']] += $Row['Value'];
    180         }
    181         $Output .= '</table><br/>';
    182         $Output .= '<strong>Souhrn</strong><br/>';
    183         $Output .= 'Celkem: '.$Total.' Kč<br/>';
    184         $Output .= '  Daňové: '.$TotalTax[1].' Kč<br/>';
    185         $Output .= '  Nedaňové: '.$TotalTax[0].' Kč<br/>';
    186         $Output .= '  Hotovostní: '.$TotalCash[1].' Kč<br/>';
    187         $Output .= '  Bezhotovostní: '.$TotalCash[0].' Kč<br/>';
     450        $Output = $this->ShowIncomes();
    188451        break;
    189452      case 'Expenses':
    190         $Table = array('Ne', 'Ano');
    191         $DbResult = $this->Database->select('FinanceYear', '*', 'Id='.$_GET['year']);
    192         $Year = $DbResult->fetch_assoc();
    193 
    194         $Total = 0;
    195         $TotalTax = array(0, 0);
    196         $TotalCash = array(0, 0);
    197         $Output .= '<strong>Výdaje za rok '.$Year['Year'].'</strong>';
    198         $Output .= '<table style="font-size: smaller;" class="WideTable">';
    199         $Output .= '<tr><th>Čas</th><th>Kód</th><th>Subjekt</th><th>Text</th><th>Hodnota [Kč]</th><th>Daňový</th><th>Hotovost</th></tr>';
    200         $DbResult = $this->Database->query('SELECT `FinanceOperation`.*, `DocumentLineCode`.`Name` AS `BillName`, '.
    201           '`Subject`.`Name` AS `SubjectName`, `FinanceOperationGroup`.`ValueSign` AS `ValueSign` FROM `FinanceOperation` '.
    202           'LEFT JOIN `Subject` ON `Subject`.`Id` = `FinanceOperation`.`Subject` '.
    203           'LEFT JOIN `FinanceOperationGroup` ON `FinanceOperationGroup`.`Id` = `FinanceOperation`.`Group` '.
    204           'LEFT JOIN `DocumentLineCode` ON `DocumentLineCode`.`Id` = `FinanceOperation`.`BillCode` '.
    205           'WHERE (`FinanceOperationGroup`.`ValueSign` = -1) AND (`FinanceOperation`.`Time` >= "'.$Year['DateStart'].'") '.
    206           'AND (`FinanceOperation`.`Time` <= "'.$Year['DateEnd'].'") ORDER BY `Time`');
    207         while($Row = $DbResult->fetch_array())
    208         {
    209           $Row['Time'] = explode(' ', $Row['Time']);
    210           $Row['Time'] = $Row['Time'][0];
    211           $Row['Value'] = $Row['Value'] * $Row['ValueSign'];
    212           $Output .= '<tr><td>'.HumanDate($Row['Time']).'</td><td>'.$Row['BillName'].
    213             '</td><td>'.$Row['SubjectName'].'</td><td>'.$Row['Text'].'</td><td>'.$Row['Value'].
    214             '</td><td>'.$Table[$Row['Taxable']].'</td><td>'.$Table[$Row['Cash']].'</td></tr>';
    215           $Total += $Row['Value'];
    216           $TotalTax[$Row['Taxable']] += $Row['Value'];
    217           $TotalCash[$Row['Cash']] += $Row['Value'];
    218         }
    219         $Output .= '</table><br/>';
    220         $Output .= '<strong>Souhrn</strong><br/>';
    221         $Output .= 'Celkem: '.$Total.' Kč<br/>';
    222         $Output .= '  Daňové: '.$TotalTax[1].' Kč<br/>';
    223         $Output .= '  Nedaňové: '.$TotalTax[0].' Kč<br/>';
    224         $Output .= '  Hotovostní: '.$TotalCash[1].' Kč<br/>';
    225         $Output .= '  Bezhotovostní: '.$TotalCash[0].' Kč<br/>';
     453        $Output = $this->ShowExpenses();
    226454        break;
    227455      case 'Claims':
    228         $Table = array('Ne', 'Ano');
    229         $DbResult = $this->Database->select('FinanceYear', '*', 'Id='.$_GET['year']);
    230         $Year = $DbResult->fetch_assoc();
    231 
    232         $Total = 0;
    233         $Output .= '<strong>Pohledávky za rok '.$Year['Year'].'</strong>';
    234         $Output .= '<table style="font-size: smaller;" class="WideTable">';
    235         $Output .= '<tr><th>Čas vystavení</th><th>Kód</th><th>Subjekt</th><th>Text</th><th>Hodnota [Kč]</th></tr>';
    236         $DbResult = $this->Database->query('SELECT `FinanceInvoice`.*, '.
    237           '`DocumentLineCode`.`Name` AS `BillName`, `Subject`.`Name` AS `SubjectName`, '.
    238           '(SELECT GROUP_CONCAT(`Description` SEPARATOR ",") '.
    239           'FROM `FinanceInvoiceItem` WHERE `FinanceInvoiceItem`.`FinanceInvoice` = `FinanceInvoice`.`Id`) AS `Text` FROM `FinanceInvoice`'.
    240           'LEFT JOIN `Subject` ON `Subject`.`Id` = `FinanceInvoice`.`Subject` '.
    241           'LEFT JOIN `FinanceInvoiceGroup` ON `FinanceInvoiceGroup`.`Id` = `FinanceInvoice`.`Group` '.
    242           'LEFT JOIN `DocumentLineCode` ON `DocumentLineCode`.`Id` = `FinanceInvoice`.`BillCode` '.
    243           'WHERE (`FinanceInvoiceGroup`.`ValueSign` = 1) AND (`FinanceInvoice`.`Time` >= "'.$Year['DateStart'].
    244           '") AND (`FinanceInvoice`.`Time` <= "'.$Year['DateEnd'].'") ORDER BY `Time`');
    245         while($Row = $DbResult->fetch_array())
    246         {
    247           if($Row['TimePayment'] == '0000-00-00 00:00:00') $Row['TimePayment'] = '&nbsp;';
    248           $Output .= '<tr><td>'.HumanDate($Row['Time']).'</td><td>'.$Row['BillName'].
    249             '</td><td>'.$Row['SubjectName'].'</td><td>'.$Row['Text'].'</td><td>'.$Row['Value'].'</td></tr>';
    250           $Total += $Row['Value'];
    251         }
    252         $Output .= '</table><br/>';
    253         $Output .= 'Celkem: '.$Total.' Kč<br/>';
    254         break;
    255      case 'Liabilities':
    256         $Table = array('Ne', 'Ano');
    257         $DbResult = $this->Database->select('FinanceYear', '*', 'Id='.$_GET['year']);
    258         $Year = $DbResult->fetch_assoc();
    259 
    260         $Total = 0;
    261         $Output .= '<strong>Závazky za rok '.$Year['Year'].'</strong>';
    262         $Output .= '<table style="font-size: smaller;" class="WideTable">';
    263         $Output .= '<tr><th>Čas vystavení</th><th>Kód</th><th>Subjekt</th><th>Text</th><th>Hodnota [Kč]</th></tr>';
    264         $DbResult = $this->Database->query('SELECT *, `DocumentLineCode`.`Name` AS `BillName`, `Subject`.`Name` AS `SubjectName`, '.
    265           '(SELECT GROUP_CONCAT(Description SEPARATOR ",") '.
    266           'FROM `FinanceInvoiceItem` WHERE `FinanceInvoiceItem`.`FinanceInvoice` = `FinanceInvoice`.`Id`) AS `Text` '.
    267           'FROM `FinanceInvoice` '.
    268           'LEFT JOIN `Subject` ON `Subject`.`Id` = `FinanceInvoice`.`Subject` '.
    269           'LEFT JOIN `FinanceInvoiceGroup` ON `FinanceInvoiceGroup`.`Id` = `FinanceInvoice`.`Group` '.
    270           'LEFT JOIN `DocumentLineCode` ON `DocumentLineCode`.`Id` = `FinanceInvoice`.`BillCode` '.
    271           'WHERE (`FinanceInvoiceGroup`.`ValueSign` = -1) AND (`FinanceInvoice`.`Time` >= "'.$Year['DateStart'].
    272           '") AND (FinanceInvoice.Time <= "'.$Year['DateEnd'].'") ORDER BY Time');
    273         while($Row = $DbResult->fetch_array())
    274         {
    275           if($Row['TimePayment'] == '0000-00-00 00:00:00') $Row['TimePayment'] = '&nbsp;';
    276           $Row['Value'] = $Row['Value'] * $Row['ValueSign'];
    277           $Output .= '<tr><td>'.HumanDate($Row['Time']).'</td><td>'.$Row['BillName'].
    278             '</td><td>'.$Row['SubjectName'].'</td><td>'.$Row['Text'].'</td><td>'.$Row['Value'].'</td></tr>';
    279           $Total += $Row['Value'];
    280         }
    281         $Output .= '</table><br/>';
    282         $Output .= 'Celkem: '.$Total.' Kč<br/>';
     456        $Output = $this->ShowClaims();
     457        break;
     458      case 'Liabilities':
     459        $Output = $this->ShowLiabilities();
    283460        break;
    284461      case 'SubjectList':
    285         $Output .= '<strong>Seznam subjektů</strong>';
    286         $Output .= '<table style="font-size: smaller;" class="WideTable">';
    287         $Output .= '<tr><th>Jméno</th><th>Závazky [Kč]</th><th>Pohledávky [Kč]</th><th>Příjmy [Kč]</th><th>Výdaje [Kč]</th><th>Stav účtu</th><th>Starý systém</th></tr>';
    288         $DbResult = $this->Database->query('SELECT Id, Name, 0 AS Cash, '.
    289         '(SELECT SUM(T1.Value) FROM FinanceInvoice AS T1 '.
    290          'LEFT JOIN `FinanceInvoiceGroup` ON `FinanceInvoiceGroup`.`Id` = `T1`.`Group` '.
    291          'WHERE (T1.Subject = Subject.Id) AND (`FinanceInvoiceGroup`.ValueSign = 1)) AS `Claims`, '.
    292         '(SELECT SUM(T2.Value) FROM FinanceInvoice AS T2 '.
    293          'LEFT JOIN `FinanceInvoiceGroup` ON `FinanceInvoiceGroup`.`Id` = `T2`.`Group` '.
    294          'WHERE (T2.Subject = Subject.Id) AND (`FinanceInvoiceGroup`.`ValueSign` = 1) AND (TimePayment IS NULL)) AS `OpenedClaims`, '.
    295         '(SELECT -SUM(T3.Value) FROM FinanceInvoice AS T3 '.
    296         'LEFT JOIN `FinanceInvoiceGroup` ON `FinanceInvoiceGroup`.`Id` = `T3`.`Group` '.
    297         'WHERE (T3.Subject = Subject.Id) AND (`FinanceInvoiceGroup`.`ValueSign` = -1)) AS `Liabilities`, '.
    298         '(SELECT -SUM(T4.Value) FROM FinanceInvoice AS T4 '.
    299         'LEFT JOIN `FinanceInvoiceGroup` ON `FinanceInvoiceGroup`.`Id` = `T4`.`Group` '.
    300         'WHERE (T4.Subject = Subject.Id) AND (`FinanceInvoiceGroup`.`ValueSign` = -1) AND (`TimePayment` IS NULL)) AS `OpenedLiabilities`, '.
    301         '(SELECT SUM(T5.Value) FROM FinanceOperation AS T5 '.
    302         'LEFT JOIN `FinanceOperationGroup` ON `FinanceOperationGroup`.`Id` = `T5`.`Group` '.
    303         'WHERE (T5.Subject = Subject.Id) AND (`FinanceOperationGroup`.`ValueSign` = 1)) AS `Gains`, '.
    304         '(SELECT SUM(T6.Value) FROM FinanceOperation AS T6 '.
    305         'LEFT JOIN `FinanceOperationGroup` ON `FinanceOperationGroup`.`Id` = `T6`.`Group` '.
    306         'WHERE (T6.Subject = Subject.Id) AND (`FinanceOperationGroup`.`ValueSign` = -1)) AS `Spends` '.
    307         'FROM Subject ORDER BY Name');
    308         while($Row = $DbResult->fetch_assoc())
    309         {
    310           $Output .= '<tr><td style="text-align: left;"><a href="?table=SubjectAccount&Id='.$Row['Id'].'">'.$Row['Name'].'</a></td><td>'.$Row['Liabilities'].' / '.$Row['OpenedLiabilities'].'</td><td>'.$Row['Claims'].' / '.$Row['OpenedClaims'].'</td><td>'.$Row['Gains'].'</td><td>'.$Row['Spends'].'</td><td>'.($Row['Gains'] - $Row['Spends'] - $Row['Claims'] + $Row['Liabilities']).'</td><td>'.$Row['Cash'].'</td></tr>';
    311         }
    312         $Output .= '</table>';
     462        $Output = $this->ShowSubjectList();
    313463        break;
    314464      case 'SmallAssets':
    315         $Output .= '<strong>Drobný majetek</strong>';
    316         $Output .= '<table style="font-size: smaller;" border="1" cellspacing="0" cellpadding="3">';
    317         $Output .= '<tr><th>Název</th><th>Hodnota [Kč]</th><th>Datum zakoupení</th><th>Datum vyřezení</th></tr>';
    318         $DbResult = $this->Database->query('SELECT Product.Name AS Name, StockSerialNumber.SellPrice AS Price, StockSerialNumber.TimeEnlistment AS TimeEnlistment, StockSerialNumber.TimeElimination AS TimeElimination '.
    319           'FROM StockSerialNumber JOIN Product ON Product.Id = StockSerialNumber.Product '.
    320           'WHERE (TimeElimination IS NOT NULL)');
    321         while($Row = $DbResult->fetch_array())
    322         {
    323           $Output .= '<tr><td>'.$Row['Name'].'</td><td>'.$Row['Price'].'</td><td>'.$Row['TimeEnlistment'].'</td><td>'.$Row['TimeElimination'].'</td></tr>';
    324         }
    325         $Output .= '</table>';
     465        $Output = $this->ShowSmallAssets();
    326466        break;
    327467      case 'SubjectAccount':
    328         $Output .= '<table style="width: 100%"><tr><td style="vertical-align: top;">';
    329         $Output .= '<strong>Výpis příjmů/výdajů</strong>';
    330         $Output .= '<table style="font-size: smaller;" border="1" cellspacing="0" cellpadding="3">';
    331         $Output .= '<tr><th>Datum</th><th>Název</th><th>Hodnota [Kč]</th><th>Doklad</th></tr>';
    332         $DbResult = $this->Database->query('SELECT `FinanceOperation`.*, `DocumentLineCode`.`Name` AS `BillName` '.
    333           'FROM `FinanceOperation` '.
    334           'LEFT JOIN `DocumentLineCode` ON `DocumentLineCode`.`Id` = `FinanceOperation`.`BillCode` '.
    335           'LEFT JOIN `FinanceOperationGroup` ON `FinanceOperationGroup`.`Id` = `FinanceOperation`.`Group` '.
    336           'WHERE `Subject`='.$_GET['Id'].' ORDER BY `Time`');
    337         while($Row = $DbResult->fetch_array())
    338         {
    339           $Output .= '<tr><td>'.HumanDate($Row['Time']).'</td><td>'.$Row['Text'].
    340             '</td><td>'.$Row['Value'].'</td><td>'.$Row['BillName'].'</td></tr>';
    341         }
    342         $Output .= '</table></td><td style="vertical-align: top;">';
    343 
    344         $Output .= '<strong>Výpis závazků/pohledávek</strong>';
    345         $Output .= '<table style="font-size: smaller;" border="1" cellspacing="0" cellpadding="3">';
    346         $Output .= '<tr><th>Datum vytvoření</th><th>Datum zaplacení</th><th>Název</th><th>Hodnota [Kč]</th><th>Doklad</th></tr>';
    347         $DbResult = $this->Database->query('SELECT `FinanceInvoice`.*, (SELECT GROUP_CONCAT(Description SEPARATOR ",") '.
    348           'FROM FinanceInvoiceItem WHERE `FinanceInvoiceItem`.`FinanceInvoice` = `FinanceInvoice`.`Id`) AS `Text`, `DocumentLineCode`.`Name` AS `BillName` '.
    349           'FROM `FinanceInvoice` '.
    350           'LEFT JOIN `DocumentLineCode` ON `DocumentLineCode`.`Id` = `FinanceInvoice`.`BillCode` '.
    351           'WHERE `Subject`='.$_GET['Id'].' ORDER BY `Time`');
    352         while($Row = $DbResult->fetch_array())
    353         {
    354           $Output .= '<tr><td>'.HumanDate($Row['Time']).'</td><td>'.HumanDate($Row['TimePayment']).
    355             '</td><td>'.$Row['Text'].'</td><td>'.round($Row['Value'], $Finance->Rounding).'</td><td>'.$Row['BillName'].'</td></tr>';
    356         }
    357         $Output .= '</table></td></tr></table>';
    358 
    359         /*$Output .= '<strong>Výpis záloh</strong>';
    360         $Output .= '<table style="font-size: smaller;" border="1" cellspacing="0" cellpadding="3">';
    361         $Output .= '<tr><th>Datum vytvoření</th><th>Datum zaplacení</th><th>Název</th><th>Hodnota [Kč]</th></tr>';
    362         $DbResult = $this->Database->select('FinanceAdvances', '*', 'Subject='.$_GET['Id']);
    363         while($Row = $DbResult->fetch_array())
    364         {
    365           $Output .= '<tr><td>'.$Row['Time'].'</td><td>'.$Row['TimePass'].'</td><td>'.$Row['ValueSign'].'</td><td>'.($Row['Value']).'</td><td>'.$Row['CashFlowId'].'</td></tr>';
    366         }
    367         $Output .= '</table>';*/
    368 
    369         $DbResult = $this->Database->query('SELECT Id, 0 AS Cash, (SELECT SUM(FinanceInvoice.Value * FinanceInvoice.ValueSign) '.
    370           'FROM FinanceInvoice WHERE (FinanceInvoice.Subject = Subject.Id) AND '.
    371           '(FinanceInvoice.ValueSign = 1)) as Claims, (SELECT SUM(FinanceInvoice.Value * FinanceInvoice.ValueSign) '.
    372           'FROM FinanceInvoice WHERE (FinanceInvoice.Subject = Subject.Id) AND ('.
    373           'FinanceInvoice.ValueSign = 1) AND (TimePayment IS NULL)) as OpenedClaims, '.
    374           '(SELECT SUM(FinanceInvoice.Value * FinanceInvoice.ValueSign) FROM FinanceInvoice '.
    375           'WHERE (FinanceInvoice.Subject = Subject.Id) AND (FinanceInvoice.ValueSign = -1)) AS '.
    376           'Liabilities, (SELECT SUM(FinanceInvoice.Value) FROM FinanceInvoice '.
    377           'WHERE (FinanceInvoice.Subject = Subject.Id) AND (FinanceInvoice.ValueSign = -1) '.
    378           'AND (TimePayment IS NULL)) AS OpenedLiabilities, '.
    379           '(SELECT SUM(FinanceOperation.Value*FinanceOperation.ValueSign) '.
    380           'FROM FinanceOperation WHERE FinanceOperation.Subject = Subject.Id AND FinanceOperation.ValueSign = 1) '.
    381           'AS Gains, (SELECT SUM(FinanceOperation.Value*FinanceOperation.ValueSign) FROM FinanceOperation WHERE '.
    382           'FinanceOperation.Subject = Subject.Id AND FinanceOperation.ValueSign = -1) as Spends '.
    383           'FROM Subject WHERE Id='.$_GET['Id']);
    384         $Row = $DbResult->fetch_array();
    385         $Output .= 'Stav placení: '.(-$Row['OpenedClaims'] + Abs($Row['OpenedLiabilities']));
     468        $Output = $this->ShowSubjectAccount();
    386469        break;
    387470      case 'PrintMonthOperations':
     
    393476        break;
    394477      default:
    395         $Output .= '<strong>Celkové přehledy</strong><br/>';
    396         $Output .= '<a href="?table=AnnualBalance">Účetní závěrka</a><br />';
    397         $Output .= '<a href="?table=MonthlyBalance">Měsíční přehledy</a><br />';
    398         $Output .= '<a href="?table=SubjectList">Seznam subjektů</a><br />';
    399         $Output .= '<a href="?table=SmallAssets">Drobný majetek</a><br />';
    400         $Output .= '<br/>';
    401         $Output .= '<strong>Roční přehledy</strong><br/>';
    402         $Output .= $this->ShowFinanceYears();
    403         if(array_key_exists('year', $_GET))
    404         {
    405           $Year = $_GET['year'] * 1;
    406           $Output .= '<a href="?table=Incomes&amp;year='.$Year.'">Příjmy</a><br />';
    407           $Output .= '<a href="?table=Expenses&amp;year='.$Year.'">Výdaje</a><br />';
    408           $Output .= '<a href="?table=Claims&amp;year='.$Year.'">Pohledávky</a><br />';
    409           $Output .= '<a href="?table=Liabilities&amp;year='.$Year.'">Závazky</a><br />';
    410           $Output .= '<a href="?table=Advantages&amp;year='.$Year.'">Zálohy</a><br />';
    411         }
     478        $Output = $this->ShowDefault();
    412479    }
    413480    return($Output);
Note: See TracChangeset for help on using the changeset viewer.