From: Ricardo Markiewicz Date: Fri, 16 Apr 2004 04:35:38 +0000 (+0000) Subject: * Interfaz de carga (solo Alta) de facturas X-Git-Tag: svn_import_r684~466 X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/commitdiff_plain/7c2f319760d15120f4dd6f7f61217d830490e4d6 * Interfaz de carga (solo Alta) de facturas * Otras modificaciones para poder hacer la alta. --- diff --git a/emufs_gui/facturas.c b/emufs_gui/facturas.c index 1e77446..d37f943 100644 --- a/emufs_gui/facturas.c +++ b/emufs_gui/facturas.c @@ -188,9 +188,7 @@ t_LstFacturas *fact_cargar(const char *filename, int tipo, int tam_bloque) save = procesar_guardar_factura(&fact, lst_facturas, &size); if (save != NULL) { id = tmp->fp->grabar_registro(tmp->fp, save, size, &error); - fprintf(stderr, "Voy a grabar el texto [%d]\n", strlen(fact.nota)); id_texto = tmp->fp_texto->grabar_registro(tmp->fp_texto, fact.nota, 400, &error); - fprintf(stderr, "Todo ok : ID=%lu , txtID=%lu\n", id, id_texto); agregar_nodo_factura(tmp, crear_nodo_factura(id, id_texto, fact.numero)); free(save); } @@ -230,38 +228,151 @@ int fact_liberar(t_LstFacturas *l) return 0; } +void fact_agregar(char *s) +{ + WINDOW *win, *items; + t_Form *form; + t_Item *its = NULL; + t_Factura fact; + EMUFS_REG_SIZE size; + EMUFS_REG_ID id, id_texto; + int y_actual, cant, error; + char *entrada; + + win = newwin(LINES-4, COLS-2, 2, 1); + box(win, 0, 0); + mvwaddch(win, 10, 0, ACS_LTEE); + mvwhline(win, 10, 1, ACS_HLINE, COLS-3); + mvwaddch(win, 10, COLS-3, ACS_RTEE); + wrefresh(win); + + items = derwin(win, LINES-20, COLS-4, 15, 1); + wrefresh(items); + + form = form_crear(win); + form_agregar_widget(form, INPUT, "Numero de Factura", 8, ""); + form_agregar_widget(form, INPUT, "Fecha Emision", 8, ""); + form_agregar_widget(form, INPUT, "Fecha Vto", 8, ""); + form_agregar_widget(form, INPUT, "Nro Remito", 8, ""); + form_agregar_widget(form, RADIO, "Estado", 6, "PN,CD,CM,SF,PM,NC"); + form_agregar_widget(form, RADIO, "Forma de pago", 3, "CO,CR,CH"); + form_agregar_widget(form, INPUT, "%% Descuento", 5, ""); + form_agregar_widget(form, INPUT, "Cuenta Cte", 5, ""); + form_agregar_widget(form, INPUT, "Cheque Nro", 18, ""); + + form_ejecutar(form, 1,1); + + fact.numero = form_obtener_valor_int(form, "Numero de Factura"); + strcpy(fact.emision, form_obtener_valor_char(form, "Fecha Emision")); + strcpy(fact.vencimiento, form_obtener_valor_char(form, "Fecha Vto")); + fact.numero_remito = form_obtener_valor_int(form, "Nro Remito"); + strcpy(fact.estado, form_obtener_valor_char(form, "Estado")); + strcpy(fact.fp, form_obtener_valor_char(form, "Forma de pago")); + fact.procdoi = form_obtener_valor_float(form, "%% Descuento"); + strcpy(fact.ctacte, form_obtener_valor_char(form, "Cuenta Cte")); + strcpy(fact.cheque, form_obtener_valor_char(form, "Cheque Nro")); + + form_destruir(form); + + form = form_crear(win); + form_agregar_widget(form, INPUT, "Nro de Articulo (* == fin)", 8, ""); + form_agregar_widget(form, INPUT, "CV", 8, ""); + form_agregar_widget(form, INPUT, "PVU", 8, ""); + y_actual = 0; + scrollok(items, 1); + mvwaddstr(win, 15, 2, "Numero"); + mvwaddstr(win, 15, 11, "CV"); + mvwaddstr(win, 15, 21, "PVU"); + do { + form_set_valor(form, "Nro de Articulo (* == fin)", ""); + form_set_valor(form, "CV", ""); + form_set_valor(form, "PVU", ""); + form_ejecutar(form, 2, 11); + + entrada = form_obtener_valor_char(form, "Nro de Articulo (* == fin)"); + + if (entrada[0] != '\0') { + y_actual++; + if (y_actual > LINES-22) { + y_actual = LINES-22; + wscrl(items, 1); + } + mvwaddstr(items, y_actual, 1, entrada); + mvwaddstr(items, y_actual, 10, form_obtener_valor_char(form, "CV")); + mvwaddstr(items, y_actual, 20, form_obtener_valor_char(form, "PVU")); + wrefresh(items); + /* Agrego el Item */ + cant++; + its = (t_Item *)realloc(its, cant*sizeof(t_Item)); + its[cant-1].numero = form_obtener_valor_int(form, entrada); + strcpy(its[cant-1].cv, form_obtener_valor_char(form, "CV")); + strcpy(its[cant-1].pvu, form_obtener_valor_char(form, "PVU")); + } + } while (strcmp(entrada, "*") != 0); + + if (lst_facturas->fp->tipo == 3) { + if (cant != 10) { + /* TODO Limitar en la GUI en lugar de truncar! */ + its = (t_Item *)realloc(its, 10*sizeof(t_Item)); + cant = 10; + } + } + fact.items = its; + fact.cant_items = cant; + + entrada = procesar_guardar_factura(&fact,lst_facturas, &size); + if (entrada) { + id = lst_facturas->fp->grabar_registro(lst_facturas->fp, entrada, size, &error); + /*id_texto = tmp->fp_texto->grabar_registro(tmp->fp_texto, fact.nota, 400, &error);*/ + /* TODO : -1 == id_texto !!!!!!!! XXX XXX XXX XXX XXX XXX XXX */ + agregar_nodo_factura(lst_facturas, crear_nodo_factura(id, -1, fact.numero)); + free(entrada); + } + + if (its) free(its); + form_destruir(form); + + werase(win); + wrefresh(win); + delwin(items); + delwin(win); +} void *procesar_guardar_factura(t_Factura *f, t_LstFacturas *lst, EMUFS_REG_SIZE *size) { char *tmp=NULL; - int i[9]; + int i[11]; switch (lst->fp->tipo) { case T1: case T2: /* Calculo el tamaƱo que voy a necesitar */ i[0] = sizeof(int); - i[1] = sizeof(char)*(strlen(f->emision)+1); /* +1 por el \0 para separar */ - i[2] = sizeof(char)*(strlen(f->vencimiento)+1); /* +1 por el \0 para separar */ + i[1] = sizeof(float); + i[2] = sizeof(int); i[3] = sizeof(int); - i[4] = sizeof(char)*(strlen(f->estado)+1); /* +1 por el \0 para separar */ - i[5] = sizeof(char)*(strlen(f->fp)+1); /* +1 por el \0 para separar */ - i[6] = sizeof(float); - i[7] = sizeof(char)*(strlen(f->ctacte)+1); /* +1 por el \0 para separar */ - i[8] = sizeof(char)*(strlen(f->cheque)+1); /* +1 por el \0 para separar */ - (*size) = i[0]+i[1]+i[2]+i[3]+i[4]+i[5]+i[6]+i[7]+i[8]; + i[4] = sizeof(char)*(strlen(f->emision)+1); /* +1 por el \0 para separar */ + i[5] = sizeof(char)*(strlen(f->vencimiento)+1); /* +1 por el \0 para separar */ + i[6] = sizeof(char)*(strlen(f->estado)+1); /* +1 por el \0 para separar */ + i[7] = sizeof(char)*(strlen(f->fp)+1); /* +1 por el \0 para separar */ + i[8] = sizeof(char)*(strlen(f->ctacte)+1); /* +1 por el \0 para separar */ + i[9] = sizeof(char)*(strlen(f->cheque)+1); /* +1 por el \0 para separar */ + i[10] = sizeof(t_Item)*f->cant_items; + (*size) = i[0]+i[1]+i[2]+i[3]+i[4]+i[5]+i[6]+i[7]+i[8]+i[9]+i[10]; tmp = (char *)malloc(*size); if (tmp == NULL) return NULL; /* Ahora copio la info */ memcpy(tmp, &f->numero, i[0]); - memcpy(tmp+i[0], f->emision, i[1]); - memcpy(tmp+i[0]+i[1], f->vencimiento, i[2]); - memcpy(tmp+i[0]+i[1]+i[2], &f->numero_remito, i[3]); - memcpy(tmp+i[0]+i[1]+i[2]+i[3], f->estado, i[4]); - memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4], f->fp, i[5]); - memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4]+i[5], &f->procdoi, i[6]); - memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4]+i[5]+i[6], f->ctacte, i[7]); - memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4]+i[5]+i[6]+i[7], f->cheque, i[8]); + memcpy(tmp, &f->procdoi, i[1]); + memcpy(tmp, &f->numero_remito, i[2]); + memcpy(tmp, &f->cant_items, i[3]); + memcpy(tmp+i[0]+i[1]+i[2]+i[3], f->emision, i[4]); + memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4], f->vencimiento, i[5]); + memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4]+i[5], f->estado, i[6]); + memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4]+i[5]+i[6], f->fp, i[7]); + memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4]+i[5]+i[6]+i[7], f->ctacte, i[8]); + memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4]+i[5]+i[6]+i[7]+i[8], f->cheque, i[9]); + memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4]+i[5]+i[6]+i[7]+i[8]+i[9], f->items, i[10]); break; case T3: (*size) = sizeof(t_Factura)-sizeof(char *)-sizeof(t_Item *) + f->cant_items*sizeof(t_Item); diff --git a/emufs_gui/facturas.h b/emufs_gui/facturas.h index 1f65e63..ffb4995 100644 --- a/emufs_gui/facturas.h +++ b/emufs_gui/facturas.h @@ -3,10 +3,12 @@ #define _FACTURAS_H_ #include "emufs.h" +#include "form.h" #include #include #include #include +#include #include #include @@ -50,5 +52,7 @@ typedef struct _lista_facturas_ { t_LstFacturas *fact_cargar(const char *filename, int tipo, int tam_bloque); int fact_liberar(t_LstFacturas *l); +void fact_agregar(char *s); + #endif diff --git a/emufs_gui/form.c b/emufs_gui/form.c index 9e5cb57..b8907a0 100644 --- a/emufs_gui/form.c +++ b/emufs_gui/form.c @@ -92,7 +92,7 @@ void form_agregar_widget(t_Form *f, t_Campo tipo, const char *nombre, unsigned i void form_ejecutar(t_Form *f, int x, int y) { - int offset = 0, my_y, salida; + int offset = 0, my_y, salida, i; t_Widget *tmp = f->primero; my_y = y-1; @@ -115,8 +115,20 @@ void form_ejecutar(t_Form *f, int x, int y) mvwaddstr(f->win, my_y, x, tmp->nombre); waddch(f->win, ':'); waddch(f->win, ' '); - /* TODO : VER QUE SI ES UNA OPCION ES DISTINTO!! */ - mvwaddstr(f->win, my_y, x+offset, tmp->valor); + if (tmp->tipo == INPUT){ + for(i=0; imax; i++) + mvwaddch(f->win, my_y, x+offset+i, ' '); + mvwaddstr(f->win, my_y, x+offset, tmp->valor); + } else { + wmove(f->win, my_y, x+offset); + for(i=0; imax; i++) { + waddch(f->win, '('); + waddch(f->win, ' '); + waddch(f->win, ')'); + waddstr(f->win, tmp->opciones[i]); + waddch(f->win, ' '); + } + } tmp = tmp->sig; } wrefresh(f->win); @@ -371,3 +383,16 @@ void form_es_modificable(t_Form *f, const char *widget, int b) } } +void form_set_valor(t_Form *f, const char *widget, const char *s) +{ + /* Busco el widget */ + t_Widget *tmp = f->primero; + while (tmp) { + if (strcmp(widget, tmp->nombre) == 0) { + strcpy(tmp->valor, s); + break; + } + tmp = tmp->sig; + } +} + diff --git a/emufs_gui/form.h b/emufs_gui/form.h index 3b5bd57..3b8c531 100644 --- a/emufs_gui/form.h +++ b/emufs_gui/form.h @@ -101,6 +101,8 @@ void form_ejecutar(t_Form *f, int x, int y); */ void form_es_modificable(t_Form *f, const char *widget, int b); +void form_set_valor(t_Form *f, const char *widget, const char *s); + /** Obtiene el valor asociado a un campo como char * * * \param f Formulario. diff --git a/emufs_gui/gui.c b/emufs_gui/gui.c index 86f7eed..84837c2 100644 --- a/emufs_gui/gui.c +++ b/emufs_gui/gui.c @@ -18,6 +18,8 @@ static void finish(int sig); int main_menu(); void menu_articulos(); +void menu_facturas(); + /* cuadro de msg. w y h son de la ventana padre */ WINDOW *msg_box(WINDOW *win, int w, int h, const char *format, ...); void msg_box_free(WINDOW *padre, WINDOW *win); @@ -147,7 +149,9 @@ int main(int argc, char *argv[]) case 0: menu_articulos(); break; - // case 1: + case 1: + menu_facturas(); + break; case 2: dialog = derwin(stdscr, LINES-4, COLS-2, 2, 1); ver_registros(dialog, COLS-2, LINES-4); @@ -172,6 +176,92 @@ int main(int argc, char *argv[]) return 0; } +void menu_facturas() +{ + WINDOW *menu_win; + MENU *menu; + ITEM **items; + int c, salir; + char *opciones[] = { + "Alta", + "Baja", + "Modificacion", + "Volver" + }; + + items = (ITEM **)calloc(5, sizeof(ITEM *)); + + items[0] = new_item(opciones[0], "Crear una nueva factura."); + set_item_userptr(items[0], fact_agregar); + items[1] = new_item(opciones[1], "Eliminar una factura existente."); +/* set_item_userptr(items[1], art_eliminar); */ + items[2] = new_item(opciones[2], "Modificar una factura existente."); +/* set_item_userptr(items[2], art_modificar); */ + items[3] = new_item(opciones[3], "Volver al menu anterior."); + items[4] = NULL; + + menu = new_menu((ITEM **)items); + menu_win = newwin(8, COLS-2, 3, 1); + keypad(menu_win, TRUE); + set_menu_mark(menu, " > "); + set_menu_win(menu, menu_win); + set_menu_sub(menu, derwin(menu_win, 5, COLS-4, 3, 1)); + + box(menu_win, 0, 0); + mvwaddch(menu_win, 2, 0, ACS_LTEE); + mvwhline(menu_win, 2, 1, ACS_HLINE, COLS-3); + mvwaddch(menu_win, 2, COLS-3, ACS_RTEE); + wattron(menu_win, COLOR_PAIR(COLOR_RED)); + mvwaddstr(menu_win, 1, 1, "Menu Facturas"); + wattroff(menu_win, COLOR_PAIR(COLOR_RED)); + post_menu(menu); + wrefresh(menu_win); + + curs_set(0); + salir = 0; + while((!salir) && (c = getch()) != KEY_F(3)) { + switch(c) { + case KEY_DOWN: + menu_driver(menu, REQ_DOWN_ITEM); + break; + case KEY_UP: + menu_driver(menu, REQ_UP_ITEM); + break; + case 13: + case 10: { + ITEM *cur; + void (*p)(char *); + + cur = current_item(menu); + if (strcmp(item_name(cur), opciones[3]) == 0) { + salir = 1; + } else { + p = item_userptr(cur); + unpost_menu(menu); + refresh(); + p(NULL); /* Paso NULL para que ejecute la accion por defecto */ + post_menu(menu); + box(menu_win,0,0); + mvwaddch(menu_win, 2, 0, ACS_LTEE); + mvwhline(menu_win, 2, 1, ACS_HLINE, 67); + mvwaddch(menu_win, 2, 67, ACS_RTEE); + wrefresh(menu_win); + } + pos_menu_cursor(menu); + } + } + wrefresh(menu_win); + } + curs_set(1); + + unpost_menu(menu); + delwin(menu_win); + free_item(items[0]); + free_item(items[1]); + free_item(items[2]); + free_item(items[3]); + free_menu(menu); +} void menu_articulos() { WINDOW *menu_win;