DiscoTOC - sommaire automatique

:discourse2: Résumé DiscoTOC vous permettra de générer une table des matières interactive pour vos sujets en un seul clic !
:eyeglasses: Aperçu Aperçu sur Discourse Theme Creator
:hammer_and_wrench: Lien du dépôt https://github.com/discourse/DiscoTOC
:open_book: Nouveau dans les thèmes Discourse ? Guide du débutant pour utiliser les thèmes Discourse

Installer ce composant de thème

Exemples

Bureau

Mobile

Fonctionnalités

toc = table des matières

  • Génère automatiquement toute la toc via un bouton dans le menu engrenage de l’éditeur

  • La toc reste toujours à l’écran - elle défile avec le contenu comme le widget de progression du sujet

  • Au fur et à mesure que vous faites défiler les sections du sujet, l’élément actif dans la table des matières sera mis en surbrillance (surlignage bleu)

  • ajoute des attributs id aux titres (vous pouvez lier à une section spécifique depuis un autre sujet / message)

  • cliquer sur n’importe quel lien dans la toc indiquera au navigateur de naviguer vers la section pertinente (défilement fluide)

  • ajoute un lien copiable à côté de chaque titre (si vous souhaitez y lier)

  • Prise en charge du RTL (écriture de droite à gauche)

  • Les couleurs sont basées sur votre palette de couleurs active actuelle

Comment ça marche ?

En résumé, il recherche les titres dans les sujets qui sont marqués pour avoir une toc (via le bouton de l’éditeur) et s’il s’avère que le sujet actuel est marqué, alors il prend tous les titres et les place dans la toc (imbriqués dans l’ordre des niveaux de titre) - cela signifie que votre markdown doit être syntaxiquement correct.

# titre 1
## titre 2
### titre 3
#### titre 4
##### titre 5
###### titre 6

Vous êtes libre de revenir en arrière et d’avancer dans les niveaux de titre, mais l’ordre doit être correct

# titre 2 
## titre 3
## titre 3
### titre 4
## titre 3
# titre 2

etc...

Pour que les liens dans la toc fonctionnent, les titres doivent avoir des attributs id. Le composant vérifiera si les titres ont déjà des id et, s’ils en ont, ils seront respectés. C’est pratique si vous avez créé manuellement une toc.

Si les titres n’ont pas d’id, il en générera un pour chaque titre basé sur son texte (les caractères indésirables sont supprimés)

une fois tout cela fait, il ajoutera également un lien à côté de chaque bouton qui pointe directement vers cette section :

Paramètres

Nom Description
niveau de confiance minimum pour créer une TOC Le niveau de confiance minimum qu’un utilisateur doit avoir pour voir le bouton TOC dans l’éditeur
texte toc de l’éditeur Texte qui apparaît en haut du panneau d’aperçu de l’éditeur pour indiquer que le sujet aura une table des matières
catégories TOC automatique Activer automatiquement la TOC sur les sujets dans ces catégories
tags TOC automatique Activer automatiquement la TOC sur les sujets avec ces tags
titre min TOC Nombre minimum de titres dans un sujet pour que la table des matières soit affichée

Traductions

Traduction Défaut
table_of_contents table des matières
insert_table_of_contents Insérer une table des matières
jump_bottom Aller au bas
toggle_toc.show_timeline Chronologie
toggle_toc.show_toc Contenu

Le thème vient avec trois chaînes que vous pouvez traduire ou modifier.

table_of_contents: "table des matières"

cela est utilisé pour le bouton qui ouvre la toc sur mobile

insert_table_of_contents: "Insérer une table des matières"

cela est utilisé comme texte pour le bouton toc dans le menu engrenage de l’éditeur

topic_will_contain_a_table_of_contents: "Ce sujet contiendra une table des matières"

C’est le texte qui s’affiche dans l’aperçu de l’éditeur pour indiquer qu’une toc sera générée pour le sujet

Comment créer une toc ?

  1. Écrivez un sujet avec des titres syntaxiquement corrects
  2. Cliquez sur le bouton toc dans le menu engrenage (n’apparaît que lors de la création d’un sujet régulier - les réponses et les MP sont ignorés
  3. Profit.

Que se passe-t-il pour le widget de progression du sujet lorsqu’un sujet a une toc ?

Comme vous pouvez probablement le deviner, il n’y a pas d’espace pour afficher les deux en même temps, donc la façon dont ce composant fonctionne est la suivante :

dans un sujet avec une toc, le widget de progression du sujet est masqué tant que le premier message est à l’écran, et vous voyez la toc à la place.

Une fois que vous faites défiler au-delà du premier message, la toc ne défilera pas avec vous et la progression du sujet sera affichée à la place pendant que vous lisez les réponses.

Donc, les premiers messages obtiennent la toc, et les messages suivants obtiennent le widget de progression du sujet régulier.

Cela se produit à la fois sur le bureau et sur mobile.

Y a-t-il des inconvénients à utiliser ce composant ?

Rien dont je sois conscient, tous les changements sont faits côté client. Donc vous pouvez facilement retirer le composant et vos messages reviendront à leur état avant que vous ne l’installiez.

Limitations

Ce composant suppose la mise en page standard des sujets. Par conséquent, il ne fonctionnera pas avec les thèmes qui modifient cette mise en page, comme le thème Vincent. La prise en charge des thèmes populaires qui modifient la mise en page sera disponible à une étape ultérieure sous forme de paramètres du composant.

Crédits

J’ai commencé avec la bibliothèque tocify.js de Greg Franko. Cependant, il semble qu’elle n’ait pas été mise à jour depuis un moment, donc il s’agit essentiellement d’un hard-fork qui supprime beaucoup de fonctionnalités inutiles, intègre et style le reste pour Discourse.

Ainsi, il n’y a pas de requêtes externes et la taille totale est d’environ 4 ko gzip.

Un grand merci à @erlend_sh pour ses précieux commentaires et à @david pour son aide avec les traductions.

:discourse2: Hébergé par nous ? Les composants de thème sont disponibles à l’utilisation sur nos plans Pro, Business et Enterprise.

182 « J'aime »
Automatic Table of Contents generation
Creative Uses of Discourse
Wiki improvement – Split content into multiple sections?
:cn: DiscoTOC 自动内容表格
Timeline with labelled step by step sections - how is this achieved?
Traditional multi level hierarchy vs flat discourse hierarchy
What are the different ways to customize content inside a post (custom attributes and such)
Is anyone working on a Discourse Wiki?
Tagged topic progress bar - feasible or not?
Big Header - Little Header
Theme Components - Can Discourse hosted sites install them?
How to get topic navigation menu
Reader Mode
How To Add Marker To Table Of Contents Feature?
How do you create a table of content like this one?
How can i show a floating sticky 300x250 Adsense Ad on right side bar of topic page above the fold?
How to add table of content sidebar beside a topic?
How do I add a table of contents sidebar to a topic?
Cannot deep link to anchor in text
How can I compare arbitrary revisions of a post?
Understanding Discourse for new users
Problem with DiscoTOC: TypeError: _offsetCalculator.headerOffset is not a function
How to create an In-app Knowledge Base with Discourse Docs?
OP Contents on Progress Bar
How to get topic sidebar
Customizing your site with existing theme components
Link to headers (anchor links)
Outline Enable
What is essential content for a new community?
Tools for creating image-heavy articles
Layouts Plugin
Adding DiscoTOC to Published Pages
Customize Your Site Branding
Discourse Doc Categories
Gif icon not displaying and showing error
Must have plugins and components for Discourse?
I created a bookmarklet to create the table of content for forum posts
Could a List of Recommended Topics Be Added to the Top Menu?
Living with corrupted SVGs for almost a year. Need Help!
Something recently changed, can't increase `--topic-body-width`
How to enable side navigation?
Displaying "full topic" text on category page + access to subcategory from menu bar
Improve iPad screen real estate
Missing anchor links in certain TOC topics?
DiscoTOC not showing in composer after latest component update
Missing anchor links in certain TOC topics?
How to create a documentation theme used by discourse
Where's Jump to end?
Handling anchors in posts created with markdown
Reader Mode
Hidden Timeline button
Horizon Theme
Collections
Bulk Export of Raw Post Sources with Markup
AI summary in topic header
Contents button and Timeline button floating unexpectedly
:cn: Discourse Post Formatting Guide 加点格式,让帖子多姿多彩
Wiki table of contents on pro plan
Auto-Linkify Words
Missing strings (DiscoTOC)
Copy pasting nested lists from Word into a post
?page=n URLs have high CLS hence bad SEO
Require users to "Reply as Linked Topic"
Links not working
Using Posts as a Wiki?
Using Posts as a Wiki?
Is anyone working on a Discourse Wiki?
Using Posts as a Wiki?
Using Posts as a Wiki?
DiscoTOC & Brand Header - using together
Docs: Add link to top menu
More than two levels of [details]
Category page with fixed organization of topics
Blog Post Styling
Inlink the topics within the same article
Navigating to local URL fragment doesn't modify browser history
Relating to Profile Picture Scroll Functionality
Need to include PGN (chess game notation) in a post
How can I get a table of contents for my docs?
Linking to a heading within a post
Topic list on the right side
Set up Slack notifications using the discourse-chat-integration plugin
Wrong title in the history popup (firefox)
Possible to insert post in a topic
I created a bookmarklet to create the table of content for forum posts

4 messages ont été déplacées vers un nouveau sujet : Comment déplacer la table des matières sur le côté gauche de l’article ?

Je ne sais pas comment ce composant est implémenté ni grand-chose sur la structure frontend de Discourse, donc je ne peux que faire une supposition.

Ne pourrait-on pas n’afficher la barre de progression a) que s’il y a plus d’un message dans le sujet et b) ajuster son début pour qu’il parte du 2e message (au lieu du 3e), mais aussi c) ajouter une marge inférieure/supérieure confortable à l’un des deux éléments pour s’assurer que l’autre reste suffisamment éloigné (par exemple 1vh) pour ne pas avoir un aspect étrange ?

En d’autres termes, au lieu d’utiliser l’intégralité du 2e message comme espace, utiliser du CSS pour permettre un certain espace entre eux (s’il y a plus d’un message).

Encore une fois, cela n’a peut-être aucun sens car je ne sais pas grand-chose sur la façon dont cela fonctionne actuellement.

3 « J'aime »

Bonjour ! Nous avons récemment installé DiscoTOC pour nos forums et nous nous demandions s’il était possible de faire en sorte que le composant lise le texte alternatif dans les images ? Nous avons utilisé des images pour certains en-têtes de notes de mise à jour…

comme ceci :
Performance and Stability

Et malheureusement, le système TOC ne semble pas être capable d’analyser une image comme un en-tête, créant une entrée vide dans la liste et créant un lien qui mène à une page vide. Existe-t-il une solution de contournement à cela, autre que « ne pas utiliser d’images » ? Merci ! Nous aimons beaucoup le système par ailleurs.

1 « J'aime »

Je suppose que la solution consiste à ne pas utiliser d’images comme titres, mais il sera peut-être possible d’y parvenir en ajoutant du code à votre site qui s’intègre au code de DiscoTOC. La pertinence d’examiner cela dépendra de l’importance que vous accordez à l’utilisation d’images dans les titres des publications.

3 « J'aime »

Nous utilisons des images comme en-têtes dans nos notes de mise à jour de manière constante depuis un certain temps, et cela fait partie de notre image de marque et de notre présentation ; non seulement sur les forums, mais aussi sur Steam et autres plateformes. Nous aimerions avoir la possibilité de continuer à utiliser des images comme en-têtes tout en utilisant DiscoTOC afin de maintenir notre cohérence.

DiscoTOC a été excellent pour d’autres choses, comme le récapitulatif d’une AMA (Ask Me Anything), un méga-post sur notre application de lancement de serveur dédié, des guides pour les nouveaux joueurs, etc. Nous apprécions beaucoup le système, mais nous aimerions une fonctionnalité supplémentaire pour la manière dont nous présentons les notes de mise à jour.

1 « J'aime »

La fonctionnalité d’ancre de titre sur ce composant entre légèrement en conflit avec la fonctionnalité Liens automatiques d’en-tête ajoutée dans la version 2.7.0beta6, car les titres affichent deux icônes au survol, une de Discourse et une de DiscoTOC. Y a-t-il un moyen de contourner ce problème ?

1 « J'aime »

Bonjour,

Vous pouvez masquer l’ancre Automatic header links avec

.anchor {
  display: none;
}

Bonjour dodesz,

J’ai rendu la largeur des publications beaucoup plus grande que celle par défaut, et après avoir installé ce composant, cela semble incorrect. Pourriez-vous me dire comment résoudre ce problème ?

:heart: merci !

Selection_839

1 « J'aime »

Sur un forum utilisant Discourse 2.8.0.beta4 (90232af778), l’activation du composant DiscoTOC entraîne un message d’erreur :

oops

Le composant avait déjà été activé et avait soulevé un problème avec la version précédente de Discourse, bien que je ne puisse pas dire de quelle version il s’agissait.

Êtes-vous en mesure de trouver des messages d’erreur liés au problème dans les journaux d’erreurs de votre site ?

Ce message d’erreur est une erreur de backend, tandis que DiscoTOC est un composant de thème de frontend, il est donc difficile qu’ils soient liés. Avez-vous installé des plugins ?

1 « J'aime »

Malheureusement, je n’ai rien trouvé d’utile dans /logs.

Oui, voici l’extrait pertinent de app.yml :

hooks:
  after_code:
    - exec:
        cd: $home/plugins
        cmd:
          - git clone https://github.com/discourse/docker_manager.git
          - git clone https://github.com/discourse/discourse-openid-connect.git
          - git clone https://github.com/discourse/discourse-checklist.git
          - git clone https://github.com/discourse/discourse-push-notifications.git
          - git clone https://github.com/discourse/discourse-characters-required.git
          - git clone https://github.com/angusmcleod/discourse-news.git
          - git clone https://github.com/discourse/discourse-data-explorer.git
          - git clone https://github.com/DNOeV/discourse-watch-category.git
          - git clone https://github.com/discourse/discourse-footnote.git
          - git clone https://github.com/discourse/discourse-knowledge-explorer.git
1 « J'aime »

Lorsqu’un titre est dans une citation, il n’apparaît pas dans la table des matières (TOC). Ce comportement pourrait-il être modifié ?

Ce titre n’apparaîtra pas dans la TOC

Contenu cité

Ce titre apparaît bien dans la TOC

Contenu cité

Je ne sais pas comment cela est prévu pour fonctionner, mais normalement non, car cela fait partie de la citation, pas d’un titre de ce texte.

2 « J'aime »

Pourriez-vous essayer d’utiliser le <blockquote> HTML à la place ? Cela permettrait au titre # d’être au début d’une ligne.

Exemple :

<blockquote>

### En-tête d'ancre

</blockquote>

En-tête d’ancre

Je n’ai pas essayé dans une table des matières (TOC), mais cela semble fonctionner avec les en-têtes auto-ancrés dans une publication normale.

Pourquoi voulez-vous que les en-têtes entre guillemets apparaissent dans la table des matières ? Quel est votre cas d’utilisation ?

Merci pour l’idée. Cela n’a pas fonctionné pour moi, cependant.

Voici un exemple de quand j’utilise des citations pour structurer visuellement le contenu commençant sous Zone de problème : Âge

3 « J'aime »

Pourquoi utilisez-vous le guillemet de cette façon ? Indiquer la source suffit. De plus, grammaticalement, c’est faux, même en anglais.

Est-ce un bug ou juste un autre utilisateur, mais… comment dois-je fermer la table des matières (TOC) ? Je cherchais des instructions de base sur la façon dont un utilisateur final doit utiliser les messages privés et bien sûr, je suis allé dans la documentation pour les nouveaux utilisateurs et j’ai ouvert la TOC pour voir s’il y avait des informations.

J’utilisais un iPad et DiscourseHub.

J’ai obtenu ceci :

kuva

La TOC est très bien. Mais elle chevauche le texte et je n’ai pas réussi à la faire disparaître. Alors, qu’est-ce que j’ai fait de mal, ou rien du tout :pleading_face: