xmlrechnung exportbuchhaltung

This commit is contained in:
OpenXE 2025-01-15 13:58:00 +01:00
parent 65f6d9e8c1
commit 23953e70b8

View File

@ -164,15 +164,14 @@ class Exportbuchhaltung
$vbchecked = $this->app->Secure->GetPOST("verbindlichkeit"); $vbchecked = $this->app->Secure->GetPOST("verbindlichkeit");
$lgchecked = $this->app->Secure->GetPOST("lieferantengutschrift"); $lgchecked = $this->app->Secure->GetPOST("lieferantengutschrift");
$diffignore = $this->app->Secure->GetPOST("diffignore"); $diffignore = $this->app->Secure->GetPOST("diffignore");
$sachkonto = $this->app->Secure->GetPOST('sachkonto'); $sachkonto = $this->app->Secure->GetPOST('sachkonto');
$format = $this->app->Secure->GetPOST('format'); $format = $this->app->Secure->GetPOST('format');
$pdfexport = $this->app->Secure->GetPOST("pdfexport"); $pdfexport = $this->app->Secure->GetPOST("pdfexport");
$account_id = null;
$account_id = null; if (!empty($sachkonto)) {
if (!empty($sachkonto)) { $sachkonto_kennung = explode(' ',$sachkonto)[0];
$sachkonto_kennung = explode(' ',$sachkonto)[0]; $account_id = $this->app->DB->SelectArr("SELECT id from kontorahmen WHERE sachkonto = '".$sachkonto_kennung."'")[0]['id'];
$account_id = $this->app->DB->SelectArr("SELECT id from kontorahmen WHERE sachkonto = '".$sachkonto_kennung."'")[0]['id']; }
}
$msg = ""; $msg = "";
@ -219,7 +218,6 @@ class Exportbuchhaltung
//---------- DOWNLOAD HERE //---------- DOWNLOAD HERE
if ($submit == 'Download') { if ($submit == 'Download') {
$dataok = true; $dataok = true;
if ( if (
!$rgchecked && !$rgchecked &&
!$gschecked && !$gschecked &&
@ -250,6 +248,7 @@ class Exportbuchhaltung
$filename_csv = "EXTF_".date('Ymd') . "_Buchungsstapel_DATEV_export.csv"; $filename_csv = "EXTF_".date('Ymd') . "_Buchungsstapel_DATEV_export.csv";
try { try {
$csv = $this->DATEV_Buchuchungsstapel($rgchecked, $gschecked, $vbchecked, $lgchecked, $buchhaltung_berater, $buchhaltung_mandant, $buchhaltung_wj_beginn, $buchhaltung_sachkontenlaenge, $von, $bis, $projekt, $filename_csv, $diffignore, $sachkonto_kennung, $format); $csv = $this->DATEV_Buchuchungsstapel($rgchecked, $gschecked, $vbchecked, $lgchecked, $buchhaltung_berater, $buchhaltung_mandant, $buchhaltung_wj_beginn, $buchhaltung_sachkontenlaenge, $von, $bis, $projekt, $filename_csv, $diffignore, $sachkonto_kennung, $format);
if ($pdfexport) { if ($pdfexport) {
$dateinamezip = 'Export_Buchhaltung_'.date('Y-m-d').'.zip'; $dateinamezip = 'Export_Buchhaltung_'.date('Y-m-d').'.zip';
@ -267,13 +266,20 @@ class Exportbuchhaltung
WHERE WHERE
b.".$typ['field_date']." BETWEEN '".date_format($von,"Y-m-d")."' AND '".date_format($bis,"Y-m-d")."' AND (b.projekt=$projekt OR $projekt=0)".$typ['condition_where']; b.".$typ['field_date']." BETWEEN '".date_format($von,"Y-m-d")."' AND '".date_format($bis,"Y-m-d")."' AND (b.projekt=$projekt OR $projekt=0)".$typ['condition_where'];
$belege = $this->app->DB->SelectArr($sql); $belege = $this->app->DB->SelectArr($sql);
foreach ($belege as $beleg) { foreach ($belege as $beleg) {
if (!$typ['do']) { if (!$typ['do']) {
continue; continue;
} }
switch ($typ['pdf']) { $action = $typ['pdf'];
if ($typ['typ'] == 'rechnung') {
if ($this->app->DB->Select("SELECT xmlrechnung FROM rechnung WHERE id = ".$beleg['id'])) {
$action = 'load';
}
}
switch ($action) {
case 'print': case 'print':
switch ($typ['typ']) { switch ($typ['typ']) {
case 'rechnung': case 'rechnung':
@ -301,15 +307,16 @@ class Exportbuchhaltung
$tmpfile = $Brief->displayTMP(); $tmpfile = $Brief->displayTMP();
$file_name = $beleg['belegnr'].".pdf"; $file_name = $beleg['belegnr'].".pdf";
$zip->addFromString($typ['typ']."/".$file_name, file_get_contents($tmpfile)); $zip->addFromString($typ['typ']."/".$file_name, file_get_contents($tmpfile));
break; break;
case 'load': case 'load':
$file_attachments = $this->app->erp->GetDateiSubjektObjekt('%',$typ['typ'],$beleg['id']); $file_attachments = $this->app->erp->GetDateiSubjektObjekt('%',$typ['typ'],$beleg['id']);
$suffix = ""; $suffix = "";
$count = 0; $count = 0;
foreach ($file_attachments as $file_attachment) { foreach ($file_attachments as $file_attachment) {
if ($this->app->erp->GetDateiEndung($file_attachment) == 'pdf') { $ending = $this->app->erp->GetDateiEndung($file_attachment);
if (in_array($ending,['pdf','xml'])) {
$file_contents = $this->app->erp->GetDatei($file_attachment); $file_contents = $this->app->erp->GetDatei($file_attachment);
$file_name = filter_var($beleg['belegnr'],FILTER_SANITIZE_EMAIL).$suffix.".pdf"; $file_name = filter_var($beleg['belegnr'],FILTER_SANITIZE_EMAIL).$suffix.".".$ending;
$zip->addFromString($typ['typ']."/".$file_name, $file_contents); $zip->addFromString($typ['typ']."/".$file_name, $file_contents);
$count++; $count++;
$suffix = "_".$count; $suffix = "_".$count;
@ -320,7 +327,6 @@ class Exportbuchhaltung
} }
} }
$zip->close(); $zip->close();
// download // download
header('Content-Type: application/zip'); header('Content-Type: application/zip');
header("Content-Disposition: attachment; filename=$dateinamezip"); header("Content-Disposition: attachment; filename=$dateinamezip");
@ -717,9 +723,6 @@ class Exportbuchhaltung
// Query position data // Query position data
$arr = $this->app->DB->Query($sql); $arr = $this->app->DB->Query($sql);
while ($row = $this->app->DB->Fetch_Assoc($arr)) { while ($row = $this->app->DB->Fetch_Assoc($arr)) {
//print_r($row);
$posid = $row['pos_id']; $posid = $row['pos_id'];
$tmpsteuersatz = 0; $tmpsteuersatz = 0;
$tmpsteuertext = ''; $tmpsteuertext = '';