openstamanager/templates/info.php

106 lines
3.0 KiB
PHP
Raw Normal View History

2017-09-08 18:19:39 +02:00
<?php
// Valori aggiuntivi per la sostituzione
$replaces = [
'docroot' => DOCROOT,
'rootdir' => ROOTDIR,
'footer' => !empty($footer) ? $footer : '',
'dicitura_fissa_fattura' => get_var('Dicitura fissa fattura'),
'pagination' => '
<table style="color:#aaa; font-size:10px;">
<tr>
<td align="left" style="width:97mm;">
'.tr('Stampato con OpenSTAManager').'
</td>
<td align="right" style="width:97mm;">
'.tr('Pagina _PAGE_ di _TOTAL_', [
'_PAGE_' => '{PAGENO}',
'_TOTAL_' => '{nb}',
]).'
2017-09-08 18:19:39 +02:00
</td>
</tr>
</table>',
];
// 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')");
2017-09-12 11:49:39 +02:00
// Prefissi e contenuti del replace
2017-09-08 18:19:39 +02:00
$replace = [
'c_' => $rsc[0],
'f_' => $rsf[0],
];
2017-09-12 11:49:39 +02:00
// Rinominazione di particolari campi all'interno delle informazioni su anagrafica e azienda
2017-09-08 18:19:39 +02:00
$rename = [
'capitale_sociale' => 'capsoc',
'ragione_sociale' => 'ragionesociale',
'codice_fiscale' => 'codicefiscale',
];
$keys = [];
2017-09-12 11:49:39 +02:00
// Predisposizione delle informazioni delle anagrafiche per la sostituzione automatica
2017-09-08 18:19:39 +02:00
foreach ($replace as $prefix => $values) {
2017-09-12 11:49:39 +02:00
// Individuazione dei campi minimi
2017-09-08 18:19:39 +02:00
$values = (array) $values;
if ($prefix == 'c_') {
$keys = array_keys($values);
}
2017-09-12 11:49:39 +02:00
// Se l'azienda predefinita non è impostata
2017-09-08 18:19:39 +02:00
if (empty($values) && $prefix == 'f_') {
$values = [];
foreach ($keys as $key) {
$values[$key] = '';
}
}
2017-09-12 11:49:39 +02:00
// Rinominazione dei campi
2017-09-08 18:19:39 +02:00
foreach ($rename as $key => $value) {
$values[$value] = $values[$key];
unset($values[$key]);
}
2017-09-12 11:49:39 +02:00
// Salvataggio dei campi come variabili PHP
2017-09-08 18:19:39 +02:00
foreach ($values as $key => $value) {
${$prefix.$key} = $value;
}
2017-09-12 11:49:39 +02:00
// Eventuali estensioni dei contenuti
2017-09-08 18:19:39 +02:00
$citta = '';
if (!empty($values['cap'])) {
2017-09-08 18:19:39 +02:00
$citta .= $values['cap'];
}
if (!empty($values['citta'])) {
2017-09-08 18:19:39 +02:00
$citta .= ' '.$values['citta'];
}
if (!empty($values['provincia'])) {
2017-09-08 18:19:39 +02:00
$citta .= ' ('.$values['provincia'].')';
}
$values['citta_full'] = $citta;
2017-09-12 11:49:39 +02:00
// Completamento dei campi minimi
2017-09-08 18:19:39 +02:00
if ($key == 'c_') {
$keys = array_unique(array_merge($keys, array_keys($values)));
}
2017-09-12 11:49:39 +02:00
// Aggiunta delle informazioni per la sostituzione automatica
2017-09-08 18:19:39 +02:00
foreach ($values as $key => $value) {
$replaces[$prefix.$key] = $value;
}
}