2018-02-19 17:57:27 +01:00
< ? php
include_once __DIR__ . '/../../core.php' ;
2018-05-24 18:41:43 +02:00
// Info documento
2019-02-15 12:12:44 +01:00
$rs = $dbo -> fetchArray ( 'SELECT * FROM co_documenti WHERE id=' . prepare ( $id_record ));
2018-02-19 17:57:27 +01:00
$idanagrafica = $rs [ 0 ][ 'idanagrafica' ];
if ( $module [ 'name' ] == 'Fatture di vendita' ) {
$dir = 'entrata' ;
$conti = 'conti-vendite' ;
} else {
$dir = 'uscita' ;
$conti = 'conti-acquisti' ;
2018-07-09 17:21:25 +02:00
}
2018-06-26 14:30:26 +02:00
2018-07-09 17:21:25 +02:00
// Conto dalle impostazioni
if ( empty ( $idconto )) {
$idconto = ( $dir == 'entrata' ) ? setting ( 'Conto predefinito fatture di vendita' ) : setting ( 'Conto predefinito fatture di acquisto' );
2018-02-19 17:57:27 +01:00
}
// Impostazioni per la gestione
$options = [
2018-10-04 17:25:42 +02:00
'op' => 'manage_riga' ,
2018-02-19 17:57:27 +01:00
'action' => 'add' ,
'dir' => $dir ,
'conti' => $conti ,
'idanagrafica' => $idanagrafica ,
2019-02-15 12:12:44 +01:00
'show-ritenuta-contributi' => ! empty ( $rs [ 0 ][ 'id_ritenuta_contributi' ]),
2018-02-19 17:57:27 +01:00
];
// Dati di default
$result = [
'descrizione' => '' ,
'qta' => 1 ,
'um' => '' ,
'prezzo' => 0 ,
'sconto_unitario' => 0 ,
'tipo_sconto' => '' ,
'idiva' => '' ,
2018-05-24 18:41:43 +02:00
'idconto' => $idconto ,
2019-02-15 12:12:44 +01:00
'ritenuta_contributi' => true ,
2018-02-19 17:57:27 +01:00
];
// Leggo l'iva predefinita per l'anagrafica e se non c'è leggo quella predefinita generica
$iva = $dbo -> fetchArray ( 'SELECT idiva_' . ( $dir == 'uscita' ? 'acquisti' : 'vendite' ) . ' AS idiva FROM an_anagrafiche WHERE idanagrafica=' . prepare ( $idanagrafica ));
2018-07-08 18:11:17 +02:00
$result [ 'idiva' ] = $iva [ 0 ][ 'idiva' ] ? : setting ( 'Iva predefinita' );
2018-02-19 17:57:27 +01:00
2019-01-11 10:22:33 +01:00
// Aggiunta sconto di default da listino per le vendite
$listino = $dbo -> fetchArray ( 'SELECT prc_guadagno FROM an_anagrafiche INNER JOIN mg_listini ON an_anagrafiche.idlistino_' . ( $dir == 'uscita' ? 'acquisti' : 'vendite' ) . '=mg_listini.id WHERE idanagrafica=' . prepare ( $idanagrafica ));
2019-01-17 16:11:10 +01:00
if ( $listino [ 0 ][ 'prc_guadagno' ] > 0 ) {
2019-01-11 10:22:33 +01:00
$result [ 'sconto_unitario' ] = $listino [ 0 ][ 'prc_guadagno' ];
$result [ 'tipo_sconto' ] = 'PRC' ;
}
2018-09-26 10:54:57 +02:00
// Leggo la ritenuta d'acconto predefinita per l'anagrafica e se non c'è leggo quella predefinita generica
2018-09-26 12:06:24 +02:00
$ritenuta_acconto = $dbo -> fetchOne ( 'SELECT id_ritenuta_acconto_' . ( $dir == 'uscita' ? 'acquisti' : 'vendite' ) . ' AS id_ritenuta_acconto FROM an_anagrafiche WHERE idanagrafica=' . prepare ( $idanagrafica ));
2018-09-26 15:37:46 +02:00
$options [ 'id_ritenuta_acconto_predefined' ] = $ritenuta_acconto [ 'id_ritenuta_acconto' ];
2018-09-26 10:54:57 +02:00
2018-02-19 17:57:27 +01:00
// Importazione della gestione dedicata
$file = 'riga' ;
2018-07-19 15:33:32 +02:00
if ( get ( 'is_descrizione' ) !== null ) {
2018-02-19 17:57:27 +01:00
$file = 'descrizione' ;
2018-09-26 15:37:46 +02:00
2018-10-04 17:25:42 +02:00
$options [ 'op' ] = 'manage_descrizione' ;
2018-07-19 15:33:32 +02:00
} elseif ( get ( 'is_articolo' ) !== null ) {
2018-02-19 17:57:27 +01:00
$file = 'articolo' ;
2018-10-04 17:25:42 +02:00
$options [ 'op' ] = 'manage_articolo' ;
2018-02-19 17:57:27 +01:00
}
echo App :: load ( $file . '.php' , $result , $options );