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..856093b
--- /dev/null
+++ b/.github/workflows/R-CMD-check.yaml
@@ -0,0 +1,57 @@
+# Workflow derived from https://github.com/r-lib/actions/tree/v2/examples
+# Need help debugging build failures? Start at https://github.com/r-lib/actions#where-to-find-help
+on:
+ push:
+ branches: [main, master]
+ pull_request:
+ branches: [main, master]
+ schedule:
+ - cron: "0 6 * * 1"
+
+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: macos-latest, r: 'release'}
+ - {os: windows-latest, r: 'release'}
+ - {os: ubuntu-latest, r: 'devel', http-user-agent: 'release'}
+ - {os: ubuntu-latest, r: 'release'}
+ - {os: ubuntu-latest, r: 'oldrel-1'}
+
+ env:
+ GITHUB_PAT: ${{ secrets.GITHUB_TOKEN }}
+ R_KEEP_PKG_SOURCE: yes
+
+ steps:
+ - uses: actions/checkout@v3
+
+ - uses: r-lib/actions/setup-pandoc@v2
+
+ - uses: r-lib/actions/setup-r@v2
+ with:
+ r-version: ${{ matrix.config.r }}
+ http-user-agent: ${{ matrix.config.http-user-agent }}
+ use-public-rspm: true
+
+ - uses: r-lib/actions/setup-r-dependencies@v2
+ with:
+ extra-packages: any::rcmdcheck
+ needs: check
+
+ - uses: r-lib/actions/check-r-package@v2
+ with:
+ upload-snapshots: true
+
+ - name: "[status] Update status dashboard"
+ uses: gadenbuie/status/actions/status-update-rcmdcheck@main
+ with:
+ github-token-repo-scope: ${{ secrets.GADENBUIE_STATUS }}
+ status-repo: gadenbuie/status
diff --git a/.github/workflows/tic.yml b/.github/workflows/tic.yml
deleted file mode 100644
index 2c49bb5..0000000
--- a/.github/workflows/tic.yml
+++ /dev/null
@@ -1,109 +0,0 @@
-## tic GitHub Actions template: linux-macos-windows-deploy
-## revision date: 2022-11-23
-on:
- workflow_dispatch:
- push:
- branches:
- - main
- - master
- - cran-*
- pull_request:
- branches:
- - main
- - master
- # for now, CRON jobs only run on the default branch of the repo (i.e. usually on master)
- schedule:
- # * is a special character in YAML so you have to quote this string
- - cron: "0 6 * * 1"
-
-name: tic
-
-jobs:
- all:
- runs-on: ${{ matrix.config.os }}
-
- name: ${{ matrix.config.os }} (${{ matrix.config.r }})
-
- strategy:
- fail-fast: false
- matrix:
- config:
- # use a different tic template type if you do not want to build on all listed platforms
- - { os: windows-latest, r: "release" }
- - { os: macOS-latest, r: "release", pkgdown: "true", latex: "true" }
- - { os: ubuntu-latest, r: "devel" }
- - { os: ubuntu-latest, r: "release" }
-
- env:
- # make sure to run `tic::use_ghactions_deploy()` to set up deployment
- TIC_DEPLOY_KEY: ${{ secrets.TIC_DEPLOY_KEY }}
- # prevent rgl issues because no X11 display is available
- RGL_USE_NULL: true
- # if you use bookdown or blogdown, replace "PKGDOWN" by the respective
- # capitalized term. This also might need to be done in tic.R
- BUILD_PKGDOWN: ${{ matrix.config.pkgdown }}
- # use GITHUB_TOKEN from GitHub to workaround rate limits in {remotes}
- GITHUB_PAT: ${{ secrets.GITHUB_TOKEN }}
-
- steps:
- - uses: actions/checkout@v3
-
- - uses: r-lib/actions/setup-r@v2
- with:
- r-version: ${{ matrix.config.r }}
- Ncpus: 4
-
- - uses: r-lib/actions/setup-tinytex@v2
- if: matrix.config.latex == 'true'
-
- - uses: r-lib/actions/setup-pandoc@v2
-
- # set date/week for use in cache creation
- # https://github.community/t5/GitHub-Actions/How-to-set-and-access-a-Workflow-variable/m-p/42970
- # - cache R packages daily
- - name: "[Cache] Prepare daily timestamp for cache"
- if: runner.os != 'Windows'
- id: date
- run: echo "date=$(date '+%d-%m')" >> $GITHUB_OUTPUT
-
- - name: "[Cache] Cache R packages"
- if: runner.os != 'Windows'
- uses: pat-s/always-upload-cache@v3
- with:
- path: ${{ env.R_LIBS_USER }}
- key: ${{ runner.os }}-r-${{ matrix.config.r }}-${{steps.date.outputs.date}}
- restore-keys: ${{ runner.os }}-r-${{ matrix.config.r }}-${{steps.date.outputs.date}}
-
- - name: "[Stage] Install pak"
- run: Rscript -e "install.packages('pak', repos = 'https://r-lib.github.io/p/pak/stable')"
-
- - name: "[Stage] Install"
- run: Rscript -e "if (grepl('Ubuntu', Sys.info()[['version']]) && !grepl('Under development', R.version[['status']])) {options(repos = c(CRAN = sprintf('https://packagemanager.rstudio.com/all/__linux__/%s/latest', system('lsb_release -cs', intern = TRUE))))}else{options(repos = c(CRAN = 'cloud.r-project.org'))}; pak::pkg_install('ropensci/tic')" -e "print(tic::dsl_load())" -e "tic::prepare_all_stages()" -e "tic::before_install()" -e "tic::install()"
-
- - name: "[Stage] Script"
- run: Rscript -e 'tic::script()'
-
- - name: "[Stage] After Success"
- run: Rscript -e "tic::after_success()"
-
- - name: "[Stage] Upload R CMD check artifacts"
- if: failure()
- uses: actions/upload-artifact@v2
- with:
- name: ${{ runner.os }}-r${{ matrix.config.r }}-results
- path: check
- - name: "[Stage] Before Deploy"
- run: |
- Rscript -e "tic::before_deploy()"
-
- - name: "[Stage] Deploy"
- run: Rscript -e "tic::deploy()"
-
- - name: "[Stage] After Deploy"
- run: Rscript -e "tic::after_deploy()"
-
- - name: "[status] Update status dashboard"
- uses: gadenbuie/status/actions/status-update-rcmdcheck@main
- with:
- github-token-repo-scope: ${{ secrets.GADENBUIE_STATUS }}
- status-repo: gadenbuie/status
diff --git a/README.Rmd b/README.Rmd
index 7d6e51a..8b9d5d6 100644
--- a/README.Rmd
+++ b/README.Rmd
@@ -7,7 +7,7 @@ always_allow_html: true
[data:image/s3,"s3://crabby-images/fb7e7/fb7e7da6f3279db871ba0d1e2b0bdd6da5479153" alt="CRAN status"](https://CRAN.R-project.org/package=xaringanExtra)
[data:image/s3,"s3://crabby-images/e666c/e666c860157c0b66e329836cec495761e25a0cbc" alt="xaringanExtra status badge"](https://gadenbuie.r-universe.dev)
-[data:image/s3,"s3://crabby-images/f7573/f7573e9be301530c1fce0985643149b9d92d0782" alt="tic"](https://github.com/gadenbuie/xaringanExtra/actions/workflows/tic.yml)
+[data:image/s3,"s3://crabby-images/ff760/ff760de4473e859490476c95279c164542fd91ed" alt="R-CMD-check"](https://github.com/gadenbuie/xaringanExtra/actions/workflows/R-CMD-check.yaml)
```{r include=FALSE}
@@ -41,7 +41,7 @@ IN_README <- TRUE
- Fit your slides to [fill the browser window](#-fit-to-screen)
- Add [extra CSS styles](#-extra-styles)
-Each item can be enabled separately,
+Each item can be enabled separately,
or load everything at once with a single call.
````markdown
@@ -82,14 +82,14 @@ install.packages('xaringanExtra')
#### 📺 [Tile View Demo](https://pkg.garrickadenbuie.com/xaringanExtra/tile-view/)
Tile view gives you a way to quickly jump between slides.
-Just press O
+Just press O
(the letter **O** for **O**verview)
at any point in your slideshow and the tile view appears.
Click on a slide to jump to the slide, or press O to exit tile view.
data:image/s3,"s3://crabby-images/9f8b6/9f8b65f36c2b4aa3501f165a52b1c10f7d18769e" alt=""
-To add tile view to your xaringan presentation,
+To add tile view to your xaringan presentation,
add the following code chunk to your slides' R Markdown file.
````markdown
@@ -107,9 +107,9 @@ by the same name by [Stephen Hesperus](https://github.com/StephenHesperus).
#### 📺 [Editable Demo](https://pkg.garrickadenbuie.com/xaringanExtra/editable/)
-Editable gives you a way to write directly inside your slides,
-updating your content live.
-Make any element of your slides editable by using the `.can-edit[...]` class.
+Editable gives you a way to write directly inside your slides,
+updating your content live.
+Make any element of your slides editable by using the `.can-edit[...]` class.
data:image/s3,"s3://crabby-images/a1d39/a1d3973a89d0795610b95100a4835b0e73dba9a3" alt=""
@@ -121,20 +121,20 @@ xaringanExtra::use_editable(expires = 1)
```
````
-Then, to make a component of your slides editable,
+Then, to make a component of your slides editable,
use the `.can-edit[]` class.
```markdown
## .can-edit[You can edit this slide title]
```
-Editable fields that only have the `.can-edit` class
-are reset whenever the slides are re-loaded in your browser.
-If you want to store the edited values and
-have them persist across browser sessions,
-give each editable field a `.key-` class.
-Be sure to make each key unique and
-note that the key name must be a valid CSS class,
+Editable fields that only have the `.can-edit` class
+are reset whenever the slides are re-loaded in your browser.
+If you want to store the edited values and
+have them persist across browser sessions,
+give each editable field a `.key-` class.
+Be sure to make each key unique and
+note that the key name must be a valid CSS class,
i.e. it cannot contain spaces.
```markdown
@@ -173,7 +173,7 @@ and a share menu for one-click (or tap!) sharing on social media sites.
Add share again to your slides in three easy steps.
1. Add `use_share_again()` to your slides
-
+
````markdown
```{r share-again, echo=FALSE}`r ''`
xaringanExtra::use_share_again()
@@ -197,11 +197,11 @@ Add share again to your slides in three easy steps.
xaringanExtra::embed_xaringan(url = "share-again.html", ratio = "4:3")
```
````
-
- `embed_xaringan()` works with
- any xaringan presentation,
+
+ `embed_xaringan()` works with
+ any xaringan presentation,
_share again_ not required!
-
+
Here's what your [slides will look like](https://pkg.garrickadenbuie.com/xaringanExtra/share-again/)
in an R Markdown HTML document.
@@ -209,10 +209,10 @@ Add share again to your slides in three easy steps.
#### 📺 [Broadcast Demo](https://pkg.garrickadenbuie.com/xaringanExtra/broadcast/)
-**Broadcast** lets others follow along, in real time!
-Built with [PeerJS](https://peerjs.com),
-**broadcast** give you a unique URL to share with your viewers.
-Then, when they load your slides,
+**Broadcast** lets others follow along, in real time!
+Built with [PeerJS](https://peerjs.com),
+**broadcast** give you a unique URL to share with your viewers.
+Then, when they load your slides,
their slides will automatically follow you as you present!
```{r child="man/fragments/broadcast-details.Rmd"}
@@ -223,7 +223,7 @@ their slides will automatically follow you as you present!
#### 📺 [Scribble Demo](https://pkg.garrickadenbuie.com/xaringanExtra/scribble/)
Scribble lets you draw on your [xaringan](https://slides.yihui.org/xaringan) slides.
-Click the *pencil* icon or press S to begin drawing.
+Click the *pencil* icon or press S to begin drawing.
Pressing S or starting the drawing mode toggles the scribble toolbox.
There, you'll find the *eraser* button, which helps you remove lines from your drawing.
Or click the *trash* button to clear the drawings on the current slide.
@@ -245,7 +245,7 @@ This means that each partial slide will have it's own drawing layer
and your drawings on one slide won't carry over to the next.
(But they'll still be there when you switch back!)
-To save a copy of the slide with your drawings,
+To save a copy of the slide with your drawings,
your best option is to print your presentation from the browser.
## 🔊 Slide Tone
@@ -253,17 +253,17 @@ your best option is to print your presentation from the browser.
#### 📺 [Slide Tone Demo](https://pkg.garrickadenbuie.com/xaringanExtra/slide-tone/)
Slide tone plays a subtle sound when you change slides.
-It was
+It was
[requested by a blind R user](https://github.com/yihui/xaringan/issues/214)
and enables users to hear an auditory signal of their progress through the slides.
The tones increase in pitch for each slide from a low C to a high C note.
The tone pitch stays the same for incremental slides.
-Visit the
+Visit the
[slide tone demo slides](https://pkg.garrickadenbuie.com/xaringanExtra/slide-tone/)
to experience it yourself.
-Or include slide tone in your next xaringan presentation
+Or include slide tone in your next xaringan presentation
by adding the following code chunk to your slides' R Markdown.
````markdown
@@ -276,7 +276,7 @@ xaringanExtra::use_slide_tone()
#### 📺 [Animate.css Demo](https://pkg.garrickadenbuie.com/xaringanExtra/animate-css/)
-[Animate.css] is a popular collection of CSS animations. It contains
+[Animate.css] is a popular collection of CSS animations. It contains
> a bunch of cool, fun, and cross-browser animations for you to use in your
> projects. Great for emphasis, home pages, sliders, and general
@@ -286,11 +286,11 @@ Use `use_animate_css()` to include the animate.css stylesheets in your slides.
This function automatically modifies the CSS selector that enables the animation
so that only the slides that are visible are animated.
This drastically improves performance on large slide decks with many animations.
-For use in other HTML documents,
-set `xaringan = FALSE` to load the default `animate.css` file
+For use in other HTML documents,
+set `xaringan = FALSE` to load the default `animate.css` file
without this performance tweak.
-To use animate.css in your slides,
+To use animate.css in your slides,
add the following code chunk to your slides' R Markdown.
````markdown
@@ -308,14 +308,14 @@ class: animated slideInRight fadeOutLeft
## This slide...
-- slides in from the right
+- slides in from the right
- and fades out to the left on exit
```
If you want to use the same slide transitions for all slides,
you can use `use_animate_all()`.
-This function sets a default in and out animation for all slides.
-Animations can be disabled for individual slides
+This function sets a default in and out animation for all slides.
+Animations can be disabled for individual slides
by adding the class `no-animation` to the slide.
````markdown
@@ -324,7 +324,7 @@ xaringanExtra::use_animate_all("slide_left")
```
````
-Note: because `use_animate_all()` only imports the CSS required for the slide in and slide out animations,
+Note: because `use_animate_all()` only imports the CSS required for the slide in and slide out animations,
you need to also include `use_animate_css()` (see above)
if you want to use other animations from `animate.css` in your slides.
@@ -332,7 +332,7 @@ if you want to use other animations from `animate.css` in your slides.
#### 📺 [Panelset Demo](https://pkg.garrickadenbuie.com/xaringanExtra/panelset/)
-Panelset adds accessible tabbed panels —
+Panelset adds accessible tabbed panels —
just like R Markdown's `.tabset` panels —
to your xaringan slides.
You can activate a panel by clicking on the tab,
@@ -351,7 +351,7 @@ xaringanExtra::use_panelset()
data:image/s3,"s3://crabby-images/7b038/7b0383bf24f3363d622103806c01bfc3d7f087d4" alt=""
Then, create a `.panelset[...]` that contains `.panel[]`s.
-Each `.panel[]` should have a `.panel-name[]` and content
+Each `.panel[]` should have a `.panel-name[]` and content
(everything that isn't the panel's name).
```markdown
@@ -407,11 +407,11 @@ Here's the example used in the demo slides.
#### 📺 [Logo Demo](https://pkg.garrickadenbuie.com/xaringanExtra/logo/)
-`use_logo()` adds a logo to all of your slides.
-You can make the logo a clickable link and choose where on the slide it is placed.
+`use_logo()` adds a logo to all of your slides.
+You can make the logo a clickable link and choose where on the slide it is placed.
You can also set which types of slides will not get the logo by default.
-To add a logo to your xaringan presentation,
+To add a logo to your xaringan presentation,
add the following code chunk to your slides' R Markdown file.
````markdown
@@ -517,11 +517,11 @@ xaringanExtra::use_tachyons()
````
Tachyons provides small, single-purpose CSS classes that are easily composed to achieve larger functionality and styles.
-In the
+In the
[remarkjs content classes syntax](https://github.com/gnab/remark/wiki/Markdown#content-classes),
you can compose classes by chaining them together.
-For example,
-the following markdown produces a box with a
+For example,
+the following markdown produces a box with a
washed green background (`.bg-washed-green`)
and a dark green border (`.b--dark-green`)
on all sides (`.ba`)
@@ -533,7 +533,7 @@ with a large top margin (`.mt5`).
```markdown
.bg-washed-green.b--dark-green.ba.bw2.br3.shadow-5.ph4.mt5[
-The only way to write good code is to write tons of bad code first.
+The only way to write good code is to write tons of bad code first.
Feeling shame about bad code stops you from getting to good code
.tr[
@@ -616,15 +616,15 @@ clipboard works in xaringan slides, R Markdown documents, blogdown sites, and Sh
#### 📺 [Fit to Screen Demo](https://pkg.garrickadenbuie.com/xaringanExtra/fit-screen/)
xaringan/remark slides scale at a consistent ratio when the browser window is resized.
-In other words, if the slide ratio is `4:3`,
-then remark scales the slides and positions them in the browser window
+In other words, if the slide ratio is `4:3`,
+then remark scales the slides and positions them in the browser window
so that they maintain the aspect ratio.
-In certain situations,
+In certain situations,
like when showing slides in split screen next to another window like RStudio,
this causes the slides to become rather small.
Alternatively,
-it's a great way to be able to adapt your slides
+it's a great way to be able to adapt your slides
to the aspect ratio of the projector or television screen
when you don't know the ratio ahead of time.
diff --git a/README.md b/README.md
index 6444761..77e9092 100644
--- a/README.md
+++ b/README.md
@@ -7,7 +7,7 @@ xaringanExtra
status](https://www.r-pkg.org/badges/version/xaringanExtra)](https://CRAN.R-project.org/package=xaringanExtra)
[data:image/s3,"s3://crabby-images/e666c/e666c860157c0b66e329836cec495761e25a0cbc" alt="xaringanExtra status
badge"](https://gadenbuie.r-universe.dev)
-[data:image/s3,"s3://crabby-images/f7573/f7573e9be301530c1fce0985643149b9d92d0782" alt="tic"](https://github.com/gadenbuie/xaringanExtra/actions/workflows/tic.yml)
+[data:image/s3,"s3://crabby-images/ff760/ff760de4473e859490476c95279c164542fd91ed" alt="R-CMD-check"](https://github.com/gadenbuie/xaringanExtra/actions/workflows/R-CMD-check.yaml)
@@ -381,7 +381,7 @@ class: animated slideInRight fadeOutLeft
## This slide...
-- slides in from the right
+- slides in from the right
- and fades out to the left on exit
```
@@ -827,7 +827,7 @@ box has a shadow (`.shadow-5`) and medium-large horizontal padding
``` markdown
.bg-washed-green.b--dark-green.ba.bw2.br3.shadow-5.ph4.mt5[
-The only way to write good code is to write tons of bad code first.
+The only way to write good code is to write tons of bad code first.
Feeling shame about bad code stops you from getting to good code
.tr[
diff --git a/tic.R b/tic.R
deleted file mode 100644
index 4a6080f..0000000
--- a/tic.R
+++ /dev/null
@@ -1,2 +0,0 @@
-# installs dependencies, runs R CMD check, runs covr::codecov()
-do_package_checks()