;(function(window) { 'use strict'; /** `QUnit.addEvent` shortcut */ var addEvent = QUnit.addEvent; /** The Lo-Dash build to load */ var build = (/build=([^&]+)/.exec(location.search) || [])[1]; /** A flag to determine if RequireJS should be loaded */ var norequire = /[?&]norequire=true(?:&|$)/.test(location.search); /** The `ui` object */ var ui = {}; /*--------------------------------------------------------------------------*/ // expose Lo-Dash build file path ui.buildPath = (function() { switch (build) { case 'lodash-prod': return 'dist/lodash.compat.min.js'; case 'lodash-underscore': return 'dist/lodash.underscore.min.js'; case 'lodash-modern': return 'dist/lodash.min.js'; case 'lodash-modern-debug': return 'dist/lodash.js'; case 'lodash-custom': return 'lodash.custom.min.js'; case 'lodash-custom-debug': return 'lodash.custom.js'; } return 'lodash.js'; }()); // assign `QUnit.urlParams` properties QUnit.extend(QUnit.urlParams, { 'build': build, 'norequire': norequire }); // initialize controls addEvent(window, 'load', function() { function eventHandler(event) { var search = location.search.replace(/^\?|&?(?:build|norequire)=[^&]*&?/g, ''); if (event.stopPropagation) { event.stopPropagation(); } else { event.cancelBubble = true; } location.href = location.href.split('?')[0] + '?' + (search ? search + '&' : '') + 'build=' + buildList[buildList.selectedIndex].value + (checkbox.checked ? '&norequire=true' : ''); } function init() { var toolbar = document.getElementById('qunit-testrunner-toolbar'); if (toolbar) { toolbar.appendChild(span1); toolbar.appendChild(span2); buildList.selectedIndex = (function() { switch (build) { case 'lodash-prod': return 1; case 'lodash-underscore': return 2; case 'lodash-modern': return 3; case 'lodash-modern-debug': return 4; case 'lodash-custom': return 5; case 'lodash-custom-debug': return 6; } return 0; }()); checkbox.checked = norequire; addEvent(checkbox, 'click', eventHandler); addEvent(buildList, 'change', eventHandler); } else { setTimeout(init, 15); } } var span1 = document.createElement('span'); span1.innerHTML = '' + ''; var span2 = document.createElement('span'); span2.style.cssText = 'float:right'; span2.innerHTML = '' + ''; var checkbox = span1.firstChild, buildList = span2.lastChild; init(); }); // expose `ui` window.ui = ui; }(this));