3 exports.__esModule = true;
4 exports.hasLoaded = exports.autoSetupTimeout = exports.autoSetup = undefined;
6 var _dom = require('./utils/dom');
8 var Dom = _interopRequireWildcard(_dom);
10 var _events = require('./utils/events.js');
12 var Events = _interopRequireWildcard(_events);
14 var _document = require('global/document');
16 var _document2 = _interopRequireDefault(_document);
18 var _window = require('global/window');
20 var _window2 = _interopRequireDefault(_window);
22 function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
24 function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj['default'] = obj; return newObj; } }
27 * @file setup.js - Functions for setting up a player without
28 * user interaction based on the data-setup `attribute` of the video tag.
32 var _windowLoaded = false;
36 * Set up any tags that have a data-setup `attribute` when the player is started.
38 var autoSetup = function autoSetup() {
40 // Protect against breakage in non-browser environments.
45 // One day, when we stop supporting IE8, go back to this, but in the meantime...*hack hack hack*
46 // var vids = Array.prototype.slice.call(document.getElementsByTagName('video'));
47 // var audios = Array.prototype.slice.call(document.getElementsByTagName('audio'));
48 // var mediaEls = vids.concat(audios);
50 // Because IE8 doesn't support calling slice on a node list, we need to loop
51 // through each list of elements to build up a new, combined list of elements.
52 var vids = _document2['default'].getElementsByTagName('video');
53 var audios = _document2['default'].getElementsByTagName('audio');
56 if (vids && vids.length > 0) {
57 for (var i = 0, e = vids.length; i < e; i++) {
58 mediaEls.push(vids[i]);
62 if (audios && audios.length > 0) {
63 for (var _i = 0, _e = audios.length; _i < _e; _i++) {
64 mediaEls.push(audios[_i]);
68 // Check if any media elements exist
69 if (mediaEls && mediaEls.length > 0) {
71 for (var _i2 = 0, _e2 = mediaEls.length; _i2 < _e2; _i2++) {
72 var mediaEl = mediaEls[_i2];
74 // Check if element exists, has getAttribute func.
75 // IE seems to consider typeof el.getAttribute == 'object' instead of
76 // 'function' like expected, at least when loading the player immediately.
77 if (mediaEl && mediaEl.getAttribute) {
79 // Make sure this player hasn't already been set up.
80 if (mediaEl.player === undefined) {
81 var options = mediaEl.getAttribute('data-setup');
83 // Check if data-setup attr exists.
84 // We only auto-setup if they've added the data-setup attr.
85 if (options !== null) {
86 // Create new video.js instance.
91 // If getAttribute isn't defined, we need to wait for the DOM.
98 // No videos were found, so keep looping unless page is finished loading.
99 } else if (!_windowLoaded) {
105 * Wait until the page is loaded before running autoSetup. This will be called in
106 * autoSetup if `hasLoaded` returns false.
108 * @param {number} wait
109 * How long to wait in ms
111 * @param {videojs} [vjs]
112 * The videojs library function
114 function autoSetupTimeout(wait, vjs) {
119 _window2['default'].setTimeout(autoSetup, wait);
122 if (Dom.isReal() && _document2['default'].readyState === 'complete') {
123 _windowLoaded = true;
126 * Listen for the load event on window, and set _windowLoaded to true.
130 Events.one(_window2['default'], 'load', function () {
131 _windowLoaded = true;
136 * check if the document has been loaded
138 var hasLoaded = function hasLoaded() {
139 return _windowLoaded;
142 exports.autoSetup = autoSetup;
143 exports.autoSetupTimeout = autoSetupTimeout;
144 exports.hasLoaded = hasLoaded;