X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/d381699312637624c1fa51dfdf0f2184636e498c..2349ad8039ce813d3a12da55574958c804aeae09:/emufs_gui/facturas.c diff --git a/emufs_gui/facturas.c b/emufs_gui/facturas.c index f1ce517..070f936 100644 --- a/emufs_gui/facturas.c +++ b/emufs_gui/facturas.c @@ -1009,7 +1009,7 @@ void fact_consultas_codigos(char *s) lista_agregar_columna(lista, "Numero", DATO_INT, 0, 8); /* numero */ lista_agregar_columna(lista, "Fecha", DATO_STR, 10, 9); /* emision */ lista_agregar_columna(lista, "Estado", DATO_STR, 20, 19); /* estado */ - lista_agregar_columna(lista, "Forma de Pago", DATO_STR, 40, 19); /* fp */ + lista_agregar_columna(lista, "F. Pago", DATO_STR, 40, 9); /* fp */ /* Leo los datos desde el archivo */ for(i=desde_codigo; i<=hasta_codigo; i++) { @@ -1036,6 +1036,126 @@ void fact_consultas_codigos(char *s) delwin(win); } +float get_importe_factura(t_Item *items, int cant, float interes) +{ + float a=0.0f; + int i; + for(i=0; ifp, "emision"); + if (idx==NULL) PERR("INDICE EMISION NO SE ENCUENTRA!!"); + if (strlen(desde_fecha) == 0) { + k_menor = idx->obtener_menor_clave(idx); + emufs_indice_obtener_valor_desde_clave(idx, k_menor, desde_fecha); + PERR("OBTUVE MENOR CLAVE DESDE EL INDICE"); + PERR(desde_fecha); + } + if (strlen(hasta_fecha) == 0) { + k_mayor = idx->obtener_mayor_clave(idx); + emufs_indice_obtener_valor_desde_clave(idx, k_mayor, hasta_fecha); + PERR("OBTUVE MAYOR CLAVE DESDE EL INDICE"); + PERR(hasta_fecha); + } + + /* Creo la lista donde mostrar la consulta*/ + /* Muestro solo info relevante */ + lista = lista_crear(4, win1, COLS-4, LINES-6); + + /* Creo las columnas */ + lista_agregar_columna(lista, "Numero", DATO_INT, 0, 8); /* numero */ + lista_agregar_columna(lista, "Fecha", DATO_STR, 10, 9); /* emision */ + lista_agregar_columna(lista, "Estado", DATO_STR, 20, 19); /* estado */ + lista_agregar_columna(lista, "F. Pago", DATO_STR, 40, 9); /* fp */ + lista_agregar_columna(lista, "Importe", DATO_FLOAT, 50, 8); /* importe */ + + /* Leo los datos desde el archivo */ + while (k_menor.i_clave != -1) { + t_Factura fact; + int error, cant, i; + char *leo; + EMUFS_REG_SIZE size; + INDICE_DATO *datos; + CLAVE k1; + datos = idx->buscar_entradas(idx, k_menor, &cant); + for(i=0; ifp->leer_registro(lst_facturas->fp, k1, &size, &error); + if (leo != NULL) { + procesar_leer_factura(&fact, leo, size, lst_facturas); + free(leo); + /*k.i_clave = fact->reg_nota; + error = 0; + fact->nota = lst->fp_texto->leer_registro(lst->fp_texto, k, &size, &error); + */ + } + if (strcmp(estado, "Todos") != 0) { + if (strcmp(estado, fact.estado) == 0) { + fprintf(stderr, "Agrego factura num=%d con %d items\n", fact.numero, fact.cant_items); + lista_agregar_fila_ordenada(lista, + fact.numero, + fact.emision, + get_estado(fact.estado), + get_forma_pago(fact.fp), + get_importe_factura(fact.items, fact.cant_items, fact.procdoi) + ); + } + } + } + if (datos) free(datos); + if (fact.items) free(fact.items); + k_menor = idx->obtener_sig_clave(idx, k_menor); + } + + curs_set(0); + lista_ejecutar(lista); + curs_set(1); + wrefresh(win1); + wrefresh(win); + werase(win1); + werase(win); + wrefresh(win); + delwin(win); +} + void fact_consultas_varias(char *nombre_indice, char *titulo) { int i, cant, error; @@ -1118,12 +1238,13 @@ void fact_consultas(char *s) MENU(mi_menu) { MENU_OPCION("por Codigos", "Consulta de Articulos por rango de codigo."), MENU_OPCION("por Fecha de Emision", "Consulta por fecha unica"), + MENU_OPCION("por Rango de Fecha", "Consulta por rando de fecha de emision"), MENU_OPCION("por Presentacion", "Consulta por Presentacion"), MENU_OPCION("Volver", "Volver al menu anterior.") }; int opt; - while ((opt = menu_ejecutar(mi_menu, 4, "Consulta de Articulos")) != 3) { + while ((opt = menu_ejecutar(mi_menu, 5, "Consulta de Articulos")) != 4) { switch (opt) { case 0: fact_consultas_codigos(s); @@ -1132,6 +1253,9 @@ void fact_consultas(char *s) fact_consultas_varias("emision", "Fecha"); break; case 2: + fact_consultas_fechas(s); + break; + case 3: fact_consultas_varias("presentacion", "Presentacion"); } }