AEM Información general del editor universal para desarrolladores developer-overview

AEM Si usted es un desarrollador de interesado en cómo funciona el editor universal y cómo utilizarlo en su proyecto, este documento le ofrece una introducción completa al instrumentarlo para que trabaje con el editor universal.

Función purpose

Este documento sirve como introducción para desarrolladores sobre cómo funciona el editor universal y cómo instrumentar la aplicación para que funcione con él.

AEM Para ello, toma un ejemplo estándar con el que la mayoría de los desarrolladores están familiarizados, los componentes principales y el sitio WKND, e instrumenta algunos componentes de ejemplo para que se puedan editar con el editor universal.

TIP
Este documento realiza pasos adicionales para ilustrar cómo funciona el editor universal y tiene la intención de profundizar la comprensión del editor por parte del desarrollador. Por lo tanto, no toma la ruta más directa para instrumentar una aplicación, sino la más ilustrativa del editor universal y cómo funciona.
AEM Si desea ponerse en marcha lo más rápido posible, consulte el documento Introducción al editor universal en la documentación de.

Requisitos previos prerequisites

Para seguir esta descripción general, necesita disponer de lo siguiente.

AEM Más allá de la familiaridad general con el desarrollo web, este documento supone una familiaridad básica con el desarrollo de la. AEM Si no tiene experiencia con el desarrollo de, considere la posibilidad de revisar el tutorial de WKND antes de continuar.

AEM Inicio y inicio de sesión en el editor universal de la aplicación sign-in

AEM Si aún no lo ha hecho, debe tener la instancia de desarrollo local de en ejecución con WKND instalado y HTTPS habilitado como detallado en los requisitos previos. Esta descripción general supone que su instancia se está ejecutando a las https://localhost:8443.

  1. AEM Abra la página principal de WKND en inglés en el Editor de.

    code language-text
    https://localhost:8443/editor.html/content/wknd/language-masters/en.html
    
  2. En el menú Información de la página del editor, seleccione Ver como publicado. AEM Se abrirá la misma página en una nueva pestaña con el Editor de páginas desactivado

    code language-text
    https://localhost:8443/content/wknd/language-masters/en.html?wcmmode=disabled
    
  3. Copie este vínculo.

  4. Ahora inicie sesión en el editor universal.

    code language-text
    https://experience.adobe.com/#/aem/editor
    
  5. Pegue el vínculo que copió anteriormente del contenido de WKND en el campo URL del sitio del editor universal y haga clic en Abrir.

    Abrir la página WKND en el editor universal

El editor universal intenta cargar el contenido sameorigin

El editor universal carga el contenido que se va a editar en un marco. AEM La configuración predeterminada de las opciones de X-Frame lo impide, lo que se puede ver claramente en el explorador como un error y detallado en la salida de la consola al intentar cargar la copia local de WKND.

Error del explorador debido a la opción SAMEORIGIN

AEM La opción X-Frame sameorigin evita que se procesen las páginas de la página de la página dentro de un marco. Debe quitar este encabezado para permitir que las páginas se carguen en el editor universal.

  1. Abra el Administrador de configuración.

    code language-text
    https://localhost:8443/system/console/configMgr
    
  2. Editar la configuración de OSGi org.apache.sling.engine.impl.SlingMainServlet

    Propiedad OSGi para SAMEORIGIN

  3. Elimine la propiedad X-Frame-Options=SAMEORIGIN de la propiedad Encabezados de respuesta adicionales.

  4. Guarde los cambios.

AEM Ahora, si vuelve a cargar el editor universal, verá que se carga la página de la.

TIP

Gestión de cookies del mismo sitio samesite-cookies

AEM Cuando el Editor universal carga la página, se carga en la página de inicio de sesión de la aplicación para asegurarse de que se ha autenticado para realizar cambios.

Sin embargo, no puede iniciar sesión correctamente. Al mostrar la consola del explorador, puede ver que el explorador ha bloqueado la entrada en el marco

Entrada bloqueada

AEM La cookie del token de inicio de sesión se envía a los usuarios como un dominio de terceros. AEM Por lo tanto, se deben permitir las cookies del mismo sitio en los.

  1. Abra el Administrador de configuración.

    code language-text
    https://localhost:8443/system/console/configMgr
    
  2. Editar la configuración de OSGi com.day.crx.security.token.impl.impl.TokenAuthenticationHandler

    propiedad OSGi para cookies del mismo sitio

  3. Cambie la propiedad Atributo SameSite para la cookie de token de inicio de sesión a None.

  4. Guarde los cambios.

AEM Ahora, si vuelve a cargar el editor universal, puede iniciar sesión correctamente en el editor y se cargará la página de destino.

TIP

El editor universal se conecta al marco remoto ue-connect-remote-frame

AEM Con la página cargada en el Editor universal y con la sesión iniciada en el Editor universal, éste intenta conectarse al marco remoto. El Editor universal intenta conectarse a la página desde el Editor universal. Esto se realiza mediante una biblioteca de JavaScript que debe cargarse en el marco remoto. Si la biblioteca JavaScript no está presente, la página crea finalmente un error de tiempo de espera en la consola.

Error de tiempo de espera

Debe añadir la biblioteca JavaScript necesaria al componente Página de la aplicación WKND.

  1. Abra el CRXDE Lite.

    code language-text
    https://localhost:8443/crx/de
    
  2. En /apps/wknd/components/page, edite el archivo customheaderlibs.html.

    Editando el archivo customheaderlibs.html

  3. Añada la biblioteca JavaScript al final del archivo.

    code language-html
    <script src="https://universal-editor-service.experiencecloud.live/corslib/LATEST"></script>
    
  4. Haga clic en Guardar todo y vuelva a cargar el editor universal.

La página ahora se carga con la biblioteca JavaScript adecuada para permitir que el editor universal se conecte a su página y el error de tiempo de espera ya no aparece en la consola.

TIP

Definición de una conexión para mantener los cambios connection

La página WKND ahora se carga correctamente en el editor universal y la biblioteca de JavaScript se carga para conectar el editor a la aplicación.

Sin embargo, es probable que haya observado que no puede interactuar con la página en el editor universal. En realidad, el editor universal no puede editar su página. Para que el editor universal pueda editar el contenido, debe definir una conexión para que sepa dónde escribirlo. AEM Para el desarrollo local, debe volver a escribir en la instancia de desarrollo local de la en https://localhost:8443.

  1. Abra el CRXDE Lite.

    code language-text
    https://localhost:8443/crx/de
    
  2. En /apps/wknd/components/page, edite el archivo customheaderlibs.html.

    Editando el archivo customheaderlibs.html

  3. AEM Añada los metadatos necesarios para la conexión con la instancia de la local al final del archivo.

    code language-html
    <meta name="urn:adobe:aue:system:aem" content="aem:https://localhost:8443">
    
  4. Agregue los metadatos necesarios para la conexión al servicio Editor universal local al final del archivo.

    code language-html
    <meta name="urn:adobe:aue:config:service" content="https://localhost:8000">
    
  5. Haga clic en Guardar todo y vuelva a cargar el editor universal.

AEM Ahora, el editor universal no solo puede cargar el contenido correctamente desde la instancia de desarrollo de la aplicación local, sino que también sabe dónde persistir los cambios que realice con el servicio de editor universal local. Este es el primer paso para instrumentar la aplicación para que se pueda editar con el editor universal.

TIP

Instrumentación de componentes instrumenting-components

Sin embargo, es probable que observe que todavía puede hacer poco con el editor universal. Si intenta hacer clic en el teaser de la parte superior de la página WKND en el editor universal, no puede seleccionarlo (ni nada más en la página).

Los componentes también deben estar instrumentados para poder editarlos con el editor universal. Para ello, debe editar el componente Teaser. Por lo tanto, debe superponer los componentes principales, ya que estos se encuentran en /libs, lo cual es inmutable.

  1. Abra el CRXDE Lite.

    code language-text
    https://localhost:8443/crx/de
    
  2. Seleccione el nodo /libs/core/wcm/components y haga clic en Nodo de superposición en la barra de herramientas.

  3. Con /apps/ seleccionado como Ubicación de superposición, haga clic en Aceptar.

    Superponer el teaser

  4. Seleccione el nodo teaser en /libs/core/wcm/components y haga clic en Copiar en la barra de herramientas.

  5. Seleccione el nodo superpuesto en /apps/core/wcm/components y haga clic en Pegar en la barra de herramientas.

  6. Haga doble clic en el archivo /apps/core/wcm/components/teaser/v2/teaser/teaser.html para editarlo.

    Editando el archivo teaser.html

  7. Al final del primer(a) div en la línea 26 aproximadamente, agregue los detalles de instrumentación para el componente.

    code language-text
    data-aue-resource="urn:aem:${resource.path}"
    data-aue-type="component"
    data-aue-label="Teaser"
    
  8. Haga clic en Guardar todo en la barra de herramientas y vuelva a cargar el editor universal.

  9. En el editor universal, haga clic en el componente teaser en la parte superior de la página y verá que ahora puede seleccionarlo.

  10. Si hace clic en el icono Árbol de contenido en el carril de propiedades del Editor universal, verá que el editor reconoce todos los teasers de la página ahora que la ha instrumentado. El teaser que seleccionó es el resaltado.

    Selección del componente de teaser instrumentado

TIP
Consulte el documento Uso de la fusión de recursos de Sling en Adobe Experience Manager as a Cloud Service para obtener más información sobre la superposición de nodos.

Subcomponentes de instrumento del teaser subcomponents

Ahora puede seleccionar el teaser, pero aún no editarlo. Esto se debe a que el teaser está compuesto por diferentes componentes, como la imagen y el componente de título. Debe instrumentar estos subcomponentes para poder editarlos.

  1. Abra el CRXDE Lite.

    code language-text
    https://localhost:8443/crx/de
    
  2. Seleccione el nodo /apps/core/wcm/components/teaser/v2/teaser/ y haga doble clic en el archivo title.html.

    Editar el archivo title.html

  3. Inserte las siguientes propiedades al final de la etiqueta h2 (cerca de la línea 17).

    code language-text
    data-aue-prop="jcr:title"
    data-aue-type="text"
    data-aue-label="Title"
    
  4. Haga clic en Guardar todo en la barra de herramientas y vuelva a cargar el editor universal.

  5. Haga clic en el título del mismo componente de teaser en la parte superior de la página y verá que ahora puede seleccionarlo. El árbol de contenido también muestra el título como parte del componente teaser seleccionado.

    Seleccionar título dentro del teaser

Ahora puede editar el título del componente Teaser.

¿Qué significa todo esto? what-does-it-mean

Ahora que puede editar el título del teaser, vamos a dedicar un momento a revisar lo que ha logrado y cómo.

Ha identificado el componente teaser en el editor universal mediante su instrumentación.

  • AEM data-aue-resource identifica el recurso en el que se está editando el recurso en el que se está realizando la.
  • data-aue-type define que los elementos deben tratarse como un componente de página (en lugar de, por ejemplo, un contenedor).
  • data-aue-label muestra una etiqueta descriptiva en la interfaz de usuario para el teaser seleccionado.

También ha instrumentado el componente de título dentro del componente teaser.

  • data-aue-prop es el atributo JCR que se escribe.
  • data-aue-type es la forma en que se debe editar el atributo. En este caso, con el editor de texto, ya que es un título (a diferencia de, por ejemplo, el editor de texto enriquecido).

Definición de encabezados de autenticación auth-header

Ahora puede editar el título del teaser en línea y los cambios se mantienen en el explorador.

Título editado del teaser

Sin embargo, si vuelve a cargar el explorador, se vuelve a cargar el título anterior. AEM AEM Esto se debe a que, aunque el editor universal sabe cómo conectarse a la instancia de la, aún no puede autenticarse en la instancia de la para escribir cambios en el JCR.

Si muestra la ficha de red de las herramientas para desarrolladores del explorador y busca update, verá que se encuentra con un error 401 al intentar editar el título.

Error al intentar editar el título

AEM AEM Cuando se utiliza el editor universal para editar el contenido de la producción, el editor universal utiliza el mismo token de IMS que se utilizó para iniciar sesión en el editor para autenticarse y para facilitar la escritura en el JCR. El editor universal utiliza el mismo token de IMS que se utilizó para iniciar sesión en el editor y, a continuación, se autentica para facilitar la escritura en el JCR.

AEM Cuando se desarrolla localmente, no se puede utilizar el proveedor de identidad de, ya que los tokens de IMS solo se pasan a dominios propiedad de la Adobe. Debe proporcionar manualmente una forma de autenticarse configurando explícitamente un encabezado de autenticación.

  1. En la interfaz del editor universal, haga clic en el icono Encabezados de autenticación de la barra de herramientas.

  2. AEM Copie en el encabezado de autenticación necesario para autenticarse en la instancia de local y haga clic en Guardar.

    Configurar encabezados de autenticación

  3. Vuelva a cargar el editor universal y, a continuación, edite el título del teaser.

AEM Ya no se notifican errores en la consola del explorador y los cambios se conservan en la instancia de desarrollo de la local.

Si investiga el tráfico en las herramientas para desarrolladores del explorador y busca los eventos de update, podrá ver los detalles de la actualización.

Se editó correctamente el título del teaser

{
  "connections": [
    {
      "name": "aem",
      "protocol": "aem",
      "uri": "https://localhost:8443"
    }
  ],
  "target": {
    "resource": "urn:aem:/content/wknd/language-masters/en/jcr:content/root/container/carousel/item_1571954853062",
    "type": "text",
    "prop": "jcr:title"
  },
  "value": "Tiny Toon Adventures"
}
  • AEM connections es la conexión con su instancia de local
  • target es el nodo y las propiedades exactos que se actualizan en el JCR
  • value es la actualización que usted hizo.

Puede ver que el cambio persiste en el JCR.

Actualización en el JCR

TIP
Hay muchas herramientas disponibles en línea para generar los encabezados de autenticación necesarios para los fines de prueba y desarrollo.
AEM El ejemplo del encabezado de autenticación básico Basic YWRtaW46YWRtaW4= es para la combinación de usuario y contraseña de admin:admin, como es común en el desarrollo de la local.

Instrumentación de la aplicación para el carril Propiedades properties-rail

Ahora tiene una aplicación instrumentada para poder editarla con el editor universal.

Actualmente, la edición se limita a la edición en línea del título del teaser. Sin embargo, hay casos en los que la edición in situ no es suficiente. El texto, como el título del teaser, se puede editar donde está con la entrada de teclado. Sin embargo, los elementos más complicados deben poder mostrarse y permitir la edición de datos estructurados independientemente de cómo se representen en el explorador. Para esto sirve el carril de propiedades.

Para actualizar la aplicación y utilizar el carril de propiedades para editarla, vuelva al archivo de encabezado del componente de página de la aplicación. AEM Aquí es donde ya ha establecido las conexiones con la instancia de desarrollo de la aplicación local y con el servicio de editor universal local. Aquí debe definir los componentes editables en la aplicación y sus modelos de datos.

  1. Abra el CRXDE Lite.

    code language-text
    https://localhost:8443/crx/de
    
  2. En /apps/wknd/components/page, edite el archivo customheaderlibs.html.

    Editando el archivo customheaderlibs.html

  3. Al final del archivo, añada la secuencia de comandos necesaria para definir los componentes.

    code language-html
    <script type="application/vnd.adobe.aue.component+json">
    {
      "groups": [
        {
          "title": "General Components",
          "id": "general",
          "components": [
            {
              "title": "Teaser",
              "id": "teaser",
              "plugins": {
                "aem": {
                  "page": {
                    "resourceType": "wknd/components/teaser"
                  }
                }
              }
            },
            {
              "title": "Title",
              "id": "title",
              "plugins": {
                "aem": {
                  "page": {
                    "resourceType": "wknd/components/title"
                  }
                }
              }
            }
          ]
        }
      ]
    }
    </script>
    
  4. Debajo, al final del archivo, añada la secuencia de comandos necesaria para definir el modelo.

    code language-html
    <script type="application/vnd.adobe.aue.model+json">
    [
      {
        "id": "teaser",
        "fields": [
          {
            "component": "text-input",
            "name": "jcr:title",
            "label": "Title",
            "valueType": "string"
          },
          {
            "component": "text-area",
            "name": "jcr:description",
            "label": "Description",
            "valueType": "string"
          }
        ]
      },
      {
        "id": "title",
        "fields": [
          {
            "component": "select",
            "name": "type",
            "value": "h1",
            "label": "Type",
            "valueType": "string",
            "options": [
              { "name": "h1", "value": "h1" },
              { "name": "h2", "value": "h2" },
              { "name": "h3", "value": "h3" },
              { "name": "h4", "value": "h4" },
              { "name": "h5", "value": "h5" },
              { "name": "h6", "value": "h6" }
            ]
          }
        ]
      }
    ]
    </script>
    
  5. Haga clic en Guardar todo en la barra de herramientas.

¿Qué significa todo esto? what-does-it-mean-2

Para poder editar con el carril de propiedades, los componentes deben asignarse a groups, de modo que cada definición comience como una lista de grupos que contengan los componentes.

  • title es el nombre del grupo.
  • id es el identificador único del grupo, en este caso componentes generales que componen el contenido de la página en lugar de componentes avanzados para el diseño de página, por ejemplo.

Cada grupo tiene una matriz de components.

  • title es el nombre del componente.
  • id es el identificador único del componente, en este caso un teaser.

AEM A continuación, cada componente tiene una definición de complemento que define cómo se asigna el componente a los elementos de la interfaz de usuario de la interfaz de usuario de.

  • aem es el complemento que administra la edición. Esto se puede considerar como el servicio que procesa el componente.
  • page define qué tipo de componente es, en este caso un componente de página estándar.
  • AEM resourceType es la asignación al componente de la real.

A continuación, cada componente debe asignarse a un model para definir los campos editables individuales.

  • id es el identificador único del modelo, que debe coincidir con el ID del componente.
  • fields es una matriz de campos individuales.
  • component es el tipo de entrada, como texto o área de texto.
  • name es el nombre de campo en el JCR al que está asignado el campo.
  • label es la descripción del campo que aparece en la interfaz de usuario del editor.
  • valueType es el tipo de datos.

Instrumentación del componente para el carril de propiedades properties-rail-component

También debe definir a nivel de componente qué modelo debe utilizar el componente.

  1. Abra el CRXDE Lite.

    code language-text
    https://localhost:8443/crx/de
    
  2. Haga doble clic en el archivo /apps/core/wcm/components/teaser/v2/teaser/teaser.html para editarlo.

    Editando el archivo teaser.html

  3. Al final del primer(a) div, aproximadamente en la línea 32, después de las propiedades agregadas anteriormente, agregue los detalles de instrumentación para el modelo que utilizará el componente teaser.

    code language-text
    data-aue-model="teaser"
    
  4. Haga clic en Guardar todo en la barra de herramientas y vuelva a cargar el editor universal.

Ahora está listo para probar el carril de propiedades instrumentado para su componente.

  1. En el editor universal, haga clic en el título del teaser para editarlo una vez más.

  2. Haga clic en el carril de propiedades para mostrar la pestaña de propiedades y ver los campos que acaba de instrumentar.

    El carril de propiedades instrumentadas

Ahora puede editar el título del teaser en línea como lo había hecho anteriormente o en el carril de propiedades. AEM En ambos casos, los cambios se conservan en la instancia de desarrollo de la comunidad local de la que se haya realizado el.

Añadir campos adicionales al carril Propiedades add-fields

Con la estructura básica del modelo de datos para el componente que ya ha implementado, puede agregar campos adicionales siguiendo el mismo modelo.

Por ejemplo, puede añadir un campo para ajustar el estilo del componente.

  1. Abra el CRXDE Lite.

    code language-text
    https://localhost:8443/crx/de
    
  2. En /apps/wknd/components/page, edite el archivo customheaderlibs.html.

    Editando el archivo customheaderlibs.html

  3. En el script de definición del modelo, agregue un elemento adicional a la matriz fields para el campo de estilo. Recuerde agregar una coma después del último campo antes de insertar el nuevo.

    code language-json
    {
       "component": "select",
       "name": "cq:styleIds",
       "label": "Style",
       "valueType": "string",
         "multi": true,
       "options": [
         {"name": "hero", "value":"1555543212672"},
         {"name": "card", "value":"1605057868937"}
       ]
    }
    
  4. Haga clic en Guardar todo en la barra de herramientas y vuelva a cargar el editor universal.

  5. Haga clic en el título del teaser para editarlo una vez más.

  6. Haga clic en el carril de propiedades y verá que hay un nuevo campo para ajustar el estilo del componente.

    El carril de propiedades instrumentadas con el campo de estilo

Cualquier campo del JCR del componente se puede exponer en el editor universal de esta manera.

Resumen summary

Enhorabuena. AEM Ahora puede instrumentar sus propias aplicaciones de para que funcionen con el editor universal.

Cuando empiece a instrumentar su propia aplicación, tenga en cuenta los pasos básicos que ha realizado en este ejemplo.

Puede seguir los mismos pasos para instrumentar su propia aplicación y utilizarla con el editor universal. Todas las propiedades del JCR se pueden exponer al editor universal.

Recursos adicionales additional-resources

Consulte los siguientes documentos para obtener más información y detalles sobre las funciones del editor universal.

recommendation-more-help
fbcff2a9-b6fe-4574-b04a-21e75df764ab