This commit is contained in:
Trey t
2023-07-02 18:55:26 -05:00
parent 9d38a33b80
commit 2344bcbd6a
5 changed files with 46 additions and 76 deletions

View File

@@ -10,6 +10,10 @@ import Foundation
enum BaseURLs: String { enum BaseURLs: String {
case local = "http://127.0.0.1:8000" case local = "http://127.0.0.1:8000"
case dev = "https://dev.werkout.fitness" case dev = "https://dev.werkout.fitness"
static var currentBaseURL: String {
return BaseURLs.dev.rawValue
}
} }
enum FetchableError: Error { enum FetchableError: Error {
@@ -37,7 +41,7 @@ protocol Postable: Fetchable {
extension Fetchable { extension Fetchable {
var baseURL: String { var baseURL: String {
BaseURLs.local.rawValue BaseURLs.currentBaseURL
} }
var attachToken: Bool { var attachToken: Bool {

View File

@@ -62,7 +62,8 @@ class UserStore: ObservableObject {
case .success(let models): case .success(let models):
self.plannedWorkouts = models self.plannedWorkouts = models
case .failure(let failure): case .failure(let failure):
fatalError("shit broke") UserStore.shared.logout()
// fatalError("shit broke")
} }
}) })
} }

View File

@@ -8,6 +8,7 @@
import Foundation import Foundation
import SwiftUI import SwiftUI
import Combine import Combine
import AVKit
struct AddExerciseView: View { struct AddExerciseView: View {
enum CreateWorkoutItemPickerViewType { enum CreateWorkoutItemPickerViewType {
@@ -25,7 +26,15 @@ struct AddExerciseView: View {
@State var createWorkoutItemPickerViewModel: CreateWorkoutItemPickerViewModel? @State var createWorkoutItemPickerViewModel: CreateWorkoutItemPickerViewModel?
@State var createWorkoutItemPickerViewType: CreateWorkoutItemPickerViewType? @State var createWorkoutItemPickerViewType: CreateWorkoutItemPickerViewType?
@State var searchString: String = "" @State var searchString: String = ""
@State var videoExercise: ExerciseExercise? @State var videoExercise: ExerciseExercise? {
didSet {
if let viddd = self.videoExercise?.videoURL,
let url = URL(string: BaseURLs.currentBaseURL + viddd) {
self.avPlayer = AVPlayer(url: url)
}
}
}
@State var avPlayer = AVPlayer(url: URL(string: "https://dev.werkout.fitness/media/exercise_videos/2_Dumbbell_Lateral_Lunges.mp4")!)
var body: some View { var body: some View {
VStack { VStack {
@@ -63,9 +72,7 @@ struct AddExerciseView: View {
filteredExercises = exercises filteredExercises = exercises
} }
.sheet(item: $videoExercise) { exercise in .sheet(item: $videoExercise) { exercise in
if let url = URL(string: BaseURLs.dev.rawValue + exercise.videoURL) { VideoPlayerView(avPlayer: $avPlayer)
VideoPlayerView(url: url)
}
} }
.sheet(item: $createWorkoutItemPickerViewModel) { item in .sheet(item: $createWorkoutItemPickerViewModel) { item in
CreateWorkoutItemPickerView(viewModel: item, completed: { selectedids in CreateWorkoutItemPickerView(viewModel: item, completed: { selectedids in

View File

@@ -10,20 +10,16 @@ import AVKit
struct ExternalWorkoutDetailView: View { struct ExternalWorkoutDetailView: View {
@StateObject var bridgeModule = BridgeModule.shared @StateObject var bridgeModule = BridgeModule.shared
@State var videoURL = URL(string: "https://dev.werkout.fitness/media/exercise_videos/recovery.mp4")! @State var avPlayer = AVPlayer(url: URL(string: "https://dev.werkout.fitness/media/exercise_videos/2_Dumbbell_Lateral_Lunges.mp4")!)
var body: some View { var body: some View {
ZStack { ZStack {
if let workout = bridgeModule.currentWorkout { if let workout = bridgeModule.currentWorkout {
GeometryReader { metrics in GeometryReader { metrics in
VStack { VStack {
HStack { HStack {
VideoViewControllerView(url: $videoURL) VideoPlayerView(avPlayer: $avPlayer, showDoneButton: false)
.frame(width: metrics.size.width * 0.6, height: metrics.size.height * 0.8) .frame(width: metrics.size.width * 0.6, height: metrics.size.height * 0.8)
// if let videoPlayer = videoPlayer {
// videoPlayer
// .frame(width: metrics.size.width * 0.6, height: metrics.size.height * 0.8)
// }
ExtExerciseList(workout: workout, ExtExerciseList(workout: workout,
currentExerciseIdx: bridgeModule.currentExerciseIdx) currentExerciseIdx: bridgeModule.currentExerciseIdx)
@@ -43,8 +39,8 @@ struct ExternalWorkoutDetailView: View {
} }
.onChange(of: bridgeModule.currentExercise, perform: { newValue in .onChange(of: bridgeModule.currentExercise, perform: { newValue in
if let viddd = newValue?.exercise.videoURL, if let viddd = newValue?.exercise.videoURL,
let url = URL(string: BaseURLs.dev.rawValue + viddd) { let url = URL(string: BaseURLs.currentBaseURL + viddd) {
videoURL = url avPlayer = AVPlayer(url: url)
} }
}) })
.frame(maxWidth: .infinity, maxHeight: .infinity) .frame(maxWidth: .infinity, maxHeight: .infinity)

View File

@@ -7,80 +7,42 @@
import SwiftUI import SwiftUI
import AVKit import AVKit
import SafariServices import Combine
struct VideoPlayerView: View { struct VideoPlayerView: View {
@State var url: URL
@Environment(\.dismiss) var dismiss @Environment(\.dismiss) var dismiss
@Binding var avPlayer: AVPlayer
var showDoneButton = true
var pub = NotificationCenter.default.publisher(for: .AVPlayerItemDidPlayToEndTime)
var body: some View { var body: some View {
VStack { VStack {
Button(action: { if self.showDoneButton {
dismiss() Button(action: {
}, label: { dismiss()
Text("Done") }, label: {
}) Text("Done")
.padding() })
.frame(maxWidth: .infinity) .padding()
.background(Color(uiColor: UIColor(red: 0.11, green: 0.11, blue: 0.12, alpha: 1))) .frame(maxWidth: .infinity)
.background(Color(uiColor: UIColor(red: 0.11, green: 0.11, blue: 0.12, alpha: 1)))
}
VideoViewControllerView(url: $url) VideoPlayer(player: avPlayer)
.onAppear{
avPlayer.play()
}
} }
.background(.black) .background(.black)
} .onReceive(pub) { (output) in
} avPlayer.pause()
avPlayer.seek(to: .zero)
struct VideoViewControllerView: UIViewControllerRepresentable { avPlayer.play()
@Binding var url: URL
func makeUIViewController(context: Context) -> VideoViewController {
return VideoViewController(videoURL: url)
}
func updateUIViewController(_ uiViewController: VideoViewController, context: Context) {
if url != uiViewController.videoURL {
uiViewController.videoURL = url
uiViewController.layoutView()
} }
} }
} }
class VideoViewController: UIViewController {
var videoURL: URL
init(videoURL: URL) {
self.videoURL = videoURL
super.init(nibName: nil, bundle: nil)
layoutView()
}
required init?(coder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
override func viewDidLoad() {
super.viewDidLoad()
}
func layoutView() {
self.view.subviews.forEach({
$0.removeFromSuperview()
})
let sfVC = SFSafariViewController(url: self.videoURL)
sfVC.view.translatesAutoresizingMaskIntoConstraints = false
view.backgroundColor = .green
self.addChild(sfVC)
sfVC.didMove(toParent: self)
sfVC.view.backgroundColor = .magenta
sfVC.view.frame = self.view.bounds;
self.view.addSubview(sfVC.view)
sfVC.view.topAnchor.constraint(equalTo: view.topAnchor).isActive = true
sfVC.view.bottomAnchor.constraint(equalTo: view.bottomAnchor).isActive = true
sfVC.view.leadingAnchor.constraint(equalTo: view.leadingAnchor).isActive = true
sfVC.view.trailingAnchor.constraint(equalTo: view.trailingAnchor).isActive = true
}
}
//struct VideoPlayerView_Previews: PreviewProvider { //struct VideoPlayerView_Previews: PreviewProvider {
// static let exercise = PreviewData.parseExercises().first! // static let exercise = PreviewData.parseExercises().first!