View Javadoc

1   /*
2    * Created on 14/12/2004
3    * 
4    * Classe que implementa a interface PopUpPesquisa que é utilizada pelo template jsp
5    * popup_pesquisa.jsp
6    * 
7    * O template instancia essa classe utilizando os métodos definidos na interface.
8    * Assim o template pode ser usado para pesquisar e navegar em várias classes sem 
9    * precisar escrever um jsp específico para cada um.
10   * Basta criar uma classe que implementa a interface PopUpPesquisa e passá-la como
11   * parâmatro no momento de chamar a tela de pesquisa
12   * 
13   * A tela de pesquisa sempre retorna um código e uma descrição do que foi selecionado.
14   *
15   */
16  package ecar.popup;
17  
18  import java.util.List;
19  
20  import javax.servlet.http.HttpServletRequest;
21  
22  import comum.database.Dao;
23  import comum.util.Pagina;
24  
25  import ecar.dao.UfDao;
26  import ecar.exception.ECARException;
27  import ecar.pojo.Uf;
28  
29  /**
30   * @author garten
31   *
32   */
33  public class PopUpUf implements PopUpPesquisa {
34      
35  
36      // array de nomes de campos em que pode pesquisar
37      private String[] pesquisarEm;
38      
39      // declare o seu pojo e o Dao aqui
40      private Uf uf;
41      private UfDao ufDao;
42  
43      public PopUpUf(){
44          uf = new Uf();
45          ufDao = new UfDao(null);
46          this.setPesquisarEm(new String[] {"Descrição", "Código da Uf"});
47      }
48      
49      /**
50       * Devolve para o template jsp o Dao.<br>
51       * 
52       * @author N/C
53       * @since N/C
54       * @version N/C
55       * @return Dao
56       * @see ecar.popup.PopUpPesquisa#getDao()
57       */
58      public Dao getDao() {
59          return ufDao;
60      }
61      
62      /**
63       * Retorna String "Uf".<br>
64       * 
65       * @author N/C
66       * @since N/C
67       * @version N/C
68       * @return String
69       */
70      public String getTitulo(){
71          return "Uf";
72      }
73  
74      /**
75       * Recebe o argumento de pesquisa do template jsp e seta nos respectivos campos.<br>
76       * String arg - a string do argumento d pesquisa.<br>
77       * String[] pesquisarEm - um array de string com os nomes dos campos que devem ser pesquisados.<br>
78       * 
79       * @author N/C
80       * @since N/C
81       * @version N/C
82       * @param HttpServletRequest request
83       * @throws ECARException
84       */
85      public void setArgPesquisa(HttpServletRequest request) throws ECARException{
86      	String arg = Pagina.getParam(request, "hidArg");
87          String[] pesquisarEm = request.getParameterValues("hidPesquisarEm");
88          
89          if (pesquisarEm != null)
90  	        for (int i = 0; i < pesquisarEm.length; i++) {
91  	            if ("0".equals(pesquisarEm[i]))
92  	                uf.setDescricaoUf(arg);
93  	            
94  	            if ("1".equals(pesquisarEm[i]))
95  	                uf.setCodUf(arg);
96  	        }
97      }
98  
99      /**
100      * Efetua pesquisa de uf.<br>
101      * 
102      * @author N/C
103      * @since N/C
104      * @version N/C
105      * @return List
106      * @throws ECARException
107      */
108     public List pesquisar() throws ECARException {
109         return ufDao.pesquisar(uf, new String[] {"codUf", "asc"});
110     }
111     
112     /**
113      * Devolve para o template o codigo do radio button.<br>
114      * 
115      * @author N/C
116      * @since N/C
117      * @version N/C
118      * @return String
119      */
120     public String getCodigo() {
121         return uf.getCodUf();
122     }
123     
124     /**
125      * Devolve para o template a descricao.<br>
126      * 
127      * @author N/C
128      * @since N/C
129      * @version N/C
130      * @return String
131      */
132     public String getDescricao() {
133         return uf.getDescricaoUf();
134     }
135     
136     /**
137      * Recebe um objeto do template.<br>
138      * 
139      * @author N/C
140      * @since N/C
141      * @version N/C
142      * @param Object o
143      */
144     public void setPojo(Object o) {
145         uf = (Uf) o;
146     }
147 
148     /**
149      * Retorna para o template um array com os nomes para montar os checkbox.<br>
150      * 
151      * @author N/C
152      * @since N/C
153      * @version N/C
154      * @return String[] - (Returns the pesquisarEm)
155      */
156     public String[] getPesquisarEm() {
157         return pesquisarEm;
158     }
159 
160     /**
161      * Atribui internamente um array com os campos possiveis para a pesquisa.<br>
162      * 
163      * @author N/C
164      * @since N/C
165      * @version N/C
166      * @param String[] pesquisarEm - The pesquisarEm to set.
167      */
168     private void setPesquisarEm(String[] pesquisarEm) {
169         this.pesquisarEm = pesquisarEm;
170     }
171 }