Michigan Tech

Courses

Background

In early 2020 I and a few other students worked on a website that allowed you to easily see courses that are pre-approved for transfer to Michigan Tech since it's a real pain to find them manually. We originally planned to add support for showing Tech-offered courses to the same tool, but not everyone was available.

I ended up building it as a separate project over the next few months. I planned to release it in two parts: first a MVP and then a more feature-rich application.

I launched the initial version in March of 2021. Even though it was fairly basic, the tool still received a very positive reception.

I launched the feature-rich v2 seven months later, again to a very positive reception.

Design

Inspired by tools like Spotlight, Alfred, Raycast, and even GitHub Issues, the primary interface to finding courses is a free-form search field. You can enter keywords, and then narrow your search by using filters of the form token:value. For example, intro subject:cs might return Intro to Programming.

The app's UI is primarily designed around reducing the number of clicks required for any particular action. Just compare how long it takes to view a course description on my app vs. Banweb (Tech's course system):

Since this is a mostly STEM school, many students have wide and/or 4k monitors. I wanted to improve the workflow if extra screen space was available, so there's a 2-column layout that's activated when the browser window is wide enough:

demo on an ultrawide monitor

Because many users often don't keep their browser window fully expanded in day-to-day use, I also added a tip instructing users to resize their browser that appears if this 2-column layout is supported.

Features

The main goal of this app was to provide both a smoother experience and additional features as compared to Banweb. For example, integrated statistics on pass, fail, drop, and class size data are shown for each course—something that Michigan Tech doesn't expose anywhere (information was retrieved through a FOIA request). Instructor ratings are also synced from Rate My Professors, so students can easily see if a course they're looking at has a particularly good or bad professor.

Of course, the biggest additional value that my app provides are what I call "baskets."

Baskets allow you to save any number of courses to a table for reference. A few features include:

  • Exporting the basket as an image or .csv file
  • Generating an importable calendar
  • Showing a realtime-preview of your schedule with monthly and weekly views
  • Filtering by sections schedule-compatible with your basket with the is:compatible search filter
  • Correctly handling edge cases, like warning you if a section was deleted from Banweb

Problems Encountered

I spent a few days looking at moving much of the core logic to Web Workers to keep the main UI thread responsive, but ultimately the complexity trade-off didn't seem worth it. After some experimentation, I was able to greatly reduce loading time and increase general responsiveness by moving expensive tasks into several requestIdleCallback() calls, which allows for better utilization of the main single thread.

As another example of an optimization necessary for this specific application, I moved from a more elegant comparison of schedules to more of a static analysis approach that makes a few assumptions, shaving several seconds off filtering sections by those schedule-compatible with the current basket.

Besides performance issues, I opened a PR and a few issues with some of the open-source libraries I was using.

I also managed to accidentally DDoS the school's course system during development of the scraper:

oops

Results

As of November 2024 (3 years later), according to analytics around 80-90% of the student body actively uses Michigan Tech Courses.