2.5. - Lógica de procesamiento en PAI: Validaciones
2.5.1. - Validación de los datos de entrada
Una de las funciones más importantes del PAI, es la de validar los datos de entrada de la pantalla antes de ser utilizados. Existen dos tipos de validaciones de los datos de entrada.
1. Chequeo automático realizado por el sistema.
2. Chequeo manual programado con el comando “FIELD” de la lógica de proceso de las dynpros.
2.5.2. - Validación automática
El sistema realiza automáticamente una serie de chequeos de los datos de entrada antes de procesar el evento PAI.
Verificación del formato
El sistema valida las entradas de acuerdo a los atributos de cada campo. Si se detecta un valor incorrecto, se desplegará un mensaje de error y se volverán a mostrar los campos para su nueva entrada. En este ejemplo, se ve que el error se está produciendo al introducir una letra en un campo numérico.
Verificación de campos obligatorios
Cuando a un campo de la pantalla se le asigna el atributo de obligatorio, el sistema no continuará el procesamiento, a menos que el campo obligatorio tenga algún valor.
Verificación de claves foráneas
Una verificación de clave foránea es procesada solo si un campo de la pantalla se refiere a un campo del diccionario de datos para el cual se ha definido una tabla de verificación. Al mismo tiempo, la funcionalidad de la tecla F4 es activada. Esto significa que las posibles entradas para un campo son desplegadas.
Verificación del ámbito de valores
En el diccionario de datos se puede definir un ámbito de valores asociado a un dominio. Si se define un campo de pantalla con referencia a un dominio con un ámbito de valores asociado, ocurre lo siguiente
1. Los valores del ámbito son desplegados si el usuario presiona F4 para ver los posibles valores para el campo de entrada.
2. El sistema verificará los valores introducidos en el campo contra el conjunto de valores del ámbito del dominio correspondiente.
2.5.3. - Validación manual
Además del chequeo automático, es posible realizar una validación más extensa con los valores de entrada con las instrucciones “FIELD” y “CHAIN-ENDCHAIN”.
Con FIELD, se puede validar individualmente cada campo de forma que en caso de error, la siguiente entrada de datos solo permitirá introducir el campo erróneo sobre el que se está utilizando en la instrucción “FIELD”.
Dependiendo del tipo de sentencia FIELD que se utilice, el mecanismo de chequeo se realizará en la lógica de proceso de la dynpro o en un módulo.
Es posible realizar distintas validaciones de n campo de entrada dependiendo de la fuente con la que se contrastan los valores posibles. Se puede chequear el contenido de un campo comparándolo con una tabla de base de datos, con una lista de valores o realizando la validación en un módulo del Module Pool.
Chequeo de un campo contra una tabla base de datos
Si no se encuentran registros en la base de datos, el sistema emite un mensaje de error estándar. Existe una versión ampliada de la instrucción anterior que permite enviar mensajes o advertencias en caso de que encuentre o no registros.
Chequeo de un campo respecto de una lista de valores
Si el valor introducido por el usuario no corresponde a ningún valor de la lista, el sistema emite un mensaje de error. La lista de valores puede ser:
Chequeo de un campo en un módulo
Para chequear un campo determinado con un módulo, se utiliza la sentencia “FIELD <campo_pantalla> MODULE <módulo_ABAP>”.
Si el modulo resulta con un error o un mensaje de advertencia, la pantalla es desplegada nuevamente pero sin procesar los módulos del PBO. El texto del mensaje es mostrado y solo el campo que ocasionó el error estará disponible para introducir datos nuevamente.
La instrucción CHAIN-ENDCHAIN
La instrucción “CHAIN-ENDCHAIN” encierra un conjunto de instrucciones FIELD, que en caso de error en la entrada de alguno de ellos, todos los campos del “CHAIN-ENDCHAIN” se podrán modificar, mientras que los que no pertenezcan al “CHAIN-ENDCHAIN” estarán bloqueados para la entrada de datos.
Definen cadenas de procesamiento. Dentro de “CHAIN-ENDCHAIN” se ejecutan las sentencias “FIELD” y “MODULE”. Las sentencias que están entre “CHAIN-ENDCHAIN” forman una cadena de procesamiento, las cuales no se pueden anidar. La sentencia “CHAIN-ENDCHAIN” puede ser especificada en el PAI y en el PBO, pero en el PBO no tiene efecto alguno.
2.5.4. - Mensajes en pantalla
Comportamiento de cada uno de los tipos de mensajes existentes en un programa de diálogo.
Mensaje de error
El texto de un mensaje de error, es desplegado en la pantalla actual.
Todos los campos de pantalla asignados al módulo correspondiente (instrucción FIELD), se vuelven disponibles para introducir información de nuevo. El sistema obliga al usuario a reintroducir datos.
Mensaje de advertencia
El texto del mensaje de advertencia, es desplegado en la pantalla actual.
Todos los campos de pantalla asignados al módulo correspondiente (instrucción FIELD), se vuelven disponibles para introducir información de nuevo. El usuario puede reintroducir los datos o ignorar el mensaje de advertencia presionando la tecla enter.
Mensaje de advertencia
El texto de un mensaje de información (I) es desplegado en la pantalla actual.
El proceso de la pantalla actual es suspendido. Después de que el usuario presione la tecla enter, el programa continúa con su ejecución normal desde el punto donde fue suspendido.
Mensaje de éxito
Un mensaje de texto de existo (S), es desplegado en la pantalla siguiente a la actual.
Mensaje de interrupción
Un texto de un mensaje de interrupción (A), es desplegado en la pantalla actual.
Después de que el usuario presione la tecla enter, el proceso actual es terminado y el proceso regresa a la pantalla inicial.