Creating a Chrome Extension to Use with Canvas LMS: Canvas LMS Mods (Basic)

Code-with-Ski
Community Participant
45
20183

Website with Feature Overviews 

https://code-with-ski.github.io/Canvas-LMS_Mods-Website/

UPDATE: 9/27/23 Change to Host Permissions Starting Version 3.0.0

To make it easier for users to begin using this when their institution is using a custom domain, I have updated the host permissions to allow all domains.  Version 3.0.0 is currently released to approve access to all domains by default.  Once version 3.1.0 is released, the host permissions will default to Instructure hosted domains as approved and all other domains can be optionally approved. This minor adjustment was suggested to improve the security and minimize the default approved access.

After you agree to the update, I would recommend updating the extension settings in "Manage Extensions" to change the setting to either be approved on click or specific sites and you can list only the domains you approve it to have access to. Install and Manage Extensions 

You are also welcome to download your own copy of the source code from the repository and manage your own local copy to set the host permissions to what you desire by default: https://github.com/Code-with-Ski/Canvas-LMS-Mods 


I have been working on improving my skills as a developer and I am impressed by all the different things people have created to solve a problem or improve a workflow through locally developed options.  Seeing these creations made me wonder about what things I could create. So I started researching and learning more about creating modifications and using the Canvas API. 

The Canvas Community had a lot of good resources to get started.  I also watched the majority of past Canvas Conference presentations that related to development.  In addition, I found the The Coding Train on YouTube and he has provided a lot of helpful tutorials on JavaScript, API calls, and even making a Chrome extension.

Discovering the playlist on making a Chrome extension sparked my interest, especially once I saw how easy it was to take your code and then package it to work as a Chrome extension.  At first, I was just using it locally by using the Developer mode in Chrome.  However, I wanted to go through the process of learning how to publish the Chrome extension and share it with others.  So I learned about manifest version 3 and updated my manifest file so that I could publish it using the latest standard.

My Chrome extension, Canvas LMS Mods (Basic), includes features to improve the user experience.  The first version only included features for the admin area of Canvas.  However, as I continue improving it, I am expanding to adding features to other areas of Canvas to be useful to more users.  For this Chrome extension, I am focusing on low-code options that can be created using vanilla JavaScript and the Canvas LMS API.  The various features are enabled by default, but if you go to the options for the Chrome extension you can disable features you don't want and/or that may conflict with theme customizations in your instance of Canvas.  I will do my best to fix features that may break with Canvas updates, but may not always be possible depending on how significant the change is.  Fortunately, with the options, it makes it easy to disable features if there is a bug waiting to be fixed.

If you try out my Chrome extension, I would appreciate any feedback that you have so I can take it into consideration for future updates.

Version Updates

Features from Prior to Version 1.2.0 Release

Current Feature Options Available:
- Global
    - Enable full-width for the page body
- Account
    - Profile
        - Enable "View Grades" button on the user's account profile page
- Dashboard
    - Enable "See all courses" button on the dashboard
- Course
    - Global for course
        - Enable sticky course header
    - Modules
        - Enable "Jump to Module" selection
- Admin
    - Course Search
        - Prevents input for "Show only blueprint courses" from filling to the end of the page in desktop view
        - Add the course code to the course search results (Uses Canvas LMS API calls)
    - People
        - User Account Details
            - Course enrollments box
                - Make it resizable
                - Set a default height
                - Sort the enrollments by status, term, and role
                - Filter enrollments by course published status, enrollment status, and/or term
                - Add the course code to the list of enrollments (Uses Canvas LMS API calls)
            - Accounts box
                - Make it resizable
                - Set a default height
                - Show the admin roles in each account (Uses Canvas LMS API calls)
            - Groups box
                - Make it resizable
                - Set a default height
            - Avatar image
                - Make it resizable by clicking and/or dragging it to resize
        - Profile Pictures
            - Make it resizable by dragging the corner
            - Make it a rounded square instead of a circle to show more of the background
            - Adjust the default size
        - Rubrics
            - Add a search ability to the rubrics
        - Question Banks
            - Add a search ability to the question banks
        - Sub-accounts
            - Enable show Canvas account ID
            - Enable show SIS account ID (Uses Canvas LMS API calls)
        - Terms
            - Add a search ability to the terms
            - Move the add term button to the top of the terms table
            - Show the Canvas Term ID
        - SIS Import
            - Enable SIS History Log (Uses Canvas LMS API Calls)

Version 1.2.0 Release Updates:

  • Patched the overlap issue with the blueprint side menu when the course sticky header is enabled
  • Patched the SIS Import log to prevent duplicate requests from loading in the table on infinite scroll
  • Added new feature for the all course page:
    • Filters for the term, enrolled as, and published columns based on the values in the table
    • Search bars for the course and nickname columns
    • Sorting on the course, nickname, term, enrolled as, and published columns

Version 1.3.0 Release Updates:

  • Dashboard
    • Shows the current course grade on the dashboard cards where you are enrolled as a student.  *This is similar to the feature that is available in the mobile app
  • Course
    • People/Users
      • Enable users export to CSV button (Requires course admin permission)
      • Enable ability to hide inactive users
      • Enable ability to filter by section (Uses Canvas LMS API)
      • Enable people sort by columns
    • Groups
      • Enable groups export to CSV button (Requires course admin permission) (Uses Canvas LMS API)
    • User
      • Enable access report export to CSV button
  • Admin
    • People
      • Add link to grades for active courses
    • User Grades
      • Updates the name, headings, and link to reflect the user (Uses Canvas LMS API)

Version 3.0.0 Release Updates:

  • Updated host permissions to all domains
  • Assignment
    • When you go to an Assignment, if there is a graded ratio showing on the right, you will now see options to export grades including rubric scores if applicable
  • Course Statistics (Accessed from Course Settings page)
    • Custom course reports have been added.
      • These are currently reports that load in detailed information about various content elements in the course. 
      • I plan on continuing to add reports and add search options to the reports.
  • Rubrics (Account and/or Course)
    • Drag and Drop Criteria Rows
      • When editing a rubric, you will be able to drag and drop criteria rows to re-arrange them if you need to change the order.
      • Dragging up will push existing content down when dropped, while dragging up will push existing content up
    • Import Criteria Details
      • When editing a rubric, you will be able to import the criteria details using a standard format for the information.
      • Imported content will show in the edit view so you can preview the imported content before updating/creating the rubric.

Version 3.1.0 Release Updates:

  • Updated host permissions to Instructure hosted domains as the default required and all other domains as optional

Version 3.2.0 Release Updates:

  • Updated Discussion Replies report to include Discussion Counts
  • Added new Enrollments course report
  • Added button link to "Course Statistics" on the home page to make it easier to get to the custom course reports in this tool

Version 4.0.0 Release Updates:

  • New Features
    • Rubric association report on individual rubrics
    • Used for grading indicator for rubrics on assignment details
    • Load assignment details feature on list of assignments
      • Submission type(s)
      • Whether or not it affects the final grade
      • Associated rubric, if it is used for grading, and if it uses outcome criteria
      • Option for Turnitin check too
    • Made rubric search on the rubrics page a shared feature so it works in accounts and courses
    • Load rubric details feature on list of rubrics
      • Context for rubric
      • Whether or not it has assignment associations
      • Whether or not it has outcome criteria
    • Export grades for discussion board
  • Deprecated features
    • Terms search in Admin (Instructure now has this as part of the new design)
    • Move add term button to top (Instructure now has this as the default in the new design)

Version 5.0.0 Release Updates:

  • Course Report Updates
    • Discussion Replies report now allows you to select a specific discussion board from which to get the replies
    • Submission report now allows you to select a specific assignment from which to get submissions and to select the submission states to check
    • Loading messages were added to show which part of the process the report is working on after clicking the button to load data.  It will also show an error message if something goes wrong. 
  • Section Reports
    • Some of the custom course reports have been modified to work as section reports too.
      • Enrollment Report
      • Submissions Report
      • Module Progress Report
    • These reports can be accessed on the settings page for an individual section.
  • Manifest and File Updates
    • The config classes for SkiTable have been combined into the SkiTable class file since they are only used with that class and to simplify the number of files that need to be listed in the manifest
    • SkiTable and SkiReport files are now listed on the specific pages that they are needed in the manifest before the feature files that need them rather than loaded by default on all pages.  This will hopefully help with some inconsistent file loading sequences that were causing some errors.

Version 5.1.0 Release Updates:

  • Fixed bug with Discussion Replies report having an error due to deleted posts. It ignores deleted posts for now until version history becomes available.
  • Added new columns to the Assignment Details report.

Version 5.2.0 Release Updates:

  • Updated import rubric feature and drag-and-drop criteria feature for rubrics so that it also works on the assignment details page when adding/editing rubrics.
  • Patched issue with module progress report failing to complete due to module progress not existing for a requested user
  • Added a local cache to SkiReport to that common requests used across reports can be saved rather than repeating requests that are unlikely to change while using the reports. Users can refresh the page to update the cache if changes are made while using the reports.
  • Added new course/section reports:
    • Grading To Do Report
    • Grade History Report (Able to check grade history of deleted users too)
    • Missing Rubric Grade Report (Find graded submissions that had an associated rubric, but the rubric wasn't used for assessment)
    • User Access Report

Version 5.2.1 Release Updates:

  • Patched loading messages on Grade History and User Access Report
  • Patched paginated request handler for User Access
  • Patched load rubric details feature to properly work in Accounts.

Version 5.2.2 Release Updates:

  • Patched page ID and page URL in the Page Details course report

Version 5.2.3 Release Updates:

  • Added more error handling to the Modules Progress course report

Version 5.2.4 Release Updates:

  • Updated the Modules Progress course report to fetch the items for a module if they were not included when all modules were fetched.

Version 5.3.0 Release Updates:

  • Updated the "All Courses" sort to apply to all columns and disable the sort button on those that don't need to sort. This is to provide consistency in headings based on the new feature from Canvas.
  • Updated the "All Courses" filters to be a part of the original thead row with the original th elements.
  • Added a filter for the favorited state on the All Courses lists
  • Deprecated the draft comment mod in SpeedGrader since it is now a native feature
  • Added option for enabling detailed logging (currently used primarily to console log API requests)
  • Added Simple Search feature to courses as a course navigation link. It currently allows searching for a specific term/phrase in Pages, Assignments, Discussion topics, and Announcements.

Version 5.3.1 Release Updates:

  • Updated manifest to ensure ski-report.js is loaded before the subclasses to avoid loading error
  • Updated grade overlay feature on dashboard to monitor for changes in case the overlay gets removed while the cards finish fully loading so it can be re-added

Version 5.3.2 Release Updates:

  • Fixed highlighting for Simple Search in titles
  • Added support for grade export feature on the discussion re-design
  • Refactored code for detailed logging feature to its own file
  • Added some new optional debugging messages when detailed logging is enabled

Version 5.3.3 Release Updates:

  • Deprecated feature adjusting the style on the only blueprint courses checkbox on the admin courses search due to additional search option added by Instructure
  • Deprecated feature for converting the sub-account name in the admin courses search since this is now a native feature
  • Updated placement of additional search options on the admin course search to be in their own row to improve the appearance
  • Updated browser extension options to add a link to the documentation website and improve spacing
  • Fixed feature for adding link to grades in the admin course search to not require enabling the number of students to be a link to the People page in the course

Version 6.0.0 Release Updates:

  • Updated simple search in course to add search options to only search certain types of content
  • Updated simple search in course to also be able to search course syllabus, files, and module items
  • Added new simple search feature to the All Courses page. This is like Simple Search for a course, but it searches across multiple courses the user is enrolled in. There are options to search by enrollment state as well (current, past, and/or future). Also, if the column search/filter options are used to hide some courses, they won't be included in the search results when they are hidden.

Version 6.1.0 Release Updates:

  • Added browser extension option control for the All Courses Simple Search
  • Updated the SkiReportCourseSimpleSearch to work for both a single course and the All Courses page - Updated the Simple Search results to have the content and HTML content cells appear collapsed initially. These can then be expanded as needed to view the full content if desired. This helps to reduce the total height required to display the results since each result could be long.

Version 7.0.0 Release Updates:

  • Simple Search on All Courses will search unique course IDs now rather than potentially duplicating a search if you have multiple enrollments in the same course
  • Added expand/collapse assignment groups button
  • Added expand/collapse buttons to the group sets
  • Added search and expand all to the sub-accounts list in the Admin area
  • Updated the sub-account IDs feature to apply to nested sub-accounts when they are revealed
  • Added error handling to Submission Results course report in case the request to get submissions fails

Version 7.1.0 Release Updates:

  • Updated loading message area on custom reports to scroll
  • Updated reports to append loading messages rather than replace to be able to review loading messages
  • Improved error messages and handling of failed requests in custom reports to assist with debugging and making it clear to the user when a part of the report generation fails. Report will still try to complete even if part of the process fails
  • Updated Simple Search to require at least 3 characters in the search query when including file names to search

Version 7.2.0 Release Updates:

  • Added ability to clear and/or download loading messages on custom reports
  • Added new filters to course enrollments when admin view a user's profile from account People search: roles filter, course name search, and course code search
  • Added support for Simple Search on course enrollments of a user's profile from account People search
  • Updated design and style of dialog for Simple Search to include a header, body, and footer to more closely resemble dialogs in Canvas

Version 7.3.0 Release Updates:

  • Added ability to load SIS course ID under each of the courses in the user's course enrollments (admin)
  • Added ability to filter user's course enrollments (admin) by SIS course ID
  • Grouped user's course enrollments filters by type (search inputs grouped together, and select menus grouped together)
  • Added "rejected" enrollment state as option for the course enrollments report

Version 7.3.1 Release Updates:

  • Fixed bug with terms select menu for user's course enrollment filter (admin)

Version 7.4.0 Release Updates:

  • Updated the Export Grades button on the Assignment page to be based on the SpeedGrader link rather than the graded ratio
  • Updated the Sub-Account features to work with the new re-design
  • Added a browser option to auto-expand the Sub-Accounts on page load (enabled by default)

Version 7.4.1 Release Updates:

  • Updated icon file paths in manifest
  • Updated better handling of when no student courses are found for the course grades feature on the Dashboard

Version 7.5.0 Release Updates:

  • Updated rubric import feature to work with new UI for the classic rubric design. It stopped working due to a recent update in Canvas.

Version 7.5.1 Release Updates:

  • Updated column sorts on People page of course to work with new UI updates.
  • Updated column sorts to remove dependency on English language headers and now looks for expected format of total activity column to determine if there is a last activity column and total activity column. Uses the Canvas API to get the last activity time (if column is found), to more accurately sort dates due to differences in formatting by language.

 

45 Comments
ProfessorBeyrer
Community Coach
Community Coach

Thank you @Code-with-Ski for this enhancement! The button to see all courses on the Dashboard is the first thing that made me jump with joy. 👍

Code-with-Ski
Community Participant
Author

@ProfessorBeyrer 

You're welcome!  I'm glad you are already enjoying the Chrome extension 😁 I'll include updates on here when I add new features too.

jerry_nguyen
Community Contributor

@Code-with-Ski 

Great works and thanks for sharing. I can see some useful UI improvements that I can implement directly into our Canvas (E.g "See all courses" button and SIS Import log)

By the way, I have a custom script to create a better To Do list on Canvas if you like to implement it to your Chrome extension: https://community.canvaslms.com/t5/Canvas-Developers-Group/Custom-JS-to-display-full-sortable-To-Do-...

 

 

Code-with-Ski
Community Participant
Author

@jerry_nguyen 

You're welcome!  The SIS Import log is definitely something I have found useful to help with monitoring SIS Imports and tracking down errors more easily than reading through the JSON format.  I have it on my queue to improve the infinite scrolling for that table to clearly show when it is loading more records and to prevent the duplicate requests that sometimes happen if you scroll too fast.  I'll be sure to post an update here once I release a patch for it.

The To Do list modification you created looks like a useful tool.  Thank you for sharing!  I like all the export options you have too for the data in case someone needs to save the information for later.  I see that you are using jQuery and some other third party libraries for your design, which I am trying to avoid for this side project.  Since I have to package all code in the Chrome extension, I would need to continue to monitor these third party tools for updates and security in addition to monitoring my own code and the Canvas UI updates.  Nonetheless, if I have time to make a similar version of this with vanilla JavaScript, I believe this would be a useful feature to include for teachers and admin that may need to review ungraded submissions in a class.  I may look into creating some type of export feature for the SIS Imports log too.

jerry_nguyen
Community Contributor

@Code-with-Ski 

As an admin on Canvas, I have a few suggestions on features that would improve our workflow and make life a little bit easier for admins 😏 . It would be great if you could consider implementing the following:

  • A "Create New Course Based In This BluePrint" button within a BluePrint course. Rather than having to create a blank course then open the BluePrint course and associate it.
  • A shortcut button straight to the admin Course/People search page from the Dashboard page. Saving us 3 mouse clicks + loading time  (Admin -> Account -> People)
  • Shortcut links to the following pages from the Account User Profile Enrollments list
  • Canvas_Shortcuts_Suggesstion.jpg

I'm not a programmer so I use jQuery as a shorthand. I know it's not best practice so It would be great if you could convert my script to Vanilla. I used an external table library (Datatables) because it provides exporting and sorting functions. However, I think we could simply utilise Canvas's built-in table library?

 

By the way, I spotted an issue, the sticky course title is overlapping the Blueprint button 

Canvas_Chrome_Extenstion_Issue.jpg

Code-with-Ski
Community Participant
Author

@jerry_nguyen 

Thank you for sharing your ideas!

  • For the "Create New Course Based In This BluePrint" button, I'll add it as an idea for an advanced version of the Chrome extension since it would require API calls other than "GET"
  • For the Course/People search, I was actually thinking about an idea to make a quick link to the People search page in the Admin flyout menu.  I hadn't though about putting it on the Dashboard, but I'll take that into consideration. 
    • Did you have an idea on what it might look like on the Dashboard?
    • How would it look for users that are admins in multiple accounts?
  • For the shortcut links on the user's enrollment page, that seems feasible to inject shortcut links for those too.  I'll add it as an idea to my queue

Thanks for letting me know about the error.  I thought I had fixed that overlap issue in my latest version 1.1.2.  Would you please let me know what version of the Chrome extension you are using?  I'll do some more testing on my end too to see if I can replicate that issue.

Code-with-Ski
Community Participant
Author

@jerry_nguyen 

Thank you again for letting me know about the issue with the blueprint menu overlap.  I found the issue and released a patch for it in the latest version that I just submitted to the Chrome Web Store.  Version 1.2.0 should hopefully be available by tomorrow (8/18/22).

jerry_nguyen
Community Contributor

@Code-with-Ski 

Great, the overlap issue is fixed.


  • For the Course/People search, I was actually thinking about an idea to make a quick link to the People search page in the Admin flyout menu.  I hadn't though about putting it on the Dashboard, but I'll take that into consideration. 
    • Did you have an idea on what it might look like on the Dashboard?
    • How would it look for users that are admins in multiple accounts?

I'm thinking of doing something like a Megamenu where you hover your mouse on the "Accounts" menu, a list of sub-accounts will appear, then hover on a sub-account, and the shortcuts will appear.

Canvas_Megamenu_Shortcut.jpg

Code-with-Ski
Community Participant
Author

Version 1.3.2 Release with patches for the following:

  • Sticky header is now hidden when the rich content editor is expanded to full screen within a course
  • People sort buttons are now re-added when a new table is generated when using the search or role selection filters.  The sort is also set to the previous version from the last table that was removed (if available)
bratsj58
Community Participant

This is brilliant! Thank you!

Code-with-Ski
Community Participant
Author

@bratsj58 

You're welcome!  I'm glad you are enjoying it 😀

jbeyer1
Community Participant

Could you post pictures of what we should be seeing when we use this extension? I am trying it out but I am not sure how it works since I am not seeing anything so far.  Thanks. 

Code-with-Ski
Community Participant
Author

@jbeyer1 

I am working on developing a website to document each of the features in more detail.  In the meantime, here are a couple screenshots a couple features you should see if the extension is running successfully.

On the Dashboard, you should see a "See all courses" button that is a quick link to all of the courses you are enrolled in.  In addition, if you are enrolled as a student in any of the courses on your Dashboard, you should see an overlay related to your grade in the course which should behavior the same as the Canvas feature that is available in their mobile apps.  You may also notice that the width extends to the full width of the page rather than leaving the empty white space on the right for larger screen sizes.  Depending on the size of your screen this can allow more course tiles to appear on each row.

Dashboard view with extension modifications activeDashboard view with extension modifications active

The one is of the All Courses page.  You will see the ability to sort and/or filter your courses based on the different column headings.  I do have them set-up to be disabled if sorting or filtering by that aspect wouldn't have any affect.

All Courses view with extension modifications activeAll Courses view with extension modifications active

 

If you don't see these modifications, please let me know the base URL for your school.  Currently it only works for schools with a URL like school-name.instructure.com  If you are on a custom URL like canvas.school-name.edu, I would need to make an update to the extension for it to work for you on your school's Canvas instance.

tkaser4
Community Member

@Code-with-Ski Is there a way to send you a private message with our school's URL?

Code-with-Ski
Community Participant
Author

@tkaser4 

I tried to send you a private message, but it says you don't have private messages enabled. If you enable private messages, you can send me a message on here. You can also use the Contact the publisher link on the Chrome extension web page in the Chrome Web Store. Canvas LMS Mods Basic 

dtod
Community Contributor

I wanted to get this working on our own custom domain (which it does not do currently), so I followed these instructions from StackOverflow. I downloaded the extension, extracted it to a folder, deleted the _metadata folder, and modified the manifest to allow any site. This considerably simplified the manifest. Snippet below:

  "host_permissions": [
    "https://*/*"
  ],
  "content_scripts": [
    {
      "matches": [
        "https://*/*"
      ],
      "js": [
        "global/global.js",
        "global/global-nav.js"
      ],
      "css": ["global/global.css"]
    },

When I loaded the unpacked extension, I was able to enable it on the specific sites I needed to. There is probably another way to do this, but this worked for me.

 

 

dtod
Community Contributor

There is another Canvas-specific extension that I don't recall seeing mention of before: CanvasCape.

Code-with-Ski
Community Participant
Author

@dtod 

Thanks for sharing the approach you took to make the extension work for you.  Since the list of domains has been growing, I've been thinking about modifying the extension to allow for any domain so it is easier to manage as there are a lot more custom domains than I realized.  I want to investigate if I can modify it to look for key features of Canvas, that way if someone does happen to enable it on a non-Canvas website, then it wouldn't load the customizations.  I'm currently working on a new Chrome extension focused on custom reports, but I plan to return to this one for further enhancements after launch.

As a side note, I did share the code on GitHub, so you can get the code from there rather than needing to extract the code after installing the Chrome extension: https://github.com/Code-with-Ski/Canvas-LMS-Mods  The steps you took to replace the sets of domains to be more generic works.  Alternatively, users could replace the existing domains with just their schools domain.  If someone else does make a local version, here are instructions for how you can load your own local version of a Chrome extension: https://developer.chrome.com/docs/extensions/mv3/getstarted/development-basics/#load-unpacked

Code-with-Ski
Community Participant
Author

@dtod 

The browser extension now allows users to use it with any domain if you would like to try installing it again and get the latest updates.  After installing, I do recommend updating the extension settings to limit access to your specific site or only activated on click.

Version 3.0.0 Release Updates:

  • Updated host permissions to all domains
  • Assignment
    • When you go to an Assignment, if there is a graded ratio showing on the right, you will now see options to export grades including rubric scores if applicable
  • Course Statistics (Accessed from Course Settings page)
    • Custom course reports have been added.
      • These are currently reports that load in detailed information about various content elements in the course. 
      • I plan on continuing to add reports and add search options to the reports.
  • Rubrics (Account and/or Course)
    • Drag and Drop Criteria Rows
      • When editing a rubric, you will be able to drag and drop criteria rows to re-arrange them if you need to change the order.
      • Dragging up will push existing content down when dropped, while dragging up will push existing content up
    • Import Criteria Details
      • When editing a rubric, you will be able to import the criteria details using a standard format for the information.
      • Imported content will show in the edit view so you can preview the imported content before updating/creating the rubric.

Version 3.1.0 Release Updates:

  • Updated host permissions to Instructure hosted domains as the default required and all other domains as optional
lettgo583
Community Participant

Does this work for Discussions that have rubrics? Or, only for Assignments? 

Code-with-Ski
Community Participant
Author

@lettgo583,

I don't have the export grades button on individual discussions at this time, but it is something that I may consider in a future update if I can get it to work.

In the meantime, if you go to the Course Statistics page (link is found in the right-hand side in course Settings or on the course home page if you are on min. version 3.2.0) you will see a set of custom course reports that I have developed.  If you use the Submission Details report, it will load the data for all submissions in the course.  This should include the rubric criteria data too (hidden by default, but you can show the columns after the data load).  If you download the results, you can filter them using Microsoft Excel or other spreadsheet application.

Code-with-Ski
Community Participant
Author

Version 3.2.0 Release Updates:

  • Updated Discussion Replies report to include Discussion Counts
  • Added new Enrollments course report
  • Added button link to "Course Statistics" on the home page to make it easier to get to the custom course reports in this tool
Code-with-Ski
Community Participant
Author

Version 4.0.0 Release Updates:

  • New Features
    • Rubric association report on individual rubrics
    • Used for grading indicator for rubrics on assignment details
    • Load assignment details feature on list of assignments
      • Submission type(s)
      • Whether or not it affects the final grade
      • Associated rubric, if it is used for grading, and if it uses outcome criteria
      • Option for Turnitin check too
    • Made rubric search on the rubrics page a shared feature so it works in accounts and courses
    • Load rubric details feature on list of rubrics
      • Context for rubric
      • Whether or not it has assignment associations
      • Whether or not it has outcome criteria
    • Export grades for discussion board
  • Deprecated features
    • Terms search in Admin (Instructure now has this as part of the new design)
    • Move add term button to top (Instructure now has this as the default in the new design)
Code-with-Ski
Community Participant
Author

@lettgo583 

You should now be able to export grades with the rubric details on individual discussion boards.  The Export Grades button is found under the 3-dot menu in the upper right.

discussion board export gradesdiscussion board export grades

 

lettgo583
Community Participant

That is fantastic!! Thank you!!! By the way, I'm a sub-account Canvas admin. I asked our University-wide admin about using your features campus-wide, but he mentioned that since it's an extension, that wouldn't be practical. We have adopted some of the Canvancements campus-wide though.  

Code-with-Ski
Community Participant
Author

@lettgo583 

You're welcome!  I am glad that you are already finding it useful.

As a side note, the code for the extension is open-source on GitHub if your school would like to extract features to deploy campus-wide, but I don't provide support for this currently.  However, utilizing the extension will ensure users get the latest updates and bug fixes that I release.

Code-with-Ski
Community Participant
Author

Version 5.0.0 Release Updates:

  • Course Report Updates
    • Discussion Replies report now allows you to select a specific discussion board from which to get the replies
    • Submission report now allows you to select a specific assignment from which to get submissions and to select the submission states to check
    • Loading messages were added to show which part of the process the report is working on after clicking the button to load data.  It will also show an error message if something goes wrong. 
  • Section Reports
    • Some of the custom course reports have been modified to work as section reports too.
      • Enrollment Report
      • Submissions Report
      • Module Progress Report
    • These reports can be accessed on the settings page for an individual section.
  • Manifest and File Updates
    • The config classes for SkiTable have been combined into the SkiTable class file since they are only used with that class and to simplify the number of files that need to be listed in the manifest
    • SkiTable and SkiReport files are now listed on the specific pages that they are needed in the manifest before the feature files that need them rather than loaded by default on all pages.  This will hopefully help with some inconsistent file loading sequences that were causing some errors.
Code-with-Ski
Community Participant
Author

Version 5.1.0 Release Updates:

  • Fixed bug with Discussion Replies report having an error due to deleted posts. It ignores deleted posts for now until version history becomes available.
  • Added new columns to the Assignment Details report.

Version 5.2.0 Release Updates:

  • Updated import rubric feature and drag-and-drop criteria feature for rubrics so that it also works on the assignment details page when adding/editing rubrics.
  • Patched issue with module progress report failing to complete due to module progress not existing for a requested user
  • Added a local cache to SkiReport to that common requests used across reports can be saved rather than repeating requests that are unlikely to change while using the reports. Users can refresh the page to update the cache if changes are made while using the reports.
  • Added new course/section reports:
    • Grading To Do Report
    • Grade History Report (Able to check grade history of deleted users too)
    • Missing Rubric Grade Report (Find graded submissions that had an associated rubric, but the rubric wasn't used for assessment)
    • User Access Report

Version 5.2.1 Release Updates:

  • Patched loading messages on Grade History and User Access Report
  • Patched paginated request handler for User Access
  • Patched load rubric details feature to properly work in Accounts.
Code-with-Ski
Community Participant
Author

Version 5.3.0 Release Updates:

  • Updated the "All Courses" sort to apply to all columns and disable the sort button on those that don't need to sort. This is to provide consistency in headings based on the new feature from Canvas.
  • Updated the "All Courses" filters to be a part of the original thead row with the original th elements.
  • Added a filter for the favorited state on the All Courses lists
  • Deprecated the draft comment mod in SpeedGrader since it is now a native feature
  • Added option for enabling detailed logging (currently used primarily to console log API requests)
  • Added Simple Search feature to courses as a course navigation link. It currently allows searching for a specific term/phrase in Pages, Assignments, Discussion topics, and Announcements.
Code-with-Ski
Community Participant
Author

Version 5.3.1 Release Updates:

  • Updated manifest to ensure ski-report.js is loaded before the subclasses to avoid loading error
  • Updated grade overlay feature on dashboard to monitor for changes in case the overlay gets removed while the cards finish fully loading so it can be re-added

Version 5.3.2 Release Updates:

  • Fixed highlighting for Simple Search in titles
  • Added support for grade export feature on the discussion re-design
  • Refactored code for detailed logging feature to its own file
  • Added some new optional debugging messages when detailed logging is enabled

Version 5.3.3 Release Updates:

  • Deprecated feature adjusting the style on the only blueprint courses checkbox on the admin courses search due to additional search option added by Instructure
  • Deprecated feature for converting the sub-account name in the admin courses search since this is now a native feature
  • Updated placement of additional search options on the admin course search to be in their own row to improve the appearance
  • Updated browser extension options to add a link to the documentation website and improve spacing
  • Fixed feature for adding link to grades in the admin course search to not require enabling the number of students to be a link to the People page in the course

Version 6.0.0 Release Updates:

  • Updated simple search in course to add search options to only search certain types of content
  • Updated simple search in course to also be able to search course syllabus, files, and module items
  • Added new simple search feature to the All Courses page. This is like Simple Search for a course, but it searches across multiple courses the user is enrolled in. There are options to search by enrollment state as well (current, past, and/or future). Also, if the column search/filter options are used to hide some courses, they won't be included in the search results when they are hidden.

Version 6.1.0 Release Updates:

  • Added browser extension option control for the All Courses Simple Search
  • Updated the SkiReportCourseSimpleSearch to work for both a single course and the All Courses page - Updated the Simple Search results to have the content and HTML content cells appear collapsed initially. These can then be expanded as needed to view the full content if desired. This helps to reduce the total height required to display the results since each result could be long.

Learn more about the Simple Search feature

Code-with-Ski
Community Participant
Author

Version 7.0.0 Release Updates:

  • Simple Search on All Courses will search unique course IDs now rather than potentially duplicating a search if you have multiple enrollments in the same course
  • Added expand/collapse assignment groups button
  • Added expand/collapse buttons to the group sets
  • Added search and expand all to the sub-accounts list in the Admin area
  • Updated the sub-account IDs feature to apply to nested sub-accounts when they are revealed
  • Added error handling to Submission Results course report in case the request to get submissions fails

Version 7.1.0 Release Updates:

  • Updated loading message area on custom reports to scroll
  • Updated reports to append loading messages rather than replace to be able to review loading messages
  • Improved error messages and handling of failed requests in custom reports to assist with debugging and making it clear to the user when a part of the report generation fails. Report will still try to complete even if part of the process fails
  • Updated Simple Search to require at least 3 characters in the search query when including file names to search
Code-with-Ski
Community Participant
Author

Version 7.2.0 Release Updates:

  • Added ability to clear and/or download loading messages on custom reports
  • Added new filters to course enrollments when admin view a user's profile from account People search: roles filter, course name search, and course code search
  • Added support for Simple Search on course enrollments of a user's profile from account People search
  • Updated design and style of dialog for Simple Search to include a header, body, and footer to more closely resemble dialogs in Canvas
BmoreSupport
Community Member

Thank you @Code-with-Ski for this fantastic code. I'm a fan. 

For you or others, do you have a way to show (my institution) that this plug-in is safe and outsiders can't view/keep data? 

 

Code-with-Ski
Community Participant
Author

@BmoreSupport 

The listing in the Chrome Web Store includes a Privacy Policy statement that "The developer has disclosed that it will not collect or use your data." Canvas LMS Mods (Basic) 

The source code for the Chrome extension is also open-source so your school is welcome to perform a code review.  They are also welcome to take features from the code and extract it to their own theme, but they will need to manage bug fixes on their own or watch for future updates for additional enhancements/bug fixes. Canvas LMS Mods GitHub 

If an admin from your school has more questions, they are welcome to contact me through the Canvas Community (comment on one of my blogs or a private message).  They can also contact me at the support email on my documentation website: Canvas LMS Mods website 

Code-with-Ski
Community Participant
Author

Version 7.3.0 Release Updates:

  • Added ability to load SIS course ID under each of the courses in the user's course enrollments (admin)
  • Added ability to filter user's course enrollments (admin) by SIS course ID
  • Grouped user's course enrollments filters by type (search inputs grouped together, and select menus grouped together)
  • Added "rejected" enrollment state as option for the course enrollments report

Version 7.3.1 Release Updates:

  • Fixed bug with terms select menu for user's course enrollment filter (admin)
MickCowan
Community Explorer

This extension is great! I needed to download all my rubric scores for all students to do some calculations, and this extension made that possible. It provides so many functions it seems like Canvas should have natively. I can't tell you how much this extension saved my booty with grading this year! Thank you @Code-with-Ski 

Code-with-Ski
Community Participant
Author

Version 7.4.0 Release Updates:

  • Updated the Export Grades button on the Assignment page to be based on the SpeedGrader link rather than the graded ratio
  • Updated the Sub-Account features to work with the new re-design
  • Added a browser option to auto-expand the Sub-Accounts on page load (enabled by default)

Version 7.4.1 Release Updates:

  • Updated icon file paths in manifest
  • Updated better handling of when no student courses are found for the course grades feature on the Dashboard
Code-with-Ski
Community Participant
Author

Version 7.5.0 Release Updates:

  • Updated rubric import feature to work with new UI for the classic rubric design. It stopped work due to a recent update in Canvas.
paul_fynn
Community Coach
Community Coach

Great work James ( @Code-with-Ski ) ; excellent to see how much is available through the Canvas REST API's and see it in this form. Notwithstanding the very different ways in which different organisations use Canvas, it would be great to see some of the community based solutions rolled back into the core product.

One of the things that I'd noticed recently in accessing the subaccount Course Access Log is that where a user appears in multiple sections Canvas seems to generate an access record for each event for each section enrolment. For us this happens where a teacher has a crossllsted section with several sections, and where sections have been used to organise students alongside their SIS enrolment,

So I've just looked at a current crosslist for final project on your, and I've noticed that when I select as user our external invigilator they appear multiple times - I'm guessing this is coming from the source data (either enrolments or activity logs).

Leaving to one side your really useful extension, I wondered whether you (or others following this thread) had noticed this anywhere else in the reporting ? Given the increasing use of LMS data for evaluating and guiding the student journey, I'm just a touch concerned to understand where the data may be over or under-counting....

 

dbrace
Community Coach
Community Coach

Hi @Code-with-Ski@JamesSekcienski

I wanted to bring two observations to your attention.

  1. When in the "Statistics" area and using the "Enrollment Report", whether for the default section that is created if none exists or for any actual sections that were intentionally created, the "Section Name" column reports as "ERROR" in the GUI and in the CSV file.
  2. Because of accessibility/UI changes, when in the "People" area, it is no longer possible to sort the different column headers.

-Doug

Code-with-Ski
Community Participant
Author

@dbrace 

Thank you for letting me know about these issues.  I'm working on an update to address those issues. 

For the People area column sorting, I'm also trying to update it to avoid relying on specific hard-coded column heading names.  This should provide more flexibility in the future if there are changes to that and should allow it to work for users viewing Canvas in a language other than English.

Code-with-Ski
Community Participant
Author

@paul_fynn 

I have seen those types of seemingly duplicate records at times too. Since each enrollment is unique, this does seem expected for activity reporting when a single user has multiple enrollments in one course.  For this specific example, it seems like it would likely apply to teachers rather than students and usually just with cross-listed courses.  I'm sure there are other use cases that will vary by school.

I haven't run across this as an issue with the reports that I regularly use for student reporting, but it is definitely something to keep in mind to make sure these types of duplicate records are handled appropriately.

Code-with-Ski
Community Participant
Author

Version 7.5.1 Release Updates:

  • Updated column sorts on People page of course to work with new UI updates.
  • Updated column sorts to remove dependency on English language headers and now looks for expected format of total activity column to determine if there is a last activity column and total activity column. Uses the Canvas API to get the last activity time (if column is found), to more accurately sort dates due to differences in formatting by language.
Code-with-Ski
Community Participant
Author

@dbrace 

Version 7.5.1 should resolve the issue with column sorts on the People page. Please let me know if you notice any additional issues with it.

I wasn't able to replicate the error for the Sections on the Enrollment report.  I know some people have reported that uninstalling and reinstalling the browser extension sometimes fixes unexpected bugs.  Feel free to send me a message if you have any additional details you can share about the errors you are seeing and/or if you notice any errors with requests in the Network tab of the Developer console.

dbrace
Community Coach
Community Coach

Thank you @Code-with-Ski.

I can confirm that sorting in "People" works again.

I am not sure what you did (or did not do, many something was done by Instructure) but "Section Names" are working again for the "Enrollment Report" on the "Statistics" page.

Thank you!

-Doug