mirror of
https://github.com/NinjaCheetah/RIT-Dining.git
synced 2025-10-19 06:36:18 -04:00
The app was previously not checking if the current day of the week was within the list of weekdays that the regular opening schedule was valid for. This lead to the app frequently claiming a location was open on the weekend when it wasn't, which burned me personally several times. I've gone to like 4 locations this weekend under the assumption they were open because my own app said so, and finally I was like "hey maybe this isn't the data being bad and I've messed something up" and lo and behold, I did. Oops. Also removes the middleman API call to get the MDO ID from the main location ID, as I realized the location info from TigerCenter actually includes the MDO ID already. This simplifies the code for getting the occupancy of a location by a good bit and just makes me happy.
137 lines
3.8 KiB
Swift
137 lines
3.8 KiB
Swift
//
|
|
// Types.swift
|
|
// RIT Dining
|
|
//
|
|
// Created by Campbell on 9/2/25.
|
|
//
|
|
|
|
import Foundation
|
|
|
|
// I'll be honest, I am NOT good at representing other people's JSON in my code. This kinda sucks but it gets the job done and can
|
|
// be improved later when I feel like it.
|
|
struct DiningLocationParser: Decodable {
|
|
// An individual "event", which is just an open period for the location.
|
|
struct Event: Decodable {
|
|
// Hour exceptions for the given event.
|
|
struct HoursException: Decodable {
|
|
let id: Int
|
|
let name: String
|
|
let startTime: String
|
|
let endTime: String
|
|
let startDate: String
|
|
let endDate: String
|
|
let open: Bool
|
|
}
|
|
let startTime: String
|
|
let endTime: String
|
|
let daysOfWeek: [String]
|
|
let exceptions: [HoursException]?
|
|
}
|
|
// An individual "menu", which can be either a daily special item or a visitng chef. Description needs to be optional because
|
|
// visiting chefs have descriptions but specials do not.
|
|
struct Menu: Decodable {
|
|
let name: String
|
|
let description: String?
|
|
let category: String
|
|
}
|
|
// Other basic information to read from a location's JSON that we'll need later.
|
|
let id: Int
|
|
let mdoId: Int
|
|
let name: String
|
|
let summary: String
|
|
let description: String
|
|
let mapsUrl: String
|
|
let events: [Event]
|
|
let menus: [Menu]
|
|
}
|
|
|
|
// Struct that probably doesn't need to exist but this made parsing the list of location responses easy.
|
|
struct DiningLocationsParser: Decodable {
|
|
let locations: [DiningLocationParser]
|
|
}
|
|
|
|
// Enum to represent the four possible states a given location can be in.
|
|
enum OpenStatus {
|
|
case open
|
|
case closed
|
|
case openingSoon
|
|
case closingSoon
|
|
}
|
|
|
|
// An individual open period for a location.
|
|
struct DiningTimes: Equatable, Hashable {
|
|
var openTime: Date
|
|
var closeTime: Date
|
|
}
|
|
|
|
// Enum to represent the five possible states a visiting chef can be in.
|
|
enum VisitingChefStatus {
|
|
case hereNow
|
|
case gone
|
|
case arrivingLater
|
|
case arrivingSoon
|
|
case leavingSoon
|
|
}
|
|
|
|
// A visiting chef present at a location.
|
|
struct VisitingChef: Equatable, Hashable {
|
|
let name: String
|
|
let description: String
|
|
var openTime: Date
|
|
var closeTime: Date
|
|
let status: VisitingChefStatus
|
|
}
|
|
|
|
// A daily special at a location.
|
|
struct DailySpecial: Equatable, Hashable {
|
|
let name: String
|
|
let type: String
|
|
}
|
|
|
|
// The basic information about a dining location needed to display it in the app after parsing is finished.
|
|
struct DiningLocation: Identifiable, Hashable {
|
|
let id: Int
|
|
let mdoId: Int
|
|
let name: String
|
|
let summary: String
|
|
let desc: String
|
|
let mapsUrl: String
|
|
let diningTimes: [DiningTimes]?
|
|
var open: OpenStatus
|
|
let visitingChefs: [VisitingChef]?
|
|
let dailySpecials: [DailySpecial]?
|
|
}
|
|
|
|
// Parser used to parse the data from the maps.rit.edu/api/api-dining.php used as a middleman to translate the IDs from TigerCenter
|
|
// to the IDs used for the maps API.
|
|
struct MapsMiddlemanParser: Decodable {
|
|
// Properties of the location, which are all I need.
|
|
struct Properties: Decodable {
|
|
let name: String
|
|
let url: String
|
|
let id: String
|
|
let mdoid: String
|
|
}
|
|
let properties: Properties
|
|
}
|
|
|
|
// Parser to read the occupancy data for a location.
|
|
struct DiningOccupancyParser: Decodable {
|
|
// Represents a per-hour occupancy rating.
|
|
struct HourlyOccupancy: Decodable {
|
|
let hour: Int
|
|
let today: Int
|
|
let today_max: Int
|
|
let one_week_ago: Int
|
|
let one_week_ago_max: Int
|
|
let average: Int
|
|
}
|
|
let count: Int
|
|
let location: String
|
|
let building: String
|
|
let mdo_id: Int
|
|
let max_occ: Int
|
|
let open_status: String
|
|
let intra_loc_hours: [HourlyOccupancy]
|
|
}
|