Aggiunta possibilità di specificare conto per IVA omaggi
git-svn-id: svn://10.65.10.50/branches/R_10_00@22634 c028cbd2-c16b-5b4b-a496-9718f37d4682
This commit is contained in:
parent
dc50349bd6
commit
6c768a9ec9
@ -1,24 +1,9 @@
|
|||||||
#include <xvt.h>
|
#include <xvt.h>
|
||||||
|
|
||||||
#ifndef __CHECKS_H
|
|
||||||
#include <checks.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef __CONFAPP_H
|
|
||||||
#include <confapp.h>
|
#include <confapp.h>
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef __MSKSHEET_H
|
|
||||||
#include <msksheet.h>
|
#include <msksheet.h>
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef __RELATION_H
|
|
||||||
#include <relation.h>
|
#include <relation.h>
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef __TABUTIL_H
|
|
||||||
#include <tabutil.h>
|
#include <tabutil.h>
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "veconf.h"
|
#include "veconf.h"
|
||||||
|
|
||||||
@ -274,9 +259,7 @@ bool TConf_vendite::user_create( )
|
|||||||
conf.set( "EdMask", "ve0200h", "ve");
|
conf.set( "EdMask", "ve0200h", "ve");
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
fatal_box( SINTASSI );
|
return fatal_box( SINTASSI );
|
||||||
return false;
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -284,7 +267,6 @@ bool TConf_vendite::user_create( )
|
|||||||
int ve0200(int argc, char* argv[])
|
int ve0200(int argc, char* argv[])
|
||||||
{
|
{
|
||||||
TConf_vendite appc;
|
TConf_vendite appc;
|
||||||
|
|
||||||
if( argc < 3 )
|
if( argc < 3 )
|
||||||
fatal_box( SINTASSI );
|
fatal_box( SINTASSI );
|
||||||
appc.run(argc, argv, "Parametri gestione vendite");
|
appc.run(argc, argv, "Parametri gestione vendite");
|
||||||
|
@ -8,7 +8,7 @@ PAGE "Contabilizzazione" 0 0 0 0
|
|||||||
|
|
||||||
GROUPBOX DLG_NULL 78 7
|
GROUPBOX DLG_NULL 78 7
|
||||||
BEGIN
|
BEGIN
|
||||||
PROMPT 1 1 "@bRicerca primaria del conto di costo ricavo"
|
PROMPT 1 1 "@bRicerca primaria del conto di costo ricavo"
|
||||||
END
|
END
|
||||||
|
|
||||||
LIST F_RICERCACR1 2 50
|
LIST F_RICERCACR1 2 50
|
||||||
@ -137,15 +137,14 @@ GROUP 3
|
|||||||
//WARNING "La sequenza di ricerca per anagrafica deve indicare quattro tipi diversi"
|
//WARNING "La sequenza di ricerca per anagrafica deve indicare quattro tipi diversi"
|
||||||
END
|
END
|
||||||
|
|
||||||
BOOLEAN F_SCONTO_LORDO
|
GROUPBOX DLG_NULL 78 4
|
||||||
BEGIN
|
BEGIN
|
||||||
PROMPT 2 14 "Contabilizzazione merci al lordo "
|
PROMPT 1 14 "@bStorno omaggi"
|
||||||
FIELD CONTSCLOR
|
|
||||||
END
|
END
|
||||||
|
|
||||||
STRING F_IVASTORNO 4
|
STRING F_IVASTORNO 4
|
||||||
BEGIN
|
BEGIN
|
||||||
PROMPT 2 15 "Cod. IVA storno art. omaggio "
|
PROMPT 2 15 "Cod. IVA "
|
||||||
FIELD IVASTO
|
FIELD IVASTO
|
||||||
USE %IVA
|
USE %IVA
|
||||||
FLAGS "U"
|
FLAGS "U"
|
||||||
@ -157,9 +156,57 @@ BEGIN
|
|||||||
OUTPUT F_IVASTORNO CODTAB
|
OUTPUT F_IVASTORNO CODTAB
|
||||||
END
|
END
|
||||||
|
|
||||||
|
NUMBER F_OMACODCONG 3
|
||||||
|
BEGIN
|
||||||
|
PROMPT 24 15 "Conto "
|
||||||
|
FIELD OMACODCON(1)
|
||||||
|
USE LF_PCON
|
||||||
|
INPUT GRUPPO F_OMACODCONG
|
||||||
|
INPUT CONTO F_OMACODCONC
|
||||||
|
INPUT SOTTOCONTO F_OMACODCONS
|
||||||
|
DISPLAY "Gruppo" GRUPPO
|
||||||
|
DISPLAY "Conto" CONTO
|
||||||
|
DISPLAY "Sottoconto" SOTTOCONTO
|
||||||
|
DISPLAY "Descrizione@50" DESCR
|
||||||
|
OUTPUT F_OMACODCONG GRUPPO
|
||||||
|
OUTPUT F_OMACODCONC CONTO
|
||||||
|
OUTPUT F_OMACODCONS SOTTOCONTO
|
||||||
|
OUTPUT F_OMACODCOND DESCR
|
||||||
|
CHECKTYPE NORMAL
|
||||||
|
END
|
||||||
|
|
||||||
|
NUMBER F_OMACODCONC 3
|
||||||
|
BEGIN
|
||||||
|
PROMPT 37 15 ""
|
||||||
|
FIELD OMACODCON(2)
|
||||||
|
COPY ALL F_OMACODCONG
|
||||||
|
CHECKTYPE NORMAL
|
||||||
|
END
|
||||||
|
|
||||||
|
NUMBER F_OMACODCONS 6
|
||||||
|
BEGIN
|
||||||
|
PROMPT 44 15 ""
|
||||||
|
FIELD OMACODCON(3)
|
||||||
|
COPY ALL F_OMACODCONG
|
||||||
|
CHECKTYPE NORMAL
|
||||||
|
END
|
||||||
|
|
||||||
|
STRING F_OMACODCOND 50
|
||||||
|
BEGIN
|
||||||
|
PROMPT 24 16 ""
|
||||||
|
USE LF_PCON KEY 2
|
||||||
|
INPUT DESCR F_OMACODCOND
|
||||||
|
DISPLAY "Descrizione@50" DESCR
|
||||||
|
DISPLAY "Gruppo" GRUPPO
|
||||||
|
DISPLAY "Conto" CONTO
|
||||||
|
DISPLAY "Sottoconto" SOTTOCONTO
|
||||||
|
COPY OUTPUT F_OMACODCONG
|
||||||
|
CHECKTYPE NORMAL
|
||||||
|
END
|
||||||
|
|
||||||
LISTBOX F_FLDVALMAT 17
|
LISTBOX F_FLDVALMAT 17
|
||||||
BEGIN
|
BEGIN
|
||||||
PROMPT 2 16 "Campo per i valore dei materiali "
|
PROMPT 2 18 "Campo per i valore dei materiali "
|
||||||
FIELD FldValMat
|
FIELD FldValMat
|
||||||
ITEM "|Nessuno"
|
ITEM "|Nessuno"
|
||||||
ITEM "ULTCOS1|Ultimo Costo"
|
ITEM "ULTCOS1|Ultimo Costo"
|
||||||
@ -187,15 +234,21 @@ BEGIN
|
|||||||
ITEM "USER20|Campo Utente 20"
|
ITEM "USER20|Campo Utente 20"
|
||||||
END
|
END
|
||||||
|
|
||||||
|
BOOLEAN F_SCONTO_LORDO
|
||||||
|
BEGIN
|
||||||
|
PROMPT 2 19 "Contabilizzazione merci al lordo "
|
||||||
|
FIELD CONTSCLOR
|
||||||
|
END
|
||||||
|
|
||||||
BOOLEAN F_CHECKPREVCONT
|
BOOLEAN F_CHECKPREVCONT
|
||||||
BEGIN
|
BEGIN
|
||||||
PROMPT 2 17 "Controlla che i documenti precedenti siano contabilizzati"
|
PROMPT 42 19 "Controllo contabilizzazione documenti precedenti"
|
||||||
FIELD CHECKPREVCONT
|
FIELD CHECKPREVCONT
|
||||||
END
|
END
|
||||||
|
|
||||||
STRING F_CMSCNTFIELD 10
|
STRING F_CMSCNTFIELD 10
|
||||||
BEGIN
|
BEGIN
|
||||||
PROMPT 2 18 "Campo commesse per reperire la causale"
|
PROMPT 2 20 "Campo commesse per reperire la causale"
|
||||||
FLAGS "U"
|
FLAGS "U"
|
||||||
FIELD CMSCNTFIELD
|
FIELD CMSCNTFIELD
|
||||||
END
|
END
|
||||||
|
@ -118,6 +118,10 @@
|
|||||||
#define F_CHECKPREVCONT 112
|
#define F_CHECKPREVCONT 112
|
||||||
#define F_CMSCNTFIELD 113
|
#define F_CMSCNTFIELD 113
|
||||||
#define F_FLDVALMAT 114
|
#define F_FLDVALMAT 114
|
||||||
|
#define F_OMACODCONG 115
|
||||||
|
#define F_OMACODCONC 116
|
||||||
|
#define F_OMACODCONS 117
|
||||||
|
#define F_OMACODCOND 120
|
||||||
|
|
||||||
// Campi per ve0200f.uml
|
// Campi per ve0200f.uml
|
||||||
#define F_IMPSPINC1 101
|
#define F_IMPSPINC1 101
|
||||||
|
@ -139,8 +139,11 @@ int TMovimentoPN_VE::set_cg_rec(int n, const TImporto& imp, const TBill& conto,
|
|||||||
rec.put(RMV_NUMREG,numreg);
|
rec.put(RMV_NUMREG,numreg);
|
||||||
rec.put(RMV_DATAREG,datareg);
|
rec.put(RMV_DATAREG,datareg);
|
||||||
}
|
}
|
||||||
rec.put(RMV_SEZIONE,imp.sezione());
|
|
||||||
rec.put(RMV_IMPORTO,imp.valore());
|
TImporto normimp(imp);
|
||||||
|
normimp.normalize();
|
||||||
|
rec.put(RMV_SEZIONE,normimp.sezione());
|
||||||
|
rec.put(RMV_IMPORTO,normimp.valore());
|
||||||
conto.put(rec);
|
conto.put(rec);
|
||||||
|
|
||||||
rec.put(RMV_DESCR, desc);
|
rec.put(RMV_DESCR, desc);
|
||||||
@ -310,8 +313,7 @@ void TMovimentoPN_VE::add_row_re(int i)
|
|||||||
|
|
||||||
if (conto.ok() && !imponibile.is_zero())
|
if (conto.ok() && !imponibile.is_zero())
|
||||||
{
|
{
|
||||||
const TImporto val(real2imp(imponibile, 'I'));
|
const TImporto val(real2imp(imponibile, 'I'));
|
||||||
|
|
||||||
if (newpos < 0)
|
if (newpos < 0)
|
||||||
set_cg_rec(-1, val, conto, _caus->desc_agg(2), ' ');
|
set_cg_rec(-1, val, conto, _caus->desc_agg(2), ' ');
|
||||||
else
|
else
|
||||||
@ -532,8 +534,9 @@ static TToken_string* _search_seq = NULL;
|
|||||||
// Gli utlimi 6 fanno parte della ricerca per costi ricavi, in particolare AR,GM,SM e RF
|
// Gli utlimi 6 fanno parte della ricerca per costi ricavi, in particolare AR,GM,SM e RF
|
||||||
// non possono essere interrotti da CV o CC. Ad es. CA|CF|AR|CV|GM|CC|RF non e' valida come stringa
|
// non possono essere interrotti da CV o CC. Ad es. CA|CF|AR|CV|GM|CC|RF non e' valida come stringa
|
||||||
// di ricerca.
|
// di ricerca.
|
||||||
static TString16 _ivasto; // Codice IVA per storno articoli Omaggio
|
static TString4 _iva_sto; // Codice IVA per storno articoli Omaggio
|
||||||
static bool _contsclor; // Contabilizza sconti al netto o al lordo (sconti suddiviso per ogni contropartita)
|
static TBill _conto_sto; // Conto per storno articoli Omaggio
|
||||||
|
static bool _contsclor; // Contabilizza sconti al netto o al lordo (sconti suddiviso per ogni contropartita)
|
||||||
//static bool _loaded = false;// Flag per evitare di caricare i parametri più di una volta
|
//static bool _loaded = false;// Flag per evitare di caricare i parametri più di una volta
|
||||||
|
|
||||||
static TCausale *_caus = NULL; // causale del documento corrente
|
static TCausale *_caus = NULL; // causale del documento corrente
|
||||||
@ -549,10 +552,10 @@ protected:
|
|||||||
TObject* dup() const { return new TIVA_array(*this); }
|
TObject* dup() const { return new TIVA_array(*this); }
|
||||||
|
|
||||||
public:
|
public:
|
||||||
error_type add(const TRiga_documento & r, const TBill& conto, const int ndec = ALL_DECIMALS, const real & p = 1.0);
|
error_type add(const TRiga_documento& r, const TBill& conto, const int ndec = ALL_DECIMALS, const real & p = UNO);
|
||||||
error_type add(const TRiga_documento * r, const TBill& conto, const int ndec = ALL_DECIMALS, const real & p = 1.0) { return add(*r, conto, ndec, p);}
|
error_type add(const TRiga_documento* r, const TBill& conto, const int ndec = ALL_DECIMALS, const real & p = UNO) { return add(*r, conto, ndec, p);}
|
||||||
error_type add_omaggi(const TRiga_documento & r, const TBill& conto, const int ndec = ALL_DECIMALS, const real & p = 1.0);
|
error_type add_omaggi(const TRiga_documento& r, const TBill& conto, const int ndec = ALL_DECIMALS, const real & p = UNO);
|
||||||
error_type add_omaggi(const TRiga_documento * r, const TBill& conto, const int ndec = ALL_DECIMALS, const real & p = 1.0) { return add_omaggi(*r, conto, ndec, p);}
|
error_type add_omaggi(const TRiga_documento* r, const TBill& conto, const int ndec = ALL_DECIMALS, const real & p = UNO) { return add_omaggi(*r, conto, ndec, p);}
|
||||||
void set_caus(TCausale * caus) { _caus = caus; }
|
void set_caus(TCausale * caus) { _caus = caus; }
|
||||||
|
|
||||||
TIVA_array() {}
|
TIVA_array() {}
|
||||||
@ -567,19 +570,24 @@ void TIVA_array::copy(const TIVA_array & a)
|
|||||||
_caus = a._caus;
|
_caus = a._caus;
|
||||||
}
|
}
|
||||||
|
|
||||||
error_type TIVA_array::add_omaggi(const TRiga_documento & r, const TBill& conto, const int ndec, const real & p)
|
error_type TIVA_array::add_omaggi(const TRiga_documento& r, const TBill& conto, const int ndec, const real& p)
|
||||||
{
|
{
|
||||||
if (_ivasto.empty())
|
if (_iva_sto.blank())
|
||||||
return ivasto_error;
|
return ivasto_error;
|
||||||
add(r, conto, ndec, p);
|
add(r, conto, ndec, p);
|
||||||
TRiga_documento r_storno(r);
|
TRiga_documento r_storno(r);
|
||||||
|
|
||||||
r_storno.set_tipo("01");
|
r_storno.set_tipo("01");
|
||||||
r_storno.put(RDOC_CODIVA, _ivasto);
|
r_storno.put(RDOC_CODIVA, _iva_sto);
|
||||||
real prezzo = r_storno.get_real(RDOC_PREZZO);
|
real prezzo = r_storno.get_real(RDOC_PREZZO);
|
||||||
prezzo = -prezzo;
|
prezzo = -prezzo;
|
||||||
r_storno.put(RDOC_PREZZO, prezzo);
|
r_storno.put(RDOC_PREZZO, prezzo);
|
||||||
add(r_storno, conto, ndec, p);
|
|
||||||
|
if (_conto_sto.ok())
|
||||||
|
add(r_storno, _conto_sto, ndec, p);
|
||||||
|
else
|
||||||
|
add(r_storno, conto, ndec, p);
|
||||||
|
|
||||||
return no_error;
|
return no_error;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -588,7 +596,7 @@ error_type TIVA_array::add(const TRiga_documento& r, const TBill& conto, const i
|
|||||||
const TTipo_riga_documento & t = r.tipo();
|
const TTipo_riga_documento & t = r.tipo();
|
||||||
TString80 key;
|
TString80 key;
|
||||||
const TCodiceIVA& tiva = r.iva();
|
const TCodiceIVA& tiva = r.iva();
|
||||||
TString16 cod(tiva.codice());
|
const TString4 cod(tiva.codice());
|
||||||
TBill c(conto);
|
TBill c(conto);
|
||||||
int ord = 0;
|
int ord = 0;
|
||||||
int detr = 0;
|
int detr = 0;
|
||||||
@ -877,7 +885,12 @@ bool TContabilizzazione::load_parameters()
|
|||||||
|
|
||||||
_contsclor = conf.get_bool("CONTSCLOR","ve");
|
_contsclor = conf.get_bool("CONTSCLOR","ve");
|
||||||
|
|
||||||
_ivasto = conf.get("IVASTO","ve");
|
_iva_sto = conf.get("IVASTO","ve");
|
||||||
|
|
||||||
|
gr = conf.get_int("OMACODCON","ve",1);
|
||||||
|
co = conf.get_int("OMACODCON","ve",2);
|
||||||
|
so = conf.get_long("OMACODCON","ve",3);
|
||||||
|
_conto_sto.set(gr,co,so);
|
||||||
|
|
||||||
gr = conf.get_int("SPINCODCONA","ve",1);
|
gr = conf.get_int("SPINCODCONA","ve",1);
|
||||||
co = conf.get_int("SPINCODCONA","ve",2);
|
co = conf.get_int("SPINCODCONA","ve",2);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user