Assistants gs-helpers
Valeur de secours par défaut default-value
L’helper Default Fallback Value est utilisé pour renvoyer une valeur de secours par défaut si un attribut est vide ou nul. Ce mécanisme fonctionne pour les attributs de profil et les événements de parcours.
Syntaxe
Hello {%=profile.personalEmail.name.firstName ?: "there" %}!
            Dans cet exemple, la valeur there s'affiche si l'attribut firstName de ce profil est vide ou nul.
Conditions if-function
L'helper if est utilisé pour définir un bloc conditionnel.
Si l'évaluation de l'expression renvoie true, le bloc est rendu, sinon il est ignoré.
Syntaxe
{%#if contains(profile.personalEmail.address, ".edu")%}
<a href="https://www.adobe.com/academia">Check out this link</a>
            À la suite de l'helper if, vous pouvez saisir une instruction else pour spécifier un bloc de code à exécuter, si la même condition est false.
L'instruction elseif spécifie une nouvelle condition à tester si la première instruction renvoie false.
Format
{
    {
        {%#if condition1%} element_1
        {%else if condition2%} element_2
        {%else%} default_element
        {%/if%}
    }
}
            Exemples
- 
                  
Générer différents liens de boutique en fonction d'expressions conditionnelles
code language-sql {%#if profile.homeAddress.countryCode = "FR"%} <a href="https://www.somedomain.com/fr">Consultez notre catalogue</a> {%else%} <a href="https://www.somedomain.com/en">Checkout our catalogue</a> {%/if%} - 
                  
Déterminer l'extension d'adresse e-mail
code language-sql {%#if contains(profile.personalEmail.address, ".edu")%} <a href="https://www.adobe.com/academia">Checkout our page for Academia personals</a> {%else if contains(profile.personalEmail.address, ".org")%} <a href="https://www.adobe.com/orgs">Checkout our page for Non Profits</a> {%else%} <a href="https://www.adobe.com/users">Checkout our page</a> {%/if%} - 
                  
Ajout d'un lien conditionnel
L'opération suivante ajoutera un lien vers le site Web 'www.adobe.com/academia' pour les profils avec des adresses e-mail '.edu' uniquement, vers le site Web 'www.adobe.com/org' pour les profils avec des adresses e-mail '.org', et l'URL par défaut 'www.adobe.com/users' pour tous les autres profils :
code language-sql {%#if contains(profile.personalEmail.address, ".edu")%} <a href="https://www.adobe.com/academia">Checkout our page for Academia personals</a> {%else if contains(profile.personalEmail.address, ".org")%} <a href="https://www.adobe.com/orgs">Checkout our page for Non Profits</a> {%else%} <a href="https://www.adobe.com/users">Checkout our page</a> {%/if%} - 
                  
Contenu conditionnel basé sur l’appartenance à une audience
code language-sql {%#if profile.segmentMembership.get("ups").get("5fd513d7-d6cf-4ea2-856a-585150041a8b").status = "existing"%} Hi! Esteemed gold member. <a href="https://www.somedomain.com/gold">Checkout your exclusive perks </a> {%else if profile.segmentMembership.get("ups").get("5fd513d7-d6cf-4ea2-856a-585150041a8c").status = "existing"%} Hi! Esteemed silver member. <a href="https://www.somedomain.com/silver">Checkout your exclusive perks </a> {%/if%} 
Unless unless
L'helper unless est utilisé pour définir un bloc conditionnel. Par opposition à l'assistant if , si l'évaluation de l'expression renvoie false, le bloc est rendu.
Syntaxe
{%#unless unlessCondition%} element_1 {%else%} default_element {%/unless%}
            Exemple
Générer du contenu en fonction de l'extension d'adresse e-mail :
{%#unless endsWith(profile.personalEmail.address, ".edu")%}
Some Normal Content
{%else%}
Some edu specific content
{%/unless%}
            Each each
L'helper each est utilisé pour effectuer une itération sur un tableau.
La syntaxe de l’assistant est {{#each ArrayName}} YourContent {{/each}}
Il est possible de se référer aux éléments individuels du tableau en utilisant le mot-clé this à l’intérieur du bloc. L’index de l’élément du tableau peut être rendu à l’aide de {{@index}}.
Syntaxe
{{#each profile.productsInCart}}
    <li>{{this.name}}</li>
{{/each}}
            Exemple
{{#each profile.homeAddress.city}}
  {{@index}} : {{this}}<br>
{{/each}}
            Exemple
Générer une liste de produits que cet utilisateur a dans son panier :
{{#each profile.products as |product|}}
    <li>{{product.productName}} {{product.productRating}}</li>
{{/each}}
            Avec with
L'helper with permet de modifier le jeton d'évaluation d'une partie de modèle.
Syntaxe
{{#with profile.person.name}}
{{this.firstName}} {{this.lastName}}
{{/with}}
            L'helper with est utile pour définir également une variable de raccourci.
Exemple
Utiliser l'option avec pour attribuer un alias aux noms de variables longs par rapport aux noms plus courts :
{{#with profile.person.name as |name|}}
 Hi {{name.firstName}} {{name.lastName}}!
 Checkout our trending products for today!
{{/with}}
            Let let
La fonction let permet à une expression d'être stockée en tant que variable et d'être utilisé ultérieurement dans une requête.
Syntaxe
{% let variable = expression %} {{variable}}
            Exemple
L'exemple suivant permet de calculer la somme totale des prix des produits du panier dont les prix sont compris entre 100 et 1 000.
{% let sum = 0%}
    {{#each profile.productsInCart as |p|}}
        {%#if p.price>100 and p.price<1000%}
            {%let sum = sum + p.price %}
        {%/if%}
    {{/each}}
{{sum}}
            Métadonnées d’exécution execution-metadata
L’assistant executionMetadata permet de capturer et de stocker dynamiquement des paires clé-valeur personnalisées dans le contexte d’exécution du message.
Syntaxe
{{executionMetadata key="your_key" value="your_value"}}
            Dans cette syntaxe, key fait référence au nom des métadonnées et value correspond aux métadonnées à conserver.
Cas d’utilisation
Cette fonction vous permet d’ajouter des informations contextuelles à toute action native de vos campagnes ou parcours. Vous pouvez ainsi exporter des données contextuelles de diffusion en temps réel vers des systèmes externes à diverses fins telles que le tracking, l’analyse, la personnalisation et le traitement en aval.
Par exemple, vous pouvez utiliser l’assistant Métadonnées d’exécution pour ajouter un identifiant spécifique à chaque diffusion envoyée à chaque profil. Ces informations sont générées lors de l’exécution, puis les métadonnées d’exécution enrichies peuvent être exportées pour la réconciliation en aval avec une plateforme de création de rapports externe.
Fonctionnement
Sélectionnez n’importe quel élément du contenu de votre canal dans une campagne ou un parcours et, à l’aide de l’éditeur de personnalisation, ajoutez l’assistant executionMetadata à cet élément.
Lors de l’exécution, la valeur des métadonnées est ajoutée au jeu de données d’événement de retour de message existant avec le schéma suivant :
"_experience": {
  "customerJourneyManagement": {
    "messageExecution": {
      "metadata": {
        "your_key": "your_value"
      }
    }
  }
}
            Limitation
La limite supérieure est de 2 Ko sur les paires clé-valeur par action.
Si la limite de 2 Ko est dépassée, le message est toujours diffusé, mais toutes les paires clé-valeur peuvent être tronquées.
Exemple
{{executionMetadata key="firstName" value=profile.person.name.firstName}}
            Dans cet exemple, en supposant que profile.person.name.firstName = « Alex », l’entité résultante est :
{
  "key": "firstName",
  "value": "Alex"
}