The toHTML S3 generic method converts various report objects into HTML representations.
This is the primary method for rendering report content for display in web browsers,
IDE Viewer, or for inclusion in Shiny applications.
Arguments
- x
-
The object to convert to HTML. Supported types include:
teal_card: A list-like structure containing report elementsteal_report: A report object containing ateal_cardReportCard: Deprecated R6 class for report cardscode_chunk: Code blocks created withcode_chunk()chunk_output: Output from evaluated code chunksPlot objects:
ggplot,recordedplot,trellis,grobTable objects:
data.frame,rtables,TableTree,ElementaryTable,listing_df,gtsummary,flextable,datatablesText:
characterstrings (rendered as markdown)Other objects: Conditions, model summaries, etc.
- ...
Additional arguments passed to methods.
Value
An HTML representation of the input object. The exact return type depends on the input class:
For
teal_card: Abslib::card()containing all elementsFor
code_chunk: Abslib::accordion()with the codeFor plots: A
shiny::tags$img()tagFor text: HTML markup from markdown conversion
For tables: HTML table elements
All returns are wrapped with htmltools::browsable() to enable viewer display.
Details
Relationship with teal_card
The teal_card class is a central component in the teal.reporter ecosystem. It is an S3 list
where each element represents a piece of report content (text, plots, tables, code chunks, etc.).
The toHTML method for teal_card objects:
Iterates through each element in the
teal_cardlistCalls
toHTML()recursively on each element based on its classWraps all converted elements in a
bslib::card()container
This hierarchical conversion allows complex report structures to be rendered as styled HTML with proper formatting for each content type.
Content Type Conversions
Text and Markdown: Character strings are converted to HTML using CommonMark markdown syntax.
Supports headers, lists, code blocks, emphasis, and other markdown features.
Code Chunks: Created with code_chunk(), these are rendered as collapsible Bootstrap
accordions with syntax highlighting. The accordion includes the programming language indicator
and an icon.
Plots: Plot objects (ggplot, recordedplot, trellis, grob) are converted to PNG
images with base64-encoded data URIs, making them self-contained in the HTML output.
Tables: Table objects are converted to styled HTML tables, typically via flextable
for consistent formatting.
Viewer Integration
All HTML output is wrapped with htmltools::browsable(), which enables:
Automatic render in IDE Viewer when displayed interactively
Proper HTML dependency injection (Bootstrap CSS/JavaScript, Font Awesome icons, etc.)
Standalone HTML files with all required resources
You can override the browsable behavior with:
print(toHTML(x), browse = FALSE) # Print markup to console instead
See also
teal_report()for creating report objectsteal_card()for creating report cardscode_chunk()for creating code blocksrender()for rendering complete reports to files
Examples
# Initialize empty report
report <- teal_report()
# Add arbitrary markdown elements to the report's teal_card
teal_card(report) <- c(
teal_card(report),
"## Document section",
"Lorem ipsum dolor sit amet"
)
# Use within() to execute code and add code-chunk
report <- within(report, a <- 2)
# within() automatically captures code and outputs
report <- within(report, plot(a))
html <- tools::toHTML(report)
# display HTML markup in viewer
html
Document section
Lorem ipsum dolor sit amet
a <- 2
plot(a)
# Print HTML markup to console instead of viewer
print(html, browse = FALSE)
#> <div class="container-fluid">
#> <div class="card bslib-card bslib-mb-spacing html-fill-item html-fill-container" data-bslib-card-init data-require-bs-caller="card()" data-require-bs-version="5">
#> <div class="card-body bslib-gap-spacing html-fill-item html-fill-container" style="margin-top:auto;margin-bottom:auto;flex:1 1 auto;">
#> <h2>Document section</h2>
#>
#> <p>Lorem ipsum dolor sit amet</p>
#>
#> <div class="accordion code_chunk" data-require-bs-caller="accordion()" data-require-bs-version="5" id="bslib-accordion-1382">
#> <div class="accordion-item" data-value="rcode">
#> <div class="accordion-header">
#> <button class="accordion-button collapsed" type="button" data-bs-toggle="collapse" data-bs-target="#bslib-accordion-panel-6549" aria-expanded="false" aria-controls="bslib-accordion-panel-6549">
#> <div class="accordion-icon"></div>
#> <div class="accordion-title">
#> <span>
#> <i class="fas fa-code" role="presentation" aria-label="code icon"></i>
#> R
#> </span>
#> </div>
#> </button>
#> </div>
#> <div id="bslib-accordion-panel-6549" class="accordion-collapse collapse">
#> <div class="accordion-body">
#> <pre><code class="language-R">a <- 2</code></pre>
#> </div>
#> </div>
#> </div>
#> </div>
#> <div class="accordion code_chunk" data-require-bs-caller="accordion()" data-require-bs-version="5" id="bslib-accordion-2131">
#> <div class="accordion-item" data-value="rcode">
#> <div class="accordion-header">
#> <button class="accordion-button collapsed" type="button" data-bs-toggle="collapse" data-bs-target="#bslib-accordion-panel-2133" aria-expanded="false" aria-controls="bslib-accordion-panel-2133">
#> <div class="accordion-icon"></div>
#> <div class="accordion-title">
#> <span>
#> <i class="fas fa-code" role="presentation" aria-label="code icon"></i>
#> R
#> </span>
#> </div>
#> </button>
#> </div>
#> <div id="bslib-accordion-panel-2133" class="accordion-collapse collapse">
#> <div class="accordion-body">
#> <pre><code class="language-R">plot(a)</code></pre>
#> </div>
#> </div>
#> </div>
#> </div>
#> <img src="" style="width: 100%; height: auto;"/>
#> </div>
#> <script data-bslib-card-init>bslib.Card.initializeAllCards();</script>
#> </div>
#> </div>