2021-05-21 08:49:41 +02:00
< ? php
/*
**** COPYRIGHT & LICENSE NOTICE *** DO NOT REMOVE ****
*
* Xentral ( c ) Xentral ERP Sorftware GmbH , Fuggerstrasse 11 , D - 86150 Augsburg , * Germany 2019
*
* This file is licensed under the Embedded Projects General Public License * Version 3.1 .
*
* You should have received a copy of this license from your vendor and / or * along with this file ; If not , please visit www . wawision . de / Lizenzhinweis
* to obtain the text of the corresponding license version .
*
**** END OF COPYRIGHT & LICENSE NOTICE *** DO NOT REMOVE ****
*/
?>
< ? php
use Xentral\Components\Http\RedirectResponse ;
class Shopexport
{
/** @var Application $app */
var $app ;
/**
* Shopexport 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 ( " login " , " ShopexportLogin " );
$this -> app -> ActionHandler ( " main " , " ShopexportMain " );
$this -> app -> ActionHandler ( " list " , " ShopexportList " );
$this -> app -> ActionHandler ( " export " , " ShopexportExport " );
$this -> app -> ActionHandler ( " artikeluebertragung " , " ShopexportArtikeluebertragung " );
$this -> app -> ActionHandler ( " adressuebertragung " , " ShopexportAdressuebertragung " );
$this -> app -> ActionHandler ( " artikeluebertragungdel " , " ShopexportArtikeluebertragungdel " );
$this -> app -> ActionHandler ( " adressuebertragungdel " , " ShopexportAdressuebertragungdel " );
$this -> app -> ActionHandler ( " besuchen " , " ShopexportBesuchen " );
$this -> app -> ActionHandler ( " navigation " , " ShopexportNavigation " );
$this -> app -> ActionHandler ( " logout " , " ShopexportLogout " );
$this -> app -> ActionHandler ( " navigationtab " , " ShopexportNavigationUebersicht " );
$this -> app -> ActionHandler ( " artikelgruppen " , " ShopexportArtikelgruppen " );
$this -> app -> ActionHandler ( " dateien " , " ShopexportDateien " );
$this -> app -> ActionHandler ( " live " , " ShopexportLive " );
$this -> app -> DefaultActionHandler ( " list " );
$this -> app -> ActionHandlerListen ( $app );
}
public function ShopexportList ()
{
$this -> app -> Location -> execute ( 'index.php?module=importvorlage&action=uebersicht' );
}
public function ShopexportLive ()
{
$id = $this -> app -> Secure -> GetGET ( 'id' );
$this -> app -> erp -> Headlines ( 'Navigation' );
$this -> ShopexportMenu ();
$url = $this -> app -> DB -> Select ( " SELECT url FROM shopexport WHERE id=' $id ' LIMIT 1 " );
$this -> app -> Tpl -> Set ( 'ID' , $id );
$this -> app -> Tpl -> Set ( 'URL' , $url );
$this -> app -> Tpl -> Parse ( 'PAGE' , 'shopexport_live.tpl' );
}
public function Install ()
{
$this -> app -> erp -> CheckColumn ( 'namenuebertragen' , 'tinyint(1)' , 'shopexport' , 'DEFAULT -1' );
$this -> app -> erp -> CheckColumn ( 'beschreibunguebertragen' , 'tinyint(1)' , 'shopexport' , 'DEFAULT -1' );
$this -> app -> erp -> CheckColumn ( 'verkaufspreis' , 'tinyint(1)' , 'shopexport' , 'DEFAULT -1' );
$this -> app -> erp -> CheckColumn ( 'staffelpreiseuebertragen' , 'tinyint(1)' , 'shopexport' , 'DEFAULT -1' );
$this -> app -> erp -> CheckColumn ( 'fremdsprachenuebertragen' , 'tinyint(1)' , 'shopexport' , 'DEFAULT -1' );
$this -> app -> erp -> CheckColumn ( 'kategorienanlegen' , 'tinyint(1)' , 'shopexport' , 'DEFAULT -1' );
$this -> app -> erp -> CheckColumn ( 'kategorienbaumuebertragen' , 'tinyint(1)' , 'shopexport' , 'DEFAULT -1' );
$this -> app -> erp -> CheckColumn ( 'eanuebertragen' , 'tinyint(1)' , 'shopexport' , 'DEFAULT -1' );
$this -> app -> erp -> CheckColumn ( 'zolltarifnummeruebertragen' , 'tinyint(1)' , 'shopexport' , 'DEFAULT -1' );
$this -> app -> erp -> CheckColumn ( 'gewichtuebertragen' , 'tinyint(1)' , 'shopexport' , 'DEFAULT -1' );
$this -> app -> erp -> CheckColumn ( 'herstelleruebertragen' , 'tinyint(1)' , 'shopexport' , 'DEFAULT -1' );
$this -> app -> erp -> CheckColumn ( 'matrixeigenschaftenuebertragen' , 'tinyint(1)' , 'shopexport' , 'DEFAULT -1' );
}
protected function CheckEdit ( $id = null , $create = false )
{
if ( $id === null ) {
$id = $this -> app -> Secure -> GetGET ( 'id' );
}
if ( ! is_numeric ( $id ) || $id <= 0 ) {
return ;
}
$shopexportarr = $this -> app -> DB -> SelectRow ( 'SELECT * FROM shopexport WHERE id = ' . $id . ' LIMIT 1' );
if ( empty ( $shopexportarr )) {
return ;
}
if ( $shopexportarr [ 'shoptyp' ] === '' || $shopexportarr [ 'shoptyp' ] === 'extern' ) {
$obj = new ShopimporterBase ();
}
elseif ( $shopexportarr [ 'shoptyp' ] === 'intern' && ! empty ( $shopexportarr [ 'modulename' ])) {
$obj = $this -> app -> erp -> LoadModul ( $shopexportarr [ 'modulename' ]);
}
if ( empty ( $obj ) || ! method_exists ( $obj , 'getArticleExportCapability' )) {
return ;
}
$export = $obj -> getArticleExportCapability ();
foreach ( $export as $k => $v ) {
if ( isset ( $v [ 'field' ]) && $shopexportarr [ $v [ 'field' ]] == - 1 ) {
if ( $create && isset ( $v [ 'defaultoncreate' ])) {
$this -> app -> DB -> Update ( " UPDATE shopexport SET ' " . $v [ 'field' ] . " ' = " . ( int ) $v [ 'defaultoncreate' ] . " WHERE id = ' $id ' LIMIT 1 " );
}
elseif ( isset ( $v [ 'default' ])) {
if ( is_numeric ( $v [ 'default' ])) {
$this -> app -> DB -> Update ( " UPDATE shopexport SET ' " . $v [ 'field' ] . " ' = " . ( int ) $v [ 'default' ] . " WHERE id = ' $id ' LIMIT 1 " );
}
elseif ( isset ( $shopexportarr [ $v [ 'default' ]])) {
$this -> app -> DB -> Update ( " UPDATE shopexport SET ' " . $v [ 'field' ] . " ' = " . ( int ) $shopexportarr [ $v [ 'default' ]] . " WHERE id = ' $id ' LIMIT 1 " );
}
}
else {
$this -> app -> DB -> Update ( " UPDATE shopexport SET ' " . $v [ 'field' ] . " ' = 0 WHERE id = ' $id ' LIMIT 1 " );
}
}
}
}
protected function CheckCreate ( $id = null )
{
$this -> CheckEdit ( $id , true );
}
public function ShopexportNavigationUebersicht ()
{
$id = $this -> app -> Secure -> GetGET ( 'id' );
$this -> app -> erp -> Headlines ( 'Navigation' );
$this -> ShopexportMenu ();
$navexport = $this -> app -> Secure -> GetPOST ( 'navexport' );
$this -> app -> Tpl -> Set ( 'ID' , $id );
$this -> app -> Tpl -> Set ( 'NAVEXPORT' , '<div class="info"> Navigation vom Shop ändern (interne Shop! kein XT & Co.).</div>' );
if ( ! empty ( $navexport )) {
$this -> app -> remote -> RemoteSendArtikelgruppen ( $id );
$anzahl = $this -> app -> remote -> RemoteSendNavigation ( $id );
$this -> app -> erp -> NewEvent ( 'Navigations-Export Online-Shop Nr. ' . $id , 'onlineshop' );
$this -> app -> Tpl -> Set ( 'NAVEXPORT' , '<div class="error">Es wurden ' . $anzahl . ' Navigationen heraufgeladen.</div>' );
}
$this -> app -> Tpl -> Parse ( 'PAGE' , 'shopexport_navigation.tpl' );
}
public function ShopexportArtikelgruppen ()
{
$this -> app -> erp -> Headlines ( 'Artikelgruppen' );
$this -> ShopexportMenu ();
$shop = $this -> app -> Secure -> GetGET ( 'id' );
$edit = $this -> app -> Secure -> GetGET ( 'edit' );
$delete = $this -> app -> Secure -> GetGET ( 'delete' );
$bezeichnung = $this -> app -> Secure -> GetPOST ( 'bezeichnung' );
$bezeichnung_en = $this -> app -> Secure -> GetPOST ( 'bezeichnung_en' );
$beschreibung_de = $this -> app -> Secure -> GetPOST ( 'beschreibung_de' );
$beschreibung_en = $this -> app -> Secure -> GetPOST ( 'beschreibung_en' );
$aktiv = $this -> app -> Secure -> GetPOST ( 'aktiv' );
$submit = $this -> app -> Secure -> GetPOST ( 'anlegen' );
// Edit
if ( is_numeric ( $edit )) {
if ( ! empty ( $submit ) && is_numeric ( $shop )) {
$this -> app -> DB -> Update ( " UPDATE artikelgruppen SET bezeichnung=' $bezeichnung ',
bezeichnung_en = '$bezeichnung_en' ,
beschreibung_de = '$beschreibung_de' ,
beschreibung_en = '$beschreibung_en' ,
shop = '$shop' , aktiv = '$aktiv' WHERE id = '$edit' LIMIT 1 " );
$this -> app -> Location -> execute ( 'index.php?module=shopexport&action=artikelgruppen&id=' . $shop . '#tabs-1' );
}
$data = $this -> app -> DB -> SelectArr ( " SELECT bezeichnung, bezeichnung_en, beschreibung_de, beschreibung_en, aktiv
FROM artikelgruppen WHERE id = '$edit' LIMIT 1 " );
if ( is_array ( $data )) {
$this -> app -> Tpl -> Set ( 'BEZEICHNUNG' , $data [ 0 ][ 'bezeichnung' ]);
$this -> app -> Tpl -> Set ( 'BESCHREIBUNG_DE' , $data [ 0 ][ 'beschreibung_de' ]);
$this -> app -> Tpl -> Set ( 'BESCHREIBUNG_EN' , $data [ 0 ][ 'beschreibung_en' ]);
$this -> app -> Tpl -> Set ( 'BEZEICHNUNGEN' , $data [ 0 ][ 'bezeichnung_en' ]);
$this -> app -> Tpl -> Set ( 'AKTIVCHECKED' , (( $data [ 0 ][ 'aktiv' ] == '1' ) ? 'checked' : '' ));
}
} else {
if ( ! empty ( $submit ) && is_numeric ( $shop )) {
$this -> app -> DB -> Insert ( " INSERT INTO artikelgruppen (bezeichnung, bezeichnung_en, beschreibung_de,beschreibung_en, shop, aktiv) VALUES (' $bezeichnung ', ' $bezeichnung_en ',' $beschreibung_de ',' $beschreibung_en ',' $shop ', ' $aktiv ') " );
$this -> app -> Location -> execute ( 'index.php?module=shopexport&action=artikelgruppen&id=' . $shop . '#tabs-1' );
}
}
// Delete
if ( is_numeric ( $delete )) {
$this -> app -> DB -> Delete ( " DELETE FROM artikelgruppen WHERE id=' $delete ' LIMIT 1 " );
$this -> app -> Location -> execute ( 'index.php?module=shopexport&action=artikelgruppen&id=' . $shop );
}
// Table
$table = new EasyTable ( $this -> app );
$this -> app -> Tpl -> Set ( 'INHALT' , '' );
$this -> app -> Tpl -> Set ( 'SUBSUBHEADING' , 'Artikelgruppen' );
$table -> Query ( " SELECT g.bezeichnung as artikelgruppe, g.id as gruppe, s.bezeichnung, if(g.aktiv,'online','') as aktiv, g.id FROM artikelgruppen g,
shopexport s WHERE s . firma = '".$this->app->User->GetFirma()."' AND s . id = g . shop AND s . id = $shop " );
$table -> DisplayNew ( 'INHALT' , " <a href= \" index.php?module=shopexport&action=artikelgruppen&edit=%value%&id= $shop #tabs-2 \" ><img border= \" 0 \" src= \" ./themes/[THEME]/images/edit.svg \" ></a>
< a onclick = \ " if(!confirm('Wirklich löschen?')) return false; else window.location.href='index.php?module=shopexport&action=artikelgruppen&delete=%value%&id= $shop '; \" >
< img src = \ " ./themes/[THEME]/images/delete.svg \" border= \" 0 \" ></a> " );
$this -> app -> Tpl -> Set ( 'EXTEND' , '' );
$this -> app -> Tpl -> Parse ( 'TABLE' , 'rahmen70.tpl' );
$this -> app -> Tpl -> Parse ( 'PAGE' , 'shopexport_artikelgruppen.tpl' );
}
public function ShopexportDateien ()
{
$this -> app -> erp -> Headlines ( 'Shopexport' , 'Dateien' );
$this -> ShopexportMenu ();
$id = $this -> app -> Secure -> GetGET ( 'id' );
$this -> app -> YUI -> DateiUpload ( 'PAGE' , 'Banner' , $id );
}
public function ShopexportMenu ()
{
$id = $this -> app -> Secure -> GetGET ( 'id' );
$shopexportRow = $id <= 0 ? null : $this -> app -> DB -> SelectRow (
sprintf (
'SELECT `bezeichnung`, `typ`, `shoptyp`, `modulename` FROM `shopexport` WHERE `id` = %d LIMIT 1' ,
$id
)
);
$name = empty ( $shopexportRow [ 'bezeichnung' ]) ? '' : $shopexportRow [ 'bezeichnung' ];
$this -> app -> erp -> Headlines ( '' , $name );
/** @var Appstore $appstore */
if (
! empty ( $shopexportRow [ 'shoptyp' ])
&& $shopexportRow [ 'shoptyp' ] === 'intern'
&& ( $appstore = $this -> app -> erp -> LoadModul ( 'appstore' ))
&& ! empty ( $shopexportRow [ 'modulename' ])
&& $appstore -> isBeta ( $shopexportRow [ 'modulename' ])) {
$appstore -> addBetaToHeadline ();
}
//$this->app->Tpl->Add('KURZUEBERSCHRIFT2',$name);
$typ = empty ( $shopexportRow [ 'typ' ]) ? '' : $shopexportRow [ 'typ' ];
$this -> app -> erp -> MenuEintrag ( 'index.php?module=onlineshops&action=create' , 'Neu' );
$this -> app -> erp -> MenuEintrag ( " index.php?module=onlineshops&action=edit&id= $id " , 'Details' );
//$this->app->erp->MenuEintrag("index.php?module=shopexport&action=export&id=$id","Export");
$this -> app -> erp -> MenuEintrag ( " index.php?module=shopexport&action=artikeluebertragung&id= $id " , " Artikel Übertragung " );
if ( $this -> app -> DB -> Select ( " SELECT modulename FROM shopexport WHERE id = ' $id ' " ) === 'shopimporter_shopware' ){
//Soll nur in Shopware angezeigt werden, da nur in Shopware unterstüzt
$this -> app -> erp -> MenuEintrag ( " index.php?module=shopexport&action=adressuebertragung&id= $id " , " Adressen Übertragung " );
}
if ( $typ === 'wawision' ) {
$this -> app -> erp -> MenuEintrag ( " index.php?module=shopexport&action=navigationtab&id= $id " , " Navigation " );
$this -> app -> erp -> MenuEintrag ( " index.php?module=shopexport&action=artikelgruppen&id= $id " , " Artikelgruppen " );
$this -> app -> erp -> MenuEintrag ( " index.php?module=shopexport&action=dateien&id= $id " , " Dateien " );
$this -> app -> erp -> MenuEintrag ( " index.php?module=shopexport&action=live&id= $id " , " Live-Status " );
$this -> app -> erp -> MenuEintrag ( " index.php?module=inhalt&action=listshop&id= $id " , " Inhalte / E-Mailvorlagen " );
}
$this -> app -> erp -> MenuEintrag ( " index.php?module=shopexport&action=list " , " Zurück zur Übersicht " );
$this -> app -> erp -> RunMenuHook ( 'shopexport' );
}
public function ShopexportBesuchen ()
{
$id = $this -> app -> Secure -> GetGET ( 'id' );
$url = $this -> app -> DB -> Select ( " SELECT url FROM shopexport WHERE id=' $id ' LIMIT 1 " );
$typ = $this -> app -> DB -> Select ( " SELECT typ FROM shopexport WHERE id=' $id ' LIMIT 1 " );
if ( $typ === 'wawision' ) {
$this -> app -> Location -> execute ( $url );
}
}
public function ShopexportExport ()
{
$id = $this -> app -> Secure -> GetGET ( 'id' );
$this -> ShopexportMenu ();
$this -> app -> erp -> MenuEintrag ( 'index.php?module=onlineshops&action=edit&id=' . $id , " Zurück zur Übersicht " );
$this -> app -> Tpl -> Set ( 'SCHRITT2' , " disabled " );
$this -> app -> Tpl -> Set ( 'SCHRITT3' , " disabled " );
$this -> app -> Tpl -> Set ( 'STATUS' , " <div class= \" info \" >Artikel Export: Bitte Verbindung prüfen.</div> " );
$this -> app -> Tpl -> Set ( 'ID' , $id );
$this -> app -> Tpl -> Set ( 'COMMONEXPORT' , " <div class= \" info \" >Abgleich zu Kundencenter.</div> " );
if ( $this -> app -> Secure -> GetPOST ( " commonexport " ) != '' ){
$anzahl = $this -> app -> remote -> RemoteSendExportlink ( $id );
//$anzahl = $this->app->remote->RemoteSendNavigation($id);
//$this->app->erp->NewEvent("Navigations-Export Online-Shop Nr. $id","onlineshop");
$this -> app -> Tpl -> Set ( 'COMMONEXPORT' , " <div class= \" error \" >Es wurden " . $anzahl . " Datensätze heraufgeladen.</div> " );
}
if ( $this -> app -> Secure -> GetPOST ( " schritt1 " ) != '' ){
$className = 'Remote' ;
$methodName = 'RemoteConnection' ;
$r = new ReflectionMethod ( $className , $methodName );
$params = $r -> getParameters ();
2022-06-10 11:28:28 +02:00
$anzargs = ( ! empty ( $params ) ? count ( $params ) : 0 );
2021-05-21 08:49:41 +02:00
if ( $anzargs > 1 ) {
$pageContents = $this -> app -> remote -> RemoteConnection ( $id , true );
}
else {
$pageContents = $this -> app -> remote -> RemoteConnection ( $id );
}
if ( $pageContents === 'success' ) {
if ( $anzargs > 1 ) {
$pageContents2 = $this -> app -> remote -> RemoteConnection ( $id , 'info' );
}
$this -> app -> Tpl -> Set ( 'SCHRITT2' , '' );
$this -> app -> Tpl -> Set ( 'HIDDENSCHRITT2' , " <input type= \" hidden \" name= \" schritt1_check \" value= \" 1 \" > " );
if ( $anzargs > 1 && is_array ( $pageContents2 )) {
$json = $this -> app -> DB -> Select ( " SELECT json FROM shopexport WHERE id = ' $id ' LIMIT 1 " );
if ( $json )
{
$json = array_merge ( json_decode ( $json , true ), $pageContents2 );
} else {
$json = $pageContents2 ;
}
$this -> app -> DB -> Update ( " UPDATE shopexport set json = ' " . $this -> app -> DB -> real_escape_string ( json_encode ( $json )) . " ' WHERE id = ' $id ' LIMIT 1 " );
unset ( $json );
$this -> app -> Tpl -> Set ( 'STATUS' , " <div class= \" info \" > " );
if ( isset ( $pageContents2 [ 'subshops' ]))
{
$this -> app -> Tpl -> Set ( 'STATUS' , " Subshops:
< table >< tr >< td > Id </ td >< td > Name </ td >< td > Aktiv </ td ></ tr >
" );
foreach ( $pageContents2 [ 'subshops' ] as $subshop )
{
$this -> app -> Tpl -> Add ( 'STATUS' , " <tr><td> " . $subshop [ 'id' ] . " </td><td> " . $subshop [ 'name' ] . " </td><td> " . ( $subshop [ 'aktiv' ] ? 'ja' : 'nein' ) . " </td></tr> " );
}
$this -> app -> Tpl -> Add ( 'STATUS' , " </table> " );
} else {
$this -> app -> Tpl -> Add ( 'STATUS' , " Verbindung: success " );
}
$this -> app -> Tpl -> Add ( 'STATUS' , " </div> " );
} else {
$this -> app -> Tpl -> Set ( 'STATUS' , " <div class= \" info \" >Verbindung: $pageContents </div> " );
}
}
else {
$this -> app -> Tpl -> Set ( 'STATUS' , " <div class= \" error \" >Verbindungsproblem: Eventuell falsche Schlüssel! ( $pageContents )</div> " );
}
}
if ( $this -> app -> Secure -> GetPOST ( 'schritt2' ) != '' && $this -> app -> Secure -> GetPOST ( 'schritt1_check' ) == '1' ) {
$projekt = $this -> app -> DB -> Select ( " SELECT projekt FROM shopexport WHERE id=' $id ' LIMIT 1 " );
$this -> app -> erp -> UpdateChecksumShopartikel ( $projekt );
$tmp = $this -> app -> remote -> RemoteGetUpdateArticleList ( $id );
$this -> app -> Tpl -> Set ( 'SCHRITT2' , '' );
$this -> app -> Tpl -> Set ( 'SCHRITT3' , '' );
$this -> app -> Tpl -> Set ( 'HIDDENSCHRITT2' , " <input type= \" hidden \" name= \" schritt1_check \" value= \" 1 \" > " );
$this -> app -> Tpl -> Set ( 'HIDDENSCHRITT3' , " <input type= \" hidden \" name= \" schritt2_check \" value= \" 1 \" > " );
$html = " <table align=center> " ;
$html = $html . " <tr><td>Pos.</td><td></td><td>Artikel</td><td>Nummer</td><td>Letzte Änderung</td></tr> " ;
if ( is_array ( $tmp )) {
foreach ( $tmp as $row ) {
$checkarray [ $row [ 'artikel' ]] = $row [ 'checksum' ];
}
}
/*
if ( $projekt == " 1 " ) $checkmasterarray = $this -> app -> DB -> SelectArr ( " SELECT id,checksum FROM artikel WHERE shop='1' AND projekt=' $projekt ' AND geloescht='0' " );
else if ( $projekt == " 2 " ) $checkmasterarray = $this -> app -> DB -> SelectArr ( " SELECT id,checksum FROM artikel WHERE shop='2' AND projekt=' $projekt ' AND geloescht='0' " );
else if ( $projekt == " 4 " ) $checkmasterarray = $this -> app -> DB -> SelectArr ( " SELECT id,checksum FROM artikel WHERE shop='3' AND projekt=' $projekt ' AND geloescht='0' " );
*/
$checkmasterarray = $this -> app -> DB -> SelectArr ( " SELECT id,checksum FROM artikel WHERE shop=' $id ' AND geloescht='0' " );
$html = $html . " <tr><td>CMS</td><td><input type= \" checkbox \" name= \" cms \" value= \" 1 \" checked></td><td>Inhaltsseiten (keine Shop-Artikeltexte)</td>
< td ></ td >< td > ( falls vorhanden ) </ td ></ tr > " ;
$html = $html . " <tr><td>Artikelgruppen</td><td><input type= \" checkbox \" name= \" artikelgruppen \" value= \" 1 \" checked></td><td>Artikelgruppen</td>
< td ></ td >< td > ( falls vorhanden ) </ td ></ tr > " ;
$html = $html . " <tr><td>Dateien/Bilder</td><td><input type= \" checkbox \" name= \" dateienupdate \" value= \" 1 \" checked></td><td>Shopbilder (dauert bei vielen Bildern)</td>
< td ></ td >< td > ( falls vorhanden ) </ td ></ tr > " ;
$aenderungen = 0 ;
$ccheckmasterarray = ! empty ( $checkmasterarray ) ? count ( $checkmasterarray ) : 0 ;
for ( $i = 0 ; $i < $ccheckmasterarray ; $i ++ ) {
$artikel = $checkmasterarray [ $i ][ 'id' ];
$checksum = $checkmasterarray [ $i ][ 'checksum' ];
if ( isset ( $checkarray ) && isset ( $checkarray [ $artikel ]) && ( $checkarray [ $artikel ] != $checksum || $checkarray [ $artikel ] == " " ))
{
$aenderungen ++ ;
$tmp = $this -> app -> DB -> SelectArr ( " SELECT a.name_de, a.nummer FROM artikel a WHERE a. id=' $artikel ' LIMIT 1 " );
if ( $tmp )
{
$tmp [ 0 ][ 'logdatei' ] = $this -> app -> DB -> Select ( " SELECT logdatei FROM shopexport_artikel WHERE artikel=' $artikel ' AND shopexport=' $id ' LIMIT 1 " );
if ( $tmp [ 0 ][ 'logdatei' ] == " " ) $tmp [ 0 ][ 'logdatei' ] = " noch nicht vorhanden " ;
$html = $html . " <tr><td> $aenderungen </td><td><input type= \" checkbox \" name= \" artikel[] \" value= \" $artikel\ " checked ></ td >< td > { $tmp [ 0 ][ 'name_de' ]} </ td >
< td > { $tmp [ 0 ][ 'nummer' ]} </ td >< td > { $tmp [ 0 ][ 'logdatei' ]} </ td ></ tr > " ;
}
}
if ( isset ( $checkarray ) && isset ( $checkarray [ $artikel ]))
{
unset ( $checkarray [ $artikel ]);
}
}
// loesche alle artikel im shop die nicht mehr im ERP als shop artikel vorhanden sind!
$ccheckarray = ! empty ( $checkarray ) ? count ( $checkarray ) : 0 ;
for ( $j = 0 ; $j < $ccheckarray ; $j ++ ) {
if ( $ccheckarray > 0 ){
foreach ( $checkarray as $key_artikel => $value_checksum ) {
$pageContents = $this -> app -> remote -> RemoteDeleteArticle ( $id , $key_artikel );
}
$this -> app -> Tpl -> Set ( 'STATUS' , " <div class= \" error \" >Es wurden " . $ccheckarray . " Artikel im Shop gelöscht (fehlende Attribute).</div> " );
}
}
$this -> app -> Tpl -> Add ( 'STATUS' , " <div class= \" info \" >Änderungen an $aenderungen Artikel gefunden.</div> " );
$html = $html . " </table> " ;
$this -> app -> Tpl -> Set ( 'UPDATES' , $html );
}
if ( $this -> app -> Secure -> GetPOST ( " schritt3 " ) != " " && $this -> app -> Secure -> GetPOST ( " schritt1_check " ) == " 1 " &&
$this -> app -> Secure -> GetPOST ( " schritt2_check " ) == " 1 " )
{
$artikel = $this -> app -> Secure -> GetPOST ( " artikel " );
$this -> app -> erp -> NewEvent ( " Artikel-Export Online-Shop Nr. $id " , " onlineshop " );
// artikelgruppen update
if ( $this -> app -> Secure -> GetPOST ( " cms " ) == " 1 " ) {
$cms = $this -> app -> DB -> Select ( " SELECT cms FROM shopexport WHERE id=' $id ' LIMIT 1 " );
if ( $cms == '1' ){
$this -> app -> remote -> RemoteSendInhalt ( $id );
}
}
if ( $this -> app -> Secure -> GetPOST ( " artikelgruppen " ) == " 1 " ) {
$this -> app -> remote -> RemoteSendArtikelgruppen ( $id );
$this -> app -> remote -> RemoteSendArtikelArtikelgruppen ( $id );
}
// sende artikel liste
$tmp_anzahl = $this -> app -> remote -> RemoteSendArticleList ( $id , $artikel );
// dateien update
//$dateien = $this->app->DB->SelectArr("SELECT DISTINCT ds.datei FROM datei_stichwoerter ds, datei d WHERE d.id=ds.datei AND (ds.subjekt!='Druckbild') AND (ds.objekt='Artikel' OR ds.objekt='Kampangen') AND d.geloescht=0 AND d.firma='".$this->app->User->GetFirma()."'");
// das sind zuviele bilder!!!! nur die bilder vom shop! TODO
//$dateien = $this->app->DB->SelectArr("SELECT DISTINCT ds.datei FROM datei_stichwoerter ds, datei d WHERE d.id=ds.datei AND (ds.subjekt!='Druckbild') AND (ds.objekt='Artikel' OR ds.objekt='Kampangen') AND d.firma='".$this->app->User->GetFirma()."'");
if ( $this -> app -> Secure -> GetPOST ( " dateienupdate " ) == 1 ) {
$dateien = $this -> app -> DB -> SelectArr ( " SELECT DISTINCT ds.datei FROM datei_stichwoerter ds, datei d, artikel a WHERE d.id=ds.datei AND (ds.subjekt='Shopbild' OR ds.subjekt='Gruppenbild') AND ((ds.objekt='Artikel' AND ds.parameter=a.id) OR (ds.objekt='Kampangen' AND ds.parameter=' $id ')) AND d.firma=' " . $this -> app -> User -> GetFirma () . " ' AND a.shop=' $id ' " );
$tmp = $this -> app -> remote -> RemoteGetFileList ( $id );
if ( is_array ( $tmp )) {
foreach ( $tmp as $row ) {
$checkarray [ $row [ 'datei' ]] = $row [ 'checksum' ];
}
}
$datei_updates = 0 ;
$cdateien = ! empty ( $dateien ) ? count ( $dateien ) : 0 ;
for ( $i = 0 ; $i < $cdateien ; $i ++ ) {
$fid = $dateien [ $i ][ 'datei' ];
$geloescht = $this -> app -> DB -> Select ( " SELECT geloescht FROM datei WHERE id=' $fid ' LIMIT 1 " );
if ( isset ( $checkarray ) && ( $checkarray [ $fid ] != md5 ( $this -> app -> erp -> GetDatei ( $fid ))) && $geloescht == 0 ) {
$datei_updates ++ ;
$this -> app -> remote -> RemoteSendFile ( $id , $fid );
$this -> app -> remote -> RemoteAddFileSubject ( $id , $fid );
$checkarray [ $fid ] = " update " ;
}
else {
if ( $geloescht ) {
$this -> app -> remote -> RemoteDeleteFile ( $id , $fid );
$checkarray [ $fid ] = 'delete' ;
}
}
$checkarray [ $fid ] = 'mark' ;
// wenn datei lokal geloescht loesche diese auch auf dem server
// if($geloescht)
}
}
//print_r($checkarray);
2022-06-10 11:28:28 +02:00
if ( is_array ( $checkarray ) && ( ! empty ( $checkarray ) ? count ( $checkarray ) : 0 ) > 0 ) {
2021-05-21 08:49:41 +02:00
$delete = 0 ;
foreach ( $checkarray as $key => $value ) {
if ( $checkarray [ $key ] !== 'mark' && $checkarray [ $key ] !== 'delete' && $checkarray [ $key ] !== 'update' ) {
//echo "loesche $key<br>";
$this -> app -> remote -> RemoteDeleteFile ( $id , $key );
$delete ++ ;
}
}
}
//ENDE DATEIEN
// loesche nicht gebrauchte dateien
if ( $datei_updates > 0 ) {
$this -> app -> Tpl -> Set ( 'STATUS' , " <div class= \" info \" >Datei-Updates: " . $datei_updates . " .</div> " );
}
if ( $delete > 0 ) {
$this -> app -> Tpl -> Add ( 'STATUS' , " <div class= \" info \" >Datei(en) gelöscht: " . $delete . " .</div> " );
}
// ende dateien update
$this -> app -> DB -> Insert ( " INSERT INTO shopexport_status (id, shopexport, bearbeiter,zeit, bemerkung,befehl)
VALUES ( '' , '$id' , '".$this->app->User->GetName()."' , NOW (), '' , '".serialize($artikel)."' ) " );
$this -> app -> Tpl -> Add ( 'STATUS' , " <div class= \" info \" >Erfolgreiche Updates an " . $tmp_anzahl . " Artikeln durchgeführt.</div> " );
}
$this -> app -> Tpl -> Set ( 'SUBHEADING' , 'Starte Artikel Export' );
$this -> app -> Tpl -> Parse ( 'PAGE' , 'shopexport_export.tpl' );
}
public function ShopexportArtikeluebertragungdel ()
{
$id = ( int ) $this -> app -> Secure -> GetGET ( 'id' );
$shop = ( int ) $this -> app -> Secure -> GetGET ( 'shop' );;
if ( $id > 0 ){
$shop = $this -> app -> DB -> Select ( " SELECT shop FROM shopexport_artikeluebertragen WHERE artikel=' $id ' AND shop = ' $shop ' LIMIT 1 " );
$this -> app -> DB -> Delete ( " DELETE FROM shopexport_artikeluebertragen WHERE artikel=' $id ' AND shop = ' $shop ' LIMIT 1 " );
$this -> app -> DB -> Delete ( " DELETE FROM shopexport_artikeluebertragen_check WHERE artikel=' $id ' AND shop = ' $shop ' LIMIT 1 " );
}
$msg = $this -> app -> erp -> base64_url_encode ( '<div class="success">Der Artikel wurde aus der Übertragung entfernt.</div>' );
$this -> app -> Location -> execute ( 'index.php?module=shopexport&action=artikeluebertragung&id=' . $shop . '&msg=' . $msg );
}
public function ShopexportAdressuebertragungdel ()
{
$id = ( int ) $this -> app -> Secure -> GetGET ( 'id' );
$shop = 0 ;
if ( $id > 0 ){
$shop = $this -> app -> DB -> Select ( " SELECT shop FROM shopexport_adressenuebertragen WHERE id=' $id ' LIMIT 1 " );
$this -> app -> DB -> Delete ( " DELETE FROM shopexport_adressenuebertragen WHERE id=' $id ' LIMIT 1 " );
}
$msg = $this -> app -> erp -> base64_url_encode ( '<div class="success">Die Adresse wurde aus der Übertragung entfernt.</div>' );
$this -> app -> Location -> execute ( 'index.php?module=shopexport&action=adressuebertragung&id=' . $shop . '&msg=' . $msg );
}
/**
* @ param int $shopId
*
* @ return array
*/
public function getChangedCount ( $shopId )
{
$checkedStarted = ( int ) $this -> app -> erp -> GetKonfiguration ( 'shopexport_artikeluebertragen_check_start_' . $shopId );
$checked = ( int ) $this -> app -> erp -> GetKonfiguration ( 'shopexport_artikeluebertragen_check_checked_' . $shopId );
$changed = ( int ) $this -> app -> erp -> GetKonfiguration ( 'shopexport_artikeluebertragen_check_changed_' . $shopId );
$transfered = ( int ) $this -> app -> erp -> GetKonfiguration ( 'shopexport_artikeluebertragen_check_transfered_' . $shopId );
$lastid = ( int ) $this -> app -> erp -> GetKonfiguration ( 'shopexport_artikeluebertragen_check_lastid_' . $shopId );
return [ $checkedStarted , $checked , $changed , $checked - $changed , $transfered , $lastid ];
}
/**
* @ param int $shopId
*/
public function resetChangedInfo ( $shopId ) {
$this -> app -> erp -> SetKonfigurationValue ( 'shopexport_artikeluebertragen_check_start_' . $shopId , '' );
$this -> app -> erp -> SetKonfigurationValue ( 'shopexport_artikeluebertragen_check_checked_' . $shopId , '' );
$this -> app -> erp -> SetKonfigurationValue ( 'shopexport_artikeluebertragen_check_changed_' . $shopId , '' );
$this -> app -> erp -> SetKonfigurationValue ( 'shopexport_artikeluebertragen_check_transfered_' . $shopId , '' );
$this -> app -> erp -> SetKonfigurationValue ( 'shopexport_artikeluebertragen_check_lastid_' . $shopId , '' );
}
/**
* @ param int $ids
*/
public function addChangedArticles ( $minutes = 15 )
{
$ids = $this -> app -> DB -> SelectFirstCols (
sprintf (
' SELECT `id`
FROM `shopexport`
WHERE `aktiv` = 1 AND `autosendarticle` = 1 AND `artikelexport` = 1
AND ( `autosendarticle_last` IS NULL OR DATE_ADD ( `autosendarticle_last` INTERVAL % d MINUTE ) <= NOW ()) ' ,
$minutes
)
);
if ( empty ( $ids )) {
return ;
}
$this -> app -> DB -> Insert (
sprintf (
" INSERT INTO `shopexport_artikeluebertragen_check` (`shop`, `artikel`)
SELECT s . id as shop , a . id
FROM `artikel` AS `a`
INNER JOIN `shopexport` AS `s` ON s . id IN ( % s )
LEFT JOIN (
SELECT `artikel` , `shop`
FROM `artikel_onlineshops`
WHERE `shop` IN ( % s ) AND `aktiv` = 1
GROUP BY `artikel` , `shop`
) AS `oa` ON a . id = oa . artikel AND s . id = oa . shop
LEFT JOIN `shopexport_artikeluebertragen_check` AS `sac` ON a . id = sac . artikel AND sac . shop = s . id
LEFT JOIN `shopexport_artikeluebertragen` AS `sa` ON sa . shop = s . id AND sa . artikel = a . id
WHERE ( a . shop = s . id OR a . shop2 = s . id OR a . shop3 = s . id OR oa . artikel IS NOT NULL )
AND a . geloescht != 1 AND sa . id IS NULL
AND sac . id IS NULL
GROUP BY a . id , s . id " ,
implode ( ',' , $ids ), implode ( ',' , $ids )
)
);
}
/**
* @ return RedirectResponse
*/
public function HandleResetArticleCacheForArticleWithZeroStock () : RedirectResponse
{
$anz = 0 ;
$id = ( int ) $this -> app -> Secure -> GetGET ( 'id' );
if ( $id > 0 ) {
$this -> app -> DB -> Update (
" UPDATE `artikel` AS `a`
INNER JOIN
`artikel_onlineshops` AS `oa` ON oa . shop = '$id' AND oa . aktiv = 1 AND a . id = oa . artikel
SET oa . storage_cache = - 999 , oa . pseudostorage_cache = - 999
WHERE ( oa . storage_cache = 0 OR oa . storage_cache IS NULL ) AND a . geloescht = 0 "
);
$anz = $this -> app -> DB -> affected_rows ();
$this -> app -> erp -> LogFile ( " Lagerzahlencache zurückgesetzt für $anz Artikel mit 0-Mengen, shopid: $id " );
}
$msg = $this -> app -> erp -> base64_url_encode (
" <div class= \" success \" >Lagerzahlen Cache für " . $anz . " Artikel zurückgesetzt.</div> "
);
return RedirectResponse :: createFromUrl ( " index.php?module=shopexport&action=artikeluebertragung&id= $id &msg= $msg " );
}
public function ShopexportArtikeluebertragung ()
{
$id = ( int ) $this -> app -> Secure -> GetGET ( 'id' );
$alle = $this -> app -> Secure -> GetPOST ( 'alle' );
$allchanged = $this -> app -> Secure -> GetPOST ( 'allchanged' );
$bestaetigen = $this -> app -> Secure -> GetPOST ( 'bestaetigen' );
$abbrechen = $this -> app -> Secure -> GetPOST ( 'abbrechen' );
$artikelladen = $this -> app -> Secure -> GetPOST ( 'artikelladen' );
$artikel = $this -> app -> Secure -> GetPOST ( 'artikel' );
$kategorie = $this -> app -> Secure -> GetPOST ( 'kategorie' );
$unterartikel = $this -> app -> Secure -> GetPOST ( 'unterartikel' );
$unterartikelkategorie = $this -> app -> Secure -> GetPOST ( 'unterartikelkategorie' );
$kategorieladen = $this -> app -> Secure -> GetPOST ( 'kategorieladen' );
$delcache = $this -> app -> Secure -> GetPOST ( 'delcache' );
$delzerostockcache = $this -> app -> Secure -> GetPOST ( 'delzerostockcache' );
$delArticleCache = $this -> app -> Secure -> GetPOST ( 'delarticlecache' );
$artikelexporterlauben = $this -> app -> Secure -> GetPOST ( 'artikelexporterlauben' );
if ( ! empty ( $artikelexporterlauben )){
$this -> app -> DB -> Update ( " UPDATE shopexport SET artikelexport=1 WHERE id=' $id ' LIMIT 1 " );
}
if ( ! empty ( $delzerostockcache )) {
$this -> HandleResetArticleCacheForArticleWithZeroStock () -> send ();
$this -> app -> ExitXentral ();
}
if ( ! empty ( $delcache )) {
$anz = 0 ;
if ( $id > 0 ) {
$this -> app -> DB -> Update ( " UPDATE artikel a
LEFT JOIN ( SELECT artikel FROM artikel_onlineshops WHERE shop = '$id' AND aktiv = 1 GROUP BY artikel ) oa ON a . id = oa . artikel
SET a . cache_lagerplatzinhaltmenge = - 999 WHERE ( a . shop = '$id' OR a . shop2 = '$id' OR a . shop3 = '$id' OR NOT ISNULL ( oa . artikel )) AND a . geloescht = 0 " );
$anz = $this -> app -> DB -> affected_rows ();
$this -> app -> erp -> LogFile ( " Lagerzahlencache zurückgesetzt für $anz Artikel, shopid: $id " );
}
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" success \" >Lagerzahlen Cache für " . $anz . " Artikel zurückgesetzt.</div> " );
$this -> app -> Location -> execute ( " index.php?module=shopexport&action=artikeluebertragung&id= $id &msg= $msg " );
}
if ( ! empty ( $delArticleCache )) {
$anz = 0 ;
if ( $id > 0 ){
$this -> app -> DB -> Update (
sprintf (
" UPDATE artikel_onlineshops SET last_article_hash = '', storage_cache=-999,pseudostorage_cache=-999 WHERE shop = %d " ,
$id
)
);
$anz = $this -> app -> DB -> affected_rows ();
if ( $anz < 0 ) {
$anz = 0 ;
}
}
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" success \" >Artikel-Cache für " . $anz . " Artikel zurückgesetzt.</div> " );
$this -> app -> Location -> execute ( " index.php?module=shopexport&action=artikeluebertragung&id= $id &msg= $msg " );
}
if ( ! empty ( $allchanged )) {
if ( ! empty ( $bestaetigen )) {
if ( $id > 0 ){
/* $artikelarr = $this -> app -> DB -> SelectArr ( " SELECT a.id FROM artikel a
LEFT JOIN ( SELECT artikel FROM artikel_onlineshops WHERE shop = '$id' AND aktiv = 1 GROUP BY artikel ) oa ON a . id = oa . artikel
WHERE ( a . shop = '$id' OR a . shop2 = '$id' OR a . shop3 = '$id' OR NOT ISNULL ( oa . artikel )) AND a . geloescht != 1 " );
$cartikelarr = ! empty ( $artikelarr ) ? count ( $artikelarr ) : 0 ;
for ( $i = 0 ; $i < $cartikelarr ; $i ++ ) {
$this -> app -> DB -> Insert ( " INSERT INTO shopexport_artikeluebertragen_check (id,shop,artikel) VALUES ('',' $id ',' " . $artikelarr [ $i ][ 'id' ] . " ') " );
}
} */
$this -> resetChangedInfo ( $id );
$this -> app -> DB -> Delete (
sprintf (
'DELETE FROM shopexport_artikeluebertragen_check WHERE shop = %d' ,
$id
)
);
$this -> app -> DB -> Insert (
sprintf (
" INSERT INTO shopexport_artikeluebertragen_check (shop, artikel)
SELECT '%d' as shop , a . id FROM artikel a
LEFT JOIN (
SELECT artikel FROM artikel_onlineshops WHERE shop = % d AND aktiv = 1 GROUP BY artikel
) oa ON a . id = oa . artikel
LEFT JOIN shopexport_artikeluebertragen AS sa ON sa . shop = % d AND sa . artikel = a . id
WHERE ( a . shop =% d OR a . shop2 =% d OR a . shop3 =% d OR NOT ISNULL ( oa . artikel )) AND a . geloescht != 1 AND ISNULL ( sa . id )
GROUP BY a . id " ,
$id , $id , $id , $id , $id , $id
)
);
echo $this -> app -> DB -> error ();
$changeStart = $this -> app -> DB -> affected_rows ();
$this -> app -> erp -> SetKonfigurationValue ( 'shopexport_artikeluebertragen_check_start_' . $id ,
$changeStart
);
$this -> app -> erp -> SetKonfigurationValue ( 'shopexport_artikeluebertragen_check_checked_' . $id , 0 );
$this -> app -> erp -> SetKonfigurationValue ( 'shopexport_artikeluebertragen_check_changed_' . $id , 0 );
$this -> app -> erp -> SetKonfigurationValue (
'shopexport_artikeluebertragen_check_lastid_' . $id ,
mt_rand ( 1 , 2000000000 )
);
}
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" success \" >Alle Artikel die mit dem Shop verknüpft sind werden überprüft.</div> " );
$this -> app -> Location -> execute ( " index.php?module=shopexport&action=artikeluebertragung&id= $id &msg= $msg " );
}
$this -> app -> Tpl -> Add ( 'MESSAGE' , '<div class="error">Bitte Bestätigen Sie die Übertragung!</div>' );
}
if ( ! empty ( $alle )) {
if ( ! empty ( $bestaetigen )) {
if ( $id > 0 ){
/* $artikelarr = $this -> app -> DB -> SelectArr ( " SELECT a.id FROM artikel a
LEFT JOIN ( SELECT artikel FROM artikel_onlineshops WHERE shop = '$id' AND aktiv = 1 GROUP BY artikel ) oa ON a . id = oa . artikel
WHERE ( a . shop = '$id' OR a . shop2 = '$id' OR a . shop3 = '$id' OR NOT ISNULL ( oa . artikel )) AND a . geloescht != 1 " );
$cartikelarr = ! empty ( $artikelarr ) ? count ( $artikelarr ) : 0 ;
for ( $i = 0 ; $i < $cartikelarr ; $i ++ ) {
$this -> app -> DB -> Insert ( " INSERT INTO shopexport_artikeluebertragen (id,shop,artikel) VALUES ('',' $id ',' " . $artikelarr [ $i ][ 'id' ] . " ') " );
}
*/
$this -> resetChangedInfo ( $id );
$this -> app -> DB -> Insert (
sprintf (
" INSERT INTO shopexport_artikeluebertragen (shop, artikel)
SELECT '%d' AS shop , a . id FROM artikel a
LEFT JOIN (
SELECT artikel FROM artikel_onlineshops WHERE shop = % d AND aktiv = 1 GROUP BY artikel
) AS oa ON a . id = oa . artikel
WHERE ( a . shop =% d OR a . shop2 =% d OR a . shop3 =% d OR NOT ISNULL ( oa . artikel )) AND a . geloescht != 1 " ,
$id , $id , $id , $id , $id
)
);
$this -> app -> erp -> SetKonfigurationValue ( 'shopexport_artikeluebertragen_start_' . $id ,
$this -> app -> DB -> affected_rows ()
);
}
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" success \" >Alle Artikel die mit dem Shop verknüpft sind werden übertragen.</div> " );
$this -> app -> Location -> execute ( " index.php?module=shopexport&action=artikeluebertragung&id= $id &msg= $msg " );
}
$this -> app -> Tpl -> Add ( 'MESSAGE' , '<div class="error">Bitte Bestätigen Sie die Übertragung!</div>' );
}
if ( ! empty ( $abbrechen )) {
$this -> app -> DB -> Delete ( " DELETE FROM shopexport_artikeluebertragen WHERE shop=' $id ' " );
$this -> app -> DB -> Delete ( " DELETE FROM shopexport_artikeluebertragen_check WHERE shop=' $id ' " );
$this -> resetChangedInfo ( $id );
//$this->app->erp-> 'shopexport_artikeluebertragen_check_start_'.$id
$msg = $this -> app -> erp -> base64_url_encode ( '<div class="success">Alle aktuellen Artikel wurden aus der Übertragung entfernt.</div>' );
$this -> app -> Location -> execute ( 'index.php?module=shopexport&action=artikeluebertragung&id=' . $id . '&msg=' . $msg );
}
if ( $kategorieladen != '' ) {
if ( ! empty ( $bestaetigen )) {
$typ = $this -> app -> DB -> Select ( " SELECT id FROM artikelkategorien WHERE bezeichnung!='' AND bezeichnung=' $kategorie ' LIMIT 1 " );
if ( $typ ) {
$typ .= '_kat' ;
}
else {
$typ = $kategorie ;
}
if (( String ) $typ !== '' ) {
$this -> app -> DB -> Query ( " INSERT INTO shopexport_artikeluebertragen (artikel, shop) SELECT id as artikel ,' $id ' as shop FROM artikel WHERE (geloescht = 0 OR isnull(geloescht)) AND nummer <> 'DEL' AND nummer <> '' AND typ = ' $typ ' " );
$anz = ( int ) $this -> app -> DB -> affected_rows ();
//$artikelarr = $this->app->DB->SelectArr("SELECT id FROM artikel WHERE (geloescht = 0 OR isnull(geloescht)) AND nummer <> 'DEL' AND nummer <> '' AND typ = '$typ'");
if ( $anz > 0 ) {
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" success \" >Die Artikelkategorie wurde der Übertragung hinzugefügt ( $anz Artikel).</div> " );
}
else {
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" error \" >Keine Artikel in dieser Artikelkategorie gefunden.</div> " );
}
$this -> app -> Location -> execute ( " index.php?module=shopexport&action=artikeluebertragung&id= $id &msg= $msg " );
}
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" error \" >Keine Artikelkategorie ausgewählt</div> " );
$this -> app -> Location -> execute ( " index.php?module=shopexport&action=artikeluebertragung&id= $id &msg= $msg " );
}
$this -> app -> Tpl -> Add ( 'MESSAGE' , '<div class="error">Bitte Bestätigen Sie die Übertragung!</div>' );
}
if ( $artikelladen != '' ) {
if ( ! empty ( $bestaetigen )) {
$artikelid = $this -> app -> DB -> Select ( " SELECT id FROM artikel WHERE nummer!='' AND nummer=' $artikel ' AND (geloescht = 0 OR isnull(geloescht)) AND nummer <> 'DEL' LIMIT 1 " );
if ( $artikelid > 0 && $id > 0 )
{
$this -> app -> DB -> Insert ( " INSERT INTO shopexport_artikeluebertragen (id,shop,artikel) VALUES ('',' $id ',' $artikelid ') " );
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" success \" >Der Artikel wurde der Übertragung hinzugefügt.</div> " );
$this -> app -> Location -> execute ( " index.php?module=shopexport&action=artikeluebertragung&id= $id &msg= $msg " );
}
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" error \" >Kein Artikel ausgewählt</div> " );
$this -> app -> Location -> execute ( " index.php?module=shopexport&action=artikeluebertragung&id= $id &msg= $msg " );
}
$this -> app -> Tpl -> Add ( 'MESSAGE' , '<div class="error">Bitte Bestätigen Sie die Übertragung!</div>' );
}
$this -> app -> Tpl -> Set ( 'VORMATRIXPRODUKT' , '<!--' );
$this -> app -> Tpl -> Set ( 'NACHMATRIXPRODUKT' , '-->' );
$this -> ShopexportMenu ();
$checking = ( int ) $this -> app -> DB -> Select (
sprintf (
'SELECT COUNT(id) FROM shopexport_artikeluebertragen_check WHERE shop = %d' ,
$id
)
);
list ( $start , $checked , $changed , $notChanged , $transfered , $lastid ) = $this -> getChangedCount ( $id );
if ( $checking || ( int ) $start > 0 ) {
$inList = ( int ) $this -> app -> DB -> Select (
sprintf (
'SELECT COUNT(id) FROM shopexport_artikeluebertragen WHERE shop = %d' ,
$id
)
);
if ( $inList === 0 && $checking === 0 ) {
$this -> app -> Tpl -> Add (
'MESSAGE' ,
'<div class="warning">' . $checked . ' von ' . $start .
' Artikel wurden überprüft. ' . ( ! empty ( $transfered ) ? $transfered : $changed ) . ' veränderte Artikel wurden gefunden und an den Shop übertragen.</div>' );
}
else {
$this -> app -> Tpl -> Add (
'MESSAGE' ,
'<div class="warning">' . $checked . ' von ' . $start . ' Artikel wurden überprüft. ' . $changed .
' veränderte Artikel wurden gefunden und ' . $transfered . ' davon an den Shop übertragen. <a href="index.php?module=shopexport&action=artikeluebertragung&id=' . $id . '"><input type="button" value="neu Laden" /></a></div>' );
/* if ( $start > 0 ) {
$this -> app -> Tpl -> Add (
'MESSAGE' ,
'<div class="warning">' .
$checked . ' von ' . $start . ' Artikel geprüft (' . $changed . ' geändert / ' .
$notChanged . ' nicht ge & auml ; ndert )
< a href = " index.php?module=shopexport&action=artikeluebertragung&id=' . $id . ' " >< input type = " button " value = " neu Laden " /></ a ></ div ></ div > '
);
}
else {
$this -> app -> Tpl -> Add (
'MESSAGE' ,
'<div class="warning">' . $inList . ' Artikel gefunden, noch zu prüfen ' . $checking . ' Artikel <a href="index.php?module=shopexport&action=artikeluebertragung&id=' . $id . '"><input type="button" value="neu Laden" /></a></div></div>'
);
} */
}
}
$exportErlaubt = $this -> app -> DB -> Select ( " SELECT artikelexport FROM shopexport WHERE id=' $id ' LIMIT 1 " );
if ( ! $exportErlaubt ){
$this -> app -> Tpl -> Set ( 'IMPORTERINFO' , '<div class="info">' );
$this -> app -> Tpl -> Add ( 'IMPORTERINFO' , ' Der Artikelexport für diesen Importer ist nicht aktiviert .
< input class = " btnBlue " type = " submit " value = " Jetzt aktivieren " name = " artikelexporterlauben " > ' );
$this -> app -> Tpl -> Add ( 'IMPORTERINFO' , '</div>' );
}
$this -> app -> erp -> checkActiveCronjob ( 'artikeluebertragen' , 'IMPORTERINFO2' );
$this -> app -> erp -> MenuEintrag ( 'index.php?module=onlineshops&action=edit&id=' . $id , 'Zurück zur Übersicht' );
$this -> app -> YUI -> AutoComplete ( 'artikel' , 'artikelnummer' , 1 );
$this -> app -> YUI -> AutoComplete ( 'kategorie' , 'artikelkategorien' );
$this -> app -> YUI -> TableSearch ( 'TAB1' , 'shopexport_artikeluebertragung' );
$this -> app -> Tpl -> Parse ( 'PAGE' , 'shopexport_artikeluebertragung.tpl' );
}
public function ShopexportAdressuebertragung ()
{
$id = ( int ) $this -> app -> Secure -> GetGET ( 'id' );
$bestaetigen = $this -> app -> Secure -> GetPOST ( 'bestaetigen' );
$alle = $this -> app -> Secure -> GetPOST ( 'alle' );
$abbrechen = $this -> app -> Secure -> GetPOST ( 'abbrechen' );
$adresseladen = $this -> app -> Secure -> GetPOST ( 'adresseladen' );
$adresse = $this -> app -> Secure -> GetPOST ( 'adresse' );
$gruppeladen = $this -> app -> Secure -> GetPOST ( 'gruppeladen' );
$gruppe = $this -> app -> Secure -> GetPOST ( 'gruppe' );
if ( ! empty ( $alle )) {
if ( ! empty ( $bestaetigen )) {
if ( $id > 0 ){
$this -> app -> DB -> Insert ( " INSERT INTO shopexport_adressenuebertragen (shop,adresse) SELECT $id , a.id FROM adresse a WHERE a.geloescht <> 1 AND a.kundennummer <> '' AND a.id NOT IN (SELECT adresse FROM shopexport_adressenuebertragen WHERE shop = $id ) " );
}
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" success \" >Alle Adressen die mit dem Shop verknüpft sind werden übertragen.</div> " );
$this -> app -> Location -> execute ( " index.php?module=shopexport&action=adressuebertragung&id= $id &msg= $msg " );
}
$this -> app -> Tpl -> Add ( 'MESSAGE' , '<div class="error">Bitte Bestätigen Sie die Übertragung!</div>' );
}
if ( ! empty ( $abbrechen )) {
$this -> app -> DB -> Delete ( " DELETE FROM shopexport_adressenuebertragen WHERE shop=' $id ' " );
$msg = $this -> app -> erp -> base64_url_encode ( '<div class="success">Alle Adressen wurden aus der Übertragung entfernt.</div>' );
$this -> app -> Location -> execute ( 'index.php?module=shopexport&action=adressuebertragung&id=' . $id . '&msg=' . $msg );
}
if ( $gruppeladen != '' ) {
if ( ! empty ( $bestaetigen ) && $gruppe != '' ) {
$gruppetmp = explode ( ' ' , $gruppe );
$gruppenid = $this -> app -> DB -> Select ( " SELECT id FROM gruppen WHERE kennziffer=' " . $gruppetmp [ 0 ] . " ' LIMIT 1 " );
if ( $gruppenid > 0 && $id > 0 )
{
$this -> app -> DB -> Insert ( " INSERT INTO shopexport_adressenuebertragen (shop,adresse) SELECT $id , a.id FROM adresse a JOIN adresse_rolle ar ON a.id = ar.adresse WHERE ar.subjekt='Mitglied' AND ar.objekt='Gruppe' AND ar.parameter=' $gruppenid ' AND a.geloescht <> 1 AND a.kundennummer <> '' AND a.id NOT IN (SELECT adresse FROM shopexport_adressenuebertragen WHERE shop = $id ) " );
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" success \" >Die Adressen wurde der Übertragung hinzugefügt.</div> " );
$this -> app -> Location -> execute ( " index.php?module=shopexport&action=adressuebertragung&id= $id &msg= $msg " );
}
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" error \" >Keie Adresse ausgewählt</div> " );
$this -> app -> Location -> execute ( " index.php?module=shopexport&action=adressuebertragung&id= $id &msg= $msg " );
}
$this -> app -> Tpl -> Add ( 'MESSAGE' , '<div class="error">Bitte Bestätigen Sie die Übertragung!</div>' );
}
if ( $adresseladen != '' )
{
if ( ! empty ( $bestaetigen ) && $adresse != '' ){
$adressetmp = explode ( ' ' , $adresse );
$adressid = $adressetmp [ 0 ];
$adressid = $this -> app -> DB -> Select ( " SELECT id FROM adresse WHERE name!='' AND kundennummer!='' AND geloescht<>1 AND id=' $adressid ' LIMIT 1 " );
if ( $adressid > 0 && $id > 0 ) {
$this -> app -> DB -> Insert ( " INSERT INTO shopexport_adressenuebertragen (id,shop,adresse) VALUES ('',' $id ',' $adressid ') " );
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" success \" >Die Adresse wurde der Übertragung hinzugefügt.</div> " );
$this -> app -> Location -> execute ( " index.php?module=shopexport&action=adressuebertragung&id= $id &msg= $msg " );
}
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" error \" >Keie Adresse ausgewählt</div> " );
$this -> app -> Location -> execute ( " index.php?module=shopexport&action=adressuebertragung&id= $id &msg= $msg " );
}
$this -> app -> Tpl -> Add ( 'MESSAGE' , '<div class="error">Bitte Bestätigen Sie die Übertragung!</div>' );
}
$this -> ShopexportMenu ();
$this -> app -> erp -> MenuEintrag ( 'index.php?module=onlineshops&action=edit&id=' . $id , 'Zurück zur Übersicht' );
$this -> app -> YUI -> AutoComplete ( 'adresse' , 'adresse' );
$this -> app -> YUI -> AutoComplete ( 'gruppe' , 'gruppekennziffer' );
$this -> app -> YUI -> TableSearch ( 'TAB1' , 'shopexport_adressuebertragung' );
$this -> app -> Tpl -> Parse ( 'PAGE' , 'shopexport_adressuebertragung.tpl' );
}
public function ShopexportNavigation ()
{
$id = $this -> app -> Secure -> GetGET ( 'id' );
$tmp = new Navigation ( $this -> app , $id );
$this -> app -> Tpl -> Set ( 'ID' , $id );
$this -> app -> Tpl -> Set ( 'PAGE' , $tmp -> Get ());
$this -> app -> BuildNavigation = false ;
}
/**
* @ param int $articleId
* @ param int | array $shopId
*
* @ return array
*/
public function hasArticleHashChanged ( $articleId , $shopId )
{
if ( is_array ( $shopId )) {
$shop = $shopId ;
$shopId = $shop [ 'id' ];
} /*
else {
$shop = $this -> app -> DB -> SelectRow ( 'SELECT * FROM shopexport WHERE id = %d' , $shopId );
} */
$hash = $this -> getArticleHash ( $articleId , $shopId , true );
$articleShopRow = $this -> app -> DB -> SelectRow (
sprintf (
'SELECT last_article_hash, last_article_transfer FROM artikel_onlineshops WHERE artikel = %d AND shop = %d' ,
$articleId , $shopId
)
);
return [
'changed' => empty ( $articleShopRow [ 'last_article_hash' ]) || ( $articleShopRow [ 'last_article_hash' ] !== $hash ),
'hash' => $hash
];
}
/**
* @ param int $articleId
* @ param int | array $shopId
* @ param bool $withAttributes
* @ param bool $widthCategorieTree
*
* @ return string
*/
public function getArticleHash ( $articleId , $shopId , $withAttributes = true , $widthCategorieTree = false )
{
if ( is_array ( $shopId )) {
$shop = $shopId ;
$shopId = $shop [ 'id' ];
} /* else {
$shop = $this -> app -> DB -> SelectRow ( 'SELECT * FROM shopexport WHERE id = %d' , $shopId );
} */
$art = $this -> app -> DB -> SelectRow (
sprintf (
'SELECT * FROM artikel WHERE id = %d' ,
$articleId
)
);
if ( empty ( $art )) {
return '' ;
}
unset (
$art [ 'logdatei' ],
$art [ 'cache_lagerplatzinhaltmenge' ],
$art [ 'shop' ],
$art [ 'shop2' ],
$art [ 'shop3' ],
$art [ 'usereditid' ],
$art [ 'useredittimestamp' ],
$art [ 'laststorage_sync' ]
);
if ( $withAttributes ) {
$art [ 'attributes' ] = $this -> app -> DB -> SelectArr (
sprintf (
" SELECT DISTINCT e.name, ew.wert
FROM artikeleigenschaften e
INNER JOIN artikeleigenschaftenwerte ew ON e . id = ew . artikeleigenschaften
WHERE ew . artikel = % d AND e . name <> '' AND ew . wert <> '' AND e . geloescht <> 1
ORDER BY e . name , ew . wert " ,
$articleId
)
);
}
if ( $widthCategorieTree ) {
$kategorienbaum = null ;
$this -> app -> erp -> GetKategorienbaum ( $kategorienbaum , 0 , 0 , $articleId );
if ( ! empty ( $kategorienbaum )) {
$kategorien = $this -> app -> DB -> SelectArr (
sprintf (
" SELECT ak.id, ak.bezeichnung
FROM `artikelbaum_artikel` aa
INNER JOIN `artikelkategorien` ak ON aa . kategorie = ak . id AND ak . geloescht <> 1 AND aa . artikel = % d
ORDER by ak . bezeichnung , ak . id " ,
$articleId
)
);
if ( $kategorien )
{
foreach ( $kategorien as $v )
{
$katid [ $v [ 'id' ]] = true ;
}
}
if ( ! empty ( $katid )) {
foreach ( $kategorienbaum as $v ) {
if ( isset ( $katid [ $v [ 'id' ]])) {
$art [ 'kategorien' ][] = array ( 'name' => $v [ 'bezeichnung' ], 'parent' => $v [ 'parent' ], 'id' => $v [ 'id' ], 'lvl' => $v [ 'lvl' ], 'extid' => $v [ 'extid' ]);
}
}
}
}
}
$art [ 'shopexport' ] = $this -> app -> DB -> SelectArr (
sprintf (
" SELECT name, wert FROM shopexport_artikel WHERE artikel = %d AND shopid = %d ORDER BY id " ,
$articleId , $shopId
)
);
return sha1 ( json_encode ( $art ));
}
}