Sondages Discourse

:discourse2: Résumé Le plugin Discourse Surveys vous permet de créer des sondages directement dans vos publications de forum Discourse en utilisant une syntaxe Markdown simple.
:hammer_and_wrench: Lien vers le dépôt \u003chttps://github.com/discourse/discourse-surveys\u003e
:open_book: Guide d’installation Comment installer des plugins dans Discourse

Le plugin Discourse Surveys vous permet de créer des sondages directement dans vos publications de forum Discourse en utilisant une syntaxe Markdown simple. Le plugin prend actuellement en charge une variété de types de questions tels que les boutons radio, les cases à cocher, les listes déroulantes, les entrées numériques, les zones de texte, les évaluations par étoiles et les évaluations pouce levé/pouce baissé.

Fonctionnalités

  • 7 Types de champs différents : Boutons radio, cases à cocher, listes déroulantes, zones de texte, sélection numérique, évaluations par étoiles et évaluations pouce levé/pouce baissé

  • Champs Obligatoires/Facultatifs : Marquez les champs comme obligatoires pour garantir leur complétion

  • Prise en charge des Emojis : Utilisez des emojis dans vos options de sondage

  • Prise en charge HTML : Formatage de texte enrichi dans les questions et les options

  • Authentification Utilisateur : Invite de connexion automatique pour les utilisateurs anonymes

  • Suivi des Réponses : Empêche les soumissions en double par le même utilisateur

  • Sensible aux Permissions : Respecte les permissions de sujet et de catégorie

  • Adaptatif Mobile : Fonctionne parfaitement sur tous les appareils

Utilisation

Structure de Sondage de Base

Tous les sondages doivent être encapsulés dans des balises [survey] :


[survey name="mon-sondage" title="Sondage de Feedback Client"]

<!-- Les champs du sondage vont ici -->

[/survey]

Attributs du Sondage

  • name : Identifiant unique pour le sondage (par défaut : « survey »)

  • title : Titre facultatif affiché en haut du sondage

  • public : Définir la visibilité (fonctionnalité future)

  • status : Statut du sondage (fonctionnalité future)

Types de Champs

1. Boutons Radio (Choix Unique)


[radio question="Quelle est votre couleur préférée ?"]

- Rouge

- Bleu

- Vert

- Jaune

[/radio]

2. Cases à Cocher (Choix Multiple)


[checkbox question="Quelles fonctionnalités utilisez-vous ? (Sélectionnez toutes celles qui s'appliquent)"]

- Notifications par e-mail

- Application mobile

- Notifications de bureau

- Accès API

[/checkbox]

3. Sélection par Liste Déroulante


[dropdown question="Quel est votre groupe d'âge ?"]

- Moins de 18 ans

- 18-24

- 25-34

- 35-44

- 45-54

- 55+

[/dropdown]

4. Zone de Texte (Texte Long)


[textarea question="Veuillez fournir un feedback détaillé :" required="false"]

[/textarea]

5. Sélection Numérique


[number question="Évaluez cette fonctionnalité de 1 à 10 :" min="1" max="10"]

[/number]

6. Évaluation par Étoiles


[star question="Comment évalueriez-vous votre expérience globale ?"]

[/star]

7. Pouce Levé/Baissé


[thumbs question="Recommanderiez-vous ceci à d'autres ?"]

[/thumbs]

Attributs de Champ

Tous les types de champs prennent en charge ces attributs :

  • question : Le texte de la question (obligatoire)

  • required : Si le champ doit être rempli (true/false, par défaut true)

  • min : Valeur minimale pour les champs numériques

  • max : Valeur maximale pour les champs numériques

Exemple Complet

Markdown de Sondage de Base

Voici un exemple de base de Markdown de sondage incluant tous les champs disponibles :

[survey name="sondage-genial-pouces" title="Sondage Génial"]

[radio question="Choisissez une seule option :"]
- chat
- chien
[/radio]

[checkbox question="Choisissez plusieurs options :"]
- rouge
- bleu
- vert
[/checkbox]

[dropdown question="Sexe :"]
- Masculin
- Féminin
[/dropdown]

[number question="Évaluez ce sondage de 1 à 10 :"]
[/number]

[textarea question="Quel est votre feedback sur xyz ?" required="false"]
[/textarea]

[star question="Comment évalueriez-vous l'expérience globale ?"]
[/star]

[thumbs question="Avez-vous été satisfait de nos services ?"]
[/thumbs]

[/survey]

Rendu du Sondage

Ci-dessous, un exemple de la façon dont le Markdown ci-dessus est rendu dans Discourse :

Utilisation Avancée

Utilisation d’Emojis dans les Options


[radio question="Choisissez votre animal préféré :"]

- 🐈 Chat

- 🐶 Chien

- 🐦 Oiseau

- 🐠 Poisson

[/radio]

Formatage HTML dans les Questions


[radio question="Quel \u003cstrong\u003elangage de programmation\u003c/strong\u003e préférez-vous ?"]

- JavaScript

- Python

- Ruby

- Go

[/radio]

Champs Obligatoires et Facultatifs Mixtes


[survey name="sondage-mixte"]

[radio question="Quel est votre rôle ?" required="true"]

- Développeur

- Designer

- Manager

- Autre

[/radio]

[textarea question="Des pensées supplémentaires ?" required="false"]

[/textarea]

[/survey]

Résultats du Sondage

Actuellement, ce plugin n’a pas d’interface utilisateur backend pour visualiser directement les résultats du sondage. Au lieu de cela, vous pouvez vous fier aux requêtes Data Explorer pour récupérer et analyser les réponses au sondage. Voici un exemple de requête :

-- [params]
-- text :survey_name = survey

SELECT
  s.id,
  s.name,
  s.post_id,
  sf.question,
  COALESCE(sr.value, sfo.html) AS value,
  sr.user_id,
  sr.created_at AS responded_at
FROM
  surveys s
  JOIN survey_fields sf ON sf.survey_id = s.id
  JOIN survey_responses sr ON sr.survey_field_id = sf.id
  LEFT JOIN survey_field_options sfo ON sfo.id = sr.survey_field_option_id
WHERE
  s.name = :survey_name
ORDER BY
  s.id DESC

Permissions et Sécurité

  • Connexion Requise : Les utilisateurs anonymes doivent se connecter avant de soumettre des réponses

  • Une Réponse par Utilisateur : Chaque utilisateur ne peut soumettre qu’une seule réponse par sondage

  • Permissions de Sujet : Les utilisateurs doivent avoir l’accès en lecture au sujet pour voir les sondages

  • Permissions de Publication : Les utilisateurs doivent avoir les permissions de publication dans le sujet pour soumettre des réponses

  • Sujets Archivés : Les sondages dans les sujets archivés ne peuvent pas accepter de nouvelles réponses

  • Publications Supprimées : Les sondages dans les publications supprimées ne sont plus accessibles

Limitations

  • Un seul sondage est autorisé par publication

  • La structure du sondage ne peut pas être modifiée après réception des réponses

  • Toutes les questions des champs du sondage doivent être uniques au sein d’un seul sondage

  • Les questions des champs du sondage ne peuvent pas être vides

Détails Techniques

Schéma de Base de Données

Le plugin crée quatre tables de base de données principales :

  • surveys : Enregistrements principaux des sondages

  • survey_fields : Champs individuels dans les sondages

  • survey_field_options : Options pour les champs basés sur le choix

  • survey_responses : Réponses des utilisateurs aux champs du sondage

Style

Le plugin inclut un CSS adaptatif qui s’adapte à votre thème. Un style personnalisé peut être ajouté en ciblant ces classes CSS :

  • .survey - Conteneur principal du sondage

  • .survey-field - Enveloppe de champ individuelle

  • .field-[type] - Conteneurs de types de champs spécifiques

  • .submit-response - Bouton de soumission

32 « J'aime »

Ainsi, les utilisateurs ne peuvent pas voir les résultats (sauf s’ils ont les droits d’utiliser la requête) et ceci est totalement destiné aux administrateurs/personnel de fond ?

3 « J'aime »

Oui, c’est exact.

7 « J'aime »

Ce n’est pas très pratique :cry:

3 « J'aime »

Besoin d’une option pour publier les résultats de l’enquête. Sinon, il est préférable d’utiliser plusieurs sondages.

3 « J'aime »

Bonjour

Le rendu Markdown d’exemple est le suivant dans un nouveau sujet. Mon Discourse est mis à jour vers la dernière version.

Quel pourrait être le problème ?

Cordialement

Salut @ppcole,

Ceci est ce qui est affiché dans l’aperçu du compositeur lorsque vous créez l’enquête. Une fois que vous avez créé le sujet, il s’affichera correctement comme prévu.

Merci Arpit. Ça a fonctionné. Au plaisir de voir les améliorations.

1 « J'aime »

Puis-je savoir si vous travaillez sur ce point, mais sans réelle priorité ?

Ce serait formidable que cela continue à être développé - il a énormément de potentiel.

J’ai constaté que le SQL ci-dessus extrayait les résultats, mais pas dans un format facile à exploiter ; cela nécessiterait une tonne de transformations au niveau de la feuille de calcul pour permettre une analyse utile.

Cependant, avec un peu d’aide de l’IA générative, j’ai pu produire une requête Data Explorer très performante. En raison de certaines limitations de Data Explorer, il n’est pas possible de la rendre suffisamment dynamique pour gérer une variété d’enquêtes ; en gros, vous avez besoin d’une requête sur mesure par enquête.

Heureusement, l’IA générative peut rendre cela assez simple. Voici un exemple d’invite qui fonctionnera probablement dans la plupart des services d’IA générative (si vous n’avez pas le plugin d’IA actif) - il suffit d’y coller votre markdown d’enquête et vous devriez être prêt :

Invite d'IA générative pour produire une requête SQL personnalisée pour une enquête spécifique

J’ai une enquête définie en format markdown, et j’ai besoin d’une requête SQL pour extraire les résultats de l’enquête d’une base de données Discourse en utilisant le plugin Data Explorer. L’enquête comprend différents types de questions tels que radio, dropdown, star, checkbox, textarea, thumbs et number. Je souhaite que la requête produise des résultats avec chaque utilisateur ayant une seule ligne et chaque question ayant sa propre colonne. Pour les questions à cases à cocher, plusieurs réponses doivent être concaténées en une seule chaîne.

Voici le markdown de l’enquête :

Collez votre markdown d'enquête ici

Voici la requête originale utilisée pour obtenir les résultats de l’enquête :

-- [params]
-- text :survey_name = survey

SELECT s.id, s.name, s.post_id, sf.question, COALESCE(sr.value, sfo.html) AS value, sr.user_id, sr.created_at as responded_at
FROM surveys s
JOIN survey_fields sf ON sf.survey_id = s.id
JOIN survey_responses sr ON sr.survey_field_id = sf.id
LEFT JOIN survey_field_options sfo ON sfo.id = sr.survey_field_option_id
WHERE s.name = :survey_name
ORDER BY s.id DESC

Veuillez générer une requête SQL qui :

  • Code en dur le nom de l’enquête.
  • Utilise l’agrégation conditionnelle pour pivoter les données, avec chaque question comme colonne.
  • Utilise STRING_AGG pour les questions à cases à cocher afin de gérer plusieurs réponses.
  • Assure que la sortie est regroupée par user_id et triée par user_id.
  • Est formatée pour la lisibilité et inclut des commentaires expliquant la logique si nécessaire.

Conseils supplémentaires pour le plugin Data Explorer :

  • La requête doit être compatible avec le plugin Discourse Data Explorer, ce qui signifie qu’elle ne doit pas se terminer par un point-virgule.
  • Utilisez des noms de colonnes comme user_id pour tirer parti des fonctionnalités de liaison automatique dans Data Explorer.
  • Évitez d’utiliser du SQL dynamique, car le plugin ne le prend pas en charge.
  • Assurez-vous que la requête est efficace et optimisée pour les performances, car elle peut être exécutée sur de grands ensembles de données.
8 « J'aime »

C’est un excellent petit plugin qui est étonnamment riche en fonctionnalités. Merci de l’avoir créé.

@nathank excellent travail sur le guide pour construire rapidement une requête de résultats.

4 « J'aime »

Je l’ai installé sur mon site auto-hébergé pour l’essayer, et c’est vraiment très bien !

Je me rends compte que c’est anathème au discours, mais ce serait utile s’il était possible de créer des sondages qui peuvent être remplis anonymement, sans se connecter. Ou du moins d’anonymiser les résultats afin qu’ils ne soient pas associés à des utilisateurs spécifiques.

Et bien sûr, oui, la possibilité de consulter les résultats comme avec les sondages sans avoir à recourir à l’explorateur de données serait fantastique.

5 « J'aime »

Oui, j’ai rencontré le même problème. J’espère qu’il existe une solution.

3 « J'aime »