Learn R Programming

ReporteRs (version 0.8.6)

addTOC: Add a table of contents into a document object

Description

Add a table of contents into a document object

Usage

addTOC(doc, ...)
"addTOC"(doc, stylename, level_max = 3, ...)
"addTOC"(doc, ...)

Arguments

doc
document object
...
further arguments passed to other methods
stylename
optional. Stylename in the document that will be used to build entries of the TOC.
level_max
max title level to show in the TOC (defaut to 3, from title1 to title3).

Value

a document object

Details

When working with docx object:

If stylename is not used, a classical table of content will be produced. If stylename is used, a custom table of contents will be produced, pointing to entries that have been formated with stylename. For example, this can be used to produce a toc with only plots.

When working with bsdoc object:

Table of contents will be added on the right side of the content.

See Also

docx, bsdoc, styles, addTitle, addParagraph

Examples

Run this code

# Create a new document
doc = docx( title = "title" )
#leave the first page blank and add a page break
doc = addPageBreak(doc)
# add a TOC (to be refresh when document is opened)
# and add a page break
doc = addTOC(doc)
doc = addPageBreak(doc)

# add titles that will be entries in the TOC
doc = addTitle( doc, "My first title", level = 1 )
doc = addTitle( doc, "My second title", level = 1 )

# Write the object in file "addTOC_example1.docx"
writeDoc( doc, "addTOC_example1.docx" )
doc = docx( title = "title" )

#leave the first page blank and add a page break
doc = addPageBreak(doc)

doc = addTitle( doc, "Plots", level = 1 )
doc = addPlot( doc, fun = plot,
  x = rnorm( 100 ),y = rnorm (100 ),
  main = "base plot main title"
)

doc = addParagraph( doc, value="graph example 1", stylename = "rPlotLegend" )

if( requireNamespace("ggplot2", quietly = TRUE) ){

  myplot = ggplot2::qplot(Sepal.Length, Petal.Length, 
    data = iris, color = Species,
    size = Petal.Width, alpha = I(0.7))
  doc = addPlot( doc = doc, fun = print, 
    x = myplot #this argument MUST be named, print is expecting argument 'x' 
  )
  doc = addParagraph( doc, value="graph example 2", 
    stylename = "rPlotLegend" )

}

# Because we used "rPlotLegend" as legend in plot
# , addTOC will use this stylename to define
# entries in the generated TOC
doc = addTOC(doc, stylename = "rPlotLegend")

# Write the object in file "addTOC_example2.docx"
writeDoc( doc, "addTOC_example2.docx" )
doc.filename = "addTOC_example/example.html"

options( "ReporteRs-fontsize" = 11 )
doc = bsdoc( )
doc = addTitle( doc, 'Title 1', level = 1 )

doc = addTitle( doc, 'Title 2', level = 1 )

doc = addTitle( doc, 'Title 3', level = 1 )

doc = addTitle( doc, 'Title A', level = 2 )

doc = addTitle( doc, 'Title B', level = 2 )

doc = addTOC( doc )

writeDoc( doc, file = doc.filename )

Run the code above in your browser using DataLab