mirror of
https://github.com/jellyfin/jellyfin-web
synced 2025-03-30 19:56:21 +00:00
Polyfill HTMLMediaElement.play
Return a `Promise` to match the new standard.
This commit is contained in:
parent
801c29d3b9
commit
270430f6a1
3 changed files with 41 additions and 21 deletions
|
@ -197,10 +197,7 @@ import { Events } from 'jellyfin-apiclient';
|
|||
|
||||
export function playWithPromise(elem, onErrorFn) {
|
||||
try {
|
||||
const promise = elem.play();
|
||||
if (promise && promise.then) {
|
||||
// Chrome now returns a promise
|
||||
return promise
|
||||
return elem.play()
|
||||
.catch((e) => {
|
||||
const errorName = (e.name || '').toLowerCase();
|
||||
// safari uses aborterror
|
||||
|
@ -215,10 +212,6 @@ import { Events } from 'jellyfin-apiclient';
|
|||
onSuccessfulPlay(elem, onErrorFn);
|
||||
return Promise.resolve();
|
||||
});
|
||||
} else {
|
||||
onSuccessfulPlay(elem, onErrorFn);
|
||||
return Promise.resolve();
|
||||
}
|
||||
} catch (err) {
|
||||
console.error('error calling video.play: ' + err);
|
||||
return Promise.reject();
|
||||
|
|
26
src/legacy/htmlMediaElement.js
Normal file
26
src/legacy/htmlMediaElement.js
Normal file
|
@ -0,0 +1,26 @@
|
|||
/**
|
||||
* Polyfill for HTMLMediaElement
|
||||
* - HTMLMediaElement.play
|
||||
* Return a `Promise`.
|
||||
*/
|
||||
|
||||
(function (HTMLMediaElement) {
|
||||
'use strict';
|
||||
|
||||
const HTMLMediaElement_proto = HTMLMediaElement.prototype;
|
||||
const real_play = HTMLMediaElement_proto.play;
|
||||
|
||||
HTMLMediaElement_proto.play = function () {
|
||||
try {
|
||||
const promise = real_play.apply(this, arguments);
|
||||
|
||||
if (typeof promise?.then === 'function') {
|
||||
return promise;
|
||||
}
|
||||
|
||||
return Promise.resolve();
|
||||
} catch (err) {
|
||||
return Promise.reject(err);
|
||||
}
|
||||
};
|
||||
}(HTMLMediaElement));
|
|
@ -31,6 +31,7 @@ import './serverNotifications';
|
|||
import '../components/playback/playerSelectionMenu';
|
||||
import '../legacy/domParserTextHtml';
|
||||
import '../legacy/focusPreventScroll';
|
||||
import '../legacy/htmlMediaElement';
|
||||
import '../legacy/vendorStyles';
|
||||
import SyncPlay from '../components/syncPlay/core';
|
||||
import { playbackManager } from '../components/playback/playbackmanager';
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue