View source: R/sprinkle_fixed_header.R
sprinkle_fixed_header | R Documentation |
Long tables to be displayed on-screen may benefit by keeping the header fixed in position while scrolling through the body of the table. This allows the user to maintain visual contact between the column name and the data.
sprinkle_fixed_header(
x,
fixed_header = TRUE,
include_fixed_header_css = TRUE,
fixed_header_class_name = "pixie-fixed",
scroll_body_height = 300,
scroll_body_height_units = "px",
scroll_body_background_color = "white",
fixed_header_height = 20,
fixed_header_height_units = "px",
fixed_header_text_height = fixed_header_height/2,
fixed_header_text_height_units = "px",
fixed_header_background_color = "white",
...
)
## Default S3 method:
sprinkle_fixed_header(
x,
fixed_header = TRUE,
include_fixed_header_css = TRUE,
fixed_header_class_name = "pixie-fixed",
scroll_body_height = 300,
scroll_body_height_units = "px",
scroll_body_background_color = "white",
fixed_header_height = 20,
fixed_header_height_units = "px",
fixed_header_text_height = fixed_header_height/2,
fixed_header_text_height_units = "px",
fixed_header_background_color = "white",
...
)
## S3 method for class 'dust_list'
sprinkle_fixed_header(
x,
fixed_header = TRUE,
include_fixed_header_css = TRUE,
fixed_header_class_name = "pixie-fixed",
scroll_body_height = 300,
scroll_body_height_units = "px",
scroll_body_background_color = "white",
fixed_header_height = 20,
fixed_header_height_units = "px",
fixed_header_text_height = fixed_header_height/2,
fixed_header_text_height_units = "px",
fixed_header_background_color = "white",
...
)
x |
An object of class |
fixed_header |
|
include_fixed_header_css |
|
fixed_header_class_name |
|
scroll_body_height |
|
scroll_body_height_units |
|
scroll_body_background_color |
|
fixed_header_height |
|
fixed_header_height_units |
|
fixed_header_text_height |
|
fixed_header_text_height_units |
|
fixed_header_background_color |
|
... |
Arguments to pass to other methods. |
CSS doesn't make this kind of table natural. The solution to
generate the fixed headers used by pixiedust
is probably not the
best solution in terms of CSS design. It is, however, the most conducive
to generating dynamically on the fly.
The fixed header table requires nesting several HTML elements.
a div
tag is used to control the alignment of the table
a section
tag is used to set up the header row that remains fixed.
a div
that sets the height of the scrollable body
the table
tag establishes the actual table.
The th
tags inside the table are set to full transparency and
the content of the headers is duplicated in a div
within the
th
tag to display the content.
To accomplish these tasks, some CSS is exported with the table and placed in the document immediately before the table. Read further to understand the conflicts that may arise if you are using custom CSS specifications in your documents.
Because of all of the shenanigans involved, exporting the CSS with the tables
may result in conflicts with your custom CSS. Most importantly, any CSS
you have applied to the th
or td
tags may be overwritten.
If you are using custom CSS, you may want to consider using
include_fixed_header_css = FALSE
and then utilizing
fixed_header_css
to generate CSS you can include in your
CSS file to provide the fixed headers. The code generated by
fixed_header_css
ought to be placed before your definitions for
td
and th
.
To get the same header design in the fixed table, you will want to modify
the .th-pixie-fixed div
definition in the CSS to match your desired
th
definition.
The code produced by fixed_header_css
will include comments where
there is potential for a CSS conflict.
Set the fixed_header
element of the dust
object correctly.
Set the include_fixed_header_css
element of the dust
object correctly.
Set the fixed_header_param
element of the dust
object
correctly.
Cast an error if x
does not inherit class dust
Cast an error if scroll_body_height
is not integerish(1)
Cast an error if scroll_body_height_units
is not character(1)
Cast an error if scroll_body_background_color
is not character(1)
Cast an error if scroll_body_background_color
is not a valid color.
Cast an error if fixed_header_height
is not integerish(1)
Cast an error if fixed_header_height_units
is not character(1)
Cast an error if fixed_header_text_height
is not numeric(1)
Cast an error if fixed_header_text_height_units
is not character(1)
Cast an error if fixed_header_background_color
is not character(1)
Cast an error if fixed_header_background_color
is not a valid color.
Cast an error if include_fixed_header_css
is not logical(1)
Cast an error if fixed_header_class_name
is not character(1)
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.