;(function(window) { 'use strict'; /** The base path of the builds */ var basePath = '../'; /** The Lo-Dash build to load */ var build = (build = /build=([^&]+)/.exec(location.search)) && decodeURIComponent(build[1]); /** The other library to load */ var other = (other = /other=([^&]+)/.exec(location.search)) && decodeURIComponent(other[1]); /** The `ui` object */ var ui = {}; /*--------------------------------------------------------------------------*/ /** * Registers an event listener on an element. * * @private * @param {Element} element The element. * @param {string} eventName The name of the event. * @param {Function} handler The event handler. * @returns {Element} The element. */ function addListener(element, eventName, handler) { if (typeof element.addEventListener != 'undefined') { element.addEventListener(eventName, handler, false); } else if (typeof element.attachEvent != 'undefined') { element.attachEvent('on' + eventName, handler); } } /*--------------------------------------------------------------------------*/ // expose `ui.urlParams` properties ui.urlParams = { 'build': build, 'other': other }; // expose Lo-Dash build file path ui.buildPath = (function() { var result; switch (build) { case 'lodash-compat': result = 'dist/lodash.compat.min.js'; break; case 'lodash-legacy': result = 'dist/lodash.legacy.min.js'; break; case 'lodash-mobile': result = 'dist/lodash.mobile.min.js'; break; case 'lodash-underscore': result = 'dist/lodash.underscore.min.js'; break; case 'lodash-custom-dev': result = 'lodash.custom.js'; break; case 'lodash-custom': result = 'lodash.custom.min.js'; break; case 'lodash-modern': case null: result = 'dist/lodash.min.js'; break; default: return build; } return basePath + result; }()); // expose other library file path ui.otherPath = (function() { var result; switch (other) { case 'lodash-compat': result = 'dist/lodash.compat.min.js'; break; case 'lodash-legacy': result = 'dist/lodash.legacy.min.js'; break; case 'lodash-mobile': result = 'dist/lodash.mobile.min.js'; break; case 'lodash-modern': result = 'dist/lodash.min.js'; break; case 'lodash-underscore': result = 'dist/lodash.underscore.min.js'; break; case 'lodash-custom-dev': result = 'lodash.custom.js'; break; case 'lodash-custom': result = 'lodash.custom.min.js'; break; case 'underscore-dev': result = 'vendor/underscore/underscore.js'; break; case 'underscore': case null: result = 'vendor/underscore/underscore-min.js'; break; default: return other; } return basePath + result; }()); // initialize controls addListener(window, 'load', function() { function eventHandler(event) { var buildIndex = buildList.selectedIndex, otherIndex = otherList.selectedIndex, search = location.search.replace(/^\?|&?(?:build|other)=[^&]*&?/g, ''); if (event.stopPropagation) { event.stopPropagation(); } else { event.cancelBubble = true; } location.href = location.href.split('?')[0] + '?' + (search ? search + '&' : '') + 'build=' + (buildIndex < 0 ? build : buildList[buildIndex].value) + '&' + 'other=' + (otherIndex < 0 ? other : otherList[otherIndex].value); } var span1 = document.createElement('span'); span1.style.cssText = 'float:right'; span1.innerHTML = '' + ''; var span2 = document.createElement('span'); span2.style.cssText = 'float:right'; span2.innerHTML = '' + ''; var buildList = span1.lastChild, otherList = span2.lastChild, toolbar = document.getElementById('perf-toolbar'); toolbar.appendChild(span2); toolbar.appendChild(span1); buildList.selectedIndex = (function() { switch (build) { case 'lodash-compat': return 0; case 'lodash-legacy': return 1; case 'lodash-mobile': return 2; case 'lodash-underscore': return 4; case 'lodash-custom-dev': return 5; case 'lodash-custom': return 6; case 'lodash-modern': case null: return 3; } return -1; }()); otherList.selectedIndex = (function() { switch (other) { case 'underscore-dev': return 0; case 'lodash-compat': return 2; case 'lodash-legacy': return 3; case 'lodash-mobile': return 4; case 'lodash-modern': return 5; case 'lodash-underscore': return 6; case 'lodash-custom-dev': return 7; case 'lodash-custom': return 8; case 'underscore': case null: return 1; } return -1; }()); addListener(buildList, 'change', eventHandler); addListener(otherList, 'change', eventHandler); }); // expose `ui` window.ui = ui; }(this));