Enquêtes Discourse

|||
-|-|-|
:discourse2: | Résumé | Le plugin Discourse Surveys vous permet de créer des sondages directement dans vos publications de forum Discourse à l’aide d’une simple syntaxe Markdown.
:hammer_and_wrench: | Lien du 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 à l’aide d’une simple syntaxe Markdown. 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 champs numériques, les zones de texte, les évaluations par étoiles et les évaluations pouce levé/baissé.

Markdown de sondage de base

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

[survey name="awesome-survey-thumbs" title="Awesome Survey"]

[radio question="Choose any one option:"]
- cat
- dog
[/radio]

[checkbox question="Choose multiple options:"]
- red
- blue
- green
[/checkbox]

[dropdown question="Gender:"]
- Male
- Female
[/dropdown]

[number question="Rate this survey from 1 to 10:"]
[/number]

[textarea question="What is your feedback about xyz?" required="false"]
[/textarea]

[star question="How would you rate overall experience?"]
[/star]

[thumbs question="Were you satisfied with our services?"]
[/thumbs]

[/survey]

Rendu du sondage

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

Résultats du sondage

Actuellement, ce plugin ne dispose pas d’interface utilisateur backend pour visualiser directement les résultats du sondage. Au lieu de cela, vous pouvez utiliser les requêtes Data Explorer pour récupérer et analyser les réponses aux sondages. 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

Portée future

Le plugin a un potentiel pour de nombreuses améliorations. N’hésitez pas à rejoindre la discussion et à soumettre des pull requests sur le dépôt du plugin.

28 « 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.
7 « 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.

4 « J'aime »

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

3 « J'aime »