This commit is contained in:
Fabio Lovato 2020-04-01 15:39:28 +02:00
commit d6e6ea200c
16 changed files with 230 additions and 252 deletions

View File

@ -241,6 +241,7 @@ elseif (post('op') == 'send-email') {
$mail->addUpload($file); $mail->addUpload($file);
} }
// Salvataggio email nella coda di invio
$mail->save(); $mail->save();
// Invio mail istantaneo // Invio mail istantaneo

View File

@ -134,13 +134,11 @@ if (empty($record) || !$has_access) {
if (!empty($record['deleted_at'])) { if (!empty($record['deleted_at'])) {
$operation = $dbo->fetchOne("SELECT zz_operations.created_at, username FROM zz_operations INNER JOIN zz_users ON zz_operations.id_utente = zz_users.id WHERE op='delete' AND id_module=".prepare($id_module).' AND id_record='.prepare($id_record).' ORDER BY zz_operations.created_at DESC'); $operation = $dbo->fetchOne("SELECT zz_operations.created_at, username FROM zz_operations INNER JOIN zz_users ON zz_operations.id_utente = zz_users.id WHERE op='delete' AND id_module=".prepare($id_module).' AND id_record='.prepare($id_record).' ORDER BY zz_operations.created_at DESC');
$info = tr('Il record è stato eliminato il <b>_DATE_</b> da <b>_USER_</b>', [ $info = tr('Il record è stato eliminato il <b>_DATE_</b> da <b>_USER_</b>', [
'_DATE_' => (($operation['created_at']) ? Translator::timestampToLocale($operation['created_at']) : Translator::timestampToLocale($record['deleted_at'])), '_DATE_' => (($operation['created_at']) ? Translator::timestampToLocale($operation['created_at']) : Translator::timestampToLocale($record['deleted_at'])),
'_USER_' => ((!empty($operation['username'])) ? $operation['username'] : 'N.D.'), '_USER_' => ((!empty($operation['username'])) ? $operation['username'] : 'N.D.'),
]).'. '; ]).'. ';
echo ' echo '
<div class="alert alert-warning"> <div class="alert alert-warning">
<div class="row" > <div class="row" >

View File

@ -24,7 +24,7 @@ switch ($resource) {
($fatture[$i]['n2_fattura'] != '') ? $n_fattura = $fatture[$i]['n2_fattura'] : $n_fattura = $fatture[$i]['n_fattura']; ($fatture[$i]['n2_fattura'] != '') ? $n_fattura = $fatture[$i]['n2_fattura'] : $n_fattura = $fatture[$i]['n_fattura'];
$link_id = Modules::get('Fatture di vendita')['id']; $link_id = Modules::get('Fatture di vendita')['id'];
echo "<tr><td class='first_cell text-left'><a href='".ROOTDIR.'/editor.php?id_module='.$link_id.'&id_record='.$fatture[$i]['iddocumento']."' target=\"_blank\" title=\"Apri il documento su una nuova finestra\">Fatt. n. ".$n_fattura." del ".Translator::dateToLocale($fatture[$i]['data_fattura'])." </a></td>\n"; echo "<tr><td class='first_cell text-left'><a href='".ROOTDIR.'/editor.php?id_module='.$link_id.'&id_record='.$fatture[$i]['iddocumento']."' target=\"_blank\" title=\"Apri il documento su una nuova finestra\">Fatt. n. ".$n_fattura.' del '.Translator::dateToLocale($fatture[$i]['data_fattura'])." </a></td>\n";
echo "<td class='table_cell text-right'>".moneyFormat($fatture[$i]['costo_unitario'])."</td></tr>\n"; echo "<td class='table_cell text-right'>".moneyFormat($fatture[$i]['costo_unitario'])."</td></tr>\n";
array_push($ids, '"'.$fatture[$i]['iddocumento'].'"'); array_push($ids, '"'.$fatture[$i]['iddocumento'].'"');
} }
@ -51,7 +51,7 @@ switch ($resource) {
($fatture[$i]['n2_fattura'] != '') ? $n_fattura = $fatture[$i]['n2_fattura'] : $n_fattura = $fatture[$i]['n_fattura']; ($fatture[$i]['n2_fattura'] != '') ? $n_fattura = $fatture[$i]['n2_fattura'] : $n_fattura = $fatture[$i]['n_fattura'];
$link_id = Modules::get('Fatture di vendita')['id']; $link_id = Modules::get('Fatture di vendita')['id'];
echo "<tr><td class='first_cell text-left'><a href='".ROOTDIR.'/editor.php?id_module='.$link_id.'&id_record='.$fatture[$i]['iddocumento']."' target=\"_blank\" title=\"Apri il documento su una nuova finestra\">Fatt. n. ".$n_fattura." del ".Translator::dateToLocale($fatture[$i]['data_fattura'])."</a></td>\n"; echo "<tr><td class='first_cell text-left'><a href='".ROOTDIR.'/editor.php?id_module='.$link_id.'&id_record='.$fatture[$i]['iddocumento']."' target=\"_blank\" title=\"Apri il documento su una nuova finestra\">Fatt. n. ".$n_fattura.' del '.Translator::dateToLocale($fatture[$i]['data_fattura'])."</a></td>\n";
echo "<td class='table_cell text-right'>".moneyFormat($fatture[$i]['costo_unitario'])."</td></tr>\n"; echo "<td class='table_cell text-right'>".moneyFormat($fatture[$i]['costo_unitario'])."</td></tr>\n";
} }
echo "</table>\n"; echo "</table>\n";
@ -78,7 +78,7 @@ switch ($resource) {
($fatture[$i]['n2_fattura'] != '') ? $n_fattura = $fatture[$i]['n2_fattura'] : $n_fattura = $fatture[$i]['n_fattura']; ($fatture[$i]['n2_fattura'] != '') ? $n_fattura = $fatture[$i]['n2_fattura'] : $n_fattura = $fatture[$i]['n_fattura'];
$link_id = Modules::get('Fatture di acquisto')['id']; $link_id = Modules::get('Fatture di acquisto')['id'];
echo "<tr><td class='first_cell text-left'><a href='".ROOTDIR.'/editor.php?id_module='.$link_id.'&id_record='.$fatture[$i]['iddocumento']."' target=\"_blank\" title=\"Apri il documento su una nuova finestra\">Fatt. n. ".$n_fattura." del ".Translator::dateToLocale($fatture[$i]['data_fattura'])."</a></td>\n"; echo "<tr><td class='first_cell text-left'><a href='".ROOTDIR.'/editor.php?id_module='.$link_id.'&id_record='.$fatture[$i]['iddocumento']."' target=\"_blank\" title=\"Apri il documento su una nuova finestra\">Fatt. n. ".$n_fattura.' del '.Translator::dateToLocale($fatture[$i]['data_fattura'])."</a></td>\n";
echo "<td class='table_cell text-right'>".moneyFormat($fatture[$i]['costo_unitario'])."</td></tr>\n"; echo "<td class='table_cell text-right'>".moneyFormat($fatture[$i]['costo_unitario'])."</td></tr>\n";
} }
echo "</table>\n"; echo "</table>\n";

View File

@ -100,13 +100,13 @@ if (!empty($elementi)) {
echo ' echo '
<li>'.Modules::link($modulo, $id, $descrizione).'</li>'; <li>'.Modules::link($modulo, $id, $descrizione).'</li>';
} }
echo ' echo '
</ul> </ul>
</div> </div>
</div>'; </div>';
}else { } else {
echo ' echo '
<a class="btn btn-danger ask" data-backto="record-list"> <a class="btn btn-danger ask" data-backto="record-list">
<i class="fa fa-trash"></i> '.tr('Elimina').' <i class="fa fa-trash"></i> '.tr('Elimina').'

View File

@ -4,10 +4,6 @@ include_once __DIR__.'/../../core.php';
$subcategorie = $dbo->fetchArray('SELECT * FROM `mg_categorie` WHERE `parent`='.prepare($id_record).' ORDER BY nome ASC '); $subcategorie = $dbo->fetchArray('SELECT * FROM `mg_categorie` WHERE `parent`='.prepare($id_record).' ORDER BY nome ASC ');
foreach ($subcategorie as $sub) { foreach ($subcategorie as $sub) {
$n_articoli = $dbo->fetchNum('SELECT * FROM `mg_articoli` WHERE `id_sottocategoria`='.prepare($sub['id'])); $n_articoli = $dbo->fetchNum('SELECT * FROM `mg_articoli` WHERE `id_sottocategoria`='.prepare($sub['id']));
echo ' echo '
@ -17,7 +13,7 @@ foreach ($subcategorie as $sub) {
<td>'.$sub['nota'].'</td> <td>'.$sub['nota'].'</td>
<td> <td>
<a class="btn btn-warning btn-sm" title="Modifica riga" onclick="launch_modal(\''.tr('Modifica sottocategoria').'\', \''.$rootdir.'/add.php?id_module='.$id_module.'&id_record='.$sub['id'].'&id_original='.$id_record.'\');"><i class="fa fa-edit"></i></a> <a class="btn btn-warning btn-sm" title="Modifica riga" onclick="launch_modal(\''.tr('Modifica sottocategoria').'\', \''.$rootdir.'/add.php?id_module='.$id_module.'&id_record='.$sub['id'].'&id_original='.$id_record.'\');"><i class="fa fa-edit"></i></a>
<a class="btn btn-sm btn-danger ask '.(($n_articoli>0) ? 'disabled tip' : '').'" data-backto="record-edit" data-id="'.$sub['id'].'" title="'.(($n_articoli>0) ? 'Sottocategoria collegata a '.$n_articoli.' articoli' : '' ).'"> <a class="btn btn-sm btn-danger ask '.(($n_articoli > 0) ? 'disabled tip' : '').'" data-backto="record-edit" data-id="'.$sub['id'].'" title="'.(($n_articoli > 0) ? 'Sottocategoria collegata a '.$n_articoli.' articoli' : '').'">
<i class="fa fa-trash"></i> <i class="fa fa-trash"></i>
</a> </a>
</td> </td>

View File

@ -65,11 +65,7 @@ class Mail extends Model
public function resetPrints() public function resetPrints()
{ {
$prints = $this->prints; $this->prints()->detach();
foreach ($prints as $print) {
$this->prints()->detach($print->id, ['id_email' => $this->id]);
}
} }
/** /**

View File

@ -615,7 +615,7 @@ if (!$block_edit) {
$art_query = 'SELECT id FROM mg_articoli WHERE attivo = 1 AND deleted_at IS NULL'; $art_query = 'SELECT id FROM mg_articoli WHERE attivo = 1 AND deleted_at IS NULL';
if ($dir == 'entrata') { if ($dir == 'entrata') {
$art_query .= ' AND (qta > 0 OR servizio = 1)'; $art_query .= ' AND (qta > 0 OR servizio = 1)';
}else{ } else {
//Gli articoli possono essere creati al volo direttamente dal modale di aggiunta articolo //Gli articoli possono essere creati al volo direttamente dal modale di aggiunta articolo
$art_query .= ' OR 1=1'; $art_query .= ' OR 1=1';
} }

View File

@ -3,12 +3,8 @@
namespace Modules\Interventi\API\v1; namespace Modules\Interventi\API\v1;
use API\Interfaces\CreateInterface; use API\Interfaces\CreateInterface;
use API\Interfaces\DeleteInterface;
use API\Interfaces\RetrieveInterface; use API\Interfaces\RetrieveInterface;
use API\Interfaces\UpdateInterface;
use API\Resource; use API\Resource;
use Modules;
use Modules\Anagrafiche\Anagrafica;
class Impianti extends Resource implements RetrieveInterface, CreateInterface class Impianti extends Resource implements RetrieveInterface, CreateInterface
{ {

View File

@ -3,14 +3,10 @@
namespace Modules\Interventi\API\v1; namespace Modules\Interventi\API\v1;
use API\Interfaces\CreateInterface; use API\Interfaces\CreateInterface;
use API\Interfaces\DeleteInterface;
use API\Interfaces\RetrieveInterface; use API\Interfaces\RetrieveInterface;
use API\Interfaces\UpdateInterface;
use API\Resource; use API\Resource;
use Modules;
use Modules\Anagrafiche\Anagrafica;
use Modules\Emails\Template;
use Modules\Emails\Mail; use Modules\Emails\Mail;
use Modules\Emails\Template;
class Rapportino extends Resource implements RetrieveInterface, CreateInterface class Rapportino extends Resource implements RetrieveInterface, CreateInterface
{ {
@ -65,7 +61,6 @@ class Rapportino extends Resource implements RetrieveInterface, CreateInterface
$mail->save(); $mail->save();
return [ return [
]; ];
} }
} }

View File

@ -2,13 +2,8 @@
namespace Modules\Impianti\API\v1; namespace Modules\Impianti\API\v1;
use API\Interfaces\CreateInterface;
use API\Interfaces\DeleteInterface;
use API\Interfaces\RetrieveInterface; use API\Interfaces\RetrieveInterface;
use API\Interfaces\UpdateInterface;
use API\Resource; use API\Resource;
use Modules;
use Modules\Anagrafiche\Anagrafica;
class Impianti extends Resource implements RetrieveInterface class Impianti extends Resource implements RetrieveInterface
{ {

View File

@ -50,7 +50,7 @@ echo '
if (!empty($variables)) { if (!empty($variables)) {
echo ' echo '
<p>'.tr("Puoi utilizzare le seguenti variabili per generare il nome del file").':</p> <p>'.tr('Puoi utilizzare le seguenti variabili per generare il nome del file').':</p>
<ul>'; <ul>';
foreach ($variables as $variable => $value) { foreach ($variables as $variable => $value) {

View File

@ -592,8 +592,7 @@ class Validator
if ($info['type'] == 'decimal') { if ($info['type'] == 'decimal') {
if (in_array($key, ['PrezzoUnitario', 'PrezzoTotale'])) { if (in_array($key, ['PrezzoUnitario', 'PrezzoTotale'])) {
$output = number_format($output, setting('Cifre decimali per importi'), '.', ''); $output = number_format($output, setting('Cifre decimali per importi'), '.', '');
} } elseif (in_array($key, ['Quantita'])) {
else if (in_array($key, ['Quantita'])) {
$output = number_format($output, setting('Cifre decimali per quantità'), '.', ''); $output = number_format($output, setting('Cifre decimali per quantità'), '.', '');
} else { } else {
$output = number_format($output, 2, '.', ''); $output = number_format($output, 2, '.', '');

View File

@ -63,7 +63,7 @@ foreach ($iva_righe as $id_iva => $righe) {
<div class="row"> <div class="row">
<div class="col-md-9"> <div class="col-md-9">
{[ "type": "textarea", "label": "'.tr('Descrizione').'", "name": "descrizione['.$id_iva.']", "value": "'.tr('Canone contratto numero _NUM__IVA_', [ {[ "type": "textarea", "label": "'.tr('Descrizione').'", "name": "descrizione['.$id_iva.']", "value": "'.tr('Canone contratto numero _NUM__IVA_', [
'_IVA_' => (count($iva_righe) > 1 ) ? ': '.$iva->descrizione : '', '_IVA_' => (count($iva_righe) > 1) ? ': '.$iva->descrizione : '',
'_NUM_' => $contratto->numero, '_NUM_' => $contratto->numero,
]).'" ]} ]).'" ]}

View File

@ -6,6 +6,10 @@ use Modules\Contratti\Contratto;
use Modules\Contratti\Stato; use Modules\Contratti\Stato;
$contratto = Contratto::find($id_record); $contratto = Contratto::find($id_record);
if (empty($contratto)) {
return;
}
$is_pianificabile = $contratto->stato->is_pianificabile && !empty($contratto['data_accettazione']); // Contratto permette la pianificazione $is_pianificabile = $contratto->stato->is_pianificabile && !empty($contratto['data_accettazione']); // Contratto permette la pianificazione
$is_pianificato = false; $is_pianificato = false;
$stati_pianificabili = Stato::where('is_pianificabile', 1)->get(); $stati_pianificabili = Stato::where('is_pianificabile', 1)->get();
@ -21,9 +25,8 @@ echo '
<i class="fa fa-warning"></i> '.tr("Tutte le righe del contratto vengono convertite in righe generiche, rendendo impossibile risalire ad eventuali articoli utilizzati all'interno del contratto e pertanto non movimentando il magazzino").'. <i class="fa fa-warning"></i> '.tr("Tutte le righe del contratto vengono convertite in righe generiche, rendendo impossibile risalire ad eventuali articoli utilizzati all'interno del contratto e pertanto non movimentando il magazzino").'.
</div>'; </div>';
if ($contratto->pianificazioni !== NULL) { $pianificazioni = $contratto->pianificazioni;
$pianificazioni = $contratto->pianificazioni; if (!$pianificazioni->isEmpty()) {
if (!$pianificazioni->isEmpty()) {
echo ' echo '
<hr> <hr>
<table class="table table-bordered table-striped table-hover table-condensed"> <table class="table table-bordered table-striped table-hover table-condensed">
@ -94,7 +97,7 @@ if ($contratto->pianificazioni !== NULL) {
</button>'; </button>';
echo '<div class="clearfix"></div>'; echo '<div class="clearfix"></div>';
} else { } else {
echo ' echo '
<div class="alert alert-info"> <div class="alert alert-info">
<i class="fa fa-info-circle"></i> '.tr('Pianificazione della fatturazione non impostata per questo contratto').'. <i class="fa fa-info-circle"></i> '.tr('Pianificazione della fatturazione non impostata per questo contratto').'.
@ -104,7 +107,7 @@ if ($contratto->pianificazioni !== NULL) {
<i class="fa fa-plus"></i> '.tr('Pianifica').' <i class="fa fa-plus"></i> '.tr('Pianifica').'
</button> </button>
<div class="clearfix"></div>'; <div class="clearfix"></div>';
} }
echo ' echo '
<script type="text/javascript"> <script type="text/javascript">
@ -116,4 +119,3 @@ if ($contratto->pianificazioni !== NULL) {
openModal("Crea fattura", "'.$structure->fileurl('crea_fattura.php').'?id_module='.$id_module.'&id_plugin='.$id_plugin.'&id_record='.$id_record.'&rata=" + rata); openModal("Crea fattura", "'.$structure->fileurl('crea_fattura.php').'?id_module='.$id_module.'&id_plugin='.$id_plugin.'&id_record='.$id_record.'&rata=" + rata);
} }
</script>'; </script>';
}

View File

@ -6,27 +6,28 @@ use Modules\Contratti\Contratto;
use Modules\Contratti\Stato; use Modules\Contratti\Stato;
$contratto = Contratto::find($id_record); $contratto = Contratto::find($id_record);
if (empty($contratto)) {
return;
}
$is_pianificabile = $contratto->stato->is_pianificabile && !empty($contratto['data_accettazione']); // Contratto permette la pianificazione $is_pianificabile = $contratto->stato->is_pianificabile && !empty($contratto['data_accettazione']); // Contratto permette la pianificazione
$elenco_promemoria = $contratto->promemoria->sortBy('data_richiesta');
if ($contratto->promemoria !== NULL) { $stati_pianificabili = Stato::where('is_pianificabile', 1)->get();
$elenco_promemoria = $contratto->promemoria->sortBy('data_richiesta'); $elenco_stati = $stati_pianificabili->implode('descrizione', ', ');
echo '
$stati_pianificabili = Stato::where('is_pianificabile', 1)->get(); <p>'.tr('Puoi <b>pianificare dei "promemoria" o direttamente gli interventi</b> da effettuare entro determinate scadenze').'. '.tr('Per poter pianificare i promemoria, il contratto deve avere <b>data accettazione</b> e <b>data conclusione</b> definita ed essere in uno dei seguenti stati: _LINK_', [
$elenco_stati = $stati_pianificabili->implode('descrizione', ', ');
echo '
<p>'.tr('Puoi <b>pianificare dei "promemoria" o direttamente gli interventi</b> da effettuare entro determinate scadenze').'. '.tr('Per poter pianificare i promemoria, il contratto deve avere <b>data accettazione</b> e <b>data conclusione</b> definita ed essere in uno dei seguenti stati: _LINK_', [
'_LINK_' => '<b>'.$elenco_stati.'</b>', '_LINK_' => '<b>'.$elenco_stati.'</b>',
]).' ]).'
<span class="tip" title="'.tr("I promemoria verranno visualizzati sulla 'Dashboard' e serviranno per semplificare la pianificazione del giorno dell'intervento, ad esempio nel caso di interventi con cadenza mensile").'"> <span class="tip" title="'.tr("I promemoria verranno visualizzati sulla 'Dashboard' e serviranno per semplificare la pianificazione del giorno dell'intervento, ad esempio nel caso di interventi con cadenza mensile").'">
<i class="fa fa-question-circle-o"></i> <i class="fa fa-question-circle-o"></i>
</span></p>'; </span></p>';
echo ' echo '
<hr> <hr>
<div class="row"> <div class="row">
<div class="col-md-9"> <div class="col-md-9">
{[ "type": "select", "placeholder": "'.tr('Tipo di promemoria').'", "name": "id_tipo_promemoria", "required": 1, "ajax-source": "tipiintervento", "class": "unblockable" ]} {[ "type": "select", "placeholder": "'.tr('Tipo di promemoria').'", "name": "id_tipo_promemoria", "required": 1, "ajax-source": "tipiintervento", "class": "unblockable" ]}
</div> </div>
@ -36,13 +37,13 @@ if ($contratto->promemoria !== NULL) {
<i class="fa fa-plus"></i> '.tr('Nuovo promemoria').' <i class="fa fa-plus"></i> '.tr('Nuovo promemoria').'
</button> </button>
</div> </div>
</div> </div>
<hr>'; <hr>';
// Nessun intervento pianificato // Nessun intervento pianificato
if (!$elenco_promemoria->isEmpty()) { if (!$elenco_promemoria->isEmpty()) {
echo ' echo '
<table class="table table-condensed table-striped table-hover"> <table class="table table-condensed table-striped table-hover">
<thead> <thead>
<tr> <tr>
<th>'.tr('Data').'</th> <th>'.tr('Data').'</th>
@ -152,26 +153,26 @@ if ($contratto->promemoria !== NULL) {
} }
echo ' echo '
</tbody> </tbody>
</table>'; </table>';
if (!empty($promemorias)) { if (!empty($promemorias)) {
echo ' echo '
<br> <br>
<div class="pull-right"> <div class="pull-right">
<button type="button" title="Elimina tutti i promemoria non associati ad intervento" class="btn btn-danger ask tip" data-op="delete-non-associati" data-id_plugin="'.$id_plugin.'" data-backto="record-edit"> <button type="button" title="Elimina tutti i promemoria non associati ad intervento" class="btn btn-danger ask tip" data-op="delete-non-associati" data-id_plugin="'.$id_plugin.'" data-backto="record-edit">
<i class="fa fa-trash"></i> '.tr('Elimina promemoria').' <i class="fa fa-trash"></i> '.tr('Elimina promemoria').'
</button> </button>
</div>'; </div>';
} }
} else { } else {
echo ' echo '
<div class="alert alert-info"> <div class="alert alert-info">
<i class="fa fa-warning"></i> '.tr('Nessun promemoria pianificato per il contratto corrente').'. <i class="fa fa-warning"></i> '.tr('Nessun promemoria pianificato per il contratto corrente').'.
</div>'; </div>';
} }
echo ' echo '
<script type="text/javascript"> <script type="text/javascript">
$("#add_promemoria").click(function() { $("#add_promemoria").click(function() {
var id_tipo = $("#id_tipo_promemoria").val(); var id_tipo = $("#id_tipo_promemoria").val();
if (!id_tipo){ if (!id_tipo){
@ -190,5 +191,4 @@ if ($contratto->promemoria !== NULL) {
buttonRestore("#add_promemoria", restore); buttonRestore("#add_promemoria", restore);
}); });
}); });
</script>'; </script>';
}