X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/b0016860bf31077b5dd026bd0bce16147dcef62d..3f9973797bd5e6552493d2c2c4e1b94b23f9a636:/emufs_gui/gui.c?ds=sidebyside diff --git a/emufs_gui/gui.c b/emufs_gui/gui.c index 6edd113..79ea648 100644 --- a/emufs_gui/gui.c +++ b/emufs_gui/gui.c @@ -3,13 +3,14 @@ #include #include #include -#include #include +#include #include "form.h" #include "articulos.h" #include "facturas.h" #include "emufs.h" +#include "registros.h" #define CTRLD 4 @@ -17,16 +18,47 @@ static void finish(int sig); int main_menu(); void menu_articulos(); +/* 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); + +/* Verifica Argumentos */ +int param_ok(int argc, char *argv[]) +{ + int n; + switch (argc) { + case 1: + return 1; + case 2: + if (strcmp("-h", argv[1]) == 0) { + return 0; + } + case 3: + n = atoi(argv[2]); + if ((n<1) || (n>3)) + return 0; + } + return 1; +} + +void print_help(char *s) +{ + printf("EMUFS - 1v0\n"); + printf("Modo de uso : %s [ tipo=[1|2|3]]\n", s); + printf("\nSi especifica un archivo XML desde donde cargar los articulos debera tambien especificar el tipo"); + printf(" de archivo a crear, siendo 1, 2, 3\n"); +} int main(int argc, char *argv[]) { int c, fin=0; -/* - art_cargar(argv[1]); + WINDOW *dialog; + + if (!param_ok(argc, argv)) { + print_help(argv[0]); + return -1; + } - art_liberar(NULL); - return 1; -*/ /* Inicio Curses */ signal(SIGINT, finish); initscr(); @@ -55,12 +87,6 @@ int main(int argc, char *argv[]) return 1; } - if (argc == 2) { - art_cargar(argv[1]); - fact_cargar(argv[1]); - } else - art_cargar(NULL); - /* Ventana, caracter para linea vertical, caracter para linea horizontal*/ box(stdscr, ACS_VLINE, ACS_HLINE); /* Ventana, Y, X, Texto */ @@ -70,6 +96,15 @@ int main(int argc, char *argv[]) attroff(COLOR_PAIR(2)); wrefresh(stdscr); + dialog = msg_box(stdscr, COLS, LINES, "Generando archivos ..."); + if (argc == 3) { + art_cargar(argv[1], atoi(argv[2])); + fact_cargar(argv[1]); + } else + art_cargar(NULL, -1); + + msg_box_free(stdscr, dialog); + /* CICLO PRINCIPAL DE LA APLICACION */ while ((c = main_menu()) != -1) { switch (c) { @@ -77,9 +112,16 @@ int main(int argc, char *argv[]) menu_articulos(); break; // case 1: - // case 2: + case 2: + dialog = derwin(stdscr, LINES-4, COLS-2, 2, 1); + ver_registros(dialog, COLS-2, LINES-4); + werase(dialog); + wrefresh(dialog); + delwin(dialog); + refresh(); + break; // case 3: - case 4: + case 6: fin = 1; break; } @@ -157,7 +199,7 @@ void menu_articulos() p = item_userptr(cur); unpost_menu(menu); refresh(); - p((char *)item_name(cur)); + 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); @@ -192,24 +234,28 @@ int main_menu() "Facturas", "Ver Registros", "Ver Bloques", + "Estadisticas", + "Mantenimiento", "Salir" }; - items = (ITEM **)calloc(5, sizeof(ITEM *)); + items = (ITEM **)calloc(8, sizeof(ITEM *)); items[0] = new_item(opciones[0], "Alta,baja,consulta y modificacion de articulos."); items[1] = new_item(opciones[1], "Alta,baja,consulta y modificacion de facturas."); items[2] = new_item(opciones[2], "Ver registros de un archivo."); items[3] = new_item(opciones[3], "Ver bloques de un archivo."); - items[4] = new_item(opciones[4], "Salir del sistema."); - items[5] = NULL; + items[4] = new_item(opciones[4], "Ver estadisticas de ocupacion de archivos."); + items[5] = new_item(opciones[5], "Tareas de mantenimiento de los archivos."); + items[6] = new_item(opciones[6], "Salir del sistema."); + items[7] = NULL; menu = new_menu((ITEM **)items); - menu_win = newwin(9, COLS-2, 3, 1); + menu_win = newwin(14, 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, 6, COLS-4, 3, 1)); + set_menu_sub(menu, derwin(menu_win, 10, COLS-4, 3, 1)); box(menu_win, 0, 0); mvwaddch(menu_win, 2, 0, ACS_LTEE); @@ -239,7 +285,7 @@ int main_menu() int i; cur = current_item(menu); - for(i=0; i<5; ++i) { + for(i=0; i<7; ++i) { if (strcmp(item_name(cur), opciones[i]) == 0) opcion = i; } @@ -259,6 +305,9 @@ int main_menu() free_item(items[1]); free_item(items[2]); free_item(items[3]); + free_item(items[4]); + free_item(items[5]); + free_item(items[6]); free_menu(menu); return opcion; @@ -273,3 +322,32 @@ static void finish(int sig) exit(0); } +WINDOW *msg_box(WINDOW *win, int w, int h, const char *format, ...) +{ + va_list ap; + char txt[255]; + int mw, mh; + WINDOW *dialog; + va_start(ap, format); + vsprintf(txt, format, ap); + va_end(ap); + + mw = strlen(txt)+2; + mh = 3; + dialog = derwin(win, mh, mw, h/2-mh/2, w/2-mw/2); + box(dialog, 0 ,0); + mvwaddstr(dialog, 1, 1, txt); + wrefresh(dialog); + curs_set(0); + return dialog; +} + +void msg_box_free(WINDOW *padre, WINDOW *win) +{ + werase(win); + wrefresh(win); + delwin(win); + curs_set(1); + wrefresh(padre); +} +