This commit is contained in:
Trey t
2023-06-20 20:49:32 -05:00
parent 55f0926a08
commit 695459ac06
15 changed files with 287 additions and 111 deletions

View File

@@ -9,8 +9,7 @@ import SwiftUI
import AVKit
struct ExternalWorkoutDetailView: View {
@EnvironmentObject var bridgeModule: BridgeModule
@State var player = AVPlayer()
@StateObject var bridgeModule = BridgeModule.shared
var body: some View {
if let workout = bridgeModule.currentWorkout {
@@ -21,76 +20,88 @@ struct ExternalWorkoutDetailView: View {
.frame(width: metrics.size.width, height: metrics.size.height * 0.1)
HStack {
VideoPlayer(player: player)
.onChange(of: bridgeModule.currentExerciseIdx, perform: { newValue in
updateVideo()
})
if let currentExercise = bridgeModule.currentExercise {
VideoPlayerView(currentExercise: currentExercise.exercise)
.frame(width: metrics.size.width * 0.6, height: metrics.size.height * 0.7)
}
if let workout = bridgeModule.currentWorkout {
List() {
ForEach(workout.exercisesSortedByCreated_at.indices, id: \.self) { i in
let obj = workout.exercisesSortedByCreated_at[i]
HStack {
if let _ = bridgeModule.currentExercise {
if i == bridgeModule.currentExerciseIdx {
Image(systemName: "checkmark")
.font(Font.system(size: 75))
.foregroundColor(.green)
}
}
Text(obj.exercise.name ?? "")
.font(Font.system(size: 75))
.padding()
}
}
}
.frame(width: metrics.size.width * 0.4)
}
ExtExerciseList(workout: workout,
currentExerciseIdx: bridgeModule.currentExerciseIdx)
.frame(width: metrics.size.width * 0.4, height: metrics.size.height * 0.7)
}
.frame(width: metrics.size.width, height: metrics.size.height * 0.7)
HStack {
if let currenExercise = bridgeModule.currentExercise {
VStack {
Text(currenExercise.exercise.name ?? "")
.font(Font.system(size: 100))
.frame(maxWidth: .infinity, alignment: .leading)
HStack {
if let duration = currenExercise.duration {
ProgressView(value: Float(bridgeModule.timeLeft), total: Float(duration))
.scaleEffect(x: 1, y: 6, anchor: .center)
Text("\(bridgeModule.timeLeft)")
.font(Font.system(size: 75))
.padding(.leading)
} else if let reps = currenExercise.reps {
Text("\(reps)")
}
}
.padding([.leading, .trailing], 50)
}
}
}
.frame(width: metrics.size.width, height: metrics.size.height * 0.2)
.padding([.leading, .trailing])
ExtCountdownView()
.frame(width: metrics.size.width-50, height: metrics.size.height * 0.2)
.padding([.leading, .trailing], 50)
}
}
}
}
}
struct ExtExerciseList: View {
var workout: Workout
var currentExerciseIdx: Int
func updateVideo() {
if let videoURL = bridgeModule.currentExercise?.exercise.videoURL {
// let completeURL = "http://127.0.0.1:8000" + videoURL
player = AVPlayer(url: Bundle.main.url(forResource: "Straight_Leg_Sit_Up", withExtension: "mp4")!)
player.play()
// print(completeURL)
// player = AVPlayer(url: URL(string: completeURL)!)
// player.play()
var body: some View {
List() {
ForEach(workout.exercisesSortedByCreated_at.indices, id: \.self) { i in
let obj = workout.exercisesSortedByCreated_at[i]
HStack {
if i == currentExerciseIdx {
Image(systemName: "checkmark")
.font(Font.system(size: 75))
.foregroundColor(.green)
}
Text(obj.exercise.name)
.font(Font.system(size: 75))
.padding()
}
}
}
}
}
struct ExtCountdownView: View {
@StateObject var bridgeModule = BridgeModule.shared
var body: some View {
VStack {
if let currenExercise = bridgeModule.currentExercise {
Text(currenExercise.exercise.name)
.font(Font.system(size: 100))
.frame(maxWidth: .infinity, alignment: .leading)
HStack {
if let duration = currenExercise.duration {
ProgressView(value: Float(bridgeModule.timeLeft), total: Float(duration))
.scaleEffect(x: 1, y: 6, anchor: .center)
Text("\(bridgeModule.timeLeft)")
.font(Font.system(size: 75))
.padding(.leading)
} else if let reps = currenExercise.reps {
Text("\(reps)")
}
}
}
}
}
}
struct VideoPlayerView: View {
var currentExercise: ExerciseExercise
@State var player = AVPlayer()
var body: some View {
VideoPlayer(player: player)
.onAppear{
player = AVPlayer(url: Bundle.main.url(forResource: "Straight_Leg_Sit_Up", withExtension: "mp4")!)
player.play()
}
}
}
struct ExternalWorkoutDetailView_Previews: PreviewProvider {
static var bridge = BridgeModule.shared