---
title: "tableHTML"
author: "Theo Boutaris, Clemens Zauchner, Dana Jomar"
date: "`r Sys.Date()`"
output:
html_document
vignette: >
%\VignetteIndexEntry{gallery}
%\VignetteEngine{knitr::rmarkdown}
%\VignetteEncoding{UTF-8}
---
```{r setup, include=FALSE}
knitr::opts_chunk$set(echo=TRUE)
```
The following are a set of more complex examples of the tableHTML package. The goal of these
examples is to show you what you can do with the package and all the different ways you can use it
to make the HTML tables they way you want them to look. The point of the examples is to
demonstrate what can be achieved and not to show nice looking HTML tables (apart from the
demonstration of the themes).
### Row groups and Second Headers
```{r example1}
library(tableHTML)
tableHTML(mtcars,
rownames = FALSE,
widths = c(120, rep(50, 11)),
row_groups = list(c(10, 10, 12), c('Group 1', 'Group 2', 'Group 3')),
second_headers = list(c(3, 4, 5), c('col1', 'col2', 'col3')))
```
### Add row css and column css
```{r example2}
tableHTML(mtcars,
border = 5,
rownames = TRUE,
widths = c(100, 140, rep(50, 11)),
row_groups = list(c(10, 10, 12), c('Group 1', 'Group 2', 'Group 3')),
second_headers = list(c(3, 4, 6), c('col1', 'col2', 'col3'))) %>%
add_css_row(css = list('background-color', 'lightgray'), rows = odd(3:34)) %>%
add_css_row(css = list('background-color', 'lightblue'), rows = even(3:34)) %>%
add_css_column(css = list('background-color', 'white'), columns = 'row_groups')
```
### Add row, column, second header and header css
```{r example3}
tableHTML(mtcars,
border = 1,
rownames = TRUE,
widths = c(110, 140, rep(50, 11)),
row_groups = list(c(10, 10, 12), c('Group 1', 'Group 2', 'Group 3')),
second_headers = list(c(2, 5, 6), c('', 'col2', 'col3'))) %>%
add_css_row(css = list('background-color', 'lightgray'), rows = odd(3:34)) %>%
add_css_row(css = list('background-color', 'lightblue'), rows = even(3:34)) %>%
add_css_column(css = list('background-color', 'white'), columns = 'row_groups') %>%
add_css_second_header(css = list(c('border-top', 'border-left'), c('1px solid white', '1px solid white')),
second_headers = 1) %>%
add_css_header(css = list(c('border-top', 'border-left', 'border-right'),
c('1px solid white', '1px solid white', '1px solid white')),
headers = 1) %>%
add_css_header(css = list('background-color', 'lightgreen'), headers = 3:13)
```
### scientific theme
```{r example4}
tableHTML(mtcars,
rownames = TRUE,
widths = c(110, 140, rep(50, 11)),
row_groups = list(c(10, 10, 12), c('Group 1', 'Group 2', 'Group 3')),
second_headers = list(c(2, 5, 6), c('col1', '', 'col3'))) %>%
add_theme('scientific')
```
### rshiny-blue theme
```{r example5}
tableHTML(mtcars,
rownames = TRUE,
widths = c(110, 140, rep(50, 11)),
row_groups = list(c(10, 10, 12), c('Group 1', 'Group 2', 'Group 3')),
second_headers = list(c(2, 5, 6), c('', 'col2', 'col3'))) %>%
add_theme('rshiny-blue')
```
### colorize theme
```{r example6}
mtcars %>%
tableHTML(rownames = TRUE,
widths = c(140, rep(50, 11))) %>%
add_theme('colorize', color = 'navyblue')
```
### colorize theme with Two Colors
```{r example7.1}
mtcars %>%
tableHTML(rownames = TRUE,
widths = c(140, rep(50, 11))) %>%
add_theme_colorize(color=c('steelblue', 'green'))
```
### colorize theme with total rows and an id_column
```{r example7.2}
ts_to_df <- data.frame(year = trunc(time(AirPassengers)),
Month = month.abb[cycle(AirPassengers)],
AirPassengers,
stringsAsFactors = F)
ts_to_df <- ts_to_df[ts_to_df$year < 1951, ]
rbind(ts_to_df[1:12, 2:3],
c('AVG', round(mean(ts_to_df[1:12, ]$AirPassengers), 2)),
ts_to_df[13:24, 2:3],
c('AVG', round(mean(ts_to_df[13:24, ]$AirPassengers), 2))) %>%
tableHTML(rownames = FALSE,
widths = rep(75, 3),
row_groups = list(c(13, 13),
unique(ts_to_df$year))) %>%
add_theme_colorize(id_column = TRUE,
total_rows = c(13, 26),
color = c('#009999', 'yellow2'))
```
### Coloring a Row Group
```{r example8}
tableHTML(mtcars,
border = 5,
rownames = TRUE,
widths = c(100, 140, rep(50, 11)),
row_groups = list(c(10, 10, 12), c('Group 1', 'Group 2', 'Group 3')),
second_headers = list(c(3, 4, 6), c('col1', 'col2', 'col3'))) %>%
add_css_row(css = list('background-color', 'lightgray'), rows = odd(3:34)) %>%
add_css_row(css = list('background-color', 'lightblue'), rows = even(3:34)) %>%
add_css_column(css = list('background-color', 'white'), columns = 'row_groups') %>%
replace_html(pattern = '
Group 1',
replacement = ' | Group 1')
```
### Collapsed table
```{r example9, eval = FALSE}
tableHTML(mtcars,
border = 5,
rownames = TRUE,
collapse = 'separate',
widths = c(100, 140, rep(50, 11)),
row_groups = list(c(10, 10, 12), c('Group 1', 'Group 2', 'Group 3')),
second_headers = list(c(3, 4, 6), c('col1', 'col2', 'col3'))) %>%
add_css_row(css = list('background-color', 'lightgray'), rows = odd(3:34)) %>%
add_css_row(css = list('background-color', 'lightblue'), rows = even(3:34)) %>%
add_css_column(css = list('background-color', 'white'), columns = 'row_groups')
```

### Table with Second Headers
```{r example10}
tableHTML(mtcars,
border = 5,
rownames = TRUE,
collapse = 'collapse',
widths = c(140, rep(50, 11)),
second_headers = list(c(3, 4, 5), c('col1', 'col2', 'col3'))) %>%
add_css_row(css = list('background-color', 'lightgray'), rows = odd(3:34)) %>%
add_css_row(css = list('background-color', 'lightblue'), rows = even(3:34)) %>%
add_css_thead(css = list('background-color', 'lightblue'))
```
### add_css_column overwrites add_css_row
```{r example11}
tableHTML(mtcars,
border = 5,
rownames = TRUE,
collapse = 'collapse',
widths = c(140, rep(50, 11)),
second_headers = list(c(3, 4, 5), c('col1', 'col2', 'col3'))) %>%
add_css_row(css = list('background-color', 'lightgray'), rows = odd(3:34)) %>%
add_css_row(css = list('background-color', 'lightblue'), rows = even(3:34)) %>%
add_css_column(css = list('background-color', 'lightyellow'), columns = 'mpg') %>%
add_css_thead(css = list('background-color', 'lightblue'))
```
### Table with thead and tbody
```{r example12}
tableHTML(mtcars,
border = 5,
rownames = TRUE,
widths = c(140, rep(50, 11)),
second_headers = list(c(3, 4, 5), c('col1', 'col2', 'col3'))) %>%
add_css_thead(css = list('background-color', 'lightgray')) %>%
add_css_tbody(css = list('background-color', 'lightblue'))
```
### Column Overwrites Row Overwrites tbody / thead Overwrites table
```{r example13}
tableHTML(mtcars,
rownames = TRUE,
widths = c(140, rep(50, 11)),
second_headers = list(c(3, 4, 5), c('col1', 'col2', 'col3'))) %>%
add_css_table(css = list('background-color', 'lightgray')) %>%
add_css_tbody(css = list('background-color', 'lightblue')) %>%
add_css_row(css = list('background-color', 'red'), row = 5) %>%
add_css_column(css = list('background-color', 'lightgreen'), columns = 'mpg')
```
### Table with One Empty Second Header
```{r example14}
tableHTML(mtcars,
border = 5,
rownames = TRUE,
collapse = 'collapse',
widths = c(140, rep(50, 11)),
second_headers = list(c(3, 4, 5), c('col1', '', 'col3'))) %>%
add_css_row(css = list('background-color', 'lightgray'), rows = odd(3:34)) %>%
add_css_row(css = list('background-color', 'lightblue'), rows = even(3:34)) %>%
add_css_thead(css = list('background-color', 'lightblue'))
```
### Table with the Last Second Header Missing
```{r example15}
tableHTML(mtcars,
border = 5,
rownames = TRUE,
collapse = 'collapse',
widths = c(140, rep(50, 11)),
second_headers = list(c(3, 4), c('col1', 'col2'))) %>%
add_css_row(css = list('background-color', 'lightgray'), rows = odd(3:34)) %>%
add_css_row(css = list('background-color', 'lightblue'), rows = even(3:34)) %>%
add_css_thead(css = list('background-color', 'lightblue'))
```
### Only Row Groups no Second Headers
```{r example16}
tableHTML(mtcars,
rownames = TRUE,
widths = c(100, 140, rep(50, 11)),
row_groups = list(c(10, 10, 12), c('Group 1', 'Group 2', 'Group 3'))) %>%
add_css_row(css = list('background-color', 'lightgray'), rows = odd(2:33)) %>%
add_css_row(css = list('background-color', 'lightblue'), rows = even(2:33)) %>%
add_css_row(css = list('background-color', 'lightgreen'), rows = 1) %>%
add_css_column(css = list('background-color', 'lightyellow'), columns = 'row_groups')
```
### Using non-collapsed tables in shiny
```{r example17}
tableHTML(mtcars, collapse = 'separate_shiny', spacing = '5px 2px') %>%
add_css_table(css = list(c('background-color'), c('lightgray'))) %>%
add_css_table(css = list('color', 'blue'))
```
### Using conditional formatting with other tableHTML functions
```{r example18}
tableHTML(mtcars,
widths = c(140, rep(50, 11))) %>%
add_theme('scientific') %>%
add_css_row(css = list('background-color', '#E0E0E0'), rows = odd(3:34)) %>%
add_css_conditional_column(conditional = 'between',
between = c(3.5, 4.22),
css = list(c('background-color'), c('gray')),
columns = c('drat', 'wt')) %>%
add_css_header(css = list(c('transform', 'height'),
c('rotate(-45deg)', '40px')),
headers = 1:12)
```
### Iris dataset with second headers, rowgroups, and conditional css
Note: the `` container is introduced,
because the css property `'transform:rotate(...deg);'` would rotate the whole ` `
element would be rotated and background color would be out of place
```{r example19}
tableHTML(iris[c(1:5, 51:55, 101:105), 1:4],
rownames = FALSE,
headers = rep(c('Length', 'Width'), 2),
second_headers = list(c(1, 2, 2), c('Species', 'Sepal', 'Petal')),
row_groups = list(rep(5, 3), paste0(' ',
c('setosa', 'versicolor', 'virginica'),
' '))) %>%
add_css_column(css = list(c('background-color', 'border'),
c('gray', 'white')),
columns = 'row_groups') %>%
add_css_second_header(css = list(c('color', 'background-color'),
c('white', 'gray')),
second_headers = 1:3) %>%
add_css_header(css = list(c('color', 'background-color'),
c('white', 'gray')),
headers = 1:5) %>%
add_css_conditional_column('color_rank',
color_rank_theme = 'White-Green',
columns = 1:2,
same_scale = FALSE) %>%
add_css_conditional_column('color_rank',
color_rank_theme = 'White-Blue',
columns = 3:4,
same_scale = FALSE)
```
### Table added as an image (not as html)
This works perfectly with rmarkdown when you want to add the table as an image in a pdf, word or html document.
```{r example20, eval=FALSE}
mtcars %>%
tableHTML(widths = c(140, rep(50, 11))) %>%
add_theme('rshiny-blue') %>%
tableHTML_to_image(type = 'png')
```

### Table added as an image (changing size of image)
To increase the size of the image, you can use the rmarkdown chunk options. Here,
I am using `fig.height=7` and `fig.width=7`.
```{r example21, fig.height=7, fig.width=7, eval=FALSE}
mtcars %>%
tableHTML(widths = c(140, rep(50, 11))) %>%
add_theme('rshiny-blue') %>%
tableHTML_to_image(type = 'png')
```

\
| |