2020-12-21 17:25:55 +01:00
< ? php
/*
* OpenSTAManager : il software gestionale open source per l ' assistenza tecnica e la fatturazione
2021-01-20 15:08:51 +01:00
* Copyright ( C ) DevCode s . r . l .
2020-12-21 17:25:55 +01:00
*
* This program is free software : you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation , either version 3 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program . If not , see < https :// www . gnu . org / licenses />.
*/
include_once __DIR__ . '/../../core.php' ;
2024-03-22 15:52:24 +01:00
use Models\Module ;
2022-02-14 10:51:36 +01:00
use Modules\Anagrafiche\Anagrafica ;
2021-07-07 07:57:10 +02:00
use Modules\Articoli\Articolo as ArticoloOriginale ;
2020-12-21 17:25:55 +01:00
use Modules\Fatture\Fattura ;
use Modules\Fatture\Stato ;
2022-02-14 10:51:36 +01:00
use Modules\Fatture\Tipo as TipoFattura ;
2021-02-18 18:48:44 +01:00
use Modules\Ordini\Ordine ;
2022-02-14 10:51:36 +01:00
use Modules\Ordini\Tipo ;
2020-12-21 17:25:55 +01:00
// Segmenti
2024-06-11 16:58:27 +02:00
$id_modulo_fatture = Module :: where ( 'name' , 'Fatture di vendita' ) -> first () -> id ;
2024-03-05 16:01:45 +01:00
if ( ! isset ( $_SESSION [ 'module_' . $id_modulo_fatture ][ 'id_segment' ])) {
$segments = Modules :: getSegments ( $id_modulo_fatture );
2024-04-08 15:44:33 +02:00
$_SESSION [ 'module_' . $id_modulo_fatture ][ 'id_segment' ] = $segments [ 0 ][ 'id' ] ? ? null ;
2020-12-21 17:25:55 +01:00
}
2024-03-05 16:01:45 +01:00
$id_segment = $_SESSION [ 'module_' . $id_modulo_fatture ][ 'id_segment' ];
2022-11-28 09:27:25 +01:00
$id_segment_ordini = $_SESSION [ 'module_' . $id_module ][ 'id_segment' ];
2021-04-28 15:29:47 +02:00
$idconto = setting ( 'Conto predefinito fatture di vendita' );
2021-09-22 12:07:11 +02:00
$idtipodocumento = $dbo -> selectOne ( 'co_tipidocumento' , [ 'id' ], [
'predefined' => 1 ,
'dir' => 'entrata' ,
])[ 'id' ];
2020-12-21 17:25:55 +01:00
switch ( post ( 'op' )) {
case 'crea_fattura' :
$documenti = collect ();
$numero_totale = 0 ;
2021-09-23 10:04:44 +02:00
2022-02-14 10:51:36 +01:00
$tipo_documento = TipoFattura :: where ( 'id' , post ( 'idtipodocumento' )) -> first ();
2020-12-21 17:25:55 +01:00
2024-06-11 16:58:27 +02:00
$stato_documenti_accodabili = Stato :: where ( 'name' , 'Bozza' ) -> first () -> id ;
2020-12-21 17:25:55 +01:00
$accodare = post ( 'accodare' );
$data = date ( 'Y-m-d' );
$id_segment = post ( 'id_segment' );
2024-01-19 15:25:36 +01:00
$raggruppamento = post ( 'raggruppamento' );
2020-12-21 17:25:55 +01:00
// Lettura righe selezionate
foreach ( $id_records as $id ) {
$documento_import = Ordine :: find ( $id );
$anagrafica = $documento_import -> anagrafica ;
$id_anagrafica = $anagrafica -> id ;
// Proseguo solo se i documenti scelti sono fatturabili
2024-04-18 17:44:05 +02:00
$ordine = $dbo -> fetchOne ( 'SELECT `or_statiordine_lang`.`title` AS stato FROM `or_ordini` INNER JOIN `or_statiordine` ON `or_ordini`.`idstatoordine`=`or_statiordine`.`id` LEFT JOIN `or_statiordine_lang` ON (`or_statiordine`.`id`=`or_statiordine_lang`.`id_record` AND `or_statiordine_lang`.`id_lang`= ' . prepare ( Models\Locale :: getDefault () -> id ) . ') WHERE `or_ordini`.`id`=' . prepare ( $id ))[ 'stato' ];
2020-12-21 17:25:55 +01:00
if ( ! in_array ( $ordine , [ 'Fatturato' , 'Evaso' , 'Bozza' , 'In attesa di conferma' , 'Annullato' ])) {
$righe = $documento_import -> getRighe ();
if ( ! empty ( $righe )) {
++ $numero_totale ;
2024-01-31 14:23:46 +01:00
// Ricerca fattura per anagrafica tra le registrate
2024-01-19 15:25:36 +01:00
$id_sede = $raggruppamento == 'sede' ? $documento_import -> idsede : 0 ;
if ( $raggruppamento == 'sede' ) {
2024-04-09 12:18:08 +02:00
$fattura = $documenti -> first ( fn ( $item , $key ) => $item -> anagrafica -> id == $id_anagrafica && $item -> idsede_destinazione == $id_sede );
2024-01-19 15:25:36 +01:00
} else {
2024-04-09 12:18:08 +02:00
$fattura = $documenti -> first ( fn ( $item , $key ) => $item -> anagrafica -> id == $id_anagrafica );
2024-01-19 15:25:36 +01:00
}
2020-12-21 17:25:55 +01:00
// Ricerca fattura per anagrafica se l'impostazione di accodamento è selezionata
if ( ! empty ( $accodare ) && empty ( $fattura )) {
2024-01-19 15:25:36 +01:00
if ( $raggruppamento == 'sede' ) {
$fattura = Fattura :: where ( 'idanagrafica' , $id_anagrafica )
-> where ( 'idstatodocumento' , $stato_documenti_accodabili -> id )
-> where ( 'idtipodocumento' , $tipo_documento -> id )
-> first ();
} else {
$fattura = Fattura :: where ( 'idanagrafica' , $id_anagrafica )
-> where ( 'idstatodocumento' , $stato_documenti_accodabili -> id )
-> where ( 'idtipodocumento' , $tipo_standard -> id )
-> where ( 'idsede' , $id_sede )
-> first ();
}
2020-12-21 17:25:55 +01:00
if ( ! empty ( $fattura )) {
$documenti -> push ( $fattura );
}
}
// Creazione fattura per anagrafica
if ( empty ( $fattura )) {
$fattura = Fattura :: build ( $anagrafica , $tipo_documento , $data , $id_segment );
2024-01-19 15:25:36 +01:00
$fattura -> idsede_destinazione = $id_sede ;
$fattura -> save ();
2020-12-21 17:25:55 +01:00
$documenti -> push ( $fattura );
}
// Inserimento righe
foreach ( $righe as $riga ) {
$qta = $riga -> qta_rimanente ;
if ( $qta > 0 ) {
$copia = $riga -> copiaIn ( $fattura , $qta );
2024-01-15 15:30:45 +01:00
// Fix per idconto righe fattura
2021-04-28 15:14:52 +02:00
$articolo = ArticoloOriginale :: find ( $copia -> idarticolo );
2024-04-08 15:44:33 +02:00
$copia -> id_conto = ( $articolo -> idconto_vendita ? : $idconto );
2021-04-28 15:14:52 +02:00
2020-12-21 17:25:55 +01:00
// Aggiornamento seriali dalla riga dell'ordine
if ( $copia -> isArticolo ()) {
$copia -> serials = $riga -> serials ;
}
2023-02-03 11:52:09 +01:00
$copia -> save ();
2020-12-21 17:25:55 +01:00
}
}
}
}
}
if ( $numero_totale > 0 ) {
flash () -> info ( tr ( '_NUM_ ordini fatturati!' , [
'_NUM_' => $numero_totale ,
]));
} else {
flash () -> warning ( tr ( 'Nessun ordine fatturato!' ));
}
2023-03-01 11:14:35 +01:00
break ;
2021-01-19 12:20:06 +01:00
case 'cambia_stato' :
$id_stato = post ( 'id_stato' );
$n_ordini = 0 ;
2021-02-18 18:48:44 +01:00
foreach ( $id_records as $id ) {
2021-01-25 09:22:10 +01:00
$ordine = Ordine :: find ( $id );
$ordine -> idstatoordine = $id_stato ;
$ordine -> save ();
2021-01-19 12:20:06 +01:00
++ $n_ordini ;
}
if ( $n_ordini > 0 ) {
flash () -> info ( tr ( 'Stato cambiato a _NUM_ ordini!' , [
'_NUM_' => $n_ordini ,
]));
} else {
flash () -> warning ( tr ( 'Nessun ordine modificato!' ));
}
2023-03-01 11:14:35 +01:00
break ;
2022-02-14 10:51:36 +01:00
case 'unisci_rdo' :
$id_stato = post ( 'id_stato' );
$data = post ( 'data' ) ? : null ;
$tipo = Tipo :: where ( 'dir' , 'uscita' ) -> first ();
2023-08-04 14:54:28 +02:00
2022-02-14 10:51:36 +01:00
$numero_ordini = [];
$fornitori = [];
$new_ordini = [];
foreach ( $id_records as $id ) {
$ordine = Ordine :: find ( $id );
2024-04-18 17:44:05 +02:00
if ( in_array ( $ordine -> stato -> getTranslation ( 'title' ), [ 'Bozza' , 'In attesa di conferma' , 'Accettato' ])) {
2022-02-14 10:51:36 +01:00
// Controllo se è già stato creato un nuovo ordine per l'anagrafica
if ( in_array ( $ordine -> idanagrafica , array_keys ( $new_ordini ))) {
$new_ordine = Ordine :: find ( $new_ordini [ $ordine -> idanagrafica ]);
} else {
$anagrafica = Anagrafica :: find ( $ordine -> idanagrafica );
2022-11-28 09:27:25 +01:00
$new_ordine = Ordine :: build ( $anagrafica , $tipo , $data , post ( 'id_segment' ));
2022-02-14 10:51:36 +01:00
$new_ordine -> idstatoordine = $id_stato ;
$new_ordine -> data = $data ;
$new_ordine -> save ();
$new_ordini [ $ordine -> idanagrafica ] = $new_ordine -> id ;
$numero_ordini [] = $new_ordine -> numero ;
}
$righe = $ordine -> getRighe ();
foreach ( $righe as $riga ) {
$new_riga = $riga -> replicate ();
$new_riga -> setDocument ( $new_ordine );
$new_riga -> save ();
}
$ordine -> delete ();
}
}
if ( sizeof ( $numero_ordini ) > 0 ) {
flash () -> info ( tr ( 'Sono stati creati i seguenti ordini: ' , [
'_NUM_' => implode ( ',' , $numero_ordini ),
]));
} else {
flash () -> warning ( tr ( 'Nessun ordine creato!' ));
}
2023-03-01 11:14:35 +01:00
break ;
2020-12-21 17:25:55 +01:00
}
2024-04-18 17:44:05 +02:00
if ( $module -> getTranslation ( 'title' ) == 'Ordini cliente' ) {
$module_fatture = Module :: find ( $id_modulo_fatture ) -> getTranslation ( 'title' );
2024-05-23 11:36:25 +02:00
$module_fatture ? strtolower (( string ) $module_fatture ) : '' ;
2021-02-18 18:48:44 +01:00
$operations [ 'crea_fattura' ] = [
2024-05-23 11:36:25 +02:00
'text' => '<span><i class="fa fa-file-code-o"></i> ' . tr ( 'Fattura _TYPE_' , [ '_TYPE_' => strtolower (( string ) $module -> getTranslation ( 'title' ))]),
2020-12-21 17:25:55 +01:00
'data' => [
2024-05-23 11:36:25 +02:00
'title' => tr ( 'Fatturare i _TYPE_ selezionati?' , [ '_TYPE_' => strtolower (( string ) $module -> getTranslation ( 'title' ))]),
2024-04-11 14:53:46 +02:00
'msg' => '{[ "type": "checkbox", "label": "<small>' . tr ( 'Aggiungere alle _TYPE_ non ancora emesse?' , [ '_TYPE_' => $module_fatture ]) . '", "placeholder": "' . tr ( 'Aggiungere alle _TYPE_ nello stato bozza?' , [ '_TYPE_' => $module_fatture ]) . ' </ small > " , " name " : " accodare " ]}
2024-03-05 16:01:45 +01:00
{[ " type " : " select " , " label " : " '.tr('Sezionale').' " , " name " : " id_segment " , " required " : 1 , " ajax-source " : " segmenti " , " select-options " : '.json_encode([' id_module ' => $id_modulo_fatture, ' is_sezionale ' => 1]).' , " value " : " '. $id_segment .' " , " select-options-escape " : true ]}
2024-04-18 17:44:05 +02:00
{[ " type " : " select " , " label " : " '.tr('Tipo documento').' " , " name " : " idtipodocumento " , " required " : 1 , " values " : " query=SELECT `co_tipidocumento`.`id`, CONCAT(`codice_tipo_documento_fe`, \ ' - \ ', `title`) AS descrizione FROM `co_tipidocumento` LEFT JOIN `co_tipidocumento_lang` ON (`co_tipidocumento`.`id` = `co_tipidocumento_lang`.`id_record` AND `co_tipidocumento_lang`.`id_lang` = '.prepare(Models \ Locale::getDefault()->id).') WHERE `enabled` = 1 AND `dir` = \ 'entrata \ ' ORDER BY `codice_tipo_documento_fe` " , " value " : " '. $idtipodocumento .' " ]} < br >
2024-01-19 15:25:36 +01:00
{[ " type " : " select " , " label " : " '.tr('Raggruppa per').' " , " name " : " raggruppamento " , " required " : 1 , " values " : " list= \" cliente \" : \" Cliente \" , \" sede \" : \" Sede \" " ]} ' ,
2020-12-21 17:25:55 +01:00
'button' => tr ( 'Procedi' ),
'class' => 'btn btn-lg btn-warning' ,
'blank' => false ,
],
];
2022-02-14 10:51:36 +01:00
} else {
if ( App :: debug ()) {
$operations [ 'unisci_rdo' ] = [
'text' => '<span><i class="fa fa-refresh"></i> ' . tr ( 'Unisci rdo' ),
'data' => [
'title' => tr ( 'Unire gli ordini selezionati?' ),
2022-11-28 09:27:25 +01:00
'msg' => tr ( 'Gli ordini saranno processati solo se in uno dei seguenti stati: Bozza, In attesa di conferma, Accettato.<br>Tutti gli ordini processati verranno eliminati e verrà creato un nuovo ordine unificato per fornitore.' ) . '
2023-08-04 14:54:28 +02:00
{[ " type " : " select " , " label " : " '.tr('Sezionale').' " , " name " : " id_segment " , " required " : 1 , " ajax-source " : " segmenti " , " select-options " : '.json_encode([' id_module ' => $id_module, ' is_sezionale ' => 1]).' , " value " : " '. $id_segment_ordini .' " , " select-options-escape " : true ]}
2024-04-18 17:44:05 +02:00
{[ " type " : " select " , " label " : " '.tr('Stato').' " , " name " : " id_stato " , " required " : 1 , " values " : " query=SELECT `or_statiordine`.`id`, `title` FROM `or_statiordine` LEFT JOIN `or_statiordine_lang` ON (`or_statiordine`.`id` = `or_statiordine_lang`.`id_record` AND `or_statiordine_lang`.`id_lang` = '.prepare(Models \ Locale::getDefault()->id).') ORDER BY `title` ASC " ]}
2022-11-28 09:27:25 +01:00
{[ " type " : " date " , " label " : " '.tr('Data').' " , " name " : " data " , " required " : 1 ]} ' ,
2022-02-14 10:51:36 +01:00
'button' => tr ( 'Procedi' ),
'class' => 'btn btn-lg btn-warning' ,
'blank' => false ,
],
];
}
2021-02-18 18:48:44 +01:00
}
2021-01-19 12:20:06 +01:00
$operations [ 'cambia_stato' ] = [
'text' => '<span><i class="fa fa-refresh"></i> ' . tr ( 'Cambia stato' ),
'data' => [
'title' => tr ( 'Vuoi davvero cambiare lo stato per questi ordini?' ),
'msg' => tr ( 'Seleziona lo stato in cui spostare tutti gli ordini' ) . ' .< br >
2024-07-11 17:19:00 +02:00
< br > {[ " type " : " select " , " label " : " '.tr('Stato').' " , " name " : " id_stato " , " required " : 1 , " values " : " query=SELECT `or_statiordine`.`id`, `title` as descrizione, `colore` as _bgcolor_ FROM `or_statiordine` LEFT JOIN `or_statiordine_lang` ON (`or_statiordine`.`id` = `or_statiordine_lang`.`id_record` AND `or_statiordine_lang`.`id_lang` = '.prepare(Models \ Locale::getDefault()->id).') ORDER BY `title` ASC " ]} ' ,
2021-01-19 12:20:06 +01:00
'button' => tr ( 'Procedi' ),
'class' => 'btn btn-lg btn-warning' ,
'blank' => false ,
],
];
2021-02-18 18:48:44 +01:00
2022-02-14 10:51:36 +01:00
return $operations ;