Extension:Page Forms/Values, mappings and autocompletion/fr

Page Forms offre de nombreuses options liées à la fois à la définition et à l'affichage des valeurs possibles pour les entrées, à la fois pour les types d'entrées qui offrent un ensemble fini d'options (tels que les listes déroulantes et les cases à cocher) et ceux qui offrent une entrée des données de forme libre (comme les combox et les tokens).



Définition des valeurs et des correspondances
Certains types d'entrée fournissent à l'utilisateur des valeurs prédéfinies. Cela peut être des valeurs parmi lesquelles l'utilisateur doit choisir (comme le type d'entrée ), ou des valeurs d'exemple pour guider l'utilisateur (comme , bien que là aussi ces options peuvent être rendues obligatoires en ajoutant le paramètre  ).

Dans les deux cas, l'ensemble des paramètres pour spécifier les valeurs affichées à l'utilisateur est presque le même. Voici les paramètres de la balise de champ (field) qui peuvent être utilisés dans tous les cas :

Il y existe quelques options supplémentaires pour les entrées basées sur l'autocomplétion; voir ci_dessous.

Correspondance
Il est possible que l'ensemble des valeurs affichées à l'utilisateur soit différent de l'ensemble des valeurs qui apparaissent actuellement dans le wikicode de la page. Si les valeurs sont des noms de pages et que ces pages ont un ensemble de titres d'affichage (display title) différent du nom réel de la page, le formulaire affichera par défaut ce display title au lieu du nom de page. Si vous le souhaitez, vous pouvez faire afficher le nom de la page lui-même en ajoutant ceci à LocalSettings.php :

Vous pouvez activer d'autres correspondances similaires en utilisant les paramètres suivants :



Exemple 1 : modèle de correspondance
Un formulaire peut contenir une balise de champ telle que :

Le modèle sur Template:StatusLabel peut ensuite contenir quelque chose comme :

Vous pouvez ensuite utiliser le même mapping template pour afficher le libellé de la valeur sur les pages classiques qui ne sont pas des formulaires. Dans le modèle qui contient le champ état, vous pouvez avoir ceci :



Exemple 2: correspondances basées sur Cargo
Supposons que, dans une entreprise, chaque employé ait un numéro d'identification. Dans le wiki, la page de chaque employé a pour nom l'identifiant de l'employé. Il existe aussi des pages sur les projets, et à l'intérieur de chaque page de projet on trouve un champ Membres du projet, qui contient la liste des identifiants des employés. Dans le formulaire "Projet", dans l'entrée "Membres du projet", vous voulez que les gens saisissent les noms réels des employés, mais que ce sont les identifiants des employés qui apparaissent sur la page. Vous pouvez le faire avec la balise de champ suivante :

Maintenant si le nom de chaque page d'employé n'est pas l'identifiant de l'employé (ni son vrai nom) mais plutôt un nom attribué au hasard, comme "Employé 12345" ? Ensuite, vous pouvez faire l'association en utilisant le paramètre supplémentaire "mapping cargo value field" comme ceci :

Autocomplétion
Quatre des types d'entrée (, , plus   et   pour les versions antérieures à la 5.0) utilisent l'autocomplétion - à mesure que l'utilisateur commence à taper, l'entrée affiche une liste déroulante des possibilités de complétion.

Si un champ représente une propriété de Semantic MediaWiki, ou de champ Cargo, de type  , l'autocomplétion sera activée par défaut — le champ se complètera automatiquement pour les noms de toutes les pages qui sont déjà marquées par cette propriété ou ce champ. Pour tous les autres types, il n'existe pas d'autocomplétion par défaut, mais vous pouvez réaliser cela simplement en déclarant ce type d'entrée comme étant l'un des quatre possèdant l'autcomplétion.

Vous pouvez définir manuellement un champ à autocomplétion sur l'ensemble des valeurs à partir d'une propriété SMW, d'un champ Cargo, d'une catégorie, d'un espace de noms, d'un concept, ou d'une liste définie manuellement, en utilisant l'un des paramètres valeurs ... - voir ci-dessus.

Vous pouvez aussi appliquer l'autocomplétion basée sur des valeurs hors du wiki, contenues dans des pages web, des bases de données, des fichiers, etc.; voir ci-après pour les différentes manières de réaliser cela.

Si un champ est désigné comme contenant des valeurs multiples, l'autocomplétion prendra en charge par défaut les valeurs multiples : après avoir saisi une valeur et placé le délimiteur, une nouvelle autocomplétion va recommencer avec la valeur suivante. Vous pouvez spécifier manuellement qu'un champ doit avoir une complétion automatique à valeurs multiples, en ajoutant le paramètre "list" à la définition du champ. Vous pouvez également spécifier le délimiteur de cette liste de valeurs, en utilisant le paramètre « delimiter=... » (valeur par défaut : une virgule ',').

Par défaut, le nombre maximum de possibilités d'autocomplétion qu'un champ peut offrir est de 1,000; c'est pour des raisons de performance. Pour modifier ce nombre, modifiez la valeur de  dans LocalSettings.php.

Désactivation
Vous pouvez désactiver l'autocomplétion si elle a été déclarée par défaut sur un champ, en indiquant que le type d'entrée est simplement « text » ou « textarea ».



Autocomplétion distante
L'ensemble des valeurs possibles d'autocomplétion d'un champ est par défaut contenu directement dans la page HTML du formulaire, dans une déclaration JavaScript. Par soucis de performance, il y existe une limite sur le nombre de valeurs placées sur la page; par défaut la limite est fixée à 100. Une fois cette valeur atteinte, l'autocomplétation à distance est réalisée à l'endroit, où l'autocompletation se produit par un appel Ajax au serveur, en fonction de ce que l'utilisateur a saisi. Ce type d'autocomplétion est plus lent, mais il permet beaucoup plus de résultats d'autocomplétion.

Vous pouvez modifier la définition par défaut en ajoutant quelque chose comme ceci à LocalSettings.php :



Correspondance de chaque caractère
Par défaut, l'autocomplétion dans Page Forms détecte le début de chaque mot dans l'ensemble des valeurs possibles. Vous pouvez par contre modifier l'autocomplétion afin qu'elle coïncide avec chaque caractère, en ajoutant la ligne suivante à LocalSettings.php :

Cette fonctionnalité est particulièrement importante pour les wikis qui ont des valeurs avec des caractères non ASCII, comme les wikis dans les langues avec des alphabets non romains; puisque la complétion automatique par défaut, basée sur les mots ne fonctionne pas encore avec des caractères non ASCII.



Autocomplétion sur les caractères accentués
L'autocomplétion des inflexions pour les caractères accentués, est prise en charge pour les types d'entrée combobox et tokens.

Le repli d'accents a ses limites mais il peut aider à ce que certaines interactions importantes quoique négligées, avec l'utilisateur fonctionnent mieux. Une fonction réalisant le repli d'accents associe essentiellement les caractères Unicode à leur équivalent ASCII. Avec le repli d'accents, il n'est pas important de savoir si vous cherchez cafe, café ou çåFé; le résultat sera le même.



Autocomplétion sur les valeurs externes
Il existe quelques façons d'avoir un champ complété automatiquement en utilisant des données provenant de l'extérieur du wiki :


 * à partir d'une URL similaire à celle d'une API qui prend une sous-chaîne et renvoie les données au format JSON nécessaire
 * à partir de Wikidata
 * à partir de toute source externe, en utilisant l'extension.



A partir d'une URL externe
Vous pouvez obtenir l'autocomplétion d'un champ sur des valeurs venant de l'extérieur du wiki, en utilisant le paramètre suivant :


 * identifiant d'URL

Pour réaliser cela, suivez ces étapes :


 * 1) Créez une page ou un service web qui recupère une sous-chaîne via la chaîne de requête, et qui affiche un ensemble de valeurs de complétion. Page Forms attend un format JSON dans la réponse avec une clé « pfautocomplete » à la racine et un tableau d'objets avec la clé « title » marquant les valeurs des complétions possibles. Un court exemple de ceci est disponible à partir de cet appel d'API sur semantic-mediawiki.org.
 * Par exemple, si vous aviez une liste de trois pays -- Uruguay, Germany et Japan -- et que l'on vous demande la liste des résultats possibles pour "an", vous renverrez :
 * Ceci facilite aussi l'autocomplétion des valeurs provenant d'un autre wiki.
 * 1) Décidez d'une chaîne courte  pour représenter cette URL.
 * Par exemple, le service qui fournit des recherches dans notre liste de pays pourrait être appelé  .
 * 1) Ajoutez la chaîne abrégée dans le tableau de   du fichier LocalSettings.php pour configurer Page Forms et utiliser votre URL lorsqu'il détecte la chaîne. Mettez «   » là où vous voulez envoyer la saisie de l'utilisateur.
 * Dans notre exemple, si nous voulons que Page Forms alimente le texte tapé par l'utilisateur vers l'URL  via le paramètre d'URL «   », nous écrivons :
 * 1) Ajoutez le paramètre « values from url=URL-identifier-string » au champ ad'hoc dans la définition du formulaire.
 * Pour notre exemple des pays, le champ peut ressembler à :
 * 1) Ajoutez le paramètre « values from url=URL-identifier-string » au champ ad'hoc dans la définition du formulaire.
 * Pour notre exemple des pays, le champ peut ressembler à :



A partir de Wikidata
Vous pouvez avoir un formulaire de saisie et compléter automatiquement les valeurs de Wikidata, en utilisant le paramètre. La valeur de ce paramètre est structurée comme une mini-requête, comme  ("instance of" = "sculpture", "country" = "Italy"). Les valeurs "Q" peuvent également être remplacées par des noms de champs, pour permettre une version basée sur Wikidata de "show on select", par exemple, où "Location" est un modèle, et "Country" est un champ, au-dessus de celui actuel.



Utiliser l'extension External Data


L'extension External Data (ED) prend en charge la récupération des données à partir d'un certain nombre de sources qui incluent les URL externes, les pages régulières de wiki, les fichiers téléversés, les fichiers du serveur local, les bases de données et les répertoires LDAP.

Pour compléter automatiquement en utilisant ED, vous devez d'abord appeler l'une des fonctions #get_..._data d'analyse de ED dans la définition du formulaire (de préférence en bas de la définition du formulaire, pour éviter les passages à la ligne inutiles). Cela permettra de récupérer les données qui peuvent ensuite être utilisées dans les balises des champs. (Voir la documentation de External Data pour savoir comment les appeler). La balise de champ peut alors utiliser ces paramètres :


 * nom de variable ED (obligatoire)
 * nom de variable ED (optionnel)
 * nom de variable ED (optionnel)

Voici un exemple d'appel à #get_web_data pour récupérer les données d'une URL :

En supposant qu'une définition de formulaire contienne un tel appel, une balise de champ peut ensuite utiliser les valeurs récupérées pour l'autocomplétion - non pas simplement pour définir les valeurs d'autocomplétion en elles-mêmes, mais également, si le type d'entrée est « combobox » ou « tokens », pour définir une image de la vignette correspondante et la description de chacunes d'elles.

En supposant que l'appel de External Data récupère trois colonnes de valeurs comme ci-dessus, la balise du champ qui utilise ces données est similaire à :



Autocomplétion dépendante
Vous pouvez définir les valeurs d'autocomplétion d'un champ en fonction de la valeur déjà définie par l'utilisateur d'un autre champ du formulaire. Ceci se fait à l'aide du paramètre  dont la syntaxe est la suivante :

Il spécifie que l'ensemble actuel de valeurs autorisées pour ce champ comprend toutes les valeurs prises par ce même champ à partir de pages où 'field name' est égal à la valeur sélectionnée pour 'field name' dans la forme actuelle.

Est-ce gênant ?

Eh bien, cet exemple peut vous aider: si un modèle s'appelle "Restaurant" et qu'il contient des champs de modèle (pas des propriétés) nommés "Country" et "City" et que vous voulez que l'ensemble des villes utilisées pour l'autocomplétion soit uniquement celui des villes "dans le pays que l'utilisateur a sélectionné", alors la balise de champ pour le champ City doit ressembler à :



Paramètre show on select
Pour les entrées de type 'checkbox', 'checkboxes', 'radiobutton', 'dropdown' et 'listbox', le paramètre  spécifie qu'un ou plusieurs éléments de la page ne doivent être affichés que si certaines valeurs sont sélectionnées dans cette entrée.

La syntaxe de ce paramètre est :



Une valeur peut être fournie avec plus d'un ID d'élément :



Si vous utilisez show on select avec un modèle de correspondance, utilisez comme valeurs, les étiquettes définies dans le modèle de correspondance (et non pas les vrais noms des paramètres).

Pour les entrées de type 'checkbox', il suffit d'utiliser «  element ID ». Notez que les identifiants d'éléments (element ID) ne peuvent pas contenir d'espaces ni de caractères multi-octets et ne peuvent pas commencer par un nombre.

Pour un exemple de cette fonctionnalité utilisée, voir ce formulaire, et observez ce qui se passe lorsque vous sélectionnez différentes valeurs de la liste déroulante Publication type. Vous pouvez voir comment cela a été mis en œuvre dans cette définition de formulaire.