diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index 484d5bbb..1703ca76 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -1,4 +1,4 @@ # codeowners' reviews are required before merging -* @PatrickKan @jeffkim2001 @ashayp22 +* @jeffkim2001 @ashayp22 @lasyaneti diff --git a/HIAPI/Models/Attendee.swift b/HIAPI/Models/Attendee.swift index 7da5a360..d5f43adc 100644 --- a/HIAPI/Models/Attendee.swift +++ b/HIAPI/Models/Attendee.swift @@ -26,4 +26,5 @@ public struct Attendee: Codable, APIReturnable { public let school: String public let major: String public let gender: String + public let dietary: [String]? } diff --git a/HIAPI/Models/Event.swift b/HIAPI/Models/Event.swift index 2a81ea9a..06f3f615 100644 --- a/HIAPI/Models/Event.swift +++ b/HIAPI/Models/Event.swift @@ -23,6 +23,47 @@ public struct EventContainer: Decodable, APIReturnable { } } +public struct StaffEventContainer: Decodable, APIReturnable { + public let events: [StaffEvent] + + public init(from data: Data) throws { + let decoder = JSONDecoder() + decoder.dateDecodingStrategy = .secondsSince1970 + self = try decoder.decode(StaffEventContainer.self, from: data) + } +} + +public struct StaffEvent: Codable { + internal enum CodingKeys: String, CodingKey { + case id + case endTime + case eventType + case info = "description" + case locations + case name + case sponsor + case startTime + case points + case isAsync + case isPrivate + case displayOnStaffCheckin + } + + public var id: String + public let endTime: Date + public let eventType: String + public let info: String + public let locations: [Location] + public let name: String + public let sponsor: String + public let startTime: Date + public let points: Int + public let isAsync: Bool + public let isPrivate: Bool + public let displayOnStaffCheckin: Bool +} + + public struct Event: Codable { internal enum CodingKeys: String, CodingKey { case id diff --git a/HIAPI/Models/Profile.swift b/HIAPI/Models/Profile.swift index fdf360e3..faf6318b 100644 --- a/HIAPI/Models/Profile.swift +++ b/HIAPI/Models/Profile.swift @@ -29,7 +29,7 @@ public struct Profile: Codable, APIReturnable { case firstName case lastName case points - case timezone + case foodWave case discord case avatarUrl } @@ -38,7 +38,7 @@ public struct Profile: Codable, APIReturnable { public let firstName: String public let lastName: String public let points: Int - public let timezone: String + public let foodWave: Int public let discord: String public let avatarUrl: String } diff --git a/HIAPI/Models/User.swift b/HIAPI/Models/User.swift index d5c2b9a3..17011a10 100644 --- a/HIAPI/Models/User.swift +++ b/HIAPI/Models/User.swift @@ -28,7 +28,7 @@ public struct RolesContainer: Codable, APIReturnable { public struct Roles: OptionSet, Codable { public let rawValue: Int - public static let null = Roles(rawValue: 0) + public static let null = Roles([]) public static let user = Roles(rawValue: 1 << 0) public static let applicant = Roles(rawValue: 1 << 1) public static let attendee = Roles(rawValue: 1 << 2) @@ -93,6 +93,11 @@ fileprivate extension Optional where Wrapped == String { } } +public struct QRData: Codable, APIReturnable { + public let id: String + public let qrInfo: String +} + public struct DietaryRestrictions: OptionSet, Codable, APIReturnable { public let rawValue: Int diff --git a/HIAPI/Services/EventService.swift b/HIAPI/Services/EventService.swift index 489c779d..d833d3d7 100644 --- a/HIAPI/Services/EventService.swift +++ b/HIAPI/Services/EventService.swift @@ -29,6 +29,19 @@ public class EventService: BaseService { return APIRequest(service: self, endpoint: "checkin/", body: body, method: .POST) } + public static func staffCheckIn(userToken: String, eventId: String) -> APIRequest { + var body = HTTPBody() + body["userToken"] = userToken + body["eventId"] = eventId + return APIRequest(service: self, endpoint: "staff/checkin/", body: body, method: .POST) + } + + public static func getStaffCheckInEvents(authToken: String) -> APIRequest { + var header = HTTPHeaders() + header["Authorization"] = authToken + return APIRequest(service: self, endpoint: "filter/?displayOnStaffCheckin=true", headers: header, method: .GET) + } + public static func create(event: Event) -> APIRequest { let eventDict = [String: Any]() assert(false) diff --git a/HIAPI/Services/RegistrationService.swift b/HIAPI/Services/RegistrationService.swift index 03fa8fe6..f27280ff 100644 --- a/HIAPI/Services/RegistrationService.swift +++ b/HIAPI/Services/RegistrationService.swift @@ -21,4 +21,9 @@ public final class RegistrationService: BaseService { public static func getAttendee() -> APIRequest { return APIRequest(service: self, endpoint: "", method: .GET) } + + public static func getAttendeeRegistrationUserID(userID: String) -> APIRequest { + + return APIRequest(service: self, endpoint: "attendee/" + userID + "/", method: .GET) + } } diff --git a/HIAPI/Services/UserService.swift b/HIAPI/Services/UserService.swift index 58c209bc..6dd3aaa9 100644 --- a/HIAPI/Services/UserService.swift +++ b/HIAPI/Services/UserService.swift @@ -21,4 +21,8 @@ public final class UserService: BaseService { public static func getUser() -> APIRequest { return APIRequest(service: self, endpoint: "", headers: headers, method: .GET) } + + public static func getQR() -> APIRequest { + return APIRequest(service: self, endpoint: "qr/", method: .GET) + } } diff --git a/HackIllinois.xcodeproj/project.pbxproj b/HackIllinois.xcodeproj/project.pbxproj index 5735868e..29454f88 100644 --- a/HackIllinois.xcodeproj/project.pbxproj +++ b/HackIllinois.xcodeproj/project.pbxproj @@ -119,7 +119,7 @@ AC3B621625E8611C002386A2 /* HIProfileDataSource.swift in Sources */ = {isa = PBXBuildFile; fileRef = AC3B621525E8611C002386A2 /* HIProfileDataSource.swift */; }; AC5E9FE326195CCF00674FCF /* HIEventType.swift in Sources */ = {isa = PBXBuildFile; fileRef = AC5E9FE226195CCF00674FCF /* HIEventType.swift */; }; AC607EF0261CD6E300B88798 /* Stickers.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = AC607EEF261CD6E300B88798 /* Stickers.xcassets */; }; - AC607EF4261CD6E300B88798 /* Stickers.appex in Embed App Extensions */ = {isa = PBXBuildFile; fileRef = AC607EED261CD6E100B88798 /* Stickers.appex */; settings = {ATTRIBUTES = (RemoveHeadersOnCopy, ); }; }; + AC607EF4261CD6E300B88798 /* Stickers.appex in Embed Foundation Extensions */ = {isa = PBXBuildFile; fileRef = AC607EED261CD6E100B88798 /* Stickers.appex */; settings = {ATTRIBUTES = (RemoveHeadersOnCopy, ); }; }; AC6F15A6261BB1B400422192 /* HIErrorView.swift in Sources */ = {isa = PBXBuildFile; fileRef = AC6F15A5261BB1B400422192 /* HIErrorView.swift */; }; ACA63C8B25E7394D00A00D83 /* HIProfile.swift in Sources */ = {isa = PBXBuildFile; fileRef = ACA63C8A25E7394D00A00D83 /* HIProfile.swift */; }; ACAA717626017EC4000F42B0 /* HICollectionViewFlowLayout.swift in Sources */ = {isa = PBXBuildFile; fileRef = ACAA717526017EC4000F42B0 /* HICollectionViewFlowLayout.swift */; }; @@ -132,7 +132,36 @@ BCEBD2DA23DE995700D32F5A /* HIPopupAnimator.swift in Sources */ = {isa = PBXBuildFile; fileRef = BCEBD2D923DE995700D32F5A /* HIPopupAnimator.swift */; }; BF0FDA3925F4DCCD003B5DB1 /* HIScheduleSegmentedControl.swift in Sources */ = {isa = PBXBuildFile; fileRef = BF0FDA3825F4DCCD003B5DB1 /* HIScheduleSegmentedControl.swift */; }; BFB1FD3E26105EA400500008 /* HIEditProfileCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = BFB1FD3D26105EA400500008 /* HIEditProfileCell.swift */; }; + D134D30F296B3F56006EA589 /* Montserrat-VariableFont_wght.ttf in Resources */ = {isa = PBXBuildFile; fileRef = D134D30E296B3F56006EA589 /* Montserrat-VariableFont_wght.ttf */; }; + D14D3AE3295FBDA200EB7995 /* HIBannerViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = D14D3AE2295FBDA100EB7995 /* HIBannerViewController.swift */; }; D3A309BC2211175200CBA351 /* PassKit.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = D3A309BB2211175200CBA351 /* PassKit.framework */; }; + DF3706382925DDAA000B4278 /* GoogleMapsBase.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DF3706372925DDAA000B4278 /* GoogleMapsBase.framework */; }; + DF37063B2925DDB8000B4278 /* GoogleMaps.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DF3706392925DDB7000B4278 /* GoogleMaps.framework */; }; + DF37063C2925DDB8000B4278 /* GoogleMapsCore.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DF37063A2925DDB8000B4278 /* GoogleMapsCore.framework */; }; + DF37063E2925DDE7000B4278 /* GoogleMaps.bundle in Resources */ = {isa = PBXBuildFile; fileRef = DF37063D2925DDE7000B4278 /* GoogleMaps.bundle */; }; + DF3706402925DE08000B4278 /* Accelerate.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DF37063F2925DE08000B4278 /* Accelerate.framework */; }; + DF3706422925DE0F000B4278 /* CoreData.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DF3706412925DE0F000B4278 /* CoreData.framework */; }; + DF3706442925DE15000B4278 /* CoreGraphics.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DF3706432925DE15000B4278 /* CoreGraphics.framework */; }; + DF3706462925DE1B000B4278 /* CoreImage.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DF3706452925DE1B000B4278 /* CoreImage.framework */; }; + DF3706482925DE22000B4278 /* CoreLocation.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DF3706472925DE22000B4278 /* CoreLocation.framework */; }; + DF37064A2925DE27000B4278 /* CoreTelephony.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DF3706492925DE27000B4278 /* CoreTelephony.framework */; }; + DF37064C2925DE2F000B4278 /* CoreText.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DF37064B2925DE2F000B4278 /* CoreText.framework */; }; + DF37064E2925DE34000B4278 /* GLKit.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DF37064D2925DE34000B4278 /* GLKit.framework */; }; + DF3706502925DE38000B4278 /* ImageIO.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DF37064F2925DE38000B4278 /* ImageIO.framework */; }; + DF3706522925DE42000B4278 /* libc++.tbd in Frameworks */ = {isa = PBXBuildFile; fileRef = DF3706512925DE42000B4278 /* libc++.tbd */; }; + DF3706542925DE47000B4278 /* libz.tbd in Frameworks */ = {isa = PBXBuildFile; fileRef = DF3706532925DE47000B4278 /* libz.tbd */; }; + DF3706562925DE4C000B4278 /* Metal.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DF3706552925DE4C000B4278 /* Metal.framework */; }; + DF3706582925DE50000B4278 /* OpenGLES.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DF3706572925DE50000B4278 /* OpenGLES.framework */; }; + DF37065A2925DE57000B4278 /* QuartzCore.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DF3706592925DE57000B4278 /* QuartzCore.framework */; }; + DF37065C2925DE5D000B4278 /* SystemConfiguration.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DF37065B2925DE5D000B4278 /* SystemConfiguration.framework */; }; + DF37065E2925DE66000B4278 /* UIKit.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DF37065D2925DE66000B4278 /* UIKit.framework */; }; + E1BF5E7A298B462F00A98390 /* HIStaffButtonView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E1BF5E79298B462F00A98390 /* HIStaffButtonView.swift */; }; + DF5B27C5299197E80034A8B9 /* Array.swift in Sources */ = {isa = PBXBuildFile; fileRef = DF5B27C4299197E80034A8B9 /* Array.swift */; }; + DF5B27C7299372AE0034A8B9 /* Hack_PopcornCart_Text.json in Resources */ = {isa = PBXBuildFile; fileRef = DF5B27C6299372AE0034A8B9 /* Hack_PopcornCart_Text.json */; }; + E170038A29679D08009B99A8 /* HIProfileCardView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E170038929679D08009B99A8 /* HIProfileCardView.swift */; }; + E1E4A5D9291C9BF800780BA1 /* HICarouselSwiftUIView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E1E4A5D6291C9BF700780BA1 /* HICarouselSwiftUIView.swift */; }; + E1E4A5DA291C9BF800780BA1 /* HIOnboardingView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E1E4A5D7291C9BF700780BA1 /* HIOnboardingView.swift */; }; + E1E4A5DB291C9BF800780BA1 /* HIOnboardingViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = E1E4A5D8291C9BF700780BA1 /* HIOnboardingViewModel.swift */; }; /* End PBXBuildFile section */ /* Begin PBXContainerItemProxy section */ @@ -153,15 +182,15 @@ /* End PBXContainerItemProxy section */ /* Begin PBXCopyFilesBuildPhase section */ - 35D7CE9F20380ACF00654E28 /* Embed App Extensions */ = { + 35D7CE9F20380ACF00654E28 /* Embed Foundation Extensions */ = { isa = PBXCopyFilesBuildPhase; buildActionMask = 2147483647; dstPath = ""; dstSubfolderSpec = 13; files = ( - AC607EF4261CD6E300B88798 /* Stickers.appex in Embed App Extensions */, + AC607EF4261CD6E300B88798 /* Stickers.appex in Embed Foundation Extensions */, ); - name = "Embed App Extensions"; + name = "Embed Foundation Extensions"; runOnlyForDeploymentPostprocessing = 0; }; 95E3143621FAD5B40092C22E /* Embed Frameworks */ = { @@ -304,8 +333,37 @@ BCEBD2D923DE995700D32F5A /* HIPopupAnimator.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; name = HIPopupAnimator.swift; path = HackIllinois/UI/Animations/HIPopupAnimator.swift; sourceTree = SOURCE_ROOT; }; BF0FDA3825F4DCCD003B5DB1 /* HIScheduleSegmentedControl.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = HIScheduleSegmentedControl.swift; sourceTree = ""; }; BFB1FD3D26105EA400500008 /* HIEditProfileCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = HIEditProfileCell.swift; sourceTree = ""; }; + D134D30E296B3F56006EA589 /* Montserrat-VariableFont_wght.ttf */ = {isa = PBXFileReference; lastKnownFileType = file; path = "Montserrat-VariableFont_wght.ttf"; sourceTree = ""; }; + D14D3AE2295FBDA100EB7995 /* HIBannerViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = HIBannerViewController.swift; sourceTree = ""; }; D3A309BA221116A600CBA351 /* HackIllinois.entitlements */ = {isa = PBXFileReference; lastKnownFileType = text.plist.entitlements; path = HackIllinois.entitlements; sourceTree = ""; }; D3A309BB2211175200CBA351 /* PassKit.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = PassKit.framework; path = System/Library/Frameworks/PassKit.framework; sourceTree = SDKROOT; }; + DF3706372925DDAA000B4278 /* GoogleMapsBase.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; path = GoogleMapsBase.framework; sourceTree = ""; }; + DF3706392925DDB7000B4278 /* GoogleMaps.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; path = GoogleMaps.framework; sourceTree = ""; }; + DF37063A2925DDB8000B4278 /* GoogleMapsCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; path = GoogleMapsCore.framework; sourceTree = ""; }; + DF37063D2925DDE7000B4278 /* GoogleMaps.bundle */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.plug-in"; name = GoogleMaps.bundle; path = HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle; sourceTree = ""; }; + DF37063F2925DE08000B4278 /* Accelerate.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Accelerate.framework; path = System/Library/Frameworks/Accelerate.framework; sourceTree = SDKROOT; }; + DF3706412925DE0F000B4278 /* CoreData.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = CoreData.framework; path = System/Library/Frameworks/CoreData.framework; sourceTree = SDKROOT; }; + DF3706432925DE15000B4278 /* CoreGraphics.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = CoreGraphics.framework; path = System/Library/Frameworks/CoreGraphics.framework; sourceTree = SDKROOT; }; + DF3706452925DE1B000B4278 /* CoreImage.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = CoreImage.framework; path = System/Library/Frameworks/CoreImage.framework; sourceTree = SDKROOT; }; + DF3706472925DE22000B4278 /* CoreLocation.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = CoreLocation.framework; path = System/Library/Frameworks/CoreLocation.framework; sourceTree = SDKROOT; }; + DF3706492925DE27000B4278 /* CoreTelephony.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = CoreTelephony.framework; path = System/Library/Frameworks/CoreTelephony.framework; sourceTree = SDKROOT; }; + DF37064B2925DE2F000B4278 /* CoreText.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = CoreText.framework; path = System/Library/Frameworks/CoreText.framework; sourceTree = SDKROOT; }; + DF37064D2925DE34000B4278 /* GLKit.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = GLKit.framework; path = System/Library/Frameworks/GLKit.framework; sourceTree = SDKROOT; }; + DF37064F2925DE38000B4278 /* ImageIO.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = ImageIO.framework; path = System/Library/Frameworks/ImageIO.framework; sourceTree = SDKROOT; }; + DF3706512925DE42000B4278 /* libc++.tbd */ = {isa = PBXFileReference; lastKnownFileType = "sourcecode.text-based-dylib-definition"; name = "libc++.tbd"; path = "usr/lib/libc++.tbd"; sourceTree = SDKROOT; }; + DF3706532925DE47000B4278 /* libz.tbd */ = {isa = PBXFileReference; lastKnownFileType = "sourcecode.text-based-dylib-definition"; name = libz.tbd; path = usr/lib/libz.tbd; sourceTree = SDKROOT; }; + DF3706552925DE4C000B4278 /* Metal.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Metal.framework; path = System/Library/Frameworks/Metal.framework; sourceTree = SDKROOT; }; + DF3706572925DE50000B4278 /* OpenGLES.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = OpenGLES.framework; path = System/Library/Frameworks/OpenGLES.framework; sourceTree = SDKROOT; }; + DF3706592925DE57000B4278 /* QuartzCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = QuartzCore.framework; path = System/Library/Frameworks/QuartzCore.framework; sourceTree = SDKROOT; }; + DF37065B2925DE5D000B4278 /* SystemConfiguration.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = SystemConfiguration.framework; path = System/Library/Frameworks/SystemConfiguration.framework; sourceTree = SDKROOT; }; + DF37065D2925DE66000B4278 /* UIKit.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = UIKit.framework; path = System/Library/Frameworks/UIKit.framework; sourceTree = SDKROOT; }; + E1BF5E79298B462F00A98390 /* HIStaffButtonView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = HIStaffButtonView.swift; sourceTree = ""; }; + DF5B27C4299197E80034A8B9 /* Array.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Array.swift; sourceTree = ""; }; + DF5B27C6299372AE0034A8B9 /* Hack_PopcornCart_Text.json */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.json; path = Hack_PopcornCart_Text.json; sourceTree = ""; }; + E170038929679D08009B99A8 /* HIProfileCardView.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = HIProfileCardView.swift; sourceTree = ""; }; + E1E4A5D6291C9BF700780BA1 /* HICarouselSwiftUIView.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = HICarouselSwiftUIView.swift; sourceTree = ""; }; + E1E4A5D7291C9BF700780BA1 /* HIOnboardingView.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = HIOnboardingView.swift; sourceTree = ""; }; + E1E4A5D8291C9BF700780BA1 /* HIOnboardingViewModel.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = HIOnboardingViewModel.swift; sourceTree = ""; }; /* End PBXFileReference section */ /* Begin PBXFrameworksBuildPhase section */ @@ -313,7 +371,26 @@ isa = PBXFrameworksBuildPhase; buildActionMask = 2147483647; files = ( + DF37065E2925DE66000B4278 /* UIKit.framework in Frameworks */, + DF37065C2925DE5D000B4278 /* SystemConfiguration.framework in Frameworks */, + DF37065A2925DE57000B4278 /* QuartzCore.framework in Frameworks */, + DF3706582925DE50000B4278 /* OpenGLES.framework in Frameworks */, + DF3706562925DE4C000B4278 /* Metal.framework in Frameworks */, + DF3706542925DE47000B4278 /* libz.tbd in Frameworks */, + DF3706522925DE42000B4278 /* libc++.tbd in Frameworks */, + DF3706502925DE38000B4278 /* ImageIO.framework in Frameworks */, + DF37064E2925DE34000B4278 /* GLKit.framework in Frameworks */, + DF37064C2925DE2F000B4278 /* CoreText.framework in Frameworks */, + DF37064A2925DE27000B4278 /* CoreTelephony.framework in Frameworks */, + DF3706482925DE22000B4278 /* CoreLocation.framework in Frameworks */, + DF3706462925DE1B000B4278 /* CoreImage.framework in Frameworks */, + DF3706442925DE15000B4278 /* CoreGraphics.framework in Frameworks */, + DF3706422925DE0F000B4278 /* CoreData.framework in Frameworks */, + DF3706402925DE08000B4278 /* Accelerate.framework in Frameworks */, + DF37063B2925DDB8000B4278 /* GoogleMaps.framework in Frameworks */, + DF3706382925DDAA000B4278 /* GoogleMapsBase.framework in Frameworks */, 951E67F923C1C88200477703 /* Lottie in Frameworks */, + DF37063C2925DDB8000B4278 /* GoogleMapsCore.framework in Frameworks */, 951E67F623C1C83B00477703 /* Keychain in Frameworks */, D3A309BC2211175200CBA351 /* PassKit.framework in Frameworks */, 95E3143121FAD5B40092C22E /* HIAPI.framework in Frameworks */, @@ -372,6 +449,7 @@ 951827761EA35AF100049F79 = { isa = PBXGroup; children = ( + DF37063D2925DDE7000B4278 /* GoogleMaps.bundle */, 951827971EA35DB800049F79 /* HackIllinois */, 95E3142B21FAD5B40092C22E /* HIAPI */, AC607EEE261CD6E100B88798 /* Stickers */, @@ -393,6 +471,11 @@ 951827971EA35DB800049F79 /* HackIllinois */ = { isa = PBXGroup; children = ( + D134D30D296B3F40006EA589 /* Fonts */, + DF3706392925DDB7000B4278 /* GoogleMaps.framework */, + DF37063A2925DDB8000B4278 /* GoogleMapsCore.framework */, + DF3706372925DDAA000B4278 /* GoogleMapsBase.framework */, + E1E4A5D4291C9BF700780BA1 /* SwiftUI */, D3A309BA221116A600CBA351 /* HackIllinois.entitlements */, 957DB2E41FC2435100F8C45E /* ViewControllers */, 957DB2E91FC2453100F8C45E /* FlowControllers */, @@ -479,6 +562,7 @@ 9510F6A61FCB7E53007D19DB /* HIBaseScannerViewController.swift */, 95C3BE2F2008B99C0008ED79 /* HIBaseViewController.swift */, 35240BD0201408DB00E0C0D8 /* HICountdownViewController.swift */, + D14D3AE2295FBDA100EB7995 /* HIBannerViewController.swift */, 95C18DC720096539004784B5 /* HIEventDetailViewController.swift */, 95C18DC920096539004784B5 /* HIEventListViewController.swift */, 9515E43622093E1300BCAF92 /* HIEventScannerViewController.swift */, @@ -487,7 +571,9 @@ 95CCEA1E203D6B3600E3E28C /* HINavigationController.swift */, 95C18DC820096539004784B5 /* HIScheduleViewController.swift */, 98CA2A3D25C899CF003E842A /* HIProfileViewController.swift */, + E170038929679D08009B99A8 /* HIProfileCardView.swift */, 60EAF98A273B1AC4002CD205 /* HIScanQRCodeViewController.swift */, + E1BF5E79298B462F00A98390 /* HIStaffButtonView.swift */, 1C9045D3274F065F00DDA74E /* HIOnboardingViewController.swift */, 3FBFA7AA27335554001FFF28 /* HILeaderboardListViewController.swift */, 3FBFA7B427335ABC001FFF28 /* HILeaderboardViewController.swift */, @@ -512,6 +598,7 @@ 9552D92721758E4C00A8C869 /* UIView+AutoLayout.swift */, 95CA922F201E60D300C46037 /* UIImage+QRCode.swift */, 1C63EE6827680DF500D60653 /* CIImage.swift */, + DF5B27C4299197E80034A8B9 /* Array.swift */, ); path = Extensions; sourceTree = ""; @@ -673,9 +760,53 @@ path = Cells; sourceTree = ""; }; + D134D30D296B3F40006EA589 /* Fonts */ = { + isa = PBXGroup; + children = ( + D134D30E296B3F56006EA589 /* Montserrat-VariableFont_wght.ttf */, + ); + path = Fonts; + sourceTree = ""; + }; + E1E4A5D4291C9BF700780BA1 /* SwiftUI */ = { + isa = PBXGroup; + children = ( + E1E4A5D5291C9BF700780BA1 /* UI */, + E1E4A5D7291C9BF700780BA1 /* HIOnboardingView.swift */, + E1E4A5D8291C9BF700780BA1 /* HIOnboardingViewModel.swift */, + ); + name = SwiftUI; + path = HackIllinois/SwiftUI; + sourceTree = SOURCE_ROOT; + }; + E1E4A5D5291C9BF700780BA1 /* UI */ = { + isa = PBXGroup; + children = ( + DF5B27C6299372AE0034A8B9 /* Hack_PopcornCart_Text.json */, + E1E4A5D6291C9BF700780BA1 /* HICarouselSwiftUIView.swift */, + ); + path = UI; + sourceTree = ""; + }; EAE6D26341C3ACE27256067A /* Frameworks */ = { isa = PBXGroup; children = ( + DF37065D2925DE66000B4278 /* UIKit.framework */, + DF37065B2925DE5D000B4278 /* SystemConfiguration.framework */, + DF3706592925DE57000B4278 /* QuartzCore.framework */, + DF3706572925DE50000B4278 /* OpenGLES.framework */, + DF3706552925DE4C000B4278 /* Metal.framework */, + DF3706532925DE47000B4278 /* libz.tbd */, + DF3706512925DE42000B4278 /* libc++.tbd */, + DF37064F2925DE38000B4278 /* ImageIO.framework */, + DF37064D2925DE34000B4278 /* GLKit.framework */, + DF37064B2925DE2F000B4278 /* CoreText.framework */, + DF3706492925DE27000B4278 /* CoreTelephony.framework */, + DF3706472925DE22000B4278 /* CoreLocation.framework */, + DF3706452925DE1B000B4278 /* CoreImage.framework */, + DF3706432925DE15000B4278 /* CoreGraphics.framework */, + DF3706412925DE0F000B4278 /* CoreData.framework */, + DF37063F2925DE08000B4278 /* Accelerate.framework */, D3A309BB2211175200CBA351 /* PassKit.framework */, ); name = Frameworks; @@ -703,7 +834,7 @@ 9518277C1EA35AF100049F79 /* Frameworks */, 9518277D1EA35AF100049F79 /* Resources */, 1C4BDBAA2744A032003BB3BB /* ShellScript */, - 35D7CE9F20380ACF00654E28 /* Embed App Extensions */, + 35D7CE9F20380ACF00654E28 /* Embed Foundation Extensions */, 95E3143621FAD5B40092C22E /* Embed Frameworks */, ); buildRules = ( @@ -764,12 +895,11 @@ isa = PBXProject; attributes = { LastSwiftUpdateCheck = 0830; - LastUpgradeCheck = 1010; + LastUpgradeCheck = 1420; ORGANIZATIONNAME = HackIllinois; TargetAttributes = { 9518277E1EA35AF100049F79 = { CreatedOnToolsVersion = 8.3; - DevelopmentTeam = 8VNQTQM2L6; LastSwiftMigration = 1130; ProvisioningStyle = Automatic; SystemCapabilities = { @@ -800,7 +930,6 @@ developmentRegion = en; hasScannedForEncodings = 0; knownRegions = ( - English, en, Base, ); @@ -833,6 +962,9 @@ 952D1542220D453D0041383A /* countdown-60.json in Resources */, 951827B41EA35E8B00049F79 /* LaunchScreen.storyboard in Resources */, 1C7561A5278E96750004D739 /* LightVespaText.json in Resources */, + D134D30F296B3F56006EA589 /* Montserrat-VariableFont_wght.ttf in Resources */, + DF37063E2925DDE7000B4278 /* GoogleMaps.bundle in Resources */, + DF5B27C7299372AE0034A8B9 /* Hack_PopcornCart_Text.json in Resources */, ); runOnlyForDeploymentPostprocessing = 0; }; @@ -902,13 +1034,17 @@ 957D7CAC1FC2940800C4332A /* HackIllinois.xcdatamodeld in Sources */, 3FBFA7AB27335554001FFF28 /* HILeaderboardListViewController.swift in Sources */, 9510F6A71FCB7E53007D19DB /* HIBaseScannerViewController.swift in Sources */, + E1E4A5DA291C9BF800780BA1 /* HIOnboardingView.swift in Sources */, 95A7D290203D4F54005EAEAF /* HIAnnouncementCell.swift in Sources */, 9515E43722093E1300BCAF92 /* HIEventScannerViewController.swift in Sources */, 95A7D28F203D4F54005EAEAF /* HIEventCell.swift in Sources */, ACAA717626017EC4000F42B0 /* HICollectionViewFlowLayout.swift in Sources */, + DF5B27C5299197E80034A8B9 /* Array.swift in Sources */, + E170038A29679D08009B99A8 /* HIProfileCardView.swift in Sources */, 95C3BE302008B99C0008ED79 /* HIBaseViewController.swift in Sources */, BFB1FD3E26105EA400500008 /* HIEditProfileCell.swift in Sources */, 95CD0ED52015217E00D79DCC /* HIApplicationStateController.swift in Sources */, + E1E4A5DB291C9BF800780BA1 /* HIOnboardingViewModel.swift in Sources */, AC0DDDDC261111B60086BDE0 /* HITextView.swift in Sources */, 95A7D292203D4F54005EAEAF /* HILoginSelectionCell.swift in Sources */, 3C26401923ADE7AA004E1DBE /* Project+CoreDataProperties.swift in Sources */, @@ -931,11 +1067,14 @@ 95C18DC52009618C004784B5 /* HIHomeViewController.swift in Sources */, 35240BD1201408DB00E0C0D8 /* HICountdownViewController.swift in Sources */, 3C7E552723AA199900213E1F /* HITimeDataSource.swift in Sources */, + D14D3AE3295FBDA200EB7995 /* HIBannerViewController.swift in Sources */, 9510F6A11FCB7D6E007D19DB /* Event+CoreDataClass.swift in Sources */, + E1E4A5D9291C9BF800780BA1 /* HICarouselSwiftUIView.swift in Sources */, 951827A81EA35DB800049F79 /* AppDelegate.swift in Sources */, AC5E9FE326195CCF00674FCF /* HIEventType.swift in Sources */, AC3B621425E86053002386A2 /* Profile+CoreDataProperties.swift in Sources */, 9564E02F2218CE6F003A8EEB /* HIMapsDataSource.swift in Sources */, + E1BF5E7A298B462F00A98390 /* HIStaffButtonView.swift in Sources */, 953199C91FC25CA0009F2AA1 /* HICoreDataController.swift in Sources */, 95A7D28D203D4F54005EAEAF /* Identifiable.swift in Sources */, 9521A6A820191590009059C6 /* HIEventDataSource.swift in Sources */, @@ -1039,6 +1178,7 @@ CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES; CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; CLANG_WARN_STRICT_PROTOTYPES = YES; CLANG_WARN_SUSPICIOUS_MOVE = YES; @@ -1049,6 +1189,7 @@ DEBUG_INFORMATION_FORMAT = dwarf; ENABLE_STRICT_OBJC_MSGSEND = YES; ENABLE_TESTABILITY = YES; + "EXCLUDED_ARCHS[sdk=*]" = arm64; GCC_C_LANGUAGE_STANDARD = gnu99; GCC_DYNAMIC_NO_PIC = NO; GCC_NO_COMMON_BLOCKS = YES; @@ -1063,9 +1204,10 @@ GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; GCC_WARN_UNUSED_FUNCTION = YES; GCC_WARN_UNUSED_VARIABLE = YES; - IPHONEOS_DEPLOYMENT_TARGET = 11.0; + IPHONEOS_DEPLOYMENT_TARGET = 14.0; MTL_ENABLE_DEBUG_INFO = YES; ONLY_ACTIVE_ARCH = YES; + "OTHER_LDFLAGS[arch=*]" = "-ObjC"; SDKROOT = iphoneos; SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG; SWIFT_OPTIMIZATION_LEVEL = "-Onone"; @@ -1098,6 +1240,7 @@ CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES; CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; CLANG_WARN_STRICT_PROTOTYPES = YES; CLANG_WARN_SUSPICIOUS_MOVE = YES; @@ -1108,6 +1251,7 @@ DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; ENABLE_NS_ASSERTIONS = NO; ENABLE_STRICT_OBJC_MSGSEND = YES; + "EXCLUDED_ARCHS[sdk=*]" = arm64; GCC_C_LANGUAGE_STANDARD = gnu99; GCC_NO_COMMON_BLOCKS = YES; GCC_WARN_64_TO_32_BIT_CONVERSION = YES; @@ -1116,8 +1260,9 @@ GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; GCC_WARN_UNUSED_FUNCTION = YES; GCC_WARN_UNUSED_VARIABLE = YES; - IPHONEOS_DEPLOYMENT_TARGET = 11.0; + IPHONEOS_DEPLOYMENT_TARGET = 14.0; MTL_ENABLE_DEBUG_INFO = NO; + "OTHER_LDFLAGS[arch=*]" = "-ObjC"; SDKROOT = iphoneos; SWIFT_COMPILATION_MODE = wholemodule; SWIFT_OPTIMIZATION_LEVEL = "-O"; @@ -1134,8 +1279,13 @@ CODE_SIGN_ENTITLEMENTS = HackIllinois/HackIllinois.entitlements; CODE_SIGN_IDENTITY = "iPhone Developer"; CURRENT_PROJECT_VERSION = 1; - DEVELOPMENT_TEAM = 8VNQTQM2L6; + DEVELOPMENT_TEAM = 88CYB22L6D; + FRAMEWORK_SEARCH_PATHS = ( + "$(inherited)", + "$(PROJECT_DIR)/HackIllinois", + ); INFOPLIST_FILE = HackIllinois/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 14.0; LD_RUNPATH_SEARCH_PATHS = ( "$(inherited)", "@executable_path/Frameworks", @@ -1157,8 +1307,13 @@ CODE_SIGN_ENTITLEMENTS = HackIllinois/HackIllinois.entitlements; CODE_SIGN_IDENTITY = "iPhone Developer"; CURRENT_PROJECT_VERSION = 1; - DEVELOPMENT_TEAM = 8VNQTQM2L6; + DEVELOPMENT_TEAM = 88CYB22L6D; + FRAMEWORK_SEARCH_PATHS = ( + "$(inherited)", + "$(PROJECT_DIR)/HackIllinois", + ); INFOPLIST_FILE = HackIllinois/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 14.0; LD_RUNPATH_SEARCH_PATHS = ( "$(inherited)", "@executable_path/Frameworks", @@ -1259,8 +1414,8 @@ DEVELOPMENT_TEAM = 8VNQTQM2L6; GCC_C_LANGUAGE_STANDARD = gnu11; INFOPLIST_FILE = Stickers/Info.plist; - IPHONEOS_DEPLOYMENT_TARGET = 11.0; - MARKETING_VERSION = 2021.1.2; + IPHONEOS_DEPLOYMENT_TARGET = 12.0; + MARKETING_VERSION = 2022.1.2; MTL_ENABLE_DEBUG_INFO = INCLUDE_SOURCE; MTL_FAST_MATH = YES; PRODUCT_BUNDLE_IDENTIFIER = org.hackillinois.ios.Stickers; @@ -1284,8 +1439,8 @@ DEVELOPMENT_TEAM = 8VNQTQM2L6; GCC_C_LANGUAGE_STANDARD = gnu11; INFOPLIST_FILE = Stickers/Info.plist; - IPHONEOS_DEPLOYMENT_TARGET = 11.0; - MARKETING_VERSION = 2021.1.2; + IPHONEOS_DEPLOYMENT_TARGET = 12.0; + MARKETING_VERSION = 2022.1.2; MTL_FAST_MATH = YES; PRODUCT_BUNDLE_IDENTIFIER = org.hackillinois.ios.Stickers; PRODUCT_NAME = "$(TARGET_NAME)"; @@ -1357,7 +1512,7 @@ repositoryURL = "https://github.com/airbnb/lottie-ios.git"; requirement = { kind = exactVersion; - version = 3.1.5; + version = 4.0.1; }; }; /* End XCRemoteSwiftPackageReference section */ diff --git a/HackIllinois.xcodeproj/xcshareddata/xcschemes/HackIllinois.xcscheme b/HackIllinois.xcodeproj/xcshareddata/xcschemes/HackIllinois.xcscheme new file mode 100644 index 00000000..c8dab23a --- /dev/null +++ b/HackIllinois.xcodeproj/xcshareddata/xcschemes/HackIllinois.xcscheme @@ -0,0 +1,78 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/HackIllinois.xcworkspace/xcshareddata/swiftpm/Package.resolved b/HackIllinois.xcworkspace/xcshareddata/swiftpm/Package.resolved new file mode 100644 index 00000000..8cc703d6 --- /dev/null +++ b/HackIllinois.xcworkspace/xcshareddata/swiftpm/Package.resolved @@ -0,0 +1,32 @@ +{ + "pins" : [ + { + "identity" : "api-manager", + "kind" : "remoteSourceControl", + "location" : "https://github.com/rauhul/api-manager.git", + "state" : { + "revision" : "c8b6b426a4172cf1cd4568601cf36b6437d65ae8", + "version" : "0.4.0" + } + }, + { + "identity" : "keychain", + "kind" : "remoteSourceControl", + "location" : "https://github.com/rauhul/keychain.git", + "state" : { + "revision" : "5c8ad6af202395cdafaa7968af473da8bfe5c35f", + "version" : "0.2.0" + } + }, + { + "identity" : "lottie-ios", + "kind" : "remoteSourceControl", + "location" : "https://github.com/airbnb/lottie-ios.git", + "state" : { + "revision" : "eb115967234671b725264422d82c9d1d6b226e5a", + "version" : "3.1.5" + } + } + ], + "version" : 2 +} diff --git a/HackIllinois/AppDelegate.swift b/HackIllinois/AppDelegate.swift index 83bd9322..651df825 100644 --- a/HackIllinois/AppDelegate.swift +++ b/HackIllinois/AppDelegate.swift @@ -14,10 +14,15 @@ import UIKit import CoreLocation import UserNotifications import HIAPI +import GoogleMaps @UIApplicationMain class AppDelegate: UIResponder, UIApplicationDelegate { + private var obfuscatedApiKey: [UInt8] = [92, 213, 228, 193, 244, 27, 239, 139, 188, 14, 85, 191, 47, 237, 55, 13, 85, 89, 111, 212, 35, 80, 45, 104, 189, 229, + 33, 32, 70, 63, 90, 163, 173, 232, 167, 90, 203, 22, 169, 29, 156, 158, 160, 167, 98, + 174, 239, 247, 118, 96, 207, 104, 180, 14, 90, 58, 61, 89, 186, 89, 7, 114, 25, 255, 141, + 115, 113, 117, 78, 10, 150, 197, 161, 158, 98, 129, 87, 228] // Handle remote notification registration. func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) { @@ -26,15 +31,15 @@ class AppDelegate: UIResponder, UIApplicationDelegate { // Send the token to notifications server AnnouncementService.sendToken(deviceToken: token) - .onCompletion { result in - do { - _ = try result.get() - } catch { - print(error) + .onCompletion { result in + do { + _ = try result.get() + } catch { + print(error) + } } - } - .authorize(with: user) - .launch() + .authorize(with: user) + .launch() } func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool { @@ -43,6 +48,7 @@ class AppDelegate: UIResponder, UIApplicationDelegate { _ = HIThemeEngine.shared _ = HICoreDataController.shared _ = HILocalNotificationController.shared + GMSServices.provideAPIKey(String(bytes: obfuscatedApiKey.deobfuscated, encoding: .utf8)!) HIApplicationStateController.shared.initalize() return true } diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/100.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/100.png deleted file mode 100644 index e51e39a8..00000000 Binary files a/HackIllinois/Assets.xcassets/AppIcon.appiconset/100.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/1024.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/1024.png deleted file mode 100644 index e7b0aab3..00000000 Binary files a/HackIllinois/Assets.xcassets/AppIcon.appiconset/1024.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/114.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/114.png deleted file mode 100644 index 0b29d822..00000000 Binary files a/HackIllinois/Assets.xcassets/AppIcon.appiconset/114.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/120.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/120.png deleted file mode 100644 index 80bb0e4f..00000000 Binary files a/HackIllinois/Assets.xcassets/AppIcon.appiconset/120.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/144.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/144.png deleted file mode 100644 index ceb26450..00000000 Binary files a/HackIllinois/Assets.xcassets/AppIcon.appiconset/144.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/152.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/152.png deleted file mode 100644 index b5c021a2..00000000 Binary files a/HackIllinois/Assets.xcassets/AppIcon.appiconset/152.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/167.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/167.png deleted file mode 100644 index cb100117..00000000 Binary files a/HackIllinois/Assets.xcassets/AppIcon.appiconset/167.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/180.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/180.png deleted file mode 100644 index 0290b35f..00000000 Binary files a/HackIllinois/Assets.xcassets/AppIcon.appiconset/180.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/20.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/20.png deleted file mode 100644 index f2c65921..00000000 Binary files a/HackIllinois/Assets.xcassets/AppIcon.appiconset/20.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/29 1.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/29 1.png new file mode 100644 index 00000000..1cdae295 Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/29 1.png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/29.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/29.png index c4e7b727..1cdae295 100644 Binary files a/HackIllinois/Assets.xcassets/AppIcon.appiconset/29.png and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/29.png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/40.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/40.png deleted file mode 100644 index 1ef29bd0..00000000 Binary files a/HackIllinois/Assets.xcassets/AppIcon.appiconset/40.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/50.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/50.png deleted file mode 100644 index 61d328e8..00000000 Binary files a/HackIllinois/Assets.xcassets/AppIcon.appiconset/50.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/57.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/57.png deleted file mode 100644 index 94d5d68a..00000000 Binary files a/HackIllinois/Assets.xcassets/AppIcon.appiconset/57.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/58.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/58.png deleted file mode 100644 index 60ea7c12..00000000 Binary files a/HackIllinois/Assets.xcassets/AppIcon.appiconset/58.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/60.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/60.png deleted file mode 100644 index 93eddc14..00000000 Binary files a/HackIllinois/Assets.xcassets/AppIcon.appiconset/60.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/72.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/72.png deleted file mode 100644 index 2631868c..00000000 Binary files a/HackIllinois/Assets.xcassets/AppIcon.appiconset/72.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/76.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/76.png deleted file mode 100644 index 95f703ed..00000000 Binary files a/HackIllinois/Assets.xcassets/AppIcon.appiconset/76.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/80.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/80.png deleted file mode 100644 index 062d7809..00000000 Binary files a/HackIllinois/Assets.xcassets/AppIcon.appiconset/80.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/87.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/87.png deleted file mode 100644 index 10f66397..00000000 Binary files a/HackIllinois/Assets.xcassets/AppIcon.appiconset/87.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/App Store iOS (1).png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/App Store iOS (1).png new file mode 100644 index 00000000..4934e06b Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/App Store iOS (1).png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/Contents.json b/HackIllinois/Assets.xcassets/AppIcon.appiconset/Contents.json index 65b74d7e..789d7ffb 100644 --- a/HackIllinois/Assets.xcassets/AppIcon.appiconset/Contents.json +++ b/HackIllinois/Assets.xcassets/AppIcon.appiconset/Contents.json @@ -1 +1,158 @@ -{"images":[{"size":"60x60","expected-size":"180","filename":"180.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"3x"},{"size":"40x40","expected-size":"80","filename":"80.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"2x"},{"size":"40x40","expected-size":"120","filename":"120.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"3x"},{"size":"60x60","expected-size":"120","filename":"120.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"2x"},{"size":"57x57","expected-size":"57","filename":"57.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"1x"},{"size":"29x29","expected-size":"58","filename":"58.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"2x"},{"size":"29x29","expected-size":"29","filename":"29.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"1x"},{"size":"29x29","expected-size":"87","filename":"87.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"3x"},{"size":"57x57","expected-size":"114","filename":"114.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"2x"},{"size":"20x20","expected-size":"40","filename":"40.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"2x"},{"size":"20x20","expected-size":"60","filename":"60.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"iphone","scale":"3x"},{"size":"1024x1024","filename":"1024.png","expected-size":"1024","idiom":"ios-marketing","folder":"Assets.xcassets/AppIcon.appiconset/","scale":"1x"},{"size":"40x40","expected-size":"80","filename":"80.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"ipad","scale":"2x"},{"size":"72x72","expected-size":"72","filename":"72.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"ipad","scale":"1x"},{"size":"76x76","expected-size":"152","filename":"152.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"ipad","scale":"2x"},{"size":"50x50","expected-size":"100","filename":"100.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"ipad","scale":"2x"},{"size":"29x29","expected-size":"58","filename":"58.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"ipad","scale":"2x"},{"size":"76x76","expected-size":"76","filename":"76.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"ipad","scale":"1x"},{"size":"29x29","expected-size":"29","filename":"29.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"ipad","scale":"1x"},{"size":"50x50","expected-size":"50","filename":"50.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"ipad","scale":"1x"},{"size":"72x72","expected-size":"144","filename":"144.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"ipad","scale":"2x"},{"size":"40x40","expected-size":"40","filename":"40.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"ipad","scale":"1x"},{"size":"83.5x83.5","expected-size":"167","filename":"167.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"ipad","scale":"2x"},{"size":"20x20","expected-size":"20","filename":"20.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"ipad","scale":"1x"},{"size":"20x20","expected-size":"40","filename":"40.png","folder":"Assets.xcassets/AppIcon.appiconset/","idiom":"ipad","scale":"2x"}]} \ No newline at end of file +{ + "images" : [ + { + "filename" : "iPad Spotlight 40pt @1x 1.png", + "idiom" : "iphone", + "scale" : "2x", + "size" : "20x20" + }, + { + "filename" : "iPhone Notifications 20pt @3x.png", + "idiom" : "iphone", + "scale" : "3x", + "size" : "20x20" + }, + { + "filename" : "29.png", + "idiom" : "iphone", + "scale" : "1x", + "size" : "29x29" + }, + { + "filename" : "iPhone Settings 29x29pt @2x (2).png", + "idiom" : "iphone", + "scale" : "2x", + "size" : "29x29" + }, + { + "filename" : "iPhone Settings 29x29pt @ 3x (1).png", + "idiom" : "iphone", + "scale" : "3x", + "size" : "29x29" + }, + { + "filename" : "iPhone Spotlight 40pt @ 2x.png", + "idiom" : "iphone", + "scale" : "2x", + "size" : "40x40" + }, + { + "filename" : "iPhone Spotlight 40pt @ 3x.png", + "idiom" : "iphone", + "scale" : "3x", + "size" : "40x40" + }, + { + "filename" : "iPhone App iOS 5,6 57pt @ 1x.png", + "idiom" : "iphone", + "scale" : "1x", + "size" : "57x57" + }, + { + "filename" : "iPhone App iOS 5,6 57pt @ 2x.png", + "idiom" : "iphone", + "scale" : "2x", + "size" : "57x57" + }, + { + "filename" : "iPhone App 60pt @ 2x.png", + "idiom" : "iphone", + "scale" : "2x", + "size" : "60x60" + }, + { + "filename" : "iPhone App 60pt @ 3x.png", + "idiom" : "iphone", + "scale" : "3x", + "size" : "60x60" + }, + { + "filename" : "iPad Notifications 20pt @1x.png", + "idiom" : "ipad", + "scale" : "1x", + "size" : "20x20" + }, + { + "filename" : "iPad Notifications 20pt @2x.png", + "idiom" : "ipad", + "scale" : "2x", + "size" : "20x20" + }, + { + "filename" : "29 1.png", + "idiom" : "ipad", + "scale" : "1x", + "size" : "29x29" + }, + { + "filename" : "iPad Settings 29pt @2x.png", + "idiom" : "ipad", + "scale" : "2x", + "size" : "29x29" + }, + { + "filename" : "iPad Spotlight 40pt @1x.png", + "idiom" : "ipad", + "scale" : "1x", + "size" : "40x40" + }, + { + "filename" : "iPad Spotlight 40pt @2x.png", + "idiom" : "ipad", + "scale" : "2x", + "size" : "40x40" + }, + { + "filename" : "iPad Spotlight iOS 5,6 50pt @1x.png", + "idiom" : "ipad", + "scale" : "1x", + "size" : "50x50" + }, + { + "filename" : "iPad Spotlight iOS 5,6 50pt @2x.png", + "idiom" : "ipad", + "scale" : "2x", + "size" : "50x50" + }, + { + "filename" : "iPad App iOS 5,6 72pt @ 1x.png", + "idiom" : "ipad", + "scale" : "1x", + "size" : "72x72" + }, + { + "filename" : "iPad App iOS 5,6 72pt @ 2x.png", + "idiom" : "ipad", + "scale" : "2x", + "size" : "72x72" + }, + { + "filename" : "iPad App 76pt @ 1x.png", + "idiom" : "ipad", + "scale" : "1x", + "size" : "76x76" + }, + { + "filename" : "iPad App 76pt @ 2x.png", + "idiom" : "ipad", + "scale" : "2x", + "size" : "76x76" + }, + { + "filename" : "iPad Pro (12.9in) App 83.5pt @ 2x (1).png", + "idiom" : "ipad", + "scale" : "2x", + "size" : "83.5x83.5" + }, + { + "filename" : "App Store iOS (1).png", + "idiom" : "ios-marketing", + "scale" : "1x", + "size" : "1024x1024" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad App 76pt @ 1x.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad App 76pt @ 1x.png new file mode 100644 index 00000000..4b5f7691 Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad App 76pt @ 1x.png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad App 76pt @ 2x.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad App 76pt @ 2x.png new file mode 100644 index 00000000..0009b08f Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad App 76pt @ 2x.png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad App iOS 5,6 72pt @ 1x.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad App iOS 5,6 72pt @ 1x.png new file mode 100644 index 00000000..8dc775e2 Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad App iOS 5,6 72pt @ 1x.png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad App iOS 5,6 72pt @ 2x.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad App iOS 5,6 72pt @ 2x.png new file mode 100644 index 00000000..2e395592 Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad App iOS 5,6 72pt @ 2x.png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Notifications 20pt @1x.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Notifications 20pt @1x.png new file mode 100644 index 00000000..d8502e07 Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Notifications 20pt @1x.png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Notifications 20pt @2x.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Notifications 20pt @2x.png new file mode 100644 index 00000000..8fd96d4a Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Notifications 20pt @2x.png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Pro (12.9in) App 83.5pt @ 2x (1).png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Pro (12.9in) App 83.5pt @ 2x (1).png new file mode 100644 index 00000000..d821b817 Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Pro (12.9in) App 83.5pt @ 2x (1).png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Settings 29pt @2x.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Settings 29pt @2x.png new file mode 100644 index 00000000..7a507c79 Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Settings 29pt @2x.png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt @1x 1.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt @1x 1.png new file mode 100644 index 00000000..8fd96d4a Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt @1x 1.png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt @1x.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt @1x.png new file mode 100644 index 00000000..8fd96d4a Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt @1x.png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt @2x.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt @2x.png new file mode 100644 index 00000000..e208d086 Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt @2x.png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Spotlight iOS 5,6 50pt @1x.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Spotlight iOS 5,6 50pt @1x.png new file mode 100644 index 00000000..c66af767 Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Spotlight iOS 5,6 50pt @1x.png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Spotlight iOS 5,6 50pt @2x.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Spotlight iOS 5,6 50pt @2x.png new file mode 100644 index 00000000..bb8c9a74 Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPad Spotlight iOS 5,6 50pt @2x.png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone App 60pt @ 2x.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone App 60pt @ 2x.png new file mode 100644 index 00000000..0257c2bc Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone App 60pt @ 2x.png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone App 60pt @ 3x.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone App 60pt @ 3x.png new file mode 100644 index 00000000..fa29b218 Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone App 60pt @ 3x.png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone App iOS 5,6 57pt @ 1x.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone App iOS 5,6 57pt @ 1x.png new file mode 100644 index 00000000..4c180610 Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone App iOS 5,6 57pt @ 1x.png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone App iOS 5,6 57pt @ 2x.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone App iOS 5,6 57pt @ 2x.png new file mode 100644 index 00000000..83e3ee8f Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone App iOS 5,6 57pt @ 2x.png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone Notifications 20pt @3x.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone Notifications 20pt @3x.png new file mode 100644 index 00000000..05a13659 Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone Notifications 20pt @3x.png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone Settings 29x29pt @ 3x (1).png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone Settings 29x29pt @ 3x (1).png new file mode 100644 index 00000000..f316c48e Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone Settings 29x29pt @ 3x (1).png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone Settings 29x29pt @2x (2).png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone Settings 29x29pt @2x (2).png new file mode 100644 index 00000000..5d501448 Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone Settings 29x29pt @2x (2).png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone Spotlight 40pt @ 2x.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone Spotlight 40pt @ 2x.png new file mode 100644 index 00000000..dd5e0f89 Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone Spotlight 40pt @ 2x.png differ diff --git a/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone Spotlight 40pt @ 3x.png b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone Spotlight 40pt @ 3x.png new file mode 100644 index 00000000..217990a9 Binary files /dev/null and b/HackIllinois/Assets.xcassets/AppIcon.appiconset/iPhone Spotlight 40pt @ 3x.png differ diff --git a/HackIllinois/Assets.xcassets/BackgroundPad.imageset/BackgroundPad@1x.png b/HackIllinois/Assets.xcassets/BackgroundPad.imageset/BackgroundPad@1x.png new file mode 100644 index 00000000..5d4887ee Binary files /dev/null and b/HackIllinois/Assets.xcassets/BackgroundPad.imageset/BackgroundPad@1x.png differ diff --git a/HackIllinois/Assets.xcassets/BackgroundPad.imageset/BackgroundPad@2x.png b/HackIllinois/Assets.xcassets/BackgroundPad.imageset/BackgroundPad@2x.png new file mode 100644 index 00000000..125c2159 Binary files /dev/null and b/HackIllinois/Assets.xcassets/BackgroundPad.imageset/BackgroundPad@2x.png differ diff --git a/HackIllinois/Assets.xcassets/BackgroundPad.imageset/BackgroundPad@3x.png b/HackIllinois/Assets.xcassets/BackgroundPad.imageset/BackgroundPad@3x.png new file mode 100644 index 00000000..820dc952 Binary files /dev/null and b/HackIllinois/Assets.xcassets/BackgroundPad.imageset/BackgroundPad@3x.png differ diff --git a/HackIllinois/Assets.xcassets/LogoutButton.imageset/Contents.json b/HackIllinois/Assets.xcassets/BackgroundPad.imageset/Contents.json similarity index 58% rename from HackIllinois/Assets.xcassets/LogoutButton.imageset/Contents.json rename to HackIllinois/Assets.xcassets/BackgroundPad.imageset/Contents.json index 3ded546d..14ae2f79 100644 --- a/HackIllinois/Assets.xcassets/LogoutButton.imageset/Contents.json +++ b/HackIllinois/Assets.xcassets/BackgroundPad.imageset/Contents.json @@ -1,17 +1,17 @@ { "images" : [ { - "filename" : "LogoutButton@1x.png", + "filename" : "BackgroundPad@1x.png", "idiom" : "universal", "scale" : "1x" }, { - "filename" : "LogoutButton@2x.png", + "filename" : "BackgroundPad@2x.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "LogoutButton@3x.png", + "filename" : "BackgroundPad@3x.png", "idiom" : "universal", "scale" : "3x" } @@ -19,8 +19,5 @@ "info" : { "author" : "xcode", "version" : 1 - }, - "properties" : { - "template-rendering-intent" : "template" } } diff --git a/HackIllinois/Assets.xcassets/Banner.imageset/Banner@1x.png b/HackIllinois/Assets.xcassets/Banner.imageset/Banner@1x.png new file mode 100644 index 00000000..6853d55d Binary files /dev/null and b/HackIllinois/Assets.xcassets/Banner.imageset/Banner@1x.png differ diff --git a/HackIllinois/Assets.xcassets/Banner.imageset/Banner@2x.png b/HackIllinois/Assets.xcassets/Banner.imageset/Banner@2x.png new file mode 100644 index 00000000..89f58b66 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Banner.imageset/Banner@2x.png differ diff --git a/HackIllinois/Assets.xcassets/Banner.imageset/Banner@3x.png b/HackIllinois/Assets.xcassets/Banner.imageset/Banner@3x.png new file mode 100644 index 00000000..3679fba9 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Banner.imageset/Banner@3x.png differ diff --git a/HackIllinois/Assets.xcassets/Banner.imageset/Contents.json b/HackIllinois/Assets.xcassets/Banner.imageset/Contents.json new file mode 100644 index 00000000..da3a0c30 --- /dev/null +++ b/HackIllinois/Assets.xcassets/Banner.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "filename" : "Banner@1x.png", + "idiom" : "universal", + "scale" : "1x" + }, + { + "filename" : "Banner@2x.png", + "idiom" : "universal", + "scale" : "2x" + }, + { + "filename" : "Banner@3x.png", + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/HackIllinois/Assets.xcassets/BannerPad.imageset/BannerPad@1x.png b/HackIllinois/Assets.xcassets/BannerPad.imageset/BannerPad@1x.png new file mode 100644 index 00000000..5e64b713 Binary files /dev/null and b/HackIllinois/Assets.xcassets/BannerPad.imageset/BannerPad@1x.png differ diff --git a/HackIllinois/Assets.xcassets/BannerPad.imageset/BannerPad@2x.png b/HackIllinois/Assets.xcassets/BannerPad.imageset/BannerPad@2x.png new file mode 100644 index 00000000..9c96b194 Binary files /dev/null and b/HackIllinois/Assets.xcassets/BannerPad.imageset/BannerPad@2x.png differ diff --git a/HackIllinois/Assets.xcassets/BannerPad.imageset/BannerPad@3x.png b/HackIllinois/Assets.xcassets/BannerPad.imageset/BannerPad@3x.png new file mode 100644 index 00000000..f82b242c Binary files /dev/null and b/HackIllinois/Assets.xcassets/BannerPad.imageset/BannerPad@3x.png differ diff --git a/HackIllinois/Assets.xcassets/BannerPad.imageset/Contents.json b/HackIllinois/Assets.xcassets/BannerPad.imageset/Contents.json new file mode 100644 index 00000000..612cdf61 --- /dev/null +++ b/HackIllinois/Assets.xcassets/BannerPad.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "filename" : "BannerPad@1x.png", + "idiom" : "universal", + "scale" : "1x" + }, + { + "filename" : "BannerPad@2x.png", + "idiom" : "universal", + "scale" : "2x" + }, + { + "filename" : "BannerPad@3x.png", + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/HackIllinois/Assets.xcassets/FavoritedPad.imageset/Contents.json b/HackIllinois/Assets.xcassets/FavoritedPad.imageset/Contents.json new file mode 100644 index 00000000..722f1684 --- /dev/null +++ b/HackIllinois/Assets.xcassets/FavoritedPad.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "filename" : "FavoritedPad@1x.png", + "idiom" : "universal", + "scale" : "1x" + }, + { + "filename" : "FavoritedPad@2x.png", + "idiom" : "universal", + "scale" : "2x" + }, + { + "filename" : "FavoritedPad@3x.png", + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/HackIllinois/Assets.xcassets/FavoritedPad.imageset/FavoritedPad@1x.png b/HackIllinois/Assets.xcassets/FavoritedPad.imageset/FavoritedPad@1x.png new file mode 100644 index 00000000..11fd1158 Binary files /dev/null and b/HackIllinois/Assets.xcassets/FavoritedPad.imageset/FavoritedPad@1x.png differ diff --git a/HackIllinois/Assets.xcassets/FavoritedPad.imageset/FavoritedPad@2x.png b/HackIllinois/Assets.xcassets/FavoritedPad.imageset/FavoritedPad@2x.png new file mode 100644 index 00000000..202e04b7 Binary files /dev/null and b/HackIllinois/Assets.xcassets/FavoritedPad.imageset/FavoritedPad@2x.png differ diff --git a/HackIllinois/Assets.xcassets/FavoritedPad.imageset/FavoritedPad@3x.png b/HackIllinois/Assets.xcassets/FavoritedPad.imageset/FavoritedPad@3x.png new file mode 100644 index 00000000..879cabae Binary files /dev/null and b/HackIllinois/Assets.xcassets/FavoritedPad.imageset/FavoritedPad@3x.png differ diff --git a/HackIllinois/Assets.xcassets/HILogo.imageset/Contents.json b/HackIllinois/Assets.xcassets/HILogo.imageset/Contents.json index 2e2b34a8..7b03edf6 100644 --- a/HackIllinois/Assets.xcassets/HILogo.imageset/Contents.json +++ b/HackIllinois/Assets.xcassets/HILogo.imageset/Contents.json @@ -1,17 +1,17 @@ { "images" : [ { - "filename" : "HILogo@1x.png", + "filename" : "Group 201.png", "idiom" : "universal", "scale" : "1x" }, { - "filename" : "HILogo@2x.png", + "filename" : "Group 201@2x.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "HILogo@3x.png", + "filename" : "Group 201@3x.png", "idiom" : "universal", "scale" : "3x" } diff --git a/HackIllinois/Assets.xcassets/HILogo.imageset/Group 201.png b/HackIllinois/Assets.xcassets/HILogo.imageset/Group 201.png new file mode 100644 index 00000000..797a0771 Binary files /dev/null and b/HackIllinois/Assets.xcassets/HILogo.imageset/Group 201.png differ diff --git a/HackIllinois/Assets.xcassets/HILogo.imageset/Group 201@2x.png b/HackIllinois/Assets.xcassets/HILogo.imageset/Group 201@2x.png new file mode 100644 index 00000000..7bf7c78a Binary files /dev/null and b/HackIllinois/Assets.xcassets/HILogo.imageset/Group 201@2x.png differ diff --git a/HackIllinois/Assets.xcassets/HILogo.imageset/Group 201@3x.png b/HackIllinois/Assets.xcassets/HILogo.imageset/Group 201@3x.png new file mode 100644 index 00000000..8ace0e8f Binary files /dev/null and b/HackIllinois/Assets.xcassets/HILogo.imageset/Group 201@3x.png differ diff --git a/HackIllinois/Assets.xcassets/HILogo.imageset/HILogo@1x.png b/HackIllinois/Assets.xcassets/HILogo.imageset/HILogo@1x.png deleted file mode 100644 index d70d06be..00000000 Binary files a/HackIllinois/Assets.xcassets/HILogo.imageset/HILogo@1x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/HILogo.imageset/HILogo@2x.png b/HackIllinois/Assets.xcassets/HILogo.imageset/HILogo@2x.png deleted file mode 100644 index a69ff39c..00000000 Binary files a/HackIllinois/Assets.xcassets/HILogo.imageset/HILogo@2x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/HILogo.imageset/HILogo@3x.png b/HackIllinois/Assets.xcassets/HILogo.imageset/HILogo@3x.png deleted file mode 100644 index 89949d1b..00000000 Binary files a/HackIllinois/Assets.xcassets/HILogo.imageset/HILogo@3x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/HomeBackground.imageset/Background (1).png b/HackIllinois/Assets.xcassets/HomeBackground.imageset/Background (1).png new file mode 100644 index 00000000..235fea61 Binary files /dev/null and b/HackIllinois/Assets.xcassets/HomeBackground.imageset/Background (1).png differ diff --git a/HackIllinois/Assets.xcassets/HomeBackground.imageset/Background (2).png b/HackIllinois/Assets.xcassets/HomeBackground.imageset/Background (2).png new file mode 100644 index 00000000..cd7217f6 Binary files /dev/null and b/HackIllinois/Assets.xcassets/HomeBackground.imageset/Background (2).png differ diff --git a/HackIllinois/Assets.xcassets/HomeBackground.imageset/Background.png b/HackIllinois/Assets.xcassets/HomeBackground.imageset/Background.png new file mode 100644 index 00000000..4bedf4f0 Binary files /dev/null and b/HackIllinois/Assets.xcassets/HomeBackground.imageset/Background.png differ diff --git a/HackIllinois/Assets.xcassets/HomeBackground.imageset/Contents.json b/HackIllinois/Assets.xcassets/HomeBackground.imageset/Contents.json new file mode 100644 index 00000000..06503aac --- /dev/null +++ b/HackIllinois/Assets.xcassets/HomeBackground.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "filename" : "Background.png", + "idiom" : "universal", + "scale" : "1x" + }, + { + "filename" : "Background (1).png", + "idiom" : "universal", + "scale" : "2x" + }, + { + "filename" : "Background (2).png", + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/HackIllinois/Assets.xcassets/Indicator.imageset/Contents.json b/HackIllinois/Assets.xcassets/Indicator.imageset/Contents.json index 738962a4..25c06774 100644 --- a/HackIllinois/Assets.xcassets/Indicator.imageset/Contents.json +++ b/HackIllinois/Assets.xcassets/Indicator.imageset/Contents.json @@ -1,17 +1,17 @@ { "images" : [ { - "filename" : "Indicator@1x.png", + "filename" : "Date underline.png", "idiom" : "universal", "scale" : "1x" }, { - "filename" : "Indicator@2x.png", + "filename" : "Date underline (1).png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "Indicator@3x.png", + "filename" : "Date underline (2).png", "idiom" : "universal", "scale" : "3x" } diff --git a/HackIllinois/Assets.xcassets/Indicator.imageset/Date underline (1).png b/HackIllinois/Assets.xcassets/Indicator.imageset/Date underline (1).png new file mode 100644 index 00000000..1f7b40fe Binary files /dev/null and b/HackIllinois/Assets.xcassets/Indicator.imageset/Date underline (1).png differ diff --git a/HackIllinois/Assets.xcassets/Indicator.imageset/Date underline (2).png b/HackIllinois/Assets.xcassets/Indicator.imageset/Date underline (2).png new file mode 100644 index 00000000..23420def Binary files /dev/null and b/HackIllinois/Assets.xcassets/Indicator.imageset/Date underline (2).png differ diff --git a/HackIllinois/Assets.xcassets/Indicator.imageset/Date underline.png b/HackIllinois/Assets.xcassets/Indicator.imageset/Date underline.png new file mode 100644 index 00000000..6e782acd Binary files /dev/null and b/HackIllinois/Assets.xcassets/Indicator.imageset/Date underline.png differ diff --git a/HackIllinois/Assets.xcassets/Indicator.imageset/Indicator@1x.png b/HackIllinois/Assets.xcassets/Indicator.imageset/Indicator@1x.png deleted file mode 100644 index d38e5598..00000000 Binary files a/HackIllinois/Assets.xcassets/Indicator.imageset/Indicator@1x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Indicator.imageset/Indicator@2x.png b/HackIllinois/Assets.xcassets/Indicator.imageset/Indicator@2x.png deleted file mode 100644 index 34056181..00000000 Binary files a/HackIllinois/Assets.xcassets/Indicator.imageset/Indicator@2x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Indicator.imageset/Indicator@3x.png b/HackIllinois/Assets.xcassets/Indicator.imageset/Indicator@3x.png deleted file mode 100644 index 1a9d9af6..00000000 Binary files a/HackIllinois/Assets.xcassets/Indicator.imageset/Indicator@3x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/IndicatorPad.imageset/Contents.json b/HackIllinois/Assets.xcassets/IndicatorPad.imageset/Contents.json new file mode 100644 index 00000000..50e0cf54 --- /dev/null +++ b/HackIllinois/Assets.xcassets/IndicatorPad.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "filename" : "IndicatorPad@1x.png", + "idiom" : "universal", + "scale" : "1x" + }, + { + "filename" : "IndicatorPad@2x.png", + "idiom" : "universal", + "scale" : "2x" + }, + { + "filename" : "IndicatorPad@3x.png", + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/HackIllinois/Assets.xcassets/IndicatorPad.imageset/IndicatorPad@1x.png b/HackIllinois/Assets.xcassets/IndicatorPad.imageset/IndicatorPad@1x.png new file mode 100644 index 00000000..148ec601 Binary files /dev/null and b/HackIllinois/Assets.xcassets/IndicatorPad.imageset/IndicatorPad@1x.png differ diff --git a/HackIllinois/Assets.xcassets/IndicatorPad.imageset/IndicatorPad@2x.png b/HackIllinois/Assets.xcassets/IndicatorPad.imageset/IndicatorPad@2x.png new file mode 100644 index 00000000..52bae19a Binary files /dev/null and b/HackIllinois/Assets.xcassets/IndicatorPad.imageset/IndicatorPad@2x.png differ diff --git a/HackIllinois/Assets.xcassets/IndicatorPad.imageset/IndicatorPad@3x.png b/HackIllinois/Assets.xcassets/IndicatorPad.imageset/IndicatorPad@3x.png new file mode 100644 index 00000000..2feaf62d Binary files /dev/null and b/HackIllinois/Assets.xcassets/IndicatorPad.imageset/IndicatorPad@3x.png differ diff --git a/HackIllinois/Assets.xcassets/LocationSign.imageset/Contents.json b/HackIllinois/Assets.xcassets/LocationSign.imageset/Contents.json new file mode 100644 index 00000000..778cdcdd --- /dev/null +++ b/HackIllinois/Assets.xcassets/LocationSign.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "filename" : "LocationSign@1x.png", + "idiom" : "universal", + "scale" : "1x" + }, + { + "filename" : "LocationSign@2x.png", + "idiom" : "universal", + "scale" : "2x" + }, + { + "filename" : "LocationSign@3x.png", + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/HackIllinois/Assets.xcassets/LocationSign.imageset/LocationSign@1x.png b/HackIllinois/Assets.xcassets/LocationSign.imageset/LocationSign@1x.png new file mode 100644 index 00000000..71fc194c Binary files /dev/null and b/HackIllinois/Assets.xcassets/LocationSign.imageset/LocationSign@1x.png differ diff --git a/HackIllinois/Assets.xcassets/LocationSign.imageset/LocationSign@2x.png b/HackIllinois/Assets.xcassets/LocationSign.imageset/LocationSign@2x.png new file mode 100644 index 00000000..f124a77f Binary files /dev/null and b/HackIllinois/Assets.xcassets/LocationSign.imageset/LocationSign@2x.png differ diff --git a/HackIllinois/Assets.xcassets/LocationSign.imageset/LocationSign@3x.png b/HackIllinois/Assets.xcassets/LocationSign.imageset/LocationSign@3x.png new file mode 100644 index 00000000..e3671685 Binary files /dev/null and b/HackIllinois/Assets.xcassets/LocationSign.imageset/LocationSign@3x.png differ diff --git a/HackIllinois/Assets.xcassets/Login.imageset/Background.png b/HackIllinois/Assets.xcassets/Login.imageset/Background.png new file mode 100644 index 00000000..4d70e705 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Login.imageset/Background.png differ diff --git a/HackIllinois/Assets.xcassets/Login.imageset/Background@2x.png b/HackIllinois/Assets.xcassets/Login.imageset/Background@2x.png new file mode 100644 index 00000000..71f5cd3f Binary files /dev/null and b/HackIllinois/Assets.xcassets/Login.imageset/Background@2x.png differ diff --git a/HackIllinois/Assets.xcassets/Login.imageset/Background@3x.png b/HackIllinois/Assets.xcassets/Login.imageset/Background@3x.png new file mode 100644 index 00000000..c3032af1 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Login.imageset/Background@3x.png differ diff --git a/HackIllinois/Assets.xcassets/Login.imageset/Contents.json b/HackIllinois/Assets.xcassets/Login.imageset/Contents.json index 13a0b444..58812d2b 100644 --- a/HackIllinois/Assets.xcassets/Login.imageset/Contents.json +++ b/HackIllinois/Assets.xcassets/Login.imageset/Contents.json @@ -1,17 +1,17 @@ { "images" : [ { - "filename" : "Login@1x.png", + "filename" : "Background.png", "idiom" : "universal", "scale" : "1x" }, { - "filename" : "Login@2x.png", + "filename" : "Background@2x.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "Login@3x.png", + "filename" : "Background@3x.png", "idiom" : "universal", "scale" : "3x" } diff --git a/HackIllinois/Assets.xcassets/Login.imageset/Login@1x.png b/HackIllinois/Assets.xcassets/Login.imageset/Login@1x.png deleted file mode 100644 index fd095451..00000000 Binary files a/HackIllinois/Assets.xcassets/Login.imageset/Login@1x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Login.imageset/Login@2x.png b/HackIllinois/Assets.xcassets/Login.imageset/Login@2x.png deleted file mode 100644 index 7315d483..00000000 Binary files a/HackIllinois/Assets.xcassets/Login.imageset/Login@2x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Login.imageset/Login@3x.png b/HackIllinois/Assets.xcassets/Login.imageset/Login@3x.png deleted file mode 100644 index f0e74abe..00000000 Binary files a/HackIllinois/Assets.xcassets/Login.imageset/Login@3x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/LoginBackgroundPad.imageset/Background.png b/HackIllinois/Assets.xcassets/LoginBackgroundPad.imageset/Background.png new file mode 100644 index 00000000..26c85aac Binary files /dev/null and b/HackIllinois/Assets.xcassets/LoginBackgroundPad.imageset/Background.png differ diff --git a/HackIllinois/Assets.xcassets/LoginBackgroundPad.imageset/Background@2x.png b/HackIllinois/Assets.xcassets/LoginBackgroundPad.imageset/Background@2x.png new file mode 100644 index 00000000..42667729 Binary files /dev/null and b/HackIllinois/Assets.xcassets/LoginBackgroundPad.imageset/Background@2x.png differ diff --git a/HackIllinois/Assets.xcassets/LoginBackgroundPad.imageset/Background@3x.png b/HackIllinois/Assets.xcassets/LoginBackgroundPad.imageset/Background@3x.png new file mode 100644 index 00000000..02bc7019 Binary files /dev/null and b/HackIllinois/Assets.xcassets/LoginBackgroundPad.imageset/Background@3x.png differ diff --git a/HackIllinois/Assets.xcassets/LoginBackgroundPad.imageset/Contents.json b/HackIllinois/Assets.xcassets/LoginBackgroundPad.imageset/Contents.json new file mode 100644 index 00000000..58812d2b --- /dev/null +++ b/HackIllinois/Assets.xcassets/LoginBackgroundPad.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "filename" : "Background.png", + "idiom" : "universal", + "scale" : "1x" + }, + { + "filename" : "Background@2x.png", + "idiom" : "universal", + "scale" : "2x" + }, + { + "filename" : "Background@3x.png", + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/HackIllinois/Assets.xcassets/LoginBackgroundPhone.imageset/Background.png b/HackIllinois/Assets.xcassets/LoginBackgroundPhone.imageset/Background.png new file mode 100644 index 00000000..585a105a Binary files /dev/null and b/HackIllinois/Assets.xcassets/LoginBackgroundPhone.imageset/Background.png differ diff --git a/HackIllinois/Assets.xcassets/LoginBackgroundPhone.imageset/Background@2x.png b/HackIllinois/Assets.xcassets/LoginBackgroundPhone.imageset/Background@2x.png new file mode 100644 index 00000000..bc6b1f0f Binary files /dev/null and b/HackIllinois/Assets.xcassets/LoginBackgroundPhone.imageset/Background@2x.png differ diff --git a/HackIllinois/Assets.xcassets/LoginBackgroundPhone.imageset/Background@3x.png b/HackIllinois/Assets.xcassets/LoginBackgroundPhone.imageset/Background@3x.png new file mode 100644 index 00000000..1dc3e5d0 Binary files /dev/null and b/HackIllinois/Assets.xcassets/LoginBackgroundPhone.imageset/Background@3x.png differ diff --git a/HackIllinois/Assets.xcassets/LoginBackgroundPhone.imageset/Contents.json b/HackIllinois/Assets.xcassets/LoginBackgroundPhone.imageset/Contents.json new file mode 100644 index 00000000..58812d2b --- /dev/null +++ b/HackIllinois/Assets.xcassets/LoginBackgroundPhone.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "filename" : "Background.png", + "idiom" : "universal", + "scale" : "1x" + }, + { + "filename" : "Background@2x.png", + "idiom" : "universal", + "scale" : "2x" + }, + { + "filename" : "Background@3x.png", + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/HackIllinois/Assets.xcassets/LoginLogoPad.imageset/Contents.json b/HackIllinois/Assets.xcassets/LoginLogoPad.imageset/Contents.json new file mode 100644 index 00000000..206b97c3 --- /dev/null +++ b/HackIllinois/Assets.xcassets/LoginLogoPad.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "filename" : "Group 199.png", + "idiom" : "universal", + "scale" : "1x" + }, + { + "filename" : "Group 199@2x.png", + "idiom" : "universal", + "scale" : "2x" + }, + { + "filename" : "Group 199@3x.png", + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/HackIllinois/Assets.xcassets/LoginLogoPad.imageset/Group 199.png b/HackIllinois/Assets.xcassets/LoginLogoPad.imageset/Group 199.png new file mode 100644 index 00000000..19c80145 Binary files /dev/null and b/HackIllinois/Assets.xcassets/LoginLogoPad.imageset/Group 199.png differ diff --git a/HackIllinois/Assets.xcassets/LoginLogoPad.imageset/Group 199@2x.png b/HackIllinois/Assets.xcassets/LoginLogoPad.imageset/Group 199@2x.png new file mode 100644 index 00000000..36ee4f84 Binary files /dev/null and b/HackIllinois/Assets.xcassets/LoginLogoPad.imageset/Group 199@2x.png differ diff --git a/HackIllinois/Assets.xcassets/LoginLogoPad.imageset/Group 199@3x.png b/HackIllinois/Assets.xcassets/LoginLogoPad.imageset/Group 199@3x.png new file mode 100644 index 00000000..31d8dfd6 Binary files /dev/null and b/HackIllinois/Assets.xcassets/LoginLogoPad.imageset/Group 199@3x.png differ diff --git a/HackIllinois/Assets.xcassets/LogoutButton.imageset/LogoutButton@1x.png b/HackIllinois/Assets.xcassets/LogoutButton.imageset/LogoutButton@1x.png deleted file mode 100644 index 7dc38290..00000000 Binary files a/HackIllinois/Assets.xcassets/LogoutButton.imageset/LogoutButton@1x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/LogoutButton.imageset/LogoutButton@2x.png b/HackIllinois/Assets.xcassets/LogoutButton.imageset/LogoutButton@2x.png deleted file mode 100644 index 53a61289..00000000 Binary files a/HackIllinois/Assets.xcassets/LogoutButton.imageset/LogoutButton@2x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/LogoutButton.imageset/LogoutButton@3x.png b/HackIllinois/Assets.xcassets/LogoutButton.imageset/LogoutButton@3x.png deleted file mode 100644 index a98ca9ff..00000000 Binary files a/HackIllinois/Assets.xcassets/LogoutButton.imageset/LogoutButton@3x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Contents.json b/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Contents.json index 77c9f4f2..7b03edf6 100644 --- a/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Contents.json +++ b/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Contents.json @@ -1,17 +1,17 @@ { "images" : [ { - "filename" : "Onboarding0@1x.png", + "filename" : "Group 201.png", "idiom" : "universal", "scale" : "1x" }, { - "filename" : "Onboarding0@2x.png", + "filename" : "Group 201@2x.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "Onboarding0@3x.png", + "filename" : "Group 201@3x.png", "idiom" : "universal", "scale" : "3x" } diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Group 201.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Group 201.png new file mode 100644 index 00000000..797a0771 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Group 201.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Group 201@2x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Group 201@2x.png new file mode 100644 index 00000000..7bf7c78a Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Group 201@2x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Group 201@3x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Group 201@3x.png new file mode 100644 index 00000000..8ace0e8f Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Group 201@3x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Onboarding0@1x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Onboarding0@1x.png deleted file mode 100644 index c1014c04..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Onboarding0@1x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Onboarding0@2x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Onboarding0@2x.png deleted file mode 100644 index b2ceaf24..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Onboarding0@2x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Onboarding0@3x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Onboarding0@3x.png deleted file mode 100644 index a39c89f1..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/Onboarding0.imageset/Onboarding0@3x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Contents.json b/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Contents.json index 387ffd43..69d633bd 100644 --- a/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Contents.json +++ b/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Contents.json @@ -1,17 +1,17 @@ { "images" : [ { - "filename" : "Onboarding1@1x.png", + "filename" : "Group 2.png", "idiom" : "universal", "scale" : "1x" }, { - "filename" : "Onboarding1@2x.png", + "filename" : "Group 2@2x.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "Onboarding1@3x.png", + "filename" : "Group 2@3x.png", "idiom" : "universal", "scale" : "3x" } diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Group 2.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Group 2.png new file mode 100644 index 00000000..05e9bb96 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Group 2.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Group 2@2x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Group 2@2x.png new file mode 100644 index 00000000..9b6292c5 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Group 2@2x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Group 2@3x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Group 2@3x.png new file mode 100644 index 00000000..aa7adfd1 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Group 2@3x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Onboarding1@1x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Onboarding1@1x.png deleted file mode 100644 index 10513b8f..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Onboarding1@1x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Onboarding1@2x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Onboarding1@2x.png deleted file mode 100644 index 272f1a54..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Onboarding1@2x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Onboarding1@3x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Onboarding1@3x.png deleted file mode 100644 index 3a3194f0..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/Onboarding1.imageset/Onboarding1@3x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Contents.json b/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Contents.json index 6a0a3c7f..84fb02e0 100644 --- a/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Contents.json +++ b/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Contents.json @@ -1,17 +1,17 @@ { "images" : [ { - "filename" : "Onboarding2@1x.png", + "filename" : "Group 3.png", "idiom" : "universal", "scale" : "1x" }, { - "filename" : "Onboarding2@2x.png", + "filename" : "Group 3@2x.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "Onboarding2@3x.png", + "filename" : "Group 3@3x.png", "idiom" : "universal", "scale" : "3x" } diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Group 3.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Group 3.png new file mode 100644 index 00000000..537ce3de Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Group 3.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Group 3@2x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Group 3@2x.png new file mode 100644 index 00000000..cb69e791 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Group 3@2x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Group 3@3x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Group 3@3x.png new file mode 100644 index 00000000..6374fd90 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Group 3@3x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Onboarding2@1x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Onboarding2@1x.png deleted file mode 100644 index 2428c5d0..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Onboarding2@1x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Onboarding2@2x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Onboarding2@2x.png deleted file mode 100644 index 69da4cc5..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Onboarding2@2x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Onboarding2@3x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Onboarding2@3x.png deleted file mode 100644 index 8496c743..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/Onboarding2.imageset/Onboarding2@3x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Contents.json b/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Contents.json index 559f8488..5648ae32 100644 --- a/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Contents.json +++ b/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Contents.json @@ -1,17 +1,17 @@ { "images" : [ { - "filename" : "Onboarding3@1x.png", + "filename" : "Group 6.png", "idiom" : "universal", "scale" : "1x" }, { - "filename" : "Onboarding3@2x.png", + "filename" : "Group 6@2x.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "Onboarding3@3x.png", + "filename" : "Group 6@3x.png", "idiom" : "universal", "scale" : "3x" } diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Group 6.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Group 6.png new file mode 100644 index 00000000..a99b3903 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Group 6.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Group 6@2x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Group 6@2x.png new file mode 100644 index 00000000..60c7070d Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Group 6@2x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Group 6@3x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Group 6@3x.png new file mode 100644 index 00000000..1cb40520 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Group 6@3x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Onboarding3@1x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Onboarding3@1x.png deleted file mode 100644 index 2f2a7c86..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Onboarding3@1x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Onboarding3@2x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Onboarding3@2x.png deleted file mode 100644 index 5301710d..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Onboarding3@2x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Onboarding3@3x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Onboarding3@3x.png deleted file mode 100644 index 835b70d2..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/Onboarding3.imageset/Onboarding3@3x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Contents.json b/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Contents.json index 59b0a50a..614720fa 100644 --- a/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Contents.json +++ b/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Contents.json @@ -1,17 +1,17 @@ { "images" : [ { - "filename" : "Onboarding4@1x.png", + "filename" : "Group 5.png", "idiom" : "universal", "scale" : "1x" }, { - "filename" : "Onboarding4@2x.png", + "filename" : "Group 5@2x.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "Onboarding4@3x.png", + "filename" : "Group 5@3x.png", "idiom" : "universal", "scale" : "3x" } diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Group 5.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Group 5.png new file mode 100644 index 00000000..ca1e5b6e Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Group 5.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Group 5@2x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Group 5@2x.png new file mode 100644 index 00000000..4a0eb6f2 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Group 5@2x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Group 5@3x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Group 5@3x.png new file mode 100644 index 00000000..d58b83fb Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Group 5@3x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Onboarding4@1x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Onboarding4@1x.png deleted file mode 100644 index 8d95d509..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Onboarding4@1x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Onboarding4@2x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Onboarding4@2x.png deleted file mode 100644 index 9e8b00f4..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Onboarding4@2x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Onboarding4@3x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Onboarding4@3x.png deleted file mode 100644 index c8f30c39..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/Onboarding4.imageset/Onboarding4@3x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Contents.json b/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Contents.json index d398f86b..89de8262 100644 --- a/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Contents.json +++ b/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Contents.json @@ -1,17 +1,17 @@ { "images" : [ { - "filename" : "Onboarding5@1x.png", + "filename" : "Group 4.png", "idiom" : "universal", "scale" : "1x" }, { - "filename" : "Onboarding5@2x.png", + "filename" : "Group 4@2x.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "Onboarding5@3x.png", + "filename" : "Group 4@3x.png", "idiom" : "universal", "scale" : "3x" } diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Group 4.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Group 4.png new file mode 100644 index 00000000..8bd44f35 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Group 4.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Group 4@2x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Group 4@2x.png new file mode 100644 index 00000000..d351a050 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Group 4@2x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Group 4@3x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Group 4@3x.png new file mode 100644 index 00000000..526ab05e Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Group 4@3x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Onboarding5@1x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Onboarding5@1x.png deleted file mode 100644 index 27aa972d..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Onboarding5@1x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Onboarding5@2x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Onboarding5@2x.png deleted file mode 100644 index 5b4f98f2..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Onboarding5@2x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Onboarding5@3x.png b/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Onboarding5@3x.png deleted file mode 100644 index 6b1f4f02..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/Onboarding5.imageset/Onboarding5@3x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/Contents.json b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/Contents.json index 32223348..609a5917 100644 --- a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/Contents.json +++ b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/Contents.json @@ -1,17 +1,17 @@ { "images" : [ { - "filename" : "iPadOnboarding0@1x.png", + "filename" : "Group 8.png", "idiom" : "universal", "scale" : "1x" }, { - "filename" : "iPadOnboarding0@2x.png", + "filename" : "Group 8@2x.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "iPadOnboarding0@3x.png", + "filename" : "Group 8@3x.png", "idiom" : "universal", "scale" : "3x" } diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/Group 8.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/Group 8.png new file mode 100644 index 00000000..2d683938 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/Group 8.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/Group 8@2x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/Group 8@2x.png new file mode 100644 index 00000000..a4598cc5 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/Group 8@2x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/Group 8@3x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/Group 8@3x.png new file mode 100644 index 00000000..895ae186 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/Group 8@3x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/iPadOnboarding0@1x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/iPadOnboarding0@1x.png deleted file mode 100644 index 20729224..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/iPadOnboarding0@1x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/iPadOnboarding0@2x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/iPadOnboarding0@2x.png deleted file mode 100644 index 38847b63..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/iPadOnboarding0@2x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/iPadOnboarding0@3x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/iPadOnboarding0@3x.png deleted file mode 100644 index 2e019040..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding0.imageset/iPadOnboarding0@3x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/Contents.json b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/Contents.json index 6e5356d7..2c2154a8 100644 --- a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/Contents.json +++ b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/Contents.json @@ -1,17 +1,17 @@ { "images" : [ { - "filename" : "iPadOnboarding1@1x.png", + "filename" : "Group 9.png", "idiom" : "universal", "scale" : "1x" }, { - "filename" : "iPadOnboarding1@2x.png", + "filename" : "Group 9@2x.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "iPadOnboarding1@3x.png", + "filename" : "Group 9@3x.png", "idiom" : "universal", "scale" : "3x" } diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/Group 9.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/Group 9.png new file mode 100644 index 00000000..536800b8 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/Group 9.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/Group 9@2x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/Group 9@2x.png new file mode 100644 index 00000000..c047df8d Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/Group 9@2x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/Group 9@3x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/Group 9@3x.png new file mode 100644 index 00000000..003050bd Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/Group 9@3x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/iPadOnboarding1@1x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/iPadOnboarding1@1x.png deleted file mode 100644 index 01b25ae8..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/iPadOnboarding1@1x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/iPadOnboarding1@2x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/iPadOnboarding1@2x.png deleted file mode 100644 index 06fd2ecd..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/iPadOnboarding1@2x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/iPadOnboarding1@3x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/iPadOnboarding1@3x.png deleted file mode 100644 index d89f60d2..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding1.imageset/iPadOnboarding1@3x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/Contents.json b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/Contents.json index 6536703b..19c53ad1 100644 --- a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/Contents.json +++ b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/Contents.json @@ -1,17 +1,17 @@ { "images" : [ { - "filename" : "iPadOnboarding2@1x.png", + "filename" : "Group 12.png", "idiom" : "universal", "scale" : "1x" }, { - "filename" : "iPadOnboarding2@2x.png", + "filename" : "Group 12@2x.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "iPadOnboarding2@3x.png", + "filename" : "Group 12@3x.png", "idiom" : "universal", "scale" : "3x" } diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/Group 12.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/Group 12.png new file mode 100644 index 00000000..e13ef7d9 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/Group 12.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/Group 12@2x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/Group 12@2x.png new file mode 100644 index 00000000..3bee8e80 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/Group 12@2x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/Group 12@3x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/Group 12@3x.png new file mode 100644 index 00000000..f913b721 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/Group 12@3x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/iPadOnboarding2@1x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/iPadOnboarding2@1x.png deleted file mode 100644 index 6068b188..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/iPadOnboarding2@1x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/iPadOnboarding2@2x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/iPadOnboarding2@2x.png deleted file mode 100644 index a956ff19..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/iPadOnboarding2@2x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/iPadOnboarding2@3x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/iPadOnboarding2@3x.png deleted file mode 100644 index 251894ea..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding2.imageset/iPadOnboarding2@3x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/Contents.json b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/Contents.json index d08beb07..b57870b0 100644 --- a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/Contents.json +++ b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/Contents.json @@ -1,17 +1,17 @@ { "images" : [ { - "filename" : "iPadOnboarding3@1x.png", + "filename" : "Group 11.png", "idiom" : "universal", "scale" : "1x" }, { - "filename" : "iPadOnboarding3@2x.png", + "filename" : "Group 11@2x.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "iPadOnboarding3@3x.png", + "filename" : "Group 11@3x.png", "idiom" : "universal", "scale" : "3x" } diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/Group 11.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/Group 11.png new file mode 100644 index 00000000..0a8ce86a Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/Group 11.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/Group 11@2x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/Group 11@2x.png new file mode 100644 index 00000000..5cf1e259 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/Group 11@2x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/Group 11@3x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/Group 11@3x.png new file mode 100644 index 00000000..6d1e1534 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/Group 11@3x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/iPadOnboarding3@1x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/iPadOnboarding3@1x.png deleted file mode 100644 index 6dfea22e..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/iPadOnboarding3@1x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/iPadOnboarding3@2x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/iPadOnboarding3@2x.png deleted file mode 100644 index 79ae3ddc..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/iPadOnboarding3@2x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/iPadOnboarding3@3x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/iPadOnboarding3@3x.png deleted file mode 100644 index 7cde52c9..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding3.imageset/iPadOnboarding3@3x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/Contents.json b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/Contents.json index a92d48ed..c3bf0a44 100644 --- a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/Contents.json +++ b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/Contents.json @@ -1,17 +1,17 @@ { "images" : [ { - "filename" : "iPadOnboarding4@1x.png", + "filename" : "Group 10.png", "idiom" : "universal", "scale" : "1x" }, { - "filename" : "iPadOnboarding4@2x.png", + "filename" : "Group 10@2x.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "iPadOnboarding4@3x.png", + "filename" : "Group 10@3x.png", "idiom" : "universal", "scale" : "3x" } diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/Group 10.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/Group 10.png new file mode 100644 index 00000000..5e6da603 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/Group 10.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/Group 10@2x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/Group 10@2x.png new file mode 100644 index 00000000..2ae21a98 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/Group 10@2x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/Group 10@3x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/Group 10@3x.png new file mode 100644 index 00000000..a29e5403 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/Group 10@3x.png differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/iPadOnboarding4@1x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/iPadOnboarding4@1x.png deleted file mode 100644 index a932b4f0..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/iPadOnboarding4@1x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/iPadOnboarding4@2x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/iPadOnboarding4@2x.png deleted file mode 100644 index 77c6b2fa..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/iPadOnboarding4@2x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/iPadOnboarding4@3x.png b/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/iPadOnboarding4@3x.png deleted file mode 100644 index 782abc9b..00000000 Binary files a/HackIllinois/Assets.xcassets/Onboarding/iPadOnboarding4.imageset/iPadOnboarding4@3x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/ProfileBackground.imageset/Background (1).png b/HackIllinois/Assets.xcassets/ProfileBackground.imageset/Background (1).png new file mode 100644 index 00000000..235fea61 Binary files /dev/null and b/HackIllinois/Assets.xcassets/ProfileBackground.imageset/Background (1).png differ diff --git a/HackIllinois/Assets.xcassets/ProfileBackground.imageset/Background (2).png b/HackIllinois/Assets.xcassets/ProfileBackground.imageset/Background (2).png new file mode 100644 index 00000000..cd7217f6 Binary files /dev/null and b/HackIllinois/Assets.xcassets/ProfileBackground.imageset/Background (2).png differ diff --git a/HackIllinois/Assets.xcassets/ProfileBackground.imageset/Background.png b/HackIllinois/Assets.xcassets/ProfileBackground.imageset/Background.png new file mode 100644 index 00000000..4bedf4f0 Binary files /dev/null and b/HackIllinois/Assets.xcassets/ProfileBackground.imageset/Background.png differ diff --git a/HackIllinois/Assets.xcassets/ProfileBackground.imageset/Contents.json b/HackIllinois/Assets.xcassets/ProfileBackground.imageset/Contents.json index 9bf2cecb..06503aac 100644 --- a/HackIllinois/Assets.xcassets/ProfileBackground.imageset/Contents.json +++ b/HackIllinois/Assets.xcassets/ProfileBackground.imageset/Contents.json @@ -1,23 +1,23 @@ { "images" : [ { + "filename" : "Background.png", "idiom" : "universal", - "filename" : "ProfileBackground@1x.png", "scale" : "1x" }, { + "filename" : "Background (1).png", "idiom" : "universal", - "filename" : "ProfileBackground@2x.png", "scale" : "2x" }, { + "filename" : "Background (2).png", "idiom" : "universal", - "filename" : "ProfileBackground@3x.png", "scale" : "3x" } ], "info" : { - "version" : 1, - "author" : "xcode" + "author" : "xcode", + "version" : 1 } } diff --git a/HackIllinois/Assets.xcassets/ProfileBackground.imageset/ProfileBackground@1x.png b/HackIllinois/Assets.xcassets/ProfileBackground.imageset/ProfileBackground@1x.png deleted file mode 100644 index 63f2fe7a..00000000 Binary files a/HackIllinois/Assets.xcassets/ProfileBackground.imageset/ProfileBackground@1x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/ProfileBackground.imageset/ProfileBackground@2x.png b/HackIllinois/Assets.xcassets/ProfileBackground.imageset/ProfileBackground@2x.png deleted file mode 100644 index 69986cf2..00000000 Binary files a/HackIllinois/Assets.xcassets/ProfileBackground.imageset/ProfileBackground@2x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/ProfileBackground.imageset/ProfileBackground@3x.png b/HackIllinois/Assets.xcassets/ProfileBackground.imageset/ProfileBackground@3x.png deleted file mode 100644 index 911095bc..00000000 Binary files a/HackIllinois/Assets.xcassets/ProfileBackground.imageset/ProfileBackground@3x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/ProfileContainer.imageset/Contents.json b/HackIllinois/Assets.xcassets/ProfileContainer.imageset/Contents.json index ed68e563..b61ff2a5 100644 --- a/HackIllinois/Assets.xcassets/ProfileContainer.imageset/Contents.json +++ b/HackIllinois/Assets.xcassets/ProfileContainer.imageset/Contents.json @@ -1,7 +1,7 @@ { "images" : [ { - "filename" : "ProfileContainer@1x.png", + "filename" : "ProfileContainer.png", "idiom" : "universal", "scale" : "1x" }, diff --git a/HackIllinois/Assets.xcassets/ProfileContainer.imageset/ProfileContainer.png b/HackIllinois/Assets.xcassets/ProfileContainer.imageset/ProfileContainer.png new file mode 100644 index 00000000..9cd60b2f Binary files /dev/null and b/HackIllinois/Assets.xcassets/ProfileContainer.imageset/ProfileContainer.png differ diff --git a/HackIllinois/Assets.xcassets/ProfileContainer.imageset/ProfileContainer@1x.png b/HackIllinois/Assets.xcassets/ProfileContainer.imageset/ProfileContainer@1x.png deleted file mode 100644 index a116e86a..00000000 Binary files a/HackIllinois/Assets.xcassets/ProfileContainer.imageset/ProfileContainer@1x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/ProfileContainer.imageset/ProfileContainer@2x.png b/HackIllinois/Assets.xcassets/ProfileContainer.imageset/ProfileContainer@2x.png index 81eb9297..a2b94667 100644 Binary files a/HackIllinois/Assets.xcassets/ProfileContainer.imageset/ProfileContainer@2x.png and b/HackIllinois/Assets.xcassets/ProfileContainer.imageset/ProfileContainer@2x.png differ diff --git a/HackIllinois/Assets.xcassets/ProfileContainer.imageset/ProfileContainer@3x.png b/HackIllinois/Assets.xcassets/ProfileContainer.imageset/ProfileContainer@3x.png index 5c0ed26d..ddfe8375 100644 Binary files a/HackIllinois/Assets.xcassets/ProfileContainer.imageset/ProfileContainer@3x.png and b/HackIllinois/Assets.xcassets/ProfileContainer.imageset/ProfileContainer@3x.png differ diff --git a/HackIllinois/Assets.xcassets/ProfileIcons/Contents.json b/HackIllinois/Assets.xcassets/ProfileIcons/Contents.json index da4a164c..73c00596 100644 --- a/HackIllinois/Assets.xcassets/ProfileIcons/Contents.json +++ b/HackIllinois/Assets.xcassets/ProfileIcons/Contents.json @@ -1,6 +1,6 @@ { "info" : { - "version" : 1, - "author" : "xcode" + "author" : "xcode", + "version" : 1 } -} \ No newline at end of file +} diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-9.sticker/Contents.json b/HackIllinois/Assets.xcassets/ProfileView/Contents.json similarity index 52% rename from Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-9.sticker/Contents.json rename to HackIllinois/Assets.xcassets/ProfileView/Contents.json index 9f88c11c..73c00596 100644 --- a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-9.sticker/Contents.json +++ b/HackIllinois/Assets.xcassets/ProfileView/Contents.json @@ -2,8 +2,5 @@ "info" : { "author" : "xcode", "version" : 1 - }, - "properties" : { - "filename" : "sticker-9.png" } } diff --git a/HackIllinois/Assets.xcassets/ProfileView/LogoutButton.imageset/Contents.json b/HackIllinois/Assets.xcassets/ProfileView/LogoutButton.imageset/Contents.json new file mode 100644 index 00000000..df240cf1 --- /dev/null +++ b/HackIllinois/Assets.xcassets/ProfileView/LogoutButton.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "filename" : "Vector.png", + "idiom" : "universal", + "scale" : "1x" + }, + { + "filename" : "Vector@2x.png", + "idiom" : "universal", + "scale" : "2x" + }, + { + "filename" : "Vector@3x.png", + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/HackIllinois/Assets.xcassets/ProfileView/LogoutButton.imageset/Vector.png b/HackIllinois/Assets.xcassets/ProfileView/LogoutButton.imageset/Vector.png new file mode 100644 index 00000000..3a09275d Binary files /dev/null and b/HackIllinois/Assets.xcassets/ProfileView/LogoutButton.imageset/Vector.png differ diff --git a/HackIllinois/Assets.xcassets/ProfileView/LogoutButton.imageset/Vector@2x.png b/HackIllinois/Assets.xcassets/ProfileView/LogoutButton.imageset/Vector@2x.png new file mode 100644 index 00000000..5a720461 Binary files /dev/null and b/HackIllinois/Assets.xcassets/ProfileView/LogoutButton.imageset/Vector@2x.png differ diff --git a/HackIllinois/Assets.xcassets/ProfileView/LogoutButton.imageset/Vector@3x.png b/HackIllinois/Assets.xcassets/ProfileView/LogoutButton.imageset/Vector@3x.png new file mode 100644 index 00000000..dffb967d Binary files /dev/null and b/HackIllinois/Assets.xcassets/ProfileView/LogoutButton.imageset/Vector@3x.png differ diff --git a/HackIllinois/Assets.xcassets/ProfileView/TicketBack.imageset/Contents.json b/HackIllinois/Assets.xcassets/ProfileView/TicketBack.imageset/Contents.json new file mode 100644 index 00000000..5cb3509c --- /dev/null +++ b/HackIllinois/Assets.xcassets/ProfileView/TicketBack.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "filename" : "Ticket.png", + "idiom" : "universal", + "scale" : "1x" + }, + { + "filename" : "Ticket@2x.png", + "idiom" : "universal", + "scale" : "2x" + }, + { + "filename" : "Ticket@3x.png", + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/HackIllinois/Assets.xcassets/ProfileView/TicketBack.imageset/Ticket.png b/HackIllinois/Assets.xcassets/ProfileView/TicketBack.imageset/Ticket.png new file mode 100644 index 00000000..1ed04c24 Binary files /dev/null and b/HackIllinois/Assets.xcassets/ProfileView/TicketBack.imageset/Ticket.png differ diff --git a/HackIllinois/Assets.xcassets/ProfileView/TicketBack.imageset/Ticket@2x.png b/HackIllinois/Assets.xcassets/ProfileView/TicketBack.imageset/Ticket@2x.png new file mode 100644 index 00000000..c9e6f11c Binary files /dev/null and b/HackIllinois/Assets.xcassets/ProfileView/TicketBack.imageset/Ticket@2x.png differ diff --git a/HackIllinois/Assets.xcassets/ProfileView/TicketBack.imageset/Ticket@3x.png b/HackIllinois/Assets.xcassets/ProfileView/TicketBack.imageset/Ticket@3x.png new file mode 100644 index 00000000..348c69c2 Binary files /dev/null and b/HackIllinois/Assets.xcassets/ProfileView/TicketBack.imageset/Ticket@3x.png differ diff --git a/HackIllinois/Assets.xcassets/ProfileView/TicketFront.imageset/Contents.json b/HackIllinois/Assets.xcassets/ProfileView/TicketFront.imageset/Contents.json new file mode 100644 index 00000000..5cb3509c --- /dev/null +++ b/HackIllinois/Assets.xcassets/ProfileView/TicketFront.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "filename" : "Ticket.png", + "idiom" : "universal", + "scale" : "1x" + }, + { + "filename" : "Ticket@2x.png", + "idiom" : "universal", + "scale" : "2x" + }, + { + "filename" : "Ticket@3x.png", + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/HackIllinois/Assets.xcassets/ProfileView/TicketFront.imageset/Ticket.png b/HackIllinois/Assets.xcassets/ProfileView/TicketFront.imageset/Ticket.png new file mode 100644 index 00000000..1582f4cc Binary files /dev/null and b/HackIllinois/Assets.xcassets/ProfileView/TicketFront.imageset/Ticket.png differ diff --git a/HackIllinois/Assets.xcassets/ProfileView/TicketFront.imageset/Ticket@2x.png b/HackIllinois/Assets.xcassets/ProfileView/TicketFront.imageset/Ticket@2x.png new file mode 100644 index 00000000..03bbf715 Binary files /dev/null and b/HackIllinois/Assets.xcassets/ProfileView/TicketFront.imageset/Ticket@2x.png differ diff --git a/HackIllinois/Assets.xcassets/ProfileView/TicketFront.imageset/Ticket@3x.png b/HackIllinois/Assets.xcassets/ProfileView/TicketFront.imageset/Ticket@3x.png new file mode 100644 index 00000000..ddcef723 Binary files /dev/null and b/HackIllinois/Assets.xcassets/ProfileView/TicketFront.imageset/Ticket@3x.png differ diff --git a/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/Background@1x.png b/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/Background@1x.png new file mode 100644 index 00000000..4bedf4f0 Binary files /dev/null and b/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/Background@1x.png differ diff --git a/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/Background@2x.png b/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/Background@2x.png new file mode 100644 index 00000000..235fea61 Binary files /dev/null and b/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/Background@2x.png differ diff --git a/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/Background@3x.png b/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/Background@3x.png new file mode 100644 index 00000000..cd7217f6 Binary files /dev/null and b/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/Background@3x.png differ diff --git a/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/Contents.json b/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/Contents.json index f8b2c925..c091139b 100644 --- a/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/Contents.json +++ b/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/Contents.json @@ -1,17 +1,17 @@ { "images" : [ { - "filename" : "ScheduleBackground@1x.png", + "filename" : "Background@1x.png", "idiom" : "universal", "scale" : "1x" }, { - "filename" : "ScheduleBackground@2x.png", + "filename" : "Background@2x.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "ScheduleBackground@3x.png", + "filename" : "Background@3x.png", "idiom" : "universal", "scale" : "3x" } diff --git a/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/ScheduleBackground@1x.png b/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/ScheduleBackground@1x.png deleted file mode 100644 index 63f2fe7a..00000000 Binary files a/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/ScheduleBackground@1x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/ScheduleBackground@2x.png b/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/ScheduleBackground@2x.png deleted file mode 100644 index 69986cf2..00000000 Binary files a/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/ScheduleBackground@2x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/ScheduleBackground@3x.png b/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/ScheduleBackground@3x.png deleted file mode 100644 index 911095bc..00000000 Binary files a/HackIllinois/Assets.xcassets/ScheduleBackground.imageset/ScheduleBackground@3x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/SponsorPad.imageset/Contents.json b/HackIllinois/Assets.xcassets/SponsorPad.imageset/Contents.json new file mode 100644 index 00000000..cf806720 --- /dev/null +++ b/HackIllinois/Assets.xcassets/SponsorPad.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "filename" : "SponsorPad@1x.png", + "idiom" : "universal", + "scale" : "1x" + }, + { + "filename" : "SponsorPad@2x.png", + "idiom" : "universal", + "scale" : "2x" + }, + { + "filename" : "SponsorPad@3x.png", + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/HackIllinois/Assets.xcassets/SponsorPad.imageset/SponsorPad@1x.png b/HackIllinois/Assets.xcassets/SponsorPad.imageset/SponsorPad@1x.png new file mode 100644 index 00000000..2c0cb2c4 Binary files /dev/null and b/HackIllinois/Assets.xcassets/SponsorPad.imageset/SponsorPad@1x.png differ diff --git a/HackIllinois/Assets.xcassets/SponsorPad.imageset/SponsorPad@2x.png b/HackIllinois/Assets.xcassets/SponsorPad.imageset/SponsorPad@2x.png new file mode 100644 index 00000000..04851aec Binary files /dev/null and b/HackIllinois/Assets.xcassets/SponsorPad.imageset/SponsorPad@2x.png differ diff --git a/HackIllinois/Assets.xcassets/SponsorPad.imageset/SponsorPad@3x.png b/HackIllinois/Assets.xcassets/SponsorPad.imageset/SponsorPad@3x.png new file mode 100644 index 00000000..0595a48c Binary files /dev/null and b/HackIllinois/Assets.xcassets/SponsorPad.imageset/SponsorPad@3x.png differ diff --git a/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/Contents.json b/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/Contents.json index 6945ed88..ac23c5af 100644 --- a/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/Contents.json +++ b/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/Contents.json @@ -1,17 +1,17 @@ { "images" : [ { - "filename" : "QRCode@1x.png", + "filename" : "qr-code.png", "idiom" : "universal", "scale" : "1x" }, { - "filename" : "QRCode@2x.png", + "filename" : "qr-code-1.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "QRCode@3x.png", + "filename" : "qr-code-2.png", "idiom" : "universal", "scale" : "3x" } diff --git a/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/QRCode@1x.png b/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/QRCode@1x.png deleted file mode 100644 index 9cda0022..00000000 Binary files a/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/QRCode@1x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/QRCode@2x.png b/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/QRCode@2x.png deleted file mode 100644 index 146604b2..00000000 Binary files a/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/QRCode@2x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/QRCode@3x.png b/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/QRCode@3x.png deleted file mode 100644 index c5a1e14c..00000000 Binary files a/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/QRCode@3x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/qr-code-1.png b/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/qr-code-1.png new file mode 100644 index 00000000..1a883f1a Binary files /dev/null and b/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/qr-code-1.png differ diff --git a/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/qr-code-2.png b/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/qr-code-2.png new file mode 100644 index 00000000..4ba70613 Binary files /dev/null and b/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/qr-code-2.png differ diff --git a/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/qr-code.png b/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/qr-code.png new file mode 100644 index 00000000..354a305b Binary files /dev/null and b/HackIllinois/Assets.xcassets/TabBarIcons/QRCode.imageset/qr-code.png differ diff --git a/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/Contents.json b/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/Contents.json index cd8d1659..ca999c92 100644 --- a/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/Contents.json +++ b/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/Contents.json @@ -1,17 +1,17 @@ { "images" : [ { - "filename" : "QRScannerPopupTabIcon@1x.png", + "filename" : "qr-code@1x.png", "idiom" : "universal", "scale" : "1x" }, { - "filename" : "QRScannerPopupTabIcon@2x.png", + "filename" : "qr-code@2x.png", "idiom" : "universal", "scale" : "2x" }, { - "filename" : "QRScannerPopupTabIcon@3x.png", + "filename" : "qr-code@3x.png", "idiom" : "universal", "scale" : "3x" } diff --git a/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/QRScannerPopupTabIcon@1x.png b/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/QRScannerPopupTabIcon@1x.png deleted file mode 100644 index f3963d70..00000000 Binary files a/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/QRScannerPopupTabIcon@1x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/QRScannerPopupTabIcon@2x.png b/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/QRScannerPopupTabIcon@2x.png deleted file mode 100644 index 303c8e7d..00000000 Binary files a/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/QRScannerPopupTabIcon@2x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/QRScannerPopupTabIcon@3x.png b/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/QRScannerPopupTabIcon@3x.png deleted file mode 100644 index 6ca79a23..00000000 Binary files a/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/QRScannerPopupTabIcon@3x.png and /dev/null differ diff --git a/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/qr-code@1x.png b/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/qr-code@1x.png new file mode 100644 index 00000000..4ba70613 Binary files /dev/null and b/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/qr-code@1x.png differ diff --git a/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/qr-code@2x.png b/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/qr-code@2x.png new file mode 100644 index 00000000..1a883f1a Binary files /dev/null and b/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/qr-code@2x.png differ diff --git a/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/qr-code@3x.png b/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/qr-code@3x.png new file mode 100644 index 00000000..354a305b Binary files /dev/null and b/HackIllinois/Assets.xcassets/TabBarIcons/QRScannerPopupTabIcon.imageset/qr-code@3x.png differ diff --git a/HackIllinois/Assets.xcassets/TimePad.imageset/Contents.json b/HackIllinois/Assets.xcassets/TimePad.imageset/Contents.json new file mode 100644 index 00000000..c966f590 --- /dev/null +++ b/HackIllinois/Assets.xcassets/TimePad.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "filename" : "TimePad@1x.png", + "idiom" : "universal", + "scale" : "1x" + }, + { + "filename" : "TimePad@2x.png", + "idiom" : "universal", + "scale" : "2x" + }, + { + "filename" : "TimePad@3x.png", + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/HackIllinois/Assets.xcassets/TimePad.imageset/TimePad@1x.png b/HackIllinois/Assets.xcassets/TimePad.imageset/TimePad@1x.png new file mode 100644 index 00000000..3a30d478 Binary files /dev/null and b/HackIllinois/Assets.xcassets/TimePad.imageset/TimePad@1x.png differ diff --git a/HackIllinois/Assets.xcassets/TimePad.imageset/TimePad@2x.png b/HackIllinois/Assets.xcassets/TimePad.imageset/TimePad@2x.png new file mode 100644 index 00000000..52181bcd Binary files /dev/null and b/HackIllinois/Assets.xcassets/TimePad.imageset/TimePad@2x.png differ diff --git a/HackIllinois/Assets.xcassets/TimePad.imageset/TimePad@3x.png b/HackIllinois/Assets.xcassets/TimePad.imageset/TimePad@3x.png new file mode 100644 index 00000000..4005154f Binary files /dev/null and b/HackIllinois/Assets.xcassets/TimePad.imageset/TimePad@3x.png differ diff --git a/HackIllinois/Assets.xcassets/UnFavoritedPad.imageset/Contents.json b/HackIllinois/Assets.xcassets/UnFavoritedPad.imageset/Contents.json new file mode 100644 index 00000000..e2154602 --- /dev/null +++ b/HackIllinois/Assets.xcassets/UnFavoritedPad.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "filename" : "UnFavoritedPad@1x.png", + "idiom" : "universal", + "scale" : "1x" + }, + { + "filename" : "UnFavoritedPad@2x.png", + "idiom" : "universal", + "scale" : "2x" + }, + { + "filename" : "UnFavoritedPad@3x.png", + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/HackIllinois/Assets.xcassets/UnFavoritedPad.imageset/UnFavoritedPad@1x.png b/HackIllinois/Assets.xcassets/UnFavoritedPad.imageset/UnFavoritedPad@1x.png new file mode 100644 index 00000000..cfa143a5 Binary files /dev/null and b/HackIllinois/Assets.xcassets/UnFavoritedPad.imageset/UnFavoritedPad@1x.png differ diff --git a/HackIllinois/Assets.xcassets/UnFavoritedPad.imageset/UnFavoritedPad@2x.png b/HackIllinois/Assets.xcassets/UnFavoritedPad.imageset/UnFavoritedPad@2x.png new file mode 100644 index 00000000..2a14d524 Binary files /dev/null and b/HackIllinois/Assets.xcassets/UnFavoritedPad.imageset/UnFavoritedPad@2x.png differ diff --git a/HackIllinois/Assets.xcassets/UnFavoritedPad.imageset/UnFavoritedPad@3x.png b/HackIllinois/Assets.xcassets/UnFavoritedPad.imageset/UnFavoritedPad@3x.png new file mode 100644 index 00000000..844ea70b Binary files /dev/null and b/HackIllinois/Assets.xcassets/UnFavoritedPad.imageset/UnFavoritedPad@3x.png differ diff --git a/HackIllinois/Assets.xcassets/Vector.imageset/Contents.json b/HackIllinois/Assets.xcassets/Vector.imageset/Contents.json new file mode 100644 index 00000000..ce358c1d --- /dev/null +++ b/HackIllinois/Assets.xcassets/Vector.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "filename" : "Vector@1x.png", + "idiom" : "universal", + "scale" : "1x" + }, + { + "filename" : "Vector@2x.png", + "idiom" : "universal", + "scale" : "2x" + }, + { + "filename" : "Vector@3x.png", + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/HackIllinois/Assets.xcassets/Vector.imageset/Vector@1x.png b/HackIllinois/Assets.xcassets/Vector.imageset/Vector@1x.png new file mode 100644 index 00000000..b4cde56d Binary files /dev/null and b/HackIllinois/Assets.xcassets/Vector.imageset/Vector@1x.png differ diff --git a/HackIllinois/Assets.xcassets/Vector.imageset/Vector@2x.png b/HackIllinois/Assets.xcassets/Vector.imageset/Vector@2x.png new file mode 100644 index 00000000..8b769859 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Vector.imageset/Vector@2x.png differ diff --git a/HackIllinois/Assets.xcassets/Vector.imageset/Vector@3x.png b/HackIllinois/Assets.xcassets/Vector.imageset/Vector@3x.png new file mode 100644 index 00000000..f3a61e34 Binary files /dev/null and b/HackIllinois/Assets.xcassets/Vector.imageset/Vector@3x.png differ diff --git a/HackIllinois/Assets.xcassets/VectorPad.imageset/Contents.json b/HackIllinois/Assets.xcassets/VectorPad.imageset/Contents.json new file mode 100644 index 00000000..df36f7eb --- /dev/null +++ b/HackIllinois/Assets.xcassets/VectorPad.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "filename" : "VectorPad@1x.png", + "idiom" : "universal", + "scale" : "1x" + }, + { + "filename" : "VectorPad@2x.png", + "idiom" : "universal", + "scale" : "2x" + }, + { + "filename" : "VectorPad@3x.png", + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/HackIllinois/Assets.xcassets/VectorPad.imageset/VectorPad@1x.png b/HackIllinois/Assets.xcassets/VectorPad.imageset/VectorPad@1x.png new file mode 100644 index 00000000..26273f7d Binary files /dev/null and b/HackIllinois/Assets.xcassets/VectorPad.imageset/VectorPad@1x.png differ diff --git a/HackIllinois/Assets.xcassets/VectorPad.imageset/VectorPad@2x.png b/HackIllinois/Assets.xcassets/VectorPad.imageset/VectorPad@2x.png new file mode 100644 index 00000000..99a17baf Binary files /dev/null and b/HackIllinois/Assets.xcassets/VectorPad.imageset/VectorPad@2x.png differ diff --git a/HackIllinois/Assets.xcassets/VectorPad.imageset/VectorPad@3x.png b/HackIllinois/Assets.xcassets/VectorPad.imageset/VectorPad@3x.png new file mode 100644 index 00000000..37e9282e Binary files /dev/null and b/HackIllinois/Assets.xcassets/VectorPad.imageset/VectorPad@3x.png differ diff --git a/HackIllinois/Controllers/HILocalNotificationController.swift b/HackIllinois/Controllers/HILocalNotificationController.swift index 5b399bd1..38bd28ad 100644 --- a/HackIllinois/Controllers/HILocalNotificationController.swift +++ b/HackIllinois/Controllers/HILocalNotificationController.swift @@ -35,6 +35,8 @@ class HILocalNotificationController: NSObject { if granted { authorized?() } } case .provisional: break + case .ephemeral: + break @unknown default: os_log( "Unknown UNAuthorizationStatus %s", diff --git a/HackIllinois/DataSources/HIAnnouncementDataSource.swift b/HackIllinois/DataSources/HIAnnouncementDataSource.swift index 47ebe7b5..cfe5b5da 100644 --- a/HackIllinois/DataSources/HIAnnouncementDataSource.swift +++ b/HackIllinois/DataSources/HIAnnouncementDataSource.swift @@ -28,7 +28,7 @@ final class HIAnnouncementDataSource { } // Waive swiftlint warning - // swiftlint:disable:next function_body_length + // swiftlint:disable:next static func refresh(completion: (() -> Void)? = nil) { guard !isRefreshing else { completion?() diff --git a/HackIllinois/DataSources/HITimeDataSource.swift b/HackIllinois/DataSources/HITimeDataSource.swift index 414bad95..e0c1a813 100644 --- a/HackIllinois/DataSources/HITimeDataSource.swift +++ b/HackIllinois/DataSources/HITimeDataSource.swift @@ -18,16 +18,16 @@ final class HITimeDataSource { static var shared = HITimeDataSource() public static let defaultTimes = EventTimes( - eventStart: Date(timeIntervalSince1970: 1645833600), // Friday, February 25, 2021 6:00:00 PM CST - eventEnd: Date(timeIntervalSince1970: 1645999200), // Sunday, February 27, 2021 4:00:00 PM CST - hackStart: Date(timeIntervalSince1970: 1645837200), // Friday, February 25, 2021 7:00:00 PM CST - hackEnd: Date(timeIntervalSince1970: 1645977600), // Sunday, February 27, 2021 10:00:00 AM CST - fridayStart: Date(timeIntervalSince1970: 1645768800), // Friday, February 25, 2021 12:00:00 AM CST - fridayEnd: Date(timeIntervalSince1970: 1645855199), // Friday, February 25, 2021 11:59:59 PM CST - saturdayStart: Date(timeIntervalSince1970: 1645855200), // Saturday, February 26, 2021 12:00:00 AM CST - saturdayEnd: Date(timeIntervalSince1970: 1645941599), // Saturday, February 26, 2021 11:59:59 PM CST - sundayStart: Date(timeIntervalSince1970: 1645941600), // Sunday, February 27, 2021 12:00:00 AM CST - sundayEnd: Date(timeIntervalSince1970: 1646027999) // Sunday, February 27, 2021 11:59:59 PM CST + eventStart: Date(timeIntervalSince1970: 1677272400), // Friday, February 25, 2023 6:00:00 PM CST + eventEnd: Date(timeIntervalSince1970: 1677445200), // Sunday, February 27, 2023 4:00:00 PM CST + hackStart: Date(timeIntervalSince1970: 1677286800), // Friday, February 25, 2023 7:00:00 PM CST + hackEnd: Date(timeIntervalSince1970: 1677423600), // Sunday, February 27, 2023 10:00:00 AM CST + fridayStart: Date(timeIntervalSince1970: 1677218400), // Friday, February 25, 2023 12:00:00 AM CST + fridayEnd: Date(timeIntervalSince1970: 1677304799), // Friday, February 25, 2023 11:59:59 PM CST + saturdayStart: Date(timeIntervalSince1970: 1677304800), // Saturday, February 26, 2023 12:00:00 AM CST + saturdayEnd: Date(timeIntervalSince1970: 1677391199), // Saturday, February 26, 2023 11:59:59 PM CST + sundayStart: Date(timeIntervalSince1970: 1677391200), // Sunday, February 27, 2023 12:00:00 AM CST + sundayEnd: Date(timeIntervalSince1970: 1677477599) // Sunday, February 27, 2023 11:59:59 PM CST ) var eventTimes = HITimeDataSource.defaultTimes diff --git a/HackIllinois/Extensions/Array.swift b/HackIllinois/Extensions/Array.swift new file mode 100644 index 00000000..677e90b0 --- /dev/null +++ b/HackIllinois/Extensions/Array.swift @@ -0,0 +1,21 @@ +// +// Array.swift +// HackIllinois +// +// Created by HackIllinois Team on 2/6/23. +// Copyright © 2023 HackIllinois. All rights reserved. +// This file is part of the Hackillinois iOS App. +// The Hackillinois iOS App is open source software, released under the University of +// Illinois/NCSA Open Source License. You should have received a copy of +// this license in a file with the distribution. +// + +import Foundation + +extension Array where Element == UInt8 { + var deobfuscated: [UInt8] { + let pre = prefix(count / 2) + let post = suffix(count / 2) + return zip(pre, post).map(^) + } +} diff --git a/HackIllinois/FlowControllers/HIApplicationStateController.swift b/HackIllinois/FlowControllers/HIApplicationStateController.swift index cf0002fa..27564cdc 100644 --- a/HackIllinois/FlowControllers/HIApplicationStateController.swift +++ b/HackIllinois/FlowControllers/HIApplicationStateController.swift @@ -12,18 +12,16 @@ import Foundation import UIKit +import SwiftUI import Keychain class HIApplicationStateController { - static var shared = HIApplicationStateController() - // MARK: - Properties var window = HIWindow(frame: UIScreen.main.bounds) var user: HIUser? var profile: HIProfile? var isGuest = false - // MARK: ViewControllers var loginFlowController = HILoginFlowController() var appFlowController = HITabBarController() @@ -35,20 +33,16 @@ class HIApplicationStateController { NotificationCenter.default.addObserver(self, selector: #selector(loginProfile), name: .loginProfile, object: nil) NotificationCenter.default.addObserver(self, selector: #selector(getStarted), name: .getStarted, object: nil) } - deinit { NotificationCenter.default.removeObserver(self) } - func initalize() { window.makeKeyAndVisible() - resetPersistentDataIfNeeded() + reset2023IfNeeded() recoverUserIfPossible() recoverProfileIfPossible() - onboardingViewController.shouldDisplayAnimationOnNextAppearance = user == nil - UserDefaults.standard.set(true, forKey: HIConstants.APPLICATION_INSTALLED_KEY) let shouldShowOnboarding = UserDefaults.standard.object(forKey: HIConstants.SHOULD_SHOW_ONBOARDING_KEY) as? Bool ?? true updateWindowViewController(animated: false, shouldShowOnboarding: shouldShowOnboarding) @@ -57,13 +51,21 @@ class HIApplicationStateController { // MARK: - API extension HIApplicationStateController { + func reset2023IfNeeded() { + let didReset = UserDefaults.standard.object(forKey: "didReset2023") as? Bool ?? false + if !didReset { + _ = Keychain.default.purge() + HICoreDataController.shared.purge() + UserDefaults.standard.set(true, forKey: "didReset2023") + logoutUser() + } + } func resetPersistentDataIfNeeded() { guard !UserDefaults.standard.bool(forKey: HIConstants.APPLICATION_INSTALLED_KEY) else { return } _ = Keychain.default.purge() HICoreDataController.shared.purge() UserDefaults.standard.set(true, forKey: HIConstants.APPLICATION_INSTALLED_KEY) } - func recoverUserIfPossible() { guard Keychain.default.hasValue(forKey: HIConstants.STORED_ACCOUNT_KEY) else { return } guard let user = Keychain.default.retrieve(HIUser.self, forKey: HIConstants.STORED_ACCOUNT_KEY) else { @@ -76,7 +78,6 @@ extension HIApplicationStateController { } self.user = user } - func recoverProfileIfPossible() { guard Keychain.default.hasValue(forKey: HIConstants.STORED_PROFILE_KEY) else { return } guard let profile = Keychain.default.retrieve(HIProfile.self, forKey: HIConstants.STORED_PROFILE_KEY) else { @@ -85,7 +86,6 @@ extension HIApplicationStateController { } self.profile = profile } - func viewControllersFor(user: HIUser) -> [UIViewController] { var viewControllers = [UIViewController]() viewControllers.append(HIHomeViewController()) @@ -95,7 +95,6 @@ extension HIApplicationStateController { viewControllers.append(HILeaderboardViewController()) return viewControllers } - @objc func loginUser(_ notification: Notification) { guard let user = notification.userInfo?["user"] as? HIUser else { return } guard Keychain.default.store(user, forKey: HIConstants.STORED_ACCOUNT_KEY) else { return } @@ -108,7 +107,6 @@ extension HIApplicationStateController { UIApplication.shared.registerForRemoteNotifications() updateWindowViewController(animated: true, shouldShowOnboarding: false) } - @objc func logoutUser() { guard user != nil else { return } guard profile != nil else { return } @@ -118,7 +116,6 @@ extension HIApplicationStateController { profile = nil updateWindowViewController(animated: true, shouldShowOnboarding: false) } - @objc func loginProfile(_ notification: Notification) { guard let profile = notification.userInfo?["profile"] as? HIProfile else { return } guard Keychain.default.store(profile, forKey: HIConstants.STORED_PROFILE_KEY) else { return } @@ -129,37 +126,37 @@ extension HIApplicationStateController { // No longer need to show onboarding UserDefaults.standard.set(false, forKey: HIConstants.SHOULD_SHOW_ONBOARDING_KEY) } - func updateWindowViewController(animated: Bool, shouldShowOnboarding: Bool) { let viewController: UIViewController if shouldShowOnboarding { - viewController = onboardingViewController + // if #available(iOS 14.0, *) { + viewController = UIHostingController(rootView: HIOnboardingView()) + // } else { + // viewController = onboardingViewController + // } + // viewController = onboardingViewController } else if let user = user { prepareAppControllerForDisplay(with: user) viewController = appFlowController } else { viewController = loginFlowController } - let duration = animated ? 0.3 : 0 viewController.view.layoutIfNeeded() UIView.transition(with: window, duration: duration, options: .transitionCrossDissolve, animations: { self.window.rootViewController = viewController }, completion: nil) } - func prepareAppControllerForDisplay(with user: HIUser) { let appViewControllers = viewControllersFor(user: user) appFlowController.setupMenuFor(appViewControllers) appFlowController.selectedIndex = 0 - // Disable the middle tabbar button (QR Code) if let items = appFlowController.tabBar.items { if items.count >= 3 { items[2].isEnabled = false } } - HIEventDataSource.refresh() HIAnnouncementDataSource.refresh() HIProjectDataSource.refresh() diff --git a/HackIllinois/FlowControllers/HILoginFlowController.swift b/HackIllinois/FlowControllers/HILoginFlowController.swift index a4e8484e..38a773c8 100644 --- a/HackIllinois/FlowControllers/HILoginFlowController.swift +++ b/HackIllinois/FlowControllers/HILoginFlowController.swift @@ -11,12 +11,14 @@ // import UIKit +import AuthenticationServices import APIManager import Lottie import SafariServices import Keychain import HIAPI +#warning("ASWebAuthticationSession not tested") class HILoginFlowController: UIViewController { // MARK: - Properties @@ -35,7 +37,7 @@ class HILoginFlowController: UIViewController { } // prevents the login session from going out of scope during presentation - var loginSession: SFAuthenticationSession? + var loginSession: ASWebAuthenticationSession? // MARK: ViewControllers lazy var loginSelectionViewController = HILoginSelectionViewController(delegate: self) @@ -65,6 +67,14 @@ class HILoginFlowController: UIViewController { } } +// add ASWebAuthenticationPresentationContextProviding to the class +extension HILoginFlowController: ASWebAuthenticationPresentationContextProviding { + func presentationAnchor(for session: ASWebAuthenticationSession) -> ASPresentationAnchor { + let window = UIApplication.shared.windows.first { $0.isKeyWindow } + return window ?? ASPresentationAnchor() + } +} + // MARK: - UIViewController extension HILoginFlowController { override func viewDidLoad() { @@ -96,7 +106,7 @@ private extension HILoginFlowController { } let loginURL = HIAPI.AuthService.oauthURL(provider: user.provider) - loginSession = SFAuthenticationSession(url: loginURL, callbackURLScheme: nil) { [weak self] (url, error) in + loginSession = ASWebAuthenticationSession(url: loginURL, callbackURLScheme: nil) { [weak self] (url, error) in if let url = url, let components = URLComponents(url: url, resolvingAgainstBaseURL: true), let queryItems = components.queryItems, @@ -108,7 +118,7 @@ private extension HILoginFlowController { profile.oauthCode = code self?.exchangeOAuthCodeForAPIToken(buildingUser: user, profile: profile, sender: sender) } else if let error = error { - if (error as? SFAuthenticationError)?.code == SFAuthenticationError.canceledLogin { + if (error as? ASWebAuthenticationSessionError)?.code == ASWebAuthenticationSessionError.canceledLogin { // do nothing } else { self?.presentAuthenticationFailure(withError: error, sender: sender) @@ -118,6 +128,7 @@ private extension HILoginFlowController { self?.presentAuthenticationFailure(withError: error, sender: sender) } } + loginSession?.presentationContextProvider = self loginSession?.start() } @@ -231,7 +242,6 @@ private extension HILoginFlowController { profile.firstName = apiProfile.firstName profile.lastName = apiProfile.lastName profile.points = apiProfile.points - profile.timezone = apiProfile.timezone profile.discord = apiProfile.discord profile.avatarUrl = apiProfile.avatarUrl DispatchQueue.main.async { diff --git a/HackIllinois/Fonts/Montserrat-VariableFont_wght.ttf b/HackIllinois/Fonts/Montserrat-VariableFont_wght.ttf new file mode 100644 index 00000000..656db666 Binary files /dev/null and b/HackIllinois/Fonts/Montserrat-VariableFont_wght.ttf differ diff --git a/HackIllinois/GoogleMaps.framework/GoogleMaps b/HackIllinois/GoogleMaps.framework/GoogleMaps new file mode 100755 index 00000000..23d5d2c0 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/GoogleMaps differ diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSAccessibilityLabels.h b/HackIllinois/GoogleMaps.framework/Headers/GMSAccessibilityLabels.h new file mode 100755 index 00000000..f3d8bb10 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSAccessibilityLabels.h @@ -0,0 +1,22 @@ +#import + +/** + * Accessibility identifier for the compass button. + * + * @related GMSMapView + */ +extern NSString *const kGMSAccessibilityCompass; + +/** + * Accessibility identifier for the "my location" button. + * + * @related GMSMapView + */ +extern NSString *const kGMSAccessibilityMyLocation; + +/** + * Accessibility identifier for the "out of quota" error label. + * + * @related GMSMapView + */ +extern NSString *const kGMSAccessiblityOutOfQuota; diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSAddress.h b/HackIllinois/GoogleMaps.framework/Headers/GMSAddress.h new file mode 100755 index 00000000..93debd56 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSAddress.h @@ -0,0 +1,76 @@ +// +// GMSAddress.h +// Google Maps SDK for iOS +// +// Copyright 2014 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +#if __has_feature(modules) +@import GoogleMapsBase; +#else +#import +#endif + +NS_ASSUME_NONNULL_BEGIN + +/** + * A result from a reverse geocode request, containing a human-readable address. This class is + * immutable and should not be instantiated directly unless under testing circumstances. Obtain an + * instance via GMSGeocoder. + * + * Some of the fields may be nil, indicating they are not present. + */ +@interface GMSAddress : NSObject + +/** Location, or kLocationCoordinate2DInvalid if unknown. */ +@property(nonatomic, readonly) CLLocationCoordinate2D coordinate; + +/** Street number and name. */ +@property(nonatomic, copy, readonly, nullable) NSString *thoroughfare; + +/** Locality or city. */ +@property(nonatomic, copy, readonly, nullable) NSString *locality; + +/** Subdivision of locality, district or park. */ +@property(nonatomic, copy, readonly, nullable) NSString *subLocality; + +/** Region/State/Administrative area. */ +@property(nonatomic, copy, readonly, nullable) NSString *administrativeArea; + +/** Postal/Zip code. */ +@property(nonatomic, copy, readonly, nullable) NSString *postalCode; + +/** The country name. */ +@property(nonatomic, copy, readonly, nullable) NSString *country; + +/** An array of NSString containing formatted lines of the address. May be nil. */ +@property(nonatomic, copy, readonly, nullable) NSArray *lines; + +/** + * Returns the first line of the address. + */ +- (nullable NSString *)addressLine1 __GMS_AVAILABLE_BUT_DEPRECATED_MSG( + "This method is obsolete and will be removed in a future release. Use the lines property " + "instead."); + +/** + * Returns the second line of the address. + */ +- (nullable NSString *)addressLine2 __GMS_AVAILABLE_BUT_DEPRECATED_MSG( + "This method is obsolete and will be removed in a future release. Use the lines property " + "instead."); + +@end + +/** + * The former type of geocode results (pre-1.7). This remains here for migration and will be + * removed in future releases. + */ +@compatibility_alias GMSReverseGeocodeResult GMSAddress; + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSCALayer.h b/HackIllinois/GoogleMaps.framework/Headers/GMSCALayer.h new file mode 100755 index 00000000..2ab6da2e --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSCALayer.h @@ -0,0 +1,20 @@ +// +// GMSCALayer.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +/** + * GMSCALayer is a superclass used by layers in the Google Maps SDK for iOS, such as GMSMapLayer and + * GMSPanoramaLayer. + * + * This is an implementation detail and it should not be instantiated directly. + */ +@interface GMSCALayer : CALayer +@end diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSCameraPosition.h b/HackIllinois/GoogleMaps.framework/Headers/GMSCameraPosition.h new file mode 100755 index 00000000..82067904 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSCameraPosition.h @@ -0,0 +1,166 @@ +// +// GMSCameraPosition.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import +#import + +NS_ASSUME_NONNULL_BEGIN + +/** + * An immutable class that aggregates all camera position parameters. + */ +@interface GMSCameraPosition : NSObject + +/** + * Location on the Earth towards which the camera points. + */ +@property(nonatomic, readonly) CLLocationCoordinate2D target; + +/** + * Zoom level. Zoom uses an exponentional scale, where zoom 0 represents the entire world as a + * 256 x 256 square. Each successive zoom level increases magnification by a factor of 2. So at + * zoom level 1, the world is 512x512, and at zoom level 2, the entire world is 1024x1024. + */ +@property(nonatomic, readonly) float zoom; + +/** + * Bearing of the camera, in degrees clockwise from true north. + */ +@property(nonatomic, readonly) CLLocationDirection bearing; + +/** + * The angle, in degrees, of the camera from the nadir (directly facing the Earth). 0 is + * straight down, 90 is parallel to the ground. Note that the maximum angle allowed is dependent + * on the zoom. You can think of it as a series of line segments as a function of zoom, rather + * than a step function. For zoom 16 and above, the maximum angle is 65 degrees. For zoom 10 and + * below, the maximum angle is 30 degrees. + */ +@property(nonatomic, readonly) double viewingAngle; + +/** + * Designated initializer. Configures this GMSCameraPosition with all available camera properties. + * Building a GMSCameraPosition via this initializer (or by the following convenience constructors) + * will implicitly clamp camera values. + * + * @param target Location on the earth towards which the camera points. + * @param zoom The zoom level near the center of the screen. + * @param bearing Bearing of the camera in degrees clockwise from true north. + * @param viewingAngle The angle, in degrees, of the camera angle from the nadir (directly facing + * the Earth) + */ +- (instancetype)initWithTarget:(CLLocationCoordinate2D)target + zoom:(float)zoom + bearing:(CLLocationDirection)bearing + viewingAngle:(double)viewingAngle; + +/** + * Convenience initializer for GMSCameraPosition for a particular target and zoom level. This will + * set the bearing and viewingAngle properties of this camera to zero defaults (i.e., directly + * facing the Earth's surface, with the top of the screen pointing north). + * + * @param target Location on the earth towards which the camera points. + * @param zoom The zoom level near the center of the screen. + */ +- (instancetype)initWithTarget:(CLLocationCoordinate2D)target zoom:(float)zoom; + +/** + * Convenience initializer for GMSCameraPosition for a particular latitidue, longitude and zoom + * level. This will set the bearing and viewingAngle properties of this camera to zero defaults + * (i.e., directly facing the Earth's surface, with the top of the screen pointing north). + * + * @param latitude The latitude component of the location towards which the camera points. + * @param longitude The latitude component of the location towards which the camera points. + * @param zoom The zoom level near the center of the screen. + */ +- (instancetype)initWithLatitude:(CLLocationDegrees)latitude + longitude:(CLLocationDegrees)longitude + zoom:(float)zoom; + +/** + * Convenience initializer for GMSCameraPosition, with latitude/longitude and all other camera + * properties as per -initWithTarget:zoom:bearing:viewingAngle:. + * + * @param latitude The latitude component of the location towards which the camera points. + * @param longitude The latitude component of the location towards which the camera points. + * @param zoom The zoom level near the center of the screen. + * @param bearing Bearing of the camera in degrees clockwise from true north. + * @param viewingAngle The angle, in degrees, of the camera angle from the nadir (directly facing + * the Earth) + */ +- (instancetype)initWithLatitude:(CLLocationDegrees)latitude + longitude:(CLLocationDegrees)longitude + zoom:(float)zoom + bearing:(CLLocationDirection)bearing + viewingAngle:(double)viewingAngle; + +/** + * Convenience constructor for GMSCameraPosition for a particular target and zoom level. This will + * set the bearing and viewingAngle properties of this camera to zero defaults (i.e., directly + * facing the Earth's surface, with the top of the screen pointing north). + */ ++ (instancetype)cameraWithTarget:(CLLocationCoordinate2D)target zoom:(float)zoom; + +/** + * Convenience constructor for GMSCameraPosition, as per cameraWithTarget:zoom:. + */ ++ (instancetype)cameraWithLatitude:(CLLocationDegrees)latitude + longitude:(CLLocationDegrees)longitude + zoom:(float)zoom; + +/** + * Convenience constructor for GMSCameraPosition, with all camera properties as per + * initWithTarget:zoom:bearing:viewingAngle:. + */ ++ (instancetype)cameraWithTarget:(CLLocationCoordinate2D)target + zoom:(float)zoom + bearing:(CLLocationDirection)bearing + viewingAngle:(double)viewingAngle; + +/** + * Convenience constructor for GMSCameraPosition, with latitude/longitude and all other camera + * properties as per initWithTarget:zoom:bearing:viewingAngle:. + */ ++ (instancetype)cameraWithLatitude:(CLLocationDegrees)latitude + longitude:(CLLocationDegrees)longitude + zoom:(float)zoom + bearing:(CLLocationDirection)bearing + viewingAngle:(double)viewingAngle; + +/** + * Get the zoom level at which |meters| distance, at given |coord| on Earth, correspond to the + * specified number of screen |points|. + * + * For extremely large or small distances the returned zoom level may be smaller or larger than the + * minimum or maximum zoom level allowed on the camera. + * + * This helper method is useful for building camera positions that contain specific physical areas + * on Earth. + */ ++ (float)zoomAtCoordinate:(CLLocationCoordinate2D)coordinate + forMeters:(CLLocationDistance)meters + perPoints:(CGFloat)points; + +@end + +/** Mutable version of GMSCameraPosition. */ +@interface GMSMutableCameraPosition : GMSCameraPosition +@property(nonatomic) CLLocationCoordinate2D target; +@property(nonatomic) float zoom; +@property(nonatomic) CLLocationDirection bearing; +@property(nonatomic) double viewingAngle; +@end + +/** The maximum zoom (closest to the Earth's surface) permitted by the map camera. */ +FOUNDATION_EXTERN const float kGMSMaxZoomLevel; + +/** The minimum zoom (farthest from the Earth's surface) permitted by the map camera. */ +FOUNDATION_EXTERN const float kGMSMinZoomLevel; + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSCameraUpdate.h b/HackIllinois/GoogleMaps.framework/Headers/GMSCameraUpdate.h new file mode 100755 index 00000000..3996d015 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSCameraUpdate.h @@ -0,0 +1,109 @@ +// +// GMSCameraUpdate.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import +#import + +@class GMSCameraPosition; +@class GMSCoordinateBounds; + +NS_ASSUME_NONNULL_BEGIN + +/** + * GMSCameraUpdate represents an update that may be applied to a GMSMapView. + * + * It encapsulates some logic for modifying the current camera. + * + * It should only be constructed using the factory helper methods below. + */ +@interface GMSCameraUpdate : NSObject + +/** + * Returns a GMSCameraUpdate that zooms in on the map. + * + * The zoom increment is 1.0. + */ ++ (GMSCameraUpdate *)zoomIn; + +/** + * Returns a GMSCameraUpdate that zooms out on the map. + * + * The zoom increment is -1.0. + */ ++ (GMSCameraUpdate *)zoomOut; + +/** + * Returns a GMSCameraUpdate that changes the zoom by the specified amount. + */ ++ (GMSCameraUpdate *)zoomBy:(float)delta; + +/** + * Returns a GMSCameraUpdate that sets the zoom to the specified amount. + */ ++ (GMSCameraUpdate *)zoomTo:(float)zoom; + +/** + * Returns a GMSCameraUpdate that sets the camera target to the specified coordinate. + */ ++ (GMSCameraUpdate *)setTarget:(CLLocationCoordinate2D)target; + +/** + * Returns a GMSCameraUpdate that sets the camera target and zoom to the specified values. + */ ++ (GMSCameraUpdate *)setTarget:(CLLocationCoordinate2D)target zoom:(float)zoom; + +/** + * Returns a GMSCameraUpdate that sets the camera to the specified GMSCameraPosition. + */ ++ (GMSCameraUpdate *)setCamera:(GMSCameraPosition *)camera; + +/** + * Returns a GMSCameraUpdate that transforms the camera such that the specified bounds are centered + * on screen at the greatest possible zoom level. The bounds will have a default padding of 64 + * points. + * + * The returned camera update will set the camera's bearing and tilt to their default zero values + * (i.e., facing north and looking directly at the Earth). + */ ++ (GMSCameraUpdate *)fitBounds:(GMSCoordinateBounds *)bounds; + +/** + * This is similar to fitBounds: but allows specifying the padding (in points) in order to inset the + * bounding box from the view's edges. + * + * If the requested |padding| is larger than the view size in either the vertical or horizontal + * direction the map will be maximally zoomed out. + */ ++ (GMSCameraUpdate *)fitBounds:(GMSCoordinateBounds *)bounds withPadding:(CGFloat)padding; + +/** + * This is similar to fitBounds: but allows specifying edge insets in order to inset the bounding + * box from the view's edges. + * + * If the requested |edgeInsets| are larger than the view size in either the vertical or horizontal + * direction the map will be maximally zoomed out. + */ ++ (GMSCameraUpdate *)fitBounds:(GMSCoordinateBounds *)bounds + withEdgeInsets:(UIEdgeInsets)edgeInsets; + +/** + * Returns a GMSCameraUpdate that shifts the center of the view by the specified number of points in + * the x and y directions. X grows to the right, Y grows down. + */ ++ (GMSCameraUpdate *)scrollByX:(CGFloat)dX Y:(CGFloat)dY; + +/** + * Returns a GMSCameraUpdate that zooms with a focus point; the focus point stays fixed on screen. + */ ++ (GMSCameraUpdate *)zoomBy:(float)zoom atPoint:(CGPoint)point; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSCircle.h b/HackIllinois/GoogleMaps.framework/Headers/GMSCircle.h new file mode 100755 index 00000000..eb68873e --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSCircle.h @@ -0,0 +1,55 @@ +// +// GMSCircle.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +#import "GMSOverlay.h" + +NS_ASSUME_NONNULL_BEGIN + +/** + * A circle on the Earth's surface (spherical cap). + */ +@interface GMSCircle : GMSOverlay + +/** Position on Earth of circle center. Ignores invalid positions. */ +@property(nonatomic) CLLocationCoordinate2D position; + +/** Radius of the circle in meters; must be positive. */ +@property(nonatomic) CLLocationDistance radius; + +/** + * The width of the circle's outline in screen points. Defaults to 1. As per GMSPolygon, the width + * does not scale when the map is zoomed. + * + * Setting strokeWidth to 0 results in no stroke. + */ +@property(nonatomic) CGFloat strokeWidth; + +/** The color of this circle's outline. The default value is black. */ +@property(nonatomic, nullable) UIColor *strokeColor; + +/** + * The interior of the circle is painted with fillColor. The default value is nil, resulting in no + * fill. + */ +@property(nonatomic, nullable) UIColor *fillColor; + +/** + * Convenience constructor for GMSCircle for a particular position and radius. Other properties will + * have default values. An invalid position will result in an overlay object that cannot be drawn on + * the map. + */ ++ (instancetype)circleWithPosition:(CLLocationCoordinate2D)position + radius:(CLLocationDistance)radius; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSCoordinateBounds+GoogleMaps.h b/HackIllinois/GoogleMaps.framework/Headers/GMSCoordinateBounds+GoogleMaps.h new file mode 100755 index 00000000..18f543f5 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSCoordinateBounds+GoogleMaps.h @@ -0,0 +1,42 @@ +// +// GMSCoordinateBounds+GoogleMaps.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + + +#if __has_feature(modules) +@import GoogleMapsBase; +#else +#import +#endif +#import "GMSProjection.h" + +@class GMSPath; + +NS_ASSUME_NONNULL_BEGIN + +@interface GMSCoordinateBounds (GoogleMaps) + +/** + * Inits with bounds that encompass |region|. + */ +- (id)initWithRegion:(GMSVisibleRegion)region; + +/** + * Inits with bounds that encompass |path|. + */ +- (id)initWithPath:(GMSPath *)path; + +/** + * Returns a GMSCoordinateBounds representing the current bounds extended to include |path|. + */ +- (GMSCoordinateBounds *)includingPath:(GMSPath *)path; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSGeocoder.h b/HackIllinois/GoogleMaps.framework/Headers/GMSGeocoder.h new file mode 100755 index 00000000..a781c06a --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSGeocoder.h @@ -0,0 +1,73 @@ +// +// GMSGeocoder.h +// Google Maps SDK for iOS +// +// Copyright 2012 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +#import "GMSAddress.h" + +@class GMSReverseGeocodeResponse; + +NS_ASSUME_NONNULL_BEGIN + +/** + * \defgroup GeocoderErrorCode GMSGeocoderErrorCode + * @{ + */ + +/** + * GMSGeocoder error codes, embedded in NSError. + */ +typedef NS_ENUM(NSInteger, GMSGeocoderErrorCode) { + kGMSGeocoderErrorInvalidCoordinate = 1, + kGMSGeocoderErrorInternal, +}; + +/**@}*/ + +/** + * Handler that reports a reverse geocoding response, or error. + * + * @related GMSGeocoder + */ +typedef void (^GMSReverseGeocodeCallback)(GMSReverseGeocodeResponse *_Nullable, NSError *_Nullable); + +/** + * Exposes a service for reverse geocoding. This maps Earth coordinates (latitude and longitude) to + * a collection of addresses near that coordinate. + */ +@interface GMSGeocoder : NSObject + +/* Convenience constructor for GMSGeocoder. */ ++ (GMSGeocoder *)geocoder; + +/** + * Reverse geocodes a coordinate on the Earth's surface. + * + * @param coordinate The coordinate to reverse geocode. + * @param handler The callback to invoke with the reverse geocode results. + * The callback will be invoked asynchronously from the main thread. + */ +- (void)reverseGeocodeCoordinate:(CLLocationCoordinate2D)coordinate + completionHandler:(GMSReverseGeocodeCallback)handler; + +@end + +/** A collection of results from a reverse geocode request. */ +@interface GMSReverseGeocodeResponse : NSObject + +/** Returns the first result, or nil if no results were available. */ +- (nullable GMSAddress *)firstResult; + +/** Returns an array of all the results (contains GMSAddress), including the first result. */ +- (nullable NSArray *)results; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSGeometryUtils.h b/HackIllinois/GoogleMaps.framework/Headers/GMSGeometryUtils.h new file mode 100755 index 00000000..b343d447 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSGeometryUtils.h @@ -0,0 +1,235 @@ +// +// GMSGeometryUtils.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +/** + * \defgroup GeometryUtils GMSGeometryUtils + * @{ + */ + +#import + +#import "GMSPath.h" + +@class GMSPath; +@class GMSStrokeStyle; +@class GMSStyleSpan; + +NS_ASSUME_NONNULL_BEGIN + +/** Average Earth radius in meters. */ +static const CLLocationDistance kGMSEarthRadius = 6371009.0; + +/** + * A point on the map. May represent a projected coordinate. + * + * x is in [-1, 1]. The axis direction is normal: y grows towards North, x grows towards East. (0, + * 0) is the center of the map. + * + * See GMSProject() and GMSUnproject(). + */ +typedef struct GMSMapPoint { + double x; + double y; +} GMSMapPoint; + +/** Projects |coordinate| to the map. |coordinate| must be valid. */ +FOUNDATION_EXPORT +GMSMapPoint GMSProject(CLLocationCoordinate2D coordinate); + +/** Unprojects |point| from the map. point.x must be in [-1, 1]. */ +FOUNDATION_EXPORT +CLLocationCoordinate2D GMSUnproject(GMSMapPoint point); + +/** + * Returns a linearly interpolated point on the segment [a, b], at the fraction |t| from |a|. |t|==0 + * corresponds to |a|, |t|==1 corresponds to |b|. + * + * The interpolation takes place along the short path between the points potentially crossing the + * date line. E.g. interpolating from San Francisco to Tokyo will pass north of Hawaii and cross the + * date line. + */ +FOUNDATION_EXPORT +GMSMapPoint GMSMapPointInterpolate(GMSMapPoint a, GMSMapPoint b, double t); + +/** + * Returns the length of the segment [a, b] in projected space. + * + * The length is computed along the short path between the points potentially crossing the date + * line. E.g. the distance between the points corresponding to San Francisco and Tokyo measures the + * segment that passes north of Hawaii crossing the date line. + */ +FOUNDATION_EXPORT +double GMSMapPointDistance(GMSMapPoint a, GMSMapPoint b); + +/** + * Returns whether |point| lies inside of path. The path is always considered closed, regardless of + * whether the last point equals the first or not. + * + * Inside is defined as not containing the South Pole -- the South Pole is always outside. + * + * |path| describes great circle segments if |geodesic| is YES, and rhumb (loxodromic) segments + * otherwise. + * + * If |point| is exactly equal to one of the vertices, the result is YES. A point that is not equal + * to a vertex is on one side or the other of any path segment -- it can never be "exactly on the + * border". + * + * See GMSGeometryIsLocationOnPath() for a border test with tolerance. + */ +FOUNDATION_EXPORT +BOOL GMSGeometryContainsLocation(CLLocationCoordinate2D point, GMSPath *path, BOOL geodesic); + +/** + * Returns whether |point| lies on or near |path|, within the specified |tolerance| in meters. + * |path| is composed of great circle segments if |geodesic| is YES, and of rhumb (loxodromic) + * segments if |geodesic| is NO. + * + * See also GMSGeometryIsLocationOnPath(point, path, geodesic). + * + * The tolerance, in meters, is relative to the spherical radius of the Earth. If you need to work + * on a sphere of different radius, you may compute the equivalent tolerance from the desired + * tolerance on the sphere of radius R: tolerance = toleranceR * (RadiusEarth / R), with + * RadiusEarth==6371009. + */ +FOUNDATION_EXPORT +BOOL GMSGeometryIsLocationOnPathTolerance(CLLocationCoordinate2D point, GMSPath *path, + BOOL geodesic, CLLocationDistance tolerance); + +/** + * Same as GMSGeometryIsLocationOnPath(point, path, geodesic, tolerance), with a default tolerance + * of 0.1 meters. + */ +FOUNDATION_EXPORT +BOOL GMSGeometryIsLocationOnPath(CLLocationCoordinate2D point, GMSPath *path, BOOL geodesic); + +/** + * Returns the great circle distance between two coordinates, in meters, on Earth. + * + * This is the shortest distance between the two coordinates on the sphere. + * + * Both coordinates must be valid. + */ +FOUNDATION_EXPORT +CLLocationDistance GMSGeometryDistance(CLLocationCoordinate2D from, CLLocationCoordinate2D to); + +/** + * Returns the great circle length of |path|, in meters, on Earth. + * + * This is the sum of GMSGeometryDistance() over the path segments. + * + * All the coordinates of the path must be valid. + */ +FOUNDATION_EXPORT +CLLocationDistance GMSGeometryLength(GMSPath *path); + +/** + * Returns the area of a geodesic polygon defined by |path| on Earth. + * + * The "inside" of the polygon is defined as not containing the South pole. + * + * If |path| is not closed, it is implicitly treated as a closed path nevertheless and the result is + * the same. + * + * All coordinates of the path must be valid. + * + * The polygon must be simple (not self-overlapping) and may be concave. + * + * If any segment of the path is a pair of antipodal points, the result is undefined -- because two + * antipodal points do not form a unique great circle segment on the sphere. + */ +FOUNDATION_EXPORT +double GMSGeometryArea(GMSPath *path); + +/** + * Returns the signed area of a geodesic polygon defined by |path| on Earth. + * + * The result has the same absolute value as GMSGeometryArea(); it is positive if the points of path + * are in counter-clockwise order, and negative otherwise. + * + * The same restrictions as on GMSGeometryArea() apply. + */ +FOUNDATION_EXPORT +double GMSGeometrySignedArea(GMSPath *path); + +/** + * Returns the initial heading (degrees clockwise of North) at |from| of the shortest path to |to|. + * + * The returned value is in the range [0, 360). + * + * Returns 0 if the two coordinates are the same. + * + * Both coordinates must be valid. + * + * To get the final heading at |to| one may use (GMSGeometryHeading(|to|, |from|) + 180) modulo 360. + */ +FOUNDATION_EXPORT +CLLocationDirection GMSGeometryHeading(CLLocationCoordinate2D from, CLLocationCoordinate2D to); + +/** + * Returns the destination coordinate, when starting at |from| with initial |heading|, travelling + * |distance| meters along a great circle arc, on Earth. + * + * The resulting longitude is in the range [-180, 180). + * + * Both coordinates must be valid. + */ +FOUNDATION_EXPORT +CLLocationCoordinate2D GMSGeometryOffset(CLLocationCoordinate2D from, CLLocationDistance distance, + CLLocationDirection heading); + +/** + * Returns the coordinate that lies the given |fraction| of the way between the |from| and |to| + * coordinates on the shortest path between the two. + * + * The resulting longitude is in the range [-180, 180). + */ +FOUNDATION_EXPORT +CLLocationCoordinate2D GMSGeometryInterpolate(CLLocationCoordinate2D from, + CLLocationCoordinate2D to, double fraction); + +/** + * Returns an NSArray of GMSStyleSpan constructed by repeated application of style and length + * information from |styles| and |lengths| along |path|. + * + * |path| the path along which the output spans are computed. + * |styles| an NSArray of GMSStrokeStyle. Wraps if consumed. Can't be empty. + * |lengths| an NSArray of NSNumber; each entry gives the length of the corresponding + * style from |styles|. Wraps if consumed. Can't be empty. + * |lengthKind| the interpretation of values from |lengths| (geodesic, rhumb or projected). + * + * Example: a polyline with alternating black and white spans: + * + *
+ * GMSMutablePath *path;
+ * NSArray *styles = @[[GMSStrokeStyle solidColor:[UIColor whiteColor]],
+ *                     [GMSStrokeStyle solidColor:[UIColor blackColor]]];
+ * NSArray *lengths = @[@100000, @50000];
+ * polyline.path = path;
+ * polyline.spans = GMSStyleSpans(path, styles, lengths, kGMSLengthRhumb);
+ * 
+ */ +FOUNDATION_EXPORT +NSArray *GMSStyleSpans(GMSPath *path, NSArray *styles, + NSArray *lengths, GMSLengthKind lengthKind); + +/** + * Similar to GMSStyleSpans(path, styles, lengths, lengthKind) but additionally takes an initial + * length offset that will be skipped over relative to the |lengths| array. + * + * |lengthOffset| the length (e.g. in meters) that should be skipped initially from |lengths|. + */ +FOUNDATION_EXPORT +NSArray *GMSStyleSpansOffset(GMSPath *path, NSArray *styles, + NSArray *lengths, GMSLengthKind lengthKind, + double lengthOffset); + +/**@}*/ + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSGroundOverlay.h b/HackIllinois/GoogleMaps.framework/Headers/GMSGroundOverlay.h new file mode 100755 index 00000000..a3a83047 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSGroundOverlay.h @@ -0,0 +1,85 @@ +// +// GMSGroundOverlay.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +#import "GMSOverlay.h" + +@class GMSCoordinateBounds; + +NS_ASSUME_NONNULL_BEGIN + +/** + * GMSGroundOverlay specifies the available options for a ground overlay that exists on the Earth's + * surface. Unlike a marker, the position of a ground overlay is specified explicitly and it does + * not face the camera. + */ +@interface GMSGroundOverlay : GMSOverlay + +/** + * The position of this GMSGroundOverlay, or more specifically, the physical position of its anchor. + * If this is changed, |bounds| will be moved around the new position. + */ +@property(nonatomic) CLLocationCoordinate2D position; + +/** + * The anchor specifies where this GMSGroundOverlay is anchored to the Earth in relation to + * |bounds|. If this is modified, |position| will be set to the corresponding new position within + * |bounds|. + */ +@property(nonatomic) CGPoint anchor; + +/** + * Icon to render within |bounds| on the Earth. If this is nil, the overlay will not be visible + * (unlike GMSMarker which has a default image). + */ +@property(nonatomic, nullable) UIImage *icon; + +/** + * Sets the opacity of the ground overlay, between 0 (completely transparent) and 1 (default) + * inclusive. + */ +@property(nonatomic) float opacity; + +/** + * Bearing of this ground overlay, in degrees. The default value, zero, points this ground overlay + * up/down along the normal Y axis of the earth. + */ +@property(nonatomic) CLLocationDirection bearing; + +/** + * The 2D bounds on the Earth in which |icon| is drawn. Changing this value will adjust |position| + * accordingly. + */ +@property(nonatomic, nullable) GMSCoordinateBounds *bounds; + +/** + * Convenience constructor for GMSGroundOverlay for a particular |bounds| and |icon|. Will set + * |position| accordingly. + */ ++ (instancetype)groundOverlayWithBounds:(nullable GMSCoordinateBounds *)bounds + icon:(nullable UIImage *)icon; + +/** + * Constructs a GMSGroundOverlay that renders the given |icon| at |position|, as if the image's + * actual size matches camera pixels at |zoomLevel|. + */ ++ (instancetype)groundOverlayWithPosition:(CLLocationCoordinate2D)position + icon:(nullable UIImage *)icon + zoomLevel:(CGFloat)zoomLevel; + +@end + +/** + * The default position of the ground anchor of a GMSGroundOverlay: the center point of the icon. + */ +FOUNDATION_EXTERN const CGPoint kGMSGroundOverlayDefaultAnchor; + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSIndoorBuilding.h b/HackIllinois/GoogleMaps.framework/Headers/GMSIndoorBuilding.h new file mode 100755 index 00000000..c40d960f --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSIndoorBuilding.h @@ -0,0 +1,43 @@ +// +// GMSIndoorBuilding.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + + +#import + +@class GMSIndoorLevel; + +NS_ASSUME_NONNULL_BEGIN + +/** + * Describes a building which contains levels. + */ +@interface GMSIndoorBuilding : NSObject + +/** + * Array of GMSIndoorLevel describing the levels which make up the building. + * The levels are in 'display order' from top to bottom. + */ +@property(nonatomic, strong, readonly) NSArray *levels; + +/** + * Index in the levels array of the default level. + */ +@property(nonatomic, assign, readonly) NSUInteger defaultLevelIndex; + +/** + * If YES, the building is entirely underground and supports being hidden. + */ +@property(nonatomic, assign, readonly, getter=isUnderground) BOOL underground; + +- (instancetype)init NS_UNAVAILABLE; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSIndoorDisplay.h b/HackIllinois/GoogleMaps.framework/Headers/GMSIndoorDisplay.h new file mode 100755 index 00000000..883a9812 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSIndoorDisplay.h @@ -0,0 +1,66 @@ +// +// GMSIndoorDisplay.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +@class GMSIndoorBuilding; +@class GMSIndoorLevel; + +NS_ASSUME_NONNULL_BEGIN + +/** Delegate for events on GMSIndoorDisplay. */ +@protocol GMSIndoorDisplayDelegate +@optional + +/** + * Raised when the activeBuilding has changed. The activeLevel will also have already been updated + * for the new building, but didChangeActiveLevel: will be raised after this method. + */ +- (void)didChangeActiveBuilding:(nullable GMSIndoorBuilding *)building; + +/** + * Raised when the activeLevel has changed. This event is raised for all changes, including + * explicit setting of the property. + */ +- (void)didChangeActiveLevel:(nullable GMSIndoorLevel *)level; + +@end + +/** + * Provides ability to observe or control the display of indoor level data. + * + * Like GMSMapView, GMSIndoorDisplay may only be used from the main thread. + */ +@interface GMSIndoorDisplay : NSObject + +/** GMSIndoorDisplay delegate */ +@property(nonatomic, weak, nullable) id delegate; + +/** + * Provides the currently focused building, will be nil if there is no building with indoor data + * currently under focus. + */ +@property(nonatomic, readonly, nullable) GMSIndoorBuilding *activeBuilding; + +/** + * Provides and controls the active level for activeBuilding. Will be updated whenever + * activeBuilding changes, and may be set to any member of activeBuilding's levels property. May + * also be set to nil if the building is underground, to stop showing the building (the building + * will remain active). + * + * Will always be nil if activeBuilding is nil. + * + * Any attempt to set it to an invalid value will be ignored. + */ +@property(nonatomic, nullable) GMSIndoorLevel *activeLevel; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSIndoorLevel.h b/HackIllinois/GoogleMaps.framework/Headers/GMSIndoorLevel.h new file mode 100755 index 00000000..b92efc6f --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSIndoorLevel.h @@ -0,0 +1,32 @@ +// +// GMSIndoorLevel.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// +#import + +NS_ASSUME_NONNULL_BEGIN + +/** + * Describes a single level in a building. + * + * Multiple buildings can share a level - in this case the level instances will compare as equal, + * even though the level numbers/names may be different. + */ +@interface GMSIndoorLevel : NSObject + +- (instancetype)init NS_UNAVAILABLE; + +/** Localized display name for the level, e.g. "Ground floor". */ +@property(nonatomic, copy, readonly, nullable) NSString *name; + +/** Localized short display name for the level, e.g. "1". */ +@property(nonatomic, copy, readonly, nullable) NSString *shortName; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSMapID.h b/HackIllinois/GoogleMaps.framework/Headers/GMSMapID.h new file mode 100755 index 00000000..c9541c75 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSMapID.h @@ -0,0 +1,29 @@ +// +// GMSMapID.h +// Google Maps SDK for iOS +// +// Copyright 2019 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +NS_ASSUME_NONNULL_BEGIN + +/** An opaque identifier for a custom map configuration. */ +@interface GMSMapID : NSObject + +- (instancetype)init NS_UNAVAILABLE; + +/** Creates a new mapID with the given string value. */ +- (instancetype)initWithIdentifier:(NSString *)identifier NS_DESIGNATED_INITIALIZER; + +/** Creates a new mapID with the given string value. */ ++ (instancetype)mapIDWithIdentifier:(NSString *)identifier + NS_SWIFT_UNAVAILABLE("Use initializer instead"); + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSMapLayer.h b/HackIllinois/GoogleMaps.framework/Headers/GMSMapLayer.h new file mode 100755 index 00000000..f5ed5eda --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSMapLayer.h @@ -0,0 +1,111 @@ +// +// GMSMapLayer.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import +#import + +#import "GMSCALayer.h" + +NS_ASSUME_NONNULL_BEGIN + +/* + * The following layer properties and constants describe the camera properties that may be animated + * on the custom model layer of a GMSMapView with Core Animation. For simple camera control and + * animation, please see the helper methods in GMSMapView+Animation.h, and the camera object + * definition within GMSCameraPosition.h. + * + * Changing layer properties triggers an implicit animation, e.g.:- + * mapView_.layer.cameraBearing = 20; + * + * An explicit animation, replacing the implicit animation, may be added after changing the + * property, for example: + *
+ *   CAMediaTimingFunction *curve = [CAMediaTimingFunction functionWithName:
+ *                                   kCAMediaTimingFunctionEaseInEaseOut];
+ *   CABasicAnimation *animation =
+ *       [CABasicAnimation animationWithKeyPath:kGMSLayerCameraBearingKey];
+ *   animation.duration = 2.0f;
+ *   animation.timingFunction = curve;
+ *   animation.toValue = @20;
+ *   [mapView_.layer addAnimation:animation forKey:kGMSLayerCameraBearingKey];
+ * 
+ * + * To control several implicit animations, Core Animation's transaction support may be used, for + * example: + *
+ *   [CATransaction begin];
+ *   [CATransaction setAnimationDuration:2.0f];
+ *   mapView_.layer.cameraBearing = 20;
+ *   mapView_.layer.cameraViewingAngle = 30;
+ *   [CATransaction commit];
+ * 
+ * + * Note that these properties are not view-based. Please see "Animating View and Layer Changes + * Together" in the + * View Programming Guide for iOS. + */ + +/** + * kGMSLayerCameraLatitudeKey ranges from [-85, 85], and values outside this range will be clamped. + * + * @related GMSMapLayer + */ +extern NSString *const kGMSLayerCameraLatitudeKey; + +/** + * kGMSLayerCameraLongitudeKey ranges from [-180, 180), and values outside this range will be + * wrapped to within this range. + * + * @related GMSMapLayer + */ +extern NSString *const kGMSLayerCameraLongitudeKey; + +/** + * kGMSLayerCameraBearingKey ranges from [0, 360), and values are wrapped. + * + * @related GMSMapLayer + */ +extern NSString *const kGMSLayerCameraBearingKey; + +/** + * kGMSLayerCameraZoomLevelKey ranges from [kGMSMinZoomLevel, kGMSMaxZoomLevel], and values are + * clamped. + * + * @related GMSMapLayer + */ +extern NSString *const kGMSLayerCameraZoomLevelKey; + +/** + * kGMSLayerCameraViewingAngleKey ranges from zero (i.e., facing straight down) and to between 30 + * and 45 degrees towards the horizon, depending on the model zoom level. + * + * @related GMSMapLayer + */ +extern NSString *const kGMSLayerCameraViewingAngleKey; + +/** + * GMSMapLayer is a custom subclass of CALayer, provided as the layer class on GMSMapView. This + * layer should not be instantiated directly. It provides model access to the camera normally + * defined on GMSMapView. + * + * Modifying or animating these properties will typically interrupt any current gesture on + * GMSMapView, e.g., a user's pan or rotation. Similarly, if a user performs an enabled gesture + * during an animation, the animation will stop 'in-place' (at the current presentation value). + */ +@interface GMSMapLayer : GMSCALayer +@property(nonatomic) CLLocationDegrees cameraLatitude; +@property(nonatomic) CLLocationDegrees cameraLongitude; +@property(nonatomic) CLLocationDirection cameraBearing; +@property(nonatomic) float cameraZoomLevel; +@property(nonatomic) double cameraViewingAngle; +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSMapStyle.h b/HackIllinois/GoogleMaps.framework/Headers/GMSMapStyle.h new file mode 100755 index 00000000..6c1e4b7e --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSMapStyle.h @@ -0,0 +1,55 @@ +// +// GMSMapStyle.h +// Google Maps SDK for iOS +// +// Copyright 2016 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +NS_ASSUME_NONNULL_BEGIN + +/** + * GMSMapStyle holds details about a style which can be applied to a map. + * + * With style options you can customize the presentation of the standard Google map styles, changing + * the visual display of features like roads, parks, and other points of interest. As well as + * changing the style of these features, you can also hide features entirely. This means that you + * can emphasize particular components of the map or make the map complement the content of your + * app. + * + * For more information see: https://developers.google.com/maps/documentation/ios-sdk/styling + */ +@interface GMSMapStyle : NSObject + +/** + * Creates a style using a string containing JSON. + * + * Returns nil and populates |error| (if provided) if |style| is invalid. + */ ++ (nullable instancetype)styleWithJSONString:(NSString *)style + error:(NSError *__autoreleasing _Nullable *)error; + +/** + * Creates a style using a file containing JSON. + * + * Returns nil and populates |error| (if provided) if |style| is invalid, the file cannot be read, + * or the URL is not a file URL. + */ ++ (nullable instancetype)styleWithContentsOfFileURL:(NSURL *)fileURL + error:(NSError *__autoreleasing _Nullable *)error; + +@end + +/** + * Calculates a hash value for the given string. + * @param string The string to use to calculate the hash value. + * @return The hash value. + * @note The current implementation uses an MD5 hash, which is sufficient for uniquifying styles. + */ +NSUInteger GMSStyleHashForString(NSString *string); + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSMapView+Animation.h b/HackIllinois/GoogleMaps.framework/Headers/GMSMapView+Animation.h new file mode 100755 index 00000000..41e5ff00 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSMapView+Animation.h @@ -0,0 +1,61 @@ +// +// GMSMapView+Animation.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import "GMSMapView.h" + +NS_ASSUME_NONNULL_BEGIN + +/** + * GMSMapView (Animation) offers several animation helper methods. + * + * During any animation, retrieving the camera position through the camera property on GMSMapView + * returns an intermediate immutable GMSCameraPosition. This camera position will typically + * represent the most recently drawn frame. + */ +@interface GMSMapView (Animation) + +/** Animates the camera of this map to |cameraPosition|. */ +- (void)animateToCameraPosition:(GMSCameraPosition *)cameraPosition; + +/** + * As animateToCameraPosition:, but changes only the location of the camera (i.e., from the current + * location to |location|). + */ +- (void)animateToLocation:(CLLocationCoordinate2D)location; + +/** + * As animateToCameraPosition:, but changes only the zoom level of the camera. + * + * This value is clamped by [kGMSMinZoomLevel, kGMSMaxZoomLevel]. + */ +- (void)animateToZoom:(float)zoom; + +/** + * As animateToCameraPosition:, but changes only the bearing of the camera (in degrees). Zero + * indicates true north. + */ +- (void)animateToBearing:(CLLocationDirection)bearing; + +/** + * As animateToCameraPosition:, but changes only the viewing angle of the camera (in degrees). This + * value will be clamped to a minimum of zero (i.e., facing straight down) and between 30 and 45 + * degrees towards the horizon, depending on the relative closeness to the earth. + */ +- (void)animateToViewingAngle:(double)viewingAngle; + +/** + * Applies |cameraUpdate| to the current camera, and then uses the result as per + * animateToCameraPosition:. + */ +- (void)animateWithCameraUpdate:(GMSCameraUpdate *)cameraUpdate; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSMapView.h b/HackIllinois/GoogleMaps.framework/Headers/GMSMapView.h new file mode 100755 index 00000000..e9fb90e3 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSMapView.h @@ -0,0 +1,521 @@ +// +// GMSMapView.h +// Google Maps SDK for iOS +// +// Copyright 2012 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import +#import + +#if __has_feature(modules) +@import GoogleMapsBase; +#else +#import +#endif +#if __has_feature(modules) +@import GoogleMapsBase; +#else +#import +#endif +#import "GMSMapLayer.h" + +@class GMSCameraPosition; +@class GMSCameraUpdate; +@class GMSCoordinateBounds; +@class GMSIndoorDisplay; +@class GMSMapID; +@class GMSMapStyle; +@class GMSMapView; +@class GMSMarker; +@class GMSOverlay; +@class GMSProjection; +@class GMSUISettings; + +NS_ASSUME_NONNULL_BEGIN + +/** Delegate for events on GMSMapView. */ +@protocol GMSMapViewDelegate + +@optional + +/** + * Called before the camera on the map changes, either due to a gesture, animation (e.g., by a user + * tapping on the "My Location" button) or by being updated explicitly via the camera or a + * zero-length animation on layer. + * + * @param mapView The map view that was tapped. + * @param gesture If YES, this is occurring due to a user gesture. + */ +- (void)mapView:(GMSMapView *)mapView willMove:(BOOL)gesture; + +/** + * Called repeatedly during any animations or gestures on the map (or once, if the camera is + * explicitly set). This may not be called for all intermediate camera positions. It is always + * called for the final position of an animation or gesture. + */ +- (void)mapView:(GMSMapView *)mapView didChangeCameraPosition:(GMSCameraPosition *)position; + +/** + * Called when the map becomes idle, after any outstanding gestures or animations have completed (or + * after the camera has been explicitly set). + */ +- (void)mapView:(GMSMapView *)mapView idleAtCameraPosition:(GMSCameraPosition *)position; + +/** + * Called after a tap gesture at a particular coordinate, but only if a marker was not tapped. This + * is called before deselecting any currently selected marker (the implicit action for tapping on + * the map). + */ +- (void)mapView:(GMSMapView *)mapView didTapAtCoordinate:(CLLocationCoordinate2D)coordinate; + +/** + * Called after a long-press gesture at a particular coordinate. + * + * @param mapView The map view that was tapped. + * @param coordinate The location that was tapped. + */ +- (void)mapView:(GMSMapView *)mapView didLongPressAtCoordinate:(CLLocationCoordinate2D)coordinate; + +/** + * Called after a marker has been tapped. + * + * @param mapView The map view that was tapped. + * @param marker The marker that was tapped. + * @return YES if this delegate handled the tap event, which prevents the map from performing its + * default selection behavior, and NO if the map should continue with its default selection + * behavior. + */ +- (BOOL)mapView:(GMSMapView *)mapView didTapMarker:(GMSMarker *)marker; + +/** + * Called after a marker's info window has been tapped. + */ +- (void)mapView:(GMSMapView *)mapView didTapInfoWindowOfMarker:(GMSMarker *)marker; + +/** + * Called after a marker's info window has been long pressed. + */ +- (void)mapView:(GMSMapView *)mapView didLongPressInfoWindowOfMarker:(GMSMarker *)marker; + +/** + * Called after an overlay has been tapped. + * + * This method is not called for taps on markers. + * + * @param mapView The map view that was tapped. + * @param overlay The overlay that was tapped. + */ +- (void)mapView:(GMSMapView *)mapView didTapOverlay:(GMSOverlay *)overlay; + +/** + * Called after a POI has been tapped. + * + * @param mapView The map view that was tapped. + * @param placeID The placeID of the POI that was tapped. + * @param name The name of the POI that was tapped. + * @param location The location of the POI that was tapped. + */ +- (void)mapView:(GMSMapView *)mapView + didTapPOIWithPlaceID:(NSString *)placeID + name:(NSString *)name + location:(CLLocationCoordinate2D)location; + +/** + * Called when a marker is about to become selected, and provides an optional custom info window to + * use for that marker if this method returns a UIView. + * + * If you change this view after this method is called, those changes will not necessarily be + * reflected in the rendered version. + * + * The returned UIView must not have bounds greater than 500 points on either dimension. As there + * is only one info window shown at any time, the returned view may be reused between other info + * windows. + * + * Removing the marker from the map or changing the map's selected marker during this call results + * in undefined behavior. + * + * @return The custom info window for the specified marker, or nil for default + */ +- (nullable UIView *)mapView:(GMSMapView *)mapView markerInfoWindow:(GMSMarker *)marker; + +/** + * Called when mapView:markerInfoWindow: returns nil. If this method returns a view, it will be + * placed within the default info window frame. If this method returns nil, then the default + * rendering will be used instead. + * + * @param mapView The map view that was pressed. + * @param marker The marker that was pressed. + * @return The custom view to display as contents in the info window, or nil to use the default + * content rendering instead + */ + +- (nullable UIView *)mapView:(GMSMapView *)mapView markerInfoContents:(GMSMarker *)marker; + +/** + * Called when the marker's info window is closed. + */ +- (void)mapView:(GMSMapView *)mapView didCloseInfoWindowOfMarker:(GMSMarker *)marker; + +/** + * Called when dragging has been initiated on a marker. + */ +- (void)mapView:(GMSMapView *)mapView didBeginDraggingMarker:(GMSMarker *)marker; + +/** + * Called after dragging of a marker ended. + */ +- (void)mapView:(GMSMapView *)mapView didEndDraggingMarker:(GMSMarker *)marker; + +/** + * Called while a marker is dragged. + */ +- (void)mapView:(GMSMapView *)mapView didDragMarker:(GMSMarker *)marker; + +/** + * Called when the My Location button is tapped. + * + * @return YES if the listener has consumed the event (i.e., the default behavior should not occur), + * NO otherwise (i.e., the default behavior should occur). The default behavior is for the + * camera to move such that it is centered on the user location. + */ +- (BOOL)didTapMyLocationButtonForMapView:(GMSMapView *)mapView; + +/** + * Called when the My Location Dot is tapped. + * + * @param mapView The map view that was tapped. + * @param location The location of the user when the location dot was tapped. + */ +- (void)mapView:(GMSMapView *)mapView didTapMyLocation:(CLLocationCoordinate2D)location; + +/** + * Called when tiles have just been requested or labels have just started rendering. + */ +- (void)mapViewDidStartTileRendering:(GMSMapView *)mapView; + +/** + * Called when all tiles have been loaded (or failed permanently) and labels have been rendered. + */ +- (void)mapViewDidFinishTileRendering:(GMSMapView *)mapView; + +/** + * Called when map is stable (tiles loaded, labels rendered, camera idle) and overlay objects have + * been rendered. + */ +- (void)mapViewSnapshotReady:(GMSMapView *)mapView; + +@end + +/** + * \defgroup MapViewType GMSMapViewType + * @{ + */ + +/** + * Display types for GMSMapView. + */ +typedef NS_ENUM(NSUInteger, GMSMapViewType) { + /** Basic maps. The default. */ + kGMSTypeNormal GMS_SWIFT_NAME_2_0_3_0(Normal, normal) = 1, + + /** Satellite maps with no labels. */ + kGMSTypeSatellite GMS_SWIFT_NAME_2_0_3_0(Satellite, satellite), + + /** Terrain maps. */ + kGMSTypeTerrain GMS_SWIFT_NAME_2_0_3_0(Terrain, terrain), + + /** Satellite maps with a transparent label overview. */ + kGMSTypeHybrid GMS_SWIFT_NAME_2_0_3_0(Hybrid, hybrid), + + /** No maps, no labels. Display of traffic data is not supported. */ + kGMSTypeNone GMS_SWIFT_NAME_2_0_3_0(None, none), + +}; + +/**@}*/ + +/** + * \defgroup FrameRate GMSFrameRate + * @{ + */ + +/** + * Rendering frame rates for GMSMapView. + */ +typedef NS_ENUM(NSUInteger, GMSFrameRate) { + /** Use the minimum frame rate to conserve battery usage. */ + kGMSFrameRatePowerSave, + + /** + * Use a median frame rate to provide smoother rendering and conserve processing cycles. + */ + kGMSFrameRateConservative, + + /** + * Use the maximum frame rate for a device. For low end devices this will be 30 FPS, + * for high end devices 60 FPS. + */ + kGMSFrameRateMaximum, +}; + +/**@}*/ + +/** + * \defgroup MapViewPaddingAdjustmentBehavior GMSMapViewPaddingAdjustmentBehavior + * @{ + */ + +/** + * Constants indicating how safe area insets are added to padding. + */ +typedef NS_ENUM(NSUInteger, GMSMapViewPaddingAdjustmentBehavior) { + /** Always include the safe area insets in the padding. */ + kGMSMapViewPaddingAdjustmentBehaviorAlways, + + /** + * When the padding value is smaller than the safe area inset for a particular edge, use the safe + * area value for layout, else use padding. + */ + kGMSMapViewPaddingAdjustmentBehaviorAutomatic, + + /** + * Never include the safe area insets in the padding. This was the behavior prior to version 2.5. + */ + kGMSMapViewPaddingAdjustmentBehaviorNever, +}; + +/**@}*/ + +/** + * This is the main class of the Google Maps SDK for iOS and is the entry point for all methods + * related to the map. + * + * The map should be instantiated via the convenience constructor [GMSMapView mapWithFrame:camera:]. + * It may also be created with the default [[GMSMapView alloc] initWithFrame:] method (wherein its + * camera will be set to a default location). + * + * GMSMapView can only be read and modified from the main thread, similar to all UIKit objects. + * Calling these methods from another thread will result in an exception or undefined behavior. + */ +@interface GMSMapView : UIView + +/** GMSMapView delegate. */ +@property(nonatomic, weak, nullable) IBOutlet id delegate; + +/** + * Controls the camera, which defines how the map is oriented. Modification of this property is + * instantaneous. + */ +@property(nonatomic, copy) GMSCameraPosition *camera; + +/** + * Returns a GMSProjection object that you can use to convert between screen coordinates and + * latitude/longitude coordinates. + * + * This is a snapshot of the current projection, and will not automatically update when the camera + * moves. It represents either the projection of the last drawn GMSMapView frame, or; where the + * camera has been explicitly set or the map just created, the upcoming frame. It will never be nil. + */ +@property(nonatomic, readonly) GMSProjection *projection; + +/** + * Controls whether the My Location dot and accuracy circle is enabled. Defaults to NO. + */ +@property(nonatomic, getter=isMyLocationEnabled) BOOL myLocationEnabled; + +/** + * If My Location is enabled, reveals where the user location dot is being drawn. If it is disabled, + * or it is enabled but no location data is available, this will be nil. This property is + * observable using KVO. + */ +@property(nonatomic, readonly, nullable) CLLocation *myLocation; + +/** + * The marker that is selected. Setting this property selects a particular marker, showing an info + * window on it. If this property is non-nil, setting it to nil deselects the marker, hiding the + * info window. This property is observable using KVO. + */ +@property(nonatomic, nullable) GMSMarker *selectedMarker; + +/** + * Controls whether the map is drawing traffic data, if available. This is subject to the + * availability of traffic data. Defaults to NO. + */ +@property(nonatomic, getter=isTrafficEnabled) BOOL trafficEnabled; + +/** + * Controls the type of map tiles that should be displayed. Defaults to kGMSTypeNormal. + */ +@property(nonatomic) GMSMapViewType mapType; + +/** + * Controls the style of the map. + * + * A non-nil mapStyle will only apply if mapType is Normal. + */ +@property(nonatomic, nullable) GMSMapStyle *mapStyle; + +/** + * Minimum zoom (the farthest the camera may be zoomed out). Defaults to kGMSMinZoomLevel. Modified + * with -setMinZoom:maxZoom:. + */ +@property(nonatomic, readonly) float minZoom; + +/** + * Maximum zoom (the closest the camera may be to the Earth). Defaults to kGMSMaxZoomLevel. Modified + * with -setMinZoom:maxZoom:. + */ +@property(nonatomic, readonly) float maxZoom; + +/** + * If set, 3D buildings will be shown where available. Defaults to YES. + * + * This may be useful when adding a custom tile layer to the map, in order to make it clearer at + * high zoom levels. Changing this value will cause all tiles to be briefly invalidated. + */ +@property(nonatomic, getter=isBuildingsEnabled) BOOL buildingsEnabled; + +/** + * Sets whether indoor maps are shown, where available. Defaults to YES. + * + * If this is set to NO, caches for indoor data may be purged and any floor currently selected by + * the end-user may be reset. + */ +@property(nonatomic, getter=isIndoorEnabled) BOOL indoorEnabled; + +/** + * Gets the GMSIndoorDisplay instance which allows to observe or control aspects of indoor data + * display. + */ +@property(nonatomic, readonly) GMSIndoorDisplay *indoorDisplay; + +/** + * Gets the GMSUISettings object, which controls user interface settings for the map. + */ +@property(nonatomic, readonly) GMSUISettings *settings; + +/** + * Controls the 'visible' region of the view. By applying padding an area around the edge of the + * view can be created which will contain map data but will not contain UI controls. + * + * If the padding is not balanced, the visual center of the view will move as appropriate. Padding + * will also affect the |projection| property so the visible region will not include the padding + * area. GMSCameraUpdate fitToBounds will ensure that both this padding and any padding requested + * will be taken into account. + * + * This property may be animated within a UIView-based animation block. + */ +@property(nonatomic) UIEdgeInsets padding; + +/** + * Controls how safe area insets are added to the padding values. Like padding, safe area insets + * position map controls such as the compass, my location button and floor picker within the device + * safe area. + * + * Defaults to kGMSMapViewPaddingAdjustmentBehaviorAlways. + */ +@property(nonatomic) GMSMapViewPaddingAdjustmentBehavior paddingAdjustmentBehavior; + +/** + * Defaults to YES. If set to NO, GMSMapView will generate accessibility elements for overlay + * objects, such as GMSMarker and GMSPolyline. + * + * This property is as per the informal UIAcessibility protocol, except for the default value of + * YES. + */ +@property(nonatomic) BOOL accessibilityElementsHidden; + +/** + * Accessor for the custom CALayer type used for the layer. + */ +@property(nonatomic, readonly, retain) GMSMapLayer *layer; + +/** + * Controls the rendering frame rate. Default value is kGMSFrameRateMaximum. + */ +@property(nonatomic) GMSFrameRate preferredFrameRate; + +/** + * If not nil, constrains the camera target so that gestures cannot cause it to leave the specified + * bounds. + */ +@property(nonatomic, nullable) GMSCoordinateBounds *cameraTargetBounds; + +/** + * Builds and returns a map view with a frame and camera target. + */ ++ (instancetype)mapWithFrame:(CGRect)frame camera:(GMSCameraPosition *)camera; + +/** + * Convenience initializer to build and return a map view with a frame, map ID, and camera target. + */ ++ (instancetype)mapWithFrame:(CGRect)frame + mapID:(GMSMapID *)mapID + camera:(GMSCameraPosition *)camera + NS_SWIFT_UNAVAILABLE("Use initializer instead"); + +/** + * Builds and returns a map view, with a frame and camera target. + */ +- (instancetype)initWithFrame:(CGRect)frame camera:(GMSCameraPosition *)camera; + +/** + * Builds and returns a map view with a frame, map ID, and camera target. + */ +- (instancetype)initWithFrame:(CGRect)frame + mapID:(GMSMapID *)mapID + camera:(GMSCameraPosition *)camera; + +/** + * Tells this map to power up its renderer. This is optional and idempotent. + */ +- (void)startRendering __GMS_AVAILABLE_BUT_DEPRECATED_MSG( + "This method is obsolete and will be removed in a future release."); + +/** + * Tells this map to power down its renderer. This is optional and idempotent. + */ +- (void)stopRendering __GMS_AVAILABLE_BUT_DEPRECATED_MSG( + "This method is obsolete and will be removed in a future release."); + +/** + * Clears all markup that has been added to the map, including markers, polylines and ground + * overlays. This will not clear the visible location dot or reset the current mapType. + */ +- (void)clear; + +/** + * Sets |minZoom| and |maxZoom|. This method expects the minimum to be less than or equal to the + * maximum, and will throw an exception with name NSRangeException otherwise. + */ +- (void)setMinZoom:(float)minZoom maxZoom:(float)maxZoom; + +/** + * Build a GMSCameraPosition that presents |bounds| with |padding|. The camera will have a zero + * bearing and tilt (i.e., facing north and looking directly at the Earth). This takes the frame and + * padding of this GMSMapView into account. + * + * If the bounds is invalid this method will return a nil camera. + */ +- (nullable GMSCameraPosition *)cameraForBounds:(GMSCoordinateBounds *)bounds + insets:(UIEdgeInsets)insets; + +/** + * Changes the camera according to |update|. The camera change is instantaneous (with no animation). + */ +- (void)moveCamera:(GMSCameraUpdate *)update; + +/** + * Check whether the given camera positions would practically cause the camera to be rendered the + * same, taking into account the level of precision and transformations used internally. + */ +- (BOOL)areEqualForRenderingPosition:(GMSCameraPosition *)position + position:(GMSCameraPosition *)otherPosition; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSMarker.h b/HackIllinois/GoogleMaps.framework/Headers/GMSMarker.h new file mode 100755 index 00000000..ea283c7d --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSMarker.h @@ -0,0 +1,161 @@ +// +// GMSMarker.h +// Google Maps SDK for iOS +// +// Copyright 2012 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +#import "GMSMarkerAnimation.h" +#import "GMSOverlay.h" + +@class GMSMarkerLayer; +@class GMSPanoramaView; + +NS_ASSUME_NONNULL_BEGIN + +/** + * A marker is an icon placed at a particular point on the map's surface. A marker's icon is drawn + * oriented against the device's screen rather than the map's surface; i.e., it will not necessarily + * change orientation due to map rotations, tilting, or zooming. + */ +@interface GMSMarker : GMSOverlay + +/** Marker position. Animated. */ +@property(nonatomic) CLLocationCoordinate2D position; + +/** Snippet text, shown beneath the title in the info window when selected. */ +@property(nonatomic, copy, nullable) NSString *snippet; + +/** + * Marker icon to render. If left nil, uses a default SDK place marker. + * + * Supports animated images, but each frame must be the same size or the behavior is undefined. + * + * Supports the use of alignmentRectInsets to specify a reduced tap area. This also redefines how + * anchors are specified. For an animated image the value for the animation is used, not the + * individual frames. + */ +@property(nonatomic, nullable) UIImage *icon; + +/** + * Marker view to render. If left nil, falls back to the |icon| property instead. + * + * Supports animation of all animatable properties of UIView, except |frame| and |center|. Changing + * these properties or their corresponding CALayer version, including |position|, is not supported. + * + * Note that the view behaves as if |clipsToBounds| is set to YES, regardless of its actual value. + */ +@property(nonatomic, nullable) UIView *iconView; + +/** + * Controls whether the icon for this marker should be redrawn every frame. + * + * Note that when this changes from NO to YES, the icon is guaranteed to be redrawn next frame. + * + * Defaults to YES. + * Has no effect if |iconView| is nil. + */ +@property(nonatomic) BOOL tracksViewChanges; + +/** + * Controls whether the info window for this marker should be redrawn every frame. + * + * Note that when this changes from NO to YES, the info window is guaranteed to be redrawn next + * frame. + * + * Defaults to NO. + */ +@property(nonatomic) BOOL tracksInfoWindowChanges; + +/** + * The ground anchor specifies the point in the icon image that is anchored to the marker's position + * on the Earth's surface. This point is specified within the continuous space [0.0, 1.0] x [0.0, + * 1.0], where (0,0) is the top-left corner of the image, and (1,1) is the bottom-right corner. + * + * If the image has non-zero alignmentRectInsets, the top-left and bottom-right mentioned above + * refer to the inset section of the image. + */ +@property(nonatomic) CGPoint groundAnchor; + +/** + * The info window anchor specifies the point in the icon image at which to anchor the info window, + * which will be displayed directly above this point. This point is specified within the same space + * as groundAnchor. + */ +@property(nonatomic) CGPoint infoWindowAnchor; + +/** + * Controls the animation used when this marker is placed on a GMSMapView (default + * kGMSMarkerAnimationNone, no animation). + */ +@property(nonatomic) GMSMarkerAnimation appearAnimation; + +/** + * Controls whether this marker can be dragged interactively (default NO). + */ +@property(nonatomic, getter=isDraggable) BOOL draggable; + +/** + * Controls whether this marker should be flat against the Earth's surface (YES) or a billboard + * facing the camera (NO, default). + */ +@property(nonatomic, getter=isFlat) BOOL flat; + +/** + * Sets the rotation of the marker in degrees clockwise about the marker's anchor point. The axis of + * rotation is perpendicular to the marker. A rotation of 0 corresponds to the default position of + * the marker. Animated. + * + * When the marker is flat on the map, the default position is north aligned and the rotation is + * such that the marker always remains flat on the map. When the marker is a billboard, the default + * position is pointing up and the rotation is such that the marker is always facing the camera. + */ +@property(nonatomic) CLLocationDegrees rotation; + +/** + * Sets the opacity of the marker, between 0 (completely transparent) and 1 (default) inclusive. + */ +@property(nonatomic) float opacity; + +/** + * Provides the Core Animation layer for this GMSMarker. + */ +@property(nonatomic, readonly) GMSMarkerLayer *layer; + +/** + * The |panoramaView| specifies which panorama view will attempt to show this marker. Note that if + * the marker's |position| is too far away from the |panoramaView|'s current panorama location, it + * will not be displayed as it will be too small. + * + * Can be set to nil to remove the marker from any current panorama view it is attached to. + * + * A marker can be shown on both a panorama and a map at the same time. + */ +@property(nonatomic, weak, nullable) GMSPanoramaView *panoramaView; + +/** Convenience constructor for a default marker. */ ++ (instancetype)markerWithPosition:(CLLocationCoordinate2D)position; + +/** Creates a tinted version of the default marker image for use as an icon. */ ++ (UIImage *)markerImageWithColor:(nullable UIColor *)color; + +@end + +/** + * The default position of the ground anchor of a GMSMarker: the center bottom point of the marker + * icon. + */ +FOUNDATION_EXTERN const CGPoint kGMSMarkerDefaultGroundAnchor; + +/** + * The default position of the info window anchor of a GMSMarker: the center top point of the marker + * icon. + */ +FOUNDATION_EXTERN const CGPoint kGMSMarkerDefaultInfoWindowAnchor; + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSMarkerAnimation.h b/HackIllinois/GoogleMaps.framework/Headers/GMSMarkerAnimation.h new file mode 100755 index 00000000..a0dab0f3 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSMarkerAnimation.h @@ -0,0 +1,36 @@ +// +// GMSMarkerAnimation.h +// Google Maps SDK for iOS +// +// Copyright 2021 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +NS_ASSUME_NONNULL_BEGIN + +/** + * \defgroup MarkerAnimation GMSMarkerAnimation + * @{ + */ + +/** + * Animation types for GMSMarker. + */ +typedef NS_ENUM(NSUInteger, GMSMarkerAnimation) { + /** No animation (default). */ + kGMSMarkerAnimationNone = 0, + + /** The marker will pop from its groundAnchor when added. */ + kGMSMarkerAnimationPop, + + /** The marker will fade in when added. */ + kGMSMarkerAnimationFadeIn, +}; + +/**@}*/ + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSMarkerLayer.h b/HackIllinois/GoogleMaps.framework/Headers/GMSMarkerLayer.h new file mode 100755 index 00000000..05389551 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSMarkerLayer.h @@ -0,0 +1,47 @@ +// +// GMSMarkerLayer.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import +#import + +#import "GMSOverlayLayer.h" + +NS_ASSUME_NONNULL_BEGIN + +/** + * GMSMarkerLayer is a subclass of GMSOverlayLayer, available on a per-marker basis, that allows + * animation of several properties of its associated GMSMarker. + * + * Note that this CALayer is never actually rendered directly, as GMSMapView is provided entirely + * via an OpenGL layer. As such, adjustments or animations to 'default' properties of CALayer will + * not have any effect. + */ +@interface GMSMarkerLayer : GMSOverlayLayer + +/** Latitude, part of |position| on GMSMarker. */ +@property(nonatomic) CLLocationDegrees latitude; + +/** Longitude, part of |position| on GMSMarker. */ +@property(nonatomic) CLLocationDegrees longitude; + +/** Rotation, as per GMSMarker. */ +@property(nonatomic) CLLocationDegrees rotation; + +/** Opacity, as per GMSMarker. */ +@property(atomic) float opacity; + +@end + +extern NSString *const kGMSMarkerLayerLatitude; +extern NSString *const kGMSMarkerLayerLongitude; +extern NSString *const kGMSMarkerLayerRotation; +extern NSString *const kGMSMarkerLayerOpacity; + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSMutablePath.h b/HackIllinois/GoogleMaps.framework/Headers/GMSMutablePath.h new file mode 100755 index 00000000..d3092de9 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSMutablePath.h @@ -0,0 +1,59 @@ +// +// GMSMutablePath.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import +#import + +#import "GMSPath.h" + +/** + * GMSMutablePath is a dynamic (resizable) array of CLLocationCoordinate2D. All coordinates must be + * valid. GMSMutablePath is the mutable counterpart to the immutable GMSPath. + */ +@interface GMSMutablePath : GMSPath + +/** Adds |coord| at the end of the path. */ +- (void)addCoordinate:(CLLocationCoordinate2D)coord; + +/** Adds a new CLLocationCoordinate2D instance with the given lat/lng. */ +- (void)addLatitude:(CLLocationDegrees)latitude longitude:(CLLocationDegrees)longitude; + +/** + * Inserts |coord| at |index|. + * + * If this is smaller than the size of the path, shifts all coordinates forward by one. Otherwise, + * behaves as replaceCoordinateAtIndex:withCoordinate:. + */ +- (void)insertCoordinate:(CLLocationCoordinate2D)coord atIndex:(NSUInteger)index; + +/** + * Replace the coordinate at |index| with |coord|. If |index| is after the end, grows the array with + * an undefined coordinate. + */ +- (void)replaceCoordinateAtIndex:(NSUInteger)index withCoordinate:(CLLocationCoordinate2D)coord; + +/** + * Remove entry at |index|. + * + * If |index| < count decrements size. If |index| >= count this is a silent no-op. + */ +- (void)removeCoordinateAtIndex:(NSUInteger)index; + +/** + * Removes the last coordinate of the path. + * + * If the array is non-empty decrements size. If the array is empty, this is a silent no-op. + */ +- (void)removeLastCoordinate; + +/** Removes all coordinates in this path. */ +- (void)removeAllCoordinates; + +@end diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSOrientation.h b/HackIllinois/GoogleMaps.framework/Headers/GMSOrientation.h new file mode 100755 index 00000000..9a3ce3df --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSOrientation.h @@ -0,0 +1,50 @@ +// +// GMSOrientation.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +/** + * GMSOrientation is a tuple of heading and pitch used to control the viewing + * direction of a GMSPanoramaCamera. + */ +typedef struct { + /** + * The camera heading (horizontal angle) in degrees. Type used to represent + * the direction in degrees from 0 to 359.9. True north is 0, east is 90, + * south is 180, and west is 270. + */ + const CLLocationDirection heading; + + /** + * The camera pitch (vertical angle), in degrees from the horizon. The |pitch| + * range is [-90,90], although it is possible that not the full range is + * supported. A positive value looks up and a negative value looks down. + */ + const double pitch; +} GMSOrientation; + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * Returns a GMSOrientation with the given |heading| and |pitch|. + * + * @related GMSOrientation + */ +inline static GMSOrientation GMSOrientationMake(CLLocationDirection heading, + double pitch) { + GMSOrientation orientation = {heading, pitch}; + return orientation; +} + +#ifdef __cplusplus +} +#endif diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSOverlay.h b/HackIllinois/GoogleMaps.framework/Headers/GMSOverlay.h new file mode 100755 index 00000000..52e7d8d2 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSOverlay.h @@ -0,0 +1,66 @@ +// +// GMSOverlay.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +@class GMSMapView; + +NS_ASSUME_NONNULL_BEGIN + +/** + * GMSOverlay is an abstract class that represents some overlay that may be attached to a specific + * GMSMapView. It may not be instantiated directly; instead, instances of concrete overlay types + * should be created directly (such as GMSMarker, GMSPolyline, and GMSPolygon). + * + * This supports the NSCopying protocol; [overlay_ copy] will return a copy of the overlay type, but + * with |map| set to nil. + */ +@interface GMSOverlay : NSObject + +/** + * Title, a short description of the overlay. Some overlays, such as markers, will display the title + * on the map. The title is also the default accessibility text. + */ +@property(nonatomic, copy, nullable) NSString *title; + +/** + * The map this overlay is on. Setting this property will add the overlay to the map. Setting it to + * nil removes this overlay from the map. An overlay may be active on at most one map at any given + * time. + */ +@property(nonatomic, weak, nullable) GMSMapView *map; + +/** + * If this overlay should cause tap notifications. Some overlays, such as markers, will default to + * being tappable. + */ +@property(nonatomic, getter=isTappable) BOOL tappable; + +/** + * Higher |zIndex| value overlays will be drawn on top of lower |zIndex| value tile layers and + * overlays. Equal values result in undefined draw ordering. Markers are an exception that + * regardless of |zIndex|, they will always be drawn above tile layers and other non-marker + * overlays; they are effectively considered to be in a separate z-index group compared to other + * overlays. + */ +@property(nonatomic) int zIndex; + +/** + * Overlay data. You can use this property to associate an arbitrary object with this overlay. + * Google Maps SDK for iOS neither reads nor writes this property. + * + * Note that userData should not hold any strong references to any Maps objects, otherwise a retain + * cycle may be created (preventing objects from being released). + */ +@property(nonatomic, nullable) id userData; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSOverlayLayer.h b/HackIllinois/GoogleMaps.framework/Headers/GMSOverlayLayer.h new file mode 100755 index 00000000..b0b8cf23 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSOverlayLayer.h @@ -0,0 +1,30 @@ +// +// GMSOverlayLayer.h +// Google Maps SDK for iOS +// +// Copyright 2018 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import +#import + +NS_ASSUME_NONNULL_BEGIN + +/** + * GMSOverlayLayer is a custom subclass of CALayer, and an abstract baseclass for GMSOverlay layers + * that allow custom animations. + * + * Note that this CALayer or any subclass are never actually rendered directly, as GMSMapView is + * provided entirely via an OpenGL layer. As such, adjustments or animations to 'default' properties + * of CALayer will not have any effect. + * + * This is an implementation detail and it should not be instantiated directly. + */ +@interface GMSOverlayLayer : CALayer + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSPanorama.h b/HackIllinois/GoogleMaps.framework/Headers/GMSPanorama.h new file mode 100755 index 00000000..70400f28 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSPanorama.h @@ -0,0 +1,34 @@ +// +// GMSPanorama.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +@class GMSPanoramaLink; + +NS_ASSUME_NONNULL_BEGIN + +/** + * GMSPanorama represents metadata for a specific panorama on the Earth. This class is not + * instantiable directly and is obtained via GMSPanoramaService or GMSPanoramaView. + */ +@interface GMSPanorama : NSObject + +/** The precise location of this panorama. */ +@property(nonatomic, readonly) CLLocationCoordinate2D coordinate; + +/** The ID of this panorama. Panoramas may change ID over time, so this should not be persisted */ +@property(nonatomic, copy, readonly) NSString *panoramaID; + +/** An array of GMSPanoramaLink describing the neighboring panoramas. */ +@property(nonatomic, copy, readonly) NSArray *links; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaCamera.h b/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaCamera.h new file mode 100755 index 00000000..4b9cc47a --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaCamera.h @@ -0,0 +1,81 @@ +// +// GMSPanoramaCamera.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +#import "GMSOrientation.h" + +NS_ASSUME_NONNULL_BEGIN + +/** + * GMSPanoramaCamera is used to control the viewing direction of a GMSPanoramaView. It does not + * contain information about which particular panorama should be displayed. + */ +@interface GMSPanoramaCamera : NSObject + +/** + * Designated initializer. Configures this GMSPanoramaCamera with |orientation|, |zoom| and |FOV|. + * These values will be clamped to acceptable ranges. + */ +- (id)initWithOrientation:(GMSOrientation)orientation zoom:(float)zoom FOV:(double)FOV; + +/** + * Convenience constructor specifying heading and pitch as part of |orientation|, plus |zoom| and + * default field of view (90 degrees). + */ ++ (instancetype)cameraWithOrientation:(GMSOrientation)orientation zoom:(float)zoom; + +/** + * Convenience constructor specifying |heading|, |pitch|, |zoom| with default field of view (90 + * degrees). + */ ++ (instancetype)cameraWithHeading:(CLLocationDirection)heading pitch:(double)pitch zoom:(float)zoom; + +/** + * Convenience constructor for GMSPanoramaCamera, specifying all camera properties with heading and + * pitch as part of |orientation|. + */ ++ (instancetype)cameraWithOrientation:(GMSOrientation)orientation zoom:(float)zoom FOV:(double)FOV; + +/** + * Convenience constructor for GMSPanoramaCamera, specifying all camera properties. + */ ++ (instancetype)cameraWithHeading:(CLLocationDirection)heading + pitch:(double)pitch + zoom:(float)zoom + FOV:(double)FOV; + +/** + * The field of view (FOV) encompassed by the larger dimension (width or height) of the view in + * degrees at zoom 1. This is clamped to the range [1, 160] degrees, and has a default value of 90. + * + * Lower FOV values produce a zooming in effect; larger FOV values produce an fisheye effect. + * + * Note: This is not the displayed FOV if zoom is anything other than 1. User zoom gestures + * control the zoom property, not this property. + */ +@property(nonatomic, readonly) double FOV; + +/** + * Adjusts the visible region of the screen. A zoom of N will show the same area as the central + * width/N height/N area of what is shown at zoom 1. + * + * Zoom is clamped to the implementation defined range [1, 5]. + */ +@property(nonatomic, readonly) float zoom; + +/** + * The camera orientation, which groups together heading and pitch. + */ +@property(nonatomic, readonly) GMSOrientation orientation; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaCameraUpdate.h b/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaCameraUpdate.h new file mode 100755 index 00000000..96dd4c29 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaCameraUpdate.h @@ -0,0 +1,37 @@ +// +// GMSPanoramaCameraUpdate.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import +#import + +NS_ASSUME_NONNULL_BEGIN + +/** + * GMSPanoramaCameraUpdate represents an update that may be applied to a GMSPanoramaView. + * It encapsulates some logic for modifying the current camera. + * It should only be constructed using the factory helper methods below. + */ +@interface GMSPanoramaCameraUpdate : NSObject + +/** Returns an update that increments the camera heading with |deltaHeading|. */ ++ (GMSPanoramaCameraUpdate *)rotateBy:(CGFloat)deltaHeading; + +/** Returns an update that sets the camera heading to the given value. */ ++ (GMSPanoramaCameraUpdate *)setHeading:(CGFloat)heading; + +/** Returns an update that sets the camera pitch to the given value. */ ++ (GMSPanoramaCameraUpdate *)setPitch:(CGFloat)pitch; + +/** Returns an update that sets the camera zoom to the given value. */ ++ (GMSPanoramaCameraUpdate *)setZoom:(CGFloat)zoom; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaLayer.h b/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaLayer.h new file mode 100755 index 00000000..4b18a876 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaLayer.h @@ -0,0 +1,57 @@ +// +// GMSPanoramaLayer.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import +#import + +#import "GMSCALayer.h" + +NS_ASSUME_NONNULL_BEGIN + +/** + * kGMSLayerPanoramaHeadingKey ranges from [0, 360). + * + * @related GMSPanoramaLayer + */ +extern NSString *const kGMSLayerPanoramaHeadingKey; + +/** + * kGMSLayerPanoramaPitchKey ranges from [-90, 90]. + * + * @related GMSPanoramaLayer + */ +extern NSString *const kGMSLayerPanoramaPitchKey; + +/** + * kGMSLayerCameraZoomLevelKey ranges from [1, 5], default 1. + * + * @related GMSPanoramaLayer + */ +extern NSString *const kGMSLayerPanoramaZoomKey; + +/** + * kGMSLayerPanoramaFOVKey ranges from [1, 160] (in degrees), default 90. + * + * @related GMSPanoramaLayer + */ +extern NSString *const kGMSLayerPanoramaFOVKey; + +/** + * GMSPanoramaLayer is a custom subclass of CALayer, provided as the layer class on GMSPanoramaView. + * This layer should not be instantiated directly. + */ +@interface GMSPanoramaLayer : GMSCALayer +@property(nonatomic) CLLocationDirection cameraHeading; +@property(nonatomic) double cameraPitch; +@property(nonatomic) float cameraZoom; +@property(nonatomic) double cameraFOV; +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaLink.h b/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaLink.h new file mode 100755 index 00000000..419545fc --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaLink.h @@ -0,0 +1,30 @@ +// +// GMSPanoramaLink.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import +#import + +NS_ASSUME_NONNULL_BEGIN + +/** Links from a GMSPanorama to neighboring panoramas. */ +@interface GMSPanoramaLink : NSObject + +/** Angle of the neighboring panorama, clockwise from north in degrees. */ +@property(nonatomic) CGFloat heading; + +/** + * Panorama ID for the neighboring panorama. + * Do not store this persistenly, it changes in time. + */ +@property(nonatomic, copy) NSString *panoramaID; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaService.h b/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaService.h new file mode 100755 index 00000000..01ea8373 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaService.h @@ -0,0 +1,83 @@ +// +// GMSPanoramaService.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +#import "GMSPanoramaSource.h" + +@class GMSPanorama; + +NS_ASSUME_NONNULL_BEGIN + +/** + * Callback for when a panorama metadata becomes available. + * If an error occurred, |panorama| is nil and |error| is not nil. + * Otherwise, |panorama| is not nil and |error| is nil. + * + * @related GMSPanoramaService + */ +typedef void (^GMSPanoramaCallback)(GMSPanorama *_Nullable panorama, NSError *_Nullable error); + +/** + * GMSPanoramaService can be used to request panorama metadata even when a GMSPanoramaView is not + * active. + * + * Get an instance like this: [[GMSPanoramaService alloc] init]. + */ +@interface GMSPanoramaService : NSObject + +/** + * Retrieves information about a panorama near the given |coordinate|. + * + * This is an asynchronous request, |callback| will be called with the result. + */ +- (void)requestPanoramaNearCoordinate:(CLLocationCoordinate2D)coordinate + callback:(GMSPanoramaCallback)callback; + +/** + * Similar to requestPanoramaNearCoordinate:callback: but allows specifying a search radius (meters) + * around |coordinate|. + */ +- (void)requestPanoramaNearCoordinate:(CLLocationCoordinate2D)coordinate + radius:(NSUInteger)radius + callback:(GMSPanoramaCallback)callback; + +/** + * Similar to requestPanoramaNearCoordinate:callback: but allows specifying the panorama source type + * near the given |coordinate|. + * + * This API is experimental and may not always filter by source. + */ +- (void)requestPanoramaNearCoordinate:(CLLocationCoordinate2D)coordinate + source:(GMSPanoramaSource)source + callback:(GMSPanoramaCallback)callback; + +/** + * Similar to requestPanoramaNearCoordinate:callback: but allows specifying a search radius (meters) + * and the panorama source type near the given |coordinate|. + * + * This API is experimental and may not always filter by source. + */ +- (void)requestPanoramaNearCoordinate:(CLLocationCoordinate2D)coordinate + radius:(NSUInteger)radius + source:(GMSPanoramaSource)source + callback:(GMSPanoramaCallback)callback; + +/** + * Retrieves information about a panorama with the given |panoramaID|. + * + * |callback| will be called with the result. Only panoramaIDs obtained from the Google Maps SDK for + * iOS are supported. + */ +- (void)requestPanoramaWithID:(NSString *)panoramaID callback:(GMSPanoramaCallback)callback; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaSource.h b/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaSource.h new file mode 100755 index 00000000..f97d176c --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaSource.h @@ -0,0 +1,30 @@ +// +// GMSPanoramaSource.h +// Google Maps SDK for iOS +// +// Copyright 2017 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +/** + * \defgroup PanoramaSource GMSPanoramaSource + * @{ + */ + +/** + * Source types for Panoramas. Used to specify the source of a StreetView Panorama. + * + * This API is experimental. Results may not always match expectations. + */ +typedef NS_ENUM(NSUInteger, GMSPanoramaSource) { + /** Panoramas of locations either inside or outside. */ + kGMSPanoramaSourceDefault = 0, + /** Panoramas of locations outside. */ + kGMSPanoramaSourceOutside, +}; + +/**@}*/ diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaView.h b/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaView.h new file mode 100755 index 00000000..e7e6f69a --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSPanoramaView.h @@ -0,0 +1,299 @@ +// +// GMSPanoramaView.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import +#import + +#import "GMSOrientation.h" +#import "GMSPanoramaLayer.h" +#import "GMSPanoramaSource.h" + +@class GMSMarker; +@class GMSPanorama; +@class GMSPanoramaCamera; +@class GMSPanoramaCameraUpdate; +@class GMSPanoramaView; + +NS_ASSUME_NONNULL_BEGIN + +/** Delegate for events on GMSPanoramaView. */ +@protocol GMSPanoramaViewDelegate +@optional + +/** + * Called when starting a move to another panorama. + * + * This can be the result of interactive navigation to a neighbouring panorama. + * + * At the moment this method is called, the |view|.panorama is still pointing to the old panorama, + * as the new panorama identified by |panoID| is not yet resolved. panoramaView:didMoveToPanorama: + * will be called when the new panorama is ready. + */ +- (void)panoramaView:(GMSPanoramaView *)view willMoveToPanoramaID:(NSString *)panoramaID; + +/** + * This is invoked every time the |view|.panorama property changes. + */ +- (void)panoramaView:(GMSPanoramaView *)view didMoveToPanorama:(nullable GMSPanorama *)panorama; + +/** + * Called when the panorama change was caused by invoking moveToPanoramaNearCoordinate:. The + * coordinate passed to that method will also be passed here. + */ +- (void)panoramaView:(GMSPanoramaView *)view + didMoveToPanorama:(GMSPanorama *)panorama + nearCoordinate:(CLLocationCoordinate2D)coordinate; + +/** + * Called when moveNearCoordinate: produces an error. + */ +- (void)panoramaView:(GMSPanoramaView *)view + error:(NSError *)error + onMoveNearCoordinate:(CLLocationCoordinate2D)coordinate; + +/** + * Called when moveToPanoramaID: produces an error. + */ +- (void)panoramaView:(GMSPanoramaView *)view + error:(NSError *)error + onMoveToPanoramaID:(NSString *)panoramaID; + +/** + * Called repeatedly during changes to the camera on GMSPanoramaView. This may not be called for all + * intermediate camera values, but is always called for the final position of the camera after an + * animation or gesture. + */ +- (void)panoramaView:(GMSPanoramaView *)panoramaView didMoveCamera:(GMSPanoramaCamera *)camera; + +/** + * Called when a user has tapped on the GMSPanoramaView, but this tap was not consumed (taps may be + * consumed by e.g., tapping on a navigation arrow). + */ +- (void)panoramaView:(GMSPanoramaView *)panoramaView didTap:(CGPoint)point; + +/** + * Called after a marker has been tapped. May return YES to indicate the event has been fully + * handled and suppress any default behavior. + */ +- (BOOL)panoramaView:(GMSPanoramaView *)panoramaView didTapMarker:(GMSMarker *)marker; + +/** + * Called when the panorama tiles for the current view have just been requested and are beginning to + * load. + */ +- (void)panoramaViewDidStartRendering:(GMSPanoramaView *)panoramaView; + +/** + * Called when the panorama tiles have been loaded (or permanently failed to load) and rendered on + * screen. + */ +- (void)panoramaViewDidFinishRendering:(GMSPanoramaView *)panoramaView; + +@end + +/** + * A panorama is used to display Street View imagery. It should be constructed via [[GMSPanoramaView + * alloc] initWithFrame:], and configured post-initialization. + * + * All properties and methods should be accessed on the main thread, similar to all UIKit objects. + * The GMSPanoramaViewDelegate methods will also be called back only on the main thread. + * + * The backgroundColor of this view is shown while no panorama is visible, such as while it is + * loading or if the panorama is later set to nil. The alpha color of backgroundColor is not + * supported. + */ +@interface GMSPanoramaView : UIView + +/** + * The panorama to display; setting it will transition to a new panorama. This is animated, except + * for the initial panorama. + * + * Can be set to nil to clear the view. + */ +@property(nonatomic, nullable) GMSPanorama *panorama; + +/** GMSPanoramaView delegate. */ +@property(nonatomic, weak, nullable) IBOutlet id delegate; + +/** + * Sets the preference for whether all gestures should be enabled (default) or disabled. + * + * This does not limit programmatic movement of the camera or control of the panorama. + */ +- (void)setAllGesturesEnabled:(BOOL)enabled; + +/** + * Controls whether orientation gestures are enabled (default) or disabled. If enabled, users may + * use gestures to change the orientation of the camera. + * + * This does not limit programmatic movement of the camera. + */ +@property(nonatomic) BOOL orientationGestures; + +/** + * Controls whether zoom gestures are enabled (default) or disabled. If enabled, users may pinch to + * zoom the camera. + * + * This does not limit programmatic movement of the camera. + */ +@property(nonatomic) BOOL zoomGestures; + +/** + * Controls whether navigation gestures are enabled (default) or disabled. If enabled, users may use + * a single tap on navigation links or double tap the view to change panoramas. + * + * This does not limit programmatic control of the panorama. + */ +@property(nonatomic) BOOL navigationGestures; + +/** + * Controls whether the tappable navigation links are hidden or visible (default). Hidden navigation + * links cannot be tapped. + */ +@property(nonatomic) BOOL navigationLinksHidden; + +/** + * Controls whether the street name overlays are hidden or visible (default). + */ +@property(nonatomic) BOOL streetNamesHidden; + +/** + * Controls the panorama's camera. Setting a new camera here jumps to the new camera value, with no + * animation. + */ +@property(nonatomic) GMSPanoramaCamera *camera; + +/** + * Accessor for the custom CALayer type used for the layer. + */ +@property(nonatomic, readonly, retain) GMSPanoramaLayer *layer; + +/** + * Animates the camera of this GMSPanoramaView to |camera|, over |duration| (specified in seconds). + */ +- (void)animateToCamera:(GMSPanoramaCamera *)camera animationDuration:(NSTimeInterval)duration; + +/** + * Modifies the camera according to |cameraUpdate|, over |duration| (specified in seconds). + */ +- (void)updateCamera:(GMSPanoramaCameraUpdate *)cameraUpdate + animationDuration:(NSTimeInterval)duration; + +/** + * Requests a panorama near |coordinate|. + * + * Upon successful completion panoramaView:didMoveToPanorama: and + * panoramaView:didMoveToPanorama:nearCoordinate: will be sent to GMSPanoramaViewDelegate. + * + * On error panoramaView:error:onMoveNearCoordinate: will be sent. + * + * Repeated calls to moveNearCoordinate: result in the previous pending (incomplete) transitions + * being cancelled -- only the most recent of moveNearCoordinate: and moveToPanoramaId: will proceed + * and generate events. + */ +- (void)moveNearCoordinate:(CLLocationCoordinate2D)coordinate; + +/** + * Similar to moveNearCoordinate: but allows specifying a search radius (meters) around + * |coordinate|. + */ +- (void)moveNearCoordinate:(CLLocationCoordinate2D)coordinate radius:(NSUInteger)radius; + +/** + * Similar to moveNearCoordinate: but allows specifying a source near |coordinate|. + * + * This API is experimental and may not always filter by source. + */ +- (void)moveNearCoordinate:(CLLocationCoordinate2D)coordinate source:(GMSPanoramaSource)source; + +/** + * Similar to moveNearCoordinate: but allows specifying a search radius (meters) around + * |coordinate| and a source. + * + * This API is experimental and may not always filter by source. + */ +- (void)moveNearCoordinate:(CLLocationCoordinate2D)coordinate + radius:(NSUInteger)radius + source:(GMSPanoramaSource)source; + +/** + * Requests a panorama with |panoramaID|. + * + * Upon successful completion panoramaView:didMoveToPanorama: will be sent to + * GMSPanoramaViewDelegate. + * + * On error panoramaView:error:onMoveToPanoramaID: will be sent. + * + * Repeated calls to moveToPanoramaID: result in the previous pending (incomplete) transitions being + * cancelled -- only the most recent of moveNearCoordinate: and moveToPanoramaId: will proceed and + * generate events. + * + * Only panoramaIDs obtained from the Google Maps SDK for iOS are supported. + */ +- (void)moveToPanoramaID:(NSString *)panoramaID; + +/** + * For the current view, returns the screen point the |orientation| points through. This value may + * be outside the view for forward facing orientations which are far enough away from straight + * ahead. + * + * The result will contain NaNs for camera orientations which point away from the view, where the + * implied screen point would have had a negative distance from the camera in the direction of + * orientation. + */ +- (CGPoint)pointForOrientation:(GMSOrientation)orientation; + +/** + * Given a point for this view, returns the current camera orientation pointing through that screen + * location. At the center of this view, the returned GMSOrientation will be approximately equal to + * that of the current GMSPanoramaCamera. + */ +- (GMSOrientation)orientationForPoint:(CGPoint)point; + +/** + * Convenience constructor for GMSPanoramaView, which searches for and displays a GMSPanorama near + * |coordinate|. This performs a similar action to that of moveNearCoordinate:, and will call the + * same delegate methods. + */ ++ (instancetype)panoramaWithFrame:(CGRect)frame nearCoordinate:(CLLocationCoordinate2D)coordinate; + +/** + * Similar to panoramaWithFrame:nearCoordinate: but allows specifying a search radius (meters) + * around |coordinate|. + */ ++ (instancetype)panoramaWithFrame:(CGRect)frame + nearCoordinate:(CLLocationCoordinate2D)coordinate + radius:(NSUInteger)radius; + +/** + * Convenience constructor for GMSPanoramaView, which searches for and displays a GMSPanorama near + * |coordinate|. This performs a similar action to that of moveNearCoordinate:source, and will call + * the same delegate methods. + * + * This API is experimental and may not always filter by source. + */ ++ (instancetype)panoramaWithFrame:(CGRect)frame + nearCoordinate:(CLLocationCoordinate2D)coordinate + source:(GMSPanoramaSource)source; +/** + * Convenience constructor for GMSPanoramaView, which searches for and displays a GMSPanorama near + * |coordinate|. This performs a similar action to that of moveNearCoordinate:radius:source, and + * will call the same delegate methods. + * + * This API is experimental and may not always filter by source. + */ ++ (instancetype)panoramaWithFrame:(CGRect)frame + nearCoordinate:(CLLocationCoordinate2D)coordinate + radius:(NSUInteger)radius + source:(GMSPanoramaSource)source; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSPath.h b/HackIllinois/GoogleMaps.framework/Headers/GMSPath.h new file mode 100755 index 00000000..311e2f05 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSPath.h @@ -0,0 +1,112 @@ +// +// GMSPath.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +NS_ASSUME_NONNULL_BEGIN + +/** + * GMSPath encapsulates an immutable array of CLLocationCooordinate2D. All the coordinates of a + * GMSPath must be valid. The mutable counterpart is GMSMutablePath. + */ +@interface GMSPath : NSObject + +/** Convenience constructor for an empty path. */ ++ (instancetype)path; + +/** Initializes a newly allocated path with the contents of another GMSPath. */ +- (id)initWithPath:(GMSPath *)path; + +/** Get size of path. */ +- (NSUInteger)count; + +/** Returns kCLLocationCoordinate2DInvalid if |index| >= count. */ +- (CLLocationCoordinate2D)coordinateAtIndex:(NSUInteger)index; + +/** + * Initializes a newly allocated path from |encodedPath|. This format is described at: + * https://developers.google.com/maps/documentation/utilities/polylinealgorithm + */ ++ (nullable instancetype)pathFromEncodedPath:(NSString *)encodedPath; + +/** Returns an encoded string of the path in the format described above. */ +- (NSString *)encodedPath; + +/** + * Returns a new path obtained by adding |deltaLatitude| and |deltaLongitude| to each coordinate + * of the current path. Does not modify the current path. + */ +- (instancetype)pathOffsetByLatitude:(CLLocationDegrees)deltaLatitude + longitude:(CLLocationDegrees)deltaLongitude; + +@end + +/** + * kGMSEquatorProjectedMeter may be useful when specifying lengths for segment in "projected" units. + * The value of kGMSEquatorProjectedMeter, 1/(pi * EarthRadius), represents the length of one meter + * at the equator in projected units. For example to specify a projected length that corresponds + * to 100km at the equator use 100000 * kGMSEquatorProjectedMeter. + * See [GMSPath segmentsForLength:kind:], [GMSPath lengthOfKind:] and kGMSLengthProjected. + */ +extern const double kGMSEquatorProjectedMeter; + +/** + * \defgroup LengthKind GMSLengthKind + * @{ + */ + +/** + * GMSLengthKind indicates the type of a length value, which can be geodesic (in meters), rhumb + * length (in meters) and projected length (in GMSMapPoint units). + */ +typedef NS_ENUM(NSUInteger, GMSLengthKind) { + /* + * Geodesic length, in meters, along geodesic segments. May be useful, for example, to specify + * lengths along the the trajectory of airplanes or ships. + */ + kGMSLengthGeodesic, + + /* + * Rhumb length, in meters, along rhumb (straight line) segments. May be useful, for example, to + * draw a scale bar on a map. The visual size of a segment of a given length depens on the + * latitude. + */ + kGMSLengthRhumb, + + /* + * Length in projected space, along rhumb segments. Projected length uses the same units as + * GMSMapPoint - the Earth equator circumference has length 2. It is possible to specify projected + * length in units corresponding to 1 meter at the equator by multiplying with + * kGMSEquatorProjectedMeter, equal to 1/(pi * EarthRadius). + * + * Projected length may be useful, for example, to specify segments with the same visual length + * regardless of latitude. + */ + kGMSLengthProjected +}; + +/**@}*/ + +@interface GMSPath (GMSPathLength) + +/** + * Returns the fractional number of segments along the path that correspond to |length|, + * interpreted according to |kind|. See GMSLengthKind. + */ +- (double)segmentsForLength:(CLLocationDistance)length kind:(GMSLengthKind)kind; + +/** + * Returns the length of the path, according to |kind|. See GMSLengthKind. + */ +- (CLLocationDistance)lengthOfKind:(GMSLengthKind)kind; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSPolygon.h b/HackIllinois/GoogleMaps.framework/Headers/GMSPolygon.h new file mode 100755 index 00000000..817c9e8c --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSPolygon.h @@ -0,0 +1,59 @@ +// +// GMSPolygon.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +#import "GMSOverlay.h" + +@class GMSPath; +@class GMSPolygonLayer; + +NS_ASSUME_NONNULL_BEGIN + +/** + * GMSPolygon defines a polygon that appears on the map. A polygon (like a polyline) defines a + * series of connected coordinates in an ordered sequence; additionally, polygons form a closed loop + * and define a filled region. + */ +@interface GMSPolygon : GMSOverlay + +/** The path that describes this polygon. The coordinates composing the path must be valid. */ +@property(nonatomic, copy, nullable) GMSPath *path; + +/** + * The array of GMSPath instances that describes any holes in this polygon. The coordinates + * composing each path must be valid. + */ +@property(nonatomic, copy, nullable) NSArray *holes; + +/** The width of the polygon outline in screen points. Defaults to 1. */ +@property(nonatomic) CGFloat strokeWidth; + +/** The color of the polygon outline. Defaults to nil. */ +@property(nonatomic, nullable) UIColor *strokeColor; + +/** The fill color. Defaults to blueColor. */ +@property(nonatomic, nullable) UIColor *fillColor; + +/** Whether this polygon should be rendered with geodesic correction. */ +@property(nonatomic) BOOL geodesic; + +/** Provides the Core Animation layer for this GMSPolygon. */ +@property(nonatomic, readonly) GMSPolygonLayer *layer; + +/** + * Convenience constructor for GMSPolygon for a particular path. Other properties will have default + * values. + */ ++ (instancetype)polygonWithPath:(nullable GMSPath *)path; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSPolygonLayer.h b/HackIllinois/GoogleMaps.framework/Headers/GMSPolygonLayer.h new file mode 100755 index 00000000..f1860a53 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSPolygonLayer.h @@ -0,0 +1,49 @@ +// +// GMSPolygonLayer.h +// Google Maps SDK for iOS +// +// Copyright 2018 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import +#import + +#import "GMSOverlayLayer.h" + +NS_ASSUME_NONNULL_BEGIN + +/** + * GMSPolygonLayer is a subclass of GMSOverlayLayer, available on a per-polygon basis, that allows + * animation of several properties of its associated GMSPolygon. + * + * Note that this CALayer is never actually rendered directly, as GMSMapView is provided entirely + * via an OpenGL layer. As such, adjustments or animations to 'default' properties of CALayer will + * not have any effect. + */ +@interface GMSPolygonLayer : GMSOverlayLayer + +/** The width of the polygon outline in screen points. */ +@property(nonatomic) CGFloat strokeWidth; + +/** + * The color of the polygon outline. This is an assign property, there is an expectation for the + * GMSPolygon to own the reference if necessary. + */ +@property(nonatomic, assign, nullable) CGColorRef strokeColor; + +/** + * The fill color. This is an assign property, there is an expectation for the GMSPolygon to own the + * reference if necessary. + */ +@property(nonatomic, assign, nullable) CGColorRef fillColor; + +@end + +extern NSString *const kGMSPolygonLayerStrokeWidth; +extern NSString *const kGMSPolygonLayerStrokeColor; +extern NSString *const kGMSPolygonLayerFillColor; + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSPolyline.h b/HackIllinois/GoogleMaps.framework/Headers/GMSPolyline.h new file mode 100755 index 00000000..9f67db1f --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSPolyline.h @@ -0,0 +1,61 @@ +// +// GMSPolyline.h +// Google Maps SDK for iOS +// +// Copyright 2012 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +#import "GMSOverlay.h" +#import "GMSStyleSpan.h" + +@class GMSPath; + +NS_ASSUME_NONNULL_BEGIN + +/** + * GMSPolyline specifies the available options for a polyline that exists on the Earth's surface. + * It is drawn as a physical line between the points specified in |path|. + */ +@interface GMSPolyline : GMSOverlay + +/** + * The path that describes this polyline. + */ +@property(nonatomic, copy, nullable) GMSPath *path; + +/** + * The width of the line in screen points. Defaults to 1. + */ +@property(nonatomic) CGFloat strokeWidth; + +/** + * The UIColor used to render the polyline. Defaults to [UIColor blueColor]. + */ +@property(nonatomic) UIColor *strokeColor; + +/** Whether this line should be rendered with geodesic correction. */ +@property(nonatomic) BOOL geodesic; + +/** + * Convenience constructor for GMSPolyline for a particular path. Other properties will have + * default values. + */ ++ (instancetype)polylineWithPath:(nullable GMSPath *)path; + +/** + * An array containing GMSStyleSpan, the spans used to render this polyline. + * + * If this array contains fewer segments than the polyline itself, the final segment will be applied + * over the remaining length. If this array is unset or empty, then |strokeColor| is used for the + * entire line instead. + */ +@property(nonatomic, copy, nullable) NSArray *spans; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSProjection.h b/HackIllinois/GoogleMaps.framework/Headers/GMSProjection.h new file mode 100755 index 00000000..a9350e0d --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSProjection.h @@ -0,0 +1,76 @@ +// +// GMSProjection.h +// Google Maps SDK for iOS +// +// Copyright 2012 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import +#import + +/** + * GMSVisibleRegion contains the four points defining the polygon that is visible in a map's camera. + * + * This polygon can be a trapezoid instead of a rectangle, because a camera can have tilt. If the + * camera is directly over the center of the camera, the shape is rectangular, but if the camera is + * tilted, the shape will appear to be a trapezoid whose smallest side is closest to the point of + * view. + */ +typedef struct { + /** Bottom left corner of the camera. */ + CLLocationCoordinate2D nearLeft; + + /** Bottom right corner of the camera. */ + CLLocationCoordinate2D nearRight; + + /** Far left corner of the camera. */ + CLLocationCoordinate2D farLeft; + + /** Far right corner of the camera. */ + CLLocationCoordinate2D farRight; +} GMSVisibleRegion; + +/** + * Defines a mapping between Earth coordinates (CLLocationCoordinate2D) and coordinates in the map's + * view (CGPoint). A projection is constant and immutable, in that the mapping it embodies never + * changes. The mapping is not necessarily linear. + * + * Passing invalid Earth coordinates (i.e., per CLLocationCoordinate2DIsValid) to this object may + * result in undefined behavior. + * + * This class should not be instantiated directly unless under testing conditions. Instead, obtain + * it via projection on GMSMapView. + */ +@interface GMSProjection : NSObject + +/** Maps an Earth coordinate to a point coordinate in the map's view. */ +- (CGPoint)pointForCoordinate:(CLLocationCoordinate2D)coordinate; + +/** Maps a point coordinate in the map's view to an Earth coordinate. */ +- (CLLocationCoordinate2D)coordinateForPoint:(CGPoint)point; + +/** + * Converts a distance in meters to content size. This is only accurate for small Earth distances, + * as it uses CGFloat for screen distances. + */ +- (CGFloat)pointsForMeters:(CLLocationDistance)meters + atCoordinate:(CLLocationCoordinate2D)coordinate; + +/** + * Returns whether a given coordinate (lat/lng) is contained within the projection. + */ +- (BOOL)containsCoordinate:(CLLocationCoordinate2D)coordinate; + +/** + * Returns the region (four location coordinates) that is visible according to the projection. If + * padding was set on GMSMapView, this region takes the padding into account. + * + * The visible region can be non-rectangular. The result is undefined if the projection includes + * points that do not map to anywhere on the map (e.g., camera sees outer space). + */ +- (GMSVisibleRegion)visibleRegion; + +@end diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSServices.h b/HackIllinois/GoogleMaps.framework/Headers/GMSServices.h new file mode 100755 index 00000000..4ea29d55 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSServices.h @@ -0,0 +1,96 @@ +// +// GMSServices.h +// Google Maps SDK for iOS +// +// Copyright 2012 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +NS_ASSUME_NONNULL_BEGIN + +/** + * Service class for the Google Maps SDK for iOS. + * + * This class is not thread safe. All methods should only be invoked on the main thread. + */ +@interface GMSServices : NSObject + +/** + * Provides the shared instance of GMSServices for the Google Maps SDK for iOS, creating it if + * necessary. Classes such as GMSMapView and GMSPanoramaView will hold this instance to provide + * their connection to Google. + * + * This is an opaque object. If your application often creates and destroys view or service classes + * provided by the Google Maps SDK for iOS, it may be useful to hold onto this object directly, as + * otherwise your connection to Google may be restarted on a regular basis. It also may be useful to + * take this object in advance of the first map creation, to reduce initial map creation performance + * cost. + * + * This method will throw an exception if provideAPIKey: has not been called. + */ ++ (id)sharedServices; + +/** + * Provides your API key to the Google Maps SDK for iOS. This key is generated for your application + * via the Google Cloud Platform Console, and is paired with your application's bundle ID to + * identify it. This must be called exactly once by your application before any iOS Maps SDK + * object is initialized. + * + * @return YES if the APIKey was successfully provided. + */ ++ (BOOL)provideAPIKey:(NSString *)APIKey; + +/** + * Provides your API options to the Google Maps SDK for iOS. Pass an array containing an NSString + * for each option. These options apply to all maps. + * + * This may be called exactly once by your application and must be called before any iOS Maps SDK + * object is initialized. + * + * @return YES if all the APIOptions were successfully provided. + */ ++ (BOOL)provideAPIOptions:(NSArray *)APIOptions; + +/** + * Enables the map to render using Metal instead of OpenGL. + * + * The rendering might look very slightly different between renderers. The default is @c NO and + * value must be updated before the services instance is initialized. + * + * This property must be set from the main thread. + */ ++ (void)setMetalRendererEnabled:(BOOL)enabled; + +/** + * Enables reporting of abnormal SDK terminations such as the app crashes while the SDK is still + * running. This allows Google to improve SDK stability when applicable. The default is @c YES and + * value must be updated before the services instance is initialized. + * + * This property must be set from the main thread. + */ ++ (void)setAbnormalTerminationReportingEnabled:(BOOL)enabled; + +/** + * Returns the open source software license information for Google Maps SDK for iOS. This + * information must be made available within your application. + */ ++ (NSString *)openSourceLicenseInfo; + +/** + * Returns the version for this release of the Google Maps SDK for iOS. For example, "1.0.0" + */ ++ (NSString *)SDKVersion; + +/** + * Returns the long version for this release of the Google Maps SDK for iOS. For example, "1.0.0 + * (102.1)". + */ ++ (NSString *)SDKLongVersion; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSStampStyle.h b/HackIllinois/GoogleMaps.framework/Headers/GMSStampStyle.h new file mode 100755 index 00000000..43d64659 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSStampStyle.h @@ -0,0 +1,56 @@ +// +// GMSStampStyle.h +// Google Maps SDK for iOS +// +// Copyright 2020 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +NS_ASSUME_NONNULL_BEGIN + +/** + * The abstract base class for polyline styles that draw a repeating image over a @c GMSStyleSpan. + */ +@interface GMSStampStyle : NSObject + +/** + * The image or texture that will repeated over a stroke. + * Note that this image will be compressed into a square - so for best results have a square image. + * The rendered stamps will be the width of the line that the GMSStrokeStyle is set on. The image + * will be oriented with the top of the image towards the start point, and the bottom of the image + * towards the end point. For example, if the underlying line has two points and the start point is + * directly above the endpoint, the stamp will appear in an upright orientation. + */ +@property(nonatomic, readonly) UIImage *stampImage; + +- (instancetype)init NS_UNAVAILABLE; + +@end + +/** A polyline style that draws a repeating image over a @c GMSStyleSpan. */ +@interface GMSTextureStyle : GMSStampStyle + +/** + * Returns a texture stamp style with the given image. + * + * @param image A @c UIImage object to use as the stamp image. + * @return An initialized texture stamp style. + */ ++ (instancetype)textureStyleWithImage:(UIImage *)image + NS_SWIFT_UNAVAILABLE("Use initializer instead"); + +/** + * Returns an initialized texture stamp style with the given image. + * + * @param image A @c UIImage object to use as the stamp image. + * @return An initialized texture stamp style. + */ +- (instancetype)initWithImage:(UIImage *)image NS_DESIGNATED_INITIALIZER; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSStrokeStyle.h b/HackIllinois/GoogleMaps.framework/Headers/GMSStrokeStyle.h new file mode 100755 index 00000000..04a0099d --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSStrokeStyle.h @@ -0,0 +1,35 @@ +// +// GMSStrokeStyle.h +// Google Maps SDK for iOS +// +// Copyright 2019 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +@class GMSStampStyle; + +NS_ASSUME_NONNULL_BEGIN + +/** Describes the drawing style for one-dimensional entities such as polylines. */ +@interface GMSStrokeStyle : NSObject + +/** + * A repeated image over the stroke to allow a user to set a 2D texture on top of a stroke. + * If the image has transparent or semi-transparent portions, the underlying stroke color will show + * through in those places. Solid portions of the stamp will completely cover the base stroke. + */ +@property(nonatomic, strong, nullable) GMSStampStyle *stampStyle; + +/** Creates a solid color stroke style. */ ++ (instancetype)solidColor:(UIColor *)color; + +/** Creates a gradient stroke style interpolating from |fromColor| to |toColor|. */ ++ (instancetype)gradientFromColor:(UIColor *)fromColor toColor:(UIColor *)toColor; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSStyleSpan.h b/HackIllinois/GoogleMaps.framework/Headers/GMSStyleSpan.h new file mode 100755 index 00000000..08462bcf --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSStyleSpan.h @@ -0,0 +1,51 @@ +// +// GMSStyleSpan.h +// Google Maps SDK for iOS +// +// Copyright 2019 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +#import "GMSStrokeStyle.h" + +NS_ASSUME_NONNULL_BEGIN +/** Describes the style for some region of a polyline. */ +@interface GMSStyleSpan : NSObject + +/** + * Factory returning a solid color span of length one segment. Equivalent to + * [GMSStyleSpan spanWithStyle:[GMSStrokeStyle solidColor:|color|] segments:1]. + */ ++ (instancetype)spanWithColor:(UIColor *)color; + +/** + * Factory returning a solid color span with a given number of segments. Equivalent to + * [GMSStyleSpan spanWithStyle:[GMSStrokeStyle solidColor:|color|] segments:|segments|]. + */ ++ (instancetype)spanWithColor:(UIColor *)color segments:(double)segments; + +/** + * Factory returning a span with the given |style| of length one segment. Equivalent to + * [GMSStyleSpan spanWithStyle:|style| segments:1]. + */ ++ (instancetype)spanWithStyle:(GMSStrokeStyle *)style; + +/** + * Factory returning a span with the given |style| and length in number of segments. + * |segments| must be greater than 0 (i.e. can't be 0). + */ ++ (instancetype)spanWithStyle:(GMSStrokeStyle *)style segments:(double)segments; + +/** The style of this span. */ +@property(nonatomic, readonly) GMSStrokeStyle *style; + +/** The length of this span in number of segments. */ +@property(nonatomic, readonly) double segments; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSSyncTileLayer.h b/HackIllinois/GoogleMaps.framework/Headers/GMSSyncTileLayer.h new file mode 100755 index 00000000..ca3f91bb --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSSyncTileLayer.h @@ -0,0 +1,35 @@ +// +// GMSSyncTileLayer.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +#import "GMSTileLayer.h" + +NS_ASSUME_NONNULL_BEGIN + +/** + * GMSSyncTileLayer is an abstract subclass of GMSTileLayer that provides a sync interface to + * generate image tile data. + */ +@interface GMSSyncTileLayer : GMSTileLayer + +/** + * As per requestTileForX:y:zoom:receiver: on GMSTileLayer, but provides a synchronous interface to + * return tiles. This method may block or otherwise perform work, and is not called on the main + * thread. + * + * Calls to this method may also be made from multiple threads so implementations must be + * threadsafe. + */ +- (nullable UIImage *)tileForX:(NSUInteger)x y:(NSUInteger)y zoom:(NSUInteger)zoom; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSTileLayer.h b/HackIllinois/GoogleMaps.framework/Headers/GMSTileLayer.h new file mode 100755 index 00000000..5ad82706 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSTileLayer.h @@ -0,0 +1,105 @@ +// +// GMSTileLayer.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +@class GMSMapView; + +NS_ASSUME_NONNULL_BEGIN + +/** + * Stub tile that is used to indicate that no tile exists for a specific tile coordinate. May be + * returned by tileForX:y:zoom: on GMSTileOverlay. + */ +FOUNDATION_EXTERN UIImage *const kGMSTileLayerNoTile; + +/** + * GMSTileReceiver is provided to GMSTileLayer when a tile request is made, allowing the callback to + * be later (or immediately) invoked. + */ +@protocol GMSTileReceiver +- (void)receiveTileWithX:(NSUInteger)x + y:(NSUInteger)y + zoom:(NSUInteger)zoom + image:(nullable UIImage *)image; +@end + +/** + * GMSTileLayer is an abstract class that allows overlaying of custom image tiles on a specified + * GMSMapView. It may not be initialized directly, and subclasses must implement the + * tileForX:y:zoom: method to return tiles. + * + * At zoom level 0 the whole world is a square covered by a single tile, and the coordinates |x| and + * |y| are both 0 for that tile. At zoom level 1, the world is covered by 4 tiles with |x| and |y| + * being 0 or 1, and so on. + */ +@interface GMSTileLayer : NSObject + +/** + * requestTileForX:y:zoom:receiver: generates image tiles for GMSTileOverlay. It must be overridden + * by subclasses. The tile for the given |x|, |y| and |zoom| _must_ be later passed to |receiver|. + * + * Specify kGMSTileLayerNoTile if no tile is available for this location; or nil if a transient + * error occured and a tile may be available later. + * + * Calls to this method will be made on the main thread. See GMSSyncTileLayer for a base class that + * implements a blocking tile layer that does not run on your application's main thread. + */ +- (void)requestTileForX:(NSUInteger)x + y:(NSUInteger)y + zoom:(NSUInteger)zoom + receiver:(id)receiver; + +/** + * Clears the cache so that all tiles will be requested again. + */ +- (void)clearTileCache; + +/** + * The map this GMSTileOverlay is displayed on. Setting this property will add the layer to the map. + * Setting it to nil removes this layer from the map. A layer may be active on at most one map at + * any given time. + */ +@property(nonatomic, weak, nullable) GMSMapView *map; + +/** + * Higher |zIndex| value tile layers will be drawn on top of lower |zIndex| value tile layers and + * overlays. Equal values result in undefined draw ordering. + */ +@property(nonatomic) int zIndex; + +/** + * Specifies the number of pixels (not points) that the returned tile images will prefer to display + * as. For best results, this should be the edge length of your custom tiles. Defaults to 256, which + * is the traditional size of Google Maps tiles. + * + * Values less than the equivalent of 128 points (e.g. 256 pixels on retina devices) may not perform + * well and are not recommended. + * + * As an example, an application developer may wish to provide retina tiles (512 pixel edge length) + * on retina devices, to keep the same number of tiles + * per view as the default value of 256 would give on a non-retina device. + */ +@property(nonatomic) NSInteger tileSize; + +/** + * Specifies the opacity of the tile layer. This provides a multiplier for the alpha channel of tile + * images. + */ +@property(nonatomic) float opacity; + +/** + * Specifies whether the tiles should fade in. Default YES. + */ +@property(nonatomic) BOOL fadeIn; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSUISettings.h b/HackIllinois/GoogleMaps.framework/Headers/GMSUISettings.h new file mode 100755 index 00000000..0b81e5c0 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSUISettings.h @@ -0,0 +1,91 @@ +// +// GMSUISettings.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +/** Settings for the user interface of a GMSMapView. */ +@interface GMSUISettings : NSObject + +/** + * Sets the preference for whether all gestures should be enabled (default) or disabled. This + * doesn't restrict users from tapping any on screen buttons to move the camera (e.g., compass or + * zoom controls), nor does it restrict programmatic movements and animation. + */ +- (void)setAllGesturesEnabled:(BOOL)enabled; + +/** + * Controls whether scroll gestures are enabled (default) or disabled. If enabled, users may drag to + * pan the camera. This does not limit programmatic movement of the camera. + */ +@property(nonatomic) BOOL scrollGestures; + +/** + * Controls whether zoom gestures are enabled (default) or disabled. If enabled, users may double + * tap/two-finger tap or pinch to zoom the camera. This does not limit programmatic movement of the + * camera. + */ +@property(nonatomic) BOOL zoomGestures; + +/** + * Controls whether tilt gestures are enabled (default) or disabled. If enabled, users may use a + * two-finger vertical down or up swipe to tilt the camera. This does not limit programmatic control + * of the camera's viewingAngle. + */ +@property(nonatomic) BOOL tiltGestures; + +/** + * Controls whether rotate gestures are enabled (default) or disabled. If enabled, users may use a + * two-finger rotate gesture to rotate the camera. This does not limit programmatic control of the + * camera's bearing. + */ +@property(nonatomic) BOOL rotateGestures; + +/** + * Controls whether gestures by users are completely consumed by the GMSMapView when gestures are + * enabled (default YES). This prevents these gestures from being received by parent views. + * + * When the GMSMapView is contained by a UIScrollView (or other scrollable area), this means that + * gestures on the map will not be additional consumed as scroll gestures. However, disabling this + * (set to NO) may be useful to support complex view hierarchies or requirements. + */ +@property(nonatomic) BOOL consumesGesturesInView; + +/** + * Enables or disables the compass. The compass is an icon on the map that indicates the direction + * of north on the map. + * + * If enabled, it is only shown when the camera is rotated away from its default orientation + * (bearing of 0). When a user taps the compass, the camera orients itself to its default + * orientation and fades away shortly after. If disabled, the compass will never be displayed. + */ +@property(nonatomic) BOOL compassButton; + +/** + * Enables or disables the My Location button. This is a button visible on the map that, when tapped + * by users, will center the map on the current user location. + */ +@property(nonatomic) BOOL myLocationButton; + +/** + * Enables (default) or disables the indoor floor picker. + * + * If enabled, it is only visible when the view is focused on a building with indoor floor data. If + * disabled, the selected floor can still be controlled programmatically via the indoorDisplay + * mapView property. + */ +@property(nonatomic) BOOL indoorPicker; + +/** + * Controls whether rotate and zoom gestures can be performed off-center and scrolled around + * (default YES). + */ +@property(nonatomic) BOOL allowScrollGesturesDuringRotateOrZoom; + +@end diff --git a/HackIllinois/GoogleMaps.framework/Headers/GMSURLTileLayer.h b/HackIllinois/GoogleMaps.framework/Headers/GMSURLTileLayer.h new file mode 100755 index 00000000..71671667 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GMSURLTileLayer.h @@ -0,0 +1,56 @@ +// +// GMSURLTileLayer.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import "GMSTileLayer.h" + +@class NSURL; + +NS_ASSUME_NONNULL_BEGIN + +/** + * |GMSTileURLConstructor| is a block taking |x|, |y| and |zoom| and returning an NSURL, or nil to + * indicate no tile for that location. + * + * @related GMSURLTileLayer + */ +typedef NSURL *_Nullable (^GMSTileURLConstructor)(NSUInteger x, NSUInteger y, NSUInteger zoom); + +/** + * GMSURLTileProvider fetches tiles based on the URLs returned from a GMSTileURLConstructor. For + * example: + *
+ *   GMSTileURLConstructor constructor = ^(NSUInteger x, NSUInteger y, NSUInteger zoom) {
+ *     NSString *URLStr =
+ *         [NSString stringWithFormat:@"https://example.com/%d/%d/%d.png", x, y, zoom];
+ *     return [NSURL URLWithString:URLStr];
+ *   };
+ *   GMSTileLayer *layer =
+ *       [GMSURLTileLayer tileLayerWithURLConstructor:constructor];
+ *   layer.userAgent = @"SDK user agent";
+ *   layer.map = map;
+ * 
+ * + * GMSURLTileProvider may not be subclassed and should only be created via its convenience + * constructor. + */ +@interface GMSURLTileLayer : GMSTileLayer + +/** Convenience constructor. |constructor| must be non-nil. */ ++ (instancetype)tileLayerWithURLConstructor:(GMSTileURLConstructor)constructor; + +/** + * Specify the user agent to describe your application. If this is nil (the default), the default + * iOS user agent is used for HTTP requests. + */ +@property(nonatomic, copy, nullable) NSString *userAgent; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMaps.framework/Headers/GoogleMaps.h b/HackIllinois/GoogleMaps.framework/Headers/GoogleMaps.h new file mode 100755 index 00000000..ee10b3c7 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Headers/GoogleMaps.h @@ -0,0 +1,46 @@ +#import "GMSIndoorBuilding.h" +#import "GMSIndoorLevel.h" +#import "GMSAddress.h" +#import "GMSCALayer.h" +#import "GMSCameraPosition.h" +#import "GMSCameraUpdate.h" +#import "GMSCircle.h" +#import "GMSCoordinateBounds+GoogleMaps.h" +#import "GMSGeocoder.h" +#import "GMSGeometryUtils.h" +#import "GMSGroundOverlay.h" +#import "GMSIndoorDisplay.h" +#import "GMSMapID.h" +#import "GMSMapLayer.h" +#import "GMSMapStyle.h" +#import "GMSMapView+Animation.h" +#import "GMSMapView.h" +#import "GMSMarker.h" +#import "GMSMarkerAnimation.h" +#import "GMSMarkerLayer.h" +#import "GMSMutablePath.h" +#import "GMSOrientation.h" +#import "GMSOverlay.h" +#import "GMSOverlayLayer.h" +#import "GMSPanorama.h" +#import "GMSPanoramaCamera.h" +#import "GMSPanoramaCameraUpdate.h" +#import "GMSPanoramaLayer.h" +#import "GMSPanoramaLink.h" +#import "GMSPanoramaService.h" +#import "GMSPanoramaSource.h" +#import "GMSPanoramaView.h" +#import "GMSPath.h" +#import "GMSPolygon.h" +#import "GMSPolygonLayer.h" +#import "GMSPolyline.h" +#import "GMSProjection.h" +#import "GMSServices.h" +#import "GMSStampStyle.h" +#import "GMSStrokeStyle.h" +#import "GMSStyleSpan.h" +#import "GMSSyncTileLayer.h" +#import "GMSTileLayer.h" +#import "GMSUISettings.h" +#import "GMSURLTileLayer.h" +#import "GMSAccessibilityLabels.h" diff --git a/HackIllinois/GoogleMaps.framework/Modules/module.modulemap b/HackIllinois/GoogleMaps.framework/Modules/module.modulemap new file mode 100755 index 00000000..38ca6666 --- /dev/null +++ b/HackIllinois/GoogleMaps.framework/Modules/module.modulemap @@ -0,0 +1,23 @@ +framework module GoogleMaps { + umbrella header "GoogleMaps.h" + export * + module * { export * } + link "m" + link "z" + link framework "CoreData" + link framework "CoreFoundation" + link framework "CoreGraphics" + link framework "CoreImage" + link framework "CoreLocation" + link framework "CoreTelephony" + link framework "CoreText" + link framework "Foundation" + link framework "GLKit" + link framework "ImageIO" + link framework "Metal" + link framework "OpenGLES" + link framework "QuartzCore" + link framework "Security" + link framework "SystemConfiguration" + link framework "UIKit" +} diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/Assets.car b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/Assets.car new file mode 100755 index 00000000..fbbf25cd Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/Assets.car differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCacheStorage.momd/Storage.mom b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCacheStorage.momd/Storage.mom new file mode 100755 index 00000000..deaabbc4 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCacheStorage.momd/Storage.mom differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCacheStorage.momd/StorageWithTileProto.mom b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCacheStorage.momd/StorageWithTileProto.mom new file mode 100755 index 00000000..3a83243c Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCacheStorage.momd/StorageWithTileProto.mom differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCacheStorage.momd/StorageWithTileVersionID.mom b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCacheStorage.momd/StorageWithTileVersionID.mom new file mode 100755 index 00000000..2ba69475 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCacheStorage.momd/StorageWithTileVersionID.mom differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCacheStorage.momd/VersionInfo.plist b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCacheStorage.momd/VersionInfo.plist new file mode 100755 index 00000000..38c1a01e Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCacheStorage.momd/VersionInfo.plist differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/Assets.car b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/Assets.car new file mode 100755 index 00000000..53c78e92 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/Assets.car differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/DroidSansMerged-Regular.ttf b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/DroidSansMerged-Regular.ttf new file mode 100755 index 00000000..2aca5f5f Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/DroidSansMerged-Regular.ttf differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSNavNightModeSprites-0-1x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSNavNightModeSprites-0-1x.png new file mode 100755 index 00000000..852182ef Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSNavNightModeSprites-0-1x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSNavNightModeSprites-0-2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSNavNightModeSprites-0-2x.png new file mode 100755 index 00000000..be8282a8 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSNavNightModeSprites-0-2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSNavNightModeSprites-0-3x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSNavNightModeSprites-0-3x.png new file mode 100755 index 00000000..680ef5df Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSNavNightModeSprites-0-3x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSNavSprites-0-1x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSNavSprites-0-1x.png new file mode 100755 index 00000000..af7815cc Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSNavSprites-0-1x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSNavSprites-0-2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSNavSprites-0-2x.png new file mode 100755 index 00000000..d6e9e8fe Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSNavSprites-0-2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSNavSprites-0-3x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSNavSprites-0-3x.png new file mode 100755 index 00000000..668d8fe8 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSNavSprites-0-3x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSShaders.metallib b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSShaders.metallib new file mode 100755 index 00000000..dac00674 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSShaders.metallib differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSShadersSim.metallib b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSShadersSim.metallib new file mode 100755 index 00000000..1442fa30 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSShadersSim.metallib differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSSprites-0-1x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSSprites-0-1x.png new file mode 100755 index 00000000..a3d86c40 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSSprites-0-1x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSSprites-0-2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSSprites-0-2x.png new file mode 100755 index 00000000..37dcbef3 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSSprites-0-2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSSprites-0-3x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSSprites-0-3x.png new file mode 100755 index 00000000..09129cd2 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/GMSSprites-0-3x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/Info.plist b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/Info.plist new file mode 100755 index 00000000..3821e63b Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/Info.plist differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/Tharlon-Regular.ttf b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/Tharlon-Regular.ttf new file mode 100755 index 00000000..4717d70c Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/Tharlon-Regular.ttf differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ar.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ar.lproj/GMSCore.strings new file mode 100755 index 00000000..7d5d573b Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ar.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_background.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_background.png new file mode 100755 index 00000000..cec89b6e Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_background.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_background@2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_background@2x.png new file mode 100755 index 00000000..7a3d29d0 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_background@2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_background@3x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_background@3x.png new file mode 100755 index 00000000..74eace5e Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_background@3x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_compass.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_compass.png new file mode 100755 index 00000000..11fee99e Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_compass.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_compass@2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_compass@2x.png new file mode 100755 index 00000000..a73d1d6e Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_compass@2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_compass_night.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_compass_night.png new file mode 100755 index 00000000..df8c234e Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_compass_night.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_compass_night@2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_compass_night@2x.png new file mode 100755 index 00000000..dccbf03d Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_compass_night@2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_my_location.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_my_location.png new file mode 100755 index 00000000..c09a65f7 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_my_location.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_my_location@2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_my_location@2x.png new file mode 100755 index 00000000..379be629 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/button_my_location@2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ca.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ca.lproj/GMSCore.strings new file mode 100755 index 00000000..7fd197d3 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ca.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/cs.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/cs.lproj/GMSCore.strings new file mode 100755 index 00000000..c1f92991 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/cs.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/da.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/da.lproj/GMSCore.strings new file mode 100755 index 00000000..4803e47f Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/da.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/dav_one_way_16_256.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/dav_one_way_16_256.png new file mode 100755 index 00000000..7f7c2fed Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/dav_one_way_16_256.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/de.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/de.lproj/GMSCore.strings new file mode 100755 index 00000000..94a75ba8 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/de.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/el.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/el.lproj/GMSCore.strings new file mode 100755 index 00000000..8030d8f1 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/el.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/en.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/en.lproj/GMSCore.strings new file mode 100755 index 00000000..5c98926b Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/en.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/en_AU.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/en_AU.lproj/GMSCore.strings new file mode 100755 index 00000000..c03b33c7 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/en_AU.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/en_GB.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/en_GB.lproj/GMSCore.strings new file mode 100755 index 00000000..c03b33c7 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/en_GB.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/en_IN.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/en_IN.lproj/GMSCore.strings new file mode 100755 index 00000000..c03b33c7 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/en_IN.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/es.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/es.lproj/GMSCore.strings new file mode 100755 index 00000000..d4d625cb Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/es.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/es_419.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/es_419.lproj/GMSCore.strings new file mode 100755 index 00000000..28e15b50 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/es_419.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/es_MX.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/es_MX.lproj/GMSCore.strings new file mode 100755 index 00000000..28e15b50 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/es_MX.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/fi.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/fi.lproj/GMSCore.strings new file mode 100755 index 00000000..8a93b819 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/fi.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/fr.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/fr.lproj/GMSCore.strings new file mode 100755 index 00000000..7f18b50c Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/fr.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/fr_CA.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/fr_CA.lproj/GMSCore.strings new file mode 100755 index 00000000..339bbb98 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/fr_CA.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/he.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/he.lproj/GMSCore.strings new file mode 100755 index 00000000..7e1faf62 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/he.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/hi.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/hi.lproj/GMSCore.strings new file mode 100755 index 00000000..f121b386 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/hi.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/hr.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/hr.lproj/GMSCore.strings new file mode 100755 index 00000000..e73adca3 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/hr.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/hu.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/hu.lproj/GMSCore.strings new file mode 100755 index 00000000..2eed3af7 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/hu.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_closed_place_waypoint_alert_32pt.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_closed_place_waypoint_alert_32pt.png new file mode 100755 index 00000000..c44be9a2 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_closed_place_waypoint_alert_32pt.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_closed_place_waypoint_alert_32pt@2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_closed_place_waypoint_alert_32pt@2x.png new file mode 100755 index 00000000..afe4d23c Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_closed_place_waypoint_alert_32pt@2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_closed_place_waypoint_alert_32pt@3x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_closed_place_waypoint_alert_32pt@3x.png new file mode 100755 index 00000000..6bbadd2f Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_closed_place_waypoint_alert_32pt@3x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_closed_place_waypoint_alert_night_32pt.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_closed_place_waypoint_alert_night_32pt.png new file mode 100755 index 00000000..eef5bffc Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_closed_place_waypoint_alert_night_32pt.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_closed_place_waypoint_alert_night_32pt@2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_closed_place_waypoint_alert_night_32pt@2x.png new file mode 100755 index 00000000..fb7a1ed5 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_closed_place_waypoint_alert_night_32pt@2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_closed_place_waypoint_alert_night_32pt@3x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_closed_place_waypoint_alert_night_32pt@3x.png new file mode 100755 index 00000000..d73437bf Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_closed_place_waypoint_alert_night_32pt@3x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle.png new file mode 100755 index 00000000..db933c80 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle@2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle@2x.png new file mode 100755 index 00000000..65fee675 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle@2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle_32pt.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle_32pt.png new file mode 100755 index 00000000..a765b86d Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle_32pt.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle_32pt@2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle_32pt@2x.png new file mode 100755 index 00000000..01a79a69 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle_32pt@2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle_32pt@3x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle_32pt@3x.png new file mode 100755 index 00000000..90542c30 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle_32pt@3x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle_large.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle_large.png new file mode 100755 index 00000000..21d2e709 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle_large.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle_large@2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle_large@2x.png new file mode 100755 index 00000000..3aaa92b6 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle_large@2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle_large@3x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle_large@3x.png new file mode 100755 index 00000000..9cb93b78 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_compass_needle_large@3x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_border_waypoint_alert_32pt.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_border_waypoint_alert_32pt.png new file mode 100755 index 00000000..15d18be3 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_border_waypoint_alert_32pt.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_border_waypoint_alert_32pt@2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_border_waypoint_alert_32pt@2x.png new file mode 100755 index 00000000..3d59b085 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_border_waypoint_alert_32pt@2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_border_waypoint_alert_32pt@3x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_border_waypoint_alert_32pt@3x.png new file mode 100755 index 00000000..f478c9bd Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_border_waypoint_alert_32pt@3x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_checkpoint_waypoint_alert_32pt.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_checkpoint_waypoint_alert_32pt.png new file mode 100755 index 00000000..06a98828 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_checkpoint_waypoint_alert_32pt.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_checkpoint_waypoint_alert_32pt@2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_checkpoint_waypoint_alert_32pt@2x.png new file mode 100755 index 00000000..db9bc9a2 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_checkpoint_waypoint_alert_32pt@2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_checkpoint_waypoint_alert_32pt@3x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_checkpoint_waypoint_alert_32pt@3x.png new file mode 100755 index 00000000..44a93a86 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_checkpoint_waypoint_alert_32pt@3x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_checkpoint_waypoint_alert_night_32pt.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_checkpoint_waypoint_alert_night_32pt.png new file mode 100755 index 00000000..453bc6ee Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_checkpoint_waypoint_alert_night_32pt.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_checkpoint_waypoint_alert_night_32pt@2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_checkpoint_waypoint_alert_night_32pt@2x.png new file mode 100755 index 00000000..f0f0e904 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_checkpoint_waypoint_alert_night_32pt@2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_checkpoint_waypoint_alert_night_32pt@3x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_checkpoint_waypoint_alert_night_32pt@3x.png new file mode 100755 index 00000000..a60770ca Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_checkpoint_waypoint_alert_night_32pt@3x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_medical_waypoint_alert_32pt.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_medical_waypoint_alert_32pt.png new file mode 100755 index 00000000..bd408df8 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_medical_waypoint_alert_32pt.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_medical_waypoint_alert_32pt@2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_medical_waypoint_alert_32pt@2x.png new file mode 100755 index 00000000..c8c176de Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_medical_waypoint_alert_32pt@2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_medical_waypoint_alert_32pt@3x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_medical_waypoint_alert_32pt@3x.png new file mode 100755 index 00000000..c70a31a1 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_medical_waypoint_alert_32pt@3x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_medical_waypoint_alert_night_32pt.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_medical_waypoint_alert_night_32pt.png new file mode 100755 index 00000000..81b60288 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_medical_waypoint_alert_night_32pt.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_medical_waypoint_alert_night_32pt@2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_medical_waypoint_alert_night_32pt@2x.png new file mode 100755 index 00000000..f631de5f Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_medical_waypoint_alert_night_32pt@2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_medical_waypoint_alert_night_32pt@3x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_medical_waypoint_alert_night_32pt@3x.png new file mode 100755 index 00000000..e07bccee Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_covid_medical_waypoint_alert_night_32pt@3x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_location_off.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_location_off.png new file mode 100755 index 00000000..2bf7984e Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_location_off.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_location_off@2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_location_off@2x.png new file mode 100755 index 00000000..565195fb Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_location_off@2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_location_off@3x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_location_off@3x.png new file mode 100755 index 00000000..4be8cb32 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_location_off@3x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_qu_direction_mylocation.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_qu_direction_mylocation.png new file mode 100755 index 00000000..dccdcfd4 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_qu_direction_mylocation.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_qu_direction_mylocation@2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_qu_direction_mylocation@2x.png new file mode 100755 index 00000000..ccb840e4 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_qu_direction_mylocation@2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_qu_direction_mylocation@3x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_qu_direction_mylocation@3x.png new file mode 100755 index 00000000..0300f62e Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ic_qu_direction_mylocation@3x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/id.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/id.lproj/GMSCore.strings new file mode 100755 index 00000000..73141967 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/id.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/it.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/it.lproj/GMSCore.strings new file mode 100755 index 00000000..d78248fd Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/it.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ja.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ja.lproj/GMSCore.strings new file mode 100755 index 00000000..1495ebdc Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ja.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ka.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ka.lproj/GMSCore.strings new file mode 100755 index 00000000..3b9711da Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ka.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ko.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ko.lproj/GMSCore.strings new file mode 100755 index 00000000..ee6a254f Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ko.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/lt.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/lt.lproj/GMSCore.strings new file mode 100755 index 00000000..ab0f769c Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/lt.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/lv.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/lv.lproj/GMSCore.strings new file mode 100755 index 00000000..17b3913e Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/lv.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ms.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ms.lproj/GMSCore.strings new file mode 100755 index 00000000..a00271f9 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ms.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/my.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/my.lproj/GMSCore.strings new file mode 100755 index 00000000..6d2a46ca Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/my.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/nb.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/nb.lproj/GMSCore.strings new file mode 100755 index 00000000..a3b68054 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/nb.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/nl.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/nl.lproj/GMSCore.strings new file mode 100755 index 00000000..21c77cbc Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/nl.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/pl.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/pl.lproj/GMSCore.strings new file mode 100755 index 00000000..3294963e Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/pl.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/polyline_colors_texture.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/polyline_colors_texture.png new file mode 100755 index 00000000..23c22ba5 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/polyline_colors_texture.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/polyline_colors_texture_dim.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/polyline_colors_texture_dim.png new file mode 100755 index 00000000..05120207 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/polyline_colors_texture_dim.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/pt.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/pt.lproj/GMSCore.strings new file mode 100755 index 00000000..55b8a3b6 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/pt.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/pt_BR.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/pt_BR.lproj/GMSCore.strings new file mode 100755 index 00000000..55b8a3b6 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/pt_BR.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/pt_PT.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/pt_PT.lproj/GMSCore.strings new file mode 100755 index 00000000..738f6e1b Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/pt_PT.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ro.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ro.lproj/GMSCore.strings new file mode 100755 index 00000000..709dc67d Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ro.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_1-1.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_1-1.png new file mode 100755 index 00000000..b6ba5ec0 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_1-1.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_128-32.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_128-32.png new file mode 100755 index 00000000..08672e68 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_128-32.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_16-4.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_16-4.png new file mode 100755 index 00000000..ba0b0a55 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_16-4.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_2-1.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_2-1.png new file mode 100755 index 00000000..6317a5c3 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_2-1.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_256-64.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_256-64.png new file mode 100755 index 00000000..45a66a47 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_256-64.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_32-8.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_32-8.png new file mode 100755 index 00000000..ed0424b5 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_32-8.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_4-1.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_4-1.png new file mode 100755 index 00000000..b2efb5d4 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_4-1.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_64-16.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_64-16.png new file mode 100755 index 00000000..664e9f65 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_64-16.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_8-2.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_8-2.png new file mode 100755 index 00000000..dabc3522 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/road_8-2.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ru.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ru.lproj/GMSCore.strings new file mode 100755 index 00000000..7f1499bb Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/ru.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/sk.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/sk.lproj/GMSCore.strings new file mode 100755 index 00000000..79508966 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/sk.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/sq.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/sq.lproj/GMSCore.strings new file mode 100755 index 00000000..eb0c5f62 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/sq.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/sr.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/sr.lproj/GMSCore.strings new file mode 100755 index 00000000..2741a27d Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/sr.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/sv.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/sv.lproj/GMSCore.strings new file mode 100755 index 00000000..5d3434a6 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/sv.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/sw.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/sw.lproj/GMSCore.strings new file mode 100755 index 00000000..9fa3dc97 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/sw.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/th.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/th.lproj/GMSCore.strings new file mode 100755 index 00000000..d6436541 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/th.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/tr.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/tr.lproj/GMSCore.strings new file mode 100755 index 00000000..0e549e1d Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/tr.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/uk.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/uk.lproj/GMSCore.strings new file mode 100755 index 00000000..19927a81 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/uk.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/vi.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/vi.lproj/GMSCore.strings new file mode 100755 index 00000000..c165157d Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/vi.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/zh_CN.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/zh_CN.lproj/GMSCore.strings new file mode 100755 index 00000000..22f6eb1f Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/zh_CN.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/zh_HK.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/zh_HK.lproj/GMSCore.strings new file mode 100755 index 00000000..fc14ec8b Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/zh_HK.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/zh_TW.lproj/GMSCore.strings b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/zh_TW.lproj/GMSCore.strings new file mode 100755 index 00000000..eb0695c4 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/GMSCoreResources.bundle/zh_TW.lproj/GMSCore.strings differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/Info.plist b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/Info.plist new file mode 100755 index 00000000..962000e0 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/Info.plist differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/bubble_left.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/bubble_left.png new file mode 100755 index 00000000..c8e4a419 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/bubble_left.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/bubble_left@2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/bubble_left@2x.png new file mode 100755 index 00000000..3e8fdcae Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/bubble_left@2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/bubble_left@3x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/bubble_left@3x.png new file mode 100755 index 00000000..1d8aee7b Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/bubble_left@3x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/bubble_right.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/bubble_right.png new file mode 100755 index 00000000..61897145 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/bubble_right.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/bubble_right@2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/bubble_right@2x.png new file mode 100755 index 00000000..8abc3f78 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/bubble_right@2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/bubble_right@3x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/bubble_right@3x.png new file mode 100755 index 00000000..7c35f064 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/bubble_right@3x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/ic_error.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/ic_error.png new file mode 100755 index 00000000..c74eda99 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/ic_error.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/ic_error@2x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/ic_error@2x.png new file mode 100755 index 00000000..a640b5ac Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/ic_error@2x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/ic_error@3x.png b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/ic_error@3x.png new file mode 100755 index 00000000..a4ecc4ba Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/ic_error@3x.png differ diff --git a/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/oss_licenses_maps.txt.gz b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/oss_licenses_maps.txt.gz new file mode 100755 index 00000000..50f2a2a6 Binary files /dev/null and b/HackIllinois/GoogleMaps.framework/Resources/GoogleMaps.bundle/oss_licenses_maps.txt.gz differ diff --git a/HackIllinois/GoogleMapsBase.framework/GoogleMapsBase b/HackIllinois/GoogleMapsBase.framework/GoogleMapsBase new file mode 100755 index 00000000..e8d243de Binary files /dev/null and b/HackIllinois/GoogleMapsBase.framework/GoogleMapsBase differ diff --git a/HackIllinois/GoogleMapsBase.framework/Headers/GMSCompatabilityMacros.h b/HackIllinois/GoogleMapsBase.framework/Headers/GMSCompatabilityMacros.h new file mode 100755 index 00000000..1d58b003 --- /dev/null +++ b/HackIllinois/GoogleMapsBase.framework/Headers/GMSCompatabilityMacros.h @@ -0,0 +1,19 @@ +// +// GMSCompatabilityMacros.h +// Google Maps SDK for iOS +// +// Copyright 2015 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +#if defined(SWIFT_SDK_OVERLAY_UIKIT_EPOCH) +#define GMS_SWIFT_NAME_2_0_3_0(name_swift_2, name_swift_3) \ + NS_SWIFT_NAME(name_swift_3) +#else +#define GMS_SWIFT_NAME_2_0_3_0(name_swift_2, name_swift_3) \ + NS_SWIFT_NAME(name_swift_2) +#endif diff --git a/HackIllinois/GoogleMapsBase.framework/Headers/GMSCoordinateBounds.h b/HackIllinois/GoogleMapsBase.framework/Headers/GMSCoordinateBounds.h new file mode 100755 index 00000000..0f6c2cdb --- /dev/null +++ b/HackIllinois/GoogleMapsBase.framework/Headers/GMSCoordinateBounds.h @@ -0,0 +1,75 @@ +// +// GMSCoordinateBounds.h +// Google Maps SDK for iOS +// +// Copyright 2013 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#import + +NS_ASSUME_NONNULL_BEGIN + +/** + * GMSCoordinateBounds represents a rectangular bounding box on the Earth's surface. + * GMSCoordinateBounds is immutable and can't be modified after construction. + */ +@interface GMSCoordinateBounds : NSObject + +/** The North-East corner of these bounds. */ +@property(nonatomic, readonly) CLLocationCoordinate2D northEast; + +/** The South-West corner of these bounds. */ +@property(nonatomic, readonly) CLLocationCoordinate2D southWest; + +/** + * Returns NO if this bounds does not contain any points. For example, + * [[GMSCoordinateBounds alloc] init].valid == NO. + * + * When an invalid bounds is expanded with valid coordinates via includingCoordinate: or + * includingBounds:, the resulting bounds will be valid but contain only the new coordinates. + */ +@property(nonatomic, readonly, getter=isValid) BOOL valid; + +/** + * Inits the northEast and southWest bounds corresponding to the rectangular region defined by the + * two corners. + * + * It is ambiguous whether the longitude of the box extends from |coord1| to |coord2| or vice-versa; + * the box is constructed as the smaller of the two variants, eliminating the ambiguity. + */ +- (id)initWithCoordinate:(CLLocationCoordinate2D)coord1 coordinate:(CLLocationCoordinate2D)coord2; + +/** + * Returns a GMSCoordinateBounds representing the current bounds extended to include the passed-in + * coordinate. + * + * If the current bounds is invalid, the result is a valid bounds containing only |coordinate|. + */ +- (GMSCoordinateBounds *)includingCoordinate:(CLLocationCoordinate2D)coordinate; + +/** + * Returns a GMSCoordinateBounds representing the current bounds extended to include the entire + * other bounds. + * + * If the current bounds is invalid, the result is a valid bounds equal to |other|. + */ +- (GMSCoordinateBounds *)includingBounds:(GMSCoordinateBounds *)other; + +/** + * Returns YES if |coordinate| is contained within this bounds. This includes points that lie + * exactly on the edge of the bounds. + */ +- (BOOL)containsCoordinate:(CLLocationCoordinate2D)coordinate; + +/** + * Returns YES if |other| overlaps with this bounds. Two bounds are overlapping if there is at least + * one coordinate point contained by both. + */ +- (BOOL)intersectsBounds:(GMSCoordinateBounds *)other; + +@end + +NS_ASSUME_NONNULL_END diff --git a/HackIllinois/GoogleMapsBase.framework/Headers/GMSDeprecationMacros.h b/HackIllinois/GoogleMapsBase.framework/Headers/GMSDeprecationMacros.h new file mode 100755 index 00000000..6000d968 --- /dev/null +++ b/HackIllinois/GoogleMapsBase.framework/Headers/GMSDeprecationMacros.h @@ -0,0 +1,22 @@ +// +// GMSDeprecationMacros.h +// Google Maps SDK for iOS +// +// Copyright 2015 Google LLC +// +// Usage of this SDK is subject to the Google Maps/Google Earth APIs Terms of +// Service: https://developers.google.com/maps/terms +// + +#ifndef IPHONE_MAPS_SDK_BASE_API_GMSDEPRECATIONMACROS_H_ +#define IPHONE_MAPS_SDK_BASE_API_GMSDEPRECATIONMACROS_H_ + +#ifndef __GMS_AVAILABLE_BUT_DEPRECATED +#define __GMS_AVAILABLE_BUT_DEPRECATED __deprecated +#endif + +#ifndef __GMS_AVAILABLE_BUT_DEPRECATED_MSG +#define __GMS_AVAILABLE_BUT_DEPRECATED_MSG(msg) __deprecated_msg(msg) +#endif + +#endif diff --git a/HackIllinois/GoogleMapsBase.framework/Headers/GoogleMapsBase.h b/HackIllinois/GoogleMapsBase.framework/Headers/GoogleMapsBase.h new file mode 100755 index 00000000..95ec44c0 --- /dev/null +++ b/HackIllinois/GoogleMapsBase.framework/Headers/GoogleMapsBase.h @@ -0,0 +1,3 @@ +#import "GMSCompatabilityMacros.h" +#import "GMSCoordinateBounds.h" +#import "GMSDeprecationMacros.h" diff --git a/HackIllinois/GoogleMapsBase.framework/Modules/module.modulemap b/HackIllinois/GoogleMapsBase.framework/Modules/module.modulemap new file mode 100755 index 00000000..ad1d2fba --- /dev/null +++ b/HackIllinois/GoogleMapsBase.framework/Modules/module.modulemap @@ -0,0 +1,15 @@ +framework module GoogleMapsBase { + umbrella header "GoogleMapsBase.h" + export * + module * { export * } + link "z" + link framework "CoreFoundation" + link framework "CoreGraphics" + link framework "CoreLocation" + link framework "CoreTelephony" + link framework "CoreText" + link framework "Foundation" + link framework "QuartzCore" + link framework "Security" + link framework "UIKit" +} diff --git a/HackIllinois/GoogleMapsCore.framework/GoogleMapsCore b/HackIllinois/GoogleMapsCore.framework/GoogleMapsCore new file mode 100755 index 00000000..b99da4dc Binary files /dev/null and b/HackIllinois/GoogleMapsCore.framework/GoogleMapsCore differ diff --git a/HackIllinois/GoogleMapsCore.framework/Modules/module.modulemap b/HackIllinois/GoogleMapsCore.framework/Modules/module.modulemap new file mode 100755 index 00000000..7e481676 --- /dev/null +++ b/HackIllinois/GoogleMapsCore.framework/Modules/module.modulemap @@ -0,0 +1,21 @@ +framework module GoogleMapsCore { + export * + link "m" + link "z" + link framework "CoreData" + link framework "CoreFoundation" + link framework "CoreGraphics" + link framework "CoreImage" + link framework "CoreLocation" + link framework "CoreTelephony" + link framework "CoreText" + link framework "Foundation" + link framework "GLKit" + link framework "ImageIO" + link framework "Metal" + link framework "OpenGLES" + link framework "QuartzCore" + link framework "Security" + link framework "SystemConfiguration" + link framework "UIKit" +} diff --git a/HackIllinois/Info.plist b/HackIllinois/Info.plist index cd70585b..5674f670 100644 --- a/HackIllinois/Info.plist +++ b/HackIllinois/Info.plist @@ -39,6 +39,10 @@ Used to scan in attendees for events NSLocationWhenInUseUsageDescription Used to display your current location in maps + UIAppFonts + + Montserrat-VariableFont_wght.ttf + UIBackgroundModes remote-notification diff --git a/HackIllinois/Misc/Constants.swift b/HackIllinois/Misc/Constants.swift index 1c390f00..be84ef95 100644 --- a/HackIllinois/Misc/Constants.swift +++ b/HackIllinois/Misc/Constants.swift @@ -23,8 +23,23 @@ struct HIConstants { return "org.hackillinois.ios.pass_prompted_\(user.id)" } // Images - static let PROFILE_IMAGES: [String: HIImage] = ["https://hackillinois-upload.s3.amazonaws.com/photos/profiles-2022/profile-0.png": \.profile0, "https://hackillinois-upload.s3.amazonaws.com/photos/profiles-2022/profile-1.png": \.profile1, "https://hackillinois-upload.s3.amazonaws.com/photos/profiles-2022/profile-2.png": \.profile2, "https://hackillinois-upload.s3.amazonaws.com/photos/profiles-2022/profile-3.png": \.profile3, "https://hackillinois-upload.s3.amazonaws.com/photos/profiles-2022/profile-4.png": \.profile4, "https://hackillinois-upload.s3.amazonaws.com/photos/profiles-2022/profile-5.png": \.profile5, "https://hackillinois-upload.s3.amazonaws.com/photos/profiles-2022/profile-6.png": \.profile6, "https://hackillinois-upload.s3.amazonaws.com/photos/profiles-2022/profile-7.png": \.profile7, "https://hackillinois-upload.s3.amazonaws.com/photos/profiles-2022/profile-8.png": \.profile8, "https://hackillinois-upload.s3.amazonaws.com/photos/profiles-2022/profile-9.png": \.profile9, "https://hackillinois-upload.s3.amazonaws.com/photos/profiles-2022/profile-10.png": \.profile10] + private static let url = "https://hackillinois-upload.s3.amazonaws.com/photos/profiles-2022/" + + static let PROFILE_IMAGES: [String: HIImage] = [ + "\(url)profile-0.png": \.profile0, + "\(url)profile-1.png": \.profile1, + "\(url)/profile-2.png": \.profile2, + "\(url)/profile-3.png": \.profile3, + "\(url)/profile-4.png": \.profile4, + "\(url)/profile-5.png": \.profile5, + "\(url)/profile-6.png": \.profile6, + "\(url)/profile-7.png": \.profile7, + "\(url)/profile-8.png": \.profile8, + "\(url)/profile-9.png": \.profile9, + "\(url)/profile-10.png": \.profile10 + ] static let LEADERBOARD_PROFILE_LIMIT = 10 static let MAX_EVENT_DESCRIPTION_LENGTH = 75 static let ASYNC_EVENT_TIME_TEXT = "All Day" + static let ONLINE_EVENT_LOCATION_TEXT = "Online" } diff --git a/HackIllinois/Misc/Formatters.swift b/HackIllinois/Misc/Formatters.swift index caf8ae16..1b0bdea8 100644 --- a/HackIllinois/Misc/Formatters.swift +++ b/HackIllinois/Misc/Formatters.swift @@ -41,45 +41,45 @@ extension Date { switch timeSinceDate { // YEARS - case (2 * YEAR_IN_SECONDS)... : + case (2 * YEAR_IN_SECONDS)...: let years = Int(floor(timeSinceDate/YEAR_IN_SECONDS)) return "\(years)y ago" - case (1 * YEAR_IN_SECONDS)... : + case (1 * YEAR_IN_SECONDS)...: return "last year" // MONTH - case (2 * MONTH_IN_SECONDS)... : + case (2 * MONTH_IN_SECONDS)...: let month = Int(floor(timeSinceDate/MONTH_IN_SECONDS)) return "\(month)mo ago" - case (1 * MONTH_IN_SECONDS)... : + case (1 * MONTH_IN_SECONDS)...: return "last month" // WEEK - case (2 * WEEK_IN_SECONDS)... : + case (2 * WEEK_IN_SECONDS)...: let week = Int(floor(timeSinceDate/WEEK_IN_SECONDS)) return "\(week)w ago" - case (1 * WEEK_IN_SECONDS)... : + case (1 * WEEK_IN_SECONDS)...: return "last week" // DAY - case (2 * DAY_IN_SECONDS)... : + case (2 * DAY_IN_SECONDS)...: let day = Int(floor(timeSinceDate/DAY_IN_SECONDS)) return "\(day)d ago" - case (1 * DAY_IN_SECONDS)... : + case (1 * DAY_IN_SECONDS)...: return "yesterday" // HOUR - case (2 * HOUR_IN_SECONDS)... : + case (2 * HOUR_IN_SECONDS)...: let hour = Int(floor(timeSinceDate/HOUR_IN_SECONDS)) return "\(hour)h ago" - case (1 * HOUR_IN_SECONDS)... : + case (1 * HOUR_IN_SECONDS)...: return "an hour ago" // MINUTE - case (2 * MINUTE_IN_SECONDS)... : + case (2 * MINUTE_IN_SECONDS)...: let minute = Int(floor(timeSinceDate/MINUTE_IN_SECONDS)) return "\(minute)m ago" - case (1 * MINUTE_IN_SECONDS)... : + case (1 * MINUTE_IN_SECONDS)...: return "a minute ago" // SECOND diff --git a/HackIllinois/Misc/MixTypeComparable.swift b/HackIllinois/Misc/MixTypeComparable.swift index 40ccc65b..89847d6e 100644 --- a/HackIllinois/Misc/MixTypeComparable.swift +++ b/HackIllinois/Misc/MixTypeComparable.swift @@ -19,11 +19,11 @@ protocol MixTypeComparable: Comparable { } extension MixTypeComparable { - public static func <(lhs: Self, rhs: Other) -> Bool where Other: MixTypeComparable, Self.ComparableType == Other.ComparableType { + public static func < (lhs: Self, rhs: Other) -> Bool where Other: MixTypeComparable, Self.ComparableType == Other.ComparableType { return lhs.comparable < rhs.comparable } - public static func ==(lhs: Self, rhs: Other) -> Bool where Other: MixTypeComparable, Self.ComparableType == Other.ComparableType { + public static func == (lhs: Self, rhs: Other) -> Bool where Other: MixTypeComparable, Self.ComparableType == Other.ComparableType { return lhs.comparable == rhs.comparable } } diff --git a/HackIllinois/Models/CoreDataModels/HackIllinois.xcdatamodeld/HackIllinois.xcdatamodel/contents b/HackIllinois/Models/CoreDataModels/HackIllinois.xcdatamodeld/HackIllinois.xcdatamodel/contents index c38e5fc5..90825541 100644 --- a/HackIllinois/Models/CoreDataModels/HackIllinois.xcdatamodeld/HackIllinois.xcdatamodel/contents +++ b/HackIllinois/Models/CoreDataModels/HackIllinois.xcdatamodeld/HackIllinois.xcdatamodel/contents @@ -1,5 +1,5 @@ - + @@ -74,12 +74,4 @@ - - - - - - - - \ No newline at end of file diff --git a/HackIllinois/Models/HIProfile.swift b/HackIllinois/Models/HIProfile.swift index 74419031..a5cbe5d8 100644 --- a/HackIllinois/Models/HIProfile.swift +++ b/HackIllinois/Models/HIProfile.swift @@ -25,6 +25,7 @@ struct HIProfile: Codable { var firstName = "" var lastName = "" var points = 0 + var foodWave = 0 var timezone = "" var discord = "" var avatarUrl = "" diff --git a/HackIllinois/SwiftUI/HIOnboardingView.swift b/HackIllinois/SwiftUI/HIOnboardingView.swift new file mode 100644 index 00000000..7a8f376e --- /dev/null +++ b/HackIllinois/SwiftUI/HIOnboardingView.swift @@ -0,0 +1,79 @@ +// +// HIOnboardingView.swift +// HackIllinois +// +// Created by HackIllinois Team on 10/29/22. +// Copyright © 2022 HackIllinois. All rights reserved. +// This file is part of the Hackillinois iOS App. +// The Hackillinois iOS App is open source software, released under the University of +// Illinois/NCSA Open Source License. You should have received a copy of +// this license in a file with the distribution. +// + +import Foundation +import SwiftUI +import UIKit +import Lottie + +struct HIOnboardingView: View { + @StateObject private var viewModel = HIOnboardingViewModel() + var body: some View { + ZStack { + Image("Login") + .resizable() + .ignoresSafeArea() + .zIndex(-1) + if viewModel.shouldDisplayAnimationOnNextAppearance { + VStack { + LottieView(shouldDisplayAnimationOnNextAppearance: $viewModel.shouldDisplayAnimationOnNextAppearance) + } + } else { + VStack { + Spacer() + HICarouselSwiftUIView(carouselData: viewModel.data) + Button { + NotificationCenter.default.post(name: .getStarted, object: nil) + }label: { + Text("GET STARTED") + .font(.title2.bold()) + .tracking(3) + } + .padding() + .font(.title3.bold()) + .frame(width: 350, height: 50) + .foregroundColor(.white) + .background(Color.clear) + .overlay(RoundedRectangle(cornerRadius: 20) + .stroke(.white, lineWidth: 5)) + Spacer() + } + } + } + } +} + +// MARK: - SwiftUI => LottieView +struct LottieView: UIViewRepresentable { + @Binding var shouldDisplayAnimationOnNextAppearance: Bool + func makeUIView(context: UIViewRepresentableContext) -> UIView { + let view = UIView(frame: .zero) + let animationView = LottieAnimationView(name: "Hack_PopcornCart_Text") + animationView.contentMode = .scaleAspectFit + animationView.frame = view.frame + animationView.autoresizingMask = [.flexibleWidth, .flexibleHeight] + view.addSubview(animationView) + animationView.play { _ in + withAnimation(.easeInOut(duration: 1)) { + shouldDisplayAnimationOnNextAppearance.toggle() + } + } + return view + } + func updateUIView(_ uiView: UIViewType, context: Context) { return } +} + +struct HIOnboardingView_Previews: PreviewProvider { + static var previews: some View { + HIOnboardingView() + } +} diff --git a/HackIllinois/SwiftUI/HIOnboardingViewModel.swift b/HackIllinois/SwiftUI/HIOnboardingViewModel.swift new file mode 100644 index 00000000..199247b4 --- /dev/null +++ b/HackIllinois/SwiftUI/HIOnboardingViewModel.swift @@ -0,0 +1,32 @@ +// +// HIOnboardingViewModel.swift +// HackIllinois +// +// Created by HackIllinois Team on 10/30/22. +// Copyright © 2022 HackIllinois. All rights reserved. +// This file is part of the Hackillinois iOS App. +// The Hackillinois iOS App is open source software, released under the University of +// Illinois/NCSA Open Source License. You should have received a copy of +// this license in a file with the distribution. +// + +import SwiftUI + +class HIOnboardingViewModel: ObservableObject { + @Published var data: [CarouselData] = UIDevice.current.userInterfaceIdiom == .pad ? [ + CarouselData(image: #imageLiteral(resourceName: "Onboarding0"), titleText: "Welcome!", descriptionText: "Swipe to see what our app has to offer!"), + CarouselData(image: UIImage(named: "iPadOnboarding0"), titleText: "Home", descriptionText: "See how much time you have left to hack!"), + CarouselData(image: UIImage(named: "iPadOnboarding1"), titleText: "Schedule", descriptionText: "See the times and details of all of our events."), + CarouselData(image: UIImage(named: "iPadOnboarding2"), titleText: "Scan for Points", descriptionText: "Scan QR codes at events to obtain points!"), + CarouselData(image: UIImage(named: "iPadOnboarding3"), titleText: "Profile", descriptionText: "View your points, tier, and other personal information."), + CarouselData(image: UIImage(named: "iPadOnboarding4"), titleText: "Leaderboard", descriptionText: "See who is leading HackIllinois 2023 in points earned!") + ] : [ + CarouselData(image: #imageLiteral(resourceName: "Onboarding0"), titleText: "Welcome!", descriptionText: "Swipe to see what our app has to offer!"), + CarouselData(image: UIImage(named: "Onboarding1"), titleText: "Home", descriptionText: "See how much time you have left to hack!"), + CarouselData(image: UIImage(named: "Onboarding2"), titleText: "Schedule", descriptionText: "See the times and details of all of our events."), + CarouselData(image: UIImage(named: "Onboarding3"), titleText: "Scan for Points", descriptionText: "Scan QR codes at events to obtain points!"), + CarouselData(image: UIImage(named: "Onboarding4"), titleText: "Profile", descriptionText: "View your points, tier, and other personal information."), + CarouselData(image: UIImage(named: "Onboarding5"), titleText: "Leaderboard", descriptionText: "See who is leading HackIllinois 2023 in points earned!") + ] + @Published var shouldDisplayAnimationOnNextAppearance = true +} diff --git a/HackIllinois/SwiftUI/UI/HICarouselSwiftUIView.swift b/HackIllinois/SwiftUI/UI/HICarouselSwiftUIView.swift new file mode 100644 index 00000000..27a2a89d --- /dev/null +++ b/HackIllinois/SwiftUI/UI/HICarouselSwiftUIView.swift @@ -0,0 +1,97 @@ +// +// HICarouselSwiftUIView.swift +// HackIllinois +// +// Created by HackIllinois Team on 10/29/22. +// Copyright © 2022 HackIllinois. All rights reserved. +// This file is part of the Hackillinois iOS App. +// The Hackillinois iOS App is open source software, released under the University of +// Illinois/NCSA Open Source License. You should have received a copy of +// this license in a file with the distribution. +// + +import Foundation +import SwiftUI + +struct CarouselData: Hashable { + let image: UIImage? + let titleText: String + let descriptionText: String +} + +struct HICarouselSwiftUIView: View { + var carouselData: [CarouselData] + @State private var currentIndex = 0 + var body: some View { + VStack { + TabView(selection: $currentIndex) { + ForEach(0.. HILabel +struct HILableSUI: UIViewRepresentable { + var text: String + var style: HILabel.Style? + func makeUIView(context: Context) -> UILabel { + let label = HILabel(style: style) + label.text = text + return label + } + func updateUIView(_ uiView: UILabel, context: Context) { + return + } +} + +struct CarouselSwiftUIView_Previews: PreviewProvider { + static var previews: some View { + HIOnboardingView() + } +} diff --git a/HackIllinois/SwiftUI/UI/Hack_PopcornCart_Text.json b/HackIllinois/SwiftUI/UI/Hack_PopcornCart_Text.json new file mode 100644 index 00000000..8ee0e1dc --- /dev/null +++ b/HackIllinois/SwiftUI/UI/Hack_PopcornCart_Text.json @@ -0,0 +1 @@ +{"v":"4.8.0","meta":{"g":"LottieFiles AE 3.1.1","a":"","k":"","d":"","tc":""},"fr":24,"ip":0,"op":120,"w":491,"h":600,"nm":"Hack_PopcornCart_Rigged","ddd":0,"assets":[{"id":"image_0","w":491,"h":486,"u":"","p":"","e":1},{"id":"image_1","w":491,"h":486,"u":"","p":"","e":1},{"id":"image_2","w":491,"h":486,"u":"","p":"","e":1},{"id":"image_3","w":491,"h":486,"u":"","p":"","e":1},{"id":"image_4","w":491,"h":486,"u":"","p":"","e":1},{"id":"image_5","w":491,"h":486,"u":"","p":"","e":1},{"id":"image_6","w":491,"h":486,"u":"","p":"","e":1},{"id":"image_7","w":491,"h":486,"u":"","p":"","e":1},{"id":"image_8","w":491,"h":486,"u":"","p":"","e":1},{"id":"image_9","w":491,"h":486,"u":"","p":"","e":1}],"layers":[{"ddd":0,"ind":1,"ty":4,"nm":"Preparing for the Day 3 Outlines","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[255.656,525.729,0],"to":[0,-1,0],"ti":[0,1,0]},{"t":77,"s":[255.656,519.729,0]}],"ix":2},"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[17.43,17.43,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[27.795,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,23.264]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[27.795,0],[0,-23.415]],"v":[[-775.394,-254.445],[-818.9,-254.445],[-818.9,-148.702],[-799.262,-148.702],[-799.262,-179.216],[-775.394,-179.216],[-730.378,-216.831]],"c":true},"ix":2},"nm":"P","mn":"ADBE Vector Shape - Group","hd":false},{"ind":1,"ty":"sh","ix":2,"ks":{"a":0,"k":{"i":[[17.221,0],[0,0],[0,0],[0,0],[0,-13.293]],"o":[[0,0],[0,0],[0,0],[17.221,0],[0,13.293]],"v":[[-776.301,-195.833],[-799.262,-195.833],[-799.262,-237.828],[-776.301,-237.828],[-750.167,-216.831]],"c":true},"ix":2},"nm":"P","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"mm","mm":1,"nm":"Merge Paths 1","mn":"ADBE Vector Filter - Merge","hd":false},{"ty":"fl","c":{"a":0,"k":[0.964705882353,0.956862745098,0.823529411765,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":0,"s":[0,0],"to":[0,16.443],"ti":[0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":1.602,"s":[0,98.66],"to":[0,0],"ti":[0,16.443]},{"t":20.0205078125,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":0,"s":[100]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":1.602,"s":[50]},{"t":20.0205078125,"s":[100]}],"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"P","np":5,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[5.438,-8.459],[0,0],[0,0],[0,0],[0,0],[0,0],[-14.351,0],[-1.662,-0.302],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,-16.466],[1.36,0],[0,0],[-13.445,0]],"v":[[-696.087,-217.586],[-696.087,-229.369],[-714.063,-229.369],[-714.063,-148.702],[-695.18,-148.702],[-695.18,-187.827],[-671.766,-212.752],[-667.385,-212.299],[-667.385,-230.275]],"c":true},"ix":2},"nm":"r","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.964705882353,0.956862745098,0.823529411765,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":0,"s":[0,0],"to":[0,25.346],"ti":[0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":3.203,"s":[0,152.074],"to":[0,0],"ti":[0,25.346]},{"t":22.4228515625,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":0,"s":[100]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":3.203,"s":[30]},{"t":22.4228515625,"s":[100]}],"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"r","np":3,"cix":2,"bm":0,"ix":2,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,1.511],[23.566,0],[0,-24.019],[-27.04,0],[-7.251,8.611],[0,0],[9.064,0],[2.266,11.783],[0,0]],"o":[[0,-25.227],[-24.019,0],[0,24.019],[13.898,0],[0,0],[-5.74,5.891],[-14.049,0],[0,0],[0.151,-1.813]],"v":[[-576.73,-188.582],[-617.517,-230.275],[-659.21,-189.035],[-614.646,-147.644],[-582.168,-160.787],[-592.289,-172.418],[-614.193,-163.657],[-640.327,-182.993],[-577.032,-182.993]],"c":true},"ix":2},"nm":"e","mn":"ADBE Vector Shape - Group","hd":false},{"ind":1,"ty":"sh","ix":2,"ks":{"a":0,"k":{"i":[[-12.236,0],[-1.511,-11.632],[0,0]],"o":[[12.387,0],[0,0],[1.813,-11.783]],"v":[[-617.517,-215.169],[-594.706,-195.531],[-640.478,-195.531]],"c":true},"ix":2},"nm":"e","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"mm","mm":1,"nm":"Merge Paths 1","mn":"ADBE Vector Filter - Merge","hd":false},{"ty":"fl","c":{"a":0,"k":[0.964705882353,0.956862745098,0.823529411765,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0.288},"t":1.602,"s":[0,0],"to":[0,59.589],"ti":[0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":4.004,"s":[0,203.414],"to":[0,0],"ti":[0,33.902]},{"t":25.6259765625,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0.288]},"t":1.602,"s":[100]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":4.004,"s":[0]},{"t":25.6259765625,"s":[100]}],"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"e","np":5,"cix":2,"bm":0,"ix":3,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[23.566,0],[6.345,-7.704],[0,0],[0,0],[0,0],[0,0],[0,0],[-10.272,0],[0,25.076]],"o":[[-11.028,0],[0,0],[0,0],[0,0],[0,0],[0,0],[6.496,7.402],[23.566,0],[0,-24.925]],"v":[[-514.549,-230.275],[-541.287,-218.794],[-541.287,-229.369],[-559.263,-229.369],[-559.263,-119.396],[-540.38,-119.396],[-540.38,-158.521],[-514.549,-147.644],[-473.611,-189.035]],"c":true},"ix":2},"nm":"p","mn":"ADBE Vector Shape - Group","hd":false},{"ind":1,"ty":"sh","ix":2,"ks":{"a":0,"k":{"i":[[13.596,0],[0,15.408],[-13.596,0],[0,-15.408]],"o":[[-13.596,0],[0,-15.408],[13.596,0],[0,15.408]],"v":[[-516.663,-163.808],[-540.682,-189.035],[-516.663,-214.263],[-492.796,-189.035]],"c":true},"ix":2},"nm":"p","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"mm","mm":1,"nm":"Merge Paths 1","mn":"ADBE Vector Filter - Merge","hd":false},{"ty":"fl","c":{"a":0,"k":[0.964705882353,0.956862745098,0.823529411765,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0.28},"t":2.402,"s":[0,0],"to":[0,57.24],"ti":[0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":5.605,"s":[0,201.633],"to":[0,0],"ti":[0,33.605]},{"t":24.8251953125,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0.28]},"t":2.402,"s":[100]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":5.605,"s":[0]},{"t":24.8251953125,"s":[100]}],"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"p","np":5,"cix":2,"bm":0,"ix":4,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[23.264,0],[8.611,-6.647],[0,0],[-9.064,0],[0,-11.028],[0,0],[0,0],[0,-13.445],[-18.43,0],[-4.532,6.949],[0,0],[0,0],[0,0]],"o":[[-12.991,0],[0,0],[6.042,-4.985],[13.445,0],[0,0],[0,0],[-24.472,0],[0,14.049],[12.085,0],[0,0],[0,0],[0,0],[0,-23.264]],"v":[[-426.596,-230.275],[-460.736,-220.305],[-453.334,-206.558],[-428.862,-214.565],[-408.771,-197.041],[-408.771,-195.833],[-429.618,-195.833],[-463.153,-171.814],[-433.092,-147.644],[-407.714,-158.521],[-407.714,-148.702],[-389.888,-148.702],[-389.888,-195.984]],"c":true},"ix":2},"nm":"a","mn":"ADBE Vector Shape - Group","hd":false},{"ind":1,"ty":"sh","ix":2,"ks":{"a":0,"k":{"i":[[9.215,0],[0,6.798],[-12.84,0],[0,0],[0,0]],"o":[[-9.668,0],[0,-5.891],[0,0],[0,0],[-3.172,8.308]],"v":[[-429.164,-161.391],[-444.573,-172.569],[-428.258,-183.295],[-408.771,-183.295],[-408.771,-173.929]],"c":true},"ix":2},"nm":"a","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"mm","mm":1,"nm":"Merge Paths 1","mn":"ADBE Vector Filter - Merge","hd":false},{"ty":"fl","c":{"a":0,"k":[0.964705882353,0.956862745098,0.823529411765,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":3.203,"s":[0,0],"to":[0,34.024],"ti":[0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":7.207,"s":[0,204.145],"to":[0,0],"ti":[0,34.024]},{"t":27.2275390625,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":3.203,"s":[100]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":7.207,"s":[0]},{"t":27.2275390625,"s":[100]}],"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"a","np":5,"cix":2,"bm":0,"ix":5,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[5.438,-8.459],[0,0],[0,0],[0,0],[0,0],[0,0],[-14.351,0],[-1.662,-0.302],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,-16.466],[1.36,0],[0,0],[-13.445,0]],"v":[[-348.387,-217.586],[-348.387,-229.369],[-366.363,-229.369],[-366.363,-148.702],[-347.48,-148.702],[-347.48,-187.827],[-324.066,-212.752],[-319.685,-212.299],[-319.685,-230.275]],"c":true},"ix":2},"nm":"r","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.964705882353,0.956862745098,0.823529411765,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0.277},"t":4.004,"s":[0,0],"to":[0,57.392],"ti":[0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":8.809,"s":[0,204.691],"to":[0,0],"ti":[0,34.115]},{"t":29.6298828125,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0.277]},"t":4.004,"s":[100]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":8.809,"s":[0]},{"t":29.6298828125,"s":[100]}],"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"r","np":3,"cix":2,"bm":0,"ix":6,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[-6.949,0],[0,6.647],[6.949,0],[0,-6.345]],"o":[[7.1,0],[0,-6.194],[-6.949,0],[0,6.345]],"v":[[-294.596,-242.662],[-282.511,-254.445],[-294.596,-265.322],[-306.681,-253.992]],"c":true},"ix":2},"nm":"i","mn":"ADBE Vector Shape - Group","hd":false},{"ind":1,"ty":"sh","ix":2,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[-304.113,-148.702],[-285.23,-148.702],[-285.23,-229.369],[-304.113,-229.369]],"c":true},"ix":2},"nm":"i","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"mm","mm":1,"nm":"Merge Paths 1","mn":"ADBE Vector Filter - Merge","hd":false},{"ty":"fl","c":{"a":0,"k":[0.964705882353,0.956862745098,0.823529411765,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":4.805,"s":[0,0],"to":[0,33.438],"ti":[0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":10.41,"s":[0,200.629],"to":[0,0],"ti":[0,33.438]},{"t":31.2314453125,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":4.805,"s":[100]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":10.41,"s":[0]},{"t":31.2314453125,"s":[100]}],"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"i","np":5,"cix":2,"bm":0,"ix":7,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[19.336,0],[6.194,-7.402],[0,0],[0,0],[0,0],[0,0],[0,0],[-13.445,0],[0,-14.351],[0,0],[0,0],[0,0]],"o":[[-11.783,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-16.164],[12.085,0],[0,0],[0,0],[0,0],[0,-24.321]],"v":[[-214.991,-230.275],[-242.787,-218.945],[-242.787,-229.369],[-260.763,-229.369],[-260.763,-148.702],[-241.88,-148.702],[-241.88,-189.488],[-219.372,-213.809],[-200.187,-192.51],[-200.187,-148.702],[-181.304,-148.702],[-181.304,-194.927]],"c":true},"ix":2},"nm":"n","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.964705882353,0.956862745098,0.823529411765,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":5.605,"s":[0,0],"to":[0,33.333],"ti":[0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":12.012,"s":[0,200],"to":[0,0],"ti":[0,33.333]},{"t":32.8330078125,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":5.605,"s":[100]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":12.012,"s":[0]},{"t":32.8330078125,"s":[100]}],"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"n","np":3,"cix":2,"bm":0,"ix":8,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[11.33,0],[0,-23.415],[-23.112,0],[-6.647,7.251],[0,0],[17.825,0],[7.1,5.891],[0,0],[-15.106,0],[0,29.306],[0,0]],"o":[[0,0],[-6.647,-8.006],[-23.112,0],[0,23.415],[10.876,0],[0,0],[0,16.315],[-11.179,0],[0,0],[9.215,7.553],[28.249,0],[0,0],[0,0]],"v":[[-95.176,-229.369],[-95.176,-218.643],[-123.123,-230.275],[-163.91,-191.452],[-123.123,-152.327],[-96.083,-163.053],[-96.083,-158.823],[-121.763,-134.351],[-151.523,-144.019],[-159.982,-129.819],[-120.706,-118.338],[-77.2,-160.938],[-77.2,-229.369]],"c":true},"ix":2},"nm":"g","mn":"ADBE Vector Shape - Group","hd":false},{"ind":1,"ty":"sh","ix":2,"ks":{"a":0,"k":{"i":[[14.2,0],[0,13.747],[-14.351,0],[0,-13.596]],"o":[[-14.351,0],[0,-13.596],[14.2,0],[0,13.747]],"v":[[-120.253,-168.34],[-144.876,-191.452],[-120.253,-214.263],[-95.781,-191.452]],"c":true},"ix":2},"nm":"g","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"mm","mm":1,"nm":"Merge Paths 1","mn":"ADBE Vector Filter - Merge","hd":false},{"ty":"fl","c":{"a":0,"k":[0.964705882353,0.956862745098,0.823529411765,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":6.406,"s":[0,0],"to":[0,33.333],"ti":[0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":12.812,"s":[0,200],"to":[0,0],"ti":[0,33.333]},{"t":36.0361328125,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":6.406,"s":[100]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":12.812,"s":[0]},{"t":36.0361328125,"s":[100]}],"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"g","np":5,"cix":2,"bm":0,"ix":9,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[-7.855,0],[-2.87,-1.964],[0,0],[6.496,0],[0,-16.919],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[3.928,0],[0,0],[-4.23,-3.021],[-18.732,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-8.611]],"v":[[21.018,-246.59],[31.441,-243.266],[36.728,-257.466],[19.658,-261.847],[-9.195,-233.901],[-9.195,-228.764],[-22.488,-228.764],[-22.488,-213.658],[-9.195,-213.658],[-9.195,-148.702],[9.688,-148.702],[9.688,-213.658],[31.29,-213.658],[31.29,-228.764],[9.084,-228.764],[9.084,-233.598]],"c":true},"ix":2},"nm":"f","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.964705882353,0.956862745098,0.823529411765,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":8.008,"s":[0,0],"to":[0,25],"ti":[0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":16.016,"s":[0,150],"to":[0,0],"ti":[0,25]},{"t":39.2392578125,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":8.008,"s":[100]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":16.016,"s":[5]},{"t":39.2392578125,"s":[100]}],"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"f","np":3,"cix":2,"bm":0,"ix":10,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[-24.774,0],[0,24.17],[25.076,0],[0,-24.17]],"o":[[25.076,0],[0,-24.17],[-24.774,0],[0,24.17]],"v":[[78.642,-147.644],[121.695,-189.035],[78.642,-230.275],[35.74,-189.035]],"c":true},"ix":2},"nm":"o","mn":"ADBE Vector Shape - Group","hd":false},{"ind":1,"ty":"sh","ix":2,"ks":{"a":0,"k":{"i":[[13.747,0],[0,15.408],[-13.596,0],[0,-15.408]],"o":[[-13.596,0],[0,-15.408],[13.747,0],[0,15.408]],"v":[[78.642,-163.808],[54.774,-189.035],[78.642,-214.263],[102.661,-189.035]],"c":true},"ix":2},"nm":"o","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"mm","mm":1,"nm":"Merge Paths 1","mn":"ADBE Vector Filter - Merge","hd":false},{"ty":"fl","c":{"a":0,"k":[0.964705882353,0.956862745098,0.823529411765,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":8.809,"s":[0,0],"to":[0,28.333],"ti":[0,9.651]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":18.418,"s":[0,170],"to":[0,-37.757],"ti":[0,22.708]},{"t":42.4423828125,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":8.809,"s":[100]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":18.418,"s":[2]},{"t":42.4423828125,"s":[100]}],"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"o","np":5,"cix":2,"bm":0,"ix":11,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[5.438,-8.459],[0,0],[0,0],[0,0],[0,0],[0,0],[-14.351,0],[-1.662,-0.302],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,-16.466],[1.36,0],[0,0],[-13.445,0]],"v":[[157.113,-217.586],[157.113,-229.369],[139.137,-229.369],[139.137,-148.702],[158.02,-148.702],[158.02,-187.827],[181.434,-212.752],[185.815,-212.299],[185.815,-230.275]],"c":true},"ix":2},"nm":"r","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.964705882353,0.956862745098,0.823529411765,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":9.609,"s":[0,0],"to":[0,30],"ti":[0,22.113]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":23.224,"s":[0,180],"to":[0,-38.877],"ti":[0,15.916]},{"t":44.0439453125,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":9.609,"s":[100]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":23.224,"s":[1]},{"t":44.0439453125,"s":[100]}],"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"r","np":3,"cix":2,"bm":0,"ix":12,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[3.928,0],[0,7.855],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-17.674,0],[-4.532,3.625]],"o":[[-2.87,2.266],[-7.251,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,17.825],[6.798,0],[0,0]],"v":[[286.741,-166.527],[276.166,-163.204],[264.988,-175.289],[264.988,-213.658],[286.59,-213.658],[286.59,-228.764],[264.988,-228.764],[264.988,-247.194],[246.105,-247.194],[246.105,-228.764],[232.812,-228.764],[232.812,-213.658],[246.105,-213.658],[246.105,-174.835],[273.901,-147.644],[292.028,-153.082]],"c":true},"ix":2},"nm":"t","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.964705882353,0.956862745098,0.823529411765,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":11.211,"s":[0,0],"to":[0,0],"ti":[0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":33.634,"s":[0,200],"to":[0,0],"ti":[0,0]},{"t":48.0478515625,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":11.211,"s":[100]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":33.634,"s":[0]},{"t":48.0478515625,"s":[100]}],"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"t","np":3,"cix":2,"bm":0,"ix":13,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[19.336,0],[6.194,-6.647],[0,0],[0,0],[0,0],[0,0],[0,0],[-13.445,0],[0,-14.351],[0,0],[0,0],[0,0]],"o":[[-11.179,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-16.164],[12.085,0],[0,0],[0,0],[0,0],[0,-24.321]],"v":[[352.909,-230.275],[326.02,-220.003],[326.02,-260.79],[307.137,-260.79],[307.137,-148.702],[326.02,-148.702],[326.02,-189.488],[348.528,-213.809],[367.713,-192.51],[367.713,-148.702],[386.596,-148.702],[386.596,-194.927]],"c":true},"ix":2},"nm":"h","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.964705882353,0.956862745098,0.823529411765,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":12.012,"s":[0,0],"to":[0,33.333],"ti":[0,26.811]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":38.438,"s":[0,200],"to":[0,-14.123],"ti":[0,5.253]},{"t":50.4501953125,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":12.012,"s":[100]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":38.438,"s":[0]},{"t":50.4501953125,"s":[100]}],"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"h","np":3,"cix":2,"bm":0,"ix":14,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,1.511],[23.566,0],[0,-24.019],[-27.04,0],[-7.251,8.611],[0,0],[9.064,0],[2.266,11.783],[0,0]],"o":[[0,-25.227],[-24.019,0],[0,24.019],[13.898,0],[0,0],[-5.74,5.891],[-14.049,0],[0,0],[0.151,-1.813]],"v":[[486.47,-188.582],[445.684,-230.275],[403.99,-189.035],[448.554,-147.644],[481.032,-160.787],[470.911,-172.418],[449.007,-163.657],[422.873,-182.993],[486.168,-182.993]],"c":true},"ix":2},"nm":"e","mn":"ADBE Vector Shape - Group","hd":false},{"ind":1,"ty":"sh","ix":2,"ks":{"a":0,"k":{"i":[[-12.236,0],[-1.511,-11.632],[0,0]],"o":[[12.387,0],[0,0],[1.813,-11.783]],"v":[[445.684,-215.169],[468.494,-195.531],[422.722,-195.531]],"c":true},"ix":2},"nm":"e","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"mm","mm":1,"nm":"Merge Paths 1","mn":"ADBE Vector Filter - Merge","hd":false},{"ty":"fl","c":{"a":0,"k":[0.964705882353,0.956862745098,0.823529411765,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":12.812,"s":[0,0],"to":[0,33.333],"ti":[0,21.326]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":42.442,"s":[0,200],"to":[0,-8.384],"ti":[0,3.3]},{"t":52.0517578125,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":12.812,"s":[100]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":42.442,"s":[0]},{"t":52.0517578125,"s":[100]}],"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"e","np":5,"cix":2,"bm":0,"ix":15,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,31.723],[34.291,0],[0,0]],"o":[[0,0],[34.291,0],[0,-31.723],[0,0],[0,0]],"v":[[547.15,-148.702],[593.375,-148.702],[651.081,-201.573],[593.375,-254.445],[547.15,-254.445]],"c":true},"ix":2},"nm":"D","mn":"ADBE Vector Shape - Group","hd":false},{"ind":1,"ty":"sh","ix":2,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,-21.904],[23.566,0]],"o":[[0,0],[0,0],[23.566,0],[0,21.904],[0,0]],"v":[[566.788,-165.318],[566.788,-237.828],[592.468,-237.828],[631.291,-201.573],[592.468,-165.318]],"c":true},"ix":2},"nm":"D","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"mm","mm":1,"nm":"Merge Paths 1","mn":"ADBE Vector Filter - Merge","hd":false},{"ty":"fl","c":{"a":0,"k":[0.964705882353,0.956862745098,0.823529411765,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":14.414,"s":[0,0],"to":[0,0],"ti":[0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":51.251,"s":[0,200],"to":[0,0],"ti":[0,0]},{"t":56.8564453125,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":14.414,"s":[100]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":51.251,"s":[0]},{"t":56.8564453125,"s":[100]}],"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"D","np":5,"cix":2,"bm":0,"ix":16,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[23.264,0],[8.611,-6.647],[0,0],[-9.064,0],[0,-11.028],[0,0],[0,0],[0,-13.445],[-18.43,0],[-4.532,6.949],[0,0],[0,0],[0,0]],"o":[[-12.991,0],[0,0],[6.042,-4.985],[13.445,0],[0,0],[0,0],[-24.472,0],[0,14.049],[12.085,0],[0,0],[0,0],[0,0],[0,-23.264]],"v":[[700.054,-230.275],[665.914,-220.305],[673.316,-206.558],[697.788,-214.565],[717.879,-197.041],[717.879,-195.833],[697.033,-195.833],[663.497,-171.814],[693.558,-147.644],[718.937,-158.521],[718.937,-148.702],[736.762,-148.702],[736.762,-195.984]],"c":true},"ix":2},"nm":"a","mn":"ADBE Vector Shape - Group","hd":false},{"ind":1,"ty":"sh","ix":2,"ks":{"a":0,"k":{"i":[[9.215,0],[0,6.798],[-12.84,0],[0,0],[0,0]],"o":[[-9.668,0],[0,-5.891],[0,0],[0,0],[-3.172,8.308]],"v":[[697.486,-161.391],[682.077,-172.569],[698.392,-183.295],[717.879,-183.295],[717.879,-173.929]],"c":true},"ix":2},"nm":"a","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"mm","mm":1,"nm":"Merge Paths 1","mn":"ADBE Vector Filter - Merge","hd":false},{"ty":"fl","c":{"a":0,"k":[0.964705882353,0.956862745098,0.823529411765,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":15.215,"s":[0,0],"to":[0,0],"ti":[0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":55.255,"s":[0,200],"to":[0,0],"ti":[0,0]},{"t":59.2587890625,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":15.215,"s":[100]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":55.255,"s":[0]},{"t":59.2587890625,"s":[100]}],"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"a","np":5,"cix":2,"bm":0,"ix":17,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[6.647,0],[3.625,3.474],[0,0],[-8.006,0],[-7.402,18.279],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[-3.625,8.006],[-5.136,0],[0,0],[5.136,4.683],[13.445,0],[0,0],[0,0]],"v":[[816.191,-229.369],[790.661,-169.699],[765.283,-229.369],[745.645,-229.369],[780.842,-148.4],[779.483,-145.227],[765.283,-134.049],[751.385,-139.638],[743.832,-125.74],[765.434,-118.338],[796.553,-142.206],[834.318,-229.369]],"c":true},"ix":2},"nm":"y","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.964705882353,0.956862745098,0.823529411765,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":20.021,"s":[0,0],"to":[0,28.333],"ti":[0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":59.259,"s":[0,170],"to":[0,0],"ti":[0,28.333]},{"t":61.662109375,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":20.021,"s":[100]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":59.259,"s":[15]},{"t":61.662109375,"s":[100]}],"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"y","np":3,"cix":2,"bm":0,"ix":18,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":120.12012012012,"st":0,"bm":0},{"ddd":0,"ind":2,"ty":2,"nm":"Roof","parent":6,"refId":"image_0","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[245.056,242.972,0],"ix":2},"a":{"a":0,"k":[245.056,242.972,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":120,"st":0,"bm":0},{"ddd":0,"ind":3,"ty":2,"nm":"Right wheel","refId":"image_1","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"t":120,"s":[360]}],"ix":10},"p":{"a":0,"k":[372.806,399.222,0],"ix":2},"a":{"a":0,"k":[372.806,342.222,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":120,"st":0,"bm":0},{"ddd":0,"ind":4,"ty":2,"nm":"Left Wheel","refId":"image_2","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"t":120,"s":[360]}],"ix":10},"p":{"a":0,"k":[140.556,398.972,0],"ix":2},"a":{"a":0,"k":[140.556,341.972,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":120,"st":0,"bm":0},{"ddd":0,"ind":5,"ty":2,"nm":"Cart print","parent":6,"refId":"image_3","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[245.056,242.972,0],"ix":2},"a":{"a":0,"k":[245.056,242.972,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":120,"st":0,"bm":0},{"ddd":0,"ind":6,"ty":2,"nm":"Cart body","refId":"image_4","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":0,"s":[245.5,309,0],"to":[0,-0.667,0],"ti":[0,0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":6,"s":[245.5,305,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":11,"s":[245.5,309,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":18,"s":[245.5,305,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":23,"s":[245.5,309,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":31,"s":[245.5,305,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":36,"s":[245.5,309,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":44,"s":[245.5,305,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":49,"s":[245.5,309,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":57,"s":[245.5,305,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":62,"s":[245.5,309,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":70,"s":[245.5,305,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":75,"s":[245.5,309,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":84,"s":[245.5,305,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":89,"s":[245.5,309,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":100,"s":[245.5,305,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":105,"s":[245.5,309,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":115,"s":[245.5,305,0],"to":[0,0,0],"ti":[0,-0.667,0]},{"t":120,"s":[245.5,309,0]}],"ix":2},"a":{"a":0,"k":[245.5,243,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":120,"st":0,"bm":0},{"ddd":0,"ind":7,"ty":2,"nm":"RightCottonCandy","parent":6,"refId":"image_5","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":6,"s":[-14.574]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":12,"s":[-0.956]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":19,"s":[-10.167]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":25,"s":[6.68]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":29,"s":[-1.736]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":35,"s":[7.32]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":46,"s":[-1.74]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":50,"s":[6.75]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":57,"s":[-5.174]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":62,"s":[5.484]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":70,"s":[-6.26]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":77,"s":[4.355]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":84,"s":[-9.784]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":90,"s":[3.394]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":100,"s":[-10.094]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":106,"s":[-0.64]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":114,"s":[-25.48]},{"t":120,"s":[0]}],"ix":10},"p":{"a":0,"k":[187.056,221.972,0],"ix":2},"a":{"a":0,"k":[187.056,221.972,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":120,"st":0,"bm":0},{"ddd":0,"ind":8,"ty":2,"nm":"LeftCottonCandy","parent":6,"refId":"image_6","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":6,"s":[5.305]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":13,"s":[-11.218]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":19,"s":[-5.562]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":23,"s":[-11.57]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":32,"s":[1.663]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":37,"s":[-4.863]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":45,"s":[11.142]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":48,"s":[1.452]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":55,"s":[10.633]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":62,"s":[-4.918]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":70,"s":[7.13]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":75,"s":[-7.976]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":84,"s":[6.117]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":90,"s":[-5.267]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":100,"s":[1.761]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":108,"s":[-8.506]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":114,"s":[1.278]},{"t":120,"s":[0]}],"ix":10},"p":{"a":0,"k":[168.056,221.222,0],"ix":2},"a":{"a":0,"k":[168.056,221.222,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":120,"st":0,"bm":0},{"ddd":0,"ind":9,"ty":2,"nm":"MidCotton Candy","parent":6,"refId":"image_7","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[179.056,222.472,0],"to":[0,-0.25,0],"ti":[0,-0.333,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":7,"s":[179.056,220.972,0],"to":[0,0.333,0],"ti":[0,-0.375,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":12,"s":[179.056,224.472,0],"to":[0,0.375,0],"ti":[0,-0.125,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":19,"s":[179.056,223.222,0],"to":[0,0.125,0],"ti":[0,0.25,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":23,"s":[179.056,225.222,0],"to":[0,-0.25,0],"ti":[0,0.167,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":32,"s":[179.056,221.722,0],"to":[0,-0.167,0],"ti":[0,0.292,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":37,"s":[179.056,224.222,0],"to":[0,-0.292,0],"ti":[0,0.25,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":44,"s":[179.056,219.972,0],"to":[0,-0.25,0],"ti":[0,-0.167,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":50,"s":[179.056,222.722,0],"to":[0,0.167,0],"ti":[0,-0.417,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":58,"s":[179.056,220.972,0],"to":[0,0.417,0],"ti":[0,-0.042,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":65,"s":[179.056,225.222,0],"to":[0,0.042,0],"ti":[0,0,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":70,"s":[179.056,221.222,0],"to":[0,0,0],"ti":[0,0.167,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":75,"s":[179.056,225.222,0],"to":[0,-0.167,0],"ti":[0,0,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":85,"s":[179.056,220.222,0],"to":[0,0,0],"ti":[0,-0.167,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":90,"s":[179.056,225.222,0],"to":[0,0.167,0],"ti":[0,-0.083,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":101,"s":[179.056,221.222,0],"to":[0,0.083,0],"ti":[0,0.25,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":107,"s":[179.056,225.722,0],"to":[0,-0.25,0],"ti":[0,0.537,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":115,"s":[179.056,219.722,0],"to":[0,-0.537,0],"ti":[0,-0.463,0]},{"t":119,"s":[179.056,222.5,0]}],"ix":2},"a":{"a":0,"k":[179.056,222.472,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":120,"st":0,"bm":0},{"ddd":0,"ind":10,"ty":2,"nm":"popcorn windo","parent":6,"refId":"image_8","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[245.056,242.972,0],"ix":2},"a":{"a":0,"k":[245.056,242.972,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":120,"st":0,"bm":0},{"ddd":0,"ind":11,"ty":2,"nm":"popcorn","parent":6,"refId":"image_9","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[245.056,242.972,0],"ix":2},"a":{"a":0,"k":[245.056,242.972,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":120,"st":0,"bm":0}],"markers":[]} \ No newline at end of file diff --git a/HackIllinois/Tests.playground/Pages/Generic Diff.xcplaygroundpage/Contents.swift b/HackIllinois/Tests.playground/Pages/Generic Diff.xcplaygroundpage/Contents.swift index 72e62a34..09bc08d9 100644 --- a/HackIllinois/Tests.playground/Pages/Generic Diff.xcplaygroundpage/Contents.swift +++ b/HackIllinois/Tests.playground/Pages/Generic Diff.xcplaygroundpage/Contents.swift @@ -18,11 +18,11 @@ protocol MixTypeComparable: Comparable { } extension MixTypeComparable { - static func <(lhs: Self, rhs: Other) -> Bool where Other: MixTypeComparable, Self.ComparableType == Other.ComparableType { + static func < (lhs: Self, rhs: Other) -> Bool where Other: MixTypeComparable, Self.ComparableType == Other.ComparableType { return lhs.comparable < rhs.comparable } - static func ==(lhs: Self, rhs: Other) -> Bool where Other: MixTypeComparable, Self.ComparableType == Other.ComparableType { + static func == (lhs: Self, rhs: Other) -> Bool where Other: MixTypeComparable, Self.ComparableType == Other.ComparableType { return lhs.comparable == rhs.comparable } } diff --git a/HackIllinois/UI/Animations/Refresh/refresh.json b/HackIllinois/UI/Animations/Refresh/refresh.json index de78ee58..b699ecdf 100644 --- a/HackIllinois/UI/Animations/Refresh/refresh.json +++ b/HackIllinois/UI/Animations/Refresh/refresh.json @@ -1 +1 @@ -{"v":"4.8.0","meta":{"g":"LottieFiles AE ","a":"","k":"","d":"","tc":""},"fr":29.9700012207031,"ip":0,"op":64.0000026067734,"w":300,"h":300,"nm":"Loading cake AI","ddd":0,"assets":[{"id":"image_0","w":243,"h":243,"u":"","p":"","e":1}],"layers":[{"ddd":0,"ind":1,"ty":2,"nm":"Strawberries","refId":"image_0","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[150,149.988,0],"ix":2},"a":{"a":0,"k":[121.318,121.305,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"hasMask":true,"masksProperties":[{"inv":false,"mode":"a","pt":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[290.646,-40.682],[-40.682,-40.682],[-40.682,285.4],[290.646,285.4]],"c":true},"ix":1},"o":{"a":0,"k":100,"ix":3},"x":{"a":0,"k":0,"ix":4},"nm":"Mask 1"},{"inv":false,"mode":"s","pt":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[120.318,-80.682],[120.42,-76.896],[120.453,-75.684],[120.618,-69.566],[120.818,-62.182],[121.818,121.818]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":4,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[307.318,-69.682],[271.259,-68.232],[259.713,-67.768],[201.449,-65.425],[120.818,-62.182],[121.818,121.818]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":8,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[366.318,121.318],[308.075,55.348],[289.425,34.223],[201.449,-65.425],[120.818,-62.182],[121.818,121.818]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":12,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[269.318,267.318],[284.548,90.759],[289.425,34.223],[201.449,-65.425],[120.818,-62.182],[121.818,121.818]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":16,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[123.318,300.318],[305.945,198.747],[364.425,166.223],[201.449,-65.425],[120.818,-62.182],[121.818,121.818]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":20,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[0.318,246.318],[312.47,268.97],[412.425,276.223],[359.449,22.575],[120.818,-62.182],[121.818,121.818]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":22,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[-23.182,183.318],[110.02,299.383],[225.925,316.223],[404.449,79.575],[120.818,-62.182],[121.818,121.818]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":24,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[-46.682,120.318],[21.57,277.796],[43.425,328.223],[449.449,136.575],[120.818,-62.182],[121.818,121.818]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":28,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[14.318,16.318],[-100.734,247.269],[-137.575,321.223],[512.449,226.575],[120.818,-62.182],[121.818,121.818]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":32,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[120.318,-68.682],[-135.875,82.19],[-137.575,321.223],[512.449,226.575],[120.818,-62.182],[121.818,121.818]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":36,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[120.318,-68.682],[-135.875,82.19],[-137.575,321.223],[512.449,226.575],[245.818,-3.182],[121.818,121.818]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":40,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[120.318,-68.682],[-135.875,82.19],[-137.575,321.223],[512.449,226.575],[307.818,121.818],[121.818,121.818]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":44,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[120.318,-68.682],[-135.875,82.19],[-137.575,321.223],[61.449,323.575],[259.818,261.818],[121.818,121.818]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":48,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[120.318,-68.682],[-135.875,82.19],[-137.575,321.223],[61.449,323.575],[117.818,294.818],[121.818,121.818]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":52,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[120.318,-68.682],[-135.875,82.19],[-137.575,321.223],[-54.551,301.575],[-14.182,251.818],[121.818,121.818]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":56,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[120.318,-68.682],[-135.875,82.19],[-124.575,93.223],[-102.551,179.575],[-64.182,119.818],[121.818,121.818]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":60,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[120.318,-68.682],[-135.875,82.19],[-124.575,93.223],[-102.551,179.575],[15.818,12.818],[121.818,121.818]],"c":true}]},{"t":64.0000026067734,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[120.318,-68.682],[-135.875,82.19],[-124.575,93.223],[-56.551,47.575],[121.818,-31.182],[121.818,121.818]],"c":true}]}],"ix":1},"o":{"a":0,"k":100,"ix":3},"x":{"a":0,"k":0,"ix":4},"nm":"Mask 2"}],"ip":0,"op":150.000006109625,"st":0,"bm":0}],"markers":[]} +{"v":"4.8.0","meta":{"g":"LottieFiles AE 3.0.2","a":"","k":"","d":"","tc":""},"fr":24,"ip":0,"op":477,"w":643,"h":700,"nm":"RiggedFerrisWheel","ddd":0,"assets":[{"id":"image_0","w":643,"h":661,"u":"","p":"","e":1},{"id":"image_1","w":643,"h":661,"u":"","p":"","e":1},{"id":"image_2","w":643,"h":661,"u":"","p":"","e":1},{"id":"image_3","w":643,"h":661,"u":"","p":"","e":1},{"id":"image_4","w":643,"h":661,"u":"","p":"","e":1},{"id":"image_5","w":643,"h":661,"u":"","p":"","e":1},{"id":"image_6","w":643,"h":661,"u":"","p":"","e":1},{"id":"image_7","w":643,"h":661,"u":"","p":"","e":1},{"id":"image_8","w":643,"h":661,"u":"","p":"","e":1},{"id":"image_9","w":643,"h":661,"u":"","p":"","e":1},{"id":"image_10","w":643,"h":661,"u":"","p":"","e":1},{"id":"image_11","w":643,"h":661,"u":"","p":"","e":1},{"id":"image_12","w":643,"h":661,"u":"","p":"","e":1},{"id":"image_13","w":643,"h":661,"u":"","p":"","e":1},{"id":"image_14","w":643,"h":661,"u":"","p":"","e":1},{"id":"image_15","w":643,"h":661,"u":"","p":"","e":1},{"id":"image_16","w":643,"h":661,"u":"","p":"","e":1}],"layers":[{"ddd":0,"ind":1,"ty":2,"nm":"MiniInnerBlue","refId":"image_0","sr":4,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":141.59,"ix":10},"p":{"a":0,"k":[321.487,338.872,0],"ix":2},"a":{"a":0,"k":[320.941,318.661,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":480,"st":0,"bm":0},{"ddd":0,"ind":2,"ty":2,"nm":"OuterWhite","parent":15,"refId":"image_1","sr":4,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":141.59,"ix":10},"p":{"a":0,"k":[314.333,309.488,0],"ix":2},"a":{"a":0,"k":[321.226,330.372,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":480,"st":0,"bm":0},{"ddd":0,"ind":3,"ty":2,"nm":"Yellow Light","parent":15,"refId":"image_2","sr":4,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":141.59,"ix":10},"p":{"a":0,"k":[314.333,309.488,0],"ix":2},"a":{"a":0,"k":[321.226,330.372,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":480,"st":0,"bm":0},{"ddd":0,"ind":4,"ty":2,"nm":"SlightlyInnerWhite","refId":"image_3","sr":4,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":-218.41,"ix":10},"p":{"a":0,"k":[317.69,339.966,0],"ix":2},"a":{"a":0,"k":[324.467,321.456,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":480,"st":0,"bm":0},{"ddd":0,"ind":5,"ty":2,"nm":"TealRing","refId":"image_4","sr":4,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":48.201,"ix":10},"p":{"a":0,"k":[316.456,340.074,0],"ix":2},"a":{"a":0,"k":[319.01,323.51,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":480,"st":0,"bm":0},{"ddd":0,"ind":6,"ty":2,"nm":"Cart10","parent":15,"refId":"image_5","sr":4,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"t":478,"s":[-360]}],"ix":10},"p":{"a":0,"k":[519.226,125.372,0],"ix":2},"a":{"a":0,"k":[508.226,107.372,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":480,"st":0,"bm":0},{"ddd":0,"ind":7,"ty":2,"nm":"Cart9","parent":15,"refId":"image_6","sr":4,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"t":478,"s":[-360]}],"ix":10},"p":{"a":0,"k":[598.226,320.372,0],"ix":2},"a":{"a":0,"k":[597.226,289.372,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":480,"st":0,"bm":0},{"ddd":0,"ind":8,"ty":2,"nm":"Cart8","parent":15,"refId":"image_7","sr":4,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":478,"s":[-360]},{"t":480,"s":[0]}],"ix":10},"p":{"a":0,"k":[520.226,515.372,0],"ix":2},"a":{"a":0,"k":[506.226,473.372,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":480,"st":0,"bm":0},{"ddd":0,"ind":9,"ty":2,"nm":"Cart7","parent":15,"refId":"image_8","sr":4,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":478,"s":[-360]},{"t":480,"s":[0]}],"ix":10},"p":{"a":0,"k":[321.226,594.872,0],"ix":2},"a":{"a":0,"k":[321.226,557.372,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":480,"st":0,"bm":0},{"ddd":0,"ind":10,"ty":2,"nm":"Cart6","parent":15,"refId":"image_9","sr":4,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":478,"s":[-360]},{"t":480,"s":[0]}],"ix":10},"p":{"a":0,"k":[319.226,40.372,0],"ix":2},"a":{"a":0,"k":[318.226,33.372,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":480,"st":0,"bm":0},{"ddd":0,"ind":11,"ty":2,"nm":"Cart5","parent":15,"refId":"image_10","sr":4,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":478,"s":[-360]},{"t":480,"s":[0]}],"ix":10},"p":{"a":0,"k":[116.226,117.372,0],"ix":2},"a":{"a":0,"k":[135.226,107.372,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":480,"st":0,"bm":0},{"ddd":0,"ind":12,"ty":2,"nm":"Cart4","parent":15,"refId":"image_11","sr":4,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":478,"s":[-360]},{"t":480,"s":[0]}],"ix":10},"p":{"a":0,"k":[45.226,320.372,0],"ix":2},"a":{"a":0,"k":[45.226,286.372,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":480,"st":0,"bm":0},{"ddd":0,"ind":13,"ty":2,"nm":"Cart3","parent":15,"refId":"image_12","sr":4,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":478,"s":[-360]},{"t":480,"s":[0]}],"ix":10},"p":{"a":0,"k":[121.226,514.372,0],"ix":2},"a":{"a":0,"k":[134.226,474.372,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":480,"st":0,"bm":0},{"ddd":0,"ind":14,"ty":2,"nm":"Core","refId":"image_13","sr":4,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[321.226,349.872,0],"ix":2},"a":{"a":0,"k":[321.226,330.372,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":480,"st":0,"bm":0},{"ddd":0,"ind":15,"ty":2,"nm":"Arms","refId":"image_14","sr":4,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":478,"s":[360]},{"t":480,"s":[0]}],"ix":10},"p":{"a":0,"k":[322.101,338.122,0],"ix":2},"a":{"a":0,"k":[320.947,319.239,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":480,"st":0,"bm":0},{"ddd":0,"ind":16,"ty":2,"nm":"OnionRings","refId":"image_15","sr":4,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[321.226,349.872,0],"ix":2},"a":{"a":0,"k":[321.226,330.372,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":480,"st":0,"bm":0},{"ddd":0,"ind":17,"ty":2,"nm":"FerrisWheelLegs","refId":"image_16","sr":4,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[321.226,349.872,0],"ix":2},"a":{"a":0,"k":[321.226,330.372,0],"ix":1},"s":{"a":0,"k":[112.703,112.703,100],"ix":6}},"ao":0,"ip":0,"op":480,"st":0,"bm":0}],"markers":[]} diff --git a/HackIllinois/UI/HIAppearance.swift b/HackIllinois/UI/HIAppearance.swift index 50a7f3a9..b8db4c4c 100644 --- a/HackIllinois/UI/HIAppearance.swift +++ b/HackIllinois/UI/HIAppearance.swift @@ -13,6 +13,7 @@ import UIKit struct HIAppearance: Equatable { + let neonCountdownText: UIColor let titleText: UIColor let whiteText: UIColor let baseText: UIColor @@ -31,12 +32,18 @@ struct HIAppearance: Equatable { let loginDefault: UIColor let loginTitleBackground: UIColor let loginLogo: UIImage + let loginLogoPad: UIImage let loginSelectionText: UIColor let attendeeText: UIColor let attendeeBackground: UIColor let whiteTagFont: UIColor let interestBackground: UIColor let buttonGreen: UIColor + let buttonPink: UIColor + let buttonBlue: UIColor + let buttonDarkBlue: UIColor + let buttonMagenta: UIColor + let buttonDarkBlueGreen: UIColor let favoriteStarBackground: UIColor let segmentedBackground: UIColor // New fonts added. Replace old ones? @@ -58,11 +65,22 @@ struct HIAppearance: Equatable { let leaderboardBackgroundTwo: UIColor let pointsBackground: UIColor + let profileCardBackground: UIColor + let profileCardVegetarian: UIColor + let profileCardVegan: UIColor + let profileCardGlutenFree: UIColor + let profileCardLactoseIntolerant: UIColor + let profileCardOther: UIColor + let profileCardNone: UIColor + + + let profileBaseText: UIColor + let clear: UIColor = .clear let black: UIColor = .black let white: UIColor = .white - // Hack 2022 color palette + //Hack 2022 color palette private static let darkRed = #colorLiteral(red: 0.6039215686, green: 0.1411764706, blue: 0.168627451, alpha: 1) private static let tan = #colorLiteral(red: 0.9098039216, green: 0.8431372549, blue: 0.6470588235, alpha: 1) private static let orange = #colorLiteral(red: 0.9294117647, green: 0.6078431373, blue: 0.1294117647, alpha: 1) @@ -75,45 +93,72 @@ struct HIAppearance: Equatable { private static let lightBlack = #colorLiteral(red: 0.03137254902, green: 0.08235294118, blue: 0.1058823529, alpha: 1) private static let salmon = #colorLiteral(red: 0.9490196078, green: 0.6078431373, blue: 0.4705882353, alpha: 1) private static let yellowWhite = #colorLiteral(red: 0.9647058824, green: 0.9568627451, blue: 0.831372549, alpha: 1) + + // Hack 2023 color palette + private static let lightYellow = #colorLiteral(red: 0.9882352941, green: 0.862745098, blue: 0.5607843137, alpha: 1) + private static let blue = #colorLiteral(red: 0.03137254902, green: 0.5450980392, blue: 0.7568627451, alpha: 1) + private static let pink = #colorLiteral(red: 0.9960784314, green: 0.4392156863, blue: 0.5960784314, alpha: 1) + private static let mediumOrange = #colorLiteral(red: 0.9764705882, green: 0.5843137255, blue: 0.3411764706, alpha: 1) + private static let teal = #colorLiteral(red: 0.2156862745, green: 0.8705882353, blue: 0.8039215686, alpha: 1) + private static let lightBlue = #colorLiteral(red: 0.7921568627, green: 0.8235294118, blue: 0.8980392157, alpha: 1) private static let white = #colorLiteral(red: 1, green: 1, blue: 1, alpha: 1) + private static let darkBlue = #colorLiteral(red: 0.05098039216, green: 0.2196078431, blue: 0.4862745098, alpha: 1) private static let transparent = #colorLiteral(red: 1, green: 1, blue: 1, alpha: 0) - + private static let magenta = #colorLiteral(red: 0.9960784314, green: 0.4392156863, blue: 0.5960784314, alpha: 1) + private static let darkBlueGreeen = #colorLiteral(red: 0.03137254902, green: 0.5450980392, blue: 0.7568627451, alpha: 1) + private static let darknavy = #colorLiteral(red: 0.1137254902, green: 0.1490196078, blue: 0.2666666667, alpha: 1) + private static let vegetarian = #colorLiteral(red: 0.2156862745, green: 0.8705882353, blue: 0.8039215686, alpha: 1) + private static let vegan = #colorLiteral(red: 0.9882352941, green: 0.862745098, blue: 0.5607843137, alpha: 1) + private static let glutenfree = #colorLiteral(red: 0.9764705882, green: 0.5843137255, blue: 0.3411764706, alpha: 1) + private static let lactoseintolerant = #colorLiteral(red: 1, green: 1, blue: 1, alpha: 1) + private static let other = #colorLiteral(red: 0.9960784314, green: 0.6392156863, blue: 0.6666666667, alpha: 1) + private static let none = #colorLiteral(red: 0.1137254902, green: 0.1490196078, blue: 0.2666666667, alpha: 1) + private static let profileBaseText = #colorLiteral(red: 0.1137254902, green: 0.1490196078, blue: 0.2666666667, alpha: 1) + + private static let transparent2 = #colorLiteral(red: 1, green: 1, blue: 1, alpha: 0) private static var statusBarWhite: UIStatusBarStyle { return .lightContent } private static var statusBarBlack: UIStatusBarStyle { if #available(iOS 13.0, *) { - return .darkContent + return .lightContent } else { - return .default + return .lightContent } } fileprivate static let day = HIAppearance( + neonCountdownText: lightYellow, titleText: lightBlack, whiteText: white, baseText: lightBlack, accent: orange, action: tan, baseBackground: white, - contentBackground: yellowWhite, + contentBackground: lightBlue, overlay: #colorLiteral(red: 0.05882352941, green: 0.07058823529, blue: 0.1803921569, alpha: 0.33), frostedTint: #colorLiteral(red: 0, green: 0.3411764706, blue: 0.462745098, alpha: 0.6), - codePopupTab: orange, - navbarBackground: green, - navbarTabTint: yellowWhite, + codePopupTab: white, + navbarBackground: darkBlue, + navbarTabTint: white, profileContainerTint: yellowWhite, preferredStatusBarStyle: statusBarBlack, scrollViewIndicatorStyle: .black, - loginDefault: lightBlack, - loginTitleBackground: lightBlack, + loginDefault: white, + loginTitleBackground: white, loginLogo: #imageLiteral(resourceName: "HILogo"), - loginSelectionText: lightBlack, - attendeeText: lightBlack, - attendeeBackground: yellowGreen, + loginLogoPad: UIImage(named: "LoginLogoPad")!, + loginSelectionText: white, + attendeeText: white, + attendeeBackground: darknavy, whiteTagFont: white, interestBackground: orange, buttonGreen: yellowGreen, + buttonPink: pink, + buttonBlue: blue, + buttonDarkBlue: darkBlue, + buttonMagenta: magenta, + buttonDarkBlueGreen: darkBlueGreeen, favoriteStarBackground: yellowWhite, segmentedBackground: white, buttonViewBackground: green, @@ -129,36 +174,51 @@ struct HIAppearance: Equatable { profile9: #imageLiteral(resourceName: "Profile9"), profile10: #imageLiteral(resourceName: "Profile10"), leaderboardText: lightBlack, - leaderboardBackgroundOne: yellowWhite, - leaderboardBackgroundTwo: tan, - pointsBackground: yellowGreen + leaderboardBackgroundOne: lightBlue, + leaderboardBackgroundTwo: lightBlue, + pointsBackground: white, + profileCardBackground: lightBlue, + profileCardVegetarian: vegetarian, + profileCardVegan: vegan, + profileCardGlutenFree: glutenfree, + profileCardLactoseIntolerant: lactoseintolerant, + profileCardOther: other, + profileCardNone: none, + profileBaseText: profileBaseText ) fileprivate static let night = HIAppearance( + neonCountdownText: lightYellow, titleText: lightBlack, whiteText: white, baseText: lightBlack, accent: orange, action: tan, baseBackground: white, - contentBackground: yellowWhite, + contentBackground: lightBlue, overlay: #colorLiteral(red: 0.05882352941, green: 0.07058823529, blue: 0.1803921569, alpha: 0.33), frostedTint: #colorLiteral(red: 0, green: 0.3411764706, blue: 0.462745098, alpha: 0.6), - codePopupTab: orange, - navbarBackground: green, - navbarTabTint: yellowWhite, + codePopupTab: white, + navbarBackground: darkBlue, + navbarTabTint: white, profileContainerTint: yellowWhite, preferredStatusBarStyle: statusBarBlack, scrollViewIndicatorStyle: .black, - loginDefault: lightBlack, - loginTitleBackground: lightBlack, + loginDefault: white, + loginTitleBackground: white, loginLogo: #imageLiteral(resourceName: "HILogo"), - loginSelectionText: lightBlack, - attendeeText: lightBlack, - attendeeBackground: yellowGreen, + loginLogoPad: UIImage(named: "LoginLogoPad")!, + loginSelectionText: white, + attendeeText: white, + attendeeBackground: darknavy, whiteTagFont: white, interestBackground: orange, buttonGreen: yellowGreen, + buttonPink: pink, + buttonBlue: blue, + buttonDarkBlue: darkBlue, + buttonMagenta: magenta, + buttonDarkBlueGreen: darkBlueGreeen, favoriteStarBackground: yellowWhite, segmentedBackground: white, buttonViewBackground: green, @@ -174,9 +234,17 @@ struct HIAppearance: Equatable { profile9: #imageLiteral(resourceName: "Profile9"), profile10: #imageLiteral(resourceName: "Profile10"), leaderboardText: lightBlack, - leaderboardBackgroundOne: yellowWhite, - leaderboardBackgroundTwo: tan, - pointsBackground: yellowGreen + leaderboardBackgroundOne: lightBlue, + leaderboardBackgroundTwo: lightBlue, + pointsBackground: white, + profileCardBackground: lightBlue, + profileCardVegetarian: vegetarian, + profileCardVegan: vegan, + profileCardGlutenFree: glutenfree, + profileCardLactoseIntolerant: lactoseintolerant, + profileCardOther: other, + profileCardNone: none, + profileBaseText: profileBaseText ) fileprivate static var current = day @@ -184,54 +252,81 @@ struct HIAppearance: Equatable { static func change(to newAppearance: HIAppearance) { guard current != newAppearance else { return } current = newAppearance - NotificationCenter.default.post(name: .themeDidChange, object: nil) } enum Font { - static let contentSubtitle = UIFont.systemFont(ofSize: 13, weight: .light) - static let contentText = UIFont.systemFont(ofSize: 14, weight: .regular) - static let contentTitle = UIFont.systemFont(ofSize: 18, weight: .medium) - static let detailTitle = UIFont.systemFont(ofSize: 24, weight: .semibold) - static let detailSubtitle = UIFont.systemFont(ofSize: 16, weight: .medium) - static let detailText = UIFont.systemFont(ofSize: 16, weight: .regular) - static let viewTitle = UIFont.systemFont(ofSize: 28, weight: .semibold) - static let happeningEventTitle = UIFont.systemFont(ofSize: 25, weight: .bold) - static let eventTitle = UIFont.systemFont(ofSize: 18, weight: .semibold) - static let eventTime = UIFont.systemFont(ofSize: 15, weight: .regular) - static let eventDetails = UIFont.systemFont(ofSize: 16, weight: .regular) - static let eventButtonText = UIFont.systemFont(ofSize: 14, weight: .regular) - static let eventCategoryText = UIFont.systemFont(ofSize: 16, weight: .regular) - static let clockText = UIFont.systemFont(ofSize: 48, weight: .semibold) - static let navigationSubtitle = UIFont.systemFont(ofSize: 14, weight: .medium) - static let navigationTitle = UIFont.systemFont(ofSize: 22, weight: .semibold) - static let navigationInfoText = UIFont.systemFont(ofSize: 12, weight: .regular) - static let descriptionText = UIFont.systemFont(ofSize: 16, weight: .regular) - static let sponsorText = UIFont.systemFont(ofSize: 16, weight: .regular) - static let loginTitle = UIFont.systemFont(ofSize: 24, weight: .bold) - static let loginOrTitle = UIFont.systemFont(ofSize: 16, weight: .bold) - static let loginSelection = UIFont.systemFont(ofSize: 16, weight: .semibold) - - static let sectionHeader = UIFont.systemFont(ofSize: 13, weight: .bold) - static let button = UIFont.systemFont(ofSize: 15, weight: .regular) - static let glyph = UIFont.systemFont(ofSize: 15, weight: .light) - - static let profileName = UIFont.systemFont(ofSize: 24, weight: .semibold) - static let profileSubtitle = UIFont.systemFont(ofSize: 14, weight: .regular) - static let profileNumberFigure = UIFont.systemFont(ofSize: 24, weight: .semibold) - static let profileTier = UIFont.systemFont(ofSize: 18, weight: .regular) - static let profileUsername = UIFont.systemFont(ofSize: 16, weight: .bold) - static let profileInterests = UIFont.systemFont(ofSize: 14, weight: .semibold) - static let segmentedTitle = UIFont.systemFont(ofSize: 16, weight: .regular) - static let segmentedNumberText = UIFont.systemFont(ofSize: 20, weight: .semibold) - - static let countdownText = UIFont.systemFont(ofSize: 25, weight: .bold) - static let onboardingGetStartedText = UIFont.systemFont(ofSize: 25, weight: .semibold) - static let onboardingTitle = UIFont.systemFont(ofSize: 30, weight: .bold) - static let onboardingDescription = UIFont.systemFont(ofSize: 20, weight: .regular) - static let leaderboardPoints = UIFont.systemFont(ofSize: 16, weight: .regular) - static let leaderboardName = UIFont.systemFont(ofSize: 14, weight: .semibold) - static let leaderboardRank = UIFont.systemFont(ofSize: 24, weight: .bold) + static let glyphPad = UIFont(name: "MontserratRoman-Bold", size: 24) + static let timeIndicator = UIFont(name: "MontserratRoman-Bold", size: 32) + static let homeSegmentedTitlePad = UIFont(name: "MontserratRoman-Bold", size: 40) + static let viewTitlePad = UIFont(name: "MontserratRoman-Bold", size: 48) + static let scheduleSegmentedNumberPad = UIFont(name: "MontserratRoman-SemiBold", size: 36) + static let scheduleSegmentedPad = UIFont(name: "MontserratRoman-SemiBold", size: 32) + static let eventTitlePad = UIFont(name: "MontserratRoman-Bold", size: 36) + static let timeTextPad = UIFont(name: "MontserratRoman-SemiBold", size: 28) + static let locationTextPad = UIFont(name: "MontserratRoman-SemiBold", size: 24) + static let sponsorTextPad = UIFont(name: "MontserratRoman-SemiBold", size: 24) + static let detailTextPad = UIFont(name: "MontserratRoman-Regular", size: 24) + static let descriptionTextPad = UIFont(name: "MontserratRoman-SemiBold", size: 18) + static let contentSubtitle = UIFont(name: "MontserratRoman-Light", size: 13) + static let contentText = UIFont(name: "MontserratRoman-Regular", size: 14) + static let contentTextPad = UIFont(name: "MontserratRoman-SemiBold", size: 18) + static let contentTitle = UIFont(name: "MontserratRoman-Medium", size: 18) + static let detailTitle = UIFont(name: "MontserratRoman-SemiBold", size: 24) + static let detailSubtitle = UIFont(name: "MontserratRoman-Medium", size: 16) + static let detailText = UIFont(name: "MontserratRoman-Regular", size: UIDevice.current.userInterfaceIdiom == .pad ? 19 : 16) + static let viewTitle = UIFont(name: "MontserratRoman-Bold", size: 24) + static let happeningEventTitle = UIFont(name: "MontserratRoman-Bold", size: 25) + static let eventTitle = UIFont(name: "MontserratRoman-SemiBold", size: 18) + static let eventTime = UIFont(name: "MontserratRoman-Regular", size: 15) + static let eventDetails = UIFont(name: "MontserratRoman-Regular", size: 14) + static let eventButtonText = UIFont(name: "MontserratRoman-SemiBold", size: UIDevice.current.userInterfaceIdiom == .pad ? 18 : 14) + static let eventCategoryText = UIFont(name: "MontserratRoman-Regular", size: 16) + static let clockText = UIFont(name: "MontserratRoman-SemiBold", size: 48) + static let navigationSubtitle = UIFont(name: "MontserratRoman-Medium", size: 14) + static let navigationTitle = UIFont(name: "MontserratRoman-SemiBold", size: 22) + static let navigationInfoText = UIFont(name: "MontserratRoman-Regular", size: 12) + static let descriptionText = UIFont(name: "MontserratRoman-Regular", size: 16) + static let timeText = UIFont(name: "MontserratRoman-SemiBold", size: 14) + static let locationText = UIFont(name: "MontserratRoman-SemiBold", size: 12) + static let bubbleSponsorText = UIFont(name: "MontserratRoman-SemiBold", size: 12) + static let sponsorText = UIFont(name: "MontserratRoman-Regular", size: 16) + static let welcomeTitle = UIFont(name: "MontserratRoman-Bold", size: UIDevice.current.userInterfaceIdiom == .pad ? 40: 24) + static let loginTitle = UIFont(name: "MontserratRoman-Bold", size: UIDevice.current.userInterfaceIdiom == .pad ? 32: 24) + static let loginOrTitle = UIFont(name: "MontserratRoman-Bold", size: UIDevice.current.userInterfaceIdiom == .pad ? 20 : 16) + static let loginSelection = UIFont(name: "MontserratRoman-SemiBold", size: UIDevice.current.userInterfaceIdiom == .pad ? 26: 16) + + static let sectionHeader = UIFont(name: "MontserratRoman-Bold", size: 13) + static let button = UIFont(name: "MontserratRoman-Regular", size: 15) + static let glyph = UIFont(name: "MontserratRoman-Bold", size: 16) + + static let profileName = UIFont(name: "MontserratRoman-Bold", size: UIDevice.current.userInterfaceIdiom == .pad ? 40 : 20) + static let profileSubtitle = UIFont(name: "MontserratRoman-Bold", size: UIDevice.current.userInterfaceIdiom == .pad ? 24 : 12) + static let profileDietaryRestrictions = UIFont(name: "MontserratRoman-SemiBold", size: UIDevice.current.userInterfaceIdiom == .pad ? 32 : 16) + static let profileDietaryRestrictionsLabel = UIFont(name: "MontserratRoman-Bold", size: UIDevice.current.userInterfaceIdiom == .pad ? 24 : 12) + static let profileTier = UIFont(name: "MontserratRoman-Bold", size: UIDevice.current.userInterfaceIdiom == .pad ? 36 : 18) + + + static let profileNumberFigure = UIFont(name: "MontserratRoman-SemiBold", size: 24) + static let profileUsername = UIFont(name: "MontserratRoman-Bold", size: 16) + static let profileInterests = UIFont(name: "MontserratRoman-SemiBold", size: 14) + static let segmentedTitle = UIFont(name: "MontserratRoman-Bold", size: 16) + static let homeSegmentedTitle = UIFont(name: "MontserratRoman-Bold", size: 24) + static let segmentedNumberText = UIFont(name: "MontserratRoman-SemiBold", size: 18) + + static let QRCheckInFont = UIFont(name: "MontserratRoman-SemiBold", size: 14) + + static let countdownText = UIFont(name: "MontserratRoman-Bold", size: 25) + static let newCountdownText = UIFont(name: "MontserratRoman-Bold", size: 48) + static let onboardingGetStartedText = UIFont(name: "MontserratRoman-SemiBold", size: 25) + static let onboardingTitle = UIFont(name: "MontserratRoman-Bold", size: 30) + static let onboardingDescription = UIFont(name: "MontserratRoman-Regular", size: 20) + static let leaderboardPoints = UIFont(name: "MontserratRoman-Semibold", size: 12) + static let leaderboardName = UIFont(name: "MontserratRoman-SemiBold", size: 16) + static let leaderboardRank = UIFont(name: "MontserratRoman-Bold", size: 24) + static let leaderboardPointsPad = UIFont(name: "MontserratRoman-Bold", size: 24) + static let leaderboardNamePad = UIFont(name: "MontserratRoman-SemiBold", size: 32) + static let leaderboardRankPad = UIFont(name: "MontserratRoman-Bold", size: 48) } } @@ -329,7 +424,6 @@ class HIThemeEngine { private init() { startUpTimer() } - deinit { tearDownTimer() } @@ -345,7 +439,6 @@ class HIThemeEngine { ) timer?.fire() } - @objc func updateThemeIfNeeded() { let calendar = Calendar.current let now = Date() @@ -360,7 +453,6 @@ class HIThemeEngine { } HIAppearance.change(to: newAppearance) } - func tearDownTimer() { timer?.invalidate() timer = nil diff --git a/HackIllinois/UI/HIErrorView.swift b/HackIllinois/UI/HIErrorView.swift index bf92ceab..75f8472e 100644 --- a/HackIllinois/UI/HIErrorView.swift +++ b/HackIllinois/UI/HIErrorView.swift @@ -13,7 +13,7 @@ import Foundation import UIKit -protocol HIErrorViewDelegate: class { +protocol HIErrorViewDelegate: AnyObject { func didSelectErrorLogout(_ sender: UIButton) } class HIErrorView: HIView { @@ -33,7 +33,7 @@ class HIErrorView: HIView { $0.titleLabel?.font = HIAppearance.Font.detailSubtitle $0.titleLabel?.baselineAdjustment = .alignCenters $0.layer.cornerRadius = 20 - $0.addTarget(self, action: #selector(didSelectLogoutButton(_:)), for: .touchUpInside) + $0.addTarget(HIErrorView.self, action: #selector(didSelectLogoutButton(_:)), for: .touchUpInside) } // MARK: - Init @@ -60,11 +60,11 @@ class HIErrorView: HIView { errorLabel.leadingAnchor.constraint(equalTo: leadingAnchor).isActive = true errorLabel.centerXAnchor.constraint(equalTo: centerXAnchor).isActive = true - self.addSubview(logoutButton) + /*self.addSubview(logoutButton) logoutButton.topAnchor.constraint(equalTo: errorLabel.bottomAnchor, constant: 10).isActive = true logoutButton.centerXAnchor.constraint(equalTo: centerXAnchor).isActive = true logoutButton.widthAnchor.constraint(equalTo: widthAnchor, multiplier: 0.5).isActive = true - logoutButton.heightAnchor.constraint(equalToConstant: 40).isActive = true + logoutButton.heightAnchor.constraint(equalToConstant: 40).isActive = true*/ translatesAutoresizingMaskIntoConstraints = false NotificationCenter.default.addObserver(self, selector: #selector(refreshForThemeChange), name: .themeDidChange, object: nil) diff --git a/HackIllinois/UI/HIHomeSegmentedControl.swift b/HackIllinois/UI/HIHomeSegmentedControl.swift index e694486c..711b81d7 100644 --- a/HackIllinois/UI/HIHomeSegmentedControl.swift +++ b/HackIllinois/UI/HIHomeSegmentedControl.swift @@ -12,6 +12,7 @@ import Foundation import UIKit +import SwiftUI class HIHomeSegmentedControl: HISegmentedControl { @@ -20,10 +21,11 @@ class HIHomeSegmentedControl: HISegmentedControl { private var views = [UIView]() private var titleLabels = [UILabel]() - private let titleFont = HIAppearance.Font.segmentedTitle + private let titleFont = HIAppearance.Font.homeSegmentedTitle + private let titleFontPad = HIAppearance.Font.homeSegmentedTitlePad private let numberFont = HIAppearance.Font.segmentedNumberText - private let viewPadding: CGFloat = 10 + private var viewPadding: CGFloat = 35 private let indicatorCornerRadiusProp: CGFloat = 0.15 private var indicatorView = UIImageView(image: #imageLiteral(resourceName: "Indicator")) @@ -50,7 +52,7 @@ class HIHomeSegmentedControl: HISegmentedControl { @objc override func refreshForThemeChange() { backgroundColor <- \.clear titleLabels.forEach { - $0.textColor <- \.baseText + $0.textColor <- \.white $0.backgroundColor <- \.clear } } @@ -58,11 +60,15 @@ class HIHomeSegmentedControl: HISegmentedControl { // MARK: - UIView override func layoutSubviews() { super.layoutSubviews() - let indicatorViewWidth = ((frame.width - viewPadding) / CGFloat(items.count) - viewPadding) - indicatorView.frame = CGRect(x: viewPadding, y: 50, width: indicatorViewWidth, height: 7) + var indicatorViewConstant: CGFloat = 4 + if UIDevice.current.userInterfaceIdiom == .pad { + indicatorViewConstant = 6 + } + indicatorView.frame = CGRect(x: indicatorViewWidth, y: 40 + indicatorViewConstant, width: indicatorViewWidth, height: indicatorViewConstant) indicatorView.layer.cornerRadius = frame.height * indicatorCornerRadiusProp indicatorView.layer.masksToBounds = true + indicatorView.contentMode = .center indicatorView.contentMode = .scaleAspectFit displayNewSelectedIndex() } @@ -70,11 +76,9 @@ class HIHomeSegmentedControl: HISegmentedControl { override func beginTracking(_ touch: UITouch, with event: UIEvent?) -> Bool { let location = touch.location(in: self) - for (index, view) in views.enumerated() { - if view.frame.contains(location) { + for (index, view) in views.enumerated() where view.frame.contains(location) { selectedIndex = index break - } } return false @@ -96,21 +100,24 @@ class HIHomeSegmentedControl: HISegmentedControl { private func setupViewForItem(at index: Int) { let view = UIView() let titleLabel = UILabel() - + if UIDevice.current.userInterfaceIdiom == .pad { + titleLabel.font = titleFontPad + } else { + titleLabel.font = titleFont + } titleLabel.textAlignment = .center - titleLabel.font = numberFont + titleLabel.text = items[index] titleLabel.textColor <- \.whiteText - titleLabel.adjustsFontSizeToFitWidth = true + titleLabel.adjustsFontSizeToFitWidth = false view.addSubview(titleLabel) titleLabel.translatesAutoresizingMaskIntoConstraints = false titleLabel.constrain(to: view, topInset: 5, trailingInset: 0, bottomInset: -5, leadingInset: 0) view.isUserInteractionEnabled = false titleLabel.isUserInteractionEnabled = false - - view.translatesAutoresizingMaskIntoConstraints = false addSubview(view) + view.translatesAutoresizingMaskIntoConstraints = false views.append(view) titleLabels.append(titleLabel) } diff --git a/HackIllinois/UI/HILabel.swift b/HackIllinois/UI/HILabel.swift index 02733265..90f7eb63 100644 --- a/HackIllinois/UI/HILabel.swift +++ b/HackIllinois/UI/HILabel.swift @@ -39,6 +39,7 @@ class HILabel: UILabel { case profileTier case profileUsername case profileInterests + case profileDietaryRestrictions case navigationInfo case countdown case pointsText @@ -50,6 +51,10 @@ class HILabel: UILabel { case leaderboardRank case leaderboardName case leaderboardPoints + case neonCountdown + case newSponsor + case newLocation + case newTime } // MARK: - Properties @@ -70,16 +75,28 @@ class HILabel: UILabel { translatesAutoresizingMaskIntoConstraints = false if let style = style { switch style { + case .neonCountdown: + textHIColor = \.neonCountdownText + backgroundHIColor = \.clear + font = HIAppearance.Font.newCountdownText case .location: textHIColor = \.baseText backgroundHIColor = \.clear - font = HIAppearance.Font.contentText + if UIDevice.current.userInterfaceIdiom == .pad { + font = HIAppearance.Font.contentTextPad + } else { + font = HIAppearance.Font.contentText + } case .event: textHIColor = \.baseText backgroundHIColor = \.clear - font = HIAppearance.Font.eventTitle + if UIDevice.current.userInterfaceIdiom == .pad { + font = HIAppearance.Font.eventTitlePad + } else { + font = HIAppearance.Font.eventTitle + } case .eventTime: textHIColor = \.baseText @@ -87,9 +104,9 @@ class HILabel: UILabel { font = HIAppearance.Font.eventTime case .eventType: - textHIColor = \.baseText + textHIColor = \.whiteText backgroundHIColor = \.clear - font = HIAppearance.Font.eventCategoryText + font = HIAppearance.Font.eventButtonText case .sponsor: textHIColor = \.baseText @@ -114,16 +131,20 @@ class HILabel: UILabel { font = HIAppearance.Font.detailText numberOfLines = 0 - case .project: - textHIColor = \.baseText + case .project: // "Schedule" + textHIColor = \.white backgroundHIColor = \.clear font = HIAppearance.Font.contentTitle - case .viewTitle: - textHIColor = \.baseText + case .viewTitle: // "What's cooking" + textHIColor = \.whiteText backgroundHIColor = \.clear textAlignment = .center - font = HIAppearance.Font.viewTitle + if UIDevice.current.userInterfaceIdiom == .pad { + font = HIAppearance.Font.viewTitlePad + } else { + font = HIAppearance.Font.viewTitle + } case .subtitle: textHIColor = \.accent @@ -133,13 +154,21 @@ class HILabel: UILabel { case .description: textHIColor = \.baseText backgroundHIColor = \.clear - font = HIAppearance.Font.descriptionText + if UIDevice.current.userInterfaceIdiom == .pad { + font = HIAppearance.Font.descriptionTextPad + } else { + font = HIAppearance.Font.descriptionText + } numberOfLines = 0 case .cellDescription: textHIColor = \.baseText backgroundHIColor = \.clear - font = HIAppearance.Font.eventDetails + if UIDevice.current.userInterfaceIdiom == .pad { + font = HIAppearance.Font.detailTextPad + } else { + font = HIAppearance.Font.eventDetails + } numberOfLines = 0 case .loginHeader: @@ -150,7 +179,7 @@ class HILabel: UILabel { case .welcomeTitle: textHIColor = \.loginSelectionText backgroundHIColor = \.clear - font = HIAppearance.Font.loginTitle + font = HIAppearance.Font.welcomeTitle case .backgroundTitle: textHIColor = \.baseText @@ -203,8 +232,14 @@ class HILabel: UILabel { textAlignment = .center font = HIAppearance.Font.profileInterests - case .navigationInfo: - textHIColor = \.titleText + case .profileDietaryRestrictions: + textHIColor = \.baseText + backgroundHIColor = \.clear + textAlignment = .center + font = HIAppearance.Font.profileDietaryRestrictions + + case .navigationInfo: // "All times are in CDT" + textHIColor = \.white backgroundHIColor = \.clear font = HIAppearance.Font.navigationInfoText textAlignment = .left @@ -215,58 +250,105 @@ class HILabel: UILabel { font = HIAppearance.Font.countdownText case .pointsText: - textHIColor = \.baseText + textHIColor = \.white backgroundHIColor = \.clear - font = HIAppearance.Font.eventButtonText + if UIDevice.current.userInterfaceIdiom == .pad { + font = HIAppearance.Font.glyphPad + } else { + font = HIAppearance.Font.eventButtonText + } textAlignment = .center case .error: - textHIColor = \.baseText + textHIColor = \.white backgroundHIColor = \.clear font = HIAppearance.Font.detailSubtitle textAlignment = .center numberOfLines = 0 case .codeError: - textHIColor = \.baseText + textHIColor = \.white backgroundHIColor = \.clear font = HIAppearance.Font.detailSubtitle textAlignment = .center numberOfLines = 0 + case .onboardingDescription: textHIColor = \.baseText backgroundHIColor = \.clear font = HIAppearance.Font.onboardingDescription textAlignment = .center numberOfLines = 0 + case .onboardingTitle: - textHIColor = \.baseText + textHIColor = \.whiteText backgroundHIColor = \.clear font = HIAppearance.Font.onboardingTitle textAlignment = .center numberOfLines = 0 + case .clock: - textHIColor = \.baseText + textHIColor = \.whiteText backgroundHIColor = \.clear font = HIAppearance.Font.clockText textAlignment = .center numberOfLines = 1 + // Leaderboard label fonts case .leaderboardRank: textHIColor = \.leaderboardText backgroundHIColor = \.clear - font = HIAppearance.Font.leaderboardRank - layer.shadowOffset = CGSize(width: 2, height: 2) - layer.shadowRadius = 2.0 - layer.shadowOpacity = 0.25 + if UIDevice.current.userInterfaceIdiom == .pad { + font = HIAppearance.Font.leaderboardRankPad + } else { + font = HIAppearance.Font.leaderboardRank + } + case .leaderboardName: textHIColor = \.leaderboardText backgroundHIColor = \.clear - font = HIAppearance.Font.leaderboardPoints + if UIDevice.current.userInterfaceIdiom == .pad { + font = HIAppearance.Font.leaderboardNamePad + } else { + font = HIAppearance.Font.leaderboardName + } + case .leaderboardPoints: textHIColor = \.leaderboardText backgroundHIColor = \.pointsBackground - font = HIAppearance.Font.leaderboardPoints + if UIDevice.current.userInterfaceIdiom == .pad { + font = HIAppearance.Font.leaderboardPointsPad + } else { + font = HIAppearance.Font.leaderboardPoints + } + + case .newTime: + textHIColor = \.black + backgroundHIColor = \.clear + if UIDevice.current.userInterfaceIdiom == .pad { + font = HIAppearance.Font.timeTextPad + } else { + font = HIAppearance.Font.timeText + } + + case .newSponsor: + textHIColor = \.black + backgroundHIColor = \.clear + font = HIAppearance.Font.bubbleSponsorText + if UIDevice.current.userInterfaceIdiom == .pad { + font = HIAppearance.Font.sponsorTextPad + } else { + font = HIAppearance.Font.bubbleSponsorText + } + + case .newLocation: + textHIColor = \.black + backgroundHIColor = \.clear + if UIDevice.current.userInterfaceIdiom == .pad { + font = HIAppearance.Font.locationTextPad + } else { + font = HIAppearance.Font.locationText + } } } diff --git a/HackIllinois/UI/HIScheduleSegmentedControl.swift b/HackIllinois/UI/HIScheduleSegmentedControl.swift index 47fd461e..479993bf 100644 --- a/HackIllinois/UI/HIScheduleSegmentedControl.swift +++ b/HackIllinois/UI/HIScheduleSegmentedControl.swift @@ -23,9 +23,11 @@ class HIScheduleSegmentedControl: HISegmentedControl { private var numberLabels = [UILabel]() private let titleFont = HIAppearance.Font.segmentedTitle + private let titleFontPad = HIAppearance.Font.scheduleSegmentedPad private let numberFont = HIAppearance.Font.segmentedNumberText + private let numberFontPad = HIAppearance.Font.scheduleSegmentedNumberPad - private let viewPadding: CGFloat = 10 + private let viewPadding: CGFloat = 65 private let indicatorCornerRadiusProp: CGFloat = 0.15 private var indicatorView = UIImageView(image: #imageLiteral(resourceName: "Indicator")) @@ -53,12 +55,12 @@ class HIScheduleSegmentedControl: HISegmentedControl { @objc override func refreshForThemeChange() { backgroundColor <- \.clear titleLabels.forEach { - $0.textColor <- \.baseText + $0.textColor <- \.white $0.backgroundColor <- \.clear } numberLabels.forEach { - $0.textColor <- \.baseText + $0.textColor <- \.white $0.backgroundColor <- \.clear } } @@ -66,22 +68,24 @@ class HIScheduleSegmentedControl: HISegmentedControl { // MARK: - UIView override func layoutSubviews() { super.layoutSubviews() - + var indicatorConstant: CGFloat = 0.0 + if UIDevice.current.userInterfaceIdiom == .pad { + indicatorConstant = 50.0 + } let indicatorViewWidth = ((frame.width - viewPadding) / CGFloat(items.count) - viewPadding) - indicatorView.frame = CGRect(x: viewPadding, y: 60, width: indicatorViewWidth, height: 7) + indicatorView.frame = CGRect(x: viewPadding, y: 68 + indicatorConstant, width: indicatorViewWidth, height: 4 + (indicatorConstant / 6)) indicatorView.layer.masksToBounds = true indicatorView.contentMode = .scaleAspectFit + indicatorView.contentMode = .center displayNewSelectedIndex() } override func beginTracking(_ touch: UITouch, with event: UIEvent?) -> Bool { let location = touch.location(in: self) - for (index, view) in views.enumerated() { - if view.frame.contains(location) { + for (index, view) in views.enumerated() where view.frame.contains(location) { selectedIndex = index break - } } return false @@ -106,12 +110,17 @@ class HIScheduleSegmentedControl: HISegmentedControl { let numberLabel = UILabel() titleLabel.textAlignment = .center - titleLabel.font = titleFont + if UIDevice.current.userInterfaceIdiom == .pad { + titleLabel.font = titleFontPad + numberLabel.font = numberFontPad + } else { + titleLabel.font = titleFont + numberLabel.font = numberFont + } titleLabel.text = items[index] titleLabel.textColor <- \.whiteText numberLabel.textAlignment = .center - numberLabel.font = numberFont numberLabel.text = index < nums.count ? (nums[index] % 10 == nums[index] ? "0" : "") + "\(nums[index])" : "00" numberLabel.textColor <- \.whiteText @@ -119,19 +128,22 @@ class HIScheduleSegmentedControl: HISegmentedControl { view.addSubview(numberLabel) titleLabel.translatesAutoresizingMaskIntoConstraints = false numberLabel.translatesAutoresizingMaskIntoConstraints = false - + var segmentedControlConstant = 0.0 + if UIDevice.current.userInterfaceIdiom == .pad { + segmentedControlConstant = 24.0 + } titleLabel.constrain(to: view, topInset: 5, trailingInset: 0, leadingInset: 0) - numberLabel.constrain(to: view, trailingInset: 0, bottomInset: -5, leadingInset: 0) - numberLabel.topAnchor.constraint(equalTo: titleLabel.bottomAnchor, constant: 0).isActive = true + numberLabel.constrain(to: view, trailingInset: 0, bottomInset: -4, leadingInset: 0) + numberLabel.topAnchor.constraint(equalTo: titleLabel.bottomAnchor, constant: segmentedControlConstant).isActive = true titleLabel.heightAnchor.constraint(equalTo: numberLabel.heightAnchor).isActive = true view.isUserInteractionEnabled = false titleLabel.isUserInteractionEnabled = false numberLabel.isUserInteractionEnabled = false - view.translatesAutoresizingMaskIntoConstraints = false addSubview(view) views.append(view) + view.translatesAutoresizingMaskIntoConstraints = false titleLabels.append(titleLabel) numberLabels.append(numberLabel) } diff --git a/HackIllinois/UI/HISegmentedControl.swift b/HackIllinois/UI/HISegmentedControl.swift index d4a4347a..dc753cc8 100644 --- a/HackIllinois/UI/HISegmentedControl.swift +++ b/HackIllinois/UI/HISegmentedControl.swift @@ -59,7 +59,7 @@ class HISegmentedControl: UIControl { @objc func refreshForThemeChange() { backgroundColor <- \.clear labels.forEach { - $0.textColor <- \.baseText + $0.textColor <- \.white $0.backgroundColor <- \.clear } @@ -82,11 +82,9 @@ class HISegmentedControl: UIControl { override func beginTracking(_ touch: UITouch, with event: UIEvent?) -> Bool { let location = touch.location(in: self) - for (index, view) in views.enumerated() { - if view.frame.contains(location) { + for (index, view) in views.enumerated() where view.frame.contains(location) { selectedIndex = index break - } } return false diff --git a/HackIllinois/UI/HITextField.swift b/HackIllinois/UI/HITextField.swift index c1416a4b..44b9ffba 100644 --- a/HackIllinois/UI/HITextField.swift +++ b/HackIllinois/UI/HITextField.swift @@ -37,7 +37,7 @@ class HITextField: UITextField { tintHIColor = \.accent backgroundHIColor = \.baseBackground case .editProfile: - font = HIAppearance.Font.profileTier.withSize(18) + font = HIAppearance.Font.profileTier!.withSize(18) textHIColor = \.whiteTagFont tintHIColor = \.whiteTagFont backgroundHIColor = \.clear diff --git a/HackIllinois/UI/HITextView.swift b/HackIllinois/UI/HITextView.swift index 8cc18ff1..ca44d321 100644 --- a/HackIllinois/UI/HITextView.swift +++ b/HackIllinois/UI/HITextView.swift @@ -24,7 +24,7 @@ class HITextView: UITextView { init() { super.init(frame: .zero, textContainer: nil) - font = HIAppearance.Font.profileTier.withSize(18) + font = HIAppearance.Font.profileTier!.withSize(18) textHIColor = \.whiteTagFont tintHIColor = \.whiteTagFont backgroundHIColor = \.clear diff --git a/HackIllinois/UI/Identifiable.swift b/HackIllinois/UI/Identifiable.swift index 7ec996fd..570b7227 100644 --- a/HackIllinois/UI/Identifiable.swift +++ b/HackIllinois/UI/Identifiable.swift @@ -13,14 +13,14 @@ import Foundation import UIKit -protocol Identifiable { - static var identifier: String { get } -} +//protocol Identifiable { +// static var identifier: String { get } +//} extension UITableViewCell: Identifiable { - static var identifier: String = String(describing: self) + static var identifier: String = String(describing: UITableViewCell.self) } extension UITableViewHeaderFooterView: Identifiable { - static var identifier: String = String(describing: self) + static var identifier: String = String(describing: UITableViewHeaderFooterView.self) } diff --git a/HackIllinois/UI/TableView/Cells/HIBubbleCell/HIBubbleCell.swift b/HackIllinois/UI/TableView/Cells/HIBubbleCell/HIBubbleCell.swift index 96a24027..31528080 100644 --- a/HackIllinois/UI/TableView/Cells/HIBubbleCell/HIBubbleCell.swift +++ b/HackIllinois/UI/TableView/Cells/HIBubbleCell/HIBubbleCell.swift @@ -20,7 +20,10 @@ class HIBubbleCell: UITableViewCell { var bubbleView = HIView { $0.backgroundHIColor = \.contentBackground $0.translatesAutoresizingMaskIntoConstraints = false - $0.layer.cornerRadius = 8 + $0.layer.cornerRadius = 20 + if UIDevice.current.userInterfaceIdiom == .pad { + $0.layer.cornerRadius = 40 + } $0.layer.masksToBounds = false $0.layer.shadowColor = #colorLiteral(red: 0.1333333333, green: 0.168627451, blue: 0.3607843137, alpha: 0.3984650088) $0.layer.shadowOffset = CGSize(width: 0, height: 3) diff --git a/HackIllinois/UI/TableView/Cells/HIBubbleCell/HIEventCell.swift b/HackIllinois/UI/TableView/Cells/HIBubbleCell/HIEventCell.swift index 91503851..4eb72289 100644 --- a/HackIllinois/UI/TableView/Cells/HIBubbleCell/HIEventCell.swift +++ b/HackIllinois/UI/TableView/Cells/HIBubbleCell/HIEventCell.swift @@ -25,44 +25,53 @@ class HIEventCell: HIBubbleCell { $0.backgroundHIColor = \.clear $0.activeImage = #imageLiteral(resourceName: "Favorited") $0.baseImage = #imageLiteral(resourceName: "Unfavorited") + if UIDevice.current.userInterfaceIdiom == .pad { + $0.activeImage = #imageLiteral(resourceName: "FavoritedPad") + $0.baseImage = #imageLiteral(resourceName: "UnFavoritedPad") + } } var headerView = UIStackView() var contentStackView = UIStackView() var contentStackViewHeight = NSLayoutConstraint() - + var indexPath: IndexPath? weak var delegate: HIEventCellDelegate? - + // MARK: - Init override init(style: UITableViewCell.CellStyle, reuseIdentifier: String?) { super.init(style: style, reuseIdentifier: reuseIdentifier) - + var headerSpacingConstant: CGFloat = 1.0 + if UIDevice.current.userInterfaceIdiom == .pad { + headerSpacingConstant = 2.0 + } backgroundColor = UIColor.clear favoritedButton.addTarget(self, action: #selector(didSelectFavoriteButton(_:)), for: .touchUpInside) // add bubble view contentView.layer.backgroundColor = UIColor.clear.cgColor + bubbleView.addSubview(headerView) headerView.axis = .vertical + headerView.alignment = .leading headerView.translatesAutoresizingMaskIntoConstraints = false - bubbleView.addSubview(headerView) - headerView.leadingAnchor.constraint(equalTo: bubbleView.leadingAnchor, constant: 17).isActive = true - headerView.topAnchor.constraint(equalTo: bubbleView.topAnchor, constant: 16).isActive = true + headerView.leadingAnchor.constraint(equalTo: bubbleView.leadingAnchor, constant: 17 * headerSpacingConstant).isActive = true + headerView.topAnchor.constraint(equalTo: bubbleView.topAnchor, constant: 16 * headerSpacingConstant).isActive = true bubbleView.addSubview(favoritedButton) - favoritedButton.constrain(width: 58, height: 60) + favoritedButton.constrain(width: 58 * headerSpacingConstant, height: 50 * headerSpacingConstant) favoritedButton.constrain(to: bubbleView, topInset: 0, trailingInset: 0) - favoritedButton.leadingAnchor.constraint(equalTo: headerView.trailingAnchor).isActive = true + + bubbleView.addSubview(contentStackView) contentStackView.axis = .vertical + contentStackView.alignment = .leading contentStackView.translatesAutoresizingMaskIntoConstraints = false - bubbleView.addSubview(contentStackView) contentStackView.leadingAnchor.constraint(equalTo: headerView.leadingAnchor).isActive = true contentStackView.trailingAnchor.constraint(equalTo: bubbleView.trailingAnchor, constant: -16).isActive = true - contentStackView.topAnchor.constraint(equalTo: headerView.bottomAnchor, constant: 4).isActive = true - contentStackView.bottomAnchor.constraint(greaterThanOrEqualTo: bubbleView.bottomAnchor).isActive = true + contentStackView.topAnchor.constraint(equalTo: headerView.bottomAnchor, constant: 10 * headerSpacingConstant).isActive = true + contentStackView.bottomAnchor.constraint(greaterThanOrEqualTo: bubbleView.bottomAnchor, constant: -16 * headerSpacingConstant).isActive = true // Don't show favorite button for guests if HIApplicationStateController.shared.isGuest { favoritedButton.isHidden = true } } - + required init?(coder aDecoder: NSCoder) { fatalError("init(coder:) should not be used.") } @@ -73,91 +82,126 @@ extension HIEventCell { @objc func didSelectFavoriteButton(_ sender: HIButton) { delegate?.eventCellDidSelectFavoriteButton(self) } - + } // MARK: - Population extension HIEventCell { static func heightForCell(with event: Event, width: CGFloat) -> CGFloat { - let heightFromEventName = HILabel.heightForView(text: event.name, font: HIAppearance.Font.eventTitle, width: width - 137) - let heightFromHeader = (heightFromEventName + 4 + 17 < 60) ? 60 : heightFromEventName + 4 + 17 - let height = heightFromEventName + 40 + 90 + 15 + let heightFromEventName = HILabel.heightForView(text: event.name, font: HIAppearance.Font.eventTitle!, width: width - 137) + var heightConstant: CGFloat = 1.6 + if UIDevice.current.userInterfaceIdiom == .pad { + heightConstant = 11.0 + } + let height = heightFromEventName + 160 if !event.sponsor.isEmpty { - return height + 20 + return height + (20 * heightConstant) + } + if UIDevice.current.userInterfaceIdiom == .pad { + return height + (22 * (heightConstant / 1.45)) } - return height + return height + 5 } - static func <- (lhs: HIEventCell, rhs: Event) { lhs.favoritedButton.isActive = rhs.favorite - var contentStackViewHeight: CGFloat = 0 - + var contentStackViewHeight: CGFloat = 0.0 + var eventCellSpacing: CGFloat = 8.0 + var stackViewSpacing: CGFloat = 4.7 + var bubbleConstant: CGFloat = 1.0 + var locationImageView = UIImageView(image: #imageLiteral(resourceName: "LocationSign")) + var timeImageView = UIImageView(image: #imageLiteral(resourceName: "Clock")) + var sponsorImageView = UIImageView(image: #imageLiteral(resourceName: "Vector")) let titleLabel = HILabel(style: .event) - titleLabel.numberOfLines = 0 - titleLabel.text = rhs.name - titleLabel.translatesAutoresizingMaskIntoConstraints = false + titleLabel.numberOfLines = 2 lhs.headerView.addArrangedSubview(titleLabel) - lhs.headerView.setCustomSpacing(4, after: titleLabel) - let eventTypeLabel = HILabel(style: .cellDescription) - let eventType = HIEventType(type: rhs.eventType) - eventTypeLabel.text = eventType.description.lowercased().capitalized - eventTypeLabel.textHIColor = \.baseText - eventTypeLabel.refreshForThemeChange() - eventTypeLabel.translatesAutoresizingMaskIntoConstraints = false - lhs.headerView.addArrangedSubview(eventTypeLabel) - let titleHeight = HILabel.heightForView(text: rhs.name, font: HIAppearance.Font.eventTitle, width: lhs.contentView.frame.width - 137) // Can test for a more accurate constant - titleLabel.constrain(height: titleHeight) - eventTypeLabel.constrain(height: 20) - if !rhs.sponsor.isEmpty { - let sponsorLabel = HILabel(style: .cellDescription) - sponsorLabel.text = "Sponsored by \(rhs.sponsor)" - contentStackViewHeight += sponsorLabel.intrinsicContentSize.height - sponsorLabel.constrain(height: 25) - lhs.contentStackView.addArrangedSubview(sponsorLabel) - lhs.contentStackView.setCustomSpacing(10, after: sponsorLabel) + titleLabel.text = rhs.name + lhs.headerView.setCustomSpacing(9, after: titleLabel) + if UIDevice.current.userInterfaceIdiom == .pad { + eventCellSpacing = 12.0 + stackViewSpacing = 15.0 + bubbleConstant = 2.0 + locationImageView = UIImageView(image: #imageLiteral(resourceName: "VectorPad")) + timeImageView = UIImageView(image: #imageLiteral(resourceName: "TimePad")) + sponsorImageView = UIImageView(image: #imageLiteral(resourceName: "SponsorPad")) + lhs.headerView.setCustomSpacing(18, after: titleLabel) } + titleLabel.constrain(width: lhs.contentView.frame.width - 120, height: (HILabel.heightForView(text: rhs.name, font: HIAppearance.Font.eventTitle!, width: lhs.contentView.frame.width - 137)) * bubbleConstant) let upperContainerView = HIView { + lhs.contentStackView.addArrangedSubview($0) $0.translatesAutoresizingMaskIntoConstraints = false } - lhs.contentStackView.addArrangedSubview(upperContainerView) - let timeImageView = UIImageView(image: #imageLiteral(resourceName: "Clock")) - upperContainerView.addSubview(timeImageView) - timeImageView.leadingAnchor.constraint(equalTo: upperContainerView.leadingAnchor).isActive = true - timeImageView.centerYAnchor.constraint(equalTo: upperContainerView.centerYAnchor).isActive = true - let timeLabel = HILabel(style: .eventTime) + let middleContainerView = HIView { + lhs.contentStackView.addArrangedSubview($0) + $0.translatesAutoresizingMaskIntoConstraints = false + } + let timeLabel = HILabel(style: .newTime) // We can check for async events by checking if the event start and end time is 1970-01-01 00:00:00 +0000 if rhs.startTime.timeIntervalSince1970 == 0 || rhs.endTime.timeIntervalSince1970 == 0 { - // Default text for async events timeLabel.text = HIConstants.ASYNC_EVENT_TIME_TEXT } else { timeLabel.text = Formatter.simpleTime.string(from: rhs.startTime) + " - " + Formatter.simpleTime.string(from: rhs.endTime) } - upperContainerView.addSubview(timeLabel) - timeLabel.leadingAnchor.constraint(equalTo: timeImageView.trailingAnchor, constant: 5).isActive = true - timeLabel.centerYAnchor.constraint(equalTo: timeImageView.centerYAnchor).isActive = true - timeLabel.heightAnchor.constraint(equalTo: upperContainerView.heightAnchor, constant: 7).isActive = true let pointsView = HIView { (view) in - view.layer.cornerRadius = 12 - view.backgroundHIColor = \.buttonGreen + view.layer.cornerRadius = 10.5 * bubbleConstant + view.backgroundHIColor = \.buttonPink + view.translatesAutoresizingMaskIntoConstraints = false + } + let eventTypeView = HIView { (view) in + view.layer.cornerRadius = 10.5 * bubbleConstant + view.backgroundHIColor = \.buttonBlue view.translatesAutoresizingMaskIntoConstraints = false } - let pointsLabel = HILabel(style: .pointsText) + upperContainerView.addSubview(pointsView) pointsView.addSubview(pointsLabel) - pointsLabel.constrain(to: pointsView, topInset: 4, trailingInset: -8, bottomInset: -4, leadingInset: 8) + pointsLabel.constrain(to: pointsView, topInset: 4, trailingInset: -8 * bubbleConstant, bottomInset: -4, leadingInset: 8 * bubbleConstant) pointsLabel.text = "+ \(rhs.points) pts" - upperContainerView.addSubview(pointsView) - pointsView.leadingAnchor.constraint(equalTo: timeLabel.trailingAnchor, constant: 5).isActive = true - pointsView.centerYAnchor.constraint(equalTo: timeImageView.centerYAnchor).isActive = true + let typeLabel = HILabel(style: .pointsText) + lhs.headerView.addArrangedSubview(eventTypeView) + eventTypeView.addSubview(typeLabel) + typeLabel.constrain(to: eventTypeView, topInset: 4, trailingInset: -8, bottomInset: -4, leadingInset: 8) + typeLabel.text = rhs.eventType.description.lowercased().capitalized + eventTypeView.constrain(height: 20 * bubbleConstant) + pointsView.constrain(height: 20 * bubbleConstant) + pointsView.leadingAnchor.constraint(equalTo: eventTypeView.trailingAnchor, constant: 8 * bubbleConstant).isActive = true + pointsView.centerYAnchor.constraint(equalTo: eventTypeView.centerYAnchor).isActive = true + upperContainerView.addSubview(timeImageView) + upperContainerView.addSubview(timeLabel) + timeLabel.leadingAnchor.constraint(equalTo: timeImageView.trailingAnchor, constant: eventCellSpacing + 1).isActive = true + timeLabel.centerYAnchor.constraint(equalTo: timeImageView.centerYAnchor).isActive = true + if !rhs.sponsor.isEmpty { + let sponsorLabel = HILabel(style: .newSponsor) + middleContainerView.addSubview(sponsorImageView) + middleContainerView.addSubview(sponsorLabel) + sponsorImageView.translatesAutoresizingMaskIntoConstraints = false + sponsorLabel.text = "\(rhs.sponsor)" + contentStackViewHeight += sponsorLabel.intrinsicContentSize.height + sponsorImageView.bottomAnchor.constraint(equalTo: timeImageView.bottomAnchor, constant: (stackViewSpacing * 2.5) + 14).isActive = true + sponsorLabel.leadingAnchor.constraint(equalTo: sponsorImageView.trailingAnchor, constant: eventCellSpacing + 1).isActive = true + sponsorLabel.centerYAnchor.constraint(equalTo: sponsorImageView.centerYAnchor).isActive = true + } + let locationLabel = HILabel(style: .newLocation) + locationLabel.text = "Online" + if rhs.locations.count > 0 { + locationLabel.text = rhs.locations.map({ ($0 as AnyObject).name }).joined(separator: ", ") + } + middleContainerView.addSubview(locationImageView) + locationImageView.translatesAutoresizingMaskIntoConstraints = false + middleContainerView.addSubview(locationLabel) + if !rhs.sponsor.isEmpty { + locationImageView.centerYAnchor.constraint(equalTo: sponsorImageView.centerYAnchor, constant: (stackViewSpacing * 2.5) + 14).isActive = true + } else { + locationImageView.centerYAnchor.constraint(equalTo: timeImageView.centerYAnchor, constant: (stackViewSpacing * 2.5) + 14).isActive = true + } + locationImageView.centerXAnchor.constraint(equalTo: timeImageView.centerXAnchor).isActive = true + locationLabel.leadingAnchor.constraint(equalTo: timeLabel.leadingAnchor).isActive = true + locationLabel.centerYAnchor.constraint(equalTo: locationImageView.centerYAnchor).isActive = true let descriptionLabel = HILabel(style: .cellDescription) descriptionLabel.numberOfLines = 2 - let descriptionText = rhs.info - descriptionLabel.text = descriptionText + descriptionLabel.text = "\(rhs.info)" lhs.contentStackView.addArrangedSubview(descriptionLabel) - lhs.contentStackView.setCustomSpacing(10, after: descriptionLabel) - let textHeight = HILabel.heightForView(text: rhs.name, font: HIAppearance.Font.eventTitle, width: lhs.contentView.frame.width - 98) - contentStackViewHeight += textHeight - contentStackViewHeight += timeLabel.intrinsicContentSize.height + 13 + 40 + 3 + 40 + contentStackViewHeight += HILabel.heightForView(text: rhs.name, font: HIAppearance.Font.eventTitle!, width: lhs.contentView.frame.width - 98) + contentStackViewHeight += timeLabel.intrinsicContentSize.height + locationLabel.intrinsicContentSize.height + 13 + 40 + 3 + 40 } } diff --git a/HackIllinois/UI/TableView/Cells/HIBubbleCell/HIProjectCell.swift b/HackIllinois/UI/TableView/Cells/HIBubbleCell/HIProjectCell.swift index 87324ea2..bed478ca 100644 --- a/HackIllinois/UI/TableView/Cells/HIBubbleCell/HIProjectCell.swift +++ b/HackIllinois/UI/TableView/Cells/HIBubbleCell/HIProjectCell.swift @@ -14,7 +14,7 @@ import Foundation import UIKit import HIAPI -protocol HIProjectCellDelegate: class { +protocol HIProjectCellDelegate: AnyObject { func projectCellDidSelectFavoriteButton(_ projectCell: HIProjectCell) } diff --git a/HackIllinois/UI/TableView/Cells/HILeaderboardCell.swift b/HackIllinois/UI/TableView/Cells/HILeaderboardCell.swift index 185d57a1..daf8c0e1 100644 --- a/HackIllinois/UI/TableView/Cells/HILeaderboardCell.swift +++ b/HackIllinois/UI/TableView/Cells/HILeaderboardCell.swift @@ -51,6 +51,10 @@ extension HILeaderboardCell { } static func <- (lhs: HILeaderboardCell, rhs: LeaderboardProfile) { + var padConstant = 1.0 + if UIDevice.current.userInterfaceIdiom == .pad { + padConstant = 2.0 + } lhs.rankLabel.textAlignment = .center lhs.pointsLabel.textAlignment = .center lhs.pointsLabel.backgroundHIColor = \.pointsBackground @@ -63,17 +67,23 @@ extension HILeaderboardCell { lhs.nameLabel.textAlignment = .left lhs.rankLabel.centerYAnchor.constraint(equalTo: lhs.cellView.centerYAnchor).isActive = true - lhs.rankLabel.leadingAnchor.constraint(equalTo: lhs.cellView.leadingAnchor, constant: 15).isActive = true + lhs.rankLabel.leadingAnchor.constraint(equalTo: lhs.cellView.leadingAnchor, constant: 25 * padConstant).isActive = true lhs.rankLabel.setContentHuggingPriority(.defaultHigh, for: .horizontal) lhs.pointsLabel.centerYAnchor.constraint(equalTo: lhs.cellView.centerYAnchor).isActive = true - lhs.pointsLabel.widthAnchor.constraint(equalTo: lhs.cellView.widthAnchor, multiplier: 0.30).isActive = true - lhs.pointsLabel.trailingAnchor.constraint(equalTo: lhs.cellView.trailingAnchor, constant: -15).isActive = true - lhs.pointsLabel.heightAnchor.constraint(equalTo: lhs.cellView.heightAnchor, multiplier: 0.45).isActive = true + lhs.pointsLabel.widthAnchor.constraint(equalTo: lhs.cellView.widthAnchor, multiplier: 0.24).isActive = true + lhs.pointsLabel.trailingAnchor.constraint(equalTo: lhs.cellView.trailingAnchor, constant: -25).isActive = true + lhs.pointsLabel.heightAnchor.constraint(equalTo: lhs.cellView.heightAnchor, multiplier: 0.38).isActive = true lhs.nameLabel.centerYAnchor.constraint(equalTo: lhs.cellView.centerYAnchor).isActive = true - lhs.nameLabel.leadingAnchor.constraint(equalTo: lhs.rankLabel.trailingAnchor, constant: 15).isActive = true - lhs.nameLabel.trailingAnchor.constraint(equalTo: lhs.pointsLabel.leadingAnchor, constant: -15).isActive = true + lhs.nameLabel.leadingAnchor.constraint(equalTo: lhs.rankLabel.leadingAnchor, constant: 50 * padConstant).isActive = true + + if UIDevice.current.userInterfaceIdiom == .pad { + lhs.nameLabel.constrain(width: lhs.contentView.frame.width, height: 40.0) + } else { + lhs.nameLabel.constrain(width: lhs.contentView.frame.width - 185, height: 20.0) + lhs.nameLabel.numberOfLines = 1 + } } } diff --git a/HackIllinois/UI/TableView/Cells/HILoginSelectionCell.swift b/HackIllinois/UI/TableView/Cells/HILoginSelectionCell.swift index 4f66ae7c..130cc0f2 100644 --- a/HackIllinois/UI/TableView/Cells/HILoginSelectionCell.swift +++ b/HackIllinois/UI/TableView/Cells/HILoginSelectionCell.swift @@ -13,7 +13,7 @@ import Foundation import UIKit -protocol HILoginSelectionCellDelegate: class { +protocol HILoginSelectionCellDelegate: AnyObject { } @@ -39,8 +39,8 @@ class HILoginSelectionCell: UITableViewCell { contentView.addSubview(titleLabel) titleLabel.centerXAnchor.constraint(equalTo: contentView.centerXAnchor).isActive = true titleLabel.centerYAnchor.constraint(equalTo: contentView.centerYAnchor).isActive = true - titleLabel.heightAnchor.constraint(equalToConstant: 36).isActive = true - titleLabel.widthAnchor.constraint(equalToConstant: 200).isActive = true + titleLabel.heightAnchor.constraint(equalToConstant: UIDevice.current.userInterfaceIdiom == .pad ? 60 : 36).isActive = true + titleLabel.widthAnchor.constraint(equalToConstant: UIDevice.current.userInterfaceIdiom == .pad ? 355 : 200).isActive = true NotificationCenter.default.addObserver(self, selector: #selector(refreshForThemeChange), name: .themeDidChange, object: nil) refreshForThemeChange() diff --git a/HackIllinois/UI/TableView/Headers/HIDateHeader.swift b/HackIllinois/UI/TableView/Headers/HIDateHeader.swift index 841f79a5..31a8520c 100644 --- a/HackIllinois/UI/TableView/Headers/HIDateHeader.swift +++ b/HackIllinois/UI/TableView/Headers/HIDateHeader.swift @@ -19,18 +19,24 @@ class HIDateHeader: UITableViewHeaderFooterView { $0.backgroundHIColor = \.clear $0.font = HIAppearance.Font.sectionHeader } + let dateView = HIView { (view) in + view.layer.cornerRadius = 10 + view.backgroundHIColor = \.buttonDarkBlue + } override init(reuseIdentifier: String?) { super.init(reuseIdentifier: reuseIdentifier) let backgroundView = HIView { $0.backgroundHIColor = \.clear } self.backgroundView = backgroundView - - backgroundView.addSubview(titleLabel) - titleLabel.topAnchor.constraint(equalTo: safeAreaLayoutGuide.topAnchor).isActive = true - titleLabel.leadingAnchor.constraint(equalTo: safeAreaLayoutGuide.leadingAnchor, constant: 14).isActive = true - titleLabel.bottomAnchor.constraint(equalTo: safeAreaLayoutGuide.bottomAnchor).isActive = true - titleLabel.trailingAnchor.constraint(equalTo: safeAreaLayoutGuide.trailingAnchor, constant: -14).isActive = true + backgroundView.addSubview(dateView) + dateView.translatesAutoresizingMaskIntoConstraints = false + var spaceConstant: CGFloat = 1.0 + dateView.addSubview(titleLabel) + dateView.topAnchor.constraint(equalTo: safeAreaLayoutGuide.topAnchor, constant: -8).isActive = true + dateView.centerXAnchor.constraint(equalTo: safeAreaLayoutGuide.centerXAnchor).isActive = true + dateView.bottomAnchor.constraint(equalTo: safeAreaLayoutGuide.bottomAnchor, constant: -8).isActive = true + titleLabel.constrain(to: dateView, topInset: 4 * spaceConstant, trailingInset: -16 * spaceConstant, bottomInset: -4 * spaceConstant, leadingInset: 16 * spaceConstant) } required init?(coder aDecoder: NSCoder) { diff --git a/HackIllinois/ViewControllers/HIBannerViewController.swift b/HackIllinois/ViewControllers/HIBannerViewController.swift new file mode 100644 index 00000000..cf1b55b2 --- /dev/null +++ b/HackIllinois/ViewControllers/HIBannerViewController.swift @@ -0,0 +1,59 @@ +// +// HIBannerViewController.swift +// HackIllinois +// +// Created by HackIllinois Team on 12/30/22. +// Copyright © 2022 HackIllinois. All rights reserved. +// This file is part of the Hackillinois iOS App. +// The Hackillinois iOS App is open source software, released under the University of +// Illinois/NCSA Open Source License. You should have received a copy of +// this license in a file with the distribution. +// + +import Foundation +import UIKit + +class HIBannerViewController: UIViewController { + private let backgroundHIColor: HIColor = \.clear + private let label = HILabel { + $0.textHIColor = \.whiteText + $0.backgroundHIColor = \.clear + $0.textAlignment = .center + $0.font = HIAppearance.Font.glyph + if UIDevice.current.userInterfaceIdiom == .pad { + $0.font = HIAppearance.Font.glyphPad + } + } +} + +extension HIBannerViewController { + override func loadView() { + view = HIView { $0.backgroundHIColor = \.clear } + + let bannerStackView = UIStackView() + view.addSubview(bannerStackView) + bannerStackView.distribution = .fillEqually + bannerStackView.translatesAutoresizingMaskIntoConstraints = false + bannerStackView.topAnchor.constraint(equalTo: view.topAnchor).isActive = true + bannerStackView.leadingAnchor.constraint(equalTo: view.leadingAnchor).isActive = true + bannerStackView.bottomAnchor.constraint(equalTo: view.bottomAnchor).isActive = true + bannerStackView.trailingAnchor.constraint(equalTo: view.trailingAnchor).isActive = true + let daysContent = bannerView(with: label) + bannerStackView.addArrangedSubview(daysContent) + } + func bannerView(with label: HILabel) -> UIView { + let bannerView = UIView() + bannerView.addSubview(label) + label.constrain(to: bannerView, topInset: 0, trailingInset: 0, leadingInset: 0) + bannerView.constrain(to: bannerView, trailingInset: 0, bottomInset: 0, leadingInset: 0) + bannerView.bottomAnchor.constraint(equalTo: label.topAnchor).isActive = true + return bannerView + } + public func updateLabel(with text: String) { + label.text = text + } + + override func viewWillAppear(_ animated: Bool) { + super.viewWillAppear(animated) + } +} diff --git a/HackIllinois/ViewControllers/HIBaseScannerViewController.swift b/HackIllinois/ViewControllers/HIBaseScannerViewController.swift index 830e2211..9ba6891e 100644 --- a/HackIllinois/ViewControllers/HIBaseScannerViewController.swift +++ b/HackIllinois/ViewControllers/HIBaseScannerViewController.swift @@ -128,8 +128,9 @@ extension HIBaseScannerViewController: AVCaptureMetadataOutputObjectsDelegate { previewLayer.frame = previewView.layer.bounds guard previewLayer.connection?.isVideoOrientationSupported == true else { return } - - switch UIApplication.shared.statusBarOrientation { + #warning ("Not tested") + let interfaceOrientation = UIApplication.shared.windows.first?.windowScene?.interfaceOrientation + switch interfaceOrientation { case .portrait, .unknown: previewLayer.connection?.videoOrientation = .portrait case .portraitUpsideDown: @@ -138,6 +139,8 @@ extension HIBaseScannerViewController: AVCaptureMetadataOutputObjectsDelegate { previewLayer.connection?.videoOrientation = .landscapeLeft case .landscapeRight: previewLayer.connection?.videoOrientation = .landscapeRight + case .none: + break @unknown default: previewLayer.connection?.videoOrientation = .portrait } diff --git a/HackIllinois/ViewControllers/HIBaseViewController.swift b/HackIllinois/ViewControllers/HIBaseViewController.swift index b716b40f..4826ca0a 100644 --- a/HackIllinois/ViewControllers/HIBaseViewController.swift +++ b/HackIllinois/ViewControllers/HIBaseViewController.swift @@ -19,7 +19,7 @@ class HIBaseViewController: UIViewController { // MARK: - Properties var _fetchedResultsController: NSFetchedResultsController? var refreshControl = UIRefreshControl() - var refreshAnimation = AnimationView(name: "refresh") + var refreshAnimation = LottieAnimationView(name: "refresh") var tableView: UITableView? var backgroundView = UIImageView() let tableBackgroundView = HIView() @@ -109,7 +109,12 @@ extension HIBaseViewController { @objc func setCustomTitle(customTitle: String) { let label = HILabel(style: .viewTitle) label.text = customTitle - self.navigationItem.leftBarButtonItem = UIBarButtonItem.init(customView: label) + + let view = UIView(frame: CGRect(x: 0, y: 0, width: 80, height: 30)) + view.bounds = view.bounds.offsetBy(dx: -24, dy: 0) + view.addSubview(label) + + self.navigationItem.leftBarButtonItem = UIBarButtonItem.init(customView: view) self.navigationItem.leftItemsSupplementBackButton = true } } @@ -353,12 +358,17 @@ extension HIBaseViewController { let keyboardFrame = keyboardFrameValue.cgRectValue layout?(keyboardFrame) - - UIView.beginAnimations(nil, context: nil) - UIView.setAnimationDuration(duration) - UIView.setAnimationCurve(curve) - view.layoutIfNeeded() - UIView.commitAnimations() +// UIView.beginAnimations(nil, context: nil) +// UIView.setAnimationDuration(duration) +// UIView.setAnimationCurve(curve) +// view.layoutIfNeeded() +// UIView.commitAnimations() + #warning("Not tested") + let animator = UIViewPropertyAnimator(duration: duration, curve: curve) + animator.addAnimations { + self.view.layoutIfNeeded() + } + animator.startAnimation() } } diff --git a/HackIllinois/ViewControllers/HICountdownViewController.swift b/HackIllinois/ViewControllers/HICountdownViewController.swift index 72a99d08..b8864179 100644 --- a/HackIllinois/ViewControllers/HICountdownViewController.swift +++ b/HackIllinois/ViewControllers/HICountdownViewController.swift @@ -12,9 +12,10 @@ import Foundation import UIKit +import SwiftUI import Lottie -protocol HICountdownViewControllerDelegate: class { +protocol HICountdownViewControllerDelegate: AnyObject { func countdownToDateFor(countdownViewController: HICountdownViewController) -> Date? } @@ -24,10 +25,10 @@ class HICountdownViewController: UIViewController { private let FRAMES_PER_TICK = 8 // MARK: - Properties - private let days = HILabel(style: .clock) - private let hours = HILabel(style: .clock) - private let minutes = HILabel(style: .clock) - private let seconds = HILabel(style: .clock) + private let days = HILabel(style: .neonCountdown) + private let hours = HILabel(style: .neonCountdown) + private let minutes = HILabel(style: .neonCountdown) + private let seconds = HILabel(style: .neonCountdown) private let backgroundHIColor: HIColor = \.clear private var countdownDate: Date? @@ -97,35 +98,66 @@ extension HICountdownViewController { countdownStackView.leadingAnchor.constraint(equalTo: view.leadingAnchor).isActive = true countdownStackView.bottomAnchor.constraint(equalTo: view.bottomAnchor).isActive = true countdownStackView.trailingAnchor.constraint(equalTo: view.trailingAnchor).isActive = true - - let daysContent = containerView(with: days, and: "Days") + let daysContent = containerView(with: "DAYS", and: days) countdownStackView.addArrangedSubview(daysContent) - let hoursContent = containerView(with: hours, and: "Hours") + let hoursContent = containerView(with: "HOURS", and: hours) countdownStackView.addArrangedSubview(hoursContent) - countdownStackView.setCustomSpacing(10, after: daysContent) - let minutesContent = containerView(with: minutes, and: "Minutes") + let minutesContent = containerView(with: "MINUTES", and: minutes) countdownStackView.addArrangedSubview(minutesContent) - countdownStackView.setCustomSpacing(10, after: hoursContent) + var countdownSpacingConstant: CGFloat = 30 + if UIDevice.current.userInterfaceIdiom == .pad { + countdownSpacingConstant = 60 + } + countdownStackView.setCustomSpacing(countdownSpacingConstant, after: daysContent) + countdownStackView.setCustomSpacing(countdownSpacingConstant, after: hoursContent) + countdownStackView.setCustomSpacing(countdownSpacingConstant, after: minutesContent) } - - func containerView(with countDownView: HILabel, and labelString: String) -> UIView { + func containerView(with labelString: String, and countDownView: HILabel) -> UIView { countDownView.backgroundColor <- backgroundHIColor countDownView.translatesAutoresizingMaskIntoConstraints = false let label = HILabel { - $0.textHIColor = \.titleText + $0.textHIColor = \.whiteText $0.backgroundHIColor = \.clear $0.textAlignment = .center - $0.font = HIAppearance.Font.glyph + if UIDevice.current.userInterfaceIdiom == .pad { + $0.font = HIAppearance.Font.timeIndicator + } else { + $0.font = HIAppearance.Font.glyph + } $0.text = labelString } + let yellowish = #colorLiteral(red: 0.9882352941, green: 0.862745098, blue: 0.5607843137, alpha: 1) + let strokeTextAttributes = [ + NSAttributedString.Key.strokeColor: yellowish, + NSAttributedString.Key.foregroundColor: UIColor.clear, + NSAttributedString.Key.strokeWidth: 5.0, + NSAttributedString.Key.font: UIFont.systemFont(ofSize: 48, weight: UIFont.Weight(rawValue: 900) )] + as [NSAttributedString.Key: Any] + let iPadStrokeTextAttributes = [ + NSAttributedString.Key.strokeColor: yellowish, + NSAttributedString.Key.foregroundColor: UIColor.clear, + NSAttributedString.Key.strokeWidth: 5.0, + NSAttributedString.Key.font: UIFont.systemFont(ofSize: 90, weight: UIFont.Weight(rawValue: 900) )] + as [NSAttributedString.Key: Any] + if UIDevice.current.userInterfaceIdiom == .pad { + countDownView.attributedText = NSMutableAttributedString(string: "Test", attributes: iPadStrokeTextAttributes) + } else { + countDownView.attributedText = NSMutableAttributedString(string: "Test", attributes: strokeTextAttributes) + } + countDownView.layer.shadowColor = yellowish.cgColor + countDownView.layer.shadowRadius = 3.0 + countDownView.layer.shadowOpacity = 100.0 + countDownView.layer.masksToBounds = false + countDownView.layer.shouldRasterize = true + countDownView.layer.shadowOffset = .zero let containerView = UIView() containerView.addSubview(label) containerView.addSubview(countDownView) label.constrain(to: containerView, topInset: 0, trailingInset: 0, leadingInset: 0) - countDownView.constrain(to: containerView, trailingInset: 0, bottomInset: 0, leadingInset: 0) - label.bottomAnchor.constraint(equalTo: countDownView.topAnchor).isActive = true + countDownView.centerXAnchor.constraint(equalTo: containerView.centerXAnchor).isActive = true + countDownView.bottomAnchor.constraint(equalTo: label.topAnchor, constant: -4).isActive = true return containerView } @@ -161,6 +193,10 @@ extension HICountdownViewController { hours.text = String(format: "%02d", (hoursRemaining)) minutes.text = String(format: "%02d", (minutesRemaining)) seconds.text = String(format: "%02d", (secondsRemaining)) + days.textAlignment = .center + hours.textAlignment = .center + minutes.textAlignment = .center + seconds.textAlignment = .center } @objc func updateCountdown() { diff --git a/HackIllinois/ViewControllers/HIEventDetailViewController.swift b/HackIllinois/ViewControllers/HIEventDetailViewController.swift index f9961ae9..1903f239 100644 --- a/HackIllinois/ViewControllers/HIEventDetailViewController.swift +++ b/HackIllinois/ViewControllers/HIEventDetailViewController.swift @@ -15,6 +15,7 @@ import UIKit import MapKit import HIAPI import APIManager +import GoogleMaps class HIEventDetailViewController: HIBaseViewController { // MARK: - Properties @@ -32,17 +33,33 @@ class HIEventDetailViewController: HIBaseViewController { $0.backgroundHIColor = \.clear } private let titleLabel = HILabel(style: .detailTitle) - private let sponsorLabel = HILabel(style: .sponsor) + + private let eventTypeView = HIView { (view) in + if UIDevice.current.userInterfaceIdiom == .pad { + view.layer.cornerRadius = 12 + } else { + view.layer.cornerRadius = 8 + } + view.backgroundHIColor = \.buttonDarkBlueGreen + view.translatesAutoresizingMaskIntoConstraints = false + } private let eventTypeLabel = HILabel(style: .eventType) + private let sponsorLabel = HILabel(style: .sponsor) + private let timeImageView = UIImageView(image: UIImage(named: "Clock")) private let timeLabel = HILabel(style: .description) + private let locationLabel = HILabel(style: .location) + private let locationImageView = UIImageView(image: UIImage(named: "LocationSign")) private let descriptionLabel = HILabel(style: .detailText) let pointsView = HIView { (view) in - view.layer.cornerRadius = 8 - view.backgroundHIColor = \.buttonGreen + if UIDevice.current.userInterfaceIdiom == .pad { + view.layer.cornerRadius = 12 + } else { + view.layer.cornerRadius = 8 + } + view.backgroundHIColor = \.buttonMagenta view.translatesAutoresizingMaskIntoConstraints = false } - private let pointsLabel = HILabel(style: .pointsText) - private let timeImageView = UIImageView(image: #imageLiteral(resourceName: "Clock")) + private let pointsLabel = HILabel(style: .eventType) private let favoritedButton = HIButton { $0.tintHIColor = \.accent $0.backgroundHIColor = \.clear @@ -55,9 +72,15 @@ class HIEventDetailViewController: HIBaseViewController { $0.activeImage = #imageLiteral(resourceName: "MenuClose") $0.baseImage = #imageLiteral(resourceName: "MenuClose") } + private var mapView: GMSMapView! + // private let mapContainerView = HIView { + // $0.translatesAutoresizingMaskIntoConstraints = false + // $0.backgroundHIColor = \.clear + // } // MARK: Constraints private var descriptionLabelHeight = NSLayoutConstraint() + } // MARK: - Actions @@ -66,27 +89,29 @@ extension HIEventDetailViewController { guard let event = event else { return } let changeFavoriteStatusRequest: APIRequest = - sender.isActive ? - HIAPI.EventService.unfavoriteBy(id: event.id) : - HIAPI.EventService.favoriteBy(id: event.id) + sender.isActive ? + HIAPI.EventService.unfavoriteBy(id: event.id) : + HIAPI.EventService.favoriteBy(id: event.id) changeFavoriteStatusRequest - .onCompletion { result in - switch result { - case .success: - DispatchQueue.main.async { - sender.isActive.toggle() - event.favorite.toggle() - event.favorite ? - HILocalNotificationController.shared.scheduleNotification(for: event) : - HILocalNotificationController.shared.unscheduleNotification(for: event) + .onCompletion { result in + switch result { + case .success: + DispatchQueue.main.async { + sender.isActive.toggle() + event.favorite.toggle() + if event.favorite { + HILocalNotificationController.shared.scheduleNotification(for: event) + } else { + HILocalNotificationController.shared.unscheduleNotification(for: event) + } + } + case .failure(let error): + print(error, error.localizedDescription) } - case .failure(let error): - print(error, error.localizedDescription) } - } - .authorize(with: HIApplicationStateController.shared.user) - .launch() + .authorize(with: HIApplicationStateController.shared.user) + .launch() } @objc func didSelectCloseButton(_ sender: HIButton) { @@ -111,6 +136,8 @@ extension HIEventDetailViewController { } setupTime() setupPoints() + setupLocation() + setupMap() setupDescription() } @@ -131,12 +158,30 @@ extension HIEventDetailViewController { timeLabel.text = Formatter.simpleTime.string(from: event.startTime) + " - " + Formatter.simpleTime.string(from: event.endTime) } favoritedButton.isActive = event.favorite - pointsLabel.text = "+ \(event.points) pts " - eventTypeLabel.text = event.eventType.lowercased().capitalized + pointsLabel.text = " + \(event.points) pts " + eventTypeLabel.text = " \(event.eventType.lowercased().capitalized) " view.layoutIfNeeded() let targetSize = CGSize(width: descriptionLabel.frame.width, height: .greatestFiniteMagnitude) let neededSize = descriptionLabel.sizeThatFits(targetSize) descriptionLabelHeight.constant = neededSize.height + // Default text for online events + locationLabel.text = HIConstants.ONLINE_EVENT_LOCATION_TEXT + // check if this event has a location + if event.locations.count > 0 { + // concatenate all location names + locationLabel.text = event.locations.map { ($0 as AnyObject).name }.joined(separator: ", ") + } + // MARK: GoogleMap Setup + for case let loc as Location in event.locations { + DispatchQueue.main.async { [self] in + let newcamera = GMSCameraPosition.camera(withLatitude: loc.latitude, longitude: loc.longitude, zoom: 18.0) + mapView.camera = newcamera + let marker = GMSMarker() + marker.title = loc.name + marker.position = CLLocationCoordinate2D(latitude: loc.latitude, longitude: loc.longitude) + marker.map = mapView + } + } } override func viewDidAppear(_ animated: Bool) { @@ -152,12 +197,14 @@ extension HIEventDetailViewController { eventDetailContainer.addSubview(upperContainerView) upperContainerView.constrain(to: eventDetailContainer, topInset: 25, trailingInset: 0, leadingInset: 0) - upperContainerView.constrain(height: 75) + upperContainerView.constrain(height: 95) } func setupEventType() { - upperContainerView.addSubview(eventTypeLabel) - eventTypeLabel.leadingAnchor.constraint(equalTo: titleLabel.leadingAnchor).isActive = true - eventTypeLabel.topAnchor.constraint(equalTo: titleLabel.bottomAnchor, constant: 5).isActive = true + upperContainerView.addSubview(eventTypeView) + eventTypeView.leadingAnchor.constraint(equalTo: titleLabel.leadingAnchor).isActive = true + eventTypeView.topAnchor.constraint(equalTo: titleLabel.bottomAnchor, constant: 10).isActive = true + eventTypeView.addSubview(eventTypeLabel) + eventTypeLabel.constrain(to: eventTypeView, topInset: 0, trailingInset: 0, bottomInset: 0, leadingInset: 0) } func setupSponsor() { upperContainerView.addSubview(sponsorLabel) @@ -182,20 +229,42 @@ extension HIEventDetailViewController { } func setupPoints() { upperContainerView.addSubview(pointsView) - pointsView.centerYAnchor.constraint(equalTo: timeImageView.centerYAnchor).isActive = true - pointsView.leadingAnchor.constraint(equalTo: timeLabel.trailingAnchor, constant: 10).isActive = true + pointsView.centerYAnchor.constraint(equalTo: eventTypeView.centerYAnchor).isActive = true + pointsView.leadingAnchor.constraint(equalTo: eventTypeView.trailingAnchor, constant: 10).isActive = true pointsView.addSubview(pointsLabel) pointsLabel.constrain(to: pointsView, topInset: 0, trailingInset: 0, bottomInset: 0, leadingInset: 0) } func setupDescription() { eventDetailContainer.addSubview(descriptionLabel) - descriptionLabel.topAnchor.constraint(equalTo: timeLabel.bottomAnchor, constant: 15).isActive = true + descriptionLabel.topAnchor.constraint(equalTo: mapView.bottomAnchor, constant: 15).isActive = true descriptionLabel.constrain(to: eventDetailContainer, trailingInset: 0) descriptionLabel.leadingAnchor.constraint(equalTo: titleLabel.leadingAnchor).isActive = true descriptionLabelHeight = descriptionLabel.heightAnchor.constraint(equalToConstant: 100) descriptionLabelHeight.isActive = true } - + func setupLocation() { + upperContainerView.addSubview(locationImageView) + locationImageView.translatesAutoresizingMaskIntoConstraints = false + locationImageView.topAnchor.constraint(equalTo: timeImageView.bottomAnchor, constant: 10).isActive = true + locationImageView.leadingAnchor.constraint(equalTo: titleLabel.leadingAnchor).isActive = true + upperContainerView.addSubview(locationLabel) + locationLabel.centerYAnchor.constraint(equalTo: locationImageView.centerYAnchor).isActive = true + locationLabel.leadingAnchor.constraint(equalTo: locationImageView.leadingAnchor, constant: 20).isActive = true + } + func setupMap() { + let camera = GMSCameraPosition.camera(withLatitude: 40.113882445333154, longitude: -88.22491715718857, zoom: 18.0) +// let mapID = GMSMapID(identifier: "66c463c9a421326e") +// mapView = GMSMapView(frame: .zero, mapID: mapID, camera: camera) + // Map without nightmode + mapView = GMSMapView(frame: .zero, camera: camera) + eventDetailContainer.addSubview(mapView) + mapView.translatesAutoresizingMaskIntoConstraints = false + mapView.leadingAnchor.constraint(equalTo: eventDetailContainer.leadingAnchor).isActive = true + mapView.trailingAnchor.constraint(equalTo: eventDetailContainer.trailingAnchor).isActive = true + mapView.topAnchor.constraint(equalTo: locationImageView.bottomAnchor, constant: 15).isActive = true + mapView.constrain(height: 300) + mapView.layer.cornerRadius = 20 + } func setupCloseButton() { view.addSubview(closeButton) closeButton.addTarget(self, action: #selector(didSelectCloseButton(_:)), for: .touchUpInside) @@ -203,7 +272,6 @@ extension HIEventDetailViewController { closeButton.leadingAnchor.constraint(equalTo: view.safeAreaLayoutGuide.leadingAnchor, constant: 12).isActive = true closeButton.constrain(height: 20) } - func setupFavoritedButton() { view.addSubview(favoritedButton) favoritedButton.topAnchor.constraint(equalTo: view.safeAreaLayoutGuide.topAnchor, constant: 10).isActive = true diff --git a/HackIllinois/ViewControllers/HIEventListViewController.swift b/HackIllinois/ViewControllers/HIEventListViewController.swift index 0beb9279..dfeeacff 100644 --- a/HackIllinois/ViewControllers/HIEventListViewController.swift +++ b/HackIllinois/ViewControllers/HIEventListViewController.swift @@ -25,7 +25,8 @@ extension HIEventListViewController { if let tableView = tableView { tableView.register(HIDateHeader.self, forHeaderFooterViewReuseIdentifier: HIDateHeader.identifier) tableView.register(HIEventCell.self, forCellReuseIdentifier: HIEventCell.identifier) - registerForPreviewing(with: self, sourceView: tableView) + #warning("I don't think this is being used. Related to 3D touch and previewing") +// registerForPreviewing(with: self, sourceView: tableView) } super.setupTableView() } @@ -85,9 +86,11 @@ extension HIEventListViewController: HIEventCellDelegate { case .success: DispatchQueue.main.async { event.favorite.toggle() - event.favorite ? - HILocalNotificationController.shared.scheduleNotification(for: event) : + if event.favorite { + HILocalNotificationController.shared.scheduleNotification(for: event) + } else { HILocalNotificationController.shared.unscheduleNotification(for: event) + } } case .failure(let error): print(error, error.localizedDescription) @@ -98,20 +101,21 @@ extension HIEventListViewController: HIEventCellDelegate { } } +#warning("I don't think this is being used. Related to 3D touch and previewing") // MARK: - UIViewControllerPreviewingDelegate -extension HIEventListViewController: UIViewControllerPreviewingDelegate { - func previewingContext(_ previewingContext: UIViewControllerPreviewing, viewControllerForLocation location: CGPoint) -> UIViewController? { - guard let tableView = tableView, - let indexPath = tableView.indexPathForRow(at: location), - let event = _fetchedResultsController?.object(at: indexPath) as? Event else { - return nil - } - previewingContext.sourceRect = tableView.rectForRow(at: indexPath) - eventDetailViewController.event = event - return eventDetailViewController - } - - func previewingContext(_ previewingContext: UIViewControllerPreviewing, commit viewControllerToCommit: UIViewController) { - self.present(viewControllerToCommit, animated: true, completion: nil) - } -} +//extension HIEventListViewController: UIViewControllerPreviewingDelegate { +// func previewingContext(_ previewingContext: UIViewControllerPreviewing, viewControllerForLocation location: CGPoint) -> UIViewController? { +// guard let tableView = tableView, +// let indexPath = tableView.indexPathForRow(at: location), +// let event = _fetchedResultsController?.object(at: indexPath) as? Event else { +// return nil +// } +// previewingContext.sourceRect = tableView.rectForRow(at: indexPath) +// eventDetailViewController.event = event +// return eventDetailViewController +// } +// +// func previewingContext(_ previewingContext: UIViewControllerPreviewing, commit viewControllerToCommit: UIViewController) { +// self.present(viewControllerToCommit, animated: true, completion: nil) +// } +//} diff --git a/HackIllinois/ViewControllers/HIHomeViewController.swift b/HackIllinois/ViewControllers/HIHomeViewController.swift index 3af615f1..efe62f32 100644 --- a/HackIllinois/ViewControllers/HIHomeViewController.swift +++ b/HackIllinois/ViewControllers/HIHomeViewController.swift @@ -43,21 +43,31 @@ class HIHomeViewController: HIEventListViewController { private var currentTab = 0 - private var dataStore: [String] = ["Ongoing", "Upcoming", "Async"] + private var dataStore: [String] = ["CURRENT", "UPCOMING"] private lazy var countdownViewController = HICountdownViewController(delegate: self) + private lazy var bannerViewController = HIBannerViewController() private let countdownFrameView = HIView { $0.translatesAutoresizingMaskIntoConstraints = false - let viewImage = #imageLiteral(resourceName: "Chicken") - $0.layer.contents = viewImage.cgImage + } + private let bannerFrameView = HIView { + $0.translatesAutoresizingMaskIntoConstraints = false + if UIDevice.current.userInterfaceIdiom == .pad { + let bannerImage = #imageLiteral(resourceName: "BannerPad") + $0.layer.contents = bannerImage.cgImage + } else { + let bannerImage = #imageLiteral(resourceName: "Banner") + $0.layer.contents = bannerImage.cgImage + } } private var countdownDataStoreIndex = 0 + // changed to upper case for 2023 designs private var staticDataStore: [(date: Date, displayText: String)] = [ - (HITimeDataSource.shared.eventTimes.eventStart, "HackIllinois Begins In"), - (HITimeDataSource.shared.eventTimes.hackStart, "Hacking Begins In"), - (HITimeDataSource.shared.eventTimes.hackEnd, "Hacking Ends In"), - (HITimeDataSource.shared.eventTimes.eventEnd, "HackIllinois Ends In") + (HITimeDataSource.shared.eventTimes.eventStart, "HACKILLINOIS BEGINS IN"), + (HITimeDataSource.shared.eventTimes.hackStart, "HACKING BEGINS IN"), + (HITimeDataSource.shared.eventTimes.hackEnd, "HACKING ENDS IN"), + (HITimeDataSource.shared.eventTimes.eventEnd, "HACKILLINOIS ENDS IN") ] private var timer: Timer? @@ -102,21 +112,29 @@ extension HIHomeViewController { extension HIHomeViewController { override func loadView() { super.loadView() + setUpBanner() setUpCountdown() let items = dataStore.map { $0 } let segmentedControl = HIHomeSegmentedControl(status: items) + view.addSubview(segmentedControl) segmentedControl.addTarget(self, action: #selector(didSelectTab(_:)), for: .valueChanged) segmentedControl.translatesAutoresizingMaskIntoConstraints = false - view.addSubview(segmentedControl) - segmentedControl.topAnchor.constraint(equalTo: countdownFrameView.bottomAnchor, constant: 20).isActive = true - segmentedControl.leadingAnchor.constraint(equalTo: view.safeAreaLayoutGuide.leadingAnchor, constant: 10).isActive = true - segmentedControl.centerXAnchor.constraint(equalTo: view.safeAreaLayoutGuide.centerXAnchor).isActive = true + var segmentedControlConstant = 1.0 + if UIDevice.current.userInterfaceIdiom == .pad { + segmentedControlConstant = 2.0 + } else if UIScreen.main.bounds.width < 375.0 { + segmentedControlConstant = 0.9 + } + segmentedControl.topAnchor.constraint(equalTo: bannerFrameView.bottomAnchor, constant: 124 * segmentedControlConstant).isActive = true + segmentedControl.leadingAnchor.constraint(equalTo: view.safeAreaLayoutGuide.leadingAnchor, constant: -30).isActive = true + segmentedControl.trailingAnchor.constraint(equalTo: view.safeAreaLayoutGuide.trailingAnchor, constant: 20).isActive = true + //segmentedControl.centerXAnchor.constraint(equalTo: view.safeAreaLayoutGuide.centerXAnchor).isActive = true segmentedControl.heightAnchor.constraint(equalToConstant: 44).isActive = true let separator = UIView() + self.view.addSubview(separator) separator.translatesAutoresizingMaskIntoConstraints = false separator.backgroundColor <- \.clear - self.view.addSubview(separator) separator.constrain(height: 1 / (UIScreen.main.scale)) separator.constrain(to: view, trailingInset: 0, leadingInset: 0) separator.topAnchor.constraint(equalTo: segmentedControl.bottomAnchor, constant: 10).isActive = true @@ -144,26 +162,56 @@ extension HIHomeViewController { func setUpCountdown() { view.addSubview(countdownFrameView) countdownFrameView.translatesAutoresizingMaskIntoConstraints = false - countdownFrameView.topAnchor.constraint(equalTo: view.safeAreaLayoutGuide.topAnchor, constant: 8).isActive = true - countdownFrameView.centerXAnchor.constraint(equalTo: view.safeAreaLayoutGuide.centerXAnchor).isActive = true var countdownFrameConstant: CGFloat = 1.0 if UIDevice.current.userInterfaceIdiom == .pad { - countdownFrameConstant = 1.2 + countdownFrameConstant = 1.7 } else if UIScreen.main.bounds.width < 375.0 { countdownFrameConstant = 0.9 } + countdownFrameView.topAnchor.constraint(equalTo: bannerFrameView.bottomAnchor, constant: 77 * countdownFrameConstant).isActive = true + countdownFrameView.centerXAnchor.constraint(equalTo: view.safeAreaLayoutGuide.centerXAnchor).isActive = true let widthConstant: CGFloat = 329 * countdownFrameConstant let heightConstant: CGFloat = 283 * countdownFrameConstant countdownFrameView.widthAnchor.constraint(equalToConstant: widthConstant).isActive = true countdownFrameView.heightAnchor.constraint(equalToConstant: heightConstant).isActive = true - - countdownViewController.view.translatesAutoresizingMaskIntoConstraints = false countdownFrameView.addSubview(countdownViewController.view) - countdownViewController.view.topAnchor.constraint(equalTo: countdownFrameView.centerYAnchor, constant: 10).isActive = true + countdownViewController.view.translatesAutoresizingMaskIntoConstraints = false + countdownViewController.view.topAnchor.constraint(equalTo: countdownFrameView.topAnchor).isActive = true countdownViewController.view.heightAnchor.constraint(equalTo: countdownFrameView.heightAnchor, multiplier: 0.3).isActive = true countdownViewController.view.centerXAnchor.constraint(equalTo: view.safeAreaLayoutGuide.centerXAnchor).isActive = true countdownViewController.didMove(toParent: self) } + func setUpBanner() { + view.addSubview(bannerFrameView) + bannerFrameView.translatesAutoresizingMaskIntoConstraints = false + bannerFrameView.leftAnchor.constraint(equalTo: view.safeAreaLayoutGuide.leftAnchor).isActive = true + bannerFrameView.rightAnchor.constraint(equalTo: view.safeAreaLayoutGuide.rightAnchor).isActive = true + bannerFrameView.centerXAnchor.constraint(equalTo: view.safeAreaLayoutGuide.centerXAnchor).isActive = true + var bannerFrameConstant: CGFloat = 1.0 + var bannerFrameTopAnchorConstant: CGFloat = 1.0 + var bannerFrameHeightConstant: CGFloat = 1.0 + if UIDevice.current.userInterfaceIdiom == .pad { + bannerFrameConstant = -0.5 + bannerFrameTopAnchorConstant = 1.9 + bannerFrameHeightConstant = 1.2 + } else if UIScreen.main.bounds.width < 375.0 { + bannerFrameConstant = 0.9 + bannerFrameTopAnchorConstant = 0.9 + bannerFrameHeightConstant = 0.9 + } + bannerFrameView.topAnchor.constraint(equalTo: view.topAnchor, constant: 31.5 * bannerFrameTopAnchorConstant).isActive = true + //let widthConstant: CGFloat = 290 + let heightConstant: CGFloat = 84 * bannerFrameHeightConstant + //bannerFrameView.widthAnchor.constraint(equalToConstant: widthConstant).isActive = true + bannerFrameView.heightAnchor.constraint(equalToConstant: heightConstant).isActive = true + bannerFrameView.addSubview(bannerViewController.view) + bannerViewController.view.translatesAutoresizingMaskIntoConstraints = false + bannerViewController.view.topAnchor.constraint(equalTo: bannerFrameView.centerYAnchor, constant: 10.0 * bannerFrameConstant).isActive = true + //bannerViewController.view.heightAnchor.constraint(equalTo: bannerFrameView.heightAnchor).isActive = true + //bannerViewController.view.heightAnchor.constraint(equalTo: bannerFrameView.heightAnchor, multiplier: 0.3).isActive = true + bannerViewController.view.centerXAnchor.constraint(equalTo: view.safeAreaLayoutGuide.centerXAnchor).isActive = true + bannerViewController.didMove(toParent: self) + } override func viewWillDisappear(_ animated: Bool) { super.viewWillDisappear(animated) @@ -175,7 +223,10 @@ extension HIHomeViewController { extension HIHomeViewController { @objc dynamic override func setUpBackgroundView() { super.setUpBackgroundView() - backgroundView.image = #imageLiteral(resourceName: "ScheduleBackground") + backgroundView.image = #imageLiteral(resourceName: "HomeBackground") + if UIDevice.current.userInterfaceIdiom == .pad { + backgroundView.image = #imageLiteral(resourceName: "BackgroundPad") + } } } @@ -195,11 +246,13 @@ extension HIHomeViewController: HICountdownViewControllerDelegate { let displayText = staticDataStore[countdownDataStoreIndex].displayText if currDate > now { // Displays before and during the event - super.setCustomTitle(customTitle: displayText) +// super.setCustomTitle(customTitle: displayText) + bannerViewController.updateLabel(with: displayText) return currDate } else { // Displays after the event ends - super.setCustomTitle(customTitle: "What's Cooking?") +// super.setCustomTitle(customTitle: "MEMORIES MADE") + bannerViewController.updateLabel(with: "MEMORIES MADE") } countdownDataStoreIndex += 1 } diff --git a/HackIllinois/ViewControllers/HILeaderboardListViewController.swift b/HackIllinois/ViewControllers/HILeaderboardListViewController.swift index b39b476b..20c06fa5 100644 --- a/HackIllinois/ViewControllers/HILeaderboardListViewController.swift +++ b/HackIllinois/ViewControllers/HILeaderboardListViewController.swift @@ -36,18 +36,19 @@ extension HILeaderboardListViewController { cell <- leaderboardProfile cell.indexPath = indexPath cell.rankLabel.text = "\((indexPath.row) + 1)" - if indexPath.row % 2 == 0 { - cell.backgroundColor = #colorLiteral(red: 0.968627451, green: 0.9568627451, blue: 0.8274509804, alpha: 1) - } else { - cell.backgroundColor = #colorLiteral(red: 0.9098039216, green: 0.8431372549, blue: 0.6470588235, alpha: 1) - } + cell.backgroundColor = #colorLiteral(red: 0.7882352941, green: 0.8235294118, blue: 0.8980392157, alpha: 1) + tableView.separatorStyle = .singleLine + tableView.separatorInset = UIEdgeInsets() + tableView.separatorColor = #colorLiteral(red: 0.04009541315, green: 0.1307413591, blue: 0.3802352191, alpha: 1) // Round certain corners based on row if indexPath.row == 0 { - cell.layer.cornerRadius = 8 + cell.layer.cornerRadius = 20 cell.layer.maskedCorners = [.layerMinXMinYCorner, .layerMaxXMinYCorner] } else if indexPath.row == 9 { - cell.layer.cornerRadius = 8 + cell.layer.cornerRadius = 20 cell.layer.maskedCorners = [.layerMinXMaxYCorner, .layerMaxXMaxYCorner] + } else { + cell.layer.cornerRadius = 0 } } diff --git a/HackIllinois/ViewControllers/HILeaderboardViewController.swift b/HackIllinois/ViewControllers/HILeaderboardViewController.swift index 7b93a6c3..e9550e03 100644 --- a/HackIllinois/ViewControllers/HILeaderboardViewController.swift +++ b/HackIllinois/ViewControllers/HILeaderboardViewController.swift @@ -69,10 +69,14 @@ extension HILeaderboardViewController { func layoutProfiles() { // Add tableView to handle leaderboard + var padConstant = 1.0 + if UIDevice.current.userInterfaceIdiom == .pad { + padConstant = 2.0 + } let tableView = HITableView() view.addSubview(tableView) tableView.layer.cornerRadius = 8 - tableView.topAnchor.constraint(equalTo: view.safeAreaLayoutGuide.topAnchor, constant: 15).isActive = true + tableView.topAnchor.constraint(equalTo: view.safeAreaLayoutGuide.topAnchor, constant: 15 * padConstant).isActive = true tableView.heightAnchor.constraint(equalTo: view.safeAreaLayoutGuide.heightAnchor, multiplier: 0.90).isActive = true tableView.widthAnchor.constraint(equalTo: view.safeAreaLayoutGuide.widthAnchor, multiplier: 0.85).isActive = true tableView.centerXAnchor.constraint(equalTo: view.safeAreaLayoutGuide.centerXAnchor).isActive = true @@ -86,7 +90,7 @@ extension HILeaderboardViewController { override func viewDidLoad() { _fetchedResultsController = fetchedResultsController as? NSFetchedResultsController setupRefreshControl() - setCustomTitle(customTitle: "Leaderboard") + setCustomTitle(customTitle: "LEADERBOARD") super.viewDidLoad() } } diff --git a/HackIllinois/ViewControllers/HILoginSelectionViewController.swift b/HackIllinois/ViewControllers/HILoginSelectionViewController.swift index 596536f5..51a39981 100644 --- a/HackIllinois/ViewControllers/HILoginSelectionViewController.swift +++ b/HackIllinois/ViewControllers/HILoginSelectionViewController.swift @@ -14,7 +14,7 @@ import Foundation import UIKit import HIAPI -protocol HILoginSelectionViewControllerDelegate: class { +protocol HILoginSelectionViewControllerDelegate: AnyObject { func loginSelectionViewController(_ loginSelectionViewController: HILoginSelectionViewController, didMakeLoginSelection selection: HIAPI.AuthService.OAuthProvider) } @@ -23,7 +23,11 @@ class HILoginSelectionViewController: HIBaseViewController { weak var delegate: HILoginSelectionViewControllerDelegate? private let logoImage = HIImageView { $0.translatesAutoresizingMaskIntoConstraints = false - $0.hiImage = \.loginLogo + if UIDevice.current.userInterfaceIdiom == .pad { + $0.hiImage = \.loginLogoPad + } else { + $0.hiImage = \.loginLogo + } $0.contentMode = .scaleAspectFit } private let welcomeHeader = HILabel(style: .welcomeTitle) @@ -49,7 +53,11 @@ class HILoginSelectionViewController: HIBaseViewController { @objc dynamic override func setUpBackgroundView() { super.setUpBackgroundView() - backgroundView.image = #imageLiteral(resourceName: "Login") + if UIDevice.current.userInterfaceIdiom == .pad { + backgroundView.image = UIImage(named: "LoginBackgroundPad") + } else { + backgroundView.image = UIImage(named: "LoginBackgroundPhone") + } } } @@ -64,24 +72,26 @@ extension HILoginSelectionViewController { view.addSubview(tableView) if UIDevice.current.userInterfaceIdiom == .pad { tableView.centerXAnchor.constraint(equalTo: view.centerXAnchor, constant: 0).isActive = true - tableView.widthAnchor.constraint(equalToConstant: 220).isActive = true - tableView.heightAnchor.constraint(equalToConstant: 240).isActive = true - tableView.centerYAnchor.constraint(equalTo: view.centerYAnchor, constant: 100).isActive = true - logoImage.bottomAnchor.constraint(equalTo: tableView.topAnchor, constant: -50).isActive = true + tableView.widthAnchor.constraint(equalToConstant: 700).isActive = true + tableView.heightAnchor.constraint(equalToConstant: 370).isActive = true + tableView.centerYAnchor.constraint(equalTo: view.centerYAnchor, constant: 150).isActive = true + logoImage.bottomAnchor.constraint(equalTo: tableView.topAnchor, constant: -20).isActive = true logoImage.centerXAnchor.constraint(equalTo: view.centerXAnchor).isActive = true + logoImage.heightAnchor.constraint(equalToConstant: 250).isActive = true welcomeHeader.text = "WELCOME TO" welcomeHeader.bottomAnchor.constraint(equalTo: logoImage.topAnchor, constant: -25).isActive = true welcomeHeader.centerXAnchor.constraint(equalTo: view.centerXAnchor).isActive = true - welcomeHeader.heightAnchor.constraint(equalToConstant: 22).isActive = true + welcomeHeader.heightAnchor.constraint(equalToConstant: 30).isActive = true } else { tableView.centerXAnchor.constraint(equalTo: view.centerXAnchor, constant: 0).isActive = true tableView.widthAnchor.constraint(equalToConstant: 220).isActive = true tableView.heightAnchor.constraint(equalToConstant: 240).isActive = true tableView.centerYAnchor.constraint(equalTo: view.centerYAnchor, constant: 175).isActive = true - logoImage.bottomAnchor.constraint(equalTo: tableView.topAnchor, constant: -50).isActive = true + logoImage.bottomAnchor.constraint(equalTo: tableView.topAnchor, constant: -20).isActive = true logoImage.centerXAnchor.constraint(equalTo: view.centerXAnchor).isActive = true + logoImage.heightAnchor.constraint(equalToConstant: 250).isActive = true welcomeHeader.text = "WELCOME TO" - welcomeHeader.bottomAnchor.constraint(equalTo: logoImage.topAnchor, constant: -25).isActive = true + welcomeHeader.bottomAnchor.constraint(equalTo: logoImage.topAnchor, constant: -15).isActive = true welcomeHeader.centerXAnchor.constraint(equalTo: view.centerXAnchor).isActive = true welcomeHeader.heightAnchor.constraint(equalToConstant: 22).isActive = true } @@ -164,11 +174,11 @@ extension HILoginSelectionViewController { // MARK: - UITableViewDelegate extension HILoginSelectionViewController { func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat { - return 45 + return UIDevice.current.userInterfaceIdiom == .pad ? 70 : 45 } func tableView(_ tableView: UITableView, heightForFooterInSection section: Int) -> CGFloat { - return 30 + return 40 } override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) { diff --git a/HackIllinois/ViewControllers/HINavigationController.swift b/HackIllinois/ViewControllers/HINavigationController.swift index 60734763..f570e56b 100644 --- a/HackIllinois/ViewControllers/HINavigationController.swift +++ b/HackIllinois/ViewControllers/HINavigationController.swift @@ -61,7 +61,6 @@ class HINavigationController: UINavigationController { infoTitle.constrain(height: 10) infoTitle.translatesAutoresizingMaskIntoConstraints = false infoTitle.isHidden = infoTitleIsHidden - infoTitle.text = "All times are in CDT" additionalSafeAreaInsets.top = 15 navigationBar.titleTextAttributes = [ diff --git a/HackIllinois/ViewControllers/HIOnboardingViewController.swift b/HackIllinois/ViewControllers/HIOnboardingViewController.swift index f401758c..dfc190d6 100644 --- a/HackIllinois/ViewControllers/HIOnboardingViewController.swift +++ b/HackIllinois/ViewControllers/HIOnboardingViewController.swift @@ -18,7 +18,7 @@ class HIOnboardingViewController: HIBaseViewController { //source: https://medium.com/swlh/swift-carousel-759800aa2952 // MARK: - Subviews private var carouselView: HICarouselView? - let animationView = AnimationView(name: "DarkVespaText") + let animationView = LottieAnimationView(name: "DarkVespaText") var shouldDisplayAnimationOnNextAppearance = true // MARK: - Properties @@ -48,7 +48,8 @@ extension HIOnboardingViewController { carouselData.append(.init(image: UIImage(named: "iPadOnboarding1"), titleText: "Schedule", descriptionText: "See the times and details of all of our events.")) carouselData.append(.init(image: UIImage(named: "iPadOnboarding2"), titleText: "Scan for Points", descriptionText: "Scan QR codes at events to obtain points!")) carouselData.append(.init(image: UIImage(named: "iPadOnboarding3"), titleText: "Profile", descriptionText: "View your points, tier, and other personal information.")) - carouselData.append(.init(image: UIImage(named: "iPadOnboarding4"), titleText: "Leaderboard", descriptionText: "See who is leading HackIllinois 2022 in points earned!")) + carouselData.append(.init(image: UIImage(named: "iPadOnboarding4"), titleText: "Leaderboard", + descriptionText: "See who is leading HackIllinois 2022 in points earned!")) } else { carouselData.append(.init(image: #imageLiteral(resourceName: "Onboarding0"), titleText: "Welcome!", descriptionText: "Swipe to see what our app has to offer!")) carouselData.append(.init(image: UIImage(named: "Onboarding1"), titleText: "Countdown", descriptionText: "See how much time you have left to hack!")) diff --git a/HackIllinois/ViewControllers/HIProfileCardView.swift b/HackIllinois/ViewControllers/HIProfileCardView.swift new file mode 100644 index 00000000..0743b73a --- /dev/null +++ b/HackIllinois/ViewControllers/HIProfileCardView.swift @@ -0,0 +1,280 @@ +// +// HIProfileViewController.swift +// HackIllinois +// +// Created by HackIllinois Team on 11/30/22. +// Copyright © 2022 HackIllinois. All rights reserved. +// This file is part of the Hackillinois iOS App. +// The Hackillinois iOS App is open source software, released under the University of +// Illinois/NCSA Open Source License. You should have received a copy of +// this license in a file with the distribution. +// + +import SwiftUI +import HIAPI + +struct HIProfileCardView: View { + let firstName: String + let lastName: String + let dietaryRestrictions: [String] + let points: Int + let tier: String + let foodWave: Int + let background = (\HIAppearance.profileCardBackground).value + let baseText = (\HIAppearance.profileBaseText).value + let id: String + let isIpad = UIDevice.current.userInterfaceIdiom == .pad + @State var flipped: Bool = false + @State var ticketRotation = 0.0 + @State var contentRotation = 0.0 + @State var flipping = false + @State var startFetchingQR = false + @State var qrInfo = "" + + var body: some View { + ScrollView { + ZStack { + Rectangle() + .frame(width: isIpad ? UIScreen.main.bounds.width - 56 * 2 : UIScreen.main.bounds.width - 32 * 2, + height: isIpad ? 978 + 80 : 569 + 40) + .cornerRadius(UIDevice.current.userInterfaceIdiom == .pad ? 40 : 20) + .foregroundColor(Color(background)) + VStack(spacing: 0) { + Text(formatName()) + .font(Font(HIAppearance.Font.profileName ?? .systemFont(ofSize: 20))) + .foregroundColor(Color(baseText)) + .padding(isIpad ? 32 : 16) + HStack(spacing: isIpad ? 16 : 8) { + Rectangle() + .frame(width: isIpad ? 146 : 73, height: isIpad ? 48 : 24) + .cornerRadius(isIpad ? 40 : 20) + .foregroundColor(.white) + .overlay( + Text("\(points) pts") + .font(Font(HIAppearance.Font.profileSubtitle ?? .systemFont(ofSize: 12))) + .foregroundColor(Color(baseText)) + ) + Rectangle() + .frame(width: isIpad ? 204 : 102, height: isIpad ? 48 : 24) + .cornerRadius(isIpad ? 40 : 20) + .foregroundColor(.white) + .overlay( + Text(tier) + .font(Font(HIAppearance.Font.profileSubtitle ?? .systemFont(ofSize: 12))) + .foregroundColor(Color(baseText)) + ) + + Rectangle() + .frame(width: isIpad ? 136 : 68, height: isIpad ? 48 : 24) + .cornerRadius(isIpad ? 40 : 20) + .foregroundColor(.white) + .overlay( + Text("Wave \(foodWave)") + .font(Font(HIAppearance.Font.profileSubtitle ?? .systemFont(ofSize: 12))) + .foregroundColor(Color(baseText)) + ) + } + ZStack { + if flipped { + ZStack { + Image("TicketFront") + .resizable() + .frame(width: isIpad ? 298 : 190.6, height: isIpad ? 544 : 347.67) + .padding(isIpad ? 48 : 24) + } + } else { + Image("TicketBack") + .resizable() + .frame(width: isIpad ? 298 : 190.6, height: isIpad ? 544 : 347.67) + .padding(isIpad ? 48 : 24) + Image(uiImage: UIImage(data: getQRCodeDate(text: qrInfo)!)!) + .resizable() + .frame(width: isIpad ? 200 : 132, height: isIpad ? 200 : 132) + } + } + .rotation3DEffect(.degrees(contentRotation), axis: (x: 0, y: 1, z: 0)) + .onTapGesture { + if !flipping { + flipFlashcard() + } + } + .rotation3DEffect(.degrees(ticketRotation), axis: (x: 0, y: 1, z: 0)) + + VStack(spacing: isIpad ? 32 : 16) { + Text("Dietary Restrictions") + .font(Font(HIAppearance.Font.profileDietaryRestrictions ?? .systemFont(ofSize: 16))) + .foregroundColor(Color(baseText)) + + + VStack { + HStack(spacing: 4) { + ForEach(dietaryRestrictions, id: \.self) { diet in + let index = dietaryRestrictions.firstIndex(of: diet) ?? 0 + if index < 3 { + Rectangle() + .frame(width: isIpad ? 204 : 92, height: isIpad ? 48 : 24) + .cornerRadius(isIpad ? 40 : 20) + .foregroundColor(Color(dietBackgroundColor(diet: diet))) + .overlay( + Text(dietString(diet: diet)) + .font(Font(HIAppearance.Font.profileDietaryRestrictionsLabel ?? .systemFont(ofSize: 12))) + .foregroundColor(dietTextColor(diet: diet)) + ) + } + } + } + HStack(spacing: 4) { + ForEach(dietaryRestrictions, id: \.self) { diet in + let index = dietaryRestrictions.firstIndex(of: diet) ?? 0 + if index > 2 { + Rectangle() + .frame(width: isIpad ? 204 : 92, height: isIpad ? 48 : 24) + .cornerRadius(isIpad ? 40 : 20) + .foregroundColor(Color(dietBackgroundColor(diet: diet))) + .overlay( + Text(dietString(diet: diet)) + .font(Font(HIAppearance.Font.profileDietaryRestrictionsLabel ?? .systemFont(ofSize: 12))) + .foregroundColor(dietTextColor(diet: diet)) + ) + } + } + } + } + .frame(width: isIpad ? UIScreen.main.bounds.width - 56 * 3.5 : UIScreen.main.bounds.width - 32 * 3.5) + } + } + } + .padding(.top, 24) + } + .preferredColorScheme(.dark) + .onAppear { + startFetchingQR = true + QRFetchLoop() + } + .onDisappear { + startFetchingQR = false + } + } + + func formatName() -> String { + if lastName.count + firstName.count > 20 { + return firstName + " " + lastName.prefix(1) + "." + } else { + return firstName + " " + lastName + } + } + + func getQRCodeDate(text: String) -> Data? { + guard let filter = CIFilter(name: "CIQRCodeGenerator") else { return nil } + let data = text.data(using: .ascii, allowLossyConversion: false) + filter.setValue(data, forKey: "inputMessage") + guard let ciimage = filter.outputImage else { return nil } + let transform = CGAffineTransform(scaleX: 10, y: 10) + let scaledCIImage = ciimage.transformed(by: transform) + let uiimage = UIImage(ciImage: scaledCIImage) + return uiimage.pngData()! + } + + func dietString(diet: String) -> String { + switch diet { + case "Vegetarian": + return "Vegetarian" + case "Vegan": + return "Vegan" + case "Gluten-Free": + return "Gluten-Free" + case "Lactose-Intolerant": + return "Dairy Free" + case "Other": + return "Other" + case "None": + return "None" + case "": + return "None" + default: + return "Custom" + } + } + + func dietTextColor(diet: String) -> Color { + switch diet { + case "Vegetarian", "Vegan", "Gluten-Free", "Lactose-Intolerant", "Other": + return Color(baseText) + case "None", "": + return .white + default: + return .white + } + } + + func dietBackgroundColor(diet: String) -> UIColor { + switch diet { + case "Vegetarian": + return (\HIAppearance.profileCardVegetarian).value + case "Vegan": + return (\HIAppearance.profileCardVegan).value + case "Gluten-Free": + return (\HIAppearance.profileCardGlutenFree).value + case "Lactose-Intolerant": + return (\HIAppearance.profileCardLactoseIntolerant).value + case "Other": + return (\HIAppearance.profileCardOther).value + case "None" , "": + return (\HIAppearance.profileCardNone).value + default: + return (\HIAppearance.profileCardNone).value + } + } + + func flipFlashcard() { + let animationTime = 0.5 + flipping = true + withAnimation(Animation.linear(duration: animationTime)) { + ticketRotation += 180 + flipping = false + } + withAnimation(Animation.linear(duration: 0.001).delay(animationTime / 2)) { + contentRotation += 180 + flipped.toggle() + } + } + + func QRFetchLoop() { + if startFetchingQR { + getQRInfo() + DispatchQueue.main.asyncAfter(deadline: .now() + 15) { + QRFetchLoop() + } + } + } + + func getQRInfo() { + guard let user = HIApplicationStateController.shared.user else { return } + HIAPI.UserService.getQR() + .onCompletion { result in + do { + let (qr, _) = try result.get() + DispatchQueue.main.async { + self.qrInfo = qr.qrInfo + } + } catch { + print("An error has occurred \(error)") + } + } + .authorize(with: user) + .launch() + } +} + +struct HIProfileCardView_Previews: PreviewProvider { + static var previews: some View { + HIProfileCardView(firstName: "first", + lastName: "last", + dietaryRestrictions: ["Vegetarian", "Lactose-Intolerant", "None", "no beef"], + points: 100, + tier: "no tier", + foodWave: 1, + id: "https://www.hackillinois.org" + ) + } +} diff --git a/HackIllinois/ViewControllers/HIProfileViewController.swift b/HackIllinois/ViewControllers/HIProfileViewController.swift index 135a98ea..8307da49 100644 --- a/HackIllinois/ViewControllers/HIProfileViewController.swift +++ b/HackIllinois/ViewControllers/HIProfileViewController.swift @@ -15,44 +15,25 @@ import UIKit import CoreData import HIAPI import CoreImage.CIFilterBuiltins +import SwiftUI class HIProfileViewController: HIBaseViewController { + deinit { + NotificationCenter.default.removeObserver(self) + } // MARK: - Properties + private var profile = HIProfile() + private var profileTier = "" + private var addedProfileCard = false + private var dietaryRestrictions = [String]() + private var profileCardController: UIHostingController? private let errorView = HIErrorView(style: .profile) private let logoutButton = HIButton { $0.tintHIColor = \.baseText $0.backgroundHIColor = \.clear $0.baseImage = #imageLiteral(resourceName: "LogoutButton") } - private let contentView = HIView { - $0.translatesAutoresizingMaskIntoConstraints = false - $0.backgroundHIColor = \.clear - $0.layer.cornerRadius = 15 - } - private let scrollView = UIScrollView(frame: .zero) - private let profilePictureView = HIImageView { - $0.layer.cornerRadius = 8 - $0.layer.masksToBounds = true - $0.translatesAutoresizingMaskIntoConstraints = false - } - private let profileNameView = HILabel(style: .profileName) { - $0.text = "" - } - private let discordImageView = HIImageView() - private let profileDiscordView = HILabel(style: .profileSubtitle) { - $0.text = "" - } - private let profilePointsView = HIView { - $0.translatesAutoresizingMaskIntoConstraints = false - $0.backgroundHIColor = \.profileContainerTint - $0.layer.cornerRadius = 25 - } - private let profilePointsLabel = HILabel(style: .profileNumberFigure) { - $0.text = "" - } - private let profileTierLabel = HILabel(style: .profileTier) { - $0.text = "" - } + @objc dynamic override func setUpBackgroundView() { super.setUpBackgroundView() backgroundView.image = #imageLiteral(resourceName: "ProfileBackground") @@ -69,29 +50,45 @@ extension HIProfileViewController { // MARK: - UIViewController extension HIProfileViewController { + override func loadView() { super.loadView() - if HIApplicationStateController.shared.isGuest { + guard let user = HIApplicationStateController.shared.user else { return } + if HIApplicationStateController.shared.isGuest || user.roles.contains(.staff) { layoutErrorView() } else { - layoutProfile() + updateProfile() + reloadProfile() + NotificationCenter.default.addObserver(self, selector: #selector(updateOnCheckin), name: .qrCodeSuccessfulScan, object: nil) } } override func viewDidLoad() { super.viewDidLoad() - super.setCustomTitle(customTitle: "Profile") + super.setCustomTitle(customTitle: "PROFILE") } - func layoutProfile() { - layoutButtons() - layoutScrollView() - layoutContentView() - layoutProfileNameView() - layoutProfileDiscordView() - layoutProfilePicture() - layoutPoints() - contentView.bottomAnchor.constraint(equalTo: profilePointsView.bottomAnchor, constant: 75).isActive = true - NotificationCenter.default.addObserver(self, selector: #selector(reloadProfile), name: .qrCodeSuccessfulScan, object: nil) + + func updateProfileCard() { + if addedProfileCard == true { + profileCardController?.view.removeFromSuperview() + view.willRemoveSubview(profileCardController!.view) + profileCardController?.removeFromParent() + } + profileCardController = UIHostingController(rootView: HIProfileCardView(firstName: profile.firstName, + lastName: profile.lastName, + dietaryRestrictions: dietaryRestrictions, + points: profile.points, + tier: profileTier, + foodWave: profile.foodWave, + id: profile.id + )) + + addChild(profileCardController!) + profileCardController!.view.backgroundColor = .clear + profileCardController!.view.frame = view.bounds + view.addSubview(profileCardController!.view) + addedProfileCard = true } + func layoutErrorView() { errorView.delegate = self view.addSubview(errorView) @@ -100,99 +97,40 @@ extension HIProfileViewController { errorView.centerYAnchor.constraint(equalTo: view.safeAreaLayoutGuide.centerYAnchor).isActive = true errorView.heightAnchor.constraint(equalToConstant: 100).isActive = true } - func layoutScrollView() { - scrollView.translatesAutoresizingMaskIntoConstraints = false - scrollView.alwaysBounceVertical = true - contentView.translatesAutoresizingMaskIntoConstraints = false - view.addSubview(scrollView) - scrollView.centerXAnchor.constraint(equalTo: view.safeAreaLayoutGuide.centerXAnchor).isActive = true - scrollView.widthAnchor.constraint(equalTo: view.safeAreaLayoutGuide.widthAnchor).isActive = true - scrollView.topAnchor.constraint(equalTo: view.safeAreaLayoutGuide.topAnchor, constant: 10).isActive = true - scrollView.bottomAnchor.constraint(equalTo: view.safeAreaLayoutGuide.bottomAnchor).isActive = true - scrollView.addSubview(contentView) - } - func layoutButtons() { + + func layoutLogOutButton() { self.navigationItem.rightBarButtonItem = logoutButton.toBarButtonItem() logoutButton.constrain(width: 25, height: 25) logoutButton.addTarget(self, action: #selector(didSelectLogoutButton(_:)), for: .touchUpInside) } - func layoutContentView() { - scrollView.addSubview(contentView) - if UIDevice.current.userInterfaceIdiom == .pad { - contentView.centerYAnchor.constraint(equalTo: scrollView.centerYAnchor).isActive = true - } else { - contentView.topAnchor.constraint(equalTo: scrollView.topAnchor, constant: 25).isActive = true - } - contentView.bottomAnchor.constraint(equalTo: scrollView.bottomAnchor).isActive = true - contentView.centerXAnchor.constraint(equalTo: scrollView.centerXAnchor).isActive = true - contentView.widthAnchor.constraint(equalTo: scrollView.widthAnchor, multiplier: 0.75).isActive = true - contentView.layer.contents = #imageLiteral(resourceName: "ProfileContainer").cgImage - } - func layoutPoints() { - contentView.addSubview(profilePointsView) - profilePointsView.topAnchor.constraint(equalTo: profilePictureView.bottomAnchor, constant: 35).isActive = true - profilePointsView.centerXAnchor.constraint(equalTo: contentView.centerXAnchor).isActive = true - profilePointsView.widthAnchor.constraint(equalTo: contentView.widthAnchor, multiplier: 0.72).isActive = true - profilePointsView.heightAnchor.constraint(equalToConstant: 100).isActive = true - profilePointsView.addSubview(profileTierLabel) - profileTierLabel.centerYAnchor.constraint(equalTo: profilePointsView.centerYAnchor, constant: -15).isActive = true - profileTierLabel.centerXAnchor.constraint(equalTo: profilePointsView.centerXAnchor).isActive = true - profilePointsView.addSubview(profilePointsLabel) - profilePointsLabel.centerYAnchor.constraint(equalTo: profilePointsView.centerYAnchor, constant: 15).isActive = true - profilePointsLabel.centerXAnchor.constraint(equalTo: profilePointsView.centerXAnchor).isActive = true - } - func layoutProfileDiscordView() { - contentView.addSubview(profileDiscordView) - profileDiscordView.topAnchor.constraint(equalTo: profileNameView.bottomAnchor, constant: 5).isActive = true - profileDiscordView.centerXAnchor.constraint(equalTo: contentView.centerXAnchor, constant: 10).isActive = true - contentView.addSubview(discordImageView) - discordImageView.translatesAutoresizingMaskIntoConstraints = false - discordImageView.topAnchor.constraint(equalTo: profileNameView.bottomAnchor, constant: 5).isActive = true - discordImageView.trailingAnchor.constraint(equalTo: profileDiscordView.leadingAnchor, constant: -3).isActive = true - } - func layoutProfileNameView() { - contentView.addSubview(profileNameView) - profileNameView.constrain(to: contentView, topInset: 50) - profileNameView.centerXAnchor.constraint(equalTo: contentView.centerXAnchor).isActive = true - profileNameView.widthAnchor.constraint(equalTo: contentView.widthAnchor, multiplier: 0.9).isActive = true - } - func layoutProfilePicture() { - contentView.addSubview(profilePictureView) - profilePictureView.topAnchor.constraint(equalTo: profileDiscordView.bottomAnchor, constant: 35).isActive = true - profilePictureView.centerXAnchor.constraint(equalTo: contentView.centerXAnchor).isActive = true - profilePictureView.widthAnchor.constraint(equalTo: contentView.widthAnchor, multiplier: 0.75).isActive = true - profilePictureView.heightAnchor.constraint(equalTo: profilePictureView.widthAnchor).isActive = true - } - override func viewWillAppear(_ animated: Bool) { - super.viewWillAppear(animated) - scrollView.setContentOffset(.zero, animated: true) - updateProfile() - reloadProfile() + @objc func updateOnCheckin(_ notification: Notification) { + guard let user = HIApplicationStateController.shared.user else { return } + if !HIApplicationStateController.shared.isGuest && !user.roles.contains(.staff) { + reloadProfile() + } } func updateProfile() { - guard let profile = HIApplicationStateController.shared.profile else { return } - view.layoutIfNeeded() - - if let url = URL(string: profile.avatarUrl), let imgValue = HIConstants.PROFILE_IMAGES[url.absoluteString] { - profilePictureView.changeImage(newImage: imgValue) - } - profileNameView.text = profile.firstName + " " + profile.lastName - profilePointsLabel.text = "\(profile.points) Points" + updateProfileCard() if tiers.count > 0 { var max_threshold = 0 for tier in tiers where (profile.points >= tier.threshold && tier.threshold >= max_threshold) { - profileTierLabel.text = "Tier: \(tier.name.capitalized)" + profileTier = "\(tier.name.capitalized) Tier" max_threshold = tier.threshold } } else { - profileTierLabel.text = "Tier: None" + profileTier = "Tier: None" + } + } + override func viewWillAppear(_ animated: Bool) { + super.viewWillAppear(animated) + guard let user = HIApplicationStateController.shared.user else { return } + layoutLogOutButton() + if !HIApplicationStateController.shared.isGuest && !user.roles.contains(.staff) { + reloadProfile() } - profileDiscordView.text = profile.discord - discordImageView.image = #imageLiteral(resourceName: "Discord") } - } // MARK: - Actions @@ -211,7 +149,6 @@ extension HIProfileViewController { alert.popoverPresentationController?.sourceView = sender present(alert, animated: true, completion: nil) } - } // MARK: - API @@ -222,22 +159,18 @@ extension HIProfileViewController { .onCompletion { [weak self] result in do { let (apiProfile, _) = try result.get() - var profile = HIProfile() - profile.id = apiProfile.id - profile.firstName = apiProfile.firstName - profile.lastName = apiProfile.lastName - profile.points = apiProfile.points - profile.timezone = apiProfile.timezone - profile.discord = apiProfile.discord - profile.avatarUrl = apiProfile.avatarUrl + self?.profile.id = apiProfile.id + self?.profile.firstName = apiProfile.firstName + self?.profile.lastName = apiProfile.lastName + self?.profile.points = apiProfile.points + self?.profile.foodWave = apiProfile.foodWave DispatchQueue.main.async { - NotificationCenter.default.post(name: .loginProfile, object: nil, userInfo: ["profile": profile]) + NotificationCenter.default.post(name: .loginProfile, object: nil, userInfo: ["profile": self?.profile]) self?.updateProfile() } } catch { print("Failed to reload profile with error: \(error)") } - } .authorize(with: user) .launch() @@ -254,8 +187,22 @@ extension HIProfileViewController { } } .launch() - } + HIAPI.RegistrationService.getAttendee() + .onCompletion { [weak self] result in + do { + let (apiAttendeeContainer, _) = try result.get() + self?.dietaryRestrictions = apiAttendeeContainer.attendee.dietary ?? [] + DispatchQueue.main.async { + self?.updateProfile() + } + } catch { + print("An error has occurred \(error)") + } + } + .authorize(with: user) + .launch() + } } // MARK: - HIErrorViewDelegate diff --git a/HackIllinois/ViewControllers/HIScanQRCodeViewController.swift b/HackIllinois/ViewControllers/HIScanQRCodeViewController.swift index 3e7af265..0b45d515 100644 --- a/HackIllinois/ViewControllers/HIScanQRCodeViewController.swift +++ b/HackIllinois/ViewControllers/HIScanQRCodeViewController.swift @@ -12,10 +12,12 @@ import Foundation import UIKit +import Combine import AVKit import CoreData import APIManager import HIAPI +import SwiftUI class HIScanQRCodeViewController: HIBaseViewController { private var captureSession: AVCaptureSession? @@ -29,24 +31,28 @@ class HIScanQRCodeViewController: HIBaseViewController { private var previewLayer: AVCaptureVideoPreviewLayer? let hapticGenerator = UINotificationFeedbackGenerator() private let pickerView = UIPickerView() - private var loadFailed = false var respondingToQRCodeFound = true - private let closeButton = HIButton { $0.tintHIColor = \.action $0.backgroundHIColor = \.clear - $0.activeImage = #imageLiteral(resourceName: "DarkCloseButton") - $0.baseImage = #imageLiteral(resourceName: "DarkCloseButton") + $0.activeImage = #imageLiteral(resourceName: "CloseButton") + $0.baseImage = #imageLiteral(resourceName: "CloseButton") } private let errorView = HIErrorView(style: .codePopup) + private var selectedEventID = "" + private var cancellables = Set() + var currentUserID = "" + var currentUserName = "" + var dietaryString = "" } // MARK: - UIViewController extension HIScanQRCodeViewController { override func loadView() { super.loadView() - if HIApplicationStateController.shared.isGuest { + guard let user = HIApplicationStateController.shared.user else { return } + if HIApplicationStateController.shared.isGuest && !user.roles.contains(.staff) { let background = #imageLiteral(resourceName: "ProfileBackground") let imageView: UIImageView = UIImageView(frame: view.bounds) view.addSubview(imageView) @@ -59,6 +65,17 @@ extension HIScanQRCodeViewController { containerView.constrain(to: view, trailingInset: 0, leadingInset: 0) containerView.addSubview(previewView) setupCaptureSession() + if user.roles.contains(.staff) { + let observable = HIStaffButtonViewObservable() + observable.$selectedEventId.sink { eventID in + self.selectedEventID = eventID + }.store(in: &cancellables) + let staffButtonController = UIHostingController(rootView: HIStaffButtonView(observable: observable)) + addChild(staffButtonController) + staffButtonController.view.backgroundColor = .clear + staffButtonController.view.frame = CGRect(x: 0, y: 100, width: Int(view.frame.maxX), height: 600) + view.addSubview(staffButtonController.view) + } } view.addSubview(closeButton) closeButton.addTarget(self, action: #selector(didSelectCloseButton(_:)), for: .touchUpInside) @@ -142,22 +159,19 @@ extension HIScanQRCodeViewController: AVCaptureMetadataOutputObjectsDelegate { func setupCaptureSession() { captureSession = AVCaptureSession() let metadataOutput = AVCaptureMetadataOutput() - guard let captureSession = captureSession, let videoCaptureDevice = AVCaptureDevice.default(for: .video), let videoInput = try? AVCaptureDeviceInput(device: videoCaptureDevice), captureSession.canAddInput(videoInput), captureSession.canAddOutput(metadataOutput) else { - loadFailed = true - return + loadFailed = true + return } - captureSession.addInput(videoInput) captureSession.addOutput(metadataOutput) metadataOutput.setMetadataObjectsDelegate(self, queue: DispatchQueue.main) metadataOutput.metadataObjectTypes = [.qr] - let previewLayer = AVCaptureVideoPreviewLayer(session: captureSession) previewLayer.videoGravity = .resizeAspectFill self.previewLayer = previewLayer @@ -167,12 +181,11 @@ extension HIScanQRCodeViewController: AVCaptureMetadataOutputObjectsDelegate { func setFrameForPreviewLayer() { guard let previewLayer = previewLayer else { return } - previewLayer.frame = previewView.layer.bounds - guard previewLayer.connection?.isVideoOrientationSupported == true else { return } - - switch UIApplication.shared.statusBarOrientation { +#warning("Not Tested") + let interfaceOrientation = UIApplication.shared.windows.first?.windowScene?.interfaceOrientation + switch interfaceOrientation { case .portrait, .unknown: previewLayer.connection?.videoOrientation = .portrait case .portraitUpsideDown: @@ -181,69 +194,192 @@ extension HIScanQRCodeViewController: AVCaptureMetadataOutputObjectsDelegate { previewLayer.connection?.videoOrientation = .landscapeLeft case .landscapeRight: previewLayer.connection?.videoOrientation = .landscapeRight + case .none: + break @unknown default: previewLayer.connection?.videoOrientation = .portrait } } - func metadataOutput(_ output: AVCaptureMetadataOutput, didOutput metadataObjects: [AVMetadataObject], from connection: AVCaptureConnection) { - guard respondingToQRCodeFound else { return } - let meta = metadataObjects.first as? AVMetadataMachineReadableCodeObject - let code = meta?.stringValue ?? "" - respondingToQRCodeFound = false - HIAPI.EventService.checkIn(code: code) + func handleCheckInAlert(status: String, newPoints: Int) { + var alertTitle = "" + var alertMessage = "" + switch status { + case "Success": + alertTitle = "Success!" + alertMessage = "You received \(newPoints) points!" + case "InvalidCode": + alertTitle = "Error!" + alertMessage = "This code doesn't seem to be correct." + self.respondingToQRCodeFound = true + case "InvalidTime": + alertTitle = "Error!" + alertMessage = "Make sure you have the right time." + self.respondingToQRCodeFound = true + case "AlreadyCheckedIn": + alertTitle = "Error!" + alertMessage = "Looks like you're already checked in." + self.respondingToQRCodeFound = true + default: + alertTitle = "Error!" + alertMessage = "Something isn't quite right." + self.respondingToQRCodeFound = true + } + let alert = UIAlertController(title: alertTitle, message: alertMessage, preferredStyle: .alert) + if alertTitle == "Success!" { + alert.addAction( + UIAlertAction(title: "OK", style: .default, handler: { _ in + self.dismiss(animated: true, completion: nil) + //Dismisses view controller + self.didSelectCloseButton(self.closeButton) + NotificationCenter.default.post(name: .qrCodeSuccessfulScan, object: nil) + })) + } else { + alert.addAction( + UIAlertAction(title: "OK", style: .default, handler: { _ in + self.registerForKeyboardNotifications() + })) + } + self.present(alert, animated: true, completion: nil) + + } + + func handleStaffCheckInAlert(status: String) { + var alertTitle = "" + var alertMessage = "" + switch status { + case "Success": + alertTitle = "Success!" + alertMessage = "Name: \(currentUserName)\n Diet: \(dietaryString)" + case "InvalidEventId": + alertTitle = "Error!" + alertMessage = "Invalid Event ID" + self.respondingToQRCodeFound = true + case "BadUserToken": + alertTitle = "Error!" + alertMessage = "BadUserToken" + self.respondingToQRCodeFound = true + case "AlreadyCheckedIn": + alertTitle = "Error!" + alertMessage = "Looks like you're already checked in." + self.respondingToQRCodeFound = true + default: + alertTitle = "Error!" + alertMessage = "Something isn't quite right." + self.respondingToQRCodeFound = true + } + let alert = UIAlertController(title: alertTitle, message: alertMessage, preferredStyle: .alert) + if alertTitle == "Success!" { + alert.addAction( + UIAlertAction(title: "OK", style: .default, handler: { _ in + self.dismiss(animated: true, completion: nil) + //Dismisses view controller + self.didSelectCloseButton(self.closeButton) + NotificationCenter.default.post(name: .qrCodeSuccessfulScan, object: nil) + })) + } else { + alert.addAction( + UIAlertAction(title: "OK", style: .default, handler: { _ in + self.registerForKeyboardNotifications() + })) + } + self.present(alert, animated: true, completion: nil) + } + + func staffCheckIn(userID: String, status: String) { + guard let user = HIApplicationStateController.shared.user else { return } + HIAPI.RegistrationService.getAttendeeRegistrationUserID(userID: userID) .onCompletion { result in do { - let (codeResult, _) = try result.get() - let newPoints = codeResult.newPoints - let status = codeResult.status - DispatchQueue.main.async { - var alertTitle = "" - var alertMessage = "" - switch status { - case "Success": - alertTitle = "Success!" - alertMessage = "You received \(newPoints) points!" - case "InvalidCode": - alertTitle = "Error!" - alertMessage = "This code doesn't seem to be correct." - self.respondingToQRCodeFound = true - case "InvalidTime": - alertTitle = "Error!" - alertMessage = "Make sure you have the right time." - self.respondingToQRCodeFound = true - case "AlreadyCheckedIn": - alertTitle = "Error!" - alertMessage = "Looks like you're already checked in." - self.respondingToQRCodeFound = true - default: - alertTitle = "Error!" - alertMessage = "Something isn't quite right." - self.respondingToQRCodeFound = true - } - let alert = UIAlertController(title: alertTitle, message: alertMessage, preferredStyle: .alert) - if alertTitle == "Success!" { - alert.addAction( - UIAlertAction(title: "OK", style: .default, handler: { _ in - self.dismiss(animated: true, completion: nil) - //Dismisses view controller - self.didSelectCloseButton(self.closeButton) - NotificationCenter.default.post(name: .qrCodeSuccessfulScan, object: nil) - })) - } else { - alert.addAction( - UIAlertAction(title: "OK", style: .default, handler: { _ in - self.registerForKeyboardNotifications() - })) + let (apiAttendeeContainer, _) = try result.get() + DispatchQueue.main.async { [self] in + dietaryString = "" + for diet in apiAttendeeContainer.dietary ?? [] { + dietaryString += diet + ", " } - self.present(alert, animated: true, completion: nil) + guard let first = apiAttendeeContainer.firstName else { return } + guard let last = apiAttendeeContainer.lastName else { return } + currentUserName = first + " " + last + self.handleStaffCheckInAlert(status: status) } } catch { - print(error, error.localizedDescription) + print("An error has occurred \(error)") } - sleep(2) } - .authorize(with: HIApplicationStateController.shared.user) + .authorize(with: user) .launch() } + + func metadataOutput(_ output: AVCaptureMetadataOutput, didOutput metadataObjects: [AVMetadataObject], from connection: AVCaptureConnection) { + guard respondingToQRCodeFound else { return } + let meta = metadataObjects.first as? AVMetadataMachineReadableCodeObject + let code = meta?.stringValue ?? "" + guard let user = HIApplicationStateController.shared.user else { return } + if user.roles.contains(.staff) { + if selectedEventID != "" { + if let range = code.range(of: "userToken=") { + let userToken = code[range.upperBound...] + respondingToQRCodeFound = false + HIAPI.EventService.staffCheckIn(userToken: String(userToken), eventId: selectedEventID) + .onCompletion { result in + do { + let (codeResult, _) = try result.get() + DispatchQueue.main.async { [self] in + if let qrInfo = self.decode(code) { + if let userId = qrInfo["userId"] { + currentUserID = userId as? String ?? "" + staffCheckIn(userID: currentUserID, status: codeResult.status) + } + } + } + } catch { + print(error, error.localizedDescription) + } + sleep(2) + } + .authorize(with: HIApplicationStateController.shared.user) + .launch() + } + } + } else { + respondingToQRCodeFound = false + HIAPI.EventService.checkIn(code: code) + .onCompletion { result in + do { + let (codeResult, _) = try result.get() + let status = codeResult.status + DispatchQueue.main.async { + self.handleCheckInAlert(status: codeResult.status, newPoints: codeResult.newPoints) + } + } catch { + print(error, error.localizedDescription) + } + sleep(2) + } + .authorize(with: HIApplicationStateController.shared.user) + .launch() + } + } + func decode(_ token: String) -> [String: AnyObject]? { + let string = token.components(separatedBy: ".") + if string.count == 1 { return nil } + let toDecode = string[1] as String + var stringtoDecode: String = toDecode.replacingOccurrences(of: "-", with: "+") // 62nd char of encoding + stringtoDecode = stringtoDecode.replacingOccurrences(of: "_", with: "/") // 63rd char of encoding + switch stringtoDecode.utf16.count % 4 { + case 2: stringtoDecode = "\(stringtoDecode)==" + case 3: stringtoDecode = "\(stringtoDecode)=" + default: // nothing to do stringtoDecode can stay the same + print("") + } + let dataToDecode = Data(base64Encoded: stringtoDecode, options: []) + let base64DecodedString = NSString(data: dataToDecode!, encoding: String.Encoding.utf8.rawValue) + var values: [String: AnyObject]? + if let string = base64DecodedString { + if let data = string.data(using: String.Encoding.utf8.rawValue, allowLossyConversion: true) { + values = try? JSONSerialization.jsonObject(with: data, options: JSONSerialization.ReadingOptions.allowFragments) as? [String: AnyObject] + } + } + return values + } } diff --git a/HackIllinois/ViewControllers/HIScheduleViewController.swift b/HackIllinois/ViewControllers/HIScheduleViewController.swift index e97a9790..080dd2d6 100644 --- a/HackIllinois/ViewControllers/HIScheduleViewController.swift +++ b/HackIllinois/ViewControllers/HIScheduleViewController.swift @@ -70,6 +70,9 @@ class HIScheduleViewController: HIEventListViewController { @objc dynamic override func setUpBackgroundView() { super.setUpBackgroundView() backgroundView.image = #imageLiteral(resourceName: "ScheduleBackground") + if UIDevice.current.userInterfaceIdiom == .pad { + backgroundView.image = #imageLiteral(resourceName: "BackgroundPad") + } } } @@ -84,6 +87,9 @@ extension HIScheduleViewController { @objc func didSelectFavoritesIcon(_ sender: UIBarButtonItem) { onlyFavorites = !onlyFavorites sender.image = onlyFavorites ? #imageLiteral(resourceName: "MenuFavorited") : #imageLiteral(resourceName: "MenuUnfavorited") + if UIDevice.current.userInterfaceIdiom == .pad { + sender.image = onlyFavorites ? #imageLiteral(resourceName: "FavoritedPad") : #imageLiteral(resourceName: "UnFavoritedPad") + } updatePredicate() animateReload() } @@ -117,19 +123,22 @@ extension HIScheduleViewController { super.loadView() let items = dataStore.map { $0.displayText } - let segmentedControl = HIScheduleSegmentedControl(titles: items, nums: [25, 26, 27]) + let segmentedControl = HIScheduleSegmentedControl(titles: items, nums: [24, 25, 26]) segmentedControl.addTarget(self, action: #selector(didSelectTab(_:)), for: .valueChanged) segmentedControl.translatesAutoresizingMaskIntoConstraints = false view.addSubview(segmentedControl) + var segmentedControlConstant: CGFloat = 0.0 + if UIDevice.current.userInterfaceIdiom == .pad { + segmentedControlConstant = 40.0 + } - segmentedControl.topAnchor.constraint(equalTo: view.safeAreaLayoutGuide.topAnchor, constant: 30).isActive = true - segmentedControl.leadingAnchor.constraint(equalTo: view.safeAreaLayoutGuide.leadingAnchor, constant: 12).isActive = true - segmentedControl.trailingAnchor.constraint(equalTo: view.safeAreaLayoutGuide.trailingAnchor, constant: -12).isActive = true - segmentedControl.heightAnchor.constraint(equalToConstant: 66).isActive = true - + segmentedControl.topAnchor.constraint(equalTo: view.safeAreaLayoutGuide.topAnchor, constant: 8 + segmentedControlConstant).isActive = true + segmentedControl.leadingAnchor.constraint(equalTo: view.safeAreaLayoutGuide.leadingAnchor, constant: -34).isActive = true + segmentedControl.trailingAnchor.constraint(equalTo: view.safeAreaLayoutGuide.trailingAnchor, constant: 34).isActive = true + segmentedControl.heightAnchor.constraint(equalToConstant: 66 + segmentedControlConstant).isActive = true let tableView = HITableView() view.addSubview(tableView) - tableView.topAnchor.constraint(equalTo: segmentedControl.bottomAnchor, constant: 10).isActive = true + tableView.topAnchor.constraint(equalTo: segmentedControl.bottomAnchor, constant: 20).isActive = true tableView.leadingAnchor.constraint(equalTo: view.safeAreaLayoutGuide.leadingAnchor).isActive = true tableView.bottomAnchor.constraint(equalTo: view.bottomAnchor).isActive = true tableView.trailingAnchor.constraint(equalTo: view.safeAreaLayoutGuide.trailingAnchor).isActive = true @@ -142,7 +151,7 @@ extension HIScheduleViewController { _fetchedResultsController = fetchedResultsController as? NSFetchedResultsController setupRefreshControl() super.viewDidLoad() - super.setCustomTitle(customTitle: "Schedule") + super.setCustomTitle(customTitle: "SCHEDULE") } } @@ -152,6 +161,9 @@ extension HIScheduleViewController { super.setupNavigationItem() if !HIApplicationStateController.shared.isGuest { navigationItem.rightBarButtonItem = UIBarButtonItem(image: #imageLiteral(resourceName: "MenuUnfavorited"), style: .plain, target: self, action: #selector(didSelectFavoritesIcon(_:))) + if UIDevice.current.userInterfaceIdiom == .pad { + navigationItem.rightBarButtonItem = UIBarButtonItem(image: #imageLiteral(resourceName: "UnFavoritedPad"), style: .plain, target: self, action: #selector(didSelectFavoritesIcon(_:))) + } } } @@ -172,7 +184,11 @@ extension HIScheduleViewController { // MARK: - UITableViewDelegate extension HIScheduleViewController { func tableView(_ tableView: UITableView, heightForHeaderInSection section: Int) -> CGFloat { - return 25 + if UIDevice.current.userInterfaceIdiom == .pad { + return 60 + } else { + return 30 + } } func tableView(_ tableView: UITableView, heightForFooterInSection section: Int) -> CGFloat { @@ -192,9 +208,15 @@ extension HIScheduleViewController { let sections = fetchedResultsController.sections, section < sections.count, let date = Formatter.coreData.date(from: sections[section].name) { - header.titleLabel.text = Formatter.simpleTime.string(from: date) + header.titleLabel.textColor = .white header.titleLabel.textAlignment = .center + if UIDevice.current.userInterfaceIdiom == .pad { + header.titleLabel.font = HIAppearance.Font.timeIndicator + } else { + header.titleLabel.font = HIAppearance.Font.glyph + } + } return header } diff --git a/HackIllinois/ViewControllers/HIStaffButtonView.swift b/HackIllinois/ViewControllers/HIStaffButtonView.swift new file mode 100644 index 00000000..276132b0 --- /dev/null +++ b/HackIllinois/ViewControllers/HIStaffButtonView.swift @@ -0,0 +1,62 @@ +// +// HIStaffButtonView.swift +// HackIllinois +// +// Created by Vincent Nguyen on 2/1/23. +// Copyright © 2023 HackIllinois. All rights reserved. +// + +import SwiftUI +import HIAPI + +struct HIStaffButtonView: View { + @State var events = [HIAPI.StaffEvent]() + @State var highlightedID = "" + @ObservedObject var observable: HIStaffButtonViewObservable + let columns = [GridItem(.flexible()), GridItem(.flexible()), GridItem(.flexible())] + var body: some View { + ScrollView { + LazyVGrid(columns: columns, spacing: 10) { + ForEach(events, id: \.id) { event in + Button(action: { + highlightedID = event.id + observable.selectedEventId = event.id + }) { + Text(event.name) + .foregroundColor(event.id == highlightedID ? .white : Color((\HIAppearance.profileBaseText).value)) + .font(Font(HIAppearance.Font.QRCheckInFont ?? .systemFont(ofSize: 14))) + .padding(4) + .cornerRadius(10) + .background( + RoundedRectangle(cornerRadius: 10) + .stroke(Color.white, lineWidth: 2) + .background(event.id == highlightedID ? Color((\HIAppearance.profileBaseText).value) : Color.white) + .cornerRadius(10) + ) + } + } + } + } + .onAppear { + getStaffEvents() + } + } + func getStaffEvents() { + HIAPI.EventService.getStaffCheckInEvents(authToken: HIApplicationStateController.shared.user?.token ?? "") + .onCompletion { result in + do { + let (containedEvents, _) = try result.get() + DispatchQueue.main.async { + self.events = containedEvents.events + } + } catch { + print("An error has occurred \(error)") + } + } + .launch() + } +} + +class HIStaffButtonViewObservable: ObservableObject { + @Published var selectedEventId: String = "" +} diff --git a/README.md b/README.md index 1c2e6a04..ec68f155 100644 --- a/README.md +++ b/README.md @@ -6,7 +6,7 @@ The repo hosts the official iOS app for HackIllinois. If you would like to get i ## Requirements 1. XCode 13.0+ 2. Swift 5.0+ -3. iOS 11.0+ +3. iOS 13.0+ ## Installation # @@ -20,7 +20,7 @@ open Hackillinois.xcodeproj Please contribute using [Github Flow](https://guides.github.com/introduction/flow/). Create a branch, add commits, and [open a pull request](https://github.com/HackIllinois/ios/compare/). ### master -Master only hosts versions of the Hackillinois application released to TestFlight or the App Store. Currently 2022.1.2. +Master only hosts versions of the Hackillinois application released to TestFlight or the App Store. Currently 2023.2.0. ### dev Dev hosts a semi-stable version of the next release and all work should be done on branches off dev and commited via PR's. diff --git a/Stickers/Info.plist b/Stickers/Info.plist index e80e6a6d..d714484d 100644 --- a/Stickers/Info.plist +++ b/Stickers/Info.plist @@ -2,10 +2,6 @@ - UIRequiredDeviceCapabilities - - arm64 - CFBundleDevelopmentRegion $(DEVELOPMENT_LANGUAGE) CFBundleDisplayName @@ -31,5 +27,9 @@ NSExtensionPrincipalClass StickerBrowserViewController + UIRequiredDeviceCapabilities + + arm64 + diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/Contents.json b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/Contents.json index 0c0e701b..333dacfc 100644 --- a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/Contents.json +++ b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/Contents.json @@ -30,15 +30,6 @@ }, { "filename" : "sticker-8.sticker" - }, - { - "filename" : "sticker-9.sticker" - }, - { - "filename" : "sticker-10.sticker" - }, - { - "filename" : "sticker-11.sticker" } ] } diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-1.sticker/Contents.json b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-1.sticker/Contents.json index cb4d9655..acd90cc2 100644 --- a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-1.sticker/Contents.json +++ b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-1.sticker/Contents.json @@ -4,6 +4,6 @@ "version" : 1 }, "properties" : { - "filename" : "sticker-1.png" + "filename" : "Crab.png" } } diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-1.sticker/Crab.png b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-1.sticker/Crab.png new file mode 100644 index 00000000..2fcbbce8 Binary files /dev/null and b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-1.sticker/Crab.png differ diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-1.sticker/sticker-1.png b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-1.sticker/sticker-1.png deleted file mode 100644 index 511d1166..00000000 Binary files a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-1.sticker/sticker-1.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-10.sticker/Contents.json b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-10.sticker/Contents.json deleted file mode 100644 index 190c1879..00000000 --- a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-10.sticker/Contents.json +++ /dev/null @@ -1,9 +0,0 @@ -{ - "info" : { - "author" : "xcode", - "version" : 1 - }, - "properties" : { - "filename" : "sticker-10.png" - } -} diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-10.sticker/sticker-10.png b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-10.sticker/sticker-10.png deleted file mode 100644 index be925400..00000000 Binary files a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-10.sticker/sticker-10.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-11.sticker/Contents.json b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-11.sticker/Contents.json deleted file mode 100644 index f6a7a60d..00000000 --- a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-11.sticker/Contents.json +++ /dev/null @@ -1,9 +0,0 @@ -{ - "info" : { - "author" : "xcode", - "version" : 1 - }, - "properties" : { - "filename" : "sticker-11.png" - } -} diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-11.sticker/sticker-11.png b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-11.sticker/sticker-11.png deleted file mode 100644 index bff2a7ad..00000000 Binary files a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-11.sticker/sticker-11.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-2.sticker/Contents.json b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-2.sticker/Contents.json index a30e8c1b..aff56d8a 100644 --- a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-2.sticker/Contents.json +++ b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-2.sticker/Contents.json @@ -4,6 +4,6 @@ "version" : 1 }, "properties" : { - "filename" : "sticker-2.png" + "filename" : "Ticket.png" } } diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-2.sticker/Ticket.png b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-2.sticker/Ticket.png new file mode 100644 index 00000000..bc048583 Binary files /dev/null and b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-2.sticker/Ticket.png differ diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-2.sticker/sticker-2.png b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-2.sticker/sticker-2.png deleted file mode 100644 index 64ca4015..00000000 Binary files a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-2.sticker/sticker-2.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-3.sticker/Contents.json b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-3.sticker/Contents.json index 2749d6fb..89f63fc1 100644 --- a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-3.sticker/Contents.json +++ b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-3.sticker/Contents.json @@ -4,6 +4,6 @@ "version" : 1 }, "properties" : { - "filename" : "sticker-3.png" + "filename" : "Cotton Candy.png" } } diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-3.sticker/Cotton Candy.png b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-3.sticker/Cotton Candy.png new file mode 100644 index 00000000..19c9229c Binary files /dev/null and b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-3.sticker/Cotton Candy.png differ diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-3.sticker/sticker-3.png b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-3.sticker/sticker-3.png deleted file mode 100644 index 6b2c8088..00000000 Binary files a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-3.sticker/sticker-3.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-4.sticker/Contents.json b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-4.sticker/Contents.json index 4fd1e311..d783423b 100644 --- a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-4.sticker/Contents.json +++ b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-4.sticker/Contents.json @@ -4,6 +4,6 @@ "version" : 1 }, "properties" : { - "filename" : "sticker-4.png" + "filename" : "Pizza.png" } } diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-4.sticker/Pizza.png b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-4.sticker/Pizza.png new file mode 100644 index 00000000..b9727099 Binary files /dev/null and b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-4.sticker/Pizza.png differ diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-4.sticker/sticker-4.png b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-4.sticker/sticker-4.png deleted file mode 100644 index 0cec8539..00000000 Binary files a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-4.sticker/sticker-4.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-5.sticker/Contents.json b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-5.sticker/Contents.json index 8b6af48f..6b575ecb 100644 --- a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-5.sticker/Contents.json +++ b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-5.sticker/Contents.json @@ -4,6 +4,6 @@ "version" : 1 }, "properties" : { - "filename" : "sticker-5.png" + "filename" : "Popcorn.png" } } diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-5.sticker/Popcorn.png b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-5.sticker/Popcorn.png new file mode 100644 index 00000000..7fae9a24 Binary files /dev/null and b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-5.sticker/Popcorn.png differ diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-5.sticker/sticker-5.png b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-5.sticker/sticker-5.png deleted file mode 100644 index 71233445..00000000 Binary files a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-5.sticker/sticker-5.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-6.sticker/Contents.json b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-6.sticker/Contents.json index a74f5912..6c100ada 100644 --- a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-6.sticker/Contents.json +++ b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-6.sticker/Contents.json @@ -4,6 +4,6 @@ "version" : 1 }, "properties" : { - "filename" : "sticker-6.png" + "filename" : "Mole.png" } } diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-6.sticker/Mole.png b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-6.sticker/Mole.png new file mode 100644 index 00000000..e5aba3fc Binary files /dev/null and b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-6.sticker/Mole.png differ diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-6.sticker/sticker-6.png b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-6.sticker/sticker-6.png deleted file mode 100644 index 9aae21db..00000000 Binary files a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-6.sticker/sticker-6.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-7.sticker/Contents.json b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-7.sticker/Contents.json index 2d6694ba..da4e068b 100644 --- a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-7.sticker/Contents.json +++ b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-7.sticker/Contents.json @@ -4,6 +4,6 @@ "version" : 1 }, "properties" : { - "filename" : "sticker-7.png" + "filename" : "Ducky.png" } } diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-7.sticker/Ducky.png b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-7.sticker/Ducky.png new file mode 100644 index 00000000..f9c6029b Binary files /dev/null and b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-7.sticker/Ducky.png differ diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-7.sticker/sticker-7.png b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-7.sticker/sticker-7.png deleted file mode 100644 index c574cda4..00000000 Binary files a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-7.sticker/sticker-7.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-8.sticker/Contents.json b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-8.sticker/Contents.json index 29c12c53..994d2613 100644 --- a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-8.sticker/Contents.json +++ b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-8.sticker/Contents.json @@ -4,6 +4,6 @@ "version" : 1 }, "properties" : { - "filename" : "sticker-8.png" + "filename" : "sticker1.png" } } diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-8.sticker/sticker-8.png b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-8.sticker/sticker-8.png deleted file mode 100644 index 561f8ae1..00000000 Binary files a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-8.sticker/sticker-8.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-8.sticker/sticker1.png b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-8.sticker/sticker1.png new file mode 100644 index 00000000..aa72ed96 Binary files /dev/null and b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-8.sticker/sticker1.png differ diff --git a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-9.sticker/sticker-9.png b/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-9.sticker/sticker-9.png deleted file mode 100644 index 589fa39b..00000000 Binary files a/Stickers/Stickers.xcassets/Sticker Pack.stickerpack/sticker-9.sticker/sticker-9.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/App Store iOS.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/App Store iOS.png new file mode 100644 index 00000000..4934e06b Binary files /dev/null and b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/App Store iOS.png differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Contents.json b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Contents.json index 95e8debf..5168b31d 100644 --- a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Contents.json +++ b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Contents.json @@ -1,83 +1,83 @@ { "images" : [ { - "filename" : "Logo_29@2x.png", + "filename" : "iPhone Settings 29x29pt @1x.png", "idiom" : "iphone", "scale" : "2x", "size" : "29x29" }, { - "filename" : "Logo_29@3x.png", + "filename" : "iPhone Settings 29x29pt @ 3x.png", "idiom" : "iphone", "scale" : "3x", "size" : "29x29" }, { - "filename" : "Logo_60_45@2x.png", + "filename" : "Messages iPhone 60x45pt @ 2x.png", "idiom" : "iphone", "scale" : "2x", "size" : "60x45" }, { - "filename" : "Logo_60_45@3x.png", + "filename" : "Messages iPhone 60x45pt @ 3x.png", "idiom" : "iphone", "scale" : "3x", "size" : "60x45" }, { - "filename" : "Logo_29_29.png", + "filename" : "iPad Settings.png", "idiom" : "ipad", "scale" : "2x", "size" : "29x29" }, { - "filename" : "Logo_67_50@2x.png", + "filename" : "Messages iPad.png", "idiom" : "ipad", "scale" : "2x", "size" : "67x50" }, { - "filename" : "Logo_74_55@2x.png", + "filename" : "Messages iPad Pro.png", "idiom" : "ipad", "scale" : "2x", "size" : "74x55" }, { - "filename" : "Logo_1024.png", + "filename" : "App Store iOS.png", "idiom" : "ios-marketing", "scale" : "1x", "size" : "1024x1024" }, { - "filename" : "Logo_27_20@2x.png", + "filename" : "Messages 27x20pt @2x (3).png", "idiom" : "universal", "platform" : "ios", "scale" : "2x", "size" : "27x20" }, { - "filename" : "Logo_27_20@3x.png", + "filename" : "Messages 27x20pt @ 3x.png", "idiom" : "universal", "platform" : "ios", "scale" : "3x", "size" : "27x20" }, { - "filename" : "Logo_32_24@2x.png", + "filename" : "Messages 32x24pt @ 2x.png", "idiom" : "universal", "platform" : "ios", "scale" : "2x", "size" : "32x24" }, { - "filename" : "Logo_32_24@3x.png", + "filename" : "Messages 32x24pt @ 3x.png", "idiom" : "universal", "platform" : "ios", "scale" : "3x", "size" : "32x24" }, { - "filename" : "Logo_1024_768.png", + "filename" : "Messages App Store.png", "idiom" : "ios-marketing", "platform" : "ios", "scale" : "1x", diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_1024.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_1024.png deleted file mode 100644 index 5e1eb182..00000000 Binary files a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_1024.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_1024_768.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_1024_768.png deleted file mode 100644 index 879825af..00000000 Binary files a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_1024_768.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_27_20@2x.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_27_20@2x.png deleted file mode 100644 index c85c0d37..00000000 Binary files a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_27_20@2x.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_27_20@3x.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_27_20@3x.png deleted file mode 100644 index beba05d1..00000000 Binary files a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_27_20@3x.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_29@2x.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_29@2x.png deleted file mode 100644 index 45f43dcc..00000000 Binary files a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_29@2x.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_29@3x.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_29@3x.png deleted file mode 100644 index da1508e7..00000000 Binary files a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_29@3x.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_29_29.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_29_29.png deleted file mode 100644 index 45f43dcc..00000000 Binary files a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_29_29.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_32_24@2x.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_32_24@2x.png deleted file mode 100644 index ec2a90ee..00000000 Binary files a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_32_24@2x.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_32_24@3x.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_32_24@3x.png deleted file mode 100644 index 7ecffb8f..00000000 Binary files a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_32_24@3x.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_60_45@2x.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_60_45@2x.png deleted file mode 100644 index de615975..00000000 Binary files a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_60_45@2x.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_60_45@3x.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_60_45@3x.png deleted file mode 100644 index f1b878fc..00000000 Binary files a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_60_45@3x.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_67_50@2x.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_67_50@2x.png deleted file mode 100644 index 3bbb38c6..00000000 Binary files a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_67_50@2x.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_74_55@2x.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_74_55@2x.png deleted file mode 100644 index f5e9a23a..00000000 Binary files a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Logo_74_55@2x.png and /dev/null differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages 27x20pt @ 3x.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages 27x20pt @ 3x.png new file mode 100644 index 00000000..4f525b5f Binary files /dev/null and b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages 27x20pt @ 3x.png differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages 27x20pt @2x (3).png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages 27x20pt @2x (3).png new file mode 100644 index 00000000..218764b0 Binary files /dev/null and b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages 27x20pt @2x (3).png differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages 32x24pt @ 2x.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages 32x24pt @ 2x.png new file mode 100644 index 00000000..7a58109c Binary files /dev/null and b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages 32x24pt @ 2x.png differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages 32x24pt @ 3x.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages 32x24pt @ 3x.png new file mode 100644 index 00000000..0bf4565a Binary files /dev/null and b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages 32x24pt @ 3x.png differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages App Store.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages App Store.png new file mode 100644 index 00000000..49f642d9 Binary files /dev/null and b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages App Store.png differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages iPad Pro.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages iPad Pro.png new file mode 100644 index 00000000..49022d11 Binary files /dev/null and b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages iPad Pro.png differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages iPad.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages iPad.png new file mode 100644 index 00000000..67e66b6d Binary files /dev/null and b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages iPad.png differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages iPhone 60x45pt @ 2x.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages iPhone 60x45pt @ 2x.png new file mode 100644 index 00000000..3ec18b75 Binary files /dev/null and b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages iPhone 60x45pt @ 2x.png differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages iPhone 60x45pt @ 3x.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages iPhone 60x45pt @ 3x.png new file mode 100644 index 00000000..c74cfe27 Binary files /dev/null and b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/Messages iPhone 60x45pt @ 3x.png differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/iPad Settings.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/iPad Settings.png new file mode 100644 index 00000000..9ed92345 Binary files /dev/null and b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/iPad Settings.png differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/iPhone Settings 29x29pt @ 3x.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/iPhone Settings 29x29pt @ 3x.png new file mode 100644 index 00000000..f316c48e Binary files /dev/null and b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/iPhone Settings 29x29pt @ 3x.png differ diff --git a/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/iPhone Settings 29x29pt @1x.png b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/iPhone Settings 29x29pt @1x.png new file mode 100644 index 00000000..5d501448 Binary files /dev/null and b/Stickers/Stickers.xcassets/iMessage App Icon.stickersiconset/iPhone Settings 29x29pt @1x.png differ