diff --git a/modules/ddt/edit.php b/modules/ddt/edit.php index 8f0e76f2c..ba12cc6c4 100755 --- a/modules/ddt/edit.php +++ b/modules/ddt/edit.php @@ -439,7 +439,11 @@
- +'; +$module_anagrafica_id = Modules::get('Anagrafiche')['id']; + +echo ' +{( "name": "filelist_and_upload", "id_module": "'.$module_anagrafica_id.'", "id_record": "'.$record['idanagrafica'].'", "readonly": "1", "title": "Allegati anagrafica")} {( "name": "filelist_and_upload", "id_module": "$id_module$", "id_record": "$id_record$" )} @@ -656,4 +660,4 @@ function salvaArticolo() { $("#idreferente").selectReset(); }); -'; \ No newline at end of file +'; diff --git a/modules/fatture/custom/edit.php b/modules/fatture/custom/edit.php new file mode 100644 index 000000000..9f28736cf --- /dev/null +++ b/modules/fatture/custom/edit.php @@ -0,0 +1,1139 @@ +. + */ + +use Carbon\Carbon; +use Modules\Anagrafiche\Anagrafica; +use Modules\Anagrafiche\Nazione; +use Modules\Fatture\Fattura; +use Modules\Fatture\Gestori\Bollo; +use Modules\Interventi\Intervento; +use Modules\Iva\Aliquota; +use Plugins\ExportFE\Interaction; + +include_once __DIR__.'/../../../core.php'; + +$anagrafica_azienda = Anagrafica::find(setting('Azienda predefinita')); + +$block_edit = !empty($note_accredito) || in_array($record['stato'], ['Emessa', 'Pagato', 'Parzialmente pagato']) || !$abilita_genera; + +if ($dir == 'entrata') { + $conto = 'vendite'; +} else { + $conto = 'acquisti'; +} + +// Informazioni sulla dichiarazione d'intento, visibili solo finchè la fattura è in bozza +if ($dir == 'entrata' && !empty($fattura->dichiarazione) ) { + $diff = $fattura->dichiarazione->massimale - $fattura->dichiarazione->totale; + $diff_in_days = Carbon::parse($fattura->dichiarazione->data_fine)->diffAsCarbonInterval($fattura->data); + + $id_iva = setting("Iva per lettere d'intento"); + $iva = Aliquota::find($id_iva); + + if (!empty($iva)) { + + if ($diff == 0) { + echo ' +
+ '.tr("La dichiarazione d'intento _PROTOCOLLO_ ha raggiunto il massimale previsto di _MONEY_.", [ + '_MONEY_' => moneyFormat(abs($fattura->dichiarazione->massimale)), + '_PROTOCOLLO_' => $fattura->dichiarazione->numero_protocollo, + ]).'. +
'; + } elseif ($diff < 0) { + echo ' +
+ '.tr("La dichiarazione d'intento _PROTOCOLLO_ ha superato il massimale previsto di _MONEY_.", [ + '_MONEY_' => moneyFormat(abs($diff)), + '_PROTOCOLLO_' => $fattura->dichiarazione->numero_protocollo, + ]).'. +
'; + } + elseif ($diff_in_days < 0) { + echo ' +
+ '.tr("La dichiarazione d'intento _PROTOCOLLO_ ha come data fine validità _SCADENZA_ mentre la fattura ha data _DATA_", [ + '_SCADENZA_' => dateFormat($fattura->dichiarazione->data_fine), + '_DATA_' => dateFormat($fattura->data), + '_PROTOCOLLO_' => $fattura->dichiarazione->numero_protocollo, + ]).'. +
'; + } + + } else { + //TODO link ad impostazioni con nuova ricerca rapida + echo ' +
+ '.tr("Attenzione nessuna aliq. IVA definita per la dichiarazione d'intento. _SETTING_", [ + '_SETTING_' => Modules::link('Impostazioni', null, tr('Selezionala dalle impostazioni'), true, null, true, null, "&search=Iva per lettere d'intento"), + ]).' +
'; + } +} + +// Autofattura +if (!empty($fattura_acquisto_originale)) { + echo ' +
+ '.tr("Questa è un'autofattura generata da una fattura di acquisto").': + '.Modules::link('Fatture di acquisto', $fattura_acquisto_originale->id, tr('Fattura num. _NUM_ del _DATE_', [ + '_NUM_' => $fattura_acquisto_originale->numero_esterno, + '_DATE_' => dateFormat($fattura_acquisto_originale->data), + ])).' +
'; +} + +if ($abilita_autofattura) { + echo ' +
+ '.tr("Per questa fattura è prevista la generazione di un'autofattura tramite Crea » Autofattura").'. +
'; +} elseif ($fattura->id_autofattura != null) { + echo ' +
+ '.tr("È presente un'autofattura collegata").': + '.Modules::link('Fatture di vendita', $fattura->id_autofattura, tr('Fattura num. _NUM_ del _DATE_', [ + '_NUM_' => $autofattura_vendita->numero_esterno, + '_DATE_' => dateFormat($autofattura_vendita->data), + ])).' +
'; +} elseif ($autofattura_collegata != null) { + echo ' +
+ '.tr("Questa autofattura è già stata importata come fattura di acquisto").': + '.Modules::link('Fatture di acquisto', $autofattura_collegata->id, tr('Fattura num. _NUM_ del _DATE_', [ + '_NUM_' => $autofattura_collegata->numero_esterno, + '_DATE_' => dateFormat($autofattura_collegata->data), + ])).' +
'; +} + +// Note di credito collegate +if (!empty($note_accredito)) { + echo ' +
'.tr('Note di credito collegate').':'; + foreach ($note_accredito as $nota) { + $text = tr('Rif. fattura _NUM_ del _DATE_', [ + '_NUM_' => $nota['numero'], + '_DATE_' => Translator::dateToLocale($nota['data']), + ]); + + echo ' +
'.Modules::link( ($dir == 'entrata' ? 'Fatture di vendita' : 'Fatture di acquisto' ), $nota['id'], $text, $text); + } + echo ' +
'; +} + +// Fattura originale della Nota di credito +if (!empty($fattura->ref_documento) && $fattura->isNota()) { + $nota = Fattura::find($fattura->ref_documento); + echo ' +
+ '.tr("Questa è una _TIPO_ generata dalla seguente fattura", [ + '_TIPO_' => $fattura->tipo->descrizione, + ]).': + '.Modules::link($module->name, $fattura->ref_documento, tr('Fattura num. _NUM_ del _DATE_', [ + '_NUM_' => $nota->numero_esterno, + '_DATE_' => dateFormat($nota->data), + ])).' +
'; +} + +// Ricordo che si sta emettendo una fattura conto terzi +if ($dir == 'entrata' && $fattura->stato->descrizione == 'Bozza' ) { + if ($fattura->is_fattura_conto_terzi){ + + echo ' +
+ '.tr("Questa è una fattura per conto di terzi. Nell'XML della Fattura Elettronica sarà indicato il fornitore _FORNITORE_ come cessionario e il cliente come cedente/prestatore", ['_FORNITORE_' => '"'.stripslashes($database->fetchOne('SELECT ragione_sociale FROM an_anagrafiche WHERE idanagrafica = '.prepare(setting('Azienda predefinita')))['ragione_sociale']).'"',]).'. +
'; + + } +} +// Verifica aggiuntive sulla sequenzialità dei numeri +if ($dir == 'entrata') { + $numero_previsto = verifica_numero_fattura($fattura); + if (!empty($numero_previsto)) { + echo ' +
+ '.tr("E' assente una fattura di vendita di numero _NUM_ in data precedente o corrispondente a _DATE_: si potrebbero verificare dei problemi con la numerazione corrente delle fatture", [ + '_DATE_' => dateFormat($fattura->data), + '_NUM_' => '"'.$numero_previsto.'"', + ]).'. +
'; + } + + // Verifica la data dell'intervento rispetto alla data della fattura + $fatturazione_futura = false; + $data_fattura = new Carbon($fattura->data); + $interventi_collegati = $fattura->getDocumentiCollegati()[Intervento::class]; + if (!empty($interventi_collegati)) { + foreach ($interventi_collegati as $intervento) { + $fine_intervento = $intervento->fine ?: $intervento->data_richiesta; + $fine_intervento = new Carbon($fine_intervento); + + if ($fine_intervento->diffInDays($data_fattura, false) < 0) { + $fatturazione_futura = true; + break; + } + } + + if ($fatturazione_futura) { + echo ' +
+ '.tr("Stai fatturando un'attività futura rispetto alla data di fatturazione.").' +
'; + } + } +} +?> +
+ + + + + +
+
+

+
+ +
+ + fetchArray('SELECT piva, codice_fiscale, citta, indirizzo, cap, id_nazione, tipo FROM an_anagrafiche WHERE idanagrafica='.prepare($record['idanagrafica'])); + $campi_mancanti = []; + + //di default è un azienda e chiedo la partita iva + if (empty($rs2[0]['piva']) and empty($rs2[0]['codice_fiscale']) and (empty($rs2[0]['tipo']) or $rs2[0]['tipo'] == 'Azienda')) { + array_push($campi_mancanti, 'Partita IVA'); + array_push($campi_mancanti, 'Codice fiscale'); + } + + $nazione = Nazione::find($rs2[0]['id_nazione']); + //se è un privato o un ente pubblico controllo il codice fiscale + if ((($rs2[0]['tipo'] == 'Privato' && $nazione->iso2 == 'IT') or $rs2[0]['tipo'] == 'Ente pubblico') and empty($rs2[0]['codice_fiscale'])) { + array_push($campi_mancanti, 'Codice fiscale'); + } + + if ($rs2[0]['citta'] == '') { + array_push($campi_mancanti, 'Città'); + } + if ($rs2[0]['indirizzo'] == '') { + array_push($campi_mancanti, 'Indirizzo'); + } + if ($rs2[0]['cap'] == '') { + array_push($campi_mancanti, 'C.A.P.'); + } + if (empty($rs2[0]['id_nazione'])) { + array_push($campi_mancanti, 'Nazione'); + } + + if (sizeof($campi_mancanti) > 0) { + echo "
Prima di procedere alla stampa completa i seguenti campi dell'anagrafica Cliente: ".implode(', ', $campi_mancanti).'
+ '.Modules::link('Anagrafiche', $record['idanagrafica'], tr('Vai alla scheda anagrafica'), null).'
'; + } + } + ?> + +
+ + {[ "type": "text", "label": "'.tr('Numero fattura/protocollo').'", "required": 1, "name": "numero","class": "text-center alphanumeric-mask", "value": "$numero$" ]} +
'; + $label = tr('N. fattura del fornitore'); + $size = 2; + } else { + $label = tr('Numero fattura'); + $size = 4; + } + ?> + + + {[ "type": "hidden", "label": "Segmento", "name": "id_segment", "class": "text-center", "value": "$id_segment$" ]} + +
+ {[ "type": "text", "label": "", "required": "", "name": "numero_esterno", "class": "text-center", "value": "$numero_esterno$", "help": "" ]} +
+ +
+ {[ "type": "date", "label": "", "name": "data", "required": 1, "value": "$data$" ]} +
+ +fetchArray("SELECT id FROM zz_plugins WHERE name='Fatturazione Elettronica' AND idmodule_to = ".prepare($id_module)); + echo ''; +} +// Forzo il passaggio della fattura da Bozza ad Emessa per il corretto calcolo del numero. +elseif ($record['stato'] == 'Bozza') { + $query .= " WHERE descrizione IN ('Emessa', 'Bozza')"; +} + +?> + + +
> + {[ "type": "date", "label": "", "name": "data_registrazione", "value": "$data_registrazione$", "help": "" ]} +
+ + +
> + {[ "type": "date", "class":"data_competenza) <= dateFormat($fattura->data)) ? 'unblockable' : ''; ?>", "label": "", "name": "data_competenza", "required": 1, "value": "$data_competenza$", "min-date": "$data$", "help": "" ]} +
+ + + +
> + {[ "type": "select", "label": "", "name": "codice_stato_fe", "values": "query=SELECT codice as id, CONCAT_WS(' - ',codice,descrizione) as text FROM fe_stati_documento", "value": "$codice_stato_fe$", "disabled": , "class": "unblockable", "help": "" ]} +
+ + + + {[ "type": "select", "label": "'.tr('Stato').'", "name": "idstatodocumento", "required": 1, "values": "query='.$query.'", "value": "$idstatodocumento$", "class": "'.(($record['stato'] != 'Bozza' && !$abilita_genera) ? '' : 'unblockable').'", "extra": "onchange=\"return cambiaStato()\"" ]} +
+
+ +
+
+ '.Modules::link('Anagrafiche', $record['idanagrafica'], null, null, 'class="pull-right"'); + + if ($dir == 'entrata') { + ?> + {[ "type": "select", "label": "", "name": "idanagrafica", "required": 1, "ajax-source": "clienti", "help": "fetchOne('SELECT ragione_sociale FROM an_anagrafiche WHERE idanagrafica = '.prepare(setting('Azienda predefinita')))['ragione_sociale']); ?>", "value": "$idanagrafica$" ]} + + {[ "type": "select", "label": "", "name": "idanagrafica", "required": 1, "ajax-source": "fornitori", "value": "$idanagrafica$" ]} + '; + + if ($dir == 'entrata') { + echo ' +
'; + if ($record['idagente'] != 0) { + echo Modules::link('Anagrafiche', $record['idagente_fattura'], null, null, 'class="pull-right"'); + } +echo ' + {[ "type": "select", "label": "'.tr('Agente di riferimento').'", "name": "idagente", "ajax-source": "agenti", "select-options": {"idanagrafica": '.$record['idanagrafica'].'}, "value": "$idagente_fattura$" ]} +
'; + } + + echo ' +
'; + if (!empty($record['idreferente'])) { + echo Plugins::link('Referenti', $record['idanagrafica'], null, null, 'class="pull-right"'); + } + echo ' + {[ "type": "select", "label": "'.tr('Referente').'", "name": "idreferente", "value": "$idreferente$", "ajax-source": "referenti", "select-options": {"idanagrafica": '.$record['idanagrafica'].'}, "icon-after": "add|'.Modules::get('Anagrafiche')['id'].'|id_plugin='.Plugins::get('Referenti')['id'].'&id_parent='.$record['idanagrafica'].'||'.(intval($block_edit) ? 'disabled' : '').'" ]} +
'; + + echo ' +
+
'; + // Conteggio numero articoli fatture + $articolo = $dbo->fetchArray('SELECT mg_articoli.id FROM ((mg_articoli INNER JOIN co_righe_documenti ON mg_articoli.id=co_righe_documenti.idarticolo) INNER JOIN co_documenti ON co_documenti.id=co_righe_documenti.iddocumento) WHERE co_documenti.id='.prepare($id_record)); + $id_modulo_anagrafiche = Modules::get('Anagrafiche')['id']; + $id_plugin_sedi = Plugins::get('Sedi')['id']; + if ($dir == 'entrata') { + echo ' +
+ {[ "type": "select", "label": "'.tr('Partenza merce').'", "name": "idsede_partenza", "ajax-source": "sedi_azienda", "value": "$idsede_partenza$", "help": "'.tr("Sedi di partenza dell'azienda").'" ]} +
+ +
+ {[ "type": "select", "label": "'.tr('Destinazione merce').'", "name": "idsede_destinazione", "ajax-source": "sedi", "select-options": {"idanagrafica": '.$record['idanagrafica'].'}, "value": "$idsede_destinazione$", "help": "'.tr('Sedi del destinatario').'", "icon-after": "add|'.$id_modulo_anagrafiche.'|id_plugin='.$id_plugin_sedi.'&id_parent='.$record['idanagrafica'].'||'.(intval($block_edit) ? 'disabled' : '').'" ]} +
'; + } else { + echo ' +
+ {[ "type": "select", "label": "'.tr('Partenza merce').'", "name": "idsede_partenza", "ajax-source": "sedi", "select-options": {"idanagrafica": '.$record['idanagrafica'].'}, "value": "$idsede_partenza$", "help": "'.tr('Sedi del mittente').'", "icon-after": "add|'.$id_modulo_anagrafiche.'|id_plugin='.$id_plugin_sedi.'&id_parent='.$record['idanagrafica'].'||'.(intval($block_edit) ? 'disabled' : '').'" ]} +
+ +
+ {[ "type": "select", "label": "'.tr('Destinazione merce').'", "name": "idsede_destinazione", "ajax-source": "sedi_azienda", "value": "$idsede_destinazione$", "help": "'.tr("Sedi di arrivo dell'azienda").'" ]} +
'; + } + ?> +
+
+ + +
+
+ + + {[ "type": "select", "label": "", "name": "idtipodocumento", "required": 1, "values": "query=SELECT id, CONCAT_WS(\" - \",codice_tipo_documento_fe, descrizione) AS descrizione FROM co_tipidocumento WHERE dir='' AND (reversed = 0 OR id = ) ORDER BY codice_tipo_documento_fe", "value": "$idtipodocumento$", "readonly": , "help": "fetchOne('SELECT tipo FROM an_anagrafiche WHERE idanagrafica = '.prepare($record['idanagrafica']))['tipo'] == 'Ente pubblico') ? 'FPA12 - fattura verso PA (Ente pubblico)' : 'FPR12 - fattura verso soggetti privati (Azienda o Privato)'; ?>" ]} +
+ +
+ + + {[ "type": "select", "label": "", "name": "idpagamento", "required": 1, "ajax-source": "pagamenti", "value": "$idpagamento$", "extra": "onchange=\"if($(this).selectData()) {$('#id_banca_azienda').selectSetNew( $(this).selectData().id_banca_, $(this).selectData().descrizione_banca_ ).change();} \" " ]} +
+ +
+ {[ "type": "select", "label": "", "name": "id_banca_azienda", "ajax-source": "banche", "select-options": $anagrafica_azienda->id]); ?>, "value": "$id_banca_azienda$", "icon-after": "add||id_anagrafica=id; ?>", "extra": " " ]} +
+ + scadenze; + + $ricalcola = true; + foreach ($scadenze as $scadenza) { + $ricalcola = empty(floatval($scadenza->pagato)) && $ricalcola; + } + + echo ' +
+

'.tr('Scadenze').'

+ +
+ '.Modules::link('Scadenzario', $scadenze[0]['id'], tr(''), '', 'class="btn btn-xs btn-primary"'); + + // Ricalcola scadenze disponibile solo per fatture di acquisto + if ($fattura->isFE() && $ricalcola && $module['name'] == 'Fatture di acquisto') { + echo ' + '; + } + echo ' +
+
'; + + foreach ($scadenze as $scadenza) { + $pagamento_iniziato = !empty(floatval($scadenza->pagato)) || $scadenza->da_pagare == 0; + + echo ' +

'.dateFormat($scadenza['scadenza']).': '; + + if ($pagamento_iniziato) { + echo ' + '; + } + + echo(empty($scadenza->da_pagare) ? '' : '').moneyFormat($scadenza->da_pagare); + + if ($pagamento_iniziato) { + echo ' + '; + } + + if ($pagamento_iniziato && $scadenza->pagato != $scadenza->da_pagare) { + echo ' ('.moneyFormat($scadenza->da_pagare - $scadenza->pagato).')'; + } + + echo ' +

'; + } + + echo ' +
'; + } + ?> +
+ + +
+ +
+ {[ "type": "checkbox", "label": "", "name": "split_payment", "value": "$split_payment$", "help": "", "placeholder": "" ]} +
+ + +
+ {[ "type": "checkbox", "label": "", "name": "is_fattura_conto_terzi", "value": "$is_fattura_conto_terzi$", "help": "fetchOne('SELECT ragione_sociale FROM an_anagrafiche WHERE idanagrafica = '.prepare(setting('Azienda predefinita')))['ragione_sociale']).') come cessionario e il cliente come cedente/prestatore.'); ?>", "placeholder": "" ]} +
+ + + {[ "type": "number", "label": "'.tr('Sconto in fattura').'", "name": "sconto_finale", "value": "'.($fattura->sconto_finale_percentuale ?: $fattura->sconto_finale).'", "icon-after": "choice|untprc|'.(empty($fattura->sconto_finale) ? 'PRC' : 'UNT').'", "help": "'.tr('Sconto in fattura, utilizzabile per applicare sconti sul Netto a pagare del documento e le relative scadenze').'. '.tr('Per utilizzarlo in relazione a una riga della Fattura Elettronica, inserire il tipo di dato in \'\'Attributi avanzati\'\' -> \'\'Altri Dati Gestionali\'\' -> \'\'TipoDato\'\' e il testo di descrizione in \'\'Attributi avanzati\'\' -> \'\'Altri Dati Gestionali\'\' -> \'\'RiferimentoTesto\'\' della specifica riga').'. '.tr('Nota: lo sconto in fattura non influenza i movimenti contabili').'." ]} +
'; + + } + ?> +
+ +
+
+ + {[ "type": "select", "label": "", "name": "id_ritenuta_contributi", "value": "$id_ritenuta_contributi$", "values": "query=SELECT *, CONCAT(descrizione,(IF(percentuale>0, CONCAT(\" - \", percentuale, \"% sul \", percentuale_imponibile, \"% imponibile\"), \"\"))) AS descrizione FROM co_ritenuta_contributi", "help": "" ]} +
+ + + {[ "type": "checkbox", "label": "'.tr('Ritenuta pagata dal fornitore').'", "name": "is_ritenuta_pagata", "value": "$is_ritenuta_pagata$" ]} +
'; + } + if ($dir == 'entrata') { + echo ' +
'; + + if (!empty($record['id_dichiarazione_intento'])) { + echo Plugins::link("Dichiarazioni d'Intento", $record['idanagrafica'], null, null, 'class="pull-right"'); + } + + echo ' + {[ "type": "select", "label": "'.tr("Dichiarazione d'intento").'", "name": "id_dichiarazione_intento", "help": "'.tr('Elenco delle dichiarazioni d\'intento definite all\'interno dell\'anagrafica del cliente').'.", "ajax-source": "dichiarazioni_intento", "select-options": {"idanagrafica": '.$record['idanagrafica'].', "data": "'.$record['data'].'"},"value": "$id_dichiarazione_intento$", "icon-after": "add|'.Modules::get('Anagrafiche')['id'].'|id_plugin='.Plugins::get('Dichiarazioni d\'Intento')['id'].'&id_parent='.$record['idanagrafica'].'", "extra": "'.((intval($block_edit)) ? 'disabled' : '').'" ]} +
'; + } + echo ' + '; + + if ($dir == 'entrata') { + echo ' +
+
+ {[ "type": "checkbox", "label": "'.tr('Marca da bollo automatica').'", "name": "bollo_automatico", "value": "'.intval(!isset($record['bollo'])).'", "help": "'.tr("Seleziona per impostare automaticamente l'importo della marca da bollo").'. '.tr('Applicata solo se il totale della fattura è maggiore di _MONEY_', [ + '_MONEY_' => moneyFormat(setting("Soglia minima per l'applicazione della marca da bollo")), + ]).'.", "placeholder": "'.tr('Bollo automatico').'" ]} +
+ +
+ {[ "type": "checkbox", "label": "'.tr('Addebita marca da bollo').'", "name": "addebita_bollo", "value": "$addebita_bollo$" ]} +
+ +
+ {[ "type": "number", "label": "'.tr('Importo marca da bollo').'", "name": "bollo", "value": "$bollo$"]} +
+
'; + + $bollo = new Bollo($fattura); + } +?> +
+
+ {[ "type": "textarea", "label": "", "name": "note", "help": "", "value": "$note$", "charcounter": 1 ]} +
+
+ +
+
+ {[ "type": "textarea", "label": "", "name": "note_aggiuntive", "help": "", "value": "$note_aggiuntive$", "class": "unblockable" ]} +
+
+ + + + +
+

'.tr('Dati Fattura accompagnatoria').'

+
+ +
+
+
+ {[ "type": "select", "label": "'.tr('Aspetto beni').'", "name": "idaspettobeni", "placeholder": "", "ajax-source": "aspetto-beni", "value": "$idaspettobeni$", "icon-after": "add|'.Modules::get('Aspetto beni')['id'].'||'.(($record['stato'] != 'Bozza') ? 'disabled' : '').'" ]} +
+ +
+ {[ "type": "select", "label": "'.tr('Causale trasporto').'", "name": "idcausalet", "placeholder": "", "ajax-source": "causali", "value": "$idcausalet$", "icon-after": "add|'.Modules::get('Causali')['id'].'||'.(($record['stato'] != 'Bozza') ? 'disabled' : '').'" ]} +
+ +
+ {[ "type": "select", "label": "'.tr('Porto').'", "name": "idporto", "placeholder": "", "values": "query=SELECT id, descrizione FROM dt_porto ORDER BY descrizione ASC", "value": "$idporto$" ]} +
+ +
+ {[ "type": "text", "label": "'.tr('Num. colli').'", "name": "n_colli", "value": "$n_colli$" ]} +
+
+ +
+
+ {[ "type": "select", "label": "'.tr('Tipo di spedizione').'", "name": "idspedizione", "values": "query=SELECT id, descrizione, esterno FROM dt_spedizione ORDER BY descrizione ASC", "value": "$idspedizione$" ]} +
+ +
'; + if (!empty($record['idvettore'])) { + echo Modules::link('Anagrafiche', $record['idvettore'], null, null, 'class="pull-right"'); + } + $esterno = $dbo->selectOne('dt_spedizione', 'esterno', [ + 'id' => $record['idspedizione'], + ])['esterno']; +?> + + {[ "type": "select", "label": "", "name": "idvettore", "ajax-source": "vettori", "value": "$idvettore$", "disabled": , "required": , "icon-after": "add||tipoanagrafica=Vettore&readonly_tipo=1|btn_idvettore|", "class": "" ]} +
+ + + 'EXW', + 'text' => 'EXW', + ], + [ + 'id' => 'FCA', + 'text' => 'FCA', + ], + [ + 'id' => 'FAS', + 'text' => 'FAS', + ], + [ + 'id' => 'FOB', + 'text' => 'FOB', + ], + [ + 'id' => 'CFR', + 'text' => 'CFR', + ], + [ + 'id' => 'CIF', + 'text' => 'CIF', + ], + [ + 'id' => 'CPT', + 'text' => 'CPT', + ], + [ + 'id' => 'CIP', + 'text' => 'CIP', + ], + [ + 'id' => 'DAF', + 'text' => 'DAF', + ], + [ + 'id' => 'DES', + 'text' => 'DES', + ], + [ + 'id' => 'DEQ', + 'text' => 'DEQ', + ], + [ + 'id' => 'DDU', + 'text' => 'DDU', + ], + [ + 'id' => 'DDP', + 'text' => 'DDP', + ], + ]; + + echo ' +
+ {[ "type": "select", "label": "'.tr('Tipo Resa').'", "name": "tipo_resa", "value": "$tipo_resa$", "values": '.json_encode($tipo_resa).', "readonly": '.intval($record['causale_desc'] != 'Reso').' ]} +
+
+
'; + + echo ' +
+
+ {[ "type": "number", "label": "'.tr('Peso').'", "name": "peso", "value": "$peso$", "readonly": "'.intval(empty($record['peso_manuale'])).'", "help": "'.tr('Il valore del campo Peso viene calcolato in automatico sulla base degli articoli inseriti nel documento, a meno dell\'impostazione di un valore manuale in questo punto').'" ]} + +
+ +
+ {[ "type": "checkbox", "label": "'.tr('Modifica peso').'", "name": "peso_manuale", "value":"$peso_manuale$", "help": "'.tr('Seleziona per modificare manualmente il campo Peso').'", "placeholder": "'.tr('Modifica peso').'" ]} +
+ +
+ {[ "type": "number", "label": "'.tr('Volume').'", "name": "volume", "value": "$volume$", "readonly": "'.intval(empty($record['volume_manuale'])).'", "help": "'.tr('Il valore del campo Volume viene calcolato in automatico sulla base degli articoli inseriti nel documento, a meno dell\'impostazione di un valore manuale in questo punto').'" ]} + +
+ +
+ {[ "type": "checkbox", "label": "'.tr('Modifica volume').'", "name": "volume_manuale", "value":"$volume_manuale$", "help": "'.tr('Seleziona per modificare manualmente il campo Volume').'", "placeholder": "'.tr('Modifica volume').'" ]} +
+
+ '; +} + +echo ' +
'; + +//Dich. intento collegata +if ($dir == 'entrata' && !empty($fattura->dichiarazione)){ + + $ive_accettate = $dbo->table('co_iva')->where('codice_natura_fe','N3.5')->get(); + foreach($ive_accettate as $iva_accettata){ + $descrizione_iva_accettata .= '
  • '.$iva_accettata->descrizione.'
  • '; + } + + if ($fattura->stato->descrizione == 'Bozza'){ + + echo ' +
    + '.tr("La fattura è collegata ad una dichiarazione d'intento con diponibilità residura pari a _MONEY_.", [ '_MONEY_' => moneyFormat($diff),]).'
    '.tr("Per collegare una riga alla dichiarazione è sufficiente specificare come IVA ", ['_IVA_' => $descrizione_iva_accettata]).' +
    '; + + } + +} + +echo ' + +
    +
    +

    '.tr('Righe').'

    +
    + +
    +
    +
    +
    '; + +if (!$block_edit) { + if (empty($record['ref_documento'])) { + if ($dir == 'entrata') { + // Lettura interventi non rifiutati, non fatturati e non collegati a preventivi o contratti + $int_query = 'SELECT COUNT(*) AS tot FROM in_interventi INNER JOIN in_statiintervento ON in_interventi.idstatointervento=in_statiintervento.idstatointervento WHERE idanagrafica='.prepare($record['idanagrafica']).' AND in_statiintervento.is_completato=1 AND in_statiintervento.is_fatturabile=1 AND in_interventi.id NOT IN (SELECT idintervento FROM co_righe_documenti WHERE idintervento IS NOT NULL) AND in_interventi.id_preventivo IS NULL AND in_interventi.id NOT IN (SELECT idintervento FROM co_promemoria WHERE idintervento IS NOT NULL)'; + $interventi = $dbo->fetchArray($int_query)[0]['tot']; + + // Se non trovo niente provo a vedere se ce ne sono per clienti terzi + if (empty($interventi)) { + // Lettura interventi non rifiutati, non fatturati e non collegati a preventivi o contratti (clienti terzi) + $int_query = 'SELECT COUNT(*) AS tot FROM in_interventi INNER JOIN in_statiintervento ON in_interventi.idstatointervento=in_statiintervento.idstatointervento WHERE idclientefinale='.prepare($record['idanagrafica']).' AND in_statiintervento.is_completato=1 AND in_statiintervento.is_fatturabile=1 AND in_interventi.id NOT IN (SELECT idintervento FROM co_righe_documenti WHERE idintervento IS NOT NULL) AND in_interventi.id_preventivo IS NULL AND in_interventi.id NOT IN (SELECT idintervento FROM co_promemoria WHERE idintervento IS NOT NULL)'; + $interventi = $dbo->fetchArray($int_query)[0]['tot']; + } + + echo ' + '; + + // Lettura preventivi accettati, in attesa di conferma o in lavorazione + $prev_query = 'SELECT COUNT(*) AS tot FROM co_preventivi WHERE idanagrafica='.prepare($record['idanagrafica']).' AND idstato IN(SELECT id FROM co_statipreventivi WHERE is_fatturabile = 1) AND default_revision=1 AND co_preventivi.id IN (SELECT idpreventivo FROM co_righe_preventivi WHERE co_righe_preventivi.idpreventivo = co_preventivi.id AND (qta - qta_evasa) > 0)'; + $preventivi = $dbo->fetchArray($prev_query)[0]['tot']; + echo ' + '; + + // Lettura contratti accettati, in attesa di conferma o in lavorazione + $contr_query = 'SELECT COUNT(*) AS tot FROM co_contratti WHERE idanagrafica='.prepare($record['idanagrafica']).' AND idstato IN( SELECT id FROM co_staticontratti WHERE is_fatturabile = 1) AND co_contratti.id IN (SELECT idcontratto FROM co_righe_contratti WHERE co_righe_contratti.idcontratto = co_contratti.id AND (qta - qta_evasa) > 0)'; + $contratti = $dbo->fetchArray($contr_query)[0]['tot']; + echo ' + '; + } + + // Lettura ddt (entrata o uscita) + $ddt_query = 'SELECT COUNT(*) AS tot FROM dt_ddt + LEFT JOIN `dt_causalet` ON `dt_causalet`.`id` = `dt_ddt`.`idcausalet` + LEFT JOIN `dt_statiddt` ON `dt_statiddt`.`id` = `dt_ddt`.`idstatoddt` + LEFT JOIN `dt_tipiddt` ON `dt_tipiddt`.`id` = `dt_ddt`.`idtipoddt` + WHERE idanagrafica='.prepare($record['idanagrafica']).' + AND `dt_statiddt`.`descrizione` IN (\'Evaso\', \'Parzialmente evaso\', \'Parzialmente fatturato\') + AND `dt_tipiddt`.`dir` = '.prepare($dir).' + AND `dt_causalet`.`is_importabile` = 1 + AND dt_ddt.id IN (SELECT idddt FROM dt_righe_ddt WHERE dt_righe_ddt.idddt = dt_ddt.id AND (qta - qta_evasa) > 0)'; + $ddt = $dbo->fetchArray($ddt_query)[0]['tot']; + echo ' + '; + + // Lettura ordini (cliente o fornitore) + $ordini_query = 'SELECT COUNT(*) AS tot FROM or_ordini WHERE idanagrafica='.prepare($record['idanagrafica']).' AND idstatoordine IN (SELECT id FROM or_statiordine WHERE descrizione IN(\'Accettato\', \'Evaso\', \'Parzialmente evaso\', \'Parzialmente fatturato\')) AND idtipoordine=(SELECT id FROM or_tipiordine WHERE dir='.prepare($dir).') AND or_ordini.id IN (SELECT idordine FROM or_righe_ordini WHERE or_righe_ordini.idordine = or_ordini.id AND (qta - qta_evasa) > 0)'; + $ordini = $dbo->fetchArray($ordini_query)[0]['tot']; + echo ' + '; + } + + // Lettura articoli + $art_query = 'SELECT COUNT(*) AS tot FROM mg_articoli WHERE attivo = 1 AND id IN(SELECT id_articolo FROM mg_articoli_distinte) AND deleted_at IS NULL'; + if ($dir == 'entrata' && !setting('Permetti selezione articoli con quantità minore o uguale a zero in Documenti di Vendita')) { + $art_query .= ' AND (qta > 0 OR servizio = 1)'; + } else { + //Gli articoli possono essere creati al volo direttamente dal modale di aggiunta articolo + $art_query .= ' OR 1=1'; + } + + $articoli = $dbo->fetchNum($art_query); + echo ' + '; + + echo ' + '; + + echo ' + '; + + echo ' + '; + + echo ' + '; +} +?> +
    + +
    + + 0) { + //echo '{( "name": "button", "type": "print", "id_module": "'.$id_module.'", "id_record": "'.$id_record.'", "class": "btn-info disabled" )}'; + } else { + //echo '{( "name": "button", "type": "print", "id_module": "'.$id_module.'", "id_record": "'.$id_record.'" )}'; + } +} +?> +
    +
    +
    +
    +
    + +
    +
    +
    +
    +
    + +isFE()) { + echo ' +
    + +'; +} + +$module_anagrafica_id = Modules::get('Anagrafiche')['id']; + +?> + +{( "name": "filelist_and_upload", "id_module": "", "id_record": "", "readonly": "1", "title": "Allegati anagrafica")} + + +{( "name": "filelist_and_upload", "id_module": "$id_module$", "id_record": "$id_record$", "abilita_genera": "" )} + +'.tr('Per allegare un documento alla fattura elettronica caricare il file PDF specificando come categoria "Allegati Fattura Elettronica"').'.'; +} + +echo ' +'; + +?> + +{( "name": "log_email", "id_module": "$id_module$", "id_record": "$id_record$" )} + +sedi)) { + $disabilita_eliminazione = in_array($fattura->codice_stato_fe, ['RC', 'MC', 'EC01']); + + echo ' + + '.tr('Elimina').' + '; +} + +echo ' +'; diff --git a/modules/ordini/edit.php b/modules/ordini/edit.php index c194976f5..6732d1415 100755 --- a/modules/ordini/edit.php +++ b/modules/ordini/edit.php @@ -304,7 +304,12 @@
    - +'; + +$module_anagrafica_id = Modules::get('Anagrafiche')['id']; + +echo ' +{( "name": "filelist_and_upload", "id_module": "'.$module_anagrafica_id.'", "id_record": "'.$record['idanagrafica'].'", "readonly": "1", "title": "Allegati anagrafica")} {( "name": "filelist_and_upload", "id_module": "$id_module$", "id_record": "$id_record$" )} diff --git a/modules/preventivi/edit.php b/modules/preventivi/edit.php index 145e2bded..24c63c07e 100755 --- a/modules/preventivi/edit.php +++ b/modules/preventivi/edit.php @@ -310,7 +310,12 @@
    - +'; + +$module_anagrafica_id = Modules::get('Anagrafiche')['id']; + +echo ' +{( "name": "filelist_and_upload", "id_module": "'.$module_anagrafica_id.'", "id_record": "'.$record['idanagrafica'].'", "readonly": "1", "title": "Allegati anagrafica")} {( "name": "filelist_and_upload", "id_module": "$id_module$", "id_record": "$id_record$" )} @@ -532,4 +537,4 @@ function salvaArticolo() { $("#idreferente").selectReset(); }); - \ No newline at end of file + diff --git a/src/HTMLBuilder/Manager/FileManager.php b/src/HTMLBuilder/Manager/FileManager.php index 699b9d0ca..9ff4ef562 100755 --- a/src/HTMLBuilder/Manager/FileManager.php +++ b/src/HTMLBuilder/Manager/FileManager.php @@ -66,9 +66,18 @@ public function manage($options) if (!empty($options['showpanel'])) { $result .= ' -
    -
    -

    '.tr('Allegati').'

    +
    +
    '; + + if (!empty($options['title'])) { + $result .= ' +

    '.$options['title'].'

    '; + } else { + $result .= ' +

    '.tr('Allegati').'

    '; + } + + $result .= '
    '; }