mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2024-12-25 06:00:28 +01:00
1806 lines
85 KiB
PHP
1806 lines
85 KiB
PHP
<?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."'");
|
|
|
|
$heading = array('' ,'Verbindlichkeit', 'Artikel-Nr.','Artikel','Menge','Preis','Steuersatz','Sachkonto');
|
|
$width = array( '1%','1%', '20%', '20%', '1%', '1%', '3%', '1%', '1%');
|
|
|
|
$findcols = array('lgp.id','v.belegnr','art.nummer','art.name_de','lgp.menge','lgp.preis','lgp.steuersatz',"CONCAT(skv.sachkonto,' ',skv.beschriftung)",'lgp.id');
|
|
$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[] = '';
|
|
|
|
$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 = "";
|
|
|
|
break;
|
|
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' => 'vp.id'],
|
|
'"/>'
|
|
);
|
|
|
|
$werte = array (
|
|
'<input type="number" name="werte[]" min="0"',
|
|
'max = "',
|
|
['sql' => 'if(vp.menge > COALESCE(lgp.menge,0),vp.menge-COALESCE(lgp.menge,0),0)'],
|
|
'" ',
|
|
'value = "',
|
|
['sql' => 'if(vp.menge > COALESCE(lgp.menge,0),vp.menge-COALESCE(lgp.menge,0),0)'],
|
|
'" ',
|
|
'/>'
|
|
);
|
|
|
|
$preise = array (
|
|
'<input type="number" name="preise[]" step="0.00001" value="',
|
|
['sql' => $this->app->erp->FormatMenge("COALESCE(bp.preis,0)",5)],
|
|
'" min="0"',
|
|
'/>'
|
|
);
|
|
|
|
$artikellink = array (
|
|
'<a href="index.php?module=artikel&action=edit&id=',
|
|
['sql' => 'art.id'],
|
|
'">',
|
|
['sql' => 'art.nummer'],
|
|
'</a>'
|
|
);
|
|
|
|
$box = "CONCAT('<input type=\"checkbox\" name=\"auswahl[]\" value=\"',vp.id,'\" />') AS `auswahl`";
|
|
|
|
$sql = "
|
|
SELECT SQL_CALC_FOUND_ROWS
|
|
vp.id,
|
|
".$this->app->erp->ConcatSQL($auswahl).",
|
|
v.belegnr,
|
|
".$this->app->erp->ConcatSQL($artikellink).",
|
|
art.name_de,
|
|
".$this->app->erp->ConcatSQL($werte).",
|
|
vp.preis,
|
|
vp.steuersatz,
|
|
CONCAT(skv.sachkonto,' ',skv.beschriftung),
|
|
vp.id
|
|
FROM
|
|
verbindlichkeit_position vp
|
|
INNER JOIN verbindlichkeit v ON
|
|
v.id = vp.verbindlichkeit
|
|
INNER JOIN paketdistribution pd ON
|
|
pd.id = vp.paketdistribution
|
|
INNER JOIN artikel art ON
|
|
art.id = pd.artikel
|
|
INNER JOIN adresse adr ON
|
|
adr.id = v.adresse
|
|
LEFT JOIN kontorahmen skv ON skv.id = vp.kontorahmen
|
|
LEFT JOIN (
|
|
SELECT
|
|
verbindlichkeit_position,
|
|
SUM(menge) AS menge
|
|
FROM
|
|
lieferantengutschrift_position lgp
|
|
INNER JOIN
|
|
lieferantengutschrift lg ON lg.id = lgp.lieferantengutschrift
|
|
WHERE
|
|
lg.status <> 'storniert' AND verbindlichkeit_position <> 0 and verbindlichkeit_position IS NOT NULL
|
|
) lgp ON lgp.verbindlichkeit_position = vp.id
|
|
";
|
|
|
|
$where = "v.adresse = (SELECT adresse FROM lieferantengutschrift WHERE id = ".$id.") AND v.status IN ('freigegeben','abgeschlossen')";
|
|
|
|
$count = "";
|
|
|
|
break;
|
|
case 'artikel_manuell':
|
|
$allowed['paketdistribution_list'] = array('list');
|
|
|
|
$heading = array('Art.-Nummer', 'Beschreibung', 'Menge', 'Preis','Steuer','Sachkonto','');
|
|
$width = array( '5%', '30%', '5%', '5%', '1%', '1%', '1%');
|
|
|
|
$findcols = array('nummer','name_de','','','umsatzsteuer',"CONCAT(skart.sachkonto,' ',skart.beschriftung)",'id');
|
|
$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>'
|
|
);
|
|
|
|
$preise = array (
|
|
'<input type="number" name="preise[]" step="0.00001" value="',
|
|
'" min="0"',
|
|
' style=\"text-align:right; width:100%\">'
|
|
);
|
|
|
|
$sql = "
|
|
SELECT SQL_CALC_FOUND_ROWS
|
|
a.id,
|
|
".$this->app->erp->ConcatSQL($auswahl).",
|
|
name_de,
|
|
".$this->app->erp->ConcatSQL($input_for_menge).",
|
|
".$this->app->erp->ConcatSQL($preise)."
|
|
'',
|
|
a.umsatzsteuer,
|
|
CONCAT(skart.sachkonto,' ',skart.beschriftung)
|
|
FROM
|
|
artikel a
|
|
LEFT JOIN
|
|
kontorahmen skart ON skart.id = a.kontorahmen";
|
|
|
|
|
|
$where = " (geloescht <> 1)";
|
|
|
|
$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;
|
|
case 'drucken':
|
|
$drucker = $this->app->Secure->GetPOST('seldrucker');
|
|
foreach ($selectedIds as $id) {
|
|
$file_attachments = $this->app->erp->GetDateiSubjektObjekt('%','lieferantengutschrift',$id);
|
|
if (!empty($file_attachments)) {
|
|
foreach ($file_attachments as $file_attachment) {
|
|
if ($this->app->erp->GetDateiEndung($file_attachment) == 'pdf') {
|
|
$file_contents = $this->app->erp->GetDatei($file_attachment);
|
|
$lieferantengutschrift = $this->app->DB->SelectRow("SELECT DATE_FORMAT(rechnungsdatum, '%Y%m%d') rechnungsdatum, belegnr FROM lieferantengutschrift WHERE id = ".$id." LIMIT 1");
|
|
$file_name = $lieferantengutschrift['rechnungsdatum']."_LG".$lieferantengutschrift['belegnr'].".pdf";
|
|
$file_path = rtrim($this->app->erp->GetTMP(),'/')."/".$file_name;
|
|
$handle = fopen ($file_path, "wb");
|
|
if ($handle)
|
|
{
|
|
fwrite($handle, $file_contents);
|
|
fclose($handle);
|
|
$this->app->printer->Drucken($drucker,$file_path);
|
|
} else {
|
|
$this->app->YUI->Message('error',"Drucken fehlgeschlagen!");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
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->Set('SELDRUCKER', $this->app->erp->GetSelectDrucker());
|
|
|
|
$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
|
|
|
|
$freigabe = $this->app->DB->SelectArr("SELECT rechnungsfreigabe, freigabe, adresse, belegnr FROM lieferantengutschrift WHERE id =".$id)[0];
|
|
|
|
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 {
|
|
|
|
if ($freigabe['belegnr']) {
|
|
unset($input['adresse']);
|
|
} else {
|
|
$input['adresse'] = $this->app->erp->ReplaceLieferantennummer(true,$input['adresse'],true); // Parameters: Target db?, value, from form?
|
|
}
|
|
|
|
$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');
|
|
|
|
foreach ($ids as $key => $verbindlichkeit_position) {
|
|
$menge = $werte[$key];
|
|
|
|
if ($menge <= 0) {
|
|
continue;
|
|
}
|
|
|
|
// Check available number
|
|
$sql = "
|
|
SELECT
|
|
IF(
|
|
vp.menge > COALESCE(lgp.menge,0),
|
|
vp.menge - COALESCE(lgp.menge,0),
|
|
0
|
|
) offen_menge
|
|
FROM
|
|
verbindlichkeit_position vp
|
|
LEFT JOIN(
|
|
SELECT
|
|
verbindlichkeit_position,
|
|
SUM(menge) AS menge
|
|
FROM
|
|
lieferantengutschrift_position lgp
|
|
GROUP BY
|
|
verbindlichkeit_position
|
|
) lgp
|
|
ON
|
|
vp.id = lgp.verbindlichkeit_position
|
|
WHERE vp.id = ".$verbindlichkeit_position."
|
|
";
|
|
$offen_menge = $this->app->DB->Select($sql);
|
|
|
|
if ($offen_menge === 0) {
|
|
continue;
|
|
}
|
|
|
|
if ($menge > $offen_menge && !empty($offen_menge)) {
|
|
$menge = $offen_menge;
|
|
}
|
|
|
|
if ($menge == 0) {
|
|
continue;
|
|
}
|
|
|
|
$sql = "SELECT
|
|
a.id,
|
|
a.umsatzsteuer,
|
|
a.steuersatz,
|
|
COALESCE(if (skart.id <> 0,skart.id,skadr.id),0) AS kontorahmen,
|
|
vp.preis
|
|
FROM
|
|
verbindlichkeit_position vp
|
|
INNER JOIN
|
|
verbindlichkeit v ON v.id = vp.verbindlichkeit
|
|
INNER JOIN
|
|
artikel a ON a.id = vp.artikel
|
|
INNER JOIN
|
|
adresse adr ON v.adresse = adr.id
|
|
LEFT JOIN
|
|
kontorahmen skart ON skart.id = a.kontorahmen
|
|
LEFT JOIN
|
|
kontorahmen skadr ON skadr.id = adr.kontorahmen
|
|
WHERE vp.id =".$verbindlichkeit_position;
|
|
|
|
$artikel = $this->app->DB->SelectRow($sql);
|
|
|
|
$einartikel = $artikel['id'];
|
|
$umsatzsteuer = $artikel['umsatzsteuer'];
|
|
$kontorahmen = $artikel['kontorahmen'];
|
|
$preis = $artikel['preis'];
|
|
|
|
if(empty($umsatzsteuer) && is_numeric($artikel['steuersatz'])) {
|
|
$steuersatz = $artikel['steuersatz'];
|
|
} else {
|
|
$steuersatz = $this->get_steuersatz($umsatzsteuer,$id);
|
|
}
|
|
|
|
$sql = "INSERT INTO lieferantengutschrift_position (lieferantengutschrift,verbindlichkeit_position, menge, preis, steuersatz, artikel, kontorahmen) VALUES ($id, $verbindlichkeit_position, $menge, $preis, $steuersatz, $einartikel, $kontorahmen)";
|
|
$this->app->DB->Insert($sql);
|
|
}
|
|
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;
|
|
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,
|
|
a.lieferantennummer,
|
|
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ä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
|
|
|
|
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']);
|
|
}
|
|
|
|
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']);
|
|
|
|
$this->app->Tpl->Set('VERBINDLICHKEIT',$this->app->erp->ReplaceVerbindlichkeit(false,$lieferantengutschrift_from_db['verbindlichkeit'],false));
|
|
|
|
$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.');
|
|
}
|
|
|
|
// -- POSITIONEN
|
|
if (empty($lieferantengutschrift_from_db['freigabe'])) {
|
|
$this->app->YUI->TableSearch('PAKETDISTRIBUTION', 'verbindlichkeit_positionen', "show", "", "", basename(__FILE__), __CLASS__);
|
|
}
|
|
$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
|
|
|
|
// -- 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
|
|
|
|
$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 freigegeben');
|
|
$error = true;
|
|
} else {
|
|
return('lieferantengutschrift nicht freigegeben '.$this->lieferantengutschrift_get_belegnr($id));
|
|
}
|
|
}
|
|
|
|
$sql = "UPDATE lieferantengutschrift SET freigabe = 1 WHERE id=".$id;
|
|
$this->app->DB->Update($sql);
|
|
|
|
if (!$text) {
|
|
$text = "lieferantengutschrift freigegeben (Einkauf)";
|
|
}
|
|
$this->app->erp->BelegProtokoll("lieferantengutschrift",$id,$text);
|
|
|
|
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 freigegeben');
|
|
$error = true;
|
|
} else {
|
|
return('lieferantengutschrift nicht freigegeben '.$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 freigegeben');
|
|
$error = true;
|
|
} else {
|
|
return('lieferantengutschrift nicht freigegeben '.$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','abgeschlossen')
|
|
";
|
|
|
|
$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);
|
|
}
|
|
}
|