From 516369fb07384b735e98b2034f8c1adbc40760d0 Mon Sep 17 00:00:00 2001 From: Matthew Hodgson Date: Wed, 31 Aug 2016 16:38:37 +0100 Subject: [PATCH] use promises to mediate access to HTMLAudioElements --- src/CallHandler.js | 21 ++++++++++++++++++--- 1 file changed, 18 insertions(+), 3 deletions(-) diff --git a/src/CallHandler.js b/src/CallHandler.js index 015160a1fe..b0057aec90 100644 --- a/src/CallHandler.js +++ b/src/CallHandler.js @@ -63,13 +63,22 @@ global.mxCalls = { var calls = global.mxCalls; var ConferenceHandler = null; +var audioPromises = {}; + function play(audioId) { // TODO: Attach an invisible element for this instead // which listens? var audio = document.getElementById(audioId); if (audio) { - audio.load(); - audio.play(); + if (audioPromises[audioId]) { + audioPromises[audioId] = audioPromises[audioId].then(()=>{ + audio.load(); + return audio.play()); + }); + } + else { + audioPromises[audioId] = audio.play(); + } } } @@ -78,7 +87,13 @@ function pause(audioId) { // which listens? var audio = document.getElementById(audioId); if (audio) { - audio.pause(); + if (audioPromises[audioId]) { + audioPromises[audioId] = audioPromises[audioId].then(()=>audio.pause()); + } + else { + // pause doesn't actually return a promise, but might as well do this for symmetry with play(); + audioPromises[audioId] = audio.pause(); + } } }