Changeset 802 for trunk/Modules/Stock


Ignore:
Timestamp:
Feb 23, 2016, 4:44:03 PM (9 years ago)
Author:
chronos
Message:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/Modules/Stock/Stock.php

    r800 r802  
    1616  function DoStart()
    1717  {
     18    global $Config;
     19   
    1820    $this->System->FormManager->RegisterClass('Product', array(
    1921      'Title' => 'Produkty',
     
    2123      'DefaultSortColumn' => 'Name',
    2224      'Items' => array(
     25        'Manufacturer' => array('Type' => 'TSubject', 'Caption' => 'Výrobce', 'Default' => '', 'Null' => true),
     26        'Code' => array('Type' => 'String', 'Caption' => 'Kód', 'Default' => ''),
    2327        'Name' => array('Type' => 'String', 'Caption' => 'Jméno', 'Default' => ''),
    2428        'SellPrice' => array('Type' => 'Integer', 'Caption' => 'Prodejní cena', 'Default' => '0', 'Suffix' => 'Kč'),
     
    2731        'Consumption' => array('Type' => 'Integer', 'Caption' => 'Spotřeba', 'Default' => '', 'Suffix' => 'Watt'),
    2832        'Supplier' => array('Type' => 'TSubject', 'Caption' => 'Dodavatel', 'Default' => '', 'Null' => true),
    29         'Manufacturer' => array('Type' => 'TSubject', 'Caption' => 'Výrobce', 'Default' => '', 'Null' => true),
    30         'Code' => array('Type' => 'String', 'Caption' => 'Kód', 'Default' => ''),
    3133        'UnitOfMeasure' => array('Type' => 'TUnitOfMeasure', 'Caption' => 'Měrná jednotka', 'Default' => '', 'Null' => true),
    3234        'StockSerialNumbers' => array('Type' => 'TStockSerialNumberListProduct', 'Caption' => 'Položky na skladě', 'Default' => '', 'Suffix' => 'ks'),
     
    7981      'DefaultSortColumn' => 'Time',
    8082      'Items' => array(
    81         'DocumentLine' => array('Type' => 'TDocumentLine', 'Caption' => 'Dokladová řada', 'Default' => ''),
    82         'BillCode' => array('Type' => 'String', 'Caption' => 'Označení', 'Default' => ''),
     83        'Group' => array('Type' => 'TStockMoveGroup', 'Caption' => 'Skupina', 'Default' => ''),
     84        'BillCode' => array('Type' => 'TDocumentLineCode', 'Caption' => 'Označení', 'Default' => '', 'ReadOnly' => true),
    8385        'Time' => array('Type' => 'DateTime', 'Caption' => 'Čas', 'Default' => ''),
    84         'StockFrom' => array('Type' => 'TStock', 'Caption' => 'Zdrojový sklad', 'Default' => '', 'Null' => true),
    85         'StockTo' => array('Type' => 'TStock', 'Caption' => 'Cílový sklad', 'Default' => '', 'Null' => true),
     86        'Stock' => array('Type' => 'TStock', 'Caption' => 'Sklad', 'Default' => '', 'Null' => true),
    8687        'File' => array('Type' => 'TFile', 'Caption' => 'Doklad', 'Default' => '', 'Null' => true),
    8788        'Price' => array('Type' => 'Float', 'Caption' => 'Cena', 'Default' => '',
     
    9192      ),
    9293      'BeforeInsert' => array($this, 'BeforeInsertStockMove'),
    93     ));
    94     $this->System->FormManager->RegisterClass('StockMoveUnion', array(
    95       'Title' => 'Skladový pohyb',
    96       'BaseTable' => 'StockMove',
    97       'DefaultSortColumn' => 'Time',
    98       'SQL' => '(SELECT *, -1 AS `Direction`, `StockFrom` AS `Stock`, `StockTo` AS `StockOther` FROM `StockMove`) '.
    99         'UNION (SELECT *, 1 AS `Direction`, `StockTo` AS `Stock`, `StockFrom` AS `StockOther` FROM `StockMove`)',
    100       'Items' => array(
    101         'DocumentLine' => array('Type' => 'TDocumentLine', 'Caption' => 'Dokladová řada', 'Default' => ''),
    102         'BillCode' => array('Type' => 'String', 'Caption' => 'Označení', 'Default' => ''),
    103         'Time' => array('Type' => 'DateTime', 'Caption' => 'Čas', 'Default' => ''),
    104         'Stock' => array('Type' => 'TStock', 'Caption' => 'První sklad', 'Default' => '', 'Null' => true),
    105         'StockOther' => array('Type' => 'TStock', 'Caption' => 'Druhý sklad', 'Default' => '', 'Null' => true),
    106         'File' => array('Type' => 'TFile', 'Caption' => 'Doklad', 'Default' => '', 'Null' => true),
    107         'Price' => array('Type' => 'Float', 'Caption' => 'Cena', 'Default' => '',
    108           'ReadOnly' => true, 'Suffix' => 'Kč', 'SQL' => '(SELECT `TX`.`Direction` * SUM(`StockMoveItem`.`UnitPrice` * `StockMoveItem`.`Amount`) FROM `StockMoveItem` '.
    109           'WHERE `StockMoveItem`.`StockMove`=#Id)'),
    110         'Items' => array('Type' => 'TStockMoveItemListStockMove', 'Caption' => 'Položky', 'Default' => ''),
    111       ),
    112       'BeforeInsert' => array($this, 'BeforeInsertStockMove'),
     94      //'AfterInsert' => array($this, 'AfterInsertStockMove'),
     95      //'BeforeModify' => array($this, 'BeforeModifyStockMove'),
    11396    ));
    11497    $this->System->FormManager->RegisterClass('StockMoveItem', array(
    11598      'Title' => 'Položka skladového pohybu',
    11699      'Table' => 'StockMoveItem',
    117       'DefaultSortColumn' => 'Text',
     100      'DefaultSortColumn' => 'Product',
    118101      'Items' => array(
    119102        'StockMove' => array('Type' => 'TStockMove', 'Caption' => 'Skladový pohyb', 'Default' => ''),
    120103        'Product' => array('Type' => 'TProduct', 'Caption' => 'Produkt', 'Default' => ''),
     104        'UnitPrice' => array('Type' => 'Integer', 'Caption' => 'Jednotková cena', 'Default' => '0', 'Suffix' => 'Kč'),
    121105        'Amount' => array('Type' => 'Integer', 'Caption' => 'Množství', 'Default' => '1'),
    122         'Text' => array('Type' => 'String', 'Caption' => 'Text', 'Default' => ''),
    123         'UnitPrice' => array('Type' => 'Integer', 'Caption' => 'Jednotková cena', 'Default' => '0', 'Suffix' => 'Kč'),
     106        'Total' => array('Type' => 'Integer', 'Caption' => 'Celkem', 'Default' => '', 'Suffix' => 'Kč',
     107          'ReadOnly' => true, 'SQL' => 'ROUND(`UnitPrice` * `Amount`, '.$Config['Finance']['Rounding'].')'),
     108      ),
     109    ));
     110    $this->System->FormManager->RegisterClass('StockMoveGroup', array(
     111      'Title' => 'Skupina skladových pohybů',
     112      'Table' => 'StockMoveGroup',
     113      'Items' => array(
     114        'Name' => array('Type' => 'String', 'Caption' => 'Název', 'Default' => '0'),
     115        'DocumentLine' => array('Type' => 'TDocumentLine', 'Caption' => 'Dokladová řada', 'Default' => '0'),
     116        'ValueSign' => array('Type' => 'TFinanceValueSign', 'Caption' => 'Znaménko hodnoty', 'Default' => '0'),
     117        'Direction' => array('Type' => 'TFinanceDirection', 'Caption' => 'Směr', 'Default' => '0'),
     118        'Items' => array('Type' => 'TStockMoveListGroup', 'Caption' => 'Operace', 'Default' => ''),
    124119      ),
    125120    ));
     
    148143      'Filter' => '1',
    149144    ));
     145    $this->System->FormManager->RegisterFormType('TStockMoveListGroup', array(
     146      'Type' => 'ManyToOne',
     147      'Table' => 'StockMove',
     148      'Id' => 'Id',
     149      'Ref' => 'Group',
     150      'Filter' => '1',
     151    ));
    150152    $this->System->FormManager->RegisterFormType('TStockMoveStock', array(
    151153      'Type' => 'ManyToOne',
    152       'Table' => 'StockMoveUnion',
     154      'Table' => 'StockMove',
    153155      'Id' => 'Id',
    154156      'Ref' => 'Stock',
     
    159161      'Table' => 'StockMove',
    160162      'Id' => 'Id',
    161       'Name' => 'BillCode',
     163      'Name' => '(SELECT `DocumentLineCode`.`Name` FROM `DocumentLineCode` WHERE `Id`=`StockMove`.`BillCode`)',
    162164      'Filter' => '1',
    163165    ));
     
    172174      'Type' => 'Reference',
    173175      'Table' => 'Stock',
     176      'Id' => 'Id',
     177      'Name' => 'Name',
     178      'Filter' => '1',
     179    ));
     180    $this->System->FormManager->RegisterFormType('TStockMoveGroup', array(
     181      'Type' => 'Reference',
     182      'Table' => 'StockMoveGroup',
    174183      'Id' => 'Id',
    175184      'Name' => 'Name',
     
    196205    if(array_key_exists('Time', $Form->Values)) $Year = date("Y", $Form->Values['Time']);
    197206      else $Year = date("Y", $Form->Values['ValidFrom']);
    198     $DocumentLine = $Form->Values['DocumentLine'];
    199     $Form->Values['BillCode'] = $this->System->Modules['Finance']->GetNextDocumentLineNumber($DocumentLine, $Year);
     207    $Group = $this->System->Modules['Finance']->GetFinanceGroupById($Form->Values['Group'], 'StockMoveGroup');
     208    $Form->Values['BillCode'] = $this->System->Modules['Finance']->GetNextDocumentLineNumberId($Group['DocumentLine'], $Year);
    200209    return($Form->Values);
    201210  }
Note: See TracChangeset for help on using the changeset viewer.