{"version":3,"sources":["webpack:/webpack/bootstrap ba99d219b9a729b4bf17","webpack:///src/loader/path-resolver.js","webpack:///src/loader/bootstrap.js","webpack:///src/loader/loader.js","webpack:///src/loader/config-parser.js","webpack:///src/loader/dependency-builder.js","webpack:///src/loader/event-emitter.js","webpack:///src/loader/url-builder.js","webpack:///package.json","webpack:///node_modules/es6-promise/dist/es6-promise.js","webpack:///node_modules/process/browser.js"],"names":["PathResolver","root","dependency","i","dependencyParts","length","dependencyPart","moduleParts","cfg","window","__CONFIG__","namespace","loader","ns","exposeGlobal","require","Loader","config","module","args","dependencies","console","name","passedArgsCount","implementation","anonymous","onScriptLoaded","loadedModules","_reportMismatchedAnonymousModules","toString","successCallback","failureCallback","log","configParser","_getConfigParser","_resolveDependencies","reject","moduleImplementations","Array","modules","rejectTimeout","registeredModules","Error","error","filteredDeps","moduleName","exportedValue","resolve","nameParts","packageParts","pathResolver","exports","moduleNames","requiredModules","property","properties","registeredModule","missingModules","Promise","modulesURL","_getURLBuilder","pendingScripts","self","script","onload","onreadystatechange","appendChild","explainResolutions","aliasedConsole","reportLevel","dependencyImplementations","moduleImpl","push","_createLocalRequire","localRequire","result","pendingImplementation","rest","modulesPromises","_waitForModule","definedModules","defineModules","ConfigParser","moduleDefinition","isArray","maps","match","existingModules","DependencyBuilder","_cachedResolutions","resolution","conditionalMark","_visit","testFunction","eval","dependencyName","moduleDependency","EventEmitter","event","callback","listeners","callbackIndex","splice","URLBuilder","modulesAbsoluteURL","modulesRelativeURL","basePath","url","REGEX_EXTERNAL_PROTOCOLS","test","_getURLWithParams","path","absolutePath","bufferAbsoluteURL","bufferRelativeURL","urlMaxLength","urlResult","Object"],"mappings":"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","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 1);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap ba99d219b9a729b4bf17","/**\n *\n */\nexport default class PathResolver {\n\t/**\n\t * Resolves the path of module.\n\t *\n\t * @param {string} root Root path which will be used as reference to resolve\n\t * the path of the dependency.\n\t * @param {string} dependency The dependency path, which have to be\n\t * resolved.\n\t * @return {string} The resolved dependency path.\n\t */\n\tresolvePath(root, dependency) {\n\t\tif (\n\t\t\tdependency === 'require' ||\n\t\t\tdependency === 'exports' ||\n\t\t\tdependency === 'module' ||\n\t\t\t!(dependency.indexOf('.') === 0 || dependency.indexOf('..') === 0)\n\t\t) {\n\t\t\treturn dependency;\n\t\t}\n\n\t\t// Split module directories\n\t\tlet moduleParts = root.split('/');\n\n\t\t// Remove module name\n\t\tmoduleParts.splice(-1, 1);\n\n\t\t// Split dependency directories\n\t\tconst dependencyParts = dependency.split('/');\n\n\t\t// Extract dependency name\n\t\tconst dependencyName = dependencyParts.splice(-1, 1);\n\n\t\tfor (let i = 0; i < dependencyParts.length; i++) {\n\t\t\tlet dependencyPart = dependencyParts[i];\n\n\t\t\tif (dependencyPart === '.') {\n\t\t\t\tcontinue;\n\t\t\t} else if (dependencyPart === '..') {\n\t\t\t\tif (moduleParts.length) {\n\t\t\t\t\tmoduleParts.splice(-1, 1);\n\t\t\t\t} else {\n\t\t\t\t\tmoduleParts = moduleParts.concat(dependencyParts.slice(i));\n\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tmoduleParts.push(dependencyPart);\n\t\t\t}\n\t\t}\n\n\t\tmoduleParts.push(dependencyName);\n\n\t\treturn moduleParts.join('/');\n\t}\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/loader/path-resolver.js","import Loader from './loader.js';\nimport Promise from 'es6-promise';\n\nif (typeof window.Promise === 'undefined') {\n\twindow.Promise = Promise;\n}\n\nconst cfg = window.__CONFIG__ || {};\nconst namespace = typeof cfg.namespace === 'string' ? cfg.namespace : undefined;\nconst exposeGlobal = cfg.exposeGlobal === undefined ? true : cfg.exposeGlobal;\nconst loader = new Loader(cfg);\n\nif (namespace) {\n\tconst ns = window[namespace] ? window[namespace] : {};\n\tns.Loader = loader;\n\twindow[namespace] = ns;\n} else {\n\twindow.Loader = loader;\n}\n\nif (exposeGlobal) {\n\twindow.Loader = loader;\n\twindow.require = Loader.prototype.require.bind(loader);\n\twindow.define = Loader.prototype.define.bind(loader);\n\twindow.define.amd = {};\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/loader/bootstrap.js","import ConfigParser from './config-parser';\nimport DependencyBuilder from './dependency-builder';\nimport EventEmitter from './event-emitter';\nimport PathResolver from './path-resolver';\nimport URLBuilder from './url-builder';\nimport packageJson from '../../package.json';\n\n/**\n *\n */\nexport default class Loader extends EventEmitter {\n\t/**\n\t * Creates an instance of Loader class.\n\t *\n\t * @namespace Loader\n\t * @extends EventEmitter\n\t * @param {object=} config Configuration options (defaults to window.__CONFIG__)\n\t * @param {object} document DOM document object to use (defaults to window.document)\n\t * @constructor\n\t */\n\tconstructor(config = null, document = null) {\n\t\tsuper();\n\n\t\tthis._config = config || window.__CONFIG__;\n\t\tthis._document = document || window.document;\n\t\tthis._modulesMap = {};\n\t}\n\n\t/**\n\t * Get loader version\n\t * @return {String} the version number as specified in package.json\n\t */\n\tversion() {\n\t\treturn packageJson.version;\n\t}\n\n\t/**\n\t * Adds a module to the configuration. See {@link ConfigParser#addModule}\n\t * for more details.\n\t *\n\t * @memberof! Loader#\n\t * @param {Object} module The module which should be added to the configuration. See {@link ConfigParser#addModule}\n\t * \t\t\t\t\t\tfor more details.\n\t * @return {Object} Returns the added module to the configuration.\n\t */\n\taddModule(module) {\n\t\treturn this._getConfigParser().addModule(module);\n\t}\n\n\t/**\n\t * Defines a module in the system and fires {@link Loader#event:moduleRegister} event with the registered module as\n\t * param.\n\t *\n\t * @memberof! Loader#\n\t * @param {string} name The name of the module.\n\t * @param {array} dependencies List of module dependencies.\n\t * @param {function} implementation The implementation of the module.\n\t * @param {object=} config Object configuration:\n\t * \n\t */\n\tdefine(...args) {\n\t\tlet name = args[0];\n\t\tlet dependencies = args[1];\n\t\tlet implementation = args[2];\n\t\tlet config = args[3] || {};\n\n\t\t\n\n\t\tconfig.anonymous = false;\n\n\t\tlet passedArgsCount = arguments.length;\n\n\t\tif (passedArgsCount < 2) {\n\t\t\t\n\t\t\timplementation = args[0];\n\t\t\tdependencies = ['module', 'exports'];\n\t\t\tconfig.anonymous = true;\n\t\t} else if (passedArgsCount === 2) {\n\t\t\tif (typeof name === 'string') {\n\t\t\t\t\n\t\t\t\t// there are two parameters, but the first one is not an array with dependencies,\n\t\t\t\t// this is a module name\n\t\t\t\tdependencies = ['module', 'exports'];\n\t\t\t\timplementation = args[1];\n\t\t\t} else {\n\t\t\t\t\n\t\t\t\tdependencies = args[0];\n\t\t\t\timplementation = args[1];\n\t\t\t\tconfig.anonymous = true;\n\t\t\t}\n\t\t}\n\t\t/* eslint-enable prefer-rest-params */\n\n\t\tif (config.anonymous) {\n\t\t\t// Postpone module's registration till the next scriptLoaded event\n\t\t\tconst onScriptLoaded = loadedModules => {\n\t\t\t\tthis.off('scriptLoaded', onScriptLoaded);\n\n\t\t\t\tif (loadedModules.length !== 1) {\n\t\t\t\t\tthis._reportMismatchedAnonymousModules(\n\t\t\t\t\t\timplementation.toString()\n\t\t\t\t\t);\n\t\t\t\t} else {\n\t\t\t\t\tlet moduleName = loadedModules[0];\n\t\t\t\t\tlet module = this.getModules()[moduleName];\n\n\t\t\t\t\tif (module && module.pendingImplementation) {\n\t\t\t\t\t\tthis._reportMismatchedAnonymousModules(\n\t\t\t\t\t\t\timplementation.toString()\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\n\t\t\t\t\tthis._define(\n\t\t\t\t\t\tmoduleName,\n\t\t\t\t\t\tdependencies,\n\t\t\t\t\t\timplementation,\n\t\t\t\t\t\tconfig\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t};\n\n\t\t\tthis.on('scriptLoaded', onScriptLoaded);\n\t\t} else {\n\t\t\t// This is not an anonymous module, go directly to module's\n\t\t\t// registration flow\n\t\t\tthis._define(name, dependencies, implementation, config);\n\t\t}\n\t}\n\n\t/**\n\t * Returns list of currently registered conditional modules.\n\t *\n\t * @memberof! Loader#\n\t * @return {array} List of currently registered conditional modules.\n\t */\n\tgetConditionalModules() {\n\t\treturn this._getConfigParser().getConditionalModules();\n\t}\n\n\t/**\n\t * Returns list of currently registered modules.\n\t *\n\t * @memberof! Loader#\n\t * @return {array} List of currently registered modules.\n\t */\n\tgetModules() {\n\t\treturn this._getConfigParser().getModules();\n\t}\n\n\t/**\n\t * Requires list of modules. If a module is not yet registered, it will be\n\t * ignored and its implementation in the provided success callback will be\n\t * left undefined.\n\t *\n\t * @memberof! Loader#\n\t * @param {array|string[]} modules Modules can be specified as an array of\n\t * \t\t\t\t\t\t\t\t\tstrings or provided as multiple string\n\t * \t\t\t\t\t\t\t\t\tparameters.\n\t * @param {function} success Callback, which will be invoked in case of\n\t * \t\t\t\t\t\t\t\tsuccess. The provided parameters will be\n\t * \t\t\t\t\t\t\t\timplementations of all required modules.\n\t * @param {function} failure Callback, which will be invoked in case of\n\t * \t\t\t\t\t\t\t\tfailure. One parameter with information\n\t * \t\t\t\t\t\t\t\tabout the error will be provided.\n\t */\n\trequire(...args) {\n\t\t\n\n\t\tconst {\n\t\t\tmodules,\n\t\t\tsuccessCallback,\n\t\t\tfailureCallback,\n\t\t} = this._normalizeRequireArgs(args);\n\n\t\t\n\n\t\tconst configParser = this._getConfigParser();\n\t\tconst mappedModules = configParser.mapModule(modules);\n\n\t\t\n\n\t\tlet rejectTimeout;\n\n\t\tnew Promise((resolve, reject) => {\n\t\t\tthis._resolveDependencies(mappedModules).then(dependencies => {\n\t\t\t\t\n\n\t\t\t\tthis._log(\n\t\t\t\t\t'Resolved modules:',\n\t\t\t\t\tmappedModules,\n\t\t\t\t\t'to:',\n\t\t\t\t\tdependencies\n\t\t\t\t);\n\n\t\t\t\tconst resolutionError = this._getResolutionError(dependencies);\n\n\t\t\t\tif (resolutionError) {\n\t\t\t\t\treject(resolutionError);\n\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\trejectTimeout = this._setRejectTimeout(\n\t\t\t\t\tmodules,\n\t\t\t\t\tmappedModules,\n\t\t\t\t\tdependencies,\n\t\t\t\t\treject\n\t\t\t\t);\n\n\t\t\t\tthis._loadModules(dependencies).then(resolve, reject);\n\t\t\t}, reject);\n\t\t}).then(\n\t\t\t() => {\n\t\t\t\t\n\t\t\t\tclearTimeout(rejectTimeout);\n\n\t\t\t\t/* istanbul ignore else */\n\t\t\t\tif (successCallback) {\n\t\t\t\t\tlet moduleImplementations;\n\n\t\t\t\t\tmoduleImplementations = this._getModuleImplementations(\n\t\t\t\t\t\tmappedModules\n\t\t\t\t\t);\n\n\t\t\t\t\tsuccessCallback.apply(\n\t\t\t\t\t\tsuccessCallback,\n\t\t\t\t\t\tmoduleImplementations\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t},\n\t\t\terror => {\n\t\t\t\t\n\t\t\t\tclearTimeout(rejectTimeout);\n\n\t\t\t\t/* istanbul ignore else */\n\t\t\t\tif (failureCallback) {\n\t\t\t\t\tfailureCallback.call(failureCallback, error);\n\t\t\t\t} else {\n\t\t\t\t\tthis._error(\n\t\t\t\t\t\t'Unhandled failure:',\n\t\t\t\t\t\terror,\n\t\t\t\t\t\t'while resolving modules:',\n\t\t\t\t\t\tmappedModules\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\t);\n\t}\n\n\t/**\n\t * Extract the three nominal arguments (modules, successCallback, and\n\t * failureCallback) of a require call from the arguments array.\n\t * @param {Array} args the arguments array of the require call\n\t * @return {Object} an object with three fields: modules, successCallback,\n\t * \t\t\t\t\tand failureCallback,\n\t */\n\t_normalizeRequireArgs(args) {\n\t\tlet modules;\n\t\tlet successCallback;\n\t\tlet failureCallback;\n\n\t\t// Modules can be specified by as an array, or just as parameters to the\n\t\t// function. We do not slice or leak arguments to not cause V8\n\t\t// performance penalties.\n\t\tif (Array.isArray(args[0])) {\n\t\t\tmodules = args[0];\n\t\t\tsuccessCallback = typeof args[1] === 'function' ? args[1] : null;\n\t\t\tfailureCallback = typeof args[2] === 'function' ? args[2] : null;\n\t\t} else {\n\t\t\tmodules = [];\n\n\t\t\tfor (let i = 0; i < args.length; ++i) {\n\t\t\t\tif (typeof args[i] === 'string') {\n\t\t\t\t\tmodules[i] = args[i];\n\n\t\t\t\t\t/* istanbul ignore else */\n\t\t\t\t} else if (typeof args[i] === 'function') {\n\t\t\t\t\tsuccessCallback = args[i];\n\t\t\t\t\tfailureCallback =\n\t\t\t\t\t\ttypeof args[++i] === 'function'\n\t\t\t\t\t\t\t? args[i]\n\t\t\t\t\t\t\t: /* istanbul ignore next */ null;\n\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn {\n\t\t\tmodules,\n\t\t\tsuccessCallback,\n\t\t\tfailureCallback,\n\t\t};\n\t}\n\n\t/**\n\t * Traverse a resolved dependencies array looking for server sent errors and\n\t * return an Error if any is found.\n\t * @param {Array} dependencies the resolved dependencies\n\t * @return {Error} a detailed Error or null if no errors were found\n\t */\n\t_getResolutionError(dependencies) {\n\t\tconst dependencyErrors = dependencies\n\t\t\t.filter(dep => dep.indexOf(':ERROR:') === 0)\n\t\t\t.map(dep => dep.substr(7));\n\n\t\tif (dependencyErrors.length > 0) {\n\t\t\treturn new Error(\n\t\t\t\t'The following problems where detected while ' +\n\t\t\t\t\t'resolving modules:\\n' +\n\t\t\t\t\tdependencyErrors.join('\\n')\n\t\t\t);\n\t\t}\n\n\t\treturn null;\n\t}\n\n\t/**\n\t * Set a timeout (only if allowed by configuration) to reject a Promise if\n\t * a certain set of modules has not been successfully loaded.\n\t * @param {Array} modules the modules to be loaded\n\t * @param {Array} mappedModules the modules after successful mapping\n\t * @param {Array} dependencies the dependencies of the modules\n\t * @param {function} reject the promise reject function\n\t * @return {int} a timeout id or undefined if configuration disabled timeout\n\t */\n\t_setRejectTimeout(modules, mappedModules, dependencies, reject) {\n\t\tconst configParser = this._getConfigParser();\n\t\tconst config = configParser.getConfig();\n\n\t\tlet rejectTimeout;\n\n\t\t// Establish a load timeout and reject the Promise in case\n\t\t// of Error\n\t\tif (config.waitTimeout !== 0) {\n\t\t\trejectTimeout = setTimeout(() => {\n\t\t\t\tconst registeredModules = configParser.getModules();\n\n\t\t\t\tlet error = new Error('Load timeout for modules: ' + modules);\n\n\t\t\t\terror.modules = modules;\n\t\t\t\terror.mappedModules = mappedModules;\n\t\t\t\terror.dependencies = dependencies;\n\n\t\t\t\tlet filteredDeps;\n\n\t\t\t\tfilteredDeps = dependencies.filter(\n\t\t\t\t\tdep =>\n\t\t\t\t\t\ttypeof registeredModules[dep].implementation ===\n\t\t\t\t\t\t'undefined'\n\t\t\t\t);\n\t\t\t\terror.missingDependencies = filteredDeps;\n\n\t\t\t\tfilteredDeps = error.missingDependencies.filter(\n\t\t\t\t\tdep =>\n\t\t\t\t\t\ttypeof registeredModules[dep].pendingImplementation !==\n\t\t\t\t\t\t'undefined'\n\t\t\t\t);\n\t\t\t\terror.fetchedMissingDependencies = filteredDeps;\n\n\t\t\t\tfilteredDeps = error.missingDependencies.filter(\n\t\t\t\t\tdep =>\n\t\t\t\t\t\ttypeof registeredModules[dep].pendingImplementation ===\n\t\t\t\t\t\t'undefined'\n\t\t\t\t);\n\t\t\t\terror.unfetchedMissingDependencies = filteredDeps;\n\n\t\t\t\t// @deprecated: fill `dependecies` field to maintain\n\t\t\t\t// backward compatibility\n\t\t\t\terror.dependecies = error.dependencies;\n\n\t\t\t\t\n\t\t\t\treject(error);\n\t\t\t}, config.waitTimeout || 7000);\n\t\t}\n\n\t\treturn rejectTimeout;\n\t}\n\n\t/**\n\t * Creates Promise for module. It will be resolved as soon as module is\n\t * being loaded from server.\n\t *\n\t * @memberof! Loader#\n\t * @protected\n\t * @param {string} moduleName The name of module for which Promise should\n\t * \t\t\t\t\t\tbe created.\n\t * @return {Promise} Promise, which will be resolved as soon as the\n\t * \t\t\t\t\t\trequested module is being loaded.\n\t */\n\t_createModulePromise(moduleName) {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tlet registeredModules = this._getConfigParser().getModules();\n\n\t\t\t// Check if this is a module, which exports something\n\t\t\t// If so, check if the exported value is available\n\t\t\tlet module = registeredModules[moduleName];\n\n\t\t\tif (module.exports) {\n\t\t\t\tlet exportedValue = this._getValueGlobalNS(module.exports);\n\n\t\t\t\tif (exportedValue) {\n\t\t\t\t\tresolve(exportedValue);\n\t\t\t\t} else {\n\t\t\t\t\tconst onScriptLoaded = loadedModules => {\n\t\t\t\t\t\tif (loadedModules.indexOf(moduleName) >= 0) {\n\t\t\t\t\t\t\tthis.off('scriptLoaded', onScriptLoaded);\n\n\t\t\t\t\t\t\tlet exportedValue = this._getValueGlobalNS(\n\t\t\t\t\t\t\t\tmodule.exports\n\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\tif (exportedValue) {\n\t\t\t\t\t\t\t\tresolve(exportedValue);\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\treject(\n\t\t\t\t\t\t\t\t\tnew Error(\n\t\t\t\t\t\t\t\t\t\t'Module ' +\n\t\t\t\t\t\t\t\t\t\t\tmoduleName +\n\t\t\t\t\t\t\t\t\t\t\t' does not export the specified value: ' +\n\t\t\t\t\t\t\t\t\t\t\tmodule.exports\n\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\n\t\t\t\t\tthis.on('scriptLoaded', onScriptLoaded);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tconst onModuleRegister = registeredModuleName => {\n\t\t\t\t\tif (registeredModuleName === moduleName) {\n\t\t\t\t\t\tthis.off('moduleRegister', onModuleRegister);\n\n\t\t\t\t\t\t// Overwrite the promise entry in the modules map with a simple `true` value.\n\t\t\t\t\t\t// Hopefully GC will remove this promise from the memory.\n\t\t\t\t\t\tthis._modulesMap[moduleName] = true;\n\n\t\t\t\t\t\tresolve(moduleName);\n\t\t\t\t\t}\n\t\t\t\t};\n\n\t\t\t\tthis.on('moduleRegister', onModuleRegister);\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Defines a module in the system and fires\n\t * {@link Loader#event:moduleRegister} event with the registered module as\n\t * param. Called internally by {@link Loader#define} method once it\n\t * normalizes the passed arguments.\n\t *\n\t * @memberof! Loader#\n\t * @protected\n\t * @param {string} name The name of the module.\n\t * @param {array} dependencies List of module dependencies.\n\t * @param {function} implementation The implementation of the module.\n\t * @param {object=} config See {@link Loader:define} for more details.\n\t */\n\t_define(name, dependencies, implementation, config) {\n\t\t// Create a new module by merging the provided config with the passed\n\t\t// name, dependencies and implementation.\n\t\tlet module = config || {};\n\t\tlet configParser = this._getConfigParser();\n\n\t\tif (configParser.getConfig().ignoreModuleVersion) {\n\t\t\tlet nameParts = name.split('/');\n\t\t\tlet packageParts = nameParts[0].split('@');\n\n\t\t\tnameParts[0] = packageParts[0];\n\n\t\t\tname = nameParts.join('/');\n\t\t}\n\n\t\tlet pathResolver = this._getPathResolver();\n\n\t\t// Resolve the path according to the parent module. Example:\n\t\t// \tdefine('metal/src/component/component', ['../array/array'])\n\t\t// will become:\n\t\t// \tdefine('metal/src/component/component', ['metal/src/array/array'])\n\t\tdependencies = dependencies.map(dependency =>\n\t\t\tpathResolver.resolvePath(name, dependency)\n\t\t);\n\n\t\tmodule.name = name;\n\t\tmodule.dependencies = dependencies;\n\t\tmodule.pendingImplementation = implementation;\n\n\t\tconfigParser.addModule(module);\n\n\t\tif (!this._modulesMap[module.name]) {\n\t\t\tthis._modulesMap[module.name] = true;\n\t\t}\n\n\t\tthis.emit('moduleRegister', name);\n\t}\n\n\t/**\n\t * Returns instance of {@link ConfigParser} class.\n\t *\n\t * @memberof! Loader#\n\t * @protected\n\t * @return {ConfigParser} Instance of {@link ConfigParser} class.\n\t */\n\t_getConfigParser() {\n\t\t/* istanbul ignore else */\n\t\tif (!this._configParser) {\n\t\t\tthis._configParser = new ConfigParser(this._config);\n\t\t}\n\n\t\treturn this._configParser;\n\t}\n\n\t/**\n\t * Returns instance of {@link DependencyBuilder} class.\n\t *\n\t * @memberof! Loader#\n\t * @protected\n\t * @return {DependencyBuilder} Instance of {@link DependencyBuilder} class.\n\t */\n\t_getDependencyBuilder() {\n\t\tif (!this._dependencyBuilder) {\n\t\t\tthis._dependencyBuilder = new DependencyBuilder(\n\t\t\t\tthis._getConfigParser()\n\t\t\t);\n\t\t}\n\n\t\treturn this._dependencyBuilder;\n\t}\n\n\t/**\n\t * Retrieves a value from the global namespace.\n\t *\n\t * @memberof! Loader#\n\t * @protected\n\t * @param {String} exports The key which should be used to retrieve the\n\t * \t\t\t\t\t\t\tvalue.\n\t * @return {Any} The retrieved value.\n\t */\n\t_getValueGlobalNS(exports) {\n\t\tlet exportVariables = exports.split('.');\n\n\t\tlet tmpVal = (0, eval)('this')[exportVariables[0]];\n\n\t\tfor (let i = 1; tmpVal && i < exportVariables.length; i++) {\n\t\t\tif (\n\t\t\t\tObject.prototype.hasOwnProperty.call(tmpVal, exportVariables[i])\n\t\t\t) {\n\t\t\t\ttmpVal = tmpVal[exportVariables[i]];\n\t\t\t} else {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t}\n\n\t\treturn tmpVal;\n\t}\n\n\t/**\n\t * Returns an array of all missing dependencies of the passed modules.\n\t * A missing dependency is a dependency, which does not have pending\n\t * implementation yet.\n\t *\n\t * @memberof! Loader#\n\t * @protected\n\t * @param {array} moduleNames List of module names to be checked for missing\n\t * \t\t\t\t\t\t\t\tdependencies.\n\t * @return {Array} A list with all missing dependencies.\n\t */\n\t_getMissingDependencies(moduleNames) {\n\t\tlet configParser = this._getConfigParser();\n\t\tlet registeredModules = configParser.getModules();\n\n\t\tlet missingDependencies = Object.create(null);\n\n\t\tfor (let i = 0; i < moduleNames.length; i++) {\n\t\t\tlet module = registeredModules[moduleNames[i]];\n\n\t\t\tlet mappedDependencies = configParser.mapModule(\n\t\t\t\tmodule.dependencies,\n\t\t\t\tmodule.map\n\t\t\t);\n\n\t\t\tfor (let j = 0; j < mappedDependencies.length; j++) {\n\t\t\t\tlet dependency = mappedDependencies[j];\n\n\t\t\t\tlet dependencyModule = registeredModules[dependency];\n\n\t\t\t\tif (\n\t\t\t\t\tdependency !== 'require' &&\n\t\t\t\t\tdependency !== 'exports' &&\n\t\t\t\t\tdependency !== 'module' &&\n\t\t\t\t\t(!dependencyModule ||\n\t\t\t\t\t\t!dependencyModule.pendingImplementation)\n\t\t\t\t) {\n\t\t\t\t\tmissingDependencies[dependency] = 1;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn Object.keys(missingDependencies);\n\t}\n\n\t/**\n\t * Retrieves module implementations to an array.\n\t *\n\t * @memberof! Loader#\n\t * @protected\n\t * @param {array} requiredModules List of modules, which implementations\n\t * \t\t\t\t\twill be added to an array.\n\t * @return {array} List of modules implementations.\n\t */\n\t_getModuleImplementations(requiredModules) {\n\t\tlet moduleImplementations = [];\n\n\t\tlet modules = this._getConfigParser().getModules();\n\n\t\tfor (let i = 0; i < requiredModules.length; i++) {\n\t\t\tlet requiredModule = modules[requiredModules[i]];\n\n\t\t\tmoduleImplementations.push(\n\t\t\t\trequiredModule ? requiredModule.implementation : undefined\n\t\t\t);\n\t\t}\n\n\t\treturn moduleImplementations;\n\t}\n\n\t/**\n\t * Returns an instance of {@link PathResolver} class.\n\t *\n\t * @memberof! Loader#\n\t * @protected\n\t * @return {PathResolver} Instance of {@link PathResolver} class.\n\t */\n\t_getPathResolver() {\n\t\tif (!this._pathResolver) {\n\t\t\tthis._pathResolver = new PathResolver();\n\t\t}\n\n\t\treturn this._pathResolver;\n\t}\n\n\t/**\n\t * Returns instance of {@link URLBuilder} class.\n\t *\n\t * @memberof! Loader#\n\t * @protected\n\t * @return {URLBuilder} Instance of {@link URLBuilder} class.\n\t */\n\t_getURLBuilder() {\n\t\t/* istanbul ignore else */\n\t\tif (!this._urlBuilder) {\n\t\t\tthis._urlBuilder = new URLBuilder(this._getConfigParser());\n\t\t}\n\n\t\treturn this._urlBuilder;\n\t}\n\n\t/**\n\t * Filters a list of modules and returns only these which don't have any of\n\t * the provided list of properties.\n\t *\n\t * @memberof! Loader#\n\t * @protected\n\t * @param {array} moduleNames List of modules which which have to be\n\t * \t\t\t\t\t\tfiltered.\n\t * @param {string|Array} property The name of the property to filter by.\n\t * @return {array} List of modules matching the specified filter.\n\t */\n\t_filterModulesByProperty(moduleNames, property) {\n\t\tlet properties = property;\n\n\t\tif (typeof property === 'string') {\n\t\t\tproperties = [property];\n\t\t}\n\n\t\tlet missingModules = [];\n\n\t\tlet registeredModules = this._getConfigParser().getModules();\n\n\t\tfor (let i = 0; i < moduleNames.length; i++) {\n\t\t\tlet moduleName = moduleNames[i];\n\n\t\t\tlet registeredModule = registeredModules[moduleNames[i]];\n\n\t\t\tif (!registeredModule) {\n\t\t\t\tmissingModules.push(moduleName);\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\t// We exclude \"require\", \"exports\" and \"module\" modules, which are\n\t\t\t// part of AMD spec.\n\t\t\tif (\n\t\t\t\tregisteredModule === 'require' ||\n\t\t\t\tregisteredModule === 'exports' ||\n\t\t\t\tregisteredModule === 'module'\n\t\t\t) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tlet found = false;\n\n\t\t\tfor (let j = 0; j < properties.length; j++) {\n\t\t\t\tif (registeredModule[properties[j]]) {\n\t\t\t\t\tfound = true;\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (!found) {\n\t\t\t\tmissingModules.push(moduleName);\n\t\t\t}\n\t\t}\n\n\t\treturn missingModules;\n\t}\n\n\t/**\n\t * Loads list of modules.\n\t *\n\t * @memberof! Loader#\n\t * @protected\n\t * @param {array} moduleNames List of modules to be loaded.\n\t * @return {Promise} Promise, which will be resolved as soon as all module a\n\t * \t\t\t\t\t\tbeing loaded.\n\t */\n\t_loadModules(moduleNames) {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\t// Get all modules without pending implementation or not yet\n\t\t\t// requested\n\t\t\tlet modulesForLoading = this._filterModulesByProperty(moduleNames, [\n\t\t\t\t'requested',\n\t\t\t\t'pendingImplementation',\n\t\t\t]);\n\n\t\t\tif (modulesForLoading.length) {\n\t\t\t\t// If there are modules, which have to be loaded, construct\n\t\t\t\t// their URLs\n\t\t\t\tlet modulesURL = this._getURLBuilder().build(modulesForLoading);\n\n\t\t\t\tlet pendingScripts = [];\n\n\t\t\t\t// Create promises for each of the scripts, which should be\n\t\t\t\t// loaded\n\t\t\t\tfor (let i = 0; i < modulesURL.length; i++) {\n\t\t\t\t\tpendingScripts.push(this._loadScript(modulesURL[i]));\n\t\t\t\t}\n\n\t\t\t\t// Wait for resolving all script Promises\n\t\t\t\t// As soon as that happens, wait for each module to define\n\t\t\t\t// itself\n\n\t\t\t\t\n\t\t\t\tPromise.all(pendingScripts)\n\t\t\t\t\t.then(() => this._waitForModules(moduleNames))\n\t\t\t\t\t// As soon as all scripts were loaded and all dependencies\n\t\t\t\t\t// have been resolved, resolve the main Promise\n\t\t\t\t\t.then(resolve)\n\t\t\t\t\t// If any script fails to load or other error happens,\n\t\t\t\t\t// reject the main Promise\n\t\t\t\t\t.catch(reject);\n\t\t\t} else {\n\t\t\t\t// If there are no any missing modules, just wait for modules dependencies\n\t\t\t\t// to be resolved and then resolve the main promise\n\t\t\t\tthis._waitForModules(moduleNames)\n\t\t\t\t\t.then(resolve)\n\t\t\t\t\t// If some error happens, for example if some module implementation\n\t\t\t\t\t// throws error, reject the main Promise\n\t\t\t\t\t.catch(reject);\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Loads a script element on the page.\n\t *\n\t * @memberof! Loader#\n\t * @protected\n\t * @param {object} modulesURL An Object with two properties:\n\t * - modules - List of the modules which should be loaded\n\t * - url - The URL from which the modules should be loaded\n\t * @return {Promise} Promise which will be resolved as soon as the script is being loaded.\n\t */\n\t_loadScript(modulesURL) {\n\t\tlet self = this;\n\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tlet script = this._document.createElement('script');\n\n\t\t\tscript.src = modulesURL.url;\n\t\t\tscript.async = false;\n\n\t\t\t// On ready state change is needed for IE < 9, not sure if that is needed anymore,\n\t\t\t// it depends which browsers will we support at the end\n\t\t\tscript.onload = script.onreadystatechange = function() {\n\t\t\t\t/* istanbul ignore else */\n\t\t\t\tif (\n\t\t\t\t\t!this.readyState ||\n\t\t\t\t\t/* istanbul ignore next */ this.readyState === 'complete' ||\n\t\t\t\t\t/* istanbul ignore next */ this.readyState === 'load'\n\t\t\t\t) {\n\t\t\t\t\tscript.onload = script.onreadystatechange = null;\n\n\t\t\t\t\tresolve(script);\n\n\t\t\t\t\tself.emit('scriptLoaded', modulesURL.modules);\n\t\t\t\t}\n\t\t\t};\n\n\t\t\t// If some script fails to load, reject the main Promise\n\t\t\tscript.onerror = () => {\n\t\t\t\tthis._document.head.removeChild(script);\n\n\t\t\t\treject(script);\n\t\t\t};\n\n\t\t\tthis._document.head.appendChild(script);\n\t\t});\n\t}\n\n\t/**\n\t * Show a message in console if the explainResolutions option is active.\n\t *\n\t * @param {Array} msgs the objects to be printed\n\t * @return {void}\n\t */\n\t_log(...msgs) {\n\t\tlet aliasedConsole = console;\n\t\tlet args = arguments.length === 1 ? [msgs[0]] : Array(...msgs);\n\t\tlet config = this._getConfigParser().getConfig();\n\n\t\tif (config.explainResolutions) {\n\t\t\taliased\n\t\t}\n\t}\n\n\t/**\n\t * Report errors to the console even in non-debug versions of the loader.\n\t *\n\t * @param {Array} msgs the objects to be printed\n\t * @return {void}\n\t */\n\t_error(...msgs) {\n\t\tlet aliasedConsole = console;\n\t\tlet args = msgs.length === 1 ? [msgs[0]] : Array(...msgs);\n\n\t\taliased\n\t}\n\n\t/**\n\t * Resolves modules dependencies.\n\t *\n\t * @memberof! Loader#\n\t * @protected\n\t * @param {array} modules List of modules which dependencies should be resolved.\n\t * @return {Promise} Promise which will be resolved as soon as all dependencies are being resolved.\n\t */\n\t_resolveDependencies(modules) {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\ttry {\n\t\t\t\tconst dependencyBuilder = this._getDependencyBuilder();\n\n\t\t\t\tresolve(dependencyBuilder.resolveDependencies(modules));\n\t\t\t} catch (error) {\n\t\t\t\treject(error);\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Reports a mismatched anonymous module error. Depending on the value of the configuration property\n\t * `__CONFIG__.reportMismatchedAnonymousModules`, this method will throw an error, use the console[level]\n\t * method to log the message or silently ignore it.\n\t *\n\t * @memberof! Loader#\n\t * @protected\n\t * @param {string} msg Additional information to log with the error.\n\t */\n\t_reportMismatchedAnonymousModules(msg) {\n\t\tlet errorMessage = 'Mismatched anonymous define() module: ' + msg;\n\t\tlet reportLevel = this._config.reportMismatchedAnonymousModules;\n\n\t\tif (!reportLevel || reportLevel === 'exception') {\n\t\t\tthrow new Error(errorMessage);\n\t\t} else if (console && console[reportLevel]) {\n\t\t\t// Call console's method by using the `call` function\n\t\t\t// to prevent stripDebug to remove the statement in production\n\t\t\tconsole[reportLevel].call(console, errorMessage);\n\t\t}\n\t}\n\n\t/**\n\t * Invokes the implementation method of list of modules passing the implementations of its dependencies.\n\t *\n\t * @memberof! Loader#\n\t * @protected\n\t * @param {array} modules List of modules to which implementation should be set.\n\t */\n\t_setModuleImplementation(modules) {\n\t\tlet registeredModules = this._getConfigParser().getModules();\n\n\t\tfor (let i = 0; i < modules.length; i++) {\n\t\t\tlet module = modules[i];\n\n\t\t\tif (typeof module.implementation !== 'undefined') {\n\t\t\t\tcontinue;\n\t\t\t} else if (typeof module.exports !== 'undefined') {\n\t\t\t\tmodule.implementation = this._getValueGlobalNS(module.exports);\n\t\t\t\tmodule.pendingImplementation = module.implementation;\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tlet dependencyImplementations = [];\n\n\t\t\t// Leave exports implementation to be {} by default\n\t\t\tlet moduleImpl = {exports: {}};\n\t\t\tlet configParser = this._getConfigParser();\n\n\t\t\tfor (let j = 0; j < module.dependencies.length; j++) {\n\t\t\t\tlet dependency = module.dependencies[j];\n\n\t\t\t\t// If the current dependency of this module is 'exports',\n\t\t\t\t// create an empty object and pass it as implementation of\n\t\t\t\t// 'exports' module\n\t\t\t\tif (dependency === 'exports') {\n\t\t\t\t\tdependencyImplementations.push(moduleImpl.exports);\n\t\t\t\t} else if (dependency === 'module') {\n\t\t\t\t\tdependencyImplementations.push(moduleImpl);\n\t\t\t\t} else if (dependency === 'require') {\n\t\t\t\t\tlet localRequire = this._createLocalRequire(module);\n\n\t\t\t\t\tlocalRequire.toUrl = moduleName => {\n\t\t\t\t\t\tlet moduleURLs = this._getURLBuilder().build([\n\t\t\t\t\t\t\tmoduleName,\n\t\t\t\t\t\t]);\n\n\t\t\t\t\t\treturn moduleURLs[0].url;\n\t\t\t\t\t};\n\n\t\t\t\t\tdependencyImplementations.push(localRequire);\n\t\t\t\t} else {\n\t\t\t\t\t// otherwise set as value the implementation of the registered module\n\t\t\t\t\tlet dependencyModule =\n\t\t\t\t\t\tregisteredModules[\n\t\t\t\t\t\t\tconfigParser.mapModule(dependency, module.map)\n\t\t\t\t\t\t];\n\n\t\t\t\t\tlet impl = dependencyModule.implementation;\n\n\t\t\t\t\tdependencyImplementations.push(impl);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tlet result;\n\n\t\t\tif (typeof module.pendingImplementation === 'function') {\n\t\t\t\tresult = module.pendingImplementation.apply(\n\t\t\t\t\tmodule.pendingImplementation,\n\t\t\t\t\tdependencyImplementations\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\tresult = module.pendingImplementation;\n\t\t\t}\n\n\t\t\t// Store as implementation either the returned value from the\n\t\t\t// function's invocation, or the value inside module.exports magic\n\t\t\t// dependency.\n\t\t\t//\n\t\t\t// The final implementation of this module may be {} if there is no\n\t\t\t// returned value, or the object does not assign anything to\n\t\t\t// module.exports.\n\t\t\tif (typeof result !== 'undefined') {\n\t\t\t\tmodule.implementation = result;\n\t\t\t} else {\n\t\t\t\tmodule.implementation = moduleImpl.exports;\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Create a function implementing the local require method of the AMD specification.\n\t * @param {Object} module a module descriptor\n\t * @return {function} the local require implementation for the given module\n\t */\n\t_createLocalRequire(module) {\n\t\tlet configParser = this._getConfigParser();\n\t\tlet pathResolver = this._getPathResolver();\n\n\t\treturn (moduleName, ...rest) => {\n\t\t\tif (rest.length > 0) {\n\t\t\t\treturn this.require(moduleName, ...rest);\n\t\t\t} else {\n\t\t\t\tmoduleName = pathResolver.resolvePath(module.name, moduleName);\n\n\t\t\t\tmoduleName = configParser.mapModule(moduleName, module.map);\n\n\t\t\t\tlet dependencyModule = configParser.getModules()[moduleName];\n\n\t\t\t\tif (\n\t\t\t\t\t!dependencyModule ||\n\t\t\t\t\t!('implementation' in dependencyModule)\n\t\t\t\t) {\n\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t'Module \"' +\n\t\t\t\t\t\t\tmoduleName +\n\t\t\t\t\t\t\t'\" has not been loaded yet for context: ' +\n\t\t\t\t\t\t\tmodule.name\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\treturn dependencyModule.implementation;\n\t\t\t}\n\t\t};\n\t}\n\n\t/**\n\t * Resolves a Promise as soon as all module dependencies are being resolved or it has implementation already.\n\t *\n\t * @memberof! Loader#\n\t * @protected\n\t * @param {Object} moduleName The module for which this function should wait.\n\t * @return {Promise}\n\t */\n\t_waitForModule(moduleName) {\n\t\t// Check if there is already a promise for this module.\n\t\t// If there is not - create one and store it to module promises map.\n\t\tlet modulePromise = this._modulesMap[moduleName];\n\n\t\tif (!modulePromise) {\n\t\t\tmodulePromise = this._createModulePromise(moduleName);\n\n\t\t\tthis._modulesMap[moduleName] = modulePromise;\n\t\t}\n\n\t\treturn modulePromise;\n\t}\n\n\t/**\n\t * Resolves a Promise as soon as all dependencies of all provided modules are being resolved and modules have\n\t * implementations.\n\t *\n\t * @memberof! Loader#\n\t * @protected\n\t * @param {array} moduleNames List of modules for which implementations this function should wait.\n\t * @return {Promise}\n\t */\n\t_waitForModules(moduleNames) {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tlet modulesPromises = [];\n\n\t\t\tfor (let i = 0; i < moduleNames.length; i++) {\n\t\t\t\tmodulesPromises.push(this._waitForModule(moduleNames[i]));\n\t\t\t}\n\n\t\t\t// Wait until all modules were loaded and their Promises resolved\n\t\t\tPromise.all(modulesPromises).then(() => {\n\t\t\t\t// The modules were loaded. However, we have to check their dependencies\n\t\t\t\t// one more time, because some dependencies might have not been registered in the configuration.\n\t\t\t\t// In this case we have to load them too, otherwise we won't be able to properly\n\t\t\t\t// get the implementation from the module.\n\t\t\t\tlet registeredModules = this._getConfigParser().getModules();\n\n\t\t\t\tlet defineModules = () => {\n\t\t\t\t\tlet definedModules = [];\n\n\t\t\t\t\tfor (let i = 0; i < moduleNames.length; i++) {\n\t\t\t\t\t\tdefinedModules.push(registeredModules[moduleNames[i]]);\n\t\t\t\t\t}\n\n\t\t\t\t\tthis._setModuleImplementation(definedModules);\n\n\t\t\t\t\tresolve(definedModules);\n\t\t\t\t};\n\n\t\t\t\tlet missingDependencies = this._getMissingDependencies(\n\t\t\t\t\tmoduleNames\n\t\t\t\t);\n\n\t\t\t\tif (missingDependencies.length) {\n\t\t\t\t\t\n\t\t\t\t\tthis.require(missingDependencies, defineModules, reject);\n\t\t\t\t} else {\n\t\t\t\t\tdefineModules();\n\t\t\t\t}\n\t\t\t}, reject);\n\t\t});\n\t}\n\n\t/**\n\t * Indicates that a module has been registered.\n\t *\n\t * @event Loader#moduleRegister\n\t * @param {Object} module - The registered module.\n\t */\n}\n\nLoader.prototype.define.amd = {};\n\n\n\n// WEBPACK FOOTER //\n// ./src/loader/loader.js","/**\n *\n */\nexport default class ConfigParser {\n\t/**\n\t * Creates an instance of ConfigurationParser class.\n\t *\n\t * @constructor\n\t * @param {object=} config - The configuration object to be parsed.\n\t */\n\tconstructor(config) {\n\t\tthis._config = {};\n\t\tthis._modules = {};\n\t\tthis._conditionalModules = {};\n\n\t\tthis._parseConfig(config);\n\t}\n\n\t/**\n\t * Adds a module to the configuration.\n\t *\n\t * @param {object} module The module which should be added to the\n\t * configuration. Should have the following properties:\n\t * \n\t *\n\t * Optional properties:\n\t * The same as those which config parameter of {@link Loader#define}\n\t * method accepts.\n\t * @return {Object} The added module\n\t */\n\taddModule(module) {\n\t\t// Module might be added via configuration or when it arrives from the\n\t\t// server. If it arrives from the server, it will have already a\n\t\t// definition. In this case, we will overwrite the existing properties\n\t\t// with those, provided from the module definition. Otherwise, we will\n\t\t// just add it to the map.\n\t\tconst moduleDefinition = this._modules[module.name];\n\n\t\tif (moduleDefinition) {\n\t\t\tfor (let key in module) {\n\t\t\t\tif (Object.prototype.hasOwnProperty.call(module, key)) {\n\t\t\t\t\tmoduleDefinition[key] = module[key];\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tthis._modules[module.name] = module;\n\t\t}\n\n\t\tthis._registerConditionalModule(module);\n\n\t\treturn this._modules[module.name];\n\t}\n\n\t/**\n\t * Returns the current configuration.\n\t *\n\t * @return {object} The current configuration.\n\t */\n\tgetConfig() {\n\t\treturn this._config;\n\t}\n\n\t/**\n\t * Returns map with all currently registered conditional modules and their\n\t * triggers.\n\t *\n\t * @return {object} Map with all currently registered conditional modules.\n\t */\n\tgetConditionalModules() {\n\t\treturn this._conditionalModules;\n\t}\n\n\t/**\n\t * Returns map with all currently registered modules.\n\t *\n\t * @return {object} Map with all currently registered modules.\n\t */\n\tgetModules() {\n\t\treturn this._modules;\n\t}\n\n\t/**\n\t * Maps module names to their aliases. Example:\n\t * __CONFIG__.maps = {\n\t * liferay: 'liferay@1.0.0'\n\t * }\n\t *\n\t * When someone does require('liferay/html/js/ac.es',...),\n\t * if the module 'liferay/html/js/ac.es' is not defined,\n\t * then a corresponding alias will be searched. If found, the name will be\n\t * replaced, so it will look like user did\n\t * require('liferay@1.0.0/html/js/ac.es',...).\n\t *\n\t * Additionally, modules can define a custom map to alias module names just\n\t * in the context of that module loading operation. When present, the\n\t * contextual module mapping will take precedence over the general one.\n\t *\n\t * @protected\n\t * @param {array|string} module The module which have to be mapped or array\n\t * of modules.\n\t * @param {?object} contextMap Contextual module mapping information\n\t * relevant to the current load operation\n\t * @return {array|string} The mapped module or array of mapped modules.\n\t */\n\tmapModule(module, contextMap) {\n\t\tif (!this._config.maps && !contextMap) {\n\t\t\treturn module;\n\t\t}\n\n\t\tlet modules;\n\n\t\tif (Array.isArray(module)) {\n\t\t\tmodules = module;\n\t\t} else {\n\t\t\tmodules = [module];\n\t\t}\n\n\t\tif (contextMap) {\n\t\t\tmodules = modules.map(this._getModuleMapper(contextMap));\n\t\t}\n\n\t\tif (this._config.maps) {\n\t\t\tmodules = modules.map(this._getModuleMapper(this._config.maps));\n\t\t}\n\n\t\treturn Array.isArray(module) ? modules : modules[0];\n\t}\n\n\t/**\n\t * Creates a function that transforms module names based on a provided\n\t * set of mappings.\n\t *\n\t * @protected\n\t * @param {object} maps Mapping information.\n\t * @return {function} The generated mapper function\n\t */\n\t_getModuleMapper(maps) {\n\t\treturn module => {\n\t\t\tlet match;\n\n\t\t\tmatch = this._mapExactMatch(module, maps);\n\n\t\t\t// Apply partial mapping only if exactMatch hasn't been\n\t\t\t// already applied for this mapping\n\t\t\tif (!match) {\n\t\t\t\tmatch = this._mapPartialMatch(module, maps);\n\t\t\t}\n\n\t\t\t// Apply * mapping only if neither exactMatch nor\n\t\t\t// partialMatch have been already applied for this mapping\n\t\t\tif (!match) {\n\t\t\t\tmatch = this._mapWildcardMatch(module, maps);\n\t\t\t}\n\n\t\t\treturn match || module;\n\t\t};\n\t}\n\n\t/**\n\t * Transforms a module name using the exactMatch mappings\n\t * in a provided mapping object.\n\t *\n\t * @protected\n\t * @param {string} module The module which have to be mapped.\n\t * @param {object} maps Mapping information.\n\t * @return {object} An object with a boolean `matched` field and a string\n\t * `result` field containing the mapped module name\n\t */\n\t_mapExactMatch(module, maps) {\n\t\tfor (let alias in maps) {\n\t\t\t/* istanbul ignore else */\n\t\t\tif (Object.prototype.hasOwnProperty.call(maps, alias)) {\n\t\t\t\tconst aliasValue = maps[alias];\n\n\t\t\t\tif (aliasValue.value && aliasValue.exactMatch) {\n\t\t\t\t\tif (module === alias) {\n\t\t\t\t\t\treturn aliasValue.value;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Transforms a module name using the partial mappings\n\t * in a provided mapping object.\n\t *\n\t * @protected\n\t * @param {string} module The module which have to be mapped.\n\t * @param {object} maps Mapping information.\n\t * @return {object} An object with a boolean `matched` field and a string\n\t * `result` field containing the mapped module name\n\t */\n\t_mapPartialMatch(module, maps) {\n\t\tfor (let alias in maps) {\n\t\t\t/* istanbul ignore else */\n\t\t\tif (Object.prototype.hasOwnProperty.call(maps, alias)) {\n\t\t\t\tlet aliasValue = maps[alias];\n\n\t\t\t\tif (!aliasValue.exactMatch) {\n\t\t\t\t\tif (aliasValue.value) {\n\t\t\t\t\t\taliasValue = aliasValue.value;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (module === alias || module.indexOf(alias + '/') === 0) {\n\t\t\t\t\t\treturn aliasValue + module.substring(alias.length);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Transforms a module name using the wildcard mapping in a provided mapping\n\t * object.\n\t *\n\t * @protected\n\t * @param {string} module The module which have to be mapped.\n\t * @param {object} maps Mapping information.\n\t * @return {object} An object with a boolean `matched` field and a string\n\t * `result` field containing the mapped module name\n\t */\n\t_mapWildcardMatch(module, maps) {\n\t\tif (typeof maps['*'] === 'function') {\n\t\t\treturn maps['*'](module);\n\t\t}\n\t}\n\n\t/**\n\t * Parses configuration object.\n\t *\n\t * @protected\n\t * @param {object} config Configuration object to be parsed.\n\t * @return {object} The created configuration\n\t */\n\t_parseConfig(config) {\n\t\tfor (let key in config) {\n\t\t\t/* istanbul ignore else */\n\t\t\tif (Object.prototype.hasOwnProperty.call(config, key)) {\n\t\t\t\tif (key === 'modules') {\n\t\t\t\t\tthis._parseModules(config[key]);\n\t\t\t\t} else {\n\t\t\t\t\tthis._config[key] = config[key];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn this._config;\n\t}\n\n\t/**\n\t * Parses a provided modules configuration.\n\t *\n\t * @protected\n\t * @param {object} modules Map of modules to be parsed.\n\t * @return {object} Map of parsed modules.\n\t */\n\t_parseModules(modules) {\n\t\tfor (let key in modules) {\n\t\t\t/* istanbul ignore else */\n\t\t\tif (Object.prototype.hasOwnProperty.call(modules, key)) {\n\t\t\t\tlet module = modules[key];\n\n\t\t\t\tmodule.name = key;\n\n\t\t\t\tthis.addModule(module);\n\t\t\t}\n\t\t}\n\n\t\treturn this._modules;\n\t}\n\n\t/**\n\t * Registers conditional module to the configuration.\n\t *\n\t * @protected\n\t * @param {object} module Module object\n\t */\n\t_registerConditionalModule(module) {\n\t\t// Create HashMap of all modules, which have conditional modules, as an\n\t\t// Array.\n\t\tif (module.condition) {\n\t\t\tlet existingModules = this._conditionalModules[\n\t\t\t\tmodule.condition.trigger\n\t\t\t];\n\n\t\t\tif (!existingModules) {\n\t\t\t\tthis._conditionalModules[\n\t\t\t\t\tmodule.condition.trigger\n\t\t\t\t] = existingModules = [];\n\t\t\t}\n\n\t\t\texistingModules.push(module.name);\n\t\t}\n\t}\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/loader/config-parser.js","import PathResolver from './path-resolver';\n\n/**\n *\n */\nexport default class DependencyBuilder {\n\t/**\n\t * Creates an instance of DependencyBuilder class.\n\t *\n\t * @constructor\n\t * @param {object} configParser - instance of {@link ConfigParser} object.\n\t */\n\tconstructor(configParser) {\n\t\tthis._configParser = configParser;\n\t\tthis._pathResolver = new PathResolver();\n\n\t\tthis._result = [];\n\n\t\t/**\n\t\t * List of modules, which dependencies should be resolved. Initially, it\n\t\t * is copy of the array of modules, passed for resolving; during the\n\t\t * process more modules may be added to the queue. For example, these\n\t\t * might be conditional modules.\n\t\t */\n\t\tthis._queue = [];\n\n\t\tthis._cachedResolutions = {};\n\t}\n\n\t/**\n\t * Resolves modules dependencies.\n\t *\n\t * @param {array} modules List of modules which dependencies should be\n\t * resolved.\n\t * @return {array} List of module names, representing module dependencies.\n\t * Module name itself is being returned too.\n\t */\n\tresolveDependencies(modules) {\n\t\tconst modulesSignature = modules\n\t\t\t.slice()\n\t\t\t.sort()\n\t\t\t.join();\n\n\t\tlet resolution = this._cachedResolutions[modulesSignature];\n\n\t\tif (!resolution) {\n\t\t\ttry {\n\t\t\t\t// Copy the passed modules to a resolving modules queue.\n\t\t\t\t// Modules may be added there during the process of resolving.\n\t\t\t\tthis._queue = modules.slice(0);\n\n\t\t\t\tthis._resolveDependencies();\n\n\t\t\t\t// Reorder the modules list so the modules without dependencies will\n\t\t\t\t// be moved upfront\n\t\t\t\tresolution = this._result.reverse().slice(0);\n\n\t\t\t\t// Cache resolution\n\t\t\t\tthis._cachedResolutions[modulesSignature] = resolution;\n\t\t\t} finally {\n\t\t\t\tthis._cleanup();\n\t\t\t}\n\t\t}\n\n\t\treturn resolution;\n\t}\n\n\t/**\n\t * Clears the used resources during the process of resolving dependencies.\n\t *\n\t * @protected\n\t */\n\t_cleanup() {\n\t\tconst modules = this._configParser.getModules();\n\n\t\t// Set to false all temporary markers which were set during the process\n\t\t// of dependencies resolving.\n\t\tfor (let key in modules) {\n\t\t\t/* istanbul ignore else */\n\t\t\tif (Object.prototype.hasOwnProperty.call(modules, key)) {\n\t\t\t\tlet module = modules[key];\n\n\t\t\t\tmodule.conditionalMark = false;\n\t\t\t\tmodule.mark = false;\n\t\t\t\tmodule.tmpMark = false;\n\t\t\t}\n\t\t}\n\n\t\tthis._queue.length = 0;\n\t\tthis._result.length = 0;\n\t}\n\n\t/**\n\t * Processes conditional modules. If a module has conditional module as\n\t * dependency, this module will be added to the list of modules, which\n\t * dependencies should be resolved.\n\t *\n\t * @protected\n\t * @param {object} module Module, which will be checked for conditional\n\t * modules as dependencies.\n\t */\n\t_processConditionalModules(module) {\n\t\tconst conditionalModules = this._configParser.getConditionalModules()[\n\t\t\tmodule.name\n\t\t];\n\n\t\t// If the current module has conditional modules as dependencies,\n\t\t// add them to the list (queue) of modules, which have to be resolved.\n\t\tif (conditionalModules && !module.conditionalMark) {\n\t\t\tconst modules = this._configParser.getModules();\n\n\t\t\tfor (let i = 0; i < conditionalModules.length; i++) {\n\t\t\t\tconst conditionalModule = modules[conditionalModules[i]];\n\n\t\t\t\tif (\n\t\t\t\t\tthis._queue.indexOf(conditionalModule.name) === -1 &&\n\t\t\t\t\tthis._testConditionalModule(\n\t\t\t\t\t\tconditionalModule.condition.test\n\t\t\t\t\t)\n\t\t\t\t) {\n\t\t\t\t\tthis._queue.push(conditionalModule.name);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tmodule.conditionalMark = true;\n\t\t}\n\t}\n\n\t/**\n\t * Processes all modules in the {@link DependencyBuilder#_queue} and\n\t * resolves their dependencies. If the module is not registered to the\n\t * configuration, it will be automatically added there with no dependencies.\n\t * The function implements a standard\n\t * [topological sorting based on depth-first search]{@link http://en.wikipedia.org/wiki/Topological_sorting}.\n\t *\n\t * @protected\n\t */\n\t_resolveDependencies() {\n\t\t// Process all modules in the queue.\n\t\t// Note: modules may be added to the queue during the process of\n\t\t// evaluating.\n\t\tconst modules = this._configParser.getModules();\n\n\t\tfor (let i = 0; i < this._queue.length; i++) {\n\t\t\tlet module = modules[this._queue[i]];\n\n\t\t\t// If not registered, add the module on the fly with no\n\t\t\t// dependencies. Note: the module name (this._queue[i]) is expected\n\t\t\t// to be already mapped.\n\t\t\tif (!module) {\n\t\t\t\tmodule = this._configParser.addModule({\n\t\t\t\t\tname: this._queue[i],\n\t\t\t\t\tdependencies: [],\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tif (!module.mark) {\n\t\t\t\tthis._visit(module);\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Executes the test function of an conditional module and adds it to the\n\t * list of module dependencies if the function returns true.\n\t *\n\t * @param {function|string} testFunction The function which have to be\n\t * \t executed. May be Function object or string.\n\t * @return {boolean} The result of the execution of the test function.\n\t */\n\t_testConditionalModule(testFunction) {\n\t\tif (typeof testFunction === 'function') {\n\t\t\treturn testFunction();\n\t\t} else {\n\t\t\treturn eval('false || ' + testFunction)();\n\t\t}\n\t}\n\n\t/**\n\t * Visits a module during the process of resolving dependencies. The\n\t * function will throw exception in case of circular dependencies among\n\t * modules. If a dependency is not registered, it will be added to the\n\t * configuration as a module without dependencies.\n\t *\n\t * @protected\n\t * @param {object} module The module which have to be visited.\n\t */\n\t_visit(module) {\n\t\t// Directed Acyclic Graph is supported only, throw exception if there\n\t\t// are circular dependencies.\n\t\tif (module.tmpMark) {\n\t\t\tthrow new Error(\n\t\t\t\t'Error processing module: ' +\n\t\t\t\t\tmodule.name +\n\t\t\t\t\t'. ' +\n\t\t\t\t\t'The provided configuration is not Directed Acyclic Graph.'\n\t\t\t);\n\t\t}\n\n\t\t// Check if this module has conditional modules and add them to the\n\t\t// queue if so.\n\t\tthis._processConditionalModules(module);\n\n\t\tif (!module.mark) {\n\t\t\tmodule.tmpMark = true;\n\n\t\t\tconst modules = this._configParser.getModules();\n\n\t\t\tfor (let i = 0; i < module.dependencies.length; i++) {\n\t\t\t\tlet dependencyName = module.dependencies[i];\n\n\t\t\t\tif (\n\t\t\t\t\tdependencyName === 'require' ||\n\t\t\t\t\tdependencyName === 'exports' ||\n\t\t\t\t\tdependencyName === 'module'\n\t\t\t\t) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\t// Resolve relative path and map the dependency to its alias\n\t\t\t\tdependencyName = this._pathResolver.resolvePath(\n\t\t\t\t\tmodule.name,\n\t\t\t\t\tdependencyName\n\t\t\t\t);\n\n\t\t\t\t// A module may have many dependencies so we should map them.\n\t\t\t\tconst mappedDependencyName = this._configParser.mapModule(\n\t\t\t\t\tdependencyName,\n\t\t\t\t\tmodule.map\n\t\t\t\t);\n\t\t\t\tlet moduleDependency = modules[mappedDependencyName];\n\n\t\t\t\t// Register on the fly all unregistered in the configuration\n\t\t\t\t// dependencies as modules without dependencies.\n\t\t\t\tif (!moduleDependency) {\n\t\t\t\t\tmoduleDependency = this._configParser.addModule({\n\t\t\t\t\t\tname: mappedDependencyName,\n\t\t\t\t\t\tdependencies: [],\n\t\t\t\t\t});\n\t\t\t\t}\n\n\t\t\t\tthis._visit(moduleDependency);\n\t\t\t}\n\n\t\t\tmodule.mark = true;\n\n\t\t\tmodule.tmpMark = false;\n\n\t\t\tthis._result.unshift(module.name);\n\t\t}\n\t}\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/loader/dependency-builder.js","/**\n *\n */\nexport default class EventEmitter {\n\t/**\n\t * Creates an instance of EventEmitter class.\n\t *\n\t * @constructor\n\t */\n\tconstructor() {\n\t\tthis._events = {};\n\t}\n\n\t/**\n\t * Adds event listener to an event.\n\t *\n\t * @param {string} event The name of the event.\n\t * @param {Function} callback Callback method to be invoked when event is\n\t * being emitted.\n\t */\n\ton(event, callback) {\n\t\tlet listeners = (this._events[event] = this._events[event] || []);\n\n\t\tlisteners.push(callback);\n\t}\n\n\t/**\n\t * Removes an event from the list of event listeners to some event.\n\t *\n\t * @param {string} event The name of the event.\n\t * @param {function} callback Callback method to be removed from the list\n\t * of listeners.\n\t */\n\toff(event, callback) {\n\t\tlet listeners = this._events[event];\n\n\t\tif (listeners) {\n\t\t\tlet callbackIndex = listeners.indexOf(callback);\n\n\t\t\tif (callbackIndex > -1) {\n\t\t\t\tlisteners.splice(callbackIndex, 1);\n\t\t\t} else {\n\t\t\t\t\n\t\t\t}\n\t\t} else {\n\t\t\t\n\t\t}\n\t}\n\n\t/**\n\t * Emits an event. The function calls all registered listeners in the order\n\t * they have been added. The provided args param will be passed to each\n\t * listener of the event.\n\t *\n\t * @param {string} event The name of the event.\n\t * @param {object} args Object, which will be passed to the listener as only\n\t * argument.\n\t */\n\temit(event, args) {\n\t\tlet listeners = this._events[event];\n\n\t\tif (listeners) {\n\t\t\t// Slicing is needed to prevent the following situation:\n\t\t\t// A listener is being invoked. During its execution, it may\n\t\t\t// remove itself from the list. In this case, for loop will\n\t\t\t// be damaged, since i will be out of sync.\n\t\t\tlisteners = listeners.slice(0);\n\n\t\t\tfor (let i = 0; i < listeners.length; i++) {\n\t\t\t\tlet listener = listeners[i];\n\n\t\t\t\tlistener.call(listener, args);\n\t\t\t}\n\t\t} else {\n\t\t\t\n\t\t}\n\t}\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/loader/event-emitter.js","// External protocols regex, supports: \"http\", \"https\", \"//\" and \"www.\"\nconst REGEX_EXTERNAL_PROTOCOLS = /^https?:\\/\\/|\\/\\/|www\\./;\n\n/**\n *\n */\nexport default class URLBuilder {\n\t/**\n\t * Creates an instance of URLBuilder class.\n\t *\n\t * @constructor\n\t * @param {object} configParser - instance of {@link ConfigParser} object.\n\t */\n\tconstructor(configParser) {\n\t\tthis._configParser = configParser;\n\t}\n\n\t/**\n\t * Returns a list of URLs from provided list of modules.\n\t *\n\t * @param {array} modules List of modules for which URLs should be created.\n\t * @return {array} List of URLs.\n\t */\n\tbuild(modules) {\n\t\tlet bufferAbsoluteURL = [];\n\t\tlet bufferRelativeURL = [];\n\t\tlet modulesAbsoluteURL = [];\n\t\tlet modulesRelativeURL = [];\n\t\tlet result = [];\n\n\t\tlet config = this._configParser.getConfig();\n\n\t\tlet basePath = config.basePath || '';\n\t\tlet registeredModules = this._configParser.getModules();\n\n\t\t/* istanbul ignore else */\n\t\tif (basePath.length && basePath.charAt(basePath.length - 1) !== '/') {\n\t\t\tbasePath += '/';\n\t\t}\n\n\t\tfor (let i = 0; i < modules.length; i++) {\n\t\t\tlet module = registeredModules[modules[i]];\n\n\t\t\t// If module has fullPath, individual URL have to be created.\n\t\t\tif (module.fullPath) {\n\t\t\t\tresult.push({\n\t\t\t\t\tmodules: [module.name],\n\t\t\t\t\turl: this._getURLWithParams(module.fullPath),\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\tlet path = this._getModulePath(module);\n\t\t\t\tlet absolutePath = path.indexOf('/') === 0;\n\n\t\t\t\t// If the URL starts with external protocol, individual URL\n\t\t\t\t// shall be created.\n\t\t\t\tif (REGEX_EXTERNAL_PROTOCOLS.test(path)) {\n\t\t\t\t\tresult.push({\n\t\t\t\t\t\tmodules: [module.name],\n\t\t\t\t\t\turl: this._getURLWithParams(path),\n\t\t\t\t\t});\n\n\t\t\t\t\t// If combine is disabled, or the module is an anonymous\n\t\t\t\t\t// one, create an individual URL based on the config URL and\n\t\t\t\t\t// module's path. If the module's path starts with \"/\", do\n\t\t\t\t\t// not include basePath in the URL.\n\t\t\t\t} else if (!config.combine || module.anonymous) {\n\t\t\t\t\tresult.push({\n\t\t\t\t\t\tmodules: [module.name],\n\t\t\t\t\t\turl: this._getURLWithParams(\n\t\t\t\t\t\t\tconfig.url + (absolutePath ? '' : basePath) + path\n\t\t\t\t\t\t),\n\t\t\t\t\t});\n\t\t\t\t} else {\n\t\t\t\t\t// If combine is true, this is not an anonymous module and\n\t\t\t\t\t// the module does not have full path. The module will be\n\t\t\t\t\t// collected in a buffer to be loaded among with other\n\t\t\t\t\t// modules from combo loader. The path will be stored in\n\t\t\t\t\t// different buffer depending on the fact if it is absolute\n\t\t\t\t\t// URL or not.\n\t\t\t\t\tif (absolutePath) {\n\t\t\t\t\t\tbufferAbsoluteURL.push(path);\n\t\t\t\t\t\tmodulesAbsoluteURL.push(module.name);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tbufferRelativeURL.push(path);\n\t\t\t\t\t\tmodulesRelativeURL.push(module.name);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tmodule.requested = true;\n\t\t}\n\n\t\t// Add to the result all modules, which have to be combined.\n\t\tif (bufferRelativeURL.length) {\n\t\t\tresult = result.concat(\n\t\t\t\tthis._generateBufferURLs(\n\t\t\t\t\tmodulesRelativeURL,\n\t\t\t\t\tbufferRelativeURL,\n\t\t\t\t\t{\n\t\t\t\t\t\tbasePath: basePath,\n\t\t\t\t\t\turl: config.url,\n\t\t\t\t\t\turlMaxLength: config.urlMaxLength,\n\t\t\t\t\t}\n\t\t\t\t)\n\t\t\t);\n\t\t\tbufferRelativeURL.length = 0;\n\t\t}\n\n\t\tif (bufferAbsoluteURL.length) {\n\t\t\tresult = result.concat(\n\t\t\t\tthis._generateBufferURLs(\n\t\t\t\t\tmodulesAbsoluteURL,\n\t\t\t\t\tbufferAbsoluteURL,\n\t\t\t\t\t{\n\t\t\t\t\t\turl: config.url,\n\t\t\t\t\t\turlMaxLength: config.urlMaxLength,\n\t\t\t\t\t}\n\t\t\t\t)\n\t\t\t);\n\t\t\tbufferAbsoluteURL.length = 0;\n\t\t}\n\n\t\treturn result;\n\t}\n\n\t/**\n\t * Generate the appropriate set of URLs based on the list of\n\t * required modules and the maximum allowed URL length\n\t *\n\t * @param {Array} modules Array of module names\n\t * @param {Array} urls Array of module URLs\n\t * @param {Object} config Configuration object containing URL, basePath and\n\t * urlMaxLength\n\t * @return {Array} Resulting array of {modules, url} objects\n\t */\n\t_generateBufferURLs(modules, urls, config) {\n\t\tlet i;\n\t\tlet basePath = config.basePath || '';\n\t\tlet result = [];\n\t\tlet urlMaxLength = config.urlMaxLength || 2000;\n\n\t\tlet urlResult = {\n\t\t\tmodules: [modules[0]],\n\t\t\turl: config.url + basePath + urls[0],\n\t\t};\n\n\t\tfor (i = 1; i < urls.length; i++) {\n\t\t\tlet module = modules[i];\n\t\t\tlet path = urls[i];\n\n\t\t\tif (\n\t\t\t\turlResult.url.length + basePath.length + path.length + 1 <\n\t\t\t\turlMaxLength\n\t\t\t) {\n\t\t\t\turlResult.modules.push(module);\n\t\t\t\turlResult.url += '&' + basePath + path;\n\t\t\t} else {\n\t\t\t\tresult.push(urlResult);\n\n\t\t\t\turlResult = {\n\t\t\t\t\tmodules: [module],\n\t\t\t\t\turl: config.url + basePath + path,\n\t\t\t\t};\n\t\t\t}\n\t\t}\n\n\t\turlResult.url = this._getURLWithParams(urlResult.url);\n\n\t\tresult.push(urlResult);\n\n\t\treturn result;\n\t}\n\n\t/**\n\t * Returns the path for a module. If module has property path, it will be\n\t * returned directly. Otherwise, the name of module will be used and\n\t * extension .js will be added to module name if omitted.\n\t *\n\t * @protected\n\t * @param {object} module The module which path should be returned.\n\t * @return {string} Module path.\n\t */\n\t_getModulePath(module) {\n\t\tlet path = module.path || module.name;\n\n\t\tlet paths = this._configParser.getConfig().paths || {};\n\n\t\tlet found = false;\n\t\tObject.keys(paths).forEach(function(item) {\n\t\t\t/* istanbul ignore else */\n\t\t\tif (path === item || path.indexOf(item + '/') === 0) {\n\t\t\t\tpath = paths[item] + path.substring(item.length);\n\t\t\t}\n\t\t});\n\n\t\t/* istanbul ignore else */\n\t\tif (!found && typeof paths['*'] === 'function') {\n\t\t\tpath = paths['*'](path);\n\t\t}\n\n\t\tif (\n\t\t\t!REGEX_EXTERNAL_PROTOCOLS.test(path) &&\n\t\t\tpath.lastIndexOf('.js') !== path.length - 3\n\t\t) {\n\t\t\tpath += '.js';\n\t\t}\n\n\t\treturn path;\n\t}\n\n\t/**\n\t * Returns an url with parameters defined in config.defaultURLParams. If\n\t * config.defaultURLParams is not defined or is an empty map, the url will\n\t * be returned unmodified.\n\t *\n\t * @protected\n\t * @param {string} url The url to be returned with parameters.\n\t * @return {string} url The url with parameters.\n\t */\n\t_getURLWithParams(url) {\n\t\tlet config = this._configParser.getConfig();\n\n\t\tlet defaultURLParams = config.defaultURLParams || {};\n\n\t\tlet keys = Object.keys(defaultURLParams);\n\n\t\tif (!keys.length) {\n\t\t\treturn url;\n\t\t}\n\n\t\tlet queryString = keys\n\t\t\t.map(function(key) {\n\t\t\t\treturn key + '=' + defaultURLParams[key];\n\t\t\t})\n\t\t\t.join('&');\n\n\t\treturn url + (url.indexOf('?') > -1 ? '&' : '?') + queryString;\n\t}\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/loader/url-builder.js","module.exports = {\"name\":\"liferay-amd-loader\",\"version\":\"3.1.2\",\"description\":\"AMD Loader with support for combo URL and conditional loading\",\"scripts\":{\"clean\":\"rm -rf build\",\"build\":\"node bin/build-loader.js\",\"ci\":\"prettier-eslint --list-different && npm run lint && npm run build && npm run build-demo && npm test\",\"build-demo\":\"node bin/build-demo.js\",\"demo\":\"node bin/run-demo.js\",\"test\":\"jest\",\"format\":\"prettier-eslint --write 'src/**/*.js'\",\"lint\":\"eslint 'src/**/*.js' && eslint 'bin/**/*.js'\",\"prepublish\":\"publish-please guard\",\"publish-please\":\"publish-please\",\"prepublishOnly\":\"npm run build && npm run build-demo && npm test\"},\"repository\":{\"type\":\"git\",\"url\":\"https://github.com/liferay/liferay-amd-loader.git\"},\"jest\":{\"collectCoverage\":true,\"coverageDirectory\":\"build/coverage\",\"modulePathIgnorePatterns\":[\"liferay-amd-loader/build/.*\",\".*/__tests__/fixture/.*\"]},\"author\":\"Iliyan Peychev\",\"license\":\"LGPL-3.0\",\"keywords\":[\"Liferay\",\"AMD\",\"ES6\",\"Loader\"],\"bugs\":{\"url\":\"https://github.com/liferay/liferay-amd-loader/issues\"},\"homepage\":\"https://github.com/liferay/liferay-amd-loader\",\"files\":[\".babelrc\",\".eslintrc\",\".publishrc\",\"LICENSE.md\",\"package.json\",\"README.md\",\"webpack.config.js\",\"src\",\"bin\",\"build\",\"src\"],\"dependencies\":{\"es6-promise\":\"^4.0.5\"},\"devDependencies\":{\"babel-loader\":\"^7.1.2\",\"babel-preset-es2015\":\"^6.24.1\",\"combohandler\":\"^0.4.0\",\"eslint\":\"^4.17.0\",\"eslint-config-liferay\":\"^2.0.18\",\"fs-extra\":\"^5.0.0\",\"globby\":\"^7.1.1\",\"http-server\":\"^0.11.1\",\"jest\":\"^22.2.1\",\"liferay-module-config-generator\":\"^1.3.3\",\"prettier-eslint-cli\":\"^4.7.0\",\"publish-please\":\"^2.3.1\",\"uglifyjs-webpack-plugin\":\"^1.2.0\",\"webpack\":\"^3.10.0\",\"webpack-clear-console\":\"^1.0.3\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./package.json\n// module id = 7\n// module chunks = 0","/*!\n * @overview es6-promise - a tiny implementation of Promises/A+.\n * @copyright Copyright (c) 2014 Yehuda Katz, Tom Dale, Stefan Penner and contributors (Conversion to ES6 API by Jake Archibald)\n * @license Licensed under MIT license\n * See https://raw.githubusercontent.com/stefanpenner/es6-promise/master/LICENSE\n * @version 4.1.0\n */\n\n(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n typeof define === 'function' && define.amd ? define(factory) :\n (global.ES6Promise = factory());\n}(this, (function () { 'use strict';\n\nfunction objectOrFunction(x) {\n return typeof x === 'function' || typeof x === 'object' && x !== null;\n}\n\nfunction isFunction(x) {\n return typeof x === 'function';\n}\n\nvar _isArray = undefined;\nif (!Array.isArray) {\n _isArray = function (x) {\n return Object.prototype.toString.call(x) === '[object Array]';\n };\n} else {\n _isArray = Array.isArray;\n}\n\nvar isArray = _isArray;\n\nvar len = 0;\nvar vertxNext = undefined;\nvar customSchedulerFn = undefined;\n\nvar asap = function asap(callback, arg) {\n queue[len] = callback;\n queue[len + 1] = arg;\n len += 2;\n if (len === 2) {\n // If len is 2, that means that we need to schedule an async flush.\n // If additional callbacks are queued before the queue is flushed, they\n // will be processed by this flush that we are scheduling.\n if (customSchedulerFn) {\n customSchedulerFn(flush);\n } else {\n scheduleFlush();\n }\n }\n};\n\nfunction setScheduler(scheduleFn) {\n customSchedulerFn = scheduleFn;\n}\n\nfunction setAsap(asapFn) {\n asap = asapFn;\n}\n\nvar browserWindow = typeof window !== 'undefined' ? window : undefined;\nvar browserGlobal = browserWindow || {};\nvar BrowserMutationObserver = browserGlobal.MutationObserver || browserGlobal.WebKitMutationObserver;\nvar isNode = typeof self === 'undefined' && typeof process !== 'undefined' && ({}).toString.call(process) === '[object process]';\n\n// test for web worker but not in IE10\nvar isWorker = typeof Uint8ClampedArray !== 'undefined' && typeof importScripts !== 'undefined' && typeof MessageChannel !== 'undefined';\n\n// node\nfunction useNextTick() {\n // node version 0.10.x displays a deprecation warning when nextTick is used recursively\n // see https://github.com/cujojs/when/issues/410 for details\n return function () {\n return process.nextTick(flush);\n };\n}\n\n// vertx\nfunction useVertxTimer() {\n if (typeof vertxNext !== 'undefined') {\n return function () {\n vertxNext(flush);\n };\n }\n\n return useSetTimeout();\n}\n\nfunction useMutationObserver() {\n var iterations = 0;\n var observer = new BrowserMutationObserver(flush);\n var node = document.createTextNode('');\n observer.observe(node, { characterData: true });\n\n return function () {\n node.data = iterations = ++iterations % 2;\n };\n}\n\n// web worker\nfunction useMessageChannel() {\n var channel = new MessageChannel();\n channel.port1.onmessage = flush;\n return function () {\n return channel.port2.postMessage(0);\n };\n}\n\nfunction useSetTimeout() {\n // Store setTimeout reference so es6-promise will be unaffected by\n // other code modifying setTimeout (like sinon.useFakeTimers())\n var globalSetTimeout = setTimeout;\n return function () {\n return globalSetTimeout(flush, 1);\n };\n}\n\nvar queue = new Array(1000);\nfunction flush() {\n for (var i = 0; i < len; i += 2) {\n var callback = queue[i];\n var arg = queue[i + 1];\n\n callback(arg);\n\n queue[i] = undefined;\n queue[i + 1] = undefined;\n }\n\n len = 0;\n}\n\nfunction attemptVertx() {\n try {\n var r = require;\n var vertx = r('vertx');\n vertxNext = vertx.runOnLoop || vertx.runOnContext;\n return useVertxTimer();\n } catch (e) {\n return useSetTimeout();\n }\n}\n\nvar scheduleFlush = undefined;\n// Decide what async method to use to triggering processing of queued callbacks:\nif (isNode) {\n scheduleFlush = useNextTick();\n} else if (BrowserMutationObserver) {\n scheduleFlush = useMutationObserver();\n} else if (isWorker) {\n scheduleFlush = useMessageChannel();\n} else if (browserWindow === undefined && typeof require === 'function') {\n scheduleFlush = attemptVertx();\n} else {\n scheduleFlush = useSetTimeout();\n}\n\nfunction then(onFulfillment, onRejection) {\n var _arguments = arguments;\n\n var parent = this;\n\n var child = new this.constructor(noop);\n\n if (child[PROMISE_ID] === undefined) {\n makePromise(child);\n }\n\n var _state = parent._state;\n\n if (_state) {\n (function () {\n var callback = _arguments[_state - 1];\n asap(function () {\n return invokeCallback(_state, child, callback, parent._result);\n });\n })();\n } else {\n subscribe(parent, child, onFulfillment, onRejection);\n }\n\n return child;\n}\n\n/**\n `Promise.resolve` returns a promise that will become resolved with the\n passed `value`. It is shorthand for the following:\n\n ```javascript\n let promise = new Promise(function(resolve, reject){\n resolve(1);\n });\n\n promise.then(function(value){\n // value === 1\n });\n ```\n\n Instead of writing the above, your code now simply becomes the following:\n\n ```javascript\n let promise = Promise.resolve(1);\n\n promise.then(function(value){\n // value === 1\n });\n ```\n\n @method resolve\n @static\n @param {Any} value value that the returned promise will be resolved with\n Useful for tooling.\n @return {Promise} a promise that will become fulfilled with the given\n `value`\n*/\nfunction resolve(object) {\n /*jshint validthis:true */\n var Constructor = this;\n\n if (object && typeof object === 'object' && object.constructor === Constructor) {\n return object;\n }\n\n var promise = new Constructor(noop);\n _resolve(promise, object);\n return promise;\n}\n\nvar PROMISE_ID = Math.random().toString(36).substring(16);\n\nfunction noop() {}\n\nvar PENDING = void 0;\nvar FULFILLED = 1;\nvar REJECTED = 2;\n\nvar GET_THEN_ERROR = new ErrorObject();\n\nfunction selfFulfillment() {\n return new TypeError(\"You cannot resolve a promise with itself\");\n}\n\nfunction cannotReturnOwn() {\n return new TypeError('A promises callback cannot return that same promise.');\n}\n\nfunction getThen(promise) {\n try {\n return promise.then;\n } catch (error) {\n GET_THEN_ERROR.error = error;\n return GET_THEN_ERROR;\n }\n}\n\nfunction tryThen(then, value, fulfillmentHandler, rejectionHandler) {\n try {\n then.call(value, fulfillmentHandler, rejectionHandler);\n } catch (e) {\n return e;\n }\n}\n\nfunction handleForeignThenable(promise, thenable, then) {\n asap(function (promise) {\n var sealed = false;\n var error = tryThen(then, thenable, function (value) {\n if (sealed) {\n return;\n }\n sealed = true;\n if (thenable !== value) {\n _resolve(promise, value);\n } else {\n fulfill(promise, value);\n }\n }, function (reason) {\n if (sealed) {\n return;\n }\n sealed = true;\n\n _reject(promise, reason);\n }, 'Settle: ' + (promise._label || ' unknown promise'));\n\n if (!sealed && error) {\n sealed = true;\n _reject(promise, error);\n }\n }, promise);\n}\n\nfunction handleOwnThenable(promise, thenable) {\n if (thenable._state === FULFILLED) {\n fulfill(promise, thenable._result);\n } else if (thenable._state === REJECTED) {\n _reject(promise, thenable._result);\n } else {\n subscribe(thenable, undefined, function (value) {\n return _resolve(promise, value);\n }, function (reason) {\n return _reject(promise, reason);\n });\n }\n}\n\nfunction handleMaybeThenable(promise, maybeThenable, then$$) {\n if (maybeThenable.constructor === promise.constructor && then$$ === then && maybeThenable.constructor.resolve === resolve) {\n handleOwnThenable(promise, maybeThenable);\n } else {\n if (then$$ === GET_THEN_ERROR) {\n _reject(promise, GET_THEN_ERROR.error);\n GET_THEN_ERROR.error = null;\n } else if (then$$ === undefined) {\n fulfill(promise, maybeThenable);\n } else if (isFunction(then$$)) {\n handleForeignThenable(promise, maybeThenable, then$$);\n } else {\n fulfill(promise, maybeThenable);\n }\n }\n}\n\nfunction _resolve(promise, value) {\n if (promise === value) {\n _reject(promise, selfFulfillment());\n } else if (objectOrFunction(value)) {\n handleMaybeThenable(promise, value, getThen(value));\n } else {\n fulfill(promise, value);\n }\n}\n\nfunction publishRejection(promise) {\n if (promise._onerror) {\n promise._onerror(promise._result);\n }\n\n publish(promise);\n}\n\nfunction fulfill(promise, value) {\n if (promise._state !== PENDING) {\n return;\n }\n\n promise._result = value;\n promise._state = FULFILLED;\n\n if (promise._subscribers.length !== 0) {\n asap(publish, promise);\n }\n}\n\nfunction _reject(promise, reason) {\n if (promise._state !== PENDING) {\n return;\n }\n promise._state = REJECTED;\n promise._result = reason;\n\n asap(publishRejection, promise);\n}\n\nfunction subscribe(parent, child, onFulfillment, onRejection) {\n var _subscribers = parent._subscribers;\n var length = _subscribers.length;\n\n parent._onerror = null;\n\n _subscribers[length] = child;\n _subscribers[length + FULFILLED] = onFulfillment;\n _subscribers[length + REJECTED] = onRejection;\n\n if (length === 0 && parent._state) {\n asap(publish, parent);\n }\n}\n\nfunction publish(promise) {\n var subscribers = promise._subscribers;\n var settled = promise._state;\n\n if (subscribers.length === 0) {\n return;\n }\n\n var child = undefined,\n callback = undefined,\n detail = promise._result;\n\n for (var i = 0; i < subscribers.length; i += 3) {\n child = subscribers[i];\n callback = subscribers[i + settled];\n\n if (child) {\n invokeCallback(settled, child, callback, detail);\n } else {\n callback(detail);\n }\n }\n\n promise._subscribers.length = 0;\n}\n\nfunction ErrorObject() {\n this.error = null;\n}\n\nvar TRY_CATCH_ERROR = new ErrorObject();\n\nfunction tryCatch(callback, detail) {\n try {\n return callback(detail);\n } catch (e) {\n TRY_CATCH_ERROR.error = e;\n return TRY_CATCH_ERROR;\n }\n}\n\nfunction invokeCallback(settled, promise, callback, detail) {\n var hasCallback = isFunction(callback),\n value = undefined,\n error = undefined,\n succeeded = undefined,\n failed = undefined;\n\n if (hasCallback) {\n value = tryCatch(callback, detail);\n\n if (value === TRY_CATCH_ERROR) {\n failed = true;\n error = value.error;\n value.error = null;\n } else {\n succeeded = true;\n }\n\n if (promise === value) {\n _reject(promise, cannotReturnOwn());\n return;\n }\n } else {\n value = detail;\n succeeded = true;\n }\n\n if (promise._state !== PENDING) {\n // noop\n } else if (hasCallback && succeeded) {\n _resolve(promise, value);\n } else if (failed) {\n _reject(promise, error);\n } else if (settled === FULFILLED) {\n fulfill(promise, value);\n } else if (settled === REJECTED) {\n _reject(promise, value);\n }\n}\n\nfunction initializePromise(promise, resolver) {\n try {\n resolver(function resolvePromise(value) {\n _resolve(promise, value);\n }, function rejectPromise(reason) {\n _reject(promise, reason);\n });\n } catch (e) {\n _reject(promise, e);\n }\n}\n\nvar id = 0;\nfunction nextId() {\n return id++;\n}\n\nfunction makePromise(promise) {\n promise[PROMISE_ID] = id++;\n promise._state = undefined;\n promise._result = undefined;\n promise._subscribers = [];\n}\n\nfunction Enumerator(Constructor, input) {\n this._instanceConstructor = Constructor;\n this.promise = new Constructor(noop);\n\n if (!this.promise[PROMISE_ID]) {\n makePromise(this.promise);\n }\n\n if (isArray(input)) {\n this._input = input;\n this.length = input.length;\n this._remaining = input.length;\n\n this._result = new Array(this.length);\n\n if (this.length === 0) {\n fulfill(this.promise, this._result);\n } else {\n this.length = this.length || 0;\n this._enumerate();\n if (this._remaining === 0) {\n fulfill(this.promise, this._result);\n }\n }\n } else {\n _reject(this.promise, validationError());\n }\n}\n\nfunction validationError() {\n return new Error('Array Methods must be provided an Array');\n};\n\nEnumerator.prototype._enumerate = function () {\n var length = this.length;\n var _input = this._input;\n\n for (var i = 0; this._state === PENDING && i < length; i++) {\n this._eachEntry(_input[i], i);\n }\n};\n\nEnumerator.prototype._eachEntry = function (entry, i) {\n var c = this._instanceConstructor;\n var resolve$$ = c.resolve;\n\n if (resolve$$ === resolve) {\n var _then = getThen(entry);\n\n if (_then === then && entry._state !== PENDING) {\n this._settledAt(entry._state, i, entry._result);\n } else if (typeof _then !== 'function') {\n this._remaining--;\n this._result[i] = entry;\n } else if (c === Promise) {\n var promise = new c(noop);\n handleMaybeThenable(promise, entry, _then);\n this._willSettleAt(promise, i);\n } else {\n this._willSettleAt(new c(function (resolve$$) {\n return resolve$$(entry);\n }), i);\n }\n } else {\n this._willSettleAt(resolve$$(entry), i);\n }\n};\n\nEnumerator.prototype._settledAt = function (state, i, value) {\n var promise = this.promise;\n\n if (promise._state === PENDING) {\n this._remaining--;\n\n if (state === REJECTED) {\n _reject(promise, value);\n } else {\n this._result[i] = value;\n }\n }\n\n if (this._remaining === 0) {\n fulfill(promise, this._result);\n }\n};\n\nEnumerator.prototype._willSettleAt = function (promise, i) {\n var enumerator = this;\n\n subscribe(promise, undefined, function (value) {\n return enumerator._settledAt(FULFILLED, i, value);\n }, function (reason) {\n return enumerator._settledAt(REJECTED, i, reason);\n });\n};\n\n/**\n `Promise.all` accepts an array of promises, and returns a new promise which\n is fulfilled with an array of fulfillment values for the passed promises, or\n rejected with the reason of the first passed promise to be rejected. It casts all\n elements of the passed iterable to promises as it runs this algorithm.\n\n Example:\n\n ```javascript\n let promise1 = resolve(1);\n let promise2 = resolve(2);\n let promise3 = resolve(3);\n let promises = [ promise1, promise2, promise3 ];\n\n Promise.all(promises).then(function(array){\n // The array here would be [ 1, 2, 3 ];\n });\n ```\n\n If any of the `promises` given to `all` are rejected, the first promise\n that is rejected will be given as an argument to the returned promises's\n rejection handler. For example:\n\n Example:\n\n ```javascript\n let promise1 = resolve(1);\n let promise2 = reject(new Error(\"2\"));\n let promise3 = reject(new Error(\"3\"));\n let promises = [ promise1, promise2, promise3 ];\n\n Promise.all(promises).then(function(array){\n // Code here never runs because there are rejected promises!\n }, function(error) {\n // error.message === \"2\"\n });\n ```\n\n @method all\n @static\n @param {Array} entries array of promises\n @param {String} label optional string for labeling the promise.\n Useful for tooling.\n @return {Promise} promise that is fulfilled when all `promises` have been\n fulfilled, or rejected if any of them become rejected.\n @static\n*/\nfunction all(entries) {\n return new Enumerator(this, entries).promise;\n}\n\n/**\n `Promise.race` returns a new promise which is settled in the same way as the\n first passed promise to settle.\n\n Example:\n\n ```javascript\n let promise1 = new Promise(function(resolve, reject){\n setTimeout(function(){\n resolve('promise 1');\n }, 200);\n });\n\n let promise2 = new Promise(function(resolve, reject){\n setTimeout(function(){\n resolve('promise 2');\n }, 100);\n });\n\n Promise.race([promise1, promise2]).then(function(result){\n // result === 'promise 2' because it was resolved before promise1\n // was resolved.\n });\n ```\n\n `Promise.race` is deterministic in that only the state of the first\n settled promise matters. For example, even if other promises given to the\n `promises` array argument are resolved, but the first settled promise has\n become rejected before the other promises became fulfilled, the returned\n promise will become rejected:\n\n ```javascript\n let promise1 = new Promise(function(resolve, reject){\n setTimeout(function(){\n resolve('promise 1');\n }, 200);\n });\n\n let promise2 = new Promise(function(resolve, reject){\n setTimeout(function(){\n reject(new Error('promise 2'));\n }, 100);\n });\n\n Promise.race([promise1, promise2]).then(function(result){\n // Code here never runs\n }, function(reason){\n // reason.message === 'promise 2' because promise 2 became rejected before\n // promise 1 became fulfilled\n });\n ```\n\n An example real-world use case is implementing timeouts:\n\n ```javascript\n Promise.race([ajax('foo.json'), timeout(5000)])\n ```\n\n @method race\n @static\n @param {Array} promises array of promises to observe\n Useful for tooling.\n @return {Promise} a promise which settles in the same way as the first passed\n promise to settle.\n*/\nfunction race(entries) {\n /*jshint validthis:true */\n var Constructor = this;\n\n if (!isArray(entries)) {\n return new Constructor(function (_, reject) {\n return reject(new TypeError('You must pass an array to race.'));\n });\n } else {\n return new Constructor(function (resolve, reject) {\n var length = entries.length;\n for (var i = 0; i < length; i++) {\n Constructor.resolve(entries[i]).then(resolve, reject);\n }\n });\n }\n}\n\n/**\n `Promise.reject` returns a promise rejected with the passed `reason`.\n It is shorthand for the following:\n\n ```javascript\n let promise = new Promise(function(resolve, reject){\n reject(new Error('WHOOPS'));\n });\n\n promise.then(function(value){\n // Code here doesn't run because the promise is rejected!\n }, function(reason){\n // reason.message === 'WHOOPS'\n });\n ```\n\n Instead of writing the above, your code now simply becomes the following:\n\n ```javascript\n let promise = Promise.reject(new Error('WHOOPS'));\n\n promise.then(function(value){\n // Code here doesn't run because the promise is rejected!\n }, function(reason){\n // reason.message === 'WHOOPS'\n });\n ```\n\n @method reject\n @static\n @param {Any} reason value that the returned promise will be rejected with.\n Useful for tooling.\n @return {Promise} a promise rejected with the given `reason`.\n*/\nfunction reject(reason) {\n /*jshint validthis:true */\n var Constructor = this;\n var promise = new Constructor(noop);\n _reject(promise, reason);\n return promise;\n}\n\nfunction needsResolver() {\n throw new TypeError('You must pass a resolver function as the first argument to the promise constructor');\n}\n\nfunction needsNew() {\n throw new TypeError(\"Failed to construct 'Promise': Please use the 'new' operator, this object constructor cannot be called as a function.\");\n}\n\n/**\n Promise objects represent the eventual result of an asynchronous operation. The\n primary way of interacting with a promise is through its `then` method, which\n registers callbacks to receive either a promise's eventual value or the reason\n why the promise cannot be fulfilled.\n\n Terminology\n -----------\n\n - `promise` is an object or function with a `then` method whose behavior conforms to this specification.\n - `thenable` is an object or function that defines a `then` method.\n - `value` is any legal JavaScript value (including undefined, a thenable, or a promise).\n - `exception` is a value that is thrown using the throw statement.\n - `reason` is a value that indicates why a promise was rejected.\n - `settled` the final resting state of a promise, fulfilled or rejected.\n\n A promise can be in one of three states: pending, fulfilled, or rejected.\n\n Promises that are fulfilled have a fulfillment value and are in the fulfilled\n state. Promises that are rejected have a rejection reason and are in the\n rejected state. A fulfillment value is never a thenable.\n\n Promises can also be said to *resolve* a value. If this value is also a\n promise, then the original promise's settled state will match the value's\n settled state. So a promise that *resolves* a promise that rejects will\n itself reject, and a promise that *resolves* a promise that fulfills will\n itself fulfill.\n\n\n Basic Usage:\n ------------\n\n ```js\n let promise = new Promise(function(resolve, reject) {\n // on success\n resolve(value);\n\n // on failure\n reject(reason);\n });\n\n promise.then(function(value) {\n // on fulfillment\n }, function(reason) {\n // on rejection\n });\n ```\n\n Advanced Usage:\n ---------------\n\n Promises shine when abstracting away asynchronous interactions such as\n `XMLHttpRequest`s.\n\n ```js\n function getJSON(url) {\n return new Promise(function(resolve, reject){\n let xhr = new XMLHttpRequest();\n\n xhr.open('GET', url);\n xhr.onreadystatechange = handler;\n xhr.responseType = 'json';\n xhr.setRequestHeader('Accept', 'application/json');\n xhr.send();\n\n function handler() {\n if (this.readyState === this.DONE) {\n if (this.status === 200) {\n resolve(this.response);\n } else {\n reject(new Error('getJSON: `' + url + '` failed with status: [' + this.status + ']'));\n }\n }\n };\n });\n }\n\n getJSON('/posts.json').then(function(json) {\n // on fulfillment\n }, function(reason) {\n // on rejection\n });\n ```\n\n Unlike callbacks, promises are great composable primitives.\n\n ```js\n Promise.all([\n getJSON('/posts'),\n getJSON('/comments')\n ]).then(function(values){\n values[0] // => postsJSON\n values[1] // => commentsJSON\n\n return values;\n });\n ```\n\n @class Promise\n @param {function} resolver\n Useful for tooling.\n @constructor\n*/\nfunction Promise(resolver) {\n this[PROMISE_ID] = nextId();\n this._result = this._state = undefined;\n this._subscribers = [];\n\n if (noop !== resolver) {\n typeof resolver !== 'function' && needsResolver();\n this instanceof Promise ? initializePromise(this, resolver) : needsNew();\n }\n}\n\nPromise.all = all;\nPromise.race = race;\nPromise.resolve = resolve;\nPromise.reject = reject;\nPromise._setScheduler = setScheduler;\nPromise._setAsap = setAsap;\nPromise._asap = asap;\n\nPromise.prototype = {\n constructor: Promise,\n\n /**\n The primary way of interacting with a promise is through its `then` method,\n which registers callbacks to receive either a promise's eventual value or the\n reason why the promise cannot be fulfilled.\n \n ```js\n findUser().then(function(user){\n // user is available\n }, function(reason){\n // user is unavailable, and you are given the reason why\n });\n ```\n \n Chaining\n --------\n \n The return value of `then` is itself a promise. This second, 'downstream'\n promise is resolved with the return value of the first promise's fulfillment\n or rejection handler, or rejected if the handler throws an exception.\n \n ```js\n findUser().then(function (user) {\n return user.name;\n }, function (reason) {\n return 'default name';\n }).then(function (userName) {\n // If `findUser` fulfilled, `userName` will be the user's name, otherwise it\n // will be `'default name'`\n });\n \n findUser().then(function (user) {\n throw new Error('Found user, but still unhappy');\n }, function (reason) {\n throw new Error('`findUser` rejected and we're unhappy');\n }).then(function (value) {\n // never reached\n }, function (reason) {\n // if `findUser` fulfilled, `reason` will be 'Found user, but still unhappy'.\n // If `findUser` rejected, `reason` will be '`findUser` rejected and we're unhappy'.\n });\n ```\n If the downstream promise does not specify a rejection handler, rejection reasons will be propagated further downstream.\n \n ```js\n findUser().then(function (user) {\n throw new PedagogicalException('Upstream error');\n }).then(function (value) {\n // never reached\n }).then(function (value) {\n // never reached\n }, function (reason) {\n // The `PedgagocialException` is propagated all the way down to here\n });\n ```\n \n Assimilation\n ------------\n \n Sometimes the value you want to propagate to a downstream promise can only be\n retrieved asynchronously. This can be achieved by returning a promise in the\n fulfillment or rejection handler. The downstream promise will then be pending\n until the returned promise is settled. This is called *assimilation*.\n \n ```js\n findUser().then(function (user) {\n return findCommentsByAuthor(user);\n }).then(function (comments) {\n // The user's comments are now available\n });\n ```\n \n If the assimliated promise rejects, then the downstream promise will also reject.\n \n ```js\n findUser().then(function (user) {\n return findCommentsByAuthor(user);\n }).then(function (comments) {\n // If `findCommentsByAuthor` fulfills, we'll have the value here\n }, function (reason) {\n // If `findCommentsByAuthor` rejects, we'll have the reason here\n });\n ```\n \n Simple Example\n --------------\n \n Synchronous Example\n \n ```javascript\n let result;\n \n try {\n result = findResult();\n // success\n } catch(reason) {\n // failure\n }\n ```\n \n Errback Example\n \n ```js\n findResult(function(result, err){\n if (err) {\n // failure\n } else {\n // success\n }\n });\n ```\n \n Promise Example;\n \n ```javascript\n findResult().then(function(result){\n // success\n }, function(reason){\n // failure\n });\n ```\n \n Advanced Example\n --------------\n \n Synchronous Example\n \n ```javascript\n let author, books;\n \n try {\n author = findAuthor();\n books = findBooksByAuthor(author);\n // success\n } catch(reason) {\n // failure\n }\n ```\n \n Errback Example\n \n ```js\n \n function foundBooks(books) {\n \n }\n \n function failure(reason) {\n \n }\n \n findAuthor(function(author, err){\n if (err) {\n failure(err);\n // failure\n } else {\n try {\n findBoooksByAuthor(author, function(books, err) {\n if (err) {\n failure(err);\n } else {\n try {\n foundBooks(books);\n } catch(reason) {\n failure(reason);\n }\n }\n });\n } catch(error) {\n failure(err);\n }\n // success\n }\n });\n ```\n \n Promise Example;\n \n ```javascript\n findAuthor().\n then(findBooksByAuthor).\n then(function(books){\n // found books\n }).catch(function(reason){\n // something went wrong\n });\n ```\n \n @method then\n @param {Function} onFulfilled\n @param {Function} onRejected\n Useful for tooling.\n @return {Promise}\n */\n then: then,\n\n /**\n `catch` is simply sugar for `then(undefined, onRejection)` which makes it the same\n as the catch block of a try/catch statement.\n \n ```js\n function findAuthor(){\n throw new Error('couldn't find that author');\n }\n \n // synchronous\n try {\n findAuthor();\n } catch(reason) {\n // something went wrong\n }\n \n // async with promises\n findAuthor().catch(function(reason){\n // something went wrong\n });\n ```\n \n @method catch\n @param {Function} onRejection\n Useful for tooling.\n @return {Promise}\n */\n 'catch': function _catch(onRejection) {\n return this.then(null, onRejection);\n }\n};\n\nfunction polyfill() {\n var local = undefined;\n\n if (typeof global !== 'undefined') {\n local = global;\n } else if (typeof self !== 'undefined') {\n local = self;\n } else {\n try {\n local = Function('return this')();\n } catch (e) {\n throw new Error('polyfill failed because global object is unavailable in this environment');\n }\n }\n\n var P = local.Promise;\n\n if (P) {\n var promiseToString = null;\n try {\n promiseToString = Object.prototype.toString.call(P.resolve());\n } catch (e) {\n // silently ignored\n }\n\n if (promiseToString === '[object Promise]' && !P.cast) {\n return;\n }\n }\n\n local.Promise = Promise;\n}\n\n// Strange compat..\nPromise.polyfill = polyfill;\nPromise.Promise = Promise;\n\nreturn Promise;\n\n})));\n//# sourceMappingURL=es6-promise.map\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/es6-promise/dist/es6-promise.js\n// module id = 8\n// module chunks = 0","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things. But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals. It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n throw new Error('clearTimeout has not been defined');\n}\n(function () {\n try {\n if (typeof setTimeout === 'function') {\n cachedSetTimeout = setTimeout;\n } else {\n cachedSetTimeout = defaultSetTimout;\n }\n } catch (e) {\n cachedSetTimeout = defaultSetTimout;\n }\n try {\n if (typeof clearTimeout === 'function') {\n cachedClearTimeout = clearTimeout;\n } else {\n cachedClearTimeout = defaultClearTimeout;\n }\n } catch (e) {\n cachedClearTimeout = defaultClearTimeout;\n }\n} ())\nfunction runTimeout(fun) {\n if (cachedSetTimeout === setTimeout) {\n //normal enviroments in sane situations\n return setTimeout(fun, 0);\n }\n // if setTimeout wasn't available but was latter defined\n if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n cachedSetTimeout = setTimeout;\n return setTimeout(fun, 0);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedSetTimeout(fun, 0);\n } catch(e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedSetTimeout.call(null, fun, 0);\n } catch(e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n return cachedSetTimeout.call(this, fun, 0);\n }\n }\n\n\n}\nfunction runClearTimeout(marker) {\n if (cachedClearTimeout === clearTimeout) {\n //normal enviroments in sane situations\n return clearTimeout(marker);\n }\n // if clearTimeout wasn't available but was latter defined\n if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n cachedClearTimeout = clearTimeout;\n return clearTimeout(marker);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedClearTimeout(marker);\n } catch (e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedClearTimeout.call(null, marker);\n } catch (e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n return cachedClearTimeout.call(this, marker);\n }\n }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = runTimeout(cleanUpNextTick);\n draining = true;\n\n var len = queue.length;\n while(len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n runTimeout(drainQueue);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/process/browser.js\n// module id = 9\n// module chunks = 0"],"sourceRoot":"","file":"loader.3.js"}