WIP
This commit is contained in:
33
Werkout_ios/APIModels/Equipment.swift
Normal file
33
Werkout_ios/APIModels/Equipment.swift
Normal file
@@ -0,0 +1,33 @@
|
||||
//
|
||||
// Equipment.swift
|
||||
// Werkout_ios
|
||||
//
|
||||
// Created by Trey Tartt on 6/15/23.
|
||||
//
|
||||
|
||||
import Foundation
|
||||
struct Equipment: Codable {
|
||||
let id: Int
|
||||
let createdAt, updatedAt: String
|
||||
let category, name: String?
|
||||
|
||||
enum CodingKeys: String, CodingKey {
|
||||
case id
|
||||
case createdAt = "created_at"
|
||||
case updatedAt = "updated_at"
|
||||
case category, name
|
||||
}
|
||||
}
|
||||
|
||||
struct ExerciseEquipment: Codable, Hashable {
|
||||
let id: Int
|
||||
let createdAt, updatedAt: String
|
||||
let exercise, equipment: Int
|
||||
|
||||
enum CodingKeys: String, CodingKey {
|
||||
case id
|
||||
case createdAt = "created_at"
|
||||
case updatedAt = "updated_at"
|
||||
case equipment, exercise
|
||||
}
|
||||
}
|
||||
77
Werkout_ios/APIModels/Exercise.swift
Normal file
77
Werkout_ios/APIModels/Exercise.swift
Normal file
@@ -0,0 +1,77 @@
|
||||
//
|
||||
// Exercise.swift
|
||||
// Werkout_ios
|
||||
//
|
||||
// Created by Trey Tartt on 6/14/23.
|
||||
//
|
||||
|
||||
import Foundation
|
||||
|
||||
struct ExerciseElement: Codable {
|
||||
let workout: Int
|
||||
let exercise: ExerciseExercise
|
||||
let weight: Int?
|
||||
let reps: Int?
|
||||
let duration: Int?
|
||||
let durationAudio: String
|
||||
let weightAudio: String?
|
||||
let createdAt: String
|
||||
|
||||
enum CodingKeys: String, CodingKey {
|
||||
case workout, exercise, weight, reps, duration
|
||||
case durationAudio = "duration_audio"
|
||||
case weightAudio = "weight_audio"
|
||||
case createdAt = "created_at"
|
||||
}
|
||||
|
||||
var createdAtDate: Date {
|
||||
let df = DateFormatter()
|
||||
df.dateFormat = "yyyy-MM-dd'T'HH:mm:ss.SSSZ"
|
||||
df.locale = Locale(identifier: "en_US_POSIX")
|
||||
return df.date(from: self.createdAt ?? "") ?? Date()
|
||||
}
|
||||
}
|
||||
|
||||
struct ExerciseExercise: Codable, Hashable {
|
||||
static func == (lhs: ExerciseExercise, rhs: ExerciseExercise) -> Bool {
|
||||
lhs.id == rhs.id
|
||||
}
|
||||
|
||||
let id: Int
|
||||
let muscles: [ExerciseMuscle]
|
||||
let equipment: [ExerciseEquipment]
|
||||
let audioURL, videoURL, createdAt, updatedAt: String
|
||||
let name, description, side: String
|
||||
let isTwoDumbbells, isTrackableDistance, isAlternating, isWeight: Bool
|
||||
let isDistance, isDuration, isReps: Bool
|
||||
let jointsUsed, movementPatterns, equipmentRequired, muscleGroups: String
|
||||
let synonyms: String?
|
||||
|
||||
enum CodingKeys: String, CodingKey {
|
||||
case id, muscles, equipment
|
||||
case audioURL = "audio_url"
|
||||
case videoURL = "video_url"
|
||||
case createdAt = "created_at"
|
||||
case updatedAt = "updated_at"
|
||||
case name, description, side
|
||||
case isTwoDumbbells = "is_two_dumbbells"
|
||||
case isTrackableDistance = "is_trackable_distance"
|
||||
case isAlternating = "is_alternating"
|
||||
case isWeight = "is_weight"
|
||||
case isDistance = "is_distance"
|
||||
case isDuration = "is_duration"
|
||||
case isReps = "is_reps"
|
||||
case jointsUsed = "joints_used"
|
||||
case movementPatterns = "movement_patterns"
|
||||
case equipmentRequired = "equipment_required"
|
||||
case muscleGroups = "muscle_groups"
|
||||
case synonyms
|
||||
}
|
||||
|
||||
var createdAtDate: Date {
|
||||
let df = DateFormatter()
|
||||
df.dateFormat = "yyyy-MM-dd'T'HH:mm:ss.SSSZ"
|
||||
df.locale = Locale(identifier: "en_US_POSIX")
|
||||
return df.date(from: self.createdAt ?? "") ?? Date()
|
||||
}
|
||||
}
|
||||
26
Werkout_ios/APIModels/Muscle.swift
Normal file
26
Werkout_ios/APIModels/Muscle.swift
Normal file
@@ -0,0 +1,26 @@
|
||||
//
|
||||
// Muscle.swift
|
||||
// Werkout_ios
|
||||
//
|
||||
// Created by Trey Tartt on 6/15/23.
|
||||
//
|
||||
|
||||
import Foundation
|
||||
|
||||
struct Muscle: Codable {
|
||||
let id: Int
|
||||
let name: String
|
||||
}
|
||||
|
||||
struct ExerciseMuscle: Codable, Hashable {
|
||||
let id: Int
|
||||
let createdAt, updatedAt: String
|
||||
let exercise, muscle: Int
|
||||
|
||||
enum CodingKeys: String, CodingKey {
|
||||
case id
|
||||
case createdAt = "created_at"
|
||||
case updatedAt = "updated_at"
|
||||
case exercise, muscle
|
||||
}
|
||||
}
|
||||
22
Werkout_ios/APIModels/RegisteredUser.swift
Normal file
22
Werkout_ios/APIModels/RegisteredUser.swift
Normal file
@@ -0,0 +1,22 @@
|
||||
//
|
||||
// RegisteredUser.swift
|
||||
// Werkout_ios
|
||||
//
|
||||
// Created by Trey Tartt on 6/14/23.
|
||||
//
|
||||
|
||||
import Foundation
|
||||
|
||||
struct RegisteredUser: Codable {
|
||||
let id: Int
|
||||
let firstName, lastName, image: String?
|
||||
let nickName: String?
|
||||
|
||||
enum CodingKeys: String, CodingKey {
|
||||
case id
|
||||
case firstName = "first_name"
|
||||
case lastName = "last_name"
|
||||
case image
|
||||
case nickName = "nick_name"
|
||||
}
|
||||
}
|
||||
39
Werkout_ios/APIModels/Workout.swift
Normal file
39
Werkout_ios/APIModels/Workout.swift
Normal file
@@ -0,0 +1,39 @@
|
||||
//
|
||||
// Workout.swift
|
||||
// Werkout_ios
|
||||
//
|
||||
// Created by Trey Tartt on 6/14/23.
|
||||
//
|
||||
|
||||
import Foundation
|
||||
|
||||
struct Workout: Codable {
|
||||
let name: String
|
||||
let description: String?
|
||||
let exercises: [ExerciseElement]
|
||||
let registeredUser: RegisteredUser
|
||||
|
||||
enum CodingKeys: String, CodingKey {
|
||||
case name, description, exercises
|
||||
case registeredUser = "registered_user"
|
||||
}
|
||||
|
||||
init(from decoder: Decoder) throws {
|
||||
let container = try decoder.container(keyedBy: CodingKeys.self)
|
||||
if let exercises = try container.decodeIfPresent([ExerciseElement].self, forKey: .exercises) {
|
||||
self.exercises = exercises
|
||||
} else {
|
||||
self.exercises = [ExerciseElement]()
|
||||
}
|
||||
|
||||
self.name = try container.decode(String.self, forKey: .name)
|
||||
self.description = try container.decodeIfPresent(String.self, forKey: .description)
|
||||
self.registeredUser = try container.decode(RegisteredUser.self, forKey: .registeredUser)
|
||||
}
|
||||
|
||||
var exercisesSortedByCreated_at: [ExerciseElement] {
|
||||
return self.exercises.sorted(by: {
|
||||
$0.createdAtDate < $1.createdAtDate
|
||||
})
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user