-
Notifications
You must be signed in to change notification settings - Fork 14
Getting started
-
Please take a look at the code of conduct.
-
Remember, if you encounter any problems or have ideas for improvements to this template repository or this getting started guide, please file an issue here! Your feedback is very much appreciated.
Background information:
- If you are not familiar with Git and Github, we recommend looking through Happy Git and GitHub for the UseR by Jenny Bryan.
- If you aren't familiar with markdown files this is a nice introduction.
- For information on RMarkdown files: RStudio has their lessons here.
When updates are made to files that aren't specific to the course content but instead run checks and other processes in the original repository, PRs are filed automatically to any downstream repositories made from this template.
To enroll in these automatic update PRs, the new course's repository name will need to be added to this file in the original template where it says #NEW REPO HERE#
.
File a pull request to make this change.
If the your new course doesn't need some of the functionality of these files or you find the automatic you can feel free to use this guide to tailor which files you want updates for.
Carefully review the sync PR before merging it! It might be that you want some of the changes from the PR but not all of them. Each file that is updated in a sync PR is updated in its own commit.
-
If you don't want the changes from a particular file, you can always revert that particular commit before merging the sync PR.
If you will not want any updates on this file in the future, you may want to remove a file from being synced in your repo by reconfiguring the sync file. -
If you want only some changes, but they are not on a whole file basis, you could check out the branch and make manual edits. To checkout the branch, navigate to your own repository you should be able to run:
git checkout repo-sync/DaSL_Course_Template_Bookdown/default
- If you don't want any of the changes you can close the PR entirely. You may want to unenroll your repository from the sync github actions by deleting your repo name from this file if this will continue to be the case.
The Github actions that this repository uses needs four Github secrets set up.
It's important that these are set up and named exactly what they are below in order for Github actions to work correctly.
See Github Actions section for how you can customize Github actions which can change the necessity of these secrets.
To set up these repository secrets, on your repository's main Github page, go to Settings
and scroll down to see Secrets
on the left side menu bar.
For each new secret, click the New repository secret
button and set each as follows, clicking Add secret
as you fill each in appropriately:
Name: GH_PAT
:
*If you are a part of jhudsl
organization you do not need to set these.
For value
: Create a personal access token following these instructions. Underneath Select scopes
, check both repo
and workflow
.
Then copy the PAT and save as the value.
Note these are not required if Docker update Github actions are not turned on.
*If you are a part of jhudsl
organization you do not need to set these.
Name: DOCKERHUB_USERNAME
:
For value
: put your login username for https://hub.docker.com/
Name: DOCKERHUB_TOKEN
:
For value
: put a access token for Dockerhub.
You can create this by following these instructions.
Note these steps are not required if Google slide update Github actions are not turned on.
Before following these steps, you'll need to set up the Google slides following the instructions here.
To set up Google Slides Github Actions, you'll need to do some set up, but you will only have to do this once.
You'll need three secrets and you'll need to run some steps in your local R/RStudio outside of Docker to get some of them.
Install the package, rgoogleslides
if you have not before.
install.packages("rgoogleslides")
Then, run the following: It will open up a browser and ask you to sign in
token <- rgoogleslides::authorize()
There are two tokens you'll need, an ACCESS
token and a REFRESH
token.
Once you've run the above steps you can get these tokens by running for the ACCESS
token:
token$credentials$access_token
and for the REFRESH
token:
token$credentials$refresh_token
Now to set up these as Github secrets, on your repository's main Github page, go to Settings
and scroll down to see Secrets
on the left side menu bar.
Click the New repository secret
button and set each as follows, clicking Add secret
as you fill each in appropriately:
Name: GOOGLE_SLIDE_ACCESS_TOKEN
:
For value
: paste the output from token$credentials$access_token
from the steps above.
Name: GOOGLE_SLIDE_REFRESH_TOKEN
:
For value
: paste the output from token$credentials$access_token
from the steps above.
Lastly, set your Google Slide ID:
Name: GOOGLE_SLIDE_ID
:
For value
: set the presentation ID of your main Google Slides for this course.
Set up the Google slides following the instructions here.
The is in the URL of your Google Slide:
https://docs.google.com/presentation/d/<presentationId>/edit
Once you click Save
for all of these, you should be all set.
Particularly for courses that involve running example code, it's recommended that you use a Docker image for development to maintain software version consistency across course developers.
If you are new to Docker, you may find it helpful to read Carrie Wright's explanation about what Docker is for.
- You will need to sign up with a Docker account if you don't have one.
- If you haven't installed Docker desktop (or need to update it), you can do so here.
If your Docker desktop is running, you should see a Docker whale in your tool bar. On Macs, this will be on the bar on the top of your screen; in Windows, on the bottom right.
A Docker image is similar to a virtual machine - it contains preinstalled software in a preconfigured environment. Docker images can be downloaded from DockerHub, or you can create your own.
We have created the course_template
image as a starting point; you can download it from jhudsl/course_template
on DockerHub using the docker pull command we have below.
To pull the docker image associated with this template, you can run this command below in your command line.
This may take a while.
docker pull jhudsl/course_template
This pulls the course_template image from Docker Hub and copies it to your computer. It will be placed in your local collection of Docker images, managed by Docker (not in your pwd).
To use the Docker image associated with the course template, first navigate to the the top of this GitHub repository. Now you can start up the Docker container using the command below.
This runs your local copy of the course_template image (which you downloaded from DockerHub).
The option -v $PWD:/home/rstudio
mounts pwd (this repo) and makes it available at /home/rstudio
within the container.
Replace all of <CHOOSE_PASSWORD>
(including the <
and >
) with a password of your choosing.
On a Mac:
docker run -it -v $PWD:/home/rstudio -e PASSWORD=<CHOOSE_PASSWORD> -p 8787:8787 jhudsl/course_template
On a Windows:
docker run -it -v %CD%:/home/rstudio -e PASSWORD=<CHOOSE_PASSWORD> -p 8787:8787 jhudsl/course_template
Do not close this window, but you can minimize it.
Open up a new command line window and run the command: docker ps
, you should see a container is up and running!
In a web browser navigate to the following to get to an RStudio that is ran from your Docker container.
localhost:8787
To log in, you'll need to use rstudio
as the username and whatever password you put for <CHOOSE_PASSWORD>
in the above command.
Couple other handy Docker commands:
- To stop your Docker container, run
docker ps
to obtain the docker container ID. Then you can use that ID to rundocker stop <CONTAINER_ID>
. - To remove a docker image (which you may need to do from time to time to clear out space), you can run
docker image ls
to see all your current images. Then you can run eitherdocker image rm <IMAGE_ID>
. - If you really need to clear out space, you can follow this StackOverflow post on how to remove all images and all containers.
For more info on how to use Docker, they have very extensive documentation here.
Should you find that your course needs additional packages beyond what's included in the template, you should probably start a new Docker image and you'll need to do two things to get this going:
- You need to uncomment the Docker image update following these instructions.
- You'll need to set up a Dockerhub account and set up Dockerhub secrets following these instructions.
To start up a new Docker image for your new course, you can start with the Dockerfile in this repository and add the additional packages you need using the tips in the next section, but you'll need to change the tag.
If you wish to keep the Docker image underneath the Dockerhub jhudsl
organization account, you'll need to be granted access to that organization -- contact one of the jhudsl
team to have them add you.
If you find you need a new package to run the code you are adding, you'll need to add the package to the docker/Dockerfile
.
Try to keep things in alphabetical order where possible.
For R packages installed from CRAN, you can add to the running vector list of R packages.
To add an R package from Bioconductor, you can follow this kind of format:
RUN Rscript -e "options(warn = 2); BiocManager::install( \
c('limma', \
'newpackagename')
To add an R package from GitHub you can add a line that follows this general format (need a comma and space):
RUN Rscript --vanilla install_github.R \
--packages "jhudsl/didactr, jhudsl/leanbuild, <NEW_PACKAGE>" \
To add a Python package, you will need to add pip3 to install Python packages using this format:
RUN pip3 install \
"somepackage==0.1.0"
When you've added a package to the Dockerfile, you'll need to check that it builds successfully before including it in a pull request.
First create a GITHUB token file by making a token and copying a pasting it into a plain text file named docker/github_token.txt
.
Then you'll need to rebuild the docker image using this command:
docker build -f docker/Dockerfile . -t jhudsl/course_template
If it fails, often the issue is a missing dependency. Take a look at the error messages and see if you can determine the issue with some Googling.
Once it builds successfully, you should file a PR with your Dockerfile changes. Once the changes are accepted and merged, we'll need to push the updated image to Dockerhub using:
docker push jhudsl/<TAG_FOR_COURSE>
When you file a pull request, the Dockerfile build will be tested automatically by the GitHub actions.
You can generally follow the Bookdown instructions about citations, but you don't need to add the additional bibliography argument at the top of the Rmds.
To add a new reference source, add to the book.bib
file, keeping your new entry in alphabetical order.
For articles (or anything with a DOI), go to doi2bib.org to get a BibTex-formatted reference.
Then copy and paste the reference to the book.bib
file.
You can also use programs like Zotero or Endnote to export a .bib file and either combine with the book.bib
or manage your references from there.
Other sources can be added using this template:
@website{citekey,
author = {First Last},
title = {Title},
url = {http://www.someurl.html},
}
To reference the citations in your writing follow the bookdown instructions:
Items can be cited directly within the documentation using the syntax @key where key is the citation key in the first line of the entry, e.g., @R-base. To put citations in parentheses, use [@key]. To cite multiple entries, separate the keys by semicolons, e.g., [@key-1; @key-2; @key-3]. To suppress the mention of the author, add a minus sign before @, e.g., [-@R-base].
See Chapter 2 of the template course for examples.
Here's a summary of the Github actions set up in this repository.
These Github actions also work across repositories to support converting Bookdown content into formats ready for publishing on Coursera or Leanpub.
If you are only looking to use this template for creating a Bookdown course, this diagram is not as pertinent.
Note that build-all
and docker-build-test
are not something we recommend requiring for status checks because docker-build-test
is only run if there are changes to the Dockerfile and build-all
is only run upon the acceptance and merging of a pull request.
However for simplicity purposes there are two sections this Github action that can you keep off if you won't be making changes to the Docker image or you won't be wanting it to sync to Google Slides automatically.
If you know for sure that the course you are working on will never require Docker updates -- this may be the case if the course doesn't any interactive code as a part of the material, you can delete the Docker updating chunk or keep it commented out.
However, if you will need to make any change to the Docker image specific to the course you are working on, in the file .github/render-bookdown.yml
you should uncomment the
###### START OF DOCKER UPDATE CHUNK
up to the part that says ###### END OF DOCKER UPDATE CHUNK
.
This will require you to set up the Github secrets for Docker.
If you know for sure that the course you are working on does not need Google Slide automatic updating, you can delete the Google Slide updating chunk or keep it commented out.
However, if you will need to make any change to the Docker image specific to the course you are working on, in the file .github/render-bookdown.yml
you should uncomment the
###### START OF GOOGLE SLIDE UPDATE CHUNK
up to the part that says ###### END OF GOOGLE SLIDE UPDATE CHUNK
.
This will require you to set up the Github secrets for Google Slides.
transfer-rendered-files.yml
is a Github action that will copy over the output docs/
files rendered by Bookdown to a parallel Leanpub
repository.
Once build-all
is run, the docs/
folder where the rendered files are place are copied over to the Leanpub repository and filed as a pull request.
There are two edits to .github/workflow/transfer-rendered-files.yml
that need to be done to turn on the automatic copying of files between these repos:
- Change line 28 to the repository name you would like the
docs/
files to be transferred to.
repository: jhudsl/Course_Template_Leanpub
- Uncomment lines 13-18 in this file:
# Only run after the render finishes running
#workflow_run:
# workflows: [ "Build, Render, and Push" ]
# branches: [ main ]
# types:
# - completed
Github actions will run the styler
package to all style R in all Rmds whenever a pull request to the main
branch is filed.
Style changes will automatically be committed back to your branch.
Github actions will automatically run a spell check on all Rmds whenever a pull request to the main
branch is filed.
Depending on your preference, you may find it easier to spell check manually on your local computer before pushing to Github.
It will fail if there are more than 2 spelling errors and you'll need to resolve those before being able to merge your pull request.
To resolve those spelling errors, go to this repository's Actions
tab.
Then, click on the GitHub action from the PR you just submitted.
Scroll all the way down to Artifacts
and click spell-check-results
.
This will download a zip file with a TSV that lists all the spelling errors.
Some of these errors may be things that the spell check doesn't recognize for example: ITCR
or DaSL
.
If it's a 'word' the spell check should recognize, you'll need to add this to the dictionary.
Go to the resources/dictionary.txt
file.
Open the file and add the new 'word' to its appropriate place (the words are in alphabetical order).
Then commit the changes to resources/dictionary.txt
to your branch and this should make the spell check status check pass.
There are two actions ran in render-bookdown.yml
that attempt to keep Google Slides updated:
Note that the steps in Google Slide related Secrets need to be followed in order for these to properly run.
-
google_slides_image_linker.R
makes sure any code output images are updated after bookdown is re-rendered. -
google_slide_png_downloader.R
downloads all the slides from the linked Google slide set as PNGs toresources/gs_slides
.
Note that for the Google Slides actions to run you need to set up the Google Slides Github actions in the render-bookdown.yml
file and its related secrets.
If you are using the Docker container, or otherwise have the spelling
and styler
package installed, you can run spell check and styling locally on all Rmds by running this:
Rscript scripts/spell-check.R
The spell check results file will be saved to a file called spell_check_results.tsv
.
This file should not be pushed to the GitHub repository (it is in the gitignore so this shouldn't happen).
GitHub actions runs a check on all the URLs upon creating a pull request to the main
branch.
If it fails, you'll need to go the Actions
tab of this repository, then find the GitHub check_urls
job for the last commit you just pushed.
Click on check_urls
and the specific step of Check URLs
to see a print out of the URLs tested.
If the URL checker is failing on something that isn't really a URL or doesn't need to be checked, open up the GitHub actions file: .github/workflows/url-checker.yml
and add the imposter URL on to the exclude-urls:
argument with a comma in between.
Logos for the table of contents are added with the _output.yml
file. This adds this an image above the table of contents when the content is rendered with bookdown
.
If you are creating a general DaSL course:
- Please replace the URL in the line 13 of code for the
_output.yml
file with the URL for the GitHub repo for your course. This will allow people to more easily find how out how you created your course. Otherwise, they will be directed to this template.
If you are creating a DaSL course for a project other than ITN:
- Delete the
_output.yml
file and rename the_output-itcr.yml
to be_output.yml
. - Please modify the lines that link to the http://jhudatascience.org/ with your own website and logo if you are not part of the jhuDaSL .
- Please replace the URL in the line 13 of code with the URL for the GitHub repo for your course. This will allow people to more easily find how out how you created your course. Otherwise, they will be directed to this template.
- If you wish to create a different color scheme, the font colors can also be modified along with other aspects in the
assets/style.css
file. Take a look at theassets/style_ITN.css
file to see what was changed for that color scheme from theassets/style.css
file. - You can replace the logo with the appropriate project logo by replacing
https://www.itcrtraining.org/
with the project website link and"https://raw.githubusercontent.com/jhudsl/DaSL_Course_Template_Bookdown/main/resources/images/logo.png"
for the project logo image link in line 11.
If you are creating an ITCR course for ITN:
- Delete the
_output.yml
file and rename the_output-itcr.yml
to be_output.yml
. - Please modify the lines that link to the http://jhudatascience.org/ with your own website and logo if you are not part of the jhuDaSL .
- Please replace the URL in the line 13 of code with the URL for the GitHub repo for your course. This will allow people to more easily find how out how you created your course. Otherwise, they will be directed to this template.
To maintain style and attributions for graphics and images, as well as to enable easy updates in the future, please start a new Google Slide document for your course. This also allows you to make videos of your slides that can be added to your course.
Each Rmd with images that is a part of your bookdown needs to have this chunk at the beginning so that images are stored properly for Leanpub conversion:
```{r, include=FALSE}
leanbuild::set_knitr_image_path()
```
Next, import the appropriate theme (see this video for assistance):
Note that you will need to change your Google Slide permissions to "Anyone with a link" in order for some functionality to work.
- If you are not creating a course as part of a larger collaboration but simply just as a DaSL course, import the theme from this template. Once you have done this add a slide with the "Title slide" layout under layouts - and add your course title.
- If you are working on a project (more likely) with the Johns Hopkins Data Science Lab than import the theme from this template.
Add a title slide and update it with your project's logo.
In either case:
Be sure to add a terms of use slide to let people know about our licensing.
For any major point, please select this layout:
For itemized lists, please select this layout:
Please select the layout that looks like this for any images/content from outside sources:
Please update the text at the bottom to describe the source.
Once complete, your slides can be downloaded and a static version can be added to your bookdown and or Leanpub repository to build your course. See this link for information on how to download slides from Google Slides.
Images should be stored in resources/images/
or you can link directly to your GoogleSlides following the instructions here.
Also add notes to each slide describing the text or images of the slide to allow for the content to be accessible to vision impaired individuals, as this can be converted to audio when creating videos.
- If you are not part of the Johns Hopkins Data Science Lab, import the theme from this template. Once you have done this add a slide with the ITN2 layout - and add your course title and any logos for your organization(s) that may be appropriate like so:
Also be sure to add a terms of use slide to let people know what licensing that you have chosen. You can use ours (that looks like the slide below) if you like or create your own with a different license.
- If you are part of the Johns Hopkins Data Science Lab than import the theme from this template.
Be sure to add a Johns Hopkins terms of use slide.
For any major point, please select this layout:
For itemized lists, please select this layout:
Please select the layout that looks like this for any images/content from outside sources:
Please update the text at the bottom to describe the source.
Once complete, your slides can be downloaded and a static version can be added to your bookdown and or Leanpub repository to build your course. See this link for information on how to download slides from Google Slides.
Images should be stored in resources/images/
or you can link directly to your GoogleSlides following the instructions here.
Also add notes to each slide describing the text or images of the slide to allow for the content to be accessible to vision impaired individuals, as this can be converted to audio when creating videos.
Each slide and image added to the courses needs to be accessible. There are two things to check for each slide:
-
Each slide is described in the notes of the slide so learners relying on a screen reader can access the content. See https://lastcallmedia.com/blog/accessible-comics for more guidance on this.
-
The color palette choices of the slide are contrasted in a way that is friendly to those with color vision deficiencies. You can check this using Color Oracle.
All images should be included in your Google Slides with the captions we discussed above. To add images in the text in your Rmd, use the following function within an R code chunk.
```{r, fig.alt="Alternative text", echo = FALSE, outwidth = "100%"}
leanbuild::include_slide(<google_slide_url>)
You must define fig.alt
in the code chunk options/parameters to pass to knitr
.
You can adjust the size(fig.hight, fig.width, out.width, out.height), alignment (fig.align), or caption (fig.cap) of the image you can use these arguments in the code chunk tag:
```{r, fig.alt="Alternative text", fig.height=4, fig.align='center', fig.cap='...'}
It's also okay to use <img src
for your images if you like you but you still need to make sure that you have alternative text designated using something like: <img src="blah.png" alt="SOMETHING">
.
Google Slides must be public. Share settings must be set to "Anyone on the internet with this link can view". Note that "Private" is the default setting when you make a new presentation.
See Chapter 2 of the template course for examples.
To add a youtube video to your Rmd files use the following:
```{r, fig.align="center", fig.alt = "video", echo=FALSE, out.width="100%"}
knitr::include_url("https://www.youtube.com/embed/yiZQaE0q9BY")
```
To get the appropriate youtube url do the following:
- click on the SHARE button on the lower right corner of the video on youtube
- click on the Embed option on the far left
- copy just the part after
"src ="
and paste the url into theknitr::include_url()
function
Again, it is important to use the echo=FALSE
option so that only the video is shown and not the code to generate it.
You could alternatively use html code by copying the entire embed code provded by youtube, but you might want to modify it a bit to center the video, like so:
<p align="center"><iframe width="560" height="315" alt = "video of Russell McClain on biases and stereotypes" src="https://www.youtube.com/embed/yiZQaE0q9BY" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe></p>
See Chapter 2 of the template course for examples.
Sometimes it is useful to include an embedded version of a website or file on a website, if there is a particularly important link and you don't want to rely on learners clicking the link.
To include such a file or website do the following:
```{r, fig.align="center", echo=FALSE}
knitr::include_url("https://www.messiah.edu/download/downloads/id/921/Microaggressions_in_the_Classroom.pdf", height = "800px")
```
Again you will need to include echo = FALSE
to ensure that the code to generate the preview of the website or file is not included in your course material.
If you want to include a file that is not hosted online, consider hosting it on GitHub using the method described for hosting your Bookdown version of the course. See the Set up GitHub pages section.
Then you would do the following, where the url is that of your hosted file:
```{r, fig.align="center", echo=FALSE}
knitr::include_url("https://carriewright11.github.io/stringr_RLadies/index.html", height = "800px")
```
You can also use html code for this like so:
<p align="center"><iframe src="https://widgets.figshare.com/articles/5427418/embed?show_title=1" width="568" height="351" allowfullscreen frameborder="0" alt = "expectation document"></iframe></p>
See Chapter 2 of the template course for examples.
Each chapter should start with Learning objectives! You can use this handout to help you craft learning objectives.
Learning objectives should be stated both in the slides and in the beginning of each bookdown chapter.
Because of this, you may find it most handy to use the List layout
slide for stating your Learning objectives and then embed that in the book from your GoogleSlides the instructions here.
As you modify the names of the chapters of your course and add more chapters (using the .Rmd
files), you need to update the _bookdown.yml
file accordingly.
For example let's say that we added another chapter and named the file 03-chapter_of_course.Rmd
.
We would update our _bookdown.yml
to look like this:
book_filename: "Course_Name"
chapter_name: "Chapter "
repo: https://github.com/jhudsl/DaSL_Course_Template_Bookdown/ ##Make sure you update this for your GitHub Repo!!
rmd_files: ["index.Rmd",
"01-intro.Rmd",
"02-chapter_of_course.Rmd",
"03-chapter_of_course.Rmd", ##Only this is new!
"about.Rmd"]
new_session: yes
delete_merged_file: true
language:
ui:
chapter_name: "Chapter "
output_dir: "docs"
Notice how only one line is different - the one that says 03-chapter_of_course.Rmd",
Be careful about quotation marks: ""
as well as commas: ,
!
Once we do this we can preview the book!
You can do so by typing:
bookdown::serve_book()
in the RStudio Console.
Note that when you run bookdown
it will create an .rds
file; you can generally ignore this file.
You will then see a live version of your book in your RStudio viewer.
Note that When a pull request is merged to main, bookdown::render_book()
will be re-run by the GitHub actions and the results added to main
.
Once your content has been largely developed you may want to add your course to Coursera.
If you are from Johns Hopkins: You will need to follow this document and send information Ira Gooding who will create a course shell for you.
If you are not from Johns Hopkins: You will need to set up your own educator profile and course shell through your institution.
The Github actions set up in the render-bookdown.yml also render your course material in a format suitable for linking to Coursera.
This Coursera version is identical except that the table of contents bar on the left side has been dropped so as to not confuse Coursera users about navigating the course.
These files can be previewed in the docs/coursera/
folder.
Click on your chapter htmls to see what it will look like.
In the Leanpub repo, Leanpub-formatted quizzes can be converted to a Coursera yaml format. Or alternatively if you do not wish to have a Leanpub version of your course, you can either manually enter your Coursera quizzes or manually write a Coursera yaml file following the format of our Coursera template quiz.
After your course shell has been added to your account you can navigate to it by going to My Courses
:
And you should see it listed:
You can click on Go to Course
. And on your main course page click Edit Course
in the right corner.
This will bring you to your version page (at this point you should only have a Version 1, so go to that one).
Now you are on the Edit content page and ready to add lessons, modules and quizzes!
In general, you will want each lesson to contain at least a chapter and a quiz.
Each module is supposed to take a learner one week, so depending on the length of your chapters and quizzes you may want one or two lessons/chapters/quizzes a module.
To add a new lesson, click the + Add Lesson
button:
Now you are ready to add a chapter!
You'll need to link out each chapters in Coursera by providing a url built from your Github pages.
You can see a preview of these chapters you will link to in Coursera by going to your Github pages, but adding /coursera
at the end of your url before the chapter file name.
So the urls for each of your chapters which you will supply to Coursera in the next steps will look like this:
<main-github-pages-url>/coursera/<html_filename>
If you are unsure what the main url for your Github pages is, in your github repository, go to Settings
> Pages
and you'll see Your site is published at:
So for example, the introduction chapter of this template would be linked by using this url:
https://jhudatascience.org/DaSL_Course_Template_Bookdown/coursera/introduction.html
To add this URL to Coursera, add a new lesson, click + More
and choose Ungraded Plugin
.
This will add an unpublished ungraded plugin to your lesson:
Now click the edit button on the new Ungraded Plugin
.
This will bring you to the standard example plug in page.
Scroll down and click Edit Configuration
:
Replace the example url with the url of your individual chapter we discussed above.
Then click on Save Configuration
:
IF the url you provided was correct, you should see a preview of your chapter:
You may want to edit the title at the top of this page to indicate the material being linked.
Now click Publish
in the left upper corner (don't worry it's not actually publishing publicly, its just saving your changes).
And it will ask you again to really scare you, but yes, click Publish
.
Congrats you added a chapter to your course! Now do the same thing for all your chapters!
To add a new quiz start from your Edit content
page and on whatever lesson you would like to add the quiz to and click the + Quiz
button.
Now go to Edit
on the new quiz.
If you are choosing to manually enter your quizzes, you can continue to add each question from this page.
If you are importing a Leanpub converted quiz click the Import Questions
button and choose your converted yml files.
(If you've not yet converted your leanpub quizzes, then refer to that section.)
Upload your Coursera quiz yml file from your device:
After you've selected the file click Upload
:
It will let you know if there are any problems uploading the quiz. If the coursera_quiz_conversion.R
script failed to render something properly, please file an issue here describing how it failed and including a file that shows the instance it failed to convert.
Note that images and links are not currently supported in that conversion script. You also cannot have :
in your prompts or answers.
But if the quiz uploads without issue, then click Continue
.
You can edit the title of your quiz and then click Publish
(don't worry it's not actually publishing publicly, its just saving your changes).
And it will ask you again to really scare you, but yes, click Publish
.
Congrats you added a quiz to your course! S
If you already have a _Leanpub
repository for your course, you can convert your quizzes to a nicely upload-able yaml file by using that repository and running this command with the leanbuild package:
leanbuild::convert_quizzes()
Note that currently images and links are not supported and if your quizzes contain those, you will have to manually add them.
The render-bookdown.yml github action the chapter content for Coursera by using this command within the docker image:
leanbuild::render_coursera()
You can run this same command locally if you wish to test something. This render the chapters without the table of Contents. If you do not wish to publish to Coursera and prefer this do not run, you may delete this section (but it shouldn't hurt anything to keep as is -- unless for some reason it causes you some troubles).
Additionally, the Leanpub companion repository has a Leanpub -> Coursera quiz conversion script if you choose to create quizzes and publish on both Leanpub and Coursera.
If you encounter any problems or have ideas for improvements to this template repository or this getting started guide, please file an issue here! Your feedback is very much appreciated.
Note all materials in this template are licensed CC-BY and can be repurposed freely with attribution.
- Getting started
- Start a new course!
- Start editing course files
- Content creation tips
- Setting up images and videos
- About citations
- About Docker
- Spell check
- URL check
- Generate docx output
- Borrowing chapters between courses
- Most common errors
- Choosing between platforms
- Publishing with Bookdown
- Publishing on Coursera
- Publishing on Leanpub
- Making quizzes private (Leanpub and Coursera)
- Set up user feedback method
- Change title and style
- Credits section
- Adding Google Analytics Traffic Tracking
- Release a course for public viewing