Fix where navigationview is determined
This commit is contained in:
parent
e677be7128
commit
365cacc2ae
|
@ -211,7 +211,7 @@ class PlayerViewController: UIViewController, GCKDiscoveryManagerListener, GCKRe
|
||||||
|
|
||||||
@IBAction func settingsButtonTapped(_ sender: UIButton) {
|
@IBAction func settingsButtonTapped(_ sender: UIButton) {
|
||||||
optionsVC = VideoPlayerSettingsView()
|
optionsVC = VideoPlayerSettingsView()
|
||||||
optionsVC?.delegate = self
|
optionsVC?.playerDelegate = self
|
||||||
|
|
||||||
optionsVC?.modalPresentationStyle = .popover
|
optionsVC?.modalPresentationStyle = .popover
|
||||||
optionsVC?.popoverPresentationController?.sourceView = playerSettingsButton
|
optionsVC?.popoverPresentationController?.sourceView = playerSettingsButton
|
||||||
|
|
|
@ -8,9 +8,9 @@
|
||||||
import Foundation
|
import Foundation
|
||||||
import SwiftUI
|
import SwiftUI
|
||||||
|
|
||||||
class VideoPlayerSettingsView: UIViewController {
|
class VideoPlayerSettingsView: UINavigationController {
|
||||||
private var contentView: UIHostingController<VideoPlayerSettings>!
|
private var contentView: UIHostingController<VideoPlayerSettings>!
|
||||||
weak var delegate: PlayerViewController?
|
weak var playerDelegate: PlayerViewController?
|
||||||
|
|
||||||
override var supportedInterfaceOrientations: UIInterfaceOrientationMask {
|
override var supportedInterfaceOrientations: UIInterfaceOrientationMask {
|
||||||
.landscape
|
.landscape
|
||||||
|
@ -18,18 +18,13 @@ class VideoPlayerSettingsView: UIViewController {
|
||||||
|
|
||||||
override func viewDidLoad() {
|
override func viewDidLoad() {
|
||||||
super.viewDidLoad()
|
super.viewDidLoad()
|
||||||
contentView = UIHostingController(rootView: VideoPlayerSettings(delegate: self.delegate ?? PlayerViewController()))
|
|
||||||
self.view.addSubview(contentView.view)
|
self.viewControllers = [UIHostingController(rootView: VideoPlayerSettings(delegate: self.playerDelegate ?? PlayerViewController()))]
|
||||||
contentView.view.translatesAutoresizingMaskIntoConstraints = false
|
|
||||||
contentView.view.topAnchor.constraint(equalTo: view.topAnchor).isActive = true
|
|
||||||
contentView.view.bottomAnchor.constraint(equalTo: view.bottomAnchor).isActive = true
|
|
||||||
contentView.view.leftAnchor.constraint(equalTo: view.leftAnchor).isActive = true
|
|
||||||
contentView.view.rightAnchor.constraint(equalTo: view.rightAnchor).isActive = true
|
|
||||||
}
|
}
|
||||||
|
|
||||||
override func viewWillDisappear(_ animated: Bool) {
|
override func viewWillDisappear(_ animated: Bool) {
|
||||||
super.viewWillDisappear(animated)
|
super.viewWillDisappear(animated)
|
||||||
self.delegate?.settingsPopoverDismissed()
|
self.playerDelegate?.settingsPopoverDismissed()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,7 +39,6 @@ struct VideoPlayerSettings: View {
|
||||||
}
|
}
|
||||||
|
|
||||||
var body: some View {
|
var body: some View {
|
||||||
NavigationView {
|
|
||||||
Form {
|
Form {
|
||||||
Picker(NSLocalizedString("Closed Captions", comment: ""), selection: $captionTrack) {
|
Picker(NSLocalizedString("Closed Captions", comment: ""), selection: $captionTrack) {
|
||||||
ForEach(delegate.subtitleTrackArray, id: \.id) { caption in
|
ForEach(delegate.subtitleTrackArray, id: \.id) { caption in
|
||||||
|
@ -85,7 +79,6 @@ struct VideoPlayerSettings: View {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}.offset(y: UIDevice.current.userInterfaceIdiom == .pad ? 14 : 0)
|
}.offset(y: UIDevice.current.userInterfaceIdiom == .pad ? 14 : 0)
|
||||||
.onAppear(perform: {
|
.onAppear(perform: {
|
||||||
captionTrack = self.delegate.selectedCaptionTrack
|
captionTrack = self.delegate.selectedCaptionTrack
|
||||||
|
|
Loading…
Reference in New Issue