Muestra las diferencias entre dos versiones de la página.
| Ambos lados, revisión anterior Revisión previa Próxima revisión | Revisión previa | ||
|
ada:sicoferp:financiero:tesoreria:conciliacionbancaria:conciliacioncargadedatos [2026/05/08 13:16] brahian.castaneda |
ada:sicoferp:financiero:tesoreria:conciliacionbancaria:conciliacioncargadedatos [2026/06/12 12:47] (actual) brahian.castaneda |
||
|---|---|---|---|
| Línea 335: | Línea 335: | ||
| using sqlca; | using sqlca; | ||
| - | === Desarrollado por: [Miguel Muñoz] Fecha: [28/04/2026] Versión de PB: 12.5 === | + | === Desarrollado por: [Miguel Muñoz] Fecha: [28/04/2026] Versión de PB: 12.5 === |
| + | |||
| + | ===== Optimización en la Conciliación Bancaria - Estado "Completa" (w_conciliacion_bancos.srw) ===== | ||
| + | |||
| + | Fecha: 2024-05-28 Autor: Gemini Code Assist (asistente de desarrollo) Componente Afectado: w_conciliacion_bancos.srw (Ventana de Conciliación Bancaria) Versión de PowerBuilder: 12.5 | ||
| + | |||
| + | === 1. Descripción del Problema Original === | ||
| + | |||
| + | El proceso de conciliación bancaria presentaba un comportamiento incorrecto: | ||
| + | |||
| + | Una conciliación no se marcaba automáticamente como "Completa" (estado = 'C') cuando no existían movimientos para conciliar (es decir, ni registros del extracto bancario ni movimientos manuales). | ||
| + | Incluso si se lograba un estado inicial de 'C', la lógica posterior podía revertir el estado a "Incompleta" (estado = 'I') si no se detectaban registros marcados como conciliados, lo cual ocurría en escenarios sin movimientos. Este comportamiento afectaba la correcta gestión y el cierre de los periodos de conciliación, obligando a intervenciones manuales o dejando conciliaciones vacías en estado "Incompleta". | ||
| + | |||
| + | === 2. Causas Raíz Identificadas === | ||
| + | |||
| + | Se identificaron dos causas principales que contribuían al problema: | ||
| + | |||
| + | Bloqueo por il_rows_import: El evento ue_grabar de la ventana w_conciliacion_bancos.srw contenía una condición If il_rows_import > 0 Then al inicio del proceso de guardado. Si no se había importado un archivo de extracto (y por ende il_rows_import era 0), toda la lógica de determinación del estado y guardado de la conciliación se omitía, resultando en un MessageBox de advertencia y un estado incorrecto. Esto impedía que conciliaciones sin movimientos de extracto pudieran ser finalizadas como "Completas". | ||
| + | |||
| + | Reversión Incondicional del Estado a 'I': Existía un bloque de código que, tras evaluar los totales de las DataWindows, verificaba si había algún movimiento marcado como conciliado (conciliado = 1 o conciliatoria = 'S'). Si no encontraba ninguno en ninguna de las DataWindows de movimientos, revertía el estado de la conciliación a 'I', incluso si no había movimientos que conciliar en primer lugar (lo que se consideraría una conciliación completa por ausencia de elementos). | ||
| + | |||
| + | === 3. Solución Implementada === | ||
| + | |||
| + | Se modificó el evento ue_grabar en w_conciliacion_bancos.srw para abordar las causas identificadas: | ||
| + | |||
| + | Introducción de lb_any_movements_loaded: Se agregó una nueva variable booleana, lb_any_movements_loaded, que verifica si existe cualquier movimiento (ya sea de tesorería o de extracto, coincidente o incoincidente) cargado en las DataWindows de conciliación. Esta verificación es más robusta que il_rows_import. | ||
| + | |||
| + | Lógica de Determinación de Estado Condicional: | ||
| + | |||
| + | Si lb_any_movements_loaded es False (es decir, no hay movimientos en absoluto para conciliar), el estado ls_estado se establece directamente como 'C' (Completa). Esto permite que las conciliaciones "vacías" se marquen correctamente como completas. | ||
| + | Si lb_any_movements_loaded es True (hay movimientos), se ejecuta la lógica existente de comparación de totales y verificación de conciliación para determinar si el estado debe ser 'C' o 'I'. | ||
| + | Eliminación del Bloqueo por il_rows_import: La condición If il_rows_import > 0 Then que encapsulaba gran parte de la lógica de guardado fue eliminada. Esto asegura que el proceso de guardado y determinación del estado siempre se ejecute, independientemente de si se importó un archivo de extracto. | ||
| + | |||
| + | Remoción del Bloque de Reversión Incondicional: El segmento de código que revertía el estado a 'I' si no se encontraban elementos conciliados fue comentado y efectivamente eliminado. Con la nueva lógica, la determinación del estado ('C' o 'I') ya se realiza de forma anticipada y precisa, haciendo este bloque redundante y perjudicial. | ||
| + | |||
| + | === Desarrollado por: [Miguel Muñoz] Fecha: [12/05/2026] Versión de PB: 12.5 === | ||
| + | |||
| + | ===== Mejora en Conciliación Bancaria Manual ===== | ||
| + | |||
| + | === 1. Descripción General === | ||
| + | |||
| + | Se ha optimizado el proceso de conciliación bancaria manual en el objeto w_conciliacion_bancos. El cambio permite que el sistema cargue automáticamente las partidas conciliatorias (pendientes) del mes anterior sin necesidad de importar un archivo plano físico. | ||
| + | |||
| + | Anteriormente, cuando un periodo no tenía movimientos nuevos en libros ni en bancos, el sistema obligaba al usuario a cargar un archivo plano con valores en "cero" para poder visualizar y conciliar los saldos pendientes del mes anterior. | ||
| + | |||
| + | === 2. Problema Técnico ==== | ||
| + | |||
| + | La lógica que recuperaba los registros pendientes de la tabla MAE_CONCILIACION (donde conciliatoria = 'S') estaba encapsulada dentro de la función de importación dinámica de archivos. Si el usuario seleccionaba el modo Manual, esa ruta de código nunca se ejecutaba, resultando en una grilla de inconsistencias vacía a pesar de existir saldos por conciliar del periodo previo. | ||
| + | |||
| + | === 3. Solución Implementada === | ||
| + | |||
| + | 3.1. Nueva Función: wf_cargar_partidas_pendientes() | ||
| + | Se creó una función centralizada en la ventana para: | ||
| + | |||
| + | Identificar el periodo anterior (manejo de cambio de año en enero). | ||
| + | |||
| + | Consultar el código de conciliación del mes anterior en estado 'C' (Completada). | ||
| + | Recuperar los registros mediante el DataStore d_incoincidentes_extracto_ant. | ||
| + | Insertar dichos registros en el buffer de trabajo idw_datos_conciliacion del periodo actual. | ||
| + | |||
| + | 3.2. Cambio de Disparador (Trigger) | ||
| + | |||
| + | En lugar de depender del botón "Importar", la lógica ahora reside en el evento selectionchanged del control carpeta (Tab Control): | ||
| + | |||
| + | Momento de ejecución: Cuando el usuario hace clic en la pestaña 3 (Inconsistencias). | ||
| + | Condición de ejecución: Solo si el modo de conciliación es 'M' (Manual) y si aún no existen registros cargados en la base de datos para el periodo actual (SELECT COUNT preventivo). | ||
| + | Acción: Carga los pendientes, realiza un Update() automático a la base de datos y ejecuta el motor de conciliación (wf_conciliar_faltante) para cruzar los datos contra los libros contables. | ||
| + | 3.3. Mejoras en la Interfaz de Usuario (UI) | ||
| + | Cierre de Ventana Manual: Se modificó el evento clicked del DataWindow dw_datos_conciliacion para que los botones de "Cancelar" o "Cerrar" oculten correctamente el panel de captura, permitiendo al usuario retractarse sin quedar bloqueado. | ||
| + | Sincronización: Se añadieron comandos Retrieve explícitos al cambiar a la pestaña de Inconsistencias para asegurar que la grilla siempre refleje los datos guardados. | ||
| + | |||
| + | === 4. Impacto y Beneficios === | ||
| + | |||
| + | Eliminación de Procesos Manuales Externos: El usuario ya no debe crear archivos Excel/planos ficticios con valores en cero. | ||
| + | Integridad de Datos: Al automatizar la carga de pendientes al cambiar de pestaña, se reduce el riesgo humano de omitir saldos del mes anterior. | ||
| + | Eficiencia: El motor de conciliación automática ahora también procesa las partidas manuales apenas el usuario intenta ver los resultados. | ||
| + | |||
| + | === Desarrollado por: [Miguel Muñoz] Fecha: [12/06/2026] Versión de PB: 12.5 === | ||
| + | |||