mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-23 03:21:12 +01:00
145 lines
5.3 KiB
PHP
145 lines
5.3 KiB
PHP
|
<?php
|
||
|
/*
|
||
|
**** COPYRIGHT & LICENSE NOTICE *** DO NOT REMOVE ****
|
||
|
*
|
||
|
* Xentral (c) Xentral ERP Sorftware GmbH, Fuggerstrasse 11, D-86150 Augsburg, * Germany 2019
|
||
|
*
|
||
|
* This file is licensed under the Embedded Projects General Public License *Version 3.1.
|
||
|
*
|
||
|
* You should have received a copy of this license from your vendor and/or *along with this file; If not, please visit www.wawision.de/Lizenzhinweis
|
||
|
* to obtain the text of the corresponding license version.
|
||
|
*
|
||
|
**** END OF COPYRIGHT & LICENSE NOTICE *** DO NOT REMOVE ****
|
||
|
*/
|
||
|
?>
|
||
|
<?php
|
||
|
class ArbeitsnachweisPDF extends Briefpapier {
|
||
|
public $doctype;
|
||
|
|
||
|
function __construct($app,$projekt="")
|
||
|
{
|
||
|
$this->app=$app;
|
||
|
//parent::Briefpapier();
|
||
|
$this->doctype="arbeitsnachweis";
|
||
|
$this->doctypeOrig="Arbeitsnachweis";
|
||
|
parent::__construct($this->app,$projekt);
|
||
|
}
|
||
|
|
||
|
|
||
|
function GetArbeitsnachweis($id,$info="",$extrafreitext="",$formular=false)
|
||
|
{
|
||
|
// das muss vom arbeitsnachweis sein!!!!
|
||
|
$this->setRecipientLieferadresse($id,"arbeitsnachweis");
|
||
|
|
||
|
$data = $this->app->DB->SelectArr("SELECT adresse,kundennummer,auftragid,bearbeiter,prefix, DATE_FORMAT(datum,'%d.%m.%Y') AS datum, belegnr,freitext, projekt, ohne_briefpapier FROM arbeitsnachweis WHERE id='$id' LIMIT 1");
|
||
|
$data = reset($data);
|
||
|
extract($data,EXTR_OVERWRITE);
|
||
|
$anzeige_verrechnungsart = ''; // Muss bei Bedarf aus den Positionen geholt werden
|
||
|
$auftrag = $this->app->DB->Select("SELECT belegnr FROM auftrag WHERE id='$auftragid' LIMIT 1");
|
||
|
$this->projekt = $projekt;
|
||
|
|
||
|
|
||
|
if($ohne_briefpapier=="1")
|
||
|
{
|
||
|
$this->logofile = "";
|
||
|
$this->briefpapier="";
|
||
|
$this->briefpapier2="";
|
||
|
}
|
||
|
|
||
|
$this->doctype="arbeitsnachweis";
|
||
|
if($belegnr<=0) $belegnr = "- Entwurf";
|
||
|
|
||
|
|
||
|
if($info=="")
|
||
|
$this->doctypeOrig="Arbeitsnachweis $belegnr";
|
||
|
else
|
||
|
$this->doctypeOrig="Arbeitsnachweis$info $belegnr";
|
||
|
|
||
|
if($arbeitsnachweis=="") $arbeitsnachweis = "-";
|
||
|
if($kundennummer=="") $kundennummer= "-";
|
||
|
|
||
|
//$this->setCorrDetails(array("Auftrag"=>$auftrag,"Ihre Kunden-Nr."=>$kundennummer,"Versand"=>$datum,"Versand"=>$bearbeiter));
|
||
|
$this->setCorrDetails(array("Auftrag"=>$auftrag,"Ihre Kunden-Nr."=>$kundennummer,"Datum"=>$datum,"Prefix"=>$prefix,"Bearbeiter"=>$bearbeiter));
|
||
|
|
||
|
$this->zusatzfooter = "Suffix: ".$prefix;
|
||
|
|
||
|
$footer_extra = $this->app->erp->ParseUserVars("arbeitsnachweis",$id,$this->app->erp->Firmendaten("arbeitsnachweis_footer"));
|
||
|
$footer_extra = str_replace("{SUFFIX}",$prefix,$footer_extra);
|
||
|
$footer_extra = str_replace("{DATUM}",$datum,$footer_extra);
|
||
|
|
||
|
|
||
|
$body=$this->app->erp->Firmendaten("arbeitsnachweis_header");
|
||
|
$body = $this->app->erp->ParseUserVars("arbeitsnachweis",$id,$body);
|
||
|
|
||
|
$this->setTextDetails(array(
|
||
|
"body"=>$body,
|
||
|
"footer"=>"$freitext\r\n$extrafreitext\r\n".$footer_extra));
|
||
|
|
||
|
$artikel = $this->app->DB->SelectArr("SELECT * FROM arbeitsnachweis_position WHERE arbeitsnachweis='$id' ORDER By sort");
|
||
|
|
||
|
//$waehrung = $this->app->DB->Select("SELECT waehrung FROM arbeitsnachweis_position WHERE arbeitsnachweis='$id' LIMIT 1");
|
||
|
if($formular)
|
||
|
{
|
||
|
for($reihen=0;$reihen<6;$reihen++)
|
||
|
{
|
||
|
$this->addItem(array('amount'=>"",'itemno'=>"",'desc'=>"________________________________________________________",
|
||
|
"name"=>'',"person"=>''));
|
||
|
}
|
||
|
} else {
|
||
|
foreach($artikel as $key=>$value)
|
||
|
{
|
||
|
|
||
|
if($value[seriennummer]!="")
|
||
|
{
|
||
|
if( $value[beschreibung]!="") $value[beschreibung] = $value[beschreibung]."\n";
|
||
|
$value[beschreibung] = "Seriennummer: ".$value[seriennummer]."\n\n";
|
||
|
}
|
||
|
|
||
|
$value[menge] = $this->app->erp->get_time_difference($value[von].":00",$value[bis].":00");
|
||
|
|
||
|
$adr_name = $this->app->DB->Select("SELECT name FROM adresse WHERE id='{$value[adresse]}' LIMIT 1");
|
||
|
|
||
|
$add_sum = explode(":", $value[menge]);
|
||
|
$hour = $hour + $add_sum[0];
|
||
|
$minutes = $minutes + $add_sum[1];
|
||
|
|
||
|
// anpassung zeit
|
||
|
$value[menge] = $this->app->erp->ZeitinMenge($value[menge]);
|
||
|
|
||
|
$verrechnungsart = $this->app->DB->Select("SELECT verrechnungsart FROM zeiterfassung
|
||
|
WHERE arbeitsnachweispositionid='{$value[id]}' LIMIT 1");
|
||
|
if($verrechnungsart!="" && $anzeige_verrechnungsart==1)
|
||
|
{
|
||
|
$verrechnungsart = $this->app->DB->Select("SELECT beschreibung FROM verrechnungsart WHERE nummer='$verrechnungsart' LIMIT 1");
|
||
|
$value[beschreibung] .= "\r\nVerrechnungsart: ".$verrechnungsart;
|
||
|
}
|
||
|
|
||
|
$value[beschreibung] .="\r\nDatum: ".date('d.m.Y',strtotime($value[datum]))." Uhrzeit: ".$value['von']." bis ".$value[bis];
|
||
|
|
||
|
|
||
|
$this->addItem(array('amount'=>$value[menge],'itemno'=>$value[ort],'desc'=>$value[bemerkung],'desc'=>ltrim($value[beschreibung]),'artikel'=>$value[artikel],
|
||
|
"name"=>$value[bezeichnung],"person"=>$adr_name));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$final_hours = floor($minutes / 60) + $hour;
|
||
|
$final_minutes = str_pad($minutes % 60,2,'0',STR_PAD_LEFT);
|
||
|
$summe = $final_hours.":".$final_minutes;
|
||
|
|
||
|
// anpassung zeit
|
||
|
$summe = $this->app->erp->ZeitinMenge($summe);
|
||
|
|
||
|
if(!$formular)
|
||
|
$this->setTotals(array("total"=>$summe));
|
||
|
|
||
|
/* Dateiname */
|
||
|
$tmp_name = str_replace(' ','',trim($this->recipient['enterprise']));
|
||
|
$tmp_name = str_replace('.','',$tmp_name);
|
||
|
|
||
|
$this->filename = $datum."_ABN".$belegnr.".pdf";
|
||
|
$this->setBarcode($belegnr);
|
||
|
}
|
||
|
|
||
|
|
||
|
}
|