Canvas Learning Management System (LMS) is visually pretty, but is sorely lacking in core usability functionality. One flaw relates to the difficulty of “unpublishing” assignments after copying a course. Assignments and files can individually be “published” or “unpublished” (available or unavailable for students to see). Assignments can also be nested with modules.
When an instructor copies a course to start a new semester, all items retain their published state. This is often undesirable when, because not all assignments should be immediately available to students at the start of a semester. However, it is often desirable to have module bucket names available for students to see.
Canvas foils both goals, as of publication date of this post. (1) There is no built-in way to unpublish all assignments. (2) When a module is published, all items within it are auto-published. But when a module is unpublished, items within it remain published. :facepalm:
Because aint nobody got time for all of the clicks it would take on the website to reach a desired publications state, we turn to our sordid friend,
$('some selector') part), and then simulating “clicks” on elements (
just as if you had done it with your mouse.
The following code can be run from a browser development console. For example, Chrome’s is found by opening the Developer Tools – one way to do that is by right-clicking
and choosing “Inspect Element”. Then, paste the script into the console input prompt, and running it by pressing
Without further ado,
Publish all modules, and unpublish module subitems
Unpublish assignments, but leave modules published
Click “unpublish” for all non-module publish buttons, using the :not() selector
Unpublish all files
Unpublishes all files. Waits 1 second after opening the model before selecting the “unpublish” radio button, and then submits the modal. Then, proceeds to the next attachment. Canvas forum link. Had to make it recursive because otherwise loop functions would try to pop open all modals at once, which wouldn’t be pretty.
Yes, Canvas should implement this functionality, but I’ve had them take three months to fix a show-stopping bug in quiz.next, so I’m not holding my breath for new features anytime soon.