jellyflood/Shared/Extensions/JellyfinAPI/DeviceProfile.swift
Joe f5bd1b8fcd
Customizable Device Profiles (#1169)
* Rename ExperimentalSettingsView.swift to PlaybackQualitySettingsView.swift

Fix Merge

* Rename MaximumBitrateSettingsView.swift to PlaybackQualitySettingsView.swift

fix merge

* Re-implement on Main. Should now have all the Main changed. Added a new change to use the Device Profile as a Transcoding Profile.

* Part 1 -> Making VideoPlayerType into a struct (I Hope) correctly

* Part 1.1 -> Making VideoPlayerType into a struct (I Hope) correctly

* Remove unneeded Files

* Missing file + CustomDeviceProfileSelection -> CustomDeviceProfileAction Rename

* Change + to Appending

* Attempt to add StorageValues+User. Not sure if this is correct?

* Move the Array unwrapping to funcitons. Not required but this should help prevent accidently doing this wrong. Add subtitles back into the custom profiles since that somehow got dropped. Added a PlaybackCompatibility enum. This might need to work for more than just video

* Complete rewrite to allow multiple profiles, compatibility mode, and directplay.

* Hardward -> Hardware

* Update CustomDeviceProfileSettingsView.swift

Double Licensing

* It was actually really easy to implement iOS... Trash cans still look weird and small.

* Swipe to Delete instead of the edit button

* wip

* wip

* Linting

* tvOS Implementation

* wip

* wip

* cleanup

* Create Package.resolved

---------

Co-authored-by: Joseph Kribs <joseph@kribs.net>
Co-authored-by: Ethan Pippin <ethanpippin2343@gmail.com>
2024-09-02 15:33:02 -06:00

80 lines
2.9 KiB
Swift

//
// Swiftfin is subject to the terms of the Mozilla Public
// License, v2.0. If a copy of the MPL was not distributed with this
// file, you can obtain one at https://mozilla.org/MPL/2.0/.
//
// Copyright (c) 2024 Jellyfin & Jellyfin Contributors
//
import Defaults
import JellyfinAPI
extension DeviceProfile {
static func build(
for videoPlayer: VideoPlayerType,
compatibilityMode: PlaybackCompatibility,
maxBitrate: Int? = nil
) -> DeviceProfile {
var deviceProfile: DeviceProfile = .init()
// MARK: - Video Player Specific Logic
deviceProfile.codecProfiles = videoPlayer.codecProfiles
deviceProfile.responseProfiles = videoPlayer.responseProfiles
deviceProfile.subtitleProfiles = videoPlayer.subtitleProfiles
// MARK: - DirectPlay & Transcoding Profiles
switch compatibilityMode {
case .auto:
deviceProfile.directPlayProfiles = videoPlayer.directPlayProfiles
deviceProfile.transcodingProfiles = videoPlayer.transcodingProfiles
case .mostCompatible:
deviceProfile.directPlayProfiles = PlaybackCompatibility.Video.compatibilityDirectPlayProfile
deviceProfile.transcodingProfiles = PlaybackCompatibility.Video.compatibilityTranscodingProfile
case .directPlay:
deviceProfile.directPlayProfiles = PlaybackCompatibility.Video.forcedDirectPlayProfile
case .custom:
let customProfileMode = Defaults[.VideoPlayer.Playback.customDeviceProfileAction]
let playbackDeviceProfile = StoredValues[.User.customDeviceProfiles]
if customProfileMode == .add {
deviceProfile.directPlayProfiles = videoPlayer.directPlayProfiles
deviceProfile.transcodingProfiles = videoPlayer.transcodingProfiles
} else {
deviceProfile.directPlayProfiles = []
// Only clear the Transcoding Profiles if one of the CustomProfiles is active as a Transcoding Profile
if playbackDeviceProfile.contains(where: { $0.useAsTranscodingProfile == true }) {
deviceProfile.transcodingProfiles = []
} else {
deviceProfile.transcodingProfiles = videoPlayer.transcodingProfiles
}
}
for profile in playbackDeviceProfile where profile.type == .video {
deviceProfile.directPlayProfiles?.append(profile.directPlayProfile)
if profile.useAsTranscodingProfile {
deviceProfile.transcodingProfiles?.append(profile.transcodingProfile)
}
}
}
// MARK: - Assign the Bitrate if provided
if let maxBitrate {
deviceProfile.maxStaticBitrate = maxBitrate
deviceProfile.maxStreamingBitrate = maxBitrate
deviceProfile.musicStreamingTranscodingBitrate = maxBitrate
}
return deviceProfile
}
}