Using data to dynamically build your Résumé or CV makes many powerful integrations possible. By using data to populate entries in the document, it becomes easy to manipulate and select relevant experiences for a particular application. There are many sources of data which can be used to populate a CV with vitae, some commonly sources are summarised in this vignette.
The main purpose of sourcing your CV entries from common data sources is to extend the “do not repeat yourself” programming philosophy to maintaining a CV. If you maintain publications on ORCID you shouldn’t need to repeat these entries in your CV. If a list of talks you’ve made can be found on your website, avoid repeating the list in multiple locations to ensure that they both contain the same content.
This vignette is far from comprehensive, and there are no doubt many other interesting ways to populate your CV with data. If you’re using a data source that you think others should know about, consider making a pull request that adds your method to this vignette.
The simplest source of entries for vitae are maintained dataset(s) of
past experiences and achievements. Just like any dataset, these entries
can be loaded into the document as a data.frame or
tibble using functions from base R or the readr package.
readr::read_csv("employment.csv") %>% 
  detailed_entries(???)It is also possible to load in data from excel using the readxl package or
from Google Sheets using the googlesheets
package.
readxl::read_excel("awards.xlsx") %>% 
  brief_entries(???)If you maintain an ORCID profile,
this information can be accessed using the rorcid
package. It will require an ORCID authentication token to be setup,
as rendering the CV is done non-interactively. From the
rorcid documentation:
The token is a alphanumeric UUID, e.g. dc0a6b6b-b4d4-4276-bc89-78c1e9ede56e. You can get this token by running orcid_auth(), then storing that key (the uuid alone, not the “Bearer” part) either as en environment variable in your .Renviron file in your home directory, or as an R option in your .Rprofile file. See ?Startup for more information. Either an environment variable or R option work. If we don’t find either we do the next option.
Essentially, use rorcid::orcid_auth() to obtain a token,
which is added to either the .Renviron
(usethis::edit_r_environ()) or .Rprofile
(usethis::edit_r_profile()) using
ORCID_TOKEN=<YOUR TOKEN HERE>.
With the token setup, it is now possible to pull data from ORCID. As
an example, here I source and display my education history using my
ORCID ID of "0000-0001-6729-7695".
edu <- do.call("rbind",
  rorcid::orcid_educations("0000-0001-6729-7695")$`0000-0001-6729-7695`$`affiliation-group`$summaries
)
edu %>%
  detailed_entries(
    what = `education-summary.role-title`,
    when = glue::glue("{`education-summary.start-date.year.value`} - {`education-summary.end-date.year.value`}"),
    with = `education-summary.organization.name`,
    where = `education-summary.organization.address.city`
  )Google Scholar does not require authentication to extract
publications. Using the scholar
package, it is easy to extract a user’s publications from their
Google Scholar ID. To obtain publications for an individual, you would
first find your ID which is accessible from your profile URL. For
example, Rob Hyndman’s ID would be "vamErfkAAAAJ" (https://scholar.google.com/citations?user=vamErfkAAAAJ&hl=en).
scholar::get_publications("vamErfkAAAAJ") %>% 
  detailed_entries(
    what = title,
    when = year,
    with = author,
    where = journal,
    why = cites
  )The vitae package directly supports loading *.bib files
using the bibliography_entries() function, which formats
the entries in a bibliography style.
bibliography_entries("publications.bib")It is also possible to display the contents of your bibliography using template specific entries formats.
bibliography_entries("publications.bib") %>% 
  detailed_entries(???)A list of R packages that you have helped develop can be obtained
using the pkgsearch
package.
pkgsearch::ps("O'Hara-Wild",size = 100) %>%
  filter(map_lgl(package_data, ~ grepl("Mitchell O'Hara-Wild", .x$Author, fixed = TRUE))) %>% 
  as_tibble() %>% 
  brief_entries(
    what = title, 
    when = lubridate::year(date), 
    with = description
  )