git-svn-id: svn://10.65.10.50/branches/R_10_00@22725 c028cbd2-c16b-5b4b-a496-9718f37d4682
		
			
				
	
	
		
			165 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			165 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
#include "halib.h"
 | 
						||
 | 
						||
#include "../ve/velib04.h"
 | 
						||
 | 
						||
class TElaborazione_NAC_definitive : public TElaborazione
 | 
						||
{ 
 | 
						||
protected:
 | 
						||
  int find_contratti_cliente(long codcfatt, const TDate& data_elab, TArray& contratti_cliente);
 | 
						||
 | 
						||
public:
 | 
						||
  virtual bool elabora(TLista_documenti& doc_in, TLista_documenti& doc_out, 
 | 
						||
                       const TDate& data_elab, bool interattivo);
 | 
						||
 | 
						||
  TElaborazione_NAC_definitive(const TString& codelab) : TElaborazione(codelab) { }
 | 
						||
};
 | 
						||
 | 
						||
//metodo che riempie un array con tutti i contratti del cliente passatogli (in base alla tipologia di contratti da elaborare)
 | 
						||
int TElaborazione_NAC_definitive::find_contratti_cliente(long codcfatt, const TDate& data_elab, 
 | 
						||
                                                         TArray& contratti_cliente)
 | 
						||
{
 | 
						||
  contratti_cliente.destroy();
 | 
						||
 | 
						||
  //settaggio delle variabili
 | 
						||
  //il codice numerazione lo trova nella configurazione Hardy, e lo deve scegliere in base alla tipologia di contratti che sta esaminando!
 | 
						||
  TConfig config(CONFIG_DITTA, "ha");
 | 
						||
 | 
						||
  const TString4 tip_ant  = config.get("CoAntTip");
 | 
						||
  const TString4 tip_rifa = config.get("CoRifaTip");
 | 
						||
  const TString4 tip_post = config.get("CoPostTip");
 | 
						||
 | 
						||
  TAssoc_array cod_num_cont;
 | 
						||
  cod_num_cont.add(config.get("CoAntNum"));
 | 
						||
  cod_num_cont.add(config.get("CoRifaNum"));
 | 
						||
  cod_num_cont.add(config.get("CoPostNum"));
 | 
						||
 | 
						||
  FOR_EACH_ASSOC_OBJECT(cod_num_cont, h, k, o)
 | 
						||
  {
 | 
						||
    //deve cercare tutti i contratti del cliente e metterli nell'array
 | 
						||
    TString query;
 | 
						||
    query << "USE DOC KEY 5";
 | 
						||
    query << "\nSELECT ((TIPODOC=#A_TIPODOC)||(TIPODOC=#R_TIPODOC)||(TIPODOC=#P_TIPODOC))&&(STR(DOC2=#CODCF))";
 | 
						||
    query << "\nFROM PROVV=D CODNUM=" << k;
 | 
						||
    query << "\nTO PROVV=D CODNUM=" << k;
 | 
						||
 | 
						||
    TISAM_recordset recset(query);
 | 
						||
 | 
						||
    recset.set_var("#A_TIPODOC", tip_ant);
 | 
						||
    recset.set_var("#R_TIPODOC", tip_rifa);
 | 
						||
    recset.set_var("#P_TIPODOC", tip_post);
 | 
						||
  
 | 
						||
    recset.set_var("#CODCF", codcfatt);
 | 
						||
 | 
						||
    const long n_contratti = recset.items(); //questo serve solo al sagace programmatore
 | 
						||
 | 
						||
    //aggiunge i contratti all'array: solo quelli in auge nel periodo di calcolo selezionato sulla maschera!
 | 
						||
    for (bool ok = recset.move_first(); ok; ok = recset.move_next())
 | 
						||
	  {
 | 
						||
      //contratti anticipo 'A': datainizio esiste sempre, datafine non esiste (va ad esaurimento)
 | 
						||
      //contratti posticipo 'P': datainizio esiste sempre, datafine pu<70> non esistere
 | 
						||
      //contratti rifatturazione 'R': come contratti anticipo
 | 
						||
 | 
						||
      //controlla validit<69> del contratto con le date scelte per l'elaborazione dei documenti
 | 
						||
      const TDate data_ini_contratto = recset.get(DOC_DATACOMP).as_date();
 | 
						||
 | 
						||
      //quindi la datainizio vale per tutti allo stesso modo (<28> obbligatoria nei contratti)
 | 
						||
      //se l'elaborazione finisce prima che cominci il contratto -> il contratto non serve a nulla
 | 
						||
      if (data_ini_contratto > data_elab)
 | 
						||
        continue;
 | 
						||
 | 
						||
      //la data fine vale invece solo per i contratti 'P' e potrebbe non esserci (contratti senza scadenza)
 | 
						||
      TDate data_fine_contratto;
 | 
						||
 | 
						||
      //se la data fine contratto non <20> valida (ma <20> presente!) non dobbiamo fare nulla, perch<63> il contratto non va elaborato
 | 
						||
      data_fine_contratto = recset.get(DOC_DATAFCOMP).as_date();
 | 
						||
      if (data_fine_contratto.ok())
 | 
						||
      {
 | 
						||
        if (data_fine_contratto < data_elab)
 | 
						||
          continue;
 | 
						||
      }
 | 
						||
 | 
						||
      TContratto_premi* curr_contratto = new TContratto_premi(recset.cursor()->curr());
 | 
						||
      contratti_cliente.add(curr_contratto);
 | 
						||
    }
 | 
						||
  }
 | 
						||
  return contratti_cliente.items();
 | 
						||
}
 | 
						||
 | 
						||
bool TElaborazione_NAC_definitive::elabora(TLista_documenti& doc_in, TLista_documenti& doc_out, 
 | 
						||
                                           const TDate& data_elab, bool interattivo)
 | 
						||
{
 | 
						||
  TArray contratti;
 | 
						||
  bool done = false;
 | 
						||
  for (int i = 0; i < doc_in.items(); i++)
 | 
						||
  {
 | 
						||
    TDocumento& doc = doc_in[i];
 | 
						||
    const long codcf = doc.codcf();
 | 
						||
    const TDate data = doc.get(DOC_DATADOC);
 | 
						||
 | 
						||
    FOR_EACH_PHYSICAL_RDOC(doc, r, rdoc)
 | 
						||
    {
 | 
						||
      const TRectype* contr = rdoc->find_original_doc();
 | 
						||
      if (contr == NULL && find_contratti_cliente(codcf, data, contratti) == 1)
 | 
						||
        contr = (TContratto_premi*)contratti.objptr(0);
 | 
						||
 | 
						||
      if (contr)
 | 
						||
      {
 | 
						||
        TContratto_premi cp(*contr);
 | 
						||
        FOR_EACH_PHYSICAL_RDOC_BACK(cp, c, rc)
 | 
						||
        {
 | 
						||
          if (rc->tipo().codice() == HARDY_TIPORIGA_SOMMA)
 | 
						||
          {
 | 
						||
            rc->add(RCA_2_RESO_STORICO, rdoc->importo(false, false, 2));
 | 
						||
            done = cp.rewrite() == NOERR;
 | 
						||
            break;
 | 
						||
          }
 | 
						||
        }
 | 
						||
      }
 | 
						||
    }
 | 
						||
  }
 | 
						||
  return done;
 | 
						||
}
 | 
						||
 | 
						||
///////////////////////////////////////////////////////////
 | 
						||
// main
 | 
						||
///////////////////////////////////////////////////////////
 | 
						||
 | 
						||
class TNac_def_app : public TSkeleton_application
 | 
						||
{
 | 
						||
protected:
 | 
						||
  virtual void main_loop();
 | 
						||
};
 | 
						||
 | 
						||
 | 
						||
void TNac_def_app::main_loop()
 | 
						||
{
 | 
						||
  if (argc() >= 2 && toupper(argv(2)[1]) == 'I')
 | 
						||
  {
 | 
						||
    open_files(LF_TABCOM, LF_TAB, LF_CLIFO, LF_DOC, LF_RIGHEDOC, 0);
 | 
						||
    TConfig ini(argv(2)+2, "Transaction");
 | 
						||
    const TString16 codelab = ini.get("Action");
 | 
						||
    ini.set_paragraph("33");
 | 
						||
    const char provv      = ini.get_char(DOC_PROVV);
 | 
						||
    const int anno        = ini.get_int(DOC_ANNO);
 | 
						||
    const TString4 codnum = ini.get(DOC_CODNUM);
 | 
						||
    const long ndoc       = ini.get_long(DOC_NDOC);
 | 
						||
    TDocumento* doc = new TDocumento(provv, anno, codnum, ndoc);
 | 
						||
      
 | 
						||
    TLista_documenti doc_in, doc_out;
 | 
						||
    doc_in.add(doc);
 | 
						||
 | 
						||
    const TDate oggi(TODAY);
 | 
						||
    TElaborazione_NAC_definitive end(codelab);
 | 
						||
    const bool done = end.elabora(doc_in, doc_out, oggi, false);
 | 
						||
 | 
						||
    ini.set("Result", done ? "SUCCESS" : "ERROR", "Transaction");
 | 
						||
  }
 | 
						||
}
 | 
						||
 | 
						||
int ha0700(int argc, char* argv[])
 | 
						||
{
 | 
						||
  TNac_def_app app;
 | 
						||
  app.run(argc, argv, TR("NAC definitive"));
 | 
						||
  return 0;
 | 
						||
}
 |