diff options
author | Sam Potts <me@sampotts.me> | 2017-11-09 19:41:12 +1100 |
---|---|---|
committer | Sam Potts <me@sampotts.me> | 2017-11-09 19:41:12 +1100 |
commit | fd97607e5512ab8aef5321c628a521d61a95b9e8 (patch) | |
tree | 8369e9fec11cd23abfbee163b764404a1d08afdc /src/js/utils.js | |
parent | f878581c8fe8c3e525722762553cf085e67d990f (diff) | |
parent | f9602acf611900d9f9ee27e62e3883fa9394bdee (diff) | |
download | plyr-fd97607e5512ab8aef5321c628a521d61a95b9e8.tar.lz plyr-fd97607e5512ab8aef5321c628a521d61a95b9e8.tar.xz plyr-fd97607e5512ab8aef5321c628a521d61a95b9e8.zip |
Merge branch 'develop' of https://github.com/Selz/plyr into develop
# Conflicts:
# dist/plyr.js
# dist/plyr.js.map
Diffstat (limited to 'src/js/utils.js')
-rw-r--r-- | src/js/utils.js | 19 |
1 files changed, 14 insertions, 5 deletions
diff --git a/src/js/utils.js b/src/js/utils.js index 1c78766f..84947e58 100644 --- a/src/js/utils.js +++ b/src/js/utils.js @@ -76,17 +76,26 @@ const utils = { }, // Load an external script - loadScript(url) { + loadScript(url, callback) { // Check script is not already referenced if (document.querySelectorAll(`script[src="${url}"]`).length) { return; } - const tag = document.createElement('script'); - tag.src = url; + // Build the element + const element = document.createElement('script'); + element.src = url; - const firstScriptTag = document.getElementsByTagName('script')[0]; - firstScriptTag.parentNode.insertBefore(tag, firstScriptTag); + // Find first script + const first = document.getElementsByTagName('script')[0]; + + // Bind callback + if (utils.is.function(callback)) { + element.addEventListener('load', event => callback.call(null, event), false); + } + + // Inject + first.parentNode.insertBefore(element, first); }, // Load an external SVG sprite |