Personalizzare i componenti core dell’CIF dell’AEM customize-cif-components
Il progetto CIF Venia è una base di codice di riferimento per l'utilizzo di componenti core CIF. In questa esercitazione, estendi ulteriormente il componente Product Teaser per visualizzare un attributo personalizzato da Adobe Commerce. Scopri anche l’integrazione di GraphQL tra AEM e Adobe Commerce e gli hook di estensione forniti dai componenti core CIF.
Cosa verrà creato
Il marchio Venia ha recentemente iniziato a produrre alcuni prodotti utilizzando materiali sostenibili e l'azienda desidera mostrare un distintivo eco-friendly come parte del Product Teaser. In Adobe Commerce viene creato un nuovo attributo personalizzato per indicare se un prodotto utilizza il materiale Eco friendly. Questo attributo personalizzato viene aggiunto come parte della query GraphQL e visualizzato nel Product Teaser per i prodotti specificati.
Prerequisiti prerequisites
Per completare questa esercitazione è necessario un ambiente di sviluppo locale. Questo ambiente include un’istanza in esecuzione dell’AEM configurata e connessa a un’istanza Adobe Commerce. Rivedi i requisiti e i passaggi per configurare uno sviluppo locale con AEM as a Cloud Service SDK. Per seguire completamente l'esercitazione, è necessario disporre dell'autorizzazione per aggiungere Attributi a un prodotto in Adobe Commerce.
Per eseguire gli esempi di codice e i tutorial è inoltre necessario GraphQL IDE, ad esempio GraphiQL o un'estensione del browser. Se installi un’estensione del browser, accertati che possa impostare le intestazioni della richiesta. In Google Chrome, Altair GraphQL Client è un'estensione in grado di eseguire il processo.
Clonare il progetto Venia clone-venia-project
Clonare il Progetto Venia, quindi sostituire gli stili predefiniti.
-
Esegui il seguente comando Git per clonare il progetto:
code language-shell $ git clone git@github.com:adobe/aem-cif-guides-venia.git
-
Crea e implementa il progetto in un’istanza locale di AEM:
code language-shell $ cd aem-cif-guides-venia/ $ mvn clean install -PautoInstallSinglePackage,cloud
-
Aggiungi le configurazioni OSGi necessarie per collegare l’istanza AEM a un’istanza Adobe Commerce o aggiungi le configurazioni al progetto creato.
-
A questo punto, devi disporre di una versione funzionante di una vetrina connessa a un’istanza di Adobe Commerce. Passare alla pagina
US
>Home
all'indirizzo: http://localhost:4502/editor.html/content/venia/us/en.html.Dovresti vedere che la vetrina si basa al momento sul tema Venia. Espandendo il menu principale della vetrina, dovresti vedere diverse categorie, a indicare che la connessione ad Adobe Commerce funziona.
Creare il Product Teaser author-product-teaser
Il componente Product Teaser viene esteso in tutta questa esercitazione. Come primo passo, aggiungi un’istanza del Product Teaser alla home page per comprenderne le funzionalità della linea di base.
-
Passa alla home page del sito: http://localhost:4502/editor.html/content/acme/us/en.html
-
Inserisci un nuovo componente Product Teaser nel contenitore di layout principale della pagina.
-
Espandi il pannello laterale (se non è già attivato) e imposta l'elenco a discesa di ricerca risorse su Prodotti. In questo elenco dovrebbe essere visualizzato un elenco dei prodotti disponibili da un’istanza di Adobe Commerce connessa. Seleziona un prodotto e trascinalo sul componente Product Teaser nella pagina.
note note NOTE Puoi anche configurare il prodotto visualizzato impostando il componente tramite la finestra di dialogo (clic sull’icona a forma di chiave inglese). -
Ora puoi vedere un prodotto visualizzato dal Product Teaser. Il nome del prodotto e il prezzo del prodotto sono attributi predefiniti visualizzati.
Aggiungere un attributo personalizzato in Adobe Commerce add-custom-attribute
I prodotti e i dati dei prodotti visualizzati nell’AEM sono memorizzati in Adobe Commerce. Quindi aggiungi un attributo per Eco Friendly come parte dell'attributo del prodotto impostato utilizzando l'interfaccia utente di Adobe Commerce.
-
Accedi all’istanza di Adobe Commerce.
-
Passa a Catalogo > Prodotti.
-
Aggiorna il filtro di ricerca in modo da trovare il prodotto configurabile utilizzato quando aggiunto al componente Teaser nell'esercizio precedente. Apri il prodotto in modalità di modifica.
-
Dalla visualizzazione del prodotto, fare clic su Aggiungi attributo > Crea nuovo attributo.
-
Compila il modulo Nuovo attributo con i seguenti valori (lascia le impostazioni predefinite per gli altri valori)
table 0-row-3 1-row-3 2-row-3 3-row-3 Set di campi Etichetta campo Valore Proprietà attributo Etichetta attributo Rispettoso Dell'Ambiente Proprietà attributo Tipo di input catalogo Sì/No Proprietà attributi avanzate Codice attributo ecologico Al termine, fai clic su Salva attributo.
-
Scorri fino alla parte inferiore del prodotto ed espandi l'intestazione Attributi. Dovresti visualizzare il nuovo campo Eco-friendly. Passa a Sì.
Salva le modifiche apportate al prodotto.
note tip TIP Ulteriori dettagli sulla gestione di Attributi del prodotto sono disponibili nella guida utente di Adobe Commerce. -
Passa a Sistema > Strumenti > Gestione cache. Poiché è stato effettuato un aggiornamento allo schema dati, è necessario invalidare alcuni dei tipi di cache in Adobe Commerce.
-
Seleziona la casella accanto a Configurazione e invia il tipo di cache per Aggiornamento
note tip TIP Ulteriori dettagli su Gestione cache sono disponibili nella guida utente di Adobe Commerce.
Utilizzare un IDE GraphQL per verificare l'attributo use-graphql-ide
Prima di passare al codice AEM, è utile esplorare la Panoramica di GraphQL utilizzando un IDE GraphQL. L’integrazione di Adobe Commerce con l’AEM viene eseguita principalmente tramite una serie di query GraphQL. Comprendere e modificare le query di GraphQL è uno dei modi chiave con cui è possibile estendere i Componenti core dell’CIF.
Utilizzare quindi un IDE di GraphQL per verificare che l'attributo eco_friendly
sia stato aggiunto al set di attributi del prodotto. Le schermate di questo tutorial utilizzano l'estensione Altair GraphQL Client Google Chrome.
-
Aprire GraphQL IDE e immettere l'URL
http://<commerce-server>/graphql
nella barra dell'URL dell'IDE o dell'estensione. -
Aggiungi la seguente query prodotti dove
YOUR_SKU
è il SKU del prodotto utilizzato nell'esercizio precedente:code language-json { products( filter: { sku: { eq: "YOUR_SKU" } } ) { items { name sku eco_friendly } } }
-
Esegui la query e dovresti ricevere una risposta simile alla seguente:
code language-json { "data": { "products": { "items": [ { "name": "Valeria Two-Layer Tank", "sku": "VT11", "eco_friendly": 1 } ] } } }
Il valore di Yes è un numero intero di 1. Questo valore è utile quando scrivi la query GraphQL in Java™.
note tip TIP Ulteriori informazioni su Adobe Commerce GraphQL qui.
Aggiornare il modello Sling per Product Teaser updating-sling-model-product-teaser
Ora puoi estendere la logica di business del Product Teaser implementando un modello Sling. I modelli Sling sono "POJO" (Plain Old Java™ Objects) basati su annotazioni che implementano la logica di business necessaria per il componente. I modelli Sling vengono utilizzati con gli script HTL come parte del componente. Segui il pattern di delega per modelli Sling in modo da estendere parti del modello esistente di Product Teaser.
I modelli Sling sono implementati come Java™ e si trovano nel modulo core del progetto generato.
Utilizza l'IDE che preferisci per importare il progetto Venia. Le schermate utilizzate provengono dall'IDE codice di Visual Studio.
-
Nell'IDE, passa al modulo core fino a:
core/src/main/java/com/venia/core/models/commerce/MyProductTeaser.java
.MyProductTeaser.java
è un'interfaccia Java™ che estende l'interfaccia CIF ProductTeaser.È già stato aggiunto un nuovo metodo denominato
isShowBadge()
per visualizzare un badge se il prodotto è considerato "Nuovo". -
Aggiungi
isEcoFriendly()
all'interfaccia:code language-java @ProviderType public interface MyProductTeaser extends ProductTeaser { // Extend the existing interface with the additional properties which you // want to expose to the HTL template. public Boolean isShowBadge(); public Boolean isEcoFriendly(); }
Questo nuovo metodo viene introdotto per incapsulare la logica per indicare se l'attributo
eco_friendly
del prodotto è impostato su Yes o No. -
Quindi, controllare
MyProductTeaserImpl.java
allecore/src/main/java/com/venia/core/models/commerce/MyProductTeaserImpl.java
.Il pattern di delega per modelli Sling consente a
MyProductTeaserImpl
di fare riferimento al modelloProductTeaser
tramite la proprietàsling:resourceSuperType
:code language-java @Self @Via(type = ResourceSuperType.class) private ProductTeaser productTeaser;
Per i metodi che non si desidera ignorare o modificare, è possibile restituire il valore restituito da
ProductTeaser
. Ad esempio:code language-java @Override public String getImage() { return productTeaser.getImage(); }
Questo metodo riduce al minimo la quantità di codice Java™ che un’implementazione deve scrivere.
-
Uno dei punti di estensione aggiuntivi forniti dai componenti core CIF dell'AEM è
AbstractProductRetriever
, che fornisce l'accesso ad attributi di prodotto specifici. Inspect il metodoinitModel()
:code language-java import javax.annotation.PostConstruct; ... @Model(adaptables = SlingHttpServletRequest.class, adapters = MyProductTeaser.class, resourceType = MyProductTeaserImpl.RESOURCE_TYPE) public class MyProductTeaserImpl implements MyProductTeaser { ... private AbstractProductRetriever productRetriever; /* add this method to initialize the productRetriever */ @PostConstruct public void initModel() { productRetriever = productTeaser.getProductRetriever(); if (productRetriever != null) { productRetriever.extendProductQueryWith(p -> p.createdAt()); } } ...
L'annotazione
@PostConstruct
assicura che questo metodo venga chiamato quando il modello Sling viene inizializzato.La query GraphQL del prodotto è già stata estesa utilizzando il metodo
extendProductQueryWith
per recuperare l'attributo aggiuntivocreated_at
. Questo attributo viene successivamente utilizzato come parte del metodoisShowBadge()
. -
Aggiornare la query GraphQL per includere l'attributo
eco_friendly
nella query parziale:code language-java //MyProductTeaserImpl.java private static final String ECO_FRIENDLY_ATTRIBUTE = "eco_friendly"; @PostConstruct public void initModel() { productRetriever = productTeaser.getProductRetriever(); if (productRetriever != null) { productRetriever.extendProductQueryWith(p -> p .createdAt() .addCustomSimpleField(ECO_FRIENDLY_ATTRIBUTE) ); } }
L'aggiunta al metodo
extendProductQueryWith
è un modo potente per garantire che gli attributi di prodotto aggiuntivi siano disponibili per il resto del modello. Inoltre si riduce la quantità di query eseguite.Nel codice precedente,
addCustomSimpleField
viene utilizzato per recuperare l'attributoeco_friendly
. Questo attributo illustra come eseguire una query per gli attributi personalizzati che fanno parte dello schema di Adobe Commerce.note note NOTE Il metodo createdAt()
è stato implementato come parte dell'interfaccia prodotto. La maggior parte degli attributi dello schema comunemente trovati è già stata implementata, quindi utilizza solo gli attributiaddCustomSimpleField
per gli attributi realmente personalizzati. -
Aggiungi un logger per eseguire il debug del codice Java™:
code language-java import org.slf4j.Logger; import org.slf4j.LoggerFactory; ... @Model(adaptables = SlingHttpServletRequest.class, adapters = MyProductTeaser.class, resourceType = MyProductTeaserImpl.RESOURCE_TYPE) public class MyProductTeaserImpl implements MyProductTeaser { private static final Logger LOGGER = LoggerFactory.getLogger(MyProductTeaserImpl.class);
-
Quindi, implementare il metodo
isEcoFriendly()
:code language-java @Override public Boolean isEcoFriendly() { Integer ecoFriendlyValue; try { ecoFriendlyValue = productRetriever.fetchProduct().getAsInteger(ECO_FRIENDLY_ATTRIBUTE); if(ecoFriendlyValue != null && ecoFriendlyValue.equals(Integer.valueOf(1))) { LOGGER.info("*** Product is Eco Friendly**"); return true; } } catch (SchemaViolationError e) { LOGGER.error("Error retrieving eco friendly attribute"); } LOGGER.info("*** Product is not Eco Friendly**"); return false; }
Nel metodo precedente, viene utilizzato
productRetriever
per recuperare il prodotto e il metodogetAsInteger()
per ottenere il valore dell'attributoeco_friendly
. In base alle query GraphQL eseguite in precedenza, si sa che il valore previsto quando l'attributoeco_friendly
è impostato su "Yes" è in realtà un numero intero di 1.Ora che il modello Sling è stato aggiornato, è necessario aggiornare il markup del componente per visualizzare effettivamente un indicatore di Rispettoso dell'ambiente basato sul modello Sling.
Personalizzazione del markup del Product Teaser customize-markup-product-teaser
I componenti AEM vengono spesso estesi per modificare il markup generato dal componente. Questa modifica viene eseguita eseguendo l'override dello script HTL utilizzato dal componente per eseguire il rendering del relativo markup. HTL (HTML Template Language) è un linguaggio per modelli leggero utilizzato dai componenti AEM per eseguire il rendering dinamico del markup in base al contenuto creato, che consente di riutilizzare i componenti. Il Product Teaser, ad esempio, può essere riutilizzato più volte per visualizzare prodotti diversi.
In questo caso, desideri applicare un banner sopra il teaser per indicare che il prodotto è "eco-compatibile" in base a un attributo personalizzato. Il modello di progettazione per personalizzare il markup di un componente è standard per tutti i componenti AEM, non solo per i componenti core CIF dell'AEM.
cif.shell.picker
richiesta per le finestre di dialogo del componente. Per informazioni dettagliate, consulta Utilizzo del selettore di prodotti e categorie CIF.-
Nell'IDE, spostarsi ed espandere il modulo
ui.apps
, espandere la gerarchia delle cartelle inui.apps/src/main/content/jcr_root/apps/venia/components/commerce/productteaser
e controllare il file.content.xml
.code language-xml <?xml version="1.0" encoding="UTF-8"?> <jcr:root xmlns:sling="http://sling.apache.org/jcr/sling/1.0" xmlns:cq="http://www.day.com/jcr/cq/1.0" xmlns:jcr="http://www.jcp.org/jcr/1.0" jcr:description="Product Teaser Component" jcr:primaryType="cq:Component" jcr:title="Product Teaser" sling:resourceSuperType="core/cif/components/commerce/productteaser/v1/productteaser" componentGroup="Venia - Commerce"/>
La definizione del componente precedente si riferisce al componente Product Teaser nel progetto. Osserva la proprietà
sling:resourceSuperType="core/cif/components/commerce/productteaser/v1/productteaser"
. Questa proprietà è un esempio di creazione di un componente proxy. Invece di copiare e incollare gli script HTL di Product Teaser dai componenti core CIF dell’AEM, puoi utilizzaresling:resourceSuperType
per ereditare tutte le funzionalità. -
Aprire il file
productteaser.html
. Questo file è una copia del fileproductteaser.html
dal Product Teaser CIF.code language-html <!--/* productteaser.html */--> <sly data-sly-use.product="com.venia.core.models.commerce.MyProductTeaser" data-sly-use.templates="core/wcm/components/commons/v1/templates.html" data-sly-use.actionsTpl="actions.html" data-sly-test.isConfigured="${properties.selection}" data-sly-test.hasProduct="${product.url}" ></sly>
Il modello Sling per
MyProductTeaser
è utilizzato e assegnato alla variabileproduct
. -
Modificare
productteaser.html
in modo da poter chiamare il metodoisEcoFriendly
implementato nell'esercizio precedente:code language-html ... <div data-sly-test="${isConfigured && hasProduct}" class="item__root" data-cmp-is="productteaser" data-virtual="${product.virtualProduct}" > <div data-sly-test="${product.showBadge}" class="item__badge"> <span>${properties.text || 'New'}</span> </div> <!--/* Insert call to Eco Friendly here */--> <div data-sly-test="${product.ecoFriendly}" class="item__eco"> <span>Eco Friendly</span> </div> ... </div>
Quando si chiama un metodo Sling Model in HTL, la parte
get
eis
del metodo viene eliminata e la prima lettera viene convertita in minuscolo.isShowBadge()
diventa.showBadge
eisEcoFriendly
diventa.ecoFriendly
. In base al valore booleano restituito da.isEcoFriendly()
determina se<span>Eco Friendly</span>
è visualizzato.Ulteriori informazioni su
data-sly-test
e altre istruzioni di blocco HTL sono disponibili qui. -
Salva le modifiche e distribuisci gli aggiornamenti a AEM utilizzando le tue competenze Maven, da un terminale della riga di comando:
code language-shell $ cd aem-cif-guides-venia/ $ mvn clean install -PautoInstallSinglePackage,cloud
-
Apri una nuova finestra del browser e passa a AEM e alla console OSGi > Stato > Modelli Sling: http://localhost:4502/system/console/status-slingmodels
-
Cerca
MyProductTeaserImpl
e dovresti vedere una riga come la seguente:code language-plain com.venia.core.models.commerce.MyProductTeaserImpl - venia/components/commerce/productteaser
Questa riga indica che il modello Sling è correttamente distribuito e mappato al componente corretto.
-
Aggiorna alla home page di Venia all'indirizzo http://localhost:4502/editor.html/content/venia/us/en.html in cui è stato aggiunto il Product Teaser.
Se l'attributo
eco_friendly
del prodotto è impostato su Yes, nella pagina dovrebbe essere visualizzato il testo "Eco-friendly". Prova a passare a prodotti diversi per vedere come cambia il comportamento. -
Aprire quindi l'AEM
error.log
per visualizzare le istruzioni di registro aggiunte.error.log
è in<AEM SDK Install Location>/crx-quickstart/logs/error.log
.Cerca nei registri AEM per visualizzare le istruzioni di registro aggiunte nel modello Sling:
code language-plain 2020-08-28 12:57:03.114 INFO [com.venia.core.models.commerce.MyProductTeaserImpl] *** Product is Eco Friendly** ... 2020-08-28 13:01:00.271 INFO [com.venia.core.models.commerce.MyProductTeaserImpl] *** Product is not Eco Friendly** ...
note caution CAUTION È inoltre possibile che vengano visualizzate alcune tracce dello stack se il prodotto utilizzato nel teaser non include l'attributo eco_friendly
come parte del relativo set di attributi.
Aggiungi stili per il badge eco-compatibile add-styles
A questo punto, la logica per la visualizzazione del badge Rispettoso dell'ambiente funziona, ma il testo normale potrebbe utilizzare alcuni stili. Aggiungere quindi un'icona e gli stili al modulo ui.frontend
per completare l'implementazione.
-
Scarica il file eco_friendly.svg. Questo file viene utilizzato come badge Rispettoso dell'ambiente.
-
Tornare all'IDE e passare alla cartella
ui.frontend
. -
Aggiungere il file
eco_friendly.svg
alla cartellaui.frontend/src/main/resources/images
: -
Aprire il file
productteaser.scss
inui.frontend/src/main/styles/commerce/_productteaser.scss
. -
Aggiungere le regole Sass seguenti nella classe
.productteaser
:code language-scss .productteaser { ... .item__eco { width: 60px; height: 60px; left: 0px; overflow: hidden; position: absolute; padding: 5px; span { display: block; position: absolute; width: 45px; height: 45px; text-indent: -9999px; background: no-repeat center center url('../resources/images/eco_friendly.svg'); } } ... }
note note NOTE Consulta Personalizzazione dello stile dei componenti core CIF per ulteriori dettagli sui flussi di lavoro front-end. -
Salva le modifiche e distribuisci gli aggiornamenti a AEM utilizzando le tue competenze Maven, da un terminale della riga di comando:
code language-shell $ cd aem-cif-guides-venia/ $ mvn clean install -PautoInstallSinglePackage,cloud
-
Aggiorna alla home page di Venia all'indirizzo http://localhost:4502/editor.html/content/venia/us/en.html in cui è stato aggiunto il Product Teaser.
Complimenti congratulations
Hai personalizzato il tuo primo componente AEM CIF. Scarica i file della soluzione completati qui.
Sfida bonus bonus-challenge
Esamina la funzionalità del badge Nuovo che è già stato implementato nel Product Teaser. Prova ad aggiungere una casella di controllo aggiuntiva per consentire agli autori di controllare quando deve essere visualizzato il badge Rispettoso dell'ambiente. Aggiorna la finestra di dialogo del componente in ui.apps/src/main/content/jcr_root/apps/venia/components/commerce/productteaser/_cq_dialog/.content.xml
.