When you are a professor with 80 students who submit hundreds of files to you every week, what do you do? One answer: you build your own learning management system (LMS).
Students do not name their files intuitively (“Untitled.pdf”), nor do many include their names on their homework. Some students submit inappropriate file formats or 1 gigabyte files. Some students don’t submit their homework at all.
This system isn’t a strict LMS. It’s a way to manage the insanity of tracking and organizing thousands of student files. It was built with HTML, CSS, JavaScript, and PHP over the course of a year, and it uses SQLite as a backend.
The LMS also integrated lightly with the course website (built with Jekyll). When announcements were committed to the website via git, a special git hook sent personalized emails with the contents of the announcement to each student. Students could elect to quell these announcements, if desired.
Visual Documentation
data:image/s3,"s3://crabby-images/0e1e3/0e1e3527d3232baf6e701f1ac935a2db985320b7" alt="homework cms - login 1"
Log in screen. Background photography of artwork from the Amsterdam Light Festival.
data:image/s3,"s3://crabby-images/2ccac/2ccacf802a7542003f87dda11c1d1303d282c176" alt="homework cms - upload 2"
Upload files for a given assignment.
data:image/s3,"s3://crabby-images/a1dab/a1dab39f024728301d43afb5b06129d249396588" alt="homework cms - file listing"
File listing of a student’s files. Includes a summary of missing files and indicates overdue assignments.
data:image/s3,"s3://crabby-images/880db/880dbff783256c4578ef13d6870c76376f3cf198" alt="homework cms - notifications"
A panel to toggle various email notifications from the system. One of the notifications is a weekly email with a report listing all of the submitted and overdue homework assignments.
data:image/s3,"s3://crabby-images/ad0e7/ad0e7b25ff3688b5d702fa7ec8aaf11e90f0cfe1" alt="homework cms - activity log"
An activity log. It also lists when new announcements have been published on the course website.
data:image/s3,"s3://crabby-images/0aa02/0aa027d2569f338c1e6dbcee65f397aaea1a683f" alt="homework cms - account settings 2"
Change the account password.
data:image/s3,"s3://crabby-images/7c212/7c212d74bd68f479fb55c44362bc3d553fa14cce" alt="homework cms - homework status"
This status report is an administrator screen. I could see an overview of all the students and all of the assignments and whether they’d been submitted.
data:image/s3,"s3://crabby-images/b07ba/b07ba6239b85af2b6f7506fe7fea60e5342db69c" alt="homework cms - individual student file listing"
The status report also included a detailed listing of every students’ files. Hovering over a students name would summon a download icon to download a zip file of all of that students’ files. Hovering over an assignment name would summon a download icon to download a zip file of all of that assignment’s files.
data:image/s3,"s3://crabby-images/c1d15/c1d15cd7e29fb6716e1b9575738ad10360859845" alt="homework cms - logged out"
Logged out. Background photography of artwork from the Amsterdam Light Festival.