import java.math.BigDecimal;

import com.softwareag.entirex.aci.Broker;
import com.softwareag.entirex.aci.BrokerException;

/**
* <p>Titre : Jwlwtil1Web</p>
* <p>Description : Consultation , Liste des titres</p>
* <p>Copyright : Copyright (c) 2013</p>
* <p>Societe : ENSOR</p>
* @author AR & DR & PY <i>24/01/2013</i>
* @version 1.0
 */
public class Jwlwtil1Web {	

		private static String PRINT = "NO";
		/**
		 * <p>Titre : getListeTitres</p>
		 * <p>Description : Consultation , Liste des titres </p>
		 * <p>Copyright : Copyright (c) 2013</p>
		 * <p>Societe : ENSOR</p>
		 * @author AR & DR & PY <i>24/01/2013</i>
		 * @version 1.0
		 */
		public static Jwlwtil1 getListeTitres( 
			String nbrep,
			String page,
			String fonction,
			String f_code_titre,
			String f_filtre_ext,
			String f_cd_zpo,
			String f_type_portage,
			String f_zpo_libelle,
			String f_cd_zpo_affect,
			String f_type_portage_affect,
			String f_localite_affect,
			String f_cd_insee_affect,
			String f_code_postal_affect,
			String f_type_trt_affect,
			String f_cible_grppres_stegrp,
			String f_cle_reprise,
			String f_nom_titre_affect,
			String top_affect,
			String top_suppr,
			String groupe_exploitant,
			String numero_session,
			String utilisateur,
			String cd_cible,
			String cd_stegrp,
			Broker broker) throws BrokerException {
			// Initialisation des variables en entrees
	     	Jwlwtil1 jwlwtil1 = new Jwlwtil1(broker, Constantes.SERVER_ADRESSE);
			// Initialisation de la vWebent depuis les informations de connexion
			Jwlwtil1.Nwlwtil1Axwebent vWebent = jwlwtil1.new Nwlwtil1Axwebent();
			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 	  = "WLWCLLST";
			vWebent.fonction 		  = fonction;
			vWebent.cd_cible 		  = cd_cible;
			vWebent.cd_stegrp 		  = cd_stegrp;
			vWebent.cd_application 	  = Constantes.CD_APPLICATION;
			jwlwtil1.setNwlwtil1Axwebent (vWebent);
	        
			// Initialisation des parametres de pagination
			Jwlwtil1.Nwlwtil1Axweblst vWeblst = jwlwtil1.new Nwlwtil1Axweblst();
			vWeblst.nb_rep_souhait 			  = new BigDecimal(nbrep);
			vWeblst.num_page_souhait 		  = new BigDecimal(page);
			jwlwtil1.setNwlwtil1Axweblst (vWeblst);

			// Initialisation des criteres (tous a vide pour l instant)
			Jwlwtil1.Nwlwtil1Awlwtil1 vLwtil1 = jwlwtil1.new Nwlwtil1Awlwtil1();
			Jwlwtil1.Nwlwtil1Awlwtil1Demande vLwtil1Demande = jwlwtil1.new Nwlwtil1Awlwtil1Demande();
			Jwlwtil1.Nwlwtil1Awlwtil1DemandeCritere_select vLwtil1DemandeCritere = jwlwtil1.new Nwlwtil1Awlwtil1DemandeCritere_select();
			Jwlwtil1.Nwlwtil1Awlwtil1DemandeAction vLwtil1DemandeAction 		 = jwlwtil1.new Nwlwtil1Awlwtil1DemandeAction();
            
            vLwtil1DemandeCritere.f_code_titre 			 = f_code_titre;
            vLwtil1DemandeCritere.f_filtre_ext 			 = f_filtre_ext;
            vLwtil1DemandeCritere.f_cd_zpo 			 	 = f_cd_zpo;
            vLwtil1DemandeCritere.f_type_portage 		 = f_type_portage;
            vLwtil1DemandeCritere.f_zpo_libelle 		 = f_zpo_libelle;
            vLwtil1DemandeCritere.f_cd_zpo_affect 		 = f_cd_zpo_affect;
            vLwtil1DemandeCritere.f_type_portage_affect  = f_type_portage_affect;
            vLwtil1DemandeCritere.f_localite_affect 	 = f_localite_affect;
            vLwtil1DemandeCritere.f_cd_insee_affect 	 = f_cd_insee_affect;
            vLwtil1DemandeCritere.f_code_postal_affect 	 = f_code_postal_affect;
            vLwtil1DemandeCritere.f_type_trt_affect 	 = f_type_trt_affect;
            vLwtil1DemandeCritere.f_cle_reprise     	 = f_cle_reprise;
            vLwtil1DemandeCritere.f_nom_titre_affect     = f_nom_titre_affect;
            vLwtil1DemandeAction.top_affect     	 	 = top_affect;
            vLwtil1DemandeAction.top_suppr     	 	     = top_suppr;

			vLwtil1Demande.critere_select = vLwtil1DemandeCritere;
			vLwtil1Demande.action 		  = vLwtil1DemandeAction;
			vLwtil1.demande = vLwtil1Demande;

			jwlwtil1.setNwlwtil1Awlwtil1 (vLwtil1);
			
		    // CALL SERVER
		    jwlwtil1.nwlwtil1();
				                                
	        // Verification du code retour
			vWebent = jwlwtil1.getNwlwtil1Axwebent();
			System.out.println("Code retour nwlwtil1() = " + 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
				Jwlwtil1.Nwlwtil1Awlwtil1_tab vWeblsttab = jwlwtil1.getNwlwtil1Awlwtil1_tab();
				
				//Affichage de la liste des resultats
				if(PRINT == "YES") {
					
					System.out.println("\n");
					for(int i = 0; i < new BigDecimal(nbrep).intValue(); i++){
							System.out.println (
									  "  cd_cible=" 	+ vWeblsttab.ligne_ref[i].cd_cible
									+ "; code_titre="   + vWeblsttab.ligne_ref[i].code_titre
									+ "; nom_titre=" 	+ vWeblsttab.ligne_ref[i].nom_titre 
									+ "; cd_zpo=" 	    + vWeblsttab.ligne_ref[i].cd_zpo 
									+ "; type_portage=" + vWeblsttab.ligne_ref[i].type_portage
									+ "; zpo_libelle=" 	+ vWeblsttab.ligne_ref[i].zpo_libelle
									+ "; nb_zones=" 	+ vWeblsttab.ligne_ref[i].nb_zones 
									+ "; nb_trt_n=" 	+ vWeblsttab.ligne_ref[i].nb_trt_n
									+ "; type_trt_n=" 	+ vWeblsttab.ligne_ref[i].type_trt_n
									+ "; nb_trt_r=" 	+ vWeblsttab.ligne_ref[i].nb_trt_r
									+ "; nb_trt_r=" 	+ vWeblsttab.ligne_ref[i].nb_trt_r
									+ "; type_trt_r=" 	+ vWeblsttab.ligne_ref[i].type_trt_r
									+ "; type_trt=" 	+ vWeblsttab.ligne_ref[i].type_trt
									+ "; lib_trt=" 	    + vWeblsttab.ligne_ref[i].lib_trt
									+ "; top_select_affect=" + vWeblsttab.ligne_ref[i].top_select_affect
									+ "; top_select_suppr="  + vWeblsttab.ligne_ref[i].top_select_suppr
									);
							System.out.println("\n");
					}
					//Affichage des informations de pagination
					System.out.println ("nb_rep_rendues : "    + jwlwtil1.getNwlwtil1Axweblst().nb_rep_rendues);
					System.out.println ("num_page_rendue : "   + jwlwtil1.getNwlwtil1Axweblst().num_page_rendue);
					System.out.println ("top_page_suivante : " + jwlwtil1.getNwlwtil1Axweblst().top_page_suivante);
					System.out.println ("nb_pages_totales : "  + jwlwtil1.getNwlwtil1Axweblst().nb_pages_totales);
				}
			}
			return jwlwtil1;
			
	   } // End getListeTitres

		/**
		 * <p>Titre : main</p>
		 * <p>Description : Programme principal de tests</p>
		 * <p>Copyright : Copyright (c) 2013</p>
		 * <p>Societe : ENSOR</p>
		 * @author AR & DR & PY <i>24/01/2013</i>
		 * @version 1.0
		 */
	   	public static void main(String[] args) throws BrokerException {
			Constantes.loadProperties("LW") ;
			JxweblogWeb.setUtilisateur ("MADAA02");
			JxweblogWeb.setPassword ("MADAA82");
			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 		= "20";
			String page 		= "1";
			String fonction 	= "I";
			String f_cible_grppres_stegrp 	= null;
			String f_code_titre 			= null;
			String f_filtre_ext 			= null;
			String f_cd_zpo 				= null;
			String f_type_portage 			= null;
			String f_zpo_libelle 			= null;
			String f_cd_zpo_affect 			= null;
			String f_type_portage_affect 	= null;
			String f_localite_affect 		= null;
			String f_cd_insee_affect 		= null;
			String f_code_postal_affect 	= null;
			String f_type_trt_affect 		= null;
			String f_cle_reprise 		    = null;
			String f_nom_titre_affect 		= null;
			String top_affect 				= null;
			String top_suppr 				= null;
			//--------------------Donnee test------------------
			getListeTitres(nbrep, page, fonction, f_code_titre, f_filtre_ext, f_cd_zpo, f_type_portage,
					f_zpo_libelle, f_cd_zpo_affect, f_type_portage_affect, f_localite_affect,
					f_cd_insee_affect, f_code_postal_affect, f_type_trt_affect,f_cible_grppres_stegrp,f_cle_reprise,f_nom_titre_affect, 
					top_affect,top_suppr,
					groupe_exploitant, numero_session, utilisateur, cd_cible, cd_stegrp, broker);
											
			JxweblogWeb.closeConnexion (jxweblog);
	   }
} // END Jwlwtil1Web