✒️ABAP Los reportes interactivos
ABAP Los reportes interactivos
REPORTES INTERACTIVOS
1.- Qué es un reporte interactivo.
Es un tipo de reporte ABAP, donde se muestra un primer listado por pantalla, con cierta información y luego haciendo doble click a una línea determinada del primer listado, se accede a otros datos relativos a esta línea y así sucesivamente por cuantos niveles tenga el listado.
A diferencia del reporte clásico, que puede ser ejecutado tanto Online como Batch, el reporte interactivo es ejecutado solo en forma Online, ya que requiere de la interacción con ek usuario.
"La principal ventaja de los reportes interactivos es que con pocas líneas de código se puede crear un reporte con interacción, a diferencia de los programas de diálogo que requieren de mucho más tiempo de construcción".
2.- Eventos y variables de un reporte interactivo
Cuando hacemos un click en alguna posición de la lista principal, se ejecutará el evento AT-SELECTION. Este evento debemos ubicarlo luego del evento START-OF-SELECTION. En este momento, ciertas variables del sistema se completan con información muy útil como:
. sy-sind.- Contiene el índice de la lista de detalle.
. sy-lisel.- Tiene el contenido de la línea seleccionada.
. sy-lilli.- Contiene la línea seleccionada de la lista.
. sy_currow.- Contiene pa posición del cursor vertical en la pantalla.
Utilizaremos el evento TOP-OF-PAGE DURING LINE-SELECTION, para imprimir por pantalla los textos de las cabeceras de las listas de detalle.
Revisar los programas:
DEMO_LIST_INTERACTIVE_1
DEMO_LIST_INTERACTIVE_2
DEMO_LIST_INTERACTIVE_3
DEMO_LIST_INTERACTIVE_4
3.- Primer reporte interactivo.
añadir a la tabla ZTABLA_USUARIOS los campos: DIRECCION, CODIGO_POSTAL, FECHA_NAC que será DATS de 8 posiciones y ESTADO_CIVIL el cuál tendrá un dominio que será char de tamaño 1 y admitirá los valores S(soltero) y C(casado).
Para modificar una tabla de base de datos:
Desde el menú de opciones:
Utilidades
Objeto de datos
Utilidad de base de datos
Activar y adaptar base de datos.
Después se debe volver a generar la superficie de actualización, y finalmente ingresamos los datos en la tabla a travès de la transacción SM30.
Luego creamos el programa: ZREPORTE_INT_USUARIOS. Dentro del evento START-OF-SELECTION realizamos la selección del DNI, Nombre y Apellido de los usuarios. Después imprimimos por pantalla el resultado de la selección realizada.
CLEAR ti_usuarios.
REFRESH ti_usuarios.
SELECT *
FROM ztabla_usuarios
INTO TABLE ti_usuarios.
LOOP AT ti_usuarios INTO wa_usuarios.
FORMAT COLOR COL_TOTAL INTENSIFIED.
WRITE: / wa_usuarios-dni,
wa_usuarios-nombre_ape.
ENDLOOP.
Ahora vamos a agregar el evento AT LINE-SELECTION. El código que esté dentro de este evento se ejecutará cuando hagamos doble click en algún lugar de la pantalla, donde se visualiza el primer listado. Utilizaremos la variable del sistema sy-lisel para obtener el DNI correspondiente a la línea de la pantalla a la cual le realizamos click.
Luego creamos la subrutina GENERAR_REPORTE_NIVEL2, la cual seleccionará de la tabla ZTABLA_USUARIOS los datos del detalle correspondiente al usuario, cuyo DNI fue capturado anteriormente y los imprimirá por pantalla.
*------------------------------
AT LINE-SELECTION.
*------------------------------
v_dni = sy-lisel(19).
PERFORM generar_repote_nivel2.
Utilizaremos el evento TOP-OF-PAGE DURING LINE SELECTION para imprimir por pantalla la cabecera de cada nivel de listados de detalle.
*--------------------------------
TOP-OF-PAGE DURING LINE SELECTION.
*---------------------------------
WRITE: /'Detalle de los usuarios', sy-uline.
Finalmente ejecutamos el reporte, hacemos click en la línea correspondiente al DNI 23545312 y se despliega el detalle del usuario.
Otra posibilidad es mostrar la pantalla del nivel de detalle como una ventana de diálogo o subscreen. Para esto usamos la sentencia WINDOWS STARTING AT, ejemplo.
* Determinar posición en la pantalla: ancho y alto
* de la subscreen
WINDOW STARTING AT 1 15
ENDING AT 79 23.
Y se visualiza una ventana en la posición indicada.
Se pueden crear tantos niveles de listados como se requiera.
El nivel del listado donde estamos lo tenemos en la variable SY-SIND.
 
 
 
Sobre el autor
Publicación académica de Miguel Angel Acosta Acosta, en su ámbito de estudios para la Carrera Consultor ABAP.
Miguel Angel Acosta Acosta
Profesión: Ingeniero de Sistemas - Ecuador - Legajo: TF64C
✒️Autor de: 238 Publicaciones Académicas
🎓Egresado de los módulos:
- Carrera Consultor en SAP SD Nivel Avanzado
- Carrera Consultor en SAP SD Nivel Inicial
- Máster ABAP for HANA
- Carrera Consultor ABAP Nivel Avanzado
- Carrera Consultor ABAP Nivel Inicial
Disponibilidad Laboral: FullTime
Presentación:
Profesional de ingeniería de sistemas en computación e informática, con experiencia en la implantación y soporte de proyectos informáticos para empresas del sector industrial y financiero.
Certificación Académica de Miguel Acosta