dcba1c1e51
Files correlati : Ricompilazione Demo : [ ] Commento : git-svn-id: svn://10.65.10.50/branches/R_10_00@22121 c028cbd2-c16b-5b4b-a496-9718f37d4682
192 lines
6.0 KiB
C++
Executable File
192 lines
6.0 KiB
C++
Executable File
#include <applicat.h>
|
||
#include <automask.h>
|
||
#include <defmask.h>
|
||
#include <progind.h>
|
||
#include <relation.h>
|
||
#include <textset.h>
|
||
|
||
#include <rdoc.h>
|
||
|
||
#include "ps1002.h"
|
||
#include "ps1002300a.h"
|
||
|
||
/////////////////////////////////////
|
||
// Maschera
|
||
////////////////////////////////////
|
||
class TRileva_produzione_msk : public TAutomask
|
||
{
|
||
protected:
|
||
virtual bool on_field_event(TOperable_field& o, TField_event e, long jolly);
|
||
|
||
public:
|
||
bool elabora();
|
||
TRileva_produzione_msk();
|
||
};
|
||
|
||
|
||
bool TRileva_produzione_msk::on_field_event(TOperable_field& o, TField_event e, long jolly)
|
||
{
|
||
switch (o.dlg())
|
||
{
|
||
case DLG_ELABORA:
|
||
if (e == fe_button)
|
||
{
|
||
elabora();
|
||
return true;
|
||
}
|
||
break;
|
||
case F_DADATA:
|
||
case F_ADATA:
|
||
if (e == fe_close)
|
||
{
|
||
const TDate dadata = o.get();
|
||
}
|
||
break;
|
||
default: break;
|
||
}
|
||
return true;
|
||
}
|
||
|
||
bool TRileva_produzione_msk::elabora()
|
||
{
|
||
TString query;
|
||
query << "USE RDOC KEY 4";
|
||
query << "\nSELECT (DOC.CODNUM=#CODNUM)&&(BETWEEN(DOC.DATADOC,#DADATA,#ADATA))&&((CODCMS!=\"\")||(FASCMS!=\"\"))";
|
||
query << "\nJOIN DOC INTO PROVV==PROVV ANNO==ANNO CODNUM==CODNUM NDOC==NDOC";
|
||
query << "\nFROM DAPROVV=D DAANNO=#ANNO DACODNUM=BEM";
|
||
query << "\nTO DAPROVV=D DAANNO=#ANNO DACODNUM=BEM";
|
||
|
||
TISAM_recordset recset(query);
|
||
recset.set_var("#CODNUM", get(F_CODNUM));
|
||
recset.set_var("#DADATA", get_date(F_DADATA));
|
||
recset.set_var("#ADATA", get_date(F_ADATA));
|
||
const long anno = get_date(F_DADATA).year();
|
||
recset.set_var("#ANNO", anno);
|
||
|
||
const long items = recset.items();
|
||
|
||
const TDate dataprod = get_date(F_DATAPROD);
|
||
TProgind pi(items, TR("Scansione righe documento in corso..."), true, true);
|
||
TRectype& bolla_rec = recset.cursor()->curr(); //record corrente del recordset
|
||
TLocalisamfile rdoc(LF_RIGHEDOC); //file delle righe documento con le BEM da aggiornare
|
||
|
||
for (bool ok = recset.move_first(); ok; ok = recset.move_next())
|
||
{
|
||
if (!pi.addstatus(1))
|
||
break;
|
||
|
||
//prende la quantita' dalla riga della bolla
|
||
const real bolla_qta = bolla_rec.get_real(RDOC_QTA);
|
||
if (bolla_qta > ZERO)
|
||
{
|
||
#ifdef DBG
|
||
const TString& bolla_codnum = bolla_rec.get(RDOC_CODNUM);
|
||
const int bolla_anno = bolla_rec.get_int(RDOC_ANNO);
|
||
const long bolla_ndoc = bolla_rec.get_long(RDOC_NDOC);
|
||
const int bolla_nriga = bolla_rec.get_int(RDOC_NRIGA);
|
||
#endif
|
||
//campi che servono per raccatare la riga della BEM
|
||
const TString& bem_codnum = bolla_rec.get(RDOC_DACODNUM);
|
||
const long bem_anno = bolla_rec.get_int(RDOC_DAANNO);
|
||
const long bem_ndoc = bolla_rec.get_long(RDOC_DANDOC);
|
||
const long bem_idriga = bolla_rec.get_int(RDOC_DAIDRIGA);
|
||
//servono anche lavorazione e colore (almeno uno dei due c'e' in base alla query)
|
||
const TString& bolla_lav = bolla_rec.get(RDOC_CODCMS);
|
||
const TString& bolla_col = bolla_rec.get(RDOC_FASCMS);
|
||
|
||
//adesso prende la riga documento della BEM e aggiorna i valori se deve
|
||
//e' costretto ad usare una query e non una read() perche' IDRIGA non appartiene alle chiavi di RDOC
|
||
TString bem_query;
|
||
bem_query << "USE RDOC";
|
||
bem_query << "\nSELECT (IDRIGA=#IDRIGA)";
|
||
bem_query << "\nFROM CODNUM=BEM ANNO=#ANNO PROVV=D NDOC=#NDOC";
|
||
bem_query << "\nTO CODNUM=BEM ANNO=#ANNO PROVV=D NDOC=#NDOC";
|
||
|
||
TISAM_recordset bem_recset(bem_query);
|
||
|
||
bem_recset.set_var("#IDRIGA", bem_idriga);
|
||
bem_recset.set_var("#ANNO", bem_anno);
|
||
bem_recset.set_var("#NDOC", bem_ndoc);
|
||
|
||
const long bem_items = bem_recset.items();
|
||
if (bem_items > 1)
|
||
return error_box("C'e' piu' di una riga della BEM %ld con IDRIGA = %ld", bem_ndoc, bem_idriga);
|
||
|
||
/*TRectype& bem_rec = rdoc.curr();
|
||
const TString& bem_codnum = bolla_rec.get(RDOC_DACODNUM); //se non fosse BEM sarebbe un errore!!!
|
||
bem_rec.put(RDOC_CODNUM, bem_codnum);
|
||
const int bem_anno = bolla_rec.get_int(RDOC_DAANNO);
|
||
bem_rec.put(RDOC_ANNO, bem_anno);
|
||
bem_rec.put(RDOC_PROVV, 'D');
|
||
const long bem_ndoc = bolla_rec.get_long(RDOC_DANDOC);
|
||
bem_rec.put(RDOC_NDOC, bem_ndoc);
|
||
//occhio alla riga, raga! DAIDRIGA sulla rigabolla deve essere uguale a IDRIGA sulla rigabem, NON a NRIGA che <20> aleatorio!
|
||
const int bem_idriga = bolla_rec.get_int(RDOC_DAIDRIGA);
|
||
bem_rec.put(RDOC_IDRIGA, bem_idriga);*/
|
||
|
||
//if (bem_rec.read(rdoc) == NOERR)
|
||
//{
|
||
TRectype& bem_rec = bem_recset.cursor()->curr();
|
||
const real bem_old_lav_qta = bem_rec.get_real(RDOC_QTAGG2);
|
||
const real bem_old_col_qta = bem_rec.get_real(RDOC_QTAGG1);
|
||
|
||
//solo le BEM a quantita' lavorazione e/o colore nulle possono essere aggiornate (senno' ci verrebbe del casino)
|
||
if (bolla_lav.full() && bem_old_lav_qta == ZERO) //lavorazione
|
||
{
|
||
bem_rec.put(RDOC_CODCMS, bolla_lav);
|
||
bem_rec.put(RDOC_QTAGG2, bolla_qta);
|
||
bem_rec.put(RDOC_CODAGG2, dataprod);
|
||
}
|
||
if (bolla_col.full() && bem_old_col_qta == ZERO) //colore
|
||
{
|
||
bem_rec.put(RDOC_FASCMS, bolla_col);
|
||
bem_rec.put(RDOC_QTAGG1, bolla_qta);
|
||
bem_rec.put(RDOC_DATACONS, dataprod);
|
||
}
|
||
const int err = bem_rec.rewrite(rdoc);
|
||
if (err != NOERR)
|
||
return false;
|
||
|
||
//} //if(bem_rec.read(rdoc)...
|
||
|
||
} // if (bolla_qta > ZERO)...
|
||
} //for (bool ok = recset.move_first()...
|
||
|
||
return true;
|
||
}
|
||
|
||
|
||
TRileva_produzione_msk::TRileva_produzione_msk()
|
||
: TAutomask ("ps1002300a")
|
||
{}
|
||
|
||
|
||
/////////////////////////////////////
|
||
// Applicazione
|
||
////////////////////////////////////
|
||
class TRileva_produzione : public TSkeleton_application
|
||
{
|
||
protected:
|
||
virtual bool check_autorization() const { return false; }
|
||
virtual const char* extra_modules() const { return "ve"; }
|
||
virtual void main_loop();
|
||
virtual bool create();
|
||
};
|
||
|
||
void TRileva_produzione::main_loop()
|
||
{
|
||
TRileva_produzione_msk mask;
|
||
mask.run();
|
||
}
|
||
|
||
bool TRileva_produzione::create()
|
||
{
|
||
return TSkeleton_application::create();
|
||
}
|
||
|
||
int ps1002300 (int argc, char* argv[])
|
||
{
|
||
TRileva_produzione main_app;
|
||
main_app.run(argc, argv, TR("Rileva produzione da bolle"));
|
||
return true;
|
||
} |