From 72166fddfae0c7abe70e31914543cf4d6421ad4d Mon Sep 17 00:00:00 2001 From: vincentarelbundock Date: Wed, 24 Jan 2024 14:36:27 +0000 Subject: [PATCH] =?UTF-8?q?Deploying=20to=20gh-pages=20from=20@=20vincenta?= =?UTF-8?q?relbundock/tinytable@23383eef05f94309cf57d734b5db746a8d6d1aff?= =?UTF-8?q?=20=F0=9F=9A=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- man/format_tt.html | 20 +- man/tt.html | 62 +- search.json | 152 +- .../id1fni2flvoo3ua1xo1ggd.png | Bin 0 -> 5097 bytes .../id2a4klaqe10atf27clfet.png | Bin 0 -> 2558 bytes .../id3qieunzhqe317k52pvjg.png | Bin 0 -> 1127 bytes .../id4cmbn1na2rt9vunpgfma.png | Bin 0 -> 11922 bytes .../id6lmz4irqcya7pavruitm.png | Bin 0 -> 1846 bytes .../id6zgjwonflqjoodq01r27.png | Bin 0 -> 5110 bytes .../id79bbxmn5n02pj1hwj20c.png | Bin 0 -> 5067 bytes .../idahmqt0pnddbdwold80tv.png | Bin 0 -> 12212 bytes .../idd2r0a0b4tcca94f3xzoo.png | Bin 0 -> 12318 bytes .../idd5km3kmv12dfuag4mfm3.png | Bin 0 -> 512 bytes .../idhhdvtl4dibmqm3r5n3ve.png | Bin 0 -> 2072 bytes .../idj69qhh8rqwyytdhuiwdt.png | Bin 0 -> 2444 bytes .../idkn7dy7njw0oikll6j98c.png | Bin 0 -> 2076 bytes .../idlcf5dkxivnemyn3vrx5h.png | Bin 0 -> 2151 bytes .../idlwbm3c71iyzwsqzk4mk4.png | Bin 0 -> 15654 bytes .../idmv9zwr78tnf0rcmnyvgb.png | Bin 0 -> 529 bytes .../idpyn3hgemetvxzuee7zrz.png | Bin 0 -> 8399 bytes .../idtuu06llf6yfqzfnwfk6y.png | Bin 0 -> 2191 bytes .../idujkj6vhbu8mp0f2u9iep.png | Bin 0 -> 2564 bytes .../idusfumd2ri94eyz798dvi.png | Bin 0 -> 2214 bytes .../idwbgmmm7qjcc3eiv3ystm.png | Bin 0 -> 1728 bytes .../idwnapsrxa1olhr3tj5nmu.png | Bin 0 -> 548 bytes .../idxgakk323j1xble6r8www.png | Bin 0 -> 11908 bytes .../idzoav0a5yj2tyouxn2yc1.png | Bin 0 -> 1829 bytes vignettes/tutorial.html | 1616 ++++++++--------- vignettes/tutorial.pdf | Bin 1694339 -> 1694329 bytes 29 files changed, 925 insertions(+), 925 deletions(-) create mode 100644 vignettes/tinytable_assets/id1fni2flvoo3ua1xo1ggd.png create mode 100644 vignettes/tinytable_assets/id2a4klaqe10atf27clfet.png create mode 100644 vignettes/tinytable_assets/id3qieunzhqe317k52pvjg.png create mode 100644 vignettes/tinytable_assets/id4cmbn1na2rt9vunpgfma.png create mode 100644 vignettes/tinytable_assets/id6lmz4irqcya7pavruitm.png create mode 100644 vignettes/tinytable_assets/id6zgjwonflqjoodq01r27.png create mode 100644 vignettes/tinytable_assets/id79bbxmn5n02pj1hwj20c.png create mode 100644 vignettes/tinytable_assets/idahmqt0pnddbdwold80tv.png create mode 100644 vignettes/tinytable_assets/idd2r0a0b4tcca94f3xzoo.png create mode 100644 vignettes/tinytable_assets/idd5km3kmv12dfuag4mfm3.png create mode 100644 vignettes/tinytable_assets/idhhdvtl4dibmqm3r5n3ve.png create mode 100644 vignettes/tinytable_assets/idj69qhh8rqwyytdhuiwdt.png create mode 100644 vignettes/tinytable_assets/idkn7dy7njw0oikll6j98c.png create mode 100644 vignettes/tinytable_assets/idlcf5dkxivnemyn3vrx5h.png create mode 100644 vignettes/tinytable_assets/idlwbm3c71iyzwsqzk4mk4.png create mode 100644 vignettes/tinytable_assets/idmv9zwr78tnf0rcmnyvgb.png create mode 100644 vignettes/tinytable_assets/idpyn3hgemetvxzuee7zrz.png create mode 100644 vignettes/tinytable_assets/idtuu06llf6yfqzfnwfk6y.png create mode 100644 vignettes/tinytable_assets/idujkj6vhbu8mp0f2u9iep.png create mode 100644 vignettes/tinytable_assets/idusfumd2ri94eyz798dvi.png create mode 100644 vignettes/tinytable_assets/idwbgmmm7qjcc3eiv3ystm.png create mode 100644 vignettes/tinytable_assets/idwnapsrxa1olhr3tj5nmu.png create mode 100644 vignettes/tinytable_assets/idxgakk323j1xble6r8www.png create mode 100644 vignettes/tinytable_assets/idzoav0a5yj2tyouxn2yc1.png diff --git a/man/format_tt.html b/man/format_tt.html index 33bff04d..cfb9c85a 100644 --- a/man/format_tt.html +++ b/man/format_tt.html @@ -419,7 +419,7 @@

Examples

- tinytable_f9nz5de5msp8rlzbrw6w + tinytable_61yhrm2mpr2q5krb0tz9 @@ -438,7 +438,7 @@

Examples

- +
@@ -449,28 +449,28 @@

Examples

- + - - + + - - + +
10 00210 000 9 999
9 999 9 99910 00010 000
10 00110 002 9 99810 000
@@ -421,7 +421,7 @@

Examples

- +
@@ -467,12 +467,12 @@

Examples

@@ -517,7 +517,7 @@

Examples

-
+
@@ -563,12 +563,12 @@

Examples

diff --git a/search.json b/search.json index 530d1ce0..74840f01 100644 --- a/search.json +++ b/search.json @@ -1,4 +1,18 @@ [ + { + "objectID": "NEWS.html", + "href": "NEWS.html", + "title": "News", + "section": "", + "text": "Initial package release. Yay!" + }, + { + "objectID": "NEWS.html#section", + "href": "NEWS.html#section", + "title": "News", + "section": "", + "text": "Initial package release. Yay!" + }, { "objectID": "LICENSE.html", "href": "LICENSE.html", @@ -27,13 +41,6 @@ "section": "", "text": "If you develop a new program, and you want it to be of the greatest possible use to the public, the best way to achieve this is to make it free software which everyone can redistribute and change under these terms.\nTo do so, attach the following notices to the program. It is safest to attach them to the start of each source file to most effectively state the exclusion of warranty; and each file should have at least the “copyright” line and a pointer to where the full notice is found.\n<one line to give the program's name and a brief idea of what it does.>\nCopyright (C) <year> <name of author>\n\nThis program is free software: you can redistribute it and/or modify\nit under the terms of the GNU General Public License as published by\nthe Free Software Foundation, either version 3 of the License, or\n(at your option) any later version.\n\nThis program is distributed in the hope that it will be useful,\nbut WITHOUT ANY WARRANTY; without even the implied warranty of\nMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\nGNU General Public License for more details.\n\nYou should have received a copy of the GNU General Public License\nalong with this program. If not, see <http://www.gnu.org/licenses/>.\nAlso add information on how to contact you by electronic and paper mail.\nIf the program does terminal interaction, make it output a short notice like this when it starts in an interactive mode:\n<program> Copyright (C) <year> <name of author>\nThis program comes with ABSOLUTELY NO WARRANTY; for details type 'show w'.\nThis is free software, and you are welcome to redistribute it\nunder certain conditions; type 'show c' for details.\nThe hypothetical commands show w and show c should show the appropriate parts of the General Public License. Of course, your program’s commands might be different; for a GUI interface, you would use an “about box”.\nYou should also get your employer (if you work as a programmer) or school, if any, to sign a “copyright disclaimer” for the program, if necessary. For more information on this, and how to apply and follow the GNU GPL, see <http://www.gnu.org/licenses/>.\nThe GNU General Public License does not permit incorporating your program into proprietary programs. If your program is a subroutine library, you may consider it more useful to permit linking proprietary applications with the library. If this is what you want to do, use the GNU Lesser General Public License instead of this License. But first, please read <http://www.gnu.org/philosophy/why-not-lgpl.html>." }, - { - "objectID": "CITATION.html", - "href": "CITATION.html", - "title": "Citation", - "section": "", - "text": "Citation\nTo cite package ‘tinytable’ in publications use:\n\n Arel-Bundock V (????). _tinytable: Simple and Configurable Tables in\n 'HTML', 'LaTeX', 'Markdown', 'Word', and 'PNG' Formats_. R package\n version 0.0.1.9001, https://github.com/vincentarelbundock/tinytable/,\n <https://vincentarelbundock.github.io/tinytable/>.\n\nA BibTeX entry for LaTeX users is\n\n @Manual{,\n title = {tinytable: Simple and Configurable Tables in 'HTML', 'LaTeX', 'Markdown', 'Word', and 'PNG' Formats},\n author = {Vincent Arel-Bundock},\n note = {R package version 0.0.1.9001, https://github.com/vincentarelbundock/tinytable/},\n url = {https://vincentarelbundock.github.io/tinytable/},\n }" - }, { "objectID": "index.html#what", "href": "index.html#what", @@ -76,6 +83,34 @@ "section": "Footnotes", "text": "Footnotes\n\n\nOther formats like Markdown and Typst are also available, but less flexible.↩︎\nSome extra packages can be imported to access specific functionality, such as integration with Quarto, inserting ggplot2 objects as inline plots, and saving tables to PNG images or PDF documents.↩︎" }, + { + "objectID": "man/format_tt.html", + "href": "man/format_tt.html", + "title": "tinytable", + "section": "", + "text": "This function formats the columns of a data frame based on the column type (logical, date, numeric). It allows various formatting options like significant digits, decimal points, and scientific notation. It also includes custom formatting for date and boolean values.\n\n\n\nformat_tt(\n x,\n j = NULL,\n digits = getOption(\"digits\"),\n num_fmt = \"significant\",\n num_zero = TRUE,\n num_suffix = FALSE,\n num_mark_big = \"\",\n num_mark_dec = getOption(\"OutDec\", default = \".\"),\n date = \"%Y-%m-%d\",\n bool = function(column) tools::toTitleCase(tolower(column)),\n other = as.character,\n markdown = FALSE,\n sprintf = NULL\n)\n\n\n\n\n\n\n\n\nx\n\n\nA data frame or a vector to be formatted.\n\n\n\n\nj\n\n\nColumn indices where the styling should be applied. Can be a single value, a vector, or a Perl-style regular expression applied to column names of the original data frame. If colspan is used, j must be of length 1.\n\n\n\n\ndigits\n\n\nNumber of significant digits or decimal places.\n\n\n\n\nnum_fmt\n\n\nThe format for numeric values; one of ‘significant’, ‘decimal’, or ‘scientific’.\n\n\n\n\nnum_zero\n\n\nLogical; if TRUE, trailing zeros are kept in \"decimal\" format (but not in \"significant\" format).\n\n\n\n\nnum_suffix\n\n\nLogical; if TRUE display short numbers with digits significant digits and K (thousands), M (millions), B (billions), or T (trillions) suffixes.\n\n\n\n\nnum_mark_big\n\n\nCharacter to use as a thousands separator.\n\n\n\n\nnum_mark_dec\n\n\nDecimal mark character. Default is the global option ‘OutDec’.\n\n\n\n\ndate\n\n\nA string passed to the format() function, such as \"%Y-%m-%d\". See the \"Details\" section in ?strptime\n\n\n\n\nbool\n\n\nA function to format logical columns. Defaults to title case.\n\n\n\n\nother\n\n\nA function to format columns of other types. Defaults to as.character().\n\n\n\n\nmarkdown\n\n\nLogical; if TRUE, render markdown syntax in cells. Ex: italicized text is properly italicized in HTML and LaTeX.\n\n\n\n\nsprintf\n\n\nString passed to the ?sprintf function to format numbers or interpolate strings with a user-defined pattern (similar to the glue package, but using Base R).\n\n\n\n\n\n\n\nA data frame with formatted columns.\n\n\n\n\nlibrary(tinytable)\n\ndat <- data.frame(\n a = rnorm(3, mean = 10000),\n b = rnorm(3, 10000))\ntab <- format_tt(dat,\n digits = 2,\n num_mark_dec = \",\",\n num_mark_big = \" \")\ntt(tab)\n\n\n \n\n \n \n \n tinytable_61yhrm2mpr2q5krb0tz9\n \n \n \n \n \n\n \n \n \n \n \n \n a\n b\n \n \n \n \n \n 10 000\n 9 999\n \n \n 10 000\n 10 000\n \n \n 9 998\n 10 000" + }, + { + "objectID": "man/format_tt.html#format-columns-of-a-data-frame", + "href": "man/format_tt.html#format-columns-of-a-data-frame", + "title": "tinytable", + "section": "", + "text": "This function formats the columns of a data frame based on the column type (logical, date, numeric). It allows various formatting options like significant digits, decimal points, and scientific notation. It also includes custom formatting for date and boolean values.\n\n\n\nformat_tt(\n x,\n j = NULL,\n digits = getOption(\"digits\"),\n num_fmt = \"significant\",\n num_zero = TRUE,\n num_suffix = FALSE,\n num_mark_big = \"\",\n num_mark_dec = getOption(\"OutDec\", default = \".\"),\n date = \"%Y-%m-%d\",\n bool = function(column) tools::toTitleCase(tolower(column)),\n other = as.character,\n markdown = FALSE,\n sprintf = NULL\n)\n\n\n\n\n\n\n\n\nx\n\n\nA data frame or a vector to be formatted.\n\n\n\n\nj\n\n\nColumn indices where the styling should be applied. Can be a single value, a vector, or a Perl-style regular expression applied to column names of the original data frame. If colspan is used, j must be of length 1.\n\n\n\n\ndigits\n\n\nNumber of significant digits or decimal places.\n\n\n\n\nnum_fmt\n\n\nThe format for numeric values; one of ‘significant’, ‘decimal’, or ‘scientific’.\n\n\n\n\nnum_zero\n\n\nLogical; if TRUE, trailing zeros are kept in \"decimal\" format (but not in \"significant\" format).\n\n\n\n\nnum_suffix\n\n\nLogical; if TRUE display short numbers with digits significant digits and K (thousands), M (millions), B (billions), or T (trillions) suffixes.\n\n\n\n\nnum_mark_big\n\n\nCharacter to use as a thousands separator.\n\n\n\n\nnum_mark_dec\n\n\nDecimal mark character. Default is the global option ‘OutDec’.\n\n\n\n\ndate\n\n\nA string passed to the format() function, such as \"%Y-%m-%d\". See the \"Details\" section in ?strptime\n\n\n\n\nbool\n\n\nA function to format logical columns. Defaults to title case.\n\n\n\n\nother\n\n\nA function to format columns of other types. Defaults to as.character().\n\n\n\n\nmarkdown\n\n\nLogical; if TRUE, render markdown syntax in cells. Ex: italicized text is properly italicized in HTML and LaTeX.\n\n\n\n\nsprintf\n\n\nString passed to the ?sprintf function to format numbers or interpolate strings with a user-defined pattern (similar to the glue package, but using Base R).\n\n\n\n\n\n\n\nA data frame with formatted columns.\n\n\n\n\nlibrary(tinytable)\n\ndat <- data.frame(\n a = rnorm(3, mean = 10000),\n b = rnorm(3, 10000))\ntab <- format_tt(dat,\n digits = 2,\n num_mark_dec = \",\",\n num_mark_big = \" \")\ntt(tab)\n\n\n \n\n \n \n \n tinytable_61yhrm2mpr2q5krb0tz9\n \n \n \n \n \n\n \n \n \n \n \n \n a\n b\n \n \n \n \n \n 10 000\n 9 999\n \n \n 10 000\n 10 000\n \n \n 9 998\n 10 000" + }, + { + "objectID": "man/save_tt.html", + "href": "man/save_tt.html", + "title": "tinytable", + "section": "", + "text": "This function saves an object of class tinytable to a specified file and format, with an option to overwrite existing files.\n\n\n\nsave_tt(x, output, overwrite = FALSE)\n\n\n\n\n\n\n\n\nx\n\n\nThe tinytable object to be saved.\n\n\n\n\noutput\n\n\nString or file path.\n\n\nIf output is \"markdown\", \"latex\", or \"html\", the table is returned in a string as an R object.\n\n\nIf output is a valid file path, the table is saved to file. The supported extensions are: .docx, .html, .png, .pdf, .tex and .md (with aliases .txt, .Rmd and .qmd).\n\n\nWarning: style_tt() does not work for Markdown or Word tables.\n\n\n\n\n\n\noverwrite\n\n\nA logical value indicating whether to overwrite an existing file.\n\n\n\n\n\n\n\nA string or TRUE when the table is written to file.\n\n\n\n\nlibrary(tinytable)\n\n\nlibrary(tinytable)\nfilename <- file.path(tempdir(), \"table.tex\")\ntt(mtcars[1:4, 1:4]) |> save_tt(filename)" + }, + { + "objectID": "man/save_tt.html#save-a-tiny-table-to-file", + "href": "man/save_tt.html#save-a-tiny-table-to-file", + "title": "tinytable", + "section": "", + "text": "This function saves an object of class tinytable to a specified file and format, with an option to overwrite existing files.\n\n\n\nsave_tt(x, output, overwrite = FALSE)\n\n\n\n\n\n\n\n\nx\n\n\nThe tinytable object to be saved.\n\n\n\n\noutput\n\n\nString or file path.\n\n\nIf output is \"markdown\", \"latex\", or \"html\", the table is returned in a string as an R object.\n\n\nIf output is a valid file path, the table is saved to file. The supported extensions are: .docx, .html, .png, .pdf, .tex and .md (with aliases .txt, .Rmd and .qmd).\n\n\nWarning: style_tt() does not work for Markdown or Word tables.\n\n\n\n\n\n\noverwrite\n\n\nA logical value indicating whether to overwrite an existing file.\n\n\n\n\n\n\n\nA string or TRUE when the table is written to file.\n\n\n\n\nlibrary(tinytable)\n\n\nlibrary(tinytable)\nfilename <- file.path(tempdir(), \"table.tex\")\ntt(mtcars[1:4, 1:4]) |> save_tt(filename)" + }, { "objectID": "man/group_tt.html", "href": "man/group_tt.html", @@ -91,18 +126,18 @@ "text": "Spanning labels to identify groups of rows or columns\n\n\n\ngroup_tt(x, i = NULL, j = NULL, indent = 1)\n\n\n\n\n\n\n\n\nx\n\n\nA data frame or data table to be rendered as a table.\n\n\n\n\ni\n\n\nRow indices where the styling should be applied. Can be a single value or a vector. i=0 is the header, and negative values are higher level headers. If colspan is used, i must be of length 1.\n\n\n\n\nj\n\n\nColumn indices where the styling should be applied. Can be a single value, a vector, or a Perl-style regular expression applied to column names of the original data frame. If colspan is used, j must be of length 1.\n\n\n\n\nindent\n\n\ninteger number of pt to use when indenting the non-labelled rows.\n\n\n\n\n\n\n\nAn object of class tt representing the table." }, { - "objectID": "man/format_tt.html", - "href": "man/format_tt.html", + "objectID": "man/style_tt.html", + "href": "man/style_tt.html", "title": "tinytable", "section": "", - "text": "This function formats the columns of a data frame based on the column type (logical, date, numeric). It allows various formatting options like significant digits, decimal points, and scientific notation. It also includes custom formatting for date and boolean values.\n\n\n\nformat_tt(\n x,\n j = NULL,\n digits = getOption(\"digits\"),\n num_fmt = \"significant\",\n num_zero = TRUE,\n num_suffix = FALSE,\n num_mark_big = \"\",\n num_mark_dec = getOption(\"OutDec\", default = \".\"),\n date = \"%Y-%m-%d\",\n bool = function(column) tools::toTitleCase(tolower(column)),\n other = as.character,\n markdown = FALSE,\n sprintf = NULL\n)\n\n\n\n\n\n\n\n\nx\n\n\nA data frame or a vector to be formatted.\n\n\n\n\nj\n\n\nColumn indices where the styling should be applied. Can be a single value, a vector, or a Perl-style regular expression applied to column names of the original data frame. If colspan is used, j must be of length 1.\n\n\n\n\ndigits\n\n\nNumber of significant digits or decimal places.\n\n\n\n\nnum_fmt\n\n\nThe format for numeric values; one of ‘significant’, ‘decimal’, or ‘scientific’.\n\n\n\n\nnum_zero\n\n\nLogical; if TRUE, trailing zeros are kept in \"decimal\" format (but not in \"significant\" format).\n\n\n\n\nnum_suffix\n\n\nLogical; if TRUE display short numbers with digits significant digits and K (thousands), M (millions), B (billions), or T (trillions) suffixes.\n\n\n\n\nnum_mark_big\n\n\nCharacter to use as a thousands separator.\n\n\n\n\nnum_mark_dec\n\n\nDecimal mark character. Default is the global option ‘OutDec’.\n\n\n\n\ndate\n\n\nA string passed to the format() function, such as \"%Y-%m-%d\". See the \"Details\" section in ?strptime\n\n\n\n\nbool\n\n\nA function to format logical columns. Defaults to title case.\n\n\n\n\nother\n\n\nA function to format columns of other types. Defaults to as.character().\n\n\n\n\nmarkdown\n\n\nLogical; if TRUE, render markdown syntax in cells. Ex: italicized text is properly italicized in HTML and LaTeX.\n\n\n\n\nsprintf\n\n\nString passed to the ?sprintf function to format numbers or interpolate strings with a user-defined pattern (similar to the glue package, but using Base R).\n\n\n\n\n\n\n\nA data frame with formatted columns.\n\n\n\n\nlibrary(tinytable)\n\ndat <- data.frame(\n a = rnorm(3, mean = 10000),\n b = rnorm(3, 10000))\ntab <- format_tt(dat,\n digits = 2,\n num_mark_dec = \",\",\n num_mark_big = \" \")\ntt(tab)\n\n\n \n\n \n \n \n tinytable_f9nz5de5msp8rlzbrw6w\n \n \n \n \n \n\n \n \n \n \n \n \n a\n b\n \n \n \n \n \n 10 002\n 9 999\n \n \n 9 999\n 9 999\n \n \n 10 001\n 10 002" + "text": "Style a Tiny Table in either LaTeX or HTML format\n\n\n\n\nstyle_tt(\n x,\n i = NULL,\n j = NULL,\n bold = FALSE,\n italic = FALSE,\n monospace = FALSE,\n underline = FALSE,\n strikeout = FALSE,\n color = NULL,\n background = NULL,\n fontsize = NULL,\n width = NULL,\n align = NULL,\n colspan = NULL,\n indent = 0,\n tabularray_inner = NULL,\n tabularray_outer = NULL,\n bootstrap_class = \"table\",\n bootstrap_css = NULL,\n bootstrap_css_rule = NULL,\n ...\n)\n\n\n\n\n\n\n\n\nx\n\n\nA table object created by tt().\n\n\n\n\ni\n\n\nRow indices where the styling should be applied. Can be a single value or a vector. i=0 is the header, and negative values are higher level headers. If colspan is used, i must be of length 1.\n\n\n\n\nj\n\n\nColumn indices where the styling should be applied. Can be a single value, a vector, or a Perl-style regular expression applied to column names of the original data frame. If colspan is used, j must be of length 1.\n\n\n\n\nbold\n\n\nLogical; if TRUE, text is styled in bold.\n\n\n\n\nitalic\n\n\nLogical; if TRUE, text is styled in italic.\n\n\n\n\nmonospace\n\n\nLogical; if TRUE, text is styled in monospace font.\n\n\n\n\nunderline\n\n\nLogical; if TRUE, text is underlined.\n\n\n\n\nstrikeout\n\n\nLogical; if TRUE, text has a strike through line.\n\n\n\n\ncolor\n\n\nText color. There are several ways to specify colors, depending on the output format.\n\n\nHTML:\n\n\nHex code composed of # and 6 characters, ex: #CC79A7.\n\n\nKeywords: black, silver, gray, white, maroon, red, purple, fuchsia, green, lime, olive, yellow, navy, blue, teal, aqua\n\n\n\n\nLaTeX:\n\n\nHex code composed of # and 6 characters, ex: \"#CC79A7\". See the section below for instructions to add in LaTeX preambles.\n\n\nKeywords: black, blue, brown, cyan, darkgray, gray, green, lightgray, lime, magenta, olive, orange, pink, purple, red, teal, violet, white, yellow.\n\n\nColor blending using xcolor, ex: white!80!blue, green!20!red’.\n\n\nColor names with luminance levels from the ninecolors package (ex: \"azure4\", \"magenta8\", \"teal2\", \"gray1\", \"olive3\").\n\n\n\n\n\n\n\n\nbackground\n\n\nBackground color. Specified as a color name or hexadecimal code. Can be NULL for default color.\n\n\n\n\nfontsize\n\n\nInteger Font size in pt units.\n\n\n\n\nwidth\n\n\nWidth of the cell or column. Can be NULL for default width.\n\n\n\n\nalign\n\n\nA single character or a string with a number of characters equal to the number of columns in j. Valid characters include ‘c’ (center), ‘l’ (left), or ‘r’ (right).\n\n\n\n\ncolspan\n\n\nNumber of columns a cell should span. Can only be used if both i and j are of length 1. Must be an integer greater than 1.\n\n\n\n\nindent\n\n\nText indentation in em units. Positive values only.\n\n\n\n\ntabularray_inner\n\n\nA string that specifies the \"inner\" settings of a tabularray LaTeX table.\n\n\n\n\ntabularray_outer\n\n\nA string that specifies the \"outer\" settings of a tabularray LaTeX table.\n\n\n\n\nbootstrap_class\n\n\nString. A Bootstrap table class such as “table”, “table table-dark” or “table table-dark table-hover”. See the bootstrap documentation.\n\n\n\n\nbootstrap_css\n\n\nA vector of CSS style declarations to be applied (ex: “font-weight: bold”). Each element corresponds to a cell defined by i and j.\n\n\n\n\nbootstrap_css_rule\n\n\nA string with complete CSS rules that apply to the table class specified using the theme argument of the tt() function.\n\n\n\n\n…\n\n\nextra arguments are ignored\n\n\n\n\n\n\n\nThis function applies styling to a table created by tt(). It allows customization of text style (bold, italic, monospace), text and background colors, font size, cell width, text alignment, column span, and indentation. The function supports both LaTeX (tabularray) and HTML (bootstrap) formats.\nNote that Markdown and Word formats are limited to these styles: italic, bold, strikeout.\n\n\n\nAn object of class tt representing the table.\n\n\n\nWhen rendering Quarto and Rmarkdown documents, tinytable will populate the LaTeX preamble automatically with all the required packages. For standalone LaTeX packages, these commands should be inserted in the preamble:\n\n\n\\usepackage{tabularray}\n\\usepackage{float}\n\\usepackage{graphicx}\n\\usepackage{codehigh}\n\\usepackage[normalem]{ulem}\n\\UseTblrLibrary{booktabs}\n\\newcommand{\\tinytableTabularrayUnderline}[1]{\\underline{#1}}\n\\newcommand{\\tinytableTabularrayStrikeout}[1]{\\sout{#1}}\n\\NewTableCommand{\\tinytableDefineColor}[3]{\\definecolor{#1}{#2}{#3}}\n\n\n\n\n\n\nlibrary(tinytable)\n\nlibrary(tinytable)\nx <- mtcars[1:5, 1:5]\ntab <- tt(x)\ntab <- style_tt(tab, j = 1:5, align = \"lcccr\")\ntab <- style_tt(tab, i = 2:3,\n background = \"black\", color = \"orange\", bold = TRUE)" }, { - "objectID": "man/format_tt.html#format-columns-of-a-data-frame", - "href": "man/format_tt.html#format-columns-of-a-data-frame", + "objectID": "man/style_tt.html#style-a-tiny-table-in-either-latex-or-html-format", + "href": "man/style_tt.html#style-a-tiny-table-in-either-latex-or-html-format", "title": "tinytable", "section": "", - "text": "This function formats the columns of a data frame based on the column type (logical, date, numeric). It allows various formatting options like significant digits, decimal points, and scientific notation. It also includes custom formatting for date and boolean values.\n\n\n\nformat_tt(\n x,\n j = NULL,\n digits = getOption(\"digits\"),\n num_fmt = \"significant\",\n num_zero = TRUE,\n num_suffix = FALSE,\n num_mark_big = \"\",\n num_mark_dec = getOption(\"OutDec\", default = \".\"),\n date = \"%Y-%m-%d\",\n bool = function(column) tools::toTitleCase(tolower(column)),\n other = as.character,\n markdown = FALSE,\n sprintf = NULL\n)\n\n\n\n\n\n\n\n\nx\n\n\nA data frame or a vector to be formatted.\n\n\n\n\nj\n\n\nColumn indices where the styling should be applied. Can be a single value, a vector, or a Perl-style regular expression applied to column names of the original data frame. If colspan is used, j must be of length 1.\n\n\n\n\ndigits\n\n\nNumber of significant digits or decimal places.\n\n\n\n\nnum_fmt\n\n\nThe format for numeric values; one of ‘significant’, ‘decimal’, or ‘scientific’.\n\n\n\n\nnum_zero\n\n\nLogical; if TRUE, trailing zeros are kept in \"decimal\" format (but not in \"significant\" format).\n\n\n\n\nnum_suffix\n\n\nLogical; if TRUE display short numbers with digits significant digits and K (thousands), M (millions), B (billions), or T (trillions) suffixes.\n\n\n\n\nnum_mark_big\n\n\nCharacter to use as a thousands separator.\n\n\n\n\nnum_mark_dec\n\n\nDecimal mark character. Default is the global option ‘OutDec’.\n\n\n\n\ndate\n\n\nA string passed to the format() function, such as \"%Y-%m-%d\". See the \"Details\" section in ?strptime\n\n\n\n\nbool\n\n\nA function to format logical columns. Defaults to title case.\n\n\n\n\nother\n\n\nA function to format columns of other types. Defaults to as.character().\n\n\n\n\nmarkdown\n\n\nLogical; if TRUE, render markdown syntax in cells. Ex: italicized text is properly italicized in HTML and LaTeX.\n\n\n\n\nsprintf\n\n\nString passed to the ?sprintf function to format numbers or interpolate strings with a user-defined pattern (similar to the glue package, but using Base R).\n\n\n\n\n\n\n\nA data frame with formatted columns.\n\n\n\n\nlibrary(tinytable)\n\ndat <- data.frame(\n a = rnorm(3, mean = 10000),\n b = rnorm(3, 10000))\ntab <- format_tt(dat,\n digits = 2,\n num_mark_dec = \",\",\n num_mark_big = \" \")\ntt(tab)\n\n\n \n\n \n \n \n tinytable_f9nz5de5msp8rlzbrw6w\n \n \n \n \n \n\n \n \n \n \n \n \n a\n b\n \n \n \n \n \n 10 002\n 9 999\n \n \n 9 999\n 9 999\n \n \n 10 001\n 10 002" + "text": "Style a Tiny Table in either LaTeX or HTML format\n\n\n\n\nstyle_tt(\n x,\n i = NULL,\n j = NULL,\n bold = FALSE,\n italic = FALSE,\n monospace = FALSE,\n underline = FALSE,\n strikeout = FALSE,\n color = NULL,\n background = NULL,\n fontsize = NULL,\n width = NULL,\n align = NULL,\n colspan = NULL,\n indent = 0,\n tabularray_inner = NULL,\n tabularray_outer = NULL,\n bootstrap_class = \"table\",\n bootstrap_css = NULL,\n bootstrap_css_rule = NULL,\n ...\n)\n\n\n\n\n\n\n\n\nx\n\n\nA table object created by tt().\n\n\n\n\ni\n\n\nRow indices where the styling should be applied. Can be a single value or a vector. i=0 is the header, and negative values are higher level headers. If colspan is used, i must be of length 1.\n\n\n\n\nj\n\n\nColumn indices where the styling should be applied. Can be a single value, a vector, or a Perl-style regular expression applied to column names of the original data frame. If colspan is used, j must be of length 1.\n\n\n\n\nbold\n\n\nLogical; if TRUE, text is styled in bold.\n\n\n\n\nitalic\n\n\nLogical; if TRUE, text is styled in italic.\n\n\n\n\nmonospace\n\n\nLogical; if TRUE, text is styled in monospace font.\n\n\n\n\nunderline\n\n\nLogical; if TRUE, text is underlined.\n\n\n\n\nstrikeout\n\n\nLogical; if TRUE, text has a strike through line.\n\n\n\n\ncolor\n\n\nText color. There are several ways to specify colors, depending on the output format.\n\n\nHTML:\n\n\nHex code composed of # and 6 characters, ex: #CC79A7.\n\n\nKeywords: black, silver, gray, white, maroon, red, purple, fuchsia, green, lime, olive, yellow, navy, blue, teal, aqua\n\n\n\n\nLaTeX:\n\n\nHex code composed of # and 6 characters, ex: \"#CC79A7\". See the section below for instructions to add in LaTeX preambles.\n\n\nKeywords: black, blue, brown, cyan, darkgray, gray, green, lightgray, lime, magenta, olive, orange, pink, purple, red, teal, violet, white, yellow.\n\n\nColor blending using xcolor, ex: white!80!blue, green!20!red’.\n\n\nColor names with luminance levels from the ninecolors package (ex: \"azure4\", \"magenta8\", \"teal2\", \"gray1\", \"olive3\").\n\n\n\n\n\n\n\n\nbackground\n\n\nBackground color. Specified as a color name or hexadecimal code. Can be NULL for default color.\n\n\n\n\nfontsize\n\n\nInteger Font size in pt units.\n\n\n\n\nwidth\n\n\nWidth of the cell or column. Can be NULL for default width.\n\n\n\n\nalign\n\n\nA single character or a string with a number of characters equal to the number of columns in j. Valid characters include ‘c’ (center), ‘l’ (left), or ‘r’ (right).\n\n\n\n\ncolspan\n\n\nNumber of columns a cell should span. Can only be used if both i and j are of length 1. Must be an integer greater than 1.\n\n\n\n\nindent\n\n\nText indentation in em units. Positive values only.\n\n\n\n\ntabularray_inner\n\n\nA string that specifies the \"inner\" settings of a tabularray LaTeX table.\n\n\n\n\ntabularray_outer\n\n\nA string that specifies the \"outer\" settings of a tabularray LaTeX table.\n\n\n\n\nbootstrap_class\n\n\nString. A Bootstrap table class such as “table”, “table table-dark” or “table table-dark table-hover”. See the bootstrap documentation.\n\n\n\n\nbootstrap_css\n\n\nA vector of CSS style declarations to be applied (ex: “font-weight: bold”). Each element corresponds to a cell defined by i and j.\n\n\n\n\nbootstrap_css_rule\n\n\nA string with complete CSS rules that apply to the table class specified using the theme argument of the tt() function.\n\n\n\n\n…\n\n\nextra arguments are ignored\n\n\n\n\n\n\n\nThis function applies styling to a table created by tt(). It allows customization of text style (bold, italic, monospace), text and background colors, font size, cell width, text alignment, column span, and indentation. The function supports both LaTeX (tabularray) and HTML (bootstrap) formats.\nNote that Markdown and Word formats are limited to these styles: italic, bold, strikeout.\n\n\n\nAn object of class tt representing the table.\n\n\n\nWhen rendering Quarto and Rmarkdown documents, tinytable will populate the LaTeX preamble automatically with all the required packages. For standalone LaTeX packages, these commands should be inserted in the preamble:\n\n\n\\usepackage{tabularray}\n\\usepackage{float}\n\\usepackage{graphicx}\n\\usepackage{codehigh}\n\\usepackage[normalem]{ulem}\n\\UseTblrLibrary{booktabs}\n\\newcommand{\\tinytableTabularrayUnderline}[1]{\\underline{#1}}\n\\newcommand{\\tinytableTabularrayStrikeout}[1]{\\sout{#1}}\n\\NewTableCommand{\\tinytableDefineColor}[3]{\\definecolor{#1}{#2}{#3}}\n\n\n\n\n\n\nlibrary(tinytable)\n\nlibrary(tinytable)\nx <- mtcars[1:5, 1:5]\ntab <- tt(x)\ntab <- style_tt(tab, j = 1:5, align = \"lcccr\")\ntab <- style_tt(tab, i = 2:3,\n background = \"black\", color = \"orange\", bold = TRUE)" }, { "objectID": "man/plot_tt.html", @@ -123,42 +158,21 @@ "href": "man/tt.html", "title": "tinytable", "section": "", - "text": "The tt function renders a table in different formats (HTML, Markdown, or LaTeX) with various styling options. The table can be customized with additional functions:\n\n\nstyle_tt() to style fonts, colors, alignment, etc.\n\n\nformat_tt() to format numbers, dates, strings, etc.\n\n\nsave_tt() to save the table to a file or return the table as a string.\n\n\ntinytable attempts to determine the appropriate way to print the table based on interactive use, RStudio availability, and output format in RMarkdown or Quarto documents. Users can call print(x, output=“markdown”) to print the table in a specific format. Alternatively, they can set a global option: options(“tinytable_print_output”=“markdown”)\n\n\n\n\ntt(\n x,\n digits = NULL,\n caption = NULL,\n width = NULL,\n notes = NULL,\n theme = \"default\",\n placement = getOption(\"tinytable_tabularray_placement\", default = NULL)\n)\n\n\n\n\n\n\n\n\nx\n\n\nA data frame or data table to be rendered as a table.\n\n\n\n\ndigits\n\n\nNumber of significant digits to keep for numeric variables. When digits is an integer, tt() calls format_tt(x, digits = digits) before proceeding to draw the table. Users who need more control can proceed in two steps: (1) format the data with format_tt() or other functions, and (2) pass the formatted data to tt() for drawing. See ?format_tt for more details on formating options (ex: decimal, scientific notation, dates, boolean variables, etc.).\n\n\n\n\ncaption\n\n\nA string that will be used as the caption of the table.\n\n\n\n\nwidth\n\n\nA numeric value between 0 and 1 indicating the proportion of the line width that the table should cover.\n\n\n\n\nnotes\n\n\nA single string or a (named) list of strings to append at the bottom of the table.\n\n\n\n\ntheme\n\n\nThe theme to apply to the table.\n\n\nLaTeX: \"default\", \"striped\", \"void\", or \"grid\".\n\n\nHTML: \"default\", \"striped\", \"void\", \"grid\", or a (composite)\n\n\n\n\n\n\nplacement\n\n\nA string to control the position of tables in LaTeX. Will be inserted in square brackets like: \\begin{table}[H]\n\n\n\n\n\n\n\nAn object of class tt representing the table.\n\n\n\nWhen rendering Quarto and Rmarkdown documents, tinytable will populate the LaTeX preamble automatically with all the required packages. For standalone LaTeX packages, these commands should be inserted in the preamble:\n\n\n\\usepackage{tabularray}\n\\usepackage{float}\n\\usepackage{graphicx}\n\\usepackage{codehigh}\n\\usepackage[normalem]{ulem}\n\\UseTblrLibrary{booktabs}\n\\newcommand{\\tinytableTabularrayUnderline}[1]{\\underline{#1}}\n\\newcommand{\\tinytableTabularrayStrikeout}[1]{\\sout{#1}}\n\\NewTableCommand{\\tinytableDefineColor}[3]{\\definecolor{#1}{#2}{#3}}\n\n\n\n\n\n\nlibrary(tinytable)\n\nlibrary(tinytable)\nx <- mtcars[1:4, 1:5]\n\ntt(x)\n\n\n \n\n \n \n \n tinytable_41b6klljz6cet9ersw00\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\ntt(x,\n theme = \"striped\",\n width = 0.5,\n caption = \"Data about cars.\")\n\n\n \n\n \n \n \n tinytable_42u7adzbm3flwx4h9ye9\n \n \n \n \n \n\n \n \n \n \n Data about cars.\n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" + "text": "The tt function renders a table in different formats (HTML, Markdown, or LaTeX) with various styling options. The table can be customized with additional functions:\n\n\nstyle_tt() to style fonts, colors, alignment, etc.\n\n\nformat_tt() to format numbers, dates, strings, etc.\n\n\nsave_tt() to save the table to a file or return the table as a string.\n\n\ntinytable attempts to determine the appropriate way to print the table based on interactive use, RStudio availability, and output format in RMarkdown or Quarto documents. Users can call print(x, output=“markdown”) to print the table in a specific format. Alternatively, they can set a global option: options(“tinytable_print_output”=“markdown”)\n\n\n\n\ntt(\n x,\n digits = NULL,\n caption = NULL,\n width = NULL,\n notes = NULL,\n theme = \"default\",\n placement = getOption(\"tinytable_tabularray_placement\", default = NULL)\n)\n\n\n\n\n\n\n\n\nx\n\n\nA data frame or data table to be rendered as a table.\n\n\n\n\ndigits\n\n\nNumber of significant digits to keep for numeric variables. When digits is an integer, tt() calls format_tt(x, digits = digits) before proceeding to draw the table. Users who need more control can proceed in two steps: (1) format the data with format_tt() or other functions, and (2) pass the formatted data to tt() for drawing. See ?format_tt for more details on formating options (ex: decimal, scientific notation, dates, boolean variables, etc.).\n\n\n\n\ncaption\n\n\nA string that will be used as the caption of the table.\n\n\n\n\nwidth\n\n\nA numeric value between 0 and 1 indicating the proportion of the line width that the table should cover.\n\n\n\n\nnotes\n\n\nA single string or a (named) list of strings to append at the bottom of the table.\n\n\n\n\ntheme\n\n\nThe theme to apply to the table.\n\n\nLaTeX: \"default\", \"striped\", \"void\", or \"grid\".\n\n\nHTML: \"default\", \"striped\", \"void\", \"grid\", or a (composite)\n\n\n\n\n\n\nplacement\n\n\nA string to control the position of tables in LaTeX. Will be inserted in square brackets like: \\begin{table}[H]\n\n\n\n\n\n\n\nAn object of class tt representing the table.\n\n\n\nWhen rendering Quarto and Rmarkdown documents, tinytable will populate the LaTeX preamble automatically with all the required packages. For standalone LaTeX packages, these commands should be inserted in the preamble:\n\n\n\\usepackage{tabularray}\n\\usepackage{float}\n\\usepackage{graphicx}\n\\usepackage{codehigh}\n\\usepackage[normalem]{ulem}\n\\UseTblrLibrary{booktabs}\n\\newcommand{\\tinytableTabularrayUnderline}[1]{\\underline{#1}}\n\\newcommand{\\tinytableTabularrayStrikeout}[1]{\\sout{#1}}\n\\NewTableCommand{\\tinytableDefineColor}[3]{\\definecolor{#1}{#2}{#3}}\n\n\n\n\n\n\nlibrary(tinytable)\n\nlibrary(tinytable)\nx <- mtcars[1:4, 1:5]\n\ntt(x)\n\n\n \n\n \n \n \n tinytable_93733hll72af1zkiidg8\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\ntt(x,\n theme = \"striped\",\n width = 0.5,\n caption = \"Data about cars.\")\n\n\n \n\n \n \n \n tinytable_ketsnpxoiaulig4pgaqh\n \n \n \n \n \n\n \n \n \n \n Data about cars.\n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" }, { "objectID": "man/tt.html#draw-a-tiny-table", "href": "man/tt.html#draw-a-tiny-table", "title": "tinytable", "section": "", - "text": "The tt function renders a table in different formats (HTML, Markdown, or LaTeX) with various styling options. The table can be customized with additional functions:\n\n\nstyle_tt() to style fonts, colors, alignment, etc.\n\n\nformat_tt() to format numbers, dates, strings, etc.\n\n\nsave_tt() to save the table to a file or return the table as a string.\n\n\ntinytable attempts to determine the appropriate way to print the table based on interactive use, RStudio availability, and output format in RMarkdown or Quarto documents. Users can call print(x, output=“markdown”) to print the table in a specific format. Alternatively, they can set a global option: options(“tinytable_print_output”=“markdown”)\n\n\n\n\ntt(\n x,\n digits = NULL,\n caption = NULL,\n width = NULL,\n notes = NULL,\n theme = \"default\",\n placement = getOption(\"tinytable_tabularray_placement\", default = NULL)\n)\n\n\n\n\n\n\n\n\nx\n\n\nA data frame or data table to be rendered as a table.\n\n\n\n\ndigits\n\n\nNumber of significant digits to keep for numeric variables. When digits is an integer, tt() calls format_tt(x, digits = digits) before proceeding to draw the table. Users who need more control can proceed in two steps: (1) format the data with format_tt() or other functions, and (2) pass the formatted data to tt() for drawing. See ?format_tt for more details on formating options (ex: decimal, scientific notation, dates, boolean variables, etc.).\n\n\n\n\ncaption\n\n\nA string that will be used as the caption of the table.\n\n\n\n\nwidth\n\n\nA numeric value between 0 and 1 indicating the proportion of the line width that the table should cover.\n\n\n\n\nnotes\n\n\nA single string or a (named) list of strings to append at the bottom of the table.\n\n\n\n\ntheme\n\n\nThe theme to apply to the table.\n\n\nLaTeX: \"default\", \"striped\", \"void\", or \"grid\".\n\n\nHTML: \"default\", \"striped\", \"void\", \"grid\", or a (composite)\n\n\n\n\n\n\nplacement\n\n\nA string to control the position of tables in LaTeX. Will be inserted in square brackets like: \\begin{table}[H]\n\n\n\n\n\n\n\nAn object of class tt representing the table.\n\n\n\nWhen rendering Quarto and Rmarkdown documents, tinytable will populate the LaTeX preamble automatically with all the required packages. For standalone LaTeX packages, these commands should be inserted in the preamble:\n\n\n\\usepackage{tabularray}\n\\usepackage{float}\n\\usepackage{graphicx}\n\\usepackage{codehigh}\n\\usepackage[normalem]{ulem}\n\\UseTblrLibrary{booktabs}\n\\newcommand{\\tinytableTabularrayUnderline}[1]{\\underline{#1}}\n\\newcommand{\\tinytableTabularrayStrikeout}[1]{\\sout{#1}}\n\\NewTableCommand{\\tinytableDefineColor}[3]{\\definecolor{#1}{#2}{#3}}\n\n\n\n\n\n\nlibrary(tinytable)\n\nlibrary(tinytable)\nx <- mtcars[1:4, 1:5]\n\ntt(x)\n\n\n \n\n \n \n \n tinytable_41b6klljz6cet9ersw00\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\ntt(x,\n theme = \"striped\",\n width = 0.5,\n caption = \"Data about cars.\")\n\n\n \n\n \n \n \n tinytable_42u7adzbm3flwx4h9ye9\n \n \n \n \n \n\n \n \n \n \n Data about cars.\n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" - }, - { - "objectID": "man/save_tt.html", - "href": "man/save_tt.html", - "title": "tinytable", - "section": "", - "text": "This function saves an object of class tinytable to a specified file and format, with an option to overwrite existing files.\n\n\n\nsave_tt(x, output, overwrite = FALSE)\n\n\n\n\n\n\n\n\nx\n\n\nThe tinytable object to be saved.\n\n\n\n\noutput\n\n\nString or file path.\n\n\nIf output is \"markdown\", \"latex\", or \"html\", the table is returned in a string as an R object.\n\n\nIf output is a valid file path, the table is saved to file. The supported extensions are: .docx, .html, .png, .pdf, .tex and .md (with aliases .txt, .Rmd and .qmd).\n\n\nWarning: style_tt() does not work for Markdown or Word tables.\n\n\n\n\n\n\noverwrite\n\n\nA logical value indicating whether to overwrite an existing file.\n\n\n\n\n\n\n\nA string or TRUE when the table is written to file.\n\n\n\n\nlibrary(tinytable)\n\n\nlibrary(tinytable)\nfilename <- file.path(tempdir(), \"table.tex\")\ntt(mtcars[1:4, 1:4]) |> save_tt(filename)" - }, - { - "objectID": "man/save_tt.html#save-a-tiny-table-to-file", - "href": "man/save_tt.html#save-a-tiny-table-to-file", - "title": "tinytable", - "section": "", - "text": "This function saves an object of class tinytable to a specified file and format, with an option to overwrite existing files.\n\n\n\nsave_tt(x, output, overwrite = FALSE)\n\n\n\n\n\n\n\n\nx\n\n\nThe tinytable object to be saved.\n\n\n\n\noutput\n\n\nString or file path.\n\n\nIf output is \"markdown\", \"latex\", or \"html\", the table is returned in a string as an R object.\n\n\nIf output is a valid file path, the table is saved to file. The supported extensions are: .docx, .html, .png, .pdf, .tex and .md (with aliases .txt, .Rmd and .qmd).\n\n\nWarning: style_tt() does not work for Markdown or Word tables.\n\n\n\n\n\n\noverwrite\n\n\nA logical value indicating whether to overwrite an existing file.\n\n\n\n\n\n\n\nA string or TRUE when the table is written to file.\n\n\n\n\nlibrary(tinytable)\n\n\nlibrary(tinytable)\nfilename <- file.path(tempdir(), \"table.tex\")\ntt(mtcars[1:4, 1:4]) |> save_tt(filename)" - }, - { - "objectID": "man/style_tt.html", - "href": "man/style_tt.html", - "title": "tinytable", - "section": "", - "text": "Style a Tiny Table in either LaTeX or HTML format\n\n\n\n\nstyle_tt(\n x,\n i = NULL,\n j = NULL,\n bold = FALSE,\n italic = FALSE,\n monospace = FALSE,\n underline = FALSE,\n strikeout = FALSE,\n color = NULL,\n background = NULL,\n fontsize = NULL,\n width = NULL,\n align = NULL,\n colspan = NULL,\n indent = 0,\n tabularray_inner = NULL,\n tabularray_outer = NULL,\n bootstrap_class = \"table\",\n bootstrap_css = NULL,\n bootstrap_css_rule = NULL,\n ...\n)\n\n\n\n\n\n\n\n\nx\n\n\nA table object created by tt().\n\n\n\n\ni\n\n\nRow indices where the styling should be applied. Can be a single value or a vector. i=0 is the header, and negative values are higher level headers. If colspan is used, i must be of length 1.\n\n\n\n\nj\n\n\nColumn indices where the styling should be applied. Can be a single value, a vector, or a Perl-style regular expression applied to column names of the original data frame. If colspan is used, j must be of length 1.\n\n\n\n\nbold\n\n\nLogical; if TRUE, text is styled in bold.\n\n\n\n\nitalic\n\n\nLogical; if TRUE, text is styled in italic.\n\n\n\n\nmonospace\n\n\nLogical; if TRUE, text is styled in monospace font.\n\n\n\n\nunderline\n\n\nLogical; if TRUE, text is underlined.\n\n\n\n\nstrikeout\n\n\nLogical; if TRUE, text has a strike through line.\n\n\n\n\ncolor\n\n\nText color. There are several ways to specify colors, depending on the output format.\n\n\nHTML:\n\n\nHex code composed of # and 6 characters, ex: #CC79A7.\n\n\nKeywords: black, silver, gray, white, maroon, red, purple, fuchsia, green, lime, olive, yellow, navy, blue, teal, aqua\n\n\n\n\nLaTeX:\n\n\nHex code composed of # and 6 characters, ex: \"#CC79A7\". See the section below for instructions to add in LaTeX preambles.\n\n\nKeywords: black, blue, brown, cyan, darkgray, gray, green, lightgray, lime, magenta, olive, orange, pink, purple, red, teal, violet, white, yellow.\n\n\nColor blending using xcolor, ex: white!80!blue, green!20!red’.\n\n\nColor names with luminance levels from the ninecolors package (ex: \"azure4\", \"magenta8\", \"teal2\", \"gray1\", \"olive3\").\n\n\n\n\n\n\n\n\nbackground\n\n\nBackground color. Specified as a color name or hexadecimal code. Can be NULL for default color.\n\n\n\n\nfontsize\n\n\nInteger Font size in pt units.\n\n\n\n\nwidth\n\n\nWidth of the cell or column. Can be NULL for default width.\n\n\n\n\nalign\n\n\nA single character or a string with a number of characters equal to the number of columns in j. Valid characters include ‘c’ (center), ‘l’ (left), or ‘r’ (right).\n\n\n\n\ncolspan\n\n\nNumber of columns a cell should span. Can only be used if both i and j are of length 1. Must be an integer greater than 1.\n\n\n\n\nindent\n\n\nText indentation in em units. Positive values only.\n\n\n\n\ntabularray_inner\n\n\nA string that specifies the \"inner\" settings of a tabularray LaTeX table.\n\n\n\n\ntabularray_outer\n\n\nA string that specifies the \"outer\" settings of a tabularray LaTeX table.\n\n\n\n\nbootstrap_class\n\n\nString. A Bootstrap table class such as “table”, “table table-dark” or “table table-dark table-hover”. See the bootstrap documentation.\n\n\n\n\nbootstrap_css\n\n\nA vector of CSS style declarations to be applied (ex: “font-weight: bold”). Each element corresponds to a cell defined by i and j.\n\n\n\n\nbootstrap_css_rule\n\n\nA string with complete CSS rules that apply to the table class specified using the theme argument of the tt() function.\n\n\n\n\n…\n\n\nextra arguments are ignored\n\n\n\n\n\n\n\nThis function applies styling to a table created by tt(). It allows customization of text style (bold, italic, monospace), text and background colors, font size, cell width, text alignment, column span, and indentation. The function supports both LaTeX (tabularray) and HTML (bootstrap) formats.\nNote that Markdown and Word formats are limited to these styles: italic, bold, strikeout.\n\n\n\nAn object of class tt representing the table.\n\n\n\nWhen rendering Quarto and Rmarkdown documents, tinytable will populate the LaTeX preamble automatically with all the required packages. For standalone LaTeX packages, these commands should be inserted in the preamble:\n\n\n\\usepackage{tabularray}\n\\usepackage{float}\n\\usepackage{graphicx}\n\\usepackage{codehigh}\n\\usepackage[normalem]{ulem}\n\\UseTblrLibrary{booktabs}\n\\newcommand{\\tinytableTabularrayUnderline}[1]{\\underline{#1}}\n\\newcommand{\\tinytableTabularrayStrikeout}[1]{\\sout{#1}}\n\\NewTableCommand{\\tinytableDefineColor}[3]{\\definecolor{#1}{#2}{#3}}\n\n\n\n\n\n\nlibrary(tinytable)\n\nlibrary(tinytable)\nx <- mtcars[1:5, 1:5]\ntab <- tt(x)\ntab <- style_tt(tab, j = 1:5, align = \"lcccr\")\ntab <- style_tt(tab, i = 2:3,\n background = \"black\", color = \"orange\", bold = TRUE)" + "text": "The tt function renders a table in different formats (HTML, Markdown, or LaTeX) with various styling options. The table can be customized with additional functions:\n\n\nstyle_tt() to style fonts, colors, alignment, etc.\n\n\nformat_tt() to format numbers, dates, strings, etc.\n\n\nsave_tt() to save the table to a file or return the table as a string.\n\n\ntinytable attempts to determine the appropriate way to print the table based on interactive use, RStudio availability, and output format in RMarkdown or Quarto documents. Users can call print(x, output=“markdown”) to print the table in a specific format. Alternatively, they can set a global option: options(“tinytable_print_output”=“markdown”)\n\n\n\n\ntt(\n x,\n digits = NULL,\n caption = NULL,\n width = NULL,\n notes = NULL,\n theme = \"default\",\n placement = getOption(\"tinytable_tabularray_placement\", default = NULL)\n)\n\n\n\n\n\n\n\n\nx\n\n\nA data frame or data table to be rendered as a table.\n\n\n\n\ndigits\n\n\nNumber of significant digits to keep for numeric variables. When digits is an integer, tt() calls format_tt(x, digits = digits) before proceeding to draw the table. Users who need more control can proceed in two steps: (1) format the data with format_tt() or other functions, and (2) pass the formatted data to tt() for drawing. See ?format_tt for more details on formating options (ex: decimal, scientific notation, dates, boolean variables, etc.).\n\n\n\n\ncaption\n\n\nA string that will be used as the caption of the table.\n\n\n\n\nwidth\n\n\nA numeric value between 0 and 1 indicating the proportion of the line width that the table should cover.\n\n\n\n\nnotes\n\n\nA single string or a (named) list of strings to append at the bottom of the table.\n\n\n\n\ntheme\n\n\nThe theme to apply to the table.\n\n\nLaTeX: \"default\", \"striped\", \"void\", or \"grid\".\n\n\nHTML: \"default\", \"striped\", \"void\", \"grid\", or a (composite)\n\n\n\n\n\n\nplacement\n\n\nA string to control the position of tables in LaTeX. Will be inserted in square brackets like: \\begin{table}[H]\n\n\n\n\n\n\n\nAn object of class tt representing the table.\n\n\n\nWhen rendering Quarto and Rmarkdown documents, tinytable will populate the LaTeX preamble automatically with all the required packages. For standalone LaTeX packages, these commands should be inserted in the preamble:\n\n\n\\usepackage{tabularray}\n\\usepackage{float}\n\\usepackage{graphicx}\n\\usepackage{codehigh}\n\\usepackage[normalem]{ulem}\n\\UseTblrLibrary{booktabs}\n\\newcommand{\\tinytableTabularrayUnderline}[1]{\\underline{#1}}\n\\newcommand{\\tinytableTabularrayStrikeout}[1]{\\sout{#1}}\n\\NewTableCommand{\\tinytableDefineColor}[3]{\\definecolor{#1}{#2}{#3}}\n\n\n\n\n\n\nlibrary(tinytable)\n\nlibrary(tinytable)\nx <- mtcars[1:4, 1:5]\n\ntt(x)\n\n\n \n\n \n \n \n tinytable_93733hll72af1zkiidg8\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\ntt(x,\n theme = \"striped\",\n width = 0.5,\n caption = \"Data about cars.\")\n\n\n \n\n \n \n \n tinytable_ketsnpxoiaulig4pgaqh\n \n \n \n \n \n\n \n \n \n \n Data about cars.\n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" }, { - "objectID": "man/style_tt.html#style-a-tiny-table-in-either-latex-or-html-format", - "href": "man/style_tt.html#style-a-tiny-table-in-either-latex-or-html-format", - "title": "tinytable", + "objectID": "CITATION.html", + "href": "CITATION.html", + "title": "Citation", "section": "", - "text": "Style a Tiny Table in either LaTeX or HTML format\n\n\n\n\nstyle_tt(\n x,\n i = NULL,\n j = NULL,\n bold = FALSE,\n italic = FALSE,\n monospace = FALSE,\n underline = FALSE,\n strikeout = FALSE,\n color = NULL,\n background = NULL,\n fontsize = NULL,\n width = NULL,\n align = NULL,\n colspan = NULL,\n indent = 0,\n tabularray_inner = NULL,\n tabularray_outer = NULL,\n bootstrap_class = \"table\",\n bootstrap_css = NULL,\n bootstrap_css_rule = NULL,\n ...\n)\n\n\n\n\n\n\n\n\nx\n\n\nA table object created by tt().\n\n\n\n\ni\n\n\nRow indices where the styling should be applied. Can be a single value or a vector. i=0 is the header, and negative values are higher level headers. If colspan is used, i must be of length 1.\n\n\n\n\nj\n\n\nColumn indices where the styling should be applied. Can be a single value, a vector, or a Perl-style regular expression applied to column names of the original data frame. If colspan is used, j must be of length 1.\n\n\n\n\nbold\n\n\nLogical; if TRUE, text is styled in bold.\n\n\n\n\nitalic\n\n\nLogical; if TRUE, text is styled in italic.\n\n\n\n\nmonospace\n\n\nLogical; if TRUE, text is styled in monospace font.\n\n\n\n\nunderline\n\n\nLogical; if TRUE, text is underlined.\n\n\n\n\nstrikeout\n\n\nLogical; if TRUE, text has a strike through line.\n\n\n\n\ncolor\n\n\nText color. There are several ways to specify colors, depending on the output format.\n\n\nHTML:\n\n\nHex code composed of # and 6 characters, ex: #CC79A7.\n\n\nKeywords: black, silver, gray, white, maroon, red, purple, fuchsia, green, lime, olive, yellow, navy, blue, teal, aqua\n\n\n\n\nLaTeX:\n\n\nHex code composed of # and 6 characters, ex: \"#CC79A7\". See the section below for instructions to add in LaTeX preambles.\n\n\nKeywords: black, blue, brown, cyan, darkgray, gray, green, lightgray, lime, magenta, olive, orange, pink, purple, red, teal, violet, white, yellow.\n\n\nColor blending using xcolor, ex: white!80!blue, green!20!red’.\n\n\nColor names with luminance levels from the ninecolors package (ex: \"azure4\", \"magenta8\", \"teal2\", \"gray1\", \"olive3\").\n\n\n\n\n\n\n\n\nbackground\n\n\nBackground color. Specified as a color name or hexadecimal code. Can be NULL for default color.\n\n\n\n\nfontsize\n\n\nInteger Font size in pt units.\n\n\n\n\nwidth\n\n\nWidth of the cell or column. Can be NULL for default width.\n\n\n\n\nalign\n\n\nA single character or a string with a number of characters equal to the number of columns in j. Valid characters include ‘c’ (center), ‘l’ (left), or ‘r’ (right).\n\n\n\n\ncolspan\n\n\nNumber of columns a cell should span. Can only be used if both i and j are of length 1. Must be an integer greater than 1.\n\n\n\n\nindent\n\n\nText indentation in em units. Positive values only.\n\n\n\n\ntabularray_inner\n\n\nA string that specifies the \"inner\" settings of a tabularray LaTeX table.\n\n\n\n\ntabularray_outer\n\n\nA string that specifies the \"outer\" settings of a tabularray LaTeX table.\n\n\n\n\nbootstrap_class\n\n\nString. A Bootstrap table class such as “table”, “table table-dark” or “table table-dark table-hover”. See the bootstrap documentation.\n\n\n\n\nbootstrap_css\n\n\nA vector of CSS style declarations to be applied (ex: “font-weight: bold”). Each element corresponds to a cell defined by i and j.\n\n\n\n\nbootstrap_css_rule\n\n\nA string with complete CSS rules that apply to the table class specified using the theme argument of the tt() function.\n\n\n\n\n…\n\n\nextra arguments are ignored\n\n\n\n\n\n\n\nThis function applies styling to a table created by tt(). It allows customization of text style (bold, italic, monospace), text and background colors, font size, cell width, text alignment, column span, and indentation. The function supports both LaTeX (tabularray) and HTML (bootstrap) formats.\nNote that Markdown and Word formats are limited to these styles: italic, bold, strikeout.\n\n\n\nAn object of class tt representing the table.\n\n\n\nWhen rendering Quarto and Rmarkdown documents, tinytable will populate the LaTeX preamble automatically with all the required packages. For standalone LaTeX packages, these commands should be inserted in the preamble:\n\n\n\\usepackage{tabularray}\n\\usepackage{float}\n\\usepackage{graphicx}\n\\usepackage{codehigh}\n\\usepackage[normalem]{ulem}\n\\UseTblrLibrary{booktabs}\n\\newcommand{\\tinytableTabularrayUnderline}[1]{\\underline{#1}}\n\\newcommand{\\tinytableTabularrayStrikeout}[1]{\\sout{#1}}\n\\NewTableCommand{\\tinytableDefineColor}[3]{\\definecolor{#1}{#2}{#3}}\n\n\n\n\n\n\nlibrary(tinytable)\n\nlibrary(tinytable)\nx <- mtcars[1:5, 1:5]\ntab <- tt(x)\ntab <- style_tt(tab, j = 1:5, align = \"lcccr\")\ntab <- style_tt(tab, i = 2:3,\n background = \"black\", color = \"orange\", bold = TRUE)" + "text": "Citation\nTo cite package ‘tinytable’ in publications use:\n\n Arel-Bundock V (????). _tinytable: Simple and Configurable Tables in\n 'HTML', 'LaTeX', 'Markdown', 'Word', and 'PNG' Formats_. R package\n version 0.0.1.9001, https://github.com/vincentarelbundock/tinytable/,\n <https://vincentarelbundock.github.io/tinytable/>.\n\nA BibTeX entry for LaTeX users is\n\n @Manual{,\n title = {tinytable: Simple and Configurable Tables in 'HTML', 'LaTeX', 'Markdown', 'Word', and 'PNG' Formats},\n author = {Vincent Arel-Bundock},\n note = {R package version 0.0.1.9001, https://github.com/vincentarelbundock/tinytable/},\n url = {https://vincentarelbundock.github.io/tinytable/},\n }" }, { "objectID": "vignettes/tutorial.html", @@ -179,154 +193,154 @@ "href": "vignettes/tutorial.html#themes", "title": "tinytable", "section": "Themes", - "text": "Themes\ntinytable offers a few basic themes out of the box: “default”, “striped”, “grid”, “void.” Those themes can be applied with the theme argument of the tt() function. As we will see below, it is easy to go much beyond those basic settings to customize your own tables. Here we only illustrate a few of the simplest settings:\n\ntt(x, theme = \"striped\")\n\n\n \n\n \n \n \n tinytable_m8tx8n6za7nfcqad866h\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\n\ntt(x, theme = \"grid\")\n\n\n \n\n \n \n \n tinytable_idknmunsoetf9tz1a1br\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" + "text": "Themes\ntinytable offers a few basic themes out of the box: “default”, “striped”, “grid”, “void.” Those themes can be applied with the theme argument of the tt() function. As we will see below, it is easy to go much beyond those basic settings to customize your own tables. Here we only illustrate a few of the simplest settings:\n\ntt(x, theme = \"striped\")\n\n\n \n\n \n \n \n tinytable_1xzy0ljqigdflhxfhiki\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\n\ntt(x, theme = \"grid\")\n\n\n \n\n \n \n \n tinytable_mipaex20qjw2hd2yuuby\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" }, { "objectID": "vignettes/tutorial.html#alignment", "href": "vignettes/tutorial.html#alignment", "title": "tinytable", "section": "Alignment", - "text": "Alignment\nTo align columns, we use a single character, or a string where each letter represents a column:\n\ndat <- data.frame(\n a = c(\"a\", \"aa\", \"aaa\"),\n b = c(\"b\", \"bb\", \"bbb\"),\n c = c(\"c\", \"cc\", \"ccc\"))\n\ntt(dat) |> style_tt(j = 1:3, align = \"c\")\n\n\n \n\n \n \n \n tinytable_hbq7tphxyxs4jucjzof3\n \n \n \n \n \n\n \n \n \n \n \n \n a\n b\n c\n \n \n \n \n \n a\n b\n c\n \n \n aa\n bb\n cc\n \n \n aaa\n bbb\n ccc\n \n \n \n \n\n \n\n \n\n\n\ntt(dat) |> style_tt(j = 1:3, align = \"lcr\")\n\n\n \n\n \n \n \n tinytable_6ef5remfu4w2iirm4go5\n \n \n \n \n \n\n \n \n \n \n \n \n a\n b\n c\n \n \n \n \n \n a\n b\n c\n \n \n aa\n bb\n cc\n \n \n aaa\n bbb\n ccc" + "text": "Alignment\nTo align columns, we use a single character, or a string where each letter represents a column:\n\ndat <- data.frame(\n a = c(\"a\", \"aa\", \"aaa\"),\n b = c(\"b\", \"bb\", \"bbb\"),\n c = c(\"c\", \"cc\", \"ccc\"))\n\ntt(dat) |> style_tt(j = 1:3, align = \"c\")\n\n\n \n\n \n \n \n tinytable_bk4r72p5zz9jp7swbfom\n \n \n \n \n \n\n \n \n \n \n \n \n a\n b\n c\n \n \n \n \n \n a\n b\n c\n \n \n aa\n bb\n cc\n \n \n aaa\n bbb\n ccc\n \n \n \n \n\n \n\n \n\n\n\ntt(dat) |> style_tt(j = 1:3, align = \"lcr\")\n\n\n \n\n \n \n \n tinytable_fn6kr1ods4uef6wht9g7\n \n \n \n \n \n\n \n \n \n \n \n \n a\n b\n c\n \n \n \n \n \n a\n b\n c\n \n \n aa\n bb\n cc\n \n \n aaa\n bbb\n ccc" }, { "objectID": "vignettes/tutorial.html#formatting-numbers-dates-strings-etc.", "href": "vignettes/tutorial.html#formatting-numbers-dates-strings-etc.", "title": "tinytable", "section": "Formatting (numbers, dates, strings, etc.)", - "text": "Formatting (numbers, dates, strings, etc.)\nThe tt() function is minimalist; it’s inteded purpose is simply to draw nice tables. Users who want to format numbers, dates, strings, and other variables in different ways should process their data before supplying it to the tt() table-drawing function. To do so, we can use the format_tt() function supplied by the tinytable.\nIn a very simple case—such as printing 2 significant digits of all numeric variables—we can use the digits argument of tt():\n\ndat <- data.frame(\n w = c(143002.2092, 201399.181, 100188.3883),\n x = c(1.43402, 201.399, 0.134588),\n y = as.Date(sample(1:1000, 3)),\n z = c(TRUE, TRUE, FALSE))\n\ntt(dat, digits = 2)\n\n\n \n\n \n \n \n tinytable_yaxa8ms3udkc3pmtl6b3\n \n \n \n \n \n\n \n \n \n \n \n \n w\n x\n y\n z\n \n \n \n \n \n 143002\n 1.43\n 1970-11-28\n True\n \n \n 201399\n 201.40\n 1970-03-07\n True\n \n \n 100188\n 0.13\n 1971-04-04\n False\n \n \n \n \n\n \n\n \n\n\n\n\nWe can get more fine-grained control over formatting by calling format_tt() after tt(), optionally by specifying the columns to format with j:\n\ntt(dat) |>\n format_tt(\n j = 2:4,\n digits = 1,\n date = \"%B %d %Y\") |>\n format_tt(\n j = 1,\n digits = 2,\n num_mark_big = \" \",\n num_mark_dec = \",\",\n num_fmt = \"decimal\")\n\n\n \n\n \n \n \n tinytable_trux6nkh86ltbnv97njq\n \n \n \n \n \n\n \n \n \n \n \n \n w\n x\n y\n z\n \n \n \n \n \n 143 002,21\n 1.4\n November 28 1970\n True\n \n \n 201 399,18\n 201.4\n March 07 1970\n True\n \n \n 100 188,39\n 0.1\n April 04 1971\n False\n \n \n \n \n\n \n\n \n\n\n\n\nWe can use a regular expression in j to select columns, and the ?sprintf function to format strings, numbers, and to do string interpolation (similar to the glue package, but using Base R):\n\ndat <- data.frame(\n a = c(\"Burger\", \"Halloumi\", \"Tofu\", \"Beans\"),\n b = c(1.43202, 201.399, 0.146188, 0.0031),\n c = c(98938272783457, 7288839482, 29111727, 93945))\ntt(dat) |>\n format_tt(j = \"a\", sprintf = \"Food: %s\") |>\n format_tt(j = 2, digits = 1) |>\n format_tt(j = \"c\", digits = 2, num_suffix = TRUE)\n\n\n \n\n \n \n \n tinytable_5do6g49i1fc79l99z66v\n \n \n \n \n \n\n \n \n \n \n \n \n a\n b\n c\n \n \n \n \n \n Food: Burger\n 1.432\n 98.94T\n \n \n Food: Halloumi\n 201.399\n 7.29B\n \n \n Food: Tofu\n 0.146\n 29.11M\n \n \n Food: Beans\n 0.003\n 93.94K\n \n \n \n \n\n \n\n \n\n\n\n\nFinally, if you like the format_tt() interface, you can use it directly with numbers, vectors, or data frames:\n\nformat_tt(pi, digits = 1)\n\n[1] \"3\"\n\nformat_tt(dat, digits = 1, num_suffix = TRUE)\n\n a b c\n1 Burger 1.4 98.9T\n2 Halloumi 201.4 7.3B\n3 Tofu 0.1 29.1M\n4 Beans 0.0 93.9K" + "text": "Formatting (numbers, dates, strings, etc.)\nThe tt() function is minimalist; it’s inteded purpose is simply to draw nice tables. Users who want to format numbers, dates, strings, and other variables in different ways should process their data before supplying it to the tt() table-drawing function. To do so, we can use the format_tt() function supplied by the tinytable.\nIn a very simple case—such as printing 2 significant digits of all numeric variables—we can use the digits argument of tt():\n\ndat <- data.frame(\n w = c(143002.2092, 201399.181, 100188.3883),\n x = c(1.43402, 201.399, 0.134588),\n y = as.Date(sample(1:1000, 3)),\n z = c(TRUE, TRUE, FALSE))\n\ntt(dat, digits = 2)\n\n\n \n\n \n \n \n tinytable_0bo0tf9d7fu2uhil8omy\n \n \n \n \n \n\n \n \n \n \n \n \n w\n x\n y\n z\n \n \n \n \n \n 143002\n 1.43\n 1970-01-11\n True\n \n \n 201399\n 201.40\n 1970-07-27\n True\n \n \n 100188\n 0.13\n 1971-04-27\n False\n \n \n \n \n\n \n\n \n\n\n\n\nWe can get more fine-grained control over formatting by calling format_tt() after tt(), optionally by specifying the columns to format with j:\n\ntt(dat) |>\n format_tt(\n j = 2:4,\n digits = 1,\n date = \"%B %d %Y\") |>\n format_tt(\n j = 1,\n digits = 2,\n num_mark_big = \" \",\n num_mark_dec = \",\",\n num_fmt = \"decimal\")\n\n\n \n\n \n \n \n tinytable_0w45aeqq2toibq3zogtt\n \n \n \n \n \n\n \n \n \n \n \n \n w\n x\n y\n z\n \n \n \n \n \n 143 002,21\n 1.4\n January 11 1970\n True\n \n \n 201 399,18\n 201.4\n July 27 1970\n True\n \n \n 100 188,39\n 0.1\n April 27 1971\n False\n \n \n \n \n\n \n\n \n\n\n\n\nWe can use a regular expression in j to select columns, and the ?sprintf function to format strings, numbers, and to do string interpolation (similar to the glue package, but using Base R):\n\ndat <- data.frame(\n a = c(\"Burger\", \"Halloumi\", \"Tofu\", \"Beans\"),\n b = c(1.43202, 201.399, 0.146188, 0.0031),\n c = c(98938272783457, 7288839482, 29111727, 93945))\ntt(dat) |>\n format_tt(j = \"a\", sprintf = \"Food: %s\") |>\n format_tt(j = 2, digits = 1) |>\n format_tt(j = \"c\", digits = 2, num_suffix = TRUE)\n\n\n \n\n \n \n \n tinytable_z7ra482pcix3qqi2qygl\n \n \n \n \n \n\n \n \n \n \n \n \n a\n b\n c\n \n \n \n \n \n Food: Burger\n 1.432\n 98.94T\n \n \n Food: Halloumi\n 201.399\n 7.29B\n \n \n Food: Tofu\n 0.146\n 29.11M\n \n \n Food: Beans\n 0.003\n 93.94K\n \n \n \n \n\n \n\n \n\n\n\n\nFinally, if you like the format_tt() interface, you can use it directly with numbers, vectors, or data frames:\n\nformat_tt(pi, digits = 1)\n\n[1] \"3\"\n\nformat_tt(dat, digits = 1, num_suffix = TRUE)\n\n a b c\n1 Burger 1.4 98.9T\n2 Halloumi 201.4 7.3B\n3 Tofu 0.1 29.1M\n4 Beans 0.0 93.9K" }, { "objectID": "vignettes/tutorial.html#width", "href": "vignettes/tutorial.html#width", "title": "tinytable", "section": "Width", - "text": "Width\nThe width arguments accepts a number between 0 and 1, indicating what proportion of the linewidth the table should cover:\n\ntt(x, width = 0.5)\n\n\n \n\n \n \n \n tinytable_u4g3ocgtwvd7weosbjt6\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\n\ntt(x, width = 1)\n\n\n \n\n \n \n \n tinytable_gy404tiltby317opedk9\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" + "text": "Width\nThe width arguments accepts a number between 0 and 1, indicating what proportion of the linewidth the table should cover:\n\ntt(x, width = 0.5)\n\n\n \n\n \n \n \n tinytable_9qwmwft5ggzowef2tlt4\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\n\ntt(x, width = 1)\n\n\n \n\n \n \n \n tinytable_u63zm6ccbi5xitmcwxqe\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" }, { "objectID": "vignettes/tutorial.html#line-breaks-and-text-wrapping", "href": "vignettes/tutorial.html#line-breaks-and-text-wrapping", "title": "tinytable", "section": "Line breaks and text wrapping", - "text": "Line breaks and text wrapping\nWhen the width argument is specified and a cell includes long text, the text is automatically wrapped to match the table.\n\nlorem <- data.frame(\n Lorem = \"Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo.\",\n Ipsum = \" Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos.\"\n)\ntt(lorem, width = 3/4)\n\n\n \n\n \n \n \n tinytable_82nqgqff4sj3h5ryryuw\n \n \n \n \n \n\n \n \n A full width table with wrapped text.\n \n \n \n Lorem\n Ipsum\n \n \n \n \n \n Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo.\n Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos.\n \n \n \n \n\n \n\n \n\n\n\n\nManual line breaks work sligthly different in LaTeX (PDF) or HTML. This table shows the two strategies. For HTML, we insert a <br> tag. For LaTeX, we wrap the string in curly braces {}, and then insert two (escaped) backslashes: \\\\\\\\\n\nd <- data.frame(\n \"{Sed ut \\\\\\\\ perspiciatis unde}\",\n \"dicta sunt<br> explicabo. Nemo\"\n) |> setNames(c(\"LaTeX line break\", \"HTML line break\"))\ntt(d, width = 1)\n\n\n \n\n \n \n \n tinytable_i7krqqkm86k6w7wcnjrr\n \n \n \n \n \n\n \n \n \n \n \n \n LaTeX line break\n HTML line break\n \n \n \n \n \n {Sed ut \\\\ perspiciatis unde}\n dicta sunt explicabo. Nemo" + "text": "Line breaks and text wrapping\nWhen the width argument is specified and a cell includes long text, the text is automatically wrapped to match the table.\n\nlorem <- data.frame(\n Lorem = \"Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo.\",\n Ipsum = \" Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos.\"\n)\ntt(lorem, width = 3/4)\n\n\n \n\n \n \n \n tinytable_dofrp38zgp824js09fq4\n \n \n \n \n \n\n \n \n A full width table with wrapped text.\n \n \n \n Lorem\n Ipsum\n \n \n \n \n \n Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo.\n Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos.\n \n \n \n \n\n \n\n \n\n\n\n\nManual line breaks work sligthly different in LaTeX (PDF) or HTML. This table shows the two strategies. For HTML, we insert a <br> tag. For LaTeX, we wrap the string in curly braces {}, and then insert two (escaped) backslashes: \\\\\\\\\n\nd <- data.frame(\n \"{Sed ut \\\\\\\\ perspiciatis unde}\",\n \"dicta sunt<br> explicabo. Nemo\"\n) |> setNames(c(\"LaTeX line break\", \"HTML line break\"))\ntt(d, width = 1)\n\n\n \n\n \n \n \n tinytable_jbgew75wm8di6dru4ryu\n \n \n \n \n \n\n \n \n \n \n \n \n LaTeX line break\n HTML line break\n \n \n \n \n \n {Sed ut \\\\ perspiciatis unde}\n dicta sunt explicabo. Nemo" }, { "objectID": "vignettes/tutorial.html#captions-and-cross-references", "href": "vignettes/tutorial.html#captions-and-cross-references", "title": "tinytable", "section": "Captions and cross-references", - "text": "Captions and cross-references\nIn Quarto, one can specify captions and use cross-references using code like this:\n@tbl-blah shows that...\n\n```{r}\n#| label: tbl-blah\n#| tbl-cap: \"Blah blah blah\"\nlibrary(tinytable)\ntt(mtcars[1:4, 1:4])\n```\nAnd here is the rendered version of the code chunk above:\nTable 1 shows that…\n\nlibrary(tinytable)\ntt(mtcars[1:4, 1:4], placement = NULL)\n\n\n\n \n\n \n \n \n tinytable_obezhuj68se7icaujwt9\n \n \n \n \n \n\n \n \n Table 1: Blah blah blah \n \n \n \n mpg\n cyl\n disp\n hp\n \n \n \n \n \n 21\n 6\n 160\n 110\n \n \n 21\n 6\n 160\n 110\n \n \n 22.8\n 4\n 108\n 93\n \n \n 21.4\n 6\n 258\n 110\n \n \n \n \n\n \n\n \n\n\n\n\n\nFor standalone LaTeX tables, you can use the caption argument like so:\n\ntt(x, caption = \"Blah blah.\\\\label{tbl-blah}\")\n\nBe aware that this more approach may not work well in Quarto or Rmarkdown documents." + "text": "Captions and cross-references\nIn Quarto, one can specify captions and use cross-references using code like this:\n@tbl-blah shows that...\n\n```{r}\n#| label: tbl-blah\n#| tbl-cap: \"Blah blah blah\"\nlibrary(tinytable)\ntt(mtcars[1:4, 1:4])\n```\nAnd here is the rendered version of the code chunk above:\nTable 1 shows that…\n\nlibrary(tinytable)\ntt(mtcars[1:4, 1:4], placement = NULL)\n\n\n\n \n\n \n \n \n tinytable_fuydyecdsutc6htkrpc7\n \n \n \n \n \n\n \n \n Table 1: Blah blah blah \n \n \n \n mpg\n cyl\n disp\n hp\n \n \n \n \n \n 21\n 6\n 160\n 110\n \n \n 21\n 6\n 160\n 110\n \n \n 22.8\n 4\n 108\n 93\n \n \n 21.4\n 6\n 258\n 110\n \n \n \n \n\n \n\n \n\n\n\n\n\nFor standalone LaTeX tables, you can use the caption argument like so:\n\ntt(x, caption = \"Blah blah.\\\\label{tbl-blah}\")\n\nBe aware that this more approach may not work well in Quarto or Rmarkdown documents." }, { "objectID": "vignettes/tutorial.html#footnotes", "href": "vignettes/tutorial.html#footnotes", "title": "tinytable", "section": "Footnotes", - "text": "Footnotes\nThe notes argument accepts single strings or named lists of strings:\n\nn <- \"Fusce id ipsum consequat ante pellentesque iaculis eu a ipsum. Mauris id ex in nulla consectetur aliquam. In nec tempus diam. Aliquam arcu nibh, dapibus id ex vestibulum, feugiat consequat erat. Morbi feugiat dapibus malesuada. Quisque vel ullamcorper felis. Aenean a sem at nisi tempor pretium sit amet quis lacus.\"\n\ntt(lorem, notes = n, width = 1)\n\n\n \n\n \n \n \n tinytable_j1czzxw02kdydf1np1v6\n \n \n \n \n \n\n \n \n A full-width table with wrapped text in cells and a footnote.\n \n \n \n Lorem\n Ipsum\n \n \n Fusce id ipsum consequat ante pellentesque iaculis eu a ipsum. Mauris id ex in nulla consectetur aliquam. In nec tempus diam. Aliquam arcu nibh, dapibus id ex vestibulum, feugiat consequat erat. Morbi feugiat dapibus malesuada. Quisque vel ullamcorper felis. Aenean a sem at nisi tempor pretium sit amet quis lacus.\n \n \n Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo.\n Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos.\n \n \n \n \n\n \n\n \n\n\n\n\nWhen notes is a named list, the names are used as identifiers and displayed as superscripts:\n\ntt(x, notes = list(a = \"Blah.\", b = \"Blah blah.\"))\n\n\n \n\n \n \n \n tinytable_vrmxs2ji4ijhk4aonkiq\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n a Blah.\nb Blah blah.\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" + "text": "Footnotes\nThe notes argument accepts single strings or named lists of strings:\n\nn <- \"Fusce id ipsum consequat ante pellentesque iaculis eu a ipsum. Mauris id ex in nulla consectetur aliquam. In nec tempus diam. Aliquam arcu nibh, dapibus id ex vestibulum, feugiat consequat erat. Morbi feugiat dapibus malesuada. Quisque vel ullamcorper felis. Aenean a sem at nisi tempor pretium sit amet quis lacus.\"\n\ntt(lorem, notes = n, width = 1)\n\n\n \n\n \n \n \n tinytable_rpupjckvu7yt3wlr45zn\n \n \n \n \n \n\n \n \n A full-width table with wrapped text in cells and a footnote.\n \n \n \n Lorem\n Ipsum\n \n \n Fusce id ipsum consequat ante pellentesque iaculis eu a ipsum. Mauris id ex in nulla consectetur aliquam. In nec tempus diam. Aliquam arcu nibh, dapibus id ex vestibulum, feugiat consequat erat. Morbi feugiat dapibus malesuada. Quisque vel ullamcorper felis. Aenean a sem at nisi tempor pretium sit amet quis lacus.\n \n \n Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo.\n Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos.\n \n \n \n \n\n \n\n \n\n\n\n\nWhen notes is a named list, the names are used as identifiers and displayed as superscripts:\n\ntt(x, notes = list(a = \"Blah.\", b = \"Blah blah.\"))\n\n\n \n\n \n \n \n tinytable_lozmeqsrbremg1683wu9\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n a Blah.\nb Blah blah.\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" }, { "objectID": "vignettes/tutorial.html#math", "href": "vignettes/tutorial.html#math", "title": "tinytable", "section": "Math", - "text": "Math\nTo insert LaTeX-style mathematical expressions in a tinytable, we enclose the expression in dollar signs: $...$. The expression will then rendered as a mathematical expression by MathJax (for HTML), LaTeX, or Pandoc. Do not forget to double escape any backslashes.\n\ndat <- data.frame(Math = c(\n \"$x^2 + y^2 = z^2$\",\n \"$\\\\frac{1}{2}$\"\n))\ntt(dat) |> style_tt(align = \"c\")\n\n\n \n\n \n \n \n tinytable_csd2kp3acbl1ofgnrhex\n \n \n \n \n \n\n \n \n \n \n \n \n Math\n \n \n \n \n \n $x^2 + y^2 = z^2$\n \n \n $\\frac{1}{2}$" + "text": "Math\nTo insert LaTeX-style mathematical expressions in a tinytable, we enclose the expression in dollar signs: $...$. The expression will then rendered as a mathematical expression by MathJax (for HTML), LaTeX, or Pandoc. Do not forget to double escape any backslashes.\n\ndat <- data.frame(Math = c(\n \"$x^2 + y^2 = z^2$\",\n \"$\\\\frac{1}{2}$\"\n))\ntt(dat) |> style_tt(align = \"c\")\n\n\n \n\n \n \n \n tinytable_qdb5wvyhv277p42ugikz\n \n \n \n \n \n\n \n \n \n \n \n \n Math\n \n \n \n \n \n $x^2 + y^2 = z^2$\n \n \n $\\frac{1}{2}$" }, { "objectID": "vignettes/tutorial.html#markdown", "href": "vignettes/tutorial.html#markdown", "title": "tinytable", "section": "Markdown", - "text": "Markdown\nMarkdown can be rendered in cells by using the markdown argument of the format_tt() function (note: this requires installing the markdown as an optional dependency).\n\ndat <- data.frame( markdown = c(\n \"This is _italic_ text.\",\n \"This sentence ends with a superscript.^2^\")\n)\n\ntt(dat) |>\n format_tt(j = 1, markdown = TRUE) |>\n style_tt(j = 1, align = \"c\")\n\n\n \n\n \n \n \n tinytable_alcohl38tke8g3hhnr6m\n \n \n \n \n \n\n \n \n \n \n \n \n markdown\n \n \n \n \n \n This is italic text.\n \n \n This sentence ends with a superscript.2\n \n \n \n \n\n \n\n \n\n\n\n\nMarkdown syntax can be particularly useful when formatting URL links in a table:\n\ndat <- data.frame(\n `Package (link)` = c(\n \"[`marginaleffects`](https://www.marginaleffects.com/)\",\n \"[`modelsummary`](https://www.modelsummary.com/)\",\n \"[`tinytable`](https://vincentarelbundock.github.io/tinytable/)\",\n \"[`countrycode`](https://vincentarelbundock.github.io/countrycode/)\",\n \"[`WDI`](https://vincentarelbundock.github.io/WDI/)\",\n \"[`softbib`](https://vincentarelbundock.github.io/softbib/)\",\n \"[`tinysnapshot`](https://vincentarelbundock.github.io/tinysnapshot/)\",\n \"[`altdoc`](https://etiennebacher.github.io/altdoc/)\",\n \"[`plot2`](https://grantmcdermott.com/plot2/)\",\n \"[`parameters`](https://easystats.github.io/parameters/)\",\n \"[`insight`](https://easystats.github.io/insight/)\"\n ),\n Purpose = c(\n \"Interpreting statistical models\",\n \"Data and model summaries\",\n \"Draw beautiful tables easily\",\n \"Convert country codes and names\",\n \"Download data from the World Bank\",\n \"Software bibliographies in R\",\n \"Snapshots for unit tests using `tinytest`\",\n \"Create documentation website for R packages\",\n \"Extension of base R plot functions\",\n \"Extract from model objects\",\n \"Extract information from model objects\"\n ),\n check.names = FALSE\n)\n\ntt(dat) |> format_tt(j = 1, markdown = TRUE)\n\n\n \n\n \n \n \n tinytable_tr3ba7a8qrlgr3afnr18\n \n \n \n \n \n\n \n \n Vincent sometimes contributes to these R packages.\n \n \n \n Package (link)\n Purpose\n \n \n \n \n \n marginaleffects\n Interpreting statistical models\n \n \n modelsummary\n Data and model summaries\n \n \n tinytable\n Draw beautiful tables easily\n \n \n countrycode\n Convert country codes and names\n \n \n WDI\n Download data from the World Bank\n \n \n softbib\n Software bibliographies in R\n \n \n tinysnapshot\n Snapshots for unit tests using `tinytest`\n \n \n altdoc\n Create documentation website for R packages\n \n \n plot2\n Extension of base R plot functions\n \n \n parameters\n Extract from model objects\n \n \n insight\n Extract information from model objects" + "text": "Markdown\nMarkdown can be rendered in cells by using the markdown argument of the format_tt() function (note: this requires installing the markdown as an optional dependency).\n\ndat <- data.frame( markdown = c(\n \"This is _italic_ text.\",\n \"This sentence ends with a superscript.^2^\")\n)\n\ntt(dat) |>\n format_tt(j = 1, markdown = TRUE) |>\n style_tt(j = 1, align = \"c\")\n\n\n \n\n \n \n \n tinytable_jl9a8srq41y1y6plb2vt\n \n \n \n \n \n\n \n \n \n \n \n \n markdown\n \n \n \n \n \n This is italic text.\n \n \n This sentence ends with a superscript.2\n \n \n \n \n\n \n\n \n\n\n\n\nMarkdown syntax can be particularly useful when formatting URL links in a table:\n\ndat <- data.frame(\n `Package (link)` = c(\n \"[`marginaleffects`](https://www.marginaleffects.com/)\",\n \"[`modelsummary`](https://www.modelsummary.com/)\",\n \"[`tinytable`](https://vincentarelbundock.github.io/tinytable/)\",\n \"[`countrycode`](https://vincentarelbundock.github.io/countrycode/)\",\n \"[`WDI`](https://vincentarelbundock.github.io/WDI/)\",\n \"[`softbib`](https://vincentarelbundock.github.io/softbib/)\",\n \"[`tinysnapshot`](https://vincentarelbundock.github.io/tinysnapshot/)\",\n \"[`altdoc`](https://etiennebacher.github.io/altdoc/)\",\n \"[`plot2`](https://grantmcdermott.com/plot2/)\",\n \"[`parameters`](https://easystats.github.io/parameters/)\",\n \"[`insight`](https://easystats.github.io/insight/)\"\n ),\n Purpose = c(\n \"Interpreting statistical models\",\n \"Data and model summaries\",\n \"Draw beautiful tables easily\",\n \"Convert country codes and names\",\n \"Download data from the World Bank\",\n \"Software bibliographies in R\",\n \"Snapshots for unit tests using `tinytest`\",\n \"Create documentation website for R packages\",\n \"Extension of base R plot functions\",\n \"Extract from model objects\",\n \"Extract information from model objects\"\n ),\n check.names = FALSE\n)\n\ntt(dat) |> format_tt(j = 1, markdown = TRUE)\n\n\n \n\n \n \n \n tinytable_2imhj84c5i3srlp8ftds\n \n \n \n \n \n\n \n \n Vincent sometimes contributes to these R packages.\n \n \n \n Package (link)\n Purpose\n \n \n \n \n \n marginaleffects\n Interpreting statistical models\n \n \n modelsummary\n Data and model summaries\n \n \n tinytable\n Draw beautiful tables easily\n \n \n countrycode\n Convert country codes and names\n \n \n WDI\n Download data from the World Bank\n \n \n softbib\n Software bibliographies in R\n \n \n tinysnapshot\n Snapshots for unit tests using `tinytest`\n \n \n altdoc\n Create documentation website for R packages\n \n \n plot2\n Extension of base R plot functions\n \n \n parameters\n Extract from model objects\n \n \n insight\n Extract information from model objects" }, { "objectID": "vignettes/tutorial.html#cells-rows-columns", "href": "vignettes/tutorial.html#cells-rows-columns", "title": "tinytable", "section": "Cells, rows, columns", - "text": "Cells, rows, columns\nTo style individual cells, we use the style_cell() function. The first two arguments—i and j—identify the cells of interest, by row and column numbers respectively. To style a cell in the 2nd row and 3rd column, we can do:\n\ntt(x) |>\n style_tt(\n i = 2,\n j = 3,\n background = \"black\",\n color = \"white\")\n\n\n \n\n \n \n \n tinytable_f629c9sfwyqsl1acnnsp\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nThe i and j accept vectors of integers to modify several cells at once:\n\ntt(x) |>\n style_tt(\n i = 2:3,\n j = c(1, 3, 4),\n italic = TRUE,\n color = \"orange\")\n\n\n \n\n \n \n \n tinytable_z5hyxj2jvsqm47j733rj\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nWe can style all cells in a table by omitting both the i and j arguments:\n\ntt(x) |> style_tt(color = \"orange\")\n\n\n \n\n \n \n \n tinytable_ok7mfhkhiz233xpwh25n\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nWe can style entire rows by omitting the j argument:\n\ntt(x) |> style_tt(i = 1:2, color = \"orange\")\n\n\n \n\n \n \n \n tinytable_8d1av5nojp5q7okn6m4t\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nWe can style entire columns by omitting the i argument:\n\ntt(x) |> style_tt(j = c(2, 4), bold = TRUE)\n\n\n \n\n \n \n \n tinytable_b3l7ulx5ojckpb0ukeow\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nThe j argument accepts integer vectors, but also a string with a Perl-style regular expression, which makes it easier to select columns by name:\n\ntt(x) |> style_tt(j = \"mpg|drat\", color = \"orange\")\n\n\n \n\n \n \n \n tinytable_z6bc0bpan5xngh1l11su\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nOf course, we can also call the style_tt() function several times to apply different styles to different parts of the table:\n\ntt(x) |> \n style_tt(i = 1, j = 1:2, color = \"orange\") |>\n style_tt(i = 1, j = 3:4, color = \"green\")\n\n\n \n\n \n \n \n tinytable_t53x1rhreslfmkck25q5\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" + "text": "Cells, rows, columns\nTo style individual cells, we use the style_cell() function. The first two arguments—i and j—identify the cells of interest, by row and column numbers respectively. To style a cell in the 2nd row and 3rd column, we can do:\n\ntt(x) |>\n style_tt(\n i = 2,\n j = 3,\n background = \"black\",\n color = \"white\")\n\n\n \n\n \n \n \n tinytable_cnptl6aweb7lggxo1f2u\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nThe i and j accept vectors of integers to modify several cells at once:\n\ntt(x) |>\n style_tt(\n i = 2:3,\n j = c(1, 3, 4),\n italic = TRUE,\n color = \"orange\")\n\n\n \n\n \n \n \n tinytable_wkfxes2bf9hpwt7awm0w\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nWe can style all cells in a table by omitting both the i and j arguments:\n\ntt(x) |> style_tt(color = \"orange\")\n\n\n \n\n \n \n \n tinytable_gr48hevgds0bk35io8sd\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nWe can style entire rows by omitting the j argument:\n\ntt(x) |> style_tt(i = 1:2, color = \"orange\")\n\n\n \n\n \n \n \n tinytable_dz1jn5nodn8yyu3pwdrb\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nWe can style entire columns by omitting the i argument:\n\ntt(x) |> style_tt(j = c(2, 4), bold = TRUE)\n\n\n \n\n \n \n \n tinytable_zh81svmyam6s1dmgdl47\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nThe j argument accepts integer vectors, but also a string with a Perl-style regular expression, which makes it easier to select columns by name:\n\ntt(x) |> style_tt(j = \"mpg|drat\", color = \"orange\")\n\n\n \n\n \n \n \n tinytable_vwaju3uugw1vvrag973b\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nOf course, we can also call the style_tt() function several times to apply different styles to different parts of the table:\n\ntt(x) |> \n style_tt(i = 1, j = 1:2, color = \"orange\") |>\n style_tt(i = 1, j = 3:4, color = \"green\")\n\n\n \n\n \n \n \n tinytable_8ohp78y0hc7a7n66mo2x\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" }, { "objectID": "vignettes/tutorial.html#colors", "href": "vignettes/tutorial.html#colors", "title": "tinytable", "section": "Colors", - "text": "Colors\nThe color and background arguments in the style_tt() function are used for specifying the text color and the background color for cells of a table created by the tt() function. This argument plays a crucial role in enhancing the visual appeal and readability of the table, whether it’s rendered in LaTeX or HTML format. The way we specify colors differs slightly between the two formats:\nFor HTML Output:\n\nHex Codes: You can specify colors using hexadecimal codes, which consist of a # followed by 6 characters (e.g., #CC79A7). This allows for a wide range of colors.\nKeywords: There’s also the option to use color keywords for convenience. The supported keywords are basic color names like black, red, blue, etc.\n\nFor LaTeX Output:\n\nHexadecimal Codes: Similar to HTML, you can use hexadecimal codes. However, in LaTeX, you need to include these codes as strings (e.g., \"#CC79A7\").\nKeywords: LaTeX supports a different set of color keywords, which include standard colors like black, red, blue, as well as additional ones like cyan, darkgray, lightgray, etc.\nColor Blending: An advanced feature in LaTeX is color blending, which can be achieved using the xcolor package. You can blend colors by specifying ratios (e.g., white!80!blue or green!20!red).\nLuminance Levels: The ninecolors package in LaTeX offers colors with predefined luminance levels, allowing for more nuanced color choices (e.g., “azure4”, “magenta8”).\n\nNote that the keywords used in LaTeX and HTML are slightly different.\n\ntt(x) |> style_tt(i = 1:4, j = 1, color = \"#FF5733\")\n\n\n \n\n \n \n \n tinytable_mms68upkqu21nm2gjoti\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nNote that when using Hex codes in a LaTeX table, we need extra declarations in the LaTeX preamble. See ?tt for details." + "text": "Colors\nThe color and background arguments in the style_tt() function are used for specifying the text color and the background color for cells of a table created by the tt() function. This argument plays a crucial role in enhancing the visual appeal and readability of the table, whether it’s rendered in LaTeX or HTML format. The way we specify colors differs slightly between the two formats:\nFor HTML Output:\n\nHex Codes: You can specify colors using hexadecimal codes, which consist of a # followed by 6 characters (e.g., #CC79A7). This allows for a wide range of colors.\nKeywords: There’s also the option to use color keywords for convenience. The supported keywords are basic color names like black, red, blue, etc.\n\nFor LaTeX Output:\n\nHexadecimal Codes: Similar to HTML, you can use hexadecimal codes. However, in LaTeX, you need to include these codes as strings (e.g., \"#CC79A7\").\nKeywords: LaTeX supports a different set of color keywords, which include standard colors like black, red, blue, as well as additional ones like cyan, darkgray, lightgray, etc.\nColor Blending: An advanced feature in LaTeX is color blending, which can be achieved using the xcolor package. You can blend colors by specifying ratios (e.g., white!80!blue or green!20!red).\nLuminance Levels: The ninecolors package in LaTeX offers colors with predefined luminance levels, allowing for more nuanced color choices (e.g., “azure4”, “magenta8”).\n\nNote that the keywords used in LaTeX and HTML are slightly different.\n\ntt(x) |> style_tt(i = 1:4, j = 1, color = \"#FF5733\")\n\n\n \n\n \n \n \n tinytable_sck0x5dwzfivxargm1cv\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nNote that when using Hex codes in a LaTeX table, we need extra declarations in the LaTeX preamble. See ?tt for details." }, { "objectID": "vignettes/tutorial.html#fonts", "href": "vignettes/tutorial.html#fonts", "title": "tinytable", "section": "Fonts", - "text": "Fonts\nThe font size is specified in em units.\n\ntt(x) |> style_tt(j = \"mpg|hp|qsec\", fontsize = 1.5)\n\n\n \n\n \n \n \n tinytable_vth5oqv0l4ekllsn9fjh\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" + "text": "Fonts\nThe font size is specified in em units.\n\ntt(x) |> style_tt(j = \"mpg|hp|qsec\", fontsize = 1.5)\n\n\n \n\n \n \n \n tinytable_7a6vnlnfa39ifmflrzur\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" }, { "objectID": "vignettes/tutorial.html#headers", "href": "vignettes/tutorial.html#headers", "title": "tinytable", "section": "Headers", - "text": "Headers\nThe header can be omitted from the table by deleting the column names in the x data frame:\n\nk <- x\ncolnames(k) <- NULL\ntt(k)\n\n\n \n\n \n \n \n tinytable_pnipxdxdryy32xqt3sht\n \n \n \n \n \n\n \n \n \n \n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nThe first is row 0, and higher level headers (ex: column spanning labels) have negative indices like -1. They can be styled as expected:\n\ntt(x) |> style_tt(i = 0, color = \"white\", background = \"black\")\n\n\n \n\n \n \n \n tinytable_3eahf6zx63k57w3r6dhg\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nWhen styling columns without specifying i, the headers are styled in accordance with the rest of the column:\n\ntt(x) |> style_tt(j = 2:3, color = \"white\", background = \"black\")\n\n\n \n\n \n \n \n tinytable_qdlow93ldljqq214t75k\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" + "text": "Headers\nThe header can be omitted from the table by deleting the column names in the x data frame:\n\nk <- x\ncolnames(k) <- NULL\ntt(k)\n\n\n \n\n \n \n \n tinytable_4ak5eians5wl3stv160r\n \n \n \n \n \n\n \n \n \n \n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nThe first is row 0, and higher level headers (ex: column spanning labels) have negative indices like -1. They can be styled as expected:\n\ntt(x) |> style_tt(i = 0, color = \"white\", background = \"black\")\n\n\n \n\n \n \n \n tinytable_2nji8kn20pq3l3zxqou0\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nWhen styling columns without specifying i, the headers are styled in accordance with the rest of the column:\n\ntt(x) |> style_tt(j = 2:3, color = \"white\", background = \"black\")\n\n\n \n\n \n \n \n tinytable_o5280k11gn6wqz5zaxe1\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" }, { "objectID": "vignettes/tutorial.html#conditional-styling", "href": "vignettes/tutorial.html#conditional-styling", "title": "tinytable", "section": "Conditional styling", - "text": "Conditional styling\nWe can use the standard which function from Base R to create indices and apply conditional stying on rows. And we can use a regular expression in j to apply conditional styling on columns:\n\nk <- mtcars[1:10, c(\"mpg\", \"am\", \"vs\")]\n\ntt(k) |> \n style_tt(\n i = which(k$am == k$vs),\n background = \"teal\",\n color = \"white\")\n\n\n \n\n \n \n \n tinytable_27hpnx4j0s07lbhsmfar\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n am\n vs\n \n \n \n \n \n 21\n 1\n 0\n \n \n 21\n 1\n 0\n \n \n 22.8\n 1\n 1\n \n \n 21.4\n 0\n 1\n \n \n 18.7\n 0\n 0\n \n \n 18.1\n 0\n 1\n \n \n 14.3\n 0\n 0\n \n \n 24.4\n 0\n 1\n \n \n 22.8\n 0\n 1\n \n \n 19.2\n 0\n 1" + "text": "Conditional styling\nWe can use the standard which function from Base R to create indices and apply conditional stying on rows. And we can use a regular expression in j to apply conditional styling on columns:\n\nk <- mtcars[1:10, c(\"mpg\", \"am\", \"vs\")]\n\ntt(k) |> \n style_tt(\n i = which(k$am == k$vs),\n background = \"teal\",\n color = \"white\")\n\n\n \n\n \n \n \n tinytable_4zv74ejwe1vy3pcsmgyr\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n am\n vs\n \n \n \n \n \n 21\n 1\n 0\n \n \n 21\n 1\n 0\n \n \n 22.8\n 1\n 1\n \n \n 21.4\n 0\n 1\n \n \n 18.7\n 0\n 0\n \n \n 18.1\n 0\n 1\n \n \n 14.3\n 0\n 0\n \n \n 24.4\n 0\n 1\n \n \n 22.8\n 0\n 1\n \n \n 19.2\n 0\n 1" }, { "objectID": "vignettes/tutorial.html#vectorized-styling-heatmaps", "href": "vignettes/tutorial.html#vectorized-styling-heatmaps", "title": "tinytable", "section": "Vectorized styling (heatmaps)", - "text": "Vectorized styling (heatmaps)\nThe color, background, and fontsize arguments are vectorized. This allows easy specification of different colors in a single call:\n\ntt(x) |>\n style_tt(\n i = 1:4,\n color = c(\"red\", \"blue\", \"green\", \"orange\"))\n\n\n \n\n \n \n \n tinytable_r0s7j5tz22kjtbyztigz\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nWhen using a single value for a vectorized argument, it gets applied to all values:\n\ntt(x) |>\n style_tt(\n j = 2:3,\n color = c(\"orange\", \"green\"),\n background = \"black\")\n\n\n \n\n \n \n \n tinytable_sgqm3ojswdbz2u9v13ey\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nWe can also produce more complex heatmap-like tables to illustrate different font sizes in em units:\n\n# font sizes\nfs <- seq(.1, 2, length.out = 20)\n\n# headless table\nk <- data.frame(matrix(fs, ncol = 5))\ncolnames(k) <- NULL\n\n# colors\nbg <- hcl.colors(20, \"Inferno\")\nfg <- ifelse(as.matrix(k) < 1.7, tail(bg, 1), head(bg, 1))\n\n# table\ntt(k, width = .7, theme = \"void\") |>\n style_tt(j = 1:5, align = \"ccccc\") |>\n style_tt(\n i = 1:4,\n j = 1:5,\n color = fg,\n background = bg,\n fontsize = fs)\n\n\n \n\n \n \n \n tinytable_uvbvrwxm8e7ibl8mgf7u\n \n \n \n \n \n\n \n \n \n \n \n \n \n \n \n 0.1\n 0.5\n 0.9\n 1.3\n 1.7\n \n \n 0.2\n 0.6\n 1\n 1.4\n 1.8\n \n \n 0.3\n 0.7\n 1.1\n 1.5\n 1.9\n \n \n 0.4\n 0.8\n 1.2\n 1.6\n 2" + "text": "Vectorized styling (heatmaps)\nThe color, background, and fontsize arguments are vectorized. This allows easy specification of different colors in a single call:\n\ntt(x) |>\n style_tt(\n i = 1:4,\n color = c(\"red\", \"blue\", \"green\", \"orange\"))\n\n\n \n\n \n \n \n tinytable_i7muhm18o8txn2ieq1ys\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nWhen using a single value for a vectorized argument, it gets applied to all values:\n\ntt(x) |>\n style_tt(\n j = 2:3,\n color = c(\"orange\", \"green\"),\n background = \"black\")\n\n\n \n\n \n \n \n tinytable_3orjwq9wkx6e7ag3feui\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nWe can also produce more complex heatmap-like tables to illustrate different font sizes in em units:\n\n# font sizes\nfs <- seq(.1, 2, length.out = 20)\n\n# headless table\nk <- data.frame(matrix(fs, ncol = 5))\ncolnames(k) <- NULL\n\n# colors\nbg <- hcl.colors(20, \"Inferno\")\nfg <- ifelse(as.matrix(k) < 1.7, tail(bg, 1), head(bg, 1))\n\n# table\ntt(k, width = .7, theme = \"void\") |>\n style_tt(j = 1:5, align = \"ccccc\") |>\n style_tt(\n i = 1:4,\n j = 1:5,\n color = fg,\n background = bg,\n fontsize = fs)\n\n\n \n\n \n \n \n tinytable_wkkcdvstbzqvmkfxv50v\n \n \n \n \n \n\n \n \n \n \n \n \n \n \n \n 0.1\n 0.5\n 0.9\n 1.3\n 1.7\n \n \n 0.2\n 0.6\n 1\n 1.4\n 1.8\n \n \n 0.3\n 0.7\n 1.1\n 1.5\n 1.9\n \n \n 0.4\n 0.8\n 1.2\n 1.6\n 2" }, { "objectID": "vignettes/tutorial.html#inserting-images-in-tables", "href": "vignettes/tutorial.html#inserting-images-in-tables", "title": "tinytable", "section": "Inserting images in tables", - "text": "Inserting images in tables\nTo insert images in a table, we use the plot_tt() function. The path_img values must be relative to the main document saved by save_tt() or to the Quarto (or Rmarkdown) document in which the code is executed.\n\ndat <- data.frame(\n Species = c(\"Spider\", \"Squirrel\"),\n Image = \"\"\n)\n\nimg <- c(\n \"../man/figures/spider.png\",\n \"../man/figures/squirrel.png\"\n)\n\ntt(dat) |>\n plot_tt(j = 2, images = img, height = 3)\n\n\n \n\n \n \n \n tinytable_8humoyagca6xiuugdfp3\n \n \n \n \n \n\n \n \n \n \n \n \n Species\n Image\n \n \n \n \n \n Spider\n \n \n \n Squirrel\n \n \n \n \n \n\n \n\n \n\n\n\n\nIn HTML tables, it is possible to insert tables directly from a web address, but not in LaTeX.\n\ndat <- data.frame(\"R\" = \"\")\nimg <- \"https://cran.r-project.org/Rlogo.svg\"\ntt(dat) |>\n plot_tt(i = 1, j = 1, images = img, height = 7) |>\n style_tt(j = 1, align = \"c\")\n\n\n \n\n \n \n \n tinytable_s6euumvelo46ppjdqfbz\n \n \n \n \n \n\n \n \n \n \n \n \n R" + "text": "Inserting images in tables\nTo insert images in a table, we use the plot_tt() function. The path_img values must be relative to the main document saved by save_tt() or to the Quarto (or Rmarkdown) document in which the code is executed.\n\ndat <- data.frame(\n Species = c(\"Spider\", \"Squirrel\"),\n Image = \"\"\n)\n\nimg <- c(\n \"../man/figures/spider.png\",\n \"../man/figures/squirrel.png\"\n)\n\ntt(dat) |>\n plot_tt(j = 2, images = img, height = 3)\n\n\n \n\n \n \n \n tinytable_ntiot49pjbt2lj0s3kvr\n \n \n \n \n \n\n \n \n \n \n \n \n Species\n Image\n \n \n \n \n \n Spider\n \n \n \n Squirrel\n \n \n \n \n \n\n \n\n \n\n\n\n\nIn HTML tables, it is possible to insert tables directly from a web address, but not in LaTeX.\n\ndat <- data.frame(\"R\" = \"\")\nimg <- \"https://cran.r-project.org/Rlogo.svg\"\ntt(dat) |>\n plot_tt(i = 1, j = 1, images = img, height = 7) |>\n style_tt(j = 1, align = \"c\")\n\n\n \n\n \n \n \n tinytable_nhm339bm7i89sla38rc3\n \n \n \n \n \n\n \n \n \n \n \n \n R" }, { "objectID": "vignettes/tutorial.html#inline-plots", "href": "vignettes/tutorial.html#inline-plots", "title": "tinytable", "section": "Inline plots", - "text": "Inline plots\nWe can draw inline plots three ways, with\n\nBuilt-in templates for histograms, density plots, and bar plots\nCustom plots using base R plots.\nCustom plots using ggplot2.\n\nTo draw custom plots, one simply has to define a custom function, whose structure we illustrate below.\n\nBuilt-in plots\nThere are several types of inline plots available by default. For example,\n\nplot_data <- list(mtcars$mpg, mtcars$hp, mtcars$qsec)\n\ndat <- data.frame(\n Variables = c(\"mpg\", \"hp\", \"qsec\"), \n Histogram = \"\",\n Density = \"\",\n Bar = \"\"\n)\n\ntt(dat) |>\n plot_tt(j = 2, fun = \"histogram\", data = plot_data) |>\n plot_tt(j = 3, fun = \"density\", data = plot_data, color = \"darkgreen\") |>\n plot_tt(j = 4, fun = \"bar\", data = list(2, 3, 6), color = \"orange\") |>\n style_tt(j = 2:4, align = \"c\")\n\n\n \n\n \n \n \n tinytable_s110w4v3fqkf94rg2xh3\n \n \n \n \n \n\n \n \n \n \n \n \n Variables\n Histogram\n Density\n Bar\n \n \n \n \n \n mpg\n \n \n \n \n \n hp\n \n \n \n \n \n qsec\n \n \n \n \n \n \n \n\n \n\n \n\n\n\n\n\n\nCustom plots: Base R\nImportant: Custom functions must have ... as an argument.\nTo create a custom inline plot using Base R plotting functions, we create a function that returns another function. tinytable will then call that second function internally to generate the plot.\nThis is easier than it sounds! For example:\n\nf <- function(d, ...) {\n function() hist(d, axes = FALSE, ann = FALSE, col = \"lightblue\")\n}\n\nplot_data <- list(mtcars$mpg, mtcars$hp, mtcars$qsec)\n\ndat <- data.frame(Variables = c(\"mpg\", \"hp\", \"qsec\"), Histogram = \"\")\n\ntt(dat) |>\n plot_tt(j = 2, fun = f, data = plot_data)\n\n\n \n\n \n \n \n tinytable_t1f0h06sq2imrehprfbr\n \n \n \n \n \n\n \n \n \n \n \n \n Variables\n Histogram\n \n \n \n \n \n mpg\n \n \n \n hp\n \n \n \n qsec\n \n \n \n \n \n\n \n\n \n\n\n\n\n\n\nCustom plots: ggplot2\nImportant: Custom functions must have ... as an argument.\nTo create a custom inline plot using ggplot2, we create a function that returns a ggplot object:\n\nlibrary(ggplot2)\n\nf <- function(d, color = \"black\", ...) {\n d <- data.frame(x = d)\n ggplot(d, aes(x = x)) + \n geom_histogram(bins = 30, color = color, fill = color) +\n scale_x_continuous(expand=c(0,0)) +\n scale_y_continuous(expand=c(0,0)) +\n theme_void()\n}\n\nplot_data <- list(mtcars$mpg, mtcars$hp, mtcars$qsec)\n\ntt(dat) |>\n plot_tt(j = 2, fun = f, data = plot_data, color = \"pink\")\n\n\n \n\n \n \n \n tinytable_pxdprf3mlsuifhfgb3oy\n \n \n \n \n \n\n \n \n \n \n \n \n Variables\n Histogram\n \n \n \n \n \n mpg\n \n \n \n hp\n \n \n \n qsec\n \n \n \n \n \n\n \n\n \n\n\n\n\nWe can insert arbitrarily complex plots by customizing the ggplot2 call:\n\nlibrary(palmerpenguins)\n\n# split data by species\ndat <- split(penguins, penguins$species)\nbody <- lapply(dat, \\(x) x$body_mass_g)\nflip <- lapply(dat, \\(x) x$flipper_length_mm)\n\n# create nearly empty table\ntab <- data.frame(\n \"Species\" = names(dat),\n \"Body Mass\" = \"\",\n \"Flipper Length\" = \"\",\n \"Body vs. Flipper\" = \"\",\n check.names = FALSE\n)\n\n# custom ggplot2 function to create inline plot\nf <- function(d, ...) {\n ggplot(d, aes(x = flipper_length_mm, y = body_mass_g, color = sex)) +\n geom_point(size = .2) +\n scale_x_continuous(expand=c(0,0)) +\n scale_y_continuous(expand=c(0,0)) +\n scale_color_manual(values = c(\"#E69F00\", \"#56B4E9\")) +\n theme_void() +\n theme(legend.position = \"none\")\n}\n\n# `tinytable` calls\ntt(tab) |>\n plot_tt(j = 2, fun = \"histogram\", data = body, height = 2) |>\n plot_tt(j = 3, fun = \"density\", data = flip, height = 2) |>\n plot_tt(j = 4, fun = f, data = dat, height = 2) |>\n style_tt(j = 2:4, align = \"c\")\n\n\n \n\n \n \n \n tinytable_oluk2em2kpj4r5n6i938\n \n \n \n \n \n\n \n \n \n \n \n \n Species\n Body Mass\n Flipper Length\n Body vs. Flipper\n \n \n \n \n \n Adelie\n \n \n \n \n \n Chinstrap\n \n \n \n \n \n Gentoo" + "text": "Inline plots\nWe can draw inline plots three ways, with\n\nBuilt-in templates for histograms, density plots, and bar plots\nCustom plots using base R plots.\nCustom plots using ggplot2.\n\nTo draw custom plots, one simply has to define a custom function, whose structure we illustrate below.\n\nBuilt-in plots\nThere are several types of inline plots available by default. For example,\n\nplot_data <- list(mtcars$mpg, mtcars$hp, mtcars$qsec)\n\ndat <- data.frame(\n Variables = c(\"mpg\", \"hp\", \"qsec\"), \n Histogram = \"\",\n Density = \"\",\n Bar = \"\"\n)\n\ntt(dat) |>\n plot_tt(j = 2, fun = \"histogram\", data = plot_data) |>\n plot_tt(j = 3, fun = \"density\", data = plot_data, color = \"darkgreen\") |>\n plot_tt(j = 4, fun = \"bar\", data = list(2, 3, 6), color = \"orange\") |>\n style_tt(j = 2:4, align = \"c\")\n\n\n \n\n \n \n \n tinytable_kkywkniwbhjlrmi6z1po\n \n \n \n \n \n\n \n \n \n \n \n \n Variables\n Histogram\n Density\n Bar\n \n \n \n \n \n mpg\n \n \n \n \n \n hp\n \n \n \n \n \n qsec\n \n \n \n \n \n \n \n\n \n\n \n\n\n\n\n\n\nCustom plots: Base R\nImportant: Custom functions must have ... as an argument.\nTo create a custom inline plot using Base R plotting functions, we create a function that returns another function. tinytable will then call that second function internally to generate the plot.\nThis is easier than it sounds! For example:\n\nf <- function(d, ...) {\n function() hist(d, axes = FALSE, ann = FALSE, col = \"lightblue\")\n}\n\nplot_data <- list(mtcars$mpg, mtcars$hp, mtcars$qsec)\n\ndat <- data.frame(Variables = c(\"mpg\", \"hp\", \"qsec\"), Histogram = \"\")\n\ntt(dat) |>\n plot_tt(j = 2, fun = f, data = plot_data)\n\n\n \n\n \n \n \n tinytable_h4h9kheh65oxmjm27qdq\n \n \n \n \n \n\n \n \n \n \n \n \n Variables\n Histogram\n \n \n \n \n \n mpg\n \n \n \n hp\n \n \n \n qsec\n \n \n \n \n \n\n \n\n \n\n\n\n\n\n\nCustom plots: ggplot2\nImportant: Custom functions must have ... as an argument.\nTo create a custom inline plot using ggplot2, we create a function that returns a ggplot object:\n\nlibrary(ggplot2)\n\nf <- function(d, color = \"black\", ...) {\n d <- data.frame(x = d)\n ggplot(d, aes(x = x)) + \n geom_histogram(bins = 30, color = color, fill = color) +\n scale_x_continuous(expand=c(0,0)) +\n scale_y_continuous(expand=c(0,0)) +\n theme_void()\n}\n\nplot_data <- list(mtcars$mpg, mtcars$hp, mtcars$qsec)\n\ntt(dat) |>\n plot_tt(j = 2, fun = f, data = plot_data, color = \"pink\")\n\n\n \n\n \n \n \n tinytable_9q52wbit18vowekvwyql\n \n \n \n \n \n\n \n \n \n \n \n \n Variables\n Histogram\n \n \n \n \n \n mpg\n \n \n \n hp\n \n \n \n qsec\n \n \n \n \n \n\n \n\n \n\n\n\n\nWe can insert arbitrarily complex plots by customizing the ggplot2 call:\n\nlibrary(palmerpenguins)\n\n# split data by species\ndat <- split(penguins, penguins$species)\nbody <- lapply(dat, \\(x) x$body_mass_g)\nflip <- lapply(dat, \\(x) x$flipper_length_mm)\n\n# create nearly empty table\ntab <- data.frame(\n \"Species\" = names(dat),\n \"Body Mass\" = \"\",\n \"Flipper Length\" = \"\",\n \"Body vs. Flipper\" = \"\",\n check.names = FALSE\n)\n\n# custom ggplot2 function to create inline plot\nf <- function(d, ...) {\n ggplot(d, aes(x = flipper_length_mm, y = body_mass_g, color = sex)) +\n geom_point(size = .2) +\n scale_x_continuous(expand=c(0,0)) +\n scale_y_continuous(expand=c(0,0)) +\n scale_color_manual(values = c(\"#E69F00\", \"#56B4E9\")) +\n theme_void() +\n theme(legend.position = \"none\")\n}\n\n# `tinytable` calls\ntt(tab) |>\n plot_tt(j = 2, fun = \"histogram\", data = body, height = 2) |>\n plot_tt(j = 3, fun = \"density\", data = flip, height = 2) |>\n plot_tt(j = 4, fun = f, data = dat, height = 2) |>\n style_tt(j = 2:4, align = \"c\")\n\n\n \n\n \n \n \n tinytable_qvb1pvad4bxhxra8zu6e\n \n \n \n \n \n\n \n \n \n \n \n \n Species\n Body Mass\n Flipper Length\n Body vs. Flipper\n \n \n \n \n \n Adelie\n \n \n \n \n \n Chinstrap\n \n \n \n \n \n Gentoo" }, { "objectID": "vignettes/tutorial.html#rows", "href": "vignettes/tutorial.html#rows", "title": "tinytable", "section": "Rows", - "text": "Rows\nThe i argument accepts a named list of integers. The numbers identify the positions where row group labels are to be inserted. The names includes the text that should be inserted:\n\ndat <- mtcars[1:9, 1:8]\n\ntt(dat) |>\n group_tt(i = list(\n \"I like (fake) hamburgers\" = 3,\n \"She prefers halloumi\" = 4,\n \"They love tofu\" = 7))\n\n\n \n\n \n \n \n tinytable_btftms36hln5x0zienpz\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n wt\n qsec\n vs\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n 2.62\n 16.46\n 0\n \n \n 21\n 6\n 160\n 110\n 3.9\n 2.875\n 17.02\n 0\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n 2.32\n 18.61\n 1\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n 3.215\n 19.44\n 1\n \n \n 18.7\n 8\n 360\n 175\n 3.15\n 3.44\n 17.02\n 0\n \n \n 18.1\n 6\n 225\n 105\n 2.76\n 3.46\n 20.22\n 1\n \n \n 14.3\n 8\n 360\n 245\n 3.21\n 3.57\n 15.84\n 0\n \n \n 24.4\n 4\n 146.7\n 62\n 3.69\n 3.19\n 20\n 1\n \n \n 22.8\n 4\n 140.8\n 95\n 3.92\n 3.15\n 22.9\n 1\n \n \n \n \n\n \n\n \n\n\n\n\nWe can style group rows in the same way as regular rows:\n\ntt(dat) |> \n group_tt(\n i = list(\n \"I like (fake) hamburgers\" = 3,\n \"She prefers halloumi\" = 4,\n \"They love tofu\" = 7)) |>\n style_tt(\n i = c(3, 5, 9),\n align = \"c\",\n color = \"white\",\n background = \"gray\",\n bold = TRUE)\n\n\n \n\n \n \n \n tinytable_e896plnenail83swkjr4\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n wt\n qsec\n vs\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n 2.62\n 16.46\n 0\n \n \n 21\n 6\n 160\n 110\n 3.9\n 2.875\n 17.02\n 0\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n 2.32\n 18.61\n 1\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n 3.215\n 19.44\n 1\n \n \n 18.7\n 8\n 360\n 175\n 3.15\n 3.44\n 17.02\n 0\n \n \n 18.1\n 6\n 225\n 105\n 2.76\n 3.46\n 20.22\n 1\n \n \n 14.3\n 8\n 360\n 245\n 3.21\n 3.57\n 15.84\n 0\n \n \n 24.4\n 4\n 146.7\n 62\n 3.69\n 3.19\n 20\n 1\n \n \n 22.8\n 4\n 140.8\n 95\n 3.92\n 3.15\n 22.9\n 1" + "text": "Rows\nThe i argument accepts a named list of integers. The numbers identify the positions where row group labels are to be inserted. The names includes the text that should be inserted:\n\ndat <- mtcars[1:9, 1:8]\n\ntt(dat) |>\n group_tt(i = list(\n \"I like (fake) hamburgers\" = 3,\n \"She prefers halloumi\" = 4,\n \"They love tofu\" = 7))\n\n\n \n\n \n \n \n tinytable_j5vwp9jnrg4dy56tv9jr\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n wt\n qsec\n vs\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n 2.62\n 16.46\n 0\n \n \n 21\n 6\n 160\n 110\n 3.9\n 2.875\n 17.02\n 0\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n 2.32\n 18.61\n 1\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n 3.215\n 19.44\n 1\n \n \n 18.7\n 8\n 360\n 175\n 3.15\n 3.44\n 17.02\n 0\n \n \n 18.1\n 6\n 225\n 105\n 2.76\n 3.46\n 20.22\n 1\n \n \n 14.3\n 8\n 360\n 245\n 3.21\n 3.57\n 15.84\n 0\n \n \n 24.4\n 4\n 146.7\n 62\n 3.69\n 3.19\n 20\n 1\n \n \n 22.8\n 4\n 140.8\n 95\n 3.92\n 3.15\n 22.9\n 1\n \n \n \n \n\n \n\n \n\n\n\n\nWe can style group rows in the same way as regular rows:\n\ntt(dat) |> \n group_tt(\n i = list(\n \"I like (fake) hamburgers\" = 3,\n \"She prefers halloumi\" = 4,\n \"They love tofu\" = 7)) |>\n style_tt(\n i = c(3, 5, 9),\n align = \"c\",\n color = \"white\",\n background = \"gray\",\n bold = TRUE)\n\n\n \n\n \n \n \n tinytable_y4ok0qgqfmqanf5y2kzx\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n wt\n qsec\n vs\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n 2.62\n 16.46\n 0\n \n \n 21\n 6\n 160\n 110\n 3.9\n 2.875\n 17.02\n 0\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n 2.32\n 18.61\n 1\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n 3.215\n 19.44\n 1\n \n \n 18.7\n 8\n 360\n 175\n 3.15\n 3.44\n 17.02\n 0\n \n \n 18.1\n 6\n 225\n 105\n 2.76\n 3.46\n 20.22\n 1\n \n \n 14.3\n 8\n 360\n 245\n 3.21\n 3.57\n 15.84\n 0\n \n \n 24.4\n 4\n 146.7\n 62\n 3.69\n 3.19\n 20\n 1\n \n \n 22.8\n 4\n 140.8\n 95\n 3.92\n 3.15\n 22.9\n 1" }, { "objectID": "vignettes/tutorial.html#columns", "href": "vignettes/tutorial.html#columns", "title": "tinytable", "section": "Columns", - "text": "Columns\nThe syntax for column groups is very similar, but we use the j argument instead. The named list specifies the labels to appear in column-spanning labels, and the values must be a vector of consecutive and non-overlapping integers that indicate which columns are associated to which labels:\n\ntt(dat) |> \n group_tt(\n j = list(\n \"Hamburgers\" = 1:3,\n \"Halloumi\" = 4:5,\n \"Tofu\" = 7))\n\n\n \n\n \n \n \n tinytable_km0j2epakqenf06fd057\n \n \n \n \n \n\n \n \n \n \nHamburgers\nHalloumi\n \nTofu\n \n \n \n mpg\n cyl\n disp\n hp\n drat\n wt\n qsec\n vs\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n 2.62\n 16.46\n 0\n \n \n 21\n 6\n 160\n 110\n 3.9\n 2.875\n 17.02\n 0\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n 2.32\n 18.61\n 1\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n 3.215\n 19.44\n 1\n \n \n 18.7\n 8\n 360\n 175\n 3.15\n 3.44\n 17.02\n 0\n \n \n 18.1\n 6\n 225\n 105\n 2.76\n 3.46\n 20.22\n 1\n \n \n 14.3\n 8\n 360\n 245\n 3.21\n 3.57\n 15.84\n 0\n \n \n 24.4\n 4\n 146.7\n 62\n 3.69\n 3.19\n 20\n 1\n \n \n 22.8\n 4\n 140.8\n 95\n 3.92\n 3.15\n 22.9\n 1\n \n \n \n \n\n \n\n \n\n\n\n\nHere is a table with both row and column headers, as well as some styling:\n\ndat <- mtcars[1:9, 1:8]\ntt(dat) |> \n group_tt(\n i = list(\"I like (fake) hamburgers\" = 3,\n \"She prefers halloumi\" = 4,\n \"They love tofu\" = 7),\n j = list(\"Hamburgers\" = 1:3,\n \"Halloumi\" = 4:5,\n \"Tofu\" = 7)) |>\n style_tt(\n i = c(3, 5, 9),\n align = \"c\",\n background = \"teal\",\n color = \"white\") |>\n style_tt(i = -1, color = \"teal\")\n\n\n \n\n \n \n \n tinytable_rdgd1xcl9558rf482kfu\n \n \n \n \n \n\n \n \n \n \nHamburgers\nHalloumi\n \nTofu\n \n \n \n mpg\n cyl\n disp\n hp\n drat\n wt\n qsec\n vs\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n 2.62\n 16.46\n 0\n \n \n 21\n 6\n 160\n 110\n 3.9\n 2.875\n 17.02\n 0\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n 2.32\n 18.61\n 1\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n 3.215\n 19.44\n 1\n \n \n 18.7\n 8\n 360\n 175\n 3.15\n 3.44\n 17.02\n 0\n \n \n 18.1\n 6\n 225\n 105\n 2.76\n 3.46\n 20.22\n 1\n \n \n 14.3\n 8\n 360\n 245\n 3.21\n 3.57\n 15.84\n 0\n \n \n 24.4\n 4\n 146.7\n 62\n 3.69\n 3.19\n 20\n 1\n \n \n 22.8\n 4\n 140.8\n 95\n 3.92\n 3.15\n 22.9\n 1" + "text": "Columns\nThe syntax for column groups is very similar, but we use the j argument instead. The named list specifies the labels to appear in column-spanning labels, and the values must be a vector of consecutive and non-overlapping integers that indicate which columns are associated to which labels:\n\ntt(dat) |> \n group_tt(\n j = list(\n \"Hamburgers\" = 1:3,\n \"Halloumi\" = 4:5,\n \"Tofu\" = 7))\n\n\n \n\n \n \n \n tinytable_es1l2rfrxbu2h02b7cp4\n \n \n \n \n \n\n \n \n \n \nHamburgers\nHalloumi\n \nTofu\n \n \n \n mpg\n cyl\n disp\n hp\n drat\n wt\n qsec\n vs\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n 2.62\n 16.46\n 0\n \n \n 21\n 6\n 160\n 110\n 3.9\n 2.875\n 17.02\n 0\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n 2.32\n 18.61\n 1\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n 3.215\n 19.44\n 1\n \n \n 18.7\n 8\n 360\n 175\n 3.15\n 3.44\n 17.02\n 0\n \n \n 18.1\n 6\n 225\n 105\n 2.76\n 3.46\n 20.22\n 1\n \n \n 14.3\n 8\n 360\n 245\n 3.21\n 3.57\n 15.84\n 0\n \n \n 24.4\n 4\n 146.7\n 62\n 3.69\n 3.19\n 20\n 1\n \n \n 22.8\n 4\n 140.8\n 95\n 3.92\n 3.15\n 22.9\n 1\n \n \n \n \n\n \n\n \n\n\n\n\nHere is a table with both row and column headers, as well as some styling:\n\ndat <- mtcars[1:9, 1:8]\ntt(dat) |> \n group_tt(\n i = list(\"I like (fake) hamburgers\" = 3,\n \"She prefers halloumi\" = 4,\n \"They love tofu\" = 7),\n j = list(\"Hamburgers\" = 1:3,\n \"Halloumi\" = 4:5,\n \"Tofu\" = 7)) |>\n style_tt(\n i = c(3, 5, 9),\n align = \"c\",\n background = \"teal\",\n color = \"white\") |>\n style_tt(i = -1, color = \"teal\")\n\n\n \n\n \n \n \n tinytable_bckleopih4vfri28sz3w\n \n \n \n \n \n\n \n \n \n \nHamburgers\nHalloumi\n \nTofu\n \n \n \n mpg\n cyl\n disp\n hp\n drat\n wt\n qsec\n vs\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n 2.62\n 16.46\n 0\n \n \n 21\n 6\n 160\n 110\n 3.9\n 2.875\n 17.02\n 0\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n 2.32\n 18.61\n 1\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n 3.215\n 19.44\n 1\n \n \n 18.7\n 8\n 360\n 175\n 3.15\n 3.44\n 17.02\n 0\n \n \n 18.1\n 6\n 225\n 105\n 2.76\n 3.46\n 20.22\n 1\n \n \n 14.3\n 8\n 360\n 245\n 3.21\n 3.57\n 15.84\n 0\n \n \n 24.4\n 4\n 146.7\n 62\n 3.69\n 3.19\n 20\n 1\n \n \n 22.8\n 4\n 140.8\n 95\n 3.92\n 3.15\n 22.9\n 1" }, { "objectID": "vignettes/tutorial.html#themes-1", "href": "vignettes/tutorial.html#themes-1", "title": "tinytable", "section": "Themes", - "text": "Themes\nThe Bootstrap framework provides a number of built-in themes to style tables, using “classes.” To use them, we call style_tt() with the bootstrap_class argument. A list of available Bootstrap classes can be found here: https://getbootstrap.com/docs/5.3/content/tables/\nFor example, to produce a “dark” table, we use the table-dark class:\n\ntt(x) |> style_tt(bootstrap_class = \"table table-dark\")\n\n\n \n\n \n \n \n tinytable_8g2f7axjfwxcdgoicbjj\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nWe can also combine several Bootstrap classes. Here, we get a table with the “warning” color and hover feature:\n\ntt(x) |> style_tt(\n bootstrap_class = \"table table-warning table-hover\")\n\n\n \n\n \n \n \n tinytable_l4dlx12ujwex6iw9i7cu\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" + "text": "Themes\nThe Bootstrap framework provides a number of built-in themes to style tables, using “classes.” To use them, we call style_tt() with the bootstrap_class argument. A list of available Bootstrap classes can be found here: https://getbootstrap.com/docs/5.3/content/tables/\nFor example, to produce a “dark” table, we use the table-dark class:\n\ntt(x) |> style_tt(bootstrap_class = \"table table-dark\")\n\n\n \n\n \n \n \n tinytable_xhijl23wc22p9roccbhw\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08\n \n \n \n \n\n \n\n \n\n\n\n\nWe can also combine several Bootstrap classes. Here, we get a table with the “warning” color and hover feature:\n\ntt(x) |> style_tt(\n bootstrap_class = \"table table-warning table-hover\")\n\n\n \n\n \n \n \n tinytable_9jxyy0w6gt4idrloibjb\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" }, { "objectID": "vignettes/tutorial.html#css-declarations", "href": "vignettes/tutorial.html#css-declarations", "title": "tinytable", "section": "CSS declarations", - "text": "CSS declarations\nThe style_tt() function allows us to declare CSS properties and values for individual cells, columns, or rows of a table. For example, if we want to make the first column bold, we could do:\n\ntt(x) |>\n style_tt(j = 1, bootstrap_css = \"font-weight: bold; color: red;\")\n\n\n \n\n \n \n \n tinytable_2s64hnc4lmfbml8q3r9o\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" + "text": "CSS declarations\nThe style_tt() function allows us to declare CSS properties and values for individual cells, columns, or rows of a table. For example, if we want to make the first column bold, we could do:\n\ntt(x) |>\n style_tt(j = 1, bootstrap_css = \"font-weight: bold; color: red;\")\n\n\n \n\n \n \n \n tinytable_keywmlbtv5hy3w9qmpja\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" }, { "objectID": "vignettes/tutorial.html#css-rules", "href": "vignettes/tutorial.html#css-rules", "title": "tinytable", "section": "CSS rules", - "text": "CSS rules\nFor more extensive customization, we can use complete CSS rules. In this example, we define several rules that apply to a new class called mytable. Then, we use the theme argument of the tt() function to ensure that our tiny table is of class mytable. Finally, we call style_bootstrap() to apply the rules with the bootstrap_css_rule argument.\n\ncss_rule <- \"\n.mytable {\n background: linear-gradient(45deg, #EA8D8D, #A890FE);\n width: 600px;\n border-collapse: collapse;\n overflow: hidden;\n box-shadow: 0 0 20px rgba(0,0,0,0.1);\n}\n\n.mytable th,\n.mytable td {\n padding: 5px;\n background-color: rgba(255,255,255,0.2);\n color: #fff;\n}\n\n.mytable tbody tr:hover {\n background-color: rgba(255,255,255,0.3);\n}\n\n.mytable tbody td:hover:before {\n content: '';\n position: absolute;\n left: 0;\n right: 0;\n top: -9999px;\n bottom: -9999px;\n background-color: rgba(255,255,255,0.2);\n z-index: -1;\n}\n\"\n\ntt(x, width = 2/3) |> \n style_tt(\n j = 1:5,\n align = \"ccccc\",\n bootstrap_class = \"table mytable\",\n bootstrap_css_rule = css_rule)\n\n\n \n\n \n \n \n tinytable_0i5slxca8i0i9x911c6x\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" + "text": "CSS rules\nFor more extensive customization, we can use complete CSS rules. In this example, we define several rules that apply to a new class called mytable. Then, we use the theme argument of the tt() function to ensure that our tiny table is of class mytable. Finally, we call style_bootstrap() to apply the rules with the bootstrap_css_rule argument.\n\ncss_rule <- \"\n.mytable {\n background: linear-gradient(45deg, #EA8D8D, #A890FE);\n width: 600px;\n border-collapse: collapse;\n overflow: hidden;\n box-shadow: 0 0 20px rgba(0,0,0,0.1);\n}\n\n.mytable th,\n.mytable td {\n padding: 5px;\n background-color: rgba(255,255,255,0.2);\n color: #fff;\n}\n\n.mytable tbody tr:hover {\n background-color: rgba(255,255,255,0.3);\n}\n\n.mytable tbody td:hover:before {\n content: '';\n position: absolute;\n left: 0;\n right: 0;\n top: -9999px;\n bottom: -9999px;\n background-color: rgba(255,255,255,0.2);\n z-index: -1;\n}\n\"\n\ntt(x, width = 2/3) |> \n style_tt(\n j = 1:5,\n align = \"ccccc\",\n bootstrap_class = \"table mytable\",\n bootstrap_css_rule = css_rule)\n\n\n \n\n \n \n \n tinytable_8f9wfxw00b8q3z7q40go\n \n \n \n \n \n\n \n \n \n \n \n \n mpg\n cyl\n disp\n hp\n drat\n \n \n \n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 21\n 6\n 160\n 110\n 3.9\n \n \n 22.8\n 4\n 108\n 93\n 3.85\n \n \n 21.4\n 6\n 258\n 110\n 3.08" }, { "objectID": "vignettes/tutorial.html#preamble", @@ -348,19 +362,5 @@ "title": "tinytable", "section": "tabularray keys", "text": "tabularray keys" - }, - { - "objectID": "NEWS.html", - "href": "NEWS.html", - "title": "News", - "section": "", - "text": "Initial package release. Yay!" - }, - { - "objectID": "NEWS.html#section", - "href": "NEWS.html#section", - "title": "News", - "section": "", - "text": "Initial package release. Yay!" } ] \ No newline at end of file diff --git a/vignettes/tinytable_assets/id1fni2flvoo3ua1xo1ggd.png b/vignettes/tinytable_assets/id1fni2flvoo3ua1xo1ggd.png new file mode 100644 index 0000000000000000000000000000000000000000..2a3649f886e2b1d07eefdc42ed2ad3c13475fb1f GIT binary patch literal 5097 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 XvO8Jq-;SNznH|Kz&c(JB9g_Dy6Rz(t literal 0 HcmV?d00001 diff --git a/vignettes/tinytable_assets/id2a4klaqe10atf27clfet.png b/vignettes/tinytable_assets/id2a4klaqe10atf27clfet.png new file mode 100644 index 0000000000000000000000000000000000000000..e0b2cddca6c1d229b1f01e786315bce11877ca98 GIT binary patch literal 2558 zcmeAS@N?(olHy`uVBq!ia0y~yV1B{C!05}t3=~;nymb+fN)GS|aRt&^T3S|CR<^db z_V)G;4i2HAp?P_E#l^+t<>eI>6&)QNot>Ti{rwXrOqe-y=B!z>R;*aDa^=eP>(_7H zx^?^Z?Pt!Mxq9{LqeqY4zJ2@d-MbGTK79N3?Z=NFfB*jd_wV2T|NrM^d`f3v;0*J0 zaSW-L^Y-%ftw+toTn@^;UwbV2sr*wHg#h{Ie)1neSsBcBZ1}AEp(>M~!A}1zJ5=l{m;{Tt=+5c>>)oxp2+n~7rEc>5j zF!n!}7yGmBcPVD_Cv;q}^r&WVZaL?8i&;Xcgzu8v0fB|Z6TUIDam;Pr!fxR5LI$MW z>AAvNMjk;c_E9aPAvVYo%OlM4XaRVQe|<1*IX7qjwt0n7^84B@%vAoewdI`5!u6^p&p2vz7aF_2$mX1D=@jq%;*8+0 zD5vzk3)h9Lid*(g8z`mc-d*^A=b!C?@}Hk0UessAv;NSl7qHqh|H4CV0jnBDr*?gZ z7av$TWcM*FJS?tI@`I^`FTMdovSH_i{h1)W_j_9Zy|w=_>)$=O1B>hH*0=1Be{tX{ g&Q=cArqFMBi-6_IXFQEo0~>M-p00i_>zopr0PGWpYXATM literal 0 HcmV?d00001 diff --git a/vignettes/tinytable_assets/id3qieunzhqe317k52pvjg.png b/vignettes/tinytable_assets/id3qieunzhqe317k52pvjg.png new file mode 100644 index 0000000000000000000000000000000000000000..0e9656bb267d9baf153edd9f92ec0ccfba89d90b GIT binary patch literal 1127 zcmeAS@N?(olHy`uVBq!ia0y~yV1B{C!05}t3=~;nymb+fQVH-0an+J$aM59?uCDIv z?Ck35nlWR>%$YOir!%~J_wN1s_y3nN{Qv*|+%+Q;paK6pT^vIy=DfXpoA;1|0LwvE z=4TV@_boZVe&W$Ct)_`?w)zQ`#a|d6d~e}nbZTc<=-hBY(cy)FLJ5a}6$^(f6HvIA zJ?#4oOUCZmH|HOCRJQQ&FWgFTm@q1g8LFdUG8!f**$hX5_m;?5b_h`Y&g2R`A> zd7JP4JNUEeOOt=hd3XIEC!T$N|8w$r{e1iB+n=a+%-;hnIT$=${an^LB{Ts5AWTbI literal 0 HcmV?d00001 diff --git a/vignettes/tinytable_assets/id4cmbn1na2rt9vunpgfma.png b/vignettes/tinytable_assets/id4cmbn1na2rt9vunpgfma.png new file mode 100644 index 0000000000000000000000000000000000000000..bfc66e8f24b7b040ad53a64509d4e0f01cd98cf4 GIT binary patch literal 11922 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 literal 0 HcmV?d00001 diff --git a/vignettes/tinytable_assets/id79bbxmn5n02pj1hwj20c.png b/vignettes/tinytable_assets/id79bbxmn5n02pj1hwj20c.png new file mode 100644 index 0000000000000000000000000000000000000000..6cee967bc397714fe5e47cd30499bbe9d8b9763f GIT binary patch literal 5067 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 literal 0 HcmV?d00001 diff --git a/vignettes/tinytable_assets/idahmqt0pnddbdwold80tv.png b/vignettes/tinytable_assets/idahmqt0pnddbdwold80tv.png new file mode 100644 index 0000000000000000000000000000000000000000..b64658129521b19ba0d4f7b35a4bca4fe68f5f85 GIT binary patch literal 12212 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 literal 0 HcmV?d00001 diff --git a/vignettes/tinytable_assets/idd2r0a0b4tcca94f3xzoo.png b/vignettes/tinytable_assets/idd2r0a0b4tcca94f3xzoo.png new file mode 100644 index 0000000000000000000000000000000000000000..3f0086271a298897b2b5266b2c9d6986485229b0 GIT binary patch literal 12318 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 literal 0 HcmV?d00001 diff --git a/vignettes/tinytable_assets/idd5km3kmv12dfuag4mfm3.png b/vignettes/tinytable_assets/idd5km3kmv12dfuag4mfm3.png new file mode 100644 index 0000000000000000000000000000000000000000..5e33c88b48ac9fae9fd4c33a022920566f8e8e3a GIT binary patch literal 512 zcmeAS@N?(olHy`uVBq!ia0y~yVAKJ!Q#hD`B=`NlpMaD~fKP}kkp92--2X#o{vSB` z|G=sL2TuRre;P!B(3$@Sf#RoqIh8H|)$x=B`2{n`8(F6I%~^i-$*ceAS7nw0#W@Q+ zB8wRq^pruEv0|xx8PK*YPZ!6KiaBpD-Sj&Yz~CCF=J@6R|8Nt-s--;AQb{Fm)i2#C zx;0f#taw}9-Wyeq?wrideA{JR7rMcTTv#ug{eSJ%z4d0w*G~TkS^f9l3s3oe)7N); zBL4D4Y)IJ4uFXOg{L;U1n*aRV`TV)ZdApad?ESpk{@&wx jZM{cVI?A$Ze_`t@uzfh`w8lrZSIXOAGxw%C}MWv;s<>lpFU0pprJu_#{T(M%s z%9ShEuV24m!-g$ewwyV0=F+80w{G2f@ZiCV7cbttdGq$|+jsBYy?_7y!-o&wzJ2@o z^XIQ$zkdJz{r~@eosU5=3=Hhio-U3d6?5KRW}hVBF5nWFB6y-&-=XjK{Q&V5y%DTW ze1iVoV_mje{r}|a2dezv*)dE|FR^I2@Q}f&otZhD<=F1M*K z>fQbRr1e3+pn05g<;o^0m2}PtF#s0;Wu*FCq(rU0#4(bRoFKPjKOKU>bGu z7qoJ1nFmb09Ja16L`J&8CkHP4udVF#f0y@p?XM5B+H5NW;pVOj=}zgQ3(vQl({h^6IXAS$PS|QS9TiT^cKZKzb@rcMGY$h?7$f}4 zU;OT~-^XR#Ud(YH4DLe-n%@r>2_IIyS6$W0uea-Lf4=UQ>-sgTe~DWM4f`Ztzz literal 0 HcmV?d00001 diff --git a/vignettes/tinytable_assets/idj69qhh8rqwyytdhuiwdt.png b/vignettes/tinytable_assets/idj69qhh8rqwyytdhuiwdt.png new file mode 100644 index 0000000000000000000000000000000000000000..5e2927f987468f0422573b4de9faa09fdf1ea03a GIT binary patch literal 2444 zcmeAS@N?(olHy`uVBq!ia0y~yV1B{C!05}t3=~;nymb+fIuPI!;>ya##>&Rd#ly?P zFCZW+Dj)(xVnX7Q(n=~a%4#wyYO4B1YHDhlCKg(z7TRW3Iu_Qt7B;$;HhNaJ`quWQ zPHqkk4$dKwE-o&vuC6}useV9^m=OpBso8;PIjMDRY4zt=%zm z|LIu=&(5Def5FLX3r}5NeCFozi+5M7Sg~^D%2ih%t-bMV{rdGAHf%U{?AXbZC(oQY zbL-ZvckkYP`0(N5$B$pWeEItI>+j#c|NQy$|Ns9zj^(o%7&zKJT^vIy=DfWeeJM3m z(Cwm=qoAn1>OEJM5C@Sxix+&^AHL_|<<1|)?8af!s(Zw0Hin%`pU?dN`@Few3}0IK z%oR#@FfKgI%ORWR@S=d(sa;yY>Q2LjhipKp4~yFWy;P5`t@@Supg!)yh5x@leO|lo z&-vS{9^YRs&%RIPOV@=+mlvW7H+Njnc1jmq7~XPD$!R^uT-TO3 zL91?#y-Fowf>o|Bbd>0$(4Xt?=K7qkWXupV+&B4h||1anJg?~OF z-^%B&Kp(dZU@(j6mEZmF9F%#C%87tRX-GoZe}uSj54{l)5J z?>#6re-Lf^H$8m5{@1_L{efOx`hG6ZtLE|6z>@L(yT9ks?LlQ^`2Sy1TmSu3Kj8Pj pD(H|uw`|2iPArWB)OJHW!(#8#(;CA=8iCC#22WQ%mvv4FO#pePX9EBL literal 0 HcmV?d00001 diff --git a/vignettes/tinytable_assets/idkn7dy7njw0oikll6j98c.png b/vignettes/tinytable_assets/idkn7dy7njw0oikll6j98c.png new file mode 100644 index 0000000000000000000000000000000000000000..f3f966d937d4911815d8688852700b9cd9987cfd GIT binary patch literal 2076 zcmeAS@N?(olHy`uVBq!ia0y~yV1B{C!05}t3=~;nymb+fiVg4yaRt)+{QTc+;# zW@cv2&dx3_E`EM~At529rKRQN<&~9{)2C0LIdkUx`SX`8Tef1wij^x@u3EKf{rdGA zHf-3qapR2}H=aIy`tIGk_wV0-`0(N9&!4}4|Ni^;@Bjb*7dKfPVqjpe@^ozQ!eW&#u`TB&UMLr|avv3>JV3Vp`nr6j-P?UWaZ@i?|Gm7o zZl2SNxh;Nz3(JM9TwCsWz7P?tQePPCGAcNX1LWtk+biqpJvE)$`EU2@Yr4Mpkcd*T zHC*TZyM6t#Uz@5=TzLD{>Hostng@2H)pQRTbZ}jWr<#1o_>cYV`$W@i9@de-YM#N<)z4*}Q$iB}Ekt=Z literal 0 HcmV?d00001 diff --git a/vignettes/tinytable_assets/idlcf5dkxivnemyn3vrx5h.png b/vignettes/tinytable_assets/idlcf5dkxivnemyn3vrx5h.png new file mode 100644 index 0000000000000000000000000000000000000000..ad809c1c02d9616c4f40672590a7165640b38400 GIT binary patch literal 2151 zcmeAS@N?(olHy`uVBq!ia0y~yV1B{C!05}t3=~;nymb+f3J>rJaRt%>0s_Lq!rI!} z#>U2`rlz*Gwhj&sj*gBlE-s0QiG_uQB_$>0<>m9|&tI`(#rpN@4;?ym?AWn$=g!@@ zapTUNJC7efe)8nWyLazCeE9J5=g;52fB*mgpDncF9|HsXX-^l&kcv5PZ$%2lxbnC< z8Yins8*Ki*-><1&P@wBl@aic$o2qI{|NT1a{-7#w7I1?k*Sn z^?8@MI?zO?`Z)R-vZ8)^{x1E=i+8>64EV1XUmmaKUV2}6;lJ3Hy6Nw#m9FgXzVQB1 zt$)iep!;GWik$X)f43EUb>Hl^7Vfr9 zU&7DxU*OmA^1IRwmJ7M(vbN}zhzabv5b5y3DV=d(1RBrVt^XWbdi=lVi-32pU-kW; zd|}}nEL9P#j%xJ3FZRpxMZx}Zr}p2RkZKAhhf#kGyu^W>7w(tWbA8CaC(r%&@%sbW pzaH1C{`v33?uNJGEs1!L@1ViqV4POf3~Vtlc)I$ztaD0e0szqU>_Gqk literal 0 HcmV?d00001 diff --git a/vignettes/tinytable_assets/idlwbm3c71iyzwsqzk4mk4.png b/vignettes/tinytable_assets/idlwbm3c71iyzwsqzk4mk4.png new file mode 100644 index 0000000000000000000000000000000000000000..79a350137a13a46e4a1490db86a402e8bf72ea9d GIT binary patch literal 15654 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 literal 0 HcmV?d00001 diff --git a/vignettes/tinytable_assets/idmv9zwr78tnf0rcmnyvgb.png b/vignettes/tinytable_assets/idmv9zwr78tnf0rcmnyvgb.png new file mode 100644 index 0000000000000000000000000000000000000000..82861ab5fd3e952e89b50c9a7cd62d32927913c0 GIT binary patch literal 529 zcmeAS@N?(olHy`uVBq!ia0y~yVAKJ!Q#hD`B=`NlpMaE5fKP}kkp92_%Krl={~tX2 z|G=sL2TmU^d+!JoWh)8t3ufT4bV~i7@VKN3D8gCb5n0T@pr;JNj1^1m%Ydd%_H=O! zshIQj*6F^c01=l!mp}jG^Qu!kF6`re5q`&1Wlq!Pl#<6LZ_n05r{0VG!pF%iB&MR{ z5iwzdLZaiLrWRHV0ZaDRM(c|#zsvsjId`yX@_S>vs$tp%;)`GJvDKNu!L4?vsdGbu z64A{6t*!r^>gO!h*S{`fn}2`TH{t)i_rLcf#~;6ZGjPWJU$?&5DzDj4(7z#pH1s%v z`T2`}o%!2irdO|%R{wH(bMWuV5Bt`ZOYSx6`kH!Qdrf2fUk|t6`<|}8b5&gIODk(_ zqGNo-1tOW+Yf@`DYzzA8R2J7pf4{hO?VDG#^HMDm9qkyB9&WlMCBJ$;FwPh}UHx3v IIVCg!00q9^&;S4c literal 0 HcmV?d00001 diff --git a/vignettes/tinytable_assets/idpyn3hgemetvxzuee7zrz.png b/vignettes/tinytable_assets/idpyn3hgemetvxzuee7zrz.png new file mode 100644 index 0000000000000000000000000000000000000000..d7222e0ff7be019556caf27e3f140f3db2b94f13 GIT binary patch literal 8399 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 C(&yj+ literal 0 HcmV?d00001 diff --git a/vignettes/tinytable_assets/idxgakk323j1xble6r8www.png b/vignettes/tinytable_assets/idxgakk323j1xble6r8www.png new file mode 100644 index 0000000000000000000000000000000000000000..7920545687b841d219a1aea7b9b553a2e9f9486f GIT binary patch literal 11908 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 AUjP6A literal 0 HcmV?d00001 diff --git a/vignettes/tinytable_assets/idzoav0a5yj2tyouxn2yc1.png b/vignettes/tinytable_assets/idzoav0a5yj2tyouxn2yc1.png new file mode 100644 index 0000000000000000000000000000000000000000..8eaafeb9f170fad97d9a846acb7cba6bebb3dc7e GIT binary patch literal 1829 zcmeAS@N?(olHy`uVBq!ia0y~yV1B{C!05}t3=~;nymb+fG6?Vqan+J$aMWUO(P8lR z_6`gTtgf!^?Ck97>Y6cQ#>|;B=chBgd-v|kJceJte*Is{@c;k+H5-4$F)*-g@N{tu zshIQj^66aBKn9nChBuxi^ZZQrX39VKDB|+7FxLw~uVd;P{@*M8&hX$dr!1dBiABSO zhYU{b%p7Q(g1r|j_y6{*c(ZF?KxNfF5bM{^*{9a8FTc;(&uObt5;jVVhQVk$7|jNw zMZpLv31hE|Yx$oC)d8{jCHLO%6PDZkPL83*X5nGR7Cv?XD;b9u1q|q%b=T$RA3Xhi sxA>p#_xk1fKh)RTy|0;ce*a(AU-N@4Wt=(#f%P7Pr>mdKI;Vst0K#MNOaK4? literal 0 HcmV?d00001 diff --git a/vignettes/tutorial.html b/vignettes/tutorial.html index f785c261..617580ce 100644 --- a/vignettes/tutorial.html +++ b/vignettes/tutorial.html @@ -349,7 +349,7 @@

Tiny Tables

- tinytable_lrcgcajalct9b59kx97p + tinytable_6nlf3w708teq7qzprpkz @@ -368,7 +368,7 @@

Tiny Tables

-
Data about cars.
+
@@ -414,12 +414,12 @@

Tiny Tables

@@ -540,7 +540,7 @@

Themes

-
+
@@ -586,12 +586,12 @@

Themes

@@ -635,9 +635,9 @@

Themes

- tinytable_idknmunsoetf9tz1a1br + tinytable_mipaex20qjw2hd2yuuby @@ -655,7 +655,7 @@

Themes

-
+
@@ -701,12 +701,12 @@

Themes

@@ -759,9 +759,9 @@

Alignment

- tinytable_hbq7tphxyxs4jucjzof3 + tinytable_bk4r72p5zz9jp7swbfom @@ -779,7 +779,7 @@

Alignment

-
+
@@ -810,12 +810,12 @@

Alignment

@@ -849,11 +849,11 @@

Alignment

- tinytable_6ef5remfu4w2iirm4go5 + tinytable_fn6kr1ods4uef6wht9g7 @@ -871,7 +871,7 @@

Alignment

-
+
@@ -902,12 +902,12 @@

Alignment

@@ -954,7 +954,7 @@

Form - tinytable_yaxa8ms3udkc3pmtl6b3 + tinytable_0bo0tf9d7fu2uhil8omy @@ -973,7 +973,7 @@

Form
-

+
@@ -988,19 +988,19 @@

Form

- + - + - + @@ -1008,12 +1008,12 @@

Form @@ -1067,7 +1067,7 @@

Form
-

143002 1.431970-11-281970-01-11 True
201399 201.401970-03-071970-07-27 True
100188 0.131971-04-041971-04-27 False
+
@@ -1082,19 +1082,19 @@

Form

- + - + - + @@ -1102,12 +1102,12 @@

Form @@ -1158,7 +1158,7 @@

Form
-

143 002,21 1.4November 28 1970January 11 1970 True
201 399,18 201.4March 07 1970July 27 1970 True
100 188,39 0.1April 04 1971April 27 1971 False
+
@@ -1194,12 +1194,12 @@

Form @@ -1261,7 +1261,7 @@

Width

-
+
@@ -1307,12 +1307,12 @@

Width

@@ -1355,7 +1355,7 @@

Width

-
+
@@ -1401,12 +1401,12 @@

Width

@@ -1457,7 +1457,7 @@

Line breaks
-

+

A full width table with wrapped text.

@@ -1476,12 +1476,12 @@

Line breaks @@ -1529,7 +1529,7 @@

Line breaks
-

A full width table with wrapped text.

+
@@ -1548,12 +1548,12 @@

Line breaks @@ -1612,7 +1612,7 @@

Captions and
-

+
Table 1:

Blah blah blah

@@ -1653,12 +1653,12 @@

Captions and @@ -1713,7 +1713,7 @@

Footnotes

-
Table 1:

Blah blah blah

+

A full-width table with wrapped text in cells and a footnote.

@@ -1732,12 +1732,12 @@

Footnotes

@@ -1781,7 +1781,7 @@

Footnotes

-

A full-width table with wrapped text in cells and a footnote.

+
@@ -1828,12 +1828,12 @@

Footnotes

@@ -1885,7 +1885,7 @@

Math

-
+
@@ -1905,12 +1905,12 @@

Math

@@ -1947,9 +1947,9 @@

Markdown

- tinytable_alcohl38tke8g3hhnr6m + tinytable_jl9a8srq41y1y6plb2vt @@ -1967,7 +1967,7 @@

Markdown

-
+
@@ -1987,12 +1987,12 @@

Markdown

@@ -2050,7 +2050,7 @@

Markdown

- tinytable_tr3ba7a8qrlgr3afnr18 + tinytable_2imhj84c5i3srlp8ftds @@ -2069,7 +2069,7 @@

Markdown

-
+

Vincent sometimes contributes to these R packages.

@@ -2128,12 +2128,12 @@

Markdown

@@ -2211,7 +2211,7 @@

Cells, rows, columns -

Vincent sometimes contributes to these R packages.

+
@@ -2257,12 +2257,12 @@

Cells, rows, columns @@ -2293,9 +2293,9 @@

Cells, rows, columns - tinytable_z5hyxj2jvsqm47j733rj + tinytable_wkfxes2bf9hpwt7awm0w @@ -2313,7 +2313,7 @@

Cells, rows, columns -

+
@@ -2359,12 +2359,12 @@

Cells, rows, columns @@ -2395,9 +2395,9 @@

Cells, rows, columns - tinytable_ok7mfhkhiz233xpwh25n + tinytable_gr48hevgds0bk35io8sd @@ -2415,7 +2415,7 @@

Cells, rows, columns -

+
@@ -2461,12 +2461,12 @@

Cells, rows, columns @@ -2511,9 +2511,9 @@

Cells, rows, columns - tinytable_8d1av5nojp5q7okn6m4t + tinytable_dz1jn5nodn8yyu3pwdrb @@ -2531,7 +2531,7 @@

Cells, rows, columns -

+
@@ -2577,12 +2577,12 @@

Cells, rows, columns @@ -2617,9 +2617,9 @@

Cells, rows, columns - tinytable_b3l7ulx5ojckpb0ukeow + tinytable_zh81svmyam6s1dmgdl47 @@ -2637,7 +2637,7 @@

Cells, rows, columns -

+
@@ -2683,12 +2683,12 @@

Cells, rows, columns @@ -2723,9 +2723,9 @@

Cells, rows, columns - tinytable_z6bc0bpan5xngh1l11su + tinytable_vwaju3uugw1vvrag973b @@ -2743,7 +2743,7 @@

Cells, rows, columns -

+
@@ -2789,12 +2789,12 @@

Cells, rows, columns @@ -2831,10 +2831,10 @@

Cells, rows, columns - tinytable_t53x1rhreslfmkck25q5 + tinytable_8ohp78y0hc7a7n66mo2x @@ -2852,7 +2852,7 @@

Cells, rows, columns -

+
@@ -2898,12 +2898,12 @@

Cells, rows, columns @@ -2948,9 +2948,9 @@

Colors

- tinytable_mms68upkqu21nm2gjoti + tinytable_sck0x5dwzfivxargm1cv @@ -2968,7 +2968,7 @@

Colors

-
+
@@ -3014,12 +3014,12 @@

Colors

@@ -3052,9 +3052,9 @@

Fonts

- tinytable_vth5oqv0l4ekllsn9fjh + tinytable_7a6vnlnfa39ifmflrzur @@ -3072,7 +3072,7 @@

Fonts

-
+
@@ -3118,12 +3118,12 @@

Fonts

@@ -3163,7 +3163,7 @@

Headers

- tinytable_pnipxdxdryy32xqt3sht + tinytable_4ak5eians5wl3stv160r @@ -3182,7 +3182,7 @@

Headers

-
+
@@ -3221,12 +3221,12 @@

Headers

@@ -3271,7 +3271,7 @@

Headers

-
+
@@ -3317,12 +3317,12 @@

Headers

@@ -3352,9 +3352,9 @@

Headers

- tinytable_qdlow93ldljqq214t75k + tinytable_o5280k11gn6wqz5zaxe1 @@ -3372,7 +3372,7 @@

Headers

-
+
@@ -3418,12 +3418,12 @@

Headers

@@ -3467,9 +3467,9 @@

Conditional styling - tinytable_27hpnx4j0s07lbhsmfar + tinytable_4zv74ejwe1vy3pcsmgyr @@ -3487,7 +3487,7 @@

Conditional styling -

+
@@ -3553,12 +3553,12 @@

Conditional styling @@ -3598,12 +3598,12 @@

Vectorized sty - tinytable_r0s7j5tz22kjtbyztigz + tinytable_i7muhm18o8txn2ieq1ys @@ -3621,7 +3621,7 @@

Vectorized sty
-

+
@@ -3667,12 +3667,12 @@

Vectorized sty @@ -3721,10 +3721,10 @@

Vectorized sty - tinytable_sgqm3ojswdbz2u9v13ey + tinytable_3orjwq9wkx6e7ag3feui @@ -3742,7 +3742,7 @@

Vectorized sty
-

+
@@ -3788,12 +3788,12 @@

Vectorized sty @@ -3847,30 +3847,30 @@

Vectorized sty - tinytable_uvbvrwxm8e7ibl8mgf7u + tinytable_wkkcdvstbzqvmkfxv50v @@ -3888,7 +3888,7 @@

Vectorized sty
-

+
@@ -3927,12 +3927,12 @@

Vectorized sty @@ -4035,7 +4035,7 @@

Inserting image - tinytable_8humoyagca6xiuugdfp3 + tinytable_ntiot49pjbt2lj0s3kvr @@ -4054,7 +4054,7 @@

Inserting image
-

+
@@ -4077,12 +4077,12 @@

Inserting image @@ -4131,7 +4131,7 @@

Inserting image
-

+
@@ -4148,12 +4148,12 @@

Inserting image @@ -4205,9 +4205,9 @@

Built-in plots

- tinytable_s110w4v3fqkf94rg2xh3 + tinytable_kkywkniwbhjlrmi6z1po @@ -4225,7 +4225,7 @@

Built-in plots

-
+
@@ -4239,33 +4239,33 @@

Built-in plots

- - - + + + - - - + + + - - - + + +
mpg
hp
qsec
@@ -4316,7 +4316,7 @@

Custom plots: Base - tinytable_t1f0h06sq2imrehprfbr + tinytable_h4h9kheh65oxmjm27qdq @@ -4335,7 +4335,7 @@

Custom plots: Base - +
@@ -4347,27 +4347,27 @@

Custom plots: Base

- + - + - +
mpg
hp
qsec
@@ -4429,7 +4429,7 @@

Custom plots: g
- +
@@ -4441,27 +4441,27 @@

Custom plots: g

- + - + - +
mpg
hp
qsec
@@ -4538,7 +4538,7 @@

Custom plots: g
- +
@@ -4552,33 +4552,33 @@

Custom plots: g

- - - + + + - - - + + + - - - + + +
Adelie
Chinstrap
Gentoo
@@ -4629,10 +4629,10 @@

Rows

- tinytable_btftms36hln5x0zienpz + tinytable_j5vwp9jnrg4dy56tv9jr @@ -4650,7 +4650,7 @@

Rows

- +
@@ -4761,12 +4761,12 @@

Rows

@@ -4822,11 +4822,11 @@

Rows

- tinytable_e896plnenail83swkjr4 + tinytable_y4ok0qgqfmqanf5y2kzx @@ -4844,7 +4844,7 @@

Rows

-
+
@@ -4955,12 +4955,12 @@

Rows

@@ -5037,7 +5037,7 @@

Columns

- tinytable_km0j2epakqenf06fd057 + tinytable_es1l2rfrxbu2h02b7cp4 @@ -5056,7 +5056,7 @@

Columns

-
+
@@ -5172,12 +5172,12 @@

Columns

@@ -5239,7 +5239,7 @@

Columns

-
Hamburgers Halloumi
+
@@ -5355,12 +5355,12 @@

Columns

@@ -5444,9 +5444,9 @@

Themes

- tinytable_8g2f7axjfwxcdgoicbjj + tinytable_xhijl23wc22p9roccbhw @@ -5464,7 +5464,7 @@

Themes

-
Hamburgers Halloumi
+
@@ -5510,12 +5510,12 @@

Themes

@@ -5561,9 +5561,9 @@

Themes

- tinytable_l4dlx12ujwex6iw9i7cu + tinytable_9jxyy0w6gt4idrloibjb @@ -5581,7 +5581,7 @@

Themes

-
+
@@ -5627,12 +5627,12 @@

Themes

@@ -5681,9 +5681,9 @@

CSS declarations

- tinytable_2s64hnc4lmfbml8q3r9o + tinytable_keywmlbtv5hy3w9qmpja @@ -5701,7 +5701,7 @@

CSS declarations

-
+
@@ -5747,12 +5747,12 @@

CSS declarations

@@ -5822,9 +5822,9 @@

CSS rules

- tinytable_0i5slxca8i0i9x911c6x + tinytable_8f9wfxw00b8q3z7q40go