Skip to content

Commit

Permalink
Transform audio nodes to video nodes on Safari
Browse files Browse the repository at this point in the history
This should allow Safari to support captions for audio
  • Loading branch information
jcoyne committed Nov 2, 2023
1 parent a68594f commit 6701295
Showing 1 changed file with 19 additions and 0 deletions.
19 changes: 19 additions & 0 deletions app/javascript/src/controllers/media_tag_controller.js
Original file line number Diff line number Diff line change
Expand Up @@ -47,12 +47,31 @@ export default class extends Controller {
}

initializeVideoJSPlayer() {
this.transformAudioToVideoForSafari()
this.mediaTagTargets.forEach((mediaTag) => {
mediaTag.classList.add('video-js', 'vjs-default-skin')
videojs(mediaTag.id).removeChild('textTrackSettings')
})
}

// Safari 16.6 and below don't render vtt tracks for audio, so change those to be video elements.
transformAudioToVideoForSafari() {
if (!navigator.userAgent.match(/Safari/i))
return
if (![...this.mediaTagTargets].some((mediaTag) => mediaTag.nodeName === "AUDIO" && mediaTag.querySelector('track')))
return

this.mediaTagTargets.forEach((audioTag) => {
if (mediaTag.nodeName !== "AUDIO")
return
const videoTag = document.createElement('video');
[...audioTag.attributes].forEach( attr => videoTag.setAttribute(attr.nodeName, attr.nodeValue))
audioTag.childNodes.forEach(child => videoTag.appendChild(child))
audioTag.parentNode.replaceChild(videoTag, audioTag);
})

}

setupThumbnails() {
const thumbnails = [...this.element.querySelectorAll('[data-slider-object]')].
map((mediaDiv, index) => buildThumbnail(mediaDiv.dataset, index))
Expand Down

0 comments on commit 6701295

Please sign in to comment.