From 57c337f99d93c6e0853fb4058664e0ac29a3cc39 Mon Sep 17 00:00:00 2001 From: Owen Stowe Date: Mon, 16 Oct 2017 17:42:40 -0400 Subject: [PATCH] Fix webpack setup to make sure hotTemplate.js is linted --- config/webpack.server.config.js | 7 +- dist/cli/index.js | 2164 ++++++++++++++++++++++++++++--- dist/cli/index.js.map | 1 + dist/web/index.js | 2028 ++++++++++++++++++++++++++++- package.json | 2 +- templates/hotTemplate.js | 2 +- 6 files changed, 3946 insertions(+), 258 deletions(-) create mode 100644 dist/cli/index.js.map diff --git a/config/webpack.server.config.js b/config/webpack.server.config.js index c9c41ff..dcd1a77 100644 --- a/config/webpack.server.config.js +++ b/config/webpack.server.config.js @@ -8,7 +8,6 @@ const CleanPlugin = require('clean-webpack-plugin'); module.exports = function getConfig(env) { const context = path.join(__dirname, '../'); - const include = path.join(__dirname, '../src/cli'); return { context, @@ -37,17 +36,17 @@ module.exports = function getConfig(env) { __dirname: false, }, module: { - noParse: [/requireExternal/, /hotTemplate/], + noParse: [/requireExternal/], rules: [ { enforce: 'pre', test: /\.js$/, - include, + exclude: [/node_modules/, /\.min\.js$/], use: 'eslint-loader', }, { test: /\.js$/, - include, + exclude: [/node_modules/, /\.min\.js$/], use: 'babel-loader', }, ], diff --git a/dist/cli/index.js b/dist/cli/index.js index e0ee01f..419c75a 100644 --- a/dist/cli/index.js +++ b/dist/cli/index.js @@ -68,361 +68,2131 @@ /************************************************************************/ /******/ ([ /* 0 */ -/* no static exports found */ -/* all exports used */ -/*!***********************!*\ - !*** external "path" ***! - \***********************/ /***/ (function(module, exports) { -eval("module.exports = require(\"path\");//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy9leHRlcm5hbCBcInBhdGhcIj81YjJhIl0sInNvdXJjZXNDb250ZW50IjpbIm1vZHVsZS5leHBvcnRzID0gcmVxdWlyZShcInBhdGhcIik7XG5cblxuLy8vLy8vLy8vLy8vLy8vLy8vXG4vLyBXRUJQQUNLIEZPT1RFUlxuLy8gZXh0ZXJuYWwgXCJwYXRoXCJcbi8vIG1vZHVsZSBpZCA9IDBcbi8vIG1vZHVsZSBjaHVua3MgPSAwIl0sIm1hcHBpbmdzIjoiQUFBQSIsInNvdXJjZVJvb3QiOiIifQ=="); +module.exports = require("path"); /***/ }), /* 1 */ -/* no static exports found */ -/* all exports used */ -/*!**************************!*\ - !*** ./src/cli/utils.js ***! - \**************************/ /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.normalizeSectionData = normalizeSectionData;\nexports.writeSectionData = writeSectionData;\nexports.getTemplateDataPair = getTemplateDataPair;\nexports.normalizeHeader = normalizeHeader;\nexports.wrapMarkup = wrapMarkup;\nexports.generateFilename = generateFilename;\nexports.writeFile = writeFile;\nexports.removeFile = removeFile;\nexports.writeSectionTemplate = writeSectionTemplate;\nexports.getSection = getSection;\nexports.matchKssDir = matchKssDir;\nexports.mergeClassnameJSON = mergeClassnameJSON;\nexports.removeTrailingSlash = removeTrailingSlash;\n\nvar _path = __webpack_require__(/*! path */ 0);\n\nvar _path2 = _interopRequireDefault(_path);\n\nvar _fsExtra = __webpack_require__(/*! fs-extra */ 3);\n\nvar _fsExtra2 = _interopRequireDefault(_fsExtra);\n\nvar _chalk = __webpack_require__(/*! chalk */ 2);\n\nvar _chalk2 = _interopRequireDefault(_chalk);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nconst cwd = process.cwd(); // Current working directory\n\n/**\n * Ensure predictable data structure for KSS section data\n *\n * @function normalizeSectionData\n * @param {object} section - section data\n * @return {object} section data\n */\n/** @module cli/utilities */\nfunction normalizeSectionData(section) {\n const data = section.data || section;\n\n if (!data.referenceURI || '' === data.referenceURI) {\n data.referenceURI = section.referenceURI();\n }\n\n return data;\n}\n\n/**\n * Ensure predictable data structure for KSS section data\n *\n * @function writeSectionData\n * @param {object} store - data store\n * @param {object} section - section data\n * @param {string} sectionPath - output destination for section data file\n */\nfunction writeSectionData(store, section, sectionPath = false) {\n let outputPath = sectionPath;\n let sectionFileInfo;\n\n if (!outputPath && {}.hasOwnProperty.call(section, 'kssPath')) {\n sectionFileInfo = _path2.default.parse(section.kssPath);\n outputPath = _path2.default.join(sectionFileInfo.dir, `${sectionFileInfo.name}.json`);\n }\n\n // Output section data\n if (outputPath) {\n return writeFile(section.referenceURI, 'section', outputPath, JSON.stringify(section), store);\n }\n\n console.warn( // eslint-disable-line no-console\n _chalk2.default.red(`Failed to write section data for ${section.referenceURI}`));\n return false;\n}\n\n/**\n * Find .json from a template file or vice versa\n *\n * @function getTemplateDataPair\n * @param {object} file - file object from path.parse()\n * @param {object} section - KSS section data\n * @return {string} relative path to module JSON file\n */\nfunction getTemplateDataPair(file, section, store) {\n const huron = store.get('config');\n const kssDir = matchKssDir(file.dir, huron);\n\n if (kssDir) {\n const componentPath = _path2.default.relative(_path2.default.resolve(cwd, kssDir), file.dir);\n const partnerType = '.json' === file.ext ? 'template' : 'data';\n const partnerExt = '.json' === file.ext ? huron.get('templates').extension : '.json';\n\n const pairPath = _path2.default.join(componentPath, generateFilename(section.referenceURI, partnerType, partnerExt, store));\n\n return `./${pairPath}`;\n }\n\n return false;\n}\n\n/**\n * Normalize a section title for use as a filename\n *\n * @function normalizeHeader\n * @param {string} header - section header extracted from KSS documentation\n * @return {string} modified header, lowercase and words separated by dash\n */\nfunction normalizeHeader(header) {\n return header.toLowerCase().replace(/\\s?\\W\\s?/g, '-');\n}\n\n/**\n * Wrap html in required template tags\n *\n * @function wrapMarkup\n * @param {string} content - html or template markup\n * @param {string} templateId - id of template (should be section reference)\n * @return {string} modified HTML\n */\nfunction wrapMarkup(content, templateId) {\n return `\n\n\\n`;\n}\n\n/**\n * Generate a filename based on referenceURI, type and file object\n *\n * @function generateFilename\n * @param {string} id - The name of the file (with extension).\n * @param {string} type - the type of file output\n * @param {object} ext - file extension\n * @param {store} store - data store\n * @return {string} Path to output file, relative to ouput dir (can be use in require statements)\n */\nfunction generateFilename(id, type, ext, store) {\n // Type of file and its corresponding extension(s)\n const types = store.get('types');\n const outputExt = '.scss' !== ext ? ext : '.html';\n\n /* eslint-disable */\n if (-1 === types.indexOf(type)) {\n console.log(`Huron data ${type} does not exist`);\n return false;\n }\n /* eslint-enable */\n\n return `${id}-${type}${outputExt}`;\n}\n\n/**\n * Copy an HTML file into the huron output directory.\n *\n * @function writeFile\n * @param {string} id - The name of the file (with extension).\n * @param {string} content - The content of the file to write.\n * @param {string} type - the type of file output\n * @param {object} store - The data store\n * @return {string} Path to output file, relative to ouput dir (can be use in require statements)\n */\nfunction writeFile(id, type, filepath, content, store) {\n const huron = store.get('config');\n const file = _path2.default.parse(filepath);\n const filename = generateFilename(id, type, file.ext, store);\n const kssDir = matchKssDir(filepath, huron);\n\n if (kssDir) {\n const componentPath = _path2.default.relative(_path2.default.resolve(cwd, kssDir), file.dir);\n const outputRelative = _path2.default.join(huron.get('output'), componentPath, `${filename}`);\n const outputPath = _path2.default.resolve(cwd, huron.get('root'), outputRelative);\n let newContent = content;\n\n if ('data' !== type && 'section' !== type) {\n newContent = wrapMarkup(content, id);\n }\n\n try {\n _fsExtra2.default.outputFileSync(outputPath, newContent);\n console.log(_chalk2.default.green(`Writing ${outputRelative}`)); // eslint-disable-line no-console\n } catch (e) {\n console.log(_chalk2.default.red(`Failed to write ${outputRelative}`)); // eslint-disable-line no-console\n }\n\n return `./${outputRelative.replace(`${huron.get('output')}/`, '')}`;\n }\n\n return false;\n}\n\n/**\n * Delete a file in the huron output directory\n *\n * @function removeFile\n * @param {string} filename - The name of the file (with extension).\n * @param {object} store - The data store\n * @return {string} Path to output file, relative to ouput dir (can be use in require statements)\n */\nfunction removeFile(id, type, filepath, store) {\n const huron = store.get('config');\n const file = _path2.default.parse(filepath);\n const filename = generateFilename(id, type, file.ext, store);\n const kssDir = matchKssDir(filepath, huron);\n\n if (kssDir) {\n const componentPath = _path2.default.relative(_path2.default.resolve(cwd, kssDir), file.dir);\n const outputRelative = _path2.default.join(huron.get('output'), componentPath, `${filename}`);\n const outputPath = _path2.default.resolve(cwd, huron.get('root'), outputRelative);\n\n try {\n _fsExtra2.default.removeSync(outputPath);\n console.log(_chalk2.default.green(`Removing ${outputRelative}`)); // eslint-disable-line no-console\n } catch (e) {\n console.log( // eslint-disable-line no-console\n _chalk2.default.red(`${outputRelative} does not exist or cannot be deleted`));\n }\n\n return `./${outputRelative.replace(`${huron.get('output')}/`, '')}`;\n }\n\n return false;\n}\n\n/**\n * Write a template for sections\n *\n * @function writeSectionTemplate\n * @param {string} filepath - the original template file\n * @param {object} store - data store\n * @return {object} updated store\n */\nfunction writeSectionTemplate(filepath, store) {\n const huron = store.get('config');\n const sectionTemplate = wrapMarkup(_fsExtra2.default.readFileSync(filepath, 'utf8'));\n const componentPath = './huron-assets/section.hbs';\n const output = _path2.default.join(cwd, huron.get('root'), componentPath);\n\n // Move huron script and section template into huron root\n _fsExtra2.default.outputFileSync(output, sectionTemplate);\n console.log(_chalk2.default.green(`writing section template to ${output}`)); // eslint-disable-line no-console\n\n return store.set('sectionTemplatePath', componentPath);\n}\n\n/**\n * Request for section data based on section reference\n *\n * @function writeSectionTemplate\n * @param {string} search - key on which to match section\n * @param {field} string - field in which to look to determine section\n * @param {obj} store - sections memory store\n */\nfunction getSection(search, field, store) {\n const sectionValues = store.getIn(['sections', 'sectionsByPath']).valueSeq();\n let selectedSection = false;\n\n if (field) {\n selectedSection = sectionValues.filter(value => value[field] === search).get(0);\n } else {\n selectedSection = store.getIn(['sections', 'sectionsByPath', search]);\n }\n\n return selectedSection;\n}\n\n/**\n * Find which configured KSS directory a filepath exists in\n *\n * @function matchKssDir\n * @param {string} filepath - filepath to search for\n * @param {object} huron - huron configuration\n * @return {string} kssMatch - relative path to KSS directory\n */\nfunction matchKssDir(filepath, huron) {\n const kssSource = huron.get('kss');\n // Include forward slash in our test to make sure we're matchin a directory, not a file extension\n const kssMatch = kssSource.filter(dir => filepath.includes(`/${dir}`));\n\n if (kssMatch.length) {\n return kssMatch[0];\n }\n\n return false;\n}\n\n/**\n * Merge JSON files for css modules classnames in a provided directory\n *\n * @function mergeClassnameJSON\n * @param {string} directory - directory containing classname JSON files\n *\n * @return {object} classnamesMerged - merged classnames. contents of each JSON file is nested within\n * the returned object by filename. (e.g. article.json -> { article: {...json contents}})\n */\nfunction mergeClassnameJSON(directory) {\n let files;\n\n // Try to read through classnames directory\n try {\n files = _fsExtra2.default.readdirSync(directory);\n } catch (e) {\n console.warn(_chalk2.default.red(e));\n return {};\n }\n\n // Merge classname json files\n const classNamesMerged = files.reduce((acc, file) => {\n const fileInfo = _path2.default.parse(file);\n let classNames = {};\n\n if ('.json' === fileInfo.ext) {\n try {\n const contents = _fsExtra2.default.readFileSync(_path2.default.join(directory, file), 'utf8');\n classNames = JSON.parse(contents);\n } catch (e) {\n console.warn(_chalk2.default.red(e));\n return classNames;\n }\n }\n\n return Object.assign({}, acc, { [fileInfo.name]: classNames });\n }, {});\n\n return classNamesMerged;\n}\n\n/**\n * Remove the trailing slash from a provided directory\n *\n * @function removeTrailingSlash\n * @param {string} directory - directory path\n * @return {string} directory - directory path with trailing slash removed\n */\nfunction removeTrailingSlash(directory) {\n if ('/' === directory.slice(-1)) {\n return directory.slice(0, -1);\n }\n\n return directory;\n}//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy9zcmMvY2xpL3V0aWxzLmpzP2U3MWMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBtb2R1bGUgY2xpL3V0aWxpdGllcyAqL1xuaW1wb3J0IHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgZnMgZnJvbSAnZnMtZXh0cmEnO1xuaW1wb3J0IGNoYWxrIGZyb20gJ2NoYWxrJztcblxuY29uc3QgY3dkID0gcHJvY2Vzcy5jd2QoKTsgLy8gQ3VycmVudCB3b3JraW5nIGRpcmVjdG9yeVxuXG4vKipcbiAqIEVuc3VyZSBwcmVkaWN0YWJsZSBkYXRhIHN0cnVjdHVyZSBmb3IgS1NTIHNlY3Rpb24gZGF0YVxuICpcbiAqIEBmdW5jdGlvbiBub3JtYWxpemVTZWN0aW9uRGF0YVxuICogQHBhcmFtIHtvYmplY3R9IHNlY3Rpb24gLSBzZWN0aW9uIGRhdGFcbiAqIEByZXR1cm4ge29iamVjdH0gc2VjdGlvbiBkYXRhXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBub3JtYWxpemVTZWN0aW9uRGF0YShzZWN0aW9uKSB7XG4gIGNvbnN0IGRhdGEgPSBzZWN0aW9uLmRhdGEgfHwgc2VjdGlvbjtcblxuICBpZiAoIWRhdGEucmVmZXJlbmNlVVJJIHx8ICcnID09PSBkYXRhLnJlZmVyZW5jZVVSSSkge1xuICAgIGRhdGEucmVmZXJlbmNlVVJJID0gc2VjdGlvbi5yZWZlcmVuY2VVUkkoKTtcbiAgfVxuXG4gIHJldHVybiBkYXRhO1xufVxuXG4vKipcbiAqIEVuc3VyZSBwcmVkaWN0YWJsZSBkYXRhIHN0cnVjdHVyZSBmb3IgS1NTIHNlY3Rpb24gZGF0YVxuICpcbiAqIEBmdW5jdGlvbiB3cml0ZVNlY3Rpb25EYXRhXG4gKiBAcGFyYW0ge29iamVjdH0gc3RvcmUgLSBkYXRhIHN0b3JlXG4gKiBAcGFyYW0ge29iamVjdH0gc2VjdGlvbiAtIHNlY3Rpb24gZGF0YVxuICogQHBhcmFtIHtzdHJpbmd9IHNlY3Rpb25QYXRoIC0gb3V0cHV0IGRlc3RpbmF0aW9uIGZvciBzZWN0aW9uIGRhdGEgZmlsZVxuICovXG5leHBvcnQgZnVuY3Rpb24gd3JpdGVTZWN0aW9uRGF0YShzdG9yZSwgc2VjdGlvbiwgc2VjdGlvblBhdGggPSBmYWxzZSkge1xuICBsZXQgb3V0cHV0UGF0aCA9IHNlY3Rpb25QYXRoO1xuICBsZXQgc2VjdGlvbkZpbGVJbmZvO1xuXG4gIGlmICghb3V0cHV0UGF0aCAmJiB7fS5oYXNPd25Qcm9wZXJ0eS5jYWxsKHNlY3Rpb24sICdrc3NQYXRoJykpIHtcbiAgICBzZWN0aW9uRmlsZUluZm8gPSBwYXRoLnBhcnNlKHNlY3Rpb24ua3NzUGF0aCk7XG4gICAgb3V0cHV0UGF0aCA9IHBhdGguam9pbihcbiAgICAgIHNlY3Rpb25GaWxlSW5mby5kaXIsXG4gICAgICBgJHtzZWN0aW9uRmlsZUluZm8ubmFtZX0uanNvbmBcbiAgICApO1xuICB9XG5cbiAgLy8gT3V0cHV0IHNlY3Rpb24gZGF0YVxuICBpZiAob3V0cHV0UGF0aCkge1xuICAgIHJldHVybiB3cml0ZUZpbGUoXG4gICAgICBzZWN0aW9uLnJlZmVyZW5jZVVSSSxcbiAgICAgICdzZWN0aW9uJyxcbiAgICAgIG91dHB1dFBhdGgsXG4gICAgICBKU09OLnN0cmluZ2lmeShzZWN0aW9uKSxcbiAgICAgIHN0b3JlXG4gICAgKTtcbiAgfVxuXG4gIGNvbnNvbGUud2FybiggLy8gZXNsaW50LWRpc2FibGUtbGluZSBuby1jb25zb2xlXG4gICAgY2hhbGsucmVkKGBGYWlsZWQgdG8gd3JpdGUgc2VjdGlvbiBkYXRhIGZvciAke3NlY3Rpb24ucmVmZXJlbmNlVVJJfWApXG4gICk7XG4gIHJldHVybiBmYWxzZTtcbn1cblxuLyoqXG4gKiBGaW5kIC5qc29uIGZyb20gYSB0ZW1wbGF0ZSBmaWxlIG9yIHZpY2UgdmVyc2FcbiAqXG4gKiBAZnVuY3Rpb24gZ2V0VGVtcGxhdGVEYXRhUGFpclxuICogQHBhcmFtIHtvYmplY3R9IGZpbGUgLSBmaWxlIG9iamVjdCBmcm9tIHBhdGgucGFyc2UoKVxuICogQHBhcmFtIHtvYmplY3R9IHNlY3Rpb24gLSBLU1Mgc2VjdGlvbiBkYXRhXG4gKiBAcmV0dXJuIHtzdHJpbmd9IHJlbGF0aXZlIHBhdGggdG8gbW9kdWxlIEpTT04gZmlsZVxuICovXG5leHBvcnQgZnVuY3Rpb24gZ2V0VGVtcGxhdGVEYXRhUGFpcihmaWxlLCBzZWN0aW9uLCBzdG9yZSkge1xuICBjb25zdCBodXJvbiA9IHN0b3JlLmdldCgnY29uZmlnJyk7XG4gIGNvbnN0IGtzc0RpciA9IG1hdGNoS3NzRGlyKGZpbGUuZGlyLCBodXJvbik7XG5cbiAgaWYgKGtzc0Rpcikge1xuICAgIGNvbnN0IGNvbXBvbmVudFBhdGggPSBwYXRoLnJlbGF0aXZlKFxuICAgICAgcGF0aC5yZXNvbHZlKGN3ZCwga3NzRGlyKSxcbiAgICAgIGZpbGUuZGlyXG4gICAgKTtcbiAgICBjb25zdCBwYXJ0bmVyVHlwZSA9ICcuanNvbicgPT09IGZpbGUuZXh0ID8gJ3RlbXBsYXRlJyA6ICdkYXRhJztcbiAgICBjb25zdCBwYXJ0bmVyRXh0ID0gJy5qc29uJyA9PT0gZmlsZS5leHQgP1xuICAgICAgaHVyb24uZ2V0KCd0ZW1wbGF0ZXMnKS5leHRlbnNpb24gOlxuICAgICAgJy5qc29uJztcblxuICAgIGNvbnN0IHBhaXJQYXRoID0gcGF0aC5qb2luKFxuICAgICAgY29tcG9uZW50UGF0aCxcbiAgICAgIGdlbmVyYXRlRmlsZW5hbWUoXG4gICAgICAgIHNlY3Rpb24ucmVmZXJlbmNlVVJJLFxuICAgICAgICBwYXJ0bmVyVHlwZSxcbiAgICAgICAgcGFydG5lckV4dCxcbiAgICAgICAgc3RvcmVcbiAgICAgIClcbiAgICApO1xuXG4gICAgcmV0dXJuIGAuLyR7cGFpclBhdGh9YDtcbiAgfVxuXG4gIHJldHVybiBmYWxzZTtcbn1cblxuLyoqXG4gKiBOb3JtYWxpemUgYSBzZWN0aW9uIHRpdGxlIGZvciB1c2UgYXMgYSBmaWxlbmFtZVxuICpcbiAqIEBmdW5jdGlvbiBub3JtYWxpemVIZWFkZXJcbiAqIEBwYXJhbSB7c3RyaW5nfSBoZWFkZXIgLSBzZWN0aW9uIGhlYWRlciBleHRyYWN0ZWQgZnJvbSBLU1MgZG9jdW1lbnRhdGlvblxuICogQHJldHVybiB7c3RyaW5nfSBtb2RpZmllZCBoZWFkZXIsIGxvd2VyY2FzZSBhbmQgd29yZHMgc2VwYXJhdGVkIGJ5IGRhc2hcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIG5vcm1hbGl6ZUhlYWRlcihoZWFkZXIpIHtcbiAgcmV0dXJuIGhlYWRlclxuICAgIC50b0xvd2VyQ2FzZSgpXG4gICAgLnJlcGxhY2UoL1xccz9cXFdcXHM/L2csICctJyk7XG59XG5cbi8qKlxuICogV3JhcCBodG1sIGluIHJlcXVpcmVkIHRlbXBsYXRlIHRhZ3NcbiAqXG4gKiBAZnVuY3Rpb24gd3JhcE1hcmt1cFxuICogQHBhcmFtIHtzdHJpbmd9IGNvbnRlbnQgLSBodG1sIG9yIHRlbXBsYXRlIG1hcmt1cFxuICogQHBhcmFtIHtzdHJpbmd9IHRlbXBsYXRlSWQgLSBpZCBvZiB0ZW1wbGF0ZSAoc2hvdWxkIGJlIHNlY3Rpb24gcmVmZXJlbmNlKVxuICogQHJldHVybiB7c3RyaW5nfSBtb2RpZmllZCBIVE1MXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB3cmFwTWFya3VwKGNvbnRlbnQsIHRlbXBsYXRlSWQpIHtcbiAgcmV0dXJuIGA8ZG9tLW1vZHVsZT5cbjx0ZW1wbGF0ZSBpZD1cIiR7dGVtcGxhdGVJZH1cIj5cbiR7Y29udGVudH1cbjwvdGVtcGxhdGU+XG48L2RvbS1tb2R1bGU+XFxuYDtcbn1cblxuLyoqXG4gKiBHZW5lcmF0ZSBhIGZpbGVuYW1lIGJhc2VkIG9uIHJlZmVyZW5jZVVSSSwgdHlwZSBhbmQgZmlsZSBvYmplY3RcbiAqXG4gKiBAZnVuY3Rpb24gZ2VuZXJhdGVGaWxlbmFtZVxuICogQHBhcmFtICB7c3RyaW5nfSBpZCAtIFRoZSBuYW1lIG9mIHRoZSBmaWxlICh3aXRoIGV4dGVuc2lvbikuXG4gKiBAcGFyYW0gIHtzdHJpbmd9IHR5cGUgLSB0aGUgdHlwZSBvZiBmaWxlIG91dHB1dFxuICogQHBhcmFtICB7b2JqZWN0fSBleHQgLSBmaWxlIGV4dGVuc2lvblxuICogQHBhcmFtICB7c3RvcmV9IHN0b3JlIC0gZGF0YSBzdG9yZVxuICogQHJldHVybiB7c3RyaW5nfSBQYXRoIHRvIG91dHB1dCBmaWxlLCByZWxhdGl2ZSB0byBvdXB1dCBkaXIgKGNhbiBiZSB1c2UgaW4gcmVxdWlyZSBzdGF0ZW1lbnRzKVxuICovXG5leHBvcnQgZnVuY3Rpb24gZ2VuZXJhdGVGaWxlbmFtZShpZCwgdHlwZSwgZXh0LCBzdG9yZSkge1xuICAvLyBUeXBlIG9mIGZpbGUgYW5kIGl0cyBjb3JyZXNwb25kaW5nIGV4dGVuc2lvbihzKVxuICBjb25zdCB0eXBlcyA9IHN0b3JlLmdldCgndHlwZXMnKTtcbiAgY29uc3Qgb3V0cHV0RXh0ID0gJy5zY3NzJyAhPT0gZXh0ID8gZXh0IDogJy5odG1sJztcblxuICAvKiBlc2xpbnQtZGlzYWJsZSAqL1xuICBpZiAoLTEgPT09IHR5cGVzLmluZGV4T2YodHlwZSkpIHtcbiAgICBjb25zb2xlLmxvZyhgSHVyb24gZGF0YSAke3R5cGV9IGRvZXMgbm90IGV4aXN0YCk7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG4gIC8qIGVzbGludC1lbmFibGUgKi9cblxuICByZXR1cm4gYCR7aWR9LSR7dHlwZX0ke291dHB1dEV4dH1gO1xufVxuXG4vKipcbiAqIENvcHkgYW4gSFRNTCBmaWxlIGludG8gdGhlIGh1cm9uIG91dHB1dCBkaXJlY3RvcnkuXG4gKlxuICogQGZ1bmN0aW9uIHdyaXRlRmlsZVxuICogQHBhcmFtICB7c3RyaW5nfSBpZCAtIFRoZSBuYW1lIG9mIHRoZSBmaWxlICh3aXRoIGV4dGVuc2lvbikuXG4gKiBAcGFyYW0gIHtzdHJpbmd9IGNvbnRlbnQgLSBUaGUgY29udGVudCBvZiB0aGUgZmlsZSB0byB3cml0ZS5cbiAqIEBwYXJhbSAge3N0cmluZ30gdHlwZSAtIHRoZSB0eXBlIG9mIGZpbGUgb3V0cHV0XG4gKiBAcGFyYW0gIHtvYmplY3R9IHN0b3JlIC0gVGhlIGRhdGEgc3RvcmVcbiAqIEByZXR1cm4ge3N0cmluZ30gUGF0aCB0byBvdXRwdXQgZmlsZSwgcmVsYXRpdmUgdG8gb3VwdXQgZGlyIChjYW4gYmUgdXNlIGluIHJlcXVpcmUgc3RhdGVtZW50cylcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHdyaXRlRmlsZShpZCwgdHlwZSwgZmlsZXBhdGgsIGNvbnRlbnQsIHN0b3JlKSB7XG4gIGNvbnN0IGh1cm9uID0gc3RvcmUuZ2V0KCdjb25maWcnKTtcbiAgY29uc3QgZmlsZSA9IHBhdGgucGFyc2UoZmlsZXBhdGgpO1xuICBjb25zdCBmaWxlbmFtZSA9IGdlbmVyYXRlRmlsZW5hbWUoaWQsIHR5cGUsIGZpbGUuZXh0LCBzdG9yZSk7XG4gIGNvbnN0IGtzc0RpciA9IG1hdGNoS3NzRGlyKGZpbGVwYXRoLCBodXJvbik7XG5cbiAgaWYgKGtzc0Rpcikge1xuICAgIGNvbnN0IGNvbXBvbmVudFBhdGggPSBwYXRoLnJlbGF0aXZlKFxuICAgICAgcGF0aC5yZXNvbHZlKGN3ZCwga3NzRGlyKSxcbiAgICAgIGZpbGUuZGlyXG4gICAgKTtcbiAgICBjb25zdCBvdXRwdXRSZWxhdGl2ZSA9IHBhdGguam9pbihcbiAgICAgIGh1cm9uLmdldCgnb3V0cHV0JyksXG4gICAgICBjb21wb25lbnRQYXRoLFxuICAgICAgYCR7ZmlsZW5hbWV9YFxuICAgICk7XG4gICAgY29uc3Qgb3V0cHV0UGF0aCA9IHBhdGgucmVzb2x2ZShjd2QsIGh1cm9uLmdldCgncm9vdCcpLCBvdXRwdXRSZWxhdGl2ZSk7XG4gICAgbGV0IG5ld0NvbnRlbnQgPSBjb250ZW50O1xuXG4gICAgaWYgKCdkYXRhJyAhPT0gdHlwZSAmJiAnc2VjdGlvbicgIT09IHR5cGUpIHtcbiAgICAgIG5ld0NvbnRlbnQgPSB3cmFwTWFya3VwKGNvbnRlbnQsIGlkKTtcbiAgICB9XG5cbiAgICB0cnkge1xuICAgICAgZnMub3V0cHV0RmlsZVN5bmMob3V0cHV0UGF0aCwgbmV3Q29udGVudCk7XG4gICAgICBjb25zb2xlLmxvZyhjaGFsay5ncmVlbihgV3JpdGluZyAke291dHB1dFJlbGF0aXZlfWApKTsgLy8gZXNsaW50LWRpc2FibGUtbGluZSBuby1jb25zb2xlXG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgY29uc29sZS5sb2coY2hhbGsucmVkKGBGYWlsZWQgdG8gd3JpdGUgJHtvdXRwdXRSZWxhdGl2ZX1gKSk7IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgbm8tY29uc29sZVxuICAgIH1cblxuICAgIHJldHVybiBgLi8ke291dHB1dFJlbGF0aXZlLnJlcGxhY2UoYCR7aHVyb24uZ2V0KCdvdXRwdXQnKX0vYCwgJycpfWA7XG4gIH1cblxuICByZXR1cm4gZmFsc2U7XG59XG5cbi8qKlxuICogRGVsZXRlIGEgZmlsZSBpbiB0aGUgaHVyb24gb3V0cHV0IGRpcmVjdG9yeVxuICpcbiAqIEBmdW5jdGlvbiByZW1vdmVGaWxlXG4gKiBAcGFyYW0gIHtzdHJpbmd9IGZpbGVuYW1lIC0gVGhlIG5hbWUgb2YgdGhlIGZpbGUgKHdpdGggZXh0ZW5zaW9uKS5cbiAqIEBwYXJhbSAge29iamVjdH0gc3RvcmUgLSBUaGUgZGF0YSBzdG9yZVxuICogQHJldHVybiB7c3RyaW5nfSBQYXRoIHRvIG91dHB1dCBmaWxlLCByZWxhdGl2ZSB0byBvdXB1dCBkaXIgKGNhbiBiZSB1c2UgaW4gcmVxdWlyZSBzdGF0ZW1lbnRzKVxuICovXG5leHBvcnQgZnVuY3Rpb24gcmVtb3ZlRmlsZShpZCwgdHlwZSwgZmlsZXBhdGgsIHN0b3JlKSB7XG4gIGNvbnN0IGh1cm9uID0gc3RvcmUuZ2V0KCdjb25maWcnKTtcbiAgY29uc3QgZmlsZSA9IHBhdGgucGFyc2UoZmlsZXBhdGgpO1xuICBjb25zdCBmaWxlbmFtZSA9IGdlbmVyYXRlRmlsZW5hbWUoaWQsIHR5cGUsIGZpbGUuZXh0LCBzdG9yZSk7XG4gIGNvbnN0IGtzc0RpciA9IG1hdGNoS3NzRGlyKGZpbGVwYXRoLCBodXJvbik7XG5cbiAgaWYgKGtzc0Rpcikge1xuICAgIGNvbnN0IGNvbXBvbmVudFBhdGggPSBwYXRoLnJlbGF0aXZlKFxuICAgICAgcGF0aC5yZXNvbHZlKGN3ZCwga3NzRGlyKSxcbiAgICAgIGZpbGUuZGlyXG4gICAgKTtcbiAgICBjb25zdCBvdXRwdXRSZWxhdGl2ZSA9IHBhdGguam9pbihcbiAgICAgIGh1cm9uLmdldCgnb3V0cHV0JyksXG4gICAgICBjb21wb25lbnRQYXRoLFxuICAgICAgYCR7ZmlsZW5hbWV9YFxuICAgICk7XG4gICAgY29uc3Qgb3V0cHV0UGF0aCA9IHBhdGgucmVzb2x2ZShjd2QsIGh1cm9uLmdldCgncm9vdCcpLCBvdXRwdXRSZWxhdGl2ZSk7XG5cbiAgICB0cnkge1xuICAgICAgZnMucmVtb3ZlU3luYyhvdXRwdXRQYXRoKTtcbiAgICAgIGNvbnNvbGUubG9nKGNoYWxrLmdyZWVuKGBSZW1vdmluZyAke291dHB1dFJlbGF0aXZlfWApKTsgLy8gZXNsaW50LWRpc2FibGUtbGluZSBuby1jb25zb2xlXG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgY29uc29sZS5sb2coIC8vIGVzbGludC1kaXNhYmxlLWxpbmUgbm8tY29uc29sZVxuICAgICAgICBjaGFsay5yZWQoYCR7b3V0cHV0UmVsYXRpdmV9IGRvZXMgbm90IGV4aXN0IG9yIGNhbm5vdCBiZSBkZWxldGVkYClcbiAgICAgICk7XG4gICAgfVxuXG4gICAgcmV0dXJuIGAuLyR7b3V0cHV0UmVsYXRpdmUucmVwbGFjZShgJHtodXJvbi5nZXQoJ291dHB1dCcpfS9gLCAnJyl9YDtcbiAgfVxuXG4gIHJldHVybiBmYWxzZTtcbn1cblxuLyoqXG4gKiBXcml0ZSBhIHRlbXBsYXRlIGZvciBzZWN0aW9uc1xuICpcbiAqIEBmdW5jdGlvbiB3cml0ZVNlY3Rpb25UZW1wbGF0ZVxuICogQHBhcmFtICB7c3RyaW5nfSBmaWxlcGF0aCAtIHRoZSBvcmlnaW5hbCB0ZW1wbGF0ZSBmaWxlXG4gKiBAcGFyYW0gIHtvYmplY3R9IHN0b3JlIC0gZGF0YSBzdG9yZVxuICogQHJldHVybiB7b2JqZWN0fSB1cGRhdGVkIHN0b3JlXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB3cml0ZVNlY3Rpb25UZW1wbGF0ZShmaWxlcGF0aCwgc3RvcmUpIHtcbiAgY29uc3QgaHVyb24gPSBzdG9yZS5nZXQoJ2NvbmZpZycpO1xuICBjb25zdCBzZWN0aW9uVGVtcGxhdGUgPSB3cmFwTWFya3VwKGZzLnJlYWRGaWxlU3luYyhmaWxlcGF0aCwgJ3V0ZjgnKSk7XG4gIGNvbnN0IGNvbXBvbmVudFBhdGggPSAnLi9odXJvbi1hc3NldHMvc2VjdGlvbi5oYnMnO1xuICBjb25zdCBvdXRwdXQgPSBwYXRoLmpvaW4oXG4gICAgY3dkLFxuICAgIGh1cm9uLmdldCgncm9vdCcpLFxuICAgIGNvbXBvbmVudFBhdGhcbiAgKTtcblxuICAvLyBNb3ZlIGh1cm9uIHNjcmlwdCBhbmQgc2VjdGlvbiB0ZW1wbGF0ZSBpbnRvIGh1cm9uIHJvb3RcbiAgZnMub3V0cHV0RmlsZVN5bmMob3V0cHV0LCBzZWN0aW9uVGVtcGxhdGUpO1xuICBjb25zb2xlLmxvZyhjaGFsay5ncmVlbihgd3JpdGluZyBzZWN0aW9uIHRlbXBsYXRlIHRvICR7b3V0cHV0fWApKTsgLy8gZXNsaW50LWRpc2FibGUtbGluZSBuby1jb25zb2xlXG5cbiAgcmV0dXJuIHN0b3JlLnNldCgnc2VjdGlvblRlbXBsYXRlUGF0aCcsIGNvbXBvbmVudFBhdGgpO1xufVxuXG4vKipcbiAqIFJlcXVlc3QgZm9yIHNlY3Rpb24gZGF0YSBiYXNlZCBvbiBzZWN0aW9uIHJlZmVyZW5jZVxuICpcbiAqIEBmdW5jdGlvbiB3cml0ZVNlY3Rpb25UZW1wbGF0ZVxuICogQHBhcmFtIHtzdHJpbmd9IHNlYXJjaCAtIGtleSBvbiB3aGljaCB0byBtYXRjaCBzZWN0aW9uXG4gKiBAcGFyYW0ge2ZpZWxkfSBzdHJpbmcgLSBmaWVsZCBpbiB3aGljaCB0byBsb29rIHRvIGRldGVybWluZSBzZWN0aW9uXG4gKiBAcGFyYW0ge29ian0gc3RvcmUgLSBzZWN0aW9ucyBtZW1vcnkgc3RvcmVcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldFNlY3Rpb24oc2VhcmNoLCBmaWVsZCwgc3RvcmUpIHtcbiAgY29uc3Qgc2VjdGlvblZhbHVlcyA9IHN0b3JlXG4gICAgLmdldEluKFsnc2VjdGlvbnMnLCAnc2VjdGlvbnNCeVBhdGgnXSlcbiAgICAudmFsdWVTZXEoKTtcbiAgbGV0IHNlbGVjdGVkU2VjdGlvbiA9IGZhbHNlO1xuXG4gIGlmIChmaWVsZCkge1xuICAgIHNlbGVjdGVkU2VjdGlvbiA9IHNlY3Rpb25WYWx1ZXNcbiAgICAgIC5maWx0ZXIoKHZhbHVlKSA9PiB2YWx1ZVtmaWVsZF0gPT09IHNlYXJjaClcbiAgICAgIC5nZXQoMCk7XG4gIH0gZWxzZSB7XG4gICAgc2VsZWN0ZWRTZWN0aW9uID0gc3RvcmUuZ2V0SW4oWydzZWN0aW9ucycsICdzZWN0aW9uc0J5UGF0aCcsIHNlYXJjaF0pO1xuICB9XG5cbiAgcmV0dXJuIHNlbGVjdGVkU2VjdGlvbjtcbn1cblxuLyoqXG4gKiBGaW5kIHdoaWNoIGNvbmZpZ3VyZWQgS1NTIGRpcmVjdG9yeSBhIGZpbGVwYXRoIGV4aXN0cyBpblxuICpcbiAqIEBmdW5jdGlvbiBtYXRjaEtzc0RpclxuICogQHBhcmFtIHtzdHJpbmd9IGZpbGVwYXRoIC0gZmlsZXBhdGggdG8gc2VhcmNoIGZvclxuICogQHBhcmFtIHtvYmplY3R9IGh1cm9uIC0gaHVyb24gY29uZmlndXJhdGlvblxuICogQHJldHVybiB7c3RyaW5nfSBrc3NNYXRjaCAtIHJlbGF0aXZlIHBhdGggdG8gS1NTIGRpcmVjdG9yeVxuICovXG5leHBvcnQgZnVuY3Rpb24gbWF0Y2hLc3NEaXIoZmlsZXBhdGgsIGh1cm9uKSB7XG4gIGNvbnN0IGtzc1NvdXJjZSA9IGh1cm9uLmdldCgna3NzJyk7XG4gIC8vIEluY2x1ZGUgZm9yd2FyZCBzbGFzaCBpbiBvdXIgdGVzdCB0byBtYWtlIHN1cmUgd2UncmUgbWF0Y2hpbiBhIGRpcmVjdG9yeSwgbm90IGEgZmlsZSBleHRlbnNpb25cbiAgY29uc3Qga3NzTWF0Y2ggPSBrc3NTb3VyY2UuZmlsdGVyKChkaXIpID0+IGZpbGVwYXRoLmluY2x1ZGVzKGAvJHtkaXJ9YCkpO1xuXG4gIGlmIChrc3NNYXRjaC5sZW5ndGgpIHtcbiAgICByZXR1cm4ga3NzTWF0Y2hbMF07XG4gIH1cblxuICByZXR1cm4gZmFsc2U7XG59XG5cbi8qKlxuICogTWVyZ2UgSlNPTiBmaWxlcyBmb3IgY3NzIG1vZHVsZXMgY2xhc3NuYW1lcyBpbiBhIHByb3ZpZGVkIGRpcmVjdG9yeVxuICpcbiAqIEBmdW5jdGlvbiBtZXJnZUNsYXNzbmFtZUpTT05cbiAqIEBwYXJhbSB7c3RyaW5nfSBkaXJlY3RvcnkgLSBkaXJlY3RvcnkgY29udGFpbmluZyBjbGFzc25hbWUgSlNPTiBmaWxlc1xuICpcbiAqIEByZXR1cm4ge29iamVjdH0gY2xhc3NuYW1lc01lcmdlZCAtIG1lcmdlZCBjbGFzc25hbWVzLiBjb250ZW50cyBvZiBlYWNoIEpTT04gZmlsZSBpcyBuZXN0ZWQgd2l0aGluXG4gKiAgICAgICAgICAgICAgICAgICAgICAgICAgIHRoZSByZXR1cm5lZCBvYmplY3QgYnkgZmlsZW5hbWUuIChlLmcuIGFydGljbGUuanNvbiAtPiB7IGFydGljbGU6IHsuLi5qc29uIGNvbnRlbnRzfX0pXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBtZXJnZUNsYXNzbmFtZUpTT04oZGlyZWN0b3J5KSB7XG4gIGxldCBmaWxlcztcblxuICAvLyBUcnkgdG8gcmVhZCB0aHJvdWdoIGNsYXNzbmFtZXMgZGlyZWN0b3J5XG4gIHRyeSB7XG4gICAgZmlsZXMgPSBmcy5yZWFkZGlyU3luYyhkaXJlY3RvcnkpO1xuICB9IGNhdGNoIChlKSB7XG4gICAgY29uc29sZS53YXJuKGNoYWxrLnJlZChlKSk7XG4gICAgcmV0dXJuIHt9O1xuICB9XG5cbiAgLy8gTWVyZ2UgY2xhc3NuYW1lIGpzb24gZmlsZXNcbiAgY29uc3QgY2xhc3NOYW1lc01lcmdlZCA9IGZpbGVzLnJlZHVjZSgoYWNjLCBmaWxlKSA9PiB7XG4gICAgY29uc3QgZmlsZUluZm8gPSBwYXRoLnBhcnNlKGZpbGUpO1xuICAgIGxldCBjbGFzc05hbWVzID0ge307XG5cbiAgICBpZiAoJy5qc29uJyA9PT0gZmlsZUluZm8uZXh0KSB7XG4gICAgICB0cnkge1xuICAgICAgICBjb25zdCBjb250ZW50cyA9IGZzLnJlYWRGaWxlU3luYyhcbiAgICAgICAgICBwYXRoLmpvaW4oZGlyZWN0b3J5LCBmaWxlKSxcbiAgICAgICAgICAndXRmOCdcbiAgICAgICAgKTtcbiAgICAgICAgY2xhc3NOYW1lcyA9IEpTT04ucGFyc2UoY29udGVudHMpO1xuICAgICAgfSBjYXRjaCAoZSkge1xuICAgICAgICBjb25zb2xlLndhcm4oY2hhbGsucmVkKGUpKTtcbiAgICAgICAgcmV0dXJuIGNsYXNzTmFtZXM7XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIE9iamVjdC5hc3NpZ24oe30sIGFjYywgeyBbZmlsZUluZm8ubmFtZV06IGNsYXNzTmFtZXMgfSk7XG4gIH0sIHt9KTtcblxuICByZXR1cm4gY2xhc3NOYW1lc01lcmdlZDtcbn1cblxuLyoqXG4gKiBSZW1vdmUgdGhlIHRyYWlsaW5nIHNsYXNoIGZyb20gYSBwcm92aWRlZCBkaXJlY3RvcnlcbiAqXG4gKiBAZnVuY3Rpb24gcmVtb3ZlVHJhaWxpbmdTbGFzaFxuICogQHBhcmFtIHtzdHJpbmd9IGRpcmVjdG9yeSAtIGRpcmVjdG9yeSBwYXRoXG4gKiBAcmV0dXJuIHtzdHJpbmd9IGRpcmVjdG9yeSAtIGRpcmVjdG9yeSBwYXRoIHdpdGggdHJhaWxpbmcgc2xhc2ggcmVtb3ZlZFxuICovXG5leHBvcnQgZnVuY3Rpb24gcmVtb3ZlVHJhaWxpbmdTbGFzaChkaXJlY3RvcnkpIHtcbiAgaWYgKCcvJyA9PT0gZGlyZWN0b3J5LnNsaWNlKC0xKSkge1xuICAgIHJldHVybiBkaXJlY3Rvcnkuc2xpY2UoMCwgLTEpO1xuICB9XG5cbiAgcmV0dXJuIGRpcmVjdG9yeTtcbn1cblxuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyBzcmMvY2xpL3V0aWxzLmpzIl0sIm1hcHBpbmdzIjoiOzs7OztBQWNBO0FBa0JBO0FBcUNBO0FBcUNBO0FBY0E7QUFrQkE7QUF5QkE7QUE0Q0E7QUF5Q0E7QUF5QkE7QUF5QkE7QUFxQkE7QUEwQ0E7QUFDQTtBQXpXQTtBQUNBOzs7QUFBQTtBQUNBOzs7QUFBQTtBQUNBOzs7OztBQUNBO0FBQ0E7QUFDQTs7Ozs7OztBQVBBO0FBY0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7Ozs7QUFRQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUlBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFPQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7OztBQVFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUlBO0FBQ0E7QUFDQTtBQUdBO0FBQ0E7QUFTQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7OztBQU9BO0FBQ0E7QUFHQTtBQUNBO0FBQ0E7Ozs7Ozs7O0FBUUE7QUFDQTtBQUNBO0FBQ0E7O0FBRkE7QUFLQTtBQUNBO0FBQ0E7Ozs7Ozs7Ozs7QUFVQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7Ozs7OztBQVVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFJQTtBQUtBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7Ozs7QUFRQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBSUE7QUFLQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7OztBQVFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUtBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7Ozs7Ozs7O0FBUUE7QUFDQTtBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7Ozs7QUFRQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7Ozs7O0FBU0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFJQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7O0FBT0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0="); + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.normalizeSectionData = normalizeSectionData; +exports.writeSectionData = writeSectionData; +exports.getTemplateDataPair = getTemplateDataPair; +exports.normalizeHeader = normalizeHeader; +exports.wrapMarkup = wrapMarkup; +exports.generateFilename = generateFilename; +exports.writeFile = writeFile; +exports.removeFile = removeFile; +exports.writeSectionTemplate = writeSectionTemplate; +exports.getSection = getSection; +exports.matchKssDir = matchKssDir; +exports.mergeClassnameJSON = mergeClassnameJSON; +exports.removeTrailingSlash = removeTrailingSlash; + +var _path = __webpack_require__(0); + +var _path2 = _interopRequireDefault(_path); + +var _fsExtra = __webpack_require__(3); + +var _fsExtra2 = _interopRequireDefault(_fsExtra); + +var _chalk = __webpack_require__(2); + +var _chalk2 = _interopRequireDefault(_chalk); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +const cwd = process.cwd(); // Current working directory + +/** + * Ensure predictable data structure for KSS section data + * + * @function normalizeSectionData + * @param {object} section - section data + * @return {object} section data + */ +/** @module cli/utilities */ +function normalizeSectionData(section) { + const data = section.data || section; + + if (!data.referenceURI || '' === data.referenceURI) { + data.referenceURI = section.referenceURI(); + } + + return data; +} + +/** + * Ensure predictable data structure for KSS section data + * + * @function writeSectionData + * @param {object} store - data store + * @param {object} section - section data + * @param {string} sectionPath - output destination for section data file + */ +function writeSectionData(store, section, sectionPath = false) { + let outputPath = sectionPath; + let sectionFileInfo; + + if (!outputPath && {}.hasOwnProperty.call(section, 'kssPath')) { + sectionFileInfo = _path2.default.parse(section.kssPath); + outputPath = _path2.default.join(sectionFileInfo.dir, `${sectionFileInfo.name}.json`); + } + + // Output section data + if (outputPath) { + return writeFile(section.referenceURI, 'section', outputPath, JSON.stringify(section), store); + } + + console.warn( // eslint-disable-line no-console + _chalk2.default.red(`Failed to write section data for ${section.referenceURI}`)); + return false; +} + +/** + * Find .json from a template file or vice versa + * + * @function getTemplateDataPair + * @param {object} file - file object from path.parse() + * @param {object} section - KSS section data + * @return {string} relative path to module JSON file + */ +function getTemplateDataPair(file, section, store) { + const huron = store.get('config'); + const kssDir = matchKssDir(file.dir, huron); + + if (kssDir) { + const componentPath = _path2.default.relative(_path2.default.resolve(cwd, kssDir), file.dir); + const partnerType = '.json' === file.ext ? 'template' : 'data'; + const partnerExt = '.json' === file.ext ? huron.get('templates').extension : '.json'; + + const pairPath = _path2.default.join(componentPath, generateFilename(section.referenceURI, partnerType, partnerExt, store)); + + return `./${pairPath}`; + } + + return false; +} + +/** + * Normalize a section title for use as a filename + * + * @function normalizeHeader + * @param {string} header - section header extracted from KSS documentation + * @return {string} modified header, lowercase and words separated by dash + */ +function normalizeHeader(header) { + return header.toLowerCase().replace(/\s?\W\s?/g, '-'); +} + +/** + * Wrap html in required template tags + * + * @function wrapMarkup + * @param {string} content - html or template markup + * @param {string} templateId - id of template (should be section reference) + * @return {string} modified HTML + */ +function wrapMarkup(content, templateId) { + return ` + +\n`; +} + +/** + * Generate a filename based on referenceURI, type and file object + * + * @function generateFilename + * @param {string} id - The name of the file (with extension). + * @param {string} type - the type of file output + * @param {object} ext - file extension + * @param {store} store - data store + * @return {string} Path to output file, relative to ouput dir (can be use in require statements) + */ +function generateFilename(id, type, ext, store) { + // Type of file and its corresponding extension(s) + const types = store.get('types'); + const outputExt = '.scss' !== ext ? ext : '.html'; + + /* eslint-disable */ + if (-1 === types.indexOf(type)) { + console.log(`Huron data ${type} does not exist`); + return false; + } + /* eslint-enable */ + + return `${id}-${type}${outputExt}`; +} + +/** + * Copy an HTML file into the huron output directory. + * + * @function writeFile + * @param {string} id - The name of the file (with extension). + * @param {string} content - The content of the file to write. + * @param {string} type - the type of file output + * @param {object} store - The data store + * @return {string} Path to output file, relative to ouput dir (can be use in require statements) + */ +function writeFile(id, type, filepath, content, store) { + const huron = store.get('config'); + const file = _path2.default.parse(filepath); + const filename = generateFilename(id, type, file.ext, store); + const kssDir = matchKssDir(filepath, huron); + + if (kssDir) { + const componentPath = _path2.default.relative(_path2.default.resolve(cwd, kssDir), file.dir); + const outputRelative = _path2.default.join(huron.get('output'), componentPath, `${filename}`); + const outputPath = _path2.default.resolve(cwd, huron.get('root'), outputRelative); + let newContent = content; + + if ('data' !== type && 'section' !== type) { + newContent = wrapMarkup(content, id); + } + + try { + _fsExtra2.default.outputFileSync(outputPath, newContent); + console.log(_chalk2.default.green(`Writing ${outputRelative}`)); // eslint-disable-line no-console + } catch (e) { + console.log(_chalk2.default.red(`Failed to write ${outputRelative}`)); // eslint-disable-line no-console + } + + return `./${outputRelative.replace(`${huron.get('output')}/`, '')}`; + } + + return false; +} + +/** + * Delete a file in the huron output directory + * + * @function removeFile + * @param {string} filename - The name of the file (with extension). + * @param {object} store - The data store + * @return {string} Path to output file, relative to ouput dir (can be use in require statements) + */ +function removeFile(id, type, filepath, store) { + const huron = store.get('config'); + const file = _path2.default.parse(filepath); + const filename = generateFilename(id, type, file.ext, store); + const kssDir = matchKssDir(filepath, huron); + + if (kssDir) { + const componentPath = _path2.default.relative(_path2.default.resolve(cwd, kssDir), file.dir); + const outputRelative = _path2.default.join(huron.get('output'), componentPath, `${filename}`); + const outputPath = _path2.default.resolve(cwd, huron.get('root'), outputRelative); + + try { + _fsExtra2.default.removeSync(outputPath); + console.log(_chalk2.default.green(`Removing ${outputRelative}`)); // eslint-disable-line no-console + } catch (e) { + console.log( // eslint-disable-line no-console + _chalk2.default.red(`${outputRelative} does not exist or cannot be deleted`)); + } + + return `./${outputRelative.replace(`${huron.get('output')}/`, '')}`; + } + + return false; +} + +/** + * Write a template for sections + * + * @function writeSectionTemplate + * @param {string} filepath - the original template file + * @param {object} store - data store + * @return {object} updated store + */ +function writeSectionTemplate(filepath, store) { + const huron = store.get('config'); + const sectionTemplate = wrapMarkup(_fsExtra2.default.readFileSync(filepath, 'utf8')); + const componentPath = './huron-assets/section.hbs'; + const output = _path2.default.join(cwd, huron.get('root'), componentPath); + + // Move huron script and section template into huron root + _fsExtra2.default.outputFileSync(output, sectionTemplate); + console.log(_chalk2.default.green(`writing section template to ${output}`)); // eslint-disable-line no-console + + return store.set('sectionTemplatePath', componentPath); +} + +/** + * Request for section data based on section reference + * + * @function writeSectionTemplate + * @param {string} search - key on which to match section + * @param {field} string - field in which to look to determine section + * @param {obj} store - sections memory store + */ +function getSection(search, field, store) { + const sectionValues = store.getIn(['sections', 'sectionsByPath']).valueSeq(); + let selectedSection = false; + + if (field) { + selectedSection = sectionValues.filter(value => value[field] === search).get(0); + } else { + selectedSection = store.getIn(['sections', 'sectionsByPath', search]); + } + + return selectedSection; +} + +/** + * Find which configured KSS directory a filepath exists in + * + * @function matchKssDir + * @param {string} filepath - filepath to search for + * @param {object} huron - huron configuration + * @return {string} kssMatch - relative path to KSS directory + */ +function matchKssDir(filepath, huron) { + const kssSource = huron.get('kss'); + // Include forward slash in our test to make sure we're matchin a directory, not a file extension + const kssMatch = kssSource.filter(dir => filepath.includes(`/${dir}`)); + + if (kssMatch.length) { + return kssMatch[0]; + } + + return false; +} + +/** + * Merge JSON files for css modules classnames in a provided directory + * + * @function mergeClassnameJSON + * @param {string} directory - directory containing classname JSON files + * + * @return {object} classnamesMerged - merged classnames. contents of each JSON file is nested within + * the returned object by filename. (e.g. article.json -> { article: {...json contents}}) + */ +function mergeClassnameJSON(directory) { + let files; + + // Try to read through classnames directory + try { + files = _fsExtra2.default.readdirSync(directory); + } catch (e) { + console.warn(_chalk2.default.red(e)); + return {}; + } + + // Merge classname json files + const classNamesMerged = files.reduce((acc, file) => { + const fileInfo = _path2.default.parse(file); + let classNames = {}; + + if ('.json' === fileInfo.ext) { + try { + const contents = _fsExtra2.default.readFileSync(_path2.default.join(directory, file), 'utf8'); + classNames = JSON.parse(contents); + } catch (e) { + console.warn(_chalk2.default.red(e)); + return classNames; + } + } + + return Object.assign({}, acc, { [fileInfo.name]: classNames }); + }, {}); + + return classNamesMerged; +} + +/** + * Remove the trailing slash from a provided directory + * + * @function removeTrailingSlash + * @param {string} directory - directory path + * @return {string} directory - directory path with trailing slash removed + */ +function removeTrailingSlash(directory) { + if ('/' === directory.slice(-1)) { + return directory.slice(0, -1); + } + + return directory; +} /***/ }), /* 2 */ -/* no static exports found */ -/* all exports used */ -/*!************************!*\ - !*** external "chalk" ***! - \************************/ /***/ (function(module, exports) { -eval("module.exports = require(\"chalk\");//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMi5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy9leHRlcm5hbCBcImNoYWxrXCI/NTNmNyJdLCJzb3VyY2VzQ29udGVudCI6WyJtb2R1bGUuZXhwb3J0cyA9IHJlcXVpcmUoXCJjaGFsa1wiKTtcblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyBleHRlcm5hbCBcImNoYWxrXCJcbi8vIG1vZHVsZSBpZCA9IDJcbi8vIG1vZHVsZSBjaHVua3MgPSAwIl0sIm1hcHBpbmdzIjoiQUFBQSIsInNvdXJjZVJvb3QiOiIifQ=="); +module.exports = require("chalk"); /***/ }), /* 3 */ -/* no static exports found */ -/* all exports used */ -/*!***************************!*\ - !*** external "fs-extra" ***! - \***************************/ /***/ (function(module, exports) { -eval("module.exports = require(\"fs-extra\");//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy9leHRlcm5hbCBcImZzLWV4dHJhXCI/N2NhNiJdLCJzb3VyY2VzQ29udGVudCI6WyJtb2R1bGUuZXhwb3J0cyA9IHJlcXVpcmUoXCJmcy1leHRyYVwiKTtcblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyBleHRlcm5hbCBcImZzLWV4dHJhXCJcbi8vIG1vZHVsZSBpZCA9IDNcbi8vIG1vZHVsZSBjaHVua3MgPSAwIl0sIm1hcHBpbmdzIjoiQUFBQSIsInNvdXJjZVJvb3QiOiIifQ=="); +module.exports = require("fs-extra"); /***/ }), /* 4 */ -/* no static exports found */ -/* all exports used */ -/*!******************************!*\ - !*** ./src/cli/parseArgs.js ***! - \******************************/ /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _commander = __webpack_require__(/*! commander */ 21);\n\nvar _commander2 = _interopRequireDefault(_commander);\n\nvar _path = __webpack_require__(/*! path */ 0);\n\nvar _path2 = _interopRequireDefault(_path);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n// Requires\n/** @global */\n\n/**\n * Process huron CLI arguments\n *\n * @function parseArgs\n * @example node huron/dist/cli/huron-cli.js --config 'client/config/webpack.config.js' --production\n */\n/** @module cli/parse-arguments */\n/* eslint-disable space-unary-ops */\n\nfunction parseArgs() {\n const envArg = {};\n\n process.argv = process.argv.filter(arg => {\n if (-1 !== arg.indexOf('--env')) {\n const envParts = arg.split('.')[1].split('=');\n\n envArg[envParts[0]] = envParts[1] || true;\n return false;\n }\n\n return true;\n });\n\n _commander2.default.version('1.0.1').option('-c, --huron-config [huronConfig]', '[huronConfig] for all huron options', _path2.default.resolve(__dirname, '../defaultConfig/huron.config.js')).option('-w, --webpack-config [webpackConfig]', '[webpackConfig] for all webpack options', _path2.default.resolve(__dirname, '../defaultConfig/webpack.config.js')).option('-p, --production', 'compile assets once for production');\n\n _commander2.default.env = envArg;\n\n // Only parse if we're not running tests\n if (!process.env.npm_lifecycle_event || 'test' !== process.env.npm_lifecycle_event) {\n _commander2.default.parse(process.argv);\n }\n}\n\nparseArgs();\n/* eslint-enable */\n\nexports.default = _commander2.default;//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy9zcmMvY2xpL3BhcnNlQXJncy5qcz9iYTdmIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBAbW9kdWxlIGNsaS9wYXJzZS1hcmd1bWVudHMgKi9cbi8qIGVzbGludC1kaXNhYmxlIHNwYWNlLXVuYXJ5LW9wcyAqL1xuXG5pbXBvcnQgcHJvZ3JhbSBmcm9tICdjb21tYW5kZXInO1xuaW1wb3J0IHBhdGggZnJvbSAncGF0aCc7XG5cbi8vIFJlcXVpcmVzXG4vKiogQGdsb2JhbCAqL1xuXG4vKipcbiAqIFByb2Nlc3MgaHVyb24gQ0xJIGFyZ3VtZW50c1xuICpcbiAqIEBmdW5jdGlvbiBwYXJzZUFyZ3NcbiAqIEBleGFtcGxlIG5vZGUgaHVyb24vZGlzdC9jbGkvaHVyb24tY2xpLmpzIC0tY29uZmlnICdjbGllbnQvY29uZmlnL3dlYnBhY2suY29uZmlnLmpzJyAtLXByb2R1Y3Rpb25cbiAqL1xuZnVuY3Rpb24gcGFyc2VBcmdzKCkge1xuICBjb25zdCBlbnZBcmcgPSB7fTtcblxuICBwcm9jZXNzLmFyZ3YgPSBwcm9jZXNzLmFyZ3YuZmlsdGVyKChhcmcpID0+IHtcbiAgICBpZiAoLTEgIT09IGFyZy5pbmRleE9mKCctLWVudicpKSB7XG4gICAgICBjb25zdCBlbnZQYXJ0cyA9IGFyZ1xuICAgICAgICAuc3BsaXQoJy4nKVsxXVxuICAgICAgICAuc3BsaXQoJz0nKTtcblxuICAgICAgZW52QXJnW2VudlBhcnRzWzBdXSA9IGVudlBhcnRzWzFdIHx8IHRydWU7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuXG4gICAgcmV0dXJuIHRydWU7XG4gIH0pO1xuXG4gIHByb2dyYW0udmVyc2lvbignMS4wLjEnKVxuICAgIC5vcHRpb24oXG4gICAgICAnLWMsIC0taHVyb24tY29uZmlnIFtodXJvbkNvbmZpZ10nLFxuICAgICAgJ1todXJvbkNvbmZpZ10gZm9yIGFsbCBodXJvbiBvcHRpb25zJyxcbiAgICAgIHBhdGgucmVzb2x2ZShfX2Rpcm5hbWUsICcuLi9kZWZhdWx0Q29uZmlnL2h1cm9uLmNvbmZpZy5qcycpXG4gICAgKVxuICAgIC5vcHRpb24oXG4gICAgICAnLXcsIC0td2VicGFjay1jb25maWcgW3dlYnBhY2tDb25maWddJyxcbiAgICAgICdbd2VicGFja0NvbmZpZ10gZm9yIGFsbCB3ZWJwYWNrIG9wdGlvbnMnLFxuICAgICAgcGF0aC5yZXNvbHZlKF9fZGlybmFtZSwgJy4uL2RlZmF1bHRDb25maWcvd2VicGFjay5jb25maWcuanMnKVxuICAgIClcbiAgICAub3B0aW9uKCctcCwgLS1wcm9kdWN0aW9uJywgJ2NvbXBpbGUgYXNzZXRzIG9uY2UgZm9yIHByb2R1Y3Rpb24nKTtcblxuICBwcm9ncmFtLmVudiA9IGVudkFyZztcblxuICAvLyBPbmx5IHBhcnNlIGlmIHdlJ3JlIG5vdCBydW5uaW5nIHRlc3RzXG4gIGlmIChcbiAgICAhIHByb2Nlc3MuZW52Lm5wbV9saWZlY3ljbGVfZXZlbnQgfHxcbiAgICAndGVzdCcgIT09IHByb2Nlc3MuZW52Lm5wbV9saWZlY3ljbGVfZXZlbnRcbiAgKSB7XG4gICAgcHJvZ3JhbS5wYXJzZShwcm9jZXNzLmFyZ3YpO1xuICB9XG59XG5cbnBhcnNlQXJncygpO1xuLyogZXNsaW50LWVuYWJsZSAqL1xuXG5leHBvcnQgZGVmYXVsdCBwcm9ncmFtO1xuXG5cblxuLy8gV0VCUEFDSyBGT09URVIgLy9cbi8vIHNyYy9jbGkvcGFyc2VBcmdzLmpzIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFHQTtBQUNBOzs7QUFBQTtBQUNBOzs7OztBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7QUFUQTtBQUNBO0FBQ0E7QUFhQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQVlBO0FBQ0E7QUFDQTtBQUNBO0FBSUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QSIsInNvdXJjZVJvb3QiOiIifQ=="); + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _commander = __webpack_require__(21); + +var _commander2 = _interopRequireDefault(_commander); + +var _path = __webpack_require__(0); + +var _path2 = _interopRequireDefault(_path); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +// Requires +/** @global */ + +/** + * Process huron CLI arguments + * + * @function parseArgs + * @example node huron/dist/cli/huron-cli.js --config 'client/config/webpack.config.js' --production + */ +/** @module cli/parse-arguments */ +/* eslint-disable space-unary-ops */ + +function parseArgs() { + const envArg = {}; + + process.argv = process.argv.filter(arg => { + if (-1 !== arg.indexOf('--env')) { + const envParts = arg.split('.')[1].split('='); + + envArg[envParts[0]] = envParts[1] || true; + return false; + } + + return true; + }); + + _commander2.default.version('1.0.1').option('-c, --huron-config [huronConfig]', '[huronConfig] for all huron options', _path2.default.resolve(__dirname, '../defaultConfig/huron.config.js')).option('-w, --webpack-config [webpackConfig]', '[webpackConfig] for all webpack options', _path2.default.resolve(__dirname, '../defaultConfig/webpack.config.js')).option('-p, --production', 'compile assets once for production'); + + _commander2.default.env = envArg; + + // Only parse if we're not running tests + if (!process.env.npm_lifecycle_event || 'test' !== process.env.npm_lifecycle_event) { + _commander2.default.parse(process.argv); + } +} + +parseArgs(); +/* eslint-enable */ + +exports.default = _commander2.default; /***/ }), /* 5 */ -/* no static exports found */ -/* all exports used */ -/*!**************************!*\ - !*** external "webpack" ***! - \**************************/ /***/ (function(module, exports) { -eval("module.exports = require(\"webpack\");//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy9leHRlcm5hbCBcIndlYnBhY2tcIj8zOTNkIl0sInNvdXJjZXNDb250ZW50IjpbIm1vZHVsZS5leHBvcnRzID0gcmVxdWlyZShcIndlYnBhY2tcIik7XG5cblxuLy8vLy8vLy8vLy8vLy8vLy8vXG4vLyBXRUJQQUNLIEZPT1RFUlxuLy8gZXh0ZXJuYWwgXCJ3ZWJwYWNrXCJcbi8vIG1vZHVsZSBpZCA9IDVcbi8vIG1vZHVsZSBjaHVua3MgPSAwIl0sIm1hcHBpbmdzIjoiQUFBQSIsInNvdXJjZVJvb3QiOiIifQ=="); +module.exports = require("webpack"); /***/ }), /* 6 */ -/* no static exports found */ -/* all exports used */ -/*!*********************************!*\ - !*** ./src/cli/defaultStore.js ***! - \*********************************/ /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.config = exports.defaultStore = undefined;\n\nvar _immutable = __webpack_require__(/*! immutable */ 24);\n\nvar _generateConfig = __webpack_require__(/*! ./generateConfig */ 13);\n\nvar _generateConfig2 = _interopRequireDefault(_generateConfig);\n\nvar _utils = __webpack_require__(/*! ./utils */ 1);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n// Create initial data structure\n\n// Merge Huron default webpack config with user config\nconst config = (0, _generateConfig2.default)();\n\n// Make sure the kss option is represented as an array\nconfig.huron.kss = [].concat(config.huron.kss);\n\n/* eslint-disable */\n/**\n * Initial structure for immutable data store\n *\n * @global\n */\nconst defaultStore = (0, _immutable.Map)({\n types: ['template', 'data', 'description', 'section', 'prototype', 'sections-template'],\n config: (0, _immutable.Map)(config.huron),\n classNames: (0, _utils.mergeClassnameJSON)(config.huron.classNames),\n sections: (0, _immutable.Map)({\n sectionsByPath: (0, _immutable.Map)({}),\n sectionsByURI: (0, _immutable.Map)({}),\n sorted: {}\n }),\n templates: (0, _immutable.Map)({}),\n prototypes: (0, _immutable.Map)({}),\n sectionTemplatePath: '',\n referenceDelimiter: '.'\n});\n/* eslint-enable */\n\nexports.defaultStore = defaultStore;\nexports.config = config;//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNi5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy9zcmMvY2xpL2RlZmF1bHRTdG9yZS5qcz8zNzBmIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1hcCB9IGZyb20gJ2ltbXV0YWJsZSc7XG5cbmltcG9ydCBnZW5lcmF0ZUNvbmZpZyBmcm9tICcuL2dlbmVyYXRlQ29uZmlnJztcbmltcG9ydCB7IG1lcmdlQ2xhc3NuYW1lSlNPTiB9IGZyb20gJy4vdXRpbHMnO1xuLy8gQ3JlYXRlIGluaXRpYWwgZGF0YSBzdHJ1Y3R1cmVcblxuLy8gTWVyZ2UgSHVyb24gZGVmYXVsdCB3ZWJwYWNrIGNvbmZpZyB3aXRoIHVzZXIgY29uZmlnXG5jb25zdCBjb25maWcgPSBnZW5lcmF0ZUNvbmZpZygpO1xuXG4vLyBNYWtlIHN1cmUgdGhlIGtzcyBvcHRpb24gaXMgcmVwcmVzZW50ZWQgYXMgYW4gYXJyYXlcbmNvbmZpZy5odXJvbi5rc3MgPSBbXS5jb25jYXQoY29uZmlnLmh1cm9uLmtzcyk7XG5cbi8qIGVzbGludC1kaXNhYmxlICovXG4vKipcbiAqIEluaXRpYWwgc3RydWN0dXJlIGZvciBpbW11dGFibGUgZGF0YSBzdG9yZVxuICpcbiAqIEBnbG9iYWxcbiAqL1xuY29uc3QgZGVmYXVsdFN0b3JlID0gTWFwKHtcbiAgdHlwZXM6IFtcbiAgICAndGVtcGxhdGUnLFxuICAgICdkYXRhJyxcbiAgICAnZGVzY3JpcHRpb24nLFxuICAgICdzZWN0aW9uJyxcbiAgICAncHJvdG90eXBlJyxcbiAgICAnc2VjdGlvbnMtdGVtcGxhdGUnLFxuICBdLFxuICBjb25maWc6IE1hcChjb25maWcuaHVyb24pLFxuICBjbGFzc05hbWVzOiBtZXJnZUNsYXNzbmFtZUpTT04oY29uZmlnLmh1cm9uLmNsYXNzTmFtZXMpLFxuICBzZWN0aW9uczogTWFwKHtcbiAgICBzZWN0aW9uc0J5UGF0aDogTWFwKHt9KSxcbiAgICBzZWN0aW9uc0J5VVJJOiBNYXAoe30pLFxuICAgIHNvcnRlZDoge30sXG4gIH0pLFxuICB0ZW1wbGF0ZXM6IE1hcCh7fSksXG4gIHByb3RvdHlwZXM6IE1hcCh7fSksXG4gIHNlY3Rpb25UZW1wbGF0ZVBhdGg6ICcnLFxuICByZWZlcmVuY2VEZWxpbWl0ZXI6ICcuJyxcbn0pO1xuLyogZXNsaW50LWVuYWJsZSAqL1xuXG5leHBvcnQgeyBkZWZhdWx0U3RvcmUsIGNvbmZpZyB9O1xuXG5cblxuLy8gV0VCUEFDSyBGT09URVIgLy9cbi8vIHNyYy9jbGkvZGVmYXVsdFN0b3JlLmpzIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7QUFDQTtBQUNBO0FBQ0E7OztBQUFBO0FBQ0E7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7OztBQUtBO0FBQ0E7QUFRQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFIQTtBQUtBO0FBQ0E7QUFDQTtBQUNBO0FBbkJBO0FBcUJBO0FBQ0E7QUFDQTtBQUFBIiwic291cmNlUm9vdCI6IiJ9"); + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.config = exports.defaultStore = undefined; + +var _immutable = __webpack_require__(24); + +var _generateConfig = __webpack_require__(13); + +var _generateConfig2 = _interopRequireDefault(_generateConfig); + +var _utils = __webpack_require__(1); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +// Create initial data structure + +// Merge Huron default webpack config with user config +const config = (0, _generateConfig2.default)(); + +// Make sure the kss option is represented as an array +config.huron.kss = [].concat(config.huron.kss); + +/* eslint-disable */ +/** + * Initial structure for immutable data store + * + * @global + */ +const defaultStore = (0, _immutable.Map)({ + types: ['template', 'data', 'description', 'section', 'prototype', 'sections-template'], + config: (0, _immutable.Map)(config.huron), + classNames: (0, _utils.mergeClassnameJSON)(config.huron.classNames), + sections: (0, _immutable.Map)({ + sectionsByPath: (0, _immutable.Map)({}), + sectionsByURI: (0, _immutable.Map)({}), + sorted: {} + }), + templates: (0, _immutable.Map)({}), + prototypes: (0, _immutable.Map)({}), + sectionTemplatePath: '', + referenceDelimiter: '.' +}); +/* eslint-enable */ + +exports.defaultStore = defaultStore; +exports.config = config; /***/ }), /* 7 */ -/* no static exports found */ -/* all exports used */ -/*!************************************!*\ - !*** ./src/cli/handleTemplates.js ***! - \************************************/ /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.updateTemplate = updateTemplate;\nexports.deleteTemplate = deleteTemplate;\n\nvar _path = __webpack_require__(/*! path */ 0);\n\nvar _path2 = _interopRequireDefault(_path);\n\nvar _fsExtra = __webpack_require__(/*! fs-extra */ 3);\n\nvar _fsExtra2 = _interopRequireDefault(_fsExtra);\n\nvar _chalk = __webpack_require__(/*! chalk */ 2);\n\nvar _chalk2 = _interopRequireDefault(_chalk);\n\nvar _utils = __webpack_require__(/*! ./utils */ 1);\n\nvar utils = _interopRequireWildcard(_utils);\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Handle update of a template or data (json) file\n *\n * @function updateTemplate\n * @param {string} filepath - filepath of changed file (comes from gaze)\n * @param {object} section - contains KSS section data\n * @param {object} store - memory store\n * @return {object} updated memory store\n */\n/** @module cli/template-handler */\nfunction updateTemplate(filepath, section, store) {\n const file = _path2.default.parse(filepath);\n const pairPath = utils.getTemplateDataPair(file, section, store);\n const type = '.json' === file.ext ? 'data' : 'template';\n const newSection = section;\n const newStore = store;\n let content = false;\n\n try {\n content = _fsExtra2.default.readFileSync(filepath, 'utf8');\n } catch (e) {\n console.log(_chalk2.default.red(`${filepath} does not exist`));\n }\n\n if (content) {\n const requirePath = utils.writeFile(newSection.referenceURI, type, filepath, content, newStore);\n newSection[`${type}Path`] = requirePath;\n\n if ('template' === type) {\n newSection.templateContent = content;\n\n // Rewrite section data with template content\n newSection.sectionPath = utils.writeSectionData(newStore, newSection);\n }\n\n return newStore.setIn(['templates', requirePath], pairPath).setIn(['sections', 'sectionsByPath', newSection.kssPath], newSection).setIn(['sections', 'sectionsByURI', newSection.referenceURI], newSection);\n }\n\n return newStore;\n}\n\n/**\n * Handle removal of a template or data (json) file\n *\n * @function deleteTemplate\n * @param {string} filepath - filepath of changed file (comes from gaze)\n * @param {object} section - contains KSS section data\n * @param {object} store - memory store\n * @return {object} updated memory store\n */\nfunction deleteTemplate(filepath, section, store) {\n const file = _path2.default.parse(filepath);\n const type = '.json' === file.ext ? 'data' : 'template';\n const newSection = section;\n const newStore = store;\n\n // Remove partner\n const requirePath = utils.removeFile(newSection.referenceURI, type, filepath, newStore);\n delete newSection[`${type}Path`];\n\n return newStore.deleteIn(['templates', requirePath]).setIn(['sections', 'sectionsByPath', newSection.kssPath], newSection).setIn(['sections', 'sectionsByURI', newSection.referenceURI], newSection);\n}//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy9zcmMvY2xpL2hhbmRsZVRlbXBsYXRlcy5qcz8yYzdmIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBAbW9kdWxlIGNsaS90ZW1wbGF0ZS1oYW5kbGVyICovXG5pbXBvcnQgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCBmcyBmcm9tICdmcy1leHRyYSc7XG5pbXBvcnQgY2hhbGsgZnJvbSAnY2hhbGsnO1xuXG5pbXBvcnQgKiBhcyB1dGlscyBmcm9tICcuL3V0aWxzJztcblxuLyoqXG4gKiBIYW5kbGUgdXBkYXRlIG9mIGEgdGVtcGxhdGUgb3IgZGF0YSAoanNvbikgZmlsZVxuICpcbiAqIEBmdW5jdGlvbiB1cGRhdGVUZW1wbGF0ZVxuICogQHBhcmFtIHtzdHJpbmd9IGZpbGVwYXRoIC0gZmlsZXBhdGggb2YgY2hhbmdlZCBmaWxlIChjb21lcyBmcm9tIGdhemUpXG4gKiBAcGFyYW0ge29iamVjdH0gc2VjdGlvbiAtIGNvbnRhaW5zIEtTUyBzZWN0aW9uIGRhdGFcbiAqIEBwYXJhbSB7b2JqZWN0fSBzdG9yZSAtIG1lbW9yeSBzdG9yZVxuICogQHJldHVybiB7b2JqZWN0fSB1cGRhdGVkIG1lbW9yeSBzdG9yZVxuICovXG5leHBvcnQgZnVuY3Rpb24gdXBkYXRlVGVtcGxhdGUoZmlsZXBhdGgsIHNlY3Rpb24sIHN0b3JlKSB7XG4gIGNvbnN0IGZpbGUgPSBwYXRoLnBhcnNlKGZpbGVwYXRoKTtcbiAgY29uc3QgcGFpclBhdGggPSB1dGlscy5nZXRUZW1wbGF0ZURhdGFQYWlyKGZpbGUsIHNlY3Rpb24sIHN0b3JlKTtcbiAgY29uc3QgdHlwZSA9ICcuanNvbicgPT09IGZpbGUuZXh0ID8gJ2RhdGEnIDogJ3RlbXBsYXRlJztcbiAgY29uc3QgbmV3U2VjdGlvbiA9IHNlY3Rpb247XG4gIGNvbnN0IG5ld1N0b3JlID0gc3RvcmU7XG4gIGxldCBjb250ZW50ID0gZmFsc2U7XG5cbiAgdHJ5IHtcbiAgICBjb250ZW50ID0gZnMucmVhZEZpbGVTeW5jKGZpbGVwYXRoLCAndXRmOCcpO1xuICB9IGNhdGNoIChlKSB7XG4gICAgY29uc29sZS5sb2coY2hhbGsucmVkKGAke2ZpbGVwYXRofSBkb2VzIG5vdCBleGlzdGApKTtcbiAgfVxuXG4gIGlmIChjb250ZW50KSB7XG4gICAgY29uc3QgcmVxdWlyZVBhdGggPSB1dGlscy53cml0ZUZpbGUoXG4gICAgICBuZXdTZWN0aW9uLnJlZmVyZW5jZVVSSSxcbiAgICAgIHR5cGUsXG4gICAgICBmaWxlcGF0aCxcbiAgICAgIGNvbnRlbnQsXG4gICAgICBuZXdTdG9yZVxuICAgICk7XG4gICAgbmV3U2VjdGlvbltgJHt0eXBlfVBhdGhgXSA9IHJlcXVpcmVQYXRoO1xuXG4gICAgaWYgKCd0ZW1wbGF0ZScgPT09IHR5cGUpIHtcbiAgICAgIG5ld1NlY3Rpb24udGVtcGxhdGVDb250ZW50ID0gY29udGVudDtcblxuICAgICAgLy8gUmV3cml0ZSBzZWN0aW9uIGRhdGEgd2l0aCB0ZW1wbGF0ZSBjb250ZW50XG4gICAgICBuZXdTZWN0aW9uLnNlY3Rpb25QYXRoID0gdXRpbHMud3JpdGVTZWN0aW9uRGF0YShuZXdTdG9yZSwgbmV3U2VjdGlvbik7XG4gICAgfVxuXG4gICAgcmV0dXJuIG5ld1N0b3JlXG4gICAgICAuc2V0SW4oXG4gICAgICAgIFsndGVtcGxhdGVzJywgcmVxdWlyZVBhdGhdLFxuICAgICAgICBwYWlyUGF0aFxuICAgICAgKVxuICAgICAgLnNldEluKFxuICAgICAgICBbJ3NlY3Rpb25zJywgJ3NlY3Rpb25zQnlQYXRoJywgbmV3U2VjdGlvbi5rc3NQYXRoXSxcbiAgICAgICAgbmV3U2VjdGlvblxuICAgICAgKVxuICAgICAgLnNldEluKFxuICAgICAgICBbJ3NlY3Rpb25zJywgJ3NlY3Rpb25zQnlVUkknLCBuZXdTZWN0aW9uLnJlZmVyZW5jZVVSSV0sXG4gICAgICAgIG5ld1NlY3Rpb25cbiAgICAgICk7XG4gIH1cblxuICByZXR1cm4gbmV3U3RvcmU7XG59XG5cbi8qKlxuICogSGFuZGxlIHJlbW92YWwgb2YgYSB0ZW1wbGF0ZSBvciBkYXRhIChqc29uKSBmaWxlXG4gKlxuICogQGZ1bmN0aW9uIGRlbGV0ZVRlbXBsYXRlXG4gKiBAcGFyYW0ge3N0cmluZ30gZmlsZXBhdGggLSBmaWxlcGF0aCBvZiBjaGFuZ2VkIGZpbGUgKGNvbWVzIGZyb20gZ2F6ZSlcbiAqIEBwYXJhbSB7b2JqZWN0fSBzZWN0aW9uIC0gY29udGFpbnMgS1NTIHNlY3Rpb24gZGF0YVxuICogQHBhcmFtIHtvYmplY3R9IHN0b3JlIC0gbWVtb3J5IHN0b3JlXG4gKiBAcmV0dXJuIHtvYmplY3R9IHVwZGF0ZWQgbWVtb3J5IHN0b3JlXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBkZWxldGVUZW1wbGF0ZShmaWxlcGF0aCwgc2VjdGlvbiwgc3RvcmUpIHtcbiAgY29uc3QgZmlsZSA9IHBhdGgucGFyc2UoZmlsZXBhdGgpO1xuICBjb25zdCB0eXBlID0gJy5qc29uJyA9PT0gZmlsZS5leHQgPyAnZGF0YScgOiAndGVtcGxhdGUnO1xuICBjb25zdCBuZXdTZWN0aW9uID0gc2VjdGlvbjtcbiAgY29uc3QgbmV3U3RvcmUgPSBzdG9yZTtcblxuICAvLyBSZW1vdmUgcGFydG5lclxuICBjb25zdCByZXF1aXJlUGF0aCA9IHV0aWxzLnJlbW92ZUZpbGUoXG4gICAgbmV3U2VjdGlvbi5yZWZlcmVuY2VVUkksXG4gICAgdHlwZSxcbiAgICBmaWxlcGF0aCxcbiAgICBuZXdTdG9yZVxuICApO1xuICBkZWxldGUgbmV3U2VjdGlvbltgJHt0eXBlfVBhdGhgXTtcblxuICByZXR1cm4gbmV3U3RvcmVcbiAgICAuZGVsZXRlSW4oWyd0ZW1wbGF0ZXMnLCByZXF1aXJlUGF0aF0pXG4gICAgLnNldEluKFxuICAgICAgWydzZWN0aW9ucycsICdzZWN0aW9uc0J5UGF0aCcsIG5ld1NlY3Rpb24ua3NzUGF0aF0sXG4gICAgICBuZXdTZWN0aW9uXG4gICAgKVxuICAgIC5zZXRJbihcbiAgICAgIFsnc2VjdGlvbnMnLCAnc2VjdGlvbnNCeVVSSScsIG5ld1NlY3Rpb24ucmVmZXJlbmNlVVJJXSxcbiAgICAgIG5ld1NlY3Rpb25cbiAgICApO1xufVxuXG5cblxuLy8gV0VCUEFDSyBGT09URVIgLy9cbi8vIHNyYy9jbGkvaGFuZGxlVGVtcGxhdGVzLmpzIl0sIm1hcHBpbmdzIjoiOzs7OztBQWdCQTtBQTBEQTtBQUNBO0FBMUVBO0FBQ0E7OztBQUFBO0FBQ0E7OztBQUFBO0FBQ0E7OztBQUNBO0FBQ0E7QUFEQTtBQUNBOzs7OztBQUNBOzs7Ozs7Ozs7QUFQQTtBQWdCQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQU9BO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBYUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7Ozs7QUFTQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBTUE7QUFDQTtBQUNBO0FBVUEiLCJzb3VyY2VSb290IjoiIn0="); + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.updateTemplate = updateTemplate; +exports.deleteTemplate = deleteTemplate; + +var _path = __webpack_require__(0); + +var _path2 = _interopRequireDefault(_path); + +var _fsExtra = __webpack_require__(3); + +var _fsExtra2 = _interopRequireDefault(_fsExtra); + +var _chalk = __webpack_require__(2); + +var _chalk2 = _interopRequireDefault(_chalk); + +var _utils = __webpack_require__(1); + +var utils = _interopRequireWildcard(_utils); + +function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Handle update of a template or data (json) file + * + * @function updateTemplate + * @param {string} filepath - filepath of changed file (comes from gaze) + * @param {object} section - contains KSS section data + * @param {object} store - memory store + * @return {object} updated memory store + */ +/** @module cli/template-handler */ +function updateTemplate(filepath, section, store) { + const file = _path2.default.parse(filepath); + const pairPath = utils.getTemplateDataPair(file, section, store); + const type = '.json' === file.ext ? 'data' : 'template'; + const newSection = section; + const newStore = store; + let content = false; + + try { + content = _fsExtra2.default.readFileSync(filepath, 'utf8'); + } catch (e) { + console.log(_chalk2.default.red(`${filepath} does not exist`)); + } + + if (content) { + const requirePath = utils.writeFile(newSection.referenceURI, type, filepath, content, newStore); + newSection[`${type}Path`] = requirePath; + + if ('template' === type) { + newSection.templateContent = content; + + // Rewrite section data with template content + newSection.sectionPath = utils.writeSectionData(newStore, newSection); + } + + return newStore.setIn(['templates', requirePath], pairPath).setIn(['sections', 'sectionsByPath', newSection.kssPath], newSection).setIn(['sections', 'sectionsByURI', newSection.referenceURI], newSection); + } + + return newStore; +} + +/** + * Handle removal of a template or data (json) file + * + * @function deleteTemplate + * @param {string} filepath - filepath of changed file (comes from gaze) + * @param {object} section - contains KSS section data + * @param {object} store - memory store + * @return {object} updated memory store + */ +function deleteTemplate(filepath, section, store) { + const file = _path2.default.parse(filepath); + const type = '.json' === file.ext ? 'data' : 'template'; + const newSection = section; + const newStore = store; + + // Remove partner + const requirePath = utils.removeFile(newSection.referenceURI, type, filepath, newStore); + delete newSection[`${type}Path`]; + + return newStore.deleteIn(['templates', requirePath]).setIn(['sections', 'sectionsByPath', newSection.kssPath], newSection).setIn(['sections', 'sectionsByURI', newSection.referenceURI], newSection); +} /***/ }), /* 8 */ -/* no static exports found */ -/* all exports used */ -/*!*************************************!*\ - !*** ./src/cli/requireTemplates.js ***! - \*************************************/ /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.writeStore = exports.requireTemplates = undefined;\n\nvar _path = __webpack_require__(/*! path */ 0);\n\nvar _path2 = _interopRequireDefault(_path);\n\nvar _fsExtra = __webpack_require__(/*! fs-extra */ 3);\n\nvar _fsExtra2 = _interopRequireDefault(_fsExtra);\n\nvar _hotTemplate = __webpack_require__(/*! raw-loader!babel-loader!../../templates/hotTemplate */ 31);\n\nvar _hotTemplate2 = _interopRequireDefault(_hotTemplate);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/* eslint-enable */\n\nconst cwd = process.cwd();\n\n// We need to prepend this to the browser script as a string but still want to transpile it,\n// hence loading it using `raw-loader` so we receive a string from webpack\n/* eslint-disable */\n/** @module cli/require-templates */\n\nconst huronScript = _fsExtra2.default.readFileSync(_path2.default.join(__dirname, '../web/index.js'), 'utf8');\n\n/**\n * Write code for requiring all generated huron assets\n *\n * @function requireTemplates\n * @param {object} store - memory store\n */\nconst requireTemplates = exports.requireTemplates = function requireTemplates(store) {\n const huron = store.get('config');\n const outputPath = _path2.default.join(cwd, huron.get('root'), 'huron-assets');\n // These will be used to replace strings in the hotTemplate.\n // In order to accurately replace strings but still keep things parseable by eslint and babel,\n // each replaceable value should be referenced in `hotTemplate.js` under the `hotScope` object.\n // For example, if you need to replace a string with a value passed in from the CLI called `userVariable`,\n // you would reference that string in `hotTemplate.js` with `hotScope.userVariable`.\n const hotVariableScope = {\n sectionTemplatePath: `'${huron.get('sectionTemplate')}'`,\n requireRegex: new RegExp(`\\\\.html|\\\\.json|\\\\${huron.get('templates').extension}$`),\n requirePath: `'../${huron.get('output')}'`\n };\n const hotTemplateTransformed = Object.keys(hotVariableScope).reduce((acc, curr) => acc.replace(new RegExp(`hotScope.${curr}`, 'g'), hotVariableScope[curr]), _hotTemplate2.default);\n\n // Write the contents of this script.\n _fsExtra2.default.outputFileSync(_path2.default.join(outputPath, 'index.js'), hotTemplateTransformed);\n _fsExtra2.default.outputFileSync(_path2.default.join(outputPath, 'insertNodes.js'), huronScript);\n};\n\n/**\n * Output entire data store to a JS object and handle if any KSS data has changed\n *\n * @function writeStore\n * @param {object} store - memory store\n * @param {string} changed - filepath of changed KSS section, if applicable\n */\nconst writeStore = exports.writeStore = function writeStore(store, newStore = false) {\n const updatedStore = newStore || store;\n const huron = updatedStore.get('config');\n const outputPath = _path2.default.join(cwd, huron.get('root'), 'huron-assets');\n\n // Write updated data store\n _fsExtra2.default.outputFileSync(_path2.default.join(outputPath, 'huron-store.js'), `module.exports = ${JSON.stringify(updatedStore.toJSON())}`);\n};//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy9zcmMvY2xpL3JlcXVpcmVUZW1wbGF0ZXMuanM/ZmViYSJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQG1vZHVsZSBjbGkvcmVxdWlyZS10ZW1wbGF0ZXMgKi9cbmltcG9ydCBwYXRoIGZyb20gJ3BhdGgnO1xuaW1wb3J0IGZzIGZyb20gJ2ZzLWV4dHJhJztcblxuLy8gV2UgbmVlZCB0byBwcmVwZW5kIHRoaXMgdG8gdGhlIGJyb3dzZXIgc2NyaXB0IGFzIGEgc3RyaW5nIGJ1dCBzdGlsbCB3YW50IHRvIHRyYW5zcGlsZSBpdCxcbi8vIGhlbmNlIGxvYWRpbmcgaXQgdXNpbmcgYHJhdy1sb2FkZXJgIHNvIHdlIHJlY2VpdmUgYSBzdHJpbmcgZnJvbSB3ZWJwYWNrXG4vKiBlc2xpbnQtZGlzYWJsZSAqL1xuaW1wb3J0IGhvdFRlbXBsYXRlIGZyb20gJyFyYXctbG9hZGVyIWJhYmVsLWxvYWRlciEuLi8uLi90ZW1wbGF0ZXMvaG90VGVtcGxhdGUnO1xuLyogZXNsaW50LWVuYWJsZSAqL1xuXG5jb25zdCBjd2QgPSBwcm9jZXNzLmN3ZCgpO1xuY29uc3QgaHVyb25TY3JpcHQgPSBmcy5yZWFkRmlsZVN5bmMoXG4gIHBhdGguam9pbihfX2Rpcm5hbWUsICcuLi93ZWIvaW5kZXguanMnKSxcbiAgJ3V0ZjgnXG4pO1xuXG4vKipcbiAqIFdyaXRlIGNvZGUgZm9yIHJlcXVpcmluZyBhbGwgZ2VuZXJhdGVkIGh1cm9uIGFzc2V0c1xuICpcbiAqIEBmdW5jdGlvbiByZXF1aXJlVGVtcGxhdGVzXG4gKiBAcGFyYW0ge29iamVjdH0gc3RvcmUgLSBtZW1vcnkgc3RvcmVcbiAqL1xuZXhwb3J0IGNvbnN0IHJlcXVpcmVUZW1wbGF0ZXMgPSBmdW5jdGlvbiByZXF1aXJlVGVtcGxhdGVzKHN0b3JlKSB7XG4gIGNvbnN0IGh1cm9uID0gc3RvcmUuZ2V0KCdjb25maWcnKTtcbiAgY29uc3Qgb3V0cHV0UGF0aCA9IHBhdGguam9pbihjd2QsIGh1cm9uLmdldCgncm9vdCcpLCAnaHVyb24tYXNzZXRzJyk7XG4gIC8vIFRoZXNlIHdpbGwgYmUgdXNlZCB0byByZXBsYWNlIHN0cmluZ3MgaW4gdGhlIGhvdFRlbXBsYXRlLlxuICAvLyBJbiBvcmRlciB0byBhY2N1cmF0ZWx5IHJlcGxhY2Ugc3RyaW5ncyBidXQgc3RpbGwga2VlcCB0aGluZ3MgcGFyc2VhYmxlIGJ5IGVzbGludCBhbmQgYmFiZWwsXG4gIC8vIGVhY2ggcmVwbGFjZWFibGUgdmFsdWUgc2hvdWxkIGJlIHJlZmVyZW5jZWQgaW4gYGhvdFRlbXBsYXRlLmpzYCB1bmRlciB0aGUgYGhvdFNjb3BlYCBvYmplY3QuXG4gIC8vIEZvciBleGFtcGxlLCBpZiB5b3UgbmVlZCB0byByZXBsYWNlIGEgc3RyaW5nIHdpdGggYSB2YWx1ZSBwYXNzZWQgaW4gZnJvbSB0aGUgQ0xJIGNhbGxlZCBgdXNlclZhcmlhYmxlYCxcbiAgLy8geW91IHdvdWxkIHJlZmVyZW5jZSB0aGF0IHN0cmluZyBpbiBgaG90VGVtcGxhdGUuanNgIHdpdGggYGhvdFNjb3BlLnVzZXJWYXJpYWJsZWAuXG4gIGNvbnN0IGhvdFZhcmlhYmxlU2NvcGUgPSB7XG4gICAgc2VjdGlvblRlbXBsYXRlUGF0aDogYCcke2h1cm9uLmdldCgnc2VjdGlvblRlbXBsYXRlJyl9J2AsXG4gICAgcmVxdWlyZVJlZ2V4OiBuZXcgUmVnRXhwKGBcXFxcLmh0bWx8XFxcXC5qc29ufFxcXFwke1xuICAgICAgaHVyb24uZ2V0KCd0ZW1wbGF0ZXMnKS5leHRlbnNpb25cbiAgICB9JGApLFxuICAgIHJlcXVpcmVQYXRoOiBgJy4uLyR7aHVyb24uZ2V0KCdvdXRwdXQnKX0nYCxcbiAgfTtcbiAgY29uc3QgaG90VGVtcGxhdGVUcmFuc2Zvcm1lZCA9IE9iamVjdC5rZXlzKGhvdFZhcmlhYmxlU2NvcGUpXG4gICAgLnJlZHVjZShcbiAgICAgIChhY2MsIGN1cnIpID0+IGFjYy5yZXBsYWNlKFxuICAgICAgICBuZXcgUmVnRXhwKGBob3RTY29wZS4ke2N1cnJ9YCwgJ2cnKSxcbiAgICAgICAgaG90VmFyaWFibGVTY29wZVtjdXJyXVxuICAgICAgKSwgaG90VGVtcGxhdGVcbiAgICApO1xuXG4gIC8vIFdyaXRlIHRoZSBjb250ZW50cyBvZiB0aGlzIHNjcmlwdC5cbiAgZnMub3V0cHV0RmlsZVN5bmMoXG4gICAgcGF0aC5qb2luKG91dHB1dFBhdGgsICdpbmRleC5qcycpLFxuICAgIGhvdFRlbXBsYXRlVHJhbnNmb3JtZWRcbiAgKTtcbiAgZnMub3V0cHV0RmlsZVN5bmMoXG4gICAgcGF0aC5qb2luKG91dHB1dFBhdGgsICdpbnNlcnROb2Rlcy5qcycpLFxuICAgIGh1cm9uU2NyaXB0XG4gICk7XG59O1xuXG4vKipcbiAqIE91dHB1dCBlbnRpcmUgZGF0YSBzdG9yZSB0byBhIEpTIG9iamVjdCBhbmQgaGFuZGxlIGlmIGFueSBLU1MgZGF0YSBoYXMgY2hhbmdlZFxuICpcbiAqIEBmdW5jdGlvbiB3cml0ZVN0b3JlXG4gKiBAcGFyYW0ge29iamVjdH0gc3RvcmUgLSBtZW1vcnkgc3RvcmVcbiAqIEBwYXJhbSB7c3RyaW5nfSBjaGFuZ2VkIC0gZmlsZXBhdGggb2YgY2hhbmdlZCBLU1Mgc2VjdGlvbiwgaWYgYXBwbGljYWJsZVxuICovXG5leHBvcnQgY29uc3Qgd3JpdGVTdG9yZSA9IGZ1bmN0aW9uIHdyaXRlU3RvcmUoc3RvcmUsIG5ld1N0b3JlID0gZmFsc2UpIHtcbiAgY29uc3QgdXBkYXRlZFN0b3JlID0gbmV3U3RvcmUgfHwgc3RvcmU7XG4gIGNvbnN0IGh1cm9uID0gdXBkYXRlZFN0b3JlLmdldCgnY29uZmlnJyk7XG4gIGNvbnN0IG91dHB1dFBhdGggPSBwYXRoLmpvaW4oY3dkLCBodXJvbi5nZXQoJ3Jvb3QnKSwgJ2h1cm9uLWFzc2V0cycpO1xuXG4gIC8vIFdyaXRlIHVwZGF0ZWQgZGF0YSBzdG9yZVxuICBmcy5vdXRwdXRGaWxlU3luYyhcbiAgICBwYXRoLmpvaW4ob3V0cHV0UGF0aCwgJ2h1cm9uLXN0b3JlLmpzJyksXG4gICAgYG1vZHVsZS5leHBvcnRzID0gJHtKU09OLnN0cmluZ2lmeSh1cGRhdGVkU3RvcmUudG9KU09OKCkpfWBcbiAgKTtcbn07XG5cblxuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyBzcmMvY2xpL3JlcXVpcmVUZW1wbGF0ZXMuanMiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFDQTtBQUNBOzs7QUFBQTtBQUNBOzs7QUFJQTtBQUNBOzs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBUEE7QUFDQTtBQUNBO0FBTkE7QUFDQTtBQVVBO0FBQ0E7QUFJQTs7Ozs7O0FBTUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUdBO0FBTEE7QUFPQTtBQUNBO0FBT0E7QUFDQTtBQUlBO0FBSUE7QUFDQTtBQUNBOzs7Ozs7O0FBT0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFJQSIsInNvdXJjZVJvb3QiOiIifQ=="); + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.writeStore = exports.requireTemplates = undefined; + +var _path = __webpack_require__(0); + +var _path2 = _interopRequireDefault(_path); + +var _fsExtra = __webpack_require__(3); + +var _fsExtra2 = _interopRequireDefault(_fsExtra); + +var _hotTemplate = __webpack_require__(20); + +var _hotTemplate2 = _interopRequireDefault(_hotTemplate); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/* eslint-enable */ + +const cwd = process.cwd(); + +// We need to prepend this to the browser script as a string but still want to transpile it, +// hence loading it using `raw-loader` so we receive a string from webpack +/* eslint-disable */ +/** @module cli/require-templates */ + +const huronScript = _fsExtra2.default.readFileSync(_path2.default.join(__dirname, '../web/index.js'), 'utf8'); + +/** + * Write code for requiring all generated huron assets + * + * @function requireTemplates + * @param {object} store - memory store + */ +const requireTemplates = exports.requireTemplates = function requireTemplates(store) { + const huron = store.get('config'); + const outputPath = _path2.default.join(cwd, huron.get('root'), 'huron-assets'); + // These will be used to replace strings in the hotTemplate. + // In order to accurately replace strings but still keep things parseable by eslint and babel, + // each replaceable value should be referenced in `hotTemplate.js` under the `hotScope` object. + // For example, if you need to replace a string with a value passed in from the CLI called `userVariable`, + // you would reference that string in `hotTemplate.js` with `hotScope.userVariable`. + const hotVariableScope = { + sectionTemplatePath: `'${huron.get('sectionTemplate')}'`, + requireRegex: new RegExp(`\\.html|\\.json|\\${huron.get('templates').extension}$`), + requirePath: `'../${huron.get('output')}'` + }; + const hotTemplateTransformed = Object.keys(hotVariableScope).reduce((acc, curr) => acc.replace(new RegExp(`hotScope.${curr}`, 'g'), hotVariableScope[curr]), _hotTemplate2.default); + + // Write the contents of this script. + _fsExtra2.default.outputFileSync(_path2.default.join(outputPath, 'index.js'), hotTemplateTransformed); + _fsExtra2.default.outputFileSync(_path2.default.join(outputPath, 'insertNodes.js'), huronScript); +}; + +/** + * Output entire data store to a JS object and handle if any KSS data has changed + * + * @function writeStore + * @param {object} store - memory store + * @param {string} changed - filepath of changed KSS section, if applicable + */ +const writeStore = exports.writeStore = function writeStore(store, newStore = false) { + const updatedStore = newStore || store; + const huron = updatedStore.get('config'); + const outputPath = _path2.default.join(cwd, huron.get('root'), 'huron-assets'); + + // Write updated data store + _fsExtra2.default.outputFileSync(_path2.default.join(outputPath, 'huron-store.js'), `module.exports = ${JSON.stringify(updatedStore.toJSON())}`); +}; /***/ }), /* 9 */ -/* no static exports found */ -/* all exports used */ -/*!**************************!*\ - !*** ./src/cli/index.js ***! - \**************************/ /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nvar _chalk = __webpack_require__(/*! chalk */ 2);\n\nvar _chalk2 = _interopRequireDefault(_chalk);\n\nvar _actions = __webpack_require__(/*! ./actions */ 11);\n\nvar _requireTemplates = __webpack_require__(/*! ./requireTemplates */ 8);\n\nvar _utils = __webpack_require__(/*! ./utils */ 1);\n\nvar _parseArgs = __webpack_require__(/*! ./parseArgs */ 4);\n\nvar _parseArgs2 = _interopRequireDefault(_parseArgs);\n\nvar _server = __webpack_require__(/*! ./server */ 17);\n\nvar _server2 = _interopRequireDefault(_server);\n\nvar _defaultStore = __webpack_require__(/*! ./defaultStore */ 6);\n\nvar _fileWatcher = __webpack_require__(/*! ./fileWatcher */ 12);\n\nvar _fileWatcher2 = _interopRequireDefault(_fileWatcher);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Initialize data store with files from gaze and original data structure\n *\n * @global\n */\n// Local imports\nconst store = (0, _actions.initFiles)(_fileWatcher2.default.watched(), _defaultStore.defaultStore);\nconst huron = _defaultStore.defaultStore.get('config');\n\n(0, _requireTemplates.requireTemplates)(store);\n(0, _requireTemplates.writeStore)(store);\n\nif (!_parseArgs2.default.production) {\n /** @module cli/gaze */\n let newStore = store;\n\n _fileWatcher2.default.on('all', (event, filepath) => {\n newStore = (0, _actions.updateClassNames)(filepath, newStore);\n (0, _requireTemplates.writeStore)(newStore);\n });\n\n /**\n * Anonymous handler for Gaze 'changed' event indicating a file has changed\n *\n * @callback changed\n * @listens gaze:changed\n * @param {string} filepath - absolute path of changed file\n */\n _fileWatcher2.default.on('changed', filepath => {\n if ((0, _utils.matchKssDir)(filepath, huron)) {\n newStore = (0, _actions.updateFile)(filepath, newStore);\n }\n\n console.log(_chalk2.default.green(`${filepath} updated!`));\n });\n\n /**\n * Anonymous handler for Gaze 'added' event indicating a file has been added to the watched directories\n *\n * @callback added\n * @listens gaze:added\n * @param {string} filepath - absolute path of changed file\n */\n _fileWatcher2.default.on('added', filepath => {\n if ((0, _utils.matchKssDir)(filepath, huron)) {\n newStore = (0, _actions.updateFile)(filepath, newStore);\n (0, _requireTemplates.writeStore)(newStore);\n }\n\n console.log(_chalk2.default.blue(`${filepath} added!`));\n });\n\n /**\n * Anonymous handler for Gaze 'renamed' event indicating a file has been renamed\n *\n * @callback renamed\n * @listens gaze:renamed\n * @param {string} filepath - absolute path of changed file\n */\n _fileWatcher2.default.on('renamed', (newPath, oldPath) => {\n if ((0, _utils.matchKssDir)(newPath, huron)) {\n newStore = (0, _actions.deleteFile)(oldPath, newStore);\n newStore = (0, _actions.updateFile)(newPath, newStore);\n (0, _requireTemplates.writeStore)(newStore);\n }\n\n console.log(_chalk2.default.blue(`${newPath} added!`));\n });\n\n /**\n * Anonymous handler for Gaze 'deleted' event indicating a file has been removed\n *\n * @callback deleted\n * @listens gaze:deleted\n * @param {string} filepath - absolute path of changed file\n */\n _fileWatcher2.default.on('deleted', filepath => {\n if ((0, _utils.matchKssDir)(filepath, huron)) {\n newStore = (0, _actions.deleteFile)(filepath, newStore);\n (0, _requireTemplates.writeStore)(newStore);\n }\n\n console.log(_chalk2.default.red(`${filepath} deleted`));\n });\n} else {\n _fileWatcher2.default.close();\n}\n\n// Start webpack or build for production\n(0, _server2.default)(_defaultStore.config);//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy9zcmMvY2xpL2luZGV4LmpzPzg2N2IiXSwic291cmNlc0NvbnRlbnQiOlsiLy8gTG9jYWwgaW1wb3J0c1xuaW1wb3J0IGNoYWxrIGZyb20gJ2NoYWxrJztcblxuaW1wb3J0IHtcbiAgaW5pdEZpbGVzLFxuICB1cGRhdGVGaWxlLFxuICBkZWxldGVGaWxlLFxuICB1cGRhdGVDbGFzc05hbWVzLFxufSBmcm9tICcuL2FjdGlvbnMnO1xuaW1wb3J0IHsgcmVxdWlyZVRlbXBsYXRlcywgd3JpdGVTdG9yZSB9IGZyb20gJy4vcmVxdWlyZVRlbXBsYXRlcyc7XG5pbXBvcnQgeyBtYXRjaEtzc0RpciB9IGZyb20gJy4vdXRpbHMnO1xuaW1wb3J0IHByb2dyYW0gZnJvbSAnLi9wYXJzZUFyZ3MnO1xuaW1wb3J0IHN0YXJ0V2VicGFjayBmcm9tICcuL3NlcnZlcic7XG5pbXBvcnQgeyBkZWZhdWx0U3RvcmUsIGNvbmZpZyB9IGZyb20gJy4vZGVmYXVsdFN0b3JlJztcbmltcG9ydCBnYXplIGZyb20gJy4vZmlsZVdhdGNoZXInO1xuXG4vKipcbiAqIEluaXRpYWxpemUgZGF0YSBzdG9yZSB3aXRoIGZpbGVzIGZyb20gZ2F6ZSBhbmQgb3JpZ2luYWwgZGF0YSBzdHJ1Y3R1cmVcbiAqXG4gKiBAZ2xvYmFsXG4gKi9cbmNvbnN0IHN0b3JlID0gaW5pdEZpbGVzKGdhemUud2F0Y2hlZCgpLCBkZWZhdWx0U3RvcmUpO1xuY29uc3QgaHVyb24gPSBkZWZhdWx0U3RvcmUuZ2V0KCdjb25maWcnKTtcblxucmVxdWlyZVRlbXBsYXRlcyhzdG9yZSk7XG53cml0ZVN0b3JlKHN0b3JlKTtcblxuaWYgKCFwcm9ncmFtLnByb2R1Y3Rpb24pIHtcbiAgLyoqIEBtb2R1bGUgY2xpL2dhemUgKi9cbiAgbGV0IG5ld1N0b3JlID0gc3RvcmU7XG5cbiAgZ2F6ZS5vbignYWxsJywgKGV2ZW50LCBmaWxlcGF0aCkgPT4ge1xuICAgIG5ld1N0b3JlID0gdXBkYXRlQ2xhc3NOYW1lcyhmaWxlcGF0aCwgbmV3U3RvcmUpO1xuICAgIHdyaXRlU3RvcmUobmV3U3RvcmUpO1xuICB9KTtcblxuICAvKipcbiAgICogQW5vbnltb3VzIGhhbmRsZXIgZm9yIEdhemUgJ2NoYW5nZWQnIGV2ZW50IGluZGljYXRpbmcgYSBmaWxlIGhhcyBjaGFuZ2VkXG4gICAqXG4gICAqIEBjYWxsYmFjayBjaGFuZ2VkXG4gICAqIEBsaXN0ZW5zIGdhemU6Y2hhbmdlZFxuICAgKiBAcGFyYW0ge3N0cmluZ30gZmlsZXBhdGggLSBhYnNvbHV0ZSBwYXRoIG9mIGNoYW5nZWQgZmlsZVxuICAgKi9cbiAgZ2F6ZS5vbignY2hhbmdlZCcsIChmaWxlcGF0aCkgPT4ge1xuICAgIGlmIChtYXRjaEtzc0RpcihmaWxlcGF0aCwgaHVyb24pKSB7XG4gICAgICBuZXdTdG9yZSA9IHVwZGF0ZUZpbGUoZmlsZXBhdGgsIG5ld1N0b3JlKTtcbiAgICB9XG5cbiAgICBjb25zb2xlLmxvZyhjaGFsay5ncmVlbihgJHtmaWxlcGF0aH0gdXBkYXRlZCFgKSk7XG4gIH0pO1xuXG4gIC8qKlxuICAgKiBBbm9ueW1vdXMgaGFuZGxlciBmb3IgR2F6ZSAnYWRkZWQnIGV2ZW50IGluZGljYXRpbmcgYSBmaWxlIGhhcyBiZWVuIGFkZGVkIHRvIHRoZSB3YXRjaGVkIGRpcmVjdG9yaWVzXG4gICAqXG4gICAqIEBjYWxsYmFjayBhZGRlZFxuICAgKiBAbGlzdGVucyBnYXplOmFkZGVkXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBmaWxlcGF0aCAtIGFic29sdXRlIHBhdGggb2YgY2hhbmdlZCBmaWxlXG4gICAqL1xuICBnYXplLm9uKCdhZGRlZCcsIChmaWxlcGF0aCkgPT4ge1xuICAgIGlmIChtYXRjaEtzc0RpcihmaWxlcGF0aCwgaHVyb24pKSB7XG4gICAgICBuZXdTdG9yZSA9IHVwZGF0ZUZpbGUoZmlsZXBhdGgsIG5ld1N0b3JlKTtcbiAgICAgIHdyaXRlU3RvcmUobmV3U3RvcmUpO1xuICAgIH1cblxuICAgIGNvbnNvbGUubG9nKGNoYWxrLmJsdWUoYCR7ZmlsZXBhdGh9IGFkZGVkIWApKTtcbiAgfSk7XG5cbiAgLyoqXG4gICAqIEFub255bW91cyBoYW5kbGVyIGZvciBHYXplICdyZW5hbWVkJyBldmVudCBpbmRpY2F0aW5nIGEgZmlsZSBoYXMgYmVlbiByZW5hbWVkXG4gICAqXG4gICAqIEBjYWxsYmFjayByZW5hbWVkXG4gICAqIEBsaXN0ZW5zIGdhemU6cmVuYW1lZFxuICAgKiBAcGFyYW0ge3N0cmluZ30gZmlsZXBhdGggLSBhYnNvbHV0ZSBwYXRoIG9mIGNoYW5nZWQgZmlsZVxuICAgKi9cbiAgZ2F6ZS5vbigncmVuYW1lZCcsIChuZXdQYXRoLCBvbGRQYXRoKSA9PiB7XG4gICAgaWYgKG1hdGNoS3NzRGlyKG5ld1BhdGgsIGh1cm9uKSkge1xuICAgICAgbmV3U3RvcmUgPSBkZWxldGVGaWxlKG9sZFBhdGgsIG5ld1N0b3JlKTtcbiAgICAgIG5ld1N0b3JlID0gdXBkYXRlRmlsZShuZXdQYXRoLCBuZXdTdG9yZSk7XG4gICAgICB3cml0ZVN0b3JlKG5ld1N0b3JlKTtcbiAgICB9XG5cbiAgICBjb25zb2xlLmxvZyhjaGFsay5ibHVlKGAke25ld1BhdGh9IGFkZGVkIWApKTtcbiAgfSk7XG5cbiAgLyoqXG4gICAqIEFub255bW91cyBoYW5kbGVyIGZvciBHYXplICdkZWxldGVkJyBldmVudCBpbmRpY2F0aW5nIGEgZmlsZSBoYXMgYmVlbiByZW1vdmVkXG4gICAqXG4gICAqIEBjYWxsYmFjayBkZWxldGVkXG4gICAqIEBsaXN0ZW5zIGdhemU6ZGVsZXRlZFxuICAgKiBAcGFyYW0ge3N0cmluZ30gZmlsZXBhdGggLSBhYnNvbHV0ZSBwYXRoIG9mIGNoYW5nZWQgZmlsZVxuICAgKi9cbiAgZ2F6ZS5vbignZGVsZXRlZCcsIChmaWxlcGF0aCkgPT4ge1xuICAgIGlmIChtYXRjaEtzc0RpcihmaWxlcGF0aCwgaHVyb24pKSB7XG4gICAgICBuZXdTdG9yZSA9IGRlbGV0ZUZpbGUoZmlsZXBhdGgsIG5ld1N0b3JlKTtcbiAgICAgIHdyaXRlU3RvcmUobmV3U3RvcmUpO1xuICAgIH1cblxuICAgIGNvbnNvbGUubG9nKGNoYWxrLnJlZChgJHtmaWxlcGF0aH0gZGVsZXRlZGApKTtcbiAgfSk7XG59IGVsc2Uge1xuICBnYXplLmNsb3NlKCk7XG59XG5cbi8vIFN0YXJ0IHdlYnBhY2sgb3IgYnVpbGQgZm9yIHByb2R1Y3Rpb25cbnN0YXJ0V2VicGFjayhjb25maWcpO1xuXG5cblxuLy8gV0VCUEFDSyBGT09URVIgLy9cbi8vIHNyYy9jbGkvaW5kZXguanMiXSwibWFwcGluZ3MiOiI7O0FBQ0E7QUFDQTs7O0FBQ0E7QUFDQTtBQUtBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFDQTs7O0FBQUE7QUFDQTs7O0FBQUE7QUFDQTtBQUFBO0FBQ0E7Ozs7O0FBQ0E7Ozs7O0FBaEJBO0FBcUJBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7O0FBT0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7O0FBT0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7Ozs7Ozs7QUFPQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7O0FBT0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ=="); + + +var _chalk = __webpack_require__(2); + +var _chalk2 = _interopRequireDefault(_chalk); + +var _actions = __webpack_require__(11); + +var _requireTemplates = __webpack_require__(8); + +var _utils = __webpack_require__(1); + +var _parseArgs = __webpack_require__(4); + +var _parseArgs2 = _interopRequireDefault(_parseArgs); + +var _server = __webpack_require__(17); + +var _server2 = _interopRequireDefault(_server); + +var _defaultStore = __webpack_require__(6); + +var _fileWatcher = __webpack_require__(12); + +var _fileWatcher2 = _interopRequireDefault(_fileWatcher); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Initialize data store with files from gaze and original data structure + * + * @global + */ +// Local imports +const store = (0, _actions.initFiles)(_fileWatcher2.default.watched(), _defaultStore.defaultStore); +const huron = _defaultStore.defaultStore.get('config'); + +(0, _requireTemplates.requireTemplates)(store); +(0, _requireTemplates.writeStore)(store); + +if (!_parseArgs2.default.production) { + /** @module cli/gaze */ + let newStore = store; + + _fileWatcher2.default.on('all', (event, filepath) => { + newStore = (0, _actions.updateClassNames)(filepath, newStore); + (0, _requireTemplates.writeStore)(newStore); + }); + + /** + * Anonymous handler for Gaze 'changed' event indicating a file has changed + * + * @callback changed + * @listens gaze:changed + * @param {string} filepath - absolute path of changed file + */ + _fileWatcher2.default.on('changed', filepath => { + if ((0, _utils.matchKssDir)(filepath, huron)) { + newStore = (0, _actions.updateFile)(filepath, newStore); + } + + console.log(_chalk2.default.green(`${filepath} updated!`)); + }); + + /** + * Anonymous handler for Gaze 'added' event indicating a file has been added to the watched directories + * + * @callback added + * @listens gaze:added + * @param {string} filepath - absolute path of changed file + */ + _fileWatcher2.default.on('added', filepath => { + if ((0, _utils.matchKssDir)(filepath, huron)) { + newStore = (0, _actions.updateFile)(filepath, newStore); + (0, _requireTemplates.writeStore)(newStore); + } + + console.log(_chalk2.default.blue(`${filepath} added!`)); + }); + + /** + * Anonymous handler for Gaze 'renamed' event indicating a file has been renamed + * + * @callback renamed + * @listens gaze:renamed + * @param {string} filepath - absolute path of changed file + */ + _fileWatcher2.default.on('renamed', (newPath, oldPath) => { + if ((0, _utils.matchKssDir)(newPath, huron)) { + newStore = (0, _actions.deleteFile)(oldPath, newStore); + newStore = (0, _actions.updateFile)(newPath, newStore); + (0, _requireTemplates.writeStore)(newStore); + } + + console.log(_chalk2.default.blue(`${newPath} added!`)); + }); + + /** + * Anonymous handler for Gaze 'deleted' event indicating a file has been removed + * + * @callback deleted + * @listens gaze:deleted + * @param {string} filepath - absolute path of changed file + */ + _fileWatcher2.default.on('deleted', filepath => { + if ((0, _utils.matchKssDir)(filepath, huron)) { + newStore = (0, _actions.deleteFile)(filepath, newStore); + (0, _requireTemplates.writeStore)(newStore); + } + + console.log(_chalk2.default.red(`${filepath} deleted`)); + }); +} else { + _fileWatcher2.default.close(); +} + +// Start webpack or build for production +(0, _server2.default)(_defaultStore.config); /***/ }), /* 10 */ -/* exports provided: default */ -/* all exports used */ -/*!************************************!*\ - !*** ./config/devServer.config.js ***! - \************************************/ -/***/ (function(module, __webpack_exports__, __webpack_require__) { +/***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("Object.defineProperty(__webpack_exports__, \"__esModule\", { value: true });\n/* harmony default export */ __webpack_exports__[\"default\"] = ((huron) => ({\n hot: true,\n quiet: false,\n noInfo: false,\n stats: {\n colors: true,\n hash: false,\n version: false,\n assets: false,\n chunks: false,\n modules: false,\n reasons: false,\n children: false,\n source: false,\n },\n contentBase: huron.root,\n overlay: true,\n publicPath: `http://localhost:${huron.port}/${huron.root}`,\n}));\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTAuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9jb25maWcvZGV2U2VydmVyLmNvbmZpZy5qcz80MjYxIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBkZWZhdWx0IChodXJvbikgPT4gKHtcbiAgaG90OiB0cnVlLFxuICBxdWlldDogZmFsc2UsXG4gIG5vSW5mbzogZmFsc2UsXG4gIHN0YXRzOiB7XG4gICAgY29sb3JzOiB0cnVlLFxuICAgIGhhc2g6IGZhbHNlLFxuICAgIHZlcnNpb246IGZhbHNlLFxuICAgIGFzc2V0czogZmFsc2UsXG4gICAgY2h1bmtzOiBmYWxzZSxcbiAgICBtb2R1bGVzOiBmYWxzZSxcbiAgICByZWFzb25zOiBmYWxzZSxcbiAgICBjaGlsZHJlbjogZmFsc2UsXG4gICAgc291cmNlOiBmYWxzZSxcbiAgfSxcbiAgY29udGVudEJhc2U6IGh1cm9uLnJvb3QsXG4gIG92ZXJsYXk6IHRydWUsXG4gIHB1YmxpY1BhdGg6IGBodHRwOi8vbG9jYWxob3N0OiR7aHVyb24ucG9ydH0vJHtodXJvbi5yb290fWAsXG59KTtcblxuXG5cbi8vLy8vLy8vLy8vLy8vLy8vL1xuLy8gV0VCUEFDSyBGT09URVJcbi8vIC4vY29uZmlnL2RldlNlcnZlci5jb25maWcuanNcbi8vIG1vZHVsZSBpZCA9IDEwXG4vLyBtb2R1bGUgY2h1bmtzID0gMCJdLCJtYXBwaW5ncyI6IkFBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTsiLCJzb3VyY2VSb290IjoiIn0="); + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +exports.default = huron => ({ + hot: true, + quiet: false, + noInfo: false, + stats: { + colors: true, + hash: false, + version: false, + assets: false, + chunks: false, + modules: false, + reasons: false, + children: false, + source: false + }, + contentBase: huron.root, + overlay: true, + publicPath: `http://localhost:${huron.port}/${huron.root}` +}); /***/ }), /* 11 */ -/* no static exports found */ -/* all exports used */ -/*!****************************!*\ - !*** ./src/cli/actions.js ***! - \****************************/ /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.initFiles = initFiles;\nexports.updateFile = updateFile;\nexports.deleteFile = deleteFile;\nexports.updateClassNames = updateClassNames;\n\nvar _path = __webpack_require__(/*! path */ 0);\n\nvar _path2 = _interopRequireDefault(_path);\n\nvar _chalk = __webpack_require__(/*! chalk */ 2);\n\nvar _chalk2 = _interopRequireDefault(_chalk);\n\nvar _isEqual = __webpack_require__(/*! lodash/isEqual */ 26);\n\nvar _isEqual2 = _interopRequireDefault(_isEqual);\n\nvar _handleHTML = __webpack_require__(/*! ./handleHTML */ 14);\n\nvar _handleTemplates = __webpack_require__(/*! ./handleTemplates */ 7);\n\nvar _handleKSS = __webpack_require__(/*! ./handleKSS */ 15);\n\nvar _utils = __webpack_require__(/*! ./utils */ 1);\n\nvar utils = _interopRequireWildcard(_utils);\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Recursively loop through initial watched files list from Gaze.\n *\n * @param {object} data - object containing directory and file paths\n * @param {object} store - memory store\n * @return {object} newStore - map object of entire data store\n */\nfunction initFiles(data, store, depth = 0) {\n const type = Object.prototype.toString.call(data);\n const huron = store.get('config');\n let newStore = store;\n let info;\n let files;\n\n switch (type) {\n case '[object Object]':\n files = Object.keys(data);\n newStore = files.reduce((prevStore, file) => initFiles(data[file], prevStore, depth), newStore);\n break;\n\n case '[object Array]':\n newStore = data.reduce((prevStore, file) => initFiles(file, prevStore, depth), newStore);\n break;\n\n case '[object String]':\n info = _path2.default.parse(data);\n\n // Only call update if data is a filepath and it's within the KSS source directory\n if (info.ext && !data.includes(huron.get('classNames'))) {\n newStore = updateFile(data, store);\n }\n break;\n\n default:\n break;\n }\n\n return newStore;\n}\n\n/**\n * Logic for updating and writing file information based on file type (extension)\n *\n * @param {string} filepath - path to updated file. usually passed in from Gaze\n * @param {object} store - memory store\n * @return {object} store - map object of map object of entire data store\n */\n/** @module cli/actions */\n\n// Imports\nfunction updateFile(filepath, store) {\n const huron = store.get('config');\n const file = _path2.default.parse(filepath);\n let field;\n let section;\n\n if (filepath.includes(huron.get('sectionTemplate'))) {\n return utils.writeSectionTemplate(filepath, store);\n }\n\n switch (file.ext) {\n // Plain HTML template, external\n case '.html':\n section = utils.getSection(file.base, 'markup', store);\n\n if (section) {\n return (0, _handleHTML.updateHTML)(filepath, section, store);\n } else if (file.dir.includes('prototypes') && file.name.includes('prototype-')) {\n return (0, _handleHTML.updatePrototype)(filepath, store);\n }\n\n console.log(_chalk2.default.red(`Failed to write file: ${file.name}`));\n break;\n\n // Handlebars template, external\n case huron.get('templates').extension:\n case '.json':\n field = '.json' === file.ext ? 'data' : 'markup';\n section = utils.getSection(file.base, field, store);\n\n if (section) {\n return (0, _handleTemplates.updateTemplate)(filepath, section, store);\n }\n\n console.log( // eslint-disable-line no-console\n _chalk2.default.red(`Could not find associated KSS section for ${filepath}`));\n break;\n\n // KSS documentation (default extension is `.css`)\n // Will also output a template if markup is inline\n // Note: inline markup does _not_ support handlebars currently\n case huron.get('kssExtension'):\n return (0, _handleKSS.updateKSS)(filepath, store);\n\n // This should never happen if Gaze is working properly\n default:\n return store;\n }\n\n return store;\n}\n\n/**\n * Logic for deleting file information and files based on file type (extension)\n *\n * @param {string} filepath - path to updated file. usually passed in from Gaze\n * @param {object} store - memory store\n * @return {object} newStore - map object of map object of entire data store\n */\nfunction deleteFile(filepath, store) {\n const huron = store.get('config');\n const file = _path2.default.parse(filepath);\n let field = '';\n let section = null;\n let newStore = store;\n\n switch (file.ext) {\n // Plain HTML template, external\n case '.html':\n section = utils.getSection(file.base, 'markup', store);\n\n if (section) {\n newStore = (0, _handleHTML.deleteHTML)(filepath, section, store);\n } else if (file.dir.includes('prototypes') && file.name.includes('prototype-')) {\n newStore = (0, _handleHTML.deletePrototype)(filepath, store);\n }\n break;\n\n case huron.get('templates').extension:\n case '.json':\n field = '.json' === file.ext ? 'data' : 'markup';\n section = utils.getSection(file.base, field, store);\n\n if (section) {\n newStore = (0, _handleTemplates.deleteTemplate)(filepath, section, store);\n }\n break;\n\n case huron.get('kssExtension'):\n section = utils.getSection(filepath, false, store);\n\n if (section) {\n newStore = (0, _handleKSS.deleteKSS)(filepath, section, store);\n }\n break;\n\n default:\n console.warn( // eslint-disable-line no-console\n _chalk2.default.red(`Could not delete: ${file.name}`));\n break;\n }\n\n return newStore;\n}\n\n/**\n * Logic for updating localized classnames from CSS modules\n *\n * @param {string} filepath - path to updated file. usually passed in from Gaze\n * @param {object} store - memory store\n *\n * @return void\n */\nfunction updateClassNames(filepath, store) {\n const classNamesPath = store.getIn(['config', 'classNames']);\n\n if (filepath.includes(classNamesPath)) {\n const oldClassnames = store.get('classNames');\n const newClassnames = utils.mergeClassnameJSON(classNamesPath);\n\n if (!(0, _isEqual2.default)(oldClassnames, newClassnames)) {\n return store.set('classNames', newClassnames);\n }\n }\n\n return store;\n}//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTEuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vc3JjL2NsaS9hY3Rpb25zLmpzPzVlNWEiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBtb2R1bGUgY2xpL2FjdGlvbnMgKi9cblxuLy8gSW1wb3J0c1xuaW1wb3J0IHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgY2hhbGsgZnJvbSAnY2hhbGsnO1xuaW1wb3J0IGlzRXF1YWwgZnJvbSAnbG9kYXNoL2lzRXF1YWwnO1xuXG5pbXBvcnQge1xuICB1cGRhdGVIVE1MLFxuICBkZWxldGVIVE1MLFxuICB1cGRhdGVQcm90b3R5cGUsXG4gIGRlbGV0ZVByb3RvdHlwZSxcbn0gZnJvbSAnLi9oYW5kbGVIVE1MJztcbmltcG9ydCB7IHVwZGF0ZVRlbXBsYXRlLCBkZWxldGVUZW1wbGF0ZSB9IGZyb20gJy4vaGFuZGxlVGVtcGxhdGVzJztcbmltcG9ydCB7IHVwZGF0ZUtTUywgZGVsZXRlS1NTIH0gZnJvbSAnLi9oYW5kbGVLU1MnO1xuaW1wb3J0ICogYXMgdXRpbHMgZnJvbSAnLi91dGlscyc7XG5cbi8qKlxuICogUmVjdXJzaXZlbHkgbG9vcCB0aHJvdWdoIGluaXRpYWwgd2F0Y2hlZCBmaWxlcyBsaXN0IGZyb20gR2F6ZS5cbiAqXG4gKiBAcGFyYW0ge29iamVjdH0gZGF0YSAtIG9iamVjdCBjb250YWluaW5nIGRpcmVjdG9yeSBhbmQgZmlsZSBwYXRoc1xuICogQHBhcmFtIHtvYmplY3R9IHN0b3JlIC0gbWVtb3J5IHN0b3JlXG4gKiBAcmV0dXJuIHtvYmplY3R9IG5ld1N0b3JlIC0gbWFwIG9iamVjdCBvZiBlbnRpcmUgZGF0YSBzdG9yZVxuICovXG5leHBvcnQgZnVuY3Rpb24gaW5pdEZpbGVzKGRhdGEsIHN0b3JlLCBkZXB0aCA9IDApIHtcbiAgY29uc3QgdHlwZSA9IE9iamVjdC5wcm90b3R5cGUudG9TdHJpbmcuY2FsbChkYXRhKTtcbiAgY29uc3QgaHVyb24gPSBzdG9yZS5nZXQoJ2NvbmZpZycpO1xuICBsZXQgbmV3U3RvcmUgPSBzdG9yZTtcbiAgbGV0IGluZm87XG4gIGxldCBmaWxlcztcblxuICBzd2l0Y2ggKHR5cGUpIHtcbiAgICBjYXNlICdbb2JqZWN0IE9iamVjdF0nOlxuICAgICAgZmlsZXMgPSBPYmplY3Qua2V5cyhkYXRhKTtcbiAgICAgIG5ld1N0b3JlID0gZmlsZXMucmVkdWNlKFxuICAgICAgICAocHJldlN0b3JlLCBmaWxlKSA9PiBpbml0RmlsZXMoZGF0YVtmaWxlXSwgcHJldlN0b3JlLCBkZXB0aCksXG4gICAgICAgIG5ld1N0b3JlXG4gICAgICApO1xuICAgICAgYnJlYWs7XG5cbiAgICBjYXNlICdbb2JqZWN0IEFycmF5XSc6XG4gICAgICBuZXdTdG9yZSA9IGRhdGEucmVkdWNlKFxuICAgICAgICAocHJldlN0b3JlLCBmaWxlKSA9PiBpbml0RmlsZXMoZmlsZSwgcHJldlN0b3JlLCBkZXB0aCksXG4gICAgICAgIG5ld1N0b3JlXG4gICAgICApO1xuICAgICAgYnJlYWs7XG5cbiAgICBjYXNlICdbb2JqZWN0IFN0cmluZ10nOlxuICAgICAgaW5mbyA9IHBhdGgucGFyc2UoZGF0YSk7XG5cbiAgICAgIC8vIE9ubHkgY2FsbCB1cGRhdGUgaWYgZGF0YSBpcyBhIGZpbGVwYXRoIGFuZCBpdCdzIHdpdGhpbiB0aGUgS1NTIHNvdXJjZSBkaXJlY3RvcnlcbiAgICAgIGlmIChpbmZvLmV4dCAmJiAhZGF0YS5pbmNsdWRlcyhodXJvbi5nZXQoJ2NsYXNzTmFtZXMnKSkpIHtcbiAgICAgICAgbmV3U3RvcmUgPSB1cGRhdGVGaWxlKGRhdGEsIHN0b3JlKTtcbiAgICAgIH1cbiAgICAgIGJyZWFrO1xuXG4gICAgZGVmYXVsdDpcbiAgICAgIGJyZWFrO1xuICB9XG5cbiAgcmV0dXJuIG5ld1N0b3JlO1xufVxuXG4vKipcbiAqIExvZ2ljIGZvciB1cGRhdGluZyBhbmQgd3JpdGluZyBmaWxlIGluZm9ybWF0aW9uIGJhc2VkIG9uIGZpbGUgdHlwZSAoZXh0ZW5zaW9uKVxuICpcbiAqIEBwYXJhbSB7c3RyaW5nfSBmaWxlcGF0aCAtIHBhdGggdG8gdXBkYXRlZCBmaWxlLiB1c3VhbGx5IHBhc3NlZCBpbiBmcm9tIEdhemVcbiAqIEBwYXJhbSB7b2JqZWN0fSBzdG9yZSAtIG1lbW9yeSBzdG9yZVxuICogQHJldHVybiB7b2JqZWN0fSBzdG9yZSAtIG1hcCBvYmplY3Qgb2YgbWFwIG9iamVjdCBvZiBlbnRpcmUgZGF0YSBzdG9yZVxuICovXG5leHBvcnQgZnVuY3Rpb24gdXBkYXRlRmlsZShmaWxlcGF0aCwgc3RvcmUpIHtcbiAgY29uc3QgaHVyb24gPSBzdG9yZS5nZXQoJ2NvbmZpZycpO1xuICBjb25zdCBmaWxlID0gcGF0aC5wYXJzZShmaWxlcGF0aCk7XG4gIGxldCBmaWVsZDtcbiAgbGV0IHNlY3Rpb247XG5cbiAgaWYgKGZpbGVwYXRoLmluY2x1ZGVzKGh1cm9uLmdldCgnc2VjdGlvblRlbXBsYXRlJykpKSB7XG4gICAgcmV0dXJuIHV0aWxzLndyaXRlU2VjdGlvblRlbXBsYXRlKGZpbGVwYXRoLCBzdG9yZSk7XG4gIH1cblxuICBzd2l0Y2ggKGZpbGUuZXh0KSB7XG4gICAgLy8gUGxhaW4gSFRNTCB0ZW1wbGF0ZSwgZXh0ZXJuYWxcbiAgICBjYXNlICcuaHRtbCc6XG4gICAgICBzZWN0aW9uID0gdXRpbHMuZ2V0U2VjdGlvbihmaWxlLmJhc2UsICdtYXJrdXAnLCBzdG9yZSk7XG5cbiAgICAgIGlmIChzZWN0aW9uKSB7XG4gICAgICAgIHJldHVybiB1cGRhdGVIVE1MKGZpbGVwYXRoLCBzZWN0aW9uLCBzdG9yZSk7XG4gICAgICB9IGVsc2UgaWYgKFxuICAgICAgICBmaWxlLmRpci5pbmNsdWRlcygncHJvdG90eXBlcycpICYmXG4gICAgICAgIGZpbGUubmFtZS5pbmNsdWRlcygncHJvdG90eXBlLScpXG4gICAgICApIHtcbiAgICAgICAgcmV0dXJuIHVwZGF0ZVByb3RvdHlwZShmaWxlcGF0aCwgc3RvcmUpO1xuICAgICAgfVxuXG4gICAgICBjb25zb2xlLmxvZyhjaGFsay5yZWQoYEZhaWxlZCB0byB3cml0ZSBmaWxlOiAke2ZpbGUubmFtZX1gKSk7XG4gICAgICBicmVhaztcblxuICAgIC8vIEhhbmRsZWJhcnMgdGVtcGxhdGUsIGV4dGVybmFsXG4gICAgY2FzZSBodXJvbi5nZXQoJ3RlbXBsYXRlcycpLmV4dGVuc2lvbjpcbiAgICBjYXNlICcuanNvbic6XG4gICAgICBmaWVsZCA9ICgnLmpzb24nID09PSBmaWxlLmV4dCkgPyAnZGF0YScgOiAnbWFya3VwJztcbiAgICAgIHNlY3Rpb24gPSB1dGlscy5nZXRTZWN0aW9uKGZpbGUuYmFzZSwgZmllbGQsIHN0b3JlKTtcblxuICAgICAgaWYgKHNlY3Rpb24pIHtcbiAgICAgICAgcmV0dXJuIHVwZGF0ZVRlbXBsYXRlKGZpbGVwYXRoLCBzZWN0aW9uLCBzdG9yZSk7XG4gICAgICB9XG5cbiAgICAgIGNvbnNvbGUubG9nKCAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIG5vLWNvbnNvbGVcbiAgICAgICAgY2hhbGsucmVkKGBDb3VsZCBub3QgZmluZCBhc3NvY2lhdGVkIEtTUyBzZWN0aW9uIGZvciAke2ZpbGVwYXRofWApXG4gICAgICApO1xuICAgICAgYnJlYWs7XG5cbiAgICAvLyBLU1MgZG9jdW1lbnRhdGlvbiAoZGVmYXVsdCBleHRlbnNpb24gaXMgYC5jc3NgKVxuICAgIC8vIFdpbGwgYWxzbyBvdXRwdXQgYSB0ZW1wbGF0ZSBpZiBtYXJrdXAgaXMgaW5saW5lXG4gICAgLy8gTm90ZTogaW5saW5lIG1hcmt1cCBkb2VzIF9ub3RfIHN1cHBvcnQgaGFuZGxlYmFycyBjdXJyZW50bHlcbiAgICBjYXNlIGh1cm9uLmdldCgna3NzRXh0ZW5zaW9uJyk6XG4gICAgICByZXR1cm4gdXBkYXRlS1NTKGZpbGVwYXRoLCBzdG9yZSk7XG5cbiAgICAvLyBUaGlzIHNob3VsZCBuZXZlciBoYXBwZW4gaWYgR2F6ZSBpcyB3b3JraW5nIHByb3Blcmx5XG4gICAgZGVmYXVsdDpcbiAgICAgIHJldHVybiBzdG9yZTtcbiAgfVxuXG4gIHJldHVybiBzdG9yZTtcbn1cblxuLyoqXG4gKiBMb2dpYyBmb3IgZGVsZXRpbmcgZmlsZSBpbmZvcm1hdGlvbiBhbmQgZmlsZXMgYmFzZWQgb24gZmlsZSB0eXBlIChleHRlbnNpb24pXG4gKlxuICogQHBhcmFtIHtzdHJpbmd9IGZpbGVwYXRoIC0gcGF0aCB0byB1cGRhdGVkIGZpbGUuIHVzdWFsbHkgcGFzc2VkIGluIGZyb20gR2F6ZVxuICogQHBhcmFtIHtvYmplY3R9IHN0b3JlIC0gbWVtb3J5IHN0b3JlXG4gKiBAcmV0dXJuIHtvYmplY3R9IG5ld1N0b3JlIC0gbWFwIG9iamVjdCBvZiBtYXAgb2JqZWN0IG9mIGVudGlyZSBkYXRhIHN0b3JlXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBkZWxldGVGaWxlKGZpbGVwYXRoLCBzdG9yZSkge1xuICBjb25zdCBodXJvbiA9IHN0b3JlLmdldCgnY29uZmlnJyk7XG4gIGNvbnN0IGZpbGUgPSBwYXRoLnBhcnNlKGZpbGVwYXRoKTtcbiAgbGV0IGZpZWxkID0gJyc7XG4gIGxldCBzZWN0aW9uID0gbnVsbDtcbiAgbGV0IG5ld1N0b3JlID0gc3RvcmU7XG5cbiAgc3dpdGNoIChmaWxlLmV4dCkge1xuICAgIC8vIFBsYWluIEhUTUwgdGVtcGxhdGUsIGV4dGVybmFsXG4gICAgY2FzZSAnLmh0bWwnOlxuICAgICAgc2VjdGlvbiA9IHV0aWxzLmdldFNlY3Rpb24oZmlsZS5iYXNlLCAnbWFya3VwJywgc3RvcmUpO1xuXG4gICAgICBpZiAoc2VjdGlvbikge1xuICAgICAgICBuZXdTdG9yZSA9IGRlbGV0ZUhUTUwoZmlsZXBhdGgsIHNlY3Rpb24sIHN0b3JlKTtcbiAgICAgIH0gZWxzZSBpZiAoXG4gICAgICAgIGZpbGUuZGlyLmluY2x1ZGVzKCdwcm90b3R5cGVzJykgJiZcbiAgICAgICAgZmlsZS5uYW1lLmluY2x1ZGVzKCdwcm90b3R5cGUtJylcbiAgICAgICkge1xuICAgICAgICBuZXdTdG9yZSA9IGRlbGV0ZVByb3RvdHlwZShmaWxlcGF0aCwgc3RvcmUpO1xuICAgICAgfVxuICAgICAgYnJlYWs7XG5cbiAgICBjYXNlIGh1cm9uLmdldCgndGVtcGxhdGVzJykuZXh0ZW5zaW9uOlxuICAgIGNhc2UgJy5qc29uJzpcbiAgICAgIGZpZWxkID0gKCcuanNvbicgPT09IGZpbGUuZXh0KSA/ICdkYXRhJyA6ICdtYXJrdXAnO1xuICAgICAgc2VjdGlvbiA9IHV0aWxzLmdldFNlY3Rpb24oZmlsZS5iYXNlLCBmaWVsZCwgc3RvcmUpO1xuXG4gICAgICBpZiAoc2VjdGlvbikge1xuICAgICAgICBuZXdTdG9yZSA9IGRlbGV0ZVRlbXBsYXRlKGZpbGVwYXRoLCBzZWN0aW9uLCBzdG9yZSk7XG4gICAgICB9XG4gICAgICBicmVhaztcblxuICAgIGNhc2UgaHVyb24uZ2V0KCdrc3NFeHRlbnNpb24nKTpcbiAgICAgIHNlY3Rpb24gPSB1dGlscy5nZXRTZWN0aW9uKGZpbGVwYXRoLCBmYWxzZSwgc3RvcmUpO1xuXG4gICAgICBpZiAoc2VjdGlvbikge1xuICAgICAgICBuZXdTdG9yZSA9IGRlbGV0ZUtTUyhmaWxlcGF0aCwgc2VjdGlvbiwgc3RvcmUpO1xuICAgICAgfVxuICAgICAgYnJlYWs7XG5cbiAgICBkZWZhdWx0OlxuICAgICAgY29uc29sZS53YXJuKCAgLy8gZXNsaW50LWRpc2FibGUtbGluZSBuby1jb25zb2xlXG4gICAgICAgIGNoYWxrLnJlZChgQ291bGQgbm90IGRlbGV0ZTogJHtmaWxlLm5hbWV9YClcbiAgICAgICk7XG4gICAgICBicmVhaztcbiAgfVxuXG4gIHJldHVybiBuZXdTdG9yZTtcbn1cblxuLyoqXG4gKiBMb2dpYyBmb3IgdXBkYXRpbmcgbG9jYWxpemVkIGNsYXNzbmFtZXMgZnJvbSBDU1MgbW9kdWxlc1xuICpcbiAqIEBwYXJhbSB7c3RyaW5nfSBmaWxlcGF0aCAtIHBhdGggdG8gdXBkYXRlZCBmaWxlLiB1c3VhbGx5IHBhc3NlZCBpbiBmcm9tIEdhemVcbiAqIEBwYXJhbSB7b2JqZWN0fSBzdG9yZSAtIG1lbW9yeSBzdG9yZVxuICpcbiAqIEByZXR1cm4gdm9pZFxuICovXG5leHBvcnQgZnVuY3Rpb24gdXBkYXRlQ2xhc3NOYW1lcyhmaWxlcGF0aCwgc3RvcmUpIHtcbiAgY29uc3QgY2xhc3NOYW1lc1BhdGggPSBzdG9yZS5nZXRJbihbJ2NvbmZpZycsICdjbGFzc05hbWVzJ10pO1xuXG4gIGlmIChmaWxlcGF0aC5pbmNsdWRlcyhjbGFzc05hbWVzUGF0aCkpIHtcbiAgICBjb25zdCBvbGRDbGFzc25hbWVzID0gc3RvcmUuZ2V0KCdjbGFzc05hbWVzJyk7XG4gICAgY29uc3QgbmV3Q2xhc3NuYW1lcyA9IHV0aWxzLm1lcmdlQ2xhc3NuYW1lSlNPTihjbGFzc05hbWVzUGF0aCk7XG5cbiAgICBpZiAoIWlzRXF1YWwob2xkQ2xhc3NuYW1lcywgbmV3Q2xhc3NuYW1lcykpIHtcbiAgICAgIHJldHVybiBzdG9yZS5zZXQoJ2NsYXNzTmFtZXMnLCBuZXdDbGFzc25hbWVzKTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gc3RvcmU7XG59XG5cblxuXG4vLyBXRUJQQUNLIEZPT1RFUiAvL1xuLy8gc3JjL2NsaS9hY3Rpb25zLmpzIl0sIm1hcHBpbmdzIjoiOzs7OztBQXdCQTtBQThDQTtBQStEQTtBQTBEQTtBQUNBO0FBN0xBO0FBQ0E7OztBQUFBO0FBQ0E7OztBQUFBO0FBQ0E7OztBQUNBO0FBQ0E7QUFLQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBQ0E7QUFEQTtBQUNBOzs7OztBQUNBOzs7Ozs7O0FBT0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUlBO0FBQ0E7QUFDQTtBQUNBO0FBSUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUExQkE7QUFDQTtBQTRCQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7OztBQS9EQTtBQUNBO0FBQ0E7QUFvRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBSUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQXhDQTtBQUNBO0FBMENBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7O0FBT0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBSUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQXJDQTtBQUNBO0FBdUNBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7OztBQVFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0="); + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.initFiles = initFiles; +exports.updateFile = updateFile; +exports.deleteFile = deleteFile; +exports.updateClassNames = updateClassNames; + +var _path = __webpack_require__(0); + +var _path2 = _interopRequireDefault(_path); + +var _chalk = __webpack_require__(2); + +var _chalk2 = _interopRequireDefault(_chalk); + +var _isEqual = __webpack_require__(26); + +var _isEqual2 = _interopRequireDefault(_isEqual); + +var _handleHTML = __webpack_require__(14); + +var _handleTemplates = __webpack_require__(7); + +var _handleKSS = __webpack_require__(15); + +var _utils = __webpack_require__(1); + +var utils = _interopRequireWildcard(_utils); + +function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Recursively loop through initial watched files list from Gaze. + * + * @param {object} data - object containing directory and file paths + * @param {object} store - memory store + * @return {object} newStore - map object of entire data store + */ +function initFiles(data, store, depth = 0) { + const type = Object.prototype.toString.call(data); + const huron = store.get('config'); + let newStore = store; + let info; + let files; + + switch (type) { + case '[object Object]': + files = Object.keys(data); + newStore = files.reduce((prevStore, file) => initFiles(data[file], prevStore, depth), newStore); + break; + + case '[object Array]': + newStore = data.reduce((prevStore, file) => initFiles(file, prevStore, depth), newStore); + break; + + case '[object String]': + info = _path2.default.parse(data); + + // Only call update if data is a filepath and it's within the KSS source directory + if (info.ext && !data.includes(huron.get('classNames'))) { + newStore = updateFile(data, store); + } + break; + + default: + break; + } + + return newStore; +} + +/** + * Logic for updating and writing file information based on file type (extension) + * + * @param {string} filepath - path to updated file. usually passed in from Gaze + * @param {object} store - memory store + * @return {object} store - map object of map object of entire data store + */ +/** @module cli/actions */ + +// Imports +function updateFile(filepath, store) { + const huron = store.get('config'); + const file = _path2.default.parse(filepath); + let field; + let section; + + if (filepath.includes(huron.get('sectionTemplate'))) { + return utils.writeSectionTemplate(filepath, store); + } + + switch (file.ext) { + // Plain HTML template, external + case '.html': + section = utils.getSection(file.base, 'markup', store); + + if (section) { + return (0, _handleHTML.updateHTML)(filepath, section, store); + } else if (file.dir.includes('prototypes') && file.name.includes('prototype-')) { + return (0, _handleHTML.updatePrototype)(filepath, store); + } + + console.log(_chalk2.default.red(`Failed to write file: ${file.name}`)); + break; + + // Handlebars template, external + case huron.get('templates').extension: + case '.json': + field = '.json' === file.ext ? 'data' : 'markup'; + section = utils.getSection(file.base, field, store); + + if (section) { + return (0, _handleTemplates.updateTemplate)(filepath, section, store); + } + + console.log( // eslint-disable-line no-console + _chalk2.default.red(`Could not find associated KSS section for ${filepath}`)); + break; + + // KSS documentation (default extension is `.css`) + // Will also output a template if markup is inline + // Note: inline markup does _not_ support handlebars currently + case huron.get('kssExtension'): + return (0, _handleKSS.updateKSS)(filepath, store); + + // This should never happen if Gaze is working properly + default: + return store; + } + + return store; +} + +/** + * Logic for deleting file information and files based on file type (extension) + * + * @param {string} filepath - path to updated file. usually passed in from Gaze + * @param {object} store - memory store + * @return {object} newStore - map object of map object of entire data store + */ +function deleteFile(filepath, store) { + const huron = store.get('config'); + const file = _path2.default.parse(filepath); + let field = ''; + let section = null; + let newStore = store; + + switch (file.ext) { + // Plain HTML template, external + case '.html': + section = utils.getSection(file.base, 'markup', store); + + if (section) { + newStore = (0, _handleHTML.deleteHTML)(filepath, section, store); + } else if (file.dir.includes('prototypes') && file.name.includes('prototype-')) { + newStore = (0, _handleHTML.deletePrototype)(filepath, store); + } + break; + + case huron.get('templates').extension: + case '.json': + field = '.json' === file.ext ? 'data' : 'markup'; + section = utils.getSection(file.base, field, store); + + if (section) { + newStore = (0, _handleTemplates.deleteTemplate)(filepath, section, store); + } + break; + + case huron.get('kssExtension'): + section = utils.getSection(filepath, false, store); + + if (section) { + newStore = (0, _handleKSS.deleteKSS)(filepath, section, store); + } + break; + + default: + console.warn( // eslint-disable-line no-console + _chalk2.default.red(`Could not delete: ${file.name}`)); + break; + } + + return newStore; +} + +/** + * Logic for updating localized classnames from CSS modules + * + * @param {string} filepath - path to updated file. usually passed in from Gaze + * @param {object} store - memory store + * + * @return void + */ +function updateClassNames(filepath, store) { + const classNamesPath = store.getIn(['config', 'classNames']); + + if (filepath.includes(classNamesPath)) { + const oldClassnames = store.get('classNames'); + const newClassnames = utils.mergeClassnameJSON(classNamesPath); + + if (!(0, _isEqual2.default)(oldClassnames, newClassnames)) { + return store.set('classNames', newClassnames); + } + } + + return store; +} /***/ }), /* 12 */ -/* no static exports found */ -/* all exports used */ -/*!********************************!*\ - !*** ./src/cli/fileWatcher.js ***! - \********************************/ /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.watchedFiles = exports.extensions = undefined;\n\nvar _gaze = __webpack_require__(/*! gaze */ 22);\n\nvar _path = __webpack_require__(/*! path */ 0);\n\nvar _path2 = _interopRequireDefault(_path);\n\nvar _utils = __webpack_require__(/*! ./utils */ 1);\n\nvar _defaultStore = __webpack_require__(/*! ./defaultStore */ 6);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Huron configuration object\n *\n * @global\n */\nconst huron = _defaultStore.defaultStore.get('config');\n\n/**\n * Available file extensions. Extensions should not include the leading '.'\n *\n * @global\n */\nconst extensions = exports.extensions = [huron.get('kssExtension'), huron.get('templates').extension, 'html', 'json'].map(extension => extension.replace('.', ''));\n\n// Generate watch list for Gaze, start gaze\nconst watchedFiles = exports.watchedFiles = [];\n\n// Watch section template\nwatchedFiles.push(_path2.default.resolve(huron.get('sectionTemplate')));\n\n// Watch cssmodules classname files (if they exist)\nif (huron.get('classNames')) {\n watchedFiles.push(`${_path2.default.resolve(huron.get('classNames'))}/*.json`);\n}\n\n// Watch all provided kss directories\nhuron.get('kss').forEach(dir => {\n watchedFiles.push(`${(0, _utils.removeTrailingSlash)(dir)}/**/*.+(${extensions.join('|')})`);\n});\n\n/**\n * Gaze instance for watching all files, including KSS, html, hbs/template, and JSON\n *\n * @global\n */\nconst gaze = new _gaze.Gaze(watchedFiles);\n\nexports.default = gaze;//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTIuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vc3JjL2NsaS9maWxlV2F0Y2hlci5qcz80ZGI4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEdhemUgfSBmcm9tICdnYXplJztcbmltcG9ydCBwYXRoIGZyb20gJ3BhdGgnO1xuXG5pbXBvcnQgeyByZW1vdmVUcmFpbGluZ1NsYXNoIH0gZnJvbSAnLi91dGlscyc7XG5pbXBvcnQgeyBkZWZhdWx0U3RvcmUgfSBmcm9tICcuL2RlZmF1bHRTdG9yZSc7XG5cbi8qKlxuICogSHVyb24gY29uZmlndXJhdGlvbiBvYmplY3RcbiAqXG4gKiBAZ2xvYmFsXG4gKi9cbmNvbnN0IGh1cm9uID0gZGVmYXVsdFN0b3JlLmdldCgnY29uZmlnJyk7XG5cbi8qKlxuICogQXZhaWxhYmxlIGZpbGUgZXh0ZW5zaW9ucy4gRXh0ZW5zaW9ucyBzaG91bGQgbm90IGluY2x1ZGUgdGhlIGxlYWRpbmcgJy4nXG4gKlxuICogQGdsb2JhbFxuICovXG5leHBvcnQgY29uc3QgZXh0ZW5zaW9ucyA9IFtcbiAgaHVyb24uZ2V0KCdrc3NFeHRlbnNpb24nKSxcbiAgaHVyb24uZ2V0KCd0ZW1wbGF0ZXMnKS5leHRlbnNpb24sXG4gICdodG1sJyxcbiAgJ2pzb24nLFxuXS5tYXAoKGV4dGVuc2lvbikgPT4gZXh0ZW5zaW9uLnJlcGxhY2UoJy4nLCAnJykpO1xuXG4vLyBHZW5lcmF0ZSB3YXRjaCBsaXN0IGZvciBHYXplLCBzdGFydCBnYXplXG5leHBvcnQgY29uc3Qgd2F0Y2hlZEZpbGVzID0gW107XG5cbi8vIFdhdGNoIHNlY3Rpb24gdGVtcGxhdGVcbndhdGNoZWRGaWxlcy5wdXNoKHBhdGgucmVzb2x2ZShodXJvbi5nZXQoJ3NlY3Rpb25UZW1wbGF0ZScpKSk7XG5cbi8vIFdhdGNoIGNzc21vZHVsZXMgY2xhc3NuYW1lIGZpbGVzIChpZiB0aGV5IGV4aXN0KVxuaWYgKGh1cm9uLmdldCgnY2xhc3NOYW1lcycpKSB7XG4gIHdhdGNoZWRGaWxlcy5wdXNoKFxuICAgIGAke3BhdGgucmVzb2x2ZShodXJvbi5nZXQoJ2NsYXNzTmFtZXMnKSl9LyouanNvbmBcbiAgKTtcbn1cblxuLy8gV2F0Y2ggYWxsIHByb3ZpZGVkIGtzcyBkaXJlY3Rvcmllc1xuaHVyb24uZ2V0KCdrc3MnKS5mb3JFYWNoKChkaXIpID0+IHtcbiAgd2F0Y2hlZEZpbGVzLnB1c2goXG4gICAgYCR7cmVtb3ZlVHJhaWxpbmdTbGFzaChkaXIpfS8qKi8qLisoJHtleHRlbnNpb25zLmpvaW4oJ3wnKX0pYFxuICApO1xufSk7XG5cbi8qKlxuICogR2F6ZSBpbnN0YW5jZSBmb3Igd2F0Y2hpbmcgYWxsIGZpbGVzLCBpbmNsdWRpbmcgS1NTLCBodG1sLCBoYnMvdGVtcGxhdGUsIGFuZCBKU09OXG4gKlxuICogQGdsb2JhbFxuICovXG5jb25zdCBnYXplID0gbmV3IEdhemUod2F0Y2hlZEZpbGVzKTtcblxuZXhwb3J0IGRlZmF1bHQgZ2F6ZTtcblxuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyBzcmMvY2xpL2ZpbGVXYXRjaGVyLmpzIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7QUFDQTtBQUFBO0FBQ0E7OztBQUNBO0FBQ0E7QUFBQTtBQUNBOzs7QUFDQTs7Ozs7QUFLQTtBQUNBO0FBQ0E7Ozs7O0FBS0E7QUFDQTtBQU1BO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFHQTtBQUNBO0FBQ0E7Ozs7O0FBS0E7QUFDQTtBQUNBIiwic291cmNlUm9vdCI6IiJ9"); + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.watchedFiles = exports.extensions = undefined; + +var _gaze = __webpack_require__(22); + +var _path = __webpack_require__(0); + +var _path2 = _interopRequireDefault(_path); + +var _utils = __webpack_require__(1); + +var _defaultStore = __webpack_require__(6); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Huron configuration object + * + * @global + */ +const huron = _defaultStore.defaultStore.get('config'); + +/** + * Available file extensions. Extensions should not include the leading '.' + * + * @global + */ +const extensions = exports.extensions = [huron.get('kssExtension'), huron.get('templates').extension, 'html', 'json'].map(extension => extension.replace('.', '')); + +// Generate watch list for Gaze, start gaze +const watchedFiles = exports.watchedFiles = []; + +// Watch section template +watchedFiles.push(_path2.default.resolve(huron.get('sectionTemplate'))); + +// Watch cssmodules classname files (if they exist) +if (huron.get('classNames')) { + watchedFiles.push(`${_path2.default.resolve(huron.get('classNames'))}/*.json`); +} + +// Watch all provided kss directories +huron.get('kss').forEach(dir => { + watchedFiles.push(`${(0, _utils.removeTrailingSlash)(dir)}/**/*.+(${extensions.join('|')})`); +}); + +/** + * Gaze instance for watching all files, including KSS, html, hbs/template, and JSON + * + * @global + */ +const gaze = new _gaze.Gaze(watchedFiles); + +exports.default = gaze; /***/ }), /* 13 */ -/* no static exports found */ -/* all exports used */ -/*!***********************************!*\ - !*** ./src/cli/generateConfig.js ***! - \***********************************/ /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = generateConfig;\n\nvar _path = __webpack_require__(/*! path */ 0);\n\nvar _path2 = _interopRequireDefault(_path);\n\nvar _url = __webpack_require__(/*! url */ 28);\n\nvar _url2 = _interopRequireDefault(_url);\n\nvar _fsExtra = __webpack_require__(/*! fs-extra */ 3);\n\nvar _fsExtra2 = _interopRequireDefault(_fsExtra);\n\nvar _webpack = __webpack_require__(/*! webpack */ 5);\n\nvar _webpack2 = _interopRequireDefault(_webpack);\n\nvar _htmlWebpackPlugin = __webpack_require__(/*! html-webpack-plugin */ 23);\n\nvar _htmlWebpackPlugin2 = _interopRequireDefault(_htmlWebpackPlugin);\n\nvar _parseArgs = __webpack_require__(/*! ./parseArgs */ 4);\n\nvar _parseArgs2 = _interopRequireDefault(_parseArgs);\n\nvar _requireExternal = __webpack_require__(/*! ./requireExternal */ 16);\n\nvar _requireExternal2 = _interopRequireDefault(_requireExternal);\n\nvar _webpack3 = __webpack_require__(/*! ../defaultConfig/webpack.config */ 20);\n\nvar _webpack4 = _interopRequireDefault(_webpack3);\n\nvar _huron = __webpack_require__(/*! ../defaultConfig/huron.config */ 19);\n\nvar _huron2 = _interopRequireDefault(_huron);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nconst cwd = process.cwd();\n\n// Require configs passed in by user from CLI\n/** @module cli/generate-config */\nlet defaultConfig = false;\nconst localConfig = (0, _requireExternal2.default)(_path2.default.resolve(_parseArgs2.default.webpackConfig));\nconst localHuron = (0, _requireExternal2.default)(_path2.default.resolve(_parseArgs2.default.huronConfig));\n\n/**\n * Generate a mutant hybrid of the huron default webpack config and your local webpack config\n *\n * @function generateConfig\n * @param {object} config - local webpack config\n * @return {object} newConfig - updated data store\n */\nfunction generateConfig() {\n let newConfig = localConfig;\n let newHuron = localHuron;\n\n // Execute config function, if provided\n if ('function' === typeof newConfig) {\n newConfig = newConfig(_parseArgs2.default.env);\n }\n\n // Execute huron config function, if provided\n if ('function' === typeof newHuron) {\n newHuron = newHuron(_parseArgs2.default.env);\n }\n\n // Merge huron defaults with user settings\n newHuron = Object.assign({}, _huron2.default, newHuron);\n // Use user huron config to modify webpack defaults\n defaultConfig = (0, _webpack4.default)(newHuron);\n\n // Set ouput options\n newConfig.output = Object.assign({}, defaultConfig.output, newConfig.output);\n newConfig.output.path = defaultConfig.output.path;\n newConfig.output.publicPath = defaultConfig.output.publicPath;\n\n // configure entries\n newConfig = configureEntries(newHuron, newConfig);\n\n // configure plugins\n newConfig = configurePlugins(newHuron, newConfig);\n\n // configure loaders\n newConfig = configureLoaders(newHuron, newConfig);\n\n // Add HTMLWebpackPlugin for each configured prototype\n newConfig = configurePrototypes(newHuron, newConfig);\n\n // Remove existing devServer settings\n delete newConfig.devServer;\n\n return {\n huron: newHuron,\n webpack: newConfig\n };\n}\n\n/**\n * Configure and manage webpack entry points\n *\n * @param {object} huron - huron configuration object\n * @param {object} config - webpack configuration object\n * @return {object} newConfig - updated data store\n */\nfunction configureEntries(huron, config) {\n const entry = config.entry[huron.entry];\n const newConfig = config;\n\n newConfig.entry = {};\n if (!_parseArgs2.default.production) {\n newConfig.entry[huron.entry] = [`webpack-dev-server/client?http://localhost:${huron.port}`, 'webpack/hot/dev-server', _path2.default.join(cwd, huron.root, 'huron-assets/index')].concat(entry);\n } else {\n newConfig.entry[huron.entry] = [_path2.default.join(cwd, huron.root, 'huron-assets/index')].concat(entry);\n }\n\n return newConfig;\n}\n\n/**\n * Configure and manage webpack plugins\n *\n * @param {object} huron - huron configuration object\n * @param {object} config - webpack configuration object\n * @return {object} newConfig - updated data store\n */\nfunction configurePlugins(huron, config) {\n const newConfig = config;\n\n newConfig.plugins = config.plugins || [];\n\n if (!_parseArgs2.default.production) {\n if (newConfig.plugins && newConfig.plugins.length) {\n newConfig.plugins = newConfig.plugins.filter(plugin => 'HotModuleReplacementPlugin' !== plugin.constructor.name && 'NamedModulesPlugin' !== plugin.constructor.name);\n }\n newConfig.plugins = newConfig.plugins.concat([new _webpack2.default.HotModuleReplacementPlugin(), new _webpack2.default.NamedModulesPlugin()]);\n }\n\n return newConfig;\n}\n\n/**\n * Configure and manage webpack loaders\n *\n * @param {object} huron - huron configuration object\n * @param {object} config - webpack configuration object\n * @return {object} newConfig - updated data store\n */\nfunction configureLoaders(huron, config) {\n // Manage loaders\n const templatesLoader = huron.templates.rule || {};\n const newConfig = config;\n\n // Make sure we're only using templates loader for files in huron root\n templatesLoader.include = [_path2.default.join(cwd, huron.root, huron.output)];\n\n // Normalize module and module.rules\n newConfig.module = newConfig.module || {};\n newConfig.module.rules = newConfig.module.rules || newConfig.module.loaders || [];\n\n // Add default loaders\n newConfig.module.rules = defaultConfig.module.rules.concat(newConfig.module.rules, templatesLoader);\n\n return newConfig;\n}\n\n/**\n * Create an HTML webpack plugin for each configured prototype\n *\n * @param {object} huron - huron configuration object\n * @param {object} config - webpack configuration object\n * @return {object} newConfig - updated data store\n */\nfunction configurePrototypes(huron, config) {\n const wrapperTemplate = _fsExtra2.default.readFileSync(_path2.default.join(__dirname, '../../templates/prototypeTemplate.hbs'), 'utf8');\n\n const defaultHTMLPluginOptions = {\n title: 'Huron',\n window: huron.window,\n js: [],\n css: [],\n filename: 'index.html',\n template: _path2.default.join(cwd, huron.root, 'huron-assets/prototypeTemplate.hbs'),\n inject: false,\n chunks: [huron.entry]\n };\n const newConfig = config;\n\n // Write prototype template file for HTML webpack plugin\n _fsExtra2.default.outputFileSync(_path2.default.join(cwd, huron.root, 'huron-assets/prototypeTemplate.hbs'), wrapperTemplate);\n\n huron.prototypes.forEach(prototype => {\n const newPrototype = prototype;\n let opts = {};\n\n // Merge configured settings with default settings\n if ('string' === typeof prototype) {\n opts = Object.assign({}, defaultHTMLPluginOptions, {\n title: prototype,\n filename: `${prototype}.html`\n });\n } else if ('object' === typeof prototype && {}.hasOwnProperty.call(prototype, 'title')) {\n // Create filename based on configured title if not provided\n if (!prototype.filename) {\n newPrototype.filename = `${prototype.title}.html`;\n }\n\n // Move css assets for this prototype,\n // reset css option with new file paths\n if (prototype.css) {\n newPrototype.css = moveAdditionalAssets(prototype.css, 'css', huron);\n }\n\n // Move js assets for this prototype,\n // reset js option with new file paths\n if (prototype.js) {\n newPrototype.js = moveAdditionalAssets(prototype.js, 'js', huron);\n }\n\n opts = Object.assign({}, defaultHTMLPluginOptions, newPrototype);\n }\n\n // Move global css assets,\n // reset css option with new file paths\n if (huron.css.length) {\n opts.css = opts.css.concat(moveAdditionalAssets(huron.css, 'css', huron));\n }\n\n // Move global js assets,\n // reset js option with new file paths\n if (huron.js.length) {\n opts.js = opts.js.concat(moveAdditionalAssets(huron.js, 'js', huron));\n }\n\n // Push a new plugin for each configured prototype\n if (Object.keys(opts).length) {\n newConfig.plugins.push(new _htmlWebpackPlugin2.default(opts));\n }\n });\n\n return newConfig;\n}\n\n/**\n * Move relative (and local) js and css assets provided in huron options\n *\n * @param {array|string} assets - array of assets or single asset\n * @param {string} subdir - subdirectory in huron root from which to load additional asset\n * @param {object} huron - huron configuration object\n * @return {array} assetResults - paths to js and css assets\n */\nfunction moveAdditionalAssets(assets, subdir = '', huron) {\n const currentAssets = [].concat(assets);\n const assetResults = [];\n\n currentAssets.forEach(asset => {\n const assetInfo = _path2.default.parse(asset);\n const assetURL = _url2.default.parse(asset);\n const sourcePath = _path2.default.join(cwd, asset);\n const outputPath = _path2.default.resolve(cwd, huron.root, subdir, assetInfo.base);\n const loadPath = _parseArgs2.default.production ? _path2.default.join(subdir, assetInfo.base) : _path2.default.join('/', subdir, assetInfo.base); // Use absolute path in development\n let contents = false;\n\n if (!_path2.default.isAbsolute(asset) && !assetURL.protocol) {\n try {\n contents = _fsExtra2.default.readFileSync(sourcePath);\n } catch (e) {\n console.warn(`could not read ${sourcePath}`);\n }\n\n if (contents) {\n _fsExtra2.default.outputFileSync(outputPath, contents);\n assetResults.push(loadPath);\n }\n } else {\n assetResults.push(asset);\n }\n });\n\n return assetResults;\n}//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTMuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vc3JjL2NsaS9nZW5lcmF0ZUNvbmZpZy5qcz9lZGUwIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBAbW9kdWxlIGNsaS9nZW5lcmF0ZS1jb25maWcgKi9cbmltcG9ydCBwYXRoIGZyb20gJ3BhdGgnO1xuaW1wb3J0IHVybCBmcm9tICd1cmwnO1xuaW1wb3J0IGZzIGZyb20gJ2ZzLWV4dHJhJztcbmltcG9ydCB3ZWJwYWNrIGZyb20gJ3dlYnBhY2snO1xuaW1wb3J0IEhUTUxXZWJwYWNrUGx1Z2luIGZyb20gJ2h0bWwtd2VicGFjay1wbHVnaW4nO1xuXG5pbXBvcnQgcHJvZ3JhbSBmcm9tICcuL3BhcnNlQXJncyc7XG5pbXBvcnQgcmVxdWlyZUV4dGVybmFsIGZyb20gJy4vcmVxdWlyZUV4dGVybmFsJztcbmltcG9ydCBkZWZhdWx0V2VicGFjayBmcm9tICcuLi9kZWZhdWx0Q29uZmlnL3dlYnBhY2suY29uZmlnJztcbmltcG9ydCBkZWZhdWx0SHVyb24gZnJvbSAnLi4vZGVmYXVsdENvbmZpZy9odXJvbi5jb25maWcnO1xuXG5jb25zdCBjd2QgPSBwcm9jZXNzLmN3ZCgpO1xuXG4vLyBSZXF1aXJlIGNvbmZpZ3MgcGFzc2VkIGluIGJ5IHVzZXIgZnJvbSBDTElcbmxldCBkZWZhdWx0Q29uZmlnID0gZmFsc2U7XG5jb25zdCBsb2NhbENvbmZpZyA9IHJlcXVpcmVFeHRlcm5hbChcbiAgcGF0aC5yZXNvbHZlKHByb2dyYW0ud2VicGFja0NvbmZpZylcbik7XG5jb25zdCBsb2NhbEh1cm9uID0gcmVxdWlyZUV4dGVybmFsKFxuICBwYXRoLnJlc29sdmUocHJvZ3JhbS5odXJvbkNvbmZpZylcbik7XG5cbi8qKlxuICogR2VuZXJhdGUgYSBtdXRhbnQgaHlicmlkIG9mIHRoZSBodXJvbiBkZWZhdWx0IHdlYnBhY2sgY29uZmlnIGFuZCB5b3VyIGxvY2FsIHdlYnBhY2sgY29uZmlnXG4gKlxuICogQGZ1bmN0aW9uIGdlbmVyYXRlQ29uZmlnXG4gKiBAcGFyYW0ge29iamVjdH0gY29uZmlnIC0gbG9jYWwgd2VicGFjayBjb25maWdcbiAqIEByZXR1cm4ge29iamVjdH0gbmV3Q29uZmlnIC0gdXBkYXRlZCBkYXRhIHN0b3JlXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGdlbmVyYXRlQ29uZmlnKCkge1xuICBsZXQgbmV3Q29uZmlnID0gbG9jYWxDb25maWc7XG4gIGxldCBuZXdIdXJvbiA9IGxvY2FsSHVyb247XG5cbiAgLy8gRXhlY3V0ZSBjb25maWcgZnVuY3Rpb24sIGlmIHByb3ZpZGVkXG4gIGlmICgnZnVuY3Rpb24nID09PSB0eXBlb2YgbmV3Q29uZmlnKSB7XG4gICAgbmV3Q29uZmlnID0gbmV3Q29uZmlnKHByb2dyYW0uZW52KTtcbiAgfVxuXG4gIC8vIEV4ZWN1dGUgaHVyb24gY29uZmlnIGZ1bmN0aW9uLCBpZiBwcm92aWRlZFxuICBpZiAoJ2Z1bmN0aW9uJyA9PT0gdHlwZW9mIG5ld0h1cm9uKSB7XG4gICAgbmV3SHVyb24gPSBuZXdIdXJvbihwcm9ncmFtLmVudik7XG4gIH1cblxuICAvLyBNZXJnZSBodXJvbiBkZWZhdWx0cyB3aXRoIHVzZXIgc2V0dGluZ3NcbiAgbmV3SHVyb24gPSBPYmplY3QuYXNzaWduKHt9LCBkZWZhdWx0SHVyb24sIG5ld0h1cm9uKTtcbiAgLy8gVXNlIHVzZXIgaHVyb24gY29uZmlnIHRvIG1vZGlmeSB3ZWJwYWNrIGRlZmF1bHRzXG4gIGRlZmF1bHRDb25maWcgPSBkZWZhdWx0V2VicGFjayhuZXdIdXJvbik7XG5cbiAgLy8gU2V0IG91cHV0IG9wdGlvbnNcbiAgbmV3Q29uZmlnLm91dHB1dCA9IE9iamVjdC5hc3NpZ24oe30sIGRlZmF1bHRDb25maWcub3V0cHV0LCBuZXdDb25maWcub3V0cHV0KTtcbiAgbmV3Q29uZmlnLm91dHB1dC5wYXRoID0gZGVmYXVsdENvbmZpZy5vdXRwdXQucGF0aDtcbiAgbmV3Q29uZmlnLm91dHB1dC5wdWJsaWNQYXRoID0gZGVmYXVsdENvbmZpZy5vdXRwdXQucHVibGljUGF0aDtcblxuICAvLyBjb25maWd1cmUgZW50cmllc1xuICBuZXdDb25maWcgPSBjb25maWd1cmVFbnRyaWVzKG5ld0h1cm9uLCBuZXdDb25maWcpO1xuXG4gIC8vIGNvbmZpZ3VyZSBwbHVnaW5zXG4gIG5ld0NvbmZpZyA9IGNvbmZpZ3VyZVBsdWdpbnMobmV3SHVyb24sIG5ld0NvbmZpZyk7XG5cbiAgLy8gY29uZmlndXJlIGxvYWRlcnNcbiAgbmV3Q29uZmlnID0gY29uZmlndXJlTG9hZGVycyhuZXdIdXJvbiwgbmV3Q29uZmlnKTtcblxuICAvLyBBZGQgSFRNTFdlYnBhY2tQbHVnaW4gZm9yIGVhY2ggY29uZmlndXJlZCBwcm90b3R5cGVcbiAgbmV3Q29uZmlnID0gY29uZmlndXJlUHJvdG90eXBlcyhuZXdIdXJvbiwgbmV3Q29uZmlnKTtcblxuICAvLyBSZW1vdmUgZXhpc3RpbmcgZGV2U2VydmVyIHNldHRpbmdzXG4gIGRlbGV0ZSBuZXdDb25maWcuZGV2U2VydmVyO1xuXG4gIHJldHVybiB7XG4gICAgaHVyb246IG5ld0h1cm9uLFxuICAgIHdlYnBhY2s6IG5ld0NvbmZpZyxcbiAgfTtcbn1cblxuLyoqXG4gKiBDb25maWd1cmUgYW5kIG1hbmFnZSB3ZWJwYWNrIGVudHJ5IHBvaW50c1xuICpcbiAqIEBwYXJhbSB7b2JqZWN0fSBodXJvbiAtIGh1cm9uIGNvbmZpZ3VyYXRpb24gb2JqZWN0XG4gKiBAcGFyYW0ge29iamVjdH0gY29uZmlnIC0gd2VicGFjayBjb25maWd1cmF0aW9uIG9iamVjdFxuICogQHJldHVybiB7b2JqZWN0fSBuZXdDb25maWcgLSB1cGRhdGVkIGRhdGEgc3RvcmVcbiAqL1xuZnVuY3Rpb24gY29uZmlndXJlRW50cmllcyhodXJvbiwgY29uZmlnKSB7XG4gIGNvbnN0IGVudHJ5ID0gY29uZmlnLmVudHJ5W2h1cm9uLmVudHJ5XTtcbiAgY29uc3QgbmV3Q29uZmlnID0gY29uZmlnO1xuXG4gIG5ld0NvbmZpZy5lbnRyeSA9IHt9O1xuICBpZiAoIXByb2dyYW0ucHJvZHVjdGlvbikge1xuICAgIG5ld0NvbmZpZy5lbnRyeVtodXJvbi5lbnRyeV0gPSBbXG4gICAgICBgd2VicGFjay1kZXYtc2VydmVyL2NsaWVudD9odHRwOi8vbG9jYWxob3N0OiR7aHVyb24ucG9ydH1gLFxuICAgICAgJ3dlYnBhY2svaG90L2Rldi1zZXJ2ZXInLFxuICAgICAgcGF0aC5qb2luKGN3ZCwgaHVyb24ucm9vdCwgJ2h1cm9uLWFzc2V0cy9pbmRleCcpLFxuICAgIF0uY29uY2F0KGVudHJ5KTtcbiAgfSBlbHNlIHtcbiAgICBuZXdDb25maWcuZW50cnlbaHVyb24uZW50cnldID0gW1xuICAgICAgcGF0aC5qb2luKGN3ZCwgaHVyb24ucm9vdCwgJ2h1cm9uLWFzc2V0cy9pbmRleCcpLFxuICAgIF0uY29uY2F0KGVudHJ5KTtcbiAgfVxuXG4gIHJldHVybiBuZXdDb25maWc7XG59XG5cbi8qKlxuICogQ29uZmlndXJlIGFuZCBtYW5hZ2Ugd2VicGFjayBwbHVnaW5zXG4gKlxuICogQHBhcmFtIHtvYmplY3R9IGh1cm9uIC0gaHVyb24gY29uZmlndXJhdGlvbiBvYmplY3RcbiAqIEBwYXJhbSB7b2JqZWN0fSBjb25maWcgLSB3ZWJwYWNrIGNvbmZpZ3VyYXRpb24gb2JqZWN0XG4gKiBAcmV0dXJuIHtvYmplY3R9IG5ld0NvbmZpZyAtIHVwZGF0ZWQgZGF0YSBzdG9yZVxuICovXG5mdW5jdGlvbiBjb25maWd1cmVQbHVnaW5zKGh1cm9uLCBjb25maWcpIHtcbiAgY29uc3QgbmV3Q29uZmlnID0gY29uZmlnO1xuXG4gIG5ld0NvbmZpZy5wbHVnaW5zID0gY29uZmlnLnBsdWdpbnMgfHwgW107XG5cbiAgaWYgKCFwcm9ncmFtLnByb2R1Y3Rpb24pIHtcbiAgICBpZiAobmV3Q29uZmlnLnBsdWdpbnMgJiYgbmV3Q29uZmlnLnBsdWdpbnMubGVuZ3RoKSB7XG4gICAgICBuZXdDb25maWcucGx1Z2lucyA9IG5ld0NvbmZpZy5wbHVnaW5zLmZpbHRlcihcbiAgICAgICAgKHBsdWdpbikgPT4gJ0hvdE1vZHVsZVJlcGxhY2VtZW50UGx1Z2luJyAhPT0gcGx1Z2luLmNvbnN0cnVjdG9yLm5hbWUgJiZcbiAgICAgICAgICAnTmFtZWRNb2R1bGVzUGx1Z2luJyAhPT0gcGx1Z2luLmNvbnN0cnVjdG9yLm5hbWVcbiAgICAgICk7XG4gICAgfVxuICAgIG5ld0NvbmZpZy5wbHVnaW5zID0gbmV3Q29uZmlnLnBsdWdpbnNcbiAgICAgIC5jb25jYXQoW1xuICAgICAgICBuZXcgd2VicGFjay5Ib3RNb2R1bGVSZXBsYWNlbWVudFBsdWdpbigpLFxuICAgICAgICBuZXcgd2VicGFjay5OYW1lZE1vZHVsZXNQbHVnaW4oKSxcbiAgICAgIF0pO1xuICB9XG5cbiAgcmV0dXJuIG5ld0NvbmZpZztcbn1cblxuLyoqXG4gKiBDb25maWd1cmUgYW5kIG1hbmFnZSB3ZWJwYWNrIGxvYWRlcnNcbiAqXG4gKiBAcGFyYW0ge29iamVjdH0gaHVyb24gLSBodXJvbiBjb25maWd1cmF0aW9uIG9iamVjdFxuICogQHBhcmFtIHtvYmplY3R9IGNvbmZpZyAtIHdlYnBhY2sgY29uZmlndXJhdGlvbiBvYmplY3RcbiAqIEByZXR1cm4ge29iamVjdH0gbmV3Q29uZmlnIC0gdXBkYXRlZCBkYXRhIHN0b3JlXG4gKi9cbmZ1bmN0aW9uIGNvbmZpZ3VyZUxvYWRlcnMoaHVyb24sIGNvbmZpZykge1xuICAvLyBNYW5hZ2UgbG9hZGVyc1xuICBjb25zdCB0ZW1wbGF0ZXNMb2FkZXIgPSBodXJvbi50ZW1wbGF0ZXMucnVsZSB8fCB7fTtcbiAgY29uc3QgbmV3Q29uZmlnID0gY29uZmlnO1xuXG4gIC8vIE1ha2Ugc3VyZSB3ZSdyZSBvbmx5IHVzaW5nIHRlbXBsYXRlcyBsb2FkZXIgZm9yIGZpbGVzIGluIGh1cm9uIHJvb3RcbiAgdGVtcGxhdGVzTG9hZGVyLmluY2x1ZGUgPSBbcGF0aC5qb2luKGN3ZCwgaHVyb24ucm9vdCwgaHVyb24ub3V0cHV0KV07XG5cbiAgLy8gTm9ybWFsaXplIG1vZHVsZSBhbmQgbW9kdWxlLnJ1bGVzXG4gIG5ld0NvbmZpZy5tb2R1bGUgPSBuZXdDb25maWcubW9kdWxlIHx8IHt9O1xuICBuZXdDb25maWcubW9kdWxlLnJ1bGVzID0gbmV3Q29uZmlnLm1vZHVsZS5ydWxlcyB8fFxuICAgIG5ld0NvbmZpZy5tb2R1bGUubG9hZGVycyB8fFxuICAgIFtdO1xuXG4gIC8vIEFkZCBkZWZhdWx0IGxvYWRlcnNcbiAgbmV3Q29uZmlnLm1vZHVsZS5ydWxlcyA9IGRlZmF1bHRDb25maWcubW9kdWxlLnJ1bGVzXG4gICAgLmNvbmNhdChcbiAgICAgIG5ld0NvbmZpZy5tb2R1bGUucnVsZXMsXG4gICAgICB0ZW1wbGF0ZXNMb2FkZXJcbiAgICApO1xuXG4gIHJldHVybiBuZXdDb25maWc7XG59XG5cbi8qKlxuICogQ3JlYXRlIGFuIEhUTUwgd2VicGFjayBwbHVnaW4gZm9yIGVhY2ggY29uZmlndXJlZCBwcm90b3R5cGVcbiAqXG4gKiBAcGFyYW0ge29iamVjdH0gaHVyb24gLSBodXJvbiBjb25maWd1cmF0aW9uIG9iamVjdFxuICogQHBhcmFtIHtvYmplY3R9IGNvbmZpZyAtIHdlYnBhY2sgY29uZmlndXJhdGlvbiBvYmplY3RcbiAqIEByZXR1cm4ge29iamVjdH0gbmV3Q29uZmlnIC0gdXBkYXRlZCBkYXRhIHN0b3JlXG4gKi9cbmZ1bmN0aW9uIGNvbmZpZ3VyZVByb3RvdHlwZXMoaHVyb24sIGNvbmZpZykge1xuICBjb25zdCB3cmFwcGVyVGVtcGxhdGUgPSBmcy5yZWFkRmlsZVN5bmMoXG4gICAgcGF0aC5qb2luKF9fZGlybmFtZSwgJy4uLy4uL3RlbXBsYXRlcy9wcm90b3R5cGVUZW1wbGF0ZS5oYnMnKSxcbiAgICAndXRmOCdcbiAgKTtcblxuICBjb25zdCBkZWZhdWx0SFRNTFBsdWdpbk9wdGlvbnMgPSB7XG4gICAgdGl0bGU6ICdIdXJvbicsXG4gICAgd2luZG93OiBodXJvbi53aW5kb3csXG4gICAganM6IFtdLFxuICAgIGNzczogW10sXG4gICAgZmlsZW5hbWU6ICdpbmRleC5odG1sJyxcbiAgICB0ZW1wbGF0ZTogcGF0aC5qb2luKFxuICAgICAgY3dkLFxuICAgICAgaHVyb24ucm9vdCxcbiAgICAgICdodXJvbi1hc3NldHMvcHJvdG90eXBlVGVtcGxhdGUuaGJzJ1xuICAgICksXG4gICAgaW5qZWN0OiBmYWxzZSxcbiAgICBjaHVua3M6IFtodXJvbi5lbnRyeV0sXG4gIH07XG4gIGNvbnN0IG5ld0NvbmZpZyA9IGNvbmZpZztcblxuICAvLyBXcml0ZSBwcm90b3R5cGUgdGVtcGxhdGUgZmlsZSBmb3IgSFRNTCB3ZWJwYWNrIHBsdWdpblxuICBmcy5vdXRwdXRGaWxlU3luYyhcbiAgICBwYXRoLmpvaW4oY3dkLCBodXJvbi5yb290LCAnaHVyb24tYXNzZXRzL3Byb3RvdHlwZVRlbXBsYXRlLmhicycpLFxuICAgIHdyYXBwZXJUZW1wbGF0ZVxuICApO1xuXG4gIGh1cm9uLnByb3RvdHlwZXMuZm9yRWFjaCgocHJvdG90eXBlKSA9PiB7XG4gICAgY29uc3QgbmV3UHJvdG90eXBlID0gcHJvdG90eXBlO1xuICAgIGxldCBvcHRzID0ge307XG5cbiAgICAvLyBNZXJnZSBjb25maWd1cmVkIHNldHRpbmdzIHdpdGggZGVmYXVsdCBzZXR0aW5nc1xuICAgIGlmICgnc3RyaW5nJyA9PT0gdHlwZW9mIHByb3RvdHlwZSkge1xuICAgICAgb3B0cyA9IE9iamVjdC5hc3NpZ24oe30sIGRlZmF1bHRIVE1MUGx1Z2luT3B0aW9ucywge1xuICAgICAgICB0aXRsZTogcHJvdG90eXBlLFxuICAgICAgICBmaWxlbmFtZTogYCR7cHJvdG90eXBlfS5odG1sYCxcbiAgICAgIH0pO1xuICAgIH0gZWxzZSBpZiAoXG4gICAgICAnb2JqZWN0JyA9PT0gdHlwZW9mIHByb3RvdHlwZSAmJlxuICAgICAge30uaGFzT3duUHJvcGVydHkuY2FsbChwcm90b3R5cGUsICd0aXRsZScpXG4gICAgKSB7XG4gICAgICAvLyBDcmVhdGUgZmlsZW5hbWUgYmFzZWQgb24gY29uZmlndXJlZCB0aXRsZSBpZiBub3QgcHJvdmlkZWRcbiAgICAgIGlmICghcHJvdG90eXBlLmZpbGVuYW1lKSB7XG4gICAgICAgIG5ld1Byb3RvdHlwZS5maWxlbmFtZSA9IGAke3Byb3RvdHlwZS50aXRsZX0uaHRtbGA7XG4gICAgICB9XG5cbiAgICAgIC8vIE1vdmUgY3NzIGFzc2V0cyBmb3IgdGhpcyBwcm90b3R5cGUsXG4gICAgICAvLyByZXNldCBjc3Mgb3B0aW9uIHdpdGggbmV3IGZpbGUgcGF0aHNcbiAgICAgIGlmIChwcm90b3R5cGUuY3NzKSB7XG4gICAgICAgIG5ld1Byb3RvdHlwZS5jc3MgPSBtb3ZlQWRkaXRpb25hbEFzc2V0cyhwcm90b3R5cGUuY3NzLCAnY3NzJywgaHVyb24pO1xuICAgICAgfVxuXG4gICAgICAvLyBNb3ZlIGpzIGFzc2V0cyBmb3IgdGhpcyBwcm90b3R5cGUsXG4gICAgICAvLyByZXNldCBqcyBvcHRpb24gd2l0aCBuZXcgZmlsZSBwYXRoc1xuICAgICAgaWYgKHByb3RvdHlwZS5qcykge1xuICAgICAgICBuZXdQcm90b3R5cGUuanMgPSBtb3ZlQWRkaXRpb25hbEFzc2V0cyhwcm90b3R5cGUuanMsICdqcycsIGh1cm9uKTtcbiAgICAgIH1cblxuICAgICAgb3B0cyA9IE9iamVjdC5hc3NpZ24oe30sIGRlZmF1bHRIVE1MUGx1Z2luT3B0aW9ucywgbmV3UHJvdG90eXBlKTtcbiAgICB9XG5cbiAgICAvLyBNb3ZlIGdsb2JhbCBjc3MgYXNzZXRzLFxuICAgIC8vIHJlc2V0IGNzcyBvcHRpb24gd2l0aCBuZXcgZmlsZSBwYXRoc1xuICAgIGlmIChodXJvbi5jc3MubGVuZ3RoKSB7XG4gICAgICBvcHRzLmNzcyA9IG9wdHMuY3NzLmNvbmNhdChcbiAgICAgICAgbW92ZUFkZGl0aW9uYWxBc3NldHMoaHVyb24uY3NzLCAnY3NzJywgaHVyb24pXG4gICAgICApO1xuICAgIH1cblxuICAgIC8vIE1vdmUgZ2xvYmFsIGpzIGFzc2V0cyxcbiAgICAvLyByZXNldCBqcyBvcHRpb24gd2l0aCBuZXcgZmlsZSBwYXRoc1xuICAgIGlmIChodXJvbi5qcy5sZW5ndGgpIHtcbiAgICAgIG9wdHMuanMgPSBvcHRzLmpzLmNvbmNhdChcbiAgICAgICAgbW92ZUFkZGl0aW9uYWxBc3NldHMoaHVyb24uanMsICdqcycsIGh1cm9uKVxuICAgICAgKTtcbiAgICB9XG5cbiAgICAvLyBQdXNoIGEgbmV3IHBsdWdpbiBmb3IgZWFjaCBjb25maWd1cmVkIHByb3RvdHlwZVxuICAgIGlmIChPYmplY3Qua2V5cyhvcHRzKS5sZW5ndGgpIHtcbiAgICAgIG5ld0NvbmZpZy5wbHVnaW5zLnB1c2goXG4gICAgICAgIG5ldyBIVE1MV2VicGFja1BsdWdpbihvcHRzKVxuICAgICAgKTtcbiAgICB9XG4gIH0pO1xuXG4gIHJldHVybiBuZXdDb25maWc7XG59XG5cbi8qKlxuICogTW92ZSByZWxhdGl2ZSAoYW5kIGxvY2FsKSBqcyBhbmQgY3NzIGFzc2V0cyBwcm92aWRlZCBpbiBodXJvbiBvcHRpb25zXG4gKlxuICogQHBhcmFtIHthcnJheXxzdHJpbmd9IGFzc2V0cyAtIGFycmF5IG9mIGFzc2V0cyBvciBzaW5nbGUgYXNzZXRcbiAqIEBwYXJhbSB7c3RyaW5nfSBzdWJkaXIgLSBzdWJkaXJlY3RvcnkgaW4gaHVyb24gcm9vdCBmcm9tIHdoaWNoIHRvIGxvYWQgYWRkaXRpb25hbCBhc3NldFxuICogQHBhcmFtIHtvYmplY3R9IGh1cm9uIC0gaHVyb24gY29uZmlndXJhdGlvbiBvYmplY3RcbiAqIEByZXR1cm4ge2FycmF5fSBhc3NldFJlc3VsdHMgLSBwYXRocyB0byBqcyBhbmQgY3NzIGFzc2V0c1xuICovXG5mdW5jdGlvbiBtb3ZlQWRkaXRpb25hbEFzc2V0cyhhc3NldHMsIHN1YmRpciA9ICcnLCBodXJvbikge1xuICBjb25zdCBjdXJyZW50QXNzZXRzID0gW10uY29uY2F0KGFzc2V0cyk7XG4gIGNvbnN0IGFzc2V0UmVzdWx0cyA9IFtdO1xuXG4gIGN1cnJlbnRBc3NldHMuZm9yRWFjaCgoYXNzZXQpID0+IHtcbiAgICBjb25zdCBhc3NldEluZm8gPSBwYXRoLnBhcnNlKGFzc2V0KTtcbiAgICBjb25zdCBhc3NldFVSTCA9IHVybC5wYXJzZShhc3NldCk7XG4gICAgY29uc3Qgc291cmNlUGF0aCA9IHBhdGguam9pbihjd2QsIGFzc2V0KTtcbiAgICBjb25zdCBvdXRwdXRQYXRoID0gcGF0aC5yZXNvbHZlKGN3ZCwgaHVyb24ucm9vdCwgc3ViZGlyLCBhc3NldEluZm8uYmFzZSk7XG4gICAgY29uc3QgbG9hZFBhdGggPSBwcm9ncmFtLnByb2R1Y3Rpb24gP1xuICAgICAgcGF0aC5qb2luKHN1YmRpciwgYXNzZXRJbmZvLmJhc2UpIDpcbiAgICAgIHBhdGguam9pbignLycsIHN1YmRpciwgYXNzZXRJbmZvLmJhc2UpOyAvLyBVc2UgYWJzb2x1dGUgcGF0aCBpbiBkZXZlbG9wbWVudFxuICAgIGxldCBjb250ZW50cyA9IGZhbHNlO1xuXG4gICAgaWYgKFxuICAgICAgIXBhdGguaXNBYnNvbHV0ZShhc3NldCkgJiZcbiAgICAgICFhc3NldFVSTC5wcm90b2NvbFxuICAgICkge1xuICAgICAgdHJ5IHtcbiAgICAgICAgY29udGVudHMgPSBmcy5yZWFkRmlsZVN5bmMoc291cmNlUGF0aCk7XG4gICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgIGNvbnNvbGUud2FybihgY291bGQgbm90IHJlYWQgJHtzb3VyY2VQYXRofWApO1xuICAgICAgfVxuXG4gICAgICBpZiAoY29udGVudHMpIHtcbiAgICAgICAgZnMub3V0cHV0RmlsZVN5bmMob3V0cHV0UGF0aCwgY29udGVudHMpO1xuICAgICAgICBhc3NldFJlc3VsdHMucHVzaChsb2FkUGF0aCk7XG4gICAgICB9XG4gICAgfSBlbHNlIHtcbiAgICAgIGFzc2V0UmVzdWx0cy5wdXNoKGFzc2V0KTtcbiAgICB9XG4gIH0pO1xuXG4gIHJldHVybiBhc3NldFJlc3VsdHM7XG59XG5cblxuXG4vLyBXRUJQQUNLIEZPT1RFUiAvL1xuLy8gc3JjL2NsaS9nZW5lcmF0ZUNvbmZpZy5qcyJdLCJtYXBwaW5ncyI6Ijs7Ozs7QUE4QkE7QUFDQTtBQTlCQTtBQUNBOzs7QUFBQTtBQUNBOzs7QUFBQTtBQUNBOzs7QUFBQTtBQUNBOzs7QUFBQTtBQUNBOzs7QUFDQTtBQUNBOzs7QUFBQTtBQUNBOzs7QUFBQTtBQUNBOzs7QUFBQTtBQUNBOzs7OztBQUNBO0FBQ0E7QUFDQTtBQWRBO0FBZUE7QUFDQTtBQUdBO0FBQ0E7QUFHQTs7Ozs7OztBQU9BO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFDQTtBQUNBOzs7Ozs7O0FBT0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFLQTtBQUNBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7O0FBT0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUlBO0FBQ0E7QUFLQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7Ozs7Ozs7QUFPQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFHQTtBQUNBO0FBQ0E7QUFLQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7OztBQU9BO0FBQ0E7QUFDQTtBQUlBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBS0E7QUFDQTtBQVpBO0FBY0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUlBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFJQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7Ozs7Ozs7O0FBUUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFHQTtBQUNBO0FBQ0E7QUFJQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlUm9vdCI6IiJ9"); + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = generateConfig; + +var _path = __webpack_require__(0); + +var _path2 = _interopRequireDefault(_path); + +var _url = __webpack_require__(28); + +var _url2 = _interopRequireDefault(_url); + +var _fsExtra = __webpack_require__(3); + +var _fsExtra2 = _interopRequireDefault(_fsExtra); + +var _webpack = __webpack_require__(5); + +var _webpack2 = _interopRequireDefault(_webpack); + +var _htmlWebpackPlugin = __webpack_require__(23); + +var _htmlWebpackPlugin2 = _interopRequireDefault(_htmlWebpackPlugin); + +var _parseArgs = __webpack_require__(4); + +var _parseArgs2 = _interopRequireDefault(_parseArgs); + +var _requireExternal = __webpack_require__(16); + +var _requireExternal2 = _interopRequireDefault(_requireExternal); + +var _webpack3 = __webpack_require__(19); + +var _webpack4 = _interopRequireDefault(_webpack3); + +var _huron = __webpack_require__(18); + +var _huron2 = _interopRequireDefault(_huron); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +const cwd = process.cwd(); + +// Require configs passed in by user from CLI +/** @module cli/generate-config */ +let defaultConfig = false; +const localConfig = (0, _requireExternal2.default)(_path2.default.resolve(_parseArgs2.default.webpackConfig)); +const localHuron = (0, _requireExternal2.default)(_path2.default.resolve(_parseArgs2.default.huronConfig)); + +/** + * Generate a mutant hybrid of the huron default webpack config and your local webpack config + * + * @function generateConfig + * @param {object} config - local webpack config + * @return {object} newConfig - updated data store + */ +function generateConfig() { + let newConfig = localConfig; + let newHuron = localHuron; + + // Execute config function, if provided + if ('function' === typeof newConfig) { + newConfig = newConfig(_parseArgs2.default.env); + } + + // Execute huron config function, if provided + if ('function' === typeof newHuron) { + newHuron = newHuron(_parseArgs2.default.env); + } + + // Merge huron defaults with user settings + newHuron = Object.assign({}, _huron2.default, newHuron); + // Use user huron config to modify webpack defaults + defaultConfig = (0, _webpack4.default)(newHuron); + + // Set ouput options + newConfig.output = Object.assign({}, defaultConfig.output, newConfig.output); + newConfig.output.path = defaultConfig.output.path; + newConfig.output.publicPath = defaultConfig.output.publicPath; + + // configure entries + newConfig = configureEntries(newHuron, newConfig); + + // configure plugins + newConfig = configurePlugins(newHuron, newConfig); + + // configure loaders + newConfig = configureLoaders(newHuron, newConfig); + + // Add HTMLWebpackPlugin for each configured prototype + newConfig = configurePrototypes(newHuron, newConfig); + + // Remove existing devServer settings + delete newConfig.devServer; + + return { + huron: newHuron, + webpack: newConfig + }; +} + +/** + * Configure and manage webpack entry points + * + * @param {object} huron - huron configuration object + * @param {object} config - webpack configuration object + * @return {object} newConfig - updated data store + */ +function configureEntries(huron, config) { + const entry = config.entry[huron.entry]; + const newConfig = config; + + newConfig.entry = {}; + if (!_parseArgs2.default.production) { + newConfig.entry[huron.entry] = [`webpack-dev-server/client?http://localhost:${huron.port}`, 'webpack/hot/dev-server', _path2.default.join(cwd, huron.root, 'huron-assets/index')].concat(entry); + } else { + newConfig.entry[huron.entry] = [_path2.default.join(cwd, huron.root, 'huron-assets/index')].concat(entry); + } + + return newConfig; +} + +/** + * Configure and manage webpack plugins + * + * @param {object} huron - huron configuration object + * @param {object} config - webpack configuration object + * @return {object} newConfig - updated data store + */ +function configurePlugins(huron, config) { + const newConfig = config; + + newConfig.plugins = config.plugins || []; + + if (!_parseArgs2.default.production) { + if (newConfig.plugins && newConfig.plugins.length) { + newConfig.plugins = newConfig.plugins.filter(plugin => 'HotModuleReplacementPlugin' !== plugin.constructor.name && 'NamedModulesPlugin' !== plugin.constructor.name); + } + newConfig.plugins = newConfig.plugins.concat([new _webpack2.default.HotModuleReplacementPlugin(), new _webpack2.default.NamedModulesPlugin()]); + } + + return newConfig; +} + +/** + * Configure and manage webpack loaders + * + * @param {object} huron - huron configuration object + * @param {object} config - webpack configuration object + * @return {object} newConfig - updated data store + */ +function configureLoaders(huron, config) { + // Manage loaders + const templatesLoader = huron.templates.rule || {}; + const newConfig = config; + + // Make sure we're only using templates loader for files in huron root + templatesLoader.include = [_path2.default.join(cwd, huron.root, huron.output)]; + + // Normalize module and module.rules + newConfig.module = newConfig.module || {}; + newConfig.module.rules = newConfig.module.rules || newConfig.module.loaders || []; + + // Add default loaders + newConfig.module.rules = defaultConfig.module.rules.concat(newConfig.module.rules, templatesLoader); + + return newConfig; +} + +/** + * Create an HTML webpack plugin for each configured prototype + * + * @param {object} huron - huron configuration object + * @param {object} config - webpack configuration object + * @return {object} newConfig - updated data store + */ +function configurePrototypes(huron, config) { + const wrapperTemplate = _fsExtra2.default.readFileSync(_path2.default.join(__dirname, '../../templates/prototypeTemplate.hbs'), 'utf8'); + + const defaultHTMLPluginOptions = { + title: 'Huron', + window: huron.window, + js: [], + css: [], + filename: 'index.html', + template: _path2.default.join(cwd, huron.root, 'huron-assets/prototypeTemplate.hbs'), + inject: false, + chunks: [huron.entry] + }; + const newConfig = config; + + // Write prototype template file for HTML webpack plugin + _fsExtra2.default.outputFileSync(_path2.default.join(cwd, huron.root, 'huron-assets/prototypeTemplate.hbs'), wrapperTemplate); + + huron.prototypes.forEach(prototype => { + const newPrototype = prototype; + let opts = {}; + + // Merge configured settings with default settings + if ('string' === typeof prototype) { + opts = Object.assign({}, defaultHTMLPluginOptions, { + title: prototype, + filename: `${prototype}.html` + }); + } else if ('object' === typeof prototype && {}.hasOwnProperty.call(prototype, 'title')) { + // Create filename based on configured title if not provided + if (!prototype.filename) { + newPrototype.filename = `${prototype.title}.html`; + } + + // Move css assets for this prototype, + // reset css option with new file paths + if (prototype.css) { + newPrototype.css = moveAdditionalAssets(prototype.css, 'css', huron); + } + + // Move js assets for this prototype, + // reset js option with new file paths + if (prototype.js) { + newPrototype.js = moveAdditionalAssets(prototype.js, 'js', huron); + } + + opts = Object.assign({}, defaultHTMLPluginOptions, newPrototype); + } + + // Move global css assets, + // reset css option with new file paths + if (huron.css.length) { + opts.css = opts.css.concat(moveAdditionalAssets(huron.css, 'css', huron)); + } + + // Move global js assets, + // reset js option with new file paths + if (huron.js.length) { + opts.js = opts.js.concat(moveAdditionalAssets(huron.js, 'js', huron)); + } + + // Push a new plugin for each configured prototype + if (Object.keys(opts).length) { + newConfig.plugins.push(new _htmlWebpackPlugin2.default(opts)); + } + }); + + return newConfig; +} + +/** + * Move relative (and local) js and css assets provided in huron options + * + * @param {array|string} assets - array of assets or single asset + * @param {string} subdir - subdirectory in huron root from which to load additional asset + * @param {object} huron - huron configuration object + * @return {array} assetResults - paths to js and css assets + */ +function moveAdditionalAssets(assets, subdir = '', huron) { + const currentAssets = [].concat(assets); + const assetResults = []; + + currentAssets.forEach(asset => { + const assetInfo = _path2.default.parse(asset); + const assetURL = _url2.default.parse(asset); + const sourcePath = _path2.default.join(cwd, asset); + const outputPath = _path2.default.resolve(cwd, huron.root, subdir, assetInfo.base); + const loadPath = _parseArgs2.default.production ? _path2.default.join(subdir, assetInfo.base) : _path2.default.join('/', subdir, assetInfo.base); // Use absolute path in development + let contents = false; + + if (!_path2.default.isAbsolute(asset) && !assetURL.protocol) { + try { + contents = _fsExtra2.default.readFileSync(sourcePath); + } catch (e) { + console.warn(`could not read ${sourcePath}`); + } + + if (contents) { + _fsExtra2.default.outputFileSync(outputPath, contents); + assetResults.push(loadPath); + } + } else { + assetResults.push(asset); + } + }); + + return assetResults; +} /***/ }), /* 14 */ -/* no static exports found */ -/* all exports used */ -/*!*******************************!*\ - !*** ./src/cli/handleHTML.js ***! - \*******************************/ /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.updateHTML = updateHTML;\nexports.deleteHTML = deleteHTML;\nexports.updatePrototype = updatePrototype;\nexports.deletePrototype = deletePrototype;\n\nvar _path = __webpack_require__(/*! path */ 0);\n\nvar _path2 = _interopRequireDefault(_path);\n\nvar _fsExtra = __webpack_require__(/*! fs-extra */ 3);\n\nvar _fsExtra2 = _interopRequireDefault(_fsExtra);\n\nvar _utils = __webpack_require__(/*! ./utils */ 1);\n\nvar utils = _interopRequireWildcard(_utils);\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Handle update of an HMTL template\n *\n * @function updateHTML\n * @param {string} filepath - filepath of changed file (comes from gaze)\n * @param {object} section - contains KSS section data\n * @param {object} store - memory store\n * @return {object} updated data store\n */\nfunction updateHTML(filepath, section, store) {\n const file = _path2.default.parse(filepath);\n const content = _fsExtra2.default.readFileSync(filepath, 'utf8');\n const newSection = section;\n\n if (content) {\n newSection.templatePath = utils.writeFile(section.referenceURI, 'template', filepath, content, store);\n newSection.templateContent = content;\n\n // Rewrite section data with template content\n newSection.sectionPath = utils.writeSectionData(store, newSection);\n\n return store.setIn(['sections', 'sectionsByPath', section.kssPath], newSection).setIn(['sections', 'sectionsByURI', section.referenceURI], newSection);\n }\n\n console.log(`File ${file.base} could not be read`);\n return store;\n}\n\n/**\n * Handle removal of an HMTL template\n *\n * @function deleteHTML\n * @param {string} filepath - filepath of changed file (comes from gaze)\n * @param {object} section - contains KSS section data\n * @param {object} store - memory store\n * @return {object} updated data store\n */\n/** @module cli/html-handler */\nfunction deleteHTML(filepath, section, store) {\n const newSection = section;\n\n utils.removeFile(newSection.referenceURI, 'template', filepath, store);\n\n delete newSection.templatePath;\n\n return store.setIn(['sections', 'sectionsByPath', section.kssPath], newSection).setIn(['sections', 'sectionsByURI', section.referenceURI], newSection);\n}\n\n/**\n * Handle update for a prototype file\n *\n * @function updatePrototype\n * @param {string} filepath - filepath of changed file (comes from gaze)\n * @param {object} store - memory store\n * @return {object} updated data store\n */\nfunction updatePrototype(filepath, store) {\n const file = _path2.default.parse(filepath);\n const content = _fsExtra2.default.readFileSync(filepath, 'utf8');\n\n if (content) {\n const requirePath = utils.writeFile(file.name, 'prototype', filepath, content, store);\n\n return store.setIn(['prototypes', file.name], requirePath);\n }\n\n console.log(`File ${file.base} could not be read`);\n return store;\n}\n\n/**\n * Handle removal of a prototype file\n *\n * @function deletePrototype\n * @param {string} filepath - filepath of changed file (comes from gaze)\n * @param {object} store - memory store\n * @return {object} updated data store\n */\nfunction deletePrototype(filepath, store) {\n const file = _path2.default.parse(filepath);\n const requirePath = utils.removeFile(file.name, 'prototype', filepath, store);\n\n return store.setIn(['prototypes', file.name], requirePath);\n}//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTQuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vc3JjL2NsaS9oYW5kbGVIVE1MLmpzP2VhMjIiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBtb2R1bGUgY2xpL2h0bWwtaGFuZGxlciAqL1xuaW1wb3J0IHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgZnMgZnJvbSAnZnMtZXh0cmEnO1xuXG5pbXBvcnQgKiBhcyB1dGlscyBmcm9tICcuL3V0aWxzJztcblxuLyoqXG4gKiBIYW5kbGUgdXBkYXRlIG9mIGFuIEhNVEwgdGVtcGxhdGVcbiAqXG4gKiBAZnVuY3Rpb24gdXBkYXRlSFRNTFxuICogQHBhcmFtIHtzdHJpbmd9IGZpbGVwYXRoIC0gZmlsZXBhdGggb2YgY2hhbmdlZCBmaWxlIChjb21lcyBmcm9tIGdhemUpXG4gKiBAcGFyYW0ge29iamVjdH0gc2VjdGlvbiAtIGNvbnRhaW5zIEtTUyBzZWN0aW9uIGRhdGFcbiAqIEBwYXJhbSB7b2JqZWN0fSBzdG9yZSAtIG1lbW9yeSBzdG9yZVxuICogQHJldHVybiB7b2JqZWN0fSB1cGRhdGVkIGRhdGEgc3RvcmVcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVwZGF0ZUhUTUwoZmlsZXBhdGgsIHNlY3Rpb24sIHN0b3JlKSB7XG4gIGNvbnN0IGZpbGUgPSBwYXRoLnBhcnNlKGZpbGVwYXRoKTtcbiAgY29uc3QgY29udGVudCA9IGZzLnJlYWRGaWxlU3luYyhmaWxlcGF0aCwgJ3V0ZjgnKTtcbiAgY29uc3QgbmV3U2VjdGlvbiA9IHNlY3Rpb247XG5cbiAgaWYgKGNvbnRlbnQpIHtcbiAgICBuZXdTZWN0aW9uLnRlbXBsYXRlUGF0aCA9IHV0aWxzLndyaXRlRmlsZShcbiAgICAgIHNlY3Rpb24ucmVmZXJlbmNlVVJJLFxuICAgICAgJ3RlbXBsYXRlJyxcbiAgICAgIGZpbGVwYXRoLFxuICAgICAgY29udGVudCxcbiAgICAgIHN0b3JlXG4gICAgKTtcbiAgICBuZXdTZWN0aW9uLnRlbXBsYXRlQ29udGVudCA9IGNvbnRlbnQ7XG5cbiAgICAvLyBSZXdyaXRlIHNlY3Rpb24gZGF0YSB3aXRoIHRlbXBsYXRlIGNvbnRlbnRcbiAgICBuZXdTZWN0aW9uLnNlY3Rpb25QYXRoID0gdXRpbHMud3JpdGVTZWN0aW9uRGF0YShzdG9yZSwgbmV3U2VjdGlvbik7XG5cbiAgICByZXR1cm4gc3RvcmVcbiAgICAgIC5zZXRJbihcbiAgICAgICAgWydzZWN0aW9ucycsICdzZWN0aW9uc0J5UGF0aCcsIHNlY3Rpb24ua3NzUGF0aF0sXG4gICAgICAgIG5ld1NlY3Rpb25cbiAgICAgIClcbiAgICAgIC5zZXRJbihcbiAgICAgICAgWydzZWN0aW9ucycsICdzZWN0aW9uc0J5VVJJJywgc2VjdGlvbi5yZWZlcmVuY2VVUkldLFxuICAgICAgICBuZXdTZWN0aW9uXG4gICAgICApO1xuICB9XG5cbiAgY29uc29sZS5sb2coYEZpbGUgJHtmaWxlLmJhc2V9IGNvdWxkIG5vdCBiZSByZWFkYCk7XG4gIHJldHVybiBzdG9yZTtcbn1cblxuLyoqXG4gKiBIYW5kbGUgcmVtb3ZhbCBvZiBhbiBITVRMIHRlbXBsYXRlXG4gKlxuICogQGZ1bmN0aW9uIGRlbGV0ZUhUTUxcbiAqIEBwYXJhbSB7c3RyaW5nfSBmaWxlcGF0aCAtIGZpbGVwYXRoIG9mIGNoYW5nZWQgZmlsZSAoY29tZXMgZnJvbSBnYXplKVxuICogQHBhcmFtIHtvYmplY3R9IHNlY3Rpb24gLSBjb250YWlucyBLU1Mgc2VjdGlvbiBkYXRhXG4gKiBAcGFyYW0ge29iamVjdH0gc3RvcmUgLSBtZW1vcnkgc3RvcmVcbiAqIEByZXR1cm4ge29iamVjdH0gdXBkYXRlZCBkYXRhIHN0b3JlXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBkZWxldGVIVE1MKGZpbGVwYXRoLCBzZWN0aW9uLCBzdG9yZSkge1xuICBjb25zdCBuZXdTZWN0aW9uID0gc2VjdGlvbjtcblxuICB1dGlscy5yZW1vdmVGaWxlKFxuICAgIG5ld1NlY3Rpb24ucmVmZXJlbmNlVVJJLFxuICAgICd0ZW1wbGF0ZScsXG4gICAgZmlsZXBhdGgsXG4gICAgc3RvcmVcbiAgKTtcblxuICBkZWxldGUgbmV3U2VjdGlvbi50ZW1wbGF0ZVBhdGg7XG5cbiAgcmV0dXJuIHN0b3JlXG4gICAgLnNldEluKFxuICAgICAgWydzZWN0aW9ucycsICdzZWN0aW9uc0J5UGF0aCcsIHNlY3Rpb24ua3NzUGF0aF0sXG4gICAgICBuZXdTZWN0aW9uXG4gICAgKVxuICAgIC5zZXRJbihcbiAgICAgIFsnc2VjdGlvbnMnLCAnc2VjdGlvbnNCeVVSSScsIHNlY3Rpb24ucmVmZXJlbmNlVVJJXSxcbiAgICAgIG5ld1NlY3Rpb25cbiAgICApO1xufVxuXG4vKipcbiAqIEhhbmRsZSB1cGRhdGUgZm9yIGEgcHJvdG90eXBlIGZpbGVcbiAqXG4gKiBAZnVuY3Rpb24gdXBkYXRlUHJvdG90eXBlXG4gKiBAcGFyYW0ge3N0cmluZ30gZmlsZXBhdGggLSBmaWxlcGF0aCBvZiBjaGFuZ2VkIGZpbGUgKGNvbWVzIGZyb20gZ2F6ZSlcbiAqIEBwYXJhbSB7b2JqZWN0fSBzdG9yZSAtIG1lbW9yeSBzdG9yZVxuICogQHJldHVybiB7b2JqZWN0fSB1cGRhdGVkIGRhdGEgc3RvcmVcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVwZGF0ZVByb3RvdHlwZShmaWxlcGF0aCwgc3RvcmUpIHtcbiAgY29uc3QgZmlsZSA9IHBhdGgucGFyc2UoZmlsZXBhdGgpO1xuICBjb25zdCBjb250ZW50ID0gZnMucmVhZEZpbGVTeW5jKGZpbGVwYXRoLCAndXRmOCcpO1xuXG4gIGlmIChjb250ZW50KSB7XG4gICAgY29uc3QgcmVxdWlyZVBhdGggPSB1dGlscy53cml0ZUZpbGUoXG4gICAgICBmaWxlLm5hbWUsXG4gICAgICAncHJvdG90eXBlJyxcbiAgICAgIGZpbGVwYXRoLFxuICAgICAgY29udGVudCxcbiAgICAgIHN0b3JlXG4gICAgKTtcblxuICAgIHJldHVybiBzdG9yZS5zZXRJbihcbiAgICAgICAgWydwcm90b3R5cGVzJywgZmlsZS5uYW1lXSxcbiAgICAgICAgcmVxdWlyZVBhdGhcbiAgICAgICk7XG4gIH1cblxuICBjb25zb2xlLmxvZyhgRmlsZSAke2ZpbGUuYmFzZX0gY291bGQgbm90IGJlIHJlYWRgKTtcbiAgcmV0dXJuIHN0b3JlO1xufVxuXG4vKipcbiAqIEhhbmRsZSByZW1vdmFsIG9mIGEgcHJvdG90eXBlIGZpbGVcbiAqXG4gKiBAZnVuY3Rpb24gZGVsZXRlUHJvdG90eXBlXG4gKiBAcGFyYW0ge3N0cmluZ30gZmlsZXBhdGggLSBmaWxlcGF0aCBvZiBjaGFuZ2VkIGZpbGUgKGNvbWVzIGZyb20gZ2F6ZSlcbiAqIEBwYXJhbSB7b2JqZWN0fSBzdG9yZSAtIG1lbW9yeSBzdG9yZVxuICogQHJldHVybiB7b2JqZWN0fSB1cGRhdGVkIGRhdGEgc3RvcmVcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGRlbGV0ZVByb3RvdHlwZShmaWxlcGF0aCwgc3RvcmUpIHtcbiAgY29uc3QgZmlsZSA9IHBhdGgucGFyc2UoZmlsZXBhdGgpO1xuICBjb25zdCByZXF1aXJlUGF0aCA9IHV0aWxzLnJlbW92ZUZpbGUoXG4gICAgZmlsZS5uYW1lLFxuICAgICdwcm90b3R5cGUnLFxuICAgIGZpbGVwYXRoLFxuICAgIHN0b3JlXG4gICk7XG5cbiAgcmV0dXJuIHN0b3JlLnNldEluKFxuICAgICAgWydwcm90b3R5cGVzJywgZmlsZS5uYW1lXSxcbiAgICAgIHJlcXVpcmVQYXRoXG4gICAgKTtcbn1cblxuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyBzcmMvY2xpL2hhbmRsZUhUTUwuanMiXSwibWFwcGluZ3MiOiI7Ozs7O0FBZUE7QUEwQ0E7QUErQkE7QUErQkE7QUFDQTtBQXZIQTtBQUNBOzs7QUFBQTtBQUNBOzs7QUFDQTtBQUNBO0FBREE7QUFDQTs7Ozs7QUFDQTs7Ozs7Ozs7O0FBU0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFPQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFTQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7Ozs7O0FBaERBO0FBeURBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFNQTtBQUNBO0FBQ0E7QUFTQTtBQUNBO0FBQ0E7Ozs7Ozs7O0FBUUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFPQTtBQUlBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7OztBQVFBO0FBQ0E7QUFDQTtBQUNBO0FBTUE7QUFJQSIsInNvdXJjZVJvb3QiOiIifQ=="); + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.updateHTML = updateHTML; +exports.deleteHTML = deleteHTML; +exports.updatePrototype = updatePrototype; +exports.deletePrototype = deletePrototype; + +var _path = __webpack_require__(0); + +var _path2 = _interopRequireDefault(_path); + +var _fsExtra = __webpack_require__(3); + +var _fsExtra2 = _interopRequireDefault(_fsExtra); + +var _utils = __webpack_require__(1); + +var utils = _interopRequireWildcard(_utils); + +function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Handle update of an HMTL template + * + * @function updateHTML + * @param {string} filepath - filepath of changed file (comes from gaze) + * @param {object} section - contains KSS section data + * @param {object} store - memory store + * @return {object} updated data store + */ +function updateHTML(filepath, section, store) { + const file = _path2.default.parse(filepath); + const content = _fsExtra2.default.readFileSync(filepath, 'utf8'); + const newSection = section; + + if (content) { + newSection.templatePath = utils.writeFile(section.referenceURI, 'template', filepath, content, store); + newSection.templateContent = content; + + // Rewrite section data with template content + newSection.sectionPath = utils.writeSectionData(store, newSection); + + return store.setIn(['sections', 'sectionsByPath', section.kssPath], newSection).setIn(['sections', 'sectionsByURI', section.referenceURI], newSection); + } + + console.log(`File ${file.base} could not be read`); + return store; +} + +/** + * Handle removal of an HMTL template + * + * @function deleteHTML + * @param {string} filepath - filepath of changed file (comes from gaze) + * @param {object} section - contains KSS section data + * @param {object} store - memory store + * @return {object} updated data store + */ +/** @module cli/html-handler */ +function deleteHTML(filepath, section, store) { + const newSection = section; + + utils.removeFile(newSection.referenceURI, 'template', filepath, store); + + delete newSection.templatePath; + + return store.setIn(['sections', 'sectionsByPath', section.kssPath], newSection).setIn(['sections', 'sectionsByURI', section.referenceURI], newSection); +} + +/** + * Handle update for a prototype file + * + * @function updatePrototype + * @param {string} filepath - filepath of changed file (comes from gaze) + * @param {object} store - memory store + * @return {object} updated data store + */ +function updatePrototype(filepath, store) { + const file = _path2.default.parse(filepath); + const content = _fsExtra2.default.readFileSync(filepath, 'utf8'); + + if (content) { + const requirePath = utils.writeFile(file.name, 'prototype', filepath, content, store); + + return store.setIn(['prototypes', file.name], requirePath); + } + + console.log(`File ${file.base} could not be read`); + return store; +} + +/** + * Handle removal of a prototype file + * + * @function deletePrototype + * @param {string} filepath - filepath of changed file (comes from gaze) + * @param {object} store - memory store + * @return {object} updated data store + */ +function deletePrototype(filepath, store) { + const file = _path2.default.parse(filepath); + const requirePath = utils.removeFile(file.name, 'prototype', filepath, store); + + return store.setIn(['prototypes', file.name], requirePath); +} /***/ }), /* 15 */ -/* no static exports found */ -/* all exports used */ -/*!******************************!*\ - !*** ./src/cli/handleKSS.js ***! - \******************************/ /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.updateKSS = updateKSS;\nexports.deleteKSS = deleteKSS;\n\nvar _path = __webpack_require__(/*! path */ 0);\n\nvar _path2 = _interopRequireDefault(_path);\n\nvar _fsExtra = __webpack_require__(/*! fs-extra */ 3);\n\nvar _fsExtra2 = _interopRequireDefault(_fsExtra);\n\nvar _kss = __webpack_require__(/*! kss */ 25);\n\nvar _chalk = __webpack_require__(/*! chalk */ 2);\n\nvar _chalk2 = _interopRequireDefault(_chalk);\n\nvar _utils = __webpack_require__(/*! ./utils */ 1);\n\nvar utils = _interopRequireWildcard(_utils);\n\nvar _handleTemplates = __webpack_require__(/*! ./handleTemplates */ 7);\n\nvar _requireTemplates = __webpack_require__(/*! ./requireTemplates */ 8);\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Handle update of a KSS section\n *\n * @function updateKSS\n * @param {string} filepath - filepath of changed file (comes from gaze)\n * @param {object} store - memory store\n * @return {object} updated data store\n */\nfunction updateKSS(filepath, store) {\n const kssSource = _fsExtra2.default.readFileSync(filepath, 'utf8');\n const huron = store.get('config');\n const oldSection = utils.getSection(filepath, false, store) || {};\n const file = _path2.default.parse(filepath);\n let newStore = store;\n\n if (kssSource) {\n const styleguide = (0, _kss.parse)(kssSource, huron.get('kssOptions'));\n\n if (styleguide.data.sections.length) {\n const section = utils.normalizeSectionData(styleguide.data.sections[0]);\n\n if (section.reference && section.referenceURI) {\n // Update or add section data\n newStore = updateSectionData(filepath, section, oldSection, newStore);\n\n // Remove old section data if reference URI has changed\n if (oldSection && oldSection.referenceURI && oldSection.referenceURI !== section.referenceURI) {\n newStore = unsetSection(oldSection, file, newStore, false);\n }\n\n (0, _requireTemplates.writeStore)(newStore);\n console.log(_chalk2.default.green(`KSS source in ${filepath} changed or added`));\n return newStore;\n }\n\n console.log(_chalk2.default.magenta(`KSS section in ${filepath} is missing a section reference`));\n return newStore;\n }\n\n console.log(_chalk2.default.magenta(`No KSS found in ${filepath}`));\n return newStore;\n }\n\n if (oldSection) {\n newStore = deleteKSS(filepath, oldSection, newStore);\n }\n\n console.log(_chalk2.default.red(`${filepath} not found or empty`)); // eslint-disable-line no-console\n return newStore;\n}\n\n/**\n * Handle removal of a KSS section\n *\n * @function deleteKSS\n * @param {string} filepath - filepath of changed file (comes from gaze)\n * @param {object} section - KSS section data\n * @param {object} store - memory store\n * @return {object} updated data store\n */\n/** @module cli/kss-handler */\n\nfunction deleteKSS(filepath, section, store) {\n const file = _path2.default.parse(filepath);\n\n if (section.reference && section.referenceURI) {\n // Remove section data from memory store\n return unsetSection(section, file, store, true);\n }\n\n return store;\n}\n\n/**\n * Update the sections store with new data for a specific section\n *\n * @function updateSectionData\n * @param {object} section - contains updated section data\n * @param {string} kssPath - path to KSS section\n * @param {object} store - memory store\n * @return {object} updated data store\n */\nfunction updateSectionData(kssPath, section, oldSection, store) {\n const sectionFileInfo = _path2.default.parse(kssPath);\n const dataFilepath = _path2.default.join(sectionFileInfo.dir, `${sectionFileInfo.name}.json`);\n const isInline = null !== section.markup.match(/<\\/[^>]*>/);\n const newSort = sortSection(store.getIn(['sections', 'sorted']), section.reference, store.get('referenceDelimiter'));\n const newSection = Object.assign({}, oldSection, section);\n let newStore = store;\n\n // Required for reference from templates and data\n newSection.kssPath = kssPath;\n\n if (isInline) {\n // Set section value if inlineTempalte() returned a path\n newStore = updateInlineTemplate(kssPath, oldSection, newSection, newStore);\n } else {\n // Remove inline template, if it exists\n utils.removeFile(newSection.referenceURI, 'template', kssPath, store);\n // Update markup and data fields\n newStore = updateTemplateFields(sectionFileInfo, oldSection, newSection, newStore);\n }\n\n // Output section description\n newStore = updateDescription(kssPath, oldSection, newSection, newStore);\n\n // Output section data to a JSON file\n newSection.sectionPath = utils.writeSectionData(newStore, newSection, dataFilepath);\n\n // Update section sorting\n return newStore.setIn(['sections', 'sorted'], newSort).setIn(['sections', 'sectionsByPath', kssPath], newSection).setIn(['sections', 'sectionsByURI', section.referenceURI], newSection);\n}\n\n/**\n * Handle detection and output of inline templates, which is markup written\n * in the KSS documentation itself as opposed to an external file\n *\n * @function updateInlineTemplate\n * @param {string} oldSection - previous iteration of KSS data, if updated\n * @param {object} section - KSS section data\n * @return {object} updated data store with new template path info\n */\nfunction updateInlineTemplate(filepath, oldSection, section, store) {\n const newSection = section;\n const newStore = store;\n\n // If we have inline markup\n if (fieldShouldOutput(oldSection, section, 'markup')) {\n newSection.templatePath = utils.writeFile(section.referenceURI, 'template', filepath, section.markup, store);\n newSection.templateContent = section.markup;\n\n return newStore.setIn(['sections', 'sectionsByPath', filepath], newSection).setIn(['sections', 'sectionsByURI', section.referenceURI], newSection);\n }\n\n return newStore;\n}\n\n/**\n * Handle output of section description\n *\n * @function updateDescription\n * @param {string} oldSection - previous iteration of KSS data, if updated\n * @param {object} section - KSS section data\n * @return {object} updated data store with new descripton path info\n */\nfunction updateDescription(filepath, oldSection, section, store) {\n const newSection = section;\n const newStore = store;\n\n // If we don't have previous KSS or the KSS has been updated\n if (fieldShouldOutput(oldSection, section, 'description')) {\n // Write new description\n newSection.descriptionPath = utils.writeFile(section.referenceURI, 'description', filepath, section.description, store);\n\n return newStore.setIn(['sections', 'sectionsByPath', filepath], newSection).setIn(['sections', 'sectionsByURI', section.referenceURI], newSection);\n }\n\n return newStore;\n}\n\n/**\n * Handle Data and Markup fields\n *\n * @function updateTemplateFields\n * @param {string} file - File data for KSS file from path.parse()\n * @param {object} oldSection - outdated KSS data\n * @param {object} section - KSS section data\n * @param {object} store - memory store\n * @return {object} KSS section data with updated asset paths\n */\nfunction updateTemplateFields(file, oldSection, section, store) {\n const kssPath = _path2.default.format(file);\n const newSection = section;\n let filepath = '';\n let oldFilepath = '';\n let newStore = store;\n\n ['data', 'markup'].forEach(field => {\n if (newSection[field]) {\n if (oldSection[field]) {\n oldFilepath = _path2.default.join(file.dir, oldSection[field]);\n newStore = (0, _handleTemplates.deleteTemplate)(oldFilepath, oldSection, newStore);\n }\n\n filepath = _path2.default.join(file.dir, newSection[field]);\n newStore = (0, _handleTemplates.updateTemplate)(filepath, newSection, newStore);\n } else {\n delete newSection[field];\n newStore = newStore.setIn(['sections', 'sectionsByPath', kssPath], newSection).setIn(['sections', 'sectionsByURI', newSection.referenceURI], newSection);\n }\n });\n\n return newStore;\n}\n\n/**\n * Remove a section from the memory store\n *\n * @function unsetSection\n * @param {object} section - contains updated section data\n * @param {string} file - file object from path.parse()\n * @param {object} store - memory store\n * @param {bool} removed - has the file been removed or just the section information changed?\n * @return {object} updated data store with new descripton path info\n */\nfunction unsetSection(section, file, store, removed) {\n const sorted = store.getIn(['sections', 'sorted']);\n const kssPath = _path2.default.format(file);\n const dataFilepath = _path2.default.join(file.dir, `${file.name}.json`);\n const isInline = section.markup && null !== section.markup.match(/<\\/[^>]*>/);\n const newSort = unsortSection(sorted, section.reference, store.get('referenceDelimiter'));\n let newStore = store;\n\n // Remove old section data\n utils.removeFile(section.referenceURI, 'section', dataFilepath, newStore);\n\n // Remove associated inline template\n if (isInline) {\n utils.removeFile(section.referenceURI, 'template', kssPath, newStore);\n }\n\n // Remove description template\n utils.removeFile(section.referenceURI, 'description', kssPath, newStore);\n\n // Remove data from sectionsByPath if file has been removed\n if (removed) {\n newStore = newStore.deleteIn(['sections', 'sectionsByPath', kssPath]);\n }\n\n return newStore.deleteIn(['sections', 'sectionsByURI', section.referenceURI]).setIn(['sections', 'sorted'], newSort);\n}\n\n/**\n * Sort sections and subsections\n *\n * @function sortSection\n * @param {object} sorted - currently sorted sections\n * @param {string} reference - reference URI of section to sort\n * @return {object} updated data store with new descripton path info\n */\nfunction sortSection(sorted, reference, delimiter) {\n const parts = reference.split(delimiter);\n const newSort = sorted[parts[0]] || {};\n const newSorted = sorted;\n\n if (1 < parts.length) {\n const newParts = parts.filter((part, idx) => 0 !== idx);\n newSorted[parts[0]] = sortSection(newSort, newParts.join(delimiter), delimiter);\n } else {\n newSorted[parts[0]] = newSort;\n }\n\n return newSorted;\n}\n\n/**\n * Remove a section from the sorted sections\n *\n * @function unsortSection\n * @param {object} sorted - currently sorted sections\n * @param {string} reference - reference URI of section to sort\n * @return {object} updated data store with new descripton path info\n */\nfunction unsortSection(sorted, reference, delimiter) {\n const parts = reference.split(delimiter);\n const subsections = Object.keys(sorted[parts[0]]);\n const newSorted = sorted;\n\n if (subsections.length) {\n if (1 < parts.length) {\n const newParts = parts.filter((part, idx) => 0 !== idx);\n newSorted[parts[0]] = unsortSection(newSorted[parts[0]], newParts.join(delimiter), delimiter);\n }\n } else {\n delete newSorted[parts[0]];\n }\n\n return newSorted;\n}\n\n/**\n * Compare a KSS field between old and new KSS data to see if we need to output\n * a new module for that field\n *\n * @function fieldShouldOutput\n * @param {object} oldSection - currently sorted sections\n * @param {object} newSection - reference URI of section to sort\n * @param {string} field - KSS field to check\n * @return {bool} output a new module for the KSS field\n */\nfunction fieldShouldOutput(oldSection, newSection, field) {\n return oldSection && (oldSection[field] !== newSection[field] || oldSection.referenceURI !== newSection.referenceURI) || !oldSection;\n}//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTUuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vc3JjL2NsaS9oYW5kbGVLU1MuanM/MzJmZCJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQG1vZHVsZSBjbGkva3NzLWhhbmRsZXIgKi9cblxuaW1wb3J0IHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgZnMgZnJvbSAnZnMtZXh0cmEnO1xuaW1wb3J0IHsgcGFyc2UgfSBmcm9tICdrc3MnO1xuaW1wb3J0IGNoYWxrIGZyb20gJ2NoYWxrJztcblxuaW1wb3J0ICogYXMgdXRpbHMgZnJvbSAnLi91dGlscyc7XG5pbXBvcnQgeyB1cGRhdGVUZW1wbGF0ZSwgZGVsZXRlVGVtcGxhdGUgfSBmcm9tICcuL2hhbmRsZVRlbXBsYXRlcyc7XG5pbXBvcnQgeyB3cml0ZVN0b3JlIH0gZnJvbSAnLi9yZXF1aXJlVGVtcGxhdGVzJztcblxuLyoqXG4gKiBIYW5kbGUgdXBkYXRlIG9mIGEgS1NTIHNlY3Rpb25cbiAqXG4gKiBAZnVuY3Rpb24gdXBkYXRlS1NTXG4gKiBAcGFyYW0ge3N0cmluZ30gZmlsZXBhdGggLSBmaWxlcGF0aCBvZiBjaGFuZ2VkIGZpbGUgKGNvbWVzIGZyb20gZ2F6ZSlcbiAqIEBwYXJhbSB7b2JqZWN0fSBzdG9yZSAtIG1lbW9yeSBzdG9yZVxuICogQHJldHVybiB7b2JqZWN0fSB1cGRhdGVkIGRhdGEgc3RvcmVcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVwZGF0ZUtTUyhmaWxlcGF0aCwgc3RvcmUpIHtcbiAgY29uc3Qga3NzU291cmNlID0gZnMucmVhZEZpbGVTeW5jKGZpbGVwYXRoLCAndXRmOCcpO1xuICBjb25zdCBodXJvbiA9IHN0b3JlLmdldCgnY29uZmlnJyk7XG4gIGNvbnN0IG9sZFNlY3Rpb24gPSB1dGlscy5nZXRTZWN0aW9uKGZpbGVwYXRoLCBmYWxzZSwgc3RvcmUpIHx8IHt9O1xuICBjb25zdCBmaWxlID0gcGF0aC5wYXJzZShmaWxlcGF0aCk7XG4gIGxldCBuZXdTdG9yZSA9IHN0b3JlO1xuXG4gIGlmIChrc3NTb3VyY2UpIHtcbiAgICBjb25zdCBzdHlsZWd1aWRlID0gcGFyc2Uoa3NzU291cmNlLCBodXJvbi5nZXQoJ2tzc09wdGlvbnMnKSk7XG5cbiAgICBpZiAoc3R5bGVndWlkZS5kYXRhLnNlY3Rpb25zLmxlbmd0aCkge1xuICAgICAgY29uc3Qgc2VjdGlvbiA9IHV0aWxzLm5vcm1hbGl6ZVNlY3Rpb25EYXRhKFxuICAgICAgICBzdHlsZWd1aWRlLmRhdGEuc2VjdGlvbnNbMF1cbiAgICAgICk7XG5cbiAgICAgIGlmIChzZWN0aW9uLnJlZmVyZW5jZSAmJiBzZWN0aW9uLnJlZmVyZW5jZVVSSSkge1xuICAgICAgICAvLyBVcGRhdGUgb3IgYWRkIHNlY3Rpb24gZGF0YVxuICAgICAgICBuZXdTdG9yZSA9IHVwZGF0ZVNlY3Rpb25EYXRhKFxuICAgICAgICAgIGZpbGVwYXRoLFxuICAgICAgICAgIHNlY3Rpb24sXG4gICAgICAgICAgb2xkU2VjdGlvbixcbiAgICAgICAgICBuZXdTdG9yZVxuICAgICAgICApO1xuXG4gICAgICAgIC8vIFJlbW92ZSBvbGQgc2VjdGlvbiBkYXRhIGlmIHJlZmVyZW5jZSBVUkkgaGFzIGNoYW5nZWRcbiAgICAgICAgaWYgKG9sZFNlY3Rpb24gJiZcbiAgICAgICAgICBvbGRTZWN0aW9uLnJlZmVyZW5jZVVSSSAmJlxuICAgICAgICAgIG9sZFNlY3Rpb24ucmVmZXJlbmNlVVJJICE9PSBzZWN0aW9uLnJlZmVyZW5jZVVSSVxuICAgICAgICApIHtcbiAgICAgICAgICBuZXdTdG9yZSA9IHVuc2V0U2VjdGlvbihvbGRTZWN0aW9uLCBmaWxlLCBuZXdTdG9yZSwgZmFsc2UpO1xuICAgICAgICB9XG5cbiAgICAgICAgd3JpdGVTdG9yZShuZXdTdG9yZSk7XG4gICAgICAgIGNvbnNvbGUubG9nKFxuICAgICAgICAgIGNoYWxrLmdyZWVuKFxuICAgICAgICAgICAgYEtTUyBzb3VyY2UgaW4gJHtmaWxlcGF0aH0gY2hhbmdlZCBvciBhZGRlZGBcbiAgICAgICAgICApXG4gICAgICAgICk7XG4gICAgICAgIHJldHVybiBuZXdTdG9yZTtcbiAgICAgIH1cblxuICAgICAgY29uc29sZS5sb2coXG4gICAgICAgIGNoYWxrLm1hZ2VudGEoXG4gICAgICAgICAgYEtTUyBzZWN0aW9uIGluICR7ZmlsZXBhdGh9IGlzIG1pc3NpbmcgYSBzZWN0aW9uIHJlZmVyZW5jZWBcbiAgICAgICAgKVxuICAgICAgKTtcbiAgICAgIHJldHVybiBuZXdTdG9yZTtcbiAgICB9XG5cbiAgICBjb25zb2xlLmxvZyhjaGFsay5tYWdlbnRhKGBObyBLU1MgZm91bmQgaW4gJHtmaWxlcGF0aH1gKSk7XG4gICAgcmV0dXJuIG5ld1N0b3JlO1xuICB9XG5cbiAgaWYgKG9sZFNlY3Rpb24pIHtcbiAgICBuZXdTdG9yZSA9IGRlbGV0ZUtTUyhmaWxlcGF0aCwgb2xkU2VjdGlvbiwgbmV3U3RvcmUpO1xuICB9XG5cbiAgY29uc29sZS5sb2coY2hhbGsucmVkKGAke2ZpbGVwYXRofSBub3QgZm91bmQgb3IgZW1wdHlgKSk7IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgbm8tY29uc29sZVxuICByZXR1cm4gbmV3U3RvcmU7XG59XG5cbi8qKlxuICogSGFuZGxlIHJlbW92YWwgb2YgYSBLU1Mgc2VjdGlvblxuICpcbiAqIEBmdW5jdGlvbiBkZWxldGVLU1NcbiAqIEBwYXJhbSB7c3RyaW5nfSBmaWxlcGF0aCAtIGZpbGVwYXRoIG9mIGNoYW5nZWQgZmlsZSAoY29tZXMgZnJvbSBnYXplKVxuICogQHBhcmFtIHtvYmplY3R9IHNlY3Rpb24gLSBLU1Mgc2VjdGlvbiBkYXRhXG4gKiBAcGFyYW0ge29iamVjdH0gc3RvcmUgLSBtZW1vcnkgc3RvcmVcbiAqIEByZXR1cm4ge29iamVjdH0gdXBkYXRlZCBkYXRhIHN0b3JlXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBkZWxldGVLU1MoZmlsZXBhdGgsIHNlY3Rpb24sIHN0b3JlKSB7XG4gIGNvbnN0IGZpbGUgPSBwYXRoLnBhcnNlKGZpbGVwYXRoKTtcblxuICBpZiAoc2VjdGlvbi5yZWZlcmVuY2UgJiYgc2VjdGlvbi5yZWZlcmVuY2VVUkkpIHtcbiAgICAvLyBSZW1vdmUgc2VjdGlvbiBkYXRhIGZyb20gbWVtb3J5IHN0b3JlXG4gICAgcmV0dXJuIHVuc2V0U2VjdGlvbihzZWN0aW9uLCBmaWxlLCBzdG9yZSwgdHJ1ZSk7XG4gIH1cblxuICByZXR1cm4gc3RvcmU7XG59XG5cbi8qKlxuICogVXBkYXRlIHRoZSBzZWN0aW9ucyBzdG9yZSB3aXRoIG5ldyBkYXRhIGZvciBhIHNwZWNpZmljIHNlY3Rpb25cbiAqXG4gKiBAZnVuY3Rpb24gdXBkYXRlU2VjdGlvbkRhdGFcbiAqIEBwYXJhbSB7b2JqZWN0fSBzZWN0aW9uIC0gY29udGFpbnMgdXBkYXRlZCBzZWN0aW9uIGRhdGFcbiAqIEBwYXJhbSB7c3RyaW5nfSBrc3NQYXRoIC0gcGF0aCB0byBLU1Mgc2VjdGlvblxuICogQHBhcmFtIHtvYmplY3R9IHN0b3JlIC0gbWVtb3J5IHN0b3JlXG4gKiBAcmV0dXJuIHtvYmplY3R9IHVwZGF0ZWQgZGF0YSBzdG9yZVxuICovXG5mdW5jdGlvbiB1cGRhdGVTZWN0aW9uRGF0YShrc3NQYXRoLCBzZWN0aW9uLCBvbGRTZWN0aW9uLCBzdG9yZSkge1xuICBjb25zdCBzZWN0aW9uRmlsZUluZm8gPSBwYXRoLnBhcnNlKGtzc1BhdGgpO1xuICBjb25zdCBkYXRhRmlsZXBhdGggPSBwYXRoLmpvaW4oXG4gICAgc2VjdGlvbkZpbGVJbmZvLmRpcixcbiAgICBgJHtzZWN0aW9uRmlsZUluZm8ubmFtZX0uanNvbmBcbiAgKTtcbiAgY29uc3QgaXNJbmxpbmUgPSBudWxsICE9PSBzZWN0aW9uLm1hcmt1cC5tYXRjaCgvPFxcL1tePl0qPi8pO1xuICBjb25zdCBuZXdTb3J0ID0gc29ydFNlY3Rpb24oXG4gICAgc3RvcmUuZ2V0SW4oWydzZWN0aW9ucycsICdzb3J0ZWQnXSksXG4gICAgc2VjdGlvbi5yZWZlcmVuY2UsXG4gICAgc3RvcmUuZ2V0KCdyZWZlcmVuY2VEZWxpbWl0ZXInKVxuICApO1xuICBjb25zdCBuZXdTZWN0aW9uID0gT2JqZWN0LmFzc2lnbih7fSwgb2xkU2VjdGlvbiwgc2VjdGlvbik7XG4gIGxldCBuZXdTdG9yZSA9IHN0b3JlO1xuXG4gIC8vIFJlcXVpcmVkIGZvciByZWZlcmVuY2UgZnJvbSB0ZW1wbGF0ZXMgYW5kIGRhdGFcbiAgbmV3U2VjdGlvbi5rc3NQYXRoID0ga3NzUGF0aDtcblxuICBpZiAoaXNJbmxpbmUpIHtcbiAgICAvLyBTZXQgc2VjdGlvbiB2YWx1ZSBpZiBpbmxpbmVUZW1wYWx0ZSgpIHJldHVybmVkIGEgcGF0aFxuICAgIG5ld1N0b3JlID0gdXBkYXRlSW5saW5lVGVtcGxhdGUoXG4gICAgICBrc3NQYXRoLFxuICAgICAgb2xkU2VjdGlvbixcbiAgICAgIG5ld1NlY3Rpb24sXG4gICAgICBuZXdTdG9yZVxuICAgICk7XG4gIH0gZWxzZSB7XG4gICAgLy8gUmVtb3ZlIGlubGluZSB0ZW1wbGF0ZSwgaWYgaXQgZXhpc3RzXG4gICAgdXRpbHMucmVtb3ZlRmlsZShcbiAgICAgIG5ld1NlY3Rpb24ucmVmZXJlbmNlVVJJLFxuICAgICAgJ3RlbXBsYXRlJyxcbiAgICAgIGtzc1BhdGgsXG4gICAgICBzdG9yZVxuICAgICk7XG4gICAgLy8gVXBkYXRlIG1hcmt1cCBhbmQgZGF0YSBmaWVsZHNcbiAgICBuZXdTdG9yZSA9IHVwZGF0ZVRlbXBsYXRlRmllbGRzKFxuICAgICAgc2VjdGlvbkZpbGVJbmZvLFxuICAgICAgb2xkU2VjdGlvbixcbiAgICAgIG5ld1NlY3Rpb24sXG4gICAgICBuZXdTdG9yZVxuICAgICk7XG4gIH1cblxuICAvLyBPdXRwdXQgc2VjdGlvbiBkZXNjcmlwdGlvblxuICBuZXdTdG9yZSA9IHVwZGF0ZURlc2NyaXB0aW9uKFxuICAgIGtzc1BhdGgsXG4gICAgb2xkU2VjdGlvbixcbiAgICBuZXdTZWN0aW9uLFxuICAgIG5ld1N0b3JlXG4gICk7XG5cbiAgLy8gT3V0cHV0IHNlY3Rpb24gZGF0YSB0byBhIEpTT04gZmlsZVxuICBuZXdTZWN0aW9uLnNlY3Rpb25QYXRoID0gdXRpbHMud3JpdGVTZWN0aW9uRGF0YShcbiAgICBuZXdTdG9yZSxcbiAgICBuZXdTZWN0aW9uLFxuICAgIGRhdGFGaWxlcGF0aFxuICApO1xuXG4gIC8vIFVwZGF0ZSBzZWN0aW9uIHNvcnRpbmdcbiAgcmV0dXJuIG5ld1N0b3JlXG4gICAgLnNldEluKFxuICAgICAgWydzZWN0aW9ucycsICdzb3J0ZWQnXSxcbiAgICAgIG5ld1NvcnRcbiAgICApXG4gICAgLnNldEluKFxuICAgICAgWydzZWN0aW9ucycsICdzZWN0aW9uc0J5UGF0aCcsIGtzc1BhdGhdLFxuICAgICAgbmV3U2VjdGlvblxuICAgIClcbiAgICAuc2V0SW4oXG4gICAgICBbJ3NlY3Rpb25zJywgJ3NlY3Rpb25zQnlVUkknLCBzZWN0aW9uLnJlZmVyZW5jZVVSSV0sXG4gICAgICBuZXdTZWN0aW9uXG4gICAgKTtcbn1cblxuLyoqXG4gKiBIYW5kbGUgZGV0ZWN0aW9uIGFuZCBvdXRwdXQgb2YgaW5saW5lIHRlbXBsYXRlcywgd2hpY2ggaXMgbWFya3VwIHdyaXR0ZW5cbiAqIGluIHRoZSBLU1MgZG9jdW1lbnRhdGlvbiBpdHNlbGYgYXMgb3Bwb3NlZCB0byBhbiBleHRlcm5hbCBmaWxlXG4gKlxuICogQGZ1bmN0aW9uIHVwZGF0ZUlubGluZVRlbXBsYXRlXG4gKiBAcGFyYW0ge3N0cmluZ30gb2xkU2VjdGlvbiAtIHByZXZpb3VzIGl0ZXJhdGlvbiBvZiBLU1MgZGF0YSwgaWYgdXBkYXRlZFxuICogQHBhcmFtIHtvYmplY3R9IHNlY3Rpb24gLSBLU1Mgc2VjdGlvbiBkYXRhXG4gKiBAcmV0dXJuIHtvYmplY3R9IHVwZGF0ZWQgZGF0YSBzdG9yZSB3aXRoIG5ldyB0ZW1wbGF0ZSBwYXRoIGluZm9cbiAqL1xuZnVuY3Rpb24gdXBkYXRlSW5saW5lVGVtcGxhdGUoZmlsZXBhdGgsIG9sZFNlY3Rpb24sIHNlY3Rpb24sIHN0b3JlKSB7XG4gIGNvbnN0IG5ld1NlY3Rpb24gPSBzZWN0aW9uO1xuICBjb25zdCBuZXdTdG9yZSA9IHN0b3JlO1xuXG4gIC8vIElmIHdlIGhhdmUgaW5saW5lIG1hcmt1cFxuICBpZiAoZmllbGRTaG91bGRPdXRwdXQob2xkU2VjdGlvbiwgc2VjdGlvbiwgJ21hcmt1cCcpKSB7XG4gICAgbmV3U2VjdGlvbi50ZW1wbGF0ZVBhdGggPSB1dGlscy53cml0ZUZpbGUoXG4gICAgICBzZWN0aW9uLnJlZmVyZW5jZVVSSSxcbiAgICAgICd0ZW1wbGF0ZScsXG4gICAgICBmaWxlcGF0aCxcbiAgICAgIHNlY3Rpb24ubWFya3VwLFxuICAgICAgc3RvcmVcbiAgICApO1xuICAgIG5ld1NlY3Rpb24udGVtcGxhdGVDb250ZW50ID0gc2VjdGlvbi5tYXJrdXA7XG5cbiAgICByZXR1cm4gbmV3U3RvcmVcbiAgICAgIC5zZXRJbihcbiAgICAgICAgWydzZWN0aW9ucycsICdzZWN0aW9uc0J5UGF0aCcsIGZpbGVwYXRoXSxcbiAgICAgICAgbmV3U2VjdGlvblxuICAgICAgKVxuICAgICAgLnNldEluKFxuICAgICAgICBbJ3NlY3Rpb25zJywgJ3NlY3Rpb25zQnlVUkknLCBzZWN0aW9uLnJlZmVyZW5jZVVSSV0sXG4gICAgICAgIG5ld1NlY3Rpb25cbiAgICAgICk7XG4gIH1cblxuICByZXR1cm4gbmV3U3RvcmU7XG59XG5cbi8qKlxuICogSGFuZGxlIG91dHB1dCBvZiBzZWN0aW9uIGRlc2NyaXB0aW9uXG4gKlxuICogQGZ1bmN0aW9uIHVwZGF0ZURlc2NyaXB0aW9uXG4gKiBAcGFyYW0ge3N0cmluZ30gb2xkU2VjdGlvbiAtIHByZXZpb3VzIGl0ZXJhdGlvbiBvZiBLU1MgZGF0YSwgaWYgdXBkYXRlZFxuICogQHBhcmFtIHtvYmplY3R9IHNlY3Rpb24gLSBLU1Mgc2VjdGlvbiBkYXRhXG4gKiBAcmV0dXJuIHtvYmplY3R9IHVwZGF0ZWQgZGF0YSBzdG9yZSB3aXRoIG5ldyBkZXNjcmlwdG9uIHBhdGggaW5mb1xuICovXG5mdW5jdGlvbiB1cGRhdGVEZXNjcmlwdGlvbihmaWxlcGF0aCwgb2xkU2VjdGlvbiwgc2VjdGlvbiwgc3RvcmUpIHtcbiAgY29uc3QgbmV3U2VjdGlvbiA9IHNlY3Rpb247XG4gIGNvbnN0IG5ld1N0b3JlID0gc3RvcmU7XG5cbiAgLy8gSWYgd2UgZG9uJ3QgaGF2ZSBwcmV2aW91cyBLU1Mgb3IgdGhlIEtTUyBoYXMgYmVlbiB1cGRhdGVkXG4gIGlmIChmaWVsZFNob3VsZE91dHB1dChvbGRTZWN0aW9uLCBzZWN0aW9uLCAnZGVzY3JpcHRpb24nKSkge1xuICAgIC8vIFdyaXRlIG5ldyBkZXNjcmlwdGlvblxuICAgIG5ld1NlY3Rpb24uZGVzY3JpcHRpb25QYXRoID0gdXRpbHMud3JpdGVGaWxlKFxuICAgICAgc2VjdGlvbi5yZWZlcmVuY2VVUkksXG4gICAgICAnZGVzY3JpcHRpb24nLFxuICAgICAgZmlsZXBhdGgsXG4gICAgICBzZWN0aW9uLmRlc2NyaXB0aW9uLFxuICAgICAgc3RvcmVcbiAgICApO1xuXG4gICAgcmV0dXJuIG5ld1N0b3JlXG4gICAgICAuc2V0SW4oXG4gICAgICAgIFsnc2VjdGlvbnMnLCAnc2VjdGlvbnNCeVBhdGgnLCBmaWxlcGF0aF0sXG4gICAgICAgIG5ld1NlY3Rpb25cbiAgICAgIClcbiAgICAgIC5zZXRJbihcbiAgICAgICAgWydzZWN0aW9ucycsICdzZWN0aW9uc0J5VVJJJywgc2VjdGlvbi5yZWZlcmVuY2VVUkldLFxuICAgICAgICBuZXdTZWN0aW9uXG4gICAgICApO1xuICB9XG5cbiAgcmV0dXJuIG5ld1N0b3JlO1xufVxuXG4vKipcbiAqIEhhbmRsZSBEYXRhIGFuZCBNYXJrdXAgZmllbGRzXG4gKlxuICogQGZ1bmN0aW9uIHVwZGF0ZVRlbXBsYXRlRmllbGRzXG4gKiBAcGFyYW0ge3N0cmluZ30gZmlsZSAtIEZpbGUgZGF0YSBmb3IgS1NTIGZpbGUgZnJvbSBwYXRoLnBhcnNlKClcbiAqIEBwYXJhbSB7b2JqZWN0fSBvbGRTZWN0aW9uIC0gb3V0ZGF0ZWQgS1NTIGRhdGFcbiAqIEBwYXJhbSB7b2JqZWN0fSBzZWN0aW9uIC0gS1NTIHNlY3Rpb24gZGF0YVxuICogQHBhcmFtIHtvYmplY3R9IHN0b3JlIC0gbWVtb3J5IHN0b3JlXG4gKiBAcmV0dXJuIHtvYmplY3R9IEtTUyBzZWN0aW9uIGRhdGEgd2l0aCB1cGRhdGVkIGFzc2V0IHBhdGhzXG4gKi9cbmZ1bmN0aW9uIHVwZGF0ZVRlbXBsYXRlRmllbGRzKGZpbGUsIG9sZFNlY3Rpb24sIHNlY3Rpb24sIHN0b3JlKSB7XG4gIGNvbnN0IGtzc1BhdGggPSBwYXRoLmZvcm1hdChmaWxlKTtcbiAgY29uc3QgbmV3U2VjdGlvbiA9IHNlY3Rpb247XG4gIGxldCBmaWxlcGF0aCA9ICcnO1xuICBsZXQgb2xkRmlsZXBhdGggPSAnJztcbiAgbGV0IG5ld1N0b3JlID0gc3RvcmU7XG5cbiAgWydkYXRhJywgJ21hcmt1cCddLmZvckVhY2goKGZpZWxkKSA9PiB7XG4gICAgaWYgKG5ld1NlY3Rpb25bZmllbGRdKSB7XG4gICAgICBpZiAob2xkU2VjdGlvbltmaWVsZF0pIHtcbiAgICAgICAgb2xkRmlsZXBhdGggPSBwYXRoLmpvaW4oZmlsZS5kaXIsIG9sZFNlY3Rpb25bZmllbGRdKTtcbiAgICAgICAgbmV3U3RvcmUgPSBkZWxldGVUZW1wbGF0ZShcbiAgICAgICAgICBvbGRGaWxlcGF0aCxcbiAgICAgICAgICBvbGRTZWN0aW9uLFxuICAgICAgICAgIG5ld1N0b3JlXG4gICAgICAgICk7XG4gICAgICB9XG5cbiAgICAgIGZpbGVwYXRoID0gcGF0aC5qb2luKGZpbGUuZGlyLCBuZXdTZWN0aW9uW2ZpZWxkXSk7XG4gICAgICBuZXdTdG9yZSA9IHVwZGF0ZVRlbXBsYXRlKFxuICAgICAgICBmaWxlcGF0aCxcbiAgICAgICAgbmV3U2VjdGlvbixcbiAgICAgICAgbmV3U3RvcmVcbiAgICAgICk7XG4gICAgfSBlbHNlIHtcbiAgICAgIGRlbGV0ZSBuZXdTZWN0aW9uW2ZpZWxkXTtcbiAgICAgIG5ld1N0b3JlID0gbmV3U3RvcmVcbiAgICAgICAgLnNldEluKFxuICAgICAgICAgIFsnc2VjdGlvbnMnLCAnc2VjdGlvbnNCeVBhdGgnLCBrc3NQYXRoXSxcbiAgICAgICAgICBuZXdTZWN0aW9uXG4gICAgICAgIClcbiAgICAgICAgLnNldEluKFxuICAgICAgICAgIFsnc2VjdGlvbnMnLCAnc2VjdGlvbnNCeVVSSScsIG5ld1NlY3Rpb24ucmVmZXJlbmNlVVJJXSxcbiAgICAgICAgICBuZXdTZWN0aW9uXG4gICAgICAgICk7XG4gICAgfVxuICB9KTtcblxuICByZXR1cm4gbmV3U3RvcmU7XG59XG5cbi8qKlxuICogUmVtb3ZlIGEgc2VjdGlvbiBmcm9tIHRoZSBtZW1vcnkgc3RvcmVcbiAqXG4gKiBAZnVuY3Rpb24gdW5zZXRTZWN0aW9uXG4gKiBAcGFyYW0ge29iamVjdH0gc2VjdGlvbiAtIGNvbnRhaW5zIHVwZGF0ZWQgc2VjdGlvbiBkYXRhXG4gKiBAcGFyYW0ge3N0cmluZ30gZmlsZSAtIGZpbGUgb2JqZWN0IGZyb20gcGF0aC5wYXJzZSgpXG4gKiBAcGFyYW0ge29iamVjdH0gc3RvcmUgLSBtZW1vcnkgc3RvcmVcbiAqIEBwYXJhbSB7Ym9vbH0gcmVtb3ZlZCAtIGhhcyB0aGUgZmlsZSBiZWVuIHJlbW92ZWQgb3IganVzdCB0aGUgc2VjdGlvbiBpbmZvcm1hdGlvbiBjaGFuZ2VkP1xuICogQHJldHVybiB7b2JqZWN0fSB1cGRhdGVkIGRhdGEgc3RvcmUgd2l0aCBuZXcgZGVzY3JpcHRvbiBwYXRoIGluZm9cbiAqL1xuZnVuY3Rpb24gdW5zZXRTZWN0aW9uKHNlY3Rpb24sIGZpbGUsIHN0b3JlLCByZW1vdmVkKSB7XG4gIGNvbnN0IHNvcnRlZCA9IHN0b3JlLmdldEluKFsnc2VjdGlvbnMnLCAnc29ydGVkJ10pO1xuICBjb25zdCBrc3NQYXRoID0gcGF0aC5mb3JtYXQoZmlsZSk7XG4gIGNvbnN0IGRhdGFGaWxlcGF0aCA9IHBhdGguam9pbihmaWxlLmRpciwgYCR7ZmlsZS5uYW1lfS5qc29uYCk7XG4gIGNvbnN0IGlzSW5saW5lID0gc2VjdGlvbi5tYXJrdXAgJiZcbiAgICBudWxsICE9PSBzZWN0aW9uLm1hcmt1cC5tYXRjaCgvPFxcL1tePl0qPi8pO1xuICBjb25zdCBuZXdTb3J0ID0gdW5zb3J0U2VjdGlvbihcbiAgICBzb3J0ZWQsXG4gICAgc2VjdGlvbi5yZWZlcmVuY2UsXG4gICAgc3RvcmUuZ2V0KCdyZWZlcmVuY2VEZWxpbWl0ZXInKVxuICApO1xuICBsZXQgbmV3U3RvcmUgPSBzdG9yZTtcblxuICAvLyBSZW1vdmUgb2xkIHNlY3Rpb24gZGF0YVxuICB1dGlscy5yZW1vdmVGaWxlKFxuICAgIHNlY3Rpb24ucmVmZXJlbmNlVVJJLFxuICAgICdzZWN0aW9uJyxcbiAgICBkYXRhRmlsZXBhdGgsXG4gICAgbmV3U3RvcmVcbiAgKTtcblxuICAgLy8gUmVtb3ZlIGFzc29jaWF0ZWQgaW5saW5lIHRlbXBsYXRlXG4gIGlmIChpc0lubGluZSkge1xuICAgIHV0aWxzLnJlbW92ZUZpbGUoc2VjdGlvbi5yZWZlcmVuY2VVUkksICd0ZW1wbGF0ZScsIGtzc1BhdGgsIG5ld1N0b3JlKTtcbiAgfVxuXG4gIC8vIFJlbW92ZSBkZXNjcmlwdGlvbiB0ZW1wbGF0ZVxuICB1dGlscy5yZW1vdmVGaWxlKHNlY3Rpb24ucmVmZXJlbmNlVVJJLCAnZGVzY3JpcHRpb24nLCBrc3NQYXRoLCBuZXdTdG9yZSk7XG5cbiAgLy8gUmVtb3ZlIGRhdGEgZnJvbSBzZWN0aW9uc0J5UGF0aCBpZiBmaWxlIGhhcyBiZWVuIHJlbW92ZWRcbiAgaWYgKHJlbW92ZWQpIHtcbiAgICBuZXdTdG9yZSA9IG5ld1N0b3JlLmRlbGV0ZUluKFsnc2VjdGlvbnMnLCAnc2VjdGlvbnNCeVBhdGgnLCBrc3NQYXRoXSk7XG4gIH1cblxuICByZXR1cm4gbmV3U3RvcmVcbiAgICAuZGVsZXRlSW4oWydzZWN0aW9ucycsICdzZWN0aW9uc0J5VVJJJywgc2VjdGlvbi5yZWZlcmVuY2VVUkldKVxuICAgIC5zZXRJbihbJ3NlY3Rpb25zJywgJ3NvcnRlZCddLCBuZXdTb3J0KTtcbn1cblxuLyoqXG4gKiBTb3J0IHNlY3Rpb25zIGFuZCBzdWJzZWN0aW9uc1xuICpcbiAqIEBmdW5jdGlvbiBzb3J0U2VjdGlvblxuICogQHBhcmFtIHtvYmplY3R9IHNvcnRlZCAtIGN1cnJlbnRseSBzb3J0ZWQgc2VjdGlvbnNcbiAqIEBwYXJhbSB7c3RyaW5nfSByZWZlcmVuY2UgLSByZWZlcmVuY2UgVVJJIG9mIHNlY3Rpb24gdG8gc29ydFxuICogQHJldHVybiB7b2JqZWN0fSB1cGRhdGVkIGRhdGEgc3RvcmUgd2l0aCBuZXcgZGVzY3JpcHRvbiBwYXRoIGluZm9cbiAqL1xuZnVuY3Rpb24gc29ydFNlY3Rpb24oc29ydGVkLCByZWZlcmVuY2UsIGRlbGltaXRlcikge1xuICBjb25zdCBwYXJ0cyA9IHJlZmVyZW5jZS5zcGxpdChkZWxpbWl0ZXIpO1xuICBjb25zdCBuZXdTb3J0ID0gc29ydGVkW3BhcnRzWzBdXSB8fCB7fTtcbiAgY29uc3QgbmV3U29ydGVkID0gc29ydGVkO1xuXG4gIGlmICgxIDwgcGFydHMubGVuZ3RoKSB7XG4gICAgY29uc3QgbmV3UGFydHMgPSBwYXJ0cy5maWx0ZXIoKHBhcnQsIGlkeCkgPT4gMCAhPT0gaWR4KTtcbiAgICBuZXdTb3J0ZWRbcGFydHNbMF1dID0gc29ydFNlY3Rpb24oXG4gICAgICBuZXdTb3J0LFxuICAgICAgbmV3UGFydHMuam9pbihkZWxpbWl0ZXIpLFxuICAgICAgZGVsaW1pdGVyXG4gICAgKTtcbiAgfSBlbHNlIHtcbiAgICBuZXdTb3J0ZWRbcGFydHNbMF1dID0gbmV3U29ydDtcbiAgfVxuXG4gIHJldHVybiBuZXdTb3J0ZWQ7XG59XG5cbi8qKlxuICogUmVtb3ZlIGEgc2VjdGlvbiBmcm9tIHRoZSBzb3J0ZWQgc2VjdGlvbnNcbiAqXG4gKiBAZnVuY3Rpb24gdW5zb3J0U2VjdGlvblxuICogQHBhcmFtIHtvYmplY3R9IHNvcnRlZCAtIGN1cnJlbnRseSBzb3J0ZWQgc2VjdGlvbnNcbiAqIEBwYXJhbSB7c3RyaW5nfSByZWZlcmVuY2UgLSByZWZlcmVuY2UgVVJJIG9mIHNlY3Rpb24gdG8gc29ydFxuICogQHJldHVybiB7b2JqZWN0fSB1cGRhdGVkIGRhdGEgc3RvcmUgd2l0aCBuZXcgZGVzY3JpcHRvbiBwYXRoIGluZm9cbiAqL1xuZnVuY3Rpb24gdW5zb3J0U2VjdGlvbihzb3J0ZWQsIHJlZmVyZW5jZSwgZGVsaW1pdGVyKSB7XG4gIGNvbnN0IHBhcnRzID0gcmVmZXJlbmNlLnNwbGl0KGRlbGltaXRlcik7XG4gIGNvbnN0IHN1YnNlY3Rpb25zID0gT2JqZWN0LmtleXMoc29ydGVkW3BhcnRzWzBdXSk7XG4gIGNvbnN0IG5ld1NvcnRlZCA9IHNvcnRlZDtcblxuICBpZiAoc3Vic2VjdGlvbnMubGVuZ3RoKSB7XG4gICAgaWYgKDEgPCBwYXJ0cy5sZW5ndGgpIHtcbiAgICAgIGNvbnN0IG5ld1BhcnRzID0gcGFydHMuZmlsdGVyKChwYXJ0LCBpZHgpID0+IDAgIT09IGlkeCk7XG4gICAgICBuZXdTb3J0ZWRbcGFydHNbMF1dID0gdW5zb3J0U2VjdGlvbihcbiAgICAgICAgbmV3U29ydGVkW3BhcnRzWzBdXSxcbiAgICAgICAgbmV3UGFydHMuam9pbihkZWxpbWl0ZXIpLFxuICAgICAgICBkZWxpbWl0ZXJcbiAgICAgICk7XG4gICAgfVxuICB9IGVsc2Uge1xuICAgIGRlbGV0ZSBuZXdTb3J0ZWRbcGFydHNbMF1dO1xuICB9XG5cbiAgcmV0dXJuIG5ld1NvcnRlZDtcbn1cblxuLyoqXG4gKiBDb21wYXJlIGEgS1NTIGZpZWxkIGJldHdlZW4gb2xkIGFuZCBuZXcgS1NTIGRhdGEgdG8gc2VlIGlmIHdlIG5lZWQgdG8gb3V0cHV0XG4gKiBhIG5ldyBtb2R1bGUgZm9yIHRoYXQgZmllbGRcbiAqXG4gKiBAZnVuY3Rpb24gZmllbGRTaG91bGRPdXRwdXRcbiAqIEBwYXJhbSB7b2JqZWN0fSBvbGRTZWN0aW9uIC0gY3VycmVudGx5IHNvcnRlZCBzZWN0aW9uc1xuICogQHBhcmFtIHtvYmplY3R9IG5ld1NlY3Rpb24gLSByZWZlcmVuY2UgVVJJIG9mIHNlY3Rpb24gdG8gc29ydFxuICogQHBhcmFtIHtzdHJpbmd9IGZpZWxkIC0gS1NTIGZpZWxkIHRvIGNoZWNrXG4gKiBAcmV0dXJuIHtib29sfSBvdXRwdXQgYSBuZXcgbW9kdWxlIGZvciB0aGUgS1NTIGZpZWxkXG4gKi9cbmZ1bmN0aW9uIGZpZWxkU2hvdWxkT3V0cHV0KG9sZFNlY3Rpb24sIG5ld1NlY3Rpb24sIGZpZWxkKSB7XG4gIHJldHVybiAob2xkU2VjdGlvbiAmJlxuICAgICAgKG9sZFNlY3Rpb25bZmllbGRdICE9PSBuZXdTZWN0aW9uW2ZpZWxkXSB8fFxuICAgICAgb2xkU2VjdGlvbi5yZWZlcmVuY2VVUkkgIT09IG5ld1NlY3Rpb24ucmVmZXJlbmNlVVJJKVxuICAgICkgfHxcbiAgICAhb2xkU2VjdGlvbjtcbn1cblxuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyBzcmMvY2xpL2hhbmRsZUtTUy5qcyJdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFtQkE7QUFzRUE7QUFDQTtBQXhGQTtBQUNBOzs7QUFBQTtBQUNBOzs7QUFBQTtBQUNBO0FBQUE7QUFDQTs7O0FBQ0E7QUFDQTtBQURBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFDQTs7Ozs7QUFDQTs7Ozs7Ozs7QUFRQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBTUE7QUFDQTtBQUlBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFLQTtBQUNBO0FBQ0E7QUFDQTtBQUtBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7Ozs7QUFoRkE7QUFDQTtBQXdGQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7Ozs7Ozs7OztBQVNBO0FBQ0E7QUFDQTtBQUlBO0FBQ0E7QUFLQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFNQTtBQUNBO0FBQ0E7QUFNQTtBQUNBO0FBTUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQU1BO0FBQ0E7QUFDQTtBQUtBO0FBQ0E7QUFhQTtBQUNBO0FBQ0E7Ozs7Ozs7OztBQVNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBT0E7QUFDQTtBQUNBO0FBU0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7OztBQVFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQU9BO0FBU0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7Ozs7O0FBVUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBS0E7QUFDQTtBQUNBO0FBQ0E7QUFLQTtBQUNBO0FBQ0E7QUFTQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7Ozs7OztBQVVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUtBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFNQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBR0E7QUFDQTtBQUNBOzs7Ozs7OztBQVFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFLQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7OztBQVFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUtBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7Ozs7OztBQVVBO0FBQ0E7QUFLQSIsInNvdXJjZVJvb3QiOiIifQ=="); + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.updateKSS = updateKSS; +exports.deleteKSS = deleteKSS; + +var _path = __webpack_require__(0); + +var _path2 = _interopRequireDefault(_path); + +var _fsExtra = __webpack_require__(3); + +var _fsExtra2 = _interopRequireDefault(_fsExtra); + +var _kss = __webpack_require__(25); + +var _chalk = __webpack_require__(2); + +var _chalk2 = _interopRequireDefault(_chalk); + +var _utils = __webpack_require__(1); + +var utils = _interopRequireWildcard(_utils); + +var _handleTemplates = __webpack_require__(7); + +var _requireTemplates = __webpack_require__(8); + +function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Handle update of a KSS section + * + * @function updateKSS + * @param {string} filepath - filepath of changed file (comes from gaze) + * @param {object} store - memory store + * @return {object} updated data store + */ +function updateKSS(filepath, store) { + const kssSource = _fsExtra2.default.readFileSync(filepath, 'utf8'); + const huron = store.get('config'); + const oldSection = utils.getSection(filepath, false, store) || {}; + const file = _path2.default.parse(filepath); + let newStore = store; + + if (kssSource) { + const styleguide = (0, _kss.parse)(kssSource, huron.get('kssOptions')); + + if (styleguide.data.sections.length) { + const section = utils.normalizeSectionData(styleguide.data.sections[0]); + + if (section.reference && section.referenceURI) { + // Update or add section data + newStore = updateSectionData(filepath, section, oldSection, newStore); + + // Remove old section data if reference URI has changed + if (oldSection && oldSection.referenceURI && oldSection.referenceURI !== section.referenceURI) { + newStore = unsetSection(oldSection, file, newStore, false); + } + + (0, _requireTemplates.writeStore)(newStore); + console.log(_chalk2.default.green(`KSS source in ${filepath} changed or added`)); + return newStore; + } + + console.log(_chalk2.default.magenta(`KSS section in ${filepath} is missing a section reference`)); + return newStore; + } + + console.log(_chalk2.default.magenta(`No KSS found in ${filepath}`)); + return newStore; + } + + if (oldSection) { + newStore = deleteKSS(filepath, oldSection, newStore); + } + + console.log(_chalk2.default.red(`${filepath} not found or empty`)); // eslint-disable-line no-console + return newStore; +} + +/** + * Handle removal of a KSS section + * + * @function deleteKSS + * @param {string} filepath - filepath of changed file (comes from gaze) + * @param {object} section - KSS section data + * @param {object} store - memory store + * @return {object} updated data store + */ +/** @module cli/kss-handler */ + +function deleteKSS(filepath, section, store) { + const file = _path2.default.parse(filepath); + + if (section.reference && section.referenceURI) { + // Remove section data from memory store + return unsetSection(section, file, store, true); + } + + return store; +} + +/** + * Update the sections store with new data for a specific section + * + * @function updateSectionData + * @param {object} section - contains updated section data + * @param {string} kssPath - path to KSS section + * @param {object} store - memory store + * @return {object} updated data store + */ +function updateSectionData(kssPath, section, oldSection, store) { + const sectionFileInfo = _path2.default.parse(kssPath); + const dataFilepath = _path2.default.join(sectionFileInfo.dir, `${sectionFileInfo.name}.json`); + const isInline = null !== section.markup.match(/<\/[^>]*>/); + const newSort = sortSection(store.getIn(['sections', 'sorted']), section.reference, store.get('referenceDelimiter')); + const newSection = Object.assign({}, oldSection, section); + let newStore = store; + + // Required for reference from templates and data + newSection.kssPath = kssPath; + + if (isInline) { + // Set section value if inlineTempalte() returned a path + newStore = updateInlineTemplate(kssPath, oldSection, newSection, newStore); + } else { + // Remove inline template, if it exists + utils.removeFile(newSection.referenceURI, 'template', kssPath, store); + // Update markup and data fields + newStore = updateTemplateFields(sectionFileInfo, oldSection, newSection, newStore); + } + + // Output section description + newStore = updateDescription(kssPath, oldSection, newSection, newStore); + + // Output section data to a JSON file + newSection.sectionPath = utils.writeSectionData(newStore, newSection, dataFilepath); + + // Update section sorting + return newStore.setIn(['sections', 'sorted'], newSort).setIn(['sections', 'sectionsByPath', kssPath], newSection).setIn(['sections', 'sectionsByURI', section.referenceURI], newSection); +} + +/** + * Handle detection and output of inline templates, which is markup written + * in the KSS documentation itself as opposed to an external file + * + * @function updateInlineTemplate + * @param {string} oldSection - previous iteration of KSS data, if updated + * @param {object} section - KSS section data + * @return {object} updated data store with new template path info + */ +function updateInlineTemplate(filepath, oldSection, section, store) { + const newSection = section; + const newStore = store; + + // If we have inline markup + if (fieldShouldOutput(oldSection, section, 'markup')) { + newSection.templatePath = utils.writeFile(section.referenceURI, 'template', filepath, section.markup, store); + newSection.templateContent = section.markup; + + return newStore.setIn(['sections', 'sectionsByPath', filepath], newSection).setIn(['sections', 'sectionsByURI', section.referenceURI], newSection); + } + + return newStore; +} + +/** + * Handle output of section description + * + * @function updateDescription + * @param {string} oldSection - previous iteration of KSS data, if updated + * @param {object} section - KSS section data + * @return {object} updated data store with new descripton path info + */ +function updateDescription(filepath, oldSection, section, store) { + const newSection = section; + const newStore = store; + + // If we don't have previous KSS or the KSS has been updated + if (fieldShouldOutput(oldSection, section, 'description')) { + // Write new description + newSection.descriptionPath = utils.writeFile(section.referenceURI, 'description', filepath, section.description, store); + + return newStore.setIn(['sections', 'sectionsByPath', filepath], newSection).setIn(['sections', 'sectionsByURI', section.referenceURI], newSection); + } + + return newStore; +} + +/** + * Handle Data and Markup fields + * + * @function updateTemplateFields + * @param {string} file - File data for KSS file from path.parse() + * @param {object} oldSection - outdated KSS data + * @param {object} section - KSS section data + * @param {object} store - memory store + * @return {object} KSS section data with updated asset paths + */ +function updateTemplateFields(file, oldSection, section, store) { + const kssPath = _path2.default.format(file); + const newSection = section; + let filepath = ''; + let oldFilepath = ''; + let newStore = store; + + ['data', 'markup'].forEach(field => { + if (newSection[field]) { + if (oldSection[field]) { + oldFilepath = _path2.default.join(file.dir, oldSection[field]); + newStore = (0, _handleTemplates.deleteTemplate)(oldFilepath, oldSection, newStore); + } + + filepath = _path2.default.join(file.dir, newSection[field]); + newStore = (0, _handleTemplates.updateTemplate)(filepath, newSection, newStore); + } else { + delete newSection[field]; + newStore = newStore.setIn(['sections', 'sectionsByPath', kssPath], newSection).setIn(['sections', 'sectionsByURI', newSection.referenceURI], newSection); + } + }); + + return newStore; +} + +/** + * Remove a section from the memory store + * + * @function unsetSection + * @param {object} section - contains updated section data + * @param {string} file - file object from path.parse() + * @param {object} store - memory store + * @param {bool} removed - has the file been removed or just the section information changed? + * @return {object} updated data store with new descripton path info + */ +function unsetSection(section, file, store, removed) { + const sorted = store.getIn(['sections', 'sorted']); + const kssPath = _path2.default.format(file); + const dataFilepath = _path2.default.join(file.dir, `${file.name}.json`); + const isInline = section.markup && null !== section.markup.match(/<\/[^>]*>/); + const newSort = unsortSection(sorted, section.reference, store.get('referenceDelimiter')); + let newStore = store; + + // Remove old section data + utils.removeFile(section.referenceURI, 'section', dataFilepath, newStore); + + // Remove associated inline template + if (isInline) { + utils.removeFile(section.referenceURI, 'template', kssPath, newStore); + } + + // Remove description template + utils.removeFile(section.referenceURI, 'description', kssPath, newStore); + + // Remove data from sectionsByPath if file has been removed + if (removed) { + newStore = newStore.deleteIn(['sections', 'sectionsByPath', kssPath]); + } + + return newStore.deleteIn(['sections', 'sectionsByURI', section.referenceURI]).setIn(['sections', 'sorted'], newSort); +} + +/** + * Sort sections and subsections + * + * @function sortSection + * @param {object} sorted - currently sorted sections + * @param {string} reference - reference URI of section to sort + * @return {object} updated data store with new descripton path info + */ +function sortSection(sorted, reference, delimiter) { + const parts = reference.split(delimiter); + const newSort = sorted[parts[0]] || {}; + const newSorted = sorted; + + if (1 < parts.length) { + const newParts = parts.filter((part, idx) => 0 !== idx); + newSorted[parts[0]] = sortSection(newSort, newParts.join(delimiter), delimiter); + } else { + newSorted[parts[0]] = newSort; + } + + return newSorted; +} + +/** + * Remove a section from the sorted sections + * + * @function unsortSection + * @param {object} sorted - currently sorted sections + * @param {string} reference - reference URI of section to sort + * @return {object} updated data store with new descripton path info + */ +function unsortSection(sorted, reference, delimiter) { + const parts = reference.split(delimiter); + const subsections = Object.keys(sorted[parts[0]]); + const newSorted = sorted; + + if (subsections.length) { + if (1 < parts.length) { + const newParts = parts.filter((part, idx) => 0 !== idx); + newSorted[parts[0]] = unsortSection(newSorted[parts[0]], newParts.join(delimiter), delimiter); + } + } else { + delete newSorted[parts[0]]; + } + + return newSorted; +} + +/** + * Compare a KSS field between old and new KSS data to see if we need to output + * a new module for that field + * + * @function fieldShouldOutput + * @param {object} oldSection - currently sorted sections + * @param {object} newSection - reference URI of section to sort + * @param {string} field - KSS field to check + * @return {bool} output a new module for the KSS field + */ +function fieldShouldOutput(oldSection, newSection, field) { + return oldSection && (oldSection[field] !== newSection[field] || oldSection.referenceURI !== newSection.referenceURI) || !oldSection; +} /***/ }), /* 16 */ -/* no static exports found */ -/* all exports used */ -/*!************************************!*\ - !*** ./src/cli/requireExternal.js ***! - \************************************/ /***/ (function(module, exports) { -eval("\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = requireExternal;\n// Necessary to remove require statement from Webpack processing preserve it in output\n/* eslint-disable import/no-dynamic-require, global-require */\nfunction requireExternal(requirePath) {\n return require(requirePath);\n}\n/* eslint-enable *///# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTYuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vc3JjL2NsaS9yZXF1aXJlRXh0ZXJuYWwuanM/OWM3MCJdLCJzb3VyY2VzQ29udGVudCI6WyIvLyBOZWNlc3NhcnkgdG8gcmVtb3ZlIHJlcXVpcmUgc3RhdGVtZW50IGZyb20gV2VicGFjayBwcm9jZXNzaW5nIHByZXNlcnZlIGl0IGluIG91dHB1dFxuLyogZXNsaW50LWRpc2FibGUgaW1wb3J0L25vLWR5bmFtaWMtcmVxdWlyZSwgZ2xvYmFsLXJlcXVpcmUgKi9cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIHJlcXVpcmVFeHRlcm5hbChyZXF1aXJlUGF0aCkge1xuICByZXR1cm4gcmVxdWlyZShyZXF1aXJlUGF0aCk7XG59XG4vKiBlc2xpbnQtZW5hYmxlICovXG5cblxuXG4vLyBXRUJQQUNLIEZPT1RFUiAvL1xuLy8gc3JjL2NsaS9yZXF1aXJlRXh0ZXJuYWwuanMiXSwibWFwcGluZ3MiOiI7Ozs7O0FBRUE7QUFGQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0="); +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = requireExternal; +// Necessary to remove require statement from Webpack processing preserve it in output +/* eslint-disable import/no-dynamic-require, global-require */ +function requireExternal(requirePath) { + return require(requirePath); +} +/* eslint-enable */ /***/ }), /* 17 */ -/* no static exports found */ -/* all exports used */ -/*!***************************!*\ - !*** ./src/cli/server.js ***! - \***************************/ /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = startWebpack;\n\nvar _webpack = __webpack_require__(/*! webpack */ 5);\n\nvar _webpack2 = _interopRequireDefault(_webpack);\n\nvar _webpackDevServer = __webpack_require__(/*! webpack-dev-server */ 29);\n\nvar _webpackDevServer2 = _interopRequireDefault(_webpackDevServer);\n\nvar _chalk = __webpack_require__(/*! chalk */ 2);\n\nvar _chalk2 = _interopRequireDefault(_chalk);\n\nvar _opn = __webpack_require__(/*! opn */ 27);\n\nvar _opn2 = _interopRequireDefault(_opn);\n\nvar _devServer = __webpack_require__(/*! ../../config/devServer.config */ 10);\n\nvar _devServer2 = _interopRequireDefault(_devServer);\n\nvar _parseArgs = __webpack_require__(/*! ./parseArgs */ 4);\n\nvar _parseArgs2 = _interopRequireDefault(_parseArgs);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Spin up webpack-dev-server or, if production flag is set, run webpack a single time\n *\n * @function startWebpack\n * @param {object} config - webpack configuration, preprocessed by {@link module:cli/generate-config generateConfig}\n * @see {@link module:cli/generate-config generateConfig}\n */\n/** @module cli/webpack-server */\nfunction startWebpack(config) {\n const huron = config.huron;\n const webpackConfig = config.webpack;\n const compiler = (0, _webpack2.default)(webpackConfig);\n\n if (_parseArgs2.default.progress) {\n compiler.apply(new _webpack2.default.ProgressPlugin((percentage, msg) => {\n console.log(`${percentage * 100}% `, msg);\n }));\n }\n\n if (_parseArgs2.default.production) {\n compiler.run((err, stats) => {\n const info = stats.toJson();\n\n if (err) {\n console.log(err);\n }\n\n if (stats.hasErrors()) {\n console.error(_chalk2.default.red('Webpack encountered errors during compile: ', info.errors));\n }\n\n if (stats.hasWarnings()) {\n console.error(_chalk2.default.yellow('Webpack encountered warnings during compile: ', info.warnings));\n }\n });\n } else {\n const server = new _webpackDevServer2.default(compiler, (0, _devServer2.default)(huron));\n const prototypeName = huron.prototypes[0].title || huron.prototypes[0];\n\n server.listen(huron.port, 'localhost', err => {\n if (err) {\n return console.log(err);\n }\n\n console.log(`Listening at http://localhost:${huron.port}/`);\n (0, _opn2.default)(`http://localhost:${huron.port}/${huron.root}/${prototypeName}.html`);\n return true;\n });\n }\n}//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTcuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vc3JjL2NsaS9zZXJ2ZXIuanM/ODJlMSJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQG1vZHVsZSBjbGkvd2VicGFjay1zZXJ2ZXIgKi9cbmltcG9ydCB3ZWJwYWNrIGZyb20gJ3dlYnBhY2snO1xuaW1wb3J0IFdlYnBhY2tEZXZTZXJ2ZXIgZnJvbSAnd2VicGFjay1kZXYtc2VydmVyJztcbmltcG9ydCBjaGFsayBmcm9tICdjaGFsayc7XG5pbXBvcnQgb3BlbiBmcm9tICdvcG4nO1xuXG5pbXBvcnQgY3JlYXRlRGV2U2VydmVyQ29uZmlnIGZyb20gJy4uLy4uL2NvbmZpZy9kZXZTZXJ2ZXIuY29uZmlnJztcbmltcG9ydCBwcm9ncmFtIGZyb20gJy4vcGFyc2VBcmdzJztcblxuLyoqXG4gKiBTcGluIHVwIHdlYnBhY2stZGV2LXNlcnZlciBvciwgaWYgcHJvZHVjdGlvbiBmbGFnIGlzIHNldCwgcnVuIHdlYnBhY2sgYSBzaW5nbGUgdGltZVxuICpcbiAqIEBmdW5jdGlvbiBzdGFydFdlYnBhY2tcbiAqIEBwYXJhbSB7b2JqZWN0fSBjb25maWcgLSB3ZWJwYWNrIGNvbmZpZ3VyYXRpb24sIHByZXByb2Nlc3NlZCBieSB7QGxpbmsgbW9kdWxlOmNsaS9nZW5lcmF0ZS1jb25maWcgZ2VuZXJhdGVDb25maWd9XG4gKiBAc2VlIHtAbGluayBtb2R1bGU6Y2xpL2dlbmVyYXRlLWNvbmZpZyBnZW5lcmF0ZUNvbmZpZ31cbiAqL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gc3RhcnRXZWJwYWNrKGNvbmZpZykge1xuICBjb25zdCBodXJvbiA9IGNvbmZpZy5odXJvbjtcbiAgY29uc3Qgd2VicGFja0NvbmZpZyA9IGNvbmZpZy53ZWJwYWNrO1xuICBjb25zdCBjb21waWxlciA9IHdlYnBhY2sod2VicGFja0NvbmZpZyk7XG5cbiAgaWYgKHByb2dyYW0ucHJvZ3Jlc3MpIHtcbiAgICBjb21waWxlci5hcHBseShcbiAgICAgIG5ldyB3ZWJwYWNrLlByb2dyZXNzUGx1Z2luKFxuICAgICAgICAocGVyY2VudGFnZSwgbXNnKSA9PiB7XG4gICAgICAgICAgY29uc29sZS5sb2coYCR7KHBlcmNlbnRhZ2UgKiAxMDApfSUgYCwgbXNnKTtcbiAgICAgICAgfVxuICAgICAgKVxuICAgICk7XG4gIH1cblxuICBpZiAocHJvZ3JhbS5wcm9kdWN0aW9uKSB7XG4gICAgY29tcGlsZXIucnVuKChlcnIsIHN0YXRzKSA9PiB7XG4gICAgICBjb25zdCBpbmZvID0gc3RhdHMudG9Kc29uKCk7XG5cbiAgICAgIGlmIChlcnIpIHtcbiAgICAgICAgY29uc29sZS5sb2coZXJyKTtcbiAgICAgIH1cblxuICAgICAgaWYgKHN0YXRzLmhhc0Vycm9ycygpKSB7XG4gICAgICAgIGNvbnNvbGUuZXJyb3IoXG4gICAgICAgICAgY2hhbGsucmVkKFxuICAgICAgICAgICAgJ1dlYnBhY2sgZW5jb3VudGVyZWQgZXJyb3JzIGR1cmluZyBjb21waWxlOiAnLFxuICAgICAgICAgICAgaW5mby5lcnJvcnNcbiAgICAgICAgICApXG4gICAgICAgICk7XG4gICAgICB9XG5cbiAgICAgIGlmIChzdGF0cy5oYXNXYXJuaW5ncygpKSB7XG4gICAgICAgIGNvbnNvbGUuZXJyb3IoXG4gICAgICAgICAgY2hhbGsueWVsbG93KFxuICAgICAgICAgICAgJ1dlYnBhY2sgZW5jb3VudGVyZWQgd2FybmluZ3MgZHVyaW5nIGNvbXBpbGU6ICcsIGluZm8ud2FybmluZ3NcbiAgICAgICAgICApXG4gICAgICAgICk7XG4gICAgICB9XG4gICAgfSk7XG4gIH0gZWxzZSB7XG4gICAgY29uc3Qgc2VydmVyID0gbmV3IFdlYnBhY2tEZXZTZXJ2ZXIoY29tcGlsZXIsIGNyZWF0ZURldlNlcnZlckNvbmZpZyhodXJvbikpO1xuICAgIGNvbnN0IHByb3RvdHlwZU5hbWUgPSBodXJvbi5wcm90b3R5cGVzWzBdLnRpdGxlIHx8IGh1cm9uLnByb3RvdHlwZXNbMF07XG5cbiAgICBzZXJ2ZXIubGlzdGVuKFxuICAgICAgaHVyb24ucG9ydCxcbiAgICAgICdsb2NhbGhvc3QnLFxuICAgICAgKGVycikgPT4ge1xuICAgICAgICBpZiAoZXJyKSB7XG4gICAgICAgICAgcmV0dXJuIGNvbnNvbGUubG9nKGVycik7XG4gICAgICAgIH1cblxuICAgICAgICBjb25zb2xlLmxvZyhgTGlzdGVuaW5nIGF0IGh0dHA6Ly9sb2NhbGhvc3Q6JHtodXJvbi5wb3J0fS9gKTtcbiAgICAgICAgb3BlbihgaHR0cDovL2xvY2FsaG9zdDoke2h1cm9uLnBvcnR9LyR7aHVyb24ucm9vdH0vJHtwcm90b3R5cGVOYW1lfS5odG1sYCk7XG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgfVxuICAgICk7XG4gIH1cbn1cblxuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyBzcmMvY2xpL3NlcnZlci5qcyJdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFnQkE7QUFDQTtBQWhCQTtBQUNBOzs7QUFBQTtBQUNBOzs7QUFBQTtBQUNBOzs7QUFBQTtBQUNBOzs7QUFDQTtBQUNBOzs7QUFBQTtBQUNBOzs7OztBQUNBOzs7Ozs7O0FBVEE7QUFnQkE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFHQTtBQUNBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBTUE7QUFDQTtBQUNBO0FBQ0E7QUFLQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUlBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBIiwic291cmNlUm9vdCI6IiJ9"); + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = startWebpack; + +var _webpack = __webpack_require__(5); + +var _webpack2 = _interopRequireDefault(_webpack); + +var _webpackDevServer = __webpack_require__(29); + +var _webpackDevServer2 = _interopRequireDefault(_webpackDevServer); + +var _chalk = __webpack_require__(2); + +var _chalk2 = _interopRequireDefault(_chalk); + +var _opn = __webpack_require__(27); + +var _opn2 = _interopRequireDefault(_opn); + +var _devServer = __webpack_require__(10); + +var _devServer2 = _interopRequireDefault(_devServer); + +var _parseArgs = __webpack_require__(4); + +var _parseArgs2 = _interopRequireDefault(_parseArgs); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Spin up webpack-dev-server or, if production flag is set, run webpack a single time + * + * @function startWebpack + * @param {object} config - webpack configuration, preprocessed by {@link module:cli/generate-config generateConfig} + * @see {@link module:cli/generate-config generateConfig} + */ +/** @module cli/webpack-server */ +function startWebpack(config) { + const huron = config.huron; + const webpackConfig = config.webpack; + const compiler = (0, _webpack2.default)(webpackConfig); + + if (_parseArgs2.default.progress) { + compiler.apply(new _webpack2.default.ProgressPlugin((percentage, msg) => { + console.log(`${percentage * 100}% `, msg); + })); + } + + if (_parseArgs2.default.production) { + compiler.run((err, stats) => { + const info = stats.toJson(); + + if (err) { + console.log(err); + } + + if (stats.hasErrors()) { + console.error(_chalk2.default.red('Webpack encountered errors during compile: ', info.errors)); + } + + if (stats.hasWarnings()) { + console.error(_chalk2.default.yellow('Webpack encountered warnings during compile: ', info.warnings)); + } + }); + } else { + const server = new _webpackDevServer2.default(compiler, (0, _devServer2.default)(huron)); + const prototypeName = huron.prototypes[0].title || huron.prototypes[0]; + + server.listen(huron.port, 'localhost', err => { + if (err) { + return console.log(err); + } + + console.log(`Listening at http://localhost:${huron.port}/`); + (0, _opn2.default)(`http://localhost:${huron.port}/${huron.root}/${prototypeName}.html`); + return true; + }); + } +} + +/***/ }), +/* 18 */ +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _path = __webpack_require__(0); + +var _path2 = _interopRequireDefault(_path); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +exports.default = { + css: [], + entry: 'huron', + js: [], + kss: 'css/', + kssExtension: '.css', + kssOptions: { + multiline: true, + markdown: true, + custom: ['data'] + }, + output: 'partials', + port: 8080, + prototypes: ['index'], + root: 'dist/', + sectionTemplate: _path2.default.join(__dirname, '../../templates/section.hbs'), + classNames: false, + templates: { + rule: { + test: /\.(hbs|handlebars)$/, + use: 'handlebars-loader' + }, + extension: '.hbs' + }, + window: {} +}; /***/ }), -/* 18 */, /* 19 */ -/* exports provided: default */ -/* all exports used */ -/*!*******************************************!*\ - !*** ./src/defaultConfig/huron.config.js ***! - \*******************************************/ -/***/ (function(module, __webpack_exports__, __webpack_require__) { +/***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("Object.defineProperty(__webpack_exports__, \"__esModule\", { value: true });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_path__ = __webpack_require__(/*! path */ 0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_path___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_path__);\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n css: [],\n entry: 'huron',\n js: [],\n kss: 'css/',\n kssExtension: '.css',\n kssOptions: {\n multiline: true,\n markdown: true,\n custom: ['data'],\n },\n output: 'partials',\n port: 8080,\n prototypes: ['index'],\n root: 'dist/',\n sectionTemplate: __WEBPACK_IMPORTED_MODULE_0_path___default.a.join(__dirname, '../../templates/section.hbs'),\n classNames: false,\n templates: {\n rule: {\n test: /\\.(hbs|handlebars)$/,\n use: 'handlebars-loader',\n },\n extension: '.hbs',\n },\n window: {},\n});\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTkuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9zcmMvZGVmYXVsdENvbmZpZy9odXJvbi5jb25maWcuanM/MGJmZCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgcGF0aCBmcm9tICdwYXRoJztcblxuZXhwb3J0IGRlZmF1bHQge1xuICBjc3M6IFtdLFxuICBlbnRyeTogJ2h1cm9uJyxcbiAganM6IFtdLFxuICBrc3M6ICdjc3MvJyxcbiAga3NzRXh0ZW5zaW9uOiAnLmNzcycsXG4gIGtzc09wdGlvbnM6IHtcbiAgICBtdWx0aWxpbmU6IHRydWUsXG4gICAgbWFya2Rvd246IHRydWUsXG4gICAgY3VzdG9tOiBbJ2RhdGEnXSxcbiAgfSxcbiAgb3V0cHV0OiAncGFydGlhbHMnLFxuICBwb3J0OiA4MDgwLFxuICBwcm90b3R5cGVzOiBbJ2luZGV4J10sXG4gIHJvb3Q6ICdkaXN0LycsXG4gIHNlY3Rpb25UZW1wbGF0ZTogcGF0aC5qb2luKF9fZGlybmFtZSwgJy4uLy4uL3RlbXBsYXRlcy9zZWN0aW9uLmhicycpLFxuICBjbGFzc05hbWVzOiBmYWxzZSxcbiAgdGVtcGxhdGVzOiB7XG4gICAgcnVsZToge1xuICAgICAgdGVzdDogL1xcLihoYnN8aGFuZGxlYmFycykkLyxcbiAgICAgIHVzZTogJ2hhbmRsZWJhcnMtbG9hZGVyJyxcbiAgICB9LFxuICAgIGV4dGVuc2lvbjogJy5oYnMnLFxuICB9LFxuICB3aW5kb3c6IHt9LFxufTtcblxuXG5cbi8vLy8vLy8vLy8vLy8vLy8vL1xuLy8gV0VCUEFDSyBGT09URVJcbi8vIC4vc3JjL2RlZmF1bHRDb25maWcvaHVyb24uY29uZmlnLmpzXG4vLyBtb2R1bGUgaWQgPSAxOVxuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOyIsInNvdXJjZVJvb3QiOiIifQ=="); + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _webpack = __webpack_require__(5); + +var _webpack2 = _interopRequireDefault(_webpack); + +var _path = __webpack_require__(0); + +var _path2 = _interopRequireDefault(_path); + +var _parseArgs = __webpack_require__(4); + +var _parseArgs2 = _interopRequireDefault(_parseArgs); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +exports.default = huron => { + const cwd = process.cwd(); + + return { + entry: {}, + output: { + path: _path2.default.join(cwd, huron.root), + publicPath: _parseArgs2.default.production ? '' : `http://localhost:${huron.port}/${huron.root}`, + filename: '[name].js', + chunkFilename: '[name].chunk.min.js' + }, + plugins: [new _webpack2.default.HotModuleReplacementPlugin(), new _webpack2.default.NamedModulesPlugin()], + resolve: { + modulesDirectories: [_path2.default.resolve(__dirname, '../src/js')] + }, + resolveLoader: { + modulesDirectories: ['web_loaders', 'web_modules', 'node_loaders', 'node_modules', _path2.default.resolve(__dirname, '../node_modules')] + }, + module: { + rules: [{ + test: /\.html$/, + include: [_path2.default.join(cwd, huron.root, huron.output)], + use: 'html-loader' + }, { + test: /\.(hbs|handlebars)$/, + include: [_path2.default.join(cwd, huron.root, 'huron-assets')], + use: { + loader: 'handlebars-loader', + options: { + helperDirs: [_path2.default.join(__dirname, '../../', 'templates/handlebarsHelpers')] + } + } + }] + } + }; +}; /***/ }), /* 20 */ -/* exports provided: default */ -/* all exports used */ -/*!*********************************************!*\ - !*** ./src/defaultConfig/webpack.config.js ***! - \*********************************************/ -/***/ (function(module, __webpack_exports__, __webpack_require__) { +/***/ (function(module, exports) { -"use strict"; -eval("Object.defineProperty(__webpack_exports__, \"__esModule\", { value: true });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_webpack__ = __webpack_require__(/*! webpack */ 5);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_webpack___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_webpack__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_path__ = __webpack_require__(/*! path */ 0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_path___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_path__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__cli_parseArgs__ = __webpack_require__(/*! ../cli/parseArgs */ 4);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__cli_parseArgs___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__cli_parseArgs__);\n\n\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ((huron) => {\n const cwd = process.cwd();\n\n return {\n entry: {},\n output: {\n path: __WEBPACK_IMPORTED_MODULE_1_path___default.a.join(cwd, huron.root),\n publicPath: __WEBPACK_IMPORTED_MODULE_2__cli_parseArgs___default.a.production ? '' :\n `http://localhost:${huron.port}/${huron.root}`,\n filename: '[name].js',\n chunkFilename: '[name].chunk.min.js',\n },\n plugins: [\n new __WEBPACK_IMPORTED_MODULE_0_webpack___default.a.HotModuleReplacementPlugin(),\n new __WEBPACK_IMPORTED_MODULE_0_webpack___default.a.NamedModulesPlugin(),\n ],\n resolve: {\n modulesDirectories: [\n __WEBPACK_IMPORTED_MODULE_1_path___default.a.resolve(__dirname, '../src/js'),\n ],\n },\n resolveLoader: {\n modulesDirectories: [\n 'web_loaders',\n 'web_modules',\n 'node_loaders',\n 'node_modules',\n __WEBPACK_IMPORTED_MODULE_1_path___default.a.resolve(__dirname, '../node_modules'),\n ],\n },\n module: {\n rules: [\n {\n test: /\\.html$/,\n include: [__WEBPACK_IMPORTED_MODULE_1_path___default.a.join(cwd, huron.root, huron.output)],\n use: 'html-loader',\n },\n {\n test: /\\.(hbs|handlebars)$/,\n include: [__WEBPACK_IMPORTED_MODULE_1_path___default.a.join(cwd, huron.root, 'huron-assets')],\n use: {\n loader: 'handlebars-loader',\n options: {\n helperDirs: [__WEBPACK_IMPORTED_MODULE_1_path___default.a.join(\n __dirname,\n '../../',\n 'templates/handlebarsHelpers'\n )],\n },\n },\n },\n ],\n },\n };\n});\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjAuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9zcmMvZGVmYXVsdENvbmZpZy93ZWJwYWNrLmNvbmZpZy5qcz82ZGUzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB3ZWJwYWNrIGZyb20gJ3dlYnBhY2snO1xuaW1wb3J0IHBhdGggZnJvbSAncGF0aCc7XG5cbmltcG9ydCBwcm9ncmFtIGZyb20gJy4uL2NsaS9wYXJzZUFyZ3MnO1xuXG5leHBvcnQgZGVmYXVsdCAoaHVyb24pID0+IHtcbiAgY29uc3QgY3dkID0gcHJvY2Vzcy5jd2QoKTtcblxuICByZXR1cm4ge1xuICAgIGVudHJ5OiB7fSxcbiAgICBvdXRwdXQ6IHtcbiAgICAgIHBhdGg6IHBhdGguam9pbihjd2QsIGh1cm9uLnJvb3QpLFxuICAgICAgcHVibGljUGF0aDogcHJvZ3JhbS5wcm9kdWN0aW9uID8gJycgOlxuICAgICAgICBgaHR0cDovL2xvY2FsaG9zdDoke2h1cm9uLnBvcnR9LyR7aHVyb24ucm9vdH1gLFxuICAgICAgZmlsZW5hbWU6ICdbbmFtZV0uanMnLFxuICAgICAgY2h1bmtGaWxlbmFtZTogJ1tuYW1lXS5jaHVuay5taW4uanMnLFxuICAgIH0sXG4gICAgcGx1Z2luczogW1xuICAgICAgbmV3IHdlYnBhY2suSG90TW9kdWxlUmVwbGFjZW1lbnRQbHVnaW4oKSxcbiAgICAgIG5ldyB3ZWJwYWNrLk5hbWVkTW9kdWxlc1BsdWdpbigpLFxuICAgIF0sXG4gICAgcmVzb2x2ZToge1xuICAgICAgbW9kdWxlc0RpcmVjdG9yaWVzOiBbXG4gICAgICAgIHBhdGgucmVzb2x2ZShfX2Rpcm5hbWUsICcuLi9zcmMvanMnKSxcbiAgICAgIF0sXG4gICAgfSxcbiAgICByZXNvbHZlTG9hZGVyOiB7XG4gICAgICBtb2R1bGVzRGlyZWN0b3JpZXM6IFtcbiAgICAgICAgJ3dlYl9sb2FkZXJzJyxcbiAgICAgICAgJ3dlYl9tb2R1bGVzJyxcbiAgICAgICAgJ25vZGVfbG9hZGVycycsXG4gICAgICAgICdub2RlX21vZHVsZXMnLFxuICAgICAgICBwYXRoLnJlc29sdmUoX19kaXJuYW1lLCAnLi4vbm9kZV9tb2R1bGVzJyksXG4gICAgICBdLFxuICAgIH0sXG4gICAgbW9kdWxlOiB7XG4gICAgICBydWxlczogW1xuICAgICAgICB7XG4gICAgICAgICAgdGVzdDogL1xcLmh0bWwkLyxcbiAgICAgICAgICBpbmNsdWRlOiBbcGF0aC5qb2luKGN3ZCwgaHVyb24ucm9vdCwgaHVyb24ub3V0cHV0KV0sXG4gICAgICAgICAgdXNlOiAnaHRtbC1sb2FkZXInLFxuICAgICAgICB9LFxuICAgICAgICB7XG4gICAgICAgICAgdGVzdDogL1xcLihoYnN8aGFuZGxlYmFycykkLyxcbiAgICAgICAgICBpbmNsdWRlOiBbcGF0aC5qb2luKGN3ZCwgaHVyb24ucm9vdCwgJ2h1cm9uLWFzc2V0cycpXSxcbiAgICAgICAgICB1c2U6IHtcbiAgICAgICAgICAgIGxvYWRlcjogJ2hhbmRsZWJhcnMtbG9hZGVyJyxcbiAgICAgICAgICAgIG9wdGlvbnM6IHtcbiAgICAgICAgICAgICAgaGVscGVyRGlyczogW3BhdGguam9pbihcbiAgICAgICAgICAgICAgICBfX2Rpcm5hbWUsXG4gICAgICAgICAgICAgICAgJy4uLy4uLycsXG4gICAgICAgICAgICAgICAgJ3RlbXBsYXRlcy9oYW5kbGViYXJzSGVscGVycydcbiAgICAgICAgICAgICAgKV0sXG4gICAgICAgICAgICB9LFxuICAgICAgICAgIH0sXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgIH0sXG4gIH07XG59O1xuXG5cblxuLy8vLy8vLy8vLy8vLy8vLy8vXG4vLyBXRUJQQUNLIEZPT1RFUlxuLy8gLi9zcmMvZGVmYXVsdENvbmZpZy93ZWJwYWNrLmNvbmZpZy5qc1xuLy8gbW9kdWxlIGlkID0gMjBcbi8vIG1vZHVsZSBjaHVua3MgPSAwIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTsiLCJzb3VyY2VSb290IjoiIn0="); +module.exports = "'use strict';\n\nvar _huronStore = require('./huron-store');\n\nvar _huronStore2 = _interopRequireDefault(_huronStore);\n\nvar _insertNodes = require('./insertNodes');\n\nvar _insertNodes2 = _interopRequireDefault(_insertNodes);\n\nvar _section = require('./section.hbs');\n\nvar _section2 = _interopRequireDefault(_section);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/* eslint-enable */\n\nconst assets = require.context(hotScope.requirePath, true, hotScope.requireRegex); /* globals hotScope */\n\n// NOTE: This is not a normal JS file! It is pulled in by the CLI as a string\n// and prepended to the browser script after replacing anything referenced via `hotScope[variable]`\n// with CLI arguments or config properties passed in by the user.\n\n/* eslint-disable */\n\nconst modules = {};\n\nmodules[hotScope.sectionTemplatePath] = _section2.default;\n\nassets.keys().forEach(key => {\n modules[key] = assets(key);\n});\n\nconst insert = new _insertNodes2.default(modules, _huronStore2.default);\n\nif (module.hot) {\n // Hot Module Replacement for huron components (json, hbs, html)\n module.hot.accept(assets.id, () => {\n const newAssets = require.context(hotScope.requirePath, true, hotScope.requireRegex);\n const newModules = newAssets.keys().map(key => [key, newAssets(key)]).filter(newModule => modules[newModule[0]] !== newModule[1]);\n\n updateStore(require('./huron-store.js')); // eslint-disable-line global-require, import/no-unresolved\n newModules.forEach(module => {\n modules[module[0]] = module[1];\n hotReplace(module[0], module[1], modules);\n });\n });\n\n // Hot Module Replacement for sections template\n module.hot.accept('./section.hbs', () => {\n const newSectionTemplate = require('./section.hbs'); // eslint-disable-line global-require, import/no-unresolved\n\n modules[hotScope.sectionTemplatePath] = newSectionTemplate;\n hotReplace('./huron-assets/section.hbs', newSectionTemplate, modules);\n });\n\n // Hot Module Replacement for data store\n module.hot.accept('./huron-store.js', () => {\n updateStore(require('./huron-store.js')); // eslint-disable-line global-require, import/no-unresolved\n });\n}\n\nfunction hotReplace(key, module, newModules) {\n insert.modules = newModules;\n if (key === _huronStore2.default.sectionTemplatePath) {\n insert.cycleSections();\n } else {\n insert.inserted = [];\n insert.loadModule(key, module, false);\n }\n}\n\nfunction updateStore(newStore) {\n insert.store = newStore;\n}" /***/ }), /* 21 */ -/* no static exports found */ -/* all exports used */ -/*!****************************!*\ - !*** external "commander" ***! - \****************************/ /***/ (function(module, exports) { -eval("module.exports = require(\"commander\");//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjEuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vZXh0ZXJuYWwgXCJjb21tYW5kZXJcIj83NTczIl0sInNvdXJjZXNDb250ZW50IjpbIm1vZHVsZS5leHBvcnRzID0gcmVxdWlyZShcImNvbW1hbmRlclwiKTtcblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyBleHRlcm5hbCBcImNvbW1hbmRlclwiXG4vLyBtb2R1bGUgaWQgPSAyMVxuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwibWFwcGluZ3MiOiJBQUFBIiwic291cmNlUm9vdCI6IiJ9"); +module.exports = require("commander"); /***/ }), /* 22 */ -/* no static exports found */ -/* all exports used */ -/*!***********************!*\ - !*** external "gaze" ***! - \***********************/ /***/ (function(module, exports) { -eval("module.exports = require(\"gaze\");//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjIuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vZXh0ZXJuYWwgXCJnYXplXCI/ZjIxOCJdLCJzb3VyY2VzQ29udGVudCI6WyJtb2R1bGUuZXhwb3J0cyA9IHJlcXVpcmUoXCJnYXplXCIpO1xuXG5cbi8vLy8vLy8vLy8vLy8vLy8vL1xuLy8gV0VCUEFDSyBGT09URVJcbi8vIGV4dGVybmFsIFwiZ2F6ZVwiXG4vLyBtb2R1bGUgaWQgPSAyMlxuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwibWFwcGluZ3MiOiJBQUFBIiwic291cmNlUm9vdCI6IiJ9"); +module.exports = require("gaze"); /***/ }), /* 23 */ -/* no static exports found */ -/* all exports used */ -/*!**************************************!*\ - !*** external "html-webpack-plugin" ***! - \**************************************/ /***/ (function(module, exports) { -eval("module.exports = require(\"html-webpack-plugin\");//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjMuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vZXh0ZXJuYWwgXCJodG1sLXdlYnBhY2stcGx1Z2luXCI/MThlYyJdLCJzb3VyY2VzQ29udGVudCI6WyJtb2R1bGUuZXhwb3J0cyA9IHJlcXVpcmUoXCJodG1sLXdlYnBhY2stcGx1Z2luXCIpO1xuXG5cbi8vLy8vLy8vLy8vLy8vLy8vL1xuLy8gV0VCUEFDSyBGT09URVJcbi8vIGV4dGVybmFsIFwiaHRtbC13ZWJwYWNrLXBsdWdpblwiXG4vLyBtb2R1bGUgaWQgPSAyM1xuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwibWFwcGluZ3MiOiJBQUFBIiwic291cmNlUm9vdCI6IiJ9"); +module.exports = require("html-webpack-plugin"); /***/ }), /* 24 */ -/* no static exports found */ -/* all exports used */ -/*!****************************!*\ - !*** external "immutable" ***! - \****************************/ /***/ (function(module, exports) { -eval("module.exports = require(\"immutable\");//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjQuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vZXh0ZXJuYWwgXCJpbW11dGFibGVcIj8xZDIwIl0sInNvdXJjZXNDb250ZW50IjpbIm1vZHVsZS5leHBvcnRzID0gcmVxdWlyZShcImltbXV0YWJsZVwiKTtcblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyBleHRlcm5hbCBcImltbXV0YWJsZVwiXG4vLyBtb2R1bGUgaWQgPSAyNFxuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwibWFwcGluZ3MiOiJBQUFBIiwic291cmNlUm9vdCI6IiJ9"); +module.exports = require("immutable"); /***/ }), /* 25 */ -/* no static exports found */ -/* all exports used */ -/*!**********************!*\ - !*** external "kss" ***! - \**********************/ /***/ (function(module, exports) { -eval("module.exports = require(\"kss\");//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjUuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vZXh0ZXJuYWwgXCJrc3NcIj9jZDAyIl0sInNvdXJjZXNDb250ZW50IjpbIm1vZHVsZS5leHBvcnRzID0gcmVxdWlyZShcImtzc1wiKTtcblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyBleHRlcm5hbCBcImtzc1wiXG4vLyBtb2R1bGUgaWQgPSAyNVxuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwibWFwcGluZ3MiOiJBQUFBIiwic291cmNlUm9vdCI6IiJ9"); +module.exports = require("kss"); /***/ }), /* 26 */ -/* no static exports found */ -/* all exports used */ -/*!*********************************!*\ - !*** external "lodash/isEqual" ***! - \*********************************/ /***/ (function(module, exports) { -eval("module.exports = require(\"lodash/isEqual\");//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjYuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vZXh0ZXJuYWwgXCJsb2Rhc2gvaXNFcXVhbFwiP2NiNTIiXSwic291cmNlc0NvbnRlbnQiOlsibW9kdWxlLmV4cG9ydHMgPSByZXF1aXJlKFwibG9kYXNoL2lzRXF1YWxcIik7XG5cblxuLy8vLy8vLy8vLy8vLy8vLy8vXG4vLyBXRUJQQUNLIEZPT1RFUlxuLy8gZXh0ZXJuYWwgXCJsb2Rhc2gvaXNFcXVhbFwiXG4vLyBtb2R1bGUgaWQgPSAyNlxuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwibWFwcGluZ3MiOiJBQUFBIiwic291cmNlUm9vdCI6IiJ9"); +module.exports = require("lodash/isEqual"); /***/ }), /* 27 */ -/* no static exports found */ -/* all exports used */ -/*!**********************!*\ - !*** external "opn" ***! - \**********************/ /***/ (function(module, exports) { -eval("module.exports = require(\"opn\");//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjcuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vZXh0ZXJuYWwgXCJvcG5cIj82MDBmIl0sInNvdXJjZXNDb250ZW50IjpbIm1vZHVsZS5leHBvcnRzID0gcmVxdWlyZShcIm9wblwiKTtcblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyBleHRlcm5hbCBcIm9wblwiXG4vLyBtb2R1bGUgaWQgPSAyN1xuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwibWFwcGluZ3MiOiJBQUFBIiwic291cmNlUm9vdCI6IiJ9"); +module.exports = require("opn"); /***/ }), /* 28 */ -/* no static exports found */ -/* all exports used */ -/*!**********************!*\ - !*** external "url" ***! - \**********************/ /***/ (function(module, exports) { -eval("module.exports = require(\"url\");//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjguanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vZXh0ZXJuYWwgXCJ1cmxcIj9jYWVjIl0sInNvdXJjZXNDb250ZW50IjpbIm1vZHVsZS5leHBvcnRzID0gcmVxdWlyZShcInVybFwiKTtcblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyBleHRlcm5hbCBcInVybFwiXG4vLyBtb2R1bGUgaWQgPSAyOFxuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwibWFwcGluZ3MiOiJBQUFBIiwic291cmNlUm9vdCI6IiJ9"); +module.exports = require("url"); /***/ }), /* 29 */ -/* no static exports found */ -/* all exports used */ -/*!*************************************!*\ - !*** external "webpack-dev-server" ***! - \*************************************/ /***/ (function(module, exports) { -eval("module.exports = require(\"webpack-dev-server\");//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjkuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vZXh0ZXJuYWwgXCJ3ZWJwYWNrLWRldi1zZXJ2ZXJcIj8xYmVhIl0sInNvdXJjZXNDb250ZW50IjpbIm1vZHVsZS5leHBvcnRzID0gcmVxdWlyZShcIndlYnBhY2stZGV2LXNlcnZlclwiKTtcblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyBleHRlcm5hbCBcIndlYnBhY2stZGV2LXNlcnZlclwiXG4vLyBtb2R1bGUgaWQgPSAyOVxuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwibWFwcGluZ3MiOiJBQUFBIiwic291cmNlUm9vdCI6IiJ9"); +module.exports = require("webpack-dev-server"); /***/ }), /* 30 */ -/* no static exports found */ -/* all exports used */ -/*!*****************************!*\ - !*** multi ./src/cli/index ***! - \*****************************/ /***/ (function(module, exports, __webpack_require__) { -module.exports = __webpack_require__(/*! ./src/cli/index */9); - - -/***/ }), -/* 31 */ -/* no static exports found */ -/* all exports used */ -/*!**********************************************************************!*\ - !*** ./~/raw-loader!./~/babel-loader/lib!./templates/hotTemplate.js ***! - \**********************************************************************/ -/***/ (function(module, exports) { +module.exports = __webpack_require__(9); -eval("module.exports = \"'use strict';\\n\\nvar _huronStore = require('./huron-store');\\n\\nvar _huronStore2 = _interopRequireDefault(_huronStore);\\n\\nvar _insertNodes = require('./insertNodes');\\n\\nvar _insertNodes2 = _interopRequireDefault(_insertNodes);\\n\\nvar _section = require('./section.hbs');\\n\\nvar _section2 = _interopRequireDefault(_section);\\n\\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\\n\\n/* eslint-enable */\\n\\nconst assets = require.context(hotScope.requirePath, true, hotScope.requireRegex); /* globals requirePath, requireRegex, sectionTemplatePath */\\n\\n// NOTE: This is not a normal JS file! It is pulled in by the CLI as a string\\n// and prepended to the browser script after replacing anything referenced via `hotScope[variable]`\\n// with CLI arguments or config properties passed in by the user.\\n\\n/* eslint-disable */\\n\\nconst modules = {};\\n\\nmodules[hotScope.sectionTemplatePath] = _section2.default;\\n\\nassets.keys().forEach(key => {\\n modules[key] = assets(key);\\n});\\n\\nconst insert = new _insertNodes2.default(modules, _huronStore2.default);\\n\\nif (module.hot) {\\n // Hot Module Replacement for huron components (json, hbs, html)\\n module.hot.accept(assets.id, () => {\\n const newAssets = require.context(hotScope.requirePath, true, hotScope.requireRegex);\\n const newModules = newAssets.keys().map(key => [key, newAssets(key)]).filter(newModule => modules[newModule[0]] !== newModule[1]);\\n\\n updateStore(require('./huron-store.js')); // eslint-disable-line global-require, import/no-unresolved\\n newModules.forEach(module => {\\n modules[module[0]] = module[1];\\n hotReplace(module[0], module[1], modules);\\n });\\n });\\n\\n // Hot Module Replacement for sections template\\n module.hot.accept('./section.hbs', () => {\\n const newSectionTemplate = require('./section.hbs'); // eslint-disable-line global-require, import/no-unresolved\\n\\n modules[hotScope.sectionTemplatePath] = newSectionTemplate;\\n hotReplace('./huron-assets/section.hbs', newSectionTemplate, modules);\\n });\\n\\n // Hot Module Replacement for data store\\n module.hot.accept('./huron-store.js', () => {\\n updateStore(require('./huron-store.js')); // eslint-disable-line global-require, import/no-unresolved\\n });\\n}\\n\\nfunction hotReplace(key, module, newModules) {\\n insert.modules = newModules;\\n if (key === _huronStore2.default.sectionTemplatePath) {\\n insert.cycleSections();\\n } else {\\n insert.inserted = [];\\n insert.loadModule(key, module, false);\\n }\\n}\\n\\nfunction updateStore(newStore) {\\n insert.store = newStore;\\n}\"//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMzEuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi90ZW1wbGF0ZXMvaG90VGVtcGxhdGUuanM/N2JiZSJdLCJzb3VyY2VzQ29udGVudCI6WyJtb2R1bGUuZXhwb3J0cyA9IFwiJ3VzZSBzdHJpY3QnO1xcblxcbnZhciBfaHVyb25TdG9yZSA9IHJlcXVpcmUoJy4vaHVyb24tc3RvcmUnKTtcXG5cXG52YXIgX2h1cm9uU3RvcmUyID0gX2ludGVyb3BSZXF1aXJlRGVmYXVsdChfaHVyb25TdG9yZSk7XFxuXFxudmFyIF9pbnNlcnROb2RlcyA9IHJlcXVpcmUoJy4vaW5zZXJ0Tm9kZXMnKTtcXG5cXG52YXIgX2luc2VydE5vZGVzMiA9IF9pbnRlcm9wUmVxdWlyZURlZmF1bHQoX2luc2VydE5vZGVzKTtcXG5cXG52YXIgX3NlY3Rpb24gPSByZXF1aXJlKCcuL3NlY3Rpb24uaGJzJyk7XFxuXFxudmFyIF9zZWN0aW9uMiA9IF9pbnRlcm9wUmVxdWlyZURlZmF1bHQoX3NlY3Rpb24pO1xcblxcbmZ1bmN0aW9uIF9pbnRlcm9wUmVxdWlyZURlZmF1bHQob2JqKSB7IHJldHVybiBvYmogJiYgb2JqLl9fZXNNb2R1bGUgPyBvYmogOiB7IGRlZmF1bHQ6IG9iaiB9OyB9XFxuXFxuLyogZXNsaW50LWVuYWJsZSAqL1xcblxcbmNvbnN0IGFzc2V0cyA9IHJlcXVpcmUuY29udGV4dChob3RTY29wZS5yZXF1aXJlUGF0aCwgdHJ1ZSwgaG90U2NvcGUucmVxdWlyZVJlZ2V4KTsgLyogZ2xvYmFscyByZXF1aXJlUGF0aCwgcmVxdWlyZVJlZ2V4LCBzZWN0aW9uVGVtcGxhdGVQYXRoICovXFxuXFxuLy8gTk9URTogVGhpcyBpcyBub3QgYSBub3JtYWwgSlMgZmlsZSEgSXQgaXMgcHVsbGVkIGluIGJ5IHRoZSBDTEkgYXMgYSBzdHJpbmdcXG4vLyBhbmQgcHJlcGVuZGVkIHRvIHRoZSBicm93c2VyIHNjcmlwdCBhZnRlciByZXBsYWNpbmcgYW55dGhpbmcgcmVmZXJlbmNlZCB2aWEgYGhvdFNjb3BlW3ZhcmlhYmxlXWBcXG4vLyB3aXRoIENMSSBhcmd1bWVudHMgb3IgY29uZmlnIHByb3BlcnRpZXMgcGFzc2VkIGluIGJ5IHRoZSB1c2VyLlxcblxcbi8qIGVzbGludC1kaXNhYmxlICovXFxuXFxuY29uc3QgbW9kdWxlcyA9IHt9O1xcblxcbm1vZHVsZXNbaG90U2NvcGUuc2VjdGlvblRlbXBsYXRlUGF0aF0gPSBfc2VjdGlvbjIuZGVmYXVsdDtcXG5cXG5hc3NldHMua2V5cygpLmZvckVhY2goa2V5ID0+IHtcXG4gIG1vZHVsZXNba2V5XSA9IGFzc2V0cyhrZXkpO1xcbn0pO1xcblxcbmNvbnN0IGluc2VydCA9IG5ldyBfaW5zZXJ0Tm9kZXMyLmRlZmF1bHQobW9kdWxlcywgX2h1cm9uU3RvcmUyLmRlZmF1bHQpO1xcblxcbmlmIChtb2R1bGUuaG90KSB7XFxuICAvLyBIb3QgTW9kdWxlIFJlcGxhY2VtZW50IGZvciBodXJvbiBjb21wb25lbnRzIChqc29uLCBoYnMsIGh0bWwpXFxuICBtb2R1bGUuaG90LmFjY2VwdChhc3NldHMuaWQsICgpID0+IHtcXG4gICAgY29uc3QgbmV3QXNzZXRzID0gcmVxdWlyZS5jb250ZXh0KGhvdFNjb3BlLnJlcXVpcmVQYXRoLCB0cnVlLCBob3RTY29wZS5yZXF1aXJlUmVnZXgpO1xcbiAgICBjb25zdCBuZXdNb2R1bGVzID0gbmV3QXNzZXRzLmtleXMoKS5tYXAoa2V5ID0+IFtrZXksIG5ld0Fzc2V0cyhrZXkpXSkuZmlsdGVyKG5ld01vZHVsZSA9PiBtb2R1bGVzW25ld01vZHVsZVswXV0gIT09IG5ld01vZHVsZVsxXSk7XFxuXFxuICAgIHVwZGF0ZVN0b3JlKHJlcXVpcmUoJy4vaHVyb24tc3RvcmUuanMnKSk7IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgZ2xvYmFsLXJlcXVpcmUsIGltcG9ydC9uby11bnJlc29sdmVkXFxuICAgIG5ld01vZHVsZXMuZm9yRWFjaChtb2R1bGUgPT4ge1xcbiAgICAgIG1vZHVsZXNbbW9kdWxlWzBdXSA9IG1vZHVsZVsxXTtcXG4gICAgICBob3RSZXBsYWNlKG1vZHVsZVswXSwgbW9kdWxlWzFdLCBtb2R1bGVzKTtcXG4gICAgfSk7XFxuICB9KTtcXG5cXG4gIC8vIEhvdCBNb2R1bGUgUmVwbGFjZW1lbnQgZm9yIHNlY3Rpb25zIHRlbXBsYXRlXFxuICBtb2R1bGUuaG90LmFjY2VwdCgnLi9zZWN0aW9uLmhicycsICgpID0+IHtcXG4gICAgY29uc3QgbmV3U2VjdGlvblRlbXBsYXRlID0gcmVxdWlyZSgnLi9zZWN0aW9uLmhicycpOyAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIGdsb2JhbC1yZXF1aXJlLCBpbXBvcnQvbm8tdW5yZXNvbHZlZFxcblxcbiAgICBtb2R1bGVzW2hvdFNjb3BlLnNlY3Rpb25UZW1wbGF0ZVBhdGhdID0gbmV3U2VjdGlvblRlbXBsYXRlO1xcbiAgICBob3RSZXBsYWNlKCcuL2h1cm9uLWFzc2V0cy9zZWN0aW9uLmhicycsIG5ld1NlY3Rpb25UZW1wbGF0ZSwgbW9kdWxlcyk7XFxuICB9KTtcXG5cXG4gIC8vIEhvdCBNb2R1bGUgUmVwbGFjZW1lbnQgZm9yIGRhdGEgc3RvcmVcXG4gIG1vZHVsZS5ob3QuYWNjZXB0KCcuL2h1cm9uLXN0b3JlLmpzJywgKCkgPT4ge1xcbiAgICB1cGRhdGVTdG9yZShyZXF1aXJlKCcuL2h1cm9uLXN0b3JlLmpzJykpOyAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIGdsb2JhbC1yZXF1aXJlLCBpbXBvcnQvbm8tdW5yZXNvbHZlZFxcbiAgfSk7XFxufVxcblxcbmZ1bmN0aW9uIGhvdFJlcGxhY2Uoa2V5LCBtb2R1bGUsIG5ld01vZHVsZXMpIHtcXG4gIGluc2VydC5tb2R1bGVzID0gbmV3TW9kdWxlcztcXG4gIGlmIChrZXkgPT09IF9odXJvblN0b3JlMi5kZWZhdWx0LnNlY3Rpb25UZW1wbGF0ZVBhdGgpIHtcXG4gICAgaW5zZXJ0LmN5Y2xlU2VjdGlvbnMoKTtcXG4gIH0gZWxzZSB7XFxuICAgIGluc2VydC5pbnNlcnRlZCA9IFtdO1xcbiAgICBpbnNlcnQubG9hZE1vZHVsZShrZXksIG1vZHVsZSwgZmFsc2UpO1xcbiAgfVxcbn1cXG5cXG5mdW5jdGlvbiB1cGRhdGVTdG9yZShuZXdTdG9yZSkge1xcbiAgaW5zZXJ0LnN0b3JlID0gbmV3U3RvcmU7XFxufVwiXG5cblxuLy8vLy8vLy8vLy8vLy8vLy8vXG4vLyBXRUJQQUNLIEZPT1RFUlxuLy8gLi9+L3Jhdy1sb2FkZXIhLi9+L2JhYmVsLWxvYWRlci9saWIhLi90ZW1wbGF0ZXMvaG90VGVtcGxhdGUuanNcbi8vIG1vZHVsZSBpZCA9IDMxXG4vLyBtb2R1bGUgY2h1bmtzID0gMCJdLCJtYXBwaW5ncyI6IkFBQUEiLCJzb3VyY2VSb290IjoiIn0="); /***/ }) -/******/ ]); \ No newline at end of file +/******/ ]); +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/dist/cli/index.js.map b/dist/cli/index.js.map new file mode 100644 index 0000000..63d085f --- /dev/null +++ b/dist/cli/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sources":["webpack:///webpack/bootstrap 03d06f67921b62e57b24","webpack:///external \"path\"","webpack:///src/cli/utils.js","webpack:///external \"chalk\"","webpack:///external \"fs-extra\"","webpack:///src/cli/parseArgs.js","webpack:///external \"webpack\"","webpack:///src/cli/defaultStore.js","webpack:///src/cli/handleTemplates.js","webpack:///src/cli/requireTemplates.js","webpack:///src/cli/index.js","webpack:///config/devServer.config.js","webpack:///src/cli/actions.js","webpack:///src/cli/fileWatcher.js","webpack:///src/cli/generateConfig.js","webpack:///src/cli/handleHTML.js","webpack:///src/cli/handleKSS.js","webpack:///src/cli/requireExternal.js","webpack:///src/cli/server.js","webpack:///src/defaultConfig/huron.config.js","webpack:///src/defaultConfig/webpack.config.js","webpack:///./templates/hotTemplate.js","webpack:///external \"commander\"","webpack:///external \"gaze\"","webpack:///external \"html-webpack-plugin\"","webpack:///external \"immutable\"","webpack:///external \"kss\"","webpack:///external \"lodash/isEqual\"","webpack:///external \"opn\"","webpack:///external \"url\"","webpack:///external \"webpack-dev-server\""],"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// identity function for calling harmony imports with the correct context\n \t__webpack_require__.i = function(value) { return value; };\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 = 30);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap 03d06f67921b62e57b24","module.exports = require(\"path\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"path\"\n// module id = 0\n// module chunks = 0","/** @module cli/utilities */\nimport path from 'path';\nimport fs from 'fs-extra';\nimport chalk from 'chalk';\n\nconst cwd = process.cwd(); // Current working directory\n\n/**\n * Ensure predictable data structure for KSS section data\n *\n * @function normalizeSectionData\n * @param {object} section - section data\n * @return {object} section data\n */\nexport function normalizeSectionData(section) {\n const data = section.data || section;\n\n if (!data.referenceURI || '' === data.referenceURI) {\n data.referenceURI = section.referenceURI();\n }\n\n return data;\n}\n\n/**\n * Ensure predictable data structure for KSS section data\n *\n * @function writeSectionData\n * @param {object} store - data store\n * @param {object} section - section data\n * @param {string} sectionPath - output destination for section data file\n */\nexport function writeSectionData(store, section, sectionPath = false) {\n let outputPath = sectionPath;\n let sectionFileInfo;\n\n if (!outputPath && {}.hasOwnProperty.call(section, 'kssPath')) {\n sectionFileInfo = path.parse(section.kssPath);\n outputPath = path.join(\n sectionFileInfo.dir,\n `${sectionFileInfo.name}.json`\n );\n }\n\n // Output section data\n if (outputPath) {\n return writeFile(\n section.referenceURI,\n 'section',\n outputPath,\n JSON.stringify(section),\n store\n );\n }\n\n console.warn( // eslint-disable-line no-console\n chalk.red(`Failed to write section data for ${section.referenceURI}`)\n );\n return false;\n}\n\n/**\n * Find .json from a template file or vice versa\n *\n * @function getTemplateDataPair\n * @param {object} file - file object from path.parse()\n * @param {object} section - KSS section data\n * @return {string} relative path to module JSON file\n */\nexport function getTemplateDataPair(file, section, store) {\n const huron = store.get('config');\n const kssDir = matchKssDir(file.dir, huron);\n\n if (kssDir) {\n const componentPath = path.relative(\n path.resolve(cwd, kssDir),\n file.dir\n );\n const partnerType = '.json' === file.ext ? 'template' : 'data';\n const partnerExt = '.json' === file.ext ?\n huron.get('templates').extension :\n '.json';\n\n const pairPath = path.join(\n componentPath,\n generateFilename(\n section.referenceURI,\n partnerType,\n partnerExt,\n store\n )\n );\n\n return `./${pairPath}`;\n }\n\n return false;\n}\n\n/**\n * Normalize a section title for use as a filename\n *\n * @function normalizeHeader\n * @param {string} header - section header extracted from KSS documentation\n * @return {string} modified header, lowercase and words separated by dash\n */\nexport function normalizeHeader(header) {\n return header\n .toLowerCase()\n .replace(/\\s?\\W\\s?/g, '-');\n}\n\n/**\n * Wrap html in required template tags\n *\n * @function wrapMarkup\n * @param {string} content - html or template markup\n * @param {string} templateId - id of template (should be section reference)\n * @return {string} modified HTML\n */\nexport function wrapMarkup(content, templateId) {\n return `\n\n\\n`;\n}\n\n/**\n * Generate a filename based on referenceURI, type and file object\n *\n * @function generateFilename\n * @param {string} id - The name of the file (with extension).\n * @param {string} type - the type of file output\n * @param {object} ext - file extension\n * @param {store} store - data store\n * @return {string} Path to output file, relative to ouput dir (can be use in require statements)\n */\nexport function generateFilename(id, type, ext, store) {\n // Type of file and its corresponding extension(s)\n const types = store.get('types');\n const outputExt = '.scss' !== ext ? ext : '.html';\n\n /* eslint-disable */\n if (-1 === types.indexOf(type)) {\n console.log(`Huron data ${type} does not exist`);\n return false;\n }\n /* eslint-enable */\n\n return `${id}-${type}${outputExt}`;\n}\n\n/**\n * Copy an HTML file into the huron output directory.\n *\n * @function writeFile\n * @param {string} id - The name of the file (with extension).\n * @param {string} content - The content of the file to write.\n * @param {string} type - the type of file output\n * @param {object} store - The data store\n * @return {string} Path to output file, relative to ouput dir (can be use in require statements)\n */\nexport function writeFile(id, type, filepath, content, store) {\n const huron = store.get('config');\n const file = path.parse(filepath);\n const filename = generateFilename(id, type, file.ext, store);\n const kssDir = matchKssDir(filepath, huron);\n\n if (kssDir) {\n const componentPath = path.relative(\n path.resolve(cwd, kssDir),\n file.dir\n );\n const outputRelative = path.join(\n huron.get('output'),\n componentPath,\n `${filename}`\n );\n const outputPath = path.resolve(cwd, huron.get('root'), outputRelative);\n let newContent = content;\n\n if ('data' !== type && 'section' !== type) {\n newContent = wrapMarkup(content, id);\n }\n\n try {\n fs.outputFileSync(outputPath, newContent);\n console.log(chalk.green(`Writing ${outputRelative}`)); // eslint-disable-line no-console\n } catch (e) {\n console.log(chalk.red(`Failed to write ${outputRelative}`)); // eslint-disable-line no-console\n }\n\n return `./${outputRelative.replace(`${huron.get('output')}/`, '')}`;\n }\n\n return false;\n}\n\n/**\n * Delete a file in the huron output directory\n *\n * @function removeFile\n * @param {string} filename - The name of the file (with extension).\n * @param {object} store - The data store\n * @return {string} Path to output file, relative to ouput dir (can be use in require statements)\n */\nexport function removeFile(id, type, filepath, store) {\n const huron = store.get('config');\n const file = path.parse(filepath);\n const filename = generateFilename(id, type, file.ext, store);\n const kssDir = matchKssDir(filepath, huron);\n\n if (kssDir) {\n const componentPath = path.relative(\n path.resolve(cwd, kssDir),\n file.dir\n );\n const outputRelative = path.join(\n huron.get('output'),\n componentPath,\n `${filename}`\n );\n const outputPath = path.resolve(cwd, huron.get('root'), outputRelative);\n\n try {\n fs.removeSync(outputPath);\n console.log(chalk.green(`Removing ${outputRelative}`)); // eslint-disable-line no-console\n } catch (e) {\n console.log( // eslint-disable-line no-console\n chalk.red(`${outputRelative} does not exist or cannot be deleted`)\n );\n }\n\n return `./${outputRelative.replace(`${huron.get('output')}/`, '')}`;\n }\n\n return false;\n}\n\n/**\n * Write a template for sections\n *\n * @function writeSectionTemplate\n * @param {string} filepath - the original template file\n * @param {object} store - data store\n * @return {object} updated store\n */\nexport function writeSectionTemplate(filepath, store) {\n const huron = store.get('config');\n const sectionTemplate = wrapMarkup(fs.readFileSync(filepath, 'utf8'));\n const componentPath = './huron-assets/section.hbs';\n const output = path.join(\n cwd,\n huron.get('root'),\n componentPath\n );\n\n // Move huron script and section template into huron root\n fs.outputFileSync(output, sectionTemplate);\n console.log(chalk.green(`writing section template to ${output}`)); // eslint-disable-line no-console\n\n return store.set('sectionTemplatePath', componentPath);\n}\n\n/**\n * Request for section data based on section reference\n *\n * @function writeSectionTemplate\n * @param {string} search - key on which to match section\n * @param {field} string - field in which to look to determine section\n * @param {obj} store - sections memory store\n */\nexport function getSection(search, field, store) {\n const sectionValues = store\n .getIn(['sections', 'sectionsByPath'])\n .valueSeq();\n let selectedSection = false;\n\n if (field) {\n selectedSection = sectionValues\n .filter((value) => value[field] === search)\n .get(0);\n } else {\n selectedSection = store.getIn(['sections', 'sectionsByPath', search]);\n }\n\n return selectedSection;\n}\n\n/**\n * Find which configured KSS directory a filepath exists in\n *\n * @function matchKssDir\n * @param {string} filepath - filepath to search for\n * @param {object} huron - huron configuration\n * @return {string} kssMatch - relative path to KSS directory\n */\nexport function matchKssDir(filepath, huron) {\n const kssSource = huron.get('kss');\n // Include forward slash in our test to make sure we're matchin a directory, not a file extension\n const kssMatch = kssSource.filter((dir) => filepath.includes(`/${dir}`));\n\n if (kssMatch.length) {\n return kssMatch[0];\n }\n\n return false;\n}\n\n/**\n * Merge JSON files for css modules classnames in a provided directory\n *\n * @function mergeClassnameJSON\n * @param {string} directory - directory containing classname JSON files\n *\n * @return {object} classnamesMerged - merged classnames. contents of each JSON file is nested within\n * the returned object by filename. (e.g. article.json -> { article: {...json contents}})\n */\nexport function mergeClassnameJSON(directory) {\n let files;\n\n // Try to read through classnames directory\n try {\n files = fs.readdirSync(directory);\n } catch (e) {\n console.warn(chalk.red(e));\n return {};\n }\n\n // Merge classname json files\n const classNamesMerged = files.reduce((acc, file) => {\n const fileInfo = path.parse(file);\n let classNames = {};\n\n if ('.json' === fileInfo.ext) {\n try {\n const contents = fs.readFileSync(\n path.join(directory, file),\n 'utf8'\n );\n classNames = JSON.parse(contents);\n } catch (e) {\n console.warn(chalk.red(e));\n return classNames;\n }\n }\n\n return Object.assign({}, acc, { [fileInfo.name]: classNames });\n }, {});\n\n return classNamesMerged;\n}\n\n/**\n * Remove the trailing slash from a provided directory\n *\n * @function removeTrailingSlash\n * @param {string} directory - directory path\n * @return {string} directory - directory path with trailing slash removed\n */\nexport function removeTrailingSlash(directory) {\n if ('/' === directory.slice(-1)) {\n return directory.slice(0, -1);\n }\n\n return directory;\n}\n\n\n\n// WEBPACK FOOTER //\n// src/cli/utils.js","module.exports = require(\"chalk\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"chalk\"\n// module id = 2\n// module chunks = 0","module.exports = require(\"fs-extra\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"fs-extra\"\n// module id = 3\n// module chunks = 0","/** @module cli/parse-arguments */\n/* eslint-disable space-unary-ops */\n\nimport program from 'commander';\nimport path from 'path';\n\n// Requires\n/** @global */\n\n/**\n * Process huron CLI arguments\n *\n * @function parseArgs\n * @example node huron/dist/cli/huron-cli.js --config 'client/config/webpack.config.js' --production\n */\nfunction parseArgs() {\n const envArg = {};\n\n process.argv = process.argv.filter((arg) => {\n if (-1 !== arg.indexOf('--env')) {\n const envParts = arg\n .split('.')[1]\n .split('=');\n\n envArg[envParts[0]] = envParts[1] || true;\n return false;\n }\n\n return true;\n });\n\n program.version('1.0.1')\n .option(\n '-c, --huron-config [huronConfig]',\n '[huronConfig] for all huron options',\n path.resolve(__dirname, '../defaultConfig/huron.config.js')\n )\n .option(\n '-w, --webpack-config [webpackConfig]',\n '[webpackConfig] for all webpack options',\n path.resolve(__dirname, '../defaultConfig/webpack.config.js')\n )\n .option('-p, --production', 'compile assets once for production');\n\n program.env = envArg;\n\n // Only parse if we're not running tests\n if (\n ! process.env.npm_lifecycle_event ||\n 'test' !== process.env.npm_lifecycle_event\n ) {\n program.parse(process.argv);\n }\n}\n\nparseArgs();\n/* eslint-enable */\n\nexport default program;\n\n\n\n// WEBPACK FOOTER //\n// src/cli/parseArgs.js","module.exports = require(\"webpack\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"webpack\"\n// module id = 5\n// module chunks = 0","import { Map } from 'immutable';\n\nimport generateConfig from './generateConfig';\nimport { mergeClassnameJSON } from './utils';\n// Create initial data structure\n\n// Merge Huron default webpack config with user config\nconst config = generateConfig();\n\n// Make sure the kss option is represented as an array\nconfig.huron.kss = [].concat(config.huron.kss);\n\n/* eslint-disable */\n/**\n * Initial structure for immutable data store\n *\n * @global\n */\nconst defaultStore = Map({\n types: [\n 'template',\n 'data',\n 'description',\n 'section',\n 'prototype',\n 'sections-template',\n ],\n config: Map(config.huron),\n classNames: mergeClassnameJSON(config.huron.classNames),\n sections: Map({\n sectionsByPath: Map({}),\n sectionsByURI: Map({}),\n sorted: {},\n }),\n templates: Map({}),\n prototypes: Map({}),\n sectionTemplatePath: '',\n referenceDelimiter: '.',\n});\n/* eslint-enable */\n\nexport { defaultStore, config };\n\n\n\n// WEBPACK FOOTER //\n// src/cli/defaultStore.js","/** @module cli/template-handler */\nimport path from 'path';\nimport fs from 'fs-extra';\nimport chalk from 'chalk';\n\nimport * as utils from './utils';\n\n/**\n * Handle update of a template or data (json) file\n *\n * @function updateTemplate\n * @param {string} filepath - filepath of changed file (comes from gaze)\n * @param {object} section - contains KSS section data\n * @param {object} store - memory store\n * @return {object} updated memory store\n */\nexport function updateTemplate(filepath, section, store) {\n const file = path.parse(filepath);\n const pairPath = utils.getTemplateDataPair(file, section, store);\n const type = '.json' === file.ext ? 'data' : 'template';\n const newSection = section;\n const newStore = store;\n let content = false;\n\n try {\n content = fs.readFileSync(filepath, 'utf8');\n } catch (e) {\n console.log(chalk.red(`${filepath} does not exist`));\n }\n\n if (content) {\n const requirePath = utils.writeFile(\n newSection.referenceURI,\n type,\n filepath,\n content,\n newStore\n );\n newSection[`${type}Path`] = requirePath;\n\n if ('template' === type) {\n newSection.templateContent = content;\n\n // Rewrite section data with template content\n newSection.sectionPath = utils.writeSectionData(newStore, newSection);\n }\n\n return newStore\n .setIn(\n ['templates', requirePath],\n pairPath\n )\n .setIn(\n ['sections', 'sectionsByPath', newSection.kssPath],\n newSection\n )\n .setIn(\n ['sections', 'sectionsByURI', newSection.referenceURI],\n newSection\n );\n }\n\n return newStore;\n}\n\n/**\n * Handle removal of a template or data (json) file\n *\n * @function deleteTemplate\n * @param {string} filepath - filepath of changed file (comes from gaze)\n * @param {object} section - contains KSS section data\n * @param {object} store - memory store\n * @return {object} updated memory store\n */\nexport function deleteTemplate(filepath, section, store) {\n const file = path.parse(filepath);\n const type = '.json' === file.ext ? 'data' : 'template';\n const newSection = section;\n const newStore = store;\n\n // Remove partner\n const requirePath = utils.removeFile(\n newSection.referenceURI,\n type,\n filepath,\n newStore\n );\n delete newSection[`${type}Path`];\n\n return newStore\n .deleteIn(['templates', requirePath])\n .setIn(\n ['sections', 'sectionsByPath', newSection.kssPath],\n newSection\n )\n .setIn(\n ['sections', 'sectionsByURI', newSection.referenceURI],\n newSection\n );\n}\n\n\n\n// WEBPACK FOOTER //\n// src/cli/handleTemplates.js","/** @module cli/require-templates */\nimport path from 'path';\nimport fs from 'fs-extra';\n\n// We need to prepend this to the browser script as a string but still want to transpile it,\n// hence loading it using `raw-loader` so we receive a string from webpack\n/* eslint-disable */\nimport hotTemplate from '!raw-loader!babel-loader!../../templates/hotTemplate';\n/* eslint-enable */\n\nconst cwd = process.cwd();\nconst huronScript = fs.readFileSync(\n path.join(__dirname, '../web/index.js'),\n 'utf8'\n);\n\n/**\n * Write code for requiring all generated huron assets\n *\n * @function requireTemplates\n * @param {object} store - memory store\n */\nexport const requireTemplates = function requireTemplates(store) {\n const huron = store.get('config');\n const outputPath = path.join(cwd, huron.get('root'), 'huron-assets');\n // These will be used to replace strings in the hotTemplate.\n // In order to accurately replace strings but still keep things parseable by eslint and babel,\n // each replaceable value should be referenced in `hotTemplate.js` under the `hotScope` object.\n // For example, if you need to replace a string with a value passed in from the CLI called `userVariable`,\n // you would reference that string in `hotTemplate.js` with `hotScope.userVariable`.\n const hotVariableScope = {\n sectionTemplatePath: `'${huron.get('sectionTemplate')}'`,\n requireRegex: new RegExp(`\\\\.html|\\\\.json|\\\\${\n huron.get('templates').extension\n }$`),\n requirePath: `'../${huron.get('output')}'`,\n };\n const hotTemplateTransformed = Object.keys(hotVariableScope)\n .reduce(\n (acc, curr) => acc.replace(\n new RegExp(`hotScope.${curr}`, 'g'),\n hotVariableScope[curr]\n ), hotTemplate\n );\n\n // Write the contents of this script.\n fs.outputFileSync(\n path.join(outputPath, 'index.js'),\n hotTemplateTransformed\n );\n fs.outputFileSync(\n path.join(outputPath, 'insertNodes.js'),\n huronScript\n );\n};\n\n/**\n * Output entire data store to a JS object and handle if any KSS data has changed\n *\n * @function writeStore\n * @param {object} store - memory store\n * @param {string} changed - filepath of changed KSS section, if applicable\n */\nexport const writeStore = function writeStore(store, newStore = false) {\n const updatedStore = newStore || store;\n const huron = updatedStore.get('config');\n const outputPath = path.join(cwd, huron.get('root'), 'huron-assets');\n\n // Write updated data store\n fs.outputFileSync(\n path.join(outputPath, 'huron-store.js'),\n `module.exports = ${JSON.stringify(updatedStore.toJSON())}`\n );\n};\n\n\n\n\n// WEBPACK FOOTER //\n// src/cli/requireTemplates.js","// Local imports\nimport chalk from 'chalk';\n\nimport {\n initFiles,\n updateFile,\n deleteFile,\n updateClassNames,\n} from './actions';\nimport { requireTemplates, writeStore } from './requireTemplates';\nimport { matchKssDir } from './utils';\nimport program from './parseArgs';\nimport startWebpack from './server';\nimport { defaultStore, config } from './defaultStore';\nimport gaze from './fileWatcher';\n\n/**\n * Initialize data store with files from gaze and original data structure\n *\n * @global\n */\nconst store = initFiles(gaze.watched(), defaultStore);\nconst huron = defaultStore.get('config');\n\nrequireTemplates(store);\nwriteStore(store);\n\nif (!program.production) {\n /** @module cli/gaze */\n let newStore = store;\n\n gaze.on('all', (event, filepath) => {\n newStore = updateClassNames(filepath, newStore);\n writeStore(newStore);\n });\n\n /**\n * Anonymous handler for Gaze 'changed' event indicating a file has changed\n *\n * @callback changed\n * @listens gaze:changed\n * @param {string} filepath - absolute path of changed file\n */\n gaze.on('changed', (filepath) => {\n if (matchKssDir(filepath, huron)) {\n newStore = updateFile(filepath, newStore);\n }\n\n console.log(chalk.green(`${filepath} updated!`));\n });\n\n /**\n * Anonymous handler for Gaze 'added' event indicating a file has been added to the watched directories\n *\n * @callback added\n * @listens gaze:added\n * @param {string} filepath - absolute path of changed file\n */\n gaze.on('added', (filepath) => {\n if (matchKssDir(filepath, huron)) {\n newStore = updateFile(filepath, newStore);\n writeStore(newStore);\n }\n\n console.log(chalk.blue(`${filepath} added!`));\n });\n\n /**\n * Anonymous handler for Gaze 'renamed' event indicating a file has been renamed\n *\n * @callback renamed\n * @listens gaze:renamed\n * @param {string} filepath - absolute path of changed file\n */\n gaze.on('renamed', (newPath, oldPath) => {\n if (matchKssDir(newPath, huron)) {\n newStore = deleteFile(oldPath, newStore);\n newStore = updateFile(newPath, newStore);\n writeStore(newStore);\n }\n\n console.log(chalk.blue(`${newPath} added!`));\n });\n\n /**\n * Anonymous handler for Gaze 'deleted' event indicating a file has been removed\n *\n * @callback deleted\n * @listens gaze:deleted\n * @param {string} filepath - absolute path of changed file\n */\n gaze.on('deleted', (filepath) => {\n if (matchKssDir(filepath, huron)) {\n newStore = deleteFile(filepath, newStore);\n writeStore(newStore);\n }\n\n console.log(chalk.red(`${filepath} deleted`));\n });\n} else {\n gaze.close();\n}\n\n// Start webpack or build for production\nstartWebpack(config);\n\n\n\n// WEBPACK FOOTER //\n// src/cli/index.js","export default (huron) => ({\n hot: true,\n quiet: false,\n noInfo: false,\n stats: {\n colors: true,\n hash: false,\n version: false,\n assets: false,\n chunks: false,\n modules: false,\n reasons: false,\n children: false,\n source: false,\n },\n contentBase: huron.root,\n overlay: true,\n publicPath: `http://localhost:${huron.port}/${huron.root}`,\n});\n\n\n\n// WEBPACK FOOTER //\n// config/devServer.config.js","/** @module cli/actions */\n\n// Imports\nimport path from 'path';\nimport chalk from 'chalk';\nimport isEqual from 'lodash/isEqual';\n\nimport {\n updateHTML,\n deleteHTML,\n updatePrototype,\n deletePrototype,\n} from './handleHTML';\nimport { updateTemplate, deleteTemplate } from './handleTemplates';\nimport { updateKSS, deleteKSS } from './handleKSS';\nimport * as utils from './utils';\n\n/**\n * Recursively loop through initial watched files list from Gaze.\n *\n * @param {object} data - object containing directory and file paths\n * @param {object} store - memory store\n * @return {object} newStore - map object of entire data store\n */\nexport function initFiles(data, store, depth = 0) {\n const type = Object.prototype.toString.call(data);\n const huron = store.get('config');\n let newStore = store;\n let info;\n let files;\n\n switch (type) {\n case '[object Object]':\n files = Object.keys(data);\n newStore = files.reduce(\n (prevStore, file) => initFiles(data[file], prevStore, depth),\n newStore\n );\n break;\n\n case '[object Array]':\n newStore = data.reduce(\n (prevStore, file) => initFiles(file, prevStore, depth),\n newStore\n );\n break;\n\n case '[object String]':\n info = path.parse(data);\n\n // Only call update if data is a filepath and it's within the KSS source directory\n if (info.ext && !data.includes(huron.get('classNames'))) {\n newStore = updateFile(data, store);\n }\n break;\n\n default:\n break;\n }\n\n return newStore;\n}\n\n/**\n * Logic for updating and writing file information based on file type (extension)\n *\n * @param {string} filepath - path to updated file. usually passed in from Gaze\n * @param {object} store - memory store\n * @return {object} store - map object of map object of entire data store\n */\nexport function updateFile(filepath, store) {\n const huron = store.get('config');\n const file = path.parse(filepath);\n let field;\n let section;\n\n if (filepath.includes(huron.get('sectionTemplate'))) {\n return utils.writeSectionTemplate(filepath, store);\n }\n\n switch (file.ext) {\n // Plain HTML template, external\n case '.html':\n section = utils.getSection(file.base, 'markup', store);\n\n if (section) {\n return updateHTML(filepath, section, store);\n } else if (\n file.dir.includes('prototypes') &&\n file.name.includes('prototype-')\n ) {\n return updatePrototype(filepath, store);\n }\n\n console.log(chalk.red(`Failed to write file: ${file.name}`));\n break;\n\n // Handlebars template, external\n case huron.get('templates').extension:\n case '.json':\n field = ('.json' === file.ext) ? 'data' : 'markup';\n section = utils.getSection(file.base, field, store);\n\n if (section) {\n return updateTemplate(filepath, section, store);\n }\n\n console.log( // eslint-disable-line no-console\n chalk.red(`Could not find associated KSS section for ${filepath}`)\n );\n break;\n\n // KSS documentation (default extension is `.css`)\n // Will also output a template if markup is inline\n // Note: inline markup does _not_ support handlebars currently\n case huron.get('kssExtension'):\n return updateKSS(filepath, store);\n\n // This should never happen if Gaze is working properly\n default:\n return store;\n }\n\n return store;\n}\n\n/**\n * Logic for deleting file information and files based on file type (extension)\n *\n * @param {string} filepath - path to updated file. usually passed in from Gaze\n * @param {object} store - memory store\n * @return {object} newStore - map object of map object of entire data store\n */\nexport function deleteFile(filepath, store) {\n const huron = store.get('config');\n const file = path.parse(filepath);\n let field = '';\n let section = null;\n let newStore = store;\n\n switch (file.ext) {\n // Plain HTML template, external\n case '.html':\n section = utils.getSection(file.base, 'markup', store);\n\n if (section) {\n newStore = deleteHTML(filepath, section, store);\n } else if (\n file.dir.includes('prototypes') &&\n file.name.includes('prototype-')\n ) {\n newStore = deletePrototype(filepath, store);\n }\n break;\n\n case huron.get('templates').extension:\n case '.json':\n field = ('.json' === file.ext) ? 'data' : 'markup';\n section = utils.getSection(file.base, field, store);\n\n if (section) {\n newStore = deleteTemplate(filepath, section, store);\n }\n break;\n\n case huron.get('kssExtension'):\n section = utils.getSection(filepath, false, store);\n\n if (section) {\n newStore = deleteKSS(filepath, section, store);\n }\n break;\n\n default:\n console.warn( // eslint-disable-line no-console\n chalk.red(`Could not delete: ${file.name}`)\n );\n break;\n }\n\n return newStore;\n}\n\n/**\n * Logic for updating localized classnames from CSS modules\n *\n * @param {string} filepath - path to updated file. usually passed in from Gaze\n * @param {object} store - memory store\n *\n * @return void\n */\nexport function updateClassNames(filepath, store) {\n const classNamesPath = store.getIn(['config', 'classNames']);\n\n if (filepath.includes(classNamesPath)) {\n const oldClassnames = store.get('classNames');\n const newClassnames = utils.mergeClassnameJSON(classNamesPath);\n\n if (!isEqual(oldClassnames, newClassnames)) {\n return store.set('classNames', newClassnames);\n }\n }\n\n return store;\n}\n\n\n\n// WEBPACK FOOTER //\n// src/cli/actions.js","import { Gaze } from 'gaze';\nimport path from 'path';\n\nimport { removeTrailingSlash } from './utils';\nimport { defaultStore } from './defaultStore';\n\n/**\n * Huron configuration object\n *\n * @global\n */\nconst huron = defaultStore.get('config');\n\n/**\n * Available file extensions. Extensions should not include the leading '.'\n *\n * @global\n */\nexport const extensions = [\n huron.get('kssExtension'),\n huron.get('templates').extension,\n 'html',\n 'json',\n].map((extension) => extension.replace('.', ''));\n\n// Generate watch list for Gaze, start gaze\nexport const watchedFiles = [];\n\n// Watch section template\nwatchedFiles.push(path.resolve(huron.get('sectionTemplate')));\n\n// Watch cssmodules classname files (if they exist)\nif (huron.get('classNames')) {\n watchedFiles.push(\n `${path.resolve(huron.get('classNames'))}/*.json`\n );\n}\n\n// Watch all provided kss directories\nhuron.get('kss').forEach((dir) => {\n watchedFiles.push(\n `${removeTrailingSlash(dir)}/**/*.+(${extensions.join('|')})`\n );\n});\n\n/**\n * Gaze instance for watching all files, including KSS, html, hbs/template, and JSON\n *\n * @global\n */\nconst gaze = new Gaze(watchedFiles);\n\nexport default gaze;\n\n\n\n// WEBPACK FOOTER //\n// src/cli/fileWatcher.js","/** @module cli/generate-config */\nimport path from 'path';\nimport url from 'url';\nimport fs from 'fs-extra';\nimport webpack from 'webpack';\nimport HTMLWebpackPlugin from 'html-webpack-plugin';\n\nimport program from './parseArgs';\nimport requireExternal from './requireExternal';\nimport defaultWebpack from '../defaultConfig/webpack.config';\nimport defaultHuron from '../defaultConfig/huron.config';\n\nconst cwd = process.cwd();\n\n// Require configs passed in by user from CLI\nlet defaultConfig = false;\nconst localConfig = requireExternal(\n path.resolve(program.webpackConfig)\n);\nconst localHuron = requireExternal(\n path.resolve(program.huronConfig)\n);\n\n/**\n * Generate a mutant hybrid of the huron default webpack config and your local webpack config\n *\n * @function generateConfig\n * @param {object} config - local webpack config\n * @return {object} newConfig - updated data store\n */\nexport default function generateConfig() {\n let newConfig = localConfig;\n let newHuron = localHuron;\n\n // Execute config function, if provided\n if ('function' === typeof newConfig) {\n newConfig = newConfig(program.env);\n }\n\n // Execute huron config function, if provided\n if ('function' === typeof newHuron) {\n newHuron = newHuron(program.env);\n }\n\n // Merge huron defaults with user settings\n newHuron = Object.assign({}, defaultHuron, newHuron);\n // Use user huron config to modify webpack defaults\n defaultConfig = defaultWebpack(newHuron);\n\n // Set ouput options\n newConfig.output = Object.assign({}, defaultConfig.output, newConfig.output);\n newConfig.output.path = defaultConfig.output.path;\n newConfig.output.publicPath = defaultConfig.output.publicPath;\n\n // configure entries\n newConfig = configureEntries(newHuron, newConfig);\n\n // configure plugins\n newConfig = configurePlugins(newHuron, newConfig);\n\n // configure loaders\n newConfig = configureLoaders(newHuron, newConfig);\n\n // Add HTMLWebpackPlugin for each configured prototype\n newConfig = configurePrototypes(newHuron, newConfig);\n\n // Remove existing devServer settings\n delete newConfig.devServer;\n\n return {\n huron: newHuron,\n webpack: newConfig,\n };\n}\n\n/**\n * Configure and manage webpack entry points\n *\n * @param {object} huron - huron configuration object\n * @param {object} config - webpack configuration object\n * @return {object} newConfig - updated data store\n */\nfunction configureEntries(huron, config) {\n const entry = config.entry[huron.entry];\n const newConfig = config;\n\n newConfig.entry = {};\n if (!program.production) {\n newConfig.entry[huron.entry] = [\n `webpack-dev-server/client?http://localhost:${huron.port}`,\n 'webpack/hot/dev-server',\n path.join(cwd, huron.root, 'huron-assets/index'),\n ].concat(entry);\n } else {\n newConfig.entry[huron.entry] = [\n path.join(cwd, huron.root, 'huron-assets/index'),\n ].concat(entry);\n }\n\n return newConfig;\n}\n\n/**\n * Configure and manage webpack plugins\n *\n * @param {object} huron - huron configuration object\n * @param {object} config - webpack configuration object\n * @return {object} newConfig - updated data store\n */\nfunction configurePlugins(huron, config) {\n const newConfig = config;\n\n newConfig.plugins = config.plugins || [];\n\n if (!program.production) {\n if (newConfig.plugins && newConfig.plugins.length) {\n newConfig.plugins = newConfig.plugins.filter(\n (plugin) => 'HotModuleReplacementPlugin' !== plugin.constructor.name &&\n 'NamedModulesPlugin' !== plugin.constructor.name\n );\n }\n newConfig.plugins = newConfig.plugins\n .concat([\n new webpack.HotModuleReplacementPlugin(),\n new webpack.NamedModulesPlugin(),\n ]);\n }\n\n return newConfig;\n}\n\n/**\n * Configure and manage webpack loaders\n *\n * @param {object} huron - huron configuration object\n * @param {object} config - webpack configuration object\n * @return {object} newConfig - updated data store\n */\nfunction configureLoaders(huron, config) {\n // Manage loaders\n const templatesLoader = huron.templates.rule || {};\n const newConfig = config;\n\n // Make sure we're only using templates loader for files in huron root\n templatesLoader.include = [path.join(cwd, huron.root, huron.output)];\n\n // Normalize module and module.rules\n newConfig.module = newConfig.module || {};\n newConfig.module.rules = newConfig.module.rules ||\n newConfig.module.loaders ||\n [];\n\n // Add default loaders\n newConfig.module.rules = defaultConfig.module.rules\n .concat(\n newConfig.module.rules,\n templatesLoader\n );\n\n return newConfig;\n}\n\n/**\n * Create an HTML webpack plugin for each configured prototype\n *\n * @param {object} huron - huron configuration object\n * @param {object} config - webpack configuration object\n * @return {object} newConfig - updated data store\n */\nfunction configurePrototypes(huron, config) {\n const wrapperTemplate = fs.readFileSync(\n path.join(__dirname, '../../templates/prototypeTemplate.hbs'),\n 'utf8'\n );\n\n const defaultHTMLPluginOptions = {\n title: 'Huron',\n window: huron.window,\n js: [],\n css: [],\n filename: 'index.html',\n template: path.join(\n cwd,\n huron.root,\n 'huron-assets/prototypeTemplate.hbs'\n ),\n inject: false,\n chunks: [huron.entry],\n };\n const newConfig = config;\n\n // Write prototype template file for HTML webpack plugin\n fs.outputFileSync(\n path.join(cwd, huron.root, 'huron-assets/prototypeTemplate.hbs'),\n wrapperTemplate\n );\n\n huron.prototypes.forEach((prototype) => {\n const newPrototype = prototype;\n let opts = {};\n\n // Merge configured settings with default settings\n if ('string' === typeof prototype) {\n opts = Object.assign({}, defaultHTMLPluginOptions, {\n title: prototype,\n filename: `${prototype}.html`,\n });\n } else if (\n 'object' === typeof prototype &&\n {}.hasOwnProperty.call(prototype, 'title')\n ) {\n // Create filename based on configured title if not provided\n if (!prototype.filename) {\n newPrototype.filename = `${prototype.title}.html`;\n }\n\n // Move css assets for this prototype,\n // reset css option with new file paths\n if (prototype.css) {\n newPrototype.css = moveAdditionalAssets(prototype.css, 'css', huron);\n }\n\n // Move js assets for this prototype,\n // reset js option with new file paths\n if (prototype.js) {\n newPrototype.js = moveAdditionalAssets(prototype.js, 'js', huron);\n }\n\n opts = Object.assign({}, defaultHTMLPluginOptions, newPrototype);\n }\n\n // Move global css assets,\n // reset css option with new file paths\n if (huron.css.length) {\n opts.css = opts.css.concat(\n moveAdditionalAssets(huron.css, 'css', huron)\n );\n }\n\n // Move global js assets,\n // reset js option with new file paths\n if (huron.js.length) {\n opts.js = opts.js.concat(\n moveAdditionalAssets(huron.js, 'js', huron)\n );\n }\n\n // Push a new plugin for each configured prototype\n if (Object.keys(opts).length) {\n newConfig.plugins.push(\n new HTMLWebpackPlugin(opts)\n );\n }\n });\n\n return newConfig;\n}\n\n/**\n * Move relative (and local) js and css assets provided in huron options\n *\n * @param {array|string} assets - array of assets or single asset\n * @param {string} subdir - subdirectory in huron root from which to load additional asset\n * @param {object} huron - huron configuration object\n * @return {array} assetResults - paths to js and css assets\n */\nfunction moveAdditionalAssets(assets, subdir = '', huron) {\n const currentAssets = [].concat(assets);\n const assetResults = [];\n\n currentAssets.forEach((asset) => {\n const assetInfo = path.parse(asset);\n const assetURL = url.parse(asset);\n const sourcePath = path.join(cwd, asset);\n const outputPath = path.resolve(cwd, huron.root, subdir, assetInfo.base);\n const loadPath = program.production ?\n path.join(subdir, assetInfo.base) :\n path.join('/', subdir, assetInfo.base); // Use absolute path in development\n let contents = false;\n\n if (\n !path.isAbsolute(asset) &&\n !assetURL.protocol\n ) {\n try {\n contents = fs.readFileSync(sourcePath);\n } catch (e) {\n console.warn(`could not read ${sourcePath}`);\n }\n\n if (contents) {\n fs.outputFileSync(outputPath, contents);\n assetResults.push(loadPath);\n }\n } else {\n assetResults.push(asset);\n }\n });\n\n return assetResults;\n}\n\n\n\n// WEBPACK FOOTER //\n// src/cli/generateConfig.js","/** @module cli/html-handler */\nimport path from 'path';\nimport fs from 'fs-extra';\n\nimport * as utils from './utils';\n\n/**\n * Handle update of an HMTL template\n *\n * @function updateHTML\n * @param {string} filepath - filepath of changed file (comes from gaze)\n * @param {object} section - contains KSS section data\n * @param {object} store - memory store\n * @return {object} updated data store\n */\nexport function updateHTML(filepath, section, store) {\n const file = path.parse(filepath);\n const content = fs.readFileSync(filepath, 'utf8');\n const newSection = section;\n\n if (content) {\n newSection.templatePath = utils.writeFile(\n section.referenceURI,\n 'template',\n filepath,\n content,\n store\n );\n newSection.templateContent = content;\n\n // Rewrite section data with template content\n newSection.sectionPath = utils.writeSectionData(store, newSection);\n\n return store\n .setIn(\n ['sections', 'sectionsByPath', section.kssPath],\n newSection\n )\n .setIn(\n ['sections', 'sectionsByURI', section.referenceURI],\n newSection\n );\n }\n\n console.log(`File ${file.base} could not be read`);\n return store;\n}\n\n/**\n * Handle removal of an HMTL template\n *\n * @function deleteHTML\n * @param {string} filepath - filepath of changed file (comes from gaze)\n * @param {object} section - contains KSS section data\n * @param {object} store - memory store\n * @return {object} updated data store\n */\nexport function deleteHTML(filepath, section, store) {\n const newSection = section;\n\n utils.removeFile(\n newSection.referenceURI,\n 'template',\n filepath,\n store\n );\n\n delete newSection.templatePath;\n\n return store\n .setIn(\n ['sections', 'sectionsByPath', section.kssPath],\n newSection\n )\n .setIn(\n ['sections', 'sectionsByURI', section.referenceURI],\n newSection\n );\n}\n\n/**\n * Handle update for a prototype file\n *\n * @function updatePrototype\n * @param {string} filepath - filepath of changed file (comes from gaze)\n * @param {object} store - memory store\n * @return {object} updated data store\n */\nexport function updatePrototype(filepath, store) {\n const file = path.parse(filepath);\n const content = fs.readFileSync(filepath, 'utf8');\n\n if (content) {\n const requirePath = utils.writeFile(\n file.name,\n 'prototype',\n filepath,\n content,\n store\n );\n\n return store.setIn(\n ['prototypes', file.name],\n requirePath\n );\n }\n\n console.log(`File ${file.base} could not be read`);\n return store;\n}\n\n/**\n * Handle removal of a prototype file\n *\n * @function deletePrototype\n * @param {string} filepath - filepath of changed file (comes from gaze)\n * @param {object} store - memory store\n * @return {object} updated data store\n */\nexport function deletePrototype(filepath, store) {\n const file = path.parse(filepath);\n const requirePath = utils.removeFile(\n file.name,\n 'prototype',\n filepath,\n store\n );\n\n return store.setIn(\n ['prototypes', file.name],\n requirePath\n );\n}\n\n\n\n// WEBPACK FOOTER //\n// src/cli/handleHTML.js","/** @module cli/kss-handler */\n\nimport path from 'path';\nimport fs from 'fs-extra';\nimport { parse } from 'kss';\nimport chalk from 'chalk';\n\nimport * as utils from './utils';\nimport { updateTemplate, deleteTemplate } from './handleTemplates';\nimport { writeStore } from './requireTemplates';\n\n/**\n * Handle update of a KSS section\n *\n * @function updateKSS\n * @param {string} filepath - filepath of changed file (comes from gaze)\n * @param {object} store - memory store\n * @return {object} updated data store\n */\nexport function updateKSS(filepath, store) {\n const kssSource = fs.readFileSync(filepath, 'utf8');\n const huron = store.get('config');\n const oldSection = utils.getSection(filepath, false, store) || {};\n const file = path.parse(filepath);\n let newStore = store;\n\n if (kssSource) {\n const styleguide = parse(kssSource, huron.get('kssOptions'));\n\n if (styleguide.data.sections.length) {\n const section = utils.normalizeSectionData(\n styleguide.data.sections[0]\n );\n\n if (section.reference && section.referenceURI) {\n // Update or add section data\n newStore = updateSectionData(\n filepath,\n section,\n oldSection,\n newStore\n );\n\n // Remove old section data if reference URI has changed\n if (oldSection &&\n oldSection.referenceURI &&\n oldSection.referenceURI !== section.referenceURI\n ) {\n newStore = unsetSection(oldSection, file, newStore, false);\n }\n\n writeStore(newStore);\n console.log(\n chalk.green(\n `KSS source in ${filepath} changed or added`\n )\n );\n return newStore;\n }\n\n console.log(\n chalk.magenta(\n `KSS section in ${filepath} is missing a section reference`\n )\n );\n return newStore;\n }\n\n console.log(chalk.magenta(`No KSS found in ${filepath}`));\n return newStore;\n }\n\n if (oldSection) {\n newStore = deleteKSS(filepath, oldSection, newStore);\n }\n\n console.log(chalk.red(`${filepath} not found or empty`)); // eslint-disable-line no-console\n return newStore;\n}\n\n/**\n * Handle removal of a KSS section\n *\n * @function deleteKSS\n * @param {string} filepath - filepath of changed file (comes from gaze)\n * @param {object} section - KSS section data\n * @param {object} store - memory store\n * @return {object} updated data store\n */\nexport function deleteKSS(filepath, section, store) {\n const file = path.parse(filepath);\n\n if (section.reference && section.referenceURI) {\n // Remove section data from memory store\n return unsetSection(section, file, store, true);\n }\n\n return store;\n}\n\n/**\n * Update the sections store with new data for a specific section\n *\n * @function updateSectionData\n * @param {object} section - contains updated section data\n * @param {string} kssPath - path to KSS section\n * @param {object} store - memory store\n * @return {object} updated data store\n */\nfunction updateSectionData(kssPath, section, oldSection, store) {\n const sectionFileInfo = path.parse(kssPath);\n const dataFilepath = path.join(\n sectionFileInfo.dir,\n `${sectionFileInfo.name}.json`\n );\n const isInline = null !== section.markup.match(/<\\/[^>]*>/);\n const newSort = sortSection(\n store.getIn(['sections', 'sorted']),\n section.reference,\n store.get('referenceDelimiter')\n );\n const newSection = Object.assign({}, oldSection, section);\n let newStore = store;\n\n // Required for reference from templates and data\n newSection.kssPath = kssPath;\n\n if (isInline) {\n // Set section value if inlineTempalte() returned a path\n newStore = updateInlineTemplate(\n kssPath,\n oldSection,\n newSection,\n newStore\n );\n } else {\n // Remove inline template, if it exists\n utils.removeFile(\n newSection.referenceURI,\n 'template',\n kssPath,\n store\n );\n // Update markup and data fields\n newStore = updateTemplateFields(\n sectionFileInfo,\n oldSection,\n newSection,\n newStore\n );\n }\n\n // Output section description\n newStore = updateDescription(\n kssPath,\n oldSection,\n newSection,\n newStore\n );\n\n // Output section data to a JSON file\n newSection.sectionPath = utils.writeSectionData(\n newStore,\n newSection,\n dataFilepath\n );\n\n // Update section sorting\n return newStore\n .setIn(\n ['sections', 'sorted'],\n newSort\n )\n .setIn(\n ['sections', 'sectionsByPath', kssPath],\n newSection\n )\n .setIn(\n ['sections', 'sectionsByURI', section.referenceURI],\n newSection\n );\n}\n\n/**\n * Handle detection and output of inline templates, which is markup written\n * in the KSS documentation itself as opposed to an external file\n *\n * @function updateInlineTemplate\n * @param {string} oldSection - previous iteration of KSS data, if updated\n * @param {object} section - KSS section data\n * @return {object} updated data store with new template path info\n */\nfunction updateInlineTemplate(filepath, oldSection, section, store) {\n const newSection = section;\n const newStore = store;\n\n // If we have inline markup\n if (fieldShouldOutput(oldSection, section, 'markup')) {\n newSection.templatePath = utils.writeFile(\n section.referenceURI,\n 'template',\n filepath,\n section.markup,\n store\n );\n newSection.templateContent = section.markup;\n\n return newStore\n .setIn(\n ['sections', 'sectionsByPath', filepath],\n newSection\n )\n .setIn(\n ['sections', 'sectionsByURI', section.referenceURI],\n newSection\n );\n }\n\n return newStore;\n}\n\n/**\n * Handle output of section description\n *\n * @function updateDescription\n * @param {string} oldSection - previous iteration of KSS data, if updated\n * @param {object} section - KSS section data\n * @return {object} updated data store with new descripton path info\n */\nfunction updateDescription(filepath, oldSection, section, store) {\n const newSection = section;\n const newStore = store;\n\n // If we don't have previous KSS or the KSS has been updated\n if (fieldShouldOutput(oldSection, section, 'description')) {\n // Write new description\n newSection.descriptionPath = utils.writeFile(\n section.referenceURI,\n 'description',\n filepath,\n section.description,\n store\n );\n\n return newStore\n .setIn(\n ['sections', 'sectionsByPath', filepath],\n newSection\n )\n .setIn(\n ['sections', 'sectionsByURI', section.referenceURI],\n newSection\n );\n }\n\n return newStore;\n}\n\n/**\n * Handle Data and Markup fields\n *\n * @function updateTemplateFields\n * @param {string} file - File data for KSS file from path.parse()\n * @param {object} oldSection - outdated KSS data\n * @param {object} section - KSS section data\n * @param {object} store - memory store\n * @return {object} KSS section data with updated asset paths\n */\nfunction updateTemplateFields(file, oldSection, section, store) {\n const kssPath = path.format(file);\n const newSection = section;\n let filepath = '';\n let oldFilepath = '';\n let newStore = store;\n\n ['data', 'markup'].forEach((field) => {\n if (newSection[field]) {\n if (oldSection[field]) {\n oldFilepath = path.join(file.dir, oldSection[field]);\n newStore = deleteTemplate(\n oldFilepath,\n oldSection,\n newStore\n );\n }\n\n filepath = path.join(file.dir, newSection[field]);\n newStore = updateTemplate(\n filepath,\n newSection,\n newStore\n );\n } else {\n delete newSection[field];\n newStore = newStore\n .setIn(\n ['sections', 'sectionsByPath', kssPath],\n newSection\n )\n .setIn(\n ['sections', 'sectionsByURI', newSection.referenceURI],\n newSection\n );\n }\n });\n\n return newStore;\n}\n\n/**\n * Remove a section from the memory store\n *\n * @function unsetSection\n * @param {object} section - contains updated section data\n * @param {string} file - file object from path.parse()\n * @param {object} store - memory store\n * @param {bool} removed - has the file been removed or just the section information changed?\n * @return {object} updated data store with new descripton path info\n */\nfunction unsetSection(section, file, store, removed) {\n const sorted = store.getIn(['sections', 'sorted']);\n const kssPath = path.format(file);\n const dataFilepath = path.join(file.dir, `${file.name}.json`);\n const isInline = section.markup &&\n null !== section.markup.match(/<\\/[^>]*>/);\n const newSort = unsortSection(\n sorted,\n section.reference,\n store.get('referenceDelimiter')\n );\n let newStore = store;\n\n // Remove old section data\n utils.removeFile(\n section.referenceURI,\n 'section',\n dataFilepath,\n newStore\n );\n\n // Remove associated inline template\n if (isInline) {\n utils.removeFile(section.referenceURI, 'template', kssPath, newStore);\n }\n\n // Remove description template\n utils.removeFile(section.referenceURI, 'description', kssPath, newStore);\n\n // Remove data from sectionsByPath if file has been removed\n if (removed) {\n newStore = newStore.deleteIn(['sections', 'sectionsByPath', kssPath]);\n }\n\n return newStore\n .deleteIn(['sections', 'sectionsByURI', section.referenceURI])\n .setIn(['sections', 'sorted'], newSort);\n}\n\n/**\n * Sort sections and subsections\n *\n * @function sortSection\n * @param {object} sorted - currently sorted sections\n * @param {string} reference - reference URI of section to sort\n * @return {object} updated data store with new descripton path info\n */\nfunction sortSection(sorted, reference, delimiter) {\n const parts = reference.split(delimiter);\n const newSort = sorted[parts[0]] || {};\n const newSorted = sorted;\n\n if (1 < parts.length) {\n const newParts = parts.filter((part, idx) => 0 !== idx);\n newSorted[parts[0]] = sortSection(\n newSort,\n newParts.join(delimiter),\n delimiter\n );\n } else {\n newSorted[parts[0]] = newSort;\n }\n\n return newSorted;\n}\n\n/**\n * Remove a section from the sorted sections\n *\n * @function unsortSection\n * @param {object} sorted - currently sorted sections\n * @param {string} reference - reference URI of section to sort\n * @return {object} updated data store with new descripton path info\n */\nfunction unsortSection(sorted, reference, delimiter) {\n const parts = reference.split(delimiter);\n const subsections = Object.keys(sorted[parts[0]]);\n const newSorted = sorted;\n\n if (subsections.length) {\n if (1 < parts.length) {\n const newParts = parts.filter((part, idx) => 0 !== idx);\n newSorted[parts[0]] = unsortSection(\n newSorted[parts[0]],\n newParts.join(delimiter),\n delimiter\n );\n }\n } else {\n delete newSorted[parts[0]];\n }\n\n return newSorted;\n}\n\n/**\n * Compare a KSS field between old and new KSS data to see if we need to output\n * a new module for that field\n *\n * @function fieldShouldOutput\n * @param {object} oldSection - currently sorted sections\n * @param {object} newSection - reference URI of section to sort\n * @param {string} field - KSS field to check\n * @return {bool} output a new module for the KSS field\n */\nfunction fieldShouldOutput(oldSection, newSection, field) {\n return (oldSection &&\n (oldSection[field] !== newSection[field] ||\n oldSection.referenceURI !== newSection.referenceURI)\n ) ||\n !oldSection;\n}\n\n\n\n// WEBPACK FOOTER //\n// src/cli/handleKSS.js","// Necessary to remove require statement from Webpack processing preserve it in output\n/* eslint-disable import/no-dynamic-require, global-require */\nexport default function requireExternal(requirePath) {\n return require(requirePath);\n}\n/* eslint-enable */\n\n\n\n// WEBPACK FOOTER //\n// src/cli/requireExternal.js","/** @module cli/webpack-server */\nimport webpack from 'webpack';\nimport WebpackDevServer from 'webpack-dev-server';\nimport chalk from 'chalk';\nimport open from 'opn';\n\nimport createDevServerConfig from '../../config/devServer.config';\nimport program from './parseArgs';\n\n/**\n * Spin up webpack-dev-server or, if production flag is set, run webpack a single time\n *\n * @function startWebpack\n * @param {object} config - webpack configuration, preprocessed by {@link module:cli/generate-config generateConfig}\n * @see {@link module:cli/generate-config generateConfig}\n */\nexport default function startWebpack(config) {\n const huron = config.huron;\n const webpackConfig = config.webpack;\n const compiler = webpack(webpackConfig);\n\n if (program.progress) {\n compiler.apply(\n new webpack.ProgressPlugin(\n (percentage, msg) => {\n console.log(`${(percentage * 100)}% `, msg);\n }\n )\n );\n }\n\n if (program.production) {\n compiler.run((err, stats) => {\n const info = stats.toJson();\n\n if (err) {\n console.log(err);\n }\n\n if (stats.hasErrors()) {\n console.error(\n chalk.red(\n 'Webpack encountered errors during compile: ',\n info.errors\n )\n );\n }\n\n if (stats.hasWarnings()) {\n console.error(\n chalk.yellow(\n 'Webpack encountered warnings during compile: ', info.warnings\n )\n );\n }\n });\n } else {\n const server = new WebpackDevServer(compiler, createDevServerConfig(huron));\n const prototypeName = huron.prototypes[0].title || huron.prototypes[0];\n\n server.listen(\n huron.port,\n 'localhost',\n (err) => {\n if (err) {\n return console.log(err);\n }\n\n console.log(`Listening at http://localhost:${huron.port}/`);\n open(`http://localhost:${huron.port}/${huron.root}/${prototypeName}.html`);\n return true;\n }\n );\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// src/cli/server.js","import path from 'path';\n\nexport default {\n css: [],\n entry: 'huron',\n js: [],\n kss: 'css/',\n kssExtension: '.css',\n kssOptions: {\n multiline: true,\n markdown: true,\n custom: ['data'],\n },\n output: 'partials',\n port: 8080,\n prototypes: ['index'],\n root: 'dist/',\n sectionTemplate: path.join(__dirname, '../../templates/section.hbs'),\n classNames: false,\n templates: {\n rule: {\n test: /\\.(hbs|handlebars)$/,\n use: 'handlebars-loader',\n },\n extension: '.hbs',\n },\n window: {},\n};\n\n\n\n// WEBPACK FOOTER //\n// src/defaultConfig/huron.config.js","import webpack from 'webpack';\nimport path from 'path';\n\nimport program from '../cli/parseArgs';\n\nexport default (huron) => {\n const cwd = process.cwd();\n\n return {\n entry: {},\n output: {\n path: path.join(cwd, huron.root),\n publicPath: program.production ? '' :\n `http://localhost:${huron.port}/${huron.root}`,\n filename: '[name].js',\n chunkFilename: '[name].chunk.min.js',\n },\n plugins: [\n new webpack.HotModuleReplacementPlugin(),\n new webpack.NamedModulesPlugin(),\n ],\n resolve: {\n modulesDirectories: [\n path.resolve(__dirname, '../src/js'),\n ],\n },\n resolveLoader: {\n modulesDirectories: [\n 'web_loaders',\n 'web_modules',\n 'node_loaders',\n 'node_modules',\n path.resolve(__dirname, '../node_modules'),\n ],\n },\n module: {\n rules: [\n {\n test: /\\.html$/,\n include: [path.join(cwd, huron.root, huron.output)],\n use: 'html-loader',\n },\n {\n test: /\\.(hbs|handlebars)$/,\n include: [path.join(cwd, huron.root, 'huron-assets')],\n use: {\n loader: 'handlebars-loader',\n options: {\n helperDirs: [path.join(\n __dirname,\n '../../',\n 'templates/handlebarsHelpers'\n )],\n },\n },\n },\n ],\n },\n };\n};\n\n\n\n// WEBPACK FOOTER //\n// src/defaultConfig/webpack.config.js","module.exports = \"'use strict';\\n\\nvar _huronStore = require('./huron-store');\\n\\nvar _huronStore2 = _interopRequireDefault(_huronStore);\\n\\nvar _insertNodes = require('./insertNodes');\\n\\nvar _insertNodes2 = _interopRequireDefault(_insertNodes);\\n\\nvar _section = require('./section.hbs');\\n\\nvar _section2 = _interopRequireDefault(_section);\\n\\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\\n\\n/* eslint-enable */\\n\\nconst assets = require.context(hotScope.requirePath, true, hotScope.requireRegex); /* globals hotScope */\\n\\n// NOTE: This is not a normal JS file! It is pulled in by the CLI as a string\\n// and prepended to the browser script after replacing anything referenced via `hotScope[variable]`\\n// with CLI arguments or config properties passed in by the user.\\n\\n/* eslint-disable */\\n\\nconst modules = {};\\n\\nmodules[hotScope.sectionTemplatePath] = _section2.default;\\n\\nassets.keys().forEach(key => {\\n modules[key] = assets(key);\\n});\\n\\nconst insert = new _insertNodes2.default(modules, _huronStore2.default);\\n\\nif (module.hot) {\\n // Hot Module Replacement for huron components (json, hbs, html)\\n module.hot.accept(assets.id, () => {\\n const newAssets = require.context(hotScope.requirePath, true, hotScope.requireRegex);\\n const newModules = newAssets.keys().map(key => [key, newAssets(key)]).filter(newModule => modules[newModule[0]] !== newModule[1]);\\n\\n updateStore(require('./huron-store.js')); // eslint-disable-line global-require, import/no-unresolved\\n newModules.forEach(module => {\\n modules[module[0]] = module[1];\\n hotReplace(module[0], module[1], modules);\\n });\\n });\\n\\n // Hot Module Replacement for sections template\\n module.hot.accept('./section.hbs', () => {\\n const newSectionTemplate = require('./section.hbs'); // eslint-disable-line global-require, import/no-unresolved\\n\\n modules[hotScope.sectionTemplatePath] = newSectionTemplate;\\n hotReplace('./huron-assets/section.hbs', newSectionTemplate, modules);\\n });\\n\\n // Hot Module Replacement for data store\\n module.hot.accept('./huron-store.js', () => {\\n updateStore(require('./huron-store.js')); // eslint-disable-line global-require, import/no-unresolved\\n });\\n}\\n\\nfunction hotReplace(key, module, newModules) {\\n insert.modules = newModules;\\n if (key === _huronStore2.default.sectionTemplatePath) {\\n insert.cycleSections();\\n } else {\\n insert.inserted = [];\\n insert.loadModule(key, module, false);\\n }\\n}\\n\\nfunction updateStore(newStore) {\\n insert.store = newStore;\\n}\"\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/raw-loader!./~/babel-loader/lib!./templates/hotTemplate.js\n// module id = 20\n// module chunks = 0","module.exports = require(\"commander\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"commander\"\n// module id = 21\n// module chunks = 0","module.exports = require(\"gaze\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"gaze\"\n// module id = 22\n// module chunks = 0","module.exports = require(\"html-webpack-plugin\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"html-webpack-plugin\"\n// module id = 23\n// module chunks = 0","module.exports = require(\"immutable\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"immutable\"\n// module id = 24\n// module chunks = 0","module.exports = require(\"kss\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"kss\"\n// module id = 25\n// module chunks = 0","module.exports = require(\"lodash/isEqual\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"lodash/isEqual\"\n// module id = 26\n// module chunks = 0","module.exports = require(\"opn\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"opn\"\n// module id = 27\n// module chunks = 0","module.exports = require(\"url\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"url\"\n// module id = 28\n// module chunks = 0","module.exports = require(\"webpack-dev-server\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external \"webpack-dev-server\"\n// module id = 29\n// module chunks = 0"],"mappings":";AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;A;;;;AChEA;;;;;;;;;;;;ACcA;AAkBA;AAqCA;AAqCA;AAcA;AAkBA;AAyBA;AA4CA;AAyCA;AAyBA;AAyBA;AAqBA;AA0CA;AACA;AAzWA;AACA;;;AAAA;AACA;;;AAAA;AACA;;;;;AACA;AACA;AACA;;;;;;;AAPA;AAcA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AAQA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AAOA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;;;;;;;;AAQA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AAGA;AACA;AASA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;AAOA;AACA;AAGA;AACA;AACA;;;;;;;;AAQA;AACA;AACA;AACA;;AAFA;AAKA;AACA;AACA;;;;;;;;;;AAUA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;AAUA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AAQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AAQA;AACA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AAQA;AACA;AAGA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AAQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AASA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;AC/WA;;;;;;ACAA;;;;;;;;;;;;;ACGA;AACA;;;AAAA;AACA;;;;;AACA;AACA;AACA;AACA;;;;;;AATA;AACA;AACA;AAaA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAYA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;ACzDA;;;;;;;;;;;;;;ACAA;AACA;AACA;AACA;;;AAAA;AACA;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AAKA;AACA;AAQA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AAnBA;AAqBA;AACA;AACA;AAAA;;;;;;;;;;;;ACzBA;AA0DA;AACA;AA1EA;AACA;;;AAAA;AACA;;;AAAA;AACA;;;AACA;AACA;AADA;AACA;;;;;AACA;;;;;;;;;AAPA;AAgBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAaA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AASA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAMA;AACA;AACA;AAUA;;;;;;;;;;;;;;AClGA;AACA;;;AAAA;AACA;;;AAIA;AACA;;;;;AAAA;AACA;AACA;AACA;AAPA;AACA;AACA;AANA;AACA;AAUA;AACA;AAIA;;;;;;AAMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AALA;AAOA;AACA;AAOA;AACA;AAIA;AAIA;AACA;AACA;;;;;;;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;;;;;;;;;ACxEA;AACA;;;AACA;AACA;AAKA;AACA;AAAA;AACA;AAAA;AACA;;;AAAA;AACA;;;AAAA;AACA;AAAA;AACA;;;;;AACA;;;;;AAhBA;AAqBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;ACxGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AATA;AAWA;AACA;AACA;AAjBA;;;;;;;;;;;;ACwBA;AA8CA;AA+DA;AA0DA;AACA;AA7LA;AACA;;;AAAA;AACA;;;AAAA;AACA;;;AACA;AACA;AAKA;AACA;AAAA;AACA;AAAA;AACA;AADA;AACA;;;;;AACA;;;;;;;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA1BA;AACA;AA4BA;AACA;AACA;AACA;;;;;;;AA/DA;AACA;AACA;AAoEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAxCA;AACA;AA0CA;AACA;AACA;AACA;;;;;;;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AArCA;AACA;AAuCA;AACA;AACA;AACA;;;;;;;;AAQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;AC5MA;AACA;AAAA;AACA;;;AACA;AACA;AAAA;AACA;;;AACA;;;;;AAKA;AACA;AACA;;;;;AAKA;AACA;AAMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;;;;;AAKA;AACA;AACA;;;;;;;;;;;;ACtBA;AACA;AA9BA;AACA;;;AAAA;AACA;;;AAAA;AACA;;;AAAA;AACA;;;AAAA;AACA;;;AACA;AACA;;;AAAA;AACA;;;AAAA;AACA;;;AAAA;AACA;;;;;AACA;AACA;AACA;AAdA;AAeA;AACA;AAGA;AACA;AAGA;;;;;;;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;;;;;;;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;;;;;;;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;;;;;;;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AAKA;AACA;AACA;AACA;;;;;;;AAOA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AACA;AAZA;AAcA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AAQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;AC7RA;AA0CA;AA+BA;AA+BA;AACA;AAvHA;AACA;;;AAAA;AACA;;;AACA;AACA;AADA;AACA;;;;;AACA;;;;;;;;;AASA;AACA;AACA;AACA;AACA;AACA;AACA;AAOA;AACA;AACA;AACA;AACA;AACA;AASA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AAhDA;AAyDA;AACA;AACA;AACA;AACA;AAMA;AACA;AACA;AASA;AACA;AACA;;;;;;;;AAQA;AACA;AACA;AACA;AACA;AACA;AACA;AAOA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AAQA;AACA;AACA;AACA;AAMA;AAIA;;;;;;;;;;;;ACjHA;AAsEA;AACA;AAxFA;AACA;;;AAAA;AACA;;;AAAA;AACA;AAAA;AACA;;;AACA;AACA;AADA;AACA;AAAA;AACA;AAAA;AACA;;;;;AACA;;;;;;;;AAQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AAMA;AACA;AAIA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AAhFA;AACA;AAwFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AASA;AACA;AACA;AAIA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAMA;AACA;AACA;AAMA;AACA;AAMA;AACA;AACA;AACA;AACA;AAMA;AACA;AACA;AAKA;AACA;AAaA;AACA;AACA;;;;;;;;;AASA;AACA;AACA;AACA;AACA;AACA;AACA;AAOA;AACA;AACA;AASA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AAQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAOA;AASA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;AAUA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AAKA;AACA;AACA;AASA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;AAUA;AACA;AACA;AACA;AACA;AAEA;AAKA;AACA;AACA;AACA;AACA;AAMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;;;;;;;;AAQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AAQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;AAUA;AACA;AAKA;;;;;;;;;;;AC5aA;AAFA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;ACWA;AACA;AAhBA;AACA;;;AAAA;AACA;;;AAAA;AACA;;;AAAA;AACA;;;AACA;AACA;;;AAAA;AACA;;;;;AACA;;;;;;;AATA;AAgBA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAMA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;;;;;;;;;;;;;AC1EA;AACA;;;;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AALA;AAOA;AAxBA;;;;;;;;;;;;;ACFA;AACA;;;AAAA;AACA;;;AACA;AACA;;;;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AALA;AAOA;AAIA;AACA;AADA;AAKA;AACA;AADA;AASA;AACA;AAEA;AACA;AACA;AAHA;AAMA;AACA;AACA;AACA;AACA;AACA;AADA;AAFA;AAHA;AAPA;AA3BA;AAmDA;;;;;;AC3DA;;;;;;ACAA;;;;;;ACAA;;;;;;ACAA;;;;;;ACAA;;;;;;ACAA;;;;;;ACAA;;;;;;ACAA;;;;;;ACAA;;;;;;ACAA;;;;;;;;;;A","sourceRoot":""} \ No newline at end of file diff --git a/dist/web/index.js b/dist/web/index.js index 55e167c..b53cceb 100644 --- a/dist/web/index.js +++ b/dist/web/index.js @@ -70,113 +70,2031 @@ module.exports = /******/ ({ /***/ "./node_modules/lodash/fp.js": -/* no static exports found */ -/* all exports used */ -/*!************************!*\ - !*** ./~/lodash/fp.js ***! - \************************/ /***/ (function(module, exports, __webpack_require__) { -eval("var _ = __webpack_require__(/*! ./lodash.min */ \"./node_modules/lodash/lodash.min.js\").runInContext();\nmodule.exports = __webpack_require__(/*! ./fp/_baseConvert */ \"./node_modules/lodash/fp/_baseConvert.js\")(_, _);\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9ub2RlX21vZHVsZXMvbG9kYXNoL2ZwLmpzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vLy4vfi9sb2Rhc2gvZnAuanM/YmRjMyJdLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgXyA9IHJlcXVpcmUoJy4vbG9kYXNoLm1pbicpLnJ1bkluQ29udGV4dCgpO1xubW9kdWxlLmV4cG9ydHMgPSByZXF1aXJlKCcuL2ZwL19iYXNlQ29udmVydCcpKF8sIF8pO1xuXG5cblxuLy8vLy8vLy8vLy8vLy8vLy8vXG4vLyBXRUJQQUNLIEZPT1RFUlxuLy8gLi9+L2xvZGFzaC9mcC5qc1xuLy8gbW9kdWxlIGlkID0gLi9ub2RlX21vZHVsZXMvbG9kYXNoL2ZwLmpzXG4vLyBtb2R1bGUgY2h1bmtzID0gMCJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTsiLCJzb3VyY2VSb290IjoiIn0="); +var _ = __webpack_require__("./node_modules/lodash/lodash.min.js").runInContext(); +module.exports = __webpack_require__("./node_modules/lodash/fp/_baseConvert.js")(_, _); + /***/ }), /***/ "./node_modules/lodash/fp/_baseConvert.js": -/* no static exports found */ -/* all exports used */ -/*!*************************************!*\ - !*** ./~/lodash/fp/_baseConvert.js ***! - \*************************************/ /***/ (function(module, exports, __webpack_require__) { -eval("var mapping = __webpack_require__(/*! ./_mapping */ \"./node_modules/lodash/fp/_mapping.js\"),\n fallbackHolder = __webpack_require__(/*! ./placeholder */ \"./node_modules/lodash/fp/placeholder.js\");\n\n/** Built-in value reference. */\nvar push = Array.prototype.push;\n\n/**\n * Creates a function, with an arity of `n`, that invokes `func` with the\n * arguments it receives.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} n The arity of the new function.\n * @returns {Function} Returns the new function.\n */\nfunction baseArity(func, n) {\n return n == 2\n ? function(a, b) { return func.apply(undefined, arguments); }\n : function(a) { return func.apply(undefined, arguments); };\n}\n\n/**\n * Creates a function that invokes `func`, with up to `n` arguments, ignoring\n * any additional arguments.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @param {number} n The arity cap.\n * @returns {Function} Returns the new function.\n */\nfunction baseAry(func, n) {\n return n == 2\n ? function(a, b) { return func(a, b); }\n : function(a) { return func(a); };\n}\n\n/**\n * Creates a clone of `array`.\n *\n * @private\n * @param {Array} array The array to clone.\n * @returns {Array} Returns the cloned array.\n */\nfunction cloneArray(array) {\n var length = array ? array.length : 0,\n result = Array(length);\n\n while (length--) {\n result[length] = array[length];\n }\n return result;\n}\n\n/**\n * Creates a function that clones a given object using the assignment `func`.\n *\n * @private\n * @param {Function} func The assignment function.\n * @returns {Function} Returns the new cloner function.\n */\nfunction createCloner(func) {\n return function(object) {\n return func({}, object);\n };\n}\n\n/**\n * A specialized version of `_.spread` which flattens the spread array into\n * the arguments of the invoked `func`.\n *\n * @private\n * @param {Function} func The function to spread arguments over.\n * @param {number} start The start position of the spread.\n * @returns {Function} Returns the new function.\n */\nfunction flatSpread(func, start) {\n return function() {\n var length = arguments.length,\n lastIndex = length - 1,\n args = Array(length);\n\n while (length--) {\n args[length] = arguments[length];\n }\n var array = args[start],\n otherArgs = args.slice(0, start);\n\n if (array) {\n push.apply(otherArgs, array);\n }\n if (start != lastIndex) {\n push.apply(otherArgs, args.slice(start + 1));\n }\n return func.apply(this, otherArgs);\n };\n}\n\n/**\n * Creates a function that wraps `func` and uses `cloner` to clone the first\n * argument it receives.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} cloner The function to clone arguments.\n * @returns {Function} Returns the new immutable function.\n */\nfunction wrapImmutable(func, cloner) {\n return function() {\n var length = arguments.length;\n if (!length) {\n return;\n }\n var args = Array(length);\n while (length--) {\n args[length] = arguments[length];\n }\n var result = args[0] = cloner.apply(undefined, args);\n func.apply(undefined, args);\n return result;\n };\n}\n\n/**\n * The base implementation of `convert` which accepts a `util` object of methods\n * required to perform conversions.\n *\n * @param {Object} util The util object.\n * @param {string} name The name of the function to convert.\n * @param {Function} func The function to convert.\n * @param {Object} [options] The options object.\n * @param {boolean} [options.cap=true] Specify capping iteratee arguments.\n * @param {boolean} [options.curry=true] Specify currying.\n * @param {boolean} [options.fixed=true] Specify fixed arity.\n * @param {boolean} [options.immutable=true] Specify immutable operations.\n * @param {boolean} [options.rearg=true] Specify rearranging arguments.\n * @returns {Function|Object} Returns the converted function or object.\n */\nfunction baseConvert(util, name, func, options) {\n var setPlaceholder,\n isLib = typeof name == 'function',\n isObj = name === Object(name);\n\n if (isObj) {\n options = func;\n func = name;\n name = undefined;\n }\n if (func == null) {\n throw new TypeError;\n }\n options || (options = {});\n\n var config = {\n 'cap': 'cap' in options ? options.cap : true,\n 'curry': 'curry' in options ? options.curry : true,\n 'fixed': 'fixed' in options ? options.fixed : true,\n 'immutable': 'immutable' in options ? options.immutable : true,\n 'rearg': 'rearg' in options ? options.rearg : true\n };\n\n var forceCurry = ('curry' in options) && options.curry,\n forceFixed = ('fixed' in options) && options.fixed,\n forceRearg = ('rearg' in options) && options.rearg,\n placeholder = isLib ? func : fallbackHolder,\n pristine = isLib ? func.runInContext() : undefined;\n\n var helpers = isLib ? func : {\n 'ary': util.ary,\n 'assign': util.assign,\n 'clone': util.clone,\n 'curry': util.curry,\n 'forEach': util.forEach,\n 'isArray': util.isArray,\n 'isFunction': util.isFunction,\n 'iteratee': util.iteratee,\n 'keys': util.keys,\n 'rearg': util.rearg,\n 'toInteger': util.toInteger,\n 'toPath': util.toPath\n };\n\n var ary = helpers.ary,\n assign = helpers.assign,\n clone = helpers.clone,\n curry = helpers.curry,\n each = helpers.forEach,\n isArray = helpers.isArray,\n isFunction = helpers.isFunction,\n keys = helpers.keys,\n rearg = helpers.rearg,\n toInteger = helpers.toInteger,\n toPath = helpers.toPath;\n\n var aryMethodKeys = keys(mapping.aryMethod);\n\n var wrappers = {\n 'castArray': function(castArray) {\n return function() {\n var value = arguments[0];\n return isArray(value)\n ? castArray(cloneArray(value))\n : castArray.apply(undefined, arguments);\n };\n },\n 'iteratee': function(iteratee) {\n return function() {\n var func = arguments[0],\n arity = arguments[1],\n result = iteratee(func, arity),\n length = result.length;\n\n if (config.cap && typeof arity == 'number') {\n arity = arity > 2 ? (arity - 2) : 1;\n return (length && length <= arity) ? result : baseAry(result, arity);\n }\n return result;\n };\n },\n 'mixin': function(mixin) {\n return function(source) {\n var func = this;\n if (!isFunction(func)) {\n return mixin(func, Object(source));\n }\n var pairs = [];\n each(keys(source), function(key) {\n if (isFunction(source[key])) {\n pairs.push([key, func.prototype[key]]);\n }\n });\n\n mixin(func, Object(source));\n\n each(pairs, function(pair) {\n var value = pair[1];\n if (isFunction(value)) {\n func.prototype[pair[0]] = value;\n } else {\n delete func.prototype[pair[0]];\n }\n });\n return func;\n };\n },\n 'nthArg': function(nthArg) {\n return function(n) {\n var arity = n < 0 ? 1 : (toInteger(n) + 1);\n return curry(nthArg(n), arity);\n };\n },\n 'rearg': function(rearg) {\n return function(func, indexes) {\n var arity = indexes ? indexes.length : 0;\n return curry(rearg(func, indexes), arity);\n };\n },\n 'runInContext': function(runInContext) {\n return function(context) {\n return baseConvert(util, runInContext(context), options);\n };\n }\n };\n\n /*--------------------------------------------------------------------------*/\n\n /**\n * Casts `func` to a function with an arity capped iteratee if needed.\n *\n * @private\n * @param {string} name The name of the function to inspect.\n * @param {Function} func The function to inspect.\n * @returns {Function} Returns the cast function.\n */\n function castCap(name, func) {\n if (config.cap) {\n var indexes = mapping.iterateeRearg[name];\n if (indexes) {\n return iterateeRearg(func, indexes);\n }\n var n = !isLib && mapping.iterateeAry[name];\n if (n) {\n return iterateeAry(func, n);\n }\n }\n return func;\n }\n\n /**\n * Casts `func` to a curried function if needed.\n *\n * @private\n * @param {string} name The name of the function to inspect.\n * @param {Function} func The function to inspect.\n * @param {number} n The arity of `func`.\n * @returns {Function} Returns the cast function.\n */\n function castCurry(name, func, n) {\n return (forceCurry || (config.curry && n > 1))\n ? curry(func, n)\n : func;\n }\n\n /**\n * Casts `func` to a fixed arity function if needed.\n *\n * @private\n * @param {string} name The name of the function to inspect.\n * @param {Function} func The function to inspect.\n * @param {number} n The arity cap.\n * @returns {Function} Returns the cast function.\n */\n function castFixed(name, func, n) {\n if (config.fixed && (forceFixed || !mapping.skipFixed[name])) {\n var data = mapping.methodSpread[name],\n start = data && data.start;\n\n return start === undefined ? ary(func, n) : flatSpread(func, start);\n }\n return func;\n }\n\n /**\n * Casts `func` to an rearged function if needed.\n *\n * @private\n * @param {string} name The name of the function to inspect.\n * @param {Function} func The function to inspect.\n * @param {number} n The arity of `func`.\n * @returns {Function} Returns the cast function.\n */\n function castRearg(name, func, n) {\n return (config.rearg && n > 1 && (forceRearg || !mapping.skipRearg[name]))\n ? rearg(func, mapping.methodRearg[name] || mapping.aryRearg[n])\n : func;\n }\n\n /**\n * Creates a clone of `object` by `path`.\n *\n * @private\n * @param {Object} object The object to clone.\n * @param {Array|string} path The path to clone by.\n * @returns {Object} Returns the cloned object.\n */\n function cloneByPath(object, path) {\n path = toPath(path);\n\n var index = -1,\n length = path.length,\n lastIndex = length - 1,\n result = clone(Object(object)),\n nested = result;\n\n while (nested != null && ++index < length) {\n var key = path[index],\n value = nested[key];\n\n if (value != null) {\n nested[path[index]] = clone(index == lastIndex ? value : Object(value));\n }\n nested = nested[key];\n }\n return result;\n }\n\n /**\n * Converts `lodash` to an immutable auto-curried iteratee-first data-last\n * version with conversion `options` applied.\n *\n * @param {Object} [options] The options object. See `baseConvert` for more details.\n * @returns {Function} Returns the converted `lodash`.\n */\n function convertLib(options) {\n return _.runInContext.convert(options)(undefined);\n }\n\n /**\n * Create a converter function for `func` of `name`.\n *\n * @param {string} name The name of the function to convert.\n * @param {Function} func The function to convert.\n * @returns {Function} Returns the new converter function.\n */\n function createConverter(name, func) {\n var realName = mapping.aliasToReal[name] || name,\n methodName = mapping.remap[realName] || realName,\n oldOptions = options;\n\n return function(options) {\n var newUtil = isLib ? pristine : helpers,\n newFunc = isLib ? pristine[methodName] : func,\n newOptions = assign(assign({}, oldOptions), options);\n\n return baseConvert(newUtil, realName, newFunc, newOptions);\n };\n }\n\n /**\n * Creates a function that wraps `func` to invoke its iteratee, with up to `n`\n * arguments, ignoring any additional arguments.\n *\n * @private\n * @param {Function} func The function to cap iteratee arguments for.\n * @param {number} n The arity cap.\n * @returns {Function} Returns the new function.\n */\n function iterateeAry(func, n) {\n return overArg(func, function(func) {\n return typeof func == 'function' ? baseAry(func, n) : func;\n });\n }\n\n /**\n * Creates a function that wraps `func` to invoke its iteratee with arguments\n * arranged according to the specified `indexes` where the argument value at\n * the first index is provided as the first argument, the argument value at\n * the second index is provided as the second argument, and so on.\n *\n * @private\n * @param {Function} func The function to rearrange iteratee arguments for.\n * @param {number[]} indexes The arranged argument indexes.\n * @returns {Function} Returns the new function.\n */\n function iterateeRearg(func, indexes) {\n return overArg(func, function(func) {\n var n = indexes.length;\n return baseArity(rearg(baseAry(func, n), indexes), n);\n });\n }\n\n /**\n * Creates a function that invokes `func` with its first argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\n function overArg(func, transform) {\n return function() {\n var length = arguments.length;\n if (!length) {\n return func();\n }\n var args = Array(length);\n while (length--) {\n args[length] = arguments[length];\n }\n var index = config.rearg ? 0 : (length - 1);\n args[index] = transform(args[index]);\n return func.apply(undefined, args);\n };\n }\n\n /**\n * Creates a function that wraps `func` and applys the conversions\n * rules by `name`.\n *\n * @private\n * @param {string} name The name of the function to wrap.\n * @param {Function} func The function to wrap.\n * @returns {Function} Returns the converted function.\n */\n function wrap(name, func) {\n var result,\n realName = mapping.aliasToReal[name] || name,\n wrapped = func,\n wrapper = wrappers[realName];\n\n if (wrapper) {\n wrapped = wrapper(func);\n }\n else if (config.immutable) {\n if (mapping.mutate.array[realName]) {\n wrapped = wrapImmutable(func, cloneArray);\n }\n else if (mapping.mutate.object[realName]) {\n wrapped = wrapImmutable(func, createCloner(func));\n }\n else if (mapping.mutate.set[realName]) {\n wrapped = wrapImmutable(func, cloneByPath);\n }\n }\n each(aryMethodKeys, function(aryKey) {\n each(mapping.aryMethod[aryKey], function(otherName) {\n if (realName == otherName) {\n var data = mapping.methodSpread[realName],\n afterRearg = data && data.afterRearg;\n\n result = afterRearg\n ? castFixed(realName, castRearg(realName, wrapped, aryKey), aryKey)\n : castRearg(realName, castFixed(realName, wrapped, aryKey), aryKey);\n\n result = castCap(realName, result);\n result = castCurry(realName, result, aryKey);\n return false;\n }\n });\n return !result;\n });\n\n result || (result = wrapped);\n if (result == func) {\n result = forceCurry ? curry(result, 1) : function() {\n return func.apply(this, arguments);\n };\n }\n result.convert = createConverter(realName, func);\n if (mapping.placeholder[realName]) {\n setPlaceholder = true;\n result.placeholder = func.placeholder = placeholder;\n }\n return result;\n }\n\n /*--------------------------------------------------------------------------*/\n\n if (!isObj) {\n return wrap(name, func);\n }\n var _ = func;\n\n // Convert methods by ary cap.\n var pairs = [];\n each(aryMethodKeys, function(aryKey) {\n each(mapping.aryMethod[aryKey], function(key) {\n var func = _[mapping.remap[key] || key];\n if (func) {\n pairs.push([key, wrap(key, func)]);\n }\n });\n });\n\n // Convert remaining methods.\n each(keys(_), function(key) {\n var func = _[key];\n if (typeof func == 'function') {\n var length = pairs.length;\n while (length--) {\n if (pairs[length][0] == key) {\n return;\n }\n }\n func.convert = createConverter(key, func);\n pairs.push([key, func]);\n }\n });\n\n // Assign to `_` leaving `_.prototype` unchanged to allow chaining.\n each(pairs, function(pair) {\n _[pair[0]] = pair[1];\n });\n\n _.convert = convertLib;\n if (setPlaceholder) {\n _.placeholder = placeholder;\n }\n // Assign aliases.\n each(keys(_), function(key) {\n each(mapping.realToAlias[key] || [], function(alias) {\n _[alias] = _[key];\n });\n });\n\n return _;\n}\n\nmodule.exports = baseConvert;\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9ub2RlX21vZHVsZXMvbG9kYXNoL2ZwL19iYXNlQ29udmVydC5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL34vbG9kYXNoL2ZwL19iYXNlQ29udmVydC5qcz8zMmU3Il0sInNvdXJjZXNDb250ZW50IjpbInZhciBtYXBwaW5nID0gcmVxdWlyZSgnLi9fbWFwcGluZycpLFxuICAgIGZhbGxiYWNrSG9sZGVyID0gcmVxdWlyZSgnLi9wbGFjZWhvbGRlcicpO1xuXG4vKiogQnVpbHQtaW4gdmFsdWUgcmVmZXJlbmNlLiAqL1xudmFyIHB1c2ggPSBBcnJheS5wcm90b3R5cGUucHVzaDtcblxuLyoqXG4gKiBDcmVhdGVzIGEgZnVuY3Rpb24sIHdpdGggYW4gYXJpdHkgb2YgYG5gLCB0aGF0IGludm9rZXMgYGZ1bmNgIHdpdGggdGhlXG4gKiBhcmd1bWVudHMgaXQgcmVjZWl2ZXMuXG4gKlxuICogQHByaXZhdGVcbiAqIEBwYXJhbSB7RnVuY3Rpb259IGZ1bmMgVGhlIGZ1bmN0aW9uIHRvIHdyYXAuXG4gKiBAcGFyYW0ge251bWJlcn0gbiBUaGUgYXJpdHkgb2YgdGhlIG5ldyBmdW5jdGlvbi5cbiAqIEByZXR1cm5zIHtGdW5jdGlvbn0gUmV0dXJucyB0aGUgbmV3IGZ1bmN0aW9uLlxuICovXG5mdW5jdGlvbiBiYXNlQXJpdHkoZnVuYywgbikge1xuICByZXR1cm4gbiA9PSAyXG4gICAgPyBmdW5jdGlvbihhLCBiKSB7IHJldHVybiBmdW5jLmFwcGx5KHVuZGVmaW5lZCwgYXJndW1lbnRzKTsgfVxuICAgIDogZnVuY3Rpb24oYSkgeyByZXR1cm4gZnVuYy5hcHBseSh1bmRlZmluZWQsIGFyZ3VtZW50cyk7IH07XG59XG5cbi8qKlxuICogQ3JlYXRlcyBhIGZ1bmN0aW9uIHRoYXQgaW52b2tlcyBgZnVuY2AsIHdpdGggdXAgdG8gYG5gIGFyZ3VtZW50cywgaWdub3JpbmdcbiAqIGFueSBhZGRpdGlvbmFsIGFyZ3VtZW50cy5cbiAqXG4gKiBAcHJpdmF0ZVxuICogQHBhcmFtIHtGdW5jdGlvbn0gZnVuYyBUaGUgZnVuY3Rpb24gdG8gY2FwIGFyZ3VtZW50cyBmb3IuXG4gKiBAcGFyYW0ge251bWJlcn0gbiBUaGUgYXJpdHkgY2FwLlxuICogQHJldHVybnMge0Z1bmN0aW9ufSBSZXR1cm5zIHRoZSBuZXcgZnVuY3Rpb24uXG4gKi9cbmZ1bmN0aW9uIGJhc2VBcnkoZnVuYywgbikge1xuICByZXR1cm4gbiA9PSAyXG4gICAgPyBmdW5jdGlvbihhLCBiKSB7IHJldHVybiBmdW5jKGEsIGIpOyB9XG4gICAgOiBmdW5jdGlvbihhKSB7IHJldHVybiBmdW5jKGEpOyB9O1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSBjbG9uZSBvZiBgYXJyYXlgLlxuICpcbiAqIEBwcml2YXRlXG4gKiBAcGFyYW0ge0FycmF5fSBhcnJheSBUaGUgYXJyYXkgdG8gY2xvbmUuXG4gKiBAcmV0dXJucyB7QXJyYXl9IFJldHVybnMgdGhlIGNsb25lZCBhcnJheS5cbiAqL1xuZnVuY3Rpb24gY2xvbmVBcnJheShhcnJheSkge1xuICB2YXIgbGVuZ3RoID0gYXJyYXkgPyBhcnJheS5sZW5ndGggOiAwLFxuICAgICAgcmVzdWx0ID0gQXJyYXkobGVuZ3RoKTtcblxuICB3aGlsZSAobGVuZ3RoLS0pIHtcbiAgICByZXN1bHRbbGVuZ3RoXSA9IGFycmF5W2xlbmd0aF07XG4gIH1cbiAgcmV0dXJuIHJlc3VsdDtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgZnVuY3Rpb24gdGhhdCBjbG9uZXMgYSBnaXZlbiBvYmplY3QgdXNpbmcgdGhlIGFzc2lnbm1lbnQgYGZ1bmNgLlxuICpcbiAqIEBwcml2YXRlXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBmdW5jIFRoZSBhc3NpZ25tZW50IGZ1bmN0aW9uLlxuICogQHJldHVybnMge0Z1bmN0aW9ufSBSZXR1cm5zIHRoZSBuZXcgY2xvbmVyIGZ1bmN0aW9uLlxuICovXG5mdW5jdGlvbiBjcmVhdGVDbG9uZXIoZnVuYykge1xuICByZXR1cm4gZnVuY3Rpb24ob2JqZWN0KSB7XG4gICAgcmV0dXJuIGZ1bmMoe30sIG9iamVjdCk7XG4gIH07XG59XG5cbi8qKlxuICogQSBzcGVjaWFsaXplZCB2ZXJzaW9uIG9mIGBfLnNwcmVhZGAgd2hpY2ggZmxhdHRlbnMgdGhlIHNwcmVhZCBhcnJheSBpbnRvXG4gKiB0aGUgYXJndW1lbnRzIG9mIHRoZSBpbnZva2VkIGBmdW5jYC5cbiAqXG4gKiBAcHJpdmF0ZVxuICogQHBhcmFtIHtGdW5jdGlvbn0gZnVuYyBUaGUgZnVuY3Rpb24gdG8gc3ByZWFkIGFyZ3VtZW50cyBvdmVyLlxuICogQHBhcmFtIHtudW1iZXJ9IHN0YXJ0IFRoZSBzdGFydCBwb3NpdGlvbiBvZiB0aGUgc3ByZWFkLlxuICogQHJldHVybnMge0Z1bmN0aW9ufSBSZXR1cm5zIHRoZSBuZXcgZnVuY3Rpb24uXG4gKi9cbmZ1bmN0aW9uIGZsYXRTcHJlYWQoZnVuYywgc3RhcnQpIHtcbiAgcmV0dXJuIGZ1bmN0aW9uKCkge1xuICAgIHZhciBsZW5ndGggPSBhcmd1bWVudHMubGVuZ3RoLFxuICAgICAgICBsYXN0SW5kZXggPSBsZW5ndGggLSAxLFxuICAgICAgICBhcmdzID0gQXJyYXkobGVuZ3RoKTtcblxuICAgIHdoaWxlIChsZW5ndGgtLSkge1xuICAgICAgYXJnc1tsZW5ndGhdID0gYXJndW1lbnRzW2xlbmd0aF07XG4gICAgfVxuICAgIHZhciBhcnJheSA9IGFyZ3Nbc3RhcnRdLFxuICAgICAgICBvdGhlckFyZ3MgPSBhcmdzLnNsaWNlKDAsIHN0YXJ0KTtcblxuICAgIGlmIChhcnJheSkge1xuICAgICAgcHVzaC5hcHBseShvdGhlckFyZ3MsIGFycmF5KTtcbiAgICB9XG4gICAgaWYgKHN0YXJ0ICE9IGxhc3RJbmRleCkge1xuICAgICAgcHVzaC5hcHBseShvdGhlckFyZ3MsIGFyZ3Muc2xpY2Uoc3RhcnQgKyAxKSk7XG4gICAgfVxuICAgIHJldHVybiBmdW5jLmFwcGx5KHRoaXMsIG90aGVyQXJncyk7XG4gIH07XG59XG5cbi8qKlxuICogQ3JlYXRlcyBhIGZ1bmN0aW9uIHRoYXQgd3JhcHMgYGZ1bmNgIGFuZCB1c2VzIGBjbG9uZXJgIHRvIGNsb25lIHRoZSBmaXJzdFxuICogYXJndW1lbnQgaXQgcmVjZWl2ZXMuXG4gKlxuICogQHByaXZhdGVcbiAqIEBwYXJhbSB7RnVuY3Rpb259IGZ1bmMgVGhlIGZ1bmN0aW9uIHRvIHdyYXAuXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBjbG9uZXIgVGhlIGZ1bmN0aW9uIHRvIGNsb25lIGFyZ3VtZW50cy5cbiAqIEByZXR1cm5zIHtGdW5jdGlvbn0gUmV0dXJucyB0aGUgbmV3IGltbXV0YWJsZSBmdW5jdGlvbi5cbiAqL1xuZnVuY3Rpb24gd3JhcEltbXV0YWJsZShmdW5jLCBjbG9uZXIpIHtcbiAgcmV0dXJuIGZ1bmN0aW9uKCkge1xuICAgIHZhciBsZW5ndGggPSBhcmd1bWVudHMubGVuZ3RoO1xuICAgIGlmICghbGVuZ3RoKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIHZhciBhcmdzID0gQXJyYXkobGVuZ3RoKTtcbiAgICB3aGlsZSAobGVuZ3RoLS0pIHtcbiAgICAgIGFyZ3NbbGVuZ3RoXSA9IGFyZ3VtZW50c1tsZW5ndGhdO1xuICAgIH1cbiAgICB2YXIgcmVzdWx0ID0gYXJnc1swXSA9IGNsb25lci5hcHBseSh1bmRlZmluZWQsIGFyZ3MpO1xuICAgIGZ1bmMuYXBwbHkodW5kZWZpbmVkLCBhcmdzKTtcbiAgICByZXR1cm4gcmVzdWx0O1xuICB9O1xufVxuXG4vKipcbiAqIFRoZSBiYXNlIGltcGxlbWVudGF0aW9uIG9mIGBjb252ZXJ0YCB3aGljaCBhY2NlcHRzIGEgYHV0aWxgIG9iamVjdCBvZiBtZXRob2RzXG4gKiByZXF1aXJlZCB0byBwZXJmb3JtIGNvbnZlcnNpb25zLlxuICpcbiAqIEBwYXJhbSB7T2JqZWN0fSB1dGlsIFRoZSB1dGlsIG9iamVjdC5cbiAqIEBwYXJhbSB7c3RyaW5nfSBuYW1lIFRoZSBuYW1lIG9mIHRoZSBmdW5jdGlvbiB0byBjb252ZXJ0LlxuICogQHBhcmFtIHtGdW5jdGlvbn0gZnVuYyBUaGUgZnVuY3Rpb24gdG8gY29udmVydC5cbiAqIEBwYXJhbSB7T2JqZWN0fSBbb3B0aW9uc10gVGhlIG9wdGlvbnMgb2JqZWN0LlxuICogQHBhcmFtIHtib29sZWFufSBbb3B0aW9ucy5jYXA9dHJ1ZV0gU3BlY2lmeSBjYXBwaW5nIGl0ZXJhdGVlIGFyZ3VtZW50cy5cbiAqIEBwYXJhbSB7Ym9vbGVhbn0gW29wdGlvbnMuY3Vycnk9dHJ1ZV0gU3BlY2lmeSBjdXJyeWluZy5cbiAqIEBwYXJhbSB7Ym9vbGVhbn0gW29wdGlvbnMuZml4ZWQ9dHJ1ZV0gU3BlY2lmeSBmaXhlZCBhcml0eS5cbiAqIEBwYXJhbSB7Ym9vbGVhbn0gW29wdGlvbnMuaW1tdXRhYmxlPXRydWVdIFNwZWNpZnkgaW1tdXRhYmxlIG9wZXJhdGlvbnMuXG4gKiBAcGFyYW0ge2Jvb2xlYW59IFtvcHRpb25zLnJlYXJnPXRydWVdIFNwZWNpZnkgcmVhcnJhbmdpbmcgYXJndW1lbnRzLlxuICogQHJldHVybnMge0Z1bmN0aW9ufE9iamVjdH0gUmV0dXJucyB0aGUgY29udmVydGVkIGZ1bmN0aW9uIG9yIG9iamVjdC5cbiAqL1xuZnVuY3Rpb24gYmFzZUNvbnZlcnQodXRpbCwgbmFtZSwgZnVuYywgb3B0aW9ucykge1xuICB2YXIgc2V0UGxhY2Vob2xkZXIsXG4gICAgICBpc0xpYiA9IHR5cGVvZiBuYW1lID09ICdmdW5jdGlvbicsXG4gICAgICBpc09iaiA9IG5hbWUgPT09IE9iamVjdChuYW1lKTtcblxuICBpZiAoaXNPYmopIHtcbiAgICBvcHRpb25zID0gZnVuYztcbiAgICBmdW5jID0gbmFtZTtcbiAgICBuYW1lID0gdW5kZWZpbmVkO1xuICB9XG4gIGlmIChmdW5jID09IG51bGwpIHtcbiAgICB0aHJvdyBuZXcgVHlwZUVycm9yO1xuICB9XG4gIG9wdGlvbnMgfHwgKG9wdGlvbnMgPSB7fSk7XG5cbiAgdmFyIGNvbmZpZyA9IHtcbiAgICAnY2FwJzogJ2NhcCcgaW4gb3B0aW9ucyA/IG9wdGlvbnMuY2FwIDogdHJ1ZSxcbiAgICAnY3VycnknOiAnY3VycnknIGluIG9wdGlvbnMgPyBvcHRpb25zLmN1cnJ5IDogdHJ1ZSxcbiAgICAnZml4ZWQnOiAnZml4ZWQnIGluIG9wdGlvbnMgPyBvcHRpb25zLmZpeGVkIDogdHJ1ZSxcbiAgICAnaW1tdXRhYmxlJzogJ2ltbXV0YWJsZScgaW4gb3B0aW9ucyA/IG9wdGlvbnMuaW1tdXRhYmxlIDogdHJ1ZSxcbiAgICAncmVhcmcnOiAncmVhcmcnIGluIG9wdGlvbnMgPyBvcHRpb25zLnJlYXJnIDogdHJ1ZVxuICB9O1xuXG4gIHZhciBmb3JjZUN1cnJ5ID0gKCdjdXJyeScgaW4gb3B0aW9ucykgJiYgb3B0aW9ucy5jdXJyeSxcbiAgICAgIGZvcmNlRml4ZWQgPSAoJ2ZpeGVkJyBpbiBvcHRpb25zKSAmJiBvcHRpb25zLmZpeGVkLFxuICAgICAgZm9yY2VSZWFyZyA9ICgncmVhcmcnIGluIG9wdGlvbnMpICYmIG9wdGlvbnMucmVhcmcsXG4gICAgICBwbGFjZWhvbGRlciA9IGlzTGliID8gZnVuYyA6IGZhbGxiYWNrSG9sZGVyLFxuICAgICAgcHJpc3RpbmUgPSBpc0xpYiA/IGZ1bmMucnVuSW5Db250ZXh0KCkgOiB1bmRlZmluZWQ7XG5cbiAgdmFyIGhlbHBlcnMgPSBpc0xpYiA/IGZ1bmMgOiB7XG4gICAgJ2FyeSc6IHV0aWwuYXJ5LFxuICAgICdhc3NpZ24nOiB1dGlsLmFzc2lnbixcbiAgICAnY2xvbmUnOiB1dGlsLmNsb25lLFxuICAgICdjdXJyeSc6IHV0aWwuY3VycnksXG4gICAgJ2ZvckVhY2gnOiB1dGlsLmZvckVhY2gsXG4gICAgJ2lzQXJyYXknOiB1dGlsLmlzQXJyYXksXG4gICAgJ2lzRnVuY3Rpb24nOiB1dGlsLmlzRnVuY3Rpb24sXG4gICAgJ2l0ZXJhdGVlJzogdXRpbC5pdGVyYXRlZSxcbiAgICAna2V5cyc6IHV0aWwua2V5cyxcbiAgICAncmVhcmcnOiB1dGlsLnJlYXJnLFxuICAgICd0b0ludGVnZXInOiB1dGlsLnRvSW50ZWdlcixcbiAgICAndG9QYXRoJzogdXRpbC50b1BhdGhcbiAgfTtcblxuICB2YXIgYXJ5ID0gaGVscGVycy5hcnksXG4gICAgICBhc3NpZ24gPSBoZWxwZXJzLmFzc2lnbixcbiAgICAgIGNsb25lID0gaGVscGVycy5jbG9uZSxcbiAgICAgIGN1cnJ5ID0gaGVscGVycy5jdXJyeSxcbiAgICAgIGVhY2ggPSBoZWxwZXJzLmZvckVhY2gsXG4gICAgICBpc0FycmF5ID0gaGVscGVycy5pc0FycmF5LFxuICAgICAgaXNGdW5jdGlvbiA9IGhlbHBlcnMuaXNGdW5jdGlvbixcbiAgICAgIGtleXMgPSBoZWxwZXJzLmtleXMsXG4gICAgICByZWFyZyA9IGhlbHBlcnMucmVhcmcsXG4gICAgICB0b0ludGVnZXIgPSBoZWxwZXJzLnRvSW50ZWdlcixcbiAgICAgIHRvUGF0aCA9IGhlbHBlcnMudG9QYXRoO1xuXG4gIHZhciBhcnlNZXRob2RLZXlzID0ga2V5cyhtYXBwaW5nLmFyeU1ldGhvZCk7XG5cbiAgdmFyIHdyYXBwZXJzID0ge1xuICAgICdjYXN0QXJyYXknOiBmdW5jdGlvbihjYXN0QXJyYXkpIHtcbiAgICAgIHJldHVybiBmdW5jdGlvbigpIHtcbiAgICAgICAgdmFyIHZhbHVlID0gYXJndW1lbnRzWzBdO1xuICAgICAgICByZXR1cm4gaXNBcnJheSh2YWx1ZSlcbiAgICAgICAgICA/IGNhc3RBcnJheShjbG9uZUFycmF5KHZhbHVlKSlcbiAgICAgICAgICA6IGNhc3RBcnJheS5hcHBseSh1bmRlZmluZWQsIGFyZ3VtZW50cyk7XG4gICAgICB9O1xuICAgIH0sXG4gICAgJ2l0ZXJhdGVlJzogZnVuY3Rpb24oaXRlcmF0ZWUpIHtcbiAgICAgIHJldHVybiBmdW5jdGlvbigpIHtcbiAgICAgICAgdmFyIGZ1bmMgPSBhcmd1bWVudHNbMF0sXG4gICAgICAgICAgICBhcml0eSA9IGFyZ3VtZW50c1sxXSxcbiAgICAgICAgICAgIHJlc3VsdCA9IGl0ZXJhdGVlKGZ1bmMsIGFyaXR5KSxcbiAgICAgICAgICAgIGxlbmd0aCA9IHJlc3VsdC5sZW5ndGg7XG5cbiAgICAgICAgaWYgKGNvbmZpZy5jYXAgJiYgdHlwZW9mIGFyaXR5ID09ICdudW1iZXInKSB7XG4gICAgICAgICAgYXJpdHkgPSBhcml0eSA+IDIgPyAoYXJpdHkgLSAyKSA6IDE7XG4gICAgICAgICAgcmV0dXJuIChsZW5ndGggJiYgbGVuZ3RoIDw9IGFyaXR5KSA/IHJlc3VsdCA6IGJhc2VBcnkocmVzdWx0LCBhcml0eSk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHJlc3VsdDtcbiAgICAgIH07XG4gICAgfSxcbiAgICAnbWl4aW4nOiBmdW5jdGlvbihtaXhpbikge1xuICAgICAgcmV0dXJuIGZ1bmN0aW9uKHNvdXJjZSkge1xuICAgICAgICB2YXIgZnVuYyA9IHRoaXM7XG4gICAgICAgIGlmICghaXNGdW5jdGlvbihmdW5jKSkge1xuICAgICAgICAgIHJldHVybiBtaXhpbihmdW5jLCBPYmplY3Qoc291cmNlKSk7XG4gICAgICAgIH1cbiAgICAgICAgdmFyIHBhaXJzID0gW107XG4gICAgICAgIGVhY2goa2V5cyhzb3VyY2UpLCBmdW5jdGlvbihrZXkpIHtcbiAgICAgICAgICBpZiAoaXNGdW5jdGlvbihzb3VyY2Vba2V5XSkpIHtcbiAgICAgICAgICAgIHBhaXJzLnB1c2goW2tleSwgZnVuYy5wcm90b3R5cGVba2V5XV0pO1xuICAgICAgICAgIH1cbiAgICAgICAgfSk7XG5cbiAgICAgICAgbWl4aW4oZnVuYywgT2JqZWN0KHNvdXJjZSkpO1xuXG4gICAgICAgIGVhY2gocGFpcnMsIGZ1bmN0aW9uKHBhaXIpIHtcbiAgICAgICAgICB2YXIgdmFsdWUgPSBwYWlyWzFdO1xuICAgICAgICAgIGlmIChpc0Z1bmN0aW9uKHZhbHVlKSkge1xuICAgICAgICAgICAgZnVuYy5wcm90b3R5cGVbcGFpclswXV0gPSB2YWx1ZTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgZGVsZXRlIGZ1bmMucHJvdG90eXBlW3BhaXJbMF1dO1xuICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgICAgIHJldHVybiBmdW5jO1xuICAgICAgfTtcbiAgICB9LFxuICAgICdudGhBcmcnOiBmdW5jdGlvbihudGhBcmcpIHtcbiAgICAgIHJldHVybiBmdW5jdGlvbihuKSB7XG4gICAgICAgIHZhciBhcml0eSA9IG4gPCAwID8gMSA6ICh0b0ludGVnZXIobikgKyAxKTtcbiAgICAgICAgcmV0dXJuIGN1cnJ5KG50aEFyZyhuKSwgYXJpdHkpO1xuICAgICAgfTtcbiAgICB9LFxuICAgICdyZWFyZyc6IGZ1bmN0aW9uKHJlYXJnKSB7XG4gICAgICByZXR1cm4gZnVuY3Rpb24oZnVuYywgaW5kZXhlcykge1xuICAgICAgICB2YXIgYXJpdHkgPSBpbmRleGVzID8gaW5kZXhlcy5sZW5ndGggOiAwO1xuICAgICAgICByZXR1cm4gY3VycnkocmVhcmcoZnVuYywgaW5kZXhlcyksIGFyaXR5KTtcbiAgICAgIH07XG4gICAgfSxcbiAgICAncnVuSW5Db250ZXh0JzogZnVuY3Rpb24ocnVuSW5Db250ZXh0KSB7XG4gICAgICByZXR1cm4gZnVuY3Rpb24oY29udGV4dCkge1xuICAgICAgICByZXR1cm4gYmFzZUNvbnZlcnQodXRpbCwgcnVuSW5Db250ZXh0KGNvbnRleHQpLCBvcHRpb25zKTtcbiAgICAgIH07XG4gICAgfVxuICB9O1xuXG4gIC8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0qL1xuXG4gIC8qKlxuICAgKiBDYXN0cyBgZnVuY2AgdG8gYSBmdW5jdGlvbiB3aXRoIGFuIGFyaXR5IGNhcHBlZCBpdGVyYXRlZSBpZiBuZWVkZWQuXG4gICAqXG4gICAqIEBwcml2YXRlXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBuYW1lIFRoZSBuYW1lIG9mIHRoZSBmdW5jdGlvbiB0byBpbnNwZWN0LlxuICAgKiBAcGFyYW0ge0Z1bmN0aW9ufSBmdW5jIFRoZSBmdW5jdGlvbiB0byBpbnNwZWN0LlxuICAgKiBAcmV0dXJucyB7RnVuY3Rpb259IFJldHVybnMgdGhlIGNhc3QgZnVuY3Rpb24uXG4gICAqL1xuICBmdW5jdGlvbiBjYXN0Q2FwKG5hbWUsIGZ1bmMpIHtcbiAgICBpZiAoY29uZmlnLmNhcCkge1xuICAgICAgdmFyIGluZGV4ZXMgPSBtYXBwaW5nLml0ZXJhdGVlUmVhcmdbbmFtZV07XG4gICAgICBpZiAoaW5kZXhlcykge1xuICAgICAgICByZXR1cm4gaXRlcmF0ZWVSZWFyZyhmdW5jLCBpbmRleGVzKTtcbiAgICAgIH1cbiAgICAgIHZhciBuID0gIWlzTGliICYmIG1hcHBpbmcuaXRlcmF0ZWVBcnlbbmFtZV07XG4gICAgICBpZiAobikge1xuICAgICAgICByZXR1cm4gaXRlcmF0ZWVBcnkoZnVuYywgbik7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiBmdW5jO1xuICB9XG5cbiAgLyoqXG4gICAqIENhc3RzIGBmdW5jYCB0byBhIGN1cnJpZWQgZnVuY3Rpb24gaWYgbmVlZGVkLlxuICAgKlxuICAgKiBAcHJpdmF0ZVxuICAgKiBAcGFyYW0ge3N0cmluZ30gbmFtZSBUaGUgbmFtZSBvZiB0aGUgZnVuY3Rpb24gdG8gaW5zcGVjdC5cbiAgICogQHBhcmFtIHtGdW5jdGlvbn0gZnVuYyBUaGUgZnVuY3Rpb24gdG8gaW5zcGVjdC5cbiAgICogQHBhcmFtIHtudW1iZXJ9IG4gVGhlIGFyaXR5IG9mIGBmdW5jYC5cbiAgICogQHJldHVybnMge0Z1bmN0aW9ufSBSZXR1cm5zIHRoZSBjYXN0IGZ1bmN0aW9uLlxuICAgKi9cbiAgZnVuY3Rpb24gY2FzdEN1cnJ5KG5hbWUsIGZ1bmMsIG4pIHtcbiAgICByZXR1cm4gKGZvcmNlQ3VycnkgfHwgKGNvbmZpZy5jdXJyeSAmJiBuID4gMSkpXG4gICAgICA/IGN1cnJ5KGZ1bmMsIG4pXG4gICAgICA6IGZ1bmM7XG4gIH1cblxuICAvKipcbiAgICogQ2FzdHMgYGZ1bmNgIHRvIGEgZml4ZWQgYXJpdHkgZnVuY3Rpb24gaWYgbmVlZGVkLlxuICAgKlxuICAgKiBAcHJpdmF0ZVxuICAgKiBAcGFyYW0ge3N0cmluZ30gbmFtZSBUaGUgbmFtZSBvZiB0aGUgZnVuY3Rpb24gdG8gaW5zcGVjdC5cbiAgICogQHBhcmFtIHtGdW5jdGlvbn0gZnVuYyBUaGUgZnVuY3Rpb24gdG8gaW5zcGVjdC5cbiAgICogQHBhcmFtIHtudW1iZXJ9IG4gVGhlIGFyaXR5IGNhcC5cbiAgICogQHJldHVybnMge0Z1bmN0aW9ufSBSZXR1cm5zIHRoZSBjYXN0IGZ1bmN0aW9uLlxuICAgKi9cbiAgZnVuY3Rpb24gY2FzdEZpeGVkKG5hbWUsIGZ1bmMsIG4pIHtcbiAgICBpZiAoY29uZmlnLmZpeGVkICYmIChmb3JjZUZpeGVkIHx8ICFtYXBwaW5nLnNraXBGaXhlZFtuYW1lXSkpIHtcbiAgICAgIHZhciBkYXRhID0gbWFwcGluZy5tZXRob2RTcHJlYWRbbmFtZV0sXG4gICAgICAgICAgc3RhcnQgPSBkYXRhICYmIGRhdGEuc3RhcnQ7XG5cbiAgICAgIHJldHVybiBzdGFydCAgPT09IHVuZGVmaW5lZCA/IGFyeShmdW5jLCBuKSA6IGZsYXRTcHJlYWQoZnVuYywgc3RhcnQpO1xuICAgIH1cbiAgICByZXR1cm4gZnVuYztcbiAgfVxuXG4gIC8qKlxuICAgKiBDYXN0cyBgZnVuY2AgdG8gYW4gcmVhcmdlZCBmdW5jdGlvbiBpZiBuZWVkZWQuXG4gICAqXG4gICAqIEBwcml2YXRlXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBuYW1lIFRoZSBuYW1lIG9mIHRoZSBmdW5jdGlvbiB0byBpbnNwZWN0LlxuICAgKiBAcGFyYW0ge0Z1bmN0aW9ufSBmdW5jIFRoZSBmdW5jdGlvbiB0byBpbnNwZWN0LlxuICAgKiBAcGFyYW0ge251bWJlcn0gbiBUaGUgYXJpdHkgb2YgYGZ1bmNgLlxuICAgKiBAcmV0dXJucyB7RnVuY3Rpb259IFJldHVybnMgdGhlIGNhc3QgZnVuY3Rpb24uXG4gICAqL1xuICBmdW5jdGlvbiBjYXN0UmVhcmcobmFtZSwgZnVuYywgbikge1xuICAgIHJldHVybiAoY29uZmlnLnJlYXJnICYmIG4gPiAxICYmIChmb3JjZVJlYXJnIHx8ICFtYXBwaW5nLnNraXBSZWFyZ1tuYW1lXSkpXG4gICAgICA/IHJlYXJnKGZ1bmMsIG1hcHBpbmcubWV0aG9kUmVhcmdbbmFtZV0gfHwgbWFwcGluZy5hcnlSZWFyZ1tuXSlcbiAgICAgIDogZnVuYztcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgY2xvbmUgb2YgYG9iamVjdGAgYnkgYHBhdGhgLlxuICAgKlxuICAgKiBAcHJpdmF0ZVxuICAgKiBAcGFyYW0ge09iamVjdH0gb2JqZWN0IFRoZSBvYmplY3QgdG8gY2xvbmUuXG4gICAqIEBwYXJhbSB7QXJyYXl8c3RyaW5nfSBwYXRoIFRoZSBwYXRoIHRvIGNsb25lIGJ5LlxuICAgKiBAcmV0dXJucyB7T2JqZWN0fSBSZXR1cm5zIHRoZSBjbG9uZWQgb2JqZWN0LlxuICAgKi9cbiAgZnVuY3Rpb24gY2xvbmVCeVBhdGgob2JqZWN0LCBwYXRoKSB7XG4gICAgcGF0aCA9IHRvUGF0aChwYXRoKTtcblxuICAgIHZhciBpbmRleCA9IC0xLFxuICAgICAgICBsZW5ndGggPSBwYXRoLmxlbmd0aCxcbiAgICAgICAgbGFzdEluZGV4ID0gbGVuZ3RoIC0gMSxcbiAgICAgICAgcmVzdWx0ID0gY2xvbmUoT2JqZWN0KG9iamVjdCkpLFxuICAgICAgICBuZXN0ZWQgPSByZXN1bHQ7XG5cbiAgICB3aGlsZSAobmVzdGVkICE9IG51bGwgJiYgKytpbmRleCA8IGxlbmd0aCkge1xuICAgICAgdmFyIGtleSA9IHBhdGhbaW5kZXhdLFxuICAgICAgICAgIHZhbHVlID0gbmVzdGVkW2tleV07XG5cbiAgICAgIGlmICh2YWx1ZSAhPSBudWxsKSB7XG4gICAgICAgIG5lc3RlZFtwYXRoW2luZGV4XV0gPSBjbG9uZShpbmRleCA9PSBsYXN0SW5kZXggPyB2YWx1ZSA6IE9iamVjdCh2YWx1ZSkpO1xuICAgICAgfVxuICAgICAgbmVzdGVkID0gbmVzdGVkW2tleV07XG4gICAgfVxuICAgIHJldHVybiByZXN1bHQ7XG4gIH1cblxuICAvKipcbiAgICogQ29udmVydHMgYGxvZGFzaGAgdG8gYW4gaW1tdXRhYmxlIGF1dG8tY3VycmllZCBpdGVyYXRlZS1maXJzdCBkYXRhLWxhc3RcbiAgICogdmVyc2lvbiB3aXRoIGNvbnZlcnNpb24gYG9wdGlvbnNgIGFwcGxpZWQuXG4gICAqXG4gICAqIEBwYXJhbSB7T2JqZWN0fSBbb3B0aW9uc10gVGhlIG9wdGlvbnMgb2JqZWN0LiBTZWUgYGJhc2VDb252ZXJ0YCBmb3IgbW9yZSBkZXRhaWxzLlxuICAgKiBAcmV0dXJucyB7RnVuY3Rpb259IFJldHVybnMgdGhlIGNvbnZlcnRlZCBgbG9kYXNoYC5cbiAgICovXG4gIGZ1bmN0aW9uIGNvbnZlcnRMaWIob3B0aW9ucykge1xuICAgIHJldHVybiBfLnJ1bkluQ29udGV4dC5jb252ZXJ0KG9wdGlvbnMpKHVuZGVmaW5lZCk7XG4gIH1cblxuICAvKipcbiAgICogQ3JlYXRlIGEgY29udmVydGVyIGZ1bmN0aW9uIGZvciBgZnVuY2Agb2YgYG5hbWVgLlxuICAgKlxuICAgKiBAcGFyYW0ge3N0cmluZ30gbmFtZSBUaGUgbmFtZSBvZiB0aGUgZnVuY3Rpb24gdG8gY29udmVydC5cbiAgICogQHBhcmFtIHtGdW5jdGlvbn0gZnVuYyBUaGUgZnVuY3Rpb24gdG8gY29udmVydC5cbiAgICogQHJldHVybnMge0Z1bmN0aW9ufSBSZXR1cm5zIHRoZSBuZXcgY29udmVydGVyIGZ1bmN0aW9uLlxuICAgKi9cbiAgZnVuY3Rpb24gY3JlYXRlQ29udmVydGVyKG5hbWUsIGZ1bmMpIHtcbiAgICB2YXIgcmVhbE5hbWUgPSBtYXBwaW5nLmFsaWFzVG9SZWFsW25hbWVdIHx8IG5hbWUsXG4gICAgICAgIG1ldGhvZE5hbWUgPSBtYXBwaW5nLnJlbWFwW3JlYWxOYW1lXSB8fCByZWFsTmFtZSxcbiAgICAgICAgb2xkT3B0aW9ucyA9IG9wdGlvbnM7XG5cbiAgICByZXR1cm4gZnVuY3Rpb24ob3B0aW9ucykge1xuICAgICAgdmFyIG5ld1V0aWwgPSBpc0xpYiA/IHByaXN0aW5lIDogaGVscGVycyxcbiAgICAgICAgICBuZXdGdW5jID0gaXNMaWIgPyBwcmlzdGluZVttZXRob2ROYW1lXSA6IGZ1bmMsXG4gICAgICAgICAgbmV3T3B0aW9ucyA9IGFzc2lnbihhc3NpZ24oe30sIG9sZE9wdGlvbnMpLCBvcHRpb25zKTtcblxuICAgICAgcmV0dXJuIGJhc2VDb252ZXJ0KG5ld1V0aWwsIHJlYWxOYW1lLCBuZXdGdW5jLCBuZXdPcHRpb25zKTtcbiAgICB9O1xuICB9XG5cbiAgLyoqXG4gICAqIENyZWF0ZXMgYSBmdW5jdGlvbiB0aGF0IHdyYXBzIGBmdW5jYCB0byBpbnZva2UgaXRzIGl0ZXJhdGVlLCB3aXRoIHVwIHRvIGBuYFxuICAgKiBhcmd1bWVudHMsIGlnbm9yaW5nIGFueSBhZGRpdGlvbmFsIGFyZ3VtZW50cy5cbiAgICpcbiAgICogQHByaXZhdGVcbiAgICogQHBhcmFtIHtGdW5jdGlvbn0gZnVuYyBUaGUgZnVuY3Rpb24gdG8gY2FwIGl0ZXJhdGVlIGFyZ3VtZW50cyBmb3IuXG4gICAqIEBwYXJhbSB7bnVtYmVyfSBuIFRoZSBhcml0eSBjYXAuXG4gICAqIEByZXR1cm5zIHtGdW5jdGlvbn0gUmV0dXJucyB0aGUgbmV3IGZ1bmN0aW9uLlxuICAgKi9cbiAgZnVuY3Rpb24gaXRlcmF0ZWVBcnkoZnVuYywgbikge1xuICAgIHJldHVybiBvdmVyQXJnKGZ1bmMsIGZ1bmN0aW9uKGZ1bmMpIHtcbiAgICAgIHJldHVybiB0eXBlb2YgZnVuYyA9PSAnZnVuY3Rpb24nID8gYmFzZUFyeShmdW5jLCBuKSA6IGZ1bmM7XG4gICAgfSk7XG4gIH1cblxuICAvKipcbiAgICogQ3JlYXRlcyBhIGZ1bmN0aW9uIHRoYXQgd3JhcHMgYGZ1bmNgIHRvIGludm9rZSBpdHMgaXRlcmF0ZWUgd2l0aCBhcmd1bWVudHNcbiAgICogYXJyYW5nZWQgYWNjb3JkaW5nIHRvIHRoZSBzcGVjaWZpZWQgYGluZGV4ZXNgIHdoZXJlIHRoZSBhcmd1bWVudCB2YWx1ZSBhdFxuICAgKiB0aGUgZmlyc3QgaW5kZXggaXMgcHJvdmlkZWQgYXMgdGhlIGZpcnN0IGFyZ3VtZW50LCB0aGUgYXJndW1lbnQgdmFsdWUgYXRcbiAgICogdGhlIHNlY29uZCBpbmRleCBpcyBwcm92aWRlZCBhcyB0aGUgc2Vjb25kIGFyZ3VtZW50LCBhbmQgc28gb24uXG4gICAqXG4gICAqIEBwcml2YXRlXG4gICAqIEBwYXJhbSB7RnVuY3Rpb259IGZ1bmMgVGhlIGZ1bmN0aW9uIHRvIHJlYXJyYW5nZSBpdGVyYXRlZSBhcmd1bWVudHMgZm9yLlxuICAgKiBAcGFyYW0ge251bWJlcltdfSBpbmRleGVzIFRoZSBhcnJhbmdlZCBhcmd1bWVudCBpbmRleGVzLlxuICAgKiBAcmV0dXJucyB7RnVuY3Rpb259IFJldHVybnMgdGhlIG5ldyBmdW5jdGlvbi5cbiAgICovXG4gIGZ1bmN0aW9uIGl0ZXJhdGVlUmVhcmcoZnVuYywgaW5kZXhlcykge1xuICAgIHJldHVybiBvdmVyQXJnKGZ1bmMsIGZ1bmN0aW9uKGZ1bmMpIHtcbiAgICAgIHZhciBuID0gaW5kZXhlcy5sZW5ndGg7XG4gICAgICByZXR1cm4gYmFzZUFyaXR5KHJlYXJnKGJhc2VBcnkoZnVuYywgbiksIGluZGV4ZXMpLCBuKTtcbiAgICB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgZnVuY3Rpb24gdGhhdCBpbnZva2VzIGBmdW5jYCB3aXRoIGl0cyBmaXJzdCBhcmd1bWVudCB0cmFuc2Zvcm1lZC5cbiAgICpcbiAgICogQHByaXZhdGVcbiAgICogQHBhcmFtIHtGdW5jdGlvbn0gZnVuYyBUaGUgZnVuY3Rpb24gdG8gd3JhcC5cbiAgICogQHBhcmFtIHtGdW5jdGlvbn0gdHJhbnNmb3JtIFRoZSBhcmd1bWVudCB0cmFuc2Zvcm0uXG4gICAqIEByZXR1cm5zIHtGdW5jdGlvbn0gUmV0dXJucyB0aGUgbmV3IGZ1bmN0aW9uLlxuICAgKi9cbiAgZnVuY3Rpb24gb3ZlckFyZyhmdW5jLCB0cmFuc2Zvcm0pIHtcbiAgICByZXR1cm4gZnVuY3Rpb24oKSB7XG4gICAgICB2YXIgbGVuZ3RoID0gYXJndW1lbnRzLmxlbmd0aDtcbiAgICAgIGlmICghbGVuZ3RoKSB7XG4gICAgICAgIHJldHVybiBmdW5jKCk7XG4gICAgICB9XG4gICAgICB2YXIgYXJncyA9IEFycmF5KGxlbmd0aCk7XG4gICAgICB3aGlsZSAobGVuZ3RoLS0pIHtcbiAgICAgICAgYXJnc1tsZW5ndGhdID0gYXJndW1lbnRzW2xlbmd0aF07XG4gICAgICB9XG4gICAgICB2YXIgaW5kZXggPSBjb25maWcucmVhcmcgPyAwIDogKGxlbmd0aCAtIDEpO1xuICAgICAgYXJnc1tpbmRleF0gPSB0cmFuc2Zvcm0oYXJnc1tpbmRleF0pO1xuICAgICAgcmV0dXJuIGZ1bmMuYXBwbHkodW5kZWZpbmVkLCBhcmdzKTtcbiAgICB9O1xuICB9XG5cbiAgLyoqXG4gICAqIENyZWF0ZXMgYSBmdW5jdGlvbiB0aGF0IHdyYXBzIGBmdW5jYCBhbmQgYXBwbHlzIHRoZSBjb252ZXJzaW9uc1xuICAgKiBydWxlcyBieSBgbmFtZWAuXG4gICAqXG4gICAqIEBwcml2YXRlXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBuYW1lIFRoZSBuYW1lIG9mIHRoZSBmdW5jdGlvbiB0byB3cmFwLlxuICAgKiBAcGFyYW0ge0Z1bmN0aW9ufSBmdW5jIFRoZSBmdW5jdGlvbiB0byB3cmFwLlxuICAgKiBAcmV0dXJucyB7RnVuY3Rpb259IFJldHVybnMgdGhlIGNvbnZlcnRlZCBmdW5jdGlvbi5cbiAgICovXG4gIGZ1bmN0aW9uIHdyYXAobmFtZSwgZnVuYykge1xuICAgIHZhciByZXN1bHQsXG4gICAgICAgIHJlYWxOYW1lID0gbWFwcGluZy5hbGlhc1RvUmVhbFtuYW1lXSB8fCBuYW1lLFxuICAgICAgICB3cmFwcGVkID0gZnVuYyxcbiAgICAgICAgd3JhcHBlciA9IHdyYXBwZXJzW3JlYWxOYW1lXTtcblxuICAgIGlmICh3cmFwcGVyKSB7XG4gICAgICB3cmFwcGVkID0gd3JhcHBlcihmdW5jKTtcbiAgICB9XG4gICAgZWxzZSBpZiAoY29uZmlnLmltbXV0YWJsZSkge1xuICAgICAgaWYgKG1hcHBpbmcubXV0YXRlLmFycmF5W3JlYWxOYW1lXSkge1xuICAgICAgICB3cmFwcGVkID0gd3JhcEltbXV0YWJsZShmdW5jLCBjbG9uZUFycmF5KTtcbiAgICAgIH1cbiAgICAgIGVsc2UgaWYgKG1hcHBpbmcubXV0YXRlLm9iamVjdFtyZWFsTmFtZV0pIHtcbiAgICAgICAgd3JhcHBlZCA9IHdyYXBJbW11dGFibGUoZnVuYywgY3JlYXRlQ2xvbmVyKGZ1bmMpKTtcbiAgICAgIH1cbiAgICAgIGVsc2UgaWYgKG1hcHBpbmcubXV0YXRlLnNldFtyZWFsTmFtZV0pIHtcbiAgICAgICAgd3JhcHBlZCA9IHdyYXBJbW11dGFibGUoZnVuYywgY2xvbmVCeVBhdGgpO1xuICAgICAgfVxuICAgIH1cbiAgICBlYWNoKGFyeU1ldGhvZEtleXMsIGZ1bmN0aW9uKGFyeUtleSkge1xuICAgICAgZWFjaChtYXBwaW5nLmFyeU1ldGhvZFthcnlLZXldLCBmdW5jdGlvbihvdGhlck5hbWUpIHtcbiAgICAgICAgaWYgKHJlYWxOYW1lID09IG90aGVyTmFtZSkge1xuICAgICAgICAgIHZhciBkYXRhID0gbWFwcGluZy5tZXRob2RTcHJlYWRbcmVhbE5hbWVdLFxuICAgICAgICAgICAgICBhZnRlclJlYXJnID0gZGF0YSAmJiBkYXRhLmFmdGVyUmVhcmc7XG5cbiAgICAgICAgICByZXN1bHQgPSBhZnRlclJlYXJnXG4gICAgICAgICAgICA/IGNhc3RGaXhlZChyZWFsTmFtZSwgY2FzdFJlYXJnKHJlYWxOYW1lLCB3cmFwcGVkLCBhcnlLZXkpLCBhcnlLZXkpXG4gICAgICAgICAgICA6IGNhc3RSZWFyZyhyZWFsTmFtZSwgY2FzdEZpeGVkKHJlYWxOYW1lLCB3cmFwcGVkLCBhcnlLZXkpLCBhcnlLZXkpO1xuXG4gICAgICAgICAgcmVzdWx0ID0gY2FzdENhcChyZWFsTmFtZSwgcmVzdWx0KTtcbiAgICAgICAgICByZXN1bHQgPSBjYXN0Q3VycnkocmVhbE5hbWUsIHJlc3VsdCwgYXJ5S2V5KTtcbiAgICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICAgIH1cbiAgICAgIH0pO1xuICAgICAgcmV0dXJuICFyZXN1bHQ7XG4gICAgfSk7XG5cbiAgICByZXN1bHQgfHwgKHJlc3VsdCA9IHdyYXBwZWQpO1xuICAgIGlmIChyZXN1bHQgPT0gZnVuYykge1xuICAgICAgcmVzdWx0ID0gZm9yY2VDdXJyeSA/IGN1cnJ5KHJlc3VsdCwgMSkgOiBmdW5jdGlvbigpIHtcbiAgICAgICAgcmV0dXJuIGZ1bmMuYXBwbHkodGhpcywgYXJndW1lbnRzKTtcbiAgICAgIH07XG4gICAgfVxuICAgIHJlc3VsdC5jb252ZXJ0ID0gY3JlYXRlQ29udmVydGVyKHJlYWxOYW1lLCBmdW5jKTtcbiAgICBpZiAobWFwcGluZy5wbGFjZWhvbGRlcltyZWFsTmFtZV0pIHtcbiAgICAgIHNldFBsYWNlaG9sZGVyID0gdHJ1ZTtcbiAgICAgIHJlc3VsdC5wbGFjZWhvbGRlciA9IGZ1bmMucGxhY2Vob2xkZXIgPSBwbGFjZWhvbGRlcjtcbiAgICB9XG4gICAgcmV0dXJuIHJlc3VsdDtcbiAgfVxuXG4gIC8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0qL1xuXG4gIGlmICghaXNPYmopIHtcbiAgICByZXR1cm4gd3JhcChuYW1lLCBmdW5jKTtcbiAgfVxuICB2YXIgXyA9IGZ1bmM7XG5cbiAgLy8gQ29udmVydCBtZXRob2RzIGJ5IGFyeSBjYXAuXG4gIHZhciBwYWlycyA9IFtdO1xuICBlYWNoKGFyeU1ldGhvZEtleXMsIGZ1bmN0aW9uKGFyeUtleSkge1xuICAgIGVhY2gobWFwcGluZy5hcnlNZXRob2RbYXJ5S2V5XSwgZnVuY3Rpb24oa2V5KSB7XG4gICAgICB2YXIgZnVuYyA9IF9bbWFwcGluZy5yZW1hcFtrZXldIHx8IGtleV07XG4gICAgICBpZiAoZnVuYykge1xuICAgICAgICBwYWlycy5wdXNoKFtrZXksIHdyYXAoa2V5LCBmdW5jKV0pO1xuICAgICAgfVxuICAgIH0pO1xuICB9KTtcblxuICAvLyBDb252ZXJ0IHJlbWFpbmluZyBtZXRob2RzLlxuICBlYWNoKGtleXMoXyksIGZ1bmN0aW9uKGtleSkge1xuICAgIHZhciBmdW5jID0gX1trZXldO1xuICAgIGlmICh0eXBlb2YgZnVuYyA9PSAnZnVuY3Rpb24nKSB7XG4gICAgICB2YXIgbGVuZ3RoID0gcGFpcnMubGVuZ3RoO1xuICAgICAgd2hpbGUgKGxlbmd0aC0tKSB7XG4gICAgICAgIGlmIChwYWlyc1tsZW5ndGhdWzBdID09IGtleSkge1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgZnVuYy5jb252ZXJ0ID0gY3JlYXRlQ29udmVydGVyKGtleSwgZnVuYyk7XG4gICAgICBwYWlycy5wdXNoKFtrZXksIGZ1bmNdKTtcbiAgICB9XG4gIH0pO1xuXG4gIC8vIEFzc2lnbiB0byBgX2AgbGVhdmluZyBgXy5wcm90b3R5cGVgIHVuY2hhbmdlZCB0byBhbGxvdyBjaGFpbmluZy5cbiAgZWFjaChwYWlycywgZnVuY3Rpb24ocGFpcikge1xuICAgIF9bcGFpclswXV0gPSBwYWlyWzFdO1xuICB9KTtcblxuICBfLmNvbnZlcnQgPSBjb252ZXJ0TGliO1xuICBpZiAoc2V0UGxhY2Vob2xkZXIpIHtcbiAgICBfLnBsYWNlaG9sZGVyID0gcGxhY2Vob2xkZXI7XG4gIH1cbiAgLy8gQXNzaWduIGFsaWFzZXMuXG4gIGVhY2goa2V5cyhfKSwgZnVuY3Rpb24oa2V5KSB7XG4gICAgZWFjaChtYXBwaW5nLnJlYWxUb0FsaWFzW2tleV0gfHwgW10sIGZ1bmN0aW9uKGFsaWFzKSB7XG4gICAgICBfW2FsaWFzXSA9IF9ba2V5XTtcbiAgICB9KTtcbiAgfSk7XG5cbiAgcmV0dXJuIF87XG59XG5cbm1vZHVsZS5leHBvcnRzID0gYmFzZUNvbnZlcnQ7XG5cblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL34vbG9kYXNoL2ZwL19iYXNlQ29udmVydC5qc1xuLy8gbW9kdWxlIGlkID0gLi9ub2RlX21vZHVsZXMvbG9kYXNoL2ZwL19iYXNlQ29udmVydC5qc1xuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOyIsInNvdXJjZVJvb3QiOiIifQ=="); +var mapping = __webpack_require__("./node_modules/lodash/fp/_mapping.js"), + fallbackHolder = __webpack_require__("./node_modules/lodash/fp/placeholder.js"); + +/** Built-in value reference. */ +var push = Array.prototype.push; + +/** + * Creates a function, with an arity of `n`, that invokes `func` with the + * arguments it receives. + * + * @private + * @param {Function} func The function to wrap. + * @param {number} n The arity of the new function. + * @returns {Function} Returns the new function. + */ +function baseArity(func, n) { + return n == 2 + ? function(a, b) { return func.apply(undefined, arguments); } + : function(a) { return func.apply(undefined, arguments); }; +} + +/** + * Creates a function that invokes `func`, with up to `n` arguments, ignoring + * any additional arguments. + * + * @private + * @param {Function} func The function to cap arguments for. + * @param {number} n The arity cap. + * @returns {Function} Returns the new function. + */ +function baseAry(func, n) { + return n == 2 + ? function(a, b) { return func(a, b); } + : function(a) { return func(a); }; +} + +/** + * Creates a clone of `array`. + * + * @private + * @param {Array} array The array to clone. + * @returns {Array} Returns the cloned array. + */ +function cloneArray(array) { + var length = array ? array.length : 0, + result = Array(length); + + while (length--) { + result[length] = array[length]; + } + return result; +} + +/** + * Creates a function that clones a given object using the assignment `func`. + * + * @private + * @param {Function} func The assignment function. + * @returns {Function} Returns the new cloner function. + */ +function createCloner(func) { + return function(object) { + return func({}, object); + }; +} + +/** + * A specialized version of `_.spread` which flattens the spread array into + * the arguments of the invoked `func`. + * + * @private + * @param {Function} func The function to spread arguments over. + * @param {number} start The start position of the spread. + * @returns {Function} Returns the new function. + */ +function flatSpread(func, start) { + return function() { + var length = arguments.length, + lastIndex = length - 1, + args = Array(length); + + while (length--) { + args[length] = arguments[length]; + } + var array = args[start], + otherArgs = args.slice(0, start); + + if (array) { + push.apply(otherArgs, array); + } + if (start != lastIndex) { + push.apply(otherArgs, args.slice(start + 1)); + } + return func.apply(this, otherArgs); + }; +} + +/** + * Creates a function that wraps `func` and uses `cloner` to clone the first + * argument it receives. + * + * @private + * @param {Function} func The function to wrap. + * @param {Function} cloner The function to clone arguments. + * @returns {Function} Returns the new immutable function. + */ +function wrapImmutable(func, cloner) { + return function() { + var length = arguments.length; + if (!length) { + return; + } + var args = Array(length); + while (length--) { + args[length] = arguments[length]; + } + var result = args[0] = cloner.apply(undefined, args); + func.apply(undefined, args); + return result; + }; +} + +/** + * The base implementation of `convert` which accepts a `util` object of methods + * required to perform conversions. + * + * @param {Object} util The util object. + * @param {string} name The name of the function to convert. + * @param {Function} func The function to convert. + * @param {Object} [options] The options object. + * @param {boolean} [options.cap=true] Specify capping iteratee arguments. + * @param {boolean} [options.curry=true] Specify currying. + * @param {boolean} [options.fixed=true] Specify fixed arity. + * @param {boolean} [options.immutable=true] Specify immutable operations. + * @param {boolean} [options.rearg=true] Specify rearranging arguments. + * @returns {Function|Object} Returns the converted function or object. + */ +function baseConvert(util, name, func, options) { + var setPlaceholder, + isLib = typeof name == 'function', + isObj = name === Object(name); + + if (isObj) { + options = func; + func = name; + name = undefined; + } + if (func == null) { + throw new TypeError; + } + options || (options = {}); + + var config = { + 'cap': 'cap' in options ? options.cap : true, + 'curry': 'curry' in options ? options.curry : true, + 'fixed': 'fixed' in options ? options.fixed : true, + 'immutable': 'immutable' in options ? options.immutable : true, + 'rearg': 'rearg' in options ? options.rearg : true + }; + + var forceCurry = ('curry' in options) && options.curry, + forceFixed = ('fixed' in options) && options.fixed, + forceRearg = ('rearg' in options) && options.rearg, + placeholder = isLib ? func : fallbackHolder, + pristine = isLib ? func.runInContext() : undefined; + + var helpers = isLib ? func : { + 'ary': util.ary, + 'assign': util.assign, + 'clone': util.clone, + 'curry': util.curry, + 'forEach': util.forEach, + 'isArray': util.isArray, + 'isFunction': util.isFunction, + 'iteratee': util.iteratee, + 'keys': util.keys, + 'rearg': util.rearg, + 'toInteger': util.toInteger, + 'toPath': util.toPath + }; + + var ary = helpers.ary, + assign = helpers.assign, + clone = helpers.clone, + curry = helpers.curry, + each = helpers.forEach, + isArray = helpers.isArray, + isFunction = helpers.isFunction, + keys = helpers.keys, + rearg = helpers.rearg, + toInteger = helpers.toInteger, + toPath = helpers.toPath; + + var aryMethodKeys = keys(mapping.aryMethod); + + var wrappers = { + 'castArray': function(castArray) { + return function() { + var value = arguments[0]; + return isArray(value) + ? castArray(cloneArray(value)) + : castArray.apply(undefined, arguments); + }; + }, + 'iteratee': function(iteratee) { + return function() { + var func = arguments[0], + arity = arguments[1], + result = iteratee(func, arity), + length = result.length; + + if (config.cap && typeof arity == 'number') { + arity = arity > 2 ? (arity - 2) : 1; + return (length && length <= arity) ? result : baseAry(result, arity); + } + return result; + }; + }, + 'mixin': function(mixin) { + return function(source) { + var func = this; + if (!isFunction(func)) { + return mixin(func, Object(source)); + } + var pairs = []; + each(keys(source), function(key) { + if (isFunction(source[key])) { + pairs.push([key, func.prototype[key]]); + } + }); + + mixin(func, Object(source)); + + each(pairs, function(pair) { + var value = pair[1]; + if (isFunction(value)) { + func.prototype[pair[0]] = value; + } else { + delete func.prototype[pair[0]]; + } + }); + return func; + }; + }, + 'nthArg': function(nthArg) { + return function(n) { + var arity = n < 0 ? 1 : (toInteger(n) + 1); + return curry(nthArg(n), arity); + }; + }, + 'rearg': function(rearg) { + return function(func, indexes) { + var arity = indexes ? indexes.length : 0; + return curry(rearg(func, indexes), arity); + }; + }, + 'runInContext': function(runInContext) { + return function(context) { + return baseConvert(util, runInContext(context), options); + }; + } + }; + + /*--------------------------------------------------------------------------*/ + + /** + * Casts `func` to a function with an arity capped iteratee if needed. + * + * @private + * @param {string} name The name of the function to inspect. + * @param {Function} func The function to inspect. + * @returns {Function} Returns the cast function. + */ + function castCap(name, func) { + if (config.cap) { + var indexes = mapping.iterateeRearg[name]; + if (indexes) { + return iterateeRearg(func, indexes); + } + var n = !isLib && mapping.iterateeAry[name]; + if (n) { + return iterateeAry(func, n); + } + } + return func; + } + + /** + * Casts `func` to a curried function if needed. + * + * @private + * @param {string} name The name of the function to inspect. + * @param {Function} func The function to inspect. + * @param {number} n The arity of `func`. + * @returns {Function} Returns the cast function. + */ + function castCurry(name, func, n) { + return (forceCurry || (config.curry && n > 1)) + ? curry(func, n) + : func; + } + + /** + * Casts `func` to a fixed arity function if needed. + * + * @private + * @param {string} name The name of the function to inspect. + * @param {Function} func The function to inspect. + * @param {number} n The arity cap. + * @returns {Function} Returns the cast function. + */ + function castFixed(name, func, n) { + if (config.fixed && (forceFixed || !mapping.skipFixed[name])) { + var data = mapping.methodSpread[name], + start = data && data.start; + + return start === undefined ? ary(func, n) : flatSpread(func, start); + } + return func; + } + + /** + * Casts `func` to an rearged function if needed. + * + * @private + * @param {string} name The name of the function to inspect. + * @param {Function} func The function to inspect. + * @param {number} n The arity of `func`. + * @returns {Function} Returns the cast function. + */ + function castRearg(name, func, n) { + return (config.rearg && n > 1 && (forceRearg || !mapping.skipRearg[name])) + ? rearg(func, mapping.methodRearg[name] || mapping.aryRearg[n]) + : func; + } + + /** + * Creates a clone of `object` by `path`. + * + * @private + * @param {Object} object The object to clone. + * @param {Array|string} path The path to clone by. + * @returns {Object} Returns the cloned object. + */ + function cloneByPath(object, path) { + path = toPath(path); + + var index = -1, + length = path.length, + lastIndex = length - 1, + result = clone(Object(object)), + nested = result; + + while (nested != null && ++index < length) { + var key = path[index], + value = nested[key]; + + if (value != null) { + nested[path[index]] = clone(index == lastIndex ? value : Object(value)); + } + nested = nested[key]; + } + return result; + } + + /** + * Converts `lodash` to an immutable auto-curried iteratee-first data-last + * version with conversion `options` applied. + * + * @param {Object} [options] The options object. See `baseConvert` for more details. + * @returns {Function} Returns the converted `lodash`. + */ + function convertLib(options) { + return _.runInContext.convert(options)(undefined); + } + + /** + * Create a converter function for `func` of `name`. + * + * @param {string} name The name of the function to convert. + * @param {Function} func The function to convert. + * @returns {Function} Returns the new converter function. + */ + function createConverter(name, func) { + var realName = mapping.aliasToReal[name] || name, + methodName = mapping.remap[realName] || realName, + oldOptions = options; + + return function(options) { + var newUtil = isLib ? pristine : helpers, + newFunc = isLib ? pristine[methodName] : func, + newOptions = assign(assign({}, oldOptions), options); + + return baseConvert(newUtil, realName, newFunc, newOptions); + }; + } + + /** + * Creates a function that wraps `func` to invoke its iteratee, with up to `n` + * arguments, ignoring any additional arguments. + * + * @private + * @param {Function} func The function to cap iteratee arguments for. + * @param {number} n The arity cap. + * @returns {Function} Returns the new function. + */ + function iterateeAry(func, n) { + return overArg(func, function(func) { + return typeof func == 'function' ? baseAry(func, n) : func; + }); + } + + /** + * Creates a function that wraps `func` to invoke its iteratee with arguments + * arranged according to the specified `indexes` where the argument value at + * the first index is provided as the first argument, the argument value at + * the second index is provided as the second argument, and so on. + * + * @private + * @param {Function} func The function to rearrange iteratee arguments for. + * @param {number[]} indexes The arranged argument indexes. + * @returns {Function} Returns the new function. + */ + function iterateeRearg(func, indexes) { + return overArg(func, function(func) { + var n = indexes.length; + return baseArity(rearg(baseAry(func, n), indexes), n); + }); + } + + /** + * Creates a function that invokes `func` with its first argument transformed. + * + * @private + * @param {Function} func The function to wrap. + * @param {Function} transform The argument transform. + * @returns {Function} Returns the new function. + */ + function overArg(func, transform) { + return function() { + var length = arguments.length; + if (!length) { + return func(); + } + var args = Array(length); + while (length--) { + args[length] = arguments[length]; + } + var index = config.rearg ? 0 : (length - 1); + args[index] = transform(args[index]); + return func.apply(undefined, args); + }; + } + + /** + * Creates a function that wraps `func` and applys the conversions + * rules by `name`. + * + * @private + * @param {string} name The name of the function to wrap. + * @param {Function} func The function to wrap. + * @returns {Function} Returns the converted function. + */ + function wrap(name, func) { + var result, + realName = mapping.aliasToReal[name] || name, + wrapped = func, + wrapper = wrappers[realName]; + + if (wrapper) { + wrapped = wrapper(func); + } + else if (config.immutable) { + if (mapping.mutate.array[realName]) { + wrapped = wrapImmutable(func, cloneArray); + } + else if (mapping.mutate.object[realName]) { + wrapped = wrapImmutable(func, createCloner(func)); + } + else if (mapping.mutate.set[realName]) { + wrapped = wrapImmutable(func, cloneByPath); + } + } + each(aryMethodKeys, function(aryKey) { + each(mapping.aryMethod[aryKey], function(otherName) { + if (realName == otherName) { + var data = mapping.methodSpread[realName], + afterRearg = data && data.afterRearg; + + result = afterRearg + ? castFixed(realName, castRearg(realName, wrapped, aryKey), aryKey) + : castRearg(realName, castFixed(realName, wrapped, aryKey), aryKey); + + result = castCap(realName, result); + result = castCurry(realName, result, aryKey); + return false; + } + }); + return !result; + }); + + result || (result = wrapped); + if (result == func) { + result = forceCurry ? curry(result, 1) : function() { + return func.apply(this, arguments); + }; + } + result.convert = createConverter(realName, func); + if (mapping.placeholder[realName]) { + setPlaceholder = true; + result.placeholder = func.placeholder = placeholder; + } + return result; + } + + /*--------------------------------------------------------------------------*/ + + if (!isObj) { + return wrap(name, func); + } + var _ = func; + + // Convert methods by ary cap. + var pairs = []; + each(aryMethodKeys, function(aryKey) { + each(mapping.aryMethod[aryKey], function(key) { + var func = _[mapping.remap[key] || key]; + if (func) { + pairs.push([key, wrap(key, func)]); + } + }); + }); + + // Convert remaining methods. + each(keys(_), function(key) { + var func = _[key]; + if (typeof func == 'function') { + var length = pairs.length; + while (length--) { + if (pairs[length][0] == key) { + return; + } + } + func.convert = createConverter(key, func); + pairs.push([key, func]); + } + }); + + // Assign to `_` leaving `_.prototype` unchanged to allow chaining. + each(pairs, function(pair) { + _[pair[0]] = pair[1]; + }); + + _.convert = convertLib; + if (setPlaceholder) { + _.placeholder = placeholder; + } + // Assign aliases. + each(keys(_), function(key) { + each(mapping.realToAlias[key] || [], function(alias) { + _[alias] = _[key]; + }); + }); + + return _; +} + +module.exports = baseConvert; + /***/ }), /***/ "./node_modules/lodash/fp/_mapping.js": -/* no static exports found */ -/* all exports used */ -/*!*********************************!*\ - !*** ./~/lodash/fp/_mapping.js ***! - \*********************************/ /***/ (function(module, exports) { -eval("/** Used to map aliases to their real names. */\nexports.aliasToReal = {\n\n // Lodash aliases.\n 'each': 'forEach',\n 'eachRight': 'forEachRight',\n 'entries': 'toPairs',\n 'entriesIn': 'toPairsIn',\n 'extend': 'assignIn',\n 'extendAll': 'assignInAll',\n 'extendAllWith': 'assignInAllWith',\n 'extendWith': 'assignInWith',\n 'first': 'head',\n\n // Methods that are curried variants of others.\n 'conforms': 'conformsTo',\n 'matches': 'isMatch',\n 'property': 'get',\n\n // Ramda aliases.\n '__': 'placeholder',\n 'F': 'stubFalse',\n 'T': 'stubTrue',\n 'all': 'every',\n 'allPass': 'overEvery',\n 'always': 'constant',\n 'any': 'some',\n 'anyPass': 'overSome',\n 'apply': 'spread',\n 'assoc': 'set',\n 'assocPath': 'set',\n 'complement': 'negate',\n 'compose': 'flowRight',\n 'contains': 'includes',\n 'dissoc': 'unset',\n 'dissocPath': 'unset',\n 'dropLast': 'dropRight',\n 'dropLastWhile': 'dropRightWhile',\n 'equals': 'isEqual',\n 'identical': 'eq',\n 'indexBy': 'keyBy',\n 'init': 'initial',\n 'invertObj': 'invert',\n 'juxt': 'over',\n 'omitAll': 'omit',\n 'nAry': 'ary',\n 'path': 'get',\n 'pathEq': 'matchesProperty',\n 'pathOr': 'getOr',\n 'paths': 'at',\n 'pickAll': 'pick',\n 'pipe': 'flow',\n 'pluck': 'map',\n 'prop': 'get',\n 'propEq': 'matchesProperty',\n 'propOr': 'getOr',\n 'props': 'at',\n 'symmetricDifference': 'xor',\n 'symmetricDifferenceBy': 'xorBy',\n 'symmetricDifferenceWith': 'xorWith',\n 'takeLast': 'takeRight',\n 'takeLastWhile': 'takeRightWhile',\n 'unapply': 'rest',\n 'unnest': 'flatten',\n 'useWith': 'overArgs',\n 'where': 'conformsTo',\n 'whereEq': 'isMatch',\n 'zipObj': 'zipObject'\n};\n\n/** Used to map ary to method names. */\nexports.aryMethod = {\n '1': [\n 'assignAll', 'assignInAll', 'attempt', 'castArray', 'ceil', 'create',\n 'curry', 'curryRight', 'defaultsAll', 'defaultsDeepAll', 'floor', 'flow',\n 'flowRight', 'fromPairs', 'invert', 'iteratee', 'memoize', 'method', 'mergeAll',\n 'methodOf', 'mixin', 'nthArg', 'over', 'overEvery', 'overSome','rest', 'reverse',\n 'round', 'runInContext', 'spread', 'template', 'trim', 'trimEnd', 'trimStart',\n 'uniqueId', 'words', 'zipAll'\n ],\n '2': [\n 'add', 'after', 'ary', 'assign', 'assignAllWith', 'assignIn', 'assignInAllWith',\n 'at', 'before', 'bind', 'bindAll', 'bindKey', 'chunk', 'cloneDeepWith',\n 'cloneWith', 'concat', 'conformsTo', 'countBy', 'curryN', 'curryRightN',\n 'debounce', 'defaults', 'defaultsDeep', 'defaultTo', 'delay', 'difference',\n 'divide', 'drop', 'dropRight', 'dropRightWhile', 'dropWhile', 'endsWith', 'eq',\n 'every', 'filter', 'find', 'findIndex', 'findKey', 'findLast', 'findLastIndex',\n 'findLastKey', 'flatMap', 'flatMapDeep', 'flattenDepth', 'forEach',\n 'forEachRight', 'forIn', 'forInRight', 'forOwn', 'forOwnRight', 'get',\n 'groupBy', 'gt', 'gte', 'has', 'hasIn', 'includes', 'indexOf', 'intersection',\n 'invertBy', 'invoke', 'invokeMap', 'isEqual', 'isMatch', 'join', 'keyBy',\n 'lastIndexOf', 'lt', 'lte', 'map', 'mapKeys', 'mapValues', 'matchesProperty',\n 'maxBy', 'meanBy', 'merge', 'mergeAllWith', 'minBy', 'multiply', 'nth', 'omit',\n 'omitBy', 'overArgs', 'pad', 'padEnd', 'padStart', 'parseInt', 'partial',\n 'partialRight', 'partition', 'pick', 'pickBy', 'propertyOf', 'pull', 'pullAll',\n 'pullAt', 'random', 'range', 'rangeRight', 'rearg', 'reject', 'remove',\n 'repeat', 'restFrom', 'result', 'sampleSize', 'some', 'sortBy', 'sortedIndex',\n 'sortedIndexOf', 'sortedLastIndex', 'sortedLastIndexOf', 'sortedUniqBy',\n 'split', 'spreadFrom', 'startsWith', 'subtract', 'sumBy', 'take', 'takeRight',\n 'takeRightWhile', 'takeWhile', 'tap', 'throttle', 'thru', 'times', 'trimChars',\n 'trimCharsEnd', 'trimCharsStart', 'truncate', 'union', 'uniqBy', 'uniqWith',\n 'unset', 'unzipWith', 'without', 'wrap', 'xor', 'zip', 'zipObject',\n 'zipObjectDeep'\n ],\n '3': [\n 'assignInWith', 'assignWith', 'clamp', 'differenceBy', 'differenceWith',\n 'findFrom', 'findIndexFrom', 'findLastFrom', 'findLastIndexFrom', 'getOr',\n 'includesFrom', 'indexOfFrom', 'inRange', 'intersectionBy', 'intersectionWith',\n 'invokeArgs', 'invokeArgsMap', 'isEqualWith', 'isMatchWith', 'flatMapDepth',\n 'lastIndexOfFrom', 'mergeWith', 'orderBy', 'padChars', 'padCharsEnd',\n 'padCharsStart', 'pullAllBy', 'pullAllWith', 'rangeStep', 'rangeStepRight',\n 'reduce', 'reduceRight', 'replace', 'set', 'slice', 'sortedIndexBy',\n 'sortedLastIndexBy', 'transform', 'unionBy', 'unionWith', 'update', 'xorBy',\n 'xorWith', 'zipWith'\n ],\n '4': [\n 'fill', 'setWith', 'updateWith'\n ]\n};\n\n/** Used to map ary to rearg configs. */\nexports.aryRearg = {\n '2': [1, 0],\n '3': [2, 0, 1],\n '4': [3, 2, 0, 1]\n};\n\n/** Used to map method names to their iteratee ary. */\nexports.iterateeAry = {\n 'dropRightWhile': 1,\n 'dropWhile': 1,\n 'every': 1,\n 'filter': 1,\n 'find': 1,\n 'findFrom': 1,\n 'findIndex': 1,\n 'findIndexFrom': 1,\n 'findKey': 1,\n 'findLast': 1,\n 'findLastFrom': 1,\n 'findLastIndex': 1,\n 'findLastIndexFrom': 1,\n 'findLastKey': 1,\n 'flatMap': 1,\n 'flatMapDeep': 1,\n 'flatMapDepth': 1,\n 'forEach': 1,\n 'forEachRight': 1,\n 'forIn': 1,\n 'forInRight': 1,\n 'forOwn': 1,\n 'forOwnRight': 1,\n 'map': 1,\n 'mapKeys': 1,\n 'mapValues': 1,\n 'partition': 1,\n 'reduce': 2,\n 'reduceRight': 2,\n 'reject': 1,\n 'remove': 1,\n 'some': 1,\n 'takeRightWhile': 1,\n 'takeWhile': 1,\n 'times': 1,\n 'transform': 2\n};\n\n/** Used to map method names to iteratee rearg configs. */\nexports.iterateeRearg = {\n 'mapKeys': [1],\n 'reduceRight': [1, 0]\n};\n\n/** Used to map method names to rearg configs. */\nexports.methodRearg = {\n 'assignInAllWith': [1, 0],\n 'assignInWith': [1, 2, 0],\n 'assignAllWith': [1, 0],\n 'assignWith': [1, 2, 0],\n 'differenceBy': [1, 2, 0],\n 'differenceWith': [1, 2, 0],\n 'getOr': [2, 1, 0],\n 'intersectionBy': [1, 2, 0],\n 'intersectionWith': [1, 2, 0],\n 'isEqualWith': [1, 2, 0],\n 'isMatchWith': [2, 1, 0],\n 'mergeAllWith': [1, 0],\n 'mergeWith': [1, 2, 0],\n 'padChars': [2, 1, 0],\n 'padCharsEnd': [2, 1, 0],\n 'padCharsStart': [2, 1, 0],\n 'pullAllBy': [2, 1, 0],\n 'pullAllWith': [2, 1, 0],\n 'rangeStep': [1, 2, 0],\n 'rangeStepRight': [1, 2, 0],\n 'setWith': [3, 1, 2, 0],\n 'sortedIndexBy': [2, 1, 0],\n 'sortedLastIndexBy': [2, 1, 0],\n 'unionBy': [1, 2, 0],\n 'unionWith': [1, 2, 0],\n 'updateWith': [3, 1, 2, 0],\n 'xorBy': [1, 2, 0],\n 'xorWith': [1, 2, 0],\n 'zipWith': [1, 2, 0]\n};\n\n/** Used to map method names to spread configs. */\nexports.methodSpread = {\n 'assignAll': { 'start': 0 },\n 'assignAllWith': { 'start': 0 },\n 'assignInAll': { 'start': 0 },\n 'assignInAllWith': { 'start': 0 },\n 'defaultsAll': { 'start': 0 },\n 'defaultsDeepAll': { 'start': 0 },\n 'invokeArgs': { 'start': 2 },\n 'invokeArgsMap': { 'start': 2 },\n 'mergeAll': { 'start': 0 },\n 'mergeAllWith': { 'start': 0 },\n 'partial': { 'start': 1 },\n 'partialRight': { 'start': 1 },\n 'without': { 'start': 1 },\n 'zipAll': { 'start': 0 }\n};\n\n/** Used to identify methods which mutate arrays or objects. */\nexports.mutate = {\n 'array': {\n 'fill': true,\n 'pull': true,\n 'pullAll': true,\n 'pullAllBy': true,\n 'pullAllWith': true,\n 'pullAt': true,\n 'remove': true,\n 'reverse': true\n },\n 'object': {\n 'assign': true,\n 'assignAll': true,\n 'assignAllWith': true,\n 'assignIn': true,\n 'assignInAll': true,\n 'assignInAllWith': true,\n 'assignInWith': true,\n 'assignWith': true,\n 'defaults': true,\n 'defaultsAll': true,\n 'defaultsDeep': true,\n 'defaultsDeepAll': true,\n 'merge': true,\n 'mergeAll': true,\n 'mergeAllWith': true,\n 'mergeWith': true,\n },\n 'set': {\n 'set': true,\n 'setWith': true,\n 'unset': true,\n 'update': true,\n 'updateWith': true\n }\n};\n\n/** Used to track methods with placeholder support */\nexports.placeholder = {\n 'bind': true,\n 'bindKey': true,\n 'curry': true,\n 'curryRight': true,\n 'partial': true,\n 'partialRight': true\n};\n\n/** Used to map real names to their aliases. */\nexports.realToAlias = (function() {\n var hasOwnProperty = Object.prototype.hasOwnProperty,\n object = exports.aliasToReal,\n result = {};\n\n for (var key in object) {\n var value = object[key];\n if (hasOwnProperty.call(result, value)) {\n result[value].push(key);\n } else {\n result[value] = [key];\n }\n }\n return result;\n}());\n\n/** Used to map method names to other names. */\nexports.remap = {\n 'assignAll': 'assign',\n 'assignAllWith': 'assignWith',\n 'assignInAll': 'assignIn',\n 'assignInAllWith': 'assignInWith',\n 'curryN': 'curry',\n 'curryRightN': 'curryRight',\n 'defaultsAll': 'defaults',\n 'defaultsDeepAll': 'defaultsDeep',\n 'findFrom': 'find',\n 'findIndexFrom': 'findIndex',\n 'findLastFrom': 'findLast',\n 'findLastIndexFrom': 'findLastIndex',\n 'getOr': 'get',\n 'includesFrom': 'includes',\n 'indexOfFrom': 'indexOf',\n 'invokeArgs': 'invoke',\n 'invokeArgsMap': 'invokeMap',\n 'lastIndexOfFrom': 'lastIndexOf',\n 'mergeAll': 'merge',\n 'mergeAllWith': 'mergeWith',\n 'padChars': 'pad',\n 'padCharsEnd': 'padEnd',\n 'padCharsStart': 'padStart',\n 'propertyOf': 'get',\n 'rangeStep': 'range',\n 'rangeStepRight': 'rangeRight',\n 'restFrom': 'rest',\n 'spreadFrom': 'spread',\n 'trimChars': 'trim',\n 'trimCharsEnd': 'trimEnd',\n 'trimCharsStart': 'trimStart',\n 'zipAll': 'zip'\n};\n\n/** Used to track methods that skip fixing their arity. */\nexports.skipFixed = {\n 'castArray': true,\n 'flow': true,\n 'flowRight': true,\n 'iteratee': true,\n 'mixin': true,\n 'rearg': true,\n 'runInContext': true\n};\n\n/** Used to track methods that skip rearranging arguments. */\nexports.skipRearg = {\n 'add': true,\n 'assign': true,\n 'assignIn': true,\n 'bind': true,\n 'bindKey': true,\n 'concat': true,\n 'difference': true,\n 'divide': true,\n 'eq': true,\n 'gt': true,\n 'gte': true,\n 'isEqual': true,\n 'lt': true,\n 'lte': true,\n 'matchesProperty': true,\n 'merge': true,\n 'multiply': true,\n 'overArgs': true,\n 'partial': true,\n 'partialRight': true,\n 'propertyOf': true,\n 'random': true,\n 'range': true,\n 'rangeRight': true,\n 'subtract': true,\n 'zip': true,\n 'zipObject': true,\n 'zipObjectDeep': true\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9ub2RlX21vZHVsZXMvbG9kYXNoL2ZwL19tYXBwaW5nLmpzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vLy4vfi9sb2Rhc2gvZnAvX21hcHBpbmcuanM/MDFhZCJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogVXNlZCB0byBtYXAgYWxpYXNlcyB0byB0aGVpciByZWFsIG5hbWVzLiAqL1xuZXhwb3J0cy5hbGlhc1RvUmVhbCA9IHtcblxuICAvLyBMb2Rhc2ggYWxpYXNlcy5cbiAgJ2VhY2gnOiAnZm9yRWFjaCcsXG4gICdlYWNoUmlnaHQnOiAnZm9yRWFjaFJpZ2h0JyxcbiAgJ2VudHJpZXMnOiAndG9QYWlycycsXG4gICdlbnRyaWVzSW4nOiAndG9QYWlyc0luJyxcbiAgJ2V4dGVuZCc6ICdhc3NpZ25JbicsXG4gICdleHRlbmRBbGwnOiAnYXNzaWduSW5BbGwnLFxuICAnZXh0ZW5kQWxsV2l0aCc6ICdhc3NpZ25JbkFsbFdpdGgnLFxuICAnZXh0ZW5kV2l0aCc6ICdhc3NpZ25JbldpdGgnLFxuICAnZmlyc3QnOiAnaGVhZCcsXG5cbiAgLy8gTWV0aG9kcyB0aGF0IGFyZSBjdXJyaWVkIHZhcmlhbnRzIG9mIG90aGVycy5cbiAgJ2NvbmZvcm1zJzogJ2NvbmZvcm1zVG8nLFxuICAnbWF0Y2hlcyc6ICdpc01hdGNoJyxcbiAgJ3Byb3BlcnR5JzogJ2dldCcsXG5cbiAgLy8gUmFtZGEgYWxpYXNlcy5cbiAgJ19fJzogJ3BsYWNlaG9sZGVyJyxcbiAgJ0YnOiAnc3R1YkZhbHNlJyxcbiAgJ1QnOiAnc3R1YlRydWUnLFxuICAnYWxsJzogJ2V2ZXJ5JyxcbiAgJ2FsbFBhc3MnOiAnb3ZlckV2ZXJ5JyxcbiAgJ2Fsd2F5cyc6ICdjb25zdGFudCcsXG4gICdhbnknOiAnc29tZScsXG4gICdhbnlQYXNzJzogJ292ZXJTb21lJyxcbiAgJ2FwcGx5JzogJ3NwcmVhZCcsXG4gICdhc3NvYyc6ICdzZXQnLFxuICAnYXNzb2NQYXRoJzogJ3NldCcsXG4gICdjb21wbGVtZW50JzogJ25lZ2F0ZScsXG4gICdjb21wb3NlJzogJ2Zsb3dSaWdodCcsXG4gICdjb250YWlucyc6ICdpbmNsdWRlcycsXG4gICdkaXNzb2MnOiAndW5zZXQnLFxuICAnZGlzc29jUGF0aCc6ICd1bnNldCcsXG4gICdkcm9wTGFzdCc6ICdkcm9wUmlnaHQnLFxuICAnZHJvcExhc3RXaGlsZSc6ICdkcm9wUmlnaHRXaGlsZScsXG4gICdlcXVhbHMnOiAnaXNFcXVhbCcsXG4gICdpZGVudGljYWwnOiAnZXEnLFxuICAnaW5kZXhCeSc6ICdrZXlCeScsXG4gICdpbml0JzogJ2luaXRpYWwnLFxuICAnaW52ZXJ0T2JqJzogJ2ludmVydCcsXG4gICdqdXh0JzogJ292ZXInLFxuICAnb21pdEFsbCc6ICdvbWl0JyxcbiAgJ25BcnknOiAnYXJ5JyxcbiAgJ3BhdGgnOiAnZ2V0JyxcbiAgJ3BhdGhFcSc6ICdtYXRjaGVzUHJvcGVydHknLFxuICAncGF0aE9yJzogJ2dldE9yJyxcbiAgJ3BhdGhzJzogJ2F0JyxcbiAgJ3BpY2tBbGwnOiAncGljaycsXG4gICdwaXBlJzogJ2Zsb3cnLFxuICAncGx1Y2snOiAnbWFwJyxcbiAgJ3Byb3AnOiAnZ2V0JyxcbiAgJ3Byb3BFcSc6ICdtYXRjaGVzUHJvcGVydHknLFxuICAncHJvcE9yJzogJ2dldE9yJyxcbiAgJ3Byb3BzJzogJ2F0JyxcbiAgJ3N5bW1ldHJpY0RpZmZlcmVuY2UnOiAneG9yJyxcbiAgJ3N5bW1ldHJpY0RpZmZlcmVuY2VCeSc6ICd4b3JCeScsXG4gICdzeW1tZXRyaWNEaWZmZXJlbmNlV2l0aCc6ICd4b3JXaXRoJyxcbiAgJ3Rha2VMYXN0JzogJ3Rha2VSaWdodCcsXG4gICd0YWtlTGFzdFdoaWxlJzogJ3Rha2VSaWdodFdoaWxlJyxcbiAgJ3VuYXBwbHknOiAncmVzdCcsXG4gICd1bm5lc3QnOiAnZmxhdHRlbicsXG4gICd1c2VXaXRoJzogJ292ZXJBcmdzJyxcbiAgJ3doZXJlJzogJ2NvbmZvcm1zVG8nLFxuICAnd2hlcmVFcSc6ICdpc01hdGNoJyxcbiAgJ3ppcE9iaic6ICd6aXBPYmplY3QnXG59O1xuXG4vKiogVXNlZCB0byBtYXAgYXJ5IHRvIG1ldGhvZCBuYW1lcy4gKi9cbmV4cG9ydHMuYXJ5TWV0aG9kID0ge1xuICAnMSc6IFtcbiAgICAnYXNzaWduQWxsJywgJ2Fzc2lnbkluQWxsJywgJ2F0dGVtcHQnLCAnY2FzdEFycmF5JywgJ2NlaWwnLCAnY3JlYXRlJyxcbiAgICAnY3VycnknLCAnY3VycnlSaWdodCcsICdkZWZhdWx0c0FsbCcsICdkZWZhdWx0c0RlZXBBbGwnLCAnZmxvb3InLCAnZmxvdycsXG4gICAgJ2Zsb3dSaWdodCcsICdmcm9tUGFpcnMnLCAnaW52ZXJ0JywgJ2l0ZXJhdGVlJywgJ21lbW9pemUnLCAnbWV0aG9kJywgJ21lcmdlQWxsJyxcbiAgICAnbWV0aG9kT2YnLCAnbWl4aW4nLCAnbnRoQXJnJywgJ292ZXInLCAnb3ZlckV2ZXJ5JywgJ292ZXJTb21lJywncmVzdCcsICdyZXZlcnNlJyxcbiAgICAncm91bmQnLCAncnVuSW5Db250ZXh0JywgJ3NwcmVhZCcsICd0ZW1wbGF0ZScsICd0cmltJywgJ3RyaW1FbmQnLCAndHJpbVN0YXJ0JyxcbiAgICAndW5pcXVlSWQnLCAnd29yZHMnLCAnemlwQWxsJ1xuICBdLFxuICAnMic6IFtcbiAgICAnYWRkJywgJ2FmdGVyJywgJ2FyeScsICdhc3NpZ24nLCAnYXNzaWduQWxsV2l0aCcsICdhc3NpZ25JbicsICdhc3NpZ25JbkFsbFdpdGgnLFxuICAgICdhdCcsICdiZWZvcmUnLCAnYmluZCcsICdiaW5kQWxsJywgJ2JpbmRLZXknLCAnY2h1bmsnLCAnY2xvbmVEZWVwV2l0aCcsXG4gICAgJ2Nsb25lV2l0aCcsICdjb25jYXQnLCAnY29uZm9ybXNUbycsICdjb3VudEJ5JywgJ2N1cnJ5TicsICdjdXJyeVJpZ2h0TicsXG4gICAgJ2RlYm91bmNlJywgJ2RlZmF1bHRzJywgJ2RlZmF1bHRzRGVlcCcsICdkZWZhdWx0VG8nLCAnZGVsYXknLCAnZGlmZmVyZW5jZScsXG4gICAgJ2RpdmlkZScsICdkcm9wJywgJ2Ryb3BSaWdodCcsICdkcm9wUmlnaHRXaGlsZScsICdkcm9wV2hpbGUnLCAnZW5kc1dpdGgnLCAnZXEnLFxuICAgICdldmVyeScsICdmaWx0ZXInLCAnZmluZCcsICdmaW5kSW5kZXgnLCAnZmluZEtleScsICdmaW5kTGFzdCcsICdmaW5kTGFzdEluZGV4JyxcbiAgICAnZmluZExhc3RLZXknLCAnZmxhdE1hcCcsICdmbGF0TWFwRGVlcCcsICdmbGF0dGVuRGVwdGgnLCAnZm9yRWFjaCcsXG4gICAgJ2ZvckVhY2hSaWdodCcsICdmb3JJbicsICdmb3JJblJpZ2h0JywgJ2Zvck93bicsICdmb3JPd25SaWdodCcsICdnZXQnLFxuICAgICdncm91cEJ5JywgJ2d0JywgJ2d0ZScsICdoYXMnLCAnaGFzSW4nLCAnaW5jbHVkZXMnLCAnaW5kZXhPZicsICdpbnRlcnNlY3Rpb24nLFxuICAgICdpbnZlcnRCeScsICdpbnZva2UnLCAnaW52b2tlTWFwJywgJ2lzRXF1YWwnLCAnaXNNYXRjaCcsICdqb2luJywgJ2tleUJ5JyxcbiAgICAnbGFzdEluZGV4T2YnLCAnbHQnLCAnbHRlJywgJ21hcCcsICdtYXBLZXlzJywgJ21hcFZhbHVlcycsICdtYXRjaGVzUHJvcGVydHknLFxuICAgICdtYXhCeScsICdtZWFuQnknLCAnbWVyZ2UnLCAnbWVyZ2VBbGxXaXRoJywgJ21pbkJ5JywgJ211bHRpcGx5JywgJ250aCcsICdvbWl0JyxcbiAgICAnb21pdEJ5JywgJ292ZXJBcmdzJywgJ3BhZCcsICdwYWRFbmQnLCAncGFkU3RhcnQnLCAncGFyc2VJbnQnLCAncGFydGlhbCcsXG4gICAgJ3BhcnRpYWxSaWdodCcsICdwYXJ0aXRpb24nLCAncGljaycsICdwaWNrQnknLCAncHJvcGVydHlPZicsICdwdWxsJywgJ3B1bGxBbGwnLFxuICAgICdwdWxsQXQnLCAncmFuZG9tJywgJ3JhbmdlJywgJ3JhbmdlUmlnaHQnLCAncmVhcmcnLCAncmVqZWN0JywgJ3JlbW92ZScsXG4gICAgJ3JlcGVhdCcsICdyZXN0RnJvbScsICdyZXN1bHQnLCAnc2FtcGxlU2l6ZScsICdzb21lJywgJ3NvcnRCeScsICdzb3J0ZWRJbmRleCcsXG4gICAgJ3NvcnRlZEluZGV4T2YnLCAnc29ydGVkTGFzdEluZGV4JywgJ3NvcnRlZExhc3RJbmRleE9mJywgJ3NvcnRlZFVuaXFCeScsXG4gICAgJ3NwbGl0JywgJ3NwcmVhZEZyb20nLCAnc3RhcnRzV2l0aCcsICdzdWJ0cmFjdCcsICdzdW1CeScsICd0YWtlJywgJ3Rha2VSaWdodCcsXG4gICAgJ3Rha2VSaWdodFdoaWxlJywgJ3Rha2VXaGlsZScsICd0YXAnLCAndGhyb3R0bGUnLCAndGhydScsICd0aW1lcycsICd0cmltQ2hhcnMnLFxuICAgICd0cmltQ2hhcnNFbmQnLCAndHJpbUNoYXJzU3RhcnQnLCAndHJ1bmNhdGUnLCAndW5pb24nLCAndW5pcUJ5JywgJ3VuaXFXaXRoJyxcbiAgICAndW5zZXQnLCAndW56aXBXaXRoJywgJ3dpdGhvdXQnLCAnd3JhcCcsICd4b3InLCAnemlwJywgJ3ppcE9iamVjdCcsXG4gICAgJ3ppcE9iamVjdERlZXAnXG4gIF0sXG4gICczJzogW1xuICAgICdhc3NpZ25JbldpdGgnLCAnYXNzaWduV2l0aCcsICdjbGFtcCcsICdkaWZmZXJlbmNlQnknLCAnZGlmZmVyZW5jZVdpdGgnLFxuICAgICdmaW5kRnJvbScsICdmaW5kSW5kZXhGcm9tJywgJ2ZpbmRMYXN0RnJvbScsICdmaW5kTGFzdEluZGV4RnJvbScsICdnZXRPcicsXG4gICAgJ2luY2x1ZGVzRnJvbScsICdpbmRleE9mRnJvbScsICdpblJhbmdlJywgJ2ludGVyc2VjdGlvbkJ5JywgJ2ludGVyc2VjdGlvbldpdGgnLFxuICAgICdpbnZva2VBcmdzJywgJ2ludm9rZUFyZ3NNYXAnLCAnaXNFcXVhbFdpdGgnLCAnaXNNYXRjaFdpdGgnLCAnZmxhdE1hcERlcHRoJyxcbiAgICAnbGFzdEluZGV4T2ZGcm9tJywgJ21lcmdlV2l0aCcsICdvcmRlckJ5JywgJ3BhZENoYXJzJywgJ3BhZENoYXJzRW5kJyxcbiAgICAncGFkQ2hhcnNTdGFydCcsICdwdWxsQWxsQnknLCAncHVsbEFsbFdpdGgnLCAncmFuZ2VTdGVwJywgJ3JhbmdlU3RlcFJpZ2h0JyxcbiAgICAncmVkdWNlJywgJ3JlZHVjZVJpZ2h0JywgJ3JlcGxhY2UnLCAnc2V0JywgJ3NsaWNlJywgJ3NvcnRlZEluZGV4QnknLFxuICAgICdzb3J0ZWRMYXN0SW5kZXhCeScsICd0cmFuc2Zvcm0nLCAndW5pb25CeScsICd1bmlvbldpdGgnLCAndXBkYXRlJywgJ3hvckJ5JyxcbiAgICAneG9yV2l0aCcsICd6aXBXaXRoJ1xuICBdLFxuICAnNCc6IFtcbiAgICAnZmlsbCcsICdzZXRXaXRoJywgJ3VwZGF0ZVdpdGgnXG4gIF1cbn07XG5cbi8qKiBVc2VkIHRvIG1hcCBhcnkgdG8gcmVhcmcgY29uZmlncy4gKi9cbmV4cG9ydHMuYXJ5UmVhcmcgPSB7XG4gICcyJzogWzEsIDBdLFxuICAnMyc6IFsyLCAwLCAxXSxcbiAgJzQnOiBbMywgMiwgMCwgMV1cbn07XG5cbi8qKiBVc2VkIHRvIG1hcCBtZXRob2QgbmFtZXMgdG8gdGhlaXIgaXRlcmF0ZWUgYXJ5LiAqL1xuZXhwb3J0cy5pdGVyYXRlZUFyeSA9IHtcbiAgJ2Ryb3BSaWdodFdoaWxlJzogMSxcbiAgJ2Ryb3BXaGlsZSc6IDEsXG4gICdldmVyeSc6IDEsXG4gICdmaWx0ZXInOiAxLFxuICAnZmluZCc6IDEsXG4gICdmaW5kRnJvbSc6IDEsXG4gICdmaW5kSW5kZXgnOiAxLFxuICAnZmluZEluZGV4RnJvbSc6IDEsXG4gICdmaW5kS2V5JzogMSxcbiAgJ2ZpbmRMYXN0JzogMSxcbiAgJ2ZpbmRMYXN0RnJvbSc6IDEsXG4gICdmaW5kTGFzdEluZGV4JzogMSxcbiAgJ2ZpbmRMYXN0SW5kZXhGcm9tJzogMSxcbiAgJ2ZpbmRMYXN0S2V5JzogMSxcbiAgJ2ZsYXRNYXAnOiAxLFxuICAnZmxhdE1hcERlZXAnOiAxLFxuICAnZmxhdE1hcERlcHRoJzogMSxcbiAgJ2ZvckVhY2gnOiAxLFxuICAnZm9yRWFjaFJpZ2h0JzogMSxcbiAgJ2ZvckluJzogMSxcbiAgJ2ZvckluUmlnaHQnOiAxLFxuICAnZm9yT3duJzogMSxcbiAgJ2Zvck93blJpZ2h0JzogMSxcbiAgJ21hcCc6IDEsXG4gICdtYXBLZXlzJzogMSxcbiAgJ21hcFZhbHVlcyc6IDEsXG4gICdwYXJ0aXRpb24nOiAxLFxuICAncmVkdWNlJzogMixcbiAgJ3JlZHVjZVJpZ2h0JzogMixcbiAgJ3JlamVjdCc6IDEsXG4gICdyZW1vdmUnOiAxLFxuICAnc29tZSc6IDEsXG4gICd0YWtlUmlnaHRXaGlsZSc6IDEsXG4gICd0YWtlV2hpbGUnOiAxLFxuICAndGltZXMnOiAxLFxuICAndHJhbnNmb3JtJzogMlxufTtcblxuLyoqIFVzZWQgdG8gbWFwIG1ldGhvZCBuYW1lcyB0byBpdGVyYXRlZSByZWFyZyBjb25maWdzLiAqL1xuZXhwb3J0cy5pdGVyYXRlZVJlYXJnID0ge1xuICAnbWFwS2V5cyc6IFsxXSxcbiAgJ3JlZHVjZVJpZ2h0JzogWzEsIDBdXG59O1xuXG4vKiogVXNlZCB0byBtYXAgbWV0aG9kIG5hbWVzIHRvIHJlYXJnIGNvbmZpZ3MuICovXG5leHBvcnRzLm1ldGhvZFJlYXJnID0ge1xuICAnYXNzaWduSW5BbGxXaXRoJzogWzEsIDBdLFxuICAnYXNzaWduSW5XaXRoJzogWzEsIDIsIDBdLFxuICAnYXNzaWduQWxsV2l0aCc6IFsxLCAwXSxcbiAgJ2Fzc2lnbldpdGgnOiBbMSwgMiwgMF0sXG4gICdkaWZmZXJlbmNlQnknOiBbMSwgMiwgMF0sXG4gICdkaWZmZXJlbmNlV2l0aCc6IFsxLCAyLCAwXSxcbiAgJ2dldE9yJzogWzIsIDEsIDBdLFxuICAnaW50ZXJzZWN0aW9uQnknOiBbMSwgMiwgMF0sXG4gICdpbnRlcnNlY3Rpb25XaXRoJzogWzEsIDIsIDBdLFxuICAnaXNFcXVhbFdpdGgnOiBbMSwgMiwgMF0sXG4gICdpc01hdGNoV2l0aCc6IFsyLCAxLCAwXSxcbiAgJ21lcmdlQWxsV2l0aCc6IFsxLCAwXSxcbiAgJ21lcmdlV2l0aCc6IFsxLCAyLCAwXSxcbiAgJ3BhZENoYXJzJzogWzIsIDEsIDBdLFxuICAncGFkQ2hhcnNFbmQnOiBbMiwgMSwgMF0sXG4gICdwYWRDaGFyc1N0YXJ0JzogWzIsIDEsIDBdLFxuICAncHVsbEFsbEJ5JzogWzIsIDEsIDBdLFxuICAncHVsbEFsbFdpdGgnOiBbMiwgMSwgMF0sXG4gICdyYW5nZVN0ZXAnOiBbMSwgMiwgMF0sXG4gICdyYW5nZVN0ZXBSaWdodCc6IFsxLCAyLCAwXSxcbiAgJ3NldFdpdGgnOiBbMywgMSwgMiwgMF0sXG4gICdzb3J0ZWRJbmRleEJ5JzogWzIsIDEsIDBdLFxuICAnc29ydGVkTGFzdEluZGV4QnknOiBbMiwgMSwgMF0sXG4gICd1bmlvbkJ5JzogWzEsIDIsIDBdLFxuICAndW5pb25XaXRoJzogWzEsIDIsIDBdLFxuICAndXBkYXRlV2l0aCc6IFszLCAxLCAyLCAwXSxcbiAgJ3hvckJ5JzogWzEsIDIsIDBdLFxuICAneG9yV2l0aCc6IFsxLCAyLCAwXSxcbiAgJ3ppcFdpdGgnOiBbMSwgMiwgMF1cbn07XG5cbi8qKiBVc2VkIHRvIG1hcCBtZXRob2QgbmFtZXMgdG8gc3ByZWFkIGNvbmZpZ3MuICovXG5leHBvcnRzLm1ldGhvZFNwcmVhZCA9IHtcbiAgJ2Fzc2lnbkFsbCc6IHsgJ3N0YXJ0JzogMCB9LFxuICAnYXNzaWduQWxsV2l0aCc6IHsgJ3N0YXJ0JzogMCB9LFxuICAnYXNzaWduSW5BbGwnOiB7ICdzdGFydCc6IDAgfSxcbiAgJ2Fzc2lnbkluQWxsV2l0aCc6IHsgJ3N0YXJ0JzogMCB9LFxuICAnZGVmYXVsdHNBbGwnOiB7ICdzdGFydCc6IDAgfSxcbiAgJ2RlZmF1bHRzRGVlcEFsbCc6IHsgJ3N0YXJ0JzogMCB9LFxuICAnaW52b2tlQXJncyc6IHsgJ3N0YXJ0JzogMiB9LFxuICAnaW52b2tlQXJnc01hcCc6IHsgJ3N0YXJ0JzogMiB9LFxuICAnbWVyZ2VBbGwnOiB7ICdzdGFydCc6IDAgfSxcbiAgJ21lcmdlQWxsV2l0aCc6IHsgJ3N0YXJ0JzogMCB9LFxuICAncGFydGlhbCc6IHsgJ3N0YXJ0JzogMSB9LFxuICAncGFydGlhbFJpZ2h0JzogeyAnc3RhcnQnOiAxIH0sXG4gICd3aXRob3V0JzogeyAnc3RhcnQnOiAxIH0sXG4gICd6aXBBbGwnOiB7ICdzdGFydCc6IDAgfVxufTtcblxuLyoqIFVzZWQgdG8gaWRlbnRpZnkgbWV0aG9kcyB3aGljaCBtdXRhdGUgYXJyYXlzIG9yIG9iamVjdHMuICovXG5leHBvcnRzLm11dGF0ZSA9IHtcbiAgJ2FycmF5Jzoge1xuICAgICdmaWxsJzogdHJ1ZSxcbiAgICAncHVsbCc6IHRydWUsXG4gICAgJ3B1bGxBbGwnOiB0cnVlLFxuICAgICdwdWxsQWxsQnknOiB0cnVlLFxuICAgICdwdWxsQWxsV2l0aCc6IHRydWUsXG4gICAgJ3B1bGxBdCc6IHRydWUsXG4gICAgJ3JlbW92ZSc6IHRydWUsXG4gICAgJ3JldmVyc2UnOiB0cnVlXG4gIH0sXG4gICdvYmplY3QnOiB7XG4gICAgJ2Fzc2lnbic6IHRydWUsXG4gICAgJ2Fzc2lnbkFsbCc6IHRydWUsXG4gICAgJ2Fzc2lnbkFsbFdpdGgnOiB0cnVlLFxuICAgICdhc3NpZ25Jbic6IHRydWUsXG4gICAgJ2Fzc2lnbkluQWxsJzogdHJ1ZSxcbiAgICAnYXNzaWduSW5BbGxXaXRoJzogdHJ1ZSxcbiAgICAnYXNzaWduSW5XaXRoJzogdHJ1ZSxcbiAgICAnYXNzaWduV2l0aCc6IHRydWUsXG4gICAgJ2RlZmF1bHRzJzogdHJ1ZSxcbiAgICAnZGVmYXVsdHNBbGwnOiB0cnVlLFxuICAgICdkZWZhdWx0c0RlZXAnOiB0cnVlLFxuICAgICdkZWZhdWx0c0RlZXBBbGwnOiB0cnVlLFxuICAgICdtZXJnZSc6IHRydWUsXG4gICAgJ21lcmdlQWxsJzogdHJ1ZSxcbiAgICAnbWVyZ2VBbGxXaXRoJzogdHJ1ZSxcbiAgICAnbWVyZ2VXaXRoJzogdHJ1ZSxcbiAgfSxcbiAgJ3NldCc6IHtcbiAgICAnc2V0JzogdHJ1ZSxcbiAgICAnc2V0V2l0aCc6IHRydWUsXG4gICAgJ3Vuc2V0JzogdHJ1ZSxcbiAgICAndXBkYXRlJzogdHJ1ZSxcbiAgICAndXBkYXRlV2l0aCc6IHRydWVcbiAgfVxufTtcblxuLyoqIFVzZWQgdG8gdHJhY2sgbWV0aG9kcyB3aXRoIHBsYWNlaG9sZGVyIHN1cHBvcnQgKi9cbmV4cG9ydHMucGxhY2Vob2xkZXIgPSB7XG4gICdiaW5kJzogdHJ1ZSxcbiAgJ2JpbmRLZXknOiB0cnVlLFxuICAnY3VycnknOiB0cnVlLFxuICAnY3VycnlSaWdodCc6IHRydWUsXG4gICdwYXJ0aWFsJzogdHJ1ZSxcbiAgJ3BhcnRpYWxSaWdodCc6IHRydWVcbn07XG5cbi8qKiBVc2VkIHRvIG1hcCByZWFsIG5hbWVzIHRvIHRoZWlyIGFsaWFzZXMuICovXG5leHBvcnRzLnJlYWxUb0FsaWFzID0gKGZ1bmN0aW9uKCkge1xuICB2YXIgaGFzT3duUHJvcGVydHkgPSBPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LFxuICAgICAgb2JqZWN0ID0gZXhwb3J0cy5hbGlhc1RvUmVhbCxcbiAgICAgIHJlc3VsdCA9IHt9O1xuXG4gIGZvciAodmFyIGtleSBpbiBvYmplY3QpIHtcbiAgICB2YXIgdmFsdWUgPSBvYmplY3Rba2V5XTtcbiAgICBpZiAoaGFzT3duUHJvcGVydHkuY2FsbChyZXN1bHQsIHZhbHVlKSkge1xuICAgICAgcmVzdWx0W3ZhbHVlXS5wdXNoKGtleSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHJlc3VsdFt2YWx1ZV0gPSBba2V5XTtcbiAgICB9XG4gIH1cbiAgcmV0dXJuIHJlc3VsdDtcbn0oKSk7XG5cbi8qKiBVc2VkIHRvIG1hcCBtZXRob2QgbmFtZXMgdG8gb3RoZXIgbmFtZXMuICovXG5leHBvcnRzLnJlbWFwID0ge1xuICAnYXNzaWduQWxsJzogJ2Fzc2lnbicsXG4gICdhc3NpZ25BbGxXaXRoJzogJ2Fzc2lnbldpdGgnLFxuICAnYXNzaWduSW5BbGwnOiAnYXNzaWduSW4nLFxuICAnYXNzaWduSW5BbGxXaXRoJzogJ2Fzc2lnbkluV2l0aCcsXG4gICdjdXJyeU4nOiAnY3VycnknLFxuICAnY3VycnlSaWdodE4nOiAnY3VycnlSaWdodCcsXG4gICdkZWZhdWx0c0FsbCc6ICdkZWZhdWx0cycsXG4gICdkZWZhdWx0c0RlZXBBbGwnOiAnZGVmYXVsdHNEZWVwJyxcbiAgJ2ZpbmRGcm9tJzogJ2ZpbmQnLFxuICAnZmluZEluZGV4RnJvbSc6ICdmaW5kSW5kZXgnLFxuICAnZmluZExhc3RGcm9tJzogJ2ZpbmRMYXN0JyxcbiAgJ2ZpbmRMYXN0SW5kZXhGcm9tJzogJ2ZpbmRMYXN0SW5kZXgnLFxuICAnZ2V0T3InOiAnZ2V0JyxcbiAgJ2luY2x1ZGVzRnJvbSc6ICdpbmNsdWRlcycsXG4gICdpbmRleE9mRnJvbSc6ICdpbmRleE9mJyxcbiAgJ2ludm9rZUFyZ3MnOiAnaW52b2tlJyxcbiAgJ2ludm9rZUFyZ3NNYXAnOiAnaW52b2tlTWFwJyxcbiAgJ2xhc3RJbmRleE9mRnJvbSc6ICdsYXN0SW5kZXhPZicsXG4gICdtZXJnZUFsbCc6ICdtZXJnZScsXG4gICdtZXJnZUFsbFdpdGgnOiAnbWVyZ2VXaXRoJyxcbiAgJ3BhZENoYXJzJzogJ3BhZCcsXG4gICdwYWRDaGFyc0VuZCc6ICdwYWRFbmQnLFxuICAncGFkQ2hhcnNTdGFydCc6ICdwYWRTdGFydCcsXG4gICdwcm9wZXJ0eU9mJzogJ2dldCcsXG4gICdyYW5nZVN0ZXAnOiAncmFuZ2UnLFxuICAncmFuZ2VTdGVwUmlnaHQnOiAncmFuZ2VSaWdodCcsXG4gICdyZXN0RnJvbSc6ICdyZXN0JyxcbiAgJ3NwcmVhZEZyb20nOiAnc3ByZWFkJyxcbiAgJ3RyaW1DaGFycyc6ICd0cmltJyxcbiAgJ3RyaW1DaGFyc0VuZCc6ICd0cmltRW5kJyxcbiAgJ3RyaW1DaGFyc1N0YXJ0JzogJ3RyaW1TdGFydCcsXG4gICd6aXBBbGwnOiAnemlwJ1xufTtcblxuLyoqIFVzZWQgdG8gdHJhY2sgbWV0aG9kcyB0aGF0IHNraXAgZml4aW5nIHRoZWlyIGFyaXR5LiAqL1xuZXhwb3J0cy5za2lwRml4ZWQgPSB7XG4gICdjYXN0QXJyYXknOiB0cnVlLFxuICAnZmxvdyc6IHRydWUsXG4gICdmbG93UmlnaHQnOiB0cnVlLFxuICAnaXRlcmF0ZWUnOiB0cnVlLFxuICAnbWl4aW4nOiB0cnVlLFxuICAncmVhcmcnOiB0cnVlLFxuICAncnVuSW5Db250ZXh0JzogdHJ1ZVxufTtcblxuLyoqIFVzZWQgdG8gdHJhY2sgbWV0aG9kcyB0aGF0IHNraXAgcmVhcnJhbmdpbmcgYXJndW1lbnRzLiAqL1xuZXhwb3J0cy5za2lwUmVhcmcgPSB7XG4gICdhZGQnOiB0cnVlLFxuICAnYXNzaWduJzogdHJ1ZSxcbiAgJ2Fzc2lnbkluJzogdHJ1ZSxcbiAgJ2JpbmQnOiB0cnVlLFxuICAnYmluZEtleSc6IHRydWUsXG4gICdjb25jYXQnOiB0cnVlLFxuICAnZGlmZmVyZW5jZSc6IHRydWUsXG4gICdkaXZpZGUnOiB0cnVlLFxuICAnZXEnOiB0cnVlLFxuICAnZ3QnOiB0cnVlLFxuICAnZ3RlJzogdHJ1ZSxcbiAgJ2lzRXF1YWwnOiB0cnVlLFxuICAnbHQnOiB0cnVlLFxuICAnbHRlJzogdHJ1ZSxcbiAgJ21hdGNoZXNQcm9wZXJ0eSc6IHRydWUsXG4gICdtZXJnZSc6IHRydWUsXG4gICdtdWx0aXBseSc6IHRydWUsXG4gICdvdmVyQXJncyc6IHRydWUsXG4gICdwYXJ0aWFsJzogdHJ1ZSxcbiAgJ3BhcnRpYWxSaWdodCc6IHRydWUsXG4gICdwcm9wZXJ0eU9mJzogdHJ1ZSxcbiAgJ3JhbmRvbSc6IHRydWUsXG4gICdyYW5nZSc6IHRydWUsXG4gICdyYW5nZVJpZ2h0JzogdHJ1ZSxcbiAgJ3N1YnRyYWN0JzogdHJ1ZSxcbiAgJ3ppcCc6IHRydWUsXG4gICd6aXBPYmplY3QnOiB0cnVlLFxuICAnemlwT2JqZWN0RGVlcCc6IHRydWVcbn07XG5cblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL34vbG9kYXNoL2ZwL19tYXBwaW5nLmpzXG4vLyBtb2R1bGUgaWQgPSAuL25vZGVfbW9kdWxlcy9sb2Rhc2gvZnAvX21hcHBpbmcuanNcbi8vIG1vZHVsZSBjaHVua3MgPSAwIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOyIsInNvdXJjZVJvb3QiOiIifQ=="); +/** Used to map aliases to their real names. */ +exports.aliasToReal = { + + // Lodash aliases. + 'each': 'forEach', + 'eachRight': 'forEachRight', + 'entries': 'toPairs', + 'entriesIn': 'toPairsIn', + 'extend': 'assignIn', + 'extendAll': 'assignInAll', + 'extendAllWith': 'assignInAllWith', + 'extendWith': 'assignInWith', + 'first': 'head', + + // Methods that are curried variants of others. + 'conforms': 'conformsTo', + 'matches': 'isMatch', + 'property': 'get', + + // Ramda aliases. + '__': 'placeholder', + 'F': 'stubFalse', + 'T': 'stubTrue', + 'all': 'every', + 'allPass': 'overEvery', + 'always': 'constant', + 'any': 'some', + 'anyPass': 'overSome', + 'apply': 'spread', + 'assoc': 'set', + 'assocPath': 'set', + 'complement': 'negate', + 'compose': 'flowRight', + 'contains': 'includes', + 'dissoc': 'unset', + 'dissocPath': 'unset', + 'dropLast': 'dropRight', + 'dropLastWhile': 'dropRightWhile', + 'equals': 'isEqual', + 'identical': 'eq', + 'indexBy': 'keyBy', + 'init': 'initial', + 'invertObj': 'invert', + 'juxt': 'over', + 'omitAll': 'omit', + 'nAry': 'ary', + 'path': 'get', + 'pathEq': 'matchesProperty', + 'pathOr': 'getOr', + 'paths': 'at', + 'pickAll': 'pick', + 'pipe': 'flow', + 'pluck': 'map', + 'prop': 'get', + 'propEq': 'matchesProperty', + 'propOr': 'getOr', + 'props': 'at', + 'symmetricDifference': 'xor', + 'symmetricDifferenceBy': 'xorBy', + 'symmetricDifferenceWith': 'xorWith', + 'takeLast': 'takeRight', + 'takeLastWhile': 'takeRightWhile', + 'unapply': 'rest', + 'unnest': 'flatten', + 'useWith': 'overArgs', + 'where': 'conformsTo', + 'whereEq': 'isMatch', + 'zipObj': 'zipObject' +}; + +/** Used to map ary to method names. */ +exports.aryMethod = { + '1': [ + 'assignAll', 'assignInAll', 'attempt', 'castArray', 'ceil', 'create', + 'curry', 'curryRight', 'defaultsAll', 'defaultsDeepAll', 'floor', 'flow', + 'flowRight', 'fromPairs', 'invert', 'iteratee', 'memoize', 'method', 'mergeAll', + 'methodOf', 'mixin', 'nthArg', 'over', 'overEvery', 'overSome','rest', 'reverse', + 'round', 'runInContext', 'spread', 'template', 'trim', 'trimEnd', 'trimStart', + 'uniqueId', 'words', 'zipAll' + ], + '2': [ + 'add', 'after', 'ary', 'assign', 'assignAllWith', 'assignIn', 'assignInAllWith', + 'at', 'before', 'bind', 'bindAll', 'bindKey', 'chunk', 'cloneDeepWith', + 'cloneWith', 'concat', 'conformsTo', 'countBy', 'curryN', 'curryRightN', + 'debounce', 'defaults', 'defaultsDeep', 'defaultTo', 'delay', 'difference', + 'divide', 'drop', 'dropRight', 'dropRightWhile', 'dropWhile', 'endsWith', 'eq', + 'every', 'filter', 'find', 'findIndex', 'findKey', 'findLast', 'findLastIndex', + 'findLastKey', 'flatMap', 'flatMapDeep', 'flattenDepth', 'forEach', + 'forEachRight', 'forIn', 'forInRight', 'forOwn', 'forOwnRight', 'get', + 'groupBy', 'gt', 'gte', 'has', 'hasIn', 'includes', 'indexOf', 'intersection', + 'invertBy', 'invoke', 'invokeMap', 'isEqual', 'isMatch', 'join', 'keyBy', + 'lastIndexOf', 'lt', 'lte', 'map', 'mapKeys', 'mapValues', 'matchesProperty', + 'maxBy', 'meanBy', 'merge', 'mergeAllWith', 'minBy', 'multiply', 'nth', 'omit', + 'omitBy', 'overArgs', 'pad', 'padEnd', 'padStart', 'parseInt', 'partial', + 'partialRight', 'partition', 'pick', 'pickBy', 'propertyOf', 'pull', 'pullAll', + 'pullAt', 'random', 'range', 'rangeRight', 'rearg', 'reject', 'remove', + 'repeat', 'restFrom', 'result', 'sampleSize', 'some', 'sortBy', 'sortedIndex', + 'sortedIndexOf', 'sortedLastIndex', 'sortedLastIndexOf', 'sortedUniqBy', + 'split', 'spreadFrom', 'startsWith', 'subtract', 'sumBy', 'take', 'takeRight', + 'takeRightWhile', 'takeWhile', 'tap', 'throttle', 'thru', 'times', 'trimChars', + 'trimCharsEnd', 'trimCharsStart', 'truncate', 'union', 'uniqBy', 'uniqWith', + 'unset', 'unzipWith', 'without', 'wrap', 'xor', 'zip', 'zipObject', + 'zipObjectDeep' + ], + '3': [ + 'assignInWith', 'assignWith', 'clamp', 'differenceBy', 'differenceWith', + 'findFrom', 'findIndexFrom', 'findLastFrom', 'findLastIndexFrom', 'getOr', + 'includesFrom', 'indexOfFrom', 'inRange', 'intersectionBy', 'intersectionWith', + 'invokeArgs', 'invokeArgsMap', 'isEqualWith', 'isMatchWith', 'flatMapDepth', + 'lastIndexOfFrom', 'mergeWith', 'orderBy', 'padChars', 'padCharsEnd', + 'padCharsStart', 'pullAllBy', 'pullAllWith', 'rangeStep', 'rangeStepRight', + 'reduce', 'reduceRight', 'replace', 'set', 'slice', 'sortedIndexBy', + 'sortedLastIndexBy', 'transform', 'unionBy', 'unionWith', 'update', 'xorBy', + 'xorWith', 'zipWith' + ], + '4': [ + 'fill', 'setWith', 'updateWith' + ] +}; + +/** Used to map ary to rearg configs. */ +exports.aryRearg = { + '2': [1, 0], + '3': [2, 0, 1], + '4': [3, 2, 0, 1] +}; + +/** Used to map method names to their iteratee ary. */ +exports.iterateeAry = { + 'dropRightWhile': 1, + 'dropWhile': 1, + 'every': 1, + 'filter': 1, + 'find': 1, + 'findFrom': 1, + 'findIndex': 1, + 'findIndexFrom': 1, + 'findKey': 1, + 'findLast': 1, + 'findLastFrom': 1, + 'findLastIndex': 1, + 'findLastIndexFrom': 1, + 'findLastKey': 1, + 'flatMap': 1, + 'flatMapDeep': 1, + 'flatMapDepth': 1, + 'forEach': 1, + 'forEachRight': 1, + 'forIn': 1, + 'forInRight': 1, + 'forOwn': 1, + 'forOwnRight': 1, + 'map': 1, + 'mapKeys': 1, + 'mapValues': 1, + 'partition': 1, + 'reduce': 2, + 'reduceRight': 2, + 'reject': 1, + 'remove': 1, + 'some': 1, + 'takeRightWhile': 1, + 'takeWhile': 1, + 'times': 1, + 'transform': 2 +}; + +/** Used to map method names to iteratee rearg configs. */ +exports.iterateeRearg = { + 'mapKeys': [1], + 'reduceRight': [1, 0] +}; + +/** Used to map method names to rearg configs. */ +exports.methodRearg = { + 'assignInAllWith': [1, 0], + 'assignInWith': [1, 2, 0], + 'assignAllWith': [1, 0], + 'assignWith': [1, 2, 0], + 'differenceBy': [1, 2, 0], + 'differenceWith': [1, 2, 0], + 'getOr': [2, 1, 0], + 'intersectionBy': [1, 2, 0], + 'intersectionWith': [1, 2, 0], + 'isEqualWith': [1, 2, 0], + 'isMatchWith': [2, 1, 0], + 'mergeAllWith': [1, 0], + 'mergeWith': [1, 2, 0], + 'padChars': [2, 1, 0], + 'padCharsEnd': [2, 1, 0], + 'padCharsStart': [2, 1, 0], + 'pullAllBy': [2, 1, 0], + 'pullAllWith': [2, 1, 0], + 'rangeStep': [1, 2, 0], + 'rangeStepRight': [1, 2, 0], + 'setWith': [3, 1, 2, 0], + 'sortedIndexBy': [2, 1, 0], + 'sortedLastIndexBy': [2, 1, 0], + 'unionBy': [1, 2, 0], + 'unionWith': [1, 2, 0], + 'updateWith': [3, 1, 2, 0], + 'xorBy': [1, 2, 0], + 'xorWith': [1, 2, 0], + 'zipWith': [1, 2, 0] +}; + +/** Used to map method names to spread configs. */ +exports.methodSpread = { + 'assignAll': { 'start': 0 }, + 'assignAllWith': { 'start': 0 }, + 'assignInAll': { 'start': 0 }, + 'assignInAllWith': { 'start': 0 }, + 'defaultsAll': { 'start': 0 }, + 'defaultsDeepAll': { 'start': 0 }, + 'invokeArgs': { 'start': 2 }, + 'invokeArgsMap': { 'start': 2 }, + 'mergeAll': { 'start': 0 }, + 'mergeAllWith': { 'start': 0 }, + 'partial': { 'start': 1 }, + 'partialRight': { 'start': 1 }, + 'without': { 'start': 1 }, + 'zipAll': { 'start': 0 } +}; + +/** Used to identify methods which mutate arrays or objects. */ +exports.mutate = { + 'array': { + 'fill': true, + 'pull': true, + 'pullAll': true, + 'pullAllBy': true, + 'pullAllWith': true, + 'pullAt': true, + 'remove': true, + 'reverse': true + }, + 'object': { + 'assign': true, + 'assignAll': true, + 'assignAllWith': true, + 'assignIn': true, + 'assignInAll': true, + 'assignInAllWith': true, + 'assignInWith': true, + 'assignWith': true, + 'defaults': true, + 'defaultsAll': true, + 'defaultsDeep': true, + 'defaultsDeepAll': true, + 'merge': true, + 'mergeAll': true, + 'mergeAllWith': true, + 'mergeWith': true, + }, + 'set': { + 'set': true, + 'setWith': true, + 'unset': true, + 'update': true, + 'updateWith': true + } +}; + +/** Used to track methods with placeholder support */ +exports.placeholder = { + 'bind': true, + 'bindKey': true, + 'curry': true, + 'curryRight': true, + 'partial': true, + 'partialRight': true +}; + +/** Used to map real names to their aliases. */ +exports.realToAlias = (function() { + var hasOwnProperty = Object.prototype.hasOwnProperty, + object = exports.aliasToReal, + result = {}; + + for (var key in object) { + var value = object[key]; + if (hasOwnProperty.call(result, value)) { + result[value].push(key); + } else { + result[value] = [key]; + } + } + return result; +}()); + +/** Used to map method names to other names. */ +exports.remap = { + 'assignAll': 'assign', + 'assignAllWith': 'assignWith', + 'assignInAll': 'assignIn', + 'assignInAllWith': 'assignInWith', + 'curryN': 'curry', + 'curryRightN': 'curryRight', + 'defaultsAll': 'defaults', + 'defaultsDeepAll': 'defaultsDeep', + 'findFrom': 'find', + 'findIndexFrom': 'findIndex', + 'findLastFrom': 'findLast', + 'findLastIndexFrom': 'findLastIndex', + 'getOr': 'get', + 'includesFrom': 'includes', + 'indexOfFrom': 'indexOf', + 'invokeArgs': 'invoke', + 'invokeArgsMap': 'invokeMap', + 'lastIndexOfFrom': 'lastIndexOf', + 'mergeAll': 'merge', + 'mergeAllWith': 'mergeWith', + 'padChars': 'pad', + 'padCharsEnd': 'padEnd', + 'padCharsStart': 'padStart', + 'propertyOf': 'get', + 'rangeStep': 'range', + 'rangeStepRight': 'rangeRight', + 'restFrom': 'rest', + 'spreadFrom': 'spread', + 'trimChars': 'trim', + 'trimCharsEnd': 'trimEnd', + 'trimCharsStart': 'trimStart', + 'zipAll': 'zip' +}; + +/** Used to track methods that skip fixing their arity. */ +exports.skipFixed = { + 'castArray': true, + 'flow': true, + 'flowRight': true, + 'iteratee': true, + 'mixin': true, + 'rearg': true, + 'runInContext': true +}; + +/** Used to track methods that skip rearranging arguments. */ +exports.skipRearg = { + 'add': true, + 'assign': true, + 'assignIn': true, + 'bind': true, + 'bindKey': true, + 'concat': true, + 'difference': true, + 'divide': true, + 'eq': true, + 'gt': true, + 'gte': true, + 'isEqual': true, + 'lt': true, + 'lte': true, + 'matchesProperty': true, + 'merge': true, + 'multiply': true, + 'overArgs': true, + 'partial': true, + 'partialRight': true, + 'propertyOf': true, + 'random': true, + 'range': true, + 'rangeRight': true, + 'subtract': true, + 'zip': true, + 'zipObject': true, + 'zipObjectDeep': true +}; + /***/ }), /***/ "./node_modules/lodash/fp/placeholder.js": -/* no static exports found */ -/* all exports used */ -/*!************************************!*\ - !*** ./~/lodash/fp/placeholder.js ***! - \************************************/ /***/ (function(module, exports) { -eval("/**\n * The default argument placeholder value for methods.\n *\n * @type {Object}\n */\nmodule.exports = {};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9ub2RlX21vZHVsZXMvbG9kYXNoL2ZwL3BsYWNlaG9sZGVyLmpzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vLy4vfi9sb2Rhc2gvZnAvcGxhY2Vob2xkZXIuanM/MTkxZCJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFRoZSBkZWZhdWx0IGFyZ3VtZW50IHBsYWNlaG9sZGVyIHZhbHVlIGZvciBtZXRob2RzLlxuICpcbiAqIEB0eXBlIHtPYmplY3R9XG4gKi9cbm1vZHVsZS5leHBvcnRzID0ge307XG5cblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL34vbG9kYXNoL2ZwL3BsYWNlaG9sZGVyLmpzXG4vLyBtb2R1bGUgaWQgPSAuL25vZGVfbW9kdWxlcy9sb2Rhc2gvZnAvcGxhY2Vob2xkZXIuanNcbi8vIG1vZHVsZSBjaHVua3MgPSAwIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7Iiwic291cmNlUm9vdCI6IiJ9"); +/** + * The default argument placeholder value for methods. + * + * @type {Object} + */ +module.exports = {}; + /***/ }), /***/ "./node_modules/lodash/lodash.min.js": -/* no static exports found */ -/* all exports used */ -/*!********************************!*\ - !*** ./~/lodash/lodash.min.js ***! - \********************************/ /***/ (function(module, exports, __webpack_require__) { -eval("/* WEBPACK VAR INJECTION */(function(global, module) {var __WEBPACK_AMD_DEFINE_RESULT__;/**\n * @license\n * Lodash lodash.com/license | Underscore.js 1.8.3 underscorejs.org/LICENSE\n */\n;(function(){function n(n,t){return n.set(t[0],t[1]),n}function t(n,t){return n.add(t),n}function r(n,t,r){switch(r.length){case 0:return n.call(t);case 1:return n.call(t,r[0]);case 2:return n.call(t,r[0],r[1]);case 3:return n.call(t,r[0],r[1],r[2])}return n.apply(t,r)}function e(n,t,r,e){for(var u=-1,i=null==n?0:n.length;++u\"']/g,J=RegExp(G.source),Y=RegExp(H.source),Q=/<%-([\\s\\S]+?)%>/g,X=/<%([\\s\\S]+?)%>/g,nn=/<%=([\\s\\S]+?)%>/g,tn=/\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,rn=/^\\w*$/,en=/^\\./,un=/[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g,on=/[\\\\^$.*+?()[\\]{}|]/g,fn=RegExp(on.source),cn=/^\\s+|\\s+$/g,an=/^\\s+/,ln=/\\s+$/,sn=/\\{(?:\\n\\/\\* \\[wrapped with .+\\] \\*\\/)?\\n?/,hn=/\\{\\n\\/\\* \\[wrapped with (.+)\\] \\*/,pn=/,? & /,_n=/[^\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\x7f]+/g,vn=/\\\\(\\\\)?/g,gn=/\\$\\{([^\\\\}]*(?:\\\\.[^\\\\}]*)*)\\}/g,dn=/\\w*$/,yn=/^[-+]0x[0-9a-f]+$/i,bn=/^0b[01]+$/i,xn=/^\\[object .+?Constructor\\]$/,jn=/^0o[0-7]+$/i,wn=/^(?:0|[1-9]\\d*)$/,mn=/[\\xc0-\\xd6\\xd8-\\xf6\\xf8-\\xff\\u0100-\\u017f]/g,An=/($^)/,kn=/['\\n\\r\\u2028\\u2029\\\\]/g,En=\"[\\\\ufe0e\\\\ufe0f]?(?:[\\\\u0300-\\\\u036f\\\\ufe20-\\\\ufe2f\\\\u20d0-\\\\u20ff]|\\\\ud83c[\\\\udffb-\\\\udfff])?(?:\\\\u200d(?:[^\\\\ud800-\\\\udfff]|(?:\\\\ud83c[\\\\udde6-\\\\uddff]){2}|[\\\\ud800-\\\\udbff][\\\\udc00-\\\\udfff])[\\\\ufe0e\\\\ufe0f]?(?:[\\\\u0300-\\\\u036f\\\\ufe20-\\\\ufe2f\\\\u20d0-\\\\u20ff]|\\\\ud83c[\\\\udffb-\\\\udfff])?)*\",On=\"(?:[\\\\u2700-\\\\u27bf]|(?:\\\\ud83c[\\\\udde6-\\\\uddff]){2}|[\\\\ud800-\\\\udbff][\\\\udc00-\\\\udfff])\"+En,Sn=\"(?:[^\\\\ud800-\\\\udfff][\\\\u0300-\\\\u036f\\\\ufe20-\\\\ufe2f\\\\u20d0-\\\\u20ff]?|[\\\\u0300-\\\\u036f\\\\ufe20-\\\\ufe2f\\\\u20d0-\\\\u20ff]|(?:\\\\ud83c[\\\\udde6-\\\\uddff]){2}|[\\\\ud800-\\\\udbff][\\\\udc00-\\\\udfff]|[\\\\ud800-\\\\udfff])\",In=RegExp(\"['\\u2019]\",\"g\"),Rn=RegExp(\"[\\\\u0300-\\\\u036f\\\\ufe20-\\\\ufe2f\\\\u20d0-\\\\u20ff]\",\"g\"),zn=RegExp(\"\\\\ud83c[\\\\udffb-\\\\udfff](?=\\\\ud83c[\\\\udffb-\\\\udfff])|\"+Sn+En,\"g\"),Wn=RegExp([\"[A-Z\\\\xc0-\\\\xd6\\\\xd8-\\\\xde]?[a-z\\\\xdf-\\\\xf6\\\\xf8-\\\\xff]+(?:['\\u2019](?:d|ll|m|re|s|t|ve))?(?=[\\\\xac\\\\xb1\\\\xd7\\\\xf7\\\\x00-\\\\x2f\\\\x3a-\\\\x40\\\\x5b-\\\\x60\\\\x7b-\\\\xbf\\\\u2000-\\\\u206f \\\\t\\\\x0b\\\\f\\\\xa0\\\\ufeff\\\\n\\\\r\\\\u2028\\\\u2029\\\\u1680\\\\u180e\\\\u2000\\\\u2001\\\\u2002\\\\u2003\\\\u2004\\\\u2005\\\\u2006\\\\u2007\\\\u2008\\\\u2009\\\\u200a\\\\u202f\\\\u205f\\\\u3000]|[A-Z\\\\xc0-\\\\xd6\\\\xd8-\\\\xde]|$)|(?:[A-Z\\\\xc0-\\\\xd6\\\\xd8-\\\\xde]|[^\\\\ud800-\\\\udfff\\\\xac\\\\xb1\\\\xd7\\\\xf7\\\\x00-\\\\x2f\\\\x3a-\\\\x40\\\\x5b-\\\\x60\\\\x7b-\\\\xbf\\\\u2000-\\\\u206f \\\\t\\\\x0b\\\\f\\\\xa0\\\\ufeff\\\\n\\\\r\\\\u2028\\\\u2029\\\\u1680\\\\u180e\\\\u2000\\\\u2001\\\\u2002\\\\u2003\\\\u2004\\\\u2005\\\\u2006\\\\u2007\\\\u2008\\\\u2009\\\\u200a\\\\u202f\\\\u205f\\\\u3000\\\\d+\\\\u2700-\\\\u27bfa-z\\\\xdf-\\\\xf6\\\\xf8-\\\\xffA-Z\\\\xc0-\\\\xd6\\\\xd8-\\\\xde])+(?:['\\u2019](?:D|LL|M|RE|S|T|VE))?(?=[\\\\xac\\\\xb1\\\\xd7\\\\xf7\\\\x00-\\\\x2f\\\\x3a-\\\\x40\\\\x5b-\\\\x60\\\\x7b-\\\\xbf\\\\u2000-\\\\u206f \\\\t\\\\x0b\\\\f\\\\xa0\\\\ufeff\\\\n\\\\r\\\\u2028\\\\u2029\\\\u1680\\\\u180e\\\\u2000\\\\u2001\\\\u2002\\\\u2003\\\\u2004\\\\u2005\\\\u2006\\\\u2007\\\\u2008\\\\u2009\\\\u200a\\\\u202f\\\\u205f\\\\u3000]|[A-Z\\\\xc0-\\\\xd6\\\\xd8-\\\\xde](?:[a-z\\\\xdf-\\\\xf6\\\\xf8-\\\\xff]|[^\\\\ud800-\\\\udfff\\\\xac\\\\xb1\\\\xd7\\\\xf7\\\\x00-\\\\x2f\\\\x3a-\\\\x40\\\\x5b-\\\\x60\\\\x7b-\\\\xbf\\\\u2000-\\\\u206f \\\\t\\\\x0b\\\\f\\\\xa0\\\\ufeff\\\\n\\\\r\\\\u2028\\\\u2029\\\\u1680\\\\u180e\\\\u2000\\\\u2001\\\\u2002\\\\u2003\\\\u2004\\\\u2005\\\\u2006\\\\u2007\\\\u2008\\\\u2009\\\\u200a\\\\u202f\\\\u205f\\\\u3000\\\\d+\\\\u2700-\\\\u27bfa-z\\\\xdf-\\\\xf6\\\\xf8-\\\\xffA-Z\\\\xc0-\\\\xd6\\\\xd8-\\\\xde])|$)|[A-Z\\\\xc0-\\\\xd6\\\\xd8-\\\\xde]?(?:[a-z\\\\xdf-\\\\xf6\\\\xf8-\\\\xff]|[^\\\\ud800-\\\\udfff\\\\xac\\\\xb1\\\\xd7\\\\xf7\\\\x00-\\\\x2f\\\\x3a-\\\\x40\\\\x5b-\\\\x60\\\\x7b-\\\\xbf\\\\u2000-\\\\u206f \\\\t\\\\x0b\\\\f\\\\xa0\\\\ufeff\\\\n\\\\r\\\\u2028\\\\u2029\\\\u1680\\\\u180e\\\\u2000\\\\u2001\\\\u2002\\\\u2003\\\\u2004\\\\u2005\\\\u2006\\\\u2007\\\\u2008\\\\u2009\\\\u200a\\\\u202f\\\\u205f\\\\u3000\\\\d+\\\\u2700-\\\\u27bfa-z\\\\xdf-\\\\xf6\\\\xf8-\\\\xffA-Z\\\\xc0-\\\\xd6\\\\xd8-\\\\xde])+(?:['\\u2019](?:d|ll|m|re|s|t|ve))?|[A-Z\\\\xc0-\\\\xd6\\\\xd8-\\\\xde]+(?:['\\u2019](?:D|LL|M|RE|S|T|VE))?|\\\\d*(?:(?:1ST|2ND|3RD|(?![123])\\\\dTH)\\\\b)|\\\\d*(?:(?:1st|2nd|3rd|(?![123])\\\\dth)\\\\b)|\\\\d+\",On].join(\"|\"),\"g\"),Bn=RegExp(\"[\\\\u200d\\\\ud800-\\\\udfff\\\\u0300-\\\\u036f\\\\ufe20-\\\\ufe2f\\\\u20d0-\\\\u20ff\\\\ufe0e\\\\ufe0f]\"),Ln=/[a-z][A-Z]|[A-Z]{2,}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/,Un=\"Array Buffer DataView Date Error Float32Array Float64Array Function Int8Array Int16Array Int32Array Map Math Object Promise RegExp Set String Symbol TypeError Uint8Array Uint8ClampedArray Uint16Array Uint32Array WeakMap _ clearTimeout isFinite parseInt setTimeout\".split(\" \"),Cn={};\nCn[\"[object Float32Array]\"]=Cn[\"[object Float64Array]\"]=Cn[\"[object Int8Array]\"]=Cn[\"[object Int16Array]\"]=Cn[\"[object Int32Array]\"]=Cn[\"[object Uint8Array]\"]=Cn[\"[object Uint8ClampedArray]\"]=Cn[\"[object Uint16Array]\"]=Cn[\"[object Uint32Array]\"]=true,Cn[\"[object Arguments]\"]=Cn[\"[object Array]\"]=Cn[\"[object ArrayBuffer]\"]=Cn[\"[object Boolean]\"]=Cn[\"[object DataView]\"]=Cn[\"[object Date]\"]=Cn[\"[object Error]\"]=Cn[\"[object Function]\"]=Cn[\"[object Map]\"]=Cn[\"[object Number]\"]=Cn[\"[object Object]\"]=Cn[\"[object RegExp]\"]=Cn[\"[object Set]\"]=Cn[\"[object String]\"]=Cn[\"[object WeakMap]\"]=false;\nvar Dn={};Dn[\"[object Arguments]\"]=Dn[\"[object Array]\"]=Dn[\"[object ArrayBuffer]\"]=Dn[\"[object DataView]\"]=Dn[\"[object Boolean]\"]=Dn[\"[object Date]\"]=Dn[\"[object Float32Array]\"]=Dn[\"[object Float64Array]\"]=Dn[\"[object Int8Array]\"]=Dn[\"[object Int16Array]\"]=Dn[\"[object Int32Array]\"]=Dn[\"[object Map]\"]=Dn[\"[object Number]\"]=Dn[\"[object Object]\"]=Dn[\"[object RegExp]\"]=Dn[\"[object Set]\"]=Dn[\"[object String]\"]=Dn[\"[object Symbol]\"]=Dn[\"[object Uint8Array]\"]=Dn[\"[object Uint8ClampedArray]\"]=Dn[\"[object Uint16Array]\"]=Dn[\"[object Uint32Array]\"]=true,\nDn[\"[object Error]\"]=Dn[\"[object Function]\"]=Dn[\"[object WeakMap]\"]=false;var Mn,Tn={\"\\\\\":\"\\\\\",\"'\":\"'\",\"\\n\":\"n\",\"\\r\":\"r\",\"\\u2028\":\"u2028\",\"\\u2029\":\"u2029\"},$n=parseFloat,Fn=parseInt,Nn=typeof global==\"object\"&&global&&global.Object===Object&&global,Pn=typeof self==\"object\"&&self&&self.Object===Object&&self,Zn=Nn||Pn||Function(\"return this\")(),qn=typeof exports==\"object\"&&exports&&!exports.nodeType&&exports,Vn=qn&&typeof module==\"object\"&&module&&!module.nodeType&&module,Kn=Vn&&Vn.exports===qn,Gn=Kn&&Nn.process;\nn:{try{Mn=Gn&&Gn.binding&&Gn.binding(\"util\");break n}catch(n){}Mn=void 0}var Hn=Mn&&Mn.isArrayBuffer,Jn=Mn&&Mn.isDate,Yn=Mn&&Mn.isMap,Qn=Mn&&Mn.isRegExp,Xn=Mn&&Mn.isSet,nt=Mn&&Mn.isTypedArray,tt=j(\"length\"),rt=w({\"\\xc0\":\"A\",\"\\xc1\":\"A\",\"\\xc2\":\"A\",\"\\xc3\":\"A\",\"\\xc4\":\"A\",\"\\xc5\":\"A\",\"\\xe0\":\"a\",\"\\xe1\":\"a\",\"\\xe2\":\"a\",\"\\xe3\":\"a\",\"\\xe4\":\"a\",\"\\xe5\":\"a\",\"\\xc7\":\"C\",\"\\xe7\":\"c\",\"\\xd0\":\"D\",\"\\xf0\":\"d\",\"\\xc8\":\"E\",\"\\xc9\":\"E\",\"\\xca\":\"E\",\"\\xcb\":\"E\",\"\\xe8\":\"e\",\"\\xe9\":\"e\",\"\\xea\":\"e\",\"\\xeb\":\"e\",\"\\xcc\":\"I\",\"\\xcd\":\"I\",\"\\xce\":\"I\",\n\"\\xcf\":\"I\",\"\\xec\":\"i\",\"\\xed\":\"i\",\"\\xee\":\"i\",\"\\xef\":\"i\",\"\\xd1\":\"N\",\"\\xf1\":\"n\",\"\\xd2\":\"O\",\"\\xd3\":\"O\",\"\\xd4\":\"O\",\"\\xd5\":\"O\",\"\\xd6\":\"O\",\"\\xd8\":\"O\",\"\\xf2\":\"o\",\"\\xf3\":\"o\",\"\\xf4\":\"o\",\"\\xf5\":\"o\",\"\\xf6\":\"o\",\"\\xf8\":\"o\",\"\\xd9\":\"U\",\"\\xda\":\"U\",\"\\xdb\":\"U\",\"\\xdc\":\"U\",\"\\xf9\":\"u\",\"\\xfa\":\"u\",\"\\xfb\":\"u\",\"\\xfc\":\"u\",\"\\xdd\":\"Y\",\"\\xfd\":\"y\",\"\\xff\":\"y\",\"\\xc6\":\"Ae\",\"\\xe6\":\"ae\",\"\\xde\":\"Th\",\"\\xfe\":\"th\",\"\\xdf\":\"ss\",\"\\u0100\":\"A\",\"\\u0102\":\"A\",\"\\u0104\":\"A\",\"\\u0101\":\"a\",\"\\u0103\":\"a\",\"\\u0105\":\"a\",\"\\u0106\":\"C\",\"\\u0108\":\"C\",\"\\u010a\":\"C\",\n\"\\u010c\":\"C\",\"\\u0107\":\"c\",\"\\u0109\":\"c\",\"\\u010b\":\"c\",\"\\u010d\":\"c\",\"\\u010e\":\"D\",\"\\u0110\":\"D\",\"\\u010f\":\"d\",\"\\u0111\":\"d\",\"\\u0112\":\"E\",\"\\u0114\":\"E\",\"\\u0116\":\"E\",\"\\u0118\":\"E\",\"\\u011a\":\"E\",\"\\u0113\":\"e\",\"\\u0115\":\"e\",\"\\u0117\":\"e\",\"\\u0119\":\"e\",\"\\u011b\":\"e\",\"\\u011c\":\"G\",\"\\u011e\":\"G\",\"\\u0120\":\"G\",\"\\u0122\":\"G\",\"\\u011d\":\"g\",\"\\u011f\":\"g\",\"\\u0121\":\"g\",\"\\u0123\":\"g\",\"\\u0124\":\"H\",\"\\u0126\":\"H\",\"\\u0125\":\"h\",\"\\u0127\":\"h\",\"\\u0128\":\"I\",\"\\u012a\":\"I\",\"\\u012c\":\"I\",\"\\u012e\":\"I\",\"\\u0130\":\"I\",\"\\u0129\":\"i\",\"\\u012b\":\"i\",\"\\u012d\":\"i\",\n\"\\u012f\":\"i\",\"\\u0131\":\"i\",\"\\u0134\":\"J\",\"\\u0135\":\"j\",\"\\u0136\":\"K\",\"\\u0137\":\"k\",\"\\u0138\":\"k\",\"\\u0139\":\"L\",\"\\u013b\":\"L\",\"\\u013d\":\"L\",\"\\u013f\":\"L\",\"\\u0141\":\"L\",\"\\u013a\":\"l\",\"\\u013c\":\"l\",\"\\u013e\":\"l\",\"\\u0140\":\"l\",\"\\u0142\":\"l\",\"\\u0143\":\"N\",\"\\u0145\":\"N\",\"\\u0147\":\"N\",\"\\u014a\":\"N\",\"\\u0144\":\"n\",\"\\u0146\":\"n\",\"\\u0148\":\"n\",\"\\u014b\":\"n\",\"\\u014c\":\"O\",\"\\u014e\":\"O\",\"\\u0150\":\"O\",\"\\u014d\":\"o\",\"\\u014f\":\"o\",\"\\u0151\":\"o\",\"\\u0154\":\"R\",\"\\u0156\":\"R\",\"\\u0158\":\"R\",\"\\u0155\":\"r\",\"\\u0157\":\"r\",\"\\u0159\":\"r\",\"\\u015a\":\"S\",\"\\u015c\":\"S\",\n\"\\u015e\":\"S\",\"\\u0160\":\"S\",\"\\u015b\":\"s\",\"\\u015d\":\"s\",\"\\u015f\":\"s\",\"\\u0161\":\"s\",\"\\u0162\":\"T\",\"\\u0164\":\"T\",\"\\u0166\":\"T\",\"\\u0163\":\"t\",\"\\u0165\":\"t\",\"\\u0167\":\"t\",\"\\u0168\":\"U\",\"\\u016a\":\"U\",\"\\u016c\":\"U\",\"\\u016e\":\"U\",\"\\u0170\":\"U\",\"\\u0172\":\"U\",\"\\u0169\":\"u\",\"\\u016b\":\"u\",\"\\u016d\":\"u\",\"\\u016f\":\"u\",\"\\u0171\":\"u\",\"\\u0173\":\"u\",\"\\u0174\":\"W\",\"\\u0175\":\"w\",\"\\u0176\":\"Y\",\"\\u0177\":\"y\",\"\\u0178\":\"Y\",\"\\u0179\":\"Z\",\"\\u017b\":\"Z\",\"\\u017d\":\"Z\",\"\\u017a\":\"z\",\"\\u017c\":\"z\",\"\\u017e\":\"z\",\"\\u0132\":\"IJ\",\"\\u0133\":\"ij\",\"\\u0152\":\"Oe\",\"\\u0153\":\"oe\",\n\"\\u0149\":\"'n\",\"\\u017f\":\"s\"}),et=w({\"&\":\"&\",\"<\":\"<\",\">\":\">\",'\"':\""\",\"'\":\"'\"}),ut=w({\"&\":\"&\",\"<\":\"<\",\">\":\">\",\""\":'\"',\"'\":\"'\"}),it=function w(En){function On(n){if(xu(n)&&!af(n)&&!(n instanceof Mn)){if(n instanceof zn)return n;if(ci.call(n,\"__wrapped__\"))return Pe(n)}return new zn(n)}function Sn(){}function zn(n,t){this.__wrapped__=n,this.__actions__=[],this.__chain__=!!t,this.__index__=0,this.__values__=F}function Mn(n){this.__wrapped__=n,this.__actions__=[],this.__dir__=1,\nthis.__filtered__=false,this.__iteratees__=[],this.__takeCount__=4294967295,this.__views__=[]}function Tn(n){var t=-1,r=null==n?0:n.length;for(this.clear();++t=t?n:t)),n}function dt(n,t,r,e,i,o){var f,c=1&t,a=2&t,l=4&t;if(r&&(f=i?r(n,e,i,o):r(n)),f!==F)return f;if(!bu(n))return n;if(e=af(n)){if(f=Ee(n),!c)return Mr(n,f)}else{var s=yo(n),h=\"[object Function]\"==s||\"[object GeneratorFunction]\"==s;if(sf(n))return Wr(n,c);if(\"[object Object]\"==s||\"[object Arguments]\"==s||h&&!i){if(f=a||h?{}:Oe(n),!c)return a?Fr(n,pt(f,n)):$r(n,ht(f,n))}else{if(!Dn[s])return i?n:{};f=Se(n,s,dt,c)}}if(o||(o=new Vn),\ni=o.get(n))return i;o.set(n,f);var a=l?a?ye:de:a?Uu:Lu,p=e?F:a(n);return u(p||n,function(e,u){p&&(u=e,e=n[u]),at(f,u,dt(e,t,r,u,n,o))}),f}function yt(n){var t=Lu(n);return function(r){return bt(r,n,t)}}function bt(n,t,r){var e=r.length;if(null==n)return!e;for(n=ni(n);e--;){var u=r[e],i=t[u],o=n[u];if(o===F&&!(u in n)||!i(o))return false}return true}function xt(n,t,r){if(typeof n!=\"function\")throw new ei(\"Expected a function\");return jo(function(){n.apply(F,r)},t)}function jt(n,t,r,e){var u=-1,i=c,o=true,f=n.length,s=[],h=t.length;\nif(!f)return s;r&&(t=l(t,S(r))),e?(i=a,o=false):200<=t.length&&(i=R,o=false,t=new qn(t));n:for(;++ut}function Bt(n,t){return null!=n&&ci.call(n,t)}function Lt(n,t){return null!=n&&t in ni(n)}function Ut(n,t,r){for(var e=r?a:c,u=n[0].length,i=n.length,o=i,f=Hu(i),s=1/0,h=[];o--;){var p=n[o];o&&t&&(p=l(p,S(t))),s=Mi(p.length,s),f[o]=!r&&(t||120<=u&&120<=p.length)?new qn(o&&p):F}var p=n[0],_=-1,v=f[0];n:for(;++_t.length?n:It(n,vr(t,0,-1)),t=null==n?n:n[$e(Ge(t))],null==t?F:r(t,n,e)}function Mt(n){return xu(n)&&\"[object Arguments]\"==zt(n)}function Tt(n){return xu(n)&&\"[object ArrayBuffer]\"==zt(n)}function $t(n){return xu(n)&&\"[object Date]\"==zt(n)}function Ft(n,t,r,e,u){if(n===t)t=true;else if(null==n||null==t||!xu(n)&&!xu(t))t=n!==n&&t!==t;else n:{\nvar i=af(n),o=af(t),f=i?\"[object Array]\":yo(n),c=o?\"[object Array]\":yo(t),f=\"[object Arguments]\"==f?\"[object Object]\":f,c=\"[object Arguments]\"==c?\"[object Object]\":c,a=\"[object Object]\"==f,o=\"[object Object]\"==c;if((c=f==c)&&sf(n)){if(!sf(t)){t=false;break n}i=true,a=false}if(c&&!a)u||(u=new Vn),t=i||gf(n)?_e(n,t,r,e,Ft,u):ve(n,t,f,r,e,Ft,u);else{if(!(1&r)&&(i=a&&ci.call(n,\"__wrapped__\"),f=o&&ci.call(t,\"__wrapped__\"),i||f)){n=i?n.value():n,t=f?t.value():t,u||(u=new Vn),t=Ft(n,t,r,e,u);break n}if(c)t:if(u||(u=new Vn),\ni=1&r,f=de(n),o=f.length,c=de(t).length,o==c||i){for(a=o;a--;){var l=f[a];if(!(i?l in t:ci.call(t,l))){t=false;break t}}if((c=u.get(n))&&u.get(t))t=c==t;else{c=true,u.set(n,t),u.set(t,n);for(var s=i;++at?r:0,Re(t,r)?n[t]:F}function rr(n,t,r){var e=-1;return t=l(t.length?t:[Nu],S(je())),n=Yt(n,function(n){return{a:l(t,function(t){return t(n)}),b:++e,c:n}}),A(n,function(n,t){var e;n:{e=-1;for(var u=n.a,i=t.a,o=u.length,f=r.length;++e=f?c:c*(\"desc\"==r[e]?-1:1);\nbreak n}}e=n.b-t.b}return e})}function er(n,t){return ur(n,t,function(t,r){return Bu(n,r)})}function ur(n,t,r){for(var e=-1,u=t.length,i={};++et||9007199254740991t&&(t=-t>u?0:u+t),r=r>u?u:r,0>r&&(r+=u),u=t>r?0:r-t>>>0,t>>>=0,r=Hu(u);++e=u){for(;e>>1,o=n[i];null!==o&&!Au(o)&&(r?o<=t:ot.length?n:It(n,vr(t,0,-1)),\nnull==n||delete n[$e(Ge(t))]}function Ar(n,t,r,e){for(var u=n.length,i=e?u:-1;(e?i--:++ie)return e?wr(n[0]):[];for(var u=-1,i=Hu(e);++u=e?n:vr(n,t,r)}function Wr(n,t){if(t)return n.slice();var r=n.length,r=yi?yi(r):new n.constructor(r);return n.copy(r),r}function Br(n){var t=new n.constructor(n.byteLength);return new di(t).set(new di(n)),t}function Lr(n,t){return new n.constructor(t?Br(n.buffer):n.buffer,n.byteOffset,n.length)}function Ur(n,t){\nif(n!==t){var r=n!==F,e=null===n,u=n===n,i=Au(n),o=t!==F,f=null===t,c=t===t,a=Au(t);if(!f&&!a&&!i&&n>t||i&&o&&c&&!f&&!a||e&&o&&c||!r&&c||!u)return 1;if(!e&&!i&&!a&&nu?F:i,u=1),t=ni(t);++eo&&f[0]!==a&&f[o-1]!==a?[]:C(f,a),o-=c.length,or?r?ar(t,n):t:(r=ar(t,Ri(n/T(t))),Bn.test(t)?zr($(r),0,n).join(\"\"):r.slice(0,n))}function ue(n,t,e,u){function i(){for(var t=-1,c=arguments.length,a=-1,l=u.length,s=Hu(l+c),h=this&&this!==Zn&&this instanceof i?f:n;++at||e)&&(1&n&&(i[2]=h[2],t|=1&r?0:4),(r=h[3])&&(e=i[3],i[3]=e?Cr(e,r,h[4]):r,i[4]=e?C(i[3],\"__lodash_placeholder__\"):h[4]),(r=h[5])&&(e=i[5],i[5]=e?Dr(e,r,h[6]):r,i[6]=e?C(i[5],\"__lodash_placeholder__\"):h[6]),(r=h[7])&&(i[7]=r),128&n&&(i[8]=null==i[8]?h[8]:Mi(i[8],h[8])),null==i[9]&&(i[9]=h[9]),i[0]=h[0],i[1]=t),n=i[0],t=i[1],\nr=i[2],e=i[3],u=i[4],f=i[9]=i[9]===F?c?0:n.length:Di(i[9]-a,0),!f&&24&t&&(t&=-25),De((h?lo:xo)(t&&1!=t?8==t||16==t?Jr(n,t,f):32!=t&&33!=t||u.length?Xr.apply(F,i):ue(n,t,r,e):Vr(n,t,r),i),n,t)}function se(n,t,r,e){return n===F||hu(n,ii[r])&&!ci.call(e,r)?t:n}function he(n,t,r,e,u,i){return bu(n)&&bu(t)&&(i.set(t,n),nr(n,t,F,he,i),i.delete(t)),n}function pe(n){return wu(n)?F:n}function _e(n,t,r,e,u,i){var o=1&r,f=n.length,c=t.length;if(f!=c&&!(o&&c>f))return false;if((c=i.get(n))&&i.get(t))return c==t;var c=-1,a=true,l=2&r?new qn:F;\nfor(i.set(n,t),i.set(t,n);++cr&&(r=Di(e+r,0)),g(n,je(t,3),r)):-1}function qe(n,t,r){var e=null==n?0:n.length;if(!e)return-1;var u=e-1;return r!==F&&(u=Ou(r),u=0>r?Di(e+u,0):Mi(u,e-1)),\ng(n,je(t,3),u,true)}function Ve(n){return(null==n?0:n.length)?kt(n,1):[]}function Ke(n){return n&&n.length?n[0]:F}function Ge(n){var t=null==n?0:n.length;return t?n[t-1]:F}function He(n,t){return n&&n.length&&t&&t.length?or(n,t):n}function Je(n){return null==n?n:Ni.call(n)}function Ye(n){if(!n||!n.length)return[];var t=0;return n=f(n,function(n){if(_u(n))return t=Di(n.length,t),true}),E(t,function(t){return l(n,j(t))})}function Qe(n,t){if(!n||!n.length)return[];var e=Ye(n);return null==t?e:l(e,function(n){\nreturn r(t,F,n)})}function Xe(n){return n=On(n),n.__chain__=true,n}function nu(n,t){return t(n)}function tu(){return this}function ru(n,t){return(af(n)?u:oo)(n,je(t,3))}function eu(n,t){return(af(n)?i:fo)(n,je(t,3))}function uu(n,t){return(af(n)?l:Yt)(n,je(t,3))}function iu(n,t,r){return t=r?F:t,t=n&&null==t?n.length:t,le(n,128,F,F,F,F,t)}function ou(n,t){var r;if(typeof t!=\"function\")throw new ei(\"Expected a function\");return n=Ou(n),function(){return 0<--n&&(r=t.apply(this,arguments)),1>=n&&(t=F),\nr}}function fu(n,t,r){return t=r?F:t,n=le(n,8,F,F,F,F,F,t),n.placeholder=fu.placeholder,n}function cu(n,t,r){return t=r?F:t,n=le(n,16,F,F,F,F,F,t),n.placeholder=cu.placeholder,n}function au(n,t,r){function e(t){var r=c,e=a;return c=a=F,_=t,s=n.apply(e,r)}function u(n){var r=n-p;return n-=_,p===F||r>=t||0>r||g&&n>=l}function i(){var n=Jo();if(u(n))return o(n);var r,e=jo;r=n-_,n=t-(n-p),r=g?Mi(n,l-r):n,h=e(i,r)}function o(n){return h=F,d&&c?e(n):(c=a=F,s)}function f(){var n=Jo(),r=u(n);if(c=arguments,\na=this,p=n,r){if(h===F)return _=n=p,h=jo(i,t),v?e(n):s;if(g)return h=jo(i,t),e(p)}return h===F&&(h=jo(i,t)),s}var c,a,l,s,h,p,_=0,v=false,g=false,d=true;if(typeof n!=\"function\")throw new ei(\"Expected a function\");return t=Iu(t)||0,bu(r)&&(v=!!r.leading,l=(g=\"maxWait\"in r)?Di(Iu(r.maxWait)||0,t):l,d=\"trailing\"in r?!!r.trailing:d),f.cancel=function(){h!==F&&ho(h),_=0,c=p=a=h=F},f.flush=function(){return h===F?s:o(Jo())},f}function lu(n,t){function r(){var e=arguments,u=t?t.apply(this,e):e[0],i=r.cache;return i.has(u)?i.get(u):(e=n.apply(this,e),\nr.cache=i.set(u,e)||i,e)}if(typeof n!=\"function\"||null!=t&&typeof t!=\"function\")throw new ei(\"Expected a function\");return r.cache=new(lu.Cache||Pn),r}function su(n){if(typeof n!=\"function\")throw new ei(\"Expected a function\");return function(){var t=arguments;switch(t.length){case 0:return!n.call(this);case 1:return!n.call(this,t[0]);case 2:return!n.call(this,t[0],t[1]);case 3:return!n.call(this,t[0],t[1],t[2])}return!n.apply(this,t)}}function hu(n,t){return n===t||n!==n&&t!==t}function pu(n){return null!=n&&yu(n.length)&&!gu(n);\n}function _u(n){return xu(n)&&pu(n)}function vu(n){if(!xu(n))return false;var t=zt(n);return\"[object Error]\"==t||\"[object DOMException]\"==t||typeof n.message==\"string\"&&typeof n.name==\"string\"&&!wu(n)}function gu(n){return!!bu(n)&&(n=zt(n),\"[object Function]\"==n||\"[object GeneratorFunction]\"==n||\"[object AsyncFunction]\"==n||\"[object Proxy]\"==n)}function du(n){return typeof n==\"number\"&&n==Ou(n)}function yu(n){return typeof n==\"number\"&&-1=n}function bu(n){var t=typeof n;return null!=n&&(\"object\"==t||\"function\"==t);\n}function xu(n){return null!=n&&typeof n==\"object\"}function ju(n){return typeof n==\"number\"||xu(n)&&\"[object Number]\"==zt(n)}function wu(n){return!(!xu(n)||\"[object Object]\"!=zt(n))&&(n=bi(n),null===n||(n=ci.call(n,\"constructor\")&&n.constructor,typeof n==\"function\"&&n instanceof n&&fi.call(n)==hi))}function mu(n){return typeof n==\"string\"||!af(n)&&xu(n)&&\"[object String]\"==zt(n)}function Au(n){return typeof n==\"symbol\"||xu(n)&&\"[object Symbol]\"==zt(n)}function ku(n){if(!n)return[];if(pu(n))return mu(n)?$(n):Mr(n);\nif(Ai&&n[Ai]){n=n[Ai]();for(var t,r=[];!(t=n.next()).done;)r.push(t.value);return r}return t=yo(n),(\"[object Map]\"==t?L:\"[object Set]\"==t?D:Du)(n)}function Eu(n){return n?(n=Iu(n),n===N||n===-N?1.7976931348623157e308*(0>n?-1:1):n===n?n:0):0===n?n:0}function Ou(n){n=Eu(n);var t=n%1;return n===n?t?n-t:n:0}function Su(n){return n?gt(Ou(n),0,4294967295):0}function Iu(n){if(typeof n==\"number\")return n;if(Au(n))return P;if(bu(n)&&(n=typeof n.valueOf==\"function\"?n.valueOf():n,n=bu(n)?n+\"\":n),typeof n!=\"string\")return 0===n?n:+n;\nn=n.replace(cn,\"\");var t=bn.test(n);return t||jn.test(n)?Fn(n.slice(2),t?2:8):yn.test(n)?P:+n}function Ru(n){return Tr(n,Uu(n))}function zu(n){return null==n?\"\":jr(n)}function Wu(n,t,r){return n=null==n?F:It(n,t),n===F?r:n}function Bu(n,t){return null!=n&&ke(n,t,Lt)}function Lu(n){return pu(n)?Gn(n):Ht(n)}function Uu(n){if(pu(n))n=Gn(n,true);else if(bu(n)){var t,r=Le(n),e=[];for(t in n)(\"constructor\"!=t||!r&&ci.call(n,t))&&e.push(t);n=e}else{if(t=[],null!=n)for(r in ni(n))t.push(r);n=t}return n}function Cu(n,t){\nif(null==n)return{};var r=l(ye(n),function(n){return[n]});return t=je(t),ur(n,r,function(n,r){return t(n,r[0])})}function Du(n){return null==n?[]:I(n,Lu(n))}function Mu(n){return Nf(zu(n).toLowerCase())}function Tu(n){return(n=zu(n))&&n.replace(mn,rt).replace(Rn,\"\")}function $u(n,t,r){return n=zu(n),t=r?F:t,t===F?Ln.test(n)?n.match(Wn)||[]:n.match(_n)||[]:n.match(t)||[]}function Fu(n){return function(){return n}}function Nu(n){return n}function Pu(n){return Gt(typeof n==\"function\"?n:dt(n,1))}function Zu(n,t,r){\nvar e=Lu(t),i=St(t,e);null!=r||bu(t)&&(i.length||!e.length)||(r=t,t=n,n=this,i=St(t,Lu(t)));var o=!(bu(r)&&\"chain\"in r&&!r.chain),f=gu(n);return u(i,function(r){var e=t[r];n[r]=e,f&&(n.prototype[r]=function(){var t=this.__chain__;if(o||t){var r=n(this.__wrapped__);return(r.__actions__=Mr(this.__actions__)).push({func:e,args:arguments,thisArg:n}),r.__chain__=t,r}return e.apply(n,s([this.value()],arguments))})}),n}function qu(){}function Vu(n){return We(n)?j($e(n)):ir(n)}function Ku(){return[]}function Gu(){\nreturn false}En=null==En?Zn:it.defaults(Zn.Object(),En,it.pick(Zn,Un));var Hu=En.Array,Ju=En.Date,Yu=En.Error,Qu=En.Function,Xu=En.Math,ni=En.Object,ti=En.RegExp,ri=En.String,ei=En.TypeError,ui=Hu.prototype,ii=ni.prototype,oi=En[\"__core-js_shared__\"],fi=Qu.prototype.toString,ci=ii.hasOwnProperty,ai=0,li=function(){var n=/[^.]+$/.exec(oi&&oi.keys&&oi.keys.IE_PROTO||\"\");return n?\"Symbol(src)_1.\"+n:\"\"}(),si=ii.toString,hi=fi.call(ni),pi=Zn._,_i=ti(\"^\"+fi.call(ci).replace(on,\"\\\\$&\").replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g,\"$1.*?\")+\"$\"),vi=Kn?En.Buffer:F,gi=En.Symbol,di=En.Uint8Array,yi=vi?vi.f:F,bi=U(ni.getPrototypeOf,ni),xi=ni.create,ji=ii.propertyIsEnumerable,wi=ui.splice,mi=gi?gi.isConcatSpreadable:F,Ai=gi?gi.iterator:F,ki=gi?gi.toStringTag:F,Ei=function(){\ntry{var n=Ae(ni,\"defineProperty\");return n({},\"\",{}),n}catch(n){}}(),Oi=En.clearTimeout!==Zn.clearTimeout&&En.clearTimeout,Si=Ju&&Ju.now!==Zn.Date.now&&Ju.now,Ii=En.setTimeout!==Zn.setTimeout&&En.setTimeout,Ri=Xu.ceil,zi=Xu.floor,Wi=ni.getOwnPropertySymbols,Bi=vi?vi.isBuffer:F,Li=En.isFinite,Ui=ui.join,Ci=U(ni.keys,ni),Di=Xu.max,Mi=Xu.min,Ti=Ju.now,$i=En.parseInt,Fi=Xu.random,Ni=ui.reverse,Pi=Ae(En,\"DataView\"),Zi=Ae(En,\"Map\"),qi=Ae(En,\"Promise\"),Vi=Ae(En,\"Set\"),Ki=Ae(En,\"WeakMap\"),Gi=Ae(ni,\"create\"),Hi=Ki&&new Ki,Ji={},Yi=Fe(Pi),Qi=Fe(Zi),Xi=Fe(qi),no=Fe(Vi),to=Fe(Ki),ro=gi?gi.prototype:F,eo=ro?ro.valueOf:F,uo=ro?ro.toString:F,io=function(){\nfunction n(){}return function(t){return bu(t)?xi?xi(t):(n.prototype=t,t=new n,n.prototype=F,t):{}}}();On.templateSettings={escape:Q,evaluate:X,interpolate:nn,variable:\"\",imports:{_:On}},On.prototype=Sn.prototype,On.prototype.constructor=On,zn.prototype=io(Sn.prototype),zn.prototype.constructor=zn,Mn.prototype=io(Sn.prototype),Mn.prototype.constructor=Mn,Tn.prototype.clear=function(){this.__data__=Gi?Gi(null):{},this.size=0},Tn.prototype.delete=function(n){return n=this.has(n)&&delete this.__data__[n],\nthis.size-=n?1:0,n},Tn.prototype.get=function(n){var t=this.__data__;return Gi?(n=t[n],\"__lodash_hash_undefined__\"===n?F:n):ci.call(t,n)?t[n]:F},Tn.prototype.has=function(n){var t=this.__data__;return Gi?t[n]!==F:ci.call(t,n)},Tn.prototype.set=function(n,t){var r=this.__data__;return this.size+=this.has(n)?0:1,r[n]=Gi&&t===F?\"__lodash_hash_undefined__\":t,this},Nn.prototype.clear=function(){this.__data__=[],this.size=0},Nn.prototype.delete=function(n){var t=this.__data__;return n=lt(t,n),!(0>n)&&(n==t.length-1?t.pop():wi.call(t,n,1),\n--this.size,true)},Nn.prototype.get=function(n){var t=this.__data__;return n=lt(t,n),0>n?F:t[n][1]},Nn.prototype.has=function(n){return-1e?(++this.size,r.push([n,t])):r[e][1]=t,this},Pn.prototype.clear=function(){this.size=0,this.__data__={hash:new Tn,map:new(Zi||Nn),string:new Tn}},Pn.prototype.delete=function(n){return n=we(this,n).delete(n),this.size-=n?1:0,n},Pn.prototype.get=function(n){return we(this,n).get(n);\n},Pn.prototype.has=function(n){return we(this,n).has(n)},Pn.prototype.set=function(n,t){var r=we(this,n),e=r.size;return r.set(n,t),this.size+=r.size==e?0:1,this},qn.prototype.add=qn.prototype.push=function(n){return this.__data__.set(n,\"__lodash_hash_undefined__\"),this},qn.prototype.has=function(n){return this.__data__.has(n)},Vn.prototype.clear=function(){this.__data__=new Nn,this.size=0},Vn.prototype.delete=function(n){var t=this.__data__;return n=t.delete(n),this.size=t.size,n},Vn.prototype.get=function(n){\nreturn this.__data__.get(n)},Vn.prototype.has=function(n){return this.__data__.has(n)},Vn.prototype.set=function(n,t){var r=this.__data__;if(r instanceof Nn){var e=r.__data__;if(!Zi||199>e.length)return e.push([n,t]),this.size=++r.size,this;r=this.__data__=new Pn(e)}return r.set(n,t),this.size=r.size,this};var oo=Zr(Et),fo=Zr(Ot,true),co=qr(),ao=qr(true),lo=Hi?function(n,t){return Hi.set(n,t),n}:Nu,so=Ei?function(n,t){return Ei(n,\"toString\",{configurable:true,enumerable:false,value:Fu(t),writable:true})}:Nu,ho=Oi||function(n){\nreturn Zn.clearTimeout(n)},po=Vi&&1/D(new Vi([,-0]))[1]==N?function(n){return new Vi(n)}:qu,_o=Hi?function(n){return Hi.get(n)}:qu,vo=Wi?function(n){return null==n?[]:(n=ni(n),f(Wi(n),function(t){return ji.call(n,t)}))}:Ku,go=Wi?function(n){for(var t=[];n;)s(t,vo(n)),n=bi(n);return t}:Ku,yo=zt;(Pi&&\"[object DataView]\"!=yo(new Pi(new ArrayBuffer(1)))||Zi&&\"[object Map]\"!=yo(new Zi)||qi&&\"[object Promise]\"!=yo(qi.resolve())||Vi&&\"[object Set]\"!=yo(new Vi)||Ki&&\"[object WeakMap]\"!=yo(new Ki))&&(yo=function(n){\nvar t=zt(n);if(n=(n=\"[object Object]\"==t?n.constructor:F)?Fe(n):\"\")switch(n){case Yi:return\"[object DataView]\";case Qi:return\"[object Map]\";case Xi:return\"[object Promise]\";case no:return\"[object Set]\";case to:return\"[object WeakMap]\"}return t});var bo=oi?gu:Gu,xo=Me(lo),jo=Ii||function(n,t){return Zn.setTimeout(n,t)},wo=Me(so),mo=function(n){n=lu(n,function(n){return 500===t.size&&t.clear(),n});var t=n.cache;return n}(function(n){var t=[];return en.test(n)&&t.push(\"\"),n.replace(un,function(n,r,e,u){\nt.push(e?u.replace(vn,\"$1\"):r||n)}),t}),Ao=lr(function(n,t){return _u(n)?jt(n,kt(t,1,_u,true)):[]}),ko=lr(function(n,t){var r=Ge(t);return _u(r)&&(r=F),_u(n)?jt(n,kt(t,1,_u,true),je(r,2)):[]}),Eo=lr(function(n,t){var r=Ge(t);return _u(r)&&(r=F),_u(n)?jt(n,kt(t,1,_u,true),F,r):[]}),Oo=lr(function(n){var t=l(n,Sr);return t.length&&t[0]===n[0]?Ut(t):[]}),So=lr(function(n){var t=Ge(n),r=l(n,Sr);return t===Ge(r)?t=F:r.pop(),r.length&&r[0]===n[0]?Ut(r,je(t,2)):[]}),Io=lr(function(n){var t=Ge(n),r=l(n,Sr);return(t=typeof t==\"function\"?t:F)&&r.pop(),\nr.length&&r[0]===n[0]?Ut(r,F,t):[]}),Ro=lr(He),zo=ge(function(n,t){var r=null==n?0:n.length,e=vt(n,t);return fr(n,l(t,function(n){return Re(n,r)?+n:n}).sort(Ur)),e}),Wo=lr(function(n){return wr(kt(n,1,_u,true))}),Bo=lr(function(n){var t=Ge(n);return _u(t)&&(t=F),wr(kt(n,1,_u,true),je(t,2))}),Lo=lr(function(n){var t=Ge(n),t=typeof t==\"function\"?t:F;return wr(kt(n,1,_u,true),F,t)}),Uo=lr(function(n,t){return _u(n)?jt(n,t):[]}),Co=lr(function(n){return Er(f(n,_u))}),Do=lr(function(n){var t=Ge(n);return _u(t)&&(t=F),\nEr(f(n,_u),je(t,2))}),Mo=lr(function(n){var t=Ge(n),t=typeof t==\"function\"?t:F;return Er(f(n,_u),F,t)}),To=lr(Ye),$o=lr(function(n){var t=n.length,t=1=t}),cf=Mt(function(){return arguments}())?Mt:function(n){return xu(n)&&ci.call(n,\"callee\")&&!ji.call(n,\"callee\")},af=Hu.isArray,lf=Hn?S(Hn):Tt,sf=Bi||Gu,hf=Jn?S(Jn):$t,pf=Yn?S(Yn):Nt,_f=Qn?S(Qn):qt,vf=Xn?S(Xn):Vt,gf=nt?S(nt):Kt,df=oe(Jt),yf=oe(function(n,t){return n<=t}),bf=Pr(function(n,t){\nif(Le(t)||pu(t))Tr(t,Lu(t),n);else for(var r in t)ci.call(t,r)&&at(n,r,t[r])}),xf=Pr(function(n,t){Tr(t,Uu(t),n)}),jf=Pr(function(n,t,r,e){Tr(t,Uu(t),n,e)}),wf=Pr(function(n,t,r,e){Tr(t,Lu(t),n,e)}),mf=ge(vt),Af=lr(function(n){return n.push(F,se),r(jf,F,n)}),kf=lr(function(n){return n.push(F,he),r(Rf,F,n)}),Ef=ne(function(n,t,r){n[t]=r},Fu(Nu)),Of=ne(function(n,t,r){ci.call(n,t)?n[t].push(r):n[t]=[r]},je),Sf=lr(Dt),If=Pr(function(n,t,r){nr(n,t,r)}),Rf=Pr(function(n,t,r,e){nr(n,t,r,e)}),zf=ge(function(n,t){\nvar r={};if(null==n)return r;var e=false;t=l(t,function(t){return t=Rr(t,n),e||(e=1--n)return t.apply(this,arguments)}},On.ary=iu,On.assign=bf,On.assignIn=xf,On.assignInWith=jf,On.assignWith=wf,On.at=mf,On.before=ou,On.bind=Yo,On.bindAll=Zf,On.bindKey=Qo,On.castArray=function(){if(!arguments.length)return[];var n=arguments[0];return af(n)?n:[n]},\nOn.chain=Xe,On.chunk=function(n,t,r){if(t=(r?ze(n,t,r):t===F)?1:Di(Ou(t),0),r=null==n?0:n.length,!r||1>t)return[];for(var e=0,u=0,i=Hu(Ri(r/t));et?0:t,e)):[]},On.dropRight=function(n,t,r){var e=null==n?0:n.length;return e?(t=r||t===F?1:Ou(t),t=e-t,vr(n,0,0>t?0:t)):[]},On.dropRightWhile=function(n,t){return n&&n.length?Ar(n,je(t,3),true,true):[]},On.dropWhile=function(n,t){return n&&n.length?Ar(n,je(t,3),true):[]},On.fill=function(n,t,r,e){var u=null==n?0:n.length;if(!u)return[];for(r&&typeof r!=\"number\"&&ze(n,t,r)&&(r=0,e=u),u=n.length,r=Ou(r),0>r&&(r=-r>u?0:u+r),e=e===F||e>u?u:Ou(e),0>e&&(e+=u),e=r>e?0:Su(e);r>>0,r?(n=zu(n))&&(typeof t==\"string\"||null!=t&&!_f(t))&&(t=jr(t),\n!t&&Bn.test(n))?zr($(n),0,r):n.split(t,r):[]},On.spread=function(n,t){if(typeof n!=\"function\")throw new ei(\"Expected a function\");return t=null==t?0:Di(Ou(t),0),lr(function(e){var u=e[t];return e=zr(e,0,t),u&&s(e,u),r(n,this,e)})},On.tail=function(n){var t=null==n?0:n.length;return t?vr(n,1,t):[]},On.take=function(n,t,r){return n&&n.length?(t=r||t===F?1:Ou(t),vr(n,0,0>t?0:t)):[]},On.takeRight=function(n,t,r){var e=null==n?0:n.length;return e?(t=r||t===F?1:Ou(t),t=e-t,vr(n,0>t?0:t,e)):[]},On.takeRightWhile=function(n,t){\nreturn n&&n.length?Ar(n,je(t,3),false,true):[]},On.takeWhile=function(n,t){return n&&n.length?Ar(n,je(t,3)):[]},On.tap=function(n,t){return t(n),n},On.throttle=function(n,t,r){var e=true,u=true;if(typeof n!=\"function\")throw new ei(\"Expected a function\");return bu(r)&&(e=\"leading\"in r?!!r.leading:e,u=\"trailing\"in r?!!r.trailing:u),au(n,t,{leading:e,maxWait:t,trailing:u})},On.thru=nu,On.toArray=ku,On.toPairs=Bf,On.toPairsIn=Lf,On.toPath=function(n){return af(n)?l(n,$e):Au(n)?[n]:Mr(mo(zu(n)))},On.toPlainObject=Ru,\nOn.transform=function(n,t,r){var e=af(n),i=e||sf(n)||gf(n);if(t=je(t,4),null==r){var o=n&&n.constructor;r=i?e?new o:[]:bu(n)&&gu(o)?io(bi(n)):{}}return(i?u:Et)(n,function(n,e,u){return t(r,n,e,u)}),r},On.unary=function(n){return iu(n,1)},On.union=Wo,On.unionBy=Bo,On.unionWith=Lo,On.uniq=function(n){return n&&n.length?wr(n):[]},On.uniqBy=function(n,t){return n&&n.length?wr(n,je(t,2)):[]},On.uniqWith=function(n,t){return t=typeof t==\"function\"?t:F,n&&n.length?wr(n,F,t):[]},On.unset=function(n,t){return null==n||mr(n,t);\n},On.unzip=Ye,On.unzipWith=Qe,On.update=function(n,t,r){return null==n?n:pr(n,t,Ir(r)(It(n,t)),void 0)},On.updateWith=function(n,t,r,e){return e=typeof e==\"function\"?e:F,null!=n&&(n=pr(n,t,Ir(r)(It(n,t)),e)),n},On.values=Du,On.valuesIn=function(n){return null==n?[]:I(n,Uu(n))},On.without=Uo,On.words=$u,On.wrap=function(n,t){return rf(Ir(t),n)},On.xor=Co,On.xorBy=Do,On.xorWith=Mo,On.zip=To,On.zipObject=function(n,t){return Or(n||[],t||[],at)},On.zipObjectDeep=function(n,t){return Or(n||[],t||[],pr);\n},On.zipWith=$o,On.entries=Bf,On.entriesIn=Lf,On.extend=xf,On.extendWith=jf,Zu(On,On),On.add=nc,On.attempt=Pf,On.camelCase=Uf,On.capitalize=Mu,On.ceil=tc,On.clamp=function(n,t,r){return r===F&&(r=t,t=F),r!==F&&(r=Iu(r),r=r===r?r:0),t!==F&&(t=Iu(t),t=t===t?t:0),gt(Iu(n),t,r)},On.clone=function(n){return dt(n,4)},On.cloneDeep=function(n){return dt(n,5)},On.cloneDeepWith=function(n,t){return t=typeof t==\"function\"?t:F,dt(n,5,t)},On.cloneWith=function(n,t){return t=typeof t==\"function\"?t:F,dt(n,4,t)},\nOn.conformsTo=function(n,t){return null==t||bt(n,t,Lu(t))},On.deburr=Tu,On.defaultTo=function(n,t){return null==n||n!==n?t:n},On.divide=rc,On.endsWith=function(n,t,r){n=zu(n),t=jr(t);var e=n.length,e=r=r===F?e:gt(Ou(r),0,e);return r-=t.length,0<=r&&n.slice(r,e)==t},On.eq=hu,On.escape=function(n){return(n=zu(n))&&Y.test(n)?n.replace(H,et):n},On.escapeRegExp=function(n){return(n=zu(n))&&fn.test(n)?n.replace(on,\"\\\\$&\"):n},On.every=function(n,t,r){var e=af(n)?o:wt;return r&&ze(n,t,r)&&(t=F),e(n,je(t,3));\n},On.find=Po,On.findIndex=Ze,On.findKey=function(n,t){return v(n,je(t,3),Et)},On.findLast=Zo,On.findLastIndex=qe,On.findLastKey=function(n,t){return v(n,je(t,3),Ot)},On.floor=ec,On.forEach=ru,On.forEachRight=eu,On.forIn=function(n,t){return null==n?n:co(n,je(t,3),Uu)},On.forInRight=function(n,t){return null==n?n:ao(n,je(t,3),Uu)},On.forOwn=function(n,t){return n&&Et(n,je(t,3))},On.forOwnRight=function(n,t){return n&&Ot(n,je(t,3))},On.get=Wu,On.gt=of,On.gte=ff,On.has=function(n,t){return null!=n&&ke(n,t,Bt);\n},On.hasIn=Bu,On.head=Ke,On.identity=Nu,On.includes=function(n,t,r,e){return n=pu(n)?n:Du(n),r=r&&!e?Ou(r):0,e=n.length,0>r&&(r=Di(e+r,0)),mu(n)?r<=e&&-1r&&(r=Di(e+r,0)),d(n,t,r)):-1},On.inRange=function(n,t,r){return t=Eu(t),r===F?(r=t,t=0):r=Eu(r),n=Iu(n),n>=Mi(t,r)&&n=n},On.isSet=vf,On.isString=mu,On.isSymbol=Au,On.isTypedArray=gf,On.isUndefined=function(n){return n===F},On.isWeakMap=function(n){return xu(n)&&\"[object WeakMap]\"==yo(n)},On.isWeakSet=function(n){return xu(n)&&\"[object WeakSet]\"==zt(n)},On.join=function(n,t){\nreturn null==n?\"\":Ui.call(n,t)},On.kebabCase=Cf,On.last=Ge,On.lastIndexOf=function(n,t,r){var e=null==n?0:n.length;if(!e)return-1;var u=e;if(r!==F&&(u=Ou(r),u=0>u?Di(e+u,0):Mi(u,e-1)),t===t){for(r=u+1;r--&&n[r]!==t;);n=r}else n=g(n,b,u,true);return n},On.lowerCase=Df,On.lowerFirst=Mf,On.lt=df,On.lte=yf,On.max=function(n){return n&&n.length?mt(n,Nu,Wt):F},On.maxBy=function(n,t){return n&&n.length?mt(n,je(t,2),Wt):F},On.mean=function(n){return x(n,Nu)},On.meanBy=function(n,t){return x(n,je(t,2))},On.min=function(n){\nreturn n&&n.length?mt(n,Nu,Jt):F},On.minBy=function(n,t){return n&&n.length?mt(n,je(t,2),Jt):F},On.stubArray=Ku,On.stubFalse=Gu,On.stubObject=function(){return{}},On.stubString=function(){return\"\"},On.stubTrue=function(){return true},On.multiply=uc,On.nth=function(n,t){return n&&n.length?tr(n,Ou(t)):F},On.noConflict=function(){return Zn._===this&&(Zn._=pi),this},On.noop=qu,On.now=Jo,On.pad=function(n,t,r){n=zu(n);var e=(t=Ou(t))?T(n):0;return!t||e>=t?n:(t=(t-e)/2,ee(zi(t),r)+n+ee(Ri(t),r))},On.padEnd=function(n,t,r){\nn=zu(n);var e=(t=Ou(t))?T(n):0;return t&&et){var e=n;n=t,t=e}return r||n%1||t%1?(r=Fi(),Mi(n+r*(t-n+$n(\"1e-\"+((r+\"\").length-1))),t)):cr(n,t);\n},On.reduce=function(n,t,r){var e=af(n)?h:m,u=3>arguments.length;return e(n,je(t,4),r,u,oo)},On.reduceRight=function(n,t,r){var e=af(n)?p:m,u=3>arguments.length;return e(n,je(t,4),r,u,fo)},On.repeat=function(n,t,r){return t=(r?ze(n,t,r):t===F)?1:Ou(t),ar(zu(n),t)},On.replace=function(){var n=arguments,t=zu(n[0]);return 3>n.length?t:t.replace(n[1],n[2])},On.result=function(n,t,r){t=Rr(t,n);var e=-1,u=t.length;for(u||(u=1,n=F);++en||9007199254740991=i)return n;if(i=r-T(e),1>i)return e;\nif(r=o?zr(o,0,i).join(\"\"):n.slice(0,i),u===F)return r+e;if(o&&(i+=r.length-i),_f(u)){if(n.slice(i).search(u)){var f=r;for(u.global||(u=ti(u.source,zu(dn.exec(u))+\"g\")),u.lastIndex=0;o=u.exec(f);)var c=o.index;r=r.slice(0,c===F?i:c)}}else n.indexOf(jr(u),i)!=i&&(u=r.lastIndexOf(u),-1e.__dir__?\"Right\":\"\")}),e},Mn.prototype[n+\"Right\"]=function(t){\nreturn this.reverse()[n](t).reverse()}}),u([\"filter\",\"map\",\"takeWhile\"],function(n,t){var r=t+1,e=1==r||3==r;Mn.prototype[n]=function(n){var t=this.clone();return t.__iteratees__.push({iteratee:je(n,3),type:r}),t.__filtered__=t.__filtered__||e,t}}),u([\"head\",\"last\"],function(n,t){var r=\"take\"+(t?\"Right\":\"\");Mn.prototype[n]=function(){return this[r](1).value()[0]}}),u([\"initial\",\"tail\"],function(n,t){var r=\"drop\"+(t?\"\":\"Right\");Mn.prototype[n]=function(){return this.__filtered__?new Mn(this):this[r](1);\n}}),Mn.prototype.compact=function(){return this.filter(Nu)},Mn.prototype.find=function(n){return this.filter(n).head()},Mn.prototype.findLast=function(n){return this.reverse().find(n)},Mn.prototype.invokeMap=lr(function(n,t){return typeof n==\"function\"?new Mn(this):this.map(function(r){return Dt(r,n,t)})}),Mn.prototype.reject=function(n){return this.filter(su(je(n)))},Mn.prototype.slice=function(n,t){n=Ou(n);var r=this;return r.__filtered__&&(0t)?new Mn(r):(0>n?r=r.takeRight(-n):n&&(r=r.drop(n)),\nt!==F&&(t=Ou(t),r=0>t?r.dropRight(-t):r.take(t-n)),r)},Mn.prototype.takeRightWhile=function(n){return this.reverse().takeWhile(n).reverse()},Mn.prototype.toArray=function(){return this.take(4294967295)},Et(Mn.prototype,function(n,t){var r=/^(?:filter|find|map|reject)|While$/.test(t),e=/^(?:head|last)$/.test(t),u=On[e?\"take\"+(\"last\"==t?\"Right\":\"\"):t],i=e||/^find/.test(t);u&&(On.prototype[t]=function(){function t(n){return n=u.apply(On,s([n],f)),e&&h?n[0]:n}var o=this.__wrapped__,f=e?[1]:arguments,c=o instanceof Mn,a=f[0],l=c||af(o);\nl&&r&&typeof a==\"function\"&&1!=a.length&&(c=l=false);var h=this.__chain__,p=!!this.__actions__.length,a=i&&!h,c=c&&!p;return!i&&l?(o=c?o:new Mn(this),o=n.apply(o,f),o.__actions__.push({func:nu,args:[t],thisArg:F}),new zn(o,h)):a&&c?n.apply(this,f):(o=this.thru(t),a?e?o.value()[0]:o.value():o)})}),u(\"pop push shift sort splice unshift\".split(\" \"),function(n){var t=ui[n],r=/^(?:push|sort|unshift)$/.test(n)?\"tap\":\"thru\",e=/^(?:pop|shift)$/.test(n);On.prototype[n]=function(){var n=arguments;if(e&&!this.__chain__){\nvar u=this.value();return t.apply(af(u)?u:[],n)}return this[r](function(r){return t.apply(af(r)?r:[],n)})}}),Et(Mn.prototype,function(n,t){var r=On[t];if(r){var e=r.name+\"\";(Ji[e]||(Ji[e]=[])).push({name:t,func:r})}}),Ji[Xr(F,2).name]=[{name:\"wrapper\",func:F}],Mn.prototype.clone=function(){var n=new Mn(this.__wrapped__);return n.__actions__=Mr(this.__actions__),n.__dir__=this.__dir__,n.__filtered__=this.__filtered__,n.__iteratees__=Mr(this.__iteratees__),n.__takeCount__=this.__takeCount__,n.__views__=Mr(this.__views__),\nn},Mn.prototype.reverse=function(){if(this.__filtered__){var n=new Mn(this);n.__dir__=-1,n.__filtered__=true}else n=this.clone(),n.__dir__*=-1;return n},Mn.prototype.value=function(){var n,t=this.__wrapped__.value(),r=this.__dir__,e=af(t),u=0>r,i=e?t.length:0;n=i;for(var o=this.__views__,f=0,c=-1,a=o.length;++c=this.__values__.length;return{done:n,value:n?F:this.__values__[this.__index__++]}},On.prototype.plant=function(n){for(var t,r=this;r instanceof Sn;){var e=Pe(r);e.__index__=0,e.__values__=F,t?u.__wrapped__=e:t=e;var u=e,r=r.__wrapped__}return u.__wrapped__=n,t},On.prototype.reverse=function(){var n=this.__wrapped__;return n instanceof Mn?(this.__actions__.length&&(n=new Mn(this)),n=n.reverse(),n.__actions__.push({func:nu,args:[Je],thisArg:F}),new zn(n,this.__chain__)):this.thru(Je);\n},On.prototype.toJSON=On.prototype.valueOf=On.prototype.value=function(){return kr(this.__wrapped__,this.__actions__)},On.prototype.first=On.prototype.head,Ai&&(On.prototype[Ai]=tu),On}(); true?(Zn._=it, !(__WEBPACK_AMD_DEFINE_RESULT__ = function(){return it}.call(exports, __webpack_require__, exports, module),\n\t\t\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__))):Vn?((Vn.exports=it)._=it,qn._=it):Zn._=it}).call(this);\n/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(/*! ./../webpack/buildin/global.js */ \"./node_modules/webpack/buildin/global.js\"), __webpack_require__(/*! ./../webpack/buildin/module.js */ \"./node_modules/webpack/buildin/module.js\")(module)))//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9ub2RlX21vZHVsZXMvbG9kYXNoL2xvZGFzaC5taW4uanMuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9+L2xvZGFzaC9sb2Rhc2gubWluLmpzPzI2NjkiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogTG9kYXNoIGxvZGFzaC5jb20vbGljZW5zZSB8IFVuZGVyc2NvcmUuanMgMS44LjMgdW5kZXJzY29yZWpzLm9yZy9MSUNFTlNFXG4gKi9cbjsoZnVuY3Rpb24oKXtmdW5jdGlvbiBuKG4sdCl7cmV0dXJuIG4uc2V0KHRbMF0sdFsxXSksbn1mdW5jdGlvbiB0KG4sdCl7cmV0dXJuIG4uYWRkKHQpLG59ZnVuY3Rpb24gcihuLHQscil7c3dpdGNoKHIubGVuZ3RoKXtjYXNlIDA6cmV0dXJuIG4uY2FsbCh0KTtjYXNlIDE6cmV0dXJuIG4uY2FsbCh0LHJbMF0pO2Nhc2UgMjpyZXR1cm4gbi5jYWxsKHQsclswXSxyWzFdKTtjYXNlIDM6cmV0dXJuIG4uY2FsbCh0LHJbMF0sclsxXSxyWzJdKX1yZXR1cm4gbi5hcHBseSh0LHIpfWZ1bmN0aW9uIGUobix0LHIsZSl7Zm9yKHZhciB1PS0xLGk9bnVsbD09bj8wOm4ubGVuZ3RoOysrdTxpOyl7dmFyIG89blt1XTt0KGUsbyxyKG8pLG4pfXJldHVybiBlfWZ1bmN0aW9uIHUobix0KXtmb3IodmFyIHI9LTEsZT1udWxsPT1uPzA6bi5sZW5ndGg7KytyPGUmJmZhbHNlIT09dChuW3JdLHIsbik7KTtyZXR1cm4gbn1mdW5jdGlvbiBpKG4sdCl7Zm9yKHZhciByPW51bGw9PW4/MDpuLmxlbmd0aDtyLS0mJmZhbHNlIT09dChuW3JdLHIsbik7KTtcbnJldHVybiBufWZ1bmN0aW9uIG8obix0KXtmb3IodmFyIHI9LTEsZT1udWxsPT1uPzA6bi5sZW5ndGg7KytyPGU7KWlmKCF0KG5bcl0scixuKSlyZXR1cm4gZmFsc2U7cmV0dXJuIHRydWV9ZnVuY3Rpb24gZihuLHQpe2Zvcih2YXIgcj0tMSxlPW51bGw9PW4/MDpuLmxlbmd0aCx1PTAsaT1bXTsrK3I8ZTspe3ZhciBvPW5bcl07dChvLHIsbikmJihpW3UrK109byl9cmV0dXJuIGl9ZnVuY3Rpb24gYyhuLHQpe3JldHVybiEobnVsbD09bnx8IW4ubGVuZ3RoKSYmLTE8ZChuLHQsMCl9ZnVuY3Rpb24gYShuLHQscil7Zm9yKHZhciBlPS0xLHU9bnVsbD09bj8wOm4ubGVuZ3RoOysrZTx1OylpZihyKHQsbltlXSkpcmV0dXJuIHRydWU7cmV0dXJuIGZhbHNlfWZ1bmN0aW9uIGwobix0KXtmb3IodmFyIHI9LTEsZT1udWxsPT1uPzA6bi5sZW5ndGgsdT1BcnJheShlKTsrK3I8ZTspdVtyXT10KG5bcl0scixuKTtyZXR1cm4gdX1mdW5jdGlvbiBzKG4sdCl7Zm9yKHZhciByPS0xLGU9dC5sZW5ndGgsdT1uLmxlbmd0aDsrK3I8ZTspblt1K3JdPXRbcl07XG5yZXR1cm4gbn1mdW5jdGlvbiBoKG4sdCxyLGUpe3ZhciB1PS0xLGk9bnVsbD09bj8wOm4ubGVuZ3RoO2ZvcihlJiZpJiYocj1uWysrdV0pOysrdTxpOylyPXQocixuW3VdLHUsbik7cmV0dXJuIHJ9ZnVuY3Rpb24gcChuLHQscixlKXt2YXIgdT1udWxsPT1uPzA6bi5sZW5ndGg7Zm9yKGUmJnUmJihyPW5bLS11XSk7dS0tOylyPXQocixuW3VdLHUsbik7cmV0dXJuIHJ9ZnVuY3Rpb24gXyhuLHQpe2Zvcih2YXIgcj0tMSxlPW51bGw9PW4/MDpuLmxlbmd0aDsrK3I8ZTspaWYodChuW3JdLHIsbikpcmV0dXJuIHRydWU7cmV0dXJuIGZhbHNlfWZ1bmN0aW9uIHYobix0LHIpe3ZhciBlO3JldHVybiByKG4sZnVuY3Rpb24obixyLHUpe2lmKHQobixyLHUpKXJldHVybiBlPXIsZmFsc2V9KSxlfWZ1bmN0aW9uIGcobix0LHIsZSl7dmFyIHU9bi5sZW5ndGg7Zm9yKHIrPWU/MTotMTtlP3ItLTorK3I8dTspaWYodChuW3JdLHIsbikpcmV0dXJuIHI7cmV0dXJuLTF9ZnVuY3Rpb24gZChuLHQscil7aWYodD09PXQpbjp7XG4tLXI7Zm9yKHZhciBlPW4ubGVuZ3RoOysrcjxlOylpZihuW3JdPT09dCl7bj1yO2JyZWFrIG59bj0tMX1lbHNlIG49ZyhuLGIscik7cmV0dXJuIG59ZnVuY3Rpb24geShuLHQscixlKXstLXI7Zm9yKHZhciB1PW4ubGVuZ3RoOysrcjx1OylpZihlKG5bcl0sdCkpcmV0dXJuIHI7cmV0dXJuLTF9ZnVuY3Rpb24gYihuKXtyZXR1cm4gbiE9PW59ZnVuY3Rpb24geChuLHQpe3ZhciByPW51bGw9PW4/MDpuLmxlbmd0aDtyZXR1cm4gcj9rKG4sdCkvcjpQfWZ1bmN0aW9uIGoobil7cmV0dXJuIGZ1bmN0aW9uKHQpe3JldHVybiBudWxsPT10P0Y6dFtuXX19ZnVuY3Rpb24gdyhuKXtyZXR1cm4gZnVuY3Rpb24odCl7cmV0dXJuIG51bGw9PW4/RjpuW3RdfX1mdW5jdGlvbiBtKG4sdCxyLGUsdSl7cmV0dXJuIHUobixmdW5jdGlvbihuLHUsaSl7cj1lPyhlPWZhbHNlLG4pOnQocixuLHUsaSl9KSxyfWZ1bmN0aW9uIEEobix0KXt2YXIgcj1uLmxlbmd0aDtmb3Iobi5zb3J0KHQpO3ItLTspbltyXT1uW3JdLmM7XG5yZXR1cm4gbn1mdW5jdGlvbiBrKG4sdCl7Zm9yKHZhciByLGU9LTEsdT1uLmxlbmd0aDsrK2U8dTspe3ZhciBpPXQobltlXSk7aSE9PUYmJihyPXI9PT1GP2k6citpKX1yZXR1cm4gcn1mdW5jdGlvbiBFKG4sdCl7Zm9yKHZhciByPS0xLGU9QXJyYXkobik7KytyPG47KWVbcl09dChyKTtyZXR1cm4gZX1mdW5jdGlvbiBPKG4sdCl7cmV0dXJuIGwodCxmdW5jdGlvbih0KXtyZXR1cm5bdCxuW3RdXX0pfWZ1bmN0aW9uIFMobil7cmV0dXJuIGZ1bmN0aW9uKHQpe3JldHVybiBuKHQpfX1mdW5jdGlvbiBJKG4sdCl7cmV0dXJuIGwodCxmdW5jdGlvbih0KXtyZXR1cm4gblt0XX0pfWZ1bmN0aW9uIFIobix0KXtyZXR1cm4gbi5oYXModCl9ZnVuY3Rpb24geihuLHQpe2Zvcih2YXIgcj0tMSxlPW4ubGVuZ3RoOysrcjxlJiYtMTxkKHQsbltyXSwwKTspO3JldHVybiByfWZ1bmN0aW9uIFcobix0KXtmb3IodmFyIHI9bi5sZW5ndGg7ci0tJiYtMTxkKHQsbltyXSwwKTspO3JldHVybiByfWZ1bmN0aW9uIEIobil7XG5yZXR1cm5cIlxcXFxcIitUbltuXX1mdW5jdGlvbiBMKG4pe3ZhciB0PS0xLHI9QXJyYXkobi5zaXplKTtyZXR1cm4gbi5mb3JFYWNoKGZ1bmN0aW9uKG4sZSl7clsrK3RdPVtlLG5dfSkscn1mdW5jdGlvbiBVKG4sdCl7cmV0dXJuIGZ1bmN0aW9uKHIpe3JldHVybiBuKHQocikpfX1mdW5jdGlvbiBDKG4sdCl7Zm9yKHZhciByPS0xLGU9bi5sZW5ndGgsdT0wLGk9W107KytyPGU7KXt2YXIgbz1uW3JdO28hPT10JiZcIl9fbG9kYXNoX3BsYWNlaG9sZGVyX19cIiE9PW98fChuW3JdPVwiX19sb2Rhc2hfcGxhY2Vob2xkZXJfX1wiLGlbdSsrXT1yKX1yZXR1cm4gaX1mdW5jdGlvbiBEKG4pe3ZhciB0PS0xLHI9QXJyYXkobi5zaXplKTtyZXR1cm4gbi5mb3JFYWNoKGZ1bmN0aW9uKG4pe3JbKyt0XT1ufSkscn1mdW5jdGlvbiBNKG4pe3ZhciB0PS0xLHI9QXJyYXkobi5zaXplKTtyZXR1cm4gbi5mb3JFYWNoKGZ1bmN0aW9uKG4pe3JbKyt0XT1bbixuXX0pLHJ9ZnVuY3Rpb24gVChuKXtpZihCbi50ZXN0KG4pKXtcbmZvcih2YXIgdD16bi5sYXN0SW5kZXg9MDt6bi50ZXN0KG4pOykrK3Q7bj10fWVsc2Ugbj10dChuKTtyZXR1cm4gbn1mdW5jdGlvbiAkKG4pe3JldHVybiBCbi50ZXN0KG4pP24ubWF0Y2goem4pfHxbXTpuLnNwbGl0KFwiXCIpfXZhciBGLE49MS8wLFA9TmFOLFo9W1tcImFyeVwiLDEyOF0sW1wiYmluZFwiLDFdLFtcImJpbmRLZXlcIiwyXSxbXCJjdXJyeVwiLDhdLFtcImN1cnJ5UmlnaHRcIiwxNl0sW1wiZmxpcFwiLDUxMl0sW1wicGFydGlhbFwiLDMyXSxbXCJwYXJ0aWFsUmlnaHRcIiw2NF0sW1wicmVhcmdcIiwyNTZdXSxxPS9cXGJfX3BcXCs9Jyc7L2csVj0vXFxiKF9fcFxcKz0pJydcXCsvZyxLPS8oX19lXFwoLio/XFwpfFxcYl9fdFxcKSlcXCsnJzsvZyxHPS8mKD86YW1wfGx0fGd0fHF1b3R8IzM5KTsvZyxIPS9bJjw+XCInXS9nLEo9UmVnRXhwKEcuc291cmNlKSxZPVJlZ0V4cChILnNvdXJjZSksUT0vPCUtKFtcXHNcXFNdKz8pJT4vZyxYPS88JShbXFxzXFxTXSs/KSU+L2csbm49LzwlPShbXFxzXFxTXSs/KSU+L2csdG49L1xcLnxcXFsoPzpbXltcXF1dKnwoW1wiJ10pKD86KD8hXFwxKVteXFxcXF18XFxcXC4pKj9cXDEpXFxdLyxybj0vXlxcdyokLyxlbj0vXlxcLi8sdW49L1teLltcXF1dK3xcXFsoPzooLT9cXGQrKD86XFwuXFxkKyk/KXwoW1wiJ10pKCg/Oig/IVxcMilbXlxcXFxdfFxcXFwuKSo/KVxcMilcXF18KD89KD86XFwufFxcW1xcXSkoPzpcXC58XFxbXFxdfCQpKS9nLG9uPS9bXFxcXF4kLiorPygpW1xcXXt9fF0vZyxmbj1SZWdFeHAob24uc291cmNlKSxjbj0vXlxccyt8XFxzKyQvZyxhbj0vXlxccysvLGxuPS9cXHMrJC8sc249L1xceyg/OlxcblxcL1xcKiBcXFt3cmFwcGVkIHdpdGggLitcXF0gXFwqXFwvKT9cXG4/Lyxobj0vXFx7XFxuXFwvXFwqIFxcW3dyYXBwZWQgd2l0aCAoLispXFxdIFxcKi8scG49Lyw/ICYgLyxfbj0vW15cXHgwMC1cXHgyZlxceDNhLVxceDQwXFx4NWItXFx4NjBcXHg3Yi1cXHg3Zl0rL2csdm49L1xcXFwoXFxcXCk/L2csZ249L1xcJFxceyhbXlxcXFx9XSooPzpcXFxcLlteXFxcXH1dKikqKVxcfS9nLGRuPS9cXHcqJC8seW49L15bLStdMHhbMC05YS1mXSskL2ksYm49L14wYlswMV0rJC9pLHhuPS9eXFxbb2JqZWN0IC4rP0NvbnN0cnVjdG9yXFxdJC8sam49L14wb1swLTddKyQvaSx3bj0vXig/OjB8WzEtOV1cXGQqKSQvLG1uPS9bXFx4YzAtXFx4ZDZcXHhkOC1cXHhmNlxceGY4LVxceGZmXFx1MDEwMC1cXHUwMTdmXS9nLEFuPS8oJF4pLyxrbj0vWydcXG5cXHJcXHUyMDI4XFx1MjAyOVxcXFxdL2csRW49XCJbXFxcXHVmZTBlXFxcXHVmZTBmXT8oPzpbXFxcXHUwMzAwLVxcXFx1MDM2ZlxcXFx1ZmUyMC1cXFxcdWZlMmZcXFxcdTIwZDAtXFxcXHUyMGZmXXxcXFxcdWQ4M2NbXFxcXHVkZmZiLVxcXFx1ZGZmZl0pPyg/OlxcXFx1MjAwZCg/OlteXFxcXHVkODAwLVxcXFx1ZGZmZl18KD86XFxcXHVkODNjW1xcXFx1ZGRlNi1cXFxcdWRkZmZdKXsyfXxbXFxcXHVkODAwLVxcXFx1ZGJmZl1bXFxcXHVkYzAwLVxcXFx1ZGZmZl0pW1xcXFx1ZmUwZVxcXFx1ZmUwZl0/KD86W1xcXFx1MDMwMC1cXFxcdTAzNmZcXFxcdWZlMjAtXFxcXHVmZTJmXFxcXHUyMGQwLVxcXFx1MjBmZl18XFxcXHVkODNjW1xcXFx1ZGZmYi1cXFxcdWRmZmZdKT8pKlwiLE9uPVwiKD86W1xcXFx1MjcwMC1cXFxcdTI3YmZdfCg/OlxcXFx1ZDgzY1tcXFxcdWRkZTYtXFxcXHVkZGZmXSl7Mn18W1xcXFx1ZDgwMC1cXFxcdWRiZmZdW1xcXFx1ZGMwMC1cXFxcdWRmZmZdKVwiK0VuLFNuPVwiKD86W15cXFxcdWQ4MDAtXFxcXHVkZmZmXVtcXFxcdTAzMDAtXFxcXHUwMzZmXFxcXHVmZTIwLVxcXFx1ZmUyZlxcXFx1MjBkMC1cXFxcdTIwZmZdP3xbXFxcXHUwMzAwLVxcXFx1MDM2ZlxcXFx1ZmUyMC1cXFxcdWZlMmZcXFxcdTIwZDAtXFxcXHUyMGZmXXwoPzpcXFxcdWQ4M2NbXFxcXHVkZGU2LVxcXFx1ZGRmZl0pezJ9fFtcXFxcdWQ4MDAtXFxcXHVkYmZmXVtcXFxcdWRjMDAtXFxcXHVkZmZmXXxbXFxcXHVkODAwLVxcXFx1ZGZmZl0pXCIsSW49UmVnRXhwKFwiWydcXHUyMDE5XVwiLFwiZ1wiKSxSbj1SZWdFeHAoXCJbXFxcXHUwMzAwLVxcXFx1MDM2ZlxcXFx1ZmUyMC1cXFxcdWZlMmZcXFxcdTIwZDAtXFxcXHUyMGZmXVwiLFwiZ1wiKSx6bj1SZWdFeHAoXCJcXFxcdWQ4M2NbXFxcXHVkZmZiLVxcXFx1ZGZmZl0oPz1cXFxcdWQ4M2NbXFxcXHVkZmZiLVxcXFx1ZGZmZl0pfFwiK1NuK0VuLFwiZ1wiKSxXbj1SZWdFeHAoW1wiW0EtWlxcXFx4YzAtXFxcXHhkNlxcXFx4ZDgtXFxcXHhkZV0/W2EtelxcXFx4ZGYtXFxcXHhmNlxcXFx4ZjgtXFxcXHhmZl0rKD86WydcXHUyMDE5XSg/OmR8bGx8bXxyZXxzfHR8dmUpKT8oPz1bXFxcXHhhY1xcXFx4YjFcXFxceGQ3XFxcXHhmN1xcXFx4MDAtXFxcXHgyZlxcXFx4M2EtXFxcXHg0MFxcXFx4NWItXFxcXHg2MFxcXFx4N2ItXFxcXHhiZlxcXFx1MjAwMC1cXFxcdTIwNmYgXFxcXHRcXFxceDBiXFxcXGZcXFxceGEwXFxcXHVmZWZmXFxcXG5cXFxcclxcXFx1MjAyOFxcXFx1MjAyOVxcXFx1MTY4MFxcXFx1MTgwZVxcXFx1MjAwMFxcXFx1MjAwMVxcXFx1MjAwMlxcXFx1MjAwM1xcXFx1MjAwNFxcXFx1MjAwNVxcXFx1MjAwNlxcXFx1MjAwN1xcXFx1MjAwOFxcXFx1MjAwOVxcXFx1MjAwYVxcXFx1MjAyZlxcXFx1MjA1ZlxcXFx1MzAwMF18W0EtWlxcXFx4YzAtXFxcXHhkNlxcXFx4ZDgtXFxcXHhkZV18JCl8KD86W0EtWlxcXFx4YzAtXFxcXHhkNlxcXFx4ZDgtXFxcXHhkZV18W15cXFxcdWQ4MDAtXFxcXHVkZmZmXFxcXHhhY1xcXFx4YjFcXFxceGQ3XFxcXHhmN1xcXFx4MDAtXFxcXHgyZlxcXFx4M2EtXFxcXHg0MFxcXFx4NWItXFxcXHg2MFxcXFx4N2ItXFxcXHhiZlxcXFx1MjAwMC1cXFxcdTIwNmYgXFxcXHRcXFxceDBiXFxcXGZcXFxceGEwXFxcXHVmZWZmXFxcXG5cXFxcclxcXFx1MjAyOFxcXFx1MjAyOVxcXFx1MTY4MFxcXFx1MTgwZVxcXFx1MjAwMFxcXFx1MjAwMVxcXFx1MjAwMlxcXFx1MjAwM1xcXFx1MjAwNFxcXFx1MjAwNVxcXFx1MjAwNlxcXFx1MjAwN1xcXFx1MjAwOFxcXFx1MjAwOVxcXFx1MjAwYVxcXFx1MjAyZlxcXFx1MjA1ZlxcXFx1MzAwMFxcXFxkK1xcXFx1MjcwMC1cXFxcdTI3YmZhLXpcXFxceGRmLVxcXFx4ZjZcXFxceGY4LVxcXFx4ZmZBLVpcXFxceGMwLVxcXFx4ZDZcXFxceGQ4LVxcXFx4ZGVdKSsoPzpbJ1xcdTIwMTldKD86RHxMTHxNfFJFfFN8VHxWRSkpPyg/PVtcXFxceGFjXFxcXHhiMVxcXFx4ZDdcXFxceGY3XFxcXHgwMC1cXFxceDJmXFxcXHgzYS1cXFxceDQwXFxcXHg1Yi1cXFxceDYwXFxcXHg3Yi1cXFxceGJmXFxcXHUyMDAwLVxcXFx1MjA2ZiBcXFxcdFxcXFx4MGJcXFxcZlxcXFx4YTBcXFxcdWZlZmZcXFxcblxcXFxyXFxcXHUyMDI4XFxcXHUyMDI5XFxcXHUxNjgwXFxcXHUxODBlXFxcXHUyMDAwXFxcXHUyMDAxXFxcXHUyMDAyXFxcXHUyMDAzXFxcXHUyMDA0XFxcXHUyMDA1XFxcXHUyMDA2XFxcXHUyMDA3XFxcXHUyMDA4XFxcXHUyMDA5XFxcXHUyMDBhXFxcXHUyMDJmXFxcXHUyMDVmXFxcXHUzMDAwXXxbQS1aXFxcXHhjMC1cXFxceGQ2XFxcXHhkOC1cXFxceGRlXSg/OlthLXpcXFxceGRmLVxcXFx4ZjZcXFxceGY4LVxcXFx4ZmZdfFteXFxcXHVkODAwLVxcXFx1ZGZmZlxcXFx4YWNcXFxceGIxXFxcXHhkN1xcXFx4ZjdcXFxceDAwLVxcXFx4MmZcXFxceDNhLVxcXFx4NDBcXFxceDViLVxcXFx4NjBcXFxceDdiLVxcXFx4YmZcXFxcdTIwMDAtXFxcXHUyMDZmIFxcXFx0XFxcXHgwYlxcXFxmXFxcXHhhMFxcXFx1ZmVmZlxcXFxuXFxcXHJcXFxcdTIwMjhcXFxcdTIwMjlcXFxcdTE2ODBcXFxcdTE4MGVcXFxcdTIwMDBcXFxcdTIwMDFcXFxcdTIwMDJcXFxcdTIwMDNcXFxcdTIwMDRcXFxcdTIwMDVcXFxcdTIwMDZcXFxcdTIwMDdcXFxcdTIwMDhcXFxcdTIwMDlcXFxcdTIwMGFcXFxcdTIwMmZcXFxcdTIwNWZcXFxcdTMwMDBcXFxcZCtcXFxcdTI3MDAtXFxcXHUyN2JmYS16XFxcXHhkZi1cXFxceGY2XFxcXHhmOC1cXFxceGZmQS1aXFxcXHhjMC1cXFxceGQ2XFxcXHhkOC1cXFxceGRlXSl8JCl8W0EtWlxcXFx4YzAtXFxcXHhkNlxcXFx4ZDgtXFxcXHhkZV0/KD86W2EtelxcXFx4ZGYtXFxcXHhmNlxcXFx4ZjgtXFxcXHhmZl18W15cXFxcdWQ4MDAtXFxcXHVkZmZmXFxcXHhhY1xcXFx4YjFcXFxceGQ3XFxcXHhmN1xcXFx4MDAtXFxcXHgyZlxcXFx4M2EtXFxcXHg0MFxcXFx4NWItXFxcXHg2MFxcXFx4N2ItXFxcXHhiZlxcXFx1MjAwMC1cXFxcdTIwNmYgXFxcXHRcXFxceDBiXFxcXGZcXFxceGEwXFxcXHVmZWZmXFxcXG5cXFxcclxcXFx1MjAyOFxcXFx1MjAyOVxcXFx1MTY4MFxcXFx1MTgwZVxcXFx1MjAwMFxcXFx1MjAwMVxcXFx1MjAwMlxcXFx1MjAwM1xcXFx1MjAwNFxcXFx1MjAwNVxcXFx1MjAwNlxcXFx1MjAwN1xcXFx1MjAwOFxcXFx1MjAwOVxcXFx1MjAwYVxcXFx1MjAyZlxcXFx1MjA1ZlxcXFx1MzAwMFxcXFxkK1xcXFx1MjcwMC1cXFxcdTI3YmZhLXpcXFxceGRmLVxcXFx4ZjZcXFxceGY4LVxcXFx4ZmZBLVpcXFxceGMwLVxcXFx4ZDZcXFxceGQ4LVxcXFx4ZGVdKSsoPzpbJ1xcdTIwMTldKD86ZHxsbHxtfHJlfHN8dHx2ZSkpP3xbQS1aXFxcXHhjMC1cXFxceGQ2XFxcXHhkOC1cXFxceGRlXSsoPzpbJ1xcdTIwMTldKD86RHxMTHxNfFJFfFN8VHxWRSkpP3xcXFxcZCooPzooPzoxU1R8Mk5EfDNSRHwoPyFbMTIzXSlcXFxcZFRIKVxcXFxiKXxcXFxcZCooPzooPzoxc3R8Mm5kfDNyZHwoPyFbMTIzXSlcXFxcZHRoKVxcXFxiKXxcXFxcZCtcIixPbl0uam9pbihcInxcIiksXCJnXCIpLEJuPVJlZ0V4cChcIltcXFxcdTIwMGRcXFxcdWQ4MDAtXFxcXHVkZmZmXFxcXHUwMzAwLVxcXFx1MDM2ZlxcXFx1ZmUyMC1cXFxcdWZlMmZcXFxcdTIwZDAtXFxcXHUyMGZmXFxcXHVmZTBlXFxcXHVmZTBmXVwiKSxMbj0vW2Etel1bQS1aXXxbQS1aXXsyLH1bYS16XXxbMC05XVthLXpBLVpdfFthLXpBLVpdWzAtOV18W15hLXpBLVowLTkgXS8sVW49XCJBcnJheSBCdWZmZXIgRGF0YVZpZXcgRGF0ZSBFcnJvciBGbG9hdDMyQXJyYXkgRmxvYXQ2NEFycmF5IEZ1bmN0aW9uIEludDhBcnJheSBJbnQxNkFycmF5IEludDMyQXJyYXkgTWFwIE1hdGggT2JqZWN0IFByb21pc2UgUmVnRXhwIFNldCBTdHJpbmcgU3ltYm9sIFR5cGVFcnJvciBVaW50OEFycmF5IFVpbnQ4Q2xhbXBlZEFycmF5IFVpbnQxNkFycmF5IFVpbnQzMkFycmF5IFdlYWtNYXAgXyBjbGVhclRpbWVvdXQgaXNGaW5pdGUgcGFyc2VJbnQgc2V0VGltZW91dFwiLnNwbGl0KFwiIFwiKSxDbj17fTtcbkNuW1wiW29iamVjdCBGbG9hdDMyQXJyYXldXCJdPUNuW1wiW29iamVjdCBGbG9hdDY0QXJyYXldXCJdPUNuW1wiW29iamVjdCBJbnQ4QXJyYXldXCJdPUNuW1wiW29iamVjdCBJbnQxNkFycmF5XVwiXT1DbltcIltvYmplY3QgSW50MzJBcnJheV1cIl09Q25bXCJbb2JqZWN0IFVpbnQ4QXJyYXldXCJdPUNuW1wiW29iamVjdCBVaW50OENsYW1wZWRBcnJheV1cIl09Q25bXCJbb2JqZWN0IFVpbnQxNkFycmF5XVwiXT1DbltcIltvYmplY3QgVWludDMyQXJyYXldXCJdPXRydWUsQ25bXCJbb2JqZWN0IEFyZ3VtZW50c11cIl09Q25bXCJbb2JqZWN0IEFycmF5XVwiXT1DbltcIltvYmplY3QgQXJyYXlCdWZmZXJdXCJdPUNuW1wiW29iamVjdCBCb29sZWFuXVwiXT1DbltcIltvYmplY3QgRGF0YVZpZXddXCJdPUNuW1wiW29iamVjdCBEYXRlXVwiXT1DbltcIltvYmplY3QgRXJyb3JdXCJdPUNuW1wiW29iamVjdCBGdW5jdGlvbl1cIl09Q25bXCJbb2JqZWN0IE1hcF1cIl09Q25bXCJbb2JqZWN0IE51bWJlcl1cIl09Q25bXCJbb2JqZWN0IE9iamVjdF1cIl09Q25bXCJbb2JqZWN0IFJlZ0V4cF1cIl09Q25bXCJbb2JqZWN0IFNldF1cIl09Q25bXCJbb2JqZWN0IFN0cmluZ11cIl09Q25bXCJbb2JqZWN0IFdlYWtNYXBdXCJdPWZhbHNlO1xudmFyIERuPXt9O0RuW1wiW29iamVjdCBBcmd1bWVudHNdXCJdPURuW1wiW29iamVjdCBBcnJheV1cIl09RG5bXCJbb2JqZWN0IEFycmF5QnVmZmVyXVwiXT1EbltcIltvYmplY3QgRGF0YVZpZXddXCJdPURuW1wiW29iamVjdCBCb29sZWFuXVwiXT1EbltcIltvYmplY3QgRGF0ZV1cIl09RG5bXCJbb2JqZWN0IEZsb2F0MzJBcnJheV1cIl09RG5bXCJbb2JqZWN0IEZsb2F0NjRBcnJheV1cIl09RG5bXCJbb2JqZWN0IEludDhBcnJheV1cIl09RG5bXCJbb2JqZWN0IEludDE2QXJyYXldXCJdPURuW1wiW29iamVjdCBJbnQzMkFycmF5XVwiXT1EbltcIltvYmplY3QgTWFwXVwiXT1EbltcIltvYmplY3QgTnVtYmVyXVwiXT1EbltcIltvYmplY3QgT2JqZWN0XVwiXT1EbltcIltvYmplY3QgUmVnRXhwXVwiXT1EbltcIltvYmplY3QgU2V0XVwiXT1EbltcIltvYmplY3QgU3RyaW5nXVwiXT1EbltcIltvYmplY3QgU3ltYm9sXVwiXT1EbltcIltvYmplY3QgVWludDhBcnJheV1cIl09RG5bXCJbb2JqZWN0IFVpbnQ4Q2xhbXBlZEFycmF5XVwiXT1EbltcIltvYmplY3QgVWludDE2QXJyYXldXCJdPURuW1wiW29iamVjdCBVaW50MzJBcnJheV1cIl09dHJ1ZSxcbkRuW1wiW29iamVjdCBFcnJvcl1cIl09RG5bXCJbb2JqZWN0IEZ1bmN0aW9uXVwiXT1EbltcIltvYmplY3QgV2Vha01hcF1cIl09ZmFsc2U7dmFyIE1uLFRuPXtcIlxcXFxcIjpcIlxcXFxcIixcIidcIjpcIidcIixcIlxcblwiOlwiblwiLFwiXFxyXCI6XCJyXCIsXCJcXHUyMDI4XCI6XCJ1MjAyOFwiLFwiXFx1MjAyOVwiOlwidTIwMjlcIn0sJG49cGFyc2VGbG9hdCxGbj1wYXJzZUludCxObj10eXBlb2YgZ2xvYmFsPT1cIm9iamVjdFwiJiZnbG9iYWwmJmdsb2JhbC5PYmplY3Q9PT1PYmplY3QmJmdsb2JhbCxQbj10eXBlb2Ygc2VsZj09XCJvYmplY3RcIiYmc2VsZiYmc2VsZi5PYmplY3Q9PT1PYmplY3QmJnNlbGYsWm49Tm58fFBufHxGdW5jdGlvbihcInJldHVybiB0aGlzXCIpKCkscW49dHlwZW9mIGV4cG9ydHM9PVwib2JqZWN0XCImJmV4cG9ydHMmJiFleHBvcnRzLm5vZGVUeXBlJiZleHBvcnRzLFZuPXFuJiZ0eXBlb2YgbW9kdWxlPT1cIm9iamVjdFwiJiZtb2R1bGUmJiFtb2R1bGUubm9kZVR5cGUmJm1vZHVsZSxLbj1WbiYmVm4uZXhwb3J0cz09PXFuLEduPUtuJiZObi5wcm9jZXNzO1xubjp7dHJ5e01uPUduJiZHbi5iaW5kaW5nJiZHbi5iaW5kaW5nKFwidXRpbFwiKTticmVhayBufWNhdGNoKG4pe31Nbj12b2lkIDB9dmFyIEhuPU1uJiZNbi5pc0FycmF5QnVmZmVyLEpuPU1uJiZNbi5pc0RhdGUsWW49TW4mJk1uLmlzTWFwLFFuPU1uJiZNbi5pc1JlZ0V4cCxYbj1NbiYmTW4uaXNTZXQsbnQ9TW4mJk1uLmlzVHlwZWRBcnJheSx0dD1qKFwibGVuZ3RoXCIpLHJ0PXcoe1wiXFx4YzBcIjpcIkFcIixcIlxceGMxXCI6XCJBXCIsXCJcXHhjMlwiOlwiQVwiLFwiXFx4YzNcIjpcIkFcIixcIlxceGM0XCI6XCJBXCIsXCJcXHhjNVwiOlwiQVwiLFwiXFx4ZTBcIjpcImFcIixcIlxceGUxXCI6XCJhXCIsXCJcXHhlMlwiOlwiYVwiLFwiXFx4ZTNcIjpcImFcIixcIlxceGU0XCI6XCJhXCIsXCJcXHhlNVwiOlwiYVwiLFwiXFx4YzdcIjpcIkNcIixcIlxceGU3XCI6XCJjXCIsXCJcXHhkMFwiOlwiRFwiLFwiXFx4ZjBcIjpcImRcIixcIlxceGM4XCI6XCJFXCIsXCJcXHhjOVwiOlwiRVwiLFwiXFx4Y2FcIjpcIkVcIixcIlxceGNiXCI6XCJFXCIsXCJcXHhlOFwiOlwiZVwiLFwiXFx4ZTlcIjpcImVcIixcIlxceGVhXCI6XCJlXCIsXCJcXHhlYlwiOlwiZVwiLFwiXFx4Y2NcIjpcIklcIixcIlxceGNkXCI6XCJJXCIsXCJcXHhjZVwiOlwiSVwiLFxuXCJcXHhjZlwiOlwiSVwiLFwiXFx4ZWNcIjpcImlcIixcIlxceGVkXCI6XCJpXCIsXCJcXHhlZVwiOlwiaVwiLFwiXFx4ZWZcIjpcImlcIixcIlxceGQxXCI6XCJOXCIsXCJcXHhmMVwiOlwiblwiLFwiXFx4ZDJcIjpcIk9cIixcIlxceGQzXCI6XCJPXCIsXCJcXHhkNFwiOlwiT1wiLFwiXFx4ZDVcIjpcIk9cIixcIlxceGQ2XCI6XCJPXCIsXCJcXHhkOFwiOlwiT1wiLFwiXFx4ZjJcIjpcIm9cIixcIlxceGYzXCI6XCJvXCIsXCJcXHhmNFwiOlwib1wiLFwiXFx4ZjVcIjpcIm9cIixcIlxceGY2XCI6XCJvXCIsXCJcXHhmOFwiOlwib1wiLFwiXFx4ZDlcIjpcIlVcIixcIlxceGRhXCI6XCJVXCIsXCJcXHhkYlwiOlwiVVwiLFwiXFx4ZGNcIjpcIlVcIixcIlxceGY5XCI6XCJ1XCIsXCJcXHhmYVwiOlwidVwiLFwiXFx4ZmJcIjpcInVcIixcIlxceGZjXCI6XCJ1XCIsXCJcXHhkZFwiOlwiWVwiLFwiXFx4ZmRcIjpcInlcIixcIlxceGZmXCI6XCJ5XCIsXCJcXHhjNlwiOlwiQWVcIixcIlxceGU2XCI6XCJhZVwiLFwiXFx4ZGVcIjpcIlRoXCIsXCJcXHhmZVwiOlwidGhcIixcIlxceGRmXCI6XCJzc1wiLFwiXFx1MDEwMFwiOlwiQVwiLFwiXFx1MDEwMlwiOlwiQVwiLFwiXFx1MDEwNFwiOlwiQVwiLFwiXFx1MDEwMVwiOlwiYVwiLFwiXFx1MDEwM1wiOlwiYVwiLFwiXFx1MDEwNVwiOlwiYVwiLFwiXFx1MDEwNlwiOlwiQ1wiLFwiXFx1MDEwOFwiOlwiQ1wiLFwiXFx1MDEwYVwiOlwiQ1wiLFxuXCJcXHUwMTBjXCI6XCJDXCIsXCJcXHUwMTA3XCI6XCJjXCIsXCJcXHUwMTA5XCI6XCJjXCIsXCJcXHUwMTBiXCI6XCJjXCIsXCJcXHUwMTBkXCI6XCJjXCIsXCJcXHUwMTBlXCI6XCJEXCIsXCJcXHUwMTEwXCI6XCJEXCIsXCJcXHUwMTBmXCI6XCJkXCIsXCJcXHUwMTExXCI6XCJkXCIsXCJcXHUwMTEyXCI6XCJFXCIsXCJcXHUwMTE0XCI6XCJFXCIsXCJcXHUwMTE2XCI6XCJFXCIsXCJcXHUwMTE4XCI6XCJFXCIsXCJcXHUwMTFhXCI6XCJFXCIsXCJcXHUwMTEzXCI6XCJlXCIsXCJcXHUwMTE1XCI6XCJlXCIsXCJcXHUwMTE3XCI6XCJlXCIsXCJcXHUwMTE5XCI6XCJlXCIsXCJcXHUwMTFiXCI6XCJlXCIsXCJcXHUwMTFjXCI6XCJHXCIsXCJcXHUwMTFlXCI6XCJHXCIsXCJcXHUwMTIwXCI6XCJHXCIsXCJcXHUwMTIyXCI6XCJHXCIsXCJcXHUwMTFkXCI6XCJnXCIsXCJcXHUwMTFmXCI6XCJnXCIsXCJcXHUwMTIxXCI6XCJnXCIsXCJcXHUwMTIzXCI6XCJnXCIsXCJcXHUwMTI0XCI6XCJIXCIsXCJcXHUwMTI2XCI6XCJIXCIsXCJcXHUwMTI1XCI6XCJoXCIsXCJcXHUwMTI3XCI6XCJoXCIsXCJcXHUwMTI4XCI6XCJJXCIsXCJcXHUwMTJhXCI6XCJJXCIsXCJcXHUwMTJjXCI6XCJJXCIsXCJcXHUwMTJlXCI6XCJJXCIsXCJcXHUwMTMwXCI6XCJJXCIsXCJcXHUwMTI5XCI6XCJpXCIsXCJcXHUwMTJiXCI6XCJpXCIsXCJcXHUwMTJkXCI6XCJpXCIsXG5cIlxcdTAxMmZcIjpcImlcIixcIlxcdTAxMzFcIjpcImlcIixcIlxcdTAxMzRcIjpcIkpcIixcIlxcdTAxMzVcIjpcImpcIixcIlxcdTAxMzZcIjpcIktcIixcIlxcdTAxMzdcIjpcImtcIixcIlxcdTAxMzhcIjpcImtcIixcIlxcdTAxMzlcIjpcIkxcIixcIlxcdTAxM2JcIjpcIkxcIixcIlxcdTAxM2RcIjpcIkxcIixcIlxcdTAxM2ZcIjpcIkxcIixcIlxcdTAxNDFcIjpcIkxcIixcIlxcdTAxM2FcIjpcImxcIixcIlxcdTAxM2NcIjpcImxcIixcIlxcdTAxM2VcIjpcImxcIixcIlxcdTAxNDBcIjpcImxcIixcIlxcdTAxNDJcIjpcImxcIixcIlxcdTAxNDNcIjpcIk5cIixcIlxcdTAxNDVcIjpcIk5cIixcIlxcdTAxNDdcIjpcIk5cIixcIlxcdTAxNGFcIjpcIk5cIixcIlxcdTAxNDRcIjpcIm5cIixcIlxcdTAxNDZcIjpcIm5cIixcIlxcdTAxNDhcIjpcIm5cIixcIlxcdTAxNGJcIjpcIm5cIixcIlxcdTAxNGNcIjpcIk9cIixcIlxcdTAxNGVcIjpcIk9cIixcIlxcdTAxNTBcIjpcIk9cIixcIlxcdTAxNGRcIjpcIm9cIixcIlxcdTAxNGZcIjpcIm9cIixcIlxcdTAxNTFcIjpcIm9cIixcIlxcdTAxNTRcIjpcIlJcIixcIlxcdTAxNTZcIjpcIlJcIixcIlxcdTAxNThcIjpcIlJcIixcIlxcdTAxNTVcIjpcInJcIixcIlxcdTAxNTdcIjpcInJcIixcIlxcdTAxNTlcIjpcInJcIixcIlxcdTAxNWFcIjpcIlNcIixcIlxcdTAxNWNcIjpcIlNcIixcblwiXFx1MDE1ZVwiOlwiU1wiLFwiXFx1MDE2MFwiOlwiU1wiLFwiXFx1MDE1YlwiOlwic1wiLFwiXFx1MDE1ZFwiOlwic1wiLFwiXFx1MDE1ZlwiOlwic1wiLFwiXFx1MDE2MVwiOlwic1wiLFwiXFx1MDE2MlwiOlwiVFwiLFwiXFx1MDE2NFwiOlwiVFwiLFwiXFx1MDE2NlwiOlwiVFwiLFwiXFx1MDE2M1wiOlwidFwiLFwiXFx1MDE2NVwiOlwidFwiLFwiXFx1MDE2N1wiOlwidFwiLFwiXFx1MDE2OFwiOlwiVVwiLFwiXFx1MDE2YVwiOlwiVVwiLFwiXFx1MDE2Y1wiOlwiVVwiLFwiXFx1MDE2ZVwiOlwiVVwiLFwiXFx1MDE3MFwiOlwiVVwiLFwiXFx1MDE3MlwiOlwiVVwiLFwiXFx1MDE2OVwiOlwidVwiLFwiXFx1MDE2YlwiOlwidVwiLFwiXFx1MDE2ZFwiOlwidVwiLFwiXFx1MDE2ZlwiOlwidVwiLFwiXFx1MDE3MVwiOlwidVwiLFwiXFx1MDE3M1wiOlwidVwiLFwiXFx1MDE3NFwiOlwiV1wiLFwiXFx1MDE3NVwiOlwid1wiLFwiXFx1MDE3NlwiOlwiWVwiLFwiXFx1MDE3N1wiOlwieVwiLFwiXFx1MDE3OFwiOlwiWVwiLFwiXFx1MDE3OVwiOlwiWlwiLFwiXFx1MDE3YlwiOlwiWlwiLFwiXFx1MDE3ZFwiOlwiWlwiLFwiXFx1MDE3YVwiOlwielwiLFwiXFx1MDE3Y1wiOlwielwiLFwiXFx1MDE3ZVwiOlwielwiLFwiXFx1MDEzMlwiOlwiSUpcIixcIlxcdTAxMzNcIjpcImlqXCIsXCJcXHUwMTUyXCI6XCJPZVwiLFwiXFx1MDE1M1wiOlwib2VcIixcblwiXFx1MDE0OVwiOlwiJ25cIixcIlxcdTAxN2ZcIjpcInNcIn0pLGV0PXcoe1wiJlwiOlwiJmFtcDtcIixcIjxcIjpcIiZsdDtcIixcIj5cIjpcIiZndDtcIiwnXCInOlwiJnF1b3Q7XCIsXCInXCI6XCImIzM5O1wifSksdXQ9dyh7XCImYW1wO1wiOlwiJlwiLFwiJmx0O1wiOlwiPFwiLFwiJmd0O1wiOlwiPlwiLFwiJnF1b3Q7XCI6J1wiJyxcIiYjMzk7XCI6XCInXCJ9KSxpdD1mdW5jdGlvbiB3KEVuKXtmdW5jdGlvbiBPbihuKXtpZih4dShuKSYmIWFmKG4pJiYhKG4gaW5zdGFuY2VvZiBNbikpe2lmKG4gaW5zdGFuY2VvZiB6bilyZXR1cm4gbjtpZihjaS5jYWxsKG4sXCJfX3dyYXBwZWRfX1wiKSlyZXR1cm4gUGUobil9cmV0dXJuIG5ldyB6bihuKX1mdW5jdGlvbiBTbigpe31mdW5jdGlvbiB6bihuLHQpe3RoaXMuX193cmFwcGVkX189bix0aGlzLl9fYWN0aW9uc19fPVtdLHRoaXMuX19jaGFpbl9fPSEhdCx0aGlzLl9faW5kZXhfXz0wLHRoaXMuX192YWx1ZXNfXz1GfWZ1bmN0aW9uIE1uKG4pe3RoaXMuX193cmFwcGVkX189bix0aGlzLl9fYWN0aW9uc19fPVtdLHRoaXMuX19kaXJfXz0xLFxudGhpcy5fX2ZpbHRlcmVkX189ZmFsc2UsdGhpcy5fX2l0ZXJhdGVlc19fPVtdLHRoaXMuX190YWtlQ291bnRfXz00Mjk0OTY3Mjk1LHRoaXMuX192aWV3c19fPVtdfWZ1bmN0aW9uIFRuKG4pe3ZhciB0PS0xLHI9bnVsbD09bj8wOm4ubGVuZ3RoO2Zvcih0aGlzLmNsZWFyKCk7Kyt0PHI7KXt2YXIgZT1uW3RdO3RoaXMuc2V0KGVbMF0sZVsxXSl9fWZ1bmN0aW9uIE5uKG4pe3ZhciB0PS0xLHI9bnVsbD09bj8wOm4ubGVuZ3RoO2Zvcih0aGlzLmNsZWFyKCk7Kyt0PHI7KXt2YXIgZT1uW3RdO3RoaXMuc2V0KGVbMF0sZVsxXSl9fWZ1bmN0aW9uIFBuKG4pe3ZhciB0PS0xLHI9bnVsbD09bj8wOm4ubGVuZ3RoO2Zvcih0aGlzLmNsZWFyKCk7Kyt0PHI7KXt2YXIgZT1uW3RdO3RoaXMuc2V0KGVbMF0sZVsxXSl9fWZ1bmN0aW9uIHFuKG4pe3ZhciB0PS0xLHI9bnVsbD09bj8wOm4ubGVuZ3RoO2Zvcih0aGlzLl9fZGF0YV9fPW5ldyBQbjsrK3Q8cjspdGhpcy5hZGQoblt0XSl9ZnVuY3Rpb24gVm4obil7XG50aGlzLnNpemU9KHRoaXMuX19kYXRhX189bmV3IE5uKG4pKS5zaXplfWZ1bmN0aW9uIEduKG4sdCl7dmFyIHIsZT1hZihuKSx1PSFlJiZjZihuKSxpPSFlJiYhdSYmc2Yobiksbz0hZSYmIXUmJiFpJiZnZihuKSx1PShlPWV8fHV8fGl8fG8pP0Uobi5sZW5ndGgscmkpOltdLGY9dS5sZW5ndGg7Zm9yKHIgaW4gbikhdCYmIWNpLmNhbGwobixyKXx8ZSYmKFwibGVuZ3RoXCI9PXJ8fGkmJihcIm9mZnNldFwiPT1yfHxcInBhcmVudFwiPT1yKXx8byYmKFwiYnVmZmVyXCI9PXJ8fFwiYnl0ZUxlbmd0aFwiPT1yfHxcImJ5dGVPZmZzZXRcIj09cil8fFJlKHIsZikpfHx1LnB1c2gocik7cmV0dXJuIHV9ZnVuY3Rpb24gdHQobil7dmFyIHQ9bi5sZW5ndGg7cmV0dXJuIHQ/bltjcigwLHQtMSldOkZ9ZnVuY3Rpb24gb3Qobix0KXtyZXR1cm4gVGUoTXIobiksZ3QodCwwLG4ubGVuZ3RoKSl9ZnVuY3Rpb24gZnQobil7cmV0dXJuIFRlKE1yKG4pKX1mdW5jdGlvbiBjdChuLHQscil7KHI9PT1GfHxodShuW3RdLHIpKSYmKHIhPT1GfHx0IGluIG4pfHxfdChuLHQscik7XG59ZnVuY3Rpb24gYXQobix0LHIpe3ZhciBlPW5bdF07Y2kuY2FsbChuLHQpJiZodShlLHIpJiYociE9PUZ8fHQgaW4gbil8fF90KG4sdCxyKX1mdW5jdGlvbiBsdChuLHQpe2Zvcih2YXIgcj1uLmxlbmd0aDtyLS07KWlmKGh1KG5bcl1bMF0sdCkpcmV0dXJuIHI7cmV0dXJuLTF9ZnVuY3Rpb24gc3Qobix0LHIsZSl7cmV0dXJuIG9vKG4sZnVuY3Rpb24obix1LGkpe3QoZSxuLHIobiksaSl9KSxlfWZ1bmN0aW9uIGh0KG4sdCl7cmV0dXJuIG4mJlRyKHQsTHUodCksbil9ZnVuY3Rpb24gcHQobix0KXtyZXR1cm4gbiYmVHIodCxVdSh0KSxuKX1mdW5jdGlvbiBfdChuLHQscil7XCJfX3Byb3RvX19cIj09dCYmRWk/RWkobix0LHtjb25maWd1cmFibGU6dHJ1ZSxlbnVtZXJhYmxlOnRydWUsdmFsdWU6cix3cml0YWJsZTp0cnVlfSk6blt0XT1yfWZ1bmN0aW9uIHZ0KG4sdCl7Zm9yKHZhciByPS0xLGU9dC5sZW5ndGgsdT1IdShlKSxpPW51bGw9PW47KytyPGU7KXVbcl09aT9GOld1KG4sdFtyXSk7cmV0dXJuIHU7XG59ZnVuY3Rpb24gZ3Qobix0LHIpe3JldHVybiBuPT09biYmKHIhPT1GJiYobj1uPD1yP246ciksdCE9PUYmJihuPW4+PXQ/bjp0KSksbn1mdW5jdGlvbiBkdChuLHQscixlLGksbyl7dmFyIGYsYz0xJnQsYT0yJnQsbD00JnQ7aWYociYmKGY9aT9yKG4sZSxpLG8pOnIobikpLGYhPT1GKXJldHVybiBmO2lmKCFidShuKSlyZXR1cm4gbjtpZihlPWFmKG4pKXtpZihmPUVlKG4pLCFjKXJldHVybiBNcihuLGYpfWVsc2V7dmFyIHM9eW8obiksaD1cIltvYmplY3QgRnVuY3Rpb25dXCI9PXN8fFwiW29iamVjdCBHZW5lcmF0b3JGdW5jdGlvbl1cIj09cztpZihzZihuKSlyZXR1cm4gV3IobixjKTtpZihcIltvYmplY3QgT2JqZWN0XVwiPT1zfHxcIltvYmplY3QgQXJndW1lbnRzXVwiPT1zfHxoJiYhaSl7aWYoZj1hfHxoP3t9Ok9lKG4pLCFjKXJldHVybiBhP0ZyKG4scHQoZixuKSk6JHIobixodChmLG4pKX1lbHNle2lmKCFEbltzXSlyZXR1cm4gaT9uOnt9O2Y9U2UobixzLGR0LGMpfX1pZihvfHwobz1uZXcgVm4pLFxuaT1vLmdldChuKSlyZXR1cm4gaTtvLnNldChuLGYpO3ZhciBhPWw/YT95ZTpkZTphP1V1Okx1LHA9ZT9GOmEobik7cmV0dXJuIHUocHx8bixmdW5jdGlvbihlLHUpe3AmJih1PWUsZT1uW3VdKSxhdChmLHUsZHQoZSx0LHIsdSxuLG8pKX0pLGZ9ZnVuY3Rpb24geXQobil7dmFyIHQ9THUobik7cmV0dXJuIGZ1bmN0aW9uKHIpe3JldHVybiBidChyLG4sdCl9fWZ1bmN0aW9uIGJ0KG4sdCxyKXt2YXIgZT1yLmxlbmd0aDtpZihudWxsPT1uKXJldHVybiFlO2ZvcihuPW5pKG4pO2UtLTspe3ZhciB1PXJbZV0saT10W3VdLG89blt1XTtpZihvPT09RiYmISh1IGluIG4pfHwhaShvKSlyZXR1cm4gZmFsc2V9cmV0dXJuIHRydWV9ZnVuY3Rpb24geHQobix0LHIpe2lmKHR5cGVvZiBuIT1cImZ1bmN0aW9uXCIpdGhyb3cgbmV3IGVpKFwiRXhwZWN0ZWQgYSBmdW5jdGlvblwiKTtyZXR1cm4gam8oZnVuY3Rpb24oKXtuLmFwcGx5KEYscil9LHQpfWZ1bmN0aW9uIGp0KG4sdCxyLGUpe3ZhciB1PS0xLGk9YyxvPXRydWUsZj1uLmxlbmd0aCxzPVtdLGg9dC5sZW5ndGg7XG5pZighZilyZXR1cm4gcztyJiYodD1sKHQsUyhyKSkpLGU/KGk9YSxvPWZhbHNlKToyMDA8PXQubGVuZ3RoJiYoaT1SLG89ZmFsc2UsdD1uZXcgcW4odCkpO246Zm9yKDsrK3U8Zjspe3ZhciBwPW5bdV0sXz1udWxsPT1yP3A6cihwKSxwPWV8fDAhPT1wP3A6MDtpZihvJiZfPT09Xyl7Zm9yKHZhciB2PWg7di0tOylpZih0W3ZdPT09Xyljb250aW51ZSBuO3MucHVzaChwKX1lbHNlIGkodCxfLGUpfHxzLnB1c2gocCl9cmV0dXJuIHN9ZnVuY3Rpb24gd3Qobix0KXt2YXIgcj10cnVlO3JldHVybiBvbyhuLGZ1bmN0aW9uKG4sZSx1KXtyZXR1cm4gcj0hIXQobixlLHUpfSkscn1mdW5jdGlvbiBtdChuLHQscil7Zm9yKHZhciBlPS0xLHU9bi5sZW5ndGg7KytlPHU7KXt2YXIgaT1uW2VdLG89dChpKTtpZihudWxsIT1vJiYoZj09PUY/bz09PW8mJiFBdShvKTpyKG8sZikpKXZhciBmPW8sYz1pfXJldHVybiBjfWZ1bmN0aW9uIEF0KG4sdCl7dmFyIHI9W107cmV0dXJuIG9vKG4sZnVuY3Rpb24obixlLHUpe1xudChuLGUsdSkmJnIucHVzaChuKX0pLHJ9ZnVuY3Rpb24ga3Qobix0LHIsZSx1KXt2YXIgaT0tMSxvPW4ubGVuZ3RoO2ZvcihyfHwocj1JZSksdXx8KHU9W10pOysraTxvOyl7dmFyIGY9bltpXTswPHQmJnIoZik/MTx0P2t0KGYsdC0xLHIsZSx1KTpzKHUsZik6ZXx8KHVbdS5sZW5ndGhdPWYpfXJldHVybiB1fWZ1bmN0aW9uIEV0KG4sdCl7cmV0dXJuIG4mJmNvKG4sdCxMdSl9ZnVuY3Rpb24gT3Qobix0KXtyZXR1cm4gbiYmYW8obix0LEx1KX1mdW5jdGlvbiBTdChuLHQpe3JldHVybiBmKHQsZnVuY3Rpb24odCl7cmV0dXJuIGd1KG5bdF0pfSl9ZnVuY3Rpb24gSXQobix0KXt0PVJyKHQsbik7Zm9yKHZhciByPTAsZT10Lmxlbmd0aDtudWxsIT1uJiZyPGU7KW49blskZSh0W3IrK10pXTtyZXR1cm4gciYmcj09ZT9uOkZ9ZnVuY3Rpb24gUnQobix0LHIpe3JldHVybiB0PXQobiksYWYobik/dDpzKHQscihuKSl9ZnVuY3Rpb24genQobil7aWYobnVsbD09biluPW49PT1GP1wiW29iamVjdCBVbmRlZmluZWRdXCI6XCJbb2JqZWN0IE51bGxdXCI7ZWxzZSBpZihraSYma2kgaW4gbmkobikpe1xudmFyIHQ9Y2kuY2FsbChuLGtpKSxyPW5ba2ldO3RyeXtuW2tpXT1GO3ZhciBlPXRydWV9Y2F0Y2gobil7fXZhciB1PXNpLmNhbGwobik7ZSYmKHQ/bltraV09cjpkZWxldGUgbltraV0pLG49dX1lbHNlIG49c2kuY2FsbChuKTtyZXR1cm4gbn1mdW5jdGlvbiBXdChuLHQpe3JldHVybiBuPnR9ZnVuY3Rpb24gQnQobix0KXtyZXR1cm4gbnVsbCE9biYmY2kuY2FsbChuLHQpfWZ1bmN0aW9uIEx0KG4sdCl7cmV0dXJuIG51bGwhPW4mJnQgaW4gbmkobil9ZnVuY3Rpb24gVXQobix0LHIpe2Zvcih2YXIgZT1yP2E6Yyx1PW5bMF0ubGVuZ3RoLGk9bi5sZW5ndGgsbz1pLGY9SHUoaSkscz0xLzAsaD1bXTtvLS07KXt2YXIgcD1uW29dO28mJnQmJihwPWwocCxTKHQpKSkscz1NaShwLmxlbmd0aCxzKSxmW29dPSFyJiYodHx8MTIwPD11JiYxMjA8PXAubGVuZ3RoKT9uZXcgcW4obyYmcCk6Rn12YXIgcD1uWzBdLF89LTEsdj1mWzBdO246Zm9yKDsrK188dSYmaC5sZW5ndGg8czspe3ZhciBnPXBbX10sZD10P3QoZyk6ZyxnPXJ8fDAhPT1nP2c6MDtcbmlmKHY/IVIodixkKTohZShoLGQscikpe2ZvcihvPWk7LS1vOyl7dmFyIHk9ZltvXTtpZih5PyFSKHksZCk6IWUobltvXSxkLHIpKWNvbnRpbnVlIG59diYmdi5wdXNoKGQpLGgucHVzaChnKX19cmV0dXJuIGh9ZnVuY3Rpb24gQ3Qobix0LHIpe3ZhciBlPXt9O3JldHVybiBFdChuLGZ1bmN0aW9uKG4sdSxpKXt0KGUscihuKSx1LGkpfSksZX1mdW5jdGlvbiBEdChuLHQsZSl7cmV0dXJuIHQ9UnIodCxuKSxuPTI+dC5sZW5ndGg/bjpJdChuLHZyKHQsMCwtMSkpLHQ9bnVsbD09bj9uOm5bJGUoR2UodCkpXSxudWxsPT10P0Y6cih0LG4sZSl9ZnVuY3Rpb24gTXQobil7cmV0dXJuIHh1KG4pJiZcIltvYmplY3QgQXJndW1lbnRzXVwiPT16dChuKX1mdW5jdGlvbiBUdChuKXtyZXR1cm4geHUobikmJlwiW29iamVjdCBBcnJheUJ1ZmZlcl1cIj09enQobil9ZnVuY3Rpb24gJHQobil7cmV0dXJuIHh1KG4pJiZcIltvYmplY3QgRGF0ZV1cIj09enQobil9ZnVuY3Rpb24gRnQobix0LHIsZSx1KXtpZihuPT09dCl0PXRydWU7ZWxzZSBpZihudWxsPT1ufHxudWxsPT10fHwheHUobikmJiF4dSh0KSl0PW4hPT1uJiZ0IT09dDtlbHNlIG46e1xudmFyIGk9YWYobiksbz1hZih0KSxmPWk/XCJbb2JqZWN0IEFycmF5XVwiOnlvKG4pLGM9bz9cIltvYmplY3QgQXJyYXldXCI6eW8odCksZj1cIltvYmplY3QgQXJndW1lbnRzXVwiPT1mP1wiW29iamVjdCBPYmplY3RdXCI6ZixjPVwiW29iamVjdCBBcmd1bWVudHNdXCI9PWM/XCJbb2JqZWN0IE9iamVjdF1cIjpjLGE9XCJbb2JqZWN0IE9iamVjdF1cIj09ZixvPVwiW29iamVjdCBPYmplY3RdXCI9PWM7aWYoKGM9Zj09YykmJnNmKG4pKXtpZighc2YodCkpe3Q9ZmFsc2U7YnJlYWsgbn1pPXRydWUsYT1mYWxzZX1pZihjJiYhYSl1fHwodT1uZXcgVm4pLHQ9aXx8Z2Yobik/X2Uobix0LHIsZSxGdCx1KTp2ZShuLHQsZixyLGUsRnQsdSk7ZWxzZXtpZighKDEmcikmJihpPWEmJmNpLmNhbGwobixcIl9fd3JhcHBlZF9fXCIpLGY9byYmY2kuY2FsbCh0LFwiX193cmFwcGVkX19cIiksaXx8Zikpe249aT9uLnZhbHVlKCk6bix0PWY/dC52YWx1ZSgpOnQsdXx8KHU9bmV3IFZuKSx0PUZ0KG4sdCxyLGUsdSk7YnJlYWsgbn1pZihjKXQ6aWYodXx8KHU9bmV3IFZuKSxcbmk9MSZyLGY9ZGUobiksbz1mLmxlbmd0aCxjPWRlKHQpLmxlbmd0aCxvPT1jfHxpKXtmb3IoYT1vO2EtLTspe3ZhciBsPWZbYV07aWYoIShpP2wgaW4gdDpjaS5jYWxsKHQsbCkpKXt0PWZhbHNlO2JyZWFrIHR9fWlmKChjPXUuZ2V0KG4pKSYmdS5nZXQodCkpdD1jPT10O2Vsc2V7Yz10cnVlLHUuc2V0KG4sdCksdS5zZXQodCxuKTtmb3IodmFyIHM9aTsrK2E8bzspe3ZhciBsPWZbYV0saD1uW2xdLHA9dFtsXTtpZihlKXZhciBfPWk/ZShwLGgsbCx0LG4sdSk6ZShoLHAsbCxuLHQsdSk7aWYoXz09PUY/aCE9PXAmJiFGdChoLHAscixlLHUpOiFfKXtjPWZhbHNlO2JyZWFrfXN8fChzPVwiY29uc3RydWN0b3JcIj09bCl9YyYmIXMmJihyPW4uY29uc3RydWN0b3IsZT10LmNvbnN0cnVjdG9yLHIhPWUmJlwiY29uc3RydWN0b3JcImluIG4mJlwiY29uc3RydWN0b3JcImluIHQmJiEodHlwZW9mIHI9PVwiZnVuY3Rpb25cIiYmciBpbnN0YW5jZW9mIHImJnR5cGVvZiBlPT1cImZ1bmN0aW9uXCImJmUgaW5zdGFuY2VvZiBlKSYmKGM9ZmFsc2UpKSxcbnUuZGVsZXRlKG4pLHUuZGVsZXRlKHQpLHQ9Y319ZWxzZSB0PWZhbHNlO2Vsc2UgdD1mYWxzZX19cmV0dXJuIHR9ZnVuY3Rpb24gTnQobil7cmV0dXJuIHh1KG4pJiZcIltvYmplY3QgTWFwXVwiPT15byhuKX1mdW5jdGlvbiBQdChuLHQscixlKXt2YXIgdT1yLmxlbmd0aCxpPXUsbz0hZTtpZihudWxsPT1uKXJldHVybiFpO2ZvcihuPW5pKG4pO3UtLTspe3ZhciBmPXJbdV07aWYobyYmZlsyXT9mWzFdIT09bltmWzBdXTohKGZbMF1pbiBuKSlyZXR1cm4gZmFsc2V9Zm9yKDsrK3U8aTspe3ZhciBmPXJbdV0sYz1mWzBdLGE9bltjXSxsPWZbMV07aWYobyYmZlsyXSl7aWYoYT09PUYmJiEoYyBpbiBuKSlyZXR1cm4gZmFsc2V9ZWxzZXtpZihmPW5ldyBWbixlKXZhciBzPWUoYSxsLGMsbix0LGYpO2lmKHM9PT1GPyFGdChsLGEsMyxlLGYpOiFzKXJldHVybiBmYWxzZX19cmV0dXJuIHRydWV9ZnVuY3Rpb24gWnQobil7cmV0dXJuISghYnUobil8fGxpJiZsaSBpbiBuKSYmKGd1KG4pP19pOnhuKS50ZXN0KEZlKG4pKX1mdW5jdGlvbiBxdChuKXtcbnJldHVybiB4dShuKSYmXCJbb2JqZWN0IFJlZ0V4cF1cIj09enQobil9ZnVuY3Rpb24gVnQobil7cmV0dXJuIHh1KG4pJiZcIltvYmplY3QgU2V0XVwiPT15byhuKX1mdW5jdGlvbiBLdChuKXtyZXR1cm4geHUobikmJnl1KG4ubGVuZ3RoKSYmISFDblt6dChuKV19ZnVuY3Rpb24gR3Qobil7cmV0dXJuIHR5cGVvZiBuPT1cImZ1bmN0aW9uXCI/bjpudWxsPT1uP051OnR5cGVvZiBuPT1cIm9iamVjdFwiP2FmKG4pP1h0KG5bMF0sblsxXSk6UXQobik6VnUobil9ZnVuY3Rpb24gSHQobil7aWYoIUxlKG4pKXJldHVybiBDaShuKTt2YXIgdCxyPVtdO2Zvcih0IGluIG5pKG4pKWNpLmNhbGwobix0KSYmXCJjb25zdHJ1Y3RvclwiIT10JiZyLnB1c2godCk7cmV0dXJuIHJ9ZnVuY3Rpb24gSnQobix0KXtyZXR1cm4gbjx0fWZ1bmN0aW9uIFl0KG4sdCl7dmFyIHI9LTEsZT1wdShuKT9IdShuLmxlbmd0aCk6W107cmV0dXJuIG9vKG4sZnVuY3Rpb24obix1LGkpe2VbKytyXT10KG4sdSxpKX0pLGV9ZnVuY3Rpb24gUXQobil7XG52YXIgdD1tZShuKTtyZXR1cm4gMT09dC5sZW5ndGgmJnRbMF1bMl0/VWUodFswXVswXSx0WzBdWzFdKTpmdW5jdGlvbihyKXtyZXR1cm4gcj09PW58fFB0KHIsbix0KX19ZnVuY3Rpb24gWHQobix0KXtyZXR1cm4gV2UobikmJnQ9PT10JiYhYnUodCk/VWUoJGUobiksdCk6ZnVuY3Rpb24ocil7dmFyIGU9V3UocixuKTtyZXR1cm4gZT09PUYmJmU9PT10P0J1KHIsbik6RnQodCxlLDMpfX1mdW5jdGlvbiBucihuLHQscixlLHUpe24hPT10JiZjbyh0LGZ1bmN0aW9uKGksbyl7aWYoYnUoaSkpe3V8fCh1PW5ldyBWbik7dmFyIGY9dSxjPW5bb10sYT10W29dLGw9Zi5nZXQoYSk7aWYobCljdChuLG8sbCk7ZWxzZXt2YXIgbD1lP2UoYyxhLG8rXCJcIixuLHQsZik6RixzPWw9PT1GO2lmKHMpe3ZhciBoPWFmKGEpLHA9IWgmJnNmKGEpLF89IWgmJiFwJiZnZihhKSxsPWE7aHx8cHx8Xz9hZihjKT9sPWM6X3UoYyk/bD1NcihjKTpwPyhzPWZhbHNlLGw9V3IoYSx0cnVlKSk6Xz8ocz1mYWxzZSxsPUxyKGEsdHJ1ZSkpOmw9W106d3UoYSl8fGNmKGEpPyhsPWMsXG5jZihjKT9sPVJ1KGMpOighYnUoYyl8fHImJmd1KGMpKSYmKGw9T2UoYSkpKTpzPWZhbHNlfXMmJihmLnNldChhLGwpLG5yKGwsYSxyLGUsZiksZi5kZWxldGUoYSkpLGN0KG4sbyxsKX19ZWxzZSBmPWU/ZShuW29dLGksbytcIlwiLG4sdCx1KTpGLGY9PT1GJiYoZj1pKSxjdChuLG8sZil9LFV1KX1mdW5jdGlvbiB0cihuLHQpe3ZhciByPW4ubGVuZ3RoO2lmKHIpcmV0dXJuIHQrPTA+dD9yOjAsUmUodCxyKT9uW3RdOkZ9ZnVuY3Rpb24gcnIobix0LHIpe3ZhciBlPS0xO3JldHVybiB0PWwodC5sZW5ndGg/dDpbTnVdLFMoamUoKSkpLG49WXQobixmdW5jdGlvbihuKXtyZXR1cm57YTpsKHQsZnVuY3Rpb24odCl7cmV0dXJuIHQobil9KSxiOisrZSxjOm59fSksQShuLGZ1bmN0aW9uKG4sdCl7dmFyIGU7bjp7ZT0tMTtmb3IodmFyIHU9bi5hLGk9dC5hLG89dS5sZW5ndGgsZj1yLmxlbmd0aDsrK2U8bzspe3ZhciBjPVVyKHVbZV0saVtlXSk7aWYoYyl7ZT1lPj1mP2M6YyooXCJkZXNjXCI9PXJbZV0/LTE6MSk7XG5icmVhayBufX1lPW4uYi10LmJ9cmV0dXJuIGV9KX1mdW5jdGlvbiBlcihuLHQpe3JldHVybiB1cihuLHQsZnVuY3Rpb24odCxyKXtyZXR1cm4gQnUobixyKX0pfWZ1bmN0aW9uIHVyKG4sdCxyKXtmb3IodmFyIGU9LTEsdT10Lmxlbmd0aCxpPXt9OysrZTx1Oyl7dmFyIG89dFtlXSxmPUl0KG4sbyk7cihmLG8pJiZwcihpLFJyKG8sbiksZil9cmV0dXJuIGl9ZnVuY3Rpb24gaXIobil7cmV0dXJuIGZ1bmN0aW9uKHQpe3JldHVybiBJdCh0LG4pfX1mdW5jdGlvbiBvcihuLHQscixlKXt2YXIgdT1lP3k6ZCxpPS0xLG89dC5sZW5ndGgsZj1uO2ZvcihuPT09dCYmKHQ9TXIodCkpLHImJihmPWwobixTKHIpKSk7KytpPG87KWZvcih2YXIgYz0wLGE9dFtpXSxhPXI/cihhKTphOy0xPChjPXUoZixhLGMsZSkpOylmIT09biYmd2kuY2FsbChmLGMsMSksd2kuY2FsbChuLGMsMSk7cmV0dXJuIG59ZnVuY3Rpb24gZnIobix0KXtmb3IodmFyIHI9bj90Lmxlbmd0aDowLGU9ci0xO3ItLTspe3ZhciB1PXRbcl07XG5pZihyPT1lfHx1IT09aSl7dmFyIGk9dTtSZSh1KT93aS5jYWxsKG4sdSwxKTptcihuLHUpfX19ZnVuY3Rpb24gY3Iobix0KXtyZXR1cm4gbit6aShGaSgpKih0LW4rMSkpfWZ1bmN0aW9uIGFyKG4sdCl7dmFyIHI9XCJcIjtpZighbnx8MT50fHw5MDA3MTk5MjU0NzQwOTkxPHQpcmV0dXJuIHI7ZG8gdCUyJiYocis9biksKHQ9emkodC8yKSkmJihuKz1uKTt3aGlsZSh0KTtyZXR1cm4gcn1mdW5jdGlvbiBscihuLHQpe3JldHVybiB3byhDZShuLHQsTnUpLG4rXCJcIil9ZnVuY3Rpb24gc3Iobil7cmV0dXJuIHR0KER1KG4pKX1mdW5jdGlvbiBocihuLHQpe3ZhciByPUR1KG4pO3JldHVybiBUZShyLGd0KHQsMCxyLmxlbmd0aCkpfWZ1bmN0aW9uIHByKG4sdCxyLGUpe2lmKCFidShuKSlyZXR1cm4gbjt0PVJyKHQsbik7Zm9yKHZhciB1PS0xLGk9dC5sZW5ndGgsbz1pLTEsZj1uO251bGwhPWYmJisrdTxpOyl7dmFyIGM9JGUodFt1XSksYT1yO2lmKHUhPW8pe3ZhciBsPWZbY10sYT1lP2UobCxjLGYpOkY7XG5hPT09RiYmKGE9YnUobCk/bDpSZSh0W3UrMV0pP1tdOnt9KX1hdChmLGMsYSksZj1mW2NdfXJldHVybiBufWZ1bmN0aW9uIF9yKG4pe3JldHVybiBUZShEdShuKSl9ZnVuY3Rpb24gdnIobix0LHIpe3ZhciBlPS0xLHU9bi5sZW5ndGg7Zm9yKDA+dCYmKHQ9LXQ+dT8wOnUrdCkscj1yPnU/dTpyLDA+ciYmKHIrPXUpLHU9dD5yPzA6ci10Pj4+MCx0Pj4+PTAscj1IdSh1KTsrK2U8dTspcltlXT1uW2UrdF07cmV0dXJuIHJ9ZnVuY3Rpb24gZ3Iobix0KXt2YXIgcjtyZXR1cm4gb28obixmdW5jdGlvbihuLGUsdSl7cmV0dXJuIHI9dChuLGUsdSksIXJ9KSwhIXJ9ZnVuY3Rpb24gZHIobix0LHIpe3ZhciBlPTAsdT1udWxsPT1uP2U6bi5sZW5ndGg7aWYodHlwZW9mIHQ9PVwibnVtYmVyXCImJnQ9PT10JiYyMTQ3NDgzNjQ3Pj11KXtmb3IoO2U8dTspe3ZhciBpPWUrdT4+PjEsbz1uW2ldO251bGwhPT1vJiYhQXUobykmJihyP288PXQ6bzx0KT9lPWkrMTp1PWl9cmV0dXJuIHV9cmV0dXJuIHlyKG4sdCxOdSxyKTtcbn1mdW5jdGlvbiB5cihuLHQscixlKXt0PXIodCk7Zm9yKHZhciB1PTAsaT1udWxsPT1uPzA6bi5sZW5ndGgsbz10IT09dCxmPW51bGw9PT10LGM9QXUodCksYT10PT09Rjt1PGk7KXt2YXIgbD16aSgodStpKS8yKSxzPXIobltsXSksaD1zIT09RixwPW51bGw9PT1zLF89cz09PXMsdj1BdShzKTsobz9lfHxfOmE/XyYmKGV8fGgpOmY/XyYmaCYmKGV8fCFwKTpjP18mJmgmJiFwJiYoZXx8IXYpOnB8fHY/MDplP3M8PXQ6czx0KT91PWwrMTppPWx9cmV0dXJuIE1pKGksNDI5NDk2NzI5NCl9ZnVuY3Rpb24gYnIobix0KXtmb3IodmFyIHI9LTEsZT1uLmxlbmd0aCx1PTAsaT1bXTsrK3I8ZTspe3ZhciBvPW5bcl0sZj10P3Qobyk6bztpZighcnx8IWh1KGYsYykpe3ZhciBjPWY7aVt1KytdPTA9PT1vPzA6b319cmV0dXJuIGl9ZnVuY3Rpb24geHIobil7cmV0dXJuIHR5cGVvZiBuPT1cIm51bWJlclwiP246QXUobik/UDorbn1mdW5jdGlvbiBqcihuKXtpZih0eXBlb2Ygbj09XCJzdHJpbmdcIilyZXR1cm4gbjtcbmlmKGFmKG4pKXJldHVybiBsKG4sanIpK1wiXCI7aWYoQXUobikpcmV0dXJuIHVvP3VvLmNhbGwobik6XCJcIjt2YXIgdD1uK1wiXCI7cmV0dXJuXCIwXCI9PXQmJjEvbj09LU4/XCItMFwiOnR9ZnVuY3Rpb24gd3Iobix0LHIpe3ZhciBlPS0xLHU9YyxpPW4ubGVuZ3RoLG89dHJ1ZSxmPVtdLGw9ZjtpZihyKW89ZmFsc2UsdT1hO2Vsc2UgaWYoMjAwPD1pKXtpZih1PXQ/bnVsbDpwbyhuKSlyZXR1cm4gRCh1KTtvPWZhbHNlLHU9UixsPW5ldyBxbn1lbHNlIGw9dD9bXTpmO246Zm9yKDsrK2U8aTspe3ZhciBzPW5bZV0saD10P3Qocyk6cyxzPXJ8fDAhPT1zP3M6MDtpZihvJiZoPT09aCl7Zm9yKHZhciBwPWwubGVuZ3RoO3AtLTspaWYobFtwXT09PWgpY29udGludWUgbjt0JiZsLnB1c2goaCksZi5wdXNoKHMpfWVsc2UgdShsLGgscil8fChsIT09ZiYmbC5wdXNoKGgpLGYucHVzaChzKSl9cmV0dXJuIGZ9ZnVuY3Rpb24gbXIobix0KXtyZXR1cm4gdD1Scih0LG4pLG49Mj50Lmxlbmd0aD9uOkl0KG4sdnIodCwwLC0xKSksXG5udWxsPT1ufHxkZWxldGUgblskZShHZSh0KSldfWZ1bmN0aW9uIEFyKG4sdCxyLGUpe2Zvcih2YXIgdT1uLmxlbmd0aCxpPWU/dTotMTsoZT9pLS06KytpPHUpJiZ0KG5baV0saSxuKTspO3JldHVybiByP3ZyKG4sZT8wOmksZT9pKzE6dSk6dnIobixlP2krMTowLGU/dTppKX1mdW5jdGlvbiBrcihuLHQpe3ZhciByPW47cmV0dXJuIHIgaW5zdGFuY2VvZiBNbiYmKHI9ci52YWx1ZSgpKSxoKHQsZnVuY3Rpb24obix0KXtyZXR1cm4gdC5mdW5jLmFwcGx5KHQudGhpc0FyZyxzKFtuXSx0LmFyZ3MpKX0scil9ZnVuY3Rpb24gRXIobix0LHIpe3ZhciBlPW4ubGVuZ3RoO2lmKDI+ZSlyZXR1cm4gZT93cihuWzBdKTpbXTtmb3IodmFyIHU9LTEsaT1IdShlKTsrK3U8ZTspZm9yKHZhciBvPW5bdV0sZj0tMTsrK2Y8ZTspZiE9dSYmKGlbdV09anQoaVt1XXx8byxuW2ZdLHQscikpO3JldHVybiB3cihrdChpLDEpLHQscil9ZnVuY3Rpb24gT3Iobix0LHIpe2Zvcih2YXIgZT0tMSx1PW4ubGVuZ3RoLGk9dC5sZW5ndGgsbz17fTsrK2U8dTspcihvLG5bZV0sZTxpP3RbZV06Rik7XG5yZXR1cm4gb31mdW5jdGlvbiBTcihuKXtyZXR1cm4gX3Uobik/bjpbXX1mdW5jdGlvbiBJcihuKXtyZXR1cm4gdHlwZW9mIG49PVwiZnVuY3Rpb25cIj9uOk51fWZ1bmN0aW9uIFJyKG4sdCl7cmV0dXJuIGFmKG4pP246V2Uobix0KT9bbl06bW8oenUobikpfWZ1bmN0aW9uIHpyKG4sdCxyKXt2YXIgZT1uLmxlbmd0aDtyZXR1cm4gcj1yPT09Rj9lOnIsIXQmJnI+PWU/bjp2cihuLHQscil9ZnVuY3Rpb24gV3Iobix0KXtpZih0KXJldHVybiBuLnNsaWNlKCk7dmFyIHI9bi5sZW5ndGgscj15aT95aShyKTpuZXcgbi5jb25zdHJ1Y3RvcihyKTtyZXR1cm4gbi5jb3B5KHIpLHJ9ZnVuY3Rpb24gQnIobil7dmFyIHQ9bmV3IG4uY29uc3RydWN0b3Iobi5ieXRlTGVuZ3RoKTtyZXR1cm4gbmV3IGRpKHQpLnNldChuZXcgZGkobikpLHR9ZnVuY3Rpb24gTHIobix0KXtyZXR1cm4gbmV3IG4uY29uc3RydWN0b3IodD9CcihuLmJ1ZmZlcik6bi5idWZmZXIsbi5ieXRlT2Zmc2V0LG4ubGVuZ3RoKX1mdW5jdGlvbiBVcihuLHQpe1xuaWYobiE9PXQpe3ZhciByPW4hPT1GLGU9bnVsbD09PW4sdT1uPT09bixpPUF1KG4pLG89dCE9PUYsZj1udWxsPT09dCxjPXQ9PT10LGE9QXUodCk7aWYoIWYmJiFhJiYhaSYmbj50fHxpJiZvJiZjJiYhZiYmIWF8fGUmJm8mJmN8fCFyJiZjfHwhdSlyZXR1cm4gMTtpZighZSYmIWkmJiFhJiZuPHR8fGEmJnImJnUmJiFlJiYhaXx8ZiYmciYmdXx8IW8mJnV8fCFjKXJldHVybi0xfXJldHVybiAwfWZ1bmN0aW9uIENyKG4sdCxyLGUpe3ZhciB1PS0xLGk9bi5sZW5ndGgsbz1yLmxlbmd0aCxmPS0xLGM9dC5sZW5ndGgsYT1EaShpLW8sMCksbD1IdShjK2EpO2ZvcihlPSFlOysrZjxjOylsW2ZdPXRbZl07Zm9yKDsrK3U8bzspKGV8fHU8aSkmJihsW3JbdV1dPW5bdV0pO2Zvcig7YS0tOylsW2YrK109blt1KytdO3JldHVybiBsfWZ1bmN0aW9uIERyKG4sdCxyLGUpe3ZhciB1PS0xLGk9bi5sZW5ndGgsbz0tMSxmPXIubGVuZ3RoLGM9LTEsYT10Lmxlbmd0aCxsPURpKGktZiwwKSxzPUh1KGwrYSk7XG5mb3IoZT0hZTsrK3U8bDspc1t1XT1uW3VdO2ZvcihsPXU7KytjPGE7KXNbbCtjXT10W2NdO2Zvcig7KytvPGY7KShlfHx1PGkpJiYoc1tsK3Jbb11dPW5bdSsrXSk7cmV0dXJuIHN9ZnVuY3Rpb24gTXIobix0KXt2YXIgcj0tMSxlPW4ubGVuZ3RoO2Zvcih0fHwodD1IdShlKSk7KytyPGU7KXRbcl09bltyXTtyZXR1cm4gdH1mdW5jdGlvbiBUcihuLHQscixlKXt2YXIgdT0hcjtyfHwocj17fSk7Zm9yKHZhciBpPS0xLG89dC5sZW5ndGg7KytpPG87KXt2YXIgZj10W2ldLGM9ZT9lKHJbZl0sbltmXSxmLHIsbik6RjtjPT09RiYmKGM9bltmXSksdT9fdChyLGYsYyk6YXQocixmLGMpfXJldHVybiByfWZ1bmN0aW9uICRyKG4sdCl7cmV0dXJuIFRyKG4sdm8obiksdCl9ZnVuY3Rpb24gRnIobix0KXtyZXR1cm4gVHIobixnbyhuKSx0KX1mdW5jdGlvbiBOcihuLHQpe3JldHVybiBmdW5jdGlvbihyLHUpe3ZhciBpPWFmKHIpP2U6c3Qsbz10P3QoKTp7fTtyZXR1cm4gaShyLG4samUodSwyKSxvKTtcbn19ZnVuY3Rpb24gUHIobil7cmV0dXJuIGxyKGZ1bmN0aW9uKHQscil7dmFyIGU9LTEsdT1yLmxlbmd0aCxpPTE8dT9yW3UtMV06RixvPTI8dT9yWzJdOkYsaT0zPG4ubGVuZ3RoJiZ0eXBlb2YgaT09XCJmdW5jdGlvblwiPyh1LS0saSk6Rjtmb3IobyYmemUoclswXSxyWzFdLG8pJiYoaT0zPnU/RjppLHU9MSksdD1uaSh0KTsrK2U8dTspKG89cltlXSkmJm4odCxvLGUsaSk7cmV0dXJuIHR9KX1mdW5jdGlvbiBacihuLHQpe3JldHVybiBmdW5jdGlvbihyLGUpe2lmKG51bGw9PXIpcmV0dXJuIHI7aWYoIXB1KHIpKXJldHVybiBuKHIsZSk7Zm9yKHZhciB1PXIubGVuZ3RoLGk9dD91Oi0xLG89bmkocik7KHQ/aS0tOisraTx1KSYmZmFsc2UhPT1lKG9baV0saSxvKTspO3JldHVybiByfX1mdW5jdGlvbiBxcihuKXtyZXR1cm4gZnVuY3Rpb24odCxyLGUpe3ZhciB1PS0xLGk9bmkodCk7ZT1lKHQpO2Zvcih2YXIgbz1lLmxlbmd0aDtvLS07KXt2YXIgZj1lW24/bzorK3VdO2lmKGZhbHNlPT09cihpW2ZdLGYsaSkpYnJlYWs7XG59cmV0dXJuIHR9fWZ1bmN0aW9uIFZyKG4sdCxyKXtmdW5jdGlvbiBlKCl7cmV0dXJuKHRoaXMmJnRoaXMhPT1abiYmdGhpcyBpbnN0YW5jZW9mIGU/aTpuKS5hcHBseSh1P3I6dGhpcyxhcmd1bWVudHMpfXZhciB1PTEmdCxpPUhyKG4pO3JldHVybiBlfWZ1bmN0aW9uIEtyKG4pe3JldHVybiBmdW5jdGlvbih0KXt0PXp1KHQpO3ZhciByPUJuLnRlc3QodCk/JCh0KTpGLGU9cj9yWzBdOnQuY2hhckF0KDApO3JldHVybiB0PXI/enIociwxKS5qb2luKFwiXCIpOnQuc2xpY2UoMSksZVtuXSgpK3R9fWZ1bmN0aW9uIEdyKG4pe3JldHVybiBmdW5jdGlvbih0KXtyZXR1cm4gaCgkdShUdSh0KS5yZXBsYWNlKEluLFwiXCIpKSxuLFwiXCIpfX1mdW5jdGlvbiBIcihuKXtyZXR1cm4gZnVuY3Rpb24oKXt2YXIgdD1hcmd1bWVudHM7c3dpdGNoKHQubGVuZ3RoKXtjYXNlIDA6cmV0dXJuIG5ldyBuO2Nhc2UgMTpyZXR1cm4gbmV3IG4odFswXSk7Y2FzZSAyOnJldHVybiBuZXcgbih0WzBdLHRbMV0pO2Nhc2UgMzpcbnJldHVybiBuZXcgbih0WzBdLHRbMV0sdFsyXSk7Y2FzZSA0OnJldHVybiBuZXcgbih0WzBdLHRbMV0sdFsyXSx0WzNdKTtjYXNlIDU6cmV0dXJuIG5ldyBuKHRbMF0sdFsxXSx0WzJdLHRbM10sdFs0XSk7Y2FzZSA2OnJldHVybiBuZXcgbih0WzBdLHRbMV0sdFsyXSx0WzNdLHRbNF0sdFs1XSk7Y2FzZSA3OnJldHVybiBuZXcgbih0WzBdLHRbMV0sdFsyXSx0WzNdLHRbNF0sdFs1XSx0WzZdKX12YXIgcj1pbyhuLnByb3RvdHlwZSksdD1uLmFwcGx5KHIsdCk7cmV0dXJuIGJ1KHQpP3Q6cn19ZnVuY3Rpb24gSnIobix0LGUpe2Z1bmN0aW9uIHUoKXtmb3IodmFyIG89YXJndW1lbnRzLmxlbmd0aCxmPUh1KG8pLGM9byxhPXhlKHUpO2MtLTspZltjXT1hcmd1bWVudHNbY107cmV0dXJuIGM9Mz5vJiZmWzBdIT09YSYmZltvLTFdIT09YT9bXTpDKGYsYSksby09Yy5sZW5ndGgsbzxlP2ZlKG4sdCxYcix1LnBsYWNlaG9sZGVyLEYsZixjLEYsRixlLW8pOnIodGhpcyYmdGhpcyE9PVpuJiZ0aGlzIGluc3RhbmNlb2YgdT9pOm4sdGhpcyxmKTtcbn12YXIgaT1IcihuKTtyZXR1cm4gdX1mdW5jdGlvbiBZcihuKXtyZXR1cm4gZnVuY3Rpb24odCxyLGUpe3ZhciB1PW5pKHQpO2lmKCFwdSh0KSl7dmFyIGk9amUociwzKTt0PUx1KHQpLHI9ZnVuY3Rpb24obil7cmV0dXJuIGkodVtuXSxuLHUpfX1yZXR1cm4gcj1uKHQscixlKSwtMTxyP3VbaT90W3JdOnJdOkZ9fWZ1bmN0aW9uIFFyKG4pe3JldHVybiBnZShmdW5jdGlvbih0KXt2YXIgcj10Lmxlbmd0aCxlPXIsdT16bi5wcm90b3R5cGUudGhydTtmb3IobiYmdC5yZXZlcnNlKCk7ZS0tOyl7dmFyIGk9dFtlXTtpZih0eXBlb2YgaSE9XCJmdW5jdGlvblwiKXRocm93IG5ldyBlaShcIkV4cGVjdGVkIGEgZnVuY3Rpb25cIik7aWYodSYmIW8mJlwid3JhcHBlclwiPT1iZShpKSl2YXIgbz1uZXcgem4oW10sdHJ1ZSl9Zm9yKGU9bz9lOnI7KytlPHI7KXZhciBpPXRbZV0sdT1iZShpKSxmPVwid3JhcHBlclwiPT11P19vKGkpOkYsbz1mJiZCZShmWzBdKSYmNDI0PT1mWzFdJiYhZls0XS5sZW5ndGgmJjE9PWZbOV0/b1tiZShmWzBdKV0uYXBwbHkobyxmWzNdKToxPT1pLmxlbmd0aCYmQmUoaSk/b1t1XSgpOm8udGhydShpKTtcbnJldHVybiBmdW5jdGlvbigpe3ZhciBuPWFyZ3VtZW50cyxlPW5bMF07aWYobyYmMT09bi5sZW5ndGgmJmFmKGUpKXJldHVybiBvLnBsYW50KGUpLnZhbHVlKCk7Zm9yKHZhciB1PTAsbj1yP3RbdV0uYXBwbHkodGhpcyxuKTplOysrdTxyOyluPXRbdV0uY2FsbCh0aGlzLG4pO3JldHVybiBufX0pfWZ1bmN0aW9uIFhyKG4sdCxyLGUsdSxpLG8sZixjLGEpe2Z1bmN0aW9uIGwoKXtmb3IodmFyIGQ9YXJndW1lbnRzLmxlbmd0aCx5PUh1KGQpLGI9ZDtiLS07KXlbYl09YXJndW1lbnRzW2JdO2lmKF8pe3ZhciB4LGo9eGUobCksYj15Lmxlbmd0aDtmb3IoeD0wO2ItLTspeVtiXT09PWomJisreH1pZihlJiYoeT1Dcih5LGUsdSxfKSksaSYmKHk9RHIoeSxpLG8sXykpLGQtPXgsXyYmZDxhKXJldHVybiBqPUMoeSxqKSxmZShuLHQsWHIsbC5wbGFjZWhvbGRlcixyLHksaixmLGMsYS1kKTtpZihqPWg/cjp0aGlzLGI9cD9qW25dOm4sZD15Lmxlbmd0aCxmKXt4PXkubGVuZ3RoO2Zvcih2YXIgdz1NaShmLmxlbmd0aCx4KSxtPU1yKHkpO3ctLTspe1xudmFyIEE9Zlt3XTt5W3ddPVJlKEEseCk/bVtBXTpGfX1lbHNlIHYmJjE8ZCYmeS5yZXZlcnNlKCk7cmV0dXJuIHMmJmM8ZCYmKHkubGVuZ3RoPWMpLHRoaXMmJnRoaXMhPT1abiYmdGhpcyBpbnN0YW5jZW9mIGwmJihiPWd8fEhyKGIpKSxiLmFwcGx5KGoseSl9dmFyIHM9MTI4JnQsaD0xJnQscD0yJnQsXz0yNCZ0LHY9NTEyJnQsZz1wP0Y6SHIobik7cmV0dXJuIGx9ZnVuY3Rpb24gbmUobix0KXtyZXR1cm4gZnVuY3Rpb24ocixlKXtyZXR1cm4gQ3QocixuLHQoZSkpfX1mdW5jdGlvbiB0ZShuLHQpe3JldHVybiBmdW5jdGlvbihyLGUpe3ZhciB1O2lmKHI9PT1GJiZlPT09RilyZXR1cm4gdDtpZihyIT09RiYmKHU9ciksZSE9PUYpe2lmKHU9PT1GKXJldHVybiBlO3R5cGVvZiByPT1cInN0cmluZ1wifHx0eXBlb2YgZT09XCJzdHJpbmdcIj8ocj1qcihyKSxlPWpyKGUpKToocj14cihyKSxlPXhyKGUpKSx1PW4ocixlKX1yZXR1cm4gdX19ZnVuY3Rpb24gcmUobil7cmV0dXJuIGdlKGZ1bmN0aW9uKHQpe1xucmV0dXJuIHQ9bCh0LFMoamUoKSkpLGxyKGZ1bmN0aW9uKGUpe3ZhciB1PXRoaXM7cmV0dXJuIG4odCxmdW5jdGlvbihuKXtyZXR1cm4gcihuLHUsZSl9KX0pfSl9ZnVuY3Rpb24gZWUobix0KXt0PXQ9PT1GP1wiIFwiOmpyKHQpO3ZhciByPXQubGVuZ3RoO3JldHVybiAyPnI/cj9hcih0LG4pOnQ6KHI9YXIodCxSaShuL1QodCkpKSxCbi50ZXN0KHQpP3pyKCQociksMCxuKS5qb2luKFwiXCIpOnIuc2xpY2UoMCxuKSl9ZnVuY3Rpb24gdWUobix0LGUsdSl7ZnVuY3Rpb24gaSgpe2Zvcih2YXIgdD0tMSxjPWFyZ3VtZW50cy5sZW5ndGgsYT0tMSxsPXUubGVuZ3RoLHM9SHUobCtjKSxoPXRoaXMmJnRoaXMhPT1abiYmdGhpcyBpbnN0YW5jZW9mIGk/ZjpuOysrYTxsOylzW2FdPXVbYV07Zm9yKDtjLS07KXNbYSsrXT1hcmd1bWVudHNbKyt0XTtyZXR1cm4gcihoLG8/ZTp0aGlzLHMpfXZhciBvPTEmdCxmPUhyKG4pO3JldHVybiBpfWZ1bmN0aW9uIGllKG4pe3JldHVybiBmdW5jdGlvbih0LHIsZSl7XG5lJiZ0eXBlb2YgZSE9XCJudW1iZXJcIiYmemUodCxyLGUpJiYocj1lPUYpLHQ9RXUodCkscj09PUY/KHI9dCx0PTApOnI9RXUociksZT1lPT09Rj90PHI/MTotMTpFdShlKTt2YXIgdT0tMTtyPURpKFJpKChyLXQpLyhlfHwxKSksMCk7Zm9yKHZhciBpPUh1KHIpO3ItLTspaVtuP3I6Kyt1XT10LHQrPWU7cmV0dXJuIGl9fWZ1bmN0aW9uIG9lKG4pe3JldHVybiBmdW5jdGlvbih0LHIpe3JldHVybiB0eXBlb2YgdD09XCJzdHJpbmdcIiYmdHlwZW9mIHI9PVwic3RyaW5nXCJ8fCh0PUl1KHQpLHI9SXUocikpLG4odCxyKX19ZnVuY3Rpb24gZmUobix0LHIsZSx1LGksbyxmLGMsYSl7dmFyIGw9OCZ0LHM9bD9vOkY7bz1sP0Y6bzt2YXIgaD1sP2k6RjtyZXR1cm4gaT1sP0Y6aSx0PSh0fChsPzMyOjY0KSkmfihsPzY0OjMyKSw0JnR8fCh0Jj0tNCksdT1bbix0LHUsaCxzLGksbyxmLGMsYV0scj1yLmFwcGx5KEYsdSksQmUobikmJnhvKHIsdSksci5wbGFjZWhvbGRlcj1lLERlKHIsbix0KX1mdW5jdGlvbiBjZShuKXtcbnZhciB0PVh1W25dO3JldHVybiBmdW5jdGlvbihuLHIpe2lmKG49SXUobikscj1udWxsPT1yPzA6TWkoT3UociksMjkyKSl7dmFyIGU9KHp1KG4pK1wiZVwiKS5zcGxpdChcImVcIiksZT10KGVbMF0rXCJlXCIrKCtlWzFdK3IpKSxlPSh6dShlKStcImVcIikuc3BsaXQoXCJlXCIpO3JldHVybisoZVswXStcImVcIisoK2VbMV0tcikpfXJldHVybiB0KG4pfX1mdW5jdGlvbiBhZShuKXtyZXR1cm4gZnVuY3Rpb24odCl7dmFyIHI9eW8odCk7cmV0dXJuXCJbb2JqZWN0IE1hcF1cIj09cj9MKHQpOlwiW29iamVjdCBTZXRdXCI9PXI/TSh0KTpPKHQsbih0KSl9fWZ1bmN0aW9uIGxlKG4sdCxyLGUsdSxpLG8sZil7dmFyIGM9MiZ0O2lmKCFjJiZ0eXBlb2YgbiE9XCJmdW5jdGlvblwiKXRocm93IG5ldyBlaShcIkV4cGVjdGVkIGEgZnVuY3Rpb25cIik7dmFyIGE9ZT9lLmxlbmd0aDowO2lmKGF8fCh0Jj0tOTcsZT11PUYpLG89bz09PUY/bzpEaShPdShvKSwwKSxmPWY9PT1GP2Y6T3UoZiksYS09dT91Lmxlbmd0aDowLDY0JnQpe1xudmFyIGw9ZSxzPXU7ZT11PUZ9dmFyIGg9Yz9GOl9vKG4pO3JldHVybiBpPVtuLHQscixlLHUsbCxzLGksbyxmXSxoJiYocj1pWzFdLG49aFsxXSx0PXJ8bixlPTEyOD09biYmOD09cnx8MTI4PT1uJiYyNTY9PXImJmlbN10ubGVuZ3RoPD1oWzhdfHwzODQ9PW4mJmhbN10ubGVuZ3RoPD1oWzhdJiY4PT1yLDEzMT50fHxlKSYmKDEmbiYmKGlbMl09aFsyXSx0fD0xJnI/MDo0KSwocj1oWzNdKSYmKGU9aVszXSxpWzNdPWU/Q3IoZSxyLGhbNF0pOnIsaVs0XT1lP0MoaVszXSxcIl9fbG9kYXNoX3BsYWNlaG9sZGVyX19cIik6aFs0XSksKHI9aFs1XSkmJihlPWlbNV0saVs1XT1lP0RyKGUscixoWzZdKTpyLGlbNl09ZT9DKGlbNV0sXCJfX2xvZGFzaF9wbGFjZWhvbGRlcl9fXCIpOmhbNl0pLChyPWhbN10pJiYoaVs3XT1yKSwxMjgmbiYmKGlbOF09bnVsbD09aVs4XT9oWzhdOk1pKGlbOF0saFs4XSkpLG51bGw9PWlbOV0mJihpWzldPWhbOV0pLGlbMF09aFswXSxpWzFdPXQpLG49aVswXSx0PWlbMV0sXG5yPWlbMl0sZT1pWzNdLHU9aVs0XSxmPWlbOV09aVs5XT09PUY/Yz8wOm4ubGVuZ3RoOkRpKGlbOV0tYSwwKSwhZiYmMjQmdCYmKHQmPS0yNSksRGUoKGg/bG86eG8pKHQmJjEhPXQ/OD09dHx8MTY9PXQ/SnIobix0LGYpOjMyIT10JiYzMyE9dHx8dS5sZW5ndGg/WHIuYXBwbHkoRixpKTp1ZShuLHQscixlKTpWcihuLHQsciksaSksbix0KX1mdW5jdGlvbiBzZShuLHQscixlKXtyZXR1cm4gbj09PUZ8fGh1KG4saWlbcl0pJiYhY2kuY2FsbChlLHIpP3Q6bn1mdW5jdGlvbiBoZShuLHQscixlLHUsaSl7cmV0dXJuIGJ1KG4pJiZidSh0KSYmKGkuc2V0KHQsbiksbnIobix0LEYsaGUsaSksaS5kZWxldGUodCkpLG59ZnVuY3Rpb24gcGUobil7cmV0dXJuIHd1KG4pP0Y6bn1mdW5jdGlvbiBfZShuLHQscixlLHUsaSl7dmFyIG89MSZyLGY9bi5sZW5ndGgsYz10Lmxlbmd0aDtpZihmIT1jJiYhKG8mJmM+ZikpcmV0dXJuIGZhbHNlO2lmKChjPWkuZ2V0KG4pKSYmaS5nZXQodCkpcmV0dXJuIGM9PXQ7dmFyIGM9LTEsYT10cnVlLGw9MiZyP25ldyBxbjpGO1xuZm9yKGkuc2V0KG4sdCksaS5zZXQodCxuKTsrK2M8Zjspe3ZhciBzPW5bY10saD10W2NdO2lmKGUpdmFyIHA9bz9lKGgscyxjLHQsbixpKTplKHMsaCxjLG4sdCxpKTtpZihwIT09Ril7aWYocCljb250aW51ZTthPWZhbHNlO2JyZWFrfWlmKGwpe2lmKCFfKHQsZnVuY3Rpb24obix0KXtpZighUihsLHQpJiYocz09PW58fHUocyxuLHIsZSxpKSkpcmV0dXJuIGwucHVzaCh0KX0pKXthPWZhbHNlO2JyZWFrfX1lbHNlIGlmKHMhPT1oJiYhdShzLGgscixlLGkpKXthPWZhbHNlO2JyZWFrfX1yZXR1cm4gaS5kZWxldGUobiksaS5kZWxldGUodCksYX1mdW5jdGlvbiB2ZShuLHQscixlLHUsaSxvKXtzd2l0Y2gocil7Y2FzZVwiW29iamVjdCBEYXRhVmlld11cIjppZihuLmJ5dGVMZW5ndGghPXQuYnl0ZUxlbmd0aHx8bi5ieXRlT2Zmc2V0IT10LmJ5dGVPZmZzZXQpYnJlYWs7bj1uLmJ1ZmZlcix0PXQuYnVmZmVyO2Nhc2VcIltvYmplY3QgQXJyYXlCdWZmZXJdXCI6aWYobi5ieXRlTGVuZ3RoIT10LmJ5dGVMZW5ndGh8fCFpKG5ldyBkaShuKSxuZXcgZGkodCkpKWJyZWFrO1xucmV0dXJuIHRydWU7Y2FzZVwiW29iamVjdCBCb29sZWFuXVwiOmNhc2VcIltvYmplY3QgRGF0ZV1cIjpjYXNlXCJbb2JqZWN0IE51bWJlcl1cIjpyZXR1cm4gaHUoK24sK3QpO2Nhc2VcIltvYmplY3QgRXJyb3JdXCI6cmV0dXJuIG4ubmFtZT09dC5uYW1lJiZuLm1lc3NhZ2U9PXQubWVzc2FnZTtjYXNlXCJbb2JqZWN0IFJlZ0V4cF1cIjpjYXNlXCJbb2JqZWN0IFN0cmluZ11cIjpyZXR1cm4gbj09dCtcIlwiO2Nhc2VcIltvYmplY3QgTWFwXVwiOnZhciBmPUw7Y2FzZVwiW29iamVjdCBTZXRdXCI6aWYoZnx8KGY9RCksbi5zaXplIT10LnNpemUmJiEoMSZlKSlicmVhaztyZXR1cm4ocj1vLmdldChuKSk/cj09dDooZXw9MixvLnNldChuLHQpLHQ9X2UoZihuKSxmKHQpLGUsdSxpLG8pLG8uZGVsZXRlKG4pLHQpO2Nhc2VcIltvYmplY3QgU3ltYm9sXVwiOmlmKGVvKXJldHVybiBlby5jYWxsKG4pPT1lby5jYWxsKHQpfXJldHVybiBmYWxzZX1mdW5jdGlvbiBnZShuKXtyZXR1cm4gd28oQ2UobixGLFZlKSxuK1wiXCIpfWZ1bmN0aW9uIGRlKG4pe1xucmV0dXJuIFJ0KG4sTHUsdm8pfWZ1bmN0aW9uIHllKG4pe3JldHVybiBSdChuLFV1LGdvKX1mdW5jdGlvbiBiZShuKXtmb3IodmFyIHQ9bi5uYW1lK1wiXCIscj1KaVt0XSxlPWNpLmNhbGwoSmksdCk/ci5sZW5ndGg6MDtlLS07KXt2YXIgdT1yW2VdLGk9dS5mdW5jO2lmKG51bGw9PWl8fGk9PW4pcmV0dXJuIHUubmFtZX1yZXR1cm4gdH1mdW5jdGlvbiB4ZShuKXtyZXR1cm4oY2kuY2FsbChPbixcInBsYWNlaG9sZGVyXCIpP09uOm4pLnBsYWNlaG9sZGVyfWZ1bmN0aW9uIGplKCl7dmFyIG49T24uaXRlcmF0ZWV8fFB1LG49bj09PVB1P0d0Om47cmV0dXJuIGFyZ3VtZW50cy5sZW5ndGg/bihhcmd1bWVudHNbMF0sYXJndW1lbnRzWzFdKTpufWZ1bmN0aW9uIHdlKG4sdCl7dmFyIHI9bi5fX2RhdGFfXyxlPXR5cGVvZiB0O3JldHVybihcInN0cmluZ1wiPT1lfHxcIm51bWJlclwiPT1lfHxcInN5bWJvbFwiPT1lfHxcImJvb2xlYW5cIj09ZT9cIl9fcHJvdG9fX1wiIT09dDpudWxsPT09dCk/clt0eXBlb2YgdD09XCJzdHJpbmdcIj9cInN0cmluZ1wiOlwiaGFzaFwiXTpyLm1hcDtcbn1mdW5jdGlvbiBtZShuKXtmb3IodmFyIHQ9THUobikscj10Lmxlbmd0aDtyLS07KXt2YXIgZT10W3JdLHU9bltlXTt0W3JdPVtlLHUsdT09PXUmJiFidSh1KV19cmV0dXJuIHR9ZnVuY3Rpb24gQWUobix0KXt2YXIgcj1udWxsPT1uP0Y6blt0XTtyZXR1cm4gWnQocik/cjpGfWZ1bmN0aW9uIGtlKG4sdCxyKXt0PVJyKHQsbik7Zm9yKHZhciBlPS0xLHU9dC5sZW5ndGgsaT1mYWxzZTsrK2U8dTspe3ZhciBvPSRlKHRbZV0pO2lmKCEoaT1udWxsIT1uJiZyKG4sbykpKWJyZWFrO249bltvXX1yZXR1cm4gaXx8KytlIT11P2k6KHU9bnVsbD09bj8wOm4ubGVuZ3RoLCEhdSYmeXUodSkmJlJlKG8sdSkmJihhZihuKXx8Y2YobikpKX1mdW5jdGlvbiBFZShuKXt2YXIgdD1uLmxlbmd0aCxyPW4uY29uc3RydWN0b3IodCk7cmV0dXJuIHQmJlwic3RyaW5nXCI9PXR5cGVvZiBuWzBdJiZjaS5jYWxsKG4sXCJpbmRleFwiKSYmKHIuaW5kZXg9bi5pbmRleCxyLmlucHV0PW4uaW5wdXQpLHJ9ZnVuY3Rpb24gT2Uobil7XG5yZXR1cm4gdHlwZW9mIG4uY29uc3RydWN0b3IhPVwiZnVuY3Rpb25cInx8TGUobik/e306aW8oYmkobikpfWZ1bmN0aW9uIFNlKHIsZSx1LGkpe3ZhciBvPXIuY29uc3RydWN0b3I7c3dpdGNoKGUpe2Nhc2VcIltvYmplY3QgQXJyYXlCdWZmZXJdXCI6cmV0dXJuIEJyKHIpO2Nhc2VcIltvYmplY3QgQm9vbGVhbl1cIjpjYXNlXCJbb2JqZWN0IERhdGVdXCI6cmV0dXJuIG5ldyBvKCtyKTtjYXNlXCJbb2JqZWN0IERhdGFWaWV3XVwiOnJldHVybiBlPWk/QnIoci5idWZmZXIpOnIuYnVmZmVyLG5ldyByLmNvbnN0cnVjdG9yKGUsci5ieXRlT2Zmc2V0LHIuYnl0ZUxlbmd0aCk7Y2FzZVwiW29iamVjdCBGbG9hdDMyQXJyYXldXCI6Y2FzZVwiW29iamVjdCBGbG9hdDY0QXJyYXldXCI6Y2FzZVwiW29iamVjdCBJbnQ4QXJyYXldXCI6Y2FzZVwiW29iamVjdCBJbnQxNkFycmF5XVwiOmNhc2VcIltvYmplY3QgSW50MzJBcnJheV1cIjpjYXNlXCJbb2JqZWN0IFVpbnQ4QXJyYXldXCI6Y2FzZVwiW29iamVjdCBVaW50OENsYW1wZWRBcnJheV1cIjpcbmNhc2VcIltvYmplY3QgVWludDE2QXJyYXldXCI6Y2FzZVwiW29iamVjdCBVaW50MzJBcnJheV1cIjpyZXR1cm4gTHIocixpKTtjYXNlXCJbb2JqZWN0IE1hcF1cIjpyZXR1cm4gZT1pP3UoTChyKSwxKTpMKHIpLGgoZSxuLG5ldyByLmNvbnN0cnVjdG9yKTtjYXNlXCJbb2JqZWN0IE51bWJlcl1cIjpjYXNlXCJbb2JqZWN0IFN0cmluZ11cIjpyZXR1cm4gbmV3IG8ocik7Y2FzZVwiW29iamVjdCBSZWdFeHBdXCI6cmV0dXJuIGU9bmV3IHIuY29uc3RydWN0b3Ioci5zb3VyY2UsZG4uZXhlYyhyKSksZS5sYXN0SW5kZXg9ci5sYXN0SW5kZXgsZTtjYXNlXCJbb2JqZWN0IFNldF1cIjpyZXR1cm4gZT1pP3UoRChyKSwxKTpEKHIpLGgoZSx0LG5ldyByLmNvbnN0cnVjdG9yKTtjYXNlXCJbb2JqZWN0IFN5bWJvbF1cIjpyZXR1cm4gZW8/bmkoZW8uY2FsbChyKSk6e319fWZ1bmN0aW9uIEllKG4pe3JldHVybiBhZihuKXx8Y2Yobil8fCEhKG1pJiZuJiZuW21pXSl9ZnVuY3Rpb24gUmUobix0KXtyZXR1cm4gdD1udWxsPT10PzkwMDcxOTkyNTQ3NDA5OTE6dCxcbiEhdCYmKHR5cGVvZiBuPT1cIm51bWJlclwifHx3bi50ZXN0KG4pKSYmLTE8biYmMD09biUxJiZuPHR9ZnVuY3Rpb24gemUobix0LHIpe2lmKCFidShyKSlyZXR1cm4gZmFsc2U7dmFyIGU9dHlwZW9mIHQ7cmV0dXJuISEoXCJudW1iZXJcIj09ZT9wdShyKSYmUmUodCxyLmxlbmd0aCk6XCJzdHJpbmdcIj09ZSYmdCBpbiByKSYmaHUoclt0XSxuKX1mdW5jdGlvbiBXZShuLHQpe2lmKGFmKG4pKXJldHVybiBmYWxzZTt2YXIgcj10eXBlb2YgbjtyZXR1cm4hKFwibnVtYmVyXCIhPXImJlwic3ltYm9sXCIhPXImJlwiYm9vbGVhblwiIT1yJiZudWxsIT1uJiYhQXUobikpfHwocm4udGVzdChuKXx8IXRuLnRlc3Qobil8fG51bGwhPXQmJm4gaW4gbmkodCkpfWZ1bmN0aW9uIEJlKG4pe3ZhciB0PWJlKG4pLHI9T25bdF07cmV0dXJuIHR5cGVvZiByPT1cImZ1bmN0aW9uXCImJnQgaW4gTW4ucHJvdG90eXBlJiYobj09PXJ8fCh0PV9vKHIpLCEhdCYmbj09PXRbMF0pKX1mdW5jdGlvbiBMZShuKXt2YXIgdD1uJiZuLmNvbnN0cnVjdG9yO1xucmV0dXJuIG49PT0odHlwZW9mIHQ9PVwiZnVuY3Rpb25cIiYmdC5wcm90b3R5cGV8fGlpKX1mdW5jdGlvbiBVZShuLHQpe3JldHVybiBmdW5jdGlvbihyKXtyZXR1cm4gbnVsbCE9ciYmKHJbbl09PT10JiYodCE9PUZ8fG4gaW4gbmkocikpKX19ZnVuY3Rpb24gQ2Uobix0LGUpe3JldHVybiB0PURpKHQ9PT1GP24ubGVuZ3RoLTE6dCwwKSxmdW5jdGlvbigpe2Zvcih2YXIgdT1hcmd1bWVudHMsaT0tMSxvPURpKHUubGVuZ3RoLXQsMCksZj1IdShvKTsrK2k8bzspZltpXT11W3QraV07Zm9yKGk9LTEsbz1IdSh0KzEpOysraTx0OylvW2ldPXVbaV07cmV0dXJuIG9bdF09ZShmKSxyKG4sdGhpcyxvKX19ZnVuY3Rpb24gRGUobix0LHIpe3ZhciBlPXQrXCJcIjt0PXdvO3ZhciB1LGk9TmU7cmV0dXJuIHU9KHU9ZS5tYXRjaChobikpP3VbMV0uc3BsaXQocG4pOltdLHI9aSh1LHIpLChpPXIubGVuZ3RoKSYmKHU9aS0xLHJbdV09KDE8aT9cIiYgXCI6XCJcIikrclt1XSxyPXIuam9pbigyPGk/XCIsIFwiOlwiIFwiKSxcbmU9ZS5yZXBsYWNlKHNuLFwie1xcbi8qIFt3cmFwcGVkIHdpdGggXCIrcitcIl0gKi9cXG5cIikpLHQobixlKX1mdW5jdGlvbiBNZShuKXt2YXIgdD0wLHI9MDtyZXR1cm4gZnVuY3Rpb24oKXt2YXIgZT1UaSgpLHU9MTYtKGUtcik7aWYocj1lLDA8dSl7aWYoODAwPD0rK3QpcmV0dXJuIGFyZ3VtZW50c1swXX1lbHNlIHQ9MDtyZXR1cm4gbi5hcHBseShGLGFyZ3VtZW50cyl9fWZ1bmN0aW9uIFRlKG4sdCl7dmFyIHI9LTEsZT1uLmxlbmd0aCx1PWUtMTtmb3IodD10PT09Rj9lOnQ7KytyPHQ7KXt2YXIgZT1jcihyLHUpLGk9bltlXTtuW2VdPW5bcl0sbltyXT1pfXJldHVybiBuLmxlbmd0aD10LG59ZnVuY3Rpb24gJGUobil7aWYodHlwZW9mIG49PVwic3RyaW5nXCJ8fEF1KG4pKXJldHVybiBuO3ZhciB0PW4rXCJcIjtyZXR1cm5cIjBcIj09dCYmMS9uPT0tTj9cIi0wXCI6dH1mdW5jdGlvbiBGZShuKXtpZihudWxsIT1uKXt0cnl7cmV0dXJuIGZpLmNhbGwobil9Y2F0Y2gobil7fXJldHVybiBuK1wiXCJ9cmV0dXJuXCJcIjtcbn1mdW5jdGlvbiBOZShuLHQpe3JldHVybiB1KFosZnVuY3Rpb24ocil7dmFyIGU9XCJfLlwiK3JbMF07dCZyWzFdJiYhYyhuLGUpJiZuLnB1c2goZSl9KSxuLnNvcnQoKX1mdW5jdGlvbiBQZShuKXtpZihuIGluc3RhbmNlb2YgTW4pcmV0dXJuIG4uY2xvbmUoKTt2YXIgdD1uZXcgem4obi5fX3dyYXBwZWRfXyxuLl9fY2hhaW5fXyk7cmV0dXJuIHQuX19hY3Rpb25zX189TXIobi5fX2FjdGlvbnNfXyksdC5fX2luZGV4X189bi5fX2luZGV4X18sdC5fX3ZhbHVlc19fPW4uX192YWx1ZXNfXyx0fWZ1bmN0aW9uIFplKG4sdCxyKXt2YXIgZT1udWxsPT1uPzA6bi5sZW5ndGg7cmV0dXJuIGU/KHI9bnVsbD09cj8wOk91KHIpLDA+ciYmKHI9RGkoZStyLDApKSxnKG4samUodCwzKSxyKSk6LTF9ZnVuY3Rpb24gcWUobix0LHIpe3ZhciBlPW51bGw9PW4/MDpuLmxlbmd0aDtpZighZSlyZXR1cm4tMTt2YXIgdT1lLTE7cmV0dXJuIHIhPT1GJiYodT1PdShyKSx1PTA+cj9EaShlK3UsMCk6TWkodSxlLTEpKSxcbmcobixqZSh0LDMpLHUsdHJ1ZSl9ZnVuY3Rpb24gVmUobil7cmV0dXJuKG51bGw9PW4/MDpuLmxlbmd0aCk/a3QobiwxKTpbXX1mdW5jdGlvbiBLZShuKXtyZXR1cm4gbiYmbi5sZW5ndGg/blswXTpGfWZ1bmN0aW9uIEdlKG4pe3ZhciB0PW51bGw9PW4/MDpuLmxlbmd0aDtyZXR1cm4gdD9uW3QtMV06Rn1mdW5jdGlvbiBIZShuLHQpe3JldHVybiBuJiZuLmxlbmd0aCYmdCYmdC5sZW5ndGg/b3Iobix0KTpufWZ1bmN0aW9uIEplKG4pe3JldHVybiBudWxsPT1uP246TmkuY2FsbChuKX1mdW5jdGlvbiBZZShuKXtpZighbnx8IW4ubGVuZ3RoKXJldHVybltdO3ZhciB0PTA7cmV0dXJuIG49ZihuLGZ1bmN0aW9uKG4pe2lmKF91KG4pKXJldHVybiB0PURpKG4ubGVuZ3RoLHQpLHRydWV9KSxFKHQsZnVuY3Rpb24odCl7cmV0dXJuIGwobixqKHQpKX0pfWZ1bmN0aW9uIFFlKG4sdCl7aWYoIW58fCFuLmxlbmd0aClyZXR1cm5bXTt2YXIgZT1ZZShuKTtyZXR1cm4gbnVsbD09dD9lOmwoZSxmdW5jdGlvbihuKXtcbnJldHVybiByKHQsRixuKX0pfWZ1bmN0aW9uIFhlKG4pe3JldHVybiBuPU9uKG4pLG4uX19jaGFpbl9fPXRydWUsbn1mdW5jdGlvbiBudShuLHQpe3JldHVybiB0KG4pfWZ1bmN0aW9uIHR1KCl7cmV0dXJuIHRoaXN9ZnVuY3Rpb24gcnUobix0KXtyZXR1cm4oYWYobik/dTpvbykobixqZSh0LDMpKX1mdW5jdGlvbiBldShuLHQpe3JldHVybihhZihuKT9pOmZvKShuLGplKHQsMykpfWZ1bmN0aW9uIHV1KG4sdCl7cmV0dXJuKGFmKG4pP2w6WXQpKG4samUodCwzKSl9ZnVuY3Rpb24gaXUobix0LHIpe3JldHVybiB0PXI/Rjp0LHQ9biYmbnVsbD09dD9uLmxlbmd0aDp0LGxlKG4sMTI4LEYsRixGLEYsdCl9ZnVuY3Rpb24gb3Uobix0KXt2YXIgcjtpZih0eXBlb2YgdCE9XCJmdW5jdGlvblwiKXRocm93IG5ldyBlaShcIkV4cGVjdGVkIGEgZnVuY3Rpb25cIik7cmV0dXJuIG49T3UobiksZnVuY3Rpb24oKXtyZXR1cm4gMDwtLW4mJihyPXQuYXBwbHkodGhpcyxhcmd1bWVudHMpKSwxPj1uJiYodD1GKSxcbnJ9fWZ1bmN0aW9uIGZ1KG4sdCxyKXtyZXR1cm4gdD1yP0Y6dCxuPWxlKG4sOCxGLEYsRixGLEYsdCksbi5wbGFjZWhvbGRlcj1mdS5wbGFjZWhvbGRlcixufWZ1bmN0aW9uIGN1KG4sdCxyKXtyZXR1cm4gdD1yP0Y6dCxuPWxlKG4sMTYsRixGLEYsRixGLHQpLG4ucGxhY2Vob2xkZXI9Y3UucGxhY2Vob2xkZXIsbn1mdW5jdGlvbiBhdShuLHQscil7ZnVuY3Rpb24gZSh0KXt2YXIgcj1jLGU9YTtyZXR1cm4gYz1hPUYsXz10LHM9bi5hcHBseShlLHIpfWZ1bmN0aW9uIHUobil7dmFyIHI9bi1wO3JldHVybiBuLT1fLHA9PT1GfHxyPj10fHwwPnJ8fGcmJm4+PWx9ZnVuY3Rpb24gaSgpe3ZhciBuPUpvKCk7aWYodShuKSlyZXR1cm4gbyhuKTt2YXIgcixlPWpvO3I9bi1fLG49dC0obi1wKSxyPWc/TWkobixsLXIpOm4saD1lKGkscil9ZnVuY3Rpb24gbyhuKXtyZXR1cm4gaD1GLGQmJmM/ZShuKTooYz1hPUYscyl9ZnVuY3Rpb24gZigpe3ZhciBuPUpvKCkscj11KG4pO2lmKGM9YXJndW1lbnRzLFxuYT10aGlzLHA9bixyKXtpZihoPT09RilyZXR1cm4gXz1uPXAsaD1qbyhpLHQpLHY/ZShuKTpzO2lmKGcpcmV0dXJuIGg9am8oaSx0KSxlKHApfXJldHVybiBoPT09RiYmKGg9am8oaSx0KSksc312YXIgYyxhLGwscyxoLHAsXz0wLHY9ZmFsc2UsZz1mYWxzZSxkPXRydWU7aWYodHlwZW9mIG4hPVwiZnVuY3Rpb25cIil0aHJvdyBuZXcgZWkoXCJFeHBlY3RlZCBhIGZ1bmN0aW9uXCIpO3JldHVybiB0PUl1KHQpfHwwLGJ1KHIpJiYodj0hIXIubGVhZGluZyxsPShnPVwibWF4V2FpdFwiaW4gcik/RGkoSXUoci5tYXhXYWl0KXx8MCx0KTpsLGQ9XCJ0cmFpbGluZ1wiaW4gcj8hIXIudHJhaWxpbmc6ZCksZi5jYW5jZWw9ZnVuY3Rpb24oKXtoIT09RiYmaG8oaCksXz0wLGM9cD1hPWg9Rn0sZi5mbHVzaD1mdW5jdGlvbigpe3JldHVybiBoPT09Rj9zOm8oSm8oKSl9LGZ9ZnVuY3Rpb24gbHUobix0KXtmdW5jdGlvbiByKCl7dmFyIGU9YXJndW1lbnRzLHU9dD90LmFwcGx5KHRoaXMsZSk6ZVswXSxpPXIuY2FjaGU7cmV0dXJuIGkuaGFzKHUpP2kuZ2V0KHUpOihlPW4uYXBwbHkodGhpcyxlKSxcbnIuY2FjaGU9aS5zZXQodSxlKXx8aSxlKX1pZih0eXBlb2YgbiE9XCJmdW5jdGlvblwifHxudWxsIT10JiZ0eXBlb2YgdCE9XCJmdW5jdGlvblwiKXRocm93IG5ldyBlaShcIkV4cGVjdGVkIGEgZnVuY3Rpb25cIik7cmV0dXJuIHIuY2FjaGU9bmV3KGx1LkNhY2hlfHxQbikscn1mdW5jdGlvbiBzdShuKXtpZih0eXBlb2YgbiE9XCJmdW5jdGlvblwiKXRocm93IG5ldyBlaShcIkV4cGVjdGVkIGEgZnVuY3Rpb25cIik7cmV0dXJuIGZ1bmN0aW9uKCl7dmFyIHQ9YXJndW1lbnRzO3N3aXRjaCh0Lmxlbmd0aCl7Y2FzZSAwOnJldHVybiFuLmNhbGwodGhpcyk7Y2FzZSAxOnJldHVybiFuLmNhbGwodGhpcyx0WzBdKTtjYXNlIDI6cmV0dXJuIW4uY2FsbCh0aGlzLHRbMF0sdFsxXSk7Y2FzZSAzOnJldHVybiFuLmNhbGwodGhpcyx0WzBdLHRbMV0sdFsyXSl9cmV0dXJuIW4uYXBwbHkodGhpcyx0KX19ZnVuY3Rpb24gaHUobix0KXtyZXR1cm4gbj09PXR8fG4hPT1uJiZ0IT09dH1mdW5jdGlvbiBwdShuKXtyZXR1cm4gbnVsbCE9biYmeXUobi5sZW5ndGgpJiYhZ3Uobik7XG59ZnVuY3Rpb24gX3Uobil7cmV0dXJuIHh1KG4pJiZwdShuKX1mdW5jdGlvbiB2dShuKXtpZigheHUobikpcmV0dXJuIGZhbHNlO3ZhciB0PXp0KG4pO3JldHVyblwiW29iamVjdCBFcnJvcl1cIj09dHx8XCJbb2JqZWN0IERPTUV4Y2VwdGlvbl1cIj09dHx8dHlwZW9mIG4ubWVzc2FnZT09XCJzdHJpbmdcIiYmdHlwZW9mIG4ubmFtZT09XCJzdHJpbmdcIiYmIXd1KG4pfWZ1bmN0aW9uIGd1KG4pe3JldHVybiEhYnUobikmJihuPXp0KG4pLFwiW29iamVjdCBGdW5jdGlvbl1cIj09bnx8XCJbb2JqZWN0IEdlbmVyYXRvckZ1bmN0aW9uXVwiPT1ufHxcIltvYmplY3QgQXN5bmNGdW5jdGlvbl1cIj09bnx8XCJbb2JqZWN0IFByb3h5XVwiPT1uKX1mdW5jdGlvbiBkdShuKXtyZXR1cm4gdHlwZW9mIG49PVwibnVtYmVyXCImJm49PU91KG4pfWZ1bmN0aW9uIHl1KG4pe3JldHVybiB0eXBlb2Ygbj09XCJudW1iZXJcIiYmLTE8biYmMD09biUxJiY5MDA3MTk5MjU0NzQwOTkxPj1ufWZ1bmN0aW9uIGJ1KG4pe3ZhciB0PXR5cGVvZiBuO3JldHVybiBudWxsIT1uJiYoXCJvYmplY3RcIj09dHx8XCJmdW5jdGlvblwiPT10KTtcbn1mdW5jdGlvbiB4dShuKXtyZXR1cm4gbnVsbCE9biYmdHlwZW9mIG49PVwib2JqZWN0XCJ9ZnVuY3Rpb24ganUobil7cmV0dXJuIHR5cGVvZiBuPT1cIm51bWJlclwifHx4dShuKSYmXCJbb2JqZWN0IE51bWJlcl1cIj09enQobil9ZnVuY3Rpb24gd3Uobil7cmV0dXJuISgheHUobil8fFwiW29iamVjdCBPYmplY3RdXCIhPXp0KG4pKSYmKG49YmkobiksbnVsbD09PW58fChuPWNpLmNhbGwobixcImNvbnN0cnVjdG9yXCIpJiZuLmNvbnN0cnVjdG9yLHR5cGVvZiBuPT1cImZ1bmN0aW9uXCImJm4gaW5zdGFuY2VvZiBuJiZmaS5jYWxsKG4pPT1oaSkpfWZ1bmN0aW9uIG11KG4pe3JldHVybiB0eXBlb2Ygbj09XCJzdHJpbmdcInx8IWFmKG4pJiZ4dShuKSYmXCJbb2JqZWN0IFN0cmluZ11cIj09enQobil9ZnVuY3Rpb24gQXUobil7cmV0dXJuIHR5cGVvZiBuPT1cInN5bWJvbFwifHx4dShuKSYmXCJbb2JqZWN0IFN5bWJvbF1cIj09enQobil9ZnVuY3Rpb24ga3Uobil7aWYoIW4pcmV0dXJuW107aWYocHUobikpcmV0dXJuIG11KG4pPyQobik6TXIobik7XG5pZihBaSYmbltBaV0pe249bltBaV0oKTtmb3IodmFyIHQscj1bXTshKHQ9bi5uZXh0KCkpLmRvbmU7KXIucHVzaCh0LnZhbHVlKTtyZXR1cm4gcn1yZXR1cm4gdD15byhuKSwoXCJbb2JqZWN0IE1hcF1cIj09dD9MOlwiW29iamVjdCBTZXRdXCI9PXQ/RDpEdSkobil9ZnVuY3Rpb24gRXUobil7cmV0dXJuIG4/KG49SXUobiksbj09PU58fG49PT0tTj8xLjc5NzY5MzEzNDg2MjMxNTdlMzA4KigwPm4/LTE6MSk6bj09PW4/bjowKTowPT09bj9uOjB9ZnVuY3Rpb24gT3Uobil7bj1FdShuKTt2YXIgdD1uJTE7cmV0dXJuIG49PT1uP3Q/bi10Om46MH1mdW5jdGlvbiBTdShuKXtyZXR1cm4gbj9ndChPdShuKSwwLDQyOTQ5NjcyOTUpOjB9ZnVuY3Rpb24gSXUobil7aWYodHlwZW9mIG49PVwibnVtYmVyXCIpcmV0dXJuIG47aWYoQXUobikpcmV0dXJuIFA7aWYoYnUobikmJihuPXR5cGVvZiBuLnZhbHVlT2Y9PVwiZnVuY3Rpb25cIj9uLnZhbHVlT2YoKTpuLG49YnUobik/bitcIlwiOm4pLHR5cGVvZiBuIT1cInN0cmluZ1wiKXJldHVybiAwPT09bj9uOituO1xubj1uLnJlcGxhY2UoY24sXCJcIik7dmFyIHQ9Ym4udGVzdChuKTtyZXR1cm4gdHx8am4udGVzdChuKT9GbihuLnNsaWNlKDIpLHQ/Mjo4KTp5bi50ZXN0KG4pP1A6K259ZnVuY3Rpb24gUnUobil7cmV0dXJuIFRyKG4sVXUobikpfWZ1bmN0aW9uIHp1KG4pe3JldHVybiBudWxsPT1uP1wiXCI6anIobil9ZnVuY3Rpb24gV3Uobix0LHIpe3JldHVybiBuPW51bGw9PW4/RjpJdChuLHQpLG49PT1GP3I6bn1mdW5jdGlvbiBCdShuLHQpe3JldHVybiBudWxsIT1uJiZrZShuLHQsTHQpfWZ1bmN0aW9uIEx1KG4pe3JldHVybiBwdShuKT9HbihuKTpIdChuKX1mdW5jdGlvbiBVdShuKXtpZihwdShuKSluPUduKG4sdHJ1ZSk7ZWxzZSBpZihidShuKSl7dmFyIHQscj1MZShuKSxlPVtdO2Zvcih0IGluIG4pKFwiY29uc3RydWN0b3JcIiE9dHx8IXImJmNpLmNhbGwobix0KSkmJmUucHVzaCh0KTtuPWV9ZWxzZXtpZih0PVtdLG51bGwhPW4pZm9yKHIgaW4gbmkobikpdC5wdXNoKHIpO249dH1yZXR1cm4gbn1mdW5jdGlvbiBDdShuLHQpe1xuaWYobnVsbD09bilyZXR1cm57fTt2YXIgcj1sKHllKG4pLGZ1bmN0aW9uKG4pe3JldHVybltuXX0pO3JldHVybiB0PWplKHQpLHVyKG4scixmdW5jdGlvbihuLHIpe3JldHVybiB0KG4sclswXSl9KX1mdW5jdGlvbiBEdShuKXtyZXR1cm4gbnVsbD09bj9bXTpJKG4sTHUobikpfWZ1bmN0aW9uIE11KG4pe3JldHVybiBOZih6dShuKS50b0xvd2VyQ2FzZSgpKX1mdW5jdGlvbiBUdShuKXtyZXR1cm4obj16dShuKSkmJm4ucmVwbGFjZShtbixydCkucmVwbGFjZShSbixcIlwiKX1mdW5jdGlvbiAkdShuLHQscil7cmV0dXJuIG49enUobiksdD1yP0Y6dCx0PT09Rj9Mbi50ZXN0KG4pP24ubWF0Y2goV24pfHxbXTpuLm1hdGNoKF9uKXx8W106bi5tYXRjaCh0KXx8W119ZnVuY3Rpb24gRnUobil7cmV0dXJuIGZ1bmN0aW9uKCl7cmV0dXJuIG59fWZ1bmN0aW9uIE51KG4pe3JldHVybiBufWZ1bmN0aW9uIFB1KG4pe3JldHVybiBHdCh0eXBlb2Ygbj09XCJmdW5jdGlvblwiP246ZHQobiwxKSl9ZnVuY3Rpb24gWnUobix0LHIpe1xudmFyIGU9THUodCksaT1TdCh0LGUpO251bGwhPXJ8fGJ1KHQpJiYoaS5sZW5ndGh8fCFlLmxlbmd0aCl8fChyPXQsdD1uLG49dGhpcyxpPVN0KHQsTHUodCkpKTt2YXIgbz0hKGJ1KHIpJiZcImNoYWluXCJpbiByJiYhci5jaGFpbiksZj1ndShuKTtyZXR1cm4gdShpLGZ1bmN0aW9uKHIpe3ZhciBlPXRbcl07bltyXT1lLGYmJihuLnByb3RvdHlwZVtyXT1mdW5jdGlvbigpe3ZhciB0PXRoaXMuX19jaGFpbl9fO2lmKG98fHQpe3ZhciByPW4odGhpcy5fX3dyYXBwZWRfXyk7cmV0dXJuKHIuX19hY3Rpb25zX189TXIodGhpcy5fX2FjdGlvbnNfXykpLnB1c2goe2Z1bmM6ZSxhcmdzOmFyZ3VtZW50cyx0aGlzQXJnOm59KSxyLl9fY2hhaW5fXz10LHJ9cmV0dXJuIGUuYXBwbHkobixzKFt0aGlzLnZhbHVlKCldLGFyZ3VtZW50cykpfSl9KSxufWZ1bmN0aW9uIHF1KCl7fWZ1bmN0aW9uIFZ1KG4pe3JldHVybiBXZShuKT9qKCRlKG4pKTppcihuKX1mdW5jdGlvbiBLdSgpe3JldHVybltdfWZ1bmN0aW9uIEd1KCl7XG5yZXR1cm4gZmFsc2V9RW49bnVsbD09RW4/Wm46aXQuZGVmYXVsdHMoWm4uT2JqZWN0KCksRW4saXQucGljayhabixVbikpO3ZhciBIdT1Fbi5BcnJheSxKdT1Fbi5EYXRlLFl1PUVuLkVycm9yLFF1PUVuLkZ1bmN0aW9uLFh1PUVuLk1hdGgsbmk9RW4uT2JqZWN0LHRpPUVuLlJlZ0V4cCxyaT1Fbi5TdHJpbmcsZWk9RW4uVHlwZUVycm9yLHVpPUh1LnByb3RvdHlwZSxpaT1uaS5wcm90b3R5cGUsb2k9RW5bXCJfX2NvcmUtanNfc2hhcmVkX19cIl0sZmk9UXUucHJvdG90eXBlLnRvU3RyaW5nLGNpPWlpLmhhc093blByb3BlcnR5LGFpPTAsbGk9ZnVuY3Rpb24oKXt2YXIgbj0vW14uXSskLy5leGVjKG9pJiZvaS5rZXlzJiZvaS5rZXlzLklFX1BST1RPfHxcIlwiKTtyZXR1cm4gbj9cIlN5bWJvbChzcmMpXzEuXCIrbjpcIlwifSgpLHNpPWlpLnRvU3RyaW5nLGhpPWZpLmNhbGwobmkpLHBpPVpuLl8sX2k9dGkoXCJeXCIrZmkuY2FsbChjaSkucmVwbGFjZShvbixcIlxcXFwkJlwiKS5yZXBsYWNlKC9oYXNPd25Qcm9wZXJ0eXwoZnVuY3Rpb24pLio/KD89XFxcXFxcKCl8IGZvciAuKz8oPz1cXFxcXFxdKS9nLFwiJDEuKj9cIikrXCIkXCIpLHZpPUtuP0VuLkJ1ZmZlcjpGLGdpPUVuLlN5bWJvbCxkaT1Fbi5VaW50OEFycmF5LHlpPXZpP3ZpLmY6RixiaT1VKG5pLmdldFByb3RvdHlwZU9mLG5pKSx4aT1uaS5jcmVhdGUsamk9aWkucHJvcGVydHlJc0VudW1lcmFibGUsd2k9dWkuc3BsaWNlLG1pPWdpP2dpLmlzQ29uY2F0U3ByZWFkYWJsZTpGLEFpPWdpP2dpLml0ZXJhdG9yOkYsa2k9Z2k/Z2kudG9TdHJpbmdUYWc6RixFaT1mdW5jdGlvbigpe1xudHJ5e3ZhciBuPUFlKG5pLFwiZGVmaW5lUHJvcGVydHlcIik7cmV0dXJuIG4oe30sXCJcIix7fSksbn1jYXRjaChuKXt9fSgpLE9pPUVuLmNsZWFyVGltZW91dCE9PVpuLmNsZWFyVGltZW91dCYmRW4uY2xlYXJUaW1lb3V0LFNpPUp1JiZKdS5ub3chPT1abi5EYXRlLm5vdyYmSnUubm93LElpPUVuLnNldFRpbWVvdXQhPT1abi5zZXRUaW1lb3V0JiZFbi5zZXRUaW1lb3V0LFJpPVh1LmNlaWwsemk9WHUuZmxvb3IsV2k9bmkuZ2V0T3duUHJvcGVydHlTeW1ib2xzLEJpPXZpP3ZpLmlzQnVmZmVyOkYsTGk9RW4uaXNGaW5pdGUsVWk9dWkuam9pbixDaT1VKG5pLmtleXMsbmkpLERpPVh1Lm1heCxNaT1YdS5taW4sVGk9SnUubm93LCRpPUVuLnBhcnNlSW50LEZpPVh1LnJhbmRvbSxOaT11aS5yZXZlcnNlLFBpPUFlKEVuLFwiRGF0YVZpZXdcIiksWmk9QWUoRW4sXCJNYXBcIikscWk9QWUoRW4sXCJQcm9taXNlXCIpLFZpPUFlKEVuLFwiU2V0XCIpLEtpPUFlKEVuLFwiV2Vha01hcFwiKSxHaT1BZShuaSxcImNyZWF0ZVwiKSxIaT1LaSYmbmV3IEtpLEppPXt9LFlpPUZlKFBpKSxRaT1GZShaaSksWGk9RmUocWkpLG5vPUZlKFZpKSx0bz1GZShLaSkscm89Z2k/Z2kucHJvdG90eXBlOkYsZW89cm8/cm8udmFsdWVPZjpGLHVvPXJvP3JvLnRvU3RyaW5nOkYsaW89ZnVuY3Rpb24oKXtcbmZ1bmN0aW9uIG4oKXt9cmV0dXJuIGZ1bmN0aW9uKHQpe3JldHVybiBidSh0KT94aT94aSh0KToobi5wcm90b3R5cGU9dCx0PW5ldyBuLG4ucHJvdG90eXBlPUYsdCk6e319fSgpO09uLnRlbXBsYXRlU2V0dGluZ3M9e2VzY2FwZTpRLGV2YWx1YXRlOlgsaW50ZXJwb2xhdGU6bm4sdmFyaWFibGU6XCJcIixpbXBvcnRzOntfOk9ufX0sT24ucHJvdG90eXBlPVNuLnByb3RvdHlwZSxPbi5wcm90b3R5cGUuY29uc3RydWN0b3I9T24sem4ucHJvdG90eXBlPWlvKFNuLnByb3RvdHlwZSksem4ucHJvdG90eXBlLmNvbnN0cnVjdG9yPXpuLE1uLnByb3RvdHlwZT1pbyhTbi5wcm90b3R5cGUpLE1uLnByb3RvdHlwZS5jb25zdHJ1Y3Rvcj1NbixUbi5wcm90b3R5cGUuY2xlYXI9ZnVuY3Rpb24oKXt0aGlzLl9fZGF0YV9fPUdpP0dpKG51bGwpOnt9LHRoaXMuc2l6ZT0wfSxUbi5wcm90b3R5cGUuZGVsZXRlPWZ1bmN0aW9uKG4pe3JldHVybiBuPXRoaXMuaGFzKG4pJiZkZWxldGUgdGhpcy5fX2RhdGFfX1tuXSxcbnRoaXMuc2l6ZS09bj8xOjAsbn0sVG4ucHJvdG90eXBlLmdldD1mdW5jdGlvbihuKXt2YXIgdD10aGlzLl9fZGF0YV9fO3JldHVybiBHaT8obj10W25dLFwiX19sb2Rhc2hfaGFzaF91bmRlZmluZWRfX1wiPT09bj9GOm4pOmNpLmNhbGwodCxuKT90W25dOkZ9LFRuLnByb3RvdHlwZS5oYXM9ZnVuY3Rpb24obil7dmFyIHQ9dGhpcy5fX2RhdGFfXztyZXR1cm4gR2k/dFtuXSE9PUY6Y2kuY2FsbCh0LG4pfSxUbi5wcm90b3R5cGUuc2V0PWZ1bmN0aW9uKG4sdCl7dmFyIHI9dGhpcy5fX2RhdGFfXztyZXR1cm4gdGhpcy5zaXplKz10aGlzLmhhcyhuKT8wOjEscltuXT1HaSYmdD09PUY/XCJfX2xvZGFzaF9oYXNoX3VuZGVmaW5lZF9fXCI6dCx0aGlzfSxObi5wcm90b3R5cGUuY2xlYXI9ZnVuY3Rpb24oKXt0aGlzLl9fZGF0YV9fPVtdLHRoaXMuc2l6ZT0wfSxObi5wcm90b3R5cGUuZGVsZXRlPWZ1bmN0aW9uKG4pe3ZhciB0PXRoaXMuX19kYXRhX187cmV0dXJuIG49bHQodCxuKSwhKDA+bikmJihuPT10Lmxlbmd0aC0xP3QucG9wKCk6d2kuY2FsbCh0LG4sMSksXG4tLXRoaXMuc2l6ZSx0cnVlKX0sTm4ucHJvdG90eXBlLmdldD1mdW5jdGlvbihuKXt2YXIgdD10aGlzLl9fZGF0YV9fO3JldHVybiBuPWx0KHQsbiksMD5uP0Y6dFtuXVsxXX0sTm4ucHJvdG90eXBlLmhhcz1mdW5jdGlvbihuKXtyZXR1cm4tMTxsdCh0aGlzLl9fZGF0YV9fLG4pfSxObi5wcm90b3R5cGUuc2V0PWZ1bmN0aW9uKG4sdCl7dmFyIHI9dGhpcy5fX2RhdGFfXyxlPWx0KHIsbik7cmV0dXJuIDA+ZT8oKyt0aGlzLnNpemUsci5wdXNoKFtuLHRdKSk6cltlXVsxXT10LHRoaXN9LFBuLnByb3RvdHlwZS5jbGVhcj1mdW5jdGlvbigpe3RoaXMuc2l6ZT0wLHRoaXMuX19kYXRhX189e2hhc2g6bmV3IFRuLG1hcDpuZXcoWml8fE5uKSxzdHJpbmc6bmV3IFRufX0sUG4ucHJvdG90eXBlLmRlbGV0ZT1mdW5jdGlvbihuKXtyZXR1cm4gbj13ZSh0aGlzLG4pLmRlbGV0ZShuKSx0aGlzLnNpemUtPW4/MTowLG59LFBuLnByb3RvdHlwZS5nZXQ9ZnVuY3Rpb24obil7cmV0dXJuIHdlKHRoaXMsbikuZ2V0KG4pO1xufSxQbi5wcm90b3R5cGUuaGFzPWZ1bmN0aW9uKG4pe3JldHVybiB3ZSh0aGlzLG4pLmhhcyhuKX0sUG4ucHJvdG90eXBlLnNldD1mdW5jdGlvbihuLHQpe3ZhciByPXdlKHRoaXMsbiksZT1yLnNpemU7cmV0dXJuIHIuc2V0KG4sdCksdGhpcy5zaXplKz1yLnNpemU9PWU/MDoxLHRoaXN9LHFuLnByb3RvdHlwZS5hZGQ9cW4ucHJvdG90eXBlLnB1c2g9ZnVuY3Rpb24obil7cmV0dXJuIHRoaXMuX19kYXRhX18uc2V0KG4sXCJfX2xvZGFzaF9oYXNoX3VuZGVmaW5lZF9fXCIpLHRoaXN9LHFuLnByb3RvdHlwZS5oYXM9ZnVuY3Rpb24obil7cmV0dXJuIHRoaXMuX19kYXRhX18uaGFzKG4pfSxWbi5wcm90b3R5cGUuY2xlYXI9ZnVuY3Rpb24oKXt0aGlzLl9fZGF0YV9fPW5ldyBObix0aGlzLnNpemU9MH0sVm4ucHJvdG90eXBlLmRlbGV0ZT1mdW5jdGlvbihuKXt2YXIgdD10aGlzLl9fZGF0YV9fO3JldHVybiBuPXQuZGVsZXRlKG4pLHRoaXMuc2l6ZT10LnNpemUsbn0sVm4ucHJvdG90eXBlLmdldD1mdW5jdGlvbihuKXtcbnJldHVybiB0aGlzLl9fZGF0YV9fLmdldChuKX0sVm4ucHJvdG90eXBlLmhhcz1mdW5jdGlvbihuKXtyZXR1cm4gdGhpcy5fX2RhdGFfXy5oYXMobil9LFZuLnByb3RvdHlwZS5zZXQ9ZnVuY3Rpb24obix0KXt2YXIgcj10aGlzLl9fZGF0YV9fO2lmKHIgaW5zdGFuY2VvZiBObil7dmFyIGU9ci5fX2RhdGFfXztpZighWml8fDE5OT5lLmxlbmd0aClyZXR1cm4gZS5wdXNoKFtuLHRdKSx0aGlzLnNpemU9KytyLnNpemUsdGhpcztyPXRoaXMuX19kYXRhX189bmV3IFBuKGUpfXJldHVybiByLnNldChuLHQpLHRoaXMuc2l6ZT1yLnNpemUsdGhpc307dmFyIG9vPVpyKEV0KSxmbz1acihPdCx0cnVlKSxjbz1xcigpLGFvPXFyKHRydWUpLGxvPUhpP2Z1bmN0aW9uKG4sdCl7cmV0dXJuIEhpLnNldChuLHQpLG59Ok51LHNvPUVpP2Z1bmN0aW9uKG4sdCl7cmV0dXJuIEVpKG4sXCJ0b1N0cmluZ1wiLHtjb25maWd1cmFibGU6dHJ1ZSxlbnVtZXJhYmxlOmZhbHNlLHZhbHVlOkZ1KHQpLHdyaXRhYmxlOnRydWV9KX06TnUsaG89T2l8fGZ1bmN0aW9uKG4pe1xucmV0dXJuIFpuLmNsZWFyVGltZW91dChuKX0scG89VmkmJjEvRChuZXcgVmkoWywtMF0pKVsxXT09Tj9mdW5jdGlvbihuKXtyZXR1cm4gbmV3IFZpKG4pfTpxdSxfbz1IaT9mdW5jdGlvbihuKXtyZXR1cm4gSGkuZ2V0KG4pfTpxdSx2bz1XaT9mdW5jdGlvbihuKXtyZXR1cm4gbnVsbD09bj9bXToobj1uaShuKSxmKFdpKG4pLGZ1bmN0aW9uKHQpe3JldHVybiBqaS5jYWxsKG4sdCl9KSl9Okt1LGdvPVdpP2Z1bmN0aW9uKG4pe2Zvcih2YXIgdD1bXTtuOylzKHQsdm8obikpLG49Ymkobik7cmV0dXJuIHR9Okt1LHlvPXp0OyhQaSYmXCJbb2JqZWN0IERhdGFWaWV3XVwiIT15byhuZXcgUGkobmV3IEFycmF5QnVmZmVyKDEpKSl8fFppJiZcIltvYmplY3QgTWFwXVwiIT15byhuZXcgWmkpfHxxaSYmXCJbb2JqZWN0IFByb21pc2VdXCIhPXlvKHFpLnJlc29sdmUoKSl8fFZpJiZcIltvYmplY3QgU2V0XVwiIT15byhuZXcgVmkpfHxLaSYmXCJbb2JqZWN0IFdlYWtNYXBdXCIhPXlvKG5ldyBLaSkpJiYoeW89ZnVuY3Rpb24obil7XG52YXIgdD16dChuKTtpZihuPShuPVwiW29iamVjdCBPYmplY3RdXCI9PXQ/bi5jb25zdHJ1Y3RvcjpGKT9GZShuKTpcIlwiKXN3aXRjaChuKXtjYXNlIFlpOnJldHVyblwiW29iamVjdCBEYXRhVmlld11cIjtjYXNlIFFpOnJldHVyblwiW29iamVjdCBNYXBdXCI7Y2FzZSBYaTpyZXR1cm5cIltvYmplY3QgUHJvbWlzZV1cIjtjYXNlIG5vOnJldHVyblwiW29iamVjdCBTZXRdXCI7Y2FzZSB0bzpyZXR1cm5cIltvYmplY3QgV2Vha01hcF1cIn1yZXR1cm4gdH0pO3ZhciBibz1vaT9ndTpHdSx4bz1NZShsbyksam89SWl8fGZ1bmN0aW9uKG4sdCl7cmV0dXJuIFpuLnNldFRpbWVvdXQobix0KX0sd289TWUoc28pLG1vPWZ1bmN0aW9uKG4pe249bHUobixmdW5jdGlvbihuKXtyZXR1cm4gNTAwPT09dC5zaXplJiZ0LmNsZWFyKCksbn0pO3ZhciB0PW4uY2FjaGU7cmV0dXJuIG59KGZ1bmN0aW9uKG4pe3ZhciB0PVtdO3JldHVybiBlbi50ZXN0KG4pJiZ0LnB1c2goXCJcIiksbi5yZXBsYWNlKHVuLGZ1bmN0aW9uKG4scixlLHUpe1xudC5wdXNoKGU/dS5yZXBsYWNlKHZuLFwiJDFcIik6cnx8bil9KSx0fSksQW89bHIoZnVuY3Rpb24obix0KXtyZXR1cm4gX3Uobik/anQobixrdCh0LDEsX3UsdHJ1ZSkpOltdfSksa289bHIoZnVuY3Rpb24obix0KXt2YXIgcj1HZSh0KTtyZXR1cm4gX3UocikmJihyPUYpLF91KG4pP2p0KG4sa3QodCwxLF91LHRydWUpLGplKHIsMikpOltdfSksRW89bHIoZnVuY3Rpb24obix0KXt2YXIgcj1HZSh0KTtyZXR1cm4gX3UocikmJihyPUYpLF91KG4pP2p0KG4sa3QodCwxLF91LHRydWUpLEYscik6W119KSxPbz1scihmdW5jdGlvbihuKXt2YXIgdD1sKG4sU3IpO3JldHVybiB0Lmxlbmd0aCYmdFswXT09PW5bMF0/VXQodCk6W119KSxTbz1scihmdW5jdGlvbihuKXt2YXIgdD1HZShuKSxyPWwobixTcik7cmV0dXJuIHQ9PT1HZShyKT90PUY6ci5wb3AoKSxyLmxlbmd0aCYmclswXT09PW5bMF0/VXQocixqZSh0LDIpKTpbXX0pLElvPWxyKGZ1bmN0aW9uKG4pe3ZhciB0PUdlKG4pLHI9bChuLFNyKTtyZXR1cm4odD10eXBlb2YgdD09XCJmdW5jdGlvblwiP3Q6RikmJnIucG9wKCksXG5yLmxlbmd0aCYmclswXT09PW5bMF0/VXQocixGLHQpOltdfSksUm89bHIoSGUpLHpvPWdlKGZ1bmN0aW9uKG4sdCl7dmFyIHI9bnVsbD09bj8wOm4ubGVuZ3RoLGU9dnQobix0KTtyZXR1cm4gZnIobixsKHQsZnVuY3Rpb24obil7cmV0dXJuIFJlKG4scik/K246bn0pLnNvcnQoVXIpKSxlfSksV289bHIoZnVuY3Rpb24obil7cmV0dXJuIHdyKGt0KG4sMSxfdSx0cnVlKSl9KSxCbz1scihmdW5jdGlvbihuKXt2YXIgdD1HZShuKTtyZXR1cm4gX3UodCkmJih0PUYpLHdyKGt0KG4sMSxfdSx0cnVlKSxqZSh0LDIpKX0pLExvPWxyKGZ1bmN0aW9uKG4pe3ZhciB0PUdlKG4pLHQ9dHlwZW9mIHQ9PVwiZnVuY3Rpb25cIj90OkY7cmV0dXJuIHdyKGt0KG4sMSxfdSx0cnVlKSxGLHQpfSksVW89bHIoZnVuY3Rpb24obix0KXtyZXR1cm4gX3Uobik/anQobix0KTpbXX0pLENvPWxyKGZ1bmN0aW9uKG4pe3JldHVybiBFcihmKG4sX3UpKX0pLERvPWxyKGZ1bmN0aW9uKG4pe3ZhciB0PUdlKG4pO3JldHVybiBfdSh0KSYmKHQ9RiksXG5FcihmKG4sX3UpLGplKHQsMikpfSksTW89bHIoZnVuY3Rpb24obil7dmFyIHQ9R2UobiksdD10eXBlb2YgdD09XCJmdW5jdGlvblwiP3Q6RjtyZXR1cm4gRXIoZihuLF91KSxGLHQpfSksVG89bHIoWWUpLCRvPWxyKGZ1bmN0aW9uKG4pe3ZhciB0PW4ubGVuZ3RoLHQ9MTx0P25bdC0xXTpGLHQ9dHlwZW9mIHQ9PVwiZnVuY3Rpb25cIj8obi5wb3AoKSx0KTpGO3JldHVybiBRZShuLHQpfSksRm89Z2UoZnVuY3Rpb24obil7ZnVuY3Rpb24gdCh0KXtyZXR1cm4gdnQodCxuKX12YXIgcj1uLmxlbmd0aCxlPXI/blswXTowLHU9dGhpcy5fX3dyYXBwZWRfXztyZXR1cm4hKDE8cnx8dGhpcy5fX2FjdGlvbnNfXy5sZW5ndGgpJiZ1IGluc3RhbmNlb2YgTW4mJlJlKGUpPyh1PXUuc2xpY2UoZSwrZSsocj8xOjApKSx1Ll9fYWN0aW9uc19fLnB1c2goe2Z1bmM6bnUsYXJnczpbdF0sdGhpc0FyZzpGfSksbmV3IHpuKHUsdGhpcy5fX2NoYWluX18pLnRocnUoZnVuY3Rpb24obil7cmV0dXJuIHImJiFuLmxlbmd0aCYmbi5wdXNoKEYpLFxubn0pKTp0aGlzLnRocnUodCl9KSxObz1OcihmdW5jdGlvbihuLHQscil7Y2kuY2FsbChuLHIpPysrbltyXTpfdChuLHIsMSl9KSxQbz1ZcihaZSksWm89WXIocWUpLHFvPU5yKGZ1bmN0aW9uKG4sdCxyKXtjaS5jYWxsKG4scik/bltyXS5wdXNoKHQpOl90KG4scixbdF0pfSksVm89bHIoZnVuY3Rpb24obix0LGUpe3ZhciB1PS0xLGk9dHlwZW9mIHQ9PVwiZnVuY3Rpb25cIixvPXB1KG4pP0h1KG4ubGVuZ3RoKTpbXTtyZXR1cm4gb28obixmdW5jdGlvbihuKXtvWysrdV09aT9yKHQsbixlKTpEdChuLHQsZSl9KSxvfSksS289TnIoZnVuY3Rpb24obix0LHIpe190KG4scix0KX0pLEdvPU5yKGZ1bmN0aW9uKG4sdCxyKXtuW3I/MDoxXS5wdXNoKHQpfSxmdW5jdGlvbigpe3JldHVybltbXSxbXV19KSxIbz1scihmdW5jdGlvbihuLHQpe2lmKG51bGw9PW4pcmV0dXJuW107dmFyIHI9dC5sZW5ndGg7cmV0dXJuIDE8ciYmemUobix0WzBdLHRbMV0pP3Q9W106MjxyJiZ6ZSh0WzBdLHRbMV0sdFsyXSkmJih0PVt0WzBdXSksXG5ycihuLGt0KHQsMSksW10pfSksSm89U2l8fGZ1bmN0aW9uKCl7cmV0dXJuIFpuLkRhdGUubm93KCl9LFlvPWxyKGZ1bmN0aW9uKG4sdCxyKXt2YXIgZT0xO2lmKHIubGVuZ3RoKXZhciB1PUMocix4ZShZbykpLGU9MzJ8ZTtyZXR1cm4gbGUobixlLHQscix1KX0pLFFvPWxyKGZ1bmN0aW9uKG4sdCxyKXt2YXIgZT0zO2lmKHIubGVuZ3RoKXZhciB1PUMocix4ZShRbykpLGU9MzJ8ZTtyZXR1cm4gbGUodCxlLG4scix1KX0pLFhvPWxyKGZ1bmN0aW9uKG4sdCl7cmV0dXJuIHh0KG4sMSx0KX0pLG5mPWxyKGZ1bmN0aW9uKG4sdCxyKXtyZXR1cm4geHQobixJdSh0KXx8MCxyKX0pO2x1LkNhY2hlPVBuO3ZhciB0Zj1scihmdW5jdGlvbihuLHQpe3Q9MT09dC5sZW5ndGgmJmFmKHRbMF0pP2wodFswXSxTKGplKCkpKTpsKGt0KHQsMSksUyhqZSgpKSk7dmFyIGU9dC5sZW5ndGg7cmV0dXJuIGxyKGZ1bmN0aW9uKHUpe2Zvcih2YXIgaT0tMSxvPU1pKHUubGVuZ3RoLGUpOysraTxvOyl1W2ldPXRbaV0uY2FsbCh0aGlzLHVbaV0pO1xucmV0dXJuIHIobix0aGlzLHUpfSl9KSxyZj1scihmdW5jdGlvbihuLHQpe3JldHVybiBsZShuLDMyLEYsdCxDKHQseGUocmYpKSl9KSxlZj1scihmdW5jdGlvbihuLHQpe3JldHVybiBsZShuLDY0LEYsdCxDKHQseGUoZWYpKSl9KSx1Zj1nZShmdW5jdGlvbihuLHQpe3JldHVybiBsZShuLDI1NixGLEYsRix0KX0pLG9mPW9lKFd0KSxmZj1vZShmdW5jdGlvbihuLHQpe3JldHVybiBuPj10fSksY2Y9TXQoZnVuY3Rpb24oKXtyZXR1cm4gYXJndW1lbnRzfSgpKT9NdDpmdW5jdGlvbihuKXtyZXR1cm4geHUobikmJmNpLmNhbGwobixcImNhbGxlZVwiKSYmIWppLmNhbGwobixcImNhbGxlZVwiKX0sYWY9SHUuaXNBcnJheSxsZj1Ibj9TKEhuKTpUdCxzZj1CaXx8R3UsaGY9Sm4/UyhKbik6JHQscGY9WW4/UyhZbik6TnQsX2Y9UW4/UyhRbik6cXQsdmY9WG4/UyhYbik6VnQsZ2Y9bnQ/UyhudCk6S3QsZGY9b2UoSnQpLHlmPW9lKGZ1bmN0aW9uKG4sdCl7cmV0dXJuIG48PXR9KSxiZj1QcihmdW5jdGlvbihuLHQpe1xuaWYoTGUodCl8fHB1KHQpKVRyKHQsTHUodCksbik7ZWxzZSBmb3IodmFyIHIgaW4gdCljaS5jYWxsKHQscikmJmF0KG4scix0W3JdKX0pLHhmPVByKGZ1bmN0aW9uKG4sdCl7VHIodCxVdSh0KSxuKX0pLGpmPVByKGZ1bmN0aW9uKG4sdCxyLGUpe1RyKHQsVXUodCksbixlKX0pLHdmPVByKGZ1bmN0aW9uKG4sdCxyLGUpe1RyKHQsTHUodCksbixlKX0pLG1mPWdlKHZ0KSxBZj1scihmdW5jdGlvbihuKXtyZXR1cm4gbi5wdXNoKEYsc2UpLHIoamYsRixuKX0pLGtmPWxyKGZ1bmN0aW9uKG4pe3JldHVybiBuLnB1c2goRixoZSkscihSZixGLG4pfSksRWY9bmUoZnVuY3Rpb24obix0LHIpe25bdF09cn0sRnUoTnUpKSxPZj1uZShmdW5jdGlvbihuLHQscil7Y2kuY2FsbChuLHQpP25bdF0ucHVzaChyKTpuW3RdPVtyXX0samUpLFNmPWxyKER0KSxJZj1QcihmdW5jdGlvbihuLHQscil7bnIobix0LHIpfSksUmY9UHIoZnVuY3Rpb24obix0LHIsZSl7bnIobix0LHIsZSl9KSx6Zj1nZShmdW5jdGlvbihuLHQpe1xudmFyIHI9e307aWYobnVsbD09bilyZXR1cm4gcjt2YXIgZT1mYWxzZTt0PWwodCxmdW5jdGlvbih0KXtyZXR1cm4gdD1Scih0LG4pLGV8fChlPTE8dC5sZW5ndGgpLHR9KSxUcihuLHllKG4pLHIpLGUmJihyPWR0KHIsNyxwZSkpO2Zvcih2YXIgdT10Lmxlbmd0aDt1LS07KW1yKHIsdFt1XSk7cmV0dXJuIHJ9KSxXZj1nZShmdW5jdGlvbihuLHQpe3JldHVybiBudWxsPT1uP3t9OmVyKG4sdCl9KSxCZj1hZShMdSksTGY9YWUoVXUpLFVmPUdyKGZ1bmN0aW9uKG4sdCxyKXtyZXR1cm4gdD10LnRvTG93ZXJDYXNlKCksbisocj9NdSh0KTp0KX0pLENmPUdyKGZ1bmN0aW9uKG4sdCxyKXtyZXR1cm4gbisocj9cIi1cIjpcIlwiKSt0LnRvTG93ZXJDYXNlKCl9KSxEZj1HcihmdW5jdGlvbihuLHQscil7cmV0dXJuIG4rKHI/XCIgXCI6XCJcIikrdC50b0xvd2VyQ2FzZSgpfSksTWY9S3IoXCJ0b0xvd2VyQ2FzZVwiKSxUZj1HcihmdW5jdGlvbihuLHQscil7cmV0dXJuIG4rKHI/XCJfXCI6XCJcIikrdC50b0xvd2VyQ2FzZSgpO1xufSksJGY9R3IoZnVuY3Rpb24obix0LHIpe3JldHVybiBuKyhyP1wiIFwiOlwiXCIpK05mKHQpfSksRmY9R3IoZnVuY3Rpb24obix0LHIpe3JldHVybiBuKyhyP1wiIFwiOlwiXCIpK3QudG9VcHBlckNhc2UoKX0pLE5mPUtyKFwidG9VcHBlckNhc2VcIiksUGY9bHIoZnVuY3Rpb24obix0KXt0cnl7cmV0dXJuIHIobixGLHQpfWNhdGNoKG4pe3JldHVybiB2dShuKT9uOm5ldyBZdShuKX19KSxaZj1nZShmdW5jdGlvbihuLHQpe3JldHVybiB1KHQsZnVuY3Rpb24odCl7dD0kZSh0KSxfdChuLHQsWW8oblt0XSxuKSl9KSxufSkscWY9UXIoKSxWZj1Rcih0cnVlKSxLZj1scihmdW5jdGlvbihuLHQpe3JldHVybiBmdW5jdGlvbihyKXtyZXR1cm4gRHQocixuLHQpfX0pLEdmPWxyKGZ1bmN0aW9uKG4sdCl7cmV0dXJuIGZ1bmN0aW9uKHIpe3JldHVybiBEdChuLHIsdCl9fSksSGY9cmUobCksSmY9cmUobyksWWY9cmUoXyksUWY9aWUoKSxYZj1pZSh0cnVlKSxuYz10ZShmdW5jdGlvbihuLHQpe3JldHVybiBuK3R9LDApLHRjPWNlKFwiY2VpbFwiKSxyYz10ZShmdW5jdGlvbihuLHQpe1xucmV0dXJuIG4vdH0sMSksZWM9Y2UoXCJmbG9vclwiKSx1Yz10ZShmdW5jdGlvbihuLHQpe3JldHVybiBuKnR9LDEpLGljPWNlKFwicm91bmRcIiksb2M9dGUoZnVuY3Rpb24obix0KXtyZXR1cm4gbi10fSwwKTtyZXR1cm4gT24uYWZ0ZXI9ZnVuY3Rpb24obix0KXtpZih0eXBlb2YgdCE9XCJmdW5jdGlvblwiKXRocm93IG5ldyBlaShcIkV4cGVjdGVkIGEgZnVuY3Rpb25cIik7cmV0dXJuIG49T3UobiksZnVuY3Rpb24oKXtpZigxPi0tbilyZXR1cm4gdC5hcHBseSh0aGlzLGFyZ3VtZW50cyl9fSxPbi5hcnk9aXUsT24uYXNzaWduPWJmLE9uLmFzc2lnbkluPXhmLE9uLmFzc2lnbkluV2l0aD1qZixPbi5hc3NpZ25XaXRoPXdmLE9uLmF0PW1mLE9uLmJlZm9yZT1vdSxPbi5iaW5kPVlvLE9uLmJpbmRBbGw9WmYsT24uYmluZEtleT1RbyxPbi5jYXN0QXJyYXk9ZnVuY3Rpb24oKXtpZighYXJndW1lbnRzLmxlbmd0aClyZXR1cm5bXTt2YXIgbj1hcmd1bWVudHNbMF07cmV0dXJuIGFmKG4pP246W25dfSxcbk9uLmNoYWluPVhlLE9uLmNodW5rPWZ1bmN0aW9uKG4sdCxyKXtpZih0PShyP3plKG4sdCxyKTp0PT09Rik/MTpEaShPdSh0KSwwKSxyPW51bGw9PW4/MDpuLmxlbmd0aCwhcnx8MT50KXJldHVybltdO2Zvcih2YXIgZT0wLHU9MCxpPUh1KFJpKHIvdCkpO2U8cjspaVt1KytdPXZyKG4sZSxlKz10KTtyZXR1cm4gaX0sT24uY29tcGFjdD1mdW5jdGlvbihuKXtmb3IodmFyIHQ9LTEscj1udWxsPT1uPzA6bi5sZW5ndGgsZT0wLHU9W107Kyt0PHI7KXt2YXIgaT1uW3RdO2kmJih1W2UrK109aSl9cmV0dXJuIHV9LE9uLmNvbmNhdD1mdW5jdGlvbigpe3ZhciBuPWFyZ3VtZW50cy5sZW5ndGg7aWYoIW4pcmV0dXJuW107Zm9yKHZhciB0PUh1KG4tMSkscj1hcmd1bWVudHNbMF07bi0tOyl0W24tMV09YXJndW1lbnRzW25dO3JldHVybiBzKGFmKHIpP01yKHIpOltyXSxrdCh0LDEpKX0sT24uY29uZD1mdW5jdGlvbihuKXt2YXIgdD1udWxsPT1uPzA6bi5sZW5ndGgsZT1qZSgpO3JldHVybiBuPXQ/bChuLGZ1bmN0aW9uKG4pe1xuaWYoXCJmdW5jdGlvblwiIT10eXBlb2YgblsxXSl0aHJvdyBuZXcgZWkoXCJFeHBlY3RlZCBhIGZ1bmN0aW9uXCIpO3JldHVybltlKG5bMF0pLG5bMV1dfSk6W10sbHIoZnVuY3Rpb24oZSl7Zm9yKHZhciB1PS0xOysrdTx0Oyl7dmFyIGk9blt1XTtpZihyKGlbMF0sdGhpcyxlKSlyZXR1cm4gcihpWzFdLHRoaXMsZSl9fSl9LE9uLmNvbmZvcm1zPWZ1bmN0aW9uKG4pe3JldHVybiB5dChkdChuLDEpKX0sT24uY29uc3RhbnQ9RnUsT24uY291bnRCeT1ObyxPbi5jcmVhdGU9ZnVuY3Rpb24obix0KXt2YXIgcj1pbyhuKTtyZXR1cm4gbnVsbD09dD9yOmh0KHIsdCl9LE9uLmN1cnJ5PWZ1LE9uLmN1cnJ5UmlnaHQ9Y3UsT24uZGVib3VuY2U9YXUsT24uZGVmYXVsdHM9QWYsT24uZGVmYXVsdHNEZWVwPWtmLE9uLmRlZmVyPVhvLE9uLmRlbGF5PW5mLE9uLmRpZmZlcmVuY2U9QW8sT24uZGlmZmVyZW5jZUJ5PWtvLE9uLmRpZmZlcmVuY2VXaXRoPUVvLE9uLmRyb3A9ZnVuY3Rpb24obix0LHIpe3ZhciBlPW51bGw9PW4/MDpuLmxlbmd0aDtcbnJldHVybiBlPyh0PXJ8fHQ9PT1GPzE6T3UodCksdnIobiwwPnQ/MDp0LGUpKTpbXX0sT24uZHJvcFJpZ2h0PWZ1bmN0aW9uKG4sdCxyKXt2YXIgZT1udWxsPT1uPzA6bi5sZW5ndGg7cmV0dXJuIGU/KHQ9cnx8dD09PUY/MTpPdSh0KSx0PWUtdCx2cihuLDAsMD50PzA6dCkpOltdfSxPbi5kcm9wUmlnaHRXaGlsZT1mdW5jdGlvbihuLHQpe3JldHVybiBuJiZuLmxlbmd0aD9BcihuLGplKHQsMyksdHJ1ZSx0cnVlKTpbXX0sT24uZHJvcFdoaWxlPWZ1bmN0aW9uKG4sdCl7cmV0dXJuIG4mJm4ubGVuZ3RoP0FyKG4samUodCwzKSx0cnVlKTpbXX0sT24uZmlsbD1mdW5jdGlvbihuLHQscixlKXt2YXIgdT1udWxsPT1uPzA6bi5sZW5ndGg7aWYoIXUpcmV0dXJuW107Zm9yKHImJnR5cGVvZiByIT1cIm51bWJlclwiJiZ6ZShuLHQscikmJihyPTAsZT11KSx1PW4ubGVuZ3RoLHI9T3UociksMD5yJiYocj0tcj51PzA6dStyKSxlPWU9PT1GfHxlPnU/dTpPdShlKSwwPmUmJihlKz11KSxlPXI+ZT8wOlN1KGUpO3I8ZTspbltyKytdPXQ7XG5yZXR1cm4gbn0sT24uZmlsdGVyPWZ1bmN0aW9uKG4sdCl7cmV0dXJuKGFmKG4pP2Y6QXQpKG4samUodCwzKSl9LE9uLmZsYXRNYXA9ZnVuY3Rpb24obix0KXtyZXR1cm4ga3QodXUobix0KSwxKX0sT24uZmxhdE1hcERlZXA9ZnVuY3Rpb24obix0KXtyZXR1cm4ga3QodXUobix0KSxOKX0sT24uZmxhdE1hcERlcHRoPWZ1bmN0aW9uKG4sdCxyKXtyZXR1cm4gcj1yPT09Rj8xOk91KHIpLGt0KHV1KG4sdCkscil9LE9uLmZsYXR0ZW49VmUsT24uZmxhdHRlbkRlZXA9ZnVuY3Rpb24obil7cmV0dXJuKG51bGw9PW4/MDpuLmxlbmd0aCk/a3QobixOKTpbXX0sT24uZmxhdHRlbkRlcHRoPWZ1bmN0aW9uKG4sdCl7cmV0dXJuIG51bGwhPW4mJm4ubGVuZ3RoPyh0PXQ9PT1GPzE6T3UodCksa3Qobix0KSk6W119LE9uLmZsaXA9ZnVuY3Rpb24obil7cmV0dXJuIGxlKG4sNTEyKX0sT24uZmxvdz1xZixPbi5mbG93UmlnaHQ9VmYsT24uZnJvbVBhaXJzPWZ1bmN0aW9uKG4pe2Zvcih2YXIgdD0tMSxyPW51bGw9PW4/MDpuLmxlbmd0aCxlPXt9OysrdDxyOyl7XG52YXIgdT1uW3RdO2VbdVswXV09dVsxXX1yZXR1cm4gZX0sT24uZnVuY3Rpb25zPWZ1bmN0aW9uKG4pe3JldHVybiBudWxsPT1uP1tdOlN0KG4sTHUobikpfSxPbi5mdW5jdGlvbnNJbj1mdW5jdGlvbihuKXtyZXR1cm4gbnVsbD09bj9bXTpTdChuLFV1KG4pKX0sT24uZ3JvdXBCeT1xbyxPbi5pbml0aWFsPWZ1bmN0aW9uKG4pe3JldHVybihudWxsPT1uPzA6bi5sZW5ndGgpP3ZyKG4sMCwtMSk6W119LE9uLmludGVyc2VjdGlvbj1PbyxPbi5pbnRlcnNlY3Rpb25CeT1TbyxPbi5pbnRlcnNlY3Rpb25XaXRoPUlvLE9uLmludmVydD1FZixPbi5pbnZlcnRCeT1PZixPbi5pbnZva2VNYXA9Vm8sT24uaXRlcmF0ZWU9UHUsT24ua2V5Qnk9S28sT24ua2V5cz1MdSxPbi5rZXlzSW49VXUsT24ubWFwPXV1LE9uLm1hcEtleXM9ZnVuY3Rpb24obix0KXt2YXIgcj17fTtyZXR1cm4gdD1qZSh0LDMpLEV0KG4sZnVuY3Rpb24obixlLHUpe190KHIsdChuLGUsdSksbil9KSxyfSxPbi5tYXBWYWx1ZXM9ZnVuY3Rpb24obix0KXtcbnZhciByPXt9O3JldHVybiB0PWplKHQsMyksRXQobixmdW5jdGlvbihuLGUsdSl7X3QocixlLHQobixlLHUpKX0pLHJ9LE9uLm1hdGNoZXM9ZnVuY3Rpb24obil7cmV0dXJuIFF0KGR0KG4sMSkpfSxPbi5tYXRjaGVzUHJvcGVydHk9ZnVuY3Rpb24obix0KXtyZXR1cm4gWHQobixkdCh0LDEpKX0sT24ubWVtb2l6ZT1sdSxPbi5tZXJnZT1JZixPbi5tZXJnZVdpdGg9UmYsT24ubWV0aG9kPUtmLE9uLm1ldGhvZE9mPUdmLE9uLm1peGluPVp1LE9uLm5lZ2F0ZT1zdSxPbi5udGhBcmc9ZnVuY3Rpb24obil7cmV0dXJuIG49T3UobiksbHIoZnVuY3Rpb24odCl7cmV0dXJuIHRyKHQsbil9KX0sT24ub21pdD16ZixPbi5vbWl0Qnk9ZnVuY3Rpb24obix0KXtyZXR1cm4gQ3UobixzdShqZSh0KSkpfSxPbi5vbmNlPWZ1bmN0aW9uKG4pe3JldHVybiBvdSgyLG4pfSxPbi5vcmRlckJ5PWZ1bmN0aW9uKG4sdCxyLGUpe3JldHVybiBudWxsPT1uP1tdOihhZih0KXx8KHQ9bnVsbD09dD9bXTpbdF0pLFxucj1lP0Y6cixhZihyKXx8KHI9bnVsbD09cj9bXTpbcl0pLHJyKG4sdCxyKSl9LE9uLm92ZXI9SGYsT24ub3ZlckFyZ3M9dGYsT24ub3ZlckV2ZXJ5PUpmLE9uLm92ZXJTb21lPVlmLE9uLnBhcnRpYWw9cmYsT24ucGFydGlhbFJpZ2h0PWVmLE9uLnBhcnRpdGlvbj1HbyxPbi5waWNrPVdmLE9uLnBpY2tCeT1DdSxPbi5wcm9wZXJ0eT1WdSxPbi5wcm9wZXJ0eU9mPWZ1bmN0aW9uKG4pe3JldHVybiBmdW5jdGlvbih0KXtyZXR1cm4gbnVsbD09bj9GOkl0KG4sdCl9fSxPbi5wdWxsPVJvLE9uLnB1bGxBbGw9SGUsT24ucHVsbEFsbEJ5PWZ1bmN0aW9uKG4sdCxyKXtyZXR1cm4gbiYmbi5sZW5ndGgmJnQmJnQubGVuZ3RoP29yKG4sdCxqZShyLDIpKTpufSxPbi5wdWxsQWxsV2l0aD1mdW5jdGlvbihuLHQscil7cmV0dXJuIG4mJm4ubGVuZ3RoJiZ0JiZ0Lmxlbmd0aD9vcihuLHQsRixyKTpufSxPbi5wdWxsQXQ9em8sT24ucmFuZ2U9UWYsT24ucmFuZ2VSaWdodD1YZixPbi5yZWFyZz11ZixPbi5yZWplY3Q9ZnVuY3Rpb24obix0KXtcbnJldHVybihhZihuKT9mOkF0KShuLHN1KGplKHQsMykpKX0sT24ucmVtb3ZlPWZ1bmN0aW9uKG4sdCl7dmFyIHI9W107aWYoIW58fCFuLmxlbmd0aClyZXR1cm4gcjt2YXIgZT0tMSx1PVtdLGk9bi5sZW5ndGg7Zm9yKHQ9amUodCwzKTsrK2U8aTspe3ZhciBvPW5bZV07dChvLGUsbikmJihyLnB1c2gobyksdS5wdXNoKGUpKX1yZXR1cm4gZnIobix1KSxyfSxPbi5yZXN0PWZ1bmN0aW9uKG4sdCl7aWYodHlwZW9mIG4hPVwiZnVuY3Rpb25cIil0aHJvdyBuZXcgZWkoXCJFeHBlY3RlZCBhIGZ1bmN0aW9uXCIpO3JldHVybiB0PXQ9PT1GP3Q6T3UodCksbHIobix0KX0sT24ucmV2ZXJzZT1KZSxPbi5zYW1wbGVTaXplPWZ1bmN0aW9uKG4sdCxyKXtyZXR1cm4gdD0ocj96ZShuLHQscik6dD09PUYpPzE6T3UodCksKGFmKG4pP290OmhyKShuLHQpfSxPbi5zZXQ9ZnVuY3Rpb24obix0LHIpe3JldHVybiBudWxsPT1uP246cHIobix0LHIpfSxPbi5zZXRXaXRoPWZ1bmN0aW9uKG4sdCxyLGUpe3JldHVybiBlPXR5cGVvZiBlPT1cImZ1bmN0aW9uXCI/ZTpGLFxubnVsbD09bj9uOnByKG4sdCxyLGUpfSxPbi5zaHVmZmxlPWZ1bmN0aW9uKG4pe3JldHVybihhZihuKT9mdDpfcikobil9LE9uLnNsaWNlPWZ1bmN0aW9uKG4sdCxyKXt2YXIgZT1udWxsPT1uPzA6bi5sZW5ndGg7cmV0dXJuIGU/KHImJnR5cGVvZiByIT1cIm51bWJlclwiJiZ6ZShuLHQscik/KHQ9MCxyPWUpOih0PW51bGw9PXQ/MDpPdSh0KSxyPXI9PT1GP2U6T3UocikpLHZyKG4sdCxyKSk6W119LE9uLnNvcnRCeT1IbyxPbi5zb3J0ZWRVbmlxPWZ1bmN0aW9uKG4pe3JldHVybiBuJiZuLmxlbmd0aD9icihuKTpbXX0sT24uc29ydGVkVW5pcUJ5PWZ1bmN0aW9uKG4sdCl7cmV0dXJuIG4mJm4ubGVuZ3RoP2JyKG4samUodCwyKSk6W119LE9uLnNwbGl0PWZ1bmN0aW9uKG4sdCxyKXtyZXR1cm4gciYmdHlwZW9mIHIhPVwibnVtYmVyXCImJnplKG4sdCxyKSYmKHQ9cj1GKSxyPXI9PT1GPzQyOTQ5NjcyOTU6cj4+PjAscj8obj16dShuKSkmJih0eXBlb2YgdD09XCJzdHJpbmdcInx8bnVsbCE9dCYmIV9mKHQpKSYmKHQ9anIodCksXG4hdCYmQm4udGVzdChuKSk/enIoJChuKSwwLHIpOm4uc3BsaXQodCxyKTpbXX0sT24uc3ByZWFkPWZ1bmN0aW9uKG4sdCl7aWYodHlwZW9mIG4hPVwiZnVuY3Rpb25cIil0aHJvdyBuZXcgZWkoXCJFeHBlY3RlZCBhIGZ1bmN0aW9uXCIpO3JldHVybiB0PW51bGw9PXQ/MDpEaShPdSh0KSwwKSxscihmdW5jdGlvbihlKXt2YXIgdT1lW3RdO3JldHVybiBlPXpyKGUsMCx0KSx1JiZzKGUsdSkscihuLHRoaXMsZSl9KX0sT24udGFpbD1mdW5jdGlvbihuKXt2YXIgdD1udWxsPT1uPzA6bi5sZW5ndGg7cmV0dXJuIHQ/dnIobiwxLHQpOltdfSxPbi50YWtlPWZ1bmN0aW9uKG4sdCxyKXtyZXR1cm4gbiYmbi5sZW5ndGg/KHQ9cnx8dD09PUY/MTpPdSh0KSx2cihuLDAsMD50PzA6dCkpOltdfSxPbi50YWtlUmlnaHQ9ZnVuY3Rpb24obix0LHIpe3ZhciBlPW51bGw9PW4/MDpuLmxlbmd0aDtyZXR1cm4gZT8odD1yfHx0PT09Rj8xOk91KHQpLHQ9ZS10LHZyKG4sMD50PzA6dCxlKSk6W119LE9uLnRha2VSaWdodFdoaWxlPWZ1bmN0aW9uKG4sdCl7XG5yZXR1cm4gbiYmbi5sZW5ndGg/QXIobixqZSh0LDMpLGZhbHNlLHRydWUpOltdfSxPbi50YWtlV2hpbGU9ZnVuY3Rpb24obix0KXtyZXR1cm4gbiYmbi5sZW5ndGg/QXIobixqZSh0LDMpKTpbXX0sT24udGFwPWZ1bmN0aW9uKG4sdCl7cmV0dXJuIHQobiksbn0sT24udGhyb3R0bGU9ZnVuY3Rpb24obix0LHIpe3ZhciBlPXRydWUsdT10cnVlO2lmKHR5cGVvZiBuIT1cImZ1bmN0aW9uXCIpdGhyb3cgbmV3IGVpKFwiRXhwZWN0ZWQgYSBmdW5jdGlvblwiKTtyZXR1cm4gYnUocikmJihlPVwibGVhZGluZ1wiaW4gcj8hIXIubGVhZGluZzplLHU9XCJ0cmFpbGluZ1wiaW4gcj8hIXIudHJhaWxpbmc6dSksYXUobix0LHtsZWFkaW5nOmUsbWF4V2FpdDp0LHRyYWlsaW5nOnV9KX0sT24udGhydT1udSxPbi50b0FycmF5PWt1LE9uLnRvUGFpcnM9QmYsT24udG9QYWlyc0luPUxmLE9uLnRvUGF0aD1mdW5jdGlvbihuKXtyZXR1cm4gYWYobik/bChuLCRlKTpBdShuKT9bbl06TXIobW8oenUobikpKX0sT24udG9QbGFpbk9iamVjdD1SdSxcbk9uLnRyYW5zZm9ybT1mdW5jdGlvbihuLHQscil7dmFyIGU9YWYobiksaT1lfHxzZihuKXx8Z2Yobik7aWYodD1qZSh0LDQpLG51bGw9PXIpe3ZhciBvPW4mJm4uY29uc3RydWN0b3I7cj1pP2U/bmV3IG86W106YnUobikmJmd1KG8pP2lvKGJpKG4pKTp7fX1yZXR1cm4oaT91OkV0KShuLGZ1bmN0aW9uKG4sZSx1KXtyZXR1cm4gdChyLG4sZSx1KX0pLHJ9LE9uLnVuYXJ5PWZ1bmN0aW9uKG4pe3JldHVybiBpdShuLDEpfSxPbi51bmlvbj1XbyxPbi51bmlvbkJ5PUJvLE9uLnVuaW9uV2l0aD1MbyxPbi51bmlxPWZ1bmN0aW9uKG4pe3JldHVybiBuJiZuLmxlbmd0aD93cihuKTpbXX0sT24udW5pcUJ5PWZ1bmN0aW9uKG4sdCl7cmV0dXJuIG4mJm4ubGVuZ3RoP3dyKG4samUodCwyKSk6W119LE9uLnVuaXFXaXRoPWZ1bmN0aW9uKG4sdCl7cmV0dXJuIHQ9dHlwZW9mIHQ9PVwiZnVuY3Rpb25cIj90OkYsbiYmbi5sZW5ndGg/d3IobixGLHQpOltdfSxPbi51bnNldD1mdW5jdGlvbihuLHQpe3JldHVybiBudWxsPT1ufHxtcihuLHQpO1xufSxPbi51bnppcD1ZZSxPbi51bnppcFdpdGg9UWUsT24udXBkYXRlPWZ1bmN0aW9uKG4sdCxyKXtyZXR1cm4gbnVsbD09bj9uOnByKG4sdCxJcihyKShJdChuLHQpKSx2b2lkIDApfSxPbi51cGRhdGVXaXRoPWZ1bmN0aW9uKG4sdCxyLGUpe3JldHVybiBlPXR5cGVvZiBlPT1cImZ1bmN0aW9uXCI/ZTpGLG51bGwhPW4mJihuPXByKG4sdCxJcihyKShJdChuLHQpKSxlKSksbn0sT24udmFsdWVzPUR1LE9uLnZhbHVlc0luPWZ1bmN0aW9uKG4pe3JldHVybiBudWxsPT1uP1tdOkkobixVdShuKSl9LE9uLndpdGhvdXQ9VW8sT24ud29yZHM9JHUsT24ud3JhcD1mdW5jdGlvbihuLHQpe3JldHVybiByZihJcih0KSxuKX0sT24ueG9yPUNvLE9uLnhvckJ5PURvLE9uLnhvcldpdGg9TW8sT24uemlwPVRvLE9uLnppcE9iamVjdD1mdW5jdGlvbihuLHQpe3JldHVybiBPcihufHxbXSx0fHxbXSxhdCl9LE9uLnppcE9iamVjdERlZXA9ZnVuY3Rpb24obix0KXtyZXR1cm4gT3Iobnx8W10sdHx8W10scHIpO1xufSxPbi56aXBXaXRoPSRvLE9uLmVudHJpZXM9QmYsT24uZW50cmllc0luPUxmLE9uLmV4dGVuZD14ZixPbi5leHRlbmRXaXRoPWpmLFp1KE9uLE9uKSxPbi5hZGQ9bmMsT24uYXR0ZW1wdD1QZixPbi5jYW1lbENhc2U9VWYsT24uY2FwaXRhbGl6ZT1NdSxPbi5jZWlsPXRjLE9uLmNsYW1wPWZ1bmN0aW9uKG4sdCxyKXtyZXR1cm4gcj09PUYmJihyPXQsdD1GKSxyIT09RiYmKHI9SXUocikscj1yPT09cj9yOjApLHQhPT1GJiYodD1JdSh0KSx0PXQ9PT10P3Q6MCksZ3QoSXUobiksdCxyKX0sT24uY2xvbmU9ZnVuY3Rpb24obil7cmV0dXJuIGR0KG4sNCl9LE9uLmNsb25lRGVlcD1mdW5jdGlvbihuKXtyZXR1cm4gZHQobiw1KX0sT24uY2xvbmVEZWVwV2l0aD1mdW5jdGlvbihuLHQpe3JldHVybiB0PXR5cGVvZiB0PT1cImZ1bmN0aW9uXCI/dDpGLGR0KG4sNSx0KX0sT24uY2xvbmVXaXRoPWZ1bmN0aW9uKG4sdCl7cmV0dXJuIHQ9dHlwZW9mIHQ9PVwiZnVuY3Rpb25cIj90OkYsZHQobiw0LHQpfSxcbk9uLmNvbmZvcm1zVG89ZnVuY3Rpb24obix0KXtyZXR1cm4gbnVsbD09dHx8YnQobix0LEx1KHQpKX0sT24uZGVidXJyPVR1LE9uLmRlZmF1bHRUbz1mdW5jdGlvbihuLHQpe3JldHVybiBudWxsPT1ufHxuIT09bj90Om59LE9uLmRpdmlkZT1yYyxPbi5lbmRzV2l0aD1mdW5jdGlvbihuLHQscil7bj16dShuKSx0PWpyKHQpO3ZhciBlPW4ubGVuZ3RoLGU9cj1yPT09Rj9lOmd0KE91KHIpLDAsZSk7cmV0dXJuIHItPXQubGVuZ3RoLDA8PXImJm4uc2xpY2UocixlKT09dH0sT24uZXE9aHUsT24uZXNjYXBlPWZ1bmN0aW9uKG4pe3JldHVybihuPXp1KG4pKSYmWS50ZXN0KG4pP24ucmVwbGFjZShILGV0KTpufSxPbi5lc2NhcGVSZWdFeHA9ZnVuY3Rpb24obil7cmV0dXJuKG49enUobikpJiZmbi50ZXN0KG4pP24ucmVwbGFjZShvbixcIlxcXFwkJlwiKTpufSxPbi5ldmVyeT1mdW5jdGlvbihuLHQscil7dmFyIGU9YWYobik/bzp3dDtyZXR1cm4gciYmemUobix0LHIpJiYodD1GKSxlKG4samUodCwzKSk7XG59LE9uLmZpbmQ9UG8sT24uZmluZEluZGV4PVplLE9uLmZpbmRLZXk9ZnVuY3Rpb24obix0KXtyZXR1cm4gdihuLGplKHQsMyksRXQpfSxPbi5maW5kTGFzdD1abyxPbi5maW5kTGFzdEluZGV4PXFlLE9uLmZpbmRMYXN0S2V5PWZ1bmN0aW9uKG4sdCl7cmV0dXJuIHYobixqZSh0LDMpLE90KX0sT24uZmxvb3I9ZWMsT24uZm9yRWFjaD1ydSxPbi5mb3JFYWNoUmlnaHQ9ZXUsT24uZm9ySW49ZnVuY3Rpb24obix0KXtyZXR1cm4gbnVsbD09bj9uOmNvKG4samUodCwzKSxVdSl9LE9uLmZvckluUmlnaHQ9ZnVuY3Rpb24obix0KXtyZXR1cm4gbnVsbD09bj9uOmFvKG4samUodCwzKSxVdSl9LE9uLmZvck93bj1mdW5jdGlvbihuLHQpe3JldHVybiBuJiZFdChuLGplKHQsMykpfSxPbi5mb3JPd25SaWdodD1mdW5jdGlvbihuLHQpe3JldHVybiBuJiZPdChuLGplKHQsMykpfSxPbi5nZXQ9V3UsT24uZ3Q9b2YsT24uZ3RlPWZmLE9uLmhhcz1mdW5jdGlvbihuLHQpe3JldHVybiBudWxsIT1uJiZrZShuLHQsQnQpO1xufSxPbi5oYXNJbj1CdSxPbi5oZWFkPUtlLE9uLmlkZW50aXR5PU51LE9uLmluY2x1ZGVzPWZ1bmN0aW9uKG4sdCxyLGUpe3JldHVybiBuPXB1KG4pP246RHUobikscj1yJiYhZT9PdShyKTowLGU9bi5sZW5ndGgsMD5yJiYocj1EaShlK3IsMCkpLG11KG4pP3I8PWUmJi0xPG4uaW5kZXhPZih0LHIpOiEhZSYmLTE8ZChuLHQscil9LE9uLmluZGV4T2Y9ZnVuY3Rpb24obix0LHIpe3ZhciBlPW51bGw9PW4/MDpuLmxlbmd0aDtyZXR1cm4gZT8ocj1udWxsPT1yPzA6T3UociksMD5yJiYocj1EaShlK3IsMCkpLGQobix0LHIpKTotMX0sT24uaW5SYW5nZT1mdW5jdGlvbihuLHQscil7cmV0dXJuIHQ9RXUodCkscj09PUY/KHI9dCx0PTApOnI9RXUociksbj1JdShuKSxuPj1NaSh0LHIpJiZuPERpKHQscil9LE9uLmludm9rZT1TZixPbi5pc0FyZ3VtZW50cz1jZixPbi5pc0FycmF5PWFmLE9uLmlzQXJyYXlCdWZmZXI9bGYsT24uaXNBcnJheUxpa2U9cHUsT24uaXNBcnJheUxpa2VPYmplY3Q9X3UsXG5Pbi5pc0Jvb2xlYW49ZnVuY3Rpb24obil7cmV0dXJuIHRydWU9PT1ufHxmYWxzZT09PW58fHh1KG4pJiZcIltvYmplY3QgQm9vbGVhbl1cIj09enQobil9LE9uLmlzQnVmZmVyPXNmLE9uLmlzRGF0ZT1oZixPbi5pc0VsZW1lbnQ9ZnVuY3Rpb24obil7cmV0dXJuIHh1KG4pJiYxPT09bi5ub2RlVHlwZSYmIXd1KG4pfSxPbi5pc0VtcHR5PWZ1bmN0aW9uKG4pe2lmKG51bGw9PW4pcmV0dXJuIHRydWU7aWYocHUobikmJihhZihuKXx8dHlwZW9mIG49PVwic3RyaW5nXCJ8fHR5cGVvZiBuLnNwbGljZT09XCJmdW5jdGlvblwifHxzZihuKXx8Z2Yobil8fGNmKG4pKSlyZXR1cm4hbi5sZW5ndGg7dmFyIHQ9eW8obik7aWYoXCJbb2JqZWN0IE1hcF1cIj09dHx8XCJbb2JqZWN0IFNldF1cIj09dClyZXR1cm4hbi5zaXplO2lmKExlKG4pKXJldHVybiFIdChuKS5sZW5ndGg7Zm9yKHZhciByIGluIG4paWYoY2kuY2FsbChuLHIpKXJldHVybiBmYWxzZTtyZXR1cm4gdHJ1ZX0sT24uaXNFcXVhbD1mdW5jdGlvbihuLHQpe3JldHVybiBGdChuLHQpO1xufSxPbi5pc0VxdWFsV2l0aD1mdW5jdGlvbihuLHQscil7dmFyIGU9KHI9dHlwZW9mIHI9PVwiZnVuY3Rpb25cIj9yOkYpP3Iobix0KTpGO3JldHVybiBlPT09Rj9GdChuLHQsRixyKTohIWV9LE9uLmlzRXJyb3I9dnUsT24uaXNGaW5pdGU9ZnVuY3Rpb24obil7cmV0dXJuIHR5cGVvZiBuPT1cIm51bWJlclwiJiZMaShuKX0sT24uaXNGdW5jdGlvbj1ndSxPbi5pc0ludGVnZXI9ZHUsT24uaXNMZW5ndGg9eXUsT24uaXNNYXA9cGYsT24uaXNNYXRjaD1mdW5jdGlvbihuLHQpe3JldHVybiBuPT09dHx8UHQobix0LG1lKHQpKX0sT24uaXNNYXRjaFdpdGg9ZnVuY3Rpb24obix0LHIpe3JldHVybiByPXR5cGVvZiByPT1cImZ1bmN0aW9uXCI/cjpGLFB0KG4sdCxtZSh0KSxyKX0sT24uaXNOYU49ZnVuY3Rpb24obil7cmV0dXJuIGp1KG4pJiZuIT0rbn0sT24uaXNOYXRpdmU9ZnVuY3Rpb24obil7aWYoYm8obikpdGhyb3cgbmV3IFl1KFwiVW5zdXBwb3J0ZWQgY29yZS1qcyB1c2UuIFRyeSBodHRwczovL25wbXMuaW8vc2VhcmNoP3E9cG9ueWZpbGwuXCIpO1xucmV0dXJuIFp0KG4pfSxPbi5pc05pbD1mdW5jdGlvbihuKXtyZXR1cm4gbnVsbD09bn0sT24uaXNOdWxsPWZ1bmN0aW9uKG4pe3JldHVybiBudWxsPT09bn0sT24uaXNOdW1iZXI9anUsT24uaXNPYmplY3Q9YnUsT24uaXNPYmplY3RMaWtlPXh1LE9uLmlzUGxhaW5PYmplY3Q9d3UsT24uaXNSZWdFeHA9X2YsT24uaXNTYWZlSW50ZWdlcj1mdW5jdGlvbihuKXtyZXR1cm4gZHUobikmJi05MDA3MTk5MjU0NzQwOTkxPD1uJiY5MDA3MTk5MjU0NzQwOTkxPj1ufSxPbi5pc1NldD12ZixPbi5pc1N0cmluZz1tdSxPbi5pc1N5bWJvbD1BdSxPbi5pc1R5cGVkQXJyYXk9Z2YsT24uaXNVbmRlZmluZWQ9ZnVuY3Rpb24obil7cmV0dXJuIG49PT1GfSxPbi5pc1dlYWtNYXA9ZnVuY3Rpb24obil7cmV0dXJuIHh1KG4pJiZcIltvYmplY3QgV2Vha01hcF1cIj09eW8obil9LE9uLmlzV2Vha1NldD1mdW5jdGlvbihuKXtyZXR1cm4geHUobikmJlwiW29iamVjdCBXZWFrU2V0XVwiPT16dChuKX0sT24uam9pbj1mdW5jdGlvbihuLHQpe1xucmV0dXJuIG51bGw9PW4/XCJcIjpVaS5jYWxsKG4sdCl9LE9uLmtlYmFiQ2FzZT1DZixPbi5sYXN0PUdlLE9uLmxhc3RJbmRleE9mPWZ1bmN0aW9uKG4sdCxyKXt2YXIgZT1udWxsPT1uPzA6bi5sZW5ndGg7aWYoIWUpcmV0dXJuLTE7dmFyIHU9ZTtpZihyIT09RiYmKHU9T3UociksdT0wPnU/RGkoZSt1LDApOk1pKHUsZS0xKSksdD09PXQpe2ZvcihyPXUrMTtyLS0mJm5bcl0hPT10Oyk7bj1yfWVsc2Ugbj1nKG4sYix1LHRydWUpO3JldHVybiBufSxPbi5sb3dlckNhc2U9RGYsT24ubG93ZXJGaXJzdD1NZixPbi5sdD1kZixPbi5sdGU9eWYsT24ubWF4PWZ1bmN0aW9uKG4pe3JldHVybiBuJiZuLmxlbmd0aD9tdChuLE51LFd0KTpGfSxPbi5tYXhCeT1mdW5jdGlvbihuLHQpe3JldHVybiBuJiZuLmxlbmd0aD9tdChuLGplKHQsMiksV3QpOkZ9LE9uLm1lYW49ZnVuY3Rpb24obil7cmV0dXJuIHgobixOdSl9LE9uLm1lYW5CeT1mdW5jdGlvbihuLHQpe3JldHVybiB4KG4samUodCwyKSl9LE9uLm1pbj1mdW5jdGlvbihuKXtcbnJldHVybiBuJiZuLmxlbmd0aD9tdChuLE51LEp0KTpGfSxPbi5taW5CeT1mdW5jdGlvbihuLHQpe3JldHVybiBuJiZuLmxlbmd0aD9tdChuLGplKHQsMiksSnQpOkZ9LE9uLnN0dWJBcnJheT1LdSxPbi5zdHViRmFsc2U9R3UsT24uc3R1Yk9iamVjdD1mdW5jdGlvbigpe3JldHVybnt9fSxPbi5zdHViU3RyaW5nPWZ1bmN0aW9uKCl7cmV0dXJuXCJcIn0sT24uc3R1YlRydWU9ZnVuY3Rpb24oKXtyZXR1cm4gdHJ1ZX0sT24ubXVsdGlwbHk9dWMsT24ubnRoPWZ1bmN0aW9uKG4sdCl7cmV0dXJuIG4mJm4ubGVuZ3RoP3RyKG4sT3UodCkpOkZ9LE9uLm5vQ29uZmxpY3Q9ZnVuY3Rpb24oKXtyZXR1cm4gWm4uXz09PXRoaXMmJihabi5fPXBpKSx0aGlzfSxPbi5ub29wPXF1LE9uLm5vdz1KbyxPbi5wYWQ9ZnVuY3Rpb24obix0LHIpe249enUobik7dmFyIGU9KHQ9T3UodCkpP1Qobik6MDtyZXR1cm4hdHx8ZT49dD9uOih0PSh0LWUpLzIsZWUoemkodCkscikrbitlZShSaSh0KSxyKSl9LE9uLnBhZEVuZD1mdW5jdGlvbihuLHQscil7XG5uPXp1KG4pO3ZhciBlPSh0PU91KHQpKT9UKG4pOjA7cmV0dXJuIHQmJmU8dD9uK2VlKHQtZSxyKTpufSxPbi5wYWRTdGFydD1mdW5jdGlvbihuLHQscil7bj16dShuKTt2YXIgZT0odD1PdSh0KSk/VChuKTowO3JldHVybiB0JiZlPHQ/ZWUodC1lLHIpK246bn0sT24ucGFyc2VJbnQ9ZnVuY3Rpb24obix0LHIpe3JldHVybiByfHxudWxsPT10P3Q9MDp0JiYodD0rdCksJGkoenUobikucmVwbGFjZShhbixcIlwiKSx0fHwwKX0sT24ucmFuZG9tPWZ1bmN0aW9uKG4sdCxyKXtpZihyJiZ0eXBlb2YgciE9XCJib29sZWFuXCImJnplKG4sdCxyKSYmKHQ9cj1GKSxyPT09RiYmKHR5cGVvZiB0PT1cImJvb2xlYW5cIj8ocj10LHQ9Rik6dHlwZW9mIG49PVwiYm9vbGVhblwiJiYocj1uLG49RikpLG49PT1GJiZ0PT09Rj8obj0wLHQ9MSk6KG49RXUobiksdD09PUY/KHQ9bixuPTApOnQ9RXUodCkpLG4+dCl7dmFyIGU9bjtuPXQsdD1lfXJldHVybiByfHxuJTF8fHQlMT8ocj1GaSgpLE1pKG4rcioodC1uKyRuKFwiMWUtXCIrKChyK1wiXCIpLmxlbmd0aC0xKSkpLHQpKTpjcihuLHQpO1xufSxPbi5yZWR1Y2U9ZnVuY3Rpb24obix0LHIpe3ZhciBlPWFmKG4pP2g6bSx1PTM+YXJndW1lbnRzLmxlbmd0aDtyZXR1cm4gZShuLGplKHQsNCkscix1LG9vKX0sT24ucmVkdWNlUmlnaHQ9ZnVuY3Rpb24obix0LHIpe3ZhciBlPWFmKG4pP3A6bSx1PTM+YXJndW1lbnRzLmxlbmd0aDtyZXR1cm4gZShuLGplKHQsNCkscix1LGZvKX0sT24ucmVwZWF0PWZ1bmN0aW9uKG4sdCxyKXtyZXR1cm4gdD0ocj96ZShuLHQscik6dD09PUYpPzE6T3UodCksYXIoenUobiksdCl9LE9uLnJlcGxhY2U9ZnVuY3Rpb24oKXt2YXIgbj1hcmd1bWVudHMsdD16dShuWzBdKTtyZXR1cm4gMz5uLmxlbmd0aD90OnQucmVwbGFjZShuWzFdLG5bMl0pfSxPbi5yZXN1bHQ9ZnVuY3Rpb24obix0LHIpe3Q9UnIodCxuKTt2YXIgZT0tMSx1PXQubGVuZ3RoO2Zvcih1fHwodT0xLG49Rik7KytlPHU7KXt2YXIgaT1udWxsPT1uP0Y6blskZSh0W2VdKV07aT09PUYmJihlPXUsaT1yKSxuPWd1KGkpP2kuY2FsbChuKTppO1xufXJldHVybiBufSxPbi5yb3VuZD1pYyxPbi5ydW5JbkNvbnRleHQ9dyxPbi5zYW1wbGU9ZnVuY3Rpb24obil7cmV0dXJuKGFmKG4pP3R0OnNyKShuKX0sT24uc2l6ZT1mdW5jdGlvbihuKXtpZihudWxsPT1uKXJldHVybiAwO2lmKHB1KG4pKXJldHVybiBtdShuKT9UKG4pOm4ubGVuZ3RoO3ZhciB0PXlvKG4pO3JldHVyblwiW29iamVjdCBNYXBdXCI9PXR8fFwiW29iamVjdCBTZXRdXCI9PXQ/bi5zaXplOkh0KG4pLmxlbmd0aH0sT24uc25ha2VDYXNlPVRmLE9uLnNvbWU9ZnVuY3Rpb24obix0LHIpe3ZhciBlPWFmKG4pP186Z3I7cmV0dXJuIHImJnplKG4sdCxyKSYmKHQ9RiksZShuLGplKHQsMykpfSxPbi5zb3J0ZWRJbmRleD1mdW5jdGlvbihuLHQpe3JldHVybiBkcihuLHQpfSxPbi5zb3J0ZWRJbmRleEJ5PWZ1bmN0aW9uKG4sdCxyKXtyZXR1cm4geXIobix0LGplKHIsMikpfSxPbi5zb3J0ZWRJbmRleE9mPWZ1bmN0aW9uKG4sdCl7dmFyIHI9bnVsbD09bj8wOm4ubGVuZ3RoO2lmKHIpe1xudmFyIGU9ZHIobix0KTtpZihlPHImJmh1KG5bZV0sdCkpcmV0dXJuIGV9cmV0dXJuLTF9LE9uLnNvcnRlZExhc3RJbmRleD1mdW5jdGlvbihuLHQpe3JldHVybiBkcihuLHQsdHJ1ZSl9LE9uLnNvcnRlZExhc3RJbmRleEJ5PWZ1bmN0aW9uKG4sdCxyKXtyZXR1cm4geXIobix0LGplKHIsMiksdHJ1ZSl9LE9uLnNvcnRlZExhc3RJbmRleE9mPWZ1bmN0aW9uKG4sdCl7aWYobnVsbD09bj8wOm4ubGVuZ3RoKXt2YXIgcj1kcihuLHQsdHJ1ZSktMTtpZihodShuW3JdLHQpKXJldHVybiByfXJldHVybi0xfSxPbi5zdGFydENhc2U9JGYsT24uc3RhcnRzV2l0aD1mdW5jdGlvbihuLHQscil7cmV0dXJuIG49enUobikscj1udWxsPT1yPzA6Z3QoT3UociksMCxuLmxlbmd0aCksdD1qcih0KSxuLnNsaWNlKHIscit0Lmxlbmd0aCk9PXR9LE9uLnN1YnRyYWN0PW9jLE9uLnN1bT1mdW5jdGlvbihuKXtyZXR1cm4gbiYmbi5sZW5ndGg/ayhuLE51KTowfSxPbi5zdW1CeT1mdW5jdGlvbihuLHQpe3JldHVybiBuJiZuLmxlbmd0aD9rKG4samUodCwyKSk6MDtcbn0sT24udGVtcGxhdGU9ZnVuY3Rpb24obix0LHIpe3ZhciBlPU9uLnRlbXBsYXRlU2V0dGluZ3M7ciYmemUobix0LHIpJiYodD1GKSxuPXp1KG4pLHQ9amYoe30sdCxlLHNlKSxyPWpmKHt9LHQuaW1wb3J0cyxlLmltcG9ydHMsc2UpO3ZhciB1LGksbz1MdShyKSxmPUkocixvKSxjPTA7cj10LmludGVycG9sYXRlfHxBbjt2YXIgYT1cIl9fcCs9J1wiO3I9dGkoKHQuZXNjYXBlfHxBbikuc291cmNlK1wifFwiK3Iuc291cmNlK1wifFwiKyhyPT09bm4/Z246QW4pLnNvdXJjZStcInxcIisodC5ldmFsdWF0ZXx8QW4pLnNvdXJjZStcInwkXCIsXCJnXCIpO3ZhciBsPVwic291cmNlVVJMXCJpbiB0P1wiLy8jIHNvdXJjZVVSTD1cIit0LnNvdXJjZVVSTCtcIlxcblwiOlwiXCI7aWYobi5yZXBsYWNlKHIsZnVuY3Rpb24odCxyLGUsbyxmLGwpe3JldHVybiBlfHwoZT1vKSxhKz1uLnNsaWNlKGMsbCkucmVwbGFjZShrbixCKSxyJiYodT10cnVlLGErPVwiJytfX2UoXCIrcitcIikrJ1wiKSxmJiYoaT10cnVlLGErPVwiJztcIitmK1wiO1xcbl9fcCs9J1wiKSxcbmUmJihhKz1cIicrKChfX3Q9KFwiK2UrXCIpKT09bnVsbD8nJzpfX3QpKydcIiksYz1sK3QubGVuZ3RoLHR9KSxhKz1cIic7XCIsKHQ9dC52YXJpYWJsZSl8fChhPVwid2l0aChvYmope1wiK2ErXCJ9XCIpLGE9KGk/YS5yZXBsYWNlKHEsXCJcIik6YSkucmVwbGFjZShWLFwiJDFcIikucmVwbGFjZShLLFwiJDE7XCIpLGE9XCJmdW5jdGlvbihcIisodHx8XCJvYmpcIikrXCIpe1wiKyh0P1wiXCI6XCJvYmp8fChvYmo9e30pO1wiKStcInZhciBfX3QsX19wPScnXCIrKHU/XCIsX19lPV8uZXNjYXBlXCI6XCJcIikrKGk/XCIsX19qPUFycmF5LnByb3RvdHlwZS5qb2luO2Z1bmN0aW9uIHByaW50KCl7X19wKz1fX2ouY2FsbChhcmd1bWVudHMsJycpfVwiOlwiO1wiKSthK1wicmV0dXJuIF9fcH1cIix0PVBmKGZ1bmN0aW9uKCl7cmV0dXJuIFF1KG8sbCtcInJldHVybiBcIithKS5hcHBseShGLGYpfSksdC5zb3VyY2U9YSx2dSh0KSl0aHJvdyB0O3JldHVybiB0fSxPbi50aW1lcz1mdW5jdGlvbihuLHQpe2lmKG49T3UobiksMT5ufHw5MDA3MTk5MjU0NzQwOTkxPG4pcmV0dXJuW107XG52YXIgcj00Mjk0OTY3Mjk1LGU9TWkobiw0Mjk0OTY3Mjk1KTtmb3IodD1qZSh0KSxuLT00Mjk0OTY3Mjk1LGU9RShlLHQpOysrcjxuOyl0KHIpO3JldHVybiBlfSxPbi50b0Zpbml0ZT1FdSxPbi50b0ludGVnZXI9T3UsT24udG9MZW5ndGg9U3UsT24udG9Mb3dlcj1mdW5jdGlvbihuKXtyZXR1cm4genUobikudG9Mb3dlckNhc2UoKX0sT24udG9OdW1iZXI9SXUsT24udG9TYWZlSW50ZWdlcj1mdW5jdGlvbihuKXtyZXR1cm4gbj9ndChPdShuKSwtOTAwNzE5OTI1NDc0MDk5MSw5MDA3MTk5MjU0NzQwOTkxKTowPT09bj9uOjB9LE9uLnRvU3RyaW5nPXp1LE9uLnRvVXBwZXI9ZnVuY3Rpb24obil7cmV0dXJuIHp1KG4pLnRvVXBwZXJDYXNlKCl9LE9uLnRyaW09ZnVuY3Rpb24obix0LHIpe3JldHVybihuPXp1KG4pKSYmKHJ8fHQ9PT1GKT9uLnJlcGxhY2UoY24sXCJcIik6biYmKHQ9anIodCkpPyhuPSQobikscj0kKHQpLHQ9eihuLHIpLHI9VyhuLHIpKzEsenIobix0LHIpLmpvaW4oXCJcIikpOm47XG59LE9uLnRyaW1FbmQ9ZnVuY3Rpb24obix0LHIpe3JldHVybihuPXp1KG4pKSYmKHJ8fHQ9PT1GKT9uLnJlcGxhY2UobG4sXCJcIik6biYmKHQ9anIodCkpPyhuPSQobiksdD1XKG4sJCh0KSkrMSx6cihuLDAsdCkuam9pbihcIlwiKSk6bn0sT24udHJpbVN0YXJ0PWZ1bmN0aW9uKG4sdCxyKXtyZXR1cm4obj16dShuKSkmJihyfHx0PT09Rik/bi5yZXBsYWNlKGFuLFwiXCIpOm4mJih0PWpyKHQpKT8obj0kKG4pLHQ9eihuLCQodCkpLHpyKG4sdCkuam9pbihcIlwiKSk6bn0sT24udHJ1bmNhdGU9ZnVuY3Rpb24obix0KXt2YXIgcj0zMCxlPVwiLi4uXCI7aWYoYnUodCkpdmFyIHU9XCJzZXBhcmF0b3JcImluIHQ/dC5zZXBhcmF0b3I6dSxyPVwibGVuZ3RoXCJpbiB0P091KHQubGVuZ3RoKTpyLGU9XCJvbWlzc2lvblwiaW4gdD9qcih0Lm9taXNzaW9uKTplO249enUobik7dmFyIGk9bi5sZW5ndGg7aWYoQm4udGVzdChuKSl2YXIgbz0kKG4pLGk9by5sZW5ndGg7aWYocj49aSlyZXR1cm4gbjtpZihpPXItVChlKSwxPmkpcmV0dXJuIGU7XG5pZihyPW8/enIobywwLGkpLmpvaW4oXCJcIik6bi5zbGljZSgwLGkpLHU9PT1GKXJldHVybiByK2U7aWYobyYmKGkrPXIubGVuZ3RoLWkpLF9mKHUpKXtpZihuLnNsaWNlKGkpLnNlYXJjaCh1KSl7dmFyIGY9cjtmb3IodS5nbG9iYWx8fCh1PXRpKHUuc291cmNlLHp1KGRuLmV4ZWModSkpK1wiZ1wiKSksdS5sYXN0SW5kZXg9MDtvPXUuZXhlYyhmKTspdmFyIGM9by5pbmRleDtyPXIuc2xpY2UoMCxjPT09Rj9pOmMpfX1lbHNlIG4uaW5kZXhPZihqcih1KSxpKSE9aSYmKHU9ci5sYXN0SW5kZXhPZih1KSwtMTx1JiYocj1yLnNsaWNlKDAsdSkpKTtyZXR1cm4gcitlfSxPbi51bmVzY2FwZT1mdW5jdGlvbihuKXtyZXR1cm4obj16dShuKSkmJkoudGVzdChuKT9uLnJlcGxhY2UoRyx1dCk6bn0sT24udW5pcXVlSWQ9ZnVuY3Rpb24obil7dmFyIHQ9KythaTtyZXR1cm4genUobikrdH0sT24udXBwZXJDYXNlPUZmLE9uLnVwcGVyRmlyc3Q9TmYsT24uZWFjaD1ydSxPbi5lYWNoUmlnaHQ9ZXUsT24uZmlyc3Q9S2UsXG5adShPbixmdW5jdGlvbigpe3ZhciBuPXt9O3JldHVybiBFdChPbixmdW5jdGlvbih0LHIpe2NpLmNhbGwoT24ucHJvdG90eXBlLHIpfHwobltyXT10KX0pLG59KCkse2NoYWluOmZhbHNlfSksT24uVkVSU0lPTj1cIjQuMTcuNFwiLHUoXCJiaW5kIGJpbmRLZXkgY3VycnkgY3VycnlSaWdodCBwYXJ0aWFsIHBhcnRpYWxSaWdodFwiLnNwbGl0KFwiIFwiKSxmdW5jdGlvbihuKXtPbltuXS5wbGFjZWhvbGRlcj1Pbn0pLHUoW1wiZHJvcFwiLFwidGFrZVwiXSxmdW5jdGlvbihuLHQpe01uLnByb3RvdHlwZVtuXT1mdW5jdGlvbihyKXtyPXI9PT1GPzE6RGkoT3UociksMCk7dmFyIGU9dGhpcy5fX2ZpbHRlcmVkX18mJiF0P25ldyBNbih0aGlzKTp0aGlzLmNsb25lKCk7cmV0dXJuIGUuX19maWx0ZXJlZF9fP2UuX190YWtlQ291bnRfXz1NaShyLGUuX190YWtlQ291bnRfXyk6ZS5fX3ZpZXdzX18ucHVzaCh7c2l6ZTpNaShyLDQyOTQ5NjcyOTUpLHR5cGU6bisoMD5lLl9fZGlyX18/XCJSaWdodFwiOlwiXCIpfSksZX0sTW4ucHJvdG90eXBlW24rXCJSaWdodFwiXT1mdW5jdGlvbih0KXtcbnJldHVybiB0aGlzLnJldmVyc2UoKVtuXSh0KS5yZXZlcnNlKCl9fSksdShbXCJmaWx0ZXJcIixcIm1hcFwiLFwidGFrZVdoaWxlXCJdLGZ1bmN0aW9uKG4sdCl7dmFyIHI9dCsxLGU9MT09cnx8Mz09cjtNbi5wcm90b3R5cGVbbl09ZnVuY3Rpb24obil7dmFyIHQ9dGhpcy5jbG9uZSgpO3JldHVybiB0Ll9faXRlcmF0ZWVzX18ucHVzaCh7aXRlcmF0ZWU6amUobiwzKSx0eXBlOnJ9KSx0Ll9fZmlsdGVyZWRfXz10Ll9fZmlsdGVyZWRfX3x8ZSx0fX0pLHUoW1wiaGVhZFwiLFwibGFzdFwiXSxmdW5jdGlvbihuLHQpe3ZhciByPVwidGFrZVwiKyh0P1wiUmlnaHRcIjpcIlwiKTtNbi5wcm90b3R5cGVbbl09ZnVuY3Rpb24oKXtyZXR1cm4gdGhpc1tyXSgxKS52YWx1ZSgpWzBdfX0pLHUoW1wiaW5pdGlhbFwiLFwidGFpbFwiXSxmdW5jdGlvbihuLHQpe3ZhciByPVwiZHJvcFwiKyh0P1wiXCI6XCJSaWdodFwiKTtNbi5wcm90b3R5cGVbbl09ZnVuY3Rpb24oKXtyZXR1cm4gdGhpcy5fX2ZpbHRlcmVkX18/bmV3IE1uKHRoaXMpOnRoaXNbcl0oMSk7XG59fSksTW4ucHJvdG90eXBlLmNvbXBhY3Q9ZnVuY3Rpb24oKXtyZXR1cm4gdGhpcy5maWx0ZXIoTnUpfSxNbi5wcm90b3R5cGUuZmluZD1mdW5jdGlvbihuKXtyZXR1cm4gdGhpcy5maWx0ZXIobikuaGVhZCgpfSxNbi5wcm90b3R5cGUuZmluZExhc3Q9ZnVuY3Rpb24obil7cmV0dXJuIHRoaXMucmV2ZXJzZSgpLmZpbmQobil9LE1uLnByb3RvdHlwZS5pbnZva2VNYXA9bHIoZnVuY3Rpb24obix0KXtyZXR1cm4gdHlwZW9mIG49PVwiZnVuY3Rpb25cIj9uZXcgTW4odGhpcyk6dGhpcy5tYXAoZnVuY3Rpb24ocil7cmV0dXJuIER0KHIsbix0KX0pfSksTW4ucHJvdG90eXBlLnJlamVjdD1mdW5jdGlvbihuKXtyZXR1cm4gdGhpcy5maWx0ZXIoc3UoamUobikpKX0sTW4ucHJvdG90eXBlLnNsaWNlPWZ1bmN0aW9uKG4sdCl7bj1PdShuKTt2YXIgcj10aGlzO3JldHVybiByLl9fZmlsdGVyZWRfXyYmKDA8bnx8MD50KT9uZXcgTW4ocik6KDA+bj9yPXIudGFrZVJpZ2h0KC1uKTpuJiYocj1yLmRyb3AobikpLFxudCE9PUYmJih0PU91KHQpLHI9MD50P3IuZHJvcFJpZ2h0KC10KTpyLnRha2UodC1uKSkscil9LE1uLnByb3RvdHlwZS50YWtlUmlnaHRXaGlsZT1mdW5jdGlvbihuKXtyZXR1cm4gdGhpcy5yZXZlcnNlKCkudGFrZVdoaWxlKG4pLnJldmVyc2UoKX0sTW4ucHJvdG90eXBlLnRvQXJyYXk9ZnVuY3Rpb24oKXtyZXR1cm4gdGhpcy50YWtlKDQyOTQ5NjcyOTUpfSxFdChNbi5wcm90b3R5cGUsZnVuY3Rpb24obix0KXt2YXIgcj0vXig/OmZpbHRlcnxmaW5kfG1hcHxyZWplY3QpfFdoaWxlJC8udGVzdCh0KSxlPS9eKD86aGVhZHxsYXN0KSQvLnRlc3QodCksdT1PbltlP1widGFrZVwiKyhcImxhc3RcIj09dD9cIlJpZ2h0XCI6XCJcIik6dF0saT1lfHwvXmZpbmQvLnRlc3QodCk7dSYmKE9uLnByb3RvdHlwZVt0XT1mdW5jdGlvbigpe2Z1bmN0aW9uIHQobil7cmV0dXJuIG49dS5hcHBseShPbixzKFtuXSxmKSksZSYmaD9uWzBdOm59dmFyIG89dGhpcy5fX3dyYXBwZWRfXyxmPWU/WzFdOmFyZ3VtZW50cyxjPW8gaW5zdGFuY2VvZiBNbixhPWZbMF0sbD1jfHxhZihvKTtcbmwmJnImJnR5cGVvZiBhPT1cImZ1bmN0aW9uXCImJjEhPWEubGVuZ3RoJiYoYz1sPWZhbHNlKTt2YXIgaD10aGlzLl9fY2hhaW5fXyxwPSEhdGhpcy5fX2FjdGlvbnNfXy5sZW5ndGgsYT1pJiYhaCxjPWMmJiFwO3JldHVybiFpJiZsPyhvPWM/bzpuZXcgTW4odGhpcyksbz1uLmFwcGx5KG8sZiksby5fX2FjdGlvbnNfXy5wdXNoKHtmdW5jOm51LGFyZ3M6W3RdLHRoaXNBcmc6Rn0pLG5ldyB6bihvLGgpKTphJiZjP24uYXBwbHkodGhpcyxmKToobz10aGlzLnRocnUodCksYT9lP28udmFsdWUoKVswXTpvLnZhbHVlKCk6byl9KX0pLHUoXCJwb3AgcHVzaCBzaGlmdCBzb3J0IHNwbGljZSB1bnNoaWZ0XCIuc3BsaXQoXCIgXCIpLGZ1bmN0aW9uKG4pe3ZhciB0PXVpW25dLHI9L14oPzpwdXNofHNvcnR8dW5zaGlmdCkkLy50ZXN0KG4pP1widGFwXCI6XCJ0aHJ1XCIsZT0vXig/OnBvcHxzaGlmdCkkLy50ZXN0KG4pO09uLnByb3RvdHlwZVtuXT1mdW5jdGlvbigpe3ZhciBuPWFyZ3VtZW50cztpZihlJiYhdGhpcy5fX2NoYWluX18pe1xudmFyIHU9dGhpcy52YWx1ZSgpO3JldHVybiB0LmFwcGx5KGFmKHUpP3U6W10sbil9cmV0dXJuIHRoaXNbcl0oZnVuY3Rpb24ocil7cmV0dXJuIHQuYXBwbHkoYWYocik/cjpbXSxuKX0pfX0pLEV0KE1uLnByb3RvdHlwZSxmdW5jdGlvbihuLHQpe3ZhciByPU9uW3RdO2lmKHIpe3ZhciBlPXIubmFtZStcIlwiOyhKaVtlXXx8KEppW2VdPVtdKSkucHVzaCh7bmFtZTp0LGZ1bmM6cn0pfX0pLEppW1hyKEYsMikubmFtZV09W3tuYW1lOlwid3JhcHBlclwiLGZ1bmM6Rn1dLE1uLnByb3RvdHlwZS5jbG9uZT1mdW5jdGlvbigpe3ZhciBuPW5ldyBNbih0aGlzLl9fd3JhcHBlZF9fKTtyZXR1cm4gbi5fX2FjdGlvbnNfXz1Ncih0aGlzLl9fYWN0aW9uc19fKSxuLl9fZGlyX189dGhpcy5fX2Rpcl9fLG4uX19maWx0ZXJlZF9fPXRoaXMuX19maWx0ZXJlZF9fLG4uX19pdGVyYXRlZXNfXz1Ncih0aGlzLl9faXRlcmF0ZWVzX18pLG4uX190YWtlQ291bnRfXz10aGlzLl9fdGFrZUNvdW50X18sbi5fX3ZpZXdzX189TXIodGhpcy5fX3ZpZXdzX18pLFxubn0sTW4ucHJvdG90eXBlLnJldmVyc2U9ZnVuY3Rpb24oKXtpZih0aGlzLl9fZmlsdGVyZWRfXyl7dmFyIG49bmV3IE1uKHRoaXMpO24uX19kaXJfXz0tMSxuLl9fZmlsdGVyZWRfXz10cnVlfWVsc2Ugbj10aGlzLmNsb25lKCksbi5fX2Rpcl9fKj0tMTtyZXR1cm4gbn0sTW4ucHJvdG90eXBlLnZhbHVlPWZ1bmN0aW9uKCl7dmFyIG4sdD10aGlzLl9fd3JhcHBlZF9fLnZhbHVlKCkscj10aGlzLl9fZGlyX18sZT1hZih0KSx1PTA+cixpPWU/dC5sZW5ndGg6MDtuPWk7Zm9yKHZhciBvPXRoaXMuX192aWV3c19fLGY9MCxjPS0xLGE9by5sZW5ndGg7KytjPGE7KXt2YXIgbD1vW2NdLHM9bC5zaXplO3N3aXRjaChsLnR5cGUpe2Nhc2VcImRyb3BcIjpmKz1zO2JyZWFrO2Nhc2VcImRyb3BSaWdodFwiOm4tPXM7YnJlYWs7Y2FzZVwidGFrZVwiOm49TWkobixmK3MpO2JyZWFrO2Nhc2VcInRha2VSaWdodFwiOmY9RGkoZixuLXMpfX1pZihuPXtzdGFydDpmLGVuZDpufSxvPW4uc3RhcnQsZj1uLmVuZCxuPWYtbyxcbm89dT9mOm8tMSxmPXRoaXMuX19pdGVyYXRlZXNfXyxjPWYubGVuZ3RoLGE9MCxsPU1pKG4sdGhpcy5fX3Rha2VDb3VudF9fKSwhZXx8IXUmJmk9PW4mJmw9PW4pcmV0dXJuIGtyKHQsdGhpcy5fX2FjdGlvbnNfXyk7ZT1bXTtuOmZvcig7bi0tJiZhPGw7KXtmb3Iobys9cix1PS0xLGk9dFtvXTsrK3U8Yzspe3ZhciBoPWZbdV0scz1oLnR5cGUsaD0oMCxoLml0ZXJhdGVlKShpKTtpZigyPT1zKWk9aDtlbHNlIGlmKCFoKXtpZigxPT1zKWNvbnRpbnVlIG47YnJlYWsgbn19ZVthKytdPWl9cmV0dXJuIGV9LE9uLnByb3RvdHlwZS5hdD1GbyxPbi5wcm90b3R5cGUuY2hhaW49ZnVuY3Rpb24oKXtyZXR1cm4gWGUodGhpcyl9LE9uLnByb3RvdHlwZS5jb21taXQ9ZnVuY3Rpb24oKXtyZXR1cm4gbmV3IHpuKHRoaXMudmFsdWUoKSx0aGlzLl9fY2hhaW5fXyl9LE9uLnByb3RvdHlwZS5uZXh0PWZ1bmN0aW9uKCl7dGhpcy5fX3ZhbHVlc19fPT09RiYmKHRoaXMuX192YWx1ZXNfXz1rdSh0aGlzLnZhbHVlKCkpKTtcbnZhciBuPXRoaXMuX19pbmRleF9fPj10aGlzLl9fdmFsdWVzX18ubGVuZ3RoO3JldHVybntkb25lOm4sdmFsdWU6bj9GOnRoaXMuX192YWx1ZXNfX1t0aGlzLl9faW5kZXhfXysrXX19LE9uLnByb3RvdHlwZS5wbGFudD1mdW5jdGlvbihuKXtmb3IodmFyIHQscj10aGlzO3IgaW5zdGFuY2VvZiBTbjspe3ZhciBlPVBlKHIpO2UuX19pbmRleF9fPTAsZS5fX3ZhbHVlc19fPUYsdD91Ll9fd3JhcHBlZF9fPWU6dD1lO3ZhciB1PWUscj1yLl9fd3JhcHBlZF9ffXJldHVybiB1Ll9fd3JhcHBlZF9fPW4sdH0sT24ucHJvdG90eXBlLnJldmVyc2U9ZnVuY3Rpb24oKXt2YXIgbj10aGlzLl9fd3JhcHBlZF9fO3JldHVybiBuIGluc3RhbmNlb2YgTW4/KHRoaXMuX19hY3Rpb25zX18ubGVuZ3RoJiYobj1uZXcgTW4odGhpcykpLG49bi5yZXZlcnNlKCksbi5fX2FjdGlvbnNfXy5wdXNoKHtmdW5jOm51LGFyZ3M6W0plXSx0aGlzQXJnOkZ9KSxuZXcgem4obix0aGlzLl9fY2hhaW5fXykpOnRoaXMudGhydShKZSk7XG59LE9uLnByb3RvdHlwZS50b0pTT049T24ucHJvdG90eXBlLnZhbHVlT2Y9T24ucHJvdG90eXBlLnZhbHVlPWZ1bmN0aW9uKCl7cmV0dXJuIGtyKHRoaXMuX193cmFwcGVkX18sdGhpcy5fX2FjdGlvbnNfXyl9LE9uLnByb3RvdHlwZS5maXJzdD1Pbi5wcm90b3R5cGUuaGVhZCxBaSYmKE9uLnByb3RvdHlwZVtBaV09dHUpLE9ufSgpO3R5cGVvZiBkZWZpbmU9PVwiZnVuY3Rpb25cIiYmdHlwZW9mIGRlZmluZS5hbWQ9PVwib2JqZWN0XCImJmRlZmluZS5hbWQ/KFpuLl89aXQsIGRlZmluZShmdW5jdGlvbigpe3JldHVybiBpdH0pKTpWbj8oKFZuLmV4cG9ydHM9aXQpLl89aXQscW4uXz1pdCk6Wm4uXz1pdH0pLmNhbGwodGhpcyk7XG5cblxuLy8vLy8vLy8vLy8vLy8vLy8vXG4vLyBXRUJQQUNLIEZPT1RFUlxuLy8gLi9+L2xvZGFzaC9sb2Rhc2gubWluLmpzXG4vLyBtb2R1bGUgaWQgPSAuL25vZGVfbW9kdWxlcy9sb2Rhc2gvbG9kYXNoLm1pbi5qc1xuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QSIsInNvdXJjZVJvb3QiOiIifQ=="); +/* WEBPACK VAR INJECTION */(function(global, module) {var __WEBPACK_AMD_DEFINE_RESULT__;/** + * @license + * Lodash lodash.com/license | Underscore.js 1.8.3 underscorejs.org/LICENSE + */ +;(function(){function n(n,t){return n.set(t[0],t[1]),n}function t(n,t){return n.add(t),n}function r(n,t,r){switch(r.length){case 0:return n.call(t);case 1:return n.call(t,r[0]);case 2:return n.call(t,r[0],r[1]);case 3:return n.call(t,r[0],r[1],r[2])}return n.apply(t,r)}function e(n,t,r,e){for(var u=-1,i=null==n?0:n.length;++u"']/g,J=RegExp(G.source),Y=RegExp(H.source),Q=/<%-([\s\S]+?)%>/g,X=/<%([\s\S]+?)%>/g,nn=/<%=([\s\S]+?)%>/g,tn=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,rn=/^\w*$/,en=/^\./,un=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,on=/[\\^$.*+?()[\]{}|]/g,fn=RegExp(on.source),cn=/^\s+|\s+$/g,an=/^\s+/,ln=/\s+$/,sn=/\{(?:\n\/\* \[wrapped with .+\] \*\/)?\n?/,hn=/\{\n\/\* \[wrapped with (.+)\] \*/,pn=/,? & /,_n=/[^\x00-\x2f\x3a-\x40\x5b-\x60\x7b-\x7f]+/g,vn=/\\(\\)?/g,gn=/\$\{([^\\}]*(?:\\.[^\\}]*)*)\}/g,dn=/\w*$/,yn=/^[-+]0x[0-9a-f]+$/i,bn=/^0b[01]+$/i,xn=/^\[object .+?Constructor\]$/,jn=/^0o[0-7]+$/i,wn=/^(?:0|[1-9]\d*)$/,mn=/[\xc0-\xd6\xd8-\xf6\xf8-\xff\u0100-\u017f]/g,An=/($^)/,kn=/['\n\r\u2028\u2029\\]/g,En="[\\ufe0e\\ufe0f]?(?:[\\u0300-\\u036f\\ufe20-\\ufe2f\\u20d0-\\u20ff]|\\ud83c[\\udffb-\\udfff])?(?:\\u200d(?:[^\\ud800-\\udfff]|(?:\\ud83c[\\udde6-\\uddff]){2}|[\\ud800-\\udbff][\\udc00-\\udfff])[\\ufe0e\\ufe0f]?(?:[\\u0300-\\u036f\\ufe20-\\ufe2f\\u20d0-\\u20ff]|\\ud83c[\\udffb-\\udfff])?)*",On="(?:[\\u2700-\\u27bf]|(?:\\ud83c[\\udde6-\\uddff]){2}|[\\ud800-\\udbff][\\udc00-\\udfff])"+En,Sn="(?:[^\\ud800-\\udfff][\\u0300-\\u036f\\ufe20-\\ufe2f\\u20d0-\\u20ff]?|[\\u0300-\\u036f\\ufe20-\\ufe2f\\u20d0-\\u20ff]|(?:\\ud83c[\\udde6-\\uddff]){2}|[\\ud800-\\udbff][\\udc00-\\udfff]|[\\ud800-\\udfff])",In=RegExp("['\u2019]","g"),Rn=RegExp("[\\u0300-\\u036f\\ufe20-\\ufe2f\\u20d0-\\u20ff]","g"),zn=RegExp("\\ud83c[\\udffb-\\udfff](?=\\ud83c[\\udffb-\\udfff])|"+Sn+En,"g"),Wn=RegExp(["[A-Z\\xc0-\\xd6\\xd8-\\xde]?[a-z\\xdf-\\xf6\\xf8-\\xff]+(?:['\u2019](?:d|ll|m|re|s|t|ve))?(?=[\\xac\\xb1\\xd7\\xf7\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf\\u2000-\\u206f \\t\\x0b\\f\\xa0\\ufeff\\n\\r\\u2028\\u2029\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000]|[A-Z\\xc0-\\xd6\\xd8-\\xde]|$)|(?:[A-Z\\xc0-\\xd6\\xd8-\\xde]|[^\\ud800-\\udfff\\xac\\xb1\\xd7\\xf7\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf\\u2000-\\u206f \\t\\x0b\\f\\xa0\\ufeff\\n\\r\\u2028\\u2029\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000\\d+\\u2700-\\u27bfa-z\\xdf-\\xf6\\xf8-\\xffA-Z\\xc0-\\xd6\\xd8-\\xde])+(?:['\u2019](?:D|LL|M|RE|S|T|VE))?(?=[\\xac\\xb1\\xd7\\xf7\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf\\u2000-\\u206f \\t\\x0b\\f\\xa0\\ufeff\\n\\r\\u2028\\u2029\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000]|[A-Z\\xc0-\\xd6\\xd8-\\xde](?:[a-z\\xdf-\\xf6\\xf8-\\xff]|[^\\ud800-\\udfff\\xac\\xb1\\xd7\\xf7\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf\\u2000-\\u206f \\t\\x0b\\f\\xa0\\ufeff\\n\\r\\u2028\\u2029\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000\\d+\\u2700-\\u27bfa-z\\xdf-\\xf6\\xf8-\\xffA-Z\\xc0-\\xd6\\xd8-\\xde])|$)|[A-Z\\xc0-\\xd6\\xd8-\\xde]?(?:[a-z\\xdf-\\xf6\\xf8-\\xff]|[^\\ud800-\\udfff\\xac\\xb1\\xd7\\xf7\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf\\u2000-\\u206f \\t\\x0b\\f\\xa0\\ufeff\\n\\r\\u2028\\u2029\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000\\d+\\u2700-\\u27bfa-z\\xdf-\\xf6\\xf8-\\xffA-Z\\xc0-\\xd6\\xd8-\\xde])+(?:['\u2019](?:d|ll|m|re|s|t|ve))?|[A-Z\\xc0-\\xd6\\xd8-\\xde]+(?:['\u2019](?:D|LL|M|RE|S|T|VE))?|\\d*(?:(?:1ST|2ND|3RD|(?![123])\\dTH)\\b)|\\d*(?:(?:1st|2nd|3rd|(?![123])\\dth)\\b)|\\d+",On].join("|"),"g"),Bn=RegExp("[\\u200d\\ud800-\\udfff\\u0300-\\u036f\\ufe20-\\ufe2f\\u20d0-\\u20ff\\ufe0e\\ufe0f]"),Ln=/[a-z][A-Z]|[A-Z]{2,}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/,Un="Array Buffer DataView Date Error Float32Array Float64Array Function Int8Array Int16Array Int32Array Map Math Object Promise RegExp Set String Symbol TypeError Uint8Array Uint8ClampedArray Uint16Array Uint32Array WeakMap _ clearTimeout isFinite parseInt setTimeout".split(" "),Cn={}; +Cn["[object Float32Array]"]=Cn["[object Float64Array]"]=Cn["[object Int8Array]"]=Cn["[object Int16Array]"]=Cn["[object Int32Array]"]=Cn["[object Uint8Array]"]=Cn["[object Uint8ClampedArray]"]=Cn["[object Uint16Array]"]=Cn["[object Uint32Array]"]=true,Cn["[object Arguments]"]=Cn["[object Array]"]=Cn["[object ArrayBuffer]"]=Cn["[object Boolean]"]=Cn["[object DataView]"]=Cn["[object Date]"]=Cn["[object Error]"]=Cn["[object Function]"]=Cn["[object Map]"]=Cn["[object Number]"]=Cn["[object Object]"]=Cn["[object RegExp]"]=Cn["[object Set]"]=Cn["[object String]"]=Cn["[object WeakMap]"]=false; +var Dn={};Dn["[object Arguments]"]=Dn["[object Array]"]=Dn["[object ArrayBuffer]"]=Dn["[object DataView]"]=Dn["[object Boolean]"]=Dn["[object Date]"]=Dn["[object Float32Array]"]=Dn["[object Float64Array]"]=Dn["[object Int8Array]"]=Dn["[object Int16Array]"]=Dn["[object Int32Array]"]=Dn["[object Map]"]=Dn["[object Number]"]=Dn["[object Object]"]=Dn["[object RegExp]"]=Dn["[object Set]"]=Dn["[object String]"]=Dn["[object Symbol]"]=Dn["[object Uint8Array]"]=Dn["[object Uint8ClampedArray]"]=Dn["[object Uint16Array]"]=Dn["[object Uint32Array]"]=true, +Dn["[object Error]"]=Dn["[object Function]"]=Dn["[object WeakMap]"]=false;var Mn,Tn={"\\":"\\","'":"'","\n":"n","\r":"r","\u2028":"u2028","\u2029":"u2029"},$n=parseFloat,Fn=parseInt,Nn=typeof global=="object"&&global&&global.Object===Object&&global,Pn=typeof self=="object"&&self&&self.Object===Object&&self,Zn=Nn||Pn||Function("return this")(),qn=typeof exports=="object"&&exports&&!exports.nodeType&&exports,Vn=qn&&typeof module=="object"&&module&&!module.nodeType&&module,Kn=Vn&&Vn.exports===qn,Gn=Kn&&Nn.process; +n:{try{Mn=Gn&&Gn.binding&&Gn.binding("util");break n}catch(n){}Mn=void 0}var Hn=Mn&&Mn.isArrayBuffer,Jn=Mn&&Mn.isDate,Yn=Mn&&Mn.isMap,Qn=Mn&&Mn.isRegExp,Xn=Mn&&Mn.isSet,nt=Mn&&Mn.isTypedArray,tt=j("length"),rt=w({"\xc0":"A","\xc1":"A","\xc2":"A","\xc3":"A","\xc4":"A","\xc5":"A","\xe0":"a","\xe1":"a","\xe2":"a","\xe3":"a","\xe4":"a","\xe5":"a","\xc7":"C","\xe7":"c","\xd0":"D","\xf0":"d","\xc8":"E","\xc9":"E","\xca":"E","\xcb":"E","\xe8":"e","\xe9":"e","\xea":"e","\xeb":"e","\xcc":"I","\xcd":"I","\xce":"I", +"\xcf":"I","\xec":"i","\xed":"i","\xee":"i","\xef":"i","\xd1":"N","\xf1":"n","\xd2":"O","\xd3":"O","\xd4":"O","\xd5":"O","\xd6":"O","\xd8":"O","\xf2":"o","\xf3":"o","\xf4":"o","\xf5":"o","\xf6":"o","\xf8":"o","\xd9":"U","\xda":"U","\xdb":"U","\xdc":"U","\xf9":"u","\xfa":"u","\xfb":"u","\xfc":"u","\xdd":"Y","\xfd":"y","\xff":"y","\xc6":"Ae","\xe6":"ae","\xde":"Th","\xfe":"th","\xdf":"ss","\u0100":"A","\u0102":"A","\u0104":"A","\u0101":"a","\u0103":"a","\u0105":"a","\u0106":"C","\u0108":"C","\u010a":"C", +"\u010c":"C","\u0107":"c","\u0109":"c","\u010b":"c","\u010d":"c","\u010e":"D","\u0110":"D","\u010f":"d","\u0111":"d","\u0112":"E","\u0114":"E","\u0116":"E","\u0118":"E","\u011a":"E","\u0113":"e","\u0115":"e","\u0117":"e","\u0119":"e","\u011b":"e","\u011c":"G","\u011e":"G","\u0120":"G","\u0122":"G","\u011d":"g","\u011f":"g","\u0121":"g","\u0123":"g","\u0124":"H","\u0126":"H","\u0125":"h","\u0127":"h","\u0128":"I","\u012a":"I","\u012c":"I","\u012e":"I","\u0130":"I","\u0129":"i","\u012b":"i","\u012d":"i", +"\u012f":"i","\u0131":"i","\u0134":"J","\u0135":"j","\u0136":"K","\u0137":"k","\u0138":"k","\u0139":"L","\u013b":"L","\u013d":"L","\u013f":"L","\u0141":"L","\u013a":"l","\u013c":"l","\u013e":"l","\u0140":"l","\u0142":"l","\u0143":"N","\u0145":"N","\u0147":"N","\u014a":"N","\u0144":"n","\u0146":"n","\u0148":"n","\u014b":"n","\u014c":"O","\u014e":"O","\u0150":"O","\u014d":"o","\u014f":"o","\u0151":"o","\u0154":"R","\u0156":"R","\u0158":"R","\u0155":"r","\u0157":"r","\u0159":"r","\u015a":"S","\u015c":"S", +"\u015e":"S","\u0160":"S","\u015b":"s","\u015d":"s","\u015f":"s","\u0161":"s","\u0162":"T","\u0164":"T","\u0166":"T","\u0163":"t","\u0165":"t","\u0167":"t","\u0168":"U","\u016a":"U","\u016c":"U","\u016e":"U","\u0170":"U","\u0172":"U","\u0169":"u","\u016b":"u","\u016d":"u","\u016f":"u","\u0171":"u","\u0173":"u","\u0174":"W","\u0175":"w","\u0176":"Y","\u0177":"y","\u0178":"Y","\u0179":"Z","\u017b":"Z","\u017d":"Z","\u017a":"z","\u017c":"z","\u017e":"z","\u0132":"IJ","\u0133":"ij","\u0152":"Oe","\u0153":"oe", +"\u0149":"'n","\u017f":"s"}),et=w({"&":"&","<":"<",">":">",'"':""","'":"'"}),ut=w({"&":"&","<":"<",">":">",""":'"',"'":"'"}),it=function w(En){function On(n){if(xu(n)&&!af(n)&&!(n instanceof Mn)){if(n instanceof zn)return n;if(ci.call(n,"__wrapped__"))return Pe(n)}return new zn(n)}function Sn(){}function zn(n,t){this.__wrapped__=n,this.__actions__=[],this.__chain__=!!t,this.__index__=0,this.__values__=F}function Mn(n){this.__wrapped__=n,this.__actions__=[],this.__dir__=1, +this.__filtered__=false,this.__iteratees__=[],this.__takeCount__=4294967295,this.__views__=[]}function Tn(n){var t=-1,r=null==n?0:n.length;for(this.clear();++t=t?n:t)),n}function dt(n,t,r,e,i,o){var f,c=1&t,a=2&t,l=4&t;if(r&&(f=i?r(n,e,i,o):r(n)),f!==F)return f;if(!bu(n))return n;if(e=af(n)){if(f=Ee(n),!c)return Mr(n,f)}else{var s=yo(n),h="[object Function]"==s||"[object GeneratorFunction]"==s;if(sf(n))return Wr(n,c);if("[object Object]"==s||"[object Arguments]"==s||h&&!i){if(f=a||h?{}:Oe(n),!c)return a?Fr(n,pt(f,n)):$r(n,ht(f,n))}else{if(!Dn[s])return i?n:{};f=Se(n,s,dt,c)}}if(o||(o=new Vn), +i=o.get(n))return i;o.set(n,f);var a=l?a?ye:de:a?Uu:Lu,p=e?F:a(n);return u(p||n,function(e,u){p&&(u=e,e=n[u]),at(f,u,dt(e,t,r,u,n,o))}),f}function yt(n){var t=Lu(n);return function(r){return bt(r,n,t)}}function bt(n,t,r){var e=r.length;if(null==n)return!e;for(n=ni(n);e--;){var u=r[e],i=t[u],o=n[u];if(o===F&&!(u in n)||!i(o))return false}return true}function xt(n,t,r){if(typeof n!="function")throw new ei("Expected a function");return jo(function(){n.apply(F,r)},t)}function jt(n,t,r,e){var u=-1,i=c,o=true,f=n.length,s=[],h=t.length; +if(!f)return s;r&&(t=l(t,S(r))),e?(i=a,o=false):200<=t.length&&(i=R,o=false,t=new qn(t));n:for(;++ut}function Bt(n,t){return null!=n&&ci.call(n,t)}function Lt(n,t){return null!=n&&t in ni(n)}function Ut(n,t,r){for(var e=r?a:c,u=n[0].length,i=n.length,o=i,f=Hu(i),s=1/0,h=[];o--;){var p=n[o];o&&t&&(p=l(p,S(t))),s=Mi(p.length,s),f[o]=!r&&(t||120<=u&&120<=p.length)?new qn(o&&p):F}var p=n[0],_=-1,v=f[0];n:for(;++_t.length?n:It(n,vr(t,0,-1)),t=null==n?n:n[$e(Ge(t))],null==t?F:r(t,n,e)}function Mt(n){return xu(n)&&"[object Arguments]"==zt(n)}function Tt(n){return xu(n)&&"[object ArrayBuffer]"==zt(n)}function $t(n){return xu(n)&&"[object Date]"==zt(n)}function Ft(n,t,r,e,u){if(n===t)t=true;else if(null==n||null==t||!xu(n)&&!xu(t))t=n!==n&&t!==t;else n:{ +var i=af(n),o=af(t),f=i?"[object Array]":yo(n),c=o?"[object Array]":yo(t),f="[object Arguments]"==f?"[object Object]":f,c="[object Arguments]"==c?"[object Object]":c,a="[object Object]"==f,o="[object Object]"==c;if((c=f==c)&&sf(n)){if(!sf(t)){t=false;break n}i=true,a=false}if(c&&!a)u||(u=new Vn),t=i||gf(n)?_e(n,t,r,e,Ft,u):ve(n,t,f,r,e,Ft,u);else{if(!(1&r)&&(i=a&&ci.call(n,"__wrapped__"),f=o&&ci.call(t,"__wrapped__"),i||f)){n=i?n.value():n,t=f?t.value():t,u||(u=new Vn),t=Ft(n,t,r,e,u);break n}if(c)t:if(u||(u=new Vn), +i=1&r,f=de(n),o=f.length,c=de(t).length,o==c||i){for(a=o;a--;){var l=f[a];if(!(i?l in t:ci.call(t,l))){t=false;break t}}if((c=u.get(n))&&u.get(t))t=c==t;else{c=true,u.set(n,t),u.set(t,n);for(var s=i;++at?r:0,Re(t,r)?n[t]:F}function rr(n,t,r){var e=-1;return t=l(t.length?t:[Nu],S(je())),n=Yt(n,function(n){return{a:l(t,function(t){return t(n)}),b:++e,c:n}}),A(n,function(n,t){var e;n:{e=-1;for(var u=n.a,i=t.a,o=u.length,f=r.length;++e=f?c:c*("desc"==r[e]?-1:1); +break n}}e=n.b-t.b}return e})}function er(n,t){return ur(n,t,function(t,r){return Bu(n,r)})}function ur(n,t,r){for(var e=-1,u=t.length,i={};++et||9007199254740991t&&(t=-t>u?0:u+t),r=r>u?u:r,0>r&&(r+=u),u=t>r?0:r-t>>>0,t>>>=0,r=Hu(u);++e=u){for(;e>>1,o=n[i];null!==o&&!Au(o)&&(r?o<=t:ot.length?n:It(n,vr(t,0,-1)), +null==n||delete n[$e(Ge(t))]}function Ar(n,t,r,e){for(var u=n.length,i=e?u:-1;(e?i--:++ie)return e?wr(n[0]):[];for(var u=-1,i=Hu(e);++u=e?n:vr(n,t,r)}function Wr(n,t){if(t)return n.slice();var r=n.length,r=yi?yi(r):new n.constructor(r);return n.copy(r),r}function Br(n){var t=new n.constructor(n.byteLength);return new di(t).set(new di(n)),t}function Lr(n,t){return new n.constructor(t?Br(n.buffer):n.buffer,n.byteOffset,n.length)}function Ur(n,t){ +if(n!==t){var r=n!==F,e=null===n,u=n===n,i=Au(n),o=t!==F,f=null===t,c=t===t,a=Au(t);if(!f&&!a&&!i&&n>t||i&&o&&c&&!f&&!a||e&&o&&c||!r&&c||!u)return 1;if(!e&&!i&&!a&&nu?F:i,u=1),t=ni(t);++eo&&f[0]!==a&&f[o-1]!==a?[]:C(f,a),o-=c.length,or?r?ar(t,n):t:(r=ar(t,Ri(n/T(t))),Bn.test(t)?zr($(r),0,n).join(""):r.slice(0,n))}function ue(n,t,e,u){function i(){for(var t=-1,c=arguments.length,a=-1,l=u.length,s=Hu(l+c),h=this&&this!==Zn&&this instanceof i?f:n;++at||e)&&(1&n&&(i[2]=h[2],t|=1&r?0:4),(r=h[3])&&(e=i[3],i[3]=e?Cr(e,r,h[4]):r,i[4]=e?C(i[3],"__lodash_placeholder__"):h[4]),(r=h[5])&&(e=i[5],i[5]=e?Dr(e,r,h[6]):r,i[6]=e?C(i[5],"__lodash_placeholder__"):h[6]),(r=h[7])&&(i[7]=r),128&n&&(i[8]=null==i[8]?h[8]:Mi(i[8],h[8])),null==i[9]&&(i[9]=h[9]),i[0]=h[0],i[1]=t),n=i[0],t=i[1], +r=i[2],e=i[3],u=i[4],f=i[9]=i[9]===F?c?0:n.length:Di(i[9]-a,0),!f&&24&t&&(t&=-25),De((h?lo:xo)(t&&1!=t?8==t||16==t?Jr(n,t,f):32!=t&&33!=t||u.length?Xr.apply(F,i):ue(n,t,r,e):Vr(n,t,r),i),n,t)}function se(n,t,r,e){return n===F||hu(n,ii[r])&&!ci.call(e,r)?t:n}function he(n,t,r,e,u,i){return bu(n)&&bu(t)&&(i.set(t,n),nr(n,t,F,he,i),i.delete(t)),n}function pe(n){return wu(n)?F:n}function _e(n,t,r,e,u,i){var o=1&r,f=n.length,c=t.length;if(f!=c&&!(o&&c>f))return false;if((c=i.get(n))&&i.get(t))return c==t;var c=-1,a=true,l=2&r?new qn:F; +for(i.set(n,t),i.set(t,n);++cr&&(r=Di(e+r,0)),g(n,je(t,3),r)):-1}function qe(n,t,r){var e=null==n?0:n.length;if(!e)return-1;var u=e-1;return r!==F&&(u=Ou(r),u=0>r?Di(e+u,0):Mi(u,e-1)), +g(n,je(t,3),u,true)}function Ve(n){return(null==n?0:n.length)?kt(n,1):[]}function Ke(n){return n&&n.length?n[0]:F}function Ge(n){var t=null==n?0:n.length;return t?n[t-1]:F}function He(n,t){return n&&n.length&&t&&t.length?or(n,t):n}function Je(n){return null==n?n:Ni.call(n)}function Ye(n){if(!n||!n.length)return[];var t=0;return n=f(n,function(n){if(_u(n))return t=Di(n.length,t),true}),E(t,function(t){return l(n,j(t))})}function Qe(n,t){if(!n||!n.length)return[];var e=Ye(n);return null==t?e:l(e,function(n){ +return r(t,F,n)})}function Xe(n){return n=On(n),n.__chain__=true,n}function nu(n,t){return t(n)}function tu(){return this}function ru(n,t){return(af(n)?u:oo)(n,je(t,3))}function eu(n,t){return(af(n)?i:fo)(n,je(t,3))}function uu(n,t){return(af(n)?l:Yt)(n,je(t,3))}function iu(n,t,r){return t=r?F:t,t=n&&null==t?n.length:t,le(n,128,F,F,F,F,t)}function ou(n,t){var r;if(typeof t!="function")throw new ei("Expected a function");return n=Ou(n),function(){return 0<--n&&(r=t.apply(this,arguments)),1>=n&&(t=F), +r}}function fu(n,t,r){return t=r?F:t,n=le(n,8,F,F,F,F,F,t),n.placeholder=fu.placeholder,n}function cu(n,t,r){return t=r?F:t,n=le(n,16,F,F,F,F,F,t),n.placeholder=cu.placeholder,n}function au(n,t,r){function e(t){var r=c,e=a;return c=a=F,_=t,s=n.apply(e,r)}function u(n){var r=n-p;return n-=_,p===F||r>=t||0>r||g&&n>=l}function i(){var n=Jo();if(u(n))return o(n);var r,e=jo;r=n-_,n=t-(n-p),r=g?Mi(n,l-r):n,h=e(i,r)}function o(n){return h=F,d&&c?e(n):(c=a=F,s)}function f(){var n=Jo(),r=u(n);if(c=arguments, +a=this,p=n,r){if(h===F)return _=n=p,h=jo(i,t),v?e(n):s;if(g)return h=jo(i,t),e(p)}return h===F&&(h=jo(i,t)),s}var c,a,l,s,h,p,_=0,v=false,g=false,d=true;if(typeof n!="function")throw new ei("Expected a function");return t=Iu(t)||0,bu(r)&&(v=!!r.leading,l=(g="maxWait"in r)?Di(Iu(r.maxWait)||0,t):l,d="trailing"in r?!!r.trailing:d),f.cancel=function(){h!==F&&ho(h),_=0,c=p=a=h=F},f.flush=function(){return h===F?s:o(Jo())},f}function lu(n,t){function r(){var e=arguments,u=t?t.apply(this,e):e[0],i=r.cache;return i.has(u)?i.get(u):(e=n.apply(this,e), +r.cache=i.set(u,e)||i,e)}if(typeof n!="function"||null!=t&&typeof t!="function")throw new ei("Expected a function");return r.cache=new(lu.Cache||Pn),r}function su(n){if(typeof n!="function")throw new ei("Expected a function");return function(){var t=arguments;switch(t.length){case 0:return!n.call(this);case 1:return!n.call(this,t[0]);case 2:return!n.call(this,t[0],t[1]);case 3:return!n.call(this,t[0],t[1],t[2])}return!n.apply(this,t)}}function hu(n,t){return n===t||n!==n&&t!==t}function pu(n){return null!=n&&yu(n.length)&&!gu(n); +}function _u(n){return xu(n)&&pu(n)}function vu(n){if(!xu(n))return false;var t=zt(n);return"[object Error]"==t||"[object DOMException]"==t||typeof n.message=="string"&&typeof n.name=="string"&&!wu(n)}function gu(n){return!!bu(n)&&(n=zt(n),"[object Function]"==n||"[object GeneratorFunction]"==n||"[object AsyncFunction]"==n||"[object Proxy]"==n)}function du(n){return typeof n=="number"&&n==Ou(n)}function yu(n){return typeof n=="number"&&-1=n}function bu(n){var t=typeof n;return null!=n&&("object"==t||"function"==t); +}function xu(n){return null!=n&&typeof n=="object"}function ju(n){return typeof n=="number"||xu(n)&&"[object Number]"==zt(n)}function wu(n){return!(!xu(n)||"[object Object]"!=zt(n))&&(n=bi(n),null===n||(n=ci.call(n,"constructor")&&n.constructor,typeof n=="function"&&n instanceof n&&fi.call(n)==hi))}function mu(n){return typeof n=="string"||!af(n)&&xu(n)&&"[object String]"==zt(n)}function Au(n){return typeof n=="symbol"||xu(n)&&"[object Symbol]"==zt(n)}function ku(n){if(!n)return[];if(pu(n))return mu(n)?$(n):Mr(n); +if(Ai&&n[Ai]){n=n[Ai]();for(var t,r=[];!(t=n.next()).done;)r.push(t.value);return r}return t=yo(n),("[object Map]"==t?L:"[object Set]"==t?D:Du)(n)}function Eu(n){return n?(n=Iu(n),n===N||n===-N?1.7976931348623157e308*(0>n?-1:1):n===n?n:0):0===n?n:0}function Ou(n){n=Eu(n);var t=n%1;return n===n?t?n-t:n:0}function Su(n){return n?gt(Ou(n),0,4294967295):0}function Iu(n){if(typeof n=="number")return n;if(Au(n))return P;if(bu(n)&&(n=typeof n.valueOf=="function"?n.valueOf():n,n=bu(n)?n+"":n),typeof n!="string")return 0===n?n:+n; +n=n.replace(cn,"");var t=bn.test(n);return t||jn.test(n)?Fn(n.slice(2),t?2:8):yn.test(n)?P:+n}function Ru(n){return Tr(n,Uu(n))}function zu(n){return null==n?"":jr(n)}function Wu(n,t,r){return n=null==n?F:It(n,t),n===F?r:n}function Bu(n,t){return null!=n&&ke(n,t,Lt)}function Lu(n){return pu(n)?Gn(n):Ht(n)}function Uu(n){if(pu(n))n=Gn(n,true);else if(bu(n)){var t,r=Le(n),e=[];for(t in n)("constructor"!=t||!r&&ci.call(n,t))&&e.push(t);n=e}else{if(t=[],null!=n)for(r in ni(n))t.push(r);n=t}return n}function Cu(n,t){ +if(null==n)return{};var r=l(ye(n),function(n){return[n]});return t=je(t),ur(n,r,function(n,r){return t(n,r[0])})}function Du(n){return null==n?[]:I(n,Lu(n))}function Mu(n){return Nf(zu(n).toLowerCase())}function Tu(n){return(n=zu(n))&&n.replace(mn,rt).replace(Rn,"")}function $u(n,t,r){return n=zu(n),t=r?F:t,t===F?Ln.test(n)?n.match(Wn)||[]:n.match(_n)||[]:n.match(t)||[]}function Fu(n){return function(){return n}}function Nu(n){return n}function Pu(n){return Gt(typeof n=="function"?n:dt(n,1))}function Zu(n,t,r){ +var e=Lu(t),i=St(t,e);null!=r||bu(t)&&(i.length||!e.length)||(r=t,t=n,n=this,i=St(t,Lu(t)));var o=!(bu(r)&&"chain"in r&&!r.chain),f=gu(n);return u(i,function(r){var e=t[r];n[r]=e,f&&(n.prototype[r]=function(){var t=this.__chain__;if(o||t){var r=n(this.__wrapped__);return(r.__actions__=Mr(this.__actions__)).push({func:e,args:arguments,thisArg:n}),r.__chain__=t,r}return e.apply(n,s([this.value()],arguments))})}),n}function qu(){}function Vu(n){return We(n)?j($e(n)):ir(n)}function Ku(){return[]}function Gu(){ +return false}En=null==En?Zn:it.defaults(Zn.Object(),En,it.pick(Zn,Un));var Hu=En.Array,Ju=En.Date,Yu=En.Error,Qu=En.Function,Xu=En.Math,ni=En.Object,ti=En.RegExp,ri=En.String,ei=En.TypeError,ui=Hu.prototype,ii=ni.prototype,oi=En["__core-js_shared__"],fi=Qu.prototype.toString,ci=ii.hasOwnProperty,ai=0,li=function(){var n=/[^.]+$/.exec(oi&&oi.keys&&oi.keys.IE_PROTO||"");return n?"Symbol(src)_1."+n:""}(),si=ii.toString,hi=fi.call(ni),pi=Zn._,_i=ti("^"+fi.call(ci).replace(on,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$"),vi=Kn?En.Buffer:F,gi=En.Symbol,di=En.Uint8Array,yi=vi?vi.f:F,bi=U(ni.getPrototypeOf,ni),xi=ni.create,ji=ii.propertyIsEnumerable,wi=ui.splice,mi=gi?gi.isConcatSpreadable:F,Ai=gi?gi.iterator:F,ki=gi?gi.toStringTag:F,Ei=function(){ +try{var n=Ae(ni,"defineProperty");return n({},"",{}),n}catch(n){}}(),Oi=En.clearTimeout!==Zn.clearTimeout&&En.clearTimeout,Si=Ju&&Ju.now!==Zn.Date.now&&Ju.now,Ii=En.setTimeout!==Zn.setTimeout&&En.setTimeout,Ri=Xu.ceil,zi=Xu.floor,Wi=ni.getOwnPropertySymbols,Bi=vi?vi.isBuffer:F,Li=En.isFinite,Ui=ui.join,Ci=U(ni.keys,ni),Di=Xu.max,Mi=Xu.min,Ti=Ju.now,$i=En.parseInt,Fi=Xu.random,Ni=ui.reverse,Pi=Ae(En,"DataView"),Zi=Ae(En,"Map"),qi=Ae(En,"Promise"),Vi=Ae(En,"Set"),Ki=Ae(En,"WeakMap"),Gi=Ae(ni,"create"),Hi=Ki&&new Ki,Ji={},Yi=Fe(Pi),Qi=Fe(Zi),Xi=Fe(qi),no=Fe(Vi),to=Fe(Ki),ro=gi?gi.prototype:F,eo=ro?ro.valueOf:F,uo=ro?ro.toString:F,io=function(){ +function n(){}return function(t){return bu(t)?xi?xi(t):(n.prototype=t,t=new n,n.prototype=F,t):{}}}();On.templateSettings={escape:Q,evaluate:X,interpolate:nn,variable:"",imports:{_:On}},On.prototype=Sn.prototype,On.prototype.constructor=On,zn.prototype=io(Sn.prototype),zn.prototype.constructor=zn,Mn.prototype=io(Sn.prototype),Mn.prototype.constructor=Mn,Tn.prototype.clear=function(){this.__data__=Gi?Gi(null):{},this.size=0},Tn.prototype.delete=function(n){return n=this.has(n)&&delete this.__data__[n], +this.size-=n?1:0,n},Tn.prototype.get=function(n){var t=this.__data__;return Gi?(n=t[n],"__lodash_hash_undefined__"===n?F:n):ci.call(t,n)?t[n]:F},Tn.prototype.has=function(n){var t=this.__data__;return Gi?t[n]!==F:ci.call(t,n)},Tn.prototype.set=function(n,t){var r=this.__data__;return this.size+=this.has(n)?0:1,r[n]=Gi&&t===F?"__lodash_hash_undefined__":t,this},Nn.prototype.clear=function(){this.__data__=[],this.size=0},Nn.prototype.delete=function(n){var t=this.__data__;return n=lt(t,n),!(0>n)&&(n==t.length-1?t.pop():wi.call(t,n,1), +--this.size,true)},Nn.prototype.get=function(n){var t=this.__data__;return n=lt(t,n),0>n?F:t[n][1]},Nn.prototype.has=function(n){return-1e?(++this.size,r.push([n,t])):r[e][1]=t,this},Pn.prototype.clear=function(){this.size=0,this.__data__={hash:new Tn,map:new(Zi||Nn),string:new Tn}},Pn.prototype.delete=function(n){return n=we(this,n).delete(n),this.size-=n?1:0,n},Pn.prototype.get=function(n){return we(this,n).get(n); +},Pn.prototype.has=function(n){return we(this,n).has(n)},Pn.prototype.set=function(n,t){var r=we(this,n),e=r.size;return r.set(n,t),this.size+=r.size==e?0:1,this},qn.prototype.add=qn.prototype.push=function(n){return this.__data__.set(n,"__lodash_hash_undefined__"),this},qn.prototype.has=function(n){return this.__data__.has(n)},Vn.prototype.clear=function(){this.__data__=new Nn,this.size=0},Vn.prototype.delete=function(n){var t=this.__data__;return n=t.delete(n),this.size=t.size,n},Vn.prototype.get=function(n){ +return this.__data__.get(n)},Vn.prototype.has=function(n){return this.__data__.has(n)},Vn.prototype.set=function(n,t){var r=this.__data__;if(r instanceof Nn){var e=r.__data__;if(!Zi||199>e.length)return e.push([n,t]),this.size=++r.size,this;r=this.__data__=new Pn(e)}return r.set(n,t),this.size=r.size,this};var oo=Zr(Et),fo=Zr(Ot,true),co=qr(),ao=qr(true),lo=Hi?function(n,t){return Hi.set(n,t),n}:Nu,so=Ei?function(n,t){return Ei(n,"toString",{configurable:true,enumerable:false,value:Fu(t),writable:true})}:Nu,ho=Oi||function(n){ +return Zn.clearTimeout(n)},po=Vi&&1/D(new Vi([,-0]))[1]==N?function(n){return new Vi(n)}:qu,_o=Hi?function(n){return Hi.get(n)}:qu,vo=Wi?function(n){return null==n?[]:(n=ni(n),f(Wi(n),function(t){return ji.call(n,t)}))}:Ku,go=Wi?function(n){for(var t=[];n;)s(t,vo(n)),n=bi(n);return t}:Ku,yo=zt;(Pi&&"[object DataView]"!=yo(new Pi(new ArrayBuffer(1)))||Zi&&"[object Map]"!=yo(new Zi)||qi&&"[object Promise]"!=yo(qi.resolve())||Vi&&"[object Set]"!=yo(new Vi)||Ki&&"[object WeakMap]"!=yo(new Ki))&&(yo=function(n){ +var t=zt(n);if(n=(n="[object Object]"==t?n.constructor:F)?Fe(n):"")switch(n){case Yi:return"[object DataView]";case Qi:return"[object Map]";case Xi:return"[object Promise]";case no:return"[object Set]";case to:return"[object WeakMap]"}return t});var bo=oi?gu:Gu,xo=Me(lo),jo=Ii||function(n,t){return Zn.setTimeout(n,t)},wo=Me(so),mo=function(n){n=lu(n,function(n){return 500===t.size&&t.clear(),n});var t=n.cache;return n}(function(n){var t=[];return en.test(n)&&t.push(""),n.replace(un,function(n,r,e,u){ +t.push(e?u.replace(vn,"$1"):r||n)}),t}),Ao=lr(function(n,t){return _u(n)?jt(n,kt(t,1,_u,true)):[]}),ko=lr(function(n,t){var r=Ge(t);return _u(r)&&(r=F),_u(n)?jt(n,kt(t,1,_u,true),je(r,2)):[]}),Eo=lr(function(n,t){var r=Ge(t);return _u(r)&&(r=F),_u(n)?jt(n,kt(t,1,_u,true),F,r):[]}),Oo=lr(function(n){var t=l(n,Sr);return t.length&&t[0]===n[0]?Ut(t):[]}),So=lr(function(n){var t=Ge(n),r=l(n,Sr);return t===Ge(r)?t=F:r.pop(),r.length&&r[0]===n[0]?Ut(r,je(t,2)):[]}),Io=lr(function(n){var t=Ge(n),r=l(n,Sr);return(t=typeof t=="function"?t:F)&&r.pop(), +r.length&&r[0]===n[0]?Ut(r,F,t):[]}),Ro=lr(He),zo=ge(function(n,t){var r=null==n?0:n.length,e=vt(n,t);return fr(n,l(t,function(n){return Re(n,r)?+n:n}).sort(Ur)),e}),Wo=lr(function(n){return wr(kt(n,1,_u,true))}),Bo=lr(function(n){var t=Ge(n);return _u(t)&&(t=F),wr(kt(n,1,_u,true),je(t,2))}),Lo=lr(function(n){var t=Ge(n),t=typeof t=="function"?t:F;return wr(kt(n,1,_u,true),F,t)}),Uo=lr(function(n,t){return _u(n)?jt(n,t):[]}),Co=lr(function(n){return Er(f(n,_u))}),Do=lr(function(n){var t=Ge(n);return _u(t)&&(t=F), +Er(f(n,_u),je(t,2))}),Mo=lr(function(n){var t=Ge(n),t=typeof t=="function"?t:F;return Er(f(n,_u),F,t)}),To=lr(Ye),$o=lr(function(n){var t=n.length,t=1=t}),cf=Mt(function(){return arguments}())?Mt:function(n){return xu(n)&&ci.call(n,"callee")&&!ji.call(n,"callee")},af=Hu.isArray,lf=Hn?S(Hn):Tt,sf=Bi||Gu,hf=Jn?S(Jn):$t,pf=Yn?S(Yn):Nt,_f=Qn?S(Qn):qt,vf=Xn?S(Xn):Vt,gf=nt?S(nt):Kt,df=oe(Jt),yf=oe(function(n,t){return n<=t}),bf=Pr(function(n,t){ +if(Le(t)||pu(t))Tr(t,Lu(t),n);else for(var r in t)ci.call(t,r)&&at(n,r,t[r])}),xf=Pr(function(n,t){Tr(t,Uu(t),n)}),jf=Pr(function(n,t,r,e){Tr(t,Uu(t),n,e)}),wf=Pr(function(n,t,r,e){Tr(t,Lu(t),n,e)}),mf=ge(vt),Af=lr(function(n){return n.push(F,se),r(jf,F,n)}),kf=lr(function(n){return n.push(F,he),r(Rf,F,n)}),Ef=ne(function(n,t,r){n[t]=r},Fu(Nu)),Of=ne(function(n,t,r){ci.call(n,t)?n[t].push(r):n[t]=[r]},je),Sf=lr(Dt),If=Pr(function(n,t,r){nr(n,t,r)}),Rf=Pr(function(n,t,r,e){nr(n,t,r,e)}),zf=ge(function(n,t){ +var r={};if(null==n)return r;var e=false;t=l(t,function(t){return t=Rr(t,n),e||(e=1--n)return t.apply(this,arguments)}},On.ary=iu,On.assign=bf,On.assignIn=xf,On.assignInWith=jf,On.assignWith=wf,On.at=mf,On.before=ou,On.bind=Yo,On.bindAll=Zf,On.bindKey=Qo,On.castArray=function(){if(!arguments.length)return[];var n=arguments[0];return af(n)?n:[n]}, +On.chain=Xe,On.chunk=function(n,t,r){if(t=(r?ze(n,t,r):t===F)?1:Di(Ou(t),0),r=null==n?0:n.length,!r||1>t)return[];for(var e=0,u=0,i=Hu(Ri(r/t));et?0:t,e)):[]},On.dropRight=function(n,t,r){var e=null==n?0:n.length;return e?(t=r||t===F?1:Ou(t),t=e-t,vr(n,0,0>t?0:t)):[]},On.dropRightWhile=function(n,t){return n&&n.length?Ar(n,je(t,3),true,true):[]},On.dropWhile=function(n,t){return n&&n.length?Ar(n,je(t,3),true):[]},On.fill=function(n,t,r,e){var u=null==n?0:n.length;if(!u)return[];for(r&&typeof r!="number"&&ze(n,t,r)&&(r=0,e=u),u=n.length,r=Ou(r),0>r&&(r=-r>u?0:u+r),e=e===F||e>u?u:Ou(e),0>e&&(e+=u),e=r>e?0:Su(e);r>>0,r?(n=zu(n))&&(typeof t=="string"||null!=t&&!_f(t))&&(t=jr(t), +!t&&Bn.test(n))?zr($(n),0,r):n.split(t,r):[]},On.spread=function(n,t){if(typeof n!="function")throw new ei("Expected a function");return t=null==t?0:Di(Ou(t),0),lr(function(e){var u=e[t];return e=zr(e,0,t),u&&s(e,u),r(n,this,e)})},On.tail=function(n){var t=null==n?0:n.length;return t?vr(n,1,t):[]},On.take=function(n,t,r){return n&&n.length?(t=r||t===F?1:Ou(t),vr(n,0,0>t?0:t)):[]},On.takeRight=function(n,t,r){var e=null==n?0:n.length;return e?(t=r||t===F?1:Ou(t),t=e-t,vr(n,0>t?0:t,e)):[]},On.takeRightWhile=function(n,t){ +return n&&n.length?Ar(n,je(t,3),false,true):[]},On.takeWhile=function(n,t){return n&&n.length?Ar(n,je(t,3)):[]},On.tap=function(n,t){return t(n),n},On.throttle=function(n,t,r){var e=true,u=true;if(typeof n!="function")throw new ei("Expected a function");return bu(r)&&(e="leading"in r?!!r.leading:e,u="trailing"in r?!!r.trailing:u),au(n,t,{leading:e,maxWait:t,trailing:u})},On.thru=nu,On.toArray=ku,On.toPairs=Bf,On.toPairsIn=Lf,On.toPath=function(n){return af(n)?l(n,$e):Au(n)?[n]:Mr(mo(zu(n)))},On.toPlainObject=Ru, +On.transform=function(n,t,r){var e=af(n),i=e||sf(n)||gf(n);if(t=je(t,4),null==r){var o=n&&n.constructor;r=i?e?new o:[]:bu(n)&&gu(o)?io(bi(n)):{}}return(i?u:Et)(n,function(n,e,u){return t(r,n,e,u)}),r},On.unary=function(n){return iu(n,1)},On.union=Wo,On.unionBy=Bo,On.unionWith=Lo,On.uniq=function(n){return n&&n.length?wr(n):[]},On.uniqBy=function(n,t){return n&&n.length?wr(n,je(t,2)):[]},On.uniqWith=function(n,t){return t=typeof t=="function"?t:F,n&&n.length?wr(n,F,t):[]},On.unset=function(n,t){return null==n||mr(n,t); +},On.unzip=Ye,On.unzipWith=Qe,On.update=function(n,t,r){return null==n?n:pr(n,t,Ir(r)(It(n,t)),void 0)},On.updateWith=function(n,t,r,e){return e=typeof e=="function"?e:F,null!=n&&(n=pr(n,t,Ir(r)(It(n,t)),e)),n},On.values=Du,On.valuesIn=function(n){return null==n?[]:I(n,Uu(n))},On.without=Uo,On.words=$u,On.wrap=function(n,t){return rf(Ir(t),n)},On.xor=Co,On.xorBy=Do,On.xorWith=Mo,On.zip=To,On.zipObject=function(n,t){return Or(n||[],t||[],at)},On.zipObjectDeep=function(n,t){return Or(n||[],t||[],pr); +},On.zipWith=$o,On.entries=Bf,On.entriesIn=Lf,On.extend=xf,On.extendWith=jf,Zu(On,On),On.add=nc,On.attempt=Pf,On.camelCase=Uf,On.capitalize=Mu,On.ceil=tc,On.clamp=function(n,t,r){return r===F&&(r=t,t=F),r!==F&&(r=Iu(r),r=r===r?r:0),t!==F&&(t=Iu(t),t=t===t?t:0),gt(Iu(n),t,r)},On.clone=function(n){return dt(n,4)},On.cloneDeep=function(n){return dt(n,5)},On.cloneDeepWith=function(n,t){return t=typeof t=="function"?t:F,dt(n,5,t)},On.cloneWith=function(n,t){return t=typeof t=="function"?t:F,dt(n,4,t)}, +On.conformsTo=function(n,t){return null==t||bt(n,t,Lu(t))},On.deburr=Tu,On.defaultTo=function(n,t){return null==n||n!==n?t:n},On.divide=rc,On.endsWith=function(n,t,r){n=zu(n),t=jr(t);var e=n.length,e=r=r===F?e:gt(Ou(r),0,e);return r-=t.length,0<=r&&n.slice(r,e)==t},On.eq=hu,On.escape=function(n){return(n=zu(n))&&Y.test(n)?n.replace(H,et):n},On.escapeRegExp=function(n){return(n=zu(n))&&fn.test(n)?n.replace(on,"\\$&"):n},On.every=function(n,t,r){var e=af(n)?o:wt;return r&&ze(n,t,r)&&(t=F),e(n,je(t,3)); +},On.find=Po,On.findIndex=Ze,On.findKey=function(n,t){return v(n,je(t,3),Et)},On.findLast=Zo,On.findLastIndex=qe,On.findLastKey=function(n,t){return v(n,je(t,3),Ot)},On.floor=ec,On.forEach=ru,On.forEachRight=eu,On.forIn=function(n,t){return null==n?n:co(n,je(t,3),Uu)},On.forInRight=function(n,t){return null==n?n:ao(n,je(t,3),Uu)},On.forOwn=function(n,t){return n&&Et(n,je(t,3))},On.forOwnRight=function(n,t){return n&&Ot(n,je(t,3))},On.get=Wu,On.gt=of,On.gte=ff,On.has=function(n,t){return null!=n&&ke(n,t,Bt); +},On.hasIn=Bu,On.head=Ke,On.identity=Nu,On.includes=function(n,t,r,e){return n=pu(n)?n:Du(n),r=r&&!e?Ou(r):0,e=n.length,0>r&&(r=Di(e+r,0)),mu(n)?r<=e&&-1r&&(r=Di(e+r,0)),d(n,t,r)):-1},On.inRange=function(n,t,r){return t=Eu(t),r===F?(r=t,t=0):r=Eu(r),n=Iu(n),n>=Mi(t,r)&&n=n},On.isSet=vf,On.isString=mu,On.isSymbol=Au,On.isTypedArray=gf,On.isUndefined=function(n){return n===F},On.isWeakMap=function(n){return xu(n)&&"[object WeakMap]"==yo(n)},On.isWeakSet=function(n){return xu(n)&&"[object WeakSet]"==zt(n)},On.join=function(n,t){ +return null==n?"":Ui.call(n,t)},On.kebabCase=Cf,On.last=Ge,On.lastIndexOf=function(n,t,r){var e=null==n?0:n.length;if(!e)return-1;var u=e;if(r!==F&&(u=Ou(r),u=0>u?Di(e+u,0):Mi(u,e-1)),t===t){for(r=u+1;r--&&n[r]!==t;);n=r}else n=g(n,b,u,true);return n},On.lowerCase=Df,On.lowerFirst=Mf,On.lt=df,On.lte=yf,On.max=function(n){return n&&n.length?mt(n,Nu,Wt):F},On.maxBy=function(n,t){return n&&n.length?mt(n,je(t,2),Wt):F},On.mean=function(n){return x(n,Nu)},On.meanBy=function(n,t){return x(n,je(t,2))},On.min=function(n){ +return n&&n.length?mt(n,Nu,Jt):F},On.minBy=function(n,t){return n&&n.length?mt(n,je(t,2),Jt):F},On.stubArray=Ku,On.stubFalse=Gu,On.stubObject=function(){return{}},On.stubString=function(){return""},On.stubTrue=function(){return true},On.multiply=uc,On.nth=function(n,t){return n&&n.length?tr(n,Ou(t)):F},On.noConflict=function(){return Zn._===this&&(Zn._=pi),this},On.noop=qu,On.now=Jo,On.pad=function(n,t,r){n=zu(n);var e=(t=Ou(t))?T(n):0;return!t||e>=t?n:(t=(t-e)/2,ee(zi(t),r)+n+ee(Ri(t),r))},On.padEnd=function(n,t,r){ +n=zu(n);var e=(t=Ou(t))?T(n):0;return t&&et){var e=n;n=t,t=e}return r||n%1||t%1?(r=Fi(),Mi(n+r*(t-n+$n("1e-"+((r+"").length-1))),t)):cr(n,t); +},On.reduce=function(n,t,r){var e=af(n)?h:m,u=3>arguments.length;return e(n,je(t,4),r,u,oo)},On.reduceRight=function(n,t,r){var e=af(n)?p:m,u=3>arguments.length;return e(n,je(t,4),r,u,fo)},On.repeat=function(n,t,r){return t=(r?ze(n,t,r):t===F)?1:Ou(t),ar(zu(n),t)},On.replace=function(){var n=arguments,t=zu(n[0]);return 3>n.length?t:t.replace(n[1],n[2])},On.result=function(n,t,r){t=Rr(t,n);var e=-1,u=t.length;for(u||(u=1,n=F);++en||9007199254740991=i)return n;if(i=r-T(e),1>i)return e; +if(r=o?zr(o,0,i).join(""):n.slice(0,i),u===F)return r+e;if(o&&(i+=r.length-i),_f(u)){if(n.slice(i).search(u)){var f=r;for(u.global||(u=ti(u.source,zu(dn.exec(u))+"g")),u.lastIndex=0;o=u.exec(f);)var c=o.index;r=r.slice(0,c===F?i:c)}}else n.indexOf(jr(u),i)!=i&&(u=r.lastIndexOf(u),-1e.__dir__?"Right":"")}),e},Mn.prototype[n+"Right"]=function(t){ +return this.reverse()[n](t).reverse()}}),u(["filter","map","takeWhile"],function(n,t){var r=t+1,e=1==r||3==r;Mn.prototype[n]=function(n){var t=this.clone();return t.__iteratees__.push({iteratee:je(n,3),type:r}),t.__filtered__=t.__filtered__||e,t}}),u(["head","last"],function(n,t){var r="take"+(t?"Right":"");Mn.prototype[n]=function(){return this[r](1).value()[0]}}),u(["initial","tail"],function(n,t){var r="drop"+(t?"":"Right");Mn.prototype[n]=function(){return this.__filtered__?new Mn(this):this[r](1); +}}),Mn.prototype.compact=function(){return this.filter(Nu)},Mn.prototype.find=function(n){return this.filter(n).head()},Mn.prototype.findLast=function(n){return this.reverse().find(n)},Mn.prototype.invokeMap=lr(function(n,t){return typeof n=="function"?new Mn(this):this.map(function(r){return Dt(r,n,t)})}),Mn.prototype.reject=function(n){return this.filter(su(je(n)))},Mn.prototype.slice=function(n,t){n=Ou(n);var r=this;return r.__filtered__&&(0t)?new Mn(r):(0>n?r=r.takeRight(-n):n&&(r=r.drop(n)), +t!==F&&(t=Ou(t),r=0>t?r.dropRight(-t):r.take(t-n)),r)},Mn.prototype.takeRightWhile=function(n){return this.reverse().takeWhile(n).reverse()},Mn.prototype.toArray=function(){return this.take(4294967295)},Et(Mn.prototype,function(n,t){var r=/^(?:filter|find|map|reject)|While$/.test(t),e=/^(?:head|last)$/.test(t),u=On[e?"take"+("last"==t?"Right":""):t],i=e||/^find/.test(t);u&&(On.prototype[t]=function(){function t(n){return n=u.apply(On,s([n],f)),e&&h?n[0]:n}var o=this.__wrapped__,f=e?[1]:arguments,c=o instanceof Mn,a=f[0],l=c||af(o); +l&&r&&typeof a=="function"&&1!=a.length&&(c=l=false);var h=this.__chain__,p=!!this.__actions__.length,a=i&&!h,c=c&&!p;return!i&&l?(o=c?o:new Mn(this),o=n.apply(o,f),o.__actions__.push({func:nu,args:[t],thisArg:F}),new zn(o,h)):a&&c?n.apply(this,f):(o=this.thru(t),a?e?o.value()[0]:o.value():o)})}),u("pop push shift sort splice unshift".split(" "),function(n){var t=ui[n],r=/^(?:push|sort|unshift)$/.test(n)?"tap":"thru",e=/^(?:pop|shift)$/.test(n);On.prototype[n]=function(){var n=arguments;if(e&&!this.__chain__){ +var u=this.value();return t.apply(af(u)?u:[],n)}return this[r](function(r){return t.apply(af(r)?r:[],n)})}}),Et(Mn.prototype,function(n,t){var r=On[t];if(r){var e=r.name+"";(Ji[e]||(Ji[e]=[])).push({name:t,func:r})}}),Ji[Xr(F,2).name]=[{name:"wrapper",func:F}],Mn.prototype.clone=function(){var n=new Mn(this.__wrapped__);return n.__actions__=Mr(this.__actions__),n.__dir__=this.__dir__,n.__filtered__=this.__filtered__,n.__iteratees__=Mr(this.__iteratees__),n.__takeCount__=this.__takeCount__,n.__views__=Mr(this.__views__), +n},Mn.prototype.reverse=function(){if(this.__filtered__){var n=new Mn(this);n.__dir__=-1,n.__filtered__=true}else n=this.clone(),n.__dir__*=-1;return n},Mn.prototype.value=function(){var n,t=this.__wrapped__.value(),r=this.__dir__,e=af(t),u=0>r,i=e?t.length:0;n=i;for(var o=this.__views__,f=0,c=-1,a=o.length;++c=this.__values__.length;return{done:n,value:n?F:this.__values__[this.__index__++]}},On.prototype.plant=function(n){for(var t,r=this;r instanceof Sn;){var e=Pe(r);e.__index__=0,e.__values__=F,t?u.__wrapped__=e:t=e;var u=e,r=r.__wrapped__}return u.__wrapped__=n,t},On.prototype.reverse=function(){var n=this.__wrapped__;return n instanceof Mn?(this.__actions__.length&&(n=new Mn(this)),n=n.reverse(),n.__actions__.push({func:nu,args:[Je],thisArg:F}),new zn(n,this.__chain__)):this.thru(Je); +},On.prototype.toJSON=On.prototype.valueOf=On.prototype.value=function(){return kr(this.__wrapped__,this.__actions__)},On.prototype.first=On.prototype.head,Ai&&(On.prototype[Ai]=tu),On}(); true?(Zn._=it, !(__WEBPACK_AMD_DEFINE_RESULT__ = function(){return it}.call(exports, __webpack_require__, exports, module), + __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__))):Vn?((Vn.exports=it)._=it,qn._=it):Zn._=it}).call(this); +/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__("./node_modules/webpack/buildin/global.js"), __webpack_require__("./node_modules/webpack/buildin/module.js")(module))) /***/ }), /***/ "./node_modules/webpack/buildin/global.js": -/* no static exports found */ -/* all exports used */ -/*!***********************************!*\ - !*** (webpack)/buildin/global.js ***! - \***********************************/ /***/ (function(module, exports) { -eval("var g;\r\n\r\n// This works in non-strict mode\r\ng = (function() {\r\n\treturn this;\r\n})();\r\n\r\ntry {\r\n\t// This works if eval is allowed (see CSP)\r\n\tg = g || Function(\"return this\")() || (1,eval)(\"this\");\r\n} catch(e) {\r\n\t// This works if the window reference is available\r\n\tif(typeof window === \"object\")\r\n\t\tg = window;\r\n}\r\n\r\n// g can still be undefined, but nothing to do about it...\r\n// We return undefined, instead of nothing here, so it's\r\n// easier to handle this case. if(!global) { ...}\r\n\r\nmodule.exports = g;\r\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9ub2RlX21vZHVsZXMvd2VicGFjay9idWlsZGluL2dsb2JhbC5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8od2VicGFjaykvYnVpbGRpbi9nbG9iYWwuanM/MzY5OCJdLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgZztcclxuXHJcbi8vIFRoaXMgd29ya3MgaW4gbm9uLXN0cmljdCBtb2RlXHJcbmcgPSAoZnVuY3Rpb24oKSB7XHJcblx0cmV0dXJuIHRoaXM7XHJcbn0pKCk7XHJcblxyXG50cnkge1xyXG5cdC8vIFRoaXMgd29ya3MgaWYgZXZhbCBpcyBhbGxvd2VkIChzZWUgQ1NQKVxyXG5cdGcgPSBnIHx8IEZ1bmN0aW9uKFwicmV0dXJuIHRoaXNcIikoKSB8fCAoMSxldmFsKShcInRoaXNcIik7XHJcbn0gY2F0Y2goZSkge1xyXG5cdC8vIFRoaXMgd29ya3MgaWYgdGhlIHdpbmRvdyByZWZlcmVuY2UgaXMgYXZhaWxhYmxlXHJcblx0aWYodHlwZW9mIHdpbmRvdyA9PT0gXCJvYmplY3RcIilcclxuXHRcdGcgPSB3aW5kb3c7XHJcbn1cclxuXHJcbi8vIGcgY2FuIHN0aWxsIGJlIHVuZGVmaW5lZCwgYnV0IG5vdGhpbmcgdG8gZG8gYWJvdXQgaXQuLi5cclxuLy8gV2UgcmV0dXJuIHVuZGVmaW5lZCwgaW5zdGVhZCBvZiBub3RoaW5nIGhlcmUsIHNvIGl0J3NcclxuLy8gZWFzaWVyIHRvIGhhbmRsZSB0aGlzIGNhc2UuIGlmKCFnbG9iYWwpIHsgLi4ufVxyXG5cclxubW9kdWxlLmV4cG9ydHMgPSBnO1xyXG5cblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAod2VicGFjaykvYnVpbGRpbi9nbG9iYWwuanNcbi8vIG1vZHVsZSBpZCA9IC4vbm9kZV9tb2R1bGVzL3dlYnBhY2svYnVpbGRpbi9nbG9iYWwuanNcbi8vIG1vZHVsZSBjaHVua3MgPSAwIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7Iiwic291cmNlUm9vdCI6IiJ9"); +var g; + +// This works in non-strict mode +g = (function() { + return this; +})(); + +try { + // This works if eval is allowed (see CSP) + g = g || Function("return this")() || (1,eval)("this"); +} catch(e) { + // This works if the window reference is available + if(typeof window === "object") + g = window; +} + +// g can still be undefined, but nothing to do about it... +// We return undefined, instead of nothing here, so it's +// easier to handle this case. if(!global) { ...} + +module.exports = g; + /***/ }), /***/ "./node_modules/webpack/buildin/module.js": -/* no static exports found */ -/* all exports used */ -/*!***********************************!*\ - !*** (webpack)/buildin/module.js ***! - \***********************************/ /***/ (function(module, exports) { -eval("module.exports = function(module) {\r\n\tif(!module.webpackPolyfill) {\r\n\t\tmodule.deprecate = function() {};\r\n\t\tmodule.paths = [];\r\n\t\t// module.parent = undefined by default\r\n\t\tif(!module.children) module.children = [];\r\n\t\tObject.defineProperty(module, \"loaded\", {\r\n\t\t\tenumerable: true,\r\n\t\t\tget: function() {\r\n\t\t\t\treturn module.l;\r\n\t\t\t}\r\n\t\t});\r\n\t\tObject.defineProperty(module, \"id\", {\r\n\t\t\tenumerable: true,\r\n\t\t\tget: function() {\r\n\t\t\t\treturn module.i;\r\n\t\t\t}\r\n\t\t});\r\n\t\tmodule.webpackPolyfill = 1;\r\n\t}\r\n\treturn module;\r\n};\r\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9ub2RlX21vZHVsZXMvd2VicGFjay9idWlsZGluL21vZHVsZS5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8od2VicGFjaykvYnVpbGRpbi9tb2R1bGUuanM/YzNjMiJdLCJzb3VyY2VzQ29udGVudCI6WyJtb2R1bGUuZXhwb3J0cyA9IGZ1bmN0aW9uKG1vZHVsZSkge1xyXG5cdGlmKCFtb2R1bGUud2VicGFja1BvbHlmaWxsKSB7XHJcblx0XHRtb2R1bGUuZGVwcmVjYXRlID0gZnVuY3Rpb24oKSB7fTtcclxuXHRcdG1vZHVsZS5wYXRocyA9IFtdO1xyXG5cdFx0Ly8gbW9kdWxlLnBhcmVudCA9IHVuZGVmaW5lZCBieSBkZWZhdWx0XHJcblx0XHRpZighbW9kdWxlLmNoaWxkcmVuKSBtb2R1bGUuY2hpbGRyZW4gPSBbXTtcclxuXHRcdE9iamVjdC5kZWZpbmVQcm9wZXJ0eShtb2R1bGUsIFwibG9hZGVkXCIsIHtcclxuXHRcdFx0ZW51bWVyYWJsZTogdHJ1ZSxcclxuXHRcdFx0Z2V0OiBmdW5jdGlvbigpIHtcclxuXHRcdFx0XHRyZXR1cm4gbW9kdWxlLmw7XHJcblx0XHRcdH1cclxuXHRcdH0pO1xyXG5cdFx0T2JqZWN0LmRlZmluZVByb3BlcnR5KG1vZHVsZSwgXCJpZFwiLCB7XHJcblx0XHRcdGVudW1lcmFibGU6IHRydWUsXHJcblx0XHRcdGdldDogZnVuY3Rpb24oKSB7XHJcblx0XHRcdFx0cmV0dXJuIG1vZHVsZS5pO1xyXG5cdFx0XHR9XHJcblx0XHR9KTtcclxuXHRcdG1vZHVsZS53ZWJwYWNrUG9seWZpbGwgPSAxO1xyXG5cdH1cclxuXHRyZXR1cm4gbW9kdWxlO1xyXG59O1xyXG5cblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAod2VicGFjaykvYnVpbGRpbi9tb2R1bGUuanNcbi8vIG1vZHVsZSBpZCA9IC4vbm9kZV9tb2R1bGVzL3dlYnBhY2svYnVpbGRpbi9tb2R1bGUuanNcbi8vIG1vZHVsZSBjaHVua3MgPSAwIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTsiLCJzb3VyY2VSb290IjoiIn0="); +module.exports = function(module) { + if(!module.webpackPolyfill) { + module.deprecate = function() {}; + module.paths = []; + // module.parent = undefined by default + if(!module.children) module.children = []; + Object.defineProperty(module, "loaded", { + enumerable: true, + get: function() { + return module.l; + } + }); + Object.defineProperty(module, "id", { + enumerable: true, + get: function() { + return module.i; + } + }); + module.webpackPolyfill = 1; + } + return module; +}; + /***/ }), /***/ "./src/web/index.js": -/* no static exports found */ -/* all exports used */ -/*!**************************!*\ - !*** ./src/web/index.js ***! - \**************************/ /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _fp = __webpack_require__(/*! lodash/fp */ \"./node_modules/lodash/fp.js\");\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/* eslint-disable no-underscore-dangle */\n// Accept the huron.js module for Huron development\nif (false) {\n module.hot.accept();\n}\n\n/** Class for inserting HTML snippets at particular insertion points.\n * Uses require() to grab html partials, then inserts that html\n * into an element with attribute [huron-id] corresponding to the reference URI of the target KSS section,\n * and [huron-type] corresponding with the required KSS field\n */\n\nvar InsertNodes = function () {\n function InsertNodes(modules, store) {\n _classCallCheck(this, InsertNodes);\n\n /** webpack module list in which keys are relative require paths and values are the module contents */\n this._modules = modules;\n /** array of module keys */\n this._moduleIds = Object.keys(modules);\n /** reference to the huron config */\n this._config = null;\n /** KSS sections organized in various formats including by reference URI, by module key, and modules sorted by parent/child */\n this._sections = null;\n /** Key/value pairs of partner data and template files */\n this._templates = null;\n /** array of prototypes */\n this._prototypes = null;\n /** array of valid huron placeholder types */\n this._types = null;\n /** array of CSS modules classnames */\n this._classNames = null;\n\n /** Cache for module metadata */\n this.meta = {};\n\n /** Reference to entire memory store */\n this.store = store;\n\n // Inits\n this.cycleModules();\n this.cycleStyleguide();\n }\n\n /**\n * Apply a modifier if one exists\n *\n * @param {object} data - data with which to render template\n * @param {string} modifier - target modifier\n *\n * @return {string} data - subset of data object for supplied modifier\n */\n\n\n _createClass(InsertNodes, [{\n key: 'cycleModules',\n\n\n /**\n * Replace all template markers with the actual template markup.\n *\n * @param {string} context - The within which to replace markup\n * @param {object} filter - Filter for modules. Fields explained in the filterModules() function docs\n */\n value: function cycleModules() {\n var _this = this;\n\n var context = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n var filter = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n\n var moduleList = {};\n var elementList = context;\n\n // We're replacing top-level elements\n if (!elementList) {\n this.regenCache();\n\n // Find all top-level huron placeholders\n elementList = [].concat(_toConsumableArray(document.querySelectorAll('[data-huron-id][data-huron-type]')));\n }\n\n moduleList = this.getModuleListFromTags(elementList);\n\n // Loop through modules array\n Object.keys(moduleList).forEach(function (key) {\n var module = _this._modules[key];\n var replaceElements = moduleList[key];\n\n _this.loadModule(key, module, replaceElements, true, filter);\n });\n }\n\n /**\n * Helper for reloading sections only\n */\n\n }, {\n key: 'cycleSections',\n value: function cycleSections() {\n this.cycleModules(false, {\n property: 'type',\n values: ['section'],\n include: true\n });\n }\n\n /**\n * Reload styleguide sections and menu helpers\n */\n\n }, {\n key: 'cycleStyleguide',\n value: function cycleStyleguide() {\n var sectionsQuery = document.querySelector('[huron-sections]');\n var menuQuery = document.querySelector('[huron-menu]');\n\n // Sections\n if (sectionsQuery) {\n sectionsQuery.innerHTML = '';\n this.outputSections(null, sectionsQuery);\n this.cycleSections();\n }\n\n // Menu\n if (menuQuery) {\n menuQuery.innerHTML = '';\n\n if (null === document.querySelector('.section-menu__expand')) {\n var menuTrigger = document.createElement('button');\n\n menuTrigger.classList.add('section-menu__expand');\n menuTrigger.innerHTML = 'Sections Menu';\n document.body.insertBefore(menuQuery.appendChild(menuTrigger), document.body.childNodes[0]);\n\n // Add menu trigger handler\n menuTrigger.addEventListener('click', function () {\n document.body.classList.toggle('section-menu-open');\n });\n }\n\n // Create menu\n this.outputMenu(null, menuQuery);\n }\n }\n\n /**\n * Generate a unique key for targeting markup replacement\n *\n * @param {string} key - module key (webpack require path) to convert into a replacement key\n * @return {string} key - generated replacement key\n */\n\n }, {\n key: 'generateModuleReplaceKey',\n value: function generateModuleReplaceKey(key) {\n var currentKey = key;\n\n // If this is section data, use the section template path\n if (key.includes('-section.json')) {\n currentKey = this._sectionTemplatePath;\n // If updated module is a json file, use template key instead\n } else if (key.includes('.json')) {\n currentKey = this._templates[key];\n }\n\n return '_' + currentKey.replace(/[/.]/g, '_');\n }\n\n /**\n * Get module metadata from a module require path\n *\n * @param {string} key - Module require path\n * @return {object} containing module id, module type, key and the module contents\n */\n\n }, {\n key: 'getMetaFromPath',\n value: function getMetaFromPath(key, module) {\n var _this2 = this;\n\n var sections = this._sections.sectionsByPath;\n var templateTypes = this._types.filter(function (type) {\n return 'prototype' !== type;\n });\n var id = false;\n var type = false;\n\n /* eslint-disable space-unary-ops */\n if (-1 !== key.indexOf('./prototypes')) {\n /* eslint-enable space-unary-ops */\n var prototype = Object.keys(this._prototypes).filter(function (name) {\n return _this2._prototypes[name] === key;\n });\n\n if (prototype.length) {\n id = prototype[0];\n type = 'prototype';\n }\n } else if (key === this._sectionTemplatePath) {\n id = 'sections-template';\n type = 'sections-template';\n } else {\n var testTypes = [];\n var testSections = Object.keys(sections).filter(function (section) {\n var tempTypes = templateTypes.filter(function (currentType) {\n return sections[section][currentType + 'Path'] === key;\n });\n\n if (tempTypes.length) {\n testTypes = tempTypes;\n return true;\n }\n\n return false;\n });\n\n if (testSections && testSections.length && testTypes && testTypes.length) {\n id = sections[testSections[0]].referenceURI;\n type = testTypes[0];\n }\n }\n\n if (id && type) {\n var renderData = this.getModuleRender(type, key, module);\n var replaceKey = this.generateModuleReplaceKey(key);\n\n if (renderData) {\n return Object.assign({ id: id, type: type, key: key, replaceKey: replaceKey, module: module }, renderData);\n }\n }\n\n console.warn( // eslint-disable-line no-console\n 'Module \\'' + key + '\\' does not exist on the page\\n or is no longer in use');\n return false;\n }\n\n /**\n * Check if a tag is a huron placeholder and, if so,\n * return its associated module key\n *\n * @param {object} tag - tag to check\n * @return {bool} associated module key\n */\n\n }, {\n key: 'getModuleKeyFromTag',\n value: function getModuleKeyFromTag(tag) {\n // Safari/webkit has some trouble parsing dataset in certain cases.\n // This is a fallback method of accessing the same data.\n var type = InsertNodes.getDataAttribute(tag, 'huron-type');\n var id = InsertNodes.getDataAttribute(tag, 'huron-id');\n var section = this._sections.sectionsByURI[id];\n\n if (id && type) {\n if (section) {\n return section[type + 'Path'];\n } else if ('prototype' === type) {\n return this._prototypes[id];\n }\n }\n\n return false;\n }\n\n /**\n * Check if an array of elements contains a Huron placeholder\n *\n * @param {array} tags - array of DOM nodes\n * @param {bool} recurse - should we recurse this function with a new array\n * @return {object} moduleList - Huron placeholder DOM node\n */\n\n }, {\n key: 'getModuleListFromTags',\n value: function getModuleListFromTags(elements) {\n var _this3 = this;\n\n var recurse = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n\n var moduleList = {};\n var newList = {};\n\n if (elements && elements.length) {\n elements.forEach(function (element) {\n var moduleKey = _this3.getModuleKeyFromTag(element);\n\n if (moduleKey) {\n if (!moduleList[moduleKey]) {\n moduleList[moduleKey] = [];\n }\n moduleList[moduleKey].push(element);\n } else if (recurse) {\n newList = _this3.getModuleListFromTags([].concat(_toConsumableArray(element.querySelectorAll('[data-huron-id][data-huron-type]'))), false);\n\n Object.keys(newList).forEach(function (key) {\n moduleList[key] = moduleList[key] ? moduleList[key].concat(newList[key]) : newList[key];\n });\n }\n });\n }\n\n return moduleList;\n }\n\n /**\n * Transform every module into a predictable object\n *\n * @param {object} type - Module metadata\n * @param {mixed} module - Module contents\n * @return {object} containing render function, render data and module id\n */\n\n }, {\n key: 'getModuleRender',\n value: function getModuleRender(type, key, module) {\n var render = false;\n var data = false;\n\n if ('template' === type && 'function' === typeof module) {\n // It's a render function for a template\n render = module;\n data = this._modules[this._templates[key]];\n } else if ('sections-template' === type && 'function' === typeof module) {\n // It's a kss section template\n render = module;\n } else if ('section' === type && 'object' === (typeof module === 'undefined' ? 'undefined' : _typeof(module))) {\n // It's section data\n render = this._modules[this._sectionTemplatePath];\n data = module;\n } else if (('template' === type || 'description' === type || 'prototype' === type) && 'string' === typeof module) {\n // it's straight HTML\n render = function render() {\n return module;\n };\n } else if ('data' === type && 'object' === (typeof module === 'undefined' ? 'undefined' : _typeof(module))) {\n // It's a data file (.json)\n render = this._modules[this._templates[key]];\n data = module;\n }\n\n // Only need render, as data will be left empty for static HTML\n if (render) {\n return { render: render, data: data };\n }\n\n return false;\n }\n\n /**\n * Replace all sections. For hot reloading use when the section template has changed.\n *\n * @param {object} replaceElements - The context (e.g. document) that you will query for the template ID to replace\n * @param {string} key - Module require path\n * @param {mixed} module - Module contents\n * @param {bool} cached - Whether or not to use cached values for module replacement\n * @param {object} filter - Filter for modules. Fields explained in the filterModules() function docs\n */\n\n }, {\n key: 'loadModule',\n value: function loadModule(key, module, replaceElements) {\n var cached = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;\n var filter = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false;\n\n var shouldLoad = true;\n var moduleMeta = false;\n\n // Check if we should load from internal module metadata cache\n if (cached) {\n moduleMeta = this.meta[key];\n } else {\n moduleMeta = this.meta[key] = this.getMetaFromPath(key, module);\n }\n\n if (moduleMeta) {\n if (filter) {\n shouldLoad = InsertNodes.filterModules(filter, moduleMeta);\n }\n\n if (shouldLoad) {\n this.replaceTemplate(moduleMeta, replaceElements);\n }\n }\n }\n\n /*\n * Helper function for inserting styleguide sections.\n *\n * Recurses over sorted styleguide sections and inserts a
    to be used as a menu for each section\n */\n\n }, {\n key: 'outputMenu',\n value: function outputMenu(parent, el) {\n var _this4 = this;\n\n var sections = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : this._sections.sorted;\n\n var templateId = null;\n var newEl = el;\n\n Object.keys(sections).forEach(function (section) {\n var hasSubmenu = Object.keys(sections[section]).length;\n var menuTarget = void 0;\n var nextMenu = void 0;\n\n if (parent) {\n templateId = parent + '-' + section;\n } else {\n templateId = section;\n }\n\n if (newEl) {\n var title = _this4._sections.sectionsByURI[templateId] ? _this4._sections.sectionsByURI[templateId].header : templateId;\n var sectionMenu = document.createElement('ul');\n var menuItem = document.createElement('li');\n var link = '' + title + '';\n\n sectionMenu.classList.add('section-menu');\n menuItem.classList.add('section-menu__item');\n menuItem.innerHTML = link;\n\n // Check if this is a UL and, if not, create one\n if ('UL' !== newEl.tagName) {\n menuTarget = sectionMenu.cloneNode();\n newEl.appendChild(menuTarget);\n newEl = menuTarget;\n }\n\n // Has subsections\n if (hasSubmenu) {\n nextMenu = sectionMenu.cloneNode();\n nextMenu.classList.add('section-menu--submenu');\n menuItem.classList.add('section-menu__item--has-submenu');\n menuItem.appendChild(nextMenu);\n }\n\n newEl.appendChild(menuItem);\n\n if (hasSubmenu) {\n _this4.outputMenu(templateId, nextMenu, sections[section]);\n }\n }\n });\n }\n\n /**\n * Helper function for inserting styleguide sections.\n *\n * Recurses over sorted styleguide sections and inserts a
    tag with [huron-id] equal to the section template name.\n */\n\n }, {\n key: 'outputSections',\n value: function outputSections(parent, el) {\n var _this5 = this;\n\n var sections = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : this._sections.sorted;\n\n var templateId = null;\n var placeholder = null;\n\n Object.keys(sections).forEach(function (section) {\n var istopLevel = false;\n var topLevelWrapper = null;\n var topLevelSection = null;\n var insertionEl = el;\n\n // Generate section ID and check if it is top-level\n if (parent) {\n templateId = parent + '-' + section;\n } else {\n templateId = section;\n istopLevel = true;\n }\n\n if (el) {\n // Generate huron placeholder for this section\n placeholder = document.createElement('div');\n placeholder.dataset.huronId = templateId;\n placeholder.dataset.huronType = 'section';\n\n if (istopLevel) {\n // Generate wrapper to contain top-level section and all subsections underneath it\n topLevelWrapper = document.createElement('div');\n topLevelWrapper.classList.add('section--top-level__wrapper');\n\n // Generate wrapper for top-level section\n topLevelSection = document.createElement('div');\n topLevelSection.classList.add('section', 'section--top-level');\n\n // Append wrappers to huron-sections element\n topLevelSection.appendChild(placeholder);\n topLevelWrapper.appendChild(topLevelSection);\n el.appendChild(topLevelWrapper);\n insertionEl = topLevelWrapper;\n } else {\n // If this is not top-level, append placeholder\n el.appendChild(placeholder);\n }\n }\n\n // Recursively call this function to insert other sections\n if (Object.keys(sections[section]).length && placeholder) {\n _this5.outputSections(templateId, insertionEl, sections[section]);\n }\n });\n }\n\n /**\n * Apply a modifier and merge classnames into template data, if it exists\n *\n * @param {object} data - data with which to render template\n * @param {string} modifier - target modifier\n *\n * @return {string} rendered - the modified HTML module\n */\n\n }, {\n key: 'provideClassnames',\n value: function provideClassnames(data) {\n if (this._classNames) {\n return Object.assign({}, data, { classNames: this._classNames });\n }\n\n return data;\n }\n\n /**\n * Regenerate module meta cache\n */\n\n }, {\n key: 'regenCache',\n value: function regenCache() {\n var _this6 = this;\n\n Object.keys(this._modules).forEach(function (moduleKey) {\n _this6.meta[moduleKey] = _this6.getMetaFromPath(moduleKey, _this6._modules[moduleKey]);\n });\n }\n\n /**\n * Recursively remove old tags\n *\n * @param {string} replaceKey - key of module for which we need to remove old tags\n * @param {object} tag - tag to start our search with\n * (usually the tag immediately preceding the current placeholder)\n */\n\n }, {\n key: 'removeOldTags',\n value: function removeOldTags(replaceKey, tag) {\n if (tag) {\n var parentModule = InsertNodes.getDataAttribute(tag, 'parent-module');\n var selfModule = InsertNodes.getDataAttribute(tag, 'self-module');\n\n if (parentModule === replaceKey && selfModule !== replaceKey) {\n // This is a child of the current module,\n // so remove it and its children (if applicable)\n var childrenModule = selfModule;\n var nextTag = tag.previousSibling;\n\n if (childrenModule) {\n this.removeOldTags(childrenModule, nextTag);\n // Reset nextTag if we removed a child\n nextTag = tag.previousSibling;\n }\n\n tag.parentNode.removeChild(tag);\n this.removeOldTags(replaceKey, nextTag);\n }\n }\n }\n\n /**\n * Replace a single template marker with template content.\n *\n * @param {object} replaceElements - Array of elements to check for Huron placeholders\n * @param {object} meta - Module metadata\n */\n\n }, {\n key: 'replaceTemplate',\n value: function replaceTemplate(meta, replaceElements) {\n var _this7 = this;\n\n var type = this.validateType(meta.type);\n var tags = [];\n var replace = replaceElements;\n var hasStyleguideHelpers = false;\n\n if (!replace) {\n replace = document.querySelectorAll('[data-huron-id][data-huron-type]');\n }\n\n if (type) {\n replace.forEach(function (tag) {\n var tagType = InsertNodes.getDataAttribute(tag, 'huron-type');\n var tagId = InsertNodes.getDataAttribute(tag, 'huron-id');\n\n if (tagId === meta.id && tagType === type) {\n tags.push(tag);\n }\n });\n\n if (tags && tags.length && meta.render) {\n tags.forEach(function (currentTag) {\n var modifiedPlaceholder = currentTag;\n var modifier = InsertNodes.getDataAttribute(modifiedPlaceholder, 'huron-modifier');\n var parent = modifiedPlaceholder.parentNode;\n var data = (0, _fp.compose)(_this7.provideClassnames.bind(_this7), InsertNodes.applyModifier)(meta.data, modifier);\n var rendered = meta.render(data);\n var renderedTemplate = InsertNodes.convertToElement(rendered).querySelector('template');\n var renderedContents = null;\n\n // Remove existing module tags\n _this7.removeOldTags(meta.replaceKey, modifiedPlaceholder.previousSibling);\n\n // Get the contents of the rendered template\n renderedContents = [].concat(_toConsumableArray(renderedTemplate.content.children));\n\n // Insert each tag of the template contents before placeholder\n renderedContents.forEach(function (element) {\n var newEl = element;\n\n if (1 === newEl.nodeType) {\n newEl.dataset.parentModule = meta.replaceKey;\n hasStyleguideHelpers = !hasStyleguideHelpers ? InsertNodes.isSectionHelper(newEl, meta) : hasStyleguideHelpers;\n\n parent.insertBefore(newEl, modifiedPlaceholder);\n }\n });\n\n // Add module replacement key to this placeholder\n modifiedPlaceholder.dataset.selfModule = meta.replaceKey;\n\n // Hide the placeholder\n modifiedPlaceholder.style.display = 'none';\n\n // Recursively load modules, excluding the current one\n _this7.cycleModules(renderedContents, {\n property: 'key',\n values: [meta.key, _this7._sectionTemplatePath],\n include: false\n });\n\n if (hasStyleguideHelpers) {\n _this7.cycleStyleguide();\n }\n });\n }\n } else {\n console.warn( // eslint-disable-line no-console\n 'Could not render module\\n section: ' + meta.id + '\\n type: ' + meta.type);\n }\n }\n\n /**\n * Verify specified element is using an acceptable huron type\n *\n * @param {string} type - type of partial (template, data, description, section or prototype )\n * @return {string} type - huron type or 'template' if invalid\n */\n\n }, {\n key: 'validateType',\n value: function validateType(type) {\n if ('data' === type) {\n return 'template';\n }\n\n if (!this._types.includes(type)) {\n return false;\n }\n\n return type;\n }\n\n /*\n * Set new modules object\n */\n\n }, {\n key: 'modules',\n set: function set(modules) {\n this._modules = modules;\n this._moduleIds = Object.keys(modules);\n }\n\n /*\n * Set store\n */\n\n }, {\n key: 'store',\n set: function set(store) {\n this._store = store;\n this._config = store.config;\n this._sections = store.sections;\n this._templates = store.templates;\n this._prototypes = store.prototypes;\n this._types = store.types;\n this._sectionTemplatePath = store.sectionTemplatePath;\n\n // Completely rerender prototype if any CSS modules classnames change\n if (!(0, _fp.isEqual)(this._classNames, store.classNames)) {\n var isInitialRender = !this._classNames;\n this._classNames = store.classNames;\n\n // Only rerender after initial render (when classnames is not falsy)\n if (!isInitialRender) {\n this.cycleModules();\n }\n }\n }\n }], [{\n key: 'applyModifier',\n value: function applyModifier(data, modifier) {\n // If we have a modifier, use it, otherwise use the entire data set\n if (modifier && data && data[modifier]) {\n return Object.assign({}, data[modifier], { modifier: modifier });\n }\n\n return data;\n }\n\n /**\n * Get markup from any type of module (html, json or template)\n *\n * @param {string} content - String corresponding to markup\n * @return {object} el.firstElementChild - HTML module\n */\n\n }, {\n key: 'convertToElement',\n value: function convertToElement(content) {\n var el = document.createElement('div');\n\n el.innerHTML = content;\n return el.firstElementChild;\n }\n\n /**\n * Filter module object by module key or module type\n *\n * @param {object} filter - Filter for modules. Options:\n * @param {string} filter.property - Which property to filter ('key' or 'type')\n * @param {array} filter.values - Values for property\n * @param {bool} filter.include - Whether the values should be included or excluded (true = include, false = exclude)\n * @param {object} moduleMeta - Filter for modules. Fields explained in the filterModules() function docs\n * @return {bool} match - determine if modules need to be filtered\n */\n\n }, {\n key: 'filterModules',\n value: function filterModules(filter, moduleMeta) {\n var match = true;\n\n // Check if we should filter out any modules\n if ('object' === (typeof filter === 'undefined' ? 'undefined' : _typeof(filter)) && {}.hasOwnProperty.call(filter, 'property') && {}.hasOwnProperty.call(filter, 'values') && {}.hasOwnProperty.call(filter, 'include')) {\n match = filter.values.filter(function (value) {\n return moduleMeta[filter.property] === value;\n });\n return Boolean(match.length) === filter.include;\n }\n\n console.log(' // eslint-disable-line no-console\\n filter ' + filter + ' is not in a valid format.\\n module filters must include \\'property\\', \\'values\\', and \\'include\\' properties\\n ');\n\n return match;\n }\n\n /**\n * Retrieve a data attribute from a tag using one of two methods\n *\n * @param {HTMLElement} tag - DOM node on which to check for a data attribute\n * @param {string} attr - attribute to check for\n * @returns {string} data - contents of data attribute\n */\n\n }, {\n key: 'getDataAttribute',\n value: function getDataAttribute(tag, attr) {\n var data = false;\n\n // Check if element has dataset and, if so, use it\n if (tag.dataset) {\n data = tag.dataset[attr];\n }\n\n // Fallback to getAttribute for ugly old Safari\n if (!data && tag.getAttribute) {\n data = tag.getAttribute('data-' + attr);\n }\n\n return data;\n }\n\n /**\n * Check if this tag is a styleguide helper\n *\n * @param {object} tag - tag to check\n * @param {object} meta - module metadata\n * @return {bool}\n */\n\n }, {\n key: 'isSectionHelper',\n value: function isSectionHelper(tag, meta) {\n if ('prototype' === meta.type) {\n return tag.hasAttribute('huron-sections') || tag.hasAttribute('huron-menu');\n }\n\n return false;\n }\n }]);\n\n return InsertNodes;\n}();\n/* eslint-enable */\n\n\nexports.default = InsertNodes;//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvd2ViL2luZGV4LmpzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vL3NyYy93ZWIvaW5kZXguanM/NDYyYiJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjb21wb3NlLCBpc0VxdWFsIH0gZnJvbSAnbG9kYXNoL2ZwJztcblxuLyogZXNsaW50LWRpc2FibGUgbm8tdW5kZXJzY29yZS1kYW5nbGUgKi9cbi8vIEFjY2VwdCB0aGUgaHVyb24uanMgbW9kdWxlIGZvciBIdXJvbiBkZXZlbG9wbWVudFxuaWYgKG1vZHVsZS5ob3QpIHtcbiAgbW9kdWxlLmhvdC5hY2NlcHQoKTtcbn1cblxuLyoqIENsYXNzIGZvciBpbnNlcnRpbmcgSFRNTCBzbmlwcGV0cyBhdCBwYXJ0aWN1bGFyIGluc2VydGlvbiBwb2ludHMuXG4gKiBVc2VzIHJlcXVpcmUoKSB0byBncmFiIGh0bWwgcGFydGlhbHMsIHRoZW4gaW5zZXJ0cyB0aGF0IGh0bWxcbiAqIGludG8gYW4gZWxlbWVudCB3aXRoIGF0dHJpYnV0ZSBbaHVyb24taWRdIGNvcnJlc3BvbmRpbmcgdG8gdGhlIHJlZmVyZW5jZSBVUkkgb2YgdGhlIHRhcmdldCBLU1Mgc2VjdGlvbixcbiAqIGFuZCBbaHVyb24tdHlwZV0gY29ycmVzcG9uZGluZyB3aXRoIHRoZSByZXF1aXJlZCBLU1MgZmllbGRcbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgSW5zZXJ0Tm9kZXMge1xuXG4gIGNvbnN0cnVjdG9yKG1vZHVsZXMsIHN0b3JlKSB7XG4gICAgLyoqIHdlYnBhY2sgbW9kdWxlIGxpc3QgaW4gd2hpY2gga2V5cyBhcmUgcmVsYXRpdmUgcmVxdWlyZSBwYXRocyBhbmQgdmFsdWVzIGFyZSB0aGUgbW9kdWxlIGNvbnRlbnRzICovXG4gICAgdGhpcy5fbW9kdWxlcyA9IG1vZHVsZXM7XG4gICAgLyoqIGFycmF5IG9mIG1vZHVsZSBrZXlzICovXG4gICAgdGhpcy5fbW9kdWxlSWRzID0gT2JqZWN0LmtleXMobW9kdWxlcyk7XG4gICAgLyoqIHJlZmVyZW5jZSB0byB0aGUgaHVyb24gY29uZmlnICovXG4gICAgdGhpcy5fY29uZmlnID0gbnVsbDtcbiAgICAvKiogS1NTIHNlY3Rpb25zIG9yZ2FuaXplZCBpbiB2YXJpb3VzIGZvcm1hdHMgaW5jbHVkaW5nIGJ5IHJlZmVyZW5jZSBVUkksIGJ5IG1vZHVsZSBrZXksIGFuZCBtb2R1bGVzIHNvcnRlZCBieSBwYXJlbnQvY2hpbGQgKi9cbiAgICB0aGlzLl9zZWN0aW9ucyA9IG51bGw7XG4gICAgLyoqIEtleS92YWx1ZSBwYWlycyBvZiBwYXJ0bmVyIGRhdGEgYW5kIHRlbXBsYXRlIGZpbGVzICovXG4gICAgdGhpcy5fdGVtcGxhdGVzID0gbnVsbDtcbiAgICAvKiogYXJyYXkgb2YgcHJvdG90eXBlcyAqL1xuICAgIHRoaXMuX3Byb3RvdHlwZXMgPSBudWxsO1xuICAgIC8qKiBhcnJheSBvZiB2YWxpZCBodXJvbiBwbGFjZWhvbGRlciB0eXBlcyAqL1xuICAgIHRoaXMuX3R5cGVzID0gbnVsbDtcbiAgICAvKiogYXJyYXkgb2YgQ1NTIG1vZHVsZXMgY2xhc3NuYW1lcyAqL1xuICAgIHRoaXMuX2NsYXNzTmFtZXMgPSBudWxsO1xuXG4gICAgLyoqIENhY2hlIGZvciBtb2R1bGUgbWV0YWRhdGEgKi9cbiAgICB0aGlzLm1ldGEgPSB7fTtcblxuICAgIC8qKiBSZWZlcmVuY2UgdG8gZW50aXJlIG1lbW9yeSBzdG9yZSAqL1xuICAgIHRoaXMuc3RvcmUgPSBzdG9yZTtcblxuICAgIC8vIEluaXRzXG4gICAgdGhpcy5jeWNsZU1vZHVsZXMoKTtcbiAgICB0aGlzLmN5Y2xlU3R5bGVndWlkZSgpO1xuICB9XG5cbiAgLyoqXG4gICAqIEFwcGx5IGEgbW9kaWZpZXIgaWYgb25lIGV4aXN0c1xuICAgKlxuICAgKiBAcGFyYW0ge29iamVjdH0gZGF0YSAtIGRhdGEgd2l0aCB3aGljaCB0byByZW5kZXIgdGVtcGxhdGVcbiAgICogQHBhcmFtIHtzdHJpbmd9IG1vZGlmaWVyIC0gdGFyZ2V0IG1vZGlmaWVyXG4gICAqXG4gICAqIEByZXR1cm4ge3N0cmluZ30gZGF0YSAtIHN1YnNldCBvZiBkYXRhIG9iamVjdCBmb3Igc3VwcGxpZWQgbW9kaWZpZXJcbiAgICovXG4gIHN0YXRpYyBhcHBseU1vZGlmaWVyKGRhdGEsIG1vZGlmaWVyKSB7XG4gICAgLy8gSWYgd2UgaGF2ZSBhIG1vZGlmaWVyLCB1c2UgaXQsIG90aGVyd2lzZSB1c2UgdGhlIGVudGlyZSBkYXRhIHNldFxuICAgIGlmIChtb2RpZmllciAmJiBkYXRhICYmIGRhdGFbbW9kaWZpZXJdKSB7XG4gICAgICByZXR1cm4gT2JqZWN0LmFzc2lnbih7fSwgZGF0YVttb2RpZmllcl0sIHsgbW9kaWZpZXIgfSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIGRhdGE7XG4gIH1cblxuICAvKipcbiAgICogR2V0IG1hcmt1cCBmcm9tIGFueSB0eXBlIG9mIG1vZHVsZSAoaHRtbCwganNvbiBvciB0ZW1wbGF0ZSlcbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IGNvbnRlbnQgLSBTdHJpbmcgY29ycmVzcG9uZGluZyB0byBtYXJrdXBcbiAgICogQHJldHVybiB7b2JqZWN0fSBlbC5maXJzdEVsZW1lbnRDaGlsZCAtIEhUTUwgbW9kdWxlXG4gICAqL1xuICBzdGF0aWMgY29udmVydFRvRWxlbWVudChjb250ZW50KSB7XG4gICAgY29uc3QgZWwgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KCdkaXYnKTtcblxuICAgIGVsLmlubmVySFRNTCA9IGNvbnRlbnQ7XG4gICAgcmV0dXJuIGVsLmZpcnN0RWxlbWVudENoaWxkO1xuICB9XG5cbiAgLyoqXG4gICAqIEZpbHRlciBtb2R1bGUgb2JqZWN0IGJ5IG1vZHVsZSBrZXkgb3IgbW9kdWxlIHR5cGVcbiAgICpcbiAgICogQHBhcmFtIHtvYmplY3R9IGZpbHRlciAtIEZpbHRlciBmb3IgbW9kdWxlcy4gT3B0aW9uczpcbiAgICogQHBhcmFtIHtzdHJpbmd9IGZpbHRlci5wcm9wZXJ0eSAtIFdoaWNoIHByb3BlcnR5IHRvIGZpbHRlciAoJ2tleScgb3IgJ3R5cGUnKVxuICAgKiBAcGFyYW0ge2FycmF5fSBmaWx0ZXIudmFsdWVzIC0gVmFsdWVzIGZvciBwcm9wZXJ0eVxuICAgKiBAcGFyYW0ge2Jvb2x9IGZpbHRlci5pbmNsdWRlIC0gV2hldGhlciB0aGUgdmFsdWVzIHNob3VsZCBiZSBpbmNsdWRlZCBvciBleGNsdWRlZCAodHJ1ZSA9IGluY2x1ZGUsIGZhbHNlID0gZXhjbHVkZSlcbiAgICogQHBhcmFtIHtvYmplY3R9IG1vZHVsZU1ldGEgLSBGaWx0ZXIgZm9yIG1vZHVsZXMuIEZpZWxkcyBleHBsYWluZWQgaW4gdGhlIGZpbHRlck1vZHVsZXMoKSBmdW5jdGlvbiBkb2NzXG4gICAqIEByZXR1cm4ge2Jvb2x9IG1hdGNoIC0gZGV0ZXJtaW5lIGlmIG1vZHVsZXMgbmVlZCB0byBiZSBmaWx0ZXJlZFxuICAgKi9cbiAgc3RhdGljIGZpbHRlck1vZHVsZXMoZmlsdGVyLCBtb2R1bGVNZXRhKSB7XG4gICAgbGV0IG1hdGNoID0gdHJ1ZTtcblxuICAgIC8vIENoZWNrIGlmIHdlIHNob3VsZCBmaWx0ZXIgb3V0IGFueSBtb2R1bGVzXG4gICAgaWYgKFxuICAgICAgJ29iamVjdCcgPT09IHR5cGVvZiBmaWx0ZXIgJiZcbiAgICAgIHt9Lmhhc093blByb3BlcnR5LmNhbGwoZmlsdGVyLCAncHJvcGVydHknKSAmJlxuICAgICAge30uaGFzT3duUHJvcGVydHkuY2FsbChmaWx0ZXIsICd2YWx1ZXMnKSAmJlxuICAgICAge30uaGFzT3duUHJvcGVydHkuY2FsbChmaWx0ZXIsICdpbmNsdWRlJylcbiAgICApIHtcbiAgICAgIG1hdGNoID0gZmlsdGVyLnZhbHVlcy5maWx0ZXIoXG4gICAgICAgICh2YWx1ZSkgPT4gbW9kdWxlTWV0YVtmaWx0ZXIucHJvcGVydHldID09PSB2YWx1ZVxuICAgICAgKTtcbiAgICAgIHJldHVybiBCb29sZWFuKG1hdGNoLmxlbmd0aCkgPT09IGZpbHRlci5pbmNsdWRlO1xuICAgIH1cblxuICAgIGNvbnNvbGUubG9nKGAgLy8gZXNsaW50LWRpc2FibGUtbGluZSBuby1jb25zb2xlXG4gICAgICBmaWx0ZXIgJHtmaWx0ZXJ9IGlzIG5vdCBpbiBhIHZhbGlkIGZvcm1hdC5cbiAgICAgIG1vZHVsZSBmaWx0ZXJzIG11c3QgaW5jbHVkZSAncHJvcGVydHknLCAndmFsdWVzJywgYW5kICdpbmNsdWRlJyBwcm9wZXJ0aWVzXG4gICAgYCk7XG5cbiAgICByZXR1cm4gbWF0Y2g7XG4gIH1cblxuICAvKipcbiAgICogUmV0cmlldmUgYSBkYXRhIGF0dHJpYnV0ZSBmcm9tIGEgdGFnIHVzaW5nIG9uZSBvZiB0d28gbWV0aG9kc1xuICAgKlxuICAgKiBAcGFyYW0ge0hUTUxFbGVtZW50fSB0YWcgLSBET00gbm9kZSBvbiB3aGljaCB0byBjaGVjayBmb3IgYSBkYXRhIGF0dHJpYnV0ZVxuICAgKiBAcGFyYW0ge3N0cmluZ30gYXR0ciAtIGF0dHJpYnV0ZSB0byBjaGVjayBmb3JcbiAgICogQHJldHVybnMge3N0cmluZ30gZGF0YSAtIGNvbnRlbnRzIG9mIGRhdGEgYXR0cmlidXRlXG4gICAqL1xuICBzdGF0aWMgZ2V0RGF0YUF0dHJpYnV0ZSh0YWcsIGF0dHIpIHtcbiAgICBsZXQgZGF0YSA9IGZhbHNlO1xuXG4gICAgLy8gQ2hlY2sgaWYgZWxlbWVudCBoYXMgZGF0YXNldCBhbmQsIGlmIHNvLCB1c2UgaXRcbiAgICBpZiAodGFnLmRhdGFzZXQpIHtcbiAgICAgIGRhdGEgPSB0YWcuZGF0YXNldFthdHRyXTtcbiAgICB9XG5cbiAgICAvLyBGYWxsYmFjayB0byBnZXRBdHRyaWJ1dGUgZm9yIHVnbHkgb2xkIFNhZmFyaVxuICAgIGlmICghZGF0YSAmJiB0YWcuZ2V0QXR0cmlidXRlKSB7XG4gICAgICBkYXRhID0gdGFnLmdldEF0dHJpYnV0ZShgZGF0YS0ke2F0dHJ9YCk7XG4gICAgfVxuXG4gICAgcmV0dXJuIGRhdGE7XG4gIH1cblxuICAvKipcbiAgICogQ2hlY2sgaWYgdGhpcyB0YWcgaXMgYSBzdHlsZWd1aWRlIGhlbHBlclxuICAgKlxuICAgKiBAcGFyYW0ge29iamVjdH0gdGFnIC0gdGFnIHRvIGNoZWNrXG4gICAqIEBwYXJhbSB7b2JqZWN0fSBtZXRhIC0gbW9kdWxlIG1ldGFkYXRhXG4gICAqIEByZXR1cm4ge2Jvb2x9XG4gICAqL1xuICBzdGF0aWMgaXNTZWN0aW9uSGVscGVyKHRhZywgbWV0YSkge1xuICAgIGlmICgncHJvdG90eXBlJyA9PT0gbWV0YS50eXBlKSB7XG4gICAgICByZXR1cm4gdGFnLmhhc0F0dHJpYnV0ZSgnaHVyb24tc2VjdGlvbnMnKSB8fFxuICAgICAgICB0YWcuaGFzQXR0cmlidXRlKCdodXJvbi1tZW51Jyk7XG4gICAgfVxuXG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgLyoqXG4gICAqIFJlcGxhY2UgYWxsIHRlbXBsYXRlIG1hcmtlcnMgd2l0aCB0aGUgYWN0dWFsIHRlbXBsYXRlIG1hcmt1cC5cbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IGNvbnRleHQgLSBUaGUgd2l0aGluIHdoaWNoIHRvIHJlcGxhY2UgbWFya3VwXG4gICAqIEBwYXJhbSB7b2JqZWN0fSBmaWx0ZXIgLSBGaWx0ZXIgZm9yIG1vZHVsZXMuIEZpZWxkcyBleHBsYWluZWQgaW4gdGhlIGZpbHRlck1vZHVsZXMoKSBmdW5jdGlvbiBkb2NzXG4gICAqL1xuICBjeWNsZU1vZHVsZXMoY29udGV4dCA9IGZhbHNlLCBmaWx0ZXIgPSBmYWxzZSkge1xuICAgIGxldCBtb2R1bGVMaXN0ID0ge307XG4gICAgbGV0IGVsZW1lbnRMaXN0ID0gY29udGV4dDtcblxuICAgIC8vIFdlJ3JlIHJlcGxhY2luZyB0b3AtbGV2ZWwgZWxlbWVudHNcbiAgICBpZiAoIWVsZW1lbnRMaXN0KSB7XG4gICAgICB0aGlzLnJlZ2VuQ2FjaGUoKTtcblxuICAgICAgLy8gRmluZCBhbGwgdG9wLWxldmVsIGh1cm9uIHBsYWNlaG9sZGVyc1xuICAgICAgZWxlbWVudExpc3QgPSBbLi4uZG9jdW1lbnQucXVlcnlTZWxlY3RvckFsbChcbiAgICAgICAgJ1tkYXRhLWh1cm9uLWlkXVtkYXRhLWh1cm9uLXR5cGVdJ1xuICAgICAgKV07XG4gICAgfVxuXG4gICAgbW9kdWxlTGlzdCA9IHRoaXMuZ2V0TW9kdWxlTGlzdEZyb21UYWdzKGVsZW1lbnRMaXN0KTtcblxuICAgIC8vIExvb3AgdGhyb3VnaCBtb2R1bGVzIGFycmF5XG4gICAgT2JqZWN0LmtleXMobW9kdWxlTGlzdCkuZm9yRWFjaCgoa2V5KSA9PiB7XG4gICAgICBjb25zdCBtb2R1bGUgPSB0aGlzLl9tb2R1bGVzW2tleV07XG4gICAgICBjb25zdCByZXBsYWNlRWxlbWVudHMgPSBtb2R1bGVMaXN0W2tleV07XG5cbiAgICAgIHRoaXMubG9hZE1vZHVsZShrZXksIG1vZHVsZSwgcmVwbGFjZUVsZW1lbnRzLCB0cnVlLCBmaWx0ZXIpO1xuICAgIH0pO1xuICB9XG5cbiAgLyoqXG4gICAqIEhlbHBlciBmb3IgcmVsb2FkaW5nIHNlY3Rpb25zIG9ubHlcbiAgICovXG4gIGN5Y2xlU2VjdGlvbnMoKSB7XG4gICAgdGhpcy5jeWNsZU1vZHVsZXMoZmFsc2UsIHtcbiAgICAgIHByb3BlcnR5OiAndHlwZScsXG4gICAgICB2YWx1ZXM6IFsnc2VjdGlvbiddLFxuICAgICAgaW5jbHVkZTogdHJ1ZSxcbiAgICB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZWxvYWQgc3R5bGVndWlkZSBzZWN0aW9ucyBhbmQgbWVudSBoZWxwZXJzXG4gICAqL1xuICBjeWNsZVN0eWxlZ3VpZGUoKSB7XG4gICAgY29uc3Qgc2VjdGlvbnNRdWVyeSA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3IoJ1todXJvbi1zZWN0aW9uc10nKTtcbiAgICBjb25zdCBtZW51UXVlcnkgPSBkb2N1bWVudC5xdWVyeVNlbGVjdG9yKCdbaHVyb24tbWVudV0nKTtcblxuICAgIC8vIFNlY3Rpb25zXG4gICAgaWYgKHNlY3Rpb25zUXVlcnkpIHtcbiAgICAgIHNlY3Rpb25zUXVlcnkuaW5uZXJIVE1MID0gJyc7XG4gICAgICB0aGlzLm91dHB1dFNlY3Rpb25zKG51bGwsIHNlY3Rpb25zUXVlcnkpO1xuICAgICAgdGhpcy5jeWNsZVNlY3Rpb25zKCk7XG4gICAgfVxuXG4gICAgLy8gTWVudVxuICAgIGlmIChtZW51UXVlcnkpIHtcbiAgICAgIG1lbnVRdWVyeS5pbm5lckhUTUwgPSAnJztcblxuICAgICAgaWYgKG51bGwgPT09IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3IoJy5zZWN0aW9uLW1lbnVfX2V4cGFuZCcpKSB7XG4gICAgICAgIGNvbnN0IG1lbnVUcmlnZ2VyID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnYnV0dG9uJyk7XG5cbiAgICAgICAgbWVudVRyaWdnZXIuY2xhc3NMaXN0LmFkZCgnc2VjdGlvbi1tZW51X19leHBhbmQnKTtcbiAgICAgICAgbWVudVRyaWdnZXIuaW5uZXJIVE1MID0gJ1NlY3Rpb25zIE1lbnUnO1xuICAgICAgICBkb2N1bWVudC5ib2R5Lmluc2VydEJlZm9yZShcbiAgICAgICAgICBtZW51UXVlcnkuYXBwZW5kQ2hpbGQobWVudVRyaWdnZXIpLFxuICAgICAgICAgIGRvY3VtZW50LmJvZHkuY2hpbGROb2Rlc1swXVxuICAgICAgICApO1xuXG4gICAgICAgIC8vIEFkZCBtZW51IHRyaWdnZXIgaGFuZGxlclxuICAgICAgICBtZW51VHJpZ2dlci5hZGRFdmVudExpc3RlbmVyKCdjbGljaycsICgpID0+IHtcbiAgICAgICAgICBkb2N1bWVudC5ib2R5LmNsYXNzTGlzdC50b2dnbGUoJ3NlY3Rpb24tbWVudS1vcGVuJyk7XG4gICAgICAgIH0pO1xuICAgICAgfVxuXG4gICAgICAvLyBDcmVhdGUgbWVudVxuICAgICAgdGhpcy5vdXRwdXRNZW51KG51bGwsIG1lbnVRdWVyeSk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEdlbmVyYXRlIGEgdW5pcXVlIGtleSBmb3IgdGFyZ2V0aW5nIG1hcmt1cCByZXBsYWNlbWVudFxuICAgKlxuICAgKiBAcGFyYW0ge3N0cmluZ30ga2V5IC0gbW9kdWxlIGtleSAod2VicGFjayByZXF1aXJlIHBhdGgpIHRvIGNvbnZlcnQgaW50byBhIHJlcGxhY2VtZW50IGtleVxuICAgKiBAcmV0dXJuIHtzdHJpbmd9IGtleSAtIGdlbmVyYXRlZCByZXBsYWNlbWVudCBrZXlcbiAgICovXG4gIGdlbmVyYXRlTW9kdWxlUmVwbGFjZUtleShrZXkpIHtcbiAgICBsZXQgY3VycmVudEtleSA9IGtleTtcblxuICAgIC8vIElmIHRoaXMgaXMgc2VjdGlvbiBkYXRhLCB1c2UgdGhlIHNlY3Rpb24gdGVtcGxhdGUgcGF0aFxuICAgIGlmIChrZXkuaW5jbHVkZXMoJy1zZWN0aW9uLmpzb24nKSkge1xuICAgICAgY3VycmVudEtleSA9IHRoaXMuX3NlY3Rpb25UZW1wbGF0ZVBhdGg7XG4gICAgLy8gSWYgdXBkYXRlZCBtb2R1bGUgaXMgYSBqc29uIGZpbGUsIHVzZSB0ZW1wbGF0ZSBrZXkgaW5zdGVhZFxuICAgIH0gZWxzZSBpZiAoa2V5LmluY2x1ZGVzKCcuanNvbicpKSB7XG4gICAgICBjdXJyZW50S2V5ID0gdGhpcy5fdGVtcGxhdGVzW2tleV07XG4gICAgfVxuXG4gICAgcmV0dXJuIGBfJHtjdXJyZW50S2V5LnJlcGxhY2UoL1svLl0vZywgJ18nKX1gO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCBtb2R1bGUgbWV0YWRhdGEgZnJvbSBhIG1vZHVsZSByZXF1aXJlIHBhdGhcbiAgICpcbiAgICogQHBhcmFtICB7c3RyaW5nfSBrZXkgLSBNb2R1bGUgcmVxdWlyZSBwYXRoXG4gICAqIEByZXR1cm4ge29iamVjdH0gY29udGFpbmluZyBtb2R1bGUgaWQsIG1vZHVsZSB0eXBlLCBrZXkgYW5kIHRoZSBtb2R1bGUgY29udGVudHNcbiAgICovXG4gIGdldE1ldGFGcm9tUGF0aChrZXksIG1vZHVsZSkge1xuICAgIGNvbnN0IHNlY3Rpb25zID0gdGhpcy5fc2VjdGlvbnMuc2VjdGlvbnNCeVBhdGg7XG4gICAgY29uc3QgdGVtcGxhdGVUeXBlcyA9IHRoaXMuX3R5cGVzLmZpbHRlcigodHlwZSkgPT4gJ3Byb3RvdHlwZScgIT09IHR5cGUpO1xuICAgIGxldCBpZCA9IGZhbHNlO1xuICAgIGxldCB0eXBlID0gZmFsc2U7XG5cbiAgICAvKiBlc2xpbnQtZGlzYWJsZSBzcGFjZS11bmFyeS1vcHMgKi9cbiAgICBpZiAoLTEgIT09IGtleS5pbmRleE9mKCcuL3Byb3RvdHlwZXMnKSkge1xuICAgIC8qIGVzbGludC1lbmFibGUgc3BhY2UtdW5hcnktb3BzICovXG4gICAgICBjb25zdCBwcm90b3R5cGUgPSBPYmplY3Qua2V5cyh0aGlzLl9wcm90b3R5cGVzKVxuICAgICAgICAuZmlsdGVyKChuYW1lKSA9PiB0aGlzLl9wcm90b3R5cGVzW25hbWVdID09PSBrZXkpO1xuXG4gICAgICBpZiAocHJvdG90eXBlLmxlbmd0aCkge1xuICAgICAgICBpZCA9IHByb3RvdHlwZVswXTtcbiAgICAgICAgdHlwZSA9ICdwcm90b3R5cGUnO1xuICAgICAgfVxuICAgIH0gZWxzZSBpZiAoa2V5ID09PSB0aGlzLl9zZWN0aW9uVGVtcGxhdGVQYXRoKSB7XG4gICAgICBpZCA9ICdzZWN0aW9ucy10ZW1wbGF0ZSc7XG4gICAgICB0eXBlID0gJ3NlY3Rpb25zLXRlbXBsYXRlJztcbiAgICB9IGVsc2Uge1xuICAgICAgbGV0IHRlc3RUeXBlcyA9IFtdO1xuICAgICAgY29uc3QgdGVzdFNlY3Rpb25zID0gT2JqZWN0LmtleXMoc2VjdGlvbnMpLmZpbHRlcigoc2VjdGlvbikgPT4ge1xuICAgICAgICBjb25zdCB0ZW1wVHlwZXMgPSB0ZW1wbGF0ZVR5cGVzLmZpbHRlcihcbiAgICAgICAgICAoY3VycmVudFR5cGUpID0+IHNlY3Rpb25zW3NlY3Rpb25dW2Ake2N1cnJlbnRUeXBlfVBhdGhgXSA9PT0ga2V5XG4gICAgICAgICk7XG5cbiAgICAgICAgaWYgKHRlbXBUeXBlcy5sZW5ndGgpIHtcbiAgICAgICAgICB0ZXN0VHlwZXMgPSB0ZW1wVHlwZXM7XG4gICAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9KTtcblxuICAgICAgaWYgKFxuICAgICAgICB0ZXN0U2VjdGlvbnMgJiZcbiAgICAgICAgdGVzdFNlY3Rpb25zLmxlbmd0aCAmJlxuICAgICAgICB0ZXN0VHlwZXMgJiZcbiAgICAgICAgdGVzdFR5cGVzLmxlbmd0aFxuICAgICAgKSB7XG4gICAgICAgIGlkID0gc2VjdGlvbnNbdGVzdFNlY3Rpb25zWzBdXS5yZWZlcmVuY2VVUkk7XG4gICAgICAgIHR5cGUgPSB0ZXN0VHlwZXNbMF07XG4gICAgICB9XG4gICAgfVxuXG4gICAgaWYgKGlkICYmIHR5cGUpIHtcbiAgICAgIGNvbnN0IHJlbmRlckRhdGEgPSB0aGlzLmdldE1vZHVsZVJlbmRlcih0eXBlLCBrZXksIG1vZHVsZSk7XG4gICAgICBjb25zdCByZXBsYWNlS2V5ID0gdGhpcy5nZW5lcmF0ZU1vZHVsZVJlcGxhY2VLZXkoa2V5KTtcblxuICAgICAgaWYgKHJlbmRlckRhdGEpIHtcbiAgICAgICAgcmV0dXJuIE9iamVjdC5hc3NpZ24oeyBpZCwgdHlwZSwga2V5LCByZXBsYWNlS2V5LCBtb2R1bGUgfSwgcmVuZGVyRGF0YSk7XG4gICAgICB9XG4gICAgfVxuXG4gICAgY29uc29sZS53YXJuKCAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIG5vLWNvbnNvbGVcbiAgICAgIGBNb2R1bGUgJyR7a2V5fScgZG9lcyBub3QgZXhpc3Qgb24gdGhlIHBhZ2VcbiAgICAgIG9yIGlzIG5vIGxvbmdlciBpbiB1c2VgXG4gICAgKTtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICAvKipcbiAgICogQ2hlY2sgaWYgYSB0YWcgaXMgYSBodXJvbiBwbGFjZWhvbGRlciBhbmQsIGlmIHNvLFxuICAgKiByZXR1cm4gaXRzIGFzc29jaWF0ZWQgbW9kdWxlIGtleVxuICAgKlxuICAgKiBAcGFyYW0ge29iamVjdH0gdGFnIC0gdGFnIHRvIGNoZWNrXG4gICAqIEByZXR1cm4ge2Jvb2x9IGFzc29jaWF0ZWQgbW9kdWxlIGtleVxuICAgKi9cbiAgZ2V0TW9kdWxlS2V5RnJvbVRhZyh0YWcpIHtcbiAgICAvLyBTYWZhcmkvd2Via2l0IGhhcyBzb21lIHRyb3VibGUgcGFyc2luZyBkYXRhc2V0IGluIGNlcnRhaW4gY2FzZXMuXG4gICAgLy8gVGhpcyBpcyBhIGZhbGxiYWNrIG1ldGhvZCBvZiBhY2Nlc3NpbmcgdGhlIHNhbWUgZGF0YS5cbiAgICBjb25zdCB0eXBlID0gSW5zZXJ0Tm9kZXMuZ2V0RGF0YUF0dHJpYnV0ZSh0YWcsICdodXJvbi10eXBlJyk7XG4gICAgY29uc3QgaWQgPSBJbnNlcnROb2Rlcy5nZXREYXRhQXR0cmlidXRlKHRhZywgJ2h1cm9uLWlkJyk7XG4gICAgY29uc3Qgc2VjdGlvbiA9IHRoaXMuX3NlY3Rpb25zLnNlY3Rpb25zQnlVUklbaWRdO1xuXG4gICAgaWYgKGlkICYmIHR5cGUpIHtcbiAgICAgIGlmIChzZWN0aW9uKSB7XG4gICAgICAgIHJldHVybiBzZWN0aW9uW2Ake3R5cGV9UGF0aGBdO1xuICAgICAgfSBlbHNlIGlmICgncHJvdG90eXBlJyA9PT0gdHlwZSkge1xuICAgICAgICByZXR1cm4gdGhpcy5fcHJvdG90eXBlc1tpZF07XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgLyoqXG4gICAqIENoZWNrIGlmIGFuIGFycmF5IG9mIGVsZW1lbnRzIGNvbnRhaW5zIGEgSHVyb24gcGxhY2Vob2xkZXJcbiAgICpcbiAgICogQHBhcmFtIHthcnJheX0gdGFncyAtIGFycmF5IG9mIERPTSBub2Rlc1xuICAgKiBAcGFyYW0ge2Jvb2x9IHJlY3Vyc2UgLSBzaG91bGQgd2UgcmVjdXJzZSB0aGlzIGZ1bmN0aW9uIHdpdGggYSBuZXcgYXJyYXlcbiAgICogQHJldHVybiB7b2JqZWN0fSBtb2R1bGVMaXN0IC0gSHVyb24gcGxhY2Vob2xkZXIgRE9NIG5vZGVcbiAgICovXG4gIGdldE1vZHVsZUxpc3RGcm9tVGFncyhlbGVtZW50cywgcmVjdXJzZSA9IHRydWUpIHtcbiAgICBjb25zdCBtb2R1bGVMaXN0ID0ge307XG4gICAgbGV0IG5ld0xpc3QgPSB7fTtcblxuICAgIGlmIChlbGVtZW50cyAmJiBlbGVtZW50cy5sZW5ndGgpIHtcbiAgICAgIGVsZW1lbnRzLmZvckVhY2goKGVsZW1lbnQpID0+IHtcbiAgICAgICAgY29uc3QgbW9kdWxlS2V5ID0gdGhpcy5nZXRNb2R1bGVLZXlGcm9tVGFnKGVsZW1lbnQpO1xuXG4gICAgICAgIGlmIChtb2R1bGVLZXkpIHtcbiAgICAgICAgICBpZiAoIW1vZHVsZUxpc3RbbW9kdWxlS2V5XSkge1xuICAgICAgICAgICAgbW9kdWxlTGlzdFttb2R1bGVLZXldID0gW107XG4gICAgICAgICAgfVxuICAgICAgICAgIG1vZHVsZUxpc3RbbW9kdWxlS2V5XS5wdXNoKGVsZW1lbnQpO1xuICAgICAgICB9IGVsc2UgaWYgKHJlY3Vyc2UpIHtcbiAgICAgICAgICBuZXdMaXN0ID0gdGhpcy5nZXRNb2R1bGVMaXN0RnJvbVRhZ3MoXG4gICAgICAgICAgICBbLi4uZWxlbWVudC5xdWVyeVNlbGVjdG9yQWxsKCdbZGF0YS1odXJvbi1pZF1bZGF0YS1odXJvbi10eXBlXScpXSxcbiAgICAgICAgICAgIGZhbHNlXG4gICAgICAgICAgKTtcblxuICAgICAgICAgIE9iamVjdC5rZXlzKG5ld0xpc3QpLmZvckVhY2goKGtleSkgPT4ge1xuICAgICAgICAgICAgbW9kdWxlTGlzdFtrZXldID0gbW9kdWxlTGlzdFtrZXldID9cbiAgICAgICAgICAgICAgbW9kdWxlTGlzdFtrZXldLmNvbmNhdChuZXdMaXN0W2tleV0pIDpcbiAgICAgICAgICAgICAgbmV3TGlzdFtrZXldO1xuICAgICAgICAgIH0pO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9XG5cbiAgICByZXR1cm4gbW9kdWxlTGlzdDtcbiAgfVxuXG4gIC8qKlxuICAgKiBUcmFuc2Zvcm0gZXZlcnkgbW9kdWxlIGludG8gYSBwcmVkaWN0YWJsZSBvYmplY3RcbiAgICpcbiAgICogQHBhcmFtIHtvYmplY3R9IHR5cGUgLSBNb2R1bGUgbWV0YWRhdGFcbiAgICogQHBhcmFtIHttaXhlZH0gbW9kdWxlIC0gTW9kdWxlIGNvbnRlbnRzXG4gICAqIEByZXR1cm4ge29iamVjdH0gY29udGFpbmluZyByZW5kZXIgZnVuY3Rpb24sIHJlbmRlciBkYXRhIGFuZCBtb2R1bGUgaWRcbiAgICovXG4gIGdldE1vZHVsZVJlbmRlcih0eXBlLCBrZXksIG1vZHVsZSkge1xuICAgIGxldCByZW5kZXIgPSBmYWxzZTtcbiAgICBsZXQgZGF0YSA9IGZhbHNlO1xuXG4gICAgaWYgKCd0ZW1wbGF0ZScgPT09IHR5cGUgJiYgJ2Z1bmN0aW9uJyA9PT0gdHlwZW9mIG1vZHVsZSkge1xuICAgICAgLy8gSXQncyBhIHJlbmRlciBmdW5jdGlvbiBmb3IgYSB0ZW1wbGF0ZVxuICAgICAgcmVuZGVyID0gbW9kdWxlO1xuICAgICAgZGF0YSA9IHRoaXMuX21vZHVsZXNbdGhpcy5fdGVtcGxhdGVzW2tleV1dO1xuICAgIH0gZWxzZSBpZiAoXG4gICAgICAnc2VjdGlvbnMtdGVtcGxhdGUnID09PSB0eXBlICYmXG4gICAgICAnZnVuY3Rpb24nID09PSB0eXBlb2YgbW9kdWxlXG4gICAgKSB7XG4gICAgICAvLyBJdCdzIGEga3NzIHNlY3Rpb24gdGVtcGxhdGVcbiAgICAgIHJlbmRlciA9IG1vZHVsZTtcbiAgICB9IGVsc2UgaWYgKFxuICAgICAgJ3NlY3Rpb24nID09PSB0eXBlICYmXG4gICAgICAnb2JqZWN0JyA9PT0gdHlwZW9mIG1vZHVsZVxuICAgICkge1xuICAgICAgLy8gSXQncyBzZWN0aW9uIGRhdGFcbiAgICAgIHJlbmRlciA9IHRoaXMuX21vZHVsZXNbdGhpcy5fc2VjdGlvblRlbXBsYXRlUGF0aF07XG4gICAgICBkYXRhID0gbW9kdWxlO1xuICAgIH0gZWxzZSBpZiAoXG4gICAgICAoJ3RlbXBsYXRlJyA9PT0gdHlwZSB8fCAnZGVzY3JpcHRpb24nID09PSB0eXBlIHx8ICdwcm90b3R5cGUnID09PSB0eXBlKSAmJlxuICAgICAgJ3N0cmluZycgPT09IHR5cGVvZiBtb2R1bGVcbiAgICApIHtcbiAgICAgIC8vIGl0J3Mgc3RyYWlnaHQgSFRNTFxuICAgICAgcmVuZGVyID0gKCkgPT4gbW9kdWxlO1xuICAgIH0gZWxzZSBpZiAoJ2RhdGEnID09PSB0eXBlICYmICdvYmplY3QnID09PSB0eXBlb2YgbW9kdWxlKSB7XG4gICAgICAvLyBJdCdzIGEgZGF0YSBmaWxlICguanNvbilcbiAgICAgIHJlbmRlciA9IHRoaXMuX21vZHVsZXNbdGhpcy5fdGVtcGxhdGVzW2tleV1dO1xuICAgICAgZGF0YSA9IG1vZHVsZTtcbiAgICB9XG5cbiAgICAvLyBPbmx5IG5lZWQgcmVuZGVyLCBhcyBkYXRhIHdpbGwgYmUgbGVmdCBlbXB0eSBmb3Igc3RhdGljIEhUTUxcbiAgICBpZiAocmVuZGVyKSB7XG4gICAgICByZXR1cm4geyByZW5kZXIsIGRhdGEgfTtcbiAgICB9XG5cbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICAvKipcbiAgICogUmVwbGFjZSBhbGwgc2VjdGlvbnMuIEZvciBob3QgcmVsb2FkaW5nIHVzZSB3aGVuIHRoZSBzZWN0aW9uIHRlbXBsYXRlIGhhcyBjaGFuZ2VkLlxuICAgKlxuICAgKiBAcGFyYW0ge29iamVjdH0gcmVwbGFjZUVsZW1lbnRzIC0gVGhlIGNvbnRleHQgKGUuZy4gZG9jdW1lbnQpIHRoYXQgeW91IHdpbGwgcXVlcnkgZm9yIHRoZSB0ZW1wbGF0ZSBJRCB0byByZXBsYWNlXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBrZXkgLSBNb2R1bGUgcmVxdWlyZSBwYXRoXG4gICAqIEBwYXJhbSB7bWl4ZWR9IG1vZHVsZSAtIE1vZHVsZSBjb250ZW50c1xuICAgKiBAcGFyYW0ge2Jvb2x9IGNhY2hlZCAtIFdoZXRoZXIgb3Igbm90IHRvIHVzZSBjYWNoZWQgdmFsdWVzIGZvciBtb2R1bGUgcmVwbGFjZW1lbnRcbiAgICogQHBhcmFtIHtvYmplY3R9IGZpbHRlciAtIEZpbHRlciBmb3IgbW9kdWxlcy4gRmllbGRzIGV4cGxhaW5lZCBpbiB0aGUgZmlsdGVyTW9kdWxlcygpIGZ1bmN0aW9uIGRvY3NcbiAgICovXG4gIGxvYWRNb2R1bGUoa2V5LCBtb2R1bGUsIHJlcGxhY2VFbGVtZW50cywgY2FjaGVkID0gZmFsc2UsIGZpbHRlciA9IGZhbHNlKSB7XG4gICAgbGV0IHNob3VsZExvYWQgPSB0cnVlO1xuICAgIGxldCBtb2R1bGVNZXRhID0gZmFsc2U7XG5cbiAgICAvLyBDaGVjayBpZiB3ZSBzaG91bGQgbG9hZCBmcm9tIGludGVybmFsIG1vZHVsZSBtZXRhZGF0YSBjYWNoZVxuICAgIGlmIChjYWNoZWQpIHtcbiAgICAgIG1vZHVsZU1ldGEgPSB0aGlzLm1ldGFba2V5XTtcbiAgICB9IGVsc2Uge1xuICAgICAgbW9kdWxlTWV0YSA9IHRoaXMubWV0YVtrZXldID0gdGhpcy5nZXRNZXRhRnJvbVBhdGgoa2V5LCBtb2R1bGUpO1xuICAgIH1cblxuICAgIGlmIChtb2R1bGVNZXRhKSB7XG4gICAgICBpZiAoZmlsdGVyKSB7XG4gICAgICAgIHNob3VsZExvYWQgPSBJbnNlcnROb2Rlcy5maWx0ZXJNb2R1bGVzKGZpbHRlciwgbW9kdWxlTWV0YSk7XG4gICAgICB9XG5cbiAgICAgIGlmIChzaG91bGRMb2FkKSB7XG4gICAgICAgIHRoaXMucmVwbGFjZVRlbXBsYXRlKG1vZHVsZU1ldGEsIHJlcGxhY2VFbGVtZW50cyk7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgLypcbiAgICogSGVscGVyIGZ1bmN0aW9uIGZvciBpbnNlcnRpbmcgc3R5bGVndWlkZSBzZWN0aW9ucy5cbiAgICpcbiAgICogUmVjdXJzZXMgb3ZlciBzb3J0ZWQgc3R5bGVndWlkZSBzZWN0aW9ucyBhbmQgaW5zZXJ0cyBhIDx1bD4gdG8gYmUgdXNlZCBhcyBhIG1lbnUgZm9yIGVhY2ggc2VjdGlvblxuICAgKi9cbiAgb3V0cHV0TWVudShwYXJlbnQsIGVsLCBzZWN0aW9ucyA9IHRoaXMuX3NlY3Rpb25zLnNvcnRlZCkge1xuICAgIGxldCB0ZW1wbGF0ZUlkID0gbnVsbDtcbiAgICBsZXQgbmV3RWwgPSBlbDtcblxuICAgIE9iamVjdC5rZXlzKHNlY3Rpb25zKS5mb3JFYWNoKChzZWN0aW9uKSA9PiB7XG4gICAgICBjb25zdCBoYXNTdWJtZW51ID0gT2JqZWN0LmtleXMoc2VjdGlvbnNbc2VjdGlvbl0pLmxlbmd0aDtcbiAgICAgIGxldCBtZW51VGFyZ2V0O1xuICAgICAgbGV0IG5leHRNZW51O1xuXG4gICAgICBpZiAocGFyZW50KSB7XG4gICAgICAgIHRlbXBsYXRlSWQgPSBgJHtwYXJlbnR9LSR7c2VjdGlvbn1gO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgdGVtcGxhdGVJZCA9IHNlY3Rpb247XG4gICAgICB9XG5cbiAgICAgIGlmIChuZXdFbCkge1xuICAgICAgICBjb25zdCB0aXRsZSA9IHRoaXMuX3NlY3Rpb25zXG4gICAgICAgICAgICAuc2VjdGlvbnNCeVVSSVt0ZW1wbGF0ZUlkXSA/XG4gICAgICAgICAgdGhpcy5fc2VjdGlvbnNcbiAgICAgICAgICAgIC5zZWN0aW9uc0J5VVJJW3RlbXBsYXRlSWRdXG4gICAgICAgICAgICAuaGVhZGVyIDpcbiAgICAgICAgICB0ZW1wbGF0ZUlkO1xuICAgICAgICBjb25zdCBzZWN0aW9uTWVudSA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ3VsJyk7XG4gICAgICAgIGNvbnN0IG1lbnVJdGVtID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnbGknKTtcbiAgICAgICAgY29uc3QgbGluayA9IGA8YSBocmVmPVwiI3N0eWxlZ3VpZGUtc2VjdGlvbi0ke3RlbXBsYXRlSWR9XCI+JHt0aXRsZX08L2E+YDtcblxuICAgICAgICBzZWN0aW9uTWVudS5jbGFzc0xpc3QuYWRkKCdzZWN0aW9uLW1lbnUnKTtcbiAgICAgICAgbWVudUl0ZW0uY2xhc3NMaXN0LmFkZCgnc2VjdGlvbi1tZW51X19pdGVtJyk7XG4gICAgICAgIG1lbnVJdGVtLmlubmVySFRNTCA9IGxpbms7XG5cbiAgICAgICAgLy8gQ2hlY2sgaWYgdGhpcyBpcyBhIFVMIGFuZCwgaWYgbm90LCBjcmVhdGUgb25lXG4gICAgICAgIGlmICgnVUwnICE9PSBuZXdFbC50YWdOYW1lKSB7XG4gICAgICAgICAgbWVudVRhcmdldCA9IHNlY3Rpb25NZW51LmNsb25lTm9kZSgpO1xuICAgICAgICAgIG5ld0VsLmFwcGVuZENoaWxkKG1lbnVUYXJnZXQpO1xuICAgICAgICAgIG5ld0VsID0gbWVudVRhcmdldDtcbiAgICAgICAgfVxuXG4gICAgICAgIC8vIEhhcyBzdWJzZWN0aW9uc1xuICAgICAgICBpZiAoaGFzU3VibWVudSkge1xuICAgICAgICAgIG5leHRNZW51ID0gc2VjdGlvbk1lbnUuY2xvbmVOb2RlKCk7XG4gICAgICAgICAgbmV4dE1lbnUuY2xhc3NMaXN0LmFkZCgnc2VjdGlvbi1tZW51LS1zdWJtZW51Jyk7XG4gICAgICAgICAgbWVudUl0ZW0uY2xhc3NMaXN0LmFkZCgnc2VjdGlvbi1tZW51X19pdGVtLS1oYXMtc3VibWVudScpO1xuICAgICAgICAgIG1lbnVJdGVtLmFwcGVuZENoaWxkKG5leHRNZW51KTtcbiAgICAgICAgfVxuXG4gICAgICAgIG5ld0VsLmFwcGVuZENoaWxkKG1lbnVJdGVtKTtcblxuICAgICAgICBpZiAoaGFzU3VibWVudSkge1xuICAgICAgICAgIHRoaXMub3V0cHV0TWVudShcbiAgICAgICAgICAgIHRlbXBsYXRlSWQsXG4gICAgICAgICAgICBuZXh0TWVudSxcbiAgICAgICAgICAgIHNlY3Rpb25zW3NlY3Rpb25dXG4gICAgICAgICAgKTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0pO1xuICB9XG5cbiAgLyoqXG4gICAqIEhlbHBlciBmdW5jdGlvbiBmb3IgaW5zZXJ0aW5nIHN0eWxlZ3VpZGUgc2VjdGlvbnMuXG4gICAqXG4gICAqIFJlY3Vyc2VzIG92ZXIgc29ydGVkIHN0eWxlZ3VpZGUgc2VjdGlvbnMgYW5kIGluc2VydHMgYSA8c2VjdGlvbj4gdGFnIHdpdGggW2h1cm9uLWlkXSBlcXVhbCB0byB0aGUgc2VjdGlvbiB0ZW1wbGF0ZSBuYW1lLlxuICAgKi9cbiAgb3V0cHV0U2VjdGlvbnMocGFyZW50LCBlbCwgc2VjdGlvbnMgPSB0aGlzLl9zZWN0aW9ucy5zb3J0ZWQpIHtcbiAgICBsZXQgdGVtcGxhdGVJZCA9IG51bGw7XG4gICAgbGV0IHBsYWNlaG9sZGVyID0gbnVsbDtcblxuICAgIE9iamVjdC5rZXlzKHNlY3Rpb25zKS5mb3JFYWNoKChzZWN0aW9uKSA9PiB7XG4gICAgICBsZXQgaXN0b3BMZXZlbCA9IGZhbHNlO1xuICAgICAgbGV0IHRvcExldmVsV3JhcHBlciA9IG51bGw7XG4gICAgICBsZXQgdG9wTGV2ZWxTZWN0aW9uID0gbnVsbDtcbiAgICAgIGxldCBpbnNlcnRpb25FbCA9IGVsO1xuXG4gICAgICAvLyBHZW5lcmF0ZSBzZWN0aW9uIElEIGFuZCBjaGVjayBpZiBpdCBpcyB0b3AtbGV2ZWxcbiAgICAgIGlmIChwYXJlbnQpIHtcbiAgICAgICAgdGVtcGxhdGVJZCA9IGAke3BhcmVudH0tJHtzZWN0aW9ufWA7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICB0ZW1wbGF0ZUlkID0gc2VjdGlvbjtcbiAgICAgICAgaXN0b3BMZXZlbCA9IHRydWU7XG4gICAgICB9XG5cbiAgICAgIGlmIChlbCkge1xuICAgICAgICAvLyBHZW5lcmF0ZSBodXJvbiBwbGFjZWhvbGRlciBmb3IgdGhpcyBzZWN0aW9uXG4gICAgICAgIHBsYWNlaG9sZGVyID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnZGl2Jyk7XG4gICAgICAgIHBsYWNlaG9sZGVyLmRhdGFzZXQuaHVyb25JZCA9IHRlbXBsYXRlSWQ7XG4gICAgICAgIHBsYWNlaG9sZGVyLmRhdGFzZXQuaHVyb25UeXBlID0gJ3NlY3Rpb24nO1xuXG4gICAgICAgIGlmIChpc3RvcExldmVsKSB7XG4gICAgICAgICAgLy8gR2VuZXJhdGUgd3JhcHBlciB0byBjb250YWluIHRvcC1sZXZlbCBzZWN0aW9uIGFuZCBhbGwgc3Vic2VjdGlvbnMgdW5kZXJuZWF0aCBpdFxuICAgICAgICAgIHRvcExldmVsV3JhcHBlciA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ2RpdicpO1xuICAgICAgICAgIHRvcExldmVsV3JhcHBlci5jbGFzc0xpc3QuYWRkKCdzZWN0aW9uLS10b3AtbGV2ZWxfX3dyYXBwZXInKTtcblxuICAgICAgICAgIC8vIEdlbmVyYXRlIHdyYXBwZXIgZm9yIHRvcC1sZXZlbCBzZWN0aW9uXG4gICAgICAgICAgdG9wTGV2ZWxTZWN0aW9uID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnZGl2Jyk7XG4gICAgICAgICAgdG9wTGV2ZWxTZWN0aW9uLmNsYXNzTGlzdC5hZGQoJ3NlY3Rpb24nLCAnc2VjdGlvbi0tdG9wLWxldmVsJyk7XG5cbiAgICAgICAgICAvLyBBcHBlbmQgd3JhcHBlcnMgdG8gaHVyb24tc2VjdGlvbnMgZWxlbWVudFxuICAgICAgICAgIHRvcExldmVsU2VjdGlvbi5hcHBlbmRDaGlsZChwbGFjZWhvbGRlcik7XG4gICAgICAgICAgdG9wTGV2ZWxXcmFwcGVyLmFwcGVuZENoaWxkKHRvcExldmVsU2VjdGlvbik7XG4gICAgICAgICAgZWwuYXBwZW5kQ2hpbGQodG9wTGV2ZWxXcmFwcGVyKTtcbiAgICAgICAgICBpbnNlcnRpb25FbCA9IHRvcExldmVsV3JhcHBlcjtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAvLyBJZiB0aGlzIGlzIG5vdCB0b3AtbGV2ZWwsIGFwcGVuZCBwbGFjZWhvbGRlclxuICAgICAgICAgIGVsLmFwcGVuZENoaWxkKHBsYWNlaG9sZGVyKTtcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICAvLyBSZWN1cnNpdmVseSBjYWxsIHRoaXMgZnVuY3Rpb24gdG8gaW5zZXJ0IG90aGVyIHNlY3Rpb25zXG4gICAgICBpZiAoT2JqZWN0LmtleXMoc2VjdGlvbnNbc2VjdGlvbl0pLmxlbmd0aCAmJiBwbGFjZWhvbGRlcikge1xuICAgICAgICB0aGlzLm91dHB1dFNlY3Rpb25zKFxuICAgICAgICAgIHRlbXBsYXRlSWQsXG4gICAgICAgICAgaW5zZXJ0aW9uRWwsXG4gICAgICAgICAgc2VjdGlvbnNbc2VjdGlvbl1cbiAgICAgICAgKTtcbiAgICAgIH1cbiAgICB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBBcHBseSBhIG1vZGlmaWVyIGFuZCBtZXJnZSBjbGFzc25hbWVzIGludG8gdGVtcGxhdGUgZGF0YSwgaWYgaXQgZXhpc3RzXG4gICAqXG4gICAqIEBwYXJhbSB7b2JqZWN0fSBkYXRhIC0gZGF0YSB3aXRoIHdoaWNoIHRvIHJlbmRlciB0ZW1wbGF0ZVxuICAgKiBAcGFyYW0ge3N0cmluZ30gbW9kaWZpZXIgLSB0YXJnZXQgbW9kaWZpZXJcbiAgICpcbiAgICogQHJldHVybiB7c3RyaW5nfSByZW5kZXJlZCAtIHRoZSBtb2RpZmllZCBIVE1MIG1vZHVsZVxuICAgKi9cbiAgcHJvdmlkZUNsYXNzbmFtZXMoZGF0YSkge1xuICAgIGlmICh0aGlzLl9jbGFzc05hbWVzKSB7XG4gICAgICByZXR1cm4gT2JqZWN0LmFzc2lnbih7fSwgZGF0YSwgeyBjbGFzc05hbWVzOiB0aGlzLl9jbGFzc05hbWVzIH0pO1xuICAgIH1cblxuICAgIHJldHVybiBkYXRhO1xuICB9XG5cbiAgLyoqXG4gICAqIFJlZ2VuZXJhdGUgbW9kdWxlIG1ldGEgY2FjaGVcbiAgICovXG4gIHJlZ2VuQ2FjaGUoKSB7XG4gICAgT2JqZWN0LmtleXModGhpcy5fbW9kdWxlcykuZm9yRWFjaCgobW9kdWxlS2V5KSA9PiB7XG4gICAgICB0aGlzLm1ldGFbbW9kdWxlS2V5XSA9IHRoaXMuZ2V0TWV0YUZyb21QYXRoKFxuICAgICAgICBtb2R1bGVLZXksIHRoaXMuX21vZHVsZXNbbW9kdWxlS2V5XVxuICAgICAgKTtcbiAgICB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZWN1cnNpdmVseSByZW1vdmUgb2xkIHRhZ3NcbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IHJlcGxhY2VLZXkgLSBrZXkgb2YgbW9kdWxlIGZvciB3aGljaCB3ZSBuZWVkIHRvIHJlbW92ZSBvbGQgdGFnc1xuICAgKiBAcGFyYW0ge29iamVjdH0gdGFnIC0gdGFnIHRvIHN0YXJ0IG91ciBzZWFyY2ggd2l0aFxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgKHVzdWFsbHkgdGhlIHRhZyBpbW1lZGlhdGVseSBwcmVjZWRpbmcgdGhlIGN1cnJlbnQgcGxhY2Vob2xkZXIpXG4gICAqL1xuICByZW1vdmVPbGRUYWdzKHJlcGxhY2VLZXksIHRhZykge1xuICAgIGlmICh0YWcpIHtcbiAgICAgIGNvbnN0IHBhcmVudE1vZHVsZSA9IEluc2VydE5vZGVzLmdldERhdGFBdHRyaWJ1dGUodGFnLCAncGFyZW50LW1vZHVsZScpO1xuICAgICAgY29uc3Qgc2VsZk1vZHVsZSA9IEluc2VydE5vZGVzLmdldERhdGFBdHRyaWJ1dGUodGFnLCAnc2VsZi1tb2R1bGUnKTtcblxuICAgICAgaWYgKHBhcmVudE1vZHVsZSA9PT0gcmVwbGFjZUtleSAmJiBzZWxmTW9kdWxlICE9PSByZXBsYWNlS2V5KSB7XG4gICAgICAgIC8vIFRoaXMgaXMgYSBjaGlsZCBvZiB0aGUgY3VycmVudCBtb2R1bGUsXG4gICAgICAgIC8vIHNvIHJlbW92ZSBpdCBhbmQgaXRzIGNoaWxkcmVuIChpZiBhcHBsaWNhYmxlKVxuICAgICAgICBjb25zdCBjaGlsZHJlbk1vZHVsZSA9IHNlbGZNb2R1bGU7XG4gICAgICAgIGxldCBuZXh0VGFnID0gdGFnLnByZXZpb3VzU2libGluZztcblxuICAgICAgICBpZiAoY2hpbGRyZW5Nb2R1bGUpIHtcbiAgICAgICAgICB0aGlzLnJlbW92ZU9sZFRhZ3MoY2hpbGRyZW5Nb2R1bGUsIG5leHRUYWcpO1xuICAgICAgICAgIC8vIFJlc2V0IG5leHRUYWcgaWYgd2UgcmVtb3ZlZCBhIGNoaWxkXG4gICAgICAgICAgbmV4dFRhZyA9IHRhZy5wcmV2aW91c1NpYmxpbmc7XG4gICAgICAgIH1cblxuICAgICAgICB0YWcucGFyZW50Tm9kZS5yZW1vdmVDaGlsZCh0YWcpO1xuICAgICAgICB0aGlzLnJlbW92ZU9sZFRhZ3MocmVwbGFjZUtleSwgbmV4dFRhZyk7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFJlcGxhY2UgYSBzaW5nbGUgdGVtcGxhdGUgbWFya2VyIHdpdGggdGVtcGxhdGUgY29udGVudC5cbiAgICpcbiAgICogQHBhcmFtIHtvYmplY3R9IHJlcGxhY2VFbGVtZW50cyAtIEFycmF5IG9mIGVsZW1lbnRzIHRvIGNoZWNrIGZvciBIdXJvbiBwbGFjZWhvbGRlcnNcbiAgICogQHBhcmFtIHtvYmplY3R9IG1ldGEgLSBNb2R1bGUgbWV0YWRhdGFcbiAgICovXG4gIHJlcGxhY2VUZW1wbGF0ZShtZXRhLCByZXBsYWNlRWxlbWVudHMpIHtcbiAgICBjb25zdCB0eXBlID0gdGhpcy52YWxpZGF0ZVR5cGUobWV0YS50eXBlKTtcbiAgICBjb25zdCB0YWdzID0gW107XG4gICAgbGV0IHJlcGxhY2UgPSByZXBsYWNlRWxlbWVudHM7XG4gICAgbGV0IGhhc1N0eWxlZ3VpZGVIZWxwZXJzID0gZmFsc2U7XG5cbiAgICBpZiAoIXJlcGxhY2UpIHtcbiAgICAgIHJlcGxhY2UgPSBkb2N1bWVudC5xdWVyeVNlbGVjdG9yQWxsKFxuICAgICAgICAnW2RhdGEtaHVyb24taWRdW2RhdGEtaHVyb24tdHlwZV0nXG4gICAgICApO1xuICAgIH1cblxuICAgIGlmICh0eXBlKSB7XG4gICAgICByZXBsYWNlLmZvckVhY2goKHRhZykgPT4ge1xuICAgICAgICBjb25zdCB0YWdUeXBlID0gSW5zZXJ0Tm9kZXMuZ2V0RGF0YUF0dHJpYnV0ZSh0YWcsICdodXJvbi10eXBlJyk7XG4gICAgICAgIGNvbnN0IHRhZ0lkID0gSW5zZXJ0Tm9kZXMuZ2V0RGF0YUF0dHJpYnV0ZSh0YWcsICdodXJvbi1pZCcpO1xuXG4gICAgICAgIGlmICh0YWdJZCA9PT0gbWV0YS5pZCAmJiB0YWdUeXBlID09PSB0eXBlKSB7XG4gICAgICAgICAgdGFncy5wdXNoKHRhZyk7XG4gICAgICAgIH1cbiAgICAgIH0pO1xuXG4gICAgICBpZiAodGFncyAmJiB0YWdzLmxlbmd0aCAmJiBtZXRhLnJlbmRlcikge1xuICAgICAgICB0YWdzLmZvckVhY2goKGN1cnJlbnRUYWcpID0+IHtcbiAgICAgICAgICBjb25zdCBtb2RpZmllZFBsYWNlaG9sZGVyID0gY3VycmVudFRhZztcbiAgICAgICAgICBjb25zdCBtb2RpZmllciA9IEluc2VydE5vZGVzXG4gICAgICAgICAgICAuZ2V0RGF0YUF0dHJpYnV0ZShtb2RpZmllZFBsYWNlaG9sZGVyLCAnaHVyb24tbW9kaWZpZXInKTtcbiAgICAgICAgICBjb25zdCBwYXJlbnQgPSBtb2RpZmllZFBsYWNlaG9sZGVyLnBhcmVudE5vZGU7XG4gICAgICAgICAgY29uc3QgZGF0YSA9IGNvbXBvc2UoXG4gICAgICAgICAgICB0aGlzLnByb3ZpZGVDbGFzc25hbWVzLmJpbmQodGhpcyksXG4gICAgICAgICAgICBJbnNlcnROb2Rlcy5hcHBseU1vZGlmaWVyXG4gICAgICAgICAgKShtZXRhLmRhdGEsIG1vZGlmaWVyKTtcbiAgICAgICAgICBjb25zdCByZW5kZXJlZCA9IG1ldGEucmVuZGVyKGRhdGEpO1xuICAgICAgICAgIGNvbnN0IHJlbmRlcmVkVGVtcGxhdGUgPSBJbnNlcnROb2Rlcy5jb252ZXJ0VG9FbGVtZW50KHJlbmRlcmVkKVxuICAgICAgICAgICAgICAucXVlcnlTZWxlY3RvcigndGVtcGxhdGUnKTtcbiAgICAgICAgICBsZXQgcmVuZGVyZWRDb250ZW50cyA9IG51bGw7XG5cbiAgICAgICAgICAvLyBSZW1vdmUgZXhpc3RpbmcgbW9kdWxlIHRhZ3NcbiAgICAgICAgICB0aGlzLnJlbW92ZU9sZFRhZ3MoXG4gICAgICAgICAgICBtZXRhLnJlcGxhY2VLZXksXG4gICAgICAgICAgICBtb2RpZmllZFBsYWNlaG9sZGVyLnByZXZpb3VzU2libGluZ1xuICAgICAgICAgICk7XG5cbiAgICAgICAgICAvLyBHZXQgdGhlIGNvbnRlbnRzIG9mIHRoZSByZW5kZXJlZCB0ZW1wbGF0ZVxuICAgICAgICAgIHJlbmRlcmVkQ29udGVudHMgPSBbXG4gICAgICAgICAgICAuLi5yZW5kZXJlZFRlbXBsYXRlLmNvbnRlbnQuY2hpbGRyZW4sXG4gICAgICAgICAgXTtcblxuICAgICAgICAgIC8vIEluc2VydCBlYWNoIHRhZyBvZiB0aGUgdGVtcGxhdGUgY29udGVudHMgYmVmb3JlIHBsYWNlaG9sZGVyXG4gICAgICAgICAgcmVuZGVyZWRDb250ZW50cy5mb3JFYWNoKChlbGVtZW50KSA9PiB7XG4gICAgICAgICAgICBjb25zdCBuZXdFbCA9IGVsZW1lbnQ7XG5cbiAgICAgICAgICAgIGlmICgxID09PSBuZXdFbC5ub2RlVHlwZSkge1xuICAgICAgICAgICAgICBuZXdFbC5kYXRhc2V0LnBhcmVudE1vZHVsZSA9IG1ldGEucmVwbGFjZUtleTtcbiAgICAgICAgICAgICAgaGFzU3R5bGVndWlkZUhlbHBlcnMgPSAhaGFzU3R5bGVndWlkZUhlbHBlcnMgP1xuICAgICAgICAgICAgICAgIEluc2VydE5vZGVzLmlzU2VjdGlvbkhlbHBlcihuZXdFbCwgbWV0YSkgOlxuICAgICAgICAgICAgICAgIGhhc1N0eWxlZ3VpZGVIZWxwZXJzO1xuXG4gICAgICAgICAgICAgIHBhcmVudC5pbnNlcnRCZWZvcmUobmV3RWwsIG1vZGlmaWVkUGxhY2Vob2xkZXIpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH0pO1xuXG4gICAgICAgICAgLy8gQWRkIG1vZHVsZSByZXBsYWNlbWVudCBrZXkgdG8gdGhpcyBwbGFjZWhvbGRlclxuICAgICAgICAgIG1vZGlmaWVkUGxhY2Vob2xkZXIuZGF0YXNldC5zZWxmTW9kdWxlID0gbWV0YS5yZXBsYWNlS2V5O1xuXG4gICAgICAgICAgLy8gSGlkZSB0aGUgcGxhY2Vob2xkZXJcbiAgICAgICAgICBtb2RpZmllZFBsYWNlaG9sZGVyLnN0eWxlLmRpc3BsYXkgPSAnbm9uZSc7XG5cbiAgICAgICAgICAvLyBSZWN1cnNpdmVseSBsb2FkIG1vZHVsZXMsIGV4Y2x1ZGluZyB0aGUgY3VycmVudCBvbmVcbiAgICAgICAgICB0aGlzLmN5Y2xlTW9kdWxlcyhyZW5kZXJlZENvbnRlbnRzLCB7XG4gICAgICAgICAgICBwcm9wZXJ0eTogJ2tleScsXG4gICAgICAgICAgICB2YWx1ZXM6IFttZXRhLmtleSwgdGhpcy5fc2VjdGlvblRlbXBsYXRlUGF0aF0sXG4gICAgICAgICAgICBpbmNsdWRlOiBmYWxzZSxcbiAgICAgICAgICB9KTtcblxuICAgICAgICAgIGlmIChoYXNTdHlsZWd1aWRlSGVscGVycykge1xuICAgICAgICAgICAgdGhpcy5jeWNsZVN0eWxlZ3VpZGUoKTtcbiAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICBjb25zb2xlLndhcm4oIC8vIGVzbGludC1kaXNhYmxlLWxpbmUgbm8tY29uc29sZVxuICAgICAgICBgQ291bGQgbm90IHJlbmRlciBtb2R1bGVcbiAgICAgICAgc2VjdGlvbjogJHttZXRhLmlkfVxuICAgICAgICB0eXBlOiAke21ldGEudHlwZX1gXG4gICAgICApO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBWZXJpZnkgc3BlY2lmaWVkIGVsZW1lbnQgaXMgdXNpbmcgYW4gYWNjZXB0YWJsZSBodXJvbiB0eXBlXG4gICAqXG4gICAqIEBwYXJhbSAge3N0cmluZ30gdHlwZSAtIHR5cGUgb2YgcGFydGlhbCAodGVtcGxhdGUsIGRhdGEsIGRlc2NyaXB0aW9uLCBzZWN0aW9uIG9yIHByb3RvdHlwZSApXG4gICAqIEByZXR1cm4ge3N0cmluZ30gdHlwZSAtIGh1cm9uIHR5cGUgb3IgJ3RlbXBsYXRlJyBpZiBpbnZhbGlkXG4gICAqL1xuICB2YWxpZGF0ZVR5cGUodHlwZSkge1xuICAgIGlmICgnZGF0YScgPT09IHR5cGUpIHtcbiAgICAgIHJldHVybiAndGVtcGxhdGUnO1xuICAgIH1cblxuICAgIGlmICghdGhpcy5fdHlwZXMuaW5jbHVkZXModHlwZSkpIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG5cbiAgICByZXR1cm4gdHlwZTtcbiAgfVxuXG4gIC8qXG4gICAqIFNldCBuZXcgbW9kdWxlcyBvYmplY3RcbiAgICovXG4gIHNldCBtb2R1bGVzKG1vZHVsZXMpIHtcbiAgICB0aGlzLl9tb2R1bGVzID0gbW9kdWxlcztcbiAgICB0aGlzLl9tb2R1bGVJZHMgPSBPYmplY3Qua2V5cyhtb2R1bGVzKTtcbiAgfVxuXG4gIC8qXG4gICAqIFNldCBzdG9yZVxuICAgKi9cbiAgc2V0IHN0b3JlKHN0b3JlKSB7XG4gICAgdGhpcy5fc3RvcmUgPSBzdG9yZTtcbiAgICB0aGlzLl9jb25maWcgPSBzdG9yZS5jb25maWc7XG4gICAgdGhpcy5fc2VjdGlvbnMgPSBzdG9yZS5zZWN0aW9ucztcbiAgICB0aGlzLl90ZW1wbGF0ZXMgPSBzdG9yZS50ZW1wbGF0ZXM7XG4gICAgdGhpcy5fcHJvdG90eXBlcyA9IHN0b3JlLnByb3RvdHlwZXM7XG4gICAgdGhpcy5fdHlwZXMgPSBzdG9yZS50eXBlcztcbiAgICB0aGlzLl9zZWN0aW9uVGVtcGxhdGVQYXRoID0gc3RvcmUuc2VjdGlvblRlbXBsYXRlUGF0aDtcblxuICAgIC8vIENvbXBsZXRlbHkgcmVyZW5kZXIgcHJvdG90eXBlIGlmIGFueSBDU1MgbW9kdWxlcyBjbGFzc25hbWVzIGNoYW5nZVxuICAgIGlmICghaXNFcXVhbCh0aGlzLl9jbGFzc05hbWVzLCBzdG9yZS5jbGFzc05hbWVzKSkge1xuICAgICAgY29uc3QgaXNJbml0aWFsUmVuZGVyID0gIXRoaXMuX2NsYXNzTmFtZXM7XG4gICAgICB0aGlzLl9jbGFzc05hbWVzID0gc3RvcmUuY2xhc3NOYW1lcztcblxuICAgICAgLy8gT25seSByZXJlbmRlciBhZnRlciBpbml0aWFsIHJlbmRlciAod2hlbiBjbGFzc25hbWVzIGlzIG5vdCBmYWxzeSlcbiAgICAgIGlmICghaXNJbml0aWFsUmVuZGVyKSB7XG4gICAgICAgIHRoaXMuY3ljbGVNb2R1bGVzKCk7XG4gICAgICB9XG4gICAgfVxuICB9XG59XG4vKiBlc2xpbnQtZW5hYmxlICovXG5cblxuXG4vLyBXRUJQQUNLIEZPT1RFUiAvL1xuLy8gc3JjL3dlYi9pbmRleC5qcyJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7OztBQUFBO0FBQ0E7Ozs7O0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7Ozs7OztBQUtBO0FBRUE7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7Ozs7Ozs7Ozs7QUF1R0E7Ozs7OztBQU1BO0FBQUE7QUFDQTtBQURBO0FBQUE7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7Ozs7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFIQTtBQUtBO0FBQ0E7QUFDQTs7Ozs7O0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFJQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7Ozs7Ozs7OztBQU1BO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7Ozs7O0FBTUE7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFNQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUlBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7Ozs7O0FBT0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7Ozs7Ozs7Ozs7QUFPQTtBQUFBO0FBQ0E7QUFEQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBSUE7QUFDQTtBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7Ozs7OztBQU9BO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUlBO0FBQ0E7QUFDQTtBQUlBO0FBQ0E7QUFDQTtBQUNBO0FBSUE7QUFDQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7Ozs7Ozs7Ozs7OztBQVNBO0FBQUE7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7Ozs7Ozs7O0FBS0E7QUFBQTtBQUNBO0FBREE7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBTUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBS0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7OztBQUtBO0FBQUE7QUFDQTtBQURBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUtBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7Ozs7Ozs7Ozs7O0FBUUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7QUFHQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7Ozs7Ozs7Ozs7QUFPQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7Ozs7Ozs7OztBQU1BO0FBQUE7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBSUE7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFJQTtBQUNBO0FBQ0E7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBSEE7QUFDQTtBQUtBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFLQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7Ozs7O0FBTUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7Ozs7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7O0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7O0FBeHRCQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7Ozs7O0FBTUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7Ozs7Ozs7Ozs7OztBQVVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFNQTtBQUNBO0FBQUE7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBSUE7QUFDQTtBQUNBO0FBQ0E7Ozs7Ozs7Ozs7QUFPQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7Ozs7O0FBT0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7Ozs7O0FBNm5CQTtBQUNBO0FBQ0E7QUFud0JBIiwic291cmNlUm9vdCI6IiJ9"); + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; + +var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); + +var _fp = __webpack_require__("./node_modules/lodash/fp.js"); + +function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } } + +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + +/* eslint-disable no-underscore-dangle */ +// Accept the huron.js module for Huron development +if (false) { + module.hot.accept(); +} + +/** Class for inserting HTML snippets at particular insertion points. + * Uses require() to grab html partials, then inserts that html + * into an element with attribute [huron-id] corresponding to the reference URI of the target KSS section, + * and [huron-type] corresponding with the required KSS field + */ + +var InsertNodes = function () { + function InsertNodes(modules, store) { + _classCallCheck(this, InsertNodes); + + /** webpack module list in which keys are relative require paths and values are the module contents */ + this._modules = modules; + /** array of module keys */ + this._moduleIds = Object.keys(modules); + /** reference to the huron config */ + this._config = null; + /** KSS sections organized in various formats including by reference URI, by module key, and modules sorted by parent/child */ + this._sections = null; + /** Key/value pairs of partner data and template files */ + this._templates = null; + /** array of prototypes */ + this._prototypes = null; + /** array of valid huron placeholder types */ + this._types = null; + /** array of CSS modules classnames */ + this._classNames = null; + + /** Cache for module metadata */ + this.meta = {}; + + /** Reference to entire memory store */ + this.store = store; + + // Inits + this.cycleModules(); + this.cycleStyleguide(); + } + + /** + * Apply a modifier if one exists + * + * @param {object} data - data with which to render template + * @param {string} modifier - target modifier + * + * @return {string} data - subset of data object for supplied modifier + */ + + + _createClass(InsertNodes, [{ + key: 'cycleModules', + + + /** + * Replace all template markers with the actual template markup. + * + * @param {string} context - The within which to replace markup + * @param {object} filter - Filter for modules. Fields explained in the filterModules() function docs + */ + value: function cycleModules() { + var _this = this; + + var context = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; + var filter = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; + + var moduleList = {}; + var elementList = context; + + // We're replacing top-level elements + if (!elementList) { + this.regenCache(); + + // Find all top-level huron placeholders + elementList = [].concat(_toConsumableArray(document.querySelectorAll('[data-huron-id][data-huron-type]'))); + } + + moduleList = this.getModuleListFromTags(elementList); + + // Loop through modules array + Object.keys(moduleList).forEach(function (key) { + var module = _this._modules[key]; + var replaceElements = moduleList[key]; + + _this.loadModule(key, module, replaceElements, true, filter); + }); + } + + /** + * Helper for reloading sections only + */ + + }, { + key: 'cycleSections', + value: function cycleSections() { + this.cycleModules(false, { + property: 'type', + values: ['section'], + include: true + }); + } + + /** + * Reload styleguide sections and menu helpers + */ + + }, { + key: 'cycleStyleguide', + value: function cycleStyleguide() { + var sectionsQuery = document.querySelector('[huron-sections]'); + var menuQuery = document.querySelector('[huron-menu]'); + + // Sections + if (sectionsQuery) { + sectionsQuery.innerHTML = ''; + this.outputSections(null, sectionsQuery); + this.cycleSections(); + } + + // Menu + if (menuQuery) { + menuQuery.innerHTML = ''; + + if (null === document.querySelector('.section-menu__expand')) { + var menuTrigger = document.createElement('button'); + + menuTrigger.classList.add('section-menu__expand'); + menuTrigger.innerHTML = 'Sections Menu'; + document.body.insertBefore(menuQuery.appendChild(menuTrigger), document.body.childNodes[0]); + + // Add menu trigger handler + menuTrigger.addEventListener('click', function () { + document.body.classList.toggle('section-menu-open'); + }); + } + + // Create menu + this.outputMenu(null, menuQuery); + } + } + + /** + * Generate a unique key for targeting markup replacement + * + * @param {string} key - module key (webpack require path) to convert into a replacement key + * @return {string} key - generated replacement key + */ + + }, { + key: 'generateModuleReplaceKey', + value: function generateModuleReplaceKey(key) { + var currentKey = key; + + // If this is section data, use the section template path + if (key.includes('-section.json')) { + currentKey = this._sectionTemplatePath; + // If updated module is a json file, use template key instead + } else if (key.includes('.json')) { + currentKey = this._templates[key]; + } + + return '_' + currentKey.replace(/[/.]/g, '_'); + } + + /** + * Get module metadata from a module require path + * + * @param {string} key - Module require path + * @return {object} containing module id, module type, key and the module contents + */ + + }, { + key: 'getMetaFromPath', + value: function getMetaFromPath(key, module) { + var _this2 = this; + + var sections = this._sections.sectionsByPath; + var templateTypes = this._types.filter(function (type) { + return 'prototype' !== type; + }); + var id = false; + var type = false; + + /* eslint-disable space-unary-ops */ + if (-1 !== key.indexOf('./prototypes')) { + /* eslint-enable space-unary-ops */ + var prototype = Object.keys(this._prototypes).filter(function (name) { + return _this2._prototypes[name] === key; + }); + + if (prototype.length) { + id = prototype[0]; + type = 'prototype'; + } + } else if (key === this._sectionTemplatePath) { + id = 'sections-template'; + type = 'sections-template'; + } else { + var testTypes = []; + var testSections = Object.keys(sections).filter(function (section) { + var tempTypes = templateTypes.filter(function (currentType) { + return sections[section][currentType + 'Path'] === key; + }); + + if (tempTypes.length) { + testTypes = tempTypes; + return true; + } + + return false; + }); + + if (testSections && testSections.length && testTypes && testTypes.length) { + id = sections[testSections[0]].referenceURI; + type = testTypes[0]; + } + } + + if (id && type) { + var renderData = this.getModuleRender(type, key, module); + var replaceKey = this.generateModuleReplaceKey(key); + + if (renderData) { + return Object.assign({ id: id, type: type, key: key, replaceKey: replaceKey, module: module }, renderData); + } + } + + console.warn( // eslint-disable-line no-console + 'Module \'' + key + '\' does not exist on the page\n or is no longer in use'); + return false; + } + + /** + * Check if a tag is a huron placeholder and, if so, + * return its associated module key + * + * @param {object} tag - tag to check + * @return {bool} associated module key + */ + + }, { + key: 'getModuleKeyFromTag', + value: function getModuleKeyFromTag(tag) { + // Safari/webkit has some trouble parsing dataset in certain cases. + // This is a fallback method of accessing the same data. + var type = InsertNodes.getDataAttribute(tag, 'huron-type'); + var id = InsertNodes.getDataAttribute(tag, 'huron-id'); + var section = this._sections.sectionsByURI[id]; + + if (id && type) { + if (section) { + return section[type + 'Path']; + } else if ('prototype' === type) { + return this._prototypes[id]; + } + } + + return false; + } + + /** + * Check if an array of elements contains a Huron placeholder + * + * @param {array} tags - array of DOM nodes + * @param {bool} recurse - should we recurse this function with a new array + * @return {object} moduleList - Huron placeholder DOM node + */ + + }, { + key: 'getModuleListFromTags', + value: function getModuleListFromTags(elements) { + var _this3 = this; + + var recurse = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; + + var moduleList = {}; + var newList = {}; + + if (elements && elements.length) { + elements.forEach(function (element) { + var moduleKey = _this3.getModuleKeyFromTag(element); + + if (moduleKey) { + if (!moduleList[moduleKey]) { + moduleList[moduleKey] = []; + } + moduleList[moduleKey].push(element); + } else if (recurse) { + newList = _this3.getModuleListFromTags([].concat(_toConsumableArray(element.querySelectorAll('[data-huron-id][data-huron-type]'))), false); + + Object.keys(newList).forEach(function (key) { + moduleList[key] = moduleList[key] ? moduleList[key].concat(newList[key]) : newList[key]; + }); + } + }); + } + + return moduleList; + } + + /** + * Transform every module into a predictable object + * + * @param {object} type - Module metadata + * @param {mixed} module - Module contents + * @return {object} containing render function, render data and module id + */ + + }, { + key: 'getModuleRender', + value: function getModuleRender(type, key, module) { + var render = false; + var data = false; + + if ('template' === type && 'function' === typeof module) { + // It's a render function for a template + render = module; + data = this._modules[this._templates[key]]; + } else if ('sections-template' === type && 'function' === typeof module) { + // It's a kss section template + render = module; + } else if ('section' === type && 'object' === (typeof module === 'undefined' ? 'undefined' : _typeof(module))) { + // It's section data + render = this._modules[this._sectionTemplatePath]; + data = module; + } else if (('template' === type || 'description' === type || 'prototype' === type) && 'string' === typeof module) { + // it's straight HTML + render = function render() { + return module; + }; + } else if ('data' === type && 'object' === (typeof module === 'undefined' ? 'undefined' : _typeof(module))) { + // It's a data file (.json) + render = this._modules[this._templates[key]]; + data = module; + } + + // Only need render, as data will be left empty for static HTML + if (render) { + return { render: render, data: data }; + } + + return false; + } + + /** + * Replace all sections. For hot reloading use when the section template has changed. + * + * @param {object} replaceElements - The context (e.g. document) that you will query for the template ID to replace + * @param {string} key - Module require path + * @param {mixed} module - Module contents + * @param {bool} cached - Whether or not to use cached values for module replacement + * @param {object} filter - Filter for modules. Fields explained in the filterModules() function docs + */ + + }, { + key: 'loadModule', + value: function loadModule(key, module, replaceElements) { + var cached = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false; + var filter = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false; + + var shouldLoad = true; + var moduleMeta = false; + + // Check if we should load from internal module metadata cache + if (cached) { + moduleMeta = this.meta[key]; + } else { + moduleMeta = this.meta[key] = this.getMetaFromPath(key, module); + } + + if (moduleMeta) { + if (filter) { + shouldLoad = InsertNodes.filterModules(filter, moduleMeta); + } + + if (shouldLoad) { + this.replaceTemplate(moduleMeta, replaceElements); + } + } + } + + /* + * Helper function for inserting styleguide sections. + * + * Recurses over sorted styleguide sections and inserts a
      to be used as a menu for each section + */ + + }, { + key: 'outputMenu', + value: function outputMenu(parent, el) { + var _this4 = this; + + var sections = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : this._sections.sorted; + + var templateId = null; + var newEl = el; + + Object.keys(sections).forEach(function (section) { + var hasSubmenu = Object.keys(sections[section]).length; + var menuTarget = void 0; + var nextMenu = void 0; + + if (parent) { + templateId = parent + '-' + section; + } else { + templateId = section; + } + + if (newEl) { + var title = _this4._sections.sectionsByURI[templateId] ? _this4._sections.sectionsByURI[templateId].header : templateId; + var sectionMenu = document.createElement('ul'); + var menuItem = document.createElement('li'); + var link = '' + title + ''; + + sectionMenu.classList.add('section-menu'); + menuItem.classList.add('section-menu__item'); + menuItem.innerHTML = link; + + // Check if this is a UL and, if not, create one + if ('UL' !== newEl.tagName) { + menuTarget = sectionMenu.cloneNode(); + newEl.appendChild(menuTarget); + newEl = menuTarget; + } + + // Has subsections + if (hasSubmenu) { + nextMenu = sectionMenu.cloneNode(); + nextMenu.classList.add('section-menu--submenu'); + menuItem.classList.add('section-menu__item--has-submenu'); + menuItem.appendChild(nextMenu); + } + + newEl.appendChild(menuItem); + + if (hasSubmenu) { + _this4.outputMenu(templateId, nextMenu, sections[section]); + } + } + }); + } + + /** + * Helper function for inserting styleguide sections. + * + * Recurses over sorted styleguide sections and inserts a
      tag with [huron-id] equal to the section template name. + */ + + }, { + key: 'outputSections', + value: function outputSections(parent, el) { + var _this5 = this; + + var sections = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : this._sections.sorted; + + var templateId = null; + var placeholder = null; + + Object.keys(sections).forEach(function (section) { + var istopLevel = false; + var topLevelWrapper = null; + var topLevelSection = null; + var insertionEl = el; + + // Generate section ID and check if it is top-level + if (parent) { + templateId = parent + '-' + section; + } else { + templateId = section; + istopLevel = true; + } + + if (el) { + // Generate huron placeholder for this section + placeholder = document.createElement('div'); + placeholder.dataset.huronId = templateId; + placeholder.dataset.huronType = 'section'; + + if (istopLevel) { + // Generate wrapper to contain top-level section and all subsections underneath it + topLevelWrapper = document.createElement('div'); + topLevelWrapper.classList.add('section--top-level__wrapper'); + + // Generate wrapper for top-level section + topLevelSection = document.createElement('div'); + topLevelSection.classList.add('section', 'section--top-level'); + + // Append wrappers to huron-sections element + topLevelSection.appendChild(placeholder); + topLevelWrapper.appendChild(topLevelSection); + el.appendChild(topLevelWrapper); + insertionEl = topLevelWrapper; + } else { + // If this is not top-level, append placeholder + el.appendChild(placeholder); + } + } + + // Recursively call this function to insert other sections + if (Object.keys(sections[section]).length && placeholder) { + _this5.outputSections(templateId, insertionEl, sections[section]); + } + }); + } + + /** + * Apply a modifier and merge classnames into template data, if it exists + * + * @param {object} data - data with which to render template + * @param {string} modifier - target modifier + * + * @return {string} rendered - the modified HTML module + */ + + }, { + key: 'provideClassnames', + value: function provideClassnames(data) { + if (this._classNames) { + return Object.assign({}, data, { classNames: this._classNames }); + } + + return data; + } + + /** + * Regenerate module meta cache + */ + + }, { + key: 'regenCache', + value: function regenCache() { + var _this6 = this; + + Object.keys(this._modules).forEach(function (moduleKey) { + _this6.meta[moduleKey] = _this6.getMetaFromPath(moduleKey, _this6._modules[moduleKey]); + }); + } + + /** + * Recursively remove old tags + * + * @param {string} replaceKey - key of module for which we need to remove old tags + * @param {object} tag - tag to start our search with + * (usually the tag immediately preceding the current placeholder) + */ + + }, { + key: 'removeOldTags', + value: function removeOldTags(replaceKey, tag) { + if (tag) { + var parentModule = InsertNodes.getDataAttribute(tag, 'parent-module'); + var selfModule = InsertNodes.getDataAttribute(tag, 'self-module'); + + if (parentModule === replaceKey && selfModule !== replaceKey) { + // This is a child of the current module, + // so remove it and its children (if applicable) + var childrenModule = selfModule; + var nextTag = tag.previousSibling; + + if (childrenModule) { + this.removeOldTags(childrenModule, nextTag); + // Reset nextTag if we removed a child + nextTag = tag.previousSibling; + } + + tag.parentNode.removeChild(tag); + this.removeOldTags(replaceKey, nextTag); + } + } + } + + /** + * Replace a single template marker with template content. + * + * @param {object} replaceElements - Array of elements to check for Huron placeholders + * @param {object} meta - Module metadata + */ + + }, { + key: 'replaceTemplate', + value: function replaceTemplate(meta, replaceElements) { + var _this7 = this; + + var type = this.validateType(meta.type); + var tags = []; + var replace = replaceElements; + var hasStyleguideHelpers = false; + + if (!replace) { + replace = document.querySelectorAll('[data-huron-id][data-huron-type]'); + } + + if (type) { + replace.forEach(function (tag) { + var tagType = InsertNodes.getDataAttribute(tag, 'huron-type'); + var tagId = InsertNodes.getDataAttribute(tag, 'huron-id'); + + if (tagId === meta.id && tagType === type) { + tags.push(tag); + } + }); + + if (tags && tags.length && meta.render) { + tags.forEach(function (currentTag) { + var modifiedPlaceholder = currentTag; + var modifier = InsertNodes.getDataAttribute(modifiedPlaceholder, 'huron-modifier'); + var parent = modifiedPlaceholder.parentNode; + var data = (0, _fp.compose)(_this7.provideClassnames.bind(_this7), InsertNodes.applyModifier)(meta.data, modifier); + var rendered = meta.render(data); + var renderedTemplate = InsertNodes.convertToElement(rendered).querySelector('template'); + var renderedContents = null; + + // Remove existing module tags + _this7.removeOldTags(meta.replaceKey, modifiedPlaceholder.previousSibling); + + // Get the contents of the rendered template + renderedContents = [].concat(_toConsumableArray(renderedTemplate.content.children)); + + // Insert each tag of the template contents before placeholder + renderedContents.forEach(function (element) { + var newEl = element; + + if (1 === newEl.nodeType) { + newEl.dataset.parentModule = meta.replaceKey; + hasStyleguideHelpers = !hasStyleguideHelpers ? InsertNodes.isSectionHelper(newEl, meta) : hasStyleguideHelpers; + + parent.insertBefore(newEl, modifiedPlaceholder); + } + }); + + // Add module replacement key to this placeholder + modifiedPlaceholder.dataset.selfModule = meta.replaceKey; + + // Hide the placeholder + modifiedPlaceholder.style.display = 'none'; + + // Recursively load modules, excluding the current one + _this7.cycleModules(renderedContents, { + property: 'key', + values: [meta.key, _this7._sectionTemplatePath], + include: false + }); + + if (hasStyleguideHelpers) { + _this7.cycleStyleguide(); + } + }); + } + } else { + console.warn( // eslint-disable-line no-console + 'Could not render module\n section: ' + meta.id + '\n type: ' + meta.type); + } + } + + /** + * Verify specified element is using an acceptable huron type + * + * @param {string} type - type of partial (template, data, description, section or prototype ) + * @return {string} type - huron type or 'template' if invalid + */ + + }, { + key: 'validateType', + value: function validateType(type) { + if ('data' === type) { + return 'template'; + } + + if (!this._types.includes(type)) { + return false; + } + + return type; + } + + /* + * Set new modules object + */ + + }, { + key: 'modules', + set: function set(modules) { + this._modules = modules; + this._moduleIds = Object.keys(modules); + } + + /* + * Set store + */ + + }, { + key: 'store', + set: function set(store) { + this._store = store; + this._config = store.config; + this._sections = store.sections; + this._templates = store.templates; + this._prototypes = store.prototypes; + this._types = store.types; + this._sectionTemplatePath = store.sectionTemplatePath; + + // Completely rerender prototype if any CSS modules classnames change + if (!(0, _fp.isEqual)(this._classNames, store.classNames)) { + var isInitialRender = !this._classNames; + this._classNames = store.classNames; + + // Only rerender after initial render (when classnames is not falsy) + if (!isInitialRender) { + this.cycleModules(); + } + } + } + }], [{ + key: 'applyModifier', + value: function applyModifier(data, modifier) { + // If we have a modifier, use it, otherwise use the entire data set + if (modifier && data && data[modifier]) { + return Object.assign({}, data[modifier], { modifier: modifier }); + } + + return data; + } + + /** + * Get markup from any type of module (html, json or template) + * + * @param {string} content - String corresponding to markup + * @return {object} el.firstElementChild - HTML module + */ + + }, { + key: 'convertToElement', + value: function convertToElement(content) { + var el = document.createElement('div'); + + el.innerHTML = content; + return el.firstElementChild; + } + + /** + * Filter module object by module key or module type + * + * @param {object} filter - Filter for modules. Options: + * @param {string} filter.property - Which property to filter ('key' or 'type') + * @param {array} filter.values - Values for property + * @param {bool} filter.include - Whether the values should be included or excluded (true = include, false = exclude) + * @param {object} moduleMeta - Filter for modules. Fields explained in the filterModules() function docs + * @return {bool} match - determine if modules need to be filtered + */ + + }, { + key: 'filterModules', + value: function filterModules(filter, moduleMeta) { + var match = true; + + // Check if we should filter out any modules + if ('object' === (typeof filter === 'undefined' ? 'undefined' : _typeof(filter)) && {}.hasOwnProperty.call(filter, 'property') && {}.hasOwnProperty.call(filter, 'values') && {}.hasOwnProperty.call(filter, 'include')) { + match = filter.values.filter(function (value) { + return moduleMeta[filter.property] === value; + }); + return Boolean(match.length) === filter.include; + } + + console.log(' // eslint-disable-line no-console\n filter ' + filter + ' is not in a valid format.\n module filters must include \'property\', \'values\', and \'include\' properties\n '); + + return match; + } + + /** + * Retrieve a data attribute from a tag using one of two methods + * + * @param {HTMLElement} tag - DOM node on which to check for a data attribute + * @param {string} attr - attribute to check for + * @returns {string} data - contents of data attribute + */ + + }, { + key: 'getDataAttribute', + value: function getDataAttribute(tag, attr) { + var data = false; + + // Check if element has dataset and, if so, use it + if (tag.dataset) { + data = tag.dataset[attr]; + } + + // Fallback to getAttribute for ugly old Safari + if (!data && tag.getAttribute) { + data = tag.getAttribute('data-' + attr); + } + + return data; + } + + /** + * Check if this tag is a styleguide helper + * + * @param {object} tag - tag to check + * @param {object} meta - module metadata + * @return {bool} + */ + + }, { + key: 'isSectionHelper', + value: function isSectionHelper(tag, meta) { + if ('prototype' === meta.type) { + return tag.hasAttribute('huron-sections') || tag.hasAttribute('huron-menu'); + } + + return false; + } + }]); + + return InsertNodes; +}(); +/* eslint-enable */ + + +exports.default = InsertNodes; /***/ }), /***/ 0: -/* no static exports found */ -/* all exports used */ -/*!*****************************!*\ - !*** multi ./src/web/index ***! - \*****************************/ /***/ (function(module, exports, __webpack_require__) { -module.exports = __webpack_require__(/*! ./src/web/index */"./src/web/index.js"); +module.exports = __webpack_require__("./src/web/index.js"); /***/ }) -/******/ }); \ No newline at end of file +/******/ }); +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/package.json b/package.json index e77da1a..d754e35 100644 --- a/package.json +++ b/package.json @@ -2,7 +2,7 @@ "name": "huron", "description": "An in-browser prototyping tool built on top of webpack and kss-node", "author": "Alley Interactive", - "version": "2.3.0-beta.4", + "version": "2.3.0-beta.5", "license": "GPL-2.0", "repository": { "type": "git", diff --git a/templates/hotTemplate.js b/templates/hotTemplate.js index 6421264..3e2da3d 100644 --- a/templates/hotTemplate.js +++ b/templates/hotTemplate.js @@ -1,4 +1,4 @@ -/* globals requirePath, requireRegex, sectionTemplatePath */ +/* globals hotScope */ // NOTE: This is not a normal JS file! It is pulled in by the CLI as a string // and prepended to the browser script after replacing anything referenced via `hotScope[variable]`