mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2024-11-16 13:07:14 +01:00
6573 lines
263 KiB
PHP
6573 lines
263 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
|
|
include '_gen/adresse.php';
|
|
|
|
class Adresse extends GenAdresse {
|
|
/** @var Application $app */
|
|
var $app;
|
|
const MODULE_NAME = 'Address';
|
|
|
|
/**
|
|
* @param Application $app
|
|
* @param string $name
|
|
* @param array $erlaubtevars
|
|
*
|
|
* @return array
|
|
*/
|
|
public static function TableSearch($app, $name, $erlaubtevars)
|
|
{
|
|
$id = $app->Secure->GetGET('id');
|
|
switch($name)
|
|
{
|
|
case 'lieferantartikel':
|
|
$allowed['adresse'] = array('lieferantartikel');
|
|
|
|
// START EXTRA checkboxen
|
|
$app->Tpl->Add('JQUERYREADY', "$('#offen').on('click', function() { fnFilterColumn1( 0 ); } );");
|
|
for ($r = 1;$r < 2;$r++) {
|
|
$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
|
|
);
|
|
}
|
|
');
|
|
}
|
|
|
|
// headings
|
|
$heading = array('Nummer', 'Artikel', 'Verkauf', 'LA', 'AB', 'BE', 'Reserv.', 'Fehlende', 'Gesamt', 'aktueller Monate', 'letzter Monat', 'Status', 'Menü');
|
|
$width = array('5%', '40%', '5%', '5%', '5%', '5%', '5%', '5%', '5%', '5%', '5%', '5%', '15%');
|
|
|
|
$findcols = array('nummer', 'name_de', 'verkauf', 'CAST(`lager` as SIGNED)', 'CAST(`offen` as SIGNED)', 'CAST(`bestellung` as SIGNED)', 'CAST(`res` as SIGNED)', 'CAST(`fehlende` as SIGNED)', 'CAST(`gesamt` as SIGNED)', 'CAST(`monat` as SIGNED)', 'CAST(`monat_last` as SIGNED)', 'status', 'id');
|
|
|
|
$searchsql = array('a.name_de', "IFNULL((SELECT e.bestellnummer FROM einkaufspreise e WHERE e.artikel=a.id AND e.adresse='$id' AND e.geloescht!=1 AND e.bestellnummer!='' LIMIT 1),'')", 'a.nummer');
|
|
$menu = "<a href=\"index.php?module=artikel&action=edit&id=%value%\"><img src=\"themes/{$app->Conf->WFconf['defaulttheme']}/images/edit.svg\" border=\"0\"></a>" . " <a href=\"#\" onclick=DeleteDialog(\"index.php?module=artikel&action=delete&id=%value%\");><img src=\"themes/{$app->Conf->WFconf['defaulttheme']}/images/delete.svg\" border=\"0\"></a>" . " <a href=\"#\" onclick=CopyDialog(\"index.php?module=artikel&action=copy&id=%value%\");><img src=\"themes/{$app->Conf->WFconf['defaulttheme']}/images/copy.svg\" border=\"0\"></a>";
|
|
$aktuellermonat = $app->DB->Select("SELECT CONCAT(YEAR(NOW()),'-',MONTH(NOW()))");
|
|
$letztermonat = $app->DB->Select("SELECT CONCAT(YEAR( DATE_SUB( NOW() , INTERVAL 1 MONTH )),'-',DATE_FORMAT( DATE_SUB( NOW() , INTERVAL 1 MONTH ) ,'%m'))");
|
|
$alignright = array(4,5,6,7,8,9,10,11);
|
|
// SQL statement
|
|
$sql = "SELECT SQL_CALC_FOUND_ROWS a.id, a.nummer as nummer,
|
|
|
|
CONCAT(if( (SELECT SUM(ap.menge) FROM auftrag_position ap LEFT JOIN auftrag auf ON auf.id=ap.auftrag WHERE ap.artikel=a.id AND auf.status='freigegeben') > IFNULL((SELECT SUM(l.menge) FROM lager_platz_inhalt l WHERE l.artikel=a.id),0) + IFNULL((SELECT SUM(bp.menge-bp.geliefert) FROM bestellung_position bp LEFT JOIN bestellung b ON b.id=bp.bestellung WHERE bp.artikel=a.id AND b.status='versendet'),0)
|
|
|
|
, CONCAT('<font color=red><b>',a.name_de,'</b></font>'),a.name_de),'<br>Best-Nr.:',IFNULL((SELECT e.bestellnummer FROM einkaufspreise e WHERE e.artikel=a.id AND e.adresse='$id' AND e.geloescht!=1 AND e.bestellnummer!='' ORDER by e.id DESC LIMIT 1),'-'),'<br>Letzter EK-Preis: ',IFNULL((SELECT ".$app->erp->FormatPreis("e.preis",2)." FROM einkaufspreise e WHERE e.artikel=a.id AND (e.gueltig_bis > NOW() OR e.gueltig_bis='0000-00-00') AND e.geloescht!=1 AND e.preis >= 0 ORDER by e.id DESC LIMIT 1),''),' ab Menge ',IFNULL((SELECT ".$app->erp->FormatMenge("e.ab_menge")." FROM einkaufspreise e WHERE e.artikel=a.id AND (e.gueltig_bis > NOW() OR e.gueltig_bis='0000-00-00') AND e.geloescht!=1 AND e.preis >= 0 ORDER by e.id DESC LIMIT 1),'')) as name,
|
|
|
|
|
|
ifnull((SELECT DATE_FORMAT(MAX(auftrag.datum), '%d.%m.%Y') FROM auftrag LEFT JOIN
|
|
auftrag_position ON auftrag.id=auftrag_position.auftrag WHERE auftrag_position.artikel=a.id
|
|
),0) as verkauf,
|
|
|
|
|
|
|
|
ifnull(if( (SELECT SUM(ap.menge) FROM auftrag_position ap LEFT JOIN auftrag auf ON auf.id=ap.auftrag WHERE ap.artikel=a.id AND auf.status='freigegeben') > IFNULL((SELECT SUM(l.menge) FROM lager_platz_inhalt l WHERE l.artikel=a.id),0) + IFNULL((SELECT SUM(bp.menge-bp.geliefert) FROM bestellung_position bp LEFT JOIN bestellung b ON b.id=bp.bestellung WHERE bp.artikel=a.id AND b.status='versendet'),0)
|
|
,
|
|
CONCAT('<font color=red>',if((SELECT SUM(l.menge) FROM lager_platz_inhalt l WHERE l.artikel=a.id) > 0,(SELECT ".$app->erp->FormatMenge("SUM(l.menge)")." FROM lager_platz_inhalt l WHERE l.artikel=a.id),'-'),'</font>'),
|
|
|
|
if((SELECT SUM(l.menge) FROM lager_platz_inhalt l WHERE l.artikel=a.id) > 0,(SELECT ".$app->erp->FormatMenge("SUM(l.menge)")." FROM lager_platz_inhalt l WHERE l.artikel=a.id),'-')),0)
|
|
as lager,
|
|
|
|
ifnull((SELECT ".$app->erp->FormatMenge("SUM(ap.menge)")." FROM auftrag_position ap LEFT JOIN auftrag auf ON auf.id=ap.auftrag WHERE ap.artikel=a.id AND auf.status='freigegeben'),0) as offen,
|
|
|
|
ifnull((SELECT ".$app->erp->FormatMenge("SUM(bp.menge-bp.geliefert)")." FROM bestellung_position bp LEFT JOIN bestellung b ON b.id=bp.bestellung WHERE bp.artikel=a.id AND b.status='versendet'),0) as bestellung,
|
|
|
|
ifnull((if((SELECT SUM(l.menge) FROM lager_reserviert l WHERE l.artikel=a.id) > 0,(SELECT ".$app->erp->FormatMenge("SUM(l.menge)")." FROM lager_reserviert l WHERE l.artikel=a.id),'-')),0) as res,
|
|
|
|
ifnull(IF((SELECT SUM(ap.menge) FROM auftrag_position ap LEFT JOIN auftrag auf ON auf.id=ap.auftrag WHERE ap.artikel=a.id AND auf.status='freigegeben') - ( IFNULL((SELECT SUM(l.menge) FROM lager_platz_inhalt l WHERE l.artikel=a.id),0) + IFNULL((SELECT SUM(bp.menge-bp.geliefert) FROM bestellung_position bp LEFT JOIN bestellung b ON b.id=bp.bestellung WHERE bp.artikel=a.id AND b.status='versendet'),0)) > 0,".$app->erp->FormatMenge("(SELECT SUM(ap.menge) FROM auftrag_position ap LEFT JOIN auftrag auf ON auf.id=ap.auftrag WHERE ap.artikel=a.id AND auf.status='freigegeben') - ( IFNULL((SELECT SUM(l.menge) FROM lager_platz_inhalt l WHERE l.artikel=a.id),0) + IFNULL((SELECT SUM(bp.menge-bp.geliefert) FROM bestellung_position bp LEFT JOIN bestellung b ON b.id=bp.bestellung WHERE bp.artikel=a.id AND b.status='versendet'),0))").",'-'),0) as fehlende,
|
|
|
|
|
|
|
|
ifnull(if((SELECT SUM(ap.menge) FROM auftrag_position ap WHERE ap.artikel=a.id) > 0, (SELECT ".$app->erp->FormatMenge("SUM(ap.menge)")." FROM auftrag_position ap WHERE ap.artikel=a.id),'-'),0) as gesamt,
|
|
ifnull((SELECT ".$app->erp->FormatMenge("SUM(ap.menge)")." FROM auftrag_position ap LEFT JOIN auftrag auf ON auf.id=ap.auftrag WHERE ap.artikel=a.id AND DATE_FORMAT(auf.datum,'%Y-%m')='$aktuellermonat'),0) as monat,
|
|
ifnull((SELECT ".$app->erp->FormatMenge("SUM(ap.menge)")." FROM auftrag_position ap LEFT JOIN auftrag auf ON auf.id=ap.auftrag WHERE ap.artikel=a.id AND DATE_FORMAT(auf.datum,'%Y-%m')='$letztermonat'),0) as monat_last,
|
|
|
|
ifnull(if( (SELECT SUM(ap.menge) FROM auftrag_position ap LEFT JOIN auftrag auf ON auf.id=ap.auftrag WHERE ap.artikel=a.id AND auf.status='freigegeben') > IFNULL((SELECT SUM(l.menge) FROM lager_platz_inhalt l WHERE l.artikel=a.id),0)+IFNULL((SELECT SUM(bp.menge-bp.geliefert) FROM bestellung_position bp LEFT JOIN bestellung b ON b.id=bp.bestellung WHERE bp.artikel=a.id AND b.status='versendet'),0), 'fehlt','ok'),'') as status,
|
|
a.id as menu
|
|
FROM artikel a ";
|
|
|
|
// START EXTRA more
|
|
$more_data1 = $app->Secure->GetGET("more_data1");
|
|
|
|
if ($more_data1 == 1) $subwhere[] = " (((SELECT MAX(auftrag.datum) FROM auftrag LEFT JOIN
|
|
auftrag_position ON auftrag.id=auftrag_position.auftrag WHERE auftrag_position.artikel=a.id
|
|
) < DATE_SUB(NOW(),INTERVAL 6 MONTH)) AND (SELECT SUM(l.menge) FROM lager_platz_inhalt l WHERE l.artikel=a.id) > 0 )";
|
|
$csubwhere = isset($subwhere)?count($subwhere):0;
|
|
$tmp = '';
|
|
for ($j = 0;$j < $csubwhere;$j++) {
|
|
$tmp.= " AND " . $subwhere[$j];
|
|
}
|
|
|
|
// fester filter
|
|
$where = " (a.adresse='$id' OR a.id IN(SELECT artikel FROM einkaufspreise WHERE adresse='$id' AND (gueltig_bis>CURRENT_DATE() OR gueltig_bis='0000-00-00'))) AND a.geloescht!=1 $tmp";
|
|
$count = "SELECT COUNT(a.id) FROM artikel a WHERE $where";
|
|
|
|
break;
|
|
case 'adressealleabos':
|
|
$allowed['adresse'] = array('artikel');
|
|
$heading = array('Bezeichnung', 'Nummer', 'Start am', 'Abgerechnet bis', 'Enddatum', 'Preis','Rabatt', 'Währung', 'Menge', 'Art', 'Dokument','Gruppe / Reihenfolge', 'Menü');
|
|
$width = array('10%', '6%', '10%', '10%', '10%', '6%','3%', '4%', '2%', '5%', '5%','15%', '8%');
|
|
|
|
$findcols = array('aa.bezeichnung', 'ar.nummer', "if(aa.startdatum!='0000-00-00',DATE_FORMAT(aa.startdatum,'%d.%m.%Y') ,if(aa.angelegtam='0000-00-00','-',DATE_FORMAT(aa.angelegtam,'%d.%m.%Y')))", "if(aa.abgerechnetbis='0000-00-00','-',aa.abgerechnetbis)", "if(aa.enddatum='0000-00-00','-',aa.enddatum)", 'aa.preis','aa.rabatt', 'aa.waehrung', 'aa.menge',
|
|
"if(aa.wiederholend=1 OR aa.preisart='monat' OR aa.preisart='jahr' OR aa.preisart='monatx' OR aa.preisart='wochen',aa.preisart,
|
|
if(aa.preisart = '30tage',
|
|
'30 Tage',
|
|
if(aa.preisart = '360tage', '360 Tage', 'einmalig')
|
|
)
|
|
)",
|
|
'aa.dokument',"CONCAT(IFNULL(ag.beschreibung,''),aa.sort)", 'id');
|
|
$searchsql = array('aa.bezeichnung', 'ar.nummer', "if(aa.startdatum!='0000-00-00',DATE_FORMAT(aa.startdatum,'%d.%m.%Y') ,if(aa.angelegtam='0000-00-00','-',DATE_FORMAT(aa.angelegtam,'%d.%m.%Y')))", "if(aa.abgerechnetbis='0000-00-00','-',DATE_FORMAT(aa.abgerechnetbis,'%d.%m.%Y'))", "if(aa.enddatum='0000-00-00','-',DATE_FORMAT(aa.enddatum,'%d.%m.%Y'))", $app->erp->FormatPreis("aa.preis"),'aa.rabatt', 'aa.waehrung', $app->erp->FormatMenge("aa.menge"),
|
|
"if(aa.wiederholend=1 OR aa.preisart='monat' OR aa.preisart='jahr' OR aa.preisart='monatx' OR aa.preisart='wochen',aa.preisart,
|
|
if(aa.preisart = '30tage',
|
|
'30 Tage',
|
|
if(aa.preisart = '360tage', '360 Tage', 'einmalig')
|
|
)
|
|
)",
|
|
'ag.beschreibung', 'aa.dokument');
|
|
|
|
$numbercols = array(5,8);
|
|
$datecols = array(3,4);
|
|
$alignright = array(6,7,8,9);
|
|
$defaultorder = 12;
|
|
$defaultorderdesc = 0;
|
|
|
|
$nurAktive = $app->YUI->TableSearchFilter($name, 5, 'nur_aktive_abos', '0', 0, 'checkbox');
|
|
$subwhere = '';
|
|
if($nurAktive){
|
|
$subwhere = " AND (aa.enddatum = '0000-00-00' OR aa.enddatum >= CURDATE())";
|
|
}
|
|
|
|
$id = $app->Secure->GetGET('id');
|
|
|
|
$menu = "<table>";
|
|
$menu .= "<tr>";
|
|
$menu .= "<td nowrap>";
|
|
$menu .= "<a onclick=\"AboartikelEdit(%value%,$id)\" href=\"#\" title=\"Artikel ändern\"><img border=\"0\" src=\"themes/{$app->Conf->WFconf['defaulttheme']}/images/edit.svg\"></a> ";
|
|
$menu .= "<a onclick=DeleteDialog(\"index.php?module=adresse&action=delartikel&sid=%value%&id=$id\"); href=\"#\" ><img border=\"0\" src=\"themes/{$app->Conf->WFconf['defaulttheme']}/images/delete.svg\"></a> ";
|
|
$menu .= "</td>";
|
|
$menu .= "</tr>";
|
|
$menu .= "</table>";
|
|
|
|
$where = " aa.adresse='$id'".$subwhere;
|
|
|
|
$sql = "SELECT SQL_CALC_FOUND_ROWS aa.id, aa.bezeichnung, ar.nummer, if(aa.startdatum!='0000-00-00',DATE_FORMAT(aa.startdatum,'%d.%m.%Y') ,if(aa.angelegtam='0000-00-00','-',DATE_FORMAT(aa.angelegtam,'%d.%m.%Y'))) as 'angelegtam', if(aa.abgerechnetbis='0000-00-00','-',DATE_FORMAT(aa.abgerechnetbis,'%d.%m.%Y')) as 'abgerechnetbis',
|
|
if(aa.enddatum='0000-00-00','-',DATE_FORMAT(aa.enddatum,'%d.%m.%Y')) as enddatum,
|
|
".$app->erp->FormatPreis("aa.preis")." as preis, aa.rabatt, aa.waehrung, ".$app->erp->FormatMenge("aa.menge")." as menge,
|
|
if(
|
|
aa.wiederholend=1 OR aa.preisart='monat' OR aa.preisart='jahr' OR aa.preisart='monatx' OR aa.preisart='wochen',
|
|
aa.preisart,
|
|
if(aa.preisart = '30tage',
|
|
'30 Tage',
|
|
if(aa.preisart = '360tage', '360 Tage', 'einmalig')
|
|
)
|
|
),
|
|
aa.dokument,CONCAT(IFNULL(ag.beschreibung,'-'), ' / ', if(ag.id > 0,' ',''),aa.sort, ''), aa.id as id
|
|
FROM abrechnungsartikel aa LEFT JOIN artikel ar ON ar.id=aa.artikel LEFT JOIN user u ON u.id=aa.angelegtvon LEFT JOIN adresse au ON au.id=u.adresse
|
|
LEFT JOIN abrechnungsartikel_gruppe ag ON aa.gruppe=ag.id";
|
|
$count = "SELECT COUNT(aa.id) FROM abrechnungsartikel aa LEFT JOIN artikel ar ON ar.id = aa.artikel LEFT JOIN user u ON u.id = aa.angelegtvon LEFT JOIN adresse au ON au.id = u.adresse WHERE $where";
|
|
|
|
break;
|
|
case 'adressealleabossort':
|
|
$allowed['adresse'] = array('artikel');
|
|
$heading = array('Bezeichnung', 'Nummer', 'Preis','Gruppe', 'Reihenfolge', 'Menü');
|
|
$width = array('10%', '10%', '10%', '10%', '10%', '8%');
|
|
|
|
$findcols = array('aa.bezeichnung', 'ar.nummer', 'preis','ag.beschreibung','aa.sort', 'id');
|
|
$searchsql = array('aa.bezeichnung', 'ar.nummer', 'preis','ag.beschreibung');
|
|
|
|
$alignright = array(6);
|
|
$defaultorder = 4;
|
|
$defaultorderdesc = 0;
|
|
|
|
$id = $app->Secure->GetGET('id');
|
|
|
|
$menu = "<table>";
|
|
$menu .= "<tr>";
|
|
$menu .= "<td nowrap>";
|
|
$menu .= "<a onclick=\"AboartikelMove(%value%,1)\" href=\"#\"><img border=\"0\" src=\"./themes/{$app->Conf->WFconf['defaulttheme']}/images/up.png\"></a>";
|
|
$menu .= "<a onclick=\"AboartikelMove(%value%,0)\" href=\"#\"><img border=\"0\" src=\"./themes/{$app->Conf->WFconf['defaulttheme']}/images/down.png\"></a>";
|
|
$menu .= "</td>";
|
|
$menu .= "</tr>";
|
|
$menu .= "</table>";
|
|
|
|
$where = " aa.adresse='$id'";
|
|
|
|
$orderby = "ORDER BY aa.gruppe ASC, aa.sort ASC";
|
|
|
|
$sql = "SELECT SQL_CALC_FOUND_ROWS aa.id,
|
|
aa.bezeichnung,
|
|
ar.nummer,
|
|
".$app->erp->FormatPreis("aa.preis")." as preis,
|
|
IFNULL(ag.beschreibung,'-') as gruppe,
|
|
aa.sort,
|
|
aa.id as id
|
|
FROM abrechnungsartikel aa LEFT JOIN artikel ar ON ar.id=aa.artikel LEFT JOIN user u ON u.id=aa.angelegtvon LEFT JOIN adresse au ON au.id=u.adresse
|
|
LEFT JOIN abrechnungsartikel_gruppe ag ON aa.gruppe=ag.id";
|
|
$count = "SELECT COUNT(aa.id) FROM abrechnungsartikel aa LEFT JOIN artikel ar ON ar.id = aa.artikel LEFT JOIN user u ON u.id = aa.angelegtvon LEFT JOIN adresse au ON au.id = u.adresse WHERE $where";
|
|
|
|
break;
|
|
case 'abrechnungsartikel_gruppe':
|
|
$allowed['adresse'] = array('artikel');
|
|
$heading = array('Bezeichnung','Reihenfolge','Ansprechpartner','Rechnung','Ziel-Projekt', 'Menü');
|
|
$width = array('30%','5%', '30%','10%','15%', '8%');
|
|
|
|
$findcols = array('ag.beschreibung','ag.sort', 'ag.ansprechpartner', "if(ag.extrarechnung=0,'Gemeinsame Rechnung', if(ag.extrarechnung=1,'Eigene Rechnung', if(ag.extrarechnung=2, 'Sammelrechnung', '-')))",'p.abkuerzung', 'ag.id');
|
|
$searchsql = array('ag.beschreibung','ag.sort', 'ag.ansprechpartner', "if(ag.extrarechnung=0,'Gemeinsame Rechnung', if(ag.extrarechnung=1,'Eigene Rechnung', if(ag.extrarechnung=2, 'Sammelrechnung', '-')))",'p.abkuerzung');
|
|
|
|
$defaultorder = 1;
|
|
$defaultorderdesc = 0;
|
|
|
|
$id = $app->Secure->GetGET('id');
|
|
|
|
$menu = "<table class=\"nopadding\" cellpadding=\"0\" cellspacing=\"0\">";
|
|
$menu .= "<tr>";
|
|
$menu .= "<td>";
|
|
$menu .= "<a onclick=\"AbogruppeEdit(%value%)\" href=\"#\" title=\"Artikel ändern\">";
|
|
$menu .= "<img border=\"0\" src=\"themes/{$app->Conf->WFconf['defaulttheme']}/images/edit.svg\">";
|
|
$menu .= "</a>";
|
|
$menu .= "</td>";
|
|
$menu .= "<td>";
|
|
$menu .= "<a onclick=AbogruppeDelete(%value%); href=\"#\" >";
|
|
$menu .= "<img border=\"0\" src=\"themes/{$app->Conf->WFconf['defaulttheme']}/images/delete.svg\">";
|
|
$menu .= "</a>";
|
|
$menu .= "</td>";
|
|
$menu .= "</tr>";
|
|
$menu .= "</table>";
|
|
|
|
$where = " ag.adresse='$id' ";
|
|
|
|
$sql = "SELECT SQL_CALC_FOUND_ROWS ag.id, ag.beschreibung,if(ag.sort<=0,'-',ag.sort),ag.ansprechpartner,if(ag.extrarechnung=0,'Gemeinsame Rechnung', if(ag.extrarechnung=1,'Eigene Rechnung', if(ag.extrarechnung=2, 'Sammelrechnung', '-'))), p.abkuerzung, ag.id FROM abrechnungsartikel_gruppe ag
|
|
LEFT JOIN projekt p ON p.id=ag.projekt";
|
|
|
|
$count = "SELECT COUNT(ag.id) FROM abrechnungsartikel_gruppe ag WHERE $where";
|
|
|
|
|
|
break;
|
|
case 'abosammelrechnungen':
|
|
$allowed['adresse'] = array('artikel');
|
|
$heading = array('Bezeichnung', 'abweichende Rechnungsadresse', 'Ziel-Projekt', 'Menü');
|
|
$width = array('30%', '30%', '30%', '1%');
|
|
|
|
$findcols = array('abs.bezeichnung', 'a.name', 'p.abkuerzung', 'abs.id');
|
|
$searchsql = array('abs.bezeichnung', 'a.name', 'p.abkuerzung');
|
|
|
|
$defaultorder = 1;
|
|
$defaultorderdesc = 0;
|
|
|
|
$id = $app->Secure->GetGET('id');
|
|
|
|
$menu = "<table cellpadding=0 cellspacing=0>";
|
|
$menu .= "<tr>";
|
|
$menu .= "<td nowrap>";
|
|
$menu .= '<a href="javascript:;" onclick="AboSammelrechnungEdit(%value%);">';
|
|
$menu .= "<img border=\"0\" src=\"themes/{$app->Conf->WFconf['defaulttheme']}/images/edit.svg\">";
|
|
$menu .= "</a> ";
|
|
$menu .= '<a href="javascript:;" onclick="AboSammelrechnungDelete(%value%);">';
|
|
$menu .= "<img border=\"0\" src=\"themes/{$app->Conf->WFconf['defaulttheme']}/images/delete.svg\">";
|
|
$menu .= "</a>";
|
|
$menu .= "</td>";
|
|
$menu .= "</tr>";
|
|
$menu .= "</table>";
|
|
|
|
$where = " abs.adresse='$id' ";
|
|
|
|
$sql = "SELECT SQL_CALC_FOUND_ROWS abs.id, abs.bezeichnung, a.name, p.abkuerzung, abs.id FROM adresse_abosammelrechnungen abs LEFT JOIN adresse a ON abs.abweichende_rechnungsadresse = a.id LEFT JOIN projekt p ON abs.projekt = p.id";
|
|
|
|
$count = "SELECT COUNT(abs.id) FROM adresse_abosammelrechnungen abs WHERE $where";
|
|
break;
|
|
|
|
case 'abrechnungsartikel':
|
|
$allowed['adresse'] = array('artikel');
|
|
$heading = array('Artikel', 'Nummer', 'Ab', 'Preis','Waehrung', 'Projekt', 'Startdatum', 'Menge', 'Aktion');
|
|
$width = array('20%', '10%', '2%', '8%', '5%','1%', '10%', '10%', '10%');
|
|
$findcols = array('a.name_de', 'a.nummer', 'ab', 'v.preis','v.waehrung','projekt', 'lieferdatum', 'menge', 'v.id');
|
|
$searchsql = array('a.name_de', 'a.nummer');
|
|
$id = $app->Secure->GetGET('id');
|
|
$alignright=array(4,5);
|
|
$menu = '<center><input type="button" value="anlegen" onclick="anlegen(' . $id . ',%value%)"></center>';
|
|
$sql = "SELECT SQL_CALC_FOUND_ROWS a.id,CONCAT(a.name_de,' ',if(v.adresse='$id','(Kundensp. Preis)',''), if(v.gruppe > 0,CONCAT('(Gruppenpreis ',g.name,' ',g.kennziffer,')'),'')), CONCAT('<a href=\"index.php?module=artikel&action=verkauf&id=',a.id,'\" target=\"_blank\">',a.nummer,'</a>'), ".$app->erp->FormatMenge("v.ab_menge")." AS ab, ".$app->erp->FormatPreis("v.preis").",v.waehrung, p.abkuerzung as projekt,
|
|
CONCAT('<center><input type=\"text\" size=\"10\" value=\"',DATE_FORMAT(NOW(),'%d.%m.%Y'),'\" id=\"datum',v.id,'\"></center>') AS lieferdatum,
|
|
CONCAT('<center><input type=\"text\" size=\"3\" value=\"\" id=\"menge',v.id,'\"><select name=\"art',v.id,'\" id=\"art',v.id,'\"><option value=\"abo\">Abo</option><option value=\"einmalig\">Einmalig</option></select></center>') AS menge,
|
|
v.id
|
|
FROM artikel AS a
|
|
LEFT JOIN verkaufspreise AS v ON v.artikel=a.id
|
|
LEFT JOIN projekt AS p ON p.id=v.projekt LEFT JOIN gruppen g ON g.id=v.gruppe";
|
|
$where = " v.ab_menge>0 AND a.geloescht!=1 AND (v.gueltig_bis ='0000-00-00' OR v.gueltig_bis >= DATE_FORMAT(NOW(),'%Y-%m-%d')) AND (v.adresse='$id' or v.adresse<=0) ";
|
|
$count = "SELECT COUNT(a.id) FROM artikel AS a
|
|
LEFT JOIN verkaufspreise AS v ON v.artikel=a.id
|
|
LEFT JOIN projekt AS p ON p.id=v.projekt
|
|
WHERE $where";
|
|
break;
|
|
case 'adresse_ansprechpartnergruppen':
|
|
//$doctype = str_replace('belegeinauslagern_bewegungen_','',$name);
|
|
$id = $app->Secure->GetGET('id');
|
|
$lid = $app->YUI->TableSearchFilter($name, 1, 'filterlid');
|
|
$allowed['adresse'] = array('ansprechpartner');
|
|
$heading = array('','Gruppe','Kategorie','');
|
|
$width = array('1%','49%','49','1%');
|
|
$findcols = array('ag.aktiv','gr.name','gk.bezeichnung','gr.id');
|
|
$searchsql = array('gr.name','gk.bezeichnung');
|
|
$defaultorder = 2;
|
|
$defaultorderdesc = 0;
|
|
$disabled = "";
|
|
//if(!$lid)$disabled = "disabled ";
|
|
$sql= "SELECT SQL_CALC_FOUND_ROWS gr.id ,
|
|
concat('<input type=\"checkbox\" $disabled onchange=\"grchange(',gr.id,',this,$lid);\" id=\"gr_',gr.id,'\" name=\"gr_',gr.id,'\" ',(if(ifnull(ag.aktiv,0) <> 0,' checked ','')),' />') as auswahl,
|
|
gr.name, gk.bezeichnung, gr.id
|
|
FROM gruppen gr
|
|
LEFT JOIN ansprechpartner_gruppen ag ON gr.id = ag.gruppe and ag.ansprechpartner = '$lid'
|
|
LEFT JOIN gruppen_kategorien gk ON gr.kategorie = gk.id
|
|
";
|
|
$where = " gr.art != 'preisgruppe' ";
|
|
$maxrows = 50;
|
|
$disablebuttons = true;
|
|
break;
|
|
|
|
case 'adresse_ustprf':
|
|
$allowed['adresse'] = array('ustprf');
|
|
|
|
$heading = array('Datum', 'Firma', 'Straße', 'PLZ', 'Ort', 'Land', 'Brief', 'Status', 'Menü');
|
|
$width = array('8%', '25%', '25%', '5%', '10%', '5%', '3%', '5%', '1%');
|
|
|
|
$findcols = array('u.datum', 'u.name', 'u.strasse', 'u.plz', 'u.ort', 'u.land', "if(u.briefbestellt != '0000-00-00', 'ja', '-')", "IF(u.status = 'gueltigmarkieren', 'gültig markiert', status)", 'u.id');
|
|
$searchsql = array("DATE_FORMAT(u.datum, '%d.%m.%Y')", 'u.name', 'u.strasse', 'u.plz', 'u.ort', 'u.land', 'u.briefbestellt', "IF(u.status = 'gueltigmarkieren', 'gültig markiert', status)");
|
|
|
|
$defaultorder = 1;
|
|
$defaultorderdesc = 0;
|
|
|
|
$menu = '<table cellpadding=0 cellspacing=0>';
|
|
$menu .= '<tr>';
|
|
$menu .= '<td nowrap>';
|
|
$menu .= '<a href="javascript:;" onclick="UstprfEdit(%value%);">';
|
|
$menu .= "<img src=\"themes/{$app->Conf->WFconf['defaulttheme']}/images/edit.svg\" border=\"0\">";
|
|
$menu .= '</a> ';
|
|
$menu .= '<a href="javascript:;" onclick="UstprfDelete(%value%);">';
|
|
$menu .= "<img src=\"themes/{$app->Conf->WFconf['defaulttheme']}/images/delete.svg\" border=\"0\">";
|
|
$menu .= '</a>';
|
|
$menu .= '</td>';
|
|
$menu .= '</tr>';
|
|
$menu .= '</table>';
|
|
|
|
$adressid = $app->Secure->GetGET('id');
|
|
|
|
$where = " u.id > 0 AND u.adresse = '$adressid'";
|
|
|
|
$sql = "SELECT SQL_CALC_FOUND_ROWS u.id, DATE_FORMAT(u.datum, '%d.%m.%Y'), u.name, u.strasse, u.plz, u.ort, u.land, if(u.briefbestellt != '0000-00-00', 'ja', '-'), IF(u.status = 'gueltigmarkieren', 'gültig markiert', IF(u.status = 'online', 'erfolgreich geprüft', u.status)), u.id FROM ustprf u";
|
|
|
|
$count = "SELECT COUNT(u.id) FROM ustprf u WHERE $where";
|
|
break;
|
|
|
|
case 'adresse_ustprf_protokoll':
|
|
$allowed['adresse'] = array('ustprf');
|
|
|
|
$heading = array('Datum / Zeit', 'Bemerkung', 'Bearbeiter', '');
|
|
$width = array('18%', '56%', '25%', '1%');
|
|
|
|
$findcols = array('u.zeit', 'u.bemerkung', 'u.bearbeiter', 'u.id');
|
|
$searchsql = array("DATE_FORMAT(u.zeit, '%d.%m.%Y %H:%i:%s')", 'u.bemerkung', 'u.bearbeiter');
|
|
|
|
$defaultorder = 1;
|
|
$defaultorderdesc = 1;
|
|
|
|
//$ustprfid = 0;
|
|
$ustprfid = $app->Secure->GetGET('more_data1');
|
|
|
|
$where = " u.ustprf_id = '$ustprfid'";
|
|
|
|
$sql = "SELECT SQL_CALC_FOUND_ROWS u.id, DATE_FORMAT(u.zeit, '%d.%m.%Y %H:%i:%s'), IF(u.daten != '', CONCAT(u.bemerkung, '<br /><i style=color:#999>', u.daten,'</i>'), u.bemerkung), u.bearbeiter, u.id FROM ustprf_protokoll u";
|
|
|
|
$count = "SELECT COUNT(u.id) FROM ustprf_protokoll u WHERE $where";
|
|
}
|
|
|
|
$erg = [];
|
|
foreach($erlaubtevars as $k => $v) {
|
|
if(isset($$v)){
|
|
$erg[$v] = $$v;
|
|
}
|
|
}
|
|
return $erg;
|
|
}
|
|
|
|
/**
|
|
* Adresse 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("create","AdresseCreate");
|
|
$this->app->ActionHandler("edit","AdresseEdit");
|
|
$this->app->ActionHandler("getid","AdresseGetid");
|
|
$this->app->ActionHandler("open","AdresseOpen");
|
|
$this->app->ActionHandler("list","AdresseList");
|
|
$this->app->ActionHandler("suche","AdresseSuche");
|
|
$this->app->ActionHandler("delete","AdresseDelete");
|
|
$this->app->ActionHandler("ustprf","AdresseUstprf");
|
|
$this->app->ActionHandler("lieferantvorlage","AdresseLieferantvorlage");
|
|
$this->app->ActionHandler("kundevorlage","AdresseKundevorlage");
|
|
$this->app->ActionHandler("zeiterfassung","AdresseZeiterfassung");
|
|
$this->app->ActionHandler("abrechnungzeit","AdresseAbrechnungzeit");
|
|
$this->app->ActionHandler("abrechnungzeitabgeschlossen","AdresseAbrechnungzeitabgeschlossen");
|
|
$this->app->ActionHandler("abrechnungzeitdelete","AdresseAbrechnungzeitdelete");
|
|
$this->app->ActionHandler("pdf","AdresseStammblatt");
|
|
|
|
$this->app->ActionHandler("lieferadresse","AdresseLieferadresse");
|
|
$this->app->ActionHandler("lieferadresseneditpopup","AdresseLieferadressenEditPopup");
|
|
$this->app->ActionHandler("ansprechpartner","AdresseAnsprechpartner");
|
|
$this->app->ActionHandler("ansprechpartnereditpopup","AdresseAnsprechpartnerEditPopup");
|
|
$this->app->ActionHandler("ansprechpartnerpopup","AdresseAnsprechpartnerPopup");
|
|
|
|
$this->app->ActionHandler("accounts","AdresseAccounts");
|
|
|
|
|
|
$this->app->ActionHandler("adressestammdatenpopup","AdresseStammdatenLieferadressePopup");
|
|
$this->app->ActionHandler("ansprechpartnerlieferadressepopup","AdresseAnsprechpartnerLieferadressePopup");
|
|
$this->app->ActionHandler("lieferadressepopup","AdresseLieferadressePopup");
|
|
$this->app->ActionHandler("ustpopup","AdresseUSTPopup");
|
|
$this->app->ActionHandler("rollen","AdresseRollen");
|
|
$this->app->ActionHandler("gruppen","AdresseGruppen");
|
|
$this->app->ActionHandler("kontakthistorie","AdresseKontakthistorie");
|
|
$this->app->ActionHandler("kontakthistorieeditpopup","AdresseKontakthistorieEditPopup");
|
|
$this->app->ActionHandler("rolecreate","AdresseRolleAnlegen");
|
|
$this->app->ActionHandler("rolledatum","AdresseRolleDatum");
|
|
$this->app->ActionHandler("roledel","AdresseRolleLoeschen");
|
|
$this->app->ActionHandler("addposition","AdresseAddPosition");
|
|
$this->app->ActionHandler("suchmaske","AdresseSuchmaske");
|
|
$this->app->ActionHandler("dateien","AdresseDateien");
|
|
$this->app->ActionHandler("brief","AdresseBrief");
|
|
$this->app->ActionHandler("briefdelete","AdresseBriefDelete");
|
|
$this->app->ActionHandler("briefpdf","AdresseBriefPDF");
|
|
$this->app->ActionHandler("briefeditpopup","AdresseBriefEditPopup");
|
|
|
|
$this->app->ActionHandler("saverolle", "AdresserolleSave");
|
|
|
|
$this->app->ActionHandler("brieferstellen","AdresseBriefErstellen");
|
|
$this->app->ActionHandler("briefpreview","AdresseBriefPreview");
|
|
$this->app->ActionHandler("briefbearbeiten","AdresseBriefBearbeiten");
|
|
$this->app->ActionHandler("briefkorrpdf", "AdresseKorrBriefPdf");
|
|
$this->app->ActionHandler("briefkorrdelete", "AdresseKorrBriefDelete");
|
|
$this->app->ActionHandler("briefdrucken", "AdresseBriefDrucken");
|
|
|
|
|
|
$this->app->ActionHandler("email","AdresseEmail");
|
|
$this->app->ActionHandler("belege","AdresseBelege");
|
|
$this->app->ActionHandler("positioneneditpopup","AdresseArtikelEditPopup");
|
|
$this->app->ActionHandler("emaileditpopup","AdresseEmailEditPopup");
|
|
$this->app->ActionHandler("artikel","AdresseArtikelPosition");
|
|
$this->app->ActionHandler("lieferantartikel","AdresseLieferantArtikel");
|
|
$this->app->ActionHandler("kundeartikel","AdresseKundeArtikel");
|
|
$this->app->ActionHandler("delartikel","DelArtikel");
|
|
$this->app->ActionHandler("upartikel","UpArtikel");
|
|
$this->app->ActionHandler("downartikel","DownArtikel");
|
|
|
|
$this->app->ActionHandler("rolledelete","AdresseRolleDelete");
|
|
$this->app->ActionHandler("artikeleditpopup","AdresseArtikelEditPopup");
|
|
$this->app->ActionHandler("kontakthistorie","AdresseKontaktHistorie");
|
|
$this->app->ActionHandler("offenebestellungen","AdresseOffeneBestellungen");
|
|
$this->app->ActionHandler("verbindlichkeiten","AdresseVerbindlichkeiten");
|
|
$this->app->ActionHandler("adressebestellungmarkieren","AdresseBestellungMarkiert");
|
|
$this->app->ActionHandler("autocomplete","AdresseAutoComplete");
|
|
|
|
$this->app->ActionHandler("lohn","AdresseLohnStundensatzUebersicht");
|
|
$this->app->ActionHandler("stundensatz","AdresseStundensatz");
|
|
$this->app->ActionHandler("stundensatzedit","AdresseStundensatzEdit");
|
|
$this->app->ActionHandler("stundensatzdelete","AdresseStundensatzDelete");
|
|
$this->app->ActionHandler("createdokument","AdresseCreateDokument");
|
|
$this->app->ActionHandler("newkontakt","AdresseNewKontakt");
|
|
$this->app->ActionHandler("delkontakt","AdresseDelKontakt");
|
|
$this->app->ActionHandler("minidetail","AdresseMiniDetailZeit");
|
|
$this->app->ActionHandler("minidetailadr","AdresseMiniDetailAdr");
|
|
$this->app->ActionHandler("minidetailbrief","AdresseMiniDetailBrief");
|
|
$this->app->ActionHandler("korreseditpopup","AdresseKorressEditPopup");
|
|
$this->app->ActionHandler("sepamandat","AdresseSEPAMandat");
|
|
|
|
$this->app->ActionHandler("verein","AdresseVerein");
|
|
|
|
$this->app->ActionHandler("removeemailanhang","Adresseremoveemailanhang");
|
|
$this->app->ActionHandler("downloaddatei", "AdresseDownloadDatei");
|
|
|
|
|
|
$this->app->ActionHandler("minidetaillieferadressen","AdresseMinidetailLieferadressen");
|
|
$this->app->ActionHandler("minidetailansprechpartner","AdresseMinidetailAnsprechpartner");
|
|
|
|
$id = $this->app->Secure->GetGET('id');
|
|
//$nummer = $this->app->Secure->GetPOST("nummer");
|
|
|
|
//if($nummer=="")
|
|
//$name = $this->app->DB->Select("SELECT CONCAT(name,' ',
|
|
if($id > 0){
|
|
$nummer = $this->app->DB->Select("SELECT CONCAT(
|
|
if(kundennummer!='',CONCAT('Kunde: ',kundennummer),''),
|
|
if(lieferantennummer!='',CONCAT(' Lieferant: ',lieferantennummer),'')) FROM adresse WHERE id='$id' AND geloescht=0 LIMIT 1");
|
|
}else{
|
|
$nummer = '';
|
|
}
|
|
|
|
|
|
if(is_numeric($id)){
|
|
$name = $this->app->DB->Select("SELECT name FROM adresse WHERE id='$id' AND geloescht=0 LIMIT 1");
|
|
}
|
|
|
|
// else
|
|
// $name = $nummer;
|
|
|
|
if(!empty($name)){
|
|
$this->app->Tpl->SetText('UEBERSCHRIFT', 'Adresse von: ' . $name);
|
|
}
|
|
else{
|
|
$this->app->Tpl->SetText('UEBERSCHRIFT', 'Adressen');
|
|
}
|
|
|
|
$this->app->Tpl->SetText('KURZUEBERSCHRIFT','Adressen');
|
|
if(isset($name) && isset($nummer) && $name!='' && $nummer!=''){
|
|
$this->app->Tpl->SetText('KURZUEBERSCHRIFT2', "$name ($nummer)");
|
|
}
|
|
else{
|
|
$this->app->Tpl->SetText('KURZUEBERSCHRIFT2', !empty($name) ? $name : '');
|
|
}
|
|
|
|
if(isset($name)){
|
|
$this->app->Tpl->SetText('ANZEIGENUMMER',$name);
|
|
}
|
|
if(isset($nummer)){
|
|
$this->app->Tpl->SetText('ANZEIGENAMEDE',' '.$nummer);
|
|
}
|
|
|
|
$this->app->Tpl->Set('FARBE','[FARBE1]');
|
|
|
|
$this->app->erp->CheckColumn('email', 'varchar(255)', 'adresse_accounts', 'NOT NULL');
|
|
$this->app->erp->CheckColumn('notiz', 'text', 'adresse_accounts', 'NOT NULL');
|
|
|
|
$this->app->erp->Headlines('Adressen');
|
|
|
|
$this->app->ActionHandlerListen($app);
|
|
}
|
|
|
|
public function Install()
|
|
{
|
|
$this->app->erp->RegisterHook('supersearch_detail', 'adresse', 'AdresseSupersearchDetail');
|
|
}
|
|
|
|
/**
|
|
* @param \Xentral\Widgets\SuperSearch\Query\DetailQuery $detailQuery
|
|
* @param \Xentral\Widgets\SuperSearch\Result\ResultDetail $detailResult
|
|
*
|
|
* @return void
|
|
*/
|
|
public function AdresseSupersearchDetail($detailQuery, $detailResult)
|
|
{
|
|
if ($detailQuery->getGroupKey() !== 'addresses') {
|
|
return;
|
|
}
|
|
|
|
$adresseId = $detailQuery->getItemIdentifier();
|
|
$sql = sprintf(
|
|
"SELECT a.id, a.name, a.ansprechpartner, a.kundennummer, a.lieferantennummer FROM `adresse` AS `a` WHERE a.id = '%s' LIMIT 1",
|
|
$this->app->DB->real_escape_string($adresseId)
|
|
);
|
|
$adresse = $this->app->DB->SelectRow($sql);
|
|
if (empty($adresse)) {
|
|
return;
|
|
}
|
|
|
|
$title = $adresse['name'];
|
|
if (!empty($adresse['ansprechpartner'])) {
|
|
$title .= ' ' . $adresse['ansprechpartner'];
|
|
}
|
|
if (!empty($adresse['kundennummer'])) {
|
|
$title .= ' <small>Kunde ' . $adresse['kundennummer'] . '</small>';
|
|
}
|
|
if (!empty($adresse['lieferantennummer'])) {
|
|
$title .= ' <small>Lieferant ' . $adresse['lieferantennummer'] . '</small>';
|
|
}
|
|
$detailResult->setTitle($title);
|
|
$detailResult->addButton('Adresse Details', sprintf('index.php?module=adresse&action=edit&id=%s', $adresse['id']));
|
|
$detailResult->setMiniDetailUrl(sprintf('index.php?module=adresse&action=minidetailadr&id=%s', $adresse['id']));
|
|
}
|
|
|
|
|
|
|
|
public function AdresseDownloadDatei()
|
|
{
|
|
$id = (int)$this->app->Secure->GetGET('id');
|
|
if($this->app->DB->Select("SELECT id FROM datei_stichwoerter where datei = '$id' AND subjekt like 'anhang' and objekt like 'dokument' LIMIT 1"))
|
|
{
|
|
$this->app->erp->SendDatei($id);
|
|
} else {
|
|
header("Content-Disposition: attachment; filename=\"Fehler.txt\"");
|
|
}
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
public function Adresseremoveemailanhang()
|
|
{
|
|
$res['status'] = false;
|
|
$datei = (int)$this->app->Secure->GetGET('id');
|
|
if($datei)
|
|
{
|
|
$checkstichwort = $this->app->DB->Select("SELECT datei FROM datei_stichwoerter WHERE datei = '$datei' AND subjekt like 'anhang' and objekt like 'dokument' LIMIT 1");
|
|
if($checkstichwort)
|
|
{
|
|
$this->app->DB->Delete("DELETE FROM datei_version WHERE datei='$datei'");
|
|
$this->app->DB->Delete("DELETE FROM datei_stichwoerter WHERE datei='$datei'");
|
|
$this->app->DB->Update("UPDATE datei SET geloescht=1 WHERE id='$datei'");
|
|
$res['status'] = true;
|
|
}
|
|
}
|
|
echo json_encode($res);
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
public function AdresseMiniDetailBrief($parsetarget = '', $menu = true)
|
|
{
|
|
$doppelteids = $this->app->Secure->GetGET('id');
|
|
$ids = preg_split('/\-/',$doppelteids);
|
|
if((!empty($ids)?count($ids):0) > 1)
|
|
{
|
|
$typ = (int)$ids[0];
|
|
$id = (int)$ids[1];
|
|
switch($typ)
|
|
{
|
|
case '1':
|
|
|
|
$this->AdresseBriefPreview('dokumente',$id,false);
|
|
break;
|
|
case '2':
|
|
$this->AdresseBriefPreview('dokumente_send',$id,false);
|
|
break;
|
|
case '4':
|
|
$this->AdresseBriefPreview('ticket_nachricht',$id,false);
|
|
break;
|
|
|
|
case '5':
|
|
|
|
$this->AdresseBriefPreview('wiedervorlage',$id,false);
|
|
break;
|
|
case '6':
|
|
$this->AdresseBriefPreview('kalender',$id,false);
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
public function AdresseKorressEditPopup()
|
|
{
|
|
// nach page inhalt des dialogs ausgeben
|
|
if (class_exists('WidgetDokumente')){
|
|
$widget = new WidgetDokumente($this->app,'PAGE');
|
|
//$sid = $this->app->DB->Select("SELECT adresse FROM abrechnungsartikel WHERE id='$id' LIMIT 1");
|
|
//$widget->form->SpecialActionAfterExecute("close_refresh",
|
|
// "index.php?module=adresse&action=artikel&id=$sid");
|
|
$widget->Edit();
|
|
$this->app->BuildNavigation=false;
|
|
}
|
|
}
|
|
|
|
public function AdresseMiniDetailAdr($parsetarget = '', $menu = true)
|
|
{
|
|
$id = (int)$this->app->Secure->GetGET('id');
|
|
$adr = $this->app->DB->SelectRow("SELECT adr.*, DATE_FORMAT(adr.mandatsreferenzdatum, '%e.%m.%Y') AS mandatsreferenzdatumd FROM adresse AS adr WHERE adr.id = ".$id." limit 1");
|
|
if(!empty($adr))
|
|
{
|
|
$this->app->Tpl->Set('EMAIL',$adr['email']);
|
|
$this->app->Tpl->Set('MOBIL',$adr['mobil']);
|
|
$this->app->Tpl->Set('MARKETINGSPERRE',($adr['marketingsperre']==1?"JA":"NEIN"));
|
|
$this->app->Tpl->Set('TELEFAX',$adr['telefax']);
|
|
$this->app->Tpl->Set('TELEFON',$adr['telefon']);
|
|
$this->app->Tpl->Set('ORT',$adr['ort']);
|
|
$this->app->Tpl->Set('LAND',$adr['land']);
|
|
$this->app->Tpl->Set('PLZ',$adr['plz']);
|
|
$this->app->Tpl->Set('STRASSE',$adr['strasse']);
|
|
$this->app->Tpl->Set('ANSPRECHPARTNERNAME',$adr['ansprechpartner']);
|
|
|
|
$this->app->Tpl->Set('ZAHLUNGSWEISE',$adr['zahlungsweise']);
|
|
$this->app->Tpl->Set('ZAHLUNGSZIELTAGE',$adr['zahlungszieltage']);
|
|
$this->app->Tpl->Set('ZAHLUNGSZIELTAGESKONTO',$adr['zahlungszieltage']);
|
|
$this->app->Tpl->Set('ZAHLUNGSZIELTAGESKONTO',$adr['zahlungszieltageskonto']);
|
|
$this->app->Tpl->Set('ZAHLUNGSZIELSKONTO',$adr['zahlungszielskonto']);
|
|
$this->app->Tpl->Set('KUNDENNUMMERLIEFERANT',$adr['kundennummerlieferant']);
|
|
$this->app->Tpl->Set('ZAHLUNGSWEISELIEFERANT',$adr['zahlungsweiselieferant']);
|
|
$this->app->Tpl->Set('ZAHLUNGSZIELTAGELIEFERANT',$adr['zahlungszieltagelieferant']);
|
|
$this->app->Tpl->Set('ZAHLUNGSZIELTAGESKONTOLIEFERANT',$adr['zahlungszieltagelieferant']);
|
|
$this->app->Tpl->Set('ZAHLUNGSZIELTAGESKONTOLIEFERANT',$adr['zahlungszieltageskontolieferant']);
|
|
$this->app->Tpl->Set('ZAHLUNGSZIELSKONTOLIEFERANT',$adr['zahlungszielskontolieferant']);
|
|
$this->app->Tpl->Set('VERSANDARTLIEFERANT', $adr['versandartlieferant']);
|
|
|
|
|
|
$this->app->Tpl->Set('INHABER',$adr['inhaber']);
|
|
$this->app->Tpl->Set('BANK',$adr['bank']);
|
|
$this->app->Tpl->Set('SWIFT',$adr['swift']);
|
|
$this->app->Tpl->Set('IBAN',$adr['iban']);
|
|
$this->app->Tpl->Set('MANDATREFERENZ',$adr['mandatsreferenz']);
|
|
$this->app->Tpl->Set('ZAHLUNGSZIELSKONTOLIEFERANT',$adr['zahlungszielskontolieferant']);
|
|
$this->app->Tpl->Set('MANDATREFERENZART',$adr['mandatsreferenzart']);
|
|
$this->app->Tpl->Set('MANDATSREFERENZDHART',$adr['mandatsreferenzdhart']);
|
|
$this->app->Tpl->Set('MANDATSREFERENZDATUM',$adr['mandatsreferenzdatumd']);
|
|
$this->app->Tpl->Set('MANDATSREFERENZAENDERUNG',($adr['mandatsreferenzaenderung']?'ja':'nein'));
|
|
$this->app->Tpl->Set('WAEHRUNG',$adr['waehrung']);
|
|
|
|
$table = new EasyTable($this->app);
|
|
$table->Query("SELECT a.name, a.bereich, a.email, a.telefon, a.telefax, a.mobil FROM ansprechpartner a WHERE adresse='$id' AND a.name!='Neuer Datensatz' ORDER by id DESC",0,"");
|
|
$table->DisplayNew('ANSPRECHPARTNER','Mobil','noAction');
|
|
|
|
$table = new EasyTable($this->app);
|
|
$table->Query("SELECT a.subjekt as Rolle,
|
|
if(a.objekt='','ALLE',a.objekt) as Zuordnung,
|
|
if(a.objekt='Projekt',if(a.parameter='','ALLE',p.abkuerzung),CONCAT(g.name,' ',g.kennziffer)) as auswahl,
|
|
DATE_FORMAT(a.von,'%d.%m.%Y') as seit, if(a.bis='0000-00-00','aktuell',DATE_FORMAT(a.bis,'%d.%m.%Y')) as bis
|
|
FROM adresse_rolle a LEFT JOIN projekt p ON a.parameter=p.id
|
|
LEFT JOIN gruppen g ON g.id=a.parameter
|
|
WHERE a.adresse='$id'",0,"");
|
|
$table->DisplayNew('ROLLEN','Bis','noAction');
|
|
|
|
|
|
$table2 = new EasyTable($this->app);
|
|
$table2->Query("SELECT if(l.standardlieferadresse,CONCAT('<strong>',l.name,' (Standardlieferadresse)</strong>'),l.name) as name2, l.strasse,
|
|
l.land, l.plz, l.ort, l.telefon,l.email FROM lieferadressen l where l.adresse='". $id . "' AND l.name!='Neuer Datensatz'",0,"");
|
|
$table2->DisplayNew('LIEFERANTEN','Email','noAction');
|
|
|
|
$table3 = new EasyTable($this->app);
|
|
$table3->Query($this->GetAddressCrmSql($id, 15),0,"");
|
|
$table3->DisplayNew('CRMDATEIEN','PDF','noAction');
|
|
}
|
|
if($parsetarget=='')
|
|
{
|
|
$this->app->Tpl->Output('adresse_minidetail.tpl');
|
|
$this->app->ExitXentral();
|
|
}
|
|
$this->app->Tpl->Parse($parsetarget,'adresse_minidetail.tpl');
|
|
}
|
|
|
|
|
|
public function AdresseStammblatt()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$projekt = '';
|
|
if(class_exists('AdressstammblattPDFCustom'))
|
|
{
|
|
$Brief = new AdressstammblattPDFCustom($this->app,$projekt);
|
|
}else{
|
|
$Brief = new AdressstammblattPDF($this->app,$projekt);
|
|
}
|
|
|
|
$Brief->GetAdressstammblatt($id);
|
|
$Brief->displayDocument();
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
|
|
|
|
function AdresseMiniDetailZeit() {
|
|
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
|
|
if(strpos($_SERVER['HTTP_REFERER'],'action=brief')!==false) {
|
|
|
|
$data = explode('||', $id);
|
|
/*
|
|
echo '<pre>';
|
|
print_r($data);
|
|
echo '</pre>';
|
|
*/
|
|
|
|
if (isset($data[1])) {
|
|
|
|
$query = '';
|
|
|
|
switch ($data[1]) {
|
|
case 'dokumente':
|
|
$query .= '
|
|
SELECT
|
|
von as personVon,
|
|
content as content,
|
|
DATE_FORMAT(datum, "%d.%m.%Y") as datum
|
|
FROM
|
|
dokumente
|
|
WHERE
|
|
id = ' . $data[0] . '
|
|
';
|
|
break;
|
|
case 'dokumente_send':
|
|
$query .= '
|
|
SELECT
|
|
bearbeiter as personVon,
|
|
text as content,
|
|
DATE_FORMAT(zeit, "%d.%m.%Y") as datum
|
|
FROM
|
|
dokumente_send
|
|
WHERE
|
|
id = ' . $data[0] . '
|
|
';
|
|
break;
|
|
case 'ticket_nachricht':
|
|
$query .= '
|
|
SELECT
|
|
verfasser as personVon,
|
|
text as content,
|
|
DATE_FORMAT(zeit, "%d.%m.%Y") as datum
|
|
FROM
|
|
ticket_nachricht
|
|
WHERE
|
|
id = ' . $data[0] . '
|
|
';
|
|
break;
|
|
case 'emailbackup_mails':
|
|
$query .= '
|
|
SELECT
|
|
sender as personVon,
|
|
if(action_html!="",action_html,action) as content,
|
|
DATE_FORMAT(empfang, "%d.%m.%Y") as datum
|
|
FROM
|
|
emailbackup_mails
|
|
WHERE
|
|
id = ' . $data[0] . '
|
|
';
|
|
break;
|
|
default:
|
|
$this->app->ExitXentral();
|
|
break;
|
|
}
|
|
|
|
$res = $this->app->DB->SelectRow($query);
|
|
|
|
if ($res) {
|
|
|
|
echo '<table cellpadding="0" cellspacing="0" width="100%" border=1>';
|
|
|
|
echo '<tr>';
|
|
echo '<td width="150">Datum:</td>';
|
|
echo '<td>' . $res['datum'] . '</td>';
|
|
echo '</tr>';
|
|
|
|
echo '<tr>';
|
|
echo '<td width="150">Von:</td>';
|
|
echo '<td>' . $res['personVon'] . '</td>';
|
|
echo '</tr>';
|
|
|
|
echo '<tr>';
|
|
echo '<td>Text:</td>';
|
|
echo '<td>' . nl2br($res['content']) . '</td>';
|
|
echo '</tr>';
|
|
|
|
echo '</table>';
|
|
|
|
}
|
|
|
|
/*
|
|
echo '<pre>';
|
|
print_r($query);
|
|
print_r($res);
|
|
echo '</pre>';
|
|
*/
|
|
|
|
|
|
}
|
|
|
|
|
|
//echo $id;
|
|
|
|
} else {
|
|
|
|
|
|
$tmp = $this->app->DB->SelectArr("SELECT * FROM zeiterfassung WHERE id='$id'");
|
|
$tmp = $tmp[0];
|
|
$teilprojekt = $this->app->DB->Select("SELECT aufgabe FROM arbeitspaket WHERE id='".$tmp[arbeitspaket]."'");
|
|
|
|
echo '<table width="710">';
|
|
echo '<tr><td width="200"><b>Ort:</b></td><td>'.$tmp['ort'].'</td></tr>';
|
|
echo '<tr><td><b>Tätigkeit:</b></td><td>'.$tmp['aufgabe'].'</td></tr>';
|
|
echo '<tr valign="top"><td><b>Beschreibung:</b></td><td>'.nl2br($tmp['beschreibung']).'</td></tr>';
|
|
echo '<tr><td><b>Teilprojekt:</b></td><td>'.$teilprojekt.'</td></tr>';
|
|
echo '<tr><td><b>Kostenstelle:</b></td><td>'.$tmp['kostenstelle'].'</td></tr>';
|
|
echo '<tr><td><b>Verrechnungsart:</b></td><td>'.$tmp['verrechnungsart'].'</td></tr>';
|
|
echo '</table>';
|
|
|
|
}
|
|
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
function AdresseAbrechnungzeitabgeschlossen()
|
|
{
|
|
$sid = $this->app->Secure->GetPOST('sid');
|
|
$id = $this->app->Secure->GetGET('id');
|
|
if($sid > 0){
|
|
$this->app->DB->Update("UPDATE zeiterfassung SET ist_abgerechnet='1', abgerechnet='1' WHERE id='$sid' AND adresse_abrechnung='$id' LIMIT 1");
|
|
}
|
|
$this->AdresseAbrechnungzeit();
|
|
}
|
|
|
|
|
|
function AdresseAbrechnungzeitdelete()
|
|
{
|
|
$sid = $this->app->Secure->GetGET('sid');
|
|
$id = $this->app->Secure->GetGET('id');
|
|
if($sid > 0){
|
|
$this->app->DB->Delete("DELETE FROM zeiterfassung WHERE id='$sid' AND adresse_abrechnung='$id' LIMIT 1");
|
|
}
|
|
$this->AdresseAbrechnungzeit();
|
|
}
|
|
|
|
|
|
|
|
function AdresseZeiterfassung()
|
|
{
|
|
$this->AdresseMenu();
|
|
$this->app->Tpl->Add('OFFENE','<form action="" method="post">');
|
|
$this->app->YUI->TableSearch('OFFENE','zeiterfassungmitarbeiter');
|
|
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
$back=$this->app->erp->base64_url_encode("index.php?module=adresse&action=abrechnungzeit&id=$id");
|
|
|
|
$this->app->Tpl->Set('BACK',$back);
|
|
$this->app->Tpl->Set('ID',$id);
|
|
|
|
$this->app->Tpl->Parse('PAGE','adresse_zeiterfassung.tpl');
|
|
}
|
|
|
|
|
|
|
|
function AdresseAbrechnungzeit()
|
|
{
|
|
$this->AdresseMenu();
|
|
$this->app->Tpl->Set('VERS','Professional');
|
|
$this->app->Tpl->Set('MODUL','Professional');
|
|
$this->app->Tpl->Parse('PAGE', 'only_version.tpl');
|
|
}
|
|
|
|
|
|
function AdresseCreateDokument()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$cmd = $this->app->Secure->GetGET('cmd');
|
|
|
|
$relocation = true;
|
|
|
|
switch($cmd)
|
|
{
|
|
case 'auftrag': $newid = $this->app->erp->CreateAuftrag($id); $this->app->erp->LoadAuftragStandardwerte($newid,$id); break;
|
|
case 'angebot': $newid = $this->app->erp->CreateAngebot($id); $this->app->erp->LoadAngebotStandardwerte($newid,$id); break;
|
|
case 'rechnung': $newid = $this->app->erp->CreateRechnung($id); $this->app->erp->LoadRechnungStandardwerte($newid,$id); break;
|
|
case 'lieferschein': $newid = $this->app->erp->CreateLieferschein($id); $this->app->erp->LoadLieferscheinStandardwerte($newid,$id); break;
|
|
case 'gutschrift': $newid = $this->app->erp->CreateGutschrift($id); $this->app->erp->LoadGutschriftStandardwerte($newid,$id); break;
|
|
case 'bestellung': $newid = $this->app->erp->CreateBestellung($id); $this->app->erp->LoadBestellungStandardwerte($newid,$id);break;
|
|
default: $relocation = false;
|
|
}
|
|
|
|
if($relocation)
|
|
{
|
|
$this->app->Location->execute("index.php?module=$cmd&action=edit&id=$newid");
|
|
}
|
|
|
|
}
|
|
|
|
function AdresseLohnStundensatzUebersicht()
|
|
{
|
|
$this->AdresseMenu();
|
|
|
|
if(method_exists($this->app->erp,'GetTmpMessageOut'))
|
|
{
|
|
$this->app->Tpl->Set('MESSAGE',$this->app->erp->GetTmpMessageOut());
|
|
}else{
|
|
$msg = $this->app->erp->base64_url_decode($this->app->Secure->GetGET("msg"));
|
|
if($msg!='') {
|
|
$this->app->Tpl->Set('MESSAGE', $msg);
|
|
}
|
|
}
|
|
$this->AdresseLohn();
|
|
$this->AdresseStundensatz();
|
|
|
|
$this->app->Tpl->Parse('PAGE','adresse_lohn.tpl');
|
|
}
|
|
|
|
function AdresseLohn()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
if(is_numeric($id))
|
|
{
|
|
$this->app->YUI->TableSearch('TAB1','adresselohn');
|
|
}else{
|
|
$this->app->Tpl->Set('MESSAGE', '<div class="error">Mitarbeiter-ID konnte nicht gefunden werden.</div>');
|
|
}
|
|
|
|
}
|
|
|
|
function AdresseStundensatz($id)
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
if(is_numeric($id))
|
|
{
|
|
$stundensatz = $this->app->Secure->GetPOST('Stundensatz_StandardStundensatz');
|
|
$submit = $this->app->Secure->GetPOST('Stundensatz_Submit');
|
|
|
|
// Speichere neuen Stundensatz
|
|
if($submit!='')
|
|
{
|
|
$this->app->DB->Insert("INSERT INTO stundensatz (adresse, satz, typ, projekt, datum) VALUES ('$id', '$stundensatz', 'Standard', '0', NOW())");
|
|
$this->app->Tpl->Set('MESSAGE', '<div class="success">Der neue Standard-Stundensatz wurde übernommen.</div>');
|
|
}
|
|
|
|
// Hole neuesten Stundensatz
|
|
$standard = $this->app->DB->Select("SELECT satz
|
|
FROM stundensatz
|
|
WHERE typ='standard'
|
|
AND adresse='$id'
|
|
ORDER BY datum DESC LIMIT 1");
|
|
$this->app->Tpl->Set('STANDARDSTUNDENSATZ', $standard);
|
|
|
|
// Fülle Projekt-Tabelle
|
|
$this->app->YUI->TableSearch('TAB2',"adressestundensatz");
|
|
}else
|
|
$this->app->Tpl->Set('MESSAGE', "<div class=\"error\">Mitarbeiter-ID konnte nicht gefunden werden.</div>");
|
|
}
|
|
|
|
function AdresseStundensatzEdit()
|
|
{
|
|
$this->AdresseMenu();
|
|
|
|
$user = $this->app->Secure->GetGET('user');
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$projekt = $this->app->Secure->GetGET('projekt');
|
|
|
|
$satz = $this->app->Secure->GetPOST('Stundensatz_Angepasst');
|
|
$adapt = $this->app->Secure->GetPOST('Stundensatz_Adapt');
|
|
$cancel = $this->app->Secure->GetPOST('Stundensatz_Angepasst_Cancel');
|
|
$submit = $this->app->Secure->GetPOST('Stundensatz_Angepasst_Submit');
|
|
|
|
|
|
if($cancel!='')
|
|
{
|
|
$this->app->Location->execute("index.php?module=adresse&action=lohn&id=$user");
|
|
}
|
|
|
|
|
|
// Hole neuesten Standard-Stundensatz
|
|
$standard = $this->app->DB->Select("SELECT satz
|
|
FROM stundensatz
|
|
WHERE typ='standard'
|
|
AND adresse='$user'
|
|
ORDER BY datum DESC LIMIT 1");
|
|
|
|
if(is_numeric($id))
|
|
{
|
|
// Stundensatz existiert bereits, hole Daten
|
|
$stundensatz = $this->app->DB->SelectArr("SELECT * FROM stundensatz WHERE id='$id' LIMIT 1");
|
|
$this->app->Tpl->Set('STUNDENSATZANGEPASST', $stundensatz[0][satz]);
|
|
|
|
if($submit!='')
|
|
{
|
|
$projekt = $this->app->DB->Select("SELECT projekt FROM stundensatz WHERE id='$id' LIMIT 1");
|
|
|
|
if($adapt!=''){
|
|
$this->app->DB->Update("UPDATE stundensatz SET satz='$satz' WHERE adresse='$user' AND projekt='$projekt'");
|
|
}
|
|
|
|
$this->app->DB->Insert("INSERT INTO stundensatz (adresse, satz, typ, projekt, datum)
|
|
VALUES ('$user', '$satz', 'Angepasst', '$projekt', NOW())");
|
|
$this->app->Location->execute("index.php?module=adresse&action=lohn&id=$user&msg=$msg");
|
|
}
|
|
|
|
|
|
$this->app->Tpl->Set('MODE', 'Stundensatz editieren');
|
|
}else
|
|
{
|
|
// Stundensatz existiert noch nicht
|
|
$this->app->Tpl->Set('STUNDENSATZANGEPASST', $standard);
|
|
$this->app->Tpl->Set('ADAPTDISABLED', 'DISABLED');
|
|
|
|
if($submit!='')
|
|
{
|
|
// Schreibe neuen Satz
|
|
$this->app->DB->Insert("INSERT INTO stundensatz (adresse, satz, typ, projekt, datum)
|
|
VALUES ('$user', '$satz', 'Angepasst', '$projekt', NOW())");
|
|
|
|
$msg = $this->app->erp->base64_url_encode('<div class="success">Der Stundensatz wurde erfolgreich gespeichert.</div>');
|
|
$this->app->Location->execute("index.php?module=adresse&action=lohn&id=$user&msg=$msg");
|
|
}
|
|
|
|
$this->app->Tpl->Set('MODE', 'Stundensatz erstellen');
|
|
}
|
|
|
|
$this->app->Tpl->Parse('PAGE', 'adresse_stundensatz_edit.tpl');
|
|
}
|
|
|
|
function AdresseStundensatzDelete()
|
|
{
|
|
$user = $this->app->Secure->GetGET('user');
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
if(is_numeric($id)){
|
|
$this->app->DB->Delete("DELETE FROM stundensatz WHERE id='$id' LIMIT 1");
|
|
}
|
|
else{
|
|
$msg = $this->app->erp->base64_url_encode('<div class="error">Stundensatz-ID konnte nicht gefunden werden. Standard-Stundensätze können nicht gelöscht werden.</div>');
|
|
}
|
|
|
|
$this->app->Location->execute("index.php?module=adresse&action=lohn&id=$user&msg=$msg");
|
|
}
|
|
|
|
|
|
|
|
function AdresseAutoComplete()
|
|
{
|
|
|
|
$table = $this->app->Secure->GetGET('table');
|
|
$filter = $this->app->Secure->GetGET('filter');
|
|
$name = $this->app->Secure->GetGET('name');
|
|
$query = $this->app->Secure->GetGET('query');
|
|
$colsstring = $this->app->erp->base64_url_decode($this->app->Secure->GetGET('colsstring'));
|
|
$returncol= $this->app->erp->base64_url_decode($this->app->Secure->GetGET('returncol'));
|
|
if($table==''){
|
|
$table = $name;
|
|
}
|
|
|
|
if($filter==='kunde'){
|
|
$filter = "LEFT JOIN adresse_rolle ON adresse_rolle.adresse=adresse.id WHERE adresse_rolle.subjekt='Kunde' AND adresse.kundennummer!=0 AND adresse.geloescht=0 AND adresse.name LIKE '%$query%'";
|
|
}
|
|
elseif($filter==='mitarbeiter'){
|
|
$filter = "LEFT JOIN adresse_rolle ON adresse_rolle.adresse=adresse.id WHERE (adresse_rolle.subjekt='Mitarbeiter' OR adresse_rolle.subjekt='Externer Mitarbeiter') AND adresse.mitarbeiternummer!=0 AND adresse.geloescht=0
|
|
AND adresse.name LIKE '%$query%'";
|
|
}
|
|
elseif($filter==='lieferant'){
|
|
$filter = "LEFT JOIN adresse_rolle ON adresse_rolle.adresse=adresse.id WHERE adresse_rolle.subjekt='Lieferant' AND adresse.geloescht=0 AND adresse.name LIKE '%$query%'";
|
|
}elseif($filter==='kunde_auftrag'){
|
|
$filter = "LEFT JOIN adresse_rolle ON adresse_rolle.adresse=adresse.id LEFT JOIN auftrag ON auftrag.adresse=adresse.id WHERE adresse_rolle.subjekt='Kunde' AND ((auftrag.status='freigegeben' OR auftrag.status='storniert') OR (auftrag.vorkasse_ok=0 AND (auftrag.zahlungsweise='paypal' OR auftrag.zahlungsweise='vorkasse' OR auftrag.zahlungsweise='kreditkarte'))) AND adresse.geloescht=0
|
|
AND adresse.name LIKE '%$query%'";
|
|
}elseif($filter==='kunde_rechnung'){
|
|
$filter = "LEFT JOIN adresse_rolle ON adresse_rolle.adresse=adresse.id LEFT JOIN rechnung ON rechnung.adresse=adresse.id WHERE adresse_rolle.subjekt='Kunde' AND rechnung.ist < rechnung.soll AND adresse.geloescht=0 AND adresse.name LIKE '%$query%'";
|
|
}elseif($filter==='kunde_gutschrift'){
|
|
$filter = "LEFT JOIN adresse_rolle ON adresse_rolle.adresse=adresse.id LEFT JOIN gutschrift ON gutschrift.adresse=adresse.id WHERE adresse_rolle.subjekt='Kunde' AND adresse.geloescht=0 AND adresse.name LIKE '%$query%'";
|
|
}elseif($table==='artikel'){
|
|
$filter = "WHERE name_de LIKE '%$query%'";
|
|
}elseif(($filter=='' || $filter==='adresse') && $name==='adresse'){
|
|
$filter = "WHERE adresse.geloescht=0 AND adresse.name LIKE '%$query%'";
|
|
}
|
|
$arr = $this->app->DB->SelectArr("SELECT DISTINCT $colsstring, $returncol FROM $table $filter ORDER by 1 LIMIT 10");
|
|
// echo "SELECT DISTINCT $colsstring, $returncol FROM $table $filter ORDER by 1";
|
|
|
|
$cols = explode(',',$colsstring);
|
|
foreach($arr as $key=>$value){
|
|
//$tpl_end .= '{id:"'.$value[$returncol].'", cola:"'.$value[$cols[0]].'", colb:"'.$value[$cols[1]].'", colc:"'.$value[$cols[2]].'"},';
|
|
echo $value[$returncol].'!*!'.$value[$cols[0]].' '.$value[$cols[1]].' '.$value[$cols[2]]."\n";
|
|
//echo $value[$cols[0]].' '.$value[$cols[1]].' '.$value[$cols[2]]."\n";
|
|
//echo $value[$cols[0]]."\n";
|
|
}
|
|
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
|
|
function AdresseDateien()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$this->AdresseMenu();
|
|
$this->app->Tpl->Add('UEBERSCHRIFT',' (Dateien)');
|
|
$this->app->YUI->DateiUpload('PAGE','Adressen',$id);
|
|
}
|
|
|
|
|
|
function AdresseDelete()
|
|
{
|
|
$id = (int)$this->app->Secure->GetGET('id');
|
|
|
|
$checkuser = $this->app->DB->Select("SELECT count(id) FROM user WHERE adresse='$id'");
|
|
$checkkassierer = $this->app->DB->Select("SELECT count(id) FROM pos_kassierer WHERE adresse='$id'");
|
|
$checkabo = $this->app->DB->Select("SELECT COUNT(id) FROM abrechnungsartikel WHERE adresse = '$id'");
|
|
|
|
if($id > 0){
|
|
$msg = '';
|
|
if($checkuser > 0){
|
|
$msg .= $this->app->erp->base64_url_encode("<div class=\"error\">Die Adresse ist noch mit einem Benutzer verlinkt und kann daher nicht gelöscht werden.</div>");
|
|
}else if($checkkassierer){
|
|
$msg .= $this->app->erp->base64_url_encode("<div class=\"error\">Die Adresse ist noch mit einem Kassierer verlinkt und kann daher nicht gelöscht werden.</div>");
|
|
}else if($checkabo > 0){
|
|
$msg .= $this->app->erp->base64_url_encode("<div class=\"error\">Die Adresse ist noch mit Abos verlinkt und kann daher nicht gelöscht werden.</div>");
|
|
}else {
|
|
$this->app->DB->Update("UPDATE adresse SET geloescht='1',kundennummer=CONCAT('DEL-',kundennummer), lieferantennummer=CONCAT('DEL-',lieferantennummer),
|
|
mitarbeiternummer=CONCAT('DEL-',mitarbeiternummer) WHERE id='$id' LIMIT 1");
|
|
|
|
$this->app->DB->Update("DELETE FROM ansprechpartner WHERE adresse='$id'");
|
|
$this->app->DB->Update("DELETE FROM lieferadressen WHERE adresse='$id'");
|
|
$this->app->DB->Update("DELETE FROM adresse_rolle WHERE adresse='$id'");
|
|
$this->app->DB->Update("DELETE FROM dokumente WHERE adresse='$id'");
|
|
$this->app->DB->Update("DELETE FROM dokumente_send WHERE adresse='$id'");
|
|
|
|
$this->app->erp->ObjektProtokoll("adresse",$id,"adresse_delete","Adresse geloescht: $id");
|
|
$this->app->erp->RunHook('address_delete', 1, $id);
|
|
|
|
$msg = $this->app->erp->base64_url_encode("<div class=\"info\">Die Adresse wurde gelöscht!</div>");
|
|
}
|
|
}
|
|
$this->app->Location->execute('index.php?module=adresse&action=list&msg='.$msg);
|
|
}
|
|
|
|
|
|
function AdresseRolleDatum()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$sid = $this->app->Secure->GetPOST('sid');
|
|
$von = $this->app->Secure->GetGET('von');
|
|
$bis = $this->app->Secure->GetGET('bis');
|
|
$von = $this->app->String->Convert($von,'%1.%2.%3','%3-%2-%1');
|
|
$bis = $this->app->String->Convert($bis,'%1.%2.%3','%3-%2-%1');
|
|
|
|
$this->app->DB->Delete("UPDATE adresse_rolle SET von='$von', bis='$bis' WHERE id='$sid' AND adresse='$id' LIMIT 1");
|
|
|
|
$gruppe = $this->app->DB->Select("SELECT parameter FROM adresse_rolle WHERE id='$sid' AND adresse='$id' LIMIT 1");
|
|
|
|
if($gruppe > 0)
|
|
{
|
|
if($von!='--' && $bis!='--')
|
|
{
|
|
$this->app->DB->Update("UPDATE auftrag SET gruppe='$gruppe' WHERE datum<='$bis' AND datum >='$von' AND adresse='$id'");
|
|
$this->app->DB->Update("UPDATE rechnung SET gruppe='$gruppe' WHERE datum<='$bis' AND datum >='$von' AND adresse='$id'");
|
|
$this->app->DB->Update("UPDATE gutschrift SET gruppe='$gruppe' WHERE datum<='$bis' AND datum >='$von' AND adresse='$id'");
|
|
} else if($von!='--' && $bis=='--')
|
|
{
|
|
$this->app->DB->Update("UPDATE auftrag SET gruppe='$gruppe' WHERE datum>='$von' AND adresse='$id'");
|
|
$this->app->DB->Update("UPDATE rechnung SET gruppe='$gruppe' WHERE datum>='$von' AND adresse='$id'");
|
|
$this->app->DB->Update("UPDATE gutschrift SET gruppe='$gruppe' WHERE datum>='$von' AND adresse='$id'");
|
|
}
|
|
}
|
|
|
|
$this->AdresseRollen();
|
|
}
|
|
|
|
|
|
function AdresseGruppen()
|
|
{
|
|
$this->AdresseMenu();
|
|
|
|
$id = (int)$this->app->Secure->GetGET('id');
|
|
$gid=(int)$this->app->Secure->GetPOST('gid');
|
|
$value=(int)$this->app->Secure->GetPOST('value');
|
|
|
|
if($gid>0)
|
|
{
|
|
if($value=='1'){
|
|
$this->app->erp->AddRolleZuAdresse($id, 'Mitglied', 'von','Gruppe', $gid);
|
|
}else{
|
|
$this->app->DB->Delete("UPDATE adresse_rolle SET bis=DATE_SUB(NOW(),INTERVAL 1 DAY) WHERE parameter='$gid' AND adresse='$id'
|
|
AND (subjekt='Mitglied' OR subjekt='Kunde') AND objekt='Gruppe' AND bis = '0000-00-00'");
|
|
}
|
|
$this->app->erp->RunHook('adresse_gruppen_change', 3, $id, $gid, $value);
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
$this->app->YUI->TableSearch('TAB1','adresse_gruppen');
|
|
|
|
$this->app->Tpl->Parse('PAGE','adresse_gruppen.tpl');
|
|
}
|
|
|
|
|
|
function AdresseRolleDelete()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$sid = $this->app->Secure->GetGET('sid');
|
|
if($sid > 0){
|
|
$this->app->DB->Delete("DELETE FROM adresse_rolle WHERE id='$sid' AND adresse='$id' LIMIT 1");
|
|
}
|
|
// $this->app->Secure->POST['rolleanlegen'] = "true";
|
|
//$this->AdresseEdit();
|
|
$this->AdresseRollen();
|
|
//$this->app->Tpl->Set(AKTIV_TAB3,"selected");
|
|
}
|
|
|
|
function AdresseCreate()
|
|
{
|
|
$cmd = $this->app->Secure->GetGET('cmd');
|
|
if($cmd === 'duplicate'){
|
|
$error = false;
|
|
|
|
$name = trim($this->app->Secure->GetPOST('name'));
|
|
$street = trim($this->app->Secure->GetPOST('street'));
|
|
$zipcode = trim($this->app->Secure->GetPOST('zipcode'));
|
|
$place = trim($this->app->Secure->GetPOST('place'));
|
|
|
|
$where = '';
|
|
|
|
if($name !== ''){
|
|
$where .= " name = '$name' AND";
|
|
}
|
|
if($street !== ''){
|
|
$where .= " strasse = '$street' AND";
|
|
}
|
|
if($zipcode !== ''){
|
|
$where .= " plz = '$zipcode' AND";
|
|
}
|
|
if($place !== ''){
|
|
$where .= " ort = '$place' AND";
|
|
}
|
|
|
|
if($where !== ''){
|
|
$where = rtrim($where, 'AND');
|
|
|
|
$addressId = $this->app->DB->Select("SELECT id FROM adresse WHERE ".$where." LIMIT 1");
|
|
if($addressId != '' && $addressId > 0){
|
|
$error = true;
|
|
}
|
|
}
|
|
|
|
header('Content-Type: application/json');
|
|
echo json_encode($error);
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
$this->app->ModuleScriptCache->IncludeJavascriptFiles('address', ['./classes/Modules/Address/www/js/address_create.js']);
|
|
|
|
$this->app->erp->Headlines('Adresse anlegen');
|
|
$this->app->Tpl->Set('TOPHEADING','Adresse anlegen');
|
|
|
|
$this->app->erp->MenuEintrag('index.php?module=adresse&action=list','Zurück zur Übersicht');
|
|
|
|
|
|
parent::AdresseCreate();
|
|
}
|
|
|
|
|
|
function AdresseSuche()
|
|
{
|
|
$this->app->erp->MenuEintrag('index.php?module=adresse&action=list','Übersicht');
|
|
$this->app->erp->MenuEintrag('index.php?module=adresse&action=create','Neue Adresse anlegen');
|
|
|
|
$this->app->YUI->TableSearch('TAB1','adresse_suche');
|
|
$this->app->Tpl->Parse('PAGE','adresse_suche.tpl');
|
|
}
|
|
|
|
function AdresseMenuList()
|
|
{
|
|
$this->app->erp->MenuEintrag('index.php?module=adresse&action=list','Übersicht');
|
|
$this->app->erp->MenuEintrag('index.php?module=adresse&action=create','Neue Adresse anlegen');
|
|
$this->app->erp->RunMenuHook('adresselist');
|
|
}
|
|
|
|
|
|
function AdresseList()
|
|
{
|
|
$parameter = $this->app->User->GetParameter('table_filter_adresse');
|
|
$parameter = json_decode($parameter, true);
|
|
|
|
$this->AdresseMenuList();
|
|
$zahlungsweisetext = null;
|
|
$zahlungsweisentabelle = $this->app->DB->SelectArr("SELECT type,bezeichnung FROM `zahlungsweisen` WHERE aktiv = 1 AND type <> '' AND bezeichnung <> ''");
|
|
if($zahlungsweisentabelle)
|
|
{
|
|
foreach($zahlungsweisentabelle as $v)
|
|
{
|
|
$zahlungsweisetext[$v['type']] = $v['bezeichunng'];
|
|
}
|
|
}
|
|
|
|
$zahlungsweisen_ = $this->app->DB->SelectArr('
|
|
SELECT
|
|
zahlungsweise, zahlungsweiselieferant
|
|
FROM
|
|
adresse WHERE ifnull(geloescht, 0) = 0 AND (zahlungsweise <> \'\' OR zahlungsweiselieferant <> \'\')
|
|
GROUP BY
|
|
zahlungsweise, zahlungsweiselieferant
|
|
');
|
|
$zahlungsweisen = null;
|
|
if($zahlungsweisen_)
|
|
{
|
|
foreach($zahlungsweisen_ as $v)
|
|
{
|
|
if($v['zahlungsweise'] != '' && (!is_array($zahlungsweisen) || !in_array($v['zahlungsweise'], $zahlungsweisen))){
|
|
$zahlungsweisen[] = $v['zahlungsweise'];
|
|
}
|
|
if($v['zahlungsweiselieferant'] != '' && (!is_array($zahlungsweisen) || !in_array($v['zahlungsweiselieferant'],$zahlungsweisen))){
|
|
$zahlungsweisen[] = $v['zahlungsweiselieferant'];
|
|
}
|
|
}
|
|
if($zahlungsweisen){
|
|
sort($zahlungsweisen);
|
|
}
|
|
}
|
|
|
|
|
|
$zahlungsweiseStr = '';
|
|
if ($zahlungsweisen) {
|
|
foreach ($zahlungsweisen as $zahlungsweise) {
|
|
$zahlungsweiseStr .= '<option value="' . $zahlungsweise . '">' . (isset($zahlungsweisetext[$zahlungsweise])?$zahlungsweisetext[$zahlungsweise]:ucfirst($zahlungsweise)) . '</option>';
|
|
}
|
|
}
|
|
|
|
$rollen = $this->app->DB->SelectArr('
|
|
SELECT
|
|
*
|
|
FROM
|
|
adresse_rolle
|
|
GROUP BY
|
|
subjekt
|
|
');
|
|
|
|
$rollenStr = '';
|
|
if ($rollen) {
|
|
foreach ($rollen as $rolle) {
|
|
$rollenStr .= '<option value="' . $rolle['subjekt'] . '">' . $rolle['subjekt'] . '</option>';
|
|
}
|
|
}
|
|
|
|
$gruppen = $this->app->DB->SelectArr("SELECT * FROM gruppen gr WHERE (art = 'gruppe' or art = 'preisgruppe') AND (projekt = 0 OR (1 ".$this->app->erp->ProjektRechte('gr.projekt')."))");
|
|
|
|
$gruppenStr = '';
|
|
if ($gruppen) {
|
|
foreach ($gruppen as $gruppe) {
|
|
$gruppenStr .= '<option value="' . $gruppe['id'] . '">' . $gruppe['name'] . '</option>';
|
|
}
|
|
}
|
|
|
|
$laender = $this->app->erp->GetSelectLaenderliste();
|
|
$laenderStr = '';
|
|
foreach ($laender as $landKey => $land) {
|
|
$laenderStr .= '<option value="' . $landKey . '">' . $land . '</option>';
|
|
}
|
|
|
|
if( $this->app->erp->ModulVorhanden('verband') ) {
|
|
$verbandsnummer = '';
|
|
$verbandsnummer .= '<tr>';
|
|
$verbandsnummer .= '<td>Verbandsnummer:</td>';
|
|
$verbandsnummer .= '<td><input type="text" name="verbandsnummer" value=""></td>';
|
|
$verbandsnummer .= '</tr>';
|
|
$this->app->Tpl->Add('VERBANDSNUMMER',$verbandsnummer);
|
|
}
|
|
|
|
$this->app->YUI->AutoComplete('projekt', 'projektname', 1);
|
|
$this->app->YUI->AutoComplete('name', 'adressename', 1);
|
|
$this->app->YUI->AutoComplete('kundennummer', 'kunde', 1);
|
|
$this->app->YUI->AutoComplete('vertrieb','adressegruppevertriebbearbeiter', 0, '&typ=vertrieb');
|
|
$this->app->YUI->AutoComplete('innendienst','adressegruppevertriebbearbeiter', 0, '&typ=bearbeiter');
|
|
$this->app->Tpl->Add('ZAHLUNGSWEISEN',$zahlungsweiseStr);
|
|
$this->app->Tpl->Add('ROLLEN',$rollenStr);
|
|
$this->app->Tpl->Add('GRUPPEN',$gruppenStr);
|
|
$this->app->Tpl->Add('LAENDER',$laenderStr);
|
|
$this->app->Tpl->Parse('TAB1','adresse_table_filter.tpl');
|
|
|
|
$this->app->YUI->TableSearch('TAB1','adressetabelle');
|
|
if($this->app->erp->Firmendaten('schnellsuche')){
|
|
$this->app->YUI->EnterSearch('SCHNELLSUCHE', 'adressetabelle');
|
|
}
|
|
$this->app->Tpl->Parse('PAGE','adresseuebersicht.tpl');
|
|
}
|
|
|
|
|
|
function AdresseMenu()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
$nummer = $this->app->DB->Select("SELECT CONCAT(
|
|
if(kundennummer!='',CONCAT('Kunde: ',kundennummer),''),
|
|
if(lieferantennummer!='',CONCAT(' Lieferant: ',lieferantennummer),'')) FROM adresse WHERE id='$id' AND geloescht=0 LIMIT 1");
|
|
|
|
if(is_numeric($id)){
|
|
$name = $this->app->DB->Select("SELECT name FROM adresse WHERE id='$id' AND geloescht=0 LIMIT 1");
|
|
}
|
|
|
|
if(isset($name) && $name!=''){
|
|
$this->app->Tpl->SetText('UEBERSCHRIFT', 'Adresse von: ' . $name);
|
|
}
|
|
else{
|
|
$this->app->Tpl->SetText('UEBERSCHRIFT', 'Adressen');
|
|
}
|
|
|
|
$this->app->Tpl->SetText('KURZUEBERSCHRIFT','Adressen');
|
|
if(isset($name) && isset($nummer) && $name!='' && $nummer!=''){
|
|
$this->app->Tpl->SetText('KURZUEBERSCHRIFT2', "$name ($nummer)");
|
|
}
|
|
else{
|
|
$this->app->Tpl->SetText('KURZUEBERSCHRIFT2', !empty($name) ? $name : '');
|
|
}
|
|
|
|
if(isset($name)){
|
|
$this->app->Tpl->SetText('ANZEIGENUMMER',$name);
|
|
}
|
|
if(isset($nummer)){
|
|
$this->app->Tpl->SetText('ANZEIGENAMEDE',' '.$nummer);
|
|
}
|
|
|
|
$cmd = $this->app->Secure->GetPOST('cmd');
|
|
|
|
if($cmd==='crm')
|
|
{
|
|
$this->app->erp->MenuEintrag('index.php?module=crm&action=list','Zurück zur Übersicht');
|
|
}
|
|
|
|
$this->app->erp->MenuEintrag('index.php?module=adresse&action=create','Neue Adresse anlegen');
|
|
|
|
$this->app->erp->MenuEintrag("index.php?module=adresse&action=edit&id=$id",'Details');
|
|
|
|
$anzahldateien = $this->app->erp->AnzahlDateien('Adressen',$id);
|
|
if($anzahldateien > 0) {
|
|
$anzahldateien = ' ('.$anzahldateien.')';
|
|
} else {
|
|
$anzahldateien='';
|
|
}
|
|
|
|
$this->app->erp->MenuEintrag("index.php?module=adresse&action=dateien&id=$id",'Dateien'.$anzahldateien);
|
|
|
|
$count = '
|
|
SELECT
|
|
SUM(anzahl)
|
|
FROM
|
|
(
|
|
|
|
(
|
|
SELECT
|
|
COUNT(id) as anzahl
|
|
FROM
|
|
dokumente
|
|
WHERE
|
|
adresse_to = ' . (int)$id . '
|
|
)
|
|
|
|
UNION ALL
|
|
|
|
(
|
|
SELECT
|
|
COUNT(id) as anzahl
|
|
FROM
|
|
dokumente_send
|
|
WHERE
|
|
adresse = ' . (int)$id . '
|
|
)';
|
|
if(1){//$this->app->erp->RechteVorhanden('ticket','list')){
|
|
$count .= '
|
|
UNION ALL
|
|
|
|
(
|
|
SELECT
|
|
COUNT(ticket.id) as anzahl
|
|
FROM
|
|
ticket
|
|
LEFT JOIN ticket_nachricht ON ticket.schluessel = ticket_nachricht.ticket
|
|
WHERE
|
|
ticket.adresse = ' . (int)$id . '
|
|
)';
|
|
}
|
|
|
|
$count .= '
|
|
UNION ALL
|
|
|
|
(
|
|
SELECT
|
|
COUNT(k.id) as anzahl
|
|
FROM
|
|
kalender_event k
|
|
LEFT JOIN adresse a2 ON k.adresseintern = a2.id
|
|
LEFT JOIN projekt p ON p.id=k.projekt
|
|
WHERE
|
|
k.adresse = ' . (int)$id . '
|
|
|
|
)';
|
|
|
|
|
|
if($this->app->erp->RechteVorhanden('wiedervorlage','list')){
|
|
$count .= '
|
|
UNION ALL
|
|
|
|
(
|
|
SELECT
|
|
COUNT(id) as anzahl
|
|
FROM
|
|
wiedervorlage
|
|
WHERE
|
|
wiedervorlage.adresse = ' . (int)$id . '
|
|
|
|
)';
|
|
}
|
|
$count .= '
|
|
) a
|
|
';
|
|
|
|
$anzahlcrm = 0;
|
|
if($id > 0){
|
|
$anzahlcrm = $this->app->DB->Select($count);
|
|
}
|
|
|
|
if($anzahlcrm > 0){
|
|
$this->app->erp->MenuEintrag("index.php?module=adresse&action=brief&id=$id", "CRM ($anzahlcrm)");
|
|
}
|
|
else{
|
|
$this->app->erp->MenuEintrag("index.php?module=adresse&action=brief&id=$id", 'CRM');
|
|
}
|
|
|
|
if($this->app->erp->Version()!=='stock'){
|
|
$this->app->erp->MenuEintrag("index.php?module=adresse&action=rollen&id=$id", 'Rollen');
|
|
}
|
|
|
|
$this->app->erp->MenuEintrag("index.php?module=adresse&action=gruppen&id=$id",'Gruppen');
|
|
|
|
|
|
|
|
if($this->app->erp->RechteVorhanden('verein','list') && $this->app->erp->Firmendaten('modul_verein')=='1'){
|
|
$this->app->erp->MenuEintrag("index.php?module=adresse&action=verein&id=$id", 'Verein');
|
|
}
|
|
|
|
|
|
// Ist Benutzer ein Mitarbeiter?
|
|
if(is_numeric($id)){
|
|
$mitarbeiter = $this->app->DB->Select("SELECT id FROM adresse_rolle WHERE adresse='$id' AND subjekt='Mitarbeiter' LIMIT 1");
|
|
}
|
|
if(is_numeric($mitarbeiter))
|
|
{
|
|
//$this->app->erp->MenuEintrag("index.php?module=adresse&action=lohn&id=$id","Lohn");
|
|
$this->app->erp->MenuEintrag("index.php?module=adresse&action=zeiterfassung&id=$id",'Zeit');
|
|
}
|
|
|
|
|
|
$anzahlansp = $this->app->DB->Select("SELECT COUNT(id) FROM ansprechpartner WHERE adresse='$id'");
|
|
if($anzahlansp>0) {
|
|
$anzahlansp = ' ('.$anzahlansp.')';
|
|
} else {
|
|
$anzahlansp='';
|
|
}
|
|
|
|
$anzahllief = $this->app->DB->Select("SELECT COUNT(id) FROM lieferadressen WHERE adresse='$id'");
|
|
if($anzahllief>0) {
|
|
$anzahllief = ' ('.$anzahllief.')';
|
|
} else {
|
|
$anzahllief='';
|
|
}
|
|
|
|
$anzahlacc = $this->app->DB->Select("SELECT COUNT(id) FROM adresse_accounts WHERE adresse='$id'");
|
|
if($anzahlacc>0) {
|
|
$anzahlacc = ' ('.$anzahlacc.')';
|
|
} else {
|
|
$anzahlacc='';
|
|
}
|
|
|
|
$this->app->erp->MenuEintrag("index.php?module=adresse&action=ansprechpartner&id=$id",'Ansprechpart.'.$anzahlansp);
|
|
$this->app->erp->MenuEintrag("index.php?module=adresse&action=lieferadresse&id=$id",'Lieferadressen'.$anzahllief);
|
|
$this->app->erp->MenuEintrag("index.php?module=adresse&action=accounts&id=$id",'Accounts'.$anzahlacc);
|
|
|
|
|
|
if($this->app->erp->IsAdresseSubjekt($id,'Kunde')){
|
|
$this->app->erp->MenuEintrag("index.php?module=adresse&action=belege&id=$id", 'Belege');
|
|
}
|
|
|
|
if($this->app->erp->Version()!=='stock'){
|
|
$this->app->erp->MenuEintrag("index.php?module=adresse&action=kundeartikel&id=$id", 'Artikel');
|
|
}
|
|
|
|
if($this->app->erp->IsAdresseSubjekt($id,'Kunde'))
|
|
{
|
|
$this->app->erp->MenuEintrag("index.php?module=adresse&action=abrechnungzeit&id=$id",'Zeitkonto');
|
|
if($this->app->erp->ModulVorhanden('rechnungslauf'))
|
|
{
|
|
$anzahlabos = $this->app->DB->Select("SELECT COUNT(id) FROM abrechnungsartikel WHERE adresse='$id' AND (enddatum = '0000-00-00' OR enddatum >= NOW())");
|
|
if($anzahlabos>0){
|
|
$this->app->erp->MenuEintrag("index.php?module=adresse&action=artikel&id=$id", "Abos ($anzahlabos)");
|
|
}
|
|
else{
|
|
$this->app->erp->MenuEintrag("index.php?module=adresse&action=artikel&id=$id", 'Abos ');
|
|
}
|
|
}
|
|
//$this->app->erp->MenuEintrag("index.php?module=adresse&action=ustprf&id=$id","USt");
|
|
}
|
|
|
|
if($this->app->erp->IsAdresseSubjekt($id,'Lieferant'))
|
|
{
|
|
$this->app->erp->MenuEintrag("index.php?module=adresse&action=lieferantartikel&id=$id",'Lieferprogramm');
|
|
$this->app->erp->MenuEintrag("index.php?module=adresse&action=offenebestellungen&id=$id",'Bestellungen');
|
|
$this->app->erp->MenuEintrag("index.php?module=adresse&action=verbindlichkeiten&id=$id",'Verbindlichkeiten');
|
|
}
|
|
|
|
|
|
$this->app->erp->MenuEintrag("index.php?module=adresse&action=ustprf&id=$id",'Ust-ID Prf.');
|
|
|
|
$this->app->erp->RunMenuHook('adresse');
|
|
}
|
|
|
|
function AdresseKontaktHistorie()
|
|
{
|
|
$this->AdresseMenu();
|
|
$this->app->Tpl->Add('UEBERSCHRIFT',' (Kontakthistorie)');
|
|
$this->app->Tpl->Set('SUBSUBHEADING','Adressen');
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
// neues arbeitspaket
|
|
$widget = new WidgetAnsprechpartner($this->app,'TAB2');
|
|
$widget->form->SpecialActionAfterExecute('none',
|
|
"index.php?module=adresse&action=ansprechpartner&id=$id");
|
|
$widget->Create();
|
|
|
|
|
|
//Formula ansprechpartner
|
|
$table = new EasyTable($this->app);
|
|
$table->Query("SELECT name, bereich, telefon, email,id FROM ansprechpartner WHERE adresse='$id'");
|
|
$table->DisplayNew('INHALT', "<a href=\"index.php?module=adresse&action=ansprechpartnereditpopup&frame=false&id=%value%\"
|
|
onclick=\"makeRequest(this);return false\">Bearbeiten</a>");
|
|
|
|
// easy table mit arbeitspaketen YUI als template
|
|
$this->app->Tpl->Parse('TAB1','rahmen70.tpl');
|
|
$this->app->Tpl->Set('AKTIV_TAB1','selected');
|
|
$this->app->Tpl->Parse('PAGE','ansprechpartneruebersicht.tpl');
|
|
}
|
|
|
|
function AdresseKontaktHistorieEditPopup()
|
|
{
|
|
$frame = $this->app->Secure->GetGET('frame');
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
if($frame=='false')
|
|
{
|
|
// hier nur fenster größe anpassen
|
|
$this->app->YUI->IframeDialog(600,320);
|
|
} else {
|
|
// nach page inhalt des dialogs ausgeben
|
|
$widget = new WidgetAnsprechpartner($this->app,'PAGE');
|
|
$adresse = $this->app->DB->Select("SELECT adresse FROM ansprechpartner WHERE id='$id' LIMIT 1");
|
|
$widget->form->SpecialActionAfterExecute('close_refresh',
|
|
"index.php?module=adresse&action=ansprechpartner&id=$adresse");
|
|
|
|
$widget->Edit();
|
|
$this->app->BuildNavigation=false;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
function AdresseRolle()
|
|
{
|
|
|
|
|
|
}
|
|
|
|
function AdresseNummern($id)
|
|
{
|
|
$tmp_data_adresse= $this->app->DB->SelectRow("SELECT * FROM adresse WHERE id='$id' AND geloescht=0 LIMIT 1");
|
|
if(is_numeric($id)) {
|
|
$kundennummer = $tmp_data_adresse['kundennummer'];
|
|
$lieferantennummer = $tmp_data_adresse['lieferantennummer'];
|
|
$mitarbeiternummer= $tmp_data_adresse['mitarbeiternummer'];
|
|
$projekt= $tmp_data_adresse['projekt'];
|
|
}
|
|
|
|
|
|
if($kundennummer=='0' || $kundennummer==''){
|
|
// pruefe ob rolle kunden vorhanden
|
|
if(is_numeric($id)){
|
|
$check = $this->app->DB->Select("SELECT adresse FROM adresse_rolle WHERE adresse='$id' AND subjekt='Kunde' LIMIT 1");
|
|
}
|
|
if(!empty($check))
|
|
{
|
|
$kundennummer = $this->app->erp->GetNextKundennummer($projekt,$tmp_data_adresse);
|
|
$this->app->erp->ObjektProtokoll('adresse',$id,'adresse_next_kundennummer',"Kundennummer erhalten: $kundennummer");
|
|
|
|
$this->app->DB->Update("UPDATE adresse SET kundennummer='$kundennummer' WHERE id='$id' AND (kundennummer='0' OR kundennummer='') LIMIT 1");
|
|
} else{
|
|
$kundennummer = 'noch keine';
|
|
}
|
|
}
|
|
|
|
if($lieferantennummer=='0'){
|
|
if(is_numeric($id)){
|
|
$check = $this->app->DB->Select("SELECT adresse FROM adresse_rolle WHERE adresse='$id' AND subjekt='Lieferant' LIMIT 1");
|
|
}else {
|
|
$check = '';
|
|
}
|
|
if($check!='')
|
|
{
|
|
$lieferantennummer= $this->app->erp->GetNextLieferantennummer($projekt,$tmp_data_adresse);
|
|
$this->app->erp->ObjektProtokoll('adresse',$id,'adresse_next_lieferantennummer',"Lieferantennummer erhalten: $lieferantennummer");
|
|
if(is_numeric($id)){
|
|
$this->app->DB->Update("UPDATE adresse SET lieferantennummer='$lieferantennummer' WHERE id='$id' AND (lieferantennummer='0' OR lieferantennummer='') LIMIT 1");
|
|
}
|
|
} else{
|
|
$lieferantennummer = 'noch keine';
|
|
}
|
|
}
|
|
|
|
if($mitarbeiternummer=='0'){
|
|
if(is_numeric($id)){
|
|
$check = $this->app->DB->Select("SELECT adresse FROM adresse_rolle WHERE adresse='$id' AND (subjekt='Mitarbeiter' OR subjekt='Externer Mitarbeiter') LIMIT 1");
|
|
}else{
|
|
$check = '';
|
|
}
|
|
if($check!='')
|
|
{
|
|
$mitarbeiternummer= $this->app->erp->GetNextMitarbeiternummer($projekt,$tmp_data_adresse);
|
|
$this->app->erp->ObjektProtokoll('adresse',$id,'adresse_next_mitarbeiternummer',"Mitarbeiternummer erhalten: $mitarbeiternummer");
|
|
if(is_numeric($id)){
|
|
$this->app->DB->Update("UPDATE adresse SET mitarbeiternummer='$mitarbeiternummer' WHERE id='$id' AND (mitarbeiternummer='0' OR mitarbeiternummer='') LIMIT 1");
|
|
}
|
|
|
|
} else{
|
|
$mitarbeiternummer = 'noch keine';
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
function AdresseDelKontakt()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$lid = $this->app->Secure->GetGET('lid');
|
|
if($lid > 0){
|
|
$this->app->DB->Delete("DELETE FROM adresse_kontakte WHERE id='$lid' LIMIT 1");
|
|
}
|
|
|
|
$this->app->Location->execute("index.php?module=adresse&action=edit&id=$id");
|
|
}
|
|
|
|
|
|
|
|
function AdresseNewKontakt()
|
|
{
|
|
$bezeichnung = $this->app->Secure->GetGET('bezeichnung');
|
|
$kontakt = $this->app->Secure->GetGET('kontakt');
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
//INSERT
|
|
$this->app->DB->Insert("INSERT INTO adresse_kontakte (id,adresse,bezeichnung,kontakt) VALUES ('','$id','$bezeichnung','$kontakt')");
|
|
|
|
$this->app->Location->execute("index.php?module=adresse&action=edit&id=$id");
|
|
}
|
|
|
|
function AdresseOpen()
|
|
{
|
|
|
|
$kundennummer=$this->app->Secure->GetGET('kundennummer');
|
|
$projekt=$this->app->Secure->GetGET('projekt');
|
|
|
|
if($projekt!='')
|
|
{
|
|
$projektid = $this->app->DB->Select("SELECT id FROM projekt WHERE abkuerzung='$projekt' LIMIT 1");
|
|
$id = $this->app->DB->Select("SELECT id FROM adresse WHERE projekt='$projektid' AND kundennummer='$kundennummer' LIMIT 1");
|
|
} else {
|
|
$id = $this->app->DB->Select("SELECT id FROM adresse WHERE kundennummer='$kundennummer' LIMIT 1");
|
|
}
|
|
|
|
$cmd=$this->app->Secure->GetPOST('cmd');
|
|
if($cmd=="") $cmd = $this->app->Secure->GetGET('cmd');
|
|
$this->app->Location->execute('index.php?module=adresse&action='.$cmd.'&id='.$id);
|
|
}
|
|
|
|
|
|
function AdresseGetid()
|
|
{
|
|
|
|
$kundennummer=$this->app->Secure->GetGET('kundennummer');
|
|
$projekt=$this->app->Secure->GetGET('projekt');
|
|
|
|
if($projekt!='')
|
|
{
|
|
$projektid = $this->app->DB->Select("SELECT id FROM projekt WHERE abkuerzung='$projekt' LIMIT 1");
|
|
$id = $this->app->DB->Select("SELECT id FROM adresse WHERE projekt='$projektid' AND kundennummer='$kundennummer' LIMIT 1");
|
|
} else {
|
|
$id = $this->app->DB->Select("SELECT id FROM adresse WHERE kundennummer='$kundennummer' LIMIT 1");
|
|
}
|
|
|
|
echo $id;
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
|
|
function AdresseEdit()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$projekt = $this->app->DB->Select("SELECT projekt FROM adresse WHERE id = '$id' LIMIT 1");
|
|
|
|
$shopid = (int)$this->app->Secure->GetGET('shop');
|
|
$export = (int)$this->app->Secure->GetGET('export');
|
|
$shops = $this->app->DB->SelectArr("SELECT id, bezeichnung, modulename, shoptyp FROM shopexport WHERE projekt = '$projekt' AND demomodus <> 1 AND aktiv = 1 AND adressupdate = 1");
|
|
|
|
if($shopid > 0){
|
|
foreach ($shops as $shop){
|
|
if((int)$shop['id'] === $shopid){
|
|
if($export){
|
|
$erg = $this->app->remote->RemoteCommand($shopid, 'sendadresse', $id);
|
|
if(isset($erg['meldung']) && (!isset($erg['fehler']) || !$erg['fehler']))
|
|
{
|
|
$msg = $this->app->erp->base64_url_encode('<div class="info">'.$erg['meldung'].'</div>');
|
|
}elseif(isset($erg['fehler']) && $erg['fehler'])
|
|
{
|
|
$msg = $this->app->erp->base64_url_encode('<div class="error">Es ist ein Fehler aufgetreten: '.$erg['fehler'].'!</div>');
|
|
}else{
|
|
$msg = $this->app->erp->base64_url_encode('<div class="error">Fehlerhafte Online-Shopkonfiguration</div>');
|
|
}
|
|
}else{
|
|
$erg = $this->app->remote->RemoteCommand($shopid, 'getadresse', $id);
|
|
if(isset($erg['meldung']) && (!isset($erg['fehler']) || !$erg['fehler']))
|
|
{
|
|
$msg = $this->app->erp->base64_url_encode('<div class="info">'.$erg['meldung'].'</div>');
|
|
}elseif(isset($erg['fehler']) && $erg['fehler'])
|
|
{
|
|
$msg = $this->app->erp->base64_url_encode('<div class="error">Es ist ein Fehler aufgetreten: '.$erg['fehler'].'!</div>');
|
|
}else{
|
|
$msg = $this->app->erp->base64_url_encode('<div class="error">Fehlerhafte Online-Shopkonfiguration</div>');
|
|
}
|
|
}
|
|
$this->app->Location->execute('index.php?module=adresse&action=edit&id='.$id.'&msg='.$msg);
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
if($this->app->erp->DisableModul('adresse',$id))
|
|
{
|
|
//$this->app->erp->MenuEintrag("index.php?module=auftrag&action=list","Zurück zur Übersicht");
|
|
$this->AdresseMenu();
|
|
return;
|
|
}
|
|
|
|
$this->app->YUI->SaveReally();
|
|
|
|
$adresse_kontakte = $this->app->Secure->GetPOST('adresse_kontakte');
|
|
if(!empty($adresse_kontakte) && (!empty($adresse_kontakte)?count($adresse_kontakte):0) > 0) {
|
|
foreach($adresse_kontakte as $key=>$value)
|
|
$this->app->DB->Update("UPDATE adresse_kontakte SET kontakt='$value' WHERE id='$key' LIMIT 1");
|
|
}
|
|
$telefon = '';
|
|
$mobil = '';
|
|
$email = '';
|
|
$internetseite = '';
|
|
if(is_numeric($id)) {
|
|
$adressarr = $this->app->DB->SelectRow("SELECT * FROM adresse WHERE id='$id' AND geloescht=0 LIMIT 1");
|
|
if(!empty($adressarr)){
|
|
$kundennummer = $adressarr['kundennummer'];//$this->app->DB->Select("SELECT kundennummer FROM adresse WHERE id='$id' AND geloescht=0 LIMIT 1");
|
|
$lieferantennummer = $adressarr['lieferantennummer'];//$this->app->DB->Select("SELECT lieferantennummer FROM adresse WHERE id='$id' AND geloescht=0 LIMIT 1");
|
|
$mitarbeiternummer = $adressarr['mitarbeiternummer'];//$this->app->DB->Select("SELECT mitarbeiternummer FROM adresse WHERE id='$id' AND geloescht=0 LIMIT 1");
|
|
$logfile = $adressarr['adresse'];//$this->app->DB->Select("SELECT logfile FROM adresse WHERE id='$id' AND geloescht=0 LIMIT 1");
|
|
$telefon = $adressarr['telefon'];
|
|
$mobil = $adressarr['mobil'];
|
|
$email = $adressarr['email'];
|
|
$internetseite = $adressarr['internetseite'];
|
|
}else{
|
|
$kundennummer = '';
|
|
$lieferantennummer = '';
|
|
$mitarbeiternummer = '';
|
|
$logfile = '';
|
|
}
|
|
$logfile = str_replace(';',"\r\n",$logfile);
|
|
$this->app->Tpl->Set('LOGFILE',"<textarea cols=\"60\" rows=\"5\" id=\"logfile\" name=\"logfile\">$logfile</textarea>");
|
|
}
|
|
|
|
$sipuid = false;
|
|
$isPlaceTelAvailable = $this->app->erp->RechteVorhanden('placetel','call')
|
|
&& !empty($sipuid = $this->app->erp->GetPlacetelSipuid());
|
|
$isSipgateAvailable = $this->app->erp->RechteVorhanden('sipgate','call')
|
|
&& !empty($this->app->erp->GetKonfiguration('sipgate_api_user'));
|
|
if($isSipgateAvailable || $isPlaceTelAvailable) {
|
|
$phoneModule = $isPlaceTelAvailable ? 'placetel' : 'sipgate';
|
|
$this->app->Tpl->Set('JSPLACETEL','
|
|
function call(id, dummy)
|
|
{
|
|
$.ajax({
|
|
url: \'index.php?module=' . $phoneModule . '&action=call&id=\'+id,
|
|
type: \'POST\',
|
|
dataType: \'json\',
|
|
data: {},
|
|
success: function(data) {
|
|
if(data)
|
|
{
|
|
|
|
}
|
|
}
|
|
});
|
|
|
|
}
|
|
');
|
|
}
|
|
//$telefon= $this->app->DB->Select("SELECT telefon FROM adresse WHERE id='$id' AND geloescht=0 LIMIT 1");
|
|
if($telefon!='')
|
|
{
|
|
$telefon = str_replace('/','',$telefon);
|
|
$telefon = str_replace(' ','',$telefon);
|
|
if($isPlaceTelAvailable || $isSipgateAvailable)
|
|
{
|
|
$this->app->Tpl->Set('TELEFONBUTTON',"<a href=\"#\" onclick=call(\"1-".$id."\") ><img border=\"0\" width=\"20\" src=\"./themes/".$this->app->Conf->WFconf['defaulttheme']."/images/phone.png\" class=\"iconininput\" alt=\"anrufen\" /></a>");
|
|
}else{
|
|
$this->app->Tpl->Set('TELEFONBUTTON',"<a href=\"tel://$telefon\"><img border=\"0\" width=\"20\" src=\"./themes/".$this->app->Conf->WFconf['defaulttheme']."/images/phone.png\" class=\"iconininput\" alt=\"anrufen\" /></a>");
|
|
}
|
|
}
|
|
//$mobil= $this->app->DB->Select("SELECT mobil FROM adresse WHERE id='$id' AND geloescht=0 LIMIT 1");
|
|
if($mobil!='')
|
|
{
|
|
$mobil = str_replace('/','',$mobil);
|
|
$mobil = str_replace(' ','',$mobil);
|
|
if($isPlaceTelAvailable || $isSipgateAvailable)
|
|
{
|
|
$this->app->Tpl->Set('MOBILBUTTON',"<a href=\"#\" onclick=call(\"2-".$id."\") ><img border=\"0\" width=\"20\" src=\"./themes/".$this->app->Conf->WFconf['defaulttheme']."/images/phone.png\" class=\"iconininput\" alt=\"anrufen\" /></a>");
|
|
}else{
|
|
$this->app->Tpl->Set('MOBILBUTTON',"<a href=\"tel://$mobil\"><img border=\"0\" width=\"20\" src=\"./themes/".$this->app->Conf->WFconf['defaulttheme']."/images/phone.png\" class=\"iconininput\" alt=\"anrufen\" /></a>");
|
|
}
|
|
}
|
|
|
|
//$email = $this->app->DB->Select("SELECT email FROM adresse WHERE id='$id' AND geloescht=0 LIMIT 1");
|
|
if($email != '')
|
|
{
|
|
$email = str_ireplace("mailto:",'',$email);
|
|
$this->app->Tpl->Set('EMAILBUTTON',"<a href=\"mailto:$email\"><img border=\"0\" width=\"20\" src=\"./themes/".$this->app->Conf->WFconf['defaulttheme']."/images/mail2.png\" alt=\"Email schreiben\" class=\"iconininput\" /></a>");
|
|
}
|
|
|
|
//$internetseite = $this->app->DB->Select("SELECT internetseite FROM adresse WHERE id='$id' AND geloescht=0 LIMIT 1");
|
|
if($internetseite != '')
|
|
{
|
|
if(stripos($internetseite,'http') === false)$internetseite = 'http://'.$internetseite;
|
|
$this->app->Tpl->Set('INTERNETBUTTON',"<a href=\"$internetseite\" target=\"_blank\"><img border=\"0\" width=\"20\" src=\"./themes/".$this->app->Conf->WFconf['defaulttheme']."/images/web.png\" class=\"iconininput\" alt=\"Internetseite besuchen\" /></a>");
|
|
}
|
|
|
|
//Weitere Kontakte
|
|
$buttons_kontakte = "
|
|
|
|
<input type=\"button\" class=\"button button-secondary\" onclick=\"var bezeichnung = prompt('Etikett bzw. Bezeichnung (z.B. E-Mail, Skype, ICQ, ...):','Telefon Privat');
|
|
if((bezeichnung !=null && bezeichnung!='')) {var kontakt = prompt('Kontakt:',''); if((bezeichnung !=null && bezeichnung!='') && (kontakt!=null && kontakt!='')) { window.location.href='index.php?module=adresse&action=newkontakt&id=".$id."&bezeichnung='+encodeURIComponent(bezeichnung)+'&kontakt='+encodeURIComponent(kontakt);}}\"
|
|
value=\"Weitere Kontaktinfos\">";
|
|
|
|
$kontakte = $this->app->DB->SelectArr("SELECT * FROM adresse_kontakte WHERE adresse='$id'");
|
|
$tabindex=60;
|
|
$table_kontakte = '';
|
|
$ckontakte = !empty($kontakte)?count($kontakte):0;
|
|
for($i=0;$i<$ckontakte;$i++)
|
|
{
|
|
$tabindex = $tabindex+i;
|
|
$table_kontakte .= "<tr><td>".$kontakte[$i]['bezeichnung'].":
|
|
</td><td><input type=text name=\"adresse_kontakte[".$kontakte[$i]['id']."]\" value=\"".$kontakte[$i]['kontakt']."\" size=\"30\" tabindex=\"$tabindex\"> <a href=\"#\" onclick=\"if(!confirm('".$kontakte[$i]['bezeichnung']." wirklich entfernen?')) return false; else window.location.href='index.php?module=adresse&action=delkontakt&id=".$id."&lid=".$kontakte[$i]['id']."';\">x</a></td></tr>";
|
|
}
|
|
|
|
|
|
$this->app->Tpl->Set('BUTTON_KONTAKTE',"$table_kontakte<tr><td></td><td>$buttons_kontakte</td></tr>");
|
|
|
|
|
|
|
|
|
|
$things = array('angebot','auftrag','rechnung','lieferschein','gutschrift');
|
|
$buttons_kunde = '';
|
|
foreach($things as $key=>$value) {
|
|
$buttons_kunde .= '
|
|
<input type="button" class="btnGreenBig" onclick="window.location.href=\'index.php?module=adresse&action=createdokument&id=' . $id . '&cmd=' . $value . '\';" value="' . ucfirst($value) . '">';
|
|
}
|
|
|
|
$things = array('bestellung');
|
|
$buttons_lieferant = '';
|
|
foreach($things as $key=>$value) {
|
|
$buttons_lieferant .= '
|
|
<input type="button" class="btnGreenBig" onclick="window.location.href=\'index.php?module=adresse&action=createdokument&id=' . $id . '&cmd=' . $value . '\';" value="' . ucfirst($value) . '">';
|
|
}
|
|
|
|
|
|
|
|
if($kundennummer !='') {
|
|
$buttons = $buttons_kunde;
|
|
}
|
|
if($lieferantennummer !='') {
|
|
$buttons .= $buttons_lieferant;
|
|
}
|
|
|
|
if(1){//$buttons !=""){
|
|
$this->app->Tpl->Set('BUTTONS','<fieldset><legend>Neu Anlegen</legend>
|
|
<div class="tabsbutton" style="float:left;">'.$buttons.'</div>
|
|
</fieldset>');
|
|
|
|
$this->app->Tpl->Set('BUTTONS2','<input type="button" class="button button-secondary" onclick="copyTextToClipboard(\''.str_replace("'","\'",$this->AdresseAnschriftString($id)).'\')" value="Adresse in Zwischenspeicher">
|
|
<input type="button" class="button button-secondary" onclick="window.location.href=\'index.php?module=adresse&action=pdf&id='.$id.'\'" value="Stammdaten PDF">');
|
|
}
|
|
|
|
if(is_numeric($id)){
|
|
$anzahl_rollen = $this->app->DB->Select("SELECT SUM(id) FROM adresse_rolle WHERE adresse='$id'");
|
|
}
|
|
|
|
$anzahl_lead = !empty($adressarr['lead'])?$adressarr['lead']:0;// $this->app->DB->Select("SELECT lead FROM adresse WHERE id='$id'");
|
|
$anzahl_rollen += $anzahl_lead;
|
|
|
|
|
|
if($anzahl_rollen<1)
|
|
{
|
|
|
|
if($this->app->erp->Version()==='stock')
|
|
{
|
|
$lieferant_checked = 'checked';
|
|
$kunde_checked = '';
|
|
} else {
|
|
$lieferant_checked = '';
|
|
$kunde_checked = 'checked';
|
|
}
|
|
|
|
if($this->app->erp->RechteVorhanden("crm","list"))
|
|
$leadbox = "<input type=\"checkbox\" value=\"1\" name=\"lead\" id=\"lead\"> <label for=\"lead\">als Lead markieren</label>";
|
|
|
|
if($this->app->erp->RechteVorhanden("adresse","rollen"))
|
|
{
|
|
$this->app->Tpl->Set('MESSAGEROLLE',"
|
|
<div class=\"info\">Die Adresse hat noch keine Rolle. Soll eine <a href=\"index.php?module=adresse&action=rollen&id=$id\">Rolle</a> anlegt werden: <form action=\"index.php?module=adresse&action=rollen&id=$id\" method=\"post\">
|
|
<input type=\"checkbox\" value=\"1\" name=\"kunde\" id=\"kunde\" $kunde_checked> <label for=\"kunde\">als Kunde markieren</label>
|
|
<input type=\"checkbox\" value=\"1\" name=\"lieferant\" id=\"lieferant\" $lieferant_checked> <label for=\"lieferant\">als Lieferant markieren</label>
|
|
<input type=\"checkbox\" value=\"1\" name=\"mitarbeiter\" id=\"mitarbeiter\"> <label for=\"mitarbeiter\">als Mitarbeiter markieren</label>
|
|
$leadbox
|
|
<input type=\"submit\" value=\"Jetzt markieren\" name=\"submitrolle\">
|
|
</form></div>");
|
|
}
|
|
}
|
|
|
|
if($anzahl_rollen==1 && $anzahl_lead==1)
|
|
{
|
|
$this->app->Tpl->Set('MESSAGEROLLE','<div class="info">Diese Adresse ist ein potentieller Neukunde (Lead).</div>');
|
|
|
|
}
|
|
|
|
// aktiviere tab 1
|
|
$this->app->Tpl->Set('AKTIV_ADRESSE','selected');
|
|
$this->AdresseNummern($id);
|
|
if($kundennummer==0) {
|
|
$kundennummer = 'keine Kundennummer vorhanden';
|
|
}
|
|
if($lieferantennummer==0){
|
|
$lieferantennummer = 'keine Lieferantennummer vorhanden';
|
|
}
|
|
if($mitarbeiternummer==0){
|
|
$mitarbeiternummer = 'keine Mitarbeiternummer vorhanden';
|
|
}
|
|
|
|
|
|
$this->app->Tpl->Set('KUNDENNUMMERANZEIGE',$kundennummer);
|
|
$this->app->Tpl->Set('LIEFERANTENNUMMERANZEIGE',$lieferantennummer);
|
|
$this->app->Tpl->Set('MITARBEITERNUMMERANZEIGE',$mitarbeiternummer);
|
|
|
|
$this->AdresseMenu();
|
|
$this->app->Tpl->Set('TABLE_ADRESSE_KONTAKTHISTORIE','TDB');
|
|
$this->app->Tpl->Set('TABLE_ADRESSE_ROLLEN','TDB');
|
|
|
|
$this->app->Tpl->Set('TABLE_ADRESSE_USTID','TDB');
|
|
|
|
|
|
$this->app->Tpl->Set('SUBSUBHEADING','Rolle anlegen');
|
|
if($this->app->Secure->GetPOST('rolleanlegen')!=''){
|
|
$this->app->Tpl->Set('AKTIV_TAB3', 'selected');
|
|
}
|
|
else{
|
|
$this->app->Tpl->Set('AKTIV_TAB1', 'selected');
|
|
}
|
|
|
|
$abweichende_rechnungsadresse= $this->app->DB->Select("SELECT abweichende_rechnungsadresse FROM adresse WHERE id='$id' LIMIT 1");
|
|
$this->app->Tpl->Set('ABWEICHENDERECHNUNGSADRESSESTYLE','none');
|
|
if($abweichende_rechnungsadresse=='1') {
|
|
$this->app->Tpl->Set('ABWEICHENDERECHNUNGSADRESSESTYLE','');
|
|
}
|
|
|
|
$liefersperre= $this->app->DB->Select("SELECT liefersperre FROM adresse WHERE id='$id' LIMIT 1");
|
|
if($liefersperre=='1')
|
|
{
|
|
$this->app->Tpl->Add('MESSAGE',"<div class=\"error\">Achtung! Bei dieser Adresse ist die Liefersperre gesetzt!</div>");
|
|
}
|
|
parent::AdresseEdit();
|
|
$this->app->erp->MessageHandlerStandardForm();
|
|
|
|
}
|
|
|
|
function AdresseRollen()
|
|
{
|
|
$this->AdresseMenu();
|
|
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$reload = $this->app->Secure->GetGET('reload');
|
|
$submitrolle = $this->app->Secure->GetPOST('submitrolle');
|
|
|
|
$this->AdresseRolleEdit();
|
|
|
|
$projekt = $this->app->DB->Select("SELECT projekt FROM adresse WHERE id='$id' LIMIT 1");
|
|
|
|
if($submitrolle!='')
|
|
{
|
|
|
|
if($this->app->Secure->GetPOST('kunde')=='1'){
|
|
$this->app->erp->AddRolleZuAdresse($id, 'Kunde', 'von', 'Projekt', $projekt);
|
|
}
|
|
if($this->app->Secure->GetPOST('mitarbeiter')=='1'){
|
|
$this->app->erp->AddRolleZuAdresse($id, 'Mitarbeiter', 'von', 'Projekt', $projekt);
|
|
}
|
|
if($this->app->Secure->GetPOST('lieferant')=='1'){
|
|
$this->app->erp->AddRolleZuAdresse($id, 'Lieferant', 'von', 'Projekt', $projekt);
|
|
}
|
|
if($this->app->Secure->GetPOST('lead')=='1'){
|
|
$this->app->DB->Update("UPDATE adresse SET `lead`=1 WHERE id='$id' LIMIT 1");
|
|
}
|
|
}
|
|
|
|
$this->AdresseNummern($id);
|
|
|
|
if($submitrolle!='')
|
|
{
|
|
$this->app->Location->execute("index.php?module=adresse&action=edit&id=$id");
|
|
}
|
|
|
|
if($this->app->Secure->GetPOST('rolleanlegen')!='')
|
|
{
|
|
$subjekt = $this->app->Secure->GetPOST('subjekt');
|
|
$objekt = $this->app->Secure->GetPOST('objekt');
|
|
if($objekt==='Projekt')
|
|
{
|
|
$projekt = $this->app->Secure->GetPOST('parameter');
|
|
$parameter = $this->app->DB->Select("SELECT id FROM projekt WHERE abkuerzung='$projekt' AND abkuerzung <> '' LIMIT 1");
|
|
} else {
|
|
$gruppe= $this->app->Secure->GetPOST('gruppe');
|
|
$parameter = $this->app->DB->Select("SELECT id FROM gruppen WHERE CONCAT(name,' ',kennziffer)='$gruppe' LIMIT 1");
|
|
}
|
|
|
|
if(!($objekt==='Gruppe' && $parameter <=0))
|
|
{
|
|
$this->app->erp->AddRolleZuAdresse($id, $subjekt, "von", $objekt, $parameter);
|
|
}
|
|
else {
|
|
$msg = $this->app->erp->base64_url_encode("<div class=\"error\">Rolle nicht gespeichert! Bitte geben Sie eine Gruppe an!</div>");
|
|
$this->app->Location->execute("index.php?module=adresse&action=rollen&id=$id&msg=$msg");
|
|
}
|
|
}
|
|
|
|
$this->app->YUI->AutoComplete('parameter','projektname',1);
|
|
$this->app->YUI->AutoComplete('gruppe','gruppe');
|
|
|
|
$subjekt= $this->app->erp->GetAdressSubject();
|
|
$this->app->Tpl->Set('ROLLE_SELECT',$this->app->erp->GetSelect($subjekt,''));
|
|
|
|
$this->app->Tpl->Parse('TAB1','adresse_rolle.tpl');
|
|
if($this->app->Secure->GetPOST('rolleanlegen')!='' || $reload=='true')
|
|
{
|
|
$this->app->Location->execute("index.php?module=adresse&action=rollen&id=$id");
|
|
}
|
|
|
|
|
|
$this->app->Tpl->Set('SUBSUBHEADING','Rollen der Adresse');
|
|
$this->app->Tpl->Set('TABTEXT','Rollen');
|
|
|
|
$table = new EasyTable($this->app);
|
|
$table->Query("SELECT a.subjekt as Rolle,
|
|
if(a.objekt='','ALLE',a.objekt) as Zuordnung,
|
|
if(a.objekt='Projekt',if(a.parameter='','ALLE',p.abkuerzung),CONCAT(g.name,' ',g.kennziffer)) as auswahl,
|
|
DATE_FORMAT(a.von,'%d.%m.%Y') as seit, if(a.bis='0000-00-00','aktuell',DATE_FORMAT(a.bis,'%d.%m.%Y')) as bis, a.id
|
|
FROM adresse_rolle a LEFT JOIN projekt p ON a.parameter=p.id
|
|
LEFT JOIN gruppen g ON g.id=a.parameter
|
|
WHERE a.adresse='$id'",0,"");
|
|
|
|
$table->DisplayNew('TAB1NEXT', "<!--<a href=\"index.php?module=adresse&action=rolleeditpopup&frame=false&id=%value%\"
|
|
onclick=\"makeRequest(this);return false\"><img src=\"./themes/[THEME]/images/edit.svg\" border=\"0\"></a> -->
|
|
<a href=\"javascript:;\" onclick=\"AdresseRolleEdit(%value%);\"><img src=\"./themes/[THEME]/images/edit.svg\" border=\"0\"></a> <a onclick=\"if(!confirm('Rolle wirklich löschen?')) return false; else window.location.href='index.php?module=adresse&action=rolledelete&id=$id&sid=%value%';\"><img src=\"./themes/[THEME]/images/delete.svg\" border=\"0\"></a>");
|
|
|
|
//<a onclick=\"var von = prompt('Von Datum:',''); if((von !=null && von!='')) {var bis = prompt('Bis Datum:',''); if((von !=null && von!='') ) { window.location.href='index.php?module=adresse&action=rolledatum&sid=%value%&id=".$id."&von='+von+'&bis='+bis;}}\">
|
|
|
|
|
|
$this->app->Tpl->Parse('PAGE','tabview.tpl');
|
|
|
|
$this->app->YUI->DatePicker('von_datum');
|
|
$this->app->YUI->DatePicker('bis_datum');
|
|
}
|
|
|
|
|
|
function AdresseRolleEdit()
|
|
{
|
|
if($this->app->Secure->GetGET('cmd')==='get'){
|
|
|
|
$id = (int)$this->app->Secure->GetPOST('id');
|
|
|
|
$data = $this->app->DB->SelectRow("SELECT id as id, DATE_FORMAT(von,'%d.%m.%Y') as von_datum, DATE_FORMAT(bis,'%d.%m.%Y') as bis_datum FROM adresse_rolle WHERE id = \"$id\" LIMIT 1");
|
|
|
|
echo json_encode($data);
|
|
$this->app->ExitXentral();
|
|
}
|
|
}
|
|
|
|
function AdresserolleSave()
|
|
{
|
|
$id = (int)$this->app->Secure->GetPOST('id');
|
|
$von_datum = $this->app->Secure->GetPOST('von_datum');
|
|
$bis_datum = $this->app->Secure->GetPOST('bis_datum');
|
|
|
|
$id = $this->app->DB->Select("SELECT id FROM adresse_rolle ar WHERE id = \"$id\"");
|
|
|
|
$von_datuml = strlen(trim($von_datum));
|
|
$bis_datuml = strlen(trim($bis_datum));
|
|
|
|
$von_datum = $this->app->String->Convert($von_datum,'%3.%2.%1','%1-%2-%3');
|
|
$bis_datum = $this->app->String->Convert($bis_datum,'%3.%2.%1','%1-%2-%3');
|
|
$fehler = '';
|
|
if($id != '' && trim($von_datum) != '' && trim($bis_datum) != '' && $von_datuml >= 8 && $von_datuml <= 10 && $bis_datuml >= 8 && $bis_datuml <= 10 && $von_datum != '0000-00-00'){
|
|
$this->app->DB->Update("UPDATE adresse_rolle SET von = \"$von_datum\", bis = \"$bis_datum\" WHERE id = \"$id\"");
|
|
}else{
|
|
if($von_datum == '0000-00-00'){
|
|
$fehler .= 'Bitte ein gültiges von Datum angeben';
|
|
}
|
|
if($von_datuml < 8 || $von_datuml > 10 || $bis_datuml < 8 || $bis_datuml > 10){
|
|
$fehler .= 'Bitte ein gültiges Datum angeben';
|
|
}
|
|
echo json_encode(array('status'=>0,'statusText'=>$fehler));
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
echo json_encode(array('status'=>1));
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
|
|
function AdresseUSTPopup()
|
|
{
|
|
$frame = $this->app->Secure->GetGET('frame');
|
|
if($frame=='false')
|
|
{
|
|
// hier nur fenster größe anpassen
|
|
$this->app->YUI->IframeDialog(650,530);
|
|
} else {
|
|
$this->AdresseUstprf();
|
|
$this->app->BuildNavigation=false;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
function AdresseUstprf()
|
|
{
|
|
$this->AdresseMenu();
|
|
$id = $this->app->Secure->GetGET("id");
|
|
|
|
$this->app->Tpl->Set("MESSAGE","<div class=\"warning\">Hinweis: Dies ist ein Beta-Feature. Bitte prüfen Sie die Daten und melden uns per Ticket-System, wenn etwas bei Ihnen nicht stimmt.</div>");
|
|
|
|
$this->app->YUI->DateiPopup('DATEIENPOPUP','adresseustprf','#e_id',array(
|
|
'openbuttontarget'=>'DATEIBUTTON'
|
|
,'frompopup'=>'editUstprf','afteropen'=>'AFTERPOPUPOPEN'
|
|
));
|
|
|
|
$laender = $this->app->erp->GetSelectLaenderliste();
|
|
$laenderstr = '';
|
|
|
|
foreach($laender as $key => $value){
|
|
if($key != "0" && $land == $key){
|
|
$laenderstr .= '<option value="' . $key . '" selected>' . $value . '</option>';
|
|
}else{
|
|
$laenderstr .= '<option value="' . $key . '">' . $value . '</option>';
|
|
}
|
|
}
|
|
|
|
$this->app->Tpl->Add("LAENDER", $laenderstr);
|
|
|
|
$this->app->Tpl->Set("ADRESSID", $id);
|
|
|
|
$this->app->YUI->CkEditor("e_mailtext", "belege");
|
|
|
|
$this->app->YUI->TableSearch('TAB1','adresse_ustprf', 'show','','',basename(__FILE__), __CLASS__);
|
|
$this->app->YUI->TableSearch('PROTOKOLLTABELLE','adresse_ustprf_protokoll','show','','',basename(__FILE__), __CLASS__);
|
|
|
|
|
|
$cmd = $this->app->Secure->GetGET('cmd');
|
|
$ustprfid = (int)$this->app->Secure->GetPOST('ustprfid');
|
|
$adressid = (int)$this->app->Secure->GetPOST('adressid');
|
|
$name = trim($this->app->Secure->GetPOST('name'));
|
|
$ustid = trim($this->app->Secure->GetPOST('ustid'));
|
|
$plz = trim($this->app->Secure->GetPOST('plz'));
|
|
$ort = trim($this->app->Secure->GetPOST('ort'));
|
|
$strasse = trim($this->app->Secure->GetPOST('strasse'));
|
|
$land = trim($this->app->Secure->GetPOST('land'));
|
|
|
|
$ustid = str_replace(' ', '', $ustid);
|
|
|
|
$url = html_entity_decode($name." ".$ort." ".$land, ENT_QUOTES | ENT_XML1);
|
|
|
|
$ownvatok = false;
|
|
|
|
include_once(dirname(__DIR__).'/lib/class.ustid.php');
|
|
|
|
switch($cmd)
|
|
{
|
|
case "startwerte":
|
|
$abwreadresse = $this->app->DB->Select("SELECT abweichende_rechnungsadresse FROM adresse WHERE id = '$adressid' LIMIT 1");
|
|
|
|
if($abwreadresse == 1){
|
|
$data = $this->app->DB->SelectRow("SELECT id, kundennummer AS nummer, rechnung_name AS name, rechnung_land AS land, ustid, rechnung_ort AS ort, rechnung_plz AS plz, rechnung_strasse AS strasse FROM adresse WHERE id = '$adressid' LIMIT 1");
|
|
} else{
|
|
$data = $this->app->DB->SelectRow("SELECT id, kundennummer AS nummer, land, name, ustid, ort, plz, strasse FROM adresse WHERE id = '$adressid' LIMIT 1");
|
|
}
|
|
|
|
if($data){
|
|
$data['name'] = html_entity_decode($data['name'], ENT_QUOTES | ENT_XML1);
|
|
$url = html_entity_decode($data['name'])." ".$data['ort']." ".$data['land'];
|
|
|
|
$data['ustid'] = str_replace(' ', '', $data['ustid']);
|
|
|
|
$data['uststatus']="angelegt";
|
|
$data['status']=1;
|
|
}
|
|
$this->app->DB->Insert("INSERT INTO ustprf (adresse, ustid, name, ort, plz, strasse, land,status,datum) VALUES ('$adressid', '".$data['ustid']."',
|
|
'".$this->app->DB->real_escape_string($data['name'])."', '".$this->app->DB->real_escape_string($data['ort'])."', '".$data['plz']."',
|
|
'".$this->app->DB->real_escape_string($data['strasse'])."', '".$data['land']."','angelegt',NOW())");
|
|
|
|
|
|
$ustprfid = $this->app->DB->GetInsertID();
|
|
$data['ustprfid'] = $ustprfid;
|
|
|
|
$protokoll = "Neue Prüfung angelegt";
|
|
|
|
break;
|
|
case "stammdaten":
|
|
$this->app->DB->Update("UPDATE adresse SET name = '$name', ustid = '$ustid', plz = '$plz', ort = '$ort', strasse = '$strasse', land = '$land' WHERE id = '$adressid'");
|
|
$this->app->DB->Update("UPDATE ustprf SET ustid = '$ustid', name = '$name', ort = '$ort', plz = '$plz', strasse = '$strasse', land = '$land' WHERE id = '$ustprfid'");
|
|
$data['status']=1;
|
|
$data['statusText']="Stammdaten wurden aktualisiert";
|
|
$protokoll = $data['statusText'];
|
|
$adressdaten = $name." | ".$ort." | ".$plz." | ".$strasse." | ".$land." | ".$ustid;
|
|
break;
|
|
case "online":
|
|
case "brief":
|
|
$ustland = substr($ustid, 0, 2);
|
|
if($ustland!=""){
|
|
$ustlaender = $this->app->erp->GetUSTEU(true);
|
|
if(!in_array($ustland, $ustlaender)){
|
|
$data['status']=0;
|
|
$data['statusText']="Dieses Land ist für die Prüfung nicht verfügbar.\nEs können nur Abfragen über Firmen in der EU durchgeführt werden.";
|
|
break;
|
|
}
|
|
}
|
|
|
|
$this->app->DB->Update("UPDATE ustprf SET ustid='".$ustid."', name='".$name."',
|
|
ort='".$ort."', plz='".$plz."', strasse='".$strasse."', land='".$land."' WHERE id='".$ustprfid."'");
|
|
|
|
$adressdaten = $name." | ".$ort." | ".$plz." | ".$strasse." | ".$land." | ".$ustid;
|
|
|
|
$UstStatus = $this->app->erp->CheckUst($this->app->erp->Firmendaten("steuernummer"), $ustid ,$name,$ort,$strasse,$plz,($cmd=="brief"?"ja":"nein"));
|
|
|
|
if(is_array($UstStatus) && !is_numeric($UstStatus)){
|
|
//$tmp = new USTID();
|
|
$msg = $UstStatus['ERROR_MSG'];
|
|
|
|
if(($UstStatus['ERROR_CODE']==200 || $UstStatus['ERROR_CODE']==222) && (($UstStatus['ERG_NAME']=="A" && $UstStatus['ERG_PLZ']=="A" && $UstStatus['ERG_ORT']=="A" && $UstStatus['ERG_STR']=="A") || $cmd=="brief")){
|
|
$data['status']=1;
|
|
if($cmd=="brief") {
|
|
$this->app->DB->Update("UPDATE ustprf SET status='$cmd',datum_brief=NOW(),briefbestellt=NOW() WHERE id='$ustprfid'");
|
|
$data['statusText']="Schriftliche Mitteilung des BZSt wurde angefordert!";
|
|
}else{
|
|
$this->app->DB->Update("UPDATE ustprf SET status='$cmd',datum_online=NOW() WHERE id='$ustprfid'");
|
|
$data['statusText']=$msg;
|
|
}
|
|
}else if($UstStatus['ERROR_CODE']==200 || $UstStatus['ERROR_CODE']==222){
|
|
$data['status']=0;
|
|
|
|
$this->app->DB->Update("UPDATE ustprf SET status='teilweise',datum_online=NOW() WHERE id='$ustprfid'");
|
|
if($UstStatus['ERG_NAME']=="B") $tmpmsg .= "\nName stimmt nicht mit BZSt Eintrag überein! ";
|
|
if($UstStatus['ERG_PLZ']=="B") $tmpmsg .= "\nPLZ stimmt nicht mit BZSt Eintrag überein! ";
|
|
if($UstStatus['ERG_ORT']=="B") $tmpmsg .= "\nOrt stimmt nicht mit BZSt Eintrag überein! ";
|
|
if($UstStatus['ERG_STR']=="B") $tmpmsg .= "\nStrasse stimmt nicht mit BZSt Eintrag überein! ";
|
|
|
|
if($UstStatus['ERG_NAME']=="C") $tmpmsg .= "\nName wurde vom BZSt nicht angefragt! ";
|
|
if($UstStatus['ERG_PLZ']=="C") $tmpmsg .= "\nPLZ wurde vom BZSt nicht angefragt! ";
|
|
if($UstStatus['ERG_ORT']=="C") $tmpmsg .= "\nOrt wurde vom BZSt nicht angefragt! ";
|
|
if($UstStatus['ERG_STR']=="C") $tmpmsg .= "\nStrasse wurde vom BZSt nicht angefragt! ";
|
|
|
|
if($UstStatus['ERG_NAME']=="D") $tmpmsg .= "\nName wird vom EU-Mitgliedsstaat nicht mitgeteilt! ";
|
|
if($UstStatus['ERG_PLZ']=="D") $tmpmsg .= "\nPLZ wird vom EU-Mitgliedsstaat nicht mitgeteilt! ";
|
|
if($UstStatus['ERG_ORT']=="D") $tmpmsg .= "\nOrt wird vom EU-Mitgliedsstaat nicht mitgeteilt! ";
|
|
if($UstStatus['ERG_STR']=="D") $tmpmsg .= "\nStrasse wird vom EU-Mitgliedsstaat nicht mitgeteilt! ";
|
|
|
|
$data['ustprfid'] = $ustprfid;
|
|
$data['adressdaten'] = $adressdaten;
|
|
$data['error_code'] = $UstStatus['ERROR_CODE'];
|
|
$data['statusText']=trim($tmpmsg);
|
|
}else{
|
|
$data['status']=0;
|
|
$this->app->DB->Update("UPDATE ustprf SET status='fehlgeschlagen',datum_online=NOW() WHERE id='$ustprfid'");
|
|
if($UstStatus['ERROR_CODE'] != ''){
|
|
$data['statusText']=$msg.' (Code: '.$UstStatus['ERROR_CODE'].')';
|
|
}else{
|
|
$data['statusText'] = $msg.' (Code: Der Server des Bundeszentralamtes für Steuern ist derzeit nicht erreichbar.\nBitte probieren Sie es zu einem späteren Zeitpunkt noch einmal.)';
|
|
}
|
|
}
|
|
$protokoll = $data['statusText'];
|
|
}
|
|
|
|
|
|
$data['uststatus'] = $this->app->DB->Select("SELECT status FROM ustprf WHERE id='$ustprfid'");
|
|
$data['datum_online'] = $this->app->DB->Select("SELECT DATE_FORMAT(datum_online,'%d.%m.%Y') as datum_online FROM ustprf WHERE id='$ustprfid'");
|
|
$data['datum_brief'] = $this->app->DB->Select("SELECT DATE_FORMAT(datum_brief,'%d.%m.%Y') as datum_brief FROM ustprf WHERE id='$ustprfid'");
|
|
|
|
if($data['datum_online'] == '00.00.0000'){
|
|
$data['datum_online'] = '-';
|
|
}
|
|
|
|
if($data['datum_brief'] == '00.00.0000'){
|
|
$data['datum_brief'] = '-';
|
|
}
|
|
break;
|
|
case "delete":
|
|
if($ustprfid > 0){
|
|
$this->app->DB->Delete("DELETE FROM ustprf WHERE id='" . $ustprfid . "'");
|
|
$this->app->DB->Delete("DELETE FROM ustprf_protokoll WHERE ustprf_id='" . $ustprfid . "'");
|
|
$data['status'] = 1;
|
|
}
|
|
break;
|
|
|
|
|
|
case "get":
|
|
$data = $this->app->DB->SelectRow("SELECT *,id as ustprfid, status as uststatus,DATE_FORMAT(datum_online,'%d.%m.%Y') as datum_online,DATE_FORMAT(datum_brief,'%d.%m.%Y') as datum_brief FROM ustprf WHERE id='".$ustprfid."'");
|
|
|
|
$url = html_entity_decode($data['name'])." ".$data['ort']." ".$data['land'];
|
|
|
|
if($data['datum_online'] == '00.00.0000'){
|
|
$data['datum_online'] = '-';
|
|
}
|
|
|
|
if($data['datum_brief'] == '00.00.0000'){
|
|
$data['datum_brief'] = '-';
|
|
}
|
|
|
|
$data['status']=1;
|
|
break;
|
|
|
|
case "gueltigmarkieren":
|
|
if($ustprfid > 0){
|
|
$this->app->DB->Update("UPDATE ustprf SET status='$cmd',datum_online=NOW() WHERE id='$ustprfid'");
|
|
$protokoll = "Manuell als gültig markiert.";
|
|
$adressdaten = $name." | ".$ort." | ".$plz." | ".$strasse." | ".$land." | ".$ustid;
|
|
$data['status'] = 1;
|
|
$data['uststatus'] = $this->app->DB->Select("SELECT status FROM ustprf WHERE id='$ustprfid'");
|
|
$data['datum_online'] = $this->app->DB->Select("SELECT DATE_FORMAT(datum_online,'%d.%m.%Y') as datum_online FROM ustprf WHERE id='$ustprfid'");
|
|
}else{
|
|
$data['status'] = 0;
|
|
$data['statusText'] = 'Keine gültige Ustprf-ID';
|
|
}
|
|
break;
|
|
}
|
|
|
|
if($ustprfid > 0 && $protokoll!='' && $cmd!=='delete')
|
|
{
|
|
$this->app->DB->Insert("INSERT INTO ustprf_protokoll (ustprf_id, zeit, bemerkung, bearbeiter,logdatei, daten) VALUES ('".$ustprfid."',NOW(),
|
|
'$protokoll', '".$this->app->User->GetName()."',NOW(), '".$adressdaten."')");
|
|
}
|
|
|
|
if($cmd!='')
|
|
{
|
|
$data['url'] = "http://www.google.de/search?q=$url&ie=utf-8&oe=utf-8&aq=t&rls=com.ubuntu:de:official&client=firefox-a";
|
|
echo json_encode($data);
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
$this->app->Tpl->Parse('PAGE',"adresse_ustprf.tpl");
|
|
}
|
|
|
|
function AdresseProtokoll($lid)
|
|
{
|
|
if($lid!=""){
|
|
$table = new EasyTable($this->app);
|
|
|
|
$table->Query("SELECT DATE_FORMAT(zeit, '%d.%m.%Y %H:%i') AS Datum, bemerkung,bearbeiter FROM ustprf_protokoll WHERE ustprf_id='$lid' ORDER BY zeit DESC", 0, "noAction");
|
|
|
|
$table->DisplayNew('PROTOKOLL',"", "noAction");
|
|
|
|
}
|
|
}
|
|
|
|
|
|
function AdresseVerbindlichkeiten()
|
|
{
|
|
$this->AdresseMenu();
|
|
|
|
$this->app->Tpl->Parse('PAGE',"adresse_verbindlichkeiten.tpl");
|
|
}
|
|
|
|
function AdresseKundeArtikel()
|
|
{
|
|
$parameter = $this->app->User->GetParameter('table_filter_adressekundeartikel');
|
|
$parameter = json_decode($parameter, true);
|
|
|
|
$cmd = $this->app->Secure->GetGET('cmd');
|
|
if($cmd==='edit') {
|
|
$id = (int)$this->app->Secure->GetPOST('id');
|
|
$art = (int)$this->app->Secure->GetPOST('art');
|
|
$tabelle = "";
|
|
|
|
if($art == 1){
|
|
$tabelle = "auftrag";
|
|
}elseif($art == 2){
|
|
$tabelle = "rechnung";
|
|
}elseif($art == 3){
|
|
$tabelle = "gutschrift";
|
|
}elseif($art == 4){
|
|
$tabelle = "angebot";
|
|
}elseif($art == 5){
|
|
$tabelle = "lieferschein";
|
|
}elseif($art == 6){
|
|
$tabelle = "produktion";
|
|
}
|
|
|
|
$data = $this->app->DB->SelectRow("SELECT id, internerkommentar FROM ".$tabelle."_position WHERE id = '$id' LIMIT 1");
|
|
|
|
if($data){
|
|
$data['art'] = $tabelle;
|
|
|
|
}else{
|
|
$data['id'] = 0;
|
|
$data['internerkommentar'] = 0;
|
|
$data['art'] = '';
|
|
}
|
|
echo json_encode($data);
|
|
$this->app->ExitXentral();
|
|
|
|
}
|
|
if($cmd==='save'){
|
|
$id = $this->app->Secure->GetPOST('id');
|
|
$internerkommentar = $this->app->Secure->GetPOST('internerkommentar');
|
|
$art = $this->app->Secure->GetPOST('art');
|
|
|
|
$error = '';
|
|
|
|
if($error == ''){
|
|
if($id > 0){
|
|
$this->app->DB->Update("UPDATE ".$art."_position SET internerkommentar = '$internerkommentar' WHERE id = '$id'");
|
|
echo json_encode(array('status'=>1));
|
|
$this->app->ExitXentral();
|
|
}
|
|
}else{
|
|
echo json_encode(array('status'=>0,'statusText'=>$error));
|
|
$this->app->ExitXentral();
|
|
}
|
|
}
|
|
|
|
|
|
if($this->app->Secure->GetPOST('speichern'))
|
|
{
|
|
$internerkommentar = $this->app->Secure->GetPOST('internerkommentar');
|
|
$rechnung_position = (int)$this->app->Secure->GetPOST('rechnung_position');
|
|
if($rechnung_position)
|
|
{
|
|
$rechnung = $this->app->DB->Select("SELECT rechnung FROM rechnung_position WHERE id = '$rechnung_position' LIMIT 1");
|
|
if($rechnung)
|
|
{
|
|
$id = (int)$this->app->Secure->GetGET('id');
|
|
if($id && $this->app->DB->Select("SELECT adresse FROM rechnung WHERE id = '$rechnung' AND adresse = '$id' LIMIT 1"))
|
|
{
|
|
$this->app->DB->Update("UPDATE rechnung_position SET internerkommentar = '$internerkommentar' WHERE id = '$rechnung_position' LIMIT 1");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
$this->AdresseMenu();
|
|
$this->app->Tpl->Parse('TAB1','adresse_kundeartikel_table_filter.tpl');
|
|
$this->app->YUI->TableSearch('TAB1','adresseartikel');
|
|
|
|
$this->app->YUI->TableSearch('TAB7','adresse_artikel_gekaufte', 'show','','',basename(__FILE__), __CLASS__);
|
|
|
|
$this->app->Tpl->Parse('PAGE','adresse_artikel.tpl');
|
|
}
|
|
|
|
public function AdresseLieferantArtikel()
|
|
{
|
|
$this->AdresseMenu();
|
|
|
|
$this->app->YUI->TableSearch('TAB1','lieferantartikel', 'show','','',basename(__FILE__), __CLASS__);
|
|
$this->app->Tpl->Parse('PAGE','adresse_lieferprogramm.tpl');
|
|
}
|
|
|
|
function AdresseBestellungMarkiert()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$sid = $this->app->Secure->GetPOST('sid');
|
|
if($sid > 0){
|
|
$geliefert = $this->app->DB->Select("SELECT geliefert FROM bestellung_position WHERE id='$sid' LIMIT 1");
|
|
$menge = $this->app->DB->Select("SELECT menge FROM bestellung_position WHERE id='$sid' LIMIT 1");
|
|
$tmp = $menge - $geliefert;
|
|
if($tmp < 0){
|
|
$tmp = 0;
|
|
}
|
|
$this->app->DB->Update("UPDATE bestellung_position SET abgeschlossen='1', mengemanuellgeliefertaktiviert='$tmp', geliefert='$menge',manuellgeliefertbearbeiter='" . $this->app->User->GetName() . "' WHERE id='$sid' LIMIT 1");
|
|
}
|
|
echo json_encode(array('status'=>1));
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
|
|
function AdresseOffeneBestellungen()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$this->app->Tpl->Set('ID',$id);
|
|
|
|
$this->AdresseMenu();
|
|
|
|
$this->app->Tpl->Set('UEBERSCHRIFT1','Bestellungen');
|
|
|
|
$this->app->YUI->TableSearch('TAB1', 'adressebestellungen');
|
|
|
|
$this->app->Tpl->Set('TAB1SELECT','selected');
|
|
$this->app->Tpl->Set('EXTEND','');
|
|
$this->app->Tpl->Set('INHALT','');
|
|
|
|
$this->app->YUI->TableSearch('TAB2', 'adressebestellungen_artikel');
|
|
$this->app->Tpl->Parse('PAGE', 'adressebestellung.tpl');
|
|
}
|
|
|
|
function AdresseAccounts()
|
|
{
|
|
$this->AdresseMenu();
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$lid = $this->app->Secure->GetGET("lid");
|
|
$cmd = $this->app->Secure->GetGET('cmd');
|
|
|
|
$iframe = $this->app->Secure->GetGET("iframe");
|
|
|
|
|
|
if($cmd === "save"){
|
|
$bearbeitungsid = (int)$this->app->Secure->GetPOST('id');
|
|
$bezeichnung = trim($this->app->Secure->GetPOST('bezeichnung'));
|
|
$benutzername = trim($this->app->Secure->GetPOST('benutzername'));
|
|
$passwort = trim($this->app->Secure->GetPOST('passwort'));
|
|
$art = trim($this->app->Secure->GetPOST('art'));
|
|
$url = trim($this->app->Secure->GetPOST('url'));
|
|
$email = trim($this->app->Secure->GetPOST('email'));
|
|
$notiz = trim($this->app->Secure->GetPOST('notiz'));
|
|
$gueltigab = trim($this->app->Secure->GetPOST('gueltigab'));
|
|
$gueltigbis = trim($this->app->Secure->GetPOST('gueltigbis'));
|
|
$aktiv = $this->app->Secure->GetPOST('aktiv');
|
|
$adressid = (int)$this->app->Secure->GetPOST('adressid');
|
|
|
|
$error = "";
|
|
|
|
if($bezeichnung == ""){
|
|
$error .= "Bitte Bezeichnung ausfüllen\n";
|
|
}
|
|
|
|
if($gueltigab == "" || $gueltigab == "0000-00-00"){
|
|
$gueltigab = "0000-00-00";
|
|
}else{
|
|
$gueltigab = date('Y-m-d',strtotime($gueltigab));
|
|
}
|
|
|
|
if($gueltigbis == "" || $gueltigbis == "0000-00-00"){
|
|
$gueltigbis = "0000-00-00";
|
|
}else{
|
|
$gueltigbis = date('Y-m-d',strtotime($gueltigbis));
|
|
}
|
|
|
|
if($error == ''){
|
|
if($bearbeitungsid){
|
|
$this->app->DB->Update("UPDATE adresse_accounts SET bezeichnung = '$bezeichnung', benutzername = '$benutzername', passwort = '$passwort', art = '$art', url = '$url', email = '$email', notiz = '$notiz', gueltig_ab = '$gueltigab', gueltig_bis = '$gueltigbis', aktiv = '$aktiv' WHERE id = '$bearbeitungsid'");
|
|
|
|
echo json_encode(array('status'=>1));
|
|
$this->app->ExitXentral();
|
|
}
|
|
$this->app->DB->Insert("INSERT INTO adresse_accounts (bezeichnung, benutzername, passwort, art, url, email, notiz, gueltig_ab, gueltig_bis, aktiv, adresse) VALUES ('$bezeichnung', '$benutzername', '$passwort', '$art', '$url', '$email', '$notiz', '$gueltigab', '$gueltigbis', '$aktiv', '$adressid')");
|
|
echo json_encode(array('status'=>1));
|
|
$this->app->ExitXentral();
|
|
}
|
|
echo json_encode(array('status'=>0,'statusText'=>$error));
|
|
$this->app->ExitXentral();
|
|
|
|
|
|
|
|
}
|
|
if($cmd === 'edit'){
|
|
|
|
$bearbeitungsid = (int)$this->app->Secure->GetPOST('id');
|
|
|
|
$data = $this->app->DB->SelectRow("SELECT id, bezeichnung, benutzername, passwort, art, url, email, notiz, gueltig_ab, gueltig_bis, aktiv FROM adresse_accounts WHERE id = '$bearbeitungsid' LIMIT 1");
|
|
|
|
if($data){
|
|
if($data['gueltig_ab'] == "0000-00-00"){
|
|
$data['gueltig_ab'] = "";
|
|
}else{
|
|
$data['gueltig_ab'] = date('d.m.Y',strtotime($data['gueltig_ab']));
|
|
}
|
|
if($data['gueltig_bis'] == "0000-00-00"){
|
|
$data['gueltig_bis'] = "";
|
|
}else{
|
|
$data['gueltig_bis'] = date('d.m.Y',strtotime($data['gueltig_bis']));
|
|
}
|
|
}else{
|
|
$data['id'] = 0;
|
|
$data['bezeichnung'] = '';
|
|
$data['benutzername'] = '';
|
|
$data['passwort'] = '';
|
|
$data['art'] = '';
|
|
$data['url'] = '';
|
|
$data['email'] = '';
|
|
$data['notiz'] = '';
|
|
$data['gueltig_ab'] = '';
|
|
$data['gueltig_bis'] = '';
|
|
$data['aktiv'] = 0;
|
|
}
|
|
echo json_encode($data);
|
|
$this->app->ExitXentral();
|
|
|
|
}
|
|
if($cmd === 'delete'){
|
|
$loeschid = (int) $this->app->Secure->GetPOST('eid');
|
|
$this->app->DB->Update("DELETE FROM adresse_accounts WHERE id = '$loeschid' LIMIT 1");
|
|
|
|
echo json_encode(array('status'=>1));
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
|
|
|
|
|
|
if($iframe=="true")
|
|
$this->app->BuildNavigation=false;
|
|
|
|
if($delete==1)
|
|
{
|
|
$this->app->DB->Delete("DELETE FROM adresse_accounts WHERE id='$lid' AND adresse='$id' LIMIT 1");
|
|
$this->app->Location->execute("index.php?module=adresse&action=accounts$add_cmd&id=$id&iframe=$iframe");
|
|
}
|
|
|
|
$this->app->YUI->AutoComplete("e_art", "accountart");
|
|
$this->app->YUI->CkEditor("e_notiz","basic",array('height'=>'11em', 'width'=>'35em'));
|
|
$this->app->YUI->DatePicker('e_gueltigab');
|
|
$this->app->YUI->DatePicker('e_gueltigbis');
|
|
|
|
|
|
//Formula lieferadresse
|
|
// easy table mit arbeitspaketen YUI als template
|
|
$this->app->YUI->TableSearch('TAB1',"adresse_accounts");
|
|
//$this->app->Tpl->Parse('TAB1',"rahmen70.tpl");
|
|
$this->app->Tpl->Set('AKTIV_TAB1',"selected");
|
|
|
|
if($iframe=="true")
|
|
$this->app->Tpl->Parse('PAGE',"adresse_accounts_uebersicht_popup.tpl");
|
|
else
|
|
$this->app->Tpl->Parse('PAGE',"adresse_accounts_uebersicht.tpl");
|
|
|
|
}
|
|
|
|
|
|
function AdresseAnsprechpartnerPopup()
|
|
{
|
|
$frame = $this->app->Secure->GetGET("frame");
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$cmd= $this->app->Secure->GetPOST('cmd');
|
|
|
|
if($cmd=="alslieferadresse")
|
|
$als_lieferadresse=true;
|
|
else
|
|
$als_lieferadresse=false;
|
|
|
|
|
|
$this->AdresseAnsprechpartner($als_lieferadresse);
|
|
$this->app->BuildNavigation=false;
|
|
}
|
|
|
|
function AdresseAnsprechpartnerLieferadressePopup()
|
|
{
|
|
$frame = $this->app->Secure->GetGET("frame");
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
$this->AdresseAnsprechpartner(true);
|
|
$this->app->BuildNavigation=false;
|
|
}
|
|
|
|
function AdresseStammdatenLieferadressePopup()
|
|
{
|
|
$frame = $this->app->Secure->GetGET("frame");
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
$this->AdresseStammdaten(true);
|
|
$this->app->BuildNavigation=false;
|
|
}
|
|
|
|
|
|
|
|
function AdresseStammdaten($als_lieferadresse=false)
|
|
{
|
|
$this->AdresseMenu();
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$lid = $this->app->Secure->GetGET("lid");
|
|
$delete = $this->app->Secure->GetGET("delete");
|
|
$create= $this->app->Secure->GetGET("create");
|
|
$cmd= $this->app->Secure->GetPOST('cmd');
|
|
|
|
$als_verzollungsadresse = false;
|
|
$als_ansprechpartner = false;
|
|
if($cmd=="alslieferadresse")
|
|
{
|
|
$this->app->Tpl->Set('STARTDISABLEANREDE',"<!--");
|
|
$this->app->Tpl->Set('ENDEDISABLEANREDE',"-->");
|
|
$als_lieferadresse=true;
|
|
$add_cmd = "&cmd=alslieferadresse";
|
|
}elseif($cmd == "alsverzollungadresse")
|
|
{
|
|
$this->app->Tpl->Set('STARTDISABLEANREDE',"<!--");
|
|
$this->app->Tpl->Set('ENDEDISABLEANREDE',"-->");
|
|
$als_verzollungsadresse=true;
|
|
$add_cmd = "&cmd=alsverzollungadresse";
|
|
} elseif($cmd == "alsansprechpartner")
|
|
{
|
|
$this->app->Tpl->Set('STARTDISABLEANREDE',"<!--");
|
|
$this->app->Tpl->Set('ENDEDISABLEANREDE',"-->");
|
|
$als_ansprechpartner=true;
|
|
$add_cmd = "&cmd=alsansprechpartner";
|
|
}
|
|
|
|
|
|
$iframe = $this->app->Secure->GetGET("iframe");
|
|
|
|
if($iframe=="true")
|
|
$this->app->BuildNavigation=false;
|
|
|
|
// neues arbeitspaket
|
|
|
|
if($iframe=="true") {
|
|
if($als_lieferadresse)
|
|
{
|
|
$einfuegen = "<a onclick=\"AnsprechpartnerLieferadresse('%value%'); parent.closeIframe();\"><img src=\"./themes/[THEME]/images/down.png\" border=\"0\"></a>";
|
|
}elseif($als_verzollungsadresse)
|
|
{
|
|
$einfuegen = "<a onclick=\"Verzolladresse('%value%'); parent.closeIframe();\"><img src=\"./themes/[THEME]/images/down.png\" border=\"0\"></a>";
|
|
}elseif($als_ansprechpartner)
|
|
{
|
|
$einfuegen = "<a onclick=\"AdresseAnsprechpartner('%value%'); parent.closeIframe();\"><img src=\"./themes/[THEME]/images/down.png\" border=\"0\"></a>";
|
|
}
|
|
else
|
|
$einfuegen = "<a onclick=\"Ansprechpartner('%value%'); parent.closeIframe();\"><img src=\"./themes/[THEME]/images/down.png\" border=\"0\"></a>";
|
|
}
|
|
//Formula lieferadresse
|
|
// easy table mit arbeitspaketen YUI als template
|
|
if($als_lieferadresse)
|
|
{
|
|
$this->app->YUI->TableSearch('TAB1',"adresse_stammdatenlieferadresselist");
|
|
}elseif($als_verzollungsadresse)
|
|
{
|
|
$this->app->YUI->TableSearch('TAB1',"adresse_stammdatenverzollungadresselist");
|
|
}
|
|
else
|
|
$this->app->YUI->TableSearch('TAB1',"adresse_ansprechpartnerlist"); //TODO fehlt
|
|
//$this->app->Tpl->Parse('TAB1',"rahmen70.tpl");
|
|
$this->app->Tpl->Set('AKTIV_TAB1',"selected");
|
|
|
|
if($iframe=="true")
|
|
$this->app->Tpl->Parse('PAGE',"ansprechpartneruebersicht_popup.tpl");
|
|
else
|
|
$this->app->Tpl->Parse('PAGE',"ansprechpartneruebersicht.tpl");
|
|
}
|
|
|
|
|
|
function AdresseAnsprechpartner($als_lieferadresse=false)
|
|
{
|
|
|
|
$id = $this->app->DB->real_escape_string($this->app->Secure->GetGET('id'));
|
|
$lid = $this->app->DB->real_escape_string($this->app->Secure->GetGET('lid'));
|
|
|
|
if($this->app->Secure->GetGET('cmd')==='changegr') {
|
|
$gruppe = (int)$this->app->Secure->GetPOST('gruppe');
|
|
$wert = $this->app->Secure->GetPOST('wert')?1:0;
|
|
if($id && $lid && $gruppe)
|
|
{
|
|
$check = $this->app->DB->Select("SELECT id FROM ansprechpartner_gruppen WHERE gruppe = '$gruppe' AND ansprechpartner = '$lid' LIMIT 1");
|
|
if($check)
|
|
{
|
|
$this->app->DB->Update("UPDATE ansprechpartner_gruppen SET aktiv = '$wert' WHERE id = '$check' LIMIT 1");
|
|
}elseif($wert){
|
|
$this->app->DB->Insert("INSERT INTO ansprechpartner_gruppen (gruppe, ansprechpartner, aktiv) VALUES ('$gruppe', '$lid', 1)");
|
|
}
|
|
}
|
|
echo json_decode(array('status'=>1));
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
$delete = $this->app->Secure->GetGET("delete");
|
|
$create= $this->app->Secure->GetGET("create");
|
|
$cmd = $this->app->Secure->GetGET('cmd');
|
|
|
|
//$ansprechpartnerspeichern = "";
|
|
$ansprechpartnerspeichern = $this->app->Secure->GetPOST('ansprechpartnerspeichern');
|
|
if($ansprechpartnerspeichern != ""){
|
|
$cmd = "save";
|
|
}
|
|
|
|
switch ($cmd) {
|
|
case 'get':
|
|
|
|
$data = $this->app->DB->SelectRow("SELECT * FROM ansprechpartner WHERE id = '$lid'");
|
|
$data['geburtstag'] = $this->app->String->Convert($data['geburtstag'],"%1-%2-%3","%3.%2.%1");
|
|
echo json_encode($data);
|
|
$this->app->ExitXentral();
|
|
break;
|
|
case 'save':
|
|
$lid = $this->app->Secure->GetPOST('lid');
|
|
$typ = $this->app->Secure->GetPOST('typ');
|
|
$land = $this->app->Secure->GetPOST('land');
|
|
$name = $this->app->Secure->GetPOST('name');
|
|
$titel = $this->app->Secure->GetPOST('titel');
|
|
$bereich = $this->app->Secure->GetPOST('bereich');
|
|
$abteilung = $this->app->Secure->GetPOST('abteilung');
|
|
$unterabteilung = $this->app->Secure->GetPOST('unterabteilung');
|
|
$adresszusatz = $this->app->Secure->GetPOST('adresszusatz');
|
|
$anschreiben = $this->app->Secure->GetPOST('anschreiben');
|
|
$vorname = $this->app->Secure->GetPOST('vorname');
|
|
$geburtstag = $this->app->String->Convert($this->app->Secure->GetPOST('geburtstag'),"%3.%2.%1","%1-%2-%3");
|
|
$geburtstagkalender = $this->app->Secure->GetPOST('geburtstagkalender');
|
|
$geburtstagskarte = $this->app->Secure->GetPOST('geburtstagskarte');
|
|
$marketingsperre = $this->app->Secure->GetPOST('marketingsperre');
|
|
$strasse = $this->app->Secure->GetPOST('strasse');
|
|
$plz = $this->app->Secure->GetPOST('plz');
|
|
$ort = $this->app->Secure->GetPOST('ort');
|
|
$email = $this->app->Secure->GetPOST('email');
|
|
$telefon = $this->app->Secure->GetPOST('telefon');
|
|
$telefax = $this->app->Secure->GetPOST('telefax');
|
|
$mobil = $this->app->Secure->GetPOST('mobil');
|
|
$sonstiges = $this->app->Secure->GetPOST('sonstiges');
|
|
$internebemerkung = $this->app->Secure->GetPOST('interne_bemerkung');
|
|
|
|
$error = "";
|
|
|
|
if(trim($name) == ""){
|
|
$error .= "Bitte Name ausfüllen"."\n";
|
|
}
|
|
|
|
if($error == ""){
|
|
if($lid == '0'){
|
|
//Neuen Eintrag anlegen
|
|
$this->app->DB->Insert("INSERT INTO ansprechpartner (typ, name, bereich, abteilung, unterabteilung, land, strasse, ort, plz, telefon, telefax, email, sonstiges, adresszusatz, adresse, logdatei, mobil, titel, anschreiben, ansprechpartner_land, vorname, geburtstag, geburtstagkalender, geburtstagskarte, marketingsperre, interne_bemerkung) VALUES ('$typ', '$name', '$bereich','$abteilung','$unterabteilung','$land','$strasse','$ort','$plz','$telefon','$telefax', '$email', '$sonstiges', '$adresszusatz','$id',NOW(),'$mobil','$titel','$anschreiben','$land','$vorname','$geburtstag', '$geburtstagkalender', '$geburtstagskarte', '$marketingsperre', '$internebemerkung')");
|
|
$lid = $this->app->DB->GetInsertID();
|
|
if (!empty($lid)) {
|
|
$this->app->erp->RunHook('contact_person_created', 1, $lid);
|
|
}
|
|
$gruppen = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('gruppen'));
|
|
$gruppenarray = explode("|", $gruppen);
|
|
|
|
for ($i=0; $i < (!empty($gruppenarray)?count($gruppenarray):0) ; $i++) {
|
|
if($gruppenarray[$i] != ''){
|
|
$gruppenid = substr($gruppenarray[$i], 3);
|
|
$this->app->DB->Insert("INSERT INTO ansprechpartner_gruppen (ansprechpartner, gruppe, aktiv) VALUES ('$lid', '".$gruppenid."', '1')");
|
|
}
|
|
}
|
|
if($ansprechpartnerspeichern == ""){
|
|
echo json_encode(array('status'=>1));
|
|
$this->app->ExitXentral();
|
|
}
|
|
}else{
|
|
//Alten Eintrag updaten
|
|
$this->app->DB->Update("UPDATE ansprechpartner SET typ ='$typ', name = '$name', bereich = '$bereich', abteilung = '$abteilung', unterabteilung = '$unterabteilung', land = '$land', strasse = '$strasse', ort = '$ort', plz = '$plz', telefon = '$telefon', telefax = '$telefax', email = '$email', sonstiges = '$sonstiges', adresszusatz = '$adresszusatz', mobil = '$mobil', titel = '$titel', anschreiben = '$anschreiben', land = '$land', vorname = '$vorname', geburtstag = '$geburtstag', geburtstagkalender = '$geburtstagkalender', geburtstagskarte = '$geburtstagskarte', marketingsperre = '$marketingsperre', interne_bemerkung = '$internebemerkung' WHERE id = '$lid'");
|
|
$this->app->erp->RunHook('contact_person_updated', 1, $lid);
|
|
if($ansprechpartnerspeichern == ''){
|
|
echo json_encode(array('status'=>1));
|
|
$this->app->ExitXentral();
|
|
}
|
|
}
|
|
}else{
|
|
if($ansprechpartnerspeichern == ''){
|
|
echo json_encode(array('status'=>0,'statusText'=>$error));
|
|
$this->app->ExitXentral();
|
|
}
|
|
}
|
|
|
|
break;
|
|
case 'change':
|
|
$lid = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('lid'));
|
|
$wert = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('wert'));
|
|
$gruppe = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('gruppe'));
|
|
if($lid != 0){
|
|
$vorhanden = $this->app->DB->Select("SELECT id FROM ansprechpartner_gruppen WHERE ansprechpartner = '$lid' AND gruppe = '$gruppe'");
|
|
if($vorhanden){
|
|
$this->app->DB->Update("UPDATE ansprechpartner_gruppen SET aktiv = $wert WHERE ansprechpartner = '$lid' AND gruppe = '$gruppe'");
|
|
}else{
|
|
$this->app->DB->Insert("INSERT INTO ansprechpartner_gruppen (ansprechpartner, gruppe, aktiv) VALUES ('$lid', '$gruppe', '$wert')");
|
|
}
|
|
}
|
|
echo json_encode('success');
|
|
$this->app->ExitXentral();
|
|
break;
|
|
case 'delete':
|
|
$lid = $this->app->DB->real_escape_string($this->app->Secure->GetGET('lid'));
|
|
$this->app->erp->RunHook('contact_person_deleted', 1, $lid);
|
|
$this->app->DB->Delete("DELETE FROM ansprechpartner WHERE id = '$lid'");
|
|
echo json_encode('success');
|
|
$this->app->ExitXentral();
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
|
|
|
|
if($cmd=="alslieferadresse")
|
|
{
|
|
$this->app->Tpl->Set('STARTDISABLEANREDE',"<!--");
|
|
$this->app->Tpl->Set('ENDEDISABLEANREDE',"-->");
|
|
$als_lieferadresse=true;
|
|
$add_cmd = "&cmd=alslieferadresse";
|
|
}
|
|
|
|
$iframe = $this->app->Secure->GetGET("iframe");
|
|
|
|
if($iframe=="true")
|
|
$this->app->BuildNavigation=false;
|
|
|
|
|
|
if($delete==1)
|
|
{
|
|
$this->app->erp->RunHook('contact_person_deleted', 1, $lid);
|
|
$this->app->DB->Delete("DELETE FROM ansprechpartner WHERE id='$lid' AND adresse='$id' LIMIT 1");
|
|
$this->app->Location->execute("index.php?module=adresse&action=ansprechpartner$add_cmd&id=$id&iframe=$iframe");
|
|
}
|
|
$this->AdresseMenu();
|
|
if($iframe != "true")
|
|
{
|
|
/*
|
|
$gruppen = $this->app->DB->SelectArr("SELECT ag.aktiv as agaktiv, gr.* FROM gruppen gr LEFT JOIN ansprechpartner_gruppen ag ON gr.id = ag.gruppe and ag.ansprechpartner = '$lid' WHERE art != 'preisgruppe'");
|
|
if($gruppen)
|
|
{
|
|
$this->app->Tpl->Add('GRUPPEN','<table>');
|
|
|
|
foreach($gruppen as $gruppe)
|
|
{
|
|
$this->app->Tpl->Add('GRUPPEN','<tr><td><input type="checkbox" onchange="grchange('.$gruppe['id'].', this);" id="gr_'.$gruppe['id'].'" name="gr_'.$gruppe['id'].'" '.($gruppe['agaktiv']?' checked="checked" ':'').' '.($lid?'':' disabled ').' /></td><td>'.$gruppe['name'].'</td></tr>');
|
|
}
|
|
$this->app->Tpl->Add('GRUPPEN','</table>');
|
|
}*/
|
|
|
|
$this->app->YUI->TableSearch('GRUPPEN','adresse_ansprechpartnergruppen', "show","","",basename(__FILE__), __CLASS__);
|
|
$this->app->Tpl->Add('GRUPPEN','<div style="overflow:hidden;width:0;height:0;padding:0;margin:0;"><input type="text" value="'.$lid.'" id="filterlid" name="filterlid" /></div>
|
|
<script>$(document).ready(function() { $(\'#filterlid\').trigger(\'change\'); });
|
|
</script>
|
|
');
|
|
|
|
$this->app->Tpl->Set('ID',$id);
|
|
$this->app->Tpl->Set('LID',$lid);
|
|
} else {
|
|
$this->app->Tpl->Set('GRUPPEAUSBLENDENSTART',"<!--");
|
|
$this->app->Tpl->Set('GRUPPEAUSBLENDENENDE',"-->");
|
|
}
|
|
|
|
$this->app->YUI->DatePicker("geburtstag");
|
|
|
|
|
|
// neues arbeitspaket
|
|
/*
|
|
$widget = new WidgetAnsprechpartner($this->app,'TAB1');
|
|
$widget->form->SpecialActionAfterExecute("none",
|
|
"index.php?module=adresse&action=ansprechpartner&id=$id&iframe=".$iframe.$add_cmd);
|
|
if($lid > 0)
|
|
{
|
|
|
|
|
|
$this->app->Tpl->Set('BUTTON','
|
|
<input type="button" onclick="copyTextToClipboard(\''.$this->app->erp->AdresseAnschriftString($lid,true).'\')" value="Adresse in Zwischenspeicher">
|
|
');
|
|
|
|
$widget->form->SpecialActionAfterExecute("none",
|
|
"index.php?module=adresse&action=ansprechpartner&id=$id&iframe=".$iframe.$add_cmd);
|
|
$widget->Edit();
|
|
}
|
|
else
|
|
{
|
|
$widget->Create();
|
|
}*/
|
|
|
|
if($iframe=="true") {
|
|
if($als_lieferadresse)
|
|
$einfuegen = "<a onclick=\"AnsprechpartnerLieferadresse('%value%'); parent.closeIframe();\"><img src=\"./themes/[THEME]/images/down.png\" border=\"0\"></a>";
|
|
else
|
|
$einfuegen = "<a onclick=\"Ansprechpartner('%value%'); parent.closeIframe();\"><img src=\"./themes/[THEME]/images/down.png\" border=\"0\"></a>";
|
|
}
|
|
//Formula lieferadresse
|
|
// easy table mit arbeitspaketen YUI als template
|
|
/*if($als_lieferadresse)
|
|
{
|
|
$this->app->Tpl->Add("TAB1","<fieldset><legend>Filter</legend><input type=\"checkbox\" name=\"alle\" id=\"alle\"> auf alle Ansprechpartner zugreifen</fieldset>");
|
|
$this->app->YUI->TableSearch('TAB1',"adresse_ansprechpartnerlieferadresselist");
|
|
}
|
|
else*/
|
|
$this->app->YUI->TableSearch('TAB1',"adresse_ansprechpartnerlist");
|
|
//$this->app->Tpl->Parse('TAB1',"rahmen70.tpl");
|
|
$this->app->Tpl->Set('AKTIV_TAB1',"selected");
|
|
|
|
$this->app->Tpl->Set('ADRESSID',$id);
|
|
|
|
$adresstypen = $this->app->DB->SelectArr("SELECT type, bezeichnung FROM adresse_typ WHERE aktiv = 1 AND geloescht = 0".$this->app->erp->ProjektRechte());
|
|
|
|
$laender = $this->app->erp->GetSelectLaenderliste();
|
|
|
|
if($lid > 0){
|
|
$adresseland = $this->app->DB->Select("SELECT land FROM ansprechpartner WHERE id = '$lid' LIMIT 1");
|
|
}else{
|
|
$adresseland = $this->app->DB->Select("SELECT land FROM adresse WHERE id = '$id' LIMIT 1");
|
|
}
|
|
|
|
if($adresseland == ""){
|
|
$this->app->erp->Firmendaten('land');
|
|
}
|
|
|
|
|
|
if($adresstypen != ""){
|
|
$lieferadressetyp = "";
|
|
foreach($adresstypen as $key=>$value){
|
|
$lieferadressetyp .= '<option value="'.$value['type'].'">'.$value['bezeichnung'].'</option>';
|
|
}
|
|
}
|
|
|
|
if($laender != ""){
|
|
$lieferadresselaender = "";
|
|
foreach ($laender as $landKey => $land) {
|
|
$lieferadresselaender .= '<option '.($adresseland == $landKey?' selected="selected" ':'').' value="' . $landKey . '">' . $land . '</option>';
|
|
}
|
|
}
|
|
|
|
if($iframe=="true"){
|
|
$this->app->Tpl->Set("ANSPRECHPARTNERTYP", $lieferadressetyp);
|
|
}
|
|
|
|
$this->app->Tpl->Add("LANDSELECTED", $adresseland);
|
|
$this->app->Tpl->Add("ANSPRECHPARTNERLAENDER", $lieferadresselaender);
|
|
|
|
|
|
$this->app->YUI->CkEditor("interne_bemerkung", "basic");
|
|
|
|
|
|
if($iframe=="true")
|
|
$this->app->Tpl->Parse('PAGE',"ansprechpartneruebersicht_popup.tpl");
|
|
else
|
|
$this->app->Tpl->Parse('PAGE',"ansprechpartneruebersicht.tpl");
|
|
}
|
|
|
|
function AdresseAnsprechpartnerEditPopup()
|
|
{
|
|
$frame = $this->app->Secure->GetGET("frame");
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
if($frame=="false")
|
|
{
|
|
// hier nur fenster größe anpassen
|
|
$this->app->YUI->IframeDialog(600,320);
|
|
} else {
|
|
// nach page inhalt des dialogs ausgeben
|
|
$widget = new WidgetAnsprechpartner($this->app,'PAGE');
|
|
$adresse = $this->app->DB->Select("SELECT adresse FROM ansprechpartner WHERE id='$id' LIMIT 1");
|
|
$widget->form->SpecialActionAfterExecute("close_refresh",
|
|
"index.php?module=adresse&action=ansprechpartner&id=$adresse");
|
|
|
|
$widget->Edit();
|
|
$this->app->BuildNavigation=false;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
function AdresseLieferadressePopup()
|
|
{
|
|
$frame = $this->app->Secure->GetGET("frame");
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$this->AdresseLieferadresse();
|
|
$this->app->BuildNavigation=false;
|
|
}
|
|
|
|
|
|
function AdresseLieferadresse()
|
|
{
|
|
$this->AdresseMenu();
|
|
$id = $this->app->DB->real_escape_string($this->app->Secure->GetGET('id'));
|
|
$lid = $this->app->DB->real_escape_string($this->app->Secure->GetGET('lid'));
|
|
|
|
$delete = $this->app->Secure->GetGET("delete");
|
|
$create = $this->app->Secure->GetGET("create");
|
|
$module = $this->app->Secure->GetGET("module");
|
|
$action = $this->app->Secure->GetGET("action");
|
|
$iframe = $this->app->Secure->GetGET("iframe");
|
|
|
|
$cmd = $this->app->Secure->GetGET('cmd');
|
|
|
|
$lieferadressespeichern = $this->app->Secure->GetPOST('lieferadressespeichern');
|
|
|
|
if($lieferadressespeichern != ""){
|
|
$cmd = "save";
|
|
}
|
|
|
|
switch ($cmd) {
|
|
case 'get':
|
|
$data = $this->app->DB->SelectRow("SELECT * FROM lieferadressen WHERE id = '$lid'");
|
|
echo json_encode($data);
|
|
$this->app->ExitXentral();
|
|
break;
|
|
case 'save':
|
|
$lid = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('lid'));
|
|
$typ = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('typ'));
|
|
$name = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('name'));
|
|
$abteilung = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('abteilung'));
|
|
$unterabteilung = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('unterabteilung'));
|
|
$land = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('land'));
|
|
$strasse = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('strasse'));
|
|
$ort = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('ort'));
|
|
$plz = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('plz'));
|
|
$telefon = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('telefon'));
|
|
$email = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('email'));
|
|
$adresszusatz = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('adresszusatz'));
|
|
$standardlieferadresse = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('standardlieferadresse'));
|
|
$gln = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('gln'));
|
|
$ustid = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('ustid'));
|
|
$lieferbedingung = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('lieferbedingung'));
|
|
$ust_befreit = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('ust_befreit'));
|
|
$internebemerkung = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('interne_bemerkung'));
|
|
$hinweis = $this->app->DB->real_escape_string($this->app->Secure->GetPOST('hinweis'));
|
|
|
|
$error = "";
|
|
|
|
if(trim($name) == ""){
|
|
$error .= "Bitte Name ausfüllen"."\n";
|
|
}
|
|
|
|
if($standardlieferadresse == 1){
|
|
$this->app->DB->Update("UPDATE lieferadressen SET standardlieferadresse = 0 WHERE adresse='$id'");
|
|
}
|
|
|
|
if($lieferadressespeichern != ''){
|
|
if($error != ''){
|
|
$this->app->Tpl->Add("MESSAGE", "<div class=\"error\">$error</div>");
|
|
}else{
|
|
if($lid == '0'){
|
|
//Neuen Eintrag anlegen
|
|
$this->app->DB->Insert("INSERT INTO lieferadressen (typ,name,abteilung,unterabteilung,land,strasse,ort,plz,adresse,telefon,email,adresszusatz,logdatei,standardlieferadresse,gln,ustid,lieferbedingung,ust_befreit,interne_bemerkung,hinweis) VALUES ('$typ','$name','$abteilung','$unterabteilung','$land','$strasse','$ort','$plz','$id','$telefon','$email','$adresszusatz',NOW(),'$standardlieferadresse','$gln','$ustid','$lieferbedingung','$ust_befreit','$internebemerkung','$hinweis')");
|
|
}else{
|
|
//Alten Eintrag updaten
|
|
$this->app->DB->Update("UPDATE lieferadressen SET typ='$typ',name='$name',abteilung='$abteilung',unterabteilung='$unterabteilung',land='$land', strasse='$strasse',ort='$ort',plz='$plz',telefon='$telefon',email='$email',adresszusatz='$adresszusatz',standardlieferadresse='$standardlieferadresse',gln='$gln',ustid='$ustid',lieferbedingung='$lieferbedingung',ust_befreit='$ust_befreit',interne_bemerkung = '$internebemerkung',hinweis='$hinweis' WHERE id = '$lid'");
|
|
}
|
|
}
|
|
}else{
|
|
if($error == ''){
|
|
if($lid == '0'){
|
|
//Neuen Eintrag anlegen
|
|
$this->app->DB->Insert("INSERT INTO lieferadressen (typ,name,abteilung,unterabteilung,land,strasse,ort,plz,adresse,telefon,email,adresszusatz,logdatei,standardlieferadresse,gln,ustid,lieferbedingung,ust_befreit,interne_bemerkung,hinweis) VALUES ('$typ','$name','$abteilung','$unterabteilung','$land','$strasse','$ort','$plz','$id','$telefon','$email','$adresszusatz',NOW(),'$standardlieferadresse','$gln','$ustid','$lieferbedingung','$ust_befreit','$internebemerkung','$hinweis')");
|
|
echo json_encode(array('status'=>1));
|
|
$this->app->ExitXentral();
|
|
}
|
|
//Alten Eintrag updaten
|
|
$this->app->DB->Update("UPDATE lieferadressen SET typ='$typ',name='$name',abteilung='$abteilung',unterabteilung='$unterabteilung',land='$land', strasse='$strasse',ort='$ort',plz='$plz',telefon='$telefon',email='$email',adresszusatz='$adresszusatz',standardlieferadresse='$standardlieferadresse',gln='$gln',ustid='$ustid',lieferbedingung='$lieferbedingung',ust_befreit='$ust_befreit',interne_bemerkung = '$internebemerkung',hinweis='$hinweis' WHERE id = '$lid'");
|
|
echo json_encode(array('status'=>1));
|
|
$this->app->ExitXentral();
|
|
|
|
}
|
|
echo json_encode(array('status'=>0,'statusText'=>$error));
|
|
$this->app->ExitXentral();
|
|
|
|
}
|
|
|
|
|
|
break;
|
|
case 'delete':
|
|
$lid = $this->app->DB->real_escape_string($this->app->Secure->GetGET('lid'));
|
|
$this->app->DB->Delete("DELETE FROM lieferadressen WHERE id = '$lid'");
|
|
echo json_encode("success");
|
|
$this->app->ExitXentral();
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
|
|
|
|
if($iframe=="true"){
|
|
$this->app->BuildNavigation = false;
|
|
}
|
|
|
|
if($iframe=="true") {
|
|
$einfuegen = "<a onclick=\"Lieferadresse('%value%'); parent.closeIframe();\"><img src=\"./themes/[THEME]/images/down.png\" border=\"0\"></a>";
|
|
}
|
|
|
|
$this->app->Tpl->Set('ADRESSID',$id);
|
|
|
|
$adresstypen = $this->app->DB->SelectArr("SELECT type, bezeichnung FROM adresse_typ WHERE aktiv = 1 AND geloescht = 0".$this->app->erp->ProjektRechte());
|
|
|
|
$laender = $this->app->erp->GetSelectLaenderliste();
|
|
|
|
if($lid > 0){
|
|
$adresseland = $this->app->DB->Select("SELECT land FROM lieferadressen WHERE id = '$lid' LIMIT 1");
|
|
}else{
|
|
$adresseland = $this->app->DB->Select("SELECT land FROM adresse WHERE id = '$id' LIMIT 1");
|
|
}
|
|
|
|
if($adresseland == ""){
|
|
$this->app->erp->Firmendaten('land');
|
|
}
|
|
|
|
if($adresstypen != ""){
|
|
$lieferadressetyp = "";
|
|
foreach($adresstypen as $key=>$value){
|
|
$lieferadressetyp .= '<option value="'.$value['type'].'">'.$value['bezeichnung'].'</option>';
|
|
}
|
|
}
|
|
|
|
if($laender != ""){
|
|
$lieferadresselaender = "";
|
|
foreach ($laender as $landKey => $land) {
|
|
$lieferadresselaender .= '<option '.($adresseland == $landKey?' selected="selected" ':'').' value="' . $landKey . '">' . $land . '</option>';
|
|
}
|
|
}
|
|
|
|
if($iframe=="true"){
|
|
$this->app->Tpl->Set("LIEFERADRESSETYP", $lieferadressetyp);
|
|
}
|
|
$this->app->Tpl->Add("LANDSELECTED", $adresseland);
|
|
$this->app->Tpl->Add("LIEFERADRESSELAENDER", $lieferadresselaender);
|
|
|
|
|
|
$this->app->YUI->AutoComplete("lieferbedingung", "lieferbedingungen");
|
|
$this->app->YUI->CkEditor("interne_bemerkung", "basic");
|
|
$this->app->YUI->CkEditor("hinweis", "basic");
|
|
|
|
|
|
$this->app->Tpl->Add("TAB1",
|
|
|
|
'<div class="filter-box filter-usersave">
|
|
<div class="filter-block filter-inline">
|
|
<div class="filter-title">{|Filter|}</div>
|
|
<ul class="filter-list">
|
|
<li class="filter-item">
|
|
<label for="alle" class="switch">
|
|
<input type="checkbox" name="alle" id="alle">
|
|
<span class="slider round"></span>
|
|
</label>
|
|
<label for="alle">{|auf alle Lieferadressen zugreifen|}</label>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</div>');
|
|
|
|
|
|
$this->app->YUI->TableSearch('TAB1',"adresse_lieferadressenlist");
|
|
// $this->app->Tpl->Parse('TAB1',"rahmen70.tpl");
|
|
$this->app->Tpl->Set('AKTIV_TAB1',"selected");
|
|
|
|
if($iframe=="true"){
|
|
$this->app->Tpl->Parse('PAGE', "lieferadressenuebersicht_popup.tpl");
|
|
}
|
|
else{
|
|
$this->app->Tpl->Parse('PAGE', "lieferadressenuebersicht.tpl");
|
|
}
|
|
}
|
|
|
|
function AdresseLieferadressenEditPopup()
|
|
{
|
|
$frame = $this->app->Secure->GetGET("frame");
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
if($frame=="false")
|
|
{
|
|
// hier nur fenster größe anpassen
|
|
$this->app->YUI->IframeDialog(600,320);
|
|
} else {
|
|
// nach page inhalt des dialogs ausgeben
|
|
$widget = new WidgetLieferadressen($this->app,'PAGE');
|
|
$adresse = $this->app->DB->Select("SELECT adresse FROM lieferadressen WHERE id='$id' LIMIT 1");
|
|
$widget->form->SpecialActionAfterExecute("close_refresh", "index.php?module=adresse&action=lieferadresse&id=$adresse");
|
|
|
|
$widget->Edit();
|
|
$this->app->BuildNavigation=false;
|
|
}
|
|
}
|
|
|
|
function DruckerSelect($selected='') {
|
|
if($selected=='') {
|
|
$selected = $this->app->DB->Select("SELECT standarddrucker FROM user WHERE id='".$this->app->User->GetID()."' LIMIT 1");
|
|
}
|
|
|
|
$drucker = $this->app->DB->SelectArr("SELECT id, name FROM drucker WHERE firma='".$this->app->User->GetFirma()."' AND aktiv='1'");
|
|
if(empty($drucker)) {
|
|
return '';
|
|
}
|
|
$out = '';
|
|
foreach($drucker as $dr) {
|
|
$mark = '';
|
|
if($dr['id']==$selected) {
|
|
$mark='selected';
|
|
}
|
|
$out .="<option value=\"{$dr['id']}\" $mark>{$dr['name']}</option>";
|
|
}
|
|
return $out;
|
|
}
|
|
|
|
function AdresseBriefDrucken() {
|
|
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$type = $this->app->Secure->GetGET('type');
|
|
|
|
if($type === 'kalender') {
|
|
$dokument = $this->app->DB->SelectRow(
|
|
sprintf(
|
|
"SELECT
|
|
*, DATE_FORMAT(von, '%%d.%%m.%%Y') as datumvon, DATE_FORMAT(bis, '%%d.%%m.%%Y') as datumbis,
|
|
DATE_FORMAT(von, '%%H:%%i') as zeitvon, DATE_FORMAT(bis, '%%H:%%i') as zeitbis
|
|
FROM kalender_event
|
|
WHERE id = %d",
|
|
$id
|
|
)
|
|
);
|
|
}
|
|
elseif($type === 'wiedervorlage') {
|
|
$dokument = $this->app->DB->SelectRow(
|
|
sprintf(
|
|
"SELECT *,
|
|
DATE_FORMAT(datum_angelegt, '%%d.%%m.%%Y') as datum_angelegt,
|
|
DATE_FORMAT(datum_erinnerung, '%%d.%%m.%%Y') as datum_erinnerung,
|
|
DATE_FORMAT(zeit_angelegt, '%%H:%%i') as zeit_angelegt,
|
|
DATE_FORMAT(zeit_erinnerung, '%%H:%%i') as zeit_erinnerung
|
|
FROM wiedervorlage
|
|
WHERE id = %d",
|
|
$id
|
|
)
|
|
);
|
|
}
|
|
else{
|
|
$dokument = $this->app->DB->SelectRow(
|
|
sprintf(
|
|
"SELECT *, DATE_FORMAT(datum, '%%d.%%m.%%Y') as datum
|
|
FROM dokumente
|
|
WHERE id = %d",
|
|
$id
|
|
)
|
|
);
|
|
}
|
|
|
|
if (empty($dokument)) {
|
|
echo 'Korrespondenz noch nicht gespeichert.';
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
$adresse = $this->app->DB->SelectRow(
|
|
sprintf(
|
|
'SELECT *
|
|
FROM adresse
|
|
WHERE
|
|
id = %d',
|
|
($type !== 'kalender' && $type !== 'wiedervorlage')?$dokument['adresse_to']:$dokument['adresse']
|
|
)
|
|
);
|
|
|
|
if ($this->app->erp->Firmendaten('modul_mlm')) {
|
|
$sponsor = $this->app->DB->SelectRow(
|
|
sprintf(
|
|
'SELECT *
|
|
FROM adresse
|
|
WHERE id = %d' , $adresse['sponsor']
|
|
)
|
|
);
|
|
if ($sponsor) {
|
|
$sponsor = $sponsor['kundennummer'] . ' ' . $sponsor['name'];
|
|
}
|
|
else {
|
|
$sponsor = 'Kein Sponsor';
|
|
}
|
|
|
|
$table = '';
|
|
$table .= '<tr>';
|
|
$table .= '<th align="left" style="border-bottom: 2px solid #d7d7d7;">Vertragsbeginn:</th>';
|
|
$table .= '<td style="border-bottom: 2px solid #d7d7d7;"> ' . $adresse['mlmvertragsbeginn'] . '</td>';
|
|
$table .= '<th align="left" style="border-bottom: 2px solid #d7d7d7;">Sponsor:</th>';
|
|
$table .= '<td style="border-bottom: 2px solid #d7d7d7;"> ' . $sponsor . '</td>';
|
|
$table .= '</tr>';
|
|
|
|
$this->app->Tpl->Add('SPONSOR',$table);
|
|
}
|
|
|
|
|
|
$this->app->Tpl->Add('KUNDENNUMMER',$adresse['kundennummer']);
|
|
$this->app->Tpl->Add('ANREDE', ucfirst($adresse['typ']));
|
|
$this->app->Tpl->Add('NAME',$adresse['name']);
|
|
$this->app->Tpl->Add('ANSPRECHPARTNER',$dokument['ansprechpartner']);
|
|
$this->app->Tpl->Add('TELEFON',$adresse['telefon']);
|
|
$this->app->Tpl->Add('TELEFAX',$adresse['telefax']);
|
|
$this->app->Tpl->Add('TITEL',$adresse['titel']);
|
|
$this->app->Tpl->Add('ANSCHREIBEN',$adresse['anschreiben']);
|
|
$this->app->Tpl->Add('ABTEILUNG',$adresse['abteilung']);
|
|
$this->app->Tpl->Add('EMAIL',$adresse['email']);
|
|
$this->app->Tpl->Add('UNTERABTEILUNG',$adresse['unterabteilung']);
|
|
$this->app->Tpl->Add('MOBIL',$adresse['mobil']);
|
|
$this->app->Tpl->Add('ADRESSZUSATZ',$adresse['adresszusatz']);
|
|
$this->app->Tpl->Add('INTERNETSEITE',$adresse['internetseite']);
|
|
$this->app->Tpl->Add('STRASSE',$adresse['strasse']);
|
|
|
|
if ($adresse['kundenfreigabe'] == 1) {
|
|
$this->app->Tpl->Add('KUNDENFREIGABE','Ja');
|
|
} else {
|
|
$this->app->Tpl->Add('KUNDENFREIGABE','Nein');
|
|
}
|
|
|
|
$this->app->Tpl->Add('PLZORT',$adresse['plz'] . ' ' . $adresse['ort']);
|
|
|
|
if ($adresse['abweichende_rechnungsadresse'] == 1) {
|
|
$this->app->Tpl->Add('ABWEICHENDE_RECHNUNGSADRESSE','Ja');
|
|
} else {
|
|
$this->app->Tpl->Add('ABWEICHENDE_RECHNUNGSADRESSE','Nein');
|
|
}
|
|
|
|
$this->app->Tpl->Add('LAND',$adresse['land']);
|
|
if($type !== 'kalender' && $type !== 'wiedervorlage'){
|
|
$this->app->Tpl->Add('DATUMTEXT','Datum:');
|
|
$this->app->Tpl->Add('UHRZEITTEXT','Uhrzeit:');
|
|
$this->app->Tpl->Add('DATUM',$dokument['datum']);
|
|
$this->app->Tpl->Add('UHRZEIT',$dokument['uhrzeit']);
|
|
$this->app->Tpl->Add('BETREFF',$dokument['betreff']);
|
|
$this->app->Tpl->Add('BEARBEITER',$dokument['bearbeiter']);
|
|
$this->app->Tpl->Add('TEXT',nl2br($dokument['content']));
|
|
}elseif($type === 'kalender'){
|
|
$this->app->Tpl->Add('DATUMTEXT','von:');
|
|
$this->app->Tpl->Add('UHRZEITTEXT','bis:');
|
|
$this->app->Tpl->Add('DATUM',$dokument['datumvon'].' '.$dokument['zeitvon']);
|
|
$this->app->Tpl->Add('UHRZEIT',$dokument['datumbis'].' '.$dokument['zeitbis']);
|
|
$this->app->Tpl->Add('BETREFF',$dokument['bezeichnung']);
|
|
$this->app->Tpl->Add('BEARBEITER',$this->app->DB->Select("SELECT name FROM adresse WHERE id = '".$dokument['angelegtvon']."' LIMIT 1"));
|
|
$this->app->Tpl->Add('TEXT',nl2br($dokument['beschreibung']));
|
|
}elseif($type === 'wiedervorlage')
|
|
{
|
|
$this->app->Tpl->Add('DATUMTEXT','angelegt:');
|
|
$this->app->Tpl->Add('UHRZEITTEXT','Erinnerung:');
|
|
$this->app->Tpl->Add('DATUM',$dokument['datum_angelegt'].' '.$dokument['zeit_angelegt']);
|
|
$this->app->Tpl->Add('UHRZEIT',$dokument['datum_erinnerung'].' '.$dokument['zeit_erinnerung']);
|
|
$this->app->Tpl->Add('BETREFF',$dokument['bezeichnung']);
|
|
$this->app->Tpl->Add('BEARBEITER',$this->app->DB->Select("SELECT name FROM adresse WHERE id = '".$dokument['bearbeiter']."' LIMIT 1"));
|
|
$this->app->Tpl->Add('TEXT',nl2br($dokument['beschreibung']));
|
|
}
|
|
|
|
$this->app->Tpl->Output('adresse_brief_druck.tpl');
|
|
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
function AdresseBriefErstellen() {
|
|
|
|
//$this->AdresseMenu();
|
|
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$type = $this->app->Secure->GetGET('type');
|
|
|
|
$adresse = $this->app->DB->SelectRow(
|
|
sprintf(
|
|
'SELECT *
|
|
FROM adresse
|
|
WHERE id = %d' , $id
|
|
)
|
|
);
|
|
$this->app->Tpl->Add('EMPFAENGER',$adresse['name']);
|
|
//$kundennummer = $this->app->DB->Select("SELECT kundennummer from adresse where id = ".(int)$id)."";
|
|
//$this->app->Tpl->Add(BEARBEITER,$kundennummer." ".$this->app->DB->Select("SELECT name from adresse where id = ".(int)$id));
|
|
$this->app->Tpl->Add('ADRESSE',$adresse['kundennummer']." ".$adresse['name']);
|
|
$this->app->Tpl->Add('MITARBEITER',$this->app->DB->Select("SELECT mitarbeiternummer from adresse where id = ".$this->app->User->GetAdresse()." limit 1")." ".$this->app->User->GetName());
|
|
$this->app->Tpl->Add('BEARBEITER',$this->app->DB->Select("SELECT mitarbeiternummer from adresse where id = ".$this->app->User->GetAdresse()." limit 1")." ".$this->app->User->GetName());
|
|
$this->app->Tpl->Add('BEARBEITEROHNENUMMER',$this->app->User->GetName());
|
|
//$this->app->BuildNavigation=false;
|
|
|
|
$this->app->YUI->DatePicker("datum");
|
|
$this->app->Tpl->Add('DATUM', date('d.m.Y'));
|
|
$this->app->Tpl->Add('UHRZEIT', date('H:i'));
|
|
$this->app->Tpl->Add('DATUMBIS', date('d.m.Y'));
|
|
$this->app->Tpl->Add('UHRZEITBIS', date('H:i'));
|
|
$this->app->Tpl->Add('DATUM_ERINNERUNG',date("d.m.Y",strtotime ("+1 day")));
|
|
$this->app->Tpl->Add('UHRZEIT_ERINNERUNG', date('H:i'));
|
|
|
|
|
|
if ($type) {
|
|
switch ($type) {
|
|
case 'wiedervorlage':
|
|
$this->app->YUI->DatePicker("datum_erinnerung");
|
|
if($this->app->erp->Firmendaten("briefhtml")=="1")
|
|
{
|
|
$this->app->YUI->CkEditor("content","internal", array('resize_dir'=>'both'), 'JQUERY2');
|
|
}
|
|
for($i=0;$i<=100;$i += 10)
|
|
{
|
|
$this->app->Tpl->Add("CHANCE","<option value=\"$i\">$i %</option>");
|
|
}
|
|
|
|
$template = 'adresse_brief_wiedervorlage.tpl';
|
|
break;
|
|
break;
|
|
case 'kalender':
|
|
$this->app->YUI->DatePicker("datum");
|
|
$this->app->YUI->DatePicker("datumbis");
|
|
$this->app->YUI->TimePicker("uhrzeit");
|
|
$this->app->YUI->TimePicker("uhrzeitbis");
|
|
$template = 'adresse_brief_kalender.tpl';
|
|
if($this->app->erp->Firmendaten("briefhtml")=="1")
|
|
{
|
|
$this->app->YUI->CkEditor("content","internal", array('resize_dir'=>'both'), 'JQUERY2');
|
|
}
|
|
break;
|
|
break;
|
|
case 'brief':
|
|
|
|
$this->app->Tpl->Add('SENDER', $this->app->User->GetName());
|
|
$this->app->Tpl->Add('STRASSE',$adresse['strasse']);
|
|
$this->app->Tpl->Add('PLZ',$adresse['plz']);
|
|
$this->app->Tpl->Add('ORT',$adresse['ort']);
|
|
$this->app->Tpl->Add('INTERNEBEZEICHNUNG',$adresse['internebezeichnung']);
|
|
|
|
$laender = $this->app->erp->GetSelectLaenderliste();
|
|
$laenderStr = '';
|
|
foreach ($laender as $landKey => $land) {
|
|
$laenderStr .= '<option '.($adresse['land'] == $landKey?' selected="selected" ':'').' value="' . $landKey . '">' . $land . '</option>';
|
|
}
|
|
|
|
$this->app->Tpl->Add('LAND',$laenderStr);
|
|
|
|
$this->app->Tpl->Set('DRUCKERSELECT', $this->DruckerSelect());
|
|
if($this->app->erp->Firmendaten("briefhtml")=="1")
|
|
{
|
|
$this->app->YUI->CkEditor("content","internal", array('resize_dir'=>'both'), 'JQUERY2');
|
|
}
|
|
|
|
$template = 'adresse_brief_brief.tpl';
|
|
break;
|
|
case 'email':
|
|
|
|
$this->app->YUI->AutoComplete("email_an","emailname");
|
|
$this->app->YUI->AutoCompleteAdd("email_cc","emailname");
|
|
$this->app->YUI->AutoCompleteAdd("email_bcc","emailname");
|
|
|
|
$this->app->Tpl->Set('EMAIL_SENDER', $this->app->erp->GetSelectEmailMitName());
|
|
if (!empty($adresse['email'])) {
|
|
$this->app->Tpl->Add('EMAIL_AN',str_replace('"','"',$adresse['name']) . ' <' . $adresse['email'] . '>');
|
|
}
|
|
|
|
$anschreiben = $this->app->DB->Select("SELECT anschreiben FROM adresse WHERE id='".$ticket_from_db['adresse']."' LIMIT 1");
|
|
if($anschreiben=="")
|
|
{
|
|
$anschreiben = $this->app->erp->Beschriftung("dokument_anschreiben").",\n".$this->app->erp->Grussformel($projekt,$sprache);
|
|
}
|
|
$this->app->Tpl->Add('CONTENT',$anschreiben);
|
|
|
|
$projekt = $this->app->DB->Select("SELECT abkuerzung FROM projekt INNER JOIN adresse ON adresse.projekt = projekt.id WHERE adresse.id='".$id."' LIMIT 1");
|
|
$this->app->Tpl->Set('PROJEKT', $projekt);
|
|
|
|
$anhaenge = '';
|
|
$anhaenge .= '<tr><td nowrap>Datei:</td><td><input type="file" name="upload[]" id="file" /></td></tr>';
|
|
// $anhaenge .= '<tr><td nowrap>Datei 2:</td><td><input type="file" name="upload[]" /></td></tr>';
|
|
// $anhaenge .= '<tr><td nowrap>Datei 3:</td><td><input type="file" name="upload[]" /></td></tr>';
|
|
|
|
$this->app->Tpl->Add('ANHAENGEHERAUFLADEN', $anhaenge);
|
|
$anhaenge = '<tr><td colspan=3 align=center><i>Keine Anhänge vorhanden</i></td></tr>';
|
|
$this->app->Tpl->Add('ANHAENGE', $anhaenge);
|
|
if($this->app->erp->Firmendaten("briefhtml")=="1")
|
|
{
|
|
$this->app->YUI->CkEditor("content","internal", array('resize_dir'=>'both'), 'JQUERY2');
|
|
}
|
|
// $this->app->Tpl->Parse('PAGE',"adresse_brief_email.tpl");
|
|
$template = 'adresse_brief_email.tpl';
|
|
break;
|
|
case 'telefon':
|
|
// $this->app->Tpl->Parse('PAGE',"adresse_brief_telefon.tpl");
|
|
if($this->app->erp->Firmendaten("briefhtml")=="1")
|
|
{
|
|
$this->app->YUI->CkEditor("content","internal", array('resize_dir'=>'both'), 'JQUERY2');
|
|
}
|
|
$template = 'adresse_brief_telefon.tpl';
|
|
break;
|
|
case 'notiz':
|
|
// $this->app->Tpl->Parse('PAGE',"adresse_brief_notiz.tpl");
|
|
if($this->app->erp->Firmendaten("briefhtml")=="1")
|
|
{
|
|
$this->app->YUI->CkEditor("content","internal", array('resize_dir'=>'both'), 'JQUERY2');
|
|
}
|
|
$template = 'adresse_brief_notiz.tpl';
|
|
break;
|
|
default:
|
|
// $this->app->Tpl->Parse('PAGE',"adresse_brief_email.tpl");
|
|
if($this->app->erp->Firmendaten("briefhtml")=="1")
|
|
{
|
|
$this->app->YUI->CkEditor("content","internal", array('resize_dir'=>'both'), 'JQUERY2');
|
|
}
|
|
$template = 'adresse_brief_email.tpl';
|
|
break;
|
|
}
|
|
} else {
|
|
$this->app->Tpl->Add('EMAIL',$adresse['email']);
|
|
// $this->app->Tpl->Parse('PAGE',"adresse_brief_email.tpl");
|
|
if($this->app->erp->Firmendaten("briefhtml")=="1")
|
|
{
|
|
$this->app->YUI->CkEditor("content","internal", array('resize_dir'=>'both'), 'JQUERY2');
|
|
}
|
|
$template = 'adresse_brief_email.tpl';
|
|
}
|
|
|
|
$this->app->Tpl->Output($template);
|
|
$this->app->ExitXentral();
|
|
|
|
/*
|
|
$this->app->BuildNavigation=false;
|
|
$this->app->Tpl->Set('INHALT',"");
|
|
$this->app->Tpl->Parse('PAGE',"adresse_brief_email.tpl");
|
|
*/
|
|
|
|
|
|
}
|
|
|
|
|
|
function AdresseBriefCreatePDF($dokumentId, $display=true) {
|
|
|
|
$data = $this->app->DB->SelectRow(
|
|
sprintf(
|
|
'SELECT *
|
|
FROM dokumente
|
|
WHERE id = %d',
|
|
$dokumentId
|
|
)
|
|
);
|
|
|
|
$data['firma'] = $this->app->DB->Select('
|
|
SELECT
|
|
MAX(id)
|
|
FROM
|
|
firma
|
|
LIMIT 1
|
|
');
|
|
|
|
/* $data['firma'] = $this->app->DB->Select('
|
|
SELECT
|
|
absender
|
|
FROM
|
|
firmendaten
|
|
WHERE
|
|
id = ' . $data['firma'] . '
|
|
');*/
|
|
|
|
$data['firma'] = $this->app->DB->Select('
|
|
SELECT
|
|
wert
|
|
FROM
|
|
firmendaten_werte
|
|
WHERE
|
|
name = \'absender\'
|
|
');
|
|
|
|
|
|
|
|
$korrespondenz = new KorrespondenzPDF($this->app,$data['projekt']);
|
|
$korrespondenz->SetBetreff($this->app->erp->ReadyForPDF($data['betreff']));
|
|
|
|
$korrespondenz->SetDetail('Datum', $this->app->String->Convert($data['datum'],"%1-%2-%3","%3.%2.%1"));
|
|
$korrespondenz->SetDetail('Bearbeiter', $this->app->erp->ReadyForPDF($data['von']));
|
|
|
|
$korrespondenz->setRecipient(
|
|
array(
|
|
$this->app->erp->ReadyForPDF($data['an']),
|
|
$this->app->erp->ReadyForPDF($data['ansprechpartner']),
|
|
'',
|
|
$this->app->erp->ReadyForPDF($data['adresse']),
|
|
$data['plz'],
|
|
$this->app->erp->ReadyForPDF($data['ort']),
|
|
$data['land']
|
|
)
|
|
);
|
|
|
|
if(strpos($data['betreff'],'{') !== false) {
|
|
$data['betreff'] = $this->app->erp->ParseUserVars('adresse', $data['adresse_to'], $data['betreff']);
|
|
}
|
|
if(strpos($data['content'],'{') !== false) {
|
|
$data['content'] = $this->app->erp->ParseUserVars('adresse', $data['adresse_to'], $data['content']);
|
|
}
|
|
|
|
$korrespondenz->setLetterDetails(
|
|
array(
|
|
$this->app->erp->ReadyForPDF($data['betreff']),
|
|
str_replace('\r\n',"\n\n",$this->app->erp->ReadyForPDF($data['content']))
|
|
)
|
|
);
|
|
$korrespondenz->setAbsender($data['firma']);
|
|
|
|
$korrespondenz->Create();
|
|
|
|
if($display) {
|
|
$korrespondenz->displayDocument();
|
|
} else {
|
|
return $korrespondenz->displayTMP();
|
|
}
|
|
}
|
|
|
|
function AdresseBriefSaveDocument() {
|
|
|
|
$data = array();
|
|
$data['user'] = '';
|
|
$data['datum'] = $this->app->Secure->GetPOST('datum');
|
|
$data['von'] = $this->app->Secure->GetPOST('von');
|
|
$data['firma'] = $this->app->Secure->GetPOST('firma');
|
|
$data['ansprechpartner'] = $this->app->Secure->GetPOST('ansprechpartner');
|
|
$data['an'] = $this->app->Secure->GetPOST('an');
|
|
$data['email_an'] = $this->app->Secure->GetPOST('email_an');
|
|
$data['email_cc'] = $this->app->Secure->GetPOST('email_cc');
|
|
$data['email_bcc'] = $this->app->Secure->GetPOST('email_bcc');
|
|
$data['firma_an'] = $this->app->Secure->GetPOST('firma_an');
|
|
$data['adresse'] = $this->app->Secure->GetPOST('adresse');
|
|
$data['plz'] = $this->app->Secure->GetPOST('plz');
|
|
$data['ort'] = $this->app->Secure->GetPOST('ort');
|
|
$data['internebezeichnung'] = $this->app->Secure->GetPOST('internebezeichnung');
|
|
$data['land'] = $this->app->Secure->GetPOST('land');
|
|
$data['betreff'] = $this->app->Secure->GetPOST('betreff');
|
|
$data['content'] = $this->app->Secure->GetPOST('content');
|
|
$data['signatur'] = $this->app->Secure->GetPOST('signatur');
|
|
$data['send_as'] = $this->app->Secure->GetPOST('send_as');
|
|
$data['email'] = $this->app->Secure->GetPOST('email');
|
|
$data['printer'] = $this->app->Secure->GetPOST('printer');
|
|
$data['fax'] = $this->app->Secure->GetPOST('fax');
|
|
$data['user'] = $this->app->Secure->GetGET('id');
|
|
$data['signatur'] = $this->app->Secure->GetPOST('signatur');
|
|
$data['eintragId'] = $this->app->Secure->GetPOST('eintragId');
|
|
$data['projekt'] = $this->app->Secure->GetPOST('projekt');
|
|
|
|
$data['projekt'] = explode(' ',$data['projekt']);
|
|
if($data['projekt'][0] !="")
|
|
$data['projekt'] = $this->app->DB->Select("SELECT id FROM projekt WHERE abkuerzung='".$data['projekt'][0]."' AND abkuerzung!='' LIMIT 1");
|
|
|
|
$data['uhrzeit'] = $this->app->Secure->GetPOST('uhrzeit');
|
|
if (!$data['uhrzeit']) {
|
|
$data['uhrzeit'] = date('H:i:s');
|
|
}
|
|
|
|
$data['bearbeiter'] = $this->app->Secure->GetPOST('bearbeiter');
|
|
|
|
if (!empty($data['signatur'])) {
|
|
$data['signatur'] = 1;
|
|
} else {
|
|
$data['signatur'] = 0;
|
|
}
|
|
|
|
if (!$data['datum']) {
|
|
$data['datum'] = date('d.m.Y');
|
|
}
|
|
|
|
$data['typ'] = $this->app->Secure->GetPOST('type');
|
|
if (!$data['typ']) {
|
|
$data['typ'] = 'brieffax';
|
|
}
|
|
|
|
$adresse = $this->app->User->GetAdresse();
|
|
$datum = $this->app->String->Convert($data['datum'],"%1.%2.%3","%3-%2-%1");
|
|
|
|
if (isset($data['eintragId']) && !empty($data['eintragId'])) {
|
|
|
|
$this->app->DB->Insert('
|
|
UPDATE
|
|
dokumente
|
|
SET
|
|
adresse_from = "' . $adresse . '",
|
|
adresse_to = "' . $data['user'] . '",
|
|
typ = "' . $data['typ'] . '",
|
|
von = "' . $data['von'] . '",
|
|
firma = "' . $data['firma'] . '",
|
|
ansprechpartner = "' . $data['ansprechpartner'] . '",
|
|
internebezeichnung = "' . $data['internebezeichnung'] . '",
|
|
an = "' . $data['an'] . '",
|
|
email_an = "' . $data['email_an'] . '",
|
|
email_cc = "' . $data['email_cc'] . '",
|
|
email_bcc = "' . $data['email_bcc'] . '",
|
|
firma_an = "' . $data['firma_an'] . '",
|
|
adresse = "' . $data['adresse'] . '",
|
|
plz = "' . $data['plz'] . '",
|
|
ort = "' . $data['ort'] . '",
|
|
land = "' . $data['land'] . '",
|
|
datum = "' . $datum . '",
|
|
betreff = "' . $data['betreff'] . '",
|
|
content = "' . $data['content'] . '",
|
|
signatur = "' . $data['signatur'] . '",
|
|
send_as = "' . $data['send_as'] . '",
|
|
email = "' . $data['email'] . '",
|
|
printer = "' . $data['printer'] . '",
|
|
fax = "' . $data['fax'] . '",
|
|
created = NOW(),
|
|
uhrzeit = "' . $data['uhrzeit'] . '",
|
|
projekt = "' . $data['projekt'] . '",
|
|
bearbeiter = "' . $data['bearbeiter'] . '"
|
|
WHERE
|
|
id = ' . $data['eintragId'] . '
|
|
');
|
|
|
|
$returnId = $data['eintragId'];
|
|
|
|
} else {
|
|
|
|
$returnId = $this->app->erp->DokumentCreate($data,$adresse);
|
|
}
|
|
|
|
if($returnId && $data['typ'] == 'email')
|
|
{
|
|
if(isset($_FILES['upload']) && is_array($_FILES['upload']))
|
|
{
|
|
foreach($_FILES['upload']['tmp_name'] as $key => $file)
|
|
{
|
|
if($file != "")
|
|
{
|
|
$fileid = $this->app->erp->CreateDatei($_FILES['upload']['name'][$key], $_FILES['upload']['name'][$key], "", "", $_FILES['upload']['tmp_name'][$key], $this->app->User->GetName());
|
|
// stichwoerter hinzufuegen
|
|
$this->app->erp->AddDateiStichwort($fileid, "anhang", "dokument", $returnId);
|
|
}
|
|
}
|
|
}
|
|
$this->app->Tpl->Add('AJAXBRIEF', "
|
|
$.ajax({
|
|
url: 'index.php',
|
|
data: {
|
|
module: 'adresse',
|
|
action: 'briefbearbeiten',
|
|
typ : 'email',
|
|
id: ".$returnId."
|
|
},
|
|
beforeSend: function() {
|
|
App.loading.open();
|
|
},
|
|
success: function(data) {
|
|
|
|
$('.alleAnzeigen').show();
|
|
|
|
$('.adresse_brief_anlegen').css({
|
|
width: $('.adresse_brief_tabelle').width()
|
|
});
|
|
|
|
|
|
$('.adresse_brief_tabelle').find('fieldset').hide();
|
|
$('.adresse_brief_tabelle').find('.adresse_brief_tabelle_view').hide();
|
|
|
|
$('.adresse_brief_anlegen')
|
|
.html(data)
|
|
.show();
|
|
|
|
fnFilterColumn8(0);
|
|
App.loading.close();
|
|
}
|
|
});
|
|
");
|
|
}
|
|
|
|
return $returnId;
|
|
|
|
}
|
|
|
|
|
|
function AdresseBriefPreview($type = '', $id = '', $json = true) {
|
|
|
|
if(!$type)$type = $this->app->Secure->GetGET('type');
|
|
if(!$id)$id = $this->app->Secure->GetGET('id');
|
|
|
|
$query = '';
|
|
if ($type) {
|
|
switch ($type) {
|
|
case 'dokumente':
|
|
$query .= '
|
|
SELECT
|
|
id,
|
|
DATE_FORMAT(datum, "%d.%m.%Y") as datum,
|
|
betreff,
|
|
content
|
|
FROM
|
|
dokumente
|
|
WHERE
|
|
id = ' . $id . '
|
|
';
|
|
break;
|
|
case 'dokumente_send':
|
|
$query .= '
|
|
SELECT
|
|
id,
|
|
DATE_FORMAT(zeit, "%d.%m.%Y") as datum,
|
|
betreff,
|
|
text as content
|
|
FROM
|
|
dokumente_send
|
|
WHERE
|
|
id = ' . $id . '
|
|
';
|
|
break;
|
|
case 'ticket_nachricht':
|
|
$query .= '
|
|
SELECT
|
|
id,
|
|
DATE_FORMAT(zeit, "%d.%m.%Y") as datum,
|
|
betreff,
|
|
text as content
|
|
FROM
|
|
ticket_nachricht
|
|
WHERE
|
|
id = ' . $id . '
|
|
';
|
|
break;
|
|
case 'wiedervorlage':
|
|
$query .= '
|
|
SELECT
|
|
id,
|
|
DATE_FORMAT(datum_angelegt, "%d.%m.%Y") as datum,
|
|
DATE_FORMAT(datum_erinnerung, "%d.%m.%Y") as datum_erinnerung,
|
|
DATE_FORMAT(zeit_angelegt,"%H:%i") as zeit_angelegt,
|
|
zeit_erinnerung,
|
|
bezeichnung as betreff,
|
|
beschreibung as content
|
|
FROM
|
|
wiedervorlage
|
|
WHERE
|
|
id = ' . $id . '
|
|
';
|
|
break;
|
|
case 'kalender':
|
|
$query .= '
|
|
SELECT
|
|
id,
|
|
DATE_FORMAT(von, "%d.%m.%Y") as datum,
|
|
DATE_FORMAT(bis, "%d.%m.%Y") as datumbis,
|
|
DATE_FORMAT(von, "%H:%i:%s") as uhrzeit,
|
|
DATE_FORMAT(bis, "%H:%i:%s") as uhrzeitbis,
|
|
allDay,
|
|
public,
|
|
adresseintern,
|
|
bezeichnung as betreff,
|
|
beschreibung as content
|
|
FROM
|
|
kalender_event
|
|
WHERE
|
|
id = ' . $id . '
|
|
';
|
|
break;
|
|
}
|
|
|
|
}
|
|
|
|
$res = $this->app->DB->SelectRow($query);
|
|
if ($res) {
|
|
/*
|
|
if (isset($res['content'])) {
|
|
$res['content'] = '<input type="button" onclick="briefDrucken(' . $res['id'] . ');" value="Drucken"><br><br>'.nl2br($res['content']);
|
|
}
|
|
*/
|
|
}
|
|
if(isset($res['datum']) && !$tickets)
|
|
{
|
|
if($type=="kalender" || $type=="dokumente_send")
|
|
$res['content'] = $res['content'];
|
|
else
|
|
$res['content'] = '<b>Angelegt am: '.$res['datum'].(isset($res['zeit_angelegt'])?' '.$res['zeit_angelegt']:'')."</b><br />".$res['content'];
|
|
}
|
|
|
|
if($json)
|
|
{
|
|
echo json_encode($res);
|
|
} else {
|
|
//$ausg = "<h2>".$res['datum'].' '.$res['betreff']."</h2>".nl2br($res['content']);
|
|
//if($res['content']=="") $res['content']="Kein Inhalt vorhanden";
|
|
|
|
if($this->app->erp->isHTML($res['content']))
|
|
$ausg = $res['content'];
|
|
else
|
|
$ausg = nl2br($res['content']);
|
|
echo $ausg;
|
|
}
|
|
$this->app->ExitXentral();
|
|
|
|
}
|
|
|
|
function AdresseBriefBearbeiten() {
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$type = $this->app->Secure->GetGET('type');
|
|
$typ = $this->app->Secure->GetGET('typ');
|
|
|
|
if($typ === 'kalender')
|
|
{
|
|
$query = '
|
|
SELECT
|
|
id,
|
|
DATE_FORMAT(von, "%d.%m.%Y") as datum,
|
|
DATE_FORMAT(bis, "%d.%m.%Y") as datumbis,
|
|
DATE_FORMAT(von, "%H:%i") as uhrzeit,
|
|
DATE_FORMAT(bis, "%H:%i") as uhrzeitbis,
|
|
allDay,
|
|
public,
|
|
adresse,
|
|
ansprechpartner_id,
|
|
angelegtvon,
|
|
adresseintern,
|
|
bezeichnung,
|
|
beschreibung
|
|
FROM
|
|
kalender_event
|
|
WHERE
|
|
id = ' . $id . '
|
|
';
|
|
}elseif($typ === 'wiedervorlage')
|
|
{
|
|
$query = 'SELECT * from wiedervorlage where id = '.(int)$id;
|
|
}else{
|
|
|
|
$query = '
|
|
SELECT
|
|
d.id,
|
|
d.typ,
|
|
d.von,
|
|
d.firma,
|
|
d.an,
|
|
d.email_an,
|
|
d.email_cc,
|
|
d.email_bcc,
|
|
d.ansprechpartner,
|
|
d.internebezeichnung,
|
|
d.adresse,
|
|
d.plz,
|
|
d.ort,
|
|
d.land,
|
|
DATE_FORMAT(d.datum, "%d.%m.%Y") as datum,
|
|
d.betreff,
|
|
d.content,
|
|
d.bearbeiter,
|
|
DATE_FORMAT(d.uhrzeit,"%H:%i") as uhrzeit,
|
|
CONCAT(p.abkuerzung," ",p.name) as projekt
|
|
FROM
|
|
dokumente d
|
|
LEFT JOIN projekt p ON p.id=d.projekt
|
|
WHERE
|
|
d.id = ' . $id . '
|
|
';
|
|
}
|
|
$dokument = $this->app->DB->SelectRow($query);
|
|
|
|
if($typ === 'kalender')
|
|
{
|
|
$this->app->YUI->DateiPopup('DATEIENBUTTON', 'kalender_event', $dokument['id']);
|
|
$template = 'adresse_brief_kalender.tpl';
|
|
if($this->app->erp->Firmendaten("briefhtml")=="1")
|
|
{
|
|
$this->app->YUI->CkEditor("content","internal", null, 'JQUERY2');
|
|
}
|
|
$bearbeiternummer = $this->app->DB->Select("SELECT mitarbeiternummer from adresse where id = ".$dokument['angelegtvon']." limit 1");
|
|
$adressdaten = $this->app->DB->SelectRow("SELECT name, kundennummer, lieferantennummer from adresse where id = ".$dokument['adresse']." limit 1");
|
|
|
|
if($dokument['ansprechpartner_id'] != "" && $dokument['ansprechpartner_id'] > 0){
|
|
$ansprechpartnerId = $this->app->DB->Select("SELECT id FROM ansprechpartner WHERE id = '" . $dokument['ansprechpartner_id'] . "' LIMIT 1");
|
|
if($ansprechpartnerId != "" && $ansprechpartnerId > 0){
|
|
$ansprechpartnerName = $this->app->DB->Select("SELECT name FROM ansprechpartner WHERE id = '$ansprechpartnerId' LIMIT 1");
|
|
$ansprechpartner = $ansprechpartnerId . ' ' . $ansprechpartnerName;
|
|
$ansprechpartner .= ' (' . $adressdaten['name'] . ', Kdr: ' . $adressdaten['kundennummer'] . ' ';
|
|
if($adressdaten['lieferantennummer'] != ''){
|
|
$ansprechpartner .= 'Liefr: ' . $adressdaten['lieferantennummer'];
|
|
}
|
|
$ansprechpartner .= ')';
|
|
$dokument['ansprechpartner'] = $ansprechpartner;
|
|
}
|
|
}
|
|
|
|
$datum = $dokument['datum'];
|
|
$datumbis = $dokument['datumbis'];
|
|
$this->app->Tpl->Add('UHRZEIT',$dokument['uhrzeit']);
|
|
$this->app->Tpl->Add('UHRZEITBIS',$dokument['uhrzeitbis']);
|
|
$this->app->Tpl->Add('DATUM',$datum);
|
|
$this->app->Tpl->Add('DATUMBIS',$datumbis);
|
|
if($dokument['allDay'])$this->app->Tpl->Set('ALLDAY',' checked="checked" ');
|
|
if($dokument['public'])$this->app->Tpl->Set('PUBLIC',' checked="checked" ');
|
|
$this->app->Tpl->Add('ADRESSEINTERN',$this->app->DB->Select("SELECT CONCAT(id,' ',name) from adresse where id = ".$dokument['adresseintern']." limit 1"));
|
|
$this->app->Tpl->Add('CONTENT',$dokument['beschreibung']);
|
|
$this->app->Tpl->Add('BETREFF',$dokument['bezeichnung']);
|
|
$this->app->Tpl->Add('BEARBEITER',$bearbeiternummer?$bearbeiternummer.' '.$this->app->DB->Select("SELECT name from adresse where id = ".$dokument['angelegtvon']." limit 1"):'');
|
|
$this->app->Tpl->Add('ANSPRECHPARTNER',$dokument['ansprechpartner']);
|
|
$check = $this->app->DB->SelectArr("SELECT * FROM layoutvorlagen WHERE kategorie like 'Besuchsbericht' order by name");
|
|
if($check)
|
|
{
|
|
$this->app->Tpl->Set('LAYOUTBUTTON','<a href="index.php?module=adresse&action=brief&cmd=layoutoeffnen&id='.$id.'&layout='.$check[0]['id'].'" target="_blank"><input type="button" name="close" value="Besuchsbericht" /></a>');
|
|
}
|
|
|
|
}
|
|
elseif($typ == 'wiedervorlage')
|
|
{
|
|
if($this->app->erp->Firmendaten("briefhtml")=="1")
|
|
{
|
|
$this->app->YUI->CkEditor("content","internal",null, 'JQUERY2');
|
|
}
|
|
$this->app->YUI->DateiPopup('DATEIENBUTTON', 'wiedervorlage', $dokument['id']);
|
|
$template = 'adresse_brief_wiedervorlage.tpl';
|
|
$mitarbeiternummer = $this->app->DB->Select("SELECT mitarbeiternummer from adresse where id = ".$dokument['adresse_mitarbeiter']." limit 1");
|
|
$bearbeiternummer = $this->app->DB->Select("SELECT mitarbeiternummer from adresse where id = ".$dokument['bearbeiter']." limit 1");
|
|
$kundennummer = $this->app->DB->Select("SELECT kundennummer from adresse where id = ".$dokument['adresse']." limit 1");
|
|
$adressdaten = $this->app->DB->SelectRow("SELECT name, kundennummer, lieferantennummer from adresse where id = ".$dokument['adresse']." limit 1");
|
|
|
|
if($dokument['ansprechpartner_id'] != "" && $dokument['ansprechpartner_id'] > 0){
|
|
$ansprechpartnerId = $this->app->DB->Select("SELECT id FROM ansprechpartner WHERE id = '" . $dokument['ansprechpartner_id'] . "' LIMIT 1");
|
|
if($ansprechpartnerId != "" && $ansprechpartnerId > 0){
|
|
$ansprechpartnerName = $this->app->DB->Select("SELECT name FROM ansprechpartner WHERE id = '$ansprechpartnerId' LIMIT 1");
|
|
$ansprechpartner = $ansprechpartnerId . ' ' . $ansprechpartnerName;
|
|
$ansprechpartner .= ' (' . $adressdaten['name'] . ', Kdr: ' . $adressdaten['kundennummer'] . ' ';
|
|
if($adressdaten['lieferantennummer'] != ''){
|
|
$ansprechpartner .= 'Liefr: ' . $adressdaten['lieferantennummer'];
|
|
}
|
|
$ansprechpartner .= ')';
|
|
$dokument['ansprechpartner'] = $ansprechpartner;
|
|
}
|
|
}
|
|
|
|
$dokument['datum_angelegt'] = $this->app->String->Convert($dokument['datum_angelegt'],"%1-%2-%3","%3.%2.%1");
|
|
$dokument['datum_erinnerung'] = $this->app->String->Convert($dokument['datum_erinnerung'],"%1-%2-%3","%3.%2.%1");
|
|
$this->app->Tpl->Add('DATUM',$dokument['datum_angelegt']);
|
|
$this->app->Tpl->Add('UHRZEIT',$dokument['zeit_angelegt']);
|
|
$this->app->Tpl->Add('BEARBEITER',$bearbeiternummer?$bearbeiternummer.' '.$this->app->DB->Select("SELECT name from adresse where id = ".$dokument['bearbeiter']." limit 1"):'');
|
|
$this->app->Tpl->Add('BETREFF',$dokument['bezeichnung']);
|
|
$this->app->Tpl->Add('MITARBEITER',$mitarbeiternummer?$mitarbeiternummer.' '.$this->app->DB->Select("SELECT name from adresse where id = ".$dokument['adresse_mitarbeiter']." limit 1"):'');
|
|
$this->app->Tpl->Add('ADRESSE',$kundennummer?$kundennummer.' '.$this->app->DB->Select("SELECT name from adresse where id = ".$dokument['adresse']." limit 1"):'');
|
|
$this->app->Tpl->Add('CONTENT',$dokument['beschreibung']);
|
|
$this->app->Tpl->Add('DATUM_ERINNERUNG',$dokument['datum_erinnerung']);
|
|
$this->app->Tpl->Add('UHRZEIT_ERINNERUNG',$dokument['zeit_erinnerung']);
|
|
if($dokument['abgeschlossen'])$this->app->Tpl->Add('ABGESCHLOSSEN',' checked="checked" ');
|
|
if($dokument['prio'])$this->app->Tpl->Add('PRIO',' checked="checked" ');
|
|
|
|
$this->app->Tpl->Set('STAGES',$this->app->DB->Select("SELECT CONCAT(id,' ',kurzbezeichnung,' (',name,')') FROM wiedervorlage_stages WHERE id='".$dokument['stages']."' LIMIT 1"));
|
|
$this->app->Tpl->Add('BETRAG',number_format($dokument['betrag'],2,",","."));
|
|
for($i=0;$i<=100;$i += 10)
|
|
{
|
|
$this->app->Tpl->Add("CHANCE","<option value=\"$i\" ".($dokument['chance']==$i?"selected":"").">$i %</option>");
|
|
}
|
|
|
|
$this->app->Tpl->Add('PROJEKT',$this->app->DB->Select("SELECT CONCAT(abkuerzung,' ',name) FROM projekt WHERE id='".$dokument['projekt']."' LIMIT 1"));
|
|
$this->app->Tpl->Add('ANSPRECHPARTNER',$dokument['ansprechpartner']);
|
|
|
|
}else {
|
|
switch($dokument['typ']) {
|
|
case 'brief':
|
|
if($this->app->erp->Firmendaten("briefhtml")=="1")
|
|
{
|
|
$this->app->YUI->CkEditor("content","belege", null, 'JQUERY2');
|
|
}
|
|
$this->app->YUI->DateiPopup('DATEIENBUTTON', 'dokumente', $dokument['id']);
|
|
$template = 'adresse_brief_brief.tpl';
|
|
break;
|
|
case 'email':
|
|
|
|
|
|
$anhaenge = '';
|
|
$anhaenge .= '<tr><td nowrap>Datei:</td><td colspan="2"><input type="file" name="upload[]" id="file"/></td></tr>';
|
|
// $anhaenge .= '<tr><td nowrap>Datei 2:</td><td colspan="2"><input type="file" name="upload[]" /></td></tr>';
|
|
// $anhaenge .= '<tr><td nowrap>Datei 3:</td><td colspan="2"><input type="file" name="upload[]" /></td></tr>';
|
|
|
|
$this->app->Tpl->Add('ANHAENGEHERAUFLADEN', $anhaenge);
|
|
$anhaenge = "";
|
|
|
|
$anhaengedb = $this->app->DB->SelectArr("SELECT ds.id, ds.datei, d.titel FROM datei_stichwoerter ds INNER JOIN datei d on ds.datei = d.id WHERE ds.parameter = '$id' AND ds.objekt = 'dokument' AND ds.subjekt = 'anhang' and d.geloescht <> 1");
|
|
if($anhaengedb)
|
|
{
|
|
foreach($anhaengedb as $anhang)
|
|
{
|
|
$anhaenge .= '<tr id="trdatei_'.$anhang['datei'].'"><td><input type="checkbox" name="datei_'.$anhang['datei'].'" value="1" checked/></td><td><a style="font-weight:normal" href="index.php?module=adresse&action=downloaddatei&id='.$anhang['datei'].'">'.$anhang['titel'].'</a></td><td width=20><img src="./themes/' . $this->app->Conf->WFconf['defaulttheme'] . '/images/delete.svg" onclick="remdatei('.$anhang['datei'].');" style="border:0;" /></td></tr>';
|
|
}
|
|
} else {
|
|
$anhaenge .= '<tr><td colspan=3 align=center><i>Keine Anhänge vorhanden</i></td></tr>';
|
|
}
|
|
|
|
$this->app->Tpl->Add('ANHAENGE', $anhaenge);
|
|
|
|
if($this->app->erp->Firmendaten("briefhtml")=="1")
|
|
{
|
|
$this->app->YUI->CkEditor("content","internal", null, 'JQUERY2');
|
|
}
|
|
$this->app->YUI->DateiPopup('DATEIENBUTTON', 'dokumente', $dokument['id']);
|
|
$template = 'adresse_brief_email.tpl';
|
|
break;
|
|
case 'telefon':
|
|
if($this->app->erp->Firmendaten("briefhtml")=="1")
|
|
{
|
|
$this->app->YUI->CkEditor("content","internal", null, 'JQUERY2');
|
|
}
|
|
$this->app->YUI->DateiPopup('DATEIENBUTTON', 'dokumente', $dokument['id']);
|
|
$template = 'adresse_brief_telefon.tpl';
|
|
break;
|
|
case 'notiz':
|
|
if($this->app->erp->Firmendaten("briefhtml")=="1")
|
|
{
|
|
$this->app->YUI->CkEditor("content","internal", null, 'JQUERY2');
|
|
}
|
|
$this->app->YUI->DateiPopup('DATEIENBUTTON', 'dokumente', $dokument['id']);
|
|
$template = 'adresse_brief_notiz.tpl';
|
|
break;
|
|
default:
|
|
if($this->app->erp->Firmendaten("briefhtml")=="1")
|
|
{
|
|
$this->app->YUI->CkEditor("content","internal", null, 'JQUERY2');
|
|
}
|
|
$template = 'adresse_brief_brief.tpl';
|
|
break;
|
|
}
|
|
$this->app->Tpl->Add('EMAIL_SENDER', $this->app->erp->GetSelectEmailMitName($dokument['von']));
|
|
$this->app->Tpl->Add('EMPFAENGER',$dokument['an']);
|
|
$this->app->Tpl->Add('SENDER',$dokument['von']);
|
|
$this->app->Tpl->Add('ANSPRECHPARTNER',$dokument['ansprechpartner']);
|
|
$this->app->Tpl->Add('DATUM',$dokument['datum']);
|
|
$this->app->Tpl->Add('STRASSE',$dokument['adresse']);
|
|
$this->app->Tpl->Add('PLZ',$dokument['plz']);
|
|
$this->app->Tpl->Add('ORT',$dokument['ort']);
|
|
|
|
$this->app->Tpl->Add('BEARBEITER',$dokument['bearbeiter']);
|
|
$this->app->Tpl->Add('UHRZEIT',$dokument['uhrzeit']);
|
|
|
|
// $this->app->Tpl->Add(LAND,$dokument['land']);
|
|
|
|
$laender = $this->app->erp->GetSelectLaenderliste();
|
|
$laenderStr = '';
|
|
foreach ($laender as $landKey => $land) {
|
|
$laenderStr .= '<option '.($dokument['land'] == $landKey?' selected="selected" ':'').' value="' . $landKey . '">' . $land . '</option>';
|
|
}
|
|
|
|
$this->app->Tpl->Add('LAND',$laenderStr);
|
|
|
|
$this->app->Tpl->Add('BETREFF',$dokument['betreff']);
|
|
$this->app->Tpl->Add('INTERNEBEZEICHNUNG',$dokument['internebezeichnung']);
|
|
$this->app->Tpl->Add('CONTENT',$dokument['content']);
|
|
|
|
$this->app->Tpl->Add('PROJEKT',$dokument['projekt']);
|
|
|
|
$this->app->Tpl->Add('EMAIL_AN',$dokument['email_an']);
|
|
$this->app->Tpl->Add('EMAIL_CC',$dokument['email_cc']);
|
|
$this->app->Tpl->Add('EMAIL_BCC',$dokument['email_bcc']);
|
|
}
|
|
|
|
|
|
|
|
$this->app->Tpl->Add('EINTRAGID',$dokument['id']);
|
|
|
|
$this->app->Tpl->Add('DRUCKERSELECT', $this->DruckerSelect());
|
|
|
|
$this->app->Tpl->Output($template);
|
|
|
|
$this->app->ExitXentral();
|
|
|
|
}
|
|
|
|
function AdresseKorrBriefPdf() {
|
|
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$this->AdresseBriefCreatePDF($id, true);
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
function AdresseKorrBriefDelete() {
|
|
|
|
$typ = $this->app->Secure->GetGET('typ');
|
|
$id = $this->app->Secure->GetGET('id');
|
|
if(strtolower($typ) === 'kalender')
|
|
{
|
|
$this->app->DB->Delete("DELETE FROM kalender_user where event = '$id'");
|
|
$this->app->DB->Delete('
|
|
DELETE FROM
|
|
kalender_event
|
|
WHERE
|
|
id = "' . $id . '"
|
|
');
|
|
}elseif(strtolower($typ) === 'wiedervorlage')
|
|
{
|
|
$this->app->DB->Delete('
|
|
DELETE FROM
|
|
wiedervorlage
|
|
WHERE
|
|
id = ' . $id . '
|
|
');
|
|
|
|
|
|
}else{
|
|
$this->app->DB->Delete('
|
|
DELETE FROM
|
|
dokumente
|
|
WHERE
|
|
id = ' . $id . '
|
|
');
|
|
|
|
|
|
}
|
|
|
|
$json['status'] = 0;
|
|
$json['statusText'] = 'Email konnte nicht gesendet werden.';
|
|
echo json_encode($json);
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
|
|
function AdresseBriefSaveKalender()
|
|
{
|
|
$data = array();
|
|
$data['id'] = $this->app->Secure->GetPOST('eintragId');
|
|
$data['adresse'] = $this->app->Secure->GetGET('id');
|
|
$data['adresseintern'] = $this->app->Secure->GetPOST('adresseintern');
|
|
$data['bezeichnung'] = $this->app->Secure->GetPOST('betreff');
|
|
$data['beschreibung'] = $this->app->Secure->GetPOST('content');
|
|
|
|
$data['projekt'] = $this->app->Secure->GetPOST("projekt");
|
|
$data['projekt'] = explode(' ',$data['projekt']);
|
|
$data['projekt'] = $this->app->DB->Select("SELECT id FROM projekt WHERE abkuerzung='".$data['projekt'][0]."' AND abkuerzung!='' LIMIT 1");
|
|
|
|
$data['angelegtvon'] = (int)$this->app->DB->Select("SELECT id from adresse where mitarbeiternummer = '" .(int)$this->app->Secure->GetPOST('angelegtvon')."'");
|
|
|
|
$tmp = trim($data['adresseintern']);
|
|
$rest = explode(" ",$tmp);
|
|
$data['adresseintern'] = $rest[0];
|
|
|
|
|
|
$data['von'] = $this->app->String->Convert($_POST['datum'],"%1.%2.%3","%3-%2-%1");
|
|
$uhrzeit = $_POST['uhrzeit']?$_POST['uhrzeit']:'0:00';
|
|
if(!$uhrzeit)$uhrzeit = '0:00';
|
|
$data['von'] = $data['von'].' '.$uhrzeit;
|
|
$data['bis'] = $this->app->String->Convert($_POST['datumbis'],"%1.%2.%3","%3-%2-%1");
|
|
$uhrzeitbis = $_POST['uhrzeitbis']?$_POST['uhrzeitbis']:'0:00';
|
|
if(!$uhrzeitbis)$uhrzeitbis = '0:00';
|
|
$data['bis'] = $data['bis'].' '.$uhrzeitbis;
|
|
|
|
$data['allDay'] = $this->app->Secure->GetPOST("allDay")?1:0;
|
|
$data['public'] = $this->app->Secure->GetPOST("public")?1:0;
|
|
|
|
$data['ansprechpartner_id'] = $this->app->Secure->GetPOST("ansprechpartner");
|
|
if($data['ansprechpartner_id'] != ""){
|
|
$ansprechpartner = explode(" ", $data['ansprechpartner_id']);
|
|
$ansprechpartnerId = $ansprechpartner[0];
|
|
$ansprechpartnerId = $this->app->DB->Select("SELECT id FROM ansprechpartner WHERE id = '$ansprechpartnerId' LIMIT 1");
|
|
if($ansprechpartnerId === '' || $ansprechpartnerId <= 0){
|
|
$ansprechpartnerId = 0;
|
|
}
|
|
}else{
|
|
$ansprechpartnerId = 0;
|
|
}
|
|
$data['ansprechpartner_id'] = $ansprechpartnerId;
|
|
|
|
|
|
if($data['von'] && $data['bezeichnung'])
|
|
{
|
|
|
|
$id = 0;
|
|
if($data['id'])
|
|
{
|
|
$id = $this->app->DB->Select("SELECT id from kalender_event where id = ".(int)$data['id']." Limit 1");
|
|
}
|
|
if($id)
|
|
{
|
|
$sql = 'UPDATE kalender_event set ';
|
|
$first = true;
|
|
foreach($data as $k => $v)
|
|
{
|
|
if($k != 'id')
|
|
{
|
|
if(!$first)$sql .= ', ';
|
|
$first = false;
|
|
$sql .= $k." = '".$v."'";
|
|
|
|
}
|
|
|
|
}
|
|
$sql .= " where id = ".$id;
|
|
|
|
if($this->app->DB->Update($sql)){
|
|
$calendarActionType = 'modified';
|
|
$this->app->erp->RunHook('kalender_event_hook', 2, $id, $calendarActionType);
|
|
return $id;
|
|
};
|
|
return false;
|
|
} else {
|
|
|
|
$sql = "INSERT INTO kalender_event (";
|
|
$first = true;
|
|
foreach($data as $k => $v)
|
|
{
|
|
if($k != 'id')
|
|
{
|
|
if(!$first)$sql .= ', ';
|
|
$first = false;
|
|
$sql .= $k;
|
|
}
|
|
}
|
|
$sql .= ") values (";
|
|
$first = true;
|
|
foreach($data as $k => $v)
|
|
{
|
|
if($k != 'id')
|
|
{
|
|
if(!$first)$sql .= ', ';
|
|
$first = false;
|
|
$sql .= "'".$v."'";
|
|
}
|
|
}
|
|
$sql .= ")";
|
|
|
|
if($this->app->DB->Insert($sql)){
|
|
$result = $this->app->DB->GetInsertID();
|
|
|
|
$calendarActionType = 'added';
|
|
$this->app->erp->RunHook('kalender_event_hook', 2, $result, $calendarActionType);
|
|
|
|
$this->app->DB->Insert("INSERT INTO kalender_user (id,event,userid) VALUES ('','$result','".$this->app->User->GetID()."')");
|
|
return $result;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
|
|
|
|
} else {
|
|
|
|
}
|
|
return false;
|
|
}
|
|
|
|
|
|
function AdresseBriefSaveWiedervorlage()
|
|
{
|
|
$data = array();
|
|
$data['id'] = $this->app->Secure->GetPOST('eintragId');
|
|
$data['adresse'] = $this->app->Secure->GetGET('id');
|
|
$bearbeiterdaten = explode(" ",$this->app->Secure->GetPOST('bearbeiter'));
|
|
$data['bearbeiter'] = (int)$this->app->DB->Select("SELECT id from adresse where mitarbeiternummer = '".$bearbeiterdaten[0]."'");
|
|
$mitarbeiterdaten = explode(" ",$this->app->Secure->GetPOST('adresse_mitarbeiter'));
|
|
$data['adresse_mitarbeiter'] = (int)$this->app->DB->Select("SELECT id from adresse where mitarbeiternummer = '".$mitarbeiterdaten[0]."'");
|
|
$data['bezeichnung'] = $this->app->Secure->GetPOST('betreff');
|
|
$data['beschreibung'] = $this->app->Secure->GetPOST('content');
|
|
$data['stages'] = $this->app->Secure->GetPOST('stages');
|
|
$data['betrag'] = $this->app->Secure->GetPOST('betrag');
|
|
$data['chance'] = $this->app->Secure->GetPOST('chance');
|
|
|
|
|
|
$data['datum_erinnerung'] = $_POST['datumerinnerung'];
|
|
$data['zeit_erinnerung'] = $_POST['uhrzeiterinnerung']?$_POST['uhrzeiterinnerung']:'0:00';
|
|
if(!$data['datum_erinnerung'])$data['datum_erinnerung'] = '0:00';
|
|
$data['module'] = $this->app->Secure->GetGET("module");
|
|
$data['action'] = $this->app->Secure->GetGET("action");
|
|
$data['abgeschlossen'] = (int)$this->app->Secure->GetPOST("abgeschlossen");
|
|
$data['prio'] = (int)$this->app->Secure->GetPOST("prio");
|
|
$data['projekt'] = $this->app->Secure->GetPOST("projekt");
|
|
if (!empty($data['projekt'])) {
|
|
$data['projekt'] = explode(' ',$data['projekt']);
|
|
$data['projekt'] = (int)$this->app->DB->Select("SELECT id FROM projekt WHERE abkuerzung='".$data['projekt'][0]."' AND abkuerzung!='' LIMIT 1");
|
|
} else {
|
|
// Kein Projekt gewählt
|
|
$projekt = (int)$this->app->DB->Select("SELECT f.standardprojekt FROM `firma` AS f WHERE f.id='".$this->app->User->GetFirma()."' LIMIT 1");
|
|
$projekt_bevorzugt = (int)$this->app->DB->Select("SELECT u.projekt_bevorzugen FROM `user` AS u WHERE u.id='".$this->app->User->GetID()."' LIMIT 1");
|
|
if($projekt_bevorzugt === 1){
|
|
$projekt = (int)$this->app->DB->Select("SELECT projekt FROM user WHERE id='".$this->app->User->GetID()."' LIMIT 1");
|
|
}
|
|
$data['projekt'] = $projekt;
|
|
}
|
|
|
|
$data['stages'] = explode(' ',$data['stages']);
|
|
$data['stages'] = $data['stages'][0];
|
|
$data['betrag'] = str_replace(',','.',$data['betrag']);
|
|
|
|
$data['ansprechpartner_id'] = $this->app->Secure->GetPOST("ansprechpartner");
|
|
if($data['ansprechpartner_id'] != ""){
|
|
$ansprechpartner = explode(" ", $data['ansprechpartner_id']);
|
|
$ansprechpartnerId = $ansprechpartner[0];
|
|
$ansprechpartnerId = $this->app->DB->Select("SELECT id FROM ansprechpartner WHERE id = '$ansprechpartnerId' LIMIT 1");
|
|
if($ansprechpartnerId === '' || $ansprechpartnerId <= 0){
|
|
$ansprechpartnerId = 0;
|
|
}
|
|
}else{
|
|
$ansprechpartnerId = 0;
|
|
}
|
|
$data['ansprechpartner_id'] = $ansprechpartnerId;
|
|
|
|
$data['datum_erinnerung'] = $this->app->String->Convert($data['datum_erinnerung'],"%1.%2.%3","%3-%2-%1");
|
|
if($data['datum_erinnerung'] && $data['zeit_erinnerung'] && $data['bezeichnung'])
|
|
{
|
|
|
|
$id = 0;
|
|
if($data['id'])
|
|
{
|
|
$id = $this->app->DB->Select("SELECT id from wiedervorlage where id = ".(int)$data['id']." Limit 1");
|
|
}
|
|
if($id)
|
|
{
|
|
$sql = 'UPDATE wiedervorlage set ';
|
|
$first = true;
|
|
foreach($data as $k => $v)
|
|
{
|
|
if($k != 'id')
|
|
{
|
|
if(!$first)$sql .= ', ';
|
|
$first = false;
|
|
$sql .= $k." = '".$v."'";
|
|
|
|
}
|
|
|
|
}
|
|
$sql .= " where id = ".$id;
|
|
|
|
if($this->app->DB->Update($sql))return $id;
|
|
return false;
|
|
} else {
|
|
|
|
$data['datum_angelegt'] = $this->app->Secure->GetPOST('datum');
|
|
$data['zeit_angelegt'] = $this->app->Secure->GetPOST('uhrzeit');
|
|
$data['datum_angelegt'] = $this->app->String->Convert($data['datum_angelegt'],"%1.%2.%3","%3-%2-%1");
|
|
|
|
$sql = "INSERT INTO wiedervorlage (";
|
|
$first = true;
|
|
foreach($data as $k => $v)
|
|
{
|
|
if($k != 'id')
|
|
{
|
|
if(!$first)$sql .= ', ';
|
|
$first = false;
|
|
$sql .= $k;
|
|
}
|
|
}
|
|
$sql .= ") values (";
|
|
$first = true;
|
|
foreach($data as $k => $v)
|
|
{
|
|
if($k != 'id')
|
|
{
|
|
if(!$first)$sql .= ', ';
|
|
$first = false;
|
|
$sql .= "'".$v."'";
|
|
}
|
|
}
|
|
$sql .= ")";
|
|
|
|
if($this->app->DB->Insert($sql))return $this->app->DB->GetInsertID();
|
|
return false;
|
|
}
|
|
|
|
|
|
|
|
} else {
|
|
|
|
}
|
|
return false;
|
|
|
|
}
|
|
|
|
function AdresseBrief() {
|
|
if($this->app->Secure->GetGET('cmd') == 'layoutoeffnen')
|
|
{
|
|
$layout = $this->app->Secure->GetGET('layout');
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$query = '
|
|
SELECT
|
|
ke.id,
|
|
DATE_FORMAT(ke.von, "%d.%m.%Y") as datum,
|
|
DATE_FORMAT(ke.bis, "%d.%m.%Y") as datumbis,
|
|
DATE_FORMAT(ke.von, "%H:%i") as uhrzeit,
|
|
DATE_FORMAT(ke.bis, "%H:%i") as uhrzeitbis,
|
|
ke.allDay,
|
|
ke.public,
|
|
ke.adresse,
|
|
ke.angelegtvon,
|
|
ke.adresseintern,
|
|
ke.bezeichnung,
|
|
ke.beschreibung,
|
|
a.telefon as telefonmitarbeiter,
|
|
a.name as vertriebmitarbeiter,
|
|
a.email as emailmitarbeiter,
|
|
a2.name as bearbeiter
|
|
FROM
|
|
kalender_event ke
|
|
LEFT JOIN adresse a ON a.id=ke.adresseintern
|
|
LEFT JOIN adresse a2 ON a2.id=ke.angelegtvon
|
|
WHERE
|
|
ke.id = ' . $id . '
|
|
';
|
|
$kalenderevent = $this->app->DB->SelectRow($query);
|
|
|
|
$data = array();
|
|
|
|
if($kalenderevent)
|
|
{
|
|
foreach($kalenderevent as $key => $value)
|
|
{
|
|
$data[strtoupper($key)] = $value;
|
|
}
|
|
}
|
|
$adressen = $this->app->DB->SelectRow("SELECT * FROM adresse WHERE id = '".$kalenderevent['adresse']."'");
|
|
if($adressen)
|
|
{
|
|
foreach($adressen as $key => $value)
|
|
{
|
|
$data['ADRESSE_'.strtoupper($key)] = $value;
|
|
}
|
|
}
|
|
if(class_exists('LayoutvorlagenPDF'))
|
|
{
|
|
$pdf = new LayoutvorlagenPDF($this->app);
|
|
$pdf->SetLanguage('deutsch');
|
|
$layout = $this->app->DB->SelectRow('SELECT * FROM layoutvorlagen WHERE id = ' . $layout);
|
|
|
|
$layoutpositionen = $this->app->DB->SelectArr('SELECT * FROM layoutvorlagen_positionen WHERE layoutvorlage = ' . $layout['id']);
|
|
if($pdf->GetLayoutvorlage($layout['id'],$data)) {
|
|
$pdf->filename = 'Besuchsbericht'.($adressen['kundennummer']?'_'.$adressen['kundennummer']:'').'.pdf';
|
|
$pdf->displayDocument($name);
|
|
}
|
|
}
|
|
$this->app->ExitXentral();
|
|
}
|
|
$this->app->YUI->AutoComplete("ansprechpartner","ansprechpartner","","&adresse=$id");
|
|
$this->app->YUI->AutoComplete("projekt","projektname",1);
|
|
$this->app->YUI->TagEditor('internebezeichnung', array('width'=>370));
|
|
|
|
$pType = $this->app->Secure->GetPOST('type');
|
|
$do = $this->app->Secure->GetPOST('do');
|
|
|
|
$json = array();
|
|
|
|
$json['status'] = 0;
|
|
$json['statusText'] = '';
|
|
|
|
if (isset($pType) && !empty($pType)) {
|
|
|
|
$newId = 0;
|
|
if($pType !== 'wiedervorlage' && $pType !== 'kalender')
|
|
{
|
|
$newId = $this->AdresseBriefSaveDocument();
|
|
} else {
|
|
if($pType === 'kalender')
|
|
{
|
|
$newId = $this->AdresseBriefSaveKalender();
|
|
}else{
|
|
$newId = $this->AdresseBriefSaveWiedervorlage();
|
|
}
|
|
}
|
|
|
|
if ($newId > 0) {
|
|
$json['status'] = 1;
|
|
$json['statusText'] = 'Das Dokument wurde gespeichert.';
|
|
$json['statusId'] = $newId;
|
|
if ($pType === 'notiz') {
|
|
$this->app->erp->RunHook('address_note_created', 1, $newId);
|
|
}
|
|
}
|
|
|
|
if($pType !== 'email' || !$this->app->Secure->GetPOST('save'))
|
|
{
|
|
if (isset($do) && !empty($do)) {
|
|
|
|
switch ($do) {
|
|
case 'PDF':
|
|
|
|
$json['id'] = $newId;
|
|
$json['responseType'] = 'PDF';
|
|
$json['statusText'] = 'PDF wurde erstellt.';
|
|
|
|
$this->app->DB->Update('
|
|
UPDATE
|
|
dokumente
|
|
SET
|
|
sent = 1
|
|
WHERE
|
|
id ='.$newId.'
|
|
');
|
|
|
|
|
|
break;
|
|
case 'DRUCKEN':
|
|
$drucker = $this->app->Secure->GetPOST('drucker');
|
|
|
|
$this->app->erp->BriefpapierHintergrundDisable($drucker);
|
|
|
|
$tmpBrief = $this->AdresseBriefCreatePDF($newId, false);
|
|
$this->app->printer->Drucken($drucker, $tmpBrief);
|
|
|
|
$this->app->DB->Update('
|
|
UPDATE
|
|
dokumente
|
|
SET
|
|
sent = 1
|
|
WHERE
|
|
id ='.$newId.'
|
|
');
|
|
|
|
|
|
unlink($tmpBrief);
|
|
$json['statusText'] = 'Dokument wird gedruckt.';
|
|
$json['responseType'] = 'TEXT';
|
|
|
|
break;
|
|
case 'EMAIL':
|
|
|
|
$data = $this->app->DB->SelectRow('
|
|
SELECT
|
|
*
|
|
FROM
|
|
dokumente
|
|
WHERE
|
|
id = ' . $newId . '
|
|
');
|
|
|
|
// TODO MK korrekte cc und bcc holen
|
|
$cc = $this->app->erp->get_emails($data['email_cc']);
|
|
$bcc = $this->app->erp->get_emails($data['email_bcc']);
|
|
|
|
//TODO MK email_an und to richtig extrahieren
|
|
//$email_string = 'Benedikt Sauter <sauter@embedded-projects.net>';
|
|
$tmp_an = trim($data['email_an']);
|
|
list($data['to'], $data['email_an']) = explode(' <', trim($data['email_an'], '> '));
|
|
list($data['von'], $data['email']) = explode(' <', trim($data['von'], '> '));
|
|
|
|
if($data['email_an']=="") {
|
|
$data['email_an'] = $tmp_an;
|
|
$data['to'] = $tmp_an;
|
|
}
|
|
|
|
//$this->app->erp->LogFile("BCC $bcc CC $cc");
|
|
|
|
$dateien = array();
|
|
foreach($_POST as $pk => $pv)
|
|
{
|
|
$pka = explode('_',$pk);
|
|
if($pka[0] === 'datei' && isset($pka[1]) && $pka[1] && is_numeric($pka[1]))
|
|
{
|
|
$dateiname = $this->app->erp->GetDateiName($pka[1]);
|
|
if($dateiname)
|
|
{
|
|
$dateiinhalt = $this->app->erp->GetDatei($pka[1]);
|
|
|
|
if($handle = fopen ($this->app->erp->GetTMP().$dateiname, "wb"))
|
|
{
|
|
fwrite($handle, $dateiinhalt);
|
|
fclose($handle);
|
|
$dateien[] = $this->app->erp->GetTMP().$dateiname;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if(strpos($data['betreff'],'{') !== false) {
|
|
$data['betreff'] = $this->app->erp->ParseUserVars('adresse', $data['adresse_to'], $data['betreff']);
|
|
}
|
|
if(strpos($data['content'],'{') !== false) {
|
|
$data['content'] = $this->app->erp->ParseUserVars('adresse', $data['adresse_to'], $data['content']);
|
|
}
|
|
|
|
$mailSend = $this->app->erp->MailSend(
|
|
$data['email'],
|
|
$data['von'],
|
|
$data['email_an'],
|
|
$data['to'],
|
|
$data['betreff'],
|
|
$data['content'],
|
|
$dateien,
|
|
$projekt,true,$cc,$bcc
|
|
);
|
|
|
|
if($dateien && is_array($dateien))
|
|
{
|
|
foreach($dateien as $datei)unlink($datei);
|
|
}
|
|
|
|
if($mailSend =='1') {
|
|
$json['status'] = 1;
|
|
$json['type'] = 'email';
|
|
$json['statusText'] = 'Email wurde gesendet.';
|
|
$this->app->DB->Update('
|
|
UPDATE
|
|
dokumente
|
|
SET
|
|
sent = 1,
|
|
send_as = "email"
|
|
WHERE
|
|
id = ' . $data['id'] . '
|
|
');
|
|
} else {
|
|
$json['status'] = 0;
|
|
$json['statusText'] = 'Email konnte nicht gesendet werden. ('.$this->app->erp->mail_error.')';
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
}
|
|
|
|
echo json_encode($json);
|
|
$this->app->ExitXentral();
|
|
}
|
|
}
|
|
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
$this->AdresseMenu();
|
|
|
|
|
|
$this->app->User->SetParameter('adresse_brief_adresseId', $id);
|
|
|
|
$count = 0;
|
|
$count += $this->app->DB->Select('SELECT count(id) FROM dokumente WHERE adresse_to = ' . $id);
|
|
$count += $this->app->DB->Select('SELECT count(id) FROM dokumente_send WHERE adresse = ' . $id);
|
|
$count += $this->app->DB->Select('SELECT count(id) FROM wiedervorlage WHERE adresse = ' . $id);
|
|
$count += $this->app->DB->Select('SELECT count(id) FROM kalender_event WHERE adresse = '.$id);
|
|
$count += $this->app->DB->Select('SELECT count(tn.id) FROM ticket_nachricht tn INNER JOIN ticket t ON tn.ticket = t.schluessel WHERE t.adresse = '.$id);
|
|
|
|
if ($count > 0) {
|
|
$this->app->YUI->TableSearch('TABELLE', 'adresse_brief');
|
|
$this->app->Tpl->Set('TABELLEFLAG', 0);
|
|
} else {
|
|
$this->app->Tpl->Set('TABELLE', '<br><div class="info">Es sind noch keine Einträge vorhanden.</div>');
|
|
$this->app->Tpl->Set('TABELLEFLAG', 1);
|
|
}
|
|
|
|
if(!$this->app->erp->RechteVorhanden('wiedervorlage','list'))
|
|
{
|
|
$this->app->Tpl->Set('VORWIEDERVORLAGE','<!-- ');
|
|
$this->app->Tpl->Set('NACHWIEDERVORLAGE',' -->');
|
|
}
|
|
/*
|
|
if(!$this->app->erp->RechteVorhanden('ticket','offene'))
|
|
{
|
|
$this->app->Tpl->Set('VORTICKETS','<!-- ');
|
|
$this->app->Tpl->Set('NACHTICKETS',' -->');
|
|
}
|
|
*/
|
|
|
|
|
|
$cmd = $this->app->Secure->GetPOST('cmd');
|
|
if($cmd=="crm")
|
|
$this->app->Tpl->Parse('CRMTABELLE',"adresse_crm_tabelle.tpl");
|
|
|
|
|
|
$this->app->Tpl->Parse('TAB1',"adresse_brief.tpl");
|
|
$this->app->Tpl->Parse('PAGE',"tabview.tpl");
|
|
$befehl = $this->app->User->GetParameter('adresse_brief_befehl');
|
|
if($befehl)
|
|
{
|
|
$this->app->User->SetParameter('adresse_brief_befehl','');
|
|
$this->app->Tpl->Add('PAGE','
|
|
<script type="text/JavaScript" language="javascript">
|
|
$(document).ready(function() {
|
|
'.$befehl.'
|
|
});
|
|
</script>
|
|
');
|
|
}
|
|
|
|
// Wenn GET-Parameter "telefon_notiz_erstellen" gesetzt ist, direkt Anlegen-Dialog öffnen
|
|
$telefonNotizErstellen = (int)$this->app->Secure->GetGET('telefon_notiz_erstellen');
|
|
if ($telefonNotizErstellen === 1) {
|
|
$this->app->Tpl->Add('PAGE','
|
|
<script type="text/javascript">
|
|
$(document).ready(function() { briefAnlegen(\'telefon\'); });
|
|
</script>
|
|
');
|
|
}
|
|
}
|
|
|
|
|
|
|
|
function AdresseBriefEditPopup()
|
|
{
|
|
$frame = $this->app->Secure->GetGET("frame");
|
|
$id= $this->app->Secure->GetGET('id');
|
|
$sid= $this->app->Secure->GetPOST('sid');
|
|
|
|
if($frame=="false")
|
|
{
|
|
// hier nur fenster größe anpassen
|
|
$this->app->YUI->IframeDialog(800,650,"index.php?module=adresse&action=briefeditpopup&id=$id&sid=$sid");
|
|
} else {
|
|
|
|
$adresse = $id;
|
|
|
|
$typ = $this->app->DB->Select("SELECT dokument FROM dokumente_send WHERE id='$sid' LIMIT 1");
|
|
//$parameter = $this->app->DB->Select("SELECT parameter FROM dokumente_send WHERE id='$sid' LIMIT 1");
|
|
$parameter = $sid;
|
|
|
|
//echo "typ = $typ ".$parameter;
|
|
|
|
$this->app->erp->DokumentMask('PAGE',$typ,$parameter,$adresse,'',true);
|
|
|
|
$this->app->BuildNavigation=false;
|
|
}
|
|
}
|
|
|
|
|
|
function AdresseBriefDelete()
|
|
{
|
|
$sid = $this->app->Secure->GetPOST('sid');
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
$this->app->DB->Update("UPDATE dokumente_send SET geloescht=1 WHERE id='$sid' LIMIT 1");
|
|
|
|
$this->AdresseBrief();
|
|
}
|
|
|
|
function AdresseBriefPDF()
|
|
{
|
|
$sid = $this->app->Secure->GetGET('sid'); // 30.03.19 von POST zu GET BS
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
//$Brief = new Geschaeftsbrief(&$this->app,$sid);
|
|
$projekt = $this->app->DB->Select("SELECT projekt FROM dokumente WHERE id='$sid'");
|
|
$Brief = new BriefPDF($this->app,$projekt);
|
|
$Brief->GetBrief($sid);
|
|
$Brief->displayDocument();
|
|
|
|
$this->AdresseBrief();
|
|
}
|
|
|
|
|
|
function AdresseBelege()
|
|
{
|
|
$cmd = $this->app->Secure->GetPOST('cmd');
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$von = $this->app->User->GetParameter("adresse_belege_von");
|
|
$bis = $this->app->User->GetParameter("adresse_belege_bis");
|
|
|
|
if($cmd == 'kundensaldodatumsrelevant'){
|
|
$von = $this->app->Secure->GetGET("von");
|
|
$bis = $this->app->Secure->GetGET("bis");
|
|
}
|
|
|
|
if (!is_null($von) && !is_null($bis))
|
|
{
|
|
$von = date_format(date_create_from_format('d.m.Y', $von), 'Y-m-d');
|
|
$bis = date_format(date_create_from_format('d.m.Y', $bis), 'Y-m-d');
|
|
}
|
|
|
|
$rechnungt = $this->app->DB->Select("SELECT SUM(soll-ist) FROM rechnung WHERE status != 'angelegt' AND zahlungsstatus != 'bezahlt' AND adresse = '$id' AND datum >= '$von' AND datum <= '$bis'");
|
|
//$gutschriftt = $this->app->DB->Select("SELECT SUM(soll-ist) FROM gutschrift WHERE status != 'angelegt' AND (manuell_vorabbezahlt != '0000-00-00' OR manuell_vorabbezahlt IS NOT NULL) AND adresse = '$id' AND datum >= '$von' AND datum <= '$bis'");
|
|
$gutschriftt = $this->app->DB->Select("SELECT SUM(soll-ist) FROM gutschrift WHERE status != 'angelegt' AND (manuell_vorabbezahlt = '0000-00-00' OR manuell_vorabbezahlt IS NULL) AND zahlungsstatus != 'bezahlt' AND rechnungid = 0 AND adresse = '$adresse' AND datum >= '$von' AND datum <= '$bis'");
|
|
$verbindlichkeitt = $this->app->DB->Select("SELECT SUM(betrag-betragbezahlt) FROM verbindlichkeit WHERE status = 'offen' AND adresse = '$id' AND rechnungsdatum >= '$von' AND rechnungsdatum <= '$bis'");
|
|
$kundensaldot = $rechnungt - $gutschriftt - $verbindlichkeitt;
|
|
$kundensaldot = round($kundensaldot, 2);
|
|
|
|
if($kundensaldot > 0){
|
|
$kundensaldot = "<font color=red>-".number_format($kundensaldot,2,',','.')."</font>";
|
|
}else if($kundensaldot == 0){
|
|
$kundensaldot = "0,00";
|
|
}else{
|
|
$kundensaldot = number_format($kundensaldot,2,',','.');
|
|
}
|
|
if($cmd === 'kundensaldodatumsrelevant'){
|
|
echo json_encode($kundensaldot);
|
|
$this->app->ExitXentral();
|
|
}
|
|
$this->AdresseMenu();
|
|
|
|
$kreditlimit = $this->app->DB->Select("SELECT kreditlimit FROM adresse WHERE id='$id' LIMIT 1");
|
|
// $saldo = $this->app->erp->SaldoAdresse($id);
|
|
|
|
$kreditlimit_frei = $kreditlimit - $saldo;
|
|
|
|
if($kreditlimit <=0) {
|
|
$kreditlimit="kein Limit";
|
|
$kreditlimit_frei = "kein Limit";
|
|
} else $kreditlimit = number_format($kreditlimit,2,',','.');
|
|
|
|
$this->app->Tpl->Set('KREDITLIMIT',$kreditlimit);
|
|
$this->app->Tpl->Set('KREDITLIMITFREI',$kreditlimit_frei);
|
|
|
|
|
|
//$this->app->Tpl->Set('UMSATZ',number_format($this->app->erp->UmsatzAdresseAuftragJahr($id),2,',','.'));
|
|
$this->app->Tpl->Set('UMSATZ',number_format($this->app->erp->UmsatzAdresseRechnungJahr($id),2,',','.'));
|
|
|
|
/* $saldo = round($saldo,2);
|
|
|
|
if($saldo > 0)
|
|
$saldo = "<font color=red>-".number_format($saldo,2,',','.')."</font>";
|
|
else if ($saldo==0) $saldo="0,00";
|
|
else $saldo = number_format($saldo,2,',','.');
|
|
*/
|
|
// $this->app->Tpl->Set('SALDO',$saldo);
|
|
|
|
|
|
$kundensaldo = $this->app->erp->KundenSaldo($id);
|
|
|
|
if($kundensaldo > 0){
|
|
$kundensaldo = "<font color=red>-".number_format($kundensaldo,2,',','.')."</font>";
|
|
}else if($kundensaldo == 0){
|
|
$kundensaldo = "0,00";
|
|
}else{
|
|
$kundensaldo = number_format($kundensaldo,2,',','.');
|
|
}
|
|
|
|
$this->app->Tpl->Set('KUNDENSALDO', $kundensaldo);
|
|
$this->app->Tpl->Set('KUNDENSALDODATUMSRELEVANT', $kundensaldot);
|
|
|
|
if($this->app->erp->IsAdresseSubjekt($id,"Lieferant")){
|
|
$this->app->Tpl->Set('MITTEBESTELLUNG',
|
|
|
|
'<li class="filter-item">
|
|
<label for="bestellung" class="switch">
|
|
<input type="checkbox" value="1" id="bestellung" />
|
|
<span class="slider round"></span>
|
|
</label>
|
|
<label for="bestellung">{|Bestellung|}</label>
|
|
</li>
|
|
<li class="filter-item">
|
|
<label for="verbindlichkeit" class="switch">
|
|
<input type="checkbox" value="1" id="verbindlichkeit" />
|
|
<span class="slider round"></span>
|
|
</label>
|
|
<label for="verbindlichkeit">{|Verbindlichkeit|}</label>
|
|
</li>');
|
|
|
|
|
|
|
|
}
|
|
|
|
$this->app->Tpl->Set('ID',$id);
|
|
|
|
$this->app->YUI->DatePicker("von");
|
|
$this->app->YUI->DatePicker("bis");
|
|
|
|
$this->app->YUI->AutoSaveUserParameter("von","adresse_belege_von");
|
|
$this->app->YUI->AutoSaveUserParameter("bis","adresse_belege_bis");
|
|
|
|
$this->app->YUI->TableSearch('TAB1',"adressebelege");
|
|
//$this->app->YUI->TableSearch('TAB2',"adresse_auftrag");
|
|
//$this->app->YUI->TableSearch('TAB3',"adresse_rechnung");
|
|
//$this->app->YUI->TableSearch('TAB4',"adresse_gutschrift");
|
|
//$this->app->YUI->TableSearch('TAB5',"adresse_lieferschein");
|
|
|
|
$this->app->Tpl->Parse('PAGE',"adresse_belege.tpl");
|
|
}
|
|
|
|
|
|
|
|
function AdresseEmail()
|
|
{
|
|
$this->AdresseMenu();
|
|
|
|
|
|
// NEU füllen
|
|
$widget = new WidgetEmail($this->app,'TAB2');
|
|
$widget->Create();
|
|
|
|
// UEBERSICHT füllen
|
|
$this->app->Tpl->Set('HEADING',"Adresse");
|
|
$this->app->Tpl->Set('SUBHEADING',"Email schreiben");
|
|
$adresse = $this->app->User->GetAdresse();
|
|
|
|
//Offene Aufgaben
|
|
$table = new EasyTable($this->app);
|
|
$table->Query("SELECT betreff, id FROM email");
|
|
$table->DisplayNew('INHALT', "<a href=\"index.php?module=adresse&action=emaileditpopup&frame=false&id=%value%\"
|
|
onclick=\"makeRequest(this);return false\">Bearbeiten</a>");
|
|
$this->app->Tpl->Parse('TAB1',"rahmen.tpl");
|
|
|
|
// PARSE
|
|
$this->app->Tpl->Set('AKTIV_TAB1',"selected");
|
|
|
|
$this->app->Tpl->Parse('PAGE',"emailuebersicht.tpl");
|
|
|
|
}
|
|
|
|
|
|
|
|
function AdresseEmailEditPopup()
|
|
{
|
|
$frame = $this->app->Secure->GetGET("frame");
|
|
if($frame=="false")
|
|
{
|
|
// hier nur fenster größe anpassen
|
|
$this->app->YUI->IframeDialog(510,610);
|
|
} else {
|
|
// nach page inhalt des dialogs ausgeben
|
|
$widget = new WidgetEmail($this->app,'PAGE');
|
|
$widget->Edit();
|
|
$this->app->BuildNavigation=false;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
function AdresseSuchmaske()
|
|
{
|
|
$typ=$this->app->Secure->GetGET("typ");
|
|
|
|
$this->app->Tpl->Set('HEADING',"Suchmaske für Adressen");
|
|
$table = new EasyTable($this->app);
|
|
switch($typ) {
|
|
case "auftragrechnung":
|
|
$table->Query("SELECT typ,name, ort, plz, strasse, abteilung, unterabteilung, ustid, email, adresszusatz, id as kundeadressid, id FROM adresse WHERE geloescht=0
|
|
order by name");
|
|
break;
|
|
case "auftraglieferschein":
|
|
$table->Query("SELECT typ as liefertyp, name as liefername, ort as lieferort, plz as lieferplz, strasse as lieferstrasse, abteilung as lieferabteilung, unterabteilung
|
|
as lieferunterabteilung, adresszusatz as lieferadresszusatz, id as lieferadressid FROM adresse WHERE geloescht=0 order by name");
|
|
break;
|
|
default:
|
|
$table->Query("SELECT typ,name, ort, plz, strasse, abteilung, unterabteilung, ustid, email, adresszusatz, id as kundeadressid, id FROM adresse WHERE geloescht=0 order by name");
|
|
}
|
|
|
|
$table->DisplayWithDelivery('PAGE');
|
|
|
|
$this->app->BuildNavigation=false;
|
|
}
|
|
|
|
|
|
|
|
function AdresseKundevorlage()
|
|
{
|
|
$this->AdresseMenu();
|
|
$id = $this->app->Secure->GetGET('id');
|
|
// prufe ob es schon einen eintrag gibt
|
|
$check = $this->app->DB->Select("SELECT id FROM kundevorlage WHERE adresse='$id' LIMIT 1");
|
|
if( !($check > 0 && is_numeric($check)))
|
|
{
|
|
$this->app->DB->Insert("INSERT INTO kundevorlage (id,adresse) VALUES ('','$id')");
|
|
}
|
|
|
|
$check = $this->app->DB->Select("SELECT id FROM kundevorlage WHERE adresse='$id' LIMIT 1");
|
|
$this->app->Secure->GET['id']=$check;
|
|
$this->app->Tpl->Set('AKTIV_TAB1',"selected");
|
|
$widget = new WidgetKundevorlage($this->app,'PAGE');
|
|
$widget->Edit();
|
|
$this->app->Secure->GET['id']=$id;
|
|
}
|
|
|
|
function AdresseAddPosition()
|
|
{
|
|
$sid = $this->app->Secure->GetPOST('sid');
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$menge = $this->app->Secure->GetGET("menge");
|
|
$datum = $this->app->Secure->GetGET("datum");
|
|
$datum = $this->app->String->Convert($datum,"%1.%2.%3","%3-%2-%1");
|
|
$tmpid = $this->app->erp->AddAdressePosition($id, $sid,$menge,$datum);
|
|
|
|
$art = $this->app->Secure->GetGET("art");
|
|
|
|
if(!$this->app->erp->CheckDateValidate($datum)) $datum=date('Y-m-d');
|
|
|
|
if($art==='abo'){
|
|
$this->app->DB->Update("UPDATE abrechnungsartikel SET wiederholend=1,startdatum='$datum',zahlzyklus=1 WHERE id='$tmpid' LIMIT 1");
|
|
}
|
|
else if ($art==='einmalig'){
|
|
$this->app->DB->Update("UPDATE abrechnungsartikel SET wiederholend=0,preisart='einmalig' WHERE id='$tmpid' LIMIT 1");
|
|
}
|
|
|
|
$this->app->DB->Update("UPDATE abrechnungsartikel SET angelegtvon='".$this->app->User->GetID()."',angelegtam=NOW() WHERE id='$tmpid' LIMIT 1");
|
|
|
|
$this->app->Location->execute("index.php?module=adresse&action=artikel&id=$id");
|
|
}
|
|
|
|
function AdresseLieferantvorlage()
|
|
{
|
|
|
|
//zahlungsweise zahlungszieltage zahlungszieltageskonto zahlungszielskonto versandart
|
|
//zahlungsweiselieferant zahlungszieltagelieferant zahlungszieltageskontolieferant zahlungszielskontolieferant versandartlieferant
|
|
$arr = $this->app->DB->SelectArr("SELECT id,kundennummerlieferant FROM adresse WHERE lieferantennummer >0");
|
|
|
|
foreach($arr as $key=>$value)
|
|
{
|
|
if($value['kundennummerlieferant']=="")
|
|
{
|
|
$id = $value['id'];
|
|
$kundennummer = $this->app->DB->Select("SELECT kundennummer FROM lieferantvorlage WHERE adresse='$id' LIMIT 1");
|
|
$zahlungsweiselieferant = $this->app->DB->Select("SELECT zahlungsweise FROM lieferantvorlage WHERE adresse='$id' LIMIT 1");
|
|
$zahlungszieltagelieferant = $this->app->DB->Select("SELECT zahlungszieltage FROM lieferantvorlage WHERE adresse='$id' LIMIT 1");
|
|
$zahlungszieltageskontolieferant = $this->app->DB->Select("SELECT zahlungszielskonto FROM lieferantvorlage WHERE adresse='$id' LIMIT 1");
|
|
$versandartlieferant = $this->app->DB->Select("SELECT versandart FROM lieferantvorlage WHERE adresse='$id' LIMIT 1");
|
|
|
|
if($kundennummer !="")
|
|
{
|
|
echo "UPDATE adresse SET kundennummerlieferant='$kundennummer',zahlungsweiselieferant='$zahlungsweiselieferant',
|
|
zahlungszieltagelieferant='$zahlungszieltagelieferant',zahlungszieltageskontolieferant='$zahlungszieltageskontolieferant',
|
|
versandartlieferant='$versandartlieferant' WHERE id='$id';";
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
|
|
$this->AdresseMenu();
|
|
$id = $this->app->Secure->GetGET('id');
|
|
// prufe ob es schon einen eintrag gibt
|
|
$check = $this->app->DB->Select("SELECT id FROM lieferantvorlage WHERE adresse='$id' LIMIT 1");
|
|
if( !($check > 0 && is_numeric($check)))
|
|
{
|
|
$this->app->DB->Insert("INSERT INTO lieferantvorlage (id,adresse) VALUES ('','$id')");
|
|
}
|
|
|
|
$check = $this->app->DB->Select("SELECT id FROM lieferantvorlage WHERE adresse='$id' LIMIT 1");
|
|
$this->app->Secure->GET['id']=$check;
|
|
$this->app->Tpl->Set('AKTIV_TAB1',"selected");
|
|
$widget = new WidgetLieferantvorlage($this->app,'PAGE');
|
|
$widget->Edit();
|
|
$this->app->Secure->GET['id']=$id;
|
|
}
|
|
|
|
/**
|
|
* @param int $addressId
|
|
*
|
|
* @return float
|
|
*/
|
|
public function getAboMonthSum($addressId) {
|
|
if(empty($addressId)) {
|
|
return 0.00;
|
|
}
|
|
$sum = (float)$this->app->DB->Select(
|
|
sprintf(
|
|
"SELECT SUM(
|
|
abo.menge * abo.preis * (1 - rabatt / 100)
|
|
*
|
|
IF(
|
|
abo.preisart = 'jahr' OR abo.preisart = '360tage',
|
|
IF(abo.zahlzyklus <= 1, 1/12,1 / (abo.zahlzyklus * 12)),
|
|
IF(
|
|
abo.preisart = 'wochen',
|
|
IF(abo.zahlzyklus <= 1, 7 / 30, 1 / (abo.zahlzyklus * 30 / 7)) ,
|
|
IF(abo.preisart = 'einmalig',
|
|
0,
|
|
IF(abo.preisart = 'monat' OR abo.preisart = '30tage',
|
|
1,
|
|
IF(abo.zahlzyklus <= 1, 1, 1/ (abo.zahlzyklus))
|
|
)
|
|
)
|
|
)
|
|
)
|
|
)
|
|
FROM abrechnungsartikel AS abo
|
|
WHERE abo.adresse = %d
|
|
AND (abo.startdatum <= CURDATE() OR IFNULL(abo.startdatum,'0000-00-00') = '0000-00-00')
|
|
AND (abo.enddatum >= CURDATE() OR IFNULL(abo.enddatum,'0000-00-00') = '0000-00-00')",
|
|
$addressId
|
|
)
|
|
);
|
|
|
|
return $sum;
|
|
}
|
|
|
|
|
|
function AdresseArtikelPosition($withmenu = true)
|
|
{
|
|
if($withmenu) {
|
|
$this->AdresseMenu();
|
|
}
|
|
$id = $this->app->Secure->GetGET('id');
|
|
/* neu anlegen formular */
|
|
$artikelart = $this->app->Secure->GetPOST("artikelart");
|
|
$bezeichnung = $this->app->Secure->GetPOST("bezeichnung");
|
|
$beschreibung = $this->app->Secure->GetPOST("beschreibung");
|
|
$vpe = $this->app->Secure->GetPOST("vpe");
|
|
$umsatzsteuerklasse = $this->app->Secure->GetPOST("umsatzsteuerklasse");
|
|
$waehrung = $this->app->Secure->GetPOST("waehrung");
|
|
$projekt= $this->app->Secure->GetPOST("projekt");
|
|
$preis = $this->app->Secure->GetPOST("preis");
|
|
$preis = str_replace(',','.',$preis);
|
|
$menge = $this->app->Secure->GetPOST("menge");
|
|
$menge = str_replace(',','.',$menge);
|
|
$art = $this->app->Secure->GetPOST("art");
|
|
$lieferdatum = $this->app->Secure->GetPOST("lieferdatum");
|
|
$zahlzyklus = $this->app->Secure->GetPOST("zahlzyklus");
|
|
$wiederholend= $this->app->Secure->GetPOST("wiederholend");
|
|
$startdatum= $this->app->Secure->GetPOST("startdatum");
|
|
|
|
if($lieferdatum=="") $lieferdatum=date("d.m.Y");
|
|
|
|
$cmd= $this->app->Secure->GetGET('cmd');
|
|
|
|
switch($cmd)
|
|
{
|
|
|
|
case "getArtikelData":
|
|
$id= $this->app->Secure->GetPOST("artikel");
|
|
$adresse = $this->app->Secure->GetPOST("adresse");
|
|
$artikel = $this->app->DB->SelectArr("SELECT * FROM artikel WHERE nummer='$id' AND nummer!='' LIMIT 1");
|
|
$artikel[0]['nettopreis'] = $this->app->erp->GetVerkaufspreis($artikel[0]['id'],1,$adresse);
|
|
echo json_encode($artikel[0]);
|
|
$this->app->ExitXentral();
|
|
break;
|
|
|
|
case "getAboartikel":
|
|
$id= $this->app->Secure->GetPOST('id');
|
|
$adresse = $this->app->Secure->GetPOST("adresse");
|
|
$artikel = $this->app->DB->SelectArr("SELECT aba.*, a.nummer FROM abrechnungsartikel aba inner JOIN artikel a ON (a.id = aba.artikel) WHERE aba.id='$id' AND aba.adresse='$adresse' LIMIT 1");
|
|
$AboGruppen_tmp = $this->app->DB->SelectArr("SELECT id,beschreibung FROM abrechnungsartikel_gruppe where (adresse = '$adresse' OR adresse = 0) ORDER BY sort");
|
|
if(is_array($AboGruppen_tmp)) {
|
|
$AboGruppen = '<option>Bitte auswählen</option>';
|
|
}else{
|
|
$AboGruppen = '';
|
|
}
|
|
foreach($AboGruppen_tmp as $value){
|
|
if($value['id'] == $artikel[0]['gruppe']){
|
|
$selected = " selected=\"selected\"";
|
|
}else{
|
|
$selected='';
|
|
}
|
|
$AboGruppen .= '<option value="' . $value['id'] . '" '.$selected.'>' . $value['beschreibung'] . '</option>';
|
|
}
|
|
|
|
if(is_array($artikel[0])) {
|
|
$artikel[0]['startdatum'] = $this->app->String->Convert($artikel[0]['startdatum'], "%3-%2-%1", "%1.%2.%3");
|
|
$artikel[0]['lieferdatum'] = $this->app->String->Convert($artikel[0]['lieferdatum'], "%3-%2-%1", "%1.%2.%3");
|
|
$artikel[0]['abgerechnetbis'] = $this->app->String->Convert($artikel[0]['abgerechnetbis'], "%3-%2-%1", "%1.%2.%3");
|
|
$artikel[0]['abgrechnetam'] = $this->app->String->Convert($artikel[0]['abgrechnetam'], "%3-%2-%1", "%1.%2.%3");
|
|
$artikel[0]['enddatum'] = $this->app->String->Convert($artikel[0]['enddatum'], "%3-%2-%1", "%1.%2.%3");
|
|
$artikel[0]['gruppen'] = $AboGruppen;
|
|
echo json_encode($artikel[0]);
|
|
}else{
|
|
$basis['startdatum'] = date("d.m.Y");
|
|
$basis['lieferdatum'] = "00.00.0000";
|
|
$basis['abgerechnetbis'] = "00.00.0000";
|
|
$basis['abgrechnetam'] = "00.00.0000";
|
|
$basis['enddatum'] = "00.00.0000";
|
|
$basis['preisart'] = "monat";
|
|
$basis['preis'] = '0.00';
|
|
$basis['menge'] = '0.00';
|
|
$basis['status'] = "1";
|
|
$basis['dokument'] = "rechnung";
|
|
$basis['gruppen'] = $AboGruppen;
|
|
echo json_encode($basis);
|
|
}
|
|
$this->app->ExitXentral();
|
|
break;
|
|
|
|
|
|
case "moveAboArtikel":
|
|
$id= $this->app->Secure->GetPOST('id');
|
|
$direction = $this->app->Secure->GetPOST("direction");
|
|
// wir schauen erstmal ob der Eintrag in einer Gruppe ist, und holen dann alle Artikel dieser gruppe
|
|
$artikel_list = $this->app->DB->SelectArr("SELECT id FROM abrechnungsartikel where gruppe=(Select gruppe from abrechnungsartikel where id='$id') order by sort asc");
|
|
$counter=0;
|
|
foreach ($artikel_list as $value){
|
|
if($value['id'] == $id){
|
|
$moveItem = $counter;
|
|
}else{
|
|
$counter++;
|
|
}
|
|
$artikel[] = $value['id'];
|
|
}
|
|
|
|
if($direction === 'down'){
|
|
$neuArtikelSortierung = $this->down($artikel,$moveItem);
|
|
} else{
|
|
$neuArtikelSortierung = $this->up($artikel,$moveItem);
|
|
}
|
|
|
|
foreach ($neuArtikelSortierung as $key => $value){
|
|
//$neuePos=0;
|
|
$neuePos = $key+1;
|
|
$update = $this->app->DB->Update("UPDATE abrechnungsartikel set sort='$neuePos' where id='$value'");
|
|
}
|
|
echo json_encode(array(
|
|
'status' => 1
|
|
));
|
|
$this->app->ExitXentral();
|
|
break;
|
|
case "saveAboartikel":
|
|
$id= $this->app->Secure->GetPOST('id');
|
|
$adresse = $this->app->Secure->GetPOST("adresse");
|
|
$artikel = $this->app->Secure->GetPOST("artikel");
|
|
$artikelid = $this->app->Secure->GetPOST("artikelid");
|
|
$artikelueberschreiben = $this->app->Secure->GetPOST("artikelueberschreiben");
|
|
$artikelneuanlage = $this->app->Secure->GetPOST("artikelneuanlage");
|
|
$preisart= $this->app->Secure->GetPOST("preisart");
|
|
$rabatt= $this->app->Secure->GetPOST("rabatt");
|
|
$dokument= $this->app->Secure->GetPOST("dokument");
|
|
$gruppe= $this->app->Secure->GetPOST("gruppe");
|
|
$sort= $this->app->Secure->GetPOST("sort");
|
|
$startdatum= $this->app->String->Convert($this->app->Secure->GetPOST("startdatum"),"%1.%2.%3","%3-%2-%1");
|
|
$enddatum= $this->app->String->Convert($this->app->Secure->GetPOST("enddatum"),"%1.%2.%3","%3-%2-%1");
|
|
$abgerechnetbis= $this->app->String->Convert($this->app->Secure->GetPOST("abgerechnetbis"),"%1.%2.%3","%3-%2-%1");
|
|
$abgrechnetam= $this->app->String->Convert($this->app->Secure->GetPOST("abgrechnetam"),"%1.%2.%3","%3-%2-%1");
|
|
$bemerkung= $this->app->Secure->GetPOST("bemerkung");
|
|
$experte= $this->app->Secure->GetPOST("experte");
|
|
$bezeichnung= $this->app->Secure->GetPOST("bezeichnung");
|
|
$beschreibungersetzten= $this->app->Secure->GetPOST("beschreibungersetzten");
|
|
|
|
$beschreibung= $this->app->Secure->GetPOST("beschreibung");
|
|
|
|
if(!$this->app->erp->CheckDateValidate($startdatum)) $startdatum=date('Y-m-d');
|
|
|
|
// prüfen ob ein neuer Artikel gesetzt ist
|
|
if($artikelneuanlage == '1'){
|
|
$tmp_id = explode(" ",$artikel);
|
|
$tmp_id = $tmp_id[0];
|
|
|
|
$artikeltmp = $this->app->DB->SelectArr("SELECT id,name_de,anabregs_text FROM artikel WHERE nummer='$tmp_id' LIMIT 1");
|
|
$artikeltmp[0]['waehrung'] = $this->app->DB->Select("SELECT waehrung FROM adresse WHERE id = '".$adresse."'");
|
|
|
|
if($artikeltmp[0]['waehrung'] == ''){
|
|
$waehrung = "EUR";
|
|
}
|
|
else {
|
|
$waehrung=$artikeltmp[0]['waehrung'];
|
|
}
|
|
|
|
$anzahlGruppe = $this->app->DB->Select("SELECT count(gruppe) FROM abrechnungsartikel WHERE gruppe='$gruppe' AND adresse='$adresse'");
|
|
|
|
if($sort == ''){$sort=$anzahlGruppe +1;}
|
|
|
|
$this->app->DB->Insert("INSERT INTO abrechnungsartikel (
|
|
id,artikel,bezeichnung,beschreibung,menge,preis, preisart,rabatt, dokument, sort,lieferdatum, steuerklasse, status,projekt,wiederholend,zahlzyklus,adresse,startdatum,enddatum,gruppe,experte,waehrung,abgerechnetbis, abgrechnetam,bemerkung, beschreibungersetzten)
|
|
VALUES (
|
|
'',
|
|
'{$artikeltmp[0]['id']}',
|
|
'$bezeichnung',
|
|
'$beschreibung',
|
|
'$menge',
|
|
'$preis',
|
|
'$preisart',
|
|
'$rabatt',
|
|
'$dokument',
|
|
'$sort',
|
|
'$lieferdatum',
|
|
'$umsatzsteuerklasse',
|
|
'angelegt',
|
|
'$projekt',
|
|
'$wiederholend',
|
|
'$zahlzyklus',
|
|
'$adresse',
|
|
'$startdatum',
|
|
'$enddatum',
|
|
'$gruppe',
|
|
'$experte',
|
|
'$waehrung',
|
|
'$abgerechnetbis',
|
|
'$abgrechnetam',
|
|
'$bemerkung',
|
|
'$beschreibungersetzten'
|
|
)");
|
|
}else{
|
|
$this->app->DB->Update("UPDATE abrechnungsartikel SET
|
|
artikel='$artikelid',
|
|
bezeichnung='$bezeichnung',
|
|
beschreibung = '$beschreibung',
|
|
menge = '$menge',
|
|
preis = '$preis',
|
|
preisart = '$preisart',
|
|
rabatt = '$rabatt',
|
|
dokument = '$dokument',
|
|
gruppe = '$gruppe',
|
|
sort = '$sort',
|
|
startdatum = '$startdatum',
|
|
zahlzyklus = '$zahlzyklus',
|
|
enddatum = '$enddatum',
|
|
abgerechnetbis = '$abgerechnetbis',
|
|
abgrechnetam = '$abgrechnetam',
|
|
bemerkung = '$bemerkung',
|
|
experte = '$experte',
|
|
beschreibungersetzten = '$beschreibungersetzten'
|
|
|
|
WHERE id='$id' LIMIT 1");
|
|
}
|
|
echo json_encode(array(
|
|
'status' => 1
|
|
));
|
|
$this->app->ExitXentral();
|
|
break;
|
|
|
|
|
|
case 'savegruppe':
|
|
$sid= $this->app->Secure->GetPOST('id');
|
|
$ansprechpartner= $this->app->Secure->GetPOST('ansprechpartner');
|
|
$beschreibung= $this->app->Secure->GetPOST('beschreibung');
|
|
$beschreibung2= $this->app->Secure->GetPOST('beschreibung2');
|
|
$rabatt = $this->app->Secure->GetPOST('rabatt');
|
|
|
|
if($rabatt != ""){
|
|
$rabatt = str_replace(',','.',$rabatt);
|
|
}
|
|
|
|
$rechnung= $this->app->Secure->GetPOST('rechnung');
|
|
//if($rechnung!="1") $rechnung=0;
|
|
|
|
$gruppensumme= $this->app->Secure->GetPOST('gruppensumme');
|
|
if($gruppensumme!='1') {
|
|
$gruppensumme=0;
|
|
}
|
|
|
|
$rechnungadresse= $this->app->Secure->GetPOST('rechnungadresse');
|
|
$rechnungadresse = explode(' ',$rechnungadresse);
|
|
$rechnungadresse = $rechnungadresse[0];
|
|
$rechnungadresse = $this->app->DB->Select("SELECT id FROM adresse WHERE kundennummer='$rechnungadresse' AND kundennummer!='' LIMIT 1");
|
|
|
|
if($rechnungadresse <=0) $rechnungadresse = 0;
|
|
|
|
$sort= $this->app->Secure->GetPOST('sort');
|
|
|
|
$projekt= $this->app->Secure->GetPOST('projekt');
|
|
$projekt = explode(' ',$projekt);
|
|
$projekt = $projekt[0];
|
|
$projekt = $this->app->DB->Select("SELECT id FROM projekt WHERE abkuerzung='$projekt' AND abkuerzung!='' LIMIT 1");
|
|
|
|
$sammelrechnung = trim($this->app->Secure->GetPOST('sammelrechnung'));
|
|
if($sammelrechnung != ''){
|
|
$sammelrechnung = explode(' ', $sammelrechnung);
|
|
$sammelrechnung = $sammelrechnung[0];
|
|
$sammelrechnung = $this->app->DB->Select("SELECT id FROM adresse_abosammelrechnungen WHERE id = '$sammelrechnung' LIMIT 1");
|
|
}else{
|
|
$sammelrechnung = 0;
|
|
}
|
|
|
|
|
|
if($sid > 0)
|
|
{
|
|
$this->app->DB->Update("UPDATE abrechnungsartikel_gruppe SET beschreibung='$beschreibung',beschreibung2='$beschreibung2',rabatt = '$rabatt',ansprechpartner='$ansprechpartner',extrarechnung='$rechnung',projekt='$projekt',sort='$sort',gruppensumme='$gruppensumme',rechnungadresse='$rechnungadresse',sammelrechnung='$sammelrechnung' WHERE id='$sid' LIMIT 1");
|
|
} else {
|
|
$this->app->DB->Insert("INSERT INTO abrechnungsartikel_gruppe (id,beschreibung,beschreibung2,rabatt,ansprechpartner,extrarechnung,projekt,adresse,sort,gruppensumme,rechnungadresse,sammelrechnung)
|
|
VALUES ('','$beschreibung','$beschreibung2','$rabatt','$ansprechpartner','$rechnung','$projekt','$id','$sort','$gruppensumme','$rechnungadresse','$sammelrechnung') ");
|
|
}
|
|
echo json_encode(array(
|
|
'status' => 1
|
|
));
|
|
$this->app->ExitXentral();
|
|
break;
|
|
|
|
case 'getgruppe':
|
|
$sid= $this->app->Secure->GetPOST('id');
|
|
$tmp = $this->app->DB->SelectRow("SELECT * FROM abrechnungsartikel_gruppe WHERE id='$sid' LIMIT 1");
|
|
$tmp['status']=1;
|
|
if($tmp['projekt'] > 0){
|
|
$tmp['projekt'] = $this->app->DB->Select("SELECT CONCAT(abkuerzung,' ',name) FROM projekt WHERE id='" . $tmp['projekt'] . "' LIMIT 1");
|
|
}
|
|
else{
|
|
$tmp['projekt'] = '';
|
|
}
|
|
|
|
if($tmp['rechnungadresse'] > 0){
|
|
$tmp['rechnungadresse'] = $this->app->DB->Select("SELECT CONCAT(kundennummer,' ',name,if(ort!='',CONCAT(' (',ort,')'),'')) FROM adresse WHERE id='" . $tmp['rechnungadresse'] . "' LIMIT 1");
|
|
}
|
|
else{
|
|
$tmp['rechnungadresse'] = '';
|
|
}
|
|
|
|
if($tmp['sammelrechnung'] > 0){
|
|
$tmp['sammelrechnung'] = $this->app->DB->Select("SELECT CONCAT(id, ' ', bezeichnung) FROM adresse_abosammelrechnungen WHERE id = '" . $tmp['sammelrechnung'] . "' LIMIT 1");
|
|
}
|
|
else{
|
|
$tmp['sammelrechnung'] = '';
|
|
}
|
|
|
|
$tmp['rabatt'] = str_replace('.',',',$tmp['rabatt']);
|
|
|
|
|
|
echo json_encode($tmp);
|
|
$this->app->ExitXentral();
|
|
break;
|
|
|
|
case 'deletegruppe':
|
|
$sid= $this->app->Secure->GetPOST('id');
|
|
$this->app->DB->Update("UPDATE `abrechnungsartikel` SET `gruppe`=0 WHERE `gruppe`='$sid'");
|
|
$this->app->DB->Update("UPDATE `subscription_cycle_autosubscription` SET `subscription_group_id`=0 WHERE `subscription_group_id`='$sid'");
|
|
$this->app->DB->Delete("DELETE FROM `abrechnungsartikel_gruppe` WHERE `id`='$sid' LIMIT 1");
|
|
$tmp['status']=1;
|
|
$tmp['statusText']='Gruppe gelöscht';
|
|
echo json_encode($tmp);
|
|
$this->app->ExitXentral();
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
$anlegen_artikelneu = $this->app->Secure->GetPOST('anlegen_artikelneu');
|
|
|
|
|
|
if($anlegen_artikelneu!='')
|
|
{
|
|
|
|
if($bezeichnung!='' && $menge!='' && $preis!='')
|
|
{
|
|
|
|
$neue_nummer = $this->app->erp->NeueArtikelNummer($artikelart,$this->app->User->GetFirma(),$projekt);
|
|
|
|
// anlegen als artikel
|
|
$this->app->DB->Insert("INSERT INTO artikel (id,typ,nummer,projekt,name_de,umsatzsteuer,adresse,firma)
|
|
VALUES ('','$artikelart','$neue_nummer','$projekt','$bezeichnung','$umsatzsteuerklasse','$lieferant','".$this->app->User->GetFirma()."')");
|
|
|
|
$artikel_id = $this->app->DB->GetInsertID();
|
|
// einkaufspreis anlegen
|
|
|
|
$this->app->DB->Insert("INSERT INTO verkaufspreise (id,artikel,adresse,objekt,projekt,preis,ab_menge,angelegt_am,bearbeiter)
|
|
VALUES ('','$artikel_id','$id','Standard','$projekt','$preis','$menge',NOW(),'".$this->app->User->GetName()."')");
|
|
|
|
$lieferdatum = $this->app->String->Convert($lieferdatum,'%1.%2.%3','%3-%2-%1');
|
|
$startdatum= $this->app->String->Convert($startdatum,'%1.%2.%3','%3-%2-%1');
|
|
|
|
if($art==='abo') {
|
|
$wiederholend=1;
|
|
} else {
|
|
$wiederholend=0;
|
|
}
|
|
|
|
if(!$this->app->erp->CheckDateValidate($startdatum)) $startdatum=date('Y-m-d');
|
|
$this->app->DB->Insert("INSERT INTO abrechnungsartikel (id,artikel,bezeichnung,nummer,menge,preis, sort,lieferdatum, steuerklasse, status,projekt,wiederholend,zahlzyklus,adresse,startdatum)
|
|
VALUES ('','$artikel_id','$bezeichnung','$neue_nummer','$menge','$preis','$sort','$lieferdatum','$umsatzsteuerklasse','angelegt','$projekt','$wiederholend','$zahlzyklus','$id','$startdatum')");
|
|
|
|
$this->app->Location->execute("index.php?module=adresse&action=artikel&id=$id");
|
|
}
|
|
$this->app->Tpl->Set('NEUMESSAGE',"<div class=\"error\">Bestellnummer, bezeichnung, Menge und Preis sind Pflichtfelder!</div>");
|
|
}
|
|
|
|
$ajaxbuchen = $this->app->Secure->GetPOST('ajaxbuchen');
|
|
if($ajaxbuchen!='')
|
|
{
|
|
$artikel = $this->app->Secure->GetPOST('artikel');
|
|
$nummer = $this->app->Secure->GetPOST('nummer');
|
|
$projekt = $this->app->Secure->GetPOST('projekt');
|
|
$projekt = $this->app->DB->Select("SELECT id FROM projekt WHERE abkuerzung='$projekt' LIMIT 1");
|
|
$sort = $this->app->DB->Select("SELECT MAX(sort) FROM angebot_position WHERE auftrag='$id' LIMIT 1");
|
|
$sort = $sort + 1;
|
|
$artikel_id = $this->app->DB->Select("SELECT id FROM artikel WHERE nummer='$nummer' LIMIT 1");
|
|
$bezeichnung = $artikel;
|
|
$neue_nummer = $nummer;
|
|
$waehrung = 'EUR';
|
|
$umsatzsteuerklasse = $this->app->DB->Select("SELECT umsatzsteuerklasse FROM artikel WHERE nummer='$nummer' LIMIT 1");
|
|
$vpe = 'einzeln';
|
|
|
|
// $this->app->DB->Insert("INSERT INTO angebot_position (id,angebot,artikel,bezeichnung,nummer,menge,preis, waehrung, sort,lieferdatum, umsatzsteuer, status,projekt,vpe)
|
|
// VALUES ('','$id','$artikel_id','$bezeichnung','$neue_nummer','$menge','$preis','$waehrung','$sort','$lieferdatum','$umsatzsteuerklasse','angelegt','$projekt','$vpe')");
|
|
}
|
|
|
|
$cmd = $this->app->Secure->GetGET('cmd');
|
|
if($cmd === 'smlsave'){
|
|
|
|
$smlid = (int)$this->app->Secure->GetPOST('id');
|
|
$bezeichnung = trim($this->app->Secure->GetPOST('bezeichnung'));
|
|
$smlrabatt = trim($this->app->Secure->GetPOST('smlrabatt'));
|
|
$abweichende_rechnungsadresse = trim($this->app->Secure->GetPOST('abwrechnungsadresse'));
|
|
$projekt = trim($this->app->Secure->GetPOST('projekt'));
|
|
$adressid = trim($this->app->Secure->GetPOST('aid'));
|
|
|
|
$error = '';
|
|
|
|
if($bezeichnung == ''){
|
|
$error .= "Bitte Bezeichnung ausfüllen\n";
|
|
}
|
|
|
|
if($smlrabatt != ''){
|
|
$smlrabatt = str_replace(',','.',$smlrabatt);
|
|
}
|
|
|
|
if($abweichende_rechnungsadresse != ''){
|
|
$abwrg = explode(' ', $abweichende_rechnungsadresse);
|
|
$abwrgid = $abwrg[0];
|
|
|
|
$abwrgid = $this->app->DB->Select("SELECT id FROM adresse WHERE id = '$abwrgid' LIMIT 1");
|
|
if($abwrgid != ''){
|
|
}else{
|
|
$error .= 'Bitte gültige abweichende Rechnungsadresse ausfüllen'."\n";
|
|
}
|
|
}
|
|
|
|
if($projekt != ''){
|
|
$projektid = $this->app->DB->Select("SELECT id FROM projekt WHERE abkuerzung = '$projekt' LIMIT 1");
|
|
if($projektid != ''){
|
|
}else{
|
|
$error .= 'Bitte gültiges Projekt ausfüllen'."\n";
|
|
}
|
|
}
|
|
|
|
if($adressid != ''){
|
|
$adressid = $this->app->DB->Select("SELECT id FROM adresse WHERE id = '$adressid' LIMIT 1");
|
|
if($adressid != ''){
|
|
}else{
|
|
$error .= 'Keine gültige Adresse'."\n";
|
|
}
|
|
}
|
|
|
|
if($error == ''){
|
|
if($smlid){
|
|
$this->app->DB->Update("UPDATE adresse_abosammelrechnungen SET bezeichnung = '$bezeichnung', rabatt = '$smlrabatt', abweichende_rechnungsadresse = '$abwrgid', projekt = '$projektid' WHERE id = '$smlid'");
|
|
|
|
echo json_encode(array('status'=>1));
|
|
$this->app->ExitXentral();
|
|
}
|
|
$this->app->DB->Insert("INSERT INTO adresse_abosammelrechnungen (bezeichnung, rabatt, abweichende_rechnungsadresse, projekt, adresse) VALUES ('$bezeichnung', '$smlrabatt', '$abwrgid', '$projektid', '$adressid')");
|
|
echo json_encode(array('status'=>1));
|
|
$this->app->ExitXentral();
|
|
}
|
|
echo json_encode(array('status'=>0,'statusText'=>$error));
|
|
$this->app->ExitXentral();
|
|
}
|
|
if($cmd === 'smledit'){
|
|
$smlid = (int)$this->app->Secure->GetPOST('id');
|
|
|
|
$data = $this->app->DB->SelectRow("SELECT abs.id, abs.bezeichnung, abs.rabatt, abs.abweichende_rechnungsadresse, abs.projekt FROM adresse_abosammelrechnungen as abs WHERE abs.id = '$smlid' LIMIT 1");
|
|
|
|
if($data){
|
|
if($data['abweichende_rechnungsadresse'] == 0){
|
|
$data['abweichende_rechnungsadresse'] = '';
|
|
}else{
|
|
if($data['abweichende_rechnungsadresse'] != ''){
|
|
$abwadressid = $this->app->DB->Select("SELECT id FROM adresse WHERE id = '".$data['abweichende_rechnungsadresse']."' LIMIT 1");
|
|
if($abwadressid != ""){
|
|
$abwadressname = $this->app->DB->Select("SELECT name FROM adresse WHERE id = '$abwadressid' LIMIT 1");
|
|
if($abwadressname != ""){
|
|
$abwkundennr = $this->app->DB->Select("SELECT kundennummer FROM adresse WHERE id = '$abwadressid' LIMIT 1");
|
|
$abwlieferantennr = $this->app->DB->Select("SELECT lieferantennummer FROM adresse WHERE id = '$abwadressid' LIMIT 1");
|
|
|
|
$restadresse = '';
|
|
$restadresse .= '(Kdr: '.$abwkundennr.' ';
|
|
|
|
if($abwlieferantennr != ''){
|
|
$restadresse .= 'Liefr: '.$abwlieferantennr;
|
|
}
|
|
|
|
$restadresse .= ')';
|
|
|
|
$data['abweichende_rechnungsadresse'] = $abwadressid.' '.$abwadressname." ".$restadresse;
|
|
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
if($data['projekt'] == 0){
|
|
$data['projekt'] = '';
|
|
}else{
|
|
if($data['projekt'] > 0){
|
|
$projektabkuerzung = $this->app->DB->Select("SELECT abkuerzung FROM projekt WHERE id = '".$data['projekt']."' LIMIT 1");
|
|
if($projektabkuerzung != ''){
|
|
$data['projekt'] = $projektabkuerzung;
|
|
}else{
|
|
$data['projekt'] = '';
|
|
}
|
|
}
|
|
}
|
|
|
|
if($data['rabatt'] != ''){
|
|
$data['rabatt'] = str_replace('.', ',', $data['rabatt']);
|
|
}
|
|
|
|
}else{
|
|
$data['id'] = 0;
|
|
$data['bezeichnung'] = '';
|
|
$data['rabatt'] = '';
|
|
$data['abweichende_rechnungsadresse'] = '';
|
|
$data['projekt'] = '';
|
|
}
|
|
|
|
echo json_encode($data);
|
|
$this->app->ExitXentral();
|
|
|
|
|
|
}
|
|
if($cmd === "smldelete"){
|
|
$smlid = (int) $this->app->Secure->GetPOST('id');
|
|
$this->app->DB->Update("DELETE FROM adresse_abosammelrechnungen WHERE id = '$smlid'");
|
|
|
|
echo json_encode(array('status'=>1));
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
|
|
|
|
if(1)
|
|
{
|
|
$this->app->Tpl->Set('ARTIKELART',$this->app->erp->GetSelect($this->app->erp->GetArtikelart(),$artikelart));
|
|
$this->app->Tpl->Set('VPE',$this->app->erp->GetSelect($this->app->erp->GetVPE(),$vpe));
|
|
$this->app->Tpl->Set('WAEHRUNG',$this->app->erp->GetSelect($this->app->erp->GetWaehrung(),$vpe));
|
|
$this->app->Tpl->Set('UMSATZSTEUERKLASSE',$this->app->erp->GetSelect($this->app->erp->GetUmsatzsteuerklasse(),$umsatzsteuerklasse));
|
|
$this->app->Tpl->Set('PROJEKT',$this->app->erp->GetProjektSelect($projekt));
|
|
$this->app->Tpl->Set('PREIS',$preis);
|
|
$this->app->Tpl->Set('MENGE',$menge);
|
|
$this->app->Tpl->Set('LIEFERDATUM',$lieferdatum);
|
|
$this->app->Tpl->Set('ZAHLZYKLUS',$zahlzyklus);
|
|
$this->app->Tpl->Set('BEZEICHNUNG',$bezeichung);
|
|
|
|
$this->app->Tpl->Set('SUBSUBHEADING','Neuen Artikel anlegen');
|
|
// $this->app->Tpl->Parse('INHALT',"aboabrechnungsartikel_artikelneu.tpl");
|
|
// $this->app->Tpl->Set(EXTEND,"<input type=\"submit\" value=\"Artikel anlegen\" name=\"anlegen_artikelneu\">");
|
|
$this->app->Tpl->Parse('UEBERSICHT','rahmen70.tpl');
|
|
$this->app->Tpl->Set('EXTEND','');
|
|
$this->app->Tpl->Set('INHALT','');
|
|
$this->app->YUI->DatePicker('startdatum');
|
|
$this->app->YUI->DatePicker('enddatum');
|
|
$this->app->YUI->DatePicker('abgerechnetbis');
|
|
$this->app->YUI->CkEditor('beschreibung','belege');
|
|
$this->app->YUI->CkEditor('editbeschreibung2','belege',array('height'=>'100'));
|
|
|
|
/* ende neu anlegen formular */
|
|
/* ende neu anlegen formular */
|
|
// child table einfuegen
|
|
|
|
//Wurde mit LiveTabelle ersetzt
|
|
/*$menu = array(//"up"=>"upartikel",
|
|
// "down"=>"downartikel",
|
|
//"add"=>"addstueckliste",
|
|
"edit"=>"positioneneditpopup",
|
|
"del"=>"delartikel");
|
|
// wiederholende artikel
|
|
$sql = "SELECT aa.bezeichnung,art.nummer, au.name as bearbeiter, if(aa.angelegtam='0000-00-00','-',DATE_FORMAT(aa.angelegtam,'%d.%m.%Y')) as 'angelegt am', if(aa.abgerechnetbis='0000-00-00','-',DATE_FORMAT(aa.abgerechnetbis,'%d.%m.%Y')) as 'abgerechnet bis',
|
|
if(aa.enddatum='0000-00-00','-',DATE_FORMAT(aa.enddatum,'%d.%m.%Y')) as enddatum,
|
|
aa.preis as preis, aa.waehrung, aa.menge as menge, if(aa.wiederholend=1 OR aa.preisart='monat' OR aa.preisart='jahr' OR aa.preisart='monatx','wdh','einmalig') as art, aa.dokument,aa.id as id
|
|
FROM abrechnungsartikel aa LEFT JOIN artikel art ON art.id=aa.artikel LEFT JOIN user u ON u.id=aa.angelegtvon LEFT JOIN adresse au ON au.id=u.adresse
|
|
WHERE aa.adresse='$id'";
|
|
|
|
$this->app->YUI->SortList('TAB1',$this,$menu,$sql,false);*/
|
|
|
|
// $this->app->YUI->TableSearch('TAB1',"adresse_abo");
|
|
|
|
|
|
$this->app->YUI->AutoComplete('e_projekt', 'projektname', 1);
|
|
$this->app->YUI->AutoComplete('e_abwrechnungsadresse', 'adresse');
|
|
$this->app->YUI->AutoComplete('editsammelrechnung','abosammelrechnungen','',"&adresse=$id");
|
|
|
|
|
|
$this->app->Tpl->Set('ADRESSE',$id);
|
|
$this->app->YUI->TableSearch('TAB1', 'adressealleabos', 'show','','',basename(__FILE__), __CLASS__);
|
|
$this->app->YUI->TableSearch('SORTPOPUP', 'adressealleabossort', 'show','','',basename(__FILE__), __CLASS__);
|
|
$this->app->YUI->TableSearch('TAB2','abrechnungsartikel_gruppe', 'show','','',basename(__FILE__), __CLASS__);
|
|
$this->app->YUI->TableSearch('TAB3','abrechnungsartikel', 'show','','',basename(__FILE__), __CLASS__);
|
|
$this->app->YUI->TableSearch('TAB4', 'abosammelrechnungen', 'show','','',basename(__FILE__), __CLASS__);
|
|
|
|
|
|
$this->app->YUI->AutoComplete('editansprechpartner','ansprechpartner','',"&adresse=$id");
|
|
$this->app->Tpl->Set('MONATLICH', number_format($this->getAboMonthSum($id),2,',','.'));
|
|
$this->app->Tpl->Parse('PAGE','adresse_abo.tpl');
|
|
}
|
|
}
|
|
|
|
|
|
function AdresseSEPAMandat()
|
|
{
|
|
$projekt = '';
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
if(class_exists('SepaMandatCustom'))
|
|
{
|
|
$pdf = new SepaMandatCustom($this->app,$projekt);
|
|
}else{
|
|
$pdf = new SepaMandat($this->app,$projekt);
|
|
}
|
|
|
|
|
|
|
|
$data = $this->app->DB->SelectArr("SELECT name,strasse, ansprechpartner,ort,plz,land,email,kundennummer, inhaber, bank, swift, iban,firmensepa,mandatsreferenzart,mandatsreferenz FROM adresse WHERE id='$id' LIMIT 1");
|
|
$pdf->firmensepa=$data[0]['firmensepa'];
|
|
$pdf->mandatsreferenzart=$data[0]['mandatsreferenzart'];
|
|
|
|
|
|
$musterlinie = '_____________________________________';
|
|
|
|
$pdf->firma=$this->app->erp->ReadyForPDF($data[0]['name']);
|
|
if($pdf->firma=='') {
|
|
$pdf->firma = $musterlinie;
|
|
}
|
|
$pdf->name=$this->app->erp->ReadyForPDF($data[0]['ansprechpartner']);
|
|
if($pdf->name=='') {
|
|
$pdf->name=$musterlinie;
|
|
}
|
|
$pdf->strasse=$this->app->erp->ReadyForPDF($data[0]['strasse']);
|
|
if($pdf->strasse=='') {
|
|
$pdf->strasse=$musterlinie;
|
|
}
|
|
$pdf->plzOrt=$this->app->erp->ReadyForPDF($data[0]['land']).'-'.$this->app->erp->ReadyForPDF($data[0]['plz'])." ".$this->app->erp->ReadyForPDF($data[0]['ort']);
|
|
if($pdf->plzOrt=='-' || $pdf->plzOrt=='- ') {
|
|
$pdf->plzOrt=$musterlinie;
|
|
}
|
|
$pdf->email=$this->app->erp->ReadyForPDF($data[0]['email']);
|
|
if($pdf->email=='') {
|
|
$pdf->email=$musterlinie;
|
|
}
|
|
|
|
$pdf->kundenNr=$this->app->erp->ReadyForPDF($data[0]['kundennummer']);
|
|
//$pdf->benutzername="info@embedded-projects.net";
|
|
|
|
$pdf->glID=$this->app->erp->Firmendaten('sepaglaeubigerid');
|
|
|
|
if($data[0]['mandatsreferenz']==''){
|
|
$pdf->mandatsRef = $this->app->erp->ReadyForPDF($data[0]['kundennummer']);
|
|
}
|
|
else{
|
|
$pdf->mandatsRef = $data[0]['mandatsreferenz'];
|
|
}
|
|
|
|
$pdf->swift=$data[0]['swift'];
|
|
if($pdf->swift=='') {
|
|
$pdf->swift='_____________________________________';
|
|
}
|
|
$pdf->iban=$data[0]['iban'];
|
|
if($pdf->iban=='') {
|
|
$pdf->iban='_____________________________________';
|
|
}
|
|
$pdf->bank=$data[0]['bank'];
|
|
if($pdf->bank=='') {
|
|
$pdf->bank='_____________________________________';
|
|
}
|
|
|
|
$pdf->ermaechText='Ich ermaechtige die '.$this->app->erp->GetFirmaName().", Zahlungen von meinem Konto mittels Lastschrift einzuziehen. Zugleich weise ich mein Kreditinstitut an, die von der ".$this->app->erp->GetFirmaName()." ".$this->app->erp->Firmendaten("strasse")." ".$this->app->erp->Firmendaten("plz")." ".$this->app->erp->Firmendaten('ort').' auf mein Konto gezogenen Lastschriften einzuloesen.';
|
|
|
|
if($pdf->firmensepa!='1')
|
|
{
|
|
$pdf->hinweis='Hinweis: Ich kann (Wir können) innerhalb von acht Wochen, beginnend mit dem Belastungsdatum, die Erstattung des belasteten Betrages verlangen. Es gelten dabei die mit meinem (unserem) Kreditinstitut vereinbarten Bedingungen.';
|
|
} else {
|
|
$pdf->hinweis='Hinweis: Dieses Lastschriftmandat dient nur dem Einzug von Lastschriften, die auf Konten von Unternehmen gezogen sind. Ich / Wir sind nicht berechtigt, nach der erfolgten Einlösung eine Erstattung des belasteten Betrags zu verlangen. Ich bin / Wir sind berechtigt, mein / unser Kreditinstitut bis zum Fälligkeitstag anzuweisen, Lastschriften nicht einzulösen.';
|
|
}
|
|
|
|
$pdf->render();
|
|
|
|
$name = $this->app->erp->UmlauteEntfernen($this->app->erp->ReadyForPDF($data[0]['name']));
|
|
$name = str_replace(' ','',$name);
|
|
$name = str_replace(',','',$name);
|
|
$name = str_replace('.','',$name);
|
|
$kundennummer = $data[0]['kundennummer'];
|
|
|
|
$filename = $tmp.date('Ymd').'_'.$kundennummer.'_'.$name.'_SEPAMANDAT.pdf';
|
|
$pdf->Output($filename,'D');
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
function AdresseArtikel()
|
|
{
|
|
$this->AdresseMenu();
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
// neues arbeitspaket
|
|
//$widget = new WidgetAbrechnungsartikel(&$this->app,'TAB2');
|
|
//$widget->Create();
|
|
|
|
|
|
// child table einfuegen
|
|
|
|
$menu = array('up'=>'upartikel',
|
|
'down'=>'downartikel',
|
|
//"add"=>"addstueckliste",
|
|
'edit'=>'artikeleditpopup',
|
|
'del'=>'delartikel');
|
|
|
|
// wiederholende artikel
|
|
$this->app->Tpl->Set('SUBSUBHEADING','wiederholende Artikel');
|
|
$sql = "SELECT aa.bezeichnung, DATE_FORMAT(aa.abgerechnetbis,'%d.%m.%Y') as abgerechnet,
|
|
aa.preis as preis, aa.waehrung, aa.menge as menge, aa.id as id
|
|
FROM abrechnungsartikel aa
|
|
WHERE aa.adresse='$id' AND aa.wiederholend=1";
|
|
$this->app->YUI->SortList('INHALT',$this,$menu,$sql,false);
|
|
$this->app->Tpl->Parse('TAB1','rahmen70.tpl');
|
|
$this->app->Tpl->Set('INHALT','');
|
|
|
|
|
|
// einmalige artikel
|
|
$this->app->Tpl->Set('SUBSUBHEADING','einmalige Artikel');
|
|
$sql = "SELECT aa.bezeichnung, DATE_FORMAT(aa.abgerechnetbis,'%d.%m.%Y') as abgerechnet,
|
|
aa.preis as preis, aa.waehrung, aa.menge as menge, aa.id as id
|
|
FROM abrechnungsartikel aa
|
|
WHERE aa.adresse='$id' AND aa.wiederholend=0 AND aa.abgerechnet=0";
|
|
$this->app->YUI->SortList('INHALT',$this,$menu,$sql,false);
|
|
$this->app->Tpl->Parse('TAB1','rahmen70.tpl');
|
|
|
|
$this->app->Tpl->Set('AKTIV_TAB1','selected');
|
|
$this->app->Tpl->Parse('PAGE','artikeluebersicht.tpl');
|
|
}
|
|
|
|
function AdresseArtikelEditPopup()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
// nach page inhalt des dialogs ausgeben
|
|
$widget = new WidgetAbrechnungsartikel($this->app,'PAGE');
|
|
$sid = $this->app->DB->Select("SELECT adresse FROM abrechnungsartikel WHERE id='$id' LIMIT 1");
|
|
$widget->form->SpecialActionAfterExecute('close_refresh',
|
|
"index.php?module=adresse&action=artikel&id=$sid");
|
|
$widget->Edit();
|
|
$this->app->BuildNavigation=false;
|
|
}
|
|
|
|
function UpArtikel()
|
|
{
|
|
$this->app->YUI->SortListEvent('up','abrechnungsartikel','adresse');
|
|
$this->AdresseArtikel();
|
|
}
|
|
|
|
function DownArtikel()
|
|
{
|
|
$this->app->YUI->SortListEvent('down','abrechnungsartikel','adresse');
|
|
$this->AdresseArtikel();
|
|
}
|
|
|
|
|
|
function DelArtikel()
|
|
{
|
|
$this->app->YUI->SortListEvent('del','abrechnungsartikel','adresse');
|
|
$this->AdresseArtikelPosition();
|
|
}
|
|
|
|
function AdresseVerein()
|
|
{
|
|
$id = $this->app->Secure->GetGET('id');
|
|
$submit = $this->app->Secure->GetPOST('submit');
|
|
$this->AdresseMenu();
|
|
|
|
$data['verein_mitglied_seit'] = $this->app->Secure->GetPOST('verein_mitglied_seit');
|
|
$data['verein_mitglied_bis'] = $this->app->Secure->GetPOST('verein_mitglied_bis');
|
|
$data['verein_spendenbescheinigung'] = $this->app->Secure->GetPOST('verein_spendenbescheinigung');
|
|
$data['verein_mitglied_aktiv'] = $this->app->Secure->GetPOST('verein_mitglied_aktiv');
|
|
|
|
if($data['verein_spendenbescheinigung']!='1') {
|
|
$data['verein_spendenbescheinigung']=0;
|
|
}
|
|
if($data['verein_mitglied_aktiv']!='1') {
|
|
$data['verein_mitglied_aktiv']=0;
|
|
}
|
|
|
|
$data['verein_mitglied_seit'] = $this->app->String->Convert($data['verein_mitglied_seit'],"%1.%2.%3","%3-%2-%1");
|
|
$data['verein_mitglied_bis'] = $this->app->String->Convert($data['verein_mitglied_bis'],"%1.%2.%3","%3-%2-%1");
|
|
|
|
$this->app->YUI->DatePicker('verein_mitglied_seit');
|
|
$this->app->YUI->DatePicker('verein_mitglied_bis');
|
|
|
|
if($submit!='')
|
|
{
|
|
$this->app->DB->Update("UPDATE adresse SET
|
|
verein_mitglied_seit='".$data['verein_mitglied_seit']."',
|
|
verein_mitglied_bis='".$data['verein_mitglied_bis']."',
|
|
verein_spendenbescheinigung='".$data['verein_spendenbescheinigung']."',
|
|
verein_mitglied_aktiv='".$data['verein_mitglied_aktiv']."'
|
|
WHERE id='$id'");
|
|
}
|
|
|
|
|
|
$data = $this->app->DB->SelectRow("SELECT * FROM adresse WHERE id='$id'");
|
|
|
|
if($data['verein_spendenbescheinigung']=='1') {
|
|
$this->app->Tpl->Set('VEREIN_SPENDENBESCHEINIGUNG','checked');
|
|
}
|
|
if($data['verein_mitglied_aktiv']=='1') {
|
|
$this->app->Tpl->Set('VEREIN_MITGLIED_AKTIV','checked');
|
|
}
|
|
$this->app->Tpl->Set('VEREIN_MITGLIED_SEIT',str_replace('..','',$this->app->String->Convert($data['verein_mitglied_seit'],"%3-%2-%1","%1.%2.%3")));
|
|
$this->app->Tpl->Set('VEREIN_MITGLIED_BIS',str_replace('..','',$this->app->String->Convert($data['verein_mitglied_bis'],"%3-%2-%1","%1.%2.%3")));
|
|
|
|
$this->app->Tpl->Parse('PAGE','adresse_verein.tpl');
|
|
}
|
|
|
|
function AdresseMinidetailLieferadressen(){
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
$interne_bemerkung = $this->app->DB->Select("SELECT interne_bemerkung FROM lieferadressen WHERE id = '$id' AND interne_bemerkung != '' LIMIT 1");
|
|
$hinweis = $this->app->DB->Select("SELECT hinweis FROM lieferadressen WHERE id = '$id' AND interne_bemerkung != '' LIMIT 1");
|
|
|
|
$this->app->Tpl->Set('TABELLE', "<table width='100%'><tr><td style='background-color:#e0e0e0'><b>Interne Bemerkung</b></td></tr>");
|
|
|
|
if($interne_bemerkung != ''){
|
|
$this->app->Tpl->Add('TABELLE',"<tr><td>".$interne_bemerkung."</td></tr>");
|
|
}else{
|
|
$this->app->Tpl->Add('TABELLE', "<tr><td><div class=\"info\">Keine Daten vorhanden!</div></td></tr>");
|
|
}
|
|
|
|
$this->app->Tpl->Add('TABELLE', "<table width='100%'><tr><td style='background-color:#e0e0e0'><b>Lieferhinweis</b></td></tr>");
|
|
if($hinweis != ''){
|
|
$this->app->Tpl->Add('TABELLE',"<tr><td>".$hinweis."</td></tr>");
|
|
}else{
|
|
$this->app->Tpl->Add('TABELLE', "<tr><td><div class=\"info\">Keine Daten vorhanden!</div></td></tr>");
|
|
}
|
|
|
|
$this->app->Tpl->Add('TABELLE', '</table>');
|
|
|
|
$this->app->Tpl->Output('adresse_lieferadressen_minidetail.tpl');
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
function AdresseMinidetailAnsprechpartner(){
|
|
$id = $this->app->Secure->GetGET('id');
|
|
|
|
$interne_bemerkung = $this->app->DB->Select("SELECT interne_bemerkung FROM ansprechpartner WHERE id = '$id' AND interne_bemerkung != '' LIMIT 1");
|
|
if($interne_bemerkung != ""){
|
|
$this->app->Tpl->Set("TABELLE", "<table width='100%'><tr><td style='background-color:#e0e0e0'><b>Interne Bemerkung</b></td></tr><tr><td>".$interne_bemerkung."</td></tr></table>");
|
|
}else{
|
|
$this->app->Tpl->Set("TABELLE", "<div class=\"info\">Keine Daten vorhanden!</div>");
|
|
}
|
|
|
|
$this->app->Tpl->Output("adresse_lieferadressen_minidetail.tpl");
|
|
$this->app->ExitXentral();
|
|
}
|
|
|
|
|
|
function down($a,$x) {
|
|
if( (!empty($a)?count($a):0)-1 > $x ) {
|
|
$b = array_slice($a,0,$x,true);
|
|
$b[] = $a[$x+1];
|
|
$b[] = $a[$x];
|
|
$b += array_slice($a,$x+2,(!empty($a)?count($a):0),true);
|
|
return($b);
|
|
}
|
|
return $a;
|
|
}
|
|
|
|
function up($a,$x) {
|
|
if( $x > 0 && $x < (!empty($a)?count($a):0) ) {
|
|
$b = array_slice($a,0,($x-1),true);
|
|
$b[] = $a[$x];
|
|
$b[] = $a[$x-1];
|
|
$b += array_slice($a,($x+1),(!empty($a)?count($a):0),true);
|
|
return($b);
|
|
}
|
|
return $a;
|
|
}
|
|
|
|
public function AdresseAnschriftString($id,$ansprechpartner=false)
|
|
{
|
|
$type = 'adresse';
|
|
if($ansprechpartner){
|
|
$type = 'ansprechpartner';
|
|
}
|
|
|
|
$vorlage = $this->app->erp->Firmendaten('reihenfolge_zwischenspeicher');
|
|
$tmp='';
|
|
if($vorlage!='')
|
|
{
|
|
if($type==='ansprechpartner')
|
|
{
|
|
$data = $this->app->DB->SelectArr(
|
|
sprintf(
|
|
'SELECT a.* ,t.bezeichnung as typbezeichnung
|
|
FROM adresse a
|
|
LEFT JOIN adresse_typ t on t.type=a.typ
|
|
WHERE a.id=%d
|
|
LIMIT 1',
|
|
(int)$id
|
|
)
|
|
);
|
|
$data[0]['name'] = $this->app->DB->Select(
|
|
sprintf(
|
|
"SELECT name FROM adresse WHERE id=%d LIMIT 1",
|
|
(int)$data[0]['adresse']
|
|
)
|
|
);
|
|
} else {
|
|
$data = $this->app->DB->SelectArr("SELECT * FROM adresse WHERE id='$id' LIMIT 1");
|
|
}
|
|
if(!empty($data))
|
|
{
|
|
foreach($data[0] as $feld=>$value)
|
|
{
|
|
$vorlage = str_replace('{ADRESSE_'.strtoupper($feld).'}',$value,$vorlage);
|
|
}
|
|
$vorlage = preg_replace('/^\h*\v+/m', '', $vorlage);
|
|
$vorlage = str_replace("\r\n", "\\n", $vorlage);
|
|
$tmp = $vorlage;
|
|
}
|
|
} else {
|
|
if($id > 0)
|
|
{
|
|
if($type==='ansprechpartner')
|
|
{
|
|
$result = $this->app->DB->SelectArr(
|
|
sprintf(
|
|
'SELECT *,name as ansprechpartner,ansprechpartner_land as land
|
|
FROM ansprechpartner WHERE id=%d LIMIT 1',
|
|
(int)$id
|
|
)
|
|
);
|
|
$result[0]['name'] = $this->app->DB->Select(
|
|
sprintf(
|
|
'SELECT name FROM adresse WHERE id=%d LIMIT 1',
|
|
$result[0]['adresse']
|
|
)
|
|
);
|
|
} else {
|
|
$result = $this->app->DB->SelectArr(
|
|
sprintf('SELECT * FROM adresse WHERE id=%d LIMIT 1',
|
|
$id
|
|
)
|
|
);
|
|
}
|
|
|
|
if($result[0]['name']!="") $tmp .= $result[0]['name']."\\n";
|
|
if($result[0]['ansprechpartner']!="") $tmp .= $result[0]['ansprechpartner']."\\n";
|
|
if($result[0]['abteilung']!="") $tmp .= $result[0]['abteilung']."\\n";
|
|
if($result[0]['unterabteilung']!="") $tmp .= $result[0]['unterabteilung']."\\n";
|
|
if($result[0]['adresszusatz']!="") $tmp .= $result[0]['adresszusatz']."\\n";
|
|
if($result[0]['strasse']!="") $tmp .= $result[0]['strasse']."\\n";
|
|
$tmp .= $result[0]['land']."-".$result[0]['plz']." ".$result[0]['ort'];
|
|
}
|
|
}
|
|
return $this->app->erp->ReadyForPDF($tmp);
|
|
}
|
|
|
|
/**
|
|
* @param int $id
|
|
*
|
|
* @return int
|
|
*/
|
|
public function CopyAdresse($id){
|
|
$this->app->DB->MysqlCopyRow('adresse','id',$id);
|
|
$idNew = $this->app->DB->GetInsertID();
|
|
//$roles = $this->app->DB->SelectArr("SELECT * FROM adresse_rolle WHERE adresse = '$id'");
|
|
$this->app->DB->Insert("INSERT INTO adresse_rolle (adresse, projekt, subjekt, praedikat, objekt, parameter, von, bis)
|
|
SELECT $idNew, projekt, subjekt, praedikat, objekt, parameter, von, bis FROM adresse_rolle WHERE adresse = '$id'");
|
|
|
|
return $idNew;
|
|
}
|
|
|
|
/**
|
|
* Query for adresse minidetail
|
|
* CRM view inside adresse page is in adresse.php
|
|
* @param int $adresseId AdressID
|
|
* @param int $maxResults SQL-Limit; Maximale Anzahl der Ergebnisse
|
|
*
|
|
* @return string
|
|
*/
|
|
protected function GetAddressCrmSql($adresseId, $maxResults = 20)
|
|
{
|
|
$adresseId = (int)$adresseId;
|
|
$limit = (int)$maxResults;
|
|
|
|
$sql = '
|
|
SELECT
|
|
DATE_FORMAT(a.datum, "%d.%m.%Y %H:%i") AS datum,
|
|
if(ifnull(a.internebezeichnung,\'\') = \'\', a.title, concat(a.title,\'<br /><i style="color:grey">\',a.internebezeichnung,\'</i>\')) AS bezeichnung,
|
|
a.ansprechpartner,
|
|
a.abkuerzung AS projekt,
|
|
a.bearbeiter,
|
|
a.art,
|
|
a.gesendet,
|
|
a.pdf
|
|
FROM
|
|
(
|
|
(
|
|
SELECT
|
|
d.id,
|
|
CONCAT(DATE_FORMAT(d.datum, "%Y-%m-%d"), " ", IF(d.uhrzeit IS NULL OR DATE_FORMAT(d.uhrzeit, "%H:%i")="00:00", "", DATE_FORMAT(d.uhrzeit, "%H:%i")) ) as datum,
|
|
d.betreff as title,if(d.typ = \'email\',if(d.ansprechpartner <> \'\',d.ansprechpartner,d.email_an),d.ansprechpartner) as ansprechpartner,
|
|
p.abkuerzung as abkuerzung,
|
|
if(bearbeiter!="",bearbeiter,a2.name) as bearbeiter,
|
|
CONCAT(UCASE(LEFT(d.typ, 1)), SUBSTRING(d.typ, 2)) as art,
|
|
CONCAT(IF(d.sent = 1, "JA", "NEIN"),"<a data-type=dokumente data-id=", d.id, "></a>") as gesendet,
|
|
"" as pdf,
|
|
concat("1","-",d.id) as did,
|
|
d.content as suchtext,
|
|
d.internebezeichnung
|
|
FROM
|
|
dokumente d
|
|
LEFT JOIN projekt p ON p.id=d.projekt
|
|
LEFT JOIN adresse a2 ON a2.id=adresse_from
|
|
WHERE
|
|
adresse_to = ' . $adresseId . '
|
|
)
|
|
|
|
UNION ALL
|
|
(
|
|
SELECT
|
|
ds.id,
|
|
CONCAT(DATE_FORMAT(ds.zeit, "%Y-%m-%d")," ", IF(DATE_FORMAT(ds.zeit, "%H:%i")="00:00", "", DATE_FORMAT(ds.zeit, "%H:%i"))) as datum,
|
|
ds.betreff as title,ds.ansprechpartner ,
|
|
p.abkuerzung as abkuerzung,
|
|
ds.bearbeiter as bearbeiter,
|
|
CONCAT(UCASE(LEFT(ds.dokument, 1)), SUBSTRING(ds.dokument, 2),"<span style=\"display:none;\" class=\"editlink\">index.php?module=",ds.dokument,"&action=edit&id=",ds.parameter,"</span>") as art,
|
|
CONCAT(IF(ds.versendet = 1, "JA", "NEIN"),"<a data-type=dokumente_send data-id=", ds.id, "></a>") as gesendet,
|
|
concat("<a href=\"index.php?module=",ds.dokument,"&action=pdf&id=",ds.parameter,"\"><img src=./themes/' . $this->app->Conf->WFconf['defaulttheme'] . '/images/pdf.svg></a>") as pdf,
|
|
concat("2","-",ds.id) as did,
|
|
ds.text as suchtext,
|
|
ifnull(d1.internebezeichnung,
|
|
ifnull(d2.internebezeichnung,
|
|
ifnull(d3.internebezeichnung,
|
|
ifnull(d4.internebezeichnung,
|
|
ifnull(d5.internebezeichnung,
|
|
ifnull(d6.internebezeichnung,
|
|
\'\')))))) as internebezeichnung
|
|
FROM
|
|
dokumente_send ds
|
|
LEFT JOIN lieferschein d1 ON ds.parameter = d1.id AND ds.dokument = \'lieferschein\'
|
|
LEFT JOIN auftrag d2 ON ds.parameter = d2.id AND ds.dokument = \'auftrag\'
|
|
LEFT JOIN rechnung d3 ON ds.parameter = d3.id AND ds.dokument = \'rechnung\'
|
|
LEFT JOIN gutschrift d4 ON ds.parameter = d4.id AND ds.dokument = \'gutschrift\'
|
|
LEFT JOIN angebot d5 ON ds.parameter = d5.id AND ds.dokument = \'angebot\'
|
|
LEFT JOIN bestellung d6 ON ds.parameter = d6.id AND ds.dokument = \'bestellung\'
|
|
LEFT JOIN projekt p ON p.id=ds.projekt
|
|
WHERE
|
|
ds.adresse = ' . $adresseId . '
|
|
)
|
|
|
|
UNION ALL
|
|
(
|
|
SELECT
|
|
k.id,
|
|
CONCAT(DATE_FORMAT(k.von, "%Y-%m-%d")," ", IF(DATE_FORMAT(k.von, "%H:%i")="00:00", "", DATE_FORMAT(k.von, "%H:%i"))) as datum,
|
|
k.bezeichnung COLLATE utf8_general_ci as title,\'\' as ansprechpartner,
|
|
p.abkuerzung as abkuerzung,
|
|
a2.name COLLATE utf8_general_ci as bearbeiter,
|
|
"Kalender" as art,
|
|
CONCAT("<a data-type=kalender data-id=", k.id, "></a>") as gesendet,
|
|
"" as pdf,
|
|
concat("6","-",k.id) as did,
|
|
k.beschreibung COLLATE utf8_general_ci as suchtext,
|
|
\'\' as internebezeichnung
|
|
FROM
|
|
kalender_event k
|
|
LEFT JOIN adresse a2 ON k.adresseintern = a2.id
|
|
LEFT JOIN projekt p ON p.id=k.projekt
|
|
WHERE
|
|
k.adresse = ' . $adresseId . '
|
|
)
|
|
';
|
|
|
|
|
|
|
|
if($this->app->erp->RechteVorhanden('wiedervorlage', 'list')){
|
|
if($this->app->erp->GetKonfiguration('adresse_crm_collateerror') && method_exists($this->app->YUI, 'ConvertLatin1UTF')){
|
|
$sql .= '
|
|
UNION ALL
|
|
(
|
|
SELECT
|
|
w.id,
|
|
CONCAT(DATE_FORMAT(datum_erinnerung, "%Y-%m-%d"), " ", IF(zeit_erinnerung IS NULL OR DATE_FORMAT(zeit_erinnerung, "%H:%i")="00:00", "", DATE_FORMAT(zeit_erinnerung, "%H:%i")) ) as datum,
|
|
' . $this->app->YUI->ConvertLatin1UTF('w.bezeichnung') . ' as title,\'\' as ansprechpartner,
|
|
' . $this->app->YUI->ConvertLatin1UTF('p.abkuerzung') . ' as abkuerzung,
|
|
adr.name COLLATE utf8_general_ci as bearbeiter,
|
|
CONCAT("Wiedervorlage") as art,
|
|
CONCAT("<a data-type=wiedervorlage data-id=", w.id, "></a>") as gesendet,
|
|
"" as pdf,
|
|
concat("5","-",w.id) as did,
|
|
' . $this->app->YUI->ConvertLatin1UTF('w.beschreibung') . ' as suchtext,
|
|
\'\' as internebezeichnung
|
|
FROM
|
|
wiedervorlage w left join adresse adr on w.bearbeiter = adr.id
|
|
LEFT JOIN projekt p ON p.id=w.projekt
|
|
WHERE
|
|
w.adresse = ' . $adresseId . '
|
|
)';
|
|
}else{
|
|
$sql .= '
|
|
UNION ALL
|
|
(
|
|
SELECT
|
|
w.id,
|
|
CONCAT(DATE_FORMAT(datum_erinnerung, "%Y-%m-%d"), " ", IF(zeit_erinnerung IS NULL OR DATE_FORMAT(zeit_erinnerung, "%H:%i")="00:00", "", DATE_FORMAT(zeit_erinnerung, "%H:%i")) ) as datum,
|
|
w.bezeichnung COLLATE utf8_general_ci as title,
|
|
\'\' as ansprechpartner,
|
|
p.abkuerzung COLLATE utf8_general_ci as abkuerzung,
|
|
adr.name COLLATE utf8_general_ci as bearbeiter,
|
|
CONCAT("Wiedervorlage") as art,
|
|
CONCAT("<a data-type=wiedervorlage data-id=", w.id, "></a>") as gesendet,
|
|
"" as pdf,
|
|
concat("5","-",w.id) as did,
|
|
w.beschreibung COLLATE utf8_general_ci as suchtext,
|
|
\'\' as internebezeichnung
|
|
FROM
|
|
wiedervorlage w left join adresse adr on w.bearbeiter = adr.id
|
|
LEFT JOIN projekt p ON p.id=w.projekt
|
|
WHERE
|
|
w.adresse = ' . $adresseId . '
|
|
)';
|
|
}
|
|
}
|
|
|
|
$sql .= 'UNION ALL
|
|
(
|
|
SELECT
|
|
t.id,
|
|
tn.zeit,
|
|
tn.betreff,
|
|
ifnull((SELECT name FROM ansprechpartner ap WHERE ap.adresse = a.id AND ap.email = tn.mail LIMIT 1),tn.mail) as ansprechpartner,
|
|
p.abkuerzung,
|
|
tn.verfasser,
|
|
\'Ticketnachricht\' as art,
|
|
CONCAT(IF(tn.versendet = 1, "JA", "NEIN"),"<a data-type=ticket_nachricht data-id=", t.id, "></a>") as gesendet,
|
|
\'\' as PDF,
|
|
concat("4","-",tn.id) as did,
|
|
CONCAT(tn.text,t.notiz) as suchtext,
|
|
\'\' as intern
|
|
FROM
|
|
ticket_nachricht tn
|
|
INNER JOIN ticket t ON
|
|
tn.ticket = t.schluessel
|
|
INNER JOIN adresse a ON t.adresse = a.id
|
|
LEFT JOIN projekt p ON t.projekt = p.id
|
|
WHERE t.adresse = '.$adresseId.' AND !(tn.versendet = 1 AND tn.zeitausgang IS NULL)
|
|
)
|
|
';
|
|
|
|
$sql .= ') AS a ';
|
|
$sql .= 'ORDER BY a.datum DESC ';
|
|
$sql .= 'LIMIT 0, ' . $maxResults;
|
|
|
|
return $sql;
|
|
}
|
|
}
|
|
|
|
|