Improve event summary parsing in course model

This commit refines event summary parsing in the course model. Instead of splitting the summary, it uses regular expressions to extract the unit code and short lecture title more accurately. The update also includes better handling of events that don't match this format.
This commit is contained in:
Joshua Coles 2024-02-04 14:03:13 +00:00
parent 49282a72bf
commit f0b458f6a1

View File

@ -18,14 +18,15 @@ class Course < ApplicationRecord
calendar = calendars.first calendar = calendars.first
events = calendar.events.map do |event| events = calendar.events.map do |event|
# Example title include: PH40065B-Lab, PH40112-Lecc (Wk 19-25, 29-32), MA40049-Leca (LOIL), MA40049-Lecb
summary = event.summary summary = event.summary
match = summary.split('-') match = /(^\w\w\d{5})-(\w+)/.match(summary)
# Handle odd events we don't care about # Handle odd events we don't care about
next if match.length != 2 next if match.nil?
unit_code = match[0] unit_code = match[1]
short_lecture_title = match[1] short_lecture_title = match[2]
start_time = event.dtstart.to_time start_time = event.dtstart.to_time
event_uuid = event.uid.to_s event_uuid = event.uid.to_s