DiscoTOC - sommario automatico

:discourse2: Riepilogo DiscoTOC ti permetterà di generare un indice interattivo per i tuoi argomenti con un solo click!
:eyeglasses: Anteprima Anteprima su Discourse Theme Creator
:hammer_and_wrench: Link al Repository https://github.com/discourse/DiscoTOC
:open_book: Nuovo su Discourse Themes? Guida per principianti all’uso di Discourse Themes

Installa questo componente del tema

Esempi

Desktop

Mobile

Funzionalità

toc = indice dei contenuti

  • Genera automaticamente l’intero indice tramite un pulsante nel menu a ingranaggi del compositore

  • L’indice rimarrà sempre sullo schermo - scorre con il contenuto come il widget di avanzamento dell’argomento

  • Mentre scorri oltre le sezioni nell’argomento, l’elemento attivo nell’indice dei contenuti verrà impostato come attivo (evidenziazione blu)

  • Aggiunge attributi ID alle intestazioni (puoi collegarti a una sezione specifica da un altro argomento/post)

  • Cliccando su qualsiasi link nell’indice, il browser verrà istruito a navigare alla sezione pertinente (scorrimento fluido)

  • Aggiunge un link copiabile accanto a ogni intestazione (se desideri collegarti ad essa)

  • Supporto RTL

  • I colori si basano sulla tua palette di colori attiva corrente

Come funziona?

In sintesi, cerca le intestazioni negli argomenti che sono contrassegnate per avere un indice (tramite il pulsante del compositore) e, se risulta che l’argomento corrente è contrassegnato, prende tutte le intestazioni e le inserisce nell’indice (annidate in base al livello delle intestazioni) - ciò significa che il tuo markdown deve essere sintatticamente corretto.

# intestazione 1
## intestazione 2
### intestazione 3
#### intestazione 4
##### intestazione 5
###### intestazione 6

Sei libero di tornare avanti e indietro nei livelli delle intestazioni, ma l’ordine deve essere corretto.

# intestazione 2 
## intestazione 3
## intestazione 3
### intestazione 4
## intestazione 3
# intestazione 2

ecc...

Affinché i link nell’indice funzionino, le intestazioni devono avere attributi ID. Il componente controllerà se le intestazioni hanno già degli ID e, se sì, verranno rispettati. Questo è utile se hai mai creato manualmente un indice.

Se le intestazioni non hanno ID, ne genererà uno per ogni intestazione in base al suo testo (i caratteri indesiderati vengono rimossi).

Una volta completato tutto ciò, verrà aggiunto anche un link accanto a ogni pulsante che collega direttamente a quella sezione:

Impostazioni

Nome Descrizione
livello di fiducia minimo per creare l’indice Il livello di fiducia minimo che un utente deve avere per vedere il pulsante dell’indice nel compositore
testo indice del compositore Testo che appare nella parte superiore del pannello di anteprima del compositore per indicare che l’argomento avrà un indice dei contenuti
categorie indice automatico Abilita automaticamente l’indice negli argomenti in queste categorie
tag indice automatico Abilita automaticamente l’indice negli argomenti con questi tag
intestazione minima indice Numero minimo di intestazioni in un argomento affinché l’indice dei contenuti venga mostrato

Traduzioni

Traduzione Predefinito
table_of_contents indice dei contenuti
insert_table_of_contents Inserisci indice dei contenuti
jump_bottom Vai alla fine
toggle_toc.show_timeline Cronologia
toggle_toc.show_toc Contenuti

Il tema include tre stringhe che puoi tradurre o modificare.

table_of_contents: "indice dei contenuti"

Questa viene utilizzata per il pulsante che apre l’indice su mobile.

insert_table_of_contents: "Inserisci indice dei contenuti"

Questa viene utilizzata come testo per il pulsante dell’indice nel menu a ingranaggi del compositore.

topic_will_contain_a_table_of_contents: "Questo argomento conterrà un indice dei contenuti"

Questo è il testo che appare nell’anteprima del compositore per indicare che verrà generato un indice per l’argomento.

Come creo un indice?

  1. Scrivi un argomento con intestazioni sintatticamente corrette
  2. Clicca sul pulsante dell’indice nel menu a ingranaggi (appare solo durante la creazione di un argomento regolare; le risposte e i messaggi privati vengono ignorati)
  3. Fatto.

Cosa succede al widget di avanzamento dell’argomento quando un argomento ha un indice?

Come puoi probabilmente immaginare, non c’è spazio per mostrare entrambi contemporaneamente, quindi il modo in cui funziona questo componente è il seguente:

in un argomento con un indice, il widget di avanzamento dell’argomento viene nascosto mentre il primo post è sullo schermo, e vedi l’indice al suo posto.

Una volta che scorri oltre il primo post, l’indice non scorrerà con te e verrà mostrato l’avanzamento dell’argomento mentre leggi le risposte.

Quindi, i primi post ricevono l’indice, e i post successivi ricevono il widget di avanzamento dell’argomento regolare.

Ciò avviene sia su desktop che su mobile.

Ci sono degli svantaggi nell’uso di questo componente?

Niente di cui io sia a conoscenza, tutte le modifiche vengono effettuate lato client. Quindi puoi facilmente rimuovere il componente e i tuoi post torneranno come erano prima dell’installazione.

Limitazioni

Questo componente presuppone il layout standard degli argomenti. Di conseguenza, non funzionerà con i temi che modificano tale layout, come il tema Vincent. Il supporto per i temi popolari che modificano il layout arriverà in una fase successiva sotto forma di impostazioni del componente.

Crediti

Ho iniziato con la libreria tocify.js di Greg Franko. Tuttavia, sembra che non sia stata aggiornata da un po’, quindi questa è essenzialmente una hard-fork che rimuove molte funzionalità non necessarie, integra e stilizza il resto per Discourse.

Quindi, non ci sono richieste esterne e la dimensione totale è di circa 4kb gzip.

Un grande grazie a @erlend_sh per il prezioso feedback e a @david per il suo aiuto con le traduzioni.

:discourse2: Ospitato da noi? I componenti del tema sono disponibili per l’uso nei nostri piani Pro, Business ed Enterprise.

182 Mi Piace
Automatic Table of Contents generation
Creative Uses of Discourse
Wiki improvement – Split content into multiple sections?
:cn: DiscoTOC 自动内容表格
Big Header - Little Header
How To Add Marker To Table Of Contents Feature?
What are the different ways to customize content inside a post (custom attributes and such)
Tagged topic progress bar - feasible or not?
Reader Mode
How can i show a floating sticky 300x250 Adsense Ad on right side bar of topic page above the fold?
How do you create a table of content like this one?
Timeline with labelled step by step sections - how is this achieved?
How to get topic navigation menu
Is anyone working on a Discourse Wiki?
Traditional multi level hierarchy vs flat discourse hierarchy
Theme Components - Can Discourse hosted sites install them?
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
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)
?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
Layouts Plugin
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
Copy pasting nested lists from Word into a post
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 post sono stati divisi in un nuovo argomento: Come spostare il TOC sul lato sinistro del post?

Non so come sia implementato questo componente o molto sulla struttura frontend di Discourse, quindi posso solo fare un’ipotesi.

La barra di avanzamento potrebbe essere mostrata solo a) se ci sono più di 1 post nell’argomento e b) la sua partenza potrebbe essere regolata dal 2° post (invece che dal 3°), ma anche c) aggiungere un margine inferiore/superiore confortevole a uno dei due elementi per assicurarsi che l’altro rimanga sufficientemente distante (es. 1vh) da non sembrare strano?

In altre parole, invece di usare l’intero 2° post come spazio, usa il CSS per consentire un po’ di spazio tra loro (se c’è più di 1 post).

Ancora una volta, questo potrebbe non avere alcun senso dato che non so molto sul modo in cui funziona al momento.

3 Mi Piace

Ciao! Abbiamo recentemente installato DiscoTOC per i nostri forum e ci chiedevamo se fosse possibile far leggere al componente il testo alternativo (alt text) nelle immagini? Abbiamo usato immagini per alcune intestazioni delle note di rilascio…

come questa:
Performance and Stability

E sfortunatamente il sistema TOC non sembra in grado di analizzare un’immagine come intestazione, creando una voce vuota nell’elenco e creando un link che porta a una pagina vuota. C’è qualche soluzione alternativa a questo oltre a “non usare immagini”? Grazie! Per il resto, adoriamo il sistema.

1 Mi Piace

La mia ipotesi è che la soluzione sia non usare immagini come titoli, ma forse ci sarà un modo per farlo funzionare aggiungendo del codice al tuo sito che si agganci al codice di DiscoTOC. Se valga la pena esaminare questa possibilità dipenderà da quanto sia importante per te usare immagini nei titoli dei post.

3 Mi Piace

Abbiamo utilizzato immagini come intestazioni nelle nostre note sulla patch in modo coerente per un bel po’ di tempo ormai, ed è parte del nostro marchio e della nostra presentazione; non solo sui forum, ma anche su Steam e simili. Vorremmo avere la possibilità di continuare a utilizzare immagini come intestazioni pur utilizzando DiscoTOC per mantenere la coerenza.

DiscoTOC è stato ottimo per altre cose, come un riepilogo di AMA, un megapost sulla nostra applicazione di avvio del server dedicato, guide per i nuovi giocatori, ecc. Ci piace molto il sistema, ma vorremmo un po’ di funzionalità aggiuntive per il modo in cui presentiamo le note sulla patch.

1 Mi Piace

La funzionalità di ancoraggio dell’intestazione su questo componente è leggermente in conflitto con la funzionalità Automatic header links aggiunta in 2.7.0beta6, poiché le intestazioni ottengono due icone al passaggio del mouse, una da Discourse e una da DiscoTOC. C’è un modo per aggirare questo problema?

1 Mi Piace

Ciao,

Puoi nascondere l’ancora Automatic header links con

.anchor {
  display: none;
}

Ciao dodesz,

Ho reso la larghezza del post molto più grande di quella predefinita e dopo aver installato questo componente sembra sbagliata, potresti dirmi come risolvere questo problema?

:heart: grazie!

Selection_839

1 Mi Piace

Su un forum che esegue Discourse 2.8.0.beta4 (90232af778), l’inclusione del componente DiscoTOC porta a un messaggio di errore:

oops

Il componente era stato attivato in precedenza e aveva sollevato un problema anche con la versione di Discourse precedentemente installata, anche se non so quale fosse quella versione.

Riesci a trovare messaggi di errore relativi al problema nei log degli errori del tuo sito?

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

1 Mi Piace

Sfortunatamente, non sono riuscito a trovare nulla di utile in /logs.

Sì, ecco l’estratto pertinente da 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 Mi Piace

Quando un’intestazione è all’interno di una citazione, l’intestazione non viene visualizzata nel TOC. Si potrebbe cambiare questo comportamento?

Questa intestazione non apparirà nel TOC

Contenuto citato

Questa intestazione APPARE nel TOC

Contenuto citato

Non so come sia previsto che funzioni, ma normalmente no perché fa parte di una citazione, non di un titolo di quel testo.

2 Mi Piace

Potresti provare a usare l’HTML <blockquote> invece? Ciò consentirebbe all’intestazione # di trovarsi all’inizio di una riga.

Esempio:

<blockquote>

### Intestazione di ancoraggio

</blockquote>

Intestazione di ancoraggio

Non l’ho provato in un TOC (indice), ma sembra funzionare con le intestazioni con ancoraggio automatico in un post normale.

Perché vuoi che le intestazioni tra virgolette appaiano nell’indice? Qual è il tuo caso d’uso?

Grazie per l’idea. Tuttavia, non ha funzionato per me.

Ecco un esempio di quando uso le citazioni per strutturare visivamente il contenuto che inizia sotto Area Problematica: Età

3 Mi Piace

Perché stai usando le citazioni in quel modo? Indicare la fonte è sufficiente. Inoltre, grammaticalmente è sbagliato, anche in inglese.

È un bug o solo un altro utente, ma… come dovrei chiudere il TOC? Stavo cercando istruzioni di base su come un utente finale dovrebbe usare i messaggi privati e ovviamente sono andato alla documentazione per i nuovi utenti e ho aperto il TOC per vedere se c’erano informazioni.

Stavo usando iPad e DiscourseHub.

Ho ottenuto questo:

kuva

Il TOC va bene. Ma si sovrappone al testo e non sono riuscito a farlo nascondere di nuovo. Quindi cosa diavolo ho sbagliato, o non ho fatto affatto :pleading_face: