WIP
This commit is contained in:
@@ -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 {
|
||||||
|
|||||||
@@ -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")
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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)
|
||||||
|
|||||||
@@ -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!
|
||||||
|
|||||||
Reference in New Issue
Block a user