Modulo Scadenzario
Gestione scadenze di pagamento — Rate, Incassi, Interessi moratori
Riferimenti normativi
- Art. 2214 Codice Civile — Obbligo di registrazione dei pagamenti: l'imprenditore commerciale e tenuto alla registrazione di tutte le operazioni di incasso e pagamento nelle scritture contabili obbligatorie. Lo scadenzario costituisce un registro ausiliario che supporta la corretta tenuta del libro giornale, tracciando le scadenze e i relativi movimenti finanziari.
- Art. 21 DPR 633/72 — Condizioni di pagamento in fattura: la fattura deve contenere, tra gli elementi obbligatori, le condizioni di pagamento concordate con il cessionario/committente. Il modulo Scadenzario genera automaticamente il piano rate a partire da queste condizioni, garantendo coerenza tra il documento fiscale e lo scadenziario finanziario.
- D.Lgs. 231/2002 — Ritardi di pagamento nelle transazioni commerciali: recepisce la Direttiva 2000/35/CE e disciplina gli interessi moratori dovuti in caso di ritardo nei pagamenti. Il tasso di mora e pari al tasso BCE maggiorato di 8 punti percentuali. Il modulo calcola automaticamente gli interessi moratori sulle scadenze non rispettate.
Note operative e permessi configurabili
🗒️ Pannello Note: ogni scheda di scadenza di pagamento o incasso ha un pannello "post-it"
giallo floating ancorato all'entità corrente. Si apre minimizzato come fascia
centrata sulla topbar (sulla barra blu del modale per i documenti); cliccando
la fascia o la freccia expand_more si espande al centro del viewport
(ridimensionabile via handle in basso a destra). La fascia minimizzata è trascinabile
e la sua posizione viene memorizzata in localStorage per ciascun record (es. ogni
documento ha la sua posizione independente). Per scrivere una nota: testo nel box giallino
+ bottone + Aggiungi (o Cmd/Ctrl + Invio). Modifica/elimina riservate
all'autore o agli amministratori. Cestino note con ripristino disponibile
dal toggle delete_outline nell'header del pannello espanso (solo ADMIN/SUPERADMIN).
Tutti i CRUD (create/update/delete/restore) sono tracciati in audit_log
(consultabile da Amministrazione Sistema → Audit Log).
🔒 Permessi configurabili: alcune azioni di questa scheda (creazione, modifica, cancellazione, esportazione, stampa) possono essere bloccate per il ruolo del tuo workspace. Quando un bottone è bloccato, appare con icona "lucchetto" e tooltip "Permesso disabilitato dal Super Amministratore". La configurazione si fa in Amministrazione di Sistema » Permessi per Ruolo (solo SUPERADMIN).
Il modulo Scadenzario gestisce il ciclo di vita delle scadenze di pagamento generate dai documenti fiscali (fatture di vendita e acquisto). Le scadenze vengono create automaticamente in base alle condizioni di pagamento associate al documento e al soggetto.
Ogni scadenza (rata) possiede una data di scadenza, un importo e uno stato che evolve nel tempo: Aperta, Pagata o Scaduta. Il sistema aggiorna lo stato automaticamente confrontando la data di scadenza con la data corrente.
All'interno di ogni documento fiscale (fattura, nota di credito) e presente la tab Scadenzario che mostra il piano rate generato automaticamente.
| Colonna | Descrizione |
|---|---|
| N. rata | Numero progressivo della rata |
| Data scadenza | Data entro cui il pagamento deve essere effettuato |
| Importo | Importo della singola rata in euro |
| Tipo pagamento | Modalita di pagamento (bonifico, RiBa, contanti, ecc.) |
| Stato | Aperta, Pagata o Scaduta |
| Data pagamento | Data effettiva dell'incasso/pagamento (compilata alla registrazione) |
🔄 Rigenerazione automatica al cambio condizioni
Le scadenze si rigenerano automaticamente in due momenti:
- Al cambio delle condizioni di pagamento (debounced 300ms)
- Dopo ogni salvataggio del documento (cambi righe/totale → rate aggiornate, debounced 400ms)
Salvaguardia: la rigenerazione automatica non parte se ci sono rate già PAGATA, per non perdere il pagato. In quel caso interviene il banner di disallineamento descritto sotto, che ti permette di scegliere consapevolmente come procedere.
⚠ Banner disallineamento con 3 azioni
Aprendo la sezione Scadenze di un documento, se il totale rate non corrisponde al totale documento appare un banner ambrato in cima alla sezione con:
- Totale documento, totale rate, differenza, eventuali spese escluse
- Avviso esplicito se ci sono rate già PAGATA (richiede attenzione)
Tre pulsanti per scegliere come risolvere:
- 🔄 Rigenera tutto (rosso) — elimina tutte le rate e ricalcola sul totale documento corrente. Se ci sono rate PAGATA chiede conferma esplicita prima di procedere.
- 🗛 Rata di pareggio (X €) (blu) — aggiunge una nuova rata della differenza, lasciando intatte le rate esistenti. Chiede solo la data scadenza (default oggi+30gg).
- ❌ Ignora (grigio) — chiude il banner senza modifiche.
La scelta giusta dipende dal contesto: se il pagato registrato è corretto e bisogna addebitare la differenza al cliente → Rata di pareggio. Se il documento è stato modificato dopo l'incasso e il pagato va riazzerato → Rigenera tutto.
Le condizioni di pagamento determinano come l'importo del documento viene suddiviso in rate. Si configurano in Impostazioni → Condizioni di pagamento.
- Accedere a Impostazioni → Condizioni di pagamento e premere + Nuova condizione.
- Inserire un codice e una descrizione (es. “30/60 DFFM”).
- Selezionare il tipo pagamento predefinito (bonifico, RiBa, cambiale, contanti, ecc.).
- Definire le righe rate: per ciascuna rata specificare i giorni dalla data documento (o da fine mese), la percentuale dell'importo totale e il tipo pagamento specifico se diverso dal predefinito.
- Salvare la condizione. Sara selezionabile nei documenti e nelle schede soggetto.
| Parametro | Esempio | Descrizione |
|---|---|---|
| Giorni | 30 | Numero di giorni dalla data documento o da fine mese |
| Fine mese | Si | Se attivo, il conteggio parte dalla fine del mese del documento (DFFM) |
| % Importo | 50% | Percentuale dell'importo totale documento assegnata alla rata |
| Tipo pagamento | Bonifico | Modalita di pagamento per la singola rata |
La vista principale del modulo presenta l'elenco di tutte le scadenze con filtri avanzati per una gestione efficace.
- Accedere al menu Contabilita → Scadenzario per visualizzare la lista completa delle scadenze.
- Utilizzare i filtri per stato: Aperta, Pagata, Scaduta oppure Tutte.
- Filtrare per periodo: selezionare un intervallo di date scadenza (da/a).
- Filtrare per soggetto: cercare per nome, ragione sociale o codice fiscale.
- Fare clic su una scadenza per aprire il dettaglio e accedere alle azioni di registrazione pagamento.
| Stato | Colore | Significato |
|---|---|---|
| Aperta | Blu | Scadenza non ancora giunta a termine e non ancora pagata |
| Scaduta | Rosso | Data scadenza superata senza pagamento registrato |
| Pagata | Verde | Pagamento registrato (totale o parziale con saldo a zero) |
💰 Importi in formato italiano (1.234,00)
Tutti gli importi nello scadenzario — sia nelle righe sia nei totali — sono visualizzati ed editati in formato italiano: punto come separatore di migliaia e virgola come separatore decimale. Es. 2.886,15 € invece di 2886.15 €.
Anche i campi editabili (importo rata in modifica inline) sono in formato italiano: alla scrittura il parser riconosce «1.234,56», «1234,56» e «1234.56». Al blur viene riformattato.
La registrazione del pagamento aggiorna lo stato della scadenza e alimenta la situazione finanziaria del soggetto.
Pagamento totale
- Dalla lista scadenze o dalla tab Scadenzario del documento, selezionare la rata da incassare.
- Premere il pulsante Registra pagamento.
- Verificare l'importo (precompilato con il saldo residuo) e la data di pagamento.
- Confermare. Lo stato della rata passa a Pagata.
Pagamento parziale
- Nella finestra di registrazione, modificare l'importo inserendo un valore inferiore al saldo residuo.
- Confermare il pagamento parziale. Il sistema registra l'acconto e aggiorna il saldo residuo della rata.
- La rata resta in stato Aperta (o Scaduta) fino al saldo completo.
Ogni riga nella lista scadenze mostra i seguenti pulsanti nella colonna Azioni:
| Pulsante | Icona | Azione | Quando visibile |
|---|---|---|---|
| Modifica | edit | Apre la riga in modalità editing per modificare importo, data, note | Sempre |
| Segna pagata | ✓ | Imposta lo stato a PAGATA con data pagamento odierna | Se non già pagata |
| Incasso parziale | payments | Registra un pagamento parziale (acconto) | Se non già pagata |
| Sollecito email | forward_to_inbox | Invia email di sollecito al soggetto | Se stato SCADUTA |
| Annulla pagamento | ↩ | Riporta lo stato da PAGATA a ATTESA | Se stato PAGATA |
| Elimina | delete_outline | Elimina definitivamente la scadenza (con conferma) | Sempre |
La dashboard principale di NOX Enterprise Suite include la stat card Scadenze aperte che fornisce una visione immediata della situazione finanziaria.
| Indicatore | Descrizione |
|---|---|
| Totale scadenze aperte | Somma degli importi di tutte le scadenze con stato Aperta |
| Scadenze in scadenza (7 gg) | Rate in scadenza nei prossimi 7 giorni |
| Scadenze scadute | Numero e importo totale delle rate oltre la data di scadenza |
Ai sensi del D.Lgs. 231/2002, in caso di ritardo nel pagamento di transazioni commerciali tra imprese (o tra imprese e PA), il creditore ha diritto agli interessi moratori calcolati automaticamente dal sistema.
| Parametro | Valore |
|---|---|
| Tasso di riferimento | Tasso BCE (aggiornato semestralmente) |
| Maggiorazione | +8 punti percentuali |
| Decorrenza | Dal giorno successivo alla scadenza del termine di pagamento |
| Importo forfettario di recupero | 40 € per ogni fattura pagata in ritardo (art. 6 D.Lgs. 231/2002) |
Il sistema calcola gli interessi moratori sulle scadenze con stato Scaduta e li rende disponibili per l'eventuale addebito al debitore tramite nota di debito.
Lo scadenzario supporta la selezione multipla per l'invio massivo di solleciti di pagamento.
- Utilizzare le checkbox a sinistra di ogni riga per selezionare le scadenze da sollecitare.
- La checkbox nell'header seleziona/deseleziona tutte le scadenze visibili.
- Una barra scura appare in alto con il conteggio e il bottone Invia Solleciti.
- Il sistema invia un'email di sollecito a ogni soggetto che ha un indirizzo email o PEC.
- L'email include: numero documento, importo, data scadenza e una richiesta di pagamento.
- Al termine viene mostrato il riepilogo: N solleciti inviati, N errori.
Sollecito singolo: è anche possibile inviare un sollecito per una singola scadenza tramite il bottone dedicato nella riga.
L'aging report (invecchiamento crediti) classifica le scadenze scadute per fasce temporali. È visibile in due punti:
| Dove | Descrizione |
|---|---|
| Dashboard → Stat card "Aging scaduto" | Card ambra con barre colorate: 0-30gg (giallo), 31-60gg (arancio), 61-90gg (rosso), >90gg (rosso scuro) |
| Dashboard → Sezione "Situazione Finanziaria" | Card dettagliata con aging, scaduto da incassare, incassato nel mese |
L'aging viene calcolato automaticamente dai dati delle scadenze aperte, senza chiamate API aggiuntive.
Lo scadenzario supporta l'incasso parziale: una scadenza può essere saldata gradualmente senza doverla chiudere interamente.
- Nella riga della scadenza, premere il bottone Registra incasso.
- Inserire l'importo parziale ricevuto, la data di pagamento e la modalità di incasso.
- Il sistema aggiorna il campo
importoPagatoe calcola il residuo. - La scadenza resta in stato ATTESA fino al saldo completo.
- Quando l'importo pagato raggiunge l'importo totale, la scadenza passa a PAGATA.
I dati dello scadenzario alimentano la sezione Situazione Finanziaria nella dashboard principale:
| Card | Contenuto |
|---|---|
| Fatture scadute (rossa) | Numero e importo totale delle scadenze oltre la data |
| Incassi del mese (verde) | Importo totale incassato nel mese corrente |
| Crediti in scadenza | Numero totale di scadenze aperte |
| Scaduto da incassare | Importo residuo delle scadenze scadute |
| Aging dettagliato | Breakdown per fasce 0-30gg / 31-60gg / 61-90gg / >90gg |
Le scadenze possono essere esportate tramite Impostazioni → Import / Export → Scadenzario.
- Selezionare il modulo Scadenzario.
- Premere Configura Campi per selezionare i campi da esportare (data scadenza, importo, soggetto, stato, numero documento, ecc.).
- I campi vengono caricati dal database con tutti i campi disponibili.
- Esportare in CSV o Excel.
Aggiornamento strutturale del modulo Scadenzario con tracciamento modifiche, cestino compliance-safe e operazioni massive. Il design rispetta le implicazioni contabili: le scadenze pagate non possono essere cancellate per non falsificare il registro incassi.
Soft-delete limitato alle scadenze ATTESA
L'eliminazione di una scadenza segue regole differenti in base allo stato:
- ATTESA: eliminazione = soft-delete (la scadenza va nel cestino, e ripristinabile).
- SCADUTA / PAGATA / ANNULLATA: eliminazione non consentita (errore 409). Per una scadenza gia pagata e necessario prima stornare il pagamento (riportandola ad ATTESA).
Questa distinzione protegge il registro incassi da cancellazioni improprie.
Cestino + ripristino
Un nuovo pulsante 🗑 Cestino nell'header della pagina apre la vista delle scadenze cancellate. Per ogni riga sono disponibili:
- ↺ Ripristina: la scadenza torna nella lista attiva.
- ✗ Definitivo: eliminazione fisica irreversibile (solo se la scadenza e gia cancellata e in stato ATTESA).
Audit log delle modifiche
Ogni modifica a una scadenza (importo, date, stato, modalita incasso, riferimento, note) viene registrata nella tabella log_modifiche_scadenze con valore precedente, valore nuovo, utente e timestamp. Accesso via GET /api/scadenzario/:id/audit-log.
Questo risponde alla domanda piu frequente: “chi ha marcato questa fattura come pagata e quando?” L'audit cattura anche i cambi di stato via bulk (marca-pagata massiva, proroga), con una entry per ogni scadenza modificata.
Timeline scadenza
L'endpoint GET /api/scadenzario/:id/timeline restituisce la cronologia completa delle modifiche in ordine decrescente.
Operazioni massive
La barra azioni che compare con la selezione multipla include ora:
- 💰 Marca pagate: imposta stato PAGATA con data di pagamento comune, modalita e riferimento per tutte le scadenze selezionate. La data comune e un default: ogni scadenza e poi modificabile singolarmente via editing inline senza perdere l'impostazione di gruppo. L'audit registra il cambio su ciascuna.
- 🔁 Proroga…: sposta la
dataScadenzadi N giorni (anche negativi) su tutte le scadenze selezionate. Utile per concordare un piano di rientro con il cliente o spostare una scadenza vicina a una festivita. - 📧 Solleciti: invariato, invia email automatiche (solo per scadenze SCADUTA).
- 🗑 Cestino: sposta nel cestino solo le scadenze in stato ATTESA; le altre vengono ignorate e riportate come bloccate nella risposta.
Matrice transizioni di stato (validate dal bulk)
| Da | Verso (consentite) |
|---|---|
| ATTESA | SCADUTA, PAGATA, ANNULLATA |
| SCADUTA | PAGATA, ATTESA, ANNULLATA |
| PAGATA | ANNULLATA |
| ANNULLATA | ATTESA |
Esempio operativo: chiudo 40 fatture di Natale
- Filtrare la lista per Stato=ATTESA e periodo dicembre.
- Spuntare Seleziona tutte in testata.
- Premere 💰 Marca pagate.
- Inserire data di pagamento 31/12/2025, modalita BONIFICO, riferimento “Saldo anno 2025”.
- Il sistema aggiorna le 40 scadenze in una sola operazione e registra 40 entry di audit.
- Se alcune sono state pagate in date diverse, aprirle singolarmente e modificare la
dataPagamento— la modifica viene registrata nell'audit.
• Pacchetto
FATTURAZIONE attivo sul workspace (configurabile da SUPERADMIN in /admin/pacchetti)
• Profilo attività compatibile: Tutti i profili
• Permesso utente abilitato in Modifica Utente → Moduli
I tre livelli si applicano in intersezione. Dettagli completi in Gerarchia Pacchetti+Profilo+Utente.
A partire dalla versione 2.2, il modulo Scadenzario adotta lo standard di certificazione NOX con i seguenti presidi:
Cestino e soft-delete
Gli elementi cancellati non vengono rimossi fisicamente ma spostati in un cestino interno (campi cancellatoIl / cancellatoDa). Dalla toolbar il pulsante Cestino alterna tra vista attivi e vista cestino. Dal cestino è possibile:
- Ripristinare l'elemento (riportarlo nella lista attiva) — operazione riservata ad amministratori.
- Eliminare definitivamente con motivazione obbligatoria — azione irreversibile, riservata ad amministratori, tracciata nell'audit log.
Azioni massive (bulk)
È possibile selezionare più elementi con le checkbox della prima colonna. Appare una barra inferiore con le azioni disponibili: Imposta data pagamento massiva (mantiene possibilità di modifica singola). La risposta indica N operazioni riuscite / M fallite; i dettagli delle fallite compaiono nella console browser (F12).
Guard periodo IVA chiuso (v 2.2)
Se il documento di origine della scadenza appartiene a un periodo IVA chiuso (registri IVA), la modifica della scadenza viene bloccata con HTTP 409. Per modificarla è necessario:
- riaprire il periodo IVA (solo admin + motivazione);
- oppure creare una nuova scadenza nel periodo corrente (consigliato).
Storico modifiche (audit log)
L'icona history nelle azioni di riga apre un modal con la storia completa delle modifiche: data, campo, valore precedente, valore nuovo, operatore, eventuale motivazione. I record di audit non sono modificabili né eliminabili via UI. Conservazione: indefinita (art. 2220 c.c. — 10 anni minimo).
Mascheramento dati sensibili (GDPR art. 32)
Se i campi modificati contengono dati sensibili (IBAN, Codice Fiscale, Partita IVA, password/token), l'audit log salva il valore mascherato anziché in chiaro:
| Campo | Esempio originale | Nel log |
|---|---|---|
| IBAN | IT60X0542811101000000123456 | IT60****3456 |
| Codice Fiscale (PF) | RSSMRA80A01H501Z | RSSMRA****501Z |
| Partita IVA | 12345678901 | 123****901 |
| Password / token | (qualsiasi) | ***REDACTED*** |
Timeline aggregata
Per ciascun elemento è disponibile una vista Timeline che aggrega in ordine cronologico audit, eventi del ciclo di vita ed eventuali entità collegate (es. documenti, movimenti, storni).
RBAC uniforme
Tutte le azioni distruttive o massive (soft-delete, ripristino, eliminazione definitiva, bulk, storno) richiedono il ruolo ADMIN o superiore. Gli operatori possono continuare a creare / modificare / consultare secondo le proprie abilitazioni.
Scadenze multi-rata acconto/saldo (v 2.2, aprile 2026)
Feature #5 del pacchetto FATTURAZIONE v 2.2: permette di definire per ogni documento un piano di pagamento articolato in acconto + rate intermedie + saldo finale. Due nuovi campi su documento_scadenze:
tipoRata(VARCHAR 20) — valori ammessi:ACCONTO,RATA,SALDO. DefaultRATAordineRata(INT) — ordine di successione (1, 2, 3...). Default 1
Endpoint dedicato:
POST /api/fatturazione/scadenze-multi-rata/:docId
Body: { rate: [ { tipoRata, percentuale, giorni, descrizione }, ... ] }
Ogni elemento rate contiene:
- tipoRata: ACCONTO / RATA / SALDO
- percentuale: quota sul totale documento (la somma di tutte le rate deve essere esattamente
100; se diversa, HTTP 400) - giorni: scadenza calcolata da
dataDocumento + N giorni - descrizione: nota libera (opzionale)
Esempio pratico — acconto 30% alla consegna + saldo 70% a 60gg:
[
{ "tipoRata": "ACCONTO", "percentuale": 30, "giorni": 0, "descrizione": "Acconto alla consegna" },
{ "tipoRata": "SALDO", "percentuale": 70, "giorni": 60, "descrizione": "Saldo a 60gg DF" }
]
L'endpoint azzera le scadenze esistenti e ricrea il piano dalla data documento. Le nuove scadenze partono tutte in stato ATTESA e sono gestibili dalle normali funzioni di scadenzario (incasso, solleciti, cancellazione).
Solleciti automatici + interessi legali (v 2.2 wave 7, aprile 2026)
Il sistema gestisce 4 livelli di sollecito con template personalizzabili: 1° cortese (+7 gg), 2° (+30 gg), 3° ultimo avviso (+60 gg), 4° diffida ex art. 1454 c.c. (+90 gg). A ogni livello può essere associato il calcolo automatico degli interessi legali al tasso BCE vigente (2026: 5%, aggiornato annualmente con decreto MEF).
Sostituzioni di variabili nel template
Oggetto e corpo supportano le seguenti variabili che vengono sostituite al momento dell'invio:
| Variabile | Contenuto |
|---|---|
{NUMERO} | Numero documento |
{ANNO} | Anno della data documento |
{DATA_DOC} | Data emissione (formato italiano) |
{DATA_SCAD} | Data scadenza rata |
{IMPORTO} | Importo residuo non pagato |
{INTERESSI} | Interessi legali calcolati sui giorni di ritardo |
{SOGGETTO} | Ragione sociale o nome + cognome |
{GIORNI_RITARDO} | Giorni di ritardo al momento dell'invio |
Formula interessi legali
interessi = (importoScaduto × aliquotaBCE × giorniRitardo) / (365 × 100)
Se il template ha calcolaInteressiLegali=false, viene stampato € 0,00. Override aliquota su base per-template (campo aliquotaInteressi).
Tabelle e endpoint
- Tabelle:
template_sollecito(4 livelli seed) +solleciti_documento(log invii) GET /api/fatturazione/solleciti/templates— elenco template attiviPUT /api/fatturazione/solleciti/templates/:id[ADMIN] — modifica oggetto/corpo/giorni/aliquotaPOST /api/fatturazione/solleciti/invia/:docIdbody{livello, scadenzaId?, destinatarioOverride?}— genera sollecito, sostituisce variabili, registra log; sescadenzaIdnon passato, usa la prima scadenza in stato ATTESAGET /api/fatturazione/solleciti/log/:docId— storico solleciti inviati al documentoGET /api/fatturazione/solleciti/scaduti?giorni=N— cruscotto operativo di tutte le scadenze pendenti oltre N giorni con livello ultimo sollecito e dati soggetto
Invio SMTP reale solleciti (v 2.2 wave 8, aprile 2026)
Sostituisce la modalità log-only della wave 7 con invio effettivo via nodemailer. La configurazione SMTP è letta dalla tabella parametri (campi smtpHost, smtpPort, smtpUser, smtpPass, smtpSecure, smtpFrom) e deve essere testata (smtpTestato = true) prima dell'uso effettivo (bandiera di sicurezza).
Endpoint
POST /api/fatturazione/solleciti-smtp/invia/:docIdbody{livello, scadenzaId?, destinatarioOverride?, allegaPdf?}— invio singolo. Ritorna{ok, esito, destinatario, importoScaduto, interessi, messageId}.POST /api/fatturazione/solleciti-smtp/invia-bulk[ADMIN] body{livello=1, giorniRitardoMinimo=7, limiteInvii=50}— invio massivo a tutte le scadenze candidate. Esclude automaticamente i destinatari già sollecitati al livello ≥ N.
Tracciamento doppio
Ogni invio SMTP riuscito/fallito viene loggato in due tabelle:
solleciti_documento— log dettagliato del sollecito con livello, corpo, interessi, destinatario, esitolog_invio_email_documento— log generale email (eventoAUTO_SOLLECITO) per riepilogo storico
smtpTestato è falso, l'endpoint restituisce errore "SMTP non configurato o non testato". È richiesto che l'ADMIN abbia eseguito prima POST /api/smtp/test verificando che le credenziali funzionino. Questa è una misura di sicurezza per evitare l'invio di email con credenziali non valide e possibile blocco dell'account mittente.Le scadenze ora supportano incassi multipli. Se un cliente paga solo una parte (es. 40% subito, 30% a 30gg, 30% a 60gg), puoi registrare ogni incasso separatamente e la scadenza tiene traccia del residuo.
Quando registri un incasso, il dialog mostra:
- Il residuo corrente a fianco del label «Importo Incassato»
- Quick-button: «Tutto residuo» / «Metà» / «1/3»
- Banner ambra «Pagamento parziale: dopo questo incasso resteranno X €. La scadenza passerà a stato PARZIALE» se l'importo è minore del residuo
Stati possibili della scadenza:
- ATTESA: nessun pagamento
- PARZIALE: incassi parziali registrati (campo
importoPagato<importototale) - PAGATA: completamente saldata
- SCADUTA: oltre la
dataScadenzae non pagata
Spese banca / bolli su tratta — Modalità di addebito
Quando una Condizione di Pagamento ha attivi i flag «Includi spese bancarie» e/o «Includi bolli su tratta», NOX permette di scegliere come trattare quelle spese tramite il selettore «Modalità di addebito spese» (vedi Manuale Tabelle):
- 🏦 In scadenzario (default) — spese addebitate dalla banca al cliente in fase di incasso (RIBA / SEPA / tratta). Le rate vengono maggiorate dalle spese (es. 100 € rata + 5 € spese banca = 105 €) e nella nota della rata appare «+ spese € X.XX». Non vanno in fattura: non sono ricavi del cedente.
- 📋 In fattura — NOX aggiunge automaticamente al documento le righe «Spese bancarie» e/o «Bolli su tratta» con importo dai Parametri Azienda, aliquota 0%, natura N1 (escluso art. 15 DPR 633/72). Le rate non vengono maggiorate (sennò le spese sarebbero conteggiate due volte) e il totale documento include già le spese.
Validazione «Scadenzario disallineato» (fix 6 Maggio 2026)
Quando si apre un documento in modifica, NOX verifica che la somma degli importi delle rate corrisponda al totale documento. Il messaggio di errore «Scadenzario disallineato: totale scadenze X € ≠ totale documento Y €. Rigenerare le scadenze.» è ora più preciso:
- Le spese banca/bolli per rata (note «+ spese € X.XX») vengono scorporate dalla somma scadenze prima del confronto, evitando falsi allarmi quando la condizione di pagamento ha
includeSpeseBanca/includeSpeseBolliattivi e modalità IN_SCADENZARIO. - Se persiste un disallineamento reale, il messaggio cita esplicitamente l'importo scorporato: «... (escluse € X.XX di spese banca/bolli per rata) ...».
In caso di disallineamento reale, vedi sotto il banner di disallineamento con le 3 azioni dedicate.