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
" ;
2023-10-25 13:26:52 +02:00
const SQL_VERSANDPAKETE_LIEFERSCHEIN_WITH_POS = "
SELECT DISTINCT
versandpaket ,
lieferschein
FROM
versandpaket_lieferschein_position vlp
INNER JOIN lieferschein_position lp ON
vlp . lieferschein_position = lp . id
" ;
2023-10-16 21:22:21 +02:00
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 " );
2023-10-25 13:26:52 +02:00
$this -> app -> ActionHandler ( " lieferungen " , " versandpakete_lieferungen " );
$this -> app -> ActionHandler ( " lieferung " , " versandpakete_lieferung " );
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 ) {
2023-10-25 13:26:52 +02:00
$lieferschein_filter = null ;
2023-10-16 21:22:21 +02:00
switch ( $name ) {
2023-10-25 13:26:52 +02:00
case " lieferung_versandpakete_list " :
$lieferschein_filter = $app -> User -> GetParameter ( 'versandpakete_lieferschein_filter' );
if ( $lieferschein_filter ) {
2023-11-01 15:42:21 +01:00
$lieferschein_filter_where = " WHERE lieferschein = " . $lieferschein_filter . " OR lieferschein_ohne_pos = " . $lieferschein_filter ;
2023-10-26 20:23:19 +02:00
$lieferung_link = " &lieferung= " . $lieferschein_filter ;
2023-10-25 13:26:52 +02:00
}
// break omitted intentionally
2023-10-16 21:22:21 +02:00
case " versandpakete_list " :
$allowed [ 'versandpakete_list' ] = array ( 'list' );
2023-11-01 15:42:21 +01:00
$heading = array ( '' , '' , 'Paket-Nr.' , 'Datum' , 'Adresse' , 'Lieferung' , 'Versandart' , 'Tracking' , 'Menge auf Lieferscheinen' , 'Menge' , 'Gewicht' , 'Versender' , 'Bemerkung' , 'Status' , 'Monitor' , 'Menü' , '' );
2023-10-25 13:26:52 +02:00
$width = array ( '1%' , '1%' , '1%' , '1%' , '10%' , '1%' , '2%' , '2%' , '1%' , '1%' , '1%' , '2%' , '10%' , '1%' , '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-25 13:26:52 +02:00
$findcols = array ( 'id' , 'id' , 'id' , 'datum' , 'name' , 'lieferscheine' , 'versandart' , 'tracking' , 'lmenge' , 'vmenge' , 'gewicht' , 'versender' , 'bemerkung' , 'status' , 'id' , 'id' );
2023-10-22 18:22:07 +02:00
$searchsql = array ( 'name' , 'if (lieferscheine IS NULL, lieferscheine_ohne_pos, lieferscheine)' , 'tracking' , 'bemerkung' );
2023-10-16 21:22:21 +02:00
$defaultorder = 1 ;
$defaultorderdesc = 0 ;
2023-10-22 18:22:07 +02:00
$aligncenter = [ 9 , 10 , 11 ];
2023-10-16 21:22:21 +02:00
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
2023-10-25 13:26:52 +02:00
$menu = " " ;
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-25 13:26:52 +02:00
$menu_link = array (
'<a href="index.php?module=versandpakete&action=edit&id=' ,
[ 'sql' => 'id' ],
2023-10-26 20:23:19 +02:00
$lieferung_link ,
2023-10-25 13:26:52 +02:00
'">' ,
" <img src= \" ./themes/ { $app -> Conf -> WFconf [ 'defaulttheme' ] } /images/edit.svg \" border= \" 0 \" ></a> " ,
'</a>' ,
" <a href= \" # \" onclick=DeleteDialog( \" index.php?module=versandpakete&action=delete&id= " ,
[ 'sql' => 'id' ],
" \" );> " . " <img src= \" themes/ { $app -> Conf -> WFconf [ 'defaulttheme' ] } /images/delete.svg \" border= \" 0 \" ></a> "
);
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-11-01 15:42:21 +01:00
$lieferung_link = array (
'<a href="index.php?module=versandpakete&action=lieferung&id=' ,
[ 'sql' => 'l.id' ],
'">' ,
[ 'sql' => 'l.belegnr' ],
'</a>'
);
$lieferung_ohne_pos_link = array (
'<a href="index.php?module=versandpakete&action=lieferung&id=' ,
2023-10-20 15:47:37 +02:00
[ 'sql' => 'lop.id' ],
'">' ,
[ 'sql' => 'lop.belegnr' ],
'</a>'
);
2023-10-18 14:35:35 +02:00
$tracking_link = array (
'<a href="' ,
2023-10-25 13:26:52 +02:00
[ 'sql' => 'tracking_link' ],
2023-10-18 14:35:35 +02:00
'">' ,
2023-10-25 13:26:52 +02:00
[ 'sql' => 'tracking' ],
2023-10-18 14:35:35 +02:00
'</a>'
2023-10-25 13:26:52 +02:00
);
$sql_lieferschein_mengen = "
SELECT
l . id ,
l . belegnr ,
l . adresse ,
l . name ,
SUM ( lp . menge ) lmenge
FROM
lieferschein_position lp
INNER JOIN
lieferschein l ON l . id = lp . lieferschein
INNER JOIN
artikel a ON a . id = lp . artikel
WHERE
a . lagerartikel
GROUP BY l . id
" ;
2023-10-18 14:35:35 +02:00
2023-10-25 13:26:52 +02:00
$sql_pakete_zu_lieferschein = "
SELECT
v . id ,
v . datum ,
v . lieferschein_ohne_pos ,
v . versandart ,
v . tracking_link ,
v . tracking ,
v . gewicht ,
v . versender ,
v . bemerkung ,
v . status ,
lp . lieferschein ,
SUM ( vlp . menge ) AS vmenge
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
GROUP BY v . id , lp . lieferschein
" ;
$sql = "
SELECT SQL_CALC_FOUND_ROWS
id ,
" . $dropnbox . " ,
id id2 ,
2023-10-26 20:23:19 +02:00
" . $app->erp ->FormatDateTimeShort( " datum " ). " ,
2023-10-25 13:26:52 +02:00
name ,
lieferscheine ,
versandart ,
" . $app->erp ->ConcatSQL( $tracking_link ). " AS tracking ,
lmenge ,
vmenge ,
gewicht ,
versender ,
bemerkung ,
status ,
" . $app->YUI ->IconsSQL_versandpaket(). " icons ,
" . $app->erp ->ConcatSQL( $menu_link ). " AS paket_edit ,
id ,
id
FROM (
SELECT
v . id ,
v . datum ,
if ( lop . id IS NOT NULL , lop . name , l . name ) AS name ,
2023-11-01 15:42:21 +01:00
if ( lop . id IS NOT NULL , " . $app->erp ->ConcatSQL( $lieferung_ohne_pos_link ). " , GROUP_CONCAT ( " . $app->erp ->ConcatSQL( $lieferung_link ). " SEPARATOR ', ' )) AS lieferscheine ,
2023-10-25 13:26:52 +02:00
v . versandart ,
tracking ,
2023-10-20 15:47:37 +02:00
tracking_link ,
2023-10-25 13:26:52 +02:00
" . $app->erp ->FormatMenge( " SUM ( l . lmenge ) " ). " AS lmenge ,
" . $app->erp ->FormatMenge( " SUM ( v . vmenge ) " ). " AS vmenge ,
v . gewicht ,
v . versender ,
v . bemerkung ,
v . status ,
lieferschein_ohne_pos
FROM
( " . $sql_pakete_zu_lieferschein . " ) AS v
LEFT JOIN
( " . $sql_lieferschein_mengen . " ) as l
ON v . lieferschein = l . id
LEFT JOIN
lieferschein lop ON lop . id = v . lieferschein_ohne_pos
" . $lieferschein_filter_where . "
GROUP BY
v . id
) final
" ;
2023-10-16 21:22:21 +02:00
2023-10-25 13:26:52 +02:00
if ( ! $lieferschein_filter ) {
$where = " ((status IN ('neu', 'versendet') " ;
// 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
);
}
' );
}
2023-10-18 14:35:35 +02:00
2023-10-25 13:26:52 +02:00
$more_data1 = $app -> Secure -> GetGET ( " more_data1 " );
if ( $more_data1 == 1 ) {
$where .= " OR status IN ('abgeschlossen')) " ;
} else {
$where .= " ) " ;
}
2023-10-18 14:35:35 +02:00
2023-10-25 13:26:52 +02:00
$more_data2 = $app -> Secure -> GetGET ( " more_data2 " );
if ( $more_data2 == 1 ) {
$where .= " OR status IN ('storniert')) " ;
}
else {
$where .= " ) " ;
}
// END Toggle filters
2023-10-18 14:35:35 +02:00
2023-10-25 13:26:52 +02:00
2023-10-18 14:35:35 +02:00
} else {
2023-10-25 13:26:52 +02:00
$where = " 1 " ;
2023-10-18 14:35:35 +02:00
}
2023-10-25 13:26:52 +02:00
$count = " SELECT count(DISTINCT id) FROM versandpakete v WHERE " . $where ;
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' );
2024-03-21 12:29:08 +00:00
$heading = array ( '' , '' , 'Lieferschein' , 'Adresse' , 'Menge' , 'Menge in Versandpaketen' , 'Projekt' , 'Monitor' , 'Pakete' , 'Paket hinzufügen' );
$width = array ( '1%' , '1%' , '10%' , '10%' , '10%' , '10%' , '5%' , '1%' , '1%' , '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);
2024-03-21 12:29:08 +00:00
$findcols = array ( 'id' , 'id' , 'belegnr' , 'name' , 'lmenge' , 'vmenge' , 'projekt' , '(alle_versendet+alle_abgeschlossen*2)' , 'id' , 'id' );
2023-10-22 18:22:07 +02:00
$searchsql = array ( 'belegnr' , 'name' );
2023-10-16 21:22:21 +02:00
$defaultorder = 1 ;
$defaultorderdesc = 0 ;
2023-10-20 15:47:37 +02:00
$menucol = 1 ;
$moreinfoaction = " lieferschein " ;
$moreinfo = true ; // Allow drop down details
2023-10-25 13:26:52 +02:00
$aligncenter = [ 5 , 6 , 7 , 8 , 9 , 10 ];
2023-10-22 18:22:07 +02:00
2023-10-27 12:49:29 +02:00
$menu = " <a href= \" index.php?module=versandpakete&action=add&lieferschein=%value% \" ><img src= \" themes/ { $app -> Conf -> WFconf [ 'defaulttheme' ] } /images/add.png \" border= \" 0 \" ></a> " ;
2023-10-16 21:22:21 +02:00
2023-10-27 12:49:29 +02:00
$sql = Versandpakete :: versandpakete_lieferstatus_sql ( $app );
2023-11-02 09:43:43 +01:00
2023-10-16 21:22:21 +02:00
$where = " " ;
2023-10-22 18:22:07 +02:00
// Toggle filters
$app -> Tpl -> Add ( 'JQUERYREADY' , " $ ('#geschlossene').click( function() { fnFilterColumn1( 0 ); } ); " );
$app -> Tpl -> Add ( 'JQUERYREADY' , " $ ('#unterwegs').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 ) {
$where = " 1 " ;
} else {
$where = " (!alle_abgeschlossen) " ;
}
$more_data2 = $app -> Secure -> GetGET ( " more_data2 " );
if ( $more_data2 == 1 ) {
2023-10-25 13:26:52 +02:00
$where .= " AND (alle_versendet | eins_versendet) " ;
2023-10-22 18:22:07 +02:00
} else {
}
// END Toggle filters
2023-10-16 21:22:21 +02:00
// $count = "SELECT count(DISTINCT id) FROM versandpakete v WHERE $where";
2023-10-22 18:22:07 +02:00
$groupby = " " ;
2023-10-16 21:22:21 +02:00
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-22 18:22:07 +02:00
$width = array ( '10%' , '10%' , '10%' , '10%' , '1%' , '1%' , '1%' , '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);
2023-10-22 18:22:07 +02:00
$findcols = array ( 'l.belegnr' , 'sort' , 'a.name_de' , 'a.nummer' , 'lp.menge' , 'vlp.menge' , 'l.belegnr' , 'l.belegnr' );
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
$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-22 18:22:07 +02:00
$menucol = 6 ;
$aligncenter = [ 5 , 6 , 7 ];
2023-10-16 21:22:21 +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
$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' );
2023-10-26 20:23:19 +02:00
$heading = array ( 'Pos' , 'Artikel' , 'Artikel-Nr.' , 'Menge Lieferschein' , 'Menge in Versandpaketen' , 'Paket-Nr.' , '' );
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);
2023-10-22 18:22:07 +02:00
$findcols = array ( 'sort' , 'name_de' , 'a.nummer' , 'lp.menge' , 'vlp.menge' , 'versandpaket' );
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 ;
$menu = " " ;
2023-10-22 18:22:07 +02:00
$menucol = 6 ;
$aligncenter = [ 4 , 5 ];
2023-10-16 21:22:21 +02:00
$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
2023-10-22 18:22:07 +02:00
INNER JOIN lieferschein_position lp ON lp . lieferschein = l . id
INNER JOIN artikel a ON lp . artikel = a . id
2023-10-16 21:22:21 +02:00
LEFT JOIN versandpaket_lieferschein_position vlp ON vlp . lieferschein_position = lp . id
" ;
2023-10-22 18:22:07 +02:00
$where = " l.id = " . $lieferschein_id . " AND a.lagerartikel " ;
2023-10-16 21:22:21 +02:00
// $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 () {
2023-10-25 13:26:52 +02:00
$this -> app -> erp -> MenuEintrag ( " index.php?module=versandpakete&action=lieferungen " , " Lieferungen " );
$this -> app -> erp -> MenuEintrag ( " index.php?module=versandpakete&action=list " , " Versandpakete " );
2023-10-16 21:22:21 +02:00
}
2023-10-25 13:26:52 +02:00
function versandpakete_status_select () {
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-25 13:26:52 +02:00
}
function versandpakete_list () {
$this -> versandpakete_menu ();
$this -> app -> erp -> MenuEintrag ( " index.php?module=versandpakete&action=create " , " Neu anlegen " );
$this -> versandpakete_status_select ();
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 ;
}
}
2023-10-26 20:23:19 +02:00
$status = $this -> app -> Secure -> GetPOST ( 'status' );
2023-10-18 14:35:35 +02:00
$sql = " UPDATE versandpakete SET status = ' " . $status . " ' " ;
$sql .= " WHERE id IN ( " . implode ( " , " , $selectedIds ) . " ) " ;
$this -> app -> DB -> Update ( $sql );
}
2023-10-26 20:23:19 +02:00
$from = $this -> app -> Secure -> GetGET ( 'from' );
if ( $from == " lieferung " ) {
$this -> versandpakete_lieferung ();
}
else {
$this -> versandpakete_list ();
}
2023-10-18 14:35:35 +02:00
}
2023-10-25 13:26:52 +02:00
function versandpakete_lieferungen () {
2023-10-16 21:22:21 +02:00
$this -> versandpakete_menu ();
$this -> app -> YUI -> TableSearch ( 'TAB1' , 'versandpakete_lieferscheine' , " show " , " " , " " , basename ( __FILE__ ), __CLASS__ );
2023-10-26 20:23:19 +02:00
$this -> app -> Tpl -> SetText ( 'KURZUEBERSCHRIFT2' , 'Lieferungen' );
2023-10-22 18:22:07 +02:00
$this -> app -> Tpl -> Parse ( 'PAGE' , " versandpakete_lieferungen.tpl " );
2023-10-16 21:22:21 +02:00
}
2023-10-25 13:26:52 +02:00
function versandpakete_lieferung () {
$lieferschein_filter = ( int ) $this -> app -> Secure -> GetGET ( 'id' );
$this -> versandpakete_menu ();
$this -> app -> erp -> MenuEintrag ( " index.php?module=versandpakete&action=add&lieferschein= " . $lieferschein_filter , " Neu anlegen " );
2023-10-26 20:23:19 +02:00
$this -> app -> erp -> MenuEintrag ( " index.php?module=versandpakete&action=lieferung&id= " . $lieferschein_filter , " Details " );
2023-10-25 13:26:52 +02:00
$this -> app -> User -> SetParameter ( 'versandpakete_lieferschein_filter' , $lieferschein_filter );
$this -> versandpakete_status_select ();
$sql = " SELECT
belegnr ,
l . name
FROM
2023-11-01 11:48:55 +01:00
lieferschein l
2023-10-25 13:26:52 +02:00
WHERE l . id = " . $lieferschein_filter . " LIMIT 1 " ;
$info = $this -> app -> DB -> SelectArr ( $sql );
2023-10-25 13:49:27 +02:00
if ( ! empty ( $info )) {
$this -> app -> Tpl -> Set ( 'BELEGNR' , $info [ 0 ][ 'belegnr' ]);
2023-11-02 11:56:05 +01:00
$this -> app -> Tpl -> Set ( 'BELEGID' , $lieferschein_filter );
2023-10-25 13:49:27 +02:00
$this -> app -> Tpl -> SetText ( 'KURZUEBERSCHRIFT2' , $info [ 0 ][ 'name' ] . " Lieferung " . $info [ 0 ][ 'belegnr' ]);
2023-10-25 13:26:52 +02:00
2023-11-01 11:48:55 +01:00
$complete = $this -> versandpakete_check_completion ( $lieferschein_filter , null );
if ( $complete === true ) {
2023-10-25 13:49:27 +02:00
$this -> app -> Tpl -> addMessage ( 'success' , 'Lieferung vollständig in Paketen.' , false , 'MESSAGE' );
}
2023-11-01 15:42:21 +01:00
else {
2023-10-25 13:49:27 +02:00
$this -> app -> Tpl -> addMessage ( 'info' , 'Lieferung unvollständig.' , false , 'MESSAGE' );
}
2023-10-25 13:26:52 +02:00
}
2023-10-25 13:49:27 +02:00
2023-10-26 20:23:19 +02:00
$this -> app -> Tpl -> Set ( 'FROMID' , $lieferschein_filter );
2023-10-25 13:26:52 +02:00
$this -> app -> YUI -> TableSearch ( 'TAB1' , 'lieferung_versandpakete_list' , " show " , " " , " " , basename ( __FILE__ ), __CLASS__ );
$this -> app -> Tpl -> Parse ( 'PAGE' , " versandpakete_lieferung.tpl " );
}
2023-10-16 21:22:21 +02:00
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 );
2023-11-01 15:42:21 +01:00
$this -> app -> Location -> execute ( " Location: index.php?module=versandpakete&action=edit&id= " . $id );
2023-10-20 15:47:37 +02:00
}
2023-10-16 21:22:21 +02:00
/*
* Edit versandpakete item
* If id is empty , create a new one
*/
function versandpakete_edit () {
2023-10-25 13:26:52 +02:00
$id = $this -> app -> Secure -> GetGET ( 'id' );
$lieferung = $this -> app -> Secure -> GetGET ( 'lieferung' );
if ( $lieferung ) {
$this -> app -> erp -> MenuEintrag ( " index.php?module=versandpakete&action=lieferung&id= " . $lieferung , " Zurück " );
}
2023-10-26 20:23:19 +02:00
2023-10-16 21:22:21 +02:00
$this -> versandpakete_menu ();
2023-10-26 20:23:19 +02:00
$this -> app -> erp -> MenuEintrag ( " index.php?module=versandpakete&action=edit&id= " . $id , " Details " );
2023-10-16 21:22:21 +02:00
// 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 ();
2023-11-01 15:42:21 +01:00
$this -> app -> Location -> execute ( " 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
2023-11-02 11:56:05 +01:00
$sql = " UPDATE versandpakete SET versandart = (SELECT versandart FROM ( " . self :: SQL_VERSANDPAKETE_LIEFERSCHEIN . " ) v INNER JOIN lieferschein l ON v.lieferschein = l.id WHERE v.versandpaket = " . $id . " LIMIT 1) WHERE id = " . $id ;
$this -> app -> DB -> Update ( $sql );
2023-10-20 15:47:37 +02:00
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
2024-06-05 15:00:40 +02:00
$sql = " SELECT * FROM versandpakete WHERE id = " . $id ;
$paket_db = $this -> app -> DB -> SelectRow ( $sql );
$input [ 'status' ] = $paket_db [ 'status' ]; // Status is not changeable
2023-11-01 15:42:21 +01:00
if ( $input [ 'status' ] != 'neu' ) {
2023-10-20 15:47:37 +02:00
$input = Array ( 'bemerkung' => $input [ 'bemerkung' ]);
2023-11-01 11:48:55 +01:00
}
2024-06-05 15:00:40 +02:00
2023-11-01 15:42:21 +01:00
if ( ! empty ( $paket_db [ 'tracking' ])) { // Tracking is not changeable
unset ( $input [ 'tracking' ]);
unset ( $input [ 'tracking_link' ]);
}
2023-10-20 15:47:37 +02:00
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' :
2023-10-20 15:52:55 +02:00
$sql = " UPDATE versandpakete SET status = 'versendet', versender = ' " . $this -> app -> User -> GetName () . " ' WHERE id = " . $id ;
2023-10-20 15:47:37 +02:00
$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-11-01 11:48:55 +01: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 ,
2023-11-01 15:42:21 +01:00
l . belegnr ,
lop . belegnr lieferschein_ohne_pos_belegnr ,
GROUP_CONCAT ( lieferschein_position ) lieferschein_position ,
2023-10-20 15:47:37 +02:00
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
2023-11-01 15:42:21 +01:00
LEFT JOIN lieferschein lop ON lop . id = v . lieferschein_ohne_pos
WHERE v . id = " . $id . "
GROUP BY v . id
" ;
2023-10-20 15:47:37 +02:00
$lieferschein_check = $this -> app -> DB -> SelectArr ( $sql );
2023-11-01 15:42:21 +01:00
2023-10-20 15:47:37 +02:00
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
}
2023-11-01 15:42:21 +01:00
if ( ! empty ( $lieferschein_check [ 0 ][ 'lieferschein_ohne_pos' ])) {
$this -> app -> Tpl -> Set ( 'LIEFERSCHEIN_OHNE_POS' , $lieferschein_check [ 0 ][ 'lieferschein_ohne_pos_belegnr' ]);
2023-10-20 15:47:37 +02:00
$this -> app -> Tpl -> Set ( 'LIEFERSCHEIN_OHNE_POS_ID' , $lieferschein_check [ 0 ][ 'lieferschein_ohne_pos' ]);
}
2023-11-01 15:42:21 +01:00
if ( empty ( $lieferschein_check [ 0 ][ 'lieferschein_position' ])) {
$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' );
2023-11-02 11:56:05 +01:00
$this -> app -> Tpl -> Set ( 'TRACKING_DISABLED' , 'disabled' );
$this -> app -> Tpl -> Set ( 'TRACKING_LINK_EDIT_HIDDEN' , 'hidden' );
2023-10-20 15:47:37 +02:00
}
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' );
2023-11-01 15:42:21 +01:00
} else {
2023-10-20 15:47:37 +02:00
$this -> app -> Tpl -> Set ( 'ABSENDEN_HIDDEN' , 'hidden' );
2023-11-01 15:42:21 +01:00
}
if ( empty ( $result [ 0 ][ 'tracking_link' ])) {
$this -> app -> Tpl -> Set ( 'TRACKING_LINK_HIDDEN' , 'hidden' );
}
$versandart = $this -> app -> DB -> SelectRow ( " SELECT va.id, va.modul FROM versandpakete vp INNER JOIN versandarten va ON vp.versandart = va.type WHERE vp.id = " . $id . " LIMIT 1 " );
if ( empty ( $versandart [ 'modul' ]) || empty ( $versandart [ 'id' ])) {
$this -> app -> Tpl -> Set ( 'PAKETMARKE_ADD_HIDDEN' , 'hidden' );
} else {
$this -> app -> Tpl -> Set ( 'TRACKING_DISABLED' , 'disabled' );
2023-11-02 11:56:05 +01:00
$this -> app -> Tpl -> Set ( 'TRACKING_LINK_EDIT_HIDDEN' , 'hidden' );
2023-11-01 11:48:55 +01:00
}
2023-10-20 15:47:37 +02:00
$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-11-01 15:42:21 +01:00
} else {
$this -> app -> Tpl -> Set ( 'PAKETMARKE_HIDDEN' , 'hidden' );
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
" ;
2023-11-02 11:56:05 +01:00
2023-10-20 15:47:37 +02:00
$icons = $this -> app -> DB -> SelectArr ( $sql );
$this -> app -> Tpl -> Set ( 'ICONS' , $icons [ 0 ][ 'icons' ]);
2023-11-01 11:48:55 +01:00
$complete = $this -> versandpakete_check_completion ( null , $id );
if ( $complete === true ) {
2023-10-25 13:26:52 +02:00
$this -> app -> Tpl -> addMessage ( 'success' , 'Lieferung vollständig in Paketen.' , false , 'MESSAGE' );
}
2023-11-01 11:48:55 +01:00
else if ( $complete === false ) {
2023-10-25 13:26:52 +02:00
$this -> app -> Tpl -> addMessage ( 'info' , 'Lieferung unvollständig.' , false , 'MESSAGE' );
}
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
$id = $this -> app -> Secure -> GetGET ( 'id' );
2023-11-01 15:42:21 +01:00
$input = $this -> GetInput ();
2023-10-26 20:23:19 +02:00
$this -> versandpakete_menu ();
$this -> app -> erp -> MenuEintrag ( " index.php?module=versandpakete&action=edit&id= " . $id , " Details " );
$this -> app -> Tpl -> SetText ( 'KURZUEBERSCHRIFT2' , 'Artikel hinzufügen' );
2023-10-16 21:22:21 +02:00
if ( empty ( $id )) {
2024-09-18 20:12:54 +02:00
2023-10-16 21:22:21 +02:00
$lieferschein = $this -> app -> Secure -> GetGET ( 'lieferschein' );
if ( empty ( $lieferschein )) {
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" error \" >Kein Lieferschein angegeben.</div> " );
2023-11-01 15:42:21 +01:00
$this -> app -> Location -> execute ( " Location: index.php?module=versandpakete&action=list&msg= $msg " );
2023-10-16 21:22:21 +02:00
} else {
$lieferschein_belegnr = $this -> app -> erp -> ReplaceLieferschein ( false , $lieferschein , false ); // Parameters: Target db?, value, from form?
2023-11-01 15:42:21 +01:00
2023-11-02 09:43:43 +01:00
if ( empty ( $lieferschein_belegnr )) {
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" error \" >Lieferschein ist nicht freigegeben.</div> " );
$this -> app -> Location -> execute ( " Location: index.php?module=versandpakete&action=list&msg= $msg " );
}
// Flag lieferschein for versand
$sql = " UPDATE lieferschein SET versand_status = 1 WHERE id = " . $lieferschein . " AND versand_status = 0 " ;
$this -> app -> DB -> Update ( $sql );
2023-11-01 15:42:21 +01:00
// Check if there is an unused paket waiting...
$sql = " SELECT
v . id ,
lieferschein_ohne_pos ,
l . id AS lieferschein_mit_pos
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 l . id = lp . lieferschein
WHERE
v . status = 'neu' AND
l . id IS NULL AND
v . lieferschein_ohne_pos = " . $lieferschein . "
LIMIT 1
" ;
$waiting_paket = $this -> app -> DB -> SelectArr ( $sql );
if ( ! empty ( $waiting_paket )) {
// Use existing
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" success \" >Versandpaket Paket Nr. " . $waiting_paket [ 0 ][ 'id' ] . " wurde zugeordnet.</div> " );
$this -> app -> Location -> execute ( " Location: index.php?module=versandpakete&action=add&id= " . $waiting_paket [ 0 ][ 'id' ] . " &lieferschein= " . $lieferschein . " &msg= $msg " );
}
else {
// Create new paket and add the given lieferschein
$sql = " INSERT INTO versandpakete (status, lieferschein_ohne_pos, versender) VALUES ('neu', " . $lieferschein . " ,' " . $this -> app -> User -> GetName () . " ') " ;
$this -> app -> DB -> Insert ( $sql );
$id = $this -> app -> DB -> GetInsertId ();
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" success \" >Versandpaket Paket Nr. " . $id . " wurde erstellt.</div> " );
$this -> app -> Location -> execute ( " Location: index.php?module=versandpakete&action=add&id= " . $id . " &lieferschein= " . $lieferschein . " &msg= $msg " );
}
2023-10-16 21:22:21 +02:00
}
} else { // $id not empty
2023-11-01 15:42:21 +01:00
$lieferschein_post = $this -> app -> Secure -> GetPOST ( 'lieferschein' );
$lieferschein = $this -> app -> erp -> ReplaceLieferschein ( true , $lieferschein_post , true ); // Parameters: Target db?, value, from form?
$lieferschein_belegnr = $this -> app -> erp -> ReplaceLieferschein ( false , $lieferschein_post , true ); // Parameters: Target db?, value, from form?
if ( empty ( $lieferschein )) {
$lieferschein = $this -> app -> Secure -> GetGET ( 'lieferschein' );
if ( empty ( $lieferschein )) {
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" error \" >Kein Lieferschein angegeben.</div> " );
$this -> app -> Location -> execute ( " Location: index.php?module=versandpakete&action=edit&id= " . $id . " &msg= $msg " );
}
$lieferschein_belegnr = $this -> app -> erp -> ReplaceLieferschein ( false , $lieferschein , false ); // Parameters: Target db?, value, from form?
$input [ 'lieferschein' ] = $lieferschein ;
2024-09-18 20:12:54 +02:00
} else {
2023-10-16 21:22:21 +02:00
}
}
2024-09-18 20:12:54 +02:00
$this -> app -> erp -> SeriennummernCheckLieferscheinWarnung ( lieferschein_id : $lieferschein );
2023-10-16 21:22:21 +02:00
// 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 );
$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 ;
2023-11-01 15:42:21 +01:00
}
2023-10-16 21:22:21 +02:00
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
2023-10-22 18:22:07 +02:00
INNER JOIN artikel a ON lp . artikel = a . id
LEFT JOIN versandpaket_lieferschein_position vlp ON vlp . lieferschein_position = lp . id
WHERE lp . lieferschein = " . $lieferschein . " AND lp . artikel = " . $artikel . " AND a . lagerartikel
2023-10-16 21:22:21 +02:00
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' ];
2023-10-25 13:26:52 +02:00
if ( $restmenge <= 0 || $menge <= 0 ) {
2023-10-16 21:22:21 +02:00
continue ;
}
if ( $menge > $restmenge ) {
$buchmenge = $restmenge ;
2023-10-20 15:47:37 +02:00
} else {
$buchmenge = $menge ;
2023-10-25 13:26:52 +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
2023-10-22 18:22:07 +02:00
INNER JOIN artikel a ON lp . artikel = a . id
2023-10-16 21:22:21 +02:00
LEFT JOIN versandpaket_lieferschein_position vlp ON vlp . lieferschein_position = lp . id
2023-10-22 18:22:07 +02:00
WHERE lp . lieferschein = " . $lieferschein . " AND a . lagerartikel
2023-10-16 21:22:21 +02:00
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-25 13:26:52 +02:00
$buchmenge_gesamt = 0 ;
2023-10-16 21:22:21 +02:00
foreach ( $lieferschein_positionen as $lieferschein_position ) {
2023-10-25 13:26:52 +02:00
$buchmenge = $lieferschein_position [ 'lp_menge' ] - $lieferschein_position [ 'v_menge' ];
if ( $buchmenge <= 0 ) {
continue ;
}
$buchmenge_gesamt += $buchmenge ;
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-25 13:26:52 +02:00
if ( $buchmenge_gesamt > 0 ) {
$msg = $this -> app -> erp -> base64_url_encode ( " <div class= \" info \" >Lieferschein hinzugefügt.</div> " );
2023-11-01 15:42:21 +01:00
$this -> app -> Location -> execute ( " Location: index.php?module=versandpakete&action=edit&id= " . $id . " &msg= $msg " );
2023-10-25 13:26:52 +02:00
}
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 );
2023-11-01 11:48:55 +01:00
$complete = $this -> versandpakete_check_completion ( $lieferschein , null );
if ( $complete === true ) {
2023-10-25 13:26:52 +02:00
$this -> app -> Tpl -> addMessage ( 'success' , 'Lieferung vollständig in Paketen.' , false , 'MESSAGE' );
}
2023-11-01 15:42:21 +01:00
else {
2023-10-25 13:26:52 +02:00
$this -> app -> Tpl -> addMessage ( 'info' , 'Lieferung unvollständig.' , false , 'MESSAGE' );
}
2023-10-16 21:22:21 +02:00
$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__ );
2023-10-25 13:26:52 +02:00
$this -> app -> Tpl -> Add ( 'MESSAGE' , $msg );
2023-10-16 21:22:21 +02:00
$this -> app -> Tpl -> Parse ( 'PAGE' , " versandpakete_add.tpl " );
}
2023-11-01 11:48:55 +01:00
// null if versandpaket not associated with lieferschein
function versandpakete_check_completion ( $lieferung , $versandpaket ) : ? bool {
if ( ! empty ( $lieferung )) {
$sql_where_lieferung = " AND l.id = " . $lieferung ;
} else {
$sql_join_lieferschein = "
INNER JOIN (
SELECT DISTINCT
lieferschein
FROM
versandpaket_lieferschein_position vlp
INNER JOIN lieferschein_position lp ON vlp . lieferschein_position = lp . id
WHERE versandpaket = " . $versandpaket . "
) lieferschein_filter
ON lieferschein_filter . lieferschein = lp . lieferschein
" ;
}
2023-10-25 13:26:52 +02:00
$sql_lieferschein_mengen = "
SELECT
belegnr ,
lp . id lieferschein_position ,
menge lmenge
FROM
lieferschein_position lp
INNER JOIN
artikel a ON a . id = lp . artikel
INNER JOIN
lieferschein l on l . id = lp . lieferschein
2023-11-01 11:48:55 +01:00
" . $sql_join_lieferschein . "
2023-10-25 13:26:52 +02:00
WHERE
a . lagerartikel
2023-11-01 11:48:55 +01:00
" . $sql_where_lieferung . "
2023-10-25 13:26:52 +02:00
GROUP BY
lp . id
" ;
// Check completion
$sql_versandmengen = "
SELECT
v . id versandpaket ,
lieferschein_position ,
SUM ( menge ) vmenge
FROM
versandpaket_lieferschein_position vlp
INNER JOIN
versandpakete v ON v . id = vlp . versandpaket
WHERE
v . status <> 'storniert'
GROUP BY
lieferschein_position
" ;
$sql_intermediate = "
SELECT
vmengen . versandpaket ,
GROUP_CONCAT ( DISTINCT lmengen . belegnr SEPARATOR ', ' ) lieferscheine ,
SUM ( lmenge ) lmenge ,
SUM ( vmenge ) vmenge
FROM
( " . $sql_lieferschein_mengen . " ) lmengen
LEFT JOIN
( " . $sql_versandmengen . " ) vmengen
ON lmengen . lieferschein_position = vmengen . lieferschein_position
" ;
$sql = "
SELECT
* ,
" . $this->app ->YUI->IconsSQL_versandpaket(). " icons
FROM
( " . $sql_intermediate . " ) final INNER JOIN versandpakete v ON v . id = final . versandpaket
" ;
$completion = $this -> app -> DB -> SelectArr ( $sql );
if ( ! empty ( $completion )) {
if ( $completion [ 0 ][ 'lmenge' ] == $completion [ 0 ][ 'vmenge' ]) {
return ( true );
2023-11-01 11:48:55 +01:00
} else {
return ( false );
}
} else {
return ( null );
2023-10-25 13:26:52 +02:00
}
}
2023-10-16 21:22:21 +02:00
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
2023-10-25 13:26:52 +02:00
INNER JOIN artikel a ON lp . artikel = a . id
LEFT JOIN versandpaket_lieferschein_position vlp ON vlp . lieferschein_position = lp . id
WHERE l . id = " . $id . " AND a . lagerartikel
2023-10-20 15:47:37 +02:00
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 ()
{
$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-25 13:26:52 +02:00
$this -> versandpakete_menu ();
2023-10-18 14:35:35 +02:00
$this -> app -> Tpl -> Set ( 'TABTEXT' , " Paketmarke " );
2023-11-01 15:42:21 +01:00
$versandart = $this -> app -> DB -> SelectRow ( " SELECT va.id, va.modul FROM versandpakete vp INNER JOIN versandarten va ON vp.versandart = va.type WHERE vp.id = " . $id . " LIMIT 1 " );
if ( empty ( $versandart [ 'modul' ]) || empty ( $versandart [ 'id' ])) {
2023-10-18 14:35:35 +02:00
$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 " );
2023-11-01 15:42:21 +01:00
$versandmodul = $this -> app -> erp -> LoadVersandModul ( $versandart [ 'modul' ], $versandart [ 'id' ]);
2024-05-23 14:27:32 +02:00
$sql = "
SELECT
SUM ( COALESCE ( a . gewicht , 0 ) * vlp . menge )
FROM
artikel a
INNER JOIN lieferschein_position lp ON
a . id = lp . artikel
INNER JOIN
versandpaket_lieferschein_position vlp ON
vlp . lieferschein_position = lp . id
WHERE vlp . versandpaket = " . $id . "
" ;
$gewicht = $this -> app -> DB -> Select ( $sql );
$versandmodul -> Paketmarke ( 'TAB1' , docType : 'lieferschein' , docId : $lieferschein [ 'lieferschein' ], versandpaket : $id , gewicht : $gewicht );
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-11-01 11:48:55 +01:00
$input [ 'bemerkung' ] = $this -> app -> Secure -> GetPOST ( 'bemerkung' );
2023-11-01 15:42:21 +01:00
$input [ 'tracking' ] = $this -> app -> Secure -> GetPOST ( 'tracking' );
2023-11-02 11:56:05 +01:00
$input [ 'tracking_link' ] = $this -> app -> Secure -> GetPOST ( 'tracking_link' );
2023-10-16 21:22:21 +02:00
return $input ;
}
2023-10-27 12:49:29 +02:00
static function versandpakete_lieferstatus_sql ( $app ) {
$dropnbox = " '<img src=./themes/new/images/details_open.png class=details>' AS `open`, CONCAT('<input type= \" checkbox \" name= \" auswahl[] \" value= \" ',id,' \" />') AS `auswahl` " ;
$sql_lieferschein_position = "
SELECT
l . id ,
2024-03-21 12:29:08 +00:00
p . abkuerzung AS projekt ,
2023-10-27 12:49:29 +02:00
l . belegnr ,
l . name ,
lp . menge lmenge ,
SUM ( vlp . menge ) vmenge ,
2023-11-01 15:42:21 +01:00
GROUP_CONCAT ( vop . id ) vop ,
2023-10-27 12:49:29 +02:00
BIT_OR ( COALESCE ( v . status , 0 ) IN ( 'versendet' )) AS eins_versendet ,
BIT_AND ( COALESCE ( v . status , 0 ) IN ( 'versendet' )) AS alle_versendet ,
BIT_OR ( COALESCE ( v . status , 0 ) IN ( 'abgeschlossen' )) AS eins_abgeschlossen ,
BIT_AND ( COALESCE ( v . status , 0 ) IN ( 'abgeschlossen' )) AS alle_abgeschlossen
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
2023-11-01 15:42:21 +01:00
LEFT JOIN versandpakete vop ON vop . lieferschein_ohne_pos = l . id
2024-03-21 12:29:08 +00:00
LEFT JOIN projekt p ON p . id = l . projekt
2023-10-27 12:49:29 +02:00
WHERE
l . versand_status <> 0 AND
l . belegnr <> '' AND
2023-11-02 09:43:43 +01:00
( v . status <> 'storniert' OR v . status IS NULL )
2023-10-27 12:49:29 +02:00
GROUP BY lp . id
" ;
$sql_lieferschein = "
SELECT
id ,
2024-03-21 12:29:08 +00:00
projekt ,
2023-10-27 12:49:29 +02:00
belegnr ,
name ,
SUM ( lmenge ) lmenge ,
SUM ( COALESCE ( vmenge , 0 )) vmenge ,
eins_versendet ,
alle_versendet ,
eins_abgeschlossen ,
2023-11-01 15:42:21 +01:00
alle_abgeschlossen ,
vop
2023-10-27 12:49:29 +02:00
FROM (
" . $sql_lieferschein_position . "
) lp
GROUP BY id
" ;
$sql = "
SELECT SQL_CALC_FOUND_ROWS
id ,
" . $dropnbox . " ,
CONCAT ( '<a href=\"index.php?module=lieferschein&action=edit&id=' , id , '\">' , belegnr , '</a>' ),
name ,
" . $app->erp ->FormatMenge( " lmenge " ). " ,
" . $app->erp ->FormatMenge( " vmenge " ). " ,
2024-03-21 12:29:08 +00:00
projekt ,
2023-10-27 12:49:29 +02:00
" . $app->YUI ->IconsSQL_lieferung(). " ,
2023-11-01 15:42:21 +01:00
if ( vmenge > 0 OR vop IS NOT NULL , CONCAT ( '<a href=\"index.php?module=versandpakete&action=lieferung&id=' , id , '\"><img src=\"themes/{$app->Conf->WFconf[' defaulttheme ']}/images/forward.svg\" title=\"Pakete anzeigen\" border=\"0\"></a>' ), '' ),
2023-10-27 12:49:29 +02:00
id ,
alle_abgeschlossen
FROM (
" . $sql_lieferschein . "
) l
" ;
return ( $sql );
}
2023-10-16 21:22:21 +02:00
}