From 63d43157bdc3988992bbeed9b6ad2caeb4e1f86f Mon Sep 17 00:00:00 2001 From: vincentarelbundock Date: Sat, 13 Jan 2024 22:14:09 +0000 Subject: [PATCH] =?UTF-8?q?Deploying=20to=20gh-pages=20from=20@=20vincenta?= =?UTF-8?q?relbundock/tinytable@26f9326ccace0ab8604bf29d33f0c951055c631b?= =?UTF-8?q?=20=F0=9F=9A=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- man/tt.html | 82 ++-- search.json | 38 +- vignettes/tutorial.html | 903 +++++++++++++++++++--------------------- vignettes/tutorial.pdf | Bin 103168 -> 103157 bytes 4 files changed, 494 insertions(+), 529 deletions(-) diff --git a/man/tt.html b/man/tt.html index dd3dfb89..3bcc96d1 100644 --- a/man/tt.html +++ b/man/tt.html @@ -394,7 +394,7 @@

Examples

- tinytable_d2v5wouipkoi6ng96nhh + tinytable_8wcdepih4gm59apfdj7n diff --git a/search.json b/search.json index d7b5be96..3b1bba0c 100644 --- a/search.json +++ b/search.json @@ -144,14 +144,14 @@ "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.\n\n\n\ntt(\n x,\n output = NULL,\n align = NULL,\n caption = NULL,\n width = NULL,\n notes = NULL,\n theme = \"default\",\n placement = getOption(\"tt_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\noutput\n\n\nThe format of the output table. Can be \"html\", \"latex\", or \"markdown\". If NULL, the format is automatically detected in Quarto or Rmarkdown documents.\n\n\n\n\nalign\n\n\nA string specifying the alignment of columns. Each character in the string corresponds to a column; ‘l’ for left, ‘c’ for center, and ‘r’ for right alignment. The length of the string must match the number of columns in x.\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) Bootstrap class such as “table table-dark” or “table table-dark table-hover”. See\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{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\n\n\nlibrary(tinytable)\nx <- mtcars[1:4, 1:5]\n\ntt(x)\n\n\n \n\n\n \n \n \n tinytable_d2v5wouipkoi6ng96nhh\n \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 align = \"ccrrl\",\n caption = \"Data about cars.\")\n\n\n \n\n\n \n \n \n tinytable_8k9qwg9cr2yjj7wepgkj\n \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.\n\n\n\ntt(\n x,\n output = NULL,\n align = NULL,\n caption = NULL,\n width = NULL,\n notes = NULL,\n theme = \"default\",\n placement = getOption(\"tt_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\noutput\n\n\nThe format of the output table. Can be \"html\", \"latex\", or \"markdown\". If NULL, the format is automatically detected in Quarto or Rmarkdown documents.\n\n\n\n\nalign\n\n\nA string specifying the alignment of columns. Each character in the string corresponds to a column; ‘l’ for left, ‘c’ for center, and ‘r’ for right alignment. The length of the string must match the number of columns in x.\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) Bootstrap class such as “table table-dark” or “table table-dark table-hover”. See\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{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\n\n\nlibrary(tinytable)\nx <- mtcars[1:4, 1:5]\n\ntt(x)\n\n\n \n\n\n \n \n \n tinytable_8wcdepih4gm59apfdj7n\n \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 align = \"ccrrl\",\n caption = \"Data about cars.\")\n\n\n \n\n\n \n \n \n tinytable_u44f164mm59aq4zke3z4\n \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.\n\n\n\ntt(\n x,\n output = NULL,\n align = NULL,\n caption = NULL,\n width = NULL,\n notes = NULL,\n theme = \"default\",\n placement = getOption(\"tt_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\noutput\n\n\nThe format of the output table. Can be \"html\", \"latex\", or \"markdown\". If NULL, the format is automatically detected in Quarto or Rmarkdown documents.\n\n\n\n\nalign\n\n\nA string specifying the alignment of columns. Each character in the string corresponds to a column; ‘l’ for left, ‘c’ for center, and ‘r’ for right alignment. The length of the string must match the number of columns in x.\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) Bootstrap class such as “table table-dark” or “table table-dark table-hover”. See\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{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\n\n\nlibrary(tinytable)\nx <- mtcars[1:4, 1:5]\n\ntt(x)\n\n\n \n\n\n \n \n \n tinytable_d2v5wouipkoi6ng96nhh\n \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 align = \"ccrrl\",\n caption = \"Data about cars.\")\n\n\n \n\n\n \n \n \n tinytable_8k9qwg9cr2yjj7wepgkj\n \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.\n\n\n\ntt(\n x,\n output = NULL,\n align = NULL,\n caption = NULL,\n width = NULL,\n notes = NULL,\n theme = \"default\",\n placement = getOption(\"tt_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\noutput\n\n\nThe format of the output table. Can be \"html\", \"latex\", or \"markdown\". If NULL, the format is automatically detected in Quarto or Rmarkdown documents.\n\n\n\n\nalign\n\n\nA string specifying the alignment of columns. Each character in the string corresponds to a column; ‘l’ for left, ‘c’ for center, and ‘r’ for right alignment. The length of the string must match the number of columns in x.\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) Bootstrap class such as “table table-dark” or “table table-dark table-hover”. See\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{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\n\n\nlibrary(tinytable)\nx <- mtcars[1:4, 1:5]\n\ntt(x)\n\n\n \n\n\n \n \n \n tinytable_8wcdepih4gm59apfdj7n\n \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 align = \"ccrrl\",\n caption = \"Data about cars.\")\n\n\n \n\n\n \n \n \n tinytable_u44f164mm59aq4zke3z4\n \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": "CITATION.html", @@ -179,98 +179,98 @@ "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 \n tinytable_sh0id77a4vjmkq2bi2w8\n \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 \n tinytable_1776pz9ri2ah6polsvr5\n \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 \n tinytable_q79gei2vzuzm4ge6z14k\n \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 \n tinytable_9jimfydhrf6e9h7adtt9\n \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 string, where each letter represents a column:\n\ntt(x, align = \"ccrrl\")\n\n\n \n\n\n \n \n \n tinytable_a53altfynqejk6jag31q\n \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": "Alignment\nTo align columns, we use a single string, where each letter represents a column:\n\ntt(x, align = \"ccrrl\")\n\n\n \n\n\n \n \n \n tinytable_x7llkq1bq4zpt1g60dj1\n \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#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 \n tinytable_jcjes6h0w5fcdji8ogcv\n \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 \n tinytable_i4gn9pj2m9kdijvih2t6\n \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 \n tinytable_7ipg508loojd4bew39ko\n \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 \n tinytable_fyv5xj42n0znz5a0gwyd\n \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 \n tinytable_zy6x8gqtrrs1cbbibiw3\n \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 \n tinytable_ith9g9izfmy6d19jllrv\n \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 \n tinytable_2sxz2qhfj4gzytxp9zqb\n \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 \n tinytable_lollhttmp70cneor8e6a\n \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 \n tinytable_2pztwqpgqiyr15gqjjh5\n \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 \n tinytable_7iy2v6vymegjcefgka6t\n \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 note 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 \n tinytable_t3zb6jbutn9mboctnzx8\n \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 note 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 \n tinytable_kt7adfy40oxcwodayj14\n \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 note 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 \n tinytable_wntqkc3v7xmrxbrvcm51\n \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 note 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 \n tinytable_8mc83496dsvzhzbquppy\n \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\nYou can render equations inside tables using the common $...$ syntax:\n\ndat <- data.frame(Math = c(\"$x^2 + y^2 = z^2$\", \"$\\\\frac{1}{2}$\"))\ntt(dat)\n\n\n \n\n\n \n \n \n tinytable_wzkdnpn7powy2xm167i9\n \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}$\n \n \n \n \n \n\n \n\n\n\n\n\nIn LaTeX (PDF), you can also use the mode inner setting from tabularray to render math in tables without $ delimiters (see Section 5 for details on tabularray):\n\ndat <- data.frame(Math = c(\"x^2 + y^2 = z^2\", \"\\\\frac{1}{2}\"))\ntt(dat) |> style_tt(tabularray_inner = \"column{1}={mode=math},\")" + "text": "Math\nYou can render equations inside tables using the common $...$ syntax:\n\ndat <- data.frame(Math = c(\"$x^2 + y^2 = z^2$\", \"$\\\\frac{1}{2}$\"))\ntt(dat)\n\n\n \n\n\n \n \n \n tinytable_0qjz5z5mwxiohbtk7yrw\n \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}$\n \n \n \n \n \n\n \n\n\n\n\n\nIn LaTeX (PDF), you can also use the mode inner setting from tabularray to render math in tables without $ delimiters (see Section 5 for details on tabularray):\n\ndat <- data.frame(Math = c(\"x^2 + y^2 = z^2\", \"\\\\frac{1}{2}\"))\ntt(dat) |> style_tt(tabularray_inner = \"column{1}={mode=math},\")" }, { "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 \n tinytable_iuvs4ana7ycvbzo8vf11\n \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\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 \n tinytable_hhbdo1ew41qi4srt5wwz\n \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\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 \n tinytable_9m9qzlwdo0f6a4rel8yb\n \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\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 \n tinytable_3kwuagmcb33iptf2g23n\n \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\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 \n tinytable_42dkcluzkxr9jvrpglux\n \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\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 \n tinytable_4s513kqmmg9whz20aobc\n \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\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 \n tinytable_jjlnjzk9c0me26q9k3g9\n \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 \n tinytable_eysqbvznku7w4xlme97q\n \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\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 \n tinytable_ezhoxifffzsczdenfgff\n \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\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 \n tinytable_z51rumfuzq0asshqvnk3\n \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\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 \n tinytable_icoq37sudgwc2upuckj9\n \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\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 \n tinytable_lqgofj06ondscijfi7je\n \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\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 \n tinytable_xexs0ewpy8si0dnwch3v\n \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\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 \n tinytable_kxgz2e6onwtp74gc7ya7\n \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 \n tinytable_h3p9ghxwryi3urxktgm0\n \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\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 \n tinytable_374doqkr2dzsrgtjq5zq\n \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\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 terms of pt units, where 1pt=1.333px:\n\ntt(x) |> style_tt(j = \"mpg|hp|qsec\", fontsize = 18)\n\n\n \n\n\n \n \n \n tinytable_b3oasvd5nuesz03zq79e\n \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 terms of pt units, where 1pt=1.333px:\n\ntt(x) |> style_tt(j = \"mpg|hp|qsec\", fontsize = 18)\n\n\n \n\n\n \n \n \n tinytable_gbfmbfwm2c5o77x3h21h\n \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#spanning-cells", "href": "vignettes/tutorial.html#spanning-cells", "title": "tinytable", "section": "Spanning cells", - "text": "Spanning cells\nSometimes, it can be useful to make a cell stretch across multiple colums, for example when we want to insert a label. To achieve this, we can use the colspan argument. Here, we make the 2nd cell of the 2nd row stretch across three columns:\n\ntt(x)|> style_tt(\n i = 2, j = 2,\n colspan = 3,\n align = \"c\",\n color = \"white\",\n background = \"black\")\n\n\n \n\n\n \n \n \n tinytable_hwf7pa1huxoqkce93bia\n \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\nHere is the original table for comparison:\n\ntt(x)\n\n\n \n\n\n \n \n \n tinytable_jxfufr5woogonidbatv5\n \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": "Spanning cells\nSometimes, it can be useful to make a cell stretch across multiple colums, for example when we want to insert a label. To achieve this, we can use the colspan argument. Here, we make the 2nd cell of the 2nd row stretch across three columns:\n\ntt(x)|> style_tt(\n i = 2, j = 2,\n colspan = 3,\n align = \"c\",\n color = \"white\",\n background = \"black\")\n\n\n \n\n\n \n \n \n tinytable_tyzuz0ddub2hi9ikgjy1\n \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\nHere is the original table for comparison:\n\ntt(x)\n\n\n \n\n\n \n \n \n tinytable_nzdutwp4zz48anjwu78b\n \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 \n tinytable_7kfrojggupwjr4yngux0\n \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 header is row 0, and can thus be styled as expected:\n\ntt(x) |> style_tt(i = 0, color = \"white\", background = \"black\")\n\n\n \n\n\n \n \n \n tinytable_jim0w8d586hb89u9hh6e\n \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 \n tinytable_lgbnjv9rxtxunuvglv7j\n \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 header is row 0, and can thus be styled as expected:\n\ntt(x) |> style_tt(i = 0, color = \"white\", background = \"black\")\n\n\n \n\n\n \n \n \n tinytable_4sudkhkztdqi3v11wyx3\n \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#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 \n tinytable_z02tdy93hzo1ilrqixbn\n \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\nThe group_tt() function only includes a few arguments: x, i, j, and indent. But whenever we call group_tt(), the function will automatically apply a style_tt() call to all the new group labels, using any extra argument supplied to group_tt() (arguments are pushed via ...). This means that we can apply all the usual stying options to row labels:\n\ntt(dat) |> \n group_tt(\n align = \"c\",\n color = \"white\",\n background = \"gray\",\n bold = TRUE,\n 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 \n tinytable_33e28dfnfzps27pnmq3a\n \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 \n tinytable_2bwocs5ftvmcrnlyl8aj\n \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\nThe group_tt() function only includes a few arguments: x, i, j, and indent. But whenever we call group_tt(), the function will automatically apply a style_tt() call to all the new group labels, using any extra argument supplied to group_tt() (arguments are pushed via ...). This means that we can apply all the usual stying options to row labels:\n\ntt(dat) |> \n group_tt(\n align = \"c\",\n color = \"white\",\n background = \"gray\",\n bold = TRUE,\n 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 \n tinytable_w2ay9vgkvxjv5ig441gv\n \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 \n tinytable_gi4q9ssgsuxkguwjzqxo\n \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\nAs above, we can pass additional styling options to the style_tt() function automatically via .... This means that all the arguments like italic, bold, color and friends can be used to style spanning column headers:\n\ndat <- mtcars[1:9, 1:8]\ntt(dat) |> \n group_tt(color = \"teal\", italic = TRUE,\n j = list(\"Hamburgers\" = 1:3,\n \"Halloumi\" = 4:5,\n \"Tofu\" = 7)) |>\n group_tt(align = \"c\", color = \"white\", background = \"teal\", bold = TRUE,\n i = list(\"I like (fake) hamburgers\" = 3,\n \"She prefers halloumi\" = 4,\n \"They love tofu\" = 7))\n\n\n \n\n\n \n \n \n tinytable_bmcyup4ytkjc2h0u1zkz\n \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 \n tinytable_md25b0z9825cwmi1tf6y\n \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\nAs above, we can pass additional styling options to the style_tt() function automatically via .... This means that all the arguments like italic, bold, color and friends can be used to style spanning column headers:\n\ndat <- mtcars[1:9, 1:8]\ntt(dat) |> \n group_tt(color = \"teal\", italic = TRUE,\n j = list(\"Hamburgers\" = 1:3,\n \"Halloumi\" = 4:5,\n \"Tofu\" = 7)) |>\n group_tt(align = \"c\", color = \"white\", background = \"teal\", bold = TRUE,\n i = list(\"I like (fake) hamburgers\" = 3,\n \"She prefers halloumi\" = 4,\n \"They love tofu\" = 7))\n\n\n \n\n\n \n \n \n tinytable_3sf1e7l4e2oif8mh18s3\n \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#conditional-styling", @@ -284,21 +284,21 @@ "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. To use them, we call bootstrapOptions() with the class argument, and we specify the Bootstrap class. 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, theme = \"table table-dark\")\n\n\n \n\n\n \n \n \n tinytable_i5501xcbissrwxh588b8\n \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 “striped” table with the “warning” color and hover feature:\n\ntt(x, theme = \"table table-striped table-warning table-hover\")\n\n\n \n\n\n \n \n \n tinytable_8mpbzjo57qufbiki7k04\n \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. To use them, we call bootstrapOptions() with the class argument, and we specify the Bootstrap class. 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, theme = \"table table-dark\")\n\n\n \n\n\n \n \n \n tinytable_zq2t8yxrfhlu6ba47rlb\n \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 “striped” table with the “warning” color and hover feature:\n\ntt(x, theme = \"table table-striped table-warning table-hover\")\n\n\n \n\n\n \n \n \n tinytable_xcneh85xzii4tuiv5a5f\n \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 \n tinytable_k5kyr1ycv2y4t2za5yjo\n \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 \n tinytable_9bzc1rqdh61ln7es9eeq\n \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, align = \"ccccc\", theme = \"table mytable\") |> \n style_tt(bootstrap_css_rule = css_rule)\n\n\n \n\n\n \n \n \n tinytable_l50prrvsokfllibwfvqj\n \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, align = \"ccccc\", theme = \"table mytable\") |> \n style_tt(bootstrap_css_rule = css_rule)\n\n\n \n\n\n \n \n \n tinytable_fxj76i79itgxnpd13xic\n \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", diff --git a/vignettes/tutorial.html b/vignettes/tutorial.html index 3ec5b590..afa8e5f6 100644 --- a/vignettes/tutorial.html +++ b/vignettes/tutorial.html @@ -324,7 +324,7 @@

Tiny Tables

- tinytable_459phdpq3pi51n5xwm04 + tinytable_g1379baft1mxjjfqm02x @@ -758,7 +754,7 @@

Width

- tinytable_jcjes6h0w5fcdji8ogcv + tinytable_7ipg508loojd4bew39ko @@ -1604,7 +1591,7 @@

Cells, rows, columns - tinytable_hhbdo1ew41qi4srt5wwz + tinytable_ezhoxifffzsczdenfgff @@ -1707,7 +1693,7 @@

Cells, rows, columns - tinytable_9m9qzlwdo0f6a4rel8yb + tinytable_z51rumfuzq0asshqvnk3 @@ -1824,7 +1809,7 @@

Cells, rows, columns - tinytable_3kwuagmcb33iptf2g23n + tinytable_icoq37sudgwc2upuckj9 @@ -1931,7 +1915,7 @@

Cells, rows, columns - tinytable_42dkcluzkxr9jvrpglux + tinytable_lqgofj06ondscijfi7je @@ -2036,7 +2019,7 @@

Cells, rows, columns - tinytable_4s513kqmmg9whz20aobc + tinytable_xexs0ewpy8si0dnwch3v @@ -2143,7 +2125,7 @@

Cells, rows, columns - tinytable_jjlnjzk9c0me26q9k3g9 + tinytable_kxgz2e6onwtp74gc7ya7 @@ -2261,7 +2242,7 @@

Colors

- tinytable_h3p9ghxwryi3urxktgm0 + tinytable_374doqkr2dzsrgtjq5zq @@ -2366,7 +2346,7 @@

Fonts

- tinytable_b3oasvd5nuesz03zq79e + tinytable_gbfmbfwm2c5o77x3h21h @@ -2479,7 +2458,7 @@

Spanning cells

- tinytable_hwf7pa1huxoqkce93bia + tinytable_tyzuz0ddub2hi9ikgjy1 @@ -2577,7 +2555,7 @@

Spanning cells

- tinytable_jxfufr5woogonidbatv5 + tinytable_nzdutwp4zz48anjwu78b @@ -2884,7 +2859,7 @@

Rows

- tinytable_z02tdy93hzo1ilrqixbn + tinytable_2bwocs5ftvmcrnlyl8aj @@ -3067,7 +3041,7 @@

Rows

- tinytable_33e28dfnfzps27pnmq3a + tinytable_w2ay9vgkvxjv5ig441gv @@ -3274,7 +3247,7 @@

Columns

- tinytable_gi4q9ssgsuxkguwjzqxo + tinytable_md25b0z9825cwmi1tf6y @@ -3673,7 +3644,7 @@

Themes

- tinytable_i5501xcbissrwxh588b8 + tinytable_zq2t8yxrfhlu6ba47rlb @@ -4013,7 +3981,7 @@

CSS rules

- tinytable_l50prrvsokfllibwfvqj + tinytable_fxj76i79itgxnpd13xic diff --git a/vignettes/tutorial.pdf b/vignettes/tutorial.pdf index f6b20de05b1447af49dbc5587a576e6a3d33fb66..142668989a07fd49a5303cda6c7671ecd7a9c47a 100644 GIT binary patch delta 7937 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 delta 7989 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