Personalización de la creación de páginas
- Temas:
- Developing
Creado para:
- Developer
AEM proporciona varios mecanismos para permitirle personalizar la funcionalidad de creación de páginas (y el consolas) de la instancia de creación.
-
Clientlibs
Clientlibs le permite ampliar la implementación predeterminada para realizar nuevas funciones, mientras reutiliza las funciones, objetos y métodos estándar. Al personalizar, puede crear su propia clientlib en
/apps.
La nueva clientlib debe:- dependen de la clientlib de creación
cq.authoring.editor.sites.page
- formar parte de las
cq.authoring.editor.sites.page.hook
categoría
- dependen de la clientlib de creación
-
Superposiciones
Las superposiciones se basan en definiciones de nodos y permiten superponer la funcionalidad estándar (en
/libs
) con su propia funcionalidad personalizada (en/apps
). Al crear una superposición, no se requiere una copia 1:1 del original, ya que la función fusión de recursos de sling permite la herencia.
Se pueden utilizar de muchas maneras para ampliar la funcionalidad de creación de páginas en la instancia de AEM. A continuación se explica una selección (de alto nivel).
- Uso y creación clientlibs.
- Uso y creación superposiciones.
- Granite
- Estructura de la interfaz de usuario táctil AEM para obtener más información sobre las áreas estructurales utilizadas para la creación de páginas.
/libs
ruta./libs
se sobrescribe la próxima vez que actualice la instancia (y puede sobrescribirse al aplicar una corrección o un paquete de funciones).- Volver a crear el elemento requerido (es decir, tal como existe en
/libs
) en/apps
- Realice cambios dentro de
/apps
Añadir nueva capa (modo)
Al editar una página, existen varios modos disponible. Estos modos se implementan utilizando capas. Permiten acceder a diferentes tipos de funcionalidad para el mismo contenido de página. Las capas estándar son: editar, previsualizar, anotar, desarrollar y segmentar.
Ejemplo de capa: Estado de Live Copy
Una instancia de AEM estándar proporciona la capa MSM. Esto accede a los datos relacionados con administración de varios sitios y lo resalta en la capa.
Para verla en acción, puede editar cualquier Copia de idioma de We.Retail (o cualquier otra página de Live Copy) y seleccione la Estado de Live Copy en el menú contextual.
Puede encontrar la definición de capa MSM (como referencia) en:
/libs/wcm/msm/content/touch-ui/authoring/editor/js/msm.Layer.js
Ejemplo de código
Este es un paquete de muestra que muestra cómo crear una nueva capa (modo), que es una nueva capa para la vista MSM.
CÓDIGO DE GITHUB
Puede encontrar el código de esta página en GitHub
- Abra el proyecto aem-authoring-new-layer-mode en GitHub
- Descargue el proyecto como un archivo ZIP
Añadir nueva categoría de selección al navegador de recursos
El navegador de recursos muestra recursos de distintos tipos o categorías (p. ej., imágenes, documentos, etc.). Los recursos también se pueden filtrar por estas categorías de recursos.
Ejemplo de código
aem-authoring-extension-assetfinder-flickr
es un paquete de muestra que muestra cómo agregar un nuevo grupo al buscador de recursos. Este ejemplo se conecta a Flickrdel flujo público de y los muestra en el panel lateral.
CÓDIGO DE GITHUB
Puede encontrar el código de esta página en GitHub
- Abra el proyecto aem-authoring-extension-assetfinder-flickr en GitHub
- Descargue el proyecto como un archivo ZIP
Filtrado de recursos
Al crear páginas, el usuario debe seleccionar a menudo entre los recursos (p. ej. páginas, componentes, recursos, etc.). Esto puede tomar la forma de una lista, por ejemplo, desde la cual el autor debe elegir un elemento.
Para mantener la lista en un tamaño razonable y también relevante para el caso de uso, se puede implementar un filtro en forma de predicado personalizado. Por ejemplo, si la variable pathbrowser
Granite se utiliza para permitir al usuario seleccionar la ruta a un recurso en particular, las rutas presentadas se pueden filtrar de la siguiente manera:
- Implementar el predicado personalizado implementando
com.day.cq.commons.predicate.AbstractNodePredicate
interfaz. - Especifique un nombre para el predicado y haga referencia a ese nombre al usar la variable
pathbrowser
.
Para obtener más información sobre la creación de un predicado personalizado, consulte este artículo.
com.day.cq.commons.predicate.AbstractNodePredicate
también funciona en la IU clásica.Añadir nueva acción a una barra de herramientas de componentes
Cada componente (normalmente) tiene una barra de herramientas que proporciona acceso a una serie de acciones que se pueden realizar en ese componente.
Ejemplo de código
aem-authoring-extension-toolbar-screenshot
es un paquete de ejemplo que muestra cómo crear una acción de barra de herramientas personalizada para procesar componentes.
CÓDIGO DE GITHUB
Puede encontrar el código de esta página en GitHub
- Abra el proyecto aem-authoring-extension-toolbar-screenshot en GitHub
- Descargue el proyecto como un archivo ZIP
Agregar nuevo editor local
Editor local estándar
En una instalación estándar de AEM:
-
/libs/cq/gui/components/authoring/editors/clientlibs/core/js/editors/editorExample.js
Contiene definiciones de los distintos editores disponibles.
-
Hay una conexión entre el editor y cada tipo de recurso (como en el componente) que puede usarlo:
-
cq:inplaceEditing
por ejemplo:
-
/libs/foundation/components/text/cq:editConfig
-
/libs/foundation/components/image/cq:editConfig
-
propiedad:
editorType
Define el tipo de editor en línea que se utilizará cuando se active la edición in situ para ese componente; p. ej.
text
,textimage
,image
,title
.
-
-
-
-
Los detalles de configuración adicionales del editor se pueden configurar mediante un
config
nodo que contiene configuraciones, así como unplugin
para contener los detalles necesarios de configuración del complemento.A continuación se muestra un ejemplo de definición de relaciones de aspecto para el complemento de recorte de imágenes del componente de imagen. Tenga en cuenta que debido al potencial de un tamaño de pantalla muy limitado, las proporciones de aspecto de recorte se han movido al editor de pantalla completa y solo se pueden ver allí.
<cq:inplaceEditing jcr:primaryType="cq:InplaceEditingConfig" active="{Boolean}true" editorType="image"> <config jcr:primaryType="nt:unstructured"> <plugins jcr:primaryType="nt:unstructured"> <crop jcr:primaryType="nt:unstructured"> <aspectRatios jcr:primaryType="nt:unstructured"> <_x0031_6-10 jcr:primaryType="nt:unstructured" name="16 : 10" ratio="0.625"/> </aspectRatios> </crop> </plugins> </config> </cq:inplaceEditing>
CAUTIONTenga en cuenta que en AEM proporciones de recorte, tal como establece elratio
, se definen como altura/anchura. Esto difiere de la definición convencional de anchura/altura y se realiza por motivos de compatibilidad con sistemas anteriores. Los usuarios de creación no notarán ninguna diferencia siempre que defina la variablename
claramente, ya que esto es lo que se muestra en la interfaz de usuario.
Creación de un nuevo editor local
Para implementar un nuevo editor in situ (dentro de su clientlib):
/libs/cq/gui/components/authoring/editors/clientlibs/core/js/editors/editorExample.js
-
Implementar:
setUp
tearDown
-
Registre el editor (incluye el constructor):
editor.register
-
Proporcione la conexión entre el editor y cada tipo de recurso (como en el componente) que pueda utilizarlo.
Ejemplo de código para crear un nuevo editor in-situ
aem-authoring-extension-inplace-editor
es un paquete de muestra que muestra cómo crear un nuevo editor in situ en AEM.
CÓDIGO DE GITHUB
Puede encontrar el código de esta página en GitHub
- Abra el proyecto aem-authoring-extension-inplace-editor en GitHub
- Descargue el proyecto como un archivo ZIP
Configuración de varios editores in situ
Es posible configurar un componente para que tenga varios editores in situ. Cuando se configuran varios editores in situ, puede seleccionar el contenido adecuado y abrir el editor adecuado. Consulte la Configuración de varios editores in situ documentación para obtener más información.
Agregar una acción de nueva página
Para agregar una nueva acción de página a la barra de herramientas de la página, por ejemplo, una Volver a Sitios (consola).
Ejemplo de código
aem-authoring-extension-header-backtosites
es un paquete de ejemplo que muestra cómo crear una acción de barra de encabezado personalizada para volver a la consola Sitios .
CÓDIGO DE GITHUB
Puede encontrar el código de esta página en GitHub
- Abra el proyecto aem-authoring-extension-header-backtosites en GitHub
- Descargue el proyecto como un archivo ZIP
Personalización del flujo de trabajo de solicitud de activación
Flujo de trabajo integrado, Solicitud de activación, se activa automáticamente cuando un autor de contenido no tiene los derechos de replicación adecuados.
Para tener un comportamiento personalizado tras dicha activación, puede superponer la variable Solicitud de activación flujo de trabajo:
-
En
/apps
superponga el Sitios asistente:/libs/wcm/core/content/common/managepublicationwizard
NOTEEsto, en sí, anula la instancia común de:/libs/cq/gui/content/common/managepublicationwizard
-
Actualice el modelo de flujo de trabajo y configuraciones/scripts relacionados según sea necesario.
-
Quite la derecha a la
replicate
acción de todos los usuarios adecuados para todas las páginas relevantes; para que este flujo de trabajo se active como acción predeterminada cuando cualquiera de los usuarios intente publicar (o replicar) una página.