2017-08-04 16:28:16 +02:00
< ? php
/**
* Sostituisce a delle stringhe ( $nome_stringa $ ) i valori delle anagrafiche .
*/
include_once __DIR__ . '/../core.php' ;
// Retrocompatibilità
$id_cliente = $id_cliente ? : $idcliente ;
// Leggo i dati della destinazione (se 0=sede legale, se!=altra sede da leggere da tabella an_sedi)
if ( empty ( $id_sede ) || $id_sede == '-1' ) {
$queryc = 'SELECT * FROM an_anagrafiche WHERE idanagrafica=' . prepare ( $id_cliente );
} else {
$queryc = 'SELECT an_anagrafiche.*, an_sedi.* FROM an_sedi JOIN an_anagrafiche ON an_anagrafiche.idanagrafica=an_sedi.idanagrafica WHERE an_sedi.idanagrafica=' . prepare ( $id_cliente ) . ' AND an_sedi.id=' . prepare ( $id_sede );
}
$rsc = $dbo -> fetchArray ( $queryc );
// Lettura dati aziendali
$rsf = $dbo -> fetchArray ( " SELECT * FROM an_anagrafiche WHERE idanagrafica = (SELECT valore FROM zz_settings WHERE nome='Azienda predefinita') " );
$id_azienda = $rsd [ 0 ][ 'id' ];
$replace = [
'c_' => $rsc [ 0 ],
'f_' => $rsf [ 0 ],
];
$rename = [
'capitale_sociale' => 'capsoc' ,
'ragione_sociale' => 'ragionesociale' ,
'codice' => 'codiceanagrafica' ,
];
$keys = [];
foreach ( $replace as $prefix => $values ) {
$values = ( array ) $values ;
if ( $prefix == 'c_' ) {
$keys = array_keys ( $values );
}
2017-08-29 16:34:02 +02:00
// Azienda predefinita non impostata
if ( empty ( $values ) && $prefix == 'f_' ) {
$values = [];
foreach ( $keys as $key ) {
$values [ $key ] = '' ;
2017-08-04 16:28:16 +02:00
}
}
foreach ( $rename as $key => $value ) {
$values [ $value ] = $values [ $key ];
unset ( $values [ $key ]);
}
foreach ( $values as $key => $value ) {
$ { $prefix . $key } = $value ;
}
$values [ 'codice' ] = ! empty ( $values [ 'codice' ]) ? $values [ 'codice' ] . ',' : '' ;
$values [ 'ragionesociale' ] = ! empty ( $values [ 'ragionesociale' ]) ? $values [ 'ragionesociale' ] . ',' : '' ;
$values [ 'provincia' ] = ! empty ( $values [ 'provincia' ]) ? '(' . $values [ 'provincia' ] . ')' : '' ;
$citta = '' ;
if ( $values [ 'cap' ] != '' ) {
$citta .= $values [ 'cap' ];
}
if ( $values [ 'citta' ] != '' ) {
$citta .= ' ' . $values [ 'citta' ];
}
if ( $values [ 'provincia' ] != '' ) {
$citta .= ' ' . $values [ 'provincia' ];
}
$citta .= '<br/>' ;
$values [ 'citta' ] = $citta ;
if ( $values [ 'piva' ] != $values [ 'codicefiscale' ]) {
$values [ 'piva' ] = ! empty ( $values [ 'piva' ]) ? 'P.Iva: ' . $values [ 'piva' ] : '' ;
$values [ 'codicefiscale' ] = ! empty ( $values [ 'codicefiscale' ]) ? 'C.F.: ' . $values [ 'codicefiscale' ] : '' ;
} else {
$values [ 'piva' ] = ! empty ( $values [ 'piva' ]) ? 'P.Iva/C.F.: ' . $values [ 'piva' ] : '' ;
$values [ 'codicefiscale' ] = '' ;
}
$values [ 'capsoc' ] = ! empty ( $values [ 'capsoc' ]) ? 'Cap.Soc.: ' . $values [ 'capsoc' ] : '' ;
$values [ 'sitoweb' ] = ! empty ( $values [ 'sitoweb' ]) ? 'Web: ' . $values [ 'sitoweb' ] : '' ;
$values [ 'telefono' ] = ! empty ( $values [ 'telefono' ]) ? 'Tel: ' . $values [ 'telefono' ] : '' ;
$values [ 'fax' ] = ! empty ( $values [ 'fax' ]) ? 'Fax: ' . $values [ 'fax' ] : '' ;
$values [ 'cellulare' ] = ! empty ( $values [ 'cellulare' ]) ? 'Cell: ' . $values [ 'cellulare' ] : '' ;
$values [ 'email' ] = ! empty ( $values [ 'email' ]) ? 'Email: ' . $values [ 'email' ] : '' ;
$values [ 'codiceiban' ] = ! empty ( $values [ 'codiceiban' ]) ? 'Cap.Soc.: ' . $values [ 'codiceiban' ] : '' ;
if ( $key == 'c_' ) {
$keys = array_unique ( array_merge ( $keys , array_keys ( $values )));
}
foreach ( $values as $key => $value ) {
$values [ '$' . $prefix . $key . '$' ] = empty ( $value ) ? $value : $value . '<br/>' ;
unset ( $values [ $key ]);
}
// Sostituisce alle variabili del template i valori
$body = str_replace ( array_keys ( $values ), array_values ( $values ), $body );
$report = str_replace ( array_keys ( $values ), array_values ( $values ), $report );
}
2017-08-31 16:23:26 +02:00
// Valori aggiuntivi per la sostituzione
$values = [
'dicitura_fissa_fattura' => get_var ( 'Dicitura fissa fattura' ),
];
foreach ( $values as $key => $value ) {
$values [ '$' . $key . '$' ] = empty ( $value ) ? $value : $value . '<br/>' ;
unset ( $values [ $key ]);
}
// Sostituisce alle variabili del template i valori
$body = str_replace ( array_keys ( $values ), array_values ( $values ), $body );
$report = str_replace ( array_keys ( $values ), array_values ( $values ), $report );
2017-08-04 16:28:16 +02:00
// Aggiunta del footer standard
2017-08-28 15:29:03 +02:00
if ( ! str_contains ( $body , '<page_footer>' ) && ! str_contains ( $report , '<page_footer>' )) {
2017-08-04 16:28:16 +02:00
$report .= '
<!-- Footer -->
< page_footer >
< table style = " color:#aaa; font-size:10px; " >
< tr >
< td align = " left " style = " width:97mm; " >
'._(' Stampato con OpenSTAManager ').'
</ td >
< td align = " right " style = " width:97mm; " >
'.str_replace([' _PAGE_ ', ' _TOTAL_ '], [' [[ page_cu ]] ', ' [[ page_nb ]] '], _(' Pagina _PAGE_ di _TOTAL_ ')).'
</ td >
</ tr >
</ table >
</ page_footer > ' ;
}