diff --git a/KoLmafia/dependencies.txt b/KoLmafia/dependencies.txt deleted file mode 100644 index e4f6c6a..0000000 --- a/KoLmafia/dependencies.txt +++ /dev/null @@ -1,4 +0,0 @@ -https://github.com/Ezandora/Bastille/branches/Release/ -https://github.com/Ezandora/Briefcase/branches/Release/ -https://github.com/Ezandora/Voting-Booth/trunk/Release/ -https://github.com/Ezandora/Detective-Solver/branches/Release/ \ No newline at end of file diff --git a/KoLmafia/relay/relay_folgerCS.js b/KoLmafia/relay/relay_folgerCS.js new file mode 100644 index 0000000..c54ebd4 --- /dev/null +++ b/KoLmafia/relay/relay_folgerCS.js @@ -0,0 +1,6655 @@ +/******/ (() => { // webpackBootstrap +/******/ var __webpack_modules__ = ({ + +/***/ 139: +/***/ ((__unused_webpack_module, exports, __webpack_require__) => { + +/******/(()=>{// webpackBootstrap +/******/"use strict";/******/var __webpack_modules__={/***/447:/***/module=>{module.exports="data:application/javascript;base64,(function webpackUniversalModuleDefinition(root, factory) {
	if(typeof exports === 'object' && typeof module === 'object')
		module.exports = factory();
	else if(typeof define === 'function' && define.amd)
		define([], factory);
	else {
		var a = factory();
		for(var i in a) (typeof exports === 'object' ? exports : root)[i] = a[i];
	}
})(self, () => {
return /******/ (() => { // webpackBootstrap
/******/ 	"use strict";
/******/ 	var __webpack_modules__ = ({

/***/ 242:
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {


// EXPORTS
__webpack_require__.d(__webpack_exports__, {
  "Z": () => (/* binding */ relay_App)
});

;// CONCATENATED MODULE: ./node_modules/@remix-run/router/dist/router.js
/**
 * @remix-run/router v1.0.3
 *
 * Copyright (c) Remix Software Inc.
 *
 * This source code is licensed under the MIT license found in the
 * LICENSE.md file in the root directory of this source tree.
 *
 * @license MIT
 */
function _extends() {
  _extends = Object.assign ? Object.assign.bind() : function (target) {
    for (var i = 1; i < arguments.length; i++) {
      var source = arguments[i];

      for (var key in source) {
        if (Object.prototype.hasOwnProperty.call(source, key)) {
          target[key] = source[key];
        }
      }
    }

    return target;
  };
  return _extends.apply(this, arguments);
}

////////////////////////////////////////////////////////////////////////////////
//#region Types and Constants
////////////////////////////////////////////////////////////////////////////////

/**
 * Actions represent the type of change to a location value.
 */
var Action;

(function (Action) {
  /**
   * A POP indicates a change to an arbitrary index in the history stack, such
   * as a back or forward navigation. It does not describe the direction of the
   * navigation, only that the current index changed.
   *
   * Note: This is the default action for newly created history objects.
   */
  Action["Pop"] = "POP";
  /**
   * A PUSH indicates a new entry being added to the history stack, such as when
   * a link is clicked and a new page loads. When this happens, all subsequent
   * entries in the stack are lost.
   */

  Action["Push"] = "PUSH";
  /**
   * A REPLACE indicates the entry at the current index in the history stack
   * being replaced by a new one.
   */

  Action["Replace"] = "REPLACE";
})(Action || (Action = {}));

const PopStateEventType = "popstate";
/**
 * Memory history stores the current location in memory. It is designed for use
 * in stateful non-browser environments like tests and React Native.
 */

function router_createMemoryHistory(options) {
  if (options === void 0) {
    options = {};
  }

  let {
    initialEntries = ["/"],
    initialIndex,
    v5Compat = false
  } = options;
  let entries; // Declare so we can access from createMemoryLocation

  entries = initialEntries.map((entry, index) => createMemoryLocation(entry, typeof entry === "string" ? null : entry.state, index === 0 ? "default" : undefined));
  let index = clampIndex(initialIndex == null ? entries.length - 1 : initialIndex);
  let action = Action.Pop;
  let listener = null;

  function clampIndex(n) {
    return Math.min(Math.max(n, 0), entries.length - 1);
  }

  function getCurrentLocation() {
    return entries[index];
  }

  function createMemoryLocation(to, state, key) {
    if (state === void 0) {
      state = null;
    }

    let location = createLocation(entries ? getCurrentLocation().pathname : "/", to, state, key);
    warning$1(location.pathname.charAt(0) === "/", "relative pathnames are not supported in memory history: " + JSON.stringify(to));
    return location;
  }

  let history = {
    get index() {
      return index;
    },

    get action() {
      return action;
    },

    get location() {
      return getCurrentLocation();
    },

    createHref(to) {
      return typeof to === "string" ? to : router_createPath(to);
    },

    encodeLocation(location) {
      return location;
    },

    push(to, state) {
      action = Action.Push;
      let nextLocation = createMemoryLocation(to, state);
      index += 1;
      entries.splice(index, entries.length, nextLocation);

      if (v5Compat && listener) {
        listener({
          action,
          location: nextLocation
        });
      }
    },

    replace(to, state) {
      action = Action.Replace;
      let nextLocation = createMemoryLocation(to, state);
      entries[index] = nextLocation;

      if (v5Compat && listener) {
        listener({
          action,
          location: nextLocation
        });
      }
    },

    go(delta) {
      action = Action.Pop;
      index = clampIndex(index + delta);

      if (listener) {
        listener({
          action,
          location: getCurrentLocation()
        });
      }
    },

    listen(fn) {
      listener = fn;
      return () => {
        listener = null;
      };
    }

  };
  return history;
}
/**
 * Browser history stores the location in regular URLs. This is the standard for
 * most web apps, but it requires some configuration on the server to ensure you
 * serve the same app at multiple URLs.
 *
 * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#createbrowserhistory
 */

function router_createBrowserHistory(options) {
  if (options === void 0) {
    options = {};
  }

  function createBrowserLocation(window, globalHistory) {
    let {
      pathname,
      search,
      hash
    } = window.location;
    return createLocation("", {
      pathname,
      search,
      hash
    }, // state defaults to `null` because `window.history.state` does
    globalHistory.state && globalHistory.state.usr || null, globalHistory.state && globalHistory.state.key || "default");
  }

  function createBrowserHref(window, to) {
    return typeof to === "string" ? to : router_createPath(to);
  }

  return getUrlBasedHistory(createBrowserLocation, createBrowserHref, null, options);
}
/**
 * Hash history stores the location in window.location.hash. This makes it ideal
 * for situations where you don't want to send the location to the server for
 * some reason, either because you do cannot configure it or the URL space is
 * reserved for something else.
 *
 * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#createhashhistory
 */

function router_createHashHistory(options) {
  if (options === void 0) {
    options = {};
  }

  function createHashLocation(window, globalHistory) {
    let {
      pathname = "/",
      search = "",
      hash = ""
    } = parsePath(window.location.hash.substr(1));
    return createLocation("", {
      pathname,
      search,
      hash
    }, // state defaults to `null` because `window.history.state` does
    globalHistory.state && globalHistory.state.usr || null, globalHistory.state && globalHistory.state.key || "default");
  }

  function createHashHref(window, to) {
    let base = window.document.querySelector("base");
    let href = "";

    if (base && base.getAttribute("href")) {
      let url = window.location.href;
      let hashIndex = url.indexOf("#");
      href = hashIndex === -1 ? url : url.slice(0, hashIndex);
    }

    return href + "#" + (typeof to === "string" ? to : router_createPath(to));
  }

  function validateHashLocation(location, to) {
    warning$1(location.pathname.charAt(0) === "/", "relative pathnames are not supported in hash history.push(" + JSON.stringify(to) + ")");
  }

  return getUrlBasedHistory(createHashLocation, createHashHref, validateHashLocation, options);
} //#endregion
////////////////////////////////////////////////////////////////////////////////
//#region UTILS
////////////////////////////////////////////////////////////////////////////////

function warning$1(cond, message) {
  if (!cond) {
    // eslint-disable-next-line no-console
    if (typeof console !== "undefined") console.warn(message);

    try {
      // Welcome to debugging history!
      //
      // This error is thrown as a convenience so you can more easily
      // find the source for a warning that appears in the console by
      // enabling "pause on exceptions" in your JavaScript debugger.
      throw new Error(message); // eslint-disable-next-line no-empty
    } catch (e) {}
  }
}

function createKey() {
  return Math.random().toString(36).substr(2, 8);
}
/**
 * For browser-based histories, we combine the state and key into an object
 */


function getHistoryState(location) {
  return {
    usr: location.state,
    key: location.key
  };
}
/**
 * Creates a Location object with a unique key from the given Path
 */


function createLocation(current, to, state, key) {
  if (state === void 0) {
    state = null;
  }

  let location = _extends({
    pathname: typeof current === "string" ? current : current.pathname,
    search: "",
    hash: ""
  }, typeof to === "string" ? parsePath(to) : to, {
    state,
    // TODO: This could be cleaned up.  push/replace should probably just take
    // full Locations now and avoid the need to run through this flow at all
    // But that's a pretty big refactor to the current test suite so going to
    // keep as is for the time being and just let any incoming keys take precedence
    key: to && to.key || key || createKey()
  });

  return location;
}
/**
 * Creates a string URL path from the given pathname, search, and hash components.
 */

function router_createPath(_ref) {
  let {
    pathname = "/",
    search = "",
    hash = ""
  } = _ref;
  if (search && search !== "?") pathname += search.charAt(0) === "?" ? search : "?" + search;
  if (hash && hash !== "#") pathname += hash.charAt(0) === "#" ? hash : "#" + hash;
  return pathname;
}
/**
 * Parses a string URL path into its separate pathname, search, and hash components.
 */

function parsePath(path) {
  let parsedPath = {};

  if (path) {
    let hashIndex = path.indexOf("#");

    if (hashIndex >= 0) {
      parsedPath.hash = path.substr(hashIndex);
      path = path.substr(0, hashIndex);
    }

    let searchIndex = path.indexOf("?");

    if (searchIndex >= 0) {
      parsedPath.search = path.substr(searchIndex);
      path = path.substr(0, searchIndex);
    }

    if (path) {
      parsedPath.pathname = path;
    }
  }

  return parsedPath;
}
function createURL(location) {
  // window.location.origin is "null" (the literal string value) in Firefox
  // under certain conditions, notably when serving from a local HTML file
  // See https://bugzilla.mozilla.org/show_bug.cgi?id=878297
  let base = typeof window !== "undefined" && typeof window.location !== "undefined" && window.location.origin !== "null" ? window.location.origin : "unknown://unknown";
  let href = typeof location === "string" ? location : router_createPath(location);
  return new URL(href, base);
}

function getUrlBasedHistory(getLocation, createHref, validateLocation, options) {
  if (options === void 0) {
    options = {};
  }

  let {
    window = document.defaultView,
    v5Compat = false
  } = options;
  let globalHistory = window.history;
  let action = Action.Pop;
  let listener = null;

  function handlePop() {
    action = Action.Pop;

    if (listener) {
      listener({
        action,
        location: history.location
      });
    }
  }

  function push(to, state) {
    action = Action.Push;
    let location = createLocation(history.location, to, state);
    if (validateLocation) validateLocation(location, to);
    let historyState = getHistoryState(location);
    let url = history.createHref(location); // try...catch because iOS limits us to 100 pushState calls :/

    try {
      globalHistory.pushState(historyState, "", url);
    } catch (error) {
      // They are going to lose state here, but there is no real
      // way to warn them about it since the page will refresh...
      window.location.assign(url);
    }

    if (v5Compat && listener) {
      listener({
        action,
        location: history.location
      });
    }
  }

  function replace(to, state) {
    action = Action.Replace;
    let location = createLocation(history.location, to, state);
    if (validateLocation) validateLocation(location, to);
    let historyState = getHistoryState(location);
    let url = history.createHref(location);
    globalHistory.replaceState(historyState, "", url);

    if (v5Compat && listener) {
      listener({
        action,
        location: history.location
      });
    }
  }

  let history = {
    get action() {
      return action;
    },

    get location() {
      return getLocation(window, globalHistory);
    },

    listen(fn) {
      if (listener) {
        throw new Error("A history only accepts one active listener");
      }

      window.addEventListener(PopStateEventType, handlePop);
      listener = fn;
      return () => {
        window.removeEventListener(PopStateEventType, handlePop);
        listener = null;
      };
    },

    createHref(to) {
      return createHref(window, to);
    },

    encodeLocation(location) {
      // Encode a Location the same way window.location would
      let url = createURL(router_createPath(location));
      return _extends({}, location, {
        pathname: url.pathname,
        search: url.search,
        hash: url.hash
      });
    },

    push,
    replace,

    go(n) {
      return globalHistory.go(n);
    }

  };
  return history;
} //#endregion

var ResultType;

(function (ResultType) {
  ResultType["data"] = "data";
  ResultType["deferred"] = "deferred";
  ResultType["redirect"] = "redirect";
  ResultType["error"] = "error";
})(ResultType || (ResultType = {}));

function isIndexRoute(route) {
  return route.index === true;
} // Walk the route tree generating unique IDs where necessary so we are working
// solely with AgnosticDataRouteObject's within the Router


function convertRoutesToDataRoutes(routes, parentPath, allIds) {
  if (parentPath === void 0) {
    parentPath = [];
  }

  if (allIds === void 0) {
    allIds = new Set();
  }

  return routes.map((route, index) => {
    let treePath = [...parentPath, index];
    let id = typeof route.id === "string" ? route.id : treePath.join("-");
    router_invariant(route.index !== true || !route.children, "Cannot specify children on an index route");
    router_invariant(!allIds.has(id), "Found a route id collision on id \"" + id + "\".  Route " + "id's must be globally unique within Data Router usages");
    allIds.add(id);

    if (isIndexRoute(route)) {
      let indexRoute = _extends({}, route, {
        id
      });

      return indexRoute;
    } else {
      let pathOrLayoutRoute = _extends({}, route, {
        id,
        children: route.children ? convertRoutesToDataRoutes(route.children, treePath, allIds) : undefined
      });

      return pathOrLayoutRoute;
    }
  });
}
/**
 * Matches the given routes to a location and returns the match data.
 *
 * @see https://reactrouter.com/docs/en/v6/utils/match-routes
 */

function matchRoutes(routes, locationArg, basename) {
  if (basename === void 0) {
    basename = "/";
  }

  let location = typeof locationArg === "string" ? parsePath(locationArg) : locationArg;
  let pathname = stripBasename(location.pathname || "/", basename);

  if (pathname == null) {
    return null;
  }

  let branches = flattenRoutes(routes);
  rankRouteBranches(branches);
  let matches = null;

  for (let i = 0; matches == null && i < branches.length; ++i) {
    matches = matchRouteBranch(branches[i], // Incoming pathnames are generally encoded from either window.location
    // or from router.navigate, but we want to match against the unencoded
    // paths in the route definitions.  Memory router locations won't be
    // encoded here but there also shouldn't be anything to decode so this
    // should be a safe operation.  This avoids needing matchRoutes to be
    // history-aware.
    safelyDecodeURI(pathname));
  }

  return matches;
}

function flattenRoutes(routes, branches, parentsMeta, parentPath) {
  if (branches === void 0) {
    branches = [];
  }

  if (parentsMeta === void 0) {
    parentsMeta = [];
  }

  if (parentPath === void 0) {
    parentPath = "";
  }

  routes.forEach((route, index) => {
    let meta = {
      relativePath: route.path || "",
      caseSensitive: route.caseSensitive === true,
      childrenIndex: index,
      route
    };

    if (meta.relativePath.startsWith("/")) {
      router_invariant(meta.relativePath.startsWith(parentPath), "Absolute route path \"" + meta.relativePath + "\" nested under path " + ("\"" + parentPath + "\" is not valid. An absolute child route path ") + "must start with the combined path of all its parent routes.");
      meta.relativePath = meta.relativePath.slice(parentPath.length);
    }

    let path = router_joinPaths([parentPath, meta.relativePath]);
    let routesMeta = parentsMeta.concat(meta); // Add the children before adding this route to the array so we traverse the
    // route tree depth-first and child routes appear before their parents in
    // the "flattened" version.

    if (route.children && route.children.length > 0) {
      router_invariant( // Our types know better, but runtime JS may not!
      // @ts-expect-error
      route.index !== true, "Index routes must not have child routes. Please remove " + ("all child routes from route path \"" + path + "\"."));
      flattenRoutes(route.children, branches, routesMeta, path);
    } // Routes without a path shouldn't ever match by themselves unless they are
    // index routes, so don't add them to the list of possible branches.


    if (route.path == null && !route.index) {
      return;
    }

    branches.push({
      path,
      score: computeScore(path, route.index),
      routesMeta
    });
  });
  return branches;
}

function rankRouteBranches(branches) {
  branches.sort((a, b) => a.score !== b.score ? b.score - a.score // Higher score first
  : compareIndexes(a.routesMeta.map(meta => meta.childrenIndex), b.routesMeta.map(meta => meta.childrenIndex)));
}

const paramRe = /^:\w+$/;
const dynamicSegmentValue = 3;
const indexRouteValue = 2;
const emptySegmentValue = 1;
const staticSegmentValue = 10;
const splatPenalty = -2;

const isSplat = s => s === "*";

function computeScore(path, index) {
  let segments = path.split("/");
  let initialScore = segments.length;

  if (segments.some(isSplat)) {
    initialScore += splatPenalty;
  }

  if (index) {
    initialScore += indexRouteValue;
  }

  return segments.filter(s => !isSplat(s)).reduce((score, segment) => score + (paramRe.test(segment) ? dynamicSegmentValue : segment === "" ? emptySegmentValue : staticSegmentValue), initialScore);
}

function compareIndexes(a, b) {
  let siblings = a.length === b.length && a.slice(0, -1).every((n, i) => n === b[i]);
  return siblings ? // If two routes are siblings, we should try to match the earlier sibling
  // first. This allows people to have fine-grained control over the matching
  // behavior by simply putting routes with identical paths in the order they
  // want them tried.
  a[a.length - 1] - b[b.length - 1] : // Otherwise, it doesn't really make sense to rank non-siblings by index,
  // so they sort equally.
  0;
}

function matchRouteBranch(branch, pathname) {
  let {
    routesMeta
  } = branch;
  let matchedParams = {};
  let matchedPathname = "/";
  let matches = [];

  for (let i = 0; i < routesMeta.length; ++i) {
    let meta = routesMeta[i];
    let end = i === routesMeta.length - 1;
    let remainingPathname = matchedPathname === "/" ? pathname : pathname.slice(matchedPathname.length) || "/";
    let match = router_matchPath({
      path: meta.relativePath,
      caseSensitive: meta.caseSensitive,
      end
    }, remainingPathname);
    if (!match) return null;
    Object.assign(matchedParams, match.params);
    let route = meta.route;
    matches.push({
      // TODO: Can this as be avoided?
      params: matchedParams,
      pathname: router_joinPaths([matchedPathname, match.pathname]),
      pathnameBase: normalizePathname(router_joinPaths([matchedPathname, match.pathnameBase])),
      route
    });

    if (match.pathnameBase !== "/") {
      matchedPathname = router_joinPaths([matchedPathname, match.pathnameBase]);
    }
  }

  return matches;
}
/**
 * Returns a path with params interpolated.
 *
 * @see https://reactrouter.com/docs/en/v6/utils/generate-path
 */


function generatePath(path, params) {
  if (params === void 0) {
    params = {};
  }

  return path.replace(/:(\w+)/g, (_, key) => {
    router_invariant(params[key] != null, "Missing \":" + key + "\" param");
    return params[key];
  }).replace(/(\/?)\*/, (_, prefix, __, str) => {
    const star = "*";

    if (params[star] == null) {
      // If no splat was provided, trim the trailing slash _unless_ it's
      // the entire path
      return str === "/*" ? "/" : "";
    } // Apply the splat


    return "" + prefix + params[star];
  });
}
/**
 * Performs pattern matching on a URL pathname and returns information about
 * the match.
 *
 * @see https://reactrouter.com/docs/en/v6/utils/match-path
 */

function router_matchPath(pattern, pathname) {
  if (typeof pattern === "string") {
    pattern = {
      path: pattern,
      caseSensitive: false,
      end: true
    };
  }

  let [matcher, paramNames] = compilePath(pattern.path, pattern.caseSensitive, pattern.end);
  let match = pathname.match(matcher);
  if (!match) return null;
  let matchedPathname = match[0];
  let pathnameBase = matchedPathname.replace(/(.)\/+$/, "$1");
  let captureGroups = match.slice(1);
  let params = paramNames.reduce((memo, paramName, index) => {
    // We need to compute the pathnameBase here using the raw splat value
    // instead of using params["*"] later because it will be decoded then
    if (paramName === "*") {
      let splatValue = captureGroups[index] || "";
      pathnameBase = matchedPathname.slice(0, matchedPathname.length - splatValue.length).replace(/(.)\/+$/, "$1");
    }

    memo[paramName] = safelyDecodeURIComponent(captureGroups[index] || "", paramName);
    return memo;
  }, {});
  return {
    params,
    pathname: matchedPathname,
    pathnameBase,
    pattern
  };
}

function compilePath(path, caseSensitive, end) {
  if (caseSensitive === void 0) {
    caseSensitive = false;
  }

  if (end === void 0) {
    end = true;
  }

  warning(path === "*" || !path.endsWith("*") || path.endsWith("/*"), "Route path \"" + path + "\" will be treated as if it were " + ("\"" + path.replace(/\*$/, "/*") + "\" because the `*` character must ") + "always follow a `/` in the pattern. To get rid of this warning, " + ("please change the route path to \"" + path.replace(/\*$/, "/*") + "\"."));
  let paramNames = [];
  let regexpSource = "^" + path.replace(/\/*\*?$/, "") // Ignore trailing / and /*, we'll handle it below
  .replace(/^\/*/, "/") // Make sure it has a leading /
  .replace(/[\\.*+^$?{}|()[\]]/g, "\\$&") // Escape special regex chars
  .replace(/:(\w+)/g, (_, paramName) => {
    paramNames.push(paramName);
    return "([^\\/]+)";
  });

  if (path.endsWith("*")) {
    paramNames.push("*");
    regexpSource += path === "*" || path === "/*" ? "(.*)$" // Already matched the initial /, just match the rest
    : "(?:\\/(.+)|\\/*)$"; // Don't include the / in params["*"]
  } else if (end) {
    // When matching to the end, ignore trailing slashes
    regexpSource += "\\/*$";
  } else if (path !== "" && path !== "/") {
    // If our path is non-empty and contains anything beyond an initial slash,
    // then we have _some_ form of path in our regex so we should expect to
    // match only if we find the end of this path segment.  Look for an optional
    // non-captured trailing slash (to match a portion of the URL) or the end
    // of the path (if we've matched to the end).  We used to do this with a
    // word boundary but that gives false positives on routes like
    // /user-preferences since `-` counts as a word boundary.
    regexpSource += "(?:(?=\\/|$))";
  } else ;

  let matcher = new RegExp(regexpSource, caseSensitive ? undefined : "i");
  return [matcher, paramNames];
}

function safelyDecodeURI(value) {
  try {
    return decodeURI(value);
  } catch (error) {
    warning(false, "The URL path \"" + value + "\" could not be decoded because it is is a " + "malformed URL segment. This is probably due to a bad percent " + ("encoding (" + error + ")."));
    return value;
  }
}

function safelyDecodeURIComponent(value, paramName) {
  try {
    return decodeURIComponent(value);
  } catch (error) {
    warning(false, "The value for the URL param \"" + paramName + "\" will not be decoded because" + (" the string \"" + value + "\" is a malformed URL segment. This is probably") + (" due to a bad percent encoding (" + error + ")."));
    return value;
  }
}
/**
 * @private
 */


function stripBasename(pathname, basename) {
  if (basename === "/") return pathname;

  if (!pathname.toLowerCase().startsWith(basename.toLowerCase())) {
    return null;
  } // We want to leave trailing slash behavior in the user's control, so if they
  // specify a basename with a trailing slash, we should support it


  let startIndex = basename.endsWith("/") ? basename.length - 1 : basename.length;
  let nextChar = pathname.charAt(startIndex);

  if (nextChar && nextChar !== "/") {
    // pathname does not start with basename/
    return null;
  }

  return pathname.slice(startIndex) || "/";
}
function router_invariant(value, message) {
  if (value === false || value === null || typeof value === "undefined") {
    throw new Error(message);
  }
}
/**
 * @private
 */

function warning(cond, message) {
  if (!cond) {
    // eslint-disable-next-line no-console
    if (typeof console !== "undefined") console.warn(message);

    try {
      // Welcome to debugging React Router!
      //
      // This error is thrown as a convenience so you can more easily
      // find the source for a warning that appears in the console by
      // enabling "pause on exceptions" in your JavaScript debugger.
      throw new Error(message); // eslint-disable-next-line no-empty
    } catch (e) {}
  }
}
/**
 * Returns a resolved path object relative to the given pathname.
 *
 * @see https://reactrouter.com/docs/en/v6/utils/resolve-path
 */

function resolvePath(to, fromPathname) {
  if (fromPathname === void 0) {
    fromPathname = "/";
  }

  let {
    pathname: toPathname,
    search = "",
    hash = ""
  } = typeof to === "string" ? parsePath(to) : to;
  let pathname = toPathname ? toPathname.startsWith("/") ? toPathname : resolvePathname(toPathname, fromPathname) : fromPathname;
  return {
    pathname,
    search: normalizeSearch(search),
    hash: normalizeHash(hash)
  };
}

function resolvePathname(relativePath, fromPathname) {
  let segments = fromPathname.replace(/\/+$/, "").split("/");
  let relativeSegments = relativePath.split("/");
  relativeSegments.forEach(segment => {
    if (segment === "..") {
      // Keep the root "" segment so the pathname starts at /
      if (segments.length > 1) segments.pop();
    } else if (segment !== ".") {
      segments.push(segment);
    }
  });
  return segments.length > 1 ? segments.join("/") : "/";
}

function getInvalidPathError(char, field, dest, path) {
  return "Cannot include a '" + char + "' character in a manually specified " + ("`to." + field + "` field [" + JSON.stringify(path) + "].  Please separate it out to the ") + ("`to." + dest + "` field. Alternatively you may provide the full path as ") + "a string in <Link to=\"...\"> and the router will parse it for you.";
}
/**
 * @private
 *
 * When processing relative navigation we want to ignore ancestor routes that
 * do not contribute to the path, such that index/pathless layout routes don't
 * interfere.
 *
 * For example, when moving a route element into an index route and/or a
 * pathless layout route, relative link behavior contained within should stay
 * the same.  Both of the following examples should link back to the root:
 *
 *   <Route path="/">
 *     <Route path="accounts" element={<Link to=".."}>
 *   </Route>
 *
 *   <Route path="/">
 *     <Route path="accounts">
 *       <Route element={<AccountsLayout />}>       // <-- Does not contribute
 *         <Route index element={<Link to=".."} />  // <-- Does not contribute
 *       </Route
 *     </Route>
 *   </Route>
 */


function getPathContributingMatches(matches) {
  return matches.filter((match, index) => index === 0 || match.route.path && match.route.path.length > 0);
}
/**
 * @private
 */

function resolveTo(toArg, routePathnames, locationPathname, isPathRelative) {
  if (isPathRelative === void 0) {
    isPathRelative = false;
  }

  let to;

  if (typeof toArg === "string") {
    to = parsePath(toArg);
  } else {
    to = _extends({}, toArg);
    router_invariant(!to.pathname || !to.pathname.includes("?"), getInvalidPathError("?", "pathname", "search", to));
    router_invariant(!to.pathname || !to.pathname.includes("#"), getInvalidPathError("#", "pathname", "hash", to));
    router_invariant(!to.search || !to.search.includes("#"), getInvalidPathError("#", "search", "hash", to));
  }

  let isEmptyPath = toArg === "" || to.pathname === "";
  let toPathname = isEmptyPath ? "/" : to.pathname;
  let from; // Routing is relative to the current pathname if explicitly requested.
  //
  // If a pathname is explicitly provided in `to`, it should be relative to the
  // route context. This is explained in `Note on `<Link to>` values` in our
  // migration guide from v5 as a means of disambiguation between `to` values
  // that begin with `/` and those that do not. However, this is problematic for
  // `to` values that do not provide a pathname. `to` can simply be a search or
  // hash string, in which case we should assume that the navigation is relative
  // to the current location's pathname and *not* the route pathname.

  if (isPathRelative || toPathname == null) {
    from = locationPathname;
  } else {
    let routePathnameIndex = routePathnames.length - 1;

    if (toPathname.startsWith("..")) {
      let toSegments = toPathname.split("/"); // Each leading .. segment means "go up one route" instead of "go up one
      // URL segment".  This is a key difference from how <a href> works and a
      // major reason we call this a "to" value instead of a "href".

      while (toSegments[0] === "..") {
        toSegments.shift();
        routePathnameIndex -= 1;
      }

      to.pathname = toSegments.join("/");
    } // If there are more ".." segments than parent routes, resolve relative to
    // the root / URL.


    from = routePathnameIndex >= 0 ? routePathnames[routePathnameIndex] : "/";
  }

  let path = resolvePath(to, from); // Ensure the pathname has a trailing slash if the original "to" had one

  let hasExplicitTrailingSlash = toPathname && toPathname !== "/" && toPathname.endsWith("/"); // Or if this was a link to the current path which has a trailing slash

  let hasCurrentTrailingSlash = (isEmptyPath || toPathname === ".") && locationPathname.endsWith("/");

  if (!path.pathname.endsWith("/") && (hasExplicitTrailingSlash || hasCurrentTrailingSlash)) {
    path.pathname += "/";
  }

  return path;
}
/**
 * @private
 */

function getToPathname(to) {
  // Empty strings should be treated the same as / paths
  return to === "" || to.pathname === "" ? "/" : typeof to === "string" ? parsePath(to).pathname : to.pathname;
}
/**
 * @private
 */

const router_joinPaths = paths => paths.join("/").replace(/\/\/+/g, "/");
/**
 * @private
 */

const normalizePathname = pathname => pathname.replace(/\/+$/, "").replace(/^\/*/, "/");
/**
 * @private
 */

const normalizeSearch = search => !search || search === "?" ? "" : search.startsWith("?") ? search : "?" + search;
/**
 * @private
 */

const normalizeHash = hash => !hash || hash === "#" ? "" : hash.startsWith("#") ? hash : "#" + hash;
/**
 * This is a shortcut for creating `application/json` responses. Converts `data`
 * to JSON and sets the `Content-Type` header.
 */

const json = function json(data, init) {
  if (init === void 0) {
    init = {};
  }

  let responseInit = typeof init === "number" ? {
    status: init
  } : init;
  let headers = new Headers(responseInit.headers);

  if (!headers.has("Content-Type")) {
    headers.set("Content-Type", "application/json; charset=utf-8");
  }

  return new Response(JSON.stringify(data), _extends({}, responseInit, {
    headers
  }));
};
class router_AbortedDeferredError extends Error {}
class DeferredData {
  constructor(data) {
    this.pendingKeys = new Set();
    this.subscriber = undefined;
    router_invariant(data && typeof data === "object" && !Array.isArray(data), "defer() only accepts plain objects"); // Set up an AbortController + Promise we can race against to exit early
    // cancellation

    let reject;
    this.abortPromise = new Promise((_, r) => reject = r);
    this.controller = new AbortController();

    let onAbort = () => reject(new router_AbortedDeferredError("Deferred data aborted"));

    this.unlistenAbortSignal = () => this.controller.signal.removeEventListener("abort", onAbort);

    this.controller.signal.addEventListener("abort", onAbort);
    this.data = Object.entries(data).reduce((acc, _ref) => {
      let [key, value] = _ref;
      return Object.assign(acc, {
        [key]: this.trackPromise(key, value)
      });
    }, {});
  }

  trackPromise(key, value) {
    if (!(value instanceof Promise)) {
      return value;
    }

    this.pendingKeys.add(key); // We store a little wrapper promise that will be extended with
    // _data/_error props upon resolve/reject

    let promise = Promise.race([value, this.abortPromise]).then(data => this.onSettle(promise, key, null, data), error => this.onSettle(promise, key, error)); // Register rejection listeners to avoid uncaught promise rejections on
    // errors or aborted deferred values

    promise.catch(() => {});
    Object.defineProperty(promise, "_tracked", {
      get: () => true
    });
    return promise;
  }

  onSettle(promise, key, error, data) {
    if (this.controller.signal.aborted && error instanceof router_AbortedDeferredError) {
      this.unlistenAbortSignal();
      Object.defineProperty(promise, "_error", {
        get: () => error
      });
      return Promise.reject(error);
    }

    this.pendingKeys.delete(key);

    if (this.done) {
      // Nothing left to abort!
      this.unlistenAbortSignal();
    }

    const subscriber = this.subscriber;

    if (error) {
      Object.defineProperty(promise, "_error", {
        get: () => error
      });
      subscriber && subscriber(false);
      return Promise.reject(error);
    }

    Object.defineProperty(promise, "_data", {
      get: () => data
    });
    subscriber && subscriber(false);
    return data;
  }

  subscribe(fn) {
    this.subscriber = fn;
  }

  cancel() {
    this.controller.abort();
    this.pendingKeys.forEach((v, k) => this.pendingKeys.delete(k));
    let subscriber = this.subscriber;
    subscriber && subscriber(true);
  }

  async resolveData(signal) {
    let aborted = false;

    if (!this.done) {
      let onAbort = () => this.cancel();

      signal.addEventListener("abort", onAbort);
      aborted = await new Promise(resolve => {
        this.subscribe(aborted => {
          signal.removeEventListener("abort", onAbort);

          if (aborted || this.done) {
            resolve(aborted);
          }
        });
      });
    }

    return aborted;
  }

  get done() {
    return this.pendingKeys.size === 0;
  }

  get unwrappedData() {
    router_invariant(this.data !== null && this.done, "Can only unwrap data on initialized and settled deferreds");
    return Object.entries(this.data).reduce((acc, _ref2) => {
      let [key, value] = _ref2;
      return Object.assign(acc, {
        [key]: unwrapTrackedPromise(value)
      });
    }, {});
  }

}

function isTrackedPromise(value) {
  return value instanceof Promise && value._tracked === true;
}

function unwrapTrackedPromise(value) {
  if (!isTrackedPromise(value)) {
    return value;
  }

  if (value._error) {
    throw value._error;
  }

  return value._data;
}

function defer(data) {
  return new DeferredData(data);
}
/**
 * A redirect response. Sets the status code and the `Location` header.
 * Defaults to "302 Found".
 */

const redirect = function redirect(url, init) {
  if (init === void 0) {
    init = 302;
  }

  let responseInit = init;

  if (typeof responseInit === "number") {
    responseInit = {
      status: responseInit
    };
  } else if (typeof responseInit.status === "undefined") {
    responseInit.status = 302;
  }

  let headers = new Headers(responseInit.headers);
  headers.set("Location", url);
  return new Response(null, _extends({}, responseInit, {
    headers
  }));
};
/**
 * @private
 * Utility class we use to hold auto-unwrapped 4xx/5xx Response bodies
 */

class ErrorResponse {
  constructor(status, statusText, data) {
    this.status = status;
    this.statusText = statusText || "";
    this.data = data;
  }

}
/**
 * Check if the given error is an ErrorResponse generated from a 4xx/5xx
 * Response throw from an action/loader
 */

function isRouteErrorResponse(e) {
  return e instanceof ErrorResponse;
}

const IDLE_NAVIGATION = {
  state: "idle",
  location: undefined,
  formMethod: undefined,
  formAction: undefined,
  formEncType: undefined,
  formData: undefined
};
const IDLE_FETCHER = {
  state: "idle",
  data: undefined,
  formMethod: undefined,
  formAction: undefined,
  formEncType: undefined,
  formData: undefined
};
const isBrowser = typeof window !== "undefined" && typeof window.document !== "undefined" && typeof window.document.createElement !== "undefined";
const isServer = !isBrowser; //#endregion
////////////////////////////////////////////////////////////////////////////////
//#region createRouter
////////////////////////////////////////////////////////////////////////////////

/**
 * Create a router and listen to history POP navigations
 */

function router_createRouter(init) {
  router_invariant(init.routes.length > 0, "You must provide a non-empty routes array to createRouter");
  let dataRoutes = convertRoutesToDataRoutes(init.routes); // Cleanup function for history

  let unlistenHistory = null; // Externally-provided functions to call on all state changes

  let subscribers = new Set(); // Externally-provided object to hold scroll restoration locations during routing

  let savedScrollPositions = null; // Externally-provided function to get scroll restoration keys

  let getScrollRestorationKey = null; // Externally-provided function to get current scroll position

  let getScrollPosition = null; // One-time flag to control the initial hydration scroll restoration.  Because
  // we don't get the saved positions from <ScrollRestoration /> until _after_
  // the initial render, we need to manually trigger a separate updateState to
  // send along the restoreScrollPosition

  let initialScrollRestored = false;
  let initialMatches = matchRoutes(dataRoutes, init.history.location, init.basename);
  let initialErrors = null;

  if (initialMatches == null) {
    // If we do not match a user-provided-route, fall back to the root
    // to allow the error boundary to take over
    let {
      matches,
      route,
      error
    } = getNotFoundMatches(dataRoutes);
    initialMatches = matches;
    initialErrors = {
      [route.id]: error
    };
  }

  let initialized = !initialMatches.some(m => m.route.loader) || init.hydrationData != null;
  let router;
  let state = {
    historyAction: init.history.action,
    location: init.history.location,
    matches: initialMatches,
    initialized,
    navigation: IDLE_NAVIGATION,
    restoreScrollPosition: null,
    preventScrollReset: false,
    revalidation: "idle",
    loaderData: init.hydrationData && init.hydrationData.loaderData || {},
    actionData: init.hydrationData && init.hydrationData.actionData || null,
    errors: init.hydrationData && init.hydrationData.errors || initialErrors,
    fetchers: new Map()
  }; // -- Stateful internal variables to manage navigations --
  // Current navigation in progress (to be committed in completeNavigation)

  let pendingAction = Action.Pop; // Should the current navigation prevent the scroll reset if scroll cannot
  // be restored?

  let pendingPreventScrollReset = false; // AbortController for the active navigation

  let pendingNavigationController; // We use this to avoid touching history in completeNavigation if a
  // revalidation is entirely uninterrupted

  let isUninterruptedRevalidation = false; // Use this internal flag to force revalidation of all loaders:
  //  - submissions (completed or interrupted)
  //  - useRevalidate()
  //  - X-Remix-Revalidate (from redirect)

  let isRevalidationRequired = false; // Use this internal array to capture routes that require revalidation due
  // to a cancelled deferred on action submission

  let cancelledDeferredRoutes = []; // Use this internal array to capture fetcher loads that were cancelled by an
  // action navigation and require revalidation

  let cancelledFetcherLoads = []; // AbortControllers for any in-flight fetchers

  let fetchControllers = new Map(); // Track loads based on the order in which they started

  let incrementingLoadId = 0; // Track the outstanding pending navigation data load to be compared against
  // the globally incrementing load when a fetcher load lands after a completed
  // navigation

  let pendingNavigationLoadId = -1; // Fetchers that triggered data reloads as a result of their actions

  let fetchReloadIds = new Map(); // Fetchers that triggered redirect navigations from their actions

  let fetchRedirectIds = new Set(); // Most recent href/match for fetcher.load calls for fetchers

  let fetchLoadMatches = new Map(); // Store DeferredData instances for active route matches.  When a
  // route loader returns defer() we stick one in here.  Then, when a nested
  // promise resolves we update loaderData.  If a new navigation starts we
  // cancel active deferreds for eliminated routes.

  let activeDeferreds = new Map(); // Initialize the router, all side effects should be kicked off from here.
  // Implemented as a Fluent API for ease of:
  //   let router = createRouter(init).initialize();

  function initialize() {
    // If history informs us of a POP navigation, start the navigation but do not update
    // state.  We'll update our own state once the navigation completes
    unlistenHistory = init.history.listen(_ref => {
      let {
        action: historyAction,
        location
      } = _ref;
      return startNavigation(historyAction, location);
    }); // Kick off initial data load if needed.  Use Pop to avoid modifying history

    if (!state.initialized) {
      startNavigation(Action.Pop, state.location);
    }

    return router;
  } // Clean up a router and it's side effects


  function dispose() {
    if (unlistenHistory) {
      unlistenHistory();
    }

    subscribers.clear();
    pendingNavigationController && pendingNavigationController.abort();
    state.fetchers.forEach((_, key) => deleteFetcher(key));
  } // Subscribe to state updates for the router


  function subscribe(fn) {
    subscribers.add(fn);
    return () => subscribers.delete(fn);
  } // Update our state and notify the calling context of the change


  function updateState(newState) {
    state = _extends({}, state, newState);
    subscribers.forEach(subscriber => subscriber(state));
  } // Complete a navigation returning the state.navigation back to the IDLE_NAVIGATION
  // and setting state.[historyAction/location/matches] to the new route.
  // - Location is a required param
  // - Navigation will always be set to IDLE_NAVIGATION
  // - Can pass any other state in newState


  function completeNavigation(location, newState) {
    var _state$navigation$for;

    // Deduce if we're in a loading/actionReload state:
    // - We have committed actionData in the store
    // - The current navigation was a submission
    // - We're past the submitting state and into the loading state
    // - The location we've finished loading is different from the submission
    //   location, indicating we redirected from the action (avoids false
    //   positives for loading/submissionRedirect when actionData returned
    //   on a prior submission)
    let isActionReload = state.actionData != null && state.navigation.formMethod != null && state.navigation.state === "loading" && ((_state$navigation$for = state.navigation.formAction) == null ? void 0 : _state$navigation$for.split("?")[0]) === location.pathname; // Always preserve any existing loaderData from re-used routes

    let newLoaderData = newState.loaderData ? {
      loaderData: mergeLoaderData(state.loaderData, newState.loaderData, newState.matches || [])
    } : {};
    updateState(_extends({}, isActionReload ? {} : {
      actionData: null
    }, newState, newLoaderData, {
      historyAction: pendingAction,
      location,
      initialized: true,
      navigation: IDLE_NAVIGATION,
      revalidation: "idle",
      // Don't restore on submission navigations
      restoreScrollPosition: state.navigation.formData ? false : getSavedScrollPosition(location, newState.matches || state.matches),
      preventScrollReset: pendingPreventScrollReset
    }));

    if (isUninterruptedRevalidation) ; else if (pendingAction === Action.Pop) ; else if (pendingAction === Action.Push) {
      init.history.push(location, location.state);
    } else if (pendingAction === Action.Replace) {
      init.history.replace(location, location.state);
    } // Reset stateful navigation vars


    pendingAction = Action.Pop;
    pendingPreventScrollReset = false;
    isUninterruptedRevalidation = false;
    isRevalidationRequired = false;
    cancelledDeferredRoutes = [];
    cancelledFetcherLoads = [];
  } // Trigger a navigation event, which can either be a numerical POP or a PUSH
  // replace with an optional submission


  async function navigate(to, opts) {
    if (typeof to === "number") {
      init.history.go(to);
      return;
    }

    let {
      path,
      submission,
      error
    } = normalizeNavigateOptions(to, opts);
    let location = createLocation(state.location, path, opts && opts.state); // When using navigate as a PUSH/REPLACE we aren't reading an already-encoded
    // URL from window.location, so we need to encode it here so the behavior
    // remains the same as POP and non-data-router usages.  new URL() does all
    // the same encoding we'd get from a history.pushState/window.location read
    // without having to touch history

    location = init.history.encodeLocation(location);
    let historyAction = (opts && opts.replace) === true || submission != null ? Action.Replace : Action.Push;
    let preventScrollReset = opts && "preventScrollReset" in opts ? opts.preventScrollReset === true : undefined;
    return await startNavigation(historyAction, location, {
      submission,
      // Send through the formData serialization error if we have one so we can
      // render at the right error boundary after we match routes
      pendingError: error,
      preventScrollReset,
      replace: opts && opts.replace
    });
  } // Revalidate all current loaders.  If a navigation is in progress or if this
  // is interrupted by a navigation, allow this to "succeed" by calling all
  // loaders during the next loader round


  function revalidate() {
    interruptActiveLoads();
    updateState({
      revalidation: "loading"
    }); // If we're currently submitting an action, we don't need to start a new
    // navigation, we'll just let the follow up loader execution call all loaders

    if (state.navigation.state === "submitting") {
      return;
    } // If we're currently in an idle state, start a new navigation for the current
    // action/location and mark it as uninterrupted, which will skip the history
    // update in completeNavigation


    if (state.navigation.state === "idle") {
      startNavigation(state.historyAction, state.location, {
        startUninterruptedRevalidation: true
      });
      return;
    } // Otherwise, if we're currently in a loading state, just start a new
    // navigation to the navigation.location but do not trigger an uninterrupted
    // revalidation so that history correctly updates once the navigation completes


    startNavigation(pendingAction || state.historyAction, state.navigation.location, {
      overrideNavigation: state.navigation
    });
  } // Start a navigation to the given action/location.  Can optionally provide a
  // overrideNavigation which will override the normalLoad in the case of a redirect
  // navigation


  async function startNavigation(historyAction, location, opts) {
    // Abort any in-progress navigations and start a new one. Unset any ongoing
    // uninterrupted revalidations unless told otherwise, since we want this
    // new navigation to update history normally
    pendingNavigationController && pendingNavigationController.abort();
    pendingNavigationController = null;
    pendingAction = historyAction;
    isUninterruptedRevalidation = (opts && opts.startUninterruptedRevalidation) === true; // Save the current scroll position every time we start a new navigation,
    // and track whether we should reset scroll on completion

    saveScrollPosition(state.location, state.matches);
    pendingPreventScrollReset = (opts && opts.preventScrollReset) === true;
    let loadingNavigation = opts && opts.overrideNavigation;
    let matches = matchRoutes(dataRoutes, location, init.basename); // Short circuit with a 404 on the root error boundary if we match nothing

    if (!matches) {
      let {
        matches: notFoundMatches,
        route,
        error
      } = getNotFoundMatches(dataRoutes); // Cancel all pending deferred on 404s since we don't keep any routes

      cancelActiveDeferreds();
      completeNavigation(location, {
        matches: notFoundMatches,
        loaderData: {},
        errors: {
          [route.id]: error
        }
      });
      return;
    } // Short circuit if it's only a hash change


    if (isHashChangeOnly(state.location, location)) {
      completeNavigation(location, {
        matches
      });
      return;
    } // Create a controller/Request for this navigation


    pendingNavigationController = new AbortController();
    let request = createRequest(location, pendingNavigationController.signal, opts && opts.submission);
    let pendingActionData;
    let pendingError;

    if (opts && opts.pendingError) {
      // If we have a pendingError, it means the user attempted a GET submission
      // with binary FormData so assign here and skip to handleLoaders.  That
      // way we handle calling loaders above the boundary etc.  It's not really
      // different from an actionError in that sense.
      pendingError = {
        [findNearestBoundary(matches).route.id]: opts.pendingError
      };
    } else if (opts && opts.submission) {
      // Call action if we received an action submission
      let actionOutput = await handleAction(request, location, opts.submission, matches, {
        replace: opts.replace
      });

      if (actionOutput.shortCircuited) {
        return;
      }

      pendingActionData = actionOutput.pendingActionData;
      pendingError = actionOutput.pendingActionError;

      let navigation = _extends({
        state: "loading",
        location
      }, opts.submission);

      loadingNavigation = navigation;
    } // Call loaders


    let {
      shortCircuited,
      loaderData,
      errors
    } = await handleLoaders(request, location, matches, loadingNavigation, opts && opts.submission, opts && opts.replace, pendingActionData, pendingError);

    if (shortCircuited) {
      return;
    } // Clean up now that the action/loaders have completed.  Don't clean up if
    // we short circuited because pendingNavigationController will have already
    // been assigned to a new controller for the next navigation


    pendingNavigationController = null;
    completeNavigation(location, {
      matches,
      loaderData,
      errors
    });
  } // Call the action matched by the leaf route for this navigation and handle
  // redirects/errors


  async function handleAction(request, location, submission, matches, opts) {
    interruptActiveLoads(); // Put us in a submitting state

    let navigation = _extends({
      state: "submitting",
      location
    }, submission);

    updateState({
      navigation
    }); // Call our action and get the result

    let result;
    let actionMatch = getTargetMatch(matches, location);

    if (!actionMatch.route.action) {
      result = getMethodNotAllowedResult(location);
    } else {
      result = await callLoaderOrAction("action", request, actionMatch, matches, router.basename);

      if (request.signal.aborted) {
        return {
          shortCircuited: true
        };
      }
    }

    if (isRedirectResult(result)) {
      let redirectNavigation = _extends({
        state: "loading",
        location: createLocation(state.location, result.location)
      }, submission);

      await startRedirectNavigation(result, redirectNavigation, opts && opts.replace);
      return {
        shortCircuited: true
      };
    }

    if (isErrorResult(result)) {
      // Store off the pending error - we use it to determine which loaders
      // to call and will commit it when we complete the navigation
      let boundaryMatch = findNearestBoundary(matches, actionMatch.route.id); // By default, all submissions are REPLACE navigations, but if the
      // action threw an error that'll be rendered in an errorElement, we fall
      // back to PUSH so that the user can use the back button to get back to
      // the pre-submission form location to try again

      if ((opts && opts.replace) !== true) {
        pendingAction = Action.Push;
      }

      return {
        pendingActionError: {
          [boundaryMatch.route.id]: result.error
        }
      };
    }

    if (isDeferredResult(result)) {
      throw new Error("defer() is not supported in actions");
    }

    return {
      pendingActionData: {
        [actionMatch.route.id]: result.data
      }
    };
  } // Call all applicable loaders for the given matches, handling redirects,
  // errors, etc.


  async function handleLoaders(request, location, matches, overrideNavigation, submission, replace, pendingActionData, pendingError) {
    // Figure out the right navigation we want to use for data loading
    let loadingNavigation = overrideNavigation;

    if (!loadingNavigation) {
      let navigation = {
        state: "loading",
        location,
        formMethod: undefined,
        formAction: undefined,
        formEncType: undefined,
        formData: undefined
      };
      loadingNavigation = navigation;
    }

    let [matchesToLoad, revalidatingFetchers] = getMatchesToLoad(state, matches, submission, location, isRevalidationRequired, cancelledDeferredRoutes, cancelledFetcherLoads, pendingActionData, pendingError, fetchLoadMatches); // Cancel pending deferreds for no-longer-matched routes or routes we're
    // about to reload.  Note that if this is an action reload we would have
    // already cancelled all pending deferreds so this would be a no-op

    cancelActiveDeferreds(routeId => !(matches && matches.some(m => m.route.id === routeId)) || matchesToLoad && matchesToLoad.some(m => m.route.id === routeId)); // Short circuit if we have no loaders to run

    if (matchesToLoad.length === 0 && revalidatingFetchers.length === 0) {
      completeNavigation(location, {
        matches,
        loaderData: mergeLoaderData(state.loaderData, {}, matches),
        // Commit pending error if we're short circuiting
        errors: pendingError || null,
        actionData: pendingActionData || null
      });
      return {
        shortCircuited: true
      };
    } // If this is an uninterrupted revalidation, we remain in our current idle
    // state.  If not, we need to switch to our loading state and load data,
    // preserving any new action data or existing action data (in the case of
    // a revalidation interrupting an actionReload)


    if (!isUninterruptedRevalidation) {
      revalidatingFetchers.forEach(_ref2 => {
        let [key] = _ref2;
        let fetcher = state.fetchers.get(key);
        let revalidatingFetcher = {
          state: "loading",
          data: fetcher && fetcher.data,
          formMethod: undefined,
          formAction: undefined,
          formEncType: undefined,
          formData: undefined
        };
        state.fetchers.set(key, revalidatingFetcher);
      });
      updateState(_extends({
        navigation: loadingNavigation,
        actionData: pendingActionData || state.actionData || null
      }, revalidatingFetchers.length > 0 ? {
        fetchers: new Map(state.fetchers)
      } : {}));
    }

    pendingNavigationLoadId = ++incrementingLoadId;
    revalidatingFetchers.forEach(_ref3 => {
      let [key] = _ref3;
      return fetchControllers.set(key, pendingNavigationController);
    });
    let {
      results,
      loaderResults,
      fetcherResults
    } = await callLoadersAndMaybeResolveData(state.matches, matches, matchesToLoad, revalidatingFetchers, request);

    if (request.signal.aborted) {
      return {
        shortCircuited: true
      };
    } // Clean up _after_ loaders have completed.  Don't clean up if we short
    // circuited because fetchControllers would have been aborted and
    // reassigned to new controllers for the next navigation


    revalidatingFetchers.forEach(_ref4 => {
      let [key] = _ref4;
      return fetchControllers.delete(key);
    }); // If any loaders returned a redirect Response, start a new REPLACE navigation

    let redirect = findRedirect(results);

    if (redirect) {
      let redirectNavigation = getLoaderRedirect(state, redirect);
      await startRedirectNavigation(redirect, redirectNavigation, replace);
      return {
        shortCircuited: true
      };
    } // Process and commit output from loaders


    let {
      loaderData,
      errors
    } = processLoaderData(state, matches, matchesToLoad, loaderResults, pendingError, revalidatingFetchers, fetcherResults, activeDeferreds); // Wire up subscribers to update loaderData as promises settle

    activeDeferreds.forEach((deferredData, routeId) => {
      deferredData.subscribe(aborted => {
        // Note: No need to updateState here since the TrackedPromise on
        // loaderData is stable across resolve/reject
        // Remove this instance if we were aborted or if promises have settled
        if (aborted || deferredData.done) {
          activeDeferreds.delete(routeId);
        }
      });
    });
    markFetchRedirectsDone();
    let didAbortFetchLoads = abortStaleFetchLoads(pendingNavigationLoadId);
    return _extends({
      loaderData,
      errors
    }, didAbortFetchLoads || revalidatingFetchers.length > 0 ? {
      fetchers: new Map(state.fetchers)
    } : {});
  }

  function getFetcher(key) {
    return state.fetchers.get(key) || IDLE_FETCHER;
  } // Trigger a fetcher load/submit for the given fetcher key


  function fetch(key, routeId, href, opts) {
    if (isServer) {
      throw new Error("router.fetch() was called during the server render, but it shouldn't be. " + "You are likely calling a useFetcher() method in the body of your component. " + "Try moving it to a useEffect or a callback.");
    }

    if (fetchControllers.has(key)) abortFetcher(key);
    let matches = matchRoutes(dataRoutes, href, init.basename);

    if (!matches) {
      setFetcherError(key, routeId, new ErrorResponse(404, "Not Found", null));
      return;
    }

    let {
      path,
      submission
    } = normalizeNavigateOptions(href, opts, true);
    let match = getTargetMatch(matches, path);

    if (submission) {
      handleFetcherAction(key, routeId, path, match, matches, submission);
      return;
    } // Store off the match so we can call it's shouldRevalidate on subsequent
    // revalidations


    fetchLoadMatches.set(key, [path, match, matches]);
    handleFetcherLoader(key, routeId, path, match, matches);
  } // Call the action for the matched fetcher.submit(), and then handle redirects,
  // errors, and revalidation


  async function handleFetcherAction(key, routeId, path, match, requestMatches, submission) {
    interruptActiveLoads();
    fetchLoadMatches.delete(key);

    if (!match.route.action) {
      let {
        error
      } = getMethodNotAllowedResult(path);
      setFetcherError(key, routeId, error);
      return;
    } // Put this fetcher into it's submitting state


    let existingFetcher = state.fetchers.get(key);

    let fetcher = _extends({
      state: "submitting"
    }, submission, {
      data: existingFetcher && existingFetcher.data
    });

    state.fetchers.set(key, fetcher);
    updateState({
      fetchers: new Map(state.fetchers)
    }); // Call the action for the fetcher

    let abortController = new AbortController();
    let fetchRequest = createRequest(path, abortController.signal, submission);
    fetchControllers.set(key, abortController);
    let actionResult = await callLoaderOrAction("action", fetchRequest, match, requestMatches, router.basename);

    if (fetchRequest.signal.aborted) {
      // We can delete this so long as we weren't aborted by ou our own fetcher
      // re-submit which would have put _new_ controller is in fetchControllers
      if (fetchControllers.get(key) === abortController) {
        fetchControllers.delete(key);
      }

      return;
    }

    if (isRedirectResult(actionResult)) {
      fetchControllers.delete(key);
      fetchRedirectIds.add(key);

      let loadingFetcher = _extends({
        state: "loading"
      }, submission, {
        data: undefined
      });

      state.fetchers.set(key, loadingFetcher);
      updateState({
        fetchers: new Map(state.fetchers)
      });

      let redirectNavigation = _extends({
        state: "loading",
        location: createLocation(state.location, actionResult.location)
      }, submission);

      await startRedirectNavigation(actionResult, redirectNavigation);
      return;
    } // Process any non-redirect errors thrown


    if (isErrorResult(actionResult)) {
      setFetcherError(key, routeId, actionResult.error);
      return;
    }

    if (isDeferredResult(actionResult)) {
      router_invariant(false, "defer() is not supported in actions");
    } // Start the data load for current matches, or the next location if we're
    // in the middle of a navigation


    let nextLocation = state.navigation.location || state.location;
    let revalidationRequest = createRequest(nextLocation, abortController.signal);
    let matches = state.navigation.state !== "idle" ? matchRoutes(dataRoutes, state.navigation.location, init.basename) : state.matches;
    router_invariant(matches, "Didn't find any matches after fetcher action");
    let loadId = ++incrementingLoadId;
    fetchReloadIds.set(key, loadId);

    let loadFetcher = _extends({
      state: "loading",
      data: actionResult.data
    }, submission);

    state.fetchers.set(key, loadFetcher);
    let [matchesToLoad, revalidatingFetchers] = getMatchesToLoad(state, matches, submission, nextLocation, isRevalidationRequired, cancelledDeferredRoutes, cancelledFetcherLoads, {
      [match.route.id]: actionResult.data
    }, undefined, // No need to send through errors since we short circuit above
    fetchLoadMatches); // Put all revalidating fetchers into the loading state, except for the
    // current fetcher which we want to keep in it's current loading state which
    // contains it's action submission info + action data

    revalidatingFetchers.filter(_ref5 => {
      let [staleKey] = _ref5;
      return staleKey !== key;
    }).forEach(_ref6 => {
      let [staleKey] = _ref6;
      let existingFetcher = state.fetchers.get(staleKey);
      let revalidatingFetcher = {
        state: "loading",
        data: existingFetcher && existingFetcher.data,
        formMethod: undefined,
        formAction: undefined,
        formEncType: undefined,
        formData: undefined
      };
      state.fetchers.set(staleKey, revalidatingFetcher);
      fetchControllers.set(staleKey, abortController);
    });
    updateState({
      fetchers: new Map(state.fetchers)
    });
    let {
      results,
      loaderResults,
      fetcherResults
    } = await callLoadersAndMaybeResolveData(state.matches, matches, matchesToLoad, revalidatingFetchers, revalidationRequest);

    if (abortController.signal.aborted) {
      return;
    }

    fetchReloadIds.delete(key);
    fetchControllers.delete(key);
    revalidatingFetchers.forEach(_ref7 => {
      let [staleKey] = _ref7;
      return fetchControllers.delete(staleKey);
    });
    let redirect = findRedirect(results);

    if (redirect) {
      let redirectNavigation = getLoaderRedirect(state, redirect);
      await startRedirectNavigation(redirect, redirectNavigation);
      return;
    } // Process and commit output from loaders


    let {
      loaderData,
      errors
    } = processLoaderData(state, state.matches, matchesToLoad, loaderResults, undefined, revalidatingFetchers, fetcherResults, activeDeferreds);
    let doneFetcher = {
      state: "idle",
      data: actionResult.data,
      formMethod: undefined,
      formAction: undefined,
      formEncType: undefined,
      formData: undefined
    };
    state.fetchers.set(key, doneFetcher);
    let didAbortFetchLoads = abortStaleFetchLoads(loadId); // If we are currently in a navigation loading state and this fetcher is
    // more recent than the navigation, we want the newer data so abort the
    // navigation and complete it with the fetcher data

    if (state.navigation.state === "loading" && loadId > pendingNavigationLoadId) {
      router_invariant(pendingAction, "Expected pending action");
      pendingNavigationController && pendingNavigationController.abort();
      completeNavigation(state.navigation.location, {
        matches,
        loaderData,
        errors,
        fetchers: new Map(state.fetchers)
      });
    } else {
      // otherwise just update with the fetcher data, preserving any existing
      // loaderData for loaders that did not need to reload.  We have to
      // manually merge here since we aren't going through completeNavigation
      updateState(_extends({
        errors,
        loaderData: mergeLoaderData(state.loaderData, loaderData, matches)
      }, didAbortFetchLoads ? {
        fetchers: new Map(state.fetchers)
      } : {}));
      isRevalidationRequired = false;
    }
  } // Call the matched loader for fetcher.load(), handling redirects, errors, etc.


  async function handleFetcherLoader(key, routeId, path, match, matches) {
    let existingFetcher = state.fetchers.get(key); // Put this fetcher into it's loading state

    let loadingFetcher = {
      state: "loading",
      formMethod: undefined,
      formAction: undefined,
      formEncType: undefined,
      formData: undefined,
      data: existingFetcher && existingFetcher.data
    };
    state.fetchers.set(key, loadingFetcher);
    updateState({
      fetchers: new Map(state.fetchers)
    }); // Call the loader for this fetcher route match

    let abortController = new AbortController();
    let fetchRequest = createRequest(path, abortController.signal);
    fetchControllers.set(key, abortController);
    let result = await callLoaderOrAction("loader", fetchRequest, match, matches, router.basename); // Deferred isn't supported or fetcher loads, await everything and treat it
    // as a normal load.  resolveDeferredData will return undefined if this
    // fetcher gets aborted, so we just leave result untouched and short circuit
    // below if that happens

    if (isDeferredResult(result)) {
      result = (await resolveDeferredData(result, fetchRequest.signal, true)) || result;
    } // We can delete this so long as we weren't aborted by ou our own fetcher
    // re-load which would have put _new_ controller is in fetchControllers


    if (fetchControllers.get(key) === abortController) {
      fetchControllers.delete(key);
    }

    if (fetchRequest.signal.aborted) {
      return;
    } // If the loader threw a redirect Response, start a new REPLACE navigation


    if (isRedirectResult(result)) {
      let redirectNavigation = getLoaderRedirect(state, result);
      await startRedirectNavigation(result, redirectNavigation);
      return;
    } // Process any non-redirect errors thrown


    if (isErrorResult(result)) {
      let boundaryMatch = findNearestBoundary(state.matches, routeId);
      state.fetchers.delete(key); // TODO: In remix, this would reset to IDLE_NAVIGATION if it was a catch -
      // do we need to behave any differently with our non-redirect errors?
      // What if it was a non-redirect Response?

      updateState({
        fetchers: new Map(state.fetchers),
        errors: {
          [boundaryMatch.route.id]: result.error
        }
      });
      return;
    }

    router_invariant(!isDeferredResult(result), "Unhandled fetcher deferred data"); // Put the fetcher back into an idle state

    let doneFetcher = {
      state: "idle",
      data: result.data,
      formMethod: undefined,
      formAction: undefined,
      formEncType: undefined,
      formData: undefined
    };
    state.fetchers.set(key, doneFetcher);
    updateState({
      fetchers: new Map(state.fetchers)
    });
  }
  /**
   * Utility function to handle redirects returned from an action or loader.
   * Normally, a redirect "replaces" the navigation that triggered it.  So, for
   * example:
   *
   *  - user is on /a
   *  - user clicks a link to /b
   *  - loader for /b redirects to /c
   *
   * In a non-JS app the browser would track the in-flight navigation to /b and
   * then replace it with /c when it encountered the redirect response.  In
   * the end it would only ever update the URL bar with /c.
   *
   * In client-side routing using pushState/replaceState, we aim to emulate
   * this behavior and we also do not update history until the end of the
   * navigation (including processed redirects).  This means that we never
   * actually touch history until we've processed redirects, so we just use
   * the history action from the original navigation (PUSH or REPLACE).
   */


  async function startRedirectNavigation(redirect, navigation, replace) {
    if (redirect.revalidate) {
      isRevalidationRequired = true;
    }

    router_invariant(navigation.location, "Expected a location on the redirect navigation"); // There's no need to abort on redirects, since we don't detect the
    // redirect until the action/loaders have settled

    pendingNavigationController = null;
    let redirectHistoryAction = replace === true ? Action.Replace : Action.Push;
    await startNavigation(redirectHistoryAction, navigation.location, {
      overrideNavigation: navigation
    });
  }

  async function callLoadersAndMaybeResolveData(currentMatches, matches, matchesToLoad, fetchersToLoad, request) {
    // Call all navigation loaders and revalidating fetcher loaders in parallel,
    // then slice off the results into separate arrays so we can handle them
    // accordingly
    let results = await Promise.all([...matchesToLoad.map(match => callLoaderOrAction("loader", request, match, matches, router.basename)), ...fetchersToLoad.map(_ref8 => {
      let [, href, match, fetchMatches] = _ref8;
      return callLoaderOrAction("loader", createRequest(href, request.signal), match, fetchMatches, router.basename);
    })]);
    let loaderResults = results.slice(0, matchesToLoad.length);
    let fetcherResults = results.slice(matchesToLoad.length);
    await Promise.all([resolveDeferredResults(currentMatches, matchesToLoad, loaderResults, request.signal, false, state.loaderData), resolveDeferredResults(currentMatches, fetchersToLoad.map(_ref9 => {
      let [,, match] = _ref9;
      return match;
    }), fetcherResults, request.signal, true)]);
    return {
      results,
      loaderResults,
      fetcherResults
    };
  }

  function interruptActiveLoads() {
    // Every interruption triggers a revalidation
    isRevalidationRequired = true; // Cancel pending route-level deferreds and mark cancelled routes for
    // revalidation

    cancelledDeferredRoutes.push(...cancelActiveDeferreds()); // Abort in-flight fetcher loads

    fetchLoadMatches.forEach((_, key) => {
      if (fetchControllers.has(key)) {
        cancelledFetcherLoads.push(key);
        abortFetcher(key);
      }
    });
  }

  function setFetcherError(key, routeId, error) {
    let boundaryMatch = findNearestBoundary(state.matches, routeId);
    deleteFetcher(key);
    updateState({
      errors: {
        [boundaryMatch.route.id]: error
      },
      fetchers: new Map(state.fetchers)
    });
  }

  function deleteFetcher(key) {
    if (fetchControllers.has(key)) abortFetcher(key);
    fetchLoadMatches.delete(key);
    fetchReloadIds.delete(key);
    fetchRedirectIds.delete(key);
    state.fetchers.delete(key);
  }

  function abortFetcher(key) {
    let controller = fetchControllers.get(key);
    router_invariant(controller, "Expected fetch controller: " + key);
    controller.abort();
    fetchControllers.delete(key);
  }

  function markFetchersDone(keys) {
    for (let key of keys) {
      let fetcher = getFetcher(key);
      let doneFetcher = {
        state: "idle",
        data: fetcher.data,
        formMethod: undefined,
        formAction: undefined,
        formEncType: undefined,
        formData: undefined
      };
      state.fetchers.set(key, doneFetcher);
    }
  }

  function markFetchRedirectsDone() {
    let doneKeys = [];

    for (let key of fetchRedirectIds) {
      let fetcher = state.fetchers.get(key);
      router_invariant(fetcher, "Expected fetcher: " + key);

      if (fetcher.state === "loading") {
        fetchRedirectIds.delete(key);
        doneKeys.push(key);
      }
    }

    markFetchersDone(doneKeys);
  }

  function abortStaleFetchLoads(landedId) {
    let yeetedKeys = [];

    for (let [key, id] of fetchReloadIds) {
      if (id < landedId) {
        let fetcher = state.fetchers.get(key);
        router_invariant(fetcher, "Expected fetcher: " + key);

        if (fetcher.state === "loading") {
          abortFetcher(key);
          fetchReloadIds.delete(key);
          yeetedKeys.push(key);
        }
      }
    }

    markFetchersDone(yeetedKeys);
    return yeetedKeys.length > 0;
  }

  function cancelActiveDeferreds(predicate) {
    let cancelledRouteIds = [];
    activeDeferreds.forEach((dfd, routeId) => {
      if (!predicate || predicate(routeId)) {
        // Cancel the deferred - but do not remove from activeDeferreds here -
        // we rely on the subscribers to do that so our tests can assert proper
        // cleanup via _internalActiveDeferreds
        dfd.cancel();
        cancelledRouteIds.push(routeId);
        activeDeferreds.delete(routeId);
      }
    });
    return cancelledRouteIds;
  } // Opt in to capturing and reporting scroll positions during navigations,
  // used by the <ScrollRestoration> component


  function enableScrollRestoration(positions, getPosition, getKey) {
    savedScrollPositions = positions;
    getScrollPosition = getPosition;

    getScrollRestorationKey = getKey || (location => location.key); // Perform initial hydration scroll restoration, since we miss the boat on
    // the initial updateState() because we've not yet rendered <ScrollRestoration/>
    // and therefore have no savedScrollPositions available


    if (!initialScrollRestored && state.navigation === IDLE_NAVIGATION) {
      initialScrollRestored = true;
      let y = getSavedScrollPosition(state.location, state.matches);

      if (y != null) {
        updateState({
          restoreScrollPosition: y
        });
      }
    }

    return () => {
      savedScrollPositions = null;
      getScrollPosition = null;
      getScrollRestorationKey = null;
    };
  }

  function saveScrollPosition(location, matches) {
    if (savedScrollPositions && getScrollRestorationKey && getScrollPosition) {
      let userMatches = matches.map(m => createUseMatchesMatch(m, state.loaderData));
      let key = getScrollRestorationKey(location, userMatches) || location.key;
      savedScrollPositions[key] = getScrollPosition();
    }
  }

  function getSavedScrollPosition(location, matches) {
    if (savedScrollPositions && getScrollRestorationKey && getScrollPosition) {
      let userMatches = matches.map(m => createUseMatchesMatch(m, state.loaderData));
      let key = getScrollRestorationKey(location, userMatches) || location.key;
      let y = savedScrollPositions[key];

      if (typeof y === "number") {
        return y;
      }
    }

    return null;
  }

  router = {
    get basename() {
      return init.basename;
    },

    get state() {
      return state;
    },

    get routes() {
      return dataRoutes;
    },

    initialize,
    subscribe,
    enableScrollRestoration,
    navigate,
    fetch,
    revalidate,
    // Passthrough to history-aware createHref used by useHref so we get proper
    // hash-aware URLs in DOM paths
    createHref: to => init.history.createHref(to),
    getFetcher,
    deleteFetcher,
    dispose,
    _internalFetchControllers: fetchControllers,
    _internalActiveDeferreds: activeDeferreds
  };
  return router;
} //#endregion
////////////////////////////////////////////////////////////////////////////////
//#region createStaticHandler
////////////////////////////////////////////////////////////////////////////////

const validActionMethods = new Set(["POST", "PUT", "PATCH", "DELETE"]);
const validRequestMethods = new Set(["GET", "HEAD", ...validActionMethods]);
function unstable_createStaticHandler(routes) {
  router_invariant(routes.length > 0, "You must provide a non-empty routes array to unstable_createStaticHandler");
  let dataRoutes = convertRoutesToDataRoutes(routes);
  /**
   * The query() method is intended for document requests, in which we want to
   * call an optional action and potentially multiple loaders for all nested
   * routes.  It returns a StaticHandlerContext object, which is very similar
   * to the router state (location, loaderData, actionData, errors, etc.) and
   * also adds SSR-specific information such as the statusCode and headers
   * from action/loaders Responses.
   *
   * It _should_ never throw and should report all errors through the
   * returned context.errors object, properly associating errors to their error
   * boundary.  Additionally, it tracks _deepestRenderedBoundaryId which can be
   * used to emulate React error boundaries during SSr by performing a second
   * pass only down to the boundaryId.
   *
   * The one exception where we do not return a StaticHandlerContext is when a
   * redirect response is returned or thrown from any action/loader.  We
   * propagate that out and return the raw Response so the HTTP server can
   * return it directly.
   */

  async function query(request) {
    let url = new URL(request.url);
    let location = createLocation("", router_createPath(url), null, "default");
    let matches = matchRoutes(dataRoutes, location);

    if (!validRequestMethods.has(request.method)) {
      let {
        matches: methodNotAllowedMatches,
        route,
        error
      } = getMethodNotAllowedMatches(dataRoutes);
      return {
        location,
        matches: methodNotAllowedMatches,
        loaderData: {},
        actionData: null,
        errors: {
          [route.id]: error
        },
        statusCode: error.status,
        loaderHeaders: {},
        actionHeaders: {}
      };
    } else if (!matches) {
      let {
        matches: notFoundMatches,
        route,
        error
      } = getNotFoundMatches(dataRoutes);
      return {
        location,
        matches: notFoundMatches,
        loaderData: {},
        actionData: null,
        errors: {
          [route.id]: error
        },
        statusCode: error.status,
        loaderHeaders: {},
        actionHeaders: {}
      };
    }

    let result = await queryImpl(request, location, matches);

    if (result instanceof Response) {
      return result;
    } // When returning StaticHandlerContext, we patch back in the location here
    // since we need it for React Context.  But this helps keep our submit and
    // loadRouteData operating on a Request instead of a Location


    return _extends({
      location
    }, result);
  }
  /**
   * The queryRoute() method is intended for targeted route requests, either
   * for fetch ?_data requests or resource route requests.  In this case, we
   * are only ever calling a single action or loader, and we are returning the
   * returned value directly.  In most cases, this will be a Response returned
   * from the action/loader, but it may be a primitive or other value as well -
   * and in such cases the calling context should handle that accordingly.
   *
   * We do respect the throw/return differentiation, so if an action/loader
   * throws, then this method will throw the value.  This is important so we
   * can do proper boundary identification in Remix where a thrown Response
   * must go to the Catch Boundary but a returned Response is happy-path.
   *
   * One thing to note is that any Router-initiated thrown Response (such as a
   * 404 or 405) will have a custom X-Remix-Router-Error: "yes" header on it
   * in order to differentiate from responses thrown from user actions/loaders.
   */


  async function queryRoute(request, routeId) {
    let url = new URL(request.url);
    let location = createLocation("", router_createPath(url), null, "default");
    let matches = matchRoutes(dataRoutes, location);

    if (!validRequestMethods.has(request.method)) {
      throw createRouterErrorResponse(null, {
        status: 405,
        statusText: "Method Not Allowed"
      });
    } else if (!matches) {
      throw createRouterErrorResponse(null, {
        status: 404,
        statusText: "Not Found"
      });
    }

    let match = routeId ? matches.find(m => m.route.id === routeId) : getTargetMatch(matches, location);

    if (!match) {
      throw createRouterErrorResponse(null, {
        status: 404,
        statusText: "Not Found"
      });
    }

    let result = await queryImpl(request, location, matches, match);

    if (result instanceof Response) {
      return result;
    }

    let error = result.errors ? Object.values(result.errors)[0] : undefined;

    if (error !== undefined) {
      // If we got back result.errors, that means the loader/action threw
      // _something_ that wasn't a Response, but it's not guaranteed/required
      // to be an `instanceof Error` either, so we have to use throw here to
      // preserve the "error" state outside of queryImpl.
      throw error;
    } // Pick off the right state value to return


    let routeData = [result.actionData, result.loaderData].find(v => v);
    return Object.values(routeData || {})[0];
  }

  async function queryImpl(request, location, matches, routeMatch) {
    router_invariant(request.signal, "query()/queryRoute() requests must contain an AbortController signal");

    try {
      if (validActionMethods.has(request.method)) {
        let result = await submit(request, matches, routeMatch || getTargetMatch(matches, location), routeMatch != null);
        return result;
      }

      let result = await loadRouteData(request, matches, routeMatch);
      return result instanceof Response ? result : _extends({}, result, {
        actionData: null,
        actionHeaders: {}
      });
    } catch (e) {
      // If the user threw/returned a Response in callLoaderOrAction, we throw
      // it to bail out and then return or throw here based on whether the user
      // returned or threw
      if (isQueryRouteResponse(e)) {
        if (e.type === ResultType.error && !isRedirectResponse(e.response)) {
          throw e.response;
        }

        return e.response;
      } // Redirects are always returned since they don't propagate to catch
      // boundaries


      if (isRedirectResponse(e)) {
        return e;
      }

      throw e;
    }
  }

  async function submit(request, matches, actionMatch, isRouteRequest) {
    let result;

    if (!actionMatch.route.action) {
      if (isRouteRequest) {
        throw createRouterErrorResponse(null, {
          status: 405,
          statusText: "Method Not Allowed"
        });
      }

      result = getMethodNotAllowedResult(request.url);
    } else {
      result = await callLoaderOrAction("action", request, actionMatch, matches, undefined, // Basename not currently supported in static handlers
      true, isRouteRequest);

      if (request.signal.aborted) {
        let method = isRouteRequest ? "queryRoute" : "query";
        throw new Error(method + "() call aborted");
      }
    }

    if (isRedirectResult(result)) {
      // Uhhhh - this should never happen, we should always throw these from
      // callLoaderOrAction, but the type narrowing here keeps TS happy and we
      // can get back on the "throw all redirect responses" train here should
      // this ever happen :/
      throw new Response(null, {
        status: result.status,
        headers: {
          Location: result.location
        }
      });
    }

    if (isDeferredResult(result)) {
      throw new Error("defer() is not supported in actions");
    }

    if (isRouteRequest) {
      // Note: This should only be non-Response values if we get here, since
      // isRouteRequest should throw any Response received in callLoaderOrAction
      if (isErrorResult(result)) {
        let boundaryMatch = findNearestBoundary(matches, actionMatch.route.id);
        return {
          matches: [actionMatch],
          loaderData: {},
          actionData: null,
          errors: {
            [boundaryMatch.route.id]: result.error
          },
          // Note: statusCode + headers are unused here since queryRoute will
          // return the raw Response or value
          statusCode: 500,
          loaderHeaders: {},
          actionHeaders: {}
        };
      }

      return {
        matches: [actionMatch],
        loaderData: {},
        actionData: {
          [actionMatch.route.id]: result.data
        },
        errors: null,
        // Note: statusCode + headers are unused here since queryRoute will
        // return the raw Response or value
        statusCode: 200,
        loaderHeaders: {},
        actionHeaders: {}
      };
    }

    if (isErrorResult(result)) {
      // Store off the pending error - we use it to determine which loaders
      // to call and will commit it when we complete the navigation
      let boundaryMatch = findNearestBoundary(matches, actionMatch.route.id);
      let context = await loadRouteData(request, matches, undefined, {
        [boundaryMatch.route.id]: result.error
      }); // action status codes take precedence over loader status codes

      return _extends({}, context, {
        statusCode: isRouteErrorResponse(result.error) ? result.error.status : 500,
        actionData: null,
        actionHeaders: _extends({}, result.headers ? {
          [actionMatch.route.id]: result.headers
        } : {})
      });
    }

    let context = await loadRouteData(request, matches);
    return _extends({}, context, result.statusCode ? {
      statusCode: result.statusCode
    } : {}, {
      actionData: {
        [actionMatch.route.id]: result.data
      },
      actionHeaders: _extends({}, result.headers ? {
        [actionMatch.route.id]: result.headers
      } : {})
    });
  }

  async function loadRouteData(request, matches, routeMatch, pendingActionError) {
    let isRouteRequest = routeMatch != null;
    let requestMatches = routeMatch ? [routeMatch] : getLoaderMatchesUntilBoundary(matches, Object.keys(pendingActionError || {})[0]);
    let matchesToLoad = requestMatches.filter(m => m.route.loader); // Short circuit if we have no loaders to run

    if (matchesToLoad.length === 0) {
      return {
        matches,
        loaderData: {},
        errors: pendingActionError || null,
        statusCode: 200,
        loaderHeaders: {}
      };
    }

    let results = await Promise.all([...matchesToLoad.map(match => callLoaderOrAction("loader", request, match, matches, undefined, // Basename not currently supported in static handlers
    true, isRouteRequest))]);

    if (request.signal.aborted) {
      let method = isRouteRequest ? "queryRoute" : "query";
      throw new Error(method + "() call aborted");
    } // Can't do anything with these without the Remix side of things, so just
    // cancel them for now


    results.forEach(result => {
      if (isDeferredResult(result)) {
        result.deferredData.cancel();
      }
    }); // Process and commit output from loaders

    let context = processRouteLoaderData(matches, matchesToLoad, results, pendingActionError);
    return _extends({}, context, {
      matches
    });
  }

  function createRouterErrorResponse(body, init) {
    return new Response(body, _extends({}, init, {
      headers: _extends({}, init.headers, {
        "X-Remix-Router-Error": "yes"
      })
    }));
  }

  return {
    dataRoutes,
    query,
    queryRoute
  };
} //#endregion
////////////////////////////////////////////////////////////////////////////////
//#region Helpers
////////////////////////////////////////////////////////////////////////////////

/**
 * Given an existing StaticHandlerContext and an error thrown at render time,
 * provide an updated StaticHandlerContext suitable for a second SSR render
 */

function getStaticContextFromError(routes, context, error) {
  let newContext = _extends({}, context, {
    statusCode: 500,
    errors: {
      [context._deepestRenderedBoundaryId || routes[0].id]: error
    }
  });

  return newContext;
} // Normalize navigation options by converting formMethod=GET formData objects to
// URLSearchParams so they behave identically to links with query params

function normalizeNavigateOptions(to, opts, isFetcher) {
  if (isFetcher === void 0) {
    isFetcher = false;
  }

  let path = typeof to === "string" ? to : router_createPath(to); // Return location verbatim on non-submission navigations

  if (!opts || !("formMethod" in opts) && !("formData" in opts)) {
    return {
      path
    };
  } // Create a Submission on non-GET navigations


  if (opts.formMethod != null && opts.formMethod !== "get") {
    return {
      path,
      submission: {
        formMethod: opts.formMethod,
        formAction: stripHashFromPath(path),
        formEncType: opts && opts.formEncType || "application/x-www-form-urlencoded",
        formData: opts.formData
      }
    };
  } // No formData to flatten for GET submission


  if (!opts.formData) {
    return {
      path
    };
  } // Flatten submission onto URLSearchParams for GET submissions


  let parsedPath = parsePath(path);

  try {
    let searchParams = convertFormDataToSearchParams(opts.formData); // Since fetcher GET submissions only run a single loader (as opposed to
    // navigation GET submissions which run all loaders), we need to preserve
    // any incoming ?index params

    if (isFetcher && parsedPath.search && hasNakedIndexQuery(parsedPath.search)) {
      searchParams.append("index", "");
    }

    parsedPath.search = "?" + searchParams;
  } catch (e) {
    return {
      path,
      error: new ErrorResponse(400, "Bad Request", "Cannot submit binary form data using GET")
    };
  }

  return {
    path: router_createPath(parsedPath)
  };
}

function getLoaderRedirect(state, redirect) {
  let {
    formMethod,
    formAction,
    formEncType,
    formData
  } = state.navigation;
  let navigation = {
    state: "loading",
    location: createLocation(state.location, redirect.location),
    formMethod: formMethod || undefined,
    formAction: formAction || undefined,
    formEncType: formEncType || undefined,
    formData: formData || undefined
  };
  return navigation;
} // Filter out all routes below any caught error as they aren't going to
// render so we don't need to load them


function getLoaderMatchesUntilBoundary(matches, boundaryId) {
  let boundaryMatches = matches;

  if (boundaryId) {
    let index = matches.findIndex(m => m.route.id === boundaryId);

    if (index >= 0) {
      boundaryMatches = matches.slice(0, index);
    }
  }

  return boundaryMatches;
}

function getMatchesToLoad(state, matches, submission, location, isRevalidationRequired, cancelledDeferredRoutes, cancelledFetcherLoads, pendingActionData, pendingError, fetchLoadMatches) {
  let actionResult = pendingError ? Object.values(pendingError)[0] : pendingActionData ? Object.values(pendingActionData)[0] : null; // Pick navigation matches that are net-new or qualify for revalidation

  let boundaryId = pendingError ? Object.keys(pendingError)[0] : undefined;
  let boundaryMatches = getLoaderMatchesUntilBoundary(matches, boundaryId);
  let navigationMatches = boundaryMatches.filter((match, index) => match.route.loader != null && (isNewLoader(state.loaderData, state.matches[index], match) || // If this route had a pending deferred cancelled it must be revalidated
  cancelledDeferredRoutes.some(id => id === match.route.id) || shouldRevalidateLoader(state.location, state.matches[index], submission, location, match, isRevalidationRequired, actionResult))); // Pick fetcher.loads that need to be revalidated

  let revalidatingFetchers = [];
  fetchLoadMatches && fetchLoadMatches.forEach((_ref10, key) => {
    let [href, match, fetchMatches] = _ref10;

    // This fetcher was cancelled from a prior action submission - force reload
    if (cancelledFetcherLoads.includes(key)) {
      revalidatingFetchers.push([key, href, match, fetchMatches]);
    } else if (isRevalidationRequired) {
      let shouldRevalidate = shouldRevalidateLoader(href, match, submission, href, match, isRevalidationRequired, actionResult);

      if (shouldRevalidate) {
        revalidatingFetchers.push([key, href, match, fetchMatches]);
      }
    }
  });
  return [navigationMatches, revalidatingFetchers];
}

function isNewLoader(currentLoaderData, currentMatch, match) {
  let isNew = // [a] -> [a, b]
  !currentMatch || // [a, b] -> [a, c]
  match.route.id !== currentMatch.route.id; // Handle the case that we don't have data for a re-used route, potentially
  // from a prior error or from a cancelled pending deferred

  let isMissingData = currentLoaderData[match.route.id] === undefined; // Always load if this is a net-new route or we don't yet have data

  return isNew || isMissingData;
}

function isNewRouteInstance(currentMatch, match) {
  let currentPath = currentMatch.route.path;
  return (// param change for this match, /users/123 -> /users/456
    currentMatch.pathname !== match.pathname || // splat param changed, which is not present in match.path
    // e.g. /files/images/avatar.jpg -> files/finances.xls
    currentPath && currentPath.endsWith("*") && currentMatch.params["*"] !== match.params["*"]
  );
}

function shouldRevalidateLoader(currentLocation, currentMatch, submission, location, match, isRevalidationRequired, actionResult) {
  let currentUrl = createURL(currentLocation);
  let currentParams = currentMatch.params;
  let nextUrl = createURL(location);
  let nextParams = match.params; // This is the default implementation as to when we revalidate.  If the route
  // provides it's own implementation, then we give them full control but
  // provide this value so they can leverage it if needed after they check
  // their own specific use cases
  // Note that fetchers always provide the same current/next locations so the
  // URL-based checks here don't apply to fetcher shouldRevalidate calls

  let defaultShouldRevalidate = isNewRouteInstance(currentMatch, match) || // Clicked the same link, resubmitted a GET form
  currentUrl.toString() === nextUrl.toString() || // Search params affect all loaders
  currentUrl.search !== nextUrl.search || // Forced revalidation due to submission, useRevalidate, or X-Remix-Revalidate
  isRevalidationRequired;

  if (match.route.shouldRevalidate) {
    let routeChoice = match.route.shouldRevalidate(_extends({
      currentUrl,
      currentParams,
      nextUrl,
      nextParams
    }, submission, {
      actionResult,
      defaultShouldRevalidate
    }));

    if (typeof routeChoice === "boolean") {
      return routeChoice;
    }
  }

  return defaultShouldRevalidate;
}

async function callLoaderOrAction(type, request, match, matches, basename, isStaticRequest, isRouteRequest) {
  if (isStaticRequest === void 0) {
    isStaticRequest = false;
  }

  if (isRouteRequest === void 0) {
    isRouteRequest = false;
  }

  let resultType;
  let result; // Setup a promise we can race against so that abort signals short circuit

  let reject;
  let abortPromise = new Promise((_, r) => reject = r);

  let onReject = () => reject();

  request.signal.addEventListener("abort", onReject);

  try {
    let handler = match.route[type];
    router_invariant(handler, "Could not find the " + type + " to run on the \"" + match.route.id + "\" route");
    result = await Promise.race([handler({
      request,
      params: match.params
    }), abortPromise]);
  } catch (e) {
    resultType = ResultType.error;
    result = e;
  } finally {
    request.signal.removeEventListener("abort", onReject);
  }

  if (result instanceof Response) {
    let status = result.status; // Process redirects

    if (status >= 300 && status <= 399) {
      let location = result.headers.get("Location");
      router_invariant(location, "Redirects returned/thrown from loaders/actions must have a Location header"); // Support relative routing in redirects

      let activeMatches = matches.slice(0, matches.indexOf(match) + 1);
      let routePathnames = getPathContributingMatches(activeMatches).map(match => match.pathnameBase);
      let requestPath = createURL(request.url).pathname;
      let resolvedLocation = resolveTo(location, routePathnames, requestPath);
      router_invariant(router_createPath(resolvedLocation), "Unable to resolve redirect location: " + result.headers.get("Location")); // Prepend the basename to the redirect location if we have one

      if (basename) {
        let path = resolvedLocation.pathname;
        resolvedLocation.pathname = path === "/" ? basename : router_joinPaths([basename, path]);
      }

      location = router_createPath(resolvedLocation); // Don't process redirects in the router during static requests requests.
      // Instead, throw the Response and let the server handle it with an HTTP
      // redirect.  We also update the Location header in place in this flow so
      // basename and relative routing is taken into account

      if (isStaticRequest) {
        result.headers.set("Location", location);
        throw result;
      }

      return {
        type: ResultType.redirect,
        status,
        location,
        revalidate: result.headers.get("X-Remix-Revalidate") !== null
      };
    } // For SSR single-route requests, we want to hand Responses back directly
    // without unwrapping.  We do this with the QueryRouteResponse wrapper
    // interface so we can know whether it was returned or thrown


    if (isRouteRequest) {
      // eslint-disable-next-line no-throw-literal
      throw {
        type: resultType || ResultType.data,
        response: result
      };
    }

    let data;
    let contentType = result.headers.get("Content-Type");

    if (contentType && contentType.startsWith("application/json")) {
      data = await result.json();
    } else {
      data = await result.text();
    }

    if (resultType === ResultType.error) {
      return {
        type: resultType,
        error: new ErrorResponse(status, result.statusText, data),
        headers: result.headers
      };
    }

    return {
      type: ResultType.data,
      data,
      statusCode: result.status,
      headers: result.headers
    };
  }

  if (resultType === ResultType.error) {
    return {
      type: resultType,
      error: result
    };
  }

  if (result instanceof DeferredData) {
    return {
      type: ResultType.deferred,
      deferredData: result
    };
  }

  return {
    type: ResultType.data,
    data: result
  };
}

function createRequest(location, signal, submission) {
  let url = createURL(stripHashFromPath(location)).toString();
  let init = {
    signal
  };

  if (submission) {
    let {
      formMethod,
      formEncType,
      formData
    } = submission;
    init.method = formMethod.toUpperCase();
    init.body = formEncType === "application/x-www-form-urlencoded" ? convertFormDataToSearchParams(formData) : formData;
  } // Content-Type is inferred (https://fetch.spec.whatwg.org/#dom-request)


  return new Request(url, init);
}

function convertFormDataToSearchParams(formData) {
  let searchParams = new URLSearchParams();

  for (let [key, value] of formData.entries()) {
    router_invariant(typeof value === "string", 'File inputs are not supported with encType "application/x-www-form-urlencoded", ' + 'please use "multipart/form-data" instead.');
    searchParams.append(key, value);
  }

  return searchParams;
}

function processRouteLoaderData(matches, matchesToLoad, results, pendingError, activeDeferreds) {
  // Fill in loaderData/errors from our loaders
  let loaderData = {};
  let errors = null;
  let statusCode;
  let foundError = false;
  let loaderHeaders = {}; // Process loader results into state.loaderData/state.errors

  results.forEach((result, index) => {
    let id = matchesToLoad[index].route.id;
    router_invariant(!isRedirectResult(result), "Cannot handle redirect results in processLoaderData");

    if (isErrorResult(result)) {
      // Look upwards from the matched route for the closest ancestor
      // error boundary, defaulting to the root match
      let boundaryMatch = findNearestBoundary(matches, id);
      let error = result.error; // If we have a pending action error, we report it at the highest-route
      // that throws a loader error, and then clear it out to indicate that
      // it was consumed

      if (pendingError) {
        error = Object.values(pendingError)[0];
        pendingError = undefined;
      }

      errors = Object.assign(errors || {}, {
        [boundaryMatch.route.id]: error
      }); // Once we find our first (highest) error, we set the status code and
      // prevent deeper status codes from overriding

      if (!foundError) {
        foundError = true;
        statusCode = isRouteErrorResponse(result.error) ? result.error.status : 500;
      }

      if (result.headers) {
        loaderHeaders[id] = result.headers;
      }
    } else if (isDeferredResult(result)) {
      activeDeferreds && activeDeferreds.set(id, result.deferredData);
      loaderData[id] = result.deferredData.data; // TODO: Add statusCode/headers once we wire up streaming in Remix
    } else {
      loaderData[id] = result.data; // Error status codes always override success status codes, but if all
      // loaders are successful we take the deepest status code.

      if (result.statusCode != null && result.statusCode !== 200 && !foundError) {
        statusCode = result.statusCode;
      }

      if (result.headers) {
        loaderHeaders[id] = result.headers;
      }
    }
  }); // If we didn't consume the pending action error (i.e., all loaders
  // resolved), then consume it here

  if (pendingError) {
    errors = pendingError;
  }

  return {
    loaderData,
    errors,
    statusCode: statusCode || 200,
    loaderHeaders
  };
}

function processLoaderData(state, matches, matchesToLoad, results, pendingError, revalidatingFetchers, fetcherResults, activeDeferreds) {
  let {
    loaderData,
    errors
  } = processRouteLoaderData(matches, matchesToLoad, results, pendingError, activeDeferreds); // Process results from our revalidating fetchers

  for (let index = 0; index < revalidatingFetchers.length; index++) {
    let [key,, match] = revalidatingFetchers[index];
    router_invariant(fetcherResults !== undefined && fetcherResults[index] !== undefined, "Did not find corresponding fetcher result");
    let result = fetcherResults[index]; // Process fetcher non-redirect errors

    if (isErrorResult(result)) {
      let boundaryMatch = findNearestBoundary(state.matches, match.route.id);

      if (!(errors && errors[boundaryMatch.route.id])) {
        errors = _extends({}, errors, {
          [boundaryMatch.route.id]: result.error
        });
      }

      state.fetchers.delete(key);
    } else if (isRedirectResult(result)) {
      // Should never get here, redirects should get processed above, but we
      // keep this to type narrow to a success result in the else
      throw new Error("Unhandled fetcher revalidation redirect");
    } else if (isDeferredResult(result)) {
      // Should never get here, deferred data should be awaited for fetchers
      // in resolveDeferredResults
      throw new Error("Unhandled fetcher deferred data");
    } else {
      let doneFetcher = {
        state: "idle",
        data: result.data,
        formMethod: undefined,
        formAction: undefined,
        formEncType: undefined,
        formData: undefined
      };
      state.fetchers.set(key, doneFetcher);
    }
  }

  return {
    loaderData,
    errors
  };
}

function mergeLoaderData(loaderData, newLoaderData, matches) {
  let mergedLoaderData = _extends({}, newLoaderData);

  matches.forEach(match => {
    let id = match.route.id;

    if (newLoaderData[id] === undefined && loaderData[id] !== undefined) {
      mergedLoaderData[id] = loaderData[id];
    }
  });
  return mergedLoaderData;
} // Find the nearest error boundary, looking upwards from the leaf route (or the
// route specified by routeId) for the closest ancestor error boundary,
// defaulting to the root match


function findNearestBoundary(matches, routeId) {
  let eligibleMatches = routeId ? matches.slice(0, matches.findIndex(m => m.route.id === routeId) + 1) : [...matches];
  return eligibleMatches.reverse().find(m => m.route.hasErrorBoundary === true) || matches[0];
}

function getShortCircuitMatches(routes, status, statusText) {
  // Prefer a root layout route if present, otherwise shim in a route object
  let route = routes.find(r => r.index || !r.path || r.path === "/") || {
    id: "__shim-" + status + "-route__"
  };
  return {
    matches: [{
      params: {},
      pathname: "",
      pathnameBase: "",
      route
    }],
    route,
    error: new ErrorResponse(status, statusText, null)
  };
}

function getNotFoundMatches(routes) {
  return getShortCircuitMatches(routes, 404, "Not Found");
}

function getMethodNotAllowedMatches(routes) {
  return getShortCircuitMatches(routes, 405, "Method Not Allowed");
}

function getMethodNotAllowedResult(path) {
  let href = typeof path === "string" ? path : router_createPath(path);
  console.warn("You're trying to submit to a route that does not have an action.  To " + "fix this, please add an `action` function to the route for " + ("[" + href + "]"));
  return {
    type: ResultType.error,
    error: new ErrorResponse(405, "Method Not Allowed", "")
  };
} // Find any returned redirect errors, starting from the lowest match


function findRedirect(results) {
  for (let i = results.length - 1; i >= 0; i--) {
    let result = results[i];

    if (isRedirectResult(result)) {
      return result;
    }
  }
}

function stripHashFromPath(path) {
  let parsedPath = typeof path === "string" ? parsePath(path) : path;
  return router_createPath(_extends({}, parsedPath, {
    hash: ""
  }));
}

function isHashChangeOnly(a, b) {
  return a.pathname === b.pathname && a.search === b.search && a.hash !== b.hash;
}

function isDeferredResult(result) {
  return result.type === ResultType.deferred;
}

function isErrorResult(result) {
  return result.type === ResultType.error;
}

function isRedirectResult(result) {
  return (result && result.type) === ResultType.redirect;
}

function isRedirectResponse(result) {
  if (!(result instanceof Response)) {
    return false;
  }

  let status = result.status;
  let location = result.headers.get("Location");
  return status >= 300 && status <= 399 && location != null;
}

function isQueryRouteResponse(obj) {
  return obj && obj.response instanceof Response && (obj.type === ResultType.data || ResultType.error);
}

async function resolveDeferredResults(currentMatches, matchesToLoad, results, signal, isFetcher, currentLoaderData) {
  for (let index = 0; index < results.length; index++) {
    let result = results[index];
    let match = matchesToLoad[index];
    let currentMatch = currentMatches.find(m => m.route.id === match.route.id);
    let isRevalidatingLoader = currentMatch != null && !isNewRouteInstance(currentMatch, match) && (currentLoaderData && currentLoaderData[match.route.id]) !== undefined;

    if (isDeferredResult(result) && (isFetcher || isRevalidatingLoader)) {
      // Note: we do not have to touch activeDeferreds here since we race them
      // against the signal in resolveDeferredData and they'll get aborted
      // there if needed
      await resolveDeferredData(result, signal, isFetcher).then(result => {
        if (result) {
          results[index] = result || results[index];
        }
      });
    }
  }
}

async function resolveDeferredData(result, signal, unwrap) {
  if (unwrap === void 0) {
    unwrap = false;
  }

  let aborted = await result.deferredData.resolveData(signal);

  if (aborted) {
    return;
  }

  if (unwrap) {
    try {
      return {
        type: ResultType.data,
        data: result.deferredData.unwrappedData
      };
    } catch (e) {
      // Handle any TrackedPromise._error values encountered while unwrapping
      return {
        type: ResultType.error,
        error: e
      };
    }
  }

  return {
    type: ResultType.data,
    data: result.deferredData.data
  };
}

function hasNakedIndexQuery(search) {
  return new URLSearchParams(search).getAll("index").some(v => v === "");
} // Note: This should match the format exported by useMatches, so if you change
// this please also change that :)  Eventually we'll DRY this up


function createUseMatchesMatch(match, loaderData) {
  let {
    route,
    pathname,
    params
  } = match;
  return {
    id: route.id,
    pathname,
    params,
    data: loaderData[route.id],
    handle: route.handle
  };
}

function getTargetMatch(matches, location) {
  let search = typeof location === "string" ? parsePath(location).search : location.search;

  if (matches[matches.length - 1].route.index && hasNakedIndexQuery(search || "")) {
    // Return the leaf index route when index is present
    return matches[matches.length - 1];
  } // Otherwise grab the deepest "path contributing" match (ignoring index and
  // pathless layout routes)


  let pathMatches = getPathContributingMatches(matches);
  return pathMatches[pathMatches.length - 1];
} //#endregion


//# sourceMappingURL=router.js.map

// EXTERNAL MODULE: ./node_modules/react/index.js
var react = __webpack_require__(294);
var react_namespaceObject = /*#__PURE__*/__webpack_require__.t(react, 2);
;// CONCATENATED MODULE: ./node_modules/react-router/dist/index.js
/**
 * React Router v6.4.3
 *
 * Copyright (c) Remix Software Inc.
 *
 * This source code is licensed under the MIT license found in the
 * LICENSE.md file in the root directory of this source tree.
 *
 * @license MIT
 */




function dist_extends() {
  dist_extends = Object.assign ? Object.assign.bind() : function (target) {
    for (var i = 1; i < arguments.length; i++) {
      var source = arguments[i];

      for (var key in source) {
        if (Object.prototype.hasOwnProperty.call(source, key)) {
          target[key] = source[key];
        }
      }
    }

    return target;
  };
  return dist_extends.apply(this, arguments);
}

/**
 * Copyright (c) Facebook, Inc. and its affiliates.
 *
 * This source code is licensed under the MIT license found in the
 * LICENSE file in the root directory of this source tree.
 */
/**
 * inlined Object.is polyfill to avoid requiring consumers ship their own
 * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is
 */

function isPolyfill(x, y) {
  return x === y && (x !== 0 || 1 / x === 1 / y) || x !== x && y !== y // eslint-disable-line no-self-compare
  ;
}

const is = typeof Object.is === "function" ? Object.is : isPolyfill; // Intentionally not using named imports because Rollup uses dynamic
// dispatch for CommonJS interop named imports.

const {
  useState,
  useEffect,
  useLayoutEffect,
  useDebugValue
} = react_namespaceObject;
let didWarnOld18Alpha = false;
let didWarnUncachedGetSnapshot = false; // Disclaimer: This shim breaks many of the rules of React, and only works
// because of a very particular set of implementation details and assumptions
// -- change any one of them and it will break. The most important assumption
// is that updates are always synchronous, because concurrent rendering is
// only available in versions of React that also have a built-in
// useSyncExternalStore API. And we only use this shim when the built-in API
// does not exist.
//
// Do not assume that the clever hacks used by this hook also work in general.
// The point of this shim is to replace the need for hacks by other libraries.

function useSyncExternalStore$2(subscribe, getSnapshot, // Note: The shim does not use getServerSnapshot, because pre-18 versions of
// React do not expose a way to check if we're hydrating. So users of the shim
// will need to track that themselves and return the correct value
// from `getSnapshot`.
getServerSnapshot) {
  if (false) {} // Read the current snapshot from the store on every render. Again, this
  // breaks the rules of React, and only works here because of specific
  // implementation details, most importantly that updates are
  // always synchronous.


  const value = getSnapshot();

  if (false) {} // Because updates are synchronous, we don't queue them. Instead we force a
  // re-render whenever the subscribed state changes by updating an some
  // arbitrary useState hook. Then, during render, we call getSnapshot to read
  // the current value.
  //
  // Because we don't actually use the state returned by the useState hook, we
  // can save a bit of memory by storing other stuff in that slot.
  //
  // To implement the early bailout, we need to track some things on a mutable
  // object. Usually, we would put that in a useRef hook, but we can stash it in
  // our useState hook instead.
  //
  // To force a re-render, we call forceUpdate({inst}). That works because the
  // new object always fails an equality check.


  const [{
    inst
  }, forceUpdate] = useState({
    inst: {
      value,
      getSnapshot
    }
  }); // Track the latest getSnapshot function with a ref. This needs to be updated
  // in the layout phase so we can access it during the tearing check that
  // happens on subscribe.

  useLayoutEffect(() => {
    inst.value = value;
    inst.getSnapshot = getSnapshot; // Whenever getSnapshot or subscribe changes, we need to check in the
    // commit phase if there was an interleaved mutation. In concurrent mode
    // this can happen all the time, but even in synchronous mode, an earlier
    // effect may have mutated the store.

    if (checkIfSnapshotChanged(inst)) {
      // Force a re-render.
      forceUpdate({
        inst
      });
    } // eslint-disable-next-line react-hooks/exhaustive-deps

  }, [subscribe, value, getSnapshot]);
  useEffect(() => {
    // Check for changes right before subscribing. Subsequent changes will be
    // detected in the subscription handler.
    if (checkIfSnapshotChanged(inst)) {
      // Force a re-render.
      forceUpdate({
        inst
      });
    }

    const handleStoreChange = () => {
      // TODO: Because there is no cross-renderer API for batching updates, it's
      // up to the consumer of this library to wrap their subscription event
      // with unstable_batchedUpdates. Should we try to detect when this isn't
      // the case and print a warning in development?
      // The store changed. Check if the snapshot changed since the last time we
      // read from the store.
      if (checkIfSnapshotChanged(inst)) {
        // Force a re-render.
        forceUpdate({
          inst
        });
      }
    }; // Subscribe to the store and return a clean-up function.


    return subscribe(handleStoreChange); // eslint-disable-next-line react-hooks/exhaustive-deps
  }, [subscribe]);
  useDebugValue(value);
  return value;
}

function checkIfSnapshotChanged(inst) {
  const latestGetSnapshot = inst.getSnapshot;
  const prevValue = inst.value;

  try {
    const nextValue = latestGetSnapshot();
    return !is(prevValue, nextValue);
  } catch (error) {
    return true;
  }
}

/**
 * Copyright (c) Facebook, Inc. and its affiliates.
 *
 * This source code is licensed under the MIT license found in the
 * LICENSE file in the root directory of this source tree.
 *
 * @flow
 */
function useSyncExternalStore$1(subscribe, getSnapshot, getServerSnapshot) {
  // Note: The shim does not use getServerSnapshot, because pre-18 versions of
  // React do not expose a way to check if we're hydrating. So users of the shim
  // will need to track that themselves and return the correct value
  // from `getSnapshot`.
  return getSnapshot();
}

/**
 * Inlined into the react-router repo since use-sync-external-store does not
 * provide a UMD-compatible package, so we need this to be able to distribute
 * UMD react-router bundles
 */
const canUseDOM = !!(typeof window !== "undefined" && typeof window.document !== "undefined" && typeof window.document.createElement !== "undefined");
const isServerEnvironment = !canUseDOM;
const shim = isServerEnvironment ? useSyncExternalStore$1 : useSyncExternalStore$2;
const useSyncExternalStore =  true ? (module => module.useSyncExternalStore)(react_namespaceObject) : shim;

// Contexts for data routers
const DataStaticRouterContext = /*#__PURE__*/react.createContext(null);

if (false) {}

const DataRouterContext = /*#__PURE__*/react.createContext(null);

if (false) {}

const DataRouterStateContext = /*#__PURE__*/react.createContext(null);

if (false) {}

const AwaitContext = /*#__PURE__*/(/* unused pure expression or super */ null && (React.createContext(null)));

if (false) {}

const NavigationContext = /*#__PURE__*/react.createContext(null);

if (false) {}

const LocationContext = /*#__PURE__*/react.createContext(null);

if (false) {}

const RouteContext = /*#__PURE__*/react.createContext({
  outlet: null,
  matches: []
});

if (false) {}

const RouteErrorContext = /*#__PURE__*/react.createContext(null);

if (false) {}

/**
 * Returns the full href for the given "to" value. This is useful for building
 * custom links that are also accessible and preserve right-click behavior.
 *
 * @see https://reactrouter.com/docs/en/v6/hooks/use-href
 */

function useHref(to, _temp) {
  let {
    relative
  } = _temp === void 0 ? {} : _temp;
  !useInRouterContext() ?  false ? 0 : router_invariant(false) : void 0;
  let {
    basename,
    navigator
  } = react.useContext(NavigationContext);
  let {
    hash,
    pathname,
    search
  } = dist_useResolvedPath(to, {
    relative
  });
  let joinedPathname = pathname; // If we're operating within a basename, prepend it to the pathname prior
  // to creating the href.  If this is a root navigation, then just use the raw
  // basename which allows the basename to have full control over the presence
  // of a trailing slash on root links

  if (basename !== "/") {
    joinedPathname = pathname === "/" ? basename : router_joinPaths([basename, pathname]);
  }

  return navigator.createHref({
    pathname: joinedPathname,
    search,
    hash
  });
}
/**
 * Returns true if this component is a descendant of a <Router>.
 *
 * @see https://reactrouter.com/docs/en/v6/hooks/use-in-router-context
 */

function useInRouterContext() {
  return react.useContext(LocationContext) != null;
}
/**
 * Returns the current location object, which represents the current URL in web
 * browsers.
 *
 * Note: If you're using this it may mean you're doing some of your own
 * "routing" in your app, and we'd like to know what your use case is. We may
 * be able to provide something higher-level to better suit your needs.
 *
 * @see https://reactrouter.com/docs/en/v6/hooks/use-location
 */

function dist_useLocation() {
  !useInRouterContext() ?  false ? 0 : router_invariant(false) : void 0;
  return react.useContext(LocationContext).location;
}
/**
 * Returns the current navigation action which describes how the router came to
 * the current location, either by a pop, push, or replace on the history stack.
 *
 * @see https://reactrouter.com/docs/en/v6/hooks/use-navigation-type
 */

function useNavigationType() {
  return React.useContext(LocationContext).navigationType;
}
/**
 * Returns true if the URL for the given "to" value matches the current URL.
 * This is useful for components that need to know "active" state, e.g.
 * <NavLink>.
 *
 * @see https://reactrouter.com/docs/en/v6/hooks/use-match
 */

function useMatch(pattern) {
  !useInRouterContext() ?  false ? 0 : invariant(false) : void 0;
  let {
    pathname
  } = dist_useLocation();
  return React.useMemo(() => matchPath(pattern, pathname), [pathname, pattern]);
}
/**
 * The interface for the navigate() function returned from useNavigate().
 */

/**
 * Returns an imperative method for changing the location. Used by <Link>s, but
 * may also be used by other elements to change the location.
 *
 * @see https://reactrouter.com/docs/en/v6/hooks/use-navigate
 */
function dist_useNavigate() {
  !useInRouterContext() ?  false ? 0 : router_invariant(false) : void 0;
  let {
    basename,
    navigator
  } = react.useContext(NavigationContext);
  let {
    matches
  } = react.useContext(RouteContext);
  let {
    pathname: locationPathname
  } = dist_useLocation();
  let routePathnamesJson = JSON.stringify(getPathContributingMatches(matches).map(match => match.pathnameBase));
  let activeRef = react.useRef(false);
  react.useEffect(() => {
    activeRef.current = true;
  });
  let navigate = react.useCallback(function (to, options) {
    if (options === void 0) {
      options = {};
    }

     false ? 0 : void 0;
    if (!activeRef.current) return;

    if (typeof to === "number") {
      navigator.go(to);
      return;
    }

    let path = resolveTo(to, JSON.parse(routePathnamesJson), locationPathname, options.relative === "path"); // If we're operating within a basename, prepend it to the pathname prior
    // to handing off to history.  If this is a root navigation, then we
    // navigate to the raw basename which allows the basename to have full
    // control over the presence of a trailing slash on root links

    if (basename !== "/") {
      path.pathname = path.pathname === "/" ? basename : router_joinPaths([basename, path.pathname]);
    }

    (!!options.replace ? navigator.replace : navigator.push)(path, options.state, options);
  }, [basename, navigator, routePathnamesJson, locationPathname]);
  return navigate;
}
const OutletContext = /*#__PURE__*/react.createContext(null);
/**
 * Returns the context (if provided) for the child route at this level of the route
 * hierarchy.
 * @see https://reactrouter.com/docs/en/v6/hooks/use-outlet-context
 */

function useOutletContext() {
  return React.useContext(OutletContext);
}
/**
 * Returns the element for the child route at this level of the route
 * hierarchy. Used internally by <Outlet> to render child routes.
 *
 * @see https://reactrouter.com/docs/en/v6/hooks/use-outlet
 */

function useOutlet(context) {
  let outlet = react.useContext(RouteContext).outlet;

  if (outlet) {
    return /*#__PURE__*/react.createElement(OutletContext.Provider, {
      value: context
    }, outlet);
  }

  return outlet;
}
/**
 * Returns an object of key/value pairs of the dynamic params from the current
 * URL that were matched by the route path.
 *
 * @see https://reactrouter.com/docs/en/v6/hooks/use-params
 */

function useParams() {
  let {
    matches
  } = React.useContext(RouteContext);
  let routeMatch = matches[matches.length - 1];
  return routeMatch ? routeMatch.params : {};
}
/**
 * Resolves the pathname of the given `to` value against the current location.
 *
 * @see https://reactrouter.com/docs/en/v6/hooks/use-resolved-path
 */

function dist_useResolvedPath(to, _temp2) {
  let {
    relative
  } = _temp2 === void 0 ? {} : _temp2;
  let {
    matches
  } = react.useContext(RouteContext);
  let {
    pathname: locationPathname
  } = dist_useLocation();
  let routePathnamesJson = JSON.stringify(getPathContributingMatches(matches).map(match => match.pathnameBase));
  return react.useMemo(() => resolveTo(to, JSON.parse(routePathnamesJson), locationPathname, relative === "path"), [to, routePathnamesJson, locationPathname, relative]);
}
/**
 * Returns the element of the route that matched the current location, prepared
 * with the correct context to render the remainder of the route tree. Route
 * elements in the tree must render an <Outlet> to render their child route's
 * element.
 *
 * @see https://reactrouter.com/docs/en/v6/hooks/use-routes
 */

function useRoutes(routes, locationArg) {
  !useInRouterContext() ?  false ? 0 : router_invariant(false) : void 0;
  let dataRouterStateContext = react.useContext(DataRouterStateContext);
  let {
    matches: parentMatches
  } = react.useContext(RouteContext);
  let routeMatch = parentMatches[parentMatches.length - 1];
  let parentParams = routeMatch ? routeMatch.params : {};
  let parentPathname = routeMatch ? routeMatch.pathname : "/";
  let parentPathnameBase = routeMatch ? routeMatch.pathnameBase : "/";
  let parentRoute = routeMatch && routeMatch.route;

  if (false) {}

  let locationFromContext = dist_useLocation();
  let location;

  if (locationArg) {
    var _parsedLocationArg$pa;

    let parsedLocationArg = typeof locationArg === "string" ? parsePath(locationArg) : locationArg;
    !(parentPathnameBase === "/" || ((_parsedLocationArg$pa = parsedLocationArg.pathname) == null ? void 0 : _parsedLocationArg$pa.startsWith(parentPathnameBase))) ?  false ? 0 : router_invariant(false) : void 0;
    location = parsedLocationArg;
  } else {
    location = locationFromContext;
  }

  let pathname = location.pathname || "/";
  let remainingPathname = parentPathnameBase === "/" ? pathname : pathname.slice(parentPathnameBase.length) || "/";
  let matches = matchRoutes(routes, {
    pathname: remainingPathname
  });

  if (false) {}

  let renderedMatches = _renderMatches(matches && matches.map(match => Object.assign({}, match, {
    params: Object.assign({}, parentParams, match.params),
    pathname: router_joinPaths([parentPathnameBase, match.pathname]),
    pathnameBase: match.pathnameBase === "/" ? parentPathnameBase : router_joinPaths([parentPathnameBase, match.pathnameBase])
  })), parentMatches, dataRouterStateContext || undefined); // When a user passes in a `locationArg`, the associated routes need to
  // be wrapped in a new `LocationContext.Provider` in order for `useLocation`
  // to use the scoped location instead of the global location.


  if (locationArg && renderedMatches) {
    return /*#__PURE__*/react.createElement(LocationContext.Provider, {
      value: {
        location: dist_extends({
          pathname: "/",
          search: "",
          hash: "",
          state: null,
          key: "default"
        }, location),
        navigationType: Action.Pop
      }
    }, renderedMatches);
  }

  return renderedMatches;
}

function DefaultErrorElement() {
  let error = useRouteError();
  let message = isRouteErrorResponse(error) ? error.status + " " + error.statusText : error instanceof Error ? error.message : JSON.stringify(error);
  let stack = error instanceof Error ? error.stack : null;
  let lightgrey = "rgba(200,200,200, 0.5)";
  let preStyles = {
    padding: "0.5rem",
    backgroundColor: lightgrey
  };
  let codeStyles = {
    padding: "2px 4px",
    backgroundColor: lightgrey
  };
  return /*#__PURE__*/react.createElement(react.Fragment, null, /*#__PURE__*/react.createElement("h2", null, "Unhandled Thrown Error!"), /*#__PURE__*/react.createElement("h3", {
    style: {
      fontStyle: "italic"
    }
  }, message), stack ? /*#__PURE__*/react.createElement("pre", {
    style: preStyles
  }, stack) : null, /*#__PURE__*/react.createElement("p", null, "\uD83D\uDCBF Hey developer \uD83D\uDC4B"), /*#__PURE__*/react.createElement("p", null, "You can provide a way better UX than this when your app throws errors by providing your own\xA0", /*#__PURE__*/react.createElement("code", {
    style: codeStyles
  }, "errorElement"), " props on\xA0", /*#__PURE__*/react.createElement("code", {
    style: codeStyles
  }, "<Route>")));
}

class RenderErrorBoundary extends react.Component {
  constructor(props) {
    super(props);
    this.state = {
      location: props.location,
      error: props.error
    };
  }

  static getDerivedStateFromError(error) {
    return {
      error: error
    };
  }

  static getDerivedStateFromProps(props, state) {
    // When we get into an error state, the user will likely click "back" to the
    // previous page that didn't have an error. Because this wraps the entire
    // application, that will have no effect--the error page continues to display.
    // This gives us a mechanism to recover from the error when the location changes.
    //
    // Whether we're in an error state or not, we update the location in state
    // so that when we are in an error state, it gets reset when a new location
    // comes in and the user recovers from the error.
    if (state.location !== props.location) {
      return {
        error: props.error,
        location: props.location
      };
    } // If we're not changing locations, preserve the location but still surface
    // any new errors that may come through. We retain the existing error, we do
    // this because the error provided from the app state may be cleared without
    // the location changing.


    return {
      error: props.error || state.error,
      location: state.location
    };
  }

  componentDidCatch(error, errorInfo) {
    console.error("React Router caught the following error during render", error, errorInfo);
  }

  render() {
    return this.state.error ? /*#__PURE__*/react.createElement(RouteErrorContext.Provider, {
      value: this.state.error,
      children: this.props.component
    }) : this.props.children;
  }

}

function RenderedRoute(_ref) {
  let {
    routeContext,
    match,
    children
  } = _ref;
  let dataStaticRouterContext = react.useContext(DataStaticRouterContext); // Track how deep we got in our render pass to emulate SSR componentDidCatch
  // in a DataStaticRouter

  if (dataStaticRouterContext && match.route.errorElement) {
    dataStaticRouterContext._deepestRenderedBoundaryId = match.route.id;
  }

  return /*#__PURE__*/react.createElement(RouteContext.Provider, {
    value: routeContext
  }, children);
}

function _renderMatches(matches, parentMatches, dataRouterState) {
  if (parentMatches === void 0) {
    parentMatches = [];
  }

  if (matches == null) {
    if (dataRouterState != null && dataRouterState.errors) {
      // Don't bail if we have data router errors so we can render them in the
      // boundary.  Use the pre-matched (or shimmed) matches
      matches = dataRouterState.matches;
    } else {
      return null;
    }
  }

  let renderedMatches = matches; // If we have data errors, trim matches to the highest error boundary

  let errors = dataRouterState == null ? void 0 : dataRouterState.errors;

  if (errors != null) {
    let errorIndex = renderedMatches.findIndex(m => m.route.id && (errors == null ? void 0 : errors[m.route.id]));
    !(errorIndex >= 0) ?  false ? 0 : router_invariant(false) : void 0;
    renderedMatches = renderedMatches.slice(0, Math.min(renderedMatches.length, errorIndex + 1));
  }

  return renderedMatches.reduceRight((outlet, match, index) => {
    let error = match.route.id ? errors == null ? void 0 : errors[match.route.id] : null; // Only data routers handle errors

    let errorElement = dataRouterState ? match.route.errorElement || /*#__PURE__*/react.createElement(DefaultErrorElement, null) : null;

    let getChildren = () => /*#__PURE__*/react.createElement(RenderedRoute, {
      match: match,
      routeContext: {
        outlet,
        matches: parentMatches.concat(renderedMatches.slice(0, index + 1))
      }
    }, error ? errorElement : match.route.element !== undefined ? match.route.element : outlet); // Only wrap in an error boundary within data router usages when we have an
    // errorElement on this route.  Otherwise let it bubble up to an ancestor
    // errorElement


    return dataRouterState && (match.route.errorElement || index === 0) ? /*#__PURE__*/react.createElement(RenderErrorBoundary, {
      location: dataRouterState.location,
      component: errorElement,
      error: error,
      children: getChildren()
    }) : getChildren();
  }, null);
}
var DataRouterHook;

(function (DataRouterHook) {
  DataRouterHook["UseRevalidator"] = "useRevalidator";
})(DataRouterHook || (DataRouterHook = {}));

var DataRouterStateHook;

(function (DataRouterStateHook) {
  DataRouterStateHook["UseLoaderData"] = "useLoaderData";
  DataRouterStateHook["UseActionData"] = "useActionData";
  DataRouterStateHook["UseRouteError"] = "useRouteError";
  DataRouterStateHook["UseNavigation"] = "useNavigation";
  DataRouterStateHook["UseRouteLoaderData"] = "useRouteLoaderData";
  DataRouterStateHook["UseMatches"] = "useMatches";
  DataRouterStateHook["UseRevalidator"] = "useRevalidator";
})(DataRouterStateHook || (DataRouterStateHook = {}));

function getDataRouterConsoleError(hookName) {
  return hookName + " must be used within a data router.  See https://reactrouter.com/en/main/routers/picking-a-router.";
}

function useDataRouterContext(hookName) {
  let ctx = React.useContext(DataRouterContext);
  !ctx ?  false ? 0 : invariant(false) : void 0;
  return ctx;
}

function useDataRouterState(hookName) {
  let state = react.useContext(DataRouterStateContext);
  !state ?  false ? 0 : router_invariant(false) : void 0;
  return state;
}
/**
 * Returns the current navigation, defaulting to an "idle" navigation when
 * no navigation is in progress
 */


function dist_useNavigation() {
  let state = useDataRouterState(DataRouterStateHook.UseNavigation);
  return state.navigation;
}
/**
 * Returns a revalidate function for manually triggering revalidation, as well
 * as the current state of any manual revalidations
 */

function useRevalidator() {
  let dataRouterContext = useDataRouterContext(DataRouterHook.UseRevalidator);
  let state = useDataRouterState(DataRouterStateHook.UseRevalidator);
  return {
    revalidate: dataRouterContext.router.revalidate,
    state: state.revalidation
  };
}
/**
 * Returns the active route matches, useful for accessing loaderData for
 * parent/child routes or the route "handle" property
 */

function dist_useMatches() {
  let {
    matches,
    loaderData
  } = useDataRouterState(DataRouterStateHook.UseMatches);
  return React.useMemo(() => matches.map(match => {
    let {
      pathname,
      params
    } = match; // Note: This structure matches that created by createUseMatchesMatch
    // in the @remix-run/router , so if you change this please also change
    // that :)  Eventually we'll DRY this up

    return {
      id: match.route.id,
      pathname,
      params,
      data: loaderData[match.route.id],
      handle: match.route.handle
    };
  }), [matches, loaderData]);
}
/**
 * Returns the loader data for the nearest ancestor Route loader
 */

function useLoaderData() {
  let state = useDataRouterState(DataRouterStateHook.UseLoaderData);
  let route = React.useContext(RouteContext);
  !route ?  false ? 0 : invariant(false) : void 0;
  let thisRoute = route.matches[route.matches.length - 1];
  !thisRoute.route.id ?  false ? 0 : invariant(false) : void 0;
  return state.loaderData[thisRoute.route.id];
}
/**
 * Returns the loaderData for the given routeId
 */

function useRouteLoaderData(routeId) {
  let state = useDataRouterState(DataRouterStateHook.UseRouteLoaderData);
  return state.loaderData[routeId];
}
/**
 * Returns the action data for the nearest ancestor Route action
 */

function useActionData() {
  let state = useDataRouterState(DataRouterStateHook.UseActionData);
  let route = React.useContext(RouteContext);
  !route ?  false ? 0 : invariant(false) : void 0;
  return Object.values((state == null ? void 0 : state.actionData) || {})[0];
}
/**
 * Returns the nearest ancestor Route error, which could be a loader/action
 * error or a render error.  This is intended to be called from your
 * errorElement to display a proper error message.
 */

function useRouteError() {
  var _state$errors;

  let error = react.useContext(RouteErrorContext);
  let state = useDataRouterState(DataRouterStateHook.UseRouteError);
  let route = react.useContext(RouteContext);
  let thisRoute = route.matches[route.matches.length - 1]; // If this was a render error, we put it in a RouteError context inside
  // of RenderErrorBoundary

  if (error) {
    return error;
  }

  !route ?  false ? 0 : router_invariant(false) : void 0;
  !thisRoute.route.id ?  false ? 0 : router_invariant(false) : void 0; // Otherwise look for errors from our data router state

  return (_state$errors = state.errors) == null ? void 0 : _state$errors[thisRoute.route.id];
}
/**
 * Returns the happy-path data from the nearest ancestor <Await /> value
 */

function useAsyncValue() {
  let value = React.useContext(AwaitContext);
  return value == null ? void 0 : value._data;
}
/**
 * Returns the error from the nearest ancestor <Await /> value
 */

function useAsyncError() {
  let value = React.useContext(AwaitContext);
  return value == null ? void 0 : value._error;
}
const alreadyWarned = {};

function warningOnce(key, cond, message) {
  if (!cond && !alreadyWarned[key]) {
    alreadyWarned[key] = true;
     false ? 0 : void 0;
  }
}

/**
 * Given a Remix Router instance, render the appropriate UI
 */
function RouterProvider(_ref) {
  let {
    fallbackElement,
    router
  } = _ref;
  // Sync router state to our component state to force re-renders
  let state = useSyncExternalStore(router.subscribe, () => router.state, // We have to provide this so React@18 doesn't complain during hydration,
  // but we pass our serialized hydration data into the router so state here
  // is already synced with what the server saw
  () => router.state);
  let navigator = React.useMemo(() => {
    return {
      createHref: router.createHref,
      go: n => router.navigate(n),
      push: (to, state, opts) => router.navigate(to, {
        state,
        preventScrollReset: opts == null ? void 0 : opts.preventScrollReset
      }),
      replace: (to, state, opts) => router.navigate(to, {
        replace: true,
        state,
        preventScrollReset: opts == null ? void 0 : opts.preventScrollReset
      })
    };
  }, [router]);
  let basename = router.basename || "/";
  return /*#__PURE__*/React.createElement(DataRouterContext.Provider, {
    value: {
      router,
      navigator,
      static: false,
      // Do we need this?
      basename
    }
  }, /*#__PURE__*/React.createElement(DataRouterStateContext.Provider, {
    value: state
  }, /*#__PURE__*/React.createElement(dist_Router, {
    basename: router.basename,
    location: router.state.location,
    navigationType: router.state.historyAction,
    navigator: navigator
  }, router.state.initialized ? /*#__PURE__*/React.createElement(Routes, null) : fallbackElement)));
}

/**
 * A <Router> that stores all entries in memory.
 *
 * @see https://reactrouter.com/docs/en/v6/routers/memory-router
 */
function MemoryRouter(_ref2) {
  let {
    basename,
    children,
    initialEntries,
    initialIndex
  } = _ref2;
  let historyRef = react.useRef();

  if (historyRef.current == null) {
    historyRef.current = router_createMemoryHistory({
      initialEntries,
      initialIndex,
      v5Compat: true
    });
  }

  let history = historyRef.current;
  let [state, setState] = react.useState({
    action: history.action,
    location: history.location
  });
  react.useLayoutEffect(() => history.listen(setState), [history]);
  return /*#__PURE__*/react.createElement(dist_Router, {
    basename: basename,
    children: children,
    location: state.location,
    navigationType: state.action,
    navigator: history
  });
}

/**
 * Changes the current location.
 *
 * Note: This API is mostly useful in React.Component subclasses that are not
 * able to use hooks. In functional components, we recommend you use the
 * `useNavigate` hook instead.
 *
 * @see https://reactrouter.com/docs/en/v6/components/navigate
 */
function Navigate(_ref3) {
  let {
    to,
    replace,
    state,
    relative
  } = _ref3;
  !useInRouterContext() ?  false ? 0 : router_invariant(false) : void 0;
   false ? 0 : void 0;
  let dataRouterState = react.useContext(DataRouterStateContext);
  let navigate = dist_useNavigate();
  react.useEffect(() => {
    // Avoid kicking off multiple navigations if we're in the middle of a
    // data-router navigation, since components get re-rendered when we enter
    // a submitting/loading state
    if (dataRouterState && dataRouterState.navigation.state !== "idle") {
      return;
    }

    navigate(to, {
      replace,
      state,
      relative
    });
  });
  return null;
}

/**
 * Renders the child route's element, if there is one.
 *
 * @see https://reactrouter.com/docs/en/v6/components/outlet
 */
function Outlet(props) {
  return useOutlet(props.context);
}

/**
 * Declares an element that should be rendered at a certain URL path.
 *
 * @see https://reactrouter.com/docs/en/v6/components/route
 */
function Route(_props) {
   false ? 0 : router_invariant(false) ;
}

/**
 * Provides location context for the rest of the app.
 *
 * Note: You usually won't render a <Router> directly. Instead, you'll render a
 * router that is more specific to your environment such as a <BrowserRouter>
 * in web browsers or a <StaticRouter> for server rendering.
 *
 * @see https://reactrouter.com/docs/en/v6/routers/router
 */
function dist_Router(_ref4) {
  let {
    basename: basenameProp = "/",
    children = null,
    location: locationProp,
    navigationType = Action.Pop,
    navigator,
    static: staticProp = false
  } = _ref4;
  !!useInRouterContext() ?  false ? 0 : router_invariant(false) : void 0; // Preserve trailing slashes on basename, so we can let the user control
  // the enforcement of trailing slashes throughout the app

  let basename = basenameProp.replace(/^\/*/, "/");
  let navigationContext = react.useMemo(() => ({
    basename,
    navigator,
    static: staticProp
  }), [basename, navigator, staticProp]);

  if (typeof locationProp === "string") {
    locationProp = parsePath(locationProp);
  }

  let {
    pathname = "/",
    search = "",
    hash = "",
    state = null,
    key = "default"
  } = locationProp;
  let location = react.useMemo(() => {
    let trailingPathname = stripBasename(pathname, basename);

    if (trailingPathname == null) {
      return null;
    }

    return {
      pathname: trailingPathname,
      search,
      hash,
      state,
      key
    };
  }, [basename, pathname, search, hash, state, key]);
   false ? 0 : void 0;

  if (location == null) {
    return null;
  }

  return /*#__PURE__*/react.createElement(NavigationContext.Provider, {
    value: navigationContext
  }, /*#__PURE__*/react.createElement(LocationContext.Provider, {
    children: children,
    value: {
      location,
      navigationType
    }
  }));
}

/**
 * A container for a nested tree of <Route> elements that renders the branch
 * that best matches the current location.
 *
 * @see https://reactrouter.com/docs/en/v6/components/routes
 */
function Routes(_ref5) {
  let {
    children,
    location
  } = _ref5;
  let dataRouterContext = react.useContext(DataRouterContext); // When in a DataRouterContext _without_ children, we use the router routes
  // directly.  If we have children, then we're in a descendant tree and we
  // need to use child routes.

  let routes = dataRouterContext && !children ? dataRouterContext.router.routes : createRoutesFromChildren(children);
  return useRoutes(routes, location);
}

/**
 * Component to use for rendering lazily loaded data from returning defer()
 * in a loader function
 */
function Await(_ref6) {
  let {
    children,
    errorElement,
    resolve
  } = _ref6;
  return /*#__PURE__*/React.createElement(AwaitErrorBoundary, {
    resolve: resolve,
    errorElement: errorElement
  }, /*#__PURE__*/React.createElement(ResolveAwait, null, children));
}
var AwaitRenderStatus;

(function (AwaitRenderStatus) {
  AwaitRenderStatus[AwaitRenderStatus["pending"] = 0] = "pending";
  AwaitRenderStatus[AwaitRenderStatus["success"] = 1] = "success";
  AwaitRenderStatus[AwaitRenderStatus["error"] = 2] = "error";
})(AwaitRenderStatus || (AwaitRenderStatus = {}));

const neverSettledPromise = new Promise(() => {});

class AwaitErrorBoundary extends react.Component {
  constructor(props) {
    super(props);
    this.state = {
      error: null
    };
  }

  static getDerivedStateFromError(error) {
    return {
      error
    };
  }

  componentDidCatch(error, errorInfo) {
    console.error("<Await> caught the following error during render", error, errorInfo);
  }

  render() {
    let {
      children,
      errorElement,
      resolve
    } = this.props;
    let promise = null;
    let status = AwaitRenderStatus.pending;

    if (!(resolve instanceof Promise)) {
      // Didn't get a promise - provide as a resolved promise
      status = AwaitRenderStatus.success;
      promise = Promise.resolve();
      Object.defineProperty(promise, "_tracked", {
        get: () => true
      });
      Object.defineProperty(promise, "_data", {
        get: () => resolve
      });
    } else if (this.state.error) {
      // Caught a render error, provide it as a rejected promise
      status = AwaitRenderStatus.error;
      let renderError = this.state.error;
      promise = Promise.reject().catch(() => {}); // Avoid unhandled rejection warnings

      Object.defineProperty(promise, "_tracked", {
        get: () => true
      });
      Object.defineProperty(promise, "_error", {
        get: () => renderError
      });
    } else if (resolve._tracked) {
      // Already tracked promise - check contents
      promise = resolve;
      status = promise._error !== undefined ? AwaitRenderStatus.error : promise._data !== undefined ? AwaitRenderStatus.success : AwaitRenderStatus.pending;
    } else {
      // Raw (untracked) promise - track it
      status = AwaitRenderStatus.pending;
      Object.defineProperty(resolve, "_tracked", {
        get: () => true
      });
      promise = resolve.then(data => Object.defineProperty(resolve, "_data", {
        get: () => data
      }), error => Object.defineProperty(resolve, "_error", {
        get: () => error
      }));
    }

    if (status === AwaitRenderStatus.error && promise._error instanceof AbortedDeferredError) {
      // Freeze the UI by throwing a never resolved promise
      throw neverSettledPromise;
    }

    if (status === AwaitRenderStatus.error && !errorElement) {
      // No errorElement, throw to the nearest route-level error boundary
      throw promise._error;
    }

    if (status === AwaitRenderStatus.error) {
      // Render via our errorElement
      return /*#__PURE__*/React.createElement(AwaitContext.Provider, {
        value: promise,
        children: errorElement
      });
    }

    if (status === AwaitRenderStatus.success) {
      // Render children with resolved value
      return /*#__PURE__*/React.createElement(AwaitContext.Provider, {
        value: promise,
        children: children
      });
    } // Throw to the suspense boundary


    throw promise;
  }

}
/**
 * @private
 * Indirection to leverage useAsyncValue for a render-prop API on <Await>
 */


function ResolveAwait(_ref7) {
  let {
    children
  } = _ref7;
  let data = useAsyncValue();

  if (typeof children === "function") {
    return children(data);
  }

  return /*#__PURE__*/React.createElement(React.Fragment, null, children);
} ///////////////////////////////////////////////////////////////////////////////
// UTILS
///////////////////////////////////////////////////////////////////////////////

/**
 * Creates a route config from a React "children" object, which is usually
 * either a `<Route>` element or an array of them. Used internally by
 * `<Routes>` to create a route config from its children.
 *
 * @see https://reactrouter.com/docs/en/v6/utils/create-routes-from-children
 */


function createRoutesFromChildren(children, parentPath) {
  if (parentPath === void 0) {
    parentPath = [];
  }

  let routes = [];
  react.Children.forEach(children, (element, index) => {
    if (! /*#__PURE__*/react.isValidElement(element)) {
      // Ignore non-elements. This allows people to more easily inline
      // conditionals in their route config.
      return;
    }

    if (element.type === react.Fragment) {
      // Transparently support React.Fragment and its children.
      routes.push.apply(routes, createRoutesFromChildren(element.props.children, parentPath));
      return;
    }

    !(element.type === Route) ?  false ? 0 : router_invariant(false) : void 0;
    !(!element.props.index || !element.props.children) ?  false ? 0 : router_invariant(false) : void 0;
    let treePath = [...parentPath, index];
    let route = {
      id: element.props.id || treePath.join("-"),
      caseSensitive: element.props.caseSensitive,
      element: element.props.element,
      index: element.props.index,
      path: element.props.path,
      loader: element.props.loader,
      action: element.props.action,
      errorElement: element.props.errorElement,
      hasErrorBoundary: element.props.errorElement != null,
      shouldRevalidate: element.props.shouldRevalidate,
      handle: element.props.handle
    };

    if (element.props.children) {
      route.children = createRoutesFromChildren(element.props.children, treePath);
    }

    routes.push(route);
  });
  return routes;
}
/**
 * Renders the result of `matchRoutes()` into a React element.
 */

function renderMatches(matches) {
  return _renderMatches(matches);
}
/**
 * @private
 * Walk the route tree and add hasErrorBoundary if it's not provided, so that
 * users providing manual route arrays can just specify errorElement
 */

function enhanceManualRouteObjects(routes) {
  return routes.map(route => {
    let routeClone = dist_extends({}, route);

    if (routeClone.hasErrorBoundary == null) {
      routeClone.hasErrorBoundary = routeClone.errorElement != null;
    }

    if (routeClone.children) {
      routeClone.children = enhanceManualRouteObjects(routeClone.children);
    }

    return routeClone;
  });
}

function createMemoryRouter(routes, opts) {
  return createRouter({
    basename: opts == null ? void 0 : opts.basename,
    history: createMemoryHistory({
      initialEntries: opts == null ? void 0 : opts.initialEntries,
      initialIndex: opts == null ? void 0 : opts.initialIndex
    }),
    hydrationData: opts == null ? void 0 : opts.hydrationData,
    routes: enhanceManualRouteObjects(routes)
  }).initialize();
} ///////////////////////////////////////////////////////////////////////////////


//# sourceMappingURL=index.js.map

;// CONCATENATED MODULE: ./node_modules/react-router-dom/dist/index.js
/**
 * React Router DOM v6.4.3
 *
 * Copyright (c) Remix Software Inc.
 *
 * This source code is licensed under the MIT license found in the
 * LICENSE.md file in the root directory of this source tree.
 *
 * @license MIT
 */





function react_router_dom_dist_extends() {
  react_router_dom_dist_extends = Object.assign ? Object.assign.bind() : function (target) {
    for (var i = 1; i < arguments.length; i++) {
      var source = arguments[i];

      for (var key in source) {
        if (Object.prototype.hasOwnProperty.call(source, key)) {
          target[key] = source[key];
        }
      }
    }

    return target;
  };
  return react_router_dom_dist_extends.apply(this, arguments);
}

function _objectWithoutPropertiesLoose(source, excluded) {
  if (source == null) return {};
  var target = {};
  var sourceKeys = Object.keys(source);
  var key, i;

  for (i = 0; i < sourceKeys.length; i++) {
    key = sourceKeys[i];
    if (excluded.indexOf(key) >= 0) continue;
    target[key] = source[key];
  }

  return target;
}

const defaultMethod = "get";
const defaultEncType = "application/x-www-form-urlencoded";
function isHtmlElement(object) {
  return object != null && typeof object.tagName === "string";
}
function isButtonElement(object) {
  return isHtmlElement(object) && object.tagName.toLowerCase() === "button";
}
function isFormElement(object) {
  return isHtmlElement(object) && object.tagName.toLowerCase() === "form";
}
function isInputElement(object) {
  return isHtmlElement(object) && object.tagName.toLowerCase() === "input";
}

function isModifiedEvent(event) {
  return !!(event.metaKey || event.altKey || event.ctrlKey || event.shiftKey);
}

function shouldProcessLinkClick(event, target) {
  return event.button === 0 && ( // Ignore everything but left clicks
  !target || target === "_self") && // Let browser handle "target=_blank" etc.
  !isModifiedEvent(event) // Ignore clicks with modifier keys
  ;
}
/**
 * Creates a URLSearchParams object using the given initializer.
 *
 * This is identical to `new URLSearchParams(init)` except it also
 * supports arrays as values in the object form of the initializer
 * instead of just strings. This is convenient when you need multiple
 * values for a given key, but don't want to use an array initializer.
 *
 * For example, instead of:
 *
 *   let searchParams = new URLSearchParams([
 *     ['sort', 'name'],
 *     ['sort', 'price']
 *   ]);
 *
 * you can do:
 *
 *   let searchParams = createSearchParams({
 *     sort: ['name', 'price']
 *   });
 */

function createSearchParams(init) {
  if (init === void 0) {
    init = "";
  }

  return new URLSearchParams(typeof init === "string" || Array.isArray(init) || init instanceof URLSearchParams ? init : Object.keys(init).reduce((memo, key) => {
    let value = init[key];
    return memo.concat(Array.isArray(value) ? value.map(v => [key, v]) : [[key, value]]);
  }, []));
}
function getSearchParamsForLocation(locationSearch, defaultSearchParams) {
  let searchParams = createSearchParams(locationSearch);

  for (let key of defaultSearchParams.keys()) {
    if (!searchParams.has(key)) {
      defaultSearchParams.getAll(key).forEach(value => {
        searchParams.append(key, value);
      });
    }
  }

  return searchParams;
}
function getFormSubmissionInfo(target, defaultAction, options) {
  let method;
  let action;
  let encType;
  let formData;

  if (isFormElement(target)) {
    let submissionTrigger = options.submissionTrigger;
    method = options.method || target.getAttribute("method") || defaultMethod;
    action = options.action || target.getAttribute("action") || defaultAction;
    encType = options.encType || target.getAttribute("enctype") || defaultEncType;
    formData = new FormData(target);

    if (submissionTrigger && submissionTrigger.name) {
      formData.append(submissionTrigger.name, submissionTrigger.value);
    }
  } else if (isButtonElement(target) || isInputElement(target) && (target.type === "submit" || target.type === "image")) {
    let form = target.form;

    if (form == null) {
      throw new Error("Cannot submit a <button> or <input type=\"submit\"> without a <form>");
    } // <button>/<input type="submit"> may override attributes of <form>


    method = options.method || target.getAttribute("formmethod") || form.getAttribute("method") || defaultMethod;
    action = options.action || target.getAttribute("formaction") || form.getAttribute("action") || defaultAction;
    encType = options.encType || target.getAttribute("formenctype") || form.getAttribute("enctype") || defaultEncType;
    formData = new FormData(form); // Include name + value from a <button>, appending in case the button name
    // matches an existing input name

    if (target.name) {
      formData.append(target.name, target.value);
    }
  } else if (isHtmlElement(target)) {
    throw new Error("Cannot submit element that is not <form>, <button>, or " + "<input type=\"submit|image\">");
  } else {
    method = options.method || defaultMethod;
    action = options.action || defaultAction;
    encType = options.encType || defaultEncType;

    if (target instanceof FormData) {
      formData = target;
    } else {
      formData = new FormData();

      if (target instanceof URLSearchParams) {
        for (let [name, value] of target) {
          formData.append(name, value);
        }
      } else if (target != null) {
        for (let name of Object.keys(target)) {
          formData.append(name, target[name]);
        }
      }
    }
  }

  let {
    protocol,
    host
  } = window.location;
  let url = new URL(action, protocol + "//" + host);
  return {
    url,
    method,
    encType,
    formData
  };
}

const _excluded = ["onClick", "relative", "reloadDocument", "replace", "state", "target", "to", "preventScrollReset"],
      _excluded2 = ["aria-current", "caseSensitive", "className", "end", "style", "to", "children"],
      _excluded3 = (/* unused pure expression or super */ null && (["reloadDocument", "replace", "method", "action", "onSubmit", "fetcherKey", "routeId", "relative"]));
//#region Routers
////////////////////////////////////////////////////////////////////////////////

function createBrowserRouter(routes, opts) {
  var _window;

  return createRouter({
    basename: opts == null ? void 0 : opts.basename,
    history: createBrowserHistory({
      window: opts == null ? void 0 : opts.window
    }),
    hydrationData: (opts == null ? void 0 : opts.hydrationData) || ((_window = window) == null ? void 0 : _window.__staticRouterHydrationData),
    routes: UNSAFE_enhanceManualRouteObjects(routes)
  }).initialize();
}
function createHashRouter(routes, opts) {
  var _window2;

  return createRouter({
    basename: opts == null ? void 0 : opts.basename,
    history: createHashHistory({
      window: opts == null ? void 0 : opts.window
    }),
    hydrationData: (opts == null ? void 0 : opts.hydrationData) || ((_window2 = window) == null ? void 0 : _window2.__staticRouterHydrationData),
    routes: UNSAFE_enhanceManualRouteObjects(routes)
  }).initialize();
}
/**
 * A `<Router>` for use in web browsers. Provides the cleanest URLs.
 */

function BrowserRouter(_ref) {
  let {
    basename,
    children,
    window
  } = _ref;
  let historyRef = React.useRef();

  if (historyRef.current == null) {
    historyRef.current = createBrowserHistory({
      window,
      v5Compat: true
    });
  }

  let history = historyRef.current;
  let [state, setState] = React.useState({
    action: history.action,
    location: history.location
  });
  React.useLayoutEffect(() => history.listen(setState), [history]);
  return /*#__PURE__*/React.createElement(Router, {
    basename: basename,
    children: children,
    location: state.location,
    navigationType: state.action,
    navigator: history
  });
}
/**
 * A `<Router>` for use in web browsers. Stores the location in the hash
 * portion of the URL so it is not sent to the server.
 */

function HashRouter(_ref2) {
  let {
    basename,
    children,
    window
  } = _ref2;
  let historyRef = React.useRef();

  if (historyRef.current == null) {
    historyRef.current = createHashHistory({
      window,
      v5Compat: true
    });
  }

  let history = historyRef.current;
  let [state, setState] = React.useState({
    action: history.action,
    location: history.location
  });
  React.useLayoutEffect(() => history.listen(setState), [history]);
  return /*#__PURE__*/React.createElement(Router, {
    basename: basename,
    children: children,
    location: state.location,
    navigationType: state.action,
    navigator: history
  });
}
/**
 * A `<Router>` that accepts a pre-instantiated history object. It's important
 * to note that using your own history object is highly discouraged and may add
 * two versions of the history library to your bundles unless you use the same
 * version of the history library that React Router uses internally.
 */

function HistoryRouter(_ref3) {
  let {
    basename,
    children,
    history
  } = _ref3;
  const [state, setState] = React.useState({
    action: history.action,
    location: history.location
  });
  React.useLayoutEffect(() => history.listen(setState), [history]);
  return /*#__PURE__*/React.createElement(Router, {
    basename: basename,
    children: children,
    location: state.location,
    navigationType: state.action,
    navigator: history
  });
}

if (false) {}
/**
 * The public API for rendering a history-aware <a>.
 */

const Link = /*#__PURE__*/react.forwardRef(function LinkWithRef(_ref4, ref) {
  let {
    onClick,
    relative,
    reloadDocument,
    replace,
    state,
    target,
    to,
    preventScrollReset
  } = _ref4,
      rest = _objectWithoutPropertiesLoose(_ref4, _excluded);

  let href = useHref(to, {
    relative
  });
  let internalOnClick = useLinkClickHandler(to, {
    replace,
    state,
    target,
    preventScrollReset,
    relative
  });

  function handleClick(event) {
    if (onClick) onClick(event);

    if (!event.defaultPrevented) {
      internalOnClick(event);
    }
  }

  return (
    /*#__PURE__*/
    // eslint-disable-next-line jsx-a11y/anchor-has-content
    react.createElement("a", react_router_dom_dist_extends({}, rest, {
      href: href,
      onClick: reloadDocument ? onClick : handleClick,
      ref: ref,
      target: target
    }))
  );
});

if (false) {}
/**
 * A <Link> wrapper that knows if it's "active" or not.
 */


const NavLink = /*#__PURE__*/react.forwardRef(function NavLinkWithRef(_ref5, ref) {
  let {
    "aria-current": ariaCurrentProp = "page",
    caseSensitive = false,
    className: classNameProp = "",
    end = false,
    style: styleProp,
    to,
    children
  } = _ref5,
      rest = _objectWithoutPropertiesLoose(_ref5, _excluded2);

  let path = dist_useResolvedPath(to, {
    relative: rest.relative
  });
  let location = dist_useLocation();
  let routerState = react.useContext(DataRouterStateContext);
  let toPathname = path.pathname;
  let locationPathname = location.pathname;
  let nextLocationPathname = routerState && routerState.navigation && routerState.navigation.location ? routerState.navigation.location.pathname : null;

  if (!caseSensitive) {
    locationPathname = locationPathname.toLowerCase();
    nextLocationPathname = nextLocationPathname ? nextLocationPathname.toLowerCase() : null;
    toPathname = toPathname.toLowerCase();
  }

  let isActive = locationPathname === toPathname || !end && locationPathname.startsWith(toPathname) && locationPathname.charAt(toPathname.length) === "/";
  let isPending = nextLocationPathname != null && (nextLocationPathname === toPathname || !end && nextLocationPathname.startsWith(toPathname) && nextLocationPathname.charAt(toPathname.length) === "/");
  let ariaCurrent = isActive ? ariaCurrentProp : undefined;
  let className;

  if (typeof classNameProp === "function") {
    className = classNameProp({
      isActive,
      isPending
    });
  } else {
    // If the className prop is not a function, we use a default `active`
    // class for <NavLink />s that are active. In v5 `active` was the default
    // value for `activeClassName`, but we are removing that API and can still
    // use the old default behavior for a cleaner upgrade path and keep the
    // simple styling rules working as they currently do.
    className = [classNameProp, isActive ? "active" : null, isPending ? "pending" : null].filter(Boolean).join(" ");
  }

  let style = typeof styleProp === "function" ? styleProp({
    isActive,
    isPending
  }) : styleProp;
  return /*#__PURE__*/react.createElement(Link, react_router_dom_dist_extends({}, rest, {
    "aria-current": ariaCurrent,
    className: className,
    ref: ref,
    style: style,
    to: to
  }), typeof children === "function" ? children({
    isActive,
    isPending
  }) : children);
});

if (false) {}
/**
 * A `@remix-run/router`-aware `<form>`. It behaves like a normal form except
 * that the interaction with the server is with `fetch` instead of new document
 * requests, allowing components to add nicer UX to the page as the form is
 * submitted and returns with data.
 */


const Form = /*#__PURE__*/(/* unused pure expression or super */ null && (React.forwardRef((props, ref) => {
  return /*#__PURE__*/React.createElement(FormImpl, react_router_dom_dist_extends({}, props, {
    ref: ref
  }));
})));

if (false) {}

const FormImpl = /*#__PURE__*/(/* unused pure expression or super */ null && (React.forwardRef((_ref6, forwardedRef) => {
  let {
    reloadDocument,
    replace,
    method = defaultMethod,
    action,
    onSubmit,
    fetcherKey,
    routeId,
    relative
  } = _ref6,
      props = _objectWithoutPropertiesLoose(_ref6, _excluded3);

  let submit = useSubmitImpl(fetcherKey, routeId);
  let formMethod = method.toLowerCase() === "get" ? "get" : "post";
  let formAction = useFormAction(action, {
    relative
  });

  let submitHandler = event => {
    onSubmit && onSubmit(event);
    if (event.defaultPrevented) return;
    event.preventDefault();
    let submitter = event.nativeEvent.submitter;
    submit(submitter || event.currentTarget, {
      method,
      replace,
      relative
    });
  };

  return /*#__PURE__*/React.createElement("form", react_router_dom_dist_extends({
    ref: forwardedRef,
    method: formMethod,
    action: formAction,
    onSubmit: reloadDocument ? onSubmit : submitHandler
  }, props));
})));

if (false) {}
/**
 * This component will emulate the browser's scroll restoration on location
 * changes.
 */


function ScrollRestoration(_ref7) {
  let {
    getKey,
    storageKey
  } = _ref7;
  useScrollRestoration({
    getKey,
    storageKey
  });
  return null;
}

if (false) {} //#endregion
////////////////////////////////////////////////////////////////////////////////
//#region Hooks
////////////////////////////////////////////////////////////////////////////////


var dist_DataRouterHook;

(function (DataRouterHook) {
  DataRouterHook["UseScrollRestoration"] = "useScrollRestoration";
  DataRouterHook["UseSubmitImpl"] = "useSubmitImpl";
  DataRouterHook["UseFetcher"] = "useFetcher";
})(dist_DataRouterHook || (dist_DataRouterHook = {}));

var dist_DataRouterStateHook;

(function (DataRouterStateHook) {
  DataRouterStateHook["UseFetchers"] = "useFetchers";
  DataRouterStateHook["UseScrollRestoration"] = "useScrollRestoration";
})(dist_DataRouterStateHook || (dist_DataRouterStateHook = {}));

function dist_getDataRouterConsoleError(hookName) {
  return hookName + " must be used within a data router.  See https://reactrouter.com/en/main/routers/picking-a-router.";
}

function dist_useDataRouterContext(hookName) {
  let ctx = React.useContext(UNSAFE_DataRouterContext);
  !ctx ?  false ? 0 : invariant(false) : void 0;
  return ctx;
}

function dist_useDataRouterState(hookName) {
  let state = React.useContext(UNSAFE_DataRouterStateContext);
  !state ?  false ? 0 : invariant(false) : void 0;
  return state;
}
/**
 * Handles the click behavior for router `<Link>` components. This is useful if
 * you need to create custom `<Link>` components with the same click behavior we
 * use in our exported `<Link>`.
 */


function useLinkClickHandler(to, _temp) {
  let {
    target,
    replace: replaceProp,
    state,
    preventScrollReset,
    relative
  } = _temp === void 0 ? {} : _temp;
  let navigate = dist_useNavigate();
  let location = dist_useLocation();
  let path = dist_useResolvedPath(to, {
    relative
  });
  return react.useCallback(event => {
    if (shouldProcessLinkClick(event, target)) {
      event.preventDefault(); // If the URL hasn't changed, a regular <a> will do a replace instead of
      // a push, so do the same here unless the replace prop is explicitly set

      let replace = replaceProp !== undefined ? replaceProp : router_createPath(location) === router_createPath(path);
      navigate(to, {
        replace,
        state,
        preventScrollReset,
        relative
      });
    }
  }, [location, navigate, path, replaceProp, state, target, to, preventScrollReset, relative]);
}
/**
 * A convenient wrapper for reading and writing search parameters via the
 * URLSearchParams interface.
 */

function useSearchParams(defaultInit) {
   false ? 0 : void 0;
  let defaultSearchParamsRef = React.useRef(createSearchParams(defaultInit));
  let location = useLocation();
  let searchParams = React.useMemo(() => getSearchParamsForLocation(location.search, defaultSearchParamsRef.current), [location.search]);
  let navigate = useNavigate();
  let setSearchParams = React.useCallback((nextInit, navigateOptions) => {
    const newSearchParams = createSearchParams(typeof nextInit === "function" ? nextInit(searchParams) : nextInit);
    navigate("?" + newSearchParams, navigateOptions);
  }, [navigate, searchParams]);
  return [searchParams, setSearchParams];
}
/**
 * Returns a function that may be used to programmatically submit a form (or
 * some arbitrary data) to the server.
 */

function useSubmit() {
  return useSubmitImpl();
}

function useSubmitImpl(fetcherKey, routeId) {
  let {
    router
  } = dist_useDataRouterContext(dist_DataRouterHook.UseSubmitImpl);
  let defaultAction = useFormAction();
  return React.useCallback(function (target, options) {
    if (options === void 0) {
      options = {};
    }

    if (typeof document === "undefined") {
      throw new Error("You are calling submit during the server render. " + "Try calling submit within a `useEffect` or callback instead.");
    }

    let {
      method,
      encType,
      formData,
      url
    } = getFormSubmissionInfo(target, defaultAction, options);
    let href = url.pathname + url.search;
    let opts = {
      replace: options.replace,
      formData,
      formMethod: method,
      formEncType: encType
    };

    if (fetcherKey) {
      !(routeId != null) ?  false ? 0 : invariant(false) : void 0;
      router.fetch(fetcherKey, routeId, href, opts);
    } else {
      router.navigate(href, opts);
    }
  }, [defaultAction, router, fetcherKey, routeId]);
}

function useFormAction(action, _temp2) {
  let {
    relative
  } = _temp2 === void 0 ? {} : _temp2;
  let {
    basename
  } = React.useContext(UNSAFE_NavigationContext);
  let routeContext = React.useContext(UNSAFE_RouteContext);
  !routeContext ?  false ? 0 : invariant(false) : void 0;
  let [match] = routeContext.matches.slice(-1);
  let resolvedAction = action != null ? action : "."; // Shallow clone path so we can modify it below, otherwise we modify the
  // object referenced by useMemo inside useResolvedPath

  let path = react_router_dom_dist_extends({}, useResolvedPath(resolvedAction, {
    relative
  })); // Previously we set the default action to ".". The problem with this is that
  // `useResolvedPath(".")` excludes search params and the hash of the resolved
  // URL. This is the intended behavior of when "." is specifically provided as
  // the form action, but inconsistent w/ browsers when the action is omitted.
  // https://github.com/remix-run/remix/issues/927


  let location = useLocation();

  if (action == null) {
    // Safe to write to these directly here since if action was undefined, we
    // would have called useResolvedPath(".") which will never include a search
    // or hash
    path.search = location.search;
    path.hash = location.hash; // When grabbing search params from the URL, remove the automatically
    // inserted ?index param so we match the useResolvedPath search behavior
    // which would not include ?index

    if (match.route.index) {
      let params = new URLSearchParams(path.search);
      params.delete("index");
      path.search = params.toString() ? "?" + params.toString() : "";
    }
  }

  if ((!action || action === ".") && match.route.index) {
    path.search = path.search ? path.search.replace(/^\?/, "?index&") : "?index";
  } // If we're operating within a basename, prepend it to the pathname prior
  // to creating the form action.  If this is a root navigation, then just use
  // the raw basename which allows the basename to have full control over the
  // presence of a trailing slash on root actions


  if (basename !== "/") {
    path.pathname = path.pathname === "/" ? basename : joinPaths([basename, path.pathname]);
  }

  return createPath(path);
}

function createFetcherForm(fetcherKey, routeId) {
  let FetcherForm = /*#__PURE__*/React.forwardRef((props, ref) => {
    return /*#__PURE__*/React.createElement(FormImpl, react_router_dom_dist_extends({}, props, {
      ref: ref,
      fetcherKey: fetcherKey,
      routeId: routeId
    }));
  });

  if (false) {}

  return FetcherForm;
}

let fetcherId = 0;
/**
 * Interacts with route loaders and actions without causing a navigation. Great
 * for any interaction that stays on the same page.
 */

function useFetcher() {
  var _route$matches;

  let {
    router
  } = dist_useDataRouterContext(dist_DataRouterHook.UseFetcher);
  let route = React.useContext(UNSAFE_RouteContext);
  !route ?  false ? 0 : invariant(false) : void 0;
  let routeId = (_route$matches = route.matches[route.matches.length - 1]) == null ? void 0 : _route$matches.route.id;
  !(routeId != null) ?  false ? 0 : invariant(false) : void 0;
  let [fetcherKey] = React.useState(() => String(++fetcherId));
  let [Form] = React.useState(() => {
    !routeId ?  false ? 0 : invariant(false) : void 0;
    return createFetcherForm(fetcherKey, routeId);
  });
  let [load] = React.useState(() => href => {
    !router ?  false ? 0 : invariant(false) : void 0;
    !routeId ?  false ? 0 : invariant(false) : void 0;
    router.fetch(fetcherKey, routeId, href);
  });
  let submit = useSubmitImpl(fetcherKey, routeId);
  let fetcher = router.getFetcher(fetcherKey);
  let fetcherWithComponents = React.useMemo(() => react_router_dom_dist_extends({
    Form,
    submit,
    load
  }, fetcher), [fetcher, Form, submit, load]);
  React.useEffect(() => {
    // Is this busted when the React team gets real weird and calls effects
    // twice on mount?  We really just need to garbage collect here when this
    // fetcher is no longer around.
    return () => {
      if (!router) {
        console.warn("No fetcher available to clean up from useFetcher()");
        return;
      }

      router.deleteFetcher(fetcherKey);
    };
  }, [router, fetcherKey]);
  return fetcherWithComponents;
}
/**
 * Provides all fetchers currently on the page. Useful for layouts and parent
 * routes that need to provide pending/optimistic UI regarding the fetch.
 */

function useFetchers() {
  let state = dist_useDataRouterState(dist_DataRouterStateHook.UseFetchers);
  return [...state.fetchers.values()];
}
const SCROLL_RESTORATION_STORAGE_KEY = "react-router-scroll-positions";
let savedScrollPositions = {};
/**
 * When rendered inside a RouterProvider, will restore scroll positions on navigations
 */

function useScrollRestoration(_temp3) {
  let {
    getKey,
    storageKey
  } = _temp3 === void 0 ? {} : _temp3;
  let {
    router
  } = dist_useDataRouterContext(dist_DataRouterHook.UseScrollRestoration);
  let {
    restoreScrollPosition,
    preventScrollReset
  } = dist_useDataRouterState(dist_DataRouterStateHook.UseScrollRestoration);
  let location = useLocation();
  let matches = useMatches();
  let navigation = useNavigation(); // Trigger manual scroll restoration while we're active

  React.useEffect(() => {
    window.history.scrollRestoration = "manual";
    return () => {
      window.history.scrollRestoration = "auto";
    };
  }, []); // Save positions on unload

  useBeforeUnload(React.useCallback(() => {
    if (navigation.state === "idle") {
      let key = (getKey ? getKey(location, matches) : null) || location.key;
      savedScrollPositions[key] = window.scrollY;
    }

    sessionStorage.setItem(storageKey || SCROLL_RESTORATION_STORAGE_KEY, JSON.stringify(savedScrollPositions));
    window.history.scrollRestoration = "auto";
  }, [storageKey, getKey, navigation.state, location, matches])); // Read in any saved scroll locations

  React.useLayoutEffect(() => {
    try {
      let sessionPositions = sessionStorage.getItem(storageKey || SCROLL_RESTORATION_STORAGE_KEY);

      if (sessionPositions) {
        savedScrollPositions = JSON.parse(sessionPositions);
      }
    } catch (e) {// no-op, use default empty object
    }
  }, [storageKey]); // Enable scroll restoration in the router

  React.useLayoutEffect(() => {
    let disableScrollRestoration = router == null ? void 0 : router.enableScrollRestoration(savedScrollPositions, () => window.scrollY, getKey);
    return () => disableScrollRestoration && disableScrollRestoration();
  }, [router, getKey]); // Restore scrolling when state.restoreScrollPosition changes

  React.useLayoutEffect(() => {
    // Explicit false means don't do anything (used for submissions)
    if (restoreScrollPosition === false) {
      return;
    } // been here before, scroll to it


    if (typeof restoreScrollPosition === "number") {
      window.scrollTo(0, restoreScrollPosition);
      return;
    } // try to scroll to the hash


    if (location.hash) {
      let el = document.getElementById(location.hash.slice(1));

      if (el) {
        el.scrollIntoView();
        return;
      }
    } // Opt out of scroll reset if this link requested it


    if (preventScrollReset === true) {
      return;
    } // otherwise go to the top on new locations


    window.scrollTo(0, 0);
  }, [location, restoreScrollPosition, preventScrollReset]);
}

function useBeforeUnload(callback) {
  React.useEffect(() => {
    window.addEventListener("beforeunload", callback);
    return () => {
      window.removeEventListener("beforeunload", callback);
    };
  }, [callback]);
} //#endregion
////////////////////////////////////////////////////////////////////////////////
//#region Utils
////////////////////////////////////////////////////////////////////////////////


function dist_warning(cond, message) {
  if (!cond) {
    // eslint-disable-next-line no-console
    if (typeof console !== "undefined") console.warn(message);

    try {
      // Welcome to debugging React Router!
      //
      // This error is thrown as a convenience so you can more easily
      // find the source for a warning that appears in the console by
      // enabling "pause on exceptions" in your JavaScript debugger.
      throw new Error(message); // eslint-disable-next-line no-empty
    } catch (e) {}
  }
} //#endregion


//# sourceMappingURL=index.js.map

;// CONCATENATED MODULE: ./src/relay/components/Layout.tsx




var Layout = function Layout(_ref) {var pages = _ref.pages;
  var outlet = /*#__PURE__*/
  react.createElement(react.Fragment, null, /*#__PURE__*/
  react.createElement("div", { id: "notificationsContainer" }), /*#__PURE__*/
  react.createElement("div", { id: "relayContainer" }, /*#__PURE__*/
  react.createElement(Outlet, null)));




  if (pages.length <= 1) {
    return outlet;
  }

  return /*#__PURE__*/(
    react.createElement(react.Fragment, null,
    " ", /*#__PURE__*/
    react.createElement("nav", null, /*#__PURE__*/
    react.createElement("div", { className: "topBar" },
    " ",
    pages.map(function (p, index) {return /*#__PURE__*/(
        react.createElement("div", { key: index, className: "tabEntry" }, /*#__PURE__*/
        react.createElement(NavLink, { to: "/" + p.file }, p.page), " "));}))),



    " ",
    outlet));


};

/* harmony default export */ const components_Layout = (Layout);
;// CONCATENATED MODULE: ./src/relay/api/ApiRequest.tsx
function _typeof(obj) {"@babel/helpers - typeof";return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) {return typeof obj;} : function (obj) {return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;}, _typeof(obj);}function _regeneratorRuntime() {"use strict";
/*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */_regeneratorRuntime = function _regeneratorRuntime() {return exports;};var exports = {},Op = Object.prototype,hasOwn = Op.hasOwnProperty,defineProperty = Object.defineProperty || function (obj, key, desc) {obj[key] = desc.value;},$Symbol = "function" == typeof Symbol ? Symbol : {},iteratorSymbol = $Symbol.iterator || "@@iterator",asyncIteratorSymbol = $Symbol.asyncIterator || "@@asyncIterator",toStringTagSymbol = $Symbol.toStringTag || "@@toStringTag";function define(obj, key, value) {return Object.defineProperty(obj, key, { value: value, enumerable: !0, configurable: !0, writable: !0 }), obj[key];}try {define({}, "");} catch (err) {define = function define(obj, key, value) {return obj[key] = value;};}function wrap(innerFn, outerFn, self, tryLocsList) {var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator,generator = Object.create(protoGenerator.prototype),context = new Context(tryLocsList || []);return defineProperty(generator, "_invoke", { value: makeInvokeMethod(innerFn, self, context) }), generator;}function tryCatch(fn, obj, arg) {try {return { type: "normal", arg: fn.call(obj, arg) };} catch (err) {return { type: "throw", arg: err };}}exports.wrap = wrap;var ContinueSentinel = {};function Generator() {}function GeneratorFunction() {}function GeneratorFunctionPrototype() {}var IteratorPrototype = {};define(IteratorPrototype, iteratorSymbol, function () {return this;});var getProto = Object.getPrototypeOf,NativeIteratorPrototype = getProto && getProto(getProto(values([])));NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype);var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype);function defineIteratorMethods(prototype) {["next", "throw", "return"].forEach(function (method) {define(prototype, method, function (arg) {return this._invoke(method, arg);});});}function AsyncIterator(generator, PromiseImpl) {function invoke(method, arg, resolve, reject) {var record = tryCatch(generator[method], generator, arg);if ("throw" !== record.type) {var result = record.arg,value = result.value;return value && "object" == _typeof(value) && hasOwn.call(value, "__await") ? PromiseImpl.resolve(value.__await).then(function (value) {invoke("next", value, resolve, reject);}, function (err) {invoke("throw", err, resolve, reject);}) : PromiseImpl.resolve(value).then(function (unwrapped) {result.value = unwrapped, resolve(result);}, function (error) {return invoke("throw", error, resolve, reject);});}reject(record.arg);}var previousPromise;defineProperty(this, "_invoke", { value: function value(method, arg) {function callInvokeWithMethodAndArg() {return new PromiseImpl(function (resolve, reject) {invoke(method, arg, resolve, reject);});}return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg();} });}function makeInvokeMethod(innerFn, self, context) {var state = "suspendedStart";return function (method, arg) {if ("executing" === state) throw new Error("Generator is already running");if ("completed" === state) {if ("throw" === method) throw arg;return doneResult();}for (context.method = method, context.arg = arg;;) {var delegate = context.delegate;if (delegate) {var delegateResult = maybeInvokeDelegate(delegate, context);if (delegateResult) {if (delegateResult === ContinueSentinel) continue;return delegateResult;}}if ("next" === context.method) context.sent = context._sent = context.arg;else if ("throw" === context.method) {if ("suspendedStart" === state) throw state = "completed", context.arg;context.dispatchException(context.arg);} else "return" === context.method && context.abrupt("return", context.arg);state = "executing";var record = tryCatch(innerFn, self, context);if ("normal" === record.type) {if (state = context.done ? "completed" : "suspendedYield", record.arg === ContinueSentinel) continue;return { value: record.arg, done: context.done };}"throw" === record.type && (state = "completed", context.method = "throw", context.arg = record.arg);}};}function maybeInvokeDelegate(delegate, context) {var method = delegate.iterator[context.method];if (undefined === method) {if (context.delegate = null, "throw" === context.method) {if (delegate.iterator["return"] && (context.method = "return", context.arg = undefined, maybeInvokeDelegate(delegate, context), "throw" === context.method)) return ContinueSentinel;context.method = "throw", context.arg = new TypeError("The iterator does not provide a 'throw' method");}return ContinueSentinel;}var record = tryCatch(method, delegate.iterator, context.arg);if ("throw" === record.type) return context.method = "throw", context.arg = record.arg, context.delegate = null, ContinueSentinel;var info = record.arg;return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, "return" !== context.method && (context.method = "next", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = "throw", context.arg = new TypeError("iterator result is not an object"), context.delegate = null, ContinueSentinel);}function pushTryEntry(locs) {var entry = { tryLoc: locs[0] };1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry);}function resetTryEntry(entry) {var record = entry.completion || {};record.type = "normal", delete record.arg, entry.completion = record;}function Context(tryLocsList) {this.tryEntries = [{ tryLoc: "root" }], tryLocsList.forEach(pushTryEntry, this), this.reset(!0);}function values(iterable) {if (iterable) {var iteratorMethod = iterable[iteratorSymbol];if (iteratorMethod) return iteratorMethod.call(iterable);if ("function" == typeof iterable.next) return iterable;if (!isNaN(iterable.length)) {var i = -1,next = function next() {for (; ++i < iterable.length;) {if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next;}return next.value = undefined, next.done = !0, next;};return next.next = next;}}return { next: doneResult };}function doneResult() {return { value: undefined, done: !0 };}return GeneratorFunction.prototype = GeneratorFunctionPrototype, defineProperty(Gp, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), defineProperty(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, "GeneratorFunction"), exports.isGeneratorFunction = function (genFun) {var ctor = "function" == typeof genFun && genFun.constructor;return !!ctor && (ctor === GeneratorFunction || "GeneratorFunction" === (ctor.displayName || ctor.name));}, exports.mark = function (genFun) {return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, "GeneratorFunction")), genFun.prototype = Object.create(Gp), genFun;}, exports.awrap = function (arg) {return { __await: arg };}, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () {return this;}), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) {void 0 === PromiseImpl && (PromiseImpl = Promise);var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl);return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) {return result.done ? result.value : iter.next();});}, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, "Generator"), define(Gp, iteratorSymbol, function () {return this;}), define(Gp, "toString", function () {return "[object Generator]";}), exports.keys = function (val) {var object = Object(val),keys = [];for (var key in object) {keys.push(key);}return keys.reverse(), function next() {for (; keys.length;) {var key = keys.pop();if (key in object) return next.value = key, next.done = !1, next;}return next.done = !0, next;};}, exports.values = values, Context.prototype = { constructor: Context, reset: function reset(skipTempReset) {if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = "next", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) {"t" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined);}}, stop: function stop() {this.done = !0;var rootRecord = this.tryEntries[0].completion;if ("throw" === rootRecord.type) throw rootRecord.arg;return this.rval;}, dispatchException: function dispatchException(exception) {if (this.done) throw exception;var context = this;function handle(loc, caught) {return record.type = "throw", record.arg = exception, context.next = loc, caught && (context.method = "next", context.arg = undefined), !!caught;}for (var i = this.tryEntries.length - 1; i >= 0; --i) {var entry = this.tryEntries[i],record = entry.completion;if ("root" === entry.tryLoc) return handle("end");if (entry.tryLoc <= this.prev) {var hasCatch = hasOwn.call(entry, "catchLoc"),hasFinally = hasOwn.call(entry, "finallyLoc");if (hasCatch && hasFinally) {if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0);if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc);} else if (hasCatch) {if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0);} else {if (!hasFinally) throw new Error("try statement without catch or finally");if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc);}}}}, abrupt: function abrupt(type, arg) {for (var i = this.tryEntries.length - 1; i >= 0; --i) {var entry = this.tryEntries[i];if (entry.tryLoc <= this.prev && hasOwn.call(entry, "finallyLoc") && this.prev < entry.finallyLoc) {var finallyEntry = entry;break;}}finallyEntry && ("break" === type || "continue" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null);var record = finallyEntry ? finallyEntry.completion : {};return record.type = type, record.arg = arg, finallyEntry ? (this.method = "next", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record);}, complete: function complete(record, afterLoc) {if ("throw" === record.type) throw record.arg;return "break" === record.type || "continue" === record.type ? this.next = record.arg : "return" === record.type ? (this.rval = this.arg = record.arg, this.method = "return", this.next = "end") : "normal" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel;}, finish: function finish(finallyLoc) {for (var i = this.tryEntries.length - 1; i >= 0; --i) {var entry = this.tryEntries[i];if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel;}}, "catch": function _catch(tryLoc) {for (var i = this.tryEntries.length - 1; i >= 0; --i) {var entry = this.tryEntries[i];if (entry.tryLoc === tryLoc) {var record = entry.completion;if ("throw" === record.type) {var thrown = record.arg;resetTryEntry(entry);}return thrown;}}throw new Error("illegal catch attempt");}, delegateYield: function delegateYield(iterable, resultName, nextLoc) {return this.delegate = { iterator: values(iterable), resultName: resultName, nextLoc: nextLoc }, "next" === this.method && (this.arg = undefined), ContinueSentinel;} }, exports;}function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {try {var info = gen[key](arg);var value = info.value;} catch (error) {reject(error);return;}if (info.done) {resolve(value);} else {Promise.resolve(value).then(_next, _throw);}}function _asyncToGenerator(fn) {return function () {var self = this,args = arguments;return new Promise(function (resolve, reject) {var gen = fn.apply(self, args);function _next(value) {asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);}function _throw(err) {asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);}_next(undefined);});};}
function addNotification(notification) {
  var ele = document.createElement("div");
  ele.className = "notification";
  ele.addEventListener("animationend", function () {return ele.remove();});
  ele.innerText = notification;

  var container = document.getElementById("notificationsContainer");

  if (!container) {
    return;
  }

  container.appendChild(ele);
}

function saveSettings(
properties)
{
  return setProperties(
  properties.
  filter(function (p) {
    if (p.previousValue === p.value) {
      return false;
    }

    p.previousValue = p.value;
    return true;
  }).
  map(function (prop) {return [prop.preference, prop.value.trim()];}));

}

function setProperties(
properties)
{
  return runRelay("setProperties", JSON.stringify(properties)).then(function (val) {return (
      JSON.parse(val));});

}function

runRelay(_x, _x2) {return _runRelay.apply(this, arguments);}function _runRelay() {_runRelay = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(formName, param) {return _regeneratorRuntime().wrap(function _callee$(_context) {while (1) {switch (_context.prev = _context.next) {case 0:return _context.abrupt("return",
            new Promise(function (resolve) {
              var xhr = new XMLHttpRequest();
              xhr.responseType = "text";
              xhr.open("POST", document.location.href, true);
              xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
              xhr.send(formName + "=" + encodeURIComponent(param));
              xhr.onreadystatechange = function () {
                if (xhr.readyState != 4 || xhr.status != 200) {
                  return;
                }

                resolve(xhr.responseText);
              };
            }));case 1:case "end":return _context.stop();}}}, _callee);}));return _runRelay.apply(this, arguments);}
;// CONCATENATED MODULE: ./src/relay/api/SettingValidator.tsx
function _slicedToArray(arr, i) {return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();}function _nonIterableRest() {throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");}function _iterableToArrayLimit(arr, i) {var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];if (_i == null) return;var _arr = [];var _n = true;var _d = false;var _s, _e;try {for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {_arr.push(_s.value);if (i && _arr.length === i) break;}} catch (err) {_d = true;_e = err;} finally {try {if (!_n && _i["return"] != null) _i["return"]();} finally {if (_d) throw _e;}}return _arr;}function _arrayWithHoles(arr) {if (Array.isArray(arr)) return arr;}function _createForOfIteratorHelper(o, allowArrayLike) {var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"];if (!it) {if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") {if (it) o = it;var i = 0;var F = function F() {};return { s: F, n: function n() {if (i >= o.length) return { done: true };return { done: false, value: o[i++] };}, e: function e(_e2) {throw _e2;}, f: F };}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");}var normalCompletion = true,didErr = false,err;return { s: function s() {it = it.call(o);}, n: function n() {var step = it.next();normalCompletion = step.done;return step;}, e: function e(_e3) {didErr = true;err = _e3;}, f: function f() {try {if (!normalCompletion && it["return"] != null) it["return"]();} finally {if (didErr) throw err;}} };}function _unsupportedIterableToArray(o, minLen) {if (!o) return;if (typeof o === "string") return _arrayLikeToArray(o, minLen);var n = Object.prototype.toString.call(o).slice(8, -1);if (n === "Object" && o.constructor) n = o.constructor.name;if (n === "Map" || n === "Set") return Array.from(o);if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);}function _arrayLikeToArray(arr, len) {if (len == null || len > arr.length) len = arr.length;for (var i = 0, arr2 = new Array(len); i < len; i++) {arr2[i] = arr[i];}return arr2;}function _classCallCheck(instance, Constructor) {if (!(instance instanceof Constructor)) {throw new TypeError("Cannot call a class as a function");}}function _defineProperties(target, props) {for (var i = 0; i < props.length; i++) {var descriptor = props[i];descriptor.enumerable = descriptor.enumerable || false;descriptor.configurable = true;if ("value" in descriptor) descriptor.writable = true;Object.defineProperty(target, descriptor.key, descriptor);}}function _createClass(Constructor, protoProps, staticProps) {if (protoProps) _defineProperties(Constructor.prototype, protoProps);if (staticProps) _defineProperties(Constructor, staticProps);Object.defineProperty(Constructor, "prototype", { writable: false });return Constructor;}function _defineProperty(obj, key, value) {if (key in obj) {Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true });} else {obj[key] = value;}return obj;}var


SettingValidator = /*#__PURE__*/function () {function SettingValidator() {_classCallCheck(this, SettingValidator);_defineProperty(this, "settings",
    []);_defineProperty(this, "object",
    {});}_createClass(SettingValidator, [{ key: "addSetting", value:

    function addSetting(setting, setState) {
      this.settings.push([setting, setState]);
    } }, { key: "updateSetting", value:

    function updateSetting(setting) {
      this.object[setting.preference] = setting.value;
      this.doValidates();
    } }, { key: "updateObject", value:

    function updateObject() {var _iterator = _createForOfIteratorHelper(
        this.settings),_step;try {for (_iterator.s(); !(_step = _iterator.n()).done;) {var _step$value = _slicedToArray(_step.value, 1),setting = _step$value[0];
          this.object[setting.preference] = setting.value;
        }} catch (err) {_iterator.e(err);} finally {_iterator.f();}
    } }, { key: "doValidates", value:

    function doValidates() {var _iterator2 = _createForOfIteratorHelper(
        this.settings),_step2;try {for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {var _step2$value = _slicedToArray(_step2.value, 2),setting = _step2$value[0],setValid = _step2$value[1];
          setValid(this.isValid(setting));
        }} catch (err) {_iterator2.e(err);} finally {_iterator2.f();}
    } }, { key: "isValid", value:

    function isValid(setting) {
      return (
        setting.validate == null || setting.validate(setting.value, this.object));

    } }]);return SettingValidator;}();


/* harmony default export */ const api_SettingValidator = (SettingValidator);
;// CONCATENATED MODULE: ./src/relay/components/Interrupt.tsx
function _toConsumableArray(arr) {return _arrayWithoutHoles(arr) || _iterableToArray(arr) || Interrupt_unsupportedIterableToArray(arr) || _nonIterableSpread();}function _nonIterableSpread() {throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");}function Interrupt_unsupportedIterableToArray(o, minLen) {if (!o) return;if (typeof o === "string") return Interrupt_arrayLikeToArray(o, minLen);var n = Object.prototype.toString.call(o).slice(8, -1);if (n === "Object" && o.constructor) n = o.constructor.name;if (n === "Map" || n === "Set") return Array.from(o);if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return Interrupt_arrayLikeToArray(o, minLen);}function _iterableToArray(iter) {if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);}function _arrayWithoutHoles(arr) {if (Array.isArray(arr)) return Interrupt_arrayLikeToArray(arr);}function Interrupt_arrayLikeToArray(arr, len) {if (len == null || len > arr.length) len = arr.length;for (var i = 0, arr2 = new Array(len); i < len; i++) {arr2[i] = arr[i];}return arr2;}function Interrupt_defineProperty(obj, key, value) {if (key in obj) {Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true });} else {obj[key] = value;}return obj;}



function Interrupt(_ref) {var button = _ref.button;
  var CSSstring = function CSSstring(string) {
    var css_json = "{\"".concat(string.
    replace(/; /g, '", "').
    replace(/: /g, '": "').
    replace(";", ""), "\"}");

    var obj = JSON.parse(css_json);

    var keyValues = Object.keys(obj).map(function (key) {
      var camelCased = key.replace(/-[a-z]/g, function (g) {return g[1].toUpperCase();});
      return Interrupt_defineProperty({}, camelCased, obj[key]);
    });

    return Object.assign.apply(Object, [{}].concat(_toConsumableArray(keyValues)));
  };

  return /*#__PURE__*/(
    react.createElement("input", {
      className: "interrupt",
      style: button.css ? CSSstring(button.css) : null,
      type: "submit",
      value: button.name,
      onClick: function onClick() {
        setProperties(
        button.actions.map(function (_ref3) {var preference = _ref3.preference,value = _ref3.value;return [preference, value];})).
        then(function () {return addNotification(button.notification || "Interrupted!");});
      } }));


}

/* harmony default export */ const components_Interrupt = (Interrupt);
;// CONCATENATED MODULE: ./src/relay/types/Types.tsx


var RelayComponentType;(function (RelayComponentType) {RelayComponentType["BOOLEAN"] = "boolean";RelayComponentType["DROPDOWN"] = "dropdown";RelayComponentType["STRING"] = "string";RelayComponentType["HTML"] = "html";RelayComponentType["INTERRUPT"] = "interrupt";})(RelayComponentType || (RelayComponentType = {}));
;// CONCATENATED MODULE: ./src/relay/components/settings/BooleanInput.tsx
function BooleanInput_slicedToArray(arr, i) {return BooleanInput_arrayWithHoles(arr) || BooleanInput_iterableToArrayLimit(arr, i) || BooleanInput_unsupportedIterableToArray(arr, i) || BooleanInput_nonIterableRest();}function BooleanInput_nonIterableRest() {throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");}function BooleanInput_unsupportedIterableToArray(o, minLen) {if (!o) return;if (typeof o === "string") return BooleanInput_arrayLikeToArray(o, minLen);var n = Object.prototype.toString.call(o).slice(8, -1);if (n === "Object" && o.constructor) n = o.constructor.name;if (n === "Map" || n === "Set") return Array.from(o);if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return BooleanInput_arrayLikeToArray(o, minLen);}function BooleanInput_arrayLikeToArray(arr, len) {if (len == null || len > arr.length) len = arr.length;for (var i = 0, arr2 = new Array(len); i < len; i++) {arr2[i] = arr[i];}return arr2;}function BooleanInput_iterableToArrayLimit(arr, i) {var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];if (_i == null) return;var _arr = [];var _n = true;var _d = false;var _s, _e;try {for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {_arr.push(_s.value);if (i && _arr.length === i) break;}} catch (err) {_d = true;_e = err;} finally {try {if (!_n && _i["return"] != null) _i["return"]();} finally {if (_d) throw _e;}}return _arr;}function BooleanInput_arrayWithHoles(arr) {if (Array.isArray(arr)) return arr;}



function BooleanInput(_ref) {var button = _ref.button;
  var _useState = (0,react.useState)(button.value === "true"),_useState2 = BooleanInput_slicedToArray(_useState, 2),value = _useState2[0],setValue = _useState2[1];

  return /*#__PURE__*/(
    react.createElement("label", { className: "checkcontainer" }, /*#__PURE__*/
    react.createElement("input", { type: "hidden", name: button.name, value: button.value }), /*#__PURE__*/
    react.createElement("div", {
      className: "toggle-track",
      onClick: function onClick() {
        setValue(!value);
        button.setValue((!value).toString());
      } }, /*#__PURE__*/

    react.createElement("span", { className: "toggle-indicator" }, /*#__PURE__*/
    react.createElement("span", { className: "checkMark" }, /*#__PURE__*/
    react.createElement("svg", {
      viewBox: "0 0 24 24",
      id: "ghq-svg-check",
      role: "presentation",
      "aria-hidden": "true" }, /*#__PURE__*/

    react.createElement("path", { d: "M9.86 18a1 1 0 01-.73-.32l-4.86-5.17a1.001 1.001 0 011.46-1.37l4.12 4.39 8.41-9.2a1 1 0 111.48 1.34l-9.14 10a1 1 0 01-.73.33h-.01z" })))))));






}

/*
<div
  class="checkmark"
  onClick={() => {
    setValue(!value);
  }}
/>
 */
/* harmony default export */ const settings_BooleanInput = (BooleanInput);
;// CONCATENATED MODULE: ./src/relay/components/settings/DropdownInput.tsx



function DropdownInput(_ref) {var button = _ref.button;
  return /*#__PURE__*/(
    react.createElement("select", {
      className: "dropdowncontainer",
      name: button.name,
      defaultValue: button.value,
      onChange: function onChange(e) {return button.setValue(e.target.value);} },

    button.dropdown.map(function (option) {
      return /*#__PURE__*/(
        react.createElement("option", { key: option.value, value: option.value },
        option.display || option.value));


    })));


}

/* harmony default export */ const settings_DropdownInput = (DropdownInput);
;// CONCATENATED MODULE: ./src/relay/components/settings/StringInput.tsx



function StringInput(_ref) {var button = _ref.button;
  return /*#__PURE__*/(
    react.createElement("input", {
      className: "stringcontainer",
      name: button.name,
      defaultValue: button.value,
      onChange: function onChange(e) {return button.setValue(e.target.value);} }));


}

/* harmony default export */ const settings_StringInput = (StringInput);
;// CONCATENATED MODULE: ./src/relay/components/settings/Setting.tsx
function Setting_slicedToArray(arr, i) {return Setting_arrayWithHoles(arr) || Setting_iterableToArrayLimit(arr, i) || Setting_unsupportedIterableToArray(arr, i) || Setting_nonIterableRest();}function Setting_nonIterableRest() {throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");}function Setting_unsupportedIterableToArray(o, minLen) {if (!o) return;if (typeof o === "string") return Setting_arrayLikeToArray(o, minLen);var n = Object.prototype.toString.call(o).slice(8, -1);if (n === "Object" && o.constructor) n = o.constructor.name;if (n === "Map" || n === "Set") return Array.from(o);if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return Setting_arrayLikeToArray(o, minLen);}function Setting_arrayLikeToArray(arr, len) {if (len == null || len > arr.length) len = arr.length;for (var i = 0, arr2 = new Array(len); i < len; i++) {arr2[i] = arr[i];}return arr2;}function Setting_iterableToArrayLimit(arr, i) {var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];if (_i == null) return;var _arr = [];var _n = true;var _d = false;var _s, _e;try {for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {_arr.push(_s.value);if (i && _arr.length === i) break;}} catch (err) {_d = true;_e = err;} finally {try {if (!_n && _i["return"] != null) _i["return"]();} finally {if (_d) throw _e;}}return _arr;}function Setting_arrayWithHoles(arr) {if (Array.isArray(arr)) return arr;}






function Setting(_ref)





{var button = _ref.button,validator = _ref.validator;
  var _useState = (0,react.useState)(validator.isValid(button)),_useState2 = Setting_slicedToArray(_useState, 2),valid = _useState2[0],setValid = _useState2[1];

  button.setValue = function (val) {
    button.value = val;
    validator.updateSetting(button);
  };

  validator.addSetting(button, setValid);

  return /*#__PURE__*/(
    react.createElement("tr", { className: "userPreference", key: button.preference }, /*#__PURE__*/
    react.createElement("td", { className: "setting" },
    button.name, /*#__PURE__*/
    react.createElement("div", { className: "settingNameHover" }, button.preference)), /*#__PURE__*/

    react.createElement("td", { className: valid ? "settingInput" : "settingInput invalid-setting" },
    button.type === RelayComponentType.BOOLEAN ? /*#__PURE__*/
    react.createElement(settings_BooleanInput, { button: button }) :
    button.type === RelayComponentType.DROPDOWN ? /*#__PURE__*/
    react.createElement(settings_DropdownInput, { button: button }) : /*#__PURE__*/

    react.createElement(settings_StringInput, { button: button }),

    button.invalidReason != null ? /*#__PURE__*/
    react.createElement("div", { className: "invalid-reason", hidden: valid }, /*#__PURE__*/
    react.createElement("small", null, button.invalidReason)) : /*#__PURE__*/


    react.createElement(react.Fragment, null), /*#__PURE__*/


    react.createElement("div", { className: "hoverBox" }, /*#__PURE__*/
    react.createElement("small", { className: "settingDefaultHover" },
    button["default"] != null ?
    "Default: " + (
    button["default"] == "" ? "<Empty>" : button["default"]) :
    "Default not set"))), /*#__PURE__*/



    react.createElement("td", null, button.description)));


}

/* harmony default export */ const settings_Setting = (Setting);
;// CONCATENATED MODULE: ./src/relay/routes/RelayPage.tsx
function RelayPage_createForOfIteratorHelper(o, allowArrayLike) {var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"];if (!it) {if (Array.isArray(o) || (it = RelayPage_unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") {if (it) o = it;var i = 0;var F = function F() {};return { s: F, n: function n() {if (i >= o.length) return { done: true };return { done: false, value: o[i++] };}, e: function e(_e) {throw _e;}, f: F };}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");}var normalCompletion = true,didErr = false,err;return { s: function s() {it = it.call(o);}, n: function n() {var step = it.next();normalCompletion = step.done;return step;}, e: function e(_e2) {didErr = true;err = _e2;}, f: function f() {try {if (!normalCompletion && it["return"] != null) it["return"]();} finally {if (didErr) throw err;}} };}function RelayPage_unsupportedIterableToArray(o, minLen) {if (!o) return;if (typeof o === "string") return RelayPage_arrayLikeToArray(o, minLen);var n = Object.prototype.toString.call(o).slice(8, -1);if (n === "Object" && o.constructor) n = o.constructor.name;if (n === "Map" || n === "Set") return Array.from(o);if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return RelayPage_arrayLikeToArray(o, minLen);}function RelayPage_arrayLikeToArray(arr, len) {if (len == null || len > arr.length) len = arr.length;for (var i = 0, arr2 = new Array(len); i < len; i++) {arr2[i] = arr[i];}return arr2;}






function RelayPage(_ref) {var page = _ref.page;
  var groups = [];
  var currentGroup = null;var _iterator = RelayPage_createForOfIteratorHelper(

    page.components),_step;try {for (_iterator.s(); !(_step = _iterator.n()).done;) {var component = _step.value;
      if (
      component.type == RelayComponentType.HTML ||
      component.type == RelayComponentType.INTERRUPT)
      {
        groups.push(component);
        currentGroup = null;
        continue;
      }

      if (currentGroup == null) {
        currentGroup = [];
        groups.push(currentGroup);
      }

      currentGroup.push(component);
    }} catch (err) {_iterator.e(err);} finally {_iterator.f();}

  var elements = [];
  var validator = new api_SettingValidator();

  groups.forEach(function (components) {
    if (components.type == RelayComponentType.HTML) {
      var html = components;

      if (html.data == null) {
        return;
      }

      elements.push( /*#__PURE__*/
      react.createElement("div", {
        dangerouslySetInnerHTML: {
          __html: components.data
        } }));


      return;
    }

    if (components.type == RelayComponentType.INTERRUPT) {
      elements.push( /*#__PURE__*/
      react.createElement(components_Interrupt, { button: components }));

      return;
    }

    var buttons = components;

    elements.push( /*#__PURE__*/
    react.createElement("table", null, /*#__PURE__*/
    react.createElement("tbody", null,
    buttons.map(function (setting, index) {return /*#__PURE__*/(
        react.createElement(settings_Setting, { key: index, button: setting, validator: validator }));}))));




  });

  validator.updateObject();

  // If we have no settings in which we'd save stuff, don't bother rendering save button
  if (
  page.components.find(function (c) {return c.preference != null;}) ==
  null)
  {
    return /*#__PURE__*/react.createElement(react.Fragment, null, elements);
  }

  return /*#__PURE__*/(
    react.createElement(react.Fragment, null,
    " ",
    elements, " ", /*#__PURE__*/react.createElement("br", null), /*#__PURE__*/
    react.createElement("input", {
      className: "save",
      onClick: function onClick() {return (
          saveSettings(
          page.components.filter(
          function (b) {return b.preference != null;})).

          then(function (notifs) {var _iterator2 = RelayPage_createForOfIteratorHelper(
              notifs),_step2;try {for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {var notif = _step2.value;
                addNotification(notif);
              }} catch (err) {_iterator2.e(err);} finally {_iterator2.f();}
          }));},

      type: "submit",
      value: "Save Changes" })));



}

/* harmony default export */ const routes_RelayPage = (RelayPage);
;// CONCATENATED MODULE: ./src/relay/App.tsx






function App(_ref) {var pages = _ref.pages;
  return /*#__PURE__*/(
    react.createElement(MemoryRouter, null,
    " ", /*#__PURE__*/
    react.createElement(Routes, null,
    " ", /*#__PURE__*/
    react.createElement(Route, { element: /*#__PURE__*/react.createElement(components_Layout, { pages: pages }) },
    " ", /*#__PURE__*/
    react.createElement(Route, {
      path: "/",
      element: /*#__PURE__*/react.createElement(Navigate, { to: "/" + pages[0].file, replace: true }) }),
    " ",
    pages.map(function (p, index) {
      return /*#__PURE__*/(
        react.createElement(Route, {
          key: index,
          path: "/" + p.file,
          element: /*#__PURE__*/react.createElement(routes_RelayPage, { page: p }) }));


    }), " "),
    " "),
    " "));


}

/* harmony default export */ const relay_App = (App);

/***/ }),

/***/ 448:
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {

/**
 * @license React
 * react-dom.production.min.js
 *
 * Copyright (c) Facebook, Inc. and its affiliates.
 *
 * This source code is licensed under the MIT license found in the
 * LICENSE file in the root directory of this source tree.
 */
/*
 Modernizr 3.0.0pre (Custom Build) | MIT
*/
var aa=__webpack_require__(294),ca=__webpack_require__(840);function p(a){for(var b="https://reactjs.org/docs/error-decoder.html?invariant="+a,c=1;c<arguments.length;c++)b+="&args[]="+encodeURIComponent(arguments[c]);return"Minified React error #"+a+"; visit "+b+" for the full message or use the non-minified dev environment for full errors and additional helpful warnings."}var da=new Set,ea={};function fa(a,b){ha(a,b);ha(a+"Capture",b)}
function ha(a,b){ea[a]=b;for(a=0;a<b.length;a++)da.add(b[a])}
var ia=!("undefined"===typeof window||"undefined"===typeof window.document||"undefined"===typeof window.document.createElement),ja=Object.prototype.hasOwnProperty,ka=/^[:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD][:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD\-.0-9\u00B7\u0300-\u036F\u203F-\u2040]*$/,la=
{},ma={};function oa(a){if(ja.call(ma,a))return!0;if(ja.call(la,a))return!1;if(ka.test(a))return ma[a]=!0;la[a]=!0;return!1}function pa(a,b,c,d){if(null!==c&&0===c.type)return!1;switch(typeof b){case "function":case "symbol":return!0;case "boolean":if(d)return!1;if(null!==c)return!c.acceptsBooleans;a=a.toLowerCase().slice(0,5);return"data-"!==a&&"aria-"!==a;default:return!1}}
function qa(a,b,c,d){if(null===b||"undefined"===typeof b||pa(a,b,c,d))return!0;if(d)return!1;if(null!==c)switch(c.type){case 3:return!b;case 4:return!1===b;case 5:return isNaN(b);case 6:return isNaN(b)||1>b}return!1}function v(a,b,c,d,e,f,g){this.acceptsBooleans=2===b||3===b||4===b;this.attributeName=d;this.attributeNamespace=e;this.mustUseProperty=c;this.propertyName=a;this.type=b;this.sanitizeURL=f;this.removeEmptyString=g}var z={};
"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style".split(" ").forEach(function(a){z[a]=new v(a,0,!1,a,null,!1,!1)});[["acceptCharset","accept-charset"],["className","class"],["htmlFor","for"],["httpEquiv","http-equiv"]].forEach(function(a){var b=a[0];z[b]=new v(b,1,!1,a[1],null,!1,!1)});["contentEditable","draggable","spellCheck","value"].forEach(function(a){z[a]=new v(a,2,!1,a.toLowerCase(),null,!1,!1)});
["autoReverse","externalResourcesRequired","focusable","preserveAlpha"].forEach(function(a){z[a]=new v(a,2,!1,a,null,!1,!1)});"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope".split(" ").forEach(function(a){z[a]=new v(a,3,!1,a.toLowerCase(),null,!1,!1)});
["checked","multiple","muted","selected"].forEach(function(a){z[a]=new v(a,3,!0,a,null,!1,!1)});["capture","download"].forEach(function(a){z[a]=new v(a,4,!1,a,null,!1,!1)});["cols","rows","size","span"].forEach(function(a){z[a]=new v(a,6,!1,a,null,!1,!1)});["rowSpan","start"].forEach(function(a){z[a]=new v(a,5,!1,a.toLowerCase(),null,!1,!1)});var ra=/[\-:]([a-z])/g;function sa(a){return a[1].toUpperCase()}
"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height".split(" ").forEach(function(a){var b=a.replace(ra,
sa);z[b]=new v(b,1,!1,a,null,!1,!1)});"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type".split(" ").forEach(function(a){var b=a.replace(ra,sa);z[b]=new v(b,1,!1,a,"http://www.w3.org/1999/xlink",!1,!1)});["xml:base","xml:lang","xml:space"].forEach(function(a){var b=a.replace(ra,sa);z[b]=new v(b,1,!1,a,"http://www.w3.org/XML/1998/namespace",!1,!1)});["tabIndex","crossOrigin"].forEach(function(a){z[a]=new v(a,1,!1,a.toLowerCase(),null,!1,!1)});
z.xlinkHref=new v("xlinkHref",1,!1,"xlink:href","http://www.w3.org/1999/xlink",!0,!1);["src","href","action","formAction"].forEach(function(a){z[a]=new v(a,1,!1,a.toLowerCase(),null,!0,!0)});
function ta(a,b,c,d){var e=z.hasOwnProperty(b)?z[b]:null;if(null!==e?0!==e.type:d||!(2<b.length)||"o"!==b[0]&&"O"!==b[0]||"n"!==b[1]&&"N"!==b[1])qa(b,c,e,d)&&(c=null),d||null===e?oa(b)&&(null===c?a.removeAttribute(b):a.setAttribute(b,""+c)):e.mustUseProperty?a[e.propertyName]=null===c?3===e.type?!1:"":c:(b=e.attributeName,d=e.attributeNamespace,null===c?a.removeAttribute(b):(e=e.type,c=3===e||4===e&&!0===c?"":""+c,d?a.setAttributeNS(d,b,c):a.setAttribute(b,c)))}
var ua=aa.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED,va=Symbol.for("react.element"),wa=Symbol.for("react.portal"),ya=Symbol.for("react.fragment"),za=Symbol.for("react.strict_mode"),Aa=Symbol.for("react.profiler"),Ba=Symbol.for("react.provider"),Ca=Symbol.for("react.context"),Da=Symbol.for("react.forward_ref"),Ea=Symbol.for("react.suspense"),Fa=Symbol.for("react.suspense_list"),Ga=Symbol.for("react.memo"),Ha=Symbol.for("react.lazy");Symbol.for("react.scope");Symbol.for("react.debug_trace_mode");
var Ia=Symbol.for("react.offscreen");Symbol.for("react.legacy_hidden");Symbol.for("react.cache");Symbol.for("react.tracing_marker");var Ja=Symbol.iterator;function Ka(a){if(null===a||"object"!==typeof a)return null;a=Ja&&a[Ja]||a["@@iterator"];return"function"===typeof a?a:null}var A=Object.assign,La;function Ma(a){if(void 0===La)try{throw Error();}catch(c){var b=c.stack.trim().match(/\n( *(at )?)/);La=b&&b[1]||""}return"\n"+La+a}var Na=!1;
function Oa(a,b){if(!a||Na)return"";Na=!0;var c=Error.prepareStackTrace;Error.prepareStackTrace=void 0;try{if(b)if(b=function(){throw Error();},Object.defineProperty(b.prototype,"props",{set:function(){throw Error();}}),"object"===typeof Reflect&&Reflect.construct){try{Reflect.construct(b,[])}catch(l){var d=l}Reflect.construct(a,[],b)}else{try{b.call()}catch(l){d=l}a.call(b.prototype)}else{try{throw Error();}catch(l){d=l}a()}}catch(l){if(l&&d&&"string"===typeof l.stack){for(var e=l.stack.split("\n"),
f=d.stack.split("\n"),g=e.length-1,h=f.length-1;1<=g&&0<=h&&e[g]!==f[h];)h--;for(;1<=g&&0<=h;g--,h--)if(e[g]!==f[h]){if(1!==g||1!==h){do if(g--,h--,0>h||e[g]!==f[h]){var k="\n"+e[g].replace(" at new "," at ");a.displayName&&k.includes("<anonymous>")&&(k=k.replace("<anonymous>",a.displayName));return k}while(1<=g&&0<=h)}break}}}finally{Na=!1,Error.prepareStackTrace=c}return(a=a?a.displayName||a.name:"")?Ma(a):""}
function Pa(a){switch(a.tag){case 5:return Ma(a.type);case 16:return Ma("Lazy");case 13:return Ma("Suspense");case 19:return Ma("SuspenseList");case 0:case 2:case 15:return a=Oa(a.type,!1),a;case 11:return a=Oa(a.type.render,!1),a;case 1:return a=Oa(a.type,!0),a;default:return""}}
function Qa(a){if(null==a)return null;if("function"===typeof a)return a.displayName||a.name||null;if("string"===typeof a)return a;switch(a){case ya:return"Fragment";case wa:return"Portal";case Aa:return"Profiler";case za:return"StrictMode";case Ea:return"Suspense";case Fa:return"SuspenseList"}if("object"===typeof a)switch(a.$$typeof){case Ca:return(a.displayName||"Context")+".Consumer";case Ba:return(a._context.displayName||"Context")+".Provider";case Da:var b=a.render;a=a.displayName;a||(a=b.displayName||
b.name||"",a=""!==a?"ForwardRef("+a+")":"ForwardRef");return a;case Ga:return b=a.displayName||null,null!==b?b:Qa(a.type)||"Memo";case Ha:b=a._payload;a=a._init;try{return Qa(a(b))}catch(c){}}return null}
function Ra(a){var b=a.type;switch(a.tag){case 24:return"Cache";case 9:return(b.displayName||"Context")+".Consumer";case 10:return(b._context.displayName||"Context")+".Provider";case 18:return"DehydratedFragment";case 11:return a=b.render,a=a.displayName||a.name||"",b.displayName||(""!==a?"ForwardRef("+a+")":"ForwardRef");case 7:return"Fragment";case 5:return b;case 4:return"Portal";case 3:return"Root";case 6:return"Text";case 16:return Qa(b);case 8:return b===za?"StrictMode":"Mode";case 22:return"Offscreen";
case 12:return"Profiler";case 21:return"Scope";case 13:return"Suspense";case 19:return"SuspenseList";case 25:return"TracingMarker";case 1:case 0:case 17:case 2:case 14:case 15:if("function"===typeof b)return b.displayName||b.name||null;if("string"===typeof b)return b}return null}function Sa(a){switch(typeof a){case "boolean":case "number":case "string":case "undefined":return a;case "object":return a;default:return""}}
function Ta(a){var b=a.type;return(a=a.nodeName)&&"input"===a.toLowerCase()&&("checkbox"===b||"radio"===b)}
function Ua(a){var b=Ta(a)?"checked":"value",c=Object.getOwnPropertyDescriptor(a.constructor.prototype,b),d=""+a[b];if(!a.hasOwnProperty(b)&&"undefined"!==typeof c&&"function"===typeof c.get&&"function"===typeof c.set){var e=c.get,f=c.set;Object.defineProperty(a,b,{configurable:!0,get:function(){return e.call(this)},set:function(a){d=""+a;f.call(this,a)}});Object.defineProperty(a,b,{enumerable:c.enumerable});return{getValue:function(){return d},setValue:function(a){d=""+a},stopTracking:function(){a._valueTracker=
null;delete a[b]}}}}function Va(a){a._valueTracker||(a._valueTracker=Ua(a))}function Wa(a){if(!a)return!1;var b=a._valueTracker;if(!b)return!0;var c=b.getValue();var d="";a&&(d=Ta(a)?a.checked?"true":"false":a.value);a=d;return a!==c?(b.setValue(a),!0):!1}function Xa(a){a=a||("undefined"!==typeof document?document:void 0);if("undefined"===typeof a)return null;try{return a.activeElement||a.body}catch(b){return a.body}}
function Ya(a,b){var c=b.checked;return A({},b,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:null!=c?c:a._wrapperState.initialChecked})}function Za(a,b){var c=null==b.defaultValue?"":b.defaultValue,d=null!=b.checked?b.checked:b.defaultChecked;c=Sa(null!=b.value?b.value:c);a._wrapperState={initialChecked:d,initialValue:c,controlled:"checkbox"===b.type||"radio"===b.type?null!=b.checked:null!=b.value}}function ab(a,b){b=b.checked;null!=b&&ta(a,"checked",b,!1)}
function bb(a,b){ab(a,b);var c=Sa(b.value),d=b.type;if(null!=c)if("number"===d){if(0===c&&""===a.value||a.value!=c)a.value=""+c}else a.value!==""+c&&(a.value=""+c);else if("submit"===d||"reset"===d){a.removeAttribute("value");return}b.hasOwnProperty("value")?cb(a,b.type,c):b.hasOwnProperty("defaultValue")&&cb(a,b.type,Sa(b.defaultValue));null==b.checked&&null!=b.defaultChecked&&(a.defaultChecked=!!b.defaultChecked)}
function db(a,b,c){if(b.hasOwnProperty("value")||b.hasOwnProperty("defaultValue")){var d=b.type;if(!("submit"!==d&&"reset"!==d||void 0!==b.value&&null!==b.value))return;b=""+a._wrapperState.initialValue;c||b===a.value||(a.value=b);a.defaultValue=b}c=a.name;""!==c&&(a.name="");a.defaultChecked=!!a._wrapperState.initialChecked;""!==c&&(a.name=c)}
function cb(a,b,c){if("number"!==b||Xa(a.ownerDocument)!==a)null==c?a.defaultValue=""+a._wrapperState.initialValue:a.defaultValue!==""+c&&(a.defaultValue=""+c)}var eb=Array.isArray;
function fb(a,b,c,d){a=a.options;if(b){b={};for(var e=0;e<c.length;e++)b["$"+c[e]]=!0;for(c=0;c<a.length;c++)e=b.hasOwnProperty("$"+a[c].value),a[c].selected!==e&&(a[c].selected=e),e&&d&&(a[c].defaultSelected=!0)}else{c=""+Sa(c);b=null;for(e=0;e<a.length;e++){if(a[e].value===c){a[e].selected=!0;d&&(a[e].defaultSelected=!0);return}null!==b||a[e].disabled||(b=a[e])}null!==b&&(b.selected=!0)}}
function gb(a,b){if(null!=b.dangerouslySetInnerHTML)throw Error(p(91));return A({},b,{value:void 0,defaultValue:void 0,children:""+a._wrapperState.initialValue})}function hb(a,b){var c=b.value;if(null==c){c=b.children;b=b.defaultValue;if(null!=c){if(null!=b)throw Error(p(92));if(eb(c)){if(1<c.length)throw Error(p(93));c=c[0]}b=c}null==b&&(b="");c=b}a._wrapperState={initialValue:Sa(c)}}
function ib(a,b){var c=Sa(b.value),d=Sa(b.defaultValue);null!=c&&(c=""+c,c!==a.value&&(a.value=c),null==b.defaultValue&&a.defaultValue!==c&&(a.defaultValue=c));null!=d&&(a.defaultValue=""+d)}function jb(a){var b=a.textContent;b===a._wrapperState.initialValue&&""!==b&&null!==b&&(a.value=b)}function kb(a){switch(a){case "svg":return"http://www.w3.org/2000/svg";case "math":return"http://www.w3.org/1998/Math/MathML";default:return"http://www.w3.org/1999/xhtml"}}
function lb(a,b){return null==a||"http://www.w3.org/1999/xhtml"===a?kb(b):"http://www.w3.org/2000/svg"===a&&"foreignObject"===b?"http://www.w3.org/1999/xhtml":a}
var mb,nb=function(a){return"undefined"!==typeof MSApp&&MSApp.execUnsafeLocalFunction?function(b,c,d,e){MSApp.execUnsafeLocalFunction(function(){return a(b,c,d,e)})}:a}(function(a,b){if("http://www.w3.org/2000/svg"!==a.namespaceURI||"innerHTML"in a)a.innerHTML=b;else{mb=mb||document.createElement("div");mb.innerHTML="<svg>"+b.valueOf().toString()+"</svg>";for(b=mb.firstChild;a.firstChild;)a.removeChild(a.firstChild);for(;b.firstChild;)a.appendChild(b.firstChild)}});
function ob(a,b){if(b){var c=a.firstChild;if(c&&c===a.lastChild&&3===c.nodeType){c.nodeValue=b;return}}a.textContent=b}
var pb={animationIterationCount:!0,aspectRatio:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,
zoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},qb=["Webkit","ms","Moz","O"];Object.keys(pb).forEach(function(a){qb.forEach(function(b){b=b+a.charAt(0).toUpperCase()+a.substring(1);pb[b]=pb[a]})});function rb(a,b,c){return null==b||"boolean"===typeof b||""===b?"":c||"number"!==typeof b||0===b||pb.hasOwnProperty(a)&&pb[a]?(""+b).trim():b+"px"}
function sb(a,b){a=a.style;for(var c in b)if(b.hasOwnProperty(c)){var d=0===c.indexOf("--"),e=rb(c,b[c],d);"float"===c&&(c="cssFloat");d?a.setProperty(c,e):a[c]=e}}var tb=A({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});
function ub(a,b){if(b){if(tb[a]&&(null!=b.children||null!=b.dangerouslySetInnerHTML))throw Error(p(137,a));if(null!=b.dangerouslySetInnerHTML){if(null!=b.children)throw Error(p(60));if("object"!==typeof b.dangerouslySetInnerHTML||!("__html"in b.dangerouslySetInnerHTML))throw Error(p(61));}if(null!=b.style&&"object"!==typeof b.style)throw Error(p(62));}}
function vb(a,b){if(-1===a.indexOf("-"))return"string"===typeof b.is;switch(a){case "annotation-xml":case "color-profile":case "font-face":case "font-face-src":case "font-face-uri":case "font-face-format":case "font-face-name":case "missing-glyph":return!1;default:return!0}}var wb=null;function xb(a){a=a.target||a.srcElement||window;a.correspondingUseElement&&(a=a.correspondingUseElement);return 3===a.nodeType?a.parentNode:a}var yb=null,zb=null,Ab=null;
function Bb(a){if(a=Cb(a)){if("function"!==typeof yb)throw Error(p(280));var b=a.stateNode;b&&(b=Db(b),yb(a.stateNode,a.type,b))}}function Eb(a){zb?Ab?Ab.push(a):Ab=[a]:zb=a}function Fb(){if(zb){var a=zb,b=Ab;Ab=zb=null;Bb(a);if(b)for(a=0;a<b.length;a++)Bb(b[a])}}function Gb(a,b){return a(b)}function Hb(){}var Ib=!1;function Jb(a,b,c){if(Ib)return a(b,c);Ib=!0;try{return Gb(a,b,c)}finally{if(Ib=!1,null!==zb||null!==Ab)Hb(),Fb()}}
function Kb(a,b){var c=a.stateNode;if(null===c)return null;var d=Db(c);if(null===d)return null;c=d[b];a:switch(b){case "onClick":case "onClickCapture":case "onDoubleClick":case "onDoubleClickCapture":case "onMouseDown":case "onMouseDownCapture":case "onMouseMove":case "onMouseMoveCapture":case "onMouseUp":case "onMouseUpCapture":case "onMouseEnter":(d=!d.disabled)||(a=a.type,d=!("button"===a||"input"===a||"select"===a||"textarea"===a));a=!d;break a;default:a=!1}if(a)return null;if(c&&"function"!==
typeof c)throw Error(p(231,b,typeof c));return c}var Lb=!1;if(ia)try{var Mb={};Object.defineProperty(Mb,"passive",{get:function(){Lb=!0}});window.addEventListener("test",Mb,Mb);window.removeEventListener("test",Mb,Mb)}catch(a){Lb=!1}function Nb(a,b,c,d,e,f,g,h,k){var l=Array.prototype.slice.call(arguments,3);try{b.apply(c,l)}catch(m){this.onError(m)}}var Ob=!1,Pb=null,Qb=!1,Rb=null,Sb={onError:function(a){Ob=!0;Pb=a}};function Tb(a,b,c,d,e,f,g,h,k){Ob=!1;Pb=null;Nb.apply(Sb,arguments)}
function Ub(a,b,c,d,e,f,g,h,k){Tb.apply(this,arguments);if(Ob){if(Ob){var l=Pb;Ob=!1;Pb=null}else throw Error(p(198));Qb||(Qb=!0,Rb=l)}}function Vb(a){var b=a,c=a;if(a.alternate)for(;b.return;)b=b.return;else{a=b;do b=a,0!==(b.flags&4098)&&(c=b.return),a=b.return;while(a)}return 3===b.tag?c:null}function Wb(a){if(13===a.tag){var b=a.memoizedState;null===b&&(a=a.alternate,null!==a&&(b=a.memoizedState));if(null!==b)return b.dehydrated}return null}function Xb(a){if(Vb(a)!==a)throw Error(p(188));}
function Yb(a){var b=a.alternate;if(!b){b=Vb(a);if(null===b)throw Error(p(188));return b!==a?null:a}for(var c=a,d=b;;){var e=c.return;if(null===e)break;var f=e.alternate;if(null===f){d=e.return;if(null!==d){c=d;continue}break}if(e.child===f.child){for(f=e.child;f;){if(f===c)return Xb(e),a;if(f===d)return Xb(e),b;f=f.sibling}throw Error(p(188));}if(c.return!==d.return)c=e,d=f;else{for(var g=!1,h=e.child;h;){if(h===c){g=!0;c=e;d=f;break}if(h===d){g=!0;d=e;c=f;break}h=h.sibling}if(!g){for(h=f.child;h;){if(h===
c){g=!0;c=f;d=e;break}if(h===d){g=!0;d=f;c=e;break}h=h.sibling}if(!g)throw Error(p(189));}}if(c.alternate!==d)throw Error(p(190));}if(3!==c.tag)throw Error(p(188));return c.stateNode.current===c?a:b}function Zb(a){a=Yb(a);return null!==a?$b(a):null}function $b(a){if(5===a.tag||6===a.tag)return a;for(a=a.child;null!==a;){var b=$b(a);if(null!==b)return b;a=a.sibling}return null}
var ac=ca.unstable_scheduleCallback,bc=ca.unstable_cancelCallback,cc=ca.unstable_shouldYield,dc=ca.unstable_requestPaint,B=ca.unstable_now,ec=ca.unstable_getCurrentPriorityLevel,fc=ca.unstable_ImmediatePriority,gc=ca.unstable_UserBlockingPriority,hc=ca.unstable_NormalPriority,ic=ca.unstable_LowPriority,jc=ca.unstable_IdlePriority,kc=null,lc=null;function mc(a){if(lc&&"function"===typeof lc.onCommitFiberRoot)try{lc.onCommitFiberRoot(kc,a,void 0,128===(a.current.flags&128))}catch(b){}}
var oc=Math.clz32?Math.clz32:nc,pc=Math.log,qc=Math.LN2;function nc(a){a>>>=0;return 0===a?32:31-(pc(a)/qc|0)|0}var rc=64,sc=4194304;
function tc(a){switch(a&-a){case 1:return 1;case 2:return 2;case 4:return 4;case 8:return 8;case 16:return 16;case 32:return 32;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return a&4194240;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return a&130023424;case 134217728:return 134217728;case 268435456:return 268435456;case 536870912:return 536870912;case 1073741824:return 1073741824;
default:return a}}function uc(a,b){var c=a.pendingLanes;if(0===c)return 0;var d=0,e=a.suspendedLanes,f=a.pingedLanes,g=c&268435455;if(0!==g){var h=g&~e;0!==h?d=tc(h):(f&=g,0!==f&&(d=tc(f)))}else g=c&~e,0!==g?d=tc(g):0!==f&&(d=tc(f));if(0===d)return 0;if(0!==b&&b!==d&&0===(b&e)&&(e=d&-d,f=b&-b,e>=f||16===e&&0!==(f&4194240)))return b;0!==(d&4)&&(d|=c&16);b=a.entangledLanes;if(0!==b)for(a=a.entanglements,b&=d;0<b;)c=31-oc(b),e=1<<c,d|=a[c],b&=~e;return d}
function vc(a,b){switch(a){case 1:case 2:case 4:return b+250;case 8:case 16:case 32:case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return b+5E3;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return-1;case 134217728:case 268435456:case 536870912:case 1073741824:return-1;default:return-1}}
function wc(a,b){for(var c=a.suspendedLanes,d=a.pingedLanes,e=a.expirationTimes,f=a.pendingLanes;0<f;){var g=31-oc(f),h=1<<g,k=e[g];if(-1===k){if(0===(h&c)||0!==(h&d))e[g]=vc(h,b)}else k<=b&&(a.expiredLanes|=h);f&=~h}}function xc(a){a=a.pendingLanes&-1073741825;return 0!==a?a:a&1073741824?1073741824:0}function yc(){var a=rc;rc<<=1;0===(rc&4194240)&&(rc=64);return a}function zc(a){for(var b=[],c=0;31>c;c++)b.push(a);return b}
function Ac(a,b,c){a.pendingLanes|=b;536870912!==b&&(a.suspendedLanes=0,a.pingedLanes=0);a=a.eventTimes;b=31-oc(b);a[b]=c}function Bc(a,b){var c=a.pendingLanes&~b;a.pendingLanes=b;a.suspendedLanes=0;a.pingedLanes=0;a.expiredLanes&=b;a.mutableReadLanes&=b;a.entangledLanes&=b;b=a.entanglements;var d=a.eventTimes;for(a=a.expirationTimes;0<c;){var e=31-oc(c),f=1<<e;b[e]=0;d[e]=-1;a[e]=-1;c&=~f}}
function Cc(a,b){var c=a.entangledLanes|=b;for(a=a.entanglements;c;){var d=31-oc(c),e=1<<d;e&b|a[d]&b&&(a[d]|=b);c&=~e}}var C=0;function Dc(a){a&=-a;return 1<a?4<a?0!==(a&268435455)?16:536870912:4:1}var Ec,Fc,Gc,Hc,Ic,Jc=!1,Kc=[],Lc=null,Mc=null,Nc=null,Oc=new Map,Pc=new Map,Qc=[],Rc="mousedown mouseup touchcancel touchend touchstart auxclick dblclick pointercancel pointerdown pointerup dragend dragstart drop compositionend compositionstart keydown keypress keyup input textInput copy cut paste click change contextmenu reset submit".split(" ");
function Sc(a,b){switch(a){case "focusin":case "focusout":Lc=null;break;case "dragenter":case "dragleave":Mc=null;break;case "mouseover":case "mouseout":Nc=null;break;case "pointerover":case "pointerout":Oc.delete(b.pointerId);break;case "gotpointercapture":case "lostpointercapture":Pc.delete(b.pointerId)}}
function Tc(a,b,c,d,e,f){if(null===a||a.nativeEvent!==f)return a={blockedOn:b,domEventName:c,eventSystemFlags:d,nativeEvent:f,targetContainers:[e]},null!==b&&(b=Cb(b),null!==b&&Fc(b)),a;a.eventSystemFlags|=d;b=a.targetContainers;null!==e&&-1===b.indexOf(e)&&b.push(e);return a}
function Uc(a,b,c,d,e){switch(b){case "focusin":return Lc=Tc(Lc,a,b,c,d,e),!0;case "dragenter":return Mc=Tc(Mc,a,b,c,d,e),!0;case "mouseover":return Nc=Tc(Nc,a,b,c,d,e),!0;case "pointerover":var f=e.pointerId;Oc.set(f,Tc(Oc.get(f)||null,a,b,c,d,e));return!0;case "gotpointercapture":return f=e.pointerId,Pc.set(f,Tc(Pc.get(f)||null,a,b,c,d,e)),!0}return!1}
function Vc(a){var b=Wc(a.target);if(null!==b){var c=Vb(b);if(null!==c)if(b=c.tag,13===b){if(b=Wb(c),null!==b){a.blockedOn=b;Ic(a.priority,function(){Gc(c)});return}}else if(3===b&&c.stateNode.current.memoizedState.isDehydrated){a.blockedOn=3===c.tag?c.stateNode.containerInfo:null;return}}a.blockedOn=null}
function Xc(a){if(null!==a.blockedOn)return!1;for(var b=a.targetContainers;0<b.length;){var c=Yc(a.domEventName,a.eventSystemFlags,b[0],a.nativeEvent);if(null===c){c=a.nativeEvent;var d=new c.constructor(c.type,c);wb=d;c.target.dispatchEvent(d);wb=null}else return b=Cb(c),null!==b&&Fc(b),a.blockedOn=c,!1;b.shift()}return!0}function Zc(a,b,c){Xc(a)&&c.delete(b)}function $c(){Jc=!1;null!==Lc&&Xc(Lc)&&(Lc=null);null!==Mc&&Xc(Mc)&&(Mc=null);null!==Nc&&Xc(Nc)&&(Nc=null);Oc.forEach(Zc);Pc.forEach(Zc)}
function ad(a,b){a.blockedOn===b&&(a.blockedOn=null,Jc||(Jc=!0,ca.unstable_scheduleCallback(ca.unstable_NormalPriority,$c)))}
function bd(a){function b(b){return ad(b,a)}if(0<Kc.length){ad(Kc[0],a);for(var c=1;c<Kc.length;c++){var d=Kc[c];d.blockedOn===a&&(d.blockedOn=null)}}null!==Lc&&ad(Lc,a);null!==Mc&&ad(Mc,a);null!==Nc&&ad(Nc,a);Oc.forEach(b);Pc.forEach(b);for(c=0;c<Qc.length;c++)d=Qc[c],d.blockedOn===a&&(d.blockedOn=null);for(;0<Qc.length&&(c=Qc[0],null===c.blockedOn);)Vc(c),null===c.blockedOn&&Qc.shift()}var cd=ua.ReactCurrentBatchConfig,dd=!0;
function ed(a,b,c,d){var e=C,f=cd.transition;cd.transition=null;try{C=1,fd(a,b,c,d)}finally{C=e,cd.transition=f}}function gd(a,b,c,d){var e=C,f=cd.transition;cd.transition=null;try{C=4,fd(a,b,c,d)}finally{C=e,cd.transition=f}}
function fd(a,b,c,d){if(dd){var e=Yc(a,b,c,d);if(null===e)hd(a,b,d,id,c),Sc(a,d);else if(Uc(e,a,b,c,d))d.stopPropagation();else if(Sc(a,d),b&4&&-1<Rc.indexOf(a)){for(;null!==e;){var f=Cb(e);null!==f&&Ec(f);f=Yc(a,b,c,d);null===f&&hd(a,b,d,id,c);if(f===e)break;e=f}null!==e&&d.stopPropagation()}else hd(a,b,d,null,c)}}var id=null;
function Yc(a,b,c,d){id=null;a=xb(d);a=Wc(a);if(null!==a)if(b=Vb(a),null===b)a=null;else if(c=b.tag,13===c){a=Wb(b);if(null!==a)return a;a=null}else if(3===c){if(b.stateNode.current.memoizedState.isDehydrated)return 3===b.tag?b.stateNode.containerInfo:null;a=null}else b!==a&&(a=null);id=a;return null}
function jd(a){switch(a){case "cancel":case "click":case "close":case "contextmenu":case "copy":case "cut":case "auxclick":case "dblclick":case "dragend":case "dragstart":case "drop":case "focusin":case "focusout":case "input":case "invalid":case "keydown":case "keypress":case "keyup":case "mousedown":case "mouseup":case "paste":case "pause":case "play":case "pointercancel":case "pointerdown":case "pointerup":case "ratechange":case "reset":case "resize":case "seeked":case "submit":case "touchcancel":case "touchend":case "touchstart":case "volumechange":case "change":case "selectionchange":case "textInput":case "compositionstart":case "compositionend":case "compositionupdate":case "beforeblur":case "afterblur":case "beforeinput":case "blur":case "fullscreenchange":case "focus":case "hashchange":case "popstate":case "select":case "selectstart":return 1;case "drag":case "dragenter":case "dragexit":case "dragleave":case "dragover":case "mousemove":case "mouseout":case "mouseover":case "pointermove":case "pointerout":case "pointerover":case "scroll":case "toggle":case "touchmove":case "wheel":case "mouseenter":case "mouseleave":case "pointerenter":case "pointerleave":return 4;
case "message":switch(ec()){case fc:return 1;case gc:return 4;case hc:case ic:return 16;case jc:return 536870912;default:return 16}default:return 16}}var kd=null,ld=null,md=null;function nd(){if(md)return md;var a,b=ld,c=b.length,d,e="value"in kd?kd.value:kd.textContent,f=e.length;for(a=0;a<c&&b[a]===e[a];a++);var g=c-a;for(d=1;d<=g&&b[c-d]===e[f-d];d++);return md=e.slice(a,1<d?1-d:void 0)}
function od(a){var b=a.keyCode;"charCode"in a?(a=a.charCode,0===a&&13===b&&(a=13)):a=b;10===a&&(a=13);return 32<=a||13===a?a:0}function pd(){return!0}function qd(){return!1}
function rd(a){function b(b,d,e,f,g){this._reactName=b;this._targetInst=e;this.type=d;this.nativeEvent=f;this.target=g;this.currentTarget=null;for(var c in a)a.hasOwnProperty(c)&&(b=a[c],this[c]=b?b(f):f[c]);this.isDefaultPrevented=(null!=f.defaultPrevented?f.defaultPrevented:!1===f.returnValue)?pd:qd;this.isPropagationStopped=qd;return this}A(b.prototype,{preventDefault:function(){this.defaultPrevented=!0;var a=this.nativeEvent;a&&(a.preventDefault?a.preventDefault():"unknown"!==typeof a.returnValue&&
(a.returnValue=!1),this.isDefaultPrevented=pd)},stopPropagation:function(){var a=this.nativeEvent;a&&(a.stopPropagation?a.stopPropagation():"unknown"!==typeof a.cancelBubble&&(a.cancelBubble=!0),this.isPropagationStopped=pd)},persist:function(){},isPersistent:pd});return b}
var sd={eventPhase:0,bubbles:0,cancelable:0,timeStamp:function(a){return a.timeStamp||Date.now()},defaultPrevented:0,isTrusted:0},td=rd(sd),ud=A({},sd,{view:0,detail:0}),vd=rd(ud),wd,xd,yd,Ad=A({},ud,{screenX:0,screenY:0,clientX:0,clientY:0,pageX:0,pageY:0,ctrlKey:0,shiftKey:0,altKey:0,metaKey:0,getModifierState:zd,button:0,buttons:0,relatedTarget:function(a){return void 0===a.relatedTarget?a.fromElement===a.srcElement?a.toElement:a.fromElement:a.relatedTarget},movementX:function(a){if("movementX"in
a)return a.movementX;a!==yd&&(yd&&"mousemove"===a.type?(wd=a.screenX-yd.screenX,xd=a.screenY-yd.screenY):xd=wd=0,yd=a);return wd},movementY:function(a){return"movementY"in a?a.movementY:xd}}),Bd=rd(Ad),Cd=A({},Ad,{dataTransfer:0}),Dd=rd(Cd),Ed=A({},ud,{relatedTarget:0}),Fd=rd(Ed),Gd=A({},sd,{animationName:0,elapsedTime:0,pseudoElement:0}),Hd=rd(Gd),Id=A({},sd,{clipboardData:function(a){return"clipboardData"in a?a.clipboardData:window.clipboardData}}),Jd=rd(Id),Kd=A({},sd,{data:0}),Ld=rd(Kd),Md={Esc:"Escape",
Spacebar:" ",Left:"ArrowLeft",Up:"ArrowUp",Right:"ArrowRight",Down:"ArrowDown",Del:"Delete",Win:"OS",Menu:"ContextMenu",Apps:"ContextMenu",Scroll:"ScrollLock",MozPrintableKey:"Unidentified"},Nd={8:"Backspace",9:"Tab",12:"Clear",13:"Enter",16:"Shift",17:"Control",18:"Alt",19:"Pause",20:"CapsLock",27:"Escape",32:" ",33:"PageUp",34:"PageDown",35:"End",36:"Home",37:"ArrowLeft",38:"ArrowUp",39:"ArrowRight",40:"ArrowDown",45:"Insert",46:"Delete",112:"F1",113:"F2",114:"F3",115:"F4",116:"F5",117:"F6",118:"F7",
119:"F8",120:"F9",121:"F10",122:"F11",123:"F12",144:"NumLock",145:"ScrollLock",224:"Meta"},Od={Alt:"altKey",Control:"ctrlKey",Meta:"metaKey",Shift:"shiftKey"};function Pd(a){var b=this.nativeEvent;return b.getModifierState?b.getModifierState(a):(a=Od[a])?!!b[a]:!1}function zd(){return Pd}
var Qd=A({},ud,{key:function(a){if(a.key){var b=Md[a.key]||a.key;if("Unidentified"!==b)return b}return"keypress"===a.type?(a=od(a),13===a?"Enter":String.fromCharCode(a)):"keydown"===a.type||"keyup"===a.type?Nd[a.keyCode]||"Unidentified":""},code:0,location:0,ctrlKey:0,shiftKey:0,altKey:0,metaKey:0,repeat:0,locale:0,getModifierState:zd,charCode:function(a){return"keypress"===a.type?od(a):0},keyCode:function(a){return"keydown"===a.type||"keyup"===a.type?a.keyCode:0},which:function(a){return"keypress"===
a.type?od(a):"keydown"===a.type||"keyup"===a.type?a.keyCode:0}}),Rd=rd(Qd),Sd=A({},Ad,{pointerId:0,width:0,height:0,pressure:0,tangentialPressure:0,tiltX:0,tiltY:0,twist:0,pointerType:0,isPrimary:0}),Td=rd(Sd),Ud=A({},ud,{touches:0,targetTouches:0,changedTouches:0,altKey:0,metaKey:0,ctrlKey:0,shiftKey:0,getModifierState:zd}),Vd=rd(Ud),Wd=A({},sd,{propertyName:0,elapsedTime:0,pseudoElement:0}),Xd=rd(Wd),Yd=A({},Ad,{deltaX:function(a){return"deltaX"in a?a.deltaX:"wheelDeltaX"in a?-a.wheelDeltaX:0},
deltaY:function(a){return"deltaY"in a?a.deltaY:"wheelDeltaY"in a?-a.wheelDeltaY:"wheelDelta"in a?-a.wheelDelta:0},deltaZ:0,deltaMode:0}),Zd=rd(Yd),$d=[9,13,27,32],ae=ia&&"CompositionEvent"in window,be=null;ia&&"documentMode"in document&&(be=document.documentMode);var ce=ia&&"TextEvent"in window&&!be,de=ia&&(!ae||be&&8<be&&11>=be),ee=String.fromCharCode(32),fe=!1;
function ge(a,b){switch(a){case "keyup":return-1!==$d.indexOf(b.keyCode);case "keydown":return 229!==b.keyCode;case "keypress":case "mousedown":case "focusout":return!0;default:return!1}}function he(a){a=a.detail;return"object"===typeof a&&"data"in a?a.data:null}var ie=!1;function je(a,b){switch(a){case "compositionend":return he(b);case "keypress":if(32!==b.which)return null;fe=!0;return ee;case "textInput":return a=b.data,a===ee&&fe?null:a;default:return null}}
function ke(a,b){if(ie)return"compositionend"===a||!ae&&ge(a,b)?(a=nd(),md=ld=kd=null,ie=!1,a):null;switch(a){case "paste":return null;case "keypress":if(!(b.ctrlKey||b.altKey||b.metaKey)||b.ctrlKey&&b.altKey){if(b.char&&1<b.char.length)return b.char;if(b.which)return String.fromCharCode(b.which)}return null;case "compositionend":return de&&"ko"!==b.locale?null:b.data;default:return null}}
var le={color:!0,date:!0,datetime:!0,"datetime-local":!0,email:!0,month:!0,number:!0,password:!0,range:!0,search:!0,tel:!0,text:!0,time:!0,url:!0,week:!0};function me(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return"input"===b?!!le[a.type]:"textarea"===b?!0:!1}function ne(a,b,c,d){Eb(d);b=oe(b,"onChange");0<b.length&&(c=new td("onChange","change",null,c,d),a.push({event:c,listeners:b}))}var pe=null,qe=null;function re(a){se(a,0)}function te(a){var b=ue(a);if(Wa(b))return a}
function ve(a,b){if("change"===a)return b}var we=!1;if(ia){var xe;if(ia){var ye="oninput"in document;if(!ye){var ze=document.createElement("div");ze.setAttribute("oninput","return;");ye="function"===typeof ze.oninput}xe=ye}else xe=!1;we=xe&&(!document.documentMode||9<document.documentMode)}function Ae(){pe&&(pe.detachEvent("onpropertychange",Be),qe=pe=null)}function Be(a){if("value"===a.propertyName&&te(qe)){var b=[];ne(b,qe,a,xb(a));Jb(re,b)}}
function Ce(a,b,c){"focusin"===a?(Ae(),pe=b,qe=c,pe.attachEvent("onpropertychange",Be)):"focusout"===a&&Ae()}function De(a){if("selectionchange"===a||"keyup"===a||"keydown"===a)return te(qe)}function Ee(a,b){if("click"===a)return te(b)}function Fe(a,b){if("input"===a||"change"===a)return te(b)}function Ge(a,b){return a===b&&(0!==a||1/a===1/b)||a!==a&&b!==b}var He="function"===typeof Object.is?Object.is:Ge;
function Ie(a,b){if(He(a,b))return!0;if("object"!==typeof a||null===a||"object"!==typeof b||null===b)return!1;var c=Object.keys(a),d=Object.keys(b);if(c.length!==d.length)return!1;for(d=0;d<c.length;d++){var e=c[d];if(!ja.call(b,e)||!He(a[e],b[e]))return!1}return!0}function Je(a){for(;a&&a.firstChild;)a=a.firstChild;return a}
function Ke(a,b){var c=Je(a);a=0;for(var d;c;){if(3===c.nodeType){d=a+c.textContent.length;if(a<=b&&d>=b)return{node:c,offset:b-a};a=d}a:{for(;c;){if(c.nextSibling){c=c.nextSibling;break a}c=c.parentNode}c=void 0}c=Je(c)}}function Le(a,b){return a&&b?a===b?!0:a&&3===a.nodeType?!1:b&&3===b.nodeType?Le(a,b.parentNode):"contains"in a?a.contains(b):a.compareDocumentPosition?!!(a.compareDocumentPosition(b)&16):!1:!1}
function Me(){for(var a=window,b=Xa();b instanceof a.HTMLIFrameElement;){try{var c="string"===typeof b.contentWindow.location.href}catch(d){c=!1}if(c)a=b.contentWindow;else break;b=Xa(a.document)}return b}function Ne(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return b&&("input"===b&&("text"===a.type||"search"===a.type||"tel"===a.type||"url"===a.type||"password"===a.type)||"textarea"===b||"true"===a.contentEditable)}
function Oe(a){var b=Me(),c=a.focusedElem,d=a.selectionRange;if(b!==c&&c&&c.ownerDocument&&Le(c.ownerDocument.documentElement,c)){if(null!==d&&Ne(c))if(b=d.start,a=d.end,void 0===a&&(a=b),"selectionStart"in c)c.selectionStart=b,c.selectionEnd=Math.min(a,c.value.length);else if(a=(b=c.ownerDocument||document)&&b.defaultView||window,a.getSelection){a=a.getSelection();var e=c.textContent.length,f=Math.min(d.start,e);d=void 0===d.end?f:Math.min(d.end,e);!a.extend&&f>d&&(e=d,d=f,f=e);e=Ke(c,f);var g=Ke(c,
d);e&&g&&(1!==a.rangeCount||a.anchorNode!==e.node||a.anchorOffset!==e.offset||a.focusNode!==g.node||a.focusOffset!==g.offset)&&(b=b.createRange(),b.setStart(e.node,e.offset),a.removeAllRanges(),f>d?(a.addRange(b),a.extend(g.node,g.offset)):(b.setEnd(g.node,g.offset),a.addRange(b)))}b=[];for(a=c;a=a.parentNode;)1===a.nodeType&&b.push({element:a,left:a.scrollLeft,top:a.scrollTop});"function"===typeof c.focus&&c.focus();for(c=0;c<b.length;c++)a=b[c],a.element.scrollLeft=a.left,a.element.scrollTop=a.top}}
var Pe=ia&&"documentMode"in document&&11>=document.documentMode,Qe=null,Re=null,Se=null,Te=!1;
function Ue(a,b,c){var d=c.window===c?c.document:9===c.nodeType?c:c.ownerDocument;Te||null==Qe||Qe!==Xa(d)||(d=Qe,"selectionStart"in d&&Ne(d)?d={start:d.selectionStart,end:d.selectionEnd}:(d=(d.ownerDocument&&d.ownerDocument.defaultView||window).getSelection(),d={anchorNode:d.anchorNode,anchorOffset:d.anchorOffset,focusNode:d.focusNode,focusOffset:d.focusOffset}),Se&&Ie(Se,d)||(Se=d,d=oe(Re,"onSelect"),0<d.length&&(b=new td("onSelect","select",null,b,c),a.push({event:b,listeners:d}),b.target=Qe)))}
function Ve(a,b){var c={};c[a.toLowerCase()]=b.toLowerCase();c["Webkit"+a]="webkit"+b;c["Moz"+a]="moz"+b;return c}var We={animationend:Ve("Animation","AnimationEnd"),animationiteration:Ve("Animation","AnimationIteration"),animationstart:Ve("Animation","AnimationStart"),transitionend:Ve("Transition","TransitionEnd")},Xe={},Ye={};
ia&&(Ye=document.createElement("div").style,"AnimationEvent"in window||(delete We.animationend.animation,delete We.animationiteration.animation,delete We.animationstart.animation),"TransitionEvent"in window||delete We.transitionend.transition);function Ze(a){if(Xe[a])return Xe[a];if(!We[a])return a;var b=We[a],c;for(c in b)if(b.hasOwnProperty(c)&&c in Ye)return Xe[a]=b[c];return a}var $e=Ze("animationend"),af=Ze("animationiteration"),bf=Ze("animationstart"),cf=Ze("transitionend"),df=new Map,ef="abort auxClick cancel canPlay canPlayThrough click close contextMenu copy cut drag dragEnd dragEnter dragExit dragLeave dragOver dragStart drop durationChange emptied encrypted ended error gotPointerCapture input invalid keyDown keyPress keyUp load loadedData loadedMetadata loadStart lostPointerCapture mouseDown mouseMove mouseOut mouseOver mouseUp paste pause play playing pointerCancel pointerDown pointerMove pointerOut pointerOver pointerUp progress rateChange reset resize seeked seeking stalled submit suspend timeUpdate touchCancel touchEnd touchStart volumeChange scroll toggle touchMove waiting wheel".split(" ");
function ff(a,b){df.set(a,b);fa(b,[a])}for(var gf=0;gf<ef.length;gf++){var hf=ef[gf],jf=hf.toLowerCase(),kf=hf[0].toUpperCase()+hf.slice(1);ff(jf,"on"+kf)}ff($e,"onAnimationEnd");ff(af,"onAnimationIteration");ff(bf,"onAnimationStart");ff("dblclick","onDoubleClick");ff("focusin","onFocus");ff("focusout","onBlur");ff(cf,"onTransitionEnd");ha("onMouseEnter",["mouseout","mouseover"]);ha("onMouseLeave",["mouseout","mouseover"]);ha("onPointerEnter",["pointerout","pointerover"]);
ha("onPointerLeave",["pointerout","pointerover"]);fa("onChange","change click focusin focusout input keydown keyup selectionchange".split(" "));fa("onSelect","focusout contextmenu dragend focusin keydown keyup mousedown mouseup selectionchange".split(" "));fa("onBeforeInput",["compositionend","keypress","textInput","paste"]);fa("onCompositionEnd","compositionend focusout keydown keypress keyup mousedown".split(" "));fa("onCompositionStart","compositionstart focusout keydown keypress keyup mousedown".split(" "));
fa("onCompositionUpdate","compositionupdate focusout keydown keypress keyup mousedown".split(" "));var lf="abort canplay canplaythrough durationchange emptied encrypted ended error loadeddata loadedmetadata loadstart pause play playing progress ratechange resize seeked seeking stalled suspend timeupdate volumechange waiting".split(" "),mf=new Set("cancel close invalid load scroll toggle".split(" ").concat(lf));
function nf(a,b,c){var d=a.type||"unknown-event";a.currentTarget=c;Ub(d,b,void 0,a);a.currentTarget=null}
function se(a,b){b=0!==(b&4);for(var c=0;c<a.length;c++){var d=a[c],e=d.event;d=d.listeners;a:{var f=void 0;if(b)for(var g=d.length-1;0<=g;g--){var h=d[g],k=h.instance,l=h.currentTarget;h=h.listener;if(k!==f&&e.isPropagationStopped())break a;nf(e,h,l);f=k}else for(g=0;g<d.length;g++){h=d[g];k=h.instance;l=h.currentTarget;h=h.listener;if(k!==f&&e.isPropagationStopped())break a;nf(e,h,l);f=k}}}if(Qb)throw a=Rb,Qb=!1,Rb=null,a;}
function D(a,b){var c=b[of];void 0===c&&(c=b[of]=new Set);var d=a+"__bubble";c.has(d)||(pf(b,a,2,!1),c.add(d))}function qf(a,b,c){var d=0;b&&(d|=4);pf(c,a,d,b)}var rf="_reactListening"+Math.random().toString(36).slice(2);function sf(a){if(!a[rf]){a[rf]=!0;da.forEach(function(b){"selectionchange"!==b&&(mf.has(b)||qf(b,!1,a),qf(b,!0,a))});var b=9===a.nodeType?a:a.ownerDocument;null===b||b[rf]||(b[rf]=!0,qf("selectionchange",!1,b))}}
function pf(a,b,c,d){switch(jd(b)){case 1:var e=ed;break;case 4:e=gd;break;default:e=fd}c=e.bind(null,b,c,a);e=void 0;!Lb||"touchstart"!==b&&"touchmove"!==b&&"wheel"!==b||(e=!0);d?void 0!==e?a.addEventListener(b,c,{capture:!0,passive:e}):a.addEventListener(b,c,!0):void 0!==e?a.addEventListener(b,c,{passive:e}):a.addEventListener(b,c,!1)}
function hd(a,b,c,d,e){var f=d;if(0===(b&1)&&0===(b&2)&&null!==d)a:for(;;){if(null===d)return;var g=d.tag;if(3===g||4===g){var h=d.stateNode.containerInfo;if(h===e||8===h.nodeType&&h.parentNode===e)break;if(4===g)for(g=d.return;null!==g;){var k=g.tag;if(3===k||4===k)if(k=g.stateNode.containerInfo,k===e||8===k.nodeType&&k.parentNode===e)return;g=g.return}for(;null!==h;){g=Wc(h);if(null===g)return;k=g.tag;if(5===k||6===k){d=f=g;continue a}h=h.parentNode}}d=d.return}Jb(function(){var d=f,e=xb(c),g=[];
a:{var h=df.get(a);if(void 0!==h){var k=td,n=a;switch(a){case "keypress":if(0===od(c))break a;case "keydown":case "keyup":k=Rd;break;case "focusin":n="focus";k=Fd;break;case "focusout":n="blur";k=Fd;break;case "beforeblur":case "afterblur":k=Fd;break;case "click":if(2===c.button)break a;case "auxclick":case "dblclick":case "mousedown":case "mousemove":case "mouseup":case "mouseout":case "mouseover":case "contextmenu":k=Bd;break;case "drag":case "dragend":case "dragenter":case "dragexit":case "dragleave":case "dragover":case "dragstart":case "drop":k=
Dd;break;case "touchcancel":case "touchend":case "touchmove":case "touchstart":k=Vd;break;case $e:case af:case bf:k=Hd;break;case cf:k=Xd;break;case "scroll":k=vd;break;case "wheel":k=Zd;break;case "copy":case "cut":case "paste":k=Jd;break;case "gotpointercapture":case "lostpointercapture":case "pointercancel":case "pointerdown":case "pointermove":case "pointerout":case "pointerover":case "pointerup":k=Td}var t=0!==(b&4),J=!t&&"scroll"===a,x=t?null!==h?h+"Capture":null:h;t=[];for(var w=d,u;null!==
w;){u=w;var F=u.stateNode;5===u.tag&&null!==F&&(u=F,null!==x&&(F=Kb(w,x),null!=F&&t.push(tf(w,F,u))));if(J)break;w=w.return}0<t.length&&(h=new k(h,n,null,c,e),g.push({event:h,listeners:t}))}}if(0===(b&7)){a:{h="mouseover"===a||"pointerover"===a;k="mouseout"===a||"pointerout"===a;if(h&&c!==wb&&(n=c.relatedTarget||c.fromElement)&&(Wc(n)||n[uf]))break a;if(k||h){h=e.window===e?e:(h=e.ownerDocument)?h.defaultView||h.parentWindow:window;if(k){if(n=c.relatedTarget||c.toElement,k=d,n=n?Wc(n):null,null!==
n&&(J=Vb(n),n!==J||5!==n.tag&&6!==n.tag))n=null}else k=null,n=d;if(k!==n){t=Bd;F="onMouseLeave";x="onMouseEnter";w="mouse";if("pointerout"===a||"pointerover"===a)t=Td,F="onPointerLeave",x="onPointerEnter",w="pointer";J=null==k?h:ue(k);u=null==n?h:ue(n);h=new t(F,w+"leave",k,c,e);h.target=J;h.relatedTarget=u;F=null;Wc(e)===d&&(t=new t(x,w+"enter",n,c,e),t.target=u,t.relatedTarget=J,F=t);J=F;if(k&&n)b:{t=k;x=n;w=0;for(u=t;u;u=vf(u))w++;u=0;for(F=x;F;F=vf(F))u++;for(;0<w-u;)t=vf(t),w--;for(;0<u-w;)x=
vf(x),u--;for(;w--;){if(t===x||null!==x&&t===x.alternate)break b;t=vf(t);x=vf(x)}t=null}else t=null;null!==k&&wf(g,h,k,t,!1);null!==n&&null!==J&&wf(g,J,n,t,!0)}}}a:{h=d?ue(d):window;k=h.nodeName&&h.nodeName.toLowerCase();if("select"===k||"input"===k&&"file"===h.type)var na=ve;else if(me(h))if(we)na=Fe;else{na=De;var xa=Ce}else(k=h.nodeName)&&"input"===k.toLowerCase()&&("checkbox"===h.type||"radio"===h.type)&&(na=Ee);if(na&&(na=na(a,d))){ne(g,na,c,e);break a}xa&&xa(a,h,d);"focusout"===a&&(xa=h._wrapperState)&&
xa.controlled&&"number"===h.type&&cb(h,"number",h.value)}xa=d?ue(d):window;switch(a){case "focusin":if(me(xa)||"true"===xa.contentEditable)Qe=xa,Re=d,Se=null;break;case "focusout":Se=Re=Qe=null;break;case "mousedown":Te=!0;break;case "contextmenu":case "mouseup":case "dragend":Te=!1;Ue(g,c,e);break;case "selectionchange":if(Pe)break;case "keydown":case "keyup":Ue(g,c,e)}var $a;if(ae)b:{switch(a){case "compositionstart":var ba="onCompositionStart";break b;case "compositionend":ba="onCompositionEnd";
break b;case "compositionupdate":ba="onCompositionUpdate";break b}ba=void 0}else ie?ge(a,c)&&(ba="onCompositionEnd"):"keydown"===a&&229===c.keyCode&&(ba="onCompositionStart");ba&&(de&&"ko"!==c.locale&&(ie||"onCompositionStart"!==ba?"onCompositionEnd"===ba&&ie&&($a=nd()):(kd=e,ld="value"in kd?kd.value:kd.textContent,ie=!0)),xa=oe(d,ba),0<xa.length&&(ba=new Ld(ba,a,null,c,e),g.push({event:ba,listeners:xa}),$a?ba.data=$a:($a=he(c),null!==$a&&(ba.data=$a))));if($a=ce?je(a,c):ke(a,c))d=oe(d,"onBeforeInput"),
0<d.length&&(e=new Ld("onBeforeInput","beforeinput",null,c,e),g.push({event:e,listeners:d}),e.data=$a)}se(g,b)})}function tf(a,b,c){return{instance:a,listener:b,currentTarget:c}}function oe(a,b){for(var c=b+"Capture",d=[];null!==a;){var e=a,f=e.stateNode;5===e.tag&&null!==f&&(e=f,f=Kb(a,c),null!=f&&d.unshift(tf(a,f,e)),f=Kb(a,b),null!=f&&d.push(tf(a,f,e)));a=a.return}return d}function vf(a){if(null===a)return null;do a=a.return;while(a&&5!==a.tag);return a?a:null}
function wf(a,b,c,d,e){for(var f=b._reactName,g=[];null!==c&&c!==d;){var h=c,k=h.alternate,l=h.stateNode;if(null!==k&&k===d)break;5===h.tag&&null!==l&&(h=l,e?(k=Kb(c,f),null!=k&&g.unshift(tf(c,k,h))):e||(k=Kb(c,f),null!=k&&g.push(tf(c,k,h))));c=c.return}0!==g.length&&a.push({event:b,listeners:g})}var xf=/\r\n?/g,yf=/\u0000|\uFFFD/g;function zf(a){return("string"===typeof a?a:""+a).replace(xf,"\n").replace(yf,"")}function Af(a,b,c){b=zf(b);if(zf(a)!==b&&c)throw Error(p(425));}function Bf(){}
var Cf=null,Df=null;function Ef(a,b){return"textarea"===a||"noscript"===a||"string"===typeof b.children||"number"===typeof b.children||"object"===typeof b.dangerouslySetInnerHTML&&null!==b.dangerouslySetInnerHTML&&null!=b.dangerouslySetInnerHTML.__html}
var Ff="function"===typeof setTimeout?setTimeout:void 0,Gf="function"===typeof clearTimeout?clearTimeout:void 0,Hf="function"===typeof Promise?Promise:void 0,Jf="function"===typeof queueMicrotask?queueMicrotask:"undefined"!==typeof Hf?function(a){return Hf.resolve(null).then(a).catch(If)}:Ff;function If(a){setTimeout(function(){throw a;})}
function Kf(a,b){var c=b,d=0;do{var e=c.nextSibling;a.removeChild(c);if(e&&8===e.nodeType)if(c=e.data,"/$"===c){if(0===d){a.removeChild(e);bd(b);return}d--}else"$"!==c&&"$?"!==c&&"$!"!==c||d++;c=e}while(c);bd(b)}function Lf(a){for(;null!=a;a=a.nextSibling){var b=a.nodeType;if(1===b||3===b)break;if(8===b){b=a.data;if("$"===b||"$!"===b||"$?"===b)break;if("/$"===b)return null}}return a}
function Mf(a){a=a.previousSibling;for(var b=0;a;){if(8===a.nodeType){var c=a.data;if("$"===c||"$!"===c||"$?"===c){if(0===b)return a;b--}else"/$"===c&&b++}a=a.previousSibling}return null}var Nf=Math.random().toString(36).slice(2),Of="__reactFiber$"+Nf,Pf="__reactProps$"+Nf,uf="__reactContainer$"+Nf,of="__reactEvents$"+Nf,Qf="__reactListeners$"+Nf,Rf="__reactHandles$"+Nf;
function Wc(a){var b=a[Of];if(b)return b;for(var c=a.parentNode;c;){if(b=c[uf]||c[Of]){c=b.alternate;if(null!==b.child||null!==c&&null!==c.child)for(a=Mf(a);null!==a;){if(c=a[Of])return c;a=Mf(a)}return b}a=c;c=a.parentNode}return null}function Cb(a){a=a[Of]||a[uf];return!a||5!==a.tag&&6!==a.tag&&13!==a.tag&&3!==a.tag?null:a}function ue(a){if(5===a.tag||6===a.tag)return a.stateNode;throw Error(p(33));}function Db(a){return a[Pf]||null}var Sf=[],Tf=-1;function Uf(a){return{current:a}}
function E(a){0>Tf||(a.current=Sf[Tf],Sf[Tf]=null,Tf--)}function G(a,b){Tf++;Sf[Tf]=a.current;a.current=b}var Vf={},H=Uf(Vf),Wf=Uf(!1),Xf=Vf;function Yf(a,b){var c=a.type.contextTypes;if(!c)return Vf;var d=a.stateNode;if(d&&d.__reactInternalMemoizedUnmaskedChildContext===b)return d.__reactInternalMemoizedMaskedChildContext;var e={},f;for(f in c)e[f]=b[f];d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=b,a.__reactInternalMemoizedMaskedChildContext=e);return e}
function Zf(a){a=a.childContextTypes;return null!==a&&void 0!==a}function $f(){E(Wf);E(H)}function ag(a,b,c){if(H.current!==Vf)throw Error(p(168));G(H,b);G(Wf,c)}function bg(a,b,c){var d=a.stateNode;b=b.childContextTypes;if("function"!==typeof d.getChildContext)return c;d=d.getChildContext();for(var e in d)if(!(e in b))throw Error(p(108,Ra(a)||"Unknown",e));return A({},c,d)}
function cg(a){a=(a=a.stateNode)&&a.__reactInternalMemoizedMergedChildContext||Vf;Xf=H.current;G(H,a);G(Wf,Wf.current);return!0}function dg(a,b,c){var d=a.stateNode;if(!d)throw Error(p(169));c?(a=bg(a,b,Xf),d.__reactInternalMemoizedMergedChildContext=a,E(Wf),E(H),G(H,a)):E(Wf);G(Wf,c)}var eg=null,fg=!1,gg=!1;function hg(a){null===eg?eg=[a]:eg.push(a)}function ig(a){fg=!0;hg(a)}
function jg(){if(!gg&&null!==eg){gg=!0;var a=0,b=C;try{var c=eg;for(C=1;a<c.length;a++){var d=c[a];do d=d(!0);while(null!==d)}eg=null;fg=!1}catch(e){throw null!==eg&&(eg=eg.slice(a+1)),ac(fc,jg),e;}finally{C=b,gg=!1}}return null}var kg=[],lg=0,mg=null,ng=0,og=[],pg=0,qg=null,rg=1,sg="";function tg(a,b){kg[lg++]=ng;kg[lg++]=mg;mg=a;ng=b}
function ug(a,b,c){og[pg++]=rg;og[pg++]=sg;og[pg++]=qg;qg=a;var d=rg;a=sg;var e=32-oc(d)-1;d&=~(1<<e);c+=1;var f=32-oc(b)+e;if(30<f){var g=e-e%5;f=(d&(1<<g)-1).toString(32);d>>=g;e-=g;rg=1<<32-oc(b)+e|c<<e|d;sg=f+a}else rg=1<<f|c<<e|d,sg=a}function vg(a){null!==a.return&&(tg(a,1),ug(a,1,0))}function wg(a){for(;a===mg;)mg=kg[--lg],kg[lg]=null,ng=kg[--lg],kg[lg]=null;for(;a===qg;)qg=og[--pg],og[pg]=null,sg=og[--pg],og[pg]=null,rg=og[--pg],og[pg]=null}var xg=null,yg=null,I=!1,zg=null;
function Ag(a,b){var c=Bg(5,null,null,0);c.elementType="DELETED";c.stateNode=b;c.return=a;b=a.deletions;null===b?(a.deletions=[c],a.flags|=16):b.push(c)}
function Cg(a,b){switch(a.tag){case 5:var c=a.type;b=1!==b.nodeType||c.toLowerCase()!==b.nodeName.toLowerCase()?null:b;return null!==b?(a.stateNode=b,xg=a,yg=Lf(b.firstChild),!0):!1;case 6:return b=""===a.pendingProps||3!==b.nodeType?null:b,null!==b?(a.stateNode=b,xg=a,yg=null,!0):!1;case 13:return b=8!==b.nodeType?null:b,null!==b?(c=null!==qg?{id:rg,overflow:sg}:null,a.memoizedState={dehydrated:b,treeContext:c,retryLane:1073741824},c=Bg(18,null,null,0),c.stateNode=b,c.return=a,a.child=c,xg=a,yg=
null,!0):!1;default:return!1}}function Dg(a){return 0!==(a.mode&1)&&0===(a.flags&128)}function Eg(a){if(I){var b=yg;if(b){var c=b;if(!Cg(a,b)){if(Dg(a))throw Error(p(418));b=Lf(c.nextSibling);var d=xg;b&&Cg(a,b)?Ag(d,c):(a.flags=a.flags&-4097|2,I=!1,xg=a)}}else{if(Dg(a))throw Error(p(418));a.flags=a.flags&-4097|2;I=!1;xg=a}}}function Fg(a){for(a=a.return;null!==a&&5!==a.tag&&3!==a.tag&&13!==a.tag;)a=a.return;xg=a}
function Gg(a){if(a!==xg)return!1;if(!I)return Fg(a),I=!0,!1;var b;(b=3!==a.tag)&&!(b=5!==a.tag)&&(b=a.type,b="head"!==b&&"body"!==b&&!Ef(a.type,a.memoizedProps));if(b&&(b=yg)){if(Dg(a))throw Hg(),Error(p(418));for(;b;)Ag(a,b),b=Lf(b.nextSibling)}Fg(a);if(13===a.tag){a=a.memoizedState;a=null!==a?a.dehydrated:null;if(!a)throw Error(p(317));a:{a=a.nextSibling;for(b=0;a;){if(8===a.nodeType){var c=a.data;if("/$"===c){if(0===b){yg=Lf(a.nextSibling);break a}b--}else"$"!==c&&"$!"!==c&&"$?"!==c||b++}a=a.nextSibling}yg=
null}}else yg=xg?Lf(a.stateNode.nextSibling):null;return!0}function Hg(){for(var a=yg;a;)a=Lf(a.nextSibling)}function Ig(){yg=xg=null;I=!1}function Jg(a){null===zg?zg=[a]:zg.push(a)}var Kg=ua.ReactCurrentBatchConfig;function Lg(a,b){if(a&&a.defaultProps){b=A({},b);a=a.defaultProps;for(var c in a)void 0===b[c]&&(b[c]=a[c]);return b}return b}var Mg=Uf(null),Ng=null,Og=null,Pg=null;function Qg(){Pg=Og=Ng=null}function Rg(a){var b=Mg.current;E(Mg);a._currentValue=b}
function Sg(a,b,c){for(;null!==a;){var d=a.alternate;(a.childLanes&b)!==b?(a.childLanes|=b,null!==d&&(d.childLanes|=b)):null!==d&&(d.childLanes&b)!==b&&(d.childLanes|=b);if(a===c)break;a=a.return}}function Tg(a,b){Ng=a;Pg=Og=null;a=a.dependencies;null!==a&&null!==a.firstContext&&(0!==(a.lanes&b)&&(Ug=!0),a.firstContext=null)}
function Vg(a){var b=a._currentValue;if(Pg!==a)if(a={context:a,memoizedValue:b,next:null},null===Og){if(null===Ng)throw Error(p(308));Og=a;Ng.dependencies={lanes:0,firstContext:a}}else Og=Og.next=a;return b}var Wg=null;function Xg(a){null===Wg?Wg=[a]:Wg.push(a)}function Yg(a,b,c,d){var e=b.interleaved;null===e?(c.next=c,Xg(b)):(c.next=e.next,e.next=c);b.interleaved=c;return Zg(a,d)}
function Zg(a,b){a.lanes|=b;var c=a.alternate;null!==c&&(c.lanes|=b);c=a;for(a=a.return;null!==a;)a.childLanes|=b,c=a.alternate,null!==c&&(c.childLanes|=b),c=a,a=a.return;return 3===c.tag?c.stateNode:null}var $g=!1;function ah(a){a.updateQueue={baseState:a.memoizedState,firstBaseUpdate:null,lastBaseUpdate:null,shared:{pending:null,interleaved:null,lanes:0},effects:null}}
function bh(a,b){a=a.updateQueue;b.updateQueue===a&&(b.updateQueue={baseState:a.baseState,firstBaseUpdate:a.firstBaseUpdate,lastBaseUpdate:a.lastBaseUpdate,shared:a.shared,effects:a.effects})}function ch(a,b){return{eventTime:a,lane:b,tag:0,payload:null,callback:null,next:null}}
function dh(a,b,c){var d=a.updateQueue;if(null===d)return null;d=d.shared;if(0!==(K&2)){var e=d.pending;null===e?b.next=b:(b.next=e.next,e.next=b);d.pending=b;return Zg(a,c)}e=d.interleaved;null===e?(b.next=b,Xg(d)):(b.next=e.next,e.next=b);d.interleaved=b;return Zg(a,c)}function eh(a,b,c){b=b.updateQueue;if(null!==b&&(b=b.shared,0!==(c&4194240))){var d=b.lanes;d&=a.pendingLanes;c|=d;b.lanes=c;Cc(a,c)}}
function fh(a,b){var c=a.updateQueue,d=a.alternate;if(null!==d&&(d=d.updateQueue,c===d)){var e=null,f=null;c=c.firstBaseUpdate;if(null!==c){do{var g={eventTime:c.eventTime,lane:c.lane,tag:c.tag,payload:c.payload,callback:c.callback,next:null};null===f?e=f=g:f=f.next=g;c=c.next}while(null!==c);null===f?e=f=b:f=f.next=b}else e=f=b;c={baseState:d.baseState,firstBaseUpdate:e,lastBaseUpdate:f,shared:d.shared,effects:d.effects};a.updateQueue=c;return}a=c.lastBaseUpdate;null===a?c.firstBaseUpdate=b:a.next=
b;c.lastBaseUpdate=b}
function gh(a,b,c,d){var e=a.updateQueue;$g=!1;var f=e.firstBaseUpdate,g=e.lastBaseUpdate,h=e.shared.pending;if(null!==h){e.shared.pending=null;var k=h,l=k.next;k.next=null;null===g?f=l:g.next=l;g=k;var m=a.alternate;null!==m&&(m=m.updateQueue,h=m.lastBaseUpdate,h!==g&&(null===h?m.firstBaseUpdate=l:h.next=l,m.lastBaseUpdate=k))}if(null!==f){var q=e.baseState;g=0;m=l=k=null;h=f;do{var r=h.lane,y=h.eventTime;if((d&r)===r){null!==m&&(m=m.next={eventTime:y,lane:0,tag:h.tag,payload:h.payload,callback:h.callback,
next:null});a:{var n=a,t=h;r=b;y=c;switch(t.tag){case 1:n=t.payload;if("function"===typeof n){q=n.call(y,q,r);break a}q=n;break a;case 3:n.flags=n.flags&-65537|128;case 0:n=t.payload;r="function"===typeof n?n.call(y,q,r):n;if(null===r||void 0===r)break a;q=A({},q,r);break a;case 2:$g=!0}}null!==h.callback&&0!==h.lane&&(a.flags|=64,r=e.effects,null===r?e.effects=[h]:r.push(h))}else y={eventTime:y,lane:r,tag:h.tag,payload:h.payload,callback:h.callback,next:null},null===m?(l=m=y,k=q):m=m.next=y,g|=r;
h=h.next;if(null===h)if(h=e.shared.pending,null===h)break;else r=h,h=r.next,r.next=null,e.lastBaseUpdate=r,e.shared.pending=null}while(1);null===m&&(k=q);e.baseState=k;e.firstBaseUpdate=l;e.lastBaseUpdate=m;b=e.shared.interleaved;if(null!==b){e=b;do g|=e.lane,e=e.next;while(e!==b)}else null===f&&(e.shared.lanes=0);hh|=g;a.lanes=g;a.memoizedState=q}}
function ih(a,b,c){a=b.effects;b.effects=null;if(null!==a)for(b=0;b<a.length;b++){var d=a[b],e=d.callback;if(null!==e){d.callback=null;d=c;if("function"!==typeof e)throw Error(p(191,e));e.call(d)}}}var jh=(new aa.Component).refs;function kh(a,b,c,d){b=a.memoizedState;c=c(d,b);c=null===c||void 0===c?b:A({},b,c);a.memoizedState=c;0===a.lanes&&(a.updateQueue.baseState=c)}
var nh={isMounted:function(a){return(a=a._reactInternals)?Vb(a)===a:!1},enqueueSetState:function(a,b,c){a=a._reactInternals;var d=L(),e=lh(a),f=ch(d,e);f.payload=b;void 0!==c&&null!==c&&(f.callback=c);b=dh(a,f,e);null!==b&&(mh(b,a,e,d),eh(b,a,e))},enqueueReplaceState:function(a,b,c){a=a._reactInternals;var d=L(),e=lh(a),f=ch(d,e);f.tag=1;f.payload=b;void 0!==c&&null!==c&&(f.callback=c);b=dh(a,f,e);null!==b&&(mh(b,a,e,d),eh(b,a,e))},enqueueForceUpdate:function(a,b){a=a._reactInternals;var c=L(),d=
lh(a),e=ch(c,d);e.tag=2;void 0!==b&&null!==b&&(e.callback=b);b=dh(a,e,d);null!==b&&(mh(b,a,d,c),eh(b,a,d))}};function oh(a,b,c,d,e,f,g){a=a.stateNode;return"function"===typeof a.shouldComponentUpdate?a.shouldComponentUpdate(d,f,g):b.prototype&&b.prototype.isPureReactComponent?!Ie(c,d)||!Ie(e,f):!0}
function ph(a,b,c){var d=!1,e=Vf;var f=b.contextType;"object"===typeof f&&null!==f?f=Vg(f):(e=Zf(b)?Xf:H.current,d=b.contextTypes,f=(d=null!==d&&void 0!==d)?Yf(a,e):Vf);b=new b(c,f);a.memoizedState=null!==b.state&&void 0!==b.state?b.state:null;b.updater=nh;a.stateNode=b;b._reactInternals=a;d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=e,a.__reactInternalMemoizedMaskedChildContext=f);return b}
function qh(a,b,c,d){a=b.state;"function"===typeof b.componentWillReceiveProps&&b.componentWillReceiveProps(c,d);"function"===typeof b.UNSAFE_componentWillReceiveProps&&b.UNSAFE_componentWillReceiveProps(c,d);b.state!==a&&nh.enqueueReplaceState(b,b.state,null)}
function rh(a,b,c,d){var e=a.stateNode;e.props=c;e.state=a.memoizedState;e.refs=jh;ah(a);var f=b.contextType;"object"===typeof f&&null!==f?e.context=Vg(f):(f=Zf(b)?Xf:H.current,e.context=Yf(a,f));e.state=a.memoizedState;f=b.getDerivedStateFromProps;"function"===typeof f&&(kh(a,b,f,c),e.state=a.memoizedState);"function"===typeof b.getDerivedStateFromProps||"function"===typeof e.getSnapshotBeforeUpdate||"function"!==typeof e.UNSAFE_componentWillMount&&"function"!==typeof e.componentWillMount||(b=e.state,
"function"===typeof e.componentWillMount&&e.componentWillMount(),"function"===typeof e.UNSAFE_componentWillMount&&e.UNSAFE_componentWillMount(),b!==e.state&&nh.enqueueReplaceState(e,e.state,null),gh(a,c,e,d),e.state=a.memoizedState);"function"===typeof e.componentDidMount&&(a.flags|=4194308)}
function sh(a,b,c){a=c.ref;if(null!==a&&"function"!==typeof a&&"object"!==typeof a){if(c._owner){c=c._owner;if(c){if(1!==c.tag)throw Error(p(309));var d=c.stateNode}if(!d)throw Error(p(147,a));var e=d,f=""+a;if(null!==b&&null!==b.ref&&"function"===typeof b.ref&&b.ref._stringRef===f)return b.ref;b=function(a){var b=e.refs;b===jh&&(b=e.refs={});null===a?delete b[f]:b[f]=a};b._stringRef=f;return b}if("string"!==typeof a)throw Error(p(284));if(!c._owner)throw Error(p(290,a));}return a}
function th(a,b){a=Object.prototype.toString.call(b);throw Error(p(31,"[object Object]"===a?"object with keys {"+Object.keys(b).join(", ")+"}":a));}function uh(a){var b=a._init;return b(a._payload)}
function vh(a){function b(b,c){if(a){var d=b.deletions;null===d?(b.deletions=[c],b.flags|=16):d.push(c)}}function c(c,d){if(!a)return null;for(;null!==d;)b(c,d),d=d.sibling;return null}function d(a,b){for(a=new Map;null!==b;)null!==b.key?a.set(b.key,b):a.set(b.index,b),b=b.sibling;return a}function e(a,b){a=wh(a,b);a.index=0;a.sibling=null;return a}function f(b,c,d){b.index=d;if(!a)return b.flags|=1048576,c;d=b.alternate;if(null!==d)return d=d.index,d<c?(b.flags|=2,c):d;b.flags|=2;return c}function g(b){a&&
null===b.alternate&&(b.flags|=2);return b}function h(a,b,c,d){if(null===b||6!==b.tag)return b=xh(c,a.mode,d),b.return=a,b;b=e(b,c);b.return=a;return b}function k(a,b,c,d){var f=c.type;if(f===ya)return m(a,b,c.props.children,d,c.key);if(null!==b&&(b.elementType===f||"object"===typeof f&&null!==f&&f.$$typeof===Ha&&uh(f)===b.type))return d=e(b,c.props),d.ref=sh(a,b,c),d.return=a,d;d=yh(c.type,c.key,c.props,null,a.mode,d);d.ref=sh(a,b,c);d.return=a;return d}function l(a,b,c,d){if(null===b||4!==b.tag||
b.stateNode.containerInfo!==c.containerInfo||b.stateNode.implementation!==c.implementation)return b=zh(c,a.mode,d),b.return=a,b;b=e(b,c.children||[]);b.return=a;return b}function m(a,b,c,d,f){if(null===b||7!==b.tag)return b=Ah(c,a.mode,d,f),b.return=a,b;b=e(b,c);b.return=a;return b}function q(a,b,c){if("string"===typeof b&&""!==b||"number"===typeof b)return b=xh(""+b,a.mode,c),b.return=a,b;if("object"===typeof b&&null!==b){switch(b.$$typeof){case va:return c=yh(b.type,b.key,b.props,null,a.mode,c),
c.ref=sh(a,null,b),c.return=a,c;case wa:return b=zh(b,a.mode,c),b.return=a,b;case Ha:var d=b._init;return q(a,d(b._payload),c)}if(eb(b)||Ka(b))return b=Ah(b,a.mode,c,null),b.return=a,b;th(a,b)}return null}function r(a,b,c,d){var e=null!==b?b.key:null;if("string"===typeof c&&""!==c||"number"===typeof c)return null!==e?null:h(a,b,""+c,d);if("object"===typeof c&&null!==c){switch(c.$$typeof){case va:return c.key===e?k(a,b,c,d):null;case wa:return c.key===e?l(a,b,c,d):null;case Ha:return e=c._init,r(a,
b,e(c._payload),d)}if(eb(c)||Ka(c))return null!==e?null:m(a,b,c,d,null);th(a,c)}return null}function y(a,b,c,d,e){if("string"===typeof d&&""!==d||"number"===typeof d)return a=a.get(c)||null,h(b,a,""+d,e);if("object"===typeof d&&null!==d){switch(d.$$typeof){case va:return a=a.get(null===d.key?c:d.key)||null,k(b,a,d,e);case wa:return a=a.get(null===d.key?c:d.key)||null,l(b,a,d,e);case Ha:var f=d._init;return y(a,b,c,f(d._payload),e)}if(eb(d)||Ka(d))return a=a.get(c)||null,m(b,a,d,e,null);th(b,d)}return null}
function n(e,g,h,k){for(var l=null,m=null,u=g,w=g=0,x=null;null!==u&&w<h.length;w++){u.index>w?(x=u,u=null):x=u.sibling;var n=r(e,u,h[w],k);if(null===n){null===u&&(u=x);break}a&&u&&null===n.alternate&&b(e,u);g=f(n,g,w);null===m?l=n:m.sibling=n;m=n;u=x}if(w===h.length)return c(e,u),I&&tg(e,w),l;if(null===u){for(;w<h.length;w++)u=q(e,h[w],k),null!==u&&(g=f(u,g,w),null===m?l=u:m.sibling=u,m=u);I&&tg(e,w);return l}for(u=d(e,u);w<h.length;w++)x=y(u,e,w,h[w],k),null!==x&&(a&&null!==x.alternate&&u.delete(null===
x.key?w:x.key),g=f(x,g,w),null===m?l=x:m.sibling=x,m=x);a&&u.forEach(function(a){return b(e,a)});I&&tg(e,w);return l}function t(e,g,h,k){var l=Ka(h);if("function"!==typeof l)throw Error(p(150));h=l.call(h);if(null==h)throw Error(p(151));for(var u=l=null,m=g,w=g=0,x=null,n=h.next();null!==m&&!n.done;w++,n=h.next()){m.index>w?(x=m,m=null):x=m.sibling;var t=r(e,m,n.value,k);if(null===t){null===m&&(m=x);break}a&&m&&null===t.alternate&&b(e,m);g=f(t,g,w);null===u?l=t:u.sibling=t;u=t;m=x}if(n.done)return c(e,
m),I&&tg(e,w),l;if(null===m){for(;!n.done;w++,n=h.next())n=q(e,n.value,k),null!==n&&(g=f(n,g,w),null===u?l=n:u.sibling=n,u=n);I&&tg(e,w);return l}for(m=d(e,m);!n.done;w++,n=h.next())n=y(m,e,w,n.value,k),null!==n&&(a&&null!==n.alternate&&m.delete(null===n.key?w:n.key),g=f(n,g,w),null===u?l=n:u.sibling=n,u=n);a&&m.forEach(function(a){return b(e,a)});I&&tg(e,w);return l}function J(a,d,f,h){"object"===typeof f&&null!==f&&f.type===ya&&null===f.key&&(f=f.props.children);if("object"===typeof f&&null!==f){switch(f.$$typeof){case va:a:{for(var k=
f.key,l=d;null!==l;){if(l.key===k){k=f.type;if(k===ya){if(7===l.tag){c(a,l.sibling);d=e(l,f.props.children);d.return=a;a=d;break a}}else if(l.elementType===k||"object"===typeof k&&null!==k&&k.$$typeof===Ha&&uh(k)===l.type){c(a,l.sibling);d=e(l,f.props);d.ref=sh(a,l,f);d.return=a;a=d;break a}c(a,l);break}else b(a,l);l=l.sibling}f.type===ya?(d=Ah(f.props.children,a.mode,h,f.key),d.return=a,a=d):(h=yh(f.type,f.key,f.props,null,a.mode,h),h.ref=sh(a,d,f),h.return=a,a=h)}return g(a);case wa:a:{for(l=f.key;null!==
d;){if(d.key===l)if(4===d.tag&&d.stateNode.containerInfo===f.containerInfo&&d.stateNode.implementation===f.implementation){c(a,d.sibling);d=e(d,f.children||[]);d.return=a;a=d;break a}else{c(a,d);break}else b(a,d);d=d.sibling}d=zh(f,a.mode,h);d.return=a;a=d}return g(a);case Ha:return l=f._init,J(a,d,l(f._payload),h)}if(eb(f))return n(a,d,f,h);if(Ka(f))return t(a,d,f,h);th(a,f)}return"string"===typeof f&&""!==f||"number"===typeof f?(f=""+f,null!==d&&6===d.tag?(c(a,d.sibling),d=e(d,f),d.return=a,a=d):
(c(a,d),d=xh(f,a.mode,h),d.return=a,a=d),g(a)):c(a,d)}return J}var Bh=vh(!0),Ch=vh(!1),Dh={},Eh=Uf(Dh),Fh=Uf(Dh),Gh=Uf(Dh);function Hh(a){if(a===Dh)throw Error(p(174));return a}function Ih(a,b){G(Gh,b);G(Fh,a);G(Eh,Dh);a=b.nodeType;switch(a){case 9:case 11:b=(b=b.documentElement)?b.namespaceURI:lb(null,"");break;default:a=8===a?b.parentNode:b,b=a.namespaceURI||null,a=a.tagName,b=lb(b,a)}E(Eh);G(Eh,b)}function Jh(){E(Eh);E(Fh);E(Gh)}
function Kh(a){Hh(Gh.current);var b=Hh(Eh.current);var c=lb(b,a.type);b!==c&&(G(Fh,a),G(Eh,c))}function Lh(a){Fh.current===a&&(E(Eh),E(Fh))}var M=Uf(0);
function Mh(a){for(var b=a;null!==b;){if(13===b.tag){var c=b.memoizedState;if(null!==c&&(c=c.dehydrated,null===c||"$?"===c.data||"$!"===c.data))return b}else if(19===b.tag&&void 0!==b.memoizedProps.revealOrder){if(0!==(b.flags&128))return b}else if(null!==b.child){b.child.return=b;b=b.child;continue}if(b===a)break;for(;null===b.sibling;){if(null===b.return||b.return===a)return null;b=b.return}b.sibling.return=b.return;b=b.sibling}return null}var Nh=[];
function Oh(){for(var a=0;a<Nh.length;a++)Nh[a]._workInProgressVersionPrimary=null;Nh.length=0}var Ph=ua.ReactCurrentDispatcher,Qh=ua.ReactCurrentBatchConfig,Rh=0,N=null,O=null,P=null,Sh=!1,Th=!1,Uh=0,Vh=0;function Q(){throw Error(p(321));}function Wh(a,b){if(null===b)return!1;for(var c=0;c<b.length&&c<a.length;c++)if(!He(a[c],b[c]))return!1;return!0}
function Xh(a,b,c,d,e,f){Rh=f;N=b;b.memoizedState=null;b.updateQueue=null;b.lanes=0;Ph.current=null===a||null===a.memoizedState?Yh:Zh;a=c(d,e);if(Th){f=0;do{Th=!1;Uh=0;if(25<=f)throw Error(p(301));f+=1;P=O=null;b.updateQueue=null;Ph.current=$h;a=c(d,e)}while(Th)}Ph.current=ai;b=null!==O&&null!==O.next;Rh=0;P=O=N=null;Sh=!1;if(b)throw Error(p(300));return a}function bi(){var a=0!==Uh;Uh=0;return a}
function ci(){var a={memoizedState:null,baseState:null,baseQueue:null,queue:null,next:null};null===P?N.memoizedState=P=a:P=P.next=a;return P}function di(){if(null===O){var a=N.alternate;a=null!==a?a.memoizedState:null}else a=O.next;var b=null===P?N.memoizedState:P.next;if(null!==b)P=b,O=a;else{if(null===a)throw Error(p(310));O=a;a={memoizedState:O.memoizedState,baseState:O.baseState,baseQueue:O.baseQueue,queue:O.queue,next:null};null===P?N.memoizedState=P=a:P=P.next=a}return P}
function ei(a,b){return"function"===typeof b?b(a):b}
function fi(a){var b=di(),c=b.queue;if(null===c)throw Error(p(311));c.lastRenderedReducer=a;var d=O,e=d.baseQueue,f=c.pending;if(null!==f){if(null!==e){var g=e.next;e.next=f.next;f.next=g}d.baseQueue=e=f;c.pending=null}if(null!==e){f=e.next;d=d.baseState;var h=g=null,k=null,l=f;do{var m=l.lane;if((Rh&m)===m)null!==k&&(k=k.next={lane:0,action:l.action,hasEagerState:l.hasEagerState,eagerState:l.eagerState,next:null}),d=l.hasEagerState?l.eagerState:a(d,l.action);else{var q={lane:m,action:l.action,hasEagerState:l.hasEagerState,
eagerState:l.eagerState,next:null};null===k?(h=k=q,g=d):k=k.next=q;N.lanes|=m;hh|=m}l=l.next}while(null!==l&&l!==f);null===k?g=d:k.next=h;He(d,b.memoizedState)||(Ug=!0);b.memoizedState=d;b.baseState=g;b.baseQueue=k;c.lastRenderedState=d}a=c.interleaved;if(null!==a){e=a;do f=e.lane,N.lanes|=f,hh|=f,e=e.next;while(e!==a)}else null===e&&(c.lanes=0);return[b.memoizedState,c.dispatch]}
function gi(a){var b=di(),c=b.queue;if(null===c)throw Error(p(311));c.lastRenderedReducer=a;var d=c.dispatch,e=c.pending,f=b.memoizedState;if(null!==e){c.pending=null;var g=e=e.next;do f=a(f,g.action),g=g.next;while(g!==e);He(f,b.memoizedState)||(Ug=!0);b.memoizedState=f;null===b.baseQueue&&(b.baseState=f);c.lastRenderedState=f}return[f,d]}function hi(){}
function ii(a,b){var c=N,d=di(),e=b(),f=!He(d.memoizedState,e);f&&(d.memoizedState=e,Ug=!0);d=d.queue;ji(ki.bind(null,c,d,a),[a]);if(d.getSnapshot!==b||f||null!==P&&P.memoizedState.tag&1){c.flags|=2048;li(9,mi.bind(null,c,d,e,b),void 0,null);if(null===R)throw Error(p(349));0!==(Rh&30)||ni(c,b,e)}return e}function ni(a,b,c){a.flags|=16384;a={getSnapshot:b,value:c};b=N.updateQueue;null===b?(b={lastEffect:null,stores:null},N.updateQueue=b,b.stores=[a]):(c=b.stores,null===c?b.stores=[a]:c.push(a))}
function mi(a,b,c,d){b.value=c;b.getSnapshot=d;oi(b)&&pi(a)}function ki(a,b,c){return c(function(){oi(b)&&pi(a)})}function oi(a){var b=a.getSnapshot;a=a.value;try{var c=b();return!He(a,c)}catch(d){return!0}}function pi(a){var b=Zg(a,1);null!==b&&mh(b,a,1,-1)}
function qi(a){var b=ci();"function"===typeof a&&(a=a());b.memoizedState=b.baseState=a;a={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:ei,lastRenderedState:a};b.queue=a;a=a.dispatch=ri.bind(null,N,a);return[b.memoizedState,a]}
function li(a,b,c,d){a={tag:a,create:b,destroy:c,deps:d,next:null};b=N.updateQueue;null===b?(b={lastEffect:null,stores:null},N.updateQueue=b,b.lastEffect=a.next=a):(c=b.lastEffect,null===c?b.lastEffect=a.next=a:(d=c.next,c.next=a,a.next=d,b.lastEffect=a));return a}function si(){return di().memoizedState}function ti(a,b,c,d){var e=ci();N.flags|=a;e.memoizedState=li(1|b,c,void 0,void 0===d?null:d)}
function ui(a,b,c,d){var e=di();d=void 0===d?null:d;var f=void 0;if(null!==O){var g=O.memoizedState;f=g.destroy;if(null!==d&&Wh(d,g.deps)){e.memoizedState=li(b,c,f,d);return}}N.flags|=a;e.memoizedState=li(1|b,c,f,d)}function vi(a,b){return ti(8390656,8,a,b)}function ji(a,b){return ui(2048,8,a,b)}function wi(a,b){return ui(4,2,a,b)}function xi(a,b){return ui(4,4,a,b)}
function yi(a,b){if("function"===typeof b)return a=a(),b(a),function(){b(null)};if(null!==b&&void 0!==b)return a=a(),b.current=a,function(){b.current=null}}function zi(a,b,c){c=null!==c&&void 0!==c?c.concat([a]):null;return ui(4,4,yi.bind(null,b,a),c)}function Ai(){}function Bi(a,b){var c=di();b=void 0===b?null:b;var d=c.memoizedState;if(null!==d&&null!==b&&Wh(b,d[1]))return d[0];c.memoizedState=[a,b];return a}
function Ci(a,b){var c=di();b=void 0===b?null:b;var d=c.memoizedState;if(null!==d&&null!==b&&Wh(b,d[1]))return d[0];a=a();c.memoizedState=[a,b];return a}function Di(a,b,c){if(0===(Rh&21))return a.baseState&&(a.baseState=!1,Ug=!0),a.memoizedState=c;He(c,b)||(c=yc(),N.lanes|=c,hh|=c,a.baseState=!0);return b}function Ei(a,b){var c=C;C=0!==c&&4>c?c:4;a(!0);var d=Qh.transition;Qh.transition={};try{a(!1),b()}finally{C=c,Qh.transition=d}}function Fi(){return di().memoizedState}
function Gi(a,b,c){var d=lh(a);c={lane:d,action:c,hasEagerState:!1,eagerState:null,next:null};if(Hi(a))Ii(b,c);else if(c=Yg(a,b,c,d),null!==c){var e=L();mh(c,a,d,e);Ji(c,b,d)}}
function ri(a,b,c){var d=lh(a),e={lane:d,action:c,hasEagerState:!1,eagerState:null,next:null};if(Hi(a))Ii(b,e);else{var f=a.alternate;if(0===a.lanes&&(null===f||0===f.lanes)&&(f=b.lastRenderedReducer,null!==f))try{var g=b.lastRenderedState,h=f(g,c);e.hasEagerState=!0;e.eagerState=h;if(He(h,g)){var k=b.interleaved;null===k?(e.next=e,Xg(b)):(e.next=k.next,k.next=e);b.interleaved=e;return}}catch(l){}finally{}c=Yg(a,b,e,d);null!==c&&(e=L(),mh(c,a,d,e),Ji(c,b,d))}}
function Hi(a){var b=a.alternate;return a===N||null!==b&&b===N}function Ii(a,b){Th=Sh=!0;var c=a.pending;null===c?b.next=b:(b.next=c.next,c.next=b);a.pending=b}function Ji(a,b,c){if(0!==(c&4194240)){var d=b.lanes;d&=a.pendingLanes;c|=d;b.lanes=c;Cc(a,c)}}
var ai={readContext:Vg,useCallback:Q,useContext:Q,useEffect:Q,useImperativeHandle:Q,useInsertionEffect:Q,useLayoutEffect:Q,useMemo:Q,useReducer:Q,useRef:Q,useState:Q,useDebugValue:Q,useDeferredValue:Q,useTransition:Q,useMutableSource:Q,useSyncExternalStore:Q,useId:Q,unstable_isNewReconciler:!1},Yh={readContext:Vg,useCallback:function(a,b){ci().memoizedState=[a,void 0===b?null:b];return a},useContext:Vg,useEffect:vi,useImperativeHandle:function(a,b,c){c=null!==c&&void 0!==c?c.concat([a]):null;return ti(4194308,
4,yi.bind(null,b,a),c)},useLayoutEffect:function(a,b){return ti(4194308,4,a,b)},useInsertionEffect:function(a,b){return ti(4,2,a,b)},useMemo:function(a,b){var c=ci();b=void 0===b?null:b;a=a();c.memoizedState=[a,b];return a},useReducer:function(a,b,c){var d=ci();b=void 0!==c?c(b):b;d.memoizedState=d.baseState=b;a={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:a,lastRenderedState:b};d.queue=a;a=a.dispatch=Gi.bind(null,N,a);return[d.memoizedState,a]},useRef:function(a){var b=
ci();a={current:a};return b.memoizedState=a},useState:qi,useDebugValue:Ai,useDeferredValue:function(a){return ci().memoizedState=a},useTransition:function(){var a=qi(!1),b=a[0];a=Ei.bind(null,a[1]);ci().memoizedState=a;return[b,a]},useMutableSource:function(){},useSyncExternalStore:function(a,b,c){var d=N,e=ci();if(I){if(void 0===c)throw Error(p(407));c=c()}else{c=b();if(null===R)throw Error(p(349));0!==(Rh&30)||ni(d,b,c)}e.memoizedState=c;var f={value:c,getSnapshot:b};e.queue=f;vi(ki.bind(null,d,
f,a),[a]);d.flags|=2048;li(9,mi.bind(null,d,f,c,b),void 0,null);return c},useId:function(){var a=ci(),b=R.identifierPrefix;if(I){var c=sg;var d=rg;c=(d&~(1<<32-oc(d)-1)).toString(32)+c;b=":"+b+"R"+c;c=Uh++;0<c&&(b+="H"+c.toString(32));b+=":"}else c=Vh++,b=":"+b+"r"+c.toString(32)+":";return a.memoizedState=b},unstable_isNewReconciler:!1},Zh={readContext:Vg,useCallback:Bi,useContext:Vg,useEffect:ji,useImperativeHandle:zi,useInsertionEffect:wi,useLayoutEffect:xi,useMemo:Ci,useReducer:fi,useRef:si,useState:function(){return fi(ei)},
useDebugValue:Ai,useDeferredValue:function(a){var b=di();return Di(b,O.memoizedState,a)},useTransition:function(){var a=fi(ei)[0],b=di().memoizedState;return[a,b]},useMutableSource:hi,useSyncExternalStore:ii,useId:Fi,unstable_isNewReconciler:!1},$h={readContext:Vg,useCallback:Bi,useContext:Vg,useEffect:ji,useImperativeHandle:zi,useInsertionEffect:wi,useLayoutEffect:xi,useMemo:Ci,useReducer:gi,useRef:si,useState:function(){return gi(ei)},useDebugValue:Ai,useDeferredValue:function(a){var b=di();return null===
O?b.memoizedState=a:Di(b,O.memoizedState,a)},useTransition:function(){var a=gi(ei)[0],b=di().memoizedState;return[a,b]},useMutableSource:hi,useSyncExternalStore:ii,useId:Fi,unstable_isNewReconciler:!1};function Ki(a,b){try{var c="",d=b;do c+=Pa(d),d=d.return;while(d);var e=c}catch(f){e="\nError generating stack: "+f.message+"\n"+f.stack}return{value:a,source:b,stack:e,digest:null}}function Li(a,b,c){return{value:a,source:null,stack:null!=c?c:null,digest:null!=b?b:null}}
function Mi(a,b){try{console.error(b.value)}catch(c){setTimeout(function(){throw c;})}}var Ni="function"===typeof WeakMap?WeakMap:Map;function Oi(a,b,c){c=ch(-1,c);c.tag=3;c.payload={element:null};var d=b.value;c.callback=function(){Pi||(Pi=!0,Qi=d);Mi(a,b)};return c}
function Ri(a,b,c){c=ch(-1,c);c.tag=3;var d=a.type.getDerivedStateFromError;if("function"===typeof d){var e=b.value;c.payload=function(){return d(e)};c.callback=function(){Mi(a,b)}}var f=a.stateNode;null!==f&&"function"===typeof f.componentDidCatch&&(c.callback=function(){Mi(a,b);"function"!==typeof d&&(null===Si?Si=new Set([this]):Si.add(this));var c=b.stack;this.componentDidCatch(b.value,{componentStack:null!==c?c:""})});return c}
function Ti(a,b,c){var d=a.pingCache;if(null===d){d=a.pingCache=new Ni;var e=new Set;d.set(b,e)}else e=d.get(b),void 0===e&&(e=new Set,d.set(b,e));e.has(c)||(e.add(c),a=Ui.bind(null,a,b,c),b.then(a,a))}function Vi(a){do{var b;if(b=13===a.tag)b=a.memoizedState,b=null!==b?null!==b.dehydrated?!0:!1:!0;if(b)return a;a=a.return}while(null!==a);return null}
function Wi(a,b,c,d,e){if(0===(a.mode&1))return a===b?a.flags|=65536:(a.flags|=128,c.flags|=131072,c.flags&=-52805,1===c.tag&&(null===c.alternate?c.tag=17:(b=ch(-1,1),b.tag=2,dh(c,b,1))),c.lanes|=1),a;a.flags|=65536;a.lanes=e;return a}var Xi=ua.ReactCurrentOwner,Ug=!1;function Yi(a,b,c,d){b.child=null===a?Ch(b,null,c,d):Bh(b,a.child,c,d)}
function Zi(a,b,c,d,e){c=c.render;var f=b.ref;Tg(b,e);d=Xh(a,b,c,d,f,e);c=bi();if(null!==a&&!Ug)return b.updateQueue=a.updateQueue,b.flags&=-2053,a.lanes&=~e,$i(a,b,e);I&&c&&vg(b);b.flags|=1;Yi(a,b,d,e);return b.child}
function aj(a,b,c,d,e){if(null===a){var f=c.type;if("function"===typeof f&&!bj(f)&&void 0===f.defaultProps&&null===c.compare&&void 0===c.defaultProps)return b.tag=15,b.type=f,cj(a,b,f,d,e);a=yh(c.type,null,d,b,b.mode,e);a.ref=b.ref;a.return=b;return b.child=a}f=a.child;if(0===(a.lanes&e)){var g=f.memoizedProps;c=c.compare;c=null!==c?c:Ie;if(c(g,d)&&a.ref===b.ref)return $i(a,b,e)}b.flags|=1;a=wh(f,d);a.ref=b.ref;a.return=b;return b.child=a}
function cj(a,b,c,d,e){if(null!==a){var f=a.memoizedProps;if(Ie(f,d)&&a.ref===b.ref)if(Ug=!1,b.pendingProps=d=f,0!==(a.lanes&e))0!==(a.flags&131072)&&(Ug=!0);else return b.lanes=a.lanes,$i(a,b,e)}return dj(a,b,c,d,e)}
function ej(a,b,c){var d=b.pendingProps,e=d.children,f=null!==a?a.memoizedState:null;if("hidden"===d.mode)if(0===(b.mode&1))b.memoizedState={baseLanes:0,cachePool:null,transitions:null},G(fj,gj),gj|=c;else{if(0===(c&1073741824))return a=null!==f?f.baseLanes|c:c,b.lanes=b.childLanes=1073741824,b.memoizedState={baseLanes:a,cachePool:null,transitions:null},b.updateQueue=null,G(fj,gj),gj|=a,null;b.memoizedState={baseLanes:0,cachePool:null,transitions:null};d=null!==f?f.baseLanes:c;G(fj,gj);gj|=d}else null!==
f?(d=f.baseLanes|c,b.memoizedState=null):d=c,G(fj,gj),gj|=d;Yi(a,b,e,c);return b.child}function hj(a,b){var c=b.ref;if(null===a&&null!==c||null!==a&&a.ref!==c)b.flags|=512,b.flags|=2097152}function dj(a,b,c,d,e){var f=Zf(c)?Xf:H.current;f=Yf(b,f);Tg(b,e);c=Xh(a,b,c,d,f,e);d=bi();if(null!==a&&!Ug)return b.updateQueue=a.updateQueue,b.flags&=-2053,a.lanes&=~e,$i(a,b,e);I&&d&&vg(b);b.flags|=1;Yi(a,b,c,e);return b.child}
function ij(a,b,c,d,e){if(Zf(c)){var f=!0;cg(b)}else f=!1;Tg(b,e);if(null===b.stateNode)jj(a,b),ph(b,c,d),rh(b,c,d,e),d=!0;else if(null===a){var g=b.stateNode,h=b.memoizedProps;g.props=h;var k=g.context,l=c.contextType;"object"===typeof l&&null!==l?l=Vg(l):(l=Zf(c)?Xf:H.current,l=Yf(b,l));var m=c.getDerivedStateFromProps,q="function"===typeof m||"function"===typeof g.getSnapshotBeforeUpdate;q||"function"!==typeof g.UNSAFE_componentWillReceiveProps&&"function"!==typeof g.componentWillReceiveProps||
(h!==d||k!==l)&&qh(b,g,d,l);$g=!1;var r=b.memoizedState;g.state=r;gh(b,d,g,e);k=b.memoizedState;h!==d||r!==k||Wf.current||$g?("function"===typeof m&&(kh(b,c,m,d),k=b.memoizedState),(h=$g||oh(b,c,h,d,r,k,l))?(q||"function"!==typeof g.UNSAFE_componentWillMount&&"function"!==typeof g.componentWillMount||("function"===typeof g.componentWillMount&&g.componentWillMount(),"function"===typeof g.UNSAFE_componentWillMount&&g.UNSAFE_componentWillMount()),"function"===typeof g.componentDidMount&&(b.flags|=4194308)):
("function"===typeof g.componentDidMount&&(b.flags|=4194308),b.memoizedProps=d,b.memoizedState=k),g.props=d,g.state=k,g.context=l,d=h):("function"===typeof g.componentDidMount&&(b.flags|=4194308),d=!1)}else{g=b.stateNode;bh(a,b);h=b.memoizedProps;l=b.type===b.elementType?h:Lg(b.type,h);g.props=l;q=b.pendingProps;r=g.context;k=c.contextType;"object"===typeof k&&null!==k?k=Vg(k):(k=Zf(c)?Xf:H.current,k=Yf(b,k));var y=c.getDerivedStateFromProps;(m="function"===typeof y||"function"===typeof g.getSnapshotBeforeUpdate)||
"function"!==typeof g.UNSAFE_componentWillReceiveProps&&"function"!==typeof g.componentWillReceiveProps||(h!==q||r!==k)&&qh(b,g,d,k);$g=!1;r=b.memoizedState;g.state=r;gh(b,d,g,e);var n=b.memoizedState;h!==q||r!==n||Wf.current||$g?("function"===typeof y&&(kh(b,c,y,d),n=b.memoizedState),(l=$g||oh(b,c,l,d,r,n,k)||!1)?(m||"function"!==typeof g.UNSAFE_componentWillUpdate&&"function"!==typeof g.componentWillUpdate||("function"===typeof g.componentWillUpdate&&g.componentWillUpdate(d,n,k),"function"===typeof g.UNSAFE_componentWillUpdate&&
g.UNSAFE_componentWillUpdate(d,n,k)),"function"===typeof g.componentDidUpdate&&(b.flags|=4),"function"===typeof g.getSnapshotBeforeUpdate&&(b.flags|=1024)):("function"!==typeof g.componentDidUpdate||h===a.memoizedProps&&r===a.memoizedState||(b.flags|=4),"function"!==typeof g.getSnapshotBeforeUpdate||h===a.memoizedProps&&r===a.memoizedState||(b.flags|=1024),b.memoizedProps=d,b.memoizedState=n),g.props=d,g.state=n,g.context=k,d=l):("function"!==typeof g.componentDidUpdate||h===a.memoizedProps&&r===
a.memoizedState||(b.flags|=4),"function"!==typeof g.getSnapshotBeforeUpdate||h===a.memoizedProps&&r===a.memoizedState||(b.flags|=1024),d=!1)}return kj(a,b,c,d,f,e)}
function kj(a,b,c,d,e,f){hj(a,b);var g=0!==(b.flags&128);if(!d&&!g)return e&&dg(b,c,!1),$i(a,b,f);d=b.stateNode;Xi.current=b;var h=g&&"function"!==typeof c.getDerivedStateFromError?null:d.render();b.flags|=1;null!==a&&g?(b.child=Bh(b,a.child,null,f),b.child=Bh(b,null,h,f)):Yi(a,b,h,f);b.memoizedState=d.state;e&&dg(b,c,!0);return b.child}function lj(a){var b=a.stateNode;b.pendingContext?ag(a,b.pendingContext,b.pendingContext!==b.context):b.context&&ag(a,b.context,!1);Ih(a,b.containerInfo)}
function mj(a,b,c,d,e){Ig();Jg(e);b.flags|=256;Yi(a,b,c,d);return b.child}var nj={dehydrated:null,treeContext:null,retryLane:0};function oj(a){return{baseLanes:a,cachePool:null,transitions:null}}
function pj(a,b,c){var d=b.pendingProps,e=M.current,f=!1,g=0!==(b.flags&128),h;(h=g)||(h=null!==a&&null===a.memoizedState?!1:0!==(e&2));if(h)f=!0,b.flags&=-129;else if(null===a||null!==a.memoizedState)e|=1;G(M,e&1);if(null===a){Eg(b);a=b.memoizedState;if(null!==a&&(a=a.dehydrated,null!==a))return 0===(b.mode&1)?b.lanes=1:"$!"===a.data?b.lanes=8:b.lanes=1073741824,null;g=d.children;a=d.fallback;return f?(d=b.mode,f=b.child,g={mode:"hidden",children:g},0===(d&1)&&null!==f?(f.childLanes=0,f.pendingProps=
g):f=qj(g,d,0,null),a=Ah(a,d,c,null),f.return=b,a.return=b,f.sibling=a,b.child=f,b.child.memoizedState=oj(c),b.memoizedState=nj,a):rj(b,g)}e=a.memoizedState;if(null!==e&&(h=e.dehydrated,null!==h))return sj(a,b,g,d,h,e,c);if(f){f=d.fallback;g=b.mode;e=a.child;h=e.sibling;var k={mode:"hidden",children:d.children};0===(g&1)&&b.child!==e?(d=b.child,d.childLanes=0,d.pendingProps=k,b.deletions=null):(d=wh(e,k),d.subtreeFlags=e.subtreeFlags&14680064);null!==h?f=wh(h,f):(f=Ah(f,g,c,null),f.flags|=2);f.return=
b;d.return=b;d.sibling=f;b.child=d;d=f;f=b.child;g=a.child.memoizedState;g=null===g?oj(c):{baseLanes:g.baseLanes|c,cachePool:null,transitions:g.transitions};f.memoizedState=g;f.childLanes=a.childLanes&~c;b.memoizedState=nj;return d}f=a.child;a=f.sibling;d=wh(f,{mode:"visible",children:d.children});0===(b.mode&1)&&(d.lanes=c);d.return=b;d.sibling=null;null!==a&&(c=b.deletions,null===c?(b.deletions=[a],b.flags|=16):c.push(a));b.child=d;b.memoizedState=null;return d}
function rj(a,b){b=qj({mode:"visible",children:b},a.mode,0,null);b.return=a;return a.child=b}function tj(a,b,c,d){null!==d&&Jg(d);Bh(b,a.child,null,c);a=rj(b,b.pendingProps.children);a.flags|=2;b.memoizedState=null;return a}
function sj(a,b,c,d,e,f,g){if(c){if(b.flags&256)return b.flags&=-257,d=Li(Error(p(422))),tj(a,b,g,d);if(null!==b.memoizedState)return b.child=a.child,b.flags|=128,null;f=d.fallback;e=b.mode;d=qj({mode:"visible",children:d.children},e,0,null);f=Ah(f,e,g,null);f.flags|=2;d.return=b;f.return=b;d.sibling=f;b.child=d;0!==(b.mode&1)&&Bh(b,a.child,null,g);b.child.memoizedState=oj(g);b.memoizedState=nj;return f}if(0===(b.mode&1))return tj(a,b,g,null);if("$!"===e.data){d=e.nextSibling&&e.nextSibling.dataset;
if(d)var h=d.dgst;d=h;f=Error(p(419));d=Li(f,d,void 0);return tj(a,b,g,d)}h=0!==(g&a.childLanes);if(Ug||h){d=R;if(null!==d){switch(g&-g){case 4:e=2;break;case 16:e=8;break;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:e=32;break;case 536870912:e=268435456;break;default:e=0}e=0!==(e&(d.suspendedLanes|g))?0:e;
0!==e&&e!==f.retryLane&&(f.retryLane=e,Zg(a,e),mh(d,a,e,-1))}uj();d=Li(Error(p(421)));return tj(a,b,g,d)}if("$?"===e.data)return b.flags|=128,b.child=a.child,b=vj.bind(null,a),e._reactRetry=b,null;a=f.treeContext;yg=Lf(e.nextSibling);xg=b;I=!0;zg=null;null!==a&&(og[pg++]=rg,og[pg++]=sg,og[pg++]=qg,rg=a.id,sg=a.overflow,qg=b);b=rj(b,d.children);b.flags|=4096;return b}function wj(a,b,c){a.lanes|=b;var d=a.alternate;null!==d&&(d.lanes|=b);Sg(a.return,b,c)}
function xj(a,b,c,d,e){var f=a.memoizedState;null===f?a.memoizedState={isBackwards:b,rendering:null,renderingStartTime:0,last:d,tail:c,tailMode:e}:(f.isBackwards=b,f.rendering=null,f.renderingStartTime=0,f.last=d,f.tail=c,f.tailMode=e)}
function yj(a,b,c){var d=b.pendingProps,e=d.revealOrder,f=d.tail;Yi(a,b,d.children,c);d=M.current;if(0!==(d&2))d=d&1|2,b.flags|=128;else{if(null!==a&&0!==(a.flags&128))a:for(a=b.child;null!==a;){if(13===a.tag)null!==a.memoizedState&&wj(a,c,b);else if(19===a.tag)wj(a,c,b);else if(null!==a.child){a.child.return=a;a=a.child;continue}if(a===b)break a;for(;null===a.sibling;){if(null===a.return||a.return===b)break a;a=a.return}a.sibling.return=a.return;a=a.sibling}d&=1}G(M,d);if(0===(b.mode&1))b.memoizedState=
null;else switch(e){case "forwards":c=b.child;for(e=null;null!==c;)a=c.alternate,null!==a&&null===Mh(a)&&(e=c),c=c.sibling;c=e;null===c?(e=b.child,b.child=null):(e=c.sibling,c.sibling=null);xj(b,!1,e,c,f);break;case "backwards":c=null;e=b.child;for(b.child=null;null!==e;){a=e.alternate;if(null!==a&&null===Mh(a)){b.child=e;break}a=e.sibling;e.sibling=c;c=e;e=a}xj(b,!0,c,null,f);break;case "together":xj(b,!1,null,null,void 0);break;default:b.memoizedState=null}return b.child}
function jj(a,b){0===(b.mode&1)&&null!==a&&(a.alternate=null,b.alternate=null,b.flags|=2)}function $i(a,b,c){null!==a&&(b.dependencies=a.dependencies);hh|=b.lanes;if(0===(c&b.childLanes))return null;if(null!==a&&b.child!==a.child)throw Error(p(153));if(null!==b.child){a=b.child;c=wh(a,a.pendingProps);b.child=c;for(c.return=b;null!==a.sibling;)a=a.sibling,c=c.sibling=wh(a,a.pendingProps),c.return=b;c.sibling=null}return b.child}
function zj(a,b,c){switch(b.tag){case 3:lj(b);Ig();break;case 5:Kh(b);break;case 1:Zf(b.type)&&cg(b);break;case 4:Ih(b,b.stateNode.containerInfo);break;case 10:var d=b.type._context,e=b.memoizedProps.value;G(Mg,d._currentValue);d._currentValue=e;break;case 13:d=b.memoizedState;if(null!==d){if(null!==d.dehydrated)return G(M,M.current&1),b.flags|=128,null;if(0!==(c&b.child.childLanes))return pj(a,b,c);G(M,M.current&1);a=$i(a,b,c);return null!==a?a.sibling:null}G(M,M.current&1);break;case 19:d=0!==(c&
b.childLanes);if(0!==(a.flags&128)){if(d)return yj(a,b,c);b.flags|=128}e=b.memoizedState;null!==e&&(e.rendering=null,e.tail=null,e.lastEffect=null);G(M,M.current);if(d)break;else return null;case 22:case 23:return b.lanes=0,ej(a,b,c)}return $i(a,b,c)}var Aj,Bj,Cj,Dj;
Aj=function(a,b){for(var c=b.child;null!==c;){if(5===c.tag||6===c.tag)a.appendChild(c.stateNode);else if(4!==c.tag&&null!==c.child){c.child.return=c;c=c.child;continue}if(c===b)break;for(;null===c.sibling;){if(null===c.return||c.return===b)return;c=c.return}c.sibling.return=c.return;c=c.sibling}};Bj=function(){};
Cj=function(a,b,c,d){var e=a.memoizedProps;if(e!==d){a=b.stateNode;Hh(Eh.current);var f=null;switch(c){case "input":e=Ya(a,e);d=Ya(a,d);f=[];break;case "select":e=A({},e,{value:void 0});d=A({},d,{value:void 0});f=[];break;case "textarea":e=gb(a,e);d=gb(a,d);f=[];break;default:"function"!==typeof e.onClick&&"function"===typeof d.onClick&&(a.onclick=Bf)}ub(c,d);var g;c=null;for(l in e)if(!d.hasOwnProperty(l)&&e.hasOwnProperty(l)&&null!=e[l])if("style"===l){var h=e[l];for(g in h)h.hasOwnProperty(g)&&
(c||(c={}),c[g]="")}else"dangerouslySetInnerHTML"!==l&&"children"!==l&&"suppressContentEditableWarning"!==l&&"suppressHydrationWarning"!==l&&"autoFocus"!==l&&(ea.hasOwnProperty(l)?f||(f=[]):(f=f||[]).push(l,null));for(l in d){var k=d[l];h=null!=e?e[l]:void 0;if(d.hasOwnProperty(l)&&k!==h&&(null!=k||null!=h))if("style"===l)if(h){for(g in h)!h.hasOwnProperty(g)||k&&k.hasOwnProperty(g)||(c||(c={}),c[g]="");for(g in k)k.hasOwnProperty(g)&&h[g]!==k[g]&&(c||(c={}),c[g]=k[g])}else c||(f||(f=[]),f.push(l,
c)),c=k;else"dangerouslySetInnerHTML"===l?(k=k?k.__html:void 0,h=h?h.__html:void 0,null!=k&&h!==k&&(f=f||[]).push(l,k)):"children"===l?"string"!==typeof k&&"number"!==typeof k||(f=f||[]).push(l,""+k):"suppressContentEditableWarning"!==l&&"suppressHydrationWarning"!==l&&(ea.hasOwnProperty(l)?(null!=k&&"onScroll"===l&&D("scroll",a),f||h===k||(f=[])):(f=f||[]).push(l,k))}c&&(f=f||[]).push("style",c);var l=f;if(b.updateQueue=l)b.flags|=4}};Dj=function(a,b,c,d){c!==d&&(b.flags|=4)};
function Ej(a,b){if(!I)switch(a.tailMode){case "hidden":b=a.tail;for(var c=null;null!==b;)null!==b.alternate&&(c=b),b=b.sibling;null===c?a.tail=null:c.sibling=null;break;case "collapsed":c=a.tail;for(var d=null;null!==c;)null!==c.alternate&&(d=c),c=c.sibling;null===d?b||null===a.tail?a.tail=null:a.tail.sibling=null:d.sibling=null}}
function S(a){var b=null!==a.alternate&&a.alternate.child===a.child,c=0,d=0;if(b)for(var e=a.child;null!==e;)c|=e.lanes|e.childLanes,d|=e.subtreeFlags&14680064,d|=e.flags&14680064,e.return=a,e=e.sibling;else for(e=a.child;null!==e;)c|=e.lanes|e.childLanes,d|=e.subtreeFlags,d|=e.flags,e.return=a,e=e.sibling;a.subtreeFlags|=d;a.childLanes=c;return b}
function Fj(a,b,c){var d=b.pendingProps;wg(b);switch(b.tag){case 2:case 16:case 15:case 0:case 11:case 7:case 8:case 12:case 9:case 14:return S(b),null;case 1:return Zf(b.type)&&$f(),S(b),null;case 3:d=b.stateNode;Jh();E(Wf);E(H);Oh();d.pendingContext&&(d.context=d.pendingContext,d.pendingContext=null);if(null===a||null===a.child)Gg(b)?b.flags|=4:null===a||a.memoizedState.isDehydrated&&0===(b.flags&256)||(b.flags|=1024,null!==zg&&(Gj(zg),zg=null));Bj(a,b);S(b);return null;case 5:Lh(b);var e=Hh(Gh.current);
c=b.type;if(null!==a&&null!=b.stateNode)Cj(a,b,c,d,e),a.ref!==b.ref&&(b.flags|=512,b.flags|=2097152);else{if(!d){if(null===b.stateNode)throw Error(p(166));S(b);return null}a=Hh(Eh.current);if(Gg(b)){d=b.stateNode;c=b.type;var f=b.memoizedProps;d[Of]=b;d[Pf]=f;a=0!==(b.mode&1);switch(c){case "dialog":D("cancel",d);D("close",d);break;case "iframe":case "object":case "embed":D("load",d);break;case "video":case "audio":for(e=0;e<lf.length;e++)D(lf[e],d);break;case "source":D("error",d);break;case "img":case "image":case "link":D("error",
d);D("load",d);break;case "details":D("toggle",d);break;case "input":Za(d,f);D("invalid",d);break;case "select":d._wrapperState={wasMultiple:!!f.multiple};D("invalid",d);break;case "textarea":hb(d,f),D("invalid",d)}ub(c,f);e=null;for(var g in f)if(f.hasOwnProperty(g)){var h=f[g];"children"===g?"string"===typeof h?d.textContent!==h&&(!0!==f.suppressHydrationWarning&&Af(d.textContent,h,a),e=["children",h]):"number"===typeof h&&d.textContent!==""+h&&(!0!==f.suppressHydrationWarning&&Af(d.textContent,
h,a),e=["children",""+h]):ea.hasOwnProperty(g)&&null!=h&&"onScroll"===g&&D("scroll",d)}switch(c){case "input":Va(d);db(d,f,!0);break;case "textarea":Va(d);jb(d);break;case "select":case "option":break;default:"function"===typeof f.onClick&&(d.onclick=Bf)}d=e;b.updateQueue=d;null!==d&&(b.flags|=4)}else{g=9===e.nodeType?e:e.ownerDocument;"http://www.w3.org/1999/xhtml"===a&&(a=kb(c));"http://www.w3.org/1999/xhtml"===a?"script"===c?(a=g.createElement("div"),a.innerHTML="<script>\x3c/script>",a=a.removeChild(a.firstChild)):
"string"===typeof d.is?a=g.createElement(c,{is:d.is}):(a=g.createElement(c),"select"===c&&(g=a,d.multiple?g.multiple=!0:d.size&&(g.size=d.size))):a=g.createElementNS(a,c);a[Of]=b;a[Pf]=d;Aj(a,b,!1,!1);b.stateNode=a;a:{g=vb(c,d);switch(c){case "dialog":D("cancel",a);D("close",a);e=d;break;case "iframe":case "object":case "embed":D("load",a);e=d;break;case "video":case "audio":for(e=0;e<lf.length;e++)D(lf[e],a);e=d;break;case "source":D("error",a);e=d;break;case "img":case "image":case "link":D("error",
a);D("load",a);e=d;break;case "details":D("toggle",a);e=d;break;case "input":Za(a,d);e=Ya(a,d);D("invalid",a);break;case "option":e=d;break;case "select":a._wrapperState={wasMultiple:!!d.multiple};e=A({},d,{value:void 0});D("invalid",a);break;case "textarea":hb(a,d);e=gb(a,d);D("invalid",a);break;default:e=d}ub(c,e);h=e;for(f in h)if(h.hasOwnProperty(f)){var k=h[f];"style"===f?sb(a,k):"dangerouslySetInnerHTML"===f?(k=k?k.__html:void 0,null!=k&&nb(a,k)):"children"===f?"string"===typeof k?("textarea"!==
c||""!==k)&&ob(a,k):"number"===typeof k&&ob(a,""+k):"suppressContentEditableWarning"!==f&&"suppressHydrationWarning"!==f&&"autoFocus"!==f&&(ea.hasOwnProperty(f)?null!=k&&"onScroll"===f&&D("scroll",a):null!=k&&ta(a,f,k,g))}switch(c){case "input":Va(a);db(a,d,!1);break;case "textarea":Va(a);jb(a);break;case "option":null!=d.value&&a.setAttribute("value",""+Sa(d.value));break;case "select":a.multiple=!!d.multiple;f=d.value;null!=f?fb(a,!!d.multiple,f,!1):null!=d.defaultValue&&fb(a,!!d.multiple,d.defaultValue,
!0);break;default:"function"===typeof e.onClick&&(a.onclick=Bf)}switch(c){case "button":case "input":case "select":case "textarea":d=!!d.autoFocus;break a;case "img":d=!0;break a;default:d=!1}}d&&(b.flags|=4)}null!==b.ref&&(b.flags|=512,b.flags|=2097152)}S(b);return null;case 6:if(a&&null!=b.stateNode)Dj(a,b,a.memoizedProps,d);else{if("string"!==typeof d&&null===b.stateNode)throw Error(p(166));c=Hh(Gh.current);Hh(Eh.current);if(Gg(b)){d=b.stateNode;c=b.memoizedProps;d[Of]=b;if(f=d.nodeValue!==c)if(a=
xg,null!==a)switch(a.tag){case 3:Af(d.nodeValue,c,0!==(a.mode&1));break;case 5:!0!==a.memoizedProps.suppressHydrationWarning&&Af(d.nodeValue,c,0!==(a.mode&1))}f&&(b.flags|=4)}else d=(9===c.nodeType?c:c.ownerDocument).createTextNode(d),d[Of]=b,b.stateNode=d}S(b);return null;case 13:E(M);d=b.memoizedState;if(null===a||null!==a.memoizedState&&null!==a.memoizedState.dehydrated){if(I&&null!==yg&&0!==(b.mode&1)&&0===(b.flags&128))Hg(),Ig(),b.flags|=98560,f=!1;else if(f=Gg(b),null!==d&&null!==d.dehydrated){if(null===
a){if(!f)throw Error(p(318));f=b.memoizedState;f=null!==f?f.dehydrated:null;if(!f)throw Error(p(317));f[Of]=b}else Ig(),0===(b.flags&128)&&(b.memoizedState=null),b.flags|=4;S(b);f=!1}else null!==zg&&(Gj(zg),zg=null),f=!0;if(!f)return b.flags&65536?b:null}if(0!==(b.flags&128))return b.lanes=c,b;d=null!==d;d!==(null!==a&&null!==a.memoizedState)&&d&&(b.child.flags|=8192,0!==(b.mode&1)&&(null===a||0!==(M.current&1)?0===T&&(T=3):uj()));null!==b.updateQueue&&(b.flags|=4);S(b);return null;case 4:return Jh(),
Bj(a,b),null===a&&sf(b.stateNode.containerInfo),S(b),null;case 10:return Rg(b.type._context),S(b),null;case 17:return Zf(b.type)&&$f(),S(b),null;case 19:E(M);f=b.memoizedState;if(null===f)return S(b),null;d=0!==(b.flags&128);g=f.rendering;if(null===g)if(d)Ej(f,!1);else{if(0!==T||null!==a&&0!==(a.flags&128))for(a=b.child;null!==a;){g=Mh(a);if(null!==g){b.flags|=128;Ej(f,!1);d=g.updateQueue;null!==d&&(b.updateQueue=d,b.flags|=4);b.subtreeFlags=0;d=c;for(c=b.child;null!==c;)f=c,a=d,f.flags&=14680066,
g=f.alternate,null===g?(f.childLanes=0,f.lanes=a,f.child=null,f.subtreeFlags=0,f.memoizedProps=null,f.memoizedState=null,f.updateQueue=null,f.dependencies=null,f.stateNode=null):(f.childLanes=g.childLanes,f.lanes=g.lanes,f.child=g.child,f.subtreeFlags=0,f.deletions=null,f.memoizedProps=g.memoizedProps,f.memoizedState=g.memoizedState,f.updateQueue=g.updateQueue,f.type=g.type,a=g.dependencies,f.dependencies=null===a?null:{lanes:a.lanes,firstContext:a.firstContext}),c=c.sibling;G(M,M.current&1|2);return b.child}a=
a.sibling}null!==f.tail&&B()>Hj&&(b.flags|=128,d=!0,Ej(f,!1),b.lanes=4194304)}else{if(!d)if(a=Mh(g),null!==a){if(b.flags|=128,d=!0,c=a.updateQueue,null!==c&&(b.updateQueue=c,b.flags|=4),Ej(f,!0),null===f.tail&&"hidden"===f.tailMode&&!g.alternate&&!I)return S(b),null}else 2*B()-f.renderingStartTime>Hj&&1073741824!==c&&(b.flags|=128,d=!0,Ej(f,!1),b.lanes=4194304);f.isBackwards?(g.sibling=b.child,b.child=g):(c=f.last,null!==c?c.sibling=g:b.child=g,f.last=g)}if(null!==f.tail)return b=f.tail,f.rendering=
b,f.tail=b.sibling,f.renderingStartTime=B(),b.sibling=null,c=M.current,G(M,d?c&1|2:c&1),b;S(b);return null;case 22:case 23:return Ij(),d=null!==b.memoizedState,null!==a&&null!==a.memoizedState!==d&&(b.flags|=8192),d&&0!==(b.mode&1)?0!==(gj&1073741824)&&(S(b),b.subtreeFlags&6&&(b.flags|=8192)):S(b),null;case 24:return null;case 25:return null}throw Error(p(156,b.tag));}
function Jj(a,b){wg(b);switch(b.tag){case 1:return Zf(b.type)&&$f(),a=b.flags,a&65536?(b.flags=a&-65537|128,b):null;case 3:return Jh(),E(Wf),E(H),Oh(),a=b.flags,0!==(a&65536)&&0===(a&128)?(b.flags=a&-65537|128,b):null;case 5:return Lh(b),null;case 13:E(M);a=b.memoizedState;if(null!==a&&null!==a.dehydrated){if(null===b.alternate)throw Error(p(340));Ig()}a=b.flags;return a&65536?(b.flags=a&-65537|128,b):null;case 19:return E(M),null;case 4:return Jh(),null;case 10:return Rg(b.type._context),null;case 22:case 23:return Ij(),
null;case 24:return null;default:return null}}var Kj=!1,U=!1,Lj="function"===typeof WeakSet?WeakSet:Set,V=null;function Mj(a,b){var c=a.ref;if(null!==c)if("function"===typeof c)try{c(null)}catch(d){W(a,b,d)}else c.current=null}function Nj(a,b,c){try{c()}catch(d){W(a,b,d)}}var Oj=!1;
function Pj(a,b){Cf=dd;a=Me();if(Ne(a)){if("selectionStart"in a)var c={start:a.selectionStart,end:a.selectionEnd};else a:{c=(c=a.ownerDocument)&&c.defaultView||window;var d=c.getSelection&&c.getSelection();if(d&&0!==d.rangeCount){c=d.anchorNode;var e=d.anchorOffset,f=d.focusNode;d=d.focusOffset;try{c.nodeType,f.nodeType}catch(F){c=null;break a}var g=0,h=-1,k=-1,l=0,m=0,q=a,r=null;b:for(;;){for(var y;;){q!==c||0!==e&&3!==q.nodeType||(h=g+e);q!==f||0!==d&&3!==q.nodeType||(k=g+d);3===q.nodeType&&(g+=
q.nodeValue.length);if(null===(y=q.firstChild))break;r=q;q=y}for(;;){if(q===a)break b;r===c&&++l===e&&(h=g);r===f&&++m===d&&(k=g);if(null!==(y=q.nextSibling))break;q=r;r=q.parentNode}q=y}c=-1===h||-1===k?null:{start:h,end:k}}else c=null}c=c||{start:0,end:0}}else c=null;Df={focusedElem:a,selectionRange:c};dd=!1;for(V=b;null!==V;)if(b=V,a=b.child,0!==(b.subtreeFlags&1028)&&null!==a)a.return=b,V=a;else for(;null!==V;){b=V;try{var n=b.alternate;if(0!==(b.flags&1024))switch(b.tag){case 0:case 11:case 15:break;
case 1:if(null!==n){var t=n.memoizedProps,J=n.memoizedState,x=b.stateNode,w=x.getSnapshotBeforeUpdate(b.elementType===b.type?t:Lg(b.type,t),J);x.__reactInternalSnapshotBeforeUpdate=w}break;case 3:var u=b.stateNode.containerInfo;1===u.nodeType?u.textContent="":9===u.nodeType&&u.documentElement&&u.removeChild(u.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(p(163));}}catch(F){W(b,b.return,F)}a=b.sibling;if(null!==a){a.return=b.return;V=a;break}V=b.return}n=Oj;Oj=!1;return n}
function Qj(a,b,c){var d=b.updateQueue;d=null!==d?d.lastEffect:null;if(null!==d){var e=d=d.next;do{if((e.tag&a)===a){var f=e.destroy;e.destroy=void 0;void 0!==f&&Nj(b,c,f)}e=e.next}while(e!==d)}}function Rj(a,b){b=b.updateQueue;b=null!==b?b.lastEffect:null;if(null!==b){var c=b=b.next;do{if((c.tag&a)===a){var d=c.create;c.destroy=d()}c=c.next}while(c!==b)}}function Sj(a){var b=a.ref;if(null!==b){var c=a.stateNode;switch(a.tag){case 5:a=c;break;default:a=c}"function"===typeof b?b(a):b.current=a}}
function Tj(a){var b=a.alternate;null!==b&&(a.alternate=null,Tj(b));a.child=null;a.deletions=null;a.sibling=null;5===a.tag&&(b=a.stateNode,null!==b&&(delete b[Of],delete b[Pf],delete b[of],delete b[Qf],delete b[Rf]));a.stateNode=null;a.return=null;a.dependencies=null;a.memoizedProps=null;a.memoizedState=null;a.pendingProps=null;a.stateNode=null;a.updateQueue=null}function Uj(a){return 5===a.tag||3===a.tag||4===a.tag}
function Vj(a){a:for(;;){for(;null===a.sibling;){if(null===a.return||Uj(a.return))return null;a=a.return}a.sibling.return=a.return;for(a=a.sibling;5!==a.tag&&6!==a.tag&&18!==a.tag;){if(a.flags&2)continue a;if(null===a.child||4===a.tag)continue a;else a.child.return=a,a=a.child}if(!(a.flags&2))return a.stateNode}}
function Wj(a,b,c){var d=a.tag;if(5===d||6===d)a=a.stateNode,b?8===c.nodeType?c.parentNode.insertBefore(a,b):c.insertBefore(a,b):(8===c.nodeType?(b=c.parentNode,b.insertBefore(a,c)):(b=c,b.appendChild(a)),c=c._reactRootContainer,null!==c&&void 0!==c||null!==b.onclick||(b.onclick=Bf));else if(4!==d&&(a=a.child,null!==a))for(Wj(a,b,c),a=a.sibling;null!==a;)Wj(a,b,c),a=a.sibling}
function Xj(a,b,c){var d=a.tag;if(5===d||6===d)a=a.stateNode,b?c.insertBefore(a,b):c.appendChild(a);else if(4!==d&&(a=a.child,null!==a))for(Xj(a,b,c),a=a.sibling;null!==a;)Xj(a,b,c),a=a.sibling}var X=null,Yj=!1;function Zj(a,b,c){for(c=c.child;null!==c;)ak(a,b,c),c=c.sibling}
function ak(a,b,c){if(lc&&"function"===typeof lc.onCommitFiberUnmount)try{lc.onCommitFiberUnmount(kc,c)}catch(h){}switch(c.tag){case 5:U||Mj(c,b);case 6:var d=X,e=Yj;X=null;Zj(a,b,c);X=d;Yj=e;null!==X&&(Yj?(a=X,c=c.stateNode,8===a.nodeType?a.parentNode.removeChild(c):a.removeChild(c)):X.removeChild(c.stateNode));break;case 18:null!==X&&(Yj?(a=X,c=c.stateNode,8===a.nodeType?Kf(a.parentNode,c):1===a.nodeType&&Kf(a,c),bd(a)):Kf(X,c.stateNode));break;case 4:d=X;e=Yj;X=c.stateNode.containerInfo;Yj=!0;
Zj(a,b,c);X=d;Yj=e;break;case 0:case 11:case 14:case 15:if(!U&&(d=c.updateQueue,null!==d&&(d=d.lastEffect,null!==d))){e=d=d.next;do{var f=e,g=f.destroy;f=f.tag;void 0!==g&&(0!==(f&2)?Nj(c,b,g):0!==(f&4)&&Nj(c,b,g));e=e.next}while(e!==d)}Zj(a,b,c);break;case 1:if(!U&&(Mj(c,b),d=c.stateNode,"function"===typeof d.componentWillUnmount))try{d.props=c.memoizedProps,d.state=c.memoizedState,d.componentWillUnmount()}catch(h){W(c,b,h)}Zj(a,b,c);break;case 21:Zj(a,b,c);break;case 22:c.mode&1?(U=(d=U)||null!==
c.memoizedState,Zj(a,b,c),U=d):Zj(a,b,c);break;default:Zj(a,b,c)}}function bk(a){var b=a.updateQueue;if(null!==b){a.updateQueue=null;var c=a.stateNode;null===c&&(c=a.stateNode=new Lj);b.forEach(function(b){var d=ck.bind(null,a,b);c.has(b)||(c.add(b),b.then(d,d))})}}
function dk(a,b){var c=b.deletions;if(null!==c)for(var d=0;d<c.length;d++){var e=c[d];try{var f=a,g=b,h=g;a:for(;null!==h;){switch(h.tag){case 5:X=h.stateNode;Yj=!1;break a;case 3:X=h.stateNode.containerInfo;Yj=!0;break a;case 4:X=h.stateNode.containerInfo;Yj=!0;break a}h=h.return}if(null===X)throw Error(p(160));ak(f,g,e);X=null;Yj=!1;var k=e.alternate;null!==k&&(k.return=null);e.return=null}catch(l){W(e,b,l)}}if(b.subtreeFlags&12854)for(b=b.child;null!==b;)ek(b,a),b=b.sibling}
function ek(a,b){var c=a.alternate,d=a.flags;switch(a.tag){case 0:case 11:case 14:case 15:dk(b,a);fk(a);if(d&4){try{Qj(3,a,a.return),Rj(3,a)}catch(t){W(a,a.return,t)}try{Qj(5,a,a.return)}catch(t){W(a,a.return,t)}}break;case 1:dk(b,a);fk(a);d&512&&null!==c&&Mj(c,c.return);break;case 5:dk(b,a);fk(a);d&512&&null!==c&&Mj(c,c.return);if(a.flags&32){var e=a.stateNode;try{ob(e,"")}catch(t){W(a,a.return,t)}}if(d&4&&(e=a.stateNode,null!=e)){var f=a.memoizedProps,g=null!==c?c.memoizedProps:f,h=a.type,k=a.updateQueue;
a.updateQueue=null;if(null!==k)try{"input"===h&&"radio"===f.type&&null!=f.name&&ab(e,f);vb(h,g);var l=vb(h,f);for(g=0;g<k.length;g+=2){var m=k[g],q=k[g+1];"style"===m?sb(e,q):"dangerouslySetInnerHTML"===m?nb(e,q):"children"===m?ob(e,q):ta(e,m,q,l)}switch(h){case "input":bb(e,f);break;case "textarea":ib(e,f);break;case "select":var r=e._wrapperState.wasMultiple;e._wrapperState.wasMultiple=!!f.multiple;var y=f.value;null!=y?fb(e,!!f.multiple,y,!1):r!==!!f.multiple&&(null!=f.defaultValue?fb(e,!!f.multiple,
f.defaultValue,!0):fb(e,!!f.multiple,f.multiple?[]:"",!1))}e[Pf]=f}catch(t){W(a,a.return,t)}}break;case 6:dk(b,a);fk(a);if(d&4){if(null===a.stateNode)throw Error(p(162));e=a.stateNode;f=a.memoizedProps;try{e.nodeValue=f}catch(t){W(a,a.return,t)}}break;case 3:dk(b,a);fk(a);if(d&4&&null!==c&&c.memoizedState.isDehydrated)try{bd(b.containerInfo)}catch(t){W(a,a.return,t)}break;case 4:dk(b,a);fk(a);break;case 13:dk(b,a);fk(a);e=a.child;e.flags&8192&&(f=null!==e.memoizedState,e.stateNode.isHidden=f,!f||
null!==e.alternate&&null!==e.alternate.memoizedState||(gk=B()));d&4&&bk(a);break;case 22:m=null!==c&&null!==c.memoizedState;a.mode&1?(U=(l=U)||m,dk(b,a),U=l):dk(b,a);fk(a);if(d&8192){l=null!==a.memoizedState;if((a.stateNode.isHidden=l)&&!m&&0!==(a.mode&1))for(V=a,m=a.child;null!==m;){for(q=V=m;null!==V;){r=V;y=r.child;switch(r.tag){case 0:case 11:case 14:case 15:Qj(4,r,r.return);break;case 1:Mj(r,r.return);var n=r.stateNode;if("function"===typeof n.componentWillUnmount){d=r;c=r.return;try{b=d,n.props=
b.memoizedProps,n.state=b.memoizedState,n.componentWillUnmount()}catch(t){W(d,c,t)}}break;case 5:Mj(r,r.return);break;case 22:if(null!==r.memoizedState){hk(q);continue}}null!==y?(y.return=r,V=y):hk(q)}m=m.sibling}a:for(m=null,q=a;;){if(5===q.tag){if(null===m){m=q;try{e=q.stateNode,l?(f=e.style,"function"===typeof f.setProperty?f.setProperty("display","none","important"):f.display="none"):(h=q.stateNode,k=q.memoizedProps.style,g=void 0!==k&&null!==k&&k.hasOwnProperty("display")?k.display:null,h.style.display=
rb("display",g))}catch(t){W(a,a.return,t)}}}else if(6===q.tag){if(null===m)try{q.stateNode.nodeValue=l?"":q.memoizedProps}catch(t){W(a,a.return,t)}}else if((22!==q.tag&&23!==q.tag||null===q.memoizedState||q===a)&&null!==q.child){q.child.return=q;q=q.child;continue}if(q===a)break a;for(;null===q.sibling;){if(null===q.return||q.return===a)break a;m===q&&(m=null);q=q.return}m===q&&(m=null);q.sibling.return=q.return;q=q.sibling}}break;case 19:dk(b,a);fk(a);d&4&&bk(a);break;case 21:break;default:dk(b,
a),fk(a)}}function fk(a){var b=a.flags;if(b&2){try{a:{for(var c=a.return;null!==c;){if(Uj(c)){var d=c;break a}c=c.return}throw Error(p(160));}switch(d.tag){case 5:var e=d.stateNode;d.flags&32&&(ob(e,""),d.flags&=-33);var f=Vj(a);Xj(a,f,e);break;case 3:case 4:var g=d.stateNode.containerInfo,h=Vj(a);Wj(a,h,g);break;default:throw Error(p(161));}}catch(k){W(a,a.return,k)}a.flags&=-3}b&4096&&(a.flags&=-4097)}function ik(a,b,c){V=a;jk(a,b,c)}
function jk(a,b,c){for(var d=0!==(a.mode&1);null!==V;){var e=V,f=e.child;if(22===e.tag&&d){var g=null!==e.memoizedState||Kj;if(!g){var h=e.alternate,k=null!==h&&null!==h.memoizedState||U;h=Kj;var l=U;Kj=g;if((U=k)&&!l)for(V=e;null!==V;)g=V,k=g.child,22===g.tag&&null!==g.memoizedState?kk(e):null!==k?(k.return=g,V=k):kk(e);for(;null!==f;)V=f,jk(f,b,c),f=f.sibling;V=e;Kj=h;U=l}lk(a,b,c)}else 0!==(e.subtreeFlags&8772)&&null!==f?(f.return=e,V=f):lk(a,b,c)}}
function lk(a){for(;null!==V;){var b=V;if(0!==(b.flags&8772)){var c=b.alternate;try{if(0!==(b.flags&8772))switch(b.tag){case 0:case 11:case 15:U||Rj(5,b);break;case 1:var d=b.stateNode;if(b.flags&4&&!U)if(null===c)d.componentDidMount();else{var e=b.elementType===b.type?c.memoizedProps:Lg(b.type,c.memoizedProps);d.componentDidUpdate(e,c.memoizedState,d.__reactInternalSnapshotBeforeUpdate)}var f=b.updateQueue;null!==f&&ih(b,f,d);break;case 3:var g=b.updateQueue;if(null!==g){c=null;if(null!==b.child)switch(b.child.tag){case 5:c=
b.child.stateNode;break;case 1:c=b.child.stateNode}ih(b,g,c)}break;case 5:var h=b.stateNode;if(null===c&&b.flags&4){c=h;var k=b.memoizedProps;switch(b.type){case "button":case "input":case "select":case "textarea":k.autoFocus&&c.focus();break;case "img":k.src&&(c.src=k.src)}}break;case 6:break;case 4:break;case 12:break;case 13:if(null===b.memoizedState){var l=b.alternate;if(null!==l){var m=l.memoizedState;if(null!==m){var q=m.dehydrated;null!==q&&bd(q)}}}break;case 19:case 17:case 21:case 22:case 23:case 25:break;
default:throw Error(p(163));}U||b.flags&512&&Sj(b)}catch(r){W(b,b.return,r)}}if(b===a){V=null;break}c=b.sibling;if(null!==c){c.return=b.return;V=c;break}V=b.return}}function hk(a){for(;null!==V;){var b=V;if(b===a){V=null;break}var c=b.sibling;if(null!==c){c.return=b.return;V=c;break}V=b.return}}
function kk(a){for(;null!==V;){var b=V;try{switch(b.tag){case 0:case 11:case 15:var c=b.return;try{Rj(4,b)}catch(k){W(b,c,k)}break;case 1:var d=b.stateNode;if("function"===typeof d.componentDidMount){var e=b.return;try{d.componentDidMount()}catch(k){W(b,e,k)}}var f=b.return;try{Sj(b)}catch(k){W(b,f,k)}break;case 5:var g=b.return;try{Sj(b)}catch(k){W(b,g,k)}}}catch(k){W(b,b.return,k)}if(b===a){V=null;break}var h=b.sibling;if(null!==h){h.return=b.return;V=h;break}V=b.return}}
var mk=Math.ceil,nk=ua.ReactCurrentDispatcher,ok=ua.ReactCurrentOwner,pk=ua.ReactCurrentBatchConfig,K=0,R=null,Y=null,Z=0,gj=0,fj=Uf(0),T=0,qk=null,hh=0,rk=0,sk=0,tk=null,uk=null,gk=0,Hj=Infinity,vk=null,Pi=!1,Qi=null,Si=null,wk=!1,xk=null,yk=0,zk=0,Ak=null,Bk=-1,Ck=0;function L(){return 0!==(K&6)?B():-1!==Bk?Bk:Bk=B()}
function lh(a){if(0===(a.mode&1))return 1;if(0!==(K&2)&&0!==Z)return Z&-Z;if(null!==Kg.transition)return 0===Ck&&(Ck=yc()),Ck;a=C;if(0!==a)return a;a=window.event;a=void 0===a?16:jd(a.type);return a}function mh(a,b,c,d){if(50<zk)throw zk=0,Ak=null,Error(p(185));Ac(a,c,d);if(0===(K&2)||a!==R)a===R&&(0===(K&2)&&(rk|=c),4===T&&Dk(a,Z)),Ek(a,d),1===c&&0===K&&0===(b.mode&1)&&(Hj=B()+500,fg&&jg())}
function Ek(a,b){var c=a.callbackNode;wc(a,b);var d=uc(a,a===R?Z:0);if(0===d)null!==c&&bc(c),a.callbackNode=null,a.callbackPriority=0;else if(b=d&-d,a.callbackPriority!==b){null!=c&&bc(c);if(1===b)0===a.tag?ig(Fk.bind(null,a)):hg(Fk.bind(null,a)),Jf(function(){0===(K&6)&&jg()}),c=null;else{switch(Dc(d)){case 1:c=fc;break;case 4:c=gc;break;case 16:c=hc;break;case 536870912:c=jc;break;default:c=hc}c=Gk(c,Hk.bind(null,a))}a.callbackPriority=b;a.callbackNode=c}}
function Hk(a,b){Bk=-1;Ck=0;if(0!==(K&6))throw Error(p(327));var c=a.callbackNode;if(Ik()&&a.callbackNode!==c)return null;var d=uc(a,a===R?Z:0);if(0===d)return null;if(0!==(d&30)||0!==(d&a.expiredLanes)||b)b=Jk(a,d);else{b=d;var e=K;K|=2;var f=Kk();if(R!==a||Z!==b)vk=null,Hj=B()+500,Lk(a,b);do try{Mk();break}catch(h){Nk(a,h)}while(1);Qg();nk.current=f;K=e;null!==Y?b=0:(R=null,Z=0,b=T)}if(0!==b){2===b&&(e=xc(a),0!==e&&(d=e,b=Ok(a,e)));if(1===b)throw c=qk,Lk(a,0),Dk(a,d),Ek(a,B()),c;if(6===b)Dk(a,d);
else{e=a.current.alternate;if(0===(d&30)&&!Pk(e)&&(b=Jk(a,d),2===b&&(f=xc(a),0!==f&&(d=f,b=Ok(a,f))),1===b))throw c=qk,Lk(a,0),Dk(a,d),Ek(a,B()),c;a.finishedWork=e;a.finishedLanes=d;switch(b){case 0:case 1:throw Error(p(345));case 2:Qk(a,uk,vk);break;case 3:Dk(a,d);if((d&130023424)===d&&(b=gk+500-B(),10<b)){if(0!==uc(a,0))break;e=a.suspendedLanes;if((e&d)!==d){L();a.pingedLanes|=a.suspendedLanes&e;break}a.timeoutHandle=Ff(Qk.bind(null,a,uk,vk),b);break}Qk(a,uk,vk);break;case 4:Dk(a,d);if((d&4194240)===
d)break;b=a.eventTimes;for(e=-1;0<d;){var g=31-oc(d);f=1<<g;g=b[g];g>e&&(e=g);d&=~f}d=e;d=B()-d;d=(120>d?120:480>d?480:1080>d?1080:1920>d?1920:3E3>d?3E3:4320>d?4320:1960*mk(d/1960))-d;if(10<d){a.timeoutHandle=Ff(Qk.bind(null,a,uk,vk),d);break}Qk(a,uk,vk);break;case 5:Qk(a,uk,vk);break;default:throw Error(p(329));}}}Ek(a,B());return a.callbackNode===c?Hk.bind(null,a):null}
function Ok(a,b){var c=tk;a.current.memoizedState.isDehydrated&&(Lk(a,b).flags|=256);a=Jk(a,b);2!==a&&(b=uk,uk=c,null!==b&&Gj(b));return a}function Gj(a){null===uk?uk=a:uk.push.apply(uk,a)}
function Pk(a){for(var b=a;;){if(b.flags&16384){var c=b.updateQueue;if(null!==c&&(c=c.stores,null!==c))for(var d=0;d<c.length;d++){var e=c[d],f=e.getSnapshot;e=e.value;try{if(!He(f(),e))return!1}catch(g){return!1}}}c=b.child;if(b.subtreeFlags&16384&&null!==c)c.return=b,b=c;else{if(b===a)break;for(;null===b.sibling;){if(null===b.return||b.return===a)return!0;b=b.return}b.sibling.return=b.return;b=b.sibling}}return!0}
function Dk(a,b){b&=~sk;b&=~rk;a.suspendedLanes|=b;a.pingedLanes&=~b;for(a=a.expirationTimes;0<b;){var c=31-oc(b),d=1<<c;a[c]=-1;b&=~d}}function Fk(a){if(0!==(K&6))throw Error(p(327));Ik();var b=uc(a,0);if(0===(b&1))return Ek(a,B()),null;var c=Jk(a,b);if(0!==a.tag&&2===c){var d=xc(a);0!==d&&(b=d,c=Ok(a,d))}if(1===c)throw c=qk,Lk(a,0),Dk(a,b),Ek(a,B()),c;if(6===c)throw Error(p(345));a.finishedWork=a.current.alternate;a.finishedLanes=b;Qk(a,uk,vk);Ek(a,B());return null}
function Rk(a,b){var c=K;K|=1;try{return a(b)}finally{K=c,0===K&&(Hj=B()+500,fg&&jg())}}function Sk(a){null!==xk&&0===xk.tag&&0===(K&6)&&Ik();var b=K;K|=1;var c=pk.transition,d=C;try{if(pk.transition=null,C=1,a)return a()}finally{C=d,pk.transition=c,K=b,0===(K&6)&&jg()}}function Ij(){gj=fj.current;E(fj)}
function Lk(a,b){a.finishedWork=null;a.finishedLanes=0;var c=a.timeoutHandle;-1!==c&&(a.timeoutHandle=-1,Gf(c));if(null!==Y)for(c=Y.return;null!==c;){var d=c;wg(d);switch(d.tag){case 1:d=d.type.childContextTypes;null!==d&&void 0!==d&&$f();break;case 3:Jh();E(Wf);E(H);Oh();break;case 5:Lh(d);break;case 4:Jh();break;case 13:E(M);break;case 19:E(M);break;case 10:Rg(d.type._context);break;case 22:case 23:Ij()}c=c.return}R=a;Y=a=wh(a.current,null);Z=gj=b;T=0;qk=null;sk=rk=hh=0;uk=tk=null;if(null!==Wg){for(b=
0;b<Wg.length;b++)if(c=Wg[b],d=c.interleaved,null!==d){c.interleaved=null;var e=d.next,f=c.pending;if(null!==f){var g=f.next;f.next=e;d.next=g}c.pending=d}Wg=null}return a}
function Nk(a,b){do{var c=Y;try{Qg();Ph.current=ai;if(Sh){for(var d=N.memoizedState;null!==d;){var e=d.queue;null!==e&&(e.pending=null);d=d.next}Sh=!1}Rh=0;P=O=N=null;Th=!1;Uh=0;ok.current=null;if(null===c||null===c.return){T=1;qk=b;Y=null;break}a:{var f=a,g=c.return,h=c,k=b;b=Z;h.flags|=32768;if(null!==k&&"object"===typeof k&&"function"===typeof k.then){var l=k,m=h,q=m.tag;if(0===(m.mode&1)&&(0===q||11===q||15===q)){var r=m.alternate;r?(m.updateQueue=r.updateQueue,m.memoizedState=r.memoizedState,
m.lanes=r.lanes):(m.updateQueue=null,m.memoizedState=null)}var y=Vi(g);if(null!==y){y.flags&=-257;Wi(y,g,h,f,b);y.mode&1&&Ti(f,l,b);b=y;k=l;var n=b.updateQueue;if(null===n){var t=new Set;t.add(k);b.updateQueue=t}else n.add(k);break a}else{if(0===(b&1)){Ti(f,l,b);uj();break a}k=Error(p(426))}}else if(I&&h.mode&1){var J=Vi(g);if(null!==J){0===(J.flags&65536)&&(J.flags|=256);Wi(J,g,h,f,b);Jg(Ki(k,h));break a}}f=k=Ki(k,h);4!==T&&(T=2);null===tk?tk=[f]:tk.push(f);f=g;do{switch(f.tag){case 3:f.flags|=65536;
b&=-b;f.lanes|=b;var x=Oi(f,k,b);fh(f,x);break a;case 1:h=k;var w=f.type,u=f.stateNode;if(0===(f.flags&128)&&("function"===typeof w.getDerivedStateFromError||null!==u&&"function"===typeof u.componentDidCatch&&(null===Si||!Si.has(u)))){f.flags|=65536;b&=-b;f.lanes|=b;var F=Ri(f,h,b);fh(f,F);break a}}f=f.return}while(null!==f)}Tk(c)}catch(na){b=na;Y===c&&null!==c&&(Y=c=c.return);continue}break}while(1)}function Kk(){var a=nk.current;nk.current=ai;return null===a?ai:a}
function uj(){if(0===T||3===T||2===T)T=4;null===R||0===(hh&268435455)&&0===(rk&268435455)||Dk(R,Z)}function Jk(a,b){var c=K;K|=2;var d=Kk();if(R!==a||Z!==b)vk=null,Lk(a,b);do try{Uk();break}catch(e){Nk(a,e)}while(1);Qg();K=c;nk.current=d;if(null!==Y)throw Error(p(261));R=null;Z=0;return T}function Uk(){for(;null!==Y;)Vk(Y)}function Mk(){for(;null!==Y&&!cc();)Vk(Y)}function Vk(a){var b=Wk(a.alternate,a,gj);a.memoizedProps=a.pendingProps;null===b?Tk(a):Y=b;ok.current=null}
function Tk(a){var b=a;do{var c=b.alternate;a=b.return;if(0===(b.flags&32768)){if(c=Fj(c,b,gj),null!==c){Y=c;return}}else{c=Jj(c,b);if(null!==c){c.flags&=32767;Y=c;return}if(null!==a)a.flags|=32768,a.subtreeFlags=0,a.deletions=null;else{T=6;Y=null;return}}b=b.sibling;if(null!==b){Y=b;return}Y=b=a}while(null!==b);0===T&&(T=5)}function Qk(a,b,c){var d=C,e=pk.transition;try{pk.transition=null,C=1,Xk(a,b,c,d)}finally{pk.transition=e,C=d}return null}
function Xk(a,b,c,d){do Ik();while(null!==xk);if(0!==(K&6))throw Error(p(327));c=a.finishedWork;var e=a.finishedLanes;if(null===c)return null;a.finishedWork=null;a.finishedLanes=0;if(c===a.current)throw Error(p(177));a.callbackNode=null;a.callbackPriority=0;var f=c.lanes|c.childLanes;Bc(a,f);a===R&&(Y=R=null,Z=0);0===(c.subtreeFlags&2064)&&0===(c.flags&2064)||wk||(wk=!0,Gk(hc,function(){Ik();return null}));f=0!==(c.flags&15990);if(0!==(c.subtreeFlags&15990)||f){f=pk.transition;pk.transition=null;
var g=C;C=1;var h=K;K|=4;ok.current=null;Pj(a,c);ek(c,a);Oe(Df);dd=!!Cf;Df=Cf=null;a.current=c;ik(c,a,e);dc();K=h;C=g;pk.transition=f}else a.current=c;wk&&(wk=!1,xk=a,yk=e);f=a.pendingLanes;0===f&&(Si=null);mc(c.stateNode,d);Ek(a,B());if(null!==b)for(d=a.onRecoverableError,c=0;c<b.length;c++)e=b[c],d(e.value,{componentStack:e.stack,digest:e.digest});if(Pi)throw Pi=!1,a=Qi,Qi=null,a;0!==(yk&1)&&0!==a.tag&&Ik();f=a.pendingLanes;0!==(f&1)?a===Ak?zk++:(zk=0,Ak=a):zk=0;jg();return null}
function Ik(){if(null!==xk){var a=Dc(yk),b=pk.transition,c=C;try{pk.transition=null;C=16>a?16:a;if(null===xk)var d=!1;else{a=xk;xk=null;yk=0;if(0!==(K&6))throw Error(p(331));var e=K;K|=4;for(V=a.current;null!==V;){var f=V,g=f.child;if(0!==(V.flags&16)){var h=f.deletions;if(null!==h){for(var k=0;k<h.length;k++){var l=h[k];for(V=l;null!==V;){var m=V;switch(m.tag){case 0:case 11:case 15:Qj(8,m,f)}var q=m.child;if(null!==q)q.return=m,V=q;else for(;null!==V;){m=V;var r=m.sibling,y=m.return;Tj(m);if(m===
l){V=null;break}if(null!==r){r.return=y;V=r;break}V=y}}}var n=f.alternate;if(null!==n){var t=n.child;if(null!==t){n.child=null;do{var J=t.sibling;t.sibling=null;t=J}while(null!==t)}}V=f}}if(0!==(f.subtreeFlags&2064)&&null!==g)g.return=f,V=g;else b:for(;null!==V;){f=V;if(0!==(f.flags&2048))switch(f.tag){case 0:case 11:case 15:Qj(9,f,f.return)}var x=f.sibling;if(null!==x){x.return=f.return;V=x;break b}V=f.return}}var w=a.current;for(V=w;null!==V;){g=V;var u=g.child;if(0!==(g.subtreeFlags&2064)&&null!==
u)u.return=g,V=u;else b:for(g=w;null!==V;){h=V;if(0!==(h.flags&2048))try{switch(h.tag){case 0:case 11:case 15:Rj(9,h)}}catch(na){W(h,h.return,na)}if(h===g){V=null;break b}var F=h.sibling;if(null!==F){F.return=h.return;V=F;break b}V=h.return}}K=e;jg();if(lc&&"function"===typeof lc.onPostCommitFiberRoot)try{lc.onPostCommitFiberRoot(kc,a)}catch(na){}d=!0}return d}finally{C=c,pk.transition=b}}return!1}function Yk(a,b,c){b=Ki(c,b);b=Oi(a,b,1);a=dh(a,b,1);b=L();null!==a&&(Ac(a,1,b),Ek(a,b))}
function W(a,b,c){if(3===a.tag)Yk(a,a,c);else for(;null!==b;){if(3===b.tag){Yk(b,a,c);break}else if(1===b.tag){var d=b.stateNode;if("function"===typeof b.type.getDerivedStateFromError||"function"===typeof d.componentDidCatch&&(null===Si||!Si.has(d))){a=Ki(c,a);a=Ri(b,a,1);b=dh(b,a,1);a=L();null!==b&&(Ac(b,1,a),Ek(b,a));break}}b=b.return}}
function Ui(a,b,c){var d=a.pingCache;null!==d&&d.delete(b);b=L();a.pingedLanes|=a.suspendedLanes&c;R===a&&(Z&c)===c&&(4===T||3===T&&(Z&130023424)===Z&&500>B()-gk?Lk(a,0):sk|=c);Ek(a,b)}function Zk(a,b){0===b&&(0===(a.mode&1)?b=1:(b=sc,sc<<=1,0===(sc&130023424)&&(sc=4194304)));var c=L();a=Zg(a,b);null!==a&&(Ac(a,b,c),Ek(a,c))}function vj(a){var b=a.memoizedState,c=0;null!==b&&(c=b.retryLane);Zk(a,c)}
function ck(a,b){var c=0;switch(a.tag){case 13:var d=a.stateNode;var e=a.memoizedState;null!==e&&(c=e.retryLane);break;case 19:d=a.stateNode;break;default:throw Error(p(314));}null!==d&&d.delete(b);Zk(a,c)}var Wk;
Wk=function(a,b,c){if(null!==a)if(a.memoizedProps!==b.pendingProps||Wf.current)Ug=!0;else{if(0===(a.lanes&c)&&0===(b.flags&128))return Ug=!1,zj(a,b,c);Ug=0!==(a.flags&131072)?!0:!1}else Ug=!1,I&&0!==(b.flags&1048576)&&ug(b,ng,b.index);b.lanes=0;switch(b.tag){case 2:var d=b.type;jj(a,b);a=b.pendingProps;var e=Yf(b,H.current);Tg(b,c);e=Xh(null,b,d,a,e,c);var f=bi();b.flags|=1;"object"===typeof e&&null!==e&&"function"===typeof e.render&&void 0===e.$$typeof?(b.tag=1,b.memoizedState=null,b.updateQueue=
null,Zf(d)?(f=!0,cg(b)):f=!1,b.memoizedState=null!==e.state&&void 0!==e.state?e.state:null,ah(b),e.updater=nh,b.stateNode=e,e._reactInternals=b,rh(b,d,a,c),b=kj(null,b,d,!0,f,c)):(b.tag=0,I&&f&&vg(b),Yi(null,b,e,c),b=b.child);return b;case 16:d=b.elementType;a:{jj(a,b);a=b.pendingProps;e=d._init;d=e(d._payload);b.type=d;e=b.tag=$k(d);a=Lg(d,a);switch(e){case 0:b=dj(null,b,d,a,c);break a;case 1:b=ij(null,b,d,a,c);break a;case 11:b=Zi(null,b,d,a,c);break a;case 14:b=aj(null,b,d,Lg(d.type,a),c);break a}throw Error(p(306,
d,""));}return b;case 0:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),dj(a,b,d,e,c);case 1:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),ij(a,b,d,e,c);case 3:a:{lj(b);if(null===a)throw Error(p(387));d=b.pendingProps;f=b.memoizedState;e=f.element;bh(a,b);gh(b,d,null,c);var g=b.memoizedState;d=g.element;if(f.isDehydrated)if(f={element:d,isDehydrated:!1,cache:g.cache,pendingSuspenseBoundaries:g.pendingSuspenseBoundaries,transitions:g.transitions},b.updateQueue.baseState=
f,b.memoizedState=f,b.flags&256){e=Ki(Error(p(423)),b);b=mj(a,b,d,c,e);break a}else if(d!==e){e=Ki(Error(p(424)),b);b=mj(a,b,d,c,e);break a}else for(yg=Lf(b.stateNode.containerInfo.firstChild),xg=b,I=!0,zg=null,c=Ch(b,null,d,c),b.child=c;c;)c.flags=c.flags&-3|4096,c=c.sibling;else{Ig();if(d===e){b=$i(a,b,c);break a}Yi(a,b,d,c)}b=b.child}return b;case 5:return Kh(b),null===a&&Eg(b),d=b.type,e=b.pendingProps,f=null!==a?a.memoizedProps:null,g=e.children,Ef(d,e)?g=null:null!==f&&Ef(d,f)&&(b.flags|=32),
hj(a,b),Yi(a,b,g,c),b.child;case 6:return null===a&&Eg(b),null;case 13:return pj(a,b,c);case 4:return Ih(b,b.stateNode.containerInfo),d=b.pendingProps,null===a?b.child=Bh(b,null,d,c):Yi(a,b,d,c),b.child;case 11:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),Zi(a,b,d,e,c);case 7:return Yi(a,b,b.pendingProps,c),b.child;case 8:return Yi(a,b,b.pendingProps.children,c),b.child;case 12:return Yi(a,b,b.pendingProps.children,c),b.child;case 10:a:{d=b.type._context;e=b.pendingProps;f=b.memoizedProps;
g=e.value;G(Mg,d._currentValue);d._currentValue=g;if(null!==f)if(He(f.value,g)){if(f.children===e.children&&!Wf.current){b=$i(a,b,c);break a}}else for(f=b.child,null!==f&&(f.return=b);null!==f;){var h=f.dependencies;if(null!==h){g=f.child;for(var k=h.firstContext;null!==k;){if(k.context===d){if(1===f.tag){k=ch(-1,c&-c);k.tag=2;var l=f.updateQueue;if(null!==l){l=l.shared;var m=l.pending;null===m?k.next=k:(k.next=m.next,m.next=k);l.pending=k}}f.lanes|=c;k=f.alternate;null!==k&&(k.lanes|=c);Sg(f.return,
c,b);h.lanes|=c;break}k=k.next}}else if(10===f.tag)g=f.type===b.type?null:f.child;else if(18===f.tag){g=f.return;if(null===g)throw Error(p(341));g.lanes|=c;h=g.alternate;null!==h&&(h.lanes|=c);Sg(g,c,b);g=f.sibling}else g=f.child;if(null!==g)g.return=f;else for(g=f;null!==g;){if(g===b){g=null;break}f=g.sibling;if(null!==f){f.return=g.return;g=f;break}g=g.return}f=g}Yi(a,b,e.children,c);b=b.child}return b;case 9:return e=b.type,d=b.pendingProps.children,Tg(b,c),e=Vg(e),d=d(e),b.flags|=1,Yi(a,b,d,c),
b.child;case 14:return d=b.type,e=Lg(d,b.pendingProps),e=Lg(d.type,e),aj(a,b,d,e,c);case 15:return cj(a,b,b.type,b.pendingProps,c);case 17:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),jj(a,b),b.tag=1,Zf(d)?(a=!0,cg(b)):a=!1,Tg(b,c),ph(b,d,e),rh(b,d,e,c),kj(null,b,d,!0,a,c);case 19:return yj(a,b,c);case 22:return ej(a,b,c)}throw Error(p(156,b.tag));};function Gk(a,b){return ac(a,b)}
function al(a,b,c,d){this.tag=a;this.key=c;this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null;this.index=0;this.ref=null;this.pendingProps=b;this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null;this.mode=d;this.subtreeFlags=this.flags=0;this.deletions=null;this.childLanes=this.lanes=0;this.alternate=null}function Bg(a,b,c,d){return new al(a,b,c,d)}function bj(a){a=a.prototype;return!(!a||!a.isReactComponent)}
function $k(a){if("function"===typeof a)return bj(a)?1:0;if(void 0!==a&&null!==a){a=a.$$typeof;if(a===Da)return 11;if(a===Ga)return 14}return 2}
function wh(a,b){var c=a.alternate;null===c?(c=Bg(a.tag,b,a.key,a.mode),c.elementType=a.elementType,c.type=a.type,c.stateNode=a.stateNode,c.alternate=a,a.alternate=c):(c.pendingProps=b,c.type=a.type,c.flags=0,c.subtreeFlags=0,c.deletions=null);c.flags=a.flags&14680064;c.childLanes=a.childLanes;c.lanes=a.lanes;c.child=a.child;c.memoizedProps=a.memoizedProps;c.memoizedState=a.memoizedState;c.updateQueue=a.updateQueue;b=a.dependencies;c.dependencies=null===b?null:{lanes:b.lanes,firstContext:b.firstContext};
c.sibling=a.sibling;c.index=a.index;c.ref=a.ref;return c}
function yh(a,b,c,d,e,f){var g=2;d=a;if("function"===typeof a)bj(a)&&(g=1);else if("string"===typeof a)g=5;else a:switch(a){case ya:return Ah(c.children,e,f,b);case za:g=8;e|=8;break;case Aa:return a=Bg(12,c,b,e|2),a.elementType=Aa,a.lanes=f,a;case Ea:return a=Bg(13,c,b,e),a.elementType=Ea,a.lanes=f,a;case Fa:return a=Bg(19,c,b,e),a.elementType=Fa,a.lanes=f,a;case Ia:return qj(c,e,f,b);default:if("object"===typeof a&&null!==a)switch(a.$$typeof){case Ba:g=10;break a;case Ca:g=9;break a;case Da:g=11;
break a;case Ga:g=14;break a;case Ha:g=16;d=null;break a}throw Error(p(130,null==a?a:typeof a,""));}b=Bg(g,c,b,e);b.elementType=a;b.type=d;b.lanes=f;return b}function Ah(a,b,c,d){a=Bg(7,a,d,b);a.lanes=c;return a}function qj(a,b,c,d){a=Bg(22,a,d,b);a.elementType=Ia;a.lanes=c;a.stateNode={isHidden:!1};return a}function xh(a,b,c){a=Bg(6,a,null,b);a.lanes=c;return a}
function zh(a,b,c){b=Bg(4,null!==a.children?a.children:[],a.key,b);b.lanes=c;b.stateNode={containerInfo:a.containerInfo,pendingChildren:null,implementation:a.implementation};return b}
function bl(a,b,c,d,e){this.tag=b;this.containerInfo=a;this.finishedWork=this.pingCache=this.current=this.pendingChildren=null;this.timeoutHandle=-1;this.callbackNode=this.pendingContext=this.context=null;this.callbackPriority=0;this.eventTimes=zc(0);this.expirationTimes=zc(-1);this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0;this.entanglements=zc(0);this.identifierPrefix=d;this.onRecoverableError=e;this.mutableSourceEagerHydrationData=
null}function cl(a,b,c,d,e,f,g,h,k){a=new bl(a,b,c,h,k);1===b?(b=1,!0===f&&(b|=8)):b=0;f=Bg(3,null,null,b);a.current=f;f.stateNode=a;f.memoizedState={element:d,isDehydrated:c,cache:null,transitions:null,pendingSuspenseBoundaries:null};ah(f);return a}function dl(a,b,c){var d=3<arguments.length&&void 0!==arguments[3]?arguments[3]:null;return{$$typeof:wa,key:null==d?null:""+d,children:a,containerInfo:b,implementation:c}}
function el(a){if(!a)return Vf;a=a._reactInternals;a:{if(Vb(a)!==a||1!==a.tag)throw Error(p(170));var b=a;do{switch(b.tag){case 3:b=b.stateNode.context;break a;case 1:if(Zf(b.type)){b=b.stateNode.__reactInternalMemoizedMergedChildContext;break a}}b=b.return}while(null!==b);throw Error(p(171));}if(1===a.tag){var c=a.type;if(Zf(c))return bg(a,c,b)}return b}
function fl(a,b,c,d,e,f,g,h,k){a=cl(c,d,!0,a,e,f,g,h,k);a.context=el(null);c=a.current;d=L();e=lh(c);f=ch(d,e);f.callback=void 0!==b&&null!==b?b:null;dh(c,f,e);a.current.lanes=e;Ac(a,e,d);Ek(a,d);return a}function gl(a,b,c,d){var e=b.current,f=L(),g=lh(e);c=el(c);null===b.context?b.context=c:b.pendingContext=c;b=ch(f,g);b.payload={element:a};d=void 0===d?null:d;null!==d&&(b.callback=d);a=dh(e,b,g);null!==a&&(mh(a,e,g,f),eh(a,e,g));return g}
function hl(a){a=a.current;if(!a.child)return null;switch(a.child.tag){case 5:return a.child.stateNode;default:return a.child.stateNode}}function il(a,b){a=a.memoizedState;if(null!==a&&null!==a.dehydrated){var c=a.retryLane;a.retryLane=0!==c&&c<b?c:b}}function jl(a,b){il(a,b);(a=a.alternate)&&il(a,b)}function kl(){return null}var ll="function"===typeof reportError?reportError:function(a){console.error(a)};function ml(a){this._internalRoot=a}
nl.prototype.render=ml.prototype.render=function(a){var b=this._internalRoot;if(null===b)throw Error(p(409));gl(a,b,null,null)};nl.prototype.unmount=ml.prototype.unmount=function(){var a=this._internalRoot;if(null!==a){this._internalRoot=null;var b=a.containerInfo;Sk(function(){gl(null,a,null,null)});b[uf]=null}};function nl(a){this._internalRoot=a}
nl.prototype.unstable_scheduleHydration=function(a){if(a){var b=Hc();a={blockedOn:null,target:a,priority:b};for(var c=0;c<Qc.length&&0!==b&&b<Qc[c].priority;c++);Qc.splice(c,0,a);0===c&&Vc(a)}};function ol(a){return!(!a||1!==a.nodeType&&9!==a.nodeType&&11!==a.nodeType)}function pl(a){return!(!a||1!==a.nodeType&&9!==a.nodeType&&11!==a.nodeType&&(8!==a.nodeType||" react-mount-point-unstable "!==a.nodeValue))}function ql(){}
function rl(a,b,c,d,e){if(e){if("function"===typeof d){var f=d;d=function(){var a=hl(g);f.call(a)}}var g=fl(b,d,a,0,null,!1,!1,"",ql);a._reactRootContainer=g;a[uf]=g.current;sf(8===a.nodeType?a.parentNode:a);Sk();return g}for(;e=a.lastChild;)a.removeChild(e);if("function"===typeof d){var h=d;d=function(){var a=hl(k);h.call(a)}}var k=cl(a,0,!1,null,null,!1,!1,"",ql);a._reactRootContainer=k;a[uf]=k.current;sf(8===a.nodeType?a.parentNode:a);Sk(function(){gl(b,k,c,d)});return k}
function sl(a,b,c,d,e){var f=c._reactRootContainer;if(f){var g=f;if("function"===typeof e){var h=e;e=function(){var a=hl(g);h.call(a)}}gl(b,g,a,e)}else g=rl(c,b,a,e,d);return hl(g)}Ec=function(a){switch(a.tag){case 3:var b=a.stateNode;if(b.current.memoizedState.isDehydrated){var c=tc(b.pendingLanes);0!==c&&(Cc(b,c|1),Ek(b,B()),0===(K&6)&&(Hj=B()+500,jg()))}break;case 13:Sk(function(){var b=Zg(a,1);if(null!==b){var c=L();mh(b,a,1,c)}}),jl(a,1)}};
Fc=function(a){if(13===a.tag){var b=Zg(a,134217728);if(null!==b){var c=L();mh(b,a,134217728,c)}jl(a,134217728)}};Gc=function(a){if(13===a.tag){var b=lh(a),c=Zg(a,b);if(null!==c){var d=L();mh(c,a,b,d)}jl(a,b)}};Hc=function(){return C};Ic=function(a,b){var c=C;try{return C=a,b()}finally{C=c}};
yb=function(a,b,c){switch(b){case "input":bb(a,c);b=c.name;if("radio"===c.type&&null!=b){for(c=a;c.parentNode;)c=c.parentNode;c=c.querySelectorAll("input[name="+JSON.stringify(""+b)+'][type="radio"]');for(b=0;b<c.length;b++){var d=c[b];if(d!==a&&d.form===a.form){var e=Db(d);if(!e)throw Error(p(90));Wa(d);bb(d,e)}}}break;case "textarea":ib(a,c);break;case "select":b=c.value,null!=b&&fb(a,!!c.multiple,b,!1)}};Gb=Rk;Hb=Sk;
var tl={usingClientEntryPoint:!1,Events:[Cb,ue,Db,Eb,Fb,Rk]},ul={findFiberByHostInstance:Wc,bundleType:0,version:"18.2.0",rendererPackageName:"react-dom"};
var vl={bundleType:ul.bundleType,version:ul.version,rendererPackageName:ul.rendererPackageName,rendererConfig:ul.rendererConfig,overrideHookState:null,overrideHookStateDeletePath:null,overrideHookStateRenamePath:null,overrideProps:null,overridePropsDeletePath:null,overridePropsRenamePath:null,setErrorHandler:null,setSuspenseHandler:null,scheduleUpdate:null,currentDispatcherRef:ua.ReactCurrentDispatcher,findHostInstanceByFiber:function(a){a=Zb(a);return null===a?null:a.stateNode},findFiberByHostInstance:ul.findFiberByHostInstance||
kl,findHostInstancesForRefresh:null,scheduleRefresh:null,scheduleRoot:null,setRefreshHandler:null,getCurrentFiber:null,reconcilerVersion:"18.2.0-next-9e3b772b8-20220608"};if("undefined"!==typeof __REACT_DEVTOOLS_GLOBAL_HOOK__){var wl=__REACT_DEVTOOLS_GLOBAL_HOOK__;if(!wl.isDisabled&&wl.supportsFiber)try{kc=wl.inject(vl),lc=wl}catch(a){}}exports.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED=tl;
exports.createPortal=function(a,b){var c=2<arguments.length&&void 0!==arguments[2]?arguments[2]:null;if(!ol(b))throw Error(p(200));return dl(a,b,null,c)};exports.createRoot=function(a,b){if(!ol(a))throw Error(p(299));var c=!1,d="",e=ll;null!==b&&void 0!==b&&(!0===b.unstable_strictMode&&(c=!0),void 0!==b.identifierPrefix&&(d=b.identifierPrefix),void 0!==b.onRecoverableError&&(e=b.onRecoverableError));b=cl(a,1,!1,null,null,c,!1,d,e);a[uf]=b.current;sf(8===a.nodeType?a.parentNode:a);return new ml(b)};
exports.findDOMNode=function(a){if(null==a)return null;if(1===a.nodeType)return a;var b=a._reactInternals;if(void 0===b){if("function"===typeof a.render)throw Error(p(188));a=Object.keys(a).join(",");throw Error(p(268,a));}a=Zb(b);a=null===a?null:a.stateNode;return a};exports.flushSync=function(a){return Sk(a)};exports.hydrate=function(a,b,c){if(!pl(b))throw Error(p(200));return sl(null,a,b,!0,c)};
exports.hydrateRoot=function(a,b,c){if(!ol(a))throw Error(p(405));var d=null!=c&&c.hydratedSources||null,e=!1,f="",g=ll;null!==c&&void 0!==c&&(!0===c.unstable_strictMode&&(e=!0),void 0!==c.identifierPrefix&&(f=c.identifierPrefix),void 0!==c.onRecoverableError&&(g=c.onRecoverableError));b=fl(b,null,a,1,null!=c?c:null,e,!1,f,g);a[uf]=b.current;sf(a);if(d)for(a=0;a<d.length;a++)c=d[a],e=c._getVersion,e=e(c._source),null==b.mutableSourceEagerHydrationData?b.mutableSourceEagerHydrationData=[c,e]:b.mutableSourceEagerHydrationData.push(c,
e);return new nl(b)};exports.render=function(a,b,c){if(!pl(b))throw Error(p(200));return sl(null,a,b,!1,c)};exports.unmountComponentAtNode=function(a){if(!pl(a))throw Error(p(40));return a._reactRootContainer?(Sk(function(){sl(null,null,a,!1,function(){a._reactRootContainer=null;a[uf]=null})}),!0):!1};exports.unstable_batchedUpdates=Rk;
exports.unstable_renderSubtreeIntoContainer=function(a,b,c,d){if(!pl(c))throw Error(p(200));if(null==a||void 0===a._reactInternals)throw Error(p(38));return sl(a,b,c,!1,d)};exports.version="18.2.0-next-9e3b772b8-20220608";


/***/ }),

/***/ 745:
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {

var __webpack_unused_export__;


var m = __webpack_require__(935);
if (true) {
  exports.s = m.createRoot;
  __webpack_unused_export__ = m.hydrateRoot;
} else { var i; }


/***/ }),

/***/ 935:
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {



function checkDCE() {
  /* global __REACT_DEVTOOLS_GLOBAL_HOOK__ */
  if (
    typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ === 'undefined' ||
    typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE !== 'function'
  ) {
    return;
  }
  if (false) {}
  try {
    // Verify that the code above has been dead code eliminated (DCE'd).
    __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(checkDCE);
  } catch (err) {
    // DevTools shouldn't crash React, no matter what.
    // We should still report in case we break this code.
    console.error(err);
  }
}

if (true) {
  // DCE check should happen before ReactDOM bundle executes so that
  // DevTools can report bad minification during injection.
  checkDCE();
  module.exports = __webpack_require__(448);
} else {}


/***/ }),

/***/ 408:
/***/ ((__unused_webpack_module, exports) => {

/**
 * @license React
 * react.production.min.js
 *
 * Copyright (c) Facebook, Inc. and its affiliates.
 *
 * This source code is licensed under the MIT license found in the
 * LICENSE file in the root directory of this source tree.
 */
var l=Symbol.for("react.element"),n=Symbol.for("react.portal"),p=Symbol.for("react.fragment"),q=Symbol.for("react.strict_mode"),r=Symbol.for("react.profiler"),t=Symbol.for("react.provider"),u=Symbol.for("react.context"),v=Symbol.for("react.forward_ref"),w=Symbol.for("react.suspense"),x=Symbol.for("react.memo"),y=Symbol.for("react.lazy"),z=Symbol.iterator;function A(a){if(null===a||"object"!==typeof a)return null;a=z&&a[z]||a["@@iterator"];return"function"===typeof a?a:null}
var B={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},C=Object.assign,D={};function E(a,b,e){this.props=a;this.context=b;this.refs=D;this.updater=e||B}E.prototype.isReactComponent={};
E.prototype.setState=function(a,b){if("object"!==typeof a&&"function"!==typeof a&&null!=a)throw Error("setState(...): takes an object of state variables to update or a function which returns an object of state variables.");this.updater.enqueueSetState(this,a,b,"setState")};E.prototype.forceUpdate=function(a){this.updater.enqueueForceUpdate(this,a,"forceUpdate")};function F(){}F.prototype=E.prototype;function G(a,b,e){this.props=a;this.context=b;this.refs=D;this.updater=e||B}var H=G.prototype=new F;
H.constructor=G;C(H,E.prototype);H.isPureReactComponent=!0;var I=Array.isArray,J=Object.prototype.hasOwnProperty,K={current:null},L={key:!0,ref:!0,__self:!0,__source:!0};
function M(a,b,e){var d,c={},k=null,h=null;if(null!=b)for(d in void 0!==b.ref&&(h=b.ref),void 0!==b.key&&(k=""+b.key),b)J.call(b,d)&&!L.hasOwnProperty(d)&&(c[d]=b[d]);var g=arguments.length-2;if(1===g)c.children=e;else if(1<g){for(var f=Array(g),m=0;m<g;m++)f[m]=arguments[m+2];c.children=f}if(a&&a.defaultProps)for(d in g=a.defaultProps,g)void 0===c[d]&&(c[d]=g[d]);return{$$typeof:l,type:a,key:k,ref:h,props:c,_owner:K.current}}
function N(a,b){return{$$typeof:l,type:a.type,key:b,ref:a.ref,props:a.props,_owner:a._owner}}function O(a){return"object"===typeof a&&null!==a&&a.$$typeof===l}function escape(a){var b={"=":"=0",":":"=2"};return"$"+a.replace(/[=:]/g,function(a){return b[a]})}var P=/\/+/g;function Q(a,b){return"object"===typeof a&&null!==a&&null!=a.key?escape(""+a.key):b.toString(36)}
function R(a,b,e,d,c){var k=typeof a;if("undefined"===k||"boolean"===k)a=null;var h=!1;if(null===a)h=!0;else switch(k){case "string":case "number":h=!0;break;case "object":switch(a.$$typeof){case l:case n:h=!0}}if(h)return h=a,c=c(h),a=""===d?"."+Q(h,0):d,I(c)?(e="",null!=a&&(e=a.replace(P,"$&/")+"/"),R(c,b,e,"",function(a){return a})):null!=c&&(O(c)&&(c=N(c,e+(!c.key||h&&h.key===c.key?"":(""+c.key).replace(P,"$&/")+"/")+a)),b.push(c)),1;h=0;d=""===d?".":d+":";if(I(a))for(var g=0;g<a.length;g++){k=
a[g];var f=d+Q(k,g);h+=R(k,b,e,f,c)}else if(f=A(a),"function"===typeof f)for(a=f.call(a),g=0;!(k=a.next()).done;)k=k.value,f=d+Q(k,g++),h+=R(k,b,e,f,c);else if("object"===k)throw b=String(a),Error("Objects are not valid as a React child (found: "+("[object Object]"===b?"object with keys {"+Object.keys(a).join(", ")+"}":b)+"). If you meant to render a collection of children, use an array instead.");return h}
function S(a,b,e){if(null==a)return a;var d=[],c=0;R(a,d,"","",function(a){return b.call(e,a,c++)});return d}function T(a){if(-1===a._status){var b=a._result;b=b();b.then(function(b){if(0===a._status||-1===a._status)a._status=1,a._result=b},function(b){if(0===a._status||-1===a._status)a._status=2,a._result=b});-1===a._status&&(a._status=0,a._result=b)}if(1===a._status)return a._result.default;throw a._result;}
var U={current:null},V={transition:null},W={ReactCurrentDispatcher:U,ReactCurrentBatchConfig:V,ReactCurrentOwner:K};exports.Children={map:S,forEach:function(a,b,e){S(a,function(){b.apply(this,arguments)},e)},count:function(a){var b=0;S(a,function(){b++});return b},toArray:function(a){return S(a,function(a){return a})||[]},only:function(a){if(!O(a))throw Error("React.Children.only expected to receive a single React element child.");return a}};exports.Component=E;exports.Fragment=p;
exports.Profiler=r;exports.PureComponent=G;exports.StrictMode=q;exports.Suspense=w;exports.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED=W;
exports.cloneElement=function(a,b,e){if(null===a||void 0===a)throw Error("React.cloneElement(...): The argument must be a React element, but you passed "+a+".");var d=C({},a.props),c=a.key,k=a.ref,h=a._owner;if(null!=b){void 0!==b.ref&&(k=b.ref,h=K.current);void 0!==b.key&&(c=""+b.key);if(a.type&&a.type.defaultProps)var g=a.type.defaultProps;for(f in b)J.call(b,f)&&!L.hasOwnProperty(f)&&(d[f]=void 0===b[f]&&void 0!==g?g[f]:b[f])}var f=arguments.length-2;if(1===f)d.children=e;else if(1<f){g=Array(f);
for(var m=0;m<f;m++)g[m]=arguments[m+2];d.children=g}return{$$typeof:l,type:a.type,key:c,ref:k,props:d,_owner:h}};exports.createContext=function(a){a={$$typeof:u,_currentValue:a,_currentValue2:a,_threadCount:0,Provider:null,Consumer:null,_defaultValue:null,_globalName:null};a.Provider={$$typeof:t,_context:a};return a.Consumer=a};exports.createElement=M;exports.createFactory=function(a){var b=M.bind(null,a);b.type=a;return b};exports.createRef=function(){return{current:null}};
exports.forwardRef=function(a){return{$$typeof:v,render:a}};exports.isValidElement=O;exports.lazy=function(a){return{$$typeof:y,_payload:{_status:-1,_result:a},_init:T}};exports.memo=function(a,b){return{$$typeof:x,type:a,compare:void 0===b?null:b}};exports.startTransition=function(a){var b=V.transition;V.transition={};try{a()}finally{V.transition=b}};exports.unstable_act=function(){throw Error("act(...) is not supported in production builds of React.");};
exports.useCallback=function(a,b){return U.current.useCallback(a,b)};exports.useContext=function(a){return U.current.useContext(a)};exports.useDebugValue=function(){};exports.useDeferredValue=function(a){return U.current.useDeferredValue(a)};exports.useEffect=function(a,b){return U.current.useEffect(a,b)};exports.useId=function(){return U.current.useId()};exports.useImperativeHandle=function(a,b,e){return U.current.useImperativeHandle(a,b,e)};
exports.useInsertionEffect=function(a,b){return U.current.useInsertionEffect(a,b)};exports.useLayoutEffect=function(a,b){return U.current.useLayoutEffect(a,b)};exports.useMemo=function(a,b){return U.current.useMemo(a,b)};exports.useReducer=function(a,b,e){return U.current.useReducer(a,b,e)};exports.useRef=function(a){return U.current.useRef(a)};exports.useState=function(a){return U.current.useState(a)};exports.useSyncExternalStore=function(a,b,e){return U.current.useSyncExternalStore(a,b,e)};
exports.useTransition=function(){return U.current.useTransition()};exports.version="18.2.0";


/***/ }),

/***/ 294:
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {



if (true) {
  module.exports = __webpack_require__(408);
} else {}


/***/ }),

/***/ 53:
/***/ ((__unused_webpack_module, exports) => {

/**
 * @license React
 * scheduler.production.min.js
 *
 * Copyright (c) Facebook, Inc. and its affiliates.
 *
 * This source code is licensed under the MIT license found in the
 * LICENSE file in the root directory of this source tree.
 */
function f(a,b){var c=a.length;a.push(b);a:for(;0<c;){var d=c-1>>>1,e=a[d];if(0<g(e,b))a[d]=b,a[c]=e,c=d;else break a}}function h(a){return 0===a.length?null:a[0]}function k(a){if(0===a.length)return null;var b=a[0],c=a.pop();if(c!==b){a[0]=c;a:for(var d=0,e=a.length,w=e>>>1;d<w;){var m=2*(d+1)-1,C=a[m],n=m+1,x=a[n];if(0>g(C,c))n<e&&0>g(x,C)?(a[d]=x,a[n]=c,d=n):(a[d]=C,a[m]=c,d=m);else if(n<e&&0>g(x,c))a[d]=x,a[n]=c,d=n;else break a}}return b}
function g(a,b){var c=a.sortIndex-b.sortIndex;return 0!==c?c:a.id-b.id}if("object"===typeof performance&&"function"===typeof performance.now){var l=performance;exports.unstable_now=function(){return l.now()}}else{var p=Date,q=p.now();exports.unstable_now=function(){return p.now()-q}}var r=[],t=[],u=1,v=null,y=3,z=!1,A=!1,B=!1,D="function"===typeof setTimeout?setTimeout:null,E="function"===typeof clearTimeout?clearTimeout:null,F="undefined"!==typeof setImmediate?setImmediate:null;
"undefined"!==typeof navigator&&void 0!==navigator.scheduling&&void 0!==navigator.scheduling.isInputPending&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function G(a){for(var b=h(t);null!==b;){if(null===b.callback)k(t);else if(b.startTime<=a)k(t),b.sortIndex=b.expirationTime,f(r,b);else break;b=h(t)}}function H(a){B=!1;G(a);if(!A)if(null!==h(r))A=!0,I(J);else{var b=h(t);null!==b&&K(H,b.startTime-a)}}
function J(a,b){A=!1;B&&(B=!1,E(L),L=-1);z=!0;var c=y;try{G(b);for(v=h(r);null!==v&&(!(v.expirationTime>b)||a&&!M());){var d=v.callback;if("function"===typeof d){v.callback=null;y=v.priorityLevel;var e=d(v.expirationTime<=b);b=exports.unstable_now();"function"===typeof e?v.callback=e:v===h(r)&&k(r);G(b)}else k(r);v=h(r)}if(null!==v)var w=!0;else{var m=h(t);null!==m&&K(H,m.startTime-b);w=!1}return w}finally{v=null,y=c,z=!1}}var N=!1,O=null,L=-1,P=5,Q=-1;
function M(){return exports.unstable_now()-Q<P?!1:!0}function R(){if(null!==O){var a=exports.unstable_now();Q=a;var b=!0;try{b=O(!0,a)}finally{b?S():(N=!1,O=null)}}else N=!1}var S;if("function"===typeof F)S=function(){F(R)};else if("undefined"!==typeof MessageChannel){var T=new MessageChannel,U=T.port2;T.port1.onmessage=R;S=function(){U.postMessage(null)}}else S=function(){D(R,0)};function I(a){O=a;N||(N=!0,S())}function K(a,b){L=D(function(){a(exports.unstable_now())},b)}
exports.unstable_IdlePriority=5;exports.unstable_ImmediatePriority=1;exports.unstable_LowPriority=4;exports.unstable_NormalPriority=3;exports.unstable_Profiling=null;exports.unstable_UserBlockingPriority=2;exports.unstable_cancelCallback=function(a){a.callback=null};exports.unstable_continueExecution=function(){A||z||(A=!0,I(J))};
exports.unstable_forceFrameRate=function(a){0>a||125<a?console.error("forceFrameRate takes a positive int between 0 and 125, forcing frame rates higher than 125 fps is not supported"):P=0<a?Math.floor(1E3/a):5};exports.unstable_getCurrentPriorityLevel=function(){return y};exports.unstable_getFirstCallbackNode=function(){return h(r)};exports.unstable_next=function(a){switch(y){case 1:case 2:case 3:var b=3;break;default:b=y}var c=y;y=b;try{return a()}finally{y=c}};exports.unstable_pauseExecution=function(){};
exports.unstable_requestPaint=function(){};exports.unstable_runWithPriority=function(a,b){switch(a){case 1:case 2:case 3:case 4:case 5:break;default:a=3}var c=y;y=a;try{return b()}finally{y=c}};
exports.unstable_scheduleCallback=function(a,b,c){var d=exports.unstable_now();"object"===typeof c&&null!==c?(c=c.delay,c="number"===typeof c&&0<c?d+c:d):c=d;switch(a){case 1:var e=-1;break;case 2:e=250;break;case 5:e=1073741823;break;case 4:e=1E4;break;default:e=5E3}e=c+e;a={id:u++,callback:b,priorityLevel:a,startTime:c,expirationTime:e,sortIndex:-1};c>d?(a.sortIndex=c,f(t,a),null===h(r)&&a===h(t)&&(B?(E(L),L=-1):B=!0,K(H,c-d))):(a.sortIndex=e,f(r,a),A||z||(A=!0,I(J)));return a};
exports.unstable_shouldYield=M;exports.unstable_wrapCallback=function(a){var b=y;return function(){var c=y;y=b;try{return a.apply(this,arguments)}finally{y=c}}};


/***/ }),

/***/ 840:
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {



if (true) {
  module.exports = __webpack_require__(53);
} else {}


/***/ })

/******/ 	});
/************************************************************************/
/******/ 	// The module cache
/******/ 	var __webpack_module_cache__ = {};
/******/ 	
/******/ 	// The require function
/******/ 	function __webpack_require__(moduleId) {
/******/ 		// Check if module is in cache
/******/ 		var cachedModule = __webpack_module_cache__[moduleId];
/******/ 		if (cachedModule !== undefined) {
/******/ 			return cachedModule.exports;
/******/ 		}
/******/ 		// Create a new module (and put it into the cache)
/******/ 		var module = __webpack_module_cache__[moduleId] = {
/******/ 			// no module.id needed
/******/ 			// no module.loaded needed
/******/ 			exports: {}
/******/ 		};
/******/ 	
/******/ 		// Execute the module function
/******/ 		__webpack_modules__[moduleId](module, module.exports, __webpack_require__);
/******/ 	
/******/ 		// Return the exports of the module
/******/ 		return module.exports;
/******/ 	}
/******/ 	
/************************************************************************/
/******/ 	/* webpack/runtime/create fake namespace object */
/******/ 	(() => {
/******/ 		var getProto = Object.getPrototypeOf ? (obj) => (Object.getPrototypeOf(obj)) : (obj) => (obj.__proto__);
/******/ 		var leafPrototypes;
/******/ 		// 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 & 16: return value when it's Promise-like
/******/ 		// mode & 8|1: behave like require
/******/ 		__webpack_require__.t = function(value, mode) {
/******/ 			if(mode & 1) value = this(value);
/******/ 			if(mode & 8) return value;
/******/ 			if(typeof value === 'object' && value) {
/******/ 				if((mode & 4) && value.__esModule) return value;
/******/ 				if((mode & 16) && typeof value.then === 'function') return value;
/******/ 			}
/******/ 			var ns = Object.create(null);
/******/ 			__webpack_require__.r(ns);
/******/ 			var def = {};
/******/ 			leafPrototypes = leafPrototypes || [null, getProto({}), getProto([]), getProto(getProto)];
/******/ 			for(var current = mode & 2 && value; typeof current == 'object' && !~leafPrototypes.indexOf(current); current = getProto(current)) {
/******/ 				Object.getOwnPropertyNames(current).forEach((key) => (def[key] = () => (value[key])));
/******/ 			}
/******/ 			def['default'] = () => (value);
/******/ 			__webpack_require__.d(ns, def);
/******/ 			return ns;
/******/ 		};
/******/ 	})();
/******/ 	
/******/ 	/* webpack/runtime/define property getters */
/******/ 	(() => {
/******/ 		// define getter functions for harmony exports
/******/ 		__webpack_require__.d = (exports, definition) => {
/******/ 			for(var key in definition) {
/******/ 				if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
/******/ 					Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
/******/ 				}
/******/ 			}
/******/ 		};
/******/ 	})();
/******/ 	
/******/ 	/* webpack/runtime/hasOwnProperty shorthand */
/******/ 	(() => {
/******/ 		__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
/******/ 	})();
/******/ 	
/******/ 	/* webpack/runtime/make namespace object */
/******/ 	(() => {
/******/ 		// define __esModule on exports
/******/ 		__webpack_require__.r = (exports) => {
/******/ 			if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ 				Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ 			}
/******/ 			Object.defineProperty(exports, '__esModule', { value: true });
/******/ 		};
/******/ 	})();
/******/ 	
/************************************************************************/
var __webpack_exports__ = {};
// This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk.
(() => {
__webpack_require__.r(__webpack_exports__);
/* harmony import */ var _App__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(242);
/* harmony import */ var react_dom_client__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(745);
/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(294);
function _createForOfIteratorHelper(o, allowArrayLike) {var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"];if (!it) {if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") {if (it) o = it;var i = 0;var F = function F() {};return { s: F, n: function n() {if (i >= o.length) return { done: true };return { done: false, value: o[i++] };}, e: function e(_e) {throw _e;}, f: F };}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");}var normalCompletion = true,didErr = false,err;return { s: function s() {it = it.call(o);}, n: function n() {var step = it.next();normalCompletion = step.done;return step;}, e: function e(_e2) {didErr = true;err = _e2;}, f: function f() {try {if (!normalCompletion && it["return"] != null) it["return"]();} finally {if (didErr) throw err;}} };}function _unsupportedIterableToArray(o, minLen) {if (!o) return;if (typeof o === "string") return _arrayLikeToArray(o, minLen);var n = Object.prototype.toString.call(o).slice(8, -1);if (n === "Object" && o.constructor) n = o.constructor.name;if (n === "Map" || n === "Set") return Array.from(o);if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);}function _arrayLikeToArray(arr, len) {if (len == null || len > arr.length) len = arr.length;for (var i = 0, arr2 = new Array(len); i < len; i++) {arr2[i] = arr[i];}return arr2;}





getData(function (pages) {var _iterator = _createForOfIteratorHelper(
    pages),_step;try {for (_iterator.s(); !(_step = _iterator.n()).done;) {var page = _step.value;
      for (var _i = 0, _arr = page.components; _i < _arr.length; _i++) {var component = _arr[_i];
        component.previousValue = component.value;

        if (component.validate != null) {
          component.validate = eval(component.validate);
        }
      }
    }} catch (err) {_iterator.e(err);} finally {_iterator.f();}

  var container = document.getElementById("root");
  // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
  var root = (0,react_dom_client__WEBPACK_IMPORTED_MODULE_1__/* .createRoot */ .s)(container);
  root.render( /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_2__.createElement(_App__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z, { pages: pages }));
});
})();

/******/ 	return __webpack_exports__;
/******/ })()
;
});";/***/},/***/171:/***/module=>{module.exports="#relayContainer{margin:1rem;font-family:Arial,Helvetica,sans-serif}#notificationsContainer{pointer-events:none;position:fixed;top:5%;left:70%;transform:translateX(-50%);z-index:999}img{display:block;margin:auto}input.stringcontainer{background-color:#fff;border-radius:5px;border:1px solid #121943;height:24px;margin:auto;display:flex;padding-left:5px}input.interrupt{width:100%;border-color:darkred;background-color:#f1948a;color:darkred;margin:10px 0px;cursor:pointer}input.interrupt:hover{background-color:#f5867a}input.interrupt:active{background-color:#f77163}input.save,input.interrupt{margin:auto;display:block;font-size:x-large;padding:5px 25px;border-radius:10px}.notification{border:3px solid #00529b;background-color:#bde5f8;width:fit-content;margin-right:auto;margin-left:auto;border-radius:40px;color:#00529b;padding:7px 60px;animation:2s fadeOut 5s 1 forwards;cursor:default;pointer-events:auto}@keyframes fadeOut{0%{opacity:1}99%{height:100%}100%{opacity:0;height:0}}td{padding:.5rem}.toggle{align-items:center;border-radius:100px;display:flex;font-weight:700;margin-bottom:16px}.toggle:last-of-type{margin:0}.toggle__input{clip:rect(0 0 0 0);clip-path:inset(50%);height:1px;overflow:hidden;position:absolute;white-space:nowrap;width:1px}.toggle__input:not([disabled]):active+.toggle-track,.toggle__input:not([disabled]):focus+.toggle-track{border:1px solid rgba(0,0,0,0);box-shadow:0px 0px 0px 2px #121943}.toggle__input:disabled+.toggle-track{cursor:not-allowed;opacity:.7}.toggle-track{background:#fff;border:1px solid #5a72b5;border-radius:100px;cursor:pointer;display:flex;height:30px;margin:auto;position:relative;width:60px}.toggle-indicator{align-items:center;background:#121943;border-radius:24px;bottom:2px;display:flex;height:24px;justify-content:center;left:2px;outline:solid 2px rgba(0,0,0,0);position:absolute;transition:.4s;width:24px}.checkMark{fill:#fff;height:20px;width:20px;opacity:0;transition:opacity .4s ease-in-out}.dropdowncontainer{padding:8px 16px;border:1px solid rgba(0,0,0,0);border-color:#000}input[value=true]+.toggle-track .toggle-indicator{background:#121943;transform:translateX(30px)}input[value=true]+.toggle-track .toggle-indicator .checkMark{opacity:1;transition:opacity .4s ease-in-out}@media screen and (-ms-high-contrast: active){.toggle-track{border-radius:0;background-color:red}}.topBar{display:flex}.tabEntry{margin-right:10px;border-radius:10px;background-color:#333}.tabEntry a{display:block;color:#fff;text-align:center;padding:6px;text-decoration:none}.tabEntry a[aria-current=page]{background-color:#00529b;border-radius:10px}.tabEntry a:hover[aria-current=page]{background-color:#002c53;border-radius:10px}.tabEntry a:hover{background-color:#111;border-radius:10px}.setting{position:relative}.setting .settingNameHover{visibility:hidden;background-color:#cacaca;color:#000;text-align:center;border-radius:6px;border-color:#000;position:absolute;z-index:1}.setting:hover .settingNameHover{visibility:visible;padding:5px;margin-left:15px}.hoverBox{position:relative;white-space:nowrap}.settingInput .settingDefaultHover{visibility:hidden;color:#666;position:absolute;z-index:1;left:50%;transform:translateX(-50%)}.settingInput:hover .settingDefaultHover{visibility:visible}.invalid-setting input,.invalid-setting select,.invalid-setting .toggle-track{background:pink !important}.invalid-reason{text-align:center}.invalid-reason small{padding:0px 5px;border-radius:10px;color:red}\n";/***/},/***/530:/***/module=>{module.exports=__webpack_require__(530);/***/}/******/};/************************************************************************/ /******/ // The module cache +/******/var __webpack_module_cache__={};/******/ /******/ // The require function +/******/function __nested_webpack_require_494289__(moduleId){/******/ // Check if module is in cache +/******/var cachedModule=__webpack_module_cache__[moduleId];/******/if(cachedModule!==undefined){/******/return cachedModule.exports;/******/}/******/ // Create a new module (and put it into the cache) +/******/var module=__webpack_module_cache__[moduleId]={/******/ // no module.id needed +/******/ // no module.loaded needed +/******/exports:{}/******/};/******/ /******/ // Execute the module function +/******/__webpack_modules__[moduleId](module,module.exports,__nested_webpack_require_494289__);/******/ /******/ // Return the exports of the module +/******/return module.exports;/******/}/******/ /************************************************************************/ /******/ /* webpack/runtime/compat get default export */ /******/(()=>{/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/__nested_webpack_require_494289__.n=module=>{/******/var getter=module&&module.__esModule?/******/()=>module['default']:/******/()=>module;/******/__nested_webpack_require_494289__.d(getter,{a:getter});/******/return getter;/******/};/******/})();/******/ /******/ /* webpack/runtime/define property getters */ /******/(()=>{/******/ // define getter functions for harmony exports +/******/__nested_webpack_require_494289__.d=(exports,definition)=>{/******/for(var key in definition){/******/if(__nested_webpack_require_494289__.o(definition,key)&&!__nested_webpack_require_494289__.o(exports,key)){/******/Object.defineProperty(exports,key,{enumerable:true,get:definition[key]});/******/}/******/}/******/};/******/})();/******/ /******/ /* webpack/runtime/hasOwnProperty shorthand */ /******/(()=>{/******/__nested_webpack_require_494289__.o=(obj,prop)=>Object.prototype.hasOwnProperty.call(obj,prop);/******/})();/******/ /******/ /* webpack/runtime/make namespace object */ /******/(()=>{/******/ // define __esModule on exports +/******/__nested_webpack_require_494289__.r=exports=>{/******/if(typeof Symbol!=='undefined'&&Symbol.toStringTag){/******/Object.defineProperty(exports,Symbol.toStringTag,{value:'Module'});/******/}/******/Object.defineProperty(exports,'__esModule',{value:true});/******/};/******/})();/******/ /************************************************************************/var __nested_webpack_exports__={};// This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk. +(()=>{__nested_webpack_require_494289__.r(__nested_webpack_exports__);/* harmony export */__nested_webpack_require_494289__.d(__nested_webpack_exports__,{/* harmony export */"generateHTML":()=>/* binding */_generateHTML,/* harmony export */"getPagePath":()=>/* binding */_getPagePath,/* harmony export */"handleApiRequest":()=>/* binding */_handleApiRequest,/* harmony export */"parseCssFromFile":()=>/* binding */_parseCssFromFile,/* harmony export */"parsePageFromFile":()=>/* binding */_parsePageFromFile,/* harmony export */"parsePageFromJson":()=>/* binding */_parsePageFromJson/* harmony export */});/* harmony import */var kolmafia__WEBPACK_IMPORTED_MODULE_0__=__nested_webpack_require_494289__(530);/* harmony import */var kolmafia__WEBPACK_IMPORTED_MODULE_0___default=/*#__PURE__*/__nested_webpack_require_494289__.n(kolmafia__WEBPACK_IMPORTED_MODULE_0__);function _toConsumableArray(arr){return _arrayWithoutHoles(arr)||_iterableToArray(arr)||_unsupportedIterableToArray(arr)||_nonIterableSpread();}function _nonIterableSpread(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");}function _iterableToArray(iter){if(typeof Symbol!=="undefined"&&iter[Symbol.iterator]!=null||iter["@@iterator"]!=null)return Array.from(iter);}function _arrayWithoutHoles(arr){if(Array.isArray(arr))return _arrayLikeToArray(arr);}function _slicedToArray(arr,i){return _arrayWithHoles(arr)||_iterableToArrayLimit(arr,i)||_unsupportedIterableToArray(arr,i)||_nonIterableRest();}function _nonIterableRest(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");}function _iterableToArrayLimit(arr,i){var _i=arr==null?null:typeof Symbol!=="undefined"&&arr[Symbol.iterator]||arr["@@iterator"];if(_i==null)return;var _arr=[];var _n=true;var _d=false;var _s,_e;try{for(_i=_i.call(arr);!(_n=(_s=_i.next()).done);_n=true){_arr.push(_s.value);if(i&&_arr.length===i)break;}}catch(err){_d=true;_e=err;}finally{try{if(!_n&&_i["return"]!=null)_i["return"]();}finally{if(_d)throw _e;}}return _arr;}function _arrayWithHoles(arr){if(Array.isArray(arr))return arr;}function _createForOfIteratorHelper(o,allowArrayLike){var it=typeof Symbol!=="undefined"&&o[Symbol.iterator]||o["@@iterator"];if(!it){if(Array.isArray(o)||(it=_unsupportedIterableToArray(o))||allowArrayLike&&o&&typeof o.length==="number"){if(it)o=it;var i=0;var F=function F(){};return{s:F,n:function n(){if(i>=o.length)return{done:true};return{done:false,value:o[i++]};},e:function e(_e2){throw _e2;},f:F};}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");}var normalCompletion=true,didErr=false,err;return{s:function s(){it=it.call(o);},n:function n(){var step=it.next();normalCompletion=step.done;return step;},e:function e(_e3){didErr=true;err=_e3;},f:function f(){try{if(!normalCompletion&&it.return!=null)it.return();}finally{if(didErr)throw err;}}};}function _unsupportedIterableToArray(o,minLen){if(!o)return;if(typeof o==="string")return _arrayLikeToArray(o,minLen);var n=Object.prototype.toString.call(o).slice(8,-1);if(n==="Object"&&o.constructor)n=o.constructor.name;if(n==="Map"||n==="Set")return Array.from(o);if(n==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))return _arrayLikeToArray(o,minLen);}function _arrayLikeToArray(arr,len){if(len==null||len>arr.length)len=arr.length;for(var i=0,arr2=new Array(len);ip!=null);var _iterator3=_createForOfIteratorHelper(pages),_step3;try{for(_iterator3.s();!(_step3=_iterator3.n()).done;){var _page$file;var page=_step3.value;page.file=(_page$file=page.file)!==null&&_page$file!==void 0?_page$file:page.page;validateComponents(page.components);}}catch(err){_iterator3.e(err);}finally{_iterator3.f();}var buffer=[];var cssFiles=[];if(extraHtml&&extraHtml.cssFiles){cssFiles.push.apply(cssFiles,_toConsumableArray(extraHtml.cssFiles));}buffer.push("");cssFiles.forEach(s=>{buffer.push(""));});buffer.push("");buffer.push("");buffer.push('
');buffer.push("");// include react script +buffer.push(""));return buffer.join("\n");}function _getPagePath(file){var fileName=file.includes("/")?file:"relay/shared_relay/pages/"+file+".json";if(!fileName.endsWith(".json")&&(0,kolmafia__WEBPACK_IMPORTED_MODULE_0__.fileToBuffer)(fileName).length==0){fileName+=".json";}return fileName;}/** + * Parses from relay/shared_relay/pages/ if no slashes are in the name, otherwise expects a valid json file + */function _parsePageFromFile(file){var data=(0,kolmafia__WEBPACK_IMPORTED_MODULE_0__.fileToBuffer)(_getPagePath(file));return _parsePageFromJson(file,data);}function _parseCssFromFile(file){var fileName=file.includes("/")?file:"shared_relay/pages/"+file+".css";if(!fileName.endsWith(".css")){fileName+=".css";}var data=(0,kolmafia__WEBPACK_IMPORTED_MODULE_0__.fileToBuffer)(fileName);if(data.length==0){return null;}return fileName;}function _parsePageFromJson(id,jsonData){if(jsonData.length==0){return null;}var subpage=JSON.parse(jsonData);subpage.file=id;for(var _i2=0,_arr2=subpage.components;_i2<_arr2.length;_i2++){var _button$dropdown;var button=_arr2[_i2];if(button.type!="dropdown"){continue;}if(button.dropdown==null){button.dropdown=[];}else if(typeof button.dropdown[0]=="string"){button.dropdown=button.dropdown.map(s=>{return{display:s,value:s};});}if(button.dropdownFiller==null){continue;}var data=eval(button.dropdownFiller).map(_ref=>{var _ref2=_slicedToArray(_ref,2),display=_ref2[0],value=_ref2[1];return{display:display,value:value};});(_button$dropdown=button.dropdown).push.apply(_button$dropdown,_toConsumableArray(data));}return subpage;}})();var __webpack_export_target__=exports;for(var i in __nested_webpack_exports__)__webpack_export_target__[i]=__nested_webpack_exports__[i];if(__nested_webpack_exports__.__esModule)Object.defineProperty(__webpack_export_target__,"__esModule",{value:true});/******/})(); + +/***/ }), + +/***/ 530: +/***/ ((module) => { + +"use strict"; +module.exports = require("kolmafia"); + +/***/ }) + +/******/ }); +/************************************************************************/ +/******/ // The module cache +/******/ var __webpack_module_cache__ = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ // Check if module is in cache +/******/ var cachedModule = __webpack_module_cache__[moduleId]; +/******/ if (cachedModule !== undefined) { +/******/ return cachedModule.exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = __webpack_module_cache__[moduleId] = { +/******/ // no module.id needed +/******/ // no module.loaded needed +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/define property getters */ +/******/ (() => { +/******/ // define getter functions for harmony exports +/******/ __webpack_require__.d = (exports, definition) => { +/******/ for(var key in definition) { +/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { +/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); +/******/ } +/******/ } +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/hasOwnProperty shorthand */ +/******/ (() => { +/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) +/******/ })(); +/******/ +/******/ /* webpack/runtime/make namespace object */ +/******/ (() => { +/******/ // define __esModule on exports +/******/ __webpack_require__.r = (exports) => { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ })(); +/******/ +/************************************************************************/ +var __webpack_exports__ = {}; +// This entry need to be wrapped in an IIFE because it need to be in strict mode. +(() => { +"use strict"; +// ESM COMPAT FLAG +__webpack_require__.r(__webpack_exports__); + +// EXPORTS +__webpack_require__.d(__webpack_exports__, { + main: () => (/* binding */ main) +}); + +// EXTERNAL MODULE: external "kolmafia" +var external_kolmafia_ = __webpack_require__(530); +;// CONCATENATED MODULE: ./node_modules/grimoire-kolmafia/dist/args.js +function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; } +function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } +function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } +function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } +function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } } +function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } +function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); } +function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } +/* eslint-disable @typescript-eslint/no-explicit-any */ + +var Args = /*#__PURE__*/function () { + function Args() { + _classCallCheck(this, Args); + } + _createClass(Args, null, [{ + key: "custom", + value: function custom(spec, _parser, valueHelpName) { + var _a, _b; + var raw_options = (_a = spec.options) === null || _a === void 0 ? void 0 : _a.map(option => option[0]); + // Check that the default value actually appears in the options. + if ("default" in spec && raw_options) { + if (!raw_options.includes(spec.default)) { + throw "Invalid default value ".concat(spec.default); + } + } + return _objectSpread(_objectSpread({}, spec), {}, { + valueHelpName: valueHelpName, + parser: value => { + var parsed_value = _parser(value); + if (parsed_value === undefined || parsed_value instanceof ParseError) return parsed_value; + if (raw_options) { + if (!raw_options.includes(parsed_value)) { + return new ParseError("received ".concat(value, " which was not in the allowed options")); + } + } + return parsed_value; + }, + options: (_b = spec.options) === null || _b === void 0 ? void 0 : _b.map(a => ["".concat(a[0]), a[1]]) + }); + } + }, { + key: "arrayFromArg", + value: function arrayFromArg(spec, argFromSpec) { + var _a, _b, _c; + // First, construct a non-array version of this argument. + // We do this by calling argFromSpec in order to extract the parser and + // valueHelpName (to make it easier to define the functions below). + // + // The default argument of an ArraySpec is of type T[], which causes + // problems, so we must remove it. + var spec_without_default = _objectSpread({}, spec); // Avoid "the operand of a 'delete' operator must be optional" + if ("default" in spec_without_default) delete spec_without_default["default"]; + var arg = argFromSpec.call(this, spec_without_default); + // Next, check that all default values actually appear in the options. + var raw_options = (_a = spec.options) === null || _a === void 0 ? void 0 : _a.map(option => option[0]); + if ("default" in spec && raw_options) { + var _iterator = _createForOfIteratorHelper(spec.default), + _step; + try { + for (_iterator.s(); !(_step = _iterator.n()).done;) { + var default_entry = _step.value; + if (!raw_options.includes(default_entry)) throw "Invalid default value ".concat(spec.default); + } + } catch (err) { + _iterator.e(err); + } finally { + _iterator.f(); + } + } + var separator = (_b = spec.separator) !== null && _b !== void 0 ? _b : ","; + var arrayParser = value => { + // Split the array + var values = value.split(separator); + if (!spec.noTrim) values = values.map(v => v.trim()); + // Parse all values, return the first error found if any + var result = values.map(v => arg.parser(v)); + var error = result.find(v => v instanceof ParseError); + if (error) return error; + var failure_index = result.indexOf(undefined); + if (failure_index !== -1) return new ParseError("components expected ".concat(arg.valueHelpName, " but could not parse ").concat(values[failure_index])); + // Otherwise, all values are good + return result; + }; + return _objectSpread(_objectSpread({}, spec), {}, { + valueHelpName: "".concat(arg.valueHelpName).concat(separator, " ").concat(arg.valueHelpName).concat(separator, " ..."), + parser: arrayParser, + options: (_c = spec.options) === null || _c === void 0 ? void 0 : _c.map(a => ["".concat(a[0]), a[1]]) + }); + } + }, { + key: "string", + value: function string(spec) { + return this.custom(spec, value => value, "TEXT"); + } + }, { + key: "strings", + value: function strings(spec) { + return this.arrayFromArg(spec, this.string); + } + }, { + key: "number", + value: function number(spec) { + return this.custom(spec, value => isNaN(Number(value)) ? undefined : Number(value), "NUMBER"); + } + }, { + key: "numbers", + value: function numbers(spec) { + return this.arrayFromArg(spec, this.number); + } + }, { + key: "boolean", + value: function boolean(spec) { + return this.custom(spec, value => { + if (value.toLowerCase() === "true") return true; + if (value.toLowerCase() === "false") return false; + return undefined; + }, "BOOLEAN"); + } + }, { + key: "booleans", + value: function booleans(spec) { + return this.arrayFromArg(spec, this.boolean); + } + }, { + key: "flag", + value: function flag(spec) { + return this.custom(spec, value => { + if (value.toLowerCase() === "true") return true; + if (value.toLowerCase() === "false") return false; + return undefined; + }, "FLAG"); + } + }, { + key: "class", + value: function _class(spec) { + return this.custom(spec, value => { + var match = external_kolmafia_.Class.get(value); + // Class.get does fuzzy matching: + // e.g. Class.get("sc") returns disco bandit. + // To avoid this foot-gun, only return exact matches or id lookups. + if (match.toString().toUpperCase() === value.toString().toUpperCase()) return match; + if (!isNaN(Number(value))) return match; + return undefined; + }, "CLASS"); + } + }, { + key: "classes", + value: function classes(spec) { + return this.arrayFromArg(spec, this.class); + } + }, { + key: "effect", + value: function effect(spec) { + return this.custom(spec, external_kolmafia_.Effect.get, "EFFECT"); + } + }, { + key: "effects", + value: function effects(spec) { + return this.arrayFromArg(spec, this.effect); + } + }, { + key: "familiar", + value: function familiar(spec) { + return this.custom(spec, external_kolmafia_.Familiar.get, "FAMILIAR"); + } + }, { + key: "familiars", + value: function familiars(spec) { + return this.arrayFromArg(spec, this.familiar); + } + }, { + key: "item", + value: function item(spec) { + return this.custom(spec, external_kolmafia_.Item.get, "ITEM"); + } + }, { + key: "items", + value: function items(spec) { + return this.arrayFromArg(spec, this.item); + } + }, { + key: "location", + value: function location(spec) { + return this.custom(spec, external_kolmafia_.Location.get, "LOCATION"); + } + }, { + key: "locations", + value: function locations(spec) { + return this.arrayFromArg(spec, this.location); + } + }, { + key: "monster", + value: function monster(spec) { + return this.custom(spec, external_kolmafia_.Monster.get, "MONSTER"); + } + }, { + key: "monsters", + value: function monsters(spec) { + return this.arrayFromArg(spec, this.monster); + } + }, { + key: "path", + value: function path(spec) { + return this.custom(spec, external_kolmafia_.Path.get, "PATH"); + } + }, { + key: "paths", + value: function paths(spec) { + return this.arrayFromArg(spec, this.path); + } + }, { + key: "skill", + value: function skill(spec) { + return this.custom(spec, external_kolmafia_.Skill.get, "SKILL"); + } + }, { + key: "skills", + value: function skills(spec) { + return this.arrayFromArg(spec, this.skill); + } + /** + * Create a group of arguments that will be printed separately in the help. + * + * Note that keys in the group must still be globally distinct. + * + * @param groupName The display name for the group in help. + * @param args A JS object specifying the script arguments. Its values should + * be {@link Arg} objects (created by Args.string, Args.number, or others) + * or groups of arguments (created by Args.group). + */ + }, { + key: "group", + value: function group(groupName, args) { + return { + name: groupName, + args: args + }; + } + /** + * Create a set of input arguments for a script. + * @param scriptName Prefix for property names; often the name of the script. + * @param scriptHelp Brief description of this script, for the help message. + * @param args A JS object specifying the script arguments. Its values should + * be {@link Arg} objects (created by Args.string, Args.number, or others) + * or groups of arguments (created by Args.group). + * @param options Config options for the args and arg parser. + * @returns An object which can hold parsed argument values. The keys of this + * object are identical to the keys in 'args'. + */ + }, { + key: "create", + value: function create(scriptName, scriptHelp, args, options) { + var _objectSpread2; + _traverse(args, (keySpec, key) => { + if (key === "help" || keySpec.key === "help") throw "help is a reserved argument name"; + }); + var argsWithHelp = _objectSpread(_objectSpread({}, args), {}, { + help: this.flag({ + help: "Show this message and exit.", + setting: "" + }) + }); + // Create an object to hold argument results, with a default value for + // each argument. + var res = _objectSpread(_objectSpread({}, _loadDefaultValues(argsWithHelp)), {}, (_objectSpread2 = {}, _defineProperty(_objectSpread2, specSymbol, argsWithHelp), _defineProperty(_objectSpread2, scriptSymbol, scriptName), _defineProperty(_objectSpread2, scriptHelpSymbol, scriptHelp), _defineProperty(_objectSpread2, optionsSymbol, options !== null && options !== void 0 ? options : {}), _objectSpread2)); + if (options === null || options === void 0 ? void 0 : options.positionalArgs) { + var keys = []; + var metadata = Args.getMetadata(res); + metadata.traverse((keySpec, key) => { + var _a; + keys.push((_a = keySpec.key) !== null && _a !== void 0 ? _a : key); + }); + var _iterator2 = _createForOfIteratorHelper(options.positionalArgs), + _step2; + try { + for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) { + var arg = _step2.value; + if (!keys.includes(arg)) throw "Unknown key for positional arg: ".concat(arg); + } + } catch (err) { + _iterator2.e(err); + } finally { + _iterator2.f(); + } + } + return res; + } + /** + * Parse the command line input into the provided script arguments. + * @param args An object to hold the parsed argument values, from Args.create(*). + * @param command The command line input. + * @param includeSettings If true, parse values from settings as well. + */ + }, { + key: "fill", + value: function fill(args, command) { + var includeSettings = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true; + var _a; + var metadata = Args.getMetadata(args); + // Load the list of keys and flags from the arg spec + var keys = new Set(); + var flags = new Set(); + metadata.traverse((keySpec, key) => { + var _a; + var name = (_a = keySpec.key) !== null && _a !== void 0 ? _a : key; + if (flags.has(name) || keys.has(name)) throw "Duplicate arg key ".concat(name, " is not allowed"); + if (keySpec.valueHelpName === "FLAG") flags.add(name);else keys.add(name); + }); + // Parse values from settings. + if (includeSettings) { + metadata.traverseAndMaybeSet(args, (keySpec, key) => { + var _a, _b; + var setting = (_a = keySpec.setting) !== null && _a !== void 0 ? _a : "".concat(metadata.scriptName, "_").concat((_b = keySpec.key) !== null && _b !== void 0 ? _b : key); + if (setting === "") return undefined; // no setting + var value_str = (0,external_kolmafia_.getProperty)(setting); + if (value_str === "") return undefined; // no setting + return parseAndValidate(keySpec, "Setting ".concat(setting), value_str); + }); + } + // Parse new argments from the command line + if (command === undefined || command === "") return; + var parsed = new CommandParser(command, keys, flags, (_a = metadata.options.positionalArgs) !== null && _a !== void 0 ? _a : []).parse(); + metadata.traverseAndMaybeSet(args, (keySpec, key) => { + var _a; + var argKey = (_a = keySpec.key) !== null && _a !== void 0 ? _a : key; + var value_str = parsed.get(argKey); + if (value_str === undefined) return undefined; // no setting + return parseAndValidate(keySpec, "Argument ".concat(argKey), value_str); + }); + } + /** + * Parse command line input into a new set of script arguments. + * @param scriptName Prefix to use in property names; typically the name of the script. + * @param scriptHelp Brief description of this script, for the help message. + * @param spec An object specifying the script arguments. + * @param command The command line input. + * @param options Config options for the args and arg parser. + */ + }, { + key: "parse", + value: function parse(scriptName, scriptHelp, spec, command, options) { + var args = this.create(scriptName, scriptHelp, spec, options); + this.fill(args, command); + return args; + } + /** + * Print a description of the script arguments to the CLI. + * + * First, all top-level argument descriptions are printed in the order they + * were defined. Afterwards, descriptions for groups of arguments are printed + * in the order they were defined. + * + * @param args An object of parsed arguments, from Args.create(*). + * @param maxOptionsToDisplay If given, do not list more than this many options for each arg. + */ + }, { + key: "showHelp", + value: function showHelp(args, maxOptionsToDisplay) { + var _a; + var metadata = Args.getMetadata(args); + (0,external_kolmafia_.printHtml)("".concat(metadata.scriptHelp)); + (0,external_kolmafia_.printHtml)(""); + (0,external_kolmafia_.printHtml)("".concat((_a = metadata.options.defaultGroupName) !== null && _a !== void 0 ? _a : "Options", ":")); + metadata.traverse((arg, key) => { + var _a, _b, _c, _d, _e; + if (arg.hidden) return; + var nameText = "").concat((_a = arg.key) !== null && _a !== void 0 ? _a : key, ""); + var valueText = arg.valueHelpName === "FLAG" ? "" : "".concat(arg.valueHelpName, ""); + var helpText = (_b = arg.help) !== null && _b !== void 0 ? _b : ""; + var defaultText = "default" in arg ? "[default: ".concat(arg.default, "]") : ""; + var settingText = arg.setting === "" ? "" : "[setting: ".concat((_c = arg.setting) !== null && _c !== void 0 ? _c : "".concat(metadata.scriptName, "_").concat((_d = arg.key) !== null && _d !== void 0 ? _d : key), "]"); + (0,external_kolmafia_.printHtml)("  ".concat([nameText, valueText, "-", helpText, defaultText, settingText].join(" "))); + var valueOptions = (_e = arg.options) !== null && _e !== void 0 ? _e : []; + if (valueOptions.length < (maxOptionsToDisplay !== null && maxOptionsToDisplay !== void 0 ? maxOptionsToDisplay : Number.MAX_VALUE)) { + var _iterator3 = _createForOfIteratorHelper(valueOptions), + _step3; + try { + for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) { + var option = _step3.value; + if (option.length === 1 || option[1] === undefined) { + (0,external_kolmafia_.printHtml)("    ".concat(nameText, " ").concat(option[0])); + } else { + (0,external_kolmafia_.printHtml)("    ".concat(nameText, " ").concat(option[0], " - ").concat(option[1])); + } + } + } catch (err) { + _iterator3.e(err); + } finally { + _iterator3.f(); + } + } + }, group => { + (0,external_kolmafia_.printHtml)(""); + (0,external_kolmafia_.printHtml)("".concat(group.name, ":")); + }); + } + /** + * Load the metadata information for a set of arguments. Only for advanced usage. + * + * @param args A JS object specifying the script arguments. Its values should + * be {@link Arg} objects (created by Args.string, Args.number, or others) + * or groups of arguments (created by Args.group). + * @returns A class containing metadata information. + */ + }, { + key: "getMetadata", + value: function getMetadata(args) { + return new WrappedArgMetadata(args); + } + }]); + return Args; +}(); +var ParseError = /*#__PURE__*/_createClass(function ParseError(message) { + _classCallCheck(this, ParseError); + this.message = message; +}); +/** + * Metadata for the parsed arguments. + * + * This information is hidden within the parsed argument object so that it + * is invisible to the user but available to fill(*) and showHelp(*). + */ +var specSymbol = Symbol("spec"); +var scriptSymbol = Symbol("script"); +var scriptHelpSymbol = Symbol("scriptHelp"); +var optionsSymbol = Symbol("options"); +/** + * Parse a string into a value for a given argument, throwing if the parsing fails. + * @param arg An argument that takes values in T. + * @param source A description of where this value came from, for the error message. + * @param value The value to parse. + * @returns the parsed value. + */ +function parseAndValidate(arg, source, value) { + var parsed_value; + try { + parsed_value = arg.parser(value); + } catch (_a) { + parsed_value = undefined; + } + if (parsed_value === undefined) throw "".concat(source, " expected ").concat(arg.valueHelpName, " but could not parse ").concat(value); + if (parsed_value instanceof ParseError) throw "".concat(source, " ").concat(parsed_value.message); + return parsed_value; +} +/** + * A class that reveals the hidden metadata and specs for arguments. + * + * Only for advanced usage. + */ +var WrappedArgMetadata = /*#__PURE__*/function () { + function WrappedArgMetadata(args) { + _classCallCheck(this, WrappedArgMetadata); + this.spec = args[specSymbol]; + this.scriptName = args[scriptSymbol]; + this.scriptHelp = args[scriptHelpSymbol]; + this.options = args[optionsSymbol]; + } + /** + * Create a parsed args object from this spec using all default values. + */ + _createClass(WrappedArgMetadata, [{ + key: "loadDefaultValues", + value: function loadDefaultValues() { + return _loadDefaultValues(this.spec); + } + /** + * Traverse the spec and possibly generate a value for each argument. + * + * @param result The object to hold the resulting argument values, typically + * the result of loadDefaultValues(). + * @param setTo A function to generate an argument value from each arg spec. + * If this function returns undefined, then the argument value is unchanged. + */ + }, { + key: "traverseAndMaybeSet", + value: function traverseAndMaybeSet(result, setTo) { + return _traverseAndMaybeSet(this.spec, result, setTo); + } + /** + * Traverse the spec and call a method for each argument. + * + * @param process A function to call at each arg spec. + */ + }, { + key: "traverse", + value: function traverse(process, onGroup) { + return _traverse(this.spec, process, onGroup); + } + }]); + return WrappedArgMetadata; +}(); +/** + * Create a parsed args object from a spec using all default values. + * + * @param spec The spec for all arguments. + */ +function _loadDefaultValues(spec) { + var result = {}; + for (var k in spec) { + var argSpec = spec[k]; + if ("args" in argSpec) { + result[k] = _loadDefaultValues(argSpec.args); + } else { + if ("default" in argSpec) result[k] = argSpec.default;else result[k] = undefined; + } + } + return result; +} +/** + * Traverse the spec and possibly generate a value for each argument. + * + * @param spec The spec for all arguments. + * @param result The object to hold the resulting argument values. + * @param setTo A function to generate an argument value from each arg spec. + * If this function returns undefined, then the argument value is unchanged. + */ +function _traverseAndMaybeSet(spec, result, setTo) { + var groups = []; + for (var k in spec) { + var argSpec = spec[k]; + if ("args" in argSpec) { + groups.push([argSpec, k]); + } else { + var value = setTo(argSpec, k); + if (value === undefined) continue; + result[k] = value; + } + } + for (var _i = 0, _groups = groups; _i < _groups.length; _i++) { + var group_and_key = _groups[_i]; + _traverseAndMaybeSet(group_and_key[0].args, result[group_and_key[1]], setTo); + } +} +/** + * Traverse the spec and possibly generate a value for each argument. + * + * @param spec The spec for all arguments. + * @param process A function to call at each arg spec. + */ +function _traverse(spec, process, onGroup) { + var groups = []; + for (var k in spec) { + var argSpec = spec[k]; + if ("args" in argSpec) { + groups.push([argSpec, k]); + } else { + process(argSpec, k); + } + } + for (var _i2 = 0, _groups2 = groups; _i2 < _groups2.length; _i2++) { + var group_and_key = _groups2[_i2]; + onGroup === null || onGroup === void 0 ? void 0 : onGroup(group_and_key[0], group_and_key[1]); + _traverse(group_and_key[0].args, process, onGroup); + } +} +/** + * A parser to extract key/value pairs from a command line input. + * @member command The command line input. + * @member keys The set of valid keys that can appear. + * @member flags The set of valid flags that can appear. + * @member index An internal marker for the progress of the parser over the input. + */ +var CommandParser = /*#__PURE__*/function () { + function CommandParser(command, keys, flags, positionalArgs) { + _classCallCheck(this, CommandParser); + this.command = command; + this.index = 0; + this.keys = keys; + this.flags = flags; + this.positionalArgs = positionalArgs; + this.positionalArgsParsed = 0; + } + /** + * Perform the parsing of (key, value) pairs. + * @returns The set of extracted (key, value) pairs. + */ + _createClass(CommandParser, [{ + key: "parse", + value: function parse() { + var _a, _b, _c, _d; + this.index = 0; // reset the parser + var result = new Map(); + while (!this.finished()) { + // A flag F may appear as !F to be parsed as false. + var parsing_negative_flag = false; + if (this.peek() === "!") { + parsing_negative_flag = true; + this.consume(["!"]); + } + var startIndex = this.index; + var key = this.parseKey(); + if (result.has(key)) { + throw "Duplicate key ".concat(key, " (first set to ").concat((_a = result.get(key)) !== null && _a !== void 0 ? _a : "", ")"); + } + if (this.flags.has(key)) { + // The key corresponds to a flag. + // Parse [key] as true and ![key] as false. + result.set(key, parsing_negative_flag ? "false" : "true"); + if (this.peek() === "=") throw "Flag ".concat(key, " cannot be assigned a value"); + if (!this.finished()) this.consume([" "]); + this.prevUnquotedKey = undefined; + } else if (this.keys.has(key)) { + // Parse [key]=[value] or [key] [value] + this.consume(["=", " "]); + var value = this.parseValue(); + if (["'", '"'].includes((_b = this.prev()) !== null && _b !== void 0 ? _b : "")) this.prevUnquotedKey = undefined;else this.prevUnquotedKey = key; + if (!this.finished()) this.consume([" "]); + result.set(key, value); + } else if (this.positionalArgsParsed < this.positionalArgs.length && this.peek() !== "=") { + // Parse [value] as the next positional arg + var positionalKey = this.positionalArgs[this.positionalArgsParsed]; + this.positionalArgsParsed++; + this.index = startIndex; // back up to reparse the key as a value + var _value = this.parseValue(); + if (["'", '"'].includes((_c = this.prev()) !== null && _c !== void 0 ? _c : "")) this.prevUnquotedKey = undefined;else this.prevUnquotedKey = key; + if (!this.finished()) this.consume([" "]); + if (result.has(positionalKey)) throw "Cannot assign ".concat(_value, " to ").concat(positionalKey, " (positionally) since ").concat(positionalKey, " was already set to ").concat((_d = result.get(positionalKey)) !== null && _d !== void 0 ? _d : ""); + result.set(positionalKey, _value); + } else { + // Key not found; include a better error message if it is possible for quotes to have been missed + if (this.prevUnquotedKey && this.peek() !== "=") throw "Unknown argument: ".concat(key, " (if this should have been parsed as part of ").concat(this.prevUnquotedKey, ", you should surround the entire value in quotes)");else throw "Unknown argument: ".concat(key); + } + } + return result; + } + /** + * @returns True if the entire command has been parsed. + */ + }, { + key: "finished", + value: function finished() { + return this.index >= this.command.length; + } + /** + * @returns The next character to parse, if it exists. + */ + }, { + key: "peek", + value: function peek() { + if (this.index >= this.command.length) return undefined; + return this.command.charAt(this.index); + } + /** + * @returns The character just parsed, if it exists. + */ + }, { + key: "prev", + value: function prev() { + if (this.index <= 0) return undefined; + if (this.index >= this.command.length + 1) return undefined; + return this.command.charAt(this.index - 1); + } + /** + * Advance the internal marker over the next expected character. + * Throws an error on unexpected characters. + * + * @param allowed Characters that are expected. + */ + }, { + key: "consume", + value: function consume(allowed) { + var _a; + if (this.finished()) throw "Expected ".concat(allowed); + if (allowed.includes((_a = this.peek()) !== null && _a !== void 0 ? _a : "")) { + this.index += 1; + } + } + /** + * Find the next occurance of one of the provided characters, or the end of + * the string if the characters never appear again. + * + * @param searchValue The characters to locate. + */ + }, { + key: "findNext", + value: function findNext(searchValue) { + var result = this.command.length; + var _iterator4 = _createForOfIteratorHelper(searchValue), + _step4; + try { + for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) { + var value = _step4.value; + var index = this.command.indexOf(value, this.index); + if (index !== -1 && index < result) result = index; + } + } catch (err) { + _iterator4.e(err); + } finally { + _iterator4.f(); + } + return result; + } + /** + * Starting from the internal marker, parse a single key. + * This also advances the internal marker. + * + * @returns The next key. + */ + }, { + key: "parseKey", + value: function parseKey() { + var keyEnd = this.findNext(["=", " "]); + var key = this.command.substring(this.index, keyEnd); + this.index = keyEnd; + return key; + } + /** + * Starting from the internal marker, parse a single value. + * This also advances the internal marker. + * + * Values are a single word or enclosed in matching quotes, i.e. one of: + * "[^"]*" + * '[^']*" + * [^'"][^ ]* + * + * @returns The next value. + */ + }, { + key: "parseValue", + value: function parseValue() { + var _a, _b; + var valueEnder = " "; + var quotes = ["'", '"']; + if (quotes.includes((_a = this.peek()) !== null && _a !== void 0 ? _a : "")) { + valueEnder = (_b = this.peek()) !== null && _b !== void 0 ? _b : ""; // The value is everything until the next quote + this.consume([valueEnder]); // Consume opening quote + } + + var valueEnd = this.findNext([valueEnder]); + var value = this.command.substring(this.index, valueEnd); + if (valueEnder !== " " && valueEnd === this.command.length) { + throw "No closing ".concat(valueEnder, " found for ").concat(valueEnder).concat(value); + } + // Consume the value (and closing quote) + this.index = valueEnd; + if (valueEnder !== " ") this.consume([valueEnder]); + return value; + } + }]); + return CommandParser; +}(); +;// CONCATENATED MODULE: ./node_modules/libram/dist/utils.js +function utils_createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = utils_unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; } +function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || utils_unsupportedIterableToArray(arr, i) || _nonIterableRest(); } +function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } +function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } +function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || utils_unsupportedIterableToArray(arr) || _nonIterableSpread(); } +function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function utils_unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return utils_arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return utils_arrayLikeToArray(o, minLen); } +function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); } +function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return utils_arrayLikeToArray(arr); } +function utils_arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } +/** + * Type guard against null value + * + * @param value Value that can be null + * @returns Whether the value is not null or... not + */ +function notNull(value) { + return value !== null; +} +/** + * Parse string to number, stripping commas + * + * @param n Numberical string to parse + * @returns Numerical value of string + */ +function parseNumber(n) { + return Number.parseInt(n.replace(/,/g, "")); +} +/** + * Clamp a number between lower and upper bounds. + * + * @param n Number to clamp. + * @param min Lower bound. + * @param max Upper bound. + * @returns Clamped value + */ +function clamp(n, min, max) { + return Math.max(min, Math.min(max, n)); +} +/** + * Split an {@param array} into {@param chunkSize} sized chunks + * + * @param array Array to split + * @param chunkSize Size of chunk + * @returns Split array + */ +function utils_chunk(array, chunkSize) { + var result = []; + for (var i = 0; i < array.length; i += chunkSize) { + result.push(array.slice(i, i + chunkSize)); + } + return result; +} +/** + * Count distinct values in an array + * + * @param array Array of values + * @returns Map of distinct values to count + */ +function arrayToCountedMap(array) { + if (!Array.isArray(array)) return array; + var map = new Map(); + array.forEach(item => { + map.set(item, (map.get(item) || 0) + 1); + }); + return map; +} +/** + * Turn map of distinct values to count into array of values + * + * @param map Map to turn into array + * @returns Array of values + */ +function countedMapToArray(map) { + var _ref; + return (_ref = []).concat.apply(_ref, _toConsumableArray(_toConsumableArray(map).map(_ref2 => { + var _ref3 = _slicedToArray(_ref2, 2), + item = _ref3[0], + quantity = _ref3[1]; + return Array(quantity).fill(item); + }))); +} +/** + * Stringify a counted map + * + * @param map Map of counted values + * @returns String representing map of counted values + */ +function countedMapToString(map) { + return _toConsumableArray(map).map(_ref4 => { + var _ref5 = _slicedToArray(_ref4, 2), + item = _ref5[0], + quantity = _ref5[1]; + return "".concat(quantity, " x ").concat(item); + }).join(", "); +} +/** + * Sum an array of numbers. + * + * @param addends Addends to sum. + * @param x Property or mapping function of addends to sum + * @returns Sum of numbers + */ +function sum(addends, x) { + return addends.reduce((subtotal, element) => subtotal + (typeof x === "function" ? x(element) : element[x]), 0); +} +/** + * Sum array of numbers + * + * @param addends Numbers to sum + * @returns Sum of numbers + */ +function sumNumbers(addends) { + return sum(addends, x => x); +} +/** + * Checks if a given item is in a readonly array, acting as a typeguard. + * + * @param item Needle + * @param array Readonly array haystack + * @returns Whether the item is in the array, and narrows the type of the item. + */ +function arrayContains(item, array) { + return array.includes(item); +} +/** + * Checks if two arrays contain the same elements in the same quantity. + * + * @param a First array for comparison + * @param b Second array for comparison + * @returns Whether the two arrays are equal, irrespective of order. + */ +function setEqual(a, b) { + var sortedA = _toConsumableArray(a).sort(); + var sortedB = _toConsumableArray(b).sort(); + return a.length === b.length && sortedA.every((item, index) => item === sortedB[index]); +} +/** + * Reverses keys and values for a given map + * + * @param map Map to invert + * @returns Inverted map + */ +function invertMap(map) { + var returnValue = new Map(); + var _iterator = utils_createForOfIteratorHelper(map), + _step; + try { + for (_iterator.s(); !(_step = _iterator.n()).done;) { + var _step$value = _slicedToArray(_step.value, 2), + key = _step$value[0], + value = _step$value[1]; + returnValue.set(value, key); + } + } catch (err) { + _iterator.e(err); + } finally { + _iterator.f(); + } + return returnValue; +} +/** + * Splits a string by commas while also respecting escaping commas with a backslash + * + * @param str String to split + * @returns List of tokens + */ +function splitByCommasWithEscapes(str) { + var returnValue = []; + var ignoreNext = false; + var currentString = ""; + var _iterator2 = utils_createForOfIteratorHelper(str.split("")), + _step2; + try { + for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) { + var char = _step2.value; + if (char === "\\") { + ignoreNext = true; + } else { + if (char == "," && !ignoreNext) { + returnValue.push(currentString.trim()); + currentString = ""; + } else { + currentString += char; + } + ignoreNext = false; + } + } + } catch (err) { + _iterator2.e(err); + } finally { + _iterator2.f(); + } + returnValue.push(currentString.trim()); + return returnValue; +} +/** + * Find the best element of an array, where "best" is defined by some given criteria. + * + * @param array The array to traverse and find the best element of. + * @param optimizer Either a key on the objects we're looking at that corresponds to numerical values, or a function for mapping these objects to numbers. Essentially, some way of assigning value to the elements of the array. + * @param reverse Make this true to find the worst element of the array, and false to find the best. Defaults to false. + * @returns Best element by optimizer function + */ +function maxBy(array, optimizer) { + var reverse = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; + if (!array.length) throw new Error("Cannot call maxBy on an empty array!"); + if (typeof optimizer === "function") { + return _toConsumableArray(array).reduce((_ref6, other) => { + var value = _ref6.value, + item = _ref6.item; + var otherValue = optimizer(other); + return value >= otherValue !== reverse ? { + value: value, + item: item + } : { + value: otherValue, + item: other + }; + }, { + item: array[0], + value: optimizer(array[0]) + }).item; + } else { + return array.reduce((a, b) => a[optimizer] >= b[optimizer] !== reverse ? a : b); + } +} +/** + * Compare arrays shallowly + * + * @param left One array to compare + * @param right The other array to compare + * @returns Whether the two arrays are shallowly equal + */ +function arrayEquals(left, right) { + if (left.length !== right.length) return false; + return left.every((element, index) => element === right[index]); +} +/** + * Used to collapse a Delayed object into an entity of type "T" as represented by the object. + * + * @param delayedObject Object of type Delayed that represents either a value of type T or a function returning a value of type T. + * @param args The arguments to pass to the delay function + * @returns The return value of the function, if delayedObject is a function. Otherwise, this returns the original element. + */ +// eslint-disable-next-line @typescript-eslint/no-explicit-any +function undelay(delayedObject) { + for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + args[_key - 1] = arguments[_key]; + } + return typeof delayedObject === "function" ? delayedObject.apply(void 0, args) : delayedObject; +} +/** + * Makes a byX function, like byStat or byClass + * + * @param source A method for finding your stat, or class, or whatever X is in this context + * @returns A function akin to byStat or byClass; it accepts an object that either is "complete" in the sense that it has a key for every conceivable value, or contains a `default` parameter. If an inappropriate input is provided, returns undefined. + */ +function makeByXFunction(source) { + return function (options) { + var _options$val; + var val = undelay(source); + if ("default" in options) return (_options$val = options[val]) !== null && _options$val !== void 0 ? _options$val : options.default; + return options[val]; + }; +} +/** + * Flattens an array. Basically replacing Array.prototype.flat for which Rhino doesn't yet have an implementation + * + * @param arr Array to flatten + * @param depth Number of layers to flatten by; Infinity for a fully flat array + * @returns Flattened array + */ +// eslint-disable-next-line @typescript-eslint/no-explicit-any +function flat(arr) { + var depth = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : Infinity; + var flatArray = []; + var _iterator3 = utils_createForOfIteratorHelper(arr), + _step3; + try { + for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) { + var item = _step3.value; + if (Array.isArray(item) && depth > 0) { + flatArray = flatArray.concat(flat(item, depth - 1)); + } else { + flatArray.push(item); + } + } + } catch (err) { + _iterator3.e(err); + } finally { + _iterator3.f(); + } + return flatArray; +} +/** + * @param array Array to select from + * @returns Random item from array + */ +function random(array) { + return array[Math.floor(Math.random() * array.length)]; +} +/** + * Title cases a single word + * + * @param word Word to transform + * @returns Word in title case + */ +var tc = word => word.charAt(0).toUpperCase() + word.slice(1); +;// CONCATENATED MODULE: ./node_modules/libram/dist/template-string.js + + +var concatTemplateString = function concatTemplateString(literals) { + for (var _len = arguments.length, placeholders = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + placeholders[_key - 1] = arguments[_key]; + } + return literals.raw.reduce((acc, literal, i) => { + var _placeholders$i; + return acc + literal + ((_placeholders$i = placeholders[i]) !== null && _placeholders$i !== void 0 ? _placeholders$i : ""); + }, ""); +}; +var handleTypeGetError = (Type, error) => { + var message = "".concat(error); + var match = message.match(RegExp("Bad ".concat(Type.name.toLowerCase(), " value: .*"))); + if (match) { + (0,external_kolmafia_.print)("".concat(match[0], "; if you're certain that this ").concat(Type.name, " exists and is spelled correctly, please update KoLMafia"), "red"); + } else { + (0,external_kolmafia_.print)(message); + } +}; +var createSingleConstant = Type => { + var tagFunction = function tagFunction(literals) { + for (var _len2 = arguments.length, placeholders = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) { + placeholders[_key2 - 1] = arguments[_key2]; + } + var input = concatTemplateString.apply(void 0, [literals].concat(placeholders)); + try { + return Type.get(input); + } catch (error) { + handleTypeGetError(Type, error); + } + (0,external_kolmafia_.abort)(); + }; + tagFunction.none = Type.none; + return tagFunction; +}; +var createPluralConstant = Type => { + var tagFunction = function tagFunction(literals) { + for (var _len3 = arguments.length, placeholders = new Array(_len3 > 1 ? _len3 - 1 : 0), _key3 = 1; _key3 < _len3; _key3++) { + placeholders[_key3 - 1] = arguments[_key3]; + } + var input = concatTemplateString.apply(void 0, [literals].concat(placeholders)); + if (input === "") { + return Type.all(); + } + try { + return Type.get(splitByCommasWithEscapes(input)); + } catch (error) { + handleTypeGetError(Type, error); + } + (0,external_kolmafia_.abort)(); + }; + tagFunction.all = () => Type.all(); + return tagFunction; +}; +/** + * A Bounty specified by name. + * + * @category In-game constant + */ +var $bounty = createSingleConstant(external_kolmafia_.Bounty); +/** + * A list of Bounties specified by a comma-separated list of names. + * For a list of all possible Bounties, leave the template string blank. + * + * @category In-game constant + */ +var $bounties = createPluralConstant(external_kolmafia_.Bounty); +/** + * A Class specified by name. + * + * @category In-game constant + */ +var $class = createSingleConstant(external_kolmafia_.Class); +/** + * A list of Classes specified by a comma-separated list of names. + * For a list of all possible Classes, leave the template string blank. + * + * @category In-game constant + */ +var $classes = createPluralConstant(external_kolmafia_.Class); +/** + * A Coinmaster specified by name. + * + * @category In-game constant + */ +var $coinmaster = createSingleConstant(external_kolmafia_.Coinmaster); +/** + * A list of Coinmasters specified by a comma-separated list of names. + * For a list of all possible Coinmasters, leave the template string blank. + * + * @category In-game constant + */ +var $coinmasters = createPluralConstant(external_kolmafia_.Coinmaster); +/** + * An Effect specified by name. + * + * @category In-game constant + */ +var template_string_$effect = createSingleConstant(external_kolmafia_.Effect); +/** + * A list of Effects specified by a comma-separated list of names. + * For a list of all possible Effects, leave the template string blank. + * + * @category In-game constant + */ +var $effects = createPluralConstant(external_kolmafia_.Effect); +/** + * An Element specified by name. + * + * @category In-game constant + */ +var $element = createSingleConstant(external_kolmafia_.Element); +/** + * A list of Elements specified by a comma-separated list of names. + * For a list of all possible Elements, leave the template string blank. + * + * @category In-game constant + */ +var $elements = createPluralConstant(external_kolmafia_.Element); +/** + * A Familiar specified by name. + * + * @category In-game constant + */ +var template_string_$familiar = createSingleConstant(external_kolmafia_.Familiar); +/** + * A list of Familiars specified by a comma-separated list of names. + * For a list of all possible Familiars, leave the template string blank. + * + * @category In-game constant + */ +var $familiars = createPluralConstant(external_kolmafia_.Familiar); +/** + * An Item specified by name. + * + * @category In-game constant + */ +var template_string_$item = createSingleConstant(external_kolmafia_.Item); +/** + * A list of Items specified by a comma-separated list of names. + * For a list of all possible Items, leave the template string blank. + * + * @category In-game constant + */ +var template_string_$items = createPluralConstant(external_kolmafia_.Item); +/** + * A Location specified by name. + * + * @category In-game constant + */ +var $location = createSingleConstant(external_kolmafia_.Location); +/** + * A list of Locations specified by a comma-separated list of names. + * For a list of all possible Locations, leave the template string blank. + * + * @category In-game constant + */ +var $locations = createPluralConstant(external_kolmafia_.Location); +/** + * A Modifier specified by name. + * + * @category In-game constant + */ +var $modifier = createSingleConstant(external_kolmafia_.Modifier); +/** + * A list of Modifiers specified by a comma-separated list of names. + * For a list of all possible Modifiers, leave the template string blank. + * + * @category In-game constant + */ +var $modifiers = createPluralConstant(external_kolmafia_.Modifier); +/** + * A Monster specified by name. + * + * @category In-game constant + */ +var $monster = createSingleConstant(external_kolmafia_.Monster); +/** + * A list of Monsters specified by a comma-separated list of names. + * For a list of all possible Monsters, leave the template string blank. + * + * @category In-game constant + */ +var $monsters = createPluralConstant(external_kolmafia_.Monster); +/** + * A Phylum specified by name. + * + * @category In-game constant + */ +var $phylum = createSingleConstant(external_kolmafia_.Phylum); +/** + * A list of Phyla specified by a comma-separated list of names. + * For a list of all possible Phyla, leave the template string blank. + * + * @category In-game constant + */ +var $phyla = createPluralConstant(external_kolmafia_.Phylum); +/** + * A Servant specified by name. + * + * @category In-game constant + */ +var $servant = createSingleConstant(external_kolmafia_.Servant); +/** + * A list of Servants specified by a comma-separated list of names. + * For a list of all possible Servants, leave the template string blank. + * + * @category In-game constant + */ +var $servants = createPluralConstant(external_kolmafia_.Servant); +/** + * A Skill specified by name. + * + * @category In-game constant + */ +var template_string_$skill = createSingleConstant(external_kolmafia_.Skill); +/** + * A list of Skills specified by a comma-separated list of names. + * For a list of all possible Skills, leave the template string blank. + * + * @category In-game constant + */ +var $skills = createPluralConstant(external_kolmafia_.Skill); +/** + * A Slot specified by name. + * + * @category In-game constant + */ +var $slot = createSingleConstant(external_kolmafia_.Slot); +/** + * A list of Slots specified by a comma-separated list of names. + * For a list of all possible Slots, leave the template string blank. + * + * @category In-game constant + */ +var $slots = createPluralConstant(external_kolmafia_.Slot); +/** + * A Stat specified by name. + * + * @category In-game constant + */ +var $stat = createSingleConstant(external_kolmafia_.Stat); +/** + * A list of Stats specified by a comma-separated list of names. + * For a list of all possible Stats, leave the template string blank. + * + * @category In-game constant + */ +var $stats = createPluralConstant(external_kolmafia_.Stat); +/** + * A Thrall specified by name. + * + * @category In-game constant + */ +var $thrall = createSingleConstant(external_kolmafia_.Thrall); +/** + * A list of Thralls specified by a comma-separated list of names. + * For a list of all possible Thralls, leave the template string blank. + * + * @category In-game constant + */ +var $thralls = createPluralConstant(external_kolmafia_.Thrall); +/** + * A Path specified by name. + * + * @category In-game constant + */ +var $path = createSingleConstant(external_kolmafia_.Path); +/** + * A list of Paths specified by a comma-separated list of names. + * For a list of all possible Paths, leave the template string blank. + * + * @category In-game constant + */ +var $paths = createPluralConstant(external_kolmafia_.Path); +;// CONCATENATED MODULE: ./node_modules/libram/dist/lib.js +var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11, _templateObject12, _templateObject13, _templateObject14, _templateObject15, _templateObject16, _templateObject17, _templateObject18, _templateObject19, _templateObject20, _templateObject21, _templateObject22, _templateObject23, _templateObject24, _templateObject25, _templateObject26, _templateObject27, _templateObject28, _templateObject29, _templateObject30, _templateObject31, _templateObject32, _templateObject33, _templateObject34, _templateObject35, _templateObject36, _templateObject37, _templateObject38, _templateObject39, _templateObject40, _templateObject41, _templateObject42, _templateObject43, _templateObject44, _templateObject45; +function lib_defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, lib_toPropertyKey(descriptor.key), descriptor); } } +function lib_createClass(Constructor, protoProps, staticProps) { if (protoProps) lib_defineProperties(Constructor.prototype, protoProps); if (staticProps) lib_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } +function lib_toPropertyKey(arg) { var key = lib_toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); } +function lib_toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } +function lib_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } +function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); } +function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } +function _wrapNativeSuper(Class) { var _cache = typeof Map === "function" ? new Map() : undefined; _wrapNativeSuper = function _wrapNativeSuper(Class) { if (Class === null || !_isNativeFunction(Class)) return Class; if (typeof Class !== "function") { throw new TypeError("Super expression must either be null or a function"); } if (typeof _cache !== "undefined") { if (_cache.has(Class)) return _cache.get(Class); _cache.set(Class, Wrapper); } function Wrapper() { return _construct(Class, arguments, _getPrototypeOf(this).constructor); } Wrapper.prototype = Object.create(Class.prototype, { constructor: { value: Wrapper, enumerable: false, writable: true, configurable: true } }); return _setPrototypeOf(Wrapper, Class); }; return _wrapNativeSuper(Class); } +function _construct(Parent, args, Class) { if (_isNativeReflectConstruct()) { _construct = Reflect.construct.bind(); } else { _construct = function _construct(Parent, args, Class) { var a = [null]; a.push.apply(a, args); var Constructor = Function.bind.apply(Parent, a); var instance = new Constructor(); if (Class) _setPrototypeOf(instance, Class.prototype); return instance; }; } return _construct.apply(null, arguments); } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } +function _isNativeFunction(fn) { return Function.toString.call(fn).indexOf("[native code]") !== -1; } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function lib_createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = lib_unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; } +function lib_slicedToArray(arr, i) { return lib_arrayWithHoles(arr) || lib_iterableToArrayLimit(arr, i) || lib_unsupportedIterableToArray(arr, i) || lib_nonIterableRest(); } +function lib_nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function lib_unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return lib_arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return lib_arrayLikeToArray(o, minLen); } +function lib_arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } +function lib_iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } +function lib_arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } +function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); } +/** @module GeneralLibrary */ + + + + + +/** + * Determines the current maximum Accordion Thief songs the player can have in their head + * + * @category General + * @returns Maximum number of songs for player + */ +function getSongLimit() { + return 3 + (booleanModifier("Four Songs") ? 1 : 0) + numericModifier("Additional Song"); +} +/** + * Determine whether the Skill or Effect provided is an Accordion Thief song + * + * @category General + * @param skillOrEffect The Skill or Effect + * @returns Whether it's a song + */ +function isSong(skillOrEffect) { + if (skillOrEffect instanceof external_kolmafia_.Effect && skillOrEffect.attributes.includes("song")) { + return true; + } else { + var skill = skillOrEffect instanceof external_kolmafia_.Effect ? (0,external_kolmafia_.toSkill)(skillOrEffect) : skillOrEffect; + return skill.class === $class(_templateObject || (_templateObject = _taggedTemplateLiteral(["Accordion Thief"]))) && skill.buff; + } +} +/** + * List all active Effects + * + * @category General + * @returns List of Effects + */ +function getActiveEffects() { + return Object.keys(myEffects()).map(e => Effect.get(e)); +} +/** + * List currently active Accordion Thief songs + * + * @category General + * @returns List of song Effects + */ +function getActiveSongs() { + return getActiveEffects().filter(isSong); +} +/** + * List number of active Accordion Thief songs + * + * @category General + * @returns Number of songs + */ +function getSongCount() { + return getActiveSongs().length; +} +/** + * Determine whether player can remember another Accordion Thief song + * + * @category General + * @param quantity Number of songs to test the space for + * @returns Whether player can remember another song + */ +function canRememberSong() { + var quantity = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 1; + return getSongLimit() - getSongCount() >= quantity; +} +/** + * Determine the locations in which the given monster can be encountered naturally + * + * @category General + * @param monster Monster to find + * @returns Locations for monster + */ +function getMonsterLocations(monster) { + return Location.all().filter(location => monster.name in appearanceRates(location)); +} +/** + * Determine the player's remaining liver space + * + * @category General + * @returns Remaining liver space + */ +function getRemainingLiver() { + return inebrietyLimit() - myInebriety(); +} +/** + * Determine the player's remaining stomach space + * + * @category General + * @returns Remaining stomach space + */ +function getRemainingStomach() { + return fullnessLimit() - myFullness(); +} +/** + * Determine the player's remaining spleen space + * + * @category General + * @returns Remaining spleen space + */ +function getRemainingSpleen() { + return spleenLimit() - mySpleenUse(); +} +/** + * Determine whether the player "has" any entity which one could feasibly "have". + * + * @category General + * @param thing Thing to check + * @param quantity Minimum quantity the player must have to pass + * @returns Whether the player meets the requirements of owning the supplied thing + */ +function have(thing) { + var quantity = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1; + if (thing instanceof external_kolmafia_.Effect) { + return (0,external_kolmafia_.haveEffect)(thing) >= quantity; + } + if (thing instanceof external_kolmafia_.Familiar) { + return (0,external_kolmafia_.haveFamiliar)(thing); + } + if (thing instanceof external_kolmafia_.Item) { + return (0,external_kolmafia_.availableAmount)(thing) >= quantity; + } + if (thing instanceof external_kolmafia_.Servant) { + return (0,external_kolmafia_.haveServant)(thing); + } + if (thing instanceof external_kolmafia_.Skill) { + return (0,external_kolmafia_.haveSkill)(thing); + } + if (thing instanceof external_kolmafia_.Thrall) { + var thrall = (0,external_kolmafia_.myThrall)(); + return thrall.id === thing.id && thrall.level >= quantity; + } + return false; +} +/** + * Determine whether a given item is in the player's campground + * + * @category General + * @param item The Item KoLmafia uses to represent the campground item + * @returns Whether the item is in the campground + */ +function haveInCampground(item) { + return Object.keys(getCampground()).map(i => Item.get(i)).includes(item); +} +var Wanderer; +(function (Wanderer) { + Wanderer["Digitize"] = "Digitize Monster"; + Wanderer["Enamorang"] = "Enamorang Monster"; + Wanderer["Familiar"] = "Familiar"; + Wanderer["Holiday"] = "Holiday Monster"; + Wanderer["Kramco"] = "Kramco"; + Wanderer["Nemesis"] = "Nemesis Assassin"; + Wanderer["Portscan"] = "portscan.edu"; + Wanderer["Romantic"] = "Romantic Monster"; + Wanderer["Vote"] = "Vote Monster"; +})(Wanderer || (Wanderer = {})); +var deterministicWanderers = [Wanderer.Digitize, Wanderer.Portscan]; +/** + * Determine whether the player has the specified counter + * + * @param counterName Name of the counter + * @param minTurns Minimum turns the counter is set to + * @param maxTurns Maximum turns the counter is set to + * @category General + * @returns Whether player has the counter + */ +function haveCounter(counterName) { + var minTurns = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0; + var maxTurns = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 500; + return getCounters(counterName, minTurns, maxTurns) === counterName; +} +/** + * Determine whether the player has the specified wanderer's counter + * + * @param wanderer Wanderer to check + * @category Wanderers + * @returns Whether player has the wanderer counter + */ +function haveWandererCounter(wanderer) { + if (deterministicWanderers.includes(wanderer)) { + return haveCounter(wanderer); + } + var begin = wanderer + " window begin"; + var end = wanderer + " window end"; + return haveCounter(begin) || haveCounter(end); +} +/** + * Determine whether the player will encounter a vote wanderer on the next turn, + * providing an "I Voted!" sticker is equipped. + * + * @category Wanderers + * @returns Whether the vote wanderer is due + */ +function isVoteWandererNow() { + return totalTurnsPlayed() % 11 === 1 && get("lastVoteMonsterTurn") < totalTurnsPlayed(); +} +/** + * Tells us whether we can expect a given wanderer now. Behaves differently + * for different types of wanderer. + * + * - For deterministic wanderers, return whether the player will encounter + * the queried wanderer on the next turn + * + * - For variable wanderers (window), return whether the player is within + * an encounter window for the queried wanderer + * + * - For variable wanderers (chance per turn), returns true unless the player + * has exhausted the number of wanderers possible + * + * @category Wanderers + * @param wanderer Wanderer to check + * @returns Whether the wanderer is due + */ +function isWandererNow(wanderer) { + if (deterministicWanderers.includes(wanderer)) { + return haveCounter(wanderer, 0, 0); + } + if (wanderer === Wanderer.Kramco) { + return true; + } + if (wanderer === Wanderer.Vote) { + return isVoteWandererNow(); + } + if (wanderer === Wanderer.Familiar) { + return get("_hipsterAdv") < 7; + } + var begin = wanderer + " window begin"; + var end = wanderer + " window end"; + return !haveCounter(begin, 1) && haveCounter(end); +} +/** + * Determines the chance the player will encounter a sausage goblin on the + * next turn, providing the Kramco Sausage-o-Matic is equipped. + * + * @category Wanderers + * @returns Chance that the sausage goblin is due (as a number between 0 and 1) + */ +function getKramcoWandererChance() { + var fights = get("_sausageFights"); + var lastFight = get("_lastSausageMonsterTurn"); + var totalTurns = totalTurnsPlayed(); + if (fights < 1) { + return lastFight === totalTurns && myTurncount() < 1 ? 0.5 : 1.0; + } + var turnsSinceLastFight = totalTurns - lastFight; + return Math.min(1.0, (turnsSinceLastFight + 1) / (5 + fights * 3 + Math.pow(Math.max(0, fights - 5), 3))); +} +/** + * Determines the chance the player will encounter an Artistic Goth Kid or + * Mini-Hipster wanderer on the next turn, providing a familiar is equipped. + * + * NOTE: You must complete one combat with the Artistic Goth Kid before you + * can encounter any wanderers. Consequently,ƒ the first combat with the + * Artist Goth Kid is effectively 0% chance to encounter a wanderer. + * + * @category Wanderers + * @returns Chance that the familiar wanderer is due (as a number between 0 and 1) + */ +function getFamiliarWandererChance() { + var totalFights = get("_hipsterAdv"); + var probability = [0.5, 0.4, 0.3, 0.2]; + if (totalFights < 4) { + return probability[totalFights]; + } + return totalFights > 7 ? 0.0 : 0.1; +} +/** + * Determines the chance the player will encounter the specified wanderer + * on the next turn. + * + * @category Wanderers + * @param wanderer Wanderer to check + * @returns Chance that the specified wanderer is due (as a number between 0 and 1) + */ +function getWandererChance(wanderer) { + if (deterministicWanderers.includes(wanderer)) { + return haveCounter(wanderer, 0, 0) ? 1.0 : 0.0; + } + if (wanderer === Wanderer.Kramco) { + getKramcoWandererChance(); + } + if (wanderer === Wanderer.Vote) { + return isVoteWandererNow() ? 1.0 : 0.0; + } + if (wanderer === Wanderer.Familiar) { + getFamiliarWandererChance(); + } + var begin = wanderer + " window begin"; + var end = wanderer + " window end"; + if (haveCounter(begin, 1, 100)) { + return 0.0; + } + var counters = get("relayCounters"); + var re = new RegExp("(\\d+):" + end); + var matches = counters.match(re); + if (matches && matches.length === 2) { + var window = Number.parseInt(matches[1]) - myTurncount(); + return 1.0 / window; + } + return 0.0; +} +/** + * Determines whether the player's current familiar is equal to the one supplied + * + * @category General + * @param familiar Familiar to check + * @returns Whether it is the player's current familiar + */ +function isCurrentFamiliar(familiar) { + return myFamiliar() === familiar; +} +/** + * Determines the fold group (if any) of which the given item is a part + * + * @category General + * @param item Item that is part of the required fold group + * @returns List of items in the fold group + */ +function getFoldGroup(item) { + return Object.entries(getRelated(item, "fold")).sort((_ref, _ref2) => { + var _ref3 = lib_slicedToArray(_ref, 2), + a = _ref3[1]; + var _ref4 = lib_slicedToArray(_ref2, 2), + b = _ref4[1]; + return a - b; + }).map(_ref5 => { + var _ref6 = lib_slicedToArray(_ref5, 1), + i = _ref6[0]; + return Item.get(i); + }); +} +/** + * Determines the zap group (if any) of which the given item is a part + * + * @category General + * @param item Item that is part of the required zap group + * @returns List of items in the zap group + */ +function getZapGroup(item) { + return Object.keys(getRelated(item, "zap")).map(i => Item.get(i)); +} +/** + * Get a map of banished monsters keyed by what banished them + * + * @category General + * @returns Map of banished monsters + */ +function getBanishedMonsters() { + var banishes = chunk(get("banishedMonsters").split(":"), 3); + var result = new Map(); + var _iterator = lib_createForOfIteratorHelper(banishes), + _step; + try { + for (_iterator.s(); !(_step = _iterator.n()).done;) { + var _step$value = lib_slicedToArray(_step.value, 2), + foe = _step$value[0], + banisher = _step$value[1]; + if (foe === undefined || banisher === undefined) break; + // toItem doesn"t error if the item doesn"t exist, so we have to use that. + var banisherItem = toItem(banisher); + if (banisher.toLowerCase() === "saber force") { + result.set($skill(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["Use the Force"]))), Monster.get(foe)); + } else if (banisher.toLowerCase() === "nanorhino") { + result.set($skill(_templateObject3 || (_templateObject3 = _taggedTemplateLiteral(["Unleash Nanites"]))), Monster.get(foe)); + } else if ([Item.none, Item.get("training scroll: Snokebomb"), Item.get("tomayohawk-style reflex hammer"), null].includes(banisherItem)) { + if (Skill.get(banisher) === $skill.none) { + break; + } else { + result.set(Skill.get(banisher), Monster.get(foe)); + } + } else { + result.set(banisherItem, Monster.get(foe)); + } + } + } catch (err) { + _iterator.e(err); + } finally { + _iterator.f(); + } + return result; +} +/** + * Determines whether the item is usable + * + * This function will be an ongoing work in progress + * + * @param item Item to check + * @returns Whether item is usable + */ +function canUse(item) { + var path = myPath(); + if (path !== Path.get("Nuclear Autumn")) { + if ($items(_templateObject4 || (_templateObject4 = _taggedTemplateLiteral(["Shrieking Weasel holo-record, Power-Guy 2000 holo-record, Lucky Strikes holo-record, EMD holo-record, Superdrifter holo-record, The Pigs holo-record, Drunk Uncles holo-record"]))).includes(item)) { + return false; + } + } + if (path === Path.get("G-Lover")) { + if (!item.name.toLowerCase().includes("g")) return false; + } + if (path === Path.get("Bees Hate You")) { + if (item.name.toLowerCase().includes("b")) return false; + } + return true; +} +/** + * Turn KoLmafia `none`s to JavaScript `null`s + * + * @param thing Thing that can have a mafia "none" value + * @returns The thing specified or `null` + */ +function noneToNull(thing) { + if (thing instanceof Effect) { + return thing === Effect.none ? null : thing; + } + if (thing instanceof Familiar) { + return thing === Familiar.none ? null : thing; + } + if (thing instanceof Item) { + return thing === Item.none ? null : thing; + } + return thing; +} +/** + * Determine the average value from the sort of range that KoLmafia encodes as a string + * + * @param range KoLmafia-style range string + * @returns Average value fo range + */ +function getAverage(range) { + var _range$match; + if (range.indexOf("-") < 0) return Number(range); + var _ref7 = (_range$match = range.match(/(-?[0-9]+)-(-?[0-9]+)/)) !== null && _range$match !== void 0 ? _range$match : ["0", "0", "0"], + _ref8 = lib_slicedToArray(_ref7, 3), + lower = _ref8[1], + upper = _ref8[2]; + return (Number(lower) + Number(upper)) / 2; +} +/** + * Deternube tge average adventures expected from consuming an Item + * + * If item is not a consumable, will just return "0". + * + * @param item Consumable item + * @returns Average aventures from consumable + */ +function getAverageAdventures(item) { + return getAverage(item.adventures); +} +/** + * Remove an effect + * + * @category General + * @param effect Effect to remove + * @returns Success + */ +function uneffect(effect) { + return (0,external_kolmafia_.cliExecute)("uneffect ".concat(effect.name)); +} +/** + * Get both the name and id of a player from either their name or id + * + * @param idOrName Id or name of player + * @returns Object containing id and name of player + */ +function getPlayerFromIdOrName(idOrName) { + var id = typeof idOrName === "number" ? idOrName : parseInt(getPlayerId(idOrName)); + return { + name: getPlayerName(id), + id: id + }; +} +/** + * Determine the step as a number for a given quest property. + * + * @param questName Name of quest property to check. + * @returns Quest step + */ +function questStep(questName) { + var stringStep = get(questName); + if (stringStep === "unstarted") return -1;else if (stringStep === "started") return 0;else if (stringStep === "finished" || stringStep === "") return 999;else { + if (stringStep.substring(0, 4) !== "step") { + throw new Error("Quest state parsing error."); + } + return parseInt(stringStep.substring(4), 10); + } +} +var EnsureError = /*#__PURE__*/function (_Error) { + _inherits(EnsureError, _Error); + var _super = _createSuper(EnsureError); + function EnsureError(cause, reason) { + var _this; + lib_classCallCheck(this, EnsureError); + _this = _super.call(this, "Failed to ensure ".concat(cause.name, "!").concat(reason ? " ".concat(reason) : "")); + _this.name = "Ensure Error"; + return _this; + } + return lib_createClass(EnsureError); +}( /*#__PURE__*/_wrapNativeSuper(Error)); +/** + * Tries to get an effect using the default method + * + * @param ef effect to try to get + * @param turns turns to aim for; default of 1 + * @throws {EnsureError} Throws an error if the effect cannot be guaranteed + */ +function ensureEffect(ef) { + var turns = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1; + if ((0,external_kolmafia_.haveEffect)(ef) < turns) { + if (ef.default === null) { + throw new EnsureError(ef, "No default action"); + } + if (!(0,external_kolmafia_.cliExecute)(ef.default) || (0,external_kolmafia_.haveEffect)(ef) === 0) { + throw new EnsureError(ef); + } + } +} +var valueMap = new Map(); +var MALL_VALUE_MODIFIER = 0.9; +/** + * Determiens the average value (based on mallprice and autosell) of a collection of items + * + * @param items items whose value you care about + * @returns Average value of items + */ +function getSaleValue() { + for (var _len = arguments.length, items = new Array(_len), _key = 0; _key < _len; _key++) { + items[_key] = arguments[_key]; + } + return items.map(item => { + if (valueMap.has(item)) return valueMap.get(item) || 0; + if (item.discardable) { + valueMap.set(item, mallPrice(item) > Math.max(2 * autosellPrice(item), 100) ? MALL_VALUE_MODIFIER * mallPrice(item) : autosellPrice(item)); + } else { + valueMap.set(item, mallPrice(item) > 100 ? MALL_VALUE_MODIFIER * mallPrice(item) : 0); + } + return valueMap.get(item) || 0; + }).reduce((s, price) => s + price, 0) / items.length; +} +var Environment = { + Outdoor: "outdoor", + Indoor: "indoor", + Underground: "underground", + Underwater: "underwater" +}; +/** + * Determines the weight-coefficient of any leprechaunning that this familiar may find itself doing + * Assumes the familiar is nude and thus fails for hatrack & pantsrack + * For the Mutant Cactus Bud, returns the efficacy-multiplier instead + * + * @param familiar The familiar whose leprechaun multiplier you're interested in + * @returns Weight-coefficient + */ +function findLeprechaunMultiplier(familiar) { + if (familiar === $familiar(_templateObject5 || (_templateObject5 = _taggedTemplateLiteral(["Mutant Cactus Bud"])))) { + return numericModifier(familiar, "Leprechaun Effectiveness", 1, $item.none); + } + if (familiar === $familiar(_templateObject6 || (_templateObject6 = _taggedTemplateLiteral(["Reanimated Reanimator"])))) return 0; + var meatBonus = numericModifier(familiar, "Meat Drop", 1, $item.none); + if (meatBonus === 0) return 0; + return Math.pow(Math.sqrt(meatBonus / 2 + 55 / 4 + 3) - Math.sqrt(55) / 2, 2); +} +/** + * Determines the weight-coefficient of any baby gravy fairying that this familiar may find itself doing + * Assumes the familiar is nude and thus fails for hatrack & pantsrack + * For the Mutant Fire Ant, returns the efficacy-multiplier instead + * + * @param familiar The familiar whose fairy multiplier you're interested in + * @returns Weight-coefficient + */ +function findFairyMultiplier(familiar) { + if (familiar === $familiar(_templateObject7 || (_templateObject7 = _taggedTemplateLiteral(["Mutant Fire Ant"])))) { + return numericModifier(familiar, "Fairy Effectiveness", 1, $item.none); + } + if (familiar === $familiar(_templateObject8 || (_templateObject8 = _taggedTemplateLiteral(["Reanimated Reanimator"])))) return 0; + var itemBonus = numericModifier(familiar, "Item Drop", 1, $item.none); + if (itemBonus === 0) return 0; + return Math.pow(Math.sqrt(itemBonus + 55 / 4 + 3) - Math.sqrt(55) / 2, 2); +} +var holidayWanderers = new Map([["El Dia De Los Muertos Borrachos", $monsters(_templateObject9 || (_templateObject9 = _taggedTemplateLiteral(["Novia Cad\xE1ver, Novio Cad\xE1ver, Padre Cad\xE1ver, Persona Inocente Cad\xE1ver"])))], ["Feast of Boris", $monsters(_templateObject10 || (_templateObject10 = _taggedTemplateLiteral(["Candied Yam Golem, Malevolent Tofurkey, Possessed Can of Cranberry Sauce, Stuffing Golem"])))], ["Talk Like a Pirate Day", $monsters(_templateObject11 || (_templateObject11 = _taggedTemplateLiteral(["ambulatory pirate, migratory pirate, peripatetic pirate"])))]]); +/** + * Get today's holiday wanderers + * + * @returns List of holiday wanderer Monsters + */ +function getTodaysHolidayWanderers() { + return flat((0,external_kolmafia_.holiday)().split("/").map(holiday => { + var _holidayWanderers$get; + return (_holidayWanderers$get = holidayWanderers.get(holiday)) !== null && _holidayWanderers$get !== void 0 ? _holidayWanderers$get : []; + })); +} +/** + * Determines whether or not we can safely call visitUrl(), based on whether we're in a fight, multi-fight, choice, etc + * + * @returns Whether urls can be safely visited + */ +function canVisitUrl() { + if (currentRound()) { + logger.debug("Current round is ".concat(currentRound(), "; you're in combat.")); + return false; + } + if (inMultiFight()) { + logger.debug("You're in a multifight."); + return false; + } + if (choiceFollowsFight()) { + logger.debug("A choice follows this fight."); + return false; + } + if (handlingChoice()) { + logger.debug("You're currently in a choice adventure"); + return false; + } + return true; +} +/** + * Calculate damage taken from a specific element after factoring in resistance + * + * @param baseDamage Base damage + * @param element Element + * @returns damage after factoring in resistances + */ +function damageTakenByElement(baseDamage, element) { + if (baseDamage < 0) return 1; + var res = elementalResistance(element); + return Math.max(1, Math.ceil(baseDamage - baseDamage * res / 100)); +} +var telescopeStats = new Map([["standing around flexing their muscles and using grip exercisers", $stat(_templateObject12 || (_templateObject12 = _taggedTemplateLiteral(["Muscle"])))], ["sitting around playing chess and solving complicated-looking logic puzzles", $stat(_templateObject13 || (_templateObject13 = _taggedTemplateLiteral(["Mysticality"])))], ["all wearing sunglasses and dancing", $stat(_templateObject14 || (_templateObject14 = _taggedTemplateLiteral(["Moxie"])))]]); +var telescopeElements = new Map([["people, all of whom appear to be on fire", $element(_templateObject15 || (_templateObject15 = _taggedTemplateLiteral(["hot"])))], ["people, surrounded by a cloud of eldritch mist", $element(_templateObject16 || (_templateObject16 = _taggedTemplateLiteral(["spooky"])))], ["greasy-looking people furtively skulking around", $element(_templateObject17 || (_templateObject17 = _taggedTemplateLiteral(["sleaze"])))], ["people, surrounded by garbage and clouds of flies", $element(_templateObject18 || (_templateObject18 = _taggedTemplateLiteral(["stench"])))], ["people, clustered around a group of igloos", $element(_templateObject19 || (_templateObject19 = _taggedTemplateLiteral(["cold"])))]]); +var hedgeTrap1 = new Map([["smoldering bushes on the outskirts of a hedge maze", $element(_templateObject20 || (_templateObject20 = _taggedTemplateLiteral(["hot"])))], ["creepy-looking black bushes on the outskirts of a hedge maze", $element(_templateObject21 || (_templateObject21 = _taggedTemplateLiteral(["spooky"])))], ["purplish, greasy-looking hedges", $element(_templateObject22 || (_templateObject22 = _taggedTemplateLiteral(["sleaze"])))], ["nasty-looking, dripping green bushes on the outskirts of a hedge maze", $element(_templateObject23 || (_templateObject23 = _taggedTemplateLiteral(["stench"])))], ["frost-rimed bushes on the outskirts of a hedge maze", $element(_templateObject24 || (_templateObject24 = _taggedTemplateLiteral(["cold"])))]]); +var hedgeTrap2 = new Map([["smoke rising from deeper within the maze", $element(_templateObject25 || (_templateObject25 = _taggedTemplateLiteral(["hot"])))], ["a miasma of eldritch vapors rising from deeper within the maze", $element(_templateObject26 || (_templateObject26 = _taggedTemplateLiteral(["spooky"])))], ["a greasy purple cloud hanging over the center of the maze", $element(_templateObject27 || (_templateObject27 = _taggedTemplateLiteral(["sleaze"])))], ["a cloud of green gas hovering over the maze", $element(_templateObject28 || (_templateObject28 = _taggedTemplateLiteral(["stench"])))], ["wintry mists rising from deeper within the maze", $element(_templateObject29 || (_templateObject29 = _taggedTemplateLiteral(["cold"])))]]); +var hedgeTrap3 = new Map([["with lava slowly oozing out of it", $element(_templateObject30 || (_templateObject30 = _taggedTemplateLiteral(["hot"])))], ["surrounded by creepy black mist", $element(_templateObject31 || (_templateObject31 = _taggedTemplateLiteral(["spooky"])))], ["that occasionally vomits out a greasy ball of hair", $element(_templateObject32 || (_templateObject32 = _taggedTemplateLiteral(["sleaze"])))], ["disgorging a really surprising amount of sewage", $element(_templateObject33 || (_templateObject33 = _taggedTemplateLiteral(["stench"])))], ["occasionally disgorging a bunch of ice cubes", $element(_templateObject34 || (_templateObject34 = _taggedTemplateLiteral(["cold"])))]]); +/** + * Get information from telescope + * + * @returns An object with all information the telescope gives you about the sorceress's contests and maze + */ +function telescope() { + return { + statContest: telescopeStats.get(get("telescope1")), + elementContest: telescopeElements.get(get("telescope2")), + hedge1: hedgeTrap1.get(get("telescope3")), + hedge2: hedgeTrap2.get(get("telescope4")), + hedge3: hedgeTrap3.get(get("telescope5")) + }; +} +/** + * Visit the desc_x.php page for a given thing + * + * @param thing Thing to examine + * @returns Contents of desc_x.php page + */ +function examine(thing) { + var url = thing instanceof Item ? "desc_item.php?whichitem=".concat(thing.descid) : thing instanceof Familiar ? "desc_familiar.php?which=".concat(thing.id) : thing instanceof Effect ? "desc_effect.php?whicheffect=".concat(thing.descid) : "desc_skill.php?whichskill=".concat(thing.id); + return visitUrl(url); +} +/** + * Picks an option based on your primestat + * + * @param options An object keyed by stat; it must either contain all stats, or have a `default` parameter. + * @returns The option corresponding to your primestat. + */ +var byStat = makeByXFunction(() => (0,external_kolmafia_.myPrimestat)().toString()); +/** + * Picks an option based on your player class + * + * @param options An object keyed by player class; it must either contain all classes, or have a `default` parameter. + * @returns The option corresponding to your player class. + */ +var byClass = makeByXFunction(() => (0,external_kolmafia_.myClass)().toString()); +/** + * Use an item with visitUrl instead of `use`; this is sometimes useful + * + * @param item The item you want to use + * @returns The html of the resulting page + */ +function directlyUse(item) { + return visitUrl("inv_use.php?which=3&whichitem=".concat(item.id, "&pwd")); +} +/** + * Empty a slot, or unequip all instances of a given equipped item + * + * @param thing The slot or item in question + * @returns Whether we succeeded completely--`false` if we unequip some but not all instances of the item. + */ +function unequip(thing) { + if (thing instanceof Slot) return equip(thing, $item.none); + var failedSlots = Slot.all().filter(s => { + // Filter the slot out if it doesn't contain the relevant item + if (equippedItem(s) !== thing) return false; + // Filter the slot out if we succeed at unequipping it + return !unequip(thing); + // This leaves only slots that do contain the item but that we failed to unequip + }); + + if (failedSlots.length) logger.debug("Failed to unequip ".concat(thing, " from slots ").concat(failedSlots.join(", "))); + return failedSlots.length === 0; +} +/** + * @returns a Date object corresponding to the current in-game day, at midnight + */ +function gameDay() { + var _todayToString$match; + var _map = ((_todayToString$match = todayToString().match(/(\d{4})(\d{2})(\d{2})/)) !== null && _todayToString$match !== void 0 ? _todayToString$match : []).map(Number), + _map2 = lib_slicedToArray(_map, 4), + year = _map2[1], + month = _map2[2], + day = _map2[3]; + return new Date(year, month - 1, day, 0, 0, 0); +} +/** + * @param [type="all"] the type of crafting to check for free crafts + * @returns the number of free crafts available of that type + */ +function freeCrafts() { + var type = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : "all"; + var effectCrafts = effect => Math.floor(haveEffect(effect) / 5); + var all = (have($skill(_templateObject35 || (_templateObject35 = _taggedTemplateLiteral(["Rapid Prototyping"])))) ? 5 - get("_rapidPrototypingUsed") : 0) + (have($skill(_templateObject36 || (_templateObject36 = _taggedTemplateLiteral(["Expert Corner-Cutter"])))) ? 5 - get("_expertCornerCutterUsed") : 0) + effectCrafts($effect(_templateObject37 || (_templateObject37 = _taggedTemplateLiteral(["Inigo's Incantation of Inspiration"])))) + effectCrafts($effect(_templateObject38 || (_templateObject38 = _taggedTemplateLiteral(["Craft Tea"])))) + + // eslint-disable-next-line libram/verify-constants + effectCrafts($effect(_templateObject39 || (_templateObject39 = _taggedTemplateLiteral(["Cooking Concentrate"])))); + var food = type === "food" ? 5 - get("_cookbookbatCrafting") : 0; + var smith = type === "smith" ? 5 - get("_thorsPliersCrafting") : 0; + var booze = 0; // currently there is no booze specific free crafting skill + return all + food + smith + booze; +} +var realmTypes = (/* unused pure expression or super */ null && (["spooky", "stench", "hot", "cold", "sleaze", "fantasy", "pirate"])); +/** + * @param identifier which realm to check for + * @returns if that realm is available + */ +function realmAvailable(identifier) { + if (identifier === "fantasy") { + return get("_frToday") || get("frAlways"); + } else if (identifier === "pirate") { + return get("_prToday") || get("prAlways"); + } + return get("_".concat(identifier, "AirportToday")) || get("".concat(identifier, "AirportAlways")); +} +/** + * Compute the currently available Lucky Gold Ring Currencies + * @param realm the realm type to consider + * @returns The currency for the given zone + */ +function realmCurrency(realm) { + switch (realm) { + case "sleaze": + return $item(_templateObject40 || (_templateObject40 = _taggedTemplateLiteral(["Beach Buck"]))); + case "spooky": + return $item(_templateObject41 || (_templateObject41 = _taggedTemplateLiteral(["Coinspiracy"]))); + case "stench": + return $item(_templateObject42 || (_templateObject42 = _taggedTemplateLiteral(["FunFunds\u2122"]))); + case "cold": + return $item(_templateObject43 || (_templateObject43 = _taggedTemplateLiteral(["Wal-Mart gift certificate"]))); + case "hot": + return $item(_templateObject44 || (_templateObject44 = _taggedTemplateLiteral(["Volcoino"]))); + case "fantasy": + return $item(_templateObject45 || (_templateObject45 = _taggedTemplateLiteral(["Rubee\u2122"]))); + } +} +/** + * Compute which Lucky Gold Ring currencies are currently available + * @returns a list of currently available currencies + */ +function lgrCurrencies() { + return realmTypes.filter(realm => realmAvailable(realm) && !(realm === "hot" && get("_luckyGoldRingVolcoino"))).map(realmCurrency).filter(i => !!i); +} +;// CONCATENATED MODULE: ./node_modules/libram/dist/overlappingNames.js +/** THIS FILE IS AUTOMATICALLY GENERATED. See tools/parseItemSkillNames.ts for more information */ +var overlappingItemNames = ["spider web", "really sticky spider web", "dictionary", "NG", "Cloaca-Cola", "yo-yo", "top", "ball", "kite", "yo", "red potion", "blue potion", "bowling ball", "adder", "red button", "pile of sand", "mushroom", "deluxe mushroom"]; +var overlappingSkillNames = ["Shoot", "Thrust-Smack", "Headbutt", "Toss", "Knife in the Dark", "Sing", "Disarm", "LIGHT", "BURN", "Extract", "Meteor Shower", "Snipe", "Cleave", "Boil", "Slice", "Rainbow"]; +;// CONCATENATED MODULE: ./node_modules/libram/dist/propertyTypes.js +/** THIS FILE IS AUTOMATICALLY GENERATED. See tools/parseDefaultProperties.ts for more information */ +var booleanProperties = ["abortOnChoiceWhenNotInChoice", "addChatCommandLine", "addCreationQueue", "addStatusBarToFrames", "allowCloseableDesktopTabs", "allowNegativeTally", "allowNonMoodBurning", "allowSummonBurning", "autoHighlightOnFocus", "broadcastEvents", "cacheMallSearches", "chatBeep", "chatLinksUseRelay", "compactChessboard", "copyAsHTML", "customizedTabs", "debugBuy", "debugConsequences", "debugFoxtrotRemoval", "debugPathnames", "debugTopMenuStyle", "gapProtection", "gitInstallDependencies", "gitShowCommitMessages", "gitUpdateOnLogin", "greenScreenProtection", "guiUsesOneWindow", "hideServerDebugText", "logAcquiredItems", "logBattleAction", "logBrowserInteractions", "logChatMessages", "logChatRequests", "logCleanedHTML", "logDecoratedResponses", "logFamiliarActions", "logGainMessages", "logReadableHTML", "logPreferenceChange", "logMonsterHealth", "logReverseOrder", "logStatGains", "logStatusEffects", "logStatusOnLogin", "macroDebug", "macroLens", "mementoListActive", "mergeHobopolisChat", "pingLogin", "pingStealthyTimein", "printStackOnAbort", "proxySet", "relayAddSounds", "relayAddsCustomCombat", "relayAddsDiscoHelper", "relayAddsGraphicalCLI", "relayAddsQuickScripts", "relayAddsRestoreLinks", "relayAddsUpArrowLinks", "relayAddsUseLinks", "relayAddsWikiLinks", "relayAllowRemoteAccess", "relayBrowserOnly", "relayCacheUncacheable", "relayFormatsChatText", "relayHidesJunkMallItems", "relayMaintainsEffects", "relayMaintainsHealth", "relayMaintainsMana", "relayOverridesImages", "relayRunsAfterAdventureScript", "relayRunsBeforeBattleScript", "relayRunsBeforePVPScript", "relayScriptButtonFirst", "relayTextualizesEffects", "relayTrimsZapList", "relayUsesInlineLinks", "relayUsesIntegratedChat", "relayWarnOnRecoverFailure", "removeMalignantEffects", "saveSettingsOnSet", "sharePriceData", "showAllRequests", "showExceptionalRequests", "stealthLogin", "svnAlwaysAdd", "svnAlwaysOverwrite", "svnInstallDependencies", "svnShowCommitMessages", "svnUpdateOnLogin", "switchEquipmentForBuffs", "syncAfterSvnUpdate", "useChatToolbar", "useContactsFrame", "useDevServer", "useDockIconBadge", "useHugglerChannel", "useImageCache", "useLastUserAgent", "useSystemTrayIcon", "useTabbedChatFrame", "useToolbars", "useCachedVolcanoMaps", "useZoneComboBox", "verboseSpeakeasy", "verboseFloundry", "wrapLongLines", "_gitUpdated", "_svnRepoFileFetched", "_svnUpdated", "antagonisticSnowmanKitAvailable", "arcadeGameHints", "armoryUnlocked", "autoForbidIgnoringStores", "autoCraft", "autoQuest", "autoEntangle", "autoGarish", "autoManaRestore", "autoFillMayoMinder", "autoPinkyRing", "autoPlantHardcore", "autoPlantSoftcore", "autoPotionID", "autoRepairBoxServants", "autoSatisfyWithCloset", "autoSatisfyWithCoinmasters", "autoSatisfyWithMall", "autoSatisfyWithNPCs", "autoSatisfyWithStash", "autoSatisfyWithStorage", "autoSetConditions", "autoSteal", "autoTuxedo", "backupCameraReverserEnabled", "badMoonEncounter01", "badMoonEncounter02", "badMoonEncounter03", "badMoonEncounter04", "badMoonEncounter05", "badMoonEncounter06", "badMoonEncounter07", "badMoonEncounter08", "badMoonEncounter09", "badMoonEncounter10", "badMoonEncounter11", "badMoonEncounter12", "badMoonEncounter13", "badMoonEncounter14", "badMoonEncounter15", "badMoonEncounter16", "badMoonEncounter17", "badMoonEncounter18", "badMoonEncounter19", "badMoonEncounter20", "badMoonEncounter21", "badMoonEncounter22", "badMoonEncounter23", "badMoonEncounter24", "badMoonEncounter25", "badMoonEncounter26", "badMoonEncounter27", "badMoonEncounter28", "badMoonEncounter29", "badMoonEncounter30", "badMoonEncounter31", "badMoonEncounter32", "badMoonEncounter33", "badMoonEncounter34", "badMoonEncounter35", "badMoonEncounter36", "badMoonEncounter37", "badMoonEncounter38", "badMoonEncounter39", "badMoonEncounter40", "badMoonEncounter41", "badMoonEncounter42", "badMoonEncounter43", "badMoonEncounter44", "badMoonEncounter45", "badMoonEncounter46", "badMoonEncounter47", "badMoonEncounter48", "barrelShrineUnlocked", "bigBrotherRescued", "blackBartsBootyAvailable", "bondAdv", "bondBeach", "bondBeat", "bondBooze", "bondBridge", "bondDesert", "bondDR", "bondDrunk1", "bondDrunk2", "bondHoney", "bondHP", "bondInit", "bondItem1", "bondItem2", "bondItem3", "bondJetpack", "bondMartiniDelivery", "bondMartiniPlus", "bondMartiniTurn", "bondMeat", "bondMox1", "bondMox2", "bondMPregen", "bondMus1", "bondMus2", "bondMys1", "bondMys2", "bondSpleen", "bondStat", "bondStat2", "bondStealth", "bondStealth2", "bondSymbols", "bondWar", "bondWeapon2", "bondWpn", "booPeakLit", "bootsCharged", "breakfastCompleted", "burrowgrubHiveUsed", "calzoneOfLegendEaten", "canteenUnlocked", "chaosButterflyThrown", "chatbotScriptExecuted", "chateauAvailable", "chatLiterate", "chatServesUpdates", "checkJackassHardcore", "checkJackassSoftcore", "clanAttacksEnabled", "coldAirportAlways", "considerShadowNoodles", "controlRoomUnlock", "concertVisited", "controlPanel1", "controlPanel2", "controlPanel3", "controlPanel4", "controlPanel5", "controlPanel6", "controlPanel7", "controlPanel8", "controlPanel9", "corralUnlocked", "dailyDungeonDone", "dampOldBootPurchased", "daycareOpen", "deepDishOfLegendEaten", "demonSummoned", "dinseyAudienceEngagement", "dinseyGarbagePirate", "dinseyRapidPassEnabled", "dinseyRollercoasterNext", "dinseySafetyProtocolsLoose", "doghouseBoarded", "dontStopForCounters", "drippingHallUnlocked", "drippyShieldUnlocked", "edUsedLash", "eldritchFissureAvailable", "eldritchHorrorAvailable", "errorOnAmbiguousFold", "essenceOfAnnoyanceAvailable", "essenceOfBearAvailable", "expressCardUsed", "falloutShelterChronoUsed", "falloutShelterCoolingTankUsed", "fireExtinguisherBatHoleUsed", "fireExtinguisherChasmUsed", "fireExtinguisherCyrptUsed", "fireExtinguisherDesertUsed", "fireExtinguisherHaremUsed", "fistTeachingsHaikuDungeon", "fistTeachingsPokerRoom", "fistTeachingsBarroomBrawl", "fistTeachingsConservatory", "fistTeachingsBatHole", "fistTeachingsFunHouse", "fistTeachingsMenagerie", "fistTeachingsSlums", "fistTeachingsFratHouse", "fistTeachingsRoad", "fistTeachingsNinjaSnowmen", "flickeringPixel1", "flickeringPixel2", "flickeringPixel3", "flickeringPixel4", "flickeringPixel5", "flickeringPixel6", "flickeringPixel7", "flickeringPixel8", "floristFriarAvailable", "floristFriarChecked", "frAlways", "frCemetaryUnlocked", "friarsBlessingReceived", "frMountainsUnlocked", "frSwampUnlocked", "frVillageUnlocked", "frWoodUnlocked", "getawayCampsiteUnlocked", "ghostPencil1", "ghostPencil2", "ghostPencil3", "ghostPencil4", "ghostPencil5", "ghostPencil6", "ghostPencil7", "ghostPencil8", "ghostPencil9", "gingerAdvanceClockUnlocked", "gingerBlackmailAccomplished", "gingerbreadCityAvailable", "gingerExtraAdventures", "gingerNegativesDropped", "gingerSewersUnlocked", "gingerSubwayLineUnlocked", "gingerRetailUnlocked", "glitchItemAvailable", "grabCloversHardcore", "grabCloversSoftcore", "guideToSafariAvailable", "guyMadeOfBeesDefeated", "hallowienerDefiledNook", "hallowienerGuanoJunction", "hallowienerKnollGym", "hallowienerMadnessBakery", "hallowienerMiddleChamber", "hallowienerOvergrownLot", "hallowienerSkeletonStore", "hallowienerSmutOrcs", "hallowienerSonofaBeach", "hallowienerVolcoino", "hardcorePVPWarning", "harvestBatteriesHardcore", "harvestBatteriesSoftcore", "hasAutumnaton", "hasBartender", "hasChef", "hasCocktailKit", "hasCosmicBowlingBall", "hasDetectiveSchool", "hasMaydayContract", "hasOven", "hasRange", "hasShaker", "hasSushiMat", "hasTwinkleVision", "haveBoxingDaydreamHardcore", "haveBoxingDaydreamSoftcore", "hermitHax0red", "holidayHalsBookAvailable", "horseryAvailable", "hotAirportAlways", "implementGlitchItem", "intenseCurrents", "itemBoughtPerAscension637", "itemBoughtPerAscension8266", "itemBoughtPerAscension10790", "itemBoughtPerAscension10794", "itemBoughtPerAscension10795", "itemBoughtPerCharacter6423", "itemBoughtPerCharacter6428", "itemBoughtPerCharacter6429", "kingLiberated", "lastPirateInsult1", "lastPirateInsult2", "lastPirateInsult3", "lastPirateInsult4", "lastPirateInsult5", "lastPirateInsult6", "lastPirateInsult7", "lastPirateInsult8", "lawOfAveragesAvailable", "leafletCompleted", "ledCandleDropped", "libraryCardUsed", "lockPicked", "logBastilleBattalionBattles", "loginRecoveryHardcore", "loginRecoverySoftcore", "lovebugsUnlocked", "loveTunnelAvailable", "lowerChamberUnlock", "madnessBakeryAvailable", "makePocketWishesHardcore", "makePocketWishesSoftcore", "manualOfNumberologyAvailable", "mappingMonsters", "mapToAnemoneMinePurchased", "mapToKokomoAvailable", "mapToMadnessReefPurchased", "mapToTheDiveBarPurchased", "mapToTheMarinaraTrenchPurchased", "mapToTheSkateParkPurchased", "maraisBeaverUnlock", "maraisCorpseUnlock", "maraisDarkUnlock", "maraisVillageUnlock", "maraisWildlifeUnlock", "maraisWizardUnlock", "maximizerAlwaysCurrent", "maximizerCreateOnHand", "maximizerCurrentMallPrices", "maximizerFoldables", "maximizerIncludeAll", "maximizerNoAdventures", "middleChamberUnlock", "milkOfMagnesiumActive", "moonTuned", "neverendingPartyAlways", "noncombatForcerActive", "oasisAvailable", "odeBuffbotCheck", "oilPeakLit", "oscusSodaUsed", "outrageousSombreroUsed", "overgrownLotAvailable", "ownsFloristFriar", "ownsSpeakeasy", "pathedSummonsHardcore", "pathedSummonsSoftcore", "pizzaOfLegendEaten", "popularTartUnlocked", "potatoAlarmClockUsed", "prAlways", "prayedForGlamour", "prayedForProtection", "prayedForVigor", "primaryLabCheerCoreGrabbed", "pyramidBombUsed", "rageGlandVented", "readManualHardcore", "readManualSoftcore", "relayShowSpoilers", "relayShowWarnings", "rememberDesktopSize", "replicaChateauAvailable", "replicaNeverendingPartyAlways", "replicaWitchessSetAvailable", "requireBoxServants", "requireSewerTestItems", "restUsingCampAwayTent", "restUsingChateau", "ROMOfOptimalityAvailable", "safePickpocket", "schoolOfHardKnocksDiplomaAvailable", "scriptCascadingMenus", "serverAddsCustomCombat", "SHAWARMAInitiativeUnlocked", "showForbiddenStores", "showGainsPerUnit", "showIgnoringStorePrices", "showNoSummonOnly", "showTurnFreeOnly", "skeletonStoreAvailable", "sleazeAirportAlways", "snojoAvailable", "sortByEffect", "sortByRoom", "spacegateAlways", "spacegateVaccine1", "spacegateVaccine2", "spacegateVaccine3", "spaceInvaderDefeated", "spelunkyHints", "spiceMelangeUsed", "spookyAirportAlways", "stenchAirportAlways", "stopForFixedWanderer", "stopForUltraRare", "styxPixieVisited", "superconductorDefeated", "suppressInappropriateNags", "suppressPowerPixellation", "suppressMallPriceCacheMessages", "telegraphOfficeAvailable", "telescopeLookedHigh", "timeTowerAvailable", "trackLightsOut", "uneffectWithHotTub", "universalSeasoningActive", "universalSeasoningAvailable", "useBookOfEverySkillHardcore", "useBookOfEverySkillSoftcore", "useCrimboToysHardcore", "useCrimboToysSoftcore", "verboseMaximizer", "visitLoungeHardcore", "visitLoungeSoftcore", "visitRumpusHardcore", "visitRumpusSoftcore", "voteAlways", "wildfireBarrelCaulked", "wildfireDusted", "wildfireFracked", "wildfirePumpGreased", "wildfireSprinkled", "yearbookCameraPending", "youRobotScavenged", "_2002MrStoreCreditsCollected", "_affirmationCookieEaten", "_affirmationHateUsed", "_airFryerUsed", "_akgyxothUsed", "_alienAnimalMilkUsed", "_alienPlantPodUsed", "_allYearSucker", "_aprilShower", "_armyToddlerCast", "_aug1Cast", "_aug2Cast", "_aug3Cast", "_aug4Cast", "_aug5Cast", "_aug6Cast", "_aug7Cast", "_aug8Cast", "_aug9Cast", "_aug10Cast", "_aug11Cast", "_aug12Cast", "_aug13Cast", "_aug14Cast", "_aug15Cast", "_aug16Cast", "_aug17Cast", "_aug18Cast", "_aug19Cast", "_aug20Cast", "_aug21Cast", "_aug22Cast", "_aug23Cast", "_aug24Cast", "_aug25Cast", "_aug26Cast", "_aug27Cast", "_aug28Cast", "_aug29Cast", "_aug30Cast", "_aug31Cast", "_augTodayCast", "_authorsInkUsed", "_baconMachineUsed", "_bagOfCandy", "_bagOfCandyUsed", "_bagOTricksUsed", "_ballastTurtleUsed", "_ballInACupUsed", "_ballpit", "_barrelPrayer", "_bastilleLastBattleWon", "_beachCombing", "_bendHellUsed", "_blackMonolithUsed", "_blankoutUsed", "_bonersSummoned", "_bookOfEverySkillUsed", "_borrowedTimeUsed", "_bowleggedSwaggerUsed", "_bowlFullOfJellyUsed", "_boxOfHammersUsed", "_brainPreservationFluidUsed", "_brassDreadFlaskUsed", "_cameraUsed", "_canSeekBirds", "_carboLoaded", "_cargoPocketEmptied", "_ceciHatUsed", "_chateauDeskHarvested", "_chateauMonsterFought", "_chibiChanged", "_chronerCrossUsed", "_chronerTriggerUsed", "_chubbyAndPlumpUsed", "_circadianRhythmsRecalled", "_circleDrumUsed", "_clanFortuneBuffUsed", "_claraBellUsed", "_coalPaperweightUsed", "_cocoaDispenserUsed", "_cocktailShakerUsed", "_coldAirportToday", "_coldOne", "_communismUsed", "_confusingLEDClockUsed", "_controlPanelUsed", "_cookbookbatRecipeDrops", "_corruptedStardustUsed", "_cosmicSixPackConjured", "_crappyCameraUsed", "_creepyVoodooDollUsed", "_crimboTraining", "_crimboTree", "_cursedKegUsed", "_cursedMicrowaveUsed", "_dailyDungeonMalwareUsed", "_darkChocolateHeart", "_daycareFights", "_daycareNap", "_daycareSpa", "_daycareToday", "_defectiveTokenChecked", "_defectiveTokenUsed", "_dinseyGarbageDisposed", "_discoKnife", "_distentionPillUsed", "_dnaHybrid", "_docClocksThymeCocktailDrunk", "_drippingHallDoor1", "_drippingHallDoor2", "_drippingHallDoor3", "_drippingHallDoor4", "_drippyCaviarUsed", "_drippyNuggetUsed", "_drippyPilsnerUsed", "_drippyPlumUsed", "_drippyWineUsed", "_eldritchHorrorEvoked", "_eldritchTentacleFought", "_entauntaunedToday", "_envyfishEggUsed", "_epicMcTwistUsed", "_essentialTofuUsed", "_etchedHourglassUsed", "_eternalCarBatteryUsed", "_everfullGlassUsed", "_eyeAndATwistUsed", "_fancyChessSetUsed", "_falloutShelterSpaUsed", "_fancyHotDogEaten", "_farmerItemsCollected", "_favoriteBirdVisited", "_firedJokestersGun", "_fireExtinguisherRefilled", "_fireStartingKitUsed", "_fireworksShop", "_fireworksShopHatBought", "_fireworksShopEquipmentBought", "_fireworkUsed", "_fishyPipeUsed", "_floundryItemCreated", "_floundryItemUsed", "_freePillKeeperUsed", "_frToday", "_fudgeSporkUsed", "_garbageItemChanged", "_gingerBiggerAlligators", "_gingerbreadCityToday", "_gingerbreadClockAdvanced", "_gingerbreadClockVisited", "_gingerbreadColumnDestroyed", "_gingerbreadMobHitUsed", "_glennGoldenDiceUsed", "_glitchItemImplemented", "_gnollEyeUsed", "_governmentPerDiemUsed", "_grimBuff", "_guildManualUsed", "_guzzlrQuestAbandoned", "_hardKnocksDiplomaUsed", "_hippyMeatCollected", "_hobbyHorseUsed", "_holidayFunUsed", "_holoWristCrystal", "_hotAirportToday", "_hungerSauceUsed", "_hyperinflatedSealLungUsed", "_iceHotelRoomsRaided", "_iceSculptureUsed", "_incredibleSelfEsteemCast", "_infernoDiscoVisited", "_internetDailyDungeonMalwareBought", "_internetGallonOfMilkBought", "_internetPlusOneBought", "_internetPrintScreenButtonBought", "_internetViralVideoBought", "_interviewIsabella", "_interviewMasquerade", "_interviewVlad", "_inquisitorsUnidentifiableObjectUsed", "_ironicMoustache", "_jackassPlumberGame", "_jarlsCheeseSummoned", "_jarlsCreamSummoned", "_jarlsDoughSummoned", "_jarlsEggsSummoned", "_jarlsFruitSummoned", "_jarlsMeatSummoned", "_jarlsPotatoSummoned", "_jarlsVeggiesSummoned", "_jingleBellUsed", "_jukebox", "_kgbFlywheelCharged", "_kgbLeftDrawerUsed", "_kgbOpened", "_kgbRightDrawerUsed", "_kolConSixPackUsed", "_kolhsCutButNotDried", "_kolhsIsskayLikeAnAshtray", "_kolhsPoeticallyLicenced", "_kolhsSchoolSpirited", "_kudzuSaladEaten", "_lastCombatLost", "_lastCombatWon", "_latteBanishUsed", "_latteCopyUsed", "_latteDrinkUsed", "_leafAntEggCrafted", "_leafDayShortenerCrafted", "_leafTattooCrafted", "_leavesJumped", "_legendaryBeat", "_licenseToChillUsed", "_lodestoneUsed", "_lookingGlass", "_loveTunnelToday", "_loveTunnelUsed", "_luckyGoldRingVolcoino", "_lunchBreak", "_lupineHormonesUsed", "_lyleFavored", "_madLiquorDrunk", "_madTeaParty", "_mafiaMiddleFingerRingUsed", "_managerialManipulationUsed", "_mansquitoSerumUsed", "_mapToACandyRichBlockUsed", "_maydayDropped", "_mayoDeviceRented", "_mayoTankSoaked", "_meatballMachineUsed", "_meatifyMatterUsed", "_milkOfMagnesiumUsed", "_mimeArmyShotglassUsed", "_missGravesVermouthDrunk", "_missileLauncherUsed", "_molehillMountainUsed", "_momFoodReceived", "_mrBurnsgerEaten", "_muffinOrderedToday", "_mushroomGardenVisited", "_neverendingPartyToday", "_newYouQuestCompleted", "_olympicSwimmingPool", "_olympicSwimmingPoolItemFound", "_overflowingGiftBasketUsed", "_partyHard", "_pastaAdditive", "_perfectFreezeUsed", "_perfectlyFairCoinUsed", "_petePartyThrown", "_peteRiotIncited", "_photocopyUsed", "_pickyTweezersUsed", "_pingPongGame", "_pirateBellowUsed", "_pirateForkUsed", "_pixelOrbUsed", "_plumbersMushroomStewEaten", "_pneumaticityPotionUsed", "_portableSteamUnitUsed", "_pottedTeaTreeUsed", "_prToday", "_psychoJarFilled", "_psychoJarUsed", "_psychokineticHugUsed", "_rainStickUsed", "_redwoodRainStickUsed", "_replicaSnowconeTomeUsed", "_replicaResolutionLibramUsed", "_replicaSmithsTomeUsed", "_requestSandwichSucceeded", "_rhinestonesAcquired", "_seaJellyHarvested", "_setOfJacksUsed", "_sewingKitUsed", "_sexChanged", "_shadowAffinityToday", "_shadowForestLooted", "_shrubDecorated", "_silverDreadFlaskUsed", "_sitCourseCompleted", "_skateBuff1", "_skateBuff2", "_skateBuff3", "_skateBuff4", "_skateBuff5", "_sleazeAirportToday", "_sobrieTeaUsed", "_softwareGlitchTurnReceived", "_sotParcelReturned", "_spacegateMurderbot", "_spacegateRuins", "_spacegateSpant", "_spacegateToday", "_spacegateVaccine", "_spaghettiBreakfast", "_spaghettiBreakfastEaten", "_spinmasterLatheVisited", "_spinningWheel", "_spookyAirportToday", "_stabonicScrollUsed", "_steelyEyedSquintUsed", "_stenchAirportToday", "_stinkyCheeseBanisherUsed", "_strangeStalagmiteUsed", "_streamsCrossed", "_stuffedPocketwatchUsed", "_styxSprayUsed", "_summonAnnoyanceUsed", "_summonCarrotUsed", "_summonResortPassUsed", "_sweetToothUsed", "_syntheticDogHairPillUsed", "_tacoFlierUsed", "_telegraphOfficeToday", "_templeHiddenPower", "_tempuraAirUsed", "_thesisDelivered", "_tiedUpFlamingLeafletFought", "_tiedUpFlamingMonsteraFought", "_tiedUpLeaviathanFought", "_timeSpinnerReplicatorUsed", "_toastSummoned", "_tonicDjinn", "_treasuryEliteMeatCollected", "_treasuryHaremMeatCollected", "_trivialAvocationsGame", "_tryptophanDartUsed", "_turtlePowerCast", "_twelveNightEnergyUsed", "_ultraMegaSourBallUsed", "_victorSpoilsUsed", "_villainLairCanLidUsed", "_villainLairColorChoiceUsed", "_villainLairDoorChoiceUsed", "_villainLairFirecrackerUsed", "_villainLairSymbologyChoiceUsed", "_villainLairWebUsed", "_vmaskBanisherUsed", "_voraciTeaUsed", "_volcanoItemRedeemed", "_volcanoSuperduperheatedMetal", "_voteToday", "_VYKEACafeteriaRaided", "_VYKEALoungeRaided", "_walfordQuestStartedToday", "_warbearBankUsed", "_warbearBreakfastMachineUsed", "_warbearGyrocopterUsed", "_warbearSodaMachineUsed", "_wildfireBarrelHarvested", "_witchessBuff", "_workshedItemUsed", "_zombieClover", "_preventScurvy", "lockedItem4637", "lockedItem4638", "lockedItem4639", "lockedItem4646", "lockedItem4647", "unknownRecipe3542", "unknownRecipe3543", "unknownRecipe3544", "unknownRecipe3545", "unknownRecipe3546", "unknownRecipe3547", "unknownRecipe3548", "unknownRecipe3749", "unknownRecipe3751", "unknownRecipe4172", "unknownRecipe4173", "unknownRecipe4174", "unknownRecipe5060", "unknownRecipe5061", "unknownRecipe5062", "unknownRecipe5063", "unknownRecipe5064", "unknownRecipe5066", "unknownRecipe5067", "unknownRecipe5069", "unknownRecipe5070", "unknownRecipe5072", "unknownRecipe5073", "unknownRecipe5670", "unknownRecipe5671", "unknownRecipe6501", "unknownRecipe6564", "unknownRecipe6565", "unknownRecipe6566", "unknownRecipe6567", "unknownRecipe6568", "unknownRecipe6569", "unknownRecipe6570", "unknownRecipe6571", "unknownRecipe6572", "unknownRecipe6573", "unknownRecipe6574", "unknownRecipe6575", "unknownRecipe6576", "unknownRecipe6577", "unknownRecipe6578", "unknownRecipe7752", "unknownRecipe7753", "unknownRecipe7754", "unknownRecipe7755", "unknownRecipe7756", "unknownRecipe7757", "unknownRecipe7758", "unknownRecipe10970", "unknownRecipe10971", "unknownRecipe10972", "unknownRecipe10973", "unknownRecipe10974", "unknownRecipe10975", "unknownRecipe10976", "unknownRecipe10977", "unknownRecipe10978", "unknownRecipe10988", "unknownRecipe10989", "unknownRecipe10990", "unknownRecipe10991", "unknownRecipe10992", "unknownRecipe11000"]; +var numericProperties = ["coinMasterIndex", "dailyDeedsVersion", "defaultDropdown1", "defaultDropdown2", "defaultDropdownSplit", "defaultLimit", "fixedThreadPoolSize", "itemManagerIndex", "lastBuffRequestType", "lastGlobalCounterDay", "lastImageCacheClear", "pingDefaultTestPings", "pingLoginCount", "pingLoginGoal", "pingLoginThreshold", "pingTestPings", "previousUpdateRevision", "relayDelayForSVN", "relaySkillButtonCount", "scriptButtonPosition", "statusDropdown", "svnThreadPoolSize", "toolbarPosition", "_beachTides", "_g9Effect", "8BitBonusTurns", "8BitScore", "addingScrolls", "affirmationCookiesEaten", "aminoAcidsUsed", "antagonisticSnowmanKitCost", "ascensionsToday", "asolDeferredPoints", "asolPointsPigSkinner", "asolPointsCheeseWizard", "asolPointsJazzAgent", "autoAbortThreshold", "autoAntidote", "autoBuyPriceLimit", "autumnatonQuestTurn", "availableCandyCredits", "availableDimes", "availableFunPoints", "availableMrStore2002Credits", "availableQuarters", "availableStoreCredits", "availableSwagger", "averageSwagger", "awolMedicine", "awolPointsBeanslinger", "awolPointsCowpuncher", "awolPointsSnakeoiler", "awolDeferredPointsBeanslinger", "awolDeferredPointsCowpuncher", "awolDeferredPointsSnakeoiler", "awolVenom", "bagOTricksCharges", "ballpitBonus", "bankedKarma", "bartenderTurnsUsed", "basementMallPrices", "basementSafetyMargin", "batmanFundsAvailable", "batmanBonusInitialFunds", "batmanTimeLeft", "bearSwagger", "beeCounter", "beGregariousCharges", "beGregariousFightsLeft", "birdformCold", "birdformHot", "birdformRoc", "birdformSleaze", "birdformSpooky", "birdformStench", "blackBartsBootyCost", "blackPuddingsDefeated", "blackForestProgress", "blankOutUsed", "bloodweiserDrunk", "bondPoints", "bondVillainsDefeated", "boneAbacusVictories", "bookOfFactsGummi", "bookOfFactsPinata", "booPeakProgress", "borisPoints", "breakableHandling", "breakableHandling1964", "breakableHandling9691", "breakableHandling9692", "breakableHandling9699", "breathitinCharges", "brodenBacteria", "brodenSprinkles", "buffBotMessageDisposal", "buffBotPhilanthropyType", "buffJimmyIngredients", "burnoutsDefeated", "burrowgrubSummonsRemaining", "camelSpit", "camerasUsed", "campAwayDecoration", "candyWitchTurnsUsed", "candyWitchCandyTotal", "carboLoading", "catBurglarBankHeists", "cellarLayout", "charitableDonations", "chasmBridgeProgress", "chefTurnsUsed", "chessboardsCleared", "chibiAlignment", "chibiBirthday", "chibiFitness", "chibiIntelligence", "chibiLastVisit", "chibiSocialization", "chilledToTheBone", "cinchoSaltAndLime", "cinderellaMinutesToMidnight", "cinderellaScore", "cocktailSummons", "commerceGhostCombats", "controlPanelOmega", "cornucopiasOpened", "cosmicBowlingBallReturnCombats", "cozyCounter6332", "cozyCounter6333", "cozyCounter6334", "craftingClay", "craftingLeather", "craftingStraw", "crimbo16BeardChakraCleanliness", "crimbo16BootsChakraCleanliness", "crimbo16BungChakraCleanliness", "crimbo16CrimboHatChakraCleanliness", "crimbo16GutsChakraCleanliness", "crimbo16HatChakraCleanliness", "crimbo16JellyChakraCleanliness", "crimbo16LiverChakraCleanliness", "crimbo16NippleChakraCleanliness", "crimbo16NoseChakraCleanliness", "crimbo16ReindeerChakraCleanliness", "crimbo16SackChakraCleanliness", "crimboTrainingSkill", "crimboTreeDays", "cubelingProgress", "currentExtremity", "currentHedgeMazeRoom", "currentMojoFilters", "currentNunneryMeat", "currentPortalEnergy", "currentReplicaStoreYear", "cursedMagnifyingGlassCount", "cyrptAlcoveEvilness", "cyrptCrannyEvilness", "cyrptNicheEvilness", "cyrptNookEvilness", "cyrptTotalEvilness", "darkGyfftePoints", "daycareEquipment", "daycareInstructors", "daycareLastScavenge", "daycareToddlers", "dbNemesisSkill1", "dbNemesisSkill2", "dbNemesisSkill3", "desertExploration", "desktopHeight", "desktopWidth", "dinseyFilthLevel", "dinseyFunProgress", "dinseyNastyBearsDefeated", "dinseySocialJusticeIProgress", "dinseySocialJusticeIIProgress", "dinseyTouristsFed", "dinseyToxicMultiplier", "doctorBagQuestLights", "doctorBagUpgrades", "dreadScroll1", "dreadScroll2", "dreadScroll3", "dreadScroll4", "dreadScroll5", "dreadScroll6", "dreadScroll7", "dreadScroll8", "dripAdventuresSinceAscension", "drippingHallAdventuresSinceAscension", "drippingTreesAdventuresSinceAscension", "drippyBatsUnlocked", "drippyJuice", "drippyOrbsClaimed", "drunkenSwagger", "edDefeatAbort", "edPoints", "eldritchTentaclesFought", "electricKoolAidEaten", "elfGratitude", "encountersUntilDMTChoice", "encountersUntilYachtzeeChoice", "encountersUntilNEPChoice", "encountersUntilSRChoice", "ensorceleeLevel", "entauntaunedColdRes", "essenceOfAnnoyanceCost", "essenceOfBearCost", "extraRolloverAdventures", "falloutShelterLevel", "familiarSweat", "fingernailsClipped", "fistSkillsKnown", "flyeredML", "fossilB", "fossilD", "fossilN", "fossilP", "fossilS", "fossilW", "fratboysDefeated", "frenchGuardTurtlesFreed", "funGuyMansionKills", "garbageChampagneCharge", "garbageFireProgress", "garbageShirtCharge", "garbageTreeCharge", "garlandUpgrades", "getsYouDrunkTurnsLeft", "ghostPepperTurnsLeft", "gingerDigCount", "gingerLawChoice", "gingerMuscleChoice", "gingerTrainScheduleStudies", "gladiatorBallMovesKnown", "gladiatorBladeMovesKnown", "gladiatorNetMovesKnown", "glitchItemCost", "glitchItemImplementationCount", "glitchItemImplementationLevel", "glitchSwagger", "gloverPoints", "gnasirProgress", "goldenMrAccessories", "gongPath", "gooseDronesRemaining", "goreCollected", "gourdItemCount", "greyYouPoints", "grimoire1Summons", "grimoire2Summons", "grimoire3Summons", "grimstoneCharge", "guardTurtlesFreed", "guideToSafariCost", "guyMadeOfBeesCount", "guzzlrBronzeDeliveries", "guzzlrDeliveryProgress", "guzzlrGoldDeliveries", "guzzlrPlatinumDeliveries", "haciendaLayout", "hallowiener8BitRealm", "hallowienerCoinspiracy", "hareMillisecondsSaved", "hareTurnsUsed", "heavyRainsStartingThunder", "heavyRainsStartingRain", "heavyRainsStartingLightning", "heroDonationBoris", "heroDonationJarlsberg", "heroDonationSneakyPete", "hiddenApartmentProgress", "hiddenBowlingAlleyProgress", "hiddenHospitalProgress", "hiddenOfficeProgress", "hiddenTavernUnlock", "highTopPumped", "hippiesDefeated", "holidayHalsBookCost", "holidaySwagger", "homemadeRobotUpgrades", "homebodylCharges", "hpAutoRecovery", "hpAutoRecoveryTarget", "iceSwagger", "jarlsbergPoints", "jungCharge", "junglePuns", "knownAscensions", "kolhsTotalSchoolSpirited", "lastAnticheeseDay", "lastArcadeAscension", "lastBadMoonReset", "lastBangPotionReset", "lastBattlefieldReset", "lastBeardBuff", "lastBreakfast", "lastCartographyBooPeak", "lastCartographyCastleTop", "lastCartographyDarkNeck", "lastCartographyDefiledNook", "lastCartographyFratHouse", "lastCartographyFratHouseVerge", "lastCartographyGuanoJunction", "lastCartographyHauntedBilliards", "lastCartographyHippyCampVerge", "lastCartographyZeppelinProtesters", "lastCastleGroundUnlock", "lastCastleTopUnlock", "lastCellarReset", "lastChanceThreshold", "lastChasmReset", "lastColosseumRoundWon", "lastCouncilVisit", "lastCounterDay", "lastDesertUnlock", "lastDispensaryOpen", "lastDMTDuplication", "lastDwarfFactoryReset", "lastEVHelmetValue", "lastEVHelmetReset", "lastEmptiedStorage", "lastFilthClearance", "lastGoofballBuy", "lastGuildStoreOpen", "lastGuyMadeOfBeesReset", "lastFratboyCall", "lastFriarCeremonyAscension", "lastFriarsElbowNC", "lastFriarsHeartNC", "lastFriarsNeckNC", "lastHippyCall", "lastIslandUnlock", "lastKeyotronUse", "lastKingLiberation", "lastLightsOutTurn", "lastMushroomPlot", "lastMiningReset", "lastNemesisReset", "lastPaperStripReset", "lastPirateEphemeraReset", "lastPirateInsultReset", "lastPlusSignUnlock", "lastQuartetAscension", "lastQuartetRequest", "lastSecondFloorUnlock", "lastShadowForgeUnlockAdventure", "lastSkateParkReset", "lastStillBeatingSpleen", "lastTavernAscension", "lastTavernSquare", "lastTelescopeReset", "lastTempleAdventures", "lastTempleButtonsUnlock", "lastTempleUnlock", "lastThingWithNoNameDefeated", "lastTowelAscension", "lastTr4pz0rQuest", "lastTrainsetConfiguration", "lastVioletFogMap", "lastVoteMonsterTurn", "lastWartDinseyDefeated", "lastWuTangDefeated", "lastYearbookCameraAscension", "lastZapperWand", "lastZapperWandExplosionDay", "lawOfAveragesCost", "legacyPoints", "libramSummons", "lightsOutAutomation", "louvreDesiredGoal", "louvreGoal", "lovebugsAridDesert", "lovebugsBeachBuck", "lovebugsBooze", "lovebugsChroner", "lovebugsCoinspiracy", "lovebugsCyrpt", "lovebugsFreddy", "lovebugsFunFunds", "lovebugsHoboNickel", "lovebugsItemDrop", "lovebugsMeat", "lovebugsMeatDrop", "lovebugsMoxie", "lovebugsMuscle", "lovebugsMysticality", "lovebugsOilPeak", "lovebugsOrcChasm", "lovebugsPowder", "lovebugsWalmart", "lttQuestDifficulty", "lttQuestStageCount", "manaBurnSummonThreshold", "manaBurningThreshold", "manaBurningTrigger", "manorDrawerCount", "manualOfNumberologyCost", "mapToKokomoCost", "masksUnlocked", "maximizerMRUSize", "maximizerCombinationLimit", "maximizerEquipmentLevel", "maximizerEquipmentScope", "maximizerMaxPrice", "maximizerPriceLevel", "maxManaBurn", "mayflyExperience", "mayoLevel", "meansuckerPrice", "merkinVocabularyMastery", "miniAdvClass", "miniMartinisDrunk", "moleTunnelLevel", "mothershipProgress", "mpAutoRecovery", "mpAutoRecoveryTarget", "munchiesPillsUsed", "mushroomGardenCropLevel", "nextParanormalActivity", "nextQuantumFamiliarOwnerId", "nextQuantumFamiliarTurn", "noobPoints", "noobDeferredPoints", "noodleSummons", "nsContestants1", "nsContestants2", "nsContestants3", "nuclearAutumnPoints", "numericSwagger", "nunsVisits", "oilPeakProgress", "optimalSwagger", "optimisticCandleProgress", "palindomeDudesDefeated", "parasolUsed", "pendingMapReflections", "pingpongSkill", "pirateSwagger", "plantingDay", "plumberBadgeCost", "plumberCostumeCost", "plumberPoints", "poolSharkCount", "poolSkill", "primaryLabGooIntensity", "prismaticSummons", "procrastinatorLanguageFluency", "promptAboutCrafting", "puzzleChampBonus", "pyramidPosition", "quantumPoints", "reagentSummons", "reanimatorArms", "reanimatorLegs", "reanimatorSkulls", "reanimatorWeirdParts", "reanimatorWings", "recentLocations", "redSnapperProgress", "relayPort", "relocatePygmyJanitor", "relocatePygmyLawyer", "rockinRobinProgress", "ROMOfOptimalityCost", "rumpelstiltskinKidsRescued", "rumpelstiltskinTurnsUsed", "rwbMonsterCount", "safariSwagger", "sausageGrinderUnits", "schoolOfHardKnocksDiplomaCost", "schoolSwagger", "scrapbookCharges", "screechCombats", "scriptMRULength", "seaodesFound", "SeasoningSwagger", "sexChanges", "shenInitiationDay", "shockingLickCharges", "singleFamiliarRun", "skillBurn3", "skillBurn90", "skillBurn153", "skillBurn154", "skillBurn155", "skillBurn1019", "skillBurn5017", "skillBurn6014", "skillBurn6015", "skillBurn6016", "skillBurn6020", "skillBurn6021", "skillBurn6022", "skillBurn6023", "skillBurn6024", "skillBurn6026", "skillBurn6028", "skillBurn7323", "skillBurn14008", "skillBurn14028", "skillBurn14038", "skillBurn15011", "skillBurn15028", "skillBurn17005", "skillBurn22034", "skillBurn22035", "skillBurn23301", "skillBurn23302", "skillBurn23303", "skillBurn23304", "skillBurn23305", "skillBurn23306", "skillLevel46", "skillLevel47", "skillLevel48", "skillLevel117", "skillLevel118", "skillLevel121", "skillLevel128", "skillLevel134", "skillLevel144", "skillLevel180", "skillLevel188", "skillLevel227", "skillLevel7254", "slimelingFullness", "slimelingStacksDropped", "slimelingStacksDue", "smoresEaten", "smutOrcNoncombatProgress", "sneakyPetePoints", "snojoMoxieWins", "snojoMuscleWins", "snojoMysticalityWins", "sourceAgentsDefeated", "sourceEnlightenment", "sourceInterval", "sourcePoints", "sourceTerminalGram", "sourceTerminalPram", "sourceTerminalSpam", "spaceBabyLanguageFluency", "spacePirateLanguageFluency", "spelunkyNextNoncombat", "spelunkySacrifices", "spelunkyWinCount", "spookyPuttyCopiesMade", "spookyVHSTapeMonsterTurn", "statbotUses", "sugarCounter4178", "sugarCounter4179", "sugarCounter4180", "sugarCounter4181", "sugarCounter4182", "sugarCounter4183", "sugarCounter4191", "summonAnnoyanceCost", "sweat", "tacoDanCocktailSauce", "tacoDanFishMeat", "tavernLayout", "telescopeUpgrades", "tempuraSummons", "timeSpinnerMedals", "timesRested", "tomeSummons", "totalCharitableDonations", "trainsetPosition", "turtleBlessingTurns", "twinPeakProgress", "twoCRSPoints", "unicornHornInflation", "universalSeasoningCost", "usable1HWeapons", "usable1xAccs", "usable2HWeapons", "usable3HWeapons", "usableAccessories", "usableHats", "usableOffhands", "usableOther", "usablePants", "usableShirts", "valueOfAdventure", "valueOfInventory", "valueOfStill", "valueOfTome", "vintnerCharge", "vintnerWineLevel", "violetFogGoal", "walfordBucketProgress", "warehouseProgress", "welcomeBackAdv", "whetstonesUsed", "wolfPigsEvicted", "wolfTurnsUsed", "writingDesksDefeated", "xoSkeleltonXProgress", "xoSkeleltonOProgress", "yearbookCameraAscensions", "yearbookCameraUpgrades", "youRobotBody", "youRobotBottom", "youRobotLeft", "youRobotPoints", "youRobotRight", "youRobotTop", "zeppelinProtestors", "zigguratLianas", "zombiePoints", "_absintheDrops", "_abstractionDropsCrown", "_aguaDrops", "_xenomorphCharge", "_ancestralRecallCasts", "_antihangoverBonus", "_astralDrops", "_augSkillsCast", "_autumnatonQuests", "_backUpUses", "_badlyRomanticArrows", "_badgerCharge", "_balefulHowlUses", "_banderRunaways", "_bastilleCheese", "_bastilleGames", "_bastilleGameTurn", "_bastilleLastCheese", "_beanCannonUses", "_bearHugs", "_beerLensDrops", "_bellydancerPickpockets", "_benettonsCasts", "_birdsSoughtToday", "_bookOfFactsWishes", "_bookOfFactsTatters", "_boomBoxFights", "_boomBoxSongsLeft", "_bootStomps", "_boxingGloveArrows", "_brickoEyeSummons", "_brickoFights", "_campAwayCloudBuffs", "_campAwaySmileBuffs", "_candySummons", "_captainHagnkUsed", "_carnieCandyDrops", "_carrotNoseDrops", "_catBurglarCharge", "_catBurglarHeistsComplete", "_cheerleaderSteam", "_chestXRayUsed", "_chibiAdventures", "_chipBags", "_chocolateCigarsUsed", "_chocolateCoveredPingPongBallsUsed", "_chocolateSculpturesUsed", "_chocolatesUsed", "_chronolithActivations", "_chronolithNextCost", "_cinchUsed", "_cinchoRests", "_circadianRhythmsAdventures", "_clanFortuneConsultUses", "_clipartSummons", "_cloversPurchased", "_coldMedicineConsults", "_coldMedicineEquipmentTaken", "_companionshipCasts", "_cookbookbatCrafting", "_cosmicBowlingSkillsUsed", "_crimbo21ColdResistance", "_dailySpecialPrice", "_daycareGymScavenges", "_daycareRecruits", "_deckCardsDrawn", "_deluxeKlawSummons", "_demandSandwich", "_detectiveCasesCompleted", "_disavowed", "_dnaPotionsMade", "_donhosCasts", "_douseFoeUses", "_dreamJarDrops", "_drunkPygmyBanishes", "_edDefeats", "_edLashCount", "_elronsCasts", "_enamorangs", "_energyCollected", "_expertCornerCutterUsed", "_favorRareSummons", "_feastUsed", "_feelinTheRhythm", "_feelPrideUsed", "_feelExcitementUsed", "_feelHatredUsed", "_feelLonelyUsed", "_feelNervousUsed", "_feelEnvyUsed", "_feelDisappointedUsed", "_feelSuperiorUsed", "_feelLostUsed", "_feelNostalgicUsed", "_feelPeacefulUsed", "_fingertrapArrows", "_fireExtinguisherCharge", "_fragrantHerbsUsed", "_freeBeachWalksUsed", "_frButtonsPressed", "_fudgeWaspFights", "_gapBuffs", "_garbageFireDrops", "_garbageFireDropsCrown", "_genieFightsUsed", "_genieWishesUsed", "_gibbererAdv", "_gibbererCharge", "_gingerbreadCityTurns", "_glarkCableUses", "_glitchMonsterFights", "_gnomeAdv", "_godLobsterFights", "_goldenMoneyCharge", "_gongDrops", "_gothKidCharge", "_gothKidFights", "_greyYouAdventures", "_grimBrotherCharge", "_grimFairyTaleDrops", "_grimFairyTaleDropsCrown", "_grimoireConfiscatorSummons", "_grimoireGeekySummons", "_grimstoneMaskDrops", "_grimstoneMaskDropsCrown", "_grooseCharge", "_grooseDrops", "_grubbyWoolDrops", "_guzzlrDeliveries", "_guzzlrGoldDeliveries", "_guzzlrPlatinumDeliveries", "_hareAdv", "_hareCharge", "_highTopPumps", "_hipsterAdv", "_hoardedCandyDropsCrown", "_hoboUnderlingSummons", "_holoWristDrops", "_holoWristProgress", "_hotAshesDrops", "_hotJellyUses", "_hotTubSoaks", "_humanMuskUses", "_iceballUses", "_inigosCasts", "_jerksHealthMagazinesUsed", "_jiggleCheese", "_jiggleCream", "_jiggleLife", "_jiggleSteak", "_jitbCharge", "_juneCleaverFightsLeft", "_juneCleaverEncounters", "_juneCleaverStench", "_juneCleaverSpooky", "_juneCleaverSleaze", "_juneCleaverHot", "_juneCleaverCold", "_juneCleaverSkips", "_jungDrops", "_kgbClicksUsed", "_kgbDispenserUses", "_kgbTranquilizerDartUses", "_klawSummons", "_kloopCharge", "_kloopDrops", "_kolhsAdventures", "_kolhsSavedByTheBell", "_lastDailyDungeonRoom", "_lastSausageMonsterTurn", "_lastZomboEye", "_latteRefillsUsed", "_leafblowerML", "_leafLassosCrafted", "_leafMonstersFought", "_leavesBurned", "_legionJackhammerCrafting", "_llamaCharge", "_longConUsed", "_lovebugsBeachBuck", "_lovebugsChroner", "_lovebugsCoinspiracy", "_lovebugsFreddy", "_lovebugsFunFunds", "_lovebugsHoboNickel", "_lovebugsWalmart", "_loveChocolatesUsed", "_lynyrdSnareUses", "_machineTunnelsAdv", "_macrometeoriteUses", "_mafiaThumbRingAdvs", "_mapToACandyRichBlockDrops", "_mayflowerDrops", "_mayflySummons", "_mediumSiphons", "_meteoriteAdesUsed", "_meteorShowerUses", "_micrometeoriteUses", "_mildEvilPerpetrated", "_miniMartiniDrops", "_monkeyPawWishesUsed", "_monsterHabitatsFightsLeft", "_monsterHabitatsRecalled", "_monstersMapped", "_mushroomGardenFights", "_nanorhinoCharge", "_navelRunaways", "_neverendingPartyFreeTurns", "_newYouQuestSharpensDone", "_newYouQuestSharpensToDo", "_nextColdMedicineConsult", "_nextQuantumAlignment", "_nightmareFuelCharges", "_noobSkillCount", "_nuclearStockpileUsed", "_oilExtracted", "_olfactionsUsed", "_optimisticCandleDropsCrown", "_oreDropsCrown", "_otoscopeUsed", "_oysterEggsFound", "_pantsgivingBanish", "_pantsgivingCount", "_pantsgivingCrumbs", "_pantsgivingFullness", "_pasteDrops", "_peteJukeboxFixed", "_peteJumpedShark", "_petePeeledOut", "_pieDrops", "_piePartsCount", "_pixieCharge", "_pocketProfessorLectures", "_poisonArrows", "_pokeGrowFertilizerDrops", "_poolGames", "_powderedGoldDrops", "_powderedMadnessUses", "_powerfulGloveBatteryPowerUsed", "_powerPillDrops", "_powerPillUses", "_precisionCasts", "_questPartyFairItemsOpened", "_radlibSummons", "_raindohCopiesMade", "_rapidPrototypingUsed", "_raveStealCount", "_reflexHammerUsed", "_resolutionAdv", "_resolutionRareSummons", "_riftletAdv", "_robinEggDrops", "_roboDrops", "_rogueProgramCharge", "_romanticFightsLeft", "_saberForceMonsterCount", "_saberForceUses", "_saberMod", "_saltGrainsConsumed", "_sandwormCharge", "_saplingsPlanted", "_sausageFights", "_sausagesEaten", "_sausagesMade", "_sealFigurineUses", "_sealScreeches", "_sealsSummoned", "_shadowBricksUsed", "_shadowRiftCombats", "_shatteringPunchUsed", "_shortOrderCookCharge", "_shrubCharge", "_sloppyDinerBeachBucks", "_smilesOfMrA", "_smithsnessSummons", "_snojoFreeFights", "_snojoParts", "_snokebombUsed", "_snowconeSummons", "_snowglobeDrops", "_snowSuitCount", "_sourceTerminalDigitizeMonsterCount", "_sourceTerminalDigitizeUses", "_sourceTerminalDuplicateUses", "_sourceTerminalEnhanceUses", "_sourceTerminalExtrudes", "_sourceTerminalPortscanUses", "_spaceFurDropsCrown", "_spacegatePlanetIndex", "_spacegateTurnsLeft", "_spaceJellyfishDrops", "_speakeasyDrinksDrunk", "_speakeasyFreeFights", "_spelunkerCharges", "_spelunkingTalesDrops", "_spikolodonSpikeUses", "_spookyJellyUses", "_stackLumpsUses", "_steamCardDrops", "_stickerSummons", "_stinkyCheeseCount", "_stressBallSqueezes", "_sugarSummons", "_sweatOutSomeBoozeUsed", "_taffyRareSummons", "_taffyYellowSummons", "_thanksgettingFoodsEaten", "_thingfinderCasts", "_thinknerdPackageDrops", "_thorsPliersCrafting", "_timeHelmetAdv", "_timeSpinnerMinutesUsed", "_tokenDrops", "_transponderDrops", "_turkeyBlastersUsed", "_turkeyBooze", "_turkeyMuscle", "_turkeyMyst", "_turkeyMoxie", "_unaccompaniedMinerUsed", "_unconsciousCollectiveCharge", "_universalSeasoningsUsed", "_universeCalculated", "_universeImploded", "_usedReplicaBatoomerang", "_vampyreCloakeFormUses", "_villainLairProgress", "_vitachocCapsulesUsed", "_vmaskAdv", "_voidFreeFights", "_volcanoItem1", "_volcanoItem2", "_volcanoItem3", "_volcanoItemCount1", "_volcanoItemCount2", "_volcanoItemCount3", "_voteFreeFights", "_VYKEACompanionLevel", "_warbearAutoAnvilCrafting", "_waxGlobDrops", "_whiteRiceDrops", "_witchessFights", "_xoHugsUsed", "_yellowPixelDropsCrown", "_zapCount", "_zombieSmashPocketsUsed"]; +var monsterProperties = ["beGregariousMonster", "cameraMonster", "chateauMonster", "clumsinessGroveBoss", "crappyCameraMonster", "crudeMonster", "enamorangMonster", "envyfishMonster", "glacierOfJerksBoss", "holdHandsMonster", "iceSculptureMonster", "lastCopyableMonster", "longConMonster", "maelstromOfLoversBoss", "makeFriendsMonster", "merkinLockkeyMonster", "monkeyPointMonster", "motifMonster", "nosyNoseMonster", "olfactedMonster", "photocopyMonster", "rainDohMonster", "romanticTarget", "rufusDesiredEntity", "rwbMonster", "screencappedMonster", "spookyPuttyMonster", "spookyVHSTapeMonster", "stenchCursedMonster", "superficiallyInterestedMonster", "waxMonster", "yearbookCameraTarget", "_gallapagosMonster", "_jiggleCreamedMonster", "_latteMonster", "_monsterHabitatsMonster", "_nanorhinoBanishedMonster", "_newYouQuestMonster", "_relativityMonster", "_saberForceMonster", "_sourceTerminalDigitizeMonster", "_voteMonster"]; +var locationProperties = ["autumnatonQuestLocation", "currentJunkyardLocation", "doctorBagQuestLocation", "ghostLocation", "guzzlrQuestLocation", "nextSpookyravenElizabethRoom", "nextSpookyravenStephenRoom", "rwbLocation", "sourceOracleTarget", "_floundryBassLocation", "_floundryCarpLocation", "_floundryCodLocation", "_floundryHatchetfishLocation", "_floundryTroutLocation", "_floundryTunaLocation", "_sotParcelLocation"]; +var stringProperties = ["autoLogin", "browserBookmarks", "chatFontSize", "combatHotkey0", "combatHotkey1", "combatHotkey2", "combatHotkey3", "combatHotkey4", "combatHotkey5", "combatHotkey6", "combatHotkey7", "combatHotkey8", "combatHotkey9", "commandLineNamespace", "dailyDeedsOptions", "defaultBorderColor", "displayName", "externalEditor", "getBreakfast", "headerStates", "highlightList", "http.proxyHost", "http.proxyPassword", "http.proxyPort", "http.proxyUser", "https.proxyHost", "https.proxyPassword", "https.proxyPort", "https.proxyUser", "initialDesktop", "initialFrames", "lastRelayUpdate", "lastUserAgent", "lastUsername", "logPreferenceChangeFilter", "loginScript", "loginServerName", "loginWindowLogo", "logoutScript", "pingDefaultTestPage", "pingLatest", "pingLoginAbort", "pingLoginCheck", "pingLoginFail", "pingLongest", "pingShortest", "pingTestPage", "previousNotifyList", "previousUpdateVersion", "saveState", "saveStateActive", "scriptList", "swingLookAndFeel", "userAgent", "8BitColor", "afterAdventureScript", "autoOlfact", "autoPutty", "autumnatonUpgrades", "backupCameraMode", "banishedMonsters", "banishedPhyla", "banishingShoutMonsters", "batmanStats", "batmanZone", "batmanUpgrades", "battleAction", "beachHeadsUnlocked", "beforePVPScript", "betweenBattleScript", "boomBoxSong", "breakfastAlways", "breakfastHardcore", "breakfastSoftcore", "buffBotCasting", "buyScript", "cargoPocketsEmptied", "cargoPocketScraps", "chatbotScript", "chatPlayerScript", "chibiName", "choiceAdventureScript", "chosenTrip", "clanFortuneReply1", "clanFortuneReply2", "clanFortuneReply3", "clanFortuneWord1", "clanFortuneWord2", "clanFortuneWord3", "commerceGhostItem", "counterScript", "copperheadClubHazard", "crimbotChassis", "crimbotArm", "crimbotPropulsion", "crystalBallPredictions", "csServicesPerformed", "currentAstralTrip", "currentDistillateMods", "currentEasyBountyItem", "currentHardBountyItem", "currentHippyStore", "currentJunkyardTool", "currentLlamaForm", "currentMood", "currentPVPSeason", "currentPvpVictories", "currentSpecialBountyItem", "currentSITSkill", "customCombatScript", "cyrusAdjectives", "defaultFlowerLossMessage", "defaultFlowerWinMessage", "demonName1", "demonName2", "demonName3", "demonName4", "demonName5", "demonName6", "demonName7", "demonName8", "demonName9", "demonName10", "demonName11", "demonName12", "demonName13", "dinseyGatorStenchDamage", "dinseyRollercoasterStats", "doctorBagQuestItem", "dolphinItem", "duckAreasCleared", "duckAreasSelected", "edPiece", "enamorangMonsterTurn", "ensorcelee", "EVEDirections", "extraCosmeticModifiers", "familiarScript", "forbiddenStores", "gameProBossSpecialPower", "gooseReprocessed", "grimoireSkillsHardcore", "grimoireSkillsSoftcore", "grimstoneMaskPath", "guzzlrQuestClient", "guzzlrQuestBooze", "guzzlrQuestTier", "harvestGardenHardcore", "harvestGardenSoftcore", "hpAutoRecoveryItems", "invalidBuffMessage", "jickSwordModifier", "juneCleaverQueue", "kingLiberatedScript", "lassoTraining", "lastAdventure", "lastBangPotion819", "lastBangPotion820", "lastBangPotion821", "lastBangPotion822", "lastBangPotion823", "lastBangPotion824", "lastBangPotion825", "lastBangPotion826", "lastBangPotion827", "lastChanceBurn", "lastChessboard", "lastCombatEnvironments", "lastDwarfDiceRolls", "lastDwarfDigitRunes", "lastDwarfEquipmentRunes", "lastDwarfFactoryItem118", "lastDwarfFactoryItem119", "lastDwarfFactoryItem120", "lastDwarfFactoryItem360", "lastDwarfFactoryItem361", "lastDwarfFactoryItem362", "lastDwarfFactoryItem363", "lastDwarfFactoryItem364", "lastDwarfFactoryItem365", "lastDwarfFactoryItem910", "lastDwarfFactoryItem3199", "lastDwarfOfficeItem3208", "lastDwarfOfficeItem3209", "lastDwarfOfficeItem3210", "lastDwarfOfficeItem3211", "lastDwarfOfficeItem3212", "lastDwarfOfficeItem3213", "lastDwarfOfficeItem3214", "lastDwarfOreRunes", "lastDwarfHopper1", "lastDwarfHopper2", "lastDwarfHopper3", "lastDwarfHopper4", "lastEncounter", "lastMacroError", "lastMessageId", "lastPaperStrip3144", "lastPaperStrip4138", "lastPaperStrip4139", "lastPaperStrip4140", "lastPaperStrip4141", "lastPaperStrip4142", "lastPaperStrip4143", "lastPaperStrip4144", "lastPirateEphemera", "lastPorkoBoard", "lastPorkoPayouts", "lastPorkoExpected", "lastSlimeVial3885", "lastSlimeVial3886", "lastSlimeVial3887", "lastSlimeVial3888", "lastSlimeVial3889", "lastSlimeVial3890", "lastSlimeVial3891", "lastSlimeVial3892", "lastSlimeVial3893", "lastSlimeVial3894", "lastSlimeVial3895", "lastSlimeVial3896", "latteIngredients", "latteModifier", "latteUnlocks", "ledCandleMode", "libramSkillsHardcore", "libramSkillsSoftcore", "louvreOverride", "lovePotion", "lttQuestName", "maximizerList", "maximizerMRUList", "mayoInMouth", "mayoMinderSetting", "merkinQuestPath", "mineLayout1", "mineLayout2", "mineLayout3", "mineLayout4", "mineLayout5", "mineLayout6", "mpAutoRecoveryItems", "muffinOnOrder", "nextAdventure", "nextDistillateMods", "nextQuantumFamiliarName", "nextQuantumFamiliarOwner", "nsChallenge2", "nsChallenge3", "nsChallenge4", "nsChallenge5", "nsTowerDoorKeysUsed", "oceanAction", "oceanDestination", "parkaMode", "pastaThrall1", "pastaThrall2", "pastaThrall3", "pastaThrall4", "pastaThrall5", "pastaThrall6", "pastaThrall7", "pastaThrall8", "peteMotorbikeTires", "peteMotorbikeGasTank", "peteMotorbikeHeadlight", "peteMotorbikeCowling", "peteMotorbikeMuffler", "peteMotorbikeSeat", "pieStuffing", "plantingDate", "plantingLength", "plantingScript", "plumberCostumeWorn", "pokefamBoosts", "postAscensionScript", "preAscensionScript", "questClumsinessGrove", "questDoctorBag", "questECoBucket", "questESlAudit", "questESlBacteria", "questESlCheeseburger", "questESlCocktail", "questESlDebt", "questESlFish", "questESlMushStash", "questESlSalt", "questESlSprinkles", "questESpClipper", "questESpEVE", "questESpFakeMedium", "questESpGore", "questESpJunglePun", "questESpOutOfOrder", "questESpSerum", "questESpSmokes", "questEStFishTrash", "questEStGiveMeFuel", "questEStNastyBears", "questEStSocialJusticeI", "questEStSocialJusticeII", "questEStSuperLuber", "questEStWorkWithFood", "questEStZippityDooDah", "questEUNewYou", "questF01Primordial", "questF02Hyboria", "questF03Future", "questF04Elves", "questF05Clancy", "questG01Meatcar", "questG02Whitecastle", "questG03Ego", "questG04Nemesis", "questG05Dark", "questG06Delivery", "questG07Myst", "questG08Moxie", "questG09Muscle", "questGlacierOfJerks", "questGuzzlr", "questI01Scapegoat", "questI02Beat", "questL02Larva", "questL03Rat", "questL04Bat", "questL05Goblin", "questL06Friar", "questL07Cyrptic", "questL08Trapper", "questL09Topping", "questL10Garbage", "questL11Black", "questL11Business", "questL11Curses", "questL11Desert", "questL11Doctor", "questL11MacGuffin", "questL11Manor", "questL11Palindome", "questL11Pyramid", "questL11Ron", "questL11Shen", "questL11Spare", "questL11Worship", "questL12HippyFrat", "questL12War", "questL13Final", "questL13Warehouse", "questLTTQuestByWire", "questM01Untinker", "questM02Artist", "questM03Bugbear", "questM05Toot", "questM06Gourd", "questM07Hammer", "questM08Baker", "questM09Rocks", "questM10Azazel", "questM11Postal", "questM12Pirate", "questM13Escape", "questM14Bounty", "questM15Lol", "questM16Temple", "questM17Babies", "questM18Swamp", "questM19Hippy", "questM20Necklace", "questM21Dance", "questM22Shirt", "questM23Meatsmith", "questM24Doc", "questM25Armorer", "questM26Oracle", "questMaelstromOfLovers", "questPAGhost", "questRufus", "questS01OldGuy", "questS02Monkees", "raveCombo1", "raveCombo2", "raveCombo3", "raveCombo4", "raveCombo5", "raveCombo6", "recoveryScript", "relayCounters", "retroCapeSuperhero", "retroCapeWashingInstructions", "royalty", "rufusDesiredArtifact", "rufusDesiredItems", "rufusQuestTarget", "rufusQuestType", "scriptMRUList", "seahorseName", "shadowLabyrinthGoal", "shadowRiftIngress", "shenQuestItem", "shrubGarland", "shrubGifts", "shrubLights", "shrubTopper", "sideDefeated", "sidequestArenaCompleted", "sidequestFarmCompleted", "sidequestJunkyardCompleted", "sidequestLighthouseCompleted", "sidequestNunsCompleted", "sidequestOrchardCompleted", "skateParkStatus", "snowsuit", "sourceTerminalChips", "sourceTerminalEducate1", "sourceTerminalEducate2", "sourceTerminalEnquiry", "sourceTerminalEducateKnown", "sourceTerminalEnhanceKnown", "sourceTerminalEnquiryKnown", "sourceTerminalExtrudeKnown", "spadingData", "spadingScript", "speakeasyName", "spelunkyStatus", "spelunkyUpgrades", "spookyravenRecipeUsed", "stationaryButton1", "stationaryButton2", "stationaryButton3", "stationaryButton4", "stationaryButton5", "streamCrossDefaultTarget", "sweetSynthesisBlacklist", "telescope1", "telescope2", "telescope3", "telescope4", "telescope5", "testudinalTeachings", "textColors", "thanksMessage", "tomeSkillsHardcore", "tomeSkillsSoftcore", "trackVoteMonster", "trainsetConfiguration", "trapperOre", "umbrellaState", "umdLastObtained", "vintnerWineEffect", "vintnerWineName", "vintnerWineType", "violetFogLayout", "volcanoMaze1", "volcanoMaze2", "volcanoMaze3", "volcanoMaze4", "volcanoMaze5", "walfordBucketItem", "warProgress", "watchedPreferences", "workteaClue", "yourFavoriteBird", "yourFavoriteBirdMods", "youRobotCPUUpgrades", "_bastilleBoosts", "_bastilleChoice1", "_bastilleChoice2", "_bastilleChoice3", "_bastilleCurrentStyles", "_bastilleEnemyCastle", "_bastilleEnemyName", "_bastilleLastBattleResults", "_bastilleLastEncounter", "_bastilleStats", "_beachHeadsUsed", "_beachLayout", "_beachMinutes", "_birdOfTheDay", "_birdOfTheDayMods", "_bittycar", "_campAwaySmileBuffSign", "_citizenZone", "_citizenZoneMods", "_cloudTalkMessage", "_cloudTalkSmoker", "_coatOfPaintModifier", "_dailySpecial", "_deckCardsSeen", "_feastedFamiliars", "_floristPlantsUsed", "_frAreasUnlocked", "_frHoursLeft", "_frMonstersKilled", "_horsery", "_horseryCrazyMox", "_horseryCrazyMus", "_horseryCrazyMys", "_horseryCrazyName", "_horseryCurrentName", "_horseryDarkName", "_horseryNormalName", "_horseryPaleName", "_jickJarAvailable", "_jiggleCheesedMonsters", "_lastCombatStarted", "_lastPirateRealmIsland", "_locketMonstersFought", "_mummeryMods", "_mummeryUses", "_newYouQuestSkill", "_noHatModifier", "_pantogramModifier", "_pottedPowerPlant", "_questESp", "_questPartyFair", "_questPartyFairProgress", "_questPartyFairQuest", "_roboDrinks", "_roninStoragePulls", "_spacegateAnimalLife", "_spacegateCoordinates", "_spacegateGear", "_spacegateHazards", "_spacegateIntelligentLife", "_spacegatePlanetName", "_spacegatePlantLife", "_stolenAccordions", "_tempRelayCounters", "_timeSpinnerFoodAvailable", "_unknownEasyBountyItem", "_unknownHardBountyItem", "_unknownSpecialBountyItem", "_untakenEasyBountyItem", "_untakenHardBountyItem", "_untakenSpecialBountyItem", "_userMods", "_villainLairColor", "_villainLairKey", "_voteLocal1", "_voteLocal2", "_voteLocal3", "_voteLocal4", "_voteMonster1", "_voteMonster2", "_voteModifier", "_VYKEACompanionType", "_VYKEACompanionRune", "_VYKEACompanionName"]; +var numericOrStringProperties = ["statusEngineering", "statusGalley", "statusMedbay", "statusMorgue", "statusNavigation", "statusScienceLab", "statusSonar", "statusSpecialOps", "statusWasteProcessing", "choiceAdventure2", "choiceAdventure3", "choiceAdventure4", "choiceAdventure5", "choiceAdventure6", "choiceAdventure7", "choiceAdventure8", "choiceAdventure9", "choiceAdventure10", "choiceAdventure11", "choiceAdventure12", "choiceAdventure14", "choiceAdventure15", "choiceAdventure16", "choiceAdventure17", "choiceAdventure18", "choiceAdventure19", "choiceAdventure20", "choiceAdventure21", "choiceAdventure22", "choiceAdventure23", "choiceAdventure24", "choiceAdventure25", "choiceAdventure26", "choiceAdventure27", "choiceAdventure28", "choiceAdventure29", "choiceAdventure40", "choiceAdventure41", "choiceAdventure42", "choiceAdventure45", "choiceAdventure46", "choiceAdventure47", "choiceAdventure71", "choiceAdventure72", "choiceAdventure73", "choiceAdventure74", "choiceAdventure75", "choiceAdventure76", "choiceAdventure77", "choiceAdventure86", "choiceAdventure87", "choiceAdventure88", "choiceAdventure89", "choiceAdventure90", "choiceAdventure91", "choiceAdventure105", "choiceAdventure106", "choiceAdventure107", "choiceAdventure108", "choiceAdventure109", "choiceAdventure110", "choiceAdventure111", "choiceAdventure112", "choiceAdventure113", "choiceAdventure114", "choiceAdventure115", "choiceAdventure116", "choiceAdventure117", "choiceAdventure118", "choiceAdventure120", "choiceAdventure123", "choiceAdventure125", "choiceAdventure126", "choiceAdventure127", "choiceAdventure129", "choiceAdventure131", "choiceAdventure132", "choiceAdventure135", "choiceAdventure136", "choiceAdventure137", "choiceAdventure138", "choiceAdventure139", "choiceAdventure140", "choiceAdventure141", "choiceAdventure142", "choiceAdventure143", "choiceAdventure144", "choiceAdventure145", "choiceAdventure146", "choiceAdventure147", "choiceAdventure148", "choiceAdventure149", "choiceAdventure151", "choiceAdventure152", "choiceAdventure153", "choiceAdventure154", "choiceAdventure155", "choiceAdventure156", "choiceAdventure157", "choiceAdventure158", "choiceAdventure159", "choiceAdventure160", "choiceAdventure161", "choiceAdventure162", "choiceAdventure163", "choiceAdventure164", "choiceAdventure165", "choiceAdventure166", "choiceAdventure167", "choiceAdventure168", "choiceAdventure169", "choiceAdventure170", "choiceAdventure171", "choiceAdventure172", "choiceAdventure177", "choiceAdventure178", "choiceAdventure180", "choiceAdventure181", "choiceAdventure182", "choiceAdventure184", "choiceAdventure185", "choiceAdventure186", "choiceAdventure187", "choiceAdventure188", "choiceAdventure189", "choiceAdventure191", "choiceAdventure197", "choiceAdventure198", "choiceAdventure199", "choiceAdventure200", "choiceAdventure201", "choiceAdventure202", "choiceAdventure203", "choiceAdventure204", "choiceAdventure205", "choiceAdventure206", "choiceAdventure207", "choiceAdventure208", "choiceAdventure211", "choiceAdventure212", "choiceAdventure213", "choiceAdventure214", "choiceAdventure215", "choiceAdventure216", "choiceAdventure217", "choiceAdventure218", "choiceAdventure219", "choiceAdventure220", "choiceAdventure221", "choiceAdventure222", "choiceAdventure223", "choiceAdventure224", "choiceAdventure225", "choiceAdventure230", "choiceAdventure272", "choiceAdventure273", "choiceAdventure276", "choiceAdventure277", "choiceAdventure278", "choiceAdventure279", "choiceAdventure280", "choiceAdventure281", "choiceAdventure282", "choiceAdventure283", "choiceAdventure284", "choiceAdventure285", "choiceAdventure286", "choiceAdventure287", "choiceAdventure288", "choiceAdventure289", "choiceAdventure290", "choiceAdventure291", "choiceAdventure292", "choiceAdventure293", "choiceAdventure294", "choiceAdventure295", "choiceAdventure296", "choiceAdventure297", "choiceAdventure298", "choiceAdventure299", "choiceAdventure302", "choiceAdventure303", "choiceAdventure304", "choiceAdventure305", "choiceAdventure306", "choiceAdventure307", "choiceAdventure308", "choiceAdventure309", "choiceAdventure310", "choiceAdventure311", "choiceAdventure317", "choiceAdventure318", "choiceAdventure319", "choiceAdventure320", "choiceAdventure321", "choiceAdventure322", "choiceAdventure326", "choiceAdventure327", "choiceAdventure328", "choiceAdventure329", "choiceAdventure330", "choiceAdventure331", "choiceAdventure332", "choiceAdventure333", "choiceAdventure334", "choiceAdventure335", "choiceAdventure336", "choiceAdventure337", "choiceAdventure338", "choiceAdventure339", "choiceAdventure340", "choiceAdventure341", "choiceAdventure342", "choiceAdventure343", "choiceAdventure344", "choiceAdventure345", "choiceAdventure346", "choiceAdventure347", "choiceAdventure348", "choiceAdventure349", "choiceAdventure350", "choiceAdventure351", "choiceAdventure352", "choiceAdventure353", "choiceAdventure354", "choiceAdventure355", "choiceAdventure356", "choiceAdventure357", "choiceAdventure358", "choiceAdventure360", "choiceAdventure361", "choiceAdventure362", "choiceAdventure363", "choiceAdventure364", "choiceAdventure365", "choiceAdventure366", "choiceAdventure367", "choiceAdventure372", "choiceAdventure376", "choiceAdventure387", "choiceAdventure388", "choiceAdventure389", "choiceAdventure390", "choiceAdventure391", "choiceAdventure392", "choiceAdventure393", "choiceAdventure395", "choiceAdventure396", "choiceAdventure397", "choiceAdventure398", "choiceAdventure399", "choiceAdventure400", "choiceAdventure401", "choiceAdventure402", "choiceAdventure403", "choiceAdventure423", "choiceAdventure424", "choiceAdventure425", "choiceAdventure426", "choiceAdventure427", "choiceAdventure428", "choiceAdventure429", "choiceAdventure430", "choiceAdventure431", "choiceAdventure432", "choiceAdventure433", "choiceAdventure435", "choiceAdventure438", "choiceAdventure439", "choiceAdventure442", "choiceAdventure444", "choiceAdventure445", "choiceAdventure446", "choiceAdventure447", "choiceAdventure448", "choiceAdventure449", "choiceAdventure451", "choiceAdventure452", "choiceAdventure453", "choiceAdventure454", "choiceAdventure455", "choiceAdventure456", "choiceAdventure457", "choiceAdventure458", "choiceAdventure460", "choiceAdventure461", "choiceAdventure462", "choiceAdventure463", "choiceAdventure464", "choiceAdventure465", "choiceAdventure467", "choiceAdventure468", "choiceAdventure469", "choiceAdventure470", "choiceAdventure471", "choiceAdventure472", "choiceAdventure473", "choiceAdventure474", "choiceAdventure475", "choiceAdventure477", "choiceAdventure478", "choiceAdventure480", "choiceAdventure483", "choiceAdventure484", "choiceAdventure485", "choiceAdventure486", "choiceAdventure488", "choiceAdventure489", "choiceAdventure490", "choiceAdventure491", "choiceAdventure496", "choiceAdventure497", "choiceAdventure502", "choiceAdventure503", "choiceAdventure504", "choiceAdventure505", "choiceAdventure506", "choiceAdventure507", "choiceAdventure509", "choiceAdventure510", "choiceAdventure511", "choiceAdventure512", "choiceAdventure513", "choiceAdventure514", "choiceAdventure515", "choiceAdventure517", "choiceAdventure518", "choiceAdventure519", "choiceAdventure521", "choiceAdventure522", "choiceAdventure523", "choiceAdventure527", "choiceAdventure528", "choiceAdventure529", "choiceAdventure530", "choiceAdventure531", "choiceAdventure532", "choiceAdventure533", "choiceAdventure534", "choiceAdventure535", "choiceAdventure536", "choiceAdventure538", "choiceAdventure539", "choiceAdventure542", "choiceAdventure543", "choiceAdventure544", "choiceAdventure546", "choiceAdventure548", "choiceAdventure549", "choiceAdventure550", "choiceAdventure551", "choiceAdventure552", "choiceAdventure553", "choiceAdventure554", "choiceAdventure556", "choiceAdventure557", "choiceAdventure558", "choiceAdventure559", "choiceAdventure560", "choiceAdventure561", "choiceAdventure562", "choiceAdventure563", "choiceAdventure564", "choiceAdventure565", "choiceAdventure566", "choiceAdventure567", "choiceAdventure568", "choiceAdventure569", "choiceAdventure571", "choiceAdventure572", "choiceAdventure573", "choiceAdventure574", "choiceAdventure575", "choiceAdventure576", "choiceAdventure577", "choiceAdventure578", "choiceAdventure579", "choiceAdventure581", "choiceAdventure582", "choiceAdventure583", "choiceAdventure584", "choiceAdventure594", "choiceAdventure595", "choiceAdventure596", "choiceAdventure597", "choiceAdventure598", "choiceAdventure599", "choiceAdventure600", "choiceAdventure603", "choiceAdventure604", "choiceAdventure616", "choiceAdventure634", "choiceAdventure640", "choiceAdventure654", "choiceAdventure655", "choiceAdventure656", "choiceAdventure657", "choiceAdventure658", "choiceAdventure664", "choiceAdventure669", "choiceAdventure670", "choiceAdventure671", "choiceAdventure672", "choiceAdventure673", "choiceAdventure674", "choiceAdventure675", "choiceAdventure676", "choiceAdventure677", "choiceAdventure678", "choiceAdventure679", "choiceAdventure681", "choiceAdventure683", "choiceAdventure684", "choiceAdventure685", "choiceAdventure686", "choiceAdventure687", "choiceAdventure688", "choiceAdventure689", "choiceAdventure690", "choiceAdventure691", "choiceAdventure692", "choiceAdventure693", "choiceAdventure694", "choiceAdventure695", "choiceAdventure696", "choiceAdventure697", "choiceAdventure698", "choiceAdventure700", "choiceAdventure701", "choiceAdventure705", "choiceAdventure706", "choiceAdventure707", "choiceAdventure708", "choiceAdventure709", "choiceAdventure710", "choiceAdventure711", "choiceAdventure712", "choiceAdventure713", "choiceAdventure714", "choiceAdventure715", "choiceAdventure716", "choiceAdventure717", "choiceAdventure721", "choiceAdventure725", "choiceAdventure729", "choiceAdventure733", "choiceAdventure737", "choiceAdventure741", "choiceAdventure745", "choiceAdventure749", "choiceAdventure753", "choiceAdventure771", "choiceAdventure778", "choiceAdventure780", "choiceAdventure781", "choiceAdventure783", "choiceAdventure784", "choiceAdventure785", "choiceAdventure786", "choiceAdventure787", "choiceAdventure788", "choiceAdventure789", "choiceAdventure791", "choiceAdventure793", "choiceAdventure794", "choiceAdventure795", "choiceAdventure796", "choiceAdventure797", "choiceAdventure803", "choiceAdventure805", "choiceAdventure808", "choiceAdventure809", "choiceAdventure813", "choiceAdventure815", "choiceAdventure830", "choiceAdventure832", "choiceAdventure833", "choiceAdventure834", "choiceAdventure835", "choiceAdventure837", "choiceAdventure838", "choiceAdventure839", "choiceAdventure840", "choiceAdventure841", "choiceAdventure842", "choiceAdventure851", "choiceAdventure852", "choiceAdventure853", "choiceAdventure854", "choiceAdventure855", "choiceAdventure856", "choiceAdventure857", "choiceAdventure858", "choiceAdventure866", "choiceAdventure873", "choiceAdventure875", "choiceAdventure876", "choiceAdventure877", "choiceAdventure878", "choiceAdventure879", "choiceAdventure880", "choiceAdventure881", "choiceAdventure882", "choiceAdventure888", "choiceAdventure889", "choiceAdventure918", "choiceAdventure919", "choiceAdventure920", "choiceAdventure921", "choiceAdventure923", "choiceAdventure924", "choiceAdventure925", "choiceAdventure926", "choiceAdventure927", "choiceAdventure928", "choiceAdventure929", "choiceAdventure930", "choiceAdventure931", "choiceAdventure932", "choiceAdventure940", "choiceAdventure941", "choiceAdventure942", "choiceAdventure943", "choiceAdventure944", "choiceAdventure945", "choiceAdventure946", "choiceAdventure950", "choiceAdventure955", "choiceAdventure957", "choiceAdventure958", "choiceAdventure959", "choiceAdventure960", "choiceAdventure961", "choiceAdventure962", "choiceAdventure963", "choiceAdventure964", "choiceAdventure965", "choiceAdventure966", "choiceAdventure970", "choiceAdventure973", "choiceAdventure974", "choiceAdventure975", "choiceAdventure976", "choiceAdventure977", "choiceAdventure979", "choiceAdventure980", "choiceAdventure981", "choiceAdventure982", "choiceAdventure983", "choiceAdventure988", "choiceAdventure989", "choiceAdventure993", "choiceAdventure998", "choiceAdventure1000", "choiceAdventure1003", "choiceAdventure1005", "choiceAdventure1006", "choiceAdventure1007", "choiceAdventure1008", "choiceAdventure1009", "choiceAdventure1010", "choiceAdventure1011", "choiceAdventure1012", "choiceAdventure1013", "choiceAdventure1015", "choiceAdventure1016", "choiceAdventure1017", "choiceAdventure1018", "choiceAdventure1019", "choiceAdventure1020", "choiceAdventure1021", "choiceAdventure1022", "choiceAdventure1023", "choiceAdventure1026", "choiceAdventure1027", "choiceAdventure1028", "choiceAdventure1029", "choiceAdventure1030", "choiceAdventure1031", "choiceAdventure1032", "choiceAdventure1033", "choiceAdventure1034", "choiceAdventure1035", "choiceAdventure1036", "choiceAdventure1037", "choiceAdventure1038", "choiceAdventure1039", "choiceAdventure1040", "choiceAdventure1041", "choiceAdventure1042", "choiceAdventure1044", "choiceAdventure1045", "choiceAdventure1046", "choiceAdventure1048", "choiceAdventure1051", "choiceAdventure1052", "choiceAdventure1053", "choiceAdventure1054", "choiceAdventure1055", "choiceAdventure1056", "choiceAdventure1057", "choiceAdventure1059", "choiceAdventure1060", "choiceAdventure1061", "choiceAdventure1062", "choiceAdventure1065", "choiceAdventure1067", "choiceAdventure1068", "choiceAdventure1069", "choiceAdventure1070", "choiceAdventure1071", "choiceAdventure1073", "choiceAdventure1077", "choiceAdventure1080", "choiceAdventure1081", "choiceAdventure1082", "choiceAdventure1083", "choiceAdventure1084", "choiceAdventure1085", "choiceAdventure1091", "choiceAdventure1094", "choiceAdventure1095", "choiceAdventure1096", "choiceAdventure1097", "choiceAdventure1102", "choiceAdventure1106", "choiceAdventure1107", "choiceAdventure1108", "choiceAdventure1110", "choiceAdventure1114", "choiceAdventure1115", "choiceAdventure1116", "choiceAdventure1118", "choiceAdventure1119", "choiceAdventure1120", "choiceAdventure1121", "choiceAdventure1122", "choiceAdventure1123", "choiceAdventure1171", "choiceAdventure1172", "choiceAdventure1173", "choiceAdventure1174", "choiceAdventure1175", "choiceAdventure1193", "choiceAdventure1195", "choiceAdventure1196", "choiceAdventure1197", "choiceAdventure1198", "choiceAdventure1199", "choiceAdventure1202", "choiceAdventure1203", "choiceAdventure1204", "choiceAdventure1205", "choiceAdventure1206", "choiceAdventure1207", "choiceAdventure1208", "choiceAdventure1209", "choiceAdventure1210", "choiceAdventure1211", "choiceAdventure1212", "choiceAdventure1213", "choiceAdventure1214", "choiceAdventure1215", "choiceAdventure1219", "choiceAdventure1222", "choiceAdventure1223", "choiceAdventure1224", "choiceAdventure1225", "choiceAdventure1226", "choiceAdventure1227", "choiceAdventure1228", "choiceAdventure1229", "choiceAdventure1236", "choiceAdventure1237", "choiceAdventure1238", "choiceAdventure1239", "choiceAdventure1240", "choiceAdventure1241", "choiceAdventure1242", "choiceAdventure1243", "choiceAdventure1244", "choiceAdventure1245", "choiceAdventure1246", "choiceAdventure1247", "choiceAdventure1248", "choiceAdventure1249", "choiceAdventure1250", "choiceAdventure1251", "choiceAdventure1252", "choiceAdventure1253", "choiceAdventure1254", "choiceAdventure1255", "choiceAdventure1256", "choiceAdventure1266", "choiceAdventure1280", "choiceAdventure1281", "choiceAdventure1282", "choiceAdventure1283", "choiceAdventure1284", "choiceAdventure1285", "choiceAdventure1286", "choiceAdventure1287", "choiceAdventure1288", "choiceAdventure1289", "choiceAdventure1290", "choiceAdventure1291", "choiceAdventure1292", "choiceAdventure1293", "choiceAdventure1294", "choiceAdventure1295", "choiceAdventure1296", "choiceAdventure1297", "choiceAdventure1298", "choiceAdventure1299", "choiceAdventure1300", "choiceAdventure1301", "choiceAdventure1302", "choiceAdventure1303", "choiceAdventure1304", "choiceAdventure1305", "choiceAdventure1307", "choiceAdventure1310", "choiceAdventure1312", "choiceAdventure1313", "choiceAdventure1314", "choiceAdventure1315", "choiceAdventure1316", "choiceAdventure1317", "choiceAdventure1318", "choiceAdventure1319", "choiceAdventure1321", "choiceAdventure1322", "choiceAdventure1323", "choiceAdventure1324", "choiceAdventure1325", "choiceAdventure1326", "choiceAdventure1327", "choiceAdventure1328", "choiceAdventure1332", "choiceAdventure1333", "choiceAdventure1335", "choiceAdventure1340", "choiceAdventure1341", "choiceAdventure1345", "choiceAdventure1389", "choiceAdventure1392", "choiceAdventure1397", "choiceAdventure1399", "choiceAdventure1405", "choiceAdventure1411", "choiceAdventure1415", "choiceAdventure1427", "choiceAdventure1428", "choiceAdventure1429", "choiceAdventure1430", "choiceAdventure1431", "choiceAdventure1432", "choiceAdventure1433", "choiceAdventure1434", "choiceAdventure1436", "choiceAdventure1460", "choiceAdventure1461", "choiceAdventure1467", "choiceAdventure1468", "choiceAdventure1469", "choiceAdventure1470", "choiceAdventure1471", "choiceAdventure1472", "choiceAdventure1473", "choiceAdventure1474", "choiceAdventure1475", "choiceAdventure1486", "choiceAdventure1487", "choiceAdventure1488", "choiceAdventure1489", "choiceAdventure1491", "choiceAdventure1494", "choiceAdventure1505"]; +var familiarProperties = ["commaFamiliar", "nextQuantumFamiliar", "stillsuitFamiliar"]; +var statProperties = ["nsChallenge1", "snojoSetting"]; +var phylumProperties = ["dnaSyringe", "locketPhylum", "redSnapperPhylum", "_circadianRhythmsPhylum"]; +;// CONCATENATED MODULE: ./node_modules/libram/dist/propertyTyping.js + +var booleanPropertiesSet = new Set(booleanProperties); +var numericPropertiesSet = new Set(numericProperties); +var numericOrStringPropertiesSet = new Set(numericOrStringProperties); +var stringPropertiesSet = new Set(stringProperties); +var locationPropertiesSet = new Set(locationProperties); +var monsterPropertiesSet = new Set(monsterProperties); +var familiarPropertiesSet = new Set(familiarProperties); +var statPropertiesSet = new Set(statProperties); +var phylumPropertiesSet = new Set(phylumProperties); +/** + * Determine whether a property has a boolean value + * + * @param property Property to check + * @returns Whether the supplied property has a boolean value + */ +function isBooleanProperty(property) { + return booleanPropertiesSet.has(property); +} +/** + * Determine whether a property has a numeric value + * + * @param property Property to check + * @returns Whether the supplied property has a numeric value + */ +function propertyTyping_isNumericProperty(property) { + return numericPropertiesSet.has(property); +} +/** + * Determine whether a property has a numeric or string value + * + * @param property Property to check + * @returns Whether the supplied property has a numeric or string value + */ +function isNumericOrStringProperty(property) { + return numericOrStringPropertiesSet.has(property); +} +/** + * Determine whether a property has a string value + * + * @param property Property to check + * @returns Whether the supplied property has a string value + */ +function isStringProperty(property) { + return stringPropertiesSet.has(property); +} +/** + * Determine whether a property has a Location value + * + * @param property Property to check + * @returns Whether the supplied property has a Location value + */ +function isLocationProperty(property) { + return locationPropertiesSet.has(property); +} +/** + * Determine whether a property has a Monster value + * + * @param property Property to check + * @returns Whether the supplied property has a Monster value + */ +function isMonsterProperty(property) { + return monsterPropertiesSet.has(property); +} +/** + * Determine whether a property has a Familiar value + * + * @param property Property to check + * @returns Whether the supplied property has a Familiar value + */ +function isFamiliarProperty(property) { + return familiarPropertiesSet.has(property); +} +/** + * Determine whether a property has a Stat value + * + * @param property Property to check + * @returns Whether the supplied property has a Stat value + */ +function isStatProperty(property) { + return statPropertiesSet.has(property); +} +/** + * Determine whether a property has a Phylum value + * + * @param property Property to check + * @returns Whether the supplied property has a Phylum value + */ +function isPhylumProperty(property) { + return phylumPropertiesSet.has(property); +} +;// CONCATENATED MODULE: ./node_modules/libram/dist/property.js +function property_ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function property_objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? property_ownKeys(Object(t), !0).forEach(function (r) { property_defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : property_ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +function property_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } +function property_defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, property_toPropertyKey(descriptor.key), descriptor); } } +function property_createClass(Constructor, protoProps, staticProps) { if (protoProps) property_defineProperties(Constructor.prototype, protoProps); if (staticProps) property_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } +function property_defineProperty(obj, key, value) { key = property_toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function property_toPropertyKey(arg) { var key = property_toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); } +function property_toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } +function property_slicedToArray(arr, i) { return property_arrayWithHoles(arr) || property_iterableToArrayLimit(arr, i) || property_unsupportedIterableToArray(arr, i) || property_nonIterableRest(); } +function property_nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function property_unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return property_arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return property_arrayLikeToArray(o, minLen); } +function property_arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } +function property_iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } +function property_arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } + + +var createPropertyGetter = transform => (property, default_) => { + var value = (0,external_kolmafia_.getProperty)(property); + if (default_ !== undefined && value === "") { + return default_; + } + return transform(value, property); +}; +var createMafiaClassPropertyGetter = (Type, toType) => createPropertyGetter(value => { + if (value === "") return null; + var v = toType(value); + return v === Type.none ? null : v; +}); +var getString = createPropertyGetter(value => value); +var getCommaSeparated = createPropertyGetter(value => value.split(/, ?/)); +var getBoolean = createPropertyGetter(value => value === "true"); +var getNumber = createPropertyGetter(value => Number(value)); +var getBounty = createMafiaClassPropertyGetter(external_kolmafia_.Bounty, external_kolmafia_.toBounty); +var getClass = createMafiaClassPropertyGetter(external_kolmafia_.Class, external_kolmafia_.toClass); +var getCoinmaster = createMafiaClassPropertyGetter(external_kolmafia_.Coinmaster, external_kolmafia_.toCoinmaster); +var getEffect = createMafiaClassPropertyGetter(external_kolmafia_.Effect, external_kolmafia_.toEffect); +var getElement = createMafiaClassPropertyGetter(external_kolmafia_.Element, external_kolmafia_.toElement); +var getFamiliar = createMafiaClassPropertyGetter(external_kolmafia_.Familiar, external_kolmafia_.toFamiliar); +var getItem = createMafiaClassPropertyGetter(external_kolmafia_.Item, external_kolmafia_.toItem); +var getLocation = createMafiaClassPropertyGetter(external_kolmafia_.Location, external_kolmafia_.toLocation); +var getMonster = createMafiaClassPropertyGetter(external_kolmafia_.Monster, external_kolmafia_.toMonster); +var getPhylum = createMafiaClassPropertyGetter(external_kolmafia_.Phylum, external_kolmafia_.toPhylum); +var getServant = createMafiaClassPropertyGetter(external_kolmafia_.Servant, external_kolmafia_.toServant); +var getSkill = createMafiaClassPropertyGetter(external_kolmafia_.Skill, external_kolmafia_.toSkill); +var getSlot = createMafiaClassPropertyGetter(external_kolmafia_.Slot, external_kolmafia_.toSlot); +var getStat = createMafiaClassPropertyGetter(external_kolmafia_.Stat, external_kolmafia_.toStat); +var getThrall = createMafiaClassPropertyGetter(external_kolmafia_.Thrall, external_kolmafia_.toThrall); +/** + * Gets the value of a mafia property, either built in or custom + * + * @param property Name of the property + * @param _default Default value for the property to take if not set + * @returns Value of the mafia property + */ +function property_get(property, _default) { + var value = getString(property); + // Handle known properties. + if (isBooleanProperty(property)) { + var _getBoolean; + return (_getBoolean = getBoolean(property, _default)) !== null && _getBoolean !== void 0 ? _getBoolean : false; + } else if (propertyTyping_isNumericProperty(property)) { + var _getNumber; + return (_getNumber = getNumber(property, _default)) !== null && _getNumber !== void 0 ? _getNumber : 0; + } else if (isNumericOrStringProperty(property)) { + return value.match(/^\d+$/) ? parseInt(value) : value; + } else if (isLocationProperty(property)) { + return getLocation(property, _default); + } else if (isMonsterProperty(property)) { + return getMonster(property, _default); + } else if (isFamiliarProperty(property)) { + return getFamiliar(property, _default); + } else if (isStatProperty(property)) { + return getStat(property, _default); + } else if (isPhylumProperty(property)) { + return getPhylum(property, _default); + } else if (isStringProperty(property)) { + return value; + } + // Not a KnownProperty from here on out. + if (_default instanceof external_kolmafia_.Location) { + return getLocation(property, _default); + } else if (_default instanceof external_kolmafia_.Monster) { + return getMonster(property, _default); + } else if (_default instanceof external_kolmafia_.Familiar) { + return getFamiliar(property, _default); + } else if (_default instanceof external_kolmafia_.Stat) { + return getStat(property, _default); + } else if (_default instanceof external_kolmafia_.Phylum) { + return getPhylum(property, _default); + } else if (typeof _default === "boolean") { + return value === "true" ? true : value === "false" ? false : _default; + } else if (typeof _default === "number") { + return value === "" ? _default : parseInt(value); + } else if (value === "") { + return _default === undefined ? "" : _default; + } else { + return value; + } +} +/** + * Sets the value of a mafia property, either built in or custom + * + * @param property Name of the property + * @param value Value to give the property + * @returns Value that was set + */ +function _set(property, value) { + var stringValue = value === null ? "" : value.toString(); + (0,external_kolmafia_.setProperty)(property, stringValue); + return value; +} +/** + * Increment a property + * + * @param property Numeric property to increment + * @param delta Number by which to increment + * @param max Maximum value to set + * @returns New value + */ + +function increment(property) { + var delta = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1; + var max = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : Infinity; + var value = property_get(property); + if (!isNumericProperty(property)) return value; + var nextValue = Math.min(max, value + delta); + return _set(property, nextValue); +} +/** + * Decrement a property + * + * @param property Numeric property to decrement + * @param delta Number by which to decrement + * @param min Maximum value to set + * @returns New value + */ +function decrement(property) { + var delta = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1; + var min = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : Infinity; + var value = property_get(property); + if (!isNumericProperty(property)) return value; + var nextValue = Math.max(min, value - delta); + return _set(property, nextValue); +} +/** + * Sets the value of a set of mafia properties + * + * @param properties Set of properties + */ +function setProperties(properties) { + for (var _i = 0, _Object$entries = Object.entries(properties); _i < _Object$entries.length; _i++) { + var _Object$entries$_i = property_slicedToArray(_Object$entries[_i], 2), + prop = _Object$entries$_i[0], + value = _Object$entries$_i[1]; + _set(prop, value); + } +} +/** + * Carries out a callback during which a set of properties will be set as supplied + * + * @param properties Properties to set during callback + * @param callback Callback to execute with set properties + * @returns Return value of the supplied callback + */ +function withProperties(properties, callback) { + var propertiesBackup = Object.fromEntries(Object.entries(properties).map(_ref => { + var _ref2 = property_slicedToArray(_ref, 1), + prop = _ref2[0]; + return [prop, property_get(prop)]; + })); + setProperties(properties); + try { + return callback(); + } finally { + setProperties(propertiesBackup); + } +} +/** + * Carries out a callback during which a property will be set as supplied + * + * @param property Property to set during callback + * @param value Value to set property during callback + * @param callback Callback to execute with set properties + * @returns Return value of the supplied callback + */ +function withProperty(property, value, callback) { + return withProperties(property_defineProperty({}, property, value), callback); +} +/** + * Carries out a callback during which a set of choices will be handled as supplied + * + * @param choices Choices to set during callback + * @param callback Callback to execute with set choices + * @returns Return value of the supplied callback + */ +function withChoices(choices, callback) { + var properties = Object.fromEntries(Object.entries(choices).map(_ref3 => { + var _ref4 = property_slicedToArray(_ref3, 2), + choice = _ref4[0], + option = _ref4[1]; + return ["choiceAdventure".concat(choice), option]; + })); + return withProperties(properties, callback); +} +/** + * Carries out a callback during which a choice will be handled as supplied + * + * @param choice Choice to set during callback + * @param value How to handle choice during callback + * @param callback Callback to execute with set properties + * @returns Return value of the supplied callback + */ +function withChoice(choice, value, callback) { + return withChoices(property_defineProperty({}, choice, value), callback); +} +var PropertiesManager = /*#__PURE__*/function () { + function PropertiesManager() { + property_classCallCheck(this, PropertiesManager); + property_defineProperty(this, "properties", {}); + } + property_createClass(PropertiesManager, [{ + key: "storedValues", + get: function get() { + return this.properties; + } + /** + * Sets a collection of properties to the given values, storing the old values. + * + * @param propertiesToSet A Properties object, keyed by property name. + */ + }, { + key: "set", + value: function set(propertiesToSet) { + for (var _i2 = 0, _Object$entries2 = Object.entries(propertiesToSet); _i2 < _Object$entries2.length; _i2++) { + var _Object$entries2$_i = property_slicedToArray(_Object$entries2[_i2], 2), + propertyName = _Object$entries2$_i[0], + propertyValue = _Object$entries2$_i[1]; + if (this.properties[propertyName] === undefined) { + this.properties[propertyName] = property_get(propertyName); + } + _set(propertyName, propertyValue); + } + } + /** + * Sets a collection of choice adventure properties to the given values, storing the old values. + * + * @param choicesToSet An object keyed by choice adventure number. + */ + }, { + key: "setChoices", + value: function setChoices(choicesToSet) { + this.set(Object.fromEntries(Object.entries(choicesToSet).map(_ref5 => { + var _ref6 = property_slicedToArray(_ref5, 2), + choiceNumber = _ref6[0], + choiceValue = _ref6[1]; + return ["choiceAdventure".concat(choiceNumber), choiceValue]; + }))); + } + /** + * Sets a single choice adventure property to the given value, storing the old value. + * + * @param choiceToSet The number of the choice adventure to set the property for. + * @param value The value to assign to that choice adventure. + */ + }, { + key: "setChoice", + value: function setChoice(choiceToSet, value) { + this.setChoices(property_defineProperty({}, choiceToSet, value)); + } + /** + * Resets the given properties to their original stored value. Does not delete entries from the manager. + * + * @param properties Collection of properties to reset. + */ + }, { + key: "reset", + value: function reset() { + for (var _len = arguments.length, properties = new Array(_len), _key = 0; _key < _len; _key++) { + properties[_key] = arguments[_key]; + } + for (var _i3 = 0, _properties = properties; _i3 < _properties.length; _i3++) { + var property = _properties[_i3]; + var value = this.properties[property]; + if (value) { + _set(property, value); + } + } + } + /** + * Iterates over all stored values, setting each property back to its original stored value. Does not delete entries from the manager. + */ + }, { + key: "resetAll", + value: function resetAll() { + setProperties(this.properties); + } + /** + * Stops storing the original values of inputted properties. + * + * @param properties Properties for the manager to forget. + */ + }, { + key: "clear", + value: function clear() { + for (var _len2 = arguments.length, properties = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { + properties[_key2] = arguments[_key2]; + } + for (var _i4 = 0, _properties2 = properties; _i4 < _properties2.length; _i4++) { + var property = _properties2[_i4]; + if (this.properties[property]) { + delete this.properties[property]; + } + } + } + /** + * Clears all properties. + */ + }, { + key: "clearAll", + value: function clearAll() { + this.properties = {}; + } + /** + * Increases a numeric property to the given value if necessary. + * + * @param property The numeric property we want to potentially raise. + * @param value The minimum value we want that property to have. + * @returns Whether we needed to change the property. + */ + }, { + key: "setMinimumValue", + value: function setMinimumValue(property, value) { + if (property_get(property, 0) < value) { + this.set(property_defineProperty({}, property, value)); + return true; + } + return false; + } + /** + * Decrease a numeric property to the given value if necessary. + * + * @param property The numeric property we want to potentially lower. + * @param value The maximum value we want that property to have. + * @returns Whether we needed to change the property. + */ + }, { + key: "setMaximumValue", + value: function setMaximumValue(property, value) { + if (property_get(property, 0) > value) { + this.set(property_defineProperty({}, property, value)); + return true; + } + return false; + } + /** + * Creates a new PropertiesManager with identical stored values to this one. + * + * @returns A new PropertiesManager, with identical stored values to this one. + */ + }, { + key: "clone", + value: function clone() { + var newGuy = new PropertiesManager(); + newGuy.properties = this.storedValues; + return newGuy; + } + /** + * Clamps a numeric property, modulating it up or down to fit within a specified range + * + * @param property The numeric property to clamp + * @param min The lower bound for what we want the property to be allowed to be. + * @param max The upper bound for what we want the property to be allowed to be. + * @returns Whether we ended up changing the property or not. + */ + }, { + key: "clamp", + value: function clamp(property, min, max) { + if (max < min) return false; + var start = property_get(property); + this.setMinimumValue(property, min); + this.setMaximumValue(property, max); + return start !== property_get(property); + } + /** + * Determines whether this PropertiesManager has identical stored values to another. + * + * @param other The PropertiesManager to compare to this one. + * @returns Whether their StoredValues are identical. + */ + }, { + key: "equals", + value: function equals(other) { + var thisProps = Object.entries(this.storedValues); + var otherProps = new Map(Object.entries(other.storedValues)); + if (thisProps.length !== otherProps.size) return false; + for (var _i5 = 0, _thisProps = thisProps; _i5 < _thisProps.length; _i5++) { + var _thisProps$_i = property_slicedToArray(_thisProps[_i5], 2), + propertyName = _thisProps$_i[0], + propertyValue = _thisProps$_i[1]; + if (otherProps.get(propertyName) === propertyValue) return false; + } + return true; + } + /** + * Merges a PropertiesManager onto this one, letting the input win in the event that both PropertiesManagers have a value stored. + * + * @param other The PropertiesManager to be merged onto this one. + * @returns A new PropertiesManager with stored values from both its parents. + */ + }, { + key: "merge", + value: function merge(other) { + var newGuy = new PropertiesManager(); + newGuy.properties = property_objectSpread(property_objectSpread({}, this.properties), other.properties); + return newGuy; + } + /** + * Merges an arbitrary collection of PropertiesManagers, letting the rightmost PropertiesManager win in the event of verlap. + * + * @param mergees The PropertiesManagers to merge together. + * @returns A PropertiesManager that is just an amalgam of all the constituents. + */ + }], [{ + key: "merge", + value: function merge() { + for (var _len3 = arguments.length, mergees = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) { + mergees[_key3] = arguments[_key3]; + } + if (mergees.length === 0) return new PropertiesManager(); + return mergees.reduce((a, b) => a.merge(b)); + } + }]); + return PropertiesManager; +}(); +;// CONCATENATED MODULE: ./node_modules/libram/dist/combat.js +function _get() { if (typeof Reflect !== "undefined" && Reflect.get) { _get = Reflect.get.bind(); } else { _get = function _get(target, property, receiver) { var base = _superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(arguments.length < 3 ? target : receiver); } return desc.value; }; } return _get.apply(this, arguments); } +function _superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = combat_getPrototypeOf(object); if (object === null) break; } return object; } +function combat_createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = combat_unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; } +function combat_toConsumableArray(arr) { return combat_arrayWithoutHoles(arr) || combat_iterableToArray(arr) || combat_unsupportedIterableToArray(arr) || combat_nonIterableSpread(); } +function combat_nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function combat_unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return combat_arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return combat_arrayLikeToArray(o, minLen); } +function combat_iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); } +function combat_arrayWithoutHoles(arr) { if (Array.isArray(arr)) return combat_arrayLikeToArray(arr); } +function combat_arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } +function combat_defineProperty(obj, key, value) { key = combat_toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function combat_defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, combat_toPropertyKey(descriptor.key), descriptor); } } +function combat_createClass(Constructor, protoProps, staticProps) { if (protoProps) combat_defineProperties(Constructor.prototype, protoProps); if (staticProps) combat_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } +function combat_toPropertyKey(arg) { var key = combat_toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); } +function combat_toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } +function combat_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } +function combat_inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) combat_setPrototypeOf(subClass, superClass); } +function combat_createSuper(Derived) { var hasNativeReflectConstruct = combat_isNativeReflectConstruct(); return function _createSuperInternal() { var Super = combat_getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = combat_getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return combat_possibleConstructorReturn(this, result); }; } +function combat_possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return combat_assertThisInitialized(self); } +function combat_assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } +function combat_wrapNativeSuper(Class) { var _cache = typeof Map === "function" ? new Map() : undefined; combat_wrapNativeSuper = function _wrapNativeSuper(Class) { if (Class === null || !combat_isNativeFunction(Class)) return Class; if (typeof Class !== "function") { throw new TypeError("Super expression must either be null or a function"); } if (typeof _cache !== "undefined") { if (_cache.has(Class)) return _cache.get(Class); _cache.set(Class, Wrapper); } function Wrapper() { return combat_construct(Class, arguments, combat_getPrototypeOf(this).constructor); } Wrapper.prototype = Object.create(Class.prototype, { constructor: { value: Wrapper, enumerable: false, writable: true, configurable: true } }); return combat_setPrototypeOf(Wrapper, Class); }; return combat_wrapNativeSuper(Class); } +function combat_construct(Parent, args, Class) { if (combat_isNativeReflectConstruct()) { combat_construct = Reflect.construct.bind(); } else { combat_construct = function _construct(Parent, args, Class) { var a = [null]; a.push.apply(a, args); var Constructor = Function.bind.apply(Parent, a); var instance = new Constructor(); if (Class) combat_setPrototypeOf(instance, Class.prototype); return instance; }; } return combat_construct.apply(null, arguments); } +function combat_isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } +function combat_isNativeFunction(fn) { return Function.toString.call(fn).indexOf("[native code]") !== -1; } +function combat_setPrototypeOf(o, p) { combat_setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return combat_setPrototypeOf(o, p); } +function combat_getPrototypeOf(o) { combat_getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return combat_getPrototypeOf(o); } + + + + +var MACRO_NAME = "Script Autoattack Macro"; +/** + * Get the KoL native ID of the macro with name name. + * + * @param name Name of the macro + * @category Combat + * @returns {number} The macro ID. + */ +function getMacroId() { + var name = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : MACRO_NAME; + var macroMatches = (0,external_kolmafia_.xpath)((0,external_kolmafia_.visitUrl)("account_combatmacros.php"), "//select[@name=\"macroid\"]/option[text()=\"".concat(name, "\"]/@value")); + if (macroMatches.length === 0) { + (0,external_kolmafia_.visitUrl)("account_combatmacros.php?action=new"); + var newMacroText = (0,external_kolmafia_.visitUrl)("account_combatmacros.php?macroid=0&name=".concat(name, "¯otext=abort&action=save")); + return parseInt((0,external_kolmafia_.xpath)(newMacroText, "//input[@name=".concat(name, "]/@value"))[0], 10); + } else { + return parseInt(macroMatches[0], 10); + } +} +/** + * Converts an item name to a Item, or passes through an existing instance of Item + * + * @param itemOrName Item name or Item instance + * @returns KoLmafia Item instance + */ +function itemOrNameToItem(itemOrName) { + return typeof itemOrName === "string" ? external_kolmafia_.Item.get(itemOrName) : itemOrName; +} +/** + * Create a string of the item or items provided that is compatible with BALLS syntax and is non-ambiguous + * + * @param itemOrItems Item name, item instance, or 2-tuple of item name or item instance + * @returns BALLS macro-compatible value for item or items provided + */ +function itemOrItemsBallsMacroName(itemOrItems) { + if (Array.isArray(itemOrItems)) { + return itemOrItems.map(itemOrItemsBallsMacroName).join(", "); + } else { + var item = itemOrNameToItem(itemOrItems); + return !overlappingItemNames.includes(item.name) ? item.name : item.id.toFixed(0); + } +} +/** + * Generate a BALLS macro condition to check wither the player has either a single or a 2-tuple of combat items + * + * @param itemOrItems Single or 2-tuple of combat items + * @returns BALLS macro condition + */ +function itemOrItemsBallsMacroPredicate(itemOrItems) { + if (Array.isArray(itemOrItems)) { + return itemOrItems.map(itemOrItemsBallsMacroPredicate).join(" && "); + } else { + return "hascombatitem ".concat(itemOrItems); + } +} +/** + * Converts a skill name to a Skill, or passes through an existing instance of Skill + * + * @param skillOrName Skill name or Skill instance + * @returns KoLmafia Skill instance + */ +function skillOrNameToSkill(skillOrName) { + if (typeof skillOrName === "string") { + return external_kolmafia_.Skill.get(skillOrName); + } else { + return skillOrName; + } +} +/** + * Get a skill name in a form that is appropriate for BALLS macros + * + * @param skillOrName Skill name or Skill instance + * @returns BALLS macro-suitable skill name + */ +function skillBallsMacroName(skillOrName) { + var skill = skillOrNameToSkill(skillOrName); + return skill.name.match(/^[A-Za-z ]+$/) && !overlappingSkillNames.includes(skill.name) ? skill.name : skill.id; +} +var InvalidMacroError = /*#__PURE__*/function (_Error) { + combat_inherits(InvalidMacroError, _Error); + var _super = combat_createSuper(InvalidMacroError); + function InvalidMacroError() { + combat_classCallCheck(this, InvalidMacroError); + return _super.apply(this, arguments); + } + return combat_createClass(InvalidMacroError); +}( /*#__PURE__*/combat_wrapNativeSuper(Error)); +/** + * BALLS macro builder for direct submission to KoL. + * Create a new macro with `new Macro()` and add steps using the instance methods. + * Uses a fluent interface, so each step returns the object for easy chaining of steps. + * Each method is also defined as a static method that creates a new Macro with only that step. + * For example, you can do `Macro.skill('Saucestorm').attack()`. + */ +var Macro = /*#__PURE__*/function () { + function Macro() { + combat_classCallCheck(this, Macro); + combat_defineProperty(this, "components", []); + combat_defineProperty(this, "name", MACRO_NAME); + } + combat_createClass(Macro, [{ + key: "toString", + value: + /** + * Convert macro to string. + * + * @returns BALLS macro + */ + function toString() { + return (this.components.join(";") + ";").replace(/;;+/g, ";"); + } + /** + * Gives your macro a new name to be used when saving an autoattack. + * + * @param name The name to be used when saving as an autoattack. + * @returns The macro in question + */ + }, { + key: "rename", + value: function rename(name) { + this.name = name; + return this; + } + /** + * Creates a new Macro with a name other than the default name. + * + * @param name The name to assign this macro. + * @returns A new Macro with the assigned name. + */ + }, { + key: "save", + value: + /** + * Save a macro to a Mafia property for use in a consult script. + */ + function save() { + _set(Macro.SAVED_MACRO_PROPERTY, this.toString()); + } + /** + * Load a saved macro from the Mafia property. + * + * @returns Loaded macro text + */ + }, { + key: "step", + value: + /** + * Statefully add one or several steps to a macro. + * + * @param nextSteps The steps to add to the macro. + * @returns {Macro} This object itself. + */ + function step() { + var _ref, _this$components; + for (var _len = arguments.length, nextSteps = new Array(_len), _key = 0; _key < _len; _key++) { + nextSteps[_key] = arguments[_key]; + } + var nextStepsStrings = (_ref = []).concat.apply(_ref, combat_toConsumableArray(nextSteps.map(x => x instanceof Macro ? x.components : [x]))); + (_this$components = this.components).push.apply(_this$components, combat_toConsumableArray(nextStepsStrings.filter(s => s.length > 0))); + return this; + } + /** + * Statefully add one or several steps to a macro. + * + * @param nextSteps The steps to add to the macro. + * @returns {Macro} This object itself. + */ + }, { + key: "submit", + value: + /** + * Submit the built macro to KoL. Only works inside combat. + * + * @returns Contents of the fight page after macro submission + */ + function submit() { + var final = this.toString(); + return (0,external_kolmafia_.visitUrl)("fight.php?action=macro¯otext=".concat((0,external_kolmafia_.urlEncode)(final)), true, true); + } + /** + * Set this macro as a KoL native autoattack. + */ + }, { + key: "setAutoAttack", + value: function setAutoAttack() { + var id = Macro.cachedMacroIds.get(this.name); + if (id === undefined) { + id = getMacroId(this.name); + Macro.cachedMacroIds.set(this.name, id); + } + if ((0,external_kolmafia_.getAutoAttack)() === 99000000 + id && this.toString() === Macro.cachedAutoAttacks.get(this.name)) { + // This macro is already set. Don"t make the server request. + return; + } + (0,external_kolmafia_.visitUrl)("account_combatmacros.php?macroid=".concat(id, "&name=").concat((0,external_kolmafia_.urlEncode)(this.name), "¯otext=").concat((0,external_kolmafia_.urlEncode)(this.toString()), "&action=save"), true, true); + (0,external_kolmafia_.visitUrl)("account.php?am=1&action=autoattack&value=".concat(99000000 + id, "&ajax=1")); + Macro.cachedAutoAttacks.set(this.name, this.toString()); + } + /** + * Renames the macro, then sets it as an autoattack. + * + * @param name The name to save the macro under as an autoattack. + */ + }, { + key: "setAutoAttackAs", + value: function setAutoAttackAs(name) { + this.name = name; + this.setAutoAttack(); + } + /** + * Clear all cached autoattacks, and delete all stored macros server-side. + */ + }, { + key: "abort", + value: + /** + * Add an "abort" step to this macro. + * + * @returns {Macro} This object itself. + */ + function abort() { + return this.step("abort"); + } + /** + * Create a new macro with an "abort" step. + * + * @returns {Macro} This object itself. + */ + }, { + key: "abortWithWarning", + value: + /** + * Adds an "abort" step to this macro, with a warning message to print + * + * @param warning The warning message to print + * @returns {Macro} This object itself. + */ + function abortWithWarning(warning) { + return this.step("abort \"".concat(warning, "\"")); + } + /** + * Create a new macro with an "abort" step to this macro, with a warning message to print + * + * @param warning The warning message to print + * @returns {Macro} This object itself. + */ + }, { + key: "runaway", + value: + /** + * Add a "runaway" step to this macro. + * + * @returns {Macro} This object itself. + */ + function runaway() { + return this.step("runaway"); + } + /** + * Create a new macro with an "runaway" step. + * + * @returns {Macro} This object itself. + */ + }, { + key: "if_", + value: + /** + * Add an "if" statement to this macro. + * + * @param condition The BALLS condition for the if statement. + * @param ifTrue Continuation if the condition is true. + * @returns {Macro} This object itself. + */ + function if_(condition, ifTrue) { + return this.step("if ".concat(Macro.makeBALLSPredicate(condition))).step(ifTrue).step("endif"); + } + /** + * Create a new macro with an "if" statement. + * + * @param condition The BALLS condition for the if statement. + * @param ifTrue Continuation if the condition is true. + * @returns {Macro} This object itself. + */ + }, { + key: "ifNot", + value: + /** + * Add an "if" statement to this macro, inverting the condition. + * + * @param condition The BALLS condition for the if statement. + * @param ifTrue Continuation if the condition is true. + * @returns {Macro} This object itself. + */ + function ifNot(condition, ifTrue) { + return this.step("if !(".concat(Macro.makeBALLSPredicate(condition), ")")).step(ifTrue).step("endif"); + } + /** + * Create a new macro with an "if" statement, inverting the condition. + * + * @param condition The BALLS condition for the if statement. + * @param ifTrue Continuation if the condition is true. + * @returns {Macro} This object itself. + */ + }, { + key: "while_", + value: + /** + * Add a "while" statement to this macro. + * + * @param condition The BALLS condition for the if statement. + * @param contents Loop to repeat while the condition is true. + * @returns {Macro} This object itself. + */ + function while_(condition, contents) { + return this.step("while ".concat(condition)).step(contents).step("endwhile"); + } + /** + * Create a new macro with a "while" statement. + * + * @param condition The BALLS condition for the if statement. + * @param contents Loop to repeat while the condition is true. + * @returns {Macro} This object itself. + */ + }, { + key: "externalIf", + value: + /** + * Conditionally add a step to a macro based on a condition evaluated at the time of building the macro. + * + * @param condition The JS condition. + * @param ifTrue Continuation to add if the condition is true. + * @param ifFalse Optional input to turn this into an if...else statement. + * @returns {Macro} This object itself. + */ + function externalIf(condition, ifTrue, ifFalse) { + if (condition) return this.step(ifTrue);else if (ifFalse) return this.step(ifFalse);else return this; + } + /** + * Create a new macro with a condition evaluated at the time of building the macro. + * + * @param condition The JS condition. + * @param ifTrue Continuation to add if the condition is true. + * @param ifFalse Optional input to turn this into an if...else statement. + * @returns {Macro} This object itself. + */ + }, { + key: "repeat", + value: + /** + * Add a repeat step to the macro. + * + * @returns {Macro} This object itself. + */ + function repeat() { + return this.step("repeat"); + } + /** + * Add one or more skill cast steps to the macro. + * + * @param skills Skills to cast. + * @returns {Macro} This object itself. + */ + }, { + key: "skill", + value: function skill() { + for (var _len2 = arguments.length, skills = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { + skills[_key2] = arguments[_key2]; + } + return this.step.apply(this, combat_toConsumableArray(skills.map(skill => { + return "skill ".concat(skillBallsMacroName(skill)); + }))); + } + /** + * Create a new macro with one or more skill cast steps. + * + * @param skills Skills to cast. + * @returns {Macro} This object itself. + */ + }, { + key: "trySkill", + value: + /** + * Add one or more skill cast steps to the macro, where each step checks if you have the skill first. + * + * @param skills Skills to try casting. + * @returns {Macro} This object itself. + */ + function trySkill() { + for (var _len3 = arguments.length, skills = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) { + skills[_key3] = arguments[_key3]; + } + return this.step.apply(this, combat_toConsumableArray(skills.map(skill => { + return Macro.if_("hasskill ".concat(skillBallsMacroName(skill)), Macro.skill(skill)); + }))); + } + /** + * Create a new macro with one or more skill cast steps, where each step checks if you have the skill first. + * + * @param skills Skills to try casting. + * @returns {Macro} This object itself. + */ + }, { + key: "trySkillRepeat", + value: + /** + * Add one or more skill-cast-and-repeat steps to the macro, where each step checks if you have the skill first. + * + * @param skills Skills to try repeatedly casting. + * @returns {Macro} This object itself. + */ + function trySkillRepeat() { + for (var _len4 = arguments.length, skills = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) { + skills[_key4] = arguments[_key4]; + } + return this.step.apply(this, combat_toConsumableArray(skills.map(skill => { + return Macro.if_("hasskill ".concat(skillBallsMacroName(skill)), Macro.skill(skill).repeat()); + }))); + } + /** + * Create a new macro with one or more skill-cast-and-repeat steps, where each step checks if you have the skill first. + * + * @param skills Skills to try repeatedly casting. + * @returns {Macro} This object itself. + */ + }, { + key: "item", + value: + /** + * Add one or more item steps to the macro. + * + * @param items Items to use. Pass a tuple [item1, item2] to funksling. + * @returns {Macro} This object itself. + */ + function item() { + for (var _len5 = arguments.length, items = new Array(_len5), _key5 = 0; _key5 < _len5; _key5++) { + items[_key5] = arguments[_key5]; + } + return this.step.apply(this, combat_toConsumableArray(items.map(itemOrItems => { + return "use ".concat(itemOrItemsBallsMacroName(itemOrItems)); + }))); + } + /** + * Create a new macro with one or more item steps. + * + * @param items Items to use. Pass a tuple [item1, item2] to funksling. + * @returns {Macro} This object itself. + */ + }, { + key: "tryItem", + value: + /** + * Add one or more item steps to the macro, where each step checks to see if you have the item first. + * + * @param items Items to try using. Pass a tuple [item1, item2] to funksling. + * @returns {Macro} This object itself. + */ + function tryItem() { + for (var _len6 = arguments.length, items = new Array(_len6), _key6 = 0; _key6 < _len6; _key6++) { + items[_key6] = arguments[_key6]; + } + return this.step.apply(this, combat_toConsumableArray(items.map(item => { + return Macro.if_(itemOrItemsBallsMacroPredicate(item), "use ".concat(itemOrItemsBallsMacroName(item))); + }))); + } + /** + * Create a new macro with one or more item steps, where each step checks to see if you have the item first. + * + * @param items Items to try using. Pass a tuple [item1, item2] to funksling. + * @returns {Macro} This object itself. + */ + }, { + key: "attack", + value: + /** + * Add an attack step to the macro. + * + * @returns {Macro} This object itself. + */ + function attack() { + return this.step("attack"); + } + /** + * Create a new macro with an attack step. + * + * @returns {Macro} This object itself. + */ + }, { + key: "ifHolidayWanderer", + value: + /** + * Create an if_ statement based on what holiday of loathing it currently is. On non-holidays, returns the original macro, unmutated. + * + * @param macro The macro to place in the if_ statement + * @returns This macro with supplied macro wapped in if statement matching holiday wanderers + */ + function ifHolidayWanderer(macro) { + var todaysWanderers = getTodaysHolidayWanderers(); + if (todaysWanderers.length === 0) return this; + return this.if_(todaysWanderers.map(monster => "monsterid ".concat(monster.id)).join(" || "), macro); + } + /** + * Create a new macro starting with an ifHolidayWanderer step. + * + * @param macro The macro to place inside the if_ statement + * @returns New macro with supplied macro wrapped in if statement matching holiday wanderers + */ + }, { + key: "ifNotHolidayWanderer", + value: + /** + * Create an if_ statement based on what holiday of loathing it currently is. On non-holidays, returns the original macro, with the input macro appended. + * + * @param macro The macro to place in the if_ statement. + * @returns This macro with supplied macro wrapped in if statement matching monsters that are not holiday wanderers + */ + function ifNotHolidayWanderer(macro) { + var todaysWanderers = getTodaysHolidayWanderers(); + if (todaysWanderers.length === 0) return this.step(macro); + return this.if_(todaysWanderers.map(monster => "!monsterid ".concat(monster.id)).join(" && "), macro); + } + /** + * Create a new macro starting with an ifNotHolidayWanderer step. + * + * @param macro The macro to place inside the if_ statement + * @returns New macro with supplied macro wrapped in if statement matching monsters that are not holiday wanderers + */ + }], [{ + key: "rename", + value: function rename(name) { + return new this().rename(name); + } + }, { + key: "load", + value: function load() { + var _this; + return (_this = new this()).step.apply(_this, combat_toConsumableArray(property_get(Macro.SAVED_MACRO_PROPERTY).split(";"))); + } + /** + * Clear the saved macro in the Mafia property. + */ + }, { + key: "clearSaved", + value: function clearSaved() { + (0,external_kolmafia_.removeProperty)(Macro.SAVED_MACRO_PROPERTY); + } + }, { + key: "step", + value: function step() { + var _this2; + return (_this2 = new this()).step.apply(_this2, arguments); + } + }, { + key: "clearAutoAttackMacros", + value: function clearAutoAttackMacros() { + var _iterator = combat_createForOfIteratorHelper(Macro.cachedAutoAttacks.keys()), + _step; + try { + for (_iterator.s(); !(_step = _iterator.n()).done;) { + var _Macro$cachedMacroIds; + var name = _step.value; + var id = (_Macro$cachedMacroIds = Macro.cachedMacroIds.get(name)) !== null && _Macro$cachedMacroIds !== void 0 ? _Macro$cachedMacroIds : getMacroId(name); + (0,external_kolmafia_.visitUrl)("account_combatmacros.php?macroid=".concat(id, "&action=edit&what=Delete&confirm=1")); + Macro.cachedAutoAttacks.delete(name); + Macro.cachedMacroIds.delete(name); + } + } catch (err) { + _iterator.e(err); + } finally { + _iterator.f(); + } + } + }, { + key: "abort", + value: function abort() { + return new this().abort(); + } + }, { + key: "abortWithWarning", + value: function abortWithWarning(warning) { + return new this().abortWithWarning(warning); + } + }, { + key: "runaway", + value: function runaway() { + return new this().runaway(); + } + }, { + key: "makeBALLSPredicate", + value: function makeBALLSPredicate(condition) { + var ballsCondition = ""; + if (condition instanceof external_kolmafia_.Monster) { + ballsCondition = "monsterid ".concat(condition.id); + } else if (condition instanceof Array) { + ballsCondition = condition.map(mon => "monsterid ".concat(mon.id)).join(" || "); + ballsCondition = "(".concat(ballsCondition, ")"); + } else if (condition instanceof external_kolmafia_.Effect) { + ballsCondition = "haseffect ".concat(condition.id); + } else if (condition instanceof external_kolmafia_.Skill) { + ballsCondition = "hasskill ".concat(skillBallsMacroName(condition)); + } else if (condition instanceof external_kolmafia_.Item) { + if (!condition.combat) { + throw new InvalidMacroError("Item ".concat(condition, " cannot be made a valid BALLS predicate (it is not combat-usable)")); + } + ballsCondition = "hascombatitem ".concat(itemOrItemsBallsMacroName(condition)); + } else if (condition instanceof external_kolmafia_.Location) { + var snarfblat = condition.id; + if (snarfblat < 1) { + throw new InvalidMacroError("Location ".concat(condition, " cannot be made a valid BALLS predicate (it has no location id)")); + } + ballsCondition = "snarfblat ".concat(snarfblat); + } else if (condition instanceof external_kolmafia_.Class) { + if (condition.id > 6) { + throw new InvalidMacroError("Class ".concat(condition, " cannot be made a valid BALLS predicate (it is not a standard class)")); + } + ballsCondition = condition.toString().replaceAll(" ", "").toLowerCase(); + } else if (condition instanceof external_kolmafia_.Stat) { + ballsCondition = "".concat(condition.toString().toLowerCase(), "class"); + } else { + ballsCondition = condition; + } + return ballsCondition; + } + }, { + key: "if_", + value: function if_(condition, ifTrue) { + return new this().if_(condition, ifTrue); + } + }, { + key: "ifNot", + value: function ifNot(condition, ifTrue) { + return new this().ifNot(condition, ifTrue); + } + }, { + key: "while_", + value: function while_(condition, contents) { + return new this().while_(condition, contents); + } + }, { + key: "externalIf", + value: function externalIf(condition, ifTrue, ifFalse) { + return new this().externalIf(condition, ifTrue, ifFalse); + } + }, { + key: "skill", + value: function skill() { + var _this3; + return (_this3 = new this()).skill.apply(_this3, arguments); + } + }, { + key: "trySkill", + value: function trySkill() { + var _this4; + return (_this4 = new this()).trySkill.apply(_this4, arguments); + } + }, { + key: "trySkillRepeat", + value: function trySkillRepeat() { + var _this5; + return (_this5 = new this()).trySkillRepeat.apply(_this5, arguments); + } + }, { + key: "item", + value: function item() { + var _this6; + return (_this6 = new this()).item.apply(_this6, arguments); + } + }, { + key: "tryItem", + value: function tryItem() { + var _this7; + return (_this7 = new this()).tryItem.apply(_this7, arguments); + } + }, { + key: "attack", + value: function attack() { + return new this().attack(); + } + }, { + key: "ifHolidayWanderer", + value: function ifHolidayWanderer(macro) { + return new this().ifHolidayWanderer(macro); + } + }, { + key: "ifNotHolidayWanderer", + value: function ifNotHolidayWanderer(macro) { + return new this().ifNotHolidayWanderer(macro); + } + }]); + return Macro; +}(); +/** + * Adventure in a location and handle all combats with a given macro. + * To use this function you will need to create a consult script that runs Macro.load().submit() and a CCS that calls that consult script. + * See examples/consult.ts for an example. + * + * @category Combat + * @param loc Location to adventure in. + * @param macro Macro to execute. + */ +combat_defineProperty(Macro, "SAVED_MACRO_PROPERTY", "libram_savedMacro"); +combat_defineProperty(Macro, "cachedMacroIds", new Map()); +combat_defineProperty(Macro, "cachedAutoAttacks", new Map()); +function adventureMacro(loc, macro) { + macro.save(); + setAutoAttack(0); + try { + adv1(loc, 0, ""); + while (inMultiFight()) runCombat(); + if (choiceFollowsFight()) visitUrl("choice.php"); + } finally { + Macro.clearSaved(); + } +} +/** + * Adventure in a location and handle all combats with a given autoattack and manual macro. + * To use the nextMacro parameter you will need to create a consult script that runs Macro.load().submit() and a CCS that calls that consult script. + * See examples/consult.ts for an example. + * + * @category Combat + * @param loc Location to adventure in. + * @param autoMacro Macro to execute via KoL autoattack. + * @param nextMacro Macro to execute manually after autoattack completes. + */ +function adventureMacroAuto(loc, autoMacro) { + var _nextMacro; + var nextMacro = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; + nextMacro = (_nextMacro = nextMacro) !== null && _nextMacro !== void 0 ? _nextMacro : Macro.abort(); + autoMacro.setAutoAttack(); + nextMacro.save(); + try { + adv1(loc, 0, ""); + while (inMultiFight()) runCombat(); + if (choiceFollowsFight()) visitUrl("choice.php"); + } finally { + Macro.clearSaved(); + } +} +var StrictMacro = /*#__PURE__*/(/* unused pure expression or super */ null && (function (_Macro) { + combat_inherits(StrictMacro, _Macro); + var _super2 = combat_createSuper(StrictMacro); + function StrictMacro() { + combat_classCallCheck(this, StrictMacro); + return _super2.apply(this, arguments); + } + combat_createClass(StrictMacro, [{ + key: "skill", + value: + /** + * Add one or more skill cast steps to the macro. + * + * @param skills Skills to cast. + * @returns {StrictMacro} This object itself. + */ + function skill() { + var _get2; + for (var _len7 = arguments.length, skills = new Array(_len7), _key7 = 0; _key7 < _len7; _key7++) { + skills[_key7] = arguments[_key7]; + } + return (_get2 = _get(combat_getPrototypeOf(StrictMacro.prototype), "skill", this)).call.apply(_get2, [this].concat(skills)); + } + /** + * Create a new macro with one or more skill cast steps. + * + * @param skills Skills to cast. + * @returns {StrictMacro} This object itself. + */ + }, { + key: "item", + value: + /** + * Add one or more item steps to the macro. + * + * @param items Items to use. Pass a tuple [item1, item2] to funksling. + * @returns {StrictMacro} This object itself. + */ + function item() { + var _get3; + for (var _len8 = arguments.length, items = new Array(_len8), _key8 = 0; _key8 < _len8; _key8++) { + items[_key8] = arguments[_key8]; + } + return (_get3 = _get(combat_getPrototypeOf(StrictMacro.prototype), "item", this)).call.apply(_get3, [this].concat(items)); + } + /** + * Create a new macro with one or more item steps. + * + * @param items Items to use. Pass a tuple [item1, item2] to funksling. + * @returns {StrictMacro} This object itself. + */ + }, { + key: "trySkill", + value: + /** + * Add one or more skill cast steps to the macro, where each step checks if you have the skill first. + * + * @param skills Skills to try casting. + * @returns {StrictMacro} This object itself. + */ + function trySkill() { + var _get4; + for (var _len9 = arguments.length, skills = new Array(_len9), _key9 = 0; _key9 < _len9; _key9++) { + skills[_key9] = arguments[_key9]; + } + return (_get4 = _get(combat_getPrototypeOf(StrictMacro.prototype), "trySkill", this)).call.apply(_get4, [this].concat(skills)); + } + /** + * Create a new macro with one or more skill cast steps, where each step checks if you have the skill first. + * + * @param skills Skills to try casting. + * @returns {StrictMacro} This object itself. + */ + }, { + key: "tryItem", + value: + /** + * Add one or more item steps to the macro, where each step checks to see if you have the item first. + * + * @param items Items to try using. Pass a tuple [item1, item2] to funksling. + * @returns {StrictMacro} This object itself. + */ + function tryItem() { + var _get5; + for (var _len10 = arguments.length, items = new Array(_len10), _key10 = 0; _key10 < _len10; _key10++) { + items[_key10] = arguments[_key10]; + } + return (_get5 = _get(combat_getPrototypeOf(StrictMacro.prototype), "tryItem", this)).call.apply(_get5, [this].concat(items)); + } + /** + * Create a new macro with one or more item steps, where each step checks to see if you have the item first. + * + * @param items Items to try using. Pass a tuple [item1, item2] to funksling. + * @returns {StrictMacro} This object itself. + */ + }, { + key: "trySkillRepeat", + value: + /** + * Add one or more skill-cast-and-repeat steps to the macro, where each step checks if you have the skill first. + * + * @param skills Skills to try repeatedly casting. + * @returns {StrictMacro} This object itself. + */ + function trySkillRepeat() { + var _get6; + for (var _len11 = arguments.length, skills = new Array(_len11), _key11 = 0; _key11 < _len11; _key11++) { + skills[_key11] = arguments[_key11]; + } + return (_get6 = _get(combat_getPrototypeOf(StrictMacro.prototype), "trySkillRepeat", this)).call.apply(_get6, [this].concat(skills)); + } + /** + * Create a new macro with one or more skill-cast-and-repeat steps, where each step checks if you have the skill first. + * + * @param skills Skills to try repeatedly casting. + * @returns {StrictMacro} This object itself. + */ + }], [{ + key: "skill", + value: function skill() { + var _this8; + return (_this8 = new this()).skill.apply(_this8, arguments); + } + }, { + key: "item", + value: function item() { + var _this9; + return (_this9 = new this()).item.apply(_this9, arguments); + } + }, { + key: "trySkill", + value: function trySkill() { + var _this10; + return (_this10 = new this()).trySkill.apply(_this10, arguments); + } + }, { + key: "tryItem", + value: function tryItem() { + var _this11; + return (_this11 = new this()).tryItem.apply(_this11, arguments); + } + }, { + key: "trySkillRepeat", + value: function trySkillRepeat() { + var _this12; + return (_this12 = new this()).trySkillRepeat.apply(_this12, arguments); + } + }]); + return StrictMacro; +}(Macro))); +;// CONCATENATED MODULE: ./node_modules/grimoire-kolmafia/dist/combat.js +function dist_combat_inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) dist_combat_setPrototypeOf(subClass, superClass); } +function dist_combat_setPrototypeOf(o, p) { dist_combat_setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return dist_combat_setPrototypeOf(o, p); } +function dist_combat_createSuper(Derived) { var hasNativeReflectConstruct = dist_combat_isNativeReflectConstruct(); return function _createSuperInternal() { var Super = dist_combat_getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = dist_combat_getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return dist_combat_possibleConstructorReturn(this, result); }; } +function dist_combat_possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return dist_combat_assertThisInitialized(self); } +function dist_combat_assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } +function dist_combat_isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } +function dist_combat_getPrototypeOf(o) { dist_combat_getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return dist_combat_getPrototypeOf(o); } +function dist_combat_toConsumableArray(arr) { return dist_combat_arrayWithoutHoles(arr) || dist_combat_iterableToArray(arr) || dist_combat_unsupportedIterableToArray(arr) || dist_combat_nonIterableSpread(); } +function dist_combat_nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function dist_combat_iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); } +function dist_combat_arrayWithoutHoles(arr) { if (Array.isArray(arr)) return dist_combat_arrayLikeToArray(arr); } +function dist_combat_createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = dist_combat_unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; } +function dist_combat_unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return dist_combat_arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return dist_combat_arrayLikeToArray(o, minLen); } +function dist_combat_arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } +function dist_combat_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } +function dist_combat_defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, dist_combat_toPropertyKey(descriptor.key), descriptor); } } +function dist_combat_createClass(Constructor, protoProps, staticProps) { if (protoProps) dist_combat_defineProperties(Constructor.prototype, protoProps); if (staticProps) dist_combat_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } +function dist_combat_toPropertyKey(arg) { var key = dist_combat_toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); } +function dist_combat_toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } + + +/** + * The strategy to use for combat for a task, which indicates what to do + * for each monster. + * + * There are two ways to specify in a task what to do for a given monster: + * 1. Provide a macro directly through .macro(macro, ...monsters) + * 2. Provide an action through .action(action, ...monsters) + * + * An action is a strategy for dealing with a monster that is not fully + * defined in the task. The possible actions are set with the type parameter A. + * Actions should typically end the fight. + * + * For example, a task may want to banish a monster but not necessarily know or + * care which banisher is used. Instead, it is best for the engine to determine + * which banisher to use on the monster. To facilitate this, "banish" can be + * defined as an action, e.g. with CombatStrategy<"banish">; + * + * Each action can be resolved by the engine by: + * 1. Providing a default macro for the action through ActionDefaults, + * which can be done through combat_defaults in Engine options, or + * 2. Providing a CombatResource for the action through CombatResources. + * This is typically done in Engine.customize() by checking if a given + * action is requested by the task with combat.can(.), and then providing + * an appropriate resource with resources.provide(.). + * + * A monster may have both a macro and an action defined, and a macro or action + * can be specified to be done on all monsters. The order of combat is then: + * 1. The macro(s) given in .startingMacro(). + * 2. The monster-specific macro(s) from .macro(). + * 3. The general macro(s) from .macro(). + * 4. The monster-specific action from .action(). + * 5. The general action from .action(). + * + * If an autoattack is set with .autoattack(), the order of the autoattack is: + * 1. The monster-specific macro(s) from .autoattack(). + * 2. The general macro(s) from .autoattack(). + */ +var CombatStrategy = /*#__PURE__*/function () { + function CombatStrategy() { + dist_combat_classCallCheck(this, CombatStrategy); + this.macros = new Map(); + this.autoattacks = new Map(); + this.actions = new Map(); + this.ccs_entries = new Map(); + } + /** + * Add a macro to perform for this monster. If multiple macros are given + * for the same monster, they are concatinated. + * + * @param macro The macro to perform. + * @param monsters Which monsters to use the macro on. If not given, add the + * macro as a general macro. + * @param prepend If true, add the macro before all previous macros for + * the same monster. If false, add after all previous macros. + * @returns this + */ + dist_combat_createClass(CombatStrategy, [{ + key: "macro", + value: function macro(_macro, monsters, prepend) { + var _a, _b; + if (monsters === undefined) { + if (this.default_macro === undefined) this.default_macro = []; + if (prepend) this.default_macro.unshift(_macro);else this.default_macro.push(_macro); + } else { + if (monsters instanceof external_kolmafia_.Monster) monsters = [monsters]; + var _iterator = dist_combat_createForOfIteratorHelper(monsters), + _step; + try { + for (_iterator.s(); !(_step = _iterator.n()).done;) { + var monster = _step.value; + if (!this.macros.has(monster)) this.macros.set(monster, []); + if (prepend) (_a = this.macros.get(monster)) === null || _a === void 0 ? void 0 : _a.unshift(_macro);else (_b = this.macros.get(monster)) === null || _b === void 0 ? void 0 : _b.push(_macro); + } + } catch (err) { + _iterator.e(err); + } finally { + _iterator.f(); + } + } + return this; + } + /** + * Add a macro to perform as an autoattack for this monster. If multiple + * macros are given for the same monster, they are concatinated. + * + * @param macro The macro to perform as autoattack. + * @param monsters Which monsters to use the macro on. If not given, add the + * macro as a general macro. + * @param prepend If true, add the macro before all previous autoattack + * macros for the same monster. If false, add after all previous macros. + * @returns this + */ + }, { + key: "autoattack", + value: function autoattack(macro, monsters, prepend) { + var _a, _b; + if (monsters === undefined) { + if (this.default_autoattack === undefined) this.default_autoattack = []; + if (prepend) this.default_autoattack.unshift(macro);else this.default_autoattack.push(macro); + } else { + if (monsters instanceof external_kolmafia_.Monster) monsters = [monsters]; + var _iterator2 = dist_combat_createForOfIteratorHelper(monsters), + _step2; + try { + for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) { + var monster = _step2.value; + if (!this.autoattacks.has(monster)) this.autoattacks.set(monster, []); + if (prepend) (_a = this.autoattacks.get(monster)) === null || _a === void 0 ? void 0 : _a.unshift(macro);else (_b = this.autoattacks.get(monster)) === null || _b === void 0 ? void 0 : _b.push(macro); + } + } catch (err) { + _iterator2.e(err); + } finally { + _iterator2.f(); + } + } + return this; + } + /** + * Add a macro to perform at the start of combat. + * @param macro The macro to perform. + * @param prepend If true, add the macro before all previous starting + * macros. If false, add after all previous starting macros. + * @returns this + */ + }, { + key: "startingMacro", + value: function startingMacro(macro, prepend) { + if (this.starting_macro === undefined) this.starting_macro = []; + if (prepend) this.starting_macro.unshift(macro);else this.starting_macro.push(macro); + return this; + } + /** + * Add an action to perform for this monster. Only one action can be set for + * each monster; any previous actions are overwritten. + * + * @param action The action to perform. + * @param monsters Which monsters to use the action on. If not given, set the + * action as the general action for all monsters. + * @returns this + */ + }, { + key: "action", + value: function action(_action, monsters) { + if (monsters === undefined) { + this.default_action = _action; + } else if (monsters instanceof external_kolmafia_.Monster) { + this.actions.set(monsters, _action); + } else { + var _iterator3 = dist_combat_createForOfIteratorHelper(monsters), + _step3; + try { + for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) { + var monster = _step3.value; + this.actions.set(monster, _action); + } + } catch (err) { + _iterator3.e(err); + } finally { + _iterator3.f(); + } + } + return this; + } + /** + * Add a separate entry in the grimoire-generated CCS file for the specified + * monster. If multiple entries are given for the same monster, they are + * concatinated. + * + * This should typically be only used rarely, on monsters for which KoL does + * not support macros in combat (e.g. rampaging adding machine). + * + * @param entry The entry to add for the given monster. + * @param monsters Which monsters to add the entry to. + * @param prepend If true, add the entry before all previous entries. If + * false, add after all previous entries. + */ + }, { + key: "ccs", + value: function ccs(entry, monsters, prepend) { + var _a, _b; + if (monsters instanceof external_kolmafia_.Monster) monsters = [monsters]; + var _iterator4 = dist_combat_createForOfIteratorHelper(monsters), + _step4; + try { + for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) { + var monster = _step4.value; + if (!this.ccs_entries.has(monster)) this.ccs_entries.set(monster, []); + if (prepend) (_a = this.ccs_entries.get(monster)) === null || _a === void 0 ? void 0 : _a.unshift(entry);else (_b = this.ccs_entries.get(monster)) === null || _b === void 0 ? void 0 : _b.push(entry); + } + } catch (err) { + _iterator4.e(err); + } finally { + _iterator4.f(); + } + return this; + } + /** + * Check if the provided action was requested for any monsters, or for the + * general action. + */ + }, { + key: "can", + value: function can(action) { + if (action === this.default_action) return true; + return Array.from(this.actions.values()).includes(action); + } + /** + * Return the general action (if it exists). + */ + }, { + key: "getDefaultAction", + value: function getDefaultAction() { + return this.default_action; + } + /** + * Return all monsters where the provided action was requested. + */ + }, { + key: "where", + value: function where(action) { + return Array.from(this.actions.keys()).filter(key => this.actions.get(key) === action); + } + /** + * Return the requested action (if it exists) for the provided monster. + */ + }, { + key: "currentStrategy", + value: function currentStrategy(monster) { + var _a; + return (_a = this.actions.get(monster)) !== null && _a !== void 0 ? _a : this.default_action; + } + /** + * Perform a deep copy of this combat strategy. + */ + }, { + key: "clone", + value: function clone() { + var result = new CombatStrategy(); + if (this.starting_macro) result.starting_macro = dist_combat_toConsumableArray(this.starting_macro); + if (this.default_macro) result.default_macro = dist_combat_toConsumableArray(this.default_macro); + var _iterator5 = dist_combat_createForOfIteratorHelper(this.macros), + _step5; + try { + for (_iterator5.s(); !(_step5 = _iterator5.n()).done;) { + var pair = _step5.value; + result.macros.set(pair[0], dist_combat_toConsumableArray(pair[1])); + } + } catch (err) { + _iterator5.e(err); + } finally { + _iterator5.f(); + } + if (this.default_autoattack) result.default_autoattack = dist_combat_toConsumableArray(this.default_autoattack); + var _iterator6 = dist_combat_createForOfIteratorHelper(this.autoattacks), + _step6; + try { + for (_iterator6.s(); !(_step6 = _iterator6.n()).done;) { + var _pair = _step6.value; + result.autoattacks.set(_pair[0], dist_combat_toConsumableArray(_pair[1])); + } + } catch (err) { + _iterator6.e(err); + } finally { + _iterator6.f(); + } + result.default_action = this.default_action; + var _iterator7 = dist_combat_createForOfIteratorHelper(this.actions), + _step7; + try { + for (_iterator7.s(); !(_step7 = _iterator7.n()).done;) { + var _pair2 = _step7.value; + result.actions.set(_pair2[0], _pair2[1]); + } + } catch (err) { + _iterator7.e(err); + } finally { + _iterator7.f(); + } + var _iterator8 = dist_combat_createForOfIteratorHelper(this.ccs_entries), + _step8; + try { + for (_iterator8.s(); !(_step8 = _iterator8.n()).done;) { + var _pair3 = _step8.value; + result.ccs_entries.set(_pair3[0], dist_combat_toConsumableArray(_pair3[1])); + } + } catch (err) { + _iterator8.e(err); + } finally { + _iterator8.f(); + } + return result; + } + /** + * Compile this combat strategy into a complete macro. + * + * @param resources The resources to use to fulfil actions. + * @param defaults Macros to perform for each action without a resource. + * @param location The adventuring location, if known. + * @returns The compiled macro. + */ + }, { + key: "compile", + value: function compile(resources, defaults, location) { + var _a, _b; + var result = new Macro(); + // If there is macro precursor, do it now + if (this.starting_macro) { + result.step.apply(result, dist_combat_toConsumableArray(this.starting_macro.map(undelay))); + } + // Perform any monster-specific macros (these may or may not end the fight) + var monster_macros = new CompressedMacro(); + this.macros.forEach((value, key) => { + var _Macro; + monster_macros.add(key, (_Macro = new Macro()).step.apply(_Macro, dist_combat_toConsumableArray(value.map(undelay)))); + }); + result.step(monster_macros.compile()); + // Perform the non-monster specific macro + if (this.default_macro) result.step.apply(result, dist_combat_toConsumableArray(this.default_macro.map(undelay))); + // Perform any monster-specific actions (these should end the fight) + var monster_actions = new CompressedMacro(); + this.actions.forEach((action, key) => { + var _a, _b; + var macro = (_a = resources.getMacro(action)) !== null && _a !== void 0 ? _a : (_b = defaults === null || defaults === void 0 ? void 0 : defaults[action]) === null || _b === void 0 ? void 0 : _b.call(defaults, key); + if (macro) monster_actions.add(key, new Macro().step(macro)); + }); + result.step(monster_actions.compile()); + // Perform the non-monster specific action (these should end the fight) + if (this.default_action) { + var macro = (_a = resources.getMacro(this.default_action)) !== null && _a !== void 0 ? _a : (_b = defaults === null || defaults === void 0 ? void 0 : defaults[this.default_action]) === null || _b === void 0 ? void 0 : _b.call(defaults, location); + if (macro) result.step(macro); + } + return result; + } + /** + * Compile the autoattack of this combat strategy into a complete macro. + * + * @returns The compiled autoattack macro. + */ + }, { + key: "compileAutoattack", + value: function compileAutoattack() { + var result = new Macro(); + // Perform any monster-specific autoattacks (these may or may not end the fight) + var monster_macros = new CompressedMacro(); + this.autoattacks.forEach((value, key) => { + var _Macro2; + monster_macros.add(key, (_Macro2 = new Macro()).step.apply(_Macro2, dist_combat_toConsumableArray(value.map(undelay)))); + }); + result.step(monster_macros.compile()); + // Perform the non-monster specific macro + if (this.default_autoattack) result.step.apply(result, dist_combat_toConsumableArray(this.default_autoattack.map(undelay))); + return result; + } + /** + * Compile the CCS entries of this combat strategy into a single array. + * + * @returns The lines of a CCS file, not including the [default] macro. + */ + }, { + key: "compileCcs", + value: function compileCcs() { + var result = []; + var _iterator9 = dist_combat_createForOfIteratorHelper(this.ccs_entries), + _step9; + try { + for (_iterator9.s(); !(_step9 = _iterator9.n()).done;) { + var ccs_entry = _step9.value; + result.push.apply(result, ["[".concat(ccs_entry[0].name, "]")].concat(dist_combat_toConsumableArray(ccs_entry[1]))); + } + } catch (err) { + _iterator9.e(err); + } finally { + _iterator9.f(); + } + return result; + } + /** + * For advanced users, this method will generate a fluent API for requesting + * actions. That is, it allows you to do + * combat.banish(monster1).kill(monster2) + * instead of + * combat.action("banish", monster1).action("kill", monster2) + * + * Example usage: + * const myActions = ["kill", "banish"] as const; + * class MyCombatStrategy extends CombatStrategy.withActions(myActions) {} + * + * const foo: MyCombatStrategy = new MyCombatStrategy(); + * const bar: MyCombatStrategy = foo.banish($monster`crate`).kill($monster`tumbleweed`); + */ + }], [{ + key: "withActions", + value: function withActions(actions) { + var CombatStrategyWithActions = /*#__PURE__*/function (_this) { + dist_combat_inherits(CombatStrategyWithActions, _this); + var _super = dist_combat_createSuper(CombatStrategyWithActions); + function CombatStrategyWithActions() { + dist_combat_classCallCheck(this, CombatStrategyWithActions); + return _super.apply(this, arguments); + } + return dist_combat_createClass(CombatStrategyWithActions); + }(this); // eslint-disable-next-line @typescript-eslint/no-explicit-any + var proto = CombatStrategyWithActions.prototype; + var _iterator10 = dist_combat_createForOfIteratorHelper(actions), + _step10; + try { + var _loop = function _loop() { + var action = _step10.value; + proto[action] = function (monsters) { + return this.action(action, monsters); + }; + }; + for (_iterator10.s(); !(_step10 = _iterator10.n()).done;) { + _loop(); + } + // eslint-disable-next-line @typescript-eslint/no-explicit-any + } catch (err) { + _iterator10.e(err); + } finally { + _iterator10.f(); + } + return CombatStrategyWithActions; + } + }]); + return CombatStrategy; +}(); +/** + * A class to build a macro that combines if statements (keyed on monster) with + * identical body into a single if statement, to avoid the 37-action limit. + * Ex: [if x; A; if y; B; if z; A;] will turn into [if x || z; A; if y; B] + */ +var CompressedMacro = /*#__PURE__*/function () { + function CompressedMacro() { + dist_combat_classCallCheck(this, CompressedMacro); + this.components = new Map(); + } + /** + * Set the macro for a given monster (replacing any previous macros). + */ + dist_combat_createClass(CompressedMacro, [{ + key: "add", + value: function add(monster, macro) { + var _a; + var macro_text = macro.toString(); + if (macro_text.length === 0) return; + if (!this.components.has(macro_text)) this.components.set(macro_text, [monster]);else (_a = this.components.get(macro_text)) === null || _a === void 0 ? void 0 : _a.push(monster); + } + /** + * Compile the compressed form of the macro. + */ + }, { + key: "compile", + value: function compile() { + var result = new Macro(); + this.components.forEach((monsters, macro) => { + var condition = monsters.map(mon => "monsterid ".concat(mon.id)).join(" || "); + result.if_(condition, macro); + }); + return result; + } + }]); + return CompressedMacro; +}(); +/** + * A class for providing resources to fulfil combat actions. + */ +var CombatResources = /*#__PURE__*/function () { + function CombatResources() { + dist_combat_classCallCheck(this, CombatResources); + this.resources = new Map(); + } + /** + * Use the provided resource to fulfil the provided action. + * (If the resource is undefined, this does nothing). + */ + dist_combat_createClass(CombatResources, [{ + key: "provide", + value: function provide(action, resource) { + if (resource === undefined) return; + this.resources.set(action, resource); + } + /** + * Return true if the provided action has a resource provided. + */ + }, { + key: "has", + value: function has(action) { + return this.resources.has(action); + } + /** + * Return all provided combat resources. + */ + }, { + key: "all", + value: function all() { + return Array.from(this.resources.values()); + } + /** + * Get the macro provided by the resource for this action, or undefined if + * no resource was provided. + */ + }, { + key: "getMacro", + value: function getMacro(action) { + var resource = this.resources.get(action); + if (resource === undefined) return undefined; + if (resource.do instanceof external_kolmafia_.Item) return new Macro().item(resource.do); + if (resource.do instanceof external_kolmafia_.Skill) return new Macro().skill(resource.do); + return undelay(resource.do); + } + }]); + return CombatResources; +}(); +;// CONCATENATED MODULE: ./node_modules/libram/dist/logger.js +var _defaultHandlers; +function logger_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } +function logger_defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, logger_toPropertyKey(descriptor.key), descriptor); } } +function logger_createClass(Constructor, protoProps, staticProps) { if (protoProps) logger_defineProperties(Constructor.prototype, protoProps); if (staticProps) logger_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } +function logger_defineProperty(obj, key, value) { key = logger_toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function logger_toPropertyKey(arg) { var key = logger_toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); } +function logger_toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } + +var LogLevels; +(function (LogLevels) { + LogLevels[LogLevels["NONE"] = 0] = "NONE"; + LogLevels[LogLevels["ERROR"] = 1] = "ERROR"; + LogLevels[LogLevels["WARNING"] = 2] = "WARNING"; + LogLevels[LogLevels["INFO"] = 3] = "INFO"; + LogLevels[LogLevels["DEBUG"] = 4] = "DEBUG"; +})(LogLevels || (LogLevels = {})); +var defaultHandlers = (_defaultHandlers = {}, logger_defineProperty(_defaultHandlers, LogLevels.INFO, message => { + (0,external_kolmafia_.printHtml)("[Libram Info] ".concat(message)); + (0,external_kolmafia_.logprint)("[Libram] ".concat(message)); + return; +}), logger_defineProperty(_defaultHandlers, LogLevels.WARNING, message => { + (0,external_kolmafia_.printHtml)("[Libram Warning] ".concat(message, "")); + (0,external_kolmafia_.logprint)("[Libram] ".concat(message)); + return; +}), logger_defineProperty(_defaultHandlers, LogLevels.ERROR, error => { + (0,external_kolmafia_.printHtml)("[Libram Error] ".concat(error.toString(), "")); + (0,external_kolmafia_.logprint)("[Libram] ".concat(error)); + return; +}), logger_defineProperty(_defaultHandlers, LogLevels.DEBUG, message => { + (0,external_kolmafia_.printHtml)("[Libram Debug] ".concat(message, "")); + (0,external_kolmafia_.logprint)("[Libram] ".concat(message)); + return; +}), _defaultHandlers); +var Logger = /*#__PURE__*/function () { + function Logger() { + logger_classCallCheck(this, Logger); + logger_defineProperty(this, "handlers", defaultHandlers); + } + logger_createClass(Logger, [{ + key: "level", + get: function get() { + return Logger.currentLevel; + } + }, { + key: "setLevel", + value: function setLevel(level) { + Logger.currentLevel = level; + } + }, { + key: "setHandler", + value: function setHandler(level, callback) { + this.handlers[level] = callback; + } + // eslint-disable-next-line @typescript-eslint/no-explicit-any + }, { + key: "log", + value: function log(level, message) { + if (this.level >= level) this.handlers[level](message); + } + }, { + key: "info", + value: function info(message) { + this.log(LogLevels.INFO, message); + } + }, { + key: "warning", + value: function warning(message) { + this.log(LogLevels.WARNING, message); + } + }, { + key: "error", + value: function error(message) { + this.log(LogLevels.ERROR, message); + } + }, { + key: "debug", + value: function debug(message) { + this.log(LogLevels.DEBUG, message); + } + }]); + return Logger; +}(); +logger_defineProperty(Logger, "currentLevel", LogLevels.ERROR); +/* harmony default export */ const dist_logger = (new Logger()); +;// CONCATENATED MODULE: ./node_modules/libram/dist/maximize.js +var maximize_templateObject, maximize_templateObject2, maximize_templateObject3, maximize_templateObject4, maximize_templateObject5, maximize_templateObject6, maximize_templateObject7, maximize_templateObject8, maximize_templateObject9, maximize_templateObject10, maximize_templateObject11, maximize_templateObject12, maximize_templateObject13, maximize_templateObject14, maximize_templateObject15, maximize_templateObject16, maximize_templateObject17, maximize_templateObject18, maximize_templateObject19, maximize_templateObject20, maximize_templateObject21, maximize_templateObject22, maximize_templateObject23, maximize_templateObject24, maximize_templateObject25, maximize_templateObject26, maximize_templateObject27, maximize_templateObject28, maximize_templateObject29, maximize_templateObject30, maximize_templateObject31, maximize_templateObject32, maximize_templateObject33, maximize_templateObject34, maximize_templateObject35, maximize_templateObject36, maximize_templateObject37, maximize_templateObject38, maximize_templateObject39, maximize_templateObject40, maximize_templateObject41, maximize_templateObject42, maximize_templateObject43, maximize_templateObject44, maximize_templateObject45, _templateObject46, _templateObject47, _templateObject48, _templateObject49; +function maximize_slicedToArray(arr, i) { return maximize_arrayWithHoles(arr) || maximize_iterableToArrayLimit(arr, i) || maximize_unsupportedIterableToArray(arr, i) || maximize_nonIterableRest(); } +function maximize_nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function maximize_iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } +function maximize_arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } +function _classPrivateFieldInitSpec(obj, privateMap, value) { _checkPrivateRedeclaration(obj, privateMap); privateMap.set(obj, value); } +function _checkPrivateRedeclaration(obj, privateCollection) { if (privateCollection.has(obj)) { throw new TypeError("Cannot initialize the same private elements twice on an object"); } } +function _classPrivateFieldGet(receiver, privateMap) { var descriptor = _classExtractFieldDescriptor(receiver, privateMap, "get"); return _classApplyDescriptorGet(receiver, descriptor); } +function _classApplyDescriptorGet(receiver, descriptor) { if (descriptor.get) { return descriptor.get.call(receiver); } return descriptor.value; } +function _classPrivateFieldSet(receiver, privateMap, value) { var descriptor = _classExtractFieldDescriptor(receiver, privateMap, "set"); _classApplyDescriptorSet(receiver, descriptor, value); return value; } +function _classExtractFieldDescriptor(receiver, privateMap, action) { if (!privateMap.has(receiver)) { throw new TypeError("attempted to " + action + " private field on non-instance"); } return privateMap.get(receiver); } +function _classApplyDescriptorSet(receiver, descriptor, value) { if (descriptor.set) { descriptor.set.call(receiver, value); } else { if (!descriptor.writable) { throw new TypeError("attempted to set read only private field"); } descriptor.value = value; } } +function maximize_defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, maximize_toPropertyKey(descriptor.key), descriptor); } } +function maximize_createClass(Constructor, protoProps, staticProps) { if (protoProps) maximize_defineProperties(Constructor.prototype, protoProps); if (staticProps) maximize_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } +function maximize_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } +function maximize_createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = maximize_unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; } +function maximize_taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); } +function maximize_ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function maximize_objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? maximize_ownKeys(Object(t), !0).forEach(function (r) { maximize_defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : maximize_ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +function maximize_defineProperty(obj, key, value) { key = maximize_toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function maximize_toPropertyKey(arg) { var key = maximize_toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); } +function maximize_toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } +function maximize_toConsumableArray(arr) { return maximize_arrayWithoutHoles(arr) || maximize_iterableToArray(arr) || maximize_unsupportedIterableToArray(arr) || maximize_nonIterableSpread(); } +function maximize_nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function maximize_unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return maximize_arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return maximize_arrayLikeToArray(o, minLen); } +function maximize_iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); } +function maximize_arrayWithoutHoles(arr) { if (Array.isArray(arr)) return maximize_arrayLikeToArray(arr); } +function maximize_arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } + + + + + +function toMaximizerName(_ref) { + var name = _ref.name, + id = _ref.id; + return name.includes(";") ? "\xB6".concat(id) : name; +} +/** + * Merges a partial set of maximizer options onto a full set maximizer options. We merge via overriding for all boolean properties and for onlySlot, and concat all other array properties. + * + * @param defaultOptions MaximizeOptions to use as a "base." + * @param addendums Options to attempt to merge onto defaultOptions. + * @returns Merged maximizer options + */ +function mergeMaximizeOptions(defaultOptions, addendums) { + var _addendums$updateOnFa, _addendums$updateOnCa, _addendums$useOutfitC, _addendums$forceEquip, _addendums$preventEqu, _addendums$bonusEquip, _addendums$onlySlot, _addendums$preventSlo, _addendums$forceUpdat, _addendums$modes; + return { + updateOnFamiliarChange: (_addendums$updateOnFa = addendums.updateOnFamiliarChange) !== null && _addendums$updateOnFa !== void 0 ? _addendums$updateOnFa : defaultOptions.updateOnFamiliarChange, + updateOnCanEquipChanged: (_addendums$updateOnCa = addendums.updateOnCanEquipChanged) !== null && _addendums$updateOnCa !== void 0 ? _addendums$updateOnCa : defaultOptions.updateOnCanEquipChanged, + useOutfitCaching: (_addendums$useOutfitC = addendums.useOutfitCaching) !== null && _addendums$useOutfitC !== void 0 ? _addendums$useOutfitC : defaultOptions.useOutfitCaching, + forceEquip: [].concat(maximize_toConsumableArray(defaultOptions.forceEquip), maximize_toConsumableArray((_addendums$forceEquip = addendums.forceEquip) !== null && _addendums$forceEquip !== void 0 ? _addendums$forceEquip : [])), + preventEquip: [].concat(maximize_toConsumableArray(defaultOptions.preventEquip), maximize_toConsumableArray((_addendums$preventEqu = addendums.preventEquip) !== null && _addendums$preventEqu !== void 0 ? _addendums$preventEqu : [])).filter(item => { + var _addendums$forceEquip2; + return !defaultOptions.forceEquip.includes(item) && !((_addendums$forceEquip2 = addendums.forceEquip) !== null && _addendums$forceEquip2 !== void 0 && _addendums$forceEquip2.includes(item)); + }), + bonusEquip: new Map([].concat(maximize_toConsumableArray(defaultOptions.bonusEquip), maximize_toConsumableArray((_addendums$bonusEquip = addendums.bonusEquip) !== null && _addendums$bonusEquip !== void 0 ? _addendums$bonusEquip : []))), + onlySlot: (_addendums$onlySlot = addendums.onlySlot) !== null && _addendums$onlySlot !== void 0 ? _addendums$onlySlot : defaultOptions.onlySlot, + preventSlot: [].concat(maximize_toConsumableArray(defaultOptions.preventSlot), maximize_toConsumableArray((_addendums$preventSlo = addendums.preventSlot) !== null && _addendums$preventSlo !== void 0 ? _addendums$preventSlo : [])), + forceUpdate: (_addendums$forceUpdat = addendums.forceUpdate) !== null && _addendums$forceUpdat !== void 0 ? _addendums$forceUpdat : defaultOptions.forceUpdate, + modes: maximize_objectSpread(maximize_objectSpread({}, defaultOptions.modes), (_addendums$modes = addendums.modes) !== null && _addendums$modes !== void 0 ? _addendums$modes : {}) + }; +} +var defaultMaximizeOptions = { + updateOnFamiliarChange: true, + updateOnCanEquipChanged: true, + useOutfitCaching: true, + forceEquip: [], + preventEquip: [], + bonusEquip: new Map(), + onlySlot: [], + preventSlot: [], + forceUpdate: false, + modes: {} +}; +/** + * + * @param options Default options for each maximizer run. + * @param options.updateOnFamiliarChange Re-run the maximizer if familiar has changed. Default true. + * @param options.updateOnCanEquipChanged Re-run the maximizer if stats have changed what can be equipped. Default true. + * @param options.forceEquip Equipment to force-equip ("equip X"). + * @param options.preventEquip Equipment to prevent equipping ("-equip X"). + * @param options.bonusEquip Equipment to apply a bonus to ("200 bonus X"). + */ +function setDefaultMaximizeOptions(options) { + Object.assign(defaultMaximizeOptions, options); +} +var modeableCommands = ["backupcamera", "umbrella", "snowsuit", "edpiece", "retrocape", "parka"]; +var modeableItems = { + backupcamera: template_string_$item(maximize_templateObject || (maximize_templateObject = maximize_taggedTemplateLiteral(["backup camera"]))), + umbrella: template_string_$item(maximize_templateObject2 || (maximize_templateObject2 = maximize_taggedTemplateLiteral(["unbreakable umbrella"]))), + snowsuit: template_string_$item(maximize_templateObject3 || (maximize_templateObject3 = maximize_taggedTemplateLiteral(["Snow Suit"]))), + edpiece: template_string_$item(maximize_templateObject4 || (maximize_templateObject4 = maximize_taggedTemplateLiteral(["The Crown of Ed the Undying"]))), + retrocape: template_string_$item(maximize_templateObject5 || (maximize_templateObject5 = maximize_taggedTemplateLiteral(["unwrapped knock-off retro superhero cape"]))), + parka: template_string_$item(maximize_templateObject6 || (maximize_templateObject6 = maximize_taggedTemplateLiteral(["Jurassic Parka"]))) +}; +var modeableState = { + backupcamera: () => (0,external_kolmafia_.getProperty)("backupCameraMode"), + umbrella: () => (0,external_kolmafia_.getProperty)("umbrellaState"), + snowsuit: () => (0,external_kolmafia_.getProperty)("snowsuit"), + edpiece: () => (0,external_kolmafia_.getProperty)("edPiece"), + retrocape: () => (0,external_kolmafia_.getProperty)("retroCapeSuperhero") + " " + (0,external_kolmafia_.getProperty)("retroCapeWashingInstructions"), + parka: () => (0,external_kolmafia_.getProperty)("parkaMode") +}; +/** + * Get set of current modes for modeables + * + * @returns Set of modes + */ +function getCurrentModes() { + var modes = {}; + var _iterator = maximize_createForOfIteratorHelper(modeableCommands), + _step; + try { + for (_iterator.s(); !(_step = _iterator.n()).done;) { + var key = _step.value; + if ((0,external_kolmafia_.haveEquipped)(modeableItems[key])) { + modes[key] = modeableState[key](); + } + } + } catch (err) { + _iterator.e(err); + } finally { + _iterator.f(); + } + return modes; +} +/** + * Apply set of modes + * + * @param modes Modes to apply + */ +function applyModes(modes) { + var _iterator2 = maximize_createForOfIteratorHelper(modeableCommands), + _step2; + try { + for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) { + var command = _step2.value; + if ((0,external_kolmafia_.haveEquipped)(modeableItems[command]) && modes[command] !== undefined) { + if (modeableState[command]() !== modes[command]) { + (0,external_kolmafia_.cliExecute)(command + " " + modes[command]); + } + } + } + } catch (err) { + _iterator2.e(err); + } finally { + _iterator2.f(); + } +} +// Subset of slots that are valid for caching. +var cachedSlots = $slots(maximize_templateObject7 || (maximize_templateObject7 = maximize_taggedTemplateLiteral(["hat, weapon, off-hand, back, shirt, pants, acc1, acc2, acc3, familiar"]))); +var CacheEntry = /*#__PURE__*/maximize_createClass(function CacheEntry(equipment, rider, familiar, canEquipItemCount, modes) { + maximize_classCallCheck(this, CacheEntry); + maximize_defineProperty(this, "equipment", void 0); + maximize_defineProperty(this, "rider", void 0); + maximize_defineProperty(this, "familiar", void 0); + maximize_defineProperty(this, "canEquipItemCount", void 0); + maximize_defineProperty(this, "modes", void 0); + this.equipment = equipment; + this.rider = rider; + this.familiar = familiar; + this.canEquipItemCount = canEquipItemCount; + this.modes = modes; +}); +var _outfitSlots = /*#__PURE__*/new WeakMap(); +var _useHistory = /*#__PURE__*/new WeakMap(); +var _maxSize = /*#__PURE__*/new WeakMap(); +var OutfitLRUCache = /*#__PURE__*/function () { + function OutfitLRUCache(maxSize) { + maximize_classCallCheck(this, OutfitLRUCache); + // Current outfits allocated + _classPrivateFieldInitSpec(this, _outfitSlots, { + writable: true, + value: [] + }); + // Array of indices into #outfitSlots in order of use. Most recent at the front. + _classPrivateFieldInitSpec(this, _useHistory, { + writable: true, + value: [] + }); + _classPrivateFieldInitSpec(this, _maxSize, { + writable: true, + value: void 0 + }); + _classPrivateFieldSet(this, _maxSize, maxSize); + } + maximize_createClass(OutfitLRUCache, [{ + key: "checkConsistent", + value: function checkConsistent() { + if (_classPrivateFieldGet(this, _useHistory).length !== _classPrivateFieldGet(this, _outfitSlots).length || !maximize_toConsumableArray(_classPrivateFieldGet(this, _useHistory)).sort().every((value, index) => value === index)) { + throw new Error("Outfit cache consistency failed."); + } + } + }, { + key: "promote", + value: function promote(index) { + _classPrivateFieldSet(this, _useHistory, [index].concat(maximize_toConsumableArray(_classPrivateFieldGet(this, _useHistory).filter(i => i !== index)))); + this.checkConsistent(); + } + }, { + key: "get", + value: function get(key) { + var index = _classPrivateFieldGet(this, _outfitSlots).indexOf(key); + if (index < 0) return undefined; + this.promote(index); + return "".concat(OutfitLRUCache.OUTFIT_PREFIX, " ").concat(index); + } + }, { + key: "insert", + value: function insert(key) { + var lastUseIndex = undefined; + if (_classPrivateFieldGet(this, _outfitSlots).length >= _classPrivateFieldGet(this, _maxSize)) { + lastUseIndex = _classPrivateFieldGet(this, _useHistory).pop(); + if (lastUseIndex === undefined) { + throw new Error("Outfit cache consistency failed."); + } + _classPrivateFieldGet(this, _useHistory).splice(0, 0, lastUseIndex); + _classPrivateFieldGet(this, _outfitSlots)[lastUseIndex] = key; + this.checkConsistent(); + return "".concat(OutfitLRUCache.OUTFIT_PREFIX, " ").concat(lastUseIndex); + } else { + var index = _classPrivateFieldGet(this, _outfitSlots).push(key) - 1; + _classPrivateFieldGet(this, _useHistory).splice(0, 0, index); + this.checkConsistent(); + return "".concat(OutfitLRUCache.OUTFIT_PREFIX, " ").concat(index); + } + } + }, { + key: "clear", + value: function clear() { + _classPrivateFieldSet(this, _outfitSlots, []); + _classPrivateFieldSet(this, _useHistory, []); + } + }]); + return OutfitLRUCache; +}(); +/** + * Save current equipment as KoL-native outfit. + * + * @param name Name of new outfit. + */ +maximize_defineProperty(OutfitLRUCache, "OUTFIT_PREFIX", "Script Outfit"); +function saveOutfit(name) { + (0,external_kolmafia_.cliExecute)("outfit save ".concat(name)); +} +// Objective cache entries. +var cachedObjectives = {}; +// Outfit cache entries. Keep 6 by default to avoid cluttering list. +var outfitCache = new OutfitLRUCache(6); +// Cache to prevent rescanning all items unnecessarily +var cachedStats = [0, 0, 0]; +var cachedCanEquipItemCount = 0; +/** + * Count the number of unique items that can be equipped. + * + * @returns The count of unique items. + */ +function canEquipItemCount() { + var stats = $stats(maximize_templateObject8 || (maximize_templateObject8 = maximize_taggedTemplateLiteral(["Muscle, Mysticality, Moxie"]))).map(stat => Math.min((0,external_kolmafia_.myBasestat)(stat), 300)); + if (stats.every((value, index) => value === cachedStats[index])) { + return cachedCanEquipItemCount; + } + cachedStats = stats; + cachedCanEquipItemCount = external_kolmafia_.Item.all().filter(item => (0,external_kolmafia_.canEquip)(item)).length; + return cachedCanEquipItemCount; +} +/** + * Checks the objective cache for a valid entry. + * + * @param cacheKey The cache key to check. + * @param options Set of maximizer options + * @returns A valid CacheEntry or null. + */ +function checkCache(cacheKey, options) { + var entry = cachedObjectives[cacheKey]; + if (!entry) { + return null; + } + if (options.updateOnFamiliarChange && (0,external_kolmafia_.myFamiliar)() !== entry.familiar) { + dist_logger.warning("Equipment found in maximize cache but familiar is different."); + return null; + } + if (options.updateOnCanEquipChanged && entry.canEquipItemCount !== canEquipItemCount()) { + dist_logger.warning("Equipment found in maximize cache but equippable item list is out of date."); + return null; + } + return entry; +} +/** + * Applies equipment that was found in the cache. + * + * @param entry The CacheEntry to apply + * @param options Set of maximizer options + */ +function applyCached(entry, options) { + var outfitName = options.useOutfitCaching ? outfitCache.get(entry) : undefined; + if (outfitName) { + if (!(0,external_kolmafia_.isWearingOutfit)(outfitName)) { + (0,external_kolmafia_.outfit)(outfitName); + } + var familiarEquip = entry.equipment.get($slot(maximize_templateObject9 || (maximize_templateObject9 = maximize_taggedTemplateLiteral(["familiar"])))); + if (familiarEquip) (0,external_kolmafia_.equip)($slot(maximize_templateObject10 || (maximize_templateObject10 = maximize_taggedTemplateLiteral(["familiar"]))), familiarEquip); + } else { + var _iterator3 = maximize_createForOfIteratorHelper(entry.equipment), + _step3; + try { + for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) { + var _step3$value = maximize_slicedToArray(_step3.value, 2), + slot = _step3$value[0], + item = _step3$value[1]; + if ((0,external_kolmafia_.equippedItem)(slot) !== item && (0,external_kolmafia_.availableAmount)(item) > 0) { + (0,external_kolmafia_.equip)(slot, item); + } + } + } catch (err) { + _iterator3.e(err); + } finally { + _iterator3.f(); + } + if (verifyCached(entry) && options.useOutfitCaching) { + var _outfitName = outfitCache.insert(entry); + dist_logger.info("Saving equipment to outfit ".concat(_outfitName, ".")); + saveOutfit(_outfitName); + } + } + if ((0,external_kolmafia_.equippedAmount)(template_string_$item(maximize_templateObject11 || (maximize_templateObject11 = maximize_taggedTemplateLiteral(["Crown of Thrones"])))) > 0 && entry.rider.get(template_string_$item(maximize_templateObject12 || (maximize_templateObject12 = maximize_taggedTemplateLiteral(["Crown of Thrones"]))))) { + (0,external_kolmafia_.enthroneFamiliar)(entry.rider.get(template_string_$item(maximize_templateObject13 || (maximize_templateObject13 = maximize_taggedTemplateLiteral(["Crown of Thrones"])))) || template_string_$familiar.none); + } + if ((0,external_kolmafia_.equippedAmount)(template_string_$item(maximize_templateObject14 || (maximize_templateObject14 = maximize_taggedTemplateLiteral(["Buddy Bjorn"])))) > 0 && entry.rider.get(template_string_$item(maximize_templateObject15 || (maximize_templateObject15 = maximize_taggedTemplateLiteral(["Buddy Bjorn"]))))) { + (0,external_kolmafia_.bjornifyFamiliar)(entry.rider.get(template_string_$item(maximize_templateObject16 || (maximize_templateObject16 = maximize_taggedTemplateLiteral(["Buddy Bjorn"])))) || template_string_$familiar.none); + } + applyModes(maximize_objectSpread(maximize_objectSpread({}, entry.modes), options.modes)); +} +var slotStructure = [$slots(maximize_templateObject17 || (maximize_templateObject17 = maximize_taggedTemplateLiteral(["hat"]))), $slots(maximize_templateObject18 || (maximize_templateObject18 = maximize_taggedTemplateLiteral(["back"]))), $slots(maximize_templateObject19 || (maximize_templateObject19 = maximize_taggedTemplateLiteral(["shirt"]))), $slots(maximize_templateObject20 || (maximize_templateObject20 = maximize_taggedTemplateLiteral(["weapon, off-hand"]))), $slots(maximize_templateObject21 || (maximize_templateObject21 = maximize_taggedTemplateLiteral(["pants"]))), $slots(maximize_templateObject22 || (maximize_templateObject22 = maximize_taggedTemplateLiteral(["acc1, acc2, acc3"]))), $slots(maximize_templateObject23 || (maximize_templateObject23 = maximize_taggedTemplateLiteral(["familiar"])))]; +/** + * Verifies that a CacheEntry was applied successfully. + * + * @param entry The CacheEntry to verify + * @param warn Whether to warn if the cache could not be applied + * @returns If all desired equipment was appliedn in the correct slots. + */ +function verifyCached(entry) { + var warn = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; + var success = true; + var _iterator4 = maximize_createForOfIteratorHelper(slotStructure), + _step4; + try { + for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) { + var slotGroup = _step4.value; + var desiredSlots = slotGroup.map(slot => { + var _entry$equipment$get; + return [slot, (_entry$equipment$get = entry.equipment.get(slot)) !== null && _entry$equipment$get !== void 0 ? _entry$equipment$get : null]; + }).filter(_ref2 => { + var _ref3 = maximize_slicedToArray(_ref2, 2), + item = _ref3[1]; + return item !== null; + }); + var desiredSet = desiredSlots.map(_ref4 => { + var _ref5 = maximize_slicedToArray(_ref4, 2), + item = _ref5[1]; + return item; + }); + var equippedSet = desiredSlots.map(_ref6 => { + var _ref7 = maximize_slicedToArray(_ref6, 1), + slot = _ref7[0]; + return (0,external_kolmafia_.equippedItem)(slot); + }); + if (!setEqual(desiredSet, equippedSet)) { + if (warn) { + dist_logger.warning("Failed to apply cached ".concat(desiredSet.join(", "), " in ").concat(slotGroup.join(", "), ".")); + } + success = false; + } + } + } catch (err) { + _iterator4.e(err); + } finally { + _iterator4.f(); + } + if ((0,external_kolmafia_.equippedAmount)(template_string_$item(maximize_templateObject24 || (maximize_templateObject24 = maximize_taggedTemplateLiteral(["Crown of Thrones"])))) > 0 && entry.rider.get(template_string_$item(maximize_templateObject25 || (maximize_templateObject25 = maximize_taggedTemplateLiteral(["Crown of Thrones"]))))) { + if (entry.rider.get(template_string_$item(maximize_templateObject26 || (maximize_templateObject26 = maximize_taggedTemplateLiteral(["Crown of Thrones"])))) !== (0,external_kolmafia_.myEnthronedFamiliar)()) { + if (warn) { + dist_logger.warning("Failed to apply ".concat(entry.rider.get(template_string_$item(maximize_templateObject27 || (maximize_templateObject27 = maximize_taggedTemplateLiteral(["Crown of Thrones"])))), " in ").concat(template_string_$item(maximize_templateObject28 || (maximize_templateObject28 = maximize_taggedTemplateLiteral(["Crown of Thrones"]))), ".")); + } + success = false; + } + } + if ((0,external_kolmafia_.equippedAmount)(template_string_$item(maximize_templateObject29 || (maximize_templateObject29 = maximize_taggedTemplateLiteral(["Buddy Bjorn"])))) > 0 && entry.rider.get(template_string_$item(maximize_templateObject30 || (maximize_templateObject30 = maximize_taggedTemplateLiteral(["Buddy Bjorn"]))))) { + if (entry.rider.get(template_string_$item(maximize_templateObject31 || (maximize_templateObject31 = maximize_taggedTemplateLiteral(["Buddy Bjorn"])))) !== (0,external_kolmafia_.myBjornedFamiliar)()) { + if (warn) { + dist_logger.warning("Failed to apply".concat(entry.rider.get(template_string_$item(maximize_templateObject32 || (maximize_templateObject32 = maximize_taggedTemplateLiteral(["Buddy Bjorn"])))), " in ").concat(template_string_$item(maximize_templateObject33 || (maximize_templateObject33 = maximize_taggedTemplateLiteral(["Buddy Bjorn"]))), ".")); + } + success = false; + } + } + return success; +} +/** + * Save current equipment to the objective cache. + * + * @param cacheKey The cache key to save. + * @param options Set of maximizer options + */ +function saveCached(cacheKey, options) { + var equipment = new Map(); + var rider = new Map(); + var _iterator5 = maximize_createForOfIteratorHelper(cachedSlots), + _step5; + try { + for (_iterator5.s(); !(_step5 = _iterator5.n()).done;) { + var _slot2 = _step5.value; + equipment.set(_slot2, (0,external_kolmafia_.equippedItem)(_slot2)); + } + } catch (err) { + _iterator5.e(err); + } finally { + _iterator5.f(); + } + if ((0,external_kolmafia_.equippedAmount)(template_string_$item(maximize_templateObject34 || (maximize_templateObject34 = maximize_taggedTemplateLiteral(["card sleeve"])))) > 0) { + equipment.set($slot(maximize_templateObject35 || (maximize_templateObject35 = maximize_taggedTemplateLiteral(["card-sleeve"]))), (0,external_kolmafia_.equippedItem)($slot(maximize_templateObject36 || (maximize_templateObject36 = maximize_taggedTemplateLiteral(["card-sleeve"]))))); + } + if ((0,external_kolmafia_.equippedAmount)(template_string_$item(maximize_templateObject37 || (maximize_templateObject37 = maximize_taggedTemplateLiteral(["Crown of Thrones"])))) > 0) { + rider.set(template_string_$item(maximize_templateObject38 || (maximize_templateObject38 = maximize_taggedTemplateLiteral(["Crown of Thrones"]))), (0,external_kolmafia_.myEnthronedFamiliar)()); + } + if ((0,external_kolmafia_.equippedAmount)(template_string_$item(maximize_templateObject39 || (maximize_templateObject39 = maximize_taggedTemplateLiteral(["Buddy Bjorn"])))) > 0) { + rider.set(template_string_$item(maximize_templateObject40 || (maximize_templateObject40 = maximize_taggedTemplateLiteral(["Buddy Bjorn"]))), (0,external_kolmafia_.myBjornedFamiliar)()); + } + if (options.preventSlot && options.preventSlot.length > 0) { + var _iterator6 = maximize_createForOfIteratorHelper(options.preventSlot), + _step6; + try { + for (_iterator6.s(); !(_step6 = _iterator6.n()).done;) { + var slot = _step6.value; + equipment.delete(slot); + } + } catch (err) { + _iterator6.e(err); + } finally { + _iterator6.f(); + } + if (options.preventSlot.includes($slot(maximize_templateObject41 || (maximize_templateObject41 = maximize_taggedTemplateLiteral(["buddy-bjorn"]))))) { + rider.delete(template_string_$item(maximize_templateObject42 || (maximize_templateObject42 = maximize_taggedTemplateLiteral(["Buddy Bjorn"])))); + } + if (options.preventSlot.includes($slot(maximize_templateObject43 || (maximize_templateObject43 = maximize_taggedTemplateLiteral(["crown-of-thrones"]))))) { + rider.delete(template_string_$item(maximize_templateObject44 || (maximize_templateObject44 = maximize_taggedTemplateLiteral(["Crown of Thrones"])))); + } + } + if (options.onlySlot && options.onlySlot.length > 0) { + var _iterator7 = maximize_createForOfIteratorHelper(external_kolmafia_.Slot.all()), + _step7; + try { + for (_iterator7.s(); !(_step7 = _iterator7.n()).done;) { + var _slot = _step7.value; + if (!options.onlySlot.includes(_slot)) { + equipment.delete(_slot); + } + } + } catch (err) { + _iterator7.e(err); + } finally { + _iterator7.f(); + } + if (!options.onlySlot.includes($slot(maximize_templateObject45 || (maximize_templateObject45 = maximize_taggedTemplateLiteral(["buddy-bjorn"]))))) { + rider.delete(template_string_$item(_templateObject46 || (_templateObject46 = maximize_taggedTemplateLiteral(["Buddy Bjorn"])))); + } + if (!options.onlySlot.includes($slot(_templateObject47 || (_templateObject47 = maximize_taggedTemplateLiteral(["crown-of-thrones"]))))) { + rider.delete(template_string_$item(_templateObject48 || (_templateObject48 = maximize_taggedTemplateLiteral(["Crown of Thrones"])))); + } + } + var entry = new CacheEntry(equipment, rider, (0,external_kolmafia_.myFamiliar)(), canEquipItemCount(), maximize_objectSpread(maximize_objectSpread({}, getCurrentModes()), options.modes)); + cachedObjectives[cacheKey] = entry; + if (options.useOutfitCaching) { + var outfitName = outfitCache.insert(entry); + dist_logger.info("Saving equipment to outfit ".concat(outfitName, ".")); + saveOutfit(outfitName); + } +} +/** + * Run the maximizer, but only if the objective and certain pieces of game state haven't changed since it was last run. + * + * @param objectives Objectives to maximize for. + * @param options Options for this run of the maximizer. + * @param options.updateOnFamiliarChange Re-run the maximizer if familiar has changed. Default true. + * @param options.updateOnCanEquipChanged Re-run the maximizer if stats have changed what can be equipped. Default true. + * @param options.forceEquip Equipment to force-equip ("equip X"). + * @param options.preventEquip Equipment to prevent equipping ("-equip X"). + * @param options.bonusEquip Equipment to apply a bonus to ("200 bonus X"). + * @returns Whether the maximize call succeeded. + */ +function maximizeCached(objectives) { + var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var fullOptions = mergeMaximizeOptions(defaultMaximizeOptions, options); + var forceEquip = fullOptions.forceEquip, + preventEquip = fullOptions.preventEquip, + bonusEquip = fullOptions.bonusEquip, + onlySlot = fullOptions.onlySlot, + preventSlot = fullOptions.preventSlot, + forceUpdate = fullOptions.forceUpdate; + // Sort each group in objective to ensure consistent ordering in string + var objective = maximize_toConsumableArray(new Set([].concat(maximize_toConsumableArray(objectives.sort()), maximize_toConsumableArray(forceEquip.map(item => "\"equip ".concat(toMaximizerName(item), "\"")).sort()), maximize_toConsumableArray(preventEquip.map(item => "-\"equip ".concat(toMaximizerName(item), "\"")).sort()), maximize_toConsumableArray(onlySlot.map(slot => "".concat(slot)).sort()), maximize_toConsumableArray(preventSlot.map(slot => "-".concat(slot)).sort()), maximize_toConsumableArray(Array.from(bonusEquip.entries()).filter(_ref8 => { + var _ref9 = maximize_slicedToArray(_ref8, 2), + bonus = _ref9[1]; + return bonus !== 0; + }).map(_ref10 => { + var _ref11 = maximize_slicedToArray(_ref10, 2), + item = _ref11[0], + bonus = _ref11[1]; + return "".concat(Math.round(bonus * 100) / 100, " \"bonus ").concat(toMaximizerName(item), "\""); + }).sort())))).join(", "); + // Items equipped in slots not touched by the maximizer must be in the cache key + var untouchedSlots = cachedSlots.filter(slot => preventSlot.includes(slot) || onlySlot.length > 0 && !onlySlot.includes(slot)); + var cacheKey = [objective].concat(maximize_toConsumableArray(untouchedSlots.map(slot => "".concat(slot, ":").concat((0,external_kolmafia_.equippedItem)(slot))).sort()), [have(template_string_$effect(_templateObject49 || (_templateObject49 = maximize_taggedTemplateLiteral(["Offhand Remarkable"]))))]).join("; "); + var cacheEntry = checkCache(cacheKey, fullOptions); + if (cacheEntry && !forceUpdate) { + if (verifyCached(cacheEntry, false)) return true; + dist_logger.info("Equipment found in maximize cache, equipping..."); + applyCached(cacheEntry, fullOptions); + if (verifyCached(cacheEntry)) { + dist_logger.info("Equipped cached ".concat(cacheKey)); + return true; + } + dist_logger.warning("Maximize cache application failed, maximizing..."); + } + var result = (0,external_kolmafia_.maximize)(objective, false); + saveCached(cacheKey, fullOptions); + return result; +} +var _maximizeParameters = /*#__PURE__*/new WeakMap(); +var _maximizeOptions = /*#__PURE__*/new WeakMap(); +var Requirement = /*#__PURE__*/function () { + /** + * A convenient way of combining maximization parameters and options + * + * @param maximizeParameters Parameters you're attempting to maximize + * @param maximizeOptions Object potentially containing forceEquips, bonusEquips, preventEquips, and preventSlots + */ + function Requirement(maximizeParameters, maximizeOptions) { + maximize_classCallCheck(this, Requirement); + _classPrivateFieldInitSpec(this, _maximizeParameters, { + writable: true, + value: void 0 + }); + _classPrivateFieldInitSpec(this, _maximizeOptions, { + writable: true, + value: void 0 + }); + _classPrivateFieldSet(this, _maximizeParameters, maximizeParameters); + _classPrivateFieldSet(this, _maximizeOptions, maximizeOptions); + } + maximize_createClass(Requirement, [{ + key: "maximizeParameters", + get: function get() { + return _classPrivateFieldGet(this, _maximizeParameters); + } + }, { + key: "maximizeOptions", + get: function get() { + return _classPrivateFieldGet(this, _maximizeOptions); + } + /** + * Merges two requirements, concanating relevant arrays. Typically used in static form. + * + * @param other Requirement to merge with. + */ + }, { + key: "merge", + value: function merge(other) { + var _optionsA$forceEquip, _other$maximizeOption, _optionsA$preventEqui, _other$maximizeOption3, _optionsA$bonusEquip$, _optionsA$bonusEquip, _optionsB$bonusEquip$, _optionsB$bonusEquip, _optionsA$onlySlot, _optionsB$onlySlot, _optionsA$preventSlot, _optionsB$preventSlot; + var optionsA = this.maximizeOptions; + var optionsB = other.maximizeOptions; + return new Requirement([].concat(maximize_toConsumableArray(this.maximizeParameters), maximize_toConsumableArray(other.maximizeParameters)), { + updateOnFamiliarChange: optionsA.updateOnFamiliarChange || other.maximizeOptions.updateOnFamiliarChange, + updateOnCanEquipChanged: optionsA.updateOnCanEquipChanged || other.maximizeOptions.updateOnCanEquipChanged, + forceEquip: [].concat(maximize_toConsumableArray((_optionsA$forceEquip = optionsA.forceEquip) !== null && _optionsA$forceEquip !== void 0 ? _optionsA$forceEquip : []), maximize_toConsumableArray((_other$maximizeOption = other.maximizeOptions.forceEquip) !== null && _other$maximizeOption !== void 0 ? _other$maximizeOption : [])).filter(x => { + var _other$maximizeOption2; + return !((_other$maximizeOption2 = other.maximizeOptions.preventEquip) !== null && _other$maximizeOption2 !== void 0 && _other$maximizeOption2.includes(x)); + }), + preventEquip: [].concat(maximize_toConsumableArray((_optionsA$preventEqui = optionsA.preventEquip) !== null && _optionsA$preventEqui !== void 0 ? _optionsA$preventEqui : []), maximize_toConsumableArray((_other$maximizeOption3 = other.maximizeOptions.preventEquip) !== null && _other$maximizeOption3 !== void 0 ? _other$maximizeOption3 : [])).filter(x => { + var _other$maximizeOption4; + return !((_other$maximizeOption4 = other.maximizeOptions.forceEquip) !== null && _other$maximizeOption4 !== void 0 && _other$maximizeOption4.includes(x)); + }), + bonusEquip: new Map([].concat(maximize_toConsumableArray((_optionsA$bonusEquip$ = (_optionsA$bonusEquip = optionsA.bonusEquip) === null || _optionsA$bonusEquip === void 0 ? void 0 : _optionsA$bonusEquip.entries()) !== null && _optionsA$bonusEquip$ !== void 0 ? _optionsA$bonusEquip$ : []), maximize_toConsumableArray((_optionsB$bonusEquip$ = (_optionsB$bonusEquip = optionsB.bonusEquip) === null || _optionsB$bonusEquip === void 0 ? void 0 : _optionsB$bonusEquip.entries()) !== null && _optionsB$bonusEquip$ !== void 0 ? _optionsB$bonusEquip$ : []))), + onlySlot: [].concat(maximize_toConsumableArray((_optionsA$onlySlot = optionsA.onlySlot) !== null && _optionsA$onlySlot !== void 0 ? _optionsA$onlySlot : []), maximize_toConsumableArray((_optionsB$onlySlot = optionsB.onlySlot) !== null && _optionsB$onlySlot !== void 0 ? _optionsB$onlySlot : [])), + preventSlot: [].concat(maximize_toConsumableArray((_optionsA$preventSlot = optionsA.preventSlot) !== null && _optionsA$preventSlot !== void 0 ? _optionsA$preventSlot : []), maximize_toConsumableArray((_optionsB$preventSlot = optionsB.preventSlot) !== null && _optionsB$preventSlot !== void 0 ? _optionsB$preventSlot : [])), + forceUpdate: optionsA.forceUpdate || optionsB.forceUpdate + }); + } + /** + * Merges a set of requirements together, starting with an empty requirement. + * + * @param allRequirements Requirements to merge + * @returns Merged requirements + */ + }, { + key: "maximize", + value: + /** + * Runs maximizeCached, using the maximizeParameters and maximizeOptions contained by this requirement. + * + * @returns Whether the maximize call succeeded. + */ + function maximize() { + return maximizeCached(this.maximizeParameters, this.maximizeOptions); + } + /** + * Merges requirements, and then runs maximizeCached on the combined requirement. + * + * @param requirements Requirements to maximize on + */ + }], [{ + key: "merge", + value: function merge(allRequirements) { + return allRequirements.reduce((x, y) => x.merge(y), new Requirement([], {})); + } + }, { + key: "maximize", + value: function maximize() { + for (var _len = arguments.length, requirements = new Array(_len), _key = 0; _key < _len; _key++) { + requirements[_key] = arguments[_key]; + } + Requirement.merge(requirements).maximize(); + } + }]); + return Requirement; +}(); +/** + * Clear all outfits cached by the maximizer. + */ +function clearMaximizerCache() { + outfitCache.clear(); + for (var member in cachedObjectives) delete cachedObjectives[member]; +} +;// CONCATENATED MODULE: ./node_modules/grimoire-kolmafia/dist/outfit.js +var outfit_templateObject, outfit_templateObject2, outfit_templateObject3, outfit_templateObject4, outfit_templateObject5, outfit_templateObject6, outfit_templateObject7, outfit_templateObject8, outfit_templateObject9, outfit_templateObject10, outfit_templateObject11, outfit_templateObject12, outfit_templateObject13, outfit_templateObject14, outfit_templateObject15, outfit_templateObject16, outfit_templateObject17, outfit_templateObject18, outfit_templateObject19, outfit_templateObject20, outfit_templateObject21, outfit_templateObject22, outfit_templateObject23, outfit_templateObject24, outfit_templateObject25, outfit_templateObject26, outfit_templateObject27, outfit_templateObject28, outfit_templateObject29, outfit_templateObject30, outfit_templateObject31, outfit_templateObject32, outfit_templateObject33, outfit_templateObject34, outfit_templateObject35, outfit_templateObject36, outfit_templateObject37, outfit_templateObject38, outfit_templateObject39, outfit_templateObject40, outfit_templateObject41, outfit_templateObject42, outfit_templateObject43, outfit_templateObject44, outfit_templateObject45, outfit_templateObject46, outfit_templateObject47, outfit_templateObject48, outfit_templateObject49, _templateObject50, _templateObject51, _templateObject52, _templateObject53, _templateObject54, _templateObject55, _templateObject56, _templateObject57, _templateObject58, _templateObject59, _templateObject60, _templateObject61, _templateObject62, _templateObject63, _templateObject64, _templateObject65, _templateObject66, _templateObject67; +function outfit_ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function outfit_objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? outfit_ownKeys(Object(t), !0).forEach(function (r) { outfit_defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : outfit_ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +function outfit_defineProperty(obj, key, value) { key = outfit_toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function outfit_slicedToArray(arr, i) { return outfit_arrayWithHoles(arr) || outfit_iterableToArrayLimit(arr, i) || outfit_unsupportedIterableToArray(arr, i) || outfit_nonIterableRest(); } +function outfit_nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function outfit_iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } +function outfit_arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } +function outfit_createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = outfit_unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; } +function outfit_taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); } +function outfit_toConsumableArray(arr) { return outfit_arrayWithoutHoles(arr) || outfit_iterableToArray(arr) || outfit_unsupportedIterableToArray(arr) || outfit_nonIterableSpread(); } +function outfit_nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function outfit_unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return outfit_arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return outfit_arrayLikeToArray(o, minLen); } +function outfit_iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); } +function outfit_arrayWithoutHoles(arr) { if (Array.isArray(arr)) return outfit_arrayLikeToArray(arr); } +function outfit_arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } +function outfit_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } +function outfit_defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, outfit_toPropertyKey(descriptor.key), descriptor); } } +function outfit_createClass(Constructor, protoProps, staticProps) { if (protoProps) outfit_defineProperties(Constructor.prototype, protoProps); if (staticProps) outfit_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } +function outfit_toPropertyKey(arg) { var key = outfit_toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); } +function outfit_toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } + + +var FORCE_REFRESH_REQUIREMENT = new Requirement([], { + forceUpdate: true +}); +var outfitSlots = ["hat", "back", "weapon", "offhand", "shirt", "pants", "acc1", "acc2", "acc3", "famequip"]; +var riderSlots = (/* unused pure expression or super */ null && (["buddy-bjorn", "crown-of-thrones"])); +var weaponHands = i => i ? (0,external_kolmafia_.weaponHands)(i) : 0; +var outfit_modeableCommands = ["backupcamera", "umbrella", "snowsuit", "edpiece", "retrocape", "parka"]; +var Outfit = /*#__PURE__*/function () { + function Outfit() { + outfit_classCallCheck(this, Outfit); + this.equips = new Map(); + this.riders = new Map(); + this.modes = {}; + this.skipDefaults = false; + this.modifier = []; + this.avoid = []; + this.bonuses = new Map(); + this.postActions = []; + this.preActions = []; + } + /** + * Create an outfit from your current player state. + */ + outfit_createClass(Outfit, [{ + key: "equippedAmount", + value: + /** + * Check how many of an item is equipped on the outfit. + */ + function equippedAmount(item) { + return outfit_toConsumableArray(this.equips.values()).filter(i => i === item).length; + } + }, { + key: "isAvailable", + value: function isAvailable(item) { + var _a; + if ((_a = this.avoid) === null || _a === void 0 ? void 0 : _a.includes(item)) return false; + if (!have(item, this.equippedAmount(item) + 1)) return false; + if ((0,external_kolmafia_.booleanModifier)(item, "Single Equip") && this.equippedAmount(item) > 0) return false; + return true; + } + /** + * Check whether an item is equipped on the outfit, optionally in a specific slot. + */ + }, { + key: "haveEquipped", + value: function haveEquipped(item, slot) { + if (slot === undefined) return this.equippedAmount(item) > 0; + return this.equips.get(slot) === item; + } + }, { + key: "equipItemNone", + value: function equipItemNone(item, slot) { + if (item !== template_string_$item.none) return false; + if (slot === undefined) return true; + if (this.equips.has(slot)) return false; + this.equips.set(slot, item); + return true; + } + }, { + key: "equipNonAccessory", + value: function equipNonAccessory(item, slot) { + if ($slots(outfit_templateObject || (outfit_templateObject = outfit_taggedTemplateLiteral(["acc1, acc2, acc3"]))).includes((0,external_kolmafia_.toSlot)(item))) return false; + if (slot !== undefined && slot !== (0,external_kolmafia_.toSlot)(item)) return false; + if (this.equips.has((0,external_kolmafia_.toSlot)(item))) return false; + switch ((0,external_kolmafia_.toSlot)(item)) { + case $slot(outfit_templateObject2 || (outfit_templateObject2 = outfit_taggedTemplateLiteral(["off-hand"]))): + if (this.equips.has($slot(outfit_templateObject3 || (outfit_templateObject3 = outfit_taggedTemplateLiteral(["weapon"])))) && weaponHands(this.equips.get($slot(outfit_templateObject4 || (outfit_templateObject4 = outfit_taggedTemplateLiteral(["weapon"]))))) !== 1) { + return false; + } + break; + case $slot(outfit_templateObject5 || (outfit_templateObject5 = outfit_taggedTemplateLiteral(["familiar"]))): + if (this.familiar !== undefined && !(0,external_kolmafia_.canEquip)(this.familiar, item)) return false; + } + if ((0,external_kolmafia_.toSlot)(item) !== $slot(outfit_templateObject6 || (outfit_templateObject6 = outfit_taggedTemplateLiteral(["familiar"]))) && !(0,external_kolmafia_.canEquip)(item)) return false; + this.equips.set((0,external_kolmafia_.toSlot)(item), item); + return true; + } + }, { + key: "equipAccessory", + value: function equipAccessory(item, slot) { + if (![undefined].concat(outfit_toConsumableArray($slots(outfit_templateObject7 || (outfit_templateObject7 = outfit_taggedTemplateLiteral(["acc1, acc2, acc3"]))))).includes(slot)) return false; + if ((0,external_kolmafia_.toSlot)(item) !== $slot(outfit_templateObject8 || (outfit_templateObject8 = outfit_taggedTemplateLiteral(["acc1"])))) return false; + if (!(0,external_kolmafia_.canEquip)(item)) return false; + if (slot === undefined) { + // We don't care which of the accessory slots we equip in + var empty = $slots(outfit_templateObject9 || (outfit_templateObject9 = outfit_taggedTemplateLiteral(["acc1, acc2, acc3"]))).find(s => !this.equips.has(s)); + if (empty === undefined) return false; + this.equips.set(empty, item); + } else { + if (this.equips.has(slot)) return false; + this.equips.set(slot, item); + } + return true; + } + }, { + key: "equipUsingDualWield", + value: function equipUsingDualWield(item, slot) { + if (![undefined, $slot(outfit_templateObject10 || (outfit_templateObject10 = outfit_taggedTemplateLiteral(["off-hand"])))].includes(slot)) return false; + if ((0,external_kolmafia_.toSlot)(item) !== $slot(outfit_templateObject11 || (outfit_templateObject11 = outfit_taggedTemplateLiteral(["weapon"])))) return false; + if (this.equips.has($slot(outfit_templateObject12 || (outfit_templateObject12 = outfit_taggedTemplateLiteral(["weapon"])))) && weaponHands(this.equips.get($slot(outfit_templateObject13 || (outfit_templateObject13 = outfit_taggedTemplateLiteral(["weapon"]))))) !== 1) { + return false; + } + if (this.equips.has($slot(outfit_templateObject14 || (outfit_templateObject14 = outfit_taggedTemplateLiteral(["off-hand"]))))) return false; + if (!have(template_string_$skill(outfit_templateObject15 || (outfit_templateObject15 = outfit_taggedTemplateLiteral(["Double-Fisted Skull Smashing"]))))) return false; + if (weaponHands(item) !== 1) return false; + if (!(0,external_kolmafia_.canEquip)(item)) return false; + this.equips.set($slot(outfit_templateObject16 || (outfit_templateObject16 = outfit_taggedTemplateLiteral(["off-hand"]))), item); + return true; + } + }, { + key: "getHoldingFamiliar", + value: function getHoldingFamiliar(item) { + switch ((0,external_kolmafia_.toSlot)(item)) { + case $slot(outfit_templateObject17 || (outfit_templateObject17 = outfit_taggedTemplateLiteral(["weapon"]))): + return template_string_$familiar(outfit_templateObject18 || (outfit_templateObject18 = outfit_taggedTemplateLiteral(["Disembodied Hand"]))); + case $slot(outfit_templateObject19 || (outfit_templateObject19 = outfit_taggedTemplateLiteral(["off-hand"]))): + return template_string_$familiar(outfit_templateObject20 || (outfit_templateObject20 = outfit_taggedTemplateLiteral(["Left-Hand Man"]))); + default: + return undefined; + } + } + /** + * Returns the bonus value associated with a given item. + * + * @param item The item to check the bonus of. + * @returns The bonus assigned to that item. + */ + }, { + key: "getBonus", + value: function getBonus(item) { + var _a; + return (_a = this.bonuses.get(item)) !== null && _a !== void 0 ? _a : 0; + } + /** + * Applies a value to any existing bonus this item has, using a rule assigned by the `reducer` parameter + * + * @param item The item to try to apply a bonus to. + * @param value The value to try to apply. + * @param reducer Function that combines new and current bonus + * @returns The total assigned bonus to that item. + */ + }, { + key: "applyBonus", + value: function applyBonus(item, value, reducer) { + var previous = this.getBonus(item); + return this.setBonus(item, reducer(value, previous)); + } + /** + * Sets the bonus value of an item equal to a given value, overriding any current bonus assigned. + * + * @param item The item to try to apply a bonus to. + * @param value The value to try to apply. + * @returns The total assigned bonus to that item. + */ + }, { + key: "setBonus", + value: function setBonus(item, value) { + this.bonuses.set(item, value); + return value; + } + /** + * Adds a value to any existing bonus this item has + * + * @param item The item to try to add a bonus to. + * @param value The value to try to add. + * @returns The total assigned bonus to that item. + */ + }, { + key: "addBonus", + value: function addBonus(item, value) { + return this.applyBonus(item, value, (a, b) => a + b); + } + /** + * Apply the given items' bonuses to the outfit, using a rule given by the reducer + * + * @param items A map containing items and their bonuses + * @param reducer A way of combining new bonuses with existing bonuses + */ + }, { + key: "applyBonuses", + value: function applyBonuses(items, reducer) { + var _iterator = outfit_createForOfIteratorHelper(items), + _step; + try { + for (_iterator.s(); !(_step = _iterator.n()).done;) { + var _step$value = outfit_slicedToArray(_step.value, 2), + item = _step$value[0], + value = _step$value[1]; + this.applyBonus(item, value, reducer); + } + } catch (err) { + _iterator.e(err); + } finally { + _iterator.f(); + } + } + /** + * Sets the bonuses of the given items, overriding existing bonuses + * + * @param items Map containing items and bonuses + */ + }, { + key: "setBonuses", + value: function setBonuses(items) { + this.applyBonuses(items, a => a); + } + /** + * Adds the bonuses of the given items to any existing bonuses they ahave + * + * @param items Map containing items and bonuses + */ + }, { + key: "addBonuses", + value: function addBonuses(items) { + this.applyBonuses(items, (a, b) => a + b); + } + }, { + key: "equipUsingFamiliar", + value: function equipUsingFamiliar(item, slot) { + if (![undefined, $slot(outfit_templateObject21 || (outfit_templateObject21 = outfit_taggedTemplateLiteral(["familiar"])))].includes(slot)) return false; + if (this.equips.has($slot(outfit_templateObject22 || (outfit_templateObject22 = outfit_taggedTemplateLiteral(["familiar"]))))) return false; + if ((0,external_kolmafia_.booleanModifier)(item, "Single Equip")) return false; + var familiar = this.getHoldingFamiliar(item); + if (familiar === undefined || !this.equip(familiar)) return false; + this.equips.set($slot(outfit_templateObject23 || (outfit_templateObject23 = outfit_taggedTemplateLiteral(["familiar"]))), item); + return true; + } + }, { + key: "equipItem", + value: function equipItem(item, slot) { + return this.haveEquipped(item, slot) || this.equipItemNone(item, slot) || this.isAvailable(item) && (this.equipNonAccessory(item, slot) || this.equipAccessory(item, slot) || this.equipUsingDualWield(item, slot) || this.equipUsingFamiliar(item, slot)); + } + }, { + key: "equipFamiliar", + value: function equipFamiliar(familiar) { + if (familiar === this.familiar) return true; + if (this.familiar !== undefined) return false; + if (familiar !== template_string_$familiar.none) { + if (!have(familiar)) return false; + if (Array.from(this.riders.values()).includes(familiar)) return false; + } + var item = this.equips.get($slot(outfit_templateObject24 || (outfit_templateObject24 = outfit_taggedTemplateLiteral(["familiar"])))); + if (item !== undefined && item !== template_string_$item.none && !(0,external_kolmafia_.canEquip)(familiar, item)) return false; + this.familiar = familiar; + return true; + } + }, { + key: "equipSpec", + value: function equipSpec(spec) { + var _this$avoid; + var _a, _b, _c, _d, _e, _f; + var succeeded = true; + for (var _i = 0, _outfitSlots = outfitSlots; _i < _outfitSlots.length; _i++) { + var slotName = _outfitSlots[_i]; + var slot = (_a = new Map([["famequip", $slot(outfit_templateObject25 || (outfit_templateObject25 = outfit_taggedTemplateLiteral(["familiar"])))], ["offhand", $slot(outfit_templateObject26 || (outfit_templateObject26 = outfit_taggedTemplateLiteral(["off-hand"])))]]).get(slotName)) !== null && _a !== void 0 ? _a : (0,external_kolmafia_.toSlot)(slotName); + var itemOrItems = spec[slotName]; + if (itemOrItems !== undefined && !this.equip(itemOrItems, slot)) succeeded = false; + } + var _iterator2 = outfit_createForOfIteratorHelper((_b = spec === null || spec === void 0 ? void 0 : spec.equip) !== null && _b !== void 0 ? _b : []), + _step2; + try { + for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) { + var item = _step2.value; + if (!this.equip(item)) succeeded = false; + } + } catch (err) { + _iterator2.e(err); + } finally { + _iterator2.f(); + } + if ((spec === null || spec === void 0 ? void 0 : spec.familiar) !== undefined) { + if (!this.equip(spec.familiar)) succeeded = false; + } + (_this$avoid = this.avoid).push.apply(_this$avoid, outfit_toConsumableArray((_c = spec === null || spec === void 0 ? void 0 : spec.avoid) !== null && _c !== void 0 ? _c : [])); + this.skipDefaults = this.skipDefaults || ((_d = spec.skipDefaults) !== null && _d !== void 0 ? _d : false); + if (spec.modifier) { + var _this$modifier; + if (Array.isArray(spec.modifier)) (_this$modifier = this.modifier).push.apply(_this$modifier, outfit_toConsumableArray(spec.modifier));else this.modifier.push(spec.modifier); + } + if (spec.modes) { + if (!this.setModes(spec.modes)) { + succeeded = false; + } + } + if (spec.riders) { + if (spec.riders["buddy-bjorn"] && !this.bjornify(spec.riders["buddy-bjorn"])) succeeded = false; + if (spec.riders["crown-of-thrones"] && !this.enthrone(spec.riders["crown-of-thrones"])) succeeded = false; + } + if (spec.bonuses) { + this.addBonuses(spec.bonuses); + } + this.beforeDress.apply(this, outfit_toConsumableArray((_e = spec.beforeDress) !== null && _e !== void 0 ? _e : [])); + this.afterDress.apply(this, outfit_toConsumableArray((_f = spec.afterDress) !== null && _f !== void 0 ? _f : [])); + return succeeded; + } + /** + * Equip the first thing that can be equipped to the outfit. + * + * @param things The things to equip. + * @param slot The slot to equip them. + * @returns True if one of the things is equipped, and false otherwise. + */ + }, { + key: "equipFirst", + value: function equipFirst(things, slot) { + // some() returns false on an empty array, yet every() returns true. + // This keeps behavior consistent between slotful and slotless equipping. + if (things.length === 0) return true; + return things.some(val => this.equip(val, slot)); + } + /** + * Equip a thing to the outfit. + * + * If no slot is given, then the thing will be equipped wherever possible + * (possibly using dual-wielding, any of the accessory slots, or as + * familiar equipment). If it is impossible to add this thing anywhere to + * the outfit, this function will return false. + * + * If a slot is given, the item will be equipped only in that slot. If the + * slot is filled with a different item, this function will return false. + * + * If the thing is already equipped in the provided slot, or if no slot is + * given and the thing is already equipped in any slot, this function will + * return true and not change the outfit. + * + * @param thing The thing or things to equip. + * @param slot The slot to equip them. + * @returns True if the thing was sucessfully equipped, and false otherwise. + */ + }, { + key: "equip", + value: function equip(thing, slot) { + if (Array.isArray(thing)) { + if (slot !== undefined) return this.equipFirst(thing, slot); + return thing.every(val => this.equip(val)); + } + if (thing instanceof external_kolmafia_.Item) return this.equipItem(thing, slot); + if (thing instanceof external_kolmafia_.Familiar) return this.equipFamiliar(thing); + if (thing instanceof Outfit) return this.equipSpec(thing.spec()); + return this.equipSpec(thing); + } + }, { + key: "bjornify", + value: + /** + * Add a bjornified familiar to the outfit. + * + * This function does *not* equip the buddy bjorn itself; it must be equipped separately. + * + * If a familiar is already specified for the buddy bjorn that is different from the provided target, this function will return false and not change the buddy bjorn. + * @param target The familiar to bjornify, or a ranked list of familiars to try to bjornify. + * @returns True if we successfully set the bjorn to a valid target. + */ + function bjornify(target) { + var current = this.riders.get($slot(outfit_templateObject27 || (outfit_templateObject27 = outfit_taggedTemplateLiteral(["buddy-bjorn"])))); + if (current) { + if (Array.isArray(target) ? target.includes(current) : current === target) { + return true; + } + return false; + } + if (Array.isArray(target)) { + var fam = target.find(f => have(f) && this.familiar !== f && this.riders.get($slot(outfit_templateObject28 || (outfit_templateObject28 = outfit_taggedTemplateLiteral(["crown-of-thrones"])))) !== f); + if (fam) { + this.riders.set($slot(outfit_templateObject29 || (outfit_templateObject29 = outfit_taggedTemplateLiteral(["buddy-bjorn"]))), fam); + return true; + } + return false; + } else { + if (have(target) && this.familiar !== target && !Array.from(this.riders.values()).includes(target)) { + this.riders.set($slot(outfit_templateObject30 || (outfit_templateObject30 = outfit_taggedTemplateLiteral(["buddy-bjorn"]))), target); + return true; + } + return false; + } + } + /** + * Add anenthroned familiar to the outfit. + * + * This function does *not* equip the crown of thrones itself; it must be equipped separately. + * + * If a familiar is already specified for the crown of thrones that is different from the provided target, this function will return false and not change the crown of thrones. + * @param target The familiar to enthrone, or a ranked list of familiars to try to enthrone. + * @returns True if we successfully set the enthrone to a valid target. + */ + }, { + key: "enthrone", + value: function enthrone(target) { + var current = this.riders.get($slot(outfit_templateObject31 || (outfit_templateObject31 = outfit_taggedTemplateLiteral(["crown-of-thrones"])))); + if (current) { + if (Array.isArray(target) ? target.includes(current) : current === target) { + return true; + } + return false; + } + if (Array.isArray(target)) { + var fam = target.find(f => have(f) && this.familiar !== f && this.riders.get($slot(outfit_templateObject32 || (outfit_templateObject32 = outfit_taggedTemplateLiteral(["buddy-bjorn"])))) !== f); + if (fam) { + this.riders.set($slot(outfit_templateObject33 || (outfit_templateObject33 = outfit_taggedTemplateLiteral(["crown-of-thrones"]))), fam); + return true; + } + return false; + } else { + if (have(target) && this.familiar !== target && !Array.from(this.riders.values()).includes(target)) { + this.riders.set($slot(outfit_templateObject34 || (outfit_templateObject34 = outfit_taggedTemplateLiteral(["crown-of-thrones"]))), target); + return true; + } + return false; + } + } + /** + * Set the provided modes for items that may be equipped in the outfit. + * + * This function does *not* equip items for the set modes; they must be + * equipped separately. + * + * If a mode is already set for an item that is different from the provided + * mode, this function will return false and not change the mode for that + * item. (But other modes might still be changed if they are compatible.) + * + * Note that the superhero and instuctions of a retrocape can be set + * independently (`undefined` is treated as "don't care"). + * + * @param modes Modes to set in this outfit. + * @returns True if all modes were sucessfully set, and false otherwise. + */ + }, { + key: "setModes", + value: function setModes(modes) { + var _a, _b; + var compatible = true; + // Check if the new modes are compatible with existing modes + for (var _i2 = 0, _modeableCommands = outfit_modeableCommands; _i2 < _modeableCommands.length; _i2++) { + var mode = _modeableCommands[_i2]; + if (mode === "retrocape") continue; // checked below + if (this.modes[mode] && modes[mode] && this.modes[mode] !== modes[mode]) { + compatible = false; + } + } + // Check if retrocape modes are compatible + // (Parts that are undefined are compatible with everything) + if (this.modes["retrocape"] && modes["retrocape"]) { + if (this.modes["retrocape"][0] && modes["retrocape"][0] && this.modes["retrocape"][0] !== modes["retrocape"][0]) { + compatible = false; + } + if (this.modes["retrocape"][1] && modes["retrocape"][1] && this.modes["retrocape"][1] !== modes["retrocape"][1]) { + compatible = false; + } + this.modes["retrocape"][0] = (_a = this.modes["retrocape"][0]) !== null && _a !== void 0 ? _a : modes["retrocape"][0]; + this.modes["retrocape"][1] = (_b = this.modes["retrocape"][1]) !== null && _b !== void 0 ? _b : modes["retrocape"][1]; + } + this.modes = outfit_objectSpread(outfit_objectSpread({}, modes), this.modes); + return compatible; + } + /** + * Check if it is possible to equip a thing to this outfit using .equip(). + * + * This does not change the current outfit. + * + * @param thing The thing to equip. + * @param slot The slot to equip them. + * @returns True if this thing can be equipped. + */ + }, { + key: "canEquip", + value: function canEquip(thing, slot) { + var outfit = this.clone(); + return outfit.equip(thing, slot); + } + /** + * Check if it is possible to equip a thing to this outfit using .equip(); if it is, do so. + * + * This does change the current outfit. + * @param thing The thing to equip. + * @param slot The slot to equip them. + * @returns True if this thing was successfully equipped. + */ + }, { + key: "tryEquip", + value: function tryEquip(thing, slot) { + return this.canEquip(thing, slot) && this.equip(thing, slot); + } + }, { + key: "afterDress", + value: function afterDress() { + var _this$postActions; + (_this$postActions = this.postActions).push.apply(_this$postActions, arguments); + } + }, { + key: "beforeDress", + value: function beforeDress() { + var _this$preActions; + (_this$preActions = this.preActions).push.apply(_this$preActions, arguments); + } + /** + * Equip this outfit. + */ + }, { + key: "_dress", + value: function _dress(refreshed) { + if (this.familiar) (0,external_kolmafia_.useFamiliar)(this.familiar); + var targetEquipment = Array.from(this.equips.values()); + var usedSlots = new Set(); + // First, we equip non-accessory equipment. + var nonaccessorySlots = $slots(outfit_templateObject35 || (outfit_templateObject35 = outfit_taggedTemplateLiteral(["weapon, off-hand, hat, back, shirt, pants, familiar"]))); + var bjorn = this.riders.get($slot(outfit_templateObject36 || (outfit_templateObject36 = outfit_taggedTemplateLiteral(["buddy-bjorn"])))); + if (bjorn && (this.equips.get($slot(outfit_templateObject37 || (outfit_templateObject37 = outfit_taggedTemplateLiteral(["back"])))) === template_string_$item(outfit_templateObject38 || (outfit_templateObject38 = outfit_taggedTemplateLiteral(["Buddy Bjorn"]))) || this.getBonus(template_string_$item(outfit_templateObject39 || (outfit_templateObject39 = outfit_taggedTemplateLiteral(["Buddy Bjorn"])))))) { + usedSlots.add($slot(outfit_templateObject40 || (outfit_templateObject40 = outfit_taggedTemplateLiteral(["buddy-bjorn"])))); + usedSlots.add($slot(outfit_templateObject41 || (outfit_templateObject41 = outfit_taggedTemplateLiteral(["crown-of-thrones"])))); + } + var crown = this.riders.get($slot(outfit_templateObject42 || (outfit_templateObject42 = outfit_taggedTemplateLiteral(["crown-of-thrones"])))); + if (crown && (this.equips.get($slot(outfit_templateObject43 || (outfit_templateObject43 = outfit_taggedTemplateLiteral(["hat"])))) === template_string_$item(outfit_templateObject44 || (outfit_templateObject44 = outfit_taggedTemplateLiteral(["Crown of Thrones"]))) || this.getBonus(template_string_$item(outfit_templateObject45 || (outfit_templateObject45 = outfit_taggedTemplateLiteral(["Crown of Thrones"])))))) { + usedSlots.add($slot(outfit_templateObject46 || (outfit_templateObject46 = outfit_taggedTemplateLiteral(["buddy-bjorn"])))); + usedSlots.add($slot(outfit_templateObject47 || (outfit_templateObject47 = outfit_taggedTemplateLiteral(["crown-of-thrones"])))); + } + // We must manually remove equipment that we want to use in a different + // slot than where it is currently equipped, to avoid a mafia issue. + // Order is anchored here to prevent DFSS shenanigans + var _iterator3 = outfit_createForOfIteratorHelper(nonaccessorySlots), + _step3; + try { + for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) { + var slot = _step3.value; + if (targetEquipment.includes((0,external_kolmafia_.equippedItem)(slot)) && this.equips.get(slot) !== (0,external_kolmafia_.equippedItem)(slot) || this.avoid.includes((0,external_kolmafia_.equippedItem)(slot)) || slot === $slot(_templateObject55 || (_templateObject55 = outfit_taggedTemplateLiteral(["weapon"]))) && weaponHands((0,external_kolmafia_.equippedItem)(slot)) !== 1 && this.equips.has($slot(_templateObject56 || (_templateObject56 = outfit_taggedTemplateLiteral(["offhand"])))) && !this.equips.has($slot(_templateObject57 || (_templateObject57 = outfit_taggedTemplateLiteral(["weapon"]))))) (0,external_kolmafia_.equip)(slot, template_string_$item.none); + } + // Then we equip all the non-accessory equipment. + } catch (err) { + _iterator3.e(err); + } finally { + _iterator3.f(); + } + var _iterator4 = outfit_createForOfIteratorHelper(nonaccessorySlots), + _step4; + try { + for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) { + var _slot = _step4.value; + var equipment = this.equips.get(_slot); + if (equipment) { + (0,external_kolmafia_.equip)(_slot, equipment); + usedSlots.add(_slot); + } + } + // Next, we equip accessories + } catch (err) { + _iterator4.e(err); + } finally { + _iterator4.f(); + } + var accessorySlots = $slots(outfit_templateObject48 || (outfit_templateObject48 = outfit_taggedTemplateLiteral(["acc1, acc2, acc3"]))); + var accessoryEquips = accessorySlots.map(slot => this.equips.get(slot)).filter(item => item !== undefined); + // To plan how to equip accessories, first check which accessories are + // already equipped in some accessory slot. There is no need to move them, + // since KoL doesn't care what order accessories are equipped in. + var missingAccessories = []; // accessories that are not already equipped + var _iterator5 = outfit_createForOfIteratorHelper(accessoryEquips), + _step5; + try { + var _loop = function _loop() { + var accessory = _step5.value; + var alreadyEquipped = accessorySlots.find(slot => !usedSlots.has(slot) && (0,external_kolmafia_.equippedItem)(slot) === accessory); + if (alreadyEquipped) { + usedSlots.add(alreadyEquipped); + } else { + missingAccessories.push(accessory); + } + }; + for (_iterator5.s(); !(_step5 = _iterator5.n()).done;) { + _loop(); + } + // Then, for all accessories that are not currently equipped, use the first + // open slot to place them. + } catch (err) { + _iterator5.e(err); + } finally { + _iterator5.f(); + } + for (var _i3 = 0, _missingAccessories = missingAccessories; _i3 < _missingAccessories.length; _i3++) { + var accessory = _missingAccessories[_i3]; + var unusedSlot = accessorySlots.find(slot => !usedSlots.has(slot)); + if (unusedSlot === undefined) { + // This should only occur if there is a bug in .dress() + throw "No accessory slots remaining"; + } + (0,external_kolmafia_.equip)(unusedSlot, accessory); + usedSlots.add(unusedSlot); + } + // Remaining slots are filled by the maximizer + var modes = convertToLibramModes(this.modes); + if (this.modifier.length > 0) { + var allRequirements = [new Requirement(this.modifier, { + preventSlot: outfit_toConsumableArray(usedSlots), + preventEquip: this.avoid, + modes: modes, + bonusEquip: this.bonuses + })]; + if (refreshed) allRequirements.push(FORCE_REFRESH_REQUIREMENT); + if (!Requirement.merge(allRequirements).maximize()) { + if (!refreshed) { + (0,external_kolmafia_.cliExecute)("refresh inventory"); + this._dress(true); + return; + } else throw new Error("Failed to maximize properly!"); + } + (0,external_kolmafia_.logprint)("Maximize: ".concat(this.modifier)); + } + // Set the modes of any equipped items. + applyModes(modes); + // Handle the rider slots next + if (bjorn && (0,external_kolmafia_.haveEquipped)(template_string_$item(outfit_templateObject49 || (outfit_templateObject49 = outfit_taggedTemplateLiteral(["Buddy Bjorn"]))))) { + if ((0,external_kolmafia_.myEnthronedFamiliar)() === bjorn) (0,external_kolmafia_.enthroneFamiliar)(template_string_$familiar.none); + if ((0,external_kolmafia_.myBjornedFamiliar)() !== bjorn) (0,external_kolmafia_.bjornifyFamiliar)(bjorn); + } + if (crown && (0,external_kolmafia_.haveEquipped)(template_string_$item(_templateObject50 || (_templateObject50 = outfit_taggedTemplateLiteral(["Crown of Thrones"]))))) { + if ((0,external_kolmafia_.myBjornedFamiliar)() === crown) (0,external_kolmafia_.bjornifyFamiliar)(template_string_$familiar.none); + if ((0,external_kolmafia_.myEnthronedFamiliar)() !== crown) (0,external_kolmafia_.enthroneFamiliar)(crown); + } + // Verify that all equipment was indeed equipped + if (this.familiar !== undefined && (0,external_kolmafia_.myFamiliar)() !== this.familiar) throw "Failed to fully dress (expected: familiar ".concat(this.familiar, ")"); + var _iterator6 = outfit_createForOfIteratorHelper(nonaccessorySlots), + _step6; + try { + for (_iterator6.s(); !(_step6 = _iterator6.n()).done;) { + var _slot2 = _step6.value; + if (this.equips.has(_slot2) && (0,external_kolmafia_.equippedItem)(_slot2) !== this.equips.get(_slot2)) { + throw "Failed to fully dress (expected: ".concat(_slot2, " ").concat(this.equips.get(_slot2), ")"); + } + } + } catch (err) { + _iterator6.e(err); + } finally { + _iterator6.f(); + } + var _iterator7 = outfit_createForOfIteratorHelper(accessoryEquips), + _step7; + try { + var _loop2 = function _loop2() { + var accessory = _step7.value; + if ((0,external_kolmafia_.equippedAmount)(accessory) < accessoryEquips.filter(acc => acc === accessory).length) { + throw "Failed to fully dress (expected: acc ".concat(accessory, ")"); + } + }; + for (_iterator7.s(); !(_step7 = _iterator7.n()).done;) { + _loop2(); + } + } catch (err) { + _iterator7.e(err); + } finally { + _iterator7.f(); + } + for (var _i4 = 0, _arr = [[$slot(_templateObject51 || (_templateObject51 = outfit_taggedTemplateLiteral(["buddy-bjorn"]))), template_string_$item(_templateObject52 || (_templateObject52 = outfit_taggedTemplateLiteral(["Buddy Bjorn"]))), external_kolmafia_.myBjornedFamiliar], [$slot(_templateObject53 || (_templateObject53 = outfit_taggedTemplateLiteral(["crown-of-thrones"]))), template_string_$item(_templateObject54 || (_templateObject54 = outfit_taggedTemplateLiteral(["Crown of Thrones"]))), external_kolmafia_.myEnthronedFamiliar]]; _i4 < _arr.length; _i4++) { + var _arr$_i = outfit_slicedToArray(_arr[_i4], 3), + rider = _arr$_i[0], + throne = _arr$_i[1], + checkingFunction = _arr$_i[2]; + var wanted = this.riders.get(rider); + if (outfit_toConsumableArray(this.equips.values()).includes(throne) && wanted && checkingFunction() !== wanted) { + throw "Failed to fully dress: (expected ".concat(rider, " ").concat(wanted, ")"); + } + } + } + }, { + key: "dress", + value: function dress() { + var _iterator8 = outfit_createForOfIteratorHelper(this.preActions), + _step8; + try { + for (_iterator8.s(); !(_step8 = _iterator8.n()).done;) { + var action = _step8.value; + action(); + } + } catch (err) { + _iterator8.e(err); + } finally { + _iterator8.f(); + } + this._dress(false); + var _iterator9 = outfit_createForOfIteratorHelper(this.postActions), + _step9; + try { + for (_iterator9.s(); !(_step9 = _iterator9.n()).done;) { + var _action = _step9.value; + _action(); + } + } catch (err) { + _iterator9.e(err); + } finally { + _iterator9.f(); + } + } + /** + * Build an Outfit identical to this outfit. + */ + }, { + key: "clone", + value: function clone() { + var result = new Outfit(); + result.equips = new Map(this.equips); + result.skipDefaults = this.skipDefaults; + result.familiar = this.familiar; + result.modifier = outfit_toConsumableArray(this.modifier); + result.avoid = outfit_toConsumableArray(this.avoid); + result.modes = outfit_objectSpread({}, this.modes); + result.riders = new Map(this.riders); + result.bonuses = new Map(this.bonuses); + result.beforeDress.apply(result, outfit_toConsumableArray(this.preActions)); + result.afterDress.apply(result, outfit_toConsumableArray(this.postActions)); + return result; + } + /** + * Build an OutfitSpec identical to this outfit. + */ + }, { + key: "spec", + value: function spec() { + var _a; + var result = { + modifier: outfit_toConsumableArray(this.modifier), + avoid: outfit_toConsumableArray(this.avoid), + skipDefaults: this.skipDefaults, + modes: outfit_objectSpread({}, this.modes), + bonuses: new Map(this.bonuses) + }; + if (this.familiar) result.familiar = this.familiar; + // Add all equipment forced in a particular slot + for (var _i5 = 0, _outfitSlots2 = outfitSlots; _i5 < _outfitSlots2.length; _i5++) { + var slotName = _outfitSlots2[_i5]; + var entry = this.equips.get((_a = new Map([["famequip", $slot(_templateObject58 || (_templateObject58 = outfit_taggedTemplateLiteral(["familiar"])))], ["offhand", $slot(_templateObject59 || (_templateObject59 = outfit_taggedTemplateLiteral(["off-hand"])))]]).get(slotName)) !== null && _a !== void 0 ? _a : (0,external_kolmafia_.toSlot)(slotName)); + if (entry) result[slotName] = entry; + } + // Include the riders + var riders = {}; + var buddyRider = this.riders.get($slot(_templateObject60 || (_templateObject60 = outfit_taggedTemplateLiteral(["buddy-bjorn"])))); + if (buddyRider !== undefined) riders["buddy-bjorn"] = buddyRider; + var throneRider = this.riders.get($slot(_templateObject61 || (_templateObject61 = outfit_taggedTemplateLiteral(["crown-of-thrones"])))); + if (throneRider !== undefined) riders["crown-of-thrones"] = throneRider; + if (buddyRider !== undefined || throneRider !== undefined) result.riders = riders; + if (this.preActions.length) result.beforeDress = this.preActions; + if (this.postActions.length) result.afterDress = this.postActions; + return result; + } + }], [{ + key: "current", + value: function current() { + var _a; + var outfit = new Outfit(); + var familiar = (0,external_kolmafia_.myFamiliar)(); + if (outfit.equip(familiar)) { + throw "Failed to create outfit from current state (expected: familiar ".concat(familiar, ")"); + } + for (var _i6 = 0, _outfitSlots3 = outfitSlots; _i6 < _outfitSlots3.length; _i6++) { + var slotName = _outfitSlots3[_i6]; + var slot = (_a = new Map([["famequip", $slot(_templateObject62 || (_templateObject62 = outfit_taggedTemplateLiteral(["familiar"])))], ["offhand", $slot(_templateObject63 || (_templateObject63 = outfit_taggedTemplateLiteral(["off-hand"])))]]).get(slotName)) !== null && _a !== void 0 ? _a : (0,external_kolmafia_.toSlot)(slotName); + var item = (0,external_kolmafia_.equippedItem)(slot); + if (!outfit.equip(item, slot)) { + throw "Failed to create outfit from current state (expected: ".concat(slot, " ").concat(item, ")"); + } + } + if ((0,external_kolmafia_.haveEquipped)(template_string_$item(_templateObject64 || (_templateObject64 = outfit_taggedTemplateLiteral(["Crown of Thrones"]))))) outfit.riders.set($slot(_templateObject65 || (_templateObject65 = outfit_taggedTemplateLiteral(["crown-of-thrones"]))), (0,external_kolmafia_.myEnthronedFamiliar)()); + if ((0,external_kolmafia_.haveEquipped)(template_string_$item(_templateObject66 || (_templateObject66 = outfit_taggedTemplateLiteral(["Buddy Bjorn"]))))) outfit.riders.set($slot(_templateObject67 || (_templateObject67 = outfit_taggedTemplateLiteral(["buddy-bjorn"]))), (0,external_kolmafia_.myBjornedFamiliar)()); + outfit.setModes(outfit_getCurrentModes()); + return outfit; + } + }, { + key: "from", + value: function from(spec) { + var error = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; + var _a; + var outfit = new Outfit(); + if (spec instanceof Requirement) { + var result = {}; + result.modifier = spec.maximizeParameters; + if ((_a = spec.maximizeOptions.forceEquip) === null || _a === void 0 ? void 0 : _a.length) { + result.equip = spec.maximizeOptions.forceEquip; + } + result.avoid = spec.maximizeOptions.preventEquip; + result.bonuses = spec.maximizeOptions.bonusEquip; + if (spec.maximizeOptions.modes) { + result.modes = convertFromLibramModes(spec.maximizeOptions.modes); + } + // Not sure if this is necessary + var cleanedResult = Object.fromEntries(outfit_toConsumableArray(Object.entries(result)).filter(_ref => { + var _ref2 = outfit_slicedToArray(_ref, 2), + v = _ref2[1]; + return v !== undefined; + })); + return Outfit.from(cleanedResult); + } + var success = outfit.equip(spec); + if (!success && error) throw error; + return success ? outfit : null; + } + }]); + return Outfit; +}(); +/** + * Get the modes of this outfit in a type compatible with Libram. + * + * This conversion is needed since we store the retrocape modes + * internally as an array, but libram uses a string. + * + * @returns The modes equipped to this outfit. + */ +function convertToLibramModes(modes) { + var _a; + return { + backupcamera: modes["backupcamera"], + umbrella: modes["umbrella"], + snowsuit: modes["snowsuit"], + edpiece: modes["edpiece"], + retrocape: (_a = modes["retrocape"]) === null || _a === void 0 ? void 0 : _a.filter(s => s !== undefined).join(" "), + parka: modes["parka"] + }; +} +function convertFromLibramModes(modes) { + return modes.retrocape ? outfit_objectSpread(outfit_objectSpread({}, modes), {}, { + retrocape: modes.retrocape.split(" ") + }) : modes; +} +/** + * Get the current modes of all items. + * + * @returns The current mode settings for all items, equipped or not. + */ +function outfit_getCurrentModes() { + return { + backupcamera: getMode("backupCameraMode", ["ml", "meat", "init"]), + umbrella: getMode("umbrellaState", ["broken", "forward-facing", "bucket style", "pitchfork style", "constantly twirling", "cocoon"]), + snowsuit: getMode("snowsuit", ["eyebrows", "smirk", "nose", "goatee", "hat"]), + edpiece: getMode("edPiece", ["bear", "owl", "puma", "hyena", "mouse", "weasel", "fish"]), + retrocape: [getMode("retroCapeSuperhero", ["vampire", "heck", "robot"]), getMode("retroCapeWashingInstructions", ["hold", "thrill", "kiss", "kill"])], + parka: getMode("parkaMode", ["kachungasaur", "dilophosaur", "ghostasaurus", "spikolodon", "pterodactyl"]) + }; +} +/** + * Get the current value for a mode in a type-safe way. + * + * @param property The mafia property for the mode. + * @param options A typed list of options for the mode. + * @returns The mode if the property value matched a valid option, or undefined. + */ +function getMode(property, options) { + var val = property_get(property, ""); + return options.find(s => s === val); // .includes has type issues +} +;// CONCATENATED MODULE: ./node_modules/grimoire-kolmafia/dist/engine.js +var engine_templateObject; +function engine_taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); } +function engine_toConsumableArray(arr) { return engine_arrayWithoutHoles(arr) || engine_iterableToArray(arr) || engine_unsupportedIterableToArray(arr) || engine_nonIterableSpread(); } +function engine_nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function engine_iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); } +function engine_arrayWithoutHoles(arr) { if (Array.isArray(arr)) return engine_arrayLikeToArray(arr); } +function engine_slicedToArray(arr, i) { return engine_arrayWithHoles(arr) || engine_iterableToArrayLimit(arr, i) || engine_unsupportedIterableToArray(arr, i) || engine_nonIterableRest(); } +function engine_nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function engine_iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } +function engine_arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } +function engine_createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = engine_unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; } +function engine_unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return engine_arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return engine_arrayLikeToArray(o, minLen); } +function engine_arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } +function engine_ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function engine_objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? engine_ownKeys(Object(t), !0).forEach(function (r) { engine_defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : engine_ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +function engine_defineProperty(obj, key, value) { key = engine_toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function engine_defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, engine_toPropertyKey(descriptor.key), descriptor); } } +function engine_createClass(Constructor, protoProps, staticProps) { if (protoProps) engine_defineProperties(Constructor.prototype, protoProps); if (staticProps) engine_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } +function engine_toPropertyKey(arg) { var key = engine_toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); } +function engine_toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } +function engine_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + + + + +var EngineOptions = /*#__PURE__*/(/* unused pure expression or super */ null && (engine_createClass(function EngineOptions() { + engine_classCallCheck(this, EngineOptions); +}))); +var grimoireCCS = "grimoire_macro"; +var Engine = /*#__PURE__*/function () { + /** + * Create the engine. + * @param tasks A list of tasks for looking up task dependencies. + * @param options Basic configuration of the engine. + */ + function Engine(tasks, options) { + engine_classCallCheck(this, Engine); + this.attempts = {}; + this.propertyManager = new PropertiesManager(); + this.tasks_by_name = new Map(); + this.cachedCcsContents = ""; + this.options = options !== null && options !== void 0 ? options : {}; + this.tasks = tasks.map(task => engine_objectSpread(engine_objectSpread({}, this.options.default_task_options), task)); + var _iterator = engine_createForOfIteratorHelper(this.tasks), + _step; + try { + for (_iterator.s(); !(_step = _iterator.n()).done;) { + var task = _step.value; + this.tasks_by_name.set(task.name, task); + } + } catch (err) { + _iterator.e(err); + } finally { + _iterator.f(); + } + this.initPropertiesManager(this.propertyManager); + } + /** + * Determine the next task to perform. + * By default, this is the first task in the task list that is available. + * @returns The next task to perform, or undefined if no tasks are available. + */ + engine_createClass(Engine, [{ + key: "getNextTask", + value: function getNextTask() { + return this.tasks.find(task => this.available(task)); + } + /** + * Continually get the next task and execute it. + * @param actions If given, only perform up to this many tasks. + */ + }, { + key: "run", + value: function run(actions) { + for (var i = 0; i < (actions !== null && actions !== void 0 ? actions : Infinity); i++) { + var task = this.getNextTask(); + if (!task) return; + this.execute(task); + } + } + /** + * Close the engine and reset all properties. + * After this has been called, this object should not be used. + */ + }, { + key: "destruct", + value: function destruct() { + this.propertyManager.resetAll(); + (0,external_kolmafia_.setAutoAttack)(0); + } + /** + * Check if the given task is available at this moment. + * @returns true if all dependencies are complete and the task is ready. + * Note that dependencies are not checked transitively. That is, if + * A depends on B which depends on C, then A is ready if B is complete + * (regardless of if C is complete or not). + */ + }, { + key: "available", + value: function available(task) { + var _a, _b; + if (((_a = task.limit) === null || _a === void 0 ? void 0 : _a.skip) !== undefined && this.attempts[task.name] >= task.limit.skip) return false; + var _iterator2 = engine_createForOfIteratorHelper((_b = task.after) !== null && _b !== void 0 ? _b : []), + _step2; + try { + for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) { + var after = _step2.value; + var after_task = this.tasks_by_name.get(after); + if (after_task === undefined) throw "Unknown task dependency ".concat(after, " on ").concat(task.name); + if (!after_task.completed()) return false; + } + } catch (err) { + _iterator2.e(err); + } finally { + _iterator2.f(); + } + if (task.ready && !task.ready()) return false; + if (task.completed()) return false; + return true; + } + /** + * Perform all steps to execute the provided task. + * This is the main entry point for the Engine. + * @param task The current executing task. + */ + }, { + key: "execute", + value: function execute(task) { + var _a, _b, _c, _d, _e; + (0,external_kolmafia_.print)(""); + (0,external_kolmafia_.print)("Executing ".concat(task.name), "blue"); + // Determine the proper postcondition for after the task executes. + var postcondition = (_b = (_a = task.limit) === null || _a === void 0 ? void 0 : _a.guard) === null || _b === void 0 ? void 0 : _b.call(_a); + // Acquire any items and effects first, possibly for later execution steps. + this.acquireItems(task); + this.acquireEffects(task); + // Prepare the outfit, with resources. + var task_combat = (_d = (_c = task.combat) === null || _c === void 0 ? void 0 : _c.clone()) !== null && _d !== void 0 ? _d : new CombatStrategy(); + var outfit = this.createOutfit(task); + var task_resources = new CombatResources(); + this.customize(task, outfit, task_combat, task_resources); + this.dress(task, outfit); + // Prepare combat and choices + this.setCombat(task, task_combat, task_resources); + this.setChoices(task, this.propertyManager); + // Actually perform the task + var _iterator3 = engine_createForOfIteratorHelper(task_resources.all()), + _step3; + try { + for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) { + var resource = _step3.value; + (_e = resource.prepare) === null || _e === void 0 ? void 0 : _e.call(resource); + } + } catch (err) { + _iterator3.e(err); + } finally { + _iterator3.f(); + } + this.prepare(task); + this.do(task); + while (this.shouldRepeatAdv(task)) { + _set("lastEncounter", ""); + this.do(task); + } + this.post(task); + // Mark that we tried the task, and apply limits + this.markAttempt(task); + this.checkLimits(task, postcondition); + } + /** + * Acquire all items for the task. + * @param task The current executing task. + */ + }, { + key: "acquireItems", + value: function acquireItems(task) { + var _a; + var acquire = undelay(task.acquire); + var _iterator4 = engine_createForOfIteratorHelper(acquire || []), + _step4; + try { + for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) { + var to_get = _step4.value; + var num_needed = (_a = to_get.num) !== null && _a !== void 0 ? _a : 1; + var num_have = (0,external_kolmafia_.itemAmount)(to_get.item) + (0,external_kolmafia_.equippedAmount)(to_get.item); + if (num_needed <= num_have) continue; + if (to_get.useful !== undefined && !to_get.useful()) continue; + if (to_get.get) { + to_get.get(); + } else if (to_get.price !== undefined) { + (0,external_kolmafia_.buy)(to_get.item, num_needed - num_have, to_get.price); + } else if (Object.keys((0,external_kolmafia_.getRelated)(to_get.item, "fold")).length > 0) { + (0,external_kolmafia_.cliExecute)("fold ".concat(to_get.item)); + } else { + (0,external_kolmafia_.retrieveItem)(to_get.item, num_needed); + } + if ((0,external_kolmafia_.itemAmount)(to_get.item) + (0,external_kolmafia_.equippedAmount)(to_get.item) < num_needed && !to_get.optional) { + throw "Task ".concat(task.name, " was unable to acquire ").concat(num_needed, " ").concat(to_get.item); + } + } + } catch (err) { + _iterator4.e(err); + } finally { + _iterator4.f(); + } + } + /** + * Acquire all effects for the task. + * @param task The current executing task. + */ + }, { + key: "acquireEffects", + value: function acquireEffects(task) { + var _a; + var effects = (_a = undelay(task.effects)) !== null && _a !== void 0 ? _a : []; + var songs = effects.filter(effect => isSong(effect)); + if (songs.length > maxSongs()) throw "Too many AT songs"; + var extraSongs = Object.keys((0,external_kolmafia_.myEffects)()).map(effectName => (0,external_kolmafia_.toEffect)(effectName)).filter(effect => isSong(effect) && !songs.includes(effect)); + while (songs.length + extraSongs.length > maxSongs()) { + var toRemove = extraSongs.pop(); + if (toRemove === undefined) { + break; + } else { + uneffect(toRemove); + } + } + var _iterator5 = engine_createForOfIteratorHelper(effects), + _step5; + try { + for (_iterator5.s(); !(_step5 = _iterator5.n()).done;) { + var effect = _step5.value; + ensureEffect(effect); + } + } catch (err) { + _iterator5.e(err); + } finally { + _iterator5.f(); + } + } + /** + * Create an outfit for the task with all required equipment. + * @param task The current executing task. + */ + }, { + key: "createOutfit", + value: function createOutfit(task) { + var spec = undelay(task.outfit); + if (spec instanceof Outfit) return spec.clone(); + var outfit = new Outfit(); + if (spec !== undefined) { + if (!outfit.equip(spec) && !this.options.allow_partial_outfits) { + throw "Unable to equip all items for ".concat(task.name); + } + } + return outfit; + } + /** + * Equip the outfit for the task. + * @param task The current executing task. + * @param outfit The outfit for the task, possibly augmented by the engine. + */ + }, { + key: "dress", + value: function dress(task, outfit) { + if (task.do instanceof external_kolmafia_.Location) (0,external_kolmafia_.setLocation)(task.do); + outfit.dress(); + } + /* eslint-disable @typescript-eslint/no-unused-vars */ + /** + * Perform any engine-specific customization for the outfit and combat plan. + * + * This is a natural method to override in order to: + * * Enable the use of any resources in the outfit or combat (e.g., allocate banishers). + * * Equip a default outfit. + * * Determine additional monster macros at a global level (e.g., use flyers). + * @param task The current executing task. + * @param outfit The outfit for the task. + * @param combat The combat strategy so far for the task. + * @param resources The combat resources assigned so far for the task. + */ + }, { + key: "customize", + value: function customize(task, outfit, combat, resources) { + // do nothing by default + } + /* eslint-enable @typescript-eslint/no-unused-vars */ + /** + * Set the choice settings for the task. + * @param task The current executing task. + * @param manager The property manager to use. + */ + }, { + key: "setChoices", + value: function setChoices(task, manager) { + var _a; + for (var _i = 0, _Object$entries = Object.entries((_a = task.choices) !== null && _a !== void 0 ? _a : {}); _i < _Object$entries.length; _i++) { + var _Object$entries$_i = engine_slicedToArray(_Object$entries[_i], 2), + key = _Object$entries$_i[0], + func = _Object$entries$_i[1]; + if (func === undefined) continue; + manager.setChoice(parseInt(key), undelay(func)); + } + } + /** + * Save the combat macro for this task. + * @param task The current executing task. + * @param task_combat The completed combat strategy far for the task. + * @param task_resources The combat resources assigned for the task. + */ + }, { + key: "setCombat", + value: function setCombat(task, task_combat, task_resources) { + var _a; + // Save regular combat macro + var macro = task_combat.compile(task_resources, (_a = this.options) === null || _a === void 0 ? void 0 : _a.combat_defaults, task.do instanceof external_kolmafia_.Location ? task.do : undefined); + macro.save(); + if (!this.options.ccs) { + // Use the macro through a CCS file + var otherCCSEntries = task_combat.compileCcs(); + var ccsContents = ["[default]", "\"".concat(macro.toString(), "\"")].concat(engine_toConsumableArray(otherCCSEntries)).join("\n"); + // Log Macro + other CCS + (0,external_kolmafia_.logprint)("CCS: ".concat(ccsContents.replace("\n", "\\n "))); + if (ccsContents !== this.cachedCcsContents) { + (0,external_kolmafia_.writeCcs)(ccsContents, grimoireCCS); + (0,external_kolmafia_.cliExecute)("ccs ".concat(grimoireCCS)); // force Mafia to reparse the ccs + this.cachedCcsContents = ccsContents; + } + } + // Save autoattack combat macro + var autoattack = task_combat.compileAutoattack(); + if (autoattack.toString().length > 1) { + (0,external_kolmafia_.logprint)("Autoattack macro: ".concat(autoattack.toString())); + autoattack.setAutoAttack(); + } else { + (0,external_kolmafia_.setAutoAttack)(0); + } + } + /** + * Do any task-specific preparation. + * @param task The current executing task. + */ + }, { + key: "prepare", + value: function prepare(task) { + var _a; + (_a = task.prepare) === null || _a === void 0 ? void 0 : _a.call(task); + } + /** + * Actually perform the task. + * @param task The current executing task. + */ + }, { + key: "do", + value: function _do(task) { + var result = typeof task.do === "function" ? task.do() : task.do; + if (result instanceof external_kolmafia_.Location) (0,external_kolmafia_.adv1)(result, -1, ""); + (0,external_kolmafia_.runCombat)(); + while ((0,external_kolmafia_.inMultiFight)()) (0,external_kolmafia_.runCombat)(); + if ((0,external_kolmafia_.choiceFollowsFight)()) (0,external_kolmafia_.runChoice)(-1); + } + /** + * Check if the task.do should be immediately repeated without any prep. + * + * By default, this is only used to repeat a task if we hit one of: + * 1. Halloweener dog noncombats, + * 2. June cleaver noncombats, + * 3. Lil' Doctor™ bag noncombat, or + * 4. Turtle taming noncombats. + * @param task The current executing task. + * @returns True if the task should be immediately repeated. + */ + }, { + key: "shouldRepeatAdv", + value: function shouldRepeatAdv(task) { + return task.do instanceof external_kolmafia_.Location && lastEncounterWasWanderingNC(); + } + /** + * Do any task-specific wrapup activities. + * @param task The current executing task. + */ + }, { + key: "post", + value: function post(task) { + var _a; + (_a = task.post) === null || _a === void 0 ? void 0 : _a.call(task); + } + /** + * Mark that an attempt was made on the current task. + * @param task The current executing task. + */ + }, { + key: "markAttempt", + value: function markAttempt(task) { + if (!(task.name in this.attempts)) this.attempts[task.name] = 0; + this.attempts[task.name]++; + } + /** + * Check if the task has passed any of its internal limits. + * @param task The task to check. + * @throws An error if any of the internal limits have been passed. + */ + }, { + key: "checkLimits", + value: function checkLimits(task, postcondition) { + var _a; + if (!task.limit) return; + var failureMessage = task.limit.message ? " ".concat(task.limit.message) : ""; + if (!task.completed()) { + if (task.limit.tries && this.attempts[task.name] >= task.limit.tries) throw "Task ".concat(task.name, " did not complete within ").concat(task.limit.tries, " attempts. Please check what went wrong.").concat(failureMessage); + if (task.limit.soft && this.attempts[task.name] >= task.limit.soft) throw "Task ".concat(task.name, " did not complete within ").concat(task.limit.soft, " attempts. Please check what went wrong (you may just be unlucky).").concat(failureMessage); + if (task.limit.turns && task.do instanceof external_kolmafia_.Location && task.do.turnsSpent >= task.limit.turns) throw "Task ".concat(task.name, " did not complete within ").concat(task.limit.turns, " turns. Please check what went wrong.").concat(failureMessage); + if (task.limit.unready && ((_a = task.ready) === null || _a === void 0 ? void 0 : _a.call(task))) throw "Task ".concat(task.name, " is still ready, but it should not be. Please check what went wrong.").concat(failureMessage); + if (task.limit.completed) throw "Task ".concat(task.name, " is not completed, but it should be. Please check what went wrong.").concat(failureMessage); + } + if (postcondition && !postcondition()) { + throw "Task ".concat(task.name, " failed its guard. Please check what went wrong.").concat(failureMessage); + } + } + }, { + key: "getDefaultSettings", + value: function getDefaultSettings() { + return this.constructor.defaultSettings; + } + /** + * Initialize properties for the script. + * @param manager The properties manager to use. + */ + }, { + key: "initPropertiesManager", + value: function initPropertiesManager(manager) { + var _a; + // Properties adapted from garbo + manager.set(this.getDefaultSettings()); + if (this.options.ccs !== "") { + if (this.options.ccs === undefined && (0,external_kolmafia_.readCcs)(grimoireCCS) === "") { + // Write a simple CCS so we can switch to it + (0,external_kolmafia_.writeCcs)("[ default ]\nabort", grimoireCCS); + } + manager.set({ + customCombatScript: (_a = this.options.ccs) !== null && _a !== void 0 ? _a : grimoireCCS + }); + } + } + }]); + return Engine; +}(); +Engine.defaultSettings = { + logPreferenceChange: true, + logPreferenceChangeFilter: engine_toConsumableArray(new Set([].concat(engine_toConsumableArray(property_get("logPreferenceChangeFilter").split(",")), ["libram_savedMacro", "maximizerMRUList", "testudinalTeachings", "_lastCombatStarted"]))).sort().filter(a => a).join(","), + battleAction: "custom combat script", + autoSatisfyWithMall: true, + autoSatisfyWithNPCs: true, + autoSatisfyWithCoinmasters: true, + autoSatisfyWithStash: false, + dontStopForCounters: true, + maximizerFoldables: true, + hpAutoRecovery: "-0.05", + hpAutoRecoveryTarget: "0.0", + mpAutoRecovery: "-0.05", + mpAutoRecoveryTarget: "0.0", + afterAdventureScript: "", + betweenBattleScript: "", + choiceAdventureScript: "", + familiarScript: "", + currentMood: "apathetic", + autoTuxedo: true, + autoPinkyRing: true, + autoGarish: true, + allowNonMoodBurning: false, + allowSummonBurning: true, + libramSkillsSoftcore: "none" +}; +function maxSongs() { + return have(template_string_$skill(engine_templateObject || (engine_templateObject = engine_taggedTemplateLiteral(["Mariachi Memory"])))) ? 4 : 3; +} +var wanderingNCs = new Set([ +// Halloweener dog noncombats +"Wooof! Wooooooof!", "Playing Fetch*", +// June cleaver noncombats +"Aunts not Ants", "Bath Time", "Beware of Aligator", "Delicious Sprouts", "Hypnotic Master", "Lost and Found", "Poetic Justice", "Summer Days", "Teacher's Pet", +// Lil' Doctor™ bag noncombat +"A Pound of Cure", +// Turtle taming noncombats +"Nantucket Snapper", "Blue Monday", "Capital!", "Training Day", "Boxed In", "Duel Nature", "Slow Food", "A Rolling Turtle Gathers No Moss", "Slow Road to Hell", "C'mere, Little Fella", "The Real Victims", "Like That Time in Tortuga", "Cleansing your Palette", "Harem Scarum", "Turtle in peril", "No Man, No Hole", "Slow and Steady Wins the Brawl", "Stormy Weather", "Turtles of the Universe", "O Turtle Were Art Thou", "Allow 6-8 Weeks For Delivery", "Kick the Can", "Turtles All The Way Around", "More eXtreme Than Usual", "Jewel in the Rough", "The worst kind of drowning", "Even Tamer Than Usual", "Never Break the Chain", "Close, but Yes Cigar", "Armchair Quarterback", "This Turtle Rocks!", "Really Sticking Her Neck Out", "It Came from Beneath the Sewer? Great!", "Don't Be Alarmed, Now", "Puttin' it on Wax", "More Like... Hurtle", "Musk! Musk! Musk!", "Silent Strolling"]); +var zoneSpecificNCs = new Map([["The Horror...", ["Frat House"]] // Duplicate choice name +]); +/** + * Return true if the last adv was one of: + * 1. Halloweener dog noncombats, + * 2. June cleaver noncombats, + * 3. Lil' Doctor™ bag noncombat, or + * 4. Turtle taming noncombats. + */ +function lastEncounterWasWanderingNC() { + var _a; + var last = property_get("lastEncounter"); + if (zoneSpecificNCs.has(last)) { + // Handle NCs with a duplicated name + var zones = (_a = zoneSpecificNCs.get(last)) !== null && _a !== void 0 ? _a : []; + return zones.includes(property_get("lastAdventure")); + } else { + return wanderingNCs.has(last); + } +} +;// CONCATENATED MODULE: ./node_modules/grimoire-kolmafia/dist/index.js + + + + + + + +// EXTERNAL MODULE: ./node_modules/mafia-shared-relay/dist/index.js +var dist = __webpack_require__(139); +;// CONCATENATED MODULE: ./src/args.ts + +var args = Args.create("FolgerCS", "Written by Seraphiii, branched from InstantSCCS by Pantocyclus. This is a CS-script with a focus on maximum aftercore profits", { + version: Args.flag({ + help: "Output script version number and exit.", + default: false, + setting: "" + }), + motherclan: Args.string({ + help: "Name of the mother clan for your slime fighting needs", + default: "" + }), + fortifiedwine: Args.flag({ + help: "Do not grab the DFW lucky adventure (if you have numberology or are using skip-BT route)", + default: true + }), + perfectfreeze: Args.flag({ + help: "Do not craft and drink a perfect drink", + default: true + }), + beesknees: Args.flag({ + help: "Do not buy and drink Bee's Knees", + default: true + }), + sacramentowine: Args.flag({ + help: "Do not drink a Sacramento Wine for the item test", + default: true + }), + synthxp: Args.flag({ + help: "Do not use synth for the Xp% buff", + default: true + }), + bodyspradium: Args.flag({ + help: "Do not chew the body spradium if we have it", + default: true + }), + deepdish: Args.flag({ + help: "Skip Deep Dish of Legend", + default: false + }), + latedeepdish: Args.flag({ + help: "Eat a deep dish, but only before the familiar test", + default: false + }), + calzone: Args.flag({ + help: "Skip Calzone of Legend", + default: false + }), + pizza: Args.flag({ + help: "Skip Pizza of Legend", + default: false + }), + asdon: Args.flag({ + help: "Should we use Asdon Martin? Incompatible with Skipping Borrowed Time", + default: false + }), + astralpils: Args.number({ + help: "How many astral pilsners should we save?", + default: 0 + }), + savepulls: Args.number({ + help: "How many pulls should we save?", + default: 0 + }), + witchess: Args.flag({ + help: "Do not fight witchess monsters nor acquire Puzzle Champ", + default: false + }), + savebackups: Args.number({ + help: "How many backup camera backups should we save?", + default: 11 + }), + savehabitats: Args.number({ + help: "How many Book of Facts habitats should we save?", + default: 3 + }), + redskeleton: Args.flag({ + help: "Do not locket a red skeleton", + default: false + }), + witchessking: Args.flag({ + help: "Do not locket a witchess king", + default: false + }), + factoryworker: Args.flag({ + help: "Do not locket a factory worker (female)", + default: false + }), + ninjamap: Args.flag({ + help: "Do not attempt to grab a li'l ninja costume for your tot", + default: false + }), + savesnokebomb: Args.flag({ + help: "Should we save snokebombs for Inner Elf?", + default: false + }), + skipbishop: Args.flag({ + help: "Save 3 Witchess fights for the Queen, King and Witch", + default: false + }), + savepurqoise: Args.flag({ + help: "Do not autosell your porquoise", + default: false + }), + savefloundry: Args.flag({ + help: "Do not create a carpe", + default: false + }), + savefortune: Args.flag({ + help: "Do not consult Zatara for the stat buff", + default: false + }), + savesnack: Args.flag({ + help: "Do not use your snack voucher", + default: false + }), + savebarrel: Args.flag({ + help: "Do not get the barrel shrine buff", + default: false + }), + saveterminal: Args.flag({ + help: "Do not acquire items.enh and substats.enh", + default: false + }), + savecopdollar: Args.flag({ + help: "Do not acquire shoe gum with cop dollars", + default: false + }), + savekgb: Args.flag({ + help: "Do not use any KGB clicks", + default: false + }), + savepantogramming: Args.flag({ + help: "Do not use your pantogram", + default: false + }), + savemumming: Args.flag({ + help: "Do not use your mumming trunk", + default: false + }), + saveglove: Args.flag({ + help: "Do not acquire Triple-Sized and Invisible Avatar", + default: false + }), + savemayday: Args.flag({ + help: "Do not use your Mayday survival package", + default: false + }), + savepumpkin: Args.flag({ + help: "Do not use harvested pumpkins", + default: false + }), + savesugar: Args.flag({ + help: "Do not spend tome uses on sugar shorts/chapeau/shank", + default: false + }), + savegarden: Args.flag({ + help: "Do not harvest your garden", + default: false + }), + savemoontune: Args.flag({ + help: "Do not tune the moon for familiar weight test", + default: false + }), + savecinch: Args.number({ + help: "How much cinch should we save?", + default: 0 + }), + saverests: Args.number({ + help: "How many rests should we use (not save, use!)?", + default: 0 + }), + savenumberology: Args.number({ + help: "How many numberology casts should we use (not save, use!)?", + default: 0 + }), + savelimitedat: Args.flag({ + help: "Should we use limited Accordian Thief songs?", + default: false + }), + savegovernment: Args.flag({ + help: "Do not attempt to unlock the beach with meat to grab an anticheese", + default: false + }), + savedeck: Args.flag({ + help: "Do not use Giant Growth or any other deck cheats", + default: false + }), + savecyclops: Args.flag({ + help: "Do not get and use cyclops eyedrops", + default: false + }), + dopulls: Args.flag({ + help: "Automatically use excess pulls for good stuff?", + default: true + }), + camelhat: Args.flag({ + help: "Use a box of familiar jacks to ensure camel is charged faster?", + default: false + }), + skipbt: Args.flag({ + help: "Route around using borrowed time? Note this requires using at least one legendary pizza.", + default: false + }), + experimentalsynth: Args.flag({ + help: "Try using Synth for item%? Requires Sugar Shummoning", + default: false + }), + explicitlyexcludedefs: Args.string({ + help: "Effects that we should not acquire throughout the run.", + default: "" + }), + explicitlyexcludedfams: Args.string({ + help: "Familiars that we should not use throughout the run.", + default: "" + }), + boozelimit: Args.number({ + help: "Set default booze test limit", + default: 10 + }), + familiarlimit: Args.number({ + help: "Set default booze test limit", + default: 40 + }), + hotlimit: Args.number({ + help: "Set default booze test limit", + default: 10 + }), + noncomlimit: Args.number({ + help: "Set default nomcombat test limit", + default: 10 + }), + spelldmglimit: Args.number({ + help: "Set default spell damage test limit", + default: 40 + }), + moxielimit: Args.number({ + help: "Set default moxie test limit", + default: 1 + }), + musclelimit: Args.number({ + help: "Set default muscle test limit", + default: 1 + }), + myslimit: Args.number({ + help: "Set default mys test limit", + default: 1 + }), + hplimit: Args.number({ + help: "Set default hp test limit", + default: 1 + }), + weaponlimit: Args.number({ + help: "Set default weapon damage test limit", + default: 12 + }) +}); +;// CONCATENATED MODULE: ./src/relay.ts +function relay_slicedToArray(arr, i) { return relay_arrayWithHoles(arr) || relay_iterableToArrayLimit(arr, i) || relay_unsupportedIterableToArray(arr, i) || relay_nonIterableRest(); } +function relay_nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function relay_unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return relay_arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return relay_arrayLikeToArray(o, minLen); } +function relay_arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } +function relay_iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } +function relay_arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } + + + + +function convertArgsToHtml() { + var _metadata$options$def; + var metadata = Args.getMetadata(args); + var pages = [{ + page: (_metadata$options$def = metadata.options.defaultGroupName) !== null && _metadata$options$def !== void 0 ? _metadata$options$def : "Options", + components: [] + }]; + metadata.traverse((key, name) => { + var _key$key, _key$setting, _key$key2; + if (key.setting === "" || key.hidden) return; + var component = { + type: "string", + name: (_key$key = key.key) !== null && _key$key !== void 0 ? _key$key : name, + description: key.help || "No Description Provided", + preference: (_key$setting = key.setting) !== null && _key$setting !== void 0 ? _key$setting : "".concat(metadata.scriptName, "_").concat((_key$key2 = key.key) !== null && _key$key2 !== void 0 ? _key$key2 : name), + default: "default" in key ? "".concat(key["default"]) : "block" + }; + if (key.valueHelpName === "FLAG" || key.valueHelpName === "BOOLEAN") { + component.type = "boolean"; + } else if (key.options !== undefined) { + component.type = "dropdown"; + component.dropdown = key.options.map(_ref => { + var _ref2 = relay_slicedToArray(_ref, 2), + k = _ref2[0], + desc = _ref2[1]; + return { + display: desc !== null && desc !== void 0 ? desc : k, + value: k + }; + }); + } + pages[0].components.push(component); + }, (group, name) => { + pages.push({ + page: name, + components: [] + }); + }); + pages.filter(p => p.components.length > 0).forEach(p => { + var html = { + type: "html", + data: "

FolgerCS ".concat(p.page, "") + }; + p.components.splice(0, 0, html); + }); + return pages.filter(page => page.components.length > 0); +} +function main() { + if ((0,dist.handleApiRequest)()) return; + (0,external_kolmafia_.write)((0,dist.generateHTML)(convertArgsToHtml())); +} +})(); + +var __webpack_export_target__ = exports; +for(var i in __webpack_exports__) __webpack_export_target__[i] = __webpack_exports__[i]; +if(__webpack_exports__.__esModule) Object.defineProperty(__webpack_export_target__, "__esModule", { value: true }); +/******/ })() +; \ No newline at end of file diff --git a/package.json b/package.json index 3503721..d0e7365 100644 --- a/package.json +++ b/package.json @@ -34,7 +34,8 @@ "garbo-lib": "^0.0.1", "grimoire-kolmafia": "^0.3.18", "kolmafia": "^5.27681.0", - "libram": "^0.8.16" + "libram": "^0.8.16", + "mafia-shared-relay": "0.0.7" }, "author": "Pantocyclus/Seraphiii", "license": "MIT", diff --git a/src/args.ts b/src/args.ts new file mode 100644 index 0000000..36ba3f7 --- /dev/null +++ b/src/args.ts @@ -0,0 +1,271 @@ +import { Args } from "grimoire-kolmafia"; + +export const args = Args.create( + "FolgerCS", + `Written by Seraphiii, branched from InstantSCCS by Pantocyclus. This is a CS-script with a focus on maximum aftercore profits`, + { + version: Args.flag({ + help: "Output script version number and exit.", + default: false, + setting: "", + }), + confirm: Args.boolean({ + help: "If the user must confirm execution of each task.", + default: false, + }), + sim: Args.flag({ help: "Check if you have the requirements to run this script.", setting: "" }), + savedresources: Args.flag({ + help: "Check which resources you have current set to be saved.", + setting: "", + }), + recap: Args.flag({ help: "Recap of today's run.", setting: "" }), + motherclan: Args.string({ + help: `Name of the mother clan for your slime fighting needs`, + default: "", + }), + fortifiedwine: Args.flag({ + help: `Do not grab the DFW lucky adventure (if you have numberology or are using skip-BT route)`, + default: true, + }), + perfectfreeze: Args.flag({ + help: `Do not craft and drink a perfect drink`, + default: true, + }), + beesknees: Args.flag({ + help: `Do not buy and drink Bee's Knees`, + default: true, + }), + sacramentowine: Args.flag({ + help: `Do not drink a Sacramento Wine for the item test`, + default: true, + }), + synthxp: Args.flag({ + help: `Do not use synth for the Xp% buff`, + default: true, + }), + bodyspradium: Args.flag({ + help: `Do not chew the body spradium if we have it`, + default: true, + }), + deepdish: Args.flag({ + help: `Skip Deep Dish of Legend`, + default: false, + }), + latedeepdish: Args.flag({ + help: `Eat a deep dish, but only before the familiar test`, + default: false, + }), + calzone: Args.flag({ + help: `Skip Calzone of Legend`, + default: false, + }), + pizza: Args.flag({ + help: `Skip Pizza of Legend`, + default: false, + }), + asdon: Args.flag({ + help: `Should we use Asdon Martin? Incompatible with Skipping Borrowed Time`, + default: false, + }), + astralpils: Args.number({ + help: "How many astral pilsners should we save?", + default: 0, + }), + savepulls: Args.number({ + help: "How many pulls should we save?", + default: 0, + }), + witchess: Args.flag({ + help: `Do not fight witchess monsters nor acquire Puzzle Champ`, + default: false, + }), + savebackups: Args.number({ + help: "How many backup camera backups should we save?", + default: 11, + }), + savehabitats: Args.number({ + help: "How many Book of Facts habitats should we save?", + default: 3, + }), + redskeleton: Args.flag({ + help: `Do not locket a red skeleton`, + default: false, + }), + witchessking: Args.flag({ + help: `Do not locket a witchess king`, + default: false, + }), + factoryworker: Args.flag({ + help: `Do not locket a factory worker (female)`, + default: false, + }), + ninjamap: Args.flag({ + help: `Do not attempt to grab a li'l ninja costume for your tot`, + default: false, + }), + savesnokebomb: Args.flag({ + help: `Should we save snokebombs for Inner Elf?`, + default: false, + }), + skipbishop: Args.flag({ + help: `Save 3 Witchess fights for the Queen, King and Witch`, + default: false, + }), + savepurqoise: Args.flag({ + help: `Do not autosell your porquoise`, + default: false, + }), + savefloundry: Args.flag({ + help: `Do not create a carpe`, + default: false, + }), + savefortune: Args.flag({ + help: `Do not consult Zatara for the stat buff`, + default: false, + }), + savesnack: Args.flag({ + help: `Do not use your snack voucher`, + default: false, + }), + savebarrel: Args.flag({ + help: `Do not get the barrel shrine buff`, + default: false, + }), + saveterminal: Args.flag({ + help: `Do not acquire items.enh and substats.enh`, + default: false, + }), + savecopdollar: Args.flag({ + help: `Do not acquire shoe gum with cop dollars`, + default: false, + }), + savekgb: Args.flag({ + help: `Do not use any KGB clicks`, + default: false, + }), + savepantogramming: Args.flag({ + help: `Do not use your pantogram`, + default: false, + }), + savemumming: Args.flag({ + help: `Do not use your mumming trunk`, + default: false, + }), + saveglove: Args.flag({ + help: `Do not acquire Triple-Sized and Invisible Avatar`, + default: false, + }), + savemayday: Args.flag({ + help: `Do not use your Mayday survival package`, + default: false, + }), + savepumpkin: Args.flag({ + help: `Do not use harvested pumpkins`, + default: false, + }), + savesugar: Args.flag({ + help: `Do not spend tome uses on sugar shorts/chapeau/shank`, + default: false, + }), + savegarden: Args.flag({ + help: `Do not harvest your garden`, + default: false, + }), + savemoontune: Args.flag({ + help: `Do not tune the moon for familiar weight test`, + default: false, + }), + savecinch: Args.number({ + help: `How much cinch should we save?`, + default: 0, + }), + saverests: Args.number({ + help: `How many rests should we use (not save, use!)?`, + default: 0, + }), + savenumberology: Args.number({ + help: `How many numberology casts should we use (not save, use!)?`, + default: 0, + }), + savelimitedat: Args.flag({ + help: `Should we use limited Accordian Thief songs?`, + default: false, + }), + savegovernment: Args.flag({ + help: `Do not attempt to unlock the beach with meat to grab an anticheese`, + default: false, + }), + savedeck: Args.flag({ + help: `Do not use Giant Growth or any other deck cheats`, + default: false, + }), + savecyclops: Args.flag({ + help: `Do not get and use cyclops eyedrops`, + default: false, + }), + dopulls: Args.flag({ + help: `Automatically use excess pulls for good stuff?`, + default: true, + }), + camelhat: Args.flag({ + help: `Use a box of familiar jacks to ensure camel is charged faster?`, + default: false, + }), + skipbt: Args.flag({ + help: `Route around using borrowed time? Note this requires using at least one legendary pizza.`, + default: false, + }), + experimentalsynth: Args.flag({ + help: `Try using Synth for item%? Requires Sugar Shummoning`, + default: false, + }), + explicitlyexcludedefs: Args.string({ + help: `Effects that we should not acquire throughout the run.`, + default: "", + }), + explicitlyexcludedfams: Args.string({ + help: `Familiars that we should not use throughout the run.`, + default: "", + }), + boozelimit: Args.number({ + help: `Set default booze test limit`, + default: 10, + }), + familiarlimit: Args.number({ + help: `Set default booze test limit`, + default: 40, + }), + hotlimit: Args.number({ + help: `Set default booze test limit`, + default: 10, + }), + noncomlimit: Args.number({ + help: `Set default nomcombat test limit`, + default: 10, + }), + spelldmglimit: Args.number({ + help: `Set default spell damage test limit`, + default: 40, + }), + moxielimit: Args.number({ + help: `Set default moxie test limit`, + default: 1, + }), + musclelimit: Args.number({ + help: `Set default muscle test limit`, + default: 1, + }), + myslimit: Args.number({ + help: `Set default mys test limit`, + default: 1, + }), + hplimit: Args.number({ + help: `Set default hp test limit`, + default: 1, + }), + weaponlimit: Args.number({ + help: `Set default weapon damage test limit`, + default: 12, + }), + } +); diff --git a/src/engine/outfit.ts b/src/engine/outfit.ts index b3b0569..10ece31 100644 --- a/src/engine/outfit.ts +++ b/src/engine/outfit.ts @@ -13,6 +13,7 @@ import { maxBy, } from "libram"; import { camelFightsLeft, statToMaximizerString } from "../lib"; +import { args } from "../args"; export function garbageShirt(): void { if ( @@ -104,9 +105,7 @@ function melodramedary(): Familiar { } export function chooseFamiliar(allowAttackingFamiliars = true): Familiar { - const ignoredFamiliars = get("instant_explicitlyExcludedFamiliars", "") - .split(",") - .map((i) => toInt(i)); + const ignoredFamiliars = args.explicitlyexcludedfams.split(",").map((i) => toInt(i)); const defaultFam = have($familiar`Cookbookbat`) ? $familiar`Cookbookbat` : $familiar.none; const familiars = [ melodramedary, @@ -151,7 +150,7 @@ export function baseOutfit(allowAttackingFamiliars = true): OutfitSpec { acc2: have($item`Cincho de Mayo`) && get("_cinchUsed", 0) < 95 && - 100 - get("_cinchUsed", 0) > get("instant_saveCinch", 0) + 100 - get("_cinchUsed", 0) > args.savecinch ? $item`Cincho de Mayo` : undefined, familiar: chooseFamiliar(allowAttackingFamiliars), diff --git a/src/lib.ts b/src/lib.ts index 8e727c4..89c5c9b 100644 --- a/src/lib.ts +++ b/src/lib.ts @@ -30,6 +30,7 @@ import { Stat, storageAmount, sweetSynthesis, + toEffect, toInt, toItem, toSkill, @@ -62,8 +63,8 @@ import { Witchess, } from "libram"; import { printModtrace } from "libram/dist/modifier"; -import { forbiddenEffects } from "./resources"; import { mainStat } from "./combat"; +import { args } from "./args"; export const startingClan = getClanName(); @@ -102,6 +103,26 @@ export const testModifiers = new Map([ } }*/ +export const forbiddenEffects: Effect[] = []; + +if (args.bodyspradium) forbiddenEffects.push($effect`Boxing Day Glow`); +if (args.witchess) forbiddenEffects.push($effect`Puzzle Champ`); +if (args.savesnack) forbiddenEffects.push($effect`Wasabi With You`, $effect`Pisces in the Skyces`); +if (args.savebarrel) forbiddenEffects.push($effect`Warlock, Warstock, and Warbarrel`); +if (args.saveterminal) forbiddenEffects.push($effect`items.enh`, $effect`substats.enh`); +if (args.savecopdollar) forbiddenEffects.push($effect`Gummed Shoes`); +if (args.saveglove) forbiddenEffects.push($effect`Triple-Sized`, $effect`Invisible Avatar`); +if (args.savelimitedat) forbiddenEffects.push($effect`Chorale of Companionship`); +const manuallyExcludedBuffs = args.explicitlyexcludedefs + .split(",") + .filter((s) => s.length > 0) + .map((s) => toEffect(s)); +if (manuallyExcludedBuffs !== undefined) { + manuallyExcludedBuffs.forEach((ef) => { + forbiddenEffects.push(ef); + }); +} + export function fuelUp(): void { buy(1, $item`all-purpose flower`); use(1, $item`all-purpose flower`); @@ -416,12 +437,12 @@ export function camelFightsLeft(): number { !Witchess.have() && CombatLoversLocket.availableLocketMonsters().includes($monster`Witchess King`) && !CombatLoversLocket.monstersReminisced().includes($monster`Witchess King`) && - !get("instant_saveLocketWitchessKing", false) + !args.witchessking ? 1 : 0; const backups = Witchess.have() || have($item`Kramco Sausage-o-Matic™`) - ? Math.max(11 - get("instant_saveBackups", 0) - get("_backUpUses"), 0) + ? Math.max(11 - args.savebackups - get("_backUpUses"), 0) : 0; // No guarantee that we hit a tentacle, so we ignore that here // Currently does not consider gregs (require free banish + free fight source) @@ -466,24 +487,18 @@ export function computeCombatFrequency(): number { const umbrella = have($item`unbreakable umbrella`) ? -10 : 0; const offhand = umbrella; - const pantogram = - have($item`portable pantogram`) && !get("instant_savePantogram", false) ? -5 : 0; + const pantogram = have($item`portable pantogram`) && !args.savepantogramming ? -5 : 0; const pants = pantogram; - const kgb = - have($item`Kremlin's Greatest Briefcase`) && !get("instant_saveKGBClicks", false) ? -5 : 0; - const codpiece = - have($item`Clan VIP Lounge key`) && !get("instant_saveFloundry", false) ? -10 : 0; - const atlas = get("hasMaydayContract") && !get("instant_saveMayday", false) ? -5 : 0; - const accessories = sumNumbers([kgb, codpiece, atlas]); + const kgb = have($item`Kremlin's Greatest Briefcase`) && !args.savekgb ? -5 : 0; + const atlas = get("hasMaydayContract") && !args.savemayday ? -5 : 0; + const accessories = sumNumbers([kgb, atlas]); const rose = -20; const smoothMovements = have($skill`Smooth Movement`) ? -5 : 0; const sonata = have($skill`The Sonata of Sneakiness`) ? -5 : 0; const favoriteBird = - have($item`Bird-a-Day calendar`) && - get("yourFavoriteBirdMods").includes("Combat Frequency") && - !get("instant_saveFavoriteBird", false) + have($item`Bird-a-Day calendar`) && get("yourFavoriteBirdMods").includes("Combat Frequency") ? toInt( get("yourFavoriteBirdMods") .split(", ") @@ -493,9 +508,8 @@ export function computeCombatFrequency(): number { ) : 0; const shadowWaters = have($item`closed-circuit pay phone`) ? -10 : 0; - const powerfulGlove = - have($item`Powerful Glove`) && !forbiddenEffects.includes($effect`Invisible Avatar`) ? -10 : 0; - const shoeGum = get("hasDetectiveSchool") && !get("instant_saveCopDollars", false) ? -5 : 0; + const powerfulGlove = have($item`Powerful Glove`) && !args.saveglove ? -10 : 0; + const shoeGum = get("hasDetectiveSchool") && !args.savecopdollar ? -5 : 0; const silentRunning = -5; const feelingLonely = have($skill`Feel Lonely`) ? -5 : 0; const effects = sumNumbers([ @@ -634,9 +648,7 @@ export const generalStoreXpEffect: Effect = { export function checkLocketAvailable(): number { const locketAvailable = - (get("instant_saveLocketRedSkeleton", false) ? 1 : 0) + - (get("instant_saveLocketWitchessKing", false) ? 1 : 0) + - (get("instant_saveLocketFactoryWorker", false) ? 1 : 0); + (args.redskeleton ? 1 : 0) + (args.witchessking ? 1 : 0) + (args.factoryworker ? 1 : 0); return locketAvailable; } @@ -805,7 +817,7 @@ export function checkPull(item: Item): boolean { have(item) || get("_roninStoragePulls").split(",").includes(toInt(item).toString()) || storageAmount(item) === 0 || - 5 - get("_roninStoragePulls").split(",").length <= get("instant_savePulls", 0) + 5 - get("_roninStoragePulls").split(",").length <= args.savepulls ) return true; return false; diff --git a/src/main.ts b/src/main.ts index 04664a8..b872195 100644 --- a/src/main.ts +++ b/src/main.ts @@ -33,23 +33,10 @@ import { WeaponDamageQuest } from "./tasks/weapondamage"; import { DonateQuest, logResourceUsage } from "./tasks/donate"; import { SpellDamageQuest } from "./tasks/spelldamage"; import { checkRequirements } from "./sim"; -import { checkResources } from "./resources"; +import { args } from "./args"; const timeProperty = "fullday_elapsedTime"; -export const args = Args.create("FolgerCS", "An automated mid-shiny SCCS script.", { - confirm: Args.boolean({ - help: "If the user must confirm execution of each task.", - default: false, - }), - sim: Args.flag({ help: "Check if you have the requirements to run this script.", setting: "" }), - savedresources: Args.flag({ - help: "Check which resources you have current set to be saved.", - setting: "", - }), - recap: Args.flag({ help: "Recap of today's run.", setting: "" }), -}); - export function main(command?: string): void { sinceKolmafiaRevision(27675); @@ -62,10 +49,6 @@ export function main(command?: string): void { checkRequirements(); return; } - if (args.savedresources) { - checkResources(); - return; - } if (args.recap) { logResourceUsage(); diff --git a/src/relay.ts b/src/relay.ts new file mode 100644 index 0000000..c915611 --- /dev/null +++ b/src/relay.ts @@ -0,0 +1,63 @@ +import { Args } from "grimoire-kolmafia"; +import { write } from "kolmafia"; +import { + ComponentHtml, + ComponentSetting, + generateHTML, + handleApiRequest, + RelayPage, +} from "mafia-shared-relay"; +import { args } from "./args"; + +function convertArgsToHtml(): RelayPage[] { + const metadata = Args.getMetadata(args); + + const pages: RelayPage[] = [ + { page: metadata.options.defaultGroupName ?? "Options", components: [] }, + ]; + + metadata.traverse( + (key, name: string) => { + if (key.setting === "" || key.hidden) return; + + const component: ComponentSetting = { + type: "string", + name: key.key ?? name, + description: key.help || "No Description Provided", + preference: key.setting ?? `${metadata.scriptName}_${key.key ?? name}`, + default: "default" in key ? `${key["default"]}` : "block", + }; + + if (key.valueHelpName === "FLAG" || key.valueHelpName === "BOOLEAN") { + component.type = "boolean"; + } else if (key.options !== undefined) { + component.type = "dropdown"; + component.dropdown = key.options.map(([k, desc]) => { + return { display: desc ?? k, value: k }; + }); + } + pages[0].components.push(component); + }, + (group, name: string) => { + pages.push({ page: name, components: [] }); + } + ); + + pages + .filter((p) => p.components.length > 0) + .forEach((p) => { + const html: ComponentHtml = { + type: "html", + data: `

FolgerCS ${p.page}`, + }; + p.components.splice(0, 0, html); + }); + + return pages.filter((page) => page.components.length > 0); +} + +export function main() { + if (handleApiRequest()) return; + + write(generateHTML(convertArgsToHtml())); +} diff --git a/src/resources.ts b/src/resources.ts index 45dbee5..2b5e227 100644 --- a/src/resources.ts +++ b/src/resources.ts @@ -1,4 +1,4 @@ -import { Effect, Familiar, print, printHtml, toEffect, toInt, totalFreeRests } from "kolmafia"; +/*import { Effect, Familiar, print, printHtml, toEffect, toInt, totalFreeRests } from "kolmafia"; import { $effect, $effects, get, set } from "libram"; class Resource { @@ -262,4 +262,4 @@ export function checkResources(): void { "Type 'set instant_explicitlyExcludedFamiliars=,...,' to exclude using specific familiars during leveling" ); print("Type 'ash remove_property(\"\")' to delete a preference"); -} +}*/ diff --git a/src/tasks/boozedrop.ts b/src/tasks/boozedrop.ts index 29851c9..e28de4c 100644 --- a/src/tasks/boozedrop.ts +++ b/src/tasks/boozedrop.ts @@ -50,6 +50,7 @@ import { checkLocketAvailable, checkTurnSave, checkValue, + forbiddenEffects, fuelUp, logTestSetup, shouldFeelLost, @@ -59,8 +60,8 @@ import { import { chooseFamiliar, sugarItemsAboutToBreak } from "../engine/outfit"; import { CombatStrategy } from "grimoire-kolmafia"; import Macro, { haveFreeBanish } from "../combat"; -import { forbiddenEffects } from "../resources"; import { drive } from "libram/dist/resources/2017/AsdonMartin"; +import { args } from "../args"; function wishOrSpleen(): boolean { if ( @@ -96,9 +97,7 @@ export const BoozeDropQuest: Quest = { { name: "Acquire Clover", completed: () => - have($item`11-leaf clover`) || - get("_cloversPurchased") >= 2 || - get("instant_skipCyclopsEyedrops", false), + have($item`11-leaf clover`) || get("_cloversPurchased") >= 2 || args.savecyclops, do: (): void => { buy(1, $item`chewing gum on a string`); use(1, $item`chewing gum on a string`); @@ -118,9 +117,7 @@ export const BoozeDropQuest: Quest = { { name: "Acquire Government", completed: () => - !have($item`government cheese`) || - get("lastAnticheeseDay") > 0 || - get("instant_skipGovernment", false), + !have($item`government cheese`) || get("lastAnticheeseDay") > 0 || args.savegovernment, do: (): void => { if (myMeat() >= 15000) retrieveItem($item`Desert Bus pass`); if (!have($item`Desert Bus pass`) && !have($item`bitchin' meatcar`)) { @@ -221,7 +218,7 @@ export const BoozeDropQuest: Quest = { have($effect`Sacré Mental`) || !have($item`Sacramento wine`) || myInebriety() >= inebrietyLimit() || - get("instant_saveSacramentoWine", false), + args.sacramentowine, do: (): void => { if (myInebriety() < inebrietyLimit()) { tryAcquiringEffect($effect`Ode to Booze`); @@ -231,36 +228,12 @@ export const BoozeDropQuest: Quest = { }, limit: { tries: 1 }, }, - { - name: "Drink Cabernet Sauvignon", - ready: () => - checkValue("August Scepter", Math.min(2.6, CommunityService.BoozeDrop.prediction - 1)), - completed: () => - have($effect`Cabernet Hunter`) || - (!have($item`bottle of Cabernet Sauvignon`) && - // eslint-disable-next-line libram/verify-constants - (!have($skill`Aug. 31st: Cabernet Sauvignon Day!`) || - get("instant_saveAugustScepter", false))) || - myInebriety() + 3 > inebrietyLimit() || - get("instant_skipCabernetSauvignon", false), - do: (): void => { - if (!have($item`bottle of Cabernet Sauvignon`)) - // eslint-disable-next-line libram/verify-constants - useSkill($skill`Aug. 31st: Cabernet Sauvignon Day!`); - if (myInebriety() + 3 <= inebrietyLimit()) { - tryAcquiringEffect($effect`Ode to Booze`); - drink($item`bottle of Cabernet Sauvignon`); - uneffect($effect`Ode to Booze`); - } - }, - limit: { tries: 1 }, - }, { name: "Pumpkin Juice", completed: () => have($effect`Juiced and Jacked`) || (!have($item`pumpkin`) && !have($item`pumpkin juice`)) || - get("instant_savePumpkins", false), + args.savepumpkin, do: (): void => { if (!have($item`pumpkin juice`)) create($item`pumpkin juice`, 1); use($item`pumpkin juice`, 1); @@ -273,17 +246,26 @@ export const BoozeDropQuest: Quest = { completed: () => have($effect`Spitting Rhymes`) || !have($item`2002 Mr. Store Catalog`) || - get("availableMrStore2002Credits", 0) <= get("instant_saveCatalogCredits", 0) || forbiddenEffects.includes($effect`Spitting Rhymes`), do: (): void => { if ( - !have($item`Loathing Idol Microphone`) || - $item`Loathing Idol Microphone (75% charged)` + !have($item`Loathing Idol Microphone`) && + !have($item`Loathing Idol Microphone (75% charged)`) && + !have($item`Loathing Idol Microphone (50% charged)`) && + !have($item`Loathing Idol Microphone (25% charged)`) ) { buy($coinmaster`Mr. Store 2002`, 1, $item`Loathing Idol Microphone`); } withChoice(1505, 3, () => - use($item`Loathing Idol Microphone` || $item`Loathing Idol Microphone (75% charged)`) + use( + have($item`Loathing Idol Microphone`) + ? $item`Loathing Idol Microphone` + : have($item`Loathing Idol Microphone (75% charged)`) + ? $item`Loathing Idol Microphone (75% charged)` + : have($item`Loathing Idol Microphone (50% charged)`) + ? $item`Loathing Idol Microphone (50% charged)` + : $item`Loathing Idol Microphone (25% charged)` + ) ); }, limit: { tries: 1 }, @@ -291,10 +273,7 @@ export const BoozeDropQuest: Quest = { { name: "Red-soled high heels", ready: () => checkValue("2002", 3), - completed: () => - have($item`red-soled high heels`) || - !have($item`2002 Mr. Store Catalog`) || - get("availableMrStore2002Credits", 0) <= get("instant_saveCatalogCredits", 0), + completed: () => have($item`red-soled high heels`) || !have($item`2002 Mr. Store Catalog`), do: (): void => { if (!have($item`Letter from Carrie Bradshaw`)) { buy($coinmaster`Mr. Store 2002`, 1, $item`Letter from Carrie Bradshaw`); @@ -308,8 +287,7 @@ export const BoozeDropQuest: Quest = { completed: () => !have($skill`Visit your Favorite Bird`) || get("_favoriteBirdVisited") || - !get("yourFavoriteBirdMods").includes("Item Drops") || - get("instant_saveFavoriteBird", false), + !get("yourFavoriteBirdMods").includes("Item Drops"), do: () => useSkill($skill`Visit your Favorite Bird`), limit: { tries: 1 }, }, @@ -329,7 +307,8 @@ export const BoozeDropQuest: Quest = { }, { name: "Driving Observantly", - completed: () => have($effect`Driving Observantly`) || !get("instant_useAsdon", false), + ready: () => args.asdon, + completed: () => have($effect`Driving Observantly`), do: (): void => { fuelUp(), drive($effect`Driving Observantly`); }, @@ -407,16 +386,13 @@ export const BoozeDropQuest: Quest = { }, completed: () => CommunityService.BoozeDrop.isDone(), do: (): void => { - const maxTurns = get("instant_boozeTestTurnLimit", 30); + const maxTurns = args.boozelimit; const testTurns = CommunityService.BoozeDrop.actualCost(); if (testTurns > maxTurns) { print(`Expected to take ${testTurns}, which is more than ${maxTurns}.`, "red"); print("Either there was a bug, or you are under-prepared for this test", "red"); print("Manually complete the test if you think this is fine.", "red"); - print( - "You may also increase the turn limit by typing 'set instant_boozeTestTurnLimit='", - "red" - ); + print("You may also increase the turn limit in the relay", "red"); } CommunityService.BoozeDrop.run(() => logTestSetup(CommunityService.BoozeDrop), maxTurns); }, diff --git a/src/tasks/earlyleveling.ts b/src/tasks/earlyleveling.ts index c6fd4e7..8acb4a9 100644 --- a/src/tasks/earlyleveling.ts +++ b/src/tasks/earlyleveling.ts @@ -55,6 +55,7 @@ import Macro from "../combat"; import { mapMonster } from "libram/dist/resources/2020/Cartography"; import { chooseRift } from "libram/dist/resources/2023/ClosedCircuitPayphone"; import { boomBoxProfit } from "../lib"; +import { args } from "../args"; const useParkaSpit = have($item`Fourth of May Cosplay Saber`) && have($skill`Feel Envy`); const baseBoozes = $items`bottle of rum, boxed wine, bottle of gin, bottle of vodka, bottle of tequila, bottle of whiskey`; @@ -135,10 +136,7 @@ function sellMiscellaneousItems(): void { export const earlyLevelingQuest: Quest = { name: "Early Leveling", completed: () => - get("pizzaOfLegendEaten") || - !get("instant_skipBorrowedTime", false) || - get("instant_useAsdon", false) || - CommunityService.CoilWire.isDone(), + get("pizzaOfLegendEaten") || !args.skipbt || args.asdon || CommunityService.CoilWire.isDone(), tasks: [ { name: "Install Trainset", @@ -208,8 +206,7 @@ export const earlyLevelingQuest: Quest = { }, completed: () => CombatLoversLocket.monstersReminisced().includes($monster`red skeleton`) || - !CombatLoversLocket.availableLocketMonsters().includes($monster`red skeleton`) || - get("instant_saveLocketRedSkeleton", false), + !CombatLoversLocket.availableLocketMonsters().includes($monster`red skeleton`), do: () => CombatLoversLocket.reminisce($monster`red skeleton`), combat: get("_daycareGymScavenges") ? new CombatStrategy().macro( @@ -257,7 +254,7 @@ export const earlyLevelingQuest: Quest = { modifier: `${baseOutfit().modifier}, -equip miniature crystal ball`, }), post: (): void => { - if (have($item`MayDay™ supply package`) && !get("instant_saveMayday", false)) + if (have($item`MayDay™ supply package`) && args.savemayday) use($item`MayDay™ supply package`, 1); if (have($item`space blanket`)) autosell($item`space blanket`, 1); use($item`red box`, 1); @@ -337,7 +334,6 @@ export const earlyLevelingQuest: Quest = { !have($skill`Just the Facts`) || get("_monstersMapped") >= 3 || have($item`pocket wish`, 1) || - get("instant_saveGenie", false) || myClass() !== $class`Seal Clubber` || ((get("_shatteringPunchUsed") >= 3 || !have($skill`Shattering Punch`)) && (get("_gingerbreadMobHitUsed") || !have($skill`Gingerbread Mob Hit`))), @@ -435,7 +431,7 @@ export const earlyLevelingQuest: Quest = { get("_roninStoragePulls") .split(",") .includes(toInt($item`Pizza of Legend`).toString()) || - get("instant_skipPizzaOfLegend", false), + args.pizza, do: (): void => { if (storageAmount($item`Pizza of Legend`) === 0) { print("Uh oh! You do not seem to have a Pizza of Legend in Hagnk's", "red"); @@ -474,7 +470,7 @@ export const earlyLevelingQuest: Quest = { get("_roninStoragePulls") .split(",") .includes(toInt($item`Calzone of Legend`).toString()) || - get("instant_skipCalzoneOfLegend", false), + args.calzone, do: (): void => { if (storageAmount($item`Calzone of Legend`) === 0) { print("Uh oh! You do not seem to have a Calzone of Legend in Hagnk's", "red"); diff --git a/src/tasks/familiarweight.ts b/src/tasks/familiarweight.ts index 09ca5d0..3f15cd3 100644 --- a/src/tasks/familiarweight.ts +++ b/src/tasks/familiarweight.ts @@ -37,6 +37,7 @@ import { chooseHeaviestFamiliar, sugarItemsAboutToBreak, } from "../engine/outfit"; +import { args } from "../args"; export const FamiliarWeightQuest: Quest = { name: "Familiar Weight", @@ -47,7 +48,7 @@ export const FamiliarWeightQuest: Quest = { completed: () => !have($item`hewn moon-rune spoon`) || get("moonTuned") || - get("instant_saveMoonTune", false) || + args.savemoontune || mySign() === "Platypus", do: (): void => { cliExecute("spoon platypus"); @@ -55,7 +56,7 @@ export const FamiliarWeightQuest: Quest = { }, { name: "Late Eat Deep Dish", - ready: () => get("instant_lateDeepDish", false), + ready: () => args.latedeepdish, completed: () => get("deepDishOfLegendEaten") || !have($item`Deep Dish of Legend`), do: (): void => { if (have($item`familiar scrapbook`)) { @@ -71,7 +72,7 @@ export const FamiliarWeightQuest: Quest = { !have($skill`Chorale of Companionship`) || have($effect`Chorale of Companionship`) || myClass() !== $class`Accordion Thief` || - get("instant_saveLimitedAT", false), + args.savelimitedat, do: (): void => { shrugAT(); cliExecute("cast 1 Chorale of Companionship"); @@ -171,7 +172,7 @@ export const FamiliarWeightQuest: Quest = { } }, do: (): void => { - const maxTurns = get("instant_famTestTurnLimit", 50); + const maxTurns = args.familiarlimit; const testTurns = CommunityService.FamiliarWeight.actualCost(); if (testTurns > maxTurns) { print(`Expected to take ${testTurns}, which is more than ${maxTurns}.`, "red"); diff --git a/src/tasks/hotres.ts b/src/tasks/hotres.ts index 7fdc7d5..4f2a9f4 100644 --- a/src/tasks/hotres.ts +++ b/src/tasks/hotres.ts @@ -17,6 +17,7 @@ import { Quest } from "../engine/task"; import { checkTurnSave, checkValue, logTestSetup, tryAcquiringEffect, wishFor } from "../lib"; import { chooseFamiliar, sugarItemsAboutToBreak } from "../engine/outfit"; import Macro from "../combat"; +import { args } from "../args"; export const HotResQuest: Quest = { name: "Hot Res", @@ -57,7 +58,7 @@ export const HotResQuest: Quest = { completed: () => CombatLoversLocket.monstersReminisced().includes($monster`factory worker (female)`) || !CombatLoversLocket.availableLocketMonsters().includes($monster`factory worker (female)`) || - get("instant_saveLocketFactoryWorker", false) || + args.factoryworker || checkValue("Locket", Math.min(14, CommunityService.HotRes.prediction - 1)), do: () => CombatLoversLocket.reminisce($monster`factory worker (female)`), outfit: () => ({ @@ -98,8 +99,7 @@ export const HotResQuest: Quest = { completed: () => !have($skill`Visit your Favorite Bird`) || get("_favoriteBirdVisited") || - !get("yourFavoriteBirdMods").includes("Hot Resistance") || - get("instant_saveFavoriteBird", false), + !get("yourFavoriteBirdMods").includes("Hot Resistance"), do: () => useSkill($skill`Visit your Favorite Bird`), limit: { tries: 1 }, }, @@ -111,7 +111,7 @@ export const HotResQuest: Quest = { if ( get("_kgbClicksUsed") < 22 && have($item`Kremlin's Greatest Briefcase`) && - !get("instant_saveKGBClicks", false) + !args.savekgb ) cliExecute("briefcase e hot"); @@ -146,7 +146,7 @@ export const HotResQuest: Quest = { }, completed: () => CommunityService.HotRes.isDone(), do: (): void => { - const maxTurns = get("instant_hotTestTurnLimit", 35); + const maxTurns = args.hotlimit; const testTurns = CommunityService.HotRes.actualCost(); if (testTurns > maxTurns) { print(`Expected to take ${testTurns}, which is more than ${maxTurns}.`, "red"); diff --git a/src/tasks/leveling.ts b/src/tasks/leveling.ts index ebb753b..6ea8597 100644 --- a/src/tasks/leveling.ts +++ b/src/tasks/leveling.ts @@ -42,7 +42,6 @@ import { takeStorage, toInt, toItem, - totalFreeRests, use, useSkill, visitUrl, @@ -82,10 +81,10 @@ import { boomBoxProfit, burnLibram, camelFightsLeft, - checkLocketAvailable, checkPull, checkValue, chooseLibram, + forbiddenEffects, fuelUp, generalStoreXpEffect, getSynthExpBuff, @@ -113,7 +112,6 @@ import { unbreakableUmbrella, } from "../engine/outfit"; import Macro, { haveFreeBanish, haveFreeKill } from "../combat"; -import { forbiddenEffects } from "../resources"; import { mapMonster } from "libram/dist/resources/2020/Cartography"; import { chooseQuest, @@ -122,8 +120,9 @@ import { } from "libram/dist/resources/2023/ClosedCircuitPayphone"; import { drive } from "libram/dist/resources/2017/AsdonMartin"; import { cheatCard, getRemainingCheats } from "libram/dist/resources/2015/DeckOfEveryCard"; +import { args } from "../args"; -const useCinch = !get("instant_saveCinch", false); +const useCinch = args.savecinch >= 100 - get("_cinchUsed"); const baseBoozes = $items`bottle of rum, boxed wine, bottle of gin, bottle of vodka, bottle of tequila, bottle of whiskey`; const freeFightMonsters: Monster[] = $monsters`Witchess Bishop, Witchess King, Witchess Witch, sausage goblin, Eldritch Tentacle`; @@ -382,7 +381,6 @@ export const LevelingQuest: Quest = { completed: () => have($effect`Hot in Herre`) || !have($item`2002 Mr. Store Catalog`) || - get("availableMrStore2002Credits", 0) <= get("instant_saveCatalogCredits", 0) || forbiddenEffects.includes($effect`Hot in Herre`), do: (): void => { if (!have($item`Charter: Nellyville`)) { @@ -394,7 +392,8 @@ export const LevelingQuest: Quest = { }, { name: "Driving Recklessly", - completed: () => have($effect`Driving Recklessly`) || !get("instant_useAsdon", false), + ready: () => args.asdon, + completed: () => have($effect`Driving Recklessly`), do: (): void => { fuelUp(), drive($effect`Driving Recklessly`); }, @@ -413,7 +412,7 @@ export const LevelingQuest: Quest = { name: "Synth Exp Buff", completed: () => !have($skill`Sweet Synthesis`) || - get("instant_skipSynthExp", false) || + args.synthxp || have(synthExpBuff) || getValidComplexCandyPairs().length === 0, do: (): void => getSynthExpBuff(), @@ -421,10 +420,9 @@ export const LevelingQuest: Quest = { }, { name: "Pull Deep Dish of Legend", + ready: () => !args.deepdish, completed: () => - checkPull($item`Deep Dish of Legend`) || - have($effect`In the Depths`) || - get("instant_skipDeepDishOfLegend", false), + checkPull($item`Deep Dish of Legend`) || have($effect`In the Depths`) || args.deepdish, prepare: (): void => { cliExecute(`maximize ${myPrimestat()} experience percent`); }, @@ -444,9 +442,7 @@ export const LevelingQuest: Quest = { { name: "Pull Calzone of Legend", completed: () => - checkPull($item`Calzone of Legend`) || - have($effect`In the 'zone zone!`) || - get("instant_skipCalzoneOfLegend", false), + checkPull($item`Calzone of Legend`) || have($effect`In the 'zone zone!`) || args.calzone, prepare: (): void => { cliExecute(`maximize ${myPrimestat()} experience percent`); }, @@ -469,9 +465,7 @@ export const LevelingQuest: Quest = { { name: "Pull Pizza of Legend", completed: () => - checkPull($item`Pizza of Legend`) || - have($effect`Endless Drool`) || - get("instant_skipPizzaOfLegend", false), + checkPull($item`Pizza of Legend`) || have($effect`Endless Drool`) || args.pizza, do: (): void => { if (storageAmount($item`Pizza of Legend`) === 0) { print("Uh oh! You do not seem to have a Pizza of Legend in Hagnk's", "red"); @@ -487,7 +481,7 @@ export const LevelingQuest: Quest = { }, { name: "Pull Buddy Bjorn", - ready: () => get("instant_experimentPulls", true), + ready: () => args.dopulls, completed: () => checkPull($item`Buddy Bjorn`), do: (): void => { takeStorage($item`Buddy Bjorn`, 1); @@ -496,7 +490,7 @@ export const LevelingQuest: Quest = { }, { name: "Pull Stick-Knife", - ready: () => get("instant_experimentPulls", true), + ready: () => args.dopulls, completed: () => checkPull($item`Stick-Knife of Loathing`), do: (): void => { takeStorage($item`Stick-Knife of Loathing`, 1); @@ -505,7 +499,7 @@ export const LevelingQuest: Quest = { }, { name: "Pull Repaid Diaper", - ready: () => get("instant_experimentPulls", true), + ready: () => args.dopulls, completed: () => checkPull($item`Great Wolf's beastly trousers`) || checkPull($item`repaid diaper`), do: (): void => { @@ -515,7 +509,7 @@ export const LevelingQuest: Quest = { }, { name: "Pull Beastly Trousers", - ready: () => get("instant_experimentPulls", true), + ready: () => args.dopulls, completed: () => checkPull($item`Great Wolf's beastly trousers`) || have($item`astral trousers`), do: (): void => { @@ -525,7 +519,7 @@ export const LevelingQuest: Quest = { }, { name: "Pull Staff of Simering Hatred", - ready: () => get("instant_experimentPulls", true), + ready: () => args.dopulls, completed: () => checkPull($item`Staff of Simmering Hatred`), do: (): void => { takeStorage($item`Staff of Simmering Hatred`, 1); @@ -534,7 +528,7 @@ export const LevelingQuest: Quest = { }, { name: "Pull Tobiko Marble Soda", - ready: () => get("instant_experimentPulls", true), + ready: () => args.dopulls, completed: () => checkPull($item`tobiko marble soda`), do: (): void => { takeStorage($item`tobiko marble soda`, 1); @@ -561,7 +555,7 @@ export const LevelingQuest: Quest = { ready: () => have($item`Deck of Every Card`), completed: () => getRemainingCheats() <= 2 || - get("instant_saveDeck", false) || + args.savedeck || have($effect`Giant Growth`) || !have($skill`Giant Growth`), do: (): void => { @@ -573,7 +567,7 @@ export const LevelingQuest: Quest = { name: "Pull Daypass", completed: () => powerlevelingLocation() !== $location`Uncle Gator's Country Fun-Time Liquid Waste Sluice` || - 5 - get("_roninStoragePulls").split(",").length >= get("instant_savePulls", 0) || + 5 - get("_roninStoragePulls").split(",").length >= args.savepulls || get("stenchAirportAlways") || get("_stenchAirportToday"), do: (): void => { @@ -614,9 +608,7 @@ export const LevelingQuest: Quest = { }, { name: "Restore mp", - completed: () => - get("timesRested") >= totalFreeRests() - get("instant_saveFreeRests", 0) || - myMp() >= Math.min(200, myMaxmp()), + completed: () => get("timesRested") >= args.saverests || myMp() >= Math.min(200, myMaxmp()), prepare: (): void => { if (have($item`Newbiesport™ tent`)) use($item`Newbiesport™ tent`); }, @@ -658,9 +650,7 @@ export const LevelingQuest: Quest = { { name: "Eat Deep Dish", completed: () => - get("deepDishOfLegendEaten") || - !have($item`Deep Dish of Legend`) || - get("instant_lateDeepDish", false), + get("deepDishOfLegendEaten") || !have($item`Deep Dish of Legend`) || args.deepdish, prepare: (): void => { cliExecute(`maximize ${myPrimestat()} experience percent`); }, @@ -682,9 +672,7 @@ export const LevelingQuest: Quest = { { name: "Cast Perfect Freeze", completed: () => - !have($skill`Perfect Freeze`) || - get("_perfectFreezeUsed") || - get("instant_savePerfectFreeze", false), + !have($skill`Perfect Freeze`) || get("_perfectFreezeUsed") || args.perfectfreeze, prepare: () => restoreMp(mpCost($skill`Perfect Freeze`)), do: () => useSkill($skill`Perfect Freeze`), limit: { tries: 1 }, @@ -695,7 +683,7 @@ export const LevelingQuest: Quest = { myInebriety() >= 3 || !have($item`perfect ice cube`) || !baseBoozes.some((it) => have(it)) || - get("instant_savePerfectFreeze", false), + args.perfectfreeze, prepare: (): void => { cliExecute(`maximize ${myPrimestat()} experience percent`); }, @@ -734,7 +722,7 @@ export const LevelingQuest: Quest = { }, { name: "Consult Fortune Teller", - completed: () => get("_clanFortuneBuffUsed") || get("instant_saveFortuneTeller", false), + completed: () => get("_clanFortuneBuffUsed") || args.savefortune, do: () => cliExecute(`fortune buff ${statToMaximizerString(myPrimestat())}`), limit: { tries: 1 }, }, @@ -767,22 +755,17 @@ export const LevelingQuest: Quest = { ready: () => myLevel() >= 11, completed: () => myInebriety() >= inebrietyLimit() || - (!have($item`astral six-pack`) && - itemAmount($item`astral pilsner`) <= get("instant_saveAstralPilsners", 0)), + (!have($item`astral six-pack`) && itemAmount($item`astral pilsner`) <= args.astralpils), prepare: (): void => { cliExecute(`maximize ${myPrimestat()} experience percent`); tryAcquiringEffect($effect`Ode to Booze`); }, do: (): void => { if (have($item`astral six-pack`)) use($item`astral six-pack`, 1); - if (itemAmount($item`astral pilsner`) > get("instant_saveAstralPilsners", 0)) - drink($item`astral pilsner`, 1); + if (itemAmount($item`astral pilsner`) > args.astralpils) drink($item`astral pilsner`, 1); }, post: (): void => { - if ( - !have($item`astral six-pack`) && - itemAmount($item`astral pilsner`) <= get("instant_saveAstralPilsners", 0) - ) + if (!have($item`astral six-pack`) && itemAmount($item`astral pilsner`) <= args.astralpils) uneffect($effect`Ode to Booze`); }, limit: { tries: 6 }, @@ -828,7 +811,7 @@ export const LevelingQuest: Quest = { get("_monstersMapped") >= 3 || have($item`li'l ninja costume`) || !have($familiar`Trick-or-Treating Tot`) || - get("instant_skipMappingNinja", false), + args.ninjamap, do: () => mapMonster($location`The Haiku Dungeon`, $monster`amateur ninja`), combat: new CombatStrategy().macro( Macro.if_( @@ -854,7 +837,7 @@ export const LevelingQuest: Quest = { { name: "Free Fight Leafy Boys", completed: () => - get("_leafMonstersFought", 0) >= 5 || !have($item`inflammable leaf`, 11) || saveLeafyBoys(), + get("_leafMonstersFought", 0) >= 4 || !have($item`inflammable leaf`, 11) || saveLeafyBoys(), do: (): void => { visitUrl("campground.php?preaction=leaves"); visitUrl("choice.php?pwd&whichchoice=1510&option=1&leaves=11"); @@ -1059,7 +1042,7 @@ export const LevelingQuest: Quest = { completed: () => CombatLoversLocket.monstersReminisced().includes($monster`red skeleton`) || !CombatLoversLocket.availableLocketMonsters().includes($monster`red skeleton`) || - get("instant_saveLocketRedSkeleton", false) || + args.redskeleton || checkValue("Locket", 4), do: () => CombatLoversLocket.reminisce($monster`red skeleton`), combat: new CombatStrategy().macro( @@ -1164,9 +1147,7 @@ export const LevelingQuest: Quest = { { name: "Restore cinch", completed: () => - get("timesRested") >= totalFreeRests() - get("instant_saveFreeRests", 0) || - get("_cinchUsed", 0) <= 95 || - !useCinch, + get("timesRested") >= args.saverests || get("_cinchUsed", 0) <= 95 || !useCinch, prepare: (): void => { if (have($item`Newbiesport™ tent`)) use($item`Newbiesport™ tent`); }, @@ -1200,8 +1181,7 @@ export const LevelingQuest: Quest = { Macro.if_($monster`fluffy bunny`, Macro.banish()) .externalIf( get("_monsterHabitatsFightsLeft") <= 1 && - toInt(get("_monsterHabitatsRecalled")) < - 3 - toInt(get("instant_saveMonsterHabitats", 0)) && + toInt(get("_monsterHabitatsRecalled")) < 3 - toInt(args.savehabitats) && have($skill`Recall Facts: Monster Habitats`) && (haveFreeBanish() || Array.from(getBanishedMonsters().values()).includes($monster`fluffy bunny`)), @@ -1230,7 +1210,7 @@ export const LevelingQuest: Quest = { completed: () => !have($item`backup camera`) || !freeFightMonsters.includes(get("lastCopyableMonster") ?? $monster.none) || - get("_backUpUses") >= 11 - clamp(get("instant_saveBackups", 0), 0, 11) || + get("_backUpUses") >= 11 - clamp(args.savebackups, 0, 11) || myBasestat(myPrimestat()) >= 190, // no longer need to back up Witchess Kings do: $location`The Dire Warren`, combat: new CombatStrategy().macro( @@ -1267,7 +1247,7 @@ export const LevelingQuest: Quest = { combat: new CombatStrategy().macro(() => Macro.externalIf( get("_monsterHabitatsFightsLeft") <= 1 && - toInt(get("_monsterHabitatsRecalled")) < 3 - get("instant_saveMonsterHabitats", 0) && + toInt(get("_monsterHabitatsRecalled")) < 3 - args.savehabitats && have($skill`Recall Facts: Monster Habitats`) && (haveFreeBanish() || Array.from(getBanishedMonsters().values()).includes($monster`fluffy bunny`)), @@ -1369,7 +1349,6 @@ export const LevelingQuest: Quest = { !have($skill`Just the Facts`) || get("_monstersMapped") >= 3 || have($item`pocket wish`, 1) || - get("instant_saveGenie", false) || myClass() !== $class`Seal Clubber` || ((get("_shatteringPunchUsed") >= 3 || !have($skill`Shattering Punch`)) && (get("_gingerbreadMobHitUsed") || !have($skill`Gingerbread Mob Hit`))), @@ -1445,14 +1424,14 @@ export const LevelingQuest: Quest = { restoreMp(50); }, completed: () => - get("_witchessFights") >= 4 - (get("instant_skipBishopsForRoyalty", false) ? 2 : 0) || + get("_witchessFights") >= 4 - (args.skipbishop ? 2 : 0) || !Witchess.have() || - get("instant_saveWitchess", false), + args.witchess, do: () => Witchess.fightPiece($monster`Witchess Bishop`), combat: new CombatStrategy().macro(() => Macro.externalIf( get("_monsterHabitatsFightsLeft") <= 1 && - toInt(get("_monsterHabitatsRecalled")) < 3 - get("instant_saveMonsterHabitats", 0) && + toInt(get("_monsterHabitatsRecalled")) < 3 - args.savehabitats && have($skill`Recall Facts: Monster Habitats`) && (haveFreeBanish() || Array.from(getBanishedMonsters().values()).includes($monster`fluffy bunny`)), @@ -1540,7 +1519,7 @@ export const LevelingQuest: Quest = { { name: "Extra Camelspit Leveling", ready: () => get("camelSpit") >= 94 && myBasestat(myPrimestat()) >= targetBaseMyst, - completed: () => !get("instant_camelExperiment", false) || get("camelSpit") >= 100, + completed: () => !args.camelhat || get("camelSpit") >= 100, do: powerlevelingLocation(), prepare: (): void => { restoreHp(clamp(1000, myMaxhp() / 2, myMaxhp())); @@ -1589,25 +1568,10 @@ export const LevelingQuest: Quest = { boomBoxProfit(); }, }, - { - name: "Acquire Wad of Dough", - completed: () => - have($item`wad of dough`) || - (get("instant_saveHoneyBun", false) && get("instant_saveWileyWheyBar", false)), - do: (): void => { - if (myMeat() < 100) throw new Error("Insufficient Meat to purchase all-purpose flower!"); - if (!have($item`all-purpose flower`)) buy($item`all-purpose flower`, 1); - use($item`all-purpose flower`, 1); - }, - post: (): void => { - if (!have($item`flat dough`)) use($item`wad of dough`, 1); - }, - limit: { tries: 1 }, - }, { name: "Drink Bee's Knees", after: ["Powerlevel"], - completed: () => have($effect`On the Trolley`) || get("instant_saveBeesKnees", false), + completed: () => have($effect`On the Trolley`) || args.beesknees, do: (): void => { if (myMeat() < 500) throw new Error("Insufficient Meat to purchase Bee's Knees!"); tryAcquiringEffect($effect`Ode to Booze`); @@ -1641,11 +1605,7 @@ export const LevelingQuest: Quest = { have($item`dented scepter`) || get("_witchessFights") >= 5 || !Witchess.have() || - get("instant_saveWitchess", false) || - (get("instant_maximizeProfit", false) && - checkLocketAvailable() === 3 && - get("valueOfAdventure", 3750) * get("embezzlerMultiplier", 2.5) > - get("valueOfAdventure", 3750) * 2), + args.witchess, do: () => Witchess.fightPiece($monster`Witchess King`), combat: new CombatStrategy().macro(Macro.default(useCinch)), outfit: baseOutfit, @@ -1674,7 +1634,7 @@ export const LevelingQuest: Quest = { have($item`battle broom`) || get("_witchessFights") >= 5 || !Witchess.have() || - get("instant_saveWitchess", false), + args.witchess, do: () => Witchess.fightPiece($monster`Witchess Witch`), combat: new CombatStrategy().macro( Macro.trySkill($skill`Curse of Weaksauce`) @@ -1715,7 +1675,7 @@ export const LevelingQuest: Quest = { have($item`very pointy crown`) || get("_witchessFights") >= 5 || !Witchess.have() || - get("instant_saveWitchess", false), + args.witchess, do: () => Witchess.fightPiece($monster`Witchess Queen`), combat: new CombatStrategy().macro(Macro.attack().repeat()), outfit: { @@ -1745,13 +1705,13 @@ export const LevelingQuest: Quest = { completed: () => CombatLoversLocket.monstersReminisced().includes($monster`Witchess King`) || !CombatLoversLocket.availableLocketMonsters().includes($monster`Witchess King`) || - get("instant_saveLocketWitchessKing", false) || + args.witchessking || have($item`dented scepter`), do: () => CombatLoversLocket.reminisce($monster`Witchess King`), combat: new CombatStrategy().macro(() => Macro.externalIf( get("_monsterHabitatsFightsLeft") <= 1 && - get("_monsterHabitatsRecalled") < 3 - get("instant_saveMonsterHabitats", 0) && + get("_monsterHabitatsRecalled") < 3 - args.savehabitats && have($skill`Recall Facts: Monster Habitats`) && (haveFreeBanish() || Array.from(getBanishedMonsters().values()).includes($monster`fluffy bunny`)), diff --git a/src/tasks/noncombat.ts b/src/tasks/noncombat.ts index 2daa319..afebb81 100644 --- a/src/tasks/noncombat.ts +++ b/src/tasks/noncombat.ts @@ -22,6 +22,7 @@ import { import { CombatStrategy } from "grimoire-kolmafia"; import Macro from "../combat"; import { drive } from "libram/dist/resources/2017/AsdonMartin"; +import { args } from "../args"; export const NoncombatQuest: Quest = { name: "Noncombat", @@ -46,14 +47,14 @@ export const NoncombatQuest: Quest = { completed: () => !have($skill`Visit your Favorite Bird`) || get("_favoriteBirdVisited") || - !get("yourFavoriteBirdMods").includes("Combat Frequency") || - get("instant_saveFavoriteBird", false), + !get("yourFavoriteBirdMods").includes("Combat Frequency"), do: () => useSkill($skill`Visit your Favorite Bird`), limit: { tries: 1 }, }, { name: "Driving Stealthily", - completed: () => have($effect`Driving Stealthily`) || !get("instant_useAsdon", false), + ready: () => args.asdon, + completed: () => have($effect`Driving Stealthily`), do: (): void => { fuelUp(), drive($effect`Driving Stealthily`); }, @@ -62,9 +63,7 @@ export const NoncombatQuest: Quest = { { name: "Invisible Avatar", completed: () => - have($effect`Invisible Avatar`) || - !have($item`Powerful Glove`) || - get("instant_savePowerfulGlove", false), + have($effect`Invisible Avatar`) || !have($item`Powerful Glove`) || args.saveglove, do: (): void => { equip($slot`acc3`, $item`Powerful Glove`); useSkill($skill`CHEAT CODE: Invisible Avatar`); @@ -89,7 +88,7 @@ export const NoncombatQuest: Quest = { if ( get("_kgbClicksUsed") < 22 && have($item`Kremlin's Greatest Briefcase`) && - !get("instant_saveKGBClicks", false) + !args.savekgb ) cliExecute("briefcase e -combat"); const usefulEffects: Effect[] = [ @@ -116,7 +115,7 @@ export const NoncombatQuest: Quest = { wishFor($effect`Disquiet Riot`); }, do: (): void => { - const maxTurns = get("instant_comTestTurnLimit", 12); + const maxTurns = args.noncomlimit; const testTurns = CommunityService.Noncombat.actualCost(); if (testTurns > maxTurns) { print(`Expected to take ${testTurns}, which is more than ${maxTurns}.`, "red"); diff --git a/src/tasks/runstart.ts b/src/tasks/runstart.ts index 5aa4245..9a9e6a4 100644 --- a/src/tasks/runstart.ts +++ b/src/tasks/runstart.ts @@ -33,14 +33,12 @@ import { storageAmount, takeStorage, toInt, - totalFreeRests, use, useFamiliar, useSkill, visitUrl, } from "kolmafia"; import { - $coinmaster, $effect, $familiar, $item, @@ -65,6 +63,7 @@ import { getGarden, goVote, statToMaximizerString, tryAcquiringEffect } from ".. import Macro from "../combat"; import { mapMonster } from "libram/dist/resources/2020/Cartography"; import { baseOutfit, chooseFamiliar, unbreakableUmbrella } from "../engine/outfit"; +import { args } from "../args"; const bestSIT = mallPrice($item`hollow rock`) + mallPrice($item`lump of loyal latite`) > @@ -132,8 +131,7 @@ export const RunStartQuest: Quest = { use($item`pork elf goodies sack`); autosell($item`hamethyst`, itemAmount($item`hamethyst`)); autosell($item`baconstone`, itemAmount($item`baconstone`)); - if (!get("instant_savePorquoise", false)) - autosell($item`porquoise`, itemAmount($item`porquoise`)); + if (!args.savepurqoise) autosell($item`porquoise`, itemAmount($item`porquoise`)); }, limit: { tries: 1 }, }, @@ -151,7 +149,7 @@ export const RunStartQuest: Quest = { }, { name: "Get Floundry item", - completed: () => get("_floundryItemCreated") || get("instant_saveFloundry", false), + completed: () => get("_floundryItemCreated") || args.savefloundry, do: (): void => { retrieveItem($item`carpe`); }, @@ -165,33 +163,16 @@ export const RunStartQuest: Quest = { visitUrl(`inv_use.php?whichitem=${toInt($item`2002 Mr. Store Catalog`)}&which=f0&pwd`), limit: { tries: 1 }, }, - { - name: "Use Meat Butler", - completed: () => - !have($item`2002 Mr. Store Catalog`) || - get("availableMrStore2002Credits") <= get("instant_saveCatalogCredits", 0) || - get("instant_skipMeatButler", false) || - haveInCampground($item`Meat Butler`), - do: (): void => { - if (!have($item`Meat Butler`)) buy($coinmaster`Mr. Store 2002`, 1, $item`Meat Butler`); - use($item`Meat Butler`, 1); - }, - limit: { tries: 1 }, - }, { name: "KGB", completed: () => - get("_kgbClicksUsed") > 0 || - !have($item`Kremlin's Greatest Briefcase`) || - get("instant_saveKGBClicks", false), + get("_kgbClicksUsed") > 0 || !have($item`Kremlin's Greatest Briefcase`) || args.savekgb, do: () => cliExecute("briefcase e ml"), limit: { tries: 1 }, }, { name: "Restore mp", - completed: () => - get("timesRested") >= totalFreeRests() - get("instant_saveFreeRests", 0) || - myMp() >= Math.min(200, myMaxmp()), + completed: () => get("timesRested") >= args.saverests || myMp() >= Math.min(200, myMaxmp()), prepare: (): void => { if (have($item`Newbiesport™ tent`)) use($item`Newbiesport™ tent`); }, @@ -217,7 +198,7 @@ export const RunStartQuest: Quest = { create($item`borrowed time`, 1); else takeStorage($item`borrowed time`, 1); }, - completed: () => get("_borrowedTimeUsed") || get("instant_skipBorrowedTime", false), + completed: () => get("_borrowedTimeUsed") || args.skipbt, do: (): void => { if (storageAmount($item`borrowed time`) === 0 && !have($item`borrowed time`)) { print("Uh oh! You do not seem to have a borrowed time in Hagnk's", "red"); @@ -235,17 +216,14 @@ export const RunStartQuest: Quest = { ready: () => Object.keys(reverseNumberology()).includes("69"), completed: () => get("_universeCalculated") >= - (get("skillLevel144") > 3 ? 3 : get("skillLevel144")) - get("instant_saveNumberology", 0), + (get("skillLevel144") > 3 ? 3 : get("skillLevel144")) - args.savenumberology, do: () => cliExecute("numberology 69"), limit: { tries: 3 }, }, { name: "Get Camel Hat", - completed: () => - have($item`dromedary drinking helmet`) || - get("instant_saveClipArt", false) || - !have($familiar`Melodramedary`) || - !get("instant_camelExperiment", false), + ready: () => args.camelhat, + completed: () => have($item`dromedary drinking helmet`) || !have($familiar`Melodramedary`), do: (): void => { if (!have($item`box of Familiar Jacks`)) create($item`box of Familiar Jacks`, 1); @@ -257,10 +235,7 @@ export const RunStartQuest: Quest = { { name: "Summon Sugar Sheets", completed: () => - !have($skill`Summon Sugar Sheets`) || - get("instant_saveSugar", false) || - get("tomeSummons") >= 3 || - (have($skill`Summon Clip Art`) && !get("instant_saveClipArt", false)), + !have($skill`Summon Sugar Sheets`) || args.savesugar || get("tomeSummons") >= 3, do: (): void => { const sheetsToMake = 3 - get("tomeSummons"); restoreMp(2 * sheetsToMake); @@ -319,9 +294,7 @@ export const RunStartQuest: Quest = { { name: "Pantogramming", completed: () => - Pantogram.havePants() || - !have($item`portable pantogram`) || - get("instant_savePantogram", false), + Pantogram.havePants() || !have($item`portable pantogram`) || args.savepantogramming, do: (): void => { Pantogram.makePants( myPrimestat().toString(), @@ -338,7 +311,7 @@ export const RunStartQuest: Quest = { completed: () => get("_mummeryMods").includes(`Experience (${myPrimestat().toString()})`) || !have($item`mumming trunk`) || - get("instant_saveMummingTrunk", false), + args.savemumming, do: (): void => { const statString = statToMaximizerString(myPrimestat()); cliExecute(`mummery ${statString}`); @@ -439,7 +412,7 @@ export const RunStartQuest: Quest = { completed: () => [$item.none, $item`packet of mushroom spores`].includes(getGarden()) || getCampground()[getGarden().name] === 0 || - get("instant_saveGarden", false), + args.savegarden, do: () => cliExecute("garden pick"), limit: { tries: 1 }, }, @@ -458,8 +431,8 @@ export const RunStartQuest: Quest = { }, { name: "Set Asdon Workshed", - completed: () => - getWorkshed() === $item`Asdon Martin keyfob` || !get("instant_useAsdon", false), + ready: () => args.asdon, + completed: () => getWorkshed() === $item`Asdon Martin keyfob`, do: () => use($item`Asdon Martin keyfob`), }, { @@ -474,8 +447,8 @@ export const RunStartQuest: Quest = { completed: () => !have($item`model train set`) || (getWorkshed() === $item`model train set` && !canConfigure()) || - get("instant_skipBorrowedTime", false) || - get("instant_useAsdon", false), + args.skipbt || + args.asdon, do: (): void => { const statStation: Station = { Muscle: Station.BRAWN_SILO, @@ -527,7 +500,7 @@ export const RunStartQuest: Quest = { !have($skill`Map the Monsters`) || get("_monstersMapped") >= 3 || have($item`cherry`) || - get("instant_skipBorrowedTime", false) || + args.skipbt || (() => { // if we have another skeleton in the ice house, we don't need to map a novelty skeleton const banishes = get("banishedMonsters").split(":"); @@ -551,7 +524,7 @@ export const RunStartQuest: Quest = { modifier: `${baseOutfit().modifier}, -equip miniature crystal ball`, }), post: (): void => { - if (have($item`MayDay™ supply package`) && !get("instant_saveMayday", false)) + if (have($item`MayDay™ supply package`) && !args.savemayday) use($item`MayDay™ supply package`, 1); if (have($item`space blanket`)) autosell($item`space blanket`, 1); }, @@ -570,7 +543,7 @@ export const RunStartQuest: Quest = { if (get("_snokebombUsed") === 0) restoreMp(50); if (haveEquipped($item`miniature crystal ball`)) equip($slot`familiar`, $item.none); }, - completed: () => get("instant_skipBorrowedTime", false) || have($item`cherry`), + completed: () => args.skipbt || have($item`cherry`), do: $location`The Skeleton Store`, combat: new CombatStrategy().macro(() => Macro.if_( @@ -604,7 +577,7 @@ export const RunStartQuest: Quest = { }; }, post: (): void => { - if (have($item`MayDay™ supply package`) && !get("instant_saveMayday", false)) + if (have($item`MayDay™ supply package`) && !args.savemayday) use($item`MayDay™ supply package`, 1); if (have($item`space blanket`)) autosell($item`space blanket`, 1); }, @@ -624,7 +597,7 @@ export const RunStartQuest: Quest = { { name: "Get Distilled Fortified Wine", ready: () => have($item`11-leaf clover`) || have($effect`Lucky!`), - completed: () => myInebriety() >= 1 || get("instant_skipDistilledFortifiedWine", false), + completed: () => myInebriety() >= 1 || args.fortifiedwine, do: (): void => { if (!have($effect`Lucky!`)) use($item`11-leaf clover`); if (!have($item`distilled fortified wine`)) adv1($location`The Sleazy Back Alley`, -1); @@ -643,9 +616,7 @@ export const RunStartQuest: Quest = { }, ready: () => getKramcoWandererChance() >= 1.0, completed: () => - getKramcoWandererChance() < 1.0 || - !have($item`Kramco Sausage-o-Matic™`) || - get("instant_skipBorrowedTime", false), + getKramcoWandererChance() < 1.0 || !have($item`Kramco Sausage-o-Matic™`) || args.skipbt, do: $location`Noob Cave`, outfit: () => ({ ...baseOutfit(), diff --git a/src/tasks/spelldamage.ts b/src/tasks/spelldamage.ts index ea50768..9d460e4 100644 --- a/src/tasks/spelldamage.ts +++ b/src/tasks/spelldamage.ts @@ -40,6 +40,7 @@ import { Quest } from "../engine/task"; import { checkTurnSave, checkValue, + forbiddenEffects, logTestSetup, shouldFeelLost, shrugAT, @@ -48,11 +49,11 @@ import { } from "../lib"; import Macro, { haveFreeBanish, haveMotherSlimeBanish } from "../combat"; import { chooseFamiliar, sugarItemsAboutToBreak } from "../engine/outfit"; -import { forbiddenEffects } from "../resources"; +import { args } from "../args"; let triedDeepDark = false; // eslint-disable-next-line no-octal -const barrels = [0o0, 0o1, 0o2, 10, 11, 12, 20, 21, 22]; +const barrels = [10, 11, 12, 20, 21, 22]; export const SpellDamageQuest: Quest = { name: "Spell Damage", @@ -116,13 +117,13 @@ export const SpellDamageQuest: Quest = { prepare: (): void => { restoreHp(clamp(1000, myMaxhp() / 2, myMaxhp())); restoreMp(50); - Clan.join(get("instant_motherSlimeClan", "")); + Clan.join(args.motherclan); }, completed: () => !have($familiar`Machine Elf`) || !haveMotherSlimeBanish() || have($effect`Inner Elf`) || - get("instant_motherSlimeClan", "").length === 0, + get(args.motherclan).length === 0, do: $location`The Slime Tube`, combat: new CombatStrategy().macro( Macro.trySkill($skill`KGB tranquilizer dart`) @@ -275,7 +276,7 @@ export const SpellDamageQuest: Quest = { }, completed: () => CommunityService.SpellDamage.isDone(), do: (): void => { - const maxTurns = get("instant_spellTestTurnLimit", 55); + const maxTurns = args.spelldmglimit; const testTurns = CommunityService.SpellDamage.actualCost(); if (testTurns > maxTurns) { print(`Expected to take ${testTurns}, which is more than ${maxTurns}.`, "red"); diff --git a/src/tasks/stat.ts b/src/tasks/stat.ts index 6806d2d..db5e549 100644 --- a/src/tasks/stat.ts +++ b/src/tasks/stat.ts @@ -27,12 +27,13 @@ import { import { Quest } from "../engine/task"; import { checkValue, + forbiddenEffects, logTestSetup, reagentBalancerEffect, reagentBalancerItem, tryAcquiringEffect, } from "../lib"; -import { forbiddenEffects } from "../resources"; +import { args } from "../args"; function useBalancerForTest(testStat: Stat): void { if (testStat === myPrimestat()) { @@ -71,7 +72,7 @@ export const HPQuest: Quest = { usefulEffects.forEach((ef) => tryAcquiringEffect(ef, true)); }, do: (): void => { - const maxTurns = get("instant_hpTestTurnLimit", 1); + const maxTurns = args.hplimit; const testTurns = CommunityService.HP.actualCost(); if (testTurns > maxTurns) { print(`Expected to take ${testTurns}, which is more than ${maxTurns}.`, "red"); @@ -132,7 +133,7 @@ export const MuscleQuest: Quest = { CommunityService.Muscle.turnsSavedBy($effect`Purity of Spirit`) >= 7 && have($skill`Summon Clip Art`) && get("tomeSummons") === 0 && - get("instant_skipBorrowedTime", false) + args.skipbt ) { create($item`cold-filtered water`, 1); use($item`cold-filtered water`, 1); @@ -146,7 +147,7 @@ export const MuscleQuest: Quest = { tryAcquiringEffect($effect`Hulkien`); }, do: (): void => { - const maxTurns = get("instant_musTestTurnLimit", 2); + const maxTurns = args.musclelimit; const testTurns = CommunityService.Muscle.actualCost(); if (testTurns > maxTurns) { print(`Expected to take ${testTurns}, which is more than ${maxTurns}.`, "red"); @@ -212,7 +213,7 @@ export const MysticalityQuest: Quest = { CommunityService.Mysticality.turnsSavedBy($effect`Purity of Spirit`) >= 7 && have($skill`Summon Clip Art`) && get("tomeSummons") === 0 && - get("instant_skipBorrowedTime", false) + args.skipbt ) { create($item`cold-filtered water`, 1); use($item`cold-filtered water`, 1); @@ -226,7 +227,7 @@ export const MysticalityQuest: Quest = { tryAcquiringEffect($effect`Hulkien`); }, do: (): void => { - const maxTurns = get("instant_mystTestTurnLimit", 1); + const maxTurns = args.myslimit; const testTurns = CommunityService.Mysticality.actualCost(); if (testTurns > maxTurns) { print(`Expected to take ${testTurns}, which is more than ${maxTurns}.`, "red"); @@ -258,11 +259,7 @@ export const MoxieQuest: Quest = { { // This is also useful for the BoozeDrop test, but we can grab the +10%mox here first name: "High Heels", - completed: () => - have($item`red-soled high heels`) || - !have($item`2002 Mr. Store Catalog`) || - get("availableMrStore2002Credits", 0) <= get("instant_saveCatalogCredits", 0) || - get("instant_skipHighHeels", false), + completed: () => have($item`red-soled high heels`) || !have($item`2002 Mr. Store Catalog`), do: (): void => { if (!have($item`Letter from Carrie Bradshaw`)) { buy($coinmaster`Mr. Store 2002`, 1, $item`Letter from Carrie Bradshaw`); @@ -274,10 +271,8 @@ export const MoxieQuest: Quest = { { name: "Loathing Idol Microphone", completed: () => - have($effect`Spitting Rhymes`) || + have($effect`Poppy Performance`) || !have($item`2002 Mr. Store Catalog`) || - (get("availableMrStore2002Credits", 0) <= get("instant_saveCatalogCredits", 0) && - !have($item`Loathing Idol Microphone`)) || forbiddenEffects.includes($effect`Poppy Performance`) || checkValue("2002", Math.min(2, CommunityService.Moxie.prediction)), do: (): void => { @@ -332,7 +327,7 @@ export const MoxieQuest: Quest = { CommunityService.Moxie.turnsSavedBy($effect`Purity of Spirit`) >= 7 && have($skill`Summon Clip Art`) && get("tomeSummons") === 0 && - get("instant_skipBorrowedTime", false) + args.skipbt ) { create($item`cold-filtered water`, 1); use($item`cold-filtered water`, 1); @@ -346,7 +341,7 @@ export const MoxieQuest: Quest = { tryAcquiringEffect($effect`Hulkien`); }, do: (): void => { - const maxTurns = get("instant_moxTestTurnLimit", 5); + const maxTurns = args.moxielimit; const testTurns = CommunityService.Moxie.actualCost(); if (testTurns > maxTurns) { print(`Expected to take ${testTurns}, which is more than ${maxTurns}.`, "red"); diff --git a/src/tasks/weapondamage.ts b/src/tasks/weapondamage.ts index 424826d..ed797b1 100644 --- a/src/tasks/weapondamage.ts +++ b/src/tasks/weapondamage.ts @@ -37,13 +37,14 @@ import { checkLocketAvailable, checkTurnSave, checkValue, + forbiddenEffects, logTestSetup, shouldFeelLost, startingClan, tryAcquiringEffect, wishFor, } from "../lib"; -import { forbiddenEffects } from "../resources"; +import { args } from "../args"; export const WeaponDamageQuest: Quest = { name: "Weapon Damage", @@ -89,13 +90,13 @@ export const WeaponDamageQuest: Quest = { prepare: (): void => { restoreHp(clamp(1000, myMaxhp() / 2, myMaxhp())); restoreMp(50); - Clan.join(get("instant_motherSlimeClan", "")); + Clan.join(get(args.motherclan)); }, completed: () => !have($familiar`Machine Elf`) || !haveMotherSlimeBanish() || have($effect`Inner Elf`) || - get("instant_motherSlimeClan", "").length === 0, + args.motherclan.length === 0, do: $location`The Slime Tube`, combat: new CombatStrategy().macro( Macro.trySkill($skill`KGB tranquilizer dart`) @@ -230,15 +231,14 @@ export const WeaponDamageQuest: Quest = { ]; usefulEffects.forEach((ef) => tryAcquiringEffect(ef, true)); - if (get("instant_experimentPulls", false)) - if ( - get("yourFavoriteBirdMods").includes("Weapon Damage Percent") && - checkValue( - "Favorite Bird", - Math.min(4, Math.max(0, CommunityService.WeaponDamage.actualCost())) - ) + if ( + get("yourFavoriteBirdMods").includes("Weapon Damage Percent") && + checkValue( + "Favorite Bird", + Math.min(4, Math.max(0, CommunityService.WeaponDamage.actualCost())) ) - useSkill($skill`Visit your Favorite Bird`); + ) + useSkill($skill`Visit your Favorite Bird`); $effects`Spit Upon, Pyramid Power, Outer Wolf™`.forEach((ef) => { if ( @@ -256,7 +256,7 @@ export const WeaponDamageQuest: Quest = { } if ( - get("instant_synthExperiment", false) && + args.experimentalsynth && CommunityService.WeaponDamage.actualCost() > 2 && get("tomeSummons") <= 1 && have($skill`Summon Sugar Sheets`) @@ -276,7 +276,7 @@ export const WeaponDamageQuest: Quest = { }, completed: () => CommunityService.WeaponDamage.isDone(), do: (): void => { - const maxTurns = get("instant_wpnTestTurnLimit", 35); + const maxTurns = args.weaponlimit; const testTurns = CommunityService.WeaponDamage.actualCost(); if (testTurns > maxTurns) { print(`Expected to take ${testTurns}, which is more than ${maxTurns}.`, "red"); diff --git a/webpack.config.js b/webpack.config.js index 01c1c7a..302547e 100644 --- a/webpack.config.js +++ b/webpack.config.js @@ -6,20 +6,16 @@ const path = require("path"); const webpack = require("webpack"); // does this have a purpose? or can it just get deleted? const packageData = require("./package.json"); /* eslint-enable @typescript-eslint/no-var-requires */ +// eslint-disable-next-line @typescript-eslint/no-var-requires +const { merge } = require("webpack-merge"); -module.exports = { - entry: { - // Define files webpack will emit, does not need to correspond 1:1 with every typescript file - // You need an emitted file for each entrypoint into your code, e.g. the main script and the ccs or ccs consult script it calls - folgercs: "./src/main.ts", - }, +const shared = { // Turns on tree-shaking and minification in the default Terser minifier // https://webpack.js.org/plugins/terser-webpack-plugin/ mode: "production", devtool: false, output: { - path: path.resolve(__dirname, "KoLmafia", "scripts", packageData.name), - filename: "folgercs.js", + filename: "[name].js", libraryTarget: "commonjs", }, resolve: { @@ -51,3 +47,33 @@ module.exports = { // "canadv.ash": "commonjs canadv.ash", }, }; + +const entry = merge( + { + entry: { + // Define files webpack will emit, does not need to correspond 1:1 with every typescript file + // You need an emitted file for each entrypoint into your code, e.g. the main script and the ccs or ccs consult script it calls + folgerCS: "./src/main.ts", + }, + output: { + path: path.resolve(__dirname, "KoLmafia", "scripts", packageData.name), + }, + }, + shared +); + +const relay = merge( + { + entry: { + // Define files webpack will emit, does not need to correspond 1:1 with every typescript file + // You need an emitted file for each entrypoint into your code, e.g. the main script and the ccs or ccs consult script it calls + relay_folgerCS: "./src/relay.ts", + }, + output: { + path: path.resolve(__dirname, "KoLmafia", "relay"), + }, + }, + shared +); + +module.exports = [entry, relay]; diff --git a/yarn.lock b/yarn.lock index 647937b..04cf914 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2334,6 +2334,11 @@ lru-cache@^6.0.0: dependencies: yallist "^4.0.0" +mafia-shared-relay@0.0.7: + version "0.0.7" + resolved "https://registry.yarnpkg.com/mafia-shared-relay/-/mafia-shared-relay-0.0.7.tgz#1a0d333ebeed8cdbb4506360376099108c72d95b" + integrity sha512-sz5a+5tlI7u8eMasVVUdItPq5VdekLx6cDYCCbIjqhiFLluCE+0I1IqZ4n0JDzwLuiUZmAcsIq0VZfAp9WlbKA== + make-dir@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-2.1.0.tgz#5f0310e18b8be898cc07009295a30ae41e91e6f5"