Use videojs::http-streaming
for all except iPhones
## Ticket 31: "quality selector not available on safari browsers" ## Notes The quality selector isn't populated in some Apple products -- a known issue with videojs as the platform doesn't relay the info. But it seems like only iPhone is affected, so let's enable the override for all platforms except iPhone.
This commit is contained in:
parent
1ad66fccd0
commit
7445063405
2 changed files with 6 additions and 8 deletions
|
@ -160,18 +160,16 @@ export default React.memo<Props>(function VideoJs(props: Props) {
|
||||||
|
|
||||||
const isMobile = useIsMobile();
|
const isMobile = useIsMobile();
|
||||||
|
|
||||||
// will later store the videojs player
|
|
||||||
const playerRef = useRef();
|
const playerRef = useRef();
|
||||||
const containerRef = useRef();
|
const containerRef = useRef();
|
||||||
|
|
||||||
const tapToUnmuteRef = useRef();
|
const tapToUnmuteRef = useRef();
|
||||||
const tapToRetryRef = useRef();
|
const tapToRetryRef = useRef();
|
||||||
|
|
||||||
const playerServerRef = useRef();
|
const playerServerRef = useRef();
|
||||||
|
|
||||||
const { url: livestreamVideoUrl } = activeLivestreamForChannel || {};
|
const { url: livestreamVideoUrl } = activeLivestreamForChannel || {};
|
||||||
|
const overrideNativeVhs = !platform.isIPhone();
|
||||||
const showQualitySelector =
|
const showQualitySelector =
|
||||||
!isLivestreamClaim ||
|
(!isLivestreamClaim && overrideNativeVhs) ||
|
||||||
(livestreamVideoUrl && (livestreamVideoUrl.includes('/transcode/') || livestreamVideoUrl.includes('cloud.odysee')));
|
(livestreamVideoUrl && (livestreamVideoUrl.includes('/transcode/') || livestreamVideoUrl.includes('cloud.odysee')));
|
||||||
|
|
||||||
// initiate keyboard shortcuts
|
// initiate keyboard shortcuts
|
||||||
|
@ -214,7 +212,7 @@ export default React.memo<Props>(function VideoJs(props: Props) {
|
||||||
controls: true,
|
controls: true,
|
||||||
html5: {
|
html5: {
|
||||||
vhs: {
|
vhs: {
|
||||||
overrideNative: !videojs.browser.IS_ANY_SAFARI,
|
overrideNative: overrideNativeVhs, // !videojs.browser.IS_ANY_SAFARI,
|
||||||
enableLowInitialPlaylist: false,
|
enableLowInitialPlaylist: false,
|
||||||
fastQualityChange: true,
|
fastQualityChange: true,
|
||||||
useDtsForTimestampOffset: true,
|
useDtsForTimestampOffset: true,
|
||||||
|
|
|
@ -203,9 +203,9 @@ export const platform = {
|
||||||
// return (/ipad/gi).test(navigator.platform);
|
// return (/ipad/gi).test(navigator.platform);
|
||||||
// },
|
// },
|
||||||
|
|
||||||
// isIPhone: function() { << untested
|
isIPhone: function () {
|
||||||
// return (/iphone/gi).test(navigator.platform);
|
return /iphone/gi.test(navigator.platform);
|
||||||
// },
|
},
|
||||||
|
|
||||||
// isLandscape: function() { << I think window.orientation makes more sense
|
// isLandscape: function() { << I think window.orientation makes more sense
|
||||||
// return window.innerHeight < window.innerWidth;
|
// return window.innerHeight < window.innerWidth;
|
||||||
|
|
Loading…
Add table
Reference in a new issue