Diferencia entre revisiones de «Tarea C: Evolucionando la arquitectura del registro»
Línea 76: | Línea 76: | ||
Ahora nos falta establecer la relación entre la ficha de '''Tercero''' y las '''Entradas''' y las '''Salidas'''. Esto lo logramos haciendo uso de los campos de tipo {{T|vinculo}}. Un {{T|vinculo}} representa una relación entre dos contenedores dentro del sistema. El siguiente código muestra cómo vincular una Entrada con una ficha de Tercero: | Ahora nos falta establecer la relación entre la ficha de '''Tercero''' y las '''Entradas''' y las '''Salidas'''. Esto lo logramos haciendo uso de los campos de tipo {{T|vinculo}}. Un {{T|vinculo}} representa una relación entre dos contenedores dentro del sistema. El siguiente código muestra cómo vincular una Entrada con una ficha de Tercero: | ||
− | tipo [Entrada] es contenedor | + | {{PR|tipo}} [Entrada] {{PR|es}} {{RE|contenedor}} |
− | [Datos generales] es formulario | + | [Datos generales] {{PR|es}} {{T|formulario}} |
− | [Número] es timbre | + | [Número] {{PR|es}} {{T|timbre}} |
− | -certificado.subsecuencia.valor = $Copiartexto($texto($Año($Hoy)), 3, 2); | + | -{{AT|certificado.subsecuencia.valor}} = $Copiartexto($texto($Año($Hoy)), 3, 2); |
− | -certificado.valor = [&Valor_subsecuencia] + "/" + [&Valor_secuencia]; | + | -{{AT|certificado.valor}} = [&Valor_subsecuencia] + {{STR|"/"}} + [&Valor_secuencia]; |
− | -certificado.secuencia.nombre = "STR$ENTRADA"; | + | -{{AT|certificado.secuencia.nombre}} = {{STR|"STR$ENTRADA"}; |
− | -certificado.secuencia.longitud = 4; | + | -{{AT|certificado.secuencia.longitud}} = 4; |
− | [Fecha] es fecha | + | [Fecha] {{PR|es}} {{T|fecha}} |
− | -edicion.modo = copia; | + | -{{AT|edicion.modo}} = copia; |
− | -edicion.valor = [Número].[&Fecha]; | + | -{{AT|edicion.valor}} = [Número].[&Fecha]; |
− | [Remitente] es vinculo | + | [Remitente] {{PR|es}} {{T|vinculo}} |
− | -vinculo.definicion = [Tercero]; | + | -{{AT|vinculo.definicion}} = [Tercero]; |
− | -vinculo.etiqueta = [Datos generales].[Nombre/Razón social] + " " + [Datos generales].[Apellidos]; | + | -{{AT|vinculo.etiqueta}} = [Datos generales].[Nombre/Razón social] + {{STR|" "}} + [Datos generales].[Apellidos]; |
− | -vinculo.valores = $matriz([Fichero de terceros].[Contenido]); | + | -{{AT|vinculo.valores}} = $matriz([Fichero de terceros].[Contenido]); |
− | [Destinatario] es texto | + | [Destinatario] {{PR|es}} {{T|texto}} |
− | fin | + | {{PR|fin}} |
− | fin | + | {{PR|fin}} |
+ | |||
+ | Como podrás observar, cambiamos el tipo del campo '''Remitente''' de {{T|texto}} a {{T|vinculo}}. Los tres atributos que vienen a continuación nos permiten configurar el comportamiento del {{T|vinculo}}: | ||
+ | :*El atributo {{AT|vinculo.definicion}} indica con qué tipo de contenedor puede establecerse el vínculo. En este caso indicamos que vincula con un objeto de tipo '''Tercero'''. | ||
+ | :*En el atributo {{AT|vinculo.etiqueta} indicamos una expresión con el texto que debe aparecer en el campo cuando se establece el vínculo. En este caso, queremos que aparezca el nombre y los apellidos concatenados. | ||
+ | :*Por último, en el atributo {{AT|vinculo.valores}} indicamos la fuente de datos de la cuál obtendremos todos los contenedores con los que podremos vincular. En nuestro caso indicamos que es la colección '''Contenido''' del '''Fichero de terceros'''. Como este atributo espera una matriz, realizamos una conversión entre {{T|coleccion}} y {{T|matriz}} con la función '''$matriz'''. | ||
+ | |||
+ | Con estas seis líneas ya habremos establecido la relación entre '''Entrada''' y '''Tercero'''. | ||
+ | |||
+ | Compila, actualiza y prueba ;). | ||
+ | |||
+ | <center> | ||
+ | {| | ||
+ | |align="center" |[[Imagen:Figura 12.jpg|thumb|250px|Figura 12 - Cuadro de búsqueda para vincular. Este cuadro se abre al hacer clic en el icono vincular del campo Remitente.]] | ||
+ | |} | ||
+ | </center> |
Revisión del 13:57 27 nov 2008
En nuestro registro, cada vez que un interesado presenta documentación, tenemos que escribir su nombre en el campo Remitente. Este sistema es válido, pero presenta algunas carencias. Si la misma persona presenta documentación en varias ocasiones, tendremos que estar repitiendo su nombre con el riesgo de equivocarnos, arriesgándonos a perder la coherencia de los datos. Además, tenemos muy poca información sobre esa persona. Si está iniciando un procedimiento administrativo y tenemos que ponernos en contacto con ella, no tenemos ni su DNI, ni su teléfono, ni su dirección. Tampoco podemos poner estos campos en el formulario del objeto Entrada ya que la introducción de datos sería muy tediosa. ¿Qué podemos hacer? Comencemos por abstraer el concepto de Tercero en el diagrama que propusimos al comienzo del tutorial.
En esta figura lo que decimos es:
- Un Fichero de terceros se compone de muchos terceros. Un Tercero representa una persona (física o jurídica) y contiene los datos jurídicos y de contacto de dicha persona.
- Un Libro de entrada se compone de muchas entradas. Cada Entrada tiene Número, Fecha y Destinatario (a qué departamento de la organización se dirige). También se relaciona con una ficha de Tercero; esta relación expresa que el Tercero es el Remitente de la documentación. Adicionalmente, puede tener uno o más documentos adjuntos.
- Un Libro de salida se compone de muchas salidas. Cada Salida tiene Número, Fecha y Origen (departamento de la organización de donde sale el documento). También se relaciona con una ficha de Tercero; esta relación expresa que el Tercero es el Destinatario de la documentación de salida. Además, puede tener uno o más documentos adjuntos.
La definición del tipo Tercero es inmediata:
tipo
[Tercero]es
contenedor
[Datos generales]es
formulario
[Nombre/Razón social]es
texto
[Apellidos]es
texto
[CIF/NIF]es
texto
[Dirección]es
texto
[Código postal]es
texto
[Municipio]es
texto
[Provincia]es
texto
[Teléfono 1]es
texto
[Teléfono 2]es
texto
[Fax]es
texto
[Email]es
texto
fin
fin
Ahora tenemos que definir el Fichero de terceros como un objeto de sistema. La definición es muy parecida a la del Libro de entrada.
[Fichero de terceros]es
contenedor
[Contenido]es
coleccion
-nombre_tabla
="TC$TERCEROS"
;
contiene
[Tercero]
columna
[Denominación] -columna_bd.nombre
="DENOMINACION"
; -origen
= [Datos generales].[Nombre/Razón social] +" "
+ [Datos generales].[Apellidos];columna
[CIF/NIF] -columna_bd.nombre
="CIF"
; -columna_bd.nombre
="EMAIL"
; -{AT|origen}} = [Datos generales].[Email];fin
fin
Como ya explicamos en la Tarea 1, las columnas de una coleccion
no tienen por qué tener una correspondencia directa con los campos de los objetos que contiene. En esta ocasión, hemos definido la columna Denominación como una concatenación del Nombre y los Apellidos, para no tener que diferenciar entre personas físicas y jurídicas (que no tendrían apellidos).
En ODL, todo recurso debe definirse antes de que se haga uso de él o de su definición. Como más adelante haremos uso tanto del tipo Tercero como del Fichero de terceros para establecer la relación, debemos asegurarnos de que las definiciones aparecen antes de que se definan los objetos Entrada o Salida.
Por último, para hacer este fichero accesible para los usuarios, tenemos que ubicarlo en el Registro de entrada y salida. En este caso lo ubicaremos en Ficheros, en vez de en Libros.
[Registro de entrada y salida]es
habitacion
ubicado
[Fichero de terceros] -lugar
="Ficheros"
;ubicado
[Libro de entrada] -lugar
= {{STR|"Libros"};ubicado
[Libro de salida] -lugar
="Libros"
;fin
Si compilamos y actualizamos ya podremos comenzar a crear fichas de Tercero en nuestro sistema. Observa cómo en la barra de navegación lateral la plataforma crea un nuevo grupo con el nombre Ficheros.
Ahora nos falta establecer la relación entre la ficha de Tercero y las Entradas y las Salidas. Esto lo logramos haciendo uso de los campos de tipo vinculo
. Un vinculo
representa una relación entre dos contenedores dentro del sistema. El siguiente código muestra cómo vincular una Entrada con una ficha de Tercero:
tipo
[Entrada]es
contenedor
[Datos generales]es
formulario
[Número]es
timbre
-certificado.subsecuencia.valor
= $Copiartexto($texto($Año($Hoy)), 3, 2); -certificado.valor
= [&Valor_subsecuencia] +"/"
+ [&Valor_secuencia]; -certificado.secuencia.nombre
= {{STR|"STR$ENTRADA"}; -certificado.secuencia.longitud
= 4; [Fecha]es
fecha
-edicion.modo
= copia; -edicion.valor
= [Número].[&Fecha]; [Remitente]es
vinculo
-vinculo.definicion
= [Tercero]; -vinculo.etiqueta
= [Datos generales].[Nombre/Razón social] +" "
+ [Datos generales].[Apellidos]; -vinculo.valores
= $matriz([Fichero de terceros].[Contenido]); [Destinatario]es
texto
fin
fin
Como podrás observar, cambiamos el tipo del campo Remitente de texto
a vinculo
. Los tres atributos que vienen a continuación nos permiten configurar el comportamiento del vinculo
:
- El atributo
vinculo.definicion
indica con qué tipo de contenedor puede establecerse el vínculo. En este caso indicamos que vincula con un objeto de tipo Tercero. - En el atributo {{AT|vinculo.etiqueta} indicamos una expresión con el texto que debe aparecer en el campo cuando se establece el vínculo. En este caso, queremos que aparezca el nombre y los apellidos concatenados.
- Por último, en el atributo
vinculo.valores
indicamos la fuente de datos de la cuál obtendremos todos los contenedores con los que podremos vincular. En nuestro caso indicamos que es la colección Contenido del Fichero de terceros. Como este atributo espera una matriz, realizamos una conversión entrecoleccion
ymatriz
con la función $matriz.
- El atributo
Con estas seis líneas ya habremos establecido la relación entre Entrada y Tercero.
Compila, actualiza y prueba ;).