This commit is contained in:
Trey t
2023-06-19 20:03:41 -05:00
parent c1dc7a2351
commit 55f0926a08
6 changed files with 87 additions and 48 deletions

View File

@@ -164,9 +164,9 @@
1CF65A3B2A3972CE0042FFBD /* ExternalWorkoutDetailView.swift */,
1CF65A622A3BF6A30042FFBD /* AllWorkoutsView.swift */,
1CF65A4B2A39FDA20042FFBD /* WorkoutDetailView.swift */,
1CF65A4D2A39FF200042FFBD /* WorkoutDetailViewModel.swift */,
1CF65A6C2A3F60100042FFBD /* CreateWorkoutViews */,
1CF65A602A3BF6020042FFBD /* AddExerciseView.swift */,
1CF65A4D2A39FF200042FFBD /* WorkoutDetailViewModel.swift */,
1CF65A682A3C018F0042FFBD /* AccountView.swift */,
);
path = Views;

View File

@@ -8,13 +8,14 @@
import Foundation
struct Workout: Codable {
let id: Int
let name: String
let description: String?
let exercises: [ExerciseElement]
let registeredUser: RegisteredUser
enum CodingKeys: String, CodingKey {
case name, description, exercises
case name, description, exercises, id
case registeredUser = "registered_user"
}
@@ -29,6 +30,7 @@ struct Workout: Codable {
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)
self.id = try container.decode(Int.self, forKey: .id)
}
var exercisesSortedByCreated_at: [ExerciseElement] {

View File

@@ -16,8 +16,8 @@ class WorkoutDetailFetchable: Fetchable {
typealias Response = Workout
var endPoint: String
init(workoutID: String) {
self.endPoint = "/workout/"+workoutID+"/details/"
init(workoutID: Int) {
self.endPoint = "workout/"+String(workoutID)+"/details/"
}
}

View File

@@ -41,7 +41,16 @@ struct AllWorkoutsView: View {
Text("no workouts")
}
}.onAppear{
testParse()
AllWorkoutFetchable().fetch(completion: { result in
switch result {
case .success(let model):
DispatchQueue.main.async {
self.workouts = model
}
case .failure(let failure):
fatalError("shit broke")
}
})
}
.sheet(isPresented: $showWorkoutDetail) {
if let selectedWorkout = selectedWorkout {
@@ -52,7 +61,7 @@ struct AllWorkoutsView: View {
}
func selectedItem(workout: Workout) {
selectedWorkout = PreviewWorkout.workout()
selectedWorkout = workout
}
func testParse() {

View File

@@ -19,52 +19,65 @@ struct WorkoutDetailView: View {
}
var body: some View {
VStack {
HStack {
Button("i dont want to do this", action: {
bridgeModule.currentWorkout = nil
dismiss()
})
.frame(maxWidth: .infinity, maxHeight: .infinity)
.background(.red)
Button("ohhh lets do it", action: {
runItemAt(idx: 0)
})
.frame(maxWidth: .infinity, maxHeight: .infinity)
.background(.green)
}
.frame(height: 88)
List() {
ForEach(viewModel.workout.exercisesSortedByCreated_at.indices, id: \.self) { i in
let obj = viewModel.workout.exercisesSortedByCreated_at[i]
Text(obj.exercise.name ?? "")
.onTapGesture { selectedIdx = i }
ZStack {
switch viewModel.status {
case .loading:
Text("Loading")
case .showWorkout(let workout):
VStack {
HStack {
Button("i dont want to do this", action: {
bridgeModule.currentWorkout = nil
dismiss()
})
.frame(maxWidth: .infinity, maxHeight: .infinity)
.background(.red)
Button("ohhh lets do it", action: {
runItemAt(idx: 0)
})
.frame(maxWidth: .infinity, maxHeight: .infinity)
.background(.green)
}
.frame(height: 88)
List() {
ForEach(workout.exercisesSortedByCreated_at.indices, id: \.self) { i in
let obj = workout.exercisesSortedByCreated_at[i]
Text(obj.exercise.name ?? "")
.onTapGesture { selectedIdx = i }
}
}
if let duration = bridgeModule.currentExercise?.duration {
HStack {
ProgressView(value: Float(bridgeModule.timeLeft), total: Float(duration))
Text("\(bridgeModule.timeLeft)")
}.padding(16)
}
}
}
if let duration = bridgeModule.currentExercise?.duration {
HStack {
ProgressView(value: Float(bridgeModule.timeLeft), total: Float(duration))
Text("\(bridgeModule.timeLeft)")
}.padding(16)
.onAppear{
bridgeModule.timerCompleted = {
selectedIdx += 1
}
}
.interactiveDismissDisabled()
}
}
.onAppear{
bridgeModule.timerCompleted = {
selectedIdx += 1
}
}
.interactiveDismissDisabled()
}
func runItemAt(idx: Int) {
if idx < viewModel.workout.exercises.count {
let exercise = viewModel.workout.exercises[idx]
bridgeModule.updateCurrent(exercise: exercise)
bridgeModule.currentExerciseIdx = idx
} else {
workoutComplete()
switch viewModel.status {
case .showWorkout(let workout):
if idx < workout.exercises.count {
let exercise = workout.exercises[idx]
bridgeModule.updateCurrent(exercise: exercise)
bridgeModule.currentExerciseIdx = idx
} else {
workoutComplete()
}
default:
fatalError("no workout!!")
}
}

View File

@@ -9,9 +9,24 @@ import Combine
import Foundation
class WorkoutDetailViewModel: ObservableObject {
@Published var workout: Workout
enum WorkoutDetailViewModelStatus {
case loading
case showWorkout(Workout)
}
@Published var status: WorkoutDetailViewModelStatus
init(workout: Workout) {
self.workout = workout
self.status = .loading
WorkoutDetailFetchable(workoutID: workout.id).fetch(completion: { result in
switch result {
case .success(let model):
DispatchQueue.main.async {
self.status = .showWorkout(model)
}
case .failure(let failure):
fatalError("failed \(failure.localizedDescription)")
}
})
}
}