dei files in caso non esistano. git-svn-id: svn://10.65.10.50/trunk@3581 c028cbd2-c16b-5b4b-a496-9718f37d4682
252 lines
6.5 KiB
C++
Executable File
252 lines
6.5 KiB
C++
Executable File
#include <confapp.h>
|
|
#include <isam.h>
|
|
#include <tabutil.h>
|
|
#include <prefix.h>
|
|
#include <attiv.h>
|
|
#include <extcdecl.h>
|
|
#include <utility.h>
|
|
#include <modaut.h>
|
|
#include "cg5100a.h"
|
|
|
|
class TParametri_ditta : public TConfig_application
|
|
{
|
|
// bool _change_pcon;
|
|
// TString16 _val;
|
|
TArray _atts;
|
|
|
|
void swap_file(int logicnum, bool tocom);
|
|
void load_file(int logicnum);
|
|
void check_registers(int year);
|
|
|
|
public:
|
|
virtual bool preprocess_config (TMask& mask, TConfig& config);
|
|
virtual bool postprocess_config (TMask& mask, TConfig& config);
|
|
virtual bool postprocess_config_changed(const char* par, const char* var,
|
|
const char* oldv, const char* newv);
|
|
|
|
virtual bool user_create();
|
|
TParametri_ditta() : TConfig_application(CONFIG_DITTA) {}
|
|
virtual ~TParametri_ditta() {}
|
|
};
|
|
|
|
bool TParametri_ditta::user_create()
|
|
{
|
|
// _change_pcon = FALSE;
|
|
|
|
TLocalisamfile attiv(LF_ATTIV);
|
|
attiv.zero();
|
|
|
|
attiv.put(ATT_CODDITTA, get_firm());
|
|
TRectype r(attiv.curr());
|
|
|
|
for(attiv.read(_isgteq); attiv.status() == NOERR && attiv.curr() == r;
|
|
attiv.next())
|
|
// istanzia array _atts on le attivita' della ditta corrente
|
|
_atts.add(new TString(attiv.get(ATT_CODATT)));
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
void TParametri_ditta::check_registers(int year)
|
|
{
|
|
// controlla che per ogni data attivita' esistano almeno un registro
|
|
// acquisti, vendite e giornale; warning appropriato in caso negativo
|
|
TTable reg("REG");
|
|
TRecfield reg_year(reg.curr(), "CODTAB", 0,3);
|
|
|
|
const byte R_ACQ = 0x01;
|
|
const byte R_VEN = 0x02;
|
|
const byte R_ALL = R_ACQ | R_VEN;
|
|
|
|
bool is_giornale = FALSE;
|
|
|
|
byte flags = 0x00;
|
|
|
|
for (int i = 0; i < _atts.items(); i++)
|
|
{
|
|
TString& att = (TString&)_atts[i];
|
|
for (reg.first(); !reg.eof(); reg.next())
|
|
{
|
|
if (atoi(reg_year) == year && reg.get_int("I0") == 5)
|
|
{
|
|
is_giornale = TRUE;
|
|
continue;
|
|
}
|
|
if (atoi(reg_year) != year || att != reg.get("S8"))
|
|
continue;
|
|
|
|
switch (reg.get_int("I0"))
|
|
{
|
|
case 1: // vendite
|
|
flags |= R_VEN; break;
|
|
case 2: // acquisti
|
|
flags |= R_ACQ; break;
|
|
default:
|
|
break;
|
|
}
|
|
if (flags == R_ALL && is_giornale) break;
|
|
}
|
|
if (flags < R_ALL)
|
|
{
|
|
TString wrn("I seguenti registri non esistono per l'attivita' ");
|
|
wrn << att << "(" << year << "):";
|
|
if ((flags & R_VEN) == 0x00) wrn << "\n\tregistro vendite";
|
|
if ((flags & R_ACQ) == 0x00) wrn << "\n\tregistro acquisti";
|
|
warning_box(wrn);
|
|
}
|
|
}
|
|
|
|
// libro giornale non si controlla per attivita'
|
|
if(!is_giornale)
|
|
warning_box("Non esiste probabilmente nessun "
|
|
"libro giornale per l'anno %d", year);
|
|
}
|
|
|
|
|
|
|
|
void TParametri_ditta::swap_file(int logicnum, bool tocom)
|
|
{
|
|
TDir dir;
|
|
TString file(16);
|
|
|
|
dir.get(logicnum, _lock, _nordir, _sysdirop);
|
|
file = dir.name();
|
|
file[0] = tocom ? '%' : '$';
|
|
dir.set(file, dir.eod(), dir.flags(), dir.des(), dir.expr());
|
|
dir.put(logicnum, _nordir, _sysdirop);
|
|
dir.get(logicnum, _lock, (tocom ? _comdir :_nordir), _sysdirop);
|
|
if (tocom)
|
|
{
|
|
file = dir.name();
|
|
file[0] = '%';
|
|
dir.set(file, dir.eod(), dir.flags(), dir.des(), dir.expr());
|
|
dir.put(logicnum, _comdir, _sysdirop);
|
|
}
|
|
else
|
|
dir.get(logicnum, _unlock, (tocom ? _comdir :_nordir), _sysdirop);
|
|
|
|
if (dir.eox() == 0L || !fexist(dir.filename()))
|
|
{
|
|
set_autoload_new_files(FALSE);
|
|
TSystemisamfile s(logicnum);
|
|
s.build(10L);
|
|
set_autoload_new_files(TRUE);
|
|
}
|
|
}
|
|
|
|
void TParametri_ditta::load_file(int logicnum)
|
|
{
|
|
TDir dir;
|
|
|
|
dir.get(logicnum);
|
|
|
|
TSystemisamfile f(logicnum);
|
|
TFilename lf;
|
|
|
|
if (dir.eox() == 0L)
|
|
f.build(10L);
|
|
lf.format("%sstd/lf%04d.txt", __ptprf, logicnum);
|
|
if (fexist(lf))
|
|
f.load(lf, '|', '\0', '\n', TRUE, TRUE);
|
|
}
|
|
|
|
|
|
bool TParametri_ditta::preprocess_config (TMask& mask, TConfig& config)
|
|
{
|
|
// these are disabled in normal applications
|
|
TLocalisamfile mov(LF_MOV);
|
|
const bool movempty = mov.empty();
|
|
mask.enable(CHK_ANCFCM, movempty);
|
|
mask.enable(CHK_PCTCCM, movempty);
|
|
if (mask.get(FLD_ANLIIV).empty())
|
|
mask.set(FLD_ANLIIV, TDate(TODAY).year());
|
|
|
|
// check auth for Saldaconto
|
|
if (!has_module(SCAUT, CHK_DONGLE))
|
|
// disable saldaconting
|
|
mask.disable(-GROUP_SALDACONTO);
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
bool TParametri_ditta::postprocess_config(TMask& mask, TConfig& config)
|
|
{
|
|
check_registers(mask.get_int(FLD_ANLIIV));
|
|
mask.field(FLD_ANLIIV).set_dirty(mask.get_int(FLD_ANLIIV) != config.get_int("AnLiIv"));
|
|
if (mask.get_bool(CHK_GELIDI))
|
|
{
|
|
TLocalisamfile ditte(LF_NDITTE);
|
|
const long ditta = get_firm();
|
|
ditte.put("CODDITTA", ditta);
|
|
ditte.read();
|
|
if (ditte.get("DINIZIOATT").empty())
|
|
error_box("La gestione della liquidazione differita richiede "
|
|
"la data di inizio attivita' sull'anagrafica della ditta.");
|
|
|
|
char freqiva = ditte.get_char("FREQVIVA");
|
|
|
|
TString16 key; key.format("%05ld%d", ditta, mask.get_int(FLD_ANLIIV));
|
|
TTable lia("%LIA");
|
|
lia.put("CODTAB", key);
|
|
if (lia.read() == NOERR)
|
|
freqiva = lia.get_char("S7");
|
|
|
|
if (freqiva != 'M')
|
|
error_box("La gestione della liquidazione differita richiede "
|
|
"la frequenza dei versamenti IVA mensile.");
|
|
}
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
bool TParametri_ditta::postprocess_config_changed(const char* par, const char* var,
|
|
const char* oldv, const char* newv)
|
|
{
|
|
TString v(var);
|
|
|
|
if (v == "AnCfCm")
|
|
{
|
|
if (yesno_box("Confermi il cambiamento dell'anagrafica clienti/fornitori"))
|
|
{
|
|
swap_file(LF_CLIFO, *newv == 'X');
|
|
swap_file(LF_INDSP, *newv == 'X');
|
|
}
|
|
else
|
|
return FALSE;
|
|
}
|
|
else if (v == "PcTcCm")
|
|
{
|
|
if (yesno_box("Confermi il cambiamento del piano conti/causali"))
|
|
{
|
|
// _change_pcon = TRUE;
|
|
// _val = newv;
|
|
swap_file(LF_PCON, *newv == 'X');
|
|
swap_file(LF_CAUSALI, *newv == 'X');
|
|
swap_file(LF_RCAUSALI, *newv == 'X');
|
|
prefix().reopen();
|
|
if (*newv == 'X')
|
|
{
|
|
TDir d;
|
|
d.get(LF_PCON, _nolock, _comdir);
|
|
if (d.eod() == 0 && yesno_box("Vuoi caricare gli archivi standard ?"))
|
|
{
|
|
load_file(LF_PCON);
|
|
load_file(LF_CAUSALI);
|
|
load_file(LF_RCAUSALI);
|
|
}
|
|
}
|
|
}
|
|
else
|
|
return FALSE;
|
|
}
|
|
return TRUE;
|
|
}
|
|
|
|
int cg5100 (int argc, char* argv[])
|
|
{
|
|
TParametri_ditta appc;
|
|
appc.run(argc, argv, "Parametri Ditta");
|
|
return 0;
|
|
}
|