Uso de Ocultar condiciones using-hide-conditions

Ocultar condiciones se puede utilizar para determinar si un recurso de componente se procesa o no. Un ejemplo de esto sería cuando un autor de plantillas configure el componente principal componente de lista en el editor de plantillas y decida deshabilitar las opciones para generar la lista basada en páginas secundarias. Al desactivar esta opción en el cuadro de diálogo de diseño, se establece una propiedad de modo que, cuando se represente el componente de lista, se evalúe la condición de ocultar y no se muestre la opción para mostrar páginas secundarias.

Información general overview

Los cuadros de diálogo pueden llegar a ser complejos, con numerosas opciones para el usuario, que sólo puede utilizar una fracción de las opciones de las que dispone. Esto puede generar experiencias de interfaz de usuario abrumadoras para los usuarios.

Al utilizar las condiciones de ocultación, los administradores, los desarrolladores y los superusuarios tienen una forma de ocultar los recursos en función de un conjunto de reglas. Esta función les permite decidir qué recursos se deben mostrar cuando un autor edita el contenido.

NOTE
Al ocultar un recurso basado en una expresión, no se reemplazan los permisos ACL. El contenido sigue siendo editable, pero no se muestra.

Detalles de implementación y uso implementation-and-usage-details

com.adobe.granite.ui.components.FilteringResourceWrapper es responsable de filtrar los recursos en función de la existencia y el valor de la propiedad granite:hide, ubicada en el campo que se va a filtrar. La implementación de /libs/cq/gui/components/authoring/dialog/dialog.jsp incluye una instancia de FilteringResourceWrapper.

La implementación utiliza la API ELResolver de Granite y agrega una variable personalizada cqDesign a través de ExpressionCustomizer.

A continuación se muestran algunos ejemplos de ocultar condiciones en un nodo de diseño ubicado en etc/design o como directiva de contenido.

${cqDesign.myProperty}
${!cqDesign.myProperty}
${cqDesign.myProperty == 'someText'}
${cqDesign.myProperty != 'someText'}
${cqDesign.myProperty == true}
${cqDesign.myProperty == true}
${cqDesign.property1 == 'someText' && cqDesign.property2 || cqDesign.property3 != 1 || header.myHeader}

Al definir la expresión Hide, tenga en cuenta lo siguiente:

  • Para ser válido, el ámbito en el que se encuentra la propiedad debe expresarse (por ejemplo, cqDesign.myProperty).
  • Los valores son de solo lectura.
  • Las funciones (si es necesario) deben limitarse a un conjunto determinado proporcionado por el servicio.

Ejemplos example

AEM Se pueden encontrar ejemplos de condiciones de ocultación en todo el sitio y en los componentes principales en particular. Por ejemplo, considere el componente principal de lista.

Con el editor de plantillas, el autor de la plantilla puede definir en el cuadro de diálogo de diseño qué opciones del componente de lista están disponibles para el autor de la página. Pueden habilitarse o deshabilitarse opciones como permitir que la lista sea una lista estática, una lista de páginas secundarias, una lista de páginas etiquetadas, etc.

Si un autor de una plantilla decide deshabilitar la opción de páginas secundarias, se establece una propiedad de diseño y se evalúa una condición de ocultación con respecto a ella, lo que hace que la opción no se procese para el autor de la página.

  1. De forma predeterminada, el autor de la página puede utilizar el componente principal de la lista para crear una lista con páginas secundarias eligiendo la opción Páginas secundarias.

    chlimage_1-218

  2. En el cuadro de diálogo de diseño del componente principal de lista, el autor de la plantilla puede elegir la opción Deshabilitar elementos secundarios para evitar que se muestre al autor de la página la opción de generar una lista basada en páginas secundarias.

    chlimage_1-219

  3. Se crea un nodo de directiva en /conf/we-retail/settings/wcm/policies/weretail/components/content/list con una propiedad disableChildren establecida en true.

  4. La condición de ocultar se define como el valor de una propiedad granite:hide en el nodo de propiedad de diálogo /conf/we-retail/settings/wcm/policies/weretail/components/content/list

    chlimage_1-220

  5. El valor de disableChildren se extrae de la configuración de diseño y la expresión ${cqDesign.disableChildren} se evalúa como false, lo que significa que la opción no se representará como parte del componente.

    Puede ver la expresión Hide como el valor de la propiedad granite:hide en GitHub.

  6. La opción Páginas secundarias ya no se representa para el autor de la página al usar el componente de lista.

    chlimage_1-221

recommendation-more-help
19ffd973-7af2-44d0-84b5-d547b0dffee2