2023-10-16 21:22:21 +02:00
< ? php
/*
* Copyright ( c ) 2022 OpenXE project
*/
use Xentral\Components\Database\Exception\QueryFailureException ;
class Versandpakete {
2023-10-18 14:35:35 +02:00
const STATUS = ARRAY ( 'neu' , 'versendet' , 'abgeschlossen' , 'storniert' );
2023-10-16 21:22:21 +02:00
const SQL_VERSANDPAKETE_LIEFERSCHEIN = "
SELECT DISTINCT
versandpaket ,
lieferschein
FROM
versandpaket_lieferschein_position vlp
INNER JOIN lieferschein_position lp ON
vlp . lieferschein_position = lp . id
UNION
SELECT DISTINCT
id ,
lieferschein_ohne_pos AS lieferschein
FROM
versandpakete
WHERE
lieferschein_ohne_pos <> 0
" ;
function __construct ( $app , $intern = false ) {
$this -> app = $app ;
if ( $intern )
return ;
$this -> app -> ActionHandlerInit ( $this );
$this -> app -> ActionHandler ( " list " , " versandpakete_list " );
$this -> app -> ActionHandler ( " create " , " versandpakete_edit " ); // This automatically adds a "New" button
$this -> app -> ActionHandler ( " edit " , " versandpakete_edit " );
$this -> app -> ActionHandler ( " add " , " versandpakete_add " );
$this -> app -> ActionHandler ( " lieferscheine " , " versandpakete_lieferscheine " );
2023-10-18 14:35:35 +02:00
$this -> app -> ActionHandler ( " stapelverarbeitung " , " versandpakete_stapelverarbeitung " );
$this -> app -> ActionHandler ( " paketmarke " , " versandpakete_paketmarke " );
2023-10-16 21:22:21 +02:00
$this -> app -> ActionHandler ( " delete " , " versandpakete_delete " );
2023-10-20 15:47:37 +02:00
$this -> app -> ActionHandler ( " deletepos " , " versandpakete_deletepos " );
2023-10-16 21:22:21 +02:00
$this -> app -> ActionHandler ( " minidetail " , " versandpakete_minidetail " );
2023-10-20 15:47:37 +02:00
$this -> app -> ActionHandler ( " minidetaillieferschein " , " versandpakete_minidetaillieferschein " );
2023-10-16 21:22:21 +02:00
$this -> app -> DefaultActionHandler ( " list " );
$this -> app -> ActionHandlerListen ( $app );
}
public function Install () {
/* Fill out manually later */
}
static function TableSearch ( & $app , $name , $erlaubtevars ) {
switch ( $name ) {
case " versandpakete_list " :
$allowed [ 'versandpakete_list' ] = array ( 'list' );
2023-10-20 15:47:37 +02:00
$heading = array ( '' , '' , 'Paket-Nr.' , 'Datum' , 'Adresse' , 'Lieferschein' , 'Versandart' , 'Tracking' , 'Menge auf Lieferscheinen' , 'Menge' , 'Gewicht' , 'Versender' , 'Bemerkung' , 'Status' , 'Monitor' , 'Menü' );
$width = array ( '1%' , '1%' , '1%' , '1%' , '10%' , '1%' , '2%' , '2%' , '1%' , '1%' , '1%' , '2%' , '10%' , '1%' , '1%' , '1%' );
2023-10-16 21:22:21 +02:00
// columns that are aligned right (numbers etc)
// $alignright = array(4,5,6,7,8);
2023-10-20 15:47:37 +02:00
$findcols = array ( 'id' , 'id' , 'id' , 'datum' );
2023-10-16 21:22:21 +02:00
$searchsql = array ( 'v.versand' , 'v.nr' , 'v.tracking' , 'v.versender' , 'v.gewicht' , 'v.bemerkung' , 'v.status' );
$defaultorder = 1 ;
$defaultorderdesc = 0 ;
2023-10-20 15:47:37 +02:00
$dropnbox = " '<img src=./themes/new/images/details_open.png class=details>' AS `open`, CONCAT('<input type= \" checkbox \" name= \" auswahl[] \" value= \" ',id,' \" />') AS `auswahl` " ;
2023-10-16 21:22:21 +02:00
$menu = " <table cellpadding=0 cellspacing=0><tr><td nowrap> " . " <a href= \" index.php?module=versandpakete&action=edit&id=%value% \" ><img src= \" ./themes/ { $app -> Conf -> WFconf [ 'defaulttheme' ] } /images/edit.svg \" border= \" 0 \" ></a> <a href= \" # \" onclick=DeleteDialog( \" index.php?module=versandpakete&action=delete&id=%value% \" );> " . " <img src= \" themes/ { $app -> Conf -> WFconf [ 'defaulttheme' ] } /images/delete.svg \" border= \" 0 \" ></a> " . " </td></tr></table> " ;
2023-10-20 15:47:37 +02:00
$menucol = 1 ;
2023-10-16 21:22:21 +02:00
$moreinfo = true ; // Allow drop down details
2023-10-18 14:35:35 +02:00
$lieferschein_link = array (
'<a href="index.php?module=lieferschein&action=edit&id=' ,
[ 'sql' => 'l.id' ],
'">' ,
[ 'sql' => 'l.belegnr' ],
'</a>'
);
2023-10-20 15:47:37 +02:00
$lieferschein_ohne_pos_link = array (
'<a href="index.php?module=lieferschein&action=edit&id=' ,
[ 'sql' => 'lop.id' ],
'">' ,
[ 'sql' => 'lop.belegnr' ],
'</a>'
);
2023-10-18 14:35:35 +02:00
$tracking_link = array (
'<a href="' ,
[ 'sql' => 'v.tracking_link' ],
'">' ,
[ 'sql' => 'v.tracking' ],
'</a>'
);
2023-10-20 15:47:37 +02:00
$sql = " SELECT SQL_CALC_FOUND_ROWS
id ,
$dropnbox ,
id ,
datum ,
if ( lieferscheine IS NULL , alop_name , name ),
if ( lieferscheine IS NULL , lieferscheine_ohne_pos , lieferscheine ),
versandart ,
tracking_link ,
lmenge ,
vmenge ,
gewicht ,
versender ,
bemerkung ,
status ,
" . $app->YUI ->IconsSQL_versandpaket(). " ,
id
FROM
(
SELECT
v . id ,
" . $app->erp ->FormatDateTimeShort('v.datum'). " AS datum ,
a . name ,
alop . name alop_name ,
GROUP_CONCAT ( DISTINCT " . $app->erp ->ConcatSQL( $lieferschein_link ). " SEPARATOR ', ' ) as lieferscheine ,
v . lieferschein_ohne_pos ,
GROUP_CONCAT ( DISTINCT " . $app->erp ->ConcatSQL( $lieferschein_ohne_pos_link ). " SEPARATOR ', ' ) as lieferscheine_ohne_pos ,
" . $app->erp ->FormatUCfirst('v.versandart'). " as versandart ,
" . $app->erp ->ConcatSQL( $tracking_link ). " as tracking_link ,
tracking ,
" . $app->erp ->FormatMenge('SUM(lp.menge)'). " as lmenge ,
" . $app->erp ->FormatMenge('SUM(vlp.menge)'). " AS vmenge ,
v . gewicht ,
v . versender ,
v . bemerkung ,
v . status
FROM
versandpakete v
LEFT JOIN
versandpaket_lieferschein_position vlp ON vlp . versandpaket = v . id
LEFT JOIN
lieferschein_position lp ON vlp . lieferschein_position = lp . id
LEFT JOIN
lieferschein l ON lp . lieferschein = l . id
LEFT JOIN
adresse a ON a . id = l . adresse
LEFT JOIN
lieferschein lop ON v . lieferschein_ohne_pos = lop . id
LEFT JOIN
adresse alop ON lop . adresse = alop . id
GROUP BY v . id
) temp
2023-10-16 21:22:21 +02:00
" ;
2023-10-20 15:47:37 +02:00
$where = " status IN ('neu', 'versendet') " ;
2023-10-18 14:35:35 +02:00
// Toggle filters
$app -> Tpl -> Add ( 'JQUERYREADY' , " $ ('#geschlossene').click( function() { fnFilterColumn1( 0 ); } ); " );
$app -> Tpl -> Add ( 'JQUERYREADY' , " $ ('#stornierte').click( function() { fnFilterColumn2( 0 ); } ); " );
for ( $r = 1 ; $r <= 2 ; $r ++ ) {
$app -> Tpl -> Add ( 'JAVASCRIPT' , '
function fnFilterColumn ' . $r . ' ( i )
{
if ( oMoreData ' . $r . $name . ' == 1 )
oMoreData ' . $r . $name . ' = 0 ;
else
oMoreData ' . $r . $name . ' = 1 ;
$ ( \ '#' . $name . ' \ ' ) . dataTable () . fnFilter (
\ ' \ ' ,
i ,
0 , 0
);
}
' );
}
$more_data1 = $app -> Secure -> GetGET ( " more_data1 " );
if ( $more_data1 == 1 ) {
2023-10-20 15:47:37 +02:00
$where .= " OR status IN ('abgeschlossen') " ;
2023-10-18 14:35:35 +02:00
} else {
}
$more_data2 = $app -> Secure -> GetGET ( " more_data2 " );
if ( $more_data2 == 1 ) {
2023-10-20 15:47:37 +02:00
$where .= " OR status IN ('storniert') " ;
2023-10-18 14:35:35 +02:00
}
else {
}
// END Toggle filters
2023-10-20 15:47:37 +02:00
$count = " SELECT count(DISTINCT id) FROM versandpakete v " ;
2023-10-16 21:22:21 +02:00
2023-10-20 15:47:37 +02:00
$groupby = " " ;
2023-10-16 21:22:21 +02:00
break ;
case " versandpakete_lieferscheine " :
$allowed [ 'versandpakete_lieferscheine' ] = array ( 'lieferscheine' );
2023-10-20 15:47:37 +02:00
$heading = array ( '' , '' , 'Lieferschein' , 'Adresse' , 'Menge' , 'Menge in Versandpaketen' , 'Paket erstellen' );
$width = array ( '1%' , '1%' , '10%' , '10%' , '10%' , '10%' , '10%' , '1%' ); // Fill out manually later
2023-10-16 21:22:21 +02:00
// columns that are aligned right (numbers etc)
// $alignright = array(4,5,6,7,8);
$findcols = array ( 'id' , 'id' );
$searchsql = array ( 'v.versand' , 'v.nr' , 'v.tracking' , 'v.versender' , 'v.gewicht' , 'v.bemerkung' , 'v.status' );
$defaultorder = 1 ;
$defaultorderdesc = 0 ;
2023-10-20 15:47:37 +02:00
$dropnbox = " '<img src=./themes/new/images/details_open.png class=details>' AS `open`, CONCAT('<input type= \" checkbox \" name= \" auswahl[] \" value= \" ',id,' \" />') AS `auswahl` " ;
$menucol = 1 ;
$moreinfoaction = " lieferschein " ;
$moreinfo = true ; // Allow drop down details
2023-10-16 21:22:21 +02:00
$menu = " <a href= \" index.php?module=versandpakete&action=add&lieferschein=%value% \" ><img src= \" themes/ { $app -> Conf -> WFconf [ 'defaulttheme' ] } /images/forward.svg \" border= \" 0 \" ></a> " ;
$sql = "
2023-10-20 15:47:37 +02:00
SELECT SQL_CALC_FOUND_ROWS
2023-10-16 21:22:21 +02:00
id ,
2023-10-20 15:47:37 +02:00
" . $dropnbox . " ,
2023-10-16 21:22:21 +02:00
CONCAT ( '<a href=\"index.php?module=lieferschein&action=edit&id=' , id , '\">' , belegnr , '</a>' ),
name ,
" . $app->erp ->FormatMenge( " SUM ( lmenge ) " ). " as lmenge ,
" . $app->erp ->FormatMenge( " SUM ( vmenge ) " ). " as vmenge ,
id
FROM
(
SELECT
l . id ,
l . belegnr ,
l . name ,
lp . menge lmenge ,
2023-10-20 15:47:37 +02:00
SUM ( vlp . menge ) vmenge
2023-10-16 21:22:21 +02:00
FROM
lieferschein l
INNER JOIN lieferschein_position lp ON lp . lieferschein = l . id
LEFT JOIN versandpaket_lieferschein_position vlp ON vlp . lieferschein_position = lp . id
LEFT JOIN versandpakete v ON vlp . versandpaket = v . id
WHERE
2023-10-20 15:47:37 +02:00
l . belegnr <> '' AND l . versendet <> 1 AND ( v . status IS NULL OR ( v . status != 'storniert' AND v . status <> 'abgeschlossen' ))
2023-10-16 21:22:21 +02:00
GROUP BY lp . id
) l_mengen
" ;
$where = " " ;
// $count = "SELECT count(DISTINCT id) FROM versandpakete v WHERE $where";
$groupby = " GROUP BY id " ;
break ;
case " versandpakete_paketinhalt_list " :
$id = ( int ) $app -> Secure -> GetGET ( 'id' );
$allowed [ 'versandpakete_paketinhalt_list' ] = array ( 'list' );
2023-10-20 15:47:37 +02:00
$heading = array ( 'Lieferschein' , 'Pos' , 'Artikel' , 'Artikel-Nr.' , 'Menge Lieferschein' , 'Menge Paket' , 'Menü' , '' );
2023-10-16 21:22:21 +02:00
$width = array ( '10%' , '10%' , '10%' ); // Fill out manually later
// columns that are aligned right (numbers etc)
// $alignright = array(4,5,6,7,8);
$findcols = array ( 'lp.id' , 'v.id' , 'v.id' , 'a.name' , 'l.belegnr' , 'v.tracking' , 'v.versender' , 'v.gewicht' , 'v.bemerkung' , 'v.status' );
$searchsql = array ( 'v.versand' , 'v.nr' , 'v.tracking' , 'v.versender' , 'v.gewicht' , 'v.bemerkung' , 'v.status' );
$defaultorder = 1 ;
$defaultorderdesc = 0 ;
2023-10-20 15:47:37 +02:00
$paket_link = array (
'<a href="index.php?module=versandpakete&action=edit&id=' ,
[ 'sql' => 'vlp.versandpaket' ],
'">' ,
[ 'sql' => 'vlp.versandpaket' ],
'</a>'
);
// $menu = "<a href=\"index.php?module=versandpakete&action=deletepos&pos=%value%\"><img src=\"themes/{$app->Conf->WFconf['defaulttheme']}/images/delete.svg\" border=\"0\"></a>";
$menu = " " ;
2023-10-16 21:22:21 +02:00
$menucol = 6 ;
$lieferschein_link = array (
'<a href="index.php?module=lieferschein&action=edit&id=' ,
[ 'sql' => 'l.id' ],
'">' ,
[ 'sql' => 'l.belegnr' ],
'</a>'
);
2023-10-20 15:47:37 +02:00
$delete_link = array (
'<a href="index.php?module=versandpakete&action=deletepos&id=' ,
[ 'sql' => 'v.id' ],
'&pos=' ,
[ 'sql' => 'vlp.id' ],
'">' ,
" <img src= \" themes/ { $app -> Conf -> WFconf [ 'defaulttheme' ] } /images/delete.svg \" border= \" 0 \" > " ,
'</a>'
);
2023-10-16 21:22:21 +02:00
$sql = " SELECT SQL_CALC_FOUND_ROWS
lp . id ,
" . $app->erp ->ConcatSQL( $lieferschein_link ). " as lieferschein ,
lp . sort ,
a . name_de ,
a . nummer ,
" . $app->erp ->FormatMenge('lp.menge'). " as l_menge ,
" . $app->erp ->FormatMenge('SUM(vlp.menge)'). " as v_menge ,
2023-10-20 15:47:37 +02:00
" . $app->erp ->ConcatSQL( $delete_link ). " as delete_link ,
2023-10-16 21:22:21 +02:00
vlp . id
FROM
versandpakete v
INNER JOIN versandpaket_lieferschein_position vlp ON
v . id = vlp . versandpaket
INNER JOIN lieferschein_position lp ON
vlp . lieferschein_position = lp . id
INNER JOIN lieferschein l ON
lp . lieferschein = l . id
INNER JOIN artikel a ON
lp . artikel = a . id
" ;
$where = " v.id = " . $id ;
// $count = "SELECT count(DISTINCT id) FROM versandpakete v WHERE $where";
$groupby = " GROUP BY lp.id " ;
break ;
case " versandpakete_lieferschein_paket_list " :
$lieferschein_id = $app -> User -> GetParameter ( 'versandpakete_lieferschein' );
$allowed [ 'versandpakete_lieferschein_paket_list' ] = array ( 'list' );
$heading = array ( 'Pos' , 'Artikel' , 'Artikel-Nr.' , 'Menge Lieferschein' , 'Menge in Versandpaketen' , 'Paket-Nr.' , 'Menü' );
$width = array ( '10%' , '10%' , '10%' ); // Fill out manually later
// columns that are aligned right (numbers etc)
// $alignright = array(4,5,6,7,8);
$findcols = array ( 'lp.id' , 'lp.id' );
$searchsql = array ( 'v.versand' , 'v.nr' , 'v.tracking' , 'v.versender' , 'v.gewicht' , 'v.bemerkung' , 'v.status' );
$defaultorder = 1 ;
$defaultorderdesc = 0 ;
$menu = " " ;
$menucol = 6 ;
$paket_link = array (
'<a href="index.php?module=versandpakete&action=edit&id=' ,
[ 'sql' => 'vlp.versandpaket' ],
'">' ,
[ 'sql' => 'vlp.versandpaket' ],
'</a>'
);
$sql = " SELECT SQL_CALC_FOUND_ROWS
vlp . id ,
lp . sort ,
a . name_de ,
a . nummer ,
" . $app->erp ->FormatMenge('lp.menge'). " as l_menge ,
" . $app->erp ->FormatMenge('SUM(vlp.menge)'). " as v_menge ,
2023-10-20 15:47:37 +02:00
GROUP_CONCAT ( " . $app->erp ->ConcatSQL( $paket_link ). " SEPARATOR ', ' ) as pakete ,
2023-10-16 21:22:21 +02:00
vlp . id
FROM lieferschein l
INNER JOIN lieferschein_position lp ON
lp . lieferschein = l . id
INNER JOIN artikel a ON
lp . artikel = a . id
LEFT JOIN versandpaket_lieferschein_position vlp ON vlp . lieferschein_position = lp . id
" ;
$where = " l.id = " . $lieferschein_id ;
// $count = "SELECT count(DISTINCT id) FROM versandpakete v WHERE $where";
// $groupby = "GROUP BY lp.id";
$groupby = " GROUP BY lp.id " ;
break ;
}
$erg = false ;
foreach ( $erlaubtevars as $k => $v ) {
if ( isset ( $$v )) {
$erg [ $v ] = $$v ;
}
}
return $erg ;
}
function versandpakete_menu () {
$this -> app -> erp -> MenuEintrag ( " index.php?module=versandpakete&action=list " , " Übersicht " );
$this -> app -> erp -> MenuEintrag ( " index.php?module=versandpakete&action=lieferscheine " , " Offene Lieferscheine " );
$this -> app -> erp -> MenuEintrag ( " index.php?module=versandpakete&action=create " , " Neu anlegen " );
}
2023-10-18 14:35:35 +02:00
function versandpakete_list () {
2023-10-16 21:22:21 +02:00
$this -> versandpakete_menu ();
2023-10-18 14:35:35 +02:00
// Status select
$options_text = " " ;
foreach ( self :: STATUS as $status )
{
$options_text .= " <option value= \" " . $status . " \" > " . $status . " </option> " ;
}
$this -> app -> Tpl -> Set ( 'STATUS_OPTIONS' , $options_text );
2023-10-16 21:22:21 +02:00
$this -> app -> YUI -> TableSearch ( 'TAB1' , 'versandpakete_list' , " show " , " " , " " , basename ( __FILE__ ), __CLASS__ );
$this -> app -> Tpl -> Parse ( 'PAGE' , " versandpakete_list.tpl " );
}
2023-10-18 14:35:35 +02:00
function versandpakete_stapelverarbeitung () {
// Process multi action
$auswahl = $this -> app -> Secure -> GetPOST ( 'auswahl' );
$selectedIds = [];
if ( ! empty ( $auswahl )) {
foreach ( $auswahl as $selectedId ) {
$selectedId = ( int ) $selectedId ;
if ( $selectedId > 0 ) {
$selectedIds [] = $selectedId ;
}
}
$status = $this -> app -> Secure -> GetPOST ( 'status' );
$sql = " UPDATE versandpakete SET status = ' " . $status . " ' " ;
$sql .= " WHERE id IN ( " . implode ( " , " , $selectedIds ) . " ) " ;
$this -> app -> DB -> Update ( $sql );
}
$this -> versandpakete_list ();
}
2023-10-16 21:22:21 +02:00
function versandpakete_lieferscheine () {
$this -> versandpakete_menu ();
$this -> app -> YUI -> TableSearch ( 'TAB1' , 'versandpakete_lieferscheine' , " show " , " " , " " , basename ( __FILE__ ), __CLASS__ );
$this -> app -> Tpl -> Parse ( 'PAGE' , " versandpakete_lieferscheine.tpl " );
}
public function versandpakete_delete () {
$id = ( int ) $this -> app -> Secure -> GetGET ( 'id' );
2023-10-20 15:47:37 +02:00
$this -> app -> DB -> Delete ( " UPDATE `versandpakete` SET status='storniert' WHERE `id` = ' { $id } ' AND `status` IN ('neu', 'versendet') " );
2023-10-16 21:22:21 +02:00
$this -> app -> Tpl -> Set ( 'MESSAGE' , " <div class= \" error \" >Der Eintrag wurde storniert.</div> " );
$this -> versandpakete_list ();
}
2023-10-20 15:47:37 +02:00
public function versandpakete_deletepos () {
$id = ( int ) $this -> app -> Secure -> GetGET ( 'id' );
$pos = ( int ) $this -> app -> Secure -> GetGET ( 'pos' );
$sql = " DELETE vlp FROM `versandpaket_lieferschein_position` vlp INNER JOIN versandpakete v ON vlp.versandpaket = v.id WHERE vlp.`id` = ' { $pos } ' AND v.status = 'neu' " ;
$this -> app -> DB -> Delete ( $sql );
header ( " Location: index.php?module=versandpakete&action=edit&id= " . $id );
}
2023-10-16 21:22:21 +02:00
/*
* Edit versandpakete item
* If id is empty , create a new one
*/
function versandpakete_edit () {
$this -> versandpakete_menu ();
$id = $this -> app -> Secure -> GetGET ( 'id' );
// Check if other users are editing this id
if ( $this -> app -> erp -> DisableModul ( 'versandpakete' , $id ))
{
return ;
}
$this -> app -> Tpl -> Set ( 'ID' , $id );
$input = $this -> GetInput ();
$submit = $this -> app -> Secure -> GetPOST ( 'submit' );
if ( empty ( $id )) {
// New item
2023-10-18 14:35:35 +02:00
$new_item = true ;
2023-10-16 21:22:21 +02:00
$id = 'NULL' ;
2023-10-20 15:47:37 +02:00
$sql = " INSERT INTO versandpakete (status, versender) VALUES ('neu',' " . $this -> app -> User -> GetName () . " ') " ;
$this -> app -> DB -> Insert ( $sql );
$id = $this -> app -> DB -> GetInsertId ();
header ( " Location: index.php?module=versandpakete&action=edit&id= " . $id );
2023-10-16 21:22:21 +02:00
}
2023-10-20 15:47:37 +02:00
// Check versandart
if ( empty ( $input [ 'versandart' ])) {
$sql = " UPDATE versandpakete SET versandart = (SELECT versandart FROM ( " . self :: SQL_VERSANDPAKETE_LIEFERSCHEIN . " ) v INNER JOIN lieferschein l ON v.lieferschein = l.id WHERE versandpaket = " . $id . " LIMIT 1) " ;
$this -> app -> DB -> Update ( $sql );
}
2023-10-16 21:22:21 +02:00
switch ( $submit ) {
case 'speichern' :
// Write to database
// Add checks here
2023-10-20 15:47:37 +02:00
$sql = " SELECT status FROM versandpakete WHERE id = " . $id ;
$input [ 'status' ] = $this -> app -> DB -> SelectArr ( $sql )[ 0 ][ 'status' ];
if ( $input [ 'status' ] != 'neu' ) {
$input = Array ( 'bemerkung' => $input [ 'bemerkung' ]);
}
2023-10-16 21:22:21 +02:00
$columns = " id, " ;
$values = " $id , " ;
$update = " " ;
$fix = " " ;
foreach ( $input as $key => $value ) {
$columns = $columns . $fix . $key ;
$values = $values . $fix . " ' " . $value . " ' " ;
$update = $update . $fix . $key . " = ' $value ' " ;
$fix = " , " ;
}
$sql = " INSERT INTO versandpakete ( " . $columns . " ) VALUES ( " . $values . " ) ON DUPLICATE KEY UPDATE " . $update ;
$this -> app -> DB -> Insert ( $sql );
2023-10-20 15:47:37 +02:00
$this -> app -> Tpl -> Set ( 'MESSAGE' , " <div class= \" success \" >Die Einstellungen wurden erfolgreich übernommen.</div> " );
2023-10-18 14:35:35 +02:00
break ;
2023-10-20 15:47:37 +02:00
case 'absenden' :
$sql = " UPDATE versandpakete SET status = 'versendet' WHERE id = " . $id ;
$this -> app -> DB -> Update ( $sql );
break ;
case 'abschliessen' :
$sql = " UPDATE versandpakete SET status = 'abgeschlossen' WHERE id = " . $id ;
$this -> app -> DB -> Update ( $sql );
break ;
2023-10-16 21:22:21 +02:00
}
// Load values again from database
$dropnbox = " '<img src=./themes/new/images/details_open.png class=details>' AS `open`, CONCAT('<input type= \" checkbox \" name= \" auswahl[] \" value= \" ',v.id,' \" />') AS `auswahl` " ;
2023-10-20 15:47:37 +02:00
$result = $this -> app -> DB -> SelectArr ( " SELECT SQL_CALC_FOUND_ROWS v.id, $dropnbox , " . $this -> app -> erp -> FormatDate ( 'datum' ) . " as datum, v.versand, v.versandart, v.nr, v.tracking, v.tracking_link, v.versender, v.gewicht, v.bemerkung, v.status, v.id FROM versandpakete v " . " WHERE id= $id " );
2023-10-16 21:22:21 +02:00
foreach ( $result [ 0 ] as $key => $value ) {
$this -> app -> Tpl -> Set ( strtoupper ( $key ), $value );
}
2023-10-20 15:47:37 +02:00
2023-10-16 21:22:21 +02:00
// Check for only one delivery adress
$this -> app -> YUI -> AutoComplete ( " lieferschein " , " lieferschein " );
$sql = " SELECT DISTINCT a.name, l.adresse FROM ( " . self :: SQL_VERSANDPAKETE_LIEFERSCHEIN . " ) vpl INNER JOIN lieferschein l ON vpl.lieferschein = l.id INNER JOIN adresse a ON l.adresse = a.id WHERE vpl.versandpaket = " . $id ;
$adress_check = $this -> app -> DB -> SelectArr ( $sql );
if ( ! empty ( $adress_check )) {
if ( count ( $adress_check ) != 1 ) {
// More than one adress for the packet -> error
} else {
$this -> app -> Tpl -> Set ( 'ADRESSE' , $adress_check [ 0 ][ 'name' ]);
$this -> app -> YUI -> AutoComplete ( " lieferschein " , " kundenlieferschein " , 0 , " &adresse= " . $adress_check [ 0 ][ 'adresse' ]);
}
}
2023-10-18 14:35:35 +02:00
if ( $new_item ) {
$this -> app -> Tpl -> Set ( 'LIEFERSCHEIN_POS_HIDDEN' , 'hidden' );
2023-10-16 21:22:21 +02:00
}
2023-10-20 15:47:37 +02:00
$sql = " SELECT
lieferschein_ohne_pos ,
belegnr ,
lieferschein_position ,
l . versandart
FROM versandpakete v
LEFT JOIN lieferschein l ON v . lieferschein_ohne_pos = l . id
LEFT JOIN versandpaket_lieferschein_position vlp ON vlp . versandpaket = v . id
WHERE v . id = " . $id ;
$lieferschein_check = $this -> app -> DB -> SelectArr ( $sql );
if ( empty ( $lieferschein_check [ 0 ][ 'lieferschein_position' ]) && empty ( $lieferschein_check [ 0 ][ 'lieferschein_ohne_pos' ])) {
$this -> app -> Tpl -> Set ( 'NO_ADDRESS_HIDDEN' , 'hidden' );
$this -> app -> Tpl -> Set ( 'PAKETMARKE_ADD_HIDDEN' , 'hidden' );
}
if ( empty ( $lieferschein_check [ 0 ][ 'lieferschein_ohne_pos' ])) {
$this -> app -> Tpl -> Set ( 'LIEFERSCHEIN_OHNE_POS_HIDDEN' , 'hidden' );
2023-10-18 14:35:35 +02:00
} else {
2023-10-20 15:47:37 +02:00
$this -> app -> Tpl -> Set ( 'LIEFERSCHEIN_ADD_POS_HIDDEN' , 'hidden' );
2023-10-18 14:35:35 +02:00
}
2023-10-20 15:47:37 +02:00
if ( empty ( $lieferschein_check [ 0 ][ 'lieferschein_position' ])) {
$this -> app -> Tpl -> Set ( 'LIEFERSCHEIN_OHNE_POS' , $lieferschein_check [ 0 ][ 'belegnr' ]);
$this -> app -> Tpl -> Set ( 'LIEFERSCHEIN_OHNE_POS_ID' , $lieferschein_check [ 0 ][ 'lieferschein_ohne_pos' ]);
$this -> app -> Tpl -> Set ( 'LIEFERSCHEIN_POS_HIDDEN' , 'hidden' );
}
2023-10-18 14:35:35 +02:00
if ( $result [ 0 ][ 'status' ] != 'neu' ) {
$this -> app -> Tpl -> Set ( 'LIEFERSCHEIN_ADD_POS_HIDDEN' , 'hidden' );
$this -> app -> Tpl -> Set ( 'LIEFERSCHEIN_GEWICHT_DISABLED' , 'disabled' );
2023-10-20 15:47:37 +02:00
$this -> app -> Tpl -> Set ( 'PAKETMARKE_ADD_HIDDEN' , 'hidden' );
}
if ( $result [ 0 ][ 'status' ] != 'versendet' ) {
$this -> app -> Tpl -> Set ( 'ABSCHLIESSEN_HIDDEN' , 'hidden' );
} else {
$this -> app -> Tpl -> Set ( 'ABSENDEN_HIDDEN' , 'hidden' );
2023-10-18 14:35:35 +02:00
}
if ( ! empty ( $result [ 0 ][ 'tracking' ])) {
2023-10-20 15:47:37 +02:00
$this -> app -> Tpl -> Set ( 'PAKETMARKE_ADD_HIDDEN' , 'hidden' );
} else {
2023-10-18 14:35:35 +02:00
$this -> app -> Tpl -> Set ( 'PAKETMARKE_HIDDEN' , 'hidden' );
2023-10-20 15:47:37 +02:00
$this -> app -> Tpl -> Set ( 'ABSENDEN_HIDDEN' , 'hidden' );
}
$file_attachments = $this -> app -> erp -> GetDateiSubjektObjekt ( 'paketmarke' , 'versandpaket' , $id );
if ( ! empty ( $file_attachments )) {
foreach ( $file_attachments as $file_attachment ) {
$this -> app -> Tpl -> Add ( 'PAKETMARKE_LINK' , " index.php?module=dateien&action=send&id= " . $file_attachment );
}
2023-10-16 21:22:21 +02:00
}
2023-10-20 15:47:37 +02:00
$sql = " SELECT SQL_CALC_FOUND_ROWS
" . $this->app ->YUI->IconsSQL_versandpaket(). " icons
FROM
(
SELECT
" . $this->app ->erp->FormatMenge('SUM(lp.menge)'). " as lmenge ,
" . $this->app ->erp->FormatMenge('SUM(vlp.menge)'). " AS vmenge ,
v . status ,
v . lieferschein_ohne_pos ,
GROUP_CONCAT ( DISTINCT lieferschein SEPARATOR ', ' ) as lieferscheine ,
tracking
FROM
versandpakete v
LEFT JOIN
versandpaket_lieferschein_position vlp ON vlp . versandpaket = v . id
LEFT JOIN
lieferschein_position lp ON vlp . lieferschein_position = lp . id
WHERE v . id = " . $id . "
GROUP BY v . id
) temp
" ;
$icons = $this -> app -> DB -> SelectArr ( $sql );
$this -> app -> Tpl -> Set ( 'ICONS' , $icons [ 0 ][ 'icons' ]);
2023-10-16 21:22:21 +02:00
$this -> app -> YUI -> TableSearch ( 'PAKETINHALT' , 'versandpakete_paketinhalt_list' , " show " , " " , " " , basename ( __FILE__ ), __CLASS__ );
$this -> app -> Tpl -> Parse ( 'PAGE' , " versandpakete_edit.tpl " );
}
2023-10-18 14:35:35 +02:00
function versandpakete_add () {
2023-10-16 21:22:21 +02:00
$this -> versandpakete_menu ();
$id = $this -> app -> Secure -> GetGET ( 'id' );
if ( empty ( $id )) {
$lieferschein = $this -> app -> Secure -> GetGET ( 'lieferschein' );
if ( empty ( $lieferschein )) {
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" error \" >Kein Lieferschein angegeben.</div> " );
header ( " Location: index.php?module=versandpakete&action=list&msg= $msg " );
} else {
$lieferschein_belegnr = $this -> app -> erp -> ReplaceLieferschein ( false , $lieferschein , false ); // Parameters: Target db?, value, from form?
/* Create new paket and add the given lieferschein */
2023-10-20 15:47:37 +02:00
$sql = " INSERT INTO versandpakete (status, versender) VALUES ('neu',' " . $this -> app -> User -> GetName () . " ') " ;
2023-10-16 21:22:21 +02:00
$this -> app -> DB -> Insert ( $sql );
$id = $this -> app -> DB -> GetInsertId ();
}
} else { // $id not empty
$lieferschein_input = $this -> app -> Secure -> GetPOST ( 'lieferschein' );
$lieferschein = $this -> app -> erp -> ReplaceLieferschein ( true , $lieferschein_input , true ); // Parameters: Target db?, value, from form?
$lieferschein_belegnr = $this -> app -> erp -> ReplaceLieferschein ( false , $lieferschein_input , true ); // Parameters: Target db?, value, from form?
if ( empty ( $lieferschein_input )) {
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" error \" >Kein Lieferschein angegeben.</div> " );
header ( " Location: index.php?module=versandpakete&action=edit&id= " . $id . " &msg= $msg " );
}
}
// Check if other users are editing this id
if ( $this -> app -> erp -> DisableModul ( 'versandpakete' , $id ))
{
return ;
}
$artikel_input = $this -> app -> Secure -> GetPOST ( 'artikel' );
$artikel = $this -> app -> erp -> ReplaceArtikel ( true , $artikel_input , true ); // Parameters: Target db?, value, from form?
$menge = $this -> app -> Secure -> GetPOST ( 'menge' );
$this -> app -> Tpl -> Set ( 'ID' , $id );
$input = $this -> GetInput ();
$submit = $this -> app -> Secure -> GetPOST ( 'submit' );
// Check Status
2023-10-18 14:35:35 +02:00
$sql = " SELECT status, lieferschein_ohne_pos FROM versandpakete WHERE id = " . $id . " LIMIT 1 " ;
2023-10-16 21:22:21 +02:00
$result = $this -> app -> DB -> SelectArr ( $sql );
2023-10-18 14:35:35 +02:00
if ( $result [ 0 ][ 'status' ] != 'neu' ) {
return ;
}
if ( ! empty ( $result [ 0 ][ 'lieferschein_ohne_pos' ])) {
2023-10-16 21:22:21 +02:00
return ;
}
switch ( $submit ) {
case 'hinzufuegen' :
if ( $menge <= 0 ) {
$msg = " <div class= \" error \" >Falsche Mengenangabe.</div> " ;
break ;
}
// Find a matching lieferschein_position
$sql = " SELECT
lp . id AS lp_id ,
MAX ( lp . menge ) AS lp_menge ,
SUM ( vlp . menge ) AS v_menge
FROM lieferschein_position lp
LEFT JOIN versandpaket_lieferschein_position vlp ON vlp . lieferschein_position = lp . id
WHERE lp . lieferschein = " . $lieferschein . " AND lp . artikel = " . $artikel . "
GROUP BY lp . id
" ;
$lieferschein_positionen = $this -> app -> DB -> SelectArr ( $sql );
if ( empty ( $lieferschein_positionen )) {
$msg = " <div class= \" error \" >Keine passende Lieferscheinposition gefunden.</div> " ;
break ;
}
2023-10-20 15:47:37 +02:00
$buchmenge_gesamt = 0 ;
$buchmenge = 0 ;
2023-10-16 21:22:21 +02:00
foreach ( $lieferschein_positionen as $lieferschein_position ) {
$restmenge = $lieferschein_position [ 'lp_menge' ] - $lieferschein_position [ 'v_menge' ];
if ( $restmenge <= 0 ) {
continue ;
}
2023-10-20 15:47:37 +02:00
2023-10-16 21:22:21 +02:00
if ( $menge > $restmenge ) {
$buchmenge = $restmenge ;
2023-10-20 15:47:37 +02:00
} else {
$buchmenge = $menge ;
2023-10-16 21:22:21 +02:00
}
2023-10-20 15:47:37 +02:00
$buchmenge_gesamt += $buchmenge ;
$menge -= $buchmenge ;
2023-10-16 21:22:21 +02:00
2023-10-20 15:47:37 +02:00
$sql = " INSERT INTO versandpaket_lieferschein_position (versandpaket, lieferschein_position, menge) VALUES ( " . $id . " , " . $lieferschein_position [ 'lp_id' ] . " , " . $buchmenge . " ) ON DUPLICATE KEY UPDATE menge = menge+ " . $buchmenge . " " ;
2023-10-16 21:22:21 +02:00
$this -> app -> DB -> Insert ( $sql );
2023-10-20 15:47:37 +02:00
if ( $menge <= 0 ) {
break ;
}
2023-10-16 21:22:21 +02:00
}
2023-10-20 15:47:37 +02:00
if ( $menge > 0 ) {
2023-10-16 21:22:21 +02:00
$msg = " <div class= \" error \" >Menge wurde angepasst auf " . $buchmenge_gesamt . " .</div> " ;
}
break ;
case 'lieferschein_komplett_hinzufuegen' :
// Find all lieferschein_position
$sql = " SELECT
lp . id AS lp_id ,
MAX ( lp . menge ) AS lp_menge ,
SUM ( vlp . menge ) AS v_menge
FROM lieferschein_position lp
LEFT JOIN versandpaket_lieferschein_position vlp ON vlp . lieferschein_position = lp . id
WHERE lp . lieferschein = " . $lieferschein . "
GROUP BY lp . id
" ;
$lieferschein_positionen = $this -> app -> DB -> SelectArr ( $sql );
if ( empty ( $lieferschein_positionen )) {
$msg = " <div class= \" error \" >Keine passende Lieferscheinposition gefunden.</div> " ;
break ;
}
foreach ( $lieferschein_positionen as $lieferschein_position ) {
$buchmenge = $lieferschein_position [ 'lp_menge' ] - $lieferschein_position [ 'v_menge' ];
2023-10-20 15:47:37 +02:00
$sql = " INSERT INTO versandpaket_lieferschein_position (versandpaket, lieferschein_position, menge) VALUES ( " . $id . " , " . $lieferschein_position [ 'lp_id' ] . " , " . $buchmenge . " ) ON DUPLICATE KEY UPDATE menge = menge+' " . $buchmenge . " ' " ;
2023-10-16 21:22:21 +02:00
$this -> app -> DB -> Insert ( $sql );
}
2023-10-20 15:47:37 +02:00
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" info \" >Lieferschein hinzugefügt.</div> " );
header ( " Location: index.php?module=versandpakete&action=edit&id= " . $id . " &msg= $msg " );
2023-10-16 21:22:21 +02:00
break ;
}
$this -> app -> Tpl -> Set ( 'LIEFERSCHEIN' , $lieferschein_belegnr );
$this -> app -> Tpl -> Set ( 'LIEFERSCHEIN_ID' , $lieferschein );
$this -> app -> Tpl -> Set ( 'VERSANDPAKET_ID' , $id );
$this -> app -> YUI -> AutoComplete ( " artikel " , " artikelnummerbeleg " , 0 , " &doctype=lieferschein&doctypeid= " . $lieferschein );
// For transfer to tablesearch
$this -> app -> User -> SetParameter ( 'versandpakete_lieferschein' , $lieferschein );
$this -> app -> User -> SetParameter ( 'versandpakete_versandpaket' , $id );
$this -> app -> YUI -> TableSearch ( 'LIEFERSCHEININHALT' , 'versandpakete_lieferschein_paket_list' , " show " , " " , " " , basename ( __FILE__ ), __CLASS__ );
$this -> app -> YUI -> TableSearch ( 'PAKETINHALT' , 'versandpakete_paketinhalt_list' , " show " , " " , " " , basename ( __FILE__ ), __CLASS__ );
$this -> app -> Tpl -> Set ( 'MESSAGE' , $msg );
$this -> app -> Tpl -> Parse ( 'PAGE' , " versandpakete_add.tpl " );
}
function versandpakete_minidetail () {
$id = $this -> app -> Secure -> GetGET ( 'id' );
$table = new EasyTable ( $this -> app );
$table -> Query ( " SELECT SQL_CALC_FOUND_ROWS
l . belegnr as Lieferschein ,
lp . sort as Pos ,
a . name_de as Artikel ,
a . nummer as `Artikel-Nr.` ,
" . $this->app ->erp->FormatMenge('lp.menge'). " as `Menge Lieferschein` ,
" . $this->app ->erp->FormatMenge('SUM(vlp.menge)'). " as `Menge Paket`
FROM
versandpakete v
INNER JOIN versandpaket_lieferschein_position vlp ON
v . id = vlp . versandpaket
INNER JOIN lieferschein_position lp ON
vlp . lieferschein_position = lp . id
INNER JOIN lieferschein l ON
lp . lieferschein = l . id
INNER JOIN artikel a ON
lp . artikel = a . id
WHERE vlp . versandpaket = " . $id . "
GROUP BY
l . belegnr , lp . id
ORDER BY l . belegnr , lp . sort
" );
$table -> DisplayNew ( 'TABLE' , 'Menge Paket' , 'noAction' );
$this -> app -> Tpl -> Output ( 'table.tpl' );
$this -> app -> ExitXentral ();
2023-10-18 14:35:35 +02:00
}
2023-10-20 15:47:37 +02:00
function versandpakete_minidetaillieferschein () {
$id = $this -> app -> Secure -> GetGET ( 'id' );
$table = new EasyTable ( $this -> app );
$paket_link = array (
'<a href="index.php?module=versandpakete&action=edit&id=' ,
[ 'sql' => 'versandpaket' ],
'">' ,
[ 'sql' => 'versandpaket' ],
'</a>'
);
$table -> Query ( "
SELECT
lp . sort AS Pos ,
lp . bezeichnung ,
" . $this->app ->erp->FormatMenge('lp.menge'). " AS 'Menge' ,
" . $this->app ->erp->FormatMenge('SUM(vlp.menge)'). " AS 'Menge in Versandpaketen' ,
GROUP_CONCAT ( DISTINCT " . $this->app ->erp->ConcatSQL( $paket_link ). " SEPARATOR ', ' )
FROM
lieferschein l
INNER JOIN lieferschein_position lp ON lp . lieferschein = l . id
INNER JOIN versandpaket_lieferschein_position vlp ON vlp . lieferschein_position = lp . id
WHERE l . id = " . $id . "
GROUP BY lp . id "
);
$table -> DisplayNew ( 'TABLE' , 'Paket' , 'noAction' );
$this -> app -> Tpl -> Output ( 'table.tpl' );
$this -> app -> ExitXentral ();
}
2023-10-18 14:35:35 +02:00
function versandpakete_paketmarke ()
{
$this -> versandpakete_menu ();
$id = $this -> app -> Secure -> GetGET ( 'id' );
2023-10-20 15:47:37 +02:00
$this -> app -> erp -> MenuEintrag ( " index.php?module=versandpakete&action=edit&id= " . $id , " Zurück " );
2023-10-18 14:35:35 +02:00
$this -> app -> Tpl -> Set ( 'TABTEXT' , " Paketmarke " );
$result = $this -> app -> DB -> SelectRow ( " SELECT va.id, va.modul FROM versandpakete vp INNER JOIN versandarten va ON vp.versandart = va.type LIMIT 1 " );
if ( empty ( $result [ 'modul' ]) || empty ( $result [ 'id' ])) {
$this -> app -> Tpl -> addMessage ( 'error' , 'Bitte zuerst eine gültige Versandart auswählen' , false , 'PAGE' );
return ;
}
$lieferschein = $this -> app -> DB -> SelectRow ( " SELECT * FROM ( " . self :: SQL_VERSANDPAKETE_LIEFERSCHEIN . " ) temp WHERE versandpaket = " . $id . " LIMIT 1 " );
$versandmodul = $this -> app -> erp -> LoadVersandModul ( $result [ 'modul' ], $result [ 'id' ]);
2023-10-20 15:47:37 +02:00
$versandmodul -> Paketmarke ( 'TAB1' , 'lieferschein' , $lieferschein [ 'lieferschein' ], $id );
2023-10-18 14:35:35 +02:00
$this -> app -> Tpl -> Parse ( 'PAGE' , " tabview.tpl " );
}
2023-10-16 21:22:21 +02:00
/**
* Get all paramters from html form and save into $input
*/
public function GetInput () : array {
$input = array ();
$input [ 'gewicht' ] = $this -> app -> Secure -> GetPOST ( 'gewicht' );
2023-10-20 15:47:37 +02:00
$input [ 'bemerkung' ] = $this -> app -> Secure -> GetPOST ( 'bemerkung' );
2023-10-16 21:22:21 +02:00
return $input ;
}
/*
* Set all fields in the page corresponding to $input
*/
function SetInput ( $input ) {
// $this->app->Tpl->Set('EMAIL', $input['email']);
$this -> app -> Tpl -> Set ( 'VERSAND' , $input [ 'versand' ]);
$this -> app -> Tpl -> Set ( 'NR' , $input [ 'nr' ]);
$this -> app -> Tpl -> Set ( 'TRACKING' , $input [ 'tracking' ]);
$this -> app -> Tpl -> Set ( 'VERSENDER' , $input [ 'versender' ]);
$this -> app -> Tpl -> Set ( 'GEWICHT' , $input [ 'gewicht' ]);
$this -> app -> Tpl -> Set ( 'BEMERKUNG' , $input [ 'bemerkung' ]);
$this -> app -> Tpl -> Set ( 'STATUS' , $input [ 'status' ]);
}
}