diff --git a/.Rbuildignore b/.Rbuildignore index 2a0cf9e..918f12e 100644 --- a/.Rbuildignore +++ b/.Rbuildignore @@ -8,3 +8,4 @@ ^codecov\.yml$ ^_pkgdown\.yml$ ^docs$ +^\.github$ diff --git a/.github/.gitignore b/.github/.gitignore new file mode 100644 index 0000000..2d19fc7 --- /dev/null +++ b/.github/.gitignore @@ -0,0 +1 @@ +*.html diff --git a/.github/workflows/R-CMD-check.yaml b/.github/workflows/R-CMD-check.yaml new file mode 100644 index 0000000..10c51d1 --- /dev/null +++ b/.github/workflows/R-CMD-check.yaml @@ -0,0 +1,81 @@ +# For help debugging build failures open an issue on the RStudio community with the 'github-actions' tag. +# https://community.rstudio.com/new-topic?category=Package%20development&tags=github-actions +on: + push: + branches: + - master + pull_request: + branches: + - master + +name: R-CMD-check + +jobs: + R-CMD-check: + runs-on: ${{ matrix.config.os }} + + name: ${{ matrix.config.os }} (${{ matrix.config.r }}) + + strategy: + fail-fast: false + matrix: + config: + - {os: windows-latest, r: 'release'} + - {os: macOS-latest, r: 'release'} + - {os: ubuntu-20.04, r: 'release', rspm: "https://packagemanager.rstudio.com/cran/__linux__/focal/latest"} + - {os: ubuntu-20.04, r: 'devel', rspm: "https://packagemanager.rstudio.com/cran/__linux__/focal/latest"} + + env: + R_REMOTES_NO_ERRORS_FROM_WARNINGS: true + RSPM: ${{ matrix.config.rspm }} + + steps: + - uses: actions/checkout@v2 + + - uses: r-lib/actions/setup-r@master + with: + r-version: ${{ matrix.config.r }} + + - uses: r-lib/actions/setup-pandoc@master + + - name: Query dependencies + run: | + install.packages('remotes') + saveRDS(remotes::dev_package_deps(dependencies = TRUE), ".github/depends.Rds", version = 2) + writeLines(sprintf("R-%i.%i", getRversion()$major, getRversion()$minor), ".github/R-version") + shell: Rscript {0} + + - name: Cache R packages + if: runner.os != 'Windows' + uses: actions/cache@v2 + with: + path: ${{ env.R_LIBS_USER }} + key: ${{ runner.os }}-${{ hashFiles('.github/R-version') }}-1-${{ hashFiles('.github/depends.Rds') }} + restore-keys: ${{ runner.os }}-${{ hashFiles('.github/R-version') }}-1- + + - name: Install system dependencies + if: runner.os == 'Linux' + run: | + while read -r cmd + do + eval sudo $cmd + done < <(Rscript -e 'writeLines(remotes::system_requirements("ubuntu", "20.04"))') + + - name: Install dependencies + run: | + remotes::install_deps(dependencies = TRUE) + remotes::install_cran("rcmdcheck") + shell: Rscript {0} + + - name: Check + env: + _R_CHECK_CRAN_INCOMING_REMOTE_: false + run: rcmdcheck::rcmdcheck(args = c("--no-manual", "--as-cran"), error_on = "warning", check_dir = "check") + shell: Rscript {0} + + - name: Upload check results + if: failure() + uses: actions/upload-artifact@main + with: + name: ${{ runner.os }}-r${{ matrix.config.r }}-results + path: check diff --git a/.github/workflows/pkgdown.yaml b/.github/workflows/pkgdown.yaml new file mode 100644 index 0000000..5871380 --- /dev/null +++ b/.github/workflows/pkgdown.yaml @@ -0,0 +1,46 @@ +on: + push: + branches: master + +name: pkgdown + +jobs: + pkgdown: + runs-on: macOS-latest + env: + GITHUB_PAT: ${{ secrets.GITHUB_TOKEN }} + steps: + - uses: actions/checkout@v2 + + - uses: r-lib/actions/setup-r@master + + - uses: r-lib/actions/setup-pandoc@master + + - name: Query dependencies + run: | + install.packages('remotes') + saveRDS(remotes::dev_package_deps(dependencies = TRUE), ".github/depends.Rds", version = 2) + writeLines(sprintf("R-%i.%i", getRversion()$major, getRversion()$minor), ".github/R-version") + shell: Rscript {0} + + - name: Cache R packages + uses: actions/cache@v2 + with: + path: ${{ env.R_LIBS_USER }} + key: ${{ runner.os }}-${{ hashFiles('.github/R-version') }}-1-${{ hashFiles('.github/depends.Rds') }} + restore-keys: ${{ runner.os }}-${{ hashFiles('.github/R-version') }}-1- + + - name: Install dependencies + run: | + remotes::install_deps(dependencies = TRUE) + install.packages("pkgdown") + shell: Rscript {0} + + - name: Install package + run: R CMD INSTALL . + + - name: Deploy package + run: | + git config --local user.email "actions@github.com" + git config --local user.name "GitHub Actions" + Rscript -e 'pkgdown::deploy_to_branch(new_process = FALSE)' diff --git a/.travis.yml b/.travis.yml deleted file mode 100644 index b8455a4..0000000 --- a/.travis.yml +++ /dev/null @@ -1,16 +0,0 @@ -# R for travis: see documentation at https://docs.travis-ci.com/user/languages/r - -language: R -sudo: false -cache: packages - -matrix: - include: - - r: devel - - r: release - before_deploy: Rscript -e 'remotes::install_cran("pkgdown")' - deploy: - provider: script - script: Rscript -e 'pkgdown::deploy_site_github()' - skip_cleanup: true - - r: oldrel diff --git a/DESCRIPTION b/DESCRIPTION index d0d643a..63f1da9 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,6 +1,6 @@ Package: vembedr Title: Embed Video in HTML -Version: 0.1.3.9000 +Version: 0.1.3.9001 Authors@R: c( person( given = "Ian", @@ -27,7 +27,7 @@ Imports: glue, assertthat, utils -RoxygenNote: 6.1.1 +RoxygenNote: 7.1.1 URL: https://github.com/ijlyttle/vembedr BugReports: https://github.com/ijlyttle/vembedr/issues Suggests: diff --git a/R/parse.R b/R/parse.R index 7bce50a..54a9145 100644 --- a/R/parse.R +++ b/R/parse.R @@ -174,29 +174,23 @@ get_service <- function(url) { #' parse_video_url <- function(url) { - list_parse <- list( - channel9 = .parse_channel9, - youtube = .parse_youtube, - youtube_short = .parse_youtube_short, - vimeo = .parse_vimeo, - box = .parse_box - ) - service <- get_service(url) url_parsed <- httr::parse_url(url) + class(url_parsed) <- c(glue::glue("vembedr_{service}")) - # idea: - # - this could be done more-conventionally using S3 dispatch - # - get_service() could return a parsed url with additional class - # - fn_parse <- list_parse[[service]] + .parse(url_parsed) +} - do.call(fn_parse, list(url_parsed = url_parsed)) +.parse <- function(url_parsed, ...) { + UseMethod(".parse") +} +.parse.default <- function(url_parsed, ...) { + stop("no method available") } -.parse_youtube <- function(url_parsed) { +.parse.vembedr_youtube <- function(url_parsed, ...) { list( service = "youtube", id = url_parsed$query$v, @@ -204,7 +198,7 @@ parse_video_url <- function(url) { ) } -.parse_youtube_short <- function(url_parsed) { +.parse.vembedr_youtube_short <- function(url_parsed, ...) { list( service = "youtube", id = url_parsed$path, @@ -212,7 +206,7 @@ parse_video_url <- function(url) { ) } -.parse_vimeo <- function(url_parsed){ +.parse.vembedr_vimeo <- function(url_parsed, ...){ start_time <- NULL if (!is.null(url_parsed$fragment)){ @@ -226,7 +220,7 @@ parse_video_url <- function(url) { ) } -.parse_channel9 <- function(url_parsed){ +.parse.vembedr_channel9 <- function(url_parsed, ...){ path_split <- url_parsed$path %>% @@ -270,7 +264,7 @@ parse_video_url <- function(url) { result } -.parse_box <- function(url_parsed) { +.parse.vembedr_box <- function(url_parsed, ...) { # determine custom-domain by taking apart hostname hostname_split <- stringr::str_split(url_parsed$hostname, "\\.")[[1]] diff --git a/README.Rmd b/README.Rmd index 402ffda..5751ec9 100644 --- a/README.Rmd +++ b/README.Rmd @@ -6,10 +6,12 @@ output: # vembedr -[![CRAN_Status_Badge](https://www.r-pkg.org/badges/version/vembedr)](https://cran.r-project.org/package=vembedr) -[![Travis-CI Build Status](https://travis-ci.org/ijlyttle/vembedr.svg?branch=master)](https://travis-ci.org/ijlyttle/vembedr) -[![lifecycle](https://img.shields.io/badge/lifecycle-maturing-blue.svg)](https://www.tidyverse.org/lifecycle/#maturing) - + + [![CRAN_Status_Badge](https://www.r-pkg.org/badges/version/vembedr)](https://cran.r-project.org/package=vembedr) + [![R build status](https://github.com/ijlyttle/vembedr/workflows/R-CMD-check/badge.svg)](https://github.com/ijlyttle/vembedr/actions) + [![lifecycle](https://img.shields.io/badge/lifecycle-maturing-blue.svg)](https://www.tidyverse.org/lifecycle/#maturing) + + ```{r, echo = FALSE} library("htmltools") library("vembedr") diff --git a/man/embed.Rd b/man/embed.Rd index f2cc0c8..3245c75 100644 --- a/man/embed.Rd +++ b/man/embed.Rd @@ -10,25 +10,63 @@ \alias{embed_box} \title{Embed a video into an HTML document} \usage{ -embed_vimeo(id, width = NULL, height = 300, ratio = c("16by9", - "4by3"), frameborder = 0, allowfullscreen = TRUE, query = NULL, - fragment = NULL) +embed_vimeo( + id, + width = NULL, + height = 300, + ratio = c("16by9", "4by3"), + frameborder = 0, + allowfullscreen = TRUE, + query = NULL, + fragment = NULL +) -embed_youtube(id, width = NULL, height = 300, ratio = c("16by9", - "4by3"), frameborder = 0, allowfullscreen = TRUE, query = NULL) +embed_youtube( + id, + width = NULL, + height = 300, + ratio = c("16by9", "4by3"), + frameborder = 0, + allowfullscreen = TRUE, + query = NULL +) -embed_user2016(id, width = NULL, height = 300, ratio = c("16by9", - "4by3"), frameborder = 0, allowfullscreen = TRUE) +embed_user2016( + id, + width = NULL, + height = 300, + ratio = c("16by9", "4by3"), + frameborder = 0, + allowfullscreen = TRUE +) -embed_user2017(id, width = NULL, height = 300, ratio = c("16by9", - "4by3"), frameborder = 0, allowfullscreen = TRUE) +embed_user2017( + id, + width = NULL, + height = 300, + ratio = c("16by9", "4by3"), + frameborder = 0, + allowfullscreen = TRUE +) -embed_channel9(id, width = NULL, height = 300, ratio = c("16by9", - "4by3"), frameborder = 0, allowfullscreen = TRUE) +embed_channel9( + id, + width = NULL, + height = 300, + ratio = c("16by9", "4by3"), + frameborder = 0, + allowfullscreen = TRUE +) -embed_box(id, custom_domain = getOption("vembedr.box_custom_domain"), - width = NULL, height = 300, ratio = c("16by9", "4by3"), - frameborder = 0, allowfullscreen = TRUE) +embed_box( + id, + custom_domain = getOption("vembedr.box_custom_domain"), + width = NULL, + height = 300, + ratio = c("16by9", "4by3"), + frameborder = 0, + allowfullscreen = TRUE +) } \arguments{ \item{id}{character, identifier provided by the service} @@ -37,7 +75,7 @@ embed_box(id, custom_domain = getOption("vembedr.box_custom_domain"), \item{height}{numeric, height of iframe (px)} -\item{ratio}{\code{character}, indicates aspect ratio for the \code{}} +\item{ratio}{\code{character}, indicates aspect ratio for the \verb{}} \item{frameborder}{numeric, size of frame border (px)} @@ -54,7 +92,7 @@ the standard Box instance.} } \value{ object with class \code{vembedr_embed}, -prints to an 'HTML' \code{
} that contains an \code{} +prints to an 'HTML' \verb{} that contains an \verb{} } \description{ These functions are used to embed video into your \strong{rmarkdown} html-documents, diff --git a/man/iframe.Rd b/man/iframe.Rd index 4655df1..8a5c676 100644 --- a/man/iframe.Rd +++ b/man/iframe.Rd @@ -31,7 +31,7 @@ set_iframe(embed, ...) } \value{ \describe{ -\item{get_iframe}{\code{shiny.tag} with \code{name} \code{"iframe"}, created using \link[htmltools:tags]{htmltools::tags}\code{$iframe()}} +\item{get_iframe}{\code{shiny.tag} with \code{name} \code{"iframe"}, created using \link[htmltools:builder]{htmltools::tags}\verb{$iframe()}} \item{set_iframe}{\code{embed} object} } } diff --git a/man/pipe.Rd b/man/pipe.Rd index c9fd007..f5b4359 100644 --- a/man/pipe.Rd +++ b/man/pipe.Rd @@ -7,7 +7,7 @@ \item{lhs, rhs}{An embed object and a function to apply to it} } \description{ -Like dplyr, vembedr also uses the pipe function, \code{\\\%>\\\%} to turn +Like dplyr, vembedr also uses the pipe function, \verb{\\\%>\\\%} to turn function composition into a series of imperative statements. } \examples{ diff --git a/man/use_align.Rd b/man/use_align.Rd index 92f8822..3cdad95 100644 --- a/man/use_align.Rd +++ b/man/use_align.Rd @@ -13,9 +13,9 @@ use_align(embed, align = c("left", "right", "center", "justified")) } \value{ object with class \code{vembedr_embed}, -prints to an 'HTML' \code{} that contains an \code{} +prints to an 'HTML' \verb{} that contains an \verb{} } \description{ -Use this function to specify the horizontal alignment of the \code{} -within the enclosing \code{}. +Use this function to specify the horizontal alignment of the \verb{} +within the enclosing \verb{}. } diff --git a/man/use_bs_responsive.Rd b/man/use_bs_responsive.Rd index 137134d..ca99bb7 100644 --- a/man/use_bs_responsive.Rd +++ b/man/use_bs_responsive.Rd @@ -11,8 +11,8 @@ use_bs_responsive(embed) } \value{ object with class \code{vembedr_embed}, -prints to an 'HTML' \code{} that contains an \code{} +prints to an 'HTML' \verb{} that contains an \verb{} } \description{ -If your 'HTML\code{page includes [Twitter Bootstrap 3](https://getbootstrap.com/docs/3.3/components/#responsive-embed), you can use this function to make the size of the}\code{responsive within the enclosing}`. +If your 'HTML\verb{page includes [Twitter Bootstrap 3](https://getbootstrap.com/docs/3.3/components/#responsive-embed), you can use this function to make the size of the}\verb{responsive within the enclosing}`. } diff --git a/man/use_rounded.Rd b/man/use_rounded.Rd index 5dca9cd..b4460c4 100644 --- a/man/use_rounded.Rd +++ b/man/use_rounded.Rd @@ -10,12 +10,12 @@ use_rounded(embed, radius = NULL) \item{embed}{\code{vembedr_embed} object, created using an \code{\link[=embed]{embed()}} function} \item{radius}{\code{numeric} or \code{character}, css property for the border-radius -for the \code{}. Numeric values will be interpreted as number of pixels.} +for the \verb{}. Numeric values will be interpreted as number of pixels.} } \value{ object with class \code{vembedr_embed}, -prints to an 'HTML' \code{} that contains an \code{} +prints to an 'HTML' \verb{} that contains an \verb{} } \description{ -You can use this function to make rounded corners for the enclosing \code{}. +You can use this function to make rounded corners for the enclosing \verb{}. } diff --git a/man/use_start_time.Rd b/man/use_start_time.Rd index 67f2c15..2a78c9e 100644 --- a/man/use_start_time.Rd +++ b/man/use_start_time.Rd @@ -17,8 +17,7 @@ use_start_time(...) \method{use_start_time}{vembedr_embed_vimeo}(embed, start_time, ...) -\method{use_start_time}{vembedr_embed_channel9}(embed, start_time, - is_paused = TRUE, ...) +\method{use_start_time}{vembedr_embed_channel9}(embed, start_time, is_paused = TRUE, ...) \method{use_start_time}{vembedr_embed_box}(embed, ...) } @@ -34,7 +33,7 @@ should be paused at this time} } \value{ object with class \code{vembedr_embed}, -prints to an 'HTML' \code{} that contains an \code{} +prints to an 'HTML' \verb{} that contains an \verb{} } \description{ This function provides you a consistent way to specify the start time, diff --git a/man/vembedr.Rd b/man/vembedr.Rd index a41c389..aea67a2 100644 --- a/man/vembedr.Rd +++ b/man/vembedr.Rd @@ -3,7 +3,6 @@ \docType{package} \name{vembedr} \alias{vembedr} -\alias{vembedr-package} \title{vembedr: A package for embedding video} \description{ The vembedr package provides two categories of functions: