Beruflich Dokumente
Kultur Dokumente
Introduccion
Los nuevos formularios SmartForms son una de las ultimas técnicas de SAP para la impresión y
envio via mail y fax de reportes e información tabulada y formateada.
A diferencia de la transaccion SE71 que se utiliza habitualmente para la creacion y edicion de los
forms estandar en SAP, en los nuevos formularios creados con Smartforms se debe trabajar con
dos transacciones nuevas:
• Una transaccion para definir el estilo del formulario llamada SMARTSTYLES en la cual se
definen tipo de paragrafos, tipo de caracteres, los fonts que se van a usar, el tamano que
tendran, los tabuladores, etc, etc.
• Otra transaccion para crear el formulario en si mismo llamda SMARTFORMS en la cual se
definen las ventanas y su contenido y que utiliza al estilo creado con SMARTSTYLES .
Tambien cambiara la forma en que se escribe la logica del programa que controlara el
formulario, antes lo haciamos directamente desde SE38, ahora el sistema escribira
automaticamente las rutinas del control del formulario y nosotros podremos invocar al
formulario a traves de un par de funciones estandar de sistema dejando de lado la vieja
manera del WRITE_FORM etc, etc.
Para esta guia de demostracion yo estoy logeado al sistema en ingles por lo que los
nombres de campos y demas estan en ingles.
Transaccion SMARTSTYLES
Click en Crear
Darle un nombre, por ejemplo P0, este sera el paragrafo por defecto mas adelante.
En la parte derecha de la pantalla apareceran las solapas con todos los posibles atributos
para este tipo de paragrafo, como va a ser el estandar es mejor usar tipo de letra y
tamano estandares como por ejemplo HELVE y tamano 10.
Ahora podemos definir el resto de todos los paragrafos que queramos usar en el
formulario, habitualmente yo los numero sistematicamente, P1, P2, etc, etc.
No olvidar dar click sobre Save y Activate.
Transaccion SMARTFORMS
Click en la opcion Form y darle el nombre del formulario, por ejemplo ZSMART1.
( Click en la opcion Style y darle el nombre del estilo, por ejemplo ZESTILO1. lo que
permite es editar el estilo sin ir a la transaccion SMARTSTYLES )
Click en Create.
Con el boton Form Painter se puede hacer aparecer o desaparecer el panel de diseno
grafico.
En el nodo Form Attributes se puede controlar los atributos basicos del formulario:
Para empezar a definir el formulario vamos a crear una primera pagina que tendra:
Ventana Main:
Por defecto el sistema nos crea una pagina llamada %PAGE1 en el arbol a la izquierda de
la pantalla debajo de Pages and Windows.
Renombrala como PAGINA1 y darle como descripcion "Primera pagina del formulario."
Si se hace Click sobre el boton Form Painter se vera como va quedano el formulario.
Para ver el aspecto que va teniendo el formulario podemos lanzar una impresion de
prueba:
Aparece el nombre del programa que ha sido creado automaticamente, por el momento lo
usaremos tal cual esta.
Elegir la impresora.
Nos crea una ventana nueva llamada %WINDOW1, renombrarla como Titulo. "Titulo del
formulario."
En la solapa General Attributes aparecera abajo del todo un cuadro en blanco donde
pondremos el titulo en si mismo del formulario, por ejemplo "Formulario de Prueba"
Si se hace click sobre el botoncito Txt Editor que esta a la izquierda del combo de texto
aparece el viejo editor de comandos de Forms ( Lo menciono solo como dato informativo
).
Nos crea una ventana nueva llamada %WINDOW2, renombrarla como CONTADOR
"Contador de paginas"
Hasta el momento solo hemos definido el "esqueleto" del formulario de prueba, ahora
vamos a colocar campos y otros datos.
El contador de paginas:
Campos que vienen de las tablas declaradas como parametros del SmartForm
Hay que utilizar el boton + (insertar campos) y poner el nombre del campo entre &&
Para este ejemplo en una parte del codigo del programa ( programa que se estudiara
completo en detalle mas adelante ) se cargaran los datos en una tabla auxiliar llamada
int_mkpf la cual sera pasada como parámetro a la funcion fm_name que es la funcion
encargada de llamar al formulario, la tabla es recibida por el formulario con el nombre
gs_mkpf tal cual aparece en este fragmento de codigo:
TABLES
gs_mkpf = int_mkpf
EXCEPTIONS
formatting_error = 1
internal_error = 2
send_error = 3
user_canceled = 4
OTHERS
Por lo tanto el SmartForm debe ser informado de los datos que va a recibir y de cómo
posicionarlos en el formulario.
Form Interface
En la solapa TABLES
Global Data
AUX_GS_MKPF LIKE MKPF
En la solapa Data
ENDLOOP.
En la solapa TABLE, click en boton Details
Style = ZESTILO1
Para que los cabezales de las columnas se impriman en todas las paginas deben ser
declarados en la seccion HEADER de la tabla GS_MKPF como un texto al que se le
pueden dar atributos en estilo tales como negrita y subrayado.
REPORT zsmart1.
* ----------------------------------------------------------------------
* Sistema : SAP R/3
* Nombre : Modelo del programa de invocacion de un SmartForm.
* Script : ZSMART1
* Autor : Exequiel Lopez Ramon.
* Fecha : 17/11/2004
* ----------------------------------------------------------------------
TABLES: mkpf.
* ----------------------------------------------------------------------
* ----------------------------------------------------------------------
* Programa principal
PERFORM cargar_datos_demo.
PERFORM invocar_smartform.
EXIT.
* ----------------------------------------------------------------------
FORM cargar_datos_demo.
ENDSELECT.
ENDFORM.
* ----------------------------------------------------------------------
FORM invocar_smartform.
* Inicializar el formulario.
CALL FUNCTION 'SSF_FUNCTION_MODULE_NAME'
EXPORTING
formname = 'ZSMART1'
IMPORTING
fm_name = nombre_modulo_funcion
EXCEPTIONS
no_form = 1
no_function_module = 2
OTHERS = 3.
MESSAGE ID sy-msgid
TYPE sy-msgty
NUMBER sy-msgno
WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.
ENDIF.
MESSAGE ID sy-msgid
TYPE sy-msgty
NUMBER sy-msgno
WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.
ENDIF.
ENDFORM.
* ----------------------------------------------------------------------
*
Para agregar codigo ejecutable que pueda por ejemplo acceder a las tablas de SAP existen algunas
secciones donde puede ser incluido.
Inicializacion:
En el combo de texto que aparece abajo pueden agregarse comandos ABAP como por ejemplo:
Por ejemplo se la puede usar como &AUX_LS_LFA1-NAME1& en cualquier lugar del formulario.
En el campo Name colocar el nombre de una imagen ya cargada en el sistema, por ejemplo
Z_LOGO_UTE_2.
Activar.