@net-helium/hc-forms
v1.1.1
Published
Intégration de formulaires Hélium Connect sur des pages web
Downloads
21
Maintainers
Readme
Hélium Connect Forms
Cette librairie permet d'intégrer facilement des formulaires Hélium Connect sur vos pages web.
Le problème résolu par cette librairie
En faisant l'intégration vous-même, vous êtes amené à utiliser un code HTML similaire à celui-ci :
<iframe title="Mon formulaire" src="URL_FORMULAIRE"></iframe>
Le problème est qu'il est impossible pour une <iframe>
d'ajuster sa hauteur automatiquement en fonction du contenu du formulaire.
Vous pouvez bien-sûr renseigner une hauteur fixe à l'iframe mais la hauteur d'un formulaire peut varier en fonction de plusieurs facteurs :
- La page de confirmation du formulaire a une hauteur différente de la page des questions
- Le formulaire est de type bloc par bloc ou question par question (les blocs et/ou questions auront des hauteurs différentes)
- Le formulaire ajoute ou supprime des questions en fonction des réponses aux questions précédentes (affichage conditionnel)
- L'utilisateur redimensionne la fenêtre de son navigateur
Si l'iframe est plus haute que nécessaire, il y aura un espace vide en dessous du formulaire. Si l'iframe n'est pas assez haute, une barre de scroll apparaitra.
Cette librairie génère une iframe pour chacun de vos formulaires et gère automatiquement sa hauteur en fonction des changements qui ont lieu dans le formulaire.
Installation
Chargement local à votre site
Installez la librairie localement sur votre site en utilisant une des commandes suivantes en fonction du package manager que vous utilisez :
# npm
npm install @net-helium/hc-forms
# pnpm
pnpm add @net-helium/hc-forms
# yarn
yarn add @net-helium/hc-forms
Intégrez une balise <script>
sur vos pages qui pointe sur le fichier /dist/hc-forms.js du package.
Le chemin dépend de la gestion des assets sur votre site.
Suivant les technologies et framework utilisés pour le développement de votre site, cette gestion sera différente.
<script src="/chemin-vers/dist/hc-forms.js" defer></script>
Chargement depuis un CDN
Si vous préférez charger la librairie depuis un CDN, intégrez l'une des balises <script>
ci-dessous sur vos pages :
<!-- Lien vers la dernière version -->
<script src="https://cdn.jsdelivr.net/npm/@net-helium/hc-forms/dist/hc-forms.js" defer></script>
<!-- Lien vers une version spécifique (exemple avec la version 1.0.0) -->
<script src="https://cdn.jsdelivr.net/npm/@net-helium/[email protected]/dist/hc-forms.js" defer></script>
Usage
Pour intégrer un formulaire Hélium Connect, utilisez le code HTML suivant (remplacez URL_FORMULAIRE) :
<hc-form url="URL_FORMULAIRE"></hc-form>
Ce code génère une iframe contenant le formulaire avec une largeur de 100% par rapport à son conteneur (l'élément parent de <hc-form>
) et une hauteur calculée en fonction du contenu du formulaire.
La hauteur de l'iframe sera modifiée automatiquement si le contenu du formulaire change ou si la fenêtre du navigateur est redimensionnée.
Si l'URL renseignée n'est pas une URL valide, un message d'erreur apparaitra à la place de l'iframe. Si l'URL est valide mais ne correspond pas à un formulaire Hélium Connect, une iframe sera générée avec le contenu de la page cible mais elle ne sera pas visible puisque la hauteur ne pourra pas être calculée par la librairie et restera donc à 0 pixels.
Suivi automatique des contacts
Chaque formulaire Hélium Connect vous donne la possibilité d'utiliser une URL avec suivi automatique des contacts. Cette URL contient un code contact qui est remplacé par l'identifiant de la fiche contact afin de préremplir les champs déjà connus. Ce remplacement se fait automatiquement à l'inclusion de ce type de lien dans le contenu d'une campagne email Hélium Connect (chaque destinataire de la campagne obtient son lien personnalisé).
Cette librairie vous permet également d'utiliser ce type d'URL pour vos formulaires. Pour cela, il faut un paramètre spécial dans l'URL de la page hôte de votre formulaire : hc_contact_code.
Cela vous permet de faire une campagne Hélium Connect avec un lien personnalisé pour chaque destinataire vers une page de votre choix en ajoutant hc_contact_code=$CODE_CONTACT$ dans les paramètres de l'URL. Lors de l'envoi de la campagne, Hélium Connect remplacera le code contact par l'identifiant de la fiche contact pour chaque destinataire et en arrivant sur votre page web, cette librairie remplacera le code contact dans l'URL des formulaires générés par la valeur du paramètre hc_contact_code.
Problème sur le calcul de la hauteur
Si la hauteur n'est pas calculée correctement (une barre de scroll est visible), il est très probable qu'il s'agisse d'un problème de style dans le formulaire qui empêche de calculer la bonne hauteur correctement.
Si la correction de ce problème ne peut pas être faite tout de suite, vous avez la possibilité de compenser comme ceci :
<hc-form url="URL_FORMULAIRE" padding-bottom="15"></hc-form>
Dans cet exemple, la librairie ajoutera 15 pixels supplémentaires à chaque hauteur calculée. Cette option est une solution de secours en attendant une correction dans le formulaire plutôt qu'une solution définitive, il est préférable de corriger le style du formulaire sur le long terme.
Si le gabarit de votre formulaire a été réalisé par Net Hélium, remontez-nous le problème.
Si non renseignée, la valeur par défaut de padding-bottom
est 0.
Élément fixe en haut de page
Lorsqu'il y a un changement de page dans le formulaire (arrivée sur la page de confirmation ou changement de page de questions par exemple), la librairie déclenche un scroll automatique sur votre page web en haut de l'iframe afin de placer l'internaute au début de la nouvelle page du formulaire.
Si vous avez un élément fixe en haut de votre page (typiquement un menu fixe qui reste visible à tout moment), il passera par dessus le début du formulaire. Pour éviter ce problème, vous pouvez utiliser le code suivant :
<hc-form url="URL_FORMULAIRE" scroll-offset="50"></hc-form>
Ce code indique à la librairie de décaler son scroll de 50 pixels par rapport au haut de la page.
À titre d'exemple, si on imagine que votre menu fixe fait 30 pixels de haut et que vous voulez un espace de 15 pixels entre le menu et le haut du formulaire après un scroll automatique réalisé par la librairie, la valeur de scroll-offset
à renseigner est 45.
Si non renseignée, la valeur par défaut de scroll-offset
est 0.
Modification dynamique
Il est possible de modifier dynamiquement les valeurs des attributs en JavaScript et elles seront prises en compte instantanément.
<hc-form>
est une balise HTML comme une autre, il est donc possible de lui attribuer un id
ou une class
pour sélectionner le(s) formulaire(s) qui vous intéresse en CSS ou en JavaScript.
Chaque attribut est mappé sur une propriété JavaScript correspondante :
// Récupération d'un <hc-form> avec un id `contact`
const contactForm = document.querySelector("hc-form#contact");
// Modification des propriétés
contactForm.url = "URL_AUTRE_FORMULAIRE";
contactForm.paddingBottom = 15;
contactForm.scrollOffset = 50;
Personnalisation du style
Les balises <hc-form>
peuvent être stylées comme n'importe quelle autre balise HTML :
/* Bordure bleue sur tous les <hc-form> ayant la classe `blue-border` */
hc-form.blue-border {
border: 2px solid #0099cc;
}
Si vous voulez modifier le style de l'iframe encapsulée dans un <hc-form>
ou du message d'erreur en cas d'URL non valide :
/* Bordure bleue sur l'iframe de tous les <hc-form> ayant une classe `blue` */
hc-form.blue::part(iframe) {
border: 2px solid #0099cc;
}
/* Alignement à droite du message d'erreur du <hc-form> ayant un id `contact` */
hc-form#contact::part(error-msg) {
text-align: right;
}
La librairie définie des variables CSS avec des valeurs par défaut pour certaines règles CSS du message d'erreur (font-family
, font-size
et color
) :
--hc-forms-error-font-family: Verdana, Arial, sans-serif;
--hc-forms-error-font-size: 1rem;
--hc-forms-error-color: #ff0000;
Vous pouvez modifier les valeurs pour ces règles en changeant les valeurs de ces variables :
/* Le message d'erreur de tous les <hc-form> aura une `font-size` de 2rem */
hc-form {
--hc-forms-error-font-size: 2rem;
}
/* Le message d'erreur sera vert pour les <hc-form> ayant une classe `green-error` */
hc-form.green-error {
--hc-forms-error-color: #4bd116;
}
Les styles par défaut de l'iframe sont les suivants :
border: none;
width: 100%;
Les styles par défaut du message d'erreur sont les suivants :
text-align: center;
font-family: var(--hc-forms-error-font-family, Verdana, Arial, sans-serif);
font-size: var(--hc-forms-error-font-size, 1rem);
color: var(--hc-forms-error-color, #ff0000);
Licence
Cette librairie est mise à disposition sous licence MIT.