193 lines
4.6 KiB
C++
193 lines
4.6 KiB
C++
|
#include <applicat.h>
|
||
|
#include <automask.h>
|
||
|
#include <progind.h>
|
||
|
#include <recarray.h>
|
||
|
#include <relation.h>
|
||
|
#include <reprint.h>
|
||
|
#include <textset.h>
|
||
|
|
||
|
#include "../ca/calib01.h"
|
||
|
#include "../ca/commesse.h"
|
||
|
|
||
|
#include "rilore.h"
|
||
|
#include "cilib.h"
|
||
|
#include "ci1400a.h"
|
||
|
|
||
|
///////////////////////////////////////////////////////////
|
||
|
// Recordset
|
||
|
///////////////////////////////////////////////////////////
|
||
|
class TRil_ore_cms_recordset : public TCSV_recordset
|
||
|
{
|
||
|
public:
|
||
|
TRil_ore_cms_recordset();
|
||
|
};
|
||
|
|
||
|
TRil_ore_cms_recordset::TRil_ore_cms_recordset()
|
||
|
: TCSV_recordset("CSV(\"|\")")
|
||
|
{
|
||
|
}
|
||
|
|
||
|
///////////////////////////////////////////////////////////
|
||
|
// Report
|
||
|
///////////////////////////////////////////////////////////
|
||
|
|
||
|
class TRil_ore_cms_report : public TReport
|
||
|
{
|
||
|
protected:
|
||
|
virtual bool use_mask() { return false; }
|
||
|
|
||
|
public:
|
||
|
TRil_ore_cms_report() { load("ci1400a"); }
|
||
|
};
|
||
|
|
||
|
|
||
|
///////////////////////////////////////////////////////////
|
||
|
// Maschera
|
||
|
///////////////////////////////////////////////////////////
|
||
|
|
||
|
class TRil_ore_cms_mask : public TAutomask
|
||
|
{
|
||
|
protected:
|
||
|
virtual bool on_field_event(TOperable_field& o, TField_event e, long jolly);
|
||
|
|
||
|
void format_report(TReport& rep) const;
|
||
|
/*long calcola_giorni_lavorativi_cms(const TDate& ini_cms, const TDate& fine_cms,
|
||
|
const TDate& dataini, const TDate& datafine,
|
||
|
TDate& inizio_lav, TDate& fine_lav) const;
|
||
|
void elabora_risorsa(const TString& curr_risorsa, TReport& rep) const;*/
|
||
|
|
||
|
public:
|
||
|
void elabora() const;
|
||
|
|
||
|
TRil_ore_cms_mask();
|
||
|
virtual ~TRil_ore_cms_mask() {}
|
||
|
};
|
||
|
|
||
|
TRil_ore_cms_mask::TRil_ore_cms_mask() : TAutomask("ci1400a")
|
||
|
{
|
||
|
}
|
||
|
|
||
|
bool TRil_ore_cms_mask::on_field_event(TOperable_field& o, TField_event e, long jolly)
|
||
|
{
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
|
||
|
void TRil_ore_cms_mask::format_report(TReport& rep) const
|
||
|
{
|
||
|
//maggico giro per formattare la testata del calendario di pagina nel report
|
||
|
const int anno = get_int(F_ANNO);
|
||
|
const int mese = get_int(F_MESE);
|
||
|
const TDate primo_del_mese(1, mese, anno);
|
||
|
TDate ultimo_del_mese = primo_del_mese;
|
||
|
ultimo_del_mese.set_end_month();
|
||
|
|
||
|
TString16 code;
|
||
|
|
||
|
for (TDate giorno = primo_del_mese; giorno <= ultimo_del_mese; ++giorno)
|
||
|
{
|
||
|
code.format("H0.%d", giorno.day() + 100);
|
||
|
TReport_field* rep_field = rep.field(code);
|
||
|
|
||
|
if (rep_field != NULL)
|
||
|
{
|
||
|
if (!ci_is_ferial_day(giorno))
|
||
|
rep_field->set_back_color(COLOR_LTGRAY);
|
||
|
|
||
|
code = itow(giorno.wday());
|
||
|
code.cut(3);
|
||
|
code << '\n' << giorno.day();
|
||
|
rep_field->set(code);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
void TRil_ore_cms_mask::elabora() const
|
||
|
{
|
||
|
TReport_book book;
|
||
|
TRil_ore_cms_report rep;
|
||
|
|
||
|
format_report(rep);
|
||
|
|
||
|
//query sul file interessato (commessa o centro di costo)
|
||
|
TString16 da_cms_cdc, a_cms_cdc;
|
||
|
TString query_cms_cdc;
|
||
|
TString msg, code_name;
|
||
|
const char tipo_cms_cdc = get(F_CMSOCDC)[0];
|
||
|
|
||
|
if (tipo_cms_cdc == 'C')
|
||
|
{
|
||
|
da_cms_cdc = get(F_DA_CODCMS);
|
||
|
a_cms_cdc = get(F_A_CODCMS);
|
||
|
query_cms_cdc << "USE COMMESSE";
|
||
|
query_cms_cdc << "\nFROM CODCMS=#DACODICE";
|
||
|
query_cms_cdc << "\nTO CODCMS=#ACODICE";
|
||
|
msg << "Scansione commesse...";
|
||
|
code_name = "CODCMS";
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
da_cms_cdc = get(F_DA_CODCDC);
|
||
|
a_cms_cdc = get(F_A_CODCDC);
|
||
|
query_cms_cdc << "USE CDC";
|
||
|
query_cms_cdc << "\nFROM CODCOSTO=#DACODICE";
|
||
|
query_cms_cdc << "\nTO CODCOSTO=#ACODICE";
|
||
|
msg << "Scansione centri di costo...";
|
||
|
code_name = "CODCOSTO";
|
||
|
}
|
||
|
|
||
|
TISAM_recordset recset_cms_cdc(query_cms_cdc);
|
||
|
recset_cms_cdc.set_var("#DACODICE", da_cms_cdc);
|
||
|
recset_cms_cdc.set_var("#ACODICE", a_cms_cdc);
|
||
|
const long recset_cms_cdc_items = recset_cms_cdc.items();
|
||
|
|
||
|
TProgind pi(recset_cms_cdc_items, msg, true, true);
|
||
|
|
||
|
//per ogni cms/cdc dell'elenco genera un report singolo che viene riempito nella elabora_commessa e..
|
||
|
//..aggiunto al book per la stampa finale
|
||
|
for (bool ok = recset_cms_cdc.move_first(); ok; ok = recset_cms_cdc.move_next())
|
||
|
{
|
||
|
if (!pi.addstatus(1))
|
||
|
break;
|
||
|
|
||
|
const TString& curr_commessa = recset_cms_cdc.cursor()->curr().get(code_name);
|
||
|
|
||
|
//elabora_commessa(curr_commessa, rep);
|
||
|
|
||
|
book.add(rep);
|
||
|
}
|
||
|
|
||
|
//e alla fine stampa il book
|
||
|
book.preview();
|
||
|
}
|
||
|
|
||
|
///////////////////////////////////////////////////////////
|
||
|
// Applicazione
|
||
|
///////////////////////////////////////////////////////////
|
||
|
|
||
|
class TRil_ore_cms : public TSkeleton_application
|
||
|
{
|
||
|
protected:
|
||
|
|
||
|
public:
|
||
|
virtual void main_loop();
|
||
|
};
|
||
|
|
||
|
void TRil_ore_cms::main_loop()
|
||
|
{
|
||
|
TRil_ore_cms_mask mask;
|
||
|
|
||
|
while (mask.run() == K_ENTER)
|
||
|
{
|
||
|
mask.elabora();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
int ci1400(int argc, char* argv[])
|
||
|
{
|
||
|
TRil_ore_cms sd;
|
||
|
sd.run(argc, argv, "Rilevazione ore per Commessa - CdC");
|
||
|
return 0;
|
||
|
}
|