2024-02-05 21:21:48 +01:00
< ? php
/*
* Copyright ( c ) 2023 OpenXE project
* Xentral ( c ) Xentral ERP Sorftware GmbH , Fuggerstrasse 11 , D - 86150 Augsburg , * Germany 2019
*/
use Xentral\Components\Database\Exception\QueryFailureException ;
class lieferantengutschrift {
function __construct ( $app , $intern = false ) {
$this -> app = $app ;
if ( $intern )
return ;
$this -> app -> ActionHandlerInit ( $this );
$this -> app -> ActionHandler ( " list " , " lieferantengutschrift_list " );
$this -> app -> ActionHandler ( " create " , " lieferantengutschrift_edit " ); // This automatically adds a "New" button
$this -> app -> ActionHandler ( " edit " , " lieferantengutschrift_edit " );
$this -> app -> ActionHandler ( " positionen " , " lieferantengutschrift_positionen " );
$this -> app -> ActionHandler ( " delete " , " lieferantengutschrift_delete " );
$this -> app -> ActionHandler ( " deletepos " , " lieferantengutschrift_deletepos " );
$this -> app -> ActionHandler ( " editpos " , " lieferantengutschrift_editpos " );
$this -> app -> ActionHandler ( " dateien " , " lieferantengutschrift_dateien " );
$this -> app -> ActionHandler ( " inlinepdf " , " lieferantengutschrift_inlinepdf " );
$this -> app -> ActionHandler ( " positioneneditpopup " , " lieferantengutschrift_positioneneditpopup " );
$this -> app -> ActionHandler ( " freigabe " , " lieferantengutschrift_freigabe " );
$this -> app -> ActionHandler ( " freigabeeinkauf " , " lieferantengutschrift_freigabeeinkauf " );
$this -> app -> ActionHandler ( " freigabebuchhaltung " , " lieferantengutschrift_freigabebuchhaltung " );
$this -> app -> ActionHandler ( " freigabebezahlt " , " lieferantengutschrift_freigabebezahlt " );
$this -> app -> ActionHandler ( " ruecksetzeneinkauf " , " lieferantengutschrift_ruecksetzeneinkauf " );
$this -> app -> ActionHandler ( " ruecksetzenbuchhaltung " , " lieferantengutschrift_ruecksetzenbuchhaltung " );
$this -> app -> ActionHandler ( " ruecksetzenbezahlt " , " lieferantengutschrift_ruecksetzenbezahlt " );
$this -> app -> ActionHandler ( " minidetail " , " lieferantengutschrift_minidetail " );
$this -> app -> DefaultActionHandler ( " list " );
$this -> app -> ActionHandlerListen ( $app );
}
public function Install () {
/* Fill out manually later */
}
function TableSearch ( & $app , $name , $erlaubtevars ) {
switch ( $name ) {
case " lieferantengutschrift_list " :
$allowed [ 'lieferantengutschrift_list' ] = array ( 'list' );
$heading = array ( '' , '' , 'Belegnr' , 'Adresse' , 'Lieferant' , 'RE-Nr' , 'RE-Datum' , 'Betrag (brutto)' , 'Währung' , 'Zahlstatus' , 'Ziel' , 'Skontoziel' , 'Skonto' , 'Status' , 'Monitor' , 'Menü' );
$width = array ( '1%' , '1%' , '10%' ); // Fill out manually later
// columns that are aligned right (numbers etc)
// $alignright = array(4,5,6,7,8);
$findcols = array (
'v.id' ,
'v.id' ,
'v.belegnr' ,
'a.name' ,
'a.lieferantennummer' ,
'v.rechnung' ,
'v.rechnungsdatum' ,
'v.betrag' ,
'v.waehrung' ,
'v.bezahlt' ,
'v.zahlbarbis' ,
'v.skontobis' ,
'v.skonto' ,
'v.status' ,
'v.status_beleg' ,
'v.id'
);
$searchsql = array (
'a.name' ,
'a.lieferantennummer' ,
'v.rechnung' ,
'v.internebemerkung'
);
$defaultorder = 1 ;
$defaultorderdesc = 0 ;
$alignright = array ( 8 );
$sumcol = array ( 8 );
$dropnbox = " '<img src=./themes/new/images/details_open.png class=details>' AS `open`, CONCAT('<input type= \" checkbox \" name= \" auswahl[] \" value= \" ',v.id,' \" />') AS `auswahl` " ;
// $moreinfo = true; // Allow drop down details
// $moreinfoaction = "lieferschein"; // specify suffix for minidetail-URL to allow different minidetails
// $menucol = 11; // Set id col for moredata/menu
$menu = " <table cellpadding=0 cellspacing=0><tr><td nowrap> " . " <a href= \" index.php?module=lieferantengutschrift&action=edit&id=%value% \" ><img src= \" ./themes/ { $app -> Conf -> WFconf [ 'defaulttheme' ] } /images/edit.svg \" border= \" 0 \" ></a> <a href= \" # \" onclick=DeleteDialog( \" index.php?module=lieferantengutschrift&action=delete&id=%value% \" );> " . " <img src= \" themes/ { $app -> Conf -> WFconf [ 'defaulttheme' ] } /images/delete.svg \" border= \" 0 \" ></a> " . " </td></tr></table> " ;
$sql = " SELECT SQL_CALC_FOUND_ROWS
v . id ,
$dropnbox ,
v . belegnr ,
a . name ,
a . lieferantennummer ,
v . rechnung ,
" . $app->erp ->FormatDate( " v . rechnungsdatum " ). " ,
" . $app->erp ->FormatMenge('v.betrag',2). " ,
v . waehrung ,
if ( v . bezahlt , 'bezahlt' , 'offen' ),
" . $app->erp ->FormatDate( " v . zahlbarbis " ). " ,
IF ( v . skonto <> 0 , " . $app->erp ->FormatDate( " v . skontobis " ). " , '' ),
IF ( v . skonto <> 0 , CONCAT ( " . $app->erp ->FormatMenge('v.skonto',0). " , '%' ), '' ),
v . status ,
" . $app->YUI ->IconsSQLverbindlichkeit(). " ,
v . id FROM lieferantengutschrift v
LEFT JOIN adresse a ON v . adresse = a . id
LEFT JOIN (
SELECT ds . parameter , COUNT ( ds . objekt ) datei_anzahl FROM datei_stichwoerter ds INNER JOIN datei d ON d . id = ds . datei WHERE ds . objekt = 'lieferantengutschrift' AND d . geloescht <> 1 GROUP BY ds . parameter
) d ON d . parameter = v . id
" ;
$where = " 1 " ;
$count = " SELECT count(DISTINCT id) FROM lieferantengutschrift WHERE $where " ;
// $groupby = "";
// Toggle filters
$this -> app -> Tpl -> Add ( 'JQUERYREADY' , " $ ('#anhang').click( function() { fnFilterColumn1( 0 ); } ); " );
$this -> app -> Tpl -> Add ( 'JQUERYREADY' , " $ ('#wareneingang').click( function() { fnFilterColumn2( 0 ); } ); " );
$this -> app -> Tpl -> Add ( 'JQUERYREADY' , " $ ('#rechnungsfreigabe').click( function() { fnFilterColumn3( 0 ); } ); " );
$this -> app -> Tpl -> Add ( 'JQUERYREADY' , " $ ('#nichtbezahlt').click( function() { fnFilterColumn4( 0 ); } ); " );
$this -> app -> Tpl -> Add ( 'JQUERYREADY' , " $ ('#stornierte').click( function() { fnFilterColumn5( 0 ); } ); " );
$this -> app -> Tpl -> Add ( 'JQUERYREADY' , " $ ('#abgeschlossen').click( function() { fnFilterColumn6( 0 ); } ); " );
for ( $r = 1 ; $r <= 8 ; $r ++ ) {
$this -> app -> Tpl -> Add ( 'JAVASCRIPT' , '
function fnFilterColumn ' . $r . ' ( i )
{
if ( oMoreData ' . $r . $name . ' == 1 )
oMoreData ' . $r . $name . ' = 0 ;
else
oMoreData ' . $r . $name . ' = 1 ;
$ ( \ '#' . $name . ' \ ' ) . dataTable () . fnFilter (
\ ' \ ' ,
i ,
0 , 0
);
}
' );
}
$more_data1 = $this -> app -> Secure -> GetGET ( " more_data1 " );
if ( $more_data1 == 1 ) {
$where .= " AND datei_anzahl IS NULL " ;
} else {
}
$more_data2 = $this -> app -> Secure -> GetGET ( " more_data2 " );
if ( $more_data2 == 1 ) {
$where .= " AND v.freigabe <> '1' " ;
}
else {
}
$more_data3 = $this -> app -> Secure -> GetGET ( " more_data3 " );
if ( $more_data3 == 1 ) {
$where .= " AND v.rechnungsfreigabe <> '1' " ;
}
else {
}
$more_data4 = $this -> app -> Secure -> GetGET ( " more_data4 " );
if ( $more_data4 == 1 ) {
$where .= " AND v.bezahlt <> 1 " ;
}
else {
}
$more_data5 = $this -> app -> Secure -> GetGET ( " more_data5 " );
if ( $more_data5 == 1 ) {
}
else {
$where .= " AND v.status <> 'storniert' " ;
}
$more_data6 = $this -> app -> Secure -> GetGET ( " more_data6 " );
if ( $more_data6 == 1 ) {
}
else {
$where .= " AND v.status <> 'abgeschlossen' " ;
}
$this -> app -> YUI -> DatePicker ( 'zahlbarbis' );
$filterzahlbarbis = $this -> app -> YUI -> TableSearchFilter ( $name , 7 , 'zahlbarbis' );
if ( ! empty ( $filterzahlbarbis )) {
$filterzahlbarbis = $this -> app -> String -> Convert ( $filterzahlbarbis , '%1.%2.%3' , '%3-%2-%1' );
$where .= " AND v.zahlbarbis <= ' " . $filterzahlbarbis . " ' " ;
}
$this -> app -> YUI -> DatePicker ( 'skontobis' );
$filterskontobis = $this -> app -> YUI -> TableSearchFilter ( $name , 8 , 'skontobis' );
if ( ! empty ( $filterskontobis )) {
$filterskontobis = $this -> app -> String -> Convert ( $filterskontobis , '%1.%2.%3' , '%3-%2-%1' );
$where .= " AND v.skontobis <= ' " . $filterskontobis . " ' " ;
}
// END Toggle filters
$moreinfo = true ; // Allow drop down details
$menucol = 1 ; // For moredata
break ;
case 'lieferantengutschrift_positionen' :
$allowed [ 'lieferantengutschrift_positionen' ] = array ( 'list' );
$id = $app -> Secure -> GetGET ( 'id' );
$freigabe = $app -> DB -> Select ( " SELECT freigabe FROM lieferantengutschrift WHERE id = ' " . $id . " ' " );
$rechnungsfreigabe = $app -> DB -> Select ( " SELECT rechnungsfreigabe FROM lieferantengutschrift WHERE id = ' " . $id . " ' " );
2024-02-07 17:57:11 +01:00
$heading = array ( '' , 'Verbindlichkeit' , 'Artikel-Nr.' , 'Artikel' , 'Menge' , 'Preis' , 'Steuersatz' , 'Sachkonto' );
$width = array ( '1%' , '1%' , '20%' , '20%' , '1%' , '1%' , '3%' , '1%' , '1%' );
2024-02-05 21:21:48 +01:00
2024-02-07 17:57:11 +01:00
$findcols = array ( 'lgp.id' , 'v.belegnr' , 'art.nummer' , 'art.name_de' , 'lgp.menge' , 'lgp.preis' , 'lgp.steuersatz' , " CONCAT(skv.sachkonto,' ',skv.beschriftung) " , 'lgp.id' );
2024-02-05 21:21:48 +01:00
$searchsql = array ( 'p.nummer' , 'p.name' , 'p.bemerkung' );
$alignright = array ( 8 , 9 , 10 );
$defaultorder = 1 ;
$defaultorderdesc = 0 ;
if ( empty ( $freigabe )) {
$menu = " <table cellpadding=0 cellspacing=0><tr><td nowrap> " . " <a href= \" index.php?module=lieferantengutschrift&action=editpos&id= $id &posid=%value% \" ><img src= \" ./themes/ { $app -> Conf -> WFconf [ 'defaulttheme' ] } /images/edit.svg \" border= \" 0 \" ></a> <a href= \" # \" onclick=DeleteDialog( \" index.php?module=lieferantengutschrift&action=deletepos&id= $id &posid=%value% \" );> " . " <img src= \" themes/ { $app -> Conf -> WFconf [ 'defaulttheme' ] } /images/delete.svg \" border= \" 0 \" ></a> " . " </td></tr></table> " ;
} else if ( empty ( $rechnungsfreigabe )) {
$menu = " <table cellpadding=0 cellspacing=0><tr><td nowrap> " . " <a href= \" index.php?module=lieferantengutschrift&action=editpos&id= $id &posid=%value% \" ><img src= \" ./themes/ { $app -> Conf -> WFconf [ 'defaulttheme' ] } /images/edit.svg \" border= \" 0 \" ></a> " . " </td></tr></table> " ;
}
else {
$deletepos = array ( '' );
}
$heading [] = '' ;
2024-02-07 17:57:11 +01:00
$box = " CONCAT('<input type= \" checkbox \" name= \" auswahl[] \" value= \" ',lgp.id,' \" />') AS `auswahl` " ;
$verbindlichkeitlink = array (
'<a href="index.php?module=verbindlichkeit&action=edit&id=' ,
[ 'sql' => 'v.id' ],
'">' ,
[ 'sql' => 'v.belegnr' ],
'</a>'
);
$artikellink = array (
'<a href="index.php?module=artikel&action=edit&id=' ,
[ 'sql' => 'art.id' ],
'">' ,
[ 'sql' => 'art.nummer' ],
'</a>'
);
$sql = "
SELECT SQL_CALC_FOUND_ROWS
lgp . id ,
$box ,
" . $this->app ->erp->ConcatSQL( $verbindlichkeitlink ). " ,
" . $this->app ->erp->ConcatSQL( $artikellink ). " ,
art . name_de ,
lgp . menge ,
lgp . preis ,
lgp . steuersatz ,
CONCAT ( skv . sachkonto , ' ' , skv . beschriftung ),
lgp . id
FROM
lieferantengutschrift_position lgp
INNER JOIN lieferantengutschrift lg ON
lg . id = lgp . lieferantengutschrift
LEFT JOIN verbindlichkeit_position vp ON
vp . id = lgp . verbindlichkeit_position
LEFT JOIN verbindlichkeit v ON
vp . verbindlichkeit = v . id
INNER JOIN artikel art ON
art . id = lgp . artikel
INNER JOIN adresse adr ON
adr . id = lg . adresse
LEFT JOIN kontorahmen skv ON skv . id = lgp . kontorahmen
" ;
$where = " lgp.lieferantengutschrift = " . $id ;
$count = " " ;
2024-02-08 16:09:50 +01:00
break ;
2024-02-07 17:57:11 +01:00
case 'verbindlichkeit_positionen' :
$allowed [ 'verbindlichkeit_positionen' ] = array ( 'list' );
$id = $app -> Secure -> GetGET ( 'id' );
//$verbindlichkeit = $app->DB->Select("SELECT verbindlichkeit FROM lieferantengutschrift WHERE id = '".$id."'");
$heading = array ( '' , 'Verbindlichkeit' , 'Artikel-Nr.' , 'Artikel' , 'Menge' , 'Preis' , 'Steuersatz' , 'Sachkonto' , '' );
$width = array ( '1%' , '2%' , '2%' , '20%' , '1%' , '1%' , '3%' , '1%' , '1%' );
$findcols = array ( 'vp.id' , 'v.belegnr' , 'art.nummer' , 'art.name_de' , 'vp.menge' , 'vp.preis' , 'vp.steuersatz' , " CONCAT(skv.sachkonto,' ',skv.beschriftung) " , 'vp.id' );
$searchsql = array ( 'p.nummer' , 'p.name' , 'p.bemerkung' );
$alignright = array ( 8 , 9 , 10 );
$defaultorder = 1 ;
$defaultorderdesc = 0 ;
$auswahl = array (
'<input type=\"checkbox\" name=\"ids[]\" value=\"' ,
[ 'sql' => 'pd.id' ],
'"/>'
);
$werte = array (
2024-02-09 10:49:18 +01:00
'<input type="number" name="werte[]" min="0"' ,
'max = "' ,
[ 'sql' => 'vp.menge' ],
'" ' ,
'value = "' ,
[ 'sql' => 'vp.menge' ],
'" ' ,
'/>'
2024-02-07 17:57:11 +01:00
);
$preise = array (
'<input type="number" name="preise[]" step="0.00001" value="' ,
[ 'sql' => $this -> app -> erp -> FormatMenge ( " COALESCE(bp.preis,0) " , 5 )],
'" min="0"' ,
2024-02-08 16:09:50 +01:00
'/>'
2024-02-07 17:57:11 +01:00
);
$artikellink = array (
'<a href="index.php?module=artikel&action=edit&id=' ,
[ 'sql' => 'art.id' ],
'">' ,
[ 'sql' => 'art.nummer' ],
'</a>'
);
2024-02-05 21:21:48 +01:00
$box = " CONCAT('<input type= \" checkbox \" name= \" auswahl[] \" value= \" ',vp.id,' \" />') AS `auswahl` " ;
$sql = "
SELECT SQL_CALC_FOUND_ROWS
vp . id ,
2024-02-07 17:57:11 +01:00
" . $this->app ->erp->ConcatSQL( $auswahl ). " ,
v . belegnr ,
" . $this->app ->erp->ConcatSQL( $artikellink ). " ,
2024-02-05 21:21:48 +01:00
art . name_de ,
2024-02-07 17:57:11 +01:00
" . $this->app ->erp->ConcatSQL( $werte ). " ,
2024-02-05 21:21:48 +01:00
vp . preis ,
vp . steuersatz ,
CONCAT ( skv . sachkonto , ' ' , skv . beschriftung ),
vp . id
FROM
2024-02-07 17:57:11 +01:00
verbindlichkeit_position vp
INNER JOIN verbindlichkeit v ON
v . id = vp . verbindlichkeit
INNER JOIN paketdistribution pd ON
pd . id = vp . paketdistribution
2024-02-05 21:21:48 +01:00
INNER JOIN artikel art ON
2024-02-07 17:57:11 +01:00
art . id = pd . artikel
2024-02-05 21:21:48 +01:00
INNER JOIN adresse adr ON
adr . id = v . adresse
LEFT JOIN kontorahmen skv ON skv . id = vp . kontorahmen
" ;
2024-02-07 17:57:11 +01:00
$where = " v.adresse = (SELECT adresse FROM lieferantengutschrift WHERE id = " . $id . " ) AND v.status = 'freigegeben' " ;
2024-02-05 21:21:48 +01:00
$count = " " ;
break ;
case 'artikel_manuell' :
$allowed [ 'paketdistribution_list' ] = array ( 'list' );
2024-02-08 16:09:50 +01:00
$heading = array ( 'Art.-Nummer' , 'Beschreibung' , 'Menge' , 'Preis' , 'Steuer' , 'Sachkonto' , '' );
$width = array ( '5%' , '30%' , '5%' , '5%' , '1%' , '1%' , '1%' );
2024-02-05 21:21:48 +01:00
2024-02-08 20:43:58 +01:00
$findcols = array ( 'nummer' , 'name_de' , '' , '' , 'umsatzsteuer' , " CONCAT(skart.sachkonto,' ',skart.beschriftung) " , 'id' );
2024-02-05 21:21:48 +01:00
$searchsql = array ( '' );
$alignright = array ( '5' );
$defaultorder = 1 ;
$defaultorderdesc = 0 ;
$auswahl = array (
'<input type=\"text\" name=\"manuell_artikel_ids[]\" value=\"' ,
[ 'sql' => 'a.id' ],
'" hidden/>' ,
[ 'sql' => 'a.nummer' ]
);
$input_for_menge = array (
'<input type = \"number\" min=\"0\"' ,
' value=\"' ,
'\"' ,
' name=\"manuell_mengen[]\"' ,
' style=\"text-align:right; width:100%\">' ,
'</input>'
);
$input_for_bemerkung = array (
'<input type = \"text\"' ,
' name=\"manuell_bemerkungen[]\"' ,
' style=\"text-align:right; width:100%\">' ,
'</input>'
);
2024-02-08 16:09:50 +01:00
$preise = array (
'<input type="number" name="preise[]" step="0.00001" value="' ,
'" min="0"' ,
' style=\"text-align:right; width:100%\">'
);
2024-02-05 21:21:48 +01:00
$sql = "
SELECT SQL_CALC_FOUND_ROWS
2024-02-08 16:09:50 +01:00
a . id ,
2024-02-05 21:21:48 +01:00
" . $this->app ->erp->ConcatSQL( $auswahl ). " ,
name_de ,
" . $this->app ->erp->ConcatSQL( $input_for_menge ). " ,
2024-02-08 16:09:50 +01:00
" . $this->app ->erp->ConcatSQL( $preise ). "
'' ,
a . umsatzsteuer ,
CONCAT ( skart . sachkonto , ' ' , skart . beschriftung )
2024-02-05 21:21:48 +01:00
FROM
artikel a
2024-02-08 16:09:50 +01:00
LEFT JOIN
kontorahmen skart ON skart . id = a . kontorahmen " ;
2024-02-05 21:21:48 +01:00
2024-02-08 16:09:50 +01:00
$where = " (geloescht <> 1) " ;
2024-02-05 21:21:48 +01:00
$multifilter = $this -> app -> YUI -> TableSearchFilter ( $name , 8 , 'multifilter' );
if ( ! empty ( $multifilter )) {
$multifilter_array = explode ( ' ' , $multifilter );
$where .= " AND (1=0 " ;
foreach ( $multifilter_array as $keyword ) {
$where .= " OR name_de LIKE '% " . $keyword . " %' " ;
$where .= " OR nummer LIKE '% " . $keyword . " %' " ;
}
$where .= " ) " ;
}
$count = " " ;
break ;
}
$erg = false ;
foreach ( $erlaubtevars as $k => $v ) {
if ( isset ( $$v )) {
$erg [ $v ] = $$v ;
}
}
return $erg ;
}
function lieferantengutschrift_list () {
// Process multi action
$submit = $this -> app -> Secure -> GetPOST ( 'submit' );
switch ( $submit ) {
case 'status_berechnen' :
$sql = " SELECT id FROM lieferantengutschrift WHERE status <> 'abgeschlossen' AND status <> 'storniert' " ;
$ids = $this -> app -> DB -> SelectArr ( $sql );
foreach ( $ids as $lieferantengutschrift ) {
$this -> lieferantengutschrift_abschliessen ( $lieferantengutschrift [ 'id' ]);
}
break ;
case 'ausfuehren' :
$auswahl = $this -> app -> Secure -> GetPOST ( 'auswahl' );
$aktion = $this -> app -> Secure -> GetPOST ( 'sel_aktion' );
$selectedIds = [];
if ( ! empty ( $auswahl )) {
foreach ( $auswahl as $selectedId ) {
$selectedId = ( int ) $selectedId ;
if ( $selectedId > 0 ) {
$selectedIds [] = $selectedId ;
}
}
switch ( $aktion ) {
case 'freigabeeinkauf' :
foreach ( $selectedIds as $id ) {
$result = $this -> lieferantengutschrift_freigabeeinkauf ( $id );
if ( $result !== true ) {
$this -> app -> YUI -> Message ( 'warning' , $result );
}
}
break ;
case 'freigabebuchhaltung' :
foreach ( $selectedIds as $id ) {
$result = $this -> lieferantengutschrift_freigabebuchhaltung ( $id );
if ( $result !== true ) {
$this -> app -> YUI -> Message ( 'warning' , $result );
}
}
break ;
case 'bezahlt' :
foreach ( $selectedIds as $id ) {
$result = $this -> lieferantengutschrift_freigabebezahlt ( $id );
if ( $result !== true ) {
$this -> app -> YUI -> Message ( 'warning' , $result );
}
}
break ;
}
}
break ;
}
$this -> app -> erp -> MenuEintrag ( " index.php?module=lieferantengutschrift&action=list " , " Übersicht " );
$this -> app -> erp -> MenuEintrag ( " index.php?module=lieferantengutschrift&action=create " , " Neu anlegen " );
$this -> app -> erp -> MenuEintrag ( " index.php " , " Zurück " );
$this -> app -> YUI -> TableSearch ( 'TAB1' , 'lieferantengutschrift_list' , " show " , " " , " " , basename ( __FILE__ ), __CLASS__ );
if ( $this -> app -> erp -> RechteVorhanden ( 'lieferantengutschrift' , 'freigabeeinkauf' )){
$this -> app -> Tpl -> Set ( 'MANUELLFREIGABEEINKAUF' , '<option value="freigabeeinkauf">{|freigeben (Einkauf)|}</option>' );
}
if ( $this -> app -> erp -> RechteVorhanden ( 'lieferantengutschrift' , 'freigabebuchhaltung' )){
$this -> app -> Tpl -> Set ( 'MANUELLFREIGABEBUCHHALTUNG' , '<option value="freigabebuchhaltung">{|freigeben (Buchhaltung)|}</option>' );
}
if ( $this -> app -> erp -> RechteVorhanden ( 'lieferantengutschrift' , 'freigabebezahlt' )){
$this -> app -> Tpl -> Set ( 'ALSBEZAHLTMARKIEREN' , '<option value="bezahlt">{|als bezahlt markieren|}</option>' );
}
$this -> app -> User -> SetParameter ( 'table_lieferantengutschrift_list_zahlbarbis' , '' );
$this -> app -> User -> SetParameter ( 'table_lieferantengutschrift_list_skontobis' , '' );
$this -> app -> Tpl -> Parse ( 'PAGE' , " lieferantengutschrift_list.tpl " );
}
public function lieferantengutschrift_delete () {
$id = ( int ) $this -> app -> Secure -> GetGET ( 'id' );
$this -> app -> DB -> Delete ( " UPDATE `lieferantengutschrift` SET status='storniert' WHERE `id` = ' { $id } ' " );
$this -> app -> Tpl -> Set ( 'MESSAGE' , " <div class= \" error \" >Der Eintrag wurde storniert.</div> " );
$this -> lieferantengutschrift_list ();
}
public function lieferantengutschrift_deletepos () {
$posid = ( int ) $this -> app -> Secure -> GetGET ( 'posid' );
$id = ( int ) $this -> app -> Secure -> GetGET ( 'id' );
$lieferantengutschrift = $this -> app -> DB -> Select ( " SELECT lieferantengutschrift FROM lieferantengutschrift_position WHERE id =' { $posid } ' " );
$this -> app -> DB -> Delete ( " DELETE vp FROM lieferantengutschrift_position vp INNER JOIN lieferantengutschrift v ON v.id = vp.lieferantengutschrift WHERE vp.id = ' { $posid } ' AND v.freigabe <> 1 " );
header ( " Location: index.php?module=lieferantengutschrift&action=edit&id= $id #tabs-2 " );
}
/*
* Edit lieferantengutschrift item
* If id is empty , create a new one
*/
function lieferantengutschrift_edit ( $einkauf_automatik_aus = false ) {
$id = $this -> app -> Secure -> GetGET ( 'id' );
// Check if other users are editing this id
if ( $this -> app -> erp -> DisableModul ( 'lieferantengutschrift' , $id ))
{
return ;
}
$this -> app -> Tpl -> Set ( 'ID' , $id );
$this -> lieferantengutschrift_menu ( $id );
$input = $this -> GetInput ();
$submit = $this -> app -> Secure -> GetPOST ( 'submit' );
if ( empty ( $id )) {
// New item
$id = 'NULL' ;
$input [ 'status' ] = 'angelegt' ;
}
if ( ! empty ( $submit )) {
$einkauf_automatik_aus = false ;
}
switch ( $submit )
{
case 'speichern' :
// Write to database
// Add checks here
2024-02-07 17:57:11 +01:00
$freigabe = $this -> app -> DB -> SelectArr ( " SELECT rechnungsfreigabe, freigabe, adresse, belegnr FROM lieferantengutschrift WHERE id = " . $id )[ 0 ];
2024-02-05 21:21:48 +01:00
if ( $freigabe [ 'rechnungsfreigabe' ] || $freigabe [ 'freigabe' ]) {
$internebemerkung = $input [ 'internebemerkung' ];
$projekt = $input [ 'projekt' ];
$kostenstelle = $input [ 'kostenstelle' ];
unset ( $input );
$input [ 'internebemerkung' ] = $internebemerkung ;
$input [ 'projekt' ] = $this -> app -> erp -> ReplaceProjekt ( true , $projekt , true );
$input [ 'kostenstelle' ] = $this -> app -> DB -> Select ( " SELECT id FROM kostenstellen WHERE nummer = ' " . $kostenstelle . " ' " );
} else {
2024-02-07 17:57:11 +01:00
if ( $freigabe [ 'belegnr' ]) {
unset ( $input [ 'adresse' ]);
} else {
$input [ 'adresse' ] = $this -> app -> erp -> ReplaceLieferantennummer ( true , $input [ 'adresse' ], true ); // Parameters: Target db?, value, from form?
}
2024-02-05 21:21:48 +01:00
$input [ 'rechnungsdatum' ] = $this -> app -> erp -> ReplaceDatum ( true , $input [ 'rechnungsdatum' ], true ); // Parameters: Target db?, value, from form?
$input [ 'eingangsdatum' ] = $this -> app -> erp -> ReplaceDatum ( true , $input [ 'eingangsdatum' ], true ); // Parameters: Target db?, value, from form?
$input [ 'skontobis' ] = $this -> app -> erp -> ReplaceDatum ( true , $input [ 'skontobis' ], true ); // Parameters: Target db?, value, from form?
$input [ 'zahlbarbis' ] = $this -> app -> erp -> ReplaceDatum ( true , $input [ 'zahlbarbis' ], true ); // Parameters: Target db?, value, from form?
$input [ 'projekt' ] = $this -> app -> erp -> ReplaceProjekt ( true , $input [ 'projekt' ], true );
$input [ 'kostenstelle' ] = $this -> app -> DB -> Select ( " SELECT id FROM kostenstellen WHERE nummer = ' " . $input [ 'kostenstelle' ] . " ' " );
if ( empty ( $input [ 'projekt' ]) && ! empty ( $input [ 'adresse' ])) {
$input [ 'projekt' ] = $this -> app -> erp -> GetCreateProjekt ( $input [ 'adresse' ]);
}
if ( ! empty ( $input [ 'adresse' ])) {
$adressdaten = $this -> app -> DB -> SelectRow ( "
SELECT
zahlungszieltagelieferant ,
zahlungszieltageskontolieferant ,
zahlungszielskontolieferant ,
ust_befreit
FROM adresse WHERE id = " . $input['adresse']
);
if ( $input [ 'zahlbarbis' ] == '0000-00-00' && $input [ 'rechnungsdatum' ] != '0000-00-00' && ! empty ( $adressdaten [ 'zahlungszieltagelieferant' ])) {
$input [ 'zahlbarbis' ] = date ( 'Y-m-d' , strtotime ( $input [ 'rechnungsdatum' ] . " + " . $adressdaten [ 'zahlungszieltagelieferant' ] . " days " ));
}
if ( $input [ 'skontobis' ] == '0000-00-00' && $input [ 'rechnungsdatum' ] != '0000-00-00' && ! empty ( $adressdaten [ 'zahlungszieltageskontolieferant' ])) {
$input [ 'skontobis' ] = date ( 'Y-m-d' , strtotime ( $input [ 'rechnungsdatum' ] . " + " . $adressdaten [ 'zahlungszieltageskontolieferant' ] . " days " ));
$input [ 'skonto' ] = $adressdaten [ 'zahlungszielskontolieferant' ];
}
}
}
$columns = " id, " ;
$values = " $id , " ;
$update = " " ;
$fix = " " ;
foreach ( $input as $key => $value ) {
$columns = $columns . $fix . $key ;
$values = $values . $fix . " ' " . $value . " ' " ;
$update = $update . $fix . $key . " = ' $value ' " ;
$fix = " , " ;
}
// echo($columns."<br>");
// echo($values."<br>");
// echo($update."<br>");
$sql = " INSERT INTO lieferantengutschrift ( " . $columns . " ) VALUES ( " . $values . " ) ON DUPLICATE KEY UPDATE " . $update ;
// echo($sql);
$this -> app -> DB -> Update ( $sql );
if ( $id == 'NULL' ) {
$id = $this -> app -> DB -> GetInsertID ();
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" success \" >Das Element wurde erfolgreich angelegt.</div> " );
header ( " Location: index.php?module=lieferantengutschrift&action=edit&id= $id &msg= $msg " );
} else {
$this -> app -> Tpl -> Set ( 'MESSAGE' , " <div class= \" success \" >Die Einstellungen wurden erfolgreich übernommen.</div> " );
}
break ;
case 'positionen_hinzufuegen' :
$freigabe = $this -> app -> DB -> SelectArr ( " SELECT rechnungsfreigabe, freigabe FROM lieferantengutschrift WHERE id = " . $id )[ 0 ];
if ( $freigabe [ 'rechnungsfreigabe' ] || $freigabe [ 'freigabe' ]) {
break ;
}
// Process multi action
$ids = $this -> app -> Secure -> GetPOST ( 'ids' );
$werte = $this -> app -> Secure -> GetPOST ( 'werte' );
$preise = $this -> app -> Secure -> GetPOST ( 'preise' );
2024-02-07 17:57:11 +01:00
foreach ( $ids as $key => $verbindlichkeit_position ) {
2024-02-05 21:21:48 +01:00
$menge = $werte [ $key ];
if ( $menge <= 0 ) {
continue ;
}
// Check available number
$sql = "
SELECT
IF (
2024-02-07 17:57:11 +01:00
vp . menge > COALESCE ( lgp . menge , 0 ),
vp . menge - COALESCE ( lgp . menge , 0 ),
2024-02-05 21:21:48 +01:00
0
) offen_menge
FROM
2024-02-07 17:57:11 +01:00
verbindlichkeit_position vp
2024-02-05 21:21:48 +01:00
LEFT JOIN (
SELECT
2024-02-07 17:57:11 +01:00
verbindlichkeit_position ,
2024-02-05 21:21:48 +01:00
SUM ( menge ) AS menge
FROM
2024-02-07 17:57:11 +01:00
lieferantengutschrift_position lgp
2024-02-05 21:21:48 +01:00
GROUP BY
2024-02-07 17:57:11 +01:00
verbindlichkeit_position
) lgp
2024-02-05 21:21:48 +01:00
ON
2024-02-07 17:57:11 +01:00
vp . id = lgp . verbindlichkeit_position
WHERE vp . id = " . $verbindlichkeit_position . "
2024-02-05 21:21:48 +01:00
" ;
$offen_menge = $this -> app -> DB -> Select ( $sql );
if ( $offen_menge == 0 ) {
continue ;
}
if ( $menge > $offen_menge ) {
$menge = $offen_menge ;
}
$sql = " SELECT
a . id ,
a . umsatzsteuer ,
a . steuersatz ,
2024-02-07 17:57:11 +01:00
COALESCE ( if ( skart . id <> 0 , skart . id , skadr . id ), 0 ) AS kontorahmen ,
vp . preis
2024-02-05 21:21:48 +01:00
FROM
2024-02-07 17:57:11 +01:00
verbindlichkeit_position vp
2024-02-05 21:21:48 +01:00
INNER JOIN
2024-02-07 17:57:11 +01:00
verbindlichkeit v ON v . id = vp . verbindlichkeit
2024-02-05 21:21:48 +01:00
INNER JOIN
2024-02-07 17:57:11 +01:00
artikel a ON a . id = vp . artikel
2024-02-05 21:21:48 +01:00
INNER JOIN
2024-02-07 17:57:11 +01:00
adresse adr ON v . adresse = adr . id
2024-02-05 21:21:48 +01:00
LEFT JOIN
kontorahmen skart ON skart . id = a . kontorahmen
LEFT JOIN
kontorahmen skadr ON skadr . id = adr . kontorahmen
2024-02-07 17:57:11 +01:00
WHERE vp . id = " . $verbindlichkeit_position ;
2024-02-05 21:21:48 +01:00
$artikel = $this -> app -> DB -> SelectRow ( $sql );
$einartikel = $artikel [ 'id' ];
$umsatzsteuer = $artikel [ 'umsatzsteuer' ];
2024-02-07 17:57:11 +01:00
$kontorahmen = $artikel [ 'kontorahmen' ];
$preis = $artikel [ 'preis' ];
2024-02-05 21:21:48 +01:00
if ( empty ( $umsatzsteuer ) && is_numeric ( $artikel [ 'steuersatz' ])) {
$steuersatz = $artikel [ 'steuersatz' ];
} else {
$steuersatz = $this -> get_steuersatz ( $umsatzsteuer , $id );
}
2024-02-08 20:37:07 +01:00
2024-02-07 17:57:11 +01:00
$sql = " INSERT INTO lieferantengutschrift_position (lieferantengutschrift,verbindlichkeit_position, menge, preis, steuersatz, artikel, kontorahmen) VALUES ( $id , $verbindlichkeit_position , $menge , $preis , $steuersatz , $einartikel , $kontorahmen ) " ;
2024-02-05 21:21:48 +01:00
$this -> app -> DB -> Insert ( $sql );
}
2024-02-08 16:09:50 +01:00
break ;
case 'artikel_manuell_hinzufuegen' :
$freigabe = $this -> app -> DB -> SelectArr ( " SELECT rechnungsfreigabe, freigabe FROM lieferantengutschrift WHERE id = " . $id )[ 0 ];
if ( $freigabe [ 'rechnungsfreigabe' ] || $freigabe [ 'freigabe' ]) {
break ;
}
// Process multi action
$ids = $this -> app -> Secure -> GetPOST ( 'manuell_artikel_ids' );
$werte = $this -> app -> Secure -> GetPOST ( 'manuell_mengen' );
$preise = $this -> app -> Secure -> GetPOST ( 'preise' );
$bruttoeingabe = $this -> app -> Secure -> GetPOST ( 'bruttoeingabe' );
foreach ( $ids as $key => $artikelid ) {
$menge = $werte [ $key ];
if ( $menge <= 0 ) {
continue ;
}
$preis = $preise [ $key ];
if ( $preis <= 0 ) {
$preis = 0 ;
}
$sql = " SELECT
a . id ,
a . umsatzsteuer ,
a . steuersatz ,
COALESCE ( skart . id , 0 ) AS kontorahmen
FROM
artikel a
LEFT JOIN
kontorahmen skart ON skart . id = a . kontorahmen
WHERE a . id = " . $artikelid ;
$artikel = $this -> app -> DB -> SelectRow ( $sql );
$einartikel = $artikel [ 'id' ];
$umsatzsteuer = $artikel [ 'umsatzsteuer' ];
if ( empty ( $artikel [ 'kontorahmen' ])) {
$kontorahmen = $this -> app -> DB -> Select ( " SELECT a.kontorahmen FROM adresse a INNER JOIN lieferantengutschrift lg ON lg.adresse = a.id WHERE lg.id = " . $id );
} else {
$kontorahmen = $artikel [ 'kontorahmen' ];
}
if ( empty ( $umsatzsteuer ) && is_numeric ( $artikel [ 'steuersatz' ])) {
$steuersatz = $artikel [ 'steuersatz' ];
} else {
$steuersatz = $this -> get_steuersatz ( $umsatzsteuer , $id );
}
if ( $bruttoeingabe ) {
$preis = $preis / ( 1 + ( $steuersatz / 100 ));
}
$sql = " INSERT INTO lieferantengutschrift_position (lieferantengutschrift,verbindlichkeit_position, menge, preis, steuersatz, artikel, kontorahmen) VALUES ( $id , 0, $menge , $preis , $steuersatz , $einartikel , $kontorahmen ) " ;
$this -> app -> DB -> Insert ( $sql );
}
break ;
2024-02-05 21:21:48 +01:00
case 'positionen_entfernen' :
$freigabe = $this -> app -> DB -> SelectArr ( " SELECT rechnungsfreigabe, freigabe FROM lieferantengutschrift WHERE id = " . $id )[ 0 ];
if ( $freigabe [ 'rechnungsfreigabe' ] || $freigabe [ 'freigabe' ]) {
break ;
}
// Process multi action
$ids = $this -> app -> Secure -> GetPOST ( 'auswahl' );
if ( ! is_array ( $ids )) {
break ;
}
$this -> app -> DB -> Delete ( " DELETE vp FROM lieferantengutschrift_position vp INNER JOIN lieferantengutschrift v ON v.id = vp.lieferantengutschrift WHERE vp.id IN ( " . implode ( ',' , $ids ) . " ) AND v.freigabe <> 1 " );
break ;
case 'positionen_steuersatz_zu_netto' :
$freigabe = $this -> app -> DB -> SelectArr ( " SELECT rechnungsfreigabe, freigabe FROM lieferantengutschrift WHERE id = " . $id )[ 0 ];
if ( $freigabe [ 'rechnungsfreigabe' ] || $freigabe [ 'freigabe' ]) {
break ;
}
// Process multi action
$ids = $this -> app -> Secure -> GetPOST ( 'auswahl' );
if ( ! is_array ( $ids )) {
break ;
}
foreach ( $ids as $posid ) {
$tmpsteuersatz = null ;
$tmpsteuertext = null ;
$erloes = null ;
$this -> app -> erp -> GetSteuerPosition ( " lieferantengutschrift " , $posid , $tmpsteuersatz , $tmpsteuertext , $erloes );
$faktor = 1 + ( $tmpsteuersatz / 100 );
$sql = " UPDATE lieferantengutschrift_position SET preis = preis / " . $faktor . " WHERE id = $posid " ;
$this -> app -> DB -> Update ( $sql );
}
break ;
case 'positionen_kontorahmen_setzen' :
$freigabe = $this -> app -> DB -> SelectArr ( " SELECT rechnungsfreigabe, freigabe FROM lieferantengutschrift WHERE id = " . $id )[ 0 ];
if ( $freigabe [ 'rechnungsfreigabe' ]) {
break ;
}
// Process multi action
$ids = $this -> app -> Secure -> GetPOST ( 'auswahl' );
if ( ! is_array ( $ids )) {
break ;
}
$positionen_sachkonto = $this -> app -> Secure -> GetPOST ( 'positionen_sachkonto' );
$positionen_kontorahmen = $this -> app -> erp -> ReplaceKontorahmen ( true , $positionen_sachkonto , false );
foreach ( $ids as $posid ) {
$sql = " UPDATE lieferantengutschrift_position SET kontorahmen = ' " . $positionen_kontorahmen . " ' WHERE id = " . $posid ;
$this -> app -> DB -> Update ( $sql );
}
break ;
}
// Load values again from database
$dropnbox = " '<img src=./themes/new/images/details_open.png class=details>' AS `open`, CONCAT('<input type= \" checkbox \" name= \" auswahl[] \" value= \" ',v.id,' \" />') AS `auswahl` " ;
$result = $this -> app -> DB -> SelectArr ( " SELECT SQL_CALC_FOUND_ROWS v.id,
$dropnbox ,
v . belegnr ,
v . status_beleg ,
v . schreibschutz ,
v . rechnung ,
v . zahlbarbis ,
" . $this->app ->erp->FormatMengeBetrag('v.betrag'). " AS betrag ,
v . skonto ,
v . skontobis ,
v . freigabe ,
v . freigabemitarbeiter ,
v . adresse ,
v . projekt ,
v . status ,
v . bezahlt ,
v . firma ,
v . logdatei ,
v . waehrung ,
v . zahlungsweise ,
v . eingangsdatum ,
v . rechnungsdatum ,
v . rechnungsfreigabe ,
v . kostenstelle ,
v . beschreibung ,
v . sachkonto ,
v . internebemerkung ,
2024-02-07 17:57:11 +01:00
a . lieferantennummer ,
2024-02-05 21:21:48 +01:00
a . name AS adresse_name FROM lieferantengutschrift v LEFT JOIN adresse a ON a . id = v . adresse " . " WHERE v . id = $id " );
foreach ( $result [ 0 ] as $key => $value ) {
$this -> app -> Tpl -> Set ( strtoupper ( $key ), $value );
}
if ( ! empty ( $result [ 0 ])) {
$lieferantengutschrift_from_db = $result [ 0 ];
}
// Check positions
$pos_check = $this -> check_positions ( $lieferantengutschrift_from_db [ 'id' ], $lieferantengutschrift_from_db [ 'betrag' ]);
$this -> app -> Tpl -> Set ( 'BETRAGNETTO' , $pos_check [ 'betrag_netto' ]);
$this -> app -> Tpl -> Set ( 'BETRAGBRUTTOPOS' , $pos_check [ 'betrag_brutto' ]);
if ( empty ( $pos_check [ 'rundungsdifferenz' ])) {
$this -> app -> Tpl -> Set ( 'RUNDUNGSDIFFERENZICONHIDDEN' , 'hidden' );
} else {
$this -> app -> Tpl -> Set ( 'RUNDUNGSDIFFERENZ' , $pos_check [ 'rundungsdifferenz' ]);
}
if ( $pos_check [ 'pos_ok' ]) {
if ( ! $lieferantengutschrift_from_db [ 'freigabe' ] && ! $einkauf_automatik_aus ) {
if ( $this -> lieferantengutschrift_freigabeeinkauf ( $id , " lieferantengutschrift automatisch freigegeben (Einkauf) " ) === true ) {
$this -> app -> YUI -> Message ( 'success' , " lieferantengutschrift automatisch freigegeben (Einkauf) " );
$lieferantengutschrift_from_db [ 'freigabe' ] = 1 ;
} else {
$this -> app -> YUI -> Message ( 'warning' , 'Waren-/Leistungsprüfung (Einkauf) nicht abgeschlossen' );
}
}
$this -> app -> Tpl -> Set ( 'POSITIONENMESSAGE' , '<div class="success">Positionen vollständig</div>' );
if ( $lieferantengutschrift_from_db [ 'status' ] != 'abgeschlossen' && $lieferantengutschrift_from_db [ 'status' ] != 'storniert' ) {
$this -> lieferantengutschrift_abschliessen ( $id );
}
} else {
$this -> app -> Tpl -> Set ( '
POSITIONENMESSAGE ', ' < div class = " warning " > Positionen nicht vollst & auml ; ndig . Bruttobetrag ' .
$lieferantengutschrift_from_db [ 'betrag' ] .
', Summe Positionen (brutto) ' .
$pos_check [ 'betrag_brutto' ] .
', Differenz ' .
round ( $pos_check [ 'betrag_brutto' ] - $lieferantengutschrift_from_db [ 'betrag' ], 2 ) .
'</div>'
);
if ( $lieferantengutschrift_from_db [ 'freigabe' ]) {
$this -> app -> DB -> Update ( " UPDATE lieferantengutschrift SET freigabe = 0 WHERE id = " . $id );
$lieferantengutschrift_from_db [ 'freigabe' ] = 0 ;
$this -> app -> YUI -> Message ( 'warning' , " lieferantengutschrift rückgesetzt (Einkauf) " );
}
}
/*
* Add displayed items later
*
$this -> app -> Tpl -> Add ( 'KURZUEBERSCHRIFT2' , $email );
$this -> app -> Tpl -> Add ( 'EMAIL' , $email );
$this -> app -> Tpl -> Add ( 'ANGEZEIGTERNAME' , $angezeigtername );
$this -> app -> YUI -> AutoComplete ( " artikel " , " artikelnummer " );
*/
$this -> app -> Tpl -> Set ( 'FREIGABEEINKAUFHIDDEN' , 'hidden' ); // prevent manual setting
2024-02-07 17:57:11 +01:00
if ( ! empty ( $lieferantengutschrift_from_db [ 'belegnr' ])) {
$this -> app -> Tpl -> Set ( 'ADRESSESAVEDISABLED' , 'disabled' );
} else {
$this -> app -> YUI -> AutoComplete ( " adresse " , " lieferant " );
$this -> app -> YUI -> AutoComplete ( " verbindlichkeit " , " verbindlichkeit " , false , " &adresse= " . $lieferantengutschrift_from_db [ 'adresse' ]);
}
2024-02-05 21:21:48 +01:00
if ( empty ( $lieferantengutschrift_from_db [ 'adresse' ]) || $lieferantengutschrift_from_db [ 'status' ] == 'angelegt' ) {
$this -> app -> Tpl -> Set ( 'FREIGABEBUCHHALTUNGHIDDEN' , 'hidden' );
$this -> app -> Tpl -> Set ( 'FREIGABEBEZAHLTHIDDEN' , 'hidden' );
$this -> app -> Tpl -> Set ( 'POSITIONHINZUFUEGENHIDDEN' , 'hidden' );
$this -> app -> Tpl -> Set ( 'POSITIONENHIDDEN' , 'hidden' );
}
if ( $lieferantengutschrift_from_db [ 'freigabe' ]) {
$this -> app -> Tpl -> Set ( 'FREIGABEEINKAUFHIDDEN' , 'hidden' );
$this -> app -> Tpl -> Set ( 'EINKAUFINFOHIDDEN' , 'hidden' );
$this -> app -> Tpl -> Set ( 'SAVEDISABLED' , 'disabled' );
$this -> app -> Tpl -> Set ( 'POSITIONHINZUFUEGENHIDDEN' , 'hidden' );
} else {
$this -> app -> Tpl -> Set ( 'RUECKSETZENEINKAUFHIDDEN' , 'hidden' );
$this -> app -> Tpl -> Set ( 'FREIGABEBUCHHALTUNGHIDDEN' , 'hidden' );
}
if ( ! empty ( $positionen )) {
$this -> app -> Tpl -> Set ( 'FREIGABEEINKAUFHIDDEN' , 'hidden' );
}
if ( $lieferantengutschrift_from_db [ 'rechnungsfreigabe' ]) {
$this -> app -> Tpl -> Set ( 'FREIGABEBUCHHALTUNGHIDDEN' , 'hidden' );
$this -> app -> Tpl -> Set ( 'RUECKSETZENEINKAUFHIDDEN' , 'hidden' );
$this -> app -> Tpl -> Set ( 'SACHKONTOCHANGEHIDDEN' , 'hidden' );
} else {
$this -> app -> Tpl -> Set ( 'RUECKSETZENBUCHHALTUNGHIDDEN' , 'hidden' );
}
if ( $lieferantengutschrift_from_db [ 'bezahlt' ] == '1' ) {
$this -> app -> Tpl -> Set ( 'FREIGABEBEZAHLTHIDDEN' , 'hidden' );
} else {
$this -> app -> Tpl -> Set ( 'RUECKSETZENBEZAHLTHIDDEN' , 'hidden' );
}
$this -> app -> Tpl -> Set ( 'WARENEINGANGCHECKED' , $lieferantengutschrift_from_db [ 'freigabe' ] == 1 ? " checked " : " " );
$this -> app -> Tpl -> Set ( 'RECHNUNGSFREIGABECHECKED' , $lieferantengutschrift_from_db [ 'rechnungsfreigabe' ] == 1 ? " checked " : " " );
$this -> app -> Tpl -> Set ( 'BEZAHLTCHECKED' , $lieferantengutschrift_from_db [ 'bezahlt' ] == 1 ? " checked " : " " );
$this -> app -> Tpl -> Set ( 'RECHNUNGSDATUM' , $this -> app -> erp -> ReplaceDatum ( false , $lieferantengutschrift_from_db [ 'rechnungsdatum' ], false ));
$this -> app -> YUI -> DatePicker ( " rechnungsdatum " );
$this -> app -> Tpl -> Set ( 'EINGANGSDATUM' , $this -> app -> erp -> ReplaceDatum ( false , $lieferantengutschrift_from_db [ 'eingangsdatum' ], false ));
$this -> app -> YUI -> DatePicker ( " eingangsdatum " );
$this -> app -> Tpl -> Set ( 'SKONTOBIS' , $this -> app -> erp -> ReplaceDatum ( false , $lieferantengutschrift_from_db [ 'skontobis' ], false ));
$this -> app -> YUI -> DatePicker ( " skontobis " );
$this -> app -> Tpl -> Set ( 'ZAHLBARBIS' , $this -> app -> erp -> ReplaceDatum ( false , $lieferantengutschrift_from_db [ 'zahlbarbis' ], false ));
$this -> app -> YUI -> DatePicker ( " zahlbarbis " );
$sql = " SELECT
" . $this->app ->YUI->IconsSQLverbindlichkeit() . " AS `icons`
FROM lieferantengutschrift v
LEFT JOIN (
SELECT ds . parameter , COUNT ( ds . objekt ) datei_anzahl FROM datei_stichwoerter ds INNER JOIN datei d ON d . id = ds . datei WHERE ds . objekt = 'lieferantengutschrift' AND d . geloescht <> 1 GROUP BY ds . parameter
) d ON d . parameter = v . id
WHERE id = $id " ;
$icons = $this -> app -> DB -> SelectArr ( $sql );
$this -> app -> Tpl -> Add ( 'STATUSICONS' , $icons [ 0 ][ 'icons' ]);
2024-02-07 17:57:11 +01:00
$this -> app -> Tpl -> Set ( 'VERBINDLICHKEIT' , $this -> app -> erp -> ReplaceVerbindlichkeit ( false , $lieferantengutschrift_from_db [ 'verbindlichkeit' ], false ));
2024-02-05 21:21:48 +01:00
$this -> app -> YUI -> AutoComplete ( " projekt " , " projektname " , 1 );
$this -> app -> Tpl -> Set ( 'PROJEKT' , $this -> app -> erp -> ReplaceProjekt ( false , $lieferantengutschrift_from_db [ 'projekt' ], false ));
$this -> app -> YUI -> AutoComplete ( " kostenstelle " , " kostenstelle " , 1 );
$this -> app -> Tpl -> Set ( 'KOSTENSTELLE' , $this -> app -> DB -> SELECT ( " SELECT nummer FROM kostenstellen WHERE id = ' " . $lieferantengutschrift_from_db [ 'kostenstelle' ] . " ' " ));
$waehrungenselect = $this -> app -> erp -> GetSelect ( $this -> app -> erp -> GetWaehrung (), $lieferantengutschrift_from_db [ 'waehrung' ]);
$this -> app -> Tpl -> Set ( 'WAEHRUNGSELECT' , $waehrungenselect );
$this -> app -> Tpl -> Set ( 'ADRESSE_ID' , $lieferantengutschrift_from_db [ 'adresse' ]);
$this -> app -> Tpl -> Set ( 'ADRESSE' , $this -> app -> erp -> ReplaceLieferantennummer ( false , $lieferantengutschrift_from_db [ 'adresse' ], false )); // Convert ID to form display
$this -> app -> Tpl -> Set ( 'BESTELLUNG' , $this -> app -> erp -> ReplaceBestellung ( false , $lieferantengutschrift_from_db [ 'bestellung' ], false ));
$this -> app -> YUI -> AutoComplete ( " bestellung " , " lieferantenbestellung " , 0 , " &adresse= " . $lieferantengutschrift_from_db [ 'adresse' ]);
$this -> app -> YUI -> CkEditor ( " internebemerkung " );
$anzahldateien = $this -> app -> erp -> AnzahlDateien ( " lieferantengutschrift " , $id );
if ( $anzahldateien > 0 ) {
$file = urlencode ( " ../../../../index.php?module=lieferantengutschrift&action=inlinepdf&id= $id " );
$iframe = " <iframe width= \" 100% \" height= \" 100% \" style= \" height:calc(100vh - 110px) \" src= \" ./js/production/generic/web/viewer.html?file= $file\ " ></ iframe > " ;
$this -> app -> Tpl -> Set ( 'INLINEPDF' , $iframe );
} else {
$this -> app -> Tpl -> Set ( 'INLINEPDF' , 'Keine Dateien vorhanden.' );
}
2024-02-08 16:09:50 +01:00
// -- POSITIONEN
2024-02-05 21:21:48 +01:00
if ( empty ( $lieferantengutschrift_from_db [ 'freigabe' ])) {
2024-02-08 16:09:50 +01:00
$this -> app -> YUI -> TableSearch ( 'PAKETDISTRIBUTION' , 'verbindlichkeit_positionen' , " show " , " " , " " , basename ( __FILE__ ), __CLASS__ );
2024-02-07 17:57:11 +01:00
}
2024-02-05 21:21:48 +01:00
$this -> app -> YUI -> AutoComplete ( " positionen_sachkonto " , " sachkonto " , 1 );
$this -> app -> YUI -> TableSearch ( 'POSITIONEN' , 'lieferantengutschrift_positionen' , " show " , " " , " " , basename ( __FILE__ ), __CLASS__ );
$this -> app -> Tpl -> Parse ( 'POSITIONENTAB' , " lieferantengutschrift_positionen.tpl " );
// -- POSITIONEN
2024-02-08 16:09:50 +01:00
// -- POSITIONEN manuell
if ( empty ( $lieferantengutschrift_from_db [ 'freigabe' ])) {
$this -> app -> YUI -> TableSearch ( 'ARTIKELMANUELL' , 'artikel_manuell' , " show " , " " , " " , basename ( __FILE__ ), __CLASS__ );
}
$this -> app -> Tpl -> Parse ( 'POSITIONENMANUELLTAB' , " lieferantengutschrift_artikel_manuell.tpl " );
// -- POSITIONEN manuell
2024-02-05 21:21:48 +01:00
$this -> lieferantengutschrift_minidetail ( 'MINIDETAIL' , false );
$this -> app -> Tpl -> Parse ( 'PAGE' , " lieferantengutschrift_edit.tpl " );
}
function lieferantengutschrift_editpos () {
$id = $this -> app -> Secure -> GetGET ( 'id' );
$posid = $this -> app -> Secure -> GetGET ( 'posid' );
$this -> app -> Tpl -> Set ( 'ID' , $id );
$this -> app -> erp -> MenuEintrag ( " index.php?module=lieferantengutschrift&action=edit&id= $id #tabs-2 " , " Zurück " );
$sachkonto = $this -> app -> Secure -> GetPOST ( 'sachkonto' );
$menge = $this -> app -> Secure -> GetPOST ( 'menge' );
$preis = $this -> app -> Secure -> GetPOST ( 'preis' );
$steuersatz = $this -> app -> Secure -> GetPOST ( 'steuersatz' );
$kontorahmen = $this -> app -> erp -> ReplaceKontorahmen ( true , $sachkonto , false );
if ( $menge < 0 ) {
$menge = 0 ;
}
if ( $preis < 0 ) {
$preis = 0 ;
}
if ( $steuersatz < 0 ) {
$steuersatz = 0 ;
}
$submit = $this -> app -> Secure -> GetPOST ( 'submit' );
$freigabe = $this -> app -> DB -> SelectArr ( " SELECT rechnungsfreigabe, freigabe FROM lieferantengutschrift WHERE id = " . $id )[ 0 ];
if ( $freigabe [ 'rechnungsfreigabe' ] && $freigabe [ 'freigabe' ]) {
$this -> app -> Tpl -> Set ( 'SAVEDISABLED' , 'disabled' );
$this -> app -> Tpl -> Set ( 'SACHKONTOSAVEDISABLED' , 'disabled' );
} else if ( $freigabe [ 'freigabe' ]) {
$this -> app -> Tpl -> Set ( 'SAVEDISABLED' , 'disabled' );
if ( $submit != '' )
{
$sql = "
UPDATE lieferantengutschrift_position SET
kontorahmen = '$kontorahmen'
WHERE id = " . $posid . "
" ;
$this -> app -> DB -> Update ( $sql );
$this -> app -> Tpl -> Set ( 'MESSAGE' , " <div class= \" success \" >Die Einstellungen wurden erfolgreich übernommen.</div> " );
header ( " Location: index.php?module=lieferantengutschrift&action=edit&id= $id &msg= $msg #tabs-2 " );
}
} else {
if ( $submit != '' )
{
$sql = "
UPDATE lieferantengutschrift_position SET
menge = '$menge' ,
preis = '$preis' ,
steuersatz = '$steuersatz' ,
kontorahmen = '$kontorahmen'
WHERE id = " . $posid . "
" ;
$this -> app -> DB -> Update ( $sql );
$this -> app -> Tpl -> Set ( 'MESSAGE' , " <div class= \" success \" >Die Einstellungen wurden erfolgreich übernommen.</div> " );
header ( " Location: index.php?module=lieferantengutschrift&action=edit&id= $id &msg= $msg #tabs-2 " );
}
}
// Load values again from database
$dropnbox = " '<img src=./themes/new/images/details_open.png class=details>' AS `open`, CONCAT('<input type= \" checkbox \" name= \" auswahl[] \" value= \" ',v.id,' \" />') AS `auswahl` " ;
$result = $this -> app -> DB -> SelectArr ( " SELECT SQL_CALC_FOUND_ROWS v.id, $dropnbox , v.steuersatz, v.preis, v.menge, v.kontorahmen, v.id FROM lieferantengutschrift_position v " . " WHERE id= $posid " );
foreach ( $result [ 0 ] as $key => $value ) {
$this -> app -> Tpl -> Set ( strtoupper ( $key ), $value );
}
if ( ! empty ( $result )) {
$lieferantengutschrift_position_from_db = $result [ 0 ];
} else {
return ;
}
/*
* Add displayed items later
*
$this -> app -> Tpl -> Add ( 'KURZUEBERSCHRIFT2' , $email );
$this -> app -> Tpl -> Add ( 'EMAIL' , $email );
$this -> app -> Tpl -> Add ( 'ANGEZEIGTERNAME' , $angezeigtername );
$this -> app -> YUI -> AutoComplete ( " artikel " , " artikelnummer " );
*/
$this -> app -> YUI -> AutoComplete ( " sachkonto " , " sachkonto " , 1 );
$this -> app -> Tpl -> Set ( 'SACHKONTO' , $this -> app -> erp -> ReplaceKontorahmen ( false , $lieferantengutschrift_position_from_db [ 'kontorahmen' ], false ));
$this -> app -> Tpl -> Parse ( 'PAGE' , " lieferantengutschrift_position_edit.tpl " );
}
/**
* Get all paramters from html form and save into $input
*/
public function GetInput () : array {
$input = array ();
$input [ 'adresse' ] = $this -> app -> Secure -> GetPOST ( 'adresse' );
$input [ 'rechnung' ] = $this -> app -> Secure -> GetPOST ( 'rechnung' );
$input [ 'zahlbarbis' ] = $this -> app -> Secure -> GetPOST ( 'zahlbarbis' );
$input [ 'betrag' ] = $this -> app -> Secure -> GetPOST ( 'betrag' );
$input [ 'waehrung' ] = $this -> app -> Secure -> GetPOST ( 'waehrung' );
$input [ 'skonto' ] = $this -> app -> Secure -> GetPOST ( 'skonto' );
$input [ 'skontobis' ] = $this -> app -> Secure -> GetPOST ( 'skontobis' );
$input [ 'projekt' ] = $this -> app -> Secure -> GetPOST ( 'projekt' );
$input [ 'zahlungsweise' ] = $this -> app -> Secure -> GetPOST ( 'zahlungsweise' );
$input [ 'eingangsdatum' ] = $this -> app -> Secure -> GetPOST ( 'eingangsdatum' );
$input [ 'rechnungsdatum' ] = $this -> app -> Secure -> GetPOST ( 'rechnungsdatum' );
$input [ 'kostenstelle' ] = $this -> app -> Secure -> GetPOST ( 'kostenstelle' );
$input [ 'internebemerkung' ] = $this -> app -> Secure -> GetPOST ( 'internebemerkung' );
return $input ;
}
function lieferantengutschrift_menu ( $id ) {
$this -> app -> erp -> MenuEintrag ( " index.php?module=lieferantengutschrift&action=edit&id= $id " , " Details " );
$this -> app -> erp -> MenuEintrag ( " index.php?module=lieferantengutschrift&action=list " , " Zurück zur Übersicht " );
$anzahldateien = $this -> app -> erp -> AnzahlDateien ( " lieferantengutschrift " , $id );
if ( $anzahldateien > 0 ) {
$anzahldateien = " ( " . $anzahldateien . " ) " ;
} else {
$anzahldateien = " " ;
}
if ( $id != 'NULL' ) {
$this -> app -> erp -> MenuEintrag ( " index.php?module=lieferantengutschrift&action=dateien&id= $id " , " Dateien " . $anzahldateien );
}
$invoiceArr = $this -> app -> DB -> SelectRow ( " SELECT v.belegnr, a.name, v.status, schreibschutz FROM lieferantengutschrift v LEFT JOIN adresse a ON v.adresse = a.id WHERE v.id=' $id ' LIMIT 1 " );
$belegnr = $invoiceArr [ 'belegnr' ];
$name = $invoiceArr [ 'name' ];
if ( $belegnr == '0' || $belegnr == '' ) {
$belegnr = '(Entwurf)' ;
}
$this -> app -> Tpl -> Set ( 'KURZUEBERSCHRIFT2' , " $name lieferantengutschrift $belegnr " );
if ( $invoiceArr [ 'status' ] === 'angelegt' || empty ( $invoiceArr [ 'status' ])) {
$this -> app -> erp -> MenuEintrag ( " index.php?module=lieferantengutschrift&action=freigabe&id= $id " , 'Freigabe' );
}
}
function lieferantengutschrift_dateien ()
{
$id = $this -> app -> Secure -> GetGET ( " id " );
$this -> lieferantengutschrift_menu ( $id );
$this -> app -> Tpl -> Add ( 'UEBERSCHRIFT' , " (Dateien) " );
$this -> app -> YUI -> DateiUpload ( 'PAGE' , " lieferantengutschrift " , $id );
}
function lieferantengutschrift_inlinepdf () {
$id = $this -> app -> Secure -> GetGET ( 'id' );
$file_attachments = $this -> app -> erp -> GetDateiSubjektObjekt ( '%' , 'lieferantengutschrift' , $id );
if ( ! empty ( $file_attachments )) {
// Try to merge all PDFs
$file_paths = array ();
foreach ( $file_attachments as $file_attachment ) {
if ( $this -> app -> erp -> GetDateiEndung ( $file_attachment ) == 'pdf' ) {
$file_paths [] = $this -> app -> erp -> GetDateiPfad ( $file_attachment );
}
}
$pdfMerger = $this -> app -> Container -> get ( 'PdfMerger' );
$mergeOutputPath = realpath ( $this -> app -> erp -> GetTMP ()) . '/' . uniqid ( 'sammelpdf_' , true ) . '.pdf' ;
try {
$pdfMerger -> merge ( $file_paths , $mergeOutputPath );
header ( 'Content-type:application/pdf' );
header ( 'Content-Disposition: attachment;filename=' . md5 ( microtime ( true )) . '.pdf' );
readfile ( $mergeOutputPath );
$this -> app -> ExitXentral ();
} catch ( Exception $exception ) {
// Just the first PDF
foreach ( $file_attachments as $file_attachment ) {
if ( $this -> app -> erp -> GetDateiEndung ( $file_attachment ) == 'pdf' ) {
$file_contents = $this -> app -> erp -> GetDatei ( $file_attachment );
header ( 'Content-type:application/pdf' );
header ( 'Content-Disposition: attachment;filename=lieferantengutschrift_' . $id . '.pdf' );
echo ( $file_contents );
$this -> app -> ExitXentral ();
}
}
}
}
$this -> app -> ExitXentral ();
}
function lieferantengutschrift_freigabe ()
{
$id = $this -> app -> Secure -> GetGET ( 'id' );
$this -> app -> erp -> BelegFreigabe ( 'lieferantengutschrift' , $id );
$this -> app -> erp -> BelegProtokoll ( " lieferantengutschrift " , $id , " lieferantengutschrift freigegeben " );
$this -> lieferantengutschrift_edit ();
}
// Returns true or error message
function lieferantengutschrift_freigabeeinkauf ( $id = null , $text = null )
{
if ( empty ( $id )) {
$id = $this -> app -> Secure -> GetGET ( 'id' );
$gotoedit = true ;
}
$error = false ;
if ( ! $this -> lieferantengutschrift_is_freigegeben ( $id )) {
if ( $gotoedit ) {
$this -> app -> YUI -> Message ( 'warning' , 'lieferantengutschrift nicht freigebeben' );
$error = true ;
} else {
return ( 'lieferantengutschrift nicht freigebeben ' . $this -> lieferantengutschrift_get_belegnr ( $id ));
}
2024-02-07 17:57:11 +01:00
}
$sql = " UPDATE lieferantengutschrift SET freigabe = 1 WHERE id= " . $id ;
$this -> app -> DB -> Update ( $sql );
2024-02-05 21:21:48 +01:00
2024-02-07 17:57:11 +01:00
if ( ! $text ) {
$text = " lieferantengutschrift freigegeben (Einkauf) " ;
2024-02-05 21:21:48 +01:00
}
2024-02-07 17:57:11 +01:00
$this -> app -> erp -> BelegProtokoll ( " lieferantengutschrift " , $id , $text );
2024-02-05 21:21:48 +01:00
if ( $gotoedit ) {
$this -> lieferantengutschrift_edit ();
}
else {
return ( true );
}
}
// Returns true or error message
function lieferantengutschrift_freigabebuchhaltung ( $id = null )
{
if ( empty ( $id )) {
$id = $this -> app -> Secure -> GetGET ( 'id' );
$gotoedit = true ;
}
$error = false ;
if ( ! $this -> lieferantengutschrift_is_freigegeben ( $id )) {
if ( $gotoedit ) {
$this -> app -> YUI -> Message ( 'warning' , 'lieferantengutschrift nicht freigebeben' );
$error = true ;
} else {
return ( 'lieferantengutschrift nicht freigebeben ' . $this -> lieferantengutschrift_get_belegnr ( $id ));
}
}
if ( ! $error ) {
// Check accounting
$sql = "
SELECT
vp . id ,
v . belegnr
FROM lieferantengutschrift_position vp
LEFT JOIN lieferantengutschrift v ON v . id = vp . lieferantengutschrift
WHERE
lieferantengutschrift = '$id'
AND vp . kontorahmen = 0
" ;
$check = $this -> app -> DB -> SelectArr ( $sql );
if ( ! empty ( $check )) {
if ( $gotoedit ) {
$this -> app -> YUI -> Message ( 'warning' , 'Kontierung unvollständig' );
$error = true ;
} else {
return ( 'Kontierung unvollständig ' . $this -> lieferantengutschrift_get_belegnr ( $id ));
}
}
}
if ( ! $error ) {
$sql = " UPDATE lieferantengutschrift SET rechnungsfreigabe = 1 WHERE freigabe = 1 AND id= " . $id ;
$this -> app -> DB -> Update ( $sql );
$this -> app -> erp -> BelegProtokoll ( " lieferantengutschrift " , $id , " lieferantengutschrift freigegeben (Buchhaltung) " );
}
if ( $gotoedit ) {
$this -> lieferantengutschrift_edit ();
} else {
return ( true );
}
}
// Returns true or error message
function lieferantengutschrift_freigabebezahlt ( $id = null )
{
if ( empty ( $id )) {
$id = $this -> app -> Secure -> GetGET ( 'id' );
$gotoedit = true ;
}
if ( ! $this -> lieferantengutschrift_is_freigegeben ( $id )) {
if ( $gotoedit ) {
$this -> app -> YUI -> Message ( 'warning' , 'lieferantengutschrift nicht freigebeben' );
$error = true ;
} else {
return ( 'lieferantengutschrift nicht freigebeben ' . $this -> lieferantengutschrift_get_belegnr ( $id ));
}
}
if ( ! $error ) {
$sql = " UPDATE lieferantengutschrift SET bezahlt = 1 WHERE id= " . $id ;
$this -> app -> DB -> Update ( $sql );
$this -> app -> erp -> BelegProtokoll ( " lieferantengutschrift " , $id , " lieferantengutschrift als bezahlt markiert " );
if ( $gotoedit ) {
$this -> lieferantengutschrift_edit ();
} else {
return ( true );
}
}
}
function lieferantengutschrift_abschliessen ( $id = null )
{
if ( empty ( $id )) {
$id = $this -> app -> Secure -> GetGET ( 'id' );
$gotoedit = true ;
}
$sql = " SELECT freigabe, rechnungsfreigabe, bezahlt, betrag FROM lieferantengutschrift WHERE id = " . $id ;
$lieferantengutschrift = $this -> app -> DB -> SelectRow ( $sql );
if ( $lieferantengutschrift [ 'freigabe' ] != 1 ) {
$einkauf_check = $this -> check_positions ( $id , $lieferantengutschrift [ 'betrag' ]);
if ( $einkauf_check [ 'pos_ok' ]) {
$this -> lieferantengutschrift_freigabeeinkauf ( $id );
$lieferantengutschrift [ 'freigabe' ] = 1 ;
}
}
$anzahldateien = $this -> app -> erp -> AnzahlDateien ( " lieferantengutschrift " , $id );
if ( ! empty ( $anzahldateien ) && $lieferantengutschrift [ 'freigabe' ] && $lieferantengutschrift [ 'rechnungsfreigabe' ] && $lieferantengutschrift [ 'bezahlt' ]) {
$sql = " UPDATE lieferantengutschrift SET status = 'abgeschlossen' WHERE id= " . $id ;
$this -> app -> DB -> Update ( $sql );
$this -> app -> erp -> BelegProtokoll ( " lieferantengutschrift " , $id , " lieferantengutschrift abgeschlossen " );
if ( $gotoedit ) {
$this -> lieferantengutschrift_edit ();
}
}
}
function lieferantengutschrift_ruecksetzeneinkauf ( $id = null )
{
if ( empty ( $id )) {
$id = $this -> app -> Secure -> GetGET ( 'id' );
$gotoedit = true ;
}
$sql = " UPDATE lieferantengutschrift SET freigabe = 0 WHERE id= " . $id ;
$this -> app -> DB -> Update ( $sql );
$this -> app -> erp -> BelegProtokoll ( " lieferantengutschrift " , $id , " lieferantengutschrift rückgesetzt (Einkauf) " );
if ( $gotoedit ) {
$this -> lieferantengutschrift_edit ( true );
}
}
function lieferantengutschrift_ruecksetzenbuchhaltung ( $id = null )
{
if ( empty ( $id )) {
$id = $this -> app -> Secure -> GetGET ( 'id' );
$gotoedit = true ;
}
$sql = " UPDATE lieferantengutschrift SET rechnungsfreigabe = 0 WHERE id= " . $id ;
$this -> app -> DB -> Update ( $sql );
$this -> app -> erp -> BelegProtokoll ( " lieferantengutschrift " , $id , " lieferantengutschrift rückgesetzt (Buchhaltung) " );
if ( $gotoedit ) {
$this -> lieferantengutschrift_edit ();
}
}
function lieferantengutschrift_ruecksetzenbezahlt ( $id = null )
{
if ( empty ( $id )) {
$id = $this -> app -> Secure -> GetGET ( 'id' );
$gotoedit = true ;
}
$sql = " UPDATE lieferantengutschrift SET bezahlt = 0 WHERE id= " . $id ;
$this -> app -> DB -> Update ( $sql );
$this -> app -> erp -> BelegProtokoll ( " lieferantengutschrift " , $id , " lieferantengutschrift bezahlt rückgesetzt " );
if ( $gotoedit ) {
$this -> lieferantengutschrift_edit ();
}
}
/* function lieferantengutschrift_schreibschutz ( $id = null )
{
if ( empty ( $id )) {
$id = $this -> app -> Secure -> GetGET ( 'id' );
$gotoedit = true ;
}
$sql = " UPDATE lieferantengutschrift SET schreibschutz = 0 WHERE id= " . $id ;
$this -> app -> DB -> Update ( $sql );
$this -> app -> erp -> BelegProtokoll ( " lieferantengutschrift " , $id , " lieferantengutschrift Schreibschutz entfernt " );
if ( $gotoedit ) {
$this -> lieferantengutschrift_edit ();
}
} */
public function lieferantengutschrift_minidetail ( $parsetarget = '' , $menu = true ) {
$id = $this -> app -> Secure -> GetGET ( 'id' );
$result = $this -> app -> DB -> SelectArr ( " SELECT SQL_CALC_FOUND_ROWS
v . id ,
v . belegnr ,
v . status_beleg ,
v . schreibschutz ,
v . rechnung ,
" . $this->app ->erp->FormatDate('v.zahlbarbis', 'zahlbarbis'). " ,
" . $this->app ->erp->FormatMengeBetrag('v.betrag'). " AS betrag ,
v . skonto ,
" . $this->app ->erp->FormatDate('v.skontobis', 'skontobis'). " ,
v . freigabe ,
v . freigabemitarbeiter ,
p . abkuerzung AS projekt ,
v . status ,
v . bezahlt ,
v . firma ,
v . logdatei ,
v . waehrung ,
v . zahlungsweise ,
" . $this->app ->erp->FormatDate('v.eingangsdatum', 'eingangsdatum'). " ,
" . $this->app ->erp->FormatDate('v.rechnungsdatum', 'rechnungsdatum'). " ,
v . rechnungsfreigabe ,
k . nummer as kostenstelle ,
v . beschreibung ,
v . internebemerkung ,
v . id ,
CONCAT ( a . lieferantennummer , ' ' , a . name ) AS adresse
FROM lieferantengutschrift v
LEFT JOIN adresse a ON a . id = v . adresse
LEFT JOIN projekt p ON a . projekt = p . id
LEFT JOIN kostenstellen k ON v . kostenstelle = k . id
WHERE v . id = '$id' " );
foreach ( $result [ 0 ] as $key => $value ) {
$this -> app -> Tpl -> Set ( strtoupper ( $key ), $value );
}
if ( ! empty ( $result [ 0 ])) {
$lieferantengutschrift_from_db = $result [ 0 ];
}
$positionen = $this -> app -> DB -> SelectArr ( " SELECT vp.id,
vp . sort ,
art . name_de ,
art . nummer ,
vp . menge ,
vp . preis ,
vp . steuersatz ,
CONCAT ( skv . sachkonto , ' ' , skv . beschriftung ) AS sachkonto ,
''
FROM lieferantengutschrift_position vp
INNER JOIN artikel art ON art . id = vp . artikel
LEFT JOIN lieferantengutschrift v ON v . id = vp . lieferantengutschrift
LEFT JOIN adresse adr ON adr . id = v . adresse
LEFT JOIN kontorahmen skv ON skv . id = vp . kontorahmen
WHERE lieferantengutschrift = '$id'
ORDER by vp . sort ASC " );
$tmp = new EasyTable ( $this -> app );
$tmp -> headings = array ( 'Pos.' , 'Artikel-Nr.' , 'Artikel' , 'Menge' , 'Preis' , 'Steuersatz' , 'WIRDUNTENGEFÜLLTWARUMAUCHIMMER' );
$betrag_netto = 0 ;
$betrag_brutto = 0 ;
$steuer_normal = 0 ;
$steuer_ermaessigt = 0 ;
foreach ( $positionen as $position ) {
$tmpsteuersatz = null ;
$tmpsteuertext = null ;
$erloes = null ;
$this -> app -> erp -> GetSteuerPosition ( " lieferantengutschrift " , $position [ 'id' ], $tmpsteuersatz , $tmpsteuertext , $erloes );
$position [ 'steuersatz_berechnet' ] = $tmpsteuersatz ;
$position [ 'steuertext_berechnet' ] = $tmpsteuertext ;
$position [ 'steuererloes_berechnet' ] = $erloes ;
$betrag_netto += ( $position [ 'menge' ] * $position [ 'preis' ]);
$betrag_brutto += ( $position [ 'menge' ] * $position [ 'preis' ]) * ( 1 + ( $tmpsteuersatz / 100 ));
$row = array (
$position [ 'sort' ],
$position [ 'nummer' ],
$position [ 'name_de' ],
$position [ 'menge' ],
$position [ 'preis' ],
$position [ 'steuersatz_berechnet' ],
$position [ 'sachkonto' ]
);
$tmp -> AddRow ( $row );
}
$row = array (
'' ,
'' ,
'' ,
'' ,
'<b>Betrag Positionen netto</b>' ,
'<b>Betrag Positionen brutto</b>'
);
$tmp -> AddRow ( $row );
$row = array (
'' ,
'' ,
'' ,
'' ,
round ( $betrag_netto , 2 ),
round ( $betrag_brutto , 2 )
);
$tmp -> AddRow ( $row );
$tmp -> DisplayNew ( 'ARTIKEL' , " Sachkonto " , " noAction " );
$tmp = new EasyTable ( $this -> app );
$tmp -> Query ( " SELECT zeit,bearbeiter,grund FROM lieferantengutschrift_protokoll WHERE lieferantengutschrift=' $id ' ORDER by zeit DESC " , 0 , " " );
$tmp -> DisplayNew ( 'PROTOKOLL' , " Protokoll " , " noAction " );
if ( $parsetarget == '' )
{
$this -> app -> Tpl -> Output ( 'lieferantengutschrift_minidetail.tpl' );
$this -> app -> ExitXentral ();
}
$this -> app -> Tpl -> Parse ( $parsetarget , 'lieferantengutschrift_minidetail.tpl' );
}
function lieferantengutschrift_is_freigegeben ( $id ) {
$sql = " SELECT
belegnr
FROM
lieferantengutschrift
WHERE
id = '$id'
AND
status IN ( 'freigegeben' )
" ;
$check = $this -> app -> DB -> SelectArr ( $sql );
if ( empty ( $check )) {
return ( false );
} else
{
return ( true );
}
}
function lieferantengutschrift_get_belegnr ( $id ) {
return ( $this -> app -> DB -> Select ( " SELECT belegnr FROM lieferantengutschrift WHERE id = " . $id ));
}
/* Calculate steuersatz
Get from
Check address first , if foreign , then steuersatz = 0
if not foreign there are three cases : befreit = 0 , ermaessigt , normal
if not befreit , get from projekt or firmendaten
*/
function get_steuersatz ( $umsatzsteuer , $lieferantengutschrift ) {
if ( is_numeric ( $umsatzsteuer )) {
return ( $umsatzsteuer );
}
if ( $umsatzsteuer == 'befreit' ) {
return ( 0 );
}
$adresse = $this -> app -> DB -> Select ( " SELECT adresse FROM lieferantengutschrift WHERE id= " . $lieferantengutschrift );
$umsatzsteuer_lieferant = $this -> app -> DB -> Select ( " SELECT umsatzsteuer_lieferant FROM adresse WHERE id= " . $adresse ); /* inland, eu-lieferung, import*/
if ( in_array ( $umsatzsteuer_lieferant , array ( 'import' , 'eulieferung' ))) {
return ( 0 );
}
$projekt = $this -> app -> DB -> Select ( " SELECT projekt FROM lieferantengutschrift WHERE id= " . $lieferantengutschrift );
$steuersatz_projekt = $this -> app -> DB -> SelectRow ( " SELECT steuersatz_normal, steuersatz_ermaessigt FROM projekt WHERE id =' " . $projekt . " ' " );
$steuersatz_normal_projekt = $steuersatz_projekt [ 'steuer_normal' ];
$steuersatz_ermaessigt_projekt = $steuersatz_projekt [ 'steuer_ermaessigt' ];
$steuersatz_normal = $this -> app -> erp -> Firmendaten ( 'steuersatz_normal' );
$steuersatz_ermaessigt = $this -> app -> erp -> Firmendaten ( 'steuersatz_ermaessigt' );
switch ( $umsatzsteuer ) {
case 'normal' :
if ( ! empty ( $steuersatz_normal_projekt )) {
return ( $steuersatz_normal_projekt );
} else {
return ( $steuersatz_normal );
}
break ;
case 'ermaessigt' :
if ( ! empty ( $steuersatz_ermaessigt_projekt )) {
return ( $steuersatz_ermaessigt_projekt );
} else {
return ( $steuersatz_ermaessigt );
}
break ;
default :
return ( 0 );
break ;
}
}
// Check positions and return status and values
function check_positions ( $id , $bruttobetrag_lieferantengutschrift ) : array {
$result = array (
" pos_ok " => false ,
" betrag_netto " => 0 ,
" betrag_brutto " => 0 ,
" rundungsdifferenz " => 0 ,
" bruttobetrag_lieferantengutschrift " => $bruttobetrag_lieferantengutschrift
);
if ( empty ( $id )) {
return ( $result );
}
// Summarize positions
$sql = " SELECT * FROM lieferantengutschrift_position WHERE lieferantengutschrift = " . $id ;
$positionen = $this -> app -> DB -> SelectArr ( $sql );
if ( ! empty ( $positionen )) {
$betrag_netto = 0 ;
$betrag_brutto = 0 ;
$betrag_brutto_pos_summe = 0 ;
$steuer_normal = 0 ;
$steuer_ermaessigt = 0 ;
/*
Normal : umsatzsteuer leer , steuersatz = leer
Ermäßigt : umsatzsteuer ermaessigt , steuersatz = - 1
Befreit : umsatzsteuer befreit , steursatz = - 1
Individuell : umsatzsteuer leer , steuersatz = wert
*/
foreach ( $positionen as $position ) {
$tmpsteuersatz = null ;
$tmpsteuertext = null ;
$erloes = null ;
$this -> app -> erp -> GetSteuerPosition ( " lieferantengutschrift " , $position [ 'id' ], $tmpsteuersatz , $tmpsteuertext , $erloes );
$position [ 'steuersatz_berechnet' ] = $tmpsteuersatz ;
$position [ 'steuertext_berechnet' ] = $tmpsteuertext ;
$position [ 'steuererloes_berechnet' ] = $erloes ;
$betrag_netto += ( $position [ 'menge' ] * $position [ 'preis' ]);
$betrag_brutto += ( $position [ 'menge' ] * $position [ 'preis' ]) * ( 1 + ( $tmpsteuersatz / 100 ));
$betrag_brutto_pos_summe += round (( $position [ 'menge' ] * $position [ 'preis' ]) * ( 1 + ( $tmpsteuersatz / 100 )), 2 );
}
$result [ 'betrag_netto' ] = round ( $betrag_netto , 2 );
$result [ 'betrag_brutto' ] = round ( $betrag_brutto , 2 );
if ( $bruttobetrag_lieferantengutschrift == round ( $betrag_brutto , 2 )) {
$result [ 'pos_ok' ] = true ;
}
else if ( round ( $bruttobetrag_lieferantengutschrift , 2 ) == round ( $betrag_brutto_pos_summe , 2 )) {
$result [ 'pos_ok' ] = true ;
if ( round ( $bruttobetrag_lieferantengutschrift , 2 ) != round ( $betrag_brutto_pos_summe , 2 )) {
$result [ 'rundungsdifferenz' ] = round ( round ( $betrag_brutto , 2 ) - $betrag_brutto_pos_summe , 2 );
}
}
}
return ( $result );
}
}