4 /** Libera la memoria ocupada por un widget
6 * \param w Widget a liberar
8 static void widget_free(t_Widget *w);
9 /** Crea un nuevo campo de entrada de texto
11 * \param tipo Debe ser INPUT
12 * \param nombre Nombre del control (también usada como etiqueta).
13 * \param max Cantidad máxima de caracteres.
14 * \param defecto Valor inicial del campo.
16 static t_Widget *widget_input_create(t_Campo tipo, const char *nombre, unsigned int max, const char *defecto);
17 /** Crea un nuevo RADIO Group
19 * \param tipo Debe ser RADIO
20 * \param nombre Nombre del campo
21 * \param max Cantidad de opciones
22 * \param valores Texto separado con comas con las opciones
24 static t_Widget *widget_radio_create(t_Campo tipo, const char *nombre, unsigned int max, const char *valores);
25 /** Ejecuta una consulta sobre un INPUT
27 * Permite ingresar texto en el INPUT hasta que se presiona ENTER
29 static int form_input(WINDOW *win, int x, int y, t_Widget *w);
30 /** Ejecuta una consulta sobre un RADIO
32 * Permite seleccionar una de las múltiples opciones del control.
33 * Para seleccionar se utilizan las feclas <- y -> y ENTER
36 static int form_radio(WINDOW *win, int x, int y, t_Widget *w);
38 t_Form *form_crear(WINDOW *win)
40 t_Form *tmp = (t_Form *)malloc(sizeof(t_Form));
41 tmp->primero = tmp->ultimo = NULL;
44 /* TODO : El error se debe verificar afuera? */
48 int form_destruir(t_Form *f)
50 t_Widget *tmp = f->primero;
53 f->primero = f->primero->sig;
61 void form_agregar_widget(t_Form *f, t_Campo tipo, const char *nombre, unsigned int max, const char *defecto)
65 /* Creo el nuevo widget segun el tipo */
68 tmp = widget_input_create(tipo, nombre, max, defecto);
71 tmp = widget_radio_create(tipo, nombre, max, defecto);
74 /* Si se creo wl widget, lo agrego al formulario al final */
76 if (f->primero == NULL) {
77 f->primero = f->ultimo = tmp;
85 void form_ejecutar(t_Form *f, int x, int y)
87 int offset = 0, my_y, salida;
88 t_Widget *tmp = f->primero;
90 /* Pongo las etiquetas de los campos, y me fijo el mayor offset */
93 mvwaddstr(f->win, my_y, x, tmp->nombre);
96 if (strlen(tmp->nombre) > offset)
97 offset = strlen(tmp->nombre);
101 /* Agrego el ": " al offset*/
108 wmove(f->win, my_y, x);
109 salida = tmp->ejecutar(f->win, x, my_y, tmp);
114 char *form_obtener_valor(t_Form *f, const char *widget)
116 /* Busco el widget */
117 t_Widget *tmp = f->primero;
119 if (strcmp(widget, tmp->nombre) == 0) {
124 return tmp->opciones[tmp->actual];
129 /* No hay nada. TODO : Retornar NULL? */
133 t_Widget *widget_input_create(t_Campo tipo, const char *nombre, unsigned int max, const char *defecto)
135 t_Widget *tmp = (t_Widget *)malloc(sizeof(t_Widget));
138 tmp->nombre = (char *)malloc(sizeof(char)*(strlen(nombre)+1));
139 strcpy(tmp->nombre, nombre);
142 tmp->valor = (char *)malloc(sizeof(char)*(max+1));
143 tmp->valor[0] = '\0';
144 strncpy(tmp->valor, defecto, max);
148 tmp->ejecutar = form_input;
149 tmp->destruir = widget_free;
153 t_Widget *widget_radio_create(t_Campo tipo, const char *nombre, unsigned int max, const char *valores)
155 int ini, fin, actual;
156 t_Widget *tmp = (t_Widget *)malloc(sizeof(t_Widget));
159 tmp->nombre = (char *)malloc(sizeof(char)*(strlen(nombre)+1));
160 strcpy(tmp->nombre, nombre);
163 tmp->opciones = (char **)malloc(sizeof(char*)*(max));
164 /* Parseo VALOR separado por comas */
168 while (valores[fin] != '\0') {
169 if (valores[fin] == ',') {
170 tmp->opciones[actual] = (char *)malloc(sizeof(char)*(fin-ini+1));
171 strncpy(tmp->opciones[actual], valores+ini, fin-ini);
172 tmp->opciones[actual][fin-ini] = '\0';
180 /* Me queda el ultimo elemento */
181 tmp->opciones[actual] = (char *)malloc(sizeof(char)*(fin-ini+1));
182 strncpy(tmp->opciones[actual], valores+ini, fin-ini);
183 tmp->opciones[actual][fin-ini] = '\0';
185 tmp->ejecutar = form_radio;
186 tmp->destruir = widget_free;
190 void widget_free(t_Widget *w)
199 for(i=0; i<w->max; i++)
200 free(w->opciones[i]);
206 int form_input(WINDOW *win, int x, int y, t_Widget *w)
208 char *tmp = w->valor;
210 mvwaddstr(win, y, x, w->valor);
212 while ((*tmp) != '\0') {
217 while ((c=getch()) != 13) {
218 /* Verifico si se apreto basckspace */
219 if (c == KEY_BACKSPACE) {
221 w->valor[current--] = '\0';
223 wmove(win, y, x+current);
225 /* Este va para dejar el cursor bien, ya que addch mueve el cursor*/
226 wmove(win, y, x+current);
229 /* Si no entra mas, ignoro toda entrada */
230 if (current >= w->max) continue;
232 wmove(win, y, x+current);
234 w->valor[current++] = c;
236 /* Cierro el string con el \0 */
237 w->valor[current+1] = '\0';
239 /* Retorno la tecla con la que se salio. */
240 /* De esa forma, ESC pasa al campo anterios. ENTER al siguiente */
244 int form_radio(WINDOW *win, int x, int y, t_Widget *w)
246 /* Por ahora solo pongo las cosas y me voy */
247 int i, actual, _x, c;
248 /* Array de posiciones para las Xs */
249 int xs[100]; /* TODO : Dinamizar!! */
254 for(i=0; i<w->max; i++) {
255 waddch(win, '('); _x++;
256 waddch(win, ' '); xs[i] = _x; _x++;
257 waddch(win, ')'); _x++;
258 waddstr(win, w->opciones[i]); _x += strlen(w->opciones[i]);
259 waddch(win, ' '); _x++;
263 wmove(win, y, xs[actual]);
266 while ((c=getch()) != 13) {
268 wmove(win, y, xs[actual]);
271 if (actual < 0) actual = 0;
272 wmove(win, y, xs[actual]);
275 if (c == KEY_RIGHT) {
276 wmove(win, y, xs[actual]);
279 if (actual >= w->max) actual = w->max-1;
280 wmove(win, y, xs[actual]);