Proyecto

General

Perfil

Actualizar valor del multiples metadatos

Información

Autor Laureano Quintero
Sitio Web http://www.facebook.com/adapting-lab
Repositorio source:Acciones-America/trunk/src/UpdateMultipleMetadataValuesAction
Código fuente http://svn-community.adapting.com:8080/svn/Community/Plugins/Acciones-America/trunk/src/UpdateMultipleMetadataValuesAction
Versión Actual v1.0
Compatible con Abox 3.0.0 y anteriores

Resumen

Esta acción se encarga de actualizar el valor de un metadato del contenido al que se le esta ejecutando la transición con un valor constante, el valor de una palabra reservada o el valor de otro metadato.

Notas de instalación

Descargue el código fuente del plugin y compílelo usando Visual Studio 2010. Luego dependiendo si lo va a integrar en una instalación de Abox o en un proyecto de extensión de Abox sigua las siguientes instrucciones.
En una instalación de Abox

Copiar la dll que genera el proyecto, en principio se debe llamar Adapting.UpdateMultipleMetadataValuesAction.dll, en la carpeta /bin del sitio web donde esta Abox.

Incluya el proyecto en su proyecto para extender Abox, añada una referencia en Adapting.Web al proyecto que acaba de incluir.

Guía de uso

Una vez incluida la clase en el proyecto y recompilado el proyecto, tiene que modificar el XML del workflow para añadir esta acción en las acciones que ejecuta el worlflow al cambiar de estado. Para hacer esto incluya este código en las acciones de la transición en la que quiere que se ejecute.

Para actualizar el metadato se puede hacer de varias maneras:

Actualizando con metadato:

        <action type="UpdateMultipleMetadataValues">
          <param name="fieldcodes">metadatacode1,metadatacode2,metadatacode3,metadatacode4</param>
          <param name=".metadata_values">metadatacode1,metadatacode2,metadatacode3,metadatacode4</param>
        </action>

Actualizando con constante:

        <action type="UpdateMultipleMetadataValues">
          <param name="fieldcodes">metadatacode1,metadatacode2,metadatacode3,metadatacode4</param>
          <param name=".constant_values">value1,value2,value3,value4</param>
        </action>

Actualizando metadatos del padre al hijo o del hijo al padre:

        <action type="UpdateMultipleMetadataValues">
          <!--Codigos de los metadatos del contenido actual-->
          <param name="fieldcodes">metadatacode1,metadatacode2,metadatacode3,metadatacode4</param>

          <!-- Utilizar ".metadata_values" y digitar los códigos del metadato del padre-->
          <param name=".metadata_values">metadatacode1,metadatacode2,metadatacode3,metadatacode4</param>

         <!-- solo admite los valores "fromchildtoparent" o "fromparenttochild", especifica si se actualizara desde el metadato de contenido hacia un metadato
         del padre o desde un metadato del padre hacia el contenido actual -->
          <param name="action">fromchildtoparent</param>

        </action>

Donde,
fieldcodes: Códigos de los metadatos que se va a actualizar, separados por (,) (Destino).
.metadata_values: Códigos de los metadatos con el valor que se copiara, separados por (,), (Origen).
.constant_values: Valores que se va a copiar, separados por (,).
action: solo admite los valores "fromchildtoparent" o "fromparenttochild", especifica si se actualizara desde el metadato de contenido hacia un metadato
del padre o desde un metadato del padre hacia el contenido actual.

Si se emplea el tag ".constant_values" NO es posible utilizar códigos de metadatos en el parámetro. Si emplea ".metadata_values" no es posible utilizar constantes en el parámetro.

Nota: Esta acción es para usarla con workflows de documentos y expedientes.

Historico

10/06/2015 (3.0.0): Ahora se podrá actualizar el valor de algunos metadatos del contenido actual, utilizando 1 metadato para agregarle una cadena de códigos de metadato separados por "," , este metadato debe llevar en su código el símbolo '#' al principio o al final, como por ejemplo:

        <action type="UpdateMultipleMetadataValues">
          <param name="fieldcodes">metadatacode1,<!--ejemplo--> #metadatacode2 <!--ejemplo-->,metadatacode3,metadatacode4</param>
          <param name=".metadata_values">metadatacode1,<!--ejemplo--> #metadatacode2 <!--ejemplo--> ,metadatacode3,metadatacode4</param>
        </action>

La cadena de códigos de metadatos origen tiene que ser ordenada de igual forma que en el metadato destino, estos se agregaran a la cola de asignación.
Esto tiene sentido para guardar dinámicamente los códigos de los metadatos que se quieran copiar.

15/07/2015 ya se puede utilizar con metadatos MirrorField y MathSuites

08/08/2016 (3.3): Se agrego un nuevo parametro opcional "othercontent", lo que hace es cambiar el contenido sobre el que se generara el update, los demas parametros afectan al nuevo contenido este puede ser Documento o Expediente, se admiten metadatos de tipo DocumentLink, CaseFolderLink, texto o constantes para indicar el contenido a actualizar, para constantes y metadatos de texto funciona con el ID del contenido a actualizar.

         <action type="UpdateMultipleMetadataValues">
           <param name="fieldcodes">15.01</param>
           <param name=".constant_values">Hola mundo</param>
           <!-- nuevo parametro opcional-->
           <param name="othercontent">esq_luis.DocLink</param>
         </action>

Volver al inicio
Agregar imagen desde el portapapeles (Tamaño máximo: 10 MB)