Code
library(tidyverse)
library(targets)
library(scales)

tar_config_set(store = here::here('_targets'),
               script = here::here('_targets.R'))

# Load graphics functions from targets
invisible(list2env(tar_read(graphic_functions), .GlobalEnv))

show_nice_pal <- function(pal, nrow = 1, show_text = TRUE) {
  out <- tibble(x = 1:length(pal),
                color = pal) %>% 
    mutate(x_nice = glue::glue("[{x}]")) %>% 
    mutate(across(c(color, x_nice), ~fct_inorder(.))) %>% 
    ggplot(aes(x = color, y = 1, fill = color)) +
    geom_tile() +
    scale_x_discrete(expand = c(0, 0)) +
    scale_fill_identity() +
    facet_wrap(vars(x_nice), scales = "free_x", nrow = nrow) +
    theme_void(base_family = "Inconsolata") +
    theme(panel.spacing.x = unit(-1, units = "pt"),
          panel.spacing.y = unit(-0.5, units = "lines"),
          strip.text = element_blank())
  
  if (show_text) {
    out <- out + 
      theme(axis.text.x = element_text(margin = margin(b = 5)),
            strip.text = element_text(size = rel(1.1), margin = margin(t = 5)),
            panel.spacing.y = unit(0, units = "lines"))
  }
  
  return(out)
}

Fonts

We use Libre Franklin (accessible for free from Google Fonts) as the main font in all our plots.

Libre Franklin

Whereas recognition of the inherent dignity and of the equal and inalienable rights of all members of the human family is the foundation of freedom, justice and peace in the world…

In the fancy preprint version of our manuscript we use Linux Libertine for the main body font, since it fits with Libertinus Math for fancier math typesetting.

Linux Libertine

Whereas recognition of the inherent dignity and of the equal and inalienable rights of all members of the human family is the foundation of freedom, justice and peace in the world…

Colors

Palettes

Prism (clrs$prism)

Our main palette is the qualitative Prism palette from CARTOColors. CARTOColors palettes were designed for data-focused map visualizations,but can be used in any kind of visualization, similar to ColorBrewer.

Access the palette using clrs$prism, and access specific colors with indexes like clrs$prism[8]:

Code
clrs$prism %>% set_names(1:length(.))
##         1         2         3         4         5         6         7         8 
## "#5F4690" "#1D6996" "#38A6A5" "#0F8554" "#73AF48" "#EDAD08" "#E17C05" "#CC503E" 
##         9        10        11        12 
## "#94346E" "#6F4070" "#994E95" "#666666"

 

Single-ish-color sequential palettes

In some cases, like with plots that use geom_lineribbon(), we use a range of sequential colors. For these, we use several different sequential palettes from CARTOColors since they tend to match the color scheme from clrs$prism.

Peach (clrs$peach)

Code
clrs$peach %>% set_names(1:length(.))
##         1         2         3         4         5         6         7 
## "#FDE0C5" "#FACBA6" "#F8B58B" "#F59E72" "#F2855D" "#EF6A4C" "#EB4A40"

Color mappings

TODO: Color sets for specific features/levels/contrasts