Title: | Fun and Shiny and Pretty Functions |
---|---|
Description: | A personal package of R functions, ggplot themes, and other miscellany. |
Authors: | Tan Ho [aut, cre] |
Maintainer: | Tan Ho <[email protected]> |
License: | MIT + file LICENSE |
Version: | 0.2.2 |
Built: | 2024-12-27 02:41:56 UTC |
Source: | https://github.com/tanho63/tantastic |
Join two dataframes, coalescing any columns with common names
coalesce_join(x, y, by, type = c("left", "inner", "full"))
coalesce_join(x, y, by, type = c("left", "inner", "full"))
x , y
|
A pair of data frames, data frame extensions (e.g. a tibble), or lazy data frames (e.g. from dbplyr or dtplyr). See Methods, below, for more details. |
by |
A join specification created with If To join on different variables between To join by multiple variables, use a
For simple equality joins, you can alternatively specify a character vector
of variable names to join by. For example, To perform a cross-join, generating all combinations of |
Colours DT columns based on the minimum and maximum of each column. Defaults to a purple-green colour scheme HULK which is colourblind-friendly, and naturally associates "green" to "good" and "purple" to "bad".
dt_fmt_col( dt, columns, column_range = NULL, colours = c("#9162C5", "#F1F1F1", "#6BA359"), reverse_colours = FALSE, colour_steps = 100 )
dt_fmt_col( dt, columns, column_range = NULL, colours = c("#9162C5", "#F1F1F1", "#6BA359"), reverse_colours = FALSE, colour_steps = 100 )
dt |
a DT object created by |
columns |
a character or numeric vector of column identifiers (column names or indices) |
column_range |
numeric or "auto": either the minimum and maximum range to be coloured, or "auto" which defaults to the max and min of the table column. |
colours |
A set of hex colours to be passed on to |
reverse_colours |
logical: reverses direction of colour scale |
colour_steps |
number: how many distinct colours to create, default 100 |
A DT object with added colour formatting
DT::datatable(mtcars) |> # standard: formats high values as green, low values as purple dt_fmt_col(columns = c("hp", "cyl")) |> # reverse: formats low values as green, high values as purple dt_fmt_col(columns = "mpg", reverse_colours = TRUE) |> # custom colours dt_fmt_col(columns = "wt", colours = c("orange", "white", "blue"))
DT::datatable(mtcars) |> # standard: formats high values as green, low values as purple dt_fmt_col(columns = c("hp", "cyl")) |> # reverse: formats low values as green, high values as purple dt_fmt_col(columns = "mpg", reverse_colours = TRUE) |> # custom colours dt_fmt_col(columns = "wt", colours = c("orange", "white", "blue"))
Generate Shiny Inputs for a vector of identifiers
gen_input_map(uid, FUN, id_prefix = NULL, ...)
gen_input_map(uid, FUN, id_prefix = NULL, ...)
uid |
a vector of unique identifiers |
FUN |
a ShinyInput function - should theoretically work for all shinyInput functions that have |
id_prefix |
a string that will be combined with the unique identifier and passed as the inputid |
... |
other arguments to be passed to the |
a character vector of shinyInputs
gen_input_map(1:5, shiny::numericInput, id_prefix = "playerid_", label = "my_label", value = 1)
gen_input_map(1:5, shiny::numericInput, id_prefix = "playerid_", label = "my_label", value = 1)
Delete merged GitHub branches
git_cleanup()
git_cleanup()
invisible(TRUE)
This function helps add progress-reporting to any function - given function f()
and progressor p()
, it will return a new function that calls f()
and then
(on-exiting) will call p()
after every iteration. Now superseded by purrr's
map .progress
arguments.
progressively(f, p = NULL)
progressively(f, p = NULL)
f |
a function to add progressr functionality to. |
p |
a progressor function similar to that created by |
This is inspired by purrr's safely
, quietly
, and possibly
function decorators.
a function that does the same as f
but it calls p()
after iteration.
try({ urls <- c("https://github.com/nflverse/nflverse-data/releases/download/test/combines.csv", "https://github.com/nflverse/nflverse-data/releases/download/test/combines.csv") read_test_files <- function(urls){ p <- progressr::progressor(along = urls) lapply(urls, progressively(read.csv, p)) } progressr::with_progress(read_test_files(urls)) # superseded by purrr::map(urls, read.csv, .progress = TRUE) })
try({ urls <- c("https://github.com/nflverse/nflverse-data/releases/download/test/combines.csv", "https://github.com/nflverse/nflverse-data/releases/download/test/combines.csv") read_test_files <- function(urls){ p <- progressr::progressor(along = urls) lapply(urls, progressively(read.csv, p)) } progressr::with_progress(read_test_files(urls)) # superseded by purrr::map(urls, read.csv, .progress = TRUE) })
Read a sequence of Shiny Inputs
read_inputs( inputid = NULL, nullarg = NA, type = c("chr", "dbl", "lgl", "int"), .env = shiny::getDefaultReactiveDomain() )
read_inputs( inputid = NULL, nullarg = NA, type = c("chr", "dbl", "lgl", "int"), .env = shiny::getDefaultReactiveDomain() )
inputid |
a vector of inputids to read |
nullarg |
the value to return if the input value is |
type |
one of |
.env |
the environment to look for the input - defaults to the default reactive domain |
a vector of values
if(interactive()){ read_inputs(inputid = c("select_1", "select_2"), nullarg = NA, type = "chr") }
if(interactive()){ read_inputs(inputid = c("select_1", "select_2"), nullarg = NA, type = "chr") }
Update geom defaults
set_geom_colour_defaults(colour = "#57c1f1")
set_geom_colour_defaults(colour = "#57c1f1")
colour |
colour of geom default |
Updates ggplot2::geom_label and ggplot2::geom_text font defaults
set_geom_font_defaults( family = "IBM Plex Sans", face = "plain", size = 3.5, color = "#2b2b2b" )
set_geom_font_defaults( family = "IBM Plex Sans", face = "plain", size = 3.5, color = "#2b2b2b" )
family , face , size , color
|
font family name, face, size and color |
Wraps utils::str()
but defaults to max.level = 2
str(..., max.level = 2)
str(..., max.level = 2)
... |
objects passed to str |
max.level |
sets max.level - by default, 2 |
output of utils::str() but defaults to max.level = 2
list( data = list( mtcars = data.frame(mtcars), airquality = data.frame(airquality) ) ) |> str()
list( data = list( mtcars = data.frame(mtcars), airquality = data.frame(airquality) ) ) |> str()
Largely inspired by hrbrthemes's modern rc with other stuff.
theme_tantastic( base_family = "IBM Plex Sans Condensed", base_size = 11.5, plot_title_family = "Bai Jamjuree", plot_title_size = 18, plot_title_face = "bold", plot_title_margin = 10, subtitle_family = base_family, subtitle_size = 14, subtitle_face = "plain", subtitle_margin = 15, strip_text_family = base_family, strip_text_size = 14, strip_text_face = "plain", caption_family = plot_title_family, caption_size = 14, caption_face = "plain", caption_margin = 14, axis_text_size = base_size, axis_title_family = base_family, axis_title_size = 12, axis_title_face = "plain", axis_title_just = "rt", plot_margin = ggplot2::margin(30, 30, 30, 30), grid = TRUE, axis = FALSE, ticks = FALSE )
theme_tantastic( base_family = "IBM Plex Sans Condensed", base_size = 11.5, plot_title_family = "Bai Jamjuree", plot_title_size = 18, plot_title_face = "bold", plot_title_margin = 10, subtitle_family = base_family, subtitle_size = 14, subtitle_face = "plain", subtitle_margin = 15, strip_text_family = base_family, strip_text_size = 14, strip_text_face = "plain", caption_family = plot_title_family, caption_size = 14, caption_face = "plain", caption_margin = 14, axis_text_size = base_size, axis_title_family = base_family, axis_title_size = 12, axis_title_face = "plain", axis_title_just = "rt", plot_margin = ggplot2::margin(30, 30, 30, 30), grid = TRUE, axis = FALSE, ticks = FALSE )
base_family , base_size
|
base font family and size |
plot_title_family , plot_title_face , plot_title_size , plot_title_margin
|
plot title family, face, size and margi |
subtitle_family , subtitle_face , subtitle_size
|
plot subtitle family, face and size |
subtitle_margin |
plot subtitle margin bottom (single numeric value) |
strip_text_family , strip_text_face , strip_text_size
|
facet label font family, face and size |
caption_family , caption_face , caption_size , caption_margin
|
plot caption family, face, size and margin |
axis_text_size |
font size of axis text |
axis_title_family , axis_title_face , axis_title_size
|
axis title font family, face and size |
axis_title_just |
axis title font justification, one of |
plot_margin |
plot margin (specify with |
grid |
panel grid ( |
axis |
add x or y axes? |
ticks |
ticks if |
## Not run: library(ggplot2) library(dplyr) # seminal scatterplot ggplot(mtcars, aes(mpg, wt)) + geom_point() + labs(x="Fuel efficiency (mpg)", y="Weight (tons)", title="Seminal ggplot2 scatterplot example", subtitle="A plot that is only useful for demonstration purposes", caption="Brought to you by the letter 'g'") + theme_tantastic() # seminal bar chart count(mpg, class) |> ggplot(aes(class, n)) + geom_col() + geom_text(aes(label=n), nudge_y=3) + labs(x="Fuel efficiency (mpg)", y="Weight (tons)", title="Seminal ggplot2 bar chart example", subtitle="A plot that is only useful for demonstration purposes", caption="Brought to you by the letter 'g'") + theme_tantastic(grid="Y") + theme(axis.text.y=element_blank()) ## End(Not run)
## Not run: library(ggplot2) library(dplyr) # seminal scatterplot ggplot(mtcars, aes(mpg, wt)) + geom_point() + labs(x="Fuel efficiency (mpg)", y="Weight (tons)", title="Seminal ggplot2 scatterplot example", subtitle="A plot that is only useful for demonstration purposes", caption="Brought to you by the letter 'g'") + theme_tantastic() # seminal bar chart count(mpg, class) |> ggplot(aes(class, n)) + geom_col() + geom_text(aes(label=n), nudge_y=3) + labs(x="Fuel efficiency (mpg)", y="Weight (tons)", title="Seminal ggplot2 bar chart example", subtitle="A plot that is only useful for demonstration purposes", caption="Brought to you by the letter 'g'") + theme_tantastic(grid="Y") + theme(axis.text.y=element_blank()) ## End(Not run)
Largely inspired by hrbrthemes's modern rc with other stuff.
theme_uv( base_family = "IBM Plex Sans Condensed", base_size = 11.5, plot_title_family = "Bai Jamjuree", plot_title_size = 18, plot_title_face = "bold", plot_title_margin = 10, subtitle_family = base_family, subtitle_size = 14, subtitle_face = "plain", subtitle_margin = 15, strip_text_family = base_family, strip_text_size = 14, strip_text_face = "plain", caption_family = plot_title_family, caption_size = 14, caption_face = "plain", caption_margin = 14, axis_text_size = base_size, axis_title_family = base_family, axis_title_size = 12, axis_title_face = "plain", axis_title_just = "rt", plot_margin = ggplot2::margin(30, 30, 30, 30), grid = TRUE, axis = FALSE, ticks = FALSE )
theme_uv( base_family = "IBM Plex Sans Condensed", base_size = 11.5, plot_title_family = "Bai Jamjuree", plot_title_size = 18, plot_title_face = "bold", plot_title_margin = 10, subtitle_family = base_family, subtitle_size = 14, subtitle_face = "plain", subtitle_margin = 15, strip_text_family = base_family, strip_text_size = 14, strip_text_face = "plain", caption_family = plot_title_family, caption_size = 14, caption_face = "plain", caption_margin = 14, axis_text_size = base_size, axis_title_family = base_family, axis_title_size = 12, axis_title_face = "plain", axis_title_just = "rt", plot_margin = ggplot2::margin(30, 30, 30, 30), grid = TRUE, axis = FALSE, ticks = FALSE )
base_family , base_size
|
base font family and size |
plot_title_family , plot_title_face , plot_title_size , plot_title_margin
|
plot title family, face, size and margi |
subtitle_family , subtitle_face , subtitle_size
|
plot subtitle family, face and size |
subtitle_margin |
plot subtitle margin bottom (single numeric value) |
strip_text_family , strip_text_face , strip_text_size
|
facet label font family, face and size |
caption_family , caption_face , caption_size , caption_margin
|
plot caption family, face, size and margin |
axis_text_size |
font size of axis text |
axis_title_family , axis_title_face , axis_title_size
|
axis title font family, face and size |
axis_title_just |
axis title font justification, one of |
plot_margin |
plot margin (specify with |
grid |
panel grid ( |
axis |
add x or y axes? |
ticks |
ticks if |
## Not run: library(ggplot2) library(dplyr) # seminal scatterplot ggplot(mtcars, aes(mpg, wt)) + geom_point() + labs(x="Fuel efficiency (mpg)", y="Weight (tons)", title="Seminal ggplot2 scatterplot example", subtitle="A plot that is only useful for demonstration purposes", caption="Brought to you by the letter 'g'") + theme_uv() # seminal bar chart count(mpg, class) |> ggplot(aes(class, n)) + geom_col() + geom_text(aes(label=n), nudge_y=3) + labs(x="Fuel efficiency (mpg)", y="Weight (tons)", title="Seminal ggplot2 bar chart example", subtitle="A plot that is only useful for demonstration purposes", caption="Brought to you by the letter 'g'") + theme_uv(grid="Y") + theme(axis.text.y=element_blank()) ## End(Not run)
## Not run: library(ggplot2) library(dplyr) # seminal scatterplot ggplot(mtcars, aes(mpg, wt)) + geom_point() + labs(x="Fuel efficiency (mpg)", y="Weight (tons)", title="Seminal ggplot2 scatterplot example", subtitle="A plot that is only useful for demonstration purposes", caption="Brought to you by the letter 'g'") + theme_uv() # seminal bar chart count(mpg, class) |> ggplot(aes(class, n)) + geom_col() + geom_text(aes(label=n), nudge_y=3) + labs(x="Fuel efficiency (mpg)", y="Weight (tons)", title="Seminal ggplot2 bar chart example", subtitle="A plot that is only useful for demonstration purposes", caption="Brought to you by the letter 'g'") + theme_uv(grid="Y") + theme(axis.text.y=element_blank()) ## End(Not run)
unbind_dt_js()
adds the JS to the UI, while unbind_dt()
is called as needed in the server component
(usually as part of an observeEvent
or eventReactive
)Unbind Shiny Inputs (server function)
When generating inputs reactively, it's sometimes necessary to unbind old inputs so that you can use the updated inputs in Shiny.
'unbind_dt_js()
adds the JS to the UI, while unbind_dt()
is called as needed in the server component
(usually as part of an observeEvent
or eventReactive
)
unbind_dt(dt_name, session = shiny::getDefaultReactiveDomain())
unbind_dt(dt_name, session = shiny::getDefaultReactiveDomain())
dt_name |
String representing the table's output ID (i.e. to unbind in output$table_alpha, use "table_alpha" as the parameter) |
session |
a |
a call to the JS that unbinds dt_name
When generating inputs reactively, it's sometimes necessary to unbind old inputs so that you can use the updated inputs in Shiny.
'unbind_dt_js()
adds the JS to the UI, while unbind_dt()
is called as needed in the server component
(usually as part of an observeEvent
or eventReactive
)
unbind_dt_js()
unbind_dt_js()
Adds JS to HTML head
Uses some Javascript to pass the client's timezone to the Shiny session.
use_client_tz(inputId = "_client_tz") get_client_tz( inputId = "_client_tz", session = shiny::getDefaultReactiveDomain() )
use_client_tz(inputId = "_client_tz") get_client_tz( inputId = "_client_tz", session = shiny::getDefaultReactiveDomain() )
inputId |
character string, name of shiny input. Defaults to "_client_tz".
When used in |
session |
a |
use_client_tz()
: HTML tags to be included in Shiny UI
timezone
if(interactive()){ shiny::shinyApp( ui = shiny::fluidPage(use_client_tz(), shiny::textOutput("time")), server = function(input, output, session) { # can be used outside of reactive context, if desired tz <- get_client_tz() time <- format(Sys.time(), format = "%x %X", tz = tz) output$time <- renderText(paste0(tz,": ", time)) } ) }
if(interactive()){ shiny::shinyApp( ui = shiny::fluidPage(use_client_tz(), shiny::textOutput("time")), server = function(input, output, session) { # can be used outside of reactive context, if desired tz <- get_client_tz() time <- format(Sys.time(), format = "%x %X", tz = tz) output$time <- renderText(paste0(tz,": ", time)) } ) }