NOTICE: By continued use of this site you understand and agree to the binding Terms of Service and Privacy Policy.
// ==UserScript== // @name Jack's Dev Helpers // @version 0.1.0.2022.5.19.22.5 // @description Hodgepodge of dev utils // @license GPL-3.0-or-later; http://www.gnu.org/licenses/gpl-3.0.txt // @author Jack McCown // @match *://*/* // @namespace jackmscripts // @run-at document-end // ==/UserScript== /******/ (function(modules) { // webpackBootstrap /******/ // The module cache /******/ var installedModules = {}; /******/ /******/ // The require function /******/ function __webpack_require__(moduleId) { /******/ /******/ // Check if module is in cache /******/ if(installedModules[moduleId]) { /******/ return installedModules[moduleId].exports; /******/ } /******/ // Create a new module (and put it into the cache) /******/ var module = installedModules[moduleId] = { /******/ i: moduleId, /******/ l: false, /******/ exports: {} /******/ }; /******/ /******/ // Execute the module function /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); /******/ /******/ // Flag the module as loaded /******/ module.l = true; /******/ /******/ // Return the exports of the module /******/ return module.exports; /******/ } /******/ /******/ /******/ // expose the modules object (__webpack_modules__) /******/ __webpack_require__.m = modules; /******/ /******/ // expose the module cache /******/ __webpack_require__.c = installedModules; /******/ /******/ // define getter function for harmony exports /******/ __webpack_require__.d = function(exports, name, getter) { /******/ if(!__webpack_require__.o(exports, name)) { /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); /******/ } /******/ }; /******/ /******/ // define __esModule on exports /******/ __webpack_require__.r = function(exports) { /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); /******/ } /******/ Object.defineProperty(exports, '__esModule', { value: true }); /******/ }; /******/ /******/ // create a fake namespace object /******/ // mode & 1: value is a module id, require it /******/ // mode & 2: merge all properties of value into the ns /******/ // mode & 4: return value when already ns object /******/ // mode & 8|1: behave like require /******/ __webpack_require__.t = function(value, mode) { /******/ if(mode & 1) value = __webpack_require__(value); /******/ if(mode & 8) return value; /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; /******/ var ns = Object.create(null); /******/ __webpack_require__.r(ns); /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); /******/ return ns; /******/ }; /******/ /******/ // getDefaultExport function for compatibility with non-harmony modules /******/ __webpack_require__.n = function(module) { /******/ var getter = module && module.__esModule ? /******/ function getDefault() { return module['default']; } : /******/ function getModuleExports() { return module; }; /******/ __webpack_require__.d(getter, 'a', getter); /******/ return getter; /******/ }; /******/ /******/ // Object.prototype.hasOwnProperty.call /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; /******/ /******/ // __webpack_public_path__ /******/ __webpack_require__.p = ""; /******/ /******/ /******/ // Load entry module and return exports /******/ return __webpack_require__(__webpack_require__.s = "./src/main.ts"); /******/ }) /************************************************************************/ /******/ ({ /***/ "./node_modules/@typed/compose/lib.es2015/compose.js": /*!***********************************************************!*\ !*** ./node_modules/@typed/compose/lib.es2015/compose.js ***! \***********************************************************/ /*! exports provided: compose */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "compose", function() { return compose; }); function compose() { switch (arguments.length) { case 1: return _compose1(arguments[0]); case 2: return _compose2(arguments[0], arguments[1]); case 3: return _compose3(arguments[0], arguments[1], arguments[2]); case 4: return _compose4(arguments[0], arguments[1], arguments[2], arguments[3]); case 5: return _compose5(arguments[0], arguments[1], arguments[2], arguments[3], arguments[4]); } ; } function _compose1(f) { return function compose1Fn(a) { return f(a); }; } function _compose2(g, f) { return function compose2Fn(a) { return g(f(a)); }; } function _compose3(h, g, f) { return function compose3Fn(a) { return h(g(f(a))); }; } function _compose4(i, h, g, f) { return function compose3Fn(a) { return i(h(g(f(a)))); }; } function _compose5(j, i, h, g, f) { return function compose5Fn(a) { return j(i(h(g(f(a))))); }; } //# sourceMappingURL=compose.js.map /***/ }), /***/ "./node_modules/@typed/compose/lib.es2015/index.js": /*!*********************************************************!*\ !*** ./node_modules/@typed/compose/lib.es2015/index.js ***! \*********************************************************/ /*! exports provided: compose */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony import */ var _compose__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./compose */ "./node_modules/@typed/compose/lib.es2015/compose.js"); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "compose", function() { return _compose__WEBPACK_IMPORTED_MODULE_0__["compose"]; }); //# sourceMappingURL=index.js.map /***/ }), /***/ "./node_modules/decode-uri-component/index.js": /*!****************************************************!*\ !*** ./node_modules/decode-uri-component/index.js ***! \****************************************************/ /*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { "use strict"; var token = '%[a-f0-9]{2}'; var singleMatcher = new RegExp(token, 'gi'); var multiMatcher = new RegExp('(' + token + ')+', 'gi'); function decodeComponents(components, split) { try { // Try to decode the entire string first return decodeURIComponent(components.join('')); } catch (err) { // Do nothing } if (components.length === 1) { return components; } split = split || 1; // Split the array in 2 parts var left = components.slice(0, split); var right = components.slice(split); return Array.prototype.concat.call([], decodeComponents(left), decodeComponents(right)); } function decode(input) { try { return decodeURIComponent(input); } catch (err) { var tokens = input.match(singleMatcher); for (var i = 1; i < tokens.length; i++) { input = decodeComponents(tokens, i).join(''); tokens = input.match(singleMatcher); } return input; } } function customDecodeURIComponent(input) { // Keep track of all the replacements and prefill the map with the `BOM` var replaceMap = { '%FE%FF': '\uFFFD\uFFFD', '%FF%FE': '\uFFFD\uFFFD' }; var match = multiMatcher.exec(input); while (match) { try { // Decode as big chunks as possible replaceMap[match[0]] = decodeURIComponent(match[0]); } catch (err) { var result = decode(match[0]); if (result !== match[0]) { replaceMap[match[0]] = result; } } match = multiMatcher.exec(input); } // Add `%C2` at the end of the map to make sure it does not replace the combinator before everything else replaceMap['%C2'] = '\uFFFD'; var entries = Object.keys(replaceMap); for (var i = 0; i < entries.length; i++) { // Replace all decoded components var key = entries[i]; input = input.replace(new RegExp(key, 'g'), replaceMap[key]); } return input; } module.exports = function (encodedURI) { if (typeof encodedURI !== 'string') { throw new TypeError('Expected `encodedURI` to be of type `string`, got `' + typeof encodedURI + '`'); } try { encodedURI = encodedURI.replace(/\+/g, ' '); // Try the built in decoder first return decodeURIComponent(encodedURI); } catch (err) { // Fallback to a more advanced decoder return customDecodeURIComponent(encodedURI); } }; /***/ }), /***/ "./node_modules/deep-entries/dist/index.esm.js": /*!*****************************************************!*\ !*** ./node_modules/deep-entries/dist/index.esm.js ***! \*****************************************************/ /*! exports provided: deepEntries, deepEntriesIterator, delimitEntry, delimitEntryBy, rotateEntry, rotateEntryBy */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "deepEntries", function() { return deepEntries; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "deepEntriesIterator", function() { return deepEntriesIterator; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "delimitEntry", function() { return delimitEntry; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "delimitEntryBy", function() { return delimitEntryBy; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "rotateEntry", function() { return rotateEntry; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "rotateEntryBy", function() { return rotateEntryBy; }); const identity = x => x; const getInterface = x => { const str = Object.prototype.toString.call(x); return str.substring(8, str.length - 1) }; const isObjectLike = x => { const tag = getInterface(x); switch (tag) { case 'String': case 'Number': case 'Boolean': case 'RegExp': case 'Date': return false default: if (x === null) { return false } if (tag.startsWith('HTML')) { return false } return typeof x === 'object' } }; function* entriesIterator(input) { switch (getInterface(input)) { case 'Array': case 'Map': case 'URLSearchParams': yield* input.entries(); break case 'Set': case 'NodeList': case 'Int8Array': case 'Uint8Array': case 'Uint8ClampedArray': case 'Int16Array': case 'Uint16Array': case 'Int32Array': case 'Uint32Array': case 'Float32Array': case 'Float64Array': case 'BigInt64Array': case 'BigUint64Array': let i = 0; for (let value of input) yield [i++, value]; break case 'Object': default: if (isObjectLike(input)) for (let key in input) if (Object.prototype.hasOwnProperty.call(input, key)) yield [key, input[key]]; break } } function* deepEntriesIterator_(input, mapFn, parentCircularSet) { const map = typeof mapFn === 'function' ? mapFn : identity; for (let [key, value] of entriesIterator(input)) { if (!isObjectLike(value)) { const entry = map([key, value]); if (entry !== undefined) yield entry; } else { const circularSet = parentCircularSet || new WeakSet(); circularSet.add(input); if (!circularSet.has(value)) { for (let entries of deepEntriesIterator_( value, undefined, circularSet )) { const entry = map([key, ...entries]); if (entry !== undefined) yield entry; } } } } } function* deepEntriesIterator(input, mapFn) { yield* deepEntriesIterator_(input, mapFn); } const deepEntries = (input, mapFn) => Array.from(deepEntriesIterator(input, mapFn)); const rotateEntryBy = n => entry => { if (entry === undefined) return const mod = (-1 * (Number(n) || 0)) % entry.length; const keys = entry.slice(0, mod); const value = entry.slice(mod); return [...value, ...keys] }; const rotateEntry = rotateEntryBy(1); const delimitEntryBy = delimiter => entry => { if (entry === undefined) return const [value, ...keys] = rotateEntry(entry); return [keys.join(delimiter), value] }; const delimitEntry = delimitEntryBy('.'); /***/ }), /***/ "./node_modules/filter-obj/index.js": /*!******************************************!*\ !*** ./node_modules/filter-obj/index.js ***! \******************************************/ /*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { "use strict"; module.exports = function (obj, predicate) { var ret = {}; var keys = Object.keys(obj); var isArr = Array.isArray(predicate); for (var i = 0; i < keys.length; i++) { var key = keys[i]; var val = obj[key]; if (isArr ? predicate.indexOf(key) !== -1 : predicate(key, val, obj)) { ret[key] = val; } } return ret; }; /***/ }), /***/ "./node_modules/git-up/lib/index.js": /*!******************************************!*\ !*** ./node_modules/git-up/lib/index.js ***! \******************************************/ /*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { "use strict"; // Dependencies var parseUrl = __webpack_require__(/*! parse-url */ "./node_modules/parse-url/lib/index.js"), isSsh = __webpack_require__(/*! is-ssh */ "./node_modules/is-ssh/lib/index.js"); /** * gitUp * Parses the input url. * * @name gitUp * @function * @param {String} input The input url. * @return {Object} An object containing the following fields: * * - `protocols` (Array): An array with the url protocols (usually it has one element). * - `port` (null|Number): The domain port. * - `resource` (String): The url domain (including subdomains). * - `user` (String): The authentication user (usually for ssh urls). * - `pathname` (String): The url pathname. * - `hash` (String): The url hash. * - `search` (String): The url querystring value. * - `href` (String): The input url. * - `protocol` (String): The git url protocol. * - `token` (String): The oauth token (could appear in the https urls). */ function gitUp(input) { var output = parseUrl(input); output.token = ""; var splits = output.user.split(":"); if (splits.length === 2) { if (splits[1] === "x-oauth-basic") { output.token = splits[0]; } else if (splits[0] === "x-token-auth") { output.token = splits[1]; } } if (isSsh(output.protocols) || isSsh(input)) { output.protocol = "ssh"; } else if (output.protocols.length) { output.protocol = output.protocols[0]; } else { output.protocol = "file"; } output.href = output.href.replace(/\/$/, ""); return output; } module.exports = gitUp; /***/ }), /***/ "./node_modules/git-url-parse/lib/index.js": /*!*************************************************!*\ !*** ./node_modules/git-url-parse/lib/index.js ***! \*************************************************/ /*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { "use strict"; var gitUp = __webpack_require__(/*! git-up */ "./node_modules/git-up/lib/index.js"); /** * gitUrlParse * Parses a Git url. * * @name gitUrlParse * @function * @param {String} url The Git url to parse. * @return {GitUrl} The `GitUrl` object containing: * * - `protocols` (Array): An array with the url protocols (usually it has one element). * - `port` (null|Number): The domain port. * - `resource` (String): The url domain (including subdomains). * - `user` (String): The authentication user (usually for ssh urls). * - `pathname` (String): The url pathname. * - `hash` (String): The url hash. * - `search` (String): The url querystring value. * - `href` (String): The input url. * - `protocol` (String): The git url protocol. * - `token` (String): The oauth token (could appear in the https urls). * - `source` (String): The Git provider (e.g. `"github.com"`). * - `owner` (String): The repository owner. * - `name` (String): The repository name. * - `ref` (String): The repository ref (e.g., "master" or "dev"). * - `filepath` (String): A filepath relative to the repository root. * - `filepathtype` (String): The type of filepath in the url ("blob" or "tree"). * - `full_name` (String): The owner and name values in the `owner/name` format. * - `toString` (Function): A function to stringify the parsed url into another url type. * - `organization` (String): The organization the owner belongs to. This is CloudForge specific. * - `git_suffix` (Boolean): Whether to add the `.git` suffix or not. * */ function gitUrlParse(url) { if (typeof url !== "string") { throw new Error("The url must be a string."); } var urlInfo = gitUp(url), sourceParts = urlInfo.resource.split("."), splits = null; urlInfo.toString = function (type) { return gitUrlParse.stringify(this, type); }; urlInfo.source = sourceParts.length > 2 ? sourceParts.slice(1 - sourceParts.length).join(".") : urlInfo.source = urlInfo.resource; // Note: Some hosting services (e.g. Visual Studio Team Services) allow whitespace characters // in the repository and owner names so we decode the URL pieces to get the correct result urlInfo.git_suffix = /\.git$/.test(urlInfo.pathname); urlInfo.name = decodeURIComponent(urlInfo.pathname.replace(/^\//, '').replace(/\.git$/, "")); urlInfo.owner = decodeURIComponent(urlInfo.user); switch (urlInfo.source) { case "git.cloudforge.com": urlInfo.owner = urlInfo.user; urlInfo.organization = sourceParts[0]; urlInfo.source = "cloudforge.com"; break; case "visualstudio.com": // Handle VSTS SSH URLs if (urlInfo.resource === 'vs-ssh.visualstudio.com') { splits = urlInfo.name.split("/"); if (splits.length === 4) { urlInfo.organization = splits[1]; urlInfo.owner = splits[2]; urlInfo.name = splits[3]; urlInfo.full_name = splits[2] + '/' + splits[3]; } break; } else { splits = urlInfo.name.split("/"); if (splits.length === 2) { urlInfo.owner = splits[1]; urlInfo.name = splits[1]; urlInfo.full_name = '_git/' + urlInfo.name; } else if (splits.length === 3) { urlInfo.name = splits[2]; if (splits[0] === 'DefaultCollection') { urlInfo.owner = splits[2]; urlInfo.organization = splits[0]; urlInfo.full_name = urlInfo.organization + '/_git/' + urlInfo.name; } else { urlInfo.owner = splits[0]; urlInfo.full_name = urlInfo.owner + '/_git/' + urlInfo.name; } } else if (splits.length === 4) { urlInfo.organization = splits[0]; urlInfo.owner = splits[1]; urlInfo.name = splits[3]; urlInfo.full_name = urlInfo.organization + '/' + urlInfo.owner + '/_git/' + urlInfo.name; } break; } // Azure DevOps (formerly Visual Studio Team Services) case "dev.azure.com": case "azure.com": if (urlInfo.resource === 'ssh.dev.azure.com') { splits = urlInfo.name.split("/"); if (splits.length === 4) { urlInfo.organization = splits[1]; urlInfo.owner = splits[2]; urlInfo.name = splits[3]; } break; } else { splits = urlInfo.name.split("/"); if (splits.length === 5) { urlInfo.organization = splits[0]; urlInfo.owner = splits[1]; urlInfo.name = splits[4]; urlInfo.full_name = '_git/' + urlInfo.name; } else if (splits.length === 3) { urlInfo.name = splits[2]; if (splits[0] === 'DefaultCollection') { urlInfo.owner = splits[2]; urlInfo.organization = splits[0]; urlInfo.full_name = urlInfo.organization + '/_git/' + urlInfo.name; } else { urlInfo.owner = splits[0]; urlInfo.full_name = urlInfo.owner + '/_git/' + urlInfo.name; } } else if (splits.length === 4) { urlInfo.organization = splits[0]; urlInfo.owner = splits[1]; urlInfo.name = splits[3]; urlInfo.full_name = urlInfo.organization + '/' + urlInfo.owner + '/_git/' + urlInfo.name; } if (urlInfo.query && urlInfo.query['path']) { urlInfo.filepath = urlInfo.query['path'].replace(/^\/+/g, ''); // Strip leading slash (/) } if (urlInfo.query && urlInfo.query['version']) { // version=GB<branch> urlInfo.ref = urlInfo.query['version'].replace(/^GB/, ''); // remove GB } break; } default: splits = urlInfo.name.split("/"); var nameIndex = splits.length - 1; if (splits.length >= 2) { var dashIndex = splits.indexOf("-", 2); var blobIndex = splits.indexOf("blob", 2); var treeIndex = splits.indexOf("tree", 2); var commitIndex = splits.indexOf("commit", 2); var srcIndex = splits.indexOf("src", 2); var rawIndex = splits.indexOf("raw", 2); nameIndex = dashIndex > 0 ? dashIndex - 1 : blobIndex > 0 ? blobIndex - 1 : treeIndex > 0 ? treeIndex - 1 : commitIndex > 0 ? commitIndex - 1 : srcIndex > 0 ? srcIndex - 1 : rawIndex > 0 ? rawIndex - 1 : nameIndex; urlInfo.owner = splits.slice(0, nameIndex).join('/'); urlInfo.name = splits[nameIndex]; if (commitIndex) { urlInfo.commit = splits[nameIndex + 2]; } } urlInfo.ref = ""; urlInfo.filepathtype = ""; urlInfo.filepath = ""; var offsetNameIndex = splits.length > nameIndex && splits[nameIndex + 1] === "-" ? nameIndex + 1 : nameIndex; if (splits.length > offsetNameIndex + 2 && ["raw", "src", "blob", "tree"].indexOf(splits[offsetNameIndex + 1]) >= 0) { urlInfo.filepathtype = splits[offsetNameIndex + 1]; urlInfo.ref = splits[offsetNameIndex + 2]; if (splits.length > offsetNameIndex + 3) { urlInfo.filepath = splits.slice(offsetNameIndex + 3).join('/'); } } urlInfo.organization = urlInfo.owner; break; } if (!urlInfo.full_name) { urlInfo.full_name = urlInfo.owner; if (urlInfo.name) { urlInfo.full_name && (urlInfo.full_name += "/"); urlInfo.full_name += urlInfo.name; } } // Bitbucket Server if (urlInfo.owner.startsWith("scm/")) { urlInfo.source = "bitbucket-server"; urlInfo.owner = urlInfo.owner.replace("scm/", ""); urlInfo.organization = urlInfo.owner; urlInfo.full_name = urlInfo.owner + "/" + urlInfo.name; } var bitbucket = /(projects|users)\/(.*?)\/repos\/(.*?)((\/.*$)|$)/; var matches = bitbucket.exec(urlInfo.pathname); if (matches != null) { urlInfo.source = "bitbucket-server"; if (matches[1] === "users") { urlInfo.owner = "~" + matches[2]; } else { urlInfo.owner = matches[2]; } urlInfo.organization = urlInfo.owner; urlInfo.name = matches[3]; splits = matches[4].split("/"); if (splits.length > 1) { if (["raw", "browse"].indexOf(splits[1]) >= 0) { urlInfo.filepathtype = splits[1]; if (splits.length > 2) { urlInfo.filepath = splits.slice(2).join('/'); } } else if (splits[1] === "commits" && splits.length > 2) { urlInfo.commit = splits[2]; } } urlInfo.full_name = urlInfo.owner + "/" + urlInfo.name; if (urlInfo.query.at) { urlInfo.ref = urlInfo.query.at; } else { urlInfo.ref = ""; } } return urlInfo; } /** * stringify * Stringifies a `GitUrl` object. * * @name stringify * @function * @param {GitUrl} obj The parsed Git url object. * @param {String} type The type of the stringified url (default `obj.protocol`). * @return {String} The stringified url. */ gitUrlParse.stringify = function (obj, type) { type = type || (obj.protocols && obj.protocols.length ? obj.protocols.join('+') : obj.protocol); var port = obj.port ? ":" + obj.port : ''; var user = obj.user || 'git'; var maybeGitSuffix = obj.git_suffix ? ".git" : ""; switch (type) { case "ssh": if (port) return "ssh://" + user + "@" + obj.resource + port + "/" + obj.full_name + maybeGitSuffix;else return user + "@" + obj.resource + ":" + obj.full_name + maybeGitSuffix; case "git+ssh": case "ssh+git": case "ftp": case "ftps": return type + "://" + user + "@" + obj.resource + port + "/" + obj.full_name + maybeGitSuffix; case "http": case "https": var auth = obj.token ? buildToken(obj) : obj.user && (obj.protocols.includes('http') || obj.protocols.includes('https')) ? obj.user + "@" : ""; return type + "://" + auth + obj.resource + port + "/" + buildPath(obj) + maybeGitSuffix; default: return obj.href; } }; /*! * buildToken * Builds OAuth token prefix (helper function) * * @name buildToken * @function * @param {GitUrl} obj The parsed Git url object. * @return {String} token prefix */ function buildToken(obj) { switch (obj.source) { case "bitbucket.org": return "x-token-auth:" + obj.token + "@"; default: return obj.token + "@"; } } function buildPath(obj) { switch (obj.source) { case "bitbucket-server": return "scm/" + obj.full_name; default: return "" + obj.full_name; } } module.exports = gitUrlParse; /***/ }), /***/ "./node_modules/is-ssh/lib/index.js": /*!******************************************!*\ !*** ./node_modules/is-ssh/lib/index.js ***! \******************************************/ /*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { "use strict"; // Dependencies var protocols = __webpack_require__(/*! protocols */ "./node_modules/protocols/lib/index.js"); /** * isSsh * Checks if an input value is a ssh url or not. * * @name isSsh * @function * @param {String|Array} input The input url or an array of protocols. * @return {Boolean} `true` if the input is a ssh url, `false` otherwise. */ function isSsh(input) { if (Array.isArray(input)) { return input.indexOf("ssh") !== -1 || input.indexOf("rsync") !== -1; } if (typeof input !== "string") { return false; } var prots = protocols(input); input = input.substring(input.indexOf("://") + 3); if (isSsh(prots)) { return true; } // TODO This probably could be improved :) var urlPortPattern = new RegExp('\.([a-zA-Z\\d]+):(\\d+)\/'); return !input.match(urlPortPattern) && input.indexOf("@") < input.indexOf(":"); } module.exports = isSsh; /***/ }), /***/ "./node_modules/lines-unlines/dist/index.mjs": /*!***************************************************!*\ !*** ./node_modules/lines-unlines/dist/index.mjs ***! \***************************************************/ /*! exports provided: lines, unlines */ /***/ (function(__webpack_module__, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "lines", function() { return lines; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "unlines", function() { return unlines; }); function lines(s) { return s === "" ? [] : s.replace(/\n$/, "").split("\n"); } function unlines(ls) { return ls.map(line => line + "\n").join(""); } //# sourceMappingURL=index.js.map /***/ }), /***/ "./node_modules/normalize-url/index.js": /*!*********************************************!*\ !*** ./node_modules/normalize-url/index.js ***! \*********************************************/ /*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { "use strict"; // https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs const DATA_URL_DEFAULT_MIME_TYPE = 'text/plain'; const DATA_URL_DEFAULT_CHARSET = 'us-ascii'; const testParameter = (name, filters) => { return filters.some(filter => filter instanceof RegExp ? filter.test(name) : filter === name); }; const normalizeDataURL = (urlString, {stripHash}) => { const match = /^data:(?<type>[^,]*?),(?<data>[^#]*?)(?:#(?<hash>.*))?$/.exec(urlString); if (!match) { throw new Error(`Invalid URL: ${urlString}`); } let {type, data, hash} = match.groups; const mediaType = type.split(';'); hash = stripHash ? '' : hash; let isBase64 = false; if (mediaType[mediaType.length - 1] === 'base64') { mediaType.pop(); isBase64 = true; } // Lowercase MIME type const mimeType = (mediaType.shift() || '').toLowerCase(); const attributes = mediaType .map(attribute => { let [key, value = ''] = attribute.split('=').map(string => string.trim()); // Lowercase `charset` if (key === 'charset') { value = value.toLowerCase(); if (value === DATA_URL_DEFAULT_CHARSET) { return ''; } } return `${key}${value ? `=${value}` : ''}`; }) .filter(Boolean); const normalizedMediaType = [ ...attributes ]; if (isBase64) { normalizedMediaType.push('base64'); } if (normalizedMediaType.length !== 0 || (mimeType && mimeType !== DATA_URL_DEFAULT_MIME_TYPE)) { normalizedMediaType.unshift(mimeType); } return `data:${normalizedMediaType.join(';')},${isBase64 ? data.trim() : data}${hash ? `#${hash}` : ''}`; }; const normalizeUrl = (urlString, options) => { options = { defaultProtocol: 'http:', normalizeProtocol: true, forceHttp: false, forceHttps: false, stripAuthentication: true, stripHash: false, stripTextFragment: true, stripWWW: true, removeQueryParameters: [/^utm_\w+/i], removeTrailingSlash: true, removeSingleSlash: true, removeDirectoryIndex: false, sortQueryParameters: true, ...options }; urlString = urlString.trim(); // Data URL if (/^data:/i.test(urlString)) { return normalizeDataURL(urlString, options); } if (/^view-source:/i.test(urlString)) { throw new Error('`view-source:` is not supported as it is a non-standard protocol'); } const hasRelativeProtocol = urlString.startsWith('//'); const isRelativeUrl = !hasRelativeProtocol && /^\.*\//.test(urlString); // Prepend protocol if (!isRelativeUrl) { urlString = urlString.replace(/^(?!(?:\w+:)?\/\/)|^\/\//, options.defaultProtocol); } const urlObj = new URL(urlString); if (options.forceHttp && options.forceHttps) { throw new Error('The `forceHttp` and `forceHttps` options cannot be used together'); } if (options.forceHttp && urlObj.protocol === 'https:') { urlObj.protocol = 'http:'; } if (options.forceHttps && urlObj.protocol === 'http:') { urlObj.protocol = 'https:'; } // Remove auth if (options.stripAuthentication) { urlObj.username = ''; urlObj.password = ''; } // Remove hash if (options.stripHash) { urlObj.hash = ''; } else if (options.stripTextFragment) { urlObj.hash = urlObj.hash.replace(/#?:~:text.*?$/i, ''); } // Remove duplicate slashes if not preceded by a protocol if (urlObj.pathname) { urlObj.pathname = urlObj.pathname.replace(/(?<!\b(?:[a-z][a-z\d+\-.]{1,50}:))\/{2,}/g, '/'); } // Decode URI octets if (urlObj.pathname) { try { urlObj.pathname = decodeURI(urlObj.pathname); } catch (_) {} } // Remove directory index if (options.removeDirectoryIndex === true) { options.removeDirectoryIndex = [/^index\.[a-z]+$/]; } if (Array.isArray(options.removeDirectoryIndex) && options.removeDirectoryIndex.length > 0) { let pathComponents = urlObj.pathname.split('/'); const lastComponent = pathComponents[pathComponents.length - 1]; if (testParameter(lastComponent, options.removeDirectoryIndex)) { pathComponents = pathComponents.slice(0, pathComponents.length - 1); urlObj.pathname = pathComponents.slice(1).join('/') + '/'; } } if (urlObj.hostname) { // Remove trailing dot urlObj.hostname = urlObj.hostname.replace(/\.$/, ''); // Remove `www.` if (options.stripWWW && /^www\.(?!www\.)(?:[a-z\-\d]{1,63})\.(?:[a-z.\-\d]{2,63})$/.test(urlObj.hostname)) { // Each label should be max 63 at length (min: 1). // Source: https://en.wikipedia.org/wiki/Hostname#Restrictions_on_valid_host_names // Each TLD should be up to 63 characters long (min: 2). // It is technically possible to have a single character TLD, but none currently exist. urlObj.hostname = urlObj.hostname.replace(/^www\./, ''); } } // Remove query unwanted parameters if (Array.isArray(options.removeQueryParameters)) { for (const key of [...urlObj.searchParams.keys()]) { if (testParameter(key, options.removeQueryParameters)) { urlObj.searchParams.delete(key); } } } if (options.removeQueryParameters === true) { urlObj.search = ''; } // Sort query parameters if (options.sortQueryParameters) { urlObj.searchParams.sort(); } if (options.removeTrailingSlash) { urlObj.pathname = urlObj.pathname.replace(/\/$/, ''); } const oldUrlString = urlString; // Take advantage of many of the Node `url` normalizations urlString = urlObj.toString(); if (!options.removeSingleSlash && urlObj.pathname === '/' && !oldUrlString.endsWith('/') && urlObj.hash === '') { urlString = urlString.replace(/\/$/, ''); } // Remove ending `/` unless removeSingleSlash is false if ((options.removeTrailingSlash || urlObj.pathname === '/') && urlObj.hash === '' && options.removeSingleSlash) { urlString = urlString.replace(/\/$/, ''); } // Restore relative protocol, if applicable if (hasRelativeProtocol && !options.normalizeProtocol) { urlString = urlString.replace(/^http:\/\//, '//'); } // Remove http/https if (options.stripProtocol) { urlString = urlString.replace(/^(?:https?:)?\/\//, ''); } return urlString; }; module.exports = normalizeUrl; /***/ }), /***/ "./node_modules/parse-path/lib/index.js": /*!**********************************************!*\ !*** ./node_modules/parse-path/lib/index.js ***! \**********************************************/ /*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { "use strict"; // Dependencies var protocols = __webpack_require__(/*! protocols */ "./node_modules/protocols/lib/index.js"), isSsh = __webpack_require__(/*! is-ssh */ "./node_modules/is-ssh/lib/index.js"), qs = __webpack_require__(/*! query-string */ "./node_modules/query-string/index.js"); /** * parsePath * Parses the input url. * * @name parsePath * @function * @param {String} url The input url. * @return {Object} An object containing the following fields: * * - `protocols` (Array): An array with the url protocols (usually it has one element). * - `protocol` (String): The first protocol, `"ssh"` (if the url is a ssh url) or `"file"`. * - `port` (null|Number): The domain port. * - `resource` (String): The url domain (including subdomains). * - `user` (String): The authentication user (usually for ssh urls). * - `pathname` (String): The url pathname. * - `hash` (String): The url hash. * - `search` (String): The url querystring value. * - `href` (String): The input url. * - `query` (Object): The url querystring, parsed as object. */ function parsePath(url) { url = (url || "").trim(); var output = { protocols: protocols(url), protocol: null, port: null, resource: "", user: "", pathname: "", hash: "", search: "", href: url, query: Object.create(null) }, protocolIndex = url.indexOf("://"), resourceIndex = -1, splits = null, parts = null; if (url.startsWith(".")) { if (url.startsWith("./")) { url = url.substring(2); } output.pathname = url; output.protocol = "file"; } var firstChar = url.charAt(1); if (!output.protocol) { output.protocol = output.protocols[0]; if (!output.protocol) { if (isSsh(url)) { output.protocol = "ssh"; } else if (firstChar === "/" || firstChar === "~") { url = url.substring(2); output.protocol = "file"; } else { output.protocol = "file"; } } } if (protocolIndex !== -1) { url = url.substring(protocolIndex + 3); } parts = url.split(/\/|\\/); if (output.protocol !== "file") { output.resource = parts.shift(); } else { output.resource = ""; } // user@domain splits = output.resource.split("@"); if (splits.length === 2) { output.user = splits[0]; output.resource = splits[1]; } // domain.com:port splits = output.resource.split(":"); if (splits.length === 2) { output.resource = splits[0]; if (splits[1]) { output.port = Number(splits[1]); if (isNaN(output.port)) { output.port = null; parts.unshift(splits[1]); } } else { output.port = null; } } // Remove empty elements parts = parts.filter(Boolean); // Stringify the pathname if (output.protocol === "file") { output.pathname = output.href; } else { output.pathname = output.pathname || (output.protocol !== "file" || output.href[0] === "/" ? "/" : "") + parts.join("/"); } // #some-hash splits = output.pathname.split("#"); if (splits.length === 2) { output.pathname = splits[0]; output.hash = splits[1]; } // ?foo=bar splits = output.pathname.split("?"); if (splits.length === 2) { output.pathname = splits[0]; output.search = splits[1]; } output.query = qs.parse(output.search); output.href = output.href.replace(/\/$/, ""); output.pathname = output.pathname.replace(/\/$/, ""); return output; } module.exports = parsePath; /***/ }), /***/ "./node_modules/parse-url/lib/index.js": /*!*********************************************!*\ !*** ./node_modules/parse-url/lib/index.js ***! \*********************************************/ /*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { "use strict"; 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 parsePath = __webpack_require__(/*! parse-path */ "./node_modules/parse-path/lib/index.js"), normalizeUrl = __webpack_require__(/*! normalize-url */ "./node_modules/normalize-url/index.js"); /** * parseUrl * Parses the input url. * * **Note**: This *throws* if invalid urls are provided. * * @name parseUrl * @function * @param {String} url The input url. * @param {Boolean|Object} normalize Wheter to normalize the url or not. * Default is `false`. If `true`, the url will * be normalized. If an object, it will be the * options object sent to [`normalize-url`](https://github.com/sindresorhus/normalize-url). * * For SSH urls, normalize won't work. * * @return {Object} An object containing the following fields: * * - `protocols` (Array): An array with the url protocols (usually it has one element). * - `protocol` (String): The first protocol, `"ssh"` (if the url is a ssh url) or `"file"`. * - `port` (null|Number): The domain port. * - `resource` (String): The url domain (including subdomains). * - `user` (String): The authentication user (usually for ssh urls). * - `pathname` (String): The url pathname. * - `hash` (String): The url hash. * - `search` (String): The url querystring value. * - `href` (String): The input url. * - `query` (Object): The url querystring, parsed as object. */ function parseUrl(url) { var normalize = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; if (typeof url !== "string" || !url.trim()) { throw new Error("Invalid url."); } if (normalize) { if ((typeof normalize === "undefined" ? "undefined" : _typeof(normalize)) !== "object") { normalize = { stripHash: false }; } url = normalizeUrl(url, normalize); } var parsed = parsePath(url); return parsed; } module.exports = parseUrl; /***/ }), /***/ "./node_modules/protocols/lib/index.js": /*!*********************************************!*\ !*** ./node_modules/protocols/lib/index.js ***! \*********************************************/ /*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { "use strict"; /** * protocols * Returns the protocols of an input url. * * @name protocols * @function * @param {String} input The input url. * @param {Boolean|Number} first If `true`, the first protocol will be returned. If number, it will represent the zero-based index of the protocols array. * @return {Array|String} The array of protocols or the specified protocol. */ module.exports = function protocols(input, first) { if (first === true) { first = 0; } var index = input.indexOf("://"), splits = input.substring(0, index).split("+").filter(Boolean); if (typeof first === "number") { return splits[first]; } return splits; }; /***/ }), /***/ "./node_modules/query-string/index.js": /*!********************************************!*\ !*** ./node_modules/query-string/index.js ***! \********************************************/ /*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { "use strict"; const strictUriEncode = __webpack_require__(/*! strict-uri-encode */ "./node_modules/strict-uri-encode/index.js"); const decodeComponent = __webpack_require__(/*! decode-uri-component */ "./node_modules/decode-uri-component/index.js"); const splitOnFirst = __webpack_require__(/*! split-on-first */ "./node_modules/split-on-first/index.js"); const filterObject = __webpack_require__(/*! filter-obj */ "./node_modules/filter-obj/index.js"); const isNullOrUndefined = value => value === null || value === undefined; function encoderForArrayFormat(options) { switch (options.arrayFormat) { case 'index': return key => (result, value) => { const index = result.length; if ( value === undefined || (options.skipNull && value === null) || (options.skipEmptyString && value === '') ) { return result; } if (value === null) { return [...result, [encode(key, options), '[', index, ']'].join('')]; } return [ ...result, [encode(key, options), '[', encode(index, options), ']=', encode(value, options)].join('') ]; }; case 'bracket': return key => (result, value) => { if ( value === undefined || (options.skipNull && value === null) || (options.skipEmptyString && value === '') ) { return result; } if (value === null) { return [...result, [encode(key, options), '[]'].join('')]; } return [...result, [encode(key, options), '[]=', encode(value, options)].join('')]; }; case 'comma': case 'separator': return key => (result, value) => { if (value === null || value === undefined || value.length === 0) { return result; } if (result.length === 0) { return [[encode(key, options), '=', encode(value, options)].join('')]; } return [[result, encode(value, options)].join(options.arrayFormatSeparator)]; }; default: return key => (result, value) => { if ( value === undefined || (options.skipNull && value === null) || (options.skipEmptyString && value === '') ) { return result; } if (value === null) { return [...result, encode(key, options)]; } return [...result, [encode(key, options), '=', encode(value, options)].join('')]; }; } } function parserForArrayFormat(options) { let result; switch (options.arrayFormat) { case 'index': return (key, value, accumulator) => { result = /\[(\d*)\]$/.exec(key); key = key.replace(/\[\d*\]$/, ''); if (!result) { accumulator[key] = value; return; } if (accumulator[key] === undefined) { accumulator[key] = {}; } accumulator[key][result[1]] = value; }; case 'bracket': return (key, value, accumulator) => { result = /(\[\])$/.exec(key); key = key.replace(/\[\]$/, ''); if (!result) { accumulator[key] = value; return; } if (accumulator[key] === undefined) { accumulator[key] = [value]; return; } accumulator[key] = [].concat(accumulator[key], value); }; case 'comma': case 'separator': return (key, value, accumulator) => { const isArray = typeof value === 'string' && value.includes(options.arrayFormatSeparator); const isEncodedArray = (typeof value === 'string' && !isArray && decode(value, options).includes(options.arrayFormatSeparator)); value = isEncodedArray ? decode(value, options) : value; const newValue = isArray || isEncodedArray ? value.split(options.arrayFormatSeparator).map(item => decode(item, options)) : value === null ? value : decode(value, options); accumulator[key] = newValue; }; default: return (key, value, accumulator) => { if (accumulator[key] === undefined) { accumulator[key] = value; return; } accumulator[key] = [].concat(accumulator[key], value); }; } } function validateArrayFormatSeparator(value) { if (typeof value !== 'string' || value.length !== 1) { throw new TypeError('arrayFormatSeparator must be single character string'); } } function encode(value, options) { if (options.encode) { return options.strict ? strictUriEncode(value) : encodeURIComponent(value); } return value; } function decode(value, options) { if (options.decode) { return decodeComponent(value); } return value; } function keysSorter(input) { if (Array.isArray(input)) { return input.sort(); } if (typeof input === 'object') { return keysSorter(Object.keys(input)) .sort((a, b) => Number(a) - Number(b)) .map(key => input[key]); } return input; } function removeHash(input) { const hashStart = input.indexOf('#'); if (hashStart !== -1) { input = input.slice(0, hashStart); } return input; } function getHash(url) { let hash = ''; const hashStart = url.indexOf('#'); if (hashStart !== -1) { hash = url.slice(hashStart); } return hash; } function extract(input) { input = removeHash(input); const queryStart = input.indexOf('?'); if (queryStart === -1) { return ''; } return input.slice(queryStart + 1); } function parseValue(value, options) { if (options.parseNumbers && !Number.isNaN(Number(value)) && (typeof value === 'string' && value.trim() !== '')) { value = Number(value); } else if (options.parseBooleans && value !== null && (value.toLowerCase() === 'true' || value.toLowerCase() === 'false')) { value = value.toLowerCase() === 'true'; } return value; } function parse(query, options) { options = Object.assign({ decode: true, sort: true, arrayFormat: 'none', arrayFormatSeparator: ',', parseNumbers: false, parseBooleans: false }, options); validateArrayFormatSeparator(options.arrayFormatSeparator); const formatter = parserForArrayFormat(options); // Create an object with no prototype const ret = Object.create(null); if (typeof query !== 'string') { return ret; } query = query.trim().replace(/^[?#&]/, ''); if (!query) { return ret; } for (const param of query.split('&')) { if (param === '') { continue; } let [key, value] = splitOnFirst(options.decode ? param.replace(/\+/g, ' ') : param, '='); // Missing `=` should be `null`: // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters value = value === undefined ? null : ['comma', 'separator'].includes(options.arrayFormat) ? value : decode(value, options); formatter(decode(key, options), value, ret); } for (const key of Object.keys(ret)) { const value = ret[key]; if (typeof value === 'object' && value !== null) { for (const k of Object.keys(value)) { value[k] = parseValue(value[k], options); } } else { ret[key] = parseValue(value, options); } } if (options.sort === false) { return ret; } return (options.sort === true ? Object.keys(ret).sort() : Object.keys(ret).sort(options.sort)).reduce((result, key) => { const value = ret[key]; if (Boolean(value) && typeof value === 'object' && !Array.isArray(value)) { // Sort object keys, not values result[key] = keysSorter(value); } else { result[key] = value; } return result; }, Object.create(null)); } exports.extract = extract; exports.parse = parse; exports.stringify = (object, options) => { if (!object) { return ''; } options = Object.assign({ encode: true, strict: true, arrayFormat: 'none', arrayFormatSeparator: ',' }, options); validateArrayFormatSeparator(options.arrayFormatSeparator); const shouldFilter = key => ( (options.skipNull && isNullOrUndefined(object[key])) || (options.skipEmptyString && object[key] === '') ); const formatter = encoderForArrayFormat(options); const objectCopy = {}; for (const key of Object.keys(object)) { if (!shouldFilter(key)) { objectCopy[key] = object[key]; } } const keys = Object.keys(objectCopy); if (options.sort !== false) { keys.sort(options.sort); } return keys.map(key => { const value = object[key]; if (value === undefined) { return ''; } if (value === null) { return encode(key, options); } if (Array.isArray(value)) { return value .reduce(formatter(key), []) .join('&'); } return encode(key, options) + '=' + encode(value, options); }).filter(x => x.length > 0).join('&'); }; exports.parseUrl = (url, options) => { options = Object.assign({ decode: true }, options); const [url_, hash] = splitOnFirst(url, '#'); return Object.assign( { url: url_.split('?')[0] || '', query: parse(extract(url), options) }, options && options.parseFragmentIdentifier && hash ? {fragmentIdentifier: decode(hash, options)} : {} ); }; exports.stringifyUrl = (object, options) => { options = Object.assign({ encode: true, strict: true }, options); const url = removeHash(object.url).split('?')[0] || ''; const queryFromUrl = exports.extract(object.url); const parsedQueryFromUrl = exports.parse(queryFromUrl, {sort: false}); const query = Object.assign(parsedQueryFromUrl, object.query); let queryString = exports.stringify(query, options); if (queryString) { queryString = `?${queryString}`; } let hash = getHash(object.url); if (object.fragmentIdentifier) { hash = `#${encode(object.fragmentIdentifier, options)}`; } return `${url}${queryString}${hash}`; }; exports.pick = (input, filter, options) => { options = Object.assign({ parseFragmentIdentifier: true }, options); const {url, query, fragmentIdentifier} = exports.parseUrl(input, options); return exports.stringifyUrl({ url, query: filterObject(query, filter), fragmentIdentifier }, options); }; exports.exclude = (input, filter, options) => { const exclusionFilter = Array.isArray(filter) ? key => !filter.includes(key) : (key, value) => !filter(key, value); return exports.pick(input, exclusionFilter, options); }; /***/ }), /***/ "./node_modules/split-on-first/index.js": /*!**********************************************!*\ !*** ./node_modules/split-on-first/index.js ***! \**********************************************/ /*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { "use strict"; module.exports = (string, separator) => { if (!(typeof string === 'string' && typeof separator === 'string')) { throw new TypeError('Expected the arguments to be of type `string`'); } if (separator === '') { return [string]; } const separatorIndex = string.indexOf(separator); if (separatorIndex === -1) { return [string]; } return [ string.slice(0, separatorIndex), string.slice(separatorIndex + separator.length) ]; }; /***/ }), /***/ "./node_modules/strict-uri-encode/index.js": /*!*************************************************!*\ !*** ./node_modules/strict-uri-encode/index.js ***! \*************************************************/ /*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { "use strict"; module.exports = str => encodeURIComponent(str).replace(/[!'()*]/g, x => `%${x.charCodeAt(0).toString(16).toUpperCase()}`); /***/ }), /***/ "./node_modules/ts-type-guards/dist/array.mjs": /*!****************************************************!*\ !*** ./node_modules/ts-type-guards/dist/array.mjs ***! \****************************************************/ /*! exports provided: isArrayOfBooleans, isArrayOfNumbers, isArrayOfStrings, isArrayOfSymbols, isArrayOfNulls, isArrayOfUndefineds, isArrayOfPrimitives, isArrayOfObjects, isArrayOf, isArrayOfLike */ /***/ (function(__webpack_module__, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isArrayOfBooleans", function() { return isArrayOfBooleans; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isArrayOfNumbers", function() { return isArrayOfNumbers; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isArrayOfStrings", function() { return isArrayOfStrings; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isArrayOfSymbols", function() { return isArrayOfSymbols; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isArrayOfNulls", function() { return isArrayOfNulls; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isArrayOfUndefineds", function() { return isArrayOfUndefineds; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isArrayOfPrimitives", function() { return isArrayOfPrimitives; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isArrayOfObjects", function() { return isArrayOfObjects; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isArrayOf", function() { return isArrayOf; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isArrayOfLike", function() { return isArrayOfLike; }); /* harmony import */ var _is__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./is */ "./node_modules/ts-type-guards/dist/is.mjs"); function isArrayOfBooleans(x) { return isArrayOfLike(true)(x); } function isArrayOfNumbers(x) { return isArrayOfLike(1)(x); } function isArrayOfStrings(x) { return isArrayOfLike("")(x); } function isArrayOfSymbols(x) { return isArrayOfLike(Symbol())(x); } function isArrayOfNulls(x) { return isArrayOfLike(null)(x); } function isArrayOfUndefineds(x) { return isArrayOfLike(undefined)(x); } function isArrayOfPrimitives(x) { return Object(_is__WEBPACK_IMPORTED_MODULE_0__["is"])(Array)(x) && x.every(_is__WEBPACK_IMPORTED_MODULE_0__["isPrimitive"]); } function isArrayOfObjects(x) { return Object(_is__WEBPACK_IMPORTED_MODULE_0__["is"])(Array)(x) && x.every(_is__WEBPACK_IMPORTED_MODULE_0__["isNonPrimitive"]); } function isArrayOf(type) { return (xs) => Object(_is__WEBPACK_IMPORTED_MODULE_0__["is"])(Array)(xs) && xs.every(Object(_is__WEBPACK_IMPORTED_MODULE_0__["is"])(type)); } function isArrayOfLike(reference) { return (x) => Object(_is__WEBPACK_IMPORTED_MODULE_0__["is"])(Array)(x) && x.every(Object(_is__WEBPACK_IMPORTED_MODULE_0__["isLike"])(reference)); } //# sourceMappingURL=array.js.map /***/ }), /***/ "./node_modules/ts-type-guards/dist/index.mjs": /*!****************************************************!*\ !*** ./node_modules/ts-type-guards/dist/index.mjs ***! \****************************************************/ /*! exports provided: isBoolean, isNumber, isString, isSymbol, isNull, isUndefined, isPrimitive, isNonPrimitive, is, isLike, isArrayOfBooleans, isArrayOfNumbers, isArrayOfStrings, isArrayOfSymbols, isArrayOfNulls, isArrayOfUndefineds, isArrayOfPrimitives, isArrayOfObjects, isArrayOf, isArrayOfLike, onlyBooleans, onlyNumbers, onlyStrings, onlySymbols, onlyNulls, onlyUndefineds, onlyPrimitives, onlyObjects, only, onlyLike */ /***/ (function(__webpack_module__, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony import */ var _is__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./is */ "./node_modules/ts-type-guards/dist/is.mjs"); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isBoolean", function() { return _is__WEBPACK_IMPORTED_MODULE_0__["isBoolean"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isNumber", function() { return _is__WEBPACK_IMPORTED_MODULE_0__["isNumber"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isString", function() { return _is__WEBPACK_IMPORTED_MODULE_0__["isString"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isSymbol", function() { return _is__WEBPACK_IMPORTED_MODULE_0__["isSymbol"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isNull", function() { return _is__WEBPACK_IMPORTED_MODULE_0__["isNull"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isUndefined", function() { return _is__WEBPACK_IMPORTED_MODULE_0__["isUndefined"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isPrimitive", function() { return _is__WEBPACK_IMPORTED_MODULE_0__["isPrimitive"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isNonPrimitive", function() { return _is__WEBPACK_IMPORTED_MODULE_0__["isNonPrimitive"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "is", function() { return _is__WEBPACK_IMPORTED_MODULE_0__["is"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isLike", function() { return _is__WEBPACK_IMPORTED_MODULE_0__["isLike"]; }); /* harmony import */ var _array__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./array */ "./node_modules/ts-type-guards/dist/array.mjs"); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isArrayOfBooleans", function() { return _array__WEBPACK_IMPORTED_MODULE_1__["isArrayOfBooleans"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isArrayOfNumbers", function() { return _array__WEBPACK_IMPORTED_MODULE_1__["isArrayOfNumbers"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isArrayOfStrings", function() { return _array__WEBPACK_IMPORTED_MODULE_1__["isArrayOfStrings"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isArrayOfSymbols", function() { return _array__WEBPACK_IMPORTED_MODULE_1__["isArrayOfSymbols"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isArrayOfNulls", function() { return _array__WEBPACK_IMPORTED_MODULE_1__["isArrayOfNulls"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isArrayOfUndefineds", function() { return _array__WEBPACK_IMPORTED_MODULE_1__["isArrayOfUndefineds"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isArrayOfPrimitives", function() { return _array__WEBPACK_IMPORTED_MODULE_1__["isArrayOfPrimitives"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isArrayOfObjects", function() { return _array__WEBPACK_IMPORTED_MODULE_1__["isArrayOfObjects"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isArrayOf", function() { return _array__WEBPACK_IMPORTED_MODULE_1__["isArrayOf"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isArrayOfLike", function() { return _array__WEBPACK_IMPORTED_MODULE_1__["isArrayOfLike"]; }); /* harmony import */ var _only__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./only */ "./node_modules/ts-type-guards/dist/only.mjs"); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "onlyBooleans", function() { return _only__WEBPACK_IMPORTED_MODULE_2__["onlyBooleans"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "onlyNumbers", function() { return _only__WEBPACK_IMPORTED_MODULE_2__["onlyNumbers"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "onlyStrings", function() { return _only__WEBPACK_IMPORTED_MODULE_2__["onlyStrings"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "onlySymbols", function() { return _only__WEBPACK_IMPORTED_MODULE_2__["onlySymbols"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "onlyNulls", function() { return _only__WEBPACK_IMPORTED_MODULE_2__["onlyNulls"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "onlyUndefineds", function() { return _only__WEBPACK_IMPORTED_MODULE_2__["onlyUndefineds"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "onlyPrimitives", function() { return _only__WEBPACK_IMPORTED_MODULE_2__["onlyPrimitives"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "onlyObjects", function() { return _only__WEBPACK_IMPORTED_MODULE_2__["onlyObjects"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "only", function() { return _only__WEBPACK_IMPORTED_MODULE_2__["only"]; }); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "onlyLike", function() { return _only__WEBPACK_IMPORTED_MODULE_2__["onlyLike"]; }); //# sourceMappingURL=index.js.map /***/ }), /***/ "./node_modules/ts-type-guards/dist/is.mjs": /*!*************************************************!*\ !*** ./node_modules/ts-type-guards/dist/is.mjs ***! \*************************************************/ /*! exports provided: isBoolean, isNumber, isString, isSymbol, isNull, isUndefined, isPrimitive, isNonPrimitive, is, isLike */ /***/ (function(__webpack_module__, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isBoolean", function() { return isBoolean; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isNumber", function() { return isNumber; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isString", function() { return isString; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isSymbol", function() { return isSymbol; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isNull", function() { return isNull; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isUndefined", function() { return isUndefined; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isPrimitive", function() { return isPrimitive; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isNonPrimitive", function() { return isNonPrimitive; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "is", function() { return is; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isLike", function() { return isLike; }); const TYPE_GUARDS_PRIMITIVE = [isBoolean, isNumber, isString, isSymbol, isNull, isUndefined]; function isBoolean(x) { return typeof x === "boolean"; } function isNumber(x) { return typeof x === "number"; } function isString(x) { return typeof x === "string"; } function isSymbol(x) { return typeof x === "symbol"; } function isNull(x) { return x === null; } function isUndefined(x) { return x === undefined; } function isPrimitive(x) { return TYPE_GUARDS_PRIMITIVE.some(f => f(x)); } function isNonPrimitive(x) { return !isPrimitive(x); } function namedFunction(name, fun) { return Object.defineProperty(fun, "name", { value: name, writable: false }); } function namedTypeGuard(creator, type, typeGuard) { return namedFunction(`${creator.name}(${type.name})`, typeGuard); } function is(type) { if (isPrimitive(type)) { return (_) => false; } return namedTypeGuard(is, type, (x) => x instanceof type); } function isLike(reference) { for (const f of TYPE_GUARDS_PRIMITIVE) { if (f(reference)) { return (x) => f(x); } } if (is(Array)(reference)) { const referenceAsArray = reference; return (x) => is(Array)(x) && (referenceAsArray.length > 0 ? x.every(isLike(referenceAsArray[0])) : true); } if (reference.constructor === Object) { return (x) => (![undefined, null].includes(x) && Object.keys(reference).every(k => isLike(reference[k])(x[k]))); } if (reference.constructor instanceof Function) { return is(reference.constructor); } throw new TypeError(isLike.name + ` cannot use this object as reference because it has no constructor: ` + JSON.stringify(reference)); } //# sourceMappingURL=is.js.map /***/ }), /***/ "./node_modules/ts-type-guards/dist/only.mjs": /*!***************************************************!*\ !*** ./node_modules/ts-type-guards/dist/only.mjs ***! \***************************************************/ /*! exports provided: onlyBooleans, onlyNumbers, onlyStrings, onlySymbols, onlyNulls, onlyUndefineds, onlyPrimitives, onlyObjects, only, onlyLike */ /***/ (function(__webpack_module__, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "onlyBooleans", function() { return onlyBooleans; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "onlyNumbers", function() { return onlyNumbers; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "onlyStrings", function() { return onlyStrings; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "onlySymbols", function() { return onlySymbols; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "onlyNulls", function() { return onlyNulls; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "onlyUndefineds", function() { return onlyUndefineds; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "onlyPrimitives", function() { return onlyPrimitives; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "onlyObjects", function() { return onlyObjects; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "only", function() { return only; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "onlyLike", function() { return onlyLike; }); /* harmony import */ var _is__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./is */ "./node_modules/ts-type-guards/dist/is.mjs"); function onlyBooleans(xs) { return xs.filter(_is__WEBPACK_IMPORTED_MODULE_0__["isBoolean"]); } function onlyNumbers(xs) { return xs.filter(_is__WEBPACK_IMPORTED_MODULE_0__["isNumber"]); } function onlyStrings(xs) { return xs.filter(_is__WEBPACK_IMPORTED_MODULE_0__["isString"]); } function onlySymbols(xs) { return xs.filter(_is__WEBPACK_IMPORTED_MODULE_0__["isSymbol"]); } function onlyNulls(xs) { return xs.filter(_is__WEBPACK_IMPORTED_MODULE_0__["isNull"]); } function onlyUndefineds(xs) { return xs.filter(_is__WEBPACK_IMPORTED_MODULE_0__["isUndefined"]); } function onlyPrimitives(xs) { return xs.filter(_is__WEBPACK_IMPORTED_MODULE_0__["isPrimitive"]); } function onlyObjects(xs) { return xs.filter(_is__WEBPACK_IMPORTED_MODULE_0__["isNonPrimitive"]); } function only(type) { return (xs) => xs.filter(Object(_is__WEBPACK_IMPORTED_MODULE_0__["is"])(type)); } function onlyLike(reference) { return (xs) => xs.filter(Object(_is__WEBPACK_IMPORTED_MODULE_0__["isLike"])(reference)); } //# sourceMappingURL=only.js.map /***/ }), /***/ "./node_modules/userscripter/lib/environment.mjs": /*!*******************************************************!*\ !*** ./node_modules/userscripter/lib/environment.mjs ***! \*******************************************************/ /*! exports provided: ALWAYS, NEVER, DOMCONTENTLOADED, LOAD */ /***/ (function(__webpack_module__, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ALWAYS", function() { return ALWAYS; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "NEVER", function() { return NEVER; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DOMCONTENTLOADED", function() { return DOMCONTENTLOADED; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LOAD", function() { return LOAD; }); const ALWAYS = () => true; const NEVER = () => false; const DOMCONTENTLOADED = (state) => state !== "loading"; const LOAD = (state) => state === "complete"; /***/ }), /***/ "./node_modules/userscripter/lib/errors.mjs": /*!**************************************************!*\ !*** ./node_modules/userscripter/lib/errors.mjs ***! \**************************************************/ /*! exports provided: explanation, failureDescriber */ /***/ (function(__webpack_module__, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "explanation", function() { return explanation; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "failureDescriber", function() { return failureDescriber; }); /* harmony import */ var lines_unlines__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! lines-unlines */ "./node_modules/lines-unlines/dist/index.mjs"); const INDENTATION = " "; function formatDependency(d) { return INDENTATION + d.key + ": " + d.selector; } function explanation(failure) { switch (failure.result.reason) { case 0: return Object(lines_unlines__WEBPACK_IMPORTED_MODULE_0__["unlines"])([ `These dependencies were not found:`, ``, Object(lines_unlines__WEBPACK_IMPORTED_MODULE_0__["unlines"])(failure.result.dependencies.map(formatDependency)), ]); case 1: return Object(lines_unlines__WEBPACK_IMPORTED_MODULE_0__["unlines"])([ `The operation failed with this error:`, ``, failure.result.message, ]); } } function failureDescriber(context) { return failure => Object(lines_unlines__WEBPACK_IMPORTED_MODULE_0__["unlines"])([ `Could not ${failure.operation.description} on this page:`, ``, INDENTATION + location.href, ``, explanation(failure).trim(), ``, `This problem might be caused by ${context.siteName} changing its content/structure, in which case ${context.extensionName} needs to be updated accordingly. Otherwise, it's probably a bug in ${context.extensionName}.`, ``, `If you file a bug report, please include this message.`, ]); } /***/ }), /***/ "./node_modules/userscripter/lib/index.mjs": /*!*************************************************!*\ !*** ./node_modules/userscripter/lib/index.mjs ***! \*************************************************/ /*! exports provided: environment, errors, log, operations, preferences, stylesheets, userscripter */ /***/ (function(__webpack_module__, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony import */ var _environment__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./environment */ "./node_modules/userscripter/lib/environment.mjs"); /* harmony reexport (module object) */ __webpack_require__.d(__webpack_exports__, "environment", function() { return _environment__WEBPACK_IMPORTED_MODULE_0__; }); /* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./errors */ "./node_modules/userscripter/lib/errors.mjs"); /* harmony reexport (module object) */ __webpack_require__.d(__webpack_exports__, "errors", function() { return _errors__WEBPACK_IMPORTED_MODULE_1__; }); /* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./log */ "./node_modules/userscripter/lib/log.mjs"); /* harmony reexport (module object) */ __webpack_require__.d(__webpack_exports__, "log", function() { return _log__WEBPACK_IMPORTED_MODULE_2__; }); /* harmony import */ var _operations__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./operations */ "./node_modules/userscripter/lib/operations.mjs"); /* harmony reexport (module object) */ __webpack_require__.d(__webpack_exports__, "operations", function() { return _operations__WEBPACK_IMPORTED_MODULE_3__; }); /* harmony import */ var _preferences__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./preferences */ "./node_modules/userscripter/lib/preferences.mjs"); /* harmony reexport (module object) */ __webpack_require__.d(__webpack_exports__, "preferences", function() { return _preferences__WEBPACK_IMPORTED_MODULE_4__; }); /* harmony import */ var _stylesheets__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./stylesheets */ "./node_modules/userscripter/lib/stylesheets.mjs"); /* harmony reexport (module object) */ __webpack_require__.d(__webpack_exports__, "stylesheets", function() { return _stylesheets__WEBPACK_IMPORTED_MODULE_5__; }); /* harmony import */ var _userscripter__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./userscripter */ "./node_modules/userscripter/lib/userscripter.mjs"); /* harmony reexport (module object) */ __webpack_require__.d(__webpack_exports__, "userscripter", function() { return _userscripter__WEBPACK_IMPORTED_MODULE_6__; }); /***/ }), /***/ "./node_modules/userscripter/lib/log.mjs": /*!***********************************************!*\ !*** ./node_modules/userscripter/lib/log.mjs ***! \***********************************************/ /*! exports provided: setPrefix, setLogger, log, info, warning, error */ /***/ (function(__webpack_module__, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setPrefix", function() { return setPrefix; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setLogger", function() { return setLogger; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "log", function() { return log; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "info", function() { return info; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "warning", function() { return warning; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "error", function() { return error; }); let prefix = ""; let logger = console; function setPrefix(p) { prefix = p; } function setLogger(l) { logger = l; } function log(str) { logger.log(prefix, str); } function info(str) { logger.info(prefix, str); } function warning(str) { logger.warn(prefix, str); } function error(str) { logger.error(prefix, str); } /***/ }), /***/ "./node_modules/userscripter/lib/operations.mjs": /*!******************************************************!*\ !*** ./node_modules/userscripter/lib/operations.mjs ***! \******************************************************/ /*! exports provided: operation, run */ /***/ (function(__webpack_module__, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "operation", function() { return operation; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "run", function() { return run; }); /* harmony import */ var ts_type_guards__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ts-type-guards */ "./node_modules/ts-type-guards/dist/index.mjs"); const SUCCESS = undefined; function operation(spec) { return spec; } function run(plan) { function recurse(operations, failures, triesLeft) { const lastTry = Object(ts_type_guards__WEBPACK_IMPORTED_MODULE_0__["isNumber"])(triesLeft) && triesLeft <= 0; const operationsToRunNow = []; const remaining = []; const readyState = document.readyState; for (const o of operations) { const shouldRunNow = o.deferUntil === undefined || o.deferUntil(readyState); (shouldRunNow ? operationsToRunNow : remaining).push(o); } for (const o of operationsToRunNow) { const result = tryToPerform(o); if (result !== SUCCESS) { switch (result.reason) { case 0: lastTry ? failures.push({ result, operation: o }) : remaining.push(o); break; case 1: failures.push({ result, operation: o }); break; } } } if (remaining.length > 0) { setTimeout(() => recurse(remaining, failures, (Object(ts_type_guards__WEBPACK_IMPORTED_MODULE_0__["isNumber"])(triesLeft) ? triesLeft - 1 : plan.tryUntil(readyState) ? plan.extraTries : undefined)), plan.interval); } else if (failures.length > 0) { plan.handleFailures(failures); } } recurse(plan.operations.filter(o => o.condition(window)), []); } function tryToPerform(o) { const dependencies = o.dependencies === undefined ? {} : o.dependencies; const queryResults = Object.entries(dependencies).map(([key, selector]) => ({ key, selector, element: document.querySelector(selector), })); const missingDependencies = queryResults.filter(x => Object(ts_type_guards__WEBPACK_IMPORTED_MODULE_0__["isNull"])(x.element)); if (missingDependencies.length > 0) { return { reason: 0, dependencies: missingDependencies }; } const e = queryResults.reduce((acc, x) => Object.defineProperty(acc, x.key, { value: x.element }), {}); return fromActionResult(o.action(e)); } function fromActionResult(r) { return Object(ts_type_guards__WEBPACK_IMPORTED_MODULE_0__["isString"])(r) ? { reason: 1, message: r } : SUCCESS; } /***/ }), /***/ "./node_modules/userscripter/lib/preferences.mjs": /*!*******************************************************!*\ !*** ./node_modules/userscripter/lib/preferences.mjs ***! \*******************************************************/ /*! exports provided: subscriptable, loggingResponseHandler, noopResponseHandler */ /***/ (function(__webpack_module__, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "subscriptable", function() { return subscriptable; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "loggingResponseHandler", function() { return loggingResponseHandler; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "noopResponseHandler", function() { return noopResponseHandler; }); /* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./log */ "./node_modules/userscripter/lib/log.mjs"); function subscriptable(handler) { const changeListeners = new Set(); return { subscribe: (listener) => { changeListeners.add(listener); }, unsubscribe: (listener) => { changeListeners.delete(listener); }, handler: (summary, preferences) => { if (summary.action === "set") { changeListeners.forEach(f => f(summary.preference)); } return handler(summary, preferences); }, }; } function loggingResponseHandler(summary, preferences) { const response = summary.response; switch (response.status) { case 0: return response; case 1: if (summary.action === "get") { _log__WEBPACK_IMPORTED_MODULE_0__["warning"](`The saved value for preference '${summary.preference.key}' (${JSON.stringify(response.saved)}) was invalid. Replacing it with ${JSON.stringify(response.value)}.`); preferences.set(summary.preference, response.value); } if (summary.action === "set") { _log__WEBPACK_IMPORTED_MODULE_0__["warning"](`Could not set value ${JSON.stringify(response.value)} for preference '${summary.preference.key}' because it was invalid.`); } return response; case 2: if (summary.action === "get") { _log__WEBPACK_IMPORTED_MODULE_0__["warning"](`The saved value for preference '${summary.preference.key}' had the wrong type. Replacing it with ${JSON.stringify(response.value)}.`); preferences.set(summary.preference, response.value); } return response; case 3: if (summary.action === "get") { _log__WEBPACK_IMPORTED_MODULE_0__["warning"](`The saved value for preference '${summary.preference.key}' could not be parsed. Replacing it with ${JSON.stringify(response.value)}.`); preferences.set(summary.preference, response.value); } return response; case 4: switch (summary.action) { case "get": _log__WEBPACK_IMPORTED_MODULE_0__["error"](`Could not read preference '${summary.preference.key}' because localStorage could not be accessed. Using value ${JSON.stringify(summary.preference.default)}.`); break; case "set": _log__WEBPACK_IMPORTED_MODULE_0__["error"](`Could not save value ${JSON.stringify(summary.response.value)} for preference '${summary.preference.key}' because localStorage could not be accessed.`); break; default: assertUnreachable(summary.action); } return response; default: return assertUnreachable(response.status); } } function noopResponseHandler(summary, _) { return summary.response; } function assertUnreachable(x) { throw new Error("assertUnreachable: " + x); } /***/ }), /***/ "./node_modules/userscripter/lib/stylesheets.mjs": /*!*******************************************************!*\ !*** ./node_modules/userscripter/lib/stylesheets.mjs ***! \*******************************************************/ /*! exports provided: stylesheet, insert, enable, disable */ /***/ (function(__webpack_module__, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "stylesheet", function() { return stylesheet; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "insert", function() { return insert; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "enable", function() { return enable; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "disable", function() { return disable; }); const MATCH_ALL = "all"; const MATCH_NONE = "not all"; function stylesheet(spec) { return spec; } function insert(stylesheets) { const fragment = document.createDocumentFragment(); Object.entries(stylesheets).forEach(([_, sheet]) => { const style = document.createElement("style"); if (sheet.id !== undefined) style.id = sheet.id; style.textContent = sheet.css; style.media = sheet.condition(window) ? MATCH_ALL : MATCH_NONE; fragment.appendChild(style); }); document.documentElement.appendChild(fragment); } const setMediaQuery = (m) => (s) => { const element = document.getElementById(s.id); if (element !== null) { element.setAttribute("media", m); } }; const enable = setMediaQuery(MATCH_ALL); const disable = setMediaQuery(MATCH_NONE); /***/ }), /***/ "./node_modules/userscripter/lib/userscripter.mjs": /*!********************************************************!*\ !*** ./node_modules/userscripter/lib/userscripter.mjs ***! \********************************************************/ /*! exports provided: run */ /***/ (function(__webpack_module__, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "run", function() { return run; }); /* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./log */ "./node_modules/userscripter/lib/log.mjs"); /* harmony import */ var _operations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./operations */ "./node_modules/userscripter/lib/operations.mjs"); /* harmony import */ var _stylesheets__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./stylesheets */ "./node_modules/userscripter/lib/stylesheets.mjs"); function run(userscript) { _log__WEBPACK_IMPORTED_MODULE_0__["setPrefix"](`[${userscript.name}]`); const attr = attribute(userscript.id); if (document.documentElement.hasAttribute(attr)) { _log__WEBPACK_IMPORTED_MODULE_0__["warning"](`It looks as though ${userscript.name} has already run (because the attribute "${attr}" was found on <head>). Stopping.`); } else { document.documentElement.setAttribute(attr, ""); userscript.initialAction(); _stylesheets__WEBPACK_IMPORTED_MODULE_2__["insert"](userscript.stylesheets); _operations__WEBPACK_IMPORTED_MODULE_1__["run"](userscript.operationsPlan); } } function attribute(id) { return "data-" + id + "-has-run"; } /***/ }), /***/ "./src/config.ts": /*!***********************!*\ !*** ./src/config.ts ***! \***********************/ /*! exports provided: OPERATIONS_INTERVAL, OPERATIONS_EXTRA_TRIES */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "OPERATIONS_INTERVAL", function() { return OPERATIONS_INTERVAL; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "OPERATIONS_EXTRA_TRIES", function() { return OPERATIONS_EXTRA_TRIES; }); // This file cannot contain Webpack-resolved imports (e.g. "~src/foo"). const OPERATIONS_INTERVAL = 200; // ms const OPERATIONS_EXTRA_TRIES = 3; /***/ }), /***/ "./src/helpers/extractTableInfo.ts": /*!*****************************************!*\ !*** ./src/helpers/extractTableInfo.ts ***! \*****************************************/ /*! exports provided: extractTableAsJson, traverseGfmTable */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "extractTableAsJson", function() { return extractTableAsJson; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "traverseGfmTable", function() { return traverseGfmTable; }); const arr = Array.from; const extractLinkedText = (node) => { const tmpNode = node.cloneNode(true); arr(tmpNode.querySelectorAll("a")).forEach((el) => (el.innerText = `[${el.innerText}](${el.href})`)); return tmpNode.innerText.trim(); }; function extractTableAsJson(table) { // Ideally first check if table is "regular" aka has equal number of th to td/tr let keys = []; if (table.tHead !== null) { keys = arr(table.tHead.querySelectorAll("th")).map((el) => extractLinkedText(el)); } else { keys = arr(table.querySelectorAll("th")).map((el) => extractLinkedText(el)); } return arr(table.tBodies).flatMap((el) => arr(el.querySelectorAll("tr")).map((tableRow) => { const dataCells = arr(tableRow.querySelectorAll("td")).map((el) => extractLinkedText(el)); if (dataCells.length !== keys.length) { console.warn("Found a row with a mismatch"); } if (keys.length === 0) { return dataCells; } return keys.reduce((tableRow, dataKey, idx) => ({ ...tableRow, [dataKey]: dataCells[idx], }), {}); })); } function traverseGfmTable(table) { let keys = []; keys = arr(table.querySelectorAll("th")).map((el) => extractLinkedText(el)); return arr(table.tBodies).map((el) => arr(el.querySelectorAll("tr")).map((tableRow) => { const dataCells = arr(tableRow.querySelectorAll("td")).map((el) => extractLinkedText(el)); if (dataCells.length !== keys.length) { console.warn("Found a row with a mismatch"); } if (keys.length === 0) { return dataCells; } return keys.reduce((tableRow, dataKey, idx) => ({ ...tableRow, [dataKey]: dataCells[idx], }), {}); })); } /***/ }), /***/ "./src/helpers/htmlTreeSelection.ts": /*!******************************************!*\ !*** ./src/helpers/htmlTreeSelection.ts ***! \******************************************/ /*! exports provided: htmlTreeSelection */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "htmlTreeSelection", function() { return htmlTreeSelection; }); function htmlTreeSelection() { return new Promise((resolve) => { // TODO select via keyboard? let clickable = [ document.getElementsByTagName("a"), document.getElementsByTagName("button"), document.querySelectorAll("[role=button]"), ]; const iframeOverlays = []; let lastElement = document.body; let overHandler = (e) => { let target = e.target; if (target === null) { return; } lastElement = target; target.classList.add("html-tree-selection"); if (target.classList.contains("html-tree-selection-overlay")) { if (target.dataset.index) { let iframe = iframeOverlays[parseInt(target.dataset.index, 10)].iframe; iframe.classList.add("html-tree-selection"); } else { console.warn("failed to find iframe"); } } e.stopPropagation(); }; let outHandler = (e) => { let target = e.target; if (target === null) { return; } const selectionClass = "html-tree-selection"; if (target.classList.contains(selectionClass)) { target.classList.remove(selectionClass); } e.stopPropagation(); }; let clickHandler = (e) => { disable(); let target = e.target; if (target === null) { return; } e.preventDefault(); e.stopPropagation(); if (target.classList.contains("html-tree-selection-overlay")) { if (target.dataset.index) { target = iframeOverlays[parseInt(target.dataset.index, 10)].iframe; } else { console.warn("maybe failed to find iframe?", target, iframeOverlays); } } resolve(target); }; let disable = () => { clickable.forEach((c) => { for (var i = 0; i < c.length; i++) { c[i].removeEventListener("click", clickHandler); // @ts-expect-error c[i].addEventListener("click", c[i].onclickBackup); // @ts-expect-error delete c[i].onclickBackup; } }); iframeOverlays.forEach((o) => o.overlay.remove()); document.documentElement.classList.remove("html-tree-selection-cursor"); // clean any orphaned hover applied class let orphan = document.querySelector(".html-tree-selection"); if (orphan !== null) { orphan.classList.remove("html-tree-selection"); } document.removeEventListener("mouseover", overHandler); document.removeEventListener("mouseout", outHandler); document.removeEventListener("click", clickHandler); document.removeEventListener("keydown", keyHandler, true); window.removeEventListener("scroll", updateOverlayPositions); window.removeEventListener("resize", updateOverlayPositions); }; const selectNode = (el) => { return el.dispatchEvent(new MouseEvent("mouseover", { bubbles: true })); }; const unselectNode = (el) => { return el.dispatchEvent(new MouseEvent("mouseout", { bubbles: true })); }; const clearCurrentSelection = () => { clickable.forEach((c) => { for (var i = 0; i < c.length; i++) { unselectNode(c[i]); } }); }; const moveSelectionToElement = (el) => { clearCurrentSelection(); selectNode(el); }; const moveSelectionToParent = () => { const parent = lastElement.parentElement; if (parent !== null) { moveSelectionToElement(parent); } }; const moveSelectionToChild = () => { const child = lastElement.children && lastElement.children[0]; if (child && child !== null) { moveSelectionToElement(child); } }; const moveSelectionToNextSibling = () => { const sibling = lastElement.nextElementSibling; if (sibling !== null) { moveSelectionToElement(sibling); } }; const moveSelectionToPrevSibling = () => { const sibling = lastElement.previousElementSibling; if (sibling !== null) { moveSelectionToElement(sibling); } }; let keyHandler = (e) => { const h = { Escape: disable, ArrowLeft: moveSelectionToParent, ArrowRight: moveSelectionToChild, ArrowUp: moveSelectionToNextSibling, ArrowDown: moveSelectionToPrevSibling, }; console.debug(e.key); // @ts-ignore const handler = h[e.key]; handler && handler(); }; let updateOverlayPositions = (_e) => { iframeOverlays.forEach((o) => { let iframe = o.iframe; let iframeClientRect = iframe.getBoundingClientRect(); let overlay = o.overlay; let offsetX = iframeClientRect.left + window.scrollX; let offsetY = iframeClientRect.top + window.scrollY; overlay.style.top = `${offsetY}px`; overlay.style.left = `${offsetX}px`; }); }; // enable window.addEventListener("scroll", updateOverlayPositions); window.addEventListener("resize", updateOverlayPositions); // override click handlers on any clickable element clickable.forEach((c) => { for (var i = 0; i < c.length; i++) { // @ts-expect-error c[i].onclickBackup = c[i].onclick; c[i].addEventListener("click", clickHandler); } }); let iframes = document.querySelectorAll("iframe"); iframes.forEach((i) => { let overlay = document.createElement("div"); let iframeClientRect = i.getBoundingClientRect(); let offsetX = iframeClientRect.left + window.scrollX; let offsetY = iframeClientRect.top + window.scrollY; overlay.classList.add("html-tree-selection-overlay"); overlay.style.top = `${offsetY}px`; overlay.style.left = `${offsetX}px`; overlay.style.width = `${iframeClientRect.width}px`; overlay.style.height = `${iframeClientRect.height}px`; overlay.dataset.index = `${iframeOverlays.length}`; iframeOverlays.push({ iframe: i, overlay: overlay, }); document.body.appendChild(overlay); }); document.documentElement.classList.add("html-tree-selection-cursor"); document.addEventListener("mouseover", overHandler); document.addEventListener("mouseout", outHandler); document.addEventListener("click", clickHandler); document.addEventListener("keydown", keyHandler, true); }); } /***/ }), /***/ "./src/helpers/utils.ts": /*!******************************!*\ !*** ./src/helpers/utils.ts ***! \******************************/ /*! exports provided: addToClipboard, getSiblings, appendBtnToElements, installEsModule */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "addToClipboard", function() { return addToClipboard; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getSiblings", function() { return getSiblings; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "appendBtnToElements", function() { return appendBtnToElements; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "installEsModule", function() { return installEsModule; }); const addToClipboard = (content) => { const permissionName = "clipboard-write"; return navigator.permissions .query({ name: permissionName }) .then((result) => { if (result.state == "granted" || result.state == "prompt") { return navigator.clipboard.writeText(content).then(() => { }); } throw Error("Permission for clipboard-write was not obtained " + result.state); }); }; const getSiblings = (elem) => { const siblings = []; let sibling = elem.parentNode && elem.parentNode.firstElementChild; if (!sibling) { return []; } // Loop through each sibling and push to the array while (sibling) { if (sibling.nodeType === 1 && sibling !== elem) { siblings.push(sibling); } sibling = sibling.nextElementSibling; } return siblings; }; const appendBtnToElements = (elements, clickHandler, modifyBtn) => { return Array.from(elements).map((codeBlock) => { codeBlock.classList.add("jacks-dev-helpers-interact-target"); codeBlock.innerHTML = `<span class="jacks-dev-helpers-outer-wrap" >${codeBlock.innerHTML}</span>`; const copyBtn = document.createElement("span"); copyBtn.classList.add("jacks-dev-helpers-interact-widget"); copyBtn.addEventListener("click", (event) => { const tmpCodeBlock = codeBlock.cloneNode(true); const children = tmpCodeBlock.children; for (let i = 0; i < children.length; i++) { const childComponent = children[i]; if (childComponent.classList.contains("jacks-dev-helpers-interact-widget")) { tmpCodeBlock.removeChild(childComponent); } } clickHandler(tmpCodeBlock, event); }); modifyBtn(copyBtn); codeBlock.appendChild(copyBtn); return copyBtn; }); }; async function installEsModule(moduleUrl) { const script = document.createElement("script"); script.setAttribute("type", "module"); script.setAttribute("src", moduleUrl); const head = document.head || document.getElementsByTagName("head")[0] || document.documentElement; head.insertBefore(script, head.lastChild); } /***/ }), /***/ "./src/main.ts": /*!*********************!*\ !*** ./src/main.ts ***! \*********************/ /*! no exports provided */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony import */ var _typed_compose__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @typed/compose */ "./node_modules/@typed/compose/lib.es2015/index.js"); /* harmony import */ var userscripter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! userscripter */ "./node_modules/userscripter/lib/index.mjs"); /* harmony import */ var _src_config__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ~src/config */ "./src/config.ts"); /* harmony import */ var _src_operations__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ~src/operations */ "./src/operations.ts"); /* harmony import */ var _src_site__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ~src/site */ "./src/site.ts"); /* harmony import */ var _src_stylesheets__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ~src/stylesheets */ "./src/stylesheets.ts"); /* harmony import */ var _src_userscript__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ~src/userscript */ "./src/userscript.ts"); const describeFailure = userscripter__WEBPACK_IMPORTED_MODULE_1__["errors"].failureDescriber({ siteName: _src_site__WEBPACK_IMPORTED_MODULE_4__["NAME"], extensionName: _src_userscript__WEBPACK_IMPORTED_MODULE_6__["default"].name, location: document.location, }); userscripter__WEBPACK_IMPORTED_MODULE_1__["userscripter"].run({ id: _src_userscript__WEBPACK_IMPORTED_MODULE_6__["default"].id, name: _src_userscript__WEBPACK_IMPORTED_MODULE_6__["default"].name, initialAction: () => userscripter__WEBPACK_IMPORTED_MODULE_1__["log"].log(`${_src_userscript__WEBPACK_IMPORTED_MODULE_6__["default"].name} ${_src_userscript__WEBPACK_IMPORTED_MODULE_6__["default"].version}`), stylesheets: _src_stylesheets__WEBPACK_IMPORTED_MODULE_5__["default"], operationsPlan: { operations: _src_operations__WEBPACK_IMPORTED_MODULE_3__["default"], interval: _src_config__WEBPACK_IMPORTED_MODULE_2__["OPERATIONS_INTERVAL"], tryUntil: userscripter__WEBPACK_IMPORTED_MODULE_1__["environment"].DOMCONTENTLOADED, extraTries: _src_config__WEBPACK_IMPORTED_MODULE_2__["OPERATIONS_EXTRA_TRIES"], handleFailures: failures => failures.forEach(Object(_typed_compose__WEBPACK_IMPORTED_MODULE_0__["compose"])(userscripter__WEBPACK_IMPORTED_MODULE_1__["log"].error, describeFailure)), }, }); /***/ }), /***/ "./src/operations.ts": /*!***************************!*\ !*** ./src/operations.ts ***! \***************************/ /*! exports provided: default */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony import */ var git_url_parse__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! git-url-parse */ "./node_modules/git-url-parse/lib/index.js"); /* harmony import */ var git_url_parse__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(git_url_parse__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var userscripter_lib_environment__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! userscripter/lib/environment */ "./node_modules/userscripter/lib/environment.mjs"); /* harmony import */ var deep_entries__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! deep-entries */ "./node_modules/deep-entries/dist/index.esm.js"); /* harmony import */ var userscripter_lib_operations__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! userscripter/lib/operations */ "./node_modules/userscripter/lib/operations.mjs"); /* harmony import */ var _helpers_utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./helpers/utils */ "./src/helpers/utils.ts"); /* harmony import */ var _helpers_extractTableInfo__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./helpers/extractTableInfo */ "./src/helpers/extractTableInfo.ts"); /* harmony import */ var _helpers_htmlTreeSelection__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./helpers/htmlTreeSelection */ "./src/helpers/htmlTreeSelection.ts"); const OPERATIONS = [ Object(userscripter_lib_operations__WEBPACK_IMPORTED_MODULE_3__["operation"])({ description: "Hacky automate page interaction", condition: userscripter_lib_environment__WEBPACK_IMPORTED_MODULE_1__["ALWAYS"], action: () => { const urlParams = new URLSearchParams(window.location.search); const autoEvalStr = urlParams.get("hackyDangerScript"); if (autoEvalStr === null) return; const autoEvalCmd = atob(autoEvalStr); if (!localStorage.getItem(`hackydanger-allowed-${autoEvalStr}`) && confirm("Ok to run command?")) { localStorage.setItem(`hackydanger-allowed-${autoEvalStr}`, "surethisistottallysafe"); } localStorage.getItem(`hackydanger-allowed-${autoEvalStr}`) && eval(autoEvalCmd); }, }), Object(userscripter_lib_operations__WEBPACK_IMPORTED_MODULE_3__["operation"])({ description: "Provide parse github url", condition: userscripter_lib_environment__WEBPACK_IMPORTED_MODULE_1__["ALWAYS"], action: () => { // @ts-expect-error window.parseGitUrl = git_url_parse__WEBPACK_IMPORTED_MODULE_0___default.a; }, }), Object(userscripter_lib_operations__WEBPACK_IMPORTED_MODULE_3__["operation"])({ description: "Provide helper funcs for surfingkeys", condition: userscripter_lib_environment__WEBPACK_IMPORTED_MODULE_1__["ALWAYS"], action: () => { // @ts-expect-error window.htmlTreeSelection = _helpers_htmlTreeSelection__WEBPACK_IMPORTED_MODULE_6__["htmlTreeSelection"]; }, }), Object(userscripter_lib_operations__WEBPACK_IMPORTED_MODULE_3__["operation"])({ description: "Provide helper funcs for dev console", condition: userscripter_lib_environment__WEBPACK_IMPORTED_MODULE_1__["ALWAYS"], action: () => { const findKeyDeep = (obj, str) => { const flatObj = Object(deep_entries__WEBPACK_IMPORTED_MODULE_2__["deepEntries"])(obj, deep_entries__WEBPACK_IMPORTED_MODULE_2__["delimitEntry"]); return flatObj.filter(([k, _value]) => k.includes(str)); }; // @ts-expect-error window.findKeyDeep = findKeyDeep; }, }), Object(userscripter_lib_operations__WEBPACK_IMPORTED_MODULE_3__["operation"])({ description: "Copy table as json via right click", condition: userscripter_lib_environment__WEBPACK_IMPORTED_MODULE_1__["ALWAYS"], action: () => { let menuActive = false; document.addEventListener("mousemove", function clickListener(event) { const maybeTable = event.target; if (!menuActive && maybeTable instanceof HTMLTableElement) { GM_registerMenuCommand("Copy this table", () => { const tableJson = Object(_helpers_extractTableInfo__WEBPACK_IMPORTED_MODULE_5__["extractTableAsJson"])(maybeTable); Object(_helpers_utils__WEBPACK_IMPORTED_MODULE_4__["addToClipboard"])(JSON.stringify(tableJson, null, 4)); }); } else if (menuActive && !(maybeTable instanceof HTMLTableElement)) { GM_unregisterMenuCommand("Copy this table"); } }); }, }), ]; /* harmony default export */ __webpack_exports__["default"] = (OPERATIONS); /***/ }), /***/ "./src/site.ts": /*!*********************!*\ !*** ./src/site.ts ***! \*********************/ /*! exports provided: NAME, HOSTNAME, SELECTOR_CODE */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "NAME", function() { return NAME; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HOSTNAME", function() { return HOSTNAME; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SELECTOR_CODE", function() { return SELECTOR_CODE; }); /* harmony import */ var _userscript__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./userscript */ "./src/userscript.ts"); // This file cannot contain Webpack-resolved imports (e.g. "~src/foo"). const NAME = _userscript__WEBPACK_IMPORTED_MODULE_0__["default"].sitename; const HOSTNAME = _userscript__WEBPACK_IMPORTED_MODULE_0__["default"].hostname; const SELECTOR_CODE = "code"; /***/ }), /***/ "./src/stylesheets.ts": /*!****************************!*\ !*** ./src/stylesheets.ts ***! \****************************/ /*! exports provided: default */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony import */ var userscripter_lib_environment__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! userscripter/lib/environment */ "./node_modules/userscripter/lib/environment.mjs"); /* harmony import */ var userscripter_lib_stylesheets__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! userscripter/lib/stylesheets */ "./node_modules/userscripter/lib/stylesheets.mjs"); const STYLESHEETS = { general: Object(userscripter_lib_stylesheets__WEBPACK_IMPORTED_MODULE_1__["stylesheet"])({ condition: userscripter_lib_environment__WEBPACK_IMPORTED_MODULE_0__["ALWAYS"], css: ` .jacks-dev-helpers-interact-widget { display: none; top: 0px; right: 0px; padding: 5px 10px; cursor: grab; background: unset; align-self: flex-end; } .jacks-dev-helper-outer-wrap { display: flex } .jacks-dev-helpers-interact-target:hover > .jacks-dev-helpers-interact-widget { display: inline-flex; } .jacks-dev-helpers-interact-widget:hover { text-decoration: underline; } `, }), htmlTreeSelectionOverlay: Object(userscripter_lib_stylesheets__WEBPACK_IMPORTED_MODULE_1__["stylesheet"])({ condition: userscripter_lib_environment__WEBPACK_IMPORTED_MODULE_0__["ALWAYS"], css: ` :root { --html-tree-selection-icon-url: "" } .html-tree-selection-cursor, .html-tree-selection-cursor a, .html-tree-selection-cursor input, .html-tree-selection-cursor select, .html-tree-selection-cursor button, .html-tree-selection-cursor div[role=button] { cursor: var(--html-tree-selection-icon-url), crosshair !important; } .html-tree-selection { filter: opacity(0.2); box-shadow: inset 0px 0px 25px rgba(255,0,0,.5); } .html-tree-selection-overlay { position: absolute; z-index: 2147483647; background: no-repeat center/70% var(--html-tree-selection-icon-url), linear-gradient( rgba(255, 255, 255, 0.85), rgba(255, 255, 255, 0.85) ); } `, }), }; // <span class="w3-badge">9</span> // This trick uncovers type errors in STYLESHEETS while retaining the static knowledge of its properties (so we can still write e.g. STYLESHEETS.foo): const _ = STYLESHEETS; void _; /* harmony default export */ __webpack_exports__["default"] = (STYLESHEETS); /***/ }), /***/ "./src/userscript.ts": /*!***************************!*\ !*** ./src/userscript.ts ***! \***************************/ /*! exports provided: default */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony default export */ __webpack_exports__["default"] = ({ id: "jacks-dev-helpers", name: "Jack's Dev Helpers", version: "0.1.0", author: "Jack McCown", description: "Hodgepodge of dev utils", hostname: "*", namespace: "jackmscripts", sitename: "google.com", runAt: "document-end", }); /***/ }) /******/ }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/bootstrap","webpack:///./node_modules/@typed/compose/lib.es2015/compose.js","webpack:///./node_modules/@typed/compose/lib.es2015/index.js","webpack:///./node_modules/decode-uri-component/index.js","webpack:///./node_modules/deep-entries/dist/index.esm.js","webpack:///./node_modules/filter-obj/index.js","webpack:///./node_modules/git-up/lib/index.js","webpack:///./node_modules/git-url-parse/lib/index.js","webpack:///./node_modules/is-ssh/lib/index.js","webpack:///./node_modules/lines-unlines/dist/index.mjs","webpack:///./node_modules/normalize-url/index.js","webpack:///./node_modules/parse-path/lib/index.js","webpack:///./node_modules/parse-url/lib/index.js","webpack:///./node_modules/protocols/lib/index.js","webpack:///./node_modules/query-string/index.js","webpack:///./node_modules/split-on-first/index.js","webpack:///./node_modules/strict-uri-encode/index.js","webpack:///./node_modules/ts-type-guards/dist/array.mjs","webpack:///./node_modules/ts-type-guards/dist/index.mjs","webpack:///./node_modules/ts-type-guards/dist/is.mjs","webpack:///./node_modules/ts-type-guards/dist/only.mjs","webpack:///./node_modules/userscripter/lib/environment.mjs","webpack:///./node_modules/userscripter/lib/errors.mjs","webpack:///./node_modules/userscripter/lib/index.mjs","webpack:///./node_modules/userscripter/lib/log.mjs","webpack:///./node_modules/userscripter/lib/operations.mjs","webpack:///./node_modules/userscripter/lib/preferences.mjs","webpack:///./node_modules/userscripter/lib/stylesheets.mjs","webpack:///./node_modules/userscripter/lib/userscripter.mjs","webpack:///./src/config.ts","webpack:///./src/helpers/extractTableInfo.ts","webpack:///./src/helpers/htmlTreeSelection.ts","webpack:///./src/helpers/utils.ts","webpack:///./src/main.ts","webpack:///./src/operations.ts","webpack:///./src/site.ts","webpack:///./src/stylesheets.ts","webpack:///./src/userscript.ts"],"names":[],"mappings":";QAAA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;;QAEA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;;;QAGA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA,0CAA0C,gCAAgC;QAC1E;QACA;;QAEA;QACA;QACA;QACA,wDAAwD,kBAAkB;QAC1E;QACA,iDAAiD,cAAc;QAC/D;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA,yCAAyC,iCAAiC;QAC1E,gHAAgH,mBAAmB,EAAE;QACrI;QACA;;QAEA;QACA;QACA;QACA,2BAA2B,0BAA0B,EAAE;QACvD,iCAAiC,eAAe;QAChD;QACA;QACA;;QAEA;QACA,sDAAsD,+DAA+D;;QAErH;QACA;;;QAGA;QACA;;;;;;;;;;;;;AClFA;AAAA;AAAO;AACP;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,mC;;;;;;;;;;;;ACnCA;AAAA;AAAA;AAAA;AAA0B;AAC1B,iC;;;;;;;;;;;;ACDa;AACb,uBAAuB,EAAE;AACzB;AACA;;AAEA;AACA;AACA;AACA;AACA,EAAE;AACF;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,EAAE;AACF;;AAEA,iBAAiB,mBAAmB;AACpC;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA,gBAAgB,oBAAoB;AACpC;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,EAAE;AACF;AACA;AACA;AACA;;;;;;;;;;;;;AC7FA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEsG;;;;;;;;;;;;;AClHzF;AACb;AACA;AACA;AACA;;AAEA,gBAAgB,iBAAiB;AACjC;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;;;;;;;;;;;;AChBa;;AAEb;;AAEA,eAAe,mBAAO,CAAC,wDAAW;AAClC,YAAY,mBAAO,CAAC,kDAAQ;;AAE5B;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,YAAY,OAAO;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;;AAEA,uB;;;;;;;;;;;;ACpDa;;AAEb,YAAY,mBAAO,CAAC,kDAAQ;;AAE5B;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,YAAY,OAAO;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA,kFAAkF;AAClF;AACA;AACA;AACA,8EAA8E;AAC9E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;;AAEA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,YAAY,OAAO;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gHAAgH;AAChH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,YAAY,OAAO;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,6B;;;;;;;;;;;;AC9Ra;;AAEb;AACA,gBAAgB,mBAAO,CAAC,wDAAW;;AAEnC;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,aAAa;AACxB,YAAY,QAAQ;AACpB;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,uB;;;;;;;;;;;;ACnCA;AAAA;AAAA;AAAO;AACP;AACA;AACO;AACP;AACA;AACA,iC;;;;;;;;;;;;ACNa;;AAEb;AACA;AACA;;AAEA;AACA;AACA;;AAEA,sCAAsC,UAAU;AAChD;;AAEA;AACA,kCAAkC,UAAU;AAC5C;;AAEA,MAAM,iBAAiB;AACvB,gCAAgC;AAChC;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,aAAa,IAAI,EAAE,YAAY,MAAM,OAAO;AAC5C,GAAG;AACH;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,gBAAgB,2BAA2B,GAAG,GAAG,8BAA8B,EAAE,WAAW,KAAK,OAAO;AACxG;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,EAAE;AACF;AACA;;AAEA;AACA;AACA,uEAAuE,KAAK,MAAM,GAAG;AACrF;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,uDAAuD,KAAK,iBAAiB,KAAK;AAClF;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;;;;;;;;;;;;ACvNa;;AAEb;AACA,gBAAgB,mBAAO,CAAC,wDAAW;AACnC,YAAY,mBAAO,CAAC,kDAAQ;AAC5B,SAAS,mBAAO,CAAC,0DAAc;;AAE/B;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,YAAY,OAAO;AACnB;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,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,2B;;;;;;;;;;;;ACpIa;;AAEb,oGAAoG,mBAAmB,EAAE,mBAAmB,8HAA8H;;AAE1Q,gBAAgB,mBAAO,CAAC,0DAAY;AACpC,mBAAmB,mBAAO,CAAC,4DAAe;;AAE1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,eAAe;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,OAAO;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,0B;;;;;;;;;;;;ACtDa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,eAAe;AAC1B,YAAY,aAAa;AACzB;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,E;;;;;;;;;;;;AC1Ba;AACb,wBAAwB,mBAAO,CAAC,oEAAmB;AACnD,wBAAwB,mBAAO,CAAC,0EAAsB;AACtD,qBAAqB,mBAAO,CAAC,8DAAgB;AAC7C,qBAAqB,mBAAO,CAAC,sDAAY;;AAEzC;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,EAAE;AACF;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,EAAE;;AAEF;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA,EAAE;AACF;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,EAAE;;AAEF;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,EAAE;AACF;;AAEA;AACA;AACA;AACA,EAAE;;AAEF;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH,wDAAwD,0CAA0C;AAClG;AACA;;AAEA;AACA;AACA;AACA;AACA,EAAE;;AAEF;AACA;AACA,yDAAyD,YAAY;;AAErE;AACA;AACA;AACA,oBAAoB,YAAY;AAChC;;AAEA;AACA;AACA,aAAa,2CAA2C;AACxD;;AAEA,WAAW,IAAI,EAAE,YAAY,EAAE,KAAK;AACpC;;AAEA;AACA;AACA;AACA,EAAE;;AAEF,QAAQ,+BAA+B;AACvC;AACA;AACA;AACA;AACA,EAAE;AACF;;AAEA;AACA;;AAEA;AACA;;;;;;;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;AACA;AACA;AACA,iDAAiD,uBAAuB;AACxE;AACA;AACA,uCAAuC,uBAAuB;AAC9D;AACA;AACA;AACA;AACA;AACA,2DAA2D,+DAAQ;AACnE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0DAA0D;AAC1D;AACA;AACA;AACA,KAAK;AACL,yDAAyD,6DAAM;AAC/D;AACA,gBAAgB;AAChB;AACA,iFAAiF,mBAAmB,KAAK;AACzG;AACA;AACA;AACA,WAAW,+DAAQ,OAAO,wBAAwB;AAClD;;;;;;;;;;;;;ACtDA;AAAA;AAAA;AAAA;AAAA;AAA6B;AACtB;AACP;AACA;AACA,kCAAkC,+BAA+B,EAAE;AACnE,oCAAoC,kCAAkC,EAAE;AACxE;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB,4CAAW,oCAAoC,uBAAuB,KAAK,+BAA+B,mCAAmC,+BAA+B;AAC5L;AACA;AACA;AACA,gBAAgB,4CAAW,wBAAwB,+BAA+B,mBAAmB,uBAAuB;AAC5H;AACA;AACA;AACA;AACA,gBAAgB,4CAAW,oCAAoC,uBAAuB,0CAA0C,+BAA+B;AAC/J;AACA;AACA;AACA;AACA;AACA,gBAAgB,4CAAW,oCAAoC,uBAAuB,2CAA2C,+BAA+B;AAChK;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,0CAAS,+BAA+B,uBAAuB,4DAA4D,2CAA2C;AAC1L;AACA;AACA,oBAAoB,0CAAS,yBAAyB,uCAAuC,mBAAmB,uBAAuB;AACvI;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;;;;;;;;;;;;;AC7DA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACA;;;;;;;;;;;;;ACxBP;AAAA;AAAA;AAAA;AAAA;AAA6B;AACc;AACE;AACtC;AACP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","file":"jacks-dev-helpers.user.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\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\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"./src/main.ts\");\n","export function compose() {\n    switch (arguments.length) {\n        case 1: return _compose1(arguments[0]);\n        case 2: return _compose2(arguments[0], arguments[1]);\n        case 3: return _compose3(arguments[0], arguments[1], arguments[2]);\n        case 4: return _compose4(arguments[0], arguments[1], arguments[2], arguments[3]);\n        case 5: return _compose5(arguments[0], arguments[1], arguments[2], arguments[3], arguments[4]);\n    }\n    ;\n}\nfunction _compose1(f) {\n    return function compose1Fn(a) {\n        return f(a);\n    };\n}\nfunction _compose2(g, f) {\n    return function compose2Fn(a) {\n        return g(f(a));\n    };\n}\nfunction _compose3(h, g, f) {\n    return function compose3Fn(a) {\n        return h(g(f(a)));\n    };\n}\nfunction _compose4(i, h, g, f) {\n    return function compose3Fn(a) {\n        return i(h(g(f(a))));\n    };\n}\nfunction _compose5(j, i, h, g, f) {\n    return function compose5Fn(a) {\n        return j(i(h(g(f(a)))));\n    };\n}\n//# sourceMappingURL=compose.js.map","export * from './compose';\n//# sourceMappingURL=index.js.map","'use strict';\nvar token = '%[a-f0-9]{2}';\nvar singleMatcher = new RegExp(token, 'gi');\nvar multiMatcher = new RegExp('(' + token + ')+', 'gi');\n\nfunction decodeComponents(components, split) {\n\ttry {\n\t\t// Try to decode the entire string first\n\t\treturn decodeURIComponent(components.join(''));\n\t} catch (err) {\n\t\t// Do nothing\n\t}\n\n\tif (components.length === 1) {\n\t\treturn components;\n\t}\n\n\tsplit = split || 1;\n\n\t// Split the array in 2 parts\n\tvar left = components.slice(0, split);\n\tvar right = components.slice(split);\n\n\treturn Array.prototype.concat.call([], decodeComponents(left), decodeComponents(right));\n}\n\nfunction decode(input) {\n\ttry {\n\t\treturn decodeURIComponent(input);\n\t} catch (err) {\n\t\tvar tokens = input.match(singleMatcher);\n\n\t\tfor (var i = 1; i < tokens.length; i++) {\n\t\t\tinput = decodeComponents(tokens, i).join('');\n\n\t\t\ttokens = input.match(singleMatcher);\n\t\t}\n\n\t\treturn input;\n\t}\n}\n\nfunction customDecodeURIComponent(input) {\n\t// Keep track of all the replacements and prefill the map with the `BOM`\n\tvar replaceMap = {\n\t\t'%FE%FF': '\\uFFFD\\uFFFD',\n\t\t'%FF%FE': '\\uFFFD\\uFFFD'\n\t};\n\n\tvar match = multiMatcher.exec(input);\n\twhile (match) {\n\t\ttry {\n\t\t\t// Decode as big chunks as possible\n\t\t\treplaceMap[match[0]] = decodeURIComponent(match[0]);\n\t\t} catch (err) {\n\t\t\tvar result = decode(match[0]);\n\n\t\t\tif (result !== match[0]) {\n\t\t\t\treplaceMap[match[0]] = result;\n\t\t\t}\n\t\t}\n\n\t\tmatch = multiMatcher.exec(input);\n\t}\n\n\t// Add `%C2` at the end of the map to make sure it does not replace the combinator before everything else\n\treplaceMap['%C2'] = '\\uFFFD';\n\n\tvar entries = Object.keys(replaceMap);\n\n\tfor (var i = 0; i < entries.length; i++) {\n\t\t// Replace all decoded components\n\t\tvar key = entries[i];\n\t\tinput = input.replace(new RegExp(key, 'g'), replaceMap[key]);\n\t}\n\n\treturn input;\n}\n\nmodule.exports = function (encodedURI) {\n\tif (typeof encodedURI !== 'string') {\n\t\tthrow new TypeError('Expected `encodedURI` to be of type `string`, got `' + typeof encodedURI + '`');\n\t}\n\n\ttry {\n\t\tencodedURI = encodedURI.replace(/\\+/g, ' ');\n\n\t\t// Try the built in decoder first\n\t\treturn decodeURIComponent(encodedURI);\n\t} catch (err) {\n\t\t// Fallback to a more advanced decoder\n\t\treturn customDecodeURIComponent(encodedURI);\n\t}\n};\n","const identity = x => x;\n\nconst getInterface = x => {\n\tconst str = Object.prototype.toString.call(x);\n\treturn str.substring(8, str.length - 1)\n};\n\nconst isObjectLike = x => {\n\tconst tag = getInterface(x);\n\tswitch (tag) {\n\t\tcase 'String':\n\t\tcase 'Number':\n\t\tcase 'Boolean':\n\t\tcase 'RegExp':\n\t\tcase 'Date':\n\t\t\treturn false\n\n\t\tdefault:\n\t\t\tif (x === null) {\n\t\t\t\treturn false\n\t\t\t}\n\n\t\t\tif (tag.startsWith('HTML')) {\n\t\t\t\treturn false\n\t\t\t}\n\n\t\t\treturn typeof x === 'object'\n\t}\n};\n\nfunction* entriesIterator(input) {\n\tswitch (getInterface(input)) {\n\t\tcase 'Array':\n\t\tcase 'Map':\n\t\tcase 'URLSearchParams':\n\t\t\tyield* input.entries();\n\t\t\tbreak\n\n\t\tcase 'Set':\n\t\tcase 'NodeList':\n\t\tcase 'Int8Array':\n\t\tcase 'Uint8Array':\n\t\tcase 'Uint8ClampedArray':\n\t\tcase 'Int16Array':\n\t\tcase 'Uint16Array':\n\t\tcase 'Int32Array':\n\t\tcase 'Uint32Array':\n\t\tcase 'Float32Array':\n\t\tcase 'Float64Array':\n\t\tcase 'BigInt64Array':\n\t\tcase 'BigUint64Array':\n\t\t\tlet i = 0;\n\t\t\tfor (let value of input) yield [i++, value];\n\t\t\tbreak\n\n\t\tcase 'Object':\n\t\tdefault:\n\t\t\tif (isObjectLike(input))\n\t\t\t\tfor (let key in input)\n\t\t\t\t\tif (Object.prototype.hasOwnProperty.call(input, key))\n\t\t\t\t\t\tyield [key, input[key]];\n\t\t\tbreak\n\t}\n}\n\nfunction* deepEntriesIterator_(input, mapFn, parentCircularSet) {\n\tconst map = typeof mapFn === 'function' ? mapFn : identity;\n\tfor (let [key, value] of entriesIterator(input)) {\n\t\tif (!isObjectLike(value)) {\n\t\t\tconst entry = map([key, value]);\n\t\t\tif (entry !== undefined) yield entry;\n\t\t} else {\n\t\t\tconst circularSet = parentCircularSet || new WeakSet();\n\t\t\tcircularSet.add(input);\n\n\t\t\tif (!circularSet.has(value)) {\n\t\t\t\tfor (let entries of deepEntriesIterator_(\n\t\t\t\t\tvalue,\n\t\t\t\t\tundefined,\n\t\t\t\t\tcircularSet\n\t\t\t\t)) {\n\t\t\t\t\tconst entry = map([key, ...entries]);\n\t\t\t\t\tif (entry !== undefined) yield entry;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n}\n\nfunction* deepEntriesIterator(input, mapFn) {\n\tyield* deepEntriesIterator_(input, mapFn);\n}\n\nconst deepEntries = (input, mapFn) =>\n\tArray.from(deepEntriesIterator(input, mapFn));\n\nconst rotateEntryBy = n => entry => {\n\tif (entry === undefined) return\n\tconst mod = (-1 * (Number(n) || 0)) % entry.length;\n\tconst keys = entry.slice(0, mod);\n\tconst value = entry.slice(mod);\n\treturn [...value, ...keys]\n};\n\nconst rotateEntry = rotateEntryBy(1);\n\nconst delimitEntryBy = delimiter => entry => {\n\tif (entry === undefined) return\n\tconst [value, ...keys] = rotateEntry(entry);\n\treturn [keys.join(delimiter), value]\n};\n\nconst delimitEntry = delimitEntryBy('.');\n\nexport { deepEntries, deepEntriesIterator, delimitEntry, delimitEntryBy, rotateEntry, rotateEntryBy };\n","'use strict';\nmodule.exports = function (obj, predicate) {\n\tvar ret = {};\n\tvar keys = Object.keys(obj);\n\tvar isArr = Array.isArray(predicate);\n\n\tfor (var i = 0; i < keys.length; i++) {\n\t\tvar key = keys[i];\n\t\tvar val = obj[key];\n\n\t\tif (isArr ? predicate.indexOf(key) !== -1 : predicate(key, val, obj)) {\n\t\t\tret[key] = val;\n\t\t}\n\t}\n\n\treturn ret;\n};\n","\"use strict\";\n\n// Dependencies\n\nvar parseUrl = require(\"parse-url\"),\n    isSsh = require(\"is-ssh\");\n\n/**\n * gitUp\n * Parses the input url.\n *\n * @name gitUp\n * @function\n * @param {String} input The input url.\n * @return {Object} An object containing the following fields:\n *\n *  - `protocols` (Array): An array with the url protocols (usually it has one element).\n *  - `port` (null|Number): The domain port.\n *  - `resource` (String): The url domain (including subdomains).\n *  - `user` (String): The authentication user (usually for ssh urls).\n *  - `pathname` (String): The url pathname.\n *  - `hash` (String): The url hash.\n *  - `search` (String): The url querystring value.\n *  - `href` (String): The input url.\n *  - `protocol` (String): The git url protocol.\n *  - `token` (String): The oauth token (could appear in the https urls).\n */\nfunction gitUp(input) {\n    var output = parseUrl(input);\n    output.token = \"\";\n\n    var splits = output.user.split(\":\");\n    if (splits.length === 2) {\n        if (splits[1] === \"x-oauth-basic\") {\n            output.token = splits[0];\n        } else if (splits[0] === \"x-token-auth\") {\n            output.token = splits[1];\n        }\n    }\n\n    if (isSsh(output.protocols) || isSsh(input)) {\n        output.protocol = \"ssh\";\n    } else if (output.protocols.length) {\n        output.protocol = output.protocols[0];\n    } else {\n        output.protocol = \"file\";\n    }\n\n    output.href = output.href.replace(/\\/$/, \"\");\n    return output;\n}\n\nmodule.exports = gitUp;","\"use strict\";\n\nvar gitUp = require(\"git-up\");\n\n/**\n * gitUrlParse\n * Parses a Git url.\n *\n * @name gitUrlParse\n * @function\n * @param {String} url The Git url to parse.\n * @return {GitUrl} The `GitUrl` object containing:\n *\n *  - `protocols` (Array): An array with the url protocols (usually it has one element).\n *  - `port` (null|Number): The domain port.\n *  - `resource` (String): The url domain (including subdomains).\n *  - `user` (String): The authentication user (usually for ssh urls).\n *  - `pathname` (String): The url pathname.\n *  - `hash` (String): The url hash.\n *  - `search` (String): The url querystring value.\n *  - `href` (String): The input url.\n *  - `protocol` (String): The git url protocol.\n *  - `token` (String): The oauth token (could appear in the https urls).\n *  - `source` (String): The Git provider (e.g. `\"github.com\"`).\n *  - `owner` (String): The repository owner.\n *  - `name` (String): The repository name.\n *  - `ref` (String): The repository ref (e.g., \"master\" or \"dev\").\n *  - `filepath` (String): A filepath relative to the repository root.\n *  - `filepathtype` (String): The type of filepath in the url (\"blob\" or \"tree\").\n *  - `full_name` (String): The owner and name values in the `owner/name` format.\n *  - `toString` (Function): A function to stringify the parsed url into another url type.\n *  - `organization` (String): The organization the owner belongs to. This is CloudForge specific.\n *  - `git_suffix` (Boolean): Whether to add the `.git` suffix or not.\n *\n */\nfunction gitUrlParse(url) {\n\n    if (typeof url !== \"string\") {\n        throw new Error(\"The url must be a string.\");\n    }\n\n    var urlInfo = gitUp(url),\n        sourceParts = urlInfo.resource.split(\".\"),\n        splits = null;\n\n    urlInfo.toString = function (type) {\n        return gitUrlParse.stringify(this, type);\n    };\n\n    urlInfo.source = sourceParts.length > 2 ? sourceParts.slice(1 - sourceParts.length).join(\".\") : urlInfo.source = urlInfo.resource;\n\n    // Note: Some hosting services (e.g. Visual Studio Team Services) allow whitespace characters\n    // in the repository and owner names so we decode the URL pieces to get the correct result\n    urlInfo.git_suffix = /\\.git$/.test(urlInfo.pathname);\n    urlInfo.name = decodeURIComponent(urlInfo.pathname.replace(/^\\//, '').replace(/\\.git$/, \"\"));\n    urlInfo.owner = decodeURIComponent(urlInfo.user);\n\n    switch (urlInfo.source) {\n        case \"git.cloudforge.com\":\n            urlInfo.owner = urlInfo.user;\n            urlInfo.organization = sourceParts[0];\n            urlInfo.source = \"cloudforge.com\";\n            break;\n        case \"visualstudio.com\":\n            // Handle VSTS SSH URLs\n            if (urlInfo.resource === 'vs-ssh.visualstudio.com') {\n                splits = urlInfo.name.split(\"/\");\n                if (splits.length === 4) {\n                    urlInfo.organization = splits[1];\n                    urlInfo.owner = splits[2];\n                    urlInfo.name = splits[3];\n                    urlInfo.full_name = splits[2] + '/' + splits[3];\n                }\n                break;\n            } else {\n                splits = urlInfo.name.split(\"/\");\n                if (splits.length === 2) {\n                    urlInfo.owner = splits[1];\n                    urlInfo.name = splits[1];\n                    urlInfo.full_name = '_git/' + urlInfo.name;\n                } else if (splits.length === 3) {\n                    urlInfo.name = splits[2];\n                    if (splits[0] === 'DefaultCollection') {\n                        urlInfo.owner = splits[2];\n                        urlInfo.organization = splits[0];\n                        urlInfo.full_name = urlInfo.organization + '/_git/' + urlInfo.name;\n                    } else {\n                        urlInfo.owner = splits[0];\n                        urlInfo.full_name = urlInfo.owner + '/_git/' + urlInfo.name;\n                    }\n                } else if (splits.length === 4) {\n                    urlInfo.organization = splits[0];\n                    urlInfo.owner = splits[1];\n                    urlInfo.name = splits[3];\n                    urlInfo.full_name = urlInfo.organization + '/' + urlInfo.owner + '/_git/' + urlInfo.name;\n                }\n                break;\n            }\n\n        // Azure DevOps (formerly Visual Studio Team Services)\n        case \"dev.azure.com\":\n        case \"azure.com\":\n            if (urlInfo.resource === 'ssh.dev.azure.com') {\n                splits = urlInfo.name.split(\"/\");\n                if (splits.length === 4) {\n                    urlInfo.organization = splits[1];\n                    urlInfo.owner = splits[2];\n                    urlInfo.name = splits[3];\n                }\n                break;\n            } else {\n                splits = urlInfo.name.split(\"/\");\n                if (splits.length === 5) {\n                    urlInfo.organization = splits[0];\n                    urlInfo.owner = splits[1];\n                    urlInfo.name = splits[4];\n                    urlInfo.full_name = '_git/' + urlInfo.name;\n                } else if (splits.length === 3) {\n                    urlInfo.name = splits[2];\n                    if (splits[0] === 'DefaultCollection') {\n                        urlInfo.owner = splits[2];\n                        urlInfo.organization = splits[0];\n                        urlInfo.full_name = urlInfo.organization + '/_git/' + urlInfo.name;\n                    } else {\n                        urlInfo.owner = splits[0];\n                        urlInfo.full_name = urlInfo.owner + '/_git/' + urlInfo.name;\n                    }\n                } else if (splits.length === 4) {\n                    urlInfo.organization = splits[0];\n                    urlInfo.owner = splits[1];\n                    urlInfo.name = splits[3];\n                    urlInfo.full_name = urlInfo.organization + '/' + urlInfo.owner + '/_git/' + urlInfo.name;\n                }\n                if (urlInfo.query && urlInfo.query['path']) {\n                    urlInfo.filepath = urlInfo.query['path'].replace(/^\\/+/g, ''); // Strip leading slash (/)\n                }\n                if (urlInfo.query && urlInfo.query['version']) {\n                    // version=GB<branch>\n                    urlInfo.ref = urlInfo.query['version'].replace(/^GB/, ''); // remove GB\n                }\n                break;\n            }\n        default:\n            splits = urlInfo.name.split(\"/\");\n            var nameIndex = splits.length - 1;\n            if (splits.length >= 2) {\n                var dashIndex = splits.indexOf(\"-\", 2);\n                var blobIndex = splits.indexOf(\"blob\", 2);\n                var treeIndex = splits.indexOf(\"tree\", 2);\n                var commitIndex = splits.indexOf(\"commit\", 2);\n                var srcIndex = splits.indexOf(\"src\", 2);\n                var rawIndex = splits.indexOf(\"raw\", 2);\n                nameIndex = dashIndex > 0 ? dashIndex - 1 : blobIndex > 0 ? blobIndex - 1 : treeIndex > 0 ? treeIndex - 1 : commitIndex > 0 ? commitIndex - 1 : srcIndex > 0 ? srcIndex - 1 : rawIndex > 0 ? rawIndex - 1 : nameIndex;\n\n                urlInfo.owner = splits.slice(0, nameIndex).join('/');\n                urlInfo.name = splits[nameIndex];\n                if (commitIndex) {\n                    urlInfo.commit = splits[nameIndex + 2];\n                }\n            }\n\n            urlInfo.ref = \"\";\n            urlInfo.filepathtype = \"\";\n            urlInfo.filepath = \"\";\n            var offsetNameIndex = splits.length > nameIndex && splits[nameIndex + 1] === \"-\" ? nameIndex + 1 : nameIndex;\n            if (splits.length > offsetNameIndex + 2 && [\"raw\", \"src\", \"blob\", \"tree\"].indexOf(splits[offsetNameIndex + 1]) >= 0) {\n                urlInfo.filepathtype = splits[offsetNameIndex + 1];\n                urlInfo.ref = splits[offsetNameIndex + 2];\n                if (splits.length > offsetNameIndex + 3) {\n                    urlInfo.filepath = splits.slice(offsetNameIndex + 3).join('/');\n                }\n            }\n            urlInfo.organization = urlInfo.owner;\n            break;\n    }\n\n    if (!urlInfo.full_name) {\n        urlInfo.full_name = urlInfo.owner;\n        if (urlInfo.name) {\n            urlInfo.full_name && (urlInfo.full_name += \"/\");\n            urlInfo.full_name += urlInfo.name;\n        }\n    }\n    // Bitbucket Server\n    if (urlInfo.owner.startsWith(\"scm/\")) {\n        urlInfo.source = \"bitbucket-server\";\n        urlInfo.owner = urlInfo.owner.replace(\"scm/\", \"\");\n        urlInfo.organization = urlInfo.owner;\n        urlInfo.full_name = urlInfo.owner + \"/\" + urlInfo.name;\n    }\n\n    var bitbucket = /(projects|users)\\/(.*?)\\/repos\\/(.*?)((\\/.*$)|$)/;\n    var matches = bitbucket.exec(urlInfo.pathname);\n    if (matches != null) {\n        urlInfo.source = \"bitbucket-server\";\n        if (matches[1] === \"users\") {\n            urlInfo.owner = \"~\" + matches[2];\n        } else {\n            urlInfo.owner = matches[2];\n        }\n\n        urlInfo.organization = urlInfo.owner;\n        urlInfo.name = matches[3];\n\n        splits = matches[4].split(\"/\");\n        if (splits.length > 1) {\n            if ([\"raw\", \"browse\"].indexOf(splits[1]) >= 0) {\n                urlInfo.filepathtype = splits[1];\n                if (splits.length > 2) {\n                    urlInfo.filepath = splits.slice(2).join('/');\n                }\n            } else if (splits[1] === \"commits\" && splits.length > 2) {\n                urlInfo.commit = splits[2];\n            }\n        }\n        urlInfo.full_name = urlInfo.owner + \"/\" + urlInfo.name;\n\n        if (urlInfo.query.at) {\n            urlInfo.ref = urlInfo.query.at;\n        } else {\n            urlInfo.ref = \"\";\n        }\n    }\n    return urlInfo;\n}\n\n/**\n * stringify\n * Stringifies a `GitUrl` object.\n *\n * @name stringify\n * @function\n * @param {GitUrl} obj The parsed Git url object.\n * @param {String} type The type of the stringified url (default `obj.protocol`).\n * @return {String} The stringified url.\n */\ngitUrlParse.stringify = function (obj, type) {\n    type = type || (obj.protocols && obj.protocols.length ? obj.protocols.join('+') : obj.protocol);\n    var port = obj.port ? \":\" + obj.port : '';\n    var user = obj.user || 'git';\n    var maybeGitSuffix = obj.git_suffix ? \".git\" : \"\";\n    switch (type) {\n        case \"ssh\":\n            if (port) return \"ssh://\" + user + \"@\" + obj.resource + port + \"/\" + obj.full_name + maybeGitSuffix;else return user + \"@\" + obj.resource + \":\" + obj.full_name + maybeGitSuffix;\n        case \"git+ssh\":\n        case \"ssh+git\":\n        case \"ftp\":\n        case \"ftps\":\n            return type + \"://\" + user + \"@\" + obj.resource + port + \"/\" + obj.full_name + maybeGitSuffix;\n        case \"http\":\n        case \"https\":\n            var auth = obj.token ? buildToken(obj) : obj.user && (obj.protocols.includes('http') || obj.protocols.includes('https')) ? obj.user + \"@\" : \"\";\n            return type + \"://\" + auth + obj.resource + port + \"/\" + buildPath(obj) + maybeGitSuffix;\n        default:\n            return obj.href;\n    }\n};\n\n/*!\n * buildToken\n * Builds OAuth token prefix (helper function)\n *\n * @name buildToken\n * @function\n * @param {GitUrl} obj The parsed Git url object.\n * @return {String} token prefix\n */\nfunction buildToken(obj) {\n    switch (obj.source) {\n        case \"bitbucket.org\":\n            return \"x-token-auth:\" + obj.token + \"@\";\n        default:\n            return obj.token + \"@\";\n    }\n}\n\nfunction buildPath(obj) {\n    switch (obj.source) {\n        case \"bitbucket-server\":\n            return \"scm/\" + obj.full_name;\n        default:\n            return \"\" + obj.full_name;\n\n    }\n}\n\nmodule.exports = gitUrlParse;","\"use strict\";\n\n// Dependencies\nvar protocols = require(\"protocols\");\n\n/**\n * isSsh\n * Checks if an input value is a ssh url or not.\n *\n * @name isSsh\n * @function\n * @param {String|Array} input The input url or an array of protocols.\n * @return {Boolean} `true` if the input is a ssh url, `false` otherwise.\n */\nfunction isSsh(input) {\n\n    if (Array.isArray(input)) {\n        return input.indexOf(\"ssh\") !== -1 || input.indexOf(\"rsync\") !== -1;\n    }\n\n    if (typeof input !== \"string\") {\n        return false;\n    }\n\n    var prots = protocols(input);\n    input = input.substring(input.indexOf(\"://\") + 3);\n    if (isSsh(prots)) {\n        return true;\n    }\n\n    // TODO This probably could be improved :)\n    var urlPortPattern = new RegExp('\\.([a-zA-Z\\\\d]+):(\\\\d+)\\/');\n    return !input.match(urlPortPattern) && input.indexOf(\"@\") < input.indexOf(\":\");\n}\n\nmodule.exports = isSsh;","export function lines(s) {\n    return s === \"\" ? [] : s.replace(/\\n$/, \"\").split(\"\\n\");\n}\nexport function unlines(ls) {\n    return ls.map(line => line + \"\\n\").join(\"\");\n}\n//# sourceMappingURL=index.js.map","'use strict';\n\n// https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs\nconst DATA_URL_DEFAULT_MIME_TYPE = 'text/plain';\nconst DATA_URL_DEFAULT_CHARSET = 'us-ascii';\n\nconst testParameter = (name, filters) => {\n\treturn filters.some(filter => filter instanceof RegExp ? filter.test(name) : filter === name);\n};\n\nconst normalizeDataURL = (urlString, {stripHash}) => {\n\tconst match = /^data:(?<type>[^,]*?),(?<data>[^#]*?)(?:#(?<hash>.*))?$/.exec(urlString);\n\n\tif (!match) {\n\t\tthrow new Error(`Invalid URL: ${urlString}`);\n\t}\n\n\tlet {type, data, hash} = match.groups;\n\tconst mediaType = type.split(';');\n\thash = stripHash ? '' : hash;\n\n\tlet isBase64 = false;\n\tif (mediaType[mediaType.length - 1] === 'base64') {\n\t\tmediaType.pop();\n\t\tisBase64 = true;\n\t}\n\n\t// Lowercase MIME type\n\tconst mimeType = (mediaType.shift() || '').toLowerCase();\n\tconst attributes = mediaType\n\t\t.map(attribute => {\n\t\t\tlet [key, value = ''] = attribute.split('=').map(string => string.trim());\n\n\t\t\t// Lowercase `charset`\n\t\t\tif (key === 'charset') {\n\t\t\t\tvalue = value.toLowerCase();\n\n\t\t\t\tif (value === DATA_URL_DEFAULT_CHARSET) {\n\t\t\t\t\treturn '';\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn `${key}${value ? `=${value}` : ''}`;\n\t\t})\n\t\t.filter(Boolean);\n\n\tconst normalizedMediaType = [\n\t\t...attributes\n\t];\n\n\tif (isBase64) {\n\t\tnormalizedMediaType.push('base64');\n\t}\n\n\tif (normalizedMediaType.length !== 0 || (mimeType && mimeType !== DATA_URL_DEFAULT_MIME_TYPE)) {\n\t\tnormalizedMediaType.unshift(mimeType);\n\t}\n\n\treturn `data:${normalizedMediaType.join(';')},${isBase64 ? data.trim() : data}${hash ? `#${hash}` : ''}`;\n};\n\nconst normalizeUrl = (urlString, options) => {\n\toptions = {\n\t\tdefaultProtocol: 'http:',\n\t\tnormalizeProtocol: true,\n\t\tforceHttp: false,\n\t\tforceHttps: false,\n\t\tstripAuthentication: true,\n\t\tstripHash: false,\n\t\tstripTextFragment: true,\n\t\tstripWWW: true,\n\t\tremoveQueryParameters: [/^utm_\\w+/i],\n\t\tremoveTrailingSlash: true,\n\t\tremoveSingleSlash: true,\n\t\tremoveDirectoryIndex: false,\n\t\tsortQueryParameters: true,\n\t\t...options\n\t};\n\n\turlString = urlString.trim();\n\n\t// Data URL\n\tif (/^data:/i.test(urlString)) {\n\t\treturn normalizeDataURL(urlString, options);\n\t}\n\n\tif (/^view-source:/i.test(urlString)) {\n\t\tthrow new Error('`view-source:` is not supported as it is a non-standard protocol');\n\t}\n\n\tconst hasRelativeProtocol = urlString.startsWith('//');\n\tconst isRelativeUrl = !hasRelativeProtocol && /^\\.*\\//.test(urlString);\n\n\t// Prepend protocol\n\tif (!isRelativeUrl) {\n\t\turlString = urlString.replace(/^(?!(?:\\w+:)?\\/\\/)|^\\/\\//, options.defaultProtocol);\n\t}\n\n\tconst urlObj = new URL(urlString);\n\n\tif (options.forceHttp && options.forceHttps) {\n\t\tthrow new Error('The `forceHttp` and `forceHttps` options cannot be used together');\n\t}\n\n\tif (options.forceHttp && urlObj.protocol === 'https:') {\n\t\turlObj.protocol = 'http:';\n\t}\n\n\tif (options.forceHttps && urlObj.protocol === 'http:') {\n\t\turlObj.protocol = 'https:';\n\t}\n\n\t// Remove auth\n\tif (options.stripAuthentication) {\n\t\turlObj.username = '';\n\t\turlObj.password = '';\n\t}\n\n\t// Remove hash\n\tif (options.stripHash) {\n\t\turlObj.hash = '';\n\t} else if (options.stripTextFragment) {\n\t\turlObj.hash = urlObj.hash.replace(/#?:~:text.*?$/i, '');\n\t}\n\n\t// Remove duplicate slashes if not preceded by a protocol\n\tif (urlObj.pathname) {\n\t\turlObj.pathname = urlObj.pathname.replace(/(?<!\\b(?:[a-z][a-z\\d+\\-.]{1,50}:))\\/{2,}/g, '/');\n\t}\n\n\t// Decode URI octets\n\tif (urlObj.pathname) {\n\t\ttry {\n\t\t\turlObj.pathname = decodeURI(urlObj.pathname);\n\t\t} catch (_) {}\n\t}\n\n\t// Remove directory index\n\tif (options.removeDirectoryIndex === true) {\n\t\toptions.removeDirectoryIndex = [/^index\\.[a-z]+$/];\n\t}\n\n\tif (Array.isArray(options.removeDirectoryIndex) && options.removeDirectoryIndex.length > 0) {\n\t\tlet pathComponents = urlObj.pathname.split('/');\n\t\tconst lastComponent = pathComponents[pathComponents.length - 1];\n\n\t\tif (testParameter(lastComponent, options.removeDirectoryIndex)) {\n\t\t\tpathComponents = pathComponents.slice(0, pathComponents.length - 1);\n\t\t\turlObj.pathname = pathComponents.slice(1).join('/') + '/';\n\t\t}\n\t}\n\n\tif (urlObj.hostname) {\n\t\t// Remove trailing dot\n\t\turlObj.hostname = urlObj.hostname.replace(/\\.$/, '');\n\n\t\t// Remove `www.`\n\t\tif (options.stripWWW && /^www\\.(?!www\\.)(?:[a-z\\-\\d]{1,63})\\.(?:[a-z.\\-\\d]{2,63})$/.test(urlObj.hostname)) {\n\t\t\t// Each label should be max 63 at length (min: 1).\n\t\t\t// Source: https://en.wikipedia.org/wiki/Hostname#Restrictions_on_valid_host_names\n\t\t\t// Each TLD should be up to 63 characters long (min: 2).\n\t\t\t// It is technically possible to have a single character TLD, but none currently exist.\n\t\t\turlObj.hostname = urlObj.hostname.replace(/^www\\./, '');\n\t\t}\n\t}\n\n\t// Remove query unwanted parameters\n\tif (Array.isArray(options.removeQueryParameters)) {\n\t\tfor (const key of [...urlObj.searchParams.keys()]) {\n\t\t\tif (testParameter(key, options.removeQueryParameters)) {\n\t\t\t\turlObj.searchParams.delete(key);\n\t\t\t}\n\t\t}\n\t}\n\n\tif (options.removeQueryParameters === true) {\n\t\turlObj.search = '';\n\t}\n\n\t// Sort query parameters\n\tif (options.sortQueryParameters) {\n\t\turlObj.searchParams.sort();\n\t}\n\n\tif (options.removeTrailingSlash) {\n\t\turlObj.pathname = urlObj.pathname.replace(/\\/$/, '');\n\t}\n\n\tconst oldUrlString = urlString;\n\n\t// Take advantage of many of the Node `url` normalizations\n\turlString = urlObj.toString();\n\n\tif (!options.removeSingleSlash && urlObj.pathname === '/' && !oldUrlString.endsWith('/') && urlObj.hash === '') {\n\t\turlString = urlString.replace(/\\/$/, '');\n\t}\n\n\t// Remove ending `/` unless removeSingleSlash is false\n\tif ((options.removeTrailingSlash || urlObj.pathname === '/') && urlObj.hash === '' && options.removeSingleSlash) {\n\t\turlString = urlString.replace(/\\/$/, '');\n\t}\n\n\t// Restore relative protocol, if applicable\n\tif (hasRelativeProtocol && !options.normalizeProtocol) {\n\t\turlString = urlString.replace(/^http:\\/\\//, '//');\n\t}\n\n\t// Remove http/https\n\tif (options.stripProtocol) {\n\t\turlString = urlString.replace(/^(?:https?:)?\\/\\//, '');\n\t}\n\n\treturn urlString;\n};\n\nmodule.exports = normalizeUrl;\n","\"use strict\";\n\n// Dependencies\nvar protocols = require(\"protocols\"),\n    isSsh = require(\"is-ssh\"),\n    qs = require(\"query-string\");\n\n/**\n * parsePath\n * Parses the input url.\n *\n * @name parsePath\n * @function\n * @param {String} url The input url.\n * @return {Object} An object containing the following fields:\n *\n *  - `protocols` (Array): An array with the url protocols (usually it has one element).\n *  - `protocol` (String): The first protocol, `\"ssh\"` (if the url is a ssh url) or `\"file\"`.\n *  - `port` (null|Number): The domain port.\n *  - `resource` (String): The url domain (including subdomains).\n *  - `user` (String): The authentication user (usually for ssh urls).\n *  - `pathname` (String): The url pathname.\n *  - `hash` (String): The url hash.\n *  - `search` (String): The url querystring value.\n *  - `href` (String): The input url.\n *  - `query` (Object): The url querystring, parsed as object.\n */\nfunction parsePath(url) {\n    url = (url || \"\").trim();\n    var output = {\n        protocols: protocols(url),\n        protocol: null,\n        port: null,\n        resource: \"\",\n        user: \"\",\n        pathname: \"\",\n        hash: \"\",\n        search: \"\",\n        href: url,\n        query: Object.create(null)\n    },\n        protocolIndex = url.indexOf(\"://\"),\n        resourceIndex = -1,\n        splits = null,\n        parts = null;\n\n    if (url.startsWith(\".\")) {\n        if (url.startsWith(\"./\")) {\n            url = url.substring(2);\n        }\n        output.pathname = url;\n        output.protocol = \"file\";\n    }\n\n    var firstChar = url.charAt(1);\n    if (!output.protocol) {\n        output.protocol = output.protocols[0];\n        if (!output.protocol) {\n            if (isSsh(url)) {\n                output.protocol = \"ssh\";\n            } else if (firstChar === \"/\" || firstChar === \"~\") {\n                url = url.substring(2);\n                output.protocol = \"file\";\n            } else {\n                output.protocol = \"file\";\n            }\n        }\n    }\n\n    if (protocolIndex !== -1) {\n        url = url.substring(protocolIndex + 3);\n    }\n\n    parts = url.split(/\\/|\\\\/);\n    if (output.protocol !== \"file\") {\n        output.resource = parts.shift();\n    } else {\n        output.resource = \"\";\n    }\n\n    // user@domain\n    splits = output.resource.split(\"@\");\n    if (splits.length === 2) {\n        output.user = splits[0];\n        output.resource = splits[1];\n    }\n\n    // domain.com:port\n    splits = output.resource.split(\":\");\n    if (splits.length === 2) {\n        output.resource = splits[0];\n        if (splits[1]) {\n            output.port = Number(splits[1]);\n            if (isNaN(output.port)) {\n                output.port = null;\n                parts.unshift(splits[1]);\n            }\n        } else {\n            output.port = null;\n        }\n    }\n\n    // Remove empty elements\n    parts = parts.filter(Boolean);\n\n    // Stringify the pathname\n    if (output.protocol === \"file\") {\n        output.pathname = output.href;\n    } else {\n        output.pathname = output.pathname || (output.protocol !== \"file\" || output.href[0] === \"/\" ? \"/\" : \"\") + parts.join(\"/\");\n    }\n\n    // #some-hash\n    splits = output.pathname.split(\"#\");\n    if (splits.length === 2) {\n        output.pathname = splits[0];\n        output.hash = splits[1];\n    }\n\n    // ?foo=bar\n    splits = output.pathname.split(\"?\");\n    if (splits.length === 2) {\n        output.pathname = splits[0];\n        output.search = splits[1];\n    }\n\n    output.query = qs.parse(output.search);\n    output.href = output.href.replace(/\\/$/, \"\");\n    output.pathname = output.pathname.replace(/\\/$/, \"\");\n    return output;\n}\n\nmodule.exports = parsePath;","\"use strict\";\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 parsePath = require(\"parse-path\"),\n    normalizeUrl = require(\"normalize-url\");\n\n/**\n * parseUrl\n * Parses the input url.\n *\n * **Note**: This *throws* if invalid urls are provided.\n *\n * @name parseUrl\n * @function\n * @param {String} url The input url.\n * @param {Boolean|Object} normalize Wheter to normalize the url or not.\n *                         Default is `false`. If `true`, the url will\n *                         be normalized. If an object, it will be the\n *                         options object sent to [`normalize-url`](https://github.com/sindresorhus/normalize-url).\n *\n *                         For SSH urls, normalize won't work.\n *\n * @return {Object} An object containing the following fields:\n *\n *  - `protocols` (Array): An array with the url protocols (usually it has one element).\n *  - `protocol` (String): The first protocol, `\"ssh\"` (if the url is a ssh url) or `\"file\"`.\n *  - `port` (null|Number): The domain port.\n *  - `resource` (String): The url domain (including subdomains).\n *  - `user` (String): The authentication user (usually for ssh urls).\n *  - `pathname` (String): The url pathname.\n *  - `hash` (String): The url hash.\n *  - `search` (String): The url querystring value.\n *  - `href` (String): The input url.\n *  - `query` (Object): The url querystring, parsed as object.\n */\nfunction parseUrl(url) {\n    var normalize = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n\n    if (typeof url !== \"string\" || !url.trim()) {\n        throw new Error(\"Invalid url.\");\n    }\n    if (normalize) {\n        if ((typeof normalize === \"undefined\" ? \"undefined\" : _typeof(normalize)) !== \"object\") {\n            normalize = {\n                stripHash: false\n            };\n        }\n        url = normalizeUrl(url, normalize);\n    }\n    var parsed = parsePath(url);\n    return parsed;\n}\n\nmodule.exports = parseUrl;","\"use strict\";\n\n/**\n * protocols\n * Returns the protocols of an input url.\n *\n * @name protocols\n * @function\n * @param {String} input The input url.\n * @param {Boolean|Number} first If `true`, the first protocol will be returned. If number, it will represent the zero-based index of the protocols array.\n * @return {Array|String} The array of protocols or the specified protocol.\n */\nmodule.exports = function protocols(input, first) {\n\n    if (first === true) {\n        first = 0;\n    }\n\n    var index = input.indexOf(\"://\"),\n        splits = input.substring(0, index).split(\"+\").filter(Boolean);\n\n    if (typeof first === \"number\") {\n        return splits[first];\n    }\n\n    return splits;\n};","'use strict';\nconst strictUriEncode = require('strict-uri-encode');\nconst decodeComponent = require('decode-uri-component');\nconst splitOnFirst = require('split-on-first');\nconst filterObject = require('filter-obj');\n\nconst isNullOrUndefined = value => value === null || value === undefined;\n\nfunction encoderForArrayFormat(options) {\n\tswitch (options.arrayFormat) {\n\t\tcase 'index':\n\t\t\treturn key => (result, value) => {\n\t\t\t\tconst index = result.length;\n\n\t\t\t\tif (\n\t\t\t\t\tvalue === undefined ||\n\t\t\t\t\t(options.skipNull && value === null) ||\n\t\t\t\t\t(options.skipEmptyString && value === '')\n\t\t\t\t) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\tif (value === null) {\n\t\t\t\t\treturn [...result, [encode(key, options), '[', index, ']'].join('')];\n\t\t\t\t}\n\n\t\t\t\treturn [\n\t\t\t\t\t...result,\n\t\t\t\t\t[encode(key, options), '[', encode(index, options), ']=', encode(value, options)].join('')\n\t\t\t\t];\n\t\t\t};\n\n\t\tcase 'bracket':\n\t\t\treturn key => (result, value) => {\n\t\t\t\tif (\n\t\t\t\t\tvalue === undefined ||\n\t\t\t\t\t(options.skipNull && value === null) ||\n\t\t\t\t\t(options.skipEmptyString && value === '')\n\t\t\t\t) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\tif (value === null) {\n\t\t\t\t\treturn [...result, [encode(key, options), '[]'].join('')];\n\t\t\t\t}\n\n\t\t\t\treturn [...result, [encode(key, options), '[]=', encode(value, options)].join('')];\n\t\t\t};\n\n\t\tcase 'comma':\n\t\tcase 'separator':\n\t\t\treturn key => (result, value) => {\n\t\t\t\tif (value === null || value === undefined || value.length === 0) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\tif (result.length === 0) {\n\t\t\t\t\treturn [[encode(key, options), '=', encode(value, options)].join('')];\n\t\t\t\t}\n\n\t\t\t\treturn [[result, encode(value, options)].join(options.arrayFormatSeparator)];\n\t\t\t};\n\n\t\tdefault:\n\t\t\treturn key => (result, value) => {\n\t\t\t\tif (\n\t\t\t\t\tvalue === undefined ||\n\t\t\t\t\t(options.skipNull && value === null) ||\n\t\t\t\t\t(options.skipEmptyString && value === '')\n\t\t\t\t) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\tif (value === null) {\n\t\t\t\t\treturn [...result, encode(key, options)];\n\t\t\t\t}\n\n\t\t\t\treturn [...result, [encode(key, options), '=', encode(value, options)].join('')];\n\t\t\t};\n\t}\n}\n\nfunction parserForArrayFormat(options) {\n\tlet result;\n\n\tswitch (options.arrayFormat) {\n\t\tcase 'index':\n\t\t\treturn (key, value, accumulator) => {\n\t\t\t\tresult = /\\[(\\d*)\\]$/.exec(key);\n\n\t\t\t\tkey = key.replace(/\\[\\d*\\]$/, '');\n\n\t\t\t\tif (!result) {\n\t\t\t\t\taccumulator[key] = value;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (accumulator[key] === undefined) {\n\t\t\t\t\taccumulator[key] = {};\n\t\t\t\t}\n\n\t\t\t\taccumulator[key][result[1]] = value;\n\t\t\t};\n\n\t\tcase 'bracket':\n\t\t\treturn (key, value, accumulator) => {\n\t\t\t\tresult = /(\\[\\])$/.exec(key);\n\t\t\t\tkey = key.replace(/\\[\\]$/, '');\n\n\t\t\t\tif (!result) {\n\t\t\t\t\taccumulator[key] = value;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (accumulator[key] === undefined) {\n\t\t\t\t\taccumulator[key] = [value];\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\taccumulator[key] = [].concat(accumulator[key], value);\n\t\t\t};\n\n\t\tcase 'comma':\n\t\tcase 'separator':\n\t\t\treturn (key, value, accumulator) => {\n\t\t\t\tconst isArray = typeof value === 'string' && value.includes(options.arrayFormatSeparator);\n\t\t\t\tconst isEncodedArray = (typeof value === 'string' && !isArray && decode(value, options).includes(options.arrayFormatSeparator));\n\t\t\t\tvalue = isEncodedArray ? decode(value, options) : value;\n\t\t\t\tconst newValue = isArray || isEncodedArray ? value.split(options.arrayFormatSeparator).map(item => decode(item, options)) : value === null ? value : decode(value, options);\n\t\t\t\taccumulator[key] = newValue;\n\t\t\t};\n\n\t\tdefault:\n\t\t\treturn (key, value, accumulator) => {\n\t\t\t\tif (accumulator[key] === undefined) {\n\t\t\t\t\taccumulator[key] = value;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\taccumulator[key] = [].concat(accumulator[key], value);\n\t\t\t};\n\t}\n}\n\nfunction validateArrayFormatSeparator(value) {\n\tif (typeof value !== 'string' || value.length !== 1) {\n\t\tthrow new TypeError('arrayFormatSeparator must be single character string');\n\t}\n}\n\nfunction encode(value, options) {\n\tif (options.encode) {\n\t\treturn options.strict ? strictUriEncode(value) : encodeURIComponent(value);\n\t}\n\n\treturn value;\n}\n\nfunction decode(value, options) {\n\tif (options.decode) {\n\t\treturn decodeComponent(value);\n\t}\n\n\treturn value;\n}\n\nfunction keysSorter(input) {\n\tif (Array.isArray(input)) {\n\t\treturn input.sort();\n\t}\n\n\tif (typeof input === 'object') {\n\t\treturn keysSorter(Object.keys(input))\n\t\t\t.sort((a, b) => Number(a) - Number(b))\n\t\t\t.map(key => input[key]);\n\t}\n\n\treturn input;\n}\n\nfunction removeHash(input) {\n\tconst hashStart = input.indexOf('#');\n\tif (hashStart !== -1) {\n\t\tinput = input.slice(0, hashStart);\n\t}\n\n\treturn input;\n}\n\nfunction getHash(url) {\n\tlet hash = '';\n\tconst hashStart = url.indexOf('#');\n\tif (hashStart !== -1) {\n\t\thash = url.slice(hashStart);\n\t}\n\n\treturn hash;\n}\n\nfunction extract(input) {\n\tinput = removeHash(input);\n\tconst queryStart = input.indexOf('?');\n\tif (queryStart === -1) {\n\t\treturn '';\n\t}\n\n\treturn input.slice(queryStart + 1);\n}\n\nfunction parseValue(value, options) {\n\tif (options.parseNumbers && !Number.isNaN(Number(value)) && (typeof value === 'string' && value.trim() !== '')) {\n\t\tvalue = Number(value);\n\t} else if (options.parseBooleans && value !== null && (value.toLowerCase() === 'true' || value.toLowerCase() === 'false')) {\n\t\tvalue = value.toLowerCase() === 'true';\n\t}\n\n\treturn value;\n}\n\nfunction parse(query, options) {\n\toptions = Object.assign({\n\t\tdecode: true,\n\t\tsort: true,\n\t\tarrayFormat: 'none',\n\t\tarrayFormatSeparator: ',',\n\t\tparseNumbers: false,\n\t\tparseBooleans: false\n\t}, options);\n\n\tvalidateArrayFormatSeparator(options.arrayFormatSeparator);\n\n\tconst formatter = parserForArrayFormat(options);\n\n\t// Create an object with no prototype\n\tconst ret = Object.create(null);\n\n\tif (typeof query !== 'string') {\n\t\treturn ret;\n\t}\n\n\tquery = query.trim().replace(/^[?#&]/, '');\n\n\tif (!query) {\n\t\treturn ret;\n\t}\n\n\tfor (const param of query.split('&')) {\n\t\tif (param === '') {\n\t\t\tcontinue;\n\t\t}\n\n\t\tlet [key, value] = splitOnFirst(options.decode ? param.replace(/\\+/g, ' ') : param, '=');\n\n\t\t// Missing `=` should be `null`:\n\t\t// http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters\n\t\tvalue = value === undefined ? null : ['comma', 'separator'].includes(options.arrayFormat) ? value : decode(value, options);\n\t\tformatter(decode(key, options), value, ret);\n\t}\n\n\tfor (const key of Object.keys(ret)) {\n\t\tconst value = ret[key];\n\t\tif (typeof value === 'object' && value !== null) {\n\t\t\tfor (const k of Object.keys(value)) {\n\t\t\t\tvalue[k] = parseValue(value[k], options);\n\t\t\t}\n\t\t} else {\n\t\t\tret[key] = parseValue(value, options);\n\t\t}\n\t}\n\n\tif (options.sort === false) {\n\t\treturn ret;\n\t}\n\n\treturn (options.sort === true ? Object.keys(ret).sort() : Object.keys(ret).sort(options.sort)).reduce((result, key) => {\n\t\tconst value = ret[key];\n\t\tif (Boolean(value) && typeof value === 'object' && !Array.isArray(value)) {\n\t\t\t// Sort object keys, not values\n\t\t\tresult[key] = keysSorter(value);\n\t\t} else {\n\t\t\tresult[key] = value;\n\t\t}\n\n\t\treturn result;\n\t}, Object.create(null));\n}\n\nexports.extract = extract;\nexports.parse = parse;\n\nexports.stringify = (object, options) => {\n\tif (!object) {\n\t\treturn '';\n\t}\n\n\toptions = Object.assign({\n\t\tencode: true,\n\t\tstrict: true,\n\t\tarrayFormat: 'none',\n\t\tarrayFormatSeparator: ','\n\t}, options);\n\n\tvalidateArrayFormatSeparator(options.arrayFormatSeparator);\n\n\tconst shouldFilter = key => (\n\t\t(options.skipNull && isNullOrUndefined(object[key])) ||\n\t\t(options.skipEmptyString && object[key] === '')\n\t);\n\n\tconst formatter = encoderForArrayFormat(options);\n\n\tconst objectCopy = {};\n\n\tfor (const key of Object.keys(object)) {\n\t\tif (!shouldFilter(key)) {\n\t\t\tobjectCopy[key] = object[key];\n\t\t}\n\t}\n\n\tconst keys = Object.keys(objectCopy);\n\n\tif (options.sort !== false) {\n\t\tkeys.sort(options.sort);\n\t}\n\n\treturn keys.map(key => {\n\t\tconst value = object[key];\n\n\t\tif (value === undefined) {\n\t\t\treturn '';\n\t\t}\n\n\t\tif (value === null) {\n\t\t\treturn encode(key, options);\n\t\t}\n\n\t\tif (Array.isArray(value)) {\n\t\t\treturn value\n\t\t\t\t.reduce(formatter(key), [])\n\t\t\t\t.join('&');\n\t\t}\n\n\t\treturn encode(key, options) + '=' + encode(value, options);\n\t}).filter(x => x.length > 0).join('&');\n};\n\nexports.parseUrl = (url, options) => {\n\toptions = Object.assign({\n\t\tdecode: true\n\t}, options);\n\n\tconst [url_, hash] = splitOnFirst(url, '#');\n\n\treturn Object.assign(\n\t\t{\n\t\t\turl: url_.split('?')[0] || '',\n\t\t\tquery: parse(extract(url), options)\n\t\t},\n\t\toptions && options.parseFragmentIdentifier && hash ? {fragmentIdentifier: decode(hash, options)} : {}\n\t);\n};\n\nexports.stringifyUrl = (object, options) => {\n\toptions = Object.assign({\n\t\tencode: true,\n\t\tstrict: true\n\t}, options);\n\n\tconst url = removeHash(object.url).split('?')[0] || '';\n\tconst queryFromUrl = exports.extract(object.url);\n\tconst parsedQueryFromUrl = exports.parse(queryFromUrl, {sort: false});\n\n\tconst query = Object.assign(parsedQueryFromUrl, object.query);\n\tlet queryString = exports.stringify(query, options);\n\tif (queryString) {\n\t\tqueryString = `?${queryString}`;\n\t}\n\n\tlet hash = getHash(object.url);\n\tif (object.fragmentIdentifier) {\n\t\thash = `#${encode(object.fragmentIdentifier, options)}`;\n\t}\n\n\treturn `${url}${queryString}${hash}`;\n};\n\nexports.pick = (input, filter, options) => {\n\toptions = Object.assign({\n\t\tparseFragmentIdentifier: true\n\t}, options);\n\n\tconst {url, query, fragmentIdentifier} = exports.parseUrl(input, options);\n\treturn exports.stringifyUrl({\n\t\turl,\n\t\tquery: filterObject(query, filter),\n\t\tfragmentIdentifier\n\t}, options);\n};\n\nexports.exclude = (input, filter, options) => {\n\tconst exclusionFilter = Array.isArray(filter) ? key => !filter.includes(key) : (key, value) => !filter(key, value);\n\n\treturn exports.pick(input, exclusionFilter, options);\n};\n","'use strict';\n\nmodule.exports = (string, separator) => {\n\tif (!(typeof string === 'string' && typeof separator === 'string')) {\n\t\tthrow new TypeError('Expected the arguments to be of type `string`');\n\t}\n\n\tif (separator === '') {\n\t\treturn [string];\n\t}\n\n\tconst separatorIndex = string.indexOf(separator);\n\n\tif (separatorIndex === -1) {\n\t\treturn [string];\n\t}\n\n\treturn [\n\t\tstring.slice(0, separatorIndex),\n\t\tstring.slice(separatorIndex + separator.length)\n\t];\n};\n","'use strict';\nmodule.exports = str => encodeURIComponent(str).replace(/[!'()*]/g, x => `%${x.charCodeAt(0).toString(16).toUpperCase()}`);\n","import { isPrimitive, isNonPrimitive, is, isLike } from \"./is\";\nexport function isArrayOfBooleans(x) {\n    return isArrayOfLike(true)(x);\n}\nexport function isArrayOfNumbers(x) {\n    return isArrayOfLike(1)(x);\n}\nexport function isArrayOfStrings(x) {\n    return isArrayOfLike(\"\")(x);\n}\nexport function isArrayOfSymbols(x) {\n    return isArrayOfLike(Symbol())(x);\n}\nexport function isArrayOfNulls(x) {\n    return isArrayOfLike(null)(x);\n}\nexport function isArrayOfUndefineds(x) {\n    return isArrayOfLike(undefined)(x);\n}\nexport function isArrayOfPrimitives(x) {\n    return is(Array)(x) && x.every(isPrimitive);\n}\nexport function isArrayOfObjects(x) {\n    return is(Array)(x) && x.every(isNonPrimitive);\n}\nexport function isArrayOf(type) {\n    return (xs) => is(Array)(xs) && xs.every(is(type));\n}\nexport function isArrayOfLike(reference) {\n    return (x) => is(Array)(x) && x.every(isLike(reference));\n}\n//# sourceMappingURL=array.js.map","export { isBoolean, isNumber, isString, isSymbol, isNull, isUndefined, isPrimitive, isNonPrimitive, is, isLike, } from \"./is\";\nexport { isArrayOfBooleans, isArrayOfNumbers, isArrayOfStrings, isArrayOfSymbols, isArrayOfNulls, isArrayOfUndefineds, isArrayOfPrimitives, isArrayOfObjects, isArrayOf, isArrayOfLike, } from \"./array\";\nexport { onlyBooleans, onlyNumbers, onlyStrings, onlySymbols, onlyNulls, onlyUndefineds, onlyPrimitives, onlyObjects, only, onlyLike, } from \"./only\";\n//# sourceMappingURL=index.js.map","const TYPE_GUARDS_PRIMITIVE = [isBoolean, isNumber, isString, isSymbol, isNull, isUndefined];\nexport function isBoolean(x) {\n    return typeof x === \"boolean\";\n}\nexport function isNumber(x) {\n    return typeof x === \"number\";\n}\nexport function isString(x) {\n    return typeof x === \"string\";\n}\nexport function isSymbol(x) {\n    return typeof x === \"symbol\";\n}\nexport function isNull(x) {\n    return x === null;\n}\nexport function isUndefined(x) {\n    return x === undefined;\n}\nexport function isPrimitive(x) {\n    return TYPE_GUARDS_PRIMITIVE.some(f => f(x));\n}\nexport function isNonPrimitive(x) {\n    return !isPrimitive(x);\n}\nfunction namedFunction(name, fun) {\n    return Object.defineProperty(fun, \"name\", { value: name, writable: false });\n}\nfunction namedTypeGuard(creator, type, typeGuard) {\n    return namedFunction(`${creator.name}(${type.name})`, typeGuard);\n}\nexport function is(type) {\n    if (isPrimitive(type)) {\n        return (_) => false;\n    }\n    return namedTypeGuard(is, type, (x) => x instanceof type);\n}\nexport function isLike(reference) {\n    for (const f of TYPE_GUARDS_PRIMITIVE) {\n        if (f(reference)) {\n            return (x) => f(x);\n        }\n    }\n    if (is(Array)(reference)) {\n        const referenceAsArray = reference;\n        return (x) => is(Array)(x) && (referenceAsArray.length > 0 ? x.every(isLike(referenceAsArray[0])) : true);\n    }\n    if (reference.constructor === Object) {\n        return (x) => (![undefined, null].includes(x)\n            &&\n                Object.keys(reference).every(k => isLike(reference[k])(x[k])));\n    }\n    if (reference.constructor instanceof Function) {\n        return is(reference.constructor);\n    }\n    throw new TypeError(isLike.name + ` cannot use this object as reference because it has no constructor: ` + JSON.stringify(reference));\n}\n//# sourceMappingURL=is.js.map","import { isBoolean, isNumber, isString, isSymbol, isNull, isUndefined, isPrimitive, isNonPrimitive, is, isLike } from \"./is\";\nexport function onlyBooleans(xs) {\n    return xs.filter(isBoolean);\n}\nexport function onlyNumbers(xs) {\n    return xs.filter(isNumber);\n}\nexport function onlyStrings(xs) {\n    return xs.filter(isString);\n}\nexport function onlySymbols(xs) {\n    return xs.filter(isSymbol);\n}\nexport function onlyNulls(xs) {\n    return xs.filter(isNull);\n}\nexport function onlyUndefineds(xs) {\n    return xs.filter(isUndefined);\n}\nexport function onlyPrimitives(xs) {\n    return xs.filter(isPrimitive);\n}\nexport function onlyObjects(xs) {\n    return xs.filter(isNonPrimitive);\n}\nexport function only(type) {\n    return (xs) => xs.filter(is(type));\n}\nexport function onlyLike(reference) {\n    return (xs) => xs.filter(isLike(reference));\n}\n//# sourceMappingURL=only.js.map","export const ALWAYS = () => true;\nexport const NEVER = () => false;\nexport const DOMCONTENTLOADED = (state) => state !== \"loading\";\nexport const LOAD = (state) => state === \"complete\";\n","import { unlines } from \"lines-unlines\";\nconst INDENTATION = \"  \";\nfunction formatDependency(d) {\n    return INDENTATION + d.key + \": \" + d.selector;\n}\nexport function explanation(failure) {\n    switch (failure.result.reason) {\n        case 0:\n            return unlines([\n                `These dependencies were not found:`,\n                ``,\n                unlines(failure.result.dependencies.map(formatDependency)),\n            ]);\n        case 1:\n            return unlines([\n                `The operation failed with this error:`,\n                ``,\n                failure.result.message,\n            ]);\n    }\n}\nexport function failureDescriber(context) {\n    return failure => unlines([\n        `Could not ${failure.operation.description} on this page:`,\n        ``,\n        INDENTATION + location.href,\n        ``,\n        explanation(failure).trim(),\n        ``,\n        `This problem might be caused by ${context.siteName} changing its content/structure, in which case ${context.extensionName} needs to be updated accordingly. Otherwise, it's probably a bug in ${context.extensionName}.`,\n        ``,\n        `If you file a bug report, please include this message.`,\n    ]);\n}\n","import * as environment from \"./environment\";\nimport * as errors from \"./errors\";\nimport * as log from \"./log\";\nimport * as operations from \"./operations\";\nimport * as preferences from \"./preferences\";\nimport * as stylesheets from \"./stylesheets\";\nimport * as userscripter from \"./userscripter\";\nexport { environment, errors, log, operations, preferences, stylesheets, userscripter, };\n","let prefix = \"\";\nlet logger = console;\nexport function setPrefix(p) {\n    prefix = p;\n}\nexport function setLogger(l) {\n    logger = l;\n}\nexport function log(str) {\n    logger.log(prefix, str);\n}\nexport function info(str) {\n    logger.info(prefix, str);\n}\nexport function warning(str) {\n    logger.warn(prefix, str);\n}\nexport function error(str) {\n    logger.error(prefix, str);\n}\n","import { isNull, isNumber, isString } from \"ts-type-guards\";\nconst SUCCESS = undefined;\nexport function operation(spec) {\n    return spec;\n}\nexport function run(plan) {\n    function recurse(operations, failures, triesLeft) {\n        const lastTry = isNumber(triesLeft) && triesLeft <= 0;\n        const operationsToRunNow = [];\n        const remaining = [];\n        const readyState = document.readyState;\n        for (const o of operations) {\n            const shouldRunNow = o.deferUntil === undefined || o.deferUntil(readyState);\n            (shouldRunNow ? operationsToRunNow : remaining).push(o);\n        }\n        for (const o of operationsToRunNow) {\n            const result = tryToPerform(o);\n            if (result !== SUCCESS) {\n                switch (result.reason) {\n                    case 0:\n                        lastTry ? failures.push({ result, operation: o }) : remaining.push(o);\n                        break;\n                    case 1:\n                        failures.push({ result, operation: o });\n                        break;\n                }\n            }\n        }\n        if (remaining.length > 0) {\n            setTimeout(() => recurse(remaining, failures, (isNumber(triesLeft)\n                ? triesLeft - 1\n                : plan.tryUntil(readyState) ? plan.extraTries : undefined)), plan.interval);\n        }\n        else if (failures.length > 0) {\n            plan.handleFailures(failures);\n        }\n    }\n    recurse(plan.operations.filter(o => o.condition(window)), []);\n}\nfunction tryToPerform(o) {\n    const dependencies = o.dependencies === undefined ? {} : o.dependencies;\n    const queryResults = Object.entries(dependencies).map(([key, selector]) => ({\n        key, selector,\n        element: document.querySelector(selector),\n    }));\n    const missingDependencies = queryResults.filter(x => isNull(x.element));\n    if (missingDependencies.length > 0) {\n        return { reason: 0, dependencies: missingDependencies };\n    }\n    const e = queryResults.reduce((acc, x) => Object.defineProperty(acc, x.key, { value: x.element }), {});\n    return fromActionResult(o.action(e));\n}\nfunction fromActionResult(r) {\n    return isString(r) ? { reason: 1, message: r } : SUCCESS;\n}\n","import * as log from \"./log\";\nexport function subscriptable(handler) {\n    const changeListeners = new Set();\n    return {\n        subscribe: (listener) => { changeListeners.add(listener); },\n        unsubscribe: (listener) => { changeListeners.delete(listener); },\n        handler: (summary, preferences) => {\n            if (summary.action === \"set\") {\n                changeListeners.forEach(f => f(summary.preference));\n            }\n            return handler(summary, preferences);\n        },\n    };\n}\nexport function loggingResponseHandler(summary, preferences) {\n    const response = summary.response;\n    switch (response.status) {\n        case 0:\n            return response;\n        case 1:\n            if (summary.action === \"get\") {\n                log.warning(`The saved value for preference '${summary.preference.key}' (${JSON.stringify(response.saved)}) was invalid. Replacing it with ${JSON.stringify(response.value)}.`);\n                preferences.set(summary.preference, response.value);\n            }\n            if (summary.action === \"set\") {\n                log.warning(`Could not set value ${JSON.stringify(response.value)} for preference '${summary.preference.key}' because it was invalid.`);\n            }\n            return response;\n        case 2:\n            if (summary.action === \"get\") {\n                log.warning(`The saved value for preference '${summary.preference.key}' had the wrong type. Replacing it with ${JSON.stringify(response.value)}.`);\n                preferences.set(summary.preference, response.value);\n            }\n            return response;\n        case 3:\n            if (summary.action === \"get\") {\n                log.warning(`The saved value for preference '${summary.preference.key}' could not be parsed. Replacing it with ${JSON.stringify(response.value)}.`);\n                preferences.set(summary.preference, response.value);\n            }\n            return response;\n        case 4:\n            switch (summary.action) {\n                case \"get\":\n                    log.error(`Could not read preference '${summary.preference.key}' because localStorage could not be accessed. Using value ${JSON.stringify(summary.preference.default)}.`);\n                    break;\n                case \"set\":\n                    log.error(`Could not save value ${JSON.stringify(summary.response.value)} for preference '${summary.preference.key}' because localStorage could not be accessed.`);\n                    break;\n                default:\n                    assertUnreachable(summary.action);\n            }\n            return response;\n        default:\n            return assertUnreachable(response.status);\n    }\n}\nexport function noopResponseHandler(summary, _) {\n    return summary.response;\n}\nfunction assertUnreachable(x) {\n    throw new Error(\"assertUnreachable: \" + x);\n}\n","const MATCH_ALL = \"all\";\nconst MATCH_NONE = \"not all\";\nexport function stylesheet(spec) {\n    return spec;\n}\nexport function insert(stylesheets) {\n    const fragment = document.createDocumentFragment();\n    Object.entries(stylesheets).forEach(([_, sheet]) => {\n        const style = document.createElement(\"style\");\n        if (sheet.id !== undefined)\n            style.id = sheet.id;\n        style.textContent = sheet.css;\n        style.media = sheet.condition(window) ? MATCH_ALL : MATCH_NONE;\n        fragment.appendChild(style);\n    });\n    document.documentElement.appendChild(fragment);\n}\nconst setMediaQuery = (m) => (s) => {\n    const element = document.getElementById(s.id);\n    if (element !== null) {\n        element.setAttribute(\"media\", m);\n    }\n};\nexport const enable = setMediaQuery(MATCH_ALL);\nexport const disable = setMediaQuery(MATCH_NONE);\n","import * as log from \"./log\";\nimport * as operations from \"./operations\";\nimport * as stylesheets from \"./stylesheets\";\nexport function run(userscript) {\n    log.setPrefix(`[${userscript.name}]`);\n    const attr = attribute(userscript.id);\n    if (document.documentElement.hasAttribute(attr)) {\n        log.warning(`It looks as though ${userscript.name} has already run (because the attribute \"${attr}\" was found on <head>). Stopping.`);\n    }\n    else {\n        document.documentElement.setAttribute(attr, \"\");\n        userscript.initialAction();\n        stylesheets.insert(userscript.stylesheets);\n        operations.run(userscript.operationsPlan);\n    }\n}\nfunction attribute(id) {\n    return \"data-\" + id + \"-has-run\";\n}\n","// This file cannot contain Webpack-resolved imports (e.g. \"~src/foo\").\n\nexport const OPERATIONS_INTERVAL = 200; // ms\nexport const OPERATIONS_EXTRA_TRIES = 3;\n","const arr = Array.from;\n\nconst extractLinkedText = (node: HTMLElement): string => {\n    const tmpNode = node.cloneNode(true) as HTMLElement;\n    arr(tmpNode.querySelectorAll(\"a\")).forEach(\n        (el) => (el.innerText = `[${el.innerText}](${el.href})`)\n    );\n    return tmpNode.innerText.trim();\n};\n\nexport function extractTableAsJson(table: HTMLTableElement): object {\n    // Ideally first check if table is \"regular\" aka has equal number of th to td/tr\n    let keys: string[] = [];\n\n    if (table.tHead !== null) {\n        keys = arr(table.tHead.querySelectorAll(\"th\")).map((el) =>\n            extractLinkedText(el)\n        );\n    } else {\n        keys = arr(table.querySelectorAll(\"th\")).map((el) =>\n            extractLinkedText(el))\n    }\n\n    return arr(table.tBodies).flatMap((el) =>\n        arr(el.querySelectorAll(\"tr\")).map((tableRow) => {\n            const dataCells = arr(tableRow.querySelectorAll(\"td\")).map((el) =>\n                extractLinkedText(el)\n            );\n            if (dataCells.length !== keys.length) {\n                console.warn(\"Found a row with a mismatch\");\n            }\n            if (keys.length === 0) {\n                return dataCells;\n            }\n            return keys.reduce(\n                (tableRow, dataKey, idx) => ({\n                    ...tableRow,\n                    [dataKey]: dataCells[idx],\n                }),\n                {}\n            );\n        })\n    );\n}\n\nexport function traverseGfmTable(table: HTMLTableElement) {\n    let keys: string[] = [];\n    keys = arr(table.querySelectorAll(\"th\")).map((el) =>\n        extractLinkedText(el)\n    );\n    return arr(table.tBodies).map((el) =>\n        arr(el.querySelectorAll(\"tr\")).map((tableRow) => {\n            const dataCells = arr(tableRow.querySelectorAll(\"td\")).map((el) =>\n                extractLinkedText(el)\n            );\n            if (dataCells.length !== keys.length) {\n                console.warn(\"Found a row with a mismatch\");\n            }\n            if (keys.length === 0) {\n                return dataCells;\n            }\n            return keys.reduce(\n                (tableRow, dataKey, idx) => ({\n                    ...tableRow,\n                    [dataKey]: dataCells[idx],\n                }),\n                {}\n            );\n        })\n    );\n}\n","export function htmlTreeSelection(): Promise<HTMLElement> {\n  return new Promise((resolve) => {\n    // TODO select via keyboard?\n    let clickable = [\n      document.getElementsByTagName(\"a\"),\n      document.getElementsByTagName(\"button\"),\n      document.querySelectorAll(\"[role=button]\"),\n    ];\n    const iframeOverlays: {\n      iframe: HTMLIFrameElement;\n      overlay: HTMLDivElement;\n    }[] = [];\n\n    let lastElement: HTMLElement = document.body;\n\n    let overHandler = (e: Event) => {\n      let target = e.target as HTMLElement;\n\n      if (target === null) {\n        return;\n      }\n\n      lastElement = target;\n\n      target.classList.add(\"html-tree-selection\");\n\n      if (target.classList.contains(\"html-tree-selection-overlay\")) {\n        if (target.dataset.index) {\n          let iframe =\n            iframeOverlays[parseInt(target.dataset.index, 10)].iframe;\n          iframe.classList.add(\"html-tree-selection\");\n        } else {\n          console.warn(\"failed to find iframe\");\n        }\n      }\n\n      e.stopPropagation();\n    };\n    let outHandler = (e: Event) => {\n      let target = e.target as HTMLElement;\n\n      if (target === null) {\n        return;\n      }\n\n      const selectionClass = \"html-tree-selection\";\n      if (target.classList.contains(selectionClass)) {\n        target.classList.remove(selectionClass);\n      }\n      e.stopPropagation();\n    };\n\n    let clickHandler = (e: Event) => {\n      disable();\n\n      let target = e.target as HTMLElement;\n\n      if (target === null) {\n        return;\n      }\n      e.preventDefault();\n      e.stopPropagation();\n\n      if (target.classList.contains(\"html-tree-selection-overlay\")) {\n        if (target.dataset.index) {\n          target = iframeOverlays[parseInt(target.dataset.index, 10)].iframe;\n        } else {\n          console.warn(\"maybe failed to find iframe?\", target, iframeOverlays);\n        }\n      }\n\n      resolve(target);\n    };\n\n    let disable = () => {\n      clickable.forEach((c) => {\n        for (var i = 0; i < c.length; i++) {\n          c[i].removeEventListener(\"click\", clickHandler);\n          // @ts-expect-error\n          c[i].addEventListener(\"click\", c[i].onclickBackup);\n          // @ts-expect-error\n          delete c[i].onclickBackup;\n        }\n      });\n\n      iframeOverlays.forEach((o) => o.overlay.remove());\n\n      document.documentElement.classList.remove(\"html-tree-selection-cursor\");\n\n      // clean any orphaned hover applied class\n      let orphan = document.querySelector(\".html-tree-selection\");\n      if (orphan !== null) {\n        orphan.classList.remove(\"html-tree-selection\");\n      }\n\n      document.removeEventListener(\"mouseover\", overHandler);\n      document.removeEventListener(\"mouseout\", outHandler);\n      document.removeEventListener(\"click\", clickHandler);\n      document.removeEventListener(\"keydown\", keyHandler, true);\n\n      window.removeEventListener(\"scroll\", updateOverlayPositions);\n      window.removeEventListener(\"resize\", updateOverlayPositions);\n    };\n\n    const selectNode = (el: Element) => {\n      return el.dispatchEvent(new MouseEvent(\"mouseover\", { bubbles: true }));\n    };\n    const unselectNode = (el: Element) => {\n      return el.dispatchEvent(new MouseEvent(\"mouseout\", { bubbles: true }));\n    };\n    const clearCurrentSelection = () => {\n      clickable.forEach((c) => {\n        for (var i = 0; i < c.length; i++) {\n          unselectNode(c[i]);\n        }\n      });\n    };\n    const moveSelectionToElement = (el: Element) => {\n      clearCurrentSelection();\n      selectNode(el);\n    };\n    const moveSelectionToParent = () => {\n      const parent = lastElement.parentElement;\n      if (parent !== null) {\n        moveSelectionToElement(parent);\n      }\n    };\n    const moveSelectionToChild = () => {\n      const child = lastElement.children && lastElement.children[0];\n      if (child && child !== null) {\n        moveSelectionToElement(child);\n      }\n    };\n    const moveSelectionToNextSibling = () => {\n      const sibling = lastElement.nextElementSibling;\n      if (sibling !== null) {\n        moveSelectionToElement(sibling);\n      }\n    };\n    const moveSelectionToPrevSibling = () => {\n      const sibling = lastElement.previousElementSibling;\n      if (sibling !== null) {\n        moveSelectionToElement(sibling);\n      }\n    };\n\n    let keyHandler = (e: KeyboardEvent) => {\n      const h = {\n        Escape: disable,\n        ArrowLeft: moveSelectionToParent,\n        ArrowRight: moveSelectionToChild,\n        ArrowUp: moveSelectionToNextSibling,\n        ArrowDown: moveSelectionToPrevSibling,\n      };\n      console.debug(e.key);\n      // @ts-ignore\n      const handler = h[e.key];\n      handler && handler();\n    };\n\n    let updateOverlayPositions = (_e: Event) => {\n      iframeOverlays.forEach((o) => {\n        let iframe = o.iframe;\n        let iframeClientRect = iframe.getBoundingClientRect();\n        let overlay = o.overlay;\n        let offsetX = iframeClientRect.left + window.scrollX;\n        let offsetY = iframeClientRect.top + window.scrollY;\n\n        overlay.style.top = `${offsetY}px`;\n        overlay.style.left = `${offsetX}px`;\n      });\n    };\n\n    // enable\n    window.addEventListener(\"scroll\", updateOverlayPositions);\n    window.addEventListener(\"resize\", updateOverlayPositions);\n\n    // override click handlers on any clickable element\n    clickable.forEach((c) => {\n      for (var i = 0; i < c.length; i++) {\n        // @ts-expect-error\n        c[i].onclickBackup = c[i].onclick;\n        c[i].addEventListener(\"click\", clickHandler);\n      }\n    });\n\n    let iframes = document.querySelectorAll(\"iframe\");\n\n    iframes.forEach((i) => {\n      let overlay = document.createElement(\"div\");\n      let iframeClientRect = i.getBoundingClientRect();\n      let offsetX = iframeClientRect.left + window.scrollX;\n      let offsetY = iframeClientRect.top + window.scrollY;\n\n      overlay.classList.add(\"html-tree-selection-overlay\");\n      overlay.style.top = `${offsetY}px`;\n      overlay.style.left = `${offsetX}px`;\n      overlay.style.width = `${iframeClientRect.width}px`;\n      overlay.style.height = `${iframeClientRect.height}px`;\n\n      overlay.dataset.index = `${iframeOverlays.length}`;\n\n      iframeOverlays.push({\n        iframe: i,\n        overlay: overlay,\n      });\n\n      document.body.appendChild(overlay);\n    });\n\n    document.documentElement.classList.add(\"html-tree-selection-cursor\");\n    document.addEventListener(\"mouseover\", overHandler);\n    document.addEventListener(\"mouseout\", outHandler);\n    document.addEventListener(\"click\", clickHandler);\n    document.addEventListener(\"keydown\", keyHandler, true);\n  });\n}\n","export const addToClipboard = (content: string) => {\n  const permissionName = \"clipboard-write\" as PermissionName;\n  return navigator.permissions\n    .query({ name: permissionName })\n    .then((result) => {\n      if (result.state == \"granted\" || result.state == \"prompt\") {\n        return navigator.clipboard.writeText(content).then(() => {});\n      }\n      throw Error(\n        \"Permission for clipboard-write was not obtained \" + result.state\n      );\n    });\n};\n\nexport const getSiblings = (elem: HTMLElement): HTMLElement[] => {\n  const siblings = [];\n  let sibling = elem.parentNode && elem.parentNode.firstElementChild;\n\n  if (!sibling) {\n    return [];\n  }\n\n  // Loop through each sibling and push to the array\n  while (sibling) {\n    if (sibling.nodeType === 1 && sibling !== elem) {\n      siblings.push(sibling as HTMLElement);\n    }\n    sibling = sibling.nextElementSibling;\n  }\n\n  return siblings;\n};\n\nexport const appendBtnToElements = <Z extends HTMLElement>(\n  elements: NodeListOf<Z>,\n  clickHandler: (e: Z, a: Event) => void,\n  modifyBtn: (b: HTMLElement) => void\n): HTMLElement[] => {\n  return Array.from(elements).map((codeBlock) => {\n    codeBlock.classList.add(\"jacks-dev-helpers-interact-target\");\n    codeBlock.innerHTML = `<span class=\"jacks-dev-helpers-outer-wrap\" >${codeBlock.innerHTML}</span>`;\n    const copyBtn = document.createElement(\"span\");\n    copyBtn.classList.add(\"jacks-dev-helpers-interact-widget\");\n    copyBtn.addEventListener(\"click\", (event) => {\n      const tmpCodeBlock = codeBlock.cloneNode(true) as Z;\n      const children = tmpCodeBlock.children;\n      for (let i = 0; i < children.length; i++) {\n        const childComponent = children[i];\n        if (\n          childComponent.classList.contains(\"jacks-dev-helpers-interact-widget\")\n        ) {\n          tmpCodeBlock.removeChild(childComponent);\n        }\n      }\n      clickHandler(tmpCodeBlock as Z, event);\n    });\n    modifyBtn(copyBtn);\n    codeBlock.appendChild(copyBtn);\n    return copyBtn;\n  });\n};\n\nexport async function installEsModule(moduleUrl: string) {\n  const script = document.createElement(\"script\");\n  script.setAttribute(\"type\", \"module\");\n  script.setAttribute(\"src\", moduleUrl);\n  const head =\n    document.head ||\n    document.getElementsByTagName(\"head\")[0] ||\n    document.documentElement;\n  head.insertBefore(script, head.lastChild);\n}\n","import { compose } from \"@typed/compose\";\nimport { environment, errors, log, userscripter } from \"userscripter\";\n\nimport * as CONFIG from \"~src/config\";\nimport OPERATIONS from \"~src/operations\";\nimport * as SITE from \"~src/site\";\nimport STYLESHEETS from \"~src/stylesheets\";\nimport U from \"~src/userscript\";\n\nconst describeFailure = errors.failureDescriber({\n    siteName: SITE.NAME,\n    extensionName: U.name,\n    location: document.location,\n});\n\nuserscripter.run({\n    id: U.id,\n    name: U.name,\n    initialAction: () => log.log(`${U.name} ${U.version}`),\n    stylesheets: STYLESHEETS,\n    operationsPlan: {\n        operations: OPERATIONS,\n        interval: CONFIG.OPERATIONS_INTERVAL,\n        tryUntil: environment.DOMCONTENTLOADED,\n        extraTries: CONFIG.OPERATIONS_EXTRA_TRIES,\n        handleFailures: failures => failures.forEach(compose(log.error, describeFailure)),\n    },\n});\n","import parseGitUrl from \"git-url-parse\";\nimport { ALWAYS } from \"userscripter/lib/environment\";\nimport { deepEntries, delimitEntry } from \"deep-entries\";\nimport { Operation, operation } from \"userscripter/lib/operations\";\nimport { addToClipboard } from \"./helpers/utils\";\nimport { extractTableAsJson } from \"./helpers/extractTableInfo\";\nimport { htmlTreeSelection } from \"./helpers/htmlTreeSelection\";\n\nconst OPERATIONS: ReadonlyArray<Operation<any>> = [\n  operation({\n    description: \"Hacky automate page interaction\",\n    condition: ALWAYS,\n    action: () => {\n      const urlParams = new URLSearchParams(window.location.search);\n      const autoEvalStr = urlParams.get(\"hackyDangerScript\");\n      if (autoEvalStr === null) return;\n      const autoEvalCmd = atob(autoEvalStr);\n      if (\n        !localStorage.getItem(`hackydanger-allowed-${autoEvalStr}`) &&\n        confirm(\"Ok to run command?\")\n      ) {\n        localStorage.setItem(\n          `hackydanger-allowed-${autoEvalStr}`,\n          \"surethisistottallysafe\"\n        );\n      }\n      localStorage.getItem(`hackydanger-allowed-${autoEvalStr}`) &&\n        eval(autoEvalCmd);\n    },\n  }),\n  operation({\n    description: \"Provide parse github url\",\n    condition: ALWAYS,\n    action: () => {\n      // @ts-expect-error\n      window.parseGitUrl = parseGitUrl;\n    },\n  }),\n  operation({\n    description: \"Provide helper funcs for surfingkeys\",\n    condition: ALWAYS,\n    action: () => {\n      // @ts-expect-error\n      window.htmlTreeSelection = htmlTreeSelection;\n    },\n  }),\n  operation({\n    description: \"Provide helper funcs for dev console\",\n    condition: ALWAYS,\n    action: () => {\n      const findKeyDeep = (obj: object, str: string) => {\n        const flatObj = deepEntries(obj, delimitEntry);\n        return flatObj.filter(([k, _value]: [string, unknown]) =>\n          k.includes(str)\n        );\n      };\n      // @ts-expect-error\n      window.findKeyDeep = findKeyDeep;\n    },\n  }),\n  operation({\n    description: \"Copy table as json via right click\",\n    condition: ALWAYS,\n    action: () => {\n      let menuActive = false;\n      document.addEventListener(\"mousemove\", function clickListener(event) {\n        const maybeTable = event.target;\n        if (!menuActive && maybeTable instanceof HTMLTableElement) {\n          GM_registerMenuCommand(\"Copy this table\", () => {\n            const tableJson = extractTableAsJson(maybeTable);\n            addToClipboard(JSON.stringify(tableJson, null, 4));\n          });\n        } else if (menuActive && !(maybeTable instanceof HTMLTableElement)) {\n          GM_unregisterMenuCommand(\"Copy this table\");\n        }\n      });\n    },\n  }),\n];\n\nexport default OPERATIONS;\n","// This file cannot contain Webpack-resolved imports (e.g. \"~src/foo\").\n\nimport U from \"./userscript\";\n\nexport const NAME = U.sitename;\nexport const HOSTNAME = U.hostname;\nexport const SELECTOR_CODE = \"code\";\n","import { ALWAYS } from \"userscripter/lib/environment\";\nimport { Stylesheets, stylesheet } from \"userscripter/lib/stylesheets\";\n\nconst STYLESHEETS = {\n  general: stylesheet({\n    condition: ALWAYS,\n    css: `\n            .jacks-dev-helpers-interact-widget {\n              display: none;\n              top: 0px;\n              right: 0px;\n              padding: 5px 10px;\n              cursor: grab;\n              background: unset;\n              align-self: flex-end;\n            }\n            .jacks-dev-helper-outer-wrap {\n              display: flex\n            }\n            .jacks-dev-helpers-interact-target:hover > .jacks-dev-helpers-interact-widget {\n              display: inline-flex;\n            }\n            .jacks-dev-helpers-interact-widget:hover {\n              text-decoration: underline;\n            }\n             `,\n  }),\n  htmlTreeSelectionOverlay: stylesheet({\n    condition: ALWAYS,\n    css: `\n:root {\n  --html-tree-selection-icon-url: \"\"\n}\n.html-tree-selection-cursor,\n.html-tree-selection-cursor a,\n.html-tree-selection-cursor input,\n.html-tree-selection-cursor select,\n.html-tree-selection-cursor button,\n.html-tree-selection-cursor div[role=button] {\n  cursor: var(--html-tree-selection-icon-url), crosshair !important;\n}\n\n.html-tree-selection {\n  filter: opacity(0.2);\n  box-shadow: inset 0px 0px 25px rgba(255,0,0,.5);\n}\n\n.html-tree-selection-overlay {\n  position: absolute;\n  z-index: 2147483647;\n  background:\n    no-repeat center/70% var(--html-tree-selection-icon-url),\n    linear-gradient(\n      rgba(255, 255, 255, 0.85),\n      rgba(255, 255, 255, 0.85)\n    );\n}\n`,\n  }),\n} as const;\n// <span class=\"w3-badge\">9</span>\n\n// This trick uncovers type errors in STYLESHEETS while retaining the static knowledge of its properties (so we can still write e.g. STYLESHEETS.foo):\nconst _: Stylesheets = STYLESHEETS;\nvoid _;\n\nexport default STYLESHEETS;\n","export default {\n    id: \"jacks-dev-helpers\",\n    name: \"Jack's Dev Helpers\",\n    version: \"0.1.0\",\n    author: \"Jack McCown\",\n    description: \"Hodgepodge of dev utils\",\n    hostname: \"*\",\n    namespace: \"jackmscripts\",\n    sitename: \"google.com\",\n    runAt: \"document-end\",\n} as const;\n"],"sourceRoot":""}