[create-pull-request] automated change
This commit is contained in:
parent
e6bd488ee1
commit
7476a11a36
|
@ -53,7 +53,7 @@ struct MainTabView: View {
|
||||||
Image(systemName: "folder")
|
Image(systemName: "folder")
|
||||||
}
|
}
|
||||||
.tag(Tab.allMedia)
|
.tag(Tab.allMedia)
|
||||||
|
|
||||||
SettingsView(viewModel: SettingsViewModel())
|
SettingsView(viewModel: SettingsViewModel())
|
||||||
.offset(y: -1) // don't remove this. it breaks tabview on 4K displays.
|
.offset(y: -1) // don't remove this. it breaks tabview on 4K displays.
|
||||||
.tabItem {
|
.tabItem {
|
||||||
|
|
|
@ -78,7 +78,7 @@ struct SettingsView: View {
|
||||||
}
|
}
|
||||||
Button {
|
Button {
|
||||||
DispatchQueue.main.asyncAfter(deadline: .now() + 0.1) {
|
DispatchQueue.main.asyncAfter(deadline: .now() + 0.1) {
|
||||||
SessionManager.current.logout();
|
SessionManager.current.logout()
|
||||||
let nc = NotificationCenter.default
|
let nc = NotificationCenter.default
|
||||||
nc.post(name: Notification.Name("didSignOut"), object: nil)
|
nc.post(name: Notification.Name("didSignOut"), object: nil)
|
||||||
}
|
}
|
||||||
|
|
|
@ -582,11 +582,11 @@ class VideoPlayerViewController: UIViewController, VideoPlayerSettingsDelegate,
|
||||||
updateNowPlayingCenter(time: nil, playing: mediaPlayer.state == .playing)
|
updateNowPlayingCenter(time: nil, playing: mediaPlayer.state == .playing)
|
||||||
|
|
||||||
if (eventName == "timeupdate" && mediaPlayer.state == .playing) || eventName != "timeupdate" {
|
if (eventName == "timeupdate" && mediaPlayer.state == .playing) || eventName != "timeupdate" {
|
||||||
var ticks: Int64 = Int64(mediaPlayer.position * Float(manifest.runTimeTicks!));
|
var ticks: Int64 = Int64(mediaPlayer.position * Float(manifest.runTimeTicks!))
|
||||||
if(ticks == 0) {
|
if ticks == 0 {
|
||||||
ticks = manifest.userData?.playbackPositionTicks ?? 0
|
ticks = manifest.userData?.playbackPositionTicks ?? 0
|
||||||
}
|
}
|
||||||
|
|
||||||
let progressInfo = PlaybackProgressInfo(canSeek: true, item: manifest, itemId: manifest.id, sessionId: playSessionId, mediaSourceId: manifest.id, audioStreamIndex: Int(selectedAudioTrack), subtitleStreamIndex: Int(selectedCaptionTrack), isPaused: (!playing), isMuted: false, positionTicks: ticks, playbackStartTimeTicks: Int64(startTime), volumeLevel: 100, brightness: 100, aspectRatio: nil, playMethod: playbackItem.videoType, liveStreamId: nil, playSessionId: playSessionId, repeatMode: .repeatNone, nowPlayingQueue: [], playlistItemId: "playlistItem0")
|
let progressInfo = PlaybackProgressInfo(canSeek: true, item: manifest, itemId: manifest.id, sessionId: playSessionId, mediaSourceId: manifest.id, audioStreamIndex: Int(selectedAudioTrack), subtitleStreamIndex: Int(selectedCaptionTrack), isPaused: (!playing), isMuted: false, positionTicks: ticks, playbackStartTimeTicks: Int64(startTime), volumeLevel: 100, brightness: 100, aspectRatio: nil, playMethod: playbackItem.videoType, liveStreamId: nil, playSessionId: playSessionId, repeatMode: .repeatNone, nowPlayingQueue: [], playlistItemId: "playlistItem0")
|
||||||
|
|
||||||
PlaystateAPI.reportPlaybackProgress(playbackProgressInfo: progressInfo)
|
PlaystateAPI.reportPlaybackProgress(playbackProgressInfo: progressInfo)
|
||||||
|
|
|
@ -192,7 +192,7 @@ class EmailHelper: NSObject, MFMailComposeViewControllerDelegate {
|
||||||
let data = fileManager.contents(atPath: logURL.path)
|
let data = fileManager.contents(atPath: logURL.path)
|
||||||
|
|
||||||
picker.setSubject("[DEV-BUG] SwiftFin")
|
picker.setSubject("[DEV-BUG] SwiftFin")
|
||||||
picker.setMessageBody("Please don't edit this email.\n Please don't change the subject. \nUDID: \(UIDevice.current.identifierForVendor?.uuidString ?? "NIL")\n", isHTML: false);
|
picker.setMessageBody("Please don't edit this email.\n Please don't change the subject. \nUDID: \(UIDevice.current.identifierForVendor?.uuidString ?? "NIL")\n", isHTML: false)
|
||||||
picker.setToRecipients(["SwiftFin Bug Reports <swiftfin-bugs@jellyfin.org>"])
|
picker.setToRecipients(["SwiftFin Bug Reports <swiftfin-bugs@jellyfin.org>"])
|
||||||
picker.addAttachmentData(data!, mimeType: "text/plain", fileName: logURL.lastPathComponent)
|
picker.addAttachmentData(data!, mimeType: "text/plain", fileName: logURL.lastPathComponent)
|
||||||
picker.mailComposeDelegate = self
|
picker.mailComposeDelegate = self
|
||||||
|
|
|
@ -77,8 +77,8 @@ struct SettingsView: View {
|
||||||
Text("Signed in as \(username)").foregroundColor(.primary)
|
Text("Signed in as \(username)").foregroundColor(.primary)
|
||||||
Spacer()
|
Spacer()
|
||||||
Button {
|
Button {
|
||||||
print("logging out");
|
print("logging out")
|
||||||
close = false;
|
close = false
|
||||||
DispatchQueue.main.asyncAfter(deadline: .now() + 0.1) {
|
DispatchQueue.main.asyncAfter(deadline: .now() + 0.1) {
|
||||||
let nc = NotificationCenter.default
|
let nc = NotificationCenter.default
|
||||||
nc.post(name: Notification.Name("didSignOut"), object: nil)
|
nc.post(name: Notification.Name("didSignOut"), object: nil)
|
||||||
|
@ -88,9 +88,9 @@ struct SettingsView: View {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Button {
|
Button {
|
||||||
close = false;
|
close = false
|
||||||
DispatchQueue.main.asyncAfter(deadline: .now() + 0.1) {
|
DispatchQueue.main.asyncAfter(deadline: .now() + 0.1) {
|
||||||
SessionManager.current.logout();
|
SessionManager.current.logout()
|
||||||
let nc = NotificationCenter.default
|
let nc = NotificationCenter.default
|
||||||
nc.post(name: Notification.Name("didSignOut"), object: nil)
|
nc.post(name: Notification.Name("didSignOut"), object: nil)
|
||||||
}
|
}
|
||||||
|
|
|
@ -653,8 +653,8 @@ class PlayerViewController: UIViewController, GCKDiscoveryManagerListener, GCKRe
|
||||||
if fetchCaptions {
|
if fetchCaptions {
|
||||||
mediaPlayer.pause()
|
mediaPlayer.pause()
|
||||||
subtitleTrackArray.forEach { sub in
|
subtitleTrackArray.forEach { sub in
|
||||||
//stupid fxcking jeff decides to re-encode these when added.
|
// stupid fxcking jeff decides to re-encode these when added.
|
||||||
//only add playback streams when codec not supported by VLC.
|
// only add playback streams when codec not supported by VLC.
|
||||||
if sub.id != -1 && sub.delivery == .external && sub.codec != "subrip" {
|
if sub.id != -1 && sub.delivery == .external && sub.codec != "subrip" {
|
||||||
mediaPlayer.addPlaybackSlave(sub.url!, type: .subtitle, enforce: false)
|
mediaPlayer.addPlaybackSlave(sub.url!, type: .subtitle, enforce: false)
|
||||||
}
|
}
|
||||||
|
@ -1014,7 +1014,7 @@ struct VLCPlayerWithControls: UIViewControllerRepresentable {
|
||||||
func showLoadingView(_ viewController: PlayerViewController) {
|
func showLoadingView(_ viewController: PlayerViewController) {
|
||||||
self.loadBinding.wrappedValue = true
|
self.loadBinding.wrappedValue = true
|
||||||
}
|
}
|
||||||
|
|
||||||
func exitPlayer(_ viewController: PlayerViewController) {
|
func exitPlayer(_ viewController: PlayerViewController) {
|
||||||
self.pBinding.wrappedValue = false
|
self.pBinding.wrappedValue = false
|
||||||
}
|
}
|
||||||
|
@ -1041,11 +1041,11 @@ struct VLCPlayerWithControls: UIViewControllerRepresentable {
|
||||||
extension PlayerViewController {
|
extension PlayerViewController {
|
||||||
func sendProgressReport(eventName: String) {
|
func sendProgressReport(eventName: String) {
|
||||||
if (eventName == "timeupdate" && mediaPlayer.state == .playing) || eventName != "timeupdate" {
|
if (eventName == "timeupdate" && mediaPlayer.state == .playing) || eventName != "timeupdate" {
|
||||||
var ticks: Int64 = Int64(mediaPlayer.position * Float(manifest.runTimeTicks!));
|
var ticks: Int64 = Int64(mediaPlayer.position * Float(manifest.runTimeTicks!))
|
||||||
if(ticks == 0) {
|
if ticks == 0 {
|
||||||
ticks = manifest.userData?.playbackPositionTicks ?? 0
|
ticks = manifest.userData?.playbackPositionTicks ?? 0
|
||||||
}
|
}
|
||||||
|
|
||||||
let progressInfo = PlaybackProgressInfo(canSeek: true, item: manifest, itemId: manifest.id, sessionId: playSessionId, mediaSourceId: manifest.id, audioStreamIndex: Int(selectedAudioTrack), subtitleStreamIndex: Int(selectedCaptionTrack), isPaused: (mediaPlayer.state == .paused), isMuted: false, positionTicks: ticks, playbackStartTimeTicks: Int64(startTime), volumeLevel: 100, brightness: 100, aspectRatio: nil, playMethod: playbackItem.videoType, liveStreamId: nil, playSessionId: playSessionId, repeatMode: .repeatNone, nowPlayingQueue: [], playlistItemId: "playlistItem0")
|
let progressInfo = PlaybackProgressInfo(canSeek: true, item: manifest, itemId: manifest.id, sessionId: playSessionId, mediaSourceId: manifest.id, audioStreamIndex: Int(selectedAudioTrack), subtitleStreamIndex: Int(selectedCaptionTrack), isPaused: (mediaPlayer.state == .paused), isMuted: false, positionTicks: ticks, playbackStartTimeTicks: Int64(startTime), volumeLevel: 100, brightness: 100, aspectRatio: nil, playMethod: playbackItem.videoType, liveStreamId: nil, playSessionId: playSessionId, repeatMode: .repeatNone, nowPlayingQueue: [], playlistItemId: "playlistItem0")
|
||||||
|
|
||||||
PlaystateAPI.reportPlaybackProgress(playbackProgressInfo: progressInfo)
|
PlaystateAPI.reportPlaybackProgress(playbackProgressInfo: progressInfo)
|
||||||
|
|
|
@ -112,8 +112,8 @@ class DeviceProfileBuilder {
|
||||||
subtitleProfiles.append(SubtitleProfile(format: "subrip", method: .embed))
|
subtitleProfiles.append(SubtitleProfile(format: "subrip", method: .embed))
|
||||||
subtitleProfiles.append(SubtitleProfile(format: "sub", method: .embed))
|
subtitleProfiles.append(SubtitleProfile(format: "sub", method: .embed))
|
||||||
subtitleProfiles.append(SubtitleProfile(format: "pgssub", method: .embed))
|
subtitleProfiles.append(SubtitleProfile(format: "pgssub", method: .embed))
|
||||||
|
|
||||||
//These need to be filtered. Most subrips are embedded. I hate subtitles.
|
// These need to be filtered. Most subrips are embedded. I hate subtitles.
|
||||||
subtitleProfiles.append(SubtitleProfile(format: "subrip", method: .external))
|
subtitleProfiles.append(SubtitleProfile(format: "subrip", method: .external))
|
||||||
subtitleProfiles.append(SubtitleProfile(format: "sub", method: .external))
|
subtitleProfiles.append(SubtitleProfile(format: "sub", method: .external))
|
||||||
subtitleProfiles.append(SubtitleProfile(format: "ass", method: .external))
|
subtitleProfiles.append(SubtitleProfile(format: "ass", method: .external))
|
||||||
|
|
|
@ -26,7 +26,7 @@ struct ImageView: View {
|
||||||
var body: some View {
|
var body: some View {
|
||||||
LazyImage(source: source)
|
LazyImage(source: source)
|
||||||
.placeholder {
|
.placeholder {
|
||||||
Image(uiImage: UIImage(blurHash: blurhash, size: CGSize(width: 8, height: 8)) ?? UIImage(blurHash: "001fC^", size: CGSize(width:8,height:8))!)
|
Image(uiImage: UIImage(blurHash: blurhash, size: CGSize(width: 8, height: 8)) ?? UIImage(blurHash: "001fC^", size: CGSize(width: 8, height: 8))!)
|
||||||
.resizable()
|
.resizable()
|
||||||
}
|
}
|
||||||
.failure {
|
.failure {
|
||||||
|
|
|
@ -23,7 +23,7 @@ final class SessionManager {
|
||||||
fileprivate(set) var user: SignedInUser!
|
fileprivate(set) var user: SignedInUser!
|
||||||
fileprivate(set) var deviceID: String = ""
|
fileprivate(set) var deviceID: String = ""
|
||||||
fileprivate(set) var accessToken: String = ""
|
fileprivate(set) var accessToken: String = ""
|
||||||
|
|
||||||
#if os(tvOS)
|
#if os(tvOS)
|
||||||
let tvUserManager = TVUserManager()
|
let tvUserManager = TVUserManager()
|
||||||
#endif
|
#endif
|
||||||
|
@ -41,10 +41,10 @@ final class SessionManager {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
if(lastUsedUserID != nil) {
|
if lastUsedUserID != nil {
|
||||||
savedUsers?.forEach { savedUser in
|
savedUsers?.forEach { savedUser in
|
||||||
if(savedUser.user_id ?? "" == lastUsedUserID!) {
|
if savedUser.user_id ?? "" == lastUsedUserID! {
|
||||||
user = savedUser;
|
user = savedUser
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -146,7 +146,7 @@ final class SessionManager {
|
||||||
#if os(tvOS)
|
#if os(tvOS)
|
||||||
let descriptor: TVAppProfileDescriptor = TVAppProfileDescriptor(name: user.username!)
|
let descriptor: TVAppProfileDescriptor = TVAppProfileDescriptor(name: user.username!)
|
||||||
self.tvUserManager.shouldStorePreferenceForCurrentUser(to: descriptor) { should in
|
self.tvUserManager.shouldStorePreferenceForCurrentUser(to: descriptor) { should in
|
||||||
if(should) {
|
if should {
|
||||||
user.appletv_id = self.tvUserManager.currentUserIdentifier ?? ""
|
user.appletv_id = self.tvUserManager.currentUserIdentifier ?? ""
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -178,7 +178,7 @@ final class SessionManager {
|
||||||
keychain.accessGroup = "9R8RREG67J.me.vigue.jellyfin.sharedKeychain"
|
keychain.accessGroup = "9R8RREG67J.me.vigue.jellyfin.sharedKeychain"
|
||||||
keychain.delete("AccessToken_\(user?.user_id ?? "")")
|
keychain.delete("AccessToken_\(user?.user_id ?? "")")
|
||||||
generateAuthHeader(with: nil, deviceID: nil)
|
generateAuthHeader(with: nil, deviceID: nil)
|
||||||
if(user != nil) {
|
if user != nil {
|
||||||
let deleteRequest = NSBatchDeleteRequest(objectIDs: [user.objectID])
|
let deleteRequest = NSBatchDeleteRequest(objectIDs: [user.objectID])
|
||||||
user = nil
|
user = nil
|
||||||
_ = try? PersistenceController.shared.container.viewContext.execute(deleteRequest)
|
_ = try? PersistenceController.shared.container.viewContext.execute(deleteRequest)
|
||||||
|
|
|
@ -54,8 +54,8 @@ final class LibraryFilterViewModel: ViewModel {
|
||||||
init(filters: LibraryFilters? = nil,
|
init(filters: LibraryFilters? = nil,
|
||||||
enabledFilterType: [FilterType] = [.tag, .genre, .sortBy, .sortOrder, .filter], parentId: String) {
|
enabledFilterType: [FilterType] = [.tag, .genre, .sortBy, .sortOrder, .filter], parentId: String) {
|
||||||
self.enabledFilterType = enabledFilterType
|
self.enabledFilterType = enabledFilterType
|
||||||
self.selectedSortBy = filters?.sortBy.first ?? .name;
|
self.selectedSortBy = filters?.sortBy.first ?? .name
|
||||||
self.selectedSortOrder = filters?.sortOrder.first ?? .descending;
|
self.selectedSortOrder = filters?.sortOrder.first ?? .descending
|
||||||
self.parentId = parentId
|
self.parentId = parentId
|
||||||
|
|
||||||
super.init()
|
super.init()
|
||||||
|
|
Loading…
Reference in New Issue