Menus latéraux des groupes Discourse

:information_source: Résumé Créer des menus latéraux personnalisés pour des groupes sélectionnés
:eyeglasses: Aperçu Rejoignez ce groupe de créateurs de thèmes puis prévisualisez ici
:hammer_and_wrench: Dépôt \u003chttps://github.com/Lillinator/discourse-group-sidebar-menus\u003e
:question: Guide d’installation Comment installer un thème ou un composant de thème
:open_book: Nouveau dans les thèmes Discourse ? Guide du débutant pour l’utilisation des thèmes Discourse

Installer ce composant de thème

:woman_technologist:t2: Vue d’ensemble

Ce composant de thème Discourse donne aux administrateurs du forum la possibilité de créer des menus latéraux personnalisés qui ne sont accessibles qu’aux membres de groupes sélectionnés.

Fonctionnalités clés :

  • Visibilité du menu basée sur le groupe - Les sections de menu n’apparaissent dans la barre latérale que pour les utilisateurs autorisés
  • Configuration basée sur des objets - Interface utilisateur de paramètres facile à utiliser pour créer des menus
  • Sections multiples - Créez un nombre illimité de sections de menu pour différents groupes (dans la limite du raisonnable)
  • Lien de modification rapide pour l’administrateur - L’icône de crayon dans les en-têtes de menu relie directement les administrateurs aux paramètres du composant

:briefcase: Quelques cas d’utilisation

  • Ressources et liens rapides réservés au personnel
  • Raccourcis pour les modérateurs de catégorie
  • Portails de groupe personnalisés (équipes de projet, groupes d’étude, clubs de lecture, membres VIP)
  • Liens vers des ressources de sites web parents ou partenaires

:gear: Paramètres

Sections de menu (menu_sections)

Ouvre l’éditeur de paramètres d’objet pour configurer des sections de menu de groupe personnalisées.

Propriétés de section

Propriété Description
Titre du menu Titre affiché comme en-tête de section de la barre latérale
Groupes autorisés Groupes autorisés à voir cette section de menu (max : 20 groupes par section)
Liens du menu Collection de liens à afficher dans cette section (max : 20 liens par section)

Propriétés de lien

Propriété Description
Icône Nom de l’icône FontAwesome (ex. : circle-info, star, user-group). Peut nécessiter d’être ajouté à Admin > Tous les paramètres du site > sous-ensemble d'icônes svg
Texte Libellé d’affichage pour le lien
URL Destination du lien - prend en charge les chemins relatifs (/faq, /my/preferences) et les URL absolues (https://example.com)

:wrench: Installation et configuration

  1. Installez le composant de thème comme indiqué sur Installing a theme or theme component.
  2. Accédez à l’ Éditeur de paramètres d'objets
  3. Cliquez sur le bouton + new_menu_section pour configurer la première section de menu personnalisée
  4. Donnez un titre au nouveau menu dans le champ Titre du menu, puis sélectionnez les groupes auxquels vous souhaitez donner accès.
  5. Cliquez sur + new_menu_section pour ajouter une autre section, ou Enregistrez les modifications.
Captures d'écran de configuration d'administration avec configuration d'exemple

Nouvelle installation - allez à l’ Éditeur de paramètres d'objets.

Scénario d’exemple avec 2 menus personnalisés et 3 utilisateurs, dont un administrateur :

  • @Catra aime les chats et est membre du groupe pink, qui aura accès au Menu Chat :grinning_cat:
  • @HelloKitty aime les chiens et est membre du groupe purple, qui aura accès au Menu Chien :dog_face:
  • @Lilly est membre de purple parce qu’elle possède un chien et que les chiens sont meilleurs. Cependant, elle est également administratrice du forum, et les administrateurs auront accès au Menu Chat parce que les chats ont besoin de plus de surveillance :dog_face: :cat_with_wry_smile:

Créez un nouveau menu personnalisé - pour notre exemple, créez Menu Chat et ajoutez les groupes autorisés à y avoir accès - pink et admins. Cliquez ensuite sur le bouton + menu_link pour configurer les liens pour le nouveau menu.

Ajoutez les liens du menu - 1. Nom de l’icône Fontawesome, 2. texte à afficher pour le lien, et 3. l’URL, relative ou absolue. Cliquez sur le bouton + menu_link pour ajouter un autre lien à ce menu.

Créez une autre section de menu personnalisée appelée Menu Chien, donnez uniquement l’accès au groupe purple et configurez les liens :

Captures d'écran de l'accès au menu latéral résultant

L’utilisateur @Catra a le menu Chat ! :grinning_cat:

L’utilisateur @HelloKitty a le menu Chien ! :dog_face:

L’utilisatrice administratrice @Lilly a les deux menus et peut les modifier ! :smiling_cat_with_heart_eyes:

Exemple de configuration

Titre du menu : "Ressources du personnel"
Groupes autorisés : staff
Liens :
  - Icône : wrench
    Texte : Guide de modération
    URL : /t/moderation-guide/123
  - Icône : chart-line
    Texte : Tableau de bord analytique
    URL : /admin/dashboard

:light_bulb: Notes importantes

Accès administrateur

Les administrateurs doivent s’ajouter aux groupes pour voir les menus configurés pour ces groupes. Le statut d’administrateur seul n’accorde pas l’accès à tous les menus personnalisés. C’est intentionnel ! De plus, les administrateurs qui appartiennent aux groupes autorisés d’un menu verront une icône de crayon dans l’en-tête de section qui mène aux paramètres du composant.

Configuration des groupes

  • Le groupe everyone n’est pas pris en charge - Utilisez l’interface utilisateur du pied de page de la barre latérale native pour créer des menus personnalisés globaux pour tous les utilisateurs, y compris les visiteurs anonymes.
  • Maximum de 20 groupes par section de menu. Si vous en avez besoin de plus, créez des sections dupliquées avec des attributions de groupe différentes.
  • Les utilisateurs appartenant à plusieurs groupes verront toutes les sections de menu auxquelles ils ont accès.

Test et organisation

Utilisez des comptes de test pour vérifier l’accès correct pour différentes combinaisons de groupes. Gardez une trace de vos configurations de menu pour éviter toute confusion à mesure que la complexité augmente ; une matrice d’accès ou une documentation similaire est recommandée pour les forums plus importants avec de nombreux groupes.

Considérations de sécurité

Ce composant fournit uniquement un contrôle d’accès au niveau de l’interface utilisateur. Il contrôle la visibilité du menu, pas l’accès aux ressources.

:white_check_mark: Expérience de navigation propre et organisée
:white_check_mark: Réduction de l’encombrement de l’interface utilisateur pour les utilisateurs non autorisés
:white_check_mark: Portails professionnels spécifiques aux groupes

Ceci n’est pas une fonctionnalité de sécurité. N’empêche pas l’accès aux sources des liens - ce composant contrôle uniquement ce qui est rendu dans la barre latérale, pas qui peut accéder aux ressources réelles.

Fiez-vous toujours au système de permission intégré de Discourse pour sécuriser les ressources réelles :

  • Configurez correctement les permissions de catégorie
  • Définissez des restrictions de visibilité des sujets
  • Utilisez des contrôles d’accès basés sur les groupes pour le contenu
  • Assurez-vous que les ressources privées nécessitent une authentification

Meilleure pratique pour les administrateurs :
Configurez séparément les permissions de sécurité des catégories liées et l’appartenance aux groupes - par exemple : un lien de menu vers une catégorie privée doit avoir les permissions de cette catégorie correctement configurées. Les administrateurs sont responsables de s’assurer que les liens vers des ressources externes sont correctement autorisés pour les groupes sélectionnés.


Ce fut un projet collaboratif avec @Moin - son apport, son inspiration et ses commentaires ont été inestimables.

9 « J'aime »

J’obtiens un 404 sur le dépôt.

EDIT : Tout est rentré dans l’ordre maintenant !

2 « J'aime »

haha, réessayez. J’ai oublié de le rendre public ! :laughing:

6 « J'aime »

Fabuleux ! Je le voulais depuis un certain temps. J’ai créé une belle collection de menus latéraux personnalisés utiles pour moi – des liens pour la modération, pour les tâches d’administration et de référence, pour la documentation de Discourse, pour le contenu externe auquel nous faisons fréquemment référence sur le forum, etc. Un menu contient des liens pour les diverses réunions périodiques qui utilise simplement le lien tag, par exemple /tag/comm-mgt-monthly, ce qui m’aide à accéder rapidement aux ordres du jour et aux procès-verbaux actuels et précédents.

J’ai souvent souhaité un moyen d’exporter mes configurations de menus latéraux personnalisés afin que d’autres membres de mon équipe puissent les importer – c’est une configuration bien supérieure !

Et les icônes ! Hourra ! Pour autant que je sache, la seule façon de le faire était d’ajouter du CSS personnalisé. Cette nouvelle solution est élégante.

Et durable ! Tous les administrateurs pourront modifier les fichiers de configuration, donc ils ne dépendront pas uniquement de moi. Merci @Lilly et @Moin !

1 « J'aime »

Bonjour @Lilly et @Moin,

Merci d’avoir créé ce composant.

J’utilisais Group sidebar menu sections - deprecated sur mon site auto-hébergé et lors de ma dernière mise à jour, j’ai été averti que l’ancien composant de thème avait été déprécié et qu’il fallait installer celui-ci à la place.

J’ai installé le composant et créé mon menu de groupe personnalisé, mais je ne vois pas comment déplacer le menu de groupe. (Je dois passer à côté de quelque chose d’évident. :see_no_evil_monkey:) Dans vos captures d’écran, votre Cat Menu et Dog Menu se trouvent dans la navigation de la barre latérale au-dessus de la section Topics, mais mon menu de groupe personnalisé apparaît tout en bas de ma navigation de barre latérale. Comment puis-je le déplacer au-dessus de Topics ?

1 « J'aime »

Ce n’est pas évident. Lilly a utilisé Discourse Sidebar Menu Reorder pour placer cat-menu en haut

2 « J'aime »

Merci beaucoup ! C’était très facile à configurer.

2 « J'aime »