Diferencias
Muestra las diferencias entre dos versiones de la página.
Ambos lados, revisión anterior Revisión previa | Última revisiónAmbos lados, revisión siguiente | ||
wiki:2.-desarrollo-app:2.3.-codigo:c.-eventos:1.-action:start [2018/04/11 13:10] – [RUNSCRIPT] ejetoro | wiki:2.-desarrollo-app:2.3.-codigo:c.-eventos:1.-action:start [2018/04/12 13:20] – editor externo 127.0.0.1 | ||
---|---|---|---|
Línea 1: | Línea 1: | ||
+ | {{indexmenu_n> | ||
+ | ====== Nodo ACTION ====== | ||
+ | \\ | ||
+ | Nodo donde se expondrán las acciones a realizar en los eventos definidos en nuestra aplicación. | ||
+ | \\ | ||
+ | El nombre de la acción define lo que va a realizar. | ||
+ | \\ | ||
+ | ===== SETVAL ===== | ||
+ | \\ | ||
+ | Consiste en asignarle un valor a una propiedad del objeto. Se pueden utilizar macros en el atributo value. | ||
+ | \\ | ||
+ | <code xml> | ||
+ | <!-- Ponemos la ID de la empresa del usuario que se ha logueado en IDEMPRESA --> | ||
+ | <action name=" | ||
+ | |||
+ | <!-- Se pueden utilizar MACROS, en este caso ## | ||
+ | OJO porque por ejemplo en un create esta macro NO TENDRIA VALOR --> | ||
+ | <action name=" | ||
+ | |||
+ | <!-- Ponemos la fecha actual del sistema y la ponemos en el campo FECHA --> | ||
+ | <action name=" | ||
+ | |||
+ | <!-- Cogemos el ID del usuario del sistema y lo ponemos en IDUSUARIO--> | ||
+ | <action name=" | ||
+ | |||
+ | <!-- Ponemos a 0 el campo EXECUTED y a 1 el campo IDCARGO --> | ||
+ | <action name=" | ||
+ | <action name=" | ||
+ | |||
+ | </ | ||
+ | \\ | ||
+ | ^Atributo | ||
+ | | **name** | Nombre de la acción a ejecutar | ||
+ | | **field** | Campo que se va a actualizar | | ||
+ | | **value** | Valor que se le va a asignar al campo | | ||
+ | |||
+ | ===== RUNSCRIPT ===== | ||
+ | |||
+ | Ejecución de código < | ||
+ | |||
+ | <code xml> | ||
+ | |||
+ | <!-- Cogemos el valor del campo MAP_SERIE y concatenamos con "/" | ||
+ | <action name=" | ||
+ | |||
+ | <!-- Si se desea pasar un parámetro en la llamada al nodo que ejecuta el script, se coloca antes de la etiqueta script --> | ||
+ | <param name=" | ||
+ | |||
+ | < | ||
+ | This(" | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | <!-- Podemos llamar a un fichero de scripts cuando lo necesitemos, | ||
+ | <action name=" | ||
+ | < | ||
+ | < | ||
+ | EntrarN | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | <!-- Esto es en Javascript --> | ||
+ | <action name=" | ||
+ | < | ||
+ | calculaTotal(self); | ||
+ | ui.refresh(" | ||
+ | </ | ||
+ | </ | ||
+ | </ | ||
+ | \\ | ||
+ | ===== SETFLDVAL ===== | ||
+ | |||
+ | Para coger un valor de un campo de la colección padre y ponerlo en un campo de la colección hija. Utilizado en los contents. | ||
+ | |||
+ | <WRAP center round important 60%> | ||
+ | Aunque esta acción sigue funcionando, | ||
+ | 1.- En vbscript: | ||
+ | 2.- En javascript: self.NOMBRE=self.getOwnerCollection().getOwnerObject().MAP_DELPADRE; | ||
+ | </ | ||
+ | |||
+ | <code xml> | ||
+ | |||
+ | <!-- Cogemos el valor del ID de la colección padre y lo ponemos en el campo IDCLIENTE de la colección Contents --> | ||
+ | < | ||
+ | |||
+ | </ | ||
+ | \\ | ||
+ | ^Atributo | ||
+ | | **name** | Nombre de la acción a ejecutar | ||
+ | | **targetfld** | Campo que se va a actualizar con el campo del padre | | ||
+ | | **sourcefld** | Campo de la colección padre que va a dar valor al campo de esta colección | ||
+ | ===== MAPVAL ===== | ||
+ | |||
+ | Buscamos un valor en otra colección y nos traemos el valor de algún campo. \\ | ||
+ | <code xml> | ||
+ | |||
+ | <!-- Buscamos en la colección Usuarios el registro cuyo ID sea el el usuario logueado actualmente | ||
+ | y cogemos el valor del campo IDSERIE para ponerlo en el campo IDSERIE de la colección actual, es decir: | ||
+ | | ||
+ | <action name=" | ||
+ | |||
+ | <!-- Buscamos en la colección TiposUsuario el registro cuyo CODIGO = 4 | ||
+ | y cogemos el valor del campo ID para ponerlo en el campo IDTIPO de la colección actual, es decir: | ||
+ | | ||
+ | <action name=" | ||
+ | |||
+ | <!-- Buscamos en la colección Usuarios el registro cuyo ID sea el el usuario logueado actualmente | ||
+ | y cogemos el valor del campo LOGIN para ponerlo en el campo CODTECNICO de la colección actual, es decir: | ||
+ | | ||
+ | < | ||
+ | |||
+ | </ | ||
+ | \\ | ||
+ | ^Atributo | ||
+ | | **name** | Nombre de la acción a ejecutar | ||
+ | | **field** | Campo que se va a actualizar | | ||
+ | | **targetfld** | Nombre del campo que tiene el valor que va a ser asignado al campo **field** | | ||
+ | | **coll** | Colección donde se va a realizar la busqueda del campo que tendrá el valor requerido | | ||
+ | | **mapfld** | Campo de la colección que esta definida en el atributo **coll**, que es clave primera de la misma | | ||
+ | | **mapvalue** | Valor del campo de la clave primera para rescatar el registro buscado | | ||
+ | ===== EXECUTESQL ===== | ||
+ | |||
+ | Para ejecutar una sentencia SQL, Insert, Update o Delete. No tiene sentido ejecutar un Select, porque la acción no devuelve ningún valor. | ||
+ | |||
+ | Muy utilizado en las colecciones de cabecera, cuando se está eliminando un registro, eliminar todas sus líneas asociadas.\\ | ||
+ | \\ | ||
+ | <code xml> | ||
+ | |||
+ | <!-- Se pueden utilizar MACROS --> | ||
+ | <action name=" | ||
+ | |||
+ | </ | ||
+ | \\ | ||
+ | ^Atributo | ||
+ | | **name** | Nombre de la acción a ejecutar. | ||
+ | | **sql** | Sentencia SQL que quiere ejecutar. Solo es válido la ejecución de Insert, Update o Delete. | | ||
+ | ===== LINK ===== | ||
+ | |||
+ | Para actualizar el campo de enlace de una colección de detalles con la ID de la cabecera. \\ | ||
+ | \\ | ||
+ | Utilizado EXCLUSIVAMENTE en el nodo INSERT de una colección de cabecera. Para enlazar las líneas de detalle de la colección CONTENTS cuando se está dando de alta al mismo tiempo la cabecera y los detalles, pues hasta que la cabecera no se graba, las líneas de detalle no saben cual es el ID de su padre. | ||
+ | |||
+ | <WRAP center round important 80%> | ||
+ | Actualmente, | ||
+ | \\ | ||
+ | No obstante, el framework internamente sigue intentando buscar un campo de enlace entre los contents y la coleccion " | ||
+ | </ | ||
+ | |||
+ | |||
+ | <code xml> | ||
+ | <action name=" | ||
+ | </ | ||
+ | \\ | ||
+ | ^Atributo | ||
+ | | **name** | Nombre de la acción a ejecutar | ||
+ | | **coll** | Colección que se busca para actualizar el campo de enlace con esta colección Padre | | ||
+ | | **field** | Nombre del campo de la colección con el nombre que está definido en el atributo **coll** y que es el enlace con esta colección Padre | | ||
+ | | **value** | Valor que se le asigna al campo enlace entre la colección Padre y la colección hija | | ||
+ | |||
+ | |||
+ | |||
+ | |||
+ | ====== NODO BEFOREACTION ====== | ||
+ | |||
+ | Nodo donde se expondrán las acciones a realizar en los eventos definidos en nuestra aplicación, | ||
+ | \\ | ||
+ | Sin embargo, como punto importante a tener en cuenta, es que esta acción solo es válida para el evento | ||
+ | [[wiki: | ||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||