2023-11-26 12:46:42 +01:00
< ? php
/*
2023-12-13 18:27:08 +01:00
* Copyright ( c ) 2023 OpenXE project
* Xentral ( c ) Xentral ERP Sorftware GmbH , Fuggerstrasse 11 , D - 86150 Augsburg , * Germany 2019
2023-11-26 12:46:42 +01:00
*/
use Xentral\Components\Database\Exception\QueryFailureException ;
class Verbindlichkeit {
function __construct ( $app , $intern = false ) {
$this -> app = $app ;
if ( $intern )
return ;
$this -> app -> ActionHandlerInit ( $this );
$this -> app -> ActionHandler ( " list " , " verbindlichkeit_list " );
$this -> app -> ActionHandler ( " create " , " verbindlichkeit_edit " ); // This automatically adds a "New" button
$this -> app -> ActionHandler ( " edit " , " verbindlichkeit_edit " );
2023-12-11 22:17:28 +01:00
$this -> app -> ActionHandler ( " positionen " , " verbindlichkeit_positionen " );
2023-11-26 12:46:42 +01:00
$this -> app -> ActionHandler ( " delete " , " verbindlichkeit_delete " );
2023-11-30 19:39:11 +01:00
$this -> app -> ActionHandler ( " dateien " , " verbindlichkeit_dateien " );
$this -> app -> ActionHandler ( " inlinepdf " , " verbindlichkeit_inlinepdf " );
2023-12-11 22:17:28 +01:00
$this -> app -> ActionHandler ( " positioneneditpopup " , " verbindlichkeit_positioneneditpopup " );
2023-12-13 18:27:08 +01:00
$this -> app -> ActionHandler ( " freigabe " , " verbindlichkeit_freigabe " );
2023-12-27 18:17:30 +01:00
$this -> app -> ActionHandler ( " schreibschutz " , " verbindlichkeit_schreibschutz " );
2023-12-25 21:30:58 +01:00
$this -> app -> ActionHandler ( " freigabeeinkauf " , " verbindlichkeit_freigabeeinkauf " );
$this -> app -> ActionHandler ( " freigabebuchhaltung " , " verbindlichkeit_freigabebuchhaltung " );
$this -> app -> ActionHandler ( " freigabebezahlt " , " verbindlichkeit_freigabebezahlt " );
2023-12-27 18:17:30 +01:00
$this -> app -> ActionHandler ( " ruecksetzeneinkauf " , " verbindlichkeit_ruecksetzeneinkauf " );
$this -> app -> ActionHandler ( " ruecksetzenbuchhaltung " , " verbindlichkeit_ruecksetzenbuchhaltung " );
$this -> app -> ActionHandler ( " ruecksetzenbezahlt " , " verbindlichkeit_ruecksetzenbezahlt " );
$this -> app -> ActionHandler ( " minidetail " , " verbindlichkeit_minidetail " );
2023-12-11 22:17:28 +01:00
2023-11-26 12:46:42 +01:00
$this -> app -> DefaultActionHandler ( " list " );
$this -> app -> ActionHandlerListen ( $app );
}
public function Install () {
/* Fill out manually later */
}
2023-12-25 21:30:58 +01:00
function TableSearch ( & $app , $name , $erlaubtevars ) {
2023-11-26 12:46:42 +01:00
switch ( $name ) {
case " verbindlichkeit_list " :
$allowed [ 'verbindlichkeit_list' ] = array ( 'list' );
2023-12-13 18:27:08 +01:00
$heading = array ( '' , '' , 'Belegnr' , 'Adresse' , 'Lieferant' , 'RE-Nr' , 'RE-Datum' , 'Betrag (brutto)' , 'Währung' , 'Ziel' , 'Skontoziel' , 'Skonto' , 'Status' , 'Monitor' , 'Menü' );
2023-11-26 12:46:42 +01:00
$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.id' ,
'a.name' ,
'a.lieferantennummer' ,
'v.rechnung' ,
'v.rechnungsdatum' ,
'v.betrag' ,
'v.waehrung' ,
'v.zahlbarbis' ,
'v.skontobis' ,
'v.skonto' ,
2023-12-13 18:27:08 +01:00
'v.status' ,
2023-11-26 12:46:42 +01:00
'v.status_beleg' ,
'v.id'
);
$searchsql = array (
'a.name' ,
'a.lieferantennummer' ,
'v.rechnung' ,
'v.internebemerkung'
);
$defaultorder = 1 ;
$defaultorderdesc = 0 ;
$alignright = array ( 8 );
2023-11-30 19:39:11 +01:00
$sumcol = array ( 8 );
2023-11-26 12:46:42 +01:00
$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=verbindlichkeit&action=edit&id=%value% \" ><img src= \" ./themes/ { $app -> Conf -> WFconf [ 'defaulttheme' ] } /images/edit.svg \" border= \" 0 \" ></a> <a href= \" # \" onclick=DeleteDialog( \" index.php?module=verbindlichkeit&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 ,
" . $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). " , '%' ), '' ),
2023-12-13 18:27:08 +01:00
v . status ,
2023-11-26 12:46:42 +01:00
" . $app->YUI ->IconsSQLVerbindlichkeit(). " ,
v . id FROM verbindlichkeit v
LEFT JOIN adresse a ON v . adresse = a . id
" ;
$where = " 1 " ;
$count = " SELECT count(DISTINCT id) FROM verbindlichkeit WHERE $where " ;
// $groupby = "";
2023-12-25 21:30:58 +01:00
// Toggle filters
$this -> app -> Tpl -> Add ( 'JQUERYREADY' , " $ ('#wareneingang').click( function() { fnFilterColumn1( 0 ); } ); " );
$this -> app -> Tpl -> Add ( 'JQUERYREADY' , " $ ('#rechnungsfreigabe').click( function() { fnFilterColumn2( 0 ); } ); " );
$this -> app -> Tpl -> Add ( 'JQUERYREADY' , " $ ('#nichtbezahlt').click( function() { fnFilterColumn3( 0 ); } ); " );
for ( $r = 1 ; $r <= 3 ; $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 v.freigabe <> '1' " ;
} else {
}
$more_data2 = $this -> app -> Secure -> GetGET ( " more_data2 " );
if ( $more_data2 == 1 ) {
$where .= " AND v.rechnungsfreigabe <> '1' " ;
}
else {
}
$more_data3 = $this -> app -> Secure -> GetGET ( " more_data3 " );
if ( $more_data3 == 1 ) {
$where .= " AND v.bezahlt <> '1' " ;
}
else {
}
// END Toggle filters
2023-12-27 18:17:30 +01:00
$this -> app -> YUI -> DatePicker ( 'zahlbarbis' );
$filterzahlbarbis = $this -> app -> YUI -> TableSearchFilter ( $name , 4 , '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 , 5 , 'skontobis' );
if ( ! empty ( $filterskontobis )) {
$filterskontobis = $this -> app -> String -> Convert ( $filterskontobis , '%1.%2.%3' , '%3-%2-%1' );
$where .= " AND v.skontobis <= ' " . $filterskontobis . " ' " ;
}
$moreinfo = true ; // Allow drop down details
$menucol = 1 ; // For moredata
2023-12-25 21:30:58 +01:00
2023-11-26 12:46:42 +01:00
break ;
}
$erg = false ;
foreach ( $erlaubtevars as $k => $v ) {
if ( isset ( $$v )) {
$erg [ $v ] = $$v ;
}
}
return $erg ;
}
function verbindlichkeit_list () {
2023-12-25 21:30:58 +01:00
// Process multi action
$submit = $this -> app -> Secure -> GetPOST ( 'ausfuehren' );
if ( ! empty ( $submit )) {
$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' :
2023-12-27 18:17:30 +01:00
foreach ( $selectedIds as $id ) {
$this -> verbindlichkeit_freigabeeinkauf ( $id );
}
2023-12-25 21:30:58 +01:00
break ;
case 'freigabebuchhaltung' :
2023-12-27 18:17:30 +01:00
foreach ( $selectedIds as $id ) {
$this -> verbindlichkeit_freigabebuchhaltung ( $id );
}
2023-12-25 21:30:58 +01:00
break ;
case 'bezahlt' :
2023-12-27 18:17:30 +01:00
foreach ( $selectedIds as $id ) {
$this -> verbindlichkeit_freigabebezahlt ( $id );
}
2023-12-25 21:30:58 +01:00
break ;
}
}
}
2023-11-26 12:46:42 +01:00
$this -> app -> erp -> MenuEintrag ( " index.php?module=verbindlichkeit&action=list " , " Übersicht " );
$this -> app -> erp -> MenuEintrag ( " index.php?module=verbindlichkeit&action=create " , " Neu anlegen " );
$this -> app -> erp -> MenuEintrag ( " index.php " , " Zurück " );
$this -> app -> YUI -> TableSearch ( 'TAB1' , 'verbindlichkeit_list' , " show " , " " , " " , basename ( __FILE__ ), __CLASS__ );
2023-12-25 21:30:58 +01:00
2023-12-27 18:17:30 +01:00
/*
Prepared for later use ...
2023-12-25 21:30:58 +01:00
if ( $this -> app -> erp -> RechteVorhanden ( 'verbindlichkeit' , 'freigabeeinkauf' )){
$this -> app -> Tpl -> Set ( 'MANUELLFREIGABEEINKAUF' , '<option value="freigabeeinkauf">{|freigeben (Einkauf)|}</option>' );
}
if ( $this -> app -> erp -> RechteVorhanden ( 'verbindlichkeit' , 'freigabebuchhaltung' )){
$this -> app -> Tpl -> Set ( 'MANUELLFREIGABEBUCHHALTUNG' , '<option value="freigabebuchhaltung">{|freigeben (Buchhaltung)|}</option>' );
}
if ( $this -> app -> erp -> RechteVorhanden ( 'verbindlichkeit' , 'freigabebezahlt' )){
$this -> app -> Tpl -> Set ( 'ALSBEZAHLTMARKIEREN' , '<option value="bezahlt">{|als bezahlt markieren|}</option>' );
}
2023-12-27 18:17:30 +01:00
*/
$this -> app -> User -> SetParameter ( 'table_verbindlichkeit_list_zahlbarbis' , '' );
$this -> app -> User -> SetParameter ( 'table_verbindlichkeit_list_skontobis' , '' );
2023-12-25 21:30:58 +01:00
2023-11-26 12:46:42 +01:00
$this -> app -> Tpl -> Parse ( 'PAGE' , " verbindlichkeit_list.tpl " );
}
public function verbindlichkeit_delete () {
$id = ( int ) $this -> app -> Secure -> GetGET ( 'id' );
2023-12-27 18:17:30 +01:00
$this -> app -> DB -> Delete ( " UPDATE `verbindlichkeit` SET status='storniert' WHERE `id` = ' { $id } ' " );
$this -> app -> Tpl -> Set ( 'MESSAGE' , " <div class= \" error \" >Der Eintrag wurde storniert.</div> " );
2023-11-26 12:46:42 +01:00
$this -> verbindlichkeit_list ();
}
/*
* Edit verbindlichkeit item
* If id is empty , create a new one
*/
function verbindlichkeit_edit () {
$id = $this -> app -> Secure -> GetGET ( 'id' );
2023-12-11 22:17:28 +01:00
$this -> app -> YUI -> AARLGPositionen ( true ); // create iframe with positionen action
2023-11-26 12:46:42 +01:00
// Check if other users are editing this id
if ( $this -> app -> erp -> DisableModul ( 'artikel' , $id ))
{
return ;
}
$this -> app -> Tpl -> Set ( 'ID' , $id );
2023-11-30 19:39:11 +01:00
$this -> verbindlichkeit_menu ( $id );
2023-11-26 12:46:42 +01:00
$input = $this -> GetInput ();
$submit = $this -> app -> Secure -> GetPOST ( 'submit' );
if ( empty ( $id )) {
// New item
$id = 'NULL' ;
2023-12-13 18:27:08 +01:00
$input [ 'status' ] = 'angelegt' ;
2023-11-26 12:46:42 +01:00
}
if ( $submit != '' )
{
2023-12-13 18:27:08 +01:00
// Write to database
2023-11-26 12:46:42 +01:00
// Add checks here
2023-12-27 18:17:30 +01:00
$schreibschutz = $this -> app -> DB -> Select ( " SELECT schreibschutz FROM verbindlichkeit WHERE id = " . $id );
2023-11-26 12:46:42 +01:00
2023-12-27 18:17:30 +01:00
if ( $schreibschutz ) {
2023-12-13 18:27:08 +01:00
$internebemerkung = $input [ 'internebemerkung' ];
2023-12-25 21:30:58 +01:00
$projekt = $input [ 'projekt' ];
$kostenstelle = $input [ 'kostenstelle' ];
2023-12-13 18:27:08 +01:00
unset ( $input );
$input [ 'internebemerkung' ] = $internebemerkung ;
2023-12-25 21:30:58 +01:00
$input [ 'projekt' ] = $this -> app -> erp -> ReplaceProjekt ( true , $projekt , true );
2023-12-27 18:17:30 +01:00
$input [ 'kostenstelle' ] = $this -> app -> DB -> Select ( " SELECT id FROM kostenstellen WHERE nummer = ' " . $kostenstelle . " ' " );
2023-12-13 18:27:08 +01:00
} else {
2023-12-25 21:30:58 +01:00
$input [ 'adresse' ] = $this -> app -> erp -> ReplaceLieferantennummer ( true , $input [ 'adresse' ], true ); // Parameters: Target db?, value, from form?
2023-12-13 18:27:08 +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 );
2023-12-27 18:17:30 +01:00
$input [ 'kostenstelle' ] = $this -> app -> DB -> Select ( " SELECT id FROM kostenstellen WHERE nummer = ' " . $input [ 'kostenstelle' ] . " ' " );
2023-12-25 21:30:58 +01:00
if ( empty ( $input [ 'projekt' ]) && ! empty ( $input [ 'adresse' ])) {
$input [ 'projekt' ] = $this -> app -> erp -> GetCreateProjekt ( $input [ 'adresse' ]);
}
2023-12-13 18:27:08 +01:00
}
2023-11-26 12:46:42 +01:00
$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 verbindlichkeit ( " . $columns . " ) VALUES ( " . $values . " ) ON DUPLICATE KEY UPDATE " . $update ;
// echo($sql);
$this -> app -> DB -> Update ( $sql );
if ( $id == 'NULL' ) {
2023-12-13 18:27:08 +01:00
$id = $this -> app -> DB -> GetInsertID ();
2023-11-26 12:46:42 +01:00
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" success \" >Das Element wurde erfolgreich angelegt.</div> " );
2023-12-13 18:27:08 +01:00
header ( " Location: index.php?module=verbindlichkeit&action=edit&id= $id &msg= $msg " );
2023-11-26 12:46:42 +01:00
} else {
$this -> app -> Tpl -> Set ( 'MESSAGE' , " <div class= \" success \" >Die Einstellungen wurden erfolgreich übernommen.</div> " );
}
}
// 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` " ;
2023-11-30 19:39:11 +01:00
$result = $this -> app -> DB -> SelectArr ( " SELECT SQL_CALC_FOUND_ROWS v.id, $dropnbox , v.belegnr, v.status_beleg, v.schreibschutz, v.rechnung, v.zahlbarbis, v.betrag, v.umsatzsteuer, v.ustid, v.summenormal, v.summeermaessigt, v.summesatz3, v.summesatz4, v.steuersatzname3, v.steuersatzname4, v.skonto, v.skontobis, v.skontofestsetzen, v.freigabe, v.freigabemitarbeiter, v.bestellung, v.adresse, v.projekt, v.teilprojekt, v.auftrag, v.status, v.bezahlt, v.kontoauszuege, v.firma, v.logdatei, v.bestellung1, v.bestellung1betrag, v.bestellung1bemerkung, v.bestellung1projekt, v.bestellung1kostenstelle, v.bestellung1auftrag, v.bestellung2, v.bestellung2betrag, v.bestellung2bemerkung, v.bestellung2kostenstelle, v.bestellung2auftrag, v.bestellung2projekt, v.bestellung3, v.bestellung3betrag, v.bestellung3bemerkung, v.bestellung3kostenstelle, v.bestellung3auftrag, v.bestellung3projekt, v.bestellung4, v.bestellung4betrag, v.bestellung4bemerkung, v.bestellung4kostenstelle, v.bestellung4auftrag, v.bestellung4projekt, v.bestellung5, v.bestellung5betrag, v.bestellung5bemerkung, v.bestellung5kostenstelle, v.bestellung5auftrag, v.bestellung5projekt, v.bestellung6, v.bestellung6betrag, v.bestellung6bemerkung, v.bestellung6kostenstelle, v.bestellung6auftrag, v.bestellung6projekt, v.bestellung7, v.bestellung7betrag, v.bestellung7bemerkung, v.bestellung7kostenstelle, v.bestellung7auftrag, v.bestellung7projekt, v.bestellung8, v.bestellung8betrag, v.bestellung8bemerkung, v.bestellung8kostenstelle, v.bestellung8auftrag, v.bestellung8projekt, v.bestellung9, v.bestellung9betrag, v.bestellung9bemerkung, v.bestellung9kostenstelle, v.bestellung9auftrag, v.bestellung9projekt, v.bestellung10, v.bestellung10betrag, v.bestellung10bemerkung, v.bestellung10kostenstelle, v.bestellung10auftrag, v.bestellung10projekt, v.bestellung11, v.bestellung11betrag, v.bestellung11bemerkung, v.bestellung11kostenstelle, v.bestellung11auftrag, v.bestellung11projekt, v.bestellung12, v.bestellung12betrag, v.bestellung12bemerkung, v.bestellung12projekt, v.bestellung12kostenstelle, v.bestellung12auftrag, v.bestellung13, v.bestellung13betrag, v.bestellung13bemerkung, v.bestellung13kostenstelle, v.bestellung13auftrag, v.bestellung13projekt, v.bestellung14, v.bestellung14betrag, v.bestellung14bemerkung, v.bestellung14kostenstelle, v.bestellung14auftrag, v.bestellung14projekt, v.bestellung15, v.bestellung15betrag, v.bestellung15bemerkung, v.bestellung15kostenstelle, v.bestellung15auftrag, v.bestellung15projekt, v.waehrung, v.zahlungsweise, v.eingangsdatum, v.buha_konto1, v.buha_belegfeld1, v.buha_betrag1, v.buha_konto2, v.buha_belegfeld2, v.buha_betrag2, v.buha_konto3, v.buha_belegfeld3, v.buha_betrag3, v.buha_konto4, v.buha_belegfeld4, v.buha_betrag4, v.buha_konto5, v.buha_belegfeld5, v.buha_betrag5, v.rechnungsdatum, v.rechnungsfreigabe, v.kostenstelle, v.beschreibung, v.sachkonto, v.art, v.verwendungszweck, v.dta_datei, v.frachtkosten, v.internebemerkung, v.ustnormal, v.ustermaessigt, v.uststuer3, v.uststuer4, v.betragbezahlt, v.bezahltam, v.klaerfall, v.klaergrund, v.skonto_erhalten, v.kurs, v.sprache, v.id, a.lieferantennummer, a.name AS adresse_name FROM verbindlichkeit v LEFT JOIN adresse a ON a.id = v.adresse " . " WHERE v.id= $id " );
2023-11-26 12:46:42 +01:00
foreach ( $result [ 0 ] as $key => $value ) {
$this -> app -> Tpl -> Set ( strtoupper ( $key ), $value );
}
2023-11-30 19:39:11 +01:00
if ( ! empty ( $result [ 0 ])) {
$verbindlichkeit_from_db = $result [ 0 ];
}
2023-12-13 18:27:08 +01:00
// Summarize positions
$sql = " SELECT * FROM verbindlichkeit_position WHERE verbindlichkeit = " . $id ;
$positionen = $this -> app -> DB -> SelectArr ( $sql );
if ( ! empty ( $positionen )) {
$betrag_netto = 0 ;
$betrag_brutto = 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 ;
// function GetSteuerPosition($typ, $posid,&$tmpsteuersatz = null, &$tmpsteuertext = null, &$erloes = null)
$this -> app -> erp -> GetSteuerPosition ( " verbindlichkeit " , $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 ));
}
$this -> app -> Tpl -> Set ( 'BETRAGNETTO' , $betrag_netto );
2023-12-25 21:30:58 +01:00
$this -> app -> Tpl -> Set ( 'BETRAGBRUTTOPOS' , round ( $betrag_brutto , 2 ));
2023-12-13 18:27:08 +01:00
$this -> app -> Tpl -> Set ( 'BETRAGDISABLED' , 'disabled' );
}
2023-11-30 19:39:11 +01:00
2023-11-26 12:46:42 +01:00
/*
* 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 " );
*/
2023-12-27 18:17:30 +01:00
if ( $verbindlichkeit_from_db [ 'schreibschutz' ]) {
2023-12-13 18:27:08 +01:00
$this -> app -> Tpl -> Set ( 'SAVEDISABLED' , 'disabled' );
2023-12-27 18:17:30 +01:00
$this -> app -> Tpl -> Set ( 'MESSAGE' , " <div class= \" warning \" >Diese Verbindlichkeit ist schreibgeschützt und darf daher nicht mehr bearbeitet werden! <input type= \" button \" value= \" Schreibschutz entfernen \" onclick= \" if(!confirm('Soll der Schreibschutz für diese Verbindlichkeit wirklich entfernt werden?')) return false;else window.location.href='index.php?module=verbindlichkeit&action=schreibschutz&id= $id '; \" ></div> " );
2023-12-13 18:27:08 +01:00
}
2023-12-27 18:17:30 +01:00
if ( empty ( $verbindlichkeit_from_db [ 'adresse' ] || $verbindlichkeit_from_db [ 'status' ] == 'angelegt' )) {
$this -> app -> Tpl -> Set ( 'FREIGABEEINKAUFHIDDEN' , 'hidden' );
$this -> app -> Tpl -> Set ( 'FREIGABEBUCHHALTUNGHIDDEN' , 'hidden' );
$this -> app -> Tpl -> Set ( 'FREIGABEBEZAHLTHIDDEN' , 'hidden' );
}
if ( $verbindlichkeit_from_db [ 'freigabe' ]) {
$this -> app -> Tpl -> Set ( 'FREIGABEEINKAUFHIDDEN' , 'hidden' );
} else {
$this -> app -> Tpl -> Set ( 'RUECKSETZENEINKAUFHIDDEN' , 'hidden' );
}
if ( $verbindlichkeit_from_db [ 'rechnungsfreigabe' ]) {
2023-12-25 21:30:58 +01:00
$this -> app -> Tpl -> Set ( 'FREIGABEBUCHHALTUNGHIDDEN' , 'hidden' );
2023-12-27 18:17:30 +01:00
} else {
$this -> app -> Tpl -> Set ( 'RUECKSETZENBUCHHALTUNGHIDDEN' , 'hidden' );
2023-12-25 21:30:58 +01:00
}
2023-12-27 18:17:30 +01:00
if ( $verbindlichkeit_from_db [ 'bezahlt' ] == '1' ) {
2023-12-25 21:30:58 +01:00
$this -> app -> Tpl -> Set ( 'FREIGABEBEZAHLTHIDDEN' , 'hidden' );
2023-12-27 18:17:30 +01:00
} else {
$this -> app -> Tpl -> Set ( 'RUECKSETZENBEZAHLTHIDDEN' , 'hidden' );
2023-12-25 21:30:58 +01:00
}
$this -> app -> Tpl -> Set ( 'WARENEINGANGCHECKED' , $verbindlichkeit_from_db [ 'freigabe' ] == 1 ? " checked " : " " );
2023-12-13 18:27:08 +01:00
$this -> app -> Tpl -> Set ( 'RECHNUNGSFREIGABECHECKED' , $verbindlichkeit_from_db [ 'rechnungsfreigabe' ] == 1 ? " checked " : " " );
$this -> app -> Tpl -> Set ( 'BEZAHLTCHECKED' , $verbindlichkeit_from_db [ 'bezahlt' ] == 1 ? " checked " : " " );
$this -> app -> Tpl -> Set ( 'RECHNUNGSDATUM' , $this -> app -> erp -> ReplaceDatum ( false , $verbindlichkeit_from_db [ 'rechnungsdatum' ], false ));
$this -> app -> YUI -> DatePicker ( " rechnungsdatum " );
$this -> app -> Tpl -> Set ( 'EINGANGSDATUM' , $this -> app -> erp -> ReplaceDatum ( false , $verbindlichkeit_from_db [ 'eingangsdatum' ], false ));
$this -> app -> YUI -> DatePicker ( " eingangsdatum " );
$this -> app -> Tpl -> Set ( 'SKONTOBIS' , $this -> app -> erp -> ReplaceDatum ( false , $verbindlichkeit_from_db [ 'skontobis' ], false ));
$this -> app -> YUI -> DatePicker ( " skontobis " );
$this -> app -> Tpl -> Set ( 'ZAHLBARBIS' , $this -> app -> erp -> ReplaceDatum ( false , $verbindlichkeit_from_db [ 'zahlbarbis' ], false ));
$this -> app -> YUI -> DatePicker ( " zahlbarbis " );
2023-11-30 19:39:11 +01:00
$sql = " SELECT " . $this -> app -> YUI -> IconsSQLVerbindlichkeit () . " AS `icons` FROM verbindlichkeit v WHERE id= $id " ;
$icons = $this -> app -> DB -> SelectArr ( $sql );
$this -> app -> Tpl -> Add ( 'STATUSICONS' , $icons [ 0 ][ 'icons' ]);
2023-12-25 21:30:58 +01:00
$this -> app -> YUI -> AutoComplete ( " adresse " , " lieferant " );
2023-12-13 18:27:08 +01:00
$this -> app -> YUI -> AutoComplete ( " projekt " , " projektname " , 1 );
$this -> app -> Tpl -> Set ( 'PROJEKT' , $this -> app -> erp -> ReplaceProjekt ( false , $verbindlichkeit_from_db [ 'projekt' ], false ));
$this -> app -> YUI -> AutoComplete ( " kostenstelle " , " kostenstelle " , 1 );
2023-12-27 18:17:30 +01:00
$this -> app -> Tpl -> Set ( 'KOSTENSTELLE' , $this -> app -> DB -> SELECT ( " SELECT nummer FROM kostenstellen WHERE id = ' " . $verbindlichkeit_from_db [ 'kostenstelle' ] . " ' " ));
2023-11-30 19:39:11 +01:00
$waehrungenselect = $this -> app -> erp -> GetSelect ( $this -> app -> erp -> GetWaehrung (), $verbindlichkeit_from_db [ 'waehrung' ]);
2023-12-27 18:17:30 +01:00
$this -> app -> Tpl -> Set ( 'WAEHRUNGSELECT' , $waehrungenselect );
2023-11-30 19:39:11 +01:00
$this -> app -> Tpl -> Set ( 'ADRESSE_ID' , $verbindlichkeit_from_db [ 'adresse' ]);
2023-12-27 18:17:30 +01:00
$this -> app -> Tpl -> Set ( 'ADRESSE' , $this -> app -> erp -> ReplaceLieferantennummer ( false , $verbindlichkeit_from_db [ 'adresse' ], false )); // Convert ID to form display
2023-12-25 21:30:58 +01:00
$this -> app -> YUI -> CkEditor ( " internebemerkung " );
2023-11-30 19:39:11 +01:00
2023-12-13 18:27:08 +01:00
$anzahldateien = $this -> app -> erp -> AnzahlDateien ( " verbindlichkeit " , $id );
if ( $anzahldateien > 0 ) {
$file = urlencode ( " ../../../../index.php?module=verbindlichkeit&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.' );
}
2023-11-30 19:39:11 +01:00
2023-12-27 18:17:30 +01:00
$this -> verbindlichkeit_minidetail ( 'MINIDETAIL' , false );
2023-11-26 12:46:42 +01:00
$this -> app -> Tpl -> Parse ( 'PAGE' , " verbindlichkeit_edit.tpl " );
2023-12-13 18:27:08 +01:00
2023-11-26 12:46:42 +01:00
}
/**
* Get all paramters from html form and save into $input
*/
public function GetInput () : array {
$input = array ();
2023-11-30 19:39:11 +01:00
$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' );
2023-12-13 18:27:08 +01:00
$input [ 'bezahlt' ] = $this -> app -> Secure -> GetPOST ( 'bezahlt' ) ? '1' : '0' ;;
2023-11-30 19:39:11 +01:00
$input [ 'zahlungsweise' ] = $this -> app -> Secure -> GetPOST ( 'zahlungsweise' );
$input [ 'eingangsdatum' ] = $this -> app -> Secure -> GetPOST ( 'eingangsdatum' );
$input [ 'rechnungsdatum' ] = $this -> app -> Secure -> GetPOST ( 'rechnungsdatum' );
2023-12-13 18:27:08 +01:00
$input [ 'freigabe' ] = $this -> app -> Secure -> GetPOST ( 'freigabe' ) ? '1' : '0' ;
$input [ 'rechnungsfreigabe' ] = $this -> app -> Secure -> GetPOST ( 'rechnungsfreigabe' ) ? '1' : '0' ;
2023-11-30 19:39:11 +01:00
$input [ 'kostenstelle' ] = $this -> app -> Secure -> GetPOST ( 'kostenstelle' );
$input [ 'internebemerkung' ] = $this -> app -> Secure -> GetPOST ( 'internebemerkung' );
2023-11-26 12:46:42 +01:00
return $input ;
}
2023-11-30 19:39:11 +01:00
function verbindlichkeit_menu ( $id ) {
2023-12-25 21:30:58 +01:00
$this -> app -> erp -> MenuEintrag ( " index.php?module=verbindlichkeit&action=edit&id= $id " , " Details " );
$this -> app -> erp -> MenuEintrag ( " index.php?module=verbindlichkeit&action=list " , " Zurück zur Übersicht " );
2023-11-30 19:39:11 +01:00
$anzahldateien = $this -> app -> erp -> AnzahlDateien ( " verbindlichkeit " , $id );
if ( $anzahldateien > 0 ) {
$anzahldateien = " ( " . $anzahldateien . " ) " ;
} else {
$anzahldateien = " " ;
}
2023-12-13 18:27:08 +01:00
if ( $id != 'NULL' ) {
$this -> app -> erp -> MenuEintrag ( " index.php?module=verbindlichkeit&action=dateien&id= $id " , " Dateien " . $anzahldateien );
}
2023-12-27 18:17:30 +01:00
$invoiceArr = $this -> app -> DB -> SelectRow ( " SELECT v.belegnr, a.name, v.status, schreibschutz FROM verbindlichkeit v LEFT JOIN adresse a ON v.adresse = a.id WHERE v.id=' $id ' LIMIT 1 " );
2023-12-13 18:27:08 +01:00
$belegnr = $invoiceArr [ 'belegnr' ];
$name = $invoiceArr [ 'name' ];
if ( $belegnr == '0' || $belegnr == '' ) {
$belegnr = '(Entwurf)' ;
}
2023-12-25 21:30:58 +01:00
$this -> app -> Tpl -> Set ( 'KURZUEBERSCHRIFT2' , " $name Verbindlichkeit $belegnr " );
2023-12-27 18:17:30 +01:00
if ( $invoiceArr [ 'status' ] === 'angelegt' || $invoiceArr [ 'schreibschutz' ] != 1 ) {
2023-12-13 18:27:08 +01:00
$this -> app -> erp -> MenuEintrag ( " index.php?module=verbindlichkeit&action=freigabe&id= $id " , 'Freigabe' );
}
2023-11-30 19:39:11 +01:00
}
function verbindlichkeit_dateien ()
{
$id = $this -> app -> Secure -> GetGET ( " id " );
$this -> verbindlichkeit_menu ( $id );
$this -> app -> Tpl -> Add ( 'UEBERSCHRIFT' , " (Dateien) " );
$this -> app -> YUI -> DateiUpload ( 'PAGE' , " verbindlichkeit " , $id );
}
function verbindlichkeit_inlinepdf () {
$id = $this -> app -> Secure -> GetGET ( 'id' );
$file_attachments = $this -> app -> erp -> GetDateiSubjektObjekt ( '%' , 'verbindlichkeit' , $id );
if ( ! empty ( $file_attachments )) {
// print_r($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 ( \Xentral\Components\Pdf\Exception\PdfComponentExceptionInterface $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=verbindlichkeit_' . $id . '.pdf' );
echo ( $file_contents );
$this -> app -> ExitXentral ();
}
}
}
}
$this -> app -> ExitXentral ();
}
2023-12-11 22:17:28 +01:00
function verbindlichkeit_positionen () {
$this -> app -> YUI -> AARLGPositionen ( false ); // Render positionen editable into iframe
}
function verbindlichkeit_positioneneditpopup () {
$cmd = $this -> app -> Secure -> GetGET ( 'cmd' );
if ( $cmd === 'getopenaccordions' )
{
$accordions = $this -> app -> Secure -> GetPOST ( 'accordions' );
$accordions = explode ( '*|*' , $accordions );
foreach ( $accordions as $k => $v )
{
if ( empty ( $v ))
{
unset ( $accordions [ $k ]);
} else {
$accordions [ $k ] = 'verbindlichkeit_accordion' . $v ;
}
}
$ret = [];
if ( ! empty ( $accordions ))
{
$accordions = $this -> app -> User -> GetParameter ( $accordions );
if ( ! empty ( $accordions ))
{
foreach ( $accordions as $v )
{
if ( ! empty ( $v [ 'value' ]))
{
$ret [ 'accordions' ][] = str_replace ( 'verbindlichkeit_accordion' , '' , $v [ 'name' ]);
}
}
}
}
echo json_encode ( $ret );
$this -> app -> ExitXentral ();
}
if ( $cmd === 'setaccordion' )
{
$name = $this -> app -> Secure -> GetPOST ( 'name' );
$active = $this -> app -> Secure -> GetPOST ( 'active' );
$this -> app -> User -> SetParameter ( 'verbindlichkeit_accordion' . $name , $active );
echo json_encode ( array ( 'success' => 1 ));
$this -> app -> ExitXentral ();
}
$id = $this -> app -> Secure -> GetGET ( 'id' );
$fmodul = $this -> app -> Secure -> GetGET ( 'fmodul' );
$artikel = $this -> app -> DB -> Select ( " SELECT artikel FROM verbindlichkeit_position WHERE id=' $id ' LIMIT 1 " );
// nach page inhalt des dialogs ausgeben
$filename = 'widgets/widget.auftag_position_custom.php' ;
if ( is_file ( $filename ))
{
include_once $filename ;
$widget = new WidgetVerbindlichkeit_positionCustom ( $this -> app , 'PAGE' );
} else {
$widget = new WidgetVerbindlichkeit_position ( $this -> app , 'PAGE' );
}
$sid = $this -> app -> DB -> Select ( " SELECT verbindlichkeit FROM verbindlichkeit_position WHERE id=' $id ' LIMIT 1 " );
$widget -> form -> SpecialActionAfterExecute ( 'close_refresh' ,
" index.php?module=verbindlichkeit&action=positionen&id= $sid &fmodul= $fmodul " );
$widget -> Edit ();
$this -> app -> BuildNavigation = false ;
}
2023-12-13 18:27:08 +01:00
function verbindlichkeit_freigabe ()
{
$id = $this -> app -> Secure -> GetGET ( 'id' );
$this -> app -> erp -> BelegFreigabe ( 'verbindlichkeit' , $id );
2023-12-27 18:17:30 +01:00
$this -> app -> erp -> BelegProtokoll ( " verbindlichkeit " , $id , " Verbindlichkeit freigegeben " );
$this -> app -> DB -> Update ( " UPDATE verbindlichkeit SET schreibschutz = 1 WHERE id = " . $id );
2023-12-13 18:27:08 +01:00
$this -> verbindlichkeit_edit ();
}
2023-12-27 18:17:30 +01:00
function verbindlichkeit_freigabeeinkauf ( $id = null )
2023-12-25 21:30:58 +01:00
{
if ( empty ( $id )) {
$id = $this -> app -> Secure -> GetGET ( 'id' );
2023-12-27 18:17:30 +01:00
$gotoedit = true ;
2023-12-25 21:30:58 +01:00
}
$sql = " UPDATE verbindlichkeit SET freigabe = 1 WHERE id= " . $id ;
$this -> app -> DB -> Update ( $sql );
$this -> app -> erp -> BelegProtokoll ( " verbindlichkeit " , $id , " Verbindlichkeit freigegeben (Einkauf) " );
2023-12-27 18:17:30 +01:00
if ( $gotoedit ) {
$this -> verbindlichkeit_edit ();
}
2023-12-25 21:30:58 +01:00
}
2023-12-27 18:17:30 +01:00
function verbindlichkeit_freigabebuchhaltung ( $id = null )
2023-12-25 21:30:58 +01:00
{
if ( empty ( $id )) {
$id = $this -> app -> Secure -> GetGET ( 'id' );
2023-12-27 18:17:30 +01:00
$gotoedit = true ;
2023-12-25 21:30:58 +01:00
}
$sql = " UPDATE verbindlichkeit SET rechnungsfreigabe = 1 WHERE id= " . $id ;
$this -> app -> DB -> Update ( $sql );
$this -> app -> erp -> BelegProtokoll ( " verbindlichkeit " , $id , " Verbindlichkeit freigegeben (Buchhaltung) " );
2023-12-27 18:17:30 +01:00
if ( $gotoedit ) {
$this -> verbindlichkeit_edit ();
}
2023-12-25 21:30:58 +01:00
}
2023-12-27 18:17:30 +01:00
function verbindlichkeit_freigabebezahlt ( $id = null )
2023-12-25 21:30:58 +01:00
{
if ( empty ( $id )) {
$id = $this -> app -> Secure -> GetGET ( 'id' );
2023-12-27 18:17:30 +01:00
$gotoedit = true ;
2023-12-25 21:30:58 +01:00
}
$sql = " UPDATE verbindlichkeit SET bezahlt = 1 WHERE id= " . $id ;
$this -> app -> DB -> Update ( $sql );
$this -> app -> erp -> BelegProtokoll ( " verbindlichkeit " , $id , " Verbindlichkeit als bezahlt markiert " );
2023-12-27 18:17:30 +01:00
if ( $gotoedit ) {
$this -> verbindlichkeit_edit ();
}
}
function verbindlichkeit_ruecksetzeneinkauf ( $id = null )
{
if ( empty ( $id )) {
$id = $this -> app -> Secure -> GetGET ( 'id' );
$gotoedit = true ;
}
$sql = " UPDATE verbindlichkeit SET freigabe = 0 WHERE id= " . $id ;
$this -> app -> DB -> Update ( $sql );
$this -> app -> erp -> BelegProtokoll ( " verbindlichkeit " , $id , " Verbindlichkeit rückgesetzt (Einkauf) " );
if ( $gotoedit ) {
$this -> verbindlichkeit_edit ();
}
2023-12-25 21:30:58 +01:00
}
2023-12-13 18:27:08 +01:00
2023-12-27 18:17:30 +01:00
function verbindlichkeit_ruecksetzenbuchhaltung ( $id = null )
{
if ( empty ( $id )) {
$id = $this -> app -> Secure -> GetGET ( 'id' );
$gotoedit = true ;
}
$sql = " UPDATE verbindlichkeit SET rechnungsfreigabe = 0 WHERE id= " . $id ;
$this -> app -> DB -> Update ( $sql );
$this -> app -> erp -> BelegProtokoll ( " verbindlichkeit " , $id , " Verbindlichkeit rückgesetzt (Buchhaltung) " );
if ( $gotoedit ) {
$this -> verbindlichkeit_edit ();
}
}
function verbindlichkeit_ruecksetzenbezahlt ( $id = null )
{
if ( empty ( $id )) {
$id = $this -> app -> Secure -> GetGET ( 'id' );
$gotoedit = true ;
}
$sql = " UPDATE verbindlichkeit SET bezahlt = 0 WHERE id= " . $id ;
$this -> app -> DB -> Update ( $sql );
$this -> app -> erp -> BelegProtokoll ( " verbindlichkeit " , $id , " Verbindlichkeit bezahlt rückgesetzt " );
if ( $gotoedit ) {
$this -> verbindlichkeit_edit ();
}
}
function verbindlichkeit_schreibschutz ( $id = null )
{
if ( empty ( $id )) {
$id = $this -> app -> Secure -> GetGET ( 'id' );
$gotoedit = true ;
}
$sql = " UPDATE verbindlichkeit SET schreibschutz = 0 WHERE id= " . $id ;
$this -> app -> DB -> Update ( $sql );
$this -> app -> erp -> BelegProtokoll ( " verbindlichkeit " , $id , " Verbindlichkeit Schreibschutz entfernt " );
if ( $gotoedit ) {
$this -> verbindlichkeit_edit ();
}
}
public function verbindlichkeit_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'). " ,
v . betrag ,
v . umsatzsteuer ,
v . ustid ,
v . summenormal ,
v . summeermaessigt ,
v . summesatz3 ,
v . summesatz4 ,
v . steuersatzname3 ,
v . steuersatzname4 ,
v . skonto ,
" . $this->app ->erp->FormatDate('v.skontobis', 'skontobis'). " ,
v . skontofestsetzen ,
v . freigabe ,
v . freigabemitarbeiter ,
v . bestellung ,
p . abkuerzung AS projekt ,
v . teilprojekt ,
v . auftrag ,
v . status ,
v . bezahlt ,
v . kontoauszuege ,
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 . sachkonto ,
v . art ,
v . verwendungszweck ,
v . dta_datei ,
v . frachtkosten ,
v . internebemerkung ,
v . ustnormal ,
v . ustermaessigt ,
v . uststuer3 ,
v . uststuer4 ,
v . betragbezahlt ,
v . bezahltam ,
v . klaerfall ,
v . klaergrund ,
v . skonto_erhalten ,
v . kurs ,
v . sprache ,
v . id ,
CONCAT ( a . lieferantennummer , ' ' , a . name ) AS adresse
FROM verbindlichkeit 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 ])) {
$verbindlichkeit_from_db = $result [ 0 ];
}
$tmp = new EasyTable ( $this -> app );
$tmp -> Query ( " SELECT zeit,bearbeiter,grund FROM verbindlichkeit_protokoll WHERE verbindlichkeit=' $id ' ORDER by zeit DESC " , 0 , " " );
$tmp -> DisplayNew ( 'PROTOKOLL' , " Protokoll " , " noAction " );
if ( $parsetarget == '' )
{
$this -> app -> Tpl -> Output ( 'verbindlichkeit_minidetail.tpl' );
$this -> app -> ExitXentral ();
}
$this -> app -> Tpl -> Parse ( $parsetarget , 'verbindlichkeit_minidetail.tpl' );
}
2023-11-30 19:39:11 +01:00
}