* Added kable_paper style for a NYT like table
* Let column_spec take conditional formats
* Added html_font option for kable_styling
diff --git a/NAMESPACE b/NAMESPACE
index 8f34d31..804a243 100644
--- a/NAMESPACE
+++ b/NAMESPACE
@@ -30,6 +30,7 @@
export(kable_material)
export(kable_material_dark)
export(kable_minimal)
+export(kable_paper)
export(kable_styling)
export(landscape)
export(linebreak)
diff --git a/R/cell_spec.R b/R/cell_spec.R
index 8e3facc..8a69c1f 100644
--- a/R/cell_spec.R
+++ b/R/cell_spec.R
@@ -59,13 +59,12 @@
latex_background_in_cell = TRUE) {
if (missing(format) || is.null(format)) {
- format <- getOption('knitr.table.format')
+ if (knitr::is_latex_output()) {
+ format <- "latex"
+ } else {
+ format <- "html"
+ }
}
- if (is.null(format)) {
- message("Setting cell_spec format as html")
- format <- "html"
- }
-
if (tolower(format) == "html") {
return(cell_spec_html(x, bold, italic, monospace, underline, strikeout,
color, background, align, font_size, angle,
@@ -174,11 +173,11 @@
x <- sprintf(ifelse(underline, "\\underline{%s}", "%s"), x)
x <- sprintf(ifelse(strikeout, "\\sout{%s}", "%s"), x)
if (!is.null(color)) {
- color <- latex_color(color)
+ color <- latex_color(color, escape = FALSE)
x <- paste0("\\textcolor", color, "{", x, "}")
}
if (!is.null(background)) {
- background <- latex_color(background)
+ background <- latex_color(background, escape = FALSE)
background_env <- ifelse(latex_background_in_cell, "cellcolor", "colorbox")
x <- paste0("\\", background_env, background, "{", x, "}")
}
diff --git a/R/collapse_rows.R b/R/collapse_rows.R
index 927502e..66349c8 100644
--- a/R/collapse_rows.R
+++ b/R/collapse_rows.R
@@ -57,7 +57,7 @@
"for details.")
return(kable_input)
}
- valign <- match.arg(valign, c("middle", "top", "bottom"))
+ valign <- match.arg(valign)
if (!is.null(target)) {
if (length(target) > 1 && is.integer(target)) {
stop("target can only be a length 1 integer")
@@ -67,8 +67,7 @@
return(collapse_rows_html(kable_input, columns, valign, target))
}
if (kable_format == "latex") {
- latex_hline <- match.arg(latex_hline, c(
- "major", "full", "none", "custom", "linespace"))
+ latex_hline <- match.arg(latex_hline)
row_group_label_position <- match.arg(row_group_label_position,
c('identity', 'stack'))
return(collapse_rows_latex(kable_input, columns, latex_hline, valign,
diff --git a/R/column_spec.R b/R/column_spec.R
index 2a97fee..0f36f65 100644
--- a/R/column_spec.R
+++ b/R/column_spec.R
@@ -7,19 +7,19 @@
#' @param column A numeric value or vector indicating which column(s) to be selected.
#' @param width A character string telling HTML & LaTeX how wide the column
#' needs to be, e.g. "10cm", "3in" or "30em".
-#' @param bold A T/F value to control whether the text of the selected column
-#' need to be bolded.
-#' @param italic A T/F value to control whether the text of the selected column
-#' need to be emphasized.
-#' @param monospace A T/F value to control whether the text of the selected column
-#' need to be monospaced (verbatim)
-#' @param underline A T/F value to control whether the text of the selected row
-#' need to be underlined
-#' @param strikeout A T/F value to control whether the text of the selected row
-#' need to be stricked out.
-#' @param color A character string for column text color. Here please pay
-#' attention to the differences in color codes between HTML and LaTeX.
-#' @param background A character string for column background color. Here please
+#' @param bold T/F value or vector to control whether the text of the selected
+#' column need to be bolded.
+#' @param italic T/F value or vector to control whether the text of the
+#' selected column need to be emphasized.
+#' @param monospace T/F value or vector to control whether the text of the
+#' selected column need to be monospaced (verbatim)
+#' @param underline T/F value or vector to control whether the text of the
+#' selected row need to be underlined
+#' @param strikeout T/F value or vector to control whether the text of the
+#' selected row need to be striked out.
+#' @param color A character string or vector for column text color. Here please
+#' pay attention to the differences in color codes between HTML and LaTeX.
+#' @param background A character string or vector for column background color. Here please
#' pay attention to the differences in color codes between HTML and LaTeX.
#' @param border_left A logical variable indicating whether there should be a
#' border line on the left of the selected column. In HTML, you can also pass
@@ -33,14 +33,24 @@
#' window is not wide enough.
#' @param width_max Only for HTML table. `width_max` defines the maximum width
#' of table columns.
-#' @param extra_css Extra css text to be passed into the cells of the row. Note
-#' that it's not for the whole column but to each individual cells
+#' @param extra_css A vector of extra css text to be passed into the cells of
+#' the column.
#' @param include_thead T/F. A HTML only feature to contoll whether the
#' header row will be manipulated. Default is `FALSE`.
#' @param latex_column_spec Only for LaTeX tables. Code to replace the column
#' specification. If not `NULL`, will override all other arguments.
#' @param latex_valign vertical alignment. Only works when you specified column
#' width. Choose among `p`, `m`, `b`.
+#' @param link A vector of strings for url links.
+#' @param new_tab T/F for whether to open up the new link in new tab
+#' @param tooltip A vector of strings to be displayed as tooltip.
+#' Obviously, this feature is only available in HTML. Read the package
+#' vignette to see how to use bootstrap tooltip css to improve the loading
+#' speed and look.
+#' @param popover Similar with tooltip but can hold more contents. The best way
+#' to build a popover is through `spec_popover()`. If you only provide a text
+#' string, it will be used as content. Note that You have to enable this
+#' bootstrap module manually. Read the package vignette to see how.
#'
#' @details Use `latex_column_spec` in a LaTeX table to change or
#' customize the column specification. Because of the way it is handled
@@ -58,7 +68,9 @@
border_left = FALSE, border_right = FALSE,
width_min = NULL, width_max = NULL,
extra_css = NULL, include_thead = FALSE,
- latex_column_spec = NULL, latex_valign = 'p') {
+ latex_column_spec = NULL, latex_valign = 'p',
+ link = NULL, new_tab = TRUE,
+ tooltip = NULL, popover = NULL) {
if (!is.numeric(column)) {
stop("column must be numeric. ")
}
@@ -76,7 +88,8 @@
color, background,
border_left, border_right,
width_min, width_max,
- extra_css, include_thead))
+ extra_css, include_thead,
+ link, new_tab, tooltip, popover))
}
if (kable_format == "latex") {
return(column_spec_latex(kable_input, column, width,
@@ -84,8 +97,8 @@
underline, strikeout,
color, background,
border_left, border_right,
- latex_column_spec = latex_column_spec,
- latex_valign = latex_valign))
+ latex_column_spec, latex_valign, include_thead,
+ link))
}
}
@@ -95,7 +108,8 @@
color, background,
border_left, border_right,
width_min, width_max,
- extra_css, include_thead) {
+ extra_css, include_thead,
+ link, new_tab, tooltip, popover) {
kable_attrs <- attributes(kable_input)
kable_xml <- read_kable_as_xml(kable_input)
kable_tbody <- xml_tpart(kable_xml, "tbody")
@@ -120,19 +134,6 @@
border_right <- T
}
- for (i in all_contents_rows) {
- for (j in column) {
- target_cell <- xml_child(xml_child(kable_tbody, i), j)
- column_spec_html_cell(
- target_cell, width, width_min, width_max,
- bold, italic, monospace, underline, strikeout,
- color, background, border_left, border_right,
- border_l_css, border_r_css,
- extra_css
- )
- }
- }
-
if (include_thead) {
kable_thead <- xml_tpart(kable_xml, "thead")
nrow_thead <- length(xml_children(kable_thead))
@@ -140,10 +141,39 @@
target_cell <- xml_child(xml_child(kable_thead, nrow_thead), j)
column_spec_html_cell(
target_cell, width, width_min, width_max,
- bold, italic, monospace, underline, strikeout,
- color, background, border_left, border_right,
+ bold[1], italic[1], monospace[1], underline[1], strikeout[1],
+ color[1], background[1], border_left, border_right,
border_l_css, border_r_css,
- extra_css
+ extra_css[1], link[1], new_tab[1], tooltip[1], popover[1]
+ )
+ }
+ }
+
+ nrows <- length(all_contents_rows)
+ off <- 0
+
+ bold <- ensure_len_html(bold, nrows, "bold")
+ italic <- ensure_len_html(italic, nrows, "italic")
+ monospace <- ensure_len_html(monospace, nrows, "monospace")
+ underline <- ensure_len_html(underline, nrows, "underline")
+ strikeout <- ensure_len_html(strikeout, nrows, "strikeout")
+ color <- ensure_len_html(color, nrows, "color")
+ background <- ensure_len_html(background, nrows,"background")
+ link <- ensure_len_html(link, nrows, "link")
+ new_tab <- ensure_len_html(new_tab, nrows, "new_tab")
+ tooltip <- ensure_len_html(tooltip, nrows, "tooltip")
+ popover <- ensure_len_html(popover, nrows, "popover")
+
+ for (i in all_contents_rows) {
+ for (j in column) {
+ target_cell <- xml_child(xml_child(kable_tbody, i), j)
+ column_spec_html_cell(
+ target_cell, width, width_min, width_max,
+ bold[i], italic[i], monospace[i], underline[i], strikeout[i],
+ color[i], background[i], border_left, border_right,
+ border_l_css, border_r_css,
+ extra_css,
+ link[i], new_tab[i], tooltip[i], popover[i]
)
}
}
@@ -154,12 +184,22 @@
return(out)
}
+ensure_len_html <- function(x, l, name) {
+ if (is.null(x)) return(NULL)
+ if (length(x) == 1) return(rep(x, l))
+ if (length(x) == l) return(x)
+ warning("The number of provided values in ", name, " does not equal to the ",
+ "number of rows. ")
+ return(rep(x, ceiling(l / length(x)))[seq(1, l)])
+}
+
column_spec_html_cell <- function(target_cell, width, width_min, width_max,
bold, italic, monospace, underline, strikeout,
color, background,
border_left, border_right,
border_l_css, border_r_css,
- extra_css) {
+ extra_css,
+ link, new_tab, tooltip, popover) {
if (is.na(xml_attr(target_cell, "style"))) {
xml_attr(target_cell, "style") <- ""
}
@@ -218,6 +258,56 @@
xml_attr(target_cell, "style") <- paste0(xml_attr(target_cell, "style"),
extra_css)
}
+
+ # favor popover over tooltip
+ if (!is.null(popover)) {
+ if (class(popover) != "ke_popover") popover <- spec_popover(popover)
+ popover_list <- attr(popover, 'list')
+ for (p in names(popover_list)) {
+ xml_attr(target_cell, p) <- popover_list[p]
+ }
+ } else if (!is.null(tooltip)) {
+ if (class(tooltip) != "ke_tooltip") tooltip <- spec_tooltip(tooltip)
+ tooltip_list <- attr(tooltip, 'list')
+ for (t in names(tooltip_list)) {
+ xml_attr(target_cell, t) <- tooltip_list[t]
+ }
+ }
+ # if (!is.null(popover)) {
+ # if (class(popover) != "ke_popover") popover <- spec_popover(popover)
+ # popover_list <- attr(popover, 'list')
+ # span_node <- xml2::read_xml(paste0(
+ # '<span>', xml_text(target_cell), '</span>'
+ # ))
+ # for (p in names(popover_list)) {
+ # xml_attr(span_node, p) <- popover_list[p]
+ # }
+ # xml_add_child(target_cell, span_node)
+ # xml_text(target_cell) <- ""
+ # } else if (!is.null(tooltip)) {
+ # if (class(tooltip) != "ke_tooltip") tooltip <- spec_tooltip(tooltip)
+ # tooltip_list <- attr(tooltip, 'list')
+ # span_node <- xml2::read_xml(paste0(
+ # '<span>', xml_text(target_cell), '</span>'
+ # ))
+ # for (t in names(tooltip_list)) {
+ # xml_attr(span_node, t) <- tooltip_list[t]
+ # }
+ # xml_add_child(target_cell, span_node)
+ # xml_text(target_cell) <- ""
+ # }
+
+ if (!is.null(link)) {
+ href_node <- xml2::read_xml(paste0(
+ '<a href="', link, '">', xml_text(target_cell), '</a>'
+ ))
+ if (!is.null(color)) {
+ xml_attr(href_node, "style") <- paste0("color: ", html_color(color),
+ " !important;")
+ }
+ xml_add_child(target_cell, href_node)
+ xml_text(target_cell) <- ""
+ }
}
column_spec_latex <- function(kable_input, column, width,
@@ -225,7 +315,8 @@
underline, strikeout,
color, background,
border_left, border_right,
- latex_column_spec, latex_valign) {
+ latex_column_spec, latex_valign, include_thead,
+ link) {
table_info <- magic_mirror(kable_input)
if (!is.null(table_info$collapse_rows)) {
message("Usually it is recommended to use column_spec before collapse_rows,",
@@ -239,9 +330,7 @@
table_info$align_vector_origin[column],
function(x) {
latex_column_align_builder(
- x, width, bold, italic, monospace, underline, strikeout,
- color, background, border_left, border_right, latex_column_spec,
- latex_valign)
+ x, width, border_left, border_right, latex_column_spec, latex_valign)
}
))
@@ -258,6 +347,49 @@
table_info <- fix_newline[[2]]
}
+ if (table_info$duplicated_rows) {
+ dup_fx_out <- fix_duplicated_rows_latex(out, table_info)
+ out <- dup_fx_out[[1]]
+ table_info <- dup_fx_out[[2]]
+ }
+
+ nrows <- length(table_info$contents)
+ off <- table_info$position_offset
+
+ bold <- ensure_len_latex(bold, nrows, off, include_thead, FALSE, "bold")
+ italic <- ensure_len_latex(italic, nrows, off, include_thead, FALSE, "italic")
+ monospace <- ensure_len_latex(monospace, nrows, off, include_thead, FALSE,
+ "monospace")
+ underline <- ensure_len_latex(underline, nrows, off, include_thead, FALSE,
+ "underline")
+ strikeout <- ensure_len_latex(strikeout, nrows, off, include_thead, FALSE,
+ "strikeout")
+ color <- ensure_len_latex(color, nrows, off, include_thead, "black", "color")
+ background <- ensure_len_latex(background, nrows, off, include_thead, "white",
+ "background")
+ link <- ensure_len_latex(link, nrows, off, include_thead, "#", "link")
+
+ if (include_thead) {
+ rows <- seq(1, nrows)
+ } else {
+ rows <- seq(1 + off, nrows)
+ }
+
+ for (i in rows) {
+ target_row <- table_info$contents[i]
+ new_row <- latex_cell_builder(
+ target_row, column, table_info,
+ bold[i], italic[i], monospace[i], underline[i],
+ strikeout[i], color[i], background[i], link[i]
+ # font_size, angle
+ )
+ temp_sub <- ifelse(i == 1 & (table_info$tabular == "longtable" |
+ !is.null(table_info$repeat_header_latex)),
+ gsub, sub)
+ out <- temp_sub(target_row, new_row, out, perl = T)
+ table_info$contents[i] <- new_row
+ }
+
out <- structure(out, format = "latex", class = "knitr_kable")
if (!is.null(width)) {
if (is.null(table_info$column_width)) {
@@ -271,9 +403,24 @@
return(out)
}
-latex_column_align_builder <- function(x, width, bold, italic, monospace,
- underline, strikeout,
- color, background,
+ensure_len_latex <- function(x, l, off, include_thead, def, name) {
+ if (is.null(x)) return(NULL)
+ if (length(x) == 1) return(rep(x, l))
+ if (include_thead) {
+ if (length(x) == l) return(x)
+ warning("The number of provided values in ", name, " does not equal to the ",
+ "number of rows. ")
+ return(rep(x, ceiling(l / length(x)))[seq(1, l)])
+ } else {
+ l_ = l - off
+ if (length(x) == l_) return(c(def, x))
+ warning("The number of provided values in ", name, " does not equal to the ",
+ "number of rows. ")
+ return(c(def, rep(x, ceiling(l_ / length(x)))[seq(1, l_)]))
+ }
+}
+
+latex_column_align_builder <- function(x, width,
border_left, border_right,
latex_column_spec, latex_valign) {
extra_align <- ""
@@ -284,24 +431,23 @@
"r" = "\\\\raggedleft\\\\arraybackslash")
x <- paste0(latex_valign, "\\{", width, "\\}")
}
-
- if (!is.null(color)) {
- color <- paste0("\\\\leavevmode\\\\color", latex_color(color))
- }
-
- if (!is.null(background)) {
- background <- paste0("\\\\columncolor", latex_color(background))
- }
-
- latex_array_options <- c("\\\\bfseries", "\\\\em", "\\\\ttfamily",
- "\\\\underline", "\\\\sout")[
- c(bold, italic, monospace, underline, strikeout)]
- latex_array_options <- c(latex_array_options, extra_align,
- color, background)
- latex_array_options <- paste0(
- "\\>\\{", paste(latex_array_options, collapse = ""), "\\}"
- )
- x <- paste0(latex_array_options, x)
+ # if (!is.null(color)) {
+ # color <- paste0("\\\\leavevmode\\\\color", latex_color(color))
+ # }
+ #
+ # if (!is.null(background)) {
+ # background <- paste0("\\\\columncolor", latex_color(background))
+ # }
+ #
+ # latex_array_options <- c("\\\\bfseries", "\\\\em", "\\\\ttfamily",
+ # "\\\\underline", "\\\\sout")[
+ # c(bold, italic, monospace, underline, strikeout)]
+ # latex_array_options <- c(latex_array_options, extra_align,
+ # color, background)
+ # latex_array_options <- paste0(
+ # "\\>\\{", paste(latex_array_options, collapse = ""), "\\}"
+ # )
+ # x <- paste0(latex_array_options, x)
if (border_left) {
x <- paste0("\\|", x)
}
@@ -309,7 +455,7 @@
x <- paste0(x, "\\|")
}
if (!is.null(latex_column_spec))
- x <- latex_column_spec
+ x <- latex_column_spec
return(x)
}
@@ -317,8 +463,8 @@
replace_makecell_with_newline <- function(kable_input, table_info, column) {
if (!str_detect(kable_input, "makecell")) return(list(kable_input, table_info))
contents_table <- data.frame(sapply(table_info$contents,
- function(x) {str_split(x, " \\& ")[[1]]}),
- stringsAsFactors = F)
+ function(x) {str_split(x, " \\& ")[[1]]}),
+ stringsAsFactors = F)
names(contents_table) <- paste0("x", 1:table_info$nrow)
rows_check_makecell <- str_detect(contents_table[column, ], "makecell")
if (sum(rows_check_makecell) == 0) return(list(kable_input, table_info))
@@ -346,3 +492,53 @@
return(list(kable_input, table_info))
}
+
+latex_cell_builder <- function(target_row, column, table_info,
+ bold, italic, monospace,
+ underline, strikeout,
+ color, background, link
+ # font_size, angle
+ ) {
+ new_row <- latex_row_cells(target_row)[[1]]
+ if (bold) {
+ new_row[column] <- paste0("\\\\textbf\\{", new_row[column], "\\}")
+ }
+ if (italic) {
+ new_row[column] <- paste0("\\\\em\\{", new_row[column], "\\}")
+ }
+ if (monospace) {
+ new_row[column] <- paste0("\\\\ttfamily\\{", new_row[column], "\\}")
+ }
+ if (underline) {
+ new_row[column] <- paste0("\\\\underline\\{", new_row[column], "\\}")
+ }
+ if (strikeout) {
+ new_row[column] <- paste0("\\\\sout\\{", new_row[column], "\\}")
+ }
+ if (!is.null(color)) {
+ new_row[column] <- paste0("\\\\textcolor", latex_color(color), "\\{",
+ new_row[column], "\\}")
+ }
+ # if (!is.null(font_size)) {
+ # new_row[column] <- paste0("\\\\begingroup\\\\fontsize\\{", font_size, "\\}\\{",
+ # as.numeric(font_size) + 2,
+ # "\\}\\\\selectfont ", new_row[column], "\\\\endgroup")
+ # }
+ # if (!is.null(angle)) {
+ # new_row[column] <- paste0("\\\\rotatebox\\{", angle, "\\}\\{",
+ # new_row[column], "\\}")
+ # }
+ if (!is.null(background)) {
+ new_row[column] <- paste0("\\\\cellcolor", latex_color(background), "\\{",
+ new_row[column], "\\}")
+ }
+
+ if (!is.null(link)) {
+ new_row[column] <- paste0("\\\\href\\{", escape_latex(link), "\\}\\{",
+ new_row[column], "\\}")
+ }
+
+ new_row <- paste(new_row, collapse = " & ")
+
+ return(new_row)
+}
diff --git a/R/kable.R b/R/kable.R
index f1709d5..108e928 100644
--- a/R/kable.R
+++ b/R/kable.R
@@ -63,10 +63,10 @@
if (!missing(align) && length(align) == 1L && !grepl('[^lcr]', align)) {
align <- strsplit(align, '')[[1]]
}
- if (missing(format) | is.null(format)) {
+ if (missing(format) || is.null(format)) {
if (knitr::is_latex_output()) {
format <- "latex"
- return(knitr::kable(
+ out <- knitr::kable(
x = x, format = format, digits = digits,
row.names = row.names, col.names = col.names, align = align,
caption = caption, label = label, format.args = format.args,
@@ -76,28 +76,59 @@
vline = vline, toprule = toprule, bottomrule = bottomrule,
midrule = midrule, linesep = linesep, caption.short = caption.short,
table.envir = table.envir, ...
- ))
+ )
+ table_info <- magic_mirror(out)
+ if (is.null(col.names)) {
+ table_info$position_offset <- 0
+ }
+ return(out)
} else {
format <- "html"
- return(knitr::kable(
+ out <- knitr::kable(
x = x, format = format, digits = digits,
row.names = row.names, col.names = col.names, align = align,
caption = caption, label = label, format.args = format.args,
escape = escape,
table.attr = table.attr, ...
- ))
+ )
+ if (!"kableExtra" %in% class(out)) class(out) <- c("kableExtra", class(out))
+ return(out)
}
} else {
+ if (format == "latex") {
+ out <- knitr::kable(
+ x = x, format = format, digits = digits,
+ row.names = row.names, col.names = col.names, align = align,
+ caption = caption, label = label, format.args = format.args,
+ escape = escape,
+ booktabs = booktabs, longtable = longtable,
+ valign = valign, position = position, centering = centering,
+ vline = vline, toprule = toprule, bottomrule = bottomrule,
+ midrule = midrule, linesep = linesep, caption.short = caption.short,
+ table.envir = table.envir, ...
+ )
+ table_info <- magic_mirror(out)
+ if (is.null(col.names)) {
+ table_info$position_offset <- 0
+ }
+ return(out)
+ }
+ if (format == "html") {
+ out <- knitr::kable(
+ x = x, format = format, digits = digits,
+ row.names = row.names, col.names = col.names, align = align,
+ caption = caption, label = label, format.args = format.args,
+ escape = escape,
+ table.attr = table.attr, ...
+ )
+ if (!"kableExtra" %in% class(out)) class(out) <- c("kableExtra", class(out))
+ return(out)
+ }
return(knitr::kable(
x = x, format = format, digits = digits,
row.names = row.names, col.names = col.names, align = align,
caption = caption, label = label, format.args = format.args,
- escape = escape, table.attr = table.attr,
- booktabs = booktabs, longtable = longtable,
- valign = valign, position = position, centering = centering,
- vline = vline, toprule = toprule, bottomrule = bottomrule,
- midrule = midrule, linesep = linesep, caption.short = caption.short,
- table.envir = table.envir, ...
+ escape = escape, ...
))
}
diff --git a/R/kable_styling.R b/R/kable_styling.R
index a777faf..778335d 100644
--- a/R/kable_styling.R
+++ b/R/kable_styling.R
@@ -65,6 +65,8 @@
#' `lightable-classic-2`, `lightable-material`, `lightable-striped` and
#' `lightable-hover`. If you have your customized style sheet loaded which
#' defines your own table class, you can also load it here.
+#' @param html_font A string for HTML css font. For example,
+#' `html_font = '"Arial Narrow", arial, helvetica, sans-serif'`.
#'
#' @details For LaTeX, if you use other than English environment
#' - all tables are converted to 'UTF-8'. If you use, for example, Hungarian
@@ -100,7 +102,8 @@
protect_latex = TRUE,
table.envir = "table",
fixed_thead = FALSE,
- htmltable_class = NULL) {
+ htmltable_class = NULL,
+ html_font = NULL) {
if (length(bootstrap_options) == 1 && bootstrap_options == "basic") {
bootstrap_options <- getOption("kable_styling_bootstrap_options", "basic")
@@ -136,7 +139,8 @@
font_size = font_size,
protect_latex = protect_latex,
fixed_thead = fixed_thead,
- htmltable_class = htmltable_class))
+ htmltable_class = htmltable_class,
+ html_font = html_font))
}
if (kable_format == "latex") {
if (is.null(full_width)) {
@@ -195,7 +199,8 @@
font_size = NULL,
protect_latex = TRUE,
fixed_thead = FALSE,
- htmltable_class = NULL) {
+ htmltable_class = NULL,
+ html_font = NULL) {
if (protect_latex) {
kable_input <- extract_latex_from_kable(kable_input)
}
@@ -246,6 +251,11 @@
xml_attr(kable_caption_node, "style") <- "font-size: initial !important;"
}
}
+ if (!is.null(html_font)) {
+ kable_xml_style <- c(kable_xml_style, paste0(
+ 'font-family: ', html_font, ';'
+ ))
+ }
if (!full_width) {
kable_xml_style <- c(kable_xml_style, "width: auto !important;")
}
diff --git a/R/light_themes.R b/R/light_themes.R
index 94aa826..4200dac 100644
--- a/R/light_themes.R
+++ b/R/light_themes.R
@@ -13,35 +13,60 @@
#' @param ... Everything else you need to specify in `kable_styling`.
#'
#' @export
-kable_classic <- function(kable_input, lightable_options = "basic", ...) {
- kable_light(kable_input, "lightable-classic", lightable_options, ...)
+kable_classic <- function(
+ kable_input, lightable_options = "basic",
+ html_font = '"Arial Narrow", "Source Sans Pro", sans-serif', ...) {
+ kable_light(kable_input, "lightable-classic",
+ lightable_options, html_font, ...)
}
#' @rdname kable_classic
#' @export
-kable_classic_2 <- function(kable_input, lightable_options = "basic", ...) {
- kable_light(kable_input, "lightable-classic-2", lightable_options, ...)
+kable_classic_2 <- function(
+ kable_input, lightable_options = "basic",
+ html_font = '"Arial Narrow", "Source Sans Pro", sans-serif', ...) {
+ kable_light(kable_input, "lightable-classic-2",
+ lightable_options, html_font, ...)
}
#' @rdname kable_classic
#' @export
-kable_minimal <- function(kable_input, lightable_options = "basic", ...) {
- kable_light(kable_input, "lightable-minimal", lightable_options, ...)
+kable_minimal <- function(
+ kable_input, lightable_options = "basic",
+ html_font = 'calibri, cambria, "Source Sans Pro", sans-serif', ...) {
+ kable_light(kable_input, "lightable-minimal",
+ lightable_options, html_font, ...)
}
#' @rdname kable_classic
#' @export
-kable_material <- function(kable_input, lightable_options = "basic", ...) {
- kable_light(kable_input, "lightable-material", lightable_options, ...)
+kable_material <- function(
+ kable_input, lightable_options = "basic",
+ html_font = '"Source Sans Pro", helvetica, sans-serif', ...) {
+ kable_light(kable_input, "lightable-material",
+ lightable_options, html_font, ...)
}
#' @rdname kable_classic
#' @export
-kable_material_dark <- function(kable_input, lightable_options = "basic", ...) {
- kable_light(kable_input, "lightable-material-dark", lightable_options, ...)
+kable_material_dark <- function(
+ kable_input, lightable_options = "basic",
+ html_font = '"Source Sans Pro", helvetica, sans-serif', ...) {
+ kable_light(kable_input, "lightable-material-dark",
+ lightable_options, html_font, ...)
}
-kable_light <- function(kable_input, light_class, lightable_options, ...) {
+#' @rdname kable_classic
+#' @export
+kable_paper <- function(
+ kable_input, lightable_options = "basic",
+ html_font = '"Arial Narrow", arial, helvetica, sans-serif', ...) {
+ kable_light(kable_input, "lightable-paper", lightable_options,
+ html_font, ...)
+}
+
+kable_light <- function(kable_input, light_class, lightable_options,
+ html_font = NULL, ...) {
lightable_options <- match.arg(lightable_options,
choices = c("basic", "striped", "hover"),
several.ok = TRUE)
@@ -51,7 +76,8 @@
if ("hover" %in% lightable_options) {
light_class <- paste(light_class, "lightable-hover")
}
- out <- kable_styling(kable_input, "none", htmltable_class = light_class, ...)
+ out <- kable_styling(kable_input, "none", htmltable_class = light_class,
+ html_font = html_font, ...)
attr(out, "lightable") <- TRUE
attr(out, "lightable_class") <- light_class
return(out)
diff --git a/R/spec_tools.R b/R/spec_tools.R
index 0ae4032..350925b 100644
--- a/R/spec_tools.R
+++ b/R/spec_tools.R
@@ -35,6 +35,16 @@
latex_color_ <- function(color) {
if (substr(color, 1, 1) != "#") {
+ return(paste0("\\{", color, "\\}"))
+ } else {
+ color <- sub("#", "", color)
+ if (nchar(color) == 8) color <- substr(color, 1, 6)
+ return(paste0("\\[HTML\\]\\{", color, "\\}"))
+ }
+}
+
+latex_color__ <- function(color) {
+ if (substr(color, 1, 1) != "#") {
return(paste0("{", color, "}"))
} else {
color <- sub("#", "", color)
@@ -42,9 +52,14 @@
return(paste0("[HTML]{", color, "}"))
}
}
-latex_color <- function(colors) {
+latex_color <- function(colors, escape = TRUE) {
colors <- as.character(colors)
- sapply(colors, latex_color_)
+ if (escape) {
+ return(sapply(colors, latex_color_))
+ } else {
+ return(sapply(colors, latex_color__))
+ }
+
}
#' Generate common font size for continuous values
@@ -98,11 +113,18 @@
position <- match.arg(position, c("right", "bottom", "top", "left", "auto"),
several.ok = TRUE)
tooltip_options <- paste(
- 'data-toggle="tooltip"',
+ 'data-toggle="tooltip" data-container="body"',
paste0('data-placement="', position, '"'),
# ifelse(as_html, 'data-html="true"', NULL),
paste0('title="', title, '"'))
+ tooltip_options_list <- list(
+ 'data-toggle' = 'tooltip',
+ 'data-container' = 'body',
+ 'data-placement' = position,
+ 'title' = if(is.null(title)) '' else title
+ )
class(tooltip_options) <- "ke_tooltip"
+ attr(tooltip_options, 'list') <- tooltip_options_list
return(tooltip_options)
}
@@ -123,11 +145,22 @@
position <- match.arg(position, c("bottom", "top", "left", "right", "auto"),
several.ok = TRUE)
popover_options <- paste(
- 'data-toggle="popover"',
+ 'data-toggle="popover" data-container="body"',
paste0('data-trigger="', trigger, '"'),
paste0('data-placement="', position, '"'),
ifelse(!is.null(title), paste0('title="', title, '"'), ""),
paste0('data-content="', content, '"'))
+ popover_options_list <- list(
+ 'data-toggle' = 'popover',
+ 'data-container' = 'body',
+ 'data-trigger' = trigger,
+ 'data-placement' = position,
+ 'data-content' = content
+ )
+ if (!is.null(title)) {
+ popover_options_list['title'] <- title
+ }
class(popover_options) <- "ke_popover"
+ attr(popover_options, 'list') <- popover_options_list
return(popover_options)
}
diff --git a/R/zzz.R b/R/zzz.R
index 36133e7..3fd88fb 100644
--- a/R/zzz.R
+++ b/R/zzz.R
@@ -18,8 +18,8 @@
# usepackage_latex("xcolor")
}
}
- auto_format <- getOption("kableExtra.auto_format", default = TRUE)
- if (auto_format) auto_set_format()
+ # auto_format <- getOption("kableExtra.auto_format", default = TRUE)
+ # if (auto_format) auto_set_format()
if (!is.null(rmarkdown::metadata$output) &&
rmarkdown::metadata$output %in% c(
"ioslides_presentation", "slidy_presentation",
diff --git a/docs/awesome_table_in_html.Rmd b/docs/awesome_table_in_html.Rmd
index 4658a3c..f8a7c67 100644
--- a/docs/awesome_table_in_html.Rmd
+++ b/docs/awesome_table_in_html.Rmd
@@ -14,6 +14,12 @@
%\VignetteEncoding{UTF-8}
---
+<script>
+$(document).ready(function(){
+ $('[data-toggle="popover"]').popover();
+});
+</script>
+
<img src="kableExtra_sm.png" align="right" alt="logo" width="80" height = "93" style = "border: none; float: right;">
> Please see the package [documentation site](http://haozhu233.github.io/kableExtra/) for how to use this package in LaTeX.
@@ -68,7 +74,13 @@
```
## Alternative themes
-`kableExtra` also offers a few in-house alternative HTML table themes other than the default bootstrap theme. Right now there are 5 of them: `kable_classic`, `kable_classic_2`, `kable_minimal`, `kable_material` and `kable_material_dark`. These functions are alternatives to `kable_styling`, which means that you can specify any additional formatting options in `kable_styling` in these functions too. The only difference is that `bootstrap_options` (as discussed in the next section) is replaced with `lightable_options` at the same location with only two choices `striped` and `hover` available.
+`kableExtra` also offers a few in-house alternative HTML table themes other than the default bootstrap theme. Right now there are 6 of them: `kable_paper`, `kable_classic`, `kable_classic_2`, `kable_minimal`, `kable_material` and `kable_material_dark`. These functions are alternatives to `kable_styling`, which means that you can specify any additional formatting options in `kable_styling` in these functions too. The only difference is that `bootstrap_options` (as discussed in the next section) is replaced with `lightable_options` at the same location with only two choices `striped` and `hover` available.
+
+```{r}
+dt %>%
+ kable() %>%
+ kable_paper("hover")
+```
```{r}
dt %>%
@@ -130,7 +142,7 @@
By default, a bootstrap table takes 100% of the width. It is supposed to use together with its grid system to scale the table properly. However, when you are writing a rmarkdown document, you probably don't want to write your own css/or grid. For some small tables with only few columns, a page wide table looks awful. To make it easier, you can specify whether you want the table to have `full_width` or not in `kable_styling`. By default, `full_width` is set to be `TRUE` for HTML tables (note that for LaTeX, the default is `FALSE` since I don't want to change the "common" looks unless you specified it.)
```{r}
kable(dt) %>%
- kable_styling(bootstrap_options = "striped", full_width = F)
+ kable_paper(bootstrap_options = "striped", full_width = F)
```
## Position
@@ -184,9 +196,23 @@
column_spec(2, width = "30em", background = "yellow")
```
+> **Key Update**: I understand the need of doing conditional formatting and the previous solution `cell_spec` is relatively hard to use. Therefore in kableExtra 1.2, I improved the functionality of `column_spec` so it can take vectorized input for most of its arguments (except `width`, `border_left` and `border_right`). It is really easy right now to format a column based on other values.
+
+```{r}
+mtcars[1:8, 1:8] %>%
+ kable() %>%
+ kable_paper(full_width = F) %>%
+ column_spec(2, color = spec_color(mtcars$mpg[1:8]),
+ link = "https://haozhu233.github.io/kableExtra") %>%
+ column_spec(6, color = "white",
+ background = spec_color(mtcars$drat[1:8], end = 0.7),
+ popover = paste("am:", mtcars$am[1:8]))
+```
+
+You can still use the `spec_***` helper functions to help you define color. See the documentation [below](#visualize-data-with-viridis-color).
## Row spec
-Similar with `column_spec`, you can define specifications for rows. Currently, you can either bold or italiciz an entire row. Note that, similar with other row-related functions in `kableExtra`, for the position of the target row, you don't need to count in header rows or the group labelling rows.
+Similar with `column_spec`, you can define specifications for rows. Currently, you can either bold or italicize an entire row. Note that, similar with other row-related functions in `kableExtra`, for the position of the target row, you don't need to count in header rows or the group labeling rows.
```{r}
kable(dt) %>%
@@ -206,6 +232,9 @@
```
# Cell/Text Specification
+
+>**Key Update: As said before, if you are using kableExtra 1.2+, you are now recommended to used `column_spec` to do conditional formatting**.
+
Function `cell_spec` is introduced in version 0.6.0 of `kableExtra`. Unlike `column_spec` and `row_spec`, **this function is designed to be used before the data.frame gets into the `kable` function**. Comparing with figuring out a list of 2 dimentional index for targeted cells, this design is way easier to learn and use and it fits perfectly well with `dplyr`'s `mutate` and `summarize` functions. With this design, there are two things to be noted:
* Since `cell_spec` generates raw `HTML` or `LaTeX` code, make sure you remember to put `escape = FALSE` in `kable`. At the same time, you have to escape special symbols including `%` manually by yourself
* `cell_spec` needs a way to know whether you want `html` or `latex`. You can specify it locally in function or globally via the `options(knitr.table.format = "latex")` method as suggested at the beginning. If you don't provide anything, this function will output as HTML by default.
@@ -230,7 +259,7 @@
```
## Visualize data with Viridis Color
-This package also comes with a few helper functions, including `spec_color`, `spec_font_size` & `spec_angle`. These functions can rescale continuous variables to certain scales. For example, function `spec_color` would map a continuous variable to any [viridis color palettes](https://CRAN.R-project.org/package=viridisLite). It offers a very visually impactful representation in a tabular format.
+This package also comes with a few helper functions, including `spec_color`, `spec_font_size` & `spec_angle`. These functions can rescale continuous variables to certain scales. For example, function `spec_color` would map a continuous variable to any [viridis color palettes](https://CRAN.R-project.org/package=viridisLite). It offers a very visually impressive representation in a tabular format.
```{r}
iris[1:10, ] %>%
@@ -296,12 +325,6 @@
</script>
```
-<script>
-$(document).ready(function(){
- $('[data-toggle="popover"]').popover();
-});
-</script>
-
```{r}
popover_dt <- data.frame(
position = c("top", "bottom", "right", "left"),
diff --git a/docs/awesome_table_in_html.html b/docs/awesome_table_in_html.html
index 9c39a08..28f5862 100644
--- a/docs/awesome_table_in_html.html
+++ b/docs/awesome_table_in_html.html
@@ -11,7 +11,7 @@
<meta name="author" content="Hao Zhu" />
-<meta name="date" content="2020-08-11" />
+<meta name="date" content="2020-08-18" />
<title>Create Awesome HTML Table with knitr::kable and kableExtra</title>
@@ -1324,6 +1324,14 @@
width: 100%;
margin-bottom: 10px;
}
+.lightable-minimal td {
+margin-left: 5px;
+margin-right: 5px;
+}
+.lightable-minimal th {
+margin-left: 5px;
+margin-right: 5px;
+}
.lightable-minimal thead tr th {
border-bottom: 2px solid black;
empty-cells: hide;
@@ -1343,11 +1351,19 @@
width: 100%;
margin-bottom: 10px;
}
+.lightable-classic td {
+padding-left: 5px;
+padding-right: 5px;
+}
+.lightable-classic th {
+padding-left: 5px;
+padding-right: 5px;
+}
.lightable-classic thead tr:last-child th {
border-bottom: 1px solid #111111;
}
.lightable-classic.lightable-hover tbody tr:hover {
-background-color: #f5f5f5;
+background-color: #F9EEC1;
}
.lightable-classic.lightable-striped tr:nth-child(even) {
background-color: #f5f5f5;
@@ -1358,11 +1374,19 @@
width: 100%;
margin-bottom: 10px;
}
+.lightable-classic-2 td {
+padding-left: 5px;
+padding-right: 5px;
+}
+.lightable-classic-2 th {
+padding-left: 5px;
+padding-right: 5px;
+}
.lightable-classic-2 thead tr:last-child th {
border-bottom: 1px solid #111111;
}
.lightable-classic-2.lightable-hover tbody tr:hover {
-background-color: #f5f5f5;
+background-color: #F9EEC1;
}
.lightable-classic-2.lightable-striped tr:nth-child(even) {
background-color: #f5f5f5;
@@ -1434,6 +1458,32 @@
.lightable-material-dark.lightable-striped thead tr:last-child th {
border-bottom: 1px solid #FFFFFF12;
}
+.lightable-paper {
+width: 100%;
+margin-bottom: 10px;
+}
+.lightable-paper th {
+color: #999;
+vertical-align: bottom;
+border-bottom: 1px solid #00000020;
+line-height: 1.15em;
+padding: 10px 5px;
+}
+.lightable-paper td {
+vertical-align: middle;
+border-bottom: 1px solid #00000010;
+line-height: 1.15em;
+padding: 7px 5px;
+}
+.lightable-paper.lightable-hover tbody tr:hover {
+background-color: #F9EEC1;
+}
+.lightable-paper.lightable-striped tr:nth-child(even) {
+background-color: #00000008;
+}
+.lightable-material-dark.lightable-striped td {
+border: 0;
+}
</style>
<style type="text/css">code{white-space: pre;}</style>
@@ -1664,11 +1714,16 @@
<h1 class="title toc-ignore">Create Awesome HTML Table with knitr::kable and kableExtra</h1>
<h4 class="author">Hao Zhu</h4>
-<h4 class="date">2020-08-11</h4>
+<h4 class="date">2020-08-18</h4>
</div>
+<script>
+$(document).ready(function(){
+ $('[data-toggle="popover"]').popover();
+});
+</script>
<p><img src="" align="right" alt="logo" width="80" height="93" style="border: none; float: right;"></p>
<blockquote>
<p>Please see the package <a href="http://haozhu233.github.io/kableExtra/">documentation site</a> for how to use this package in LaTeX.</p>
@@ -1691,8 +1746,13 @@
<h1>Getting Started</h1>
<p>Here we are using the first few columns and rows from dataset <code>mtcars</code></p>
<pre class="r"><code>library(knitr)
-library(kableExtra)
-dt <- mtcars[1:5, 1:6]</code></pre>
+library(kableExtra)</code></pre>
+<pre><code>##
+## Attaching package: 'kableExtra'</code></pre>
+<pre><code>## The following object is masked from 'package:knitr':
+##
+## kable</code></pre>
+<pre class="r"><code>dt <- mtcars[1:5, 1:6]</code></pre>
<p>When you are using <code>kable()</code>, if you don’t specify <code>format</code>, by default it will generate a markdown table and let pandoc handle the conversion from markdown to HTML/PDF. This is the most favorable approach to render most simple tables as it is format independent. If you switch from HTML to pdf, you basically don’t need to change anything in your code. However, markdown doesn’t support complex table. For example, if you want to have a double-row header table, markdown just cannot provide you the functionality you need. As a result, when you have such a need, you should <strong>define <code>format</code> in <code>kable()</code></strong> as either “html” or “latex”. <em>You can also define a global option at the beginning using <code>options(knitr.table.format = "html")</code> so you don’t repeat the step everytime.</em></p>
<p><strong>Starting from <code>kableExtra</code> 0.9.0</strong>, when you load this package (<code>library(kableExtra)</code>), <span style=" font-weight: bold; color: white !important;border-radius: 4px; padding-right: 4px; padding-left: 4px; background-color: #d9230f !important;">it will automatically set up the global option ‘knitr.table.format’ based on your current environment</span>. Unless you are rendering a PDF, <code>kableExtra</code> will try to render a HTML table for you. <strong>You no longer need to manually set either the global option or the <code>format</code> option in each <code>kable()</code> function</strong>. I’m still including the explanation above here in this vignette so you can understand what is going on behind the scene. Note that this is only an global option. You can manually set any format in <code>kable()</code> whenever you want. I just hope you can enjoy a peace of mind in most of your time.</p>
<p>You can disable this behavior by setting <code>options(kableExtra.auto_format = FALSE)</code> before you load <code>kableExtra</code>.</p>
@@ -1999,11 +2059,157 @@
</div>
<div id="alternative-themes" class="section level2">
<h2>Alternative themes</h2>
-<p><code>kableExtra</code> also offers a few in-house alternative HTML table themes other than the default bootstrap theme. Right now there are 5 of them: <code>kable_classic</code>, <code>kable_classic_2</code>, <code>kable_minimal</code>, <code>kable_material</code> and <code>kable_material_dark</code>. These functions are alternatives to <code>kable_styling</code>, which means that you can specify any additional formatting options in <code>kable_styling</code> in these functions too. The only difference is that <code>bootstrap_options</code> (as discussed in the next section) is replaced with <code>lightable_options</code> at the same location with only two choices <code>striped</code> and <code>hover</code> available.</p>
+<p><code>kableExtra</code> also offers a few in-house alternative HTML table themes other than the default bootstrap theme. Right now there are 6 of them: <code>kable_paper</code>, <code>kable_classic</code>, <code>kable_classic_2</code>, <code>kable_minimal</code>, <code>kable_material</code> and <code>kable_material_dark</code>. These functions are alternatives to <code>kable_styling</code>, which means that you can specify any additional formatting options in <code>kable_styling</code> in these functions too. The only difference is that <code>bootstrap_options</code> (as discussed in the next section) is replaced with <code>lightable_options</code> at the same location with only two choices <code>striped</code> and <code>hover</code> available.</p>
+<pre class="r"><code>dt %>%
+ kable() %>%
+ kable_paper("hover")</code></pre>
+<table class=" lightable-paper lightable-hover" style="font-family: "Arial Narrow", arial, helvetica, sans-serif; margin-left: auto; margin-right: auto;">
+<thead>
+<tr>
+<th style="text-align:left;">
+</th>
+<th style="text-align:right;">
+mpg
+</th>
+<th style="text-align:right;">
+cyl
+</th>
+<th style="text-align:right;">
+disp
+</th>
+<th style="text-align:right;">
+hp
+</th>
+<th style="text-align:right;">
+drat
+</th>
+<th style="text-align:right;">
+wt
+</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td style="text-align:left;">
+Mazda RX4
+</td>
+<td style="text-align:right;">
+21.0
+</td>
+<td style="text-align:right;">
+6
+</td>
+<td style="text-align:right;">
+160
+</td>
+<td style="text-align:right;">
+110
+</td>
+<td style="text-align:right;">
+3.90
+</td>
+<td style="text-align:right;">
+2.620
+</td>
+</tr>
+<tr>
+<td style="text-align:left;">
+Mazda RX4 Wag
+</td>
+<td style="text-align:right;">
+21.0
+</td>
+<td style="text-align:right;">
+6
+</td>
+<td style="text-align:right;">
+160
+</td>
+<td style="text-align:right;">
+110
+</td>
+<td style="text-align:right;">
+3.90
+</td>
+<td style="text-align:right;">
+2.875
+</td>
+</tr>
+<tr>
+<td style="text-align:left;">
+Datsun 710
+</td>
+<td style="text-align:right;">
+22.8
+</td>
+<td style="text-align:right;">
+4
+</td>
+<td style="text-align:right;">
+108
+</td>
+<td style="text-align:right;">
+93
+</td>
+<td style="text-align:right;">
+3.85
+</td>
+<td style="text-align:right;">
+2.320
+</td>
+</tr>
+<tr>
+<td style="text-align:left;">
+Hornet 4 Drive
+</td>
+<td style="text-align:right;">
+21.4
+</td>
+<td style="text-align:right;">
+6
+</td>
+<td style="text-align:right;">
+258
+</td>
+<td style="text-align:right;">
+110
+</td>
+<td style="text-align:right;">
+3.08
+</td>
+<td style="text-align:right;">
+3.215
+</td>
+</tr>
+<tr>
+<td style="text-align:left;">
+Hornet Sportabout
+</td>
+<td style="text-align:right;">
+18.7
+</td>
+<td style="text-align:right;">
+8
+</td>
+<td style="text-align:right;">
+360
+</td>
+<td style="text-align:right;">
+175
+</td>
+<td style="text-align:right;">
+3.15
+</td>
+<td style="text-align:right;">
+3.440
+</td>
+</tr>
+</tbody>
+</table>
<pre class="r"><code>dt %>%
kable() %>%
kable_classic()</code></pre>
-<table class=" lightable-classic" style="margin-left: auto; margin-right: auto;">
+<table class=" lightable-classic" style="font-family: "Arial Narrow", "Source Sans Pro", sans-serif; margin-left: auto; margin-right: auto;">
<thead>
<tr>
<th style="text-align:left;">
@@ -2149,7 +2355,7 @@
<pre class="r"><code>dt %>%
kable() %>%
kable_classic_2()</code></pre>
-<table class=" lightable-classic-2" style="margin-left: auto; margin-right: auto;">
+<table class=" lightable-classic-2" style="font-family: "Arial Narrow", "Source Sans Pro", sans-serif; margin-left: auto; margin-right: auto;">
<thead>
<tr>
<th style="text-align:left;">
@@ -2295,7 +2501,7 @@
<pre class="r"><code>dt %>%
kable() %>%
kable_minimal()</code></pre>
-<table class=" lightable-minimal" style="margin-left: auto; margin-right: auto;">
+<table class=" lightable-minimal" style="font-family: calibri, cambria, "Source Sans Pro", sans-serif; margin-left: auto; margin-right: auto;">
<thead>
<tr>
<th style="text-align:left;">
@@ -2441,7 +2647,7 @@
<pre class="r"><code>dt %>%
kable() %>%
kable_material(c("striped", "hover"))</code></pre>
-<table class=" lightable-material lightable-striped lightable-hover" style="margin-left: auto; margin-right: auto;">
+<table class=" lightable-material lightable-striped lightable-hover" style="font-family: "Source Sans Pro", helvetica, sans-serif; margin-left: auto; margin-right: auto;">
<thead>
<tr>
<th style="text-align:left;">
@@ -2587,7 +2793,7 @@
<pre class="r"><code>dt %>%
kable() %>%
kable_material_dark()</code></pre>
-<table class=" lightable-material-dark" style="margin-left: auto; margin-right: auto;">
+<table class=" lightable-material-dark" style="font-family: "Source Sans Pro", helvetica, sans-serif; margin-left: auto; margin-right: auto;">
<thead>
<tr>
<th style="text-align:left;">
@@ -3181,8 +3387,8 @@
<h2>Full width?</h2>
<p>By default, a bootstrap table takes 100% of the width. It is supposed to use together with its grid system to scale the table properly. However, when you are writing a rmarkdown document, you probably don’t want to write your own css/or grid. For some small tables with only few columns, a page wide table looks awful. To make it easier, you can specify whether you want the table to have <code>full_width</code> or not in <code>kable_styling</code>. By default, <code>full_width</code> is set to be <code>TRUE</code> for HTML tables (note that for LaTeX, the default is <code>FALSE</code> since I don’t want to change the “common” looks unless you specified it.)</p>
<pre class="r"><code>kable(dt) %>%
- kable_styling(bootstrap_options = "striped", full_width = F)</code></pre>
-<table class="table table-striped" style="width: auto !important; margin-left: auto; margin-right: auto;">
+ kable_paper(bootstrap_options = "striped", full_width = F)</code></pre>
+<table class=" lightable-paper" style="font-family: "Arial Narrow", arial, helvetica, sans-serif; width: auto !important; margin-left: auto; margin-right: auto;">
<thead>
<tr>
<th style="text-align:left;">
@@ -4060,10 +4266,288 @@
</tr>
</tbody>
</table>
+<blockquote>
+<p><strong>Key Update</strong>: I understand the need of doing conditional formatting and the previous solution <code>cell_spec</code> is relatively hard to use. Therefore in kableExtra 1.2, I improved the functionality of <code>column_spec</code> so it can take vectorized input for most of its arguments (except <code>width</code>, <code>border_left</code> and <code>border_right</code>). It is really easy right now to format a column based on other values.</p>
+</blockquote>
+<pre class="r"><code>mtcars[1:8, 1:8] %>%
+ kable() %>%
+ kable_paper(full_width = F) %>%
+ column_spec(2, color = spec_color(mtcars$mpg[1:8]),
+ link = "https://haozhu233.github.io/kableExtra") %>%
+ column_spec(6, color = "white",
+ background = spec_color(mtcars$drat[1:8], end = 0.7),
+ popover = paste("am:", mtcars$am[1:8]))</code></pre>
+<table class=" lightable-paper" style="font-family: "Arial Narrow", arial, helvetica, sans-serif; width: auto !important; margin-left: auto; margin-right: auto;">
+<thead>
+<tr>
+<th style="text-align:left;">
+</th>
+<th style="text-align:right;">
+mpg
+</th>
+<th style="text-align:right;">
+cyl
+</th>
+<th style="text-align:right;">
+disp
+</th>
+<th style="text-align:right;">
+hp
+</th>
+<th style="text-align:right;">
+drat
+</th>
+<th style="text-align:right;">
+wt
+</th>
+<th style="text-align:right;">
+qsec
+</th>
+<th style="text-align:right;">
+vs
+</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td style="text-align:left;">
+Mazda RX4
+</td>
+<td style="text-align:right;color: rgba(52, 182, 121, 1) !important;">
+<a href="https://haozhu233.github.io/kableExtra" style="color: rgba(52, 182, 121, 1) !important;"> 21.0 </a>
+</td>
+<td style="text-align:right;">
+6
+</td>
+<td style="text-align:right;">
+160.0
+</td>
+<td style="text-align:right;">
+110
+</td>
+<td style="text-align:right;color: white !important;background-color: rgba(67, 191, 113, 1) !important;" data-toggle="popover" data-container="body" data-trigger="hover" data-placement="right" data-content="am: 1">
+3.90
+</td>
+<td style="text-align:right;">
+2.620
+</td>
+<td style="text-align:right;">
+16.46
+</td>
+<td style="text-align:right;">
+0
+</td>
+</tr>
+<tr>
+<td style="text-align:left;">
+Mazda RX4 Wag
+</td>
+<td style="text-align:right;color: rgba(52, 182, 121, 1) !important;">
+<a href="https://haozhu233.github.io/kableExtra" style="color: rgba(52, 182, 121, 1) !important;"> 21.0 </a>
+</td>
+<td style="text-align:right;">
+6
+</td>
+<td style="text-align:right;">
+160.0
+</td>
+<td style="text-align:right;">
+110
+</td>
+<td style="text-align:right;color: white !important;background-color: rgba(67, 191, 113, 1) !important;" data-toggle="popover" data-container="body" data-trigger="hover" data-placement="right" data-content="am: 1">
+3.90
+</td>
+<td style="text-align:right;">
+2.875
+</td>
+<td style="text-align:right;">
+17.02
+</td>
+<td style="text-align:right;">
+0
+</td>
+</tr>
+<tr>
+<td style="text-align:left;">
+Datsun 710
+</td>
+<td style="text-align:right;color: rgba(149, 216, 64, 1) !important;">
+<a href="https://haozhu233.github.io/kableExtra" style="color: rgba(149, 216, 64, 1) !important;"> 22.8 </a>
+</td>
+<td style="text-align:right;">
+4
+</td>
+<td style="text-align:right;">
+108.0
+</td>
+<td style="text-align:right;">
+93
+</td>
+<td style="text-align:right;color: white !important;background-color: rgba(55, 184, 120, 1) !important;" data-toggle="popover" data-container="body" data-trigger="hover" data-placement="right" data-content="am: 1">
+3.85
+</td>
+<td style="text-align:right;">
+2.320
+</td>
+<td style="text-align:right;">
+18.61
+</td>
+<td style="text-align:right;">
+1
+</td>
+</tr>
+<tr>
+<td style="text-align:left;">
+Hornet 4 Drive
+</td>
+<td style="text-align:right;color: rgba(68, 191, 112, 1) !important;">
+<a href="https://haozhu233.github.io/kableExtra" style="color: rgba(68, 191, 112, 1) !important;"> 21.4 </a>
+</td>
+<td style="text-align:right;">
+6
+</td>
+<td style="text-align:right;">
+258.0
+</td>
+<td style="text-align:right;">
+110
+</td>
+<td style="text-align:right;color: white !important;background-color: rgba(65, 67, 135, 1) !important;" data-toggle="popover" data-container="body" data-trigger="hover" data-placement="right" data-content="am: 0">
+3.08
+</td>
+<td style="text-align:right;">
+3.215
+</td>
+<td style="text-align:right;">
+19.44
+</td>
+<td style="text-align:right;">
+1
+</td>
+</tr>
+<tr>
+<td style="text-align:left;">
+Hornet Sportabout
+</td>
+<td style="text-align:right;color: rgba(38, 129, 142, 1) !important;">
+<a href="https://haozhu233.github.io/kableExtra" style="color: rgba(38, 129, 142, 1) !important;"> 18.7 </a>
+</td>
+<td style="text-align:right;">
+8
+</td>
+<td style="text-align:right;">
+360.0
+</td>
+<td style="text-align:right;">
+175
+</td>
+<td style="text-align:right;color: white !important;background-color: rgba(60, 79, 138, 1) !important;" data-toggle="popover" data-container="body" data-trigger="hover" data-placement="right" data-content="am: 0">
+3.15
+</td>
+<td style="text-align:right;">
+3.440
+</td>
+<td style="text-align:right;">
+17.02
+</td>
+<td style="text-align:right;">
+0
+</td>
+</tr>
+<tr>
+<td style="text-align:left;">
+Valiant
+</td>
+<td style="text-align:right;color: rgba(44, 114, 142, 1) !important;">
+<a href="https://haozhu233.github.io/kableExtra" style="color: rgba(44, 114, 142, 1) !important;"> 18.1 </a>
+</td>
+<td style="text-align:right;">
+6
+</td>
+<td style="text-align:right;">
+225.0
+</td>
+<td style="text-align:right;">
+105
+</td>
+<td style="text-align:right;color: white !important;background-color: rgba(68, 1, 84, 1) !important;" data-toggle="popover" data-container="body" data-trigger="hover" data-placement="right" data-content="am: 0">
+2.76
+</td>
+<td style="text-align:right;">
+3.460
+</td>
+<td style="text-align:right;">
+20.22
+</td>
+<td style="text-align:right;">
+1
+</td>
+</tr>
+<tr>
+<td style="text-align:left;">
+Duster 360
+</td>
+<td style="text-align:right;color: rgba(68, 1, 84, 1) !important;">
+<a href="https://haozhu233.github.io/kableExtra" style="color: rgba(68, 1, 84, 1) !important;"> 14.3 </a>
+</td>
+<td style="text-align:right;">
+8
+</td>
+<td style="text-align:right;">
+360.0
+</td>
+<td style="text-align:right;">
+245
+</td>
+<td style="text-align:right;color: white !important;background-color: rgba(55, 90, 140, 1) !important;" data-toggle="popover" data-container="body" data-trigger="hover" data-placement="right" data-content="am: 0">
+3.21
+</td>
+<td style="text-align:right;">
+3.570
+</td>
+<td style="text-align:right;">
+15.84
+</td>
+<td style="text-align:right;">
+0
+</td>
+</tr>
+<tr>
+<td style="text-align:left;">
+Merc 240D
+</td>
+<td style="text-align:right;color: rgba(253, 231, 37, 1) !important;">
+<a href="https://haozhu233.github.io/kableExtra" style="color: rgba(253, 231, 37, 1) !important;"> 24.4 </a>
+</td>
+<td style="text-align:right;">
+4
+</td>
+<td style="text-align:right;">
+146.7
+</td>
+<td style="text-align:right;">
+62
+</td>
+<td style="text-align:right;color: white !important;background-color: rgba(31, 161, 135, 1) !important;" data-toggle="popover" data-container="body" data-trigger="hover" data-placement="right" data-content="am: 0">
+3.69
+</td>
+<td style="text-align:right;">
+3.190
+</td>
+<td style="text-align:right;">
+20.00
+</td>
+<td style="text-align:right;">
+1
+</td>
+</tr>
+</tbody>
+</table>
+<p>You can still use the <code>spec_***</code> helper functions to help you define color. See the documentation <a href="#visualize-data-with-viridis-color">below</a>.</p>
</div>
<div id="row-spec" class="section level2">
<h2>Row spec</h2>
-<p>Similar with <code>column_spec</code>, you can define specifications for rows. Currently, you can either bold or italiciz an entire row. Note that, similar with other row-related functions in <code>kableExtra</code>, for the position of the target row, you don’t need to count in header rows or the group labelling rows.</p>
+<p>Similar with <code>column_spec</code>, you can define specifications for rows. Currently, you can either bold or italicize an entire row. Note that, similar with other row-related functions in <code>kableExtra</code>, for the position of the target row, you don’t need to count in header rows or the group labeling rows.</p>
<pre class="r"><code>kable(dt) %>%
kable_styling("striped", full_width = F) %>%
column_spec(5:7, bold = T) %>%
@@ -4365,6 +4849,9 @@
</div>
<div id="celltext-specification" class="section level1">
<h1>Cell/Text Specification</h1>
+<blockquote>
+<p><strong>Key Update: As said before, if you are using kableExtra 1.2+, you are now recommended to used <code>column_spec</code> to do conditional formatting</strong>.</p>
+</blockquote>
<p>Function <code>cell_spec</code> is introduced in version 0.6.0 of <code>kableExtra</code>. Unlike <code>column_spec</code> and <code>row_spec</code>, <strong>this function is designed to be used before the data.frame gets into the <code>kable</code> function</strong>. Comparing with figuring out a list of 2 dimentional index for targeted cells, this design is way easier to learn and use and it fits perfectly well with <code>dplyr</code>’s <code>mutate</code> and <code>summarize</code> functions. With this design, there are two things to be noted: * Since <code>cell_spec</code> generates raw <code>HTML</code> or <code>LaTeX</code> code, make sure you remember to put <code>escape = FALSE</code> in <code>kable</code>. At the same time, you have to escape special symbols including <code>%</code> manually by yourself * <code>cell_spec</code> needs a way to know whether you want <code>html</code> or <code>latex</code>. You can specify it locally in function or globally via the <code>options(knitr.table.format = "latex")</code> method as suggested at the beginning. If you don’t provide anything, this function will output as HTML by default.</p>
<p>Currently, <code>cell_spec</code> supports features including bold, italic, monospace, text color, background color, align, font size & rotation angle. More features may be added in the future. Please see function documentations as reference.</p>
<div id="conditional-logic" class="section level2">
@@ -4512,7 +4999,7 @@
</div>
<div id="visualize-data-with-viridis-color" class="section level2">
<h2>Visualize data with Viridis Color</h2>
-<p>This package also comes with a few helper functions, including <code>spec_color</code>, <code>spec_font_size</code> & <code>spec_angle</code>. These functions can rescale continuous variables to certain scales. For example, function <code>spec_color</code> would map a continuous variable to any <a href="https://CRAN.R-project.org/package=viridisLite">viridis color palettes</a>. It offers a very visually impactful representation in a tabular format.</p>
+<p>This package also comes with a few helper functions, including <code>spec_color</code>, <code>spec_font_size</code> & <code>spec_angle</code>. These functions can rescale continuous variables to certain scales. For example, function <code>spec_color</code> would map a continuous variable to any <a href="https://CRAN.R-project.org/package=viridisLite">viridis color palettes</a>. It offers a very visually impressive representation in a tabular format.</p>
<pre class="r"><code>iris[1:10, ] %>%
mutate_if(is.numeric, function(x) {
cell_spec(x, bold = T,
@@ -4739,7 +5226,7 @@
</div>
<div id="tooltip" class="section level2">
<h2>Tooltip</h2>
-<p>It’s very easy to add a tooltip to text via <code>cell_spec</code>. For example, <code>text_spec("tooltip", color = "red", tooltip = "Hello World")</code> will give you something like <span style=" color: red !important;" data-toggle="tooltip" data-placement="right" title="Hello World">Hover over me</span> (you need to wait for a few seconds before your browser renders it).</p>
+<p>It’s very easy to add a tooltip to text via <code>cell_spec</code>. For example, <code>text_spec("tooltip", color = "red", tooltip = "Hello World")</code> will give you something like <span style=" color: red !important;" data-toggle="tooltip" data-container="body" data-placement="right" title="Hello World">Hover over me</span> (you need to wait for a few seconds before your browser renders it).</p>
<p>Note that the original browser-based tooltip is slow. If you want to have a faster response, you may want to initialize bootstrap’s tooltip by putting the following HTML code on the page.</p>
<pre><code><script>
$(document).ready(function(){
@@ -4756,11 +5243,6 @@
$('[data-toggle="popover"]').popover();
});
</script></code></pre>
-<script>
-$(document).ready(function(){
- $('[data-toggle="popover"]').popover();
-});
-</script>
<pre class="r"><code>popover_dt <- data.frame(
position = c("top", "bottom", "right", "left"),
stringsAsFactors = FALSE
@@ -4791,7 +5273,7 @@
top
</td>
<td style="text-align:left;">
-<span style=" " data-toggle="popover" data-trigger="hover" data-placement="top" data-content="top">Message on top</span>
+<span style=" " data-toggle="popover" data-container="body" data-trigger="hover" data-placement="top" data-content="top">Message on top</span>
</td>
</tr>
<tr>
@@ -4799,7 +5281,7 @@
bottom
</td>
<td style="text-align:left;">
-<span style=" " data-toggle="popover" data-trigger="hover" data-placement="bottom" data-content="bottom">Message on bottom</span>
+<span style=" " data-toggle="popover" data-container="body" data-trigger="hover" data-placement="bottom" data-content="bottom">Message on bottom</span>
</td>
</tr>
<tr>
@@ -4807,7 +5289,7 @@
right
</td>
<td style="text-align:left;">
-<span style=" " data-toggle="popover" data-trigger="hover" data-placement="right" data-content="right">Message on right</span>
+<span style=" " data-toggle="popover" data-container="body" data-trigger="hover" data-placement="right" data-content="right">Message on right</span>
</td>
</tr>
<tr>
@@ -4815,7 +5297,7 @@
left
</td>
<td style="text-align:left;">
-<span style=" " data-toggle="popover" data-trigger="hover" data-placement="left" data-content="left">Message on left</span>
+<span style=" " data-toggle="popover" data-container="body" data-trigger="hover" data-placement="left" data-content="left">Message on left</span>
</td>
</tr>
</tbody>
@@ -4823,7 +5305,7 @@
</div>
<div id="links" class="section level2">
<h2>Links</h2>
-<p>You can add links to text via <code>text_spec("Google", link = "https://google.com")</code>: <a href="https://google.com" style=" ">Google</a>. If you want your hover message to be more obvious, it might be a good idea to put a <code>#</code> (go back to the top of the page) or <code>javascript:void(0)</code> (literally do nothing) in the <code>link</code> option. <code>text_spec("Hover on me", link = "javascript:void(0)", popover = "Hello")</code>: <a href="javascript:void(0)" style=" " data-toggle="popover" data-trigger="hover" data-placement="right" data-content="Hello">Hover on me</a></p>
+<p>You can add links to text via <code>text_spec("Google", link = "https://google.com")</code>: <a href="https://google.com" style=" ">Google</a>. If you want your hover message to be more obvious, it might be a good idea to put a <code>#</code> (go back to the top of the page) or <code>javascript:void(0)</code> (literally do nothing) in the <code>link</code> option. <code>text_spec("Hover on me", link = "javascript:void(0)", popover = "Hello")</code>: <a href="javascript:void(0)" style=" " data-toggle="popover" data-container="body" data-trigger="hover" data-placement="right" data-content="Hello">Hover on me</a></p>
</div>
<div id="integration-with-formattable" class="section level2">
<h2>Integration with <code>formattable</code></h2>
@@ -5977,7 +6459,7 @@
2
</td>
<td style="text-align:center;">
-0
+1
</td>
</tr>
<tr>
@@ -5993,7 +6475,7 @@
4
</td>
<td style="text-align:center;">
-0
+1
</td>
</tr>
<tr>
@@ -6028,7 +6510,7 @@
8
</td>
<td style="text-align:center;">
-1
+0
</td>
</tr>
<tr>
@@ -6036,7 +6518,7 @@
9
</td>
<td style="text-align:center;">
-1
+0
</td>
</tr>
<tr>
@@ -6044,7 +6526,7 @@
10
</td>
<td style="text-align:center;">
-0
+1
</td>
</tr>
<tr>
@@ -6058,7 +6540,7 @@
11
</td>
<td style="text-align:center;">
-0
+1
</td>
</tr>
<tr>
@@ -6077,7 +6559,7 @@
13
</td>
<td style="text-align:center;">
-0
+1
</td>
</tr>
<tr>
@@ -6085,7 +6567,7 @@
14
</td>
<td style="text-align:center;">
-0
+1
</td>
</tr>
<tr>
@@ -6478,10 +6960,12 @@
<p>If you need to add footnote marks in table, you need to do it manually (no fancy) using <code>footnote_mark_***()</code>. Remember that similar with <code>cell_spec</code>, you need to tell this function whether you want it to do it in <code>HTML</code> (default) or <code>LaTeX</code>. You can set it for all using the <code>knitr.table.format</code> global option. ALso, if you have ever use <code>footnote_mark_***()</code>, you need to put <code>escape = F</code> in your <code>kable</code> function to avoid escaping of special characters.</p>
<pre class="r"><code>dt_footnote <- dt
names(dt_footnote)[2] <- paste0(names(dt_footnote)[2],
- footnote_marker_symbol(1))
-row.names(dt_footnote)[4] <- paste0(row.names(dt_footnote)[4],
- footnote_marker_alphabet(1))
-kable(dt_footnote, align = "c",
+ footnote_marker_symbol(1))</code></pre>
+<pre><code>## Setting footnote_marker_symbol format as html</code></pre>
+<pre class="r"><code>row.names(dt_footnote)[4] <- paste0(row.names(dt_footnote)[4],
+ footnote_marker_alphabet(1))</code></pre>
+<pre><code>## Setting footnote_marker_alphabet format as html</code></pre>
+<pre class="r"><code>kable(dt_footnote, align = "c",
# Remember this escape = F
escape = F) %>%
kable_styling(full_width = F) %>%
diff --git a/docs/awesome_table_in_pdf.Rmd b/docs/awesome_table_in_pdf.Rmd
index ef3a126..7959839 100644
--- a/docs/awesome_table_in_pdf.Rmd
+++ b/docs/awesome_table_in_pdf.Rmd
@@ -54,7 +54,6 @@
```
```{r}
-library(knitr)
library(kableExtra)
dt <- mtcars[1:5, 1:6]
```
@@ -220,6 +219,26 @@
column_spec(2, width = "30em")
```
+
+> **Key Update**: I understand the need of doing conditional formatting and the previous solution `cell_spec` is relatively hard to use. Therefore in kableExtra 1.2, I improved the functionality of `column_spec` so it can take vectorized input for most of its arguments (except `width`, `border_left` and `border_right`). It is really easy right now to format a column based on other values.
+
+```{r}
+that_cell <- c(rep(F, 7), T)
+mtcars[1:8, 1:8] %>%
+ kable(booktabs = T, linesep = "") %>%
+ kable_paper(full_width = F) %>%
+ column_spec(2, color = spec_color(mtcars$mpg[1:8]),
+ link = "https://haozhu233.github.io/kableExtra") %>%
+ column_spec(6, color = "white",
+ background = spec_color(mtcars$drat[1:8], end = 0.7),
+ popover = paste("am:", mtcars$am[1:8])) %>%
+ column_spec(9, strikeout = that_cell, bold = that_cell,
+ color = c(rep("black", 7), "red"))
+```
+
+You can still use the `spec_***` helper functions to help you define color. See the documentation [below](#visualize-data-with-viridis-color).
+
+
## Row spec
Similar with `column_spec`, you can define specifications for rows. Currently, you can either bold or italicize an entire row. Note that, similar to other row-related functions in `kableExtra`, for the position of the target row, you don't need to count in header rows or the group labeling rows.
@@ -242,6 +261,9 @@
# Cell/Text Specification
+
+>**Key Update: As said before, if you are using kableExtra 1.2+, you are now recommended to used `column_spec` to do conditional formatting**.
+
Function `cell_spec` is introduced in version 0.6.0 of `kableExtra`. Unlike `column_spec` and `row_spec`, **this function is designed to be used before the data.frame gets into the `kable` function**. Comparing with figuring out a list of 2 dimensional indexes for targeted cells, this design is way easier to learn and use, and it fits perfectly well with `dplyr`'s `mutate` and `summarize` functions. With this design, there are two things to be noted:
* Since `cell_spec` generates raw `HTML` or `LaTeX` code, make sure you remember to put `escape = FALSE` in `kable`. At the same time, you have to escape special symbols including `%` manually by yourself
* `cell_spec` needs a way to know whether you want `html` or `latex`. You can specify it locally in function or globally via the `options(knitr.table.format = "latex")` method as suggested at the beginning. If you don't provide anything, this function will output as HTML by default.
diff --git a/docs/awesome_table_in_pdf.pdf b/docs/awesome_table_in_pdf.pdf
index 196968e..10b350d 100644
--- a/docs/awesome_table_in_pdf.pdf
+++ b/docs/awesome_table_in_pdf.pdf
Binary files differ
diff --git a/docs/awesome_table_in_pdf.toc b/docs/awesome_table_in_pdf.toc
index a985c6b..984d331 100644
--- a/docs/awesome_table_in_pdf.toc
+++ b/docs/awesome_table_in_pdf.toc
@@ -3,7 +3,7 @@
\contentsline {section}{Getting Started}{2}{section*.4}%
\contentsline {subsection}{LaTeX packages used in this package}{3}{section*.5}%
\contentsline {subsection}{Plain LaTeX}{3}{section*.6}%
-\contentsline {subsection}{LaTeX table with booktabs}{3}{section*.7}%
+\contentsline {subsection}{LaTeX table with booktabs}{4}{section*.7}%
\contentsline {section}{Table Styles}{4}{section*.8}%
\contentsline {subsection}{LaTeX options}{4}{section*.9}%
\contentsline {subsubsection}{Striped}{4}{section*.10}%
@@ -16,21 +16,21 @@
\contentsline {section}{Column / Row Specification}{9}{section*.17}%
\contentsline {subsection}{Column spec}{9}{section*.18}%
\contentsline {subsection}{Row spec}{10}{section*.19}%
-\contentsline {subsection}{Header Rows}{10}{section*.20}%
-\contentsline {section}{Cell/Text Specification}{10}{section*.21}%
+\contentsline {subsection}{Header Rows}{11}{section*.20}%
+\contentsline {section}{Cell/Text Specification}{11}{section*.21}%
\contentsline {subsection}{Conditional logic}{11}{section*.22}%
-\contentsline {subsection}{Visualize data with Viridis Color}{11}{section*.23}%
-\contentsline {subsection}{Text Specification}{12}{section*.24}%
-\contentsline {section}{Grouped Columns / Rows}{12}{section*.25}%
-\contentsline {subsection}{Add header rows to group columns}{12}{section*.26}%
-\contentsline {subsection}{Group rows via labeling}{13}{section*.27}%
+\contentsline {subsection}{Visualize data with Viridis Color}{12}{section*.23}%
+\contentsline {subsection}{Text Specification}{13}{section*.24}%
+\contentsline {section}{Grouped Columns / Rows}{13}{section*.25}%
+\contentsline {subsection}{Add header rows to group columns}{13}{section*.26}%
+\contentsline {subsection}{Group rows via labeling}{14}{section*.27}%
\contentsline {subsection}{Row indentation}{15}{section*.28}%
-\contentsline {subsection}{Group rows via multi-row cell}{15}{section*.29}%
-\contentsline {section}{Table Footnote}{18}{section*.30}%
-\contentsline {section}{LaTeX Only Features}{20}{section*.31}%
-\contentsline {subsection}{Linebreak processor}{20}{section*.32}%
-\contentsline {subsection}{Table on a Landscape Page}{21}{section*.33}%
-\contentsline {subsection}{Use LaTeX table in HTML or Word}{23}{section*.34}%
-\contentsline {section}{From other packages}{23}{section*.35}%
-\contentsline {subsection}{\texttt {tables}}{23}{section*.36}%
-\contentsline {subsection}{\texttt {xtable}}{23}{section*.37}%
+\contentsline {subsection}{Group rows via multi-row cell}{16}{section*.29}%
+\contentsline {section}{Table Footnote}{19}{section*.30}%
+\contentsline {section}{LaTeX Only Features}{22}{section*.31}%
+\contentsline {subsection}{Linebreak processor}{22}{section*.32}%
+\contentsline {subsection}{Table on a Landscape Page}{22}{section*.33}%
+\contentsline {subsection}{Use LaTeX table in HTML or Word}{24}{section*.34}%
+\contentsline {section}{From other packages}{24}{section*.35}%
+\contentsline {subsection}{\texttt {tables}}{24}{section*.36}%
+\contentsline {subsection}{\texttt {xtable}}{24}{section*.37}%
diff --git a/inst/NEWS.md b/inst/NEWS.md
index 9b48ed4..3818d58 100644
--- a/inst/NEWS.md
+++ b/inst/NEWS.md
@@ -1,6 +1,19 @@
kableExtra 1.2.0
--------------------------------------------------------------------------------
+# Major Change
+
+* Added a `kable` function as a wrapper of the original `kable` but provides better documentation and auto-complete. We also moved the automatic format
+setup piece into the `kable` function call instead of changing global option
+during package start-up.
+
+* Added a few alternative HTML table themes. See https://haozhu233.github.io/kableExtra/awesome_table_in_html.html#Alternative_themes. (#451)
+
+* `column_spec` now takes vectorized input so it's easier to do conditional
+formatting without using `cell_spec`
+
+# Minor Change
+
* `add_indent` has a new option `level_of_indent` to control the width of the
indentation. (thanks @samiaab1990 #479)
@@ -12,33 +25,36 @@
* `collapse_rows` has a new option `target` to choose the target column in
`collapse_rows` (#484)
-* Fixed a bug with `group_rows` when used with `repeat_header` on the last row
-(#476)
-
-* Added mathjax to preview (#473)
-
-* Fixed a bug with `repeat_header` when the header row is customized (#480)
-
-* Fixed a bug with `collapse_rows` when text is too long. (#464)
+* Added mathjax to HTML preview (#473)
* Added a new function `remove_column` for html. The latex part hasn't been
implemented yet. (#490, thanks @DanChaltiel)
-* `add_header_above` now can take a data.frame as input. (#440, thanks @jokorn)
-
-* Fixed a bug when using UTF-8 on non-UTF-8 system. (#440, thanks @jokorn)
-
* Added a global option to control whether to preview HTML tables in RStudio
viewer. If you want to disable the default behavior, try to set
`options(kableExtra_view_html = F)`. (#455)
-* Added a few alternative HTML table themes. See https://haozhu233.github.io/kableExtra/awesome_table_in_html.html#Alternative_themes. (#451)
-
* Added a `new_tab` option to `cell_spec` to control whether to open up links
in new tab. (#454)
* Improved the behavior of `scroll_box` so it will skip non-html tables. (#450)
+* Added a `html_font` option to `kable_styling` and its variants.
+
+
+# Bug Fix
+
+* Fixed a bug with `group_rows` when used with `repeat_header` on the last row
+(#476)
+
+* Fixed a bug with `repeat_header` when the header row is customized (#480)
+
+* Fixed a bug with `collapse_rows` when text is too long. (#464)
+
+* `add_header_above` now can take a data.frame as input. (#440, thanks @jokorn)
+
+* Fixed a bug when using UTF-8 on non-UTF-8 system. (#440, thanks @jokorn)
+
* Fixed a bug in `collapse_rows` when there is no column names (#459)
* Fixed a bug for `add_header_rows` when there isn't thead in HTML (#246, #423,
@@ -48,6 +64,10 @@
#422, thanks @kbrevoort)
+
+
+
+
kableExtra 1.1.0
--------------------------------------------------------------------------------
diff --git a/inst/lightable-0.0.1/lightable.css b/inst/lightable-0.0.1/lightable.css
index d18f18c..ae1fb53 100644
--- a/inst/lightable-0.0.1/lightable.css
+++ b/inst/lightable-0.0.1/lightable.css
@@ -11,9 +11,20 @@
margin-bottom: 10px;
}
+.lightable-minimal td {
+ margin-left: 5px;
+ margin-right: 5px;
+}
+
+.lightable-minimal th {
+ margin-left: 5px;
+ margin-right: 5px;
+}
+
.lightable-minimal thead tr th {
border-bottom: 2px solid black;
empty-cells: hide;
+
}
.lightable-minimal tbody tr:first-child td {
@@ -35,12 +46,22 @@
margin-bottom: 10px;
}
+.lightable-classic td {
+ padding-left: 5px;
+ padding-right: 5px;
+}
+
+.lightable-classic th {
+ padding-left: 5px;
+ padding-right: 5px;
+}
+
.lightable-classic thead tr:last-child th {
border-bottom: 1px solid #111111;
}
.lightable-classic.lightable-hover tbody tr:hover {
- background-color: #f5f5f5;
+ background-color: #F9EEC1;
}
.lightable-classic.lightable-striped tr:nth-child(even) {
@@ -54,12 +75,22 @@
margin-bottom: 10px;
}
+.lightable-classic-2 td {
+ padding-left: 5px;
+ padding-right: 5px;
+}
+
+.lightable-classic-2 th {
+ padding-left: 5px;
+ padding-right: 5px;
+}
+
.lightable-classic-2 thead tr:last-child th {
border-bottom: 1px solid #111111;
}
.lightable-classic-2.lightable-hover tbody tr:hover {
- background-color: #f5f5f5;
+ background-color: #F9EEC1;
}
.lightable-classic-2.lightable-striped tr:nth-child(even) {
@@ -146,3 +177,35 @@
.lightable-material-dark.lightable-striped thead tr:last-child th {
border-bottom: 1px solid #FFFFFF12;
}
+
+.lightable-paper {
+ width: 100%;
+ margin-bottom: 10px;
+}
+
+.lightable-paper th {
+ color: #999;
+ vertical-align: bottom;
+ border-bottom: 1px solid #00000020;
+ line-height: 1.15em;
+ padding: 10px 5px;
+}
+
+.lightable-paper td {
+ vertical-align: middle;
+ border-bottom: 1px solid #00000010;
+ line-height: 1.15em;
+ padding: 7px 5px;
+}
+
+.lightable-paper.lightable-hover tbody tr:hover {
+ background-color: #F9EEC1;
+}
+
+.lightable-paper.lightable-striped tr:nth-child(even) {
+ background-color: #00000008;
+}
+
+.lightable-material-dark.lightable-striped td {
+ border: 0;
+}
diff --git a/man/column_spec.Rd b/man/column_spec.Rd
index 698c688..aeff8ec 100644
--- a/man/column_spec.Rd
+++ b/man/column_spec.Rd
@@ -22,7 +22,11 @@
extra_css = NULL,
include_thead = FALSE,
latex_column_spec = NULL,
- latex_valign = "p"
+ latex_valign = "p",
+ link = NULL,
+ new_tab = TRUE,
+ tooltip = NULL,
+ popover = NULL
)
}
\arguments{
@@ -33,25 +37,25 @@
\item{width}{A character string telling HTML & LaTeX how wide the column
needs to be, e.g. "10cm", "3in" or "30em".}
-\item{bold}{A T/F value to control whether the text of the selected column
-need to be bolded.}
+\item{bold}{T/F value or vector to control whether the text of the selected
+column need to be bolded.}
-\item{italic}{A T/F value to control whether the text of the selected column
-need to be emphasized.}
+\item{italic}{T/F value or vector to control whether the text of the
+selected column need to be emphasized.}
-\item{monospace}{A T/F value to control whether the text of the selected column
-need to be monospaced (verbatim)}
+\item{monospace}{T/F value or vector to control whether the text of the
+selected column need to be monospaced (verbatim)}
-\item{underline}{A T/F value to control whether the text of the selected row
-need to be underlined}
+\item{underline}{T/F value or vector to control whether the text of the
+selected row need to be underlined}
-\item{strikeout}{A T/F value to control whether the text of the selected row
-need to be stricked out.}
+\item{strikeout}{T/F value or vector to control whether the text of the
+selected row need to be striked out.}
-\item{color}{A character string for column text color. Here please pay
-attention to the differences in color codes between HTML and LaTeX.}
+\item{color}{A character string or vector for column text color. Here please
+pay attention to the differences in color codes between HTML and LaTeX.}
-\item{background}{A character string for column background color. Here please
+\item{background}{A character string or vector for column background color. Here please
pay attention to the differences in color codes between HTML and LaTeX.}
\item{border_left}{A logical variable indicating whether there should be a
@@ -70,8 +74,8 @@
\item{width_max}{Only for HTML table. \code{width_max} defines the maximum width
of table columns.}
-\item{extra_css}{Extra css text to be passed into the cells of the row. Note
-that it's not for the whole column but to each individual cells}
+\item{extra_css}{A vector of extra css text to be passed into the cells of
+the column.}
\item{include_thead}{T/F. A HTML only feature to contoll whether the
header row will be manipulated. Default is \code{FALSE}.}
@@ -81,6 +85,20 @@
\item{latex_valign}{vertical alignment. Only works when you specified column
width. Choose among \code{p}, \code{m}, \code{b}.}
+
+\item{link}{A vector of strings for url links.}
+
+\item{new_tab}{T/F for whether to open up the new link in new tab}
+
+\item{tooltip}{A vector of strings to be displayed as tooltip.
+Obviously, this feature is only available in HTML. Read the package
+vignette to see how to use bootstrap tooltip css to improve the loading
+speed and look.}
+
+\item{popover}{Similar with tooltip but can hold more contents. The best way
+to build a popover is through \code{spec_popover()}. If you only provide a text
+string, it will be used as content. Note that You have to enable this
+bootstrap module manually. Read the package vignette to see how.}
}
\description{
This function allows users to select a column and then specify
diff --git a/man/kable_classic.Rd b/man/kable_classic.Rd
index 4250603..787d44e 100644
--- a/man/kable_classic.Rd
+++ b/man/kable_classic.Rd
@@ -6,17 +6,50 @@
\alias{kable_minimal}
\alias{kable_material}
\alias{kable_material_dark}
+\alias{kable_paper}
\title{Alternative HTML themes}
\usage{
-kable_classic(kable_input, lightable_options = "basic", ...)
+kable_classic(
+ kable_input,
+ lightable_options = "basic",
+ html_font = "\\"Arial Narrow\\", \\"Source Sans Pro\\", sans-serif",
+ ...
+)
-kable_classic_2(kable_input, lightable_options = "basic", ...)
+kable_classic_2(
+ kable_input,
+ lightable_options = "basic",
+ html_font = "\\"Arial Narrow\\", \\"Source Sans Pro\\", sans-serif",
+ ...
+)
-kable_minimal(kable_input, lightable_options = "basic", ...)
+kable_minimal(
+ kable_input,
+ lightable_options = "basic",
+ html_font = "calibri, cambria, \\"Source Sans Pro\\", sans-serif",
+ ...
+)
-kable_material(kable_input, lightable_options = "basic", ...)
+kable_material(
+ kable_input,
+ lightable_options = "basic",
+ html_font = "\\"Source Sans Pro\\", helvetica, sans-serif",
+ ...
+)
-kable_material_dark(kable_input, lightable_options = "basic", ...)
+kable_material_dark(
+ kable_input,
+ lightable_options = "basic",
+ html_font = "\\"Source Sans Pro\\", helvetica, sans-serif",
+ ...
+)
+
+kable_paper(
+ kable_input,
+ lightable_options = "basic",
+ html_font = "\\"Arial Narrow\\", arial, helvetica, sans-serif",
+ ...
+)
}
\arguments{
\item{kable_input}{A HTML kable object.}
diff --git a/man/kable_styling.Rd b/man/kable_styling.Rd
index 4aedfaa..d95b4b8 100644
--- a/man/kable_styling.Rd
+++ b/man/kable_styling.Rd
@@ -21,7 +21,8 @@
protect_latex = TRUE,
table.envir = "table",
fixed_thead = FALSE,
- htmltable_class = NULL
+ htmltable_class = NULL,
+ html_font = NULL
)
}
\arguments{
@@ -101,6 +102,9 @@
\code{lightable-classic-2}, \code{lightable-material}, \code{lightable-striped} and
\code{lightable-hover}. If you have your customized style sheet loaded which
defines your own table class, you can also load it here.}
+
+\item{html_font}{A string for HTML css font. For example,
+\code{html_font = '"Arial Narrow", arial, helvetica, sans-serif'}.}
}
\description{
This function provides a cleaner approach to modify the style