Création de formulaires adaptatifs à l’aide d’un schéma JSON creating-adaptive-forms-using-json-schema

Adobe recommande d’utiliser les composants principauxde capture de données modernes et extensibles pour créer de nouveaux formulaires adaptatifsou ajouter des formulaires adaptatifs à des pages AEM Sites. Ces composants représentent une avancée significative dans la création de formulaires adaptatifs, ce qui garantit des expériences utilisateur impressionnantes. Cet article décrit l’ancienne approche de la création de formulaires adaptatifs à l’aide de composants de base.

Version
Lien de l’article
AEM as a Cloud Service
Cliquez ici
AEM 6.5
Cet article

Prérequis prerequisites

La création d’un formulaire adaptatif à l’aide d’un schéma JSON en tant que modèle de formulaire requiert des connaissances de base en matière de schémas JSON. Il est recommandé de lire le contenu suivant avant cet article.

Utilisation d’un schéma JSON comme modèle de formulaire using-a-json-schema-as-form-model

Adobe Experience Manager Forms prend en charge la création d’un formulaire adaptatif en utilisant un schéma JSON existant en tant que modèle de formulaire. Ce schéma JSON représente la structure dans laquelle les données sont générées ou utilisées par le système back-end de votre organisation. Le schéma JSON que vous utilisez doit être compatible avec les spécifications v4.

Les fonctionnalités clés de l’utilisation d’un schéma JSON sont les suivantes :

  • La structure du modèle JSON s’affiche sous forme d’arborescence sous l’onglet Outil de recherche de contenu en mode création pour un formulaire adaptatif. Vous pouvez faire glisser et ajouter un élément de la hiérarchie JSON dans le formulaire adaptatif.
  • Vous pouvez préremplir le formulaire avec le code JSON conforme au schéma associé.
  • Au moment de l’envoi, les données saisies par l’utilisateur ou l’utilisatrice sont envoyées au format JSON approprié pour le schéma associé.

Un schéma JSON se compose de types d’éléments simples et complexes. Les éléments possèdent des attributs qui ajoutent des règles à ceux-ci. Lorsque ces éléments et attributs sont déplacés vers un formulaire adaptatif, ils sont automatiquement mis en correspondance avec les composants de formulaires adaptatifs correspondants.

Cette mise en correspondance des éléments JSON avec les composants de formulaires adaptatifs est la suivante :

"birthDate": {
              "type": "string",
              "format": "date",
              "pattern": "date{DD MMMM, YYYY}",
              "aem:affKeyword": [
                "DOB",
                "Date of Birth"
              ],
              "description": "Date of birth in DD MMMM, YYYY",
              "aem:afProperties": {
                "displayPictureClause": "date{DD MMMM, YYYY}",
                "displayPatternType": "date{DD MMMM, YYYY}",
                "validationPatternType": "date{DD MMMM, YYYY}",
                "validatePictureClause": "date{DD MMMM, YYYY}",
                "validatePictureClauseMessage": "Date must be in DD MMMM, YYYY format."
              }
Élément, propriétés ou attributs JSON
Composant de formulaire adaptatif

Propriétés de chaînes avec contrainte d’énumération et enumNames.

Syntaxe,

{

"type" : "string",

"enum" : ["M", "F"]

"enumNames" : ["Male", "Female"]

}

Composant de liste déroulante :

  • Les valeurs énumérées dans enumNames s’affichent dans la zone de dépôt.
  • Les valeurs répertoriées dans l’énumération sont utilisées pour le calcul.

Propriété de chaîne avec contrainte de format. Par exemple, e-mail et date.

Syntaxe,

{

"type" : "string",

"format" : "email"

}

  • Le composant d’e-mail est mappé lorsque le type est une chaîne et le format un e-mail.
  • Le composant de textbox avec validation est mappé lorsque le type est une chaîne et le format un nom d’hôte.

{

"type" : "string",

}

Champ de texte
propriété de nombre
Champ numérique dont le sous-type est défini comme flottant
propriété Entier
Champ numérique dont le sous-type est défini sur entier
propriété Booléen
Basculer
propriété de l’objet
Panneau
propriété de tableau
Panneau répétable dont les valeurs min et max sont respectivement égales à minItems et maxItems. Seuls les tableaux homogènes sont pris en charge. Par conséquent, la contrainte d’éléments doit être un objet et n’est pas un tableau.

Propriétés communes de schéma common-schema-properties

Le formulaire adaptatif utilise les informations disponibles dans le schéma JSON pour mapper chaque champ généré. En particulier :

  • La propriété title sert de libellé aux composants de formulaire adaptatif.
  • La propriété description est définie comme description longue pour un composant de formulaire adaptatif.
  • La propriété default sert de valeur initiale d’un champ de formulaire adaptatif.
  • La propriété maxLength est définie en tant qu’attribut maxlength du composant champ de texte.
  • Les propriétés minimum, maximum, exclusiveMinimum et exclusiveMaximum sont utilisées pour le composant zone numérique.
  • Pour prendre en charge la plage de composants DatePicker component, les propriétés supplémentaires minDate et maxDate de schéma JSON sont fournis.
  • Les propriétés minItems et maxItems servent à limiter le nombre d’éléments/champs qui peuvent être ajoutés ou retirés d’un composant de panneau.
  • La propriété readOnly définit l’attribut readonly d’un composant de formulaire adaptatif.
  • La propriété required marque le champ de formulaire adaptatif comme obligatoire alors qu’en cas de panneau (lorsque le type est objet), les données JSON finales soumises ont des champs avec une valeur vide correspondant à cet objet.
  • La propriété pattern est définie comme modèle de validation (expression régulière) dans le formulaire adaptatif.
  • L’extension du fichier de schéma JSON doit être conservée dans .schema.json. Par exemple, <nom_fichier>.schema.json.

Exemple de schéma JSON sample-json-schema

Vous trouverez ci-dessous un exemple de schéma JSON.

{
 "$schema": "https://json-schema.org/draft-04/schema#",
 "definitions": {
  "employee": {
   "type": "object",
   "properties": {
    "userName": {
     "type": "string"
    },
    "dateOfBirth": {
     "type": "string",
     "format": "date"
    },
    "email": {
     "type": "string",
     "format": "email"
    },
    "language": {
     "type": "string"
    },
    "personalDetails": {
     "$ref": "#/definitions/personalDetails"
    },
    "projectDetails": {
     "$ref": "#/definitions/projectDetails"
    }
   },
   "required": [
    "userName",
    "dateOfBirth",
    "language"
   ]
  },
  "personalDetails": {
   "type": "object",
   "properties": {
    "GeneralDetails": {
     "$ref": "#/definitions/GeneralDetails"
    },
    "Family": {
     "$ref": "#/definitions/Family"
    },
    "Income": {
     "$ref": "#/definitions/Income"
    }
   }
  },
  "projectDetails": {
   "type": "array",
   "items": {
    "properties": {
     "name": {
      "type": "string"
     },
     "age": {
      "type": "number"
     },
     "projects": {
      "$ref": "#/definitions/projects"
     }
    }
   },
   "minItems": 1,
   "maxItems": 4
  },
  "projects": {
   "type": "array",
   "items": {
    "properties": {
     "name": {
      "type": "string"
     },
     "age": {
      "type": "number"
     },
     "projectsAdditional": {
      "$ref": "#/definitions/projectsAdditional"
     }
    }
   },
   "minItems": 1,
   "maxItems": 4
  },
  "projectsAdditional": {
   "type": "array",
   "items": {
    "properties": {
     "Additional_name": {
      "type": "string"
     },
     "Additional_areacode": {
      "type": "number"
     }
    }
   },
   "minItems": 1,
   "maxItems": 4
  },
  "GeneralDetails": {
   "type": "object",
   "properties": {
    "age": {
     "type": "number"
    },
    "married": {
     "type": "boolean"
    },
    "phone": {
     "type": "number",
     "aem:afProperties": {
      "sling:resourceType": "/libs/fd/af/components/guidetelephone",
      "guideNodeClass": "guideTelephone"
     }
    },
    "address": {
     "type": "string"
    }
   }
  },
  "Family": {
   "type": "object",
   "properties": {
    "spouse": {
     "$ref": "#/definitions/spouse"
    },
    "kids": {
     "$ref": "#/definitions/kids"
    }
   }
  },
  "Income": {
   "type": "object",
   "properties": {
    "monthly": {
     "type": "number"
    },
    "yearly": {
     "type": "number"
    }
   }
  },
  "spouse": {
   "type": "object",
   "properties": {
    "name": {
     "type": "string"
    },
    "Income": {
     "$ref": "#/definitions/Income"
    }
   }
  },
  "kids": {
   "type": "array",
   "items": {
    "properties": {
     "name": {
      "type": "string"
     },
     "age": {
      "type": "number"
     }
    }
   },
   "minItems": 1,
   "maxItems": 4
  }
 },
 "type": "object",
 "properties": {
  "employee": {
   "$ref": "#/definitions/employee"
  }
 }
}

Définitions de schéma réutilisables reusable-schema-definitions

Les clés de définition sont utilisées pour identifier les schémas réutilisables. Les définitions de schéma réutilisables sont utilisées pour créer des fragments. Elle est similaire à l’identification des types complexes dans XSD. Un exemple de schéma JSON dont la définition est fournie ci-dessous :

{
  "$schema": "https://json-schema.org/draft-04/schema#",

  "definitions": {
    "address": {
      "type": "object",
      "properties": {
        "street_address": { "type": "string" },
        "city":           { "type": "string" },
        "state":          { "type": "string" }
      },
      "required": ["street_address", "city", "state"]
    }
  },

  "type": "object",

  "properties": {
    "billing_address": { "$ref": "#/definitions/address" },
    "shipping_address": { "$ref": "#/definitions/address" }
  }
}

L’exemple ci-dessus définit un enregistrement client dans lequel chaque client ou cliente dispose d’une adresse d’expédition et de facturation. La structure des deux adresses est la même : les adresses indiquent une rue, la ville et un État. Il est donc préférable de ne pas dupliquer les adresses. Cela facilite également l’ajout et la suppression de champs pour toute modification ultérieure.

Préconfiguration des champs dans la définition du schéma JSON pre-configuring-fields-in-json-schema-definition

Vous pouvez utiliser la propriété aem:afProperties pour préconfigurer le champ de schéma JSON pour mapper vers un composant de formulaire adaptatif personnalisé. Un exemple est répertorié ci-dessous :

{
    "properties": {
        "sizeInMB": {
            "type": "integer",
            "minimum": 16,
            "maximum": 512,
            "aem:afProperties" : {
                 "sling:resourceType" : "/apps/fd/af/components/guideTextBox",
                 "guideNodeClass" : "guideTextBox"
             }
        }
    },
    "required": [ "sizeInMB" ],
    "additionalProperties": false
}

Configuration de scripts ou d’expressions pour les objets de formulaire configure-scripts-or-expressions-for-form-objects

JavaScript est le langage d’expression des formulaires adaptatifs. Toutes les expressions sont des expressions JavaScript valides qui utilisent des API de modèle de script pour les formulaires adaptatifs. Vous pouvez préconfigurer les objets de formulaire pour évaluer une expression sur un événement de formulaire.

Utilisez la propriété aem:afproperties pour préconfigurer les expressions ou scripts de formulaires adaptatifs pour les composants de ces formulaires. Par exemple, lorsque l’événement initialize est déclenché, le code ci-dessous définit la valeur du champ téléphonique et imprime une valeur dans le journal :

"telephone": {
  "type": "string",
  "pattern": "/\\d{10}/",
  "aem:affKeyword": ["phone", "telephone","mobile phone", "work phone", "home phone", "telephone number", "telephone no", "phone number"],
  "description": "Telephone Number",
  "aem:afProperties" : {
    "sling:resourceType" : "fd/af/components/guidetelephone",
    "guideNodeClass" : "guideTelephone",
    "events": {
      "Initialize" : "this.value = \"1234567890\"; console.log(\"ef:gh\") "
    }
  }
}

Vous devez être membre du groupe forms-power-user pour configurer des scripts ou des expressions pour l’objet de formulaire. Le tableau ci-dessous répertorie tous les événements de script pris en charge pour un composant de formulaire adaptatif.

Composant
Événement
initialize
Calculer
Visibilité
Valider
Activé
Validation de la valeur
Cliquer
Options
Champ de texte
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Champ numérique
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Procédure pas à pas numérique
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Bouton radio
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Téléphone
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Basculer
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Bouton
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Case à cocher
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Liste déroulante
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Choix d’image
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Champ de saisie de date
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Sélecteur de date
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
E-mail
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Pièce jointe
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Icône de coche Oui
Image
Icône de coche Oui
Icône de coche Oui
Dessin
Icône de coche Oui
Icône de coche Oui
Panneau
Icône de coche Oui
Icône de coche Oui

Certains exemples d’utilisation d’événements dans un JSON masquent un champ sur l’événement initialize et configurent la valeur d’un autre champ sur l’événement de validation de valeur. Pour plus d’informations sur la création d’expressions pour les événements de script, voir Expressions de formulaire adaptatif.

Voici l’exemple de code JSON pour les exemples mentionnés précédemment.

Masquage d’un champ sur l’événement initialize hiding-a-field-on-initialize-event

"name": {
    "type": "string",
    "aem:afProperties": {
        "events" : {
            "Initialize" : "this.visible = false;"
        }
    }
}

Configuration de la valeur d’un autre champ sur l’événement de validation de valeur configure-value-of-another-field-on-value-commit-event

"Income": {
    "type": "object",
    "properties": {
        "monthly": {
            "type": "number",
            "aem:afProperties": {
                "events" : {
                    "Value Commit" : "IncomeYearly.value = this.value * 12;"
                }
            }
        },
        "yearly": {
            "type": "number",
            "aem:afProperties": {
                "name": "IncomeYearly"
            }
        }
    }
}

Valeurs possibles de limite pour un composant de formulaire adaptatif limit-acceptable-values-for-an-adaptive-form-component

Vous pouvez ajouter les restrictions suivantes aux éléments de schéma JSON pour limiter les valeurs possibles pour un composant de formulaire adaptatif :

Propriété de schéma
Type de données
Description
Composant
maximum
Chaîne
Spécifie la limite supérieure pour les valeurs numériques et les dates. Par défaut, la valeur maximale est incluse.
  • Zone numérique
  • Procédure pas à pas numérique
  • Sélecteur de date
minimum
Chaîne
Définit la limite inférieure pour les valeurs numériques et les dates. Par défaut, la valeur minimale est incluse.
  • Zone numérique
  • Procédure pas à pas numérique
  • Sélecteur de date
exclusiveMaximum
Booléen

Si elle est définie sur true, la valeur numérique ou la date spécifiée dans le composant de formulaire doit être inférieure à la valeur numérique ou la date spécifiée pour la propriété maximum.

Si elle est définie sur false, la valeur numérique ou la date spécifiée dans le composant de formulaire doit être inférieure ou égale à la valeur numérique ou la date spécifiée pour la propriété maximum.

  • Zone numérique
  • Procédure pas à pas numérique
  • Sélecteur de date
exclusiveMinimum
Booléen

Si elle est définie sur true, la valeur numérique ou la date spécifiée dans le composant de formulaire doit être supérieure à la valeur numérique ou la date spécifiée pour la propriété minimum.

Si elle est définie sur false, la valeur numérique ou la date spécifiée dans le composant de formulaire doit être supérieure ou égale à la valeur numérique ou la date spécifiée pour la propriété minimum.

  • Zone numérique
  • Procédure pas à pas numérique
  • Sélecteur de date
minLength
Chaîne
Indique le nombre minimum de caractères autorisés dans un composant. La longueur minimale doit être égale ou supérieure à zéro.
  • Zone de texte
maxLength
Chaîne
Spécifie le nombre maximal de caractères autorisés dans un composant. La longueur maximale doit être égale ou supérieure à zéro.
  • Zone de texte
pattern
Chaîne

Spécifie la séquence de caractères. Un composant accepte les caractères si les caractères sont conformes au modèle spécifié.

La propriété de modèle mappe au modèle de validation du composant de formulaire adaptatif correspondant.

  • Tous les composants de formulaires adaptatifs qui sont mappés vers un schéma XSD
maxItems
Chaîne
Indique le nombre maximum d’éléments dans un tableau. Le nombre maximal d’éléments doit être égal ou supérieur à zéro.
minItems
Chaîne
Indique le nombre minimum d’éléments dans un tableau. Le nombre d’éléments minimum doit être égal ou supérieur à zéro.

Activer des données conformes aux schémas enablig-schema-compliant-data

Pour permettre à tous les formulairess adaptatifs basés sur un schéma JSON de générer des données conformes au schéma lors de l’envoi du formulaire, procédez comme suit :

  1. Accédez à la console web Experience Manager à l’adresse https://server:host/system/console/configMgr.
  2. Recherchez Configuration des canaux web du formulaire adaptatif et de la communication interactive
  3. Sélectionnez cette option pour ouvrir la configuration en mode d’édition.
  4. Cochez la case Générer des données conformes aux schémas.
  5. Enregistrez les paramètres.

configuration des canaux web du formulaire adaptatif et de la communication interactive

Éléments non pris en charge non-supported-constructs

Les formulaires adaptatifs ne prennent pas en charge les éléments suivants de schéma JSON :

  • Type null
  • Types d’union tels que n’importe lequel, et
  • OneOf, AnyOf, AllOf, et NOT
  • Seuls les tableaux homogènes sont pris en charge. Par conséquent, la contrainte d’éléments doit être un objet et ne doit pas être un tableau.

Questions fréquemment posées frequently-asked-questions

Pourquoi est-ce que je ne parviens pas à faire glisser des éléments individuels d’un sous-formulaire (structure générée à partir de n’importe quel type complexe) pour les sous-formulaires répétables (les valeurs minOccurs ou maxOccurs sont supérieures à 1) ?

Dans un sous-formulaire répétable, vous devez utiliser le sous-formulaire complet. Si vous souhaitez uniquement des champs sélectifs, utilisez la structure entière et supprimez les champs indésirables.

Je dispose d’une longue structure complexe dans l’Outil de recherche de contenu. Comment puis-je trouver un élément spécifique ?

Vous disposez de deux options :

  • Parcourez la structure de l’arborescence.
  • Utilisez la zone Rechercher pour rechercher un élément.

Quelle doit être l’extension d’un fichier de schéma JSON ?

L’extension d’un fichier de schéma JSON doit être .schema.json, Par exemple, <nom_fichier>.schema.json.

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