mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-12 06:41:14 +01:00
1156 lines
47 KiB
PHP
1156 lines
47 KiB
PHP
|
<?php
|
||
|
include '_gen/widget.gen.shopexport.php';
|
||
|
|
||
|
class WidgetShopexport extends WidgetGenShopexport
|
||
|
{
|
||
|
/**
|
||
|
* @var Application $app
|
||
|
*/
|
||
|
private $app;
|
||
|
|
||
|
/**
|
||
|
* WidgetShopexport constructor.
|
||
|
*
|
||
|
* @param Application $app
|
||
|
* @param string $parsetarget
|
||
|
*/
|
||
|
function __construct($app,$parsetarget)
|
||
|
{
|
||
|
$this->app = $app;
|
||
|
$this->parsetarget = $parsetarget;
|
||
|
parent::__construct($app,$parsetarget);
|
||
|
$this->ExtendsForm();
|
||
|
}
|
||
|
|
||
|
function ExtendsForm()
|
||
|
{
|
||
|
//firma
|
||
|
$id = (int)$this->app->Secure->GetGET('id');
|
||
|
$this->app->Tpl->Set('NURPREISESTYLE',' style="display:none;" ');
|
||
|
$this->app->Secure->POST["firma"]=$this->app->User->GetFirma();
|
||
|
$field = new HTMLInput("firma","hidden",$this->app->User->GetFirma());
|
||
|
$this->form->NewField($field);
|
||
|
|
||
|
$this->app->YUI->AutoComplete("projekt","projektname",1);
|
||
|
$this->form->ReplaceFunction("projekt",$this,"ReplaceProjekt");
|
||
|
$this->app->YUI->AutoComplete("artikelrabattsteuer","steuersatz",1);
|
||
|
$this->form->ReplaceFunction("artikelrabattsteuer",$this,"ReplaceSteuersatz");
|
||
|
$this->app->YUI->AutoComplete("artikelporto","artikelnummer",1);
|
||
|
$this->form->ReplaceFunction("artikelporto",$this,"ReplaceArtikel");
|
||
|
$this->app->YUI->AutoComplete("preisgruppe","preisgruppekennziffer");
|
||
|
$this->form->ReplaceFunction("preisgruppe",$this,"ReplacePreisgruppe");
|
||
|
$this->app->YUI->AutoComplete("artikelportoermaessigt","artikelnummer",1);
|
||
|
$this->form->ReplaceFunction("artikelportoermaessigt",$this,"ReplaceArtikel");
|
||
|
$this->app->YUI->AutoComplete("artikelrabatt","artikelnummer",1);
|
||
|
$this->form->ReplaceFunction("artikelrabatt",$this,"ReplaceArtikel");
|
||
|
$this->app->YUI->AutoComplete('vertrieb','adressemitvertrieb');
|
||
|
$this->form->ReplaceFunction('vertrieb',$this,'ReplaceVertrieb');
|
||
|
|
||
|
$this->app->YUI->AutoComplete("artikelnachnahme","artikelnummer",1);
|
||
|
$this->form->ReplaceFunction("artikelnachnahme",$this,"ReplaceArtikel");
|
||
|
|
||
|
$this->app->YUI->DatePicker('vondatum');
|
||
|
$this->app->YUI->TimePicker('vonzeit');
|
||
|
|
||
|
$this->app->YUI->DatePicker('startdate');
|
||
|
$this->form->ReplaceFunction('startdate',$this,'ReplaceDatum');
|
||
|
|
||
|
if($id > 0 && $this->app->Secure->GetPOST('resetarchiv')) {
|
||
|
$this->app->DB->Update("UPDATE shopexport_archiv SET status = 'abgebrochen' WHERE shop = '$id' LIMIT 1");
|
||
|
$this->app->Tpl->Add('MESSAGE','<div class="info">{|Alte Aufträge abholen abgebrochen.|}</div>');
|
||
|
}
|
||
|
elseif($id > 0 && $this->app->Secure->GetPOST('resetgetarticlelist')) {
|
||
|
$this->app->DB->Delete("DELETE FROM shopexport_getarticles WHERE shop = '$id'");
|
||
|
$this->app->Tpl->Add('MESSAGE','<div class="info">{|Artikel abholen abgebrochen.|}</div>');
|
||
|
}
|
||
|
elseif($id > 0 && $this->app->Secure->GetPOST('getarticlelist')) {
|
||
|
if($this->app->DB->Select(sprintf("SELECT id FROM prozessstarter WHERE parameter = 'onlineshops_tasks' AND aktiv = 1 LIMIT 1"))){
|
||
|
|
||
|
|
||
|
$command = 'getarticlelist';
|
||
|
$task = $this->app->DB->SelectRow('SELECT * FROM onlineshops_tasks WHERE shop_id=\'' . $id . '\' AND command=\'' . $command . '\' LIMIT 1');
|
||
|
if(!empty($task['id'])){
|
||
|
if($task['status'] !== 'running'){
|
||
|
$this->app->DB->Update('UPDATE onlineshop_tasks SET status=\'inactive\',counter=0 WHERE id=' . $task['id']);
|
||
|
}
|
||
|
}else{
|
||
|
$this->app->DB->Insert('INSERT INTO onlineshops_tasks (shop_id, command) VALUES (' . $id . ',\'' . $command . '\')');
|
||
|
}
|
||
|
|
||
|
$status = $this->app->DB->Select("SELECT status FROM onlineshops_tasks WHERE shop_id=$id AND command='$command'");
|
||
|
|
||
|
if($status === 'running'){
|
||
|
$this->app->Tpl->Add('MESSAGE', '<div class="info">{|Anzahl abzuholender Artikel wird ermittelt|}.</div>');
|
||
|
}else{
|
||
|
$this->app->Tpl->Add('MESSAGE', '<div class="info">{|Aufgabe wurde zu Shoptasks hinzugefügt und wird im Hintergrund ausgeführt|}.</div>');
|
||
|
}
|
||
|
}
|
||
|
else {
|
||
|
$ret = $this->app->remote->RemoteCommand($id,'getarticlelist');
|
||
|
if($ret) {
|
||
|
$anz = 0;
|
||
|
if(isset($ret['errors']) && $ret['errors']) {
|
||
|
if(is_array($ret['errors'])) {
|
||
|
$this->app->Tpl->Add('MESSAGE', '<div class="error">'.implode('<br />',$ret['errors']).'</div>');
|
||
|
}
|
||
|
else {
|
||
|
$this->app->Tpl->Add('MESSAGE', '<div class="error">'.$ret['errors'].'</div>');
|
||
|
}
|
||
|
}
|
||
|
else{
|
||
|
foreach($ret as $v) {
|
||
|
$anz++;
|
||
|
$this->app->DB->Insert("INSERT INTO shopexport_getarticles (shop, nummer) VALUES ('$id', '".$this->app->DB->real_escape_string($v)."')");
|
||
|
}
|
||
|
if(!$this->app->DB->Select("SELECT id FROM `prozessstarter` WHERE aktiv = 1 AND parameter = 'getarticles' LIMIT 1")) {
|
||
|
$this->app->DB->Update("UPDATE `prozessstarter` SET aktiv = 1 WHERE parameter = 'getarticles' LIMIT 1");
|
||
|
}
|
||
|
$this->app->DB->Update("UPDATE `prozessstarter` SET letzteausfuerhung = DATE_SUB(now(), INTERVAL periode MINUTE) WHERE aktiv = 1 AND parameter = 'getarticles' AND mutex = 0 LIMIT 1");
|
||
|
$this->app->Tpl->Add('MESSAGE', '<div class="info">'.$anz.' {|Artikel gefunden. Diese werden im Hintergrund importiert.|}</div>');
|
||
|
}
|
||
|
$this->app->erp->SetKonfigurationValue('artikelimportanzahl_'.$id, $anz);
|
||
|
unset($ret);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// $this->app->erp->SetKonfigurationValue('artikelimportanzahl_'.$id, $anz);
|
||
|
|
||
|
|
||
|
/*
|
||
|
$ret = $this->app->remote->RemoteCommand($id,"getarticlelist");
|
||
|
if($ret)
|
||
|
{
|
||
|
$anz = 0;
|
||
|
if(isset($ret['errors']) && $ret['errors'])
|
||
|
{
|
||
|
if(is_array($ret['errors']))
|
||
|
{
|
||
|
$this->app->Tpl->Add('MESSAGE', '<div class="error">'.implode('<br />',$ret['errors']).'</div>');
|
||
|
}else
|
||
|
{
|
||
|
$this->app->Tpl->Add('MESSAGE', '<div class="error">'.$ret['errors'].'</div>');
|
||
|
}
|
||
|
}else{
|
||
|
foreach($ret as $v)
|
||
|
{
|
||
|
$anz++;
|
||
|
$this->app->DB->Insert("INSERT INTO shopexport_getarticles (shop, nummer) VALUES ('$id', '".$this->app->DB->real_escape_string($v)."')");
|
||
|
}
|
||
|
if(!$this->app->DB->Select("SELECT id FROM `prozessstarter` WHERE aktiv = 1 AND parameter = 'getarticles' LIMIT 1"))$this->app->DB->Update("UPDATE `prozessstarter` SET aktiv = 1 WHERE parameter = 'getarticles' LIMIT 1");
|
||
|
$this->app->DB->Update("UPDATE `prozessstarter` SET letzteausfuerhung = DATE_SUB(now(), INTERVAL periode MINUTE) WHERE aktiv = 1 AND parameter = 'getarticles' AND mutex = 0 LIMIT 1");
|
||
|
$this->app->Tpl->Add('MESSAGE', '<div class="info">'.$anz.' {|Artikel gefunden. Diese werden im Hintergrund importiert.|}</div>');
|
||
|
}
|
||
|
$this->app->erp->SetKonfigurationValue('artikelimportanzahl_'.$id, $anz);
|
||
|
unset($ret);
|
||
|
}
|
||
|
*/
|
||
|
|
||
|
}
|
||
|
|
||
|
if($this->app->Secure->GetGET('action') === 'create') {
|
||
|
$field = new HTMLInput("versandartenmapping","checkbox",1,'','','','','checked');
|
||
|
$this->form->NewField($field);
|
||
|
$field = new HTMLInput("zahlungsweisenmapping","checkbox",1,'','','','','checked');
|
||
|
$this->form->NewField($field);
|
||
|
$field = new HTMLInput("artikeltexteuebernehmen","checkbox",1,'','','','','checked');
|
||
|
$this->form->NewField($field);
|
||
|
$field = new HTMLInput("artikelimport","checkbox",1,'','','','','checked');
|
||
|
$this->form->NewField($field);
|
||
|
}else{
|
||
|
if($this->app->Secure->GetPOST('speichern'))
|
||
|
{
|
||
|
$this->app->erp->StartChangeLog('shopexport');
|
||
|
$altedaten = $this->app->DB->SelectArr("SELECT * FROM shopexport WHERE aktiv = 0 AND (shoptyp = 'intern' OR shoptyp = 'custom') AND modulename <> '' AND id = '$id' LIMIT 1");
|
||
|
$altedaten2 = $this->app->DB->SelectArr("SELECT * FROM shopexport WHERE id = '$id' LIMIT 1");
|
||
|
if(true || $this->form->CallbackAndMandatorycheck(true))
|
||
|
{
|
||
|
$data = $this->app->DB->SelectArr("SELECT * FROM shopexport WHERE id = '$id' LIMIT 1");
|
||
|
if($data)$data = reset($data);
|
||
|
/*$bezeichnung = $this->app->Secure->GetPOST('frm_bezeichnung');
|
||
|
//$this->app->DB->Update("UPDATE shopexport SET bezeichnung = '$bezeichnung' WHERE id = '$id' LIMIT 1");
|
||
|
$projekt = (String)reset(explode(' ',$this->app->Secure->GetPOST('frm_projekt')));
|
||
|
if($projekt !== '')
|
||
|
{
|
||
|
$projekt = $this->app->DB->Select("SELECT id FROM projekt WHERE abkuerzung <> '' AND abkuerzung = '".$projekt."' ORDER BY geloescht LIMIT 1");
|
||
|
}
|
||
|
$this->app->DB->Update("UPDATE shopexport SET projekt = '$projekt' WHERE id = '$id' LIMIT 1");*/
|
||
|
if($this->app->Secure->GetPOST('modulename') != $altedaten2[0]['modulename'])
|
||
|
{
|
||
|
$modulename = $this->app->Secure->GetPOST('modulename');
|
||
|
if($modulename == '')
|
||
|
{
|
||
|
$this->app->DB->Update("UPDATE shopexport SET shoptyp = 'extern' WHERE id = '$id' LIMIT 1");
|
||
|
$data['shoptyp'] = 'extern';
|
||
|
}else
|
||
|
{
|
||
|
$found = false;
|
||
|
$obj = $this->app->erp->LoadModul('onlineshops');
|
||
|
$modulesel = array(''=>'Extern');
|
||
|
if($obj)
|
||
|
{
|
||
|
$module = $obj->getApps();
|
||
|
if(isset($module['installiert']))
|
||
|
{
|
||
|
foreach($module['installiert'] as $k => $v)
|
||
|
{
|
||
|
if(strpos($v['key'],'shopimporter_') !== 0)continue;
|
||
|
if($v['key'] == $modulename)
|
||
|
{
|
||
|
$this->app->DB->Update("UPDATE shopexport SET shoptyp = 'intern' WHERE id = '$id' LIMIT 1");
|
||
|
$data['shoptyp'] = 'intern';
|
||
|
$found = true;
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
$einzelnabholen = $this->app->Secure->GetPOST('einzelnabholen');
|
||
|
$inwarteschlange = $this->app->Secure->GetPOST('inwarteschlange');
|
||
|
$modus = $this->app->Secure->GetPOST('modus');
|
||
|
$abholmodus = $this->app->Secure->GetPOST('abholmodus');
|
||
|
$vondatum = (String)$this->app->Secure->GetPOST('vondatum');
|
||
|
$vonzeit = (String)$this->app->Secure->GetPOST('vonzeit');
|
||
|
$this->form->HTMLList['datumvon']->htmlvalue = '0000-00-00 00:00:00';
|
||
|
$this->form->HTMLList['datumvon']->dbvalue = '0000-00-00 00:00:00';
|
||
|
if($vondatum !== '')
|
||
|
{
|
||
|
$this->form->HTMLList['datumvon']->htmlvalue = $this->app->String->Convert($vondatum, '%1.%2.%3', '%3-%2-%1');
|
||
|
if($vonzeit !== '')$this->form->HTMLList['datumvon']->htmlvalue = $this->form->HTMLList['datumvon']->htmlvalue.' '.$vonzeit.':00';
|
||
|
$this->form->HTMLList['datumvon']->dbvalue = $this->form->HTMLList['datumvon']->htmlvalue;
|
||
|
}
|
||
|
|
||
|
if($abholmodus !== 'zeitbereich' && $this->app->Secure->GetPOST('maxmanuell') == 1)
|
||
|
{
|
||
|
$this->form->HTMLList['einzelsync']->dbvalue = 1;
|
||
|
$this->form->HTMLList['einzelsync']->htmlvalue = 1;
|
||
|
}
|
||
|
|
||
|
/*switch($abholmodus)
|
||
|
{
|
||
|
case 'ab_nummer':
|
||
|
$this->app->DB->Update("UPDATE shopexport SET holealle = 1, anzgleichzeitig = 0 WHERE id = '$id' LIMIT 1");
|
||
|
break;
|
||
|
case 'zeitbereich':
|
||
|
$this->app->DB->Update("UPDATE shopexport SET anzgleichzeitig = 50 WHERE id = '$id' AND anzgleichzeitig < 2 LIMIT 1");
|
||
|
break;
|
||
|
default:
|
||
|
$this->app->DB->Update("UPDATE shopexport SET holealle = 0, anzgleichzeitig = 0 WHERE id = '$id' LIMIT 1");
|
||
|
break;
|
||
|
}*/
|
||
|
|
||
|
$aktivhaken = $this->app->Secure->GetPOST('aktivhaken');
|
||
|
$frmarr = array('ab_nummer','holeallestati','datumvon','datumbis','nummersyncstatusaendern');
|
||
|
//foreach($frmarr as $v)$this->app->DB->Update("UPDATE shopexport SET $v = '".$this->app->Secure->GetPOST($v)."' WHERE id = '$id' LIMIT 1");
|
||
|
switch($modus)
|
||
|
{
|
||
|
case 'demomodus':
|
||
|
//$this->app->DB->Update("UPDATE shopexport SET demomodus = 1 WHERE id = '$id' LIMIT 1");
|
||
|
//$this->app->DB->Update("UPDATE shopexport SET cronjobaktiv = 0 WHERE id = '$id' LIMIT 1");
|
||
|
break;
|
||
|
case 'manuell':
|
||
|
//$this->app->DB->Update("UPDATE shopexport SET demomodus = 0 WHERE id = '$id' LIMIT 1");
|
||
|
//$this->app->DB->Update("UPDATE shopexport SET cronjobaktiv = 0 WHERE id = '$id' LIMIT 1");
|
||
|
break;
|
||
|
case 'automatisch':
|
||
|
//$this->app->DB->Update("UPDATE shopexport SET demomodus = 0 WHERE id = '$id' LIMIT 1");
|
||
|
//$this->app->DB->Update("UPDATE shopexport SET cronjobaktiv = 1 WHERE id = '$id' LIMIT 1");
|
||
|
if(!$this->app->DB->Select("SELECT id FROM `prozessstarter` WHERE parameter = 'shopimport' AND aktiv = 1"))
|
||
|
{
|
||
|
if($this->app->DB->Select("SELECT id FROM `prozessstarter` WHERE parameter = 'shopimport' AND aktiv = 0"))
|
||
|
{
|
||
|
$this->app->DB->Update("UPDATE `prozessstarter` SET aktiv = 1 WHERE parameter = 'shopimport' LIMIT 1");
|
||
|
}else{
|
||
|
$this->app->erp->CheckProzessstarter("Shopimporter","periodisch","15","2017-01-01 00:00:00","cronjob","shopimport",1);
|
||
|
}
|
||
|
}
|
||
|
break;
|
||
|
}
|
||
|
/*
|
||
|
if($einzelnabholen)
|
||
|
{
|
||
|
$this->app->DB->Update("UPDATE shopexport SET einzelsync = 1 WHERE id = '$id' LIMIT 1");
|
||
|
}else{
|
||
|
$this->app->DB->Update("UPDATE shopexport SET einzelsync = 0 WHERE id = '$id' LIMIT 1");
|
||
|
}
|
||
|
if($inwarteschlange)
|
||
|
{
|
||
|
$this->app->DB->Update("UPDATE shopexport SET direktimport = 0 WHERE id = '$id' LIMIT 1");
|
||
|
}else{
|
||
|
$this->app->DB->Update("UPDATE shopexport SET direktimport = 1 WHERE id = '$id' LIMIT 1");
|
||
|
}*/
|
||
|
if($data['shoptyp'] !== 'custom')
|
||
|
{
|
||
|
$this->app->DB->Update("UPDATE shopexport SET aktiv = '$aktivhaken' WHERE id = '$id' LIMIT 1");
|
||
|
}else{
|
||
|
$this->app->DB->Update("UPDATE shopexport SET aktiv = '0' WHERE id = '$id' LIMIT 1");
|
||
|
$data['modulename'] = trim($data['modulename'],'.');
|
||
|
if($data['modulename'] !== '')
|
||
|
{
|
||
|
$file = __DIR__ .'/../plugins/external/shopimporter/'.$data['modulename'];
|
||
|
if(is_file($file))
|
||
|
{
|
||
|
include_once($file);
|
||
|
$this->app->DB->Update("UPDATE shopexport SET aktiv = '$aktivhaken' WHERE id = '$id' LIMIT 1");
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
$err = null;
|
||
|
if($altedaten && $this->app->Secure->GetPOST('aktiv') && method_exists($this->app->erp, 'OnlineshopsLizenzFehler'))
|
||
|
{
|
||
|
if($err = $this->app->erp->OnlineshopsLizenzFehler($data['modulename']))
|
||
|
{
|
||
|
$this->app->DB->Update("UPDATE shopexport SET aktiv = '0' WHERE id = '$id' LIMIT 1");
|
||
|
$this->form->HTMLList['aktiv']->dbvalue = 0;
|
||
|
$this->form->HTMLList['aktiv']->htmlvalue = 0;
|
||
|
$this->app->User->SetParameter('shopexport_meldung', '<div class="error">'.$err['Error'].'</div>');
|
||
|
}
|
||
|
}
|
||
|
$this->app->erp->RunHook('shopexport_speichern',1, $id);
|
||
|
}
|
||
|
}else
|
||
|
{
|
||
|
$meldung = $this->app->User->GetParameter('shopexport_meldung');
|
||
|
if($meldung <> '')
|
||
|
{
|
||
|
$this->app->User->SetParameter('shopexport_meldung','');
|
||
|
$this->app->Tpl->Set('MESSAGE', $meldung);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$this->app->erp->RunHook('shopexport_widget', 1, $id);
|
||
|
|
||
|
$this->app->Tpl->Set('ID', $id);
|
||
|
$data = $this->app->DB->SelectRow(
|
||
|
sprintf(
|
||
|
'SELECT * FROM shopexport WHERE id = %d LIMIT 1', $id
|
||
|
)
|
||
|
);
|
||
|
if($data['aktiv'])
|
||
|
{
|
||
|
//$this->app->Tpl->Set('AKTIVHAKEN', ' checked="checked" ');
|
||
|
}else{
|
||
|
|
||
|
}
|
||
|
if($data['projekt'])
|
||
|
{
|
||
|
//$this->app->Tpl->Set('FRM_PROJEKT', $this->app->DB->Select("SELECT abkuerzung FROM projekt WHERE id = '".$data['projekt']."' LIMIT 1"));
|
||
|
}
|
||
|
//$this->app->YUI->AutoComplete('projekt',"projektname", 1);
|
||
|
//$this->app->Tpl->Set('FRM_BEZEICHNUNG', $data['bezeichnung']);
|
||
|
if($data['demomodus'])
|
||
|
{
|
||
|
$status = 'demomodus';
|
||
|
}elseif($data['cronjobaktiv'])
|
||
|
{
|
||
|
$status = 'automatisch';
|
||
|
}else{
|
||
|
$status = 'manuell';
|
||
|
}
|
||
|
|
||
|
if($data['anzgleichzeitig'] > 1)
|
||
|
{
|
||
|
$abbholstatus = 'zeitbereich';
|
||
|
}elseif($data['holealle']){
|
||
|
$abbholstatus = 'ab_nummer';
|
||
|
}else{
|
||
|
$abbholstatus = 'status';
|
||
|
}
|
||
|
if($data['datumvon'] !== '0000-00-00 00:00:00')
|
||
|
{
|
||
|
$vondatum = $this->app->String->Convert($data['datumvon'],'%1-%2-%3 %4:%5:%6', '%3.%2.%1');
|
||
|
$vonzeit = $this->app->String->Convert($data['datumvon'],'%1-%2-%3 %4:%5:%6', '%4:%5');
|
||
|
}else{
|
||
|
$vonzeit = '';
|
||
|
$vondatum = '';
|
||
|
}
|
||
|
$field = new HTMLInput('vonzeit','text',$vonzeit,'10','','','','');
|
||
|
$this->form->NewField($field);
|
||
|
$field = new HTMLInput('vondatum','text',$vondatum,'12','','','','');
|
||
|
$this->form->NewField($field);
|
||
|
$this->app->YUI->HideFormular('abholmodus',array('status'=>'ab_nummer zeitraum','ab_nummer'=>'zeitraum','zeitbereich'=>'ab_nummer manuellebegrenzung'));
|
||
|
//$this->app->YUI->HideFormular('abholmodus',array('status'=>'dummy','zeitbereich'=>'manuellebegrenzung'));
|
||
|
|
||
|
//$this->app->Tpl->Set('CBINWARTESCHLANGE', '<input type="checkbox" name="inwarteschlange" value="1" [INWARTESCHLANGE] />');
|
||
|
|
||
|
//if($data['holeallestati'])$this->app->Tpl->Set('HOLEALLESTATI',' checked="checked" ');
|
||
|
//if($data['nummersyncstatusaendern'])$this->app->Tpl->Set('NUMMERSYNCSTATUSAENDERN',' checked="checked" ');
|
||
|
$this->app->Tpl->Set('AB_NUMMER', $data['ab_nummer']);
|
||
|
$this->app->Tpl->Set('DATUMVON', $data['datumvon']);
|
||
|
$this->app->Tpl->Set('DATUMBIS', $data['datumbis']);
|
||
|
$this->app->Tpl->Add('AKTIONBUTTONS','<tr><td><a href="index.php?module=shopimport&action=import"><input type="button" class="aktionbutton btnzwischentabelle" value="{|Shopimport Zwischentabelle|}"></a></td></tr>');
|
||
|
$this->app->YUI->HideFormular('modulename', [''=>'trstartderschnittstelle','shopimporter_amazon' => 'dummy','shopimporter_shopify'=>'dummy']);
|
||
|
$this->app->YUI->HideFormular('ueberschreibe_lagerkorrekturwert',['checked'=>'dummy','unchecked'=>'lagerkorrektur']);
|
||
|
$tab = 10;
|
||
|
switch($data['shoptyp'])
|
||
|
{
|
||
|
case 'intern':
|
||
|
$this->app->Tpl->Set('SHOPTYP', 'Intern');
|
||
|
break;
|
||
|
case 'custom':
|
||
|
$this->app->Tpl->Set('SHOPTYP', 'Custom');
|
||
|
$data['modulename'] = trim($data['modulename'],'.');
|
||
|
$this->app->Tpl->Set('DATEINAME',$data['modulename']);
|
||
|
$file = __DIR__ .'/../plugins/external/shopimporter/'.$data['modulename'];
|
||
|
if(is_file($file))$this->app->Tpl->Set('CUSTOMDATEI', htmlspecialchars(file_get_contents($file)));
|
||
|
$this->app->Tpl->Add('HOOKLITABS','<li><a href="#tabs-9">Custom</a></li>');
|
||
|
|
||
|
$this->app->Tpl->Parse('HOOKTABS','shopexport_datei.tpl');
|
||
|
$tab++;
|
||
|
|
||
|
break;
|
||
|
default:
|
||
|
$this->app->Tpl->Set('SHOPTYP', 'Extern');
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
$struktur = null;
|
||
|
if($data['shoptyp'] === 'intern' || ($data['shoptyp'] === 'custom' && $data['aktiv']))
|
||
|
{
|
||
|
if($data['modulename'] !== '')
|
||
|
{
|
||
|
$obj = null;
|
||
|
if($data['shoptyp'] === 'intern')
|
||
|
{
|
||
|
$obj = $this->app->erp->LoadModul($data['modulename']);
|
||
|
}else{
|
||
|
$file = __DIR__ .'/../plugins/external/shopimporter/'.$data['modulename'];
|
||
|
if(is_file($file))
|
||
|
{
|
||
|
include_once($file);
|
||
|
$classa = explode('_',str_replace('_'.$id.'.php','', $data['modulename']));
|
||
|
foreach($classa as $k => $v)$classa[$k] = ucfirst($v);
|
||
|
$class = implode('_', $classa);
|
||
|
$obj = new $class($this->app, true);
|
||
|
}
|
||
|
}
|
||
|
if($obj)
|
||
|
{
|
||
|
$this->ShowExtraeinstellungen($id, $obj, 'EXTRAEINSTELLUNGEN', $struktur);
|
||
|
$this->app->erp->RunHook('shopexport_show', 3, $id, $obj, $tab);
|
||
|
$shopCapabilities = ShopimporterBase::shopCapabilities();
|
||
|
if(
|
||
|
!empty($shopCapabilities[$data['modulename']])
|
||
|
&& !empty($shopCapabilities[$data['modulename']]['kategoriebaum'])
|
||
|
&& $shopCapabilities[$data['modulename']]['kategoriebaum']['updatearticle'] === ShopimporterBase::CAN
|
||
|
) {
|
||
|
$this->showCategoryTree($id, $tab);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}else{
|
||
|
$this->app->Tpl->Set('VOREXTRA', '<!--');
|
||
|
$this->app->Tpl->Set('NACHEXTRA', '-->');
|
||
|
}
|
||
|
}
|
||
|
elseif($data['shoptyp'] === 'custom') {
|
||
|
$this->app->Tpl->Set('EXTRAEINSTELLUNGEN','<tr><td></td><td style="color:red;">Für weitere Einstellungen den Importer aktivieren</td></tr>');
|
||
|
}else{
|
||
|
$this->app->Tpl->Set('VOREXTRA', '<!--');
|
||
|
$this->app->Tpl->Set('NACHEXTRA', '-->');
|
||
|
}
|
||
|
|
||
|
$statusarr = array('demomodus'=>'{|Demo (zum Testen)|}','manuell'=>'{|Manuell (mit Importzentrale)|}','automatisch'=>'{|Automatisch (per Prozessstarter)|}');
|
||
|
$abholarr = array('status'=>'{|nach Status|}','ab_nummer'=>'{|ab Nummer|}','zeitbereich'=>'{|ab Datum|}');
|
||
|
|
||
|
if($struktur && isset($struktur['ausblenden']))
|
||
|
{
|
||
|
if(isset($struktur['ausblenden']['abholmodus']) && is_array($struktur['ausblenden']['abholmodus']))
|
||
|
{
|
||
|
foreach($struktur['ausblenden']['abholmodus'] as $k)unset($abholarr[$k]);
|
||
|
}
|
||
|
}
|
||
|
$this->app->Tpl->Add('SELABHOLMODUS','<select id="abholmodus" name="abholmodus" onchange="changeabholmodus(this);">');
|
||
|
foreach($abholarr as $k => $v)
|
||
|
{
|
||
|
$this->app->Tpl->Add('SELABHOLMODUS','<option value="'.$k.'"'.($k == $abbholstatus?' selected="selected" ':'').'>'.$v.'</option>');
|
||
|
}
|
||
|
$this->app->Tpl->Add('SELABHOLMODUS','</select>');
|
||
|
$this->app->Tpl->Add('SELMODUS','<select id="modus" name="modus" onchange="changemodus(this);">');
|
||
|
foreach($statusarr as $k => $v)
|
||
|
{
|
||
|
$this->app->Tpl->Add('SELMODUS','<option value="'.$k.'"'.($k == $status?' selected="selected" ':'').'>'.$v.'</option>');
|
||
|
}
|
||
|
$this->app->Tpl->Add('SELMODUS','</select>');
|
||
|
|
||
|
$this->app->Tpl->Set('WARTESCHLANGE','<input type="checkbox" value="1" id="warteschlange" '.($data['direktimport']?'':' checked="checked" ').' onchange="changedirektimport(this);" />');
|
||
|
/*if(!$data['direktimport'])
|
||
|
{
|
||
|
$this->app->Tpl->Set('INWARTESCHLANGE', ' checked="checked" ');
|
||
|
}*/
|
||
|
/*
|
||
|
if($data['einzelsync'])
|
||
|
{
|
||
|
$this->app->Tpl->Set('EINZELNABHOLEN', ' checked="checked" ');
|
||
|
}*/
|
||
|
|
||
|
|
||
|
//$this->app->Tpl->Parse('TAB1', 'shopexport_detail.tpl');
|
||
|
|
||
|
$json = $data['json'];
|
||
|
if($json)
|
||
|
{
|
||
|
$json = @json_decode($json, true);
|
||
|
if($json && is_array($json))
|
||
|
{
|
||
|
|
||
|
if(isset($json['erlaubtefunktionen']))
|
||
|
{
|
||
|
if(isset($json['erlaubtefunktionen']['rabattartikel']) && !$json['erlaubtefunktionen']['rabattartikel'])
|
||
|
{
|
||
|
$this->app->Tpl->Add('MSGARTIKELRABATT',' <b style="color:red;">wird von diesem Importer nicht unterstützt</b> ');
|
||
|
}
|
||
|
if(isset($json['erlaubtefunktionen']['zeitbereich']) && !$json['erlaubtefunktionen']['zeitbereich'])
|
||
|
{
|
||
|
$this->app->Tpl->Add('MSGANZGLEICHZEITIG',' <b style="color:red;">wird von diesem Importer nicht unterstützt</b> ');
|
||
|
}
|
||
|
if(isset($json['erlaubtefunktionen']['auftragabnummer']) && !$json['erlaubtefunktionen']['auftragabnummer'])
|
||
|
{
|
||
|
$this->app->Tpl->Add('MSGHOLEALLE',' <b style="color:red;">wird von diesem Importer nicht unterstützt</b> ');
|
||
|
}
|
||
|
if(isset($json['erlaubtefunktionen']['eigenschaften']) && !$json['erlaubtefunktionen']['eigenschaften'])
|
||
|
{
|
||
|
$this->app->Tpl->Add('MSGEIGENSCHAFTENUEBERTRAGEN',' <b style="color:red;">wird von diesem Importer nicht unterstützt</b> ');
|
||
|
}
|
||
|
if(isset($json['erlaubtefunktionen']['artikelbilder']) && !$json['erlaubtefunktionen']['artikelbilder'])
|
||
|
{
|
||
|
$this->app->Tpl->Add('MSGSHOPBILDERUEBERTRAGEN',' <b style="color:red;">wird von diesem Importer nicht unterstützt</b> ');
|
||
|
}
|
||
|
if(isset($json['erlaubtefunktionen']['kategorien']) && !$json['erlaubtefunktionen']['kategorien'])
|
||
|
{
|
||
|
$this->app->Tpl->Add('MSGKATEGORIENUEBERTRAGEN',' <b style="color:red;">wird von diesem Importer nicht unterstützt</b> ');
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
if($this->app->erp->RechteVorhanden('shopexport','artikeluebertragen')){
|
||
|
$this->app->Tpl->Add('AKTIONBUTTONS', '<tr><td><a href="index.php?module=shopexport&action=artikeluebertragung&id=' . $id . '"><input type="button" class="aktionbutton" value="{|Artikel übertragen|}"></a></td></tr>');
|
||
|
}
|
||
|
if($struktur && isset($struktur['functions']) && is_array($struktur['functions']) && in_array('exportartikelbaum',$struktur['functions']))
|
||
|
{
|
||
|
$this->app->Tpl->Add('AKTIONBUTTONS','<tr><td><a href="#" onclick="artikelbaumexport();"><input type="button" class="aktionbutton" value="Artikelbaum übertragen"></a></td></tr>');
|
||
|
}
|
||
|
if($struktur && isset($struktur['functions']) && is_array($struktur['functions']) && in_array('getarticlelist',$struktur['functions']))
|
||
|
{
|
||
|
$anzahl = $this->app->DB->Select("SELECT COUNT(id) FROM shopexport_getarticles WHERE shop = '$id' AND nummer <> ''");
|
||
|
if($anzahl > 0)
|
||
|
{
|
||
|
$this->app->Tpl->Add('VORFORMULAR','
|
||
|
<form action="" method="post" id="frmresetgetarticlelist">
|
||
|
<input type="hidden" name="resetgetarticlelist" value="1" />
|
||
|
</form>
|
||
|
');
|
||
|
$gesamtAnzahlAbgeholteArtikel = $this->app->erp->GetKonfiguration('artikelimportanzahl_'.$id);
|
||
|
$anzahlstring = '('.$anzahl.' von '.$gesamtAnzahlAbgeholteArtikel.')';
|
||
|
$this->app->Tpl->Add('AKTIONBUTTONS','<tr><td><a href="#" onclick="$(\'#frmresetgetarticlelist\').submit();"><input type="button" class="aktionbutton" value="Artikel abholen abbrechen '.$anzahlstring.'"></a></td></tr>');
|
||
|
}else {
|
||
|
$buttoninfo = '';
|
||
|
if(!empty($struktur['buttoninfo']) && !empty($struktur['buttoninfo']['getarticlelist']))
|
||
|
{
|
||
|
$buttoninfo = $struktur['buttoninfo']['getarticlelist'];
|
||
|
}
|
||
|
$this->app->Tpl->Add('VORFORMULAR','
|
||
|
<form action="" method="post" id="frmgetarticlelist">
|
||
|
<input type="hidden" name="getarticlelist" value="1" />
|
||
|
</form>
|
||
|
');
|
||
|
$this->app->Tpl->Add('AKTIONBUTTONS','<tr><td><a href="#" onclick="$(\'#frmgetarticlelist\').submit();"><input type="button" class="aktionbutton" value="{|Artikelliste abholen|}'.$buttoninfo.'"></a></td></tr>');
|
||
|
}
|
||
|
}else{
|
||
|
$this->app->Tpl->Set('NURARTIKELLISTESTYLE',' style="display:none;" ');
|
||
|
}
|
||
|
if($struktur && isset($struktur['archiv']) && is_array($struktur['archiv']))
|
||
|
{
|
||
|
if($this->app->DB->Select("SELECT id FROM shopexport_archiv WHERE shop='$id' AND status = 'aktiv' LIMIT 1"))
|
||
|
{
|
||
|
$this->app->Tpl->Add('VORFORMULAR','
|
||
|
<form action="" method="post" id="frmresetarchiv">
|
||
|
<input type="hidden" name="resetarchiv" value="1" />
|
||
|
</form>
|
||
|
');
|
||
|
$this->app->Tpl->Add('AKTIONBUTTONS','<tr><td><a href="#" onclick="$(\'#frmresetarchiv\').submit();"><input type="button" class="aktionbutton" value="{|Alte Aufträge abholen abbrechen|}"></a></td></tr>');
|
||
|
}else{
|
||
|
if(in_array('zeitraum', $struktur['archiv']))
|
||
|
{
|
||
|
$this->app->Tpl->Set('ARCHIVTYP', 'Zeitraum');
|
||
|
$this->app->Tpl->Set('ARCHIVTYPVAL', 'zeitraum');
|
||
|
$this->app->YUI->DatePicker('archiv_von');
|
||
|
$this->app->YUI->DatePicker('archiv_bis');
|
||
|
$this->app->YUI->TimePicker('archiv_zeitvon');
|
||
|
$this->app->YUI->TimePicker('archiv_zeitbis');
|
||
|
}elseif(in_array('ab_nummer', $struktur['archiv'])){
|
||
|
$this->app->Tpl->Set('ARCHIVTYP', 'Nummer');
|
||
|
$this->app->Tpl->Set('ARCHIVTYPVAL', 'ab_nummer');
|
||
|
$this->app->Tpl->Set('ARCHIVZEITSTYPE','display:none;');
|
||
|
}
|
||
|
$this->app->Tpl->Parse('VORFORMULAR', 'shopexport_archiv.tpl');
|
||
|
$this->app->Tpl->Add('AKTIONBUTTONS','<tr><td><a href="#" onclick="$(\'#popuparchiv\').dialog(\'open\');"><input type="button" class="aktionbutton" value="{|Alte Aufträge importieren|}"></a></td></tr>');
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
$this->app->YUI->HideFormular('artikelimport',array('unchecked'=>'dummy','checked'=>'hinweisartikelimport'));
|
||
|
$this->app->YUI->HideFormular('cronjobaktiv',array('unchecked'=>'direktimport','checked'=>'dummy'));
|
||
|
$aktmodule = (String)$this->app->DB->Select("SELECT modulename FROM shopexport WHERE id = '$id' LIMIT 1");
|
||
|
$found = false;
|
||
|
if($aktmodule === '') {
|
||
|
$found = true;
|
||
|
}
|
||
|
$obj = $this->app->erp->LoadModul('onlineshops');
|
||
|
$modulesel = array(''=>'Extern');
|
||
|
if($obj){
|
||
|
$module = $obj->getApps();
|
||
|
if(isset($module['installiert'])){
|
||
|
foreach($module['installiert'] as $k => $v) {
|
||
|
if(strpos($v['key'],'shopimporter_') !== 0) {
|
||
|
continue;
|
||
|
}
|
||
|
if($v['key'] == $aktmodule){
|
||
|
$found = true;
|
||
|
}
|
||
|
$modulesel[$v['key']] = $v['Bezeichnung'].(!empty($v['beta'])?' (Beta)':'');
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
if(!$found)$modulesel[$aktmodule] = 'Custom';
|
||
|
$field = new HTMLSelect("modulename",0);
|
||
|
$field->onchange = 'selectmodule(this);';
|
||
|
//$field->onchange="onchange_typ(this.form.typ.options[this.form.typ.selectedIndex].value);";
|
||
|
$field->AddOptionsSimpleArray($modulesel);
|
||
|
$this->form->NewField($field);
|
||
|
|
||
|
//$this->app->Tpl->Set(DATUM_BUCHUNG,
|
||
|
// "<img src=\"./themes/[THEME]/images/kalender.png\" onclick=\"displayCalendar(document.forms[0].datum,'dd.mm.yyyy',this)\">");
|
||
|
|
||
|
}
|
||
|
|
||
|
function ShowExtraeinstellungen($id, $obj, $target, &$struktur)
|
||
|
{
|
||
|
$target2 = $target.'2';
|
||
|
if(method_exists($obj, 'EinstellungenStruktur'))
|
||
|
{
|
||
|
$r = new ReflectionMethod(get_class($obj), 'EinstellungenStruktur');
|
||
|
$params = $r->getParameters();
|
||
|
$anzargs = count($params);
|
||
|
if($anzargs > 0)
|
||
|
{
|
||
|
$struktur = $obj->EinstellungenStruktur($id);
|
||
|
}else{
|
||
|
$struktur = $obj->EinstellungenStruktur();
|
||
|
}
|
||
|
|
||
|
if(empty($struktur['felder']['category_root_id'])) {
|
||
|
$struktur['felder']['category_root_id'] = [
|
||
|
'typ' => 'hidden',
|
||
|
];
|
||
|
}
|
||
|
if(empty($struktur['felder']['transform_cart_active'])) {
|
||
|
$struktur['felder']['transform_cart_active'] = [
|
||
|
'typ' => 'hidden',
|
||
|
];
|
||
|
$struktur['felder']['transform_cart_data'] = [
|
||
|
'typ' => 'hidden', 'bezeichnung' => '',
|
||
|
];
|
||
|
$struktur['felder']['transform_cart'] = [
|
||
|
'typ' => 'hidden',
|
||
|
];
|
||
|
$struktur['felder']['transform_cart_replace'] = [
|
||
|
'typ' => 'hidden',
|
||
|
];
|
||
|
$struktur['felder']['transform_cart_format'] = [
|
||
|
'typ' => 'hidden',
|
||
|
];
|
||
|
$this->app->YUI->AutoComplete('cart', 'shopimport_auftraege', 1, '&id='.$id);
|
||
|
$this->app->Tpl->Set('SHOPID', $id);
|
||
|
//$this->app->Tpl->Parse('EXTRAEINSTELLUNGEN', 'shopexport_carttransformation.tpl');
|
||
|
}
|
||
|
|
||
|
if($struktur && isset($struktur['erlauben']) && is_array($struktur['erlauben']) && in_array('nurpreise',$struktur['erlauben']))
|
||
|
{
|
||
|
$this->app->Tpl->Set('NURPREISESTYLE','');
|
||
|
}
|
||
|
|
||
|
if($this->app->Secure->GetPOST('speichern'))
|
||
|
{
|
||
|
if(isset($struktur['felder']))
|
||
|
{
|
||
|
$json = array();
|
||
|
$ok = false;
|
||
|
foreach($struktur['felder'] as $name => $val)
|
||
|
{
|
||
|
if(isset($_POST[$name])){
|
||
|
$ok = true;
|
||
|
}
|
||
|
$json['felder'][$name] = $this->app->Secure->GetPOST($name, '','', 1);
|
||
|
if(isset($val['replace']))
|
||
|
{
|
||
|
switch($val['replace'])
|
||
|
{
|
||
|
case 'lieferantennummer':
|
||
|
$json['felder'][$name] = $this->app->erp->ReplaceLieferantennummer(1,$json['felder'][$name],1);
|
||
|
break;
|
||
|
case 'projekt':
|
||
|
$json['felder'][$name] = $this->app->erp->ReplaceProjekt(1,$json['felder'][$name],1);
|
||
|
break;
|
||
|
case 'artikel':
|
||
|
$json['felder'][$name] = $this->app->erp->ReplaceArtikel(1,$json['felder'][$name],1);
|
||
|
break;
|
||
|
case 'preisgruppekennziffer':
|
||
|
$json['felder'][$name] = $this->app->erp->ReplacePreisgruppe(1,$json['felder'][$name],1);
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
if(isset($val['autocomplete']))
|
||
|
{
|
||
|
switch($val['autocomplete'])
|
||
|
{
|
||
|
case 'kunde':
|
||
|
$json['felder'][$name] = $this->app->erp->ReplaceKundennummer(1,$json['felder'][$name],1);
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
$typ = 'text';
|
||
|
if(!empty($val['typ'])){
|
||
|
$typ = $val['typ'];
|
||
|
}
|
||
|
switch($typ) {
|
||
|
case 'datum':
|
||
|
case 'date':
|
||
|
$this->app->YUI->DatePicker($name);
|
||
|
if(isset($json['felder'][$name]) && strpos($json['felder'][$name], '.') !== false) {
|
||
|
$json['felder'][$name] = $this->app->String->Convert($json['felder'][$name],'%3.%2.%1','%1-%2-%3');
|
||
|
}
|
||
|
break;
|
||
|
case 'password':
|
||
|
if($json['felder'][$name] === '***************'){
|
||
|
$oldData = json_decode($this->app->DB->Select('SELECT einstellungen_json FROM shopexport WHERE id='.$id),true);
|
||
|
$json['felder'][$name] = $oldData['felder'][$name];
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
$json_str = $this->app->DB->real_escape_string(json_encode($json));
|
||
|
if(json_decode(json_encode($json),true) && $ok)
|
||
|
{
|
||
|
$this->app->DB->Update("UPDATE shopexport SET einstellungen_json = '$json_str' WHERE id = '".$id."' LIMIT 1");
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
$html = '';
|
||
|
$html2 = '';
|
||
|
$cols1 = null;
|
||
|
$cols2 = null;
|
||
|
$aktcol = null;
|
||
|
$hidden = '';
|
||
|
$json = $this->app->DB->Select("SELECT einstellungen_json FROM shopexport WHERE id = '$id' LIMIT 1");
|
||
|
if($json == '' && isset($struktur['felder']))
|
||
|
{
|
||
|
$json = null;
|
||
|
foreach($struktur['felder'] as $k => $v)
|
||
|
{
|
||
|
if(!empty($v['defaultcreate']))
|
||
|
{
|
||
|
$json['felder'][$k] = $v['defaultcreate'];
|
||
|
}elseif(!empty($v['default']))
|
||
|
{
|
||
|
$json['felder'][$k] = $v['default'];
|
||
|
}
|
||
|
}
|
||
|
$json = json_encode($json);
|
||
|
}
|
||
|
if($json){
|
||
|
$json = json_decode($json, true);
|
||
|
}
|
||
|
$this->app->Tpl->Set(
|
||
|
'TEXTAREASMARTYINCOMMING',
|
||
|
!isset($json['felder']['transform_cart'])?'': htmlspecialchars(trim($json['felder']['transform_cart']))
|
||
|
);
|
||
|
if(!empty($json['felder']['transform_cart_active'])) {
|
||
|
$this->app->Tpl->Set('TRANSFERACTIVE', ' checked="checked" ');
|
||
|
}
|
||
|
if(!empty($json['felder']['transform_cart_replace'])) {
|
||
|
$this->app->Tpl->Set('REPLACECART', ' checked="checked" ');
|
||
|
}
|
||
|
if(!empty($json['felder']['transform_cart_format'])) {
|
||
|
if($json['felder']['transform_cart_format'] === 'xml') {
|
||
|
$this->app->Tpl->Set('OPTIONXML', ' selected="selected" ');
|
||
|
}
|
||
|
elseif($json['felder']['transform_cart_format'] === 'json') {
|
||
|
$this->app->Tpl->Set('OPTIONJSON', ' selected="selected" ');
|
||
|
}
|
||
|
}
|
||
|
if(!is_array($json)) {
|
||
|
$json = ['felder' => []];
|
||
|
}
|
||
|
if(!is_array($json['felder'])) {
|
||
|
$json['felder'] = [];
|
||
|
}
|
||
|
foreach($struktur['felder'] as $name => $val)
|
||
|
{
|
||
|
if(!isset($json['felder'][$name]))
|
||
|
{
|
||
|
if(isset($val['default']))
|
||
|
{
|
||
|
$json['felder'][$name] = $val['default'];
|
||
|
}else{
|
||
|
$json['felder'][$name] = '';
|
||
|
}
|
||
|
}
|
||
|
$typ = 'text';
|
||
|
if(!empty($val['typ'])){
|
||
|
$typ = $val['typ'];
|
||
|
}
|
||
|
if($typ === 'hidden')
|
||
|
{
|
||
|
$hidden .= '<input type="hidden" name="'.$name.'" value="'.(!isset($json['felder'][$name])?'':htmlspecialchars($json['felder'][$name])).'" id="'.$name.'" />';
|
||
|
continue;
|
||
|
}
|
||
|
$aktcol = '';
|
||
|
//$aktcol .= '<tr><td>'.(empty($val['bezeichnung'])?$name:$val['bezeichnung']).'</td><td>';
|
||
|
$aktcol .= '<td>'.(empty($val['bezeichnung'])?$name:$val['bezeichnung']).'</td><td>';
|
||
|
|
||
|
if(isset($val['replace']))
|
||
|
{
|
||
|
switch($val['replace'])
|
||
|
{
|
||
|
case 'lieferantennummer':
|
||
|
$json['felder'][$name] = $this->app->erp->ReplaceLieferantennummer(0,$json['felder'][$name],0);
|
||
|
if($target !== 'return'){
|
||
|
$this->app->YUI->AutoComplete($name, 'lieferant', 1);
|
||
|
}
|
||
|
break;
|
||
|
case 'projekt':
|
||
|
$json['felder'][$name] = $this->app->erp->ReplaceProjekt(0,$json['felder'][$name],0);
|
||
|
if($target !== 'return'){
|
||
|
$this->app->YUI->AutoComplete($name, 'projektname', 1);
|
||
|
}
|
||
|
break;
|
||
|
case 'artikel':
|
||
|
$json['felder'][$name] = $this->app->erp->ReplaceArtikel(0,$json['felder'][$name],0);
|
||
|
if($target !== 'return'){
|
||
|
$this->app->YUI->AutoComplete($name, 'artikelnummer', 1);
|
||
|
}
|
||
|
break;
|
||
|
case 'preisgruppekennziffer':
|
||
|
$json['felder'][$name] = $this->app->erp->ReplacePreisgruppe(0,$json['felder'][$name],0);
|
||
|
if($target !== 'return'){
|
||
|
$this->app->YUI->AutoComplete($name, 'preisgruppekennziffer', 1);
|
||
|
}
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
if(isset($val['autocomplete']))
|
||
|
{
|
||
|
switch($val['autocomplete'])
|
||
|
{
|
||
|
case 'kunde':
|
||
|
$json['felder'][$name] = $this->app->erp->ReplaceKundennummer(0,$json['felder'][$name],0);
|
||
|
$this->app->YUI->AutoComplete($name, 'kunde');
|
||
|
break;
|
||
|
case 'adresse':
|
||
|
$this->app->YUI->AutoComplete($name, 'adresse');
|
||
|
break;
|
||
|
case 'artikel':
|
||
|
$this->app->YUI->AutoComplete($name, 'artikelnummer');
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
switch($typ)
|
||
|
{
|
||
|
case 'textarea':
|
||
|
$aktcol .= '<textarea name="'.$name.'" id="'.$name.'">'.(!isset($json['felder'][$name])?'':htmlspecialchars($json['felder'][$name])).'</textarea>';
|
||
|
break;
|
||
|
case 'checkbox':
|
||
|
$aktcol .= '<input type="checkbox" name="'.$name.'" id="'.$name.'" value="1" '.((isset($json['felder'][$name]) && $json['felder'][$name])?' checked="checked" ':'').' />';
|
||
|
break;
|
||
|
case 'password':
|
||
|
$aktcol .= '<input type="text" name="'.$name.'" id="'.$name.'" value="'.(empty($json['felder'][$name])?'':'***************').'" />';
|
||
|
break;
|
||
|
case 'select':
|
||
|
$aktcol .= '<select name="'.$name.'">';
|
||
|
if(isset($val['optionen']) && is_array($val['optionen']))
|
||
|
{
|
||
|
foreach($val['optionen'] as $k => $v)
|
||
|
{
|
||
|
$aktcol .= '<option value="'.$k.'"'.($k == (isset($json['felder'][$name])?$json['felder'][$name]:'')?' selected="selected" ':'').'>'.$v.'</option>';
|
||
|
}
|
||
|
}
|
||
|
$aktcol .= '</select>';
|
||
|
break;
|
||
|
case 'submit':
|
||
|
if(isset($val['text'])){
|
||
|
$aktcol .= '<form method="POST"><input type="submit" name="'.$name.'" value="'.$val['text'].'"></form>';
|
||
|
}
|
||
|
break;
|
||
|
case 'custom':
|
||
|
if(isset($val['function']))
|
||
|
{
|
||
|
$tmpfunction = $val['function'];
|
||
|
if(method_exists($this, $tmpfunction)){
|
||
|
$aktcol .= $this->$tmpfunction();
|
||
|
}
|
||
|
}
|
||
|
break;
|
||
|
default:
|
||
|
switch($typ) {
|
||
|
case 'datum':
|
||
|
case 'date':
|
||
|
$this->app->YUI->DatePicker($name);
|
||
|
if(isset($json['felder'][$name]) && strpos($json['felder'][$name], '-') !== false) {
|
||
|
$json['felder'][$name] = $this->app->String->Convert($json['felder'][$name],'%1-%2-%3','%3.%2.%1');
|
||
|
}
|
||
|
break;
|
||
|
}
|
||
|
$aktcol .= '<input type="text" '.(empty($val['size'])?'':' size="'.$val['size'].'" ').' name="'.$name.'" id="'.$name.'" value="'.(!isset($json['felder'][$name])?'':htmlspecialchars($json['felder'][$name])).'" />';
|
||
|
break;
|
||
|
}
|
||
|
if(isset($val['vorschlag']) && $val['vorschlag'] != '')
|
||
|
{
|
||
|
$aktcol .= ' <input type="button" value="'.($val['vorschlag_label']!=''?$val['vorschlag_label']:$val['vorschlag']).'" onclick="$(\'#'.$name.'\').val(\''.$val['vorschlag'].'\');" '.(isset($val['minvorschlagsize']) && $val['minvorschlagsize']?' style="min-width:'.$val['minvorschlagsize'].'px;" ':'').' />';
|
||
|
}
|
||
|
if(isset($val['info']) && $val['info']){
|
||
|
$aktcol .= ' <i>'.$val['info'].'</i>';
|
||
|
}
|
||
|
if(isset($val['col']) && $val['col'] == 2)
|
||
|
{
|
||
|
if(isset($val['heading']))
|
||
|
{
|
||
|
$cols2[] = '<td colspan="2"><b>'.$val['heading'].'</b></td>';
|
||
|
}
|
||
|
$cols2[] = $aktcol;
|
||
|
}else{
|
||
|
if(isset($val['heading']))
|
||
|
{
|
||
|
$cols1[] = '<td colspan="2"><b>'.$val['heading'].'</b></td>';
|
||
|
}
|
||
|
$cols1[] = $aktcol;
|
||
|
}
|
||
|
$aktcol .= '</td>';
|
||
|
//$aktcol .= '</td></tr>';
|
||
|
//$htmlname = 'html';
|
||
|
//if(isset($val['col']) && $val['col'] == 2)$htmlname = 'html2';
|
||
|
|
||
|
}
|
||
|
/*if($cols1)
|
||
|
{
|
||
|
foreach($cols1 as $k => $v)
|
||
|
{
|
||
|
$html .= '<tr>'.$cols1[$k].'</tr>';
|
||
|
}
|
||
|
}
|
||
|
if($cols2)
|
||
|
{
|
||
|
$html2 .= '<table>';
|
||
|
foreach($cols2 as $k => $v)
|
||
|
{
|
||
|
$html2 .= '<tr>'.$cols2[$k].'</tr>';
|
||
|
}
|
||
|
$html2 .= '</table>';
|
||
|
}*/
|
||
|
|
||
|
|
||
|
|
||
|
$rows = 0;
|
||
|
if($cols1){
|
||
|
$rows = count($cols1);
|
||
|
}
|
||
|
if($cols2 && count($cols2) > $rows){
|
||
|
$rows = count($cols2);
|
||
|
}
|
||
|
if($rows == 0)
|
||
|
{
|
||
|
$this->app->Tpl->Set('VOREXTRA', '<!--');
|
||
|
$this->app->Tpl->Set('NACHEXTRA', '-->');
|
||
|
}
|
||
|
|
||
|
for($i = 0; $i < $rows; $i++)
|
||
|
{
|
||
|
if($i == 0)
|
||
|
{
|
||
|
$html .= '<tr id="erstezeile">';
|
||
|
}else
|
||
|
{
|
||
|
$html .= '<tr>';
|
||
|
}
|
||
|
if($cols1 && isset($cols1[$i]))
|
||
|
{
|
||
|
$html .= $cols1[$i];
|
||
|
}else{
|
||
|
$html .= '<td> </td><td> </td>';
|
||
|
}
|
||
|
if($cols2 && isset($cols2[$i]))
|
||
|
{
|
||
|
$html .= $cols2[$i];
|
||
|
}else{
|
||
|
$html .= '<td> </td><td> </td>';
|
||
|
}
|
||
|
$html .= '</tr>';
|
||
|
}
|
||
|
$html .= $hidden;
|
||
|
|
||
|
$this->app->Tpl->Parse('TAB9', 'shopexport_smarty.tpl');
|
||
|
if($target === 'return'){
|
||
|
return $html;
|
||
|
}
|
||
|
$this->app->Tpl->Add($target, $html);
|
||
|
$this->app->Tpl->Add($target2, $html2);
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
function ReplaceProjekt($db,$value,$fromform)
|
||
|
{
|
||
|
return $this->app->erp->ReplaceProjekt($db,$value,$fromform);
|
||
|
}
|
||
|
|
||
|
function ReplaceArtikel($db,$value,$fromform)
|
||
|
{
|
||
|
return $this->app->erp->ReplaceArtikel($db,$value,$fromform);
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
function ReplaceDecimal($db,$value,$fromform)
|
||
|
{
|
||
|
//value muss hier vom format ueberprueft werden
|
||
|
|
||
|
return str_replace(",",".",$value);
|
||
|
}
|
||
|
|
||
|
function ReplaceDatum($db,$value,$fromform)
|
||
|
{
|
||
|
//value muss hier vom format ueberprueft werden
|
||
|
$dbformat = 0;
|
||
|
if(strpos($value,'-') > 0) $dbformat = 1;
|
||
|
|
||
|
// wenn ziel datenbank
|
||
|
if($db)
|
||
|
{
|
||
|
if($dbformat) return $value;
|
||
|
else return $this->app->String->Convert($value,"%1.%2.%3","%3-%2-%1");
|
||
|
}
|
||
|
// wenn ziel formular
|
||
|
else
|
||
|
{
|
||
|
if($dbformat) return $this->app->String->Convert($value,"%1-%2-%3","%3.%2.%1");
|
||
|
else return $value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param int|bool $db
|
||
|
* @param int|string $value
|
||
|
* @param int|bool $fromform
|
||
|
*
|
||
|
* @return array|mixed|string|null
|
||
|
*/
|
||
|
public function ReplaceVertrieb($db,$value,$fromform)
|
||
|
{
|
||
|
if(!$fromform) {
|
||
|
$id = $value;
|
||
|
$abkuerzung = $this->app->DB->Select(sprintf("SELECT CONCAT(id, ' ', name) FROM adresse WHERE id=%d AND geloescht=0 LIMIT 1", $id));
|
||
|
}
|
||
|
else {
|
||
|
$abkuerzung = explode(' ', $value);
|
||
|
$id = reset($abkuerzung);
|
||
|
$id = $this->app->DB->Select(sprintf('SELECT id FROM adresse WHERE id = %d AND geloescht=0 LIMIT 1', $id));
|
||
|
}
|
||
|
|
||
|
// wenn ziel datenbank
|
||
|
if($db) {
|
||
|
return $id;
|
||
|
}
|
||
|
// wenn ziel formular
|
||
|
|
||
|
return $abkuerzung;
|
||
|
}
|
||
|
|
||
|
function ReplaceAdresse($db,$value,$fromform)
|
||
|
{
|
||
|
//value muss hier vom format ueberprueft werden
|
||
|
if(!$fromform) {
|
||
|
$id = $value;
|
||
|
$abkuerzung = $this->app->DB->Select("SELECT name FROM adresse WHERE id='$id' AND geloescht=0 LIMIT 1");
|
||
|
}
|
||
|
else {
|
||
|
$abkuerzung = $value;
|
||
|
$id = $this->app->DB->Select("SELECT id FROM adresse WHERE name='$value' AND name <> '' AND geloescht=0 LIMIT 1");
|
||
|
}
|
||
|
|
||
|
// wenn ziel datenbank
|
||
|
if($db) {
|
||
|
return $id;
|
||
|
}
|
||
|
// wenn ziel formular
|
||
|
|
||
|
return $abkuerzung;
|
||
|
}
|
||
|
|
||
|
public function Table()
|
||
|
{
|
||
|
$this->app->YUI->TableSearch('INHALT',"onlineshopslist");
|
||
|
$this->app->Tpl->Parse($this->parsetarget,"rahmen70.tpl");
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
public function Search()
|
||
|
{
|
||
|
//$this->app->Tpl->Set($this->parsetarget,"suchmaske");
|
||
|
//$this->app->Table(
|
||
|
//$table = new OrderTable("veranstalter");
|
||
|
//$table->Heading(array('Name','Homepage','Telefon'));
|
||
|
}
|
||
|
function ReplaceSteuersatz($db,$value,$fromform)
|
||
|
{
|
||
|
if($db)
|
||
|
{
|
||
|
if($value === "" || $value === null)return -1;
|
||
|
return str_replace(',','.', $value);
|
||
|
}else{
|
||
|
if($value < 0)return "";
|
||
|
return $value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
function ReplacePreisgruppe($db,$value,$fromform)
|
||
|
{
|
||
|
//value muss hier vom format ueberprueft werden
|
||
|
$dbformat = 0;
|
||
|
if(!$fromform) {
|
||
|
$dbformat = 1;
|
||
|
$id = $value;
|
||
|
$abkuerzung = $this->app->DB->Select("SELECT CONCAT(kennziffer,' ',name) as name FROM gruppen WHERE id='$id' LIMIT 1");
|
||
|
} else {
|
||
|
$dbformat = 0;
|
||
|
$abkuerzung = $value;
|
||
|
$id = $this->app->DB->Select("SELECT id FROM gruppen WHERE CONCAT(kennziffer,' ',name)='$value' OR (kennziffer='$value' AND kennziffer!='') AND art LIKE 'preisgruppe' LIMIT 1");
|
||
|
if($id <=0) $id=0;
|
||
|
}
|
||
|
|
||
|
// wenn ziel datenbank
|
||
|
if($db)
|
||
|
{
|
||
|
return $id;
|
||
|
}
|
||
|
// wenn ziel formular
|
||
|
else
|
||
|
{
|
||
|
return $abkuerzung;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param int $shopId
|
||
|
* @param string $tab
|
||
|
*/
|
||
|
protected function showCategoryTree($shopId, $tab)
|
||
|
{
|
||
|
$this->app->Tpl->Set('SHOPID', $shopId);
|
||
|
$this->app->Tpl->Add('TAB'.$tab,$this->app->Tpl->OutputAsString('shopexport_tree.tpl'));
|
||
|
$this->app->Tpl->Add('HOOKLITABS','<li><a href="#tabs-'.$tab.'">{|Artikelbaum|}</a></li>');
|
||
|
$this->app->Tpl->Add('HOOKTABS', '<div id="tabs-'.$tab.'">[TAB'.$tab.']</div>');
|
||
|
}
|
||
|
}
|