import java.math.BigDecimal;

import com.softwareag.entirex.aci.Broker;
import com.softwareag.entirex.aci.BrokerException;

/**
* <p>Titre : Jwrbspl1Web</p>
* <p>Description : Consultation , Liste suivi des échanges SEPA  </p>
* <p>Copyright : Copyright (c) 2013</p>
* <p>Societe : ENSOR</p>
* @author AR & DR & MA <i>19/07/2013</i>
* @version 1.0
* RBSPL1
*/
public class Jwrbspl1Web {	

		private static String PRINT = "NO";
		/**
		 * <p>Titre : getListeEchangeSEPA </p>
		 * <p>Description : Consultation , Liste suivi des échanges SEPA  </p>
		 * <p>Copyright : Copyright (c) 2013</p>
		 * <p>Societe : ENSOR</p>
		 * @author MR & PR & HJ <i>19/07/2013</i>
		 * @version 1.0
		 */
		public static Jwrbspl1 getListeEchangeSepa(
			String nbrep,
			String page,
			String fonction,

			String f_k_cible,
			String f_k_stegrp,
			String f_type_fic,
			String f_dt_creat,
			String f_ordre_tri,
			String f_mt_fic_deb,
			String f_mt_fic_fin,
			String f_top_date_creat,
			String f_date_per_deb,
			String f_date_per_fin,
			String f_ics_emet, 
			String f_k_titre,
			String f_bic,
			String f_iban,
			String f_top_etat,
		
			String groupe_exploitant,
			String numero_session,
			String utilisateur,		
			String cd_cible,
			String cd_stegrp,			
			Broker broker) throws BrokerException {
			// Initialisation des variables en entrees
	     		Jwrbspl1 jwrbspl1 = new Jwrbspl1(broker, Constantes.SERVER_ADRESSE);
			// Initialisation de la vWebent depuis les informations de connexion
			Jwrbspl1.Nwrbspl1Axwebent vWebent = jwrbspl1.new Nwrbspl1Axwebent();
			vWebent.dbid 		   	  = new BigDecimal (Constantes.DBID);
			vWebent.cible_exploitant  = Constantes.CD_CIBLE;
			vWebent.groupe_exploitant = groupe_exploitant;
			vWebent.numero_session 	  = new BigDecimal (numero_session);
			vWebent.utilisateur       = utilisateur;
			vWebent.transaction 	  = "WBWRB";
			vWebent.fonction 	  	  = fonction;
			vWebent.cd_cible 	  	  = cd_cible;
			vWebent.cd_stegrp 	  	  = cd_stegrp;
			vWebent.cd_application 	  = Constantes.CD_APPLICATION;
			jwrbspl1.setNwrbspl1Axwebent (vWebent);
	        
			// Initialisation des parametres de pagination
			Jwrbspl1.Nwrbspl1Axweblst vWeblst = jwrbspl1.new Nwrbspl1Axweblst();
			vWeblst.nb_rep_souhait 			  = new BigDecimal(nbrep);
			vWeblst.num_page_souhait 		  = new BigDecimal(page);
			jwrbspl1.setNwrbspl1Axweblst (vWeblst);

			// Initialisation des criteres (tous a vide pour l instant)
			Jwrbspl1.Nwrbspl1Awrbspl1 vLwspl1 = jwrbspl1.new Nwrbspl1Awrbspl1();
			Jwrbspl1.Nwrbspl1Awrbspl1Demande vLwspl1Demande = jwrbspl1.new Nwrbspl1Awrbspl1Demande();
			
			Jwrbspl1.Nwrbspl1Awrbspl1DemandeCritere_select vLwspl1DemandeCritere = jwrbspl1.new Nwrbspl1Awrbspl1DemandeCritere_select();
			
            vLwspl1DemandeCritere.f_k_cible 	      		= f_k_cible;
			vLwspl1DemandeCritere.f_k_stegrp 	      		= f_k_stegrp;         
			vLwspl1DemandeCritere.f_ordre_tri 	      		= f_ordre_tri;
			vLwspl1DemandeCritere.f_top_date_creat 	   		= f_top_date_creat; 
			vLwspl1DemandeCritere.f_type_fic 	   			= f_type_fic;
			
			// Il faut convertir les données String en BigDecimal
			if(!"".equals(f_dt_creat) && f_dt_creat!=null){
            			vLwspl1DemandeCritere.f_dt_creat  = new BigDecimal(f_dt_creat);
	    		}
			if(!"".equals(f_date_per_deb) && f_date_per_deb!=null){
            			vLwspl1DemandeCritere.f_date_per_deb  = new BigDecimal(f_date_per_deb);
	    		}
			if(!"".equals(f_date_per_fin) && f_date_per_fin!=null){
            			vLwspl1DemandeCritere.f_date_per_fin  = new BigDecimal(f_date_per_fin);
	    		}

			if(!"".equals(f_mt_fic_deb) && f_mt_fic_deb!=null){
            			vLwspl1DemandeCritere.f_mt_fic_deb  = new BigDecimal(f_mt_fic_deb);
	    		}
	
			if(!"".equals(f_mt_fic_fin) && f_mt_fic_fin!=null){
            			vLwspl1DemandeCritere.f_mt_fic_fin  = new BigDecimal(f_mt_fic_fin);
	    		}
			// =======
			vLwspl1DemandeCritere.f_ics_emet 	= f_ics_emet;
			vLwspl1DemandeCritere.f_k_titre 	= f_k_titre;
			vLwspl1DemandeCritere.f_bic 		= f_bic;
			vLwspl1DemandeCritere.f_iban 		= f_iban;
			if(!"".equals(f_top_etat) && f_top_etat!=null){
					vLwspl1DemandeCritere.f_top_etat = new BigDecimal(f_top_etat);	
			}
			//========
			vLwspl1Demande.critere_select = vLwspl1DemandeCritere;
			vLwspl1.demande = vLwspl1Demande;

			jwrbspl1.setNwrbspl1Awrbspl1 (vLwspl1);
			
		    // CALL SERVER
		    jwrbspl1.nwrbspl1();
				                                
	        // Verification du code retour
			vWebent = jwrbspl1.getNwrbspl1Axwebent();
			System.out.println("Code retour nwrbspl1() = " + vWebent.code_retour.intValue());
			
			if(vWebent.code_retour.intValue() != 0){
				for(int i=0; i < vWebent.nb_ano.intValue(); i++){
				   System.out.println(vWebent.t_ano[i].code_ano + "[" + vWebent.t_ano[i].type_ano + "] :  " + vWebent.t_ano[i].lib_ano.trim() + " ");
			   	   }
				}
			else {
				//Recuperation du resultat si code retour OK
				Jwrbspl1.Nwrbspl1Awrbspl1_tab vWeblsttab = jwrbspl1.getNwrbspl1Awrbspl1_tab();
				
				//Affichage de la liste des resultats
				if(PRINT == "YES") {
					
					System.out.println("\n");
					//System.out.println("cle reprise="+f_cle_reprise+"\n");
					for(int i = 0; i < new BigDecimal(nbrep).intValue(); i++){
							System.out.println (
									  " CIBLE = "               + vWeblsttab.ligne_ref[i].k_cible 	
									+ "; DT-CREAT ="			+ vWeblsttab.ligne_ref[i].dt_creat 
									+ "; ICS émetteur =" 		+ vWeblsttab.ligne_ref[i].ics_emet
									+ "; Titre ="  				+ vWeblsttab.ligne_ref[i].k_titre
									+ "; Titre ="  				+ vWeblsttab.ligne_ref[i].lib_titre

									+ "; Libellé titre =" 		+ vWeblsttab.ligne_ref[i].lib_titre
									+ "; BIC ="  				+ vWeblsttab.ligne_ref[i].bic 
									+ "; IBAN =" 				+ vWeblsttab.ligne_ref[i].iban
									+ "; Montant du Fichier =" 	+ vWeblsttab.ligne_ref[i].mt_fic
									+ "; Nombre de Remises =" 	+ vWeblsttab.ligne_ref[i].nb_remise_fic 
									+ "; Nombre de mvt  =" 		+ vWeblsttab.ligne_ref[i].nb_mvt_fic 
									+ "; Top etat  =" 			+ vWeblsttab.ligne_ref[i].top_etat
									+ "; Libellé etat =" 		+ vWeblsttab.ligne_ref[i].lib_etat
									+ "; User validat°  =" 		+ vWeblsttab.ligne_ref[i].usr_val 
									+ "; Date validat°  =" 		+ vWeblsttab.ligne_ref[i].dt_val 
									+ "; Heure validat° =" 		+ vWeblsttab.ligne_ref[i].hhmmss_val
									); 
							System.out.println("\n");
					}
					//Affichage des informations de pagination
					System.out.println ("nb_rep_rendues : "    + jwrbspl1.getNwrbspl1Axweblst().nb_rep_rendues);
					System.out.println ("num_page_rendue : "   + jwrbspl1.getNwrbspl1Axweblst().num_page_rendue);
					System.out.println ("top_page_suivante : " + jwrbspl1.getNwrbspl1Axweblst().top_page_suivante);
					System.out.println ("nb_pages_totales : "  + jwrbspl1.getNwrbspl1Axweblst().nb_pages_totales);
				}
			}
			return jwrbspl1;
			
	   } // End getListeEchangeSepa

		/**
		 * <p>Titre : main</p>
		 * <p>Description : Programme principal de tests</p>
		 * <p>Copyright : Copyright (c) 2013</p>
		 * <p>Societe : ENSOR</p>
		 * @author MR & PR & HJ <i>19/07/2013</i>
		 * @version 1.0
		 */
	   	public static void main(String[] args) throws BrokerException {
			Constantes.loadProperties("LW") ;
			JxweblogWeb.setUtilisateur ("MADAE04");
			JxweblogWeb.setPassword ("MADAE94");
			Broker broker 	  = JxweblogWeb.logonBroker();
			Jxweblog jxweblog = JxweblogWeb.getConnexion(broker);
			PRINT = "YES";
			
			
			Jxweblog.NxweblogAxwebent connexion = jxweblog.getNxweblogAxwebent();
			String groupe_exploitant 			= connexion.groupe_exploitant;
			String numero_session 				= Integer.toString(connexion.numero_session.intValue());
			String utilisateur 					= connexion.utilisateur;
			String cd_cible						= connexion.cd_cible;
			String cd_stegrp 					= connexion.cd_stegrp;
		
			//--------------------Donnee test------------------
			String nbrep 		       = "10";
			String page 		       = "1";
			String fonction 	       = "I";
			
			String f_k_cible		   = "08";
			String f_k_stegrp	 	   = null;
			String f_type_fic		   = null;
			String f_dt_creat   	   = null;
			String f_ordre_tri 	  	   = null;
			String f_mt_fic_deb		   = null;
			String f_mt_fic_fin 	   = null;
			String f_top_date_creat	   = null;
			String f_date_per_deb	   = null;
			String f_date_per_fin	   = null;
			String f_ics_emet          = null; 
			String f_k_titre           = null;
			String f_bic               = null;
			String f_iban              = null;
			String f_top_etat          = "4";
		
			//--------------------Donnee test------------------
			getListeEchangeSepa(nbrep, page, fonction, 
					f_k_cible, f_k_stegrp, f_type_fic, f_dt_creat, f_ordre_tri, 
					f_mt_fic_deb, f_mt_fic_fin,f_top_date_creat, f_date_per_deb, f_date_per_fin,
					f_ics_emet,f_k_titre,f_bic,f_iban,f_top_etat,
					groupe_exploitant, numero_session, utilisateur, cd_cible, cd_stegrp, broker);
											
			JxweblogWeb.closeConnexion (jxweblog);
	   }
} // END Jwrbspl1Web