diff options
| author | Sam Potts <sam@potts.es> | 2019-04-25 12:09:46 +1000 | 
|---|---|---|
| committer | Sam Potts <sam@potts.es> | 2019-04-25 12:09:46 +1000 | 
| commit | 5ddd9e02def654bb677c988403dbefbc4a32787c (patch) | |
| tree | 60f96b088ce8490429199163a5e71768b8a9b52c /src/js | |
| parent | a064f0b4fdc2d654063ff0af651d1abc1604f3f4 (diff) | |
| download | plyr-5ddd9e02def654bb677c988403dbefbc4a32787c.tar.lz plyr-5ddd9e02def654bb677c988403dbefbc4a32787c.tar.xz plyr-5ddd9e02def654bb677c988403dbefbc4a32787c.zip | |
Fix for the menu in the shadow DOM
Diffstat (limited to 'src/js')
| -rw-r--r-- | src/js/controls.js | 20 | 
1 files changed, 4 insertions, 16 deletions
| diff --git a/src/js/controls.js b/src/js/controls.js index 150dcdd2..9a960b38 100644 --- a/src/js/controls.js +++ b/src/js/controls.js @@ -10,20 +10,7 @@ import support from './support';  import { repaint, transitionEndEvent } from './utils/animation';  import { dedupe } from './utils/arrays';  import browser from './utils/browser'; -import { -    createElement, -    emptyElement, -    getAttributesFromSelector, -    getElement, -    getElements, -    hasClass, -    matches, -    removeElement, -    setAttributes, -    setFocus, -    toggleClass, -    toggleHidden, -} from './utils/elements'; +import { createElement, emptyElement, getAttributesFromSelector, getElement, getElements, hasClass, matches, removeElement, setAttributes, setFocus, toggleClass, toggleHidden } from './utils/elements';  import { off, on } from './utils/events';  import i18n from './utils/i18n';  import is from './utils/is'; @@ -1141,8 +1128,9 @@ const controls = {              show = false;          } else if (is.event(input)) {              // If Plyr is in a shadowDOM, the event target is set to the component, instead of the -            // element in the shadowDOM. The path, however, is complete. -            const isMenuItem = popup.contains(input.path[0]); +            // Element in the shadowDOM. The path, if available, is complete. +            const target = is.function(input.composedPath) ? input.composedPath()[0] : input.target; +            const isMenuItem = popup.contains(target);              // If the click was inside the menu or if the click              // wasn't the button or menu item and we're trying to | 
