mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-24 19:51:14 +01:00
1995 lines
82 KiB
PHP
1995 lines
82 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
|
|
use Xentral\Components\Pdf\Exception\PdfComponentExceptionInterface;
|
|
use Xentral\Components\Pdf\PdfMerger;
|
|
|
|
include __DIR__.'/_gen/gutschrift.php';
|
|
|
|
class Gutschrift extends GenGutschrift
|
|
{
|
|
/**
|
|
* Gutschrift constructor.
|
|
*
|
|
* @param Application $app
|
|
* @param bool $intern
|
|
*/
|
|
public function __construct($app, $intern = false)
|
|
{
|
|
$this->app=$app;
|
|
if($intern) {
|
|
return;
|
|
}
|
|
$this->app->ActionHandlerInit($this);
|
|
|
|
$this->app->ActionHandler("list","GutschriftList");
|
|
$this->app->ActionHandler("create","GutschriftCreate");
|
|
$this->app->ActionHandler("positionen","GutschriftPositionen");
|
|
$this->app->ActionHandler("upgutschriftposition","UpGutschriftPosition");
|
|
$this->app->ActionHandler("delgutschriftposition","DelGutschriftPosition");
|
|
$this->app->ActionHandler("copygutschriftposition","CopyGutschriftPosition");
|
|
$this->app->ActionHandler("downgutschriftposition","DownGutschriftPosition");
|
|
$this->app->ActionHandler("positioneneditpopup","GutschriftPositionenEditPopup");
|
|
$this->app->ActionHandler("edit","GutschriftEdit");
|
|
$this->app->ActionHandler("copy","GutschriftCopy");
|
|
$this->app->ActionHandler("delete","GutschriftDelete");
|
|
$this->app->ActionHandler("storno","GutschriftStorno");
|
|
$this->app->ActionHandler("freigabe","GutschriftFreigabe");
|
|
$this->app->ActionHandler("abschicken","GutschriftAbschicken");
|
|
$this->app->ActionHandler("pdf","GutschriftPDF");
|
|
$this->app->ActionHandler("inlinepdf","GutschriftInlinePDF");
|
|
$this->app->ActionHandler("protokoll","GutschriftProtokoll");
|
|
$this->app->ActionHandler("zahlungseingang","GutschriftZahlungseingang");
|
|
$this->app->ActionHandler("minidetail","GutschriftMiniDetail");
|
|
$this->app->ActionHandler("editable","GutschriftEditable");
|
|
$this->app->ActionHandler("livetabelle","GutschriftLiveTabelle");
|
|
$this->app->ActionHandler("schreibschutz","GutschriftSchreibschutz");
|
|
$this->app->ActionHandler("zahlungsmahnungswesen","GutschriftZahlungMahnungswesen");
|
|
$this->app->ActionHandler("deleterabatte","GutschriftDeleteRabatte");
|
|
$this->app->ActionHandler("dateien","GutschriftDateien");
|
|
$this->app->ActionHandler("pdffromarchive","GutschriftPDFFromArchiv");
|
|
$this->app->ActionHandler("archivierepdf","GutschriftArchivierePDF");
|
|
$this->app->ActionHandler("summe","GutschriftSumme"); // nur fuer rechte
|
|
$this->app->ActionHandler("einkaufspreise","GutschriftEinkaufspreise");
|
|
$this->app->ActionHandler("steuer","GutschriftSteuer");
|
|
$this->app->ActionHandler("formeln","GutschriftFormeln");
|
|
$this->app->ActionHandler("createpayment","GutschriftCreatePayment");
|
|
|
|
$this->app->DefaultActionHandler("list");
|
|
|
|
|
|
$id = (int)$this->app->Secure->GetGET('id');
|
|
$returnOrderRow = $id <= 0 ? null : $this->app->DB->SelectRow(
|
|
"SELECT ro.stornorechnung, ro.belegnr, adr.name
|
|
FROM `gutschrift` AS `ro`
|
|
LEFT JOIN `adresse` AS `adr` ON ro.adresse = adr.id
|
|
WHERE ro.id = {$id}"
|
|
);
|
|
$stornorechnung = !empty($returnOrderRow['stornorechnung']);
|
|
if($stornorechnung){
|
|
$this->app->Tpl->Set('BEZEICHNUNGTITEL', $this->app->erp->Firmendaten('bezeichnungstornorechnung'));
|
|
}
|
|
else{
|
|
$this->app->Tpl->Set('BEZEICHNUNGTITEL', 'Gutschrift');
|
|
}
|
|
$nummer = $this->app->Secure->GetPOST('adresse');
|
|
|
|
if($nummer==''){
|
|
$adresse = empty($returnOrderRow)?'':$returnOrderRow['name'];
|
|
}
|
|
else{
|
|
$adresse = $nummer;
|
|
}
|
|
|
|
$nummer = empty($returnOrderRow)?'':$returnOrderRow['belegnr'];
|
|
if($nummer=='' || $nummer==0) {
|
|
$nummer='ohne Nummer';
|
|
}
|
|
|
|
$this->app->Tpl->Set('UEBERSCHRIFT','Auftrag: '.$adresse.' ('.$nummer.')');
|
|
|
|
$this->app->erp->Headlines('Gutschrift');
|
|
|
|
$this->app->ActionHandlerListen($app);
|
|
}
|
|
|
|
public function Install()
|
|
{
|
|
$this->app->erp->RegisterHook('supersearch_detail', 'gutschrift', 'GutschriftSupersearchDetail');
|
|
}
|
|
|
|
/**
|
|
* @param \Xentral\Widgets\SuperSearch\Query\DetailQuery $detailQuery
|
|
* @param \Xentral\Widgets\SuperSearch\Result\ResultDetail $detailResult
|
|
*
|
|
* @return void
|
|
*/
|
|
public function GutschriftSupersearchDetail($detailQuery, $detailResult)
|
|
{
|
|
if ($detailQuery->getGroupKey() !== 'creditnotes') {
|
|
return;
|
|
}
|
|
|
|
$guschriftId = $detailQuery->getItemIdentifier();
|
|
$sql = sprintf(
|
|
"SELECT gs.id, gs.belegnr, gs.datum, gs.soll FROM `gutschrift` AS `gs` WHERE gs.id = '%s' LIMIT 1",
|
|
$this->app->DB->real_escape_string($guschriftId)
|
|
);
|
|
$gutschrift = $this->app->DB->SelectRow($sql);
|
|
if (empty($gutschrift)) {
|
|
return;
|
|
}
|
|
$datum = date('d.m.Y', strtotime($gutschrift['datum']));
|
|
$detailResult->setTitle(sprintf('Gutschrift %s', $gutschrift['belegnr']));
|
|
$detailResult->addButton('Gutschrift Details', sprintf('index.php?module=gutschrift&action=edit&id=%s', $gutschrift['id']));
|
|
$detailResult->setMiniDetailUrl(sprintf('index.php?module=gutschrift&action=minidetail&id=%s', $gutschrift['id']));
|
|
}
|
|
|
|
public function GutschriftFormeln()
|
|
{
|
|
|
|
}
|
|
|
|
public function GutschriftCreatePayment()
|
|
{
|
|
$id = (int)$this->app->Secure->GetGET('id');
|
|
$ids = [$id];
|
|
$this->app->DB->Insert(
|
|
sprintf(
|
|
"INSERT INTO `payment_transaction`
|
|
(`returnorder_id`, `payment_status`, `address_id`, `amount`, `currency`, `payment_json`, `payment_info`)
|
|
SELECT ro.id,'angelegt', ro.adresse, ro.soll, IF(ro.waehrung <> '', ro.waehrung, 'EUR'),
|
|
JSON_OBJECT('bic', ad.swift, 'iban', ad.iban, 'empfaenger', ad.inhaber, 'betrag', ro.soll, 'waehrung',
|
|
IF(ro.waehrung <> '', ro.waehrung, 'EUR'), 'datum', ro.datum, 'vz1', '', 'vz2', ''),
|
|
CONCAT(IF(ad.swift != '', IF(ad.iban != '', CONCAT('BIC: ', ad.swift, '<br />'),
|
|
CONCAT('BIC: ', ad.swift)), ''), IF(ad.iban != '', CONCAT('IBAN: ', ad.iban), ''))
|
|
FROM `gutschrift` AS `ro`
|
|
LEFT JOIN `payment_transaction` AS `pt` ON ro.id = pt.returnorder_id
|
|
LEFT JOIN `adresse` AS `ad` ON ro.adresse = ad.id
|
|
WHERE pt.id IS NULL AND ro.id IN (%s)
|
|
AND ro.status <> '' AND ro.status <> 'angelegt' AND ro.status <> 'storniert'",
|
|
implode(',', $ids)
|
|
)
|
|
);
|
|
if($this->app->DB->affected_rows() > 0) {
|
|
$this->app->Location->execute('index.php?module=zahlungsverkehr&action=ueberweisung');
|
|
}
|
|
$this->app->Location->execute('index.php?module=gutschrift&action=edit&id='.$id);
|
|
}
|
|
|
|
public function GutschriftSteuer()
|
|
{
|
|
|
|
}
|
|
|
|
public function GutschriftSumme()
|
|
{
|
|
|
|
}
|
|
|
|
public function GutschriftEinkaufspreise()
|
|
{
|
|
|
|
}
|
|
|
|
public function GutschriftArchivierePDF()
|
|
{
|
|
$id = (int)$this->app->Secure->GetGET('id');
|
|
$projektbriefpapier = $this->app->DB->Select(
|
|
sprintf(
|
|
'SELECT `projekt` FROM `gutschrift` WHERE `id` = %d LIMIT 1',
|
|
$id
|
|
)
|
|
);
|
|
if(class_exists('GutschriftPDFCustom')) {
|
|
$Brief = new GutschriftPDFCustom($this->app,$projektbriefpapier);
|
|
}
|
|
else{
|
|
$Brief = new GutschriftPDF($this->app,$projektbriefpapier);
|
|
}
|
|
$Brief->GetGutschrift($id);
|
|
$tmpfile = $Brief->displayTMP();
|
|
$Brief->ArchiviereDocument(1, 1);
|
|
$this->app->DB->Update(
|
|
sprintf(
|
|
'UPDATE `gutschrift` SET `schreibschutz` = 1 WHERE `id` = %d',
|
|
$id
|
|
)
|
|
);
|
|
@unlink($tmpfile);
|
|
$this->app->Location->execute('index.php?module=gutschrift&action=edit&id='.$id);
|
|
}
|
|
|
|
public function GutschriftPDFFromArchiv()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$archiv = $this->app->DB->Select(
|
|
sprintf(
|
|
'SELECT `table_id` FROM `pdfarchiv` WHERE `id` = %d LIMIT 1',
|
|
$id
|
|
)
|
|
);
|
|
if(empty($archiv)) {
|
|
header('Content-type: application/pdf');
|
|
header('Content-Disposition: attachment; filename="Fehler.pdf"');
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
$projekt = $this->app->DB->Select(
|
|
sprintf(
|
|
'SELECT `projekt` FROM `gutschrift` WHERE `id` = %d',
|
|
$archiv
|
|
)
|
|
);
|
|
if(class_exists('GutschriftPDFCustom')) {
|
|
$Brief = new GutschriftPDFCustom($this->app,$projekt);
|
|
}
|
|
else{
|
|
$Brief = new GutschriftPDF($this->app,$projekt);
|
|
}
|
|
$content = $Brief->getArchivByID($id);
|
|
if(empty($content)) {
|
|
header('Content-type: application/pdf');
|
|
header('Content-Disposition: attachment; filename="Fehler.pdf"');
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
header('Content-type: application/pdf');
|
|
header('Content-Disposition: attachment; filename="'.$content['belegnr'].'.pdf"');
|
|
echo $content['file'];
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
public function GutschriftCopy()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
$newid = $this->CopyGutschrift($id);
|
|
|
|
$this->app->Location->execute('index.php?module=gutschrift&action=edit&id='.$newid);
|
|
}
|
|
|
|
|
|
public function GutschriftDeleteRabatte()
|
|
{
|
|
$id=$this->app->Secure->GetGET('id');
|
|
$this->app->DB->Update(
|
|
sprintf(
|
|
'UPDATE `gutschrift`
|
|
SET `rabatt` = 0, `rabatt1` = 0,`rabatt2` = 0,`rabatt3` = 0,`rabatt4` = 0,`rabatt5` = 0,`realrabatt`= 0
|
|
WHERE `id` = %d
|
|
LIMIT 1',
|
|
$id
|
|
)
|
|
);
|
|
$msg = $this->app->erp->base64_url_encode('<div class="info">Die Rabatte wurden entfernt!</div> ');
|
|
$this->app->Location->execute("index.php?module=gutschrift&action=edit&id=$id&msg=$msg");
|
|
}
|
|
|
|
public function GutschriftSchreibschutz()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$this->app->DB->Update(
|
|
sprintf(
|
|
'UPDATE gutschrift SET zuarchivieren=1, schreibschutz = 0 WHERE id = %d',
|
|
$id
|
|
)
|
|
);
|
|
$this->app->erp->GutschriftProtokoll($id,'Schreibschutz entfernt');
|
|
$this->app->Location->execute('index.php?module=gutschrift&action=edit&id='.$id);
|
|
}
|
|
|
|
public function GutschriftDateien()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$this->GutschriftMenu();
|
|
$this->app->Tpl->Add('UEBERSCHRIFT',' (Dateien)');
|
|
$this->app->YUI->DateiUpload('PAGE','Gutschrift',$id);
|
|
}
|
|
|
|
|
|
public function GutschriftZahlungMahnungswesen()
|
|
{
|
|
$this->GutschriftMenu();
|
|
$this->app->Tpl->Set('TABTEXT','Zahlung-/Mahnwesen');
|
|
$this->GutschriftMiniDetail('TAB1',true);
|
|
|
|
$this->app->Tpl->Parse('PAGE','tabview.tpl');
|
|
}
|
|
|
|
|
|
public function GutschriftEditable()
|
|
{
|
|
$this->app->YUI->AARLGEditable();
|
|
}
|
|
|
|
/**
|
|
* @param int $id
|
|
* @param string $prefix
|
|
*
|
|
* @return string|string[]
|
|
*/
|
|
public function GutschriftIconMenu($id,$prefix='')
|
|
{
|
|
$status = $this->app->DB->Select(
|
|
sprintf(
|
|
"SELECT `status` FROM `gutschrift` WHERE `id`= %d LIMIT 1",
|
|
$id
|
|
)
|
|
);
|
|
|
|
if($status==='angelegt' || $status==''){
|
|
$freigabe = "<option value=\"freigabe\">Gutschrift freigeben</option>";
|
|
}
|
|
|
|
if($this->app->erp->RechteVorhanden('belegeimport', 'belegcsvexport')) {
|
|
$casebelegeimport = "case 'belegeimport': window.location.href='index.php?module=belegeimport&action=belegcsvexport&cmd=gutschrift&id=%value%'; break;";
|
|
$optionbelegeimport = "<option value=\"belegeimport\">Export als CSV</option>";
|
|
}
|
|
|
|
$createpayment = '';
|
|
$casecreatepayment = '';
|
|
|
|
$hookoption = '';
|
|
$hookcase = '';
|
|
$this->app->erp->RunHook('Gutschrift_Aktion_option',3, $id, $status, $hookoption);
|
|
$this->app->erp->RunHook('Gutschrift_Aktion_case',3, $id, $status, $hookcase);
|
|
|
|
$menu ="
|
|
|
|
<script type=\"text/javascript\">
|
|
function onchangegutschrift(cmd)
|
|
{
|
|
switch(cmd)
|
|
{
|
|
case 'storno': if(!confirm('Wirklich stornieren?')) return document.getElementById('aktion$prefix').selectedIndex = 0; else window.location.href='index.php?module=gutschrift&action=delete&id=%value%'; break;
|
|
case 'copy': if(!confirm('Wirklich kopieren?')) return document.getElementById('aktion$prefix').selectedIndex = 0; else window.location.href='index.php?module=gutschrift&action=copy&id=%value%'; break;
|
|
case 'pdf': window.location.href='index.php?module=gutschrift&action=pdf&id=%value%'; document.getElementById('aktion$prefix').selectedIndex = 0; break;
|
|
case 'abschicken': ".$this->app->erp->DokumentAbschickenPopup()." break;
|
|
case 'freigabe': window.location.href='index.php?module=gutschrift&action=freigabe&id=%value%'; break;
|
|
$casecreatepayment
|
|
$casebelegeimport
|
|
$hookcase
|
|
}
|
|
|
|
}
|
|
</script>
|
|
|
|
Aktion: <select id=\"aktion$prefix\" onchange=\"onchangegutschrift(this.value);\">
|
|
<option>bitte wählen ...</option>
|
|
<option value=\"storno\">Gutschrift stornieren</option>
|
|
<option value=\"copy\">Gutschrift kopieren</option>
|
|
$freigabe
|
|
<option value=\"abschicken\">Gutschrift abschicken</option>
|
|
$optionbelegeimport
|
|
<option value=\"pdf\">PDF öffnen</option>
|
|
$createpayment
|
|
$hookoption
|
|
</select>
|
|
|
|
<a href=\"index.php?module=gutschrift&action=pdf&id=%value%\" title=\"PDF\"><img border=\"0\" src=\"./themes/new/images/pdf.svg\"></a>
|
|
";
|
|
|
|
$menu = str_replace('%value%',$id,$menu);
|
|
return $menu;
|
|
}
|
|
|
|
|
|
|
|
function GutschriftLiveTabelle()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$status = $this->app->DB->Select(
|
|
sprintf(
|
|
"SELECT `status` FROM `gutschrift` WHERE `id`= %d LIMIT 1",
|
|
$id
|
|
)
|
|
);
|
|
|
|
$table = new EasyTable($this->app);
|
|
|
|
if($status==='freigegeben')
|
|
{
|
|
$table->Query(
|
|
"SELECT SUBSTRING(ap.bezeichnung,1,20) as artikel, ap.nummer as Nummer,
|
|
TRIM(ap.menge)+0 as Menge,FORMAT(ap.preis,2,'de_DE') as Preis
|
|
FROM gutschrift_position ap, artikel a
|
|
WHERE ap.gutschrift='$id' AND a.id=ap.artikel"
|
|
);
|
|
$artikel = $table->DisplayNew('return','Preis','noAction');
|
|
}
|
|
else {
|
|
$table->Query(
|
|
"SELECT SUBSTRING(ap.bezeichnung,1,20) as artikel, ap.nummer as Nummer, TRIM(ap.menge)+0 as Menge,
|
|
FORMAT(ap.preis,2,'de_DE') as Preis
|
|
FROM gutschrift_position ap, artikel a
|
|
WHERE ap.gutschrift='$id' AND a.id=ap.artikel"
|
|
);
|
|
$artikel = $table->DisplayNew('return','Preis','noAction');
|
|
}
|
|
echo $artikel;
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
/**
|
|
* @param string $parsetarget
|
|
* @param bool $menu
|
|
*/
|
|
public function GutschriftMiniDetail($parsetarget='',$menu=true)
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
if(!$this->app->DB->Select("SELECT deckungsbeitragcalc FROM gutschrift WHERE id='$id' LIMIT 1")) {
|
|
$this->app->erp->BerechneDeckungsbeitrag($id,'gutschrift');
|
|
}
|
|
$auftragArr = $this->app->DB->SelectArr("SELECT * FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
$kundennummer = $this->app->DB->Select("SELECT kundennummer FROM adresse WHERE id='{$auftragArr[0]['adresse']}' LIMIT 1");
|
|
$projekt = $this->app->DB->Select("SELECT abkuerzung FROM projekt WHERE id='{$auftragArr[0]['projekt']}' LIMIT 1");
|
|
$kundenname = $this->app->DB->Select("SELECT name FROM adresse WHERE id='{$auftragArr[0]['adresse']}' LIMIT 1");
|
|
$this->app->Tpl->Set('DECKUNGSBEITRAG',0);
|
|
$this->app->Tpl->Set('DBPROZENT',0);
|
|
$this->app->Tpl->Set('KUNDE',"<a href=\"index.php?module=adresse&action=edit&id=".$auftragArr[0]['adresse']."\">".$kundennummer."</a> ".$kundenname);
|
|
|
|
if($this->app->erp->RechteVorhanden("projekt","dashboard"))
|
|
$this->app->Tpl->Set('PROJEKT',"<a href=\"index.php?module=projekt&action=dashboard&id=".$auftragArr[0]['projekt']."\" target=\"_blank\">$projekt</a>");
|
|
else
|
|
$this->app->Tpl->Set('PROJEKT',$projekt);
|
|
|
|
$this->app->Tpl->Set('ZAHLWEISE',$auftragArr[0]['zahlungsweise']);
|
|
$this->app->Tpl->Set('STATUS',$auftragArr[0]['status']);
|
|
|
|
$internet = $this->app->DB->Select("SELECT a.internet FROM gutschrift g LEFT JOIN rechnung r ON r.id=g.rechnungid LEFT JOIN auftrag a ON a.id=r.auftragid WHERE g.id='$id' AND g.id > 0 LIMIT 1");
|
|
$this->app->Tpl->Set('INTERNET',$internet);
|
|
|
|
$rechnung = $this->app->DB->SelectArr(
|
|
"SELECT
|
|
`r`.auftragid,
|
|
CONCAT('<a href=\"index.php?module=rechnung&action=edit&id=',
|
|
`r`.id,'\" target=\"_blank\">',
|
|
if(`r`.belegnr='0' OR `r`.belegnr='','ENTWURF',`r`.belegnr),
|
|
' <a href=\"index.php?module=rechnung&action=pdf&id=', `r`.id,
|
|
'\"><img src=\"./themes/new/images/pdf.svg\" title=\"Rechnung PDF\" border=\"0\"></a>
|
|
<a href=\"index.php?module=rechnung&action=edit&id=',`r`.id,
|
|
'\" target=\"_blank\"><img src=\"./themes/new/images/edit.svg\" title=\"Rechnung bearbeiten\" border=\"0\"></a>'
|
|
) as `rechnung`
|
|
FROM `gutschrift` AS `g`
|
|
LEFT JOIN `rechnung` AS `r` ON `r`.id=`g`.rechnungid
|
|
WHERE `g`.id='$id'"
|
|
);
|
|
|
|
$orderIds = [];
|
|
if(!empty($rechnung)) {
|
|
$cRechnung = (!empty($rechnung)?count($rechnung):0);
|
|
for($li=0;$li<$cRechnung;$li++) {
|
|
$orderIds[] = (int)$rechnung[$li]['auftragid'];
|
|
$this->app->Tpl->Add('RECHNUNG',$rechnung[$li]['rechnung']);
|
|
if($li<$cRechnung) {
|
|
$this->app->Tpl->Add('RECHNUNG',"<br>");
|
|
$lieferscheinid = $this->app->DB->Select("SELECT r.lieferschein FROM gutschrift g LEFT JOIN rechnung r ON r.id=g.rechnungid WHERE g.id='$id'");
|
|
if($lieferscheinid > 0) {
|
|
$lieferschein = $this->app->DB->Select("SELECT CONCAT(belegnr,' <a href=\"index.php?module=lieferschein&action=pdf&id=',id,'\">
|
|
<img src=\"./themes/new/images/pdf.svg\" title=\"Lieferschein PDF\" border=\"0\"></a>
|
|
<a href=\"index.php?module=lieferschein&action=edit&id=',id,'\"><img src=\"./themes/new/images/edit.svg\" title=\"Lieferschein bearbeiten\" border=\"0\"></a>')
|
|
FROM lieferschein WHERE id='$lieferscheinid' LIMIT 1");
|
|
}
|
|
|
|
$this->app->Tpl->Set('LIEFERSCHEIN',$lieferschein);
|
|
}
|
|
}
|
|
}
|
|
else{
|
|
$this->app->Tpl->Set('RECHNUNG', '-');
|
|
}
|
|
|
|
$orders = empty($orderIds)?[]:$this->app->DB->SelectFirstCols(
|
|
sprintf(
|
|
"SELECT CONCAT('<a href=\"index.php?module=auftrag&action=edit&id=',
|
|
`o`.id,'\" target=\"_blank\">',
|
|
if(`o`.belegnr='0' OR `o`.belegnr='','ENTWURF',`o`.belegnr),
|
|
' <a href=\"index.php?module=auftrag&action=pdf&id=', `o`.id,
|
|
'\"><img src=\"./themes/new/images/pdf.svg\" title=\"Auftrag PDF\" border=\"0\"></a>
|
|
<a href=\"index.php?module=auftrag&action=edit&id=',`o`.id,
|
|
'\" target=\"_blank\"><img src=\"./themes/new/images/edit.svg\" title=\"Auftrag bearbeiten\" border=\"0\"></a>'
|
|
)
|
|
FROM `auftrag` AS `o`
|
|
WHERE `o`.`id` IN (%s)
|
|
ORDER BY `o`.datum, `o`.id",
|
|
implode(',', $orderIds)
|
|
)
|
|
);
|
|
|
|
if(!empty($orders)) {
|
|
$this->app->Tpl->Set('AUFTRAG', implode('<br />', $orders));
|
|
}
|
|
else {
|
|
$this->app->Tpl->Set('AUFTRAG', '-');
|
|
}
|
|
|
|
/*
|
|
$rechnung = $this->app->DB->Select("SELECT CONCAT(rechnung,' <a href=\"index.php?module=rechnung&action=pdf&id=',rechnungid,'\">
|
|
<img src=\"./themes/new/images/pdf.svg\" title=\"Rechnung PDF\" border=\"0\"></a>
|
|
<a href=\"index.php?module=rechnung&action=edit&id=',rechnungid,'\"><img src=\"./themes/new/images/edit.svg\" title=\"Rechnung bearbeiten\" border=\"0\"></a>')
|
|
FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
|
|
if($rechnung=="" || $rechnung <=0 ) $rechnung = "-";
|
|
$this->app->Tpl->Set(RECHNUNG,$rechnung);
|
|
*/
|
|
if($auftragArr[0]['ust_befreit']==0){
|
|
$this->app->Tpl->Set('STEUER', "Inland");
|
|
}
|
|
else if($auftragArr[0]['ust_befreit']==1){
|
|
$this->app->Tpl->Set('STEUER', "EU-Lieferung");
|
|
}
|
|
else{
|
|
$this->app->Tpl->Set('STEUER', 'Export');
|
|
}
|
|
|
|
|
|
if($menu)
|
|
{
|
|
$menu = $this->GutschriftIconMenu($id);
|
|
$this->app->Tpl->Set('MENU',$menu);
|
|
}
|
|
// ARTIKEL
|
|
|
|
$status = $this->app->DB->Select("SELECT status FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
|
|
$table = new EasyTable($this->app);
|
|
|
|
$table->Query("SELECT if(CHAR_LENGTH(ap.beschreibung) > 0,CONCAT(ap.bezeichnung,' *'),ap.bezeichnung) as artikel, CONCAT('<a href=\"index.php?module=artikel&action=edit&id=',ap.artikel,'\" target=\"_blank\">', ap.nummer,'</a>') as Nummer, ".$this->app->erp->FormatMenge("ap.menge")." as Menge,".$this->app->erp->FormatPreis("ap.preis*(100-ap.rabatt)/100",2)." as Preis
|
|
FROM gutschrift_position ap, artikel a WHERE ap.gutschrift='$id' AND a.id=ap.artikel ORDER by ap.sort",0,'');
|
|
|
|
|
|
$table->align = array('left','left','right','right');
|
|
$artikel = $table->DisplayNew('return','Preis','noAction','false',0,0,false);
|
|
$this->app->Tpl->Set('ARTIKEL','<div id="artikeltabellelive'.$id.'">'.$artikel.'</div>');
|
|
|
|
if($auftragArr[0]['belegnr']=='0' || $auftragArr[0]['belegnr']=='') {
|
|
$auftragArr[0]['belegnr'] = 'ENTWURF';
|
|
}
|
|
$this->app->Tpl->Set('BELEGNR',$auftragArr[0]['belegnr']);
|
|
$this->app->Tpl->Set('GUTSCHRIFTID',$auftragArr[0]['id']);
|
|
$this->app->Tpl->Set('DELIVERYTHRESHOLDVATID',!empty($auftragArr[0]['deliverythresholdvatid'])?$auftragArr[0]['deliverythresholdvatid']:'');
|
|
|
|
if($auftragArr[0]['status']==='freigegeben')
|
|
{
|
|
$this->app->Tpl->Set('ANGEBOTFARBE',"orange");
|
|
$this->app->Tpl->Set('ANGEBOTTEXT',"Das Angebot wurde noch nicht als Auftrag weitergeführt!");
|
|
}
|
|
else if($auftragArr[0]['status']==='versendet')
|
|
{
|
|
$this->app->Tpl->Set('ANGEBOTFARBE',"red");
|
|
$this->app->Tpl->Set('ANGEBOTTEXT',"Das Angebot versendet aber noch kein Auftrag vom Kunden erhalten!");
|
|
}
|
|
else if($auftragArr[0]['status']==='beauftragt')
|
|
{
|
|
$this->app->Tpl->Set('ANGEBOTFARBE','green');
|
|
$this->app->Tpl->Set('ANGEBOTTEXT',"Das Angebot wurde beauftragt und abgeschlossen!");
|
|
}
|
|
else if($auftragArr[0]['status']==='angelegt')
|
|
{
|
|
$this->app->Tpl->Set('ANGEBOTFARBE',"grey");
|
|
$this->app->Tpl->Set('ANGEBOTTEXT',"Das Angebot wird bearbeitet und wurde noch nicht freigegeben und abgesendet!");
|
|
}
|
|
|
|
|
|
$this->app->Tpl->Set('GUTSCHRIFTADRESSE',$this->Gutschriftadresse($auftragArr[0]['id']));
|
|
|
|
$tmp = new EasyTable($this->app);
|
|
$tmp->Query("SELECT zeit,bearbeiter,grund FROM gutschrift_protokoll WHERE gutschrift='$id' ORDER by zeit DESC",0,'');
|
|
$tmp->DisplayNew('PROTOKOLL',"Protokoll","noAction");
|
|
|
|
if(class_exists('GutschriftPDFCustom'))
|
|
{
|
|
$Brief = new GutschriftPDFCustom($this->app,$projekt);
|
|
}else{
|
|
$Brief = new GutschriftPDF($this->app,$projekt);
|
|
}
|
|
|
|
$Dokumentenliste = $Brief->getArchivedFiles($id, 'gutschrift');
|
|
if($Dokumentenliste)
|
|
{
|
|
$tmp3 = new EasyTable($this->app);
|
|
$tmp3->headings = array('Datum','Belegnr','Bearbeiter','Menü');
|
|
foreach($Dokumentenliste as $k => $v)
|
|
{
|
|
if(!$v['erstesoriginal'])
|
|
{
|
|
$tmpr['datum'] = date('d.m.Y H:i:s',strtotime($v['zeitstempel']));
|
|
$tmpr['belegnr'] = str_replace('.pdf','',$v['file']);
|
|
$tmpr['belegnr'] = substr($tmpr['belegnr'],strrpos($tmpr['belegnr'],'_')+1);
|
|
if(isset($v['belegnummer']) && $v['belegnummer']) {
|
|
$tmpr['belegnr'] = $v['belegnummer'];
|
|
}
|
|
$tmpr['bearbeiter'] = $v['bearbeiter'];
|
|
$tmpr['menu'] = '<a href="index.php?module=gutschrift&action=pdffromarchive&id='.$v['id'].'"><img src="themes/'.$this->app->Conf->WFconf['defaulttheme'].'/images/pdf.svg" /></a>';
|
|
$tmp3->datasets[] = $tmpr;
|
|
}
|
|
}
|
|
$tmp3->DisplayNew('PDFARCHIV','Menü','noAction');
|
|
}
|
|
|
|
$this->app->Tpl->Add('ZAHLUNGEN',$this->GutschriftZahlung(true));
|
|
|
|
if($parsetarget=='') {
|
|
$this->app->Tpl->Output('gutschrift_minidetail.tpl');
|
|
$this->app->ExitXentral();
|
|
}
|
|
$this->app->Tpl->Parse($parsetarget,'gutschrift_minidetail.tpl');
|
|
}
|
|
|
|
function Gutschriftadresse($id)
|
|
{
|
|
$data = $this->app->DB->SelectArr("SELECT * FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
|
|
foreach($data[0] as $key=>$value)
|
|
{
|
|
if($data[0][$key]!='' && $key!=='abweichendelieferadresse'
|
|
&& $key!=='land' && $key!=='plz' && $key!=='lieferland' && $key!=='lieferplz') {
|
|
$data[0][$key] = $data[0][$key].'<br>';
|
|
}
|
|
}
|
|
|
|
|
|
$rechnungsadresse = $data[0]['name']."".$data[0]['ansprechpartner']."".$data[0]['abteilung']."".$data[0]['unterabteilung'].
|
|
"".$data[0]['strasse']."".$data[0]['adresszusatz']."".$data[0]['land']."-".$data[0]['plz']." ".$data[0]['ort'];
|
|
return "<table width=\"100%\">
|
|
<tr valign=\"top\"><td width=\"50%\"><b>Gutschrift:</b><br><br>$rechnungsadresse</td></tr>";
|
|
}
|
|
|
|
|
|
/**
|
|
* @param bool $return
|
|
*
|
|
* @return string
|
|
*/
|
|
function GutschriftZahlung($return=false)
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
$gutschriftArr = $this->app->DB->SelectArr(
|
|
"SELECT DATE_FORMAT(datum,'%d.%m.%Y') as datum, belegnr, soll, waehrung, rechnungid
|
|
FROM gutschrift WHERE id='$id' LIMIT 1"
|
|
);
|
|
$waehrung = empty($gutschriftArr)?'EUR':$gutschriftArr[0]['waehrung'];
|
|
if(!$waehrung) {
|
|
$waehrung = 'EUR';
|
|
}
|
|
|
|
$rechnungid = empty($gutschriftArr)?0: $gutschriftArr[0]['rechnungid'];
|
|
|
|
$auftragid = $rechnungid <= 0?0:$this->app->DB->Select(
|
|
sprintf(
|
|
'SELECT `auftragid` FROM `rechnung` WHERE `id` = %d LIMIT 1',
|
|
$rechnungid
|
|
)
|
|
);
|
|
$eingang ="<tr><td colspan=\"3\"><b>Zahlungen</b></td></tr>";
|
|
|
|
|
|
$eingang .="<tr><td class=auftrag_cell>".$gutschriftArr[0]['datum']
|
|
."</td><td class=auftrag_cell>GS ".$gutschriftArr[0]['belegnr']
|
|
."</td><td class=auftrag_cell align=right>".$this->app->erp->EUR($gutschriftArr[0]['soll'])
|
|
." $waehrung</td></tr>";
|
|
|
|
$eingangArr = $this->app->DB->SelectArr(
|
|
"SELECT ko.bezeichnung as konto, DATE_FORMAT(ke.datum,'%d.%m.%Y') as datum, k.id as kontoauszuege,
|
|
ke.betrag as betrag, k.id as zeile,k.waehrung
|
|
FROM kontoauszuege_zahlungseingang ke
|
|
LEFT JOIN kontoauszuege k ON ke.kontoauszuege=k.id
|
|
LEFT JOIN konten ko ON k.konto=ko.id
|
|
WHERE (ke.objekt='gutschrift' AND ke.parameter='$id')
|
|
OR (ke.objekt='auftrag' AND ke.parameter='$auftragid' AND ke.parameter>0)
|
|
OR (ke.objekt='rechnung' AND ke.parameter='$rechnungid' AND ke.parameter>0)"
|
|
);
|
|
$ceingangArr = empty($eingangArr)?0:(!empty($eingangArr)?count($eingangArr):0);
|
|
|
|
for($i=0;$i<$ceingangArr;$i++) {
|
|
$waehrung = 'EUR';
|
|
if($eingangArr[$i]['waehrung']) {
|
|
$waehrung = $eingangArr[$i]['waehrung'];
|
|
}
|
|
$eingang .="<tr><td class=auftrag_cell>".$eingangArr[$i]['datum']
|
|
."</td><td class=auftrag_cell>".$eingangArr[$i]['konto']
|
|
." (<a href=\"index.php?module=zahlungseingang&action=editzeile&id="
|
|
.$eingangArr[$i]['zeile']."\">zur Buchung</a>)</td><td class=auftrag_cell align=right>"
|
|
.$this->app->erp->EUR($eingangArr[$i]['betrag'])
|
|
." $waehrung</td></tr>";
|
|
}
|
|
// gutschriften zu dieser rechnung anzeigen
|
|
/*
|
|
$gutschriften = $this->app->DB->SelectArr("SELECT belegnr, DATE_FORMAT(datum,'%d.%m.%Y') as datum,soll FROM gutschrift WHERE rechnungid='$id'");
|
|
|
|
for($i=0;$i<(!empty($gutschriften)?count($gutschriften):0);$i++)
|
|
$eingang .="<tr><td class=auftrag_cell>".$gutschriften[$i]['datum']."</td><td class=auftrag_cell>GS ".$gutschriften[$i]['belegnr']."</td><td class=auftrag_cell align=right>".$this->app->erp->EUR($gutschriften[$i]['soll'])." EUR</td></tr>";
|
|
|
|
*/
|
|
|
|
$ausgang = '';
|
|
$ausgangArr = $this->app->DB->SelectArr(
|
|
"SELECT ko.bezeichnung as konto, DATE_FORMAT(ke.datum,'%d.%m.%Y') as datum, ke.betrag as betrag,
|
|
k.id as zeile,k.waehrung
|
|
FROM kontoauszuege_zahlungsausgang ke
|
|
LEFT JOIN kontoauszuege k ON ke.kontoauszuege=k.id
|
|
LEFT JOIN konten ko ON k.konto=ko.id
|
|
WHERE (ke.objekt='gutschrift' AND ke.parameter='$id')
|
|
OR (ke.objekt='rechnung' AND ke.parameter='$rechnungid' AND ke.parameter>0)
|
|
OR (ke.objekt='auftrag' AND ke.parameter='$auftragid' AND ke.parameter>0)"
|
|
);
|
|
$cAusgangArr = empty($ausgangArr)?0:(!empty($ausgangArr)?count($ausgangArr):0);
|
|
for($i=0;$i<$cAusgangArr;$i++) {
|
|
$waehrung = 'EUR';
|
|
if($ausgangArr[$i]['waehrung']) {
|
|
$waehrung = $ausgangArr[$i]['waehrung'];
|
|
}
|
|
$ausgang .="<tr><td class=auftrag_cell>".$ausgangArr[$i]['datum']."</td><td class=auftrag_cell>"
|
|
.$ausgangArr[$i]['konto']." (<a href=\"index.php?module=zahlungseingang&action=editzeile&id="
|
|
.$ausgangArr[$i]['zeile']."\">zur Buchung</a>)</td><td class=auftrag_cell align=right>"
|
|
.$this->app->erp->EUR($ausgangArr[$i]['betrag'])
|
|
." $waehrung</td></tr>";
|
|
}
|
|
|
|
$saldo = $this->app->erp->EUR($this->GutschriftSaldo($id));
|
|
|
|
if($saldo < 0) {
|
|
$saldo = "<b style=\"color:red\">$saldo</b>";
|
|
}
|
|
$waehrung = $this->app->DB->Select("SELECT waehrung FROM gutschrift WHERE id = '$id' LIMIT 1");
|
|
if(!$waehrung) {
|
|
$waehrung = 'EUR';
|
|
}
|
|
$ausgang .="<tr><td class=auftrag_cell></td><td class=auftrag_cell align=right>Saldo</td><td class=auftrag_cell align=right>$saldo $waehrung</td></tr>";
|
|
|
|
if($return) {
|
|
return "<table width=100% border=0 class=auftrag_cell cellpadding=0 cellspacing=0>".$eingang." ".$ausgang."</table>";
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* @param string|int $id
|
|
*
|
|
* @return int
|
|
*/
|
|
public function GutschriftFreigabe($id='')
|
|
{
|
|
if($id<=0) {
|
|
$id = (int)$this->app->Secure->GetGET('id');
|
|
$freigabe= $this->app->Secure->GetGET('freigabe');
|
|
}
|
|
else {
|
|
$intern = true;
|
|
$freigabe=$intern;
|
|
}
|
|
$allowedFrm = true;
|
|
$showDefault = true;
|
|
$this->app->Tpl->Set('TABTEXT','Freigabe');
|
|
$this->app->erp->GutschriftNeuberechnen($id);
|
|
|
|
$this->app->erp->CheckVertrieb($id,'gutschrift');
|
|
$this->app->erp->CheckBearbeiter($id,'gutschrift');
|
|
$doctype = 'gutschrift';
|
|
if(empty($intern)){
|
|
$this->app->erp->RunHook('beleg_freigabe', 4, $doctype, $id, $allowedFrm, $showDefault);
|
|
}
|
|
if($allowedFrm && $freigabe==$id) {
|
|
$belegnr = $this->app->DB->Select("SELECT belegnr FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
if($belegnr=='') {
|
|
$this->app->erp->BelegFreigabe('gutschrift',$id);
|
|
if($intern) {
|
|
return 1;
|
|
}
|
|
$msg = $this->app->erp->base64_url_encode("<div class=\"info\">Die Gutschrift wurde freigegeben und kann jetzt versendet werden!</div>");
|
|
$this->app->Location->execute("index.php?module=gutschrift&action=edit&id=$id&msg=$msg");
|
|
}
|
|
if($intern) {
|
|
return 0;
|
|
}
|
|
$msg = $this->app->erp->base64_url_encode("<div class=\"error\">Die Gutschrift war bereits freigegeben!</div>");
|
|
$this->app->Location->execute("index.php?module=gutschrift&action=edit&id=$id&msg=$msg");
|
|
}
|
|
if($showDefault){
|
|
$name = $this->app->DB->Select("SELECT a.name FROM gutschrift b LEFT JOIN adresse a ON a.id=b.adresse WHERE b.id='$id' LIMIT 1");
|
|
$summe = $this->app->DB->Select("SELECT soll FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
$waehrung = $this->app->DB->Select("SELECT waehrung FROM gutschrift_position
|
|
WHERE gutschrift='$id' LIMIT 1");
|
|
|
|
$this->app->Tpl->Set('TAB1', "<div class=\"info\">Soll die Gutschrift an <b>$name</b> im Wert von <b>$summe $waehrung</b>
|
|
jetzt freigegeben werden? <input type=\"button\" value=\"Freigabe\" onclick=\"window.location.href='index.php?module=gutschrift&action=freigabe&id=$id&freigabe=$id'\">
|
|
</div>");
|
|
}
|
|
$this->GutschriftMenu();
|
|
$this->app->Tpl->Parse('PAGE','tabview.tpl');
|
|
}
|
|
|
|
|
|
function GutschriftAbschicken()
|
|
{
|
|
$this->GutschriftMenu();
|
|
$this->app->erp->DokumentAbschicken();
|
|
}
|
|
|
|
function GutschriftDelete()
|
|
{
|
|
$id = $this->app->Secure->GetGET("id");
|
|
|
|
$belegnr = $this->app->DB->Select("SELECT belegnr FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
$name = $this->app->DB->Select("SELECT name FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
$status = $this->app->DB->Select("SELECT status FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
|
|
if($belegnr=="0" || $belegnr=="")
|
|
{
|
|
|
|
$this->app->erp->DeleteGutschrift($id);
|
|
$belegnr="ENTWURF";
|
|
$msg = $this->app->erp->base64_url_encode("<div class=\"info\">Die Gutschrift \"$name\" ($belegnr) wurde gelöscht!</div>");
|
|
//header("Location: ".$_SERVER['HTTP_REFERER']."&msg=$msg");
|
|
header("Location: index.php?module=gutschrift&action=list&msg=$msg");
|
|
exit;
|
|
} else
|
|
{
|
|
if(0)//$status=="versendet")
|
|
{
|
|
// KUNDE muss RMA starten
|
|
$msg = $this->app->erp->base64_url_encode("<div class=\"error\">Gutschrift \"$name\" ($belegnr) kann nicht storniert werden sie bereits versendet ist.</div>");
|
|
}
|
|
else
|
|
{
|
|
$maxbelegnr = $this->app->DB->Select("SELECT MAX(belegnr) FROM gutschrift");
|
|
if(0)//$maxbelegnr == $belegnr)
|
|
{
|
|
$this->app->DB->Delete("DELETE FROM gutschrift_position WHERE gutschrift='$id'");
|
|
$this->app->DB->Delete("DELETE FROM gutschrift_protokoll WHERE gutschrift='$id'");
|
|
$this->app->DB->Delete("DELETE FROM gutschrift WHERE id='$id'");
|
|
$msg = $this->app->erp->base64_url_encode("<div class=\"info\">Gutschrift \"$name\" ($belegnr) wurde geöscht !</div>");
|
|
} else
|
|
{
|
|
$msg = $this->app->erp->base64_url_encode("<div class=\"error\">Gutschrift \"$name\" ($belegnr) kann nicht storniert werden da sie bereits freigegeben oder versendet ist!</div>");
|
|
}
|
|
header("Location: index.php?module=gutschrift&action=list&msg=$msg");
|
|
exit;
|
|
}
|
|
header("Location: index.php?module=gutschrift&action=list&msg=$msg#tabs-1");
|
|
exit;
|
|
}
|
|
|
|
}
|
|
|
|
|
|
function GutschriftDelete2()
|
|
{
|
|
$id = $this->app->Secure->GetGET("id");
|
|
|
|
$belegnr = $this->app->DB->Select("SELECT belegnr FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
|
|
if($belegnr=="" || $belegnr=="0")
|
|
{
|
|
$this->app->erp->DeleteGutschrift($id);
|
|
$this->app->Tpl->Set('MESSAGE',"<div class=\"info\">Gutschrift wurde gelöscht!</div>");
|
|
} else
|
|
{
|
|
$this->app->Tpl->Set('MESSAGE',"<div class=\"error\">Die Gutschrift kann nicht mehr gelöscht werden, da diese bereits versendet wurde!</div>");
|
|
}
|
|
$this->GutschriftList();
|
|
|
|
}
|
|
|
|
function GutschriftProtokoll()
|
|
{
|
|
$this->GutschriftMenu();
|
|
$id = $this->app->Secure->GetGET("id");
|
|
|
|
$this->app->Tpl->Set('TABTEXT',"Protokoll");
|
|
$tmp = new EasyTable($this->app);
|
|
$tmp->Query("SELECT zeit,bearbeiter,grund FROM gutschrift_protokoll WHERE gutschrift='$id' ORDER by zeit DESC");
|
|
$tmp->DisplayNew('TAB1',"Protokoll","noAction");
|
|
|
|
$this->app->Tpl->Parse('PAGE',"tabview.tpl");
|
|
}
|
|
|
|
|
|
function GutschriftInlinePDF()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$this->app->erp->GutschriftNeuberechnen($id);
|
|
|
|
$frame = $this->app->Secure->GetGET('frame');
|
|
|
|
if($frame=='') {
|
|
$projekt = $this->app->DB->Select(
|
|
sprintf(
|
|
"SELECT `projekt` FROM `gutschrift` WHERE `id` = %d LIMIT 1",
|
|
$id
|
|
)
|
|
);
|
|
if(class_exists('GutschriftPDFCustom')) {
|
|
$Brief = new GutschriftPDFCustom($this->app,$projekt);
|
|
}
|
|
else{
|
|
$Brief = new GutschriftPDF($this->app,$projekt);
|
|
}
|
|
$Brief->GetGutschrift($id);
|
|
$Brief->inlineDocument();
|
|
}
|
|
else {
|
|
$file = urlencode("../../../../index.php?module=gutschrift&action=inlinepdf&id=$id");
|
|
echo "<iframe width=\"100%\" height=\"100%\" style=\"height:calc(100vh - 110px)\" src=\"./js/production/generic/web/viewer.html?file=$file\"></iframe>";
|
|
$this->app->ExitXentral();
|
|
}
|
|
}
|
|
|
|
|
|
public function GutschriftPDF()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$this->app->erp->GutschriftNeuberechnen($id);
|
|
$projekt = $this->app->DB->Select("SELECT projekt FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
|
|
// if(is_numeric($belegnr) && $belegnr!=0)
|
|
{
|
|
if(class_exists('GutschriftPDFCustom'))
|
|
{
|
|
$Brief = new GutschriftPDFCustom($this->app,$projekt);
|
|
}
|
|
else{
|
|
$Brief = new GutschriftPDF($this->app,$projekt);
|
|
}
|
|
$Brief->GetGutschrift($id);
|
|
$Brief->displayDocument();
|
|
}// else
|
|
// $this->app->Tpl->Set(MESSAGE,"<div class=\"error\">Noch nicht freigegebene Gutschriften können nicht als PDF betrachtet werden.!</div>");
|
|
|
|
$this->GutschriftList();
|
|
}
|
|
|
|
|
|
function GutschriftMenu()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
$belegnr = $this->app->DB->Select("SELECT belegnr FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
$name = $this->app->DB->Select("SELECT name FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
|
|
if($belegnr=='0' || $belegnr=='') {
|
|
$belegnr ='(Entwurf)';
|
|
}
|
|
// $this->app->Tpl->Set(KURZUEBERSCHRIFT,"Gutschrift $belegnr");
|
|
$this->app->Tpl->Set('KURZUEBERSCHRIFT2',"$name Gutschrift $belegnr");
|
|
|
|
$this->app->erp->GutschriftNeuberechnen($id);
|
|
|
|
// status bestell
|
|
$status = $this->app->DB->Select("SELECT status FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
|
|
|
|
if ($status==='angelegt') {
|
|
$this->app->erp->MenuEintrag('index.php?module=gutschrift&action=freigabe&id='.$id,'Freigabe');
|
|
}
|
|
|
|
$this->app->erp->MenuEintrag('index.php?module=gutschrift&action=edit&id='.$id,'Details');
|
|
|
|
$anzahldateien = $this->app->erp->AnzahlDateien('Gutschein',$id);
|
|
if($anzahldateien > 0) {
|
|
$anzahldateien = ' ('.$anzahldateien.')';
|
|
} else {
|
|
$anzahldateien='';
|
|
}
|
|
|
|
$this->app->erp->MenuEintrag('index.php?module=gutschrift&action=dateien&id='.$id,'Dateien'.$anzahldateien);
|
|
$this->app->erp->MenuEintrag('index.php?module=gutschrift&action=zahlungsmahnungswesen&id='.$id,'Zahlung-/Mahnwesen');
|
|
|
|
$this->app->erp->RunMenuHook('gutschrift');
|
|
|
|
$this->app->erp->MenuEintrag('index.php?module=gutschrift&action=list','Zurück zur Übersicht');
|
|
}
|
|
|
|
|
|
public function GutschriftPositionen()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$this->app->erp->GutschriftNeuberechnen($id);
|
|
$this->app->YUI->AARLGPositionen(false);
|
|
}
|
|
|
|
public function CopyGutschriftPosition()
|
|
{
|
|
$this->app->YUI->SortListEvent('copy','gutschrift_position','gutschrift');
|
|
$this->GutschriftPositionen();
|
|
}
|
|
|
|
public function DelGutschriftPosition()
|
|
{
|
|
$this->app->YUI->SortListEvent('del','gutschrift_position','gutschrift');
|
|
$this->GutschriftPositionen();
|
|
}
|
|
|
|
public function UpGutschriftPosition()
|
|
{
|
|
$this->app->YUI->SortListEvent('up','gutschrift_position','gutschrift');
|
|
$this->GutschriftPositionen();
|
|
}
|
|
|
|
public function DownGutschriftPosition()
|
|
{
|
|
$this->app->YUI->SortListEvent('down','gutschrift_position','gutschrift');
|
|
$this->GutschriftPositionen();
|
|
}
|
|
|
|
|
|
public function GutschriftPositionenEditPopup()
|
|
{
|
|
$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] = 'gutschrift_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('gutschrift_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('gutschrift_accordion'.$name, $active);
|
|
echo json_encode(array('success'=>1));
|
|
$this->app->ExitXentral();
|
|
}
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
$artikel= $this->app->DB->Select("SELECT artikel FROM gutschrift_position WHERE id='$id' LIMIT 1");
|
|
|
|
// nach page inhalt des dialogs ausgeben
|
|
$filename = 'widgets/widget.gutschrift_position_custom.php';
|
|
if(is_file($filename)) {
|
|
include_once $filename;
|
|
$widget = new WidgetGutschrift_positionCustom($this->app,'PAGE');
|
|
}
|
|
else {
|
|
$widget = new WidgetGutschrift_position($this->app,'PAGE');
|
|
}
|
|
$sid= $this->app->DB->Select("SELECT gutschrift FROM gutschrift_position WHERE id='$id' LIMIT 1");
|
|
$widget->form->SpecialActionAfterExecute('close_refresh',
|
|
"index.php?module=gutschrift&action=positionen&id=$sid");
|
|
$widget->Edit();
|
|
$this->app->BuildNavigation=false;
|
|
}
|
|
|
|
|
|
public function GutschriftEdit()
|
|
{
|
|
$action = $this->app->Secure->GetGET('action');
|
|
$id = $this->app->Secure->GetGET('id');
|
|
if($this->app->Secure->GetPOST('resetextsoll')) {
|
|
$this->app->DB->Update(
|
|
sprintf(
|
|
'UPDATE gutschrift SET extsoll = 0 WHERE id = %d',
|
|
$id
|
|
)
|
|
);
|
|
$this->app->erp->GutschriftNeuberechnen($id);
|
|
}
|
|
// zum aendern vom Vertrieb
|
|
$sid = $this->app->Secure->GetGET("sid");
|
|
$cmd = $this->app->Secure->GetGET("cmd");
|
|
|
|
if($cmd === 'dadown')
|
|
{
|
|
$erg['status'] = 0;
|
|
$daid = $this->app->Secure->GetPOST("da_id");
|
|
$check = $this->app->DB->SelectArr("SELECT ds.* FROM datei_stichwoerter ds INNER JOIN datei d on ds.datei = d.id WHERE ds.id = '$daid' and d.geloescht <> 1 LIMIT 1");
|
|
if($check)
|
|
{
|
|
$sort = $check[0]['sort']+1;
|
|
if($sort > 1)
|
|
{
|
|
$check2 = $this->app->DB->SelectArr("SELECT ds.* FROM datei_stichwoerter ds INNER JOIN datei d on ds.datei = d.id WHERE ds.objekt like 'angebot' AND ds.sort = '$sort' AND d.geloescht <> 1 AND ds.parameter = '$id' LIMIT 1");
|
|
if($check2)
|
|
{
|
|
$erg['status'] = 1;
|
|
$erg['from'] = $check2[0]['id'];
|
|
$this->app->DB->Update("UPDATE datei_stichwoerter SET sort = sort + 1 WHERE id = '$daid' LIMIT 1");
|
|
$this->app->DB->Update("UPDATE datei_stichwoerter SET sort = sort - 1 WHERE id = '".$check2[0]['id']."' LIMIT 1");
|
|
}
|
|
}
|
|
}
|
|
echo json_encode($erg);
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
if($cmd === 'daup')
|
|
{
|
|
$erg['status'] = 0;
|
|
$daid = $this->app->Secure->GetPOST("da_id");
|
|
$check = $this->app->DB->SelectArr("SELECT ds.* FROM datei_stichwoerter ds INNER JOIN datei d on ds.datei = d.id WHERE ds.id = '$daid' and d.geloescht <> 1 LIMIT 1");
|
|
if($check)
|
|
{
|
|
$sort = $check[0]['sort']-1;
|
|
if($sort > 0)
|
|
{
|
|
$check2 = $this->app->DB->SelectArr("SELECT ds.* FROM datei_stichwoerter ds INNER JOIN datei d on ds.datei = d.id WHERE ds.objekt like 'gutschrift' AND ds.sort = '$sort' AND d.geloescht <> 1 AND ds.parameter = '$id' LIMIT 1");
|
|
if($check2)
|
|
{
|
|
$erg['status'] = 1;
|
|
$erg['from'] = $check2[0]['id'];
|
|
$this->app->DB->Update("UPDATE datei_stichwoerter SET sort = sort - 1 WHERE id = '$daid' LIMIT 1");
|
|
$this->app->DB->Update("UPDATE datei_stichwoerter SET sort = sort + 1 WHERE id = '".$check2[0]['id']."' LIMIT 1");
|
|
}
|
|
}
|
|
}
|
|
echo json_encode($erg);
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
if($this->app->erp->VertriebAendern('gutschrift',$id,$cmd,$sid)) {
|
|
return;
|
|
}
|
|
if($this->app->erp->InnendienstAendern('gutschrift',$id,$cmd,$sid)){
|
|
return;
|
|
}
|
|
|
|
if($this->app->erp->Firmendaten('modul_verband')!='1') {
|
|
$this->app->Tpl->Set('VERBANDSTART','<!--');
|
|
$this->app->Tpl->Set('VERBANDENDE','-->');
|
|
}
|
|
|
|
if($this->app->erp->DisableModul('gutschrift',$id)) {
|
|
//$this->app->erp->MenuEintrag("index.php?module=auftrag&action=list","Zurück zur Übersicht");
|
|
$this->GutschriftMenu();
|
|
return;
|
|
}
|
|
|
|
$adresse = $this->app->DB->Select("SELECT adresse FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
if($adresse <=0)
|
|
{
|
|
$this->app->Tpl->Add('JAVASCRIPT','$(document).ready(function() { if(document.getElementById("adresse"))document.getElementById("adresse").focus(); });');
|
|
$this->app->Tpl->Set('MESSAGE',"<div class=\"error\">Achtung! Dieses Dokument ist mit keiner Kunden-Nr. verlinkt. Bitte geben Sie die Kundennummer an und klicken Sie übernehmen oder Speichern!</div>");
|
|
}
|
|
$this->app->YUI->AARLGPositionen();
|
|
|
|
$this->app->erp->CheckBearbeiter($id,"gutschrift");
|
|
$this->app->erp->CheckBuchhaltung($id,"gutschrift");
|
|
|
|
|
|
$this->app->erp->GutschriftNeuberechnen($id);
|
|
|
|
$this->app->erp->DisableVerband();
|
|
|
|
//$this->GutschriftMiniDetail(MINIDETAIL,false);
|
|
$this->app->Tpl->Set('ICONMENU',$this->GutschriftIconMenu($id));
|
|
$this->app->Tpl->Set('ICONMENU2',$this->GutschriftIconMenu($id,2));
|
|
|
|
|
|
$belegnr = $this->app->DB->Select("SELECT belegnr FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
$nummer = $this->app->DB->Select("SELECT belegnr FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
$kundennummer = $this->app->DB->Select("SELECT kundennummer FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
$adresse = $this->app->DB->Select("SELECT adresse FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
|
|
|
|
|
|
$status= $this->app->DB->Select("SELECT status FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
$schreibschutz= $this->app->DB->Select("SELECT schreibschutz FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
if($status !== 'angelegt' && $status !== 'angelegta' && $status !== 'a')
|
|
{
|
|
$Brief = new Briefpapier($this->app);
|
|
if($Brief->zuArchivieren($id, 'gutschrift'))
|
|
{
|
|
$this->app->Tpl->Add('MESSAGE',"<div class=\"warning\">Die Gutschrift ist noch nicht archiviert! Bitte versenden oder manuell archivieren. <input type=\"button\" onclick=\"if(!confirm('Soll das Dokument archiviert werden?')) return false;else window.location.href='index.php?module=gutschrift&action=archivierepdf&id=$id';\" value=\"Manuell archivieren\" /> <input type=\"button\" value=\"Dokument versenden\" onclick=\"DokumentAbschicken('gutschrift',$id)\"></div>");
|
|
}
|
|
elseif(!$this->app->DB->Select("SELECT versendet FROM gutschrift WHERE id = '$id' LIMIT 1"))
|
|
{
|
|
$this->app->Tpl->Add('MESSAGE',"<div class=\"warning\">Die Gutschrift wurde noch nicht versendet! <input type=\"button\" onclick=\"if(!confirm('Soll das Dokument archiviert werden?')) return false;else window.location.href='index.php?module=gutschrift&action=archivierepdf&id=$id';\" value=\"Manuell archivieren\" /> <input type=\"button\" value=\"Dokument versenden\" onclick=\"DokumentAbschicken('gutschrift',$id)\"></div>");
|
|
}
|
|
}
|
|
|
|
if($schreibschutz!='1' && $this->app->erp->RechteVorhanden('gutschrift','schreibschutz')){
|
|
$this->app->erp->AnsprechpartnerButton($adresse);
|
|
}
|
|
|
|
if($nummer!='')
|
|
{
|
|
$this->app->Tpl->Set('NUMMER',$nummer);
|
|
if($this->app->erp->RechteVorhanden('adresse','edit')){
|
|
$this->app->Tpl->Set('KUNDE', " Kd-Nr. <a href=\"index.php?module=adresse&action=edit&id=$adresse\" target=\"_blank\">" . $kundennummer . "</a>");
|
|
}
|
|
else{
|
|
$this->app->Tpl->Set('KUNDE', ' Kd-Nr. ' . $kundennummer);
|
|
}
|
|
}
|
|
|
|
$zahlungsweise = $this->app->DB->Select("SELECT zahlungsweise FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
if($this->app->Secure->GetPOST('zahlungsweise')!='') {
|
|
$zahlungsweise = $this->app->Secure->GetPOST('zahlungsweise');
|
|
}
|
|
$zahlungsweise = strtolower($zahlungsweise);
|
|
$this->app->Tpl->Set('RECHNUNG',"none");
|
|
$this->app->Tpl->Set('UEBERWEISUNG',"none");
|
|
$this->app->Tpl->Set('KREDITKARTE',"none");
|
|
$this->app->Tpl->Set('VORKASSE',"none");
|
|
$this->app->Tpl->Set('PAYPAL',"none");
|
|
$this->app->Tpl->Set('EINZUGSERMAECHTIGUNG',"none");
|
|
if($zahlungsweise=="rechnung") $this->app->Tpl->Set('RECHNUNG',"");
|
|
if($zahlungsweise=="paypal") $this->app->Tpl->Set('PAYPAL',"");
|
|
if($zahlungsweise=="ueberweisung") $this->app->Tpl->Set('UEBERWEISUNG',"");
|
|
if($zahlungsweise=="kreditkarte") $this->app->Tpl->Set('KREDITKARTE',"");
|
|
if($zahlungsweise=="einzugsermaechtigung" || $zahlungsweise=="lastschrift") $this->app->Tpl->Set('EINZUGSERMAECHTIGUNG',"");
|
|
if($zahlungsweise=="vorkasse" || $zahlungsweise=="kreditkarte" || $zahlungsweise=="paypal" || $zahlungsweise=="bar") $this->app->Tpl->Set('VORKASSE',"");
|
|
|
|
|
|
|
|
if($schreibschutz=="1" && $this->app->erp->RechteVorhanden("gutschrift","schreibschutz"))
|
|
{
|
|
$this->app->Tpl->Set('MESSAGE',"<div class=\"warning\">Diese Gutschrift 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 Gutschrift wirklich entfernt werden?')) return false;else window.location.href='index.php?module=gutschrift&action=schreibschutz&id=$id';\"></div>");
|
|
// $this->app->erp->CommonReadonly();
|
|
}
|
|
|
|
if($schreibschutz=="1")
|
|
$this->app->erp->CommonReadonly();
|
|
|
|
$rechnungid = $this->app->DB->Select("SELECT rechnungid FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
$rechnungid = $this->app->DB->Select("SELECT id FROM rechnung WHERE id='$rechnungid' AND belegnr!='' LIMIT 1");
|
|
$alle_gutschriften = $this->app->DB->SelectArr("SELECT id,belegnr FROM gutschrift WHERE rechnungid='$rechnungid' AND rechnungid>0");
|
|
|
|
if (!is_null($alle_gutschriften)) {
|
|
if((!empty($alle_gutschriften)?count($alle_gutschriften):0) > 1)
|
|
{
|
|
for($agi=0;$agi<(!empty($alle_gutschriften)?count($alle_gutschriften):0);$agi++)
|
|
$gutschriften .= "<a href=\"index.php?module=gutschrift&action=edit&id=".$alle_gutschriften[$agi][id]."\" target=\"_blank\">".$alle_gutschriften[$agi][belegnr]."</a> ";
|
|
$this->app->Tpl->Add('MESSAGE',"<div class=\"warning\">Für die angebene Rechnung gibt es schon folgende Gutschriften: $gutschriften</div>");
|
|
}
|
|
}
|
|
|
|
|
|
// if($status=="versendet")
|
|
// $this->app->Tpl->Set(MESSAGE,"<div class=\"error\">Diese Gutschrift wurde bereits versendet und darf daher nicht mehr bearbeitet werden!</div>");
|
|
|
|
if($status=="")
|
|
$this->app->DB->Update("UPDATE gutschrift SET status='angelegt' WHERE id='$id' LIMIT 1");
|
|
if($schreibschutz != '1'){
|
|
if($this->app->erp->Firmendaten("schnellanlegen") == "1"){
|
|
$this->app->Tpl->Set('BUTTON_UEBERNEHMEN', ' <input type="button" value="übernehmen" onclick="document.getElementById(\'uebernehmen\').value=1; document.getElementById(\'eprooform\').submit();"/><input type="hidden" id="uebernehmen" name="uebernehmen" value="0">
|
|
');
|
|
}else{
|
|
$this->app->Tpl->Set('BUTTON_UEBERNEHMEN', '
|
|
<input type="button" value="übernehmen" onclick="if(!confirm(\'Soll der neue Kunde wirklich übernommen werden? Es werden alle Felder überladen.\')) return false;else document.getElementById(\'uebernehmen\').value=1; document.getElementById(\'eprooform\').submit();"/><input type="hidden" id="uebernehmen" name="uebernehmen" value="0">
|
|
');
|
|
}
|
|
}
|
|
|
|
// immer wenn sich der lieferant genändert hat standartwerte setzen
|
|
if($this->app->Secure->GetPOST("adresse")!="")
|
|
{
|
|
$tmp = $this->app->Secure->GetPOST("adresse");
|
|
$kundennummer = $this->app->erp->FirstTillSpace($tmp);
|
|
$filter_projekt = $this->app->DB->Select("SELECT projekt FROM gutschrift WHERE id = '$id' LIMIT 1");
|
|
//if($filter_projekt)$filter_projekt = $this->app->DB->Select("SELECT id FROM projekt WHERE id= '$filter_projekt' and eigenernummernkreis = 1 LIMIT 1");
|
|
$name = substr($tmp,6);
|
|
$adresse = $this->app->DB->Select("SELECT id FROM adresse WHERE kundennummer='$kundennummer' AND geloescht=0 ".$this->app->erp->ProjektRechte("projekt", true, 'vertrieb')." ORDER by ".($filter_projekt?" projekt = '$filter_projekt' DESC, ":"")." projekt LIMIT 1");
|
|
|
|
$uebernehmen =$this->app->Secure->GetPOST("uebernehmen");
|
|
if($uebernehmen=="1" && $schreibschutz != '1') // nur neuladen bei tastendruck auf uebernehmen // FRAGEN!!!!
|
|
{
|
|
$this->app->erp->LoadGutschriftStandardwerte($id,$adresse);
|
|
$this->app->erp->GutschriftNeuberechnen($id);
|
|
header("Location: index.php?module=gutschrift&action=edit&id=$id");
|
|
exit;
|
|
}
|
|
}
|
|
|
|
// optional rechnungen als bezahlt markieren wenn es jetzt gutschriften gibt
|
|
|
|
$land = $this->app->DB->Select("SELECT land FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
$ustid = $this->app->DB->Select("SELECT ustid FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
$ust_befreit = $this->app->DB->Select("SELECT ust_befreit FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
if($ust_befreit) {
|
|
$this->app->Tpl->Set('USTBEFREIT',"<div class=\"info\">EU-Lieferung <br>(bereits geprüft!)</div>");
|
|
}
|
|
else if($land!=='DE' && $ustid!='') {
|
|
$this->app->Tpl->Set('USTBEFREIT',"<div class=\"error\">EU-Lieferung <br>(Fehler bei Prüfung!)</div>");
|
|
}
|
|
|
|
|
|
// easy table mit arbeitspaketen YUI als template
|
|
$table = new EasyTable($this->app);
|
|
$table->Query("SELECT bezeichnung as artikel, nummer as Nummer, menge, vpe as VPE, FORMAT(preis,4) as preis FROM gutschrift_position WHERE gutschrift='$id'",0,'');
|
|
$table->DisplayNew('POSITIONEN','Preis','noAction');
|
|
/*
|
|
$table->Query("SELECT nummer as Nummer, menge,vpe as VPE, FORMAT(preis,4) as preis, FORMAT(menge*preis,4) as gesamt
|
|
FROM gutschrift_position
|
|
WHERE gutschrift='$id'");
|
|
$table->DisplayNew(POSITIONEN,"Preis","noAction");
|
|
*/
|
|
$summe = $this->app->DB->Select("SELECT FORMAT(SUM(menge*preis),2) FROM gutschrift_position
|
|
WHERE gutschrift='$id'");
|
|
$waehrung = $this->app->DB->Select("SELECT waehrung FROM gutschrift_position
|
|
WHERE gutschrift='$id' LIMIT 1");
|
|
|
|
if($summe > 0)
|
|
$this->app->Tpl->Add('POSITIONEN', "<br><center>Gesamtsumme: <b>$summe $waehrung</b>
|
|
<a href=\"index.php?module=buchhaltung&action=preview&frame=false\" onclick=\"makeRequest(this);return false\"><img src=\"./themes/new/images/money_preview.png\" border=\"0\"></a></center>");
|
|
|
|
$status= $this->app->DB->Select("SELECT status FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
// $this->app->Tpl->Set(STATUS,"<input type=\"text\" size=\"30\" value=\"".$status."\" readonly>");
|
|
$this->app->Tpl->Set('STATUS',"<input type=\"text\" size=\"30\" value=\"".$status."\" readonly [COMMONREADONLYINPUT]>");
|
|
|
|
$internet = $this->app->DB->Select("SELECT a.internet FROM gutschrift g LEFT JOIN rechnung r ON r.id=g.rechnungid LEFT JOIN auftrag a ON a.id=r.auftragid WHERE g.id='$id' AND g.id > 0 LIMIT 1");
|
|
if($internet!="")
|
|
{
|
|
$this->app->Tpl->Set('INTERNET',"<tr><td>Internet:</td><td><input type=\"text\" size=\"30\" value=\"".$internet."\" readonly [COMMONREADONLYINPUT]></td></tr>");
|
|
}
|
|
|
|
|
|
$this->app->Tpl->Set('AKTIV_TAB1','selected');
|
|
|
|
$sollExtSoll = $this->app->DB->SelectRow(
|
|
sprintf(
|
|
"SELECT extsoll, soll
|
|
FROM gutschrift
|
|
WHERE id = %d AND schreibschutz = 0 AND status = 'versendet' AND extsoll <> 0",
|
|
$id
|
|
)
|
|
);
|
|
if(!empty($sollExtSoll['extsoll']) && $sollExtSoll['extsoll'] == $sollExtSoll['soll']) {
|
|
$sollExtSoll['soll'] = $this->app->DB->Select(
|
|
sprintf(
|
|
'SELECT ROUND(SUM(`umsatz_brutto_gesamt`),2) FROM `gutschrift_position` WHERE `gutschrift` = %d ',
|
|
$id
|
|
)
|
|
);
|
|
}
|
|
|
|
if(!empty($sollExtSoll) && $sollExtSoll['soll'] != $sollExtSoll['extsoll']) {
|
|
$extsoll = $sollExtSoll['extsoll'];
|
|
$this->app->Tpl->Add(
|
|
'MESSAGE','<form method="post"><div class="error">
|
|
Der Sollbetrag stimmt nicht mehr mit ursprünglich festgelegten Betrag '.
|
|
number_format($extsoll,2,',','.').
|
|
' überein <input type="submit" name="resetextsoll" value="Festgeschriebene Summe zurücksetzen" /></div></form>'
|
|
);
|
|
}
|
|
|
|
parent::GutschriftEdit();
|
|
if($id > 0 && $this->app->DB->Select(
|
|
sprintf(
|
|
'SELECT id FROM gutschrift WHERE schreibschutz =1 AND zuarchivieren = 1 AND id = %d',
|
|
$id
|
|
)
|
|
)
|
|
) {
|
|
$this->app->erp->PDFArchivieren('gutschrift', $id, true);
|
|
}
|
|
$this->app->erp->MessageHandlerStandardForm();
|
|
|
|
|
|
if($this->app->Secure->GetPOST('weiter')!='') {
|
|
$this->app->Location->execute('index.php?module=gutschrift&action=positionen&id='.$id);
|
|
}
|
|
$this->GutschriftMenu();
|
|
}
|
|
|
|
public function GutschriftCreate()
|
|
{
|
|
$this->app->erp->MenuEintrag('index.php?module=gutschrift&action=list','Zurück zur Übersicht');
|
|
|
|
$anlegen = $this->app->Secure->GetGET('anlegen');
|
|
|
|
if($anlegen!='1' && $this->app->erp->Firmendaten('schnellanlegen')=='1') {
|
|
$this->app->Location->execute('index.php?module=gutschrift&action=create&anlegen=1');
|
|
}
|
|
|
|
if($anlegen != '') {
|
|
$id = $this->app->erp->CreateGutschrift();
|
|
$this->app->Location->execute('index.php?module=gutschrift&action=edit&id='.$id);
|
|
}
|
|
$this->app->Tpl->Set('MESSAGE',"<div class=\"warning\">Möchten Sie eine Gutschrift jetzt anlegen?
|
|
<input type=\"button\" onclick=\"window.location.href='index.php?module=gutschrift&action=create&anlegen=1'\" value=\"Ja - Gutschrift jetzt anlegen\"></div><br>");
|
|
$this->app->Tpl->Set('TAB1',"
|
|
<table width=\"100%\" style=\"background-color: #fff; border: solid 1px #000;\" align=\"center\">
|
|
<tr>
|
|
<td align=\"center\">
|
|
<br><b style=\"font-size: 14pt\">Gutschriften in Bearbeitung</b>
|
|
<br>
|
|
<br>
|
|
Offene Aufträge, die durch andere Mitarbeiter in Bearbeitung sind.
|
|
<br>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
<br>
|
|
[AUFTRAGE]");
|
|
|
|
|
|
$this->app->Tpl->Set('AKTIV_TAB1',"selected");
|
|
$table = new EasyTable($this->app);
|
|
$table->Query("SELECT DATE_FORMAT(datum,'%d.%m.%y') as vom, if(belegnr!='',belegnr,'ohne Nummer') as beleg, name, status, id
|
|
FROM gutschrift WHERE status='angelegt' order by datum DESC, id DESC");
|
|
$table->DisplayNew('AUFTRAGE', "<a href=\"index.php?module=gutschrift&action=edit&id=%value%\"><img border=\"0\" src=\"./themes/new/images/edit.svg\"></a>
|
|
<a onclick=\"if(!confirm('Wirklich löschen?')) return false; else window.location.href='index.php?module=gutschrift&action=delete&id=%value%';\">
|
|
<img src=\"./themes/new/images/delete.svg\" border=\"0\"></a>
|
|
<a onclick=\"if(!confirm('Wirklich kopieren?')) return false; else window.location.href='index.php?module=gutschrift&action=copy&id=%value%';\">
|
|
<img src=\"./themes/new/images/copy.svg\" border=\"0\"></a>
|
|
");
|
|
|
|
$this->app->Tpl->Set('TABTEXT','Gutschrift anlegen');
|
|
$this->app->Tpl->Parse('PAGE','tabview.tpl');
|
|
}
|
|
|
|
|
|
public function GutschriftList()
|
|
{
|
|
$this->app->Tpl->Set('UEBERSCHRIFT', 'Gutschriften');
|
|
|
|
if($this->app->Secure->GetPOST('ausfuehren') && $this->app->erp->RechteVorhanden('gutschrift', 'edit')) {
|
|
$drucker = $this->app->Secure->GetPOST('seldrucker');
|
|
$aktion = $this->app->Secure->GetPOST('sel_aktion');
|
|
$auswahl = $this->app->Secure->GetPOST('auswahl');
|
|
if($drucker > 0) {
|
|
$this->app->erp->BriefpapierHintergrundDisable($drucker);
|
|
}
|
|
if(is_array($auswahl)) {
|
|
$ids = [];
|
|
foreach($auswahl as $id) {
|
|
$id = (int)$id;
|
|
if($id > 0) {
|
|
$ids[] = $id;
|
|
}
|
|
}
|
|
$ids = array_unique($ids);
|
|
|
|
switch($aktion) {
|
|
case 'erledigtam':
|
|
if(!empty($ids)){
|
|
$this->app->DB->Update(
|
|
sprintf(
|
|
"UPDATE `gutschrift`
|
|
SET `manuell_vorabbezahlt`=CURDATE(),
|
|
`manuell_vorabbezahlt_hinweis`=CONCAT(`manuell_vorabbezahlt_hinweis`,'\r\n','Erledigt am manuell auf %s gesetzt')
|
|
WHERE `id` IN (%s)",
|
|
date('d.m.Y'), implode(',', $ids)
|
|
)
|
|
);
|
|
}
|
|
break;
|
|
case 'offen':
|
|
if(!empty($ids)) {
|
|
$this->app->DB->Update(
|
|
sprintf(
|
|
"UPDATE `gutschrift`
|
|
SET `manuell_vorabbezahlt` = NULL,
|
|
`manuell_vorabbezahlt_hinweis`=CONCAT(`manuell_vorabbezahlt_hinweis`,'\r\n','Erledigt am manuell zurückgesetzt am %s')
|
|
WHERE `id` IN (%s)",
|
|
date('d.m.Y'), implode(',', $ids)
|
|
)
|
|
);
|
|
}
|
|
break;
|
|
case 'mail':
|
|
$returnOrders = empty($ids)?[]:$this->app->DB->SelectArr(
|
|
sprintf(
|
|
"SELECT * FROM `gutschrift` WHERE `id` IN (%s)",
|
|
implode(',', $ids)
|
|
)
|
|
);
|
|
if(empty($returnOrders)) {
|
|
$returnOrders = [];
|
|
}
|
|
foreach($returnOrders as $returnOrder) {
|
|
$v = $returnOrder['id'];
|
|
$email = (string)$returnOrder['email'];
|
|
$adresse = $returnOrder['adresse'];
|
|
$projekt = $returnOrder['projekt'];
|
|
$name = $returnOrder['name'];
|
|
$sprache = $returnOrder['sprache'];
|
|
if($sprache=='' && $adresse > 0){
|
|
$sprache = $this->app->DB->Select(
|
|
sprintf(
|
|
'SELECT `sprache` FROM `adresse` WHERE `id`= %d AND `geloescht` = 0 LIMIT 1',
|
|
$adresse
|
|
)
|
|
);
|
|
}
|
|
|
|
if($sprache=='') {
|
|
$sprache='de';
|
|
}
|
|
|
|
$emailtext = $this->app->erp->Geschaeftsbriefvorlage($sprache,'gutschrift',$projekt,$name,$v);
|
|
|
|
if($email === '' && $adresse > 0) {
|
|
$email = (string)$this->app->DB->Select(
|
|
sprintf(
|
|
"SELECT `email` FROM `adresse` WHERE `id` = %d LIMIT 1",
|
|
$adresse
|
|
)
|
|
);
|
|
}
|
|
if($email !== '') {
|
|
$this->app->erp->BriefpapierHintergrunddisable = !$this->app->erp->BriefpapierHintergrunddisable;
|
|
if(class_exists('GutschriftPDFCustom')) {
|
|
$Brief = new GutschriftPDFCustom($this->app,$projekt);
|
|
}
|
|
else{
|
|
$Brief = new GutschriftPDF($this->app,$projekt);
|
|
}
|
|
$Brief->GetGutschrift($v);
|
|
$_tmpfile = $Brief->displayTMP();
|
|
$Brief->ArchiviereDocument();
|
|
unlink($_tmpfile);
|
|
$this->app->erp->BriefpapierHintergrunddisable = !$this->app->erp->BriefpapierHintergrunddisable;
|
|
if(class_exists('GutschriftPDFCustom')) {
|
|
$Brief = new GutschriftPDFCustom($this->app,$projekt);
|
|
}
|
|
else{
|
|
$Brief = new GutschriftPDF($this->app,$projekt);
|
|
}
|
|
$Brief->GetGutschrift($v);
|
|
$tmpfile = $Brief->displayTMP();
|
|
$Brief->ArchiviereDocument();
|
|
|
|
$fileid = $this->app->erp->CreateDatei(
|
|
$Brief->filename,'gutschrift','','',$tmpfile,$this->app->User->GetName()
|
|
);
|
|
$this->app->erp->AddDateiStichwort($fileid,'gutschrift','gutschrift',$v);
|
|
$this->app->erp->DokumentSend(
|
|
$adresse,'gutschrift', $v, 'email',$emailtext['betreff'],$emailtext['text'],
|
|
[$tmpfile],'','',$projekt,$email, $name
|
|
);
|
|
$ansprechpartner = $name.' <'.$email.'>';
|
|
$this->app->DB->Insert("INSERT INTO dokumente_send
|
|
(id,dokument,zeit,bearbeiter,adresse,parameter,art,betreff,text,projekt,ansprechpartner,versendet,dateiid)
|
|
VALUES ('','gutschrift',NOW(),'".$this->app->DB->real_escape_string($this->app->User->GetName())."',
|
|
'$adresse','$v','email','$betreff','$text','$projekt','$ansprechpartner',1,'$fileid')");
|
|
$tmpid = $this->app->DB->GetInsertID();
|
|
unlink($tmpfile);
|
|
$this->app->DB->Update("UPDATE gutschrift SET versendet=1, versendet_am=NOW(),
|
|
versendet_per='email',versendet_durch='".$this->app->DB->real_escape_string($this->app->User->GetName())."',schreibschutz='1' WHERE id='$v' LIMIT 1");
|
|
$this->app->erp->GutschriftProtokoll($v,'Gutschrift versendet');
|
|
}
|
|
}
|
|
break;
|
|
case 'versendet':
|
|
$returnOrders = empty($ids)?[]: $this->app->DB->SelectPairs(
|
|
sprintf(
|
|
'SELECT `id`, `projekt` FROM `gutschrift` WHERE `id` IN (%s)',
|
|
implode(',', $ids)
|
|
)
|
|
);
|
|
foreach($returnOrders as $returnOrderId => $projectId) {
|
|
if(class_exists('GutschriftPDFCustom')) {
|
|
$Brief = new GutschriftPDFCustom($this->app,$projectId);
|
|
}
|
|
else{
|
|
$Brief = new GutschriftPDF($this->app,$projectId);
|
|
}
|
|
$Brief->GetGutschrift($returnOrderId);
|
|
$tmpfile = $Brief->displayTMP();
|
|
$Brief->ArchiviereDocument();
|
|
$this->app->erp->GutschriftProtokoll($returnOrderId, 'Gutschrift versendet');
|
|
$this->app->DB->Update(
|
|
sprintf(
|
|
"UPDATE `gutschrift`
|
|
SET `schreibschutz`=1, `versendet` = 1, `status`='versendet'
|
|
WHERE `id` = %d
|
|
LIMIT 1",
|
|
$returnOrderId
|
|
)
|
|
);
|
|
@unlink($tmpfile);
|
|
}
|
|
break;
|
|
case 'drucken':
|
|
if($drucker && !empty($ids)) {
|
|
$returnOrders = $this->app->DB->SelectPairs(
|
|
sprintf(
|
|
'SELECT `id`, `projekt` FROM `gutschrift` WHERE `id` IN (%s)',
|
|
implode(',', $ids)
|
|
)
|
|
);
|
|
foreach($returnOrders as $returnOrderId => $projekt) {
|
|
if(class_exists('GutschriftPDFCustom')) {
|
|
$Brief = new GutschriftPDFCustom($this->app,$projekt);
|
|
}
|
|
else{
|
|
$Brief = new GutschriftPDF($this->app,$projekt);
|
|
}
|
|
$Brief->GetGutschrift($returnOrderId);
|
|
$tmpfile = $Brief->displayTMP();
|
|
$Brief->ArchiviereDocument();
|
|
$this->app->printer->Drucken($drucker,$tmpfile);
|
|
$doctype = 'gutschrift';
|
|
$adressId = $this->app->DB->Select("SELECT adresse FROM gutschrift WHERE id = '$returnOrderId' LIMIT 1");
|
|
$this->app->erp->RunHook('dokumentsend_ende', 5, $doctype, $returnOrderId, $projekt, $adressId, $aktion);
|
|
$this->app->erp->GutschriftProtokoll($returnOrderId,'Gutschrift versendet');
|
|
$this->app->DB->Update(
|
|
sprintf(
|
|
"UPDATE `gutschrift`
|
|
SET `schreibschutz` = 1, `versendet` = 1, `status`='versendet'
|
|
WHERE `id` = %d
|
|
LIMIT 1",
|
|
$returnOrderId
|
|
)
|
|
);
|
|
}
|
|
}
|
|
break;
|
|
case 'pdf':
|
|
$tmpfile = [];
|
|
$returnOrders = empty($ids)?[]: $this->app->DB->SelectPairs(
|
|
sprintf(
|
|
'SELECT `id`, `projekt` FROM `gutschrift` WHERE `id` IN (%s)',
|
|
implode(',', $ids)
|
|
)
|
|
);
|
|
foreach($returnOrders as $returnOrderId => $projectId) {
|
|
if(class_exists('GutschriftPDFCustom')) {
|
|
$Brief = new GutschriftPDFCustom($this->app,$projectId);
|
|
}
|
|
else{
|
|
$Brief = new GutschriftPDF($this->app,$projectId);
|
|
}
|
|
$Brief->GetGutschrift($returnOrderId);
|
|
$tmpfile[] = $Brief->displayTMP();
|
|
}
|
|
|
|
if((!empty($tmpfile)?count($tmpfile):0) > 0) {
|
|
try {
|
|
/** @var PdfMerger $pdfMerger */
|
|
$pdfMerger = $this->app->Container->get('PdfMerger');
|
|
$mergeOutputPath = realpath($this->app->erp->GetTMP()) . '/' . uniqid('sammelpdf_', true) . '.pdf';
|
|
$pdfMerger->merge($tmpfile, $mergeOutputPath);
|
|
|
|
foreach($tmpfile as $key=>$value) {
|
|
unlink($value);
|
|
}
|
|
|
|
header('Content-type:application/pdf');
|
|
header('Content-Disposition: attachment;filename='.md5(microtime(true)).'.pdf');
|
|
readfile($mergeOutputPath);
|
|
$this->app->ExitXentral();
|
|
} catch (PdfComponentExceptionInterface $exception) {
|
|
echo 'Fehler beim Generieren der Sammelpdf: ' . htmlspecialchars($exception->getMessage());
|
|
$this->app->ExitXentral();
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
$backurl = $this->app->Secure->GetGET('backurl');
|
|
$backurl = $this->app->erp->base64_url_decode($backurl);
|
|
|
|
$this->app->erp->MenuEintrag('index.php?module=gutschrift&action=list','Übersicht');
|
|
$this->app->erp->MenuEintrag('index.php?module=gutschrift&action=create','Neue Gutschrift anlegen');
|
|
|
|
if(strlen($backurl)>5){
|
|
$this->app->erp->MenuEintrag((string)$backurl, 'Zurück zur Übersicht');
|
|
}
|
|
else{
|
|
$this->app->erp->MenuEintrag('index.php', 'Zurück zur Übersicht');
|
|
}
|
|
|
|
$zahlungsweisen = $this->app->DB->SelectArr('
|
|
SELECT `zahlungsweise`
|
|
FROM `gutschrift`
|
|
GROUP BY `zahlungsweise`
|
|
');
|
|
|
|
$zahlungsweiseStr = '';
|
|
if ($zahlungsweisen) {
|
|
foreach ($zahlungsweisen as $zahlungsweise) {
|
|
if (empty($zahlungsweise['zahlungsweise'])) {
|
|
continue;
|
|
}
|
|
$zahlungsweiseStr .= '<option name="' . $zahlungsweise['zahlungsweise'] . '">' . ucfirst($zahlungsweise['zahlungsweise']) . '</option>';
|
|
}
|
|
}
|
|
|
|
$status = $this->app->DB->SelectArr('
|
|
SELECT status
|
|
FROM gutschrift
|
|
GROUP BY status
|
|
');
|
|
|
|
$statusStr = '';
|
|
if ($status) {
|
|
foreach ($status as $statusE) {
|
|
if (empty($statusE['status'])) {
|
|
continue;
|
|
}
|
|
$statusStr .= '<option name="' . $statusE['status'] . '">' . ucfirst($statusE['status']) . '</option>';
|
|
}
|
|
}
|
|
|
|
$versandarten = $this->app->DB->SelectArr('
|
|
SELECT versandart
|
|
FROM gutschrift
|
|
GROUP BY versandart
|
|
');
|
|
|
|
$versandartenStr = '';
|
|
if ($versandarten) {
|
|
foreach ($versandarten as $versandart) {
|
|
if (empty($versandart['versandart'])) {
|
|
continue;
|
|
}
|
|
$versandartenStr .= '<option name="' . $versandart['versandart'] . '">' . ucfirst($versandart['versandart'])
|
|
. '</option>';
|
|
}
|
|
}
|
|
|
|
$laender = $this->app->erp->GetSelectLaenderliste();
|
|
$laenderStr = '';
|
|
foreach ($laender as $landKey => $land) {
|
|
$laenderStr .= '<option value="' . $landKey . '">' . $land . '</option>';
|
|
}
|
|
|
|
$this->app->YUI->DatePicker('datumVon');
|
|
$this->app->YUI->DatePicker('datumBis');
|
|
$this->app->YUI->AutoComplete('projekt', 'projektname', 1);
|
|
$this->app->YUI->AutoComplete('kundennummer', 'kunde', 1);
|
|
$this->app->YUI->AutoComplete('gutschriftnummer', 'gutschrift', 1);
|
|
$this->app->YUI->AutoComplete('artikel', 'artikelnummer', 1);
|
|
|
|
$this->app->Tpl->Add('ZAHLUNGSWEISEN',$zahlungsweiseStr);
|
|
$this->app->Tpl->Add('STATUS',$statusStr);
|
|
$this->app->Tpl->Add('VERSANDARTEN',$versandartenStr);
|
|
$this->app->Tpl->Add('LAENDER',$laenderStr);
|
|
$this->app->Tpl->Parse('TAB1','gutschrift_table_filter.tpl');
|
|
|
|
$this->app->Tpl->Set('AKTIV_TAB1','selected');
|
|
$this->app->Tpl->Set('INHALT','');
|
|
|
|
$this->app->YUI->TableSearch('TAB2','gutschriftenoffene');
|
|
$this->app->YUI->TableSearch('TAB1','gutschriften');
|
|
$this->app->YUI->TableSearch('TAB3','gutschrifteninbearbeitung');
|
|
|
|
$this->app->Tpl->Set(
|
|
'SELDRUCKER',
|
|
$this->app->erp->GetSelectDrucker($this->app->User->GetParameter('rechnung_list_drucker'))
|
|
);
|
|
|
|
$this->app->Tpl->Parse('PAGE','gutschriftuebersicht.tpl');
|
|
}
|
|
|
|
/**
|
|
* @param int $id
|
|
*
|
|
* @return int|string|null
|
|
*/
|
|
public function CopyGutschrift($id)
|
|
{
|
|
$this->app->DB->Insert('INSERT INTO gutschrift (id) VALUES (NULL)');
|
|
$newid = $this->app->DB->GetInsertID();
|
|
$arr = $this->app->DB->SelectRow("SELECT NOW() as datum,projekt,bodyzusatz,freitext,adresse,name,abteilung,unterabteilung,strasse,adresszusatz,plz,ort,land,ustid,email,telefon,telefax,betreff,kundennummer, bearbeiter,zahlungszieltage,zahlungszieltageskonto,zahlungsweise,ohne_artikeltext,ohne_briefpapier,'angelegt' as status,typ,
|
|
zahlungszielskonto,ust_befreit,rabatt,rabatt1,rabatt2,rabatt3,rabatt4,rabatt5,gruppe,vertriebid,bearbeiterid,provision,provision_summe,sprache,anzeigesteuer,waehrung,kurs,kostenstelle,
|
|
firma FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
$this->app->DB->LogIfError();
|
|
$arr['kundennummer'] = $this->app->DB->Select("SELECT kundennummer FROM adresse WHERE id = '".$arr['adresse']."' LIMIT 1");
|
|
$arr['bundesstaat'] = $this->app->DB->Select("SELECT bundesstaat FROM gutschrift WHERE id='$id' LIMIT 1");
|
|
$this->app->DB->UpdateArr('gutschrift',$newid,'id',$arr, true);
|
|
$pos = $this->app->DB->SelectArr("SELECT * FROM gutschrift_position WHERE gutschrift='$id'");
|
|
$cpos = !empty($pos)?count($pos):0;
|
|
for($i=0;$i<$cpos;$i++){
|
|
$this->app->DB->Insert("INSERT INTO gutschrift_position (gutschrift) VALUES ($newid)");
|
|
$newposid = $this->app->DB->GetInsertID();
|
|
$pos[$i]['gutschrift']=$newid;
|
|
$this->app->DB->UpdateArr('gutschrift_position',$newposid,'id',$pos[$i], true);
|
|
if(is_null($pos[$i]['steuersatz'])){
|
|
$this->app->DB->Update("UPDATE gutschrift_position SET steuersatz = null WHERE id = '$newposid' LIMIT 1");
|
|
}
|
|
}
|
|
$this->app->erp->CheckFreifelder('gutschrift',$newid);
|
|
$this->app->erp->CopyBelegZwischenpositionen('gutschrift',$id,'gutschrift',$newid);
|
|
$this->app->erp->LoadSteuersaetzeWaehrung($newid,'gutschrift');
|
|
|
|
return $newid;
|
|
}
|
|
|
|
/**
|
|
* @param int $id
|
|
* @param int $adresse
|
|
*/
|
|
public function LoadGutschriftStandardwerte($id,$adresse)
|
|
{
|
|
if($id==0 || $id=='' || $adresse=='' || $adresse=='0') {
|
|
return;
|
|
}
|
|
|
|
// standard adresse von lieferant
|
|
$arr = $this->app->DB->SelectRow(
|
|
sprintf(
|
|
"SELECT adr.*,adr.vertrieb as vertriebid, '' as bearbeiter, adr.innendienst as bearbeiterid
|
|
FROM `adresse` AS `adr`
|
|
WHERE adr.id= %d AND adr.geloescht=0
|
|
LIMIT 1",
|
|
$adresse
|
|
)
|
|
);
|
|
|
|
if($arr['bearbeiterid'] <=0 ){
|
|
$arr['bearbeiterid'] = $this->app->User->GetAdresse();
|
|
}
|
|
|
|
$arr['gruppe'] = $this->app->erp->GetVerband($adresse);
|
|
|
|
$rolle_projekt = $this->app->DB->Select(
|
|
sprintf(
|
|
"SELECT ar.parameter
|
|
FROM `adresse_rolle` AS `ar`
|
|
WHERE ar.adresse= %d
|
|
AND ar.subjekt='Kunde' AND ar.objekt='Projekt'
|
|
AND (IFNULL(ar.bis,'0000-00-00') ='0000-00-00' OR ar.bis <= CURDATE())
|
|
LIMIT 1",
|
|
$adresse
|
|
)
|
|
);
|
|
|
|
if($rolle_projekt > 0) {
|
|
$arr['projekt'] = $rolle_projekt;
|
|
}
|
|
|
|
$field = [
|
|
'gln','anschreiben','name','abteilung','unterabteilung','strasse','adresszusatz','plz','ort','land','ustid',
|
|
'email','telefon','telefax','kundennummer','projekt','ust_befreit','gruppe','typ','vertriebid','bearbeiter',
|
|
'ansprechpartner','bearbeiterid','titel','lieferbedingung'
|
|
];
|
|
foreach($field as $key=>$value) {
|
|
if($value ==='projekt' && $this->app->Secure->POST[$value]!='' && 0) {
|
|
$uparr[$value] = str_replace("'", ''',$this->app->Secure->POST[$value]);
|
|
}
|
|
else {
|
|
$this->app->Secure->POST[$value] = str_replace("'", ''',$arr[$value]);
|
|
$uparr[$value] = str_replace("'", ''',$arr[$value]);
|
|
}
|
|
}
|
|
|
|
$uparr['adresse'] = $adresse;
|
|
$uparr['ust_befreit'] = $this->app->erp->AdresseUSTCheck($adresse);
|
|
$uparr['zahlungsstatusstatus']='offen';
|
|
|
|
$this->app->DB->UpdateArr('gutschrift',$id,'id',$uparr,true);
|
|
$uparr=null;
|
|
|
|
//liefernantenvorlage
|
|
$arr = $this->app->DB->SelectRow("SELECT * FROM adresse WHERE id='$adresse' LIMIT 1");
|
|
$field = array('zahlungsweise','zahlungszieltage','zahlungszieltageskonto','zahlungszielskonto','versandart');
|
|
|
|
// falls von Benutzer projekt ueberladen werden soll
|
|
$projekt_bevorzugt=$this->app->DB->Select("SELECT projekt_bevorzugen FROM user WHERE id='".$this->app->User->GetID()."' LIMIT 1");
|
|
if($projekt_bevorzugt=='1') {
|
|
$uparr['projekt'] = $this->app->DB->Select("SELECT projekt FROM user WHERE id='".$this->app->User->GetID()."' LIMIT 1");
|
|
$arr['projekt'] = $uparr['projekt'];
|
|
$this->app->Secure->POST['projekt']=$this->app->DB->Select("SELECT abkuerzung FROM projekt WHERE id='".$arr['projekt']."' AND id > 0 LIMIT 1");
|
|
}
|
|
|
|
$this->app->erp->LoadZahlungsweise($adresse,$arr);
|
|
|
|
$this->app->Secure->POST['zahlungsweise'] = strtolower($arr['zahlungsweise']);
|
|
$this->app->Secure->POST['zahlungszieltage'] = strtolower($arr['zahlungszieltage']);
|
|
$this->app->Secure->POST['zahlungszieltageskonto'] = strtolower($arr['zahlungszieltageskonto']);
|
|
$this->app->Secure->POST['zahlungszielskonto'] = strtolower($arr['zahlungszielskonto']);
|
|
$this->app->Secure->POST['versandart'] = strtolower($arr['versandart']);
|
|
|
|
if(isset($arr['usereditid'])){
|
|
unset($arr['usereditid']);
|
|
}
|
|
|
|
// Enter the correct billing address into the credit note data before it gets saved.
|
|
$arr = $this->app->Container->get('CreditNoteAddressService')->applyBillingAddressToCreditNoteArray($id, $arr);
|
|
|
|
$this->app->DB->UpdateArr('gutschrift',$id,'id',$arr,true);
|
|
$this->app->erp->LoadSteuersaetzeWaehrung($id,'gutschrift');
|
|
$this->app->erp->LoadAdresseStandard('gutschrift',$id,$adresse);
|
|
}
|
|
|
|
/**
|
|
* @param int $id
|
|
*
|
|
* @return int|mixed
|
|
*/
|
|
public function GutschriftSaldo($id)
|
|
{
|
|
if($id <= 0) {
|
|
return 0;
|
|
}
|
|
|
|
$rechnungid = $this->app->DB->Select(
|
|
sprintf(
|
|
'SELECT `rechnungid` FROM `gutschrift` WHERE `id`= %d LIMIT 1',
|
|
$id
|
|
)
|
|
);
|
|
$auftragid = $rechnungid <= 0?0:$this->app->DB->Select(
|
|
sprintf(
|
|
'SELECT `auftragid` FROM `rechnung` WHERE `id`=%d LIMIT 1',
|
|
$rechnungid
|
|
)
|
|
);
|
|
|
|
$eingangArr = $this->app->DB->SelectArr(
|
|
sprintf(
|
|
"SELECT ko.bezeichnung as konto, DATE_FORMAT(ke.datum,'%%d.%%m.%%Y') as datum, k.id as kontoauszuege, ke.betrag as betrag
|
|
FROM `kontoauszuege_zahlungseingang` AS `ke`
|
|
LEFT JOIN `kontoauszuege` AS `k` ON ke.kontoauszuege=k.id
|
|
LEFT JOIN `konten` AS `ko` ON k.konto=ko.id
|
|
WHERE (ke.objekt='gutschrift' AND ke.parameter=%d)
|
|
OR (ke.objekt='auftrag' AND ke.parameter=%d AND ke.parameter>0)
|
|
OR (ke.objekt='rechnung' AND ke.parameter=%d AND ke.parameter>0)",
|
|
$id, $auftragid, $rechnungid
|
|
)
|
|
);
|
|
$einnahmen = 0;
|
|
if(!empty($eingangArr)) {
|
|
foreach($eingangArr AS $eingangRow) {
|
|
$einnahmen += $eingangRow['betrag'];
|
|
}
|
|
}
|
|
|
|
//$gutschriften = $this->app->DB->SelectArr("SELECT belegnr, DATE_FORMAT(datum,'%d.%m.%Y') as datum,soll FROM gutschrift WHERE rechnungid='$id' "); // alt
|
|
$gutschriften = $this->app->DB->SelectArr(
|
|
sprintf(
|
|
"SELECT ro.belegnr, DATE_FORMAT(ro.datum,'%%d.%%m.%%Y') as datum, ro.soll
|
|
FROM `gutschrift` AS `ro`
|
|
WHERE ro.`id` = %d ",
|
|
$id
|
|
)
|
|
);
|
|
|
|
if(!empty($gutschriften)) {
|
|
foreach($gutschriften as $gutschriftRow) {
|
|
$einnahmen += $gutschriftRow['soll'];
|
|
}
|
|
}
|
|
|
|
$ausgangArr = $this->app->DB->SelectArr(
|
|
sprintf(
|
|
"SELECT ko.bezeichnung as konto, DATE_FORMAT(ke.datum,'%%d.%%m') as datum, ke.betrag as betrag
|
|
FROM kontoauszuege_zahlungsausgang ke
|
|
LEFT JOIN kontoauszuege k ON ke.kontoauszuege=k.id
|
|
LEFT JOIN konten ko ON k.konto=ko.id
|
|
WHERE (ke.objekt='gutschrift' AND ke.parameter=%d)
|
|
OR (ke.objekt='rechnung' AND ke.parameter=%d AND ke.parameter>0)
|
|
OR (ke.objekt='auftrag' AND ke.parameter=%d AND ke.parameter>0)",
|
|
$id, $rechnungid, $auftragid
|
|
)
|
|
);
|
|
$ausgaben = 0;
|
|
if(!empty($ausgangArr)){
|
|
foreach($ausgangArr as $ausgangRow) {
|
|
$ausgaben += $ausgangRow['betrg'];
|
|
}
|
|
}
|
|
|
|
return $einnahmen - $ausgaben;
|
|
}
|
|
}
|