1
0
silverbullet/mobile/bundle.json
2022-03-07 10:21:02 +01:00

1 line
4.0 MiB

{"html": "<!DOCTYPE html>\n<html lang=\"en\">\n <head>\n <meta charset=\"utf-8\">\n <title>Page</title>\n <style>.cm-editor {\n width: 100%;\n height: 100%;\n font-size: var(--ident);\n /* Color list item this way */\n /* Then undo other meta */\n}\n.cm-editor .cm-content {\n font-family: var(--editor-font);\n margin: auto;\n max-width: 800px;\n}\n.cm-editor .cm-selectionBackground {\n background-color: #d7e1f6 !important;\n}\n.cm-editor .line-h1,\n.cm-editor .line-h2,\n.cm-editor .line-h3 {\n background-color: rgba(0, 15, 52, 0.6);\n color: #fff;\n font-weight: bold;\n padding: 2px 2px;\n}\n.cm-editor .line-h1 .meta,\n.cm-editor .line-h2 .meta,\n.cm-editor .line-h3 .meta {\n color: orange;\n}\n.cm-editor .line-h1 {\n font-size: 1.5em;\n}\n.cm-editor .line-h2 {\n font-size: 1.2em;\n}\n.cm-editor .line-h3 {\n font-size: 1.1em;\n}\n.cm-editor .line-li .meta {\n color: #007b13;\n}\n.cm-editor .line-li .meta ~ .meta {\n color: #650007;\n}\n.cm-editor .line-code {\n background-color: #efefef;\n margin-left: 30px;\n}\n.cm-editor .line-fenced-code {\n background-color: #efefef;\n}\n.cm-editor .meta {\n color: #650007;\n}\n.cm-editor .line-blockquote {\n background-color: rgba(220, 220, 220, 0.5);\n color: #676767;\n text-indent: -2ch;\n padding-left: 2ch;\n}\n.cm-editor .emphasis {\n font-style: italic;\n}\n.cm-editor .strong {\n font-weight: 900;\n}\n.cm-editor .link:not(.meta, .url) {\n color: #0330cb;\n text-decoration: underline;\n}\n.cm-editor .link.url {\n color: #7e7d7d;\n}\n.cm-editor .url:not(.link) {\n color: #0330cb;\n text-decoration: underline;\n}\n.cm-editor .wiki-link-page {\n color: #0330cb;\n text-decoration: underline;\n}\n.cm-editor .wiki-link {\n color: #808080;\n}\n.cm-editor .mention {\n color: gray;\n}\n.cm-editor .tag {\n color: #8d8d8d;\n}\n.cm-editor .code {\n background-color: #efefef;\n}\n.cm-editor .line-ul.line-li-1 {\n text-indent: -2ch;\n padding-left: 2ch;\n}\n.cm-editor .line-ul.line-li-1.line-task {\n text-indent: -6ch;\n padding-left: 6ch;\n}\n.cm-editor .line-ul.line-li-1.line-blockquote {\n text-indent: -4ch;\n padding-left: 4ch;\n}\n.cm-editor .line-ul.line-li-1.line-li-2 {\n text-indent: -4ch;\n padding-left: 4ch;\n}\n.cm-editor .line-ul.line-li-1.line-li-2.line-task {\n text-indent: -8ch;\n padding-left: 8ch;\n}\n.cm-editor .line-ul.line-li-1.line-li-2.line-blockquote {\n text-indent: -6ch;\n padding-left: 6ch;\n}\n.cm-editor .line-ul.line-li-1.line-li-2.line-li-3 {\n text-indent: -6ch;\n padding-left: 6ch;\n}\n.cm-editor .line-ul.line-li-1.line-li-2.line-li-3.line-task {\n text-indent: -10ch;\n padding-left: 10ch;\n}\n.cm-editor .line-ul.line-li-1.line-li-2.line-li-3.line-blockquote {\n text-indent: -8ch;\n padding-left: 8ch;\n}\n.cm-editor .line-ul.line-li-1.line-li-2.line-li-3.line-li-4 {\n text-indent: -8ch;\n padding-left: 8ch;\n}\n.cm-editor .line-ul.line-li-1.line-li-2.line-li-3.line-li-4.line-task {\n text-indent: -12ch;\n padding-left: 12ch;\n}\n.cm-editor .line-ul.line-li-1.line-li-2.line-li-3.line-li-4.line-blockquote {\n text-indent: -10ch;\n padding-left: 10ch;\n}\n.cm-editor .line-ul.line-li-1.line-li-2.line-li-3.line-li-4.line-li-5 {\n text-indent: -10ch;\n padding-left: 10ch;\n}\n.cm-editor .line-ul.line-li-1.line-li-2.line-li-3.line-li-4.line-li-5.line-task {\n text-indent: -14ch;\n padding-left: 14ch;\n}\n.cm-editor .line-ul.line-li-1.line-li-2.line-li-3.line-li-4.line-li-5.line-blockquote {\n text-indent: -12ch;\n padding-left: 12ch;\n}\n.cm-editor .line-ol.line-li-1 {\n text-indent: -3ch;\n padding-left: 3ch;\n}\n.cm-editor .line-ol.line-li-1.line-task {\n text-indent: -7ch;\n padding-left: 7ch;\n}\n.cm-editor .line-ol.line-li-1.line-blockquote {\n text-indent: -5ch;\n padding-left: 5ch;\n}\n.cm-editor .line-ol.line-li-1.line-li-2 {\n text-indent: -4ch;\n padding-left: 4ch;\n}\n.cm-editor .line-ol.line-li-1.line-li-2.line-task {\n text-indent: -8ch;\n padding-left: 8ch;\n}\n.cm-editor .line-ol.line-li-1.line-li-2.line-blockquote {\n text-indent: -6ch;\n padding-left: 6ch;\n}\n.cm-editor .line-ol.line-li-1.line-li-2.line-li-3 {\n text-indent: -6ch;\n padding-left: 6ch;\n}\n.cm-editor .line-ol.line-li-1.line-li-2.line-li-3.line-task {\n text-indent: -10ch;\n padding-left: 10ch;\n}\n.cm-editor .line-ol.line-li-1.line-li-2.line-li-3.line-blockquote {\n text-indent: -8ch;\n padding-left: 8ch;\n}\n.cm-editor .line-ol.line-li-1.line-li-2.line-li-3.line-li-4 {\n text-indent: -8ch;\n padding-left: 8ch;\n}\n.cm-editor .line-ol.line-li-1.line-li-2.line-li-3.line-li-4.line-task {\n text-indent: -12ch;\n padding-left: 12ch;\n}\n.cm-editor .line-ol.line-li-1.line-li-2.line-li-3.line-li-4.line-blockquote {\n text-indent: -10ch;\n padding-left: 10ch;\n}\n.cm-editor .line-ol.line-li-1.line-li-2.line-li-3.line-li-4.line-li-5 {\n text-indent: -10ch;\n padding-left: 10ch;\n}\n.cm-editor .line-ol.line-li-1.line-li-2.line-li-3.line-li-4.line-li-5.line-task {\n text-indent: -14ch;\n padding-left: 14ch;\n}\n.cm-editor .line-ol.line-li-1.line-li-2.line-li-3.line-li-4.line-li-5.line-blockquote {\n text-indent: -12ch;\n padding-left: 12ch;\n}\n.cm-editor .line-comment {\n text-indent: -3ch;\n padding-left: 3ch;\n}\n.cm-editor .task-marker {\n background-color: #ddd;\n}\n.cm-editor .line-comment {\n background-color: rgba(255, 255, 0, 0.5);\n}\n\n.filter-box {\n position: absolute;\n font-family: var(--ui-font);\n margin: auto;\n max-width: 500px;\n height: 600px;\n background-color: #fff;\n left: 0;\n right: 0;\n top: 0;\n bottom: 0;\n max-height: 290px;\n overflow: auto;\n z-index: 100;\n border: #676767 1px solid;\n border-radius: 8px;\n box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;\n}\n.filter-box .header {\n border-bottom: 1px #6c6c6c solid;\n padding: 13px 10px 10px 10px;\n display: flex;\n}\n.filter-box .header label {\n color: var(--highlight-color);\n margin: 3px;\n}\n.filter-box .header input {\n font-family: \"Arial\";\n background: transparent;\n color: #000;\n border: 0;\n padding: 3px;\n outline: 0;\n font-size: 1em;\n flex-grow: 100;\n}\n.filter-box .header input::placeholder {\n color: #c7c7c7;\n font-weight: normal;\n}\n.filter-box .help-text {\n background-color: #eee;\n border-bottom: 1px #6c6c6c solid;\n padding: 5px;\n color: #555;\n}\n.filter-box .result-list {\n max-height: 200px;\n overflow-y: scroll;\n background-color: white;\n}\n.filter-box .result-list .icon {\n padding: 0 8px 0 5px;\n}\n.filter-box .result-list .name {\n padding-top: -3px;\n}\n.filter-box .option,\n.filter-box .selected-option {\n padding: 8px;\n cursor: pointer;\n}\n.filter-box .selected-option {\n background-color: var(--highlight-color);\n color: #eee;\n}\n.filter-box .option .hint,\n.filter-box .selected-option .hint {\n float: right;\n margin-right: 0;\n margin-top: -4px;\n padding-left: 5px;\n padding-right: 5px;\n padding-top: 3px;\n padding-bottom: 3px;\n color: #eee;\n background-color: #212476;\n border-radius: 5px;\n}\n\n:root {\n --ident: 18px;\n /* --editor-font: \"Avenir\"; */\n --editor-font: \"Menlo\";\n --ui-font: \"Arial\";\n --top-bar-bg: rgb(41, 41, 41);\n --highlight-color: #464cfc;\n}\n\nhtml,\nbody {\n height: 100%;\n margin: 0;\n padding: 0;\n}\n\n#top {\n height: 55px;\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n background-color: #d5d5d5;\n border-bottom: #c1c1c1 1px solid;\n color: #373737;\n}\n#top .inner {\n padding-top: 12px;\n max-width: 800px;\n font-size: 28px;\n margin: auto;\n}\n#top .current-page {\n font-family: var(--ui-font);\n font-weight: bold;\n}\n#top .icon {\n padding-left: 5px;\n padding-right: 10px;\n}\n\n#bottom {\n position: fixed;\n bottom: 0;\n left: 0;\n right: 0;\n height: 20px;\n background-color: #e8e8e8;\n color: #4f4e4e;\n border-top: #bababa 1px solid;\n margin: 0;\n padding: 5px 10px;\n font-family: var(--ui-font);\n font-size: 0.9em;\n text-align: right;\n}\n\n#editor {\n position: absolute;\n top: 55px;\n bottom: 30px;\n left: 0;\n right: 0;\n overflow-y: hidden;\n}\n\n@media only screen and (max-width: 800px) {\n .cm-editor .cm-content {\n margin: 0 10px !important;\n }\n}\n\n \n</style>\n <script src=\"/index.d3ef8254.js\" defer=\"\"></script>\n <meta charset=\"UTF-8\">\n <meta name=\"viewport\" content=\"width=device-width\">\n </head>\n <body>\n <div id=\"root\"></div>\n <script>// modules are defined as an array\n// [ module function, map of requires ]\n//\n// map of requires is short require name -> numeric require\n//\n// anything defined in a previous bundle is accessed via the\n// orig method which is the require for previous bundles\n\n(function (modules, entry, mainEntry, parcelRequireName, globalName) {\n /* eslint-disable no-undef */\n var globalObject =\n typeof globalThis !== 'undefined'\n ? globalThis\n : typeof self !== 'undefined'\n ? self\n : typeof window !== 'undefined'\n ? window\n : typeof global !== 'undefined'\n ? global\n : {};\n /* eslint-enable no-undef */\n\n // Save the require from previous bundle to this closure if any\n var previousRequire =\n typeof globalObject[parcelRequireName] === 'function' &&\n globalObject[parcelRequireName];\n\n var cache = previousRequire.cache || {};\n // Do not use `require` to prevent Webpack from trying to bundle this call\n var nodeRequire =\n typeof module !== 'undefined' &&\n typeof module.require === 'function' &&\n module.require.bind(module);\n\n function newRequire(name, jumped) {\n if (!cache[name]) {\n if (!modules[name]) {\n // if we cannot find the module within our internal map or\n // cache jump to the current global require ie. the last bundle\n // that was added to the page.\n var currentRequire =\n typeof globalObject[parcelRequireName] === 'function' &&\n globalObject[parcelRequireName];\n if (!jumped && currentRequire) {\n return currentRequire(name, true);\n }\n\n // If there are other bundles on this page the require from the\n // previous one is saved to 'previousRequire'. Repeat this as\n // many times as there are bundles until the module is found or\n // we exhaust the require chain.\n if (previousRequire) {\n return previousRequire(name, true);\n }\n\n // Try the node require function if it exists.\n if (nodeRequire && typeof name === 'string') {\n return nodeRequire(name);\n }\n\n var err = new Error(\"Cannot find module '\" + name + \"'\");\n err.code = 'MODULE_NOT_FOUND';\n throw err;\n }\n\n localRequire.resolve = resolve;\n localRequire.cache = {};\n\n var module = (cache[name] = new newRequire.Module(name));\n\n modules[name][0].call(\n module.exports,\n localRequire,\n module,\n module.exports,\n this\n );\n }\n\n return cache[name].exports;\n\n function localRequire(x) {\n var res = localRequire.resolve(x);\n return res === false ? {} : newRequire(res);\n }\n\n function resolve(x) {\n var id = modules[name][1][x];\n return id != null ? id : x;\n }\n }\n\n function Module(moduleName) {\n this.id = moduleName;\n this.bundle = newRequire;\n this.exports = {};\n }\n\n newRequire.isParcelRequire = true;\n newRequire.Module = Module;\n newRequire.modules = modules;\n newRequire.cache = cache;\n newRequire.parent = previousRequire;\n newRequire.register = function (id, exports) {\n modules[id] = [\n function (require, module) {\n module.exports = exports;\n },\n {},\n ];\n };\n\n Object.defineProperty(newRequire, 'root', {\n get: function () {\n return globalObject[parcelRequireName];\n },\n });\n\n globalObject[parcelRequireName] = newRequire;\n\n for (var i = 0; i < entry.length; i++) {\n newRequire(entry[i]);\n }\n\n if (mainEntry) {\n // Expose entry point to Node, AMD or browser globals\n // Based on https://github.com/ForbesLindesay/umd/blob/master/template.js\n var mainExports = newRequire(mainEntry);\n\n // CommonJS\n if (typeof exports === 'object' && typeof module !== 'undefined') {\n module.exports = mainExports;\n\n // RequireJS\n } else if (typeof define === 'function' && define.amd) {\n define(function () {\n return mainExports;\n });\n\n // <script>\n } else if (globalName) {\n this[globalName] = mainExports;\n }\n }\n})({\"kn9T2\":[function(require,module,exports) {\nvar Refresh = require('react-refresh/runtime');\nRefresh.injectIntoGlobalHook(window);\nwindow.$RefreshReg$ = function() {\n};\nwindow.$RefreshSig$ = function() {\n return function(type) {\n return type;\n };\n};\n\n},{\"react-refresh/runtime\":\"3FsDI\"}],\"3FsDI\":[function(require,module,exports) {\n'use strict';\nmodule.exports = require('./cjs/react-refresh-runtime.development.js');\n\n},{\"./cjs/react-refresh-runtime.development.js\":\"dtx5b\"}],\"dtx5b\":[function(require,module,exports) {\n/** @license React v0.9.0\n * react-refresh-runtime.development.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */ 'use strict';\n(function() {\n // ATTENTION\n // When adding new symbols to this file,\n // Please consider also adding to 'react-devtools-shared/src/backend/ReactSymbols'\n // The Symbol used to tag the ReactElement-like types. If there is no native Symbol\n // nor polyfill, then a plain number is used for performance.\n var REACT_ELEMENT_TYPE = 60103;\n var REACT_PORTAL_TYPE = 60106;\n var REACT_FRAGMENT_TYPE = 60107;\n var REACT_STRICT_MODE_TYPE = 60108;\n var REACT_PROFILER_TYPE = 60114;\n var REACT_PROVIDER_TYPE = 60109;\n var REACT_CONTEXT_TYPE = 60110;\n var REACT_FORWARD_REF_TYPE = 60112;\n var REACT_SUSPENSE_TYPE = 60113;\n var REACT_SUSPENSE_LIST_TYPE = 60120;\n var REACT_MEMO_TYPE = 60115;\n var REACT_LAZY_TYPE = 60116;\n var REACT_BLOCK_TYPE = 60121;\n var REACT_SERVER_BLOCK_TYPE = 60122;\n var REACT_FUNDAMENTAL_TYPE = 60117;\n var REACT_SCOPE_TYPE = 60119;\n var REACT_OPAQUE_ID_TYPE = 60128;\n var REACT_DEBUG_TRACING_MODE_TYPE = 60129;\n var REACT_OFFSCREEN_TYPE = 60130;\n var REACT_LEGACY_HIDDEN_TYPE = 60131;\n if (typeof Symbol === 'function' && Symbol.for) {\n var symbolFor = Symbol.for;\n REACT_ELEMENT_TYPE = symbolFor('react.element');\n REACT_PORTAL_TYPE = symbolFor('react.portal');\n REACT_FRAGMENT_TYPE = symbolFor('react.fragment');\n REACT_STRICT_MODE_TYPE = symbolFor('react.strict_mode');\n REACT_PROFILER_TYPE = symbolFor('react.profiler');\n REACT_PROVIDER_TYPE = symbolFor('react.provider');\n REACT_CONTEXT_TYPE = symbolFor('react.context');\n REACT_FORWARD_REF_TYPE = symbolFor('react.forward_ref');\n REACT_SUSPENSE_TYPE = symbolFor('react.suspense');\n REACT_SUSPENSE_LIST_TYPE = symbolFor('react.suspense_list');\n REACT_MEMO_TYPE = symbolFor('react.memo');\n REACT_LAZY_TYPE = symbolFor('react.lazy');\n REACT_BLOCK_TYPE = symbolFor('react.block');\n REACT_SERVER_BLOCK_TYPE = symbolFor('react.server.block');\n REACT_FUNDAMENTAL_TYPE = symbolFor('react.fundamental');\n REACT_SCOPE_TYPE = symbolFor('react.scope');\n REACT_OPAQUE_ID_TYPE = symbolFor('react.opaque.id');\n REACT_DEBUG_TRACING_MODE_TYPE = symbolFor('react.debug_trace_mode');\n REACT_OFFSCREEN_TYPE = symbolFor('react.offscreen');\n REACT_LEGACY_HIDDEN_TYPE = symbolFor('react.legacy_hidden');\n }\n var PossiblyWeakMap = typeof WeakMap === 'function' ? WeakMap : Map; // We never remove these associations.\n // It's OK to reference families, but use WeakMap/Set for types.\n var allFamiliesByID = new Map();\n var allFamiliesByType = new PossiblyWeakMap();\n var allSignaturesByType = new PossiblyWeakMap(); // This WeakMap is read by React, so we only put families\n // that have actually been edited here. This keeps checks fast.\n // $FlowIssue\n var updatedFamiliesByType = new PossiblyWeakMap(); // This is cleared on every performReactRefresh() call.\n // It is an array of [Family, NextType] tuples.\n var pendingUpdates = []; // This is injected by the renderer via DevTools global hook.\n var helpersByRendererID = new Map();\n var helpersByRoot = new Map(); // We keep track of mounted roots so we can schedule updates.\n var mountedRoots = new Set(); // If a root captures an error, we remember it so we can retry on edit.\n var failedRoots = new Set(); // In environments that support WeakMap, we also remember the last element for every root.\n // It needs to be weak because we do this even for roots that failed to mount.\n // If there is no WeakMap, we won't attempt to do retrying.\n // $FlowIssue\n var rootElements = typeof WeakMap === 'function' ? new WeakMap() : null;\n var isPerformingRefresh = false;\n function computeFullKey(signature) {\n if (signature.fullKey !== null) return signature.fullKey;\n var fullKey = signature.ownKey;\n var hooks;\n try {\n hooks = signature.getCustomHooks();\n } catch (err) {\n // This can happen in an edge case, e.g. if expression like Foo.useSomething\n // depends on Foo which is lazily initialized during rendering.\n // In that case just assume we'll have to remount.\n signature.forceReset = true;\n signature.fullKey = fullKey;\n return fullKey;\n }\n for(var i = 0; i < hooks.length; i++){\n var hook = hooks[i];\n if (typeof hook !== 'function') {\n // Something's wrong. Assume we need to remount.\n signature.forceReset = true;\n signature.fullKey = fullKey;\n return fullKey;\n }\n var nestedHookSignature = allSignaturesByType.get(hook);\n if (nestedHookSignature === undefined) continue;\n var nestedHookKey = computeFullKey(nestedHookSignature);\n if (nestedHookSignature.forceReset) signature.forceReset = true;\n fullKey += '\\n---\\n' + nestedHookKey;\n }\n signature.fullKey = fullKey;\n return fullKey;\n }\n function haveEqualSignatures(prevType, nextType) {\n var prevSignature = allSignaturesByType.get(prevType);\n var nextSignature = allSignaturesByType.get(nextType);\n if (prevSignature === undefined && nextSignature === undefined) return true;\n if (prevSignature === undefined || nextSignature === undefined) return false;\n if (computeFullKey(prevSignature) !== computeFullKey(nextSignature)) return false;\n if (nextSignature.forceReset) return false;\n return true;\n }\n function isReactClass(type) {\n return type.prototype && type.prototype.isReactComponent;\n }\n function canPreserveStateBetween(prevType, nextType) {\n if (isReactClass(prevType) || isReactClass(nextType)) return false;\n if (haveEqualSignatures(prevType, nextType)) return true;\n return false;\n }\n function resolveFamily(type) {\n // Only check updated types to keep lookups fast.\n return updatedFamiliesByType.get(type);\n } // If we didn't care about IE11, we could use new Map/Set(iterable).\n function cloneMap(map) {\n var clone = new Map();\n map.forEach(function(value, key) {\n clone.set(key, value);\n });\n return clone;\n }\n function cloneSet(set) {\n var clone = new Set();\n set.forEach(function(value) {\n clone.add(value);\n });\n return clone;\n }\n function performReactRefresh() {\n if (pendingUpdates.length === 0) return null;\n if (isPerformingRefresh) return null;\n isPerformingRefresh = true;\n try {\n var staleFamilies = new Set();\n var updatedFamilies = new Set();\n var updates = pendingUpdates;\n pendingUpdates = [];\n updates.forEach(function(_ref) {\n var family = _ref[0], nextType = _ref[1];\n // Now that we got a real edit, we can create associations\n // that will be read by the React reconciler.\n var prevType = family.current;\n updatedFamiliesByType.set(prevType, family);\n updatedFamiliesByType.set(nextType, family);\n family.current = nextType; // Determine whether this should be a re-render or a re-mount.\n if (canPreserveStateBetween(prevType, nextType)) updatedFamilies.add(family);\n else staleFamilies.add(family);\n }); // TODO: rename these fields to something more meaningful.\n var update = {\n updatedFamilies: updatedFamilies,\n // Families that will re-render preserving state\n staleFamilies: staleFamilies // Families that will be remounted\n };\n helpersByRendererID.forEach(function(helpers) {\n // Even if there are no roots, set the handler on first update.\n // This ensures that if *new* roots are mounted, they'll use the resolve handler.\n helpers.setRefreshHandler(resolveFamily);\n });\n var didError = false;\n var firstError = null; // We snapshot maps and sets that are mutated during commits.\n // If we don't do this, there is a risk they will be mutated while\n // we iterate over them. For example, trying to recover a failed root\n // may cause another root to be added to the failed list -- an infinite loop.\n var failedRootsSnapshot = cloneSet(failedRoots);\n var mountedRootsSnapshot = cloneSet(mountedRoots);\n var helpersByRootSnapshot = cloneMap(helpersByRoot);\n failedRootsSnapshot.forEach(function(root) {\n var helpers = helpersByRootSnapshot.get(root);\n if (helpers === undefined) throw new Error('Could not find helpers for a root. This is a bug in React Refresh.');\n failedRoots.has(root);\n if (rootElements === null) return;\n if (!rootElements.has(root)) return;\n var element = rootElements.get(root);\n try {\n helpers.scheduleRoot(root, element);\n } catch (err) {\n if (!didError) {\n didError = true;\n firstError = err;\n } // Keep trying other roots.\n }\n });\n mountedRootsSnapshot.forEach(function(root) {\n var helpers = helpersByRootSnapshot.get(root);\n if (helpers === undefined) throw new Error('Could not find helpers for a root. This is a bug in React Refresh.');\n mountedRoots.has(root);\n try {\n helpers.scheduleRefresh(root, update);\n } catch (err) {\n if (!didError) {\n didError = true;\n firstError = err;\n } // Keep trying other roots.\n }\n });\n if (didError) throw firstError;\n return update;\n } finally{\n isPerformingRefresh = false;\n }\n }\n function register(type, id) {\n if (type === null) return;\n if (typeof type !== 'function' && typeof type !== 'object') return;\n // This can happen in an edge case, e.g. if we register\n // return value of a HOC but it returns a cached component.\n // Ignore anything but the first registration for each type.\n if (allFamiliesByType.has(type)) return;\n // Create family or remember to update it.\n // None of this bookkeeping affects reconciliation\n // until the first performReactRefresh() call above.\n var family = allFamiliesByID.get(id);\n if (family === undefined) {\n family = {\n current: type\n };\n allFamiliesByID.set(id, family);\n } else pendingUpdates.push([\n family,\n type\n ]);\n allFamiliesByType.set(type, family); // Visit inner types because we might not have registered them.\n if (typeof type === 'object' && type !== null) switch(type.$$typeof){\n case REACT_FORWARD_REF_TYPE:\n register(type.render, id + '$render');\n break;\n case REACT_MEMO_TYPE:\n register(type.type, id + '$type');\n break;\n }\n }\n function setSignature(type, key) {\n var forceReset = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;\n var getCustomHooks = arguments.length > 3 ? arguments[3] : undefined;\n allSignaturesByType.set(type, {\n forceReset: forceReset,\n ownKey: key,\n fullKey: null,\n getCustomHooks: getCustomHooks || function() {\n return [];\n }\n });\n } // This is lazily called during first render for a type.\n // It captures Hook list at that time so inline requires don't break comparisons.\n function collectCustomHooksForSignature(type) {\n var signature = allSignaturesByType.get(type);\n if (signature !== undefined) computeFullKey(signature);\n }\n function getFamilyByID(id) {\n return allFamiliesByID.get(id);\n }\n function getFamilyByType(type) {\n return allFamiliesByType.get(type);\n }\n function findAffectedHostInstances(families) {\n var affectedInstances = new Set();\n mountedRoots.forEach(function(root) {\n var helpers = helpersByRoot.get(root);\n if (helpers === undefined) throw new Error('Could not find helpers for a root. This is a bug in React Refresh.');\n var instancesForRoot = helpers.findHostInstancesForRefresh(root, families);\n instancesForRoot.forEach(function(inst) {\n affectedInstances.add(inst);\n });\n });\n return affectedInstances;\n }\n function injectIntoGlobalHook(globalObject) {\n // For React Native, the global hook will be set up by require('react-devtools-core').\n // That code will run before us. So we need to monkeypatch functions on existing hook.\n // For React Web, the global hook will be set up by the extension.\n // This will also run before us.\n var hook = globalObject.__REACT_DEVTOOLS_GLOBAL_HOOK__;\n if (hook === undefined) {\n // However, if there is no DevTools extension, we'll need to set up the global hook ourselves.\n // Note that in this case it's important that renderer code runs *after* this method call.\n // Otherwise, the renderer will think that there is no global hook, and won't do the injection.\n var nextID = 0;\n globalObject.__REACT_DEVTOOLS_GLOBAL_HOOK__ = hook = {\n renderers: new Map(),\n supportsFiber: true,\n inject: function(injected) {\n return nextID++;\n },\n onScheduleFiberRoot: function(id, root, children) {\n },\n onCommitFiberRoot: function(id, root, maybePriorityLevel, didError) {\n },\n onCommitFiberUnmount: function() {\n }\n };\n } // Here, we just want to get a reference to scheduleRefresh.\n var oldInject = hook.inject;\n hook.inject = function(injected) {\n var id = oldInject.apply(this, arguments);\n if (typeof injected.scheduleRefresh === 'function' && typeof injected.setRefreshHandler === 'function') // This version supports React Refresh.\n helpersByRendererID.set(id, injected);\n return id;\n }; // Do the same for any already injected roots.\n // This is useful if ReactDOM has already been initialized.\n // https://github.com/facebook/react/issues/17626\n hook.renderers.forEach(function(injected, id) {\n if (typeof injected.scheduleRefresh === 'function' && typeof injected.setRefreshHandler === 'function') // This version supports React Refresh.\n helpersByRendererID.set(id, injected);\n }); // We also want to track currently mounted roots.\n var oldOnCommitFiberRoot = hook.onCommitFiberRoot;\n var oldOnScheduleFiberRoot = hook.onScheduleFiberRoot || function() {\n };\n hook.onScheduleFiberRoot = function(id, root, children) {\n if (!isPerformingRefresh) {\n // If it was intentionally scheduled, don't attempt to restore.\n // This includes intentionally scheduled unmounts.\n failedRoots.delete(root);\n if (rootElements !== null) rootElements.set(root, children);\n }\n return oldOnScheduleFiberRoot.apply(this, arguments);\n };\n hook.onCommitFiberRoot = function(id, root, maybePriorityLevel, didError) {\n var helpers = helpersByRendererID.get(id);\n if (helpers === undefined) return;\n helpersByRoot.set(root, helpers);\n var current = root.current;\n var alternate = current.alternate; // We need to determine whether this root has just (un)mounted.\n // This logic is copy-pasted from similar logic in the DevTools backend.\n // If this breaks with some refactoring, you'll want to update DevTools too.\n if (alternate !== null) {\n var wasMounted = alternate.memoizedState != null && alternate.memoizedState.element != null;\n var isMounted = current.memoizedState != null && current.memoizedState.element != null;\n if (!wasMounted && isMounted) {\n // Mount a new root.\n mountedRoots.add(root);\n failedRoots.delete(root);\n } else if (wasMounted && isMounted) ;\n else if (wasMounted && !isMounted) {\n // Unmount an existing root.\n mountedRoots.delete(root);\n if (didError) // We'll remount it on future edits.\n failedRoots.add(root);\n else helpersByRoot.delete(root);\n } else if (!wasMounted && !isMounted) {\n if (didError) // We'll remount it on future edits.\n failedRoots.add(root);\n }\n } else // Mount a new root.\n mountedRoots.add(root);\n return oldOnCommitFiberRoot.apply(this, arguments);\n };\n }\n function hasUnrecoverableErrors() {\n // TODO: delete this after removing dependency in RN.\n return false;\n } // Exposed for testing.\n function _getMountedRootCount() {\n return mountedRoots.size;\n } // This is a wrapper over more primitive functions for setting signature.\n // Signatures let us decide whether the Hook order has changed on refresh.\n //\n // This function is intended to be used as a transform target, e.g.:\n // var _s = createSignatureFunctionForTransform()\n //\n // function Hello() {\n // const [foo, setFoo] = useState(0);\n // const value = useCustomHook();\n // _s(); /* Second call triggers collecting the custom Hook list.\n // * This doesn't happen during the module evaluation because we\n // * don't want to change the module order with inline requires.\n // * Next calls are noops. */\n // return <h1>Hi</h1>;\n // }\n //\n // /* First call specifies the signature: */\n // _s(\n // Hello,\n // 'useState{[foo, setFoo]}(0)',\n // () => [useCustomHook], /* Lazy to avoid triggering inline requires */\n // );\n function createSignatureFunctionForTransform() {\n // We'll fill in the signature in two steps.\n // First, we'll know the signature itself. This happens outside the component.\n // Then, we'll know the references to custom Hooks. This happens inside the component.\n // After that, the returned function will be a fast path no-op.\n var status = 'needsSignature';\n var savedType;\n var hasCustomHooks;\n return function(type, key, forceReset, getCustomHooks) {\n switch(status){\n case 'needsSignature':\n if (type !== undefined) {\n // If we received an argument, this is the initial registration call.\n savedType = type;\n hasCustomHooks = typeof getCustomHooks === 'function';\n setSignature(type, key, forceReset, getCustomHooks); // The next call we expect is from inside a function, to fill in the custom Hooks.\n status = 'needsCustomHooks';\n }\n break;\n case 'needsCustomHooks':\n if (hasCustomHooks) collectCustomHooksForSignature(savedType);\n status = 'resolved';\n break;\n }\n return type;\n };\n }\n function isLikelyComponentType(type) {\n switch(typeof type){\n case 'function':\n // First, deal with classes.\n if (type.prototype != null) {\n if (type.prototype.isReactComponent) // React class.\n return true;\n var ownNames = Object.getOwnPropertyNames(type.prototype);\n if (ownNames.length > 1 || ownNames[0] !== 'constructor') // This looks like a class.\n return false;\n // eslint-disable-next-line no-proto\n if (type.prototype.__proto__ !== Object.prototype) // It has a superclass.\n return false;\n // Pass through.\n // This looks like a regular function with empty prototype.\n } // For plain functions and arrows, use name as a heuristic.\n var name = type.name || type.displayName;\n return typeof name === 'string' && /^[A-Z]/.test(name);\n case 'object':\n if (type != null) switch(type.$$typeof){\n case REACT_FORWARD_REF_TYPE:\n case REACT_MEMO_TYPE:\n // Definitely React components.\n return true;\n default:\n return false;\n }\n return false;\n default:\n return false;\n }\n }\n exports._getMountedRootCount = _getMountedRootCount;\n exports.collectCustomHooksForSignature = collectCustomHooksForSignature;\n exports.createSignatureFunctionForTransform = createSignatureFunctionForTransform;\n exports.findAffectedHostInstances = findAffectedHostInstances;\n exports.getFamilyByID = getFamilyByID;\n exports.getFamilyByType = getFamilyByType;\n exports.hasUnrecoverableErrors = hasUnrecoverableErrors;\n exports.injectIntoGlobalHook = injectIntoGlobalHook;\n exports.isLikelyComponentType = isLikelyComponentType;\n exports.performReactRefresh = performReactRefresh;\n exports.register = register;\n exports.setSignature = setSignature;\n})();\n\n},{}],\"1lNQd\":[function(require,module,exports) {\n\"use strict\";\nvar HMR_HOST = null;\nvar HMR_PORT = null;\nvar HMR_SECURE = false;\nvar HMR_ENV_HASH = \"d6ea1d42532a7575\";\nmodule.bundle.HMR_BUNDLE_ID = \"adedf34a7e512d43\";\nfunction _toConsumableArray(arr) {\n return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();\n}\nfunction _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nfunction _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}\nfunction _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return _arrayLikeToArray(arr);\n}\nfunction _createForOfIteratorHelper(o, allowArrayLike) {\n var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"];\n if (!it) {\n if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") {\n if (it) o = it;\n var i = 0;\n var F = function F() {\n };\n return {\n s: F,\n n: function n() {\n if (i >= o.length) return {\n done: true\n };\n return {\n done: false,\n value: o[i++]\n };\n },\n e: function e(_e) {\n throw _e;\n },\n f: F\n };\n }\n throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n }\n var normalCompletion = true, didErr = false, err;\n return {\n s: function s() {\n it = it.call(o);\n },\n n: function n() {\n var step = it.next();\n normalCompletion = step.done;\n return step;\n },\n e: function e(_e2) {\n didErr = true;\n err = _e2;\n },\n f: function f() {\n try {\n if (!normalCompletion && it.return != null) it.return();\n } finally{\n if (didErr) throw err;\n }\n }\n };\n}\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);\n}\nfunction _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];\n return arr2;\n}\n/* global HMR_HOST, HMR_PORT, HMR_ENV_HASH, HMR_SECURE */ /*::\nimport type {\n HMRAsset,\n HMRMessage,\n} from '@parcel/reporter-dev-server/src/HMRServer.js';\ninterface ParcelRequire {\n (string): mixed;\n cache: {|[string]: ParcelModule|};\n hotData: mixed;\n Module: any;\n parent: ?ParcelRequire;\n isParcelRequire: true;\n modules: {|[string]: [Function, {|[string]: string|}]|};\n HMR_BUNDLE_ID: string;\n root: ParcelRequire;\n}\ninterface ParcelModule {\n hot: {|\n data: mixed,\n accept(cb: (Function) => void): void,\n dispose(cb: (mixed) => void): void,\n // accept(deps: Array<string> | string, cb: (Function) => void): void,\n // decline(): void,\n _acceptCallbacks: Array<(Function) => void>,\n _disposeCallbacks: Array<(mixed) => void>,\n |};\n}\ndeclare var module: {bundle: ParcelRequire, ...};\ndeclare var HMR_HOST: string;\ndeclare var HMR_PORT: string;\ndeclare var HMR_ENV_HASH: string;\ndeclare var HMR_SECURE: boolean;\n*/ var OVERLAY_ID = '__parcel__error__overlay__';\nvar OldModule = module.bundle.Module;\nfunction Module(moduleName) {\n OldModule.call(this, moduleName);\n this.hot = {\n data: module.bundle.hotData,\n _acceptCallbacks: [],\n _disposeCallbacks: [],\n accept: function accept(fn) {\n this._acceptCallbacks.push(fn || function() {\n });\n },\n dispose: function dispose(fn) {\n this._disposeCallbacks.push(fn);\n }\n };\n module.bundle.hotData = undefined;\n}\nmodule.bundle.Module = Module;\nvar checkedAssets, acceptedAssets, assetsToAccept;\nfunction getHostname() {\n return HMR_HOST || (location.protocol.indexOf('http') === 0 ? location.hostname : 'localhost');\n}\nfunction getPort() {\n return HMR_PORT || location.port;\n} // eslint-disable-next-line no-redeclare\nvar parent = module.bundle.parent;\nif ((!parent || !parent.isParcelRequire) && typeof WebSocket !== 'undefined') {\n var hostname = getHostname();\n var port = getPort();\n var protocol = HMR_SECURE || location.protocol == 'https:' && !/localhost|127.0.0.1|0.0.0.0/.test(hostname) ? 'wss' : 'ws';\n var ws = new WebSocket(protocol + '://' + hostname + (port ? ':' + port : '') + '/'); // $FlowFixMe\n ws.onmessage = function(event) {\n checkedAssets = {\n };\n acceptedAssets = {\n };\n assetsToAccept = [];\n var data = JSON.parse(event.data);\n if (data.type === 'update') {\n // Remove error overlay if there is one\n if (typeof document !== 'undefined') removeErrorOverlay();\n var assets = data.assets.filter(function(asset) {\n return asset.envHash === HMR_ENV_HASH;\n }); // Handle HMR Update\n var handled = assets.every(function(asset) {\n return asset.type === 'css' || asset.type === 'js' && hmrAcceptCheck(module.bundle.root, asset.id, asset.depsByBundle);\n });\n if (handled) {\n console.clear();\n assets.forEach(function(asset) {\n hmrApply(module.bundle.root, asset);\n });\n for(var i = 0; i < assetsToAccept.length; i++){\n var id = assetsToAccept[i][1];\n if (!acceptedAssets[id]) hmrAcceptRun(assetsToAccept[i][0], id);\n }\n } else window.location.reload();\n }\n if (data.type === 'error') {\n // Log parcel errors to console\n var _iterator = _createForOfIteratorHelper(data.diagnostics.ansi), _step;\n try {\n for(_iterator.s(); !(_step = _iterator.n()).done;){\n var ansiDiagnostic = _step.value;\n var stack = ansiDiagnostic.codeframe ? ansiDiagnostic.codeframe : ansiDiagnostic.stack;\n console.error('\ud83d\udea8 [parcel]: ' + ansiDiagnostic.message + '\\n' + stack + '\\n\\n' + ansiDiagnostic.hints.join('\\n'));\n }\n } catch (err) {\n _iterator.e(err);\n } finally{\n _iterator.f();\n }\n if (typeof document !== 'undefined') {\n // Render the fancy html overlay\n removeErrorOverlay();\n var overlay = createErrorOverlay(data.diagnostics.html); // $FlowFixMe\n document.body.appendChild(overlay);\n }\n }\n };\n ws.onerror = function(e) {\n console.error(e.message);\n };\n ws.onclose = function() {\n console.warn('[parcel] \ud83d\udea8 Connection to the HMR server was lost');\n };\n}\nfunction removeErrorOverlay() {\n var overlay = document.getElementById(OVERLAY_ID);\n if (overlay) {\n overlay.remove();\n console.log('[parcel] \u2728 Error resolved');\n }\n}\nfunction createErrorOverlay(diagnostics) {\n var overlay = document.createElement('div');\n overlay.id = OVERLAY_ID;\n var errorHTML = '<div style=\"background: black; opacity: 0.85; font-size: 16px; color: white; position: fixed; height: 100%; width: 100%; top: 0px; left: 0px; padding: 30px; font-family: Menlo, Consolas, monospace; z-index: 9999;\">';\n var _iterator2 = _createForOfIteratorHelper(diagnostics), _step2;\n try {\n for(_iterator2.s(); !(_step2 = _iterator2.n()).done;){\n var diagnostic = _step2.value;\n var stack = diagnostic.codeframe ? diagnostic.codeframe : diagnostic.stack;\n errorHTML += \"\\n <div>\\n <div style=\\\"font-size: 18px; font-weight: bold; margin-top: 20px;\\\">\\n \\uD83D\\uDEA8 \".concat(diagnostic.message, \"\\n </div>\\n <pre>\").concat(stack, \"</pre>\\n <div>\\n \").concat(diagnostic.hints.map(function(hint) {\n return '<div>\ud83d\udca1 ' + hint + '</div>';\n }).join(''), \"\\n </div>\\n \").concat(diagnostic.documentation ? \"<div>\\uD83D\\uDCDD <a style=\\\"color: violet\\\" href=\\\"\".concat(diagnostic.documentation, \"\\\" target=\\\"_blank\\\">Learn more</a></div>\") : '', \"\\n </div>\\n \");\n }\n } catch (err) {\n _iterator2.e(err);\n } finally{\n _iterator2.f();\n }\n errorHTML += '</div>';\n overlay.innerHTML = errorHTML;\n return overlay;\n}\nfunction getParents(bundle, id) /*: Array<[ParcelRequire, string]> */ {\n var modules = bundle.modules;\n if (!modules) return [];\n var parents = [];\n var k, d, dep;\n for(k in modules)for(d in modules[k][1]){\n dep = modules[k][1][d];\n if (dep === id || Array.isArray(dep) && dep[dep.length - 1] === id) parents.push([\n bundle,\n k\n ]);\n }\n if (bundle.parent) parents = parents.concat(getParents(bundle.parent, id));\n return parents;\n}\nfunction updateLink(link) {\n var newLink = link.cloneNode();\n newLink.onload = function() {\n if (link.parentNode !== null) // $FlowFixMe\n link.parentNode.removeChild(link);\n };\n newLink.setAttribute('href', link.getAttribute('href').split('?')[0] + '?' + Date.now()); // $FlowFixMe\n link.parentNode.insertBefore(newLink, link.nextSibling);\n}\nvar cssTimeout = null;\nfunction reloadCSS() {\n if (cssTimeout) return;\n cssTimeout = setTimeout(function() {\n var links = document.querySelectorAll('link[rel=\"stylesheet\"]');\n for(var i = 0; i < links.length; i++){\n // $FlowFixMe[incompatible-type]\n var href = links[i].getAttribute('href');\n var hostname = getHostname();\n var servedFromHMRServer = hostname === 'localhost' ? new RegExp('^(https?:\\\\/\\\\/(0.0.0.0|127.0.0.1)|localhost):' + getPort()).test(href) : href.indexOf(hostname + ':' + getPort());\n var absolute = /^https?:\\/\\//i.test(href) && href.indexOf(window.location.origin) !== 0 && !servedFromHMRServer;\n if (!absolute) updateLink(links[i]);\n }\n cssTimeout = null;\n }, 50);\n}\nfunction hmrApply(bundle, asset) {\n var modules = bundle.modules;\n if (!modules) return;\n if (asset.type === 'css') reloadCSS();\n else if (asset.type === 'js') {\n var deps = asset.depsByBundle[bundle.HMR_BUNDLE_ID];\n if (deps) {\n if (modules[asset.id]) {\n // Remove dependencies that are removed and will become orphaned.\n // This is necessary so that if the asset is added back again, the cache is gone, and we prevent a full page reload.\n var oldDeps = modules[asset.id][1];\n for(var dep in oldDeps)if (!deps[dep] || deps[dep] !== oldDeps[dep]) {\n var id = oldDeps[dep];\n var parents = getParents(module.bundle.root, id);\n if (parents.length === 1) hmrDelete(module.bundle.root, id);\n }\n }\n var fn = new Function('require', 'module', 'exports', asset.output);\n modules[asset.id] = [\n fn,\n deps\n ];\n } else if (bundle.parent) hmrApply(bundle.parent, asset);\n }\n}\nfunction hmrDelete(bundle, id1) {\n var modules = bundle.modules;\n if (!modules) return;\n if (modules[id1]) {\n // Collect dependencies that will become orphaned when this module is deleted.\n var deps = modules[id1][1];\n var orphans = [];\n for(var dep in deps){\n var parents = getParents(module.bundle.root, deps[dep]);\n if (parents.length === 1) orphans.push(deps[dep]);\n } // Delete the module. This must be done before deleting dependencies in case of circular dependencies.\n delete modules[id1];\n delete bundle.cache[id1]; // Now delete the orphans.\n orphans.forEach(function(id) {\n hmrDelete(module.bundle.root, id);\n });\n } else if (bundle.parent) hmrDelete(bundle.parent, id1);\n}\nfunction hmrAcceptCheck(bundle, id, depsByBundle) {\n if (hmrAcceptCheckOne(bundle, id, depsByBundle)) return true;\n // Traverse parents breadth first. All possible ancestries must accept the HMR update, or we'll reload.\n var parents = getParents(module.bundle.root, id);\n var accepted = false;\n while(parents.length > 0){\n var v = parents.shift();\n var a = hmrAcceptCheckOne(v[0], v[1], null);\n if (a) // If this parent accepts, stop traversing upward, but still consider siblings.\n accepted = true;\n else {\n // Otherwise, queue the parents in the next level upward.\n var p = getParents(module.bundle.root, v[1]);\n if (p.length === 0) {\n // If there are no parents, then we've reached an entry without accepting. Reload.\n accepted = false;\n break;\n }\n parents.push.apply(parents, _toConsumableArray(p));\n }\n }\n return accepted;\n}\nfunction hmrAcceptCheckOne(bundle, id, depsByBundle) {\n var modules = bundle.modules;\n if (!modules) return;\n if (depsByBundle && !depsByBundle[bundle.HMR_BUNDLE_ID]) {\n // If we reached the root bundle without finding where the asset should go,\n // there's nothing to do. Mark as \"accepted\" so we don't reload the page.\n if (!bundle.parent) return true;\n return hmrAcceptCheck(bundle.parent, id, depsByBundle);\n }\n if (checkedAssets[id]) return true;\n checkedAssets[id] = true;\n var cached = bundle.cache[id];\n assetsToAccept.push([\n bundle,\n id\n ]);\n if (!cached || cached.hot && cached.hot._acceptCallbacks.length) return true;\n}\nfunction hmrAcceptRun(bundle, id) {\n var cached = bundle.cache[id];\n bundle.hotData = {\n };\n if (cached && cached.hot) cached.hot.data = bundle.hotData;\n if (cached && cached.hot && cached.hot._disposeCallbacks.length) cached.hot._disposeCallbacks.forEach(function(cb) {\n cb(bundle.hotData);\n });\n delete bundle.cache[id];\n bundle(id);\n cached = bundle.cache[id];\n if (cached && cached.hot && cached.hot._acceptCallbacks.length) cached.hot._acceptCallbacks.forEach(function(cb) {\n var assetsToAlsoAccept = cb(function() {\n return getParents(module.bundle.root, id);\n });\n if (assetsToAlsoAccept && assetsToAccept.length) // $FlowFixMe[method-unbinding]\n assetsToAccept.push.apply(assetsToAccept, assetsToAlsoAccept);\n });\n acceptedAssets[id] = true;\n}\n\n},{}],\"4Bi4U\":[function(require,module,exports) {\nrequire(\"./boot\");\n\n},{\"./boot\":\"kGMVG\"}],\"kGMVG\":[function(require,module,exports) {\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\nvar _regenerator = _interopRequireDefault(require(\"@babel/runtime/regenerator\"));\nvar _editor = require(\"../../webapp/src/editor\");\nvar _space = require(\"../../webapp/src/space\");\nfunction safeRun(fn) {\n fn().catch(function(e) {\n console.error(e);\n });\n}\nwindow.receiveMessage = function(msg) {\n console.log(\"Received message\", msg);\n}; // @ts-ignore\nwindow.onerror = function(msg, source, lineno, colno, error) {\n console.error(\"Error\", msg, source, lineno, error);\n};\nconsole.log = function() {\n for(var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++)args[_key] = arguments[_key];\n window.ReactNativeWebView.postMessage(JSON.stringify({\n type: \"console.log\",\n args: args\n }));\n};\nconsole.error = function() {\n for(var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++)args[_key2] = arguments[_key2];\n window.ReactNativeWebView.postMessage(JSON.stringify({\n type: \"console.error\",\n args: args\n }));\n};\ntry {\n var editor = new _editor.Editor(new _space.HttpRemoteSpace(\"http://192.168.2.22:3000/fs\", null), document.getElementById(\"root\"));\n console.log(\"Initing editor\");\n safeRun(function _callee() {\n return _regenerator.default.async(function _callee$(_context) {\n while(true)switch(_context.prev = _context.next){\n case 0:\n _context.next = 2;\n return _regenerator.default.awrap(editor.loadPageList());\n case 2:\n _context.next = 4;\n return _regenerator.default.awrap(editor.loadPlugs());\n case 4:\n editor.focus();\n console.log(\"Inited\", editor.viewState);\n case 6:\n case \"end\":\n return _context.stop();\n }\n }, null, null, null, Promise);\n });\n} catch (e) {\n console.error(\"Got an error\", e.message);\n}\n\n},{\"@babel/runtime/helpers/interopRequireDefault\":\"7XM86\",\"@babel/runtime/regenerator\":\"5nQUq\",\"../../webapp/src/editor\":\"bggJk\",\"../../webapp/src/space\":\"91mo1\"}],\"7XM86\":[function(require,module,exports) {\nfunction _interopRequireDefault(obj) {\n return obj && obj.__esModule ? obj : {\n \"default\": obj\n };\n}\nmodule.exports = _interopRequireDefault, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n\n},{}],\"5nQUq\":[function(require,module,exports) {\nmodule.exports = require(\"regenerator-runtime\");\n\n},{\"regenerator-runtime\":\"dXNgZ\"}],\"dXNgZ\":[function(require,module,exports) {\n/**\n * Copyright (c) 2014-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */ var runtime = function(exports) {\n var Op = Object.prototype;\n var hasOwn = Op.hasOwnProperty;\n var undefined; // More compressible than void 0.\n var $Symbol = typeof Symbol === \"function\" ? Symbol : {\n };\n var iteratorSymbol = $Symbol.iterator || \"@@iterator\";\n var asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\";\n var toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n function define(obj, key, value) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n return obj[key];\n }\n try {\n // IE 8 has a broken Object.defineProperty that only works on DOM objects.\n define({\n }, \"\");\n } catch (err1) {\n define = function(obj, key, value) {\n return obj[key] = value;\n };\n }\n function wrap(innerFn, outerFn, self, tryLocsList) {\n // If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.\n var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;\n var generator = Object.create(protoGenerator.prototype);\n var context = new Context(tryLocsList || []);\n // The ._invoke method unifies the implementations of the .next,\n // .throw, and .return methods.\n generator._invoke = makeInvokeMethod(innerFn, self, context);\n return generator;\n }\n exports.wrap = wrap;\n // Try/catch helper to minimize deoptimizations. Returns a completion\n // record like context.tryEntries[i].completion. This interface could\n // have been (and was previously) designed to take a closure to be\n // invoked without arguments, but in all the cases we care about we\n // already have an existing method we want to call, so there's no need\n // to create a new function object. We can even get away with assuming\n // the method takes exactly one argument, since that happens to be true\n // in every case, so we don't have to touch the arguments object. The\n // only additional allocation required is the completion record, which\n // has a stable shape and so hopefully should be cheap to allocate.\n function tryCatch(fn, obj, arg) {\n try {\n return {\n type: \"normal\",\n arg: fn.call(obj, arg)\n };\n } catch (err) {\n return {\n type: \"throw\",\n arg: err\n };\n }\n }\n var GenStateSuspendedStart = \"suspendedStart\";\n var GenStateSuspendedYield = \"suspendedYield\";\n var GenStateExecuting = \"executing\";\n var GenStateCompleted = \"completed\";\n // Returning this object from the innerFn has the same effect as\n // breaking out of the dispatch switch statement.\n var ContinueSentinel = {\n };\n // Dummy constructor functions that we use as the .constructor and\n // .constructor.prototype properties for functions that return Generator\n // objects. For full spec compliance, you may wish to configure your\n // minifier not to mangle the names of these two functions.\n function Generator() {\n }\n function GeneratorFunction() {\n }\n function GeneratorFunctionPrototype() {\n }\n // This is a polyfill for %IteratorPrototype% for environments that\n // don't natively support it.\n var IteratorPrototype = {\n };\n define(IteratorPrototype, iteratorSymbol, function() {\n return this;\n });\n var getProto = Object.getPrototypeOf;\n var NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n if (NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) // This environment has a native %IteratorPrototype%; use it instead\n // of the polyfill.\n IteratorPrototype = NativeIteratorPrototype;\n var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype);\n GeneratorFunction.prototype = GeneratorFunctionPrototype;\n define(Gp, \"constructor\", GeneratorFunctionPrototype);\n define(GeneratorFunctionPrototype, \"constructor\", GeneratorFunction);\n GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, \"GeneratorFunction\");\n // Helper for defining the .next, .throw, and .return methods of the\n // Iterator interface in terms of a single ._invoke method.\n function defineIteratorMethods(prototype) {\n [\n \"next\",\n \"throw\",\n \"return\"\n ].forEach(function(method) {\n define(prototype, method, function(arg) {\n return this._invoke(method, arg);\n });\n });\n }\n exports.isGeneratorFunction = function(genFun) {\n var ctor = typeof genFun === \"function\" && genFun.constructor;\n return ctor ? ctor === GeneratorFunction || // For the native GeneratorFunction constructor, the best we can\n // do is to check its .name property.\n (ctor.displayName || ctor.name) === \"GeneratorFunction\" : false;\n };\n exports.mark = function(genFun) {\n if (Object.setPrototypeOf) Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);\n else {\n genFun.__proto__ = GeneratorFunctionPrototype;\n define(genFun, toStringTagSymbol, \"GeneratorFunction\");\n }\n genFun.prototype = Object.create(Gp);\n return genFun;\n };\n // Within the body of any async function, `await x` is transformed to\n // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n // `hasOwn.call(value, \"__await\")` to determine if the yielded value is\n // meant to be awaited.\n exports.awrap = function(arg) {\n return {\n __await: arg\n };\n };\n function AsyncIterator(generator, PromiseImpl) {\n function invoke(method, arg, resolve, reject) {\n var record = tryCatch(generator[method], generator, arg);\n if (record.type === \"throw\") reject(record.arg);\n else {\n var result = record.arg;\n var value1 = result.value;\n if (value1 && typeof value1 === \"object\" && hasOwn.call(value1, \"__await\")) return PromiseImpl.resolve(value1.__await).then(function(value) {\n invoke(\"next\", value, resolve, reject);\n }, function(err) {\n invoke(\"throw\", err, resolve, reject);\n });\n return PromiseImpl.resolve(value1).then(function(unwrapped) {\n // When a yielded Promise is resolved, its final value becomes\n // the .value of the Promise<{value,done}> result for the\n // current iteration.\n result.value = unwrapped;\n resolve(result);\n }, function(error) {\n // If a rejected Promise was yielded, throw the rejection back\n // into the async generator function so it can be handled there.\n return invoke(\"throw\", error, resolve, reject);\n });\n }\n }\n var previousPromise;\n function enqueue(method, arg) {\n function callInvokeWithMethodAndArg() {\n return new PromiseImpl(function(resolve, reject) {\n invoke(method, arg, resolve, reject);\n });\n }\n return previousPromise = // If enqueue has been called before, then we want to wait until\n // all previous Promises have been resolved before calling invoke,\n // so that results are always delivered in the correct order. If\n // enqueue has not been called before, then it is important to\n // call invoke immediately, without waiting on a callback to fire,\n // so that the async generator function has the opportunity to do\n // any necessary setup in a predictable way. This predictability\n // is why the Promise constructor synchronously invokes its\n // executor callback, and why async functions synchronously\n // execute code before the first await. Since we implement simple\n // async functions in terms of async generators, it is especially\n // important to get this right, even though it requires care.\n previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, // Avoid propagating failures to Promises returned by later\n // invocations of the iterator.\n callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg();\n }\n // Define the unified helper method that is used to implement .next,\n // .throw, and .return (see defineIteratorMethods).\n this._invoke = enqueue;\n }\n defineIteratorMethods(AsyncIterator.prototype);\n define(AsyncIterator.prototype, asyncIteratorSymbol, function() {\n return this;\n });\n exports.AsyncIterator = AsyncIterator;\n // Note that simple async functions are implemented on top of\n // AsyncIterator objects; they just return a Promise for the value of\n // the final result produced by the iterator.\n exports.async = function(innerFn, outerFn, self, tryLocsList, PromiseImpl) {\n if (PromiseImpl === void 0) PromiseImpl = Promise;\n var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl);\n return exports.isGeneratorFunction(outerFn) ? iter // If outerFn is a generator, return the full iterator.\n : iter.next().then(function(result) {\n return result.done ? result.value : iter.next();\n });\n };\n function makeInvokeMethod(innerFn, self, context) {\n var state = GenStateSuspendedStart;\n return function invoke(method, arg) {\n if (state === GenStateExecuting) throw new Error(\"Generator is already running\");\n if (state === GenStateCompleted) {\n if (method === \"throw\") throw arg;\n // Be forgiving, per 25.3.3.3.3 of the spec:\n // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n return doneResult();\n }\n context.method = method;\n context.arg = arg;\n while(true){\n var delegate = context.delegate;\n if (delegate) {\n var delegateResult = maybeInvokeDelegate(delegate, context);\n if (delegateResult) {\n if (delegateResult === ContinueSentinel) continue;\n return delegateResult;\n }\n }\n if (context.method === \"next\") // Setting context._sent for legacy support of Babel's\n // function.sent implementation.\n context.sent = context._sent = context.arg;\n else if (context.method === \"throw\") {\n if (state === GenStateSuspendedStart) {\n state = GenStateCompleted;\n throw context.arg;\n }\n context.dispatchException(context.arg);\n } else if (context.method === \"return\") context.abrupt(\"return\", context.arg);\n state = GenStateExecuting;\n var record = tryCatch(innerFn, self, context);\n if (record.type === \"normal\") {\n // If an exception is thrown from innerFn, we leave state ===\n // GenStateExecuting and loop back for another invocation.\n state = context.done ? GenStateCompleted : GenStateSuspendedYield;\n if (record.arg === ContinueSentinel) continue;\n return {\n value: record.arg,\n done: context.done\n };\n } else if (record.type === \"throw\") {\n state = GenStateCompleted;\n // Dispatch the exception by looping back around to the\n // context.dispatchException(context.arg) call above.\n context.method = \"throw\";\n context.arg = record.arg;\n }\n }\n };\n }\n // Call delegate.iterator[context.method](context.arg) and handle the\n // result, either by returning a { value, done } result from the\n // delegate iterator, or by modifying context.method and context.arg,\n // setting context.delegate to null, and returning the ContinueSentinel.\n function maybeInvokeDelegate(delegate, context) {\n var method = delegate.iterator[context.method];\n if (method === undefined) {\n // A .throw or .return when the delegate iterator has no .throw\n // method always terminates the yield* loop.\n context.delegate = null;\n if (context.method === \"throw\") {\n // Note: [\"return\"] must be used for ES3 parsing compatibility.\n if (delegate.iterator[\"return\"]) {\n // If the delegate iterator has a return method, give it a\n // chance to clean up.\n context.method = \"return\";\n context.arg = undefined;\n maybeInvokeDelegate(delegate, context);\n if (context.method === \"throw\") // If maybeInvokeDelegate(context) changed context.method from\n // \"return\" to \"throw\", let that override the TypeError below.\n return ContinueSentinel;\n }\n context.method = \"throw\";\n context.arg = new TypeError(\"The iterator does not provide a 'throw' method\");\n }\n return ContinueSentinel;\n }\n var record = tryCatch(method, delegate.iterator, context.arg);\n if (record.type === \"throw\") {\n context.method = \"throw\";\n context.arg = record.arg;\n context.delegate = null;\n return ContinueSentinel;\n }\n var info = record.arg;\n if (!info) {\n context.method = \"throw\";\n context.arg = new TypeError(\"iterator result is not an object\");\n context.delegate = null;\n return ContinueSentinel;\n }\n if (info.done) {\n // Assign the result of the finished delegate to the temporary\n // variable specified by delegate.resultName (see delegateYield).\n context[delegate.resultName] = info.value;\n // Resume execution at the desired location (see delegateYield).\n context.next = delegate.nextLoc;\n // If context.method was \"throw\" but the delegate handled the\n // exception, let the outer generator proceed normally. If\n // context.method was \"next\", forget context.arg since it has been\n // \"consumed\" by the delegate iterator. If context.method was\n // \"return\", allow the original .return call to continue in the\n // outer generator.\n if (context.method !== \"return\") {\n context.method = \"next\";\n context.arg = undefined;\n }\n } else // Re-yield the result returned by the delegate method.\n return info;\n // The delegate iterator is finished, so forget it and continue with\n // the outer generator.\n context.delegate = null;\n return ContinueSentinel;\n }\n // Define Generator.prototype.{next,throw,return} in terms of the\n // unified ._invoke helper method.\n defineIteratorMethods(Gp);\n define(Gp, toStringTagSymbol, \"Generator\");\n // A Generator should always return itself as the iterator object when the\n // @@iterator function is called on it. Some browsers' implementations of the\n // iterator prototype chain incorrectly implement this, causing the Generator\n // object to not be returned from this call. This ensures that doesn't happen.\n // See https://github.com/facebook/regenerator/issues/274 for more details.\n define(Gp, iteratorSymbol, function() {\n return this;\n });\n define(Gp, \"toString\", function() {\n return \"[object Generator]\";\n });\n function pushTryEntry(locs) {\n var entry = {\n tryLoc: locs[0]\n };\n if (1 in locs) entry.catchLoc = locs[1];\n if (2 in locs) {\n entry.finallyLoc = locs[2];\n entry.afterLoc = locs[3];\n }\n this.tryEntries.push(entry);\n }\n function resetTryEntry(entry) {\n var record = entry.completion || {\n };\n record.type = \"normal\";\n delete record.arg;\n entry.completion = record;\n }\n function Context(tryLocsList) {\n // The root entry object (effectively a try statement without a catch\n // or a finally block) gives us a place to store values thrown from\n // locations where there is no enclosing try statement.\n this.tryEntries = [\n {\n tryLoc: \"root\"\n }\n ];\n tryLocsList.forEach(pushTryEntry, this);\n this.reset(true);\n }\n exports.keys = function(object) {\n var keys = [];\n for(var key1 in object)keys.push(key1);\n keys.reverse();\n // Rather than returning an object with a next method, we keep\n // things simple and return the next function itself.\n return function next() {\n while(keys.length){\n var key = keys.pop();\n if (key in object) {\n next.value = key;\n next.done = false;\n return next;\n }\n }\n // To avoid creating an additional object, we just hang the .value\n // and .done properties off the next function object itself. This\n // also ensures that the minifier will not anonymize the function.\n next.done = true;\n return next;\n };\n };\n function values(iterable) {\n if (iterable) {\n var iteratorMethod = iterable[iteratorSymbol];\n if (iteratorMethod) return iteratorMethod.call(iterable);\n if (typeof iterable.next === \"function\") return iterable;\n if (!isNaN(iterable.length)) {\n var i = -1, next1 = function next() {\n while(++i < iterable.length)if (hasOwn.call(iterable, i)) {\n next.value = iterable[i];\n next.done = false;\n return next;\n }\n next.value = undefined;\n next.done = true;\n return next;\n };\n return next1.next = next1;\n }\n }\n // Return an iterator with no values.\n return {\n next: doneResult\n };\n }\n exports.values = values;\n function doneResult() {\n return {\n value: undefined,\n done: true\n };\n }\n Context.prototype = {\n constructor: Context,\n reset: function(skipTempReset) {\n this.prev = 0;\n this.next = 0;\n // Resetting context._sent for legacy support of Babel's\n // function.sent implementation.\n this.sent = this._sent = undefined;\n this.done = false;\n this.delegate = null;\n this.method = \"next\";\n this.arg = undefined;\n this.tryEntries.forEach(resetTryEntry);\n if (!skipTempReset) {\n for(var name in this)// Not sure about the optimal order of these conditions:\n if (name.charAt(0) === \"t\" && hasOwn.call(this, name) && !isNaN(+name.slice(1))) this[name] = undefined;\n }\n },\n stop: function() {\n this.done = true;\n var rootEntry = this.tryEntries[0];\n var rootRecord = rootEntry.completion;\n if (rootRecord.type === \"throw\") throw rootRecord.arg;\n return this.rval;\n },\n dispatchException: function(exception) {\n if (this.done) throw exception;\n var context = this;\n function handle(loc, caught) {\n record.type = \"throw\";\n record.arg = exception;\n context.next = loc;\n if (caught) {\n // If the dispatched exception was caught by a catch block,\n // then let that catch block handle the exception normally.\n context.method = \"next\";\n context.arg = undefined;\n }\n return !!caught;\n }\n for(var i = this.tryEntries.length - 1; i >= 0; --i){\n var entry = this.tryEntries[i];\n var record = entry.completion;\n if (entry.tryLoc === \"root\") // Exception thrown outside of any try block that could handle\n // it, so set the completion value of the entire function to\n // throw the exception.\n return handle(\"end\");\n if (entry.tryLoc <= this.prev) {\n var hasCatch = hasOwn.call(entry, \"catchLoc\");\n var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n if (hasCatch && hasFinally) {\n if (this.prev < entry.catchLoc) return handle(entry.catchLoc, true);\n else if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc);\n } else if (hasCatch) {\n if (this.prev < entry.catchLoc) return handle(entry.catchLoc, true);\n } else if (hasFinally) {\n if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc);\n } else throw new Error(\"try statement without catch or finally\");\n }\n }\n },\n abrupt: function(type, arg) {\n for(var i = this.tryEntries.length - 1; i >= 0; --i){\n var entry = this.tryEntries[i];\n if (entry.tryLoc <= this.prev && hasOwn.call(entry, \"finallyLoc\") && this.prev < entry.finallyLoc) {\n var finallyEntry = entry;\n break;\n }\n }\n if (finallyEntry && (type === \"break\" || type === \"continue\") && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc) // Ignore the finally entry if control is not jumping to a\n // location outside the try/catch block.\n finallyEntry = null;\n var record = finallyEntry ? finallyEntry.completion : {\n };\n record.type = type;\n record.arg = arg;\n if (finallyEntry) {\n this.method = \"next\";\n this.next = finallyEntry.finallyLoc;\n return ContinueSentinel;\n }\n return this.complete(record);\n },\n complete: function(record, afterLoc) {\n if (record.type === \"throw\") throw record.arg;\n if (record.type === \"break\" || record.type === \"continue\") this.next = record.arg;\n else if (record.type === \"return\") {\n this.rval = this.arg = record.arg;\n this.method = \"return\";\n this.next = \"end\";\n } else if (record.type === \"normal\" && afterLoc) this.next = afterLoc;\n return ContinueSentinel;\n },\n finish: function(finallyLoc) {\n for(var i = this.tryEntries.length - 1; i >= 0; --i){\n var entry = this.tryEntries[i];\n if (entry.finallyLoc === finallyLoc) {\n this.complete(entry.completion, entry.afterLoc);\n resetTryEntry(entry);\n return ContinueSentinel;\n }\n }\n },\n \"catch\": function(tryLoc) {\n for(var i = this.tryEntries.length - 1; i >= 0; --i){\n var entry = this.tryEntries[i];\n if (entry.tryLoc === tryLoc) {\n var record = entry.completion;\n if (record.type === \"throw\") {\n var thrown = record.arg;\n resetTryEntry(entry);\n }\n return thrown;\n }\n }\n // The context.catch method must only be called with a location\n // argument that corresponds to a known catch block.\n throw new Error(\"illegal catch attempt\");\n },\n delegateYield: function(iterable, resultName, nextLoc) {\n this.delegate = {\n iterator: values(iterable),\n resultName: resultName,\n nextLoc: nextLoc\n };\n if (this.method === \"next\") // Deliberately forget the last sent value so that we don't\n // accidentally pass it on to the delegate.\n this.arg = undefined;\n return ContinueSentinel;\n }\n };\n // Regardless of whether this script is executing as a CommonJS module\n // or not, return the runtime object so that we can declare the variable\n // regeneratorRuntime in the outer scope, which allows this module to be\n // injected easily by `bin/regenerator --include-runtime script.js`.\n return exports;\n}(// If this script is executing as a CommonJS module, use module.exports\n// as the regeneratorRuntime namespace. Otherwise create a new empty\n// object. Either way, the resulting object will be used to initialize\n// the regeneratorRuntime variable at the top of this file.\ntypeof module === \"object\" ? module.exports : {\n});\ntry {\n regeneratorRuntime = runtime;\n} catch (accidentalStrictMode) {\n // This module should not be running in strict mode, so the above\n // assignment should always work unless something is misconfigured. Just\n // in case runtime.js accidentally runs in strict mode, in modern engines\n // we can explicitly access globalThis. In older engines we can escape\n // strict mode using a global Function call. This could conceivably fail\n // if a Content Security Policy forbids using Function, but in that case\n // the proper solution is to fix the accidental strict mode problem. If\n // you've misconfigured your bundler to force strict mode and applied a\n // CSP to forbid Function, and you're not willing to fix either of those\n // problems, please detail your unique predicament in a GitHub issue.\n if (typeof globalThis === \"object\") globalThis.regeneratorRuntime = runtime;\n else Function(\"r\", \"regeneratorRuntime = r\")(runtime);\n}\n\n},{}],\"bggJk\":[function(require,module,exports) {\nvar $parcel$ReactRefreshHelpers$7051 = require(\"@parcel/transformer-react-refresh-wrap/lib/helpers/helpers.js\");\nvar prevRefreshReg = window.$RefreshReg$;\nvar prevRefreshSig = window.$RefreshSig$;\n$parcel$ReactRefreshHelpers$7051.prelude(module);\n\ntry {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"Editor\", ()=>Editor\n);\nvar _jsxDevRuntime = require(\"react/jsx-dev-runtime\");\nvar _autocomplete = require(\"@codemirror/autocomplete\");\nvar _closebrackets = require(\"@codemirror/closebrackets\");\nvar _commands = require(\"@codemirror/commands\");\nvar _history = require(\"@codemirror/history\");\nvar _matchbrackets = require(\"@codemirror/matchbrackets\");\nvar _search = require(\"@codemirror/search\");\nvar _state = require(\"@codemirror/state\");\nvar _view = require(\"@codemirror/view\");\nvar _react = require(\"react\");\nvar _reactDefault = parcelHelpers.interopDefault(_react);\nvar _reactDom = require(\"react-dom\");\nvar _reactDomDefault = parcelHelpers.interopDefault(_reactDom);\nvar _corePlugJson = require(\"./generated/core.plug.json\");\nvar _corePlugJsonDefault = parcelHelpers.interopDefault(_corePlugJson);\nvar _commands1 = require(\"./commands\");\nvar _commandPalette = require(\"./components/command_palette\");\nvar _pageNavigator = require(\"./components/page_navigator\");\nvar _statusBar = require(\"./components/status_bar\");\nvar _topBar = require(\"./components/top_bar\");\nvar _indexer = require(\"./indexer\");\nvar _lineWrapper = require(\"./lineWrapper\");\nvar _markdown = require(\"./markdown\");\nvar _navigator = require(\"./navigator\");\nvar _parser = require(\"./parser\");\nvar _parserDefault = parcelHelpers.interopDefault(_parser);\nvar _runtime = require(\"../../plugbox/src/runtime\");\nvar _types = require(\"./types\");\nvar _reducer = require(\"./reducer\");\nvar _reducerDefault = parcelHelpers.interopDefault(_reducer);\nvar _smartQuotes = require(\"./smart_quotes\");\nvar _style = require(\"./style\");\nvar _styleDefault = parcelHelpers.interopDefault(_style);\nvar _dbLocalstorage = require(\"./syscalls/db.localstorage\");\nvar _dbLocalstorageDefault = parcelHelpers.interopDefault(_dbLocalstorage);\nvar _editorBrowser = require(\"./syscalls/editor.browser\");\nvar _editorBrowserDefault = parcelHelpers.interopDefault(_editorBrowser);\nvar _indexerNative = require(\"./syscalls/indexer.native\");\nvar _indexerNativeDefault = parcelHelpers.interopDefault(_indexerNative);\nvar _spaceNative = require(\"./syscalls/space.native\");\nvar _spaceNativeDefault = parcelHelpers.interopDefault(_spaceNative);\nvar _util = require(\"./util\");\n// @ts-ignore\nwindow.coreManifest = _corePlugJsonDefault.default;\nclass PageState {\n constructor(editorState, scrollTop, meta){\n this.editorState = editorState;\n this.scrollTop = scrollTop;\n this.meta = meta;\n }\n}\nconst watchInterval = 5000;\nclass Editor {\n constructor(space, parent){\n this.editorCommands = new Map();\n this.openPages = new Map();\n this.plugs = [];\n this.space = space;\n this.viewState = _types.initialViewState;\n this.viewDispatch = ()=>{\n };\n this.render(parent);\n this.editorView = new _view.EditorView({\n state: this.createEditorState(\"\"),\n parent: document.getElementById(\"editor\")\n });\n this.pageNavigator = new _navigator.PathPageNavigator();\n this.indexer = new _indexer.Indexer(\"page-index\", space);\n this.watch();\n }\n async init() {\n await this.loadPageList();\n await this.loadPlugs();\n this.focus();\n this.pageNavigator.subscribe(async (pageName)=>{\n await this.save();\n console.log(\"Now navigating to\", pageName);\n if (!this.editorView) return;\n await this.loadPage(pageName);\n });\n if (this.pageNavigator.getCurrentPage() === \"\") this.pageNavigator.navigate(\"start\");\n }\n async loadPlugs() {\n const system = new _runtime.System();\n system.registerSyscalls(_dbLocalstorageDefault.default, _editorBrowserDefault.default(this), _spaceNativeDefault.default(this), _indexerNativeDefault.default(this.indexer));\n console.log(\"Now loading core plug\");\n let mainPlug = await system.load(\"core\", _corePlugJsonDefault.default);\n this.plugs.push(mainPlug);\n this.editorCommands = new Map();\n for (let plug of this.plugs)this.buildCommands(plug);\n this.viewDispatch({\n type: \"update-commands\",\n commands: this.editorCommands\n });\n }\n buildCommands(plug) {\n const cmds = plug.manifest.hooks.commands;\n for(let name in cmds){\n let cmd = cmds[name];\n this.editorCommands.set(name, {\n command: cmd,\n run: async (arg)=>{\n return await plug.invoke(cmd.invoke, [\n arg\n ]);\n }\n });\n }\n }\n // TODO: Parallelize?\n async dispatchAppEvent(name, data) {\n let results = [];\n for (let plug of this.plugs){\n let plugResults = await plug.dispatchEvent(name, data);\n if (plugResults) for (let result of plugResults)results.push(result);\n }\n return results;\n }\n get currentPage() {\n return this.viewState.currentPage;\n }\n createEditorState(text) {\n const editor = this;\n let commandKeyBindings = [];\n for (let def of this.editorCommands.values())if (def.command.key) commandKeyBindings.push({\n key: def.command.key,\n mac: def.command.mac,\n run: ()=>{\n Promise.resolve().then(async ()=>{\n await def.run(null);\n }).catch((e)=>console.error(e)\n );\n return true;\n }\n });\n return _state.EditorState.create({\n doc: text,\n extensions: [\n _view.highlightSpecialChars(),\n _history.history(),\n _view.drawSelection(),\n _view.dropCursor(),\n // indentOnInput(),\n _styleDefault.default,\n _matchbrackets.bracketMatching(),\n _closebrackets.closeBrackets(),\n _autocomplete.autocompletion({\n override: [\n this.plugCompleter.bind(this),\n this.commandCompleter.bind(this), \n ]\n }),\n _view.EditorView.lineWrapping,\n _lineWrapper.lineWrapper([\n {\n selector: \"ATXHeading1\",\n class: \"line-h1\"\n },\n {\n selector: \"ATXHeading2\",\n class: \"line-h2\"\n },\n {\n selector: \"ATXHeading3\",\n class: \"line-h3\"\n },\n {\n selector: \"ListItem\",\n class: \"line-li\",\n nesting: true\n },\n {\n selector: \"Blockquote\",\n class: \"line-blockquote\"\n },\n {\n selector: \"Task\",\n class: \"line-task\"\n },\n {\n selector: \"CodeBlock\",\n class: \"line-code\"\n },\n {\n selector: \"FencedCode\",\n class: \"line-fenced-code\"\n },\n {\n selector: \"Comment\",\n class: \"line-comment\"\n },\n {\n selector: \"BulletList\",\n class: \"line-ul\"\n },\n {\n selector: \"OrderedList\",\n class: \"line-ol\"\n }, \n ]),\n _view.keymap.of([\n ..._smartQuotes.smartQuoteKeymap,\n ..._closebrackets.closeBracketsKeymap,\n ..._commands.standardKeymap,\n ..._search.searchKeymap,\n ..._history.historyKeymap,\n ..._autocomplete.completionKeymap,\n _commands.indentWithTab,\n ...commandKeyBindings,\n {\n key: \"Ctrl-b\",\n mac: \"Cmd-b\",\n run: _commands1.insertMarker(\"**\")\n },\n {\n key: \"Ctrl-i\",\n mac: \"Cmd-i\",\n run: _commands1.insertMarker(\"_\")\n },\n {\n key: \"Ctrl-p\",\n mac: \"Cmd-p\",\n run: ()=>{\n window.open(location.href, \"_blank\").focus();\n return true;\n }\n },\n {\n key: \"Ctrl-k\",\n mac: \"Cmd-k\",\n run: (target)=>{\n this.viewDispatch({\n type: \"start-navigate\"\n });\n return true;\n }\n },\n {\n key: \"Ctrl-s\",\n mac: \"Cmd-s\",\n run: (target)=>{\n this.save();\n return true;\n }\n },\n {\n key: \"Ctrl-.\",\n mac: \"Cmd-.\",\n run: (target)=>{\n console.log(\"YO\");\n this.viewDispatch({\n type: \"show-palette\"\n });\n return true;\n }\n }, \n ]),\n _view.EditorView.domEventHandlers({\n click: (event, view)=>{\n _util.safeRun(async ()=>{\n let clickEvent = {\n ctrlKey: event.ctrlKey,\n metaKey: event.metaKey,\n altKey: event.altKey,\n pos: view.posAtCoords(event)\n };\n await this.dispatchAppEvent(\"page:click\", clickEvent);\n });\n }\n }),\n _markdown.markdown({\n base: _parserDefault.default\n }),\n _state.StateField.define({\n create: ()=>null\n ,\n update: this.update.bind(this)\n }), \n ]\n });\n }\n async plugCompleter(ctx) {\n let allCompletionResults = await this.dispatchAppEvent(\"editor:complete\");\n if (allCompletionResults.length === 1) return allCompletionResults[0];\n else if (allCompletionResults.length > 1) console.error(\"Got completion results from multiple sources, cannot deal with that\", allCompletionResults);\n return null;\n }\n commandCompleter(ctx) {\n let prefix = ctx.matchBefore(_types.slashCommandRegexp);\n if (!prefix) return null;\n let options = [];\n for (let [name, def] of this.viewState.commands){\n if (!def.command.slashCommand) continue;\n options.push({\n label: def.command.slashCommand,\n detail: name,\n apply: ()=>{\n this.editorView?.dispatch({\n changes: {\n from: prefix.from,\n to: ctx.pos,\n insert: \"\"\n }\n });\n _util.safeRun(async ()=>{\n def.run(null);\n });\n }\n });\n }\n return {\n from: prefix.from + 1,\n options: options\n };\n }\n update(value, transaction) {\n if (transaction.docChanged) this.viewDispatch({\n type: \"page-updated\"\n });\n return null;\n }\n async save() {\n const editorState = this.editorView.state;\n if (!this.currentPage) return;\n if (this.viewState.isSaved) {\n console.log(\"Page not modified, skipping saving\");\n return;\n }\n // Write to the space\n const pageName = this.currentPage.name;\n const text = editorState.sliceDoc();\n let pageMeta = await this.space.writePage(pageName, text);\n // Update in open page cache\n this.openPages.set(pageName, new PageState(editorState, this.editorView.scrollDOM.scrollTop, pageMeta));\n // Dispatch update to view\n this.viewDispatch({\n type: \"page-saved\",\n meta: pageMeta\n });\n // If a new page was created, let's refresh the page list\n if (pageMeta.created) await this.loadPageList();\n // Reindex page\n await this.indexPage(text, pageMeta);\n }\n async indexPage(text, pageMeta) {\n console.log(\"Indexing page\", pageMeta.name);\n this.indexer.indexPage(this, pageMeta, text, true);\n }\n async loadPageList() {\n let pagesMeta = await this.space.listPages();\n this.viewDispatch({\n type: \"pages-listed\",\n pages: pagesMeta\n });\n }\n watch() {\n setInterval(()=>{\n _util.safeRun(async ()=>{\n if (this.currentPage && this.viewState.isSaved) await this.checkForNewVersion(this.currentPage);\n });\n }, watchInterval);\n }\n async checkForNewVersion(cachedMeta) {\n const currentPageName = cachedMeta.name;\n let newPageMeta = await this.space.getPageMeta(currentPageName);\n if (cachedMeta.lastModified.getTime() !== newPageMeta.lastModified.getTime()) {\n console.log(\"File changed on disk, reloading\");\n let pageData = await this.space.readPage(currentPageName);\n this.openPages.set(currentPageName, new PageState(this.createEditorState(pageData.text), 0, newPageMeta));\n await this.loadPage(currentPageName, false);\n }\n }\n focus() {\n this.editorView.focus();\n }\n navigate(name) {\n this.pageNavigator.navigate(name);\n }\n async loadPage(pageName, checkNewVersion = true) {\n let pageState = this.openPages.get(pageName);\n if (!pageState) {\n let pageData = await this.space.readPage(pageName);\n pageState = new PageState(this.createEditorState(pageData.text), 0, pageData.meta);\n this.openPages.set(pageName, pageState);\n // Freshly loaded, no need to check for a new version either way\n checkNewVersion = false;\n }\n this.editorView.setState(pageState.editorState);\n this.editorView.scrollDOM.scrollTop = pageState.scrollTop;\n this.viewDispatch({\n type: \"page-loaded\",\n meta: pageState.meta\n });\n let indexerPageMeta = await this.indexer.getPageIndexPageMeta(pageName);\n if (indexerPageMeta && pageState.meta.lastModified.getTime() !== indexerPageMeta.lastModified.getTime() || !indexerPageMeta) await this.indexPage(pageState.editorState.sliceDoc(), pageState.meta);\n if (checkNewVersion) // Loaded page from in-memory cache, let's async see if this page hasn't been updated\n this.checkForNewVersion(pageState.meta).catch((e)=>{\n console.error(\"Failed to check for new version\");\n });\n }\n ViewComponent() {\n const [viewState, dispatch] = _react.useReducer(_reducerDefault.default, _types.initialViewState);\n this.viewState = viewState;\n this.viewDispatch = dispatch;\n // Auto save\n _react.useEffect(()=>{\n const id = setTimeout(()=>{\n if (!viewState.isSaved) this.save();\n }, 2000);\n return ()=>{\n clearTimeout(id);\n };\n }, [\n viewState.isSaved\n ]);\n let editor = this;\n _react.useEffect(()=>{\n if (viewState.currentPage) document.title = viewState.currentPage.name;\n }, [\n viewState.currentPage\n ]);\n return(/*#__PURE__*/ _jsxDevRuntime.jsxDEV(_jsxDevRuntime.Fragment, {\n children: [\n viewState.showPageNavigator && /*#__PURE__*/ _jsxDevRuntime.jsxDEV(_pageNavigator.PageNavigator, {\n allPages: viewState.allPages,\n currentPage: this.currentPage,\n onNavigate: (page)=>{\n dispatch({\n type: \"stop-navigate\"\n });\n editor.focus();\n if (page) _util.safeRun(async ()=>{\n editor.navigate(page);\n });\n }\n }, void 0, false, {\n fileName: \"/Users/zef/git/nugget/webapp/src/editor.tsx\",\n lineNumber: 526,\n columnNumber: 11\n }, this),\n viewState.showCommandPalette && /*#__PURE__*/ _jsxDevRuntime.jsxDEV(_commandPalette.CommandPalette, {\n onTrigger: (cmd)=>{\n dispatch({\n type: \"hide-palette\"\n });\n editor.focus();\n if (cmd) _util.safeRun(async ()=>{\n let result = await cmd.run(null);\n console.log(\"Result of command\", result);\n });\n },\n commands: viewState.commands\n }, void 0, false, {\n fileName: \"/Users/zef/git/nugget/webapp/src/editor.tsx\",\n lineNumber: 541,\n columnNumber: 11\n }, this),\n /*#__PURE__*/ _jsxDevRuntime.jsxDEV(_topBar.TopBar, {\n currentPage: viewState.currentPage,\n onClick: ()=>{\n dispatch({\n type: \"start-navigate\"\n });\n }\n }, void 0, false, {\n fileName: \"/Users/zef/git/nugget/webapp/src/editor.tsx\",\n lineNumber: 555,\n columnNumber: 9\n }, this),\n /*#__PURE__*/ _jsxDevRuntime.jsxDEV(\"div\", {\n id: \"editor\"\n }, void 0, false, {\n fileName: \"/Users/zef/git/nugget/webapp/src/editor.tsx\",\n lineNumber: 561,\n columnNumber: 9\n }, this),\n /*#__PURE__*/ _jsxDevRuntime.jsxDEV(_statusBar.StatusBar, {\n isSaved: viewState.isSaved,\n editorView: this.editorView\n }, void 0, false, {\n fileName: \"/Users/zef/git/nugget/webapp/src/editor.tsx\",\n lineNumber: 562,\n columnNumber: 9\n }, this)\n ]\n }, void 0, true));\n }\n render(container) {\n const ViewComponent = this.ViewComponent.bind(this);\n _reactDomDefault.default.render(/*#__PURE__*/ _jsxDevRuntime.jsxDEV(ViewComponent, {\n }, void 0, false, {\n fileName: \"/Users/zef/git/nugget/webapp/src/editor.tsx\",\n lineNumber: 569,\n columnNumber: 21\n }, this), container);\n }\n}\n\n $parcel$ReactRefreshHelpers$7051.postlude(module);\n} finally {\n window.$RefreshReg$ = prevRefreshReg;\n window.$RefreshSig$ = prevRefreshSig;\n}\n},{\"react/jsx-dev-runtime\":\"jsc7i\",\"@codemirror/autocomplete\":\"6gQUZ\",\"@codemirror/closebrackets\":\"kSxGE\",\"@codemirror/commands\":\"jsegn\",\"@codemirror/history\":\"foAcC\",\"@codemirror/matchbrackets\":\"58KS3\",\"@codemirror/search\":\"d16bT\",\"@codemirror/state\":\"e6FBl\",\"@codemirror/view\":\"JuP5Z\",\"react\":\"1PJsa\",\"react-dom\":\"dPtAI\",\"./generated/core.plug.json\":\"4ZyF2\",\"./commands\":\"6J6FU\",\"./components/command_palette\":\"hTiUo\",\"./components/page_navigator\":\"fsrQb\",\"./components/status_bar\":\"d3BjR\",\"./components/top_bar\":\"clh7D\",\"./indexer\":\"bIR6j\",\"./lineWrapper\":\"kLtCZ\",\"./markdown\":\"bsH55\",\"./navigator\":\"hU6Am\",\"./parser\":\"ecodz\",\"../../plugbox/src/runtime\":\"eSjNz\",\"./types\":\"8TXso\",\"./reducer\":\"nLnWn\",\"./smart_quotes\":\"1Ie8K\",\"./style\":\"cDDDV\",\"./syscalls/db.localstorage\":\"8aIJL\",\"./syscalls/editor.browser\":\"lj9QJ\",\"./syscalls/indexer.native\":\"c4pla\",\"./syscalls/space.native\":\"h23Wg\",\"./util\":\"eF4A3\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\",\"@parcel/transformer-react-refresh-wrap/lib/helpers/helpers.js\":\"km3Ru\"}],\"jsc7i\":[function(require,module,exports) {\n'use strict';\nmodule.exports = require('./cjs/react-jsx-dev-runtime.development.js');\n\n},{\"./cjs/react-jsx-dev-runtime.development.js\":\"gOwRd\"}],\"gOwRd\":[function(require,module,exports) {\n/** @license React v17.0.2\n * react-jsx-dev-runtime.development.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */ 'use strict';\n(function() {\n var React = require('react');\n var _assign = require('object-assign');\n // ATTENTION\n // When adding new symbols to this file,\n // Please consider also adding to 'react-devtools-shared/src/backend/ReactSymbols'\n // The Symbol used to tag the ReactElement-like types. If there is no native Symbol\n // nor polyfill, then a plain number is used for performance.\n var REACT_ELEMENT_TYPE = 60103;\n var REACT_PORTAL_TYPE = 60106;\n exports.Fragment = 60107;\n var REACT_STRICT_MODE_TYPE = 60108;\n var REACT_PROFILER_TYPE = 60114;\n var REACT_PROVIDER_TYPE = 60109;\n var REACT_CONTEXT_TYPE = 60110;\n var REACT_FORWARD_REF_TYPE = 60112;\n var REACT_SUSPENSE_TYPE = 60113;\n var REACT_SUSPENSE_LIST_TYPE = 60120;\n var REACT_MEMO_TYPE = 60115;\n var REACT_LAZY_TYPE = 60116;\n var REACT_BLOCK_TYPE = 60121;\n var REACT_SERVER_BLOCK_TYPE = 60122;\n var REACT_FUNDAMENTAL_TYPE = 60117;\n var REACT_SCOPE_TYPE = 60119;\n var REACT_OPAQUE_ID_TYPE = 60128;\n var REACT_DEBUG_TRACING_MODE_TYPE = 60129;\n var REACT_OFFSCREEN_TYPE = 60130;\n var REACT_LEGACY_HIDDEN_TYPE = 60131;\n if (typeof Symbol === 'function' && Symbol.for) {\n var symbolFor = Symbol.for;\n REACT_ELEMENT_TYPE = symbolFor('react.element');\n REACT_PORTAL_TYPE = symbolFor('react.portal');\n exports.Fragment = symbolFor('react.fragment');\n REACT_STRICT_MODE_TYPE = symbolFor('react.strict_mode');\n REACT_PROFILER_TYPE = symbolFor('react.profiler');\n REACT_PROVIDER_TYPE = symbolFor('react.provider');\n REACT_CONTEXT_TYPE = symbolFor('react.context');\n REACT_FORWARD_REF_TYPE = symbolFor('react.forward_ref');\n REACT_SUSPENSE_TYPE = symbolFor('react.suspense');\n REACT_SUSPENSE_LIST_TYPE = symbolFor('react.suspense_list');\n REACT_MEMO_TYPE = symbolFor('react.memo');\n REACT_LAZY_TYPE = symbolFor('react.lazy');\n REACT_BLOCK_TYPE = symbolFor('react.block');\n REACT_SERVER_BLOCK_TYPE = symbolFor('react.server.block');\n REACT_FUNDAMENTAL_TYPE = symbolFor('react.fundamental');\n REACT_SCOPE_TYPE = symbolFor('react.scope');\n REACT_OPAQUE_ID_TYPE = symbolFor('react.opaque.id');\n REACT_DEBUG_TRACING_MODE_TYPE = symbolFor('react.debug_trace_mode');\n REACT_OFFSCREEN_TYPE = symbolFor('react.offscreen');\n REACT_LEGACY_HIDDEN_TYPE = symbolFor('react.legacy_hidden');\n }\n var MAYBE_ITERATOR_SYMBOL = typeof Symbol === 'function' && Symbol.iterator;\n var FAUX_ITERATOR_SYMBOL = '@@iterator';\n function getIteratorFn(maybeIterable) {\n if (maybeIterable === null || typeof maybeIterable !== 'object') return null;\n var maybeIterator = MAYBE_ITERATOR_SYMBOL && maybeIterable[MAYBE_ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL];\n if (typeof maybeIterator === 'function') return maybeIterator;\n return null;\n }\n var ReactSharedInternals = React.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;\n function error(format) {\n for(var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++)args[_key2 - 1] = arguments[_key2];\n printWarning('error', format, args);\n }\n function printWarning(level, format, args) {\n var ReactDebugCurrentFrame = ReactSharedInternals.ReactDebugCurrentFrame;\n var stack = ReactDebugCurrentFrame.getStackAddendum();\n if (stack !== '') {\n format += '%s';\n args = args.concat([\n stack\n ]);\n }\n var argsWithFormat = args.map(function(item) {\n return '' + item;\n }); // Careful: RN currently depends on this prefix\n argsWithFormat.unshift('Warning: ' + format); // We intentionally don't use spread (or .apply) directly because it\n // breaks IE9: https://github.com/facebook/react/issues/13610\n // eslint-disable-next-line react-internal/no-production-logging\n Function.prototype.apply.call(console[level], console, argsWithFormat);\n }\n // Filter certain DOM attributes (e.g. src, href) if their values are empty strings.\n var enableScopeAPI = false; // Experimental Create Event Handle API.\n function isValidElementType(type) {\n if (typeof type === 'string' || typeof type === 'function') return true;\n // Note: typeof might be other than 'symbol' or 'number' (e.g. if it's a polyfill).\n if (type === exports.Fragment || type === REACT_PROFILER_TYPE || type === REACT_DEBUG_TRACING_MODE_TYPE || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || type === REACT_LEGACY_HIDDEN_TYPE || enableScopeAPI) return true;\n if (typeof type === 'object' && type !== null) {\n if (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_PROVIDER_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE || type.$$typeof === REACT_FUNDAMENTAL_TYPE || type.$$typeof === REACT_BLOCK_TYPE || type[0] === REACT_SERVER_BLOCK_TYPE) return true;\n }\n return false;\n }\n function getWrappedName(outerType, innerType, wrapperName) {\n var functionName = innerType.displayName || innerType.name || '';\n return outerType.displayName || (functionName !== '' ? wrapperName + \"(\" + functionName + \")\" : wrapperName);\n }\n function getContextName(type) {\n return type.displayName || 'Context';\n }\n function getComponentName(type) {\n if (type == null) // Host root, text node or just invalid type.\n return null;\n if (typeof type.tag === 'number') error(\"Received an unexpected object in getComponentName(). This is likely a bug in React. Please file an issue.\");\n if (typeof type === 'function') return type.displayName || type.name || null;\n if (typeof type === 'string') return type;\n switch(type){\n case exports.Fragment:\n return 'Fragment';\n case REACT_PORTAL_TYPE:\n return 'Portal';\n case REACT_PROFILER_TYPE:\n return 'Profiler';\n case REACT_STRICT_MODE_TYPE:\n return 'StrictMode';\n case REACT_SUSPENSE_TYPE:\n return 'Suspense';\n case REACT_SUSPENSE_LIST_TYPE:\n return 'SuspenseList';\n }\n if (typeof type === 'object') switch(type.$$typeof){\n case REACT_CONTEXT_TYPE:\n var context = type;\n return getContextName(context) + '.Consumer';\n case REACT_PROVIDER_TYPE:\n var provider = type;\n return getContextName(provider._context) + '.Provider';\n case REACT_FORWARD_REF_TYPE:\n return getWrappedName(type, type.render, 'ForwardRef');\n case REACT_MEMO_TYPE:\n return getComponentName(type.type);\n case REACT_BLOCK_TYPE:\n return getComponentName(type._render);\n case REACT_LAZY_TYPE:\n var lazyComponent = type;\n var payload = lazyComponent._payload;\n var init = lazyComponent._init;\n try {\n return getComponentName(init(payload));\n } catch (x) {\n return null;\n }\n }\n return null;\n }\n // Helpers to patch console.logs to avoid logging during side-effect free\n // replaying on render function. This currently only patches the object\n // lazily which won't cover if the log function was extracted eagerly.\n // We could also eagerly patch the method.\n var disabledDepth = 0;\n var prevLog;\n var prevInfo;\n var prevWarn;\n var prevError;\n var prevGroup;\n var prevGroupCollapsed;\n var prevGroupEnd;\n function disabledLog() {\n }\n disabledLog.__reactDisabledLog = true;\n function disableLogs() {\n if (disabledDepth === 0) {\n /* eslint-disable react-internal/no-production-logging */ prevLog = console.log;\n prevInfo = console.info;\n prevWarn = console.warn;\n prevError = console.error;\n prevGroup = console.group;\n prevGroupCollapsed = console.groupCollapsed;\n prevGroupEnd = console.groupEnd; // https://github.com/facebook/react/issues/19099\n var props = {\n configurable: true,\n enumerable: true,\n value: disabledLog,\n writable: true\n }; // $FlowFixMe Flow thinks console is immutable.\n Object.defineProperties(console, {\n info: props,\n log: props,\n warn: props,\n error: props,\n group: props,\n groupCollapsed: props,\n groupEnd: props\n });\n /* eslint-enable react-internal/no-production-logging */ }\n disabledDepth++;\n }\n function reenableLogs() {\n disabledDepth--;\n if (disabledDepth === 0) {\n /* eslint-disable react-internal/no-production-logging */ var props = {\n configurable: true,\n enumerable: true,\n writable: true\n }; // $FlowFixMe Flow thinks console is immutable.\n Object.defineProperties(console, {\n log: _assign({\n }, props, {\n value: prevLog\n }),\n info: _assign({\n }, props, {\n value: prevInfo\n }),\n warn: _assign({\n }, props, {\n value: prevWarn\n }),\n error: _assign({\n }, props, {\n value: prevError\n }),\n group: _assign({\n }, props, {\n value: prevGroup\n }),\n groupCollapsed: _assign({\n }, props, {\n value: prevGroupCollapsed\n }),\n groupEnd: _assign({\n }, props, {\n value: prevGroupEnd\n })\n });\n /* eslint-enable react-internal/no-production-logging */ }\n if (disabledDepth < 0) error(\"disabledDepth fell below zero. This is a bug in React. Please file an issue.\");\n }\n var ReactCurrentDispatcher = ReactSharedInternals.ReactCurrentDispatcher;\n var prefix;\n function describeBuiltInComponentFrame(name, source, ownerFn) {\n if (prefix === undefined) // Extract the VM specific prefix used by each line.\n try {\n throw Error();\n } catch (x) {\n var match = x.stack.trim().match(/\\n( *(at )?)/);\n prefix = match && match[1] || '';\n }\n // We use the prefix to ensure our stacks line up with native stack frames.\n return '\\n' + prefix + name;\n }\n var reentry = false;\n var componentFrameCache;\n var PossiblyWeakMap = typeof WeakMap === 'function' ? WeakMap : Map;\n componentFrameCache = new PossiblyWeakMap();\n function describeNativeComponentFrame(fn, construct) {\n // If something asked for a stack inside a fake render, it should get ignored.\n if (!fn || reentry) return '';\n var frame = componentFrameCache.get(fn);\n if (frame !== undefined) return frame;\n var control;\n reentry = true;\n var previousPrepareStackTrace = Error.prepareStackTrace; // $FlowFixMe It does accept undefined.\n Error.prepareStackTrace = undefined;\n var previousDispatcher;\n previousDispatcher = ReactCurrentDispatcher.current; // Set the dispatcher in DEV because this might be call in the render function\n // for warnings.\n ReactCurrentDispatcher.current = null;\n disableLogs();\n try {\n // This should throw.\n if (construct) {\n // Something should be setting the props in the constructor.\n var Fake = function() {\n throw Error();\n }; // $FlowFixMe\n Object.defineProperty(Fake.prototype, 'props', {\n set: function() {\n // We use a throwing setter instead of frozen or non-writable props\n // because that won't throw in a non-strict mode function.\n throw Error();\n }\n });\n if (typeof Reflect === 'object' && Reflect.construct) {\n // We construct a different control for this case to include any extra\n // frames added by the construct call.\n try {\n Reflect.construct(Fake, []);\n } catch (x) {\n control = x;\n }\n Reflect.construct(fn, [], Fake);\n } else {\n try {\n Fake.call();\n } catch (x) {\n control = x;\n }\n fn.call(Fake.prototype);\n }\n } else {\n try {\n throw Error();\n } catch (x) {\n control = x;\n }\n fn();\n }\n } catch (sample) {\n // This is inlined manually because closure doesn't do it for us.\n if (sample && control && typeof sample.stack === 'string') {\n // This extracts the first frame from the sample that isn't also in the control.\n // Skipping one frame that we assume is the frame that calls the two.\n var sampleLines = sample.stack.split('\\n');\n var controlLines = control.stack.split('\\n');\n var s = sampleLines.length - 1;\n var c = controlLines.length - 1;\n while(s >= 1 && c >= 0 && sampleLines[s] !== controlLines[c])// We expect at least one stack frame to be shared.\n // Typically this will be the root most one. However, stack frames may be\n // cut off due to maximum stack limits. In this case, one maybe cut off\n // earlier than the other. We assume that the sample is longer or the same\n // and there for cut off earlier. So we should find the root most frame in\n // the sample somewhere in the control.\n c--;\n for(; s >= 1 && c >= 0; s--, c--)// Next we find the first one that isn't the same which should be the\n // frame that called our sample function and the control.\n if (sampleLines[s] !== controlLines[c]) {\n // In V8, the first line is describing the message but other VMs don't.\n // If we're about to return the first line, and the control is also on the same\n // line, that's a pretty good indicator that our sample threw at same line as\n // the control. I.e. before we entered the sample frame. So we ignore this result.\n // This can happen if you passed a class to function component, or non-function.\n if (s !== 1 || c !== 1) do {\n s--;\n c--; // We may still have similar intermediate frames from the construct call.\n // The next one that isn't the same should be our match though.\n if (c < 0 || sampleLines[s] !== controlLines[c]) {\n // V8 adds a \"new\" prefix for native classes. Let's remove it to make it prettier.\n var _frame = '\\n' + sampleLines[s].replace(' at new ', ' at ');\n if (typeof fn === 'function') componentFrameCache.set(fn, _frame);\n return _frame;\n }\n }while (s >= 1 && c >= 0)\n break;\n }\n }\n } finally{\n reentry = false;\n ReactCurrentDispatcher.current = previousDispatcher;\n reenableLogs();\n Error.prepareStackTrace = previousPrepareStackTrace;\n } // Fallback to just using the name if we couldn't make it throw.\n var name = fn ? fn.displayName || fn.name : '';\n var syntheticFrame = name ? describeBuiltInComponentFrame(name) : '';\n if (typeof fn === 'function') componentFrameCache.set(fn, syntheticFrame);\n return syntheticFrame;\n }\n function describeFunctionComponentFrame(fn, source, ownerFn) {\n return describeNativeComponentFrame(fn, false);\n }\n function shouldConstruct(Component) {\n var prototype = Component.prototype;\n return !!(prototype && prototype.isReactComponent);\n }\n function describeUnknownElementTypeFrameInDEV(type, source, ownerFn) {\n if (type == null) return '';\n if (typeof type === 'function') return describeNativeComponentFrame(type, shouldConstruct(type));\n if (typeof type === 'string') return describeBuiltInComponentFrame(type);\n switch(type){\n case REACT_SUSPENSE_TYPE:\n return describeBuiltInComponentFrame('Suspense');\n case REACT_SUSPENSE_LIST_TYPE:\n return describeBuiltInComponentFrame('SuspenseList');\n }\n if (typeof type === 'object') switch(type.$$typeof){\n case REACT_FORWARD_REF_TYPE:\n return describeFunctionComponentFrame(type.render);\n case REACT_MEMO_TYPE:\n // Memo may contain any component type so we recursively resolve it.\n return describeUnknownElementTypeFrameInDEV(type.type, source, ownerFn);\n case REACT_BLOCK_TYPE:\n return describeFunctionComponentFrame(type._render);\n case REACT_LAZY_TYPE:\n var lazyComponent = type;\n var payload = lazyComponent._payload;\n var init = lazyComponent._init;\n try {\n // Lazy may contain any component type so we recursively resolve it.\n return describeUnknownElementTypeFrameInDEV(init(payload), source, ownerFn);\n } catch (x) {\n }\n }\n return '';\n }\n var loggedTypeFailures = {\n };\n var ReactDebugCurrentFrame1 = ReactSharedInternals.ReactDebugCurrentFrame;\n function setCurrentlyValidatingElement(element) {\n if (element) {\n var owner = element._owner;\n var stack = describeUnknownElementTypeFrameInDEV(element.type, element._source, owner ? owner.type : null);\n ReactDebugCurrentFrame1.setExtraStackFrame(stack);\n } else ReactDebugCurrentFrame1.setExtraStackFrame(null);\n }\n function checkPropTypes(typeSpecs, values, location, componentName, element) {\n // $FlowFixMe This is okay but Flow doesn't know it.\n var has = Function.call.bind(Object.prototype.hasOwnProperty);\n for(var typeSpecName in typeSpecs)if (has(typeSpecs, typeSpecName)) {\n var error$1 = void 0; // Prop type validation may throw. In case they do, we don't want to\n // fail the render phase where it didn't fail before. So we log it.\n // After these have been cleaned up, we'll let them throw.\n try {\n // This is intentionally an invariant that gets caught. It's the same\n // behavior as without this statement except with a better message.\n if (typeof typeSpecs[typeSpecName] !== 'function') {\n var err = Error((componentName || 'React class') + ': ' + location + ' type `' + typeSpecName + '` is invalid; ' + 'it must be a function, usually from the `prop-types` package, but received `' + typeof typeSpecs[typeSpecName] + '`.' + 'This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.');\n err.name = 'Invariant Violation';\n throw err;\n }\n error$1 = typeSpecs[typeSpecName](values, typeSpecName, componentName, location, null, 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED');\n } catch (ex) {\n error$1 = ex;\n }\n if (error$1 && !(error$1 instanceof Error)) {\n setCurrentlyValidatingElement(element);\n error(\"%s: type specification of %s `%s` is invalid; the type checker function must return `null` or an `Error` but returned a %s. You may have forgotten to pass an argument to the type checker creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and shape all require an argument).\", componentName || 'React class', location, typeSpecName, typeof error$1);\n setCurrentlyValidatingElement(null);\n }\n if (error$1 instanceof Error && !(error$1.message in loggedTypeFailures)) {\n // Only monitor this failure once because there tends to be a lot of the\n // same error.\n loggedTypeFailures[error$1.message] = true;\n setCurrentlyValidatingElement(element);\n error('Failed %s type: %s', location, error$1.message);\n setCurrentlyValidatingElement(null);\n }\n }\n }\n var ReactCurrentOwner = ReactSharedInternals.ReactCurrentOwner;\n var hasOwnProperty = Object.prototype.hasOwnProperty;\n var RESERVED_PROPS = {\n key: true,\n ref: true,\n __self: true,\n __source: true\n };\n var specialPropKeyWarningShown;\n var specialPropRefWarningShown;\n var didWarnAboutStringRefs;\n didWarnAboutStringRefs = {\n };\n function hasValidRef(config) {\n if (hasOwnProperty.call(config, 'ref')) {\n var getter = Object.getOwnPropertyDescriptor(config, 'ref').get;\n if (getter && getter.isReactWarning) return false;\n }\n return config.ref !== undefined;\n }\n function hasValidKey(config) {\n if (hasOwnProperty.call(config, 'key')) {\n var getter = Object.getOwnPropertyDescriptor(config, 'key').get;\n if (getter && getter.isReactWarning) return false;\n }\n return config.key !== undefined;\n }\n function warnIfStringRefCannotBeAutoConverted(config, self) {\n if (typeof config.ref === 'string' && ReactCurrentOwner.current && self && ReactCurrentOwner.current.stateNode !== self) {\n var componentName = getComponentName(ReactCurrentOwner.current.type);\n if (!didWarnAboutStringRefs[componentName]) {\n error(\"Component \\\"%s\\\" contains the string ref \\\"%s\\\". Support for string refs will be removed in a future major release. This case cannot be automatically converted to an arrow function. We ask you to manually fix this case by using useRef() or createRef() instead. Learn more about using refs safely here: https://reactjs.org/link/strict-mode-string-ref\", getComponentName(ReactCurrentOwner.current.type), config.ref);\n didWarnAboutStringRefs[componentName] = true;\n }\n }\n }\n function defineKeyPropWarningGetter(props, displayName) {\n var warnAboutAccessingKey = function() {\n if (!specialPropKeyWarningShown) {\n specialPropKeyWarningShown = true;\n error(\"%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)\", displayName);\n }\n };\n warnAboutAccessingKey.isReactWarning = true;\n Object.defineProperty(props, 'key', {\n get: warnAboutAccessingKey,\n configurable: true\n });\n }\n function defineRefPropWarningGetter(props, displayName) {\n var warnAboutAccessingRef = function() {\n if (!specialPropRefWarningShown) {\n specialPropRefWarningShown = true;\n error(\"%s: `ref` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)\", displayName);\n }\n };\n warnAboutAccessingRef.isReactWarning = true;\n Object.defineProperty(props, 'ref', {\n get: warnAboutAccessingRef,\n configurable: true\n });\n }\n /**\n * Factory method to create a new React element. This no longer adheres to\n * the class pattern, so do not use new to call it. Also, instanceof check\n * will not work. Instead test $$typeof field against Symbol.for('react.element') to check\n * if something is a React Element.\n *\n * @param {*} type\n * @param {*} props\n * @param {*} key\n * @param {string|object} ref\n * @param {*} owner\n * @param {*} self A *temporary* helper to detect places where `this` is\n * different from the `owner` when React.createElement is called, so that we\n * can warn. We want to get rid of owner and replace string `ref`s with arrow\n * functions, and as long as `this` and owner are the same, there will be no\n * change in behavior.\n * @param {*} source An annotation object (added by a transpiler or otherwise)\n * indicating filename, line number, and/or other information.\n * @internal\n */ var ReactElement = function(type, key, ref, self, source, owner, props) {\n var element = {\n // This tag allows us to uniquely identify this as a React Element\n $$typeof: REACT_ELEMENT_TYPE,\n // Built-in properties that belong on the element\n type: type,\n key: key,\n ref: ref,\n props: props,\n // Record the component responsible for creating this element.\n _owner: owner\n };\n // The validation flag is currently mutative. We put it on\n // an external backing store so that we can freeze the whole object.\n // This can be replaced with a WeakMap once they are implemented in\n // commonly used development environments.\n element._store = {\n }; // To make comparing ReactElements easier for testing purposes, we make\n // the validation flag non-enumerable (where possible, which should\n // include every environment we run tests in), so the test framework\n // ignores it.\n Object.defineProperty(element._store, 'validated', {\n configurable: false,\n enumerable: false,\n writable: true,\n value: false\n }); // self and source are DEV only properties.\n Object.defineProperty(element, '_self', {\n configurable: false,\n enumerable: false,\n writable: false,\n value: self\n }); // Two elements created in two different places should be considered\n // equal for testing purposes and therefore we hide it from enumeration.\n Object.defineProperty(element, '_source', {\n configurable: false,\n enumerable: false,\n writable: false,\n value: source\n });\n if (Object.freeze) {\n Object.freeze(element.props);\n Object.freeze(element);\n }\n return element;\n };\n /**\n * https://github.com/reactjs/rfcs/pull/107\n * @param {*} type\n * @param {object} props\n * @param {string} key\n */ function jsxDEV(type, config, maybeKey, source, self) {\n var propName; // Reserved names are extracted\n var props = {\n };\n var key = null;\n var ref = null; // Currently, key can be spread in as a prop. This causes a potential\n // issue if key is also explicitly declared (ie. <div {...props} key=\"Hi\" />\n // or <div key=\"Hi\" {...props} /> ). We want to deprecate key spread,\n // but as an intermediary step, we will use jsxDEV for everything except\n // <div {...props} key=\"Hi\" />, because we aren't currently able to tell if\n // key is explicitly declared to be undefined or not.\n if (maybeKey !== undefined) key = '' + maybeKey;\n if (hasValidKey(config)) key = '' + config.key;\n if (hasValidRef(config)) {\n ref = config.ref;\n warnIfStringRefCannotBeAutoConverted(config, self);\n } // Remaining properties are added to a new props object\n for(propName in config)if (hasOwnProperty.call(config, propName) && !RESERVED_PROPS.hasOwnProperty(propName)) props[propName] = config[propName];\n // Resolve default props\n if (type && type.defaultProps) {\n var defaultProps = type.defaultProps;\n for(propName in defaultProps)if (props[propName] === undefined) props[propName] = defaultProps[propName];\n }\n if (key || ref) {\n var displayName = typeof type === 'function' ? type.displayName || type.name || 'Unknown' : type;\n if (key) defineKeyPropWarningGetter(props, displayName);\n if (ref) defineRefPropWarningGetter(props, displayName);\n }\n return ReactElement(type, key, ref, self, source, ReactCurrentOwner.current, props);\n }\n var ReactCurrentOwner$1 = ReactSharedInternals.ReactCurrentOwner;\n var ReactDebugCurrentFrame$1 = ReactSharedInternals.ReactDebugCurrentFrame;\n function setCurrentlyValidatingElement$1(element) {\n if (element) {\n var owner = element._owner;\n var stack = describeUnknownElementTypeFrameInDEV(element.type, element._source, owner ? owner.type : null);\n ReactDebugCurrentFrame$1.setExtraStackFrame(stack);\n } else ReactDebugCurrentFrame$1.setExtraStackFrame(null);\n }\n var propTypesMisspellWarningShown;\n propTypesMisspellWarningShown = false;\n /**\n * Verifies the object is a ReactElement.\n * See https://reactjs.org/docs/react-api.html#isvalidelement\n * @param {?object} object\n * @return {boolean} True if `object` is a ReactElement.\n * @final\n */ function isValidElement(object) {\n return typeof object === 'object' && object !== null && object.$$typeof === REACT_ELEMENT_TYPE;\n }\n function getDeclarationErrorAddendum() {\n if (ReactCurrentOwner$1.current) {\n var name = getComponentName(ReactCurrentOwner$1.current.type);\n if (name) return '\\n\\nCheck the render method of `' + name + '`.';\n }\n return '';\n }\n function getSourceInfoErrorAddendum(source) {\n if (source !== undefined) {\n var fileName = source.fileName.replace(/^.*[\\\\\\/]/, '');\n var lineNumber = source.lineNumber;\n return '\\n\\nCheck your code at ' + fileName + ':' + lineNumber + '.';\n }\n return '';\n }\n /**\n * Warn if there's no key explicitly set on dynamic arrays of children or\n * object keys are not valid. This allows us to keep track of children between\n * updates.\n */ var ownerHasKeyUseWarning = {\n };\n function getCurrentComponentErrorInfo(parentType) {\n var info = getDeclarationErrorAddendum();\n if (!info) {\n var parentName = typeof parentType === 'string' ? parentType : parentType.displayName || parentType.name;\n if (parentName) info = \"\\n\\nCheck the top-level render call using <\" + parentName + \">.\";\n }\n return info;\n }\n /**\n * Warn if the element doesn't have an explicit key assigned to it.\n * This element is in an array. The array could grow and shrink or be\n * reordered. All children that haven't already been validated are required to\n * have a \"key\" property assigned to it. Error statuses are cached so a warning\n * will only be shown once.\n *\n * @internal\n * @param {ReactElement} element Element that requires a key.\n * @param {*} parentType element's parent's type.\n */ function validateExplicitKey(element, parentType) {\n if (!element._store || element._store.validated || element.key != null) return;\n element._store.validated = true;\n var currentComponentErrorInfo = getCurrentComponentErrorInfo(parentType);\n if (ownerHasKeyUseWarning[currentComponentErrorInfo]) return;\n ownerHasKeyUseWarning[currentComponentErrorInfo] = true; // Usually the current owner is the offender, but if it accepts children as a\n // property, it may be the creator of the child that's responsible for\n // assigning it a key.\n var childOwner = '';\n if (element && element._owner && element._owner !== ReactCurrentOwner$1.current) // Give the component that originally created this child.\n childOwner = \" It was passed a child from \" + getComponentName(element._owner.type) + \".\";\n setCurrentlyValidatingElement$1(element);\n error(\"Each child in a list should have a unique \\\"key\\\" prop.%s%s See https://reactjs.org/link/warning-keys for more information.\", currentComponentErrorInfo, childOwner);\n setCurrentlyValidatingElement$1(null);\n }\n /**\n * Ensure that every element either is passed in a static location, in an\n * array with an explicit keys property defined, or in an object literal\n * with valid key property.\n *\n * @internal\n * @param {ReactNode} node Statically passed child of any type.\n * @param {*} parentType node's parent's type.\n */ function validateChildKeys(node, parentType) {\n if (typeof node !== 'object') return;\n if (Array.isArray(node)) for(var i = 0; i < node.length; i++){\n var child = node[i];\n if (isValidElement(child)) validateExplicitKey(child, parentType);\n }\n else if (isValidElement(node)) // This element was passed in a valid location.\n {\n if (node._store) node._store.validated = true;\n } else if (node) {\n var iteratorFn = getIteratorFn(node);\n if (typeof iteratorFn === 'function') // Entry iterators used to provide implicit keys,\n // but now we print a separate warning for them later.\n {\n if (iteratorFn !== node.entries) {\n var iterator = iteratorFn.call(node);\n var step;\n while(!(step = iterator.next()).done)if (isValidElement(step.value)) validateExplicitKey(step.value, parentType);\n }\n }\n }\n }\n /**\n * Given an element, validate that its props follow the propTypes definition,\n * provided by the type.\n *\n * @param {ReactElement} element\n */ function validatePropTypes(element) {\n var type = element.type;\n if (type === null || type === undefined || typeof type === 'string') return;\n var propTypes;\n if (typeof type === 'function') propTypes = type.propTypes;\n else if (typeof type === 'object' && (type.$$typeof === REACT_FORWARD_REF_TYPE || // Inner props are checked in the reconciler.\n type.$$typeof === REACT_MEMO_TYPE)) propTypes = type.propTypes;\n else return;\n if (propTypes) {\n // Intentionally inside to avoid triggering lazy initializers:\n var name = getComponentName(type);\n checkPropTypes(propTypes, element.props, 'prop', name, element);\n } else if (type.PropTypes !== undefined && !propTypesMisspellWarningShown) {\n propTypesMisspellWarningShown = true; // Intentionally inside to avoid triggering lazy initializers:\n var _name = getComponentName(type);\n error('Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?', _name || 'Unknown');\n }\n if (typeof type.getDefaultProps === 'function' && !type.getDefaultProps.isReactClassApproved) error(\"getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead.\");\n }\n /**\n * Given a fragment, validate that it can only be provided with fragment props\n * @param {ReactElement} fragment\n */ function validateFragmentProps(fragment) {\n var keys = Object.keys(fragment.props);\n for(var i = 0; i < keys.length; i++){\n var key = keys[i];\n if (key !== 'children' && key !== 'key') {\n setCurrentlyValidatingElement$1(fragment);\n error(\"Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.\", key);\n setCurrentlyValidatingElement$1(null);\n break;\n }\n }\n if (fragment.ref !== null) {\n setCurrentlyValidatingElement$1(fragment);\n error('Invalid attribute `ref` supplied to `React.Fragment`.');\n setCurrentlyValidatingElement$1(null);\n }\n }\n function jsxWithValidation(type, props, key, isStaticChildren, source, self) {\n var validType = isValidElementType(type); // We warn in this case but don't throw. We expect the element creation to\n // succeed and there will likely be errors in render.\n if (!validType) {\n var info = '';\n if (type === undefined || typeof type === 'object' && type !== null && Object.keys(type).length === 0) info += \" You likely forgot to export your component from the file it's defined in, or you might have mixed up default and named imports.\";\n var sourceInfo = getSourceInfoErrorAddendum(source);\n if (sourceInfo) info += sourceInfo;\n else info += getDeclarationErrorAddendum();\n var typeString;\n if (type === null) typeString = 'null';\n else if (Array.isArray(type)) typeString = 'array';\n else if (type !== undefined && type.$$typeof === REACT_ELEMENT_TYPE) {\n typeString = \"<\" + (getComponentName(type.type) || 'Unknown') + \" />\";\n info = ' Did you accidentally export a JSX literal instead of a component?';\n } else typeString = typeof type;\n error(\"React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s\", typeString, info);\n }\n var element = jsxDEV(type, props, key, source, self); // The result can be nullish if a mock or a custom function is used.\n // TODO: Drop this when these are no longer allowed as the type argument.\n if (element == null) return element;\n // Skip key warning if the type isn't valid since our key validation logic\n // doesn't expect a non-string/function type and can throw confusing errors.\n // We don't want exception behavior to differ between dev and prod.\n // (Rendering will throw with a helpful message and as soon as the type is\n // fixed, the key warnings will appear.)\n if (validType) {\n var children = props.children;\n if (children !== undefined) {\n if (isStaticChildren) {\n if (Array.isArray(children)) {\n for(var i = 0; i < children.length; i++)validateChildKeys(children[i], type);\n if (Object.freeze) Object.freeze(children);\n } else error(\"React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead.\");\n } else validateChildKeys(children, type);\n }\n }\n if (type === exports.Fragment) validateFragmentProps(element);\n else validatePropTypes(element);\n return element;\n } // These two functions exist to still get child warnings in dev\n var jsxDEV$1 = jsxWithValidation;\n exports.jsxDEV = jsxDEV$1;\n})();\n\n},{\"react\":\"1PJsa\",\"object-assign\":\"7zBzH\"}],\"1PJsa\":[function(require,module,exports) {\n'use strict';\nmodule.exports = require('./cjs/react.development.js');\n\n},{\"./cjs/react.development.js\":\"hbjo1\"}],\"hbjo1\":[function(require,module,exports) {\n/** @license React v17.0.2\n * react.development.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */ 'use strict';\n(function() {\n var _assign = require('object-assign');\n // TODO: this is special because it gets imported during build.\n var ReactVersion = '17.0.2';\n // ATTENTION\n // When adding new symbols to this file,\n // Please consider also adding to 'react-devtools-shared/src/backend/ReactSymbols'\n // The Symbol used to tag the ReactElement-like types. If there is no native Symbol\n // nor polyfill, then a plain number is used for performance.\n var REACT_ELEMENT_TYPE = 60103;\n var REACT_PORTAL_TYPE = 60106;\n exports.Fragment = 60107;\n exports.StrictMode = 60108;\n exports.Profiler = 60114;\n var REACT_PROVIDER_TYPE = 60109;\n var REACT_CONTEXT_TYPE = 60110;\n var REACT_FORWARD_REF_TYPE = 60112;\n exports.Suspense = 60113;\n var REACT_SUSPENSE_LIST_TYPE = 60120;\n var REACT_MEMO_TYPE = 60115;\n var REACT_LAZY_TYPE = 60116;\n var REACT_BLOCK_TYPE = 60121;\n var REACT_SERVER_BLOCK_TYPE = 60122;\n var REACT_FUNDAMENTAL_TYPE = 60117;\n var REACT_SCOPE_TYPE = 60119;\n var REACT_OPAQUE_ID_TYPE = 60128;\n var REACT_DEBUG_TRACING_MODE_TYPE = 60129;\n var REACT_OFFSCREEN_TYPE = 60130;\n var REACT_LEGACY_HIDDEN_TYPE = 60131;\n if (typeof Symbol === 'function' && Symbol.for) {\n var symbolFor = Symbol.for;\n REACT_ELEMENT_TYPE = symbolFor('react.element');\n REACT_PORTAL_TYPE = symbolFor('react.portal');\n exports.Fragment = symbolFor('react.fragment');\n exports.StrictMode = symbolFor('react.strict_mode');\n exports.Profiler = symbolFor('react.profiler');\n REACT_PROVIDER_TYPE = symbolFor('react.provider');\n REACT_CONTEXT_TYPE = symbolFor('react.context');\n REACT_FORWARD_REF_TYPE = symbolFor('react.forward_ref');\n exports.Suspense = symbolFor('react.suspense');\n REACT_SUSPENSE_LIST_TYPE = symbolFor('react.suspense_list');\n REACT_MEMO_TYPE = symbolFor('react.memo');\n REACT_LAZY_TYPE = symbolFor('react.lazy');\n REACT_BLOCK_TYPE = symbolFor('react.block');\n REACT_SERVER_BLOCK_TYPE = symbolFor('react.server.block');\n REACT_FUNDAMENTAL_TYPE = symbolFor('react.fundamental');\n REACT_SCOPE_TYPE = symbolFor('react.scope');\n REACT_OPAQUE_ID_TYPE = symbolFor('react.opaque.id');\n REACT_DEBUG_TRACING_MODE_TYPE = symbolFor('react.debug_trace_mode');\n REACT_OFFSCREEN_TYPE = symbolFor('react.offscreen');\n REACT_LEGACY_HIDDEN_TYPE = symbolFor('react.legacy_hidden');\n }\n var MAYBE_ITERATOR_SYMBOL = typeof Symbol === 'function' && Symbol.iterator;\n var FAUX_ITERATOR_SYMBOL = '@@iterator';\n function getIteratorFn(maybeIterable) {\n if (maybeIterable === null || typeof maybeIterable !== 'object') return null;\n var maybeIterator = MAYBE_ITERATOR_SYMBOL && maybeIterable[MAYBE_ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL];\n if (typeof maybeIterator === 'function') return maybeIterator;\n return null;\n }\n /**\n * Keeps track of the current dispatcher.\n */ var ReactCurrentDispatcher = {\n /**\n * @internal\n * @type {ReactComponent}\n */ current: null\n };\n /**\n * Keeps track of the current batch's configuration such as how long an update\n * should suspend for if it needs to.\n */ var ReactCurrentBatchConfig = {\n transition: 0\n };\n /**\n * Keeps track of the current owner.\n *\n * The current owner is the component who should own any components that are\n * currently being constructed.\n */ var ReactCurrentOwner = {\n /**\n * @internal\n * @type {ReactComponent}\n */ current: null\n };\n var ReactDebugCurrentFrame1 = {\n };\n var currentExtraStackFrame = null;\n function setExtraStackFrame(stack) {\n currentExtraStackFrame = stack;\n }\n ReactDebugCurrentFrame1.setExtraStackFrame = function(stack) {\n currentExtraStackFrame = stack;\n }; // Stack implementation injected by the current renderer.\n ReactDebugCurrentFrame1.getCurrentStack = null;\n ReactDebugCurrentFrame1.getStackAddendum = function() {\n var stack = ''; // Add an extra top frame while an element is being validated\n if (currentExtraStackFrame) stack += currentExtraStackFrame;\n // Delegate to the injected renderer-specific implementation\n var impl = ReactDebugCurrentFrame1.getCurrentStack;\n if (impl) stack += impl() || '';\n return stack;\n };\n /**\n * Used by act() to track whether you're inside an act() scope.\n */ var IsSomeRendererActing = {\n current: false\n };\n var ReactSharedInternals = {\n ReactCurrentDispatcher: ReactCurrentDispatcher,\n ReactCurrentBatchConfig: ReactCurrentBatchConfig,\n ReactCurrentOwner: ReactCurrentOwner,\n IsSomeRendererActing: IsSomeRendererActing,\n // Used by renderers to avoid bundling object-assign twice in UMD bundles:\n assign: _assign\n };\n ReactSharedInternals.ReactDebugCurrentFrame = ReactDebugCurrentFrame1;\n // by calls to these methods by a Babel plugin.\n //\n // In PROD (or in packages without access to React internals),\n // they are left as they are instead.\n function warn(format) {\n for(var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++)args[_key - 1] = arguments[_key];\n printWarning('warn', format, args);\n }\n function error1(format) {\n for(var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++)args[_key2 - 1] = arguments[_key2];\n printWarning('error', format, args);\n }\n function printWarning(level, format, args) {\n var ReactDebugCurrentFrame = ReactSharedInternals.ReactDebugCurrentFrame;\n var stack = ReactDebugCurrentFrame.getStackAddendum();\n if (stack !== '') {\n format += '%s';\n args = args.concat([\n stack\n ]);\n }\n var argsWithFormat = args.map(function(item) {\n return '' + item;\n }); // Careful: RN currently depends on this prefix\n argsWithFormat.unshift('Warning: ' + format); // We intentionally don't use spread (or .apply) directly because it\n // breaks IE9: https://github.com/facebook/react/issues/13610\n // eslint-disable-next-line react-internal/no-production-logging\n Function.prototype.apply.call(console[level], console, argsWithFormat);\n }\n var didWarnStateUpdateForUnmountedComponent = {\n };\n function warnNoop(publicInstance, callerName) {\n var _constructor = publicInstance.constructor;\n var componentName = _constructor && (_constructor.displayName || _constructor.name) || 'ReactClass';\n var warningKey = componentName + \".\" + callerName;\n if (didWarnStateUpdateForUnmountedComponent[warningKey]) return;\n error1(\"Can't call %s on a component that is not yet mounted. This is a no-op, but it might indicate a bug in your application. Instead, assign to `this.state` directly or define a `state = {};` class property with the desired state in the %s component.\", callerName, componentName);\n didWarnStateUpdateForUnmountedComponent[warningKey] = true;\n }\n /**\n * This is the abstract API for an update queue.\n */ var ReactNoopUpdateQueue = {\n /**\n * Checks whether or not this composite component is mounted.\n * @param {ReactClass} publicInstance The instance we want to test.\n * @return {boolean} True if mounted, false otherwise.\n * @protected\n * @final\n */ isMounted: function(publicInstance) {\n return false;\n },\n /**\n * Forces an update. This should only be invoked when it is known with\n * certainty that we are **not** in a DOM transaction.\n *\n * You may want to call this when you know that some deeper aspect of the\n * component's state has changed but `setState` was not called.\n *\n * This will not invoke `shouldComponentUpdate`, but it will invoke\n * `componentWillUpdate` and `componentDidUpdate`.\n *\n * @param {ReactClass} publicInstance The instance that should rerender.\n * @param {?function} callback Called after component is updated.\n * @param {?string} callerName name of the calling function in the public API.\n * @internal\n */ enqueueForceUpdate: function(publicInstance, callback, callerName) {\n warnNoop(publicInstance, 'forceUpdate');\n },\n /**\n * Replaces all of the state. Always use this or `setState` to mutate state.\n * You should treat `this.state` as immutable.\n *\n * There is no guarantee that `this.state` will be immediately updated, so\n * accessing `this.state` after calling this method may return the old value.\n *\n * @param {ReactClass} publicInstance The instance that should rerender.\n * @param {object} completeState Next state.\n * @param {?function} callback Called after component is updated.\n * @param {?string} callerName name of the calling function in the public API.\n * @internal\n */ enqueueReplaceState: function(publicInstance, completeState, callback, callerName) {\n warnNoop(publicInstance, 'replaceState');\n },\n /**\n * Sets a subset of the state. This only exists because _pendingState is\n * internal. This provides a merging strategy that is not available to deep\n * properties which is confusing. TODO: Expose pendingState or don't use it\n * during the merge.\n *\n * @param {ReactClass} publicInstance The instance that should rerender.\n * @param {object} partialState Next partial state to be merged with state.\n * @param {?function} callback Called after component is updated.\n * @param {?string} Name of the calling function in the public API.\n * @internal\n */ enqueueSetState: function(publicInstance, partialState, callback, callerName) {\n warnNoop(publicInstance, 'setState');\n }\n };\n var emptyObject = {\n };\n Object.freeze(emptyObject);\n /**\n * Base class helpers for the updating state of a component.\n */ function Component1(props, context, updater) {\n this.props = props;\n this.context = context; // If a component has string refs, we will assign a different object later.\n this.refs = emptyObject; // We initialize the default updater but the real one gets injected by the\n // renderer.\n this.updater = updater || ReactNoopUpdateQueue;\n }\n Component1.prototype.isReactComponent = {\n };\n /**\n * Sets a subset of the state. Always use this to mutate\n * state. You should treat `this.state` as immutable.\n *\n * There is no guarantee that `this.state` will be immediately updated, so\n * accessing `this.state` after calling this method may return the old value.\n *\n * There is no guarantee that calls to `setState` will run synchronously,\n * as they may eventually be batched together. You can provide an optional\n * callback that will be executed when the call to setState is actually\n * completed.\n *\n * When a function is provided to setState, it will be called at some point in\n * the future (not synchronously). It will be called with the up to date\n * component arguments (state, props, context). These values can be different\n * from this.* because your function may be called after receiveProps but before\n * shouldComponentUpdate, and this new state, props, and context will not yet be\n * assigned to this.\n *\n * @param {object|function} partialState Next partial state or function to\n * produce next partial state to be merged with current state.\n * @param {?function} callback Called after state is updated.\n * @final\n * @protected\n */ Component1.prototype.setState = function(partialState, callback) {\n if (!(typeof partialState === 'object' || typeof partialState === 'function' || partialState == null)) throw Error(\"setState(...): takes an object of state variables to update or a function which returns an object of state variables.\");\n this.updater.enqueueSetState(this, partialState, callback, 'setState');\n };\n /**\n * Forces an update. This should only be invoked when it is known with\n * certainty that we are **not** in a DOM transaction.\n *\n * You may want to call this when you know that some deeper aspect of the\n * component's state has changed but `setState` was not called.\n *\n * This will not invoke `shouldComponentUpdate`, but it will invoke\n * `componentWillUpdate` and `componentDidUpdate`.\n *\n * @param {?function} callback Called after update is complete.\n * @final\n * @protected\n */ Component1.prototype.forceUpdate = function(callback) {\n this.updater.enqueueForceUpdate(this, callback, 'forceUpdate');\n };\n var deprecatedAPIs = {\n isMounted: [\n 'isMounted',\n \"Instead, make sure to clean up subscriptions and pending requests in componentWillUnmount to prevent memory leaks.\"\n ],\n replaceState: [\n 'replaceState',\n \"Refactor your code to use setState instead (see https://github.com/facebook/react/issues/3236).\"\n ]\n };\n var defineDeprecationWarning = function(methodName, info) {\n Object.defineProperty(Component1.prototype, methodName, {\n get: function() {\n warn('%s(...) is deprecated in plain JavaScript React classes. %s', info[0], info[1]);\n return undefined;\n }\n });\n };\n for(var fnName in deprecatedAPIs)if (deprecatedAPIs.hasOwnProperty(fnName)) defineDeprecationWarning(fnName, deprecatedAPIs[fnName]);\n function ComponentDummy() {\n }\n ComponentDummy.prototype = Component1.prototype;\n /**\n * Convenience component with default shallow equality check for sCU.\n */ function PureComponent(props, context, updater) {\n this.props = props;\n this.context = context; // If a component has string refs, we will assign a different object later.\n this.refs = emptyObject;\n this.updater = updater || ReactNoopUpdateQueue;\n }\n var pureComponentPrototype = PureComponent.prototype = new ComponentDummy();\n pureComponentPrototype.constructor = PureComponent; // Avoid an extra prototype jump for these methods.\n _assign(pureComponentPrototype, Component1.prototype);\n pureComponentPrototype.isPureReactComponent = true;\n // an immutable object with a single mutable value\n function createRef() {\n var refObject = {\n current: null\n };\n Object.seal(refObject);\n return refObject;\n }\n function getWrappedName(outerType, innerType, wrapperName) {\n var functionName = innerType.displayName || innerType.name || '';\n return outerType.displayName || (functionName !== '' ? wrapperName + \"(\" + functionName + \")\" : wrapperName);\n }\n function getContextName(type) {\n return type.displayName || 'Context';\n }\n function getComponentName(type) {\n if (type == null) // Host root, text node or just invalid type.\n return null;\n if (typeof type.tag === 'number') error1(\"Received an unexpected object in getComponentName(). This is likely a bug in React. Please file an issue.\");\n if (typeof type === 'function') return type.displayName || type.name || null;\n if (typeof type === 'string') return type;\n switch(type){\n case exports.Fragment:\n return 'Fragment';\n case REACT_PORTAL_TYPE:\n return 'Portal';\n case exports.Profiler:\n return 'Profiler';\n case exports.StrictMode:\n return 'StrictMode';\n case exports.Suspense:\n return 'Suspense';\n case REACT_SUSPENSE_LIST_TYPE:\n return 'SuspenseList';\n }\n if (typeof type === 'object') switch(type.$$typeof){\n case REACT_CONTEXT_TYPE:\n var context = type;\n return getContextName(context) + '.Consumer';\n case REACT_PROVIDER_TYPE:\n var provider = type;\n return getContextName(provider._context) + '.Provider';\n case REACT_FORWARD_REF_TYPE:\n return getWrappedName(type, type.render, 'ForwardRef');\n case REACT_MEMO_TYPE:\n return getComponentName(type.type);\n case REACT_BLOCK_TYPE:\n return getComponentName(type._render);\n case REACT_LAZY_TYPE:\n var lazyComponent = type;\n var payload = lazyComponent._payload;\n var init = lazyComponent._init;\n try {\n return getComponentName(init(payload));\n } catch (x) {\n return null;\n }\n }\n return null;\n }\n var hasOwnProperty = Object.prototype.hasOwnProperty;\n var RESERVED_PROPS = {\n key: true,\n ref: true,\n __self: true,\n __source: true\n };\n var specialPropKeyWarningShown, specialPropRefWarningShown, didWarnAboutStringRefs;\n didWarnAboutStringRefs = {\n };\n function hasValidRef(config) {\n if (hasOwnProperty.call(config, 'ref')) {\n var getter = Object.getOwnPropertyDescriptor(config, 'ref').get;\n if (getter && getter.isReactWarning) return false;\n }\n return config.ref !== undefined;\n }\n function hasValidKey(config) {\n if (hasOwnProperty.call(config, 'key')) {\n var getter = Object.getOwnPropertyDescriptor(config, 'key').get;\n if (getter && getter.isReactWarning) return false;\n }\n return config.key !== undefined;\n }\n function defineKeyPropWarningGetter(props, displayName) {\n var warnAboutAccessingKey = function() {\n if (!specialPropKeyWarningShown) {\n specialPropKeyWarningShown = true;\n error1(\"%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)\", displayName);\n }\n };\n warnAboutAccessingKey.isReactWarning = true;\n Object.defineProperty(props, 'key', {\n get: warnAboutAccessingKey,\n configurable: true\n });\n }\n function defineRefPropWarningGetter(props, displayName) {\n var warnAboutAccessingRef = function() {\n if (!specialPropRefWarningShown) {\n specialPropRefWarningShown = true;\n error1(\"%s: `ref` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)\", displayName);\n }\n };\n warnAboutAccessingRef.isReactWarning = true;\n Object.defineProperty(props, 'ref', {\n get: warnAboutAccessingRef,\n configurable: true\n });\n }\n function warnIfStringRefCannotBeAutoConverted(config) {\n if (typeof config.ref === 'string' && ReactCurrentOwner.current && config.__self && ReactCurrentOwner.current.stateNode !== config.__self) {\n var componentName = getComponentName(ReactCurrentOwner.current.type);\n if (!didWarnAboutStringRefs[componentName]) {\n error1(\"Component \\\"%s\\\" contains the string ref \\\"%s\\\". Support for string refs will be removed in a future major release. This case cannot be automatically converted to an arrow function. We ask you to manually fix this case by using useRef() or createRef() instead. Learn more about using refs safely here: https://reactjs.org/link/strict-mode-string-ref\", componentName, config.ref);\n didWarnAboutStringRefs[componentName] = true;\n }\n }\n }\n /**\n * Factory method to create a new React element. This no longer adheres to\n * the class pattern, so do not use new to call it. Also, instanceof check\n * will not work. Instead test $$typeof field against Symbol.for('react.element') to check\n * if something is a React Element.\n *\n * @param {*} type\n * @param {*} props\n * @param {*} key\n * @param {string|object} ref\n * @param {*} owner\n * @param {*} self A *temporary* helper to detect places where `this` is\n * different from the `owner` when React.createElement is called, so that we\n * can warn. We want to get rid of owner and replace string `ref`s with arrow\n * functions, and as long as `this` and owner are the same, there will be no\n * change in behavior.\n * @param {*} source An annotation object (added by a transpiler or otherwise)\n * indicating filename, line number, and/or other information.\n * @internal\n */ var ReactElement = function(type, key, ref, self, source, owner, props) {\n var element = {\n // This tag allows us to uniquely identify this as a React Element\n $$typeof: REACT_ELEMENT_TYPE,\n // Built-in properties that belong on the element\n type: type,\n key: key,\n ref: ref,\n props: props,\n // Record the component responsible for creating this element.\n _owner: owner\n };\n // The validation flag is currently mutative. We put it on\n // an external backing store so that we can freeze the whole object.\n // This can be replaced with a WeakMap once they are implemented in\n // commonly used development environments.\n element._store = {\n }; // To make comparing ReactElements easier for testing purposes, we make\n // the validation flag non-enumerable (where possible, which should\n // include every environment we run tests in), so the test framework\n // ignores it.\n Object.defineProperty(element._store, 'validated', {\n configurable: false,\n enumerable: false,\n writable: true,\n value: false\n }); // self and source are DEV only properties.\n Object.defineProperty(element, '_self', {\n configurable: false,\n enumerable: false,\n writable: false,\n value: self\n }); // Two elements created in two different places should be considered\n // equal for testing purposes and therefore we hide it from enumeration.\n Object.defineProperty(element, '_source', {\n configurable: false,\n enumerable: false,\n writable: false,\n value: source\n });\n if (Object.freeze) {\n Object.freeze(element.props);\n Object.freeze(element);\n }\n return element;\n };\n /**\n * Create and return a new ReactElement of the given type.\n * See https://reactjs.org/docs/react-api.html#createelement\n */ function createElement(type, config, children) {\n var propName; // Reserved names are extracted\n var props = {\n };\n var key = null;\n var ref = null;\n var self = null;\n var source = null;\n if (config != null) {\n if (hasValidRef(config)) {\n ref = config.ref;\n warnIfStringRefCannotBeAutoConverted(config);\n }\n if (hasValidKey(config)) key = '' + config.key;\n self = config.__self === undefined ? null : config.__self;\n source = config.__source === undefined ? null : config.__source; // Remaining properties are added to a new props object\n for(propName in config)if (hasOwnProperty.call(config, propName) && !RESERVED_PROPS.hasOwnProperty(propName)) props[propName] = config[propName];\n } // Children can be more than one argument, and those are transferred onto\n // the newly allocated props object.\n var childrenLength = arguments.length - 2;\n if (childrenLength === 1) props.children = children;\n else if (childrenLength > 1) {\n var childArray = Array(childrenLength);\n for(var i = 0; i < childrenLength; i++)childArray[i] = arguments[i + 2];\n if (Object.freeze) Object.freeze(childArray);\n props.children = childArray;\n } // Resolve default props\n if (type && type.defaultProps) {\n var defaultProps = type.defaultProps;\n for(propName in defaultProps)if (props[propName] === undefined) props[propName] = defaultProps[propName];\n }\n if (key || ref) {\n var displayName = typeof type === 'function' ? type.displayName || type.name || 'Unknown' : type;\n if (key) defineKeyPropWarningGetter(props, displayName);\n if (ref) defineRefPropWarningGetter(props, displayName);\n }\n return ReactElement(type, key, ref, self, source, ReactCurrentOwner.current, props);\n }\n function cloneAndReplaceKey(oldElement, newKey) {\n var newElement = ReactElement(oldElement.type, newKey, oldElement.ref, oldElement._self, oldElement._source, oldElement._owner, oldElement.props);\n return newElement;\n }\n /**\n * Clone and return a new ReactElement using element as the starting point.\n * See https://reactjs.org/docs/react-api.html#cloneelement\n */ function cloneElement(element, config, children) {\n if (!!(element === null || element === undefined)) throw Error(\"React.cloneElement(...): The argument must be a React element, but you passed \" + element + \".\");\n var propName; // Original props are copied\n var props = _assign({\n }, element.props); // Reserved names are extracted\n var key = element.key;\n var ref = element.ref; // Self is preserved since the owner is preserved.\n var self = element._self; // Source is preserved since cloneElement is unlikely to be targeted by a\n // transpiler, and the original source is probably a better indicator of the\n // true owner.\n var source = element._source; // Owner will be preserved, unless ref is overridden\n var owner = element._owner;\n if (config != null) {\n if (hasValidRef(config)) {\n // Silently steal the ref from the parent.\n ref = config.ref;\n owner = ReactCurrentOwner.current;\n }\n if (hasValidKey(config)) key = '' + config.key;\n // Remaining properties override existing props\n var defaultProps;\n if (element.type && element.type.defaultProps) defaultProps = element.type.defaultProps;\n for(propName in config)if (hasOwnProperty.call(config, propName) && !RESERVED_PROPS.hasOwnProperty(propName)) {\n if (config[propName] === undefined && defaultProps !== undefined) // Resolve default props\n props[propName] = defaultProps[propName];\n else props[propName] = config[propName];\n }\n } // Children can be more than one argument, and those are transferred onto\n // the newly allocated props object.\n var childrenLength = arguments.length - 2;\n if (childrenLength === 1) props.children = children;\n else if (childrenLength > 1) {\n var childArray = Array(childrenLength);\n for(var i = 0; i < childrenLength; i++)childArray[i] = arguments[i + 2];\n props.children = childArray;\n }\n return ReactElement(element.type, key, ref, self, source, owner, props);\n }\n /**\n * Verifies the object is a ReactElement.\n * See https://reactjs.org/docs/react-api.html#isvalidelement\n * @param {?object} object\n * @return {boolean} True if `object` is a ReactElement.\n * @final\n */ function isValidElement(object) {\n return typeof object === 'object' && object !== null && object.$$typeof === REACT_ELEMENT_TYPE;\n }\n var SEPARATOR = '.';\n var SUBSEPARATOR = ':';\n /**\n * Escape and wrap key so it is safe to use as a reactid\n *\n * @param {string} key to be escaped.\n * @return {string} the escaped key.\n */ function escape(key) {\n var escapeRegex = /[=:]/g;\n var escaperLookup = {\n '=': '=0',\n ':': '=2'\n };\n var escapedString = key.replace(escapeRegex, function(match) {\n return escaperLookup[match];\n });\n return '$' + escapedString;\n }\n /**\n * TODO: Test that a single child and an array with one item have the same key\n * pattern.\n */ var didWarnAboutMaps = false;\n var userProvidedKeyEscapeRegex = /\\/+/g;\n function escapeUserProvidedKey(text) {\n return text.replace(userProvidedKeyEscapeRegex, '$&/');\n }\n /**\n * Generate a key string that identifies a element within a set.\n *\n * @param {*} element A element that could contain a manual key.\n * @param {number} index Index that is used if a manual key is not provided.\n * @return {string}\n */ function getElementKey(element, index) {\n // Do some typechecking here since we call this blindly. We want to ensure\n // that we don't block potential future ES APIs.\n if (typeof element === 'object' && element !== null && element.key != null) // Explicit key\n return escape('' + element.key);\n // Implicit key determined by the index in the set\n return index.toString(36);\n }\n function mapIntoArray(children, array, escapedPrefix, nameSoFar, callback) {\n var type = typeof children;\n if (type === 'undefined' || type === 'boolean') // All of the above are perceived as null.\n children = null;\n var invokeCallback = false;\n if (children === null) invokeCallback = true;\n else switch(type){\n case 'string':\n case 'number':\n invokeCallback = true;\n break;\n case 'object':\n switch(children.$$typeof){\n case REACT_ELEMENT_TYPE:\n case REACT_PORTAL_TYPE:\n invokeCallback = true;\n }\n }\n if (invokeCallback) {\n var _child = children;\n var mappedChild = callback(_child); // If it's the only child, treat the name as if it was wrapped in an array\n // so that it's consistent if the number of children grows:\n var childKey = nameSoFar === '' ? SEPARATOR + getElementKey(_child, 0) : nameSoFar;\n if (Array.isArray(mappedChild)) {\n var escapedChildKey = '';\n if (childKey != null) escapedChildKey = escapeUserProvidedKey(childKey) + '/';\n mapIntoArray(mappedChild, array, escapedChildKey, '', function(c) {\n return c;\n });\n } else if (mappedChild != null) {\n if (isValidElement(mappedChild)) mappedChild = cloneAndReplaceKey(mappedChild, // traverseAllChildren used to do for objects as children\n escapedPrefix + (mappedChild.key && (!_child || _child.key !== mappedChild.key) ? escapeUserProvidedKey('' + mappedChild.key) + '/' : '') + childKey);\n array.push(mappedChild);\n }\n return 1;\n }\n var child;\n var nextName;\n var subtreeCount = 0; // Count of children found in the current subtree.\n var nextNamePrefix = nameSoFar === '' ? SEPARATOR : nameSoFar + SUBSEPARATOR;\n if (Array.isArray(children)) for(var i = 0; i < children.length; i++){\n child = children[i];\n nextName = nextNamePrefix + getElementKey(child, i);\n subtreeCount += mapIntoArray(child, array, escapedPrefix, nextName, callback);\n }\n else {\n var iteratorFn = getIteratorFn(children);\n if (typeof iteratorFn === 'function') {\n var iterableChildren = children;\n // Warn about using Maps as children\n if (iteratorFn === iterableChildren.entries) {\n if (!didWarnAboutMaps) warn(\"Using Maps as children is not supported. Use an array of keyed ReactElements instead.\");\n didWarnAboutMaps = true;\n }\n var iterator = iteratorFn.call(iterableChildren);\n var step;\n var ii = 0;\n while(!(step = iterator.next()).done){\n child = step.value;\n nextName = nextNamePrefix + getElementKey(child, ii++);\n subtreeCount += mapIntoArray(child, array, escapedPrefix, nextName, callback);\n }\n } else if (type === 'object') {\n var childrenString = '' + children;\n throw Error(\"Objects are not valid as a React child (found: \" + (childrenString === '[object Object]' ? 'object with keys {' + Object.keys(children).join(', ') + '}' : childrenString) + \"). If you meant to render a collection of children, use an array instead.\");\n }\n }\n return subtreeCount;\n }\n /**\n * Maps children that are typically specified as `props.children`.\n *\n * See https://reactjs.org/docs/react-api.html#reactchildrenmap\n *\n * The provided mapFunction(child, index) will be called for each\n * leaf child.\n *\n * @param {?*} children Children tree container.\n * @param {function(*, int)} func The map function.\n * @param {*} context Context for mapFunction.\n * @return {object} Object containing the ordered map of results.\n */ function mapChildren(children, func, context) {\n if (children == null) return children;\n var result = [];\n var count = 0;\n mapIntoArray(children, result, '', '', function(child) {\n return func.call(context, child, count++);\n });\n return result;\n }\n /**\n * Count the number of children that are typically specified as\n * `props.children`.\n *\n * See https://reactjs.org/docs/react-api.html#reactchildrencount\n *\n * @param {?*} children Children tree container.\n * @return {number} The number of children.\n */ function countChildren(children) {\n var n = 0;\n mapChildren(children, function() {\n n++; // Don't return anything\n });\n return n;\n }\n /**\n * Iterates through children that are typically specified as `props.children`.\n *\n * See https://reactjs.org/docs/react-api.html#reactchildrenforeach\n *\n * The provided forEachFunc(child, index) will be called for each\n * leaf child.\n *\n * @param {?*} children Children tree container.\n * @param {function(*, int)} forEachFunc\n * @param {*} forEachContext Context for forEachContext.\n */ function forEachChildren(children, forEachFunc, forEachContext) {\n mapChildren(children, function() {\n forEachFunc.apply(this, arguments); // Don't return anything.\n }, forEachContext);\n }\n /**\n * Flatten a children object (typically specified as `props.children`) and\n * return an array with appropriately re-keyed children.\n *\n * See https://reactjs.org/docs/react-api.html#reactchildrentoarray\n */ function toArray(children) {\n return mapChildren(children, function(child) {\n return child;\n }) || [];\n }\n /**\n * Returns the first child in a collection of children and verifies that there\n * is only one child in the collection.\n *\n * See https://reactjs.org/docs/react-api.html#reactchildrenonly\n *\n * The current implementation of this function assumes that a single child gets\n * passed without a wrapper, but the purpose of this helper function is to\n * abstract away the particular structure of children.\n *\n * @param {?object} children Child collection structure.\n * @return {ReactElement} The first and only `ReactElement` contained in the\n * structure.\n */ function onlyChild(children) {\n if (!isValidElement(children)) throw Error(\"React.Children.only expected to receive a single React element child.\");\n return children;\n }\n function createContext(defaultValue, calculateChangedBits) {\n if (calculateChangedBits === undefined) calculateChangedBits = null;\n else if (calculateChangedBits !== null && typeof calculateChangedBits !== 'function') error1(\"createContext: Expected the optional second argument to be a function. Instead received: %s\", calculateChangedBits);\n var context = {\n $$typeof: REACT_CONTEXT_TYPE,\n _calculateChangedBits: calculateChangedBits,\n // As a workaround to support multiple concurrent renderers, we categorize\n // some renderers as primary and others as secondary. We only expect\n // there to be two concurrent renderers at most: React Native (primary) and\n // Fabric (secondary); React DOM (primary) and React ART (secondary).\n // Secondary renderers store their context values on separate fields.\n _currentValue: defaultValue,\n _currentValue2: defaultValue,\n // Used to track how many concurrent renderers this context currently\n // supports within in a single renderer. Such as parallel server rendering.\n _threadCount: 0,\n // These are circular\n Provider: null,\n Consumer: null\n };\n context.Provider = {\n $$typeof: REACT_PROVIDER_TYPE,\n _context: context\n };\n var hasWarnedAboutUsingNestedContextConsumers = false;\n var hasWarnedAboutUsingConsumerProvider = false;\n var hasWarnedAboutDisplayNameOnConsumer = false;\n // A separate object, but proxies back to the original context object for\n // backwards compatibility. It has a different $$typeof, so we can properly\n // warn for the incorrect usage of Context as a Consumer.\n var Consumer = {\n $$typeof: REACT_CONTEXT_TYPE,\n _context: context,\n _calculateChangedBits: context._calculateChangedBits\n }; // $FlowFixMe: Flow complains about not setting a value, which is intentional here\n Object.defineProperties(Consumer, {\n Provider: {\n get: function() {\n if (!hasWarnedAboutUsingConsumerProvider) {\n hasWarnedAboutUsingConsumerProvider = true;\n error1(\"Rendering <Context.Consumer.Provider> is not supported and will be removed in a future major release. Did you mean to render <Context.Provider> instead?\");\n }\n return context.Provider;\n },\n set: function(_Provider) {\n context.Provider = _Provider;\n }\n },\n _currentValue: {\n get: function() {\n return context._currentValue;\n },\n set: function(_currentValue) {\n context._currentValue = _currentValue;\n }\n },\n _currentValue2: {\n get: function() {\n return context._currentValue2;\n },\n set: function(_currentValue2) {\n context._currentValue2 = _currentValue2;\n }\n },\n _threadCount: {\n get: function() {\n return context._threadCount;\n },\n set: function(_threadCount) {\n context._threadCount = _threadCount;\n }\n },\n Consumer: {\n get: function() {\n if (!hasWarnedAboutUsingNestedContextConsumers) {\n hasWarnedAboutUsingNestedContextConsumers = true;\n error1(\"Rendering <Context.Consumer.Consumer> is not supported and will be removed in a future major release. Did you mean to render <Context.Consumer> instead?\");\n }\n return context.Consumer;\n }\n },\n displayName: {\n get: function() {\n return context.displayName;\n },\n set: function(displayName) {\n if (!hasWarnedAboutDisplayNameOnConsumer) {\n warn(\"Setting `displayName` on Context.Consumer has no effect. You should set it directly on the context with Context.displayName = '%s'.\", displayName);\n hasWarnedAboutDisplayNameOnConsumer = true;\n }\n }\n }\n }); // $FlowFixMe: Flow complains about missing properties because it doesn't understand defineProperty\n context.Consumer = Consumer;\n context._currentRenderer = null;\n context._currentRenderer2 = null;\n return context;\n }\n var Uninitialized = -1;\n var Pending = 0;\n var Resolved = 1;\n var Rejected = 2;\n function lazyInitializer(payload) {\n if (payload._status === Uninitialized) {\n var ctor = payload._result;\n var thenable = ctor(); // Transition to the next state.\n var pending = payload;\n pending._status = Pending;\n pending._result = thenable;\n thenable.then(function(moduleObject) {\n if (payload._status === Pending) {\n var defaultExport = moduleObject.default;\n if (defaultExport === undefined) error1(\"lazy: Expected the result of a dynamic import() call. Instead received: %s\\n\\nYour code should look like: \\n const MyComponent = lazy(() => import('./MyComponent'))\", moduleObject);\n var resolved = payload;\n resolved._status = Resolved;\n resolved._result = defaultExport;\n }\n }, function(error) {\n if (payload._status === Pending) {\n // Transition to the next state.\n var rejected = payload;\n rejected._status = Rejected;\n rejected._result = error;\n }\n });\n }\n if (payload._status === Resolved) return payload._result;\n else throw payload._result;\n }\n function lazy(ctor) {\n var payload = {\n // We use these fields to store the result.\n _status: -1,\n _result: ctor\n };\n var lazyType = {\n $$typeof: REACT_LAZY_TYPE,\n _payload: payload,\n _init: lazyInitializer\n };\n // In production, this would just set it on the object.\n var defaultProps;\n var propTypes; // $FlowFixMe\n Object.defineProperties(lazyType, {\n defaultProps: {\n configurable: true,\n get: function() {\n return defaultProps;\n },\n set: function(newDefaultProps) {\n error1(\"React.lazy(...): It is not supported to assign `defaultProps` to a lazy component import. Either specify them where the component is defined, or create a wrapping component around it.\");\n defaultProps = newDefaultProps; // Match production behavior more closely:\n // $FlowFixMe\n Object.defineProperty(lazyType, 'defaultProps', {\n enumerable: true\n });\n }\n },\n propTypes: {\n configurable: true,\n get: function() {\n return propTypes;\n },\n set: function(newPropTypes) {\n error1(\"React.lazy(...): It is not supported to assign `propTypes` to a lazy component import. Either specify them where the component is defined, or create a wrapping component around it.\");\n propTypes = newPropTypes; // Match production behavior more closely:\n // $FlowFixMe\n Object.defineProperty(lazyType, 'propTypes', {\n enumerable: true\n });\n }\n }\n });\n return lazyType;\n }\n function forwardRef(render) {\n if (render != null && render.$$typeof === REACT_MEMO_TYPE) error1(\"forwardRef requires a render function but received a `memo` component. Instead of forwardRef(memo(...)), use memo(forwardRef(...)).\");\n else if (typeof render !== 'function') error1('forwardRef requires a render function but was given %s.', render === null ? 'null' : typeof render);\n else if (render.length !== 0 && render.length !== 2) error1('forwardRef render functions accept exactly two parameters: props and ref. %s', render.length === 1 ? 'Did you forget to use the ref parameter?' : 'Any additional parameter will be undefined.');\n if (render != null) {\n if (render.defaultProps != null || render.propTypes != null) error1(\"forwardRef render functions do not support propTypes or defaultProps. Did you accidentally pass a React component?\");\n }\n var elementType = {\n $$typeof: REACT_FORWARD_REF_TYPE,\n render: render\n };\n var ownName;\n Object.defineProperty(elementType, 'displayName', {\n enumerable: false,\n configurable: true,\n get: function() {\n return ownName;\n },\n set: function(name) {\n ownName = name;\n if (render.displayName == null) render.displayName = name;\n }\n });\n return elementType;\n }\n // Filter certain DOM attributes (e.g. src, href) if their values are empty strings.\n var enableScopeAPI = false; // Experimental Create Event Handle API.\n function isValidElementType(type) {\n if (typeof type === 'string' || typeof type === 'function') return true;\n // Note: typeof might be other than 'symbol' or 'number' (e.g. if it's a polyfill).\n if (type === exports.Fragment || type === exports.Profiler || type === REACT_DEBUG_TRACING_MODE_TYPE || type === exports.StrictMode || type === exports.Suspense || type === REACT_SUSPENSE_LIST_TYPE || type === REACT_LEGACY_HIDDEN_TYPE || enableScopeAPI) return true;\n if (typeof type === 'object' && type !== null) {\n if (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_PROVIDER_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE || type.$$typeof === REACT_FUNDAMENTAL_TYPE || type.$$typeof === REACT_BLOCK_TYPE || type[0] === REACT_SERVER_BLOCK_TYPE) return true;\n }\n return false;\n }\n function memo(type, compare) {\n if (!isValidElementType(type)) error1(\"memo: The first argument must be a component. Instead received: %s\", type === null ? 'null' : typeof type);\n var elementType = {\n $$typeof: REACT_MEMO_TYPE,\n type: type,\n compare: compare === undefined ? null : compare\n };\n var ownName;\n Object.defineProperty(elementType, 'displayName', {\n enumerable: false,\n configurable: true,\n get: function() {\n return ownName;\n },\n set: function(name) {\n ownName = name;\n if (type.displayName == null) type.displayName = name;\n }\n });\n return elementType;\n }\n function resolveDispatcher() {\n var dispatcher = ReactCurrentDispatcher.current;\n if (!(dispatcher !== null)) throw Error(\"Invalid hook call. Hooks can only be called inside of the body of a function component. This could happen for one of the following reasons:\\n1. You might have mismatching versions of React and the renderer (such as React DOM)\\n2. You might be breaking the Rules of Hooks\\n3. You might have more than one copy of React in the same app\\nSee https://reactjs.org/link/invalid-hook-call for tips about how to debug and fix this problem.\");\n return dispatcher;\n }\n function useContext(Context, unstable_observedBits) {\n var dispatcher = resolveDispatcher();\n if (unstable_observedBits !== undefined) error1(\"useContext() second argument is reserved for future use in React. Passing it is not supported. You passed: %s.%s\", unstable_observedBits, typeof unstable_observedBits === 'number' && Array.isArray(arguments[2]) ? \"\\n\\nDid you call array.map(useContext)? Calling Hooks inside a loop is not supported. Learn more at https://reactjs.org/link/rules-of-hooks\" : '');\n // TODO: add a more generic warning for invalid values.\n if (Context._context !== undefined) {\n var realContext = Context._context; // Don't deduplicate because this legitimately causes bugs\n // and nobody should be using this in existing code.\n if (realContext.Consumer === Context) error1(\"Calling useContext(Context.Consumer) is not supported, may cause bugs, and will be removed in a future major release. Did you mean to call useContext(Context) instead?\");\n else if (realContext.Provider === Context) error1(\"Calling useContext(Context.Provider) is not supported. Did you mean to call useContext(Context) instead?\");\n }\n return dispatcher.useContext(Context, unstable_observedBits);\n }\n function useState(initialState) {\n var dispatcher = resolveDispatcher();\n return dispatcher.useState(initialState);\n }\n function useReducer(reducer, initialArg, init) {\n var dispatcher = resolveDispatcher();\n return dispatcher.useReducer(reducer, initialArg, init);\n }\n function useRef(initialValue) {\n var dispatcher = resolveDispatcher();\n return dispatcher.useRef(initialValue);\n }\n function useEffect(create, deps) {\n var dispatcher = resolveDispatcher();\n return dispatcher.useEffect(create, deps);\n }\n function useLayoutEffect(create, deps) {\n var dispatcher = resolveDispatcher();\n return dispatcher.useLayoutEffect(create, deps);\n }\n function useCallback(callback, deps) {\n var dispatcher = resolveDispatcher();\n return dispatcher.useCallback(callback, deps);\n }\n function useMemo(create, deps) {\n var dispatcher = resolveDispatcher();\n return dispatcher.useMemo(create, deps);\n }\n function useImperativeHandle(ref, create, deps) {\n var dispatcher = resolveDispatcher();\n return dispatcher.useImperativeHandle(ref, create, deps);\n }\n function useDebugValue(value, formatterFn) {\n var dispatcher = resolveDispatcher();\n return dispatcher.useDebugValue(value, formatterFn);\n }\n // Helpers to patch console.logs to avoid logging during side-effect free\n // replaying on render function. This currently only patches the object\n // lazily which won't cover if the log function was extracted eagerly.\n // We could also eagerly patch the method.\n var disabledDepth = 0;\n var prevLog;\n var prevInfo;\n var prevWarn;\n var prevError;\n var prevGroup;\n var prevGroupCollapsed;\n var prevGroupEnd;\n function disabledLog() {\n }\n disabledLog.__reactDisabledLog = true;\n function disableLogs() {\n if (disabledDepth === 0) {\n /* eslint-disable react-internal/no-production-logging */ prevLog = console.log;\n prevInfo = console.info;\n prevWarn = console.warn;\n prevError = console.error;\n prevGroup = console.group;\n prevGroupCollapsed = console.groupCollapsed;\n prevGroupEnd = console.groupEnd; // https://github.com/facebook/react/issues/19099\n var props = {\n configurable: true,\n enumerable: true,\n value: disabledLog,\n writable: true\n }; // $FlowFixMe Flow thinks console is immutable.\n Object.defineProperties(console, {\n info: props,\n log: props,\n warn: props,\n error: props,\n group: props,\n groupCollapsed: props,\n groupEnd: props\n });\n /* eslint-enable react-internal/no-production-logging */ }\n disabledDepth++;\n }\n function reenableLogs() {\n disabledDepth--;\n if (disabledDepth === 0) {\n /* eslint-disable react-internal/no-production-logging */ var props = {\n configurable: true,\n enumerable: true,\n writable: true\n }; // $FlowFixMe Flow thinks console is immutable.\n Object.defineProperties(console, {\n log: _assign({\n }, props, {\n value: prevLog\n }),\n info: _assign({\n }, props, {\n value: prevInfo\n }),\n warn: _assign({\n }, props, {\n value: prevWarn\n }),\n error: _assign({\n }, props, {\n value: prevError\n }),\n group: _assign({\n }, props, {\n value: prevGroup\n }),\n groupCollapsed: _assign({\n }, props, {\n value: prevGroupCollapsed\n }),\n groupEnd: _assign({\n }, props, {\n value: prevGroupEnd\n })\n });\n /* eslint-enable react-internal/no-production-logging */ }\n if (disabledDepth < 0) error1(\"disabledDepth fell below zero. This is a bug in React. Please file an issue.\");\n }\n var ReactCurrentDispatcher$1 = ReactSharedInternals.ReactCurrentDispatcher;\n var prefix;\n function describeBuiltInComponentFrame(name, source, ownerFn) {\n if (prefix === undefined) // Extract the VM specific prefix used by each line.\n try {\n throw Error();\n } catch (x) {\n var match = x.stack.trim().match(/\\n( *(at )?)/);\n prefix = match && match[1] || '';\n }\n // We use the prefix to ensure our stacks line up with native stack frames.\n return '\\n' + prefix + name;\n }\n var reentry = false;\n var componentFrameCache;\n var PossiblyWeakMap = typeof WeakMap === 'function' ? WeakMap : Map;\n componentFrameCache = new PossiblyWeakMap();\n function describeNativeComponentFrame(fn, construct) {\n // If something asked for a stack inside a fake render, it should get ignored.\n if (!fn || reentry) return '';\n var frame = componentFrameCache.get(fn);\n if (frame !== undefined) return frame;\n var control;\n reentry = true;\n var previousPrepareStackTrace = Error.prepareStackTrace; // $FlowFixMe It does accept undefined.\n Error.prepareStackTrace = undefined;\n var previousDispatcher;\n previousDispatcher = ReactCurrentDispatcher$1.current; // Set the dispatcher in DEV because this might be call in the render function\n // for warnings.\n ReactCurrentDispatcher$1.current = null;\n disableLogs();\n try {\n // This should throw.\n if (construct) {\n // Something should be setting the props in the constructor.\n var Fake = function() {\n throw Error();\n }; // $FlowFixMe\n Object.defineProperty(Fake.prototype, 'props', {\n set: function() {\n // We use a throwing setter instead of frozen or non-writable props\n // because that won't throw in a non-strict mode function.\n throw Error();\n }\n });\n if (typeof Reflect === 'object' && Reflect.construct) {\n // We construct a different control for this case to include any extra\n // frames added by the construct call.\n try {\n Reflect.construct(Fake, []);\n } catch (x) {\n control = x;\n }\n Reflect.construct(fn, [], Fake);\n } else {\n try {\n Fake.call();\n } catch (x) {\n control = x;\n }\n fn.call(Fake.prototype);\n }\n } else {\n try {\n throw Error();\n } catch (x) {\n control = x;\n }\n fn();\n }\n } catch (sample) {\n // This is inlined manually because closure doesn't do it for us.\n if (sample && control && typeof sample.stack === 'string') {\n // This extracts the first frame from the sample that isn't also in the control.\n // Skipping one frame that we assume is the frame that calls the two.\n var sampleLines = sample.stack.split('\\n');\n var controlLines = control.stack.split('\\n');\n var s = sampleLines.length - 1;\n var c = controlLines.length - 1;\n while(s >= 1 && c >= 0 && sampleLines[s] !== controlLines[c])// We expect at least one stack frame to be shared.\n // Typically this will be the root most one. However, stack frames may be\n // cut off due to maximum stack limits. In this case, one maybe cut off\n // earlier than the other. We assume that the sample is longer or the same\n // and there for cut off earlier. So we should find the root most frame in\n // the sample somewhere in the control.\n c--;\n for(; s >= 1 && c >= 0; s--, c--)// Next we find the first one that isn't the same which should be the\n // frame that called our sample function and the control.\n if (sampleLines[s] !== controlLines[c]) {\n // In V8, the first line is describing the message but other VMs don't.\n // If we're about to return the first line, and the control is also on the same\n // line, that's a pretty good indicator that our sample threw at same line as\n // the control. I.e. before we entered the sample frame. So we ignore this result.\n // This can happen if you passed a class to function component, or non-function.\n if (s !== 1 || c !== 1) do {\n s--;\n c--; // We may still have similar intermediate frames from the construct call.\n // The next one that isn't the same should be our match though.\n if (c < 0 || sampleLines[s] !== controlLines[c]) {\n // V8 adds a \"new\" prefix for native classes. Let's remove it to make it prettier.\n var _frame = '\\n' + sampleLines[s].replace(' at new ', ' at ');\n if (typeof fn === 'function') componentFrameCache.set(fn, _frame);\n return _frame;\n }\n }while (s >= 1 && c >= 0)\n break;\n }\n }\n } finally{\n reentry = false;\n ReactCurrentDispatcher$1.current = previousDispatcher;\n reenableLogs();\n Error.prepareStackTrace = previousPrepareStackTrace;\n } // Fallback to just using the name if we couldn't make it throw.\n var name = fn ? fn.displayName || fn.name : '';\n var syntheticFrame = name ? describeBuiltInComponentFrame(name) : '';\n if (typeof fn === 'function') componentFrameCache.set(fn, syntheticFrame);\n return syntheticFrame;\n }\n function describeFunctionComponentFrame(fn, source, ownerFn) {\n return describeNativeComponentFrame(fn, false);\n }\n function shouldConstruct(Component) {\n var prototype = Component.prototype;\n return !!(prototype && prototype.isReactComponent);\n }\n function describeUnknownElementTypeFrameInDEV(type, source, ownerFn) {\n if (type == null) return '';\n if (typeof type === 'function') return describeNativeComponentFrame(type, shouldConstruct(type));\n if (typeof type === 'string') return describeBuiltInComponentFrame(type);\n switch(type){\n case exports.Suspense:\n return describeBuiltInComponentFrame('Suspense');\n case REACT_SUSPENSE_LIST_TYPE:\n return describeBuiltInComponentFrame('SuspenseList');\n }\n if (typeof type === 'object') switch(type.$$typeof){\n case REACT_FORWARD_REF_TYPE:\n return describeFunctionComponentFrame(type.render);\n case REACT_MEMO_TYPE:\n // Memo may contain any component type so we recursively resolve it.\n return describeUnknownElementTypeFrameInDEV(type.type, source, ownerFn);\n case REACT_BLOCK_TYPE:\n return describeFunctionComponentFrame(type._render);\n case REACT_LAZY_TYPE:\n var lazyComponent = type;\n var payload = lazyComponent._payload;\n var init = lazyComponent._init;\n try {\n // Lazy may contain any component type so we recursively resolve it.\n return describeUnknownElementTypeFrameInDEV(init(payload), source, ownerFn);\n } catch (x) {\n }\n }\n return '';\n }\n var loggedTypeFailures = {\n };\n var ReactDebugCurrentFrame$1 = ReactSharedInternals.ReactDebugCurrentFrame;\n function setCurrentlyValidatingElement(element) {\n if (element) {\n var owner = element._owner;\n var stack = describeUnknownElementTypeFrameInDEV(element.type, element._source, owner ? owner.type : null);\n ReactDebugCurrentFrame$1.setExtraStackFrame(stack);\n } else ReactDebugCurrentFrame$1.setExtraStackFrame(null);\n }\n function checkPropTypes(typeSpecs, values, location, componentName, element) {\n // $FlowFixMe This is okay but Flow doesn't know it.\n var has = Function.call.bind(Object.prototype.hasOwnProperty);\n for(var typeSpecName in typeSpecs)if (has(typeSpecs, typeSpecName)) {\n var error$1 = void 0; // Prop type validation may throw. In case they do, we don't want to\n // fail the render phase where it didn't fail before. So we log it.\n // After these have been cleaned up, we'll let them throw.\n try {\n // This is intentionally an invariant that gets caught. It's the same\n // behavior as without this statement except with a better message.\n if (typeof typeSpecs[typeSpecName] !== 'function') {\n var err = Error((componentName || 'React class') + ': ' + location + ' type `' + typeSpecName + '` is invalid; ' + 'it must be a function, usually from the `prop-types` package, but received `' + typeof typeSpecs[typeSpecName] + '`.' + 'This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.');\n err.name = 'Invariant Violation';\n throw err;\n }\n error$1 = typeSpecs[typeSpecName](values, typeSpecName, componentName, location, null, 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED');\n } catch (ex) {\n error$1 = ex;\n }\n if (error$1 && !(error$1 instanceof Error)) {\n setCurrentlyValidatingElement(element);\n error1(\"%s: type specification of %s `%s` is invalid; the type checker function must return `null` or an `Error` but returned a %s. You may have forgotten to pass an argument to the type checker creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and shape all require an argument).\", componentName || 'React class', location, typeSpecName, typeof error$1);\n setCurrentlyValidatingElement(null);\n }\n if (error$1 instanceof Error && !(error$1.message in loggedTypeFailures)) {\n // Only monitor this failure once because there tends to be a lot of the\n // same error.\n loggedTypeFailures[error$1.message] = true;\n setCurrentlyValidatingElement(element);\n error1('Failed %s type: %s', location, error$1.message);\n setCurrentlyValidatingElement(null);\n }\n }\n }\n function setCurrentlyValidatingElement$1(element) {\n if (element) {\n var owner = element._owner;\n var stack = describeUnknownElementTypeFrameInDEV(element.type, element._source, owner ? owner.type : null);\n setExtraStackFrame(stack);\n } else setExtraStackFrame(null);\n }\n var propTypesMisspellWarningShown;\n propTypesMisspellWarningShown = false;\n function getDeclarationErrorAddendum() {\n if (ReactCurrentOwner.current) {\n var name = getComponentName(ReactCurrentOwner.current.type);\n if (name) return '\\n\\nCheck the render method of `' + name + '`.';\n }\n return '';\n }\n function getSourceInfoErrorAddendum(source) {\n if (source !== undefined) {\n var fileName = source.fileName.replace(/^.*[\\\\\\/]/, '');\n var lineNumber = source.lineNumber;\n return '\\n\\nCheck your code at ' + fileName + ':' + lineNumber + '.';\n }\n return '';\n }\n function getSourceInfoErrorAddendumForProps(elementProps) {\n if (elementProps !== null && elementProps !== undefined) return getSourceInfoErrorAddendum(elementProps.__source);\n return '';\n }\n /**\n * Warn if there's no key explicitly set on dynamic arrays of children or\n * object keys are not valid. This allows us to keep track of children between\n * updates.\n */ var ownerHasKeyUseWarning = {\n };\n function getCurrentComponentErrorInfo(parentType) {\n var info = getDeclarationErrorAddendum();\n if (!info) {\n var parentName = typeof parentType === 'string' ? parentType : parentType.displayName || parentType.name;\n if (parentName) info = \"\\n\\nCheck the top-level render call using <\" + parentName + \">.\";\n }\n return info;\n }\n /**\n * Warn if the element doesn't have an explicit key assigned to it.\n * This element is in an array. The array could grow and shrink or be\n * reordered. All children that haven't already been validated are required to\n * have a \"key\" property assigned to it. Error statuses are cached so a warning\n * will only be shown once.\n *\n * @internal\n * @param {ReactElement} element Element that requires a key.\n * @param {*} parentType element's parent's type.\n */ function validateExplicitKey(element, parentType) {\n if (!element._store || element._store.validated || element.key != null) return;\n element._store.validated = true;\n var currentComponentErrorInfo = getCurrentComponentErrorInfo(parentType);\n if (ownerHasKeyUseWarning[currentComponentErrorInfo]) return;\n ownerHasKeyUseWarning[currentComponentErrorInfo] = true; // Usually the current owner is the offender, but if it accepts children as a\n // property, it may be the creator of the child that's responsible for\n // assigning it a key.\n var childOwner = '';\n if (element && element._owner && element._owner !== ReactCurrentOwner.current) // Give the component that originally created this child.\n childOwner = \" It was passed a child from \" + getComponentName(element._owner.type) + \".\";\n setCurrentlyValidatingElement$1(element);\n error1(\"Each child in a list should have a unique \\\"key\\\" prop.%s%s See https://reactjs.org/link/warning-keys for more information.\", currentComponentErrorInfo, childOwner);\n setCurrentlyValidatingElement$1(null);\n }\n /**\n * Ensure that every element either is passed in a static location, in an\n * array with an explicit keys property defined, or in an object literal\n * with valid key property.\n *\n * @internal\n * @param {ReactNode} node Statically passed child of any type.\n * @param {*} parentType node's parent's type.\n */ function validateChildKeys(node, parentType) {\n if (typeof node !== 'object') return;\n if (Array.isArray(node)) for(var i = 0; i < node.length; i++){\n var child = node[i];\n if (isValidElement(child)) validateExplicitKey(child, parentType);\n }\n else if (isValidElement(node)) // This element was passed in a valid location.\n {\n if (node._store) node._store.validated = true;\n } else if (node) {\n var iteratorFn = getIteratorFn(node);\n if (typeof iteratorFn === 'function') // Entry iterators used to provide implicit keys,\n // but now we print a separate warning for them later.\n {\n if (iteratorFn !== node.entries) {\n var iterator = iteratorFn.call(node);\n var step;\n while(!(step = iterator.next()).done)if (isValidElement(step.value)) validateExplicitKey(step.value, parentType);\n }\n }\n }\n }\n /**\n * Given an element, validate that its props follow the propTypes definition,\n * provided by the type.\n *\n * @param {ReactElement} element\n */ function validatePropTypes(element) {\n var type = element.type;\n if (type === null || type === undefined || typeof type === 'string') return;\n var propTypes;\n if (typeof type === 'function') propTypes = type.propTypes;\n else if (typeof type === 'object' && (type.$$typeof === REACT_FORWARD_REF_TYPE || // Inner props are checked in the reconciler.\n type.$$typeof === REACT_MEMO_TYPE)) propTypes = type.propTypes;\n else return;\n if (propTypes) {\n // Intentionally inside to avoid triggering lazy initializers:\n var name = getComponentName(type);\n checkPropTypes(propTypes, element.props, 'prop', name, element);\n } else if (type.PropTypes !== undefined && !propTypesMisspellWarningShown) {\n propTypesMisspellWarningShown = true; // Intentionally inside to avoid triggering lazy initializers:\n var _name = getComponentName(type);\n error1('Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?', _name || 'Unknown');\n }\n if (typeof type.getDefaultProps === 'function' && !type.getDefaultProps.isReactClassApproved) error1(\"getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead.\");\n }\n /**\n * Given a fragment, validate that it can only be provided with fragment props\n * @param {ReactElement} fragment\n */ function validateFragmentProps(fragment) {\n var keys = Object.keys(fragment.props);\n for(var i = 0; i < keys.length; i++){\n var key = keys[i];\n if (key !== 'children' && key !== 'key') {\n setCurrentlyValidatingElement$1(fragment);\n error1(\"Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.\", key);\n setCurrentlyValidatingElement$1(null);\n break;\n }\n }\n if (fragment.ref !== null) {\n setCurrentlyValidatingElement$1(fragment);\n error1('Invalid attribute `ref` supplied to `React.Fragment`.');\n setCurrentlyValidatingElement$1(null);\n }\n }\n function createElementWithValidation(type, props, children) {\n var validType = isValidElementType(type); // We warn in this case but don't throw. We expect the element creation to\n // succeed and there will likely be errors in render.\n if (!validType) {\n var info = '';\n if (type === undefined || typeof type === 'object' && type !== null && Object.keys(type).length === 0) info += \" You likely forgot to export your component from the file it's defined in, or you might have mixed up default and named imports.\";\n var sourceInfo = getSourceInfoErrorAddendumForProps(props);\n if (sourceInfo) info += sourceInfo;\n else info += getDeclarationErrorAddendum();\n var typeString;\n if (type === null) typeString = 'null';\n else if (Array.isArray(type)) typeString = 'array';\n else if (type !== undefined && type.$$typeof === REACT_ELEMENT_TYPE) {\n typeString = \"<\" + (getComponentName(type.type) || 'Unknown') + \" />\";\n info = ' Did you accidentally export a JSX literal instead of a component?';\n } else typeString = typeof type;\n error1(\"React.createElement: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s\", typeString, info);\n }\n var element = createElement.apply(this, arguments); // The result can be nullish if a mock or a custom function is used.\n // TODO: Drop this when these are no longer allowed as the type argument.\n if (element == null) return element;\n // Skip key warning if the type isn't valid since our key validation logic\n // doesn't expect a non-string/function type and can throw confusing errors.\n // We don't want exception behavior to differ between dev and prod.\n // (Rendering will throw with a helpful message and as soon as the type is\n // fixed, the key warnings will appear.)\n if (validType) for(var i = 2; i < arguments.length; i++)validateChildKeys(arguments[i], type);\n if (type === exports.Fragment) validateFragmentProps(element);\n else validatePropTypes(element);\n return element;\n }\n var didWarnAboutDeprecatedCreateFactory = false;\n function createFactoryWithValidation(type) {\n var validatedFactory = createElementWithValidation.bind(null, type);\n validatedFactory.type = type;\n if (!didWarnAboutDeprecatedCreateFactory) {\n didWarnAboutDeprecatedCreateFactory = true;\n warn(\"React.createFactory() is deprecated and will be removed in a future major release. Consider using JSX or use React.createElement() directly instead.\");\n } // Legacy hook: remove it\n Object.defineProperty(validatedFactory, 'type', {\n enumerable: false,\n get: function() {\n warn(\"Factory.type is deprecated. Access the class directly before passing it to createFactory.\");\n Object.defineProperty(this, 'type', {\n value: type\n });\n return type;\n }\n });\n return validatedFactory;\n }\n function cloneElementWithValidation(element, props, children) {\n var newElement = cloneElement.apply(this, arguments);\n for(var i = 2; i < arguments.length; i++)validateChildKeys(arguments[i], newElement.type);\n validatePropTypes(newElement);\n return newElement;\n }\n try {\n var frozenObject = Object.freeze({\n });\n /* eslint-disable no-new */ new Map([\n [\n frozenObject,\n null\n ]\n ]);\n new Set([\n frozenObject\n ]);\n /* eslint-enable no-new */ } catch (e) {\n }\n var createElement$1 = createElementWithValidation;\n var cloneElement$1 = cloneElementWithValidation;\n var createFactory = createFactoryWithValidation;\n var Children = {\n map: mapChildren,\n forEach: forEachChildren,\n count: countChildren,\n toArray: toArray,\n only: onlyChild\n };\n exports.Children = Children;\n exports.Component = Component1;\n exports.PureComponent = PureComponent;\n exports.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED = ReactSharedInternals;\n exports.cloneElement = cloneElement$1;\n exports.createContext = createContext;\n exports.createElement = createElement$1;\n exports.createFactory = createFactory;\n exports.createRef = createRef;\n exports.forwardRef = forwardRef;\n exports.isValidElement = isValidElement;\n exports.lazy = lazy;\n exports.memo = memo;\n exports.useCallback = useCallback;\n exports.useContext = useContext;\n exports.useDebugValue = useDebugValue;\n exports.useEffect = useEffect;\n exports.useImperativeHandle = useImperativeHandle;\n exports.useLayoutEffect = useLayoutEffect;\n exports.useMemo = useMemo;\n exports.useReducer = useReducer;\n exports.useRef = useRef;\n exports.useState = useState;\n exports.version = ReactVersion;\n})();\n\n},{\"object-assign\":\"7zBzH\"}],\"7zBzH\":[function(require,module,exports) {\n/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/ 'use strict';\n/* eslint-disable no-unused-vars */ var getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\nfunction toObject(val) {\n if (val === null || val === undefined) throw new TypeError('Object.assign cannot be called with null or undefined');\n return Object(val);\n}\nfunction shouldUseNative() {\n try {\n if (!Object.assign) return false;\n // Detect buggy property enumeration order in older V8 versions.\n // https://bugs.chromium.org/p/v8/issues/detail?id=4118\n var test1 = \"abc\"; // eslint-disable-line no-new-wrappers\n test1[5] = 'de';\n if (Object.getOwnPropertyNames(test1)[0] === '5') return false;\n // https://bugs.chromium.org/p/v8/issues/detail?id=3056\n var test2 = {\n };\n for(var i = 0; i < 10; i++)test2['_' + String.fromCharCode(i)] = i;\n var order2 = Object.getOwnPropertyNames(test2).map(function(n) {\n return test2[n];\n });\n if (order2.join('') !== '0123456789') return false;\n // https://bugs.chromium.org/p/v8/issues/detail?id=3056\n var test3 = {\n };\n 'abcdefghijklmnopqrst'.split('').forEach(function(letter) {\n test3[letter] = letter;\n });\n if (Object.keys(Object.assign({\n }, test3)).join('') !== 'abcdefghijklmnopqrst') return false;\n return true;\n } catch (err) {\n // We don't expect any of the above to throw, but better to be safe.\n return false;\n }\n}\nmodule.exports = shouldUseNative() ? Object.assign : function(target, source) {\n var from;\n var to = toObject(target);\n var symbols;\n for(var s = 1; s < arguments.length; s++){\n from = Object(arguments[s]);\n for(var key in from)if (hasOwnProperty.call(from, key)) to[key] = from[key];\n if (getOwnPropertySymbols) {\n symbols = getOwnPropertySymbols(from);\n for(var i = 0; i < symbols.length; i++)if (propIsEnumerable.call(from, symbols[i])) to[symbols[i]] = from[symbols[i]];\n }\n }\n return to;\n};\n\n},{}],\"6gQUZ\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"CompletionContext\", ()=>CompletionContext\n);\nparcelHelpers.export(exports, \"acceptCompletion\", ()=>acceptCompletion\n);\nparcelHelpers.export(exports, \"autocompletion\", ()=>autocompletion\n);\nparcelHelpers.export(exports, \"clearSnippet\", ()=>clearSnippet\n);\nparcelHelpers.export(exports, \"closeCompletion\", ()=>closeCompletion\n);\nparcelHelpers.export(exports, \"completeAnyWord\", ()=>completeAnyWord\n);\nparcelHelpers.export(exports, \"completeFromList\", ()=>completeFromList\n);\nparcelHelpers.export(exports, \"completionKeymap\", ()=>completionKeymap\n);\nparcelHelpers.export(exports, \"completionStatus\", ()=>completionStatus\n);\nparcelHelpers.export(exports, \"currentCompletions\", ()=>currentCompletions\n);\nparcelHelpers.export(exports, \"ifIn\", ()=>ifIn\n);\nparcelHelpers.export(exports, \"ifNotIn\", ()=>ifNotIn\n);\nparcelHelpers.export(exports, \"moveCompletionSelection\", ()=>moveCompletionSelection\n);\nparcelHelpers.export(exports, \"nextSnippetField\", ()=>nextSnippetField\n);\nparcelHelpers.export(exports, \"pickedCompletion\", ()=>pickedCompletion\n);\nparcelHelpers.export(exports, \"prevSnippetField\", ()=>prevSnippetField\n);\nparcelHelpers.export(exports, \"selectedCompletion\", ()=>selectedCompletion\n);\nparcelHelpers.export(exports, \"snippet\", ()=>snippet\n);\nparcelHelpers.export(exports, \"snippetCompletion\", ()=>snippetCompletion\n);\nparcelHelpers.export(exports, \"snippetKeymap\", ()=>snippetKeymap\n);\nparcelHelpers.export(exports, \"startCompletion\", ()=>startCompletion\n);\nvar _state = require(\"@codemirror/state\");\nvar _view = require(\"@codemirror/view\");\nvar _tooltip = require(\"@codemirror/tooltip\");\nvar _language = require(\"@codemirror/language\");\nvar _text = require(\"@codemirror/text\");\n/**\nAn instance of this is passed to completion source functions.\n*/ class CompletionContext {\n /**\n Create a new completion context. (Mostly useful for testing\n completion sources\u2014in the editor, the extension will create\n these for you.)\n */ constructor(/**\n The editor state that the completion happens in.\n */ state, /**\n The position at which the completion is happening.\n */ pos, /**\n Indicates whether completion was activated explicitly, or\n implicitly by typing. The usual way to respond to this is to\n only return completions when either there is part of a\n completable entity before the cursor, or `explicit` is true.\n */ explicit){\n this.state = state;\n this.pos = pos;\n this.explicit = explicit;\n /**\n @internal\n */ this.abortListeners = [];\n }\n /**\n Get the extent, content, and (if there is a token) type of the\n token before `this.pos`.\n */ tokenBefore(types) {\n let token = _language.syntaxTree(this.state).resolveInner(this.pos, -1);\n while(token && types.indexOf(token.name) < 0)token = token.parent;\n return token ? {\n from: token.from,\n to: this.pos,\n text: this.state.sliceDoc(token.from, this.pos),\n type: token.type\n } : null;\n }\n /**\n Get the match of the given expression directly before the\n cursor.\n */ matchBefore(expr) {\n let line = this.state.doc.lineAt(this.pos);\n let start = Math.max(line.from, this.pos - 250);\n let str = line.text.slice(start - line.from, this.pos - line.from);\n let found = str.search(ensureAnchor(expr, false));\n return found < 0 ? null : {\n from: start + found,\n to: this.pos,\n text: str.slice(found)\n };\n }\n /**\n Yields true when the query has been aborted. Can be useful in\n asynchronous queries to avoid doing work that will be ignored.\n */ get aborted() {\n return this.abortListeners == null;\n }\n /**\n Allows you to register abort handlers, which will be called when\n the query is\n [aborted](https://codemirror.net/6/docs/ref/#autocomplete.CompletionContext.aborted).\n */ addEventListener(type, listener) {\n if (type == \"abort\" && this.abortListeners) this.abortListeners.push(listener);\n }\n}\nfunction toSet(chars) {\n let flat = Object.keys(chars).join(\"\");\n let words = /\\w/.test(flat);\n if (words) flat = flat.replace(/\\w/g, \"\");\n return `[${words ? \"\\\\w\" : \"\"}${flat.replace(/[^\\w\\s]/g, \"\\\\$&\")}]`;\n}\nfunction prefixMatch(options) {\n let first = Object.create(null), rest = Object.create(null);\n for (let { label } of options){\n first[label[0]] = true;\n for(let i = 1; i < label.length; i++)rest[label[i]] = true;\n }\n let source = toSet(first) + toSet(rest) + \"*$\";\n return [\n new RegExp(\"^\" + source),\n new RegExp(source)\n ];\n}\n/**\nGiven a a fixed array of options, return an autocompleter that\ncompletes them.\n*/ function completeFromList(list) {\n let options = list.map((o)=>typeof o == \"string\" ? {\n label: o\n } : o\n );\n let [span, match] = options.every((o)=>/^\\w+$/.test(o.label)\n ) ? [\n /\\w*$/,\n /\\w+$/\n ] : prefixMatch(options);\n return (context)=>{\n let token = context.matchBefore(match);\n return token || context.explicit ? {\n from: token ? token.from : context.pos,\n options,\n span\n } : null;\n };\n}\n/**\nWrap the given completion source so that it will only fire when the\ncursor is in a syntax node with one of the given names.\n*/ function ifIn(nodes, source) {\n return (context)=>{\n for(let pos = _language.syntaxTree(context.state).resolveInner(context.pos, -1); pos; pos = pos.parent)if (nodes.indexOf(pos.name) > -1) return source(context);\n return null;\n };\n}\n/**\nWrap the given completion source so that it will not fire when the\ncursor is in a syntax node with one of the given names.\n*/ function ifNotIn(nodes, source) {\n return (context)=>{\n for(let pos = _language.syntaxTree(context.state).resolveInner(context.pos, -1); pos; pos = pos.parent)if (nodes.indexOf(pos.name) > -1) return null;\n return source(context);\n };\n}\nclass Option {\n constructor(completion, source, match){\n this.completion = completion;\n this.source = source;\n this.match = match;\n }\n}\nfunction cur(state) {\n return state.selection.main.head;\n}\n// Make sure the given regexp has a $ at its end and, if `start` is\n// true, a ^ at its start.\nfunction ensureAnchor(expr, start) {\n var _a;\n let { source } = expr;\n let addStart = start && source[0] != \"^\", addEnd = source[source.length - 1] != \"$\";\n if (!addStart && !addEnd) return expr;\n return new RegExp(`${addStart ? \"^\" : \"\"}(?:${source})${addEnd ? \"$\" : \"\"}`, (_a = expr.flags) !== null && _a !== void 0 ? _a : expr.ignoreCase ? \"i\" : \"\");\n}\n/**\nThis annotation is added to transactions that are produced by\npicking a completion.\n*/ const pickedCompletion = /*@__PURE__*/ _state.Annotation.define();\nfunction applyCompletion(view, option) {\n let apply = option.completion.apply || option.completion.label;\n let result = option.source;\n if (typeof apply == \"string\") view.dispatch({\n changes: {\n from: result.from,\n to: result.to,\n insert: apply\n },\n selection: {\n anchor: result.from + apply.length\n },\n userEvent: \"input.complete\",\n annotations: pickedCompletion.of(option.completion)\n });\n else apply(view, option.completion, result.from, result.to);\n}\nconst SourceCache = /*@__PURE__*/ new WeakMap();\nfunction asSource(source) {\n if (!Array.isArray(source)) return source;\n let known = SourceCache.get(source);\n if (!known) SourceCache.set(source, known = completeFromList(source));\n return known;\n}\n// A pattern matcher for fuzzy completion matching. Create an instance\n// once for a pattern, and then use that to match any number of\n// completions.\nclass FuzzyMatcher {\n constructor(pattern){\n this.pattern = pattern;\n this.chars = [];\n this.folded = [];\n // Buffers reused by calls to `match` to track matched character\n // positions.\n this.any = [];\n this.precise = [];\n this.byWord = [];\n for(let p = 0; p < pattern.length;){\n let char = _text.codePointAt(pattern, p), size = _text.codePointSize(char);\n this.chars.push(char);\n let part = pattern.slice(p, p + size), upper = part.toUpperCase();\n this.folded.push(_text.codePointAt(upper == part ? part.toLowerCase() : upper, 0));\n p += size;\n }\n this.astral = pattern.length != this.chars.length;\n }\n // Matches a given word (completion) against the pattern (input).\n // Will return null for no match, and otherwise an array that starts\n // with the match score, followed by any number of `from, to` pairs\n // indicating the matched parts of `word`.\n //\n // The score is a number that is more negative the worse the match\n // is. See `Penalty` above.\n match(word) {\n if (this.pattern.length == 0) return [\n 0\n ];\n if (word.length < this.pattern.length) return null;\n let { chars , folded , any , precise , byWord } = this;\n // For single-character queries, only match when they occur right\n // at the start\n if (chars.length == 1) {\n let first = _text.codePointAt(word, 0);\n return first == chars[0] ? [\n 0,\n 0,\n _text.codePointSize(first)\n ] : first == folded[0] ? [\n -200 /* CaseFold */ ,\n 0,\n _text.codePointSize(first)\n ] : null;\n }\n let direct = word.indexOf(this.pattern);\n if (direct == 0) return [\n 0,\n 0,\n this.pattern.length\n ];\n let len = chars.length, anyTo = 0;\n if (direct < 0) {\n for(let i = 0, e = Math.min(word.length, 200); i < e && anyTo < len;){\n let next = _text.codePointAt(word, i);\n if (next == chars[anyTo] || next == folded[anyTo]) any[anyTo++] = i;\n i += _text.codePointSize(next);\n }\n // No match, exit immediately\n if (anyTo < len) return null;\n }\n // This tracks the extent of the precise (non-folded, not\n // necessarily adjacent) match\n let preciseTo = 0;\n // Tracks whether there is a match that hits only characters that\n // appear to be starting words. `byWordFolded` is set to true when\n // a case folded character is encountered in such a match\n let byWordTo = 0, byWordFolded = false;\n // If we've found a partial adjacent match, these track its state\n let adjacentTo = 0, adjacentStart = -1, adjacentEnd = -1;\n let hasLower = /[a-z]/.test(word), wordAdjacent = true;\n // Go over the option's text, scanning for the various kinds of matches\n for(let i = 0, e = Math.min(word.length, 200), prevType = 0 /* NonWord */ ; i < e && byWordTo < len;){\n let next = _text.codePointAt(word, i);\n if (direct < 0) {\n if (preciseTo < len && next == chars[preciseTo]) precise[preciseTo++] = i;\n if (adjacentTo < len) {\n if (next == chars[adjacentTo] || next == folded[adjacentTo]) {\n if (adjacentTo == 0) adjacentStart = i;\n adjacentEnd = i + 1;\n adjacentTo++;\n } else adjacentTo = 0;\n }\n }\n let ch, type = next < 255 ? next >= 48 && next <= 57 || next >= 97 && next <= 122 ? 2 /* Lower */ : next >= 65 && next <= 90 ? 1 /* Upper */ : 0 /* NonWord */ : (ch = _text.fromCodePoint(next)) != ch.toLowerCase() ? 1 /* Upper */ : ch != ch.toUpperCase() ? 2 /* Lower */ : 0 /* NonWord */ ;\n if (!i || type == 1 /* Upper */ && hasLower || prevType == 0 /* NonWord */ && type != 0 /* NonWord */ ) {\n if (chars[byWordTo] == next || folded[byWordTo] == next && (byWordFolded = true)) byWord[byWordTo++] = i;\n else if (byWord.length) wordAdjacent = false;\n }\n prevType = type;\n i += _text.codePointSize(next);\n }\n if (byWordTo == len && byWord[0] == 0 && wordAdjacent) return this.result(-100 /* ByWord */ + (byWordFolded ? -200 /* CaseFold */ : 0), byWord, word);\n if (adjacentTo == len && adjacentStart == 0) return [\n -200 /* CaseFold */ - word.length,\n 0,\n adjacentEnd\n ];\n if (direct > -1) return [\n -700 /* NotStart */ - word.length,\n direct,\n direct + this.pattern.length\n ];\n if (adjacentTo == len) return [\n -900 /* NotStart */ - word.length,\n adjacentStart,\n adjacentEnd\n ];\n if (byWordTo == len) return this.result(-100 /* ByWord */ + (byWordFolded ? -200 /* CaseFold */ : 0) + -700 /* NotStart */ + (wordAdjacent ? 0 : -1100 /* Gap */ ), byWord, word);\n return chars.length == 2 ? null : this.result((any[0] ? -700 /* NotStart */ : 0) + -200 /* CaseFold */ + -1100 /* Gap */ , any, word);\n }\n result(score1, positions, word) {\n let result = [\n score1 - word.length\n ], i = 1;\n for (let pos of positions){\n let to = pos + (this.astral ? _text.codePointSize(_text.codePointAt(word, pos)) : 1);\n if (i > 1 && result[i - 1] == pos) result[i - 1] = to;\n else {\n result[i++] = pos;\n result[i++] = to;\n }\n }\n return result;\n }\n}\nconst completionConfig = /*@__PURE__*/ _state.Facet.define({\n combine (configs) {\n return _state.combineConfig(configs, {\n activateOnTyping: true,\n override: null,\n maxRenderedOptions: 100,\n defaultKeymap: true,\n optionClass: ()=>\"\"\n ,\n aboveCursor: false,\n icons: true,\n addToOptions: []\n }, {\n defaultKeymap: (a, b)=>a && b\n ,\n icons: (a, b)=>a && b\n ,\n optionClass: (a, b)=>(c)=>joinClass(a(c), b(c))\n ,\n addToOptions: (a, b)=>a.concat(b)\n });\n }\n});\nfunction joinClass(a, b) {\n return a ? b ? a + \" \" + b : a : b;\n}\nfunction optionContent(config) {\n let content = config.addToOptions.slice();\n if (config.icons) content.push({\n render (completion) {\n let icon = document.createElement(\"div\");\n icon.classList.add(\"cm-completionIcon\");\n if (completion.type) icon.classList.add(...completion.type.split(/\\s+/g).map((cls)=>\"cm-completionIcon-\" + cls\n ));\n icon.setAttribute(\"aria-hidden\", \"true\");\n return icon;\n },\n position: 20\n });\n content.push({\n render (completion, _s, match) {\n let labelElt = document.createElement(\"span\");\n labelElt.className = \"cm-completionLabel\";\n let { label } = completion, off = 0;\n for(let j = 1; j < match.length;){\n let from = match[j++], to = match[j++];\n if (from > off) labelElt.appendChild(document.createTextNode(label.slice(off, from)));\n let span = labelElt.appendChild(document.createElement(\"span\"));\n span.appendChild(document.createTextNode(label.slice(from, to)));\n span.className = \"cm-completionMatchedText\";\n off = to;\n }\n if (off < label.length) labelElt.appendChild(document.createTextNode(label.slice(off)));\n return labelElt;\n },\n position: 50\n }, {\n render (completion) {\n if (!completion.detail) return null;\n let detailElt = document.createElement(\"span\");\n detailElt.className = \"cm-completionDetail\";\n detailElt.textContent = completion.detail;\n return detailElt;\n },\n position: 80\n });\n return content.sort((a, b)=>a.position - b.position\n ).map((a)=>a.render\n );\n}\nfunction createInfoDialog(option, view) {\n let dom = document.createElement(\"div\");\n dom.className = \"cm-tooltip cm-completionInfo\";\n let { info } = option.completion;\n if (typeof info == \"string\") dom.textContent = info;\n else {\n let content = info(option.completion);\n if (content.then) content.then((node)=>dom.appendChild(node)\n , (e)=>_view.logException(view.state, e, \"completion info\")\n );\n else dom.appendChild(content);\n }\n return dom;\n}\nfunction rangeAroundSelected(total, selected, max) {\n if (total <= max) return {\n from: 0,\n to: total\n };\n if (selected <= total >> 1) {\n let off = Math.floor(selected / max);\n return {\n from: off * max,\n to: (off + 1) * max\n };\n }\n let off = Math.floor((total - selected) / max);\n return {\n from: total - (off + 1) * max,\n to: total - off * max\n };\n}\nclass CompletionTooltip {\n constructor(view, stateField){\n this.view = view;\n this.stateField = stateField;\n this.info = null;\n this.placeInfo = {\n read: ()=>this.measureInfo()\n ,\n write: (pos)=>this.positionInfo(pos)\n ,\n key: this\n };\n let cState = view.state.field(stateField);\n let { options , selected } = cState.open;\n let config = view.state.facet(completionConfig);\n this.optionContent = optionContent(config);\n this.optionClass = config.optionClass;\n this.range = rangeAroundSelected(options.length, selected, config.maxRenderedOptions);\n this.dom = document.createElement(\"div\");\n this.dom.className = \"cm-tooltip-autocomplete\";\n this.dom.addEventListener(\"mousedown\", (e)=>{\n for(let dom = e.target, match; dom && dom != this.dom; dom = dom.parentNode)if (dom.nodeName == \"LI\" && (match = /-(\\d+)$/.exec(dom.id)) && +match[1] < options.length) {\n applyCompletion(view, options[+match[1]]);\n e.preventDefault();\n return;\n }\n });\n this.list = this.dom.appendChild(this.createListBox(options, cState.id, this.range));\n this.list.addEventListener(\"scroll\", ()=>{\n if (this.info) this.view.requestMeasure(this.placeInfo);\n });\n }\n mount() {\n this.updateSel();\n }\n update(update) {\n if (update.state.field(this.stateField) != update.startState.field(this.stateField)) this.updateSel();\n }\n positioned() {\n if (this.info) this.view.requestMeasure(this.placeInfo);\n }\n updateSel() {\n let cState = this.view.state.field(this.stateField), open = cState.open;\n if (open.selected < this.range.from || open.selected >= this.range.to) {\n this.range = rangeAroundSelected(open.options.length, open.selected, this.view.state.facet(completionConfig).maxRenderedOptions);\n this.list.remove();\n this.list = this.dom.appendChild(this.createListBox(open.options, cState.id, this.range));\n this.list.addEventListener(\"scroll\", ()=>{\n if (this.info) this.view.requestMeasure(this.placeInfo);\n });\n }\n if (this.updateSelectedOption(open.selected)) {\n if (this.info) {\n this.info.remove();\n this.info = null;\n }\n let option = open.options[open.selected];\n if (option.completion.info) {\n this.info = this.dom.appendChild(createInfoDialog(option, this.view));\n this.view.requestMeasure(this.placeInfo);\n }\n }\n }\n updateSelectedOption(selected) {\n let set = null;\n for(let opt = this.list.firstChild, i = this.range.from; opt; opt = opt.nextSibling, i++){\n if (i == selected) {\n if (!opt.hasAttribute(\"aria-selected\")) {\n opt.setAttribute(\"aria-selected\", \"true\");\n set = opt;\n }\n } else if (opt.hasAttribute(\"aria-selected\")) opt.removeAttribute(\"aria-selected\");\n }\n if (set) scrollIntoView(this.list, set);\n return set;\n }\n measureInfo() {\n let sel = this.dom.querySelector(\"[aria-selected]\");\n if (!sel || !this.info) return null;\n let listRect = this.dom.getBoundingClientRect();\n let infoRect = this.info.getBoundingClientRect();\n let selRect = sel.getBoundingClientRect();\n if (selRect.top > Math.min(innerHeight, listRect.bottom) - 10 || selRect.bottom < Math.max(0, listRect.top) + 10) return null;\n let top = Math.max(0, Math.min(selRect.top, innerHeight - infoRect.height)) - listRect.top;\n let left = this.view.textDirection == _view.Direction.RTL;\n let spaceLeft = listRect.left, spaceRight = innerWidth - listRect.right;\n if (left && spaceLeft < Math.min(infoRect.width, spaceRight)) left = false;\n else if (!left && spaceRight < Math.min(infoRect.width, spaceLeft)) left = true;\n return {\n top,\n left\n };\n }\n positionInfo(pos) {\n if (this.info) {\n this.info.style.top = (pos ? pos.top : -1000000) + \"px\";\n if (pos) {\n this.info.classList.toggle(\"cm-completionInfo-left\", pos.left);\n this.info.classList.toggle(\"cm-completionInfo-right\", !pos.left);\n }\n }\n }\n createListBox(options, id, range) {\n const ul = document.createElement(\"ul\");\n ul.id = id;\n ul.setAttribute(\"role\", \"listbox\");\n for(let i = range.from; i < range.to; i++){\n let { completion , match } = options[i];\n const li = ul.appendChild(document.createElement(\"li\"));\n li.id = id + \"-\" + i;\n li.setAttribute(\"role\", \"option\");\n let cls = this.optionClass(completion);\n if (cls) li.className = cls;\n for (let source of this.optionContent){\n let node = source(completion, this.view.state, match);\n if (node) li.appendChild(node);\n }\n }\n if (range.from) ul.classList.add(\"cm-completionListIncompleteTop\");\n if (range.to < options.length) ul.classList.add(\"cm-completionListIncompleteBottom\");\n return ul;\n }\n}\n// We allocate a new function instance every time the completion\n// changes to force redrawing/repositioning of the tooltip\nfunction completionTooltip(stateField) {\n return (view)=>new CompletionTooltip(view, stateField)\n ;\n}\nfunction scrollIntoView(container, element) {\n let parent = container.getBoundingClientRect();\n let self = element.getBoundingClientRect();\n if (self.top < parent.top) container.scrollTop -= parent.top - self.top;\n else if (self.bottom > parent.bottom) container.scrollTop += self.bottom - parent.bottom;\n}\nconst MaxOptions = 300;\n// Used to pick a preferred option when two options with the same\n// label occur in the result.\nfunction score(option) {\n return (option.boost || 0) * 100 + (option.apply ? 10 : 0) + (option.info ? 5 : 0) + (option.type ? 1 : 0);\n}\nfunction sortOptions(active, state) {\n let options = [], i = 0;\n for (let a of active)if (a.hasResult()) {\n if (a.result.filter === false) for (let option of a.result.options)options.push(new Option(option, a, [\n 1000000000 - i++\n ]));\n else {\n let matcher = new FuzzyMatcher(state.sliceDoc(a.from, a.to)), match;\n for (let option of a.result.options)if (match = matcher.match(option.label)) {\n if (option.boost != null) match[0] += option.boost;\n options.push(new Option(option, a, match));\n }\n }\n }\n options.sort(cmpOption);\n let result = [], prev = null;\n for (let opt of options.sort(cmpOption)){\n if (result.length == MaxOptions) break;\n if (!prev || prev.label != opt.completion.label || prev.detail != opt.completion.detail || prev.type != opt.completion.type || prev.apply != opt.completion.apply) result.push(opt);\n else if (score(opt.completion) > score(prev)) result[result.length - 1] = opt;\n prev = opt.completion;\n }\n return result;\n}\nclass CompletionDialog {\n constructor(options, attrs, tooltip, timestamp, selected){\n this.options = options;\n this.attrs = attrs;\n this.tooltip = tooltip;\n this.timestamp = timestamp;\n this.selected = selected;\n }\n setSelected(selected, id) {\n return selected == this.selected || selected >= this.options.length ? this : new CompletionDialog(this.options, makeAttrs(id, selected), this.tooltip, this.timestamp, selected);\n }\n static build(active, state, id, prev, conf) {\n let options = sortOptions(active, state);\n if (!options.length) return null;\n let selected = 0;\n if (prev && prev.selected) {\n let selectedValue = prev.options[prev.selected].completion;\n for(let i = 0; i < options.length && !selected; i++)if (options[i].completion == selectedValue) selected = i;\n }\n return new CompletionDialog(options, makeAttrs(id, selected), {\n pos: active.reduce((a, b)=>b.hasResult() ? Math.min(a, b.from) : a\n , 100000000),\n create: completionTooltip(completionState),\n above: conf.aboveCursor\n }, prev ? prev.timestamp : Date.now(), selected);\n }\n map(changes) {\n return new CompletionDialog(this.options, this.attrs, Object.assign(Object.assign({\n }, this.tooltip), {\n pos: changes.mapPos(this.tooltip.pos)\n }), this.timestamp, this.selected);\n }\n}\nclass CompletionState {\n constructor(active, id, open){\n this.active = active;\n this.id = id;\n this.open = open;\n }\n static start() {\n return new CompletionState(none, \"cm-ac-\" + Math.floor(Math.random() * 2000000).toString(36), null);\n }\n update(tr) {\n let { state } = tr, conf = state.facet(completionConfig);\n let sources = conf.override || state.languageDataAt(\"autocomplete\", cur(state)).map(asSource);\n let active = sources.map((source)=>{\n let value = this.active.find((s)=>s.source == source\n ) || new ActiveSource(source, this.active.some((a)=>a.state != 0 /* Inactive */ \n ) ? 1 /* Pending */ : 0 /* Inactive */ );\n return value.update(tr, conf);\n });\n if (active.length == this.active.length && active.every((a, i)=>a == this.active[i]\n )) active = this.active;\n let open = tr.selection || active.some((a)=>a.hasResult() && tr.changes.touchesRange(a.from, a.to)\n ) || !sameResults(active, this.active) ? CompletionDialog.build(active, state, this.id, this.open, conf) : this.open && tr.docChanged ? this.open.map(tr.changes) : this.open;\n if (!open && active.every((a)=>a.state != 1 /* Pending */ \n ) && active.some((a)=>a.hasResult()\n )) active = active.map((a)=>a.hasResult() ? new ActiveSource(a.source, 0 /* Inactive */ ) : a\n );\n for (let effect of tr.effects)if (effect.is(setSelectedEffect)) open = open && open.setSelected(effect.value, this.id);\n return active == this.active && open == this.open ? this : new CompletionState(active, this.id, open);\n }\n get tooltip() {\n return this.open ? this.open.tooltip : null;\n }\n get attrs() {\n return this.open ? this.open.attrs : baseAttrs;\n }\n}\nfunction sameResults(a, b) {\n if (a == b) return true;\n for(let iA = 0, iB = 0;;){\n while(iA < a.length && !a[iA].hasResult)iA++;\n while(iB < b.length && !b[iB].hasResult)iB++;\n let endA = iA == a.length, endB = iB == b.length;\n if (endA || endB) return endA == endB;\n if (a[iA++].result != b[iB++].result) return false;\n }\n}\nconst baseAttrs = {\n \"aria-autocomplete\": \"list\",\n \"aria-expanded\": \"false\"\n};\nfunction makeAttrs(id, selected) {\n return {\n \"aria-autocomplete\": \"list\",\n \"aria-expanded\": \"true\",\n \"aria-activedescendant\": id + \"-\" + selected,\n \"aria-controls\": id\n };\n}\nconst none = [];\nfunction cmpOption(a, b) {\n let dScore = b.match[0] - a.match[0];\n if (dScore) return dScore;\n return a.completion.label.localeCompare(b.completion.label);\n}\nfunction getUserEvent(tr) {\n return tr.isUserEvent(\"input.type\") ? \"input\" : tr.isUserEvent(\"delete.backward\") ? \"delete\" : null;\n}\nclass ActiveSource {\n constructor(source, state, explicitPos = -1){\n this.source = source;\n this.state = state;\n this.explicitPos = explicitPos;\n }\n hasResult() {\n return false;\n }\n update(tr, conf) {\n let event = getUserEvent(tr), value = this;\n if (event) value = value.handleUserEvent(tr, event, conf);\n else if (tr.docChanged) value = value.handleChange(tr);\n else if (tr.selection && value.state != 0 /* Inactive */ ) value = new ActiveSource(value.source, 0 /* Inactive */ );\n for (let effect of tr.effects){\n if (effect.is(startCompletionEffect)) value = new ActiveSource(value.source, 1 /* Pending */ , effect.value ? cur(tr.state) : -1);\n else if (effect.is(closeCompletionEffect)) value = new ActiveSource(value.source, 0 /* Inactive */ );\n else if (effect.is(setActiveEffect)) {\n for (let active of effect.value)if (active.source == value.source) value = active;\n }\n }\n return value;\n }\n handleUserEvent(tr, type, conf) {\n return type == \"delete\" || !conf.activateOnTyping ? this.map(tr.changes) : new ActiveSource(this.source, 1 /* Pending */ );\n }\n handleChange(tr) {\n return tr.changes.touchesRange(cur(tr.startState)) ? new ActiveSource(this.source, 0 /* Inactive */ ) : this.map(tr.changes);\n }\n map(changes) {\n return changes.empty || this.explicitPos < 0 ? this : new ActiveSource(this.source, this.state, changes.mapPos(this.explicitPos));\n }\n}\nclass ActiveResult extends ActiveSource {\n constructor(source, explicitPos, result, from, to, span){\n super(source, 2 /* Result */ , explicitPos);\n this.result = result;\n this.from = from;\n this.to = to;\n this.span = span;\n }\n hasResult() {\n return true;\n }\n handleUserEvent(tr, type, conf) {\n let from = tr.changes.mapPos(this.from), to = tr.changes.mapPos(this.to, 1);\n let pos = cur(tr.state);\n if ((this.explicitPos > -1 ? pos < from : pos <= from) || pos > to) return new ActiveSource(this.source, type == \"input\" && conf.activateOnTyping ? 1 /* Pending */ : 0 /* Inactive */ );\n let explicitPos = this.explicitPos < 0 ? -1 : tr.changes.mapPos(this.explicitPos);\n if (this.span && (from == to || this.span.test(tr.state.sliceDoc(from, to)))) return new ActiveResult(this.source, explicitPos, this.result, from, to, this.span);\n return new ActiveSource(this.source, 1 /* Pending */ , explicitPos);\n }\n handleChange(tr) {\n return tr.changes.touchesRange(this.from, this.to) ? new ActiveSource(this.source, 0 /* Inactive */ ) : this.map(tr.changes);\n }\n map(mapping) {\n return mapping.empty ? this : new ActiveResult(this.source, this.explicitPos < 0 ? -1 : mapping.mapPos(this.explicitPos), this.result, mapping.mapPos(this.from), mapping.mapPos(this.to, 1), this.span);\n }\n}\nconst startCompletionEffect = /*@__PURE__*/ _state.StateEffect.define();\nconst closeCompletionEffect = /*@__PURE__*/ _state.StateEffect.define();\nconst setActiveEffect = /*@__PURE__*/ _state.StateEffect.define({\n map (sources, mapping) {\n return sources.map((s)=>s.map(mapping)\n );\n }\n});\nconst setSelectedEffect = /*@__PURE__*/ _state.StateEffect.define();\nconst completionState = /*@__PURE__*/ _state.StateField.define({\n create () {\n return CompletionState.start();\n },\n update (value, tr) {\n return value.update(tr);\n },\n provide: (f)=>[\n _tooltip.showTooltip.from(f, (val)=>val.tooltip\n ),\n _view.EditorView.contentAttributes.from(f, (state)=>state.attrs\n )\n ]\n});\nconst CompletionInteractMargin = 75;\n/**\nReturns a command that moves the completion selection forward or\nbackward by the given amount.\n*/ function moveCompletionSelection(forward, by = \"option\") {\n return (view)=>{\n let cState = view.state.field(completionState, false);\n if (!cState || !cState.open || Date.now() - cState.open.timestamp < CompletionInteractMargin) return false;\n let step = 1, tooltip;\n if (by == \"page\" && (tooltip = _tooltip.getTooltip(view, cState.open.tooltip))) step = Math.max(2, Math.floor(tooltip.dom.offsetHeight / tooltip.dom.querySelector(\"li\").offsetHeight) - 1);\n let selected = cState.open.selected + step * (forward ? 1 : -1), { length } = cState.open.options;\n if (selected < 0) selected = by == \"page\" ? 0 : length - 1;\n else if (selected >= length) selected = by == \"page\" ? length - 1 : 0;\n view.dispatch({\n effects: setSelectedEffect.of(selected)\n });\n return true;\n };\n}\n/**\nAccept the current completion.\n*/ const acceptCompletion = (view)=>{\n let cState = view.state.field(completionState, false);\n if (view.state.readOnly || !cState || !cState.open || Date.now() - cState.open.timestamp < CompletionInteractMargin) return false;\n applyCompletion(view, cState.open.options[cState.open.selected]);\n return true;\n};\n/**\nExplicitly start autocompletion.\n*/ const startCompletion = (view)=>{\n let cState = view.state.field(completionState, false);\n if (!cState) return false;\n view.dispatch({\n effects: startCompletionEffect.of(true)\n });\n return true;\n};\n/**\nClose the currently active completion.\n*/ const closeCompletion = (view)=>{\n let cState = view.state.field(completionState, false);\n if (!cState || !cState.active.some((a)=>a.state != 0 /* Inactive */ \n )) return false;\n view.dispatch({\n effects: closeCompletionEffect.of(null)\n });\n return true;\n};\nclass RunningQuery {\n constructor(active, context){\n this.active = active;\n this.context = context;\n this.time = Date.now();\n this.updates = [];\n // Note that 'undefined' means 'not done yet', whereas 'null' means\n // 'query returned null'.\n this.done = undefined;\n }\n}\nconst DebounceTime = 50, MaxUpdateCount = 50, MinAbortTime = 1000;\nconst completionPlugin = /*@__PURE__*/ _view.ViewPlugin.fromClass(class {\n constructor(view){\n this.view = view;\n this.debounceUpdate = -1;\n this.running = [];\n this.debounceAccept = -1;\n this.composing = 0 /* None */ ;\n for (let active of view.state.field(completionState).active)if (active.state == 1 /* Pending */ ) this.startQuery(active);\n }\n update(update) {\n let cState = update.state.field(completionState);\n if (!update.selectionSet && !update.docChanged && update.startState.field(completionState) == cState) return;\n let doesReset = update.transactions.some((tr)=>{\n return (tr.selection || tr.docChanged) && !getUserEvent(tr);\n });\n for(let i = 0; i < this.running.length; i++){\n let query = this.running[i];\n if (doesReset || query.updates.length + update.transactions.length > MaxUpdateCount && query.time - Date.now() > MinAbortTime) {\n for (let handler of query.context.abortListeners)try {\n handler();\n } catch (e) {\n _view.logException(this.view.state, e);\n }\n query.context.abortListeners = null;\n this.running.splice(i--, 1);\n } else query.updates.push(...update.transactions);\n }\n if (this.debounceUpdate > -1) clearTimeout(this.debounceUpdate);\n this.debounceUpdate = cState.active.some((a)=>a.state == 1 /* Pending */ && !this.running.some((q)=>q.active.source == a.source\n )\n ) ? setTimeout(()=>this.startUpdate()\n , DebounceTime) : -1;\n if (this.composing != 0 /* None */ ) for (let tr1 of update.transactions){\n if (getUserEvent(tr1) == \"input\") this.composing = 2 /* Changed */ ;\n else if (this.composing == 2 /* Changed */ && tr1.selection) this.composing = 3 /* ChangedAndMoved */ ;\n }\n }\n startUpdate() {\n this.debounceUpdate = -1;\n let { state } = this.view, cState = state.field(completionState);\n for (let active of cState.active)if (active.state == 1 /* Pending */ && !this.running.some((r)=>r.active.source == active.source\n )) this.startQuery(active);\n }\n startQuery(active) {\n let { state } = this.view, pos = cur(state);\n let context = new CompletionContext(state, pos, active.explicitPos == pos);\n let pending = new RunningQuery(active, context);\n this.running.push(pending);\n Promise.resolve(active.source(context)).then((result)=>{\n if (!pending.context.aborted) {\n pending.done = result || null;\n this.scheduleAccept();\n }\n }, (err)=>{\n this.view.dispatch({\n effects: closeCompletionEffect.of(null)\n });\n _view.logException(this.view.state, err);\n });\n }\n scheduleAccept() {\n if (this.running.every((q)=>q.done !== undefined\n )) this.accept();\n else if (this.debounceAccept < 0) this.debounceAccept = setTimeout(()=>this.accept()\n , DebounceTime);\n }\n // For each finished query in this.running, try to create a result\n // or, if appropriate, restart the query.\n accept() {\n var _a;\n if (this.debounceAccept > -1) clearTimeout(this.debounceAccept);\n this.debounceAccept = -1;\n let updated = [];\n let conf = this.view.state.facet(completionConfig);\n for(let i = 0; i < this.running.length; i++){\n let query = this.running[i];\n if (query.done === undefined) continue;\n this.running.splice(i--, 1);\n if (query.done) {\n let active = new ActiveResult(query.active.source, query.active.explicitPos, query.done, query.done.from, (_a = query.done.to) !== null && _a !== void 0 ? _a : cur(query.updates.length ? query.updates[0].startState : this.view.state), query.done.span && query.done.filter !== false ? ensureAnchor(query.done.span, true) : null);\n // Replay the transactions that happened since the start of\n // the request and see if that preserves the result\n for (let tr of query.updates)active = active.update(tr, conf);\n if (active.hasResult()) {\n updated.push(active);\n continue;\n }\n }\n let current = this.view.state.field(completionState).active.find((a)=>a.source == query.active.source\n );\n if (current && current.state == 1 /* Pending */ ) {\n if (query.done == null) {\n // Explicitly failed. Should clear the pending status if it\n // hasn't been re-set in the meantime.\n let active = new ActiveSource(query.active.source, 0 /* Inactive */ );\n for (let tr of query.updates)active = active.update(tr, conf);\n if (active.state != 1 /* Pending */ ) updated.push(active);\n } else // Cleared by subsequent transactions. Restart.\n this.startQuery(current);\n }\n }\n if (updated.length) this.view.dispatch({\n effects: setActiveEffect.of(updated)\n });\n }\n}, {\n eventHandlers: {\n compositionstart () {\n this.composing = 1 /* Started */ ;\n },\n compositionend () {\n if (this.composing == 3 /* ChangedAndMoved */ ) // Safari fires compositionend events synchronously, possibly\n // from inside an update, so dispatch asynchronously to avoid reentrancy\n setTimeout(()=>this.view.dispatch({\n effects: startCompletionEffect.of(false)\n })\n , 20);\n this.composing = 0 /* None */ ;\n }\n }\n});\nconst baseTheme = /*@__PURE__*/ _view.EditorView.baseTheme({\n \".cm-tooltip.cm-tooltip-autocomplete\": {\n \"& > ul\": {\n fontFamily: \"monospace\",\n whiteSpace: \"nowrap\",\n overflow: \"hidden auto\",\n maxWidth_fallback: \"700px\",\n maxWidth: \"min(700px, 95vw)\",\n minWidth: \"250px\",\n maxHeight: \"10em\",\n listStyle: \"none\",\n margin: 0,\n padding: 0,\n \"& > li\": {\n overflowX: \"hidden\",\n textOverflow: \"ellipsis\",\n cursor: \"pointer\",\n padding: \"1px 3px\",\n lineHeight: 1.2\n }\n }\n },\n \"&light .cm-tooltip-autocomplete ul li[aria-selected]\": {\n background: \"#17c\",\n color: \"white\"\n },\n \"&dark .cm-tooltip-autocomplete ul li[aria-selected]\": {\n background: \"#347\",\n color: \"white\"\n },\n \".cm-completionListIncompleteTop:before, .cm-completionListIncompleteBottom:after\": {\n content: '\"\u00b7\u00b7\u00b7\"',\n opacity: 0.5,\n display: \"block\",\n textAlign: \"center\"\n },\n \".cm-tooltip.cm-completionInfo\": {\n position: \"absolute\",\n padding: \"3px 9px\",\n width: \"max-content\",\n maxWidth: \"300px\"\n },\n \".cm-completionInfo.cm-completionInfo-left\": {\n right: \"100%\"\n },\n \".cm-completionInfo.cm-completionInfo-right\": {\n left: \"100%\"\n },\n \"&light .cm-snippetField\": {\n backgroundColor: \"#00000022\"\n },\n \"&dark .cm-snippetField\": {\n backgroundColor: \"#ffffff22\"\n },\n \".cm-snippetFieldPosition\": {\n verticalAlign: \"text-top\",\n width: 0,\n height: \"1.15em\",\n margin: \"0 -0.7px -.7em\",\n borderLeft: \"1.4px dotted #888\"\n },\n \".cm-completionMatchedText\": {\n textDecoration: \"underline\"\n },\n \".cm-completionDetail\": {\n marginLeft: \"0.5em\",\n fontStyle: \"italic\"\n },\n \".cm-completionIcon\": {\n fontSize: \"90%\",\n width: \".8em\",\n display: \"inline-block\",\n textAlign: \"center\",\n paddingRight: \".6em\",\n opacity: \"0.6\"\n },\n \".cm-completionIcon-function, .cm-completionIcon-method\": {\n \"&:after\": {\n content: \"'\u0192'\"\n }\n },\n \".cm-completionIcon-class\": {\n \"&:after\": {\n content: \"'\u25cb'\"\n }\n },\n \".cm-completionIcon-interface\": {\n \"&:after\": {\n content: \"'\u25cc'\"\n }\n },\n \".cm-completionIcon-variable\": {\n \"&:after\": {\n content: \"'\ud835\udc65'\"\n }\n },\n \".cm-completionIcon-constant\": {\n \"&:after\": {\n content: \"'\ud835\udc36'\"\n }\n },\n \".cm-completionIcon-type\": {\n \"&:after\": {\n content: \"'\ud835\udc61'\"\n }\n },\n \".cm-completionIcon-enum\": {\n \"&:after\": {\n content: \"'\u222a'\"\n }\n },\n \".cm-completionIcon-property\": {\n \"&:after\": {\n content: \"'\u25a1'\"\n }\n },\n \".cm-completionIcon-keyword\": {\n \"&:after\": {\n content: \"'\ud83d\udd11\\uFE0E'\"\n } // Disable emoji rendering\n },\n \".cm-completionIcon-namespace\": {\n \"&:after\": {\n content: \"'\u25a2'\"\n }\n },\n \".cm-completionIcon-text\": {\n \"&:after\": {\n content: \"'abc'\",\n fontSize: \"50%\",\n verticalAlign: \"middle\"\n }\n }\n});\nclass FieldPos {\n constructor(field, line, from, to){\n this.field = field;\n this.line = line;\n this.from = from;\n this.to = to;\n }\n}\nclass FieldRange {\n constructor(field, from, to){\n this.field = field;\n this.from = from;\n this.to = to;\n }\n map(changes) {\n return new FieldRange(this.field, changes.mapPos(this.from, -1), changes.mapPos(this.to, 1));\n }\n}\nclass Snippet {\n constructor(lines, fieldPositions){\n this.lines = lines;\n this.fieldPositions = fieldPositions;\n }\n instantiate(state, pos1) {\n let text = [], lineStart = [\n pos1\n ];\n let lineObj = state.doc.lineAt(pos1), baseIndent = /^\\s*/.exec(lineObj.text)[0];\n for (let line of this.lines){\n if (text.length) {\n let indent = baseIndent, tabs = /^\\t*/.exec(line)[0].length;\n for(let i = 0; i < tabs; i++)indent += state.facet(_language.indentUnit);\n lineStart.push(pos1 + indent.length - tabs);\n line = indent + line.slice(tabs);\n }\n text.push(line);\n pos1 += line.length + 1;\n }\n let ranges = this.fieldPositions.map((pos)=>new FieldRange(pos.field, lineStart[pos.line] + pos.from, lineStart[pos.line] + pos.to)\n );\n return {\n text,\n ranges\n };\n }\n static parse(template) {\n let fields = [];\n let lines = [], positions = [], m;\n for (let line of template.split(/\\r\\n?|\\n/)){\n while(m = /[#$]\\{(?:(\\d+)(?::([^}]*))?|([^}]*))\\}/.exec(line)){\n let seq = m[1] ? +m[1] : null, name = m[2] || m[3] || \"\", found = -1;\n for(let i = 0; i < fields.length; i++)if (seq != null ? fields[i].seq == seq : name ? fields[i].name == name : false) found = i;\n if (found < 0) {\n let i = 0;\n while(i < fields.length && (seq == null || fields[i].seq != null && fields[i].seq < seq))i++;\n fields.splice(i, 0, {\n seq,\n name\n });\n found = i;\n for (let pos of positions)if (pos.field >= found) pos.field++;\n }\n positions.push(new FieldPos(found, lines.length, m.index, m.index + name.length));\n line = line.slice(0, m.index) + name + line.slice(m.index + m[0].length);\n }\n lines.push(line);\n }\n return new Snippet(lines, positions);\n }\n}\nlet fieldMarker = /*@__PURE__*/ _view.Decoration.widget({\n widget: /*@__PURE__*/ new class extends _view.WidgetType {\n toDOM() {\n let span = document.createElement(\"span\");\n span.className = \"cm-snippetFieldPosition\";\n return span;\n }\n ignoreEvent() {\n return false;\n }\n }\n});\nlet fieldRange = /*@__PURE__*/ _view.Decoration.mark({\n class: \"cm-snippetField\"\n});\nclass ActiveSnippet {\n constructor(ranges, active){\n this.ranges = ranges;\n this.active = active;\n this.deco = _view.Decoration.set(ranges.map((r)=>(r.from == r.to ? fieldMarker : fieldRange).range(r.from, r.to)\n ));\n }\n map(changes) {\n return new ActiveSnippet(this.ranges.map((r)=>r.map(changes)\n ), this.active);\n }\n selectionInsideField(sel) {\n return sel.ranges.every((range)=>this.ranges.some((r)=>r.field == this.active && r.from <= range.from && r.to >= range.to\n )\n );\n }\n}\nconst setActive = /*@__PURE__*/ _state.StateEffect.define({\n map (value, changes) {\n return value && value.map(changes);\n }\n});\nconst moveToField = /*@__PURE__*/ _state.StateEffect.define();\nconst snippetState = /*@__PURE__*/ _state.StateField.define({\n create () {\n return null;\n },\n update (value, tr) {\n for (let effect of tr.effects){\n if (effect.is(setActive)) return effect.value;\n if (effect.is(moveToField) && value) return new ActiveSnippet(value.ranges, effect.value);\n }\n if (value && tr.docChanged) value = value.map(tr.changes);\n if (value && tr.selection && !value.selectionInsideField(tr.selection)) value = null;\n return value;\n },\n provide: (f)=>_view.EditorView.decorations.from(f, (val)=>val ? val.deco : _view.Decoration.none\n )\n});\nfunction fieldSelection(ranges, field) {\n return _state.EditorSelection.create(ranges.filter((r)=>r.field == field\n ).map((r)=>_state.EditorSelection.range(r.from, r.to)\n ));\n}\n/**\nConvert a snippet template to a function that can apply it.\nSnippets are written using syntax like this:\n\n \"for (let ${index} = 0; ${index} < ${end}; ${index}++) {\\n\\t${}\\n}\"\n\nEach `${}` placeholder (you may also use `#{}`) indicates a field\nthat the user can fill in. Its name, if any, will be the default\ncontent for the field.\n\nWhen the snippet is activated by calling the returned function,\nthe code is inserted at the given position. Newlines in the\ntemplate are indented by the indentation of the start line, plus\none [indent unit](https://codemirror.net/6/docs/ref/#language.indentUnit) per tab character after\nthe newline.\n\nOn activation, (all instances of) the first field are selected.\nThe user can move between fields with Tab and Shift-Tab as long as\nthe fields are active. Moving to the last field or moving the\ncursor out of the current field deactivates the fields.\n\nThe order of fields defaults to textual order, but you can add\nnumbers to placeholders (`${1}` or `${1:defaultText}`) to provide\na custom order.\n*/ function snippet(template) {\n let snippet1 = Snippet.parse(template);\n return (editor, _completion, from, to)=>{\n let { text , ranges } = snippet1.instantiate(editor.state, from);\n let spec = {\n changes: {\n from,\n to,\n insert: _state.Text.of(text)\n }\n };\n if (ranges.length) spec.selection = fieldSelection(ranges, 0);\n if (ranges.length > 1) {\n let active = new ActiveSnippet(ranges, 0);\n let effects = spec.effects = [\n setActive.of(active)\n ];\n if (editor.state.field(snippetState, false) === undefined) effects.push(_state.StateEffect.appendConfig.of([\n snippetState,\n addSnippetKeymap,\n snippetPointerHandler,\n baseTheme\n ]));\n }\n editor.dispatch(editor.state.update(spec));\n };\n}\nfunction moveField(dir) {\n return ({ state , dispatch })=>{\n let active = state.field(snippetState, false);\n if (!active || dir < 0 && active.active == 0) return false;\n let next = active.active + dir, last = dir > 0 && !active.ranges.some((r)=>r.field == next + dir\n );\n dispatch(state.update({\n selection: fieldSelection(active.ranges, next),\n effects: setActive.of(last ? null : new ActiveSnippet(active.ranges, next))\n }));\n return true;\n };\n}\n/**\nA command that clears the active snippet, if any.\n*/ const clearSnippet = ({ state , dispatch })=>{\n let active = state.field(snippetState, false);\n if (!active) return false;\n dispatch(state.update({\n effects: setActive.of(null)\n }));\n return true;\n};\n/**\nMove to the next snippet field, if available.\n*/ const nextSnippetField = /*@__PURE__*/ moveField(1);\n/**\nMove to the previous snippet field, if available.\n*/ const prevSnippetField = /*@__PURE__*/ moveField(-1);\nconst defaultSnippetKeymap = [\n {\n key: \"Tab\",\n run: nextSnippetField,\n shift: prevSnippetField\n },\n {\n key: \"Escape\",\n run: clearSnippet\n }\n];\n/**\nA facet that can be used to configure the key bindings used by\nsnippets. The default binds Tab to\n[`nextSnippetField`](https://codemirror.net/6/docs/ref/#autocomplete.nextSnippetField), Shift-Tab to\n[`prevSnippetField`](https://codemirror.net/6/docs/ref/#autocomplete.prevSnippetField), and Escape\nto [`clearSnippet`](https://codemirror.net/6/docs/ref/#autocomplete.clearSnippet).\n*/ const snippetKeymap = /*@__PURE__*/ _state.Facet.define({\n combine (maps) {\n return maps.length ? maps[0] : defaultSnippetKeymap;\n }\n});\nconst addSnippetKeymap = /*@__PURE__*/ _state.Prec.highest(/*@__PURE__*/ _view.keymap.compute([\n snippetKeymap\n], (state)=>state.facet(snippetKeymap)\n));\n/**\nCreate a completion from a snippet. Returns an object with the\nproperties from `completion`, plus an `apply` function that\napplies the snippet.\n*/ function snippetCompletion(template, completion) {\n return Object.assign(Object.assign({\n }, completion), {\n apply: snippet(template)\n });\n}\nconst snippetPointerHandler = /*@__PURE__*/ _view.EditorView.domEventHandlers({\n mousedown (event, view) {\n let active = view.state.field(snippetState, false), pos;\n if (!active || (pos = view.posAtCoords({\n x: event.clientX,\n y: event.clientY\n })) == null) return false;\n let match = active.ranges.find((r)=>r.from <= pos && r.to >= pos\n );\n if (!match || match.field == active.active) return false;\n view.dispatch({\n selection: fieldSelection(active.ranges, match.field),\n effects: setActive.of(active.ranges.some((r)=>r.field > match.field\n ) ? new ActiveSnippet(active.ranges, match.field) : null)\n });\n return true;\n }\n});\nfunction wordRE(wordChars) {\n let escaped = wordChars.replace(/[\\\\[.+*?(){|^$]/g, \"\\\\$&\");\n try {\n return new RegExp(`[\\\\p{Alphabetic}\\\\p{Number}_${escaped}]+`, \"ug\");\n } catch (_a) {\n return new RegExp(`[\\w${escaped}]`, \"g\");\n }\n}\nfunction mapRE(re, f) {\n return new RegExp(f(re.source), re.unicode ? \"u\" : \"\");\n}\nconst wordCaches = /*@__PURE__*/ Object.create(null);\nfunction wordCache(wordChars) {\n return wordCaches[wordChars] || (wordCaches[wordChars] = new WeakMap);\n}\nfunction storeWords(doc, wordRE1, result, seen, ignoreAt) {\n for(let lines = doc.iterLines(), pos = 0; !lines.next().done;){\n let { value } = lines, m;\n wordRE1.lastIndex = 0;\n while(m = wordRE1.exec(value))if (!seen[m[0]] && pos + m.index != ignoreAt) {\n result.push({\n type: \"text\",\n label: m[0]\n });\n seen[m[0]] = true;\n if (result.length >= 2000 /* MaxList */ ) return;\n }\n pos += value.length + 1;\n }\n}\nfunction collectWords(doc, cache, wordRE2, to, ignoreAt) {\n let big = doc.length >= 1000 /* MinCacheLen */ ;\n let cached = big && cache.get(doc);\n if (cached) return cached;\n let result = [], seen = Object.create(null);\n if (doc.children) {\n let pos = 0;\n for (let ch of doc.children){\n if (ch.length >= 1000 /* MinCacheLen */ ) {\n for (let c of collectWords(ch, cache, wordRE2, to - pos, ignoreAt - pos))if (!seen[c.label]) {\n seen[c.label] = true;\n result.push(c);\n }\n } else storeWords(ch, wordRE2, result, seen, ignoreAt - pos);\n pos += ch.length + 1;\n }\n } else storeWords(doc, wordRE2, result, seen, ignoreAt);\n if (big && result.length < 2000 /* MaxList */ ) cache.set(doc, result);\n return result;\n}\n/**\nA completion source that will scan the document for words (using a\n[character categorizer](https://codemirror.net/6/docs/ref/#state.EditorState.charCategorizer)), and\nreturn those as completions.\n*/ const completeAnyWord = (context)=>{\n let wordChars = context.state.languageDataAt(\"wordChars\", context.pos).join(\"\");\n let re = wordRE(wordChars);\n let token = context.matchBefore(mapRE(re, (s)=>s + \"$\"\n ));\n if (!token && !context.explicit) return null;\n let from = token ? token.from : context.pos;\n let options = collectWords(context.state.doc, wordCache(wordChars), re, 50000 /* Range */ , from);\n return {\n from,\n options,\n span: mapRE(re, (s)=>\"^\" + s\n )\n };\n};\n/**\nReturns an extension that enables autocompletion.\n*/ function autocompletion(config = {\n}) {\n return [\n completionState,\n completionConfig.of(config),\n completionPlugin,\n completionKeymapExt,\n baseTheme\n ];\n}\n/**\nBasic keybindings for autocompletion.\n\n - Ctrl-Space: [`startCompletion`](https://codemirror.net/6/docs/ref/#autocomplete.startCompletion)\n - Escape: [`closeCompletion`](https://codemirror.net/6/docs/ref/#autocomplete.closeCompletion)\n - ArrowDown: [`moveCompletionSelection`](https://codemirror.net/6/docs/ref/#autocomplete.moveCompletionSelection)`(true)`\n - ArrowUp: [`moveCompletionSelection`](https://codemirror.net/6/docs/ref/#autocomplete.moveCompletionSelection)`(false)`\n - PageDown: [`moveCompletionSelection`](https://codemirror.net/6/docs/ref/#autocomplete.moveCompletionSelection)`(true, \"page\")`\n - PageDown: [`moveCompletionSelection`](https://codemirror.net/6/docs/ref/#autocomplete.moveCompletionSelection)`(true, \"page\")`\n - Enter: [`acceptCompletion`](https://codemirror.net/6/docs/ref/#autocomplete.acceptCompletion)\n*/ const completionKeymap = [\n {\n key: \"Ctrl-Space\",\n run: startCompletion\n },\n {\n key: \"Escape\",\n run: closeCompletion\n },\n {\n key: \"ArrowDown\",\n run: /*@__PURE__*/ moveCompletionSelection(true)\n },\n {\n key: \"ArrowUp\",\n run: /*@__PURE__*/ moveCompletionSelection(false)\n },\n {\n key: \"PageDown\",\n run: /*@__PURE__*/ moveCompletionSelection(true, \"page\")\n },\n {\n key: \"PageUp\",\n run: /*@__PURE__*/ moveCompletionSelection(false, \"page\")\n },\n {\n key: \"Enter\",\n run: acceptCompletion\n }\n];\nconst completionKeymapExt = /*@__PURE__*/ _state.Prec.highest(/*@__PURE__*/ _view.keymap.computeN([\n completionConfig\n], (state)=>state.facet(completionConfig).defaultKeymap ? [\n completionKeymap\n ] : []\n));\n/**\nGet the current completion status. When completions are available,\nthis will return `\"active\"`. When completions are pending (in the\nprocess of being queried), this returns `\"pending\"`. Otherwise, it\nreturns `null`.\n*/ function completionStatus(state) {\n let cState = state.field(completionState, false);\n return cState && cState.active.some((a)=>a.state == 1 /* Pending */ \n ) ? \"pending\" : cState && cState.active.some((a)=>a.state != 0 /* Inactive */ \n ) ? \"active\" : null;\n}\n/**\nReturns the available completions as an array.\n*/ function currentCompletions(state) {\n var _a;\n let open = (_a = state.field(completionState, false)) === null || _a === void 0 ? void 0 : _a.open;\n return open ? open.options.map((o)=>o.completion\n ) : [];\n}\n/**\nReturn the currently selected completion, if any.\n*/ function selectedCompletion(state) {\n var _a;\n let open = (_a = state.field(completionState, false)) === null || _a === void 0 ? void 0 : _a.open;\n return open ? open.options[open.selected].completion : null;\n}\n\n},{\"@codemirror/state\":\"e6FBl\",\"@codemirror/view\":\"JuP5Z\",\"@codemirror/tooltip\":\"ky3DW\",\"@codemirror/language\":\"70QHL\",\"@codemirror/text\":\"kn7DT\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"e6FBl\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"Text\", ()=>_text.Text\n);\nparcelHelpers.export(exports, \"Annotation\", ()=>Annotation\n);\nparcelHelpers.export(exports, \"AnnotationType\", ()=>AnnotationType\n);\nparcelHelpers.export(exports, \"ChangeDesc\", ()=>ChangeDesc\n);\nparcelHelpers.export(exports, \"ChangeSet\", ()=>ChangeSet\n);\nparcelHelpers.export(exports, \"CharCategory\", ()=>CharCategory\n);\nparcelHelpers.export(exports, \"Compartment\", ()=>Compartment\n);\nparcelHelpers.export(exports, \"EditorSelection\", ()=>EditorSelection\n);\nparcelHelpers.export(exports, \"EditorState\", ()=>EditorState\n);\nparcelHelpers.export(exports, \"Facet\", ()=>Facet\n);\nparcelHelpers.export(exports, \"MapMode\", ()=>MapMode\n);\nparcelHelpers.export(exports, \"Prec\", ()=>Prec\n);\nparcelHelpers.export(exports, \"SelectionRange\", ()=>SelectionRange\n);\nparcelHelpers.export(exports, \"StateEffect\", ()=>StateEffect\n);\nparcelHelpers.export(exports, \"StateEffectType\", ()=>StateEffectType\n);\nparcelHelpers.export(exports, \"StateField\", ()=>StateField\n);\nparcelHelpers.export(exports, \"Transaction\", ()=>Transaction\n);\nparcelHelpers.export(exports, \"combineConfig\", ()=>combineConfig\n);\nvar _text = require(\"@codemirror/text\");\nconst DefaultSplit = /\\r\\n?|\\n/;\n/**\nDistinguishes different ways in which positions can be mapped.\n*/ var MapMode = /*@__PURE__*/ function(MapMode1) {\n /**\n Map a position to a valid new position, even when its context\n was deleted.\n */ MapMode1[MapMode1[\"Simple\"] = 0] = \"Simple\";\n /**\n Return null if deletion happens across the position.\n */ MapMode1[MapMode1[\"TrackDel\"] = 1] = \"TrackDel\";\n /**\n Return null if the character _before_ the position is deleted.\n */ MapMode1[MapMode1[\"TrackBefore\"] = 2] = \"TrackBefore\";\n /**\n Return null if the character _after_ the position is deleted.\n */ MapMode1[MapMode1[\"TrackAfter\"] = 3] = \"TrackAfter\";\n return MapMode1;\n}(MapMode || (MapMode = {\n}));\n/**\nA change description is a variant of [change set](https://codemirror.net/6/docs/ref/#state.ChangeSet)\nthat doesn't store the inserted text. As such, it can't be\napplied, but is cheaper to store and manipulate.\n*/ class ChangeDesc {\n // Sections are encoded as pairs of integers. The first is the\n // length in the current document, and the second is -1 for\n // unaffected sections, and the length of the replacement content\n // otherwise. So an insertion would be (0, n>0), a deletion (n>0,\n // 0), and a replacement two positive numbers.\n /**\n @internal\n */ constructor(/**\n @internal\n */ sections){\n this.sections = sections;\n }\n /**\n The length of the document before the change.\n */ get length() {\n let result = 0;\n for(let i = 0; i < this.sections.length; i += 2)result += this.sections[i];\n return result;\n }\n /**\n The length of the document after the change.\n */ get newLength() {\n let result = 0;\n for(let i = 0; i < this.sections.length; i += 2){\n let ins = this.sections[i + 1];\n result += ins < 0 ? this.sections[i] : ins;\n }\n return result;\n }\n /**\n False when there are actual changes in this set.\n */ get empty() {\n return this.sections.length == 0 || this.sections.length == 2 && this.sections[1] < 0;\n }\n /**\n Iterate over the unchanged parts left by these changes.\n */ iterGaps(f) {\n for(let i = 0, posA = 0, posB = 0; i < this.sections.length;){\n let len = this.sections[i++], ins = this.sections[i++];\n if (ins < 0) {\n f(posA, posB, len);\n posB += len;\n } else posB += ins;\n posA += len;\n }\n }\n /**\n Iterate over the ranges changed by these changes. (See\n [`ChangeSet.iterChanges`](https://codemirror.net/6/docs/ref/#state.ChangeSet.iterChanges) for a\n variant that also provides you with the inserted text.)\n \n When `individual` is true, adjacent changes (which are kept\n separate for [position mapping](https://codemirror.net/6/docs/ref/#state.ChangeDesc.mapPos)) are\n reported separately.\n */ iterChangedRanges(f, individual = false) {\n iterChanges(this, f, individual);\n }\n /**\n Get a description of the inverted form of these changes.\n */ get invertedDesc() {\n let sections = [];\n for(let i = 0; i < this.sections.length;){\n let len = this.sections[i++], ins = this.sections[i++];\n if (ins < 0) sections.push(len, ins);\n else sections.push(ins, len);\n }\n return new ChangeDesc(sections);\n }\n /**\n Compute the combined effect of applying another set of changes\n after this one. The length of the document after this set should\n match the length before `other`.\n */ composeDesc(other) {\n return this.empty ? other : other.empty ? this : composeSets(this, other);\n }\n /**\n Map this description, which should start with the same document\n as `other`, over another set of changes, so that it can be\n applied after it. When `before` is true, map as if the changes\n in `other` happened before the ones in `this`.\n */ mapDesc(other, before = false) {\n return other.empty ? this : mapSet(this, other, before);\n }\n mapPos(pos, assoc = -1, mode = MapMode.Simple) {\n let posA = 0, posB = 0;\n for(let i = 0; i < this.sections.length;){\n let len = this.sections[i++], ins = this.sections[i++], endA = posA + len;\n if (ins < 0) {\n if (endA > pos) return posB + (pos - posA);\n posB += len;\n } else {\n if (mode != MapMode.Simple && endA >= pos && (mode == MapMode.TrackDel && posA < pos && endA > pos || mode == MapMode.TrackBefore && posA < pos || mode == MapMode.TrackAfter && endA > pos)) return null;\n if (endA > pos || endA == pos && assoc < 0 && !len) return pos == posA || assoc < 0 ? posB : posB + ins;\n posB += ins;\n }\n posA = endA;\n }\n if (pos > posA) throw new RangeError(`Position ${pos} is out of range for changeset of length ${posA}`);\n return posB;\n }\n /**\n Check whether these changes touch a given range. When one of the\n changes entirely covers the range, the string `\"cover\"` is\n returned.\n */ touchesRange(from, to = from) {\n for(let i = 0, pos = 0; i < this.sections.length && pos <= to;){\n let len = this.sections[i++], ins = this.sections[i++], end = pos + len;\n if (ins >= 0 && pos <= to && end >= from) return pos < from && end > to ? \"cover\" : true;\n pos = end;\n }\n return false;\n }\n /**\n @internal\n */ toString() {\n let result = \"\";\n for(let i = 0; i < this.sections.length;){\n let len = this.sections[i++], ins = this.sections[i++];\n result += (result ? \" \" : \"\") + len + (ins >= 0 ? \":\" + ins : \"\");\n }\n return result;\n }\n /**\n Serialize this change desc to a JSON-representable value.\n */ toJSON() {\n return this.sections;\n }\n /**\n Create a change desc from its JSON representation (as produced\n by [`toJSON`](https://codemirror.net/6/docs/ref/#state.ChangeDesc.toJSON).\n */ static fromJSON(json) {\n if (!Array.isArray(json) || json.length % 2 || json.some((a)=>typeof a != \"number\"\n )) throw new RangeError(\"Invalid JSON representation of ChangeDesc\");\n return new ChangeDesc(json);\n }\n}\n/**\nA change set represents a group of modifications to a document. It\nstores the document length, and can only be applied to documents\nwith exactly that length.\n*/ class ChangeSet extends ChangeDesc {\n /**\n @internal\n */ constructor(sections, /**\n @internal\n */ inserted){\n super(sections);\n this.inserted = inserted;\n }\n /**\n Apply the changes to a document, returning the modified\n document.\n */ apply(doc) {\n if (this.length != doc.length) throw new RangeError(\"Applying change set to a document with the wrong length\");\n iterChanges(this, (fromA, toA, fromB, _toB, text)=>doc = doc.replace(fromB, fromB + (toA - fromA), text)\n , false);\n return doc;\n }\n mapDesc(other, before = false) {\n return mapSet(this, other, before, true);\n }\n /**\n Given the document as it existed _before_ the changes, return a\n change set that represents the inverse of this set, which could\n be used to go from the document created by the changes back to\n the document as it existed before the changes.\n */ invert(doc) {\n let sections = this.sections.slice(), inserted = [];\n for(let i = 0, pos = 0; i < sections.length; i += 2){\n let len = sections[i], ins = sections[i + 1];\n if (ins >= 0) {\n sections[i] = ins;\n sections[i + 1] = len;\n let index = i >> 1;\n while(inserted.length < index)inserted.push(_text.Text.empty);\n inserted.push(len ? doc.slice(pos, pos + len) : _text.Text.empty);\n }\n pos += len;\n }\n return new ChangeSet(sections, inserted);\n }\n /**\n Combine two subsequent change sets into a single set. `other`\n must start in the document produced by `this`. If `this` goes\n `docA` \u2192 `docB` and `other` represents `docB` \u2192 `docC`, the\n returned value will represent the change `docA` \u2192 `docC`.\n */ compose(other) {\n return this.empty ? other : other.empty ? this : composeSets(this, other, true);\n }\n /**\n Given another change set starting in the same document, maps this\n change set over the other, producing a new change set that can be\n applied to the document produced by applying `other`. When\n `before` is `true`, order changes as if `this` comes before\n `other`, otherwise (the default) treat `other` as coming first.\n \n Given two changes `A` and `B`, `A.compose(B.map(A))` and\n `B.compose(A.map(B, true))` will produce the same document. This\n provides a basic form of [operational\n transformation](https://en.wikipedia.org/wiki/Operational_transformation),\n and can be used for collaborative editing.\n */ map(other, before = false) {\n return other.empty ? this : mapSet(this, other, before, true);\n }\n /**\n Iterate over the changed ranges in the document, calling `f` for\n each, with the range in the original document (`fromA`-`toA`)\n and the range that replaces it in the new document\n (`fromB`-`toB`).\n \n When `individual` is true, adjacent changes are reported\n separately.\n */ iterChanges(f, individual = false) {\n iterChanges(this, f, individual);\n }\n /**\n Get a [change description](https://codemirror.net/6/docs/ref/#state.ChangeDesc) for this change\n set.\n */ get desc() {\n return new ChangeDesc(this.sections);\n }\n /**\n @internal\n */ filter(ranges) {\n let resultSections = [], resultInserted = [], filteredSections = [];\n let iter = new SectionIter(this);\n done: for(let i = 0, pos = 0;;){\n let next = i == ranges.length ? 1000000000 : ranges[i++];\n while(pos < next || pos == next && iter.len == 0){\n if (iter.done) break done;\n let len = Math.min(iter.len, next - pos);\n addSection(filteredSections, len, -1);\n let ins = iter.ins == -1 ? -1 : iter.off == 0 ? iter.ins : 0;\n addSection(resultSections, len, ins);\n if (ins > 0) addInsert(resultInserted, resultSections, iter.text);\n iter.forward(len);\n pos += len;\n }\n let end = ranges[i++];\n while(pos < end){\n if (iter.done) break done;\n let len = Math.min(iter.len, end - pos);\n addSection(resultSections, len, -1);\n addSection(filteredSections, len, iter.ins == -1 ? -1 : iter.off == 0 ? iter.ins : 0);\n iter.forward(len);\n pos += len;\n }\n }\n return {\n changes: new ChangeSet(resultSections, resultInserted),\n filtered: new ChangeDesc(filteredSections)\n };\n }\n /**\n Serialize this change set to a JSON-representable value.\n */ toJSON() {\n let parts = [];\n for(let i = 0; i < this.sections.length; i += 2){\n let len = this.sections[i], ins = this.sections[i + 1];\n if (ins < 0) parts.push(len);\n else if (ins == 0) parts.push([\n len\n ]);\n else parts.push([\n len\n ].concat(this.inserted[i >> 1].toJSON()));\n }\n return parts;\n }\n /**\n Create a change set for the given changes, for a document of the\n given length, using `lineSep` as line separator.\n */ static of(changes, length, lineSep) {\n let sections = [], inserted = [], pos = 0;\n let total = null;\n function flush(force = false) {\n if (!force && !sections.length) return;\n if (pos < length) addSection(sections, length - pos, -1);\n let set = new ChangeSet(sections, inserted);\n total = total ? total.compose(set.map(total)) : set;\n sections = [];\n inserted = [];\n pos = 0;\n }\n function process(spec) {\n if (Array.isArray(spec)) for (let sub of spec)process(sub);\n else if (spec instanceof ChangeSet) {\n if (spec.length != length) throw new RangeError(`Mismatched change set length (got ${spec.length}, expected ${length})`);\n flush();\n total = total ? total.compose(spec.map(total)) : spec;\n } else {\n let { from , to =from , insert } = spec;\n if (from > to || from < 0 || to > length) throw new RangeError(`Invalid change range ${from} to ${to} (in doc of length ${length})`);\n let insText = !insert ? _text.Text.empty : typeof insert == \"string\" ? _text.Text.of(insert.split(lineSep || DefaultSplit)) : insert;\n let insLen = insText.length;\n if (from == to && insLen == 0) return;\n if (from < pos) flush();\n if (from > pos) addSection(sections, from - pos, -1);\n addSection(sections, to - from, insLen);\n addInsert(inserted, sections, insText);\n pos = to;\n }\n }\n process(changes);\n flush(!total);\n return total;\n }\n /**\n Create an empty changeset of the given length.\n */ static empty(length) {\n return new ChangeSet(length ? [\n length,\n -1\n ] : [], []);\n }\n /**\n Create a changeset from its JSON representation (as produced by\n [`toJSON`](https://codemirror.net/6/docs/ref/#state.ChangeSet.toJSON).\n */ static fromJSON(json) {\n if (!Array.isArray(json)) throw new RangeError(\"Invalid JSON representation of ChangeSet\");\n let sections = [], inserted = [];\n for(let i1 = 0; i1 < json.length; i1++){\n let part = json[i1];\n if (typeof part == \"number\") sections.push(part, -1);\n else if (!Array.isArray(part) || typeof part[0] != \"number\" || part.some((e, i)=>i && typeof e != \"string\"\n )) throw new RangeError(\"Invalid JSON representation of ChangeSet\");\n else if (part.length == 1) sections.push(part[0], 0);\n else {\n while(inserted.length < i1)inserted.push(_text.Text.empty);\n inserted[i1] = _text.Text.of(part.slice(1));\n sections.push(part[0], inserted[i1].length);\n }\n }\n return new ChangeSet(sections, inserted);\n }\n}\nfunction addSection(sections, len, ins, forceJoin = false) {\n if (len == 0 && ins <= 0) return;\n let last = sections.length - 2;\n if (last >= 0 && ins <= 0 && ins == sections[last + 1]) sections[last] += len;\n else if (len == 0 && sections[last] == 0) sections[last + 1] += ins;\n else if (forceJoin) {\n sections[last] += len;\n sections[last + 1] += ins;\n } else sections.push(len, ins);\n}\nfunction addInsert(values, sections, value) {\n if (value.length == 0) return;\n let index = sections.length - 2 >> 1;\n if (index < values.length) values[values.length - 1] = values[values.length - 1].append(value);\n else {\n while(values.length < index)values.push(_text.Text.empty);\n values.push(value);\n }\n}\nfunction iterChanges(desc, f, individual) {\n let inserted = desc.inserted;\n for(let posA = 0, posB = 0, i = 0; i < desc.sections.length;){\n let len = desc.sections[i++], ins = desc.sections[i++];\n if (ins < 0) {\n posA += len;\n posB += len;\n } else {\n let endA = posA, endB = posB, text = _text.Text.empty;\n for(;;){\n endA += len;\n endB += ins;\n if (ins && inserted) text = text.append(inserted[i - 2 >> 1]);\n if (individual || i == desc.sections.length || desc.sections[i + 1] < 0) break;\n len = desc.sections[i++];\n ins = desc.sections[i++];\n }\n f(posA, endA, posB, endB, text);\n posA = endA;\n posB = endB;\n }\n }\n}\nfunction mapSet(setA, setB, before, mkSet = false) {\n let sections = [], insert = mkSet ? [] : null;\n let a = new SectionIter(setA), b = new SectionIter(setB);\n for(let posA = 0, posB = 0;;){\n if (a.ins == -1) {\n posA += a.len;\n a.next();\n } else if (b.ins == -1 && posB < posA) {\n let skip = Math.min(b.len, posA - posB);\n b.forward(skip);\n addSection(sections, skip, -1);\n posB += skip;\n } else if (b.ins >= 0 && (a.done || posB < posA || posB == posA && (b.len < a.len || b.len == a.len && !before))) {\n addSection(sections, b.ins, -1);\n while(posA > posB && !a.done && posA + a.len < posB + b.len){\n posA += a.len;\n a.next();\n }\n posB += b.len;\n b.next();\n } else if (a.ins >= 0) {\n let len = 0, end = posA + a.len;\n for(;;){\n if (b.ins >= 0 && posB > posA && posB + b.len < end) {\n len += b.ins;\n posB += b.len;\n b.next();\n } else if (b.ins == -1 && posB < end) {\n let skip = Math.min(b.len, end - posB);\n len += skip;\n b.forward(skip);\n posB += skip;\n } else break;\n }\n addSection(sections, len, a.ins);\n if (insert) addInsert(insert, sections, a.text);\n posA = end;\n a.next();\n } else if (a.done && b.done) return insert ? new ChangeSet(sections, insert) : new ChangeDesc(sections);\n else throw new Error(\"Mismatched change set lengths\");\n }\n}\nfunction composeSets(setA, setB, mkSet = false) {\n let sections = [];\n let insert = mkSet ? [] : null;\n let a = new SectionIter(setA), b = new SectionIter(setB);\n for(let open = false;;){\n if (a.done && b.done) return insert ? new ChangeSet(sections, insert) : new ChangeDesc(sections);\n else if (a.ins == 0) {\n addSection(sections, a.len, 0, open);\n a.next();\n } else if (b.len == 0 && !b.done) {\n addSection(sections, 0, b.ins, open);\n if (insert) addInsert(insert, sections, b.text);\n b.next();\n } else if (a.done || b.done) throw new Error(\"Mismatched change set lengths\");\n else {\n let len = Math.min(a.len2, b.len), sectionLen = sections.length;\n if (a.ins == -1) {\n let insB = b.ins == -1 ? -1 : b.off ? 0 : b.ins;\n addSection(sections, len, insB, open);\n if (insert && insB) addInsert(insert, sections, b.text);\n } else if (b.ins == -1) {\n addSection(sections, a.off ? 0 : a.len, len, open);\n if (insert) addInsert(insert, sections, a.textBit(len));\n } else {\n addSection(sections, a.off ? 0 : a.len, b.off ? 0 : b.ins, open);\n if (insert && !b.off) addInsert(insert, sections, b.text);\n }\n open = (a.ins > len || b.ins >= 0 && b.len > len) && (open || sections.length > sectionLen);\n a.forward2(len);\n b.forward(len);\n }\n }\n}\nclass SectionIter {\n constructor(set){\n this.set = set;\n this.i = 0;\n this.next();\n }\n next() {\n let { sections } = this.set;\n if (this.i < sections.length) {\n this.len = sections[this.i++];\n this.ins = sections[this.i++];\n } else {\n this.len = 0;\n this.ins = -2;\n }\n this.off = 0;\n }\n get done() {\n return this.ins == -2;\n }\n get len2() {\n return this.ins < 0 ? this.len : this.ins;\n }\n get text() {\n let { inserted } = this.set, index = this.i - 2 >> 1;\n return index >= inserted.length ? _text.Text.empty : inserted[index];\n }\n textBit(len) {\n let { inserted } = this.set, index = this.i - 2 >> 1;\n return index >= inserted.length && !len ? _text.Text.empty : inserted[index].slice(this.off, len == null ? undefined : this.off + len);\n }\n forward(len) {\n if (len == this.len) this.next();\n else {\n this.len -= len;\n this.off += len;\n }\n }\n forward2(len) {\n if (this.ins == -1) this.forward(len);\n else if (len == this.ins) this.next();\n else {\n this.ins -= len;\n this.off += len;\n }\n }\n}\n/**\nA single selection range. When\n[`allowMultipleSelections`](https://codemirror.net/6/docs/ref/#state.EditorState^allowMultipleSelections)\nis enabled, a [selection](https://codemirror.net/6/docs/ref/#state.EditorSelection) may hold\nmultiple ranges. By default, selections hold exactly one range.\n*/ class SelectionRange {\n /**\n @internal\n */ constructor(/**\n The lower boundary of the range.\n */ from, /**\n The upper boundary of the range.\n */ to, flags){\n this.from = from;\n this.to = to;\n this.flags = flags;\n }\n /**\n The anchor of the range\u2014the side that doesn't move when you\n extend it.\n */ get anchor() {\n return this.flags & 16 /* Inverted */ ? this.to : this.from;\n }\n /**\n The head of the range, which is moved when the range is\n [extended](https://codemirror.net/6/docs/ref/#state.SelectionRange.extend).\n */ get head() {\n return this.flags & 16 /* Inverted */ ? this.from : this.to;\n }\n /**\n True when `anchor` and `head` are at the same position.\n */ get empty() {\n return this.from == this.to;\n }\n /**\n If this is a cursor that is explicitly associated with the\n character on one of its sides, this returns the side. -1 means\n the character before its position, 1 the character after, and 0\n means no association.\n */ get assoc() {\n return this.flags & 4 /* AssocBefore */ ? -1 : this.flags & 8 /* AssocAfter */ ? 1 : 0;\n }\n /**\n The bidirectional text level associated with this cursor, if\n any.\n */ get bidiLevel() {\n let level = this.flags & 3 /* BidiLevelMask */ ;\n return level == 3 ? null : level;\n }\n /**\n The goal column (stored vertical offset) associated with a\n cursor. This is used to preserve the vertical position when\n [moving](https://codemirror.net/6/docs/ref/#view.EditorView.moveVertically) across\n lines of different length.\n */ get goalColumn() {\n let value = this.flags >> 5 /* GoalColumnOffset */ ;\n return value == 33554431 /* NoGoalColumn */ ? undefined : value;\n }\n /**\n Map this range through a change, producing a valid range in the\n updated document.\n */ map(change, assoc = -1) {\n let from = change.mapPos(this.from, assoc), to = change.mapPos(this.to, assoc);\n return from == this.from && to == this.to ? this : new SelectionRange(from, to, this.flags);\n }\n /**\n Extend this range to cover at least `from` to `to`.\n */ extend(from, to = from) {\n if (from <= this.anchor && to >= this.anchor) return EditorSelection.range(from, to);\n let head = Math.abs(from - this.anchor) > Math.abs(to - this.anchor) ? from : to;\n return EditorSelection.range(this.anchor, head);\n }\n /**\n Compare this range to another range.\n */ eq(other) {\n return this.anchor == other.anchor && this.head == other.head;\n }\n /**\n Return a JSON-serializable object representing the range.\n */ toJSON() {\n return {\n anchor: this.anchor,\n head: this.head\n };\n }\n /**\n Convert a JSON representation of a range to a `SelectionRange`\n instance.\n */ static fromJSON(json) {\n if (!json || typeof json.anchor != \"number\" || typeof json.head != \"number\") throw new RangeError(\"Invalid JSON representation for SelectionRange\");\n return EditorSelection.range(json.anchor, json.head);\n }\n}\n/**\nAn editor selection holds one or more selection ranges.\n*/ class EditorSelection {\n /**\n @internal\n */ constructor(/**\n The ranges in the selection, sorted by position. Ranges cannot\n overlap (but they may touch, if they aren't empty).\n */ ranges, /**\n The index of the _main_ range in the selection (which is\n usually the range that was added last).\n */ mainIndex = 0){\n this.ranges = ranges;\n this.mainIndex = mainIndex;\n }\n /**\n Map a selection through a change. Used to adjust the selection\n position for changes.\n */ map(change, assoc = -1) {\n if (change.empty) return this;\n return EditorSelection.create(this.ranges.map((r)=>r.map(change, assoc)\n ), this.mainIndex);\n }\n /**\n Compare this selection to another selection.\n */ eq(other) {\n if (this.ranges.length != other.ranges.length || this.mainIndex != other.mainIndex) return false;\n for(let i = 0; i < this.ranges.length; i++)if (!this.ranges[i].eq(other.ranges[i])) return false;\n return true;\n }\n /**\n Get the primary selection range. Usually, you should make sure\n your code applies to _all_ ranges, by using methods like\n [`changeByRange`](https://codemirror.net/6/docs/ref/#state.EditorState.changeByRange).\n */ get main() {\n return this.ranges[this.mainIndex];\n }\n /**\n Make sure the selection only has one range. Returns a selection\n holding only the main range from this selection.\n */ asSingle() {\n return this.ranges.length == 1 ? this : new EditorSelection([\n this.main\n ]);\n }\n /**\n Extend this selection with an extra range.\n */ addRange(range, main = true) {\n return EditorSelection.create([\n range\n ].concat(this.ranges), main ? 0 : this.mainIndex + 1);\n }\n /**\n Replace a given range with another range, and then normalize the\n selection to merge and sort ranges if necessary.\n */ replaceRange(range, which = this.mainIndex) {\n let ranges = this.ranges.slice();\n ranges[which] = range;\n return EditorSelection.create(ranges, this.mainIndex);\n }\n /**\n Convert this selection to an object that can be serialized to\n JSON.\n */ toJSON() {\n return {\n ranges: this.ranges.map((r)=>r.toJSON()\n ),\n main: this.mainIndex\n };\n }\n /**\n Create a selection from a JSON representation.\n */ static fromJSON(json) {\n if (!json || !Array.isArray(json.ranges) || typeof json.main != \"number\" || json.main >= json.ranges.length) throw new RangeError(\"Invalid JSON representation for EditorSelection\");\n return new EditorSelection(json.ranges.map((r)=>SelectionRange.fromJSON(r)\n ), json.main);\n }\n /**\n Create a selection holding a single range.\n */ static single(anchor, head = anchor) {\n return new EditorSelection([\n EditorSelection.range(anchor, head)\n ], 0);\n }\n /**\n Sort and merge the given set of ranges, creating a valid\n selection.\n */ static create(ranges, mainIndex = 0) {\n if (ranges.length == 0) throw new RangeError(\"A selection needs at least one range\");\n for(let pos = 0, i = 0; i < ranges.length; i++){\n let range = ranges[i];\n if (range.empty ? range.from <= pos : range.from < pos) return normalized(ranges.slice(), mainIndex);\n pos = range.to;\n }\n return new EditorSelection(ranges, mainIndex);\n }\n /**\n Create a cursor selection range at the given position. You can\n safely ignore the optional arguments in most situations.\n */ static cursor(pos, assoc = 0, bidiLevel, goalColumn) {\n return new SelectionRange(pos, pos, (assoc == 0 ? 0 : assoc < 0 ? 4 /* AssocBefore */ : 8 /* AssocAfter */ ) | (bidiLevel == null ? 3 : Math.min(2, bidiLevel)) | (goalColumn !== null && goalColumn !== void 0 ? goalColumn : 33554431 /* NoGoalColumn */ ) << 5 /* GoalColumnOffset */ );\n }\n /**\n Create a selection range.\n */ static range(anchor, head, goalColumn) {\n let goal = (goalColumn !== null && goalColumn !== void 0 ? goalColumn : 33554431 /* NoGoalColumn */ ) << 5 /* GoalColumnOffset */ ;\n return head < anchor ? new SelectionRange(head, anchor, 16 /* Inverted */ | goal | 8 /* AssocAfter */ ) : new SelectionRange(anchor, head, goal | (head > anchor ? 4 /* AssocBefore */ : 0));\n }\n}\nfunction normalized(ranges, mainIndex = 0) {\n let main = ranges[mainIndex];\n ranges.sort((a, b)=>a.from - b.from\n );\n mainIndex = ranges.indexOf(main);\n for(let i = 1; i < ranges.length; i++){\n let range = ranges[i], prev = ranges[i - 1];\n if (range.empty ? range.from <= prev.to : range.from < prev.to) {\n let from = prev.from, to = Math.max(range.to, prev.to);\n if (i <= mainIndex) mainIndex--;\n ranges.splice(--i, 2, range.anchor > range.head ? EditorSelection.range(to, from) : EditorSelection.range(from, to));\n }\n }\n return new EditorSelection(ranges, mainIndex);\n}\nfunction checkSelection(selection, docLength) {\n for (let range of selection.ranges)if (range.to > docLength) throw new RangeError(\"Selection points outside of document\");\n}\nlet nextID = 0;\n/**\nA facet is a labeled value that is associated with an editor\nstate. It takes inputs from any number of extensions, and combines\nthose into a single output value.\n\nExamples of facets are the [theme](https://codemirror.net/6/docs/ref/#view.EditorView^theme) styles\nassociated with an editor or the [tab\nsize](https://codemirror.net/6/docs/ref/#state.EditorState^tabSize) (which is reduced to a single\nvalue, using the input with the hightest precedence).\n*/ class Facet {\n constructor(/**\n @internal\n */ combine, /**\n @internal\n */ compareInput, /**\n @internal\n */ compare, isStatic, /**\n @internal\n */ extensions){\n this.combine = combine;\n this.compareInput = compareInput;\n this.compare = compare;\n this.isStatic = isStatic;\n this.extensions = extensions;\n /**\n @internal\n */ this.id = nextID++;\n this.default = combine([]);\n }\n /**\n Define a new facet.\n */ static define(config = {\n }) {\n return new Facet(config.combine || ((a)=>a\n ), config.compareInput || ((a, b)=>a === b\n ), config.compare || (!config.combine ? sameArray : (a, b)=>a === b\n ), !!config.static, config.enables);\n }\n /**\n Returns an extension that adds the given value for this facet.\n */ of(value) {\n return new FacetProvider([], this, 0 /* Static */ , value);\n }\n /**\n Create an extension that computes a value for the facet from a\n state. You must take care to declare the parts of the state that\n this value depends on, since your function is only called again\n for a new state when one of those parts changed.\n \n In most cases, you'll want to use the\n [`provide`](https://codemirror.net/6/docs/ref/#state.StateField^define^config.provide) option when\n defining a field instead.\n */ compute(deps, get) {\n if (this.isStatic) throw new Error(\"Can't compute a static facet\");\n return new FacetProvider(deps, this, 1 /* Single */ , get);\n }\n /**\n Create an extension that computes zero or more values for this\n facet from a state.\n */ computeN(deps, get) {\n if (this.isStatic) throw new Error(\"Can't compute a static facet\");\n return new FacetProvider(deps, this, 2 /* Multi */ , get);\n }\n from(field, get) {\n if (!get) get = (x)=>x\n ;\n return this.compute([\n field\n ], (state)=>get(state.field(field))\n );\n }\n}\nfunction sameArray(a, b) {\n return a == b || a.length == b.length && a.every((e, i)=>e === b[i]\n );\n}\nclass FacetProvider {\n constructor(dependencies, facet, type, value){\n this.dependencies = dependencies;\n this.facet = facet;\n this.type = type;\n this.value = value;\n this.id = nextID++;\n }\n dynamicSlot(addresses) {\n var _a;\n let getter = this.value;\n let compare = this.facet.compareInput;\n let idx = addresses[this.id] >> 1, multi = this.type == 2 /* Multi */ ;\n let depDoc = false, depSel = false, depAddrs = [];\n for (let dep of this.dependencies){\n if (dep == \"doc\") depDoc = true;\n else if (dep == \"selection\") depSel = true;\n else if ((((_a = addresses[dep.id]) !== null && _a !== void 0 ? _a : 1) & 1) == 0) depAddrs.push(addresses[dep.id]);\n }\n return (state, tr)=>{\n let oldVal = state.values[idx];\n if (oldVal === Uninitialized) {\n state.values[idx] = getter(state);\n return 1 /* Changed */ ;\n }\n if (tr) {\n let depChanged = depDoc && tr.docChanged || depSel && (tr.docChanged || tr.selection) || depAddrs.some((addr)=>(ensureAddr(state, addr) & 1 /* Changed */ ) > 0\n );\n if (depChanged) {\n let newVal = getter(state);\n if (multi ? !compareArray(newVal, oldVal, compare) : !compare(newVal, oldVal)) {\n state.values[idx] = newVal;\n return 1 /* Changed */ ;\n }\n }\n }\n return 0;\n };\n }\n}\nfunction compareArray(a, b, compare) {\n if (a.length != b.length) return false;\n for(let i = 0; i < a.length; i++)if (!compare(a[i], b[i])) return false;\n return true;\n}\nfunction dynamicFacetSlot(addresses, facet, providers) {\n let providerAddrs = providers.map((p)=>addresses[p.id]\n );\n let providerTypes = providers.map((p)=>p.type\n );\n let dynamic = providerAddrs.filter((p)=>!(p & 1)\n );\n let idx = addresses[facet.id] >> 1;\n return (state, tr)=>{\n let oldVal = state.values[idx], changed = oldVal === Uninitialized;\n for (let dynAddr of dynamic)if (ensureAddr(state, dynAddr) & 1 /* Changed */ ) changed = true;\n if (!changed) return 0;\n let values = [];\n for(let i = 0; i < providerAddrs.length; i++){\n let value = getAddr(state, providerAddrs[i]);\n if (providerTypes[i] == 2 /* Multi */ ) for (let val of value)values.push(val);\n else values.push(value);\n }\n let value = facet.combine(values);\n if (oldVal !== Uninitialized && facet.compare(value, oldVal)) return 0;\n state.values[idx] = value;\n return 1 /* Changed */ ;\n };\n}\nconst initField = /*@__PURE__*/ Facet.define({\n static: true\n});\n/**\nFields can store additional information in an editor state, and\nkeep it in sync with the rest of the state.\n*/ class StateField {\n constructor(/**\n @internal\n */ id, createF, updateF, compareF, /**\n @internal\n */ spec){\n this.id = id;\n this.createF = createF;\n this.updateF = updateF;\n this.compareF = compareF;\n this.spec = spec;\n /**\n @internal\n */ this.provides = undefined;\n }\n /**\n Define a state field.\n */ static define(config) {\n let field = new StateField(nextID++, config.create, config.update, config.compare || ((a, b)=>a === b\n ), config);\n if (config.provide) field.provides = config.provide(field);\n return field;\n }\n create(state) {\n let init = state.facet(initField).find((i)=>i.field == this\n );\n return ((init === null || init === void 0 ? void 0 : init.create) || this.createF)(state);\n }\n /**\n @internal\n */ slot(addresses) {\n let idx = addresses[this.id] >> 1;\n return (state, tr)=>{\n let oldVal = state.values[idx];\n if (oldVal === Uninitialized) {\n state.values[idx] = this.create(state);\n return 1 /* Changed */ ;\n }\n if (tr) {\n let value = this.updateF(oldVal, tr);\n if (!this.compareF(oldVal, value)) {\n state.values[idx] = value;\n return 1 /* Changed */ ;\n }\n }\n return 0;\n };\n }\n /**\n Returns an extension that enables this field and overrides the\n way it is initialized. Can be useful when you need to provide a\n non-default starting value for the field.\n */ init(create) {\n return [\n this,\n initField.of({\n field: this,\n create\n })\n ];\n }\n /**\n State field instances can be used as\n [`Extension`](https://codemirror.net/6/docs/ref/#state.Extension) values to enable the field in a\n given state.\n */ get extension() {\n return this;\n }\n}\nconst Prec_ = {\n lowest: 4,\n low: 3,\n default: 2,\n high: 1,\n highest: 0\n};\nfunction prec(value) {\n return (ext)=>new PrecExtension(ext, value)\n ;\n}\n/**\nBy default extensions are registered in the order they are found\nin the flattened form of nested array that was provided.\nIndividual extension values can be assigned a precedence to\noverride this. Extensions that do not have a precedence set get\nthe precedence of the nearest parent with a precedence, or\n[`default`](https://codemirror.net/6/docs/ref/#state.Prec.default) if there is no such parent. The\nfinal ordering of extensions is determined by first sorting by\nprecedence and then by order within each precedence.\n*/ const Prec = {\n /**\n The lowest precedence level. Meant for things that should end up\n near the end of the extension order.\n */ lowest: /*@__PURE__*/ prec(Prec_.lowest),\n /**\n A lower-than-default precedence, for extensions.\n */ low: /*@__PURE__*/ prec(Prec_.low),\n /**\n The default precedence, which is also used for extensions\n without an explicit precedence.\n */ default: /*@__PURE__*/ prec(Prec_.default),\n /**\n A higher-than-default precedence, for extensions that should\n come before those with default precedence.\n */ high: /*@__PURE__*/ prec(Prec_.high),\n /**\n The highest precedence level, for extensions that should end up\n near the start of the precedence ordering.\n */ highest: /*@__PURE__*/ prec(Prec_.highest),\n // FIXME Drop these in some future breaking version\n /**\n Backwards-compatible synonym for `Prec.lowest`.\n */ fallback: /*@__PURE__*/ prec(Prec_.lowest),\n /**\n Backwards-compatible synonym for `Prec.high`.\n */ extend: /*@__PURE__*/ prec(Prec_.high),\n /**\n Backwards-compatible synonym for `Prec.highest`.\n */ override: /*@__PURE__*/ prec(Prec_.highest)\n};\nclass PrecExtension {\n constructor(inner, prec1){\n this.inner = inner;\n this.prec = prec1;\n }\n}\n/**\nExtension compartments can be used to make a configuration\ndynamic. By [wrapping](https://codemirror.net/6/docs/ref/#state.Compartment.of) part of your\nconfiguration in a compartment, you can later\n[replace](https://codemirror.net/6/docs/ref/#state.Compartment.reconfigure) that part through a\ntransaction.\n*/ class Compartment {\n /**\n Create an instance of this compartment to add to your [state\n configuration](https://codemirror.net/6/docs/ref/#state.EditorStateConfig.extensions).\n */ of(ext) {\n return new CompartmentInstance(this, ext);\n }\n /**\n Create an [effect](https://codemirror.net/6/docs/ref/#state.TransactionSpec.effects) that\n reconfigures this compartment.\n */ reconfigure(content) {\n return Compartment.reconfigure.of({\n compartment: this,\n extension: content\n });\n }\n /**\n Get the current content of the compartment in the state, or\n `undefined` if it isn't present.\n */ get(state) {\n return state.config.compartments.get(this);\n }\n}\nclass CompartmentInstance {\n constructor(compartment, inner){\n this.compartment = compartment;\n this.inner = inner;\n }\n}\nclass Configuration {\n constructor(base, compartments, dynamicSlots, address, staticValues, facets){\n this.base = base;\n this.compartments = compartments;\n this.dynamicSlots = dynamicSlots;\n this.address = address;\n this.staticValues = staticValues;\n this.facets = facets;\n this.statusTemplate = [];\n while(this.statusTemplate.length < dynamicSlots.length)this.statusTemplate.push(0 /* Unresolved */ );\n }\n staticFacet(facet) {\n let addr = this.address[facet.id];\n return addr == null ? facet.default : this.staticValues[addr >> 1];\n }\n static resolve(base, compartments, oldState) {\n let fields = [];\n let facets = Object.create(null);\n let newCompartments = new Map();\n for (let ext of flatten(base, compartments, newCompartments))if (ext instanceof StateField) fields.push(ext);\n else (facets[ext.facet.id] || (facets[ext.facet.id] = [])).push(ext);\n let address = Object.create(null);\n let staticValues = [];\n let dynamicSlots = [];\n let dynamicValues = [];\n for (let field of fields){\n address[field.id] = dynamicSlots.length << 1;\n dynamicSlots.push((a)=>field.slot(a)\n );\n dynamicValues.push(oldState && oldState.config.address[field.id] != null ? oldState.field(field) : Uninitialized);\n }\n let canReuseCache = new Map;\n let canReuseDep = (dep)=>{\n if (!(dep instanceof Facet)) return true;\n let cached = canReuseCache.get(dep);\n if (cached != null) return cached;\n canReuseCache.set(dep, false);\n if (!oldFacets || !sameArray(oldFacets[dep.id] || [], facets[dep.id] || [])) return;\n for (let input of facets[dep.id] || [])if (!input.dependencies.every(canReuseDep)) return;\n canReuseCache.set(dep, true);\n };\n let oldFacets = oldState === null || oldState === void 0 ? void 0 : oldState.config.facets;\n for(let id in facets){\n let providers = facets[id], facet = providers[0].facet;\n let oldProviders = oldFacets && oldFacets[id] || [];\n let canReuse = sameArray(providers, oldProviders);\n if (providers.every((p)=>p.type == 0 /* Static */ \n )) {\n address[facet.id] = staticValues.length << 1 | 1;\n let value = canReuse ? oldState.facet(facet) : facet.combine(providers.map((p)=>p.value\n )), oldValue;\n if (!canReuse && oldState && facet.compare(value, oldValue = oldState.facet(facet))) value = oldValue;\n staticValues.push(value);\n } else {\n for (let p of providers){\n let canReuseThis = p.dependencies.every(canReuseDep);\n if (!canReuseThis) canReuse = false;\n if (p.type == 0 /* Static */ ) {\n address[p.id] = staticValues.length << 1 | 1;\n staticValues.push(p.value);\n } else {\n address[p.id] = dynamicSlots.length << 1;\n dynamicSlots.push((a)=>p.dynamicSlot(a)\n );\n let oldAddr = oldState && canReuseThis ? oldState.config.address[p.id] : null;\n dynamicValues.push(oldAddr != null ? getAddr(oldState, oldAddr) : Uninitialized);\n }\n }\n address[facet.id] = dynamicSlots.length << 1;\n dynamicSlots.push((a)=>dynamicFacetSlot(a, facet, providers)\n );\n dynamicValues.push(canReuse || oldProviders.length ? oldState.facet(facet) : Uninitialized);\n }\n }\n let dynamic = dynamicSlots.map((f)=>f(address)\n );\n return {\n configuration: new Configuration(base, newCompartments, dynamic, address, staticValues, facets),\n values: dynamicValues\n };\n }\n}\nfunction flatten(extension, compartments, newCompartments) {\n let result = [\n [],\n [],\n [],\n [],\n []\n ];\n let seen = new Map();\n function inner(ext, prec2) {\n let known = seen.get(ext);\n if (known != null) {\n if (known >= prec2) return;\n let found = result[known].indexOf(ext);\n if (found > -1) result[known].splice(found, 1);\n if (ext instanceof CompartmentInstance) newCompartments.delete(ext.compartment);\n }\n seen.set(ext, prec2);\n if (Array.isArray(ext)) for (let e of ext)inner(e, prec2);\n else if (ext instanceof CompartmentInstance) {\n if (newCompartments.has(ext.compartment)) throw new RangeError(`Duplicate use of compartment in extensions`);\n let content = compartments.get(ext.compartment) || ext.inner;\n newCompartments.set(ext.compartment, content);\n inner(content, prec2);\n } else if (ext instanceof PrecExtension) inner(ext.inner, ext.prec);\n else if (ext instanceof StateField) {\n result[prec2].push(ext);\n if (ext.provides) inner(ext.provides, prec2);\n } else if (ext instanceof FacetProvider) {\n result[prec2].push(ext);\n if (ext.facet.extensions) inner(ext.facet.extensions, prec2);\n } else {\n let content = ext.extension;\n if (!content) throw new Error(`Unrecognized extension value in extension set (${ext}). This sometimes happens because multiple instances of @codemirror/state are loaded, breaking instanceof checks.`);\n inner(content, prec2);\n }\n }\n inner(extension, Prec_.default);\n return result.reduce((a, b)=>a.concat(b)\n );\n}\nconst Uninitialized = {\n};\nfunction ensureAddr(state, addr) {\n if (addr & 1) return 2 /* Computed */ ;\n let idx = addr >> 1;\n let status = state.status[idx];\n if (status == 4 /* Computing */ ) throw new Error(\"Cyclic dependency between fields and/or facets\");\n if (status & 2 /* Computed */ ) return status;\n state.status[idx] = 4 /* Computing */ ;\n let changed = state.config.dynamicSlots[idx](state, state.applying);\n return state.status[idx] = 2 /* Computed */ | changed;\n}\nfunction getAddr(state, addr) {\n return addr & 1 ? state.config.staticValues[addr >> 1] : state.values[addr >> 1];\n}\nconst languageData = /*@__PURE__*/ Facet.define();\nconst allowMultipleSelections = /*@__PURE__*/ Facet.define({\n combine: (values)=>values.some((v)=>v\n )\n ,\n static: true\n});\nconst lineSeparator = /*@__PURE__*/ Facet.define({\n combine: (values)=>values.length ? values[0] : undefined\n ,\n static: true\n});\nconst changeFilter = /*@__PURE__*/ Facet.define();\nconst transactionFilter = /*@__PURE__*/ Facet.define();\nconst transactionExtender = /*@__PURE__*/ Facet.define();\nconst readOnly = /*@__PURE__*/ Facet.define({\n combine: (values)=>values.length ? values[0] : false\n});\n/**\nAnnotations are tagged values that are used to add metadata to\ntransactions in an extensible way. They should be used to model\nthings that effect the entire transaction (such as its [time\nstamp](https://codemirror.net/6/docs/ref/#state.Transaction^time) or information about its\n[origin](https://codemirror.net/6/docs/ref/#state.Transaction^userEvent)). For effects that happen\n_alongside_ the other changes made by the transaction, [state\neffects](https://codemirror.net/6/docs/ref/#state.StateEffect) are more appropriate.\n*/ class Annotation {\n /**\n @internal\n */ constructor(/**\n The annotation type.\n */ type, /**\n The value of this annotation.\n */ value){\n this.type = type;\n this.value = value;\n }\n /**\n Define a new type of annotation.\n */ static define() {\n return new AnnotationType();\n }\n}\n/**\nMarker that identifies a type of [annotation](https://codemirror.net/6/docs/ref/#state.Annotation).\n*/ class AnnotationType {\n /**\n Create an instance of this annotation.\n */ of(value) {\n return new Annotation(this, value);\n }\n}\n/**\nRepresentation of a type of state effect. Defined with\n[`StateEffect.define`](https://codemirror.net/6/docs/ref/#state.StateEffect^define).\n*/ class StateEffectType {\n /**\n @internal\n */ constructor(// The `any` types in these function types are there to work\n // around TypeScript issue #37631, where the type guard on\n // `StateEffect.is` mysteriously stops working when these properly\n // have type `Value`.\n /**\n @internal\n */ map){\n this.map = map;\n }\n /**\n Create a [state effect](https://codemirror.net/6/docs/ref/#state.StateEffect) instance of this\n type.\n */ of(value) {\n return new StateEffect(this, value);\n }\n}\n/**\nState effects can be used to represent additional effects\nassociated with a [transaction](https://codemirror.net/6/docs/ref/#state.Transaction.effects). They\nare often useful to model changes to custom [state\nfields](https://codemirror.net/6/docs/ref/#state.StateField), when those changes aren't implicit in\ndocument or selection changes.\n*/ class StateEffect {\n /**\n @internal\n */ constructor(/**\n @internal\n */ type, /**\n The value of this effect.\n */ value){\n this.type = type;\n this.value = value;\n }\n /**\n Map this effect through a position mapping. Will return\n `undefined` when that ends up deleting the effect.\n */ map(mapping) {\n let mapped = this.type.map(this.value, mapping);\n return mapped === undefined ? undefined : mapped == this.value ? this : new StateEffect(this.type, mapped);\n }\n /**\n Tells you whether this effect object is of a given\n [type](https://codemirror.net/6/docs/ref/#state.StateEffectType).\n */ is(type) {\n return this.type == type;\n }\n /**\n Define a new effect type. The type parameter indicates the type\n of values that his effect holds.\n */ static define(spec = {\n }) {\n return new StateEffectType(spec.map || ((v)=>v\n ));\n }\n /**\n Map an array of effects through a change set.\n */ static mapEffects(effects, mapping) {\n if (!effects.length) return effects;\n let result = [];\n for (let effect of effects){\n let mapped = effect.map(mapping);\n if (mapped) result.push(mapped);\n }\n return result;\n }\n}\n/**\nThis effect can be used to reconfigure the root extensions of\nthe editor. Doing this will discard any extensions\n[appended](https://codemirror.net/6/docs/ref/#state.StateEffect^appendConfig), but does not reset\nthe content of [reconfigured](https://codemirror.net/6/docs/ref/#state.Compartment.reconfigure)\ncompartments.\n*/ StateEffect.reconfigure = /*@__PURE__*/ StateEffect.define();\n/**\nAppend extensions to the top-level configuration of the editor.\n*/ StateEffect.appendConfig = /*@__PURE__*/ StateEffect.define();\n/**\nChanges to the editor state are grouped into transactions.\nTypically, a user action creates a single transaction, which may\ncontain any number of document changes, may change the selection,\nor have other effects. Create a transaction by calling\n[`EditorState.update`](https://codemirror.net/6/docs/ref/#state.EditorState.update).\n*/ class Transaction {\n /**\n @internal\n */ constructor(/**\n The state from which the transaction starts.\n */ startState, /**\n The document changes made by this transaction.\n */ changes, /**\n The selection set by this transaction, or undefined if it\n doesn't explicitly set a selection.\n */ selection, /**\n The effects added to the transaction.\n */ effects, /**\n @internal\n */ annotations, /**\n Whether the selection should be scrolled into view after this\n transaction is dispatched.\n */ scrollIntoView){\n this.startState = startState;\n this.changes = changes;\n this.selection = selection;\n this.effects = effects;\n this.annotations = annotations;\n this.scrollIntoView = scrollIntoView;\n /**\n @internal\n */ this._doc = null;\n /**\n @internal\n */ this._state = null;\n if (selection) checkSelection(selection, changes.newLength);\n if (!annotations.some((a)=>a.type == Transaction.time\n )) this.annotations = annotations.concat(Transaction.time.of(Date.now()));\n }\n /**\n The new document produced by the transaction. Contrary to\n [`.state`](https://codemirror.net/6/docs/ref/#state.Transaction.state)`.doc`, accessing this won't\n force the entire new state to be computed right away, so it is\n recommended that [transaction\n filters](https://codemirror.net/6/docs/ref/#state.EditorState^transactionFilter) use this getter\n when they need to look at the new document.\n */ get newDoc() {\n return this._doc || (this._doc = this.changes.apply(this.startState.doc));\n }\n /**\n The new selection produced by the transaction. If\n [`this.selection`](https://codemirror.net/6/docs/ref/#state.Transaction.selection) is undefined,\n this will [map](https://codemirror.net/6/docs/ref/#state.EditorSelection.map) the start state's\n current selection through the changes made by the transaction.\n */ get newSelection() {\n return this.selection || this.startState.selection.map(this.changes);\n }\n /**\n The new state created by the transaction. Computed on demand\n (but retained for subsequent access), so itis recommended not to\n access it in [transaction\n filters](https://codemirror.net/6/docs/ref/#state.EditorState^transactionFilter) when possible.\n */ get state() {\n if (!this._state) this.startState.applyTransaction(this);\n return this._state;\n }\n /**\n Get the value of the given annotation type, if any.\n */ annotation(type) {\n for (let ann of this.annotations)if (ann.type == type) return ann.value;\n return undefined;\n }\n /**\n Indicates whether the transaction changed the document.\n */ get docChanged() {\n return !this.changes.empty;\n }\n /**\n Indicates whether this transaction reconfigures the state\n (through a [configuration compartment](https://codemirror.net/6/docs/ref/#state.Compartment) or\n with a top-level configuration\n [effect](https://codemirror.net/6/docs/ref/#state.StateEffect^reconfigure).\n */ get reconfigured() {\n return this.startState.config != this.state.config;\n }\n /**\n Returns true if the transaction has a [user\n event](https://codemirror.net/6/docs/ref/#state.Transaction^userEvent) annotation that is equal to\n or more specific than `event`. For example, if the transaction\n has `\"select.pointer\"` as user event, `\"select\"` and\n `\"select.pointer\"` will match it.\n */ isUserEvent(event) {\n let e = this.annotation(Transaction.userEvent);\n return !!(e && (e == event || e.length > event.length && e.slice(0, event.length) == event && e[event.length] == \".\"));\n }\n}\n/**\nAnnotation used to store transaction timestamps.\n*/ Transaction.time = /*@__PURE__*/ Annotation.define();\n/**\nAnnotation used to associate a transaction with a user interface\nevent. Holds a string identifying the event, using a\ndot-separated format to support attaching more specific\ninformation. The events used by the core libraries are:\n\n - `\"input\"` when content is entered\n - `\"input.type\"` for typed input\n - `\"input.type.compose\"` for composition\n - `\"input.paste\"` for pasted input\n - `\"input.drop\"` when adding content with drag-and-drop\n - `\"input.complete\"` when autocompleting\n - `\"delete\"` when the user deletes content\n - `\"delete.selection\"` when deleting the selection\n - `\"delete.forward\"` when deleting forward from the selection\n - `\"delete.backward\"` when deleting backward from the selection\n - `\"delete.cut\"` when cutting to the clipboard\n - `\"move\"` when content is moved\n - `\"move.drop\"` when content is moved within the editor through drag-and-drop\n - `\"select\"` when explicitly changing the selection\n - `\"select.pointer\"` when selecting with a mouse or other pointing device\n - `\"undo\"` and `\"redo\"` for history actions\n\nUse [`isUserEvent`](https://codemirror.net/6/docs/ref/#state.Transaction.isUserEvent) to check\nwhether the annotation matches a given event.\n*/ Transaction.userEvent = /*@__PURE__*/ Annotation.define();\n/**\nAnnotation indicating whether a transaction should be added to\nthe undo history or not.\n*/ Transaction.addToHistory = /*@__PURE__*/ Annotation.define();\n/**\nAnnotation indicating (when present and true) that a transaction\nrepresents a change made by some other actor, not the user. This\nis used, for example, to tag other people's changes in\ncollaborative editing.\n*/ Transaction.remote = /*@__PURE__*/ Annotation.define();\nfunction joinRanges(a, b) {\n let result = [];\n for(let iA = 0, iB = 0;;){\n let from, to;\n if (iA < a.length && (iB == b.length || b[iB] >= a[iA])) {\n from = a[iA++];\n to = a[iA++];\n } else if (iB < b.length) {\n from = b[iB++];\n to = b[iB++];\n } else return result;\n if (!result.length || result[result.length - 1] < from) result.push(from, to);\n else if (result[result.length - 1] < to) result[result.length - 1] = to;\n }\n}\nfunction mergeTransaction(a, b, sequential) {\n var _a;\n let mapForA, mapForB, changes;\n if (sequential) {\n mapForA = b.changes;\n mapForB = ChangeSet.empty(b.changes.length);\n changes = a.changes.compose(b.changes);\n } else {\n mapForA = b.changes.map(a.changes);\n mapForB = a.changes.mapDesc(b.changes, true);\n changes = a.changes.compose(mapForA);\n }\n return {\n changes,\n selection: b.selection ? b.selection.map(mapForB) : (_a = a.selection) === null || _a === void 0 ? void 0 : _a.map(mapForA),\n effects: StateEffect.mapEffects(a.effects, mapForA).concat(StateEffect.mapEffects(b.effects, mapForB)),\n annotations: a.annotations.length ? a.annotations.concat(b.annotations) : b.annotations,\n scrollIntoView: a.scrollIntoView || b.scrollIntoView\n };\n}\nfunction resolveTransactionInner(state, spec, docSize) {\n let sel = spec.selection, annotations = asArray(spec.annotations);\n if (spec.userEvent) annotations = annotations.concat(Transaction.userEvent.of(spec.userEvent));\n return {\n changes: spec.changes instanceof ChangeSet ? spec.changes : ChangeSet.of(spec.changes || [], docSize, state.facet(lineSeparator)),\n selection: sel && (sel instanceof EditorSelection ? sel : EditorSelection.single(sel.anchor, sel.head)),\n effects: asArray(spec.effects),\n annotations,\n scrollIntoView: !!spec.scrollIntoView\n };\n}\nfunction resolveTransaction(state, specs, filter) {\n let s = resolveTransactionInner(state, specs.length ? specs[0] : {\n }, state.doc.length);\n if (specs.length && specs[0].filter === false) filter = false;\n for(let i = 1; i < specs.length; i++){\n if (specs[i].filter === false) filter = false;\n let seq = !!specs[i].sequential;\n s = mergeTransaction(s, resolveTransactionInner(state, specs[i], seq ? s.changes.newLength : state.doc.length), seq);\n }\n let tr = new Transaction(state, s.changes, s.selection, s.effects, s.annotations, s.scrollIntoView);\n return extendTransaction(filter ? filterTransaction(tr) : tr);\n}\n// Finish a transaction by applying filters if necessary.\nfunction filterTransaction(tr) {\n let state = tr.startState;\n // Change filters\n let result = true;\n for (let filter of state.facet(changeFilter)){\n let value = filter(tr);\n if (value === false) {\n result = false;\n break;\n }\n if (Array.isArray(value)) result = result === true ? value : joinRanges(result, value);\n }\n if (result !== true) {\n let changes, back;\n if (result === false) {\n back = tr.changes.invertedDesc;\n changes = ChangeSet.empty(state.doc.length);\n } else {\n let filtered = tr.changes.filter(result);\n changes = filtered.changes;\n back = filtered.filtered.invertedDesc;\n }\n tr = new Transaction(state, changes, tr.selection && tr.selection.map(back), StateEffect.mapEffects(tr.effects, back), tr.annotations, tr.scrollIntoView);\n }\n // Transaction filters\n let filters = state.facet(transactionFilter);\n for(let i = filters.length - 1; i >= 0; i--){\n let filtered = filters[i](tr);\n if (filtered instanceof Transaction) tr = filtered;\n else if (Array.isArray(filtered) && filtered.length == 1 && filtered[0] instanceof Transaction) tr = filtered[0];\n else tr = resolveTransaction(state, asArray(filtered), false);\n }\n return tr;\n}\nfunction extendTransaction(tr) {\n let state = tr.startState, extenders = state.facet(transactionExtender), spec = tr;\n for(let i = extenders.length - 1; i >= 0; i--){\n let extension = extenders[i](tr);\n if (extension && Object.keys(extension).length) spec = mergeTransaction(tr, resolveTransactionInner(state, extension, tr.changes.newLength), true);\n }\n return spec == tr ? tr : new Transaction(state, tr.changes, tr.selection, spec.effects, spec.annotations, spec.scrollIntoView);\n}\nconst none = [];\nfunction asArray(value) {\n return value == null ? none : Array.isArray(value) ? value : [\n value\n ];\n}\n/**\nThe categories produced by a [character\ncategorizer](https://codemirror.net/6/docs/ref/#state.EditorState.charCategorizer). These are used\ndo things like selecting by word.\n*/ var CharCategory = /*@__PURE__*/ function(CharCategory1) {\n /**\n Word characters.\n */ CharCategory1[CharCategory1[\"Word\"] = 0] = \"Word\";\n /**\n Whitespace.\n */ CharCategory1[CharCategory1[\"Space\"] = 1] = \"Space\";\n /**\n Anything else.\n */ CharCategory1[CharCategory1[\"Other\"] = 2] = \"Other\";\n return CharCategory1;\n}(CharCategory || (CharCategory = {\n}));\nconst nonASCIISingleCaseWordChar = /[\\u00df\\u0587\\u0590-\\u05f4\\u0600-\\u06ff\\u3040-\\u309f\\u30a0-\\u30ff\\u3400-\\u4db5\\u4e00-\\u9fcc\\uac00-\\ud7af]/;\nlet wordChar;\ntry {\n wordChar = /*@__PURE__*/ new RegExp(\"[\\\\p{Alphabetic}\\\\p{Number}_]\", \"u\");\n} catch (_) {\n}\nfunction hasWordChar(str) {\n if (wordChar) return wordChar.test(str);\n for(let i = 0; i < str.length; i++){\n let ch = str[i];\n if (/\\w/.test(ch) || ch > \"\\x80\" && (ch.toUpperCase() != ch.toLowerCase() || nonASCIISingleCaseWordChar.test(ch))) return true;\n }\n return false;\n}\nfunction makeCategorizer(wordChars) {\n return (char)=>{\n if (!/\\S/.test(char)) return CharCategory.Space;\n if (hasWordChar(char)) return CharCategory.Word;\n for(let i = 0; i < wordChars.length; i++)if (char.indexOf(wordChars[i]) > -1) return CharCategory.Word;\n return CharCategory.Other;\n };\n}\n/**\nThe editor state class is a persistent (immutable) data structure.\nTo update a state, you [create](https://codemirror.net/6/docs/ref/#state.EditorState.update) a\n[transaction](https://codemirror.net/6/docs/ref/#state.Transaction), which produces a _new_ state\ninstance, without modifying the original object.\n\nAs such, _never_ mutate properties of a state directly. That'll\njust break things.\n*/ class EditorState {\n /**\n @internal\n */ constructor(/**\n @internal\n */ config, /**\n The current document.\n */ doc, /**\n The current selection.\n */ selection, /**\n @internal\n */ values, tr = null){\n this.config = config;\n this.doc = doc;\n this.selection = selection;\n this.values = values;\n /**\n @internal\n */ this.applying = null;\n this.status = config.statusTemplate.slice();\n this.applying = tr;\n // Fill in the computed state immediately, so that further queries\n // for it made during the update return this state\n if (tr) tr._state = this;\n for(let i = 0; i < this.config.dynamicSlots.length; i++)ensureAddr(this, i << 1);\n this.applying = null;\n }\n field(field, require = true) {\n let addr = this.config.address[field.id];\n if (addr == null) {\n if (require) throw new RangeError(\"Field is not present in this state\");\n return undefined;\n }\n ensureAddr(this, addr);\n return getAddr(this, addr);\n }\n /**\n Create a [transaction](https://codemirror.net/6/docs/ref/#state.Transaction) that updates this\n state. Any number of [transaction specs](https://codemirror.net/6/docs/ref/#state.TransactionSpec)\n can be passed. Unless\n [`sequential`](https://codemirror.net/6/docs/ref/#state.TransactionSpec.sequential) is set, the\n [changes](https://codemirror.net/6/docs/ref/#state.TransactionSpec.changes) (if any) of each spec\n are assumed to start in the _current_ document (not the document\n produced by previous specs), and its\n [selection](https://codemirror.net/6/docs/ref/#state.TransactionSpec.selection) and\n [effects](https://codemirror.net/6/docs/ref/#state.TransactionSpec.effects) are assumed to refer\n to the document created by its _own_ changes. The resulting\n transaction contains the combined effect of all the different\n specs. For [selection](https://codemirror.net/6/docs/ref/#state.TransactionSpec.selection), later\n specs take precedence over earlier ones.\n */ update(...specs) {\n return resolveTransaction(this, specs, true);\n }\n /**\n @internal\n */ applyTransaction(tr) {\n let conf = this.config, { base , compartments } = conf;\n for (let effect of tr.effects){\n if (effect.is(Compartment.reconfigure)) {\n if (conf) {\n compartments = new Map;\n conf.compartments.forEach((val, key)=>compartments.set(key, val)\n );\n conf = null;\n }\n compartments.set(effect.value.compartment, effect.value.extension);\n } else if (effect.is(StateEffect.reconfigure)) {\n conf = null;\n base = effect.value;\n } else if (effect.is(StateEffect.appendConfig)) {\n conf = null;\n base = asArray(base).concat(effect.value);\n }\n }\n let startValues;\n if (!conf) {\n let resolved = Configuration.resolve(base, compartments, this);\n conf = resolved.configuration;\n let intermediateState = new EditorState(conf, this.doc, this.selection, resolved.values, null);\n startValues = intermediateState.values;\n } else startValues = tr.startState.values.slice();\n new EditorState(conf, tr.newDoc, tr.newSelection, startValues, tr);\n }\n /**\n Create a [transaction spec](https://codemirror.net/6/docs/ref/#state.TransactionSpec) that\n replaces every selection range with the given content.\n */ replaceSelection(text) {\n if (typeof text == \"string\") text = this.toText(text);\n return this.changeByRange((range)=>({\n changes: {\n from: range.from,\n to: range.to,\n insert: text\n },\n range: EditorSelection.cursor(range.from + text.length)\n })\n );\n }\n /**\n Create a set of changes and a new selection by running the given\n function for each range in the active selection. The function\n can return an optional set of changes (in the coordinate space\n of the start document), plus an updated range (in the coordinate\n space of the document produced by the call's own changes). This\n method will merge all the changes and ranges into a single\n changeset and selection, and return it as a [transaction\n spec](https://codemirror.net/6/docs/ref/#state.TransactionSpec), which can be passed to\n [`update`](https://codemirror.net/6/docs/ref/#state.EditorState.update).\n */ changeByRange(f) {\n let sel = this.selection;\n let result1 = f(sel.ranges[0]);\n let changes = this.changes(result1.changes), ranges = [\n result1.range\n ];\n let effects = asArray(result1.effects);\n for(let i = 1; i < sel.ranges.length; i++){\n let result = f(sel.ranges[i]);\n let newChanges = this.changes(result.changes), newMapped = newChanges.map(changes);\n for(let j = 0; j < i; j++)ranges[j] = ranges[j].map(newMapped);\n let mapBy = changes.mapDesc(newChanges, true);\n ranges.push(result.range.map(mapBy));\n changes = changes.compose(newMapped);\n effects = StateEffect.mapEffects(effects, newMapped).concat(StateEffect.mapEffects(asArray(result.effects), mapBy));\n }\n return {\n changes,\n selection: EditorSelection.create(ranges, sel.mainIndex),\n effects\n };\n }\n /**\n Create a [change set](https://codemirror.net/6/docs/ref/#state.ChangeSet) from the given change\n description, taking the state's document length and line\n separator into account.\n */ changes(spec = []) {\n if (spec instanceof ChangeSet) return spec;\n return ChangeSet.of(spec, this.doc.length, this.facet(EditorState.lineSeparator));\n }\n /**\n Using the state's [line\n separator](https://codemirror.net/6/docs/ref/#state.EditorState^lineSeparator), create a\n [`Text`](https://codemirror.net/6/docs/ref/#text.Text) instance from the given string.\n */ toText(string) {\n return _text.Text.of(string.split(this.facet(EditorState.lineSeparator) || DefaultSplit));\n }\n /**\n Return the given range of the document as a string.\n */ sliceDoc(from = 0, to = this.doc.length) {\n return this.doc.sliceString(from, to, this.lineBreak);\n }\n /**\n Get the value of a state [facet](https://codemirror.net/6/docs/ref/#state.Facet).\n */ facet(facet) {\n let addr = this.config.address[facet.id];\n if (addr == null) return facet.default;\n ensureAddr(this, addr);\n return getAddr(this, addr);\n }\n /**\n Convert this state to a JSON-serializable object. When custom\n fields should be serialized, you can pass them in as an object\n mapping property names (in the resulting object, which should\n not use `doc` or `selection`) to fields.\n */ toJSON(fields) {\n let result = {\n doc: this.sliceDoc(),\n selection: this.selection.toJSON()\n };\n if (fields) for(let prop in fields){\n let value = fields[prop];\n if (value instanceof StateField) result[prop] = value.spec.toJSON(this.field(fields[prop]), this);\n }\n return result;\n }\n /**\n Deserialize a state from its JSON representation. When custom\n fields should be deserialized, pass the same object you passed\n to [`toJSON`](https://codemirror.net/6/docs/ref/#state.EditorState.toJSON) when serializing as\n third argument.\n */ static fromJSON(json, config = {\n }, fields) {\n if (!json || typeof json.doc != \"string\") throw new RangeError(\"Invalid JSON representation for EditorState\");\n let fieldInit = [];\n if (fields) for(let prop in fields){\n let field = fields[prop], value = json[prop];\n fieldInit.push(field.init((state)=>field.spec.fromJSON(value, state)\n ));\n }\n return EditorState.create({\n doc: json.doc,\n selection: EditorSelection.fromJSON(json.selection),\n extensions: config.extensions ? fieldInit.concat([\n config.extensions\n ]) : fieldInit\n });\n }\n /**\n Create a new state. You'll usually only need this when\n initializing an editor\u2014updated states are created by applying\n transactions.\n */ static create(config = {\n }) {\n let { configuration , values } = Configuration.resolve(config.extensions || [], new Map);\n let doc = config.doc instanceof _text.Text ? config.doc : _text.Text.of((config.doc || \"\").split(configuration.staticFacet(EditorState.lineSeparator) || DefaultSplit));\n let selection = !config.selection ? EditorSelection.single(0) : config.selection instanceof EditorSelection ? config.selection : EditorSelection.single(config.selection.anchor, config.selection.head);\n checkSelection(selection, doc.length);\n if (!configuration.staticFacet(allowMultipleSelections)) selection = selection.asSingle();\n return new EditorState(configuration, doc, selection, values);\n }\n /**\n The size (in columns) of a tab in the document, determined by\n the [`tabSize`](https://codemirror.net/6/docs/ref/#state.EditorState^tabSize) facet.\n */ get tabSize() {\n return this.facet(EditorState.tabSize);\n }\n /**\n Get the proper [line-break](https://codemirror.net/6/docs/ref/#state.EditorState^lineSeparator)\n string for this state.\n */ get lineBreak() {\n return this.facet(EditorState.lineSeparator) || \"\\n\";\n }\n /**\n Returns true when the editor is\n [configured](https://codemirror.net/6/docs/ref/#state.EditorState^readOnly) to be read-only.\n */ get readOnly() {\n return this.facet(readOnly);\n }\n /**\n Look up a translation for the given phrase (via the\n [`phrases`](https://codemirror.net/6/docs/ref/#state.EditorState^phrases) facet), or return the\n original string if no translation is found.\n */ phrase(phrase) {\n for (let map of this.facet(EditorState.phrases))if (Object.prototype.hasOwnProperty.call(map, phrase)) return map[phrase];\n return phrase;\n }\n /**\n Find the values for a given language data field, provided by the\n the [`languageData`](https://codemirror.net/6/docs/ref/#state.EditorState^languageData) facet.\n */ languageDataAt(name, pos, side = -1) {\n let values = [];\n for (let provider of this.facet(languageData)){\n for (let result of provider(this, pos, side))if (Object.prototype.hasOwnProperty.call(result, name)) values.push(result[name]);\n }\n return values;\n }\n /**\n Return a function that can categorize strings (expected to\n represent a single [grapheme cluster](https://codemirror.net/6/docs/ref/#text.findClusterBreak))\n into one of:\n \n - Word (contains an alphanumeric character or a character\n explicitly listed in the local language's `\"wordChars\"`\n language data, which should be a string)\n - Space (contains only whitespace)\n - Other (anything else)\n */ charCategorizer(at) {\n return makeCategorizer(this.languageDataAt(\"wordChars\", at).join(\"\"));\n }\n /**\n Find the word at the given position, meaning the range\n containing all [word](https://codemirror.net/6/docs/ref/#state.CharCategory.Word) characters\n around it. If no word characters are adjacent to the position,\n this returns null.\n */ wordAt(pos) {\n let { text , from , length } = this.doc.lineAt(pos);\n let cat = this.charCategorizer(pos);\n let start = pos - from, end = pos - from;\n while(start > 0){\n let prev = _text.findClusterBreak(text, start, false);\n if (cat(text.slice(prev, start)) != CharCategory.Word) break;\n start = prev;\n }\n while(end < length){\n let next = _text.findClusterBreak(text, end);\n if (cat(text.slice(end, next)) != CharCategory.Word) break;\n end = next;\n }\n return start == end ? null : EditorSelection.range(start + from, end + from);\n }\n}\n/**\nA facet that, when enabled, causes the editor to allow multiple\nranges to be selected. Be careful though, because by default the\neditor relies on the native DOM selection, which cannot handle\nmultiple selections. An extension like\n[`drawSelection`](https://codemirror.net/6/docs/ref/#view.drawSelection) can be used to make\nsecondary selections visible to the user.\n*/ EditorState.allowMultipleSelections = allowMultipleSelections;\n/**\nConfigures the tab size to use in this state. The first\n(highest-precedence) value of the facet is used. If no value is\ngiven, this defaults to 4.\n*/ EditorState.tabSize = /*@__PURE__*/ Facet.define({\n combine: (values)=>values.length ? values[0] : 4\n});\n/**\nThe line separator to use. By default, any of `\"\\n\"`, `\"\\r\\n\"`\nand `\"\\r\"` is treated as a separator when splitting lines, and\nlines are joined with `\"\\n\"`.\n\nWhen you configure a value here, only that precise separator\nwill be used, allowing you to round-trip documents through the\neditor without normalizing line separators.\n*/ EditorState.lineSeparator = lineSeparator;\n/**\nThis facet controls the value of the\n[`readOnly`](https://codemirror.net/6/docs/ref/#state.EditorState.readOnly) getter, which is\nconsulted by commands and extensions that implement editing\nfunctionality to determine whether they should apply. It\ndefaults to false, but when its highest-precedence value is\n`true`, such functionality disables itself.\n\nNot to be confused with\n[`EditorView.editable`](https://codemirror.net/6/docs/ref/#view.EditorView^editable), which\ncontrols whether the editor's DOM is set to be editable (and\nthus focusable).\n*/ EditorState.readOnly = readOnly;\n/**\nRegisters translation phrases. The\n[`phrase`](https://codemirror.net/6/docs/ref/#state.EditorState.phrase) method will look through\nall objects registered with this facet to find translations for\nits argument.\n*/ EditorState.phrases = /*@__PURE__*/ Facet.define();\n/**\nA facet used to register [language\ndata](https://codemirror.net/6/docs/ref/#state.EditorState.languageDataAt) providers.\n*/ EditorState.languageData = languageData;\n/**\nFacet used to register change filters, which are called for each\ntransaction (unless explicitly\n[disabled](https://codemirror.net/6/docs/ref/#state.TransactionSpec.filter)), and can suppress\npart of the transaction's changes.\n\nSuch a function can return `true` to indicate that it doesn't\nwant to do anything, `false` to completely stop the changes in\nthe transaction, or a set of ranges in which changes should be\nsuppressed. Such ranges are represented as an array of numbers,\nwith each pair of two number indicating the start and end of a\nrange. So for example `[10, 20, 100, 110]` suppresses changes\nbetween 10 and 20, and between 100 and 110.\n*/ EditorState.changeFilter = changeFilter;\n/**\nFacet used to register a hook that gets a chance to update or\nreplace transaction specs before they are applied. This will\nonly be applied for transactions that don't have\n[`filter`](https://codemirror.net/6/docs/ref/#state.TransactionSpec.filter) set to `false`. You\ncan either return a single transaction spec (possibly the input\ntransaction), or an array of specs (which will be combined in\nthe same way as the arguments to\n[`EditorState.update`](https://codemirror.net/6/docs/ref/#state.EditorState.update)).\n\nWhen possible, it is recommended to avoid accessing\n[`Transaction.state`](https://codemirror.net/6/docs/ref/#state.Transaction.state) in a filter,\nsince it will force creation of a state that will then be\ndiscarded again, if the transaction is actually filtered.\n\n(This functionality should be used with care. Indiscriminately\nmodifying transaction is likely to break something or degrade\nthe user experience.)\n*/ EditorState.transactionFilter = transactionFilter;\n/**\nThis is a more limited form of\n[`transactionFilter`](https://codemirror.net/6/docs/ref/#state.EditorState^transactionFilter),\nwhich can only add\n[annotations](https://codemirror.net/6/docs/ref/#state.TransactionSpec.annotations) and\n[effects](https://codemirror.net/6/docs/ref/#state.TransactionSpec.effects). _But_, this type\nof filter runs even the transaction has disabled regular\n[filtering](https://codemirror.net/6/docs/ref/#state.TransactionSpec.filter), making it suitable\nfor effects that don't need to touch the changes or selection,\nbut do want to process every transaction.\n\nExtenders run _after_ filters, when both are applied.\n*/ EditorState.transactionExtender = transactionExtender;\nCompartment.reconfigure = /*@__PURE__*/ StateEffect.define();\n/**\nUtility function for combining behaviors to fill in a config\nobject from an array of provided configs. Will, by default, error\nwhen a field gets two values that aren't `===`-equal, but you can\nprovide combine functions per field to do something else.\n*/ function combineConfig(configs, defaults, combine = {\n}) {\n let result = {\n };\n for (let config of configs)for (let key of Object.keys(config)){\n let value = config[key], current = result[key];\n if (current === undefined) result[key] = value;\n else if (current === value || value === undefined) ; // No conflict\n else if (Object.hasOwnProperty.call(combine, key)) result[key] = combine[key](current, value);\n else throw new Error(\"Config merge conflict for field \" + key);\n }\n for(let key1 in defaults)if (result[key1] === undefined) result[key1] = defaults[key1];\n return result;\n}\n\n},{\"@codemirror/text\":\"kn7DT\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"kn7DT\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"Line\", ()=>Line\n);\nparcelHelpers.export(exports, \"Text\", ()=>Text\n);\nparcelHelpers.export(exports, \"codePointAt\", ()=>codePointAt\n);\nparcelHelpers.export(exports, \"codePointSize\", ()=>codePointSize\n);\nparcelHelpers.export(exports, \"countColumn\", ()=>countColumn\n);\nparcelHelpers.export(exports, \"findClusterBreak\", ()=>findClusterBreak\n);\nparcelHelpers.export(exports, \"findColumn\", ()=>findColumn\n);\nparcelHelpers.export(exports, \"fromCodePoint\", ()=>fromCodePoint\n);\n// Compressed representation of the Grapheme_Cluster_Break=Extend\n// information from\n// http://www.unicode.org/Public/13.0.0/ucd/auxiliary/GraphemeBreakProperty.txt.\n// Each pair of elements represents a range, as an offet from the\n// previous range and a length. Numbers are in base-36, with the empty\n// string being a shorthand for 1.\nlet extend = /*@__PURE__*/ \"lc,34,7n,7,7b,19,,,,2,,2,,,20,b,1c,l,g,,2t,7,2,6,2,2,,4,z,,u,r,2j,b,1m,9,9,,o,4,,9,,3,,5,17,3,3b,f,,w,1j,,,,4,8,4,,3,7,a,2,t,,1m,,,,2,4,8,,9,,a,2,q,,2,2,1l,,4,2,4,2,2,3,3,,u,2,3,,b,2,1l,,4,5,,2,4,,k,2,m,6,,,1m,,,2,,4,8,,7,3,a,2,u,,1n,,,,c,,9,,14,,3,,1l,3,5,3,,4,7,2,b,2,t,,1m,,2,,2,,3,,5,2,7,2,b,2,s,2,1l,2,,,2,4,8,,9,,a,2,t,,20,,4,,2,3,,,8,,29,,2,7,c,8,2q,,2,9,b,6,22,2,r,,,,,,1j,e,,5,,2,5,b,,10,9,,2u,4,,6,,2,2,2,p,2,4,3,g,4,d,,2,2,6,,f,,jj,3,qa,3,t,3,t,2,u,2,1s,2,,7,8,,2,b,9,,19,3,3b,2,y,,3a,3,4,2,9,,6,3,63,2,2,,1m,,,7,,,,,2,8,6,a,2,,1c,h,1r,4,1c,7,,,5,,14,9,c,2,w,4,2,2,,3,1k,,,2,3,,,3,1m,8,2,2,48,3,,d,,7,4,,6,,3,2,5i,1m,,5,ek,,5f,x,2da,3,3x,,2o,w,fe,6,2x,2,n9w,4,,a,w,2,28,2,7k,,3,,4,,p,2,5,,47,2,q,i,d,,12,8,p,b,1a,3,1c,,2,4,2,2,13,,1v,6,2,2,2,2,c,,8,,1b,,1f,,,3,2,2,5,2,,,16,2,8,,6m,,2,,4,,fn4,,kh,g,g,g,a6,2,gt,,6a,,45,5,1ae,3,,2,5,4,14,3,4,,4l,2,fx,4,ar,2,49,b,4w,,1i,f,1k,3,1d,4,2,2,1x,3,10,5,,8,1q,,c,2,1g,9,a,4,2,,2n,3,2,,,2,6,,4g,,3,8,l,2,1l,2,,,,,m,,e,7,3,5,5f,8,2,3,,,n,,29,,2,6,,,2,,,2,,2,6j,,2,4,6,2,,2,r,2,2d,8,2,,,2,2y,,,,2,6,,,2t,3,2,4,,5,77,9,,2,6t,,a,2,,,4,,40,4,2,2,4,,w,a,14,6,2,4,8,,9,6,2,3,1a,d,,2,ba,7,,6,,,2a,m,2,7,,2,,2,3e,6,3,,,2,,7,,,20,2,3,,,,9n,2,f0b,5,1n,7,t4,,1r,4,29,,f5k,2,43q,,,3,4,5,8,8,2,7,u,4,44,3,1iz,1j,4,1e,8,,e,,m,5,,f,11s,7,,h,2,7,,2,,5,79,7,c5,4,15s,7,31,7,240,5,gx7k,2o,3k,6o\".split(\",\").map((s)=>s ? parseInt(s, 36) : 1\n);\n// Convert offsets into absolute values\nfor(let i = 1; i < extend.length; i++)extend[i] += extend[i - 1];\nfunction isExtendingChar(code) {\n for(let i1 = 1; i1 < extend.length; i1 += 2)if (extend[i1] > code) return extend[i1 - 1] <= code;\n return false;\n}\nfunction isRegionalIndicator(code) {\n return code >= 127462 && code <= 127487;\n}\nconst ZWJ = 8205;\n/**\nReturns a next grapheme cluster break _after_ (not equal to)\n`pos`, if `forward` is true, or before otherwise. Returns `pos`\nitself if no further cluster break is available in the string.\nMoves across surrogate pairs, extending characters (when\n`includeExtending` is true), characters joined with zero-width\njoiners, and flag emoji.\n*/ function findClusterBreak(str, pos, forward = true, includeExtending = true) {\n return (forward ? nextClusterBreak : prevClusterBreak)(str, pos, includeExtending);\n}\nfunction nextClusterBreak(str, pos, includeExtending) {\n if (pos == str.length) return pos;\n // If pos is in the middle of a surrogate pair, move to its start\n if (pos && surrogateLow(str.charCodeAt(pos)) && surrogateHigh(str.charCodeAt(pos - 1))) pos--;\n let prev = codePointAt(str, pos);\n pos += codePointSize(prev);\n while(pos < str.length){\n let next = codePointAt(str, pos);\n if (prev == ZWJ || next == ZWJ || includeExtending && isExtendingChar(next)) {\n pos += codePointSize(next);\n prev = next;\n } else if (isRegionalIndicator(next)) {\n let countBefore = 0, i2 = pos - 2;\n while(i2 >= 0 && isRegionalIndicator(codePointAt(str, i2))){\n countBefore++;\n i2 -= 2;\n }\n if (countBefore % 2 == 0) break;\n else pos += 2;\n } else break;\n }\n return pos;\n}\nfunction prevClusterBreak(str, pos, includeExtending) {\n while(pos > 0){\n let found = nextClusterBreak(str, pos - 2, includeExtending);\n if (found < pos) return found;\n pos--;\n }\n return 0;\n}\nfunction surrogateLow(ch) {\n return ch >= 56320 && ch < 57344;\n}\nfunction surrogateHigh(ch) {\n return ch >= 55296 && ch < 56320;\n}\n/**\nFind the code point at the given position in a string (like the\n[`codePointAt`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/codePointAt)\nstring method).\n*/ function codePointAt(str, pos) {\n let code0 = str.charCodeAt(pos);\n if (!surrogateHigh(code0) || pos + 1 == str.length) return code0;\n let code1 = str.charCodeAt(pos + 1);\n if (!surrogateLow(code1)) return code0;\n return (code0 - 55296 << 10) + (code1 - 56320) + 65536;\n}\n/**\nGiven a Unicode codepoint, return the JavaScript string that\nrespresents it (like\n[`String.fromCodePoint`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/fromCodePoint)).\n*/ function fromCodePoint(code) {\n if (code <= 65535) return String.fromCharCode(code);\n code -= 65536;\n return String.fromCharCode((code >> 10) + 55296, (code & 1023) + 56320);\n}\n/**\nThe first character that takes up two positions in a JavaScript\nstring. It is often useful to compare with this after calling\n`codePointAt`, to figure out whether your character takes up 1 or\n2 index positions.\n*/ function codePointSize(code) {\n return code < 65536 ? 1 : 2;\n}\n/**\nCount the column position at the given offset into the string,\ntaking extending characters and tab size into account.\n*/ function countColumn(string, tabSize, to = string.length) {\n let n = 0;\n for(let i3 = 0; i3 < to;)if (string.charCodeAt(i3) == 9) {\n n += tabSize - n % tabSize;\n i3++;\n } else {\n n++;\n i3 = findClusterBreak(string, i3);\n }\n return n;\n}\n/**\nFind the offset that corresponds to the given column position in a\nstring, taking extending characters and tab size into account. By\ndefault, the string length is returned when it is too short to\nreach the column. Pass `strict` true to make it return -1 in that\nsituation.\n*/ function findColumn(string, col, tabSize, strict) {\n for(let i4 = 0, n = 0;;){\n if (n >= col) return i4;\n if (i4 == string.length) break;\n n += string.charCodeAt(i4) == 9 ? tabSize - n % tabSize : 1;\n i4 = findClusterBreak(string, i4);\n }\n return strict === true ? -1 : string.length;\n}\n/**\nThe data structure for documents.\n*/ class Text {\n /**\n @internal\n */ constructor(){\n }\n /**\n Get the line description around the given position.\n */ lineAt(pos) {\n if (pos < 0 || pos > this.length) throw new RangeError(`Invalid position ${pos} in document of length ${this.length}`);\n return this.lineInner(pos, false, 1, 0);\n }\n /**\n Get the description for the given (1-based) line number.\n */ line(n) {\n if (n < 1 || n > this.lines) throw new RangeError(`Invalid line number ${n} in ${this.lines}-line document`);\n return this.lineInner(n, true, 1, 0);\n }\n /**\n Replace a range of the text with the given content.\n */ replace(from, to, text) {\n let parts = [];\n this.decompose(0, from, parts, 2 /* To */ );\n if (text.length) text.decompose(0, text.length, parts, 3 /* To */ );\n this.decompose(to, this.length, parts, 1 /* From */ );\n return TextNode.from(parts, this.length - (to - from) + text.length);\n }\n /**\n Append another document to this one.\n */ append(other) {\n return this.replace(this.length, this.length, other);\n }\n /**\n Retrieve the text between the given points.\n */ slice(from, to = this.length) {\n let parts = [];\n this.decompose(from, to, parts, 0);\n return TextNode.from(parts, to - from);\n }\n /**\n Test whether this text is equal to another instance.\n */ eq(other) {\n if (other == this) return true;\n if (other.length != this.length || other.lines != this.lines) return false;\n let start = this.scanIdentical(other, 1), end = this.length - this.scanIdentical(other, -1);\n let a = new RawTextCursor(this), b = new RawTextCursor(other);\n for(let skip = start, pos = start;;){\n a.next(skip);\n b.next(skip);\n skip = 0;\n if (a.lineBreak != b.lineBreak || a.done != b.done || a.value != b.value) return false;\n pos += a.value.length;\n if (a.done || pos >= end) return true;\n }\n }\n /**\n Iterate over the text. When `dir` is `-1`, iteration happens\n from end to start. This will return lines and the breaks between\n them as separate strings, and for long lines, might split lines\n themselves into multiple chunks as well.\n */ iter(dir = 1) {\n return new RawTextCursor(this, dir);\n }\n /**\n Iterate over a range of the text. When `from` > `to`, the\n iterator will run in reverse.\n */ iterRange(from, to = this.length) {\n return new PartialTextCursor(this, from, to);\n }\n /**\n Return a cursor that iterates over the given range of lines,\n _without_ returning the line breaks between, and yielding empty\n strings for empty lines.\n \n When `from` and `to` are given, they should be 1-based line numbers.\n */ iterLines(from, to) {\n let inner;\n if (from == null) inner = this.iter();\n else {\n if (to == null) to = this.lines + 1;\n let start = this.line(from).from;\n inner = this.iterRange(start, Math.max(start, to == this.lines + 1 ? this.length : to <= 1 ? 0 : this.line(to - 1).to));\n }\n return new LineCursor(inner);\n }\n /**\n @internal\n */ toString() {\n return this.sliceString(0);\n }\n /**\n Convert the document to an array of lines (which can be\n deserialized again via [`Text.of`](https://codemirror.net/6/docs/ref/#text.Text^of)).\n */ toJSON() {\n let lines = [];\n this.flatten(lines);\n return lines;\n }\n /**\n Create a `Text` instance for the given array of lines.\n */ static of(text) {\n if (text.length == 0) throw new RangeError(\"A document must have at least one line\");\n if (text.length == 1 && !text[0]) return Text.empty;\n return text.length <= 32 /* Branch */ ? new TextLeaf(text) : TextNode.from(TextLeaf.split(text, []));\n }\n}\n// Leaves store an array of line strings. There are always line breaks\n// between these strings. Leaves are limited in size and have to be\n// contained in TextNode instances for bigger documents.\nclass TextLeaf extends Text {\n constructor(text, length = textLength(text)){\n super();\n this.text = text;\n this.length = length;\n }\n get lines() {\n return this.text.length;\n }\n get children() {\n return null;\n }\n lineInner(target, isLine, line, offset) {\n for(let i5 = 0;; i5++){\n let string = this.text[i5], end = offset + string.length;\n if ((isLine ? line : end) >= target) return new Line(offset, end, line, string);\n offset = end + 1;\n line++;\n }\n }\n decompose(from, to, target, open) {\n let text = from <= 0 && to >= this.length ? this : new TextLeaf(sliceText(this.text, from, to), Math.min(to, this.length) - Math.max(0, from));\n if (open & 1 /* From */ ) {\n let prev = target.pop();\n let joined = appendText(text.text, prev.text.slice(), 0, text.length);\n if (joined.length <= 32 /* Branch */ ) target.push(new TextLeaf(joined, prev.length + text.length));\n else {\n let mid = joined.length >> 1;\n target.push(new TextLeaf(joined.slice(0, mid)), new TextLeaf(joined.slice(mid)));\n }\n } else target.push(text);\n }\n replace(from, to, text) {\n if (!(text instanceof TextLeaf)) return super.replace(from, to, text);\n let lines = appendText(this.text, appendText(text.text, sliceText(this.text, 0, from)), to);\n let newLen = this.length + text.length - (to - from);\n if (lines.length <= 32 /* Branch */ ) return new TextLeaf(lines, newLen);\n return TextNode.from(TextLeaf.split(lines, []), newLen);\n }\n sliceString(from, to = this.length, lineSep = \"\\n\") {\n let result = \"\";\n for(let pos = 0, i6 = 0; pos <= to && i6 < this.text.length; i6++){\n let line = this.text[i6], end = pos + line.length;\n if (pos > from && i6) result += lineSep;\n if (from < end && to > pos) result += line.slice(Math.max(0, from - pos), to - pos);\n pos = end + 1;\n }\n return result;\n }\n flatten(target) {\n for (let line of this.text)target.push(line);\n }\n scanIdentical() {\n return 0;\n }\n static split(text, target) {\n let part = [], len = -1;\n for (let line of text){\n part.push(line);\n len += line.length + 1;\n if (part.length == 32 /* Branch */ ) {\n target.push(new TextLeaf(part, len));\n part = [];\n len = -1;\n }\n }\n if (len > -1) target.push(new TextLeaf(part, len));\n return target;\n }\n}\n// Nodes provide the tree structure of the `Text` type. They store a\n// number of other nodes or leaves, taking care to balance themselves\n// on changes. There are implied line breaks _between_ the children of\n// a node (but not before the first or after the last child).\nclass TextNode extends Text {\n constructor(children, length){\n super();\n this.children = children;\n this.length = length;\n this.lines = 0;\n for (let child of children)this.lines += child.lines;\n }\n lineInner(target, isLine, line, offset) {\n for(let i7 = 0;; i7++){\n let child = this.children[i7], end = offset + child.length, endLine = line + child.lines - 1;\n if ((isLine ? endLine : end) >= target) return child.lineInner(target, isLine, line, offset);\n offset = end + 1;\n line = endLine + 1;\n }\n }\n decompose(from, to, target, open) {\n for(let i8 = 0, pos = 0; pos <= to && i8 < this.children.length; i8++){\n let child = this.children[i8], end = pos + child.length;\n if (from <= end && to >= pos) {\n let childOpen = open & ((pos <= from ? 1 /* From */ : 0) | (end >= to ? 2 /* To */ : 0));\n if (pos >= from && end <= to && !childOpen) target.push(child);\n else child.decompose(from - pos, to - pos, target, childOpen);\n }\n pos = end + 1;\n }\n }\n replace(from, to, text) {\n if (text.lines < this.lines) for(let i9 = 0, pos = 0; i9 < this.children.length; i9++){\n let child = this.children[i9], end = pos + child.length;\n // Fast path: if the change only affects one child and the\n // child's size remains in the acceptable range, only update\n // that child\n if (from >= pos && to <= end) {\n let updated = child.replace(from - pos, to - pos, text);\n let totalLines = this.lines - child.lines + updated.lines;\n if (updated.lines < totalLines >> 4 && updated.lines > totalLines >> 6) {\n let copy = this.children.slice();\n copy[i9] = updated;\n return new TextNode(copy, this.length - (to - from) + text.length);\n }\n return super.replace(pos, end, updated);\n }\n pos = end + 1;\n }\n return super.replace(from, to, text);\n }\n sliceString(from, to = this.length, lineSep = \"\\n\") {\n let result = \"\";\n for(let i10 = 0, pos = 0; i10 < this.children.length && pos <= to; i10++){\n let child = this.children[i10], end = pos + child.length;\n if (pos > from && i10) result += lineSep;\n if (from < end && to > pos) result += child.sliceString(from - pos, to - pos, lineSep);\n pos = end + 1;\n }\n return result;\n }\n flatten(target) {\n for (let child of this.children)child.flatten(target);\n }\n scanIdentical(other, dir) {\n if (!(other instanceof TextNode)) return 0;\n let length = 0;\n let [iA, iB, eA, eB] = dir > 0 ? [\n 0,\n 0,\n this.children.length,\n other.children.length\n ] : [\n this.children.length - 1,\n other.children.length - 1,\n -1,\n -1\n ];\n for(;; iA += dir, iB += dir){\n if (iA == eA || iB == eB) return length;\n let chA = this.children[iA], chB = other.children[iB];\n if (chA != chB) return length + chA.scanIdentical(chB, dir);\n length += chA.length + 1;\n }\n }\n static from(children, length = children.reduce((l, ch)=>l + ch.length + 1\n , -1)) {\n let lines = 0;\n for (let ch of children)lines += ch.lines;\n if (lines < 32 /* Branch */ ) {\n let flat = [];\n for (let ch of children)ch.flatten(flat);\n return new TextLeaf(flat, length);\n }\n let chunk = Math.max(32 /* Branch */ , lines >> 5 /* BranchShift */ ), maxChunk = chunk << 1, minChunk = chunk >> 1;\n let chunked = [], currentLines = 0, currentLen = -1, currentChunk = [];\n function add(child) {\n let last;\n if (child.lines > maxChunk && child instanceof TextNode) for (let node of child.children)add(node);\n else if (child.lines > minChunk && (currentLines > minChunk || !currentLines)) {\n flush();\n chunked.push(child);\n } else if (child instanceof TextLeaf && currentLines && (last = currentChunk[currentChunk.length - 1]) instanceof TextLeaf && child.lines + last.lines <= 32 /* Branch */ ) {\n currentLines += child.lines;\n currentLen += child.length + 1;\n currentChunk[currentChunk.length - 1] = new TextLeaf(last.text.concat(child.text), last.length + 1 + child.length);\n } else {\n if (currentLines + child.lines > chunk) flush();\n currentLines += child.lines;\n currentLen += child.length + 1;\n currentChunk.push(child);\n }\n }\n function flush() {\n if (currentLines == 0) return;\n chunked.push(currentChunk.length == 1 ? currentChunk[0] : TextNode.from(currentChunk, currentLen));\n currentLen = -1;\n currentLines = currentChunk.length = 0;\n }\n for (let child1 of children)add(child1);\n flush();\n return chunked.length == 1 ? chunked[0] : new TextNode(chunked, length);\n }\n}\nText.empty = /*@__PURE__*/ new TextLeaf([\n \"\"\n], 0);\nfunction textLength(text) {\n let length = -1;\n for (let line of text)length += line.length + 1;\n return length;\n}\nfunction appendText(text, target, from = 0, to = 1000000000) {\n for(let pos = 0, i11 = 0, first = true; i11 < text.length && pos <= to; i11++){\n let line = text[i11], end = pos + line.length;\n if (end >= from) {\n if (end > to) line = line.slice(0, to - pos);\n if (pos < from) line = line.slice(from - pos);\n if (first) {\n target[target.length - 1] += line;\n first = false;\n } else target.push(line);\n }\n pos = end + 1;\n }\n return target;\n}\nfunction sliceText(text, from, to) {\n return appendText(text, [\n \"\"\n ], from, to);\n}\nclass RawTextCursor {\n constructor(text, dir = 1){\n this.dir = dir;\n this.done = false;\n this.lineBreak = false;\n this.value = \"\";\n this.nodes = [\n text\n ];\n this.offsets = [\n dir > 0 ? 1 : (text instanceof TextLeaf ? text.text.length : text.children.length) << 1\n ];\n }\n nextInner(skip, dir) {\n this.done = this.lineBreak = false;\n for(;;){\n let last = this.nodes.length - 1;\n let top = this.nodes[last], offsetValue = this.offsets[last], offset = offsetValue >> 1;\n let size = top instanceof TextLeaf ? top.text.length : top.children.length;\n if (offset == (dir > 0 ? size : 0)) {\n if (last == 0) {\n this.done = true;\n this.value = \"\";\n return this;\n }\n if (dir > 0) this.offsets[last - 1]++;\n this.nodes.pop();\n this.offsets.pop();\n } else if ((offsetValue & 1) == (dir > 0 ? 0 : 1)) {\n this.offsets[last] += dir;\n if (skip == 0) {\n this.lineBreak = true;\n this.value = \"\\n\";\n return this;\n }\n skip--;\n } else if (top instanceof TextLeaf) {\n // Move to the next string\n let next = top.text[offset + (dir < 0 ? -1 : 0)];\n this.offsets[last] += dir;\n if (next.length > Math.max(0, skip)) {\n this.value = skip == 0 ? next : dir > 0 ? next.slice(skip) : next.slice(0, next.length - skip);\n return this;\n }\n skip -= next.length;\n } else {\n let next = top.children[offset + (dir < 0 ? -1 : 0)];\n if (skip > next.length) {\n skip -= next.length;\n this.offsets[last] += dir;\n } else {\n if (dir < 0) this.offsets[last]--;\n this.nodes.push(next);\n this.offsets.push(dir > 0 ? 1 : (next instanceof TextLeaf ? next.text.length : next.children.length) << 1);\n }\n }\n }\n }\n next(skip = 0) {\n if (skip < 0) {\n this.nextInner(-skip, -this.dir);\n skip = this.value.length;\n }\n return this.nextInner(skip, this.dir);\n }\n}\nclass PartialTextCursor {\n constructor(text, start, end){\n this.value = \"\";\n this.done = false;\n this.cursor = new RawTextCursor(text, start > end ? -1 : 1);\n this.pos = start > end ? text.length : 0;\n this.from = Math.min(start, end);\n this.to = Math.max(start, end);\n }\n nextInner(skip, dir) {\n if (dir < 0 ? this.pos <= this.from : this.pos >= this.to) {\n this.value = \"\";\n this.done = true;\n return this;\n }\n skip += Math.max(0, dir < 0 ? this.pos - this.to : this.from - this.pos);\n let limit = dir < 0 ? this.pos - this.from : this.to - this.pos;\n if (skip > limit) skip = limit;\n limit -= skip;\n let { value } = this.cursor.next(skip);\n this.pos += (value.length + skip) * dir;\n this.value = value.length <= limit ? value : dir < 0 ? value.slice(value.length - limit) : value.slice(0, limit);\n this.done = !this.value;\n return this;\n }\n next(skip = 0) {\n if (skip < 0) skip = Math.max(skip, this.from - this.pos);\n else if (skip > 0) skip = Math.min(skip, this.to - this.pos);\n return this.nextInner(skip, this.cursor.dir);\n }\n get lineBreak() {\n return this.cursor.lineBreak && this.value != \"\";\n }\n}\nclass LineCursor {\n constructor(inner){\n this.inner = inner;\n this.afterBreak = true;\n this.value = \"\";\n this.done = false;\n }\n next(skip = 0) {\n let { done , lineBreak , value } = this.inner.next(skip);\n if (done) {\n this.done = true;\n this.value = \"\";\n } else if (lineBreak) {\n if (this.afterBreak) this.value = \"\";\n else {\n this.afterBreak = true;\n this.next();\n }\n } else {\n this.value = value;\n this.afterBreak = false;\n }\n return this;\n }\n get lineBreak() {\n return false;\n }\n}\nif (typeof Symbol != \"undefined\") {\n Text.prototype[Symbol.iterator] = function() {\n return this.iter();\n };\n RawTextCursor.prototype[Symbol.iterator] = PartialTextCursor.prototype[Symbol.iterator] = LineCursor.prototype[Symbol.iterator] = function() {\n return this;\n };\n}\n/**\nThis type describes a line in the document. It is created\non-demand when lines are [queried](https://codemirror.net/6/docs/ref/#text.Text.lineAt).\n*/ class Line {\n /**\n @internal\n */ constructor(/**\n The position of the start of the line.\n */ from, /**\n The position at the end of the line (_before_ the line break,\n or at the end of document for the last line).\n */ to, /**\n This line's line number (1-based).\n */ number, /**\n The line's content.\n */ text){\n this.from = from;\n this.to = to;\n this.number = number;\n this.text = text;\n }\n /**\n The length of the line (not including any line break after it).\n */ get length() {\n return this.to - this.from;\n }\n}\n\n},{\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"gkKU3\":[function(require,module,exports) {\nexports.interopDefault = function(a) {\n return a && a.__esModule ? a : {\n default: a\n };\n};\nexports.defineInteropFlag = function(a) {\n Object.defineProperty(a, '__esModule', {\n value: true\n });\n};\nexports.exportAll = function(source, dest) {\n Object.keys(source).forEach(function(key) {\n if (key === 'default' || key === '__esModule' || dest.hasOwnProperty(key)) return;\n Object.defineProperty(dest, key, {\n enumerable: true,\n get: function() {\n return source[key];\n }\n });\n });\n return dest;\n};\nexports.export = function(dest, destName, get) {\n Object.defineProperty(dest, destName, {\n enumerable: true,\n get: get\n });\n};\n\n},{}],\"JuP5Z\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"Range\", ()=>_rangeset.Range\n);\nparcelHelpers.export(exports, \"BidiSpan\", ()=>BidiSpan\n);\nparcelHelpers.export(exports, \"BlockInfo\", ()=>BlockInfo\n);\nparcelHelpers.export(exports, \"BlockType\", ()=>BlockType\n);\nparcelHelpers.export(exports, \"Decoration\", ()=>Decoration\n);\nparcelHelpers.export(exports, \"Direction\", ()=>Direction\n);\nparcelHelpers.export(exports, \"EditorView\", ()=>EditorView\n);\nparcelHelpers.export(exports, \"MatchDecorator\", ()=>MatchDecorator\n);\nparcelHelpers.export(exports, \"PluginField\", ()=>PluginField\n);\nparcelHelpers.export(exports, \"PluginFieldProvider\", ()=>PluginFieldProvider\n);\nparcelHelpers.export(exports, \"ViewPlugin\", ()=>ViewPlugin\n);\nparcelHelpers.export(exports, \"ViewUpdate\", ()=>ViewUpdate\n);\nparcelHelpers.export(exports, \"WidgetType\", ()=>WidgetType\n);\nparcelHelpers.export(exports, \"__test\", ()=>__test\n);\nparcelHelpers.export(exports, \"drawSelection\", ()=>drawSelection\n);\nparcelHelpers.export(exports, \"dropCursor\", ()=>dropCursor\n);\nparcelHelpers.export(exports, \"highlightActiveLine\", ()=>highlightActiveLine\n);\nparcelHelpers.export(exports, \"highlightSpecialChars\", ()=>highlightSpecialChars\n);\nparcelHelpers.export(exports, \"keymap\", ()=>keymap\n);\nparcelHelpers.export(exports, \"logException\", ()=>logException\n);\nparcelHelpers.export(exports, \"placeholder\", ()=>placeholder\n);\nparcelHelpers.export(exports, \"runScopeHandlers\", ()=>runScopeHandlers\n);\nparcelHelpers.export(exports, \"scrollPastEnd\", ()=>scrollPastEnd\n);\nvar _state = require(\"@codemirror/state\");\nvar _styleMod = require(\"style-mod\");\nvar _rangeset = require(\"@codemirror/rangeset\");\nvar _text = require(\"@codemirror/text\");\nvar _w3CKeyname = require(\"w3c-keyname\");\nfunction getSelection(root) {\n let target;\n // Browsers differ on whether shadow roots have a getSelection\n // method. If it exists, use that, otherwise, call it on the\n // document.\n if (root.nodeType == 11) target = root.getSelection ? root : root.ownerDocument;\n else target = root;\n return target.getSelection();\n}\nfunction contains(dom, node) {\n return node ? dom.contains(node.nodeType != 1 ? node.parentNode : node) : false;\n}\nfunction deepActiveElement() {\n let elt = document.activeElement;\n while(elt && elt.shadowRoot)elt = elt.shadowRoot.activeElement;\n return elt;\n}\nfunction hasSelection(dom, selection) {\n if (!selection.anchorNode) return false;\n try {\n // Firefox will raise 'permission denied' errors when accessing\n // properties of `sel.anchorNode` when it's in a generated CSS\n // element.\n return contains(dom, selection.anchorNode);\n } catch (_) {\n return false;\n }\n}\nfunction clientRectsFor(dom) {\n if (dom.nodeType == 3) return textRange(dom, 0, dom.nodeValue.length).getClientRects();\n else if (dom.nodeType == 1) return dom.getClientRects();\n else return [];\n}\n// Scans forward and backward through DOM positions equivalent to the\n// given one to see if the two are in the same place (i.e. after a\n// text node vs at the end of that text node)\nfunction isEquivalentPosition(node, off, targetNode, targetOff) {\n return targetNode ? scanFor(node, off, targetNode, targetOff, -1) || scanFor(node, off, targetNode, targetOff, 1) : false;\n}\nfunction domIndex(node) {\n for(var index = 0;; index++){\n node = node.previousSibling;\n if (!node) return index;\n }\n}\nfunction scanFor(node, off, targetNode, targetOff, dir) {\n for(;;){\n if (node == targetNode && off == targetOff) return true;\n if (off == (dir < 0 ? 0 : maxOffset(node))) {\n if (node.nodeName == \"DIV\") return false;\n let parent = node.parentNode;\n if (!parent || parent.nodeType != 1) return false;\n off = domIndex(node) + (dir < 0 ? 0 : 1);\n node = parent;\n } else if (node.nodeType == 1) {\n node = node.childNodes[off + (dir < 0 ? -1 : 0)];\n if (node.nodeType == 1 && node.contentEditable == \"false\") return false;\n off = dir < 0 ? maxOffset(node) : 0;\n } else return false;\n }\n}\nfunction maxOffset(node) {\n return node.nodeType == 3 ? node.nodeValue.length : node.childNodes.length;\n}\nconst Rect0 = {\n left: 0,\n right: 0,\n top: 0,\n bottom: 0\n};\nfunction flattenRect(rect, left) {\n let x = left ? rect.left : rect.right;\n return {\n left: x,\n right: x,\n top: rect.top,\n bottom: rect.bottom\n };\n}\nfunction windowRect(win) {\n return {\n left: 0,\n right: win.innerWidth,\n top: 0,\n bottom: win.innerHeight\n };\n}\nfunction scrollRectIntoView(dom, rect, side, x, y, xMargin, yMargin, ltr) {\n let doc1 = dom.ownerDocument, win = doc1.defaultView;\n for(let cur = dom; cur;){\n if (cur.nodeType == 1) {\n let bounding, top = cur == doc1.body;\n if (top) bounding = windowRect(win);\n else {\n if (cur.scrollHeight <= cur.clientHeight && cur.scrollWidth <= cur.clientWidth) {\n cur = cur.parentNode;\n continue;\n }\n let rect = cur.getBoundingClientRect();\n // Make sure scrollbar width isn't included in the rectangle\n bounding = {\n left: rect.left,\n right: rect.left + cur.clientWidth,\n top: rect.top,\n bottom: rect.top + cur.clientHeight\n };\n }\n let moveX = 0, moveY = 0;\n if (y == \"nearest\") {\n if (rect.top < bounding.top) {\n moveY = -(bounding.top - rect.top + yMargin);\n if (side > 0 && rect.bottom > bounding.bottom + moveY) moveY = rect.bottom - bounding.bottom + moveY + yMargin;\n } else if (rect.bottom > bounding.bottom) {\n moveY = rect.bottom - bounding.bottom + yMargin;\n if (side < 0 && rect.top - moveY < bounding.top) moveY = -(bounding.top + moveY - rect.top + yMargin);\n }\n } else {\n let rectHeight = rect.bottom - rect.top, boundingHeight = bounding.bottom - bounding.top;\n let targetTop = y == \"center\" && rectHeight <= boundingHeight ? rect.top + rectHeight / 2 - boundingHeight / 2 : y == \"start\" || y == \"center\" && side < 0 ? rect.top - yMargin : rect.bottom - boundingHeight + yMargin;\n moveY = targetTop - bounding.top;\n }\n if (x == \"nearest\") {\n if (rect.left < bounding.left) {\n moveX = -(bounding.left - rect.left + xMargin);\n if (side > 0 && rect.right > bounding.right + moveX) moveX = rect.right - bounding.right + moveX + xMargin;\n } else if (rect.right > bounding.right) {\n moveX = rect.right - bounding.right + xMargin;\n if (side < 0 && rect.left < bounding.left + moveX) moveX = -(bounding.left + moveX - rect.left + xMargin);\n }\n } else {\n let targetLeft = x == \"center\" ? rect.left + (rect.right - rect.left) / 2 - (bounding.right - bounding.left) / 2 : x == \"start\" == ltr ? rect.left - xMargin : rect.right - (bounding.right - bounding.left) + xMargin;\n moveX = targetLeft - bounding.left;\n }\n if (moveX || moveY) {\n if (top) win.scrollBy(moveX, moveY);\n else {\n if (moveY) {\n let start = cur.scrollTop;\n cur.scrollTop += moveY;\n moveY = cur.scrollTop - start;\n }\n if (moveX) {\n let start = cur.scrollLeft;\n cur.scrollLeft += moveX;\n moveX = cur.scrollLeft - start;\n }\n rect = {\n left: rect.left - moveX,\n top: rect.top - moveY,\n right: rect.right - moveX,\n bottom: rect.bottom - moveY\n };\n }\n }\n if (top) break;\n cur = cur.assignedSlot || cur.parentNode;\n x = y = \"nearest\";\n } else if (cur.nodeType == 11) cur = cur.host;\n else break;\n }\n}\nclass DOMSelectionState {\n constructor(){\n this.anchorNode = null;\n this.anchorOffset = 0;\n this.focusNode = null;\n this.focusOffset = 0;\n }\n eq(domSel) {\n return this.anchorNode == domSel.anchorNode && this.anchorOffset == domSel.anchorOffset && this.focusNode == domSel.focusNode && this.focusOffset == domSel.focusOffset;\n }\n setRange(range) {\n this.set(range.anchorNode, range.anchorOffset, range.focusNode, range.focusOffset);\n }\n set(anchorNode, anchorOffset, focusNode, focusOffset) {\n this.anchorNode = anchorNode;\n this.anchorOffset = anchorOffset;\n this.focusNode = focusNode;\n this.focusOffset = focusOffset;\n }\n}\nlet preventScrollSupported = null;\n// Feature-detects support for .focus({preventScroll: true}), and uses\n// a fallback kludge when not supported.\nfunction focusPreventScroll(dom) {\n if (dom.setActive) return dom.setActive(); // in IE\n if (preventScrollSupported) return dom.focus(preventScrollSupported);\n let stack = [];\n for(let cur = dom; cur; cur = cur.parentNode){\n stack.push(cur, cur.scrollTop, cur.scrollLeft);\n if (cur == cur.ownerDocument) break;\n }\n dom.focus(preventScrollSupported == null ? {\n get preventScroll () {\n preventScrollSupported = {\n preventScroll: true\n };\n return true;\n }\n } : undefined);\n if (!preventScrollSupported) {\n preventScrollSupported = false;\n for(let i = 0; i < stack.length;){\n let elt = stack[i++], top = stack[i++], left = stack[i++];\n if (elt.scrollTop != top) elt.scrollTop = top;\n if (elt.scrollLeft != left) elt.scrollLeft = left;\n }\n }\n}\nlet scratchRange;\nfunction textRange(node, from, to = from) {\n let range = scratchRange || (scratchRange = document.createRange());\n range.setEnd(node, to);\n range.setStart(node, from);\n return range;\n}\nfunction dispatchKey(elt, name, code) {\n let options = {\n key: name,\n code: name,\n keyCode: code,\n which: code,\n cancelable: true\n };\n let down = new KeyboardEvent(\"keydown\", options);\n down.synthetic = true;\n elt.dispatchEvent(down);\n let up = new KeyboardEvent(\"keyup\", options);\n up.synthetic = true;\n elt.dispatchEvent(up);\n return down.defaultPrevented || up.defaultPrevented;\n}\nfunction getRoot(node) {\n while(node){\n if (node && (node.nodeType == 9 || node.nodeType == 11 && node.host)) return node;\n node = node.assignedSlot || node.parentNode;\n }\n return null;\n}\nfunction clearAttributes(node) {\n while(node.attributes.length)node.removeAttributeNode(node.attributes[0]);\n}\nclass DOMPos {\n constructor(node, offset, precise = true){\n this.node = node;\n this.offset = offset;\n this.precise = precise;\n }\n static before(dom, precise) {\n return new DOMPos(dom.parentNode, domIndex(dom), precise);\n }\n static after(dom, precise) {\n return new DOMPos(dom.parentNode, domIndex(dom) + 1, precise);\n }\n}\nconst noChildren = [];\nclass ContentView {\n constructor(){\n this.parent = null;\n this.dom = null;\n this.dirty = 2 /* Node */ ;\n }\n get editorView() {\n if (!this.parent) throw new Error(\"Accessing view in orphan content view\");\n return this.parent.editorView;\n }\n get overrideDOMText() {\n return null;\n }\n get posAtStart() {\n return this.parent ? this.parent.posBefore(this) : 0;\n }\n get posAtEnd() {\n return this.posAtStart + this.length;\n }\n posBefore(view) {\n let pos = this.posAtStart;\n for (let child of this.children){\n if (child == view) return pos;\n pos += child.length + child.breakAfter;\n }\n throw new RangeError(\"Invalid child in posBefore\");\n }\n posAfter(view) {\n return this.posBefore(view) + view.length;\n }\n // Will return a rectangle directly before (when side < 0), after\n // (side > 0) or directly on (when the browser supports it) the\n // given position.\n coordsAt(_pos, _side) {\n return null;\n }\n sync(track) {\n if (this.dirty & 2 /* Node */ ) {\n let parent = this.dom;\n let pos = parent.firstChild;\n for (let child of this.children){\n if (child.dirty) {\n if (!child.dom && pos) {\n let contentView = ContentView.get(pos);\n if (!contentView || !contentView.parent && contentView.constructor == child.constructor) child.reuseDOM(pos);\n }\n child.sync(track);\n child.dirty = 0 /* Not */ ;\n }\n if (track && !track.written && track.node == parent && pos != child.dom) track.written = true;\n if (child.dom.parentNode == parent) {\n while(pos && pos != child.dom)pos = rm(pos);\n pos = child.dom.nextSibling;\n } else parent.insertBefore(child.dom, pos);\n }\n if (pos && track && track.node == parent) track.written = true;\n while(pos)pos = rm(pos);\n } else if (this.dirty & 1 /* Child */ ) {\n for (let child of this.children)if (child.dirty) {\n child.sync(track);\n child.dirty = 0 /* Not */ ;\n }\n }\n }\n reuseDOM(_dom) {\n }\n localPosFromDOM(node, offset) {\n let after;\n if (node == this.dom) after = this.dom.childNodes[offset];\n else {\n let bias = maxOffset(node) == 0 ? 0 : offset == 0 ? -1 : 1;\n for(;;){\n let parent = node.parentNode;\n if (parent == this.dom) break;\n if (bias == 0 && parent.firstChild != parent.lastChild) {\n if (node == parent.firstChild) bias = -1;\n else bias = 1;\n }\n node = parent;\n }\n if (bias < 0) after = node;\n else after = node.nextSibling;\n }\n if (after == this.dom.firstChild) return 0;\n while(after && !ContentView.get(after))after = after.nextSibling;\n if (!after) return this.length;\n for(let i = 0, pos = 0;; i++){\n let child = this.children[i];\n if (child.dom == after) return pos;\n pos += child.length + child.breakAfter;\n }\n }\n domBoundsAround(from, to, offset = 0) {\n let fromI = -1, fromStart = -1, toI = -1, toEnd = -1;\n for(let i = 0, pos = offset, prevEnd = offset; i < this.children.length; i++){\n let child = this.children[i], end = pos + child.length;\n if (pos < from && end > to) return child.domBoundsAround(from, to, pos);\n if (end >= from && fromI == -1) {\n fromI = i;\n fromStart = pos;\n }\n if (pos > to && child.dom.parentNode == this.dom) {\n toI = i;\n toEnd = prevEnd;\n break;\n }\n prevEnd = end;\n pos = end + child.breakAfter;\n }\n return {\n from: fromStart,\n to: toEnd < 0 ? offset + this.length : toEnd,\n startDOM: (fromI ? this.children[fromI - 1].dom.nextSibling : null) || this.dom.firstChild,\n endDOM: toI < this.children.length && toI >= 0 ? this.children[toI].dom : null\n };\n }\n markDirty(andParent = false) {\n this.dirty |= 2 /* Node */ ;\n this.markParentsDirty(andParent);\n }\n markParentsDirty(childList) {\n for(let parent = this.parent; parent; parent = parent.parent){\n if (childList) parent.dirty |= 2 /* Node */ ;\n if (parent.dirty & 1 /* Child */ ) return;\n parent.dirty |= 1 /* Child */ ;\n childList = false;\n }\n }\n setParent(parent) {\n if (this.parent != parent) {\n this.parent = parent;\n if (this.dirty) this.markParentsDirty(true);\n }\n }\n setDOM(dom) {\n if (this.dom) this.dom.cmView = null;\n this.dom = dom;\n dom.cmView = this;\n }\n get rootView() {\n for(let v = this;;){\n let parent = v.parent;\n if (!parent) return v;\n v = parent;\n }\n }\n replaceChildren(from, to, children = noChildren) {\n this.markDirty();\n for(let i = from; i < to; i++){\n let child = this.children[i];\n if (child.parent == this) child.destroy();\n }\n this.children.splice(from, to - from, ...children);\n for(let i1 = 0; i1 < children.length; i1++)children[i1].setParent(this);\n }\n ignoreMutation(_rec) {\n return false;\n }\n ignoreEvent(_event) {\n return false;\n }\n childCursor(pos = this.length) {\n return new ChildCursor(this.children, pos, this.children.length);\n }\n childPos(pos, bias = 1) {\n return this.childCursor().findPos(pos, bias);\n }\n toString() {\n let name = this.constructor.name.replace(\"View\", \"\");\n return name + (this.children.length ? \"(\" + this.children.join() + \")\" : this.length ? \"[\" + (name == \"Text\" ? this.text : this.length) + \"]\" : \"\") + (this.breakAfter ? \"#\" : \"\");\n }\n static get(node) {\n return node.cmView;\n }\n get isEditable() {\n return true;\n }\n merge(from, to, source, hasStart, openStart, openEnd) {\n return false;\n }\n become(other) {\n return false;\n }\n // When this is a zero-length view with a side, this should return a\n // number <= 0 to indicate it is before its position, or a\n // number > 0 when after its position.\n getSide() {\n return 0;\n }\n destroy() {\n this.parent = null;\n }\n}\nContentView.prototype.breakAfter = 0;\n// Remove a DOM node and return its next sibling.\nfunction rm(dom) {\n let next = dom.nextSibling;\n dom.parentNode.removeChild(dom);\n return next;\n}\nclass ChildCursor {\n constructor(children, pos, i){\n this.children = children;\n this.pos = pos;\n this.i = i;\n this.off = 0;\n }\n findPos(pos, bias = 1) {\n for(;;){\n if (pos > this.pos || pos == this.pos && (bias > 0 || this.i == 0 || this.children[this.i - 1].breakAfter)) {\n this.off = pos - this.pos;\n return this;\n }\n let next = this.children[--this.i];\n this.pos -= next.length + next.breakAfter;\n }\n }\n}\nfunction replaceRange(parent, fromI, fromOff, toI, toOff, insert, breakAtStart, openStart, openEnd) {\n let { children } = parent;\n let before = children.length ? children[fromI] : null;\n let last = insert.length ? insert[insert.length - 1] : null;\n let breakAtEnd = last ? last.breakAfter : breakAtStart;\n // Change within a single child\n if (fromI == toI && before && !breakAtStart && !breakAtEnd && insert.length < 2 && before.merge(fromOff, toOff, insert.length ? last : null, fromOff == 0, openStart, openEnd)) return;\n if (toI < children.length) {\n let after = children[toI];\n // Make sure the end of the child after the update is preserved in `after`\n if (after && toOff < after.length) {\n // If we're splitting a child, separate part of it to avoid that\n // being mangled when updating the child before the update.\n if (fromI == toI) {\n after = after.split(toOff);\n toOff = 0;\n }\n // If the element after the replacement should be merged with\n // the last replacing element, update `content`\n if (!breakAtEnd && last && after.merge(0, toOff, last, true, 0, openEnd)) insert[insert.length - 1] = after;\n else {\n // Remove the start of the after element, if necessary, and\n // add it to `content`.\n if (toOff) after.merge(0, toOff, null, false, 0, openEnd);\n insert.push(after);\n }\n } else if (after === null || after === void 0 ? void 0 : after.breakAfter) {\n // The element at `toI` is entirely covered by this range.\n // Preserve its line break, if any.\n if (last) last.breakAfter = 1;\n else breakAtStart = 1;\n }\n // Since we've handled the next element from the current elements\n // now, make sure `toI` points after that.\n toI++;\n }\n if (before) {\n before.breakAfter = breakAtStart;\n if (fromOff > 0) {\n if (!breakAtStart && insert.length && before.merge(fromOff, before.length, insert[0], false, openStart, 0)) before.breakAfter = insert.shift().breakAfter;\n else if (fromOff < before.length || before.children.length && before.children[before.children.length - 1].length == 0) before.merge(fromOff, before.length, null, false, openStart, 0);\n fromI++;\n }\n }\n // Try to merge widgets on the boundaries of the replacement\n while(fromI < toI && insert.length){\n if (children[toI - 1].become(insert[insert.length - 1])) {\n toI--;\n insert.pop();\n openEnd = insert.length ? 0 : openStart;\n } else if (children[fromI].become(insert[0])) {\n fromI++;\n insert.shift();\n openStart = insert.length ? 0 : openEnd;\n } else break;\n }\n if (!insert.length && fromI && toI < children.length && !children[fromI - 1].breakAfter && children[toI].merge(0, 0, children[fromI - 1], false, openStart, openEnd)) fromI--;\n if (fromI < toI || insert.length) parent.replaceChildren(fromI, toI, insert);\n}\nfunction mergeChildrenInto(parent, from, to, insert, openStart, openEnd) {\n let cur = parent.childCursor();\n let { i: toI , off: toOff } = cur.findPos(to, 1);\n let { i: fromI , off: fromOff } = cur.findPos(from, -1);\n let dLen = from - to;\n for (let view of insert)dLen += view.length;\n parent.length += dLen;\n replaceRange(parent, fromI, fromOff, toI, toOff, insert, 0, openStart, openEnd);\n}\nlet nav = typeof navigator != \"undefined\" ? navigator : {\n userAgent: \"\",\n vendor: \"\",\n platform: \"\"\n};\nlet doc = typeof document != \"undefined\" ? document : {\n documentElement: {\n style: {\n }\n }\n};\nconst ie_edge = /*@__PURE__*/ /Edge\\/(\\d+)/.exec(nav.userAgent);\nconst ie_upto10 = /*@__PURE__*/ /MSIE \\d/.test(nav.userAgent);\nconst ie_11up = /*@__PURE__*/ /Trident\\/(?:[7-9]|\\d{2,})\\..*rv:(\\d+)/.exec(nav.userAgent);\nconst ie = !!(ie_upto10 || ie_11up || ie_edge);\nconst gecko = !ie && /*@__PURE__*/ /gecko\\/(\\d+)/i.test(nav.userAgent);\nconst chrome = !ie && /*@__PURE__*/ /Chrome\\/(\\d+)/.exec(nav.userAgent);\nconst webkit = \"webkitFontSmoothing\" in doc.documentElement.style;\nconst safari = !ie && /*@__PURE__*/ /Apple Computer/.test(nav.vendor);\nconst ios = safari && /*@__PURE__*/ (/Mobile\\/\\w+/.test(nav.userAgent) || nav.maxTouchPoints > 2);\nvar browser = {\n mac: ios || /*@__PURE__*/ /Mac/.test(nav.platform),\n windows: /*@__PURE__*/ /Win/.test(nav.platform),\n linux: /*@__PURE__*/ /Linux|X11/.test(nav.platform),\n ie,\n ie_version: ie_upto10 ? doc.documentMode || 6 : ie_11up ? +ie_11up[1] : ie_edge ? +ie_edge[1] : 0,\n gecko,\n gecko_version: gecko ? +/*@__PURE__*/ (/Firefox\\/(\\d+)/.exec(nav.userAgent) || [\n 0,\n 0\n ])[1] : 0,\n chrome: !!chrome,\n chrome_version: chrome ? +chrome[1] : 0,\n ios,\n android: /*@__PURE__*/ /Android\\b/.test(nav.userAgent),\n webkit,\n safari,\n webkit_version: webkit ? +/*@__PURE__*/ (/\\bAppleWebKit\\/(\\d+)/.exec(navigator.userAgent) || [\n 0,\n 0\n ])[1] : 0,\n tabSize: doc.documentElement.style.tabSize != null ? \"tab-size\" : \"-moz-tab-size\"\n};\nconst MaxJoinLen = 256;\nclass TextView extends ContentView {\n constructor(text){\n super();\n this.text = text;\n }\n get length() {\n return this.text.length;\n }\n createDOM(textDOM) {\n this.setDOM(textDOM || document.createTextNode(this.text));\n }\n sync(track) {\n if (!this.dom) this.createDOM();\n if (this.dom.nodeValue != this.text) {\n if (track && track.node == this.dom) track.written = true;\n this.dom.nodeValue = this.text;\n }\n }\n reuseDOM(dom) {\n if (dom.nodeType == 3) this.createDOM(dom);\n }\n merge(from, to, source) {\n if (source && (!(source instanceof TextView) || this.length - (to - from) + source.length > MaxJoinLen)) return false;\n this.text = this.text.slice(0, from) + (source ? source.text : \"\") + this.text.slice(to);\n this.markDirty();\n return true;\n }\n split(from) {\n let result = new TextView(this.text.slice(from));\n this.text = this.text.slice(0, from);\n this.markDirty();\n return result;\n }\n localPosFromDOM(node, offset) {\n return node == this.dom ? offset : offset ? this.text.length : 0;\n }\n domAtPos(pos) {\n return new DOMPos(this.dom, pos);\n }\n domBoundsAround(_from, _to, offset) {\n return {\n from: offset,\n to: offset + this.length,\n startDOM: this.dom,\n endDOM: this.dom.nextSibling\n };\n }\n coordsAt(pos, side) {\n return textCoords(this.dom, pos, side);\n }\n}\nclass MarkView extends ContentView {\n constructor(mark, children = [], length = 0){\n super();\n this.mark = mark;\n this.children = children;\n this.length = length;\n for (let ch of children)ch.setParent(this);\n }\n setAttrs(dom) {\n clearAttributes(dom);\n if (this.mark.class) dom.className = this.mark.class;\n if (this.mark.attrs) for(let name in this.mark.attrs)dom.setAttribute(name, this.mark.attrs[name]);\n return dom;\n }\n reuseDOM(node) {\n if (node.nodeName == this.mark.tagName.toUpperCase()) {\n this.setDOM(node);\n this.dirty |= 6 /* Node */ ;\n }\n }\n sync(track) {\n if (!this.dom) this.setDOM(this.setAttrs(document.createElement(this.mark.tagName)));\n else if (this.dirty & 4 /* Attrs */ ) this.setAttrs(this.dom);\n super.sync(track);\n }\n merge(from, to, source, _hasStart, openStart, openEnd) {\n if (source && (!(source instanceof MarkView && source.mark.eq(this.mark)) || from && openStart <= 0 || to < this.length && openEnd <= 0)) return false;\n mergeChildrenInto(this, from, to, source ? source.children : [], openStart - 1, openEnd - 1);\n this.markDirty();\n return true;\n }\n split(from) {\n let result = [], off = 0, detachFrom = -1, i = 0;\n for (let elt of this.children){\n let end = off + elt.length;\n if (end > from) result.push(off < from ? elt.split(from - off) : elt);\n if (detachFrom < 0 && off >= from) detachFrom = i;\n off = end;\n i++;\n }\n let length = this.length - from;\n this.length = from;\n if (detachFrom > -1) {\n this.children.length = detachFrom;\n this.markDirty();\n }\n return new MarkView(this.mark, result, length);\n }\n domAtPos(pos) {\n return inlineDOMAtPos(this.dom, this.children, pos);\n }\n coordsAt(pos, side) {\n return coordsInChildren(this, pos, side);\n }\n}\nfunction textCoords(text, pos, side) {\n let length = text.nodeValue.length;\n if (pos > length) pos = length;\n let from = pos, to = pos, flatten = 0;\n if (pos == 0 && side < 0 || pos == length && side >= 0) {\n if (!(browser.chrome || browser.gecko)) {\n if (pos) {\n from--;\n flatten = 1;\n } else {\n to++;\n flatten = -1;\n }\n }\n } else if (side < 0) from--;\n else to++;\n let rects = textRange(text, from, to).getClientRects();\n if (!rects.length) return Rect0;\n let rect = rects[(flatten ? flatten < 0 : side >= 0) ? 0 : rects.length - 1];\n if (browser.safari && !flatten && rect.width == 0) rect = Array.prototype.find.call(rects, (r)=>r.width\n ) || rect;\n return flatten ? flattenRect(rect, flatten < 0) : rect || null;\n}\n// Also used for collapsed ranges that don't have a placeholder widget!\nclass WidgetView extends ContentView {\n constructor(widget, length, side){\n super();\n this.widget = widget;\n this.length = length;\n this.side = side;\n }\n static create(widget, length, side) {\n return new (widget.customView || WidgetView)(widget, length, side);\n }\n split(from) {\n let result = WidgetView.create(this.widget, this.length - from, this.side);\n this.length -= from;\n return result;\n }\n sync() {\n if (!this.dom || !this.widget.updateDOM(this.dom)) {\n this.setDOM(this.widget.toDOM(this.editorView));\n this.dom.contentEditable = \"false\";\n }\n }\n getSide() {\n return this.side;\n }\n merge(from, to, source, hasStart, openStart, openEnd) {\n if (source && (!(source instanceof WidgetView) || !this.widget.compare(source.widget) || from > 0 && openStart <= 0 || to < this.length && openEnd <= 0)) return false;\n this.length = from + (source ? source.length : 0) + (this.length - to);\n return true;\n }\n become(other) {\n if (other.length == this.length && other instanceof WidgetView && other.side == this.side) {\n if (this.widget.constructor == other.widget.constructor) {\n if (!this.widget.eq(other.widget)) this.markDirty(true);\n this.widget = other.widget;\n return true;\n }\n }\n return false;\n }\n ignoreMutation() {\n return true;\n }\n ignoreEvent(event) {\n return this.widget.ignoreEvent(event);\n }\n get overrideDOMText() {\n if (this.length == 0) return _text.Text.empty;\n let top = this;\n while(top.parent)top = top.parent;\n let view = top.editorView, text = view && view.state.doc, start = this.posAtStart;\n return text ? text.slice(start, start + this.length) : _text.Text.empty;\n }\n domAtPos(pos) {\n return pos == 0 ? DOMPos.before(this.dom) : DOMPos.after(this.dom, pos == this.length);\n }\n domBoundsAround() {\n return null;\n }\n coordsAt(pos, side) {\n let rects = this.dom.getClientRects(), rect = null;\n if (!rects.length) return Rect0;\n for(let i = pos > 0 ? rects.length - 1 : 0;; i += pos > 0 ? -1 : 1){\n rect = rects[i];\n if (pos > 0 ? i == 0 : i == rects.length - 1 || rect.top < rect.bottom) break;\n }\n return pos == 0 && side > 0 || pos == this.length && side <= 0 ? rect : flattenRect(rect, pos == 0);\n }\n get isEditable() {\n return false;\n }\n destroy() {\n super.destroy();\n if (this.dom) this.widget.destroy(this.dom);\n }\n}\nclass CompositionView extends WidgetView {\n domAtPos(pos) {\n return new DOMPos(this.widget.text, pos);\n }\n sync() {\n this.setDOM(this.widget.toDOM());\n }\n localPosFromDOM(node, offset) {\n return !offset ? 0 : node.nodeType == 3 ? Math.min(offset, this.length) : this.length;\n }\n ignoreMutation() {\n return false;\n }\n get overrideDOMText() {\n return null;\n }\n coordsAt(pos, side) {\n return textCoords(this.widget.text, pos, side);\n }\n get isEditable() {\n return true;\n }\n}\n// Use two characters on Android, to prevent Chrome from closing the\n// virtual keyboard when backspacing after a widget (#602).\nconst ZeroWidthSpace = browser.android ? \"\\u200b\\u200b\" : \"\\u200b\";\n// These are drawn around uneditable widgets to avoid a number of\n// browser bugs that show up when the cursor is directly next to\n// uneditable inline content.\nclass WidgetBufferView extends ContentView {\n constructor(side){\n super();\n this.side = side;\n }\n get length() {\n return 0;\n }\n merge() {\n return false;\n }\n become(other) {\n return other instanceof WidgetBufferView && other.side == this.side;\n }\n split() {\n return new WidgetBufferView(this.side);\n }\n sync() {\n if (!this.dom) this.setDOM(document.createTextNode(ZeroWidthSpace));\n else if (this.dirty && this.dom.nodeValue != ZeroWidthSpace) this.dom.nodeValue = ZeroWidthSpace;\n }\n getSide() {\n return this.side;\n }\n domAtPos(pos) {\n return DOMPos.before(this.dom);\n }\n localPosFromDOM() {\n return 0;\n }\n domBoundsAround() {\n return null;\n }\n coordsAt(pos) {\n let rects = clientRectsFor(this.dom);\n return rects[rects.length - 1] || null;\n }\n get overrideDOMText() {\n return _text.Text.of([\n this.dom.nodeValue.replace(/\\u200b/g, \"\")\n ]);\n }\n}\nTextView.prototype.children = WidgetView.prototype.children = WidgetBufferView.prototype.children = noChildren;\nfunction inlineDOMAtPos(dom, children, pos) {\n let i = 0;\n for(let off = 0; i < children.length; i++){\n let child = children[i], end = off + child.length;\n if (end == off && child.getSide() <= 0) continue;\n if (pos > off && pos < end && child.dom.parentNode == dom) return child.domAtPos(pos - off);\n if (pos <= off) break;\n off = end;\n }\n for(; i > 0; i--){\n let before = children[i - 1].dom;\n if (before.parentNode == dom) return DOMPos.after(before);\n }\n return new DOMPos(dom, 0);\n}\n// Assumes `view`, if a mark view, has precisely 1 child.\nfunction joinInlineInto(parent, view, open) {\n let last, { children } = parent;\n if (open > 0 && view instanceof MarkView && children.length && (last = children[children.length - 1]) instanceof MarkView && last.mark.eq(view.mark)) joinInlineInto(last, view.children[0], open - 1);\n else {\n children.push(view);\n view.setParent(parent);\n }\n parent.length += view.length;\n}\nfunction coordsInChildren(view, pos, side) {\n for(let off = 0, i = 0; i < view.children.length; i++){\n let child = view.children[i], end = off + child.length, next;\n if ((side <= 0 || end == view.length || child.getSide() > 0 ? end >= pos : end > pos) && (pos < end || i + 1 == view.children.length || (next = view.children[i + 1]).length || next.getSide() > 0)) {\n let flatten = 0;\n if (end == off) {\n if (child.getSide() <= 0) continue;\n flatten = side = -child.getSide();\n }\n let rect = child.coordsAt(pos - off, side);\n return flatten && rect ? flattenRect(rect, side < 0) : rect;\n }\n off = end;\n }\n let last = view.dom.lastChild;\n if (!last) return view.dom.getBoundingClientRect();\n let rects = clientRectsFor(last);\n return rects[rects.length - 1] || null;\n}\nfunction combineAttrs(source, target) {\n for(let name in source){\n if (name == \"class\" && target.class) target.class += \" \" + source.class;\n else if (name == \"style\" && target.style) target.style += \";\" + source.style;\n else target[name] = source[name];\n }\n return target;\n}\nfunction attrsEq(a, b) {\n if (a == b) return true;\n if (!a || !b) return false;\n let keysA = Object.keys(a), keysB = Object.keys(b);\n if (keysA.length != keysB.length) return false;\n for (let key of keysA){\n if (keysB.indexOf(key) == -1 || a[key] !== b[key]) return false;\n }\n return true;\n}\nfunction updateAttrs(dom, prev, attrs) {\n if (prev) {\n for(let name in prev)if (!(attrs && name in attrs)) dom.removeAttribute(name);\n }\n if (attrs) {\n for(let name1 in attrs)if (!(prev && prev[name1] == attrs[name1])) dom.setAttribute(name1, attrs[name1]);\n }\n}\n/**\nWidgets added to the content are described by subclasses of this\nclass. Using a description object like that makes it possible to\ndelay creating of the DOM structure for a widget until it is\nneeded, and to avoid redrawing widgets even when the decorations\nthat define them are recreated.\n*/ class WidgetType {\n /**\n Compare this instance to another instance of the same type.\n (TypeScript can't express this, but only instances of the same\n specific class will be passed to this method.) This is used to\n avoid redrawing widgets when they are replaced by a new\n decoration of the same type. The default implementation just\n returns `false`, which will cause new instances of the widget to\n always be redrawn.\n */ eq(_widget) {\n return false;\n }\n /**\n Update a DOM element created by a widget of the same type (but\n different, non-`eq` content) to reflect this widget. May return\n true to indicate that it could update, false to indicate it\n couldn't (in which case the widget will be redrawn). The default\n implementation just returns false.\n */ updateDOM(_dom) {\n return false;\n }\n /**\n @internal\n */ compare(other) {\n return this == other || this.constructor == other.constructor && this.eq(other);\n }\n /**\n The estimated height this widget will have, to be used when\n estimating the height of content that hasn't been drawn. May\n return -1 to indicate you don't know. The default implementation\n returns -1.\n */ get estimatedHeight() {\n return -1;\n }\n /**\n Can be used to configure which kinds of events inside the widget\n should be ignored by the editor. The default is to ignore all\n events.\n */ ignoreEvent(_event) {\n return true;\n }\n /**\n @internal\n */ get customView() {\n return null;\n }\n /**\n This is called when the an instance of the widget is removed\n from the editor view.\n */ destroy(_dom) {\n }\n}\n/**\nThe different types of blocks that can occur in an editor view.\n*/ var BlockType = /*@__PURE__*/ function(BlockType1) {\n /**\n A line of text.\n */ BlockType1[BlockType1[\"Text\"] = 0] = \"Text\";\n /**\n A block widget associated with the position after it.\n */ BlockType1[BlockType1[\"WidgetBefore\"] = 1] = \"WidgetBefore\";\n /**\n A block widget associated with the position before it.\n */ BlockType1[BlockType1[\"WidgetAfter\"] = 2] = \"WidgetAfter\";\n /**\n A block widget [replacing](https://codemirror.net/6/docs/ref/#view.Decoration^replace) a range of content.\n */ BlockType1[BlockType1[\"WidgetRange\"] = 3] = \"WidgetRange\";\n return BlockType1;\n}(BlockType || (BlockType = {\n}));\n/**\nA decoration provides information on how to draw or style a piece\nof content. You'll usually use it wrapped in a\n[`Range`](https://codemirror.net/6/docs/ref/#rangeset.Range), which adds a start and end position.\n*/ class Decoration extends _rangeset.RangeValue {\n /**\n @internal\n */ constructor(/**\n @internal\n */ startSide, /**\n @internal\n */ endSide, /**\n @internal\n */ widget, /**\n The config object used to create this decoration. You can\n include additional properties in there to store metadata about\n your decoration.\n */ spec){\n super();\n this.startSide = startSide;\n this.endSide = endSide;\n this.widget = widget;\n this.spec = spec;\n }\n /**\n @internal\n */ get heightRelevant() {\n return false;\n }\n /**\n Create a mark decoration, which influences the styling of the\n content in its range. Nested mark decorations will cause nested\n DOM elements to be created. Nesting order is determined by\n precedence of the [facet](https://codemirror.net/6/docs/ref/#view.EditorView^decorations) or\n (below the facet-provided decorations) [view\n plugin](https://codemirror.net/6/docs/ref/#view.PluginSpec.decorations). Such elements are split\n on line boundaries and on the boundaries of higher-precedence\n decorations.\n */ static mark(spec) {\n return new MarkDecoration(spec);\n }\n /**\n Create a widget decoration, which adds an element at the given\n position.\n */ static widget(spec) {\n let side = spec.side || 0, block = !!spec.block;\n side += block ? side > 0 ? 300000000 /* BlockAfter */ : -400000000 /* BlockBefore */ : side > 0 ? 100000000 /* InlineAfter */ : -100000000 /* InlineBefore */ ;\n return new PointDecoration(spec, side, side, block, spec.widget || null, false);\n }\n /**\n Create a replace decoration which replaces the given range with\n a widget, or simply hides it.\n */ static replace(spec) {\n let block = !!spec.block;\n let { start , end } = getInclusive(spec, block);\n let startSide = (start ? block ? -300000000 /* BlockIncStart */ : -1 /* InlineIncStart */ : 400000000 /* NonIncStart */ ) - 1;\n let endSide = (end ? block ? 200000000 /* BlockIncEnd */ : 1 /* InlineIncEnd */ : -500000000 /* NonIncEnd */ ) + 1;\n return new PointDecoration(spec, startSide, endSide, block, spec.widget || null, true);\n }\n /**\n Create a line decoration, which can add DOM attributes to the\n line starting at the given position.\n */ static line(spec) {\n return new LineDecoration(spec);\n }\n /**\n Build a [`DecorationSet`](https://codemirror.net/6/docs/ref/#view.DecorationSet) from the given\n decorated range or ranges. If the ranges aren't already sorted,\n pass `true` for `sort` to make the library sort them for you.\n */ static set(of, sort = false) {\n return _rangeset.RangeSet.of(of, sort);\n }\n /**\n @internal\n */ hasHeight() {\n return this.widget ? this.widget.estimatedHeight > -1 : false;\n }\n}\n/**\nThe empty set of decorations.\n*/ Decoration.none = _rangeset.RangeSet.empty;\nclass MarkDecoration extends Decoration {\n constructor(spec){\n let { start , end } = getInclusive(spec);\n super(start ? -1 /* InlineIncStart */ : 400000000 /* NonIncStart */ , end ? 1 /* InlineIncEnd */ : -500000000 /* NonIncEnd */ , null, spec);\n this.tagName = spec.tagName || \"span\";\n this.class = spec.class || \"\";\n this.attrs = spec.attributes || null;\n }\n eq(other) {\n return this == other || other instanceof MarkDecoration && this.tagName == other.tagName && this.class == other.class && attrsEq(this.attrs, other.attrs);\n }\n range(from, to = from) {\n if (from >= to) throw new RangeError(\"Mark decorations may not be empty\");\n return super.range(from, to);\n }\n}\nMarkDecoration.prototype.point = false;\nclass LineDecoration extends Decoration {\n constructor(spec){\n super(-200000000 /* Line */ , -200000000 /* Line */ , null, spec);\n }\n eq(other) {\n return other instanceof LineDecoration && attrsEq(this.spec.attributes, other.spec.attributes);\n }\n range(from, to = from) {\n if (to != from) throw new RangeError(\"Line decoration ranges must be zero-length\");\n return super.range(from, to);\n }\n}\nLineDecoration.prototype.mapMode = _state.MapMode.TrackBefore;\nLineDecoration.prototype.point = true;\nclass PointDecoration extends Decoration {\n constructor(spec, startSide, endSide, block, widget, isReplace){\n super(startSide, endSide, widget, spec);\n this.block = block;\n this.isReplace = isReplace;\n this.mapMode = !block ? _state.MapMode.TrackDel : startSide <= 0 ? _state.MapMode.TrackBefore : _state.MapMode.TrackAfter;\n }\n // Only relevant when this.block == true\n get type() {\n return this.startSide < this.endSide ? BlockType.WidgetRange : this.startSide <= 0 ? BlockType.WidgetBefore : BlockType.WidgetAfter;\n }\n get heightRelevant() {\n return this.block || !!this.widget && this.widget.estimatedHeight >= 5;\n }\n eq(other) {\n return other instanceof PointDecoration && widgetsEq(this.widget, other.widget) && this.block == other.block && this.startSide == other.startSide && this.endSide == other.endSide;\n }\n range(from, to = from) {\n if (this.isReplace && (from > to || from == to && this.startSide > 0 && this.endSide <= 0)) throw new RangeError(\"Invalid range for replacement decoration\");\n if (!this.isReplace && to != from) throw new RangeError(\"Widget decorations can only have zero-length ranges\");\n return super.range(from, to);\n }\n}\nPointDecoration.prototype.point = true;\nfunction getInclusive(spec, block = false) {\n let { inclusiveStart: start , inclusiveEnd: end } = spec;\n if (start == null) start = spec.inclusive;\n if (end == null) end = spec.inclusive;\n return {\n start: start !== null && start !== void 0 ? start : block,\n end: end !== null && end !== void 0 ? end : block\n };\n}\nfunction widgetsEq(a, b) {\n return a == b || !!(a && b && a.compare(b));\n}\nfunction addRange(from, to, ranges, margin = 0) {\n let last = ranges.length - 1;\n if (last >= 0 && ranges[last] + margin >= from) ranges[last] = Math.max(ranges[last], to);\n else ranges.push(from, to);\n}\nclass LineView extends ContentView {\n constructor(){\n super(...arguments);\n this.children = [];\n this.length = 0;\n this.prevAttrs = undefined;\n this.attrs = null;\n this.breakAfter = 0;\n }\n // Consumes source\n merge(from, to, source, hasStart, openStart, openEnd) {\n if (source) {\n if (!(source instanceof LineView)) return false;\n if (!this.dom) source.transferDOM(this); // Reuse source.dom when appropriate\n }\n if (hasStart) this.setDeco(source ? source.attrs : null);\n mergeChildrenInto(this, from, to, source ? source.children : [], openStart, openEnd);\n return true;\n }\n split(at) {\n let end = new LineView;\n end.breakAfter = this.breakAfter;\n if (this.length == 0) return end;\n let { i , off } = this.childPos(at);\n if (off) {\n end.append(this.children[i].split(off), 0);\n this.children[i].merge(off, this.children[i].length, null, false, 0, 0);\n i++;\n }\n for(let j = i; j < this.children.length; j++)end.append(this.children[j], 0);\n while(i > 0 && this.children[i - 1].length == 0)this.children[--i].destroy();\n this.children.length = i;\n this.markDirty();\n this.length = at;\n return end;\n }\n transferDOM(other) {\n if (!this.dom) return;\n other.setDOM(this.dom);\n other.prevAttrs = this.prevAttrs === undefined ? this.attrs : this.prevAttrs;\n this.prevAttrs = undefined;\n this.dom = null;\n }\n setDeco(attrs) {\n if (!attrsEq(this.attrs, attrs)) {\n if (this.dom) {\n this.prevAttrs = this.attrs;\n this.markDirty();\n }\n this.attrs = attrs;\n }\n }\n append(child, openStart) {\n joinInlineInto(this, child, openStart);\n }\n // Only called when building a line view in ContentBuilder\n addLineDeco(deco) {\n let attrs = deco.spec.attributes, cls = deco.spec.class;\n if (attrs) this.attrs = combineAttrs(attrs, this.attrs || {\n });\n if (cls) this.attrs = combineAttrs({\n class: cls\n }, this.attrs || {\n });\n }\n domAtPos(pos) {\n return inlineDOMAtPos(this.dom, this.children, pos);\n }\n reuseDOM(node) {\n if (node.nodeName == \"DIV\") {\n this.setDOM(node);\n this.dirty |= 6 /* Node */ ;\n }\n }\n sync(track) {\n var _a;\n if (!this.dom) {\n this.setDOM(document.createElement(\"div\"));\n this.dom.className = \"cm-line\";\n this.prevAttrs = this.attrs ? null : undefined;\n } else if (this.dirty & 4 /* Attrs */ ) {\n clearAttributes(this.dom);\n this.dom.className = \"cm-line\";\n this.prevAttrs = this.attrs ? null : undefined;\n }\n if (this.prevAttrs !== undefined) {\n updateAttrs(this.dom, this.prevAttrs, this.attrs);\n this.dom.classList.add(\"cm-line\");\n this.prevAttrs = undefined;\n }\n super.sync(track);\n let last = this.dom.lastChild;\n while(last && ContentView.get(last) instanceof MarkView)last = last.lastChild;\n if (!last || last.nodeName != \"BR\" && ((_a = ContentView.get(last)) === null || _a === void 0 ? void 0 : _a.isEditable) == false && (!browser.ios || !this.children.some((ch)=>ch instanceof TextView\n ))) {\n let hack = document.createElement(\"BR\");\n hack.cmIgnore = true;\n this.dom.appendChild(hack);\n }\n }\n measureTextSize() {\n if (this.children.length == 0 || this.length > 20) return null;\n let totalWidth = 0;\n for (let child of this.children){\n if (!(child instanceof TextView)) return null;\n let rects = clientRectsFor(child.dom);\n if (rects.length != 1) return null;\n totalWidth += rects[0].width;\n }\n return {\n lineHeight: this.dom.getBoundingClientRect().height,\n charWidth: totalWidth / this.length\n };\n }\n coordsAt(pos, side) {\n return coordsInChildren(this, pos, side);\n }\n become(_other) {\n return false;\n }\n get type() {\n return BlockType.Text;\n }\n static find(docView, pos) {\n for(let i = 0, off = 0; i < docView.children.length; i++){\n let block = docView.children[i], end = off + block.length;\n if (end >= pos) {\n if (block instanceof LineView) return block;\n if (end > pos) break;\n }\n off = end + block.breakAfter;\n }\n return null;\n }\n}\nclass BlockWidgetView extends ContentView {\n constructor(widget, length, type){\n super();\n this.widget = widget;\n this.length = length;\n this.type = type;\n this.breakAfter = 0;\n }\n merge(from, to, source, _takeDeco, openStart, openEnd) {\n if (source && (!(source instanceof BlockWidgetView) || !this.widget.compare(source.widget) || from > 0 && openStart <= 0 || to < this.length && openEnd <= 0)) return false;\n this.length = from + (source ? source.length : 0) + (this.length - to);\n return true;\n }\n domAtPos(pos) {\n return pos == 0 ? DOMPos.before(this.dom) : DOMPos.after(this.dom, pos == this.length);\n }\n split(at) {\n let len = this.length - at;\n this.length = at;\n let end = new BlockWidgetView(this.widget, len, this.type);\n end.breakAfter = this.breakAfter;\n return end;\n }\n get children() {\n return noChildren;\n }\n sync() {\n if (!this.dom || !this.widget.updateDOM(this.dom)) {\n this.setDOM(this.widget.toDOM(this.editorView));\n this.dom.contentEditable = \"false\";\n }\n }\n get overrideDOMText() {\n return this.parent ? this.parent.view.state.doc.slice(this.posAtStart, this.posAtEnd) : _state.Text.empty;\n }\n domBoundsAround() {\n return null;\n }\n become(other) {\n if (other instanceof BlockWidgetView && other.type == this.type && other.widget.constructor == this.widget.constructor) {\n if (!other.widget.eq(this.widget)) this.markDirty(true);\n this.widget = other.widget;\n this.length = other.length;\n this.breakAfter = other.breakAfter;\n return true;\n }\n return false;\n }\n ignoreMutation() {\n return true;\n }\n ignoreEvent(event) {\n return this.widget.ignoreEvent(event);\n }\n destroy() {\n super.destroy();\n if (this.dom) this.widget.destroy(this.dom);\n }\n}\nclass ContentBuilder {\n constructor(doc2, pos, end, disallowBlockEffectsBelow){\n this.doc = doc2;\n this.pos = pos;\n this.end = end;\n this.disallowBlockEffectsBelow = disallowBlockEffectsBelow;\n this.content = [];\n this.curLine = null;\n this.breakAtStart = 0;\n this.pendingBuffer = 0 /* No */ ;\n // Set to false directly after a widget that covers the position after it\n this.atCursorPos = true;\n this.openStart = -1;\n this.openEnd = -1;\n this.text = \"\";\n this.textOff = 0;\n this.cursor = doc2.iter();\n this.skip = pos;\n }\n posCovered() {\n if (this.content.length == 0) return !this.breakAtStart && this.doc.lineAt(this.pos).from != this.pos;\n let last = this.content[this.content.length - 1];\n return !last.breakAfter && !(last instanceof BlockWidgetView && last.type == BlockType.WidgetBefore);\n }\n getLine() {\n if (!this.curLine) {\n this.content.push(this.curLine = new LineView);\n this.atCursorPos = true;\n }\n return this.curLine;\n }\n flushBuffer(active) {\n if (this.pendingBuffer) {\n this.curLine.append(wrapMarks(new WidgetBufferView(-1), active), active.length);\n this.pendingBuffer = 0 /* No */ ;\n }\n }\n addBlockWidget(view) {\n this.flushBuffer([]);\n this.curLine = null;\n this.content.push(view);\n }\n finish(openEnd) {\n if (!openEnd) this.flushBuffer([]);\n else this.pendingBuffer = 0 /* No */ ;\n if (!this.posCovered()) this.getLine();\n }\n buildText(length, active, openStart) {\n while(length > 0){\n if (this.textOff == this.text.length) {\n let { value , lineBreak , done } = this.cursor.next(this.skip);\n this.skip = 0;\n if (done) throw new Error(\"Ran out of text content when drawing inline views\");\n if (lineBreak) {\n if (!this.posCovered()) this.getLine();\n if (this.content.length) this.content[this.content.length - 1].breakAfter = 1;\n else this.breakAtStart = 1;\n this.flushBuffer([]);\n this.curLine = null;\n length--;\n continue;\n } else {\n this.text = value;\n this.textOff = 0;\n }\n }\n let take = Math.min(this.text.length - this.textOff, length, 512 /* Chunk */ );\n this.flushBuffer(active.slice(0, openStart));\n this.getLine().append(wrapMarks(new TextView(this.text.slice(this.textOff, this.textOff + take)), active), openStart);\n this.atCursorPos = true;\n this.textOff += take;\n length -= take;\n openStart = 0;\n }\n }\n span(from, to, active, openStart) {\n this.buildText(to - from, active, openStart);\n this.pos = to;\n if (this.openStart < 0) this.openStart = openStart;\n }\n point(from, to, deco, active, openStart) {\n let len = to - from;\n if (deco instanceof PointDecoration) {\n if (deco.block) {\n let { type } = deco;\n if (type == BlockType.WidgetAfter && !this.posCovered()) this.getLine();\n this.addBlockWidget(new BlockWidgetView(deco.widget || new NullWidget(\"div\"), len, type));\n } else {\n let view = WidgetView.create(deco.widget || new NullWidget(\"span\"), len, deco.startSide);\n let cursorBefore = this.atCursorPos && !view.isEditable && openStart <= active.length && (from < to || deco.startSide > 0);\n let cursorAfter = !view.isEditable && (from < to || deco.startSide <= 0);\n let line = this.getLine();\n if (this.pendingBuffer == 2 /* IfCursor */ && !cursorBefore) this.pendingBuffer = 0 /* No */ ;\n this.flushBuffer(active);\n if (cursorBefore) {\n line.append(wrapMarks(new WidgetBufferView(1), active), openStart);\n openStart = active.length + Math.max(0, openStart - active.length);\n }\n line.append(wrapMarks(view, active), openStart);\n this.atCursorPos = cursorAfter;\n this.pendingBuffer = !cursorAfter ? 0 /* No */ : from < to ? 1 /* Yes */ : 2 /* IfCursor */ ;\n }\n } else if (this.doc.lineAt(this.pos).from == this.pos) this.getLine().addLineDeco(deco);\n if (len) {\n // Advance the iterator past the replaced content\n if (this.textOff + len <= this.text.length) this.textOff += len;\n else {\n this.skip += len - (this.text.length - this.textOff);\n this.text = \"\";\n this.textOff = 0;\n }\n this.pos = to;\n }\n if (this.openStart < 0) this.openStart = openStart;\n }\n filterPoint(from, to, value, index) {\n if (index < this.disallowBlockEffectsBelow && value instanceof PointDecoration) {\n if (value.block) throw new RangeError(\"Block decorations may not be specified via plugins\");\n if (to > this.doc.lineAt(this.pos).to) throw new RangeError(\"Decorations that replace line breaks may not be specified via plugins\");\n }\n return true;\n }\n static build(text, from, to, decorations1, pluginDecorationLength) {\n let builder = new ContentBuilder(text, from, to, pluginDecorationLength);\n builder.openEnd = _rangeset.RangeSet.spans(decorations1, from, to, builder);\n if (builder.openStart < 0) builder.openStart = builder.openEnd;\n builder.finish(builder.openEnd);\n return builder;\n }\n}\nfunction wrapMarks(view, active) {\n for (let mark of active)view = new MarkView(mark, [\n view\n ], view.length);\n return view;\n}\nclass NullWidget extends WidgetType {\n constructor(tag){\n super();\n this.tag = tag;\n }\n eq(other) {\n return other.tag == this.tag;\n }\n toDOM() {\n return document.createElement(this.tag);\n }\n updateDOM(elt) {\n return elt.nodeName.toLowerCase() == this.tag;\n }\n}\nconst none = [];\nconst clickAddsSelectionRange = /*@__PURE__*/ _state.Facet.define();\nconst dragMovesSelection$1 = /*@__PURE__*/ _state.Facet.define();\nconst mouseSelectionStyle = /*@__PURE__*/ _state.Facet.define();\nconst exceptionSink = /*@__PURE__*/ _state.Facet.define();\nconst updateListener = /*@__PURE__*/ _state.Facet.define();\nconst inputHandler = /*@__PURE__*/ _state.Facet.define();\n// FIXME remove\nconst scrollTo = /*@__PURE__*/ _state.StateEffect.define({\n map: (range, changes)=>range.map(changes)\n});\n// FIXME remove\nconst centerOn = /*@__PURE__*/ _state.StateEffect.define({\n map: (range, changes)=>range.map(changes)\n});\nclass ScrollTarget {\n constructor(range, y = \"nearest\", x = \"nearest\", yMargin = 5, xMargin = 5){\n this.range = range;\n this.y = y;\n this.x = x;\n this.yMargin = yMargin;\n this.xMargin = xMargin;\n }\n map(changes) {\n return changes.empty ? this : new ScrollTarget(this.range.map(changes), this.y, this.x, this.yMargin, this.xMargin);\n }\n}\nconst scrollIntoView = /*@__PURE__*/ _state.StateEffect.define({\n map: (t, ch)=>t.map(ch)\n});\n/**\nLog or report an unhandled exception in client code. Should\nprobably only be used by extension code that allows client code to\nprovide functions, and calls those functions in a context where an\nexception can't be propagated to calling code in a reasonable way\n(for example when in an event handler).\n\nEither calls a handler registered with\n[`EditorView.exceptionSink`](https://codemirror.net/6/docs/ref/#view.EditorView^exceptionSink),\n`window.onerror`, if defined, or `console.error` (in which case\nit'll pass `context`, when given, as first argument).\n*/ function logException(state, exception, context) {\n let handler = state.facet(exceptionSink);\n if (handler.length) handler[0](exception);\n else if (window.onerror) window.onerror(String(exception), context, undefined, undefined, exception);\n else if (context) console.error(context + \":\", exception);\n else console.error(exception);\n}\nconst editable = /*@__PURE__*/ _state.Facet.define({\n combine: (values)=>values.length ? values[0] : true\n});\n/**\nUsed to [declare](https://codemirror.net/6/docs/ref/#view.PluginSpec.provide) which\n[fields](https://codemirror.net/6/docs/ref/#view.PluginValue) a [view plugin](https://codemirror.net/6/docs/ref/#view.ViewPlugin)\nprovides.\n*/ class PluginFieldProvider {\n /**\n @internal\n */ constructor(/**\n @internal\n */ field, /**\n @internal\n */ get){\n this.field = field;\n this.get = get;\n }\n}\n/**\nPlugin fields are a mechanism for allowing plugins to provide\nvalues that can be retrieved through the\n[`pluginField`](https://codemirror.net/6/docs/ref/#view.EditorView.pluginField) view method.\n*/ class PluginField {\n /**\n Create a [provider](https://codemirror.net/6/docs/ref/#view.PluginFieldProvider) for this field,\n to use with a plugin's [provide](https://codemirror.net/6/docs/ref/#view.PluginSpec.provide)\n option.\n */ from(get) {\n return new PluginFieldProvider(this, get);\n }\n /**\n Define a new plugin field.\n */ static define() {\n return new PluginField();\n }\n}\n/**\nThis field can be used by plugins to provide\n[decorations](https://codemirror.net/6/docs/ref/#view.Decoration).\n\n**Note**: For reasons of data flow (plugins are only updated\nafter the viewport is computed), decorations produced by plugins\nare _not_ taken into account when predicting the vertical layout\nstructure of the editor. They **must not** introduce block\nwidgets (that will raise an error) or replacing decorations that\ncover line breaks (these will be ignored if they occur). Such\ndecorations, or others that cause a large amount of vertical\nsize shift compared to the undecorated content, should be\nprovided through the state-level [`decorations`\nfacet](https://codemirror.net/6/docs/ref/#view.EditorView^decorations) instead.\n*/ PluginField.decorations = /*@__PURE__*/ PluginField.define();\n/**\nUsed to provide ranges that should be treated as atoms as far as\ncursor motion is concerned. This causes methods like\n[`moveByChar`](https://codemirror.net/6/docs/ref/#view.EditorView.moveByChar) and\n[`moveVertically`](https://codemirror.net/6/docs/ref/#view.EditorView.moveVertically) (and the\ncommands built on top of them) to skip across such regions when\na selection endpoint would enter them. This does _not_ prevent\ndirect programmatic [selection\nupdates](https://codemirror.net/6/docs/ref/#state.TransactionSpec.selection) from moving into such\nregions.\n*/ PluginField.atomicRanges = /*@__PURE__*/ PluginField.define();\n/**\nPlugins can provide additional scroll margins (space around the\nsides of the scrolling element that should be considered\ninvisible) through this field. This can be useful when the\nplugin introduces elements that cover part of that element (for\nexample a horizontally fixed gutter).\n*/ PluginField.scrollMargins = /*@__PURE__*/ PluginField.define();\nlet nextPluginID = 0;\nconst viewPlugin = /*@__PURE__*/ _state.Facet.define();\n/**\nView plugins associate stateful values with a view. They can\ninfluence the way the content is drawn, and are notified of things\nthat happen in the view.\n*/ class ViewPlugin {\n constructor(/**\n @internal\n */ id, /**\n @internal\n */ create, /**\n @internal\n */ fields){\n this.id = id;\n this.create = create;\n this.fields = fields;\n this.extension = viewPlugin.of(this);\n }\n /**\n Define a plugin from a constructor function that creates the\n plugin's value, given an editor view.\n */ static define(create, spec) {\n let { eventHandlers , provide , decorations: decorations2 } = spec || {\n };\n let fields = [];\n if (provide) for (let provider of Array.isArray(provide) ? provide : [\n provide\n ])fields.push(provider);\n if (eventHandlers) fields.push(domEventHandlers.from((value)=>({\n plugin: value,\n handlers: eventHandlers\n })\n ));\n if (decorations2) fields.push(PluginField.decorations.from(decorations2));\n return new ViewPlugin(nextPluginID++, create, fields);\n }\n /**\n Create a plugin for a class whose constructor takes a single\n editor view as argument.\n */ static fromClass(cls, spec) {\n return ViewPlugin.define((view)=>new cls(view)\n , spec);\n }\n}\nconst domEventHandlers = /*@__PURE__*/ PluginField.define();\nclass PluginInstance {\n constructor(spec){\n this.spec = spec;\n // When starting an update, all plugins have this field set to the\n // update object, indicating they need to be updated. When finished\n // updating, it is set to `false`. Retrieving a plugin that needs to\n // be updated with `view.plugin` forces an eager update.\n this.mustUpdate = null;\n // This is null when the plugin is initially created, but\n // initialized on the first update.\n this.value = null;\n }\n takeField(type, target) {\n if (this.spec) {\n for (let { field , get } of this.spec.fields)if (field == type) target.push(get(this.value));\n }\n }\n update(view) {\n if (!this.value) {\n if (this.spec) try {\n this.value = this.spec.create(view);\n } catch (e) {\n logException(view.state, e, \"CodeMirror plugin crashed\");\n this.deactivate();\n }\n } else if (this.mustUpdate) {\n let update = this.mustUpdate;\n this.mustUpdate = null;\n if (this.value.update) try {\n this.value.update(update);\n } catch (e) {\n logException(update.state, e, \"CodeMirror plugin crashed\");\n if (this.value.destroy) try {\n this.value.destroy();\n } catch (_) {\n }\n this.deactivate();\n }\n }\n return this;\n }\n destroy(view) {\n var _a;\n if ((_a = this.value) === null || _a === void 0 ? void 0 : _a.destroy) try {\n this.value.destroy();\n } catch (e) {\n logException(view.state, e, \"CodeMirror plugin crashed\");\n }\n }\n deactivate() {\n this.spec = this.value = null;\n }\n}\nconst editorAttributes = /*@__PURE__*/ _state.Facet.define();\nconst contentAttributes = /*@__PURE__*/ _state.Facet.define();\n// Provide decorations\nconst decorations = /*@__PURE__*/ _state.Facet.define();\nconst styleModule = /*@__PURE__*/ _state.Facet.define();\nclass ChangedRange {\n constructor(fromA, toA, fromB, toB){\n this.fromA = fromA;\n this.toA = toA;\n this.fromB = fromB;\n this.toB = toB;\n }\n join(other) {\n return new ChangedRange(Math.min(this.fromA, other.fromA), Math.max(this.toA, other.toA), Math.min(this.fromB, other.fromB), Math.max(this.toB, other.toB));\n }\n addToSet(set) {\n let i = set.length, me = this;\n for(; i > 0; i--){\n let range = set[i - 1];\n if (range.fromA > me.toA) continue;\n if (range.toA < me.fromA) break;\n me = me.join(range);\n set.splice(i - 1, 1);\n }\n set.splice(i, 0, me);\n return set;\n }\n static extendWithRanges(diff, ranges) {\n if (ranges.length == 0) return diff;\n let result = [];\n for(let dI = 0, rI = 0, posA = 0, posB = 0;; dI++){\n let next = dI == diff.length ? null : diff[dI], off = posA - posB;\n let end = next ? next.fromB : 1000000000;\n while(rI < ranges.length && ranges[rI] < end){\n let from = ranges[rI], to = ranges[rI + 1];\n let fromB = Math.max(posB, from), toB = Math.min(end, to);\n if (fromB <= toB) new ChangedRange(fromB + off, toB + off, fromB, toB).addToSet(result);\n if (to > end) break;\n else rI += 2;\n }\n if (!next) return result;\n new ChangedRange(next.fromA, next.toA, next.fromB, next.toB).addToSet(result);\n posA = next.toA;\n posB = next.toB;\n }\n }\n}\n/**\nView [plugins](https://codemirror.net/6/docs/ref/#view.ViewPlugin) are given instances of this\nclass, which describe what happened, whenever the view is updated.\n*/ class ViewUpdate {\n /**\n @internal\n */ constructor(/**\n The editor view that the update is associated with.\n */ view, /**\n The new editor state.\n */ state, /**\n The transactions involved in the update. May be empty.\n */ transactions = none){\n this.view = view;\n this.state = state;\n this.transactions = transactions;\n /**\n @internal\n */ this.flags = 0;\n this.startState = view.state;\n this.changes = _state.ChangeSet.empty(this.startState.doc.length);\n for (let tr of transactions)this.changes = this.changes.compose(tr.changes);\n let changedRanges = [];\n this.changes.iterChangedRanges((fromA, toA, fromB, toB)=>changedRanges.push(new ChangedRange(fromA, toA, fromB, toB))\n );\n this.changedRanges = changedRanges;\n let focus = view.hasFocus;\n if (focus != view.inputState.notifiedFocused) {\n view.inputState.notifiedFocused = focus;\n this.flags |= 1 /* Focus */ ;\n }\n }\n /**\n Tells you whether the [viewport](https://codemirror.net/6/docs/ref/#view.EditorView.viewport) or\n [visible ranges](https://codemirror.net/6/docs/ref/#view.EditorView.visibleRanges) changed in this\n update.\n */ get viewportChanged() {\n return (this.flags & 4 /* Viewport */ ) > 0;\n }\n /**\n Indicates whether the height of an element in the editor changed\n in this update.\n */ get heightChanged() {\n return (this.flags & 2 /* Height */ ) > 0;\n }\n /**\n Returns true when the document was modified or the size of the\n editor, or elements within the editor, changed.\n */ get geometryChanged() {\n return this.docChanged || (this.flags & 10 /* Height */ ) > 0;\n }\n /**\n True when this update indicates a focus change.\n */ get focusChanged() {\n return (this.flags & 1 /* Focus */ ) > 0;\n }\n /**\n Whether the document changed in this update.\n */ get docChanged() {\n return !this.changes.empty;\n }\n /**\n Whether the selection was explicitly set in this update.\n */ get selectionSet() {\n return this.transactions.some((tr)=>tr.selection\n );\n }\n /**\n @internal\n */ get empty() {\n return this.flags == 0 && this.transactions.length == 0;\n }\n}\n/**\nUsed to indicate [text direction](https://codemirror.net/6/docs/ref/#view.EditorView.textDirection).\n*/ var Direction = /*@__PURE__*/ function(Direction1) {\n // (These are chosen to match the base levels, in bidi algorithm\n // terms, of spans in that direction.)\n /**\n Left-to-right.\n */ Direction1[Direction1[\"LTR\"] = 0] = \"LTR\";\n /**\n Right-to-left.\n */ Direction1[Direction1[\"RTL\"] = 1] = \"RTL\";\n return Direction1;\n}(Direction || (Direction = {\n}));\nconst LTR = Direction.LTR, RTL = Direction.RTL;\n// Decode a string with each type encoded as log2(type)\nfunction dec(str) {\n let result = [];\n for(let i = 0; i < str.length; i++)result.push(1 << +str[i]);\n return result;\n}\n// Character types for codepoints 0 to 0xf8\nconst LowTypes = /*@__PURE__*/ dec(\"88888888888888888888888888888888888666888888787833333333337888888000000000000000000000000008888880000000000000000000000000088888888888888888888888888888888888887866668888088888663380888308888800000000000000000000000800000000000000000000000000000008\");\n// Character types for codepoints 0x600 to 0x6f9\nconst ArabicTypes = /*@__PURE__*/ dec(\"4444448826627288999999999992222222222222222222222222222222222222222222222229999999999999999999994444444444644222822222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222999999949999999229989999223333333333\");\nconst Brackets = /*@__PURE__*/ Object.create(null), BracketStack = [];\n// There's a lot more in\n// https://www.unicode.org/Public/UCD/latest/ucd/BidiBrackets.txt,\n// which are left out to keep code size down.\nfor (let p of [\n \"()\",\n \"[]\",\n \"{}\"\n]){\n let l = /*@__PURE__*/ p.charCodeAt(0), r = /*@__PURE__*/ p.charCodeAt(1);\n Brackets[l] = r;\n Brackets[r] = -l;\n}\nfunction charType(ch) {\n return ch <= 247 ? LowTypes[ch] : 1424 <= ch && ch <= 1524 ? 2 /* R */ : 1536 <= ch && ch <= 1785 ? ArabicTypes[ch - 1536] : 1774 <= ch && ch <= 2220 ? 4 /* AL */ : 8192 <= ch && ch <= 8203 ? 256 /* NI */ : ch == 8204 ? 256 /* NI */ : 1 /* L */ ;\n}\nconst BidiRE = /[\\u0590-\\u05f4\\u0600-\\u06ff\\u0700-\\u08ac]/;\n/**\nRepresents a contiguous range of text that has a single direction\n(as in left-to-right or right-to-left).\n*/ class BidiSpan {\n /**\n @internal\n */ constructor(/**\n The start of the span (relative to the start of the line).\n */ from, /**\n The end of the span.\n */ to, /**\n The [\"bidi\n level\"](https://unicode.org/reports/tr9/#Basic_Display_Algorithm)\n of the span (in this context, 0 means\n left-to-right, 1 means right-to-left, 2 means left-to-right\n number inside right-to-left text).\n */ level){\n this.from = from;\n this.to = to;\n this.level = level;\n }\n /**\n The direction of this span.\n */ get dir() {\n return this.level % 2 ? RTL : LTR;\n }\n /**\n @internal\n */ side(end, dir) {\n return this.dir == dir == end ? this.to : this.from;\n }\n /**\n @internal\n */ static find(order, index, level, assoc) {\n let maybe = -1;\n for(let i = 0; i < order.length; i++){\n let span = order[i];\n if (span.from <= index && span.to >= index) {\n if (span.level == level) return i;\n // When multiple spans match, if assoc != 0, take the one that\n // covers that side, otherwise take the one with the minimum\n // level.\n if (maybe < 0 || (assoc != 0 ? assoc < 0 ? span.from < index : span.to > index : order[maybe].level > span.level)) maybe = i;\n }\n }\n if (maybe < 0) throw new RangeError(\"Index out of range\");\n return maybe;\n }\n}\n// Reused array of character types\nconst types = [];\nfunction computeOrder(line, direction) {\n let len = line.length, outerType = direction == LTR ? 1 /* L */ : 2 /* R */ , oppositeType = direction == LTR ? 2 /* R */ : 1 /* L */ ;\n if (!line || outerType == 1 /* L */ && !BidiRE.test(line)) return trivialOrder(len);\n // W1. Examine each non-spacing mark (NSM) in the level run, and\n // change the type of the NSM to the type of the previous\n // character. If the NSM is at the start of the level run, it will\n // get the type of sor.\n // W2. Search backwards from each instance of a European number\n // until the first strong type (R, L, AL, or sor) is found. If an\n // AL is found, change the type of the European number to Arabic\n // number.\n // W3. Change all ALs to R.\n // (Left after this: L, R, EN, AN, ET, CS, NI)\n for(let i = 0, prev = outerType, prevStrong = outerType; i < len; i++){\n let type = charType(line.charCodeAt(i));\n if (type == 512 /* NSM */ ) type = prev;\n else if (type == 8 /* EN */ && prevStrong == 4 /* AL */ ) type = 16 /* AN */ ;\n types[i] = type == 4 /* AL */ ? 2 /* R */ : type;\n if (type & 7 /* Strong */ ) prevStrong = type;\n prev = type;\n }\n // W5. A sequence of European terminators adjacent to European\n // numbers changes to all European numbers.\n // W6. Otherwise, separators and terminators change to Other\n // Neutral.\n // W7. Search backwards from each instance of a European number\n // until the first strong type (R, L, or sor) is found. If an L is\n // found, then change the type of the European number to L.\n // (Left after this: L, R, EN+AN, NI)\n for(let i2 = 0, prev1 = outerType, prevStrong1 = outerType; i2 < len; i2++){\n let type = types[i2];\n if (type == 128 /* CS */ ) {\n if (i2 < len - 1 && prev1 == types[i2 + 1] && prev1 & 24 /* Num */ ) type = types[i2] = prev1;\n else types[i2] = 256 /* NI */ ;\n } else if (type == 64 /* ET */ ) {\n let end = i2 + 1;\n while(end < len && types[end] == 64 /* ET */ )end++;\n let replace = i2 && prev1 == 8 /* EN */ || end < len && types[end] == 8 /* EN */ ? prevStrong1 == 1 /* L */ ? 1 /* L */ : 8 /* EN */ : 256 /* NI */ ;\n for(let j = i2; j < end; j++)types[j] = replace;\n i2 = end - 1;\n } else if (type == 8 /* EN */ && prevStrong1 == 1 /* L */ ) types[i2] = 1 /* L */ ;\n prev1 = type;\n if (type & 7 /* Strong */ ) prevStrong1 = type;\n }\n // N0. Process bracket pairs in an isolating run sequence\n // sequentially in the logical order of the text positions of the\n // opening paired brackets using the logic given below. Within this\n // scope, bidirectional types EN and AN are treated as R.\n for(let i3 = 0, sI = 0, context = 0, ch, br, type; i3 < len; i3++){\n // Keeps [startIndex, type, strongSeen] triples for each open\n // bracket on BracketStack.\n if (br = Brackets[ch = line.charCodeAt(i3)]) {\n if (br < 0) {\n for(let sJ = sI - 3; sJ >= 0; sJ -= 3)if (BracketStack[sJ + 1] == -br) {\n let flags = BracketStack[sJ + 2];\n let type = flags & 2 /* EmbedInside */ ? outerType : !(flags & 4 /* OppositeInside */ ) ? 0 : flags & 1 /* OppositeBefore */ ? oppositeType : outerType;\n if (type) types[i3] = types[BracketStack[sJ]] = type;\n sI = sJ;\n break;\n }\n } else if (BracketStack.length == 189 /* MaxDepth */ ) break;\n else {\n BracketStack[sI++] = i3;\n BracketStack[sI++] = ch;\n BracketStack[sI++] = context;\n }\n } else if ((type = types[i3]) == 2 /* R */ || type == 1 /* L */ ) {\n let embed = type == outerType;\n context = embed ? 0 : 1 /* OppositeBefore */ ;\n for(let sJ = sI - 3; sJ >= 0; sJ -= 3){\n let cur = BracketStack[sJ + 2];\n if (cur & 2 /* EmbedInside */ ) break;\n if (embed) BracketStack[sJ + 2] |= 2 /* EmbedInside */ ;\n else {\n if (cur & 4 /* OppositeInside */ ) break;\n BracketStack[sJ + 2] |= 4 /* OppositeInside */ ;\n }\n }\n }\n }\n // N1. A sequence of neutrals takes the direction of the\n // surrounding strong text if the text on both sides has the same\n // direction. European and Arabic numbers act as if they were R in\n // terms of their influence on neutrals. Start-of-level-run (sor)\n // and end-of-level-run (eor) are used at level run boundaries.\n // N2. Any remaining neutrals take the embedding direction.\n // (Left after this: L, R, EN+AN)\n for(let i4 = 0; i4 < len; i4++)if (types[i4] == 256 /* NI */ ) {\n let end = i4 + 1;\n while(end < len && types[end] == 256 /* NI */ )end++;\n let beforeL = (i4 ? types[i4 - 1] : outerType) == 1 /* L */ ;\n let afterL = (end < len ? types[end] : outerType) == 1 /* L */ ;\n let replace = beforeL == afterL ? beforeL ? 1 /* L */ : 2 /* R */ : outerType;\n for(let j = i4; j < end; j++)types[j] = replace;\n i4 = end - 1;\n }\n // Here we depart from the documented algorithm, in order to avoid\n // building up an actual levels array. Since there are only three\n // levels (0, 1, 2) in an implementation that doesn't take\n // explicit embedding into account, we can build up the order on\n // the fly, without following the level-based algorithm.\n let order = [];\n if (outerType == 1 /* L */ ) for(let i5 = 0; i5 < len;){\n let start = i5, rtl = types[i5++] != 1 /* L */ ;\n while(i5 < len && rtl == (types[i5] != 1 /* L */ ))i5++;\n if (rtl) for(let j = i5; j > start;){\n let end = j, l = types[--j] != 2 /* R */ ;\n while(j > start && l == (types[j - 1] != 2 /* R */ ))j--;\n order.push(new BidiSpan(j, end, l ? 2 : 1));\n }\n else order.push(new BidiSpan(start, i5, 0));\n }\n else for(let i6 = 0; i6 < len;){\n let start = i6, rtl = types[i6++] == 2 /* R */ ;\n while(i6 < len && rtl == (types[i6] == 2 /* R */ ))i6++;\n order.push(new BidiSpan(start, i6, rtl ? 1 : 2));\n }\n return order;\n}\nfunction trivialOrder(length) {\n return [\n new BidiSpan(0, length, 0)\n ];\n}\nlet movedOver = \"\";\nfunction moveVisually(line, order, dir, start, forward) {\n var _a;\n let startIndex = start.head - line.from, spanI = -1;\n if (startIndex == 0) {\n if (!forward || !line.length) return null;\n if (order[0].level != dir) {\n startIndex = order[0].side(false, dir);\n spanI = 0;\n }\n } else if (startIndex == line.length) {\n if (forward) return null;\n let last = order[order.length - 1];\n if (last.level != dir) {\n startIndex = last.side(true, dir);\n spanI = order.length - 1;\n }\n }\n if (spanI < 0) spanI = BidiSpan.find(order, startIndex, (_a = start.bidiLevel) !== null && _a !== void 0 ? _a : -1, start.assoc);\n let span = order[spanI];\n // End of span. (But not end of line--that was checked for above.)\n if (startIndex == span.side(forward, dir)) {\n span = order[spanI += forward ? 1 : -1];\n startIndex = span.side(!forward, dir);\n }\n let indexForward = forward == (span.dir == dir);\n let nextIndex = _text.findClusterBreak(line.text, startIndex, indexForward);\n movedOver = line.text.slice(Math.min(startIndex, nextIndex), Math.max(startIndex, nextIndex));\n if (nextIndex != span.side(forward, dir)) return _state.EditorSelection.cursor(nextIndex + line.from, indexForward ? -1 : 1, span.level);\n let nextSpan = spanI == (forward ? order.length - 1 : 0) ? null : order[spanI + (forward ? 1 : -1)];\n if (!nextSpan && span.level != dir) return _state.EditorSelection.cursor(forward ? line.to : line.from, forward ? -1 : 1, dir);\n if (nextSpan && nextSpan.level < span.level) return _state.EditorSelection.cursor(nextSpan.side(!forward, dir) + line.from, forward ? 1 : -1, nextSpan.level);\n return _state.EditorSelection.cursor(nextIndex + line.from, forward ? -1 : 1, span.level);\n}\nconst LineBreakPlaceholder = \"\\uffff\";\nclass DOMReader {\n constructor(points, state){\n this.points = points;\n this.text = \"\";\n this.lineSeparator = state.facet(_state.EditorState.lineSeparator);\n }\n append(text) {\n this.text += text;\n }\n lineBreak() {\n this.text += LineBreakPlaceholder;\n }\n readRange(start, end) {\n if (!start) return this;\n let parent = start.parentNode;\n for(let cur = start;;){\n this.findPointBefore(parent, cur);\n this.readNode(cur);\n let next = cur.nextSibling;\n if (next == end) break;\n let view = ContentView.get(cur), nextView = ContentView.get(next);\n if (view && nextView ? view.breakAfter : (view ? view.breakAfter : isBlockElement(cur)) || isBlockElement(next) && (cur.nodeName != \"BR\" || cur.cmIgnore)) this.lineBreak();\n cur = next;\n }\n this.findPointBefore(parent, end);\n return this;\n }\n readTextNode(node) {\n let text = node.nodeValue;\n for (let point of this.points)if (point.node == node) point.pos = this.text.length + Math.min(point.offset, text.length);\n for(let off = 0, re = this.lineSeparator ? null : /\\r\\n?|\\n/g;;){\n let nextBreak = -1, breakSize = 1, m;\n if (this.lineSeparator) {\n nextBreak = text.indexOf(this.lineSeparator, off);\n breakSize = this.lineSeparator.length;\n } else if (m = re.exec(text)) {\n nextBreak = m.index;\n breakSize = m[0].length;\n }\n this.append(text.slice(off, nextBreak < 0 ? text.length : nextBreak));\n if (nextBreak < 0) break;\n this.lineBreak();\n if (breakSize > 1) {\n for (let point of this.points)if (point.node == node && point.pos > this.text.length) point.pos -= breakSize - 1;\n }\n off = nextBreak + breakSize;\n }\n }\n readNode(node) {\n if (node.cmIgnore) return;\n let view = ContentView.get(node);\n let fromView = view && view.overrideDOMText;\n if (fromView != null) {\n this.findPointInside(node, fromView.length);\n for(let i = fromView.iter(); !i.next().done;)if (i.lineBreak) this.lineBreak();\n else this.append(i.value);\n } else if (node.nodeType == 3) this.readTextNode(node);\n else if (node.nodeName == \"BR\") {\n if (node.nextSibling) this.lineBreak();\n } else if (node.nodeType == 1) this.readRange(node.firstChild, null);\n }\n findPointBefore(node, next) {\n for (let point of this.points)if (point.node == node && node.childNodes[point.offset] == next) point.pos = this.text.length;\n }\n findPointInside(node, maxLen) {\n for (let point of this.points)if (node.nodeType == 3 ? point.node == node : node.contains(point.node)) point.pos = this.text.length + Math.min(maxLen, point.offset);\n }\n}\nfunction isBlockElement(node) {\n return node.nodeType == 1 && /^(DIV|P|LI|UL|OL|BLOCKQUOTE|DD|DT|H\\d|SECTION|PRE)$/.test(node.nodeName);\n}\nclass DOMPoint {\n constructor(node, offset){\n this.node = node;\n this.offset = offset;\n this.pos = -1;\n }\n}\nclass DocView extends ContentView {\n constructor(view){\n super();\n this.view = view;\n this.compositionDeco = Decoration.none;\n this.decorations = [];\n this.pluginDecorationLength = 0;\n // Track a minimum width for the editor. When measuring sizes in\n // measureVisibleLineHeights, this is updated to point at the width\n // of a given element and its extent in the document. When a change\n // happens in that range, these are reset. That way, once we've seen\n // a line/element of a given length, we keep the editor wide enough\n // to fit at least that element, until it is changed, at which point\n // we forget it again.\n this.minWidth = 0;\n this.minWidthFrom = 0;\n this.minWidthTo = 0;\n // Track whether the DOM selection was set in a lossy way, so that\n // we don't mess it up when reading it back it\n this.impreciseAnchor = null;\n this.impreciseHead = null;\n this.forceSelection = false;\n // Used by the resize observer to ignore resizes that we caused\n // ourselves\n this.lastUpdate = Date.now();\n this.setDOM(view.contentDOM);\n this.children = [\n new LineView\n ];\n this.children[0].setParent(this);\n this.updateDeco();\n this.updateInner([\n new ChangedRange(0, 0, 0, view.state.doc.length)\n ], 0);\n }\n get root() {\n return this.view.root;\n }\n get editorView() {\n return this.view;\n }\n get length() {\n return this.view.state.doc.length;\n }\n // Update the document view to a given state. scrollIntoView can be\n // used as a hint to compute a new viewport that includes that\n // position, if we know the editor is going to scroll that position\n // into view.\n update(update) {\n let changedRanges = update.changedRanges;\n if (this.minWidth > 0 && changedRanges.length) {\n if (!changedRanges.every(({ fromA , toA })=>toA < this.minWidthFrom || fromA > this.minWidthTo\n )) this.minWidth = this.minWidthFrom = this.minWidthTo = 0;\n else {\n this.minWidthFrom = update.changes.mapPos(this.minWidthFrom, 1);\n this.minWidthTo = update.changes.mapPos(this.minWidthTo, 1);\n }\n }\n if (this.view.inputState.composing < 0) this.compositionDeco = Decoration.none;\n else if (update.transactions.length || this.dirty) this.compositionDeco = computeCompositionDeco(this.view, update.changes);\n // When the DOM nodes around the selection are moved to another\n // parent, Chrome sometimes reports a different selection through\n // getSelection than the one that it actually shows to the user.\n // This forces a selection update when lines are joined to work\n // around that. Issue #54\n if ((browser.ie || browser.chrome) && !this.compositionDeco.size && update && update.state.doc.lines != update.startState.doc.lines) this.forceSelection = true;\n let prevDeco = this.decorations, deco = this.updateDeco();\n let decoDiff = findChangedDeco(prevDeco, deco, update.changes);\n changedRanges = ChangedRange.extendWithRanges(changedRanges, decoDiff);\n if (this.dirty == 0 /* Not */ && changedRanges.length == 0) return false;\n else {\n this.updateInner(changedRanges, update.startState.doc.length);\n if (update.transactions.length) this.lastUpdate = Date.now();\n return true;\n }\n }\n // Used by update and the constructor do perform the actual DOM\n // update\n updateInner(changes, oldLength) {\n this.view.viewState.mustMeasureContent = true;\n this.updateChildren(changes, oldLength);\n let { observer } = this.view;\n observer.ignore(()=>{\n // Lock the height during redrawing, since Chrome sometimes\n // messes with the scroll position during DOM mutation (though\n // no relayout is triggered and I cannot imagine how it can\n // recompute the scroll position without a layout)\n this.dom.style.height = this.view.viewState.contentHeight + \"px\";\n this.dom.style.minWidth = this.minWidth ? this.minWidth + \"px\" : \"\";\n // Chrome will sometimes, when DOM mutations occur directly\n // around the selection, get confused and report a different\n // selection from the one it displays (issue #218). This tries\n // to detect that situation.\n let track = browser.chrome || browser.ios ? {\n node: observer.selectionRange.focusNode,\n written: false\n } : undefined;\n this.sync(track);\n this.dirty = 0 /* Not */ ;\n if (track && (track.written || observer.selectionRange.focusNode != track.node)) this.forceSelection = true;\n this.dom.style.height = \"\";\n });\n let gaps = [];\n if (this.view.viewport.from || this.view.viewport.to < this.view.state.doc.length) {\n for (let child of this.children)if (child instanceof BlockWidgetView && child.widget instanceof BlockGapWidget) gaps.push(child.dom);\n }\n observer.updateGaps(gaps);\n }\n updateChildren(changes, oldLength) {\n let cursor = this.childCursor(oldLength);\n for(let i = changes.length - 1;; i--){\n let next = i >= 0 ? changes[i] : null;\n if (!next) break;\n let { fromA , toA , fromB , toB } = next;\n let { content , breakAtStart , openStart , openEnd } = ContentBuilder.build(this.view.state.doc, fromB, toB, this.decorations, this.pluginDecorationLength);\n let { i: toI , off: toOff } = cursor.findPos(toA, 1);\n let { i: fromI , off: fromOff } = cursor.findPos(fromA, -1);\n replaceRange(this, fromI, fromOff, toI, toOff, content, breakAtStart, openStart, openEnd);\n }\n }\n // Sync the DOM selection to this.state.selection\n updateSelection(mustRead = false, fromPointer = false) {\n if (mustRead) this.view.observer.readSelectionRange();\n if (!(fromPointer || this.mayControlSelection()) || browser.ios && this.view.inputState.rapidCompositionStart) return;\n let force = this.forceSelection;\n this.forceSelection = false;\n let main = this.view.state.selection.main;\n // FIXME need to handle the case where the selection falls inside a block range\n let anchor = this.domAtPos(main.anchor);\n let head = main.empty ? anchor : this.domAtPos(main.head);\n // Always reset on Firefox when next to an uneditable node to\n // avoid invisible cursor bugs (#111)\n if (browser.gecko && main.empty && betweenUneditable(anchor)) {\n let dummy = document.createTextNode(\"\");\n this.view.observer.ignore(()=>anchor.node.insertBefore(dummy, anchor.node.childNodes[anchor.offset] || null)\n );\n anchor = head = new DOMPos(dummy, 0);\n force = true;\n }\n let domSel = this.view.observer.selectionRange;\n // If the selection is already here, or in an equivalent position, don't touch it\n if (force || !domSel.focusNode || !isEquivalentPosition(anchor.node, anchor.offset, domSel.anchorNode, domSel.anchorOffset) || !isEquivalentPosition(head.node, head.offset, domSel.focusNode, domSel.focusOffset)) {\n this.view.observer.ignore(()=>{\n // Chrome Android will hide the virtual keyboard when tapping\n // inside an uneditable node, and not bring it back when we\n // move the cursor to its proper position. This tries to\n // restore the keyboard by cycling focus.\n if (browser.android && browser.chrome && this.dom.contains(domSel.focusNode) && inUneditable(domSel.focusNode, this.dom)) {\n this.dom.blur();\n this.dom.focus({\n preventScroll: true\n });\n }\n let rawSel = getSelection(this.root);\n if (main.empty) {\n // Work around https://bugzilla.mozilla.org/show_bug.cgi?id=1612076\n if (browser.gecko) {\n let nextTo = nextToUneditable(anchor.node, anchor.offset);\n if (nextTo && nextTo != 3 /* After */ ) {\n let text = nearbyTextNode(anchor.node, anchor.offset, nextTo == 1 /* Before */ ? 1 : -1);\n if (text) anchor = new DOMPos(text, nextTo == 1 /* Before */ ? 0 : text.nodeValue.length);\n }\n }\n rawSel.collapse(anchor.node, anchor.offset);\n if (main.bidiLevel != null && domSel.cursorBidiLevel != null) domSel.cursorBidiLevel = main.bidiLevel;\n } else if (rawSel.extend) {\n // Selection.extend can be used to create an 'inverted' selection\n // (one where the focus is before the anchor), but not all\n // browsers support it yet.\n rawSel.collapse(anchor.node, anchor.offset);\n rawSel.extend(head.node, head.offset);\n } else {\n // Primitive (IE) way\n let range = document.createRange();\n if (main.anchor > main.head) [anchor, head] = [\n head,\n anchor\n ];\n range.setEnd(head.node, head.offset);\n range.setStart(anchor.node, anchor.offset);\n rawSel.removeAllRanges();\n rawSel.addRange(range);\n }\n });\n this.view.observer.setSelectionRange(anchor, head);\n }\n this.impreciseAnchor = anchor.precise ? null : new DOMPos(domSel.anchorNode, domSel.anchorOffset);\n this.impreciseHead = head.precise ? null : new DOMPos(domSel.focusNode, domSel.focusOffset);\n }\n enforceCursorAssoc() {\n if (this.compositionDeco.size) return;\n let cursor = this.view.state.selection.main;\n let sel = getSelection(this.root);\n if (!cursor.empty || !cursor.assoc || !sel.modify) return;\n let line = LineView.find(this, cursor.head);\n if (!line) return;\n let lineStart = line.posAtStart;\n if (cursor.head == lineStart || cursor.head == lineStart + line.length) return;\n let before = this.coordsAt(cursor.head, -1), after = this.coordsAt(cursor.head, 1);\n if (!before || !after || before.bottom > after.top) return;\n let dom = this.domAtPos(cursor.head + cursor.assoc);\n sel.collapse(dom.node, dom.offset);\n sel.modify(\"move\", cursor.assoc < 0 ? \"forward\" : \"backward\", \"lineboundary\");\n }\n mayControlSelection() {\n return this.view.state.facet(editable) ? this.root.activeElement == this.dom : hasSelection(this.dom, this.view.observer.selectionRange);\n }\n nearest(dom) {\n for(let cur = dom; cur;){\n let domView = ContentView.get(cur);\n if (domView && domView.rootView == this) return domView;\n cur = cur.parentNode;\n }\n return null;\n }\n posFromDOM(node, offset) {\n let view = this.nearest(node);\n if (!view) throw new RangeError(\"Trying to find position for a DOM position outside of the document\");\n return view.localPosFromDOM(node, offset) + view.posAtStart;\n }\n domAtPos(pos) {\n let { i , off } = this.childCursor().findPos(pos, -1);\n for(; i < this.children.length - 1;){\n let child = this.children[i];\n if (off < child.length || child instanceof LineView) break;\n i++;\n off = 0;\n }\n return this.children[i].domAtPos(off);\n }\n coordsAt(pos, side) {\n for(let off = this.length, i = this.children.length - 1;; i--){\n let child = this.children[i], start = off - child.breakAfter - child.length;\n if (pos > start || pos == start && child.type != BlockType.WidgetBefore && child.type != BlockType.WidgetAfter && (!i || side == 2 || this.children[i - 1].breakAfter || this.children[i - 1].type == BlockType.WidgetBefore && side > -2)) return child.coordsAt(pos - start, side);\n off = start;\n }\n }\n measureVisibleLineHeights() {\n let result = [], { from , to } = this.view.viewState.viewport;\n let contentWidth = this.view.contentDOM.clientWidth;\n let isWider = contentWidth > Math.max(this.view.scrollDOM.clientWidth, this.minWidth) + 1;\n let widest = -1;\n for(let pos = 0, i = 0; i < this.children.length; i++){\n let child = this.children[i], end = pos + child.length;\n if (end > to) break;\n if (pos >= from) {\n let childRect = child.dom.getBoundingClientRect();\n result.push(childRect.height);\n if (isWider) {\n let last = child.dom.lastChild;\n let rects = last ? clientRectsFor(last) : [];\n if (rects.length) {\n let rect = rects[rects.length - 1];\n let width = this.view.textDirection == Direction.LTR ? rect.right - childRect.left : childRect.right - rect.left;\n if (width > widest) {\n widest = width;\n this.minWidth = contentWidth;\n this.minWidthFrom = pos;\n this.minWidthTo = end;\n }\n }\n }\n }\n pos = end + child.breakAfter;\n }\n return result;\n }\n measureTextSize() {\n for (let child of this.children)if (child instanceof LineView) {\n let measure = child.measureTextSize();\n if (measure) return measure;\n }\n // If no workable line exists, force a layout of a measurable element\n let dummy = document.createElement(\"div\"), lineHeight, charWidth;\n dummy.className = \"cm-line\";\n dummy.textContent = \"abc def ghi jkl mno pqr stu\";\n this.view.observer.ignore(()=>{\n this.dom.appendChild(dummy);\n let rect = clientRectsFor(dummy.firstChild)[0];\n lineHeight = dummy.getBoundingClientRect().height;\n charWidth = rect ? rect.width / 27 : 7;\n dummy.remove();\n });\n return {\n lineHeight,\n charWidth\n };\n }\n childCursor(pos = this.length) {\n // Move back to start of last element when possible, so that\n // `ChildCursor.findPos` doesn't have to deal with the edge case\n // of being after the last element.\n let i = this.children.length;\n if (i) pos -= this.children[--i].length;\n return new ChildCursor(this.children, pos, i);\n }\n computeBlockGapDeco() {\n let deco = [], vs = this.view.viewState;\n for(let pos = 0, i = 0;; i++){\n let next = i == vs.viewports.length ? null : vs.viewports[i];\n let end = next ? next.from - 1 : this.length;\n if (end > pos) {\n let height = vs.lineBlockAt(end).bottom - vs.lineBlockAt(pos).top;\n deco.push(Decoration.replace({\n widget: new BlockGapWidget(height),\n block: true,\n inclusive: true\n }).range(pos, end));\n }\n if (!next) break;\n pos = next.to + 1;\n }\n return Decoration.set(deco);\n }\n updateDeco() {\n let pluginDecorations = this.view.pluginField(PluginField.decorations);\n this.pluginDecorationLength = pluginDecorations.length;\n return this.decorations = [\n ...pluginDecorations,\n ...this.view.state.facet(decorations),\n this.compositionDeco,\n this.computeBlockGapDeco(),\n this.view.viewState.lineGapDeco\n ];\n }\n scrollIntoView(target) {\n let { range } = target;\n let rect = this.coordsAt(range.head, range.empty ? range.assoc : range.head > range.anchor ? -1 : 1), other;\n if (!rect) return;\n if (!range.empty && (other = this.coordsAt(range.anchor, range.anchor > range.head ? -1 : 1))) rect = {\n left: Math.min(rect.left, other.left),\n top: Math.min(rect.top, other.top),\n right: Math.max(rect.right, other.right),\n bottom: Math.max(rect.bottom, other.bottom)\n };\n let mLeft = 0, mRight = 0, mTop = 0, mBottom = 0;\n for (let margins of this.view.pluginField(PluginField.scrollMargins))if (margins) {\n let { left , right , top , bottom } = margins;\n if (left != null) mLeft = Math.max(mLeft, left);\n if (right != null) mRight = Math.max(mRight, right);\n if (top != null) mTop = Math.max(mTop, top);\n if (bottom != null) mBottom = Math.max(mBottom, bottom);\n }\n let targetRect = {\n left: rect.left - mLeft,\n top: rect.top - mTop,\n right: rect.right + mRight,\n bottom: rect.bottom + mBottom\n };\n scrollRectIntoView(this.view.scrollDOM, targetRect, range.head < range.anchor ? -1 : 1, target.x, target.y, target.xMargin, target.yMargin, this.view.textDirection == Direction.LTR);\n }\n}\nfunction betweenUneditable(pos) {\n return pos.node.nodeType == 1 && pos.node.firstChild && (pos.offset == 0 || pos.node.childNodes[pos.offset - 1].contentEditable == \"false\") && (pos.offset == pos.node.childNodes.length || pos.node.childNodes[pos.offset].contentEditable == \"false\");\n}\nclass BlockGapWidget extends WidgetType {\n constructor(height){\n super();\n this.height = height;\n }\n toDOM() {\n let elt = document.createElement(\"div\");\n this.updateDOM(elt);\n return elt;\n }\n eq(other) {\n return other.height == this.height;\n }\n updateDOM(elt) {\n elt.style.height = this.height + \"px\";\n return true;\n }\n get estimatedHeight() {\n return this.height;\n }\n}\nfunction compositionSurroundingNode(view) {\n let sel = view.observer.selectionRange;\n let textNode = sel.focusNode && nearbyTextNode(sel.focusNode, sel.focusOffset, 0);\n if (!textNode) return null;\n let cView = view.docView.nearest(textNode);\n if (!cView) return null;\n if (cView instanceof LineView) {\n let topNode = textNode;\n while(topNode.parentNode != cView.dom)topNode = topNode.parentNode;\n let prev = topNode.previousSibling;\n while(prev && !ContentView.get(prev))prev = prev.previousSibling;\n let pos = prev ? ContentView.get(prev).posAtEnd : cView.posAtStart;\n return {\n from: pos,\n to: pos,\n node: topNode,\n text: textNode\n };\n } else {\n for(;;){\n let { parent } = cView;\n if (!parent) return null;\n if (parent instanceof LineView) break;\n cView = parent;\n }\n let from = cView.posAtStart;\n return {\n from,\n to: from + cView.length,\n node: cView.dom,\n text: textNode\n };\n }\n}\nfunction computeCompositionDeco(view, changes) {\n let surrounding = compositionSurroundingNode(view);\n if (!surrounding) return Decoration.none;\n let { from , to , node , text: textNode } = surrounding;\n let newFrom = changes.mapPos(from, 1), newTo = Math.max(newFrom, changes.mapPos(to, -1));\n let { state } = view, text = node.nodeType == 3 ? node.nodeValue : new DOMReader([], state).readRange(node.firstChild, null).text;\n if (newTo - newFrom < text.length) {\n if (state.doc.sliceString(newFrom, Math.min(state.doc.length, newFrom + text.length), LineBreakPlaceholder) == text) newTo = newFrom + text.length;\n else if (state.doc.sliceString(Math.max(0, newTo - text.length), newTo, LineBreakPlaceholder) == text) newFrom = newTo - text.length;\n else return Decoration.none;\n } else if (state.doc.sliceString(newFrom, newTo, LineBreakPlaceholder) != text) return Decoration.none;\n return Decoration.set(Decoration.replace({\n widget: new CompositionWidget(node, textNode)\n }).range(newFrom, newTo));\n}\nclass CompositionWidget extends WidgetType {\n constructor(top, text){\n super();\n this.top = top;\n this.text = text;\n }\n eq(other) {\n return this.top == other.top && this.text == other.text;\n }\n toDOM() {\n return this.top;\n }\n ignoreEvent() {\n return false;\n }\n get customView() {\n return CompositionView;\n }\n}\nfunction nearbyTextNode(node, offset, side) {\n for(;;){\n if (node.nodeType == 3) return node;\n if (node.nodeType == 1 && offset > 0 && side <= 0) {\n node = node.childNodes[offset - 1];\n offset = maxOffset(node);\n } else if (node.nodeType == 1 && offset < node.childNodes.length && side >= 0) {\n node = node.childNodes[offset];\n offset = 0;\n } else return null;\n }\n}\nfunction nextToUneditable(node, offset) {\n if (node.nodeType != 1) return 0;\n return (offset && node.childNodes[offset - 1].contentEditable == \"false\" ? 1 /* Before */ : 0) | (offset < node.childNodes.length && node.childNodes[offset].contentEditable == \"false\" ? 2 /* After */ : 0);\n}\nclass DecorationComparator$1 {\n constructor(){\n this.changes = [];\n }\n compareRange(from, to) {\n addRange(from, to, this.changes);\n }\n comparePoint(from, to) {\n addRange(from, to, this.changes);\n }\n}\nfunction findChangedDeco(a, b, diff) {\n let comp = new DecorationComparator$1;\n _rangeset.RangeSet.compare(a, b, diff, comp);\n return comp.changes;\n}\nfunction inUneditable(node, inside1) {\n for(let cur = node; cur && cur != inside1; cur = cur.assignedSlot || cur.parentNode){\n if (cur.nodeType == 1 && cur.contentEditable == 'false') return true;\n }\n return false;\n}\nfunction groupAt(state, pos, bias = 1) {\n let categorize = state.charCategorizer(pos);\n let line = state.doc.lineAt(pos), linePos = pos - line.from;\n if (line.length == 0) return _state.EditorSelection.cursor(pos);\n if (linePos == 0) bias = 1;\n else if (linePos == line.length) bias = -1;\n let from = linePos, to = linePos;\n if (bias < 0) from = _text.findClusterBreak(line.text, linePos, false);\n else to = _text.findClusterBreak(line.text, linePos);\n let cat = categorize(line.text.slice(from, to));\n while(from > 0){\n let prev = _text.findClusterBreak(line.text, from, false);\n if (categorize(line.text.slice(prev, from)) != cat) break;\n from = prev;\n }\n while(to < line.length){\n let next = _text.findClusterBreak(line.text, to);\n if (categorize(line.text.slice(to, next)) != cat) break;\n to = next;\n }\n return _state.EditorSelection.range(from + line.from, to + line.from);\n}\n// Search the DOM for the {node, offset} position closest to the given\n// coordinates. Very inefficient and crude, but can usually be avoided\n// by calling caret(Position|Range)FromPoint instead.\nfunction getdx(x, rect) {\n return rect.left > x ? rect.left - x : Math.max(0, x - rect.right);\n}\nfunction getdy(y, rect) {\n return rect.top > y ? rect.top - y : Math.max(0, y - rect.bottom);\n}\nfunction yOverlap(a, b) {\n return a.top < b.bottom - 1 && a.bottom > b.top + 1;\n}\nfunction upTop(rect, top) {\n return top < rect.top ? {\n top,\n left: rect.left,\n right: rect.right,\n bottom: rect.bottom\n } : rect;\n}\nfunction upBot(rect, bottom) {\n return bottom > rect.bottom ? {\n top: rect.top,\n left: rect.left,\n right: rect.right,\n bottom\n } : rect;\n}\nfunction domPosAtCoords(parent, x, y) {\n let closest, closestRect, closestX, closestY;\n let above, below, aboveRect, belowRect;\n for(let child = parent.firstChild; child; child = child.nextSibling){\n let rects = clientRectsFor(child);\n for(let i = 0; i < rects.length; i++){\n let rect = rects[i];\n if (closestRect && yOverlap(closestRect, rect)) rect = upTop(upBot(rect, closestRect.bottom), closestRect.top);\n let dx = getdx(x, rect), dy = getdy(y, rect);\n if (dx == 0 && dy == 0) return child.nodeType == 3 ? domPosInText(child, x, y) : domPosAtCoords(child, x, y);\n if (!closest || closestY > dy || closestY == dy && closestX > dx) {\n closest = child;\n closestRect = rect;\n closestX = dx;\n closestY = dy;\n }\n if (dx == 0) {\n if (y > rect.bottom && (!aboveRect || aboveRect.bottom < rect.bottom)) {\n above = child;\n aboveRect = rect;\n } else if (y < rect.top && (!belowRect || belowRect.top > rect.top)) {\n below = child;\n belowRect = rect;\n }\n } else if (aboveRect && yOverlap(aboveRect, rect)) aboveRect = upBot(aboveRect, rect.bottom);\n else if (belowRect && yOverlap(belowRect, rect)) belowRect = upTop(belowRect, rect.top);\n }\n }\n if (aboveRect && aboveRect.bottom >= y) {\n closest = above;\n closestRect = aboveRect;\n } else if (belowRect && belowRect.top <= y) {\n closest = below;\n closestRect = belowRect;\n }\n if (!closest) return {\n node: parent,\n offset: 0\n };\n let clipX = Math.max(closestRect.left, Math.min(closestRect.right, x));\n if (closest.nodeType == 3) return domPosInText(closest, clipX, y);\n if (!closestX && closest.contentEditable == \"true\") return domPosAtCoords(closest, clipX, y);\n let offset = Array.prototype.indexOf.call(parent.childNodes, closest) + (x >= (closestRect.left + closestRect.right) / 2 ? 1 : 0);\n return {\n node: parent,\n offset\n };\n}\nfunction domPosInText(node, x, y) {\n let len = node.nodeValue.length;\n let closestOffset = -1, closestDY = 1000000000, generalSide = 0;\n for(let i = 0; i < len; i++){\n let rects = textRange(node, i, i + 1).getClientRects();\n for(let j = 0; j < rects.length; j++){\n let rect = rects[j];\n if (rect.top == rect.bottom) continue;\n if (!generalSide) generalSide = x - rect.left;\n let dy = (rect.top > y ? rect.top - y : y - rect.bottom) - 1;\n if (rect.left - 1 <= x && rect.right + 1 >= x && dy < closestDY) {\n let right = x >= (rect.left + rect.right) / 2, after = right;\n if (browser.chrome || browser.gecko) {\n // Check for RTL on browsers that support getting client\n // rects for empty ranges.\n let rectBefore = textRange(node, i).getBoundingClientRect();\n if (rectBefore.left == rect.right) after = !right;\n }\n if (dy <= 0) return {\n node,\n offset: i + (after ? 1 : 0)\n };\n closestOffset = i + (after ? 1 : 0);\n closestDY = dy;\n }\n }\n }\n return {\n node,\n offset: closestOffset > -1 ? closestOffset : generalSide > 0 ? node.nodeValue.length : 0\n };\n}\nfunction posAtCoords(view, { x , y }, precise, bias = -1) {\n var _a;\n let content = view.contentDOM.getBoundingClientRect(), docTop = content.top + view.viewState.paddingTop;\n let block, { docHeight } = view.viewState;\n let yOffset = y - docTop;\n if (yOffset < 0) return 0;\n if (yOffset > docHeight) return view.state.doc.length;\n // Scan for a text block near the queried y position\n for(let halfLine = view.defaultLineHeight / 2, bounced = false;;){\n block = view.elementAtHeight(yOffset);\n if (block.type == BlockType.Text) break;\n for(;;){\n // Move the y position out of this block\n yOffset = bias > 0 ? block.bottom + halfLine : block.top - halfLine;\n if (yOffset >= 0 && yOffset <= docHeight) break;\n // If the document consists entirely of replaced widgets, we\n // won't find a text block, so return 0\n if (bounced) return precise ? null : 0;\n bounced = true;\n bias = -bias;\n }\n }\n y = docTop + yOffset;\n let lineStart = block.from;\n // If this is outside of the rendered viewport, we can't determine a position\n if (lineStart < view.viewport.from) return view.viewport.from == 0 ? 0 : precise ? null : posAtCoordsImprecise(view, content, block, x, y);\n if (lineStart > view.viewport.to) return view.viewport.to == view.state.doc.length ? view.state.doc.length : precise ? null : posAtCoordsImprecise(view, content, block, x, y);\n // Prefer ShadowRootOrDocument.elementFromPoint if present, fall back to document if not\n let doc3 = view.dom.ownerDocument;\n let root = view.root.elementFromPoint ? view.root : doc3;\n let element = root.elementFromPoint(x, y);\n if (element && !view.contentDOM.contains(element)) element = null;\n // If the element is unexpected, clip x at the sides of the content area and try again\n if (!element) {\n x = Math.max(content.left + 1, Math.min(content.right - 1, x));\n element = root.elementFromPoint(x, y);\n if (element && !view.contentDOM.contains(element)) element = null;\n }\n // There's visible editor content under the point, so we can try\n // using caret(Position|Range)FromPoint as a shortcut\n let node, offset = -1;\n if (element && ((_a = view.docView.nearest(element)) === null || _a === void 0 ? void 0 : _a.isEditable) != false) {\n if (doc3.caretPositionFromPoint) {\n let pos = doc3.caretPositionFromPoint(x, y);\n if (pos) ({ offsetNode: node , offset } = pos);\n } else if (doc3.caretRangeFromPoint) {\n let range = doc3.caretRangeFromPoint(x, y);\n if (range) {\n ({ startContainer: node , startOffset: offset } = range);\n if (browser.safari && isSuspiciousCaretResult(node, offset, x)) node = undefined;\n }\n }\n }\n // No luck, do our own (potentially expensive) search\n if (!node || !view.docView.dom.contains(node)) {\n let line = LineView.find(view.docView, lineStart);\n if (!line) return yOffset > block.top + block.height / 2 ? block.to : block.from;\n ({ node , offset } = domPosAtCoords(line.dom, x, y));\n }\n return view.docView.posFromDOM(node, offset);\n}\nfunction posAtCoordsImprecise(view, contentRect, block, x, y) {\n let into = Math.round((x - contentRect.left) * view.defaultCharacterWidth);\n if (view.lineWrapping && block.height > view.defaultLineHeight * 1.5) {\n let line = Math.floor((y - block.top) / view.defaultLineHeight);\n into += line * view.viewState.heightOracle.lineLength;\n }\n let content = view.state.sliceDoc(block.from, block.to);\n return block.from + _text.findColumn(content, into, view.state.tabSize);\n}\n// In case of a high line height, Safari's caretRangeFromPoint treats\n// the space between lines as belonging to the last character of the\n// line before. This is used to detect such a result so that it can be\n// ignored (issue #401).\nfunction isSuspiciousCaretResult(node, offset, x) {\n let len;\n if (node.nodeType != 3 || offset != (len = node.nodeValue.length)) return false;\n for(let next = node.nextSibling; next; next = next.nextSibling)if (next.nodeType != 1 || next.nodeName != \"BR\") return false;\n return textRange(node, len - 1, len).getBoundingClientRect().left > x;\n}\nfunction moveToLineBoundary(view, start, forward, includeWrap) {\n let line = view.state.doc.lineAt(start.head);\n let coords = !includeWrap || !view.lineWrapping ? null : view.coordsAtPos(start.assoc < 0 && start.head > line.from ? start.head - 1 : start.head);\n if (coords) {\n let editorRect = view.dom.getBoundingClientRect();\n let pos = view.posAtCoords({\n x: forward == (view.textDirection == Direction.LTR) ? editorRect.right - 1 : editorRect.left + 1,\n y: (coords.top + coords.bottom) / 2\n });\n if (pos != null) return _state.EditorSelection.cursor(pos, forward ? -1 : 1);\n }\n let lineView = LineView.find(view.docView, start.head);\n let end = lineView ? forward ? lineView.posAtEnd : lineView.posAtStart : forward ? line.to : line.from;\n return _state.EditorSelection.cursor(end, forward ? -1 : 1);\n}\nfunction moveByChar(view, start, forward, by) {\n let line = view.state.doc.lineAt(start.head), spans = view.bidiSpans(line);\n for(let cur = start, check = null;;){\n let next = moveVisually(line, spans, view.textDirection, cur, forward), char = movedOver;\n if (!next) {\n if (line.number == (forward ? view.state.doc.lines : 1)) return cur;\n char = \"\\n\";\n line = view.state.doc.line(line.number + (forward ? 1 : -1));\n spans = view.bidiSpans(line);\n next = _state.EditorSelection.cursor(forward ? line.from : line.to);\n }\n if (!check) {\n if (!by) return next;\n check = by(char);\n } else if (!check(char)) return cur;\n cur = next;\n }\n}\nfunction byGroup(view, pos, start) {\n let categorize = view.state.charCategorizer(pos);\n let cat = categorize(start);\n return (next)=>{\n let nextCat = categorize(next);\n if (cat == _state.CharCategory.Space) cat = nextCat;\n return cat == nextCat;\n };\n}\nfunction moveVertically(view, start, forward, distance) {\n let startPos = start.head, dir = forward ? 1 : -1;\n if (startPos == (forward ? view.state.doc.length : 0)) return _state.EditorSelection.cursor(startPos, start.assoc);\n let goal = start.goalColumn, startY;\n let rect = view.contentDOM.getBoundingClientRect();\n let startCoords = view.coordsAtPos(startPos), docTop = view.documentTop;\n if (startCoords) {\n if (goal == null) goal = startCoords.left - rect.left;\n startY = dir < 0 ? startCoords.top : startCoords.bottom;\n } else {\n let line = view.viewState.lineBlockAt(startPos - docTop);\n if (goal == null) goal = Math.min(rect.right - rect.left, view.defaultCharacterWidth * (startPos - line.from));\n startY = (dir < 0 ? line.top : line.bottom) + docTop;\n }\n let resolvedGoal = rect.left + goal;\n let dist = distance !== null && distance !== void 0 ? distance : view.defaultLineHeight >> 1;\n for(let extra = 0;; extra += 10){\n let curY = startY + (dist + extra) * dir;\n let pos = posAtCoords(view, {\n x: resolvedGoal,\n y: curY\n }, false, dir);\n if (curY < rect.top || curY > rect.bottom || (dir < 0 ? pos < startPos : pos > startPos)) return _state.EditorSelection.cursor(pos, start.assoc, undefined, goal);\n }\n}\nfunction skipAtoms(view, oldPos, pos) {\n let atoms = view.pluginField(PluginField.atomicRanges);\n for(;;){\n let moved = false;\n for (let set of atoms)set.between(pos.from - 1, pos.from + 1, (from, to, value)=>{\n if (pos.from > from && pos.from < to) {\n pos = oldPos.from > pos.from ? _state.EditorSelection.cursor(from, 1) : _state.EditorSelection.cursor(to, -1);\n moved = true;\n }\n });\n if (!moved) return pos;\n }\n}\n// This will also be where dragging info and such goes\nclass InputState {\n constructor(view){\n this.lastKeyCode = 0;\n this.lastKeyTime = 0;\n // On iOS, some keys need to have their default behavior happen\n // (after which we retroactively handle them and reset the DOM) to\n // avoid messing up the virtual keyboard state.\n this.pendingIOSKey = undefined;\n this.lastSelectionOrigin = null;\n this.lastSelectionTime = 0;\n this.lastEscPress = 0;\n this.lastContextMenu = 0;\n this.scrollHandlers = [];\n this.registeredEvents = [];\n this.customHandlers = [];\n // -1 means not in a composition. Otherwise, this counts the number\n // of changes made during the composition. The count is used to\n // avoid treating the start state of the composition, before any\n // changes have been made, as part of the composition.\n this.composing = -1;\n // Tracks whether the next change should be marked as starting the\n // composition (null means no composition, true means next is the\n // first, false means first has already been marked for this\n // composition)\n this.compositionFirstChange = null;\n this.compositionEndedAt = 0;\n this.rapidCompositionStart = false;\n this.mouseSelection = null;\n for(let type in handlers){\n let handler = handlers[type];\n view.contentDOM.addEventListener(type, (event)=>{\n if (type == \"keydown\" && this.keydown(view, event)) return;\n if (!eventBelongsToEditor(view, event) || this.ignoreDuringComposition(event)) return;\n if (this.mustFlushObserver(event)) view.observer.forceFlush();\n if (this.runCustomHandlers(type, view, event)) event.preventDefault();\n else handler(view, event);\n });\n this.registeredEvents.push(type);\n }\n this.notifiedFocused = view.hasFocus;\n this.ensureHandlers(view);\n // On Safari adding an input event handler somehow prevents an\n // issue where the composition vanishes when you press enter.\n if (browser.safari) view.contentDOM.addEventListener(\"input\", ()=>null\n );\n }\n setSelectionOrigin(origin) {\n this.lastSelectionOrigin = origin;\n this.lastSelectionTime = Date.now();\n }\n ensureHandlers(view) {\n let handlers1 = this.customHandlers = view.pluginField(domEventHandlers);\n for (let set of handlers1){\n for(let type in set.handlers)if (this.registeredEvents.indexOf(type) < 0 && type != \"scroll\") {\n this.registeredEvents.push(type);\n view.contentDOM.addEventListener(type, (event)=>{\n if (!eventBelongsToEditor(view, event)) return;\n if (this.runCustomHandlers(type, view, event)) event.preventDefault();\n });\n }\n }\n }\n runCustomHandlers(type, view, event) {\n for (let set of this.customHandlers){\n let handler = set.handlers[type];\n if (handler) try {\n if (handler.call(set.plugin, event, view) || event.defaultPrevented) return true;\n } catch (e) {\n logException(view.state, e);\n }\n }\n return false;\n }\n runScrollHandlers(view, event) {\n for (let set of this.customHandlers){\n let handler = set.handlers.scroll;\n if (handler) try {\n handler.call(set.plugin, event, view);\n } catch (e) {\n logException(view.state, e);\n }\n }\n }\n keydown(view, event) {\n // Must always run, even if a custom handler handled the event\n this.lastKeyCode = event.keyCode;\n this.lastKeyTime = Date.now();\n if (this.screenKeyEvent(view, event)) return true;\n // Chrome for Android usually doesn't fire proper key events, but\n // occasionally does, usually surrounded by a bunch of complicated\n // composition changes. When an enter or backspace key event is\n // seen, hold off on handling DOM events for a bit, and then\n // dispatch it.\n if (browser.android && browser.chrome && !event.synthetic && (event.keyCode == 13 || event.keyCode == 8)) {\n view.observer.delayAndroidKey(event.key, event.keyCode);\n return true;\n }\n // Prevent the default behavior of Enter on iOS makes the\n // virtual keyboard get stuck in the wrong (lowercase)\n // state. So we let it go through, and then, in\n // applyDOMChange, notify key handlers of it and reset to\n // the state they produce.\n let pending;\n if (browser.ios && (pending = PendingKeys.find((key)=>key.keyCode == event.keyCode\n )) && !(event.ctrlKey || event.altKey || event.metaKey) && !event.synthetic) {\n this.pendingIOSKey = pending;\n setTimeout(()=>this.flushIOSKey(view)\n , 250);\n return true;\n }\n return false;\n }\n flushIOSKey(view) {\n let key = this.pendingIOSKey;\n if (!key) return false;\n this.pendingIOSKey = undefined;\n return dispatchKey(view.contentDOM, key.key, key.keyCode);\n }\n ignoreDuringComposition(event) {\n if (!/^key/.test(event.type)) return false;\n if (this.composing > 0) return true;\n // See https://www.stum.de/2016/06/24/handling-ime-events-in-javascript/.\n // On some input method editors (IMEs), the Enter key is used to\n // confirm character selection. On Safari, when Enter is pressed,\n // compositionend and keydown events are sometimes emitted in the\n // wrong order. The key event should still be ignored, even when\n // it happens after the compositionend event.\n if (browser.safari && Date.now() - this.compositionEndedAt < 500) {\n this.compositionEndedAt = 0;\n return true;\n }\n return false;\n }\n screenKeyEvent(view, event) {\n let protectedTab = event.keyCode == 9 && Date.now() < this.lastEscPress + 2000;\n if (event.keyCode == 27) this.lastEscPress = Date.now();\n else if (modifierCodes.indexOf(event.keyCode) < 0) this.lastEscPress = 0;\n return protectedTab;\n }\n mustFlushObserver(event) {\n return event.type == \"keydown\" && event.keyCode != 229 || event.type == \"compositionend\" && !browser.ios;\n }\n startMouseSelection(mouseSelection) {\n if (this.mouseSelection) this.mouseSelection.destroy();\n this.mouseSelection = mouseSelection;\n }\n update(update) {\n if (this.mouseSelection) this.mouseSelection.update(update);\n if (update.transactions.length) this.lastKeyCode = this.lastSelectionTime = 0;\n }\n destroy() {\n if (this.mouseSelection) this.mouseSelection.destroy();\n }\n}\nconst PendingKeys = [\n {\n key: \"Backspace\",\n keyCode: 8,\n inputType: \"deleteContentBackward\"\n },\n {\n key: \"Enter\",\n keyCode: 13,\n inputType: \"insertParagraph\"\n },\n {\n key: \"Delete\",\n keyCode: 46,\n inputType: \"deleteContentForward\"\n }\n];\n// Key codes for modifier keys\nconst modifierCodes = [\n 16,\n 17,\n 18,\n 20,\n 91,\n 92,\n 224,\n 225\n];\nclass MouseSelection {\n constructor(view, startEvent, style, mustSelect){\n this.view = view;\n this.style = style;\n this.mustSelect = mustSelect;\n this.lastEvent = startEvent;\n let doc4 = view.contentDOM.ownerDocument;\n doc4.addEventListener(\"mousemove\", this.move = this.move.bind(this));\n doc4.addEventListener(\"mouseup\", this.up = this.up.bind(this));\n this.extend = startEvent.shiftKey;\n this.multiple = view.state.facet(_state.EditorState.allowMultipleSelections) && addsSelectionRange(view, startEvent);\n this.dragMove = dragMovesSelection(view, startEvent);\n this.dragging = isInPrimarySelection(view, startEvent) && getClickType(startEvent) == 1 ? null : false;\n // When clicking outside of the selection, immediately apply the\n // effect of starting the selection\n if (this.dragging === false) {\n startEvent.preventDefault();\n this.select(startEvent);\n }\n }\n move(event) {\n if (event.buttons == 0) return this.destroy();\n if (this.dragging !== false) return;\n this.select(this.lastEvent = event);\n }\n up(event) {\n if (this.dragging == null) this.select(this.lastEvent);\n if (!this.dragging) event.preventDefault();\n this.destroy();\n }\n destroy() {\n let doc5 = this.view.contentDOM.ownerDocument;\n doc5.removeEventListener(\"mousemove\", this.move);\n doc5.removeEventListener(\"mouseup\", this.up);\n this.view.inputState.mouseSelection = null;\n }\n select(event) {\n let selection = this.style.get(event, this.extend, this.multiple);\n if (this.mustSelect || !selection.eq(this.view.state.selection) || selection.main.assoc != this.view.state.selection.main.assoc) this.view.dispatch({\n selection,\n userEvent: \"select.pointer\",\n scrollIntoView: true\n });\n this.mustSelect = false;\n }\n update(update) {\n if (update.docChanged && this.dragging) this.dragging = this.dragging.map(update.changes);\n if (this.style.update(update)) setTimeout(()=>this.select(this.lastEvent)\n , 20);\n }\n}\nfunction addsSelectionRange(view, event) {\n let facet = view.state.facet(clickAddsSelectionRange);\n return facet.length ? facet[0](event) : browser.mac ? event.metaKey : event.ctrlKey;\n}\nfunction dragMovesSelection(view, event) {\n let facet = view.state.facet(dragMovesSelection$1);\n return facet.length ? facet[0](event) : browser.mac ? !event.altKey : !event.ctrlKey;\n}\nfunction isInPrimarySelection(view, event) {\n let { main } = view.state.selection;\n if (main.empty) return false;\n // On boundary clicks, check whether the coordinates are inside the\n // selection's client rectangles\n let sel = getSelection(view.root);\n if (sel.rangeCount == 0) return true;\n let rects = sel.getRangeAt(0).getClientRects();\n for(let i = 0; i < rects.length; i++){\n let rect = rects[i];\n if (rect.left <= event.clientX && rect.right >= event.clientX && rect.top <= event.clientY && rect.bottom >= event.clientY) return true;\n }\n return false;\n}\nfunction eventBelongsToEditor(view, event) {\n if (!event.bubbles) return true;\n if (event.defaultPrevented) return false;\n for(let node = event.target, cView; node != view.contentDOM; node = node.parentNode)if (!node || node.nodeType == 11 || (cView = ContentView.get(node)) && cView.ignoreEvent(event)) return false;\n return true;\n}\nconst handlers = /*@__PURE__*/ Object.create(null);\n// This is very crude, but unfortunately both these browsers _pretend_\n// that they have a clipboard API\u2014all the objects and methods are\n// there, they just don't work, and they are hard to test.\nconst brokenClipboardAPI = browser.ie && browser.ie_version < 15 || browser.ios && browser.webkit_version < 604;\nfunction capturePaste(view) {\n let parent = view.dom.parentNode;\n if (!parent) return;\n let target = parent.appendChild(document.createElement(\"textarea\"));\n target.style.cssText = \"position: fixed; left: -10000px; top: 10px\";\n target.focus();\n setTimeout(()=>{\n view.focus();\n target.remove();\n doPaste(view, target.value);\n }, 50);\n}\nfunction doPaste(view, input) {\n let { state } = view, changes, i = 1, text = state.toText(input);\n let byLine = text.lines == state.selection.ranges.length;\n let linewise = lastLinewiseCopy != null && state.selection.ranges.every((r)=>r.empty\n ) && lastLinewiseCopy == text.toString();\n if (linewise) {\n let lastLine = -1;\n changes = state.changeByRange((range)=>{\n let line = state.doc.lineAt(range.from);\n if (line.from == lastLine) return {\n range\n };\n lastLine = line.from;\n let insert = state.toText((byLine ? text.line(i++).text : input) + state.lineBreak);\n return {\n changes: {\n from: line.from,\n insert\n },\n range: _state.EditorSelection.cursor(range.from + insert.length)\n };\n });\n } else if (byLine) changes = state.changeByRange((range)=>{\n let line = text.line(i++);\n return {\n changes: {\n from: range.from,\n to: range.to,\n insert: line.text\n },\n range: _state.EditorSelection.cursor(range.from + line.length)\n };\n });\n else changes = state.replaceSelection(text);\n view.dispatch(changes, {\n userEvent: \"input.paste\",\n scrollIntoView: true\n });\n}\nhandlers.keydown = (view, event)=>{\n view.inputState.setSelectionOrigin(\"select\");\n};\nlet lastTouch = 0;\nhandlers.touchstart = (view, e)=>{\n lastTouch = Date.now();\n view.inputState.setSelectionOrigin(\"select.pointer\");\n};\nhandlers.touchmove = (view)=>{\n view.inputState.setSelectionOrigin(\"select.pointer\");\n};\nhandlers.mousedown = (view, event)=>{\n view.observer.flush();\n if (lastTouch > Date.now() - 2000 && getClickType(event) == 1) return; // Ignore touch interaction\n let style = null;\n for (let makeStyle of view.state.facet(mouseSelectionStyle)){\n style = makeStyle(view, event);\n if (style) break;\n }\n if (!style && event.button == 0) style = basicMouseSelection(view, event);\n if (style) {\n let mustFocus = view.root.activeElement != view.contentDOM;\n if (mustFocus) view.observer.ignore(()=>focusPreventScroll(view.contentDOM)\n );\n view.inputState.startMouseSelection(new MouseSelection(view, event, style, mustFocus));\n }\n};\nfunction rangeForClick(view, pos, bias, type) {\n if (type == 1) return _state.EditorSelection.cursor(pos, bias);\n else if (type == 2) return groupAt(view.state, pos, bias);\n else {\n let visual = LineView.find(view.docView, pos), line = view.state.doc.lineAt(visual ? visual.posAtEnd : pos);\n let from = visual ? visual.posAtStart : line.from, to = visual ? visual.posAtEnd : line.to;\n if (to < view.state.doc.length && to == line.to) to++;\n return _state.EditorSelection.range(from, to);\n }\n}\nlet insideY = (y, rect)=>y >= rect.top && y <= rect.bottom\n;\nlet inside = (x, y, rect)=>insideY(y, rect) && x >= rect.left && x <= rect.right\n;\n// Try to determine, for the given coordinates, associated with the\n// given position, whether they are related to the element before or\n// the element after the position.\nfunction findPositionSide(view, pos, x, y) {\n let line = LineView.find(view.docView, pos);\n if (!line) return 1;\n let off = pos - line.posAtStart;\n // Line boundaries point into the line\n if (off == 0) return 1;\n if (off == line.length) return -1;\n // Positions on top of an element point at that element\n let before = line.coordsAt(off, -1);\n if (before && inside(x, y, before)) return -1;\n let after = line.coordsAt(off, 1);\n if (after && inside(x, y, after)) return 1;\n // This is probably a line wrap point. Pick before if the point is\n // beside it.\n return before && insideY(y, before) ? -1 : 1;\n}\nfunction queryPos(view, event) {\n let pos = view.posAtCoords({\n x: event.clientX,\n y: event.clientY\n }, false);\n return {\n pos,\n bias: findPositionSide(view, pos, event.clientX, event.clientY)\n };\n}\nconst BadMouseDetail = browser.ie && browser.ie_version <= 11;\nlet lastMouseDown = null, lastMouseDownCount = 0, lastMouseDownTime = 0;\nfunction getClickType(event) {\n if (!BadMouseDetail) return event.detail;\n let last = lastMouseDown, lastTime = lastMouseDownTime;\n lastMouseDown = event;\n lastMouseDownTime = Date.now();\n return lastMouseDownCount = !last || lastTime > Date.now() - 400 && Math.abs(last.clientX - event.clientX) < 2 && Math.abs(last.clientY - event.clientY) < 2 ? (lastMouseDownCount + 1) % 3 : 1;\n}\nfunction basicMouseSelection(view, event1) {\n let start = queryPos(view, event1), type = getClickType(event1);\n let startSel = view.state.selection;\n let last = start, lastEvent = event1;\n return {\n update (update) {\n if (update.docChanged) {\n if (start) start.pos = update.changes.mapPos(start.pos);\n startSel = startSel.map(update.changes);\n lastEvent = null;\n }\n },\n get (event, extend, multiple) {\n let cur;\n if (lastEvent && event.clientX == lastEvent.clientX && event.clientY == lastEvent.clientY) cur = last;\n else {\n cur = last = queryPos(view, event);\n lastEvent = event;\n }\n if (!cur || !start) return startSel;\n let range = rangeForClick(view, cur.pos, cur.bias, type);\n if (start.pos != cur.pos && !extend) {\n let startRange = rangeForClick(view, start.pos, start.bias, type);\n let from = Math.min(startRange.from, range.from), to = Math.max(startRange.to, range.to);\n range = from < range.from ? _state.EditorSelection.range(from, to) : _state.EditorSelection.range(to, from);\n }\n if (extend) return startSel.replaceRange(startSel.main.extend(range.from, range.to));\n else if (multiple) return startSel.addRange(range);\n else return _state.EditorSelection.create([\n range\n ]);\n }\n };\n}\nhandlers.dragstart = (view, event)=>{\n let { selection: { main } } = view.state;\n let { mouseSelection } = view.inputState;\n if (mouseSelection) mouseSelection.dragging = main;\n if (event.dataTransfer) {\n event.dataTransfer.setData(\"Text\", view.state.sliceDoc(main.from, main.to));\n event.dataTransfer.effectAllowed = \"copyMove\";\n }\n};\nfunction dropText(view, event, text, direct) {\n if (!text) return;\n let dropPos = view.posAtCoords({\n x: event.clientX,\n y: event.clientY\n }, false);\n event.preventDefault();\n let { mouseSelection } = view.inputState;\n let del = direct && mouseSelection && mouseSelection.dragging && mouseSelection.dragMove ? {\n from: mouseSelection.dragging.from,\n to: mouseSelection.dragging.to\n } : null;\n let ins = {\n from: dropPos,\n insert: text\n };\n let changes = view.state.changes(del ? [\n del,\n ins\n ] : ins);\n view.focus();\n view.dispatch({\n changes,\n selection: {\n anchor: changes.mapPos(dropPos, -1),\n head: changes.mapPos(dropPos, 1)\n },\n userEvent: del ? \"move.drop\" : \"input.drop\"\n });\n}\nhandlers.drop = (view, event)=>{\n if (!event.dataTransfer) return;\n if (view.state.readOnly) return event.preventDefault();\n let files = event.dataTransfer.files;\n if (files && files.length) {\n event.preventDefault();\n let text = Array(files.length), read = 0;\n let finishFile = ()=>{\n if (++read == files.length) dropText(view, event, text.filter((s)=>s != null\n ).join(view.state.lineBreak), false);\n };\n for(let i = 0; i < files.length; i++){\n let reader = new FileReader;\n reader.onerror = finishFile;\n reader.onload = ()=>{\n if (!/[\\x00-\\x08\\x0e-\\x1f]{2}/.test(reader.result)) text[i] = reader.result;\n finishFile();\n };\n reader.readAsText(files[i]);\n }\n } else dropText(view, event, event.dataTransfer.getData(\"Text\"), true);\n};\nhandlers.paste = (view, event)=>{\n if (view.state.readOnly) return event.preventDefault();\n view.observer.flush();\n let data = brokenClipboardAPI ? null : event.clipboardData;\n if (data) {\n doPaste(view, data.getData(\"text/plain\"));\n event.preventDefault();\n } else capturePaste(view);\n};\nfunction captureCopy(view, text) {\n // The extra wrapper is somehow necessary on IE/Edge to prevent the\n // content from being mangled when it is put onto the clipboard\n let parent = view.dom.parentNode;\n if (!parent) return;\n let target = parent.appendChild(document.createElement(\"textarea\"));\n target.style.cssText = \"position: fixed; left: -10000px; top: 10px\";\n target.value = text;\n target.focus();\n target.selectionEnd = text.length;\n target.selectionStart = 0;\n setTimeout(()=>{\n target.remove();\n view.focus();\n }, 50);\n}\nfunction copiedRange(state) {\n let content = [], ranges = [], linewise = false;\n for (let range of state.selection.ranges)if (!range.empty) {\n content.push(state.sliceDoc(range.from, range.to));\n ranges.push(range);\n }\n if (!content.length) {\n // Nothing selected, do a line-wise copy\n let upto = -1;\n for (let { from } of state.selection.ranges){\n let line = state.doc.lineAt(from);\n if (line.number > upto) {\n content.push(line.text);\n ranges.push({\n from: line.from,\n to: Math.min(state.doc.length, line.to + 1)\n });\n }\n upto = line.number;\n }\n linewise = true;\n }\n return {\n text: content.join(state.lineBreak),\n ranges,\n linewise\n };\n}\nlet lastLinewiseCopy = null;\nhandlers.copy = handlers.cut = (view, event)=>{\n let { text , ranges , linewise } = copiedRange(view.state);\n if (!text && !linewise) return;\n lastLinewiseCopy = linewise ? text : null;\n let data = brokenClipboardAPI ? null : event.clipboardData;\n if (data) {\n event.preventDefault();\n data.clearData();\n data.setData(\"text/plain\", text);\n } else captureCopy(view, text);\n if (event.type == \"cut\" && !view.state.readOnly) view.dispatch({\n changes: ranges,\n scrollIntoView: true,\n userEvent: \"delete.cut\"\n });\n};\nhandlers.focus = handlers.blur = (view)=>{\n setTimeout(()=>{\n if (view.hasFocus != view.inputState.notifiedFocused) view.update([]);\n }, 10);\n};\nhandlers.beforeprint = (view)=>{\n view.viewState.printing = true;\n view.requestMeasure();\n setTimeout(()=>{\n view.viewState.printing = false;\n view.requestMeasure();\n }, 2000);\n};\nfunction forceClearComposition(view, rapid) {\n if (view.docView.compositionDeco.size) {\n view.inputState.rapidCompositionStart = rapid;\n try {\n view.update([]);\n } finally{\n view.inputState.rapidCompositionStart = false;\n }\n }\n}\nhandlers.compositionstart = handlers.compositionupdate = (view)=>{\n if (view.inputState.compositionFirstChange == null) view.inputState.compositionFirstChange = true;\n if (view.inputState.composing < 0) {\n // FIXME possibly set a timeout to clear it again on Android\n view.inputState.composing = 0;\n if (view.docView.compositionDeco.size) {\n view.observer.flush();\n forceClearComposition(view, true);\n }\n }\n};\nhandlers.compositionend = (view)=>{\n view.inputState.composing = -1;\n view.inputState.compositionEndedAt = Date.now();\n view.inputState.compositionFirstChange = null;\n setTimeout(()=>{\n if (view.inputState.composing < 0) forceClearComposition(view, false);\n }, 50);\n};\nhandlers.contextmenu = (view)=>{\n view.inputState.lastContextMenu = Date.now();\n};\nhandlers.beforeinput = (view, event)=>{\n var _a1;\n // Because Chrome Android doesn't fire useful key events, use\n // beforeinput to detect backspace (and possibly enter and delete,\n // but those usually don't even seem to fire beforeinput events at\n // the moment) and fake a key event for it.\n //\n // (preventDefault on beforeinput, though supported in the spec,\n // seems to do nothing at all on Chrome).\n let pending;\n if (browser.chrome && browser.android && (pending = PendingKeys.find((key)=>key.inputType == event.inputType\n ))) {\n view.observer.delayAndroidKey(pending.key, pending.keyCode);\n if (pending.key == \"Backspace\" || pending.key == \"Delete\") {\n let startViewHeight = ((_a1 = window.visualViewport) === null || _a1 === void 0 ? void 0 : _a1.height) || 0;\n setTimeout(()=>{\n var _a;\n // Backspacing near uneditable nodes on Chrome Android sometimes\n // closes the virtual keyboard. This tries to crudely detect\n // that and refocus to get it back.\n if ((((_a = window.visualViewport) === null || _a === void 0 ? void 0 : _a.height) || 0) > startViewHeight + 10 && view.hasFocus) {\n view.contentDOM.blur();\n view.focus();\n }\n }, 100);\n }\n }\n};\nconst wrappingWhiteSpace = [\n \"pre-wrap\",\n \"normal\",\n \"pre-line\",\n \"break-spaces\"\n];\nclass HeightOracle {\n constructor(){\n this.doc = _text.Text.empty;\n this.lineWrapping = false;\n this.direction = Direction.LTR;\n this.heightSamples = {\n };\n this.lineHeight = 14;\n this.charWidth = 7;\n this.lineLength = 30;\n // Used to track, during updateHeight, if any actual heights changed\n this.heightChanged = false;\n }\n heightForGap(from, to) {\n let lines = this.doc.lineAt(to).number - this.doc.lineAt(from).number + 1;\n if (this.lineWrapping) lines += Math.ceil((to - from - lines * this.lineLength * 0.5) / this.lineLength);\n return this.lineHeight * lines;\n }\n heightForLine(length) {\n if (!this.lineWrapping) return this.lineHeight;\n let lines = 1 + Math.max(0, Math.ceil((length - this.lineLength) / (this.lineLength - 5)));\n return lines * this.lineHeight;\n }\n setDoc(doc6) {\n this.doc = doc6;\n return this;\n }\n mustRefreshForStyle(whiteSpace, direction) {\n return wrappingWhiteSpace.indexOf(whiteSpace) > -1 != this.lineWrapping || this.direction != direction;\n }\n mustRefreshForHeights(lineHeights) {\n let newHeight = false;\n for(let i = 0; i < lineHeights.length; i++){\n let h = lineHeights[i];\n if (h < 0) i++;\n else if (!this.heightSamples[Math.floor(h * 10)]) {\n newHeight = true;\n this.heightSamples[Math.floor(h * 10)] = true;\n }\n }\n return newHeight;\n }\n refresh(whiteSpace, direction, lineHeight, charWidth, lineLength, knownHeights) {\n let lineWrapping = wrappingWhiteSpace.indexOf(whiteSpace) > -1;\n let changed = Math.round(lineHeight) != Math.round(this.lineHeight) || this.lineWrapping != lineWrapping || this.direction != direction;\n this.lineWrapping = lineWrapping;\n this.direction = direction;\n this.lineHeight = lineHeight;\n this.charWidth = charWidth;\n this.lineLength = lineLength;\n if (changed) {\n this.heightSamples = {\n };\n for(let i = 0; i < knownHeights.length; i++){\n let h = knownHeights[i];\n if (h < 0) i++;\n else this.heightSamples[Math.floor(h * 10)] = true;\n }\n }\n return changed;\n }\n}\n// This object is used by `updateHeight` to make DOM measurements\n// arrive at the right nides. The `heights` array is a sequence of\n// block heights, starting from position `from`.\nclass MeasuredHeights {\n constructor(from, heights){\n this.from = from;\n this.heights = heights;\n this.index = 0;\n }\n get more() {\n return this.index < this.heights.length;\n }\n}\n/**\nRecord used to represent information about a block-level element\nin the editor view.\n*/ class BlockInfo {\n /**\n @internal\n */ constructor(/**\n The start of the element in the document.\n */ from, /**\n The length of the element.\n */ length, /**\n The top position of the element (relative to the top of the\n document).\n */ top, /**\n Its height.\n */ height, /**\n The type of element this is. When querying lines, this may be\n an array of all the blocks that make up the line.\n */ type){\n this.from = from;\n this.length = length;\n this.top = top;\n this.height = height;\n this.type = type;\n }\n /**\n The end of the element as a document position.\n */ get to() {\n return this.from + this.length;\n }\n /**\n The bottom position of the element.\n */ get bottom() {\n return this.top + this.height;\n }\n /**\n @internal\n */ join(other) {\n let detail = (Array.isArray(this.type) ? this.type : [\n this\n ]).concat(Array.isArray(other.type) ? other.type : [\n other\n ]);\n return new BlockInfo(this.from, this.length + other.length, this.top, this.height + other.height, detail);\n }\n /**\n FIXME remove on next breaking release @internal\n */ moveY(offset) {\n return !offset ? this : new BlockInfo(this.from, this.length, this.top + offset, this.height, Array.isArray(this.type) ? this.type.map((b)=>b.moveY(offset)\n ) : this.type);\n }\n}\nvar QueryType = /*@__PURE__*/ function(QueryType1) {\n QueryType1[QueryType1[\"ByPos\"] = 0] = \"ByPos\";\n QueryType1[QueryType1[\"ByHeight\"] = 1] = \"ByHeight\";\n QueryType1[QueryType1[\"ByPosNoHeight\"] = 2] = \"ByPosNoHeight\";\n return QueryType1;\n}(QueryType || (QueryType = {\n}));\nconst Epsilon = 0.001;\nclass HeightMap {\n constructor(length, height, flags = 2 /* Outdated */ ){\n this.length = length;\n this.height = height;\n this.flags = flags;\n }\n get outdated() {\n return (this.flags & 2 /* Outdated */ ) > 0;\n }\n set outdated(value) {\n this.flags = (value ? 2 /* Outdated */ : 0) | this.flags & -3 /* Outdated */ ;\n }\n setHeight(oracle, height) {\n if (this.height != height) {\n if (Math.abs(this.height - height) > Epsilon) oracle.heightChanged = true;\n this.height = height;\n }\n }\n // Base case is to replace a leaf node, which simply builds a tree\n // from the new nodes and returns that (HeightMapBranch and\n // HeightMapGap override this to actually use from/to)\n replace(_from, _to, nodes) {\n return HeightMap.of(nodes);\n }\n // Again, these are base cases, and are overridden for branch and gap nodes.\n decomposeLeft(_to, result) {\n result.push(this);\n }\n decomposeRight(_from, result) {\n result.push(this);\n }\n applyChanges(decorations3, oldDoc, oracle, changes) {\n let me = this;\n for(let i = changes.length - 1; i >= 0; i--){\n let { fromA , toA , fromB , toB } = changes[i];\n let start = me.lineAt(fromA, QueryType.ByPosNoHeight, oldDoc, 0, 0);\n let end = start.to >= toA ? start : me.lineAt(toA, QueryType.ByPosNoHeight, oldDoc, 0, 0);\n toB += end.to - toA;\n toA = end.to;\n while(i > 0 && start.from <= changes[i - 1].toA){\n fromA = changes[i - 1].fromA;\n fromB = changes[i - 1].fromB;\n i--;\n if (fromA < start.from) start = me.lineAt(fromA, QueryType.ByPosNoHeight, oldDoc, 0, 0);\n }\n fromB += start.from - fromA;\n fromA = start.from;\n let nodes = NodeBuilder.build(oracle, decorations3, fromB, toB);\n me = me.replace(fromA, toA, nodes);\n }\n return me.updateHeight(oracle, 0);\n }\n static empty() {\n return new HeightMapText(0, 0);\n }\n // nodes uses null values to indicate the position of line breaks.\n // There are never line breaks at the start or end of the array, or\n // two line breaks next to each other, and the array isn't allowed\n // to be empty (same restrictions as return value from the builder).\n static of(nodes) {\n if (nodes.length == 1) return nodes[0];\n let i = 0, j = nodes.length, before = 0, after = 0;\n for(;;){\n if (i == j) {\n if (before > after * 2) {\n let split = nodes[i - 1];\n if (split.break) nodes.splice(--i, 1, split.left, null, split.right);\n else nodes.splice(--i, 1, split.left, split.right);\n j += 1 + split.break;\n before -= split.size;\n } else if (after > before * 2) {\n let split = nodes[j];\n if (split.break) nodes.splice(j, 1, split.left, null, split.right);\n else nodes.splice(j, 1, split.left, split.right);\n j += 2 + split.break;\n after -= split.size;\n } else break;\n } else if (before < after) {\n let next = nodes[i++];\n if (next) before += next.size;\n } else {\n let next = nodes[--j];\n if (next) after += next.size;\n }\n }\n let brk = 0;\n if (nodes[i - 1] == null) {\n brk = 1;\n i--;\n } else if (nodes[i] == null) {\n brk = 1;\n j++;\n }\n return new HeightMapBranch(HeightMap.of(nodes.slice(0, i)), brk, HeightMap.of(nodes.slice(j)));\n }\n}\nHeightMap.prototype.size = 1;\nclass HeightMapBlock extends HeightMap {\n constructor(length, height, type){\n super(length, height);\n this.type = type;\n }\n blockAt(_height, _doc, top, offset) {\n return new BlockInfo(offset, this.length, top, this.height, this.type);\n }\n lineAt(_value, _type, doc7, top, offset) {\n return this.blockAt(0, doc7, top, offset);\n }\n forEachLine(_from, _to, doc8, top, offset, f) {\n f(this.blockAt(0, doc8, top, offset));\n }\n updateHeight(oracle, offset = 0, _force = false, measured) {\n if (measured && measured.from <= offset && measured.more) this.setHeight(oracle, measured.heights[measured.index++]);\n this.outdated = false;\n return this;\n }\n toString() {\n return `block(${this.length})`;\n }\n}\nclass HeightMapText extends HeightMapBlock {\n constructor(length, height){\n super(length, height, BlockType.Text);\n this.collapsed = 0; // Amount of collapsed content in the line\n this.widgetHeight = 0; // Maximum inline widget height\n }\n replace(_from, _to, nodes) {\n let node = nodes[0];\n if (nodes.length == 1 && (node instanceof HeightMapText || node instanceof HeightMapGap && node.flags & 4 /* SingleLine */ ) && Math.abs(this.length - node.length) < 10) {\n if (node instanceof HeightMapGap) node = new HeightMapText(node.length, this.height);\n else node.height = this.height;\n if (!this.outdated) node.outdated = false;\n return node;\n } else return HeightMap.of(nodes);\n }\n updateHeight(oracle, offset = 0, force = false, measured) {\n if (measured && measured.from <= offset && measured.more) this.setHeight(oracle, measured.heights[measured.index++]);\n else if (force || this.outdated) this.setHeight(oracle, Math.max(this.widgetHeight, oracle.heightForLine(this.length - this.collapsed)));\n this.outdated = false;\n return this;\n }\n toString() {\n return `line(${this.length}${this.collapsed ? -this.collapsed : \"\"}${this.widgetHeight ? \":\" + this.widgetHeight : \"\"})`;\n }\n}\nclass HeightMapGap extends HeightMap {\n constructor(length){\n super(length, 0);\n }\n lines(doc9, offset) {\n let firstLine = doc9.lineAt(offset).number, lastLine = doc9.lineAt(offset + this.length).number;\n return {\n firstLine,\n lastLine,\n lineHeight: this.height / (lastLine - firstLine + 1)\n };\n }\n blockAt(height, doc10, top, offset) {\n let { firstLine , lastLine , lineHeight } = this.lines(doc10, offset);\n let line = Math.max(0, Math.min(lastLine - firstLine, Math.floor((height - top) / lineHeight)));\n let { from , length } = doc10.line(firstLine + line);\n return new BlockInfo(from, length, top + lineHeight * line, lineHeight, BlockType.Text);\n }\n lineAt(value, type, doc11, top, offset) {\n if (type == QueryType.ByHeight) return this.blockAt(value, doc11, top, offset);\n if (type == QueryType.ByPosNoHeight) {\n let { from , to } = doc11.lineAt(value);\n return new BlockInfo(from, to - from, 0, 0, BlockType.Text);\n }\n let { firstLine , lineHeight } = this.lines(doc11, offset);\n let { from , length , number } = doc11.lineAt(value);\n return new BlockInfo(from, length, top + lineHeight * (number - firstLine), lineHeight, BlockType.Text);\n }\n forEachLine(from, to, doc12, top, offset, f) {\n let { firstLine , lineHeight } = this.lines(doc12, offset);\n for(let pos = Math.max(from, offset), end = Math.min(offset + this.length, to); pos <= end;){\n let line = doc12.lineAt(pos);\n if (pos == from) top += lineHeight * (line.number - firstLine);\n f(new BlockInfo(line.from, line.length, top, lineHeight, BlockType.Text));\n top += lineHeight;\n pos = line.to + 1;\n }\n }\n replace(from, to, nodes) {\n let after = this.length - to;\n if (after > 0) {\n let last = nodes[nodes.length - 1];\n if (last instanceof HeightMapGap) nodes[nodes.length - 1] = new HeightMapGap(last.length + after);\n else nodes.push(null, new HeightMapGap(after - 1));\n }\n if (from > 0) {\n let first = nodes[0];\n if (first instanceof HeightMapGap) nodes[0] = new HeightMapGap(from + first.length);\n else nodes.unshift(new HeightMapGap(from - 1), null);\n }\n return HeightMap.of(nodes);\n }\n decomposeLeft(to, result) {\n result.push(new HeightMapGap(to - 1), null);\n }\n decomposeRight(from, result) {\n result.push(null, new HeightMapGap(this.length - from - 1));\n }\n updateHeight(oracle, offset = 0, force = false, measured) {\n let end = offset + this.length;\n if (measured && measured.from <= offset + this.length && measured.more) {\n // Fill in part of this gap with measured lines. We know there\n // can't be widgets or collapsed ranges in those lines, because\n // they would already have been added to the heightmap (gaps\n // only contain plain text).\n let nodes = [], pos = Math.max(offset, measured.from), singleHeight = -1;\n let wasChanged = oracle.heightChanged;\n if (measured.from > offset) nodes.push(new HeightMapGap(measured.from - offset - 1).updateHeight(oracle, offset));\n while(pos <= end && measured.more){\n let len = oracle.doc.lineAt(pos).length;\n if (nodes.length) nodes.push(null);\n let height = measured.heights[measured.index++];\n if (singleHeight == -1) singleHeight = height;\n else if (Math.abs(height - singleHeight) >= Epsilon) singleHeight = -2;\n let line = new HeightMapText(len, height);\n line.outdated = false;\n nodes.push(line);\n pos += len + 1;\n }\n if (pos <= end) nodes.push(null, new HeightMapGap(end - pos).updateHeight(oracle, pos));\n let result = HeightMap.of(nodes);\n oracle.heightChanged = wasChanged || singleHeight < 0 || Math.abs(result.height - this.height) >= Epsilon || Math.abs(singleHeight - this.lines(oracle.doc, offset).lineHeight) >= Epsilon;\n return result;\n } else if (force || this.outdated) {\n this.setHeight(oracle, oracle.heightForGap(offset, offset + this.length));\n this.outdated = false;\n }\n return this;\n }\n toString() {\n return `gap(${this.length})`;\n }\n}\nclass HeightMapBranch extends HeightMap {\n constructor(left, brk, right){\n super(left.length + brk + right.length, left.height + right.height, brk | (left.outdated || right.outdated ? 2 /* Outdated */ : 0));\n this.left = left;\n this.right = right;\n this.size = left.size + right.size;\n }\n get break() {\n return this.flags & 1 /* Break */ ;\n }\n blockAt(height, doc13, top, offset) {\n let mid = top + this.left.height;\n return height < mid ? this.left.blockAt(height, doc13, top, offset) : this.right.blockAt(height, doc13, mid, offset + this.left.length + this.break);\n }\n lineAt(value, type, doc14, top, offset) {\n let rightTop = top + this.left.height, rightOffset = offset + this.left.length + this.break;\n let left = type == QueryType.ByHeight ? value < rightTop : value < rightOffset;\n let base = left ? this.left.lineAt(value, type, doc14, top, offset) : this.right.lineAt(value, type, doc14, rightTop, rightOffset);\n if (this.break || (left ? base.to < rightOffset : base.from > rightOffset)) return base;\n let subQuery = type == QueryType.ByPosNoHeight ? QueryType.ByPosNoHeight : QueryType.ByPos;\n if (left) return base.join(this.right.lineAt(rightOffset, subQuery, doc14, rightTop, rightOffset));\n else return this.left.lineAt(rightOffset, subQuery, doc14, top, offset).join(base);\n }\n forEachLine(from, to, doc15, top, offset, f) {\n let rightTop = top + this.left.height, rightOffset = offset + this.left.length + this.break;\n if (this.break) {\n if (from < rightOffset) this.left.forEachLine(from, to, doc15, top, offset, f);\n if (to >= rightOffset) this.right.forEachLine(from, to, doc15, rightTop, rightOffset, f);\n } else {\n let mid = this.lineAt(rightOffset, QueryType.ByPos, doc15, top, offset);\n if (from < mid.from) this.left.forEachLine(from, mid.from - 1, doc15, top, offset, f);\n if (mid.to >= from && mid.from <= to) f(mid);\n if (to > mid.to) this.right.forEachLine(mid.to + 1, to, doc15, rightTop, rightOffset, f);\n }\n }\n replace(from, to, nodes) {\n let rightStart = this.left.length + this.break;\n if (to < rightStart) return this.balanced(this.left.replace(from, to, nodes), this.right);\n if (from > this.left.length) return this.balanced(this.left, this.right.replace(from - rightStart, to - rightStart, nodes));\n let result = [];\n if (from > 0) this.decomposeLeft(from, result);\n let left = result.length;\n for (let node of nodes)result.push(node);\n if (from > 0) mergeGaps(result, left - 1);\n if (to < this.length) {\n let right = result.length;\n this.decomposeRight(to, result);\n mergeGaps(result, right);\n }\n return HeightMap.of(result);\n }\n decomposeLeft(to, result) {\n let left = this.left.length;\n if (to <= left) return this.left.decomposeLeft(to, result);\n result.push(this.left);\n if (this.break) {\n left++;\n if (to >= left) result.push(null);\n }\n if (to > left) this.right.decomposeLeft(to - left, result);\n }\n decomposeRight(from, result) {\n let left = this.left.length, right = left + this.break;\n if (from >= right) return this.right.decomposeRight(from - right, result);\n if (from < left) this.left.decomposeRight(from, result);\n if (this.break && from < right) result.push(null);\n result.push(this.right);\n }\n balanced(left, right) {\n if (left.size > 2 * right.size || right.size > 2 * left.size) return HeightMap.of(this.break ? [\n left,\n null,\n right\n ] : [\n left,\n right\n ]);\n this.left = left;\n this.right = right;\n this.height = left.height + right.height;\n this.outdated = left.outdated || right.outdated;\n this.size = left.size + right.size;\n this.length = left.length + this.break + right.length;\n return this;\n }\n updateHeight(oracle, offset = 0, force = false, measured) {\n let { left , right } = this, rightStart = offset + left.length + this.break, rebalance = null;\n if (measured && measured.from <= offset + left.length && measured.more) rebalance = left = left.updateHeight(oracle, offset, force, measured);\n else left.updateHeight(oracle, offset, force);\n if (measured && measured.from <= rightStart + right.length && measured.more) rebalance = right = right.updateHeight(oracle, rightStart, force, measured);\n else right.updateHeight(oracle, rightStart, force);\n if (rebalance) return this.balanced(left, right);\n this.height = this.left.height + this.right.height;\n this.outdated = false;\n return this;\n }\n toString() {\n return this.left + (this.break ? \" \" : \"-\") + this.right;\n }\n}\nfunction mergeGaps(nodes, around) {\n let before, after;\n if (nodes[around] == null && (before = nodes[around - 1]) instanceof HeightMapGap && (after = nodes[around + 1]) instanceof HeightMapGap) nodes.splice(around - 1, 3, new HeightMapGap(before.length + 1 + after.length));\n}\nconst relevantWidgetHeight = 5;\nclass NodeBuilder {\n constructor(pos, oracle){\n this.pos = pos;\n this.oracle = oracle;\n this.nodes = [];\n this.lineStart = -1;\n this.lineEnd = -1;\n this.covering = null;\n this.writtenTo = pos;\n }\n get isCovered() {\n return this.covering && this.nodes[this.nodes.length - 1] == this.covering;\n }\n span(_from, to) {\n if (this.lineStart > -1) {\n let end = Math.min(to, this.lineEnd), last = this.nodes[this.nodes.length - 1];\n if (last instanceof HeightMapText) last.length += end - this.pos;\n else if (end > this.pos || !this.isCovered) this.nodes.push(new HeightMapText(end - this.pos, -1));\n this.writtenTo = end;\n if (to > end) {\n this.nodes.push(null);\n this.writtenTo++;\n this.lineStart = -1;\n }\n }\n this.pos = to;\n }\n point(from, to, deco) {\n if (from < to || deco.heightRelevant) {\n let height = deco.widget ? deco.widget.estimatedHeight : 0;\n if (height < 0) height = this.oracle.lineHeight;\n let len = to - from;\n if (deco.block) this.addBlock(new HeightMapBlock(len, height, deco.type));\n else if (len || height >= relevantWidgetHeight) this.addLineDeco(height, len);\n } else if (to > from) this.span(from, to);\n if (this.lineEnd > -1 && this.lineEnd < this.pos) this.lineEnd = this.oracle.doc.lineAt(this.pos).to;\n }\n enterLine() {\n if (this.lineStart > -1) return;\n let { from , to } = this.oracle.doc.lineAt(this.pos);\n this.lineStart = from;\n this.lineEnd = to;\n if (this.writtenTo < from) {\n if (this.writtenTo < from - 1 || this.nodes[this.nodes.length - 1] == null) this.nodes.push(this.blankContent(this.writtenTo, from - 1));\n this.nodes.push(null);\n }\n if (this.pos > from) this.nodes.push(new HeightMapText(this.pos - from, -1));\n this.writtenTo = this.pos;\n }\n blankContent(from, to) {\n let gap = new HeightMapGap(to - from);\n if (this.oracle.doc.lineAt(from).to == to) gap.flags |= 4 /* SingleLine */ ;\n return gap;\n }\n ensureLine() {\n this.enterLine();\n let last = this.nodes.length ? this.nodes[this.nodes.length - 1] : null;\n if (last instanceof HeightMapText) return last;\n let line = new HeightMapText(0, -1);\n this.nodes.push(line);\n return line;\n }\n addBlock(block) {\n this.enterLine();\n if (block.type == BlockType.WidgetAfter && !this.isCovered) this.ensureLine();\n this.nodes.push(block);\n this.writtenTo = this.pos = this.pos + block.length;\n if (block.type != BlockType.WidgetBefore) this.covering = block;\n }\n addLineDeco(height, length) {\n let line = this.ensureLine();\n line.length += length;\n line.collapsed += length;\n line.widgetHeight = Math.max(line.widgetHeight, height);\n this.writtenTo = this.pos = this.pos + length;\n }\n finish(from) {\n let last = this.nodes.length == 0 ? null : this.nodes[this.nodes.length - 1];\n if (this.lineStart > -1 && !(last instanceof HeightMapText) && !this.isCovered) this.nodes.push(new HeightMapText(0, -1));\n else if (this.writtenTo < this.pos || last == null) this.nodes.push(this.blankContent(this.writtenTo, this.pos));\n let pos = from;\n for (let node of this.nodes){\n if (node instanceof HeightMapText) node.updateHeight(this.oracle, pos);\n pos += node ? node.length : 1;\n }\n return this.nodes;\n }\n // Always called with a region that on both sides either stretches\n // to a line break or the end of the document.\n // The returned array uses null to indicate line breaks, but never\n // starts or ends in a line break, or has multiple line breaks next\n // to each other.\n static build(oracle, decorations4, from, to) {\n let builder = new NodeBuilder(from, oracle);\n _rangeset.RangeSet.spans(decorations4, from, to, builder, 0);\n return builder.finish(from);\n }\n}\nfunction heightRelevantDecoChanges(a, b, diff) {\n let comp = new DecorationComparator;\n _rangeset.RangeSet.compare(a, b, diff, comp, 0);\n return comp.changes;\n}\nclass DecorationComparator {\n constructor(){\n this.changes = [];\n }\n compareRange() {\n }\n comparePoint(from, to, a, b) {\n if (from < to || a && a.heightRelevant || b && b.heightRelevant) addRange(from, to, this.changes, 5);\n }\n}\nfunction visiblePixelRange(dom, paddingTop) {\n let rect = dom.getBoundingClientRect();\n let left = Math.max(0, rect.left), right = Math.min(innerWidth, rect.right);\n let top = Math.max(0, rect.top), bottom = Math.min(innerHeight, rect.bottom);\n let body = dom.ownerDocument.body;\n for(let parent = dom.parentNode; parent && parent != body;){\n if (parent.nodeType == 1) {\n let elt = parent;\n let style = window.getComputedStyle(elt);\n if ((elt.scrollHeight > elt.clientHeight || elt.scrollWidth > elt.clientWidth) && style.overflow != \"visible\") {\n let parentRect = elt.getBoundingClientRect();\n left = Math.max(left, parentRect.left);\n right = Math.min(right, parentRect.right);\n top = Math.max(top, parentRect.top);\n bottom = Math.min(bottom, parentRect.bottom);\n }\n parent = style.position == \"absolute\" || style.position == \"fixed\" ? elt.offsetParent : elt.parentNode;\n } else if (parent.nodeType == 11) parent = parent.host;\n else break;\n }\n return {\n left: left - rect.left,\n right: Math.max(left, right) - rect.left,\n top: top - (rect.top + paddingTop),\n bottom: Math.max(top, bottom) - (rect.top + paddingTop)\n };\n}\n// Line gaps are placeholder widgets used to hide pieces of overlong\n// lines within the viewport, as a kludge to keep the editor\n// responsive when a ridiculously long line is loaded into it.\nclass LineGap {\n constructor(from, to, size){\n this.from = from;\n this.to = to;\n this.size = size;\n }\n static same(a, b) {\n if (a.length != b.length) return false;\n for(let i = 0; i < a.length; i++){\n let gA = a[i], gB = b[i];\n if (gA.from != gB.from || gA.to != gB.to || gA.size != gB.size) return false;\n }\n return true;\n }\n draw(wrapping) {\n return Decoration.replace({\n widget: new LineGapWidget(this.size, wrapping)\n }).range(this.from, this.to);\n }\n}\nclass LineGapWidget extends WidgetType {\n constructor(size, vertical){\n super();\n this.size = size;\n this.vertical = vertical;\n }\n eq(other) {\n return other.size == this.size && other.vertical == this.vertical;\n }\n toDOM() {\n let elt = document.createElement(\"div\");\n if (this.vertical) elt.style.height = this.size + \"px\";\n else {\n elt.style.width = this.size + \"px\";\n elt.style.height = \"2px\";\n elt.style.display = \"inline-block\";\n }\n return elt;\n }\n get estimatedHeight() {\n return this.vertical ? this.size : -1;\n }\n}\nclass ViewState {\n constructor(state){\n this.state = state;\n // These are contentDOM-local coordinates\n this.pixelViewport = {\n left: 0,\n right: window.innerWidth,\n top: 0,\n bottom: 0\n };\n this.inView = true;\n this.paddingTop = 0;\n this.paddingBottom = 0;\n this.contentDOMWidth = 0;\n this.contentDOMHeight = 0;\n this.editorHeight = 0;\n this.editorWidth = 0;\n this.heightOracle = new HeightOracle;\n // See VP.MaxDOMHeight\n this.scaler = IdScaler;\n this.scrollTarget = null;\n // Briefly set to true when printing, to disable viewport limiting\n this.printing = false;\n // Flag set when editor content was redrawn, so that the next\n // measure stage knows it must read DOM layout\n this.mustMeasureContent = true;\n this.visibleRanges = [];\n // Cursor 'assoc' is only significant when the cursor is on a line\n // wrap point, where it must stick to the character that it is\n // associated with. Since browsers don't provide a reasonable\n // interface to set or query this, when a selection is set that\n // might cause this to be significant, this flag is set. The next\n // measure phase will check whether the cursor is on a line-wrapping\n // boundary and, if so, reset it to make sure it is positioned in\n // the right place.\n this.mustEnforceCursorAssoc = false;\n this.heightMap = HeightMap.empty().applyChanges(state.facet(decorations), _text.Text.empty, this.heightOracle.setDoc(state.doc), [\n new ChangedRange(0, 0, 0, state.doc.length)\n ]);\n this.viewport = this.getViewport(0, null);\n this.updateViewportLines();\n this.updateForViewport();\n this.lineGaps = this.ensureLineGaps([]);\n this.lineGapDeco = Decoration.set(this.lineGaps.map((gap)=>gap.draw(false)\n ));\n this.computeVisibleRanges();\n }\n updateForViewport() {\n let viewports = [\n this.viewport\n ], { main } = this.state.selection;\n for(let i = 0; i <= 1; i++){\n let pos = i ? main.head : main.anchor;\n if (!viewports.some(({ from , to })=>pos >= from && pos <= to\n )) {\n let { from , to } = this.lineBlockAt(pos);\n viewports.push(new Viewport(from, to));\n }\n }\n this.viewports = viewports.sort((a, b)=>a.from - b.from\n );\n this.scaler = this.heightMap.height <= 7000000 /* MaxDOMHeight */ ? IdScaler : new BigScaler(this.heightOracle.doc, this.heightMap, this.viewports);\n }\n updateViewportLines() {\n this.viewportLines = [];\n this.heightMap.forEachLine(this.viewport.from, this.viewport.to, this.state.doc, 0, 0, (block)=>{\n this.viewportLines.push(this.scaler.scale == 1 ? block : scaleBlock(block, this.scaler));\n });\n }\n update(update, scrollTarget = null) {\n let prev = this.state;\n this.state = update.state;\n let newDeco = this.state.facet(decorations);\n let contentChanges = update.changedRanges;\n let heightChanges = ChangedRange.extendWithRanges(contentChanges, heightRelevantDecoChanges(update.startState.facet(decorations), newDeco, update ? update.changes : _state.ChangeSet.empty(this.state.doc.length)));\n let prevHeight = this.heightMap.height;\n this.heightMap = this.heightMap.applyChanges(newDeco, prev.doc, this.heightOracle.setDoc(this.state.doc), heightChanges);\n if (this.heightMap.height != prevHeight) update.flags |= 2 /* Height */ ;\n let viewport = heightChanges.length ? this.mapViewport(this.viewport, update.changes) : this.viewport;\n if (scrollTarget && (scrollTarget.range.head < viewport.from || scrollTarget.range.head > viewport.to) || !this.viewportIsAppropriate(viewport)) viewport = this.getViewport(0, scrollTarget);\n let updateLines = !update.changes.empty || update.flags & 2 /* Height */ || viewport.from != this.viewport.from || viewport.to != this.viewport.to;\n this.viewport = viewport;\n this.updateForViewport();\n if (updateLines) this.updateViewportLines();\n if (this.lineGaps.length || this.viewport.to - this.viewport.from > 4000 /* DoubleMargin */ ) this.updateLineGaps(this.ensureLineGaps(this.mapLineGaps(this.lineGaps, update.changes)));\n update.flags |= this.computeVisibleRanges();\n if (scrollTarget) this.scrollTarget = scrollTarget;\n if (!this.mustEnforceCursorAssoc && update.selectionSet && update.view.lineWrapping && update.state.selection.main.empty && update.state.selection.main.assoc) this.mustEnforceCursorAssoc = true;\n }\n measure(view) {\n let dom = view.contentDOM, style = window.getComputedStyle(dom);\n let oracle = this.heightOracle;\n let whiteSpace = style.whiteSpace, direction = style.direction == \"rtl\" ? Direction.RTL : Direction.LTR;\n let refresh = this.heightOracle.mustRefreshForStyle(whiteSpace, direction);\n let measureContent = refresh || this.mustMeasureContent || this.contentDOMHeight != dom.clientHeight;\n let result = 0, bias = 0;\n if (this.editorWidth != view.scrollDOM.clientWidth) {\n if (oracle.lineWrapping) measureContent = true;\n this.editorWidth = view.scrollDOM.clientWidth;\n result |= 8 /* Geometry */ ;\n }\n if (measureContent) {\n this.mustMeasureContent = false;\n this.contentDOMHeight = dom.clientHeight;\n // Vertical padding\n let paddingTop = parseInt(style.paddingTop) || 0, paddingBottom = parseInt(style.paddingBottom) || 0;\n if (this.paddingTop != paddingTop || this.paddingBottom != paddingBottom) {\n result |= 8 /* Geometry */ ;\n this.paddingTop = paddingTop;\n this.paddingBottom = paddingBottom;\n }\n }\n // Pixel viewport\n let pixelViewport = this.printing ? {\n top: -100000000,\n bottom: 100000000,\n left: -100000000,\n right: 100000000\n } : visiblePixelRange(dom, this.paddingTop);\n let dTop = pixelViewport.top - this.pixelViewport.top, dBottom = pixelViewport.bottom - this.pixelViewport.bottom;\n this.pixelViewport = pixelViewport;\n let inView = this.pixelViewport.bottom > this.pixelViewport.top && this.pixelViewport.right > this.pixelViewport.left;\n if (inView != this.inView) {\n this.inView = inView;\n if (inView) measureContent = true;\n }\n if (!this.inView) return 0;\n let contentWidth = dom.clientWidth;\n if (this.contentDOMWidth != contentWidth || this.editorHeight != view.scrollDOM.clientHeight) {\n this.contentDOMWidth = contentWidth;\n this.editorHeight = view.scrollDOM.clientHeight;\n result |= 8 /* Geometry */ ;\n }\n if (measureContent) {\n let lineHeights = view.docView.measureVisibleLineHeights();\n if (oracle.mustRefreshForHeights(lineHeights)) refresh = true;\n if (refresh || oracle.lineWrapping && Math.abs(contentWidth - this.contentDOMWidth) > oracle.charWidth) {\n let { lineHeight , charWidth } = view.docView.measureTextSize();\n refresh = oracle.refresh(whiteSpace, direction, lineHeight, charWidth, contentWidth / charWidth, lineHeights);\n if (refresh) {\n view.docView.minWidth = 0;\n result |= 8 /* Geometry */ ;\n }\n }\n if (dTop > 0 && dBottom > 0) bias = Math.max(dTop, dBottom);\n else if (dTop < 0 && dBottom < 0) bias = Math.min(dTop, dBottom);\n oracle.heightChanged = false;\n this.heightMap = this.heightMap.updateHeight(oracle, 0, refresh, new MeasuredHeights(this.viewport.from, lineHeights));\n if (oracle.heightChanged) result |= 2 /* Height */ ;\n }\n let viewportChange = !this.viewportIsAppropriate(this.viewport, bias) || this.scrollTarget && (this.scrollTarget.range.head < this.viewport.from || this.scrollTarget.range.head > this.viewport.to);\n if (viewportChange) this.viewport = this.getViewport(bias, this.scrollTarget);\n this.updateForViewport();\n if (result & 2 /* Height */ || viewportChange) this.updateViewportLines();\n if (this.lineGaps.length || this.viewport.to - this.viewport.from > 4000 /* DoubleMargin */ ) this.updateLineGaps(this.ensureLineGaps(refresh ? [] : this.lineGaps));\n result |= this.computeVisibleRanges();\n if (this.mustEnforceCursorAssoc) {\n this.mustEnforceCursorAssoc = false;\n // This is done in the read stage, because moving the selection\n // to a line end is going to trigger a layout anyway, so it\n // can't be a pure write. It should be rare that it does any\n // writing.\n view.docView.enforceCursorAssoc();\n }\n return result;\n }\n get visibleTop() {\n return this.scaler.fromDOM(this.pixelViewport.top);\n }\n get visibleBottom() {\n return this.scaler.fromDOM(this.pixelViewport.bottom);\n }\n getViewport(bias, scrollTarget) {\n // This will divide VP.Margin between the top and the\n // bottom, depending on the bias (the change in viewport position\n // since the last update). It'll hold a number between 0 and 1\n let marginTop = 0.5 - Math.max(-0.5, Math.min(0.5, bias / 1000 /* Margin */ / 2));\n let map = this.heightMap, doc16 = this.state.doc, { visibleTop , visibleBottom } = this;\n let viewport = new Viewport(map.lineAt(visibleTop - marginTop * 1000 /* Margin */ , QueryType.ByHeight, doc16, 0, 0).from, map.lineAt(visibleBottom + (1 - marginTop) * 1000 /* Margin */ , QueryType.ByHeight, doc16, 0, 0).to);\n // If scrollTarget is given, make sure the viewport includes that position\n if (scrollTarget) {\n let { head } = scrollTarget.range;\n if (head < viewport.from || head > viewport.to) {\n let viewHeight = Math.min(this.editorHeight, this.pixelViewport.bottom - this.pixelViewport.top);\n let block = map.lineAt(head, QueryType.ByPos, doc16, 0, 0), topPos;\n if (scrollTarget.y == \"center\") topPos = (block.top + block.bottom) / 2 - viewHeight / 2;\n else if (scrollTarget.y == \"start\" || scrollTarget.y == \"nearest\" && head < viewport.from) topPos = block.top;\n else topPos = block.bottom - viewHeight;\n viewport = new Viewport(map.lineAt(topPos - 500, QueryType.ByHeight, doc16, 0, 0).from, map.lineAt(topPos + viewHeight + 500, QueryType.ByHeight, doc16, 0, 0).to);\n }\n }\n return viewport;\n }\n mapViewport(viewport, changes) {\n let from = changes.mapPos(viewport.from, -1), to = changes.mapPos(viewport.to, 1);\n return new Viewport(this.heightMap.lineAt(from, QueryType.ByPos, this.state.doc, 0, 0).from, this.heightMap.lineAt(to, QueryType.ByPos, this.state.doc, 0, 0).to);\n }\n // Checks if a given viewport covers the visible part of the\n // document and not too much beyond that.\n viewportIsAppropriate({ from , to }, bias = 0) {\n if (!this.inView) return true;\n let { top } = this.heightMap.lineAt(from, QueryType.ByPos, this.state.doc, 0, 0);\n let { bottom } = this.heightMap.lineAt(to, QueryType.ByPos, this.state.doc, 0, 0);\n let { visibleTop , visibleBottom } = this;\n return (from == 0 || top <= visibleTop - Math.max(10 /* MinCoverMargin */ , Math.min(-bias, 250 /* MaxCoverMargin */ ))) && (to == this.state.doc.length || bottom >= visibleBottom + Math.max(10 /* MinCoverMargin */ , Math.min(bias, 250 /* MaxCoverMargin */ ))) && top > visibleTop - 2000 /* Margin */ && bottom < visibleBottom + 2000 /* Margin */ ;\n }\n mapLineGaps(gaps, changes) {\n if (!gaps.length || changes.empty) return gaps;\n let mapped = [];\n for (let gap of gaps)if (!changes.touchesRange(gap.from, gap.to)) mapped.push(new LineGap(changes.mapPos(gap.from), changes.mapPos(gap.to), gap.size));\n return mapped;\n }\n // Computes positions in the viewport where the start or end of a\n // line should be hidden, trying to reuse existing line gaps when\n // appropriate to avoid unneccesary redraws.\n // Uses crude character-counting for the positioning and sizing,\n // since actual DOM coordinates aren't always available and\n // predictable. Relies on generous margins (see LG.Margin) to hide\n // the artifacts this might produce from the user.\n ensureLineGaps(current) {\n let gaps = [];\n // This won't work at all in predominantly right-to-left text.\n if (this.heightOracle.direction != Direction.LTR) return gaps;\n for (let line of this.viewportLines){\n if (line.length < 4000 /* DoubleMargin */ ) continue;\n let structure = lineStructure(line.from, line.to, this.state);\n if (structure.total < 4000 /* DoubleMargin */ ) continue;\n let viewFrom, viewTo;\n if (this.heightOracle.lineWrapping) {\n let marginHeight = 2000 /* Margin */ / this.heightOracle.lineLength * this.heightOracle.lineHeight;\n viewFrom = findPosition(structure, (this.visibleTop - line.top - marginHeight) / line.height);\n viewTo = findPosition(structure, (this.visibleBottom - line.top + marginHeight) / line.height);\n } else {\n let totalWidth = structure.total * this.heightOracle.charWidth;\n let marginWidth = 2000 /* Margin */ * this.heightOracle.charWidth;\n viewFrom = findPosition(structure, (this.pixelViewport.left - marginWidth) / totalWidth);\n viewTo = findPosition(structure, (this.pixelViewport.right + marginWidth) / totalWidth);\n }\n let outside = [];\n if (viewFrom > line.from) outside.push({\n from: line.from,\n to: viewFrom\n });\n if (viewTo < line.to) outside.push({\n from: viewTo,\n to: line.to\n });\n let sel = this.state.selection.main;\n // Make sure the gaps don't cover a selection end\n if (sel.from >= line.from && sel.from <= line.to) cutRange(outside, sel.from - 10 /* SelectionMargin */ , sel.from + 10 /* SelectionMargin */ );\n if (!sel.empty && sel.to >= line.from && sel.to <= line.to) cutRange(outside, sel.to - 10 /* SelectionMargin */ , sel.to + 10 /* SelectionMargin */ );\n for (let { from , to } of outside)if (to - from > 1000 /* HalfMargin */ ) gaps.push(find(current, (gap)=>gap.from >= line.from && gap.to <= line.to && Math.abs(gap.from - from) < 1000 /* HalfMargin */ && Math.abs(gap.to - to) < 1000 /* HalfMargin */ \n ) || new LineGap(from, to, this.gapSize(line, from, to, structure)));\n }\n return gaps;\n }\n gapSize(line, from, to, structure) {\n let fraction = findFraction(structure, to) - findFraction(structure, from);\n if (this.heightOracle.lineWrapping) return line.height * fraction;\n else return structure.total * this.heightOracle.charWidth * fraction;\n }\n updateLineGaps(gaps) {\n if (!LineGap.same(gaps, this.lineGaps)) {\n this.lineGaps = gaps;\n this.lineGapDeco = Decoration.set(gaps.map((gap)=>gap.draw(this.heightOracle.lineWrapping)\n ));\n }\n }\n computeVisibleRanges() {\n let deco = this.state.facet(decorations);\n if (this.lineGaps.length) deco = deco.concat(this.lineGapDeco);\n let ranges = [];\n _rangeset.RangeSet.spans(deco, this.viewport.from, this.viewport.to, {\n span (from, to) {\n ranges.push({\n from,\n to\n });\n },\n point () {\n }\n }, 20);\n let changed = ranges.length != this.visibleRanges.length || this.visibleRanges.some((r, i)=>r.from != ranges[i].from || r.to != ranges[i].to\n );\n this.visibleRanges = ranges;\n return changed ? 4 /* Viewport */ : 0;\n }\n lineBlockAt(pos) {\n return pos >= this.viewport.from && pos <= this.viewport.to && this.viewportLines.find((b)=>b.from <= pos && b.to >= pos\n ) || scaleBlock(this.heightMap.lineAt(pos, QueryType.ByPos, this.state.doc, 0, 0), this.scaler);\n }\n lineBlockAtHeight(height) {\n return scaleBlock(this.heightMap.lineAt(this.scaler.fromDOM(height), QueryType.ByHeight, this.state.doc, 0, 0), this.scaler);\n }\n elementAtHeight(height) {\n return scaleBlock(this.heightMap.blockAt(this.scaler.fromDOM(height), this.state.doc, 0, 0), this.scaler);\n }\n get docHeight() {\n return this.scaler.toDOM(this.heightMap.height);\n }\n get contentHeight() {\n return this.docHeight + this.paddingTop + this.paddingBottom;\n }\n}\nclass Viewport {\n constructor(from, to){\n this.from = from;\n this.to = to;\n }\n}\nfunction lineStructure(from1, to1, state) {\n let ranges = [], pos = from1, total = 0;\n _rangeset.RangeSet.spans(state.facet(decorations), from1, to1, {\n span () {\n },\n point (from, to) {\n if (from > pos) {\n ranges.push({\n from: pos,\n to: from\n });\n total += from - pos;\n }\n pos = to;\n }\n }, 20); // We're only interested in collapsed ranges of a significant size\n if (pos < to1) {\n ranges.push({\n from: pos,\n to: to1\n });\n total += to1 - pos;\n }\n return {\n total,\n ranges\n };\n}\nfunction findPosition({ total , ranges }, ratio) {\n if (ratio <= 0) return ranges[0].from;\n if (ratio >= 1) return ranges[ranges.length - 1].to;\n let dist = Math.floor(total * ratio);\n for(let i = 0;; i++){\n let { from , to } = ranges[i], size = to - from;\n if (dist <= size) return from + dist;\n dist -= size;\n }\n}\nfunction findFraction(structure, pos) {\n let counted = 0;\n for (let { from , to } of structure.ranges){\n if (pos <= to) {\n counted += pos - from;\n break;\n }\n counted += to - from;\n }\n return counted / structure.total;\n}\nfunction cutRange(ranges, from, to) {\n for(let i = 0; i < ranges.length; i++){\n let r = ranges[i];\n if (r.from < to && r.to > from) {\n let pieces = [];\n if (r.from < from) pieces.push({\n from: r.from,\n to: from\n });\n if (r.to > to) pieces.push({\n from: to,\n to: r.to\n });\n ranges.splice(i, 1, ...pieces);\n i += pieces.length - 1;\n }\n }\n}\nfunction find(array, f) {\n for (let val of array)if (f(val)) return val;\n return undefined;\n}\n// Don't scale when the document height is within the range of what\n// the DOM can handle.\nconst IdScaler = {\n toDOM (n) {\n return n;\n },\n fromDOM (n) {\n return n;\n },\n scale: 1\n};\n// When the height is too big (> VP.MaxDOMHeight), scale down the\n// regions outside the viewports so that the total height is\n// VP.MaxDOMHeight.\nclass BigScaler {\n constructor(doc17, heightMap, viewports){\n let vpHeight = 0, base = 0, domBase = 0;\n this.viewports = viewports.map(({ from , to })=>{\n let top = heightMap.lineAt(from, QueryType.ByPos, doc17, 0, 0).top;\n let bottom = heightMap.lineAt(to, QueryType.ByPos, doc17, 0, 0).bottom;\n vpHeight += bottom - top;\n return {\n from,\n to,\n top,\n bottom,\n domTop: 0,\n domBottom: 0\n };\n });\n this.scale = (7000000 /* MaxDOMHeight */ - vpHeight) / (heightMap.height - vpHeight);\n for (let obj of this.viewports){\n obj.domTop = domBase + (obj.top - base) * this.scale;\n domBase = obj.domBottom = obj.domTop + (obj.bottom - obj.top);\n base = obj.bottom;\n }\n }\n toDOM(n) {\n for(let i = 0, base = 0, domBase = 0;; i++){\n let vp = i < this.viewports.length ? this.viewports[i] : null;\n if (!vp || n < vp.top) return domBase + (n - base) * this.scale;\n if (n <= vp.bottom) return vp.domTop + (n - vp.top);\n base = vp.bottom;\n domBase = vp.domBottom;\n }\n }\n fromDOM(n) {\n for(let i = 0, base = 0, domBase = 0;; i++){\n let vp = i < this.viewports.length ? this.viewports[i] : null;\n if (!vp || n < vp.domTop) return base + (n - domBase) / this.scale;\n if (n <= vp.domBottom) return vp.top + (n - vp.domTop);\n base = vp.bottom;\n domBase = vp.domBottom;\n }\n }\n}\nfunction scaleBlock(block, scaler) {\n if (scaler.scale == 1) return block;\n let bTop = scaler.toDOM(block.top), bBottom = scaler.toDOM(block.bottom);\n return new BlockInfo(block.from, block.length, bTop, bBottom - bTop, Array.isArray(block.type) ? block.type.map((b)=>scaleBlock(b, scaler)\n ) : block.type);\n}\nconst theme = /*@__PURE__*/ _state.Facet.define({\n combine: (strs)=>strs.join(\" \")\n});\nconst darkTheme = /*@__PURE__*/ _state.Facet.define({\n combine: (values)=>values.indexOf(true) > -1\n});\nconst baseThemeID = /*@__PURE__*/ _styleMod.StyleModule.newName(), baseLightID = /*@__PURE__*/ _styleMod.StyleModule.newName(), baseDarkID = /*@__PURE__*/ _styleMod.StyleModule.newName();\nconst lightDarkIDs = {\n \"&light\": \".\" + baseLightID,\n \"&dark\": \".\" + baseDarkID\n};\nfunction buildTheme(main, spec, scopes) {\n return new _styleMod.StyleModule(spec, {\n finish (sel) {\n return /&/.test(sel) ? sel.replace(/&\\w*/, (m)=>{\n if (m == \"&\") return main;\n if (!scopes || !scopes[m]) throw new RangeError(`Unsupported selector: ${m}`);\n return scopes[m];\n }) : main + \" \" + sel;\n }\n });\n}\nconst baseTheme = /*@__PURE__*/ buildTheme(\".\" + baseThemeID, {\n \"&.cm-editor\": {\n position: \"relative !important\",\n boxSizing: \"border-box\",\n \"&.cm-focused\": {\n // Provide a simple default outline to make sure a focused\n // editor is visually distinct. Can't leave the default behavior\n // because that will apply to the content element, which is\n // inside the scrollable container and doesn't include the\n // gutters. We also can't use an 'auto' outline, since those\n // are, for some reason, drawn behind the element content, which\n // will cause things like the active line background to cover\n // the outline (#297).\n outline: \"1px dotted #212121\"\n },\n display: \"flex !important\",\n flexDirection: \"column\"\n },\n \".cm-scroller\": {\n display: \"flex !important\",\n alignItems: \"flex-start !important\",\n fontFamily: \"monospace\",\n lineHeight: 1.4,\n height: \"100%\",\n overflowX: \"auto\",\n position: \"relative\",\n zIndex: 0\n },\n \".cm-content\": {\n margin: 0,\n flexGrow: 2,\n minHeight: \"100%\",\n display: \"block\",\n whiteSpace: \"pre\",\n wordWrap: \"normal\",\n boxSizing: \"border-box\",\n padding: \"4px 0\",\n outline: \"none\",\n \"&[contenteditable=true]\": {\n WebkitUserModify: \"read-write-plaintext-only\"\n }\n },\n \".cm-lineWrapping\": {\n whiteSpace_fallback: \"pre-wrap\",\n whiteSpace: \"break-spaces\",\n wordBreak: \"break-word\",\n overflowWrap: \"anywhere\"\n },\n \"&light .cm-content\": {\n caretColor: \"black\"\n },\n \"&dark .cm-content\": {\n caretColor: \"white\"\n },\n \".cm-line\": {\n display: \"block\",\n padding: \"0 2px 0 4px\"\n },\n \".cm-selectionLayer\": {\n zIndex: -1,\n contain: \"size style\"\n },\n \".cm-selectionBackground\": {\n position: \"absolute\"\n },\n \"&light .cm-selectionBackground\": {\n background: \"#d9d9d9\"\n },\n \"&dark .cm-selectionBackground\": {\n background: \"#222\"\n },\n \"&light.cm-focused .cm-selectionBackground\": {\n background: \"#d7d4f0\"\n },\n \"&dark.cm-focused .cm-selectionBackground\": {\n background: \"#233\"\n },\n \".cm-cursorLayer\": {\n zIndex: 100,\n contain: \"size style\",\n pointerEvents: \"none\"\n },\n \"&.cm-focused .cm-cursorLayer\": {\n animation: \"steps(1) cm-blink 1.2s infinite\"\n },\n // Two animations defined so that we can switch between them to\n // restart the animation without forcing another style\n // recomputation.\n \"@keyframes cm-blink\": {\n \"0%\": {\n },\n \"50%\": {\n visibility: \"hidden\"\n },\n \"100%\": {\n }\n },\n \"@keyframes cm-blink2\": {\n \"0%\": {\n },\n \"50%\": {\n visibility: \"hidden\"\n },\n \"100%\": {\n }\n },\n \".cm-cursor, .cm-dropCursor\": {\n position: \"absolute\",\n borderLeft: \"1.2px solid black\",\n marginLeft: \"-0.6px\",\n pointerEvents: \"none\"\n },\n \".cm-cursor\": {\n display: \"none\"\n },\n \"&dark .cm-cursor\": {\n borderLeftColor: \"#444\"\n },\n \"&.cm-focused .cm-cursor\": {\n display: \"block\"\n },\n \"&light .cm-activeLine\": {\n backgroundColor: \"#f3f9ff\"\n },\n \"&dark .cm-activeLine\": {\n backgroundColor: \"#223039\"\n },\n \"&light .cm-specialChar\": {\n color: \"red\"\n },\n \"&dark .cm-specialChar\": {\n color: \"#f78\"\n },\n \".cm-tab\": {\n display: \"inline-block\",\n overflow: \"hidden\",\n verticalAlign: \"bottom\"\n },\n \".cm-placeholder\": {\n color: \"#888\",\n display: \"inline-block\",\n verticalAlign: \"top\"\n },\n \".cm-button\": {\n verticalAlign: \"middle\",\n color: \"inherit\",\n fontSize: \"70%\",\n padding: \".2em 1em\",\n borderRadius: \"1px\"\n },\n \"&light .cm-button\": {\n backgroundImage: \"linear-gradient(#eff1f5, #d9d9df)\",\n border: \"1px solid #888\",\n \"&:active\": {\n backgroundImage: \"linear-gradient(#b4b4b4, #d0d3d6)\"\n }\n },\n \"&dark .cm-button\": {\n backgroundImage: \"linear-gradient(#393939, #111)\",\n border: \"1px solid #888\",\n \"&:active\": {\n backgroundImage: \"linear-gradient(#111, #333)\"\n }\n },\n \".cm-textfield\": {\n verticalAlign: \"middle\",\n color: \"inherit\",\n fontSize: \"70%\",\n border: \"1px solid silver\",\n padding: \".2em .5em\"\n },\n \"&light .cm-textfield\": {\n backgroundColor: \"white\"\n },\n \"&dark .cm-textfield\": {\n border: \"1px solid #555\",\n backgroundColor: \"inherit\"\n }\n}, lightDarkIDs);\nconst observeOptions = {\n childList: true,\n characterData: true,\n subtree: true,\n attributes: true,\n characterDataOldValue: true\n};\n// IE11 has very broken mutation observers, so we also listen to\n// DOMCharacterDataModified there\nconst useCharData = browser.ie && browser.ie_version <= 11;\nclass DOMObserver {\n constructor(view, onChange, onScrollChanged){\n this.view = view;\n this.onChange = onChange;\n this.onScrollChanged = onScrollChanged;\n this.active = false;\n // The known selection. Kept in our own object, as opposed to just\n // directly accessing the selection because:\n // - Safari doesn't report the right selection in shadow DOM\n // - Reading from the selection forces a DOM layout\n // - This way, we can ignore selectionchange events if we have\n // already seen the 'new' selection\n this.selectionRange = new DOMSelectionState;\n // Set when a selection change is detected, cleared on flush\n this.selectionChanged = false;\n this.delayedFlush = -1;\n this.resizeTimeout = -1;\n this.queue = [];\n this.delayedAndroidKey = null;\n this.scrollTargets = [];\n this.intersection = null;\n this.resize = null;\n this.intersecting = false;\n this.gapIntersection = null;\n this.gaps = [];\n // Timeout for scheduling check of the parents that need scroll handlers\n this.parentCheck = -1;\n this.dom = view.contentDOM;\n this.observer = new MutationObserver((mutations)=>{\n for (let mut of mutations)this.queue.push(mut);\n // IE11 will sometimes (on typing over a selection or\n // backspacing out a single character text node) call the\n // observer callback before actually updating the DOM.\n //\n // Unrelatedly, iOS Safari will, when ending a composition,\n // sometimes first clear it, deliver the mutations, and then\n // reinsert the finished text. CodeMirror's handling of the\n // deletion will prevent the reinsertion from happening,\n // breaking composition.\n if ((browser.ie && browser.ie_version <= 11 || browser.ios && view.composing) && mutations.some((m)=>m.type == \"childList\" && m.removedNodes.length || m.type == \"characterData\" && m.oldValue.length > m.target.nodeValue.length\n )) this.flushSoon();\n else this.flush();\n });\n if (useCharData) this.onCharData = (event)=>{\n this.queue.push({\n target: event.target,\n type: \"characterData\",\n oldValue: event.prevValue\n });\n this.flushSoon();\n };\n this.onSelectionChange = this.onSelectionChange.bind(this);\n if (typeof ResizeObserver == \"function\") {\n this.resize = new ResizeObserver(()=>{\n if (this.view.docView.lastUpdate < Date.now() - 75 && this.resizeTimeout < 0) this.resizeTimeout = setTimeout(()=>{\n this.resizeTimeout = -1;\n this.view.requestMeasure();\n }, 50);\n });\n this.resize.observe(view.scrollDOM);\n }\n this.start();\n this.onScroll = this.onScroll.bind(this);\n window.addEventListener(\"scroll\", this.onScroll);\n if (typeof IntersectionObserver == \"function\") {\n this.intersection = new IntersectionObserver((entries)=>{\n if (this.parentCheck < 0) this.parentCheck = setTimeout(this.listenForScroll.bind(this), 1000);\n if (entries.length > 0 && entries[entries.length - 1].intersectionRatio > 0 != this.intersecting) {\n this.intersecting = !this.intersecting;\n if (this.intersecting != this.view.inView) this.onScrollChanged(document.createEvent(\"Event\"));\n }\n }, {\n });\n this.intersection.observe(this.dom);\n this.gapIntersection = new IntersectionObserver((entries)=>{\n if (entries.length > 0 && entries[entries.length - 1].intersectionRatio > 0) this.onScrollChanged(document.createEvent(\"Event\"));\n }, {\n });\n }\n this.listenForScroll();\n this.readSelectionRange();\n this.dom.ownerDocument.addEventListener(\"selectionchange\", this.onSelectionChange);\n }\n onScroll(e) {\n if (this.intersecting) this.flush(false);\n this.onScrollChanged(e);\n }\n updateGaps(gaps) {\n if (this.gapIntersection && (gaps.length != this.gaps.length || this.gaps.some((g, i)=>g != gaps[i]\n ))) {\n this.gapIntersection.disconnect();\n for (let gap of gaps)this.gapIntersection.observe(gap);\n this.gaps = gaps;\n }\n }\n onSelectionChange(event) {\n if (!this.readSelectionRange() || this.delayedAndroidKey) return;\n let { view } = this, sel = this.selectionRange;\n if (view.state.facet(editable) ? view.root.activeElement != this.dom : !hasSelection(view.dom, sel)) return;\n let context = sel.anchorNode && view.docView.nearest(sel.anchorNode);\n if (context && context.ignoreEvent(event)) return;\n // Deletions on IE11 fire their events in the wrong order, giving\n // us a selection change event before the DOM changes are\n // reported.\n // Chrome Android has a similar issue when backspacing out a\n // selection (#645).\n if ((browser.ie && browser.ie_version <= 11 || browser.android && browser.chrome) && !view.state.selection.main.empty && // (Selection.isCollapsed isn't reliable on IE)\n sel.focusNode && isEquivalentPosition(sel.focusNode, sel.focusOffset, sel.anchorNode, sel.anchorOffset)) this.flushSoon();\n else this.flush(false);\n }\n readSelectionRange() {\n let { root } = this.view, domSel = getSelection(root);\n // The Selection object is broken in shadow roots in Safari. See\n // https://github.com/codemirror/codemirror.next/issues/414\n let range = browser.safari && root.nodeType == 11 && deepActiveElement() == this.view.contentDOM && safariSelectionRangeHack(this.view) || domSel;\n if (this.selectionRange.eq(range)) return false;\n this.selectionRange.setRange(range);\n return this.selectionChanged = true;\n }\n setSelectionRange(anchor, head) {\n this.selectionRange.set(anchor.node, anchor.offset, head.node, head.offset);\n this.selectionChanged = false;\n }\n listenForScroll() {\n this.parentCheck = -1;\n let i = 0, changed = null;\n for(let dom = this.dom; dom;){\n if (dom.nodeType == 1) {\n if (!changed && i < this.scrollTargets.length && this.scrollTargets[i] == dom) i++;\n else if (!changed) changed = this.scrollTargets.slice(0, i);\n if (changed) changed.push(dom);\n dom = dom.assignedSlot || dom.parentNode;\n } else if (dom.nodeType == 11) dom = dom.host;\n else break;\n }\n if (i < this.scrollTargets.length && !changed) changed = this.scrollTargets.slice(0, i);\n if (changed) {\n for (let dom of this.scrollTargets)dom.removeEventListener(\"scroll\", this.onScroll);\n for (let dom1 of this.scrollTargets = changed)dom1.addEventListener(\"scroll\", this.onScroll);\n }\n }\n ignore(f) {\n if (!this.active) return f();\n try {\n this.stop();\n return f();\n } finally{\n this.start();\n this.clear();\n }\n }\n start() {\n if (this.active) return;\n this.observer.observe(this.dom, observeOptions);\n if (useCharData) this.dom.addEventListener(\"DOMCharacterDataModified\", this.onCharData);\n this.active = true;\n }\n stop() {\n if (!this.active) return;\n this.active = false;\n this.observer.disconnect();\n if (useCharData) this.dom.removeEventListener(\"DOMCharacterDataModified\", this.onCharData);\n }\n // Throw away any pending changes\n clear() {\n this.observer.takeRecords();\n this.queue.length = 0;\n this.selectionChanged = false;\n }\n // Chrome Android, especially in combination with GBoard, not only\n // doesn't reliably fire regular key events, but also often\n // surrounds the effect of enter or backspace with a bunch of\n // composition events that, when interrupted, cause text duplication\n // or other kinds of corruption. This hack makes the editor back off\n // from handling DOM changes for a moment when such a key is\n // detected (via beforeinput or keydown), and then dispatches the\n // key event, throwing away the DOM changes if it gets handled.\n delayAndroidKey(key1, keyCode) {\n if (!this.delayedAndroidKey) requestAnimationFrame(()=>{\n let key = this.delayedAndroidKey;\n this.delayedAndroidKey = null;\n let startState = this.view.state;\n if (dispatchKey(this.view.contentDOM, key.key, key.keyCode)) this.processRecords();\n else this.flush();\n if (this.view.state == startState) this.view.update([]);\n });\n // Since backspace beforeinput is sometimes signalled spuriously,\n // Enter always takes precedence.\n if (!this.delayedAndroidKey || key1 == \"Enter\") this.delayedAndroidKey = {\n key: key1,\n keyCode\n };\n }\n flushSoon() {\n if (this.delayedFlush < 0) this.delayedFlush = window.setTimeout(()=>{\n this.delayedFlush = -1;\n this.flush();\n }, 20);\n }\n forceFlush() {\n if (this.delayedFlush >= 0) {\n window.clearTimeout(this.delayedFlush);\n this.delayedFlush = -1;\n this.flush();\n }\n }\n processRecords() {\n let records = this.queue;\n for (let mut of this.observer.takeRecords())records.push(mut);\n if (records.length) this.queue = [];\n let from = -1, to = -1, typeOver = false;\n for (let record of records){\n let range = this.readMutation(record);\n if (!range) continue;\n if (range.typeOver) typeOver = true;\n if (from == -1) ({ from , to } = range);\n else {\n from = Math.min(range.from, from);\n to = Math.max(range.to, to);\n }\n }\n return {\n from,\n to,\n typeOver\n };\n }\n // Apply pending changes, if any\n flush(readSelection = true) {\n // Completely hold off flushing when pending keys are set\u2014the code\n // managing those will make sure processRecords is called and the\n // view is resynchronized after\n if (this.delayedFlush >= 0 || this.delayedAndroidKey) return;\n if (readSelection) this.readSelectionRange();\n let { from , to , typeOver } = this.processRecords();\n let newSel = this.selectionChanged && hasSelection(this.dom, this.selectionRange);\n if (from < 0 && !newSel) return;\n this.selectionChanged = false;\n let startState = this.view.state;\n this.onChange(from, to, typeOver);\n // The view wasn't updated\n if (this.view.state == startState) this.view.update([]);\n }\n readMutation(rec) {\n let cView = this.view.docView.nearest(rec.target);\n if (!cView || cView.ignoreMutation(rec)) return null;\n cView.markDirty(rec.type == \"attributes\");\n if (rec.type == \"attributes\") cView.dirty |= 4 /* Attrs */ ;\n if (rec.type == \"childList\") {\n let childBefore = findChild(cView, rec.previousSibling || rec.target.previousSibling, -1);\n let childAfter = findChild(cView, rec.nextSibling || rec.target.nextSibling, 1);\n return {\n from: childBefore ? cView.posAfter(childBefore) : cView.posAtStart,\n to: childAfter ? cView.posBefore(childAfter) : cView.posAtEnd,\n typeOver: false\n };\n } else if (rec.type == \"characterData\") return {\n from: cView.posAtStart,\n to: cView.posAtEnd,\n typeOver: rec.target.nodeValue == rec.oldValue\n };\n else return null;\n }\n destroy() {\n var _a, _b, _c;\n this.stop();\n (_a = this.intersection) === null || _a === void 0 || _a.disconnect();\n (_b = this.gapIntersection) === null || _b === void 0 || _b.disconnect();\n (_c = this.resize) === null || _c === void 0 || _c.disconnect();\n for (let dom of this.scrollTargets)dom.removeEventListener(\"scroll\", this.onScroll);\n window.removeEventListener(\"scroll\", this.onScroll);\n this.dom.ownerDocument.removeEventListener(\"selectionchange\", this.onSelectionChange);\n clearTimeout(this.parentCheck);\n clearTimeout(this.resizeTimeout);\n }\n}\nfunction findChild(cView, dom, dir) {\n while(dom){\n let curView = ContentView.get(dom);\n if (curView && curView.parent == cView) return curView;\n let parent = dom.parentNode;\n dom = parent != cView.dom ? parent : dir > 0 ? dom.nextSibling : dom.previousSibling;\n }\n return null;\n}\n// Used to work around a Safari Selection/shadow DOM bug (#414)\nfunction safariSelectionRangeHack(view) {\n let found = null;\n // Because Safari (at least in 2018-2021) doesn't provide regular\n // access to the selection inside a shadowroot, we have to perform a\n // ridiculous hack to get at it\u2014using `execCommand` to trigger a\n // `beforeInput` event so that we can read the target range from the\n // event.\n function read(event) {\n event.preventDefault();\n event.stopImmediatePropagation();\n found = event.getTargetRanges()[0];\n }\n view.contentDOM.addEventListener(\"beforeinput\", read, true);\n document.execCommand(\"indent\");\n view.contentDOM.removeEventListener(\"beforeinput\", read, true);\n if (!found) return null;\n let anchorNode = found.startContainer, anchorOffset = found.startOffset;\n let focusNode = found.endContainer, focusOffset = found.endOffset;\n let curAnchor = view.docView.domAtPos(view.state.selection.main.anchor);\n // Since such a range doesn't distinguish between anchor and head,\n // use a heuristic that flips it around if its end matches the\n // current anchor.\n if (isEquivalentPosition(curAnchor.node, curAnchor.offset, focusNode, focusOffset)) [anchorNode, anchorOffset, focusNode, focusOffset] = [\n focusNode,\n focusOffset,\n anchorNode,\n anchorOffset\n ];\n return {\n anchorNode,\n anchorOffset,\n focusNode,\n focusOffset\n };\n}\nfunction applyDOMChange(view, start, end, typeOver) {\n let change, newSel;\n let sel = view.state.selection.main;\n if (start > -1) {\n let bounds = view.docView.domBoundsAround(start, end, 0);\n if (!bounds || view.state.readOnly) return;\n let { from , to } = bounds;\n let selPoints = view.docView.impreciseHead || view.docView.impreciseAnchor ? [] : selectionPoints(view);\n let reader = new DOMReader(selPoints, view.state);\n reader.readRange(bounds.startDOM, bounds.endDOM);\n let preferredPos = sel.from, preferredSide = null;\n // Prefer anchoring to end when Backspace is pressed (or, on\n // Android, when something was deleted)\n if (view.inputState.lastKeyCode === 8 && view.inputState.lastKeyTime > Date.now() - 100 || browser.android && reader.text.length < to - from) {\n preferredPos = sel.to;\n preferredSide = \"end\";\n }\n let diff = findDiff(view.state.doc.sliceString(from, to, LineBreakPlaceholder), reader.text, preferredPos - from, preferredSide);\n if (diff) {\n let orig = diff;\n // Chrome inserts two newlines when pressing shift-enter at the\n // end of a line. This drops one of those.\n if (browser.chrome && view.inputState.lastKeyCode == 13 && diff.toB == diff.from + 2 && reader.text.slice(diff.from, diff.toB) == LineBreakPlaceholder + LineBreakPlaceholder) diff.toB--;\n // Strip leading and trailing zero-width spaces from the inserted\n // content, to work around widget buffers being moved into text\n // nodes by the browser.\n while(diff.from < diff.toB && reader.text[diff.from] == \"\\u200b\"){\n diff = {\n from: diff.from + 1,\n toA: diff.toA,\n toB: diff.toB\n };\n selPoints.forEach((p1)=>p1.pos -= p1.pos > orig.from ? 1 : 0\n );\n }\n while(diff.toB > diff.from && reader.text[diff.toB - 1] == \"\\u200b\"){\n diff = {\n from: diff.from,\n toA: diff.toA,\n toB: diff.toB - 1\n };\n selPoints.forEach((p2)=>p2.pos -= p2.pos > orig.toB ? 1 : 0\n );\n }\n change = {\n from: from + diff.from,\n to: from + diff.toA,\n insert: _state.Text.of(reader.text.slice(diff.from, diff.toB).split(LineBreakPlaceholder))\n };\n }\n newSel = selectionFromPoints(selPoints, from);\n } else if (view.hasFocus || !view.state.facet(editable)) {\n let domSel = view.observer.selectionRange;\n let { impreciseHead: iHead , impreciseAnchor: iAnchor } = view.docView;\n let head = iHead && iHead.node == domSel.focusNode && iHead.offset == domSel.focusOffset || !contains(view.contentDOM, domSel.focusNode) ? view.state.selection.main.head : view.docView.posFromDOM(domSel.focusNode, domSel.focusOffset);\n let anchor = iAnchor && iAnchor.node == domSel.anchorNode && iAnchor.offset == domSel.anchorOffset || !contains(view.contentDOM, domSel.anchorNode) ? view.state.selection.main.anchor : view.docView.posFromDOM(domSel.anchorNode, domSel.anchorOffset);\n if (head != sel.head || anchor != sel.anchor) newSel = _state.EditorSelection.single(anchor, head);\n }\n if (!change && !newSel) return;\n // Heuristic to notice typing over a selected character\n if (!change && typeOver && !sel.empty && newSel && newSel.main.empty) change = {\n from: sel.from,\n to: sel.to,\n insert: view.state.doc.slice(sel.from, sel.to)\n };\n else if (change && change.from >= sel.from && change.to <= sel.to && (change.from != sel.from || change.to != sel.to) && sel.to - sel.from - (change.to - change.from) <= 4) change = {\n from: sel.from,\n to: sel.to,\n insert: view.state.doc.slice(sel.from, change.from).append(change.insert).append(view.state.doc.slice(change.to, sel.to))\n };\n if (change) {\n let startState = view.state;\n if (browser.ios && view.inputState.flushIOSKey(view)) return;\n // Android browsers don't fire reasonable key events for enter,\n // backspace, or delete. So this detects changes that look like\n // they're caused by those keys, and reinterprets them as key\n // events. (Some of these keys are also handled by beforeinput\n // events and the pendingAndroidKey mechanism, but that's not\n // reliable in all situations.)\n if (browser.android && (change.from == sel.from && change.to == sel.to && change.insert.length == 1 && change.insert.lines == 2 && dispatchKey(view.contentDOM, \"Enter\", 13) || change.from == sel.from - 1 && change.to == sel.to && change.insert.length == 0 && dispatchKey(view.contentDOM, \"Backspace\", 8) || change.from == sel.from && change.to == sel.to + 1 && change.insert.length == 0 && dispatchKey(view.contentDOM, \"Delete\", 46))) return;\n let text = change.insert.toString();\n if (view.state.facet(inputHandler).some((h)=>h(view, change.from, change.to, text)\n )) return;\n if (view.inputState.composing >= 0) view.inputState.composing++;\n let tr;\n if (change.from >= sel.from && change.to <= sel.to && change.to - change.from >= (sel.to - sel.from) / 3 && (!newSel || newSel.main.empty && newSel.main.from == change.from + change.insert.length) && view.inputState.composing < 0) {\n let before = sel.from < change.from ? startState.sliceDoc(sel.from, change.from) : \"\";\n let after = sel.to > change.to ? startState.sliceDoc(change.to, sel.to) : \"\";\n tr = startState.replaceSelection(view.state.toText(before + change.insert.sliceString(0, undefined, view.state.lineBreak) + after));\n } else {\n let changes = startState.changes(change);\n let mainSel = newSel && !startState.selection.main.eq(newSel.main) && newSel.main.to <= changes.newLength ? newSel.main : undefined;\n // Try to apply a composition change to all cursors\n if (startState.selection.ranges.length > 1 && view.inputState.composing >= 0 && change.to <= sel.to && change.to >= sel.to - 10) {\n let replaced = view.state.sliceDoc(change.from, change.to);\n let compositionRange = compositionSurroundingNode(view) || view.state.doc.lineAt(sel.head);\n let offset = sel.to - change.to, size = sel.to - sel.from;\n tr = startState.changeByRange((range)=>{\n if (range.from == sel.from && range.to == sel.to) return {\n changes,\n range: mainSel || range.map(changes)\n };\n let to = range.to - offset, from = to - replaced.length;\n if (range.to - range.from != size || view.state.sliceDoc(from, to) != replaced || // Unfortunately, there's no way to make multiple\n // changes in the same node work without aborting\n // composition, so cursors in the composition range are\n // ignored.\n compositionRange && range.to >= compositionRange.from && range.from <= compositionRange.to) return {\n range\n };\n let rangeChanges = startState.changes({\n from,\n to,\n insert: change.insert\n }), selOff = range.to - sel.to;\n return {\n changes: rangeChanges,\n range: !mainSel ? range.map(rangeChanges) : _state.EditorSelection.range(Math.max(0, mainSel.anchor + selOff), Math.max(0, mainSel.head + selOff))\n };\n });\n } else tr = {\n changes,\n selection: mainSel && startState.selection.replaceRange(mainSel)\n };\n }\n let userEvent = \"input.type\";\n if (view.composing) {\n userEvent += \".compose\";\n if (view.inputState.compositionFirstChange) {\n userEvent += \".start\";\n view.inputState.compositionFirstChange = false;\n }\n }\n view.dispatch(tr, {\n scrollIntoView: true,\n userEvent\n });\n } else if (newSel && !newSel.main.eq(sel)) {\n let scrollIntoView1 = false, userEvent = \"select\";\n if (view.inputState.lastSelectionTime > Date.now() - 50) {\n if (view.inputState.lastSelectionOrigin == \"select\") scrollIntoView1 = true;\n userEvent = view.inputState.lastSelectionOrigin;\n }\n view.dispatch({\n selection: newSel,\n scrollIntoView: scrollIntoView1,\n userEvent\n });\n }\n}\nfunction findDiff(a, b, preferredPos, preferredSide) {\n let minLen = Math.min(a.length, b.length);\n let from = 0;\n while(from < minLen && a.charCodeAt(from) == b.charCodeAt(from))from++;\n if (from == minLen && a.length == b.length) return null;\n let toA = a.length, toB = b.length;\n while(toA > 0 && toB > 0 && a.charCodeAt(toA - 1) == b.charCodeAt(toB - 1)){\n toA--;\n toB--;\n }\n if (preferredSide == \"end\") {\n let adjust = Math.max(0, from - Math.min(toA, toB));\n preferredPos -= toA + adjust - from;\n }\n if (toA < from && a.length < b.length) {\n let move = preferredPos <= from && preferredPos >= toA ? from - preferredPos : 0;\n from -= move;\n toB = from + (toB - toA);\n toA = from;\n } else if (toB < from) {\n let move = preferredPos <= from && preferredPos >= toB ? from - preferredPos : 0;\n from -= move;\n toA = from + (toA - toB);\n toB = from;\n }\n return {\n from,\n toA,\n toB\n };\n}\nfunction selectionPoints(view) {\n let result = [];\n if (view.root.activeElement != view.contentDOM) return result;\n let { anchorNode , anchorOffset , focusNode , focusOffset } = view.observer.selectionRange;\n if (anchorNode) {\n result.push(new DOMPoint(anchorNode, anchorOffset));\n if (focusNode != anchorNode || focusOffset != anchorOffset) result.push(new DOMPoint(focusNode, focusOffset));\n }\n return result;\n}\nfunction selectionFromPoints(points, base) {\n if (points.length == 0) return null;\n let anchor = points[0].pos, head = points.length == 2 ? points[1].pos : anchor;\n return anchor > -1 && head > -1 ? _state.EditorSelection.single(anchor + base, head + base) : null;\n}\n// The editor's update state machine looks something like this:\n//\n// Idle \u2192 Updating \u21c6 Idle (unchecked) \u2192 Measuring \u2192 Idle\n// \u2191 \u2193\n// Updating (measure)\n//\n// The difference between 'Idle' and 'Idle (unchecked)' lies in\n// whether a layout check has been scheduled. A regular update through\n// the `update` method updates the DOM in a write-only fashion, and\n// relies on a check (scheduled with `requestAnimationFrame`) to make\n// sure everything is where it should be and the viewport covers the\n// visible code. That check continues to measure and then optionally\n// update until it reaches a coherent state.\n/**\nAn editor view represents the editor's user interface. It holds\nthe editable DOM surface, and possibly other elements such as the\nline number gutter. It handles events and dispatches state\ntransactions for editing actions.\n*/ class EditorView {\n /**\n Construct a new view. You'll usually want to put `view.dom` into\n your document after creating a view, so that the user can see\n it.\n */ constructor(/**\n Initialization options.\n */ config = {\n }){\n this.plugins = [];\n this.pluginMap = new Map;\n this.editorAttrs = {\n };\n this.contentAttrs = {\n };\n this.bidiCache = [];\n this.destroyed = false;\n /**\n @internal\n */ this.updateState = 2 /* Updating */ ;\n /**\n @internal\n */ this.measureScheduled = -1;\n /**\n @internal\n */ this.measureRequests = [];\n this.contentDOM = document.createElement(\"div\");\n this.scrollDOM = document.createElement(\"div\");\n this.scrollDOM.tabIndex = -1;\n this.scrollDOM.className = \"cm-scroller\";\n this.scrollDOM.appendChild(this.contentDOM);\n this.announceDOM = document.createElement(\"div\");\n this.announceDOM.style.cssText = \"position: absolute; top: -10000px\";\n this.announceDOM.setAttribute(\"aria-live\", \"polite\");\n this.dom = document.createElement(\"div\");\n this.dom.appendChild(this.announceDOM);\n this.dom.appendChild(this.scrollDOM);\n this._dispatch = config.dispatch || ((tr)=>this.update([\n tr\n ])\n );\n this.dispatch = this.dispatch.bind(this);\n this.root = config.root || getRoot(config.parent) || document;\n this.viewState = new ViewState(config.state || _state.EditorState.create());\n this.plugins = this.state.facet(viewPlugin).map((spec)=>new PluginInstance(spec)\n );\n for (let plugin1 of this.plugins)plugin1.update(this);\n this.observer = new DOMObserver(this, (from, to, typeOver)=>{\n applyDOMChange(this, from, to, typeOver);\n }, (event)=>{\n this.inputState.runScrollHandlers(this, event);\n if (this.observer.intersecting) this.measure();\n });\n this.inputState = new InputState(this);\n this.docView = new DocView(this);\n this.mountStyles();\n this.updateAttrs();\n this.updateState = 0 /* Idle */ ;\n ensureGlobalHandler();\n this.requestMeasure();\n if (config.parent) config.parent.appendChild(this.dom);\n }\n /**\n The current editor state.\n */ get state() {\n return this.viewState.state;\n }\n /**\n To be able to display large documents without consuming too much\n memory or overloading the browser, CodeMirror only draws the\n code that is visible (plus a margin around it) to the DOM. This\n property tells you the extent of the current drawn viewport, in\n document positions.\n */ get viewport() {\n return this.viewState.viewport;\n }\n /**\n When there are, for example, large collapsed ranges in the\n viewport, its size can be a lot bigger than the actual visible\n content. Thus, if you are doing something like styling the\n content in the viewport, it is preferable to only do so for\n these ranges, which are the subset of the viewport that is\n actually drawn.\n */ get visibleRanges() {\n return this.viewState.visibleRanges;\n }\n /**\n Returns false when the editor is entirely scrolled out of view\n or otherwise hidden.\n */ get inView() {\n return this.viewState.inView;\n }\n /**\n Indicates whether the user is currently composing text via\n [IME](https://en.wikipedia.org/wiki/Input_method).\n */ get composing() {\n return this.inputState.composing > 0;\n }\n dispatch(...input) {\n this._dispatch(input.length == 1 && input[0] instanceof _state.Transaction ? input[0] : this.state.update(...input));\n }\n /**\n Update the view for the given array of transactions. This will\n update the visible document and selection to match the state\n produced by the transactions, and notify view plugins of the\n change. You should usually call\n [`dispatch`](https://codemirror.net/6/docs/ref/#view.EditorView.dispatch) instead, which uses this\n as a primitive.\n */ update(transactions) {\n if (this.updateState != 0 /* Idle */ ) throw new Error(\"Calls to EditorView.update are not allowed while an update is in progress\");\n let redrawn = false, update;\n let state = this.state;\n for (let tr of transactions){\n if (tr.startState != state) throw new RangeError(\"Trying to update state with a transaction that doesn't start from the previous state.\");\n state = tr.state;\n }\n if (this.destroyed) {\n this.viewState.state = state;\n return;\n }\n // When the phrases change, redraw the editor\n if (state.facet(_state.EditorState.phrases) != this.state.facet(_state.EditorState.phrases)) return this.setState(state);\n update = new ViewUpdate(this, state, transactions);\n let scrollTarget = this.viewState.scrollTarget;\n try {\n this.updateState = 2 /* Updating */ ;\n for (let tr1 of transactions){\n if (scrollTarget) scrollTarget = scrollTarget.map(tr1.changes);\n if (tr1.scrollIntoView) {\n let { main } = tr1.state.selection;\n scrollTarget = new ScrollTarget(main.empty ? main : _state.EditorSelection.cursor(main.head, main.head > main.anchor ? -1 : 1));\n }\n for (let e of tr1.effects){\n if (e.is(scrollTo)) scrollTarget = new ScrollTarget(e.value);\n else if (e.is(centerOn)) scrollTarget = new ScrollTarget(e.value, \"center\");\n else if (e.is(scrollIntoView)) scrollTarget = e.value;\n }\n }\n this.viewState.update(update, scrollTarget);\n this.bidiCache = CachedOrder.update(this.bidiCache, update.changes);\n if (!update.empty) {\n this.updatePlugins(update);\n this.inputState.update(update);\n }\n redrawn = this.docView.update(update);\n if (this.state.facet(styleModule) != this.styleModules) this.mountStyles();\n this.updateAttrs();\n this.showAnnouncements(transactions);\n this.docView.updateSelection(redrawn, transactions.some((tr)=>tr.isUserEvent(\"select.pointer\")\n ));\n } finally{\n this.updateState = 0 /* Idle */ ;\n }\n if (redrawn || scrollTarget || this.viewState.mustEnforceCursorAssoc) this.requestMeasure();\n if (!update.empty) for (let listener of this.state.facet(updateListener))listener(update);\n }\n /**\n Reset the view to the given state. (This will cause the entire\n document to be redrawn and all view plugins to be reinitialized,\n so you should probably only use it when the new state isn't\n derived from the old state. Otherwise, use\n [`dispatch`](https://codemirror.net/6/docs/ref/#view.EditorView.dispatch) instead.)\n */ setState(newState) {\n if (this.updateState != 0 /* Idle */ ) throw new Error(\"Calls to EditorView.setState are not allowed while an update is in progress\");\n if (this.destroyed) {\n this.viewState.state = newState;\n return;\n }\n this.updateState = 2 /* Updating */ ;\n let hadFocus = this.hasFocus;\n try {\n for (let plugin3 of this.plugins)plugin3.destroy(this);\n this.viewState = new ViewState(newState);\n this.plugins = newState.facet(viewPlugin).map((spec)=>new PluginInstance(spec)\n );\n this.pluginMap.clear();\n for (let plugin2 of this.plugins)plugin2.update(this);\n this.docView = new DocView(this);\n this.inputState.ensureHandlers(this);\n this.mountStyles();\n this.updateAttrs();\n this.bidiCache = [];\n } finally{\n this.updateState = 0 /* Idle */ ;\n }\n if (hadFocus) this.focus();\n this.requestMeasure();\n }\n updatePlugins(update) {\n let prevSpecs = update.startState.facet(viewPlugin), specs = update.state.facet(viewPlugin);\n if (prevSpecs != specs) {\n let newPlugins = [];\n for (let spec of specs){\n let found = prevSpecs.indexOf(spec);\n if (found < 0) newPlugins.push(new PluginInstance(spec));\n else {\n let plugin4 = this.plugins[found];\n plugin4.mustUpdate = update;\n newPlugins.push(plugin4);\n }\n }\n for (let plugin5 of this.plugins)if (plugin5.mustUpdate != update) plugin5.destroy(this);\n this.plugins = newPlugins;\n this.pluginMap.clear();\n this.inputState.ensureHandlers(this);\n } else for (let p3 of this.plugins)p3.mustUpdate = update;\n for(let i = 0; i < this.plugins.length; i++)this.plugins[i].update(this);\n }\n /**\n @internal\n */ measure(flush = true) {\n if (this.destroyed) return;\n if (this.measureScheduled > -1) cancelAnimationFrame(this.measureScheduled);\n this.measureScheduled = 0; // Prevent requestMeasure calls from scheduling another animation frame\n if (flush) this.observer.flush();\n let updated = null;\n try {\n for(let i = 0;; i++){\n this.updateState = 1 /* Measuring */ ;\n let oldViewport = this.viewport;\n let changed = this.viewState.measure(this);\n if (!changed && !this.measureRequests.length && this.viewState.scrollTarget == null) break;\n if (i > 5) {\n console.warn(this.measureRequests.length ? \"Measure loop restarted more than 5 times\" : \"Viewport failed to stabilize\");\n break;\n }\n let measuring = [];\n // Only run measure requests in this cycle when the viewport didn't change\n if (!(changed & 4 /* Viewport */ )) [this.measureRequests, measuring] = [\n measuring,\n this.measureRequests\n ];\n let measured = measuring.map((m)=>{\n try {\n return m.read(this);\n } catch (e) {\n logException(this.state, e);\n return BadMeasure;\n }\n });\n let update = new ViewUpdate(this, this.state), redrawn = false, scrolled = false;\n update.flags |= changed;\n if (!updated) updated = update;\n else updated.flags |= changed;\n this.updateState = 2 /* Updating */ ;\n if (!update.empty) {\n this.updatePlugins(update);\n this.inputState.update(update);\n this.updateAttrs();\n redrawn = this.docView.update(update);\n }\n for(let i7 = 0; i7 < measuring.length; i7++)if (measured[i7] != BadMeasure) try {\n let m = measuring[i7];\n if (m.write) m.write(measured[i7], this);\n } catch (e) {\n logException(this.state, e);\n }\n if (this.viewState.scrollTarget) {\n this.docView.scrollIntoView(this.viewState.scrollTarget);\n this.viewState.scrollTarget = null;\n scrolled = true;\n }\n if (redrawn) this.docView.updateSelection(true);\n if (this.viewport.from == oldViewport.from && this.viewport.to == oldViewport.to && !scrolled && this.measureRequests.length == 0) break;\n }\n } finally{\n this.updateState = 0 /* Idle */ ;\n this.measureScheduled = -1;\n }\n if (updated && !updated.empty) for (let listener of this.state.facet(updateListener))listener(updated);\n }\n /**\n Get the CSS classes for the currently active editor themes.\n */ get themeClasses() {\n return baseThemeID + \" \" + (this.state.facet(darkTheme) ? baseDarkID : baseLightID) + \" \" + this.state.facet(theme);\n }\n updateAttrs() {\n let editorAttrs = attrsFromFacet(this, editorAttributes, {\n class: \"cm-editor\" + (this.hasFocus ? \" cm-focused \" : \" \") + this.themeClasses\n });\n let contentAttrs = {\n spellcheck: \"false\",\n autocorrect: \"off\",\n autocapitalize: \"off\",\n translate: \"no\",\n contenteditable: !this.state.facet(editable) ? \"false\" : \"true\",\n class: \"cm-content\",\n style: `${browser.tabSize}: ${this.state.tabSize}`,\n role: \"textbox\",\n \"aria-multiline\": \"true\"\n };\n if (this.state.readOnly) contentAttrs[\"aria-readonly\"] = \"true\";\n attrsFromFacet(this, contentAttributes, contentAttrs);\n this.observer.ignore(()=>{\n updateAttrs(this.contentDOM, this.contentAttrs, contentAttrs);\n updateAttrs(this.dom, this.editorAttrs, editorAttrs);\n });\n this.editorAttrs = editorAttrs;\n this.contentAttrs = contentAttrs;\n }\n showAnnouncements(trs) {\n let first = true;\n for (let tr of trs)for (let effect of tr.effects)if (effect.is(EditorView.announce)) {\n if (first) this.announceDOM.textContent = \"\";\n first = false;\n let div = this.announceDOM.appendChild(document.createElement(\"div\"));\n div.textContent = effect.value;\n }\n }\n mountStyles() {\n this.styleModules = this.state.facet(styleModule);\n _styleMod.StyleModule.mount(this.root, this.styleModules.concat(baseTheme).reverse());\n }\n readMeasured() {\n if (this.updateState == 2 /* Updating */ ) throw new Error(\"Reading the editor layout isn't allowed during an update\");\n if (this.updateState == 0 /* Idle */ && this.measureScheduled > -1) this.measure(false);\n }\n /**\n Schedule a layout measurement, optionally providing callbacks to\n do custom DOM measuring followed by a DOM write phase. Using\n this is preferable reading DOM layout directly from, for\n example, an event handler, because it'll make sure measuring and\n drawing done by other components is synchronized, avoiding\n unnecessary DOM layout computations.\n */ requestMeasure(request) {\n if (this.measureScheduled < 0) this.measureScheduled = requestAnimationFrame(()=>this.measure()\n );\n if (request) {\n if (request.key != null) {\n for(let i = 0; i < this.measureRequests.length; i++)if (this.measureRequests[i].key === request.key) {\n this.measureRequests[i] = request;\n return;\n }\n }\n this.measureRequests.push(request);\n }\n }\n /**\n Collect all values provided by the active plugins for a given\n field.\n */ pluginField(field) {\n let result = [];\n for (let plugin6 of this.plugins)plugin6.update(this).takeField(field, result);\n return result;\n }\n /**\n Get the value of a specific plugin, if present. Note that\n plugins that crash can be dropped from a view, so even when you\n know you registered a given plugin, it is recommended to check\n the return value of this method.\n */ plugin(plugin7) {\n let known = this.pluginMap.get(plugin7);\n if (known === undefined || known && known.spec != plugin7) this.pluginMap.set(plugin7, known = this.plugins.find((p4)=>p4.spec == plugin7\n ) || null);\n return known && known.update(this).value;\n }\n /**\n The top position of the document, in screen coordinates. This\n may be negative when the editor is scrolled down. Points\n directly to the top of the first line, not above the padding.\n */ get documentTop() {\n return this.contentDOM.getBoundingClientRect().top + this.viewState.paddingTop;\n }\n /**\n Reports the padding above and below the document.\n */ get documentPadding() {\n return {\n top: this.viewState.paddingTop,\n bottom: this.viewState.paddingBottom\n };\n }\n /**\n Find the line or block widget at the given vertical position.\n \n By default, this position is interpreted as a screen position,\n meaning `docTop` is set to the DOM top position of the editor\n content (forcing a layout). You can pass a different `docTop`\n value\u2014for example 0 to interpret `height` as a document-relative\n position, or a precomputed document top\n (`view.contentDOM.getBoundingClientRect().top`) to limit layout\n queries.\n \n *Deprecated: use `elementAtHeight` instead.*\n */ blockAtHeight(height, docTop) {\n let top = ensureTop(docTop, this);\n return this.elementAtHeight(height - top).moveY(top);\n }\n /**\n Find the text line or block widget at the given vertical\n position (which is interpreted as relative to the [top of the\n document](https://codemirror.net/6/docs/ref/#view.EditorView.documentTop)\n */ elementAtHeight(height) {\n this.readMeasured();\n return this.viewState.elementAtHeight(height);\n }\n /**\n Find information for the visual line (see\n [`visualLineAt`](https://codemirror.net/6/docs/ref/#view.EditorView.visualLineAt)) at the given\n vertical position. The resulting block info might hold another\n array of block info structs in its `type` field if this line\n consists of more than one block.\n \n Defaults to treating `height` as a screen position. See\n [`blockAtHeight`](https://codemirror.net/6/docs/ref/#view.EditorView.blockAtHeight) for the\n interpretation of the `docTop` parameter.\n \n *Deprecated: use `lineBlockAtHeight` instead.*\n */ visualLineAtHeight(height, docTop) {\n let top = ensureTop(docTop, this);\n return this.lineBlockAtHeight(height - top).moveY(top);\n }\n /**\n Find the line block (see\n [`lineBlockAt`](https://codemirror.net/6/docs/ref/#view.EditorView.lineBlockAt) at the given\n height.\n */ lineBlockAtHeight(height) {\n this.readMeasured();\n return this.viewState.lineBlockAtHeight(height);\n }\n /**\n Iterate over the height information of the visual lines in the\n viewport. The heights of lines are reported relative to the\n given document top, which defaults to the screen position of the\n document (forcing a layout).\n \n *Deprecated: use `viewportLineBlocks` instead.*\n */ viewportLines(f, docTop) {\n let top = ensureTop(docTop, this);\n for (let line of this.viewportLineBlocks)f(line.moveY(top));\n }\n /**\n Get the extent and vertical position of all [line\n blocks](https://codemirror.net/6/docs/ref/#view.EditorView.lineBlockAt) in the viewport. Positions\n are relative to the [top of the\n document](https://codemirror.net/6/docs/ref/#view.EditorView.documentTop);\n */ get viewportLineBlocks() {\n return this.viewState.viewportLines;\n }\n /**\n Find the extent and height of the visual line (a range delimited\n on both sides by either non-[hidden](https://codemirror.net/6/docs/ref/#view.Decoration^range)\n line breaks, or the start/end of the document) at the given position.\n \n Vertical positions are computed relative to the `docTop`\n argument, which defaults to 0 for this method. You can pass\n `view.contentDOM.getBoundingClientRect().top` here to get screen\n coordinates.\n \n *Deprecated: use `lineBlockAt` instead.*\n */ visualLineAt(pos, docTop = 0) {\n return this.lineBlockAt(pos).moveY(docTop + this.viewState.paddingTop);\n }\n /**\n Find the line block around the given document position. A line\n block is a range delimited on both sides by either a\n non-[hidden](https://codemirror.net/6/docs/ref/#view.Decoration^range) line breaks, or the\n start/end of the document. It will usually just hold a line of\n text, but may be broken into multiple textblocks by block\n widgets.\n */ lineBlockAt(pos) {\n return this.viewState.lineBlockAt(pos);\n }\n /**\n The editor's total content height.\n */ get contentHeight() {\n return this.viewState.contentHeight;\n }\n /**\n Move a cursor position by [grapheme\n cluster](https://codemirror.net/6/docs/ref/#text.findClusterBreak). `forward` determines whether\n the motion is away from the line start, or towards it. Motion in\n bidirectional text is in visual order, in the editor's [text\n direction](https://codemirror.net/6/docs/ref/#view.EditorView.textDirection). When the start\n position was the last one on the line, the returned position\n will be across the line break. If there is no further line, the\n original position is returned.\n \n By default, this method moves over a single cluster. The\n optional `by` argument can be used to move across more. It will\n be called with the first cluster as argument, and should return\n a predicate that determines, for each subsequent cluster,\n whether it should also be moved over.\n */ moveByChar(start, forward, by) {\n return skipAtoms(this, start, moveByChar(this, start, forward, by));\n }\n /**\n Move a cursor position across the next group of either\n [letters](https://codemirror.net/6/docs/ref/#state.EditorState.charCategorizer) or non-letter\n non-whitespace characters.\n */ moveByGroup(start, forward) {\n return skipAtoms(this, start, moveByChar(this, start, forward, (initial)=>byGroup(this, start.head, initial)\n ));\n }\n /**\n Move to the next line boundary in the given direction. If\n `includeWrap` is true, line wrapping is on, and there is a\n further wrap point on the current line, the wrap point will be\n returned. Otherwise this function will return the start or end\n of the line.\n */ moveToLineBoundary(start, forward, includeWrap = true) {\n return moveToLineBoundary(this, start, forward, includeWrap);\n }\n /**\n Move a cursor position vertically. When `distance` isn't given,\n it defaults to moving to the next line (including wrapped\n lines). Otherwise, `distance` should provide a positive distance\n in pixels.\n \n When `start` has a\n [`goalColumn`](https://codemirror.net/6/docs/ref/#state.SelectionRange.goalColumn), the vertical\n motion will use that as a target horizontal position. Otherwise,\n the cursor's own horizontal position is used. The returned\n cursor will have its goal column set to whichever column was\n used.\n */ moveVertically(start, forward, distance) {\n return skipAtoms(this, start, moveVertically(this, start, forward, distance));\n }\n // FIXME remove on next major version\n scrollPosIntoView(pos) {\n this.dispatch({\n effects: scrollTo.of(_state.EditorSelection.cursor(pos))\n });\n }\n /**\n Find the DOM parent node and offset (child offset if `node` is\n an element, character offset when it is a text node) at the\n given document position.\n \n Note that for positions that aren't currently in\n `visibleRanges`, the resulting DOM position isn't necessarily\n meaningful (it may just point before or after a placeholder\n element).\n */ domAtPos(pos) {\n return this.docView.domAtPos(pos);\n }\n /**\n Find the document position at the given DOM node. Can be useful\n for associating positions with DOM events. Will raise an error\n when `node` isn't part of the editor content.\n */ posAtDOM(node, offset = 0) {\n return this.docView.posFromDOM(node, offset);\n }\n posAtCoords(coords, precise = true) {\n this.readMeasured();\n return posAtCoords(this, coords, precise);\n }\n /**\n Get the screen coordinates at the given document position.\n `side` determines whether the coordinates are based on the\n element before (-1) or after (1) the position (if no element is\n available on the given side, the method will transparently use\n another strategy to get reasonable coordinates).\n */ coordsAtPos(pos, side = 1) {\n this.readMeasured();\n let rect = this.docView.coordsAt(pos, side);\n if (!rect || rect.left == rect.right) return rect;\n let line = this.state.doc.lineAt(pos), order = this.bidiSpans(line);\n let span = order[BidiSpan.find(order, pos - line.from, -1, side)];\n return flattenRect(rect, span.dir == Direction.LTR == side > 0);\n }\n /**\n The default width of a character in the editor. May not\n accurately reflect the width of all characters (given variable\n width fonts or styling of invididual ranges).\n */ get defaultCharacterWidth() {\n return this.viewState.heightOracle.charWidth;\n }\n /**\n The default height of a line in the editor. May not be accurate\n for all lines.\n */ get defaultLineHeight() {\n return this.viewState.heightOracle.lineHeight;\n }\n /**\n The text direction\n ([`direction`](https://developer.mozilla.org/en-US/docs/Web/CSS/direction)\n CSS property) of the editor.\n */ get textDirection() {\n return this.viewState.heightOracle.direction;\n }\n /**\n Whether this editor [wraps lines](https://codemirror.net/6/docs/ref/#view.EditorView.lineWrapping)\n (as determined by the\n [`white-space`](https://developer.mozilla.org/en-US/docs/Web/CSS/white-space)\n CSS property of its content element).\n */ get lineWrapping() {\n return this.viewState.heightOracle.lineWrapping;\n }\n /**\n Returns the bidirectional text structure of the given line\n (which should be in the current document) as an array of span\n objects. The order of these spans matches the [text\n direction](https://codemirror.net/6/docs/ref/#view.EditorView.textDirection)\u2014if that is\n left-to-right, the leftmost spans come first, otherwise the\n rightmost spans come first.\n */ bidiSpans(line) {\n if (line.length > MaxBidiLine) return trivialOrder(line.length);\n let dir = this.textDirection;\n for (let entry of this.bidiCache)if (entry.from == line.from && entry.dir == dir) return entry.order;\n let order = computeOrder(line.text, this.textDirection);\n this.bidiCache.push(new CachedOrder(line.from, line.to, dir, order));\n return order;\n }\n /**\n Check whether the editor has focus.\n */ get hasFocus() {\n var _a;\n // Safari return false for hasFocus when the context menu is open\n // or closing, which leads us to ignore selection changes from the\n // context menu because it looks like the editor isn't focused.\n // This kludges around that.\n return (document.hasFocus() || browser.safari && ((_a = this.inputState) === null || _a === void 0 ? void 0 : _a.lastContextMenu) > Date.now() - 30000) && this.root.activeElement == this.contentDOM;\n }\n /**\n Put focus on the editor.\n */ focus() {\n this.observer.ignore(()=>{\n focusPreventScroll(this.contentDOM);\n this.docView.updateSelection();\n });\n }\n /**\n Clean up this editor view, removing its element from the\n document, unregistering event handlers, and notifying\n plugins. The view instance can no longer be used after\n calling this.\n */ destroy() {\n for (let plugin8 of this.plugins)plugin8.destroy(this);\n this.plugins = [];\n this.inputState.destroy();\n this.dom.remove();\n this.observer.destroy();\n if (this.measureScheduled > -1) cancelAnimationFrame(this.measureScheduled);\n this.destroyed = true;\n }\n /**\n Returns an effect that can be\n [added](https://codemirror.net/6/docs/ref/#state.TransactionSpec.effects) to a transaction to\n cause it to scroll the given position or range into view.\n */ static scrollIntoView(pos, options = {\n }) {\n return scrollIntoView.of(new ScrollTarget(typeof pos == \"number\" ? _state.EditorSelection.cursor(pos) : pos, options.y, options.x, options.yMargin, options.xMargin));\n }\n /**\n Facet that can be used to add DOM event handlers. The value\n should be an object mapping event names to handler functions. The\n first such function to return true will be assumed to have handled\n that event, and no other handlers or built-in behavior will be\n activated for it.\n These are registered on the [content\n element](https://codemirror.net/6/docs/ref/#view.EditorView.contentDOM), except for `scroll`\n handlers, which will be called any time the editor's [scroll\n element](https://codemirror.net/6/docs/ref/#view.EditorView.scrollDOM) or one of its parent nodes\n is scrolled.\n */ static domEventHandlers(handlers2) {\n return ViewPlugin.define(()=>({\n })\n , {\n eventHandlers: handlers2\n });\n }\n /**\n Create a theme extension. The first argument can be a\n [`style-mod`](https://github.com/marijnh/style-mod#documentation)\n style spec providing the styles for the theme. These will be\n prefixed with a generated class for the style.\n \n Because the selectors will be prefixed with a scope class, rule\n that directly match the editor's [wrapper\n element](https://codemirror.net/6/docs/ref/#view.EditorView.dom)\u2014to which the scope class will be\n added\u2014need to be explicitly differentiated by adding an `&` to\n the selector for that element\u2014for example\n `&.cm-focused`.\n \n When `dark` is set to true, the theme will be marked as dark,\n which will cause the `&dark` rules from [base\n themes](https://codemirror.net/6/docs/ref/#view.EditorView^baseTheme) to be used (as opposed to\n `&light` when a light theme is active).\n */ static theme(spec, options) {\n let prefix = _styleMod.StyleModule.newName();\n let result = [\n theme.of(prefix),\n styleModule.of(buildTheme(`.${prefix}`, spec))\n ];\n if (options && options.dark) result.push(darkTheme.of(true));\n return result;\n }\n /**\n Create an extension that adds styles to the base theme. Like\n with [`theme`](https://codemirror.net/6/docs/ref/#view.EditorView^theme), use `&` to indicate the\n place of the editor wrapper element when directly targeting\n that. You can also use `&dark` or `&light` instead to only\n target editors with a dark or light theme.\n */ static baseTheme(spec) {\n return _state.Prec.lowest(styleModule.of(buildTheme(\".\" + baseThemeID, spec, lightDarkIDs)));\n }\n}\n/**\nEffect that can be [added](https://codemirror.net/6/docs/ref/#state.TransactionSpec.effects) to a\ntransaction to make it scroll the given range into view.\n\n*Deprecated*. Use [`scrollIntoView`](https://codemirror.net/6/docs/ref/#view.EditorView^scrollIntoView) instead.\n*/ EditorView.scrollTo = scrollTo;\n/**\nEffect that makes the editor scroll the given range to the\ncenter of the visible view.\n\n*Deprecated*. Use [`scrollIntoView`](https://codemirror.net/6/docs/ref/#view.EditorView^scrollIntoView) instead.\n*/ EditorView.centerOn = centerOn;\n/**\nFacet to add a [style\nmodule](https://github.com/marijnh/style-mod#documentation) to\nan editor view. The view will ensure that the module is\nmounted in its [document\nroot](https://codemirror.net/6/docs/ref/#view.EditorView.constructor^config.root).\n*/ EditorView.styleModule = styleModule;\n/**\nAn input handler can override the way changes to the editable\nDOM content are handled. Handlers are passed the document\npositions between which the change was found, and the new\ncontent. When one returns true, no further input handlers are\ncalled and the default behavior is prevented.\n*/ EditorView.inputHandler = inputHandler;\n/**\nAllows you to provide a function that should be called when the\nlibrary catches an exception from an extension (mostly from view\nplugins, but may be used by other extensions to route exceptions\nfrom user-code-provided callbacks). This is mostly useful for\ndebugging and logging. See [`logException`](https://codemirror.net/6/docs/ref/#view.logException).\n*/ EditorView.exceptionSink = exceptionSink;\n/**\nA facet that can be used to register a function to be called\nevery time the view updates.\n*/ EditorView.updateListener = updateListener;\n/**\nFacet that controls whether the editor content DOM is editable.\nWhen its highest-precedence value is `false`, the element will\nnot longer have its `contenteditable` attribute set. (Note that\nthis doesn't affect API calls that change the editor content,\neven when those are bound to keys or buttons. See the\n[`readOnly`](https://codemirror.net/6/docs/ref/#state.EditorState.readOnly) facet for that.)\n*/ EditorView.editable = editable;\n/**\nAllows you to influence the way mouse selection happens. The\nfunctions in this facet will be called for a `mousedown` event\non the editor, and can return an object that overrides the way a\nselection is computed from that mouse click or drag.\n*/ EditorView.mouseSelectionStyle = mouseSelectionStyle;\n/**\nFacet used to configure whether a given selection drag event\nshould move or copy the selection. The given predicate will be\ncalled with the `mousedown` event, and can return `true` when\nthe drag should move the content.\n*/ EditorView.dragMovesSelection = dragMovesSelection$1;\n/**\nFacet used to configure whether a given selecting click adds\na new range to the existing selection or replaces it entirely.\n*/ EditorView.clickAddsSelectionRange = clickAddsSelectionRange;\n/**\nA facet that determines which [decorations](https://codemirror.net/6/docs/ref/#view.Decoration)\nare shown in the view. See also [view\nplugins](https://codemirror.net/6/docs/ref/#view.EditorView^decorations), which have a separate\nmechanism for providing decorations.\n*/ EditorView.decorations = decorations;\n/**\nThis facet records whether a dark theme is active. The extension\nreturned by [`theme`](https://codemirror.net/6/docs/ref/#view.EditorView^theme) automatically\nincludes an instance of this when the `dark` option is set to\ntrue.\n*/ EditorView.darkTheme = darkTheme;\n/**\nFacet that provides additional DOM attributes for the editor's\neditable DOM element.\n*/ EditorView.contentAttributes = contentAttributes;\n/**\nFacet that provides DOM attributes for the editor's outer\nelement.\n*/ EditorView.editorAttributes = editorAttributes;\n/**\nAn extension that enables line wrapping in the editor (by\nsetting CSS `white-space` to `pre-wrap` in the content).\n*/ EditorView.lineWrapping = /*@__PURE__*/ EditorView.contentAttributes.of({\n \"class\": \"cm-lineWrapping\"\n});\n/**\nState effect used to include screen reader announcements in a\ntransaction. These will be added to the DOM in a visually hidden\nelement with `aria-live=\"polite\"` set, and should be used to\ndescribe effects that are visually obvious but may not be\nnoticed by screen reader users (such as moving to the next\nsearch match).\n*/ EditorView.announce = /*@__PURE__*/ _state.StateEffect.define();\n// Maximum line length for which we compute accurate bidi info\nconst MaxBidiLine = 4096;\n// FIXME remove this and its callers on next breaking release\nfunction ensureTop(given, view) {\n return (given == null ? view.contentDOM.getBoundingClientRect().top : given) + view.viewState.paddingTop;\n}\nlet resizeDebounce = -1;\nfunction ensureGlobalHandler() {\n window.addEventListener(\"resize\", ()=>{\n if (resizeDebounce == -1) resizeDebounce = setTimeout(handleResize, 50);\n });\n}\nfunction handleResize() {\n resizeDebounce = -1;\n let found = document.querySelectorAll(\".cm-content\");\n for(let i = 0; i < found.length; i++){\n let docView = ContentView.get(found[i]);\n if (docView) docView.editorView.requestMeasure();\n }\n}\nconst BadMeasure = {\n};\nclass CachedOrder {\n constructor(from, to, dir, order){\n this.from = from;\n this.to = to;\n this.dir = dir;\n this.order = order;\n }\n static update(cache, changes) {\n if (changes.empty) return cache;\n let result = [], lastDir = cache.length ? cache[cache.length - 1].dir : Direction.LTR;\n for(let i = Math.max(0, cache.length - 10); i < cache.length; i++){\n let entry = cache[i];\n if (entry.dir == lastDir && !changes.touchesRange(entry.from, entry.to)) result.push(new CachedOrder(changes.mapPos(entry.from, 1), changes.mapPos(entry.to, -1), entry.dir, entry.order));\n }\n return result;\n }\n}\nfunction attrsFromFacet(view, facet, base) {\n for(let sources = view.state.facet(facet), i = sources.length - 1; i >= 0; i--){\n let source = sources[i], value = typeof source == \"function\" ? source(view) : source;\n if (value) combineAttrs(value, base);\n }\n return base;\n}\nconst currentPlatform = browser.mac ? \"mac\" : browser.windows ? \"win\" : browser.linux ? \"linux\" : \"key\";\nfunction normalizeKeyName(name, platform) {\n const parts = name.split(/-(?!$)/);\n let result = parts[parts.length - 1];\n if (result == \"Space\") result = \" \";\n let alt, ctrl, shift, meta;\n for(let i = 0; i < parts.length - 1; ++i){\n const mod = parts[i];\n if (/^(cmd|meta|m)$/i.test(mod)) meta = true;\n else if (/^a(lt)?$/i.test(mod)) alt = true;\n else if (/^(c|ctrl|control)$/i.test(mod)) ctrl = true;\n else if (/^s(hift)?$/i.test(mod)) shift = true;\n else if (/^mod$/i.test(mod)) {\n if (platform == \"mac\") meta = true;\n else ctrl = true;\n } else throw new Error(\"Unrecognized modifier name: \" + mod);\n }\n if (alt) result = \"Alt-\" + result;\n if (ctrl) result = \"Ctrl-\" + result;\n if (meta) result = \"Meta-\" + result;\n if (shift) result = \"Shift-\" + result;\n return result;\n}\nfunction modifiers(name, event, shift) {\n if (event.altKey) name = \"Alt-\" + name;\n if (event.ctrlKey) name = \"Ctrl-\" + name;\n if (event.metaKey) name = \"Meta-\" + name;\n if (shift !== false && event.shiftKey) name = \"Shift-\" + name;\n return name;\n}\nconst handleKeyEvents = /*@__PURE__*/ EditorView.domEventHandlers({\n keydown (event, view) {\n return runHandlers(getKeymap(view.state), event, view, \"editor\");\n }\n});\n/**\nFacet used for registering keymaps.\n\nYou can add multiple keymaps to an editor. Their priorities\ndetermine their precedence (the ones specified early or with high\npriority get checked first). When a handler has returned `true`\nfor a given key, no further handlers are called.\n*/ const keymap = /*@__PURE__*/ _state.Facet.define({\n enables: handleKeyEvents\n});\nconst Keymaps = /*@__PURE__*/ new WeakMap();\n// This is hidden behind an indirection, rather than directly computed\n// by the facet, to keep internal types out of the facet's type.\nfunction getKeymap(state) {\n let bindings = state.facet(keymap);\n let map = Keymaps.get(bindings);\n if (!map) Keymaps.set(bindings, map = buildKeymap(bindings.reduce((a, b)=>a.concat(b)\n , [])));\n return map;\n}\n/**\nRun the key handlers registered for a given scope. The event\nobject should be `\"keydown\"` event. Returns true if any of the\nhandlers handled it.\n*/ function runScopeHandlers(view, event, scope) {\n return runHandlers(getKeymap(view.state), event, view, scope);\n}\nlet storedPrefix = null;\nconst PrefixTimeout = 4000;\nfunction buildKeymap(bindings, platform = currentPlatform) {\n let bound = Object.create(null);\n let isPrefix = Object.create(null);\n let checkPrefix = (name, is)=>{\n let current = isPrefix[name];\n if (current == null) isPrefix[name] = is;\n else if (current != is) throw new Error(\"Key binding \" + name + \" is used both as a regular binding and as a multi-stroke prefix\");\n };\n let add = (scope, key, command, preventDefault)=>{\n let scopeObj = bound[scope] || (bound[scope] = Object.create(null));\n let parts = key.split(/ (?!$)/).map((k)=>normalizeKeyName(k, platform)\n );\n for(let i = 1; i < parts.length; i++){\n let prefix = parts.slice(0, i).join(\" \");\n checkPrefix(prefix, true);\n if (!scopeObj[prefix]) scopeObj[prefix] = {\n preventDefault: true,\n commands: [\n (view)=>{\n let ourObj = storedPrefix = {\n view,\n prefix,\n scope\n };\n setTimeout(()=>{\n if (storedPrefix == ourObj) storedPrefix = null;\n }, PrefixTimeout);\n return true;\n }\n ]\n };\n }\n let full = parts.join(\" \");\n checkPrefix(full, false);\n let binding = scopeObj[full] || (scopeObj[full] = {\n preventDefault: false,\n commands: []\n });\n binding.commands.push(command);\n if (preventDefault) binding.preventDefault = true;\n };\n for (let b of bindings){\n let name = b[platform] || b.key;\n if (!name) continue;\n for (let scope of b.scope ? b.scope.split(\" \") : [\n \"editor\"\n ]){\n add(scope, name, b.run, b.preventDefault);\n if (b.shift) add(scope, \"Shift-\" + name, b.shift, b.preventDefault);\n }\n }\n return bound;\n}\nfunction runHandlers(map, event, view, scope) {\n let name = _w3CKeyname.keyName(event), isChar = name.length == 1 && name != \" \";\n let prefix = \"\", fallthrough = false;\n if (storedPrefix && storedPrefix.view == view && storedPrefix.scope == scope) {\n prefix = storedPrefix.prefix + \" \";\n if (fallthrough = modifierCodes.indexOf(event.keyCode) < 0) storedPrefix = null;\n }\n let runFor = (binding)=>{\n if (binding) {\n for (let cmd of binding.commands)if (cmd(view)) return true;\n if (binding.preventDefault) fallthrough = true;\n }\n return false;\n };\n let scopeObj = map[scope], baseName;\n if (scopeObj) {\n if (runFor(scopeObj[prefix + modifiers(name, event, !isChar)])) return true;\n if (isChar && (event.shiftKey || event.altKey || event.metaKey) && (baseName = _w3CKeyname.base[event.keyCode]) && baseName != name) {\n if (runFor(scopeObj[prefix + modifiers(baseName, event, true)])) return true;\n } else if (isChar && event.shiftKey) {\n if (runFor(scopeObj[prefix + modifiers(name, event, true)])) return true;\n }\n }\n return fallthrough;\n}\nconst CanHidePrimary = !browser.ios; // FIXME test IE\nconst selectionConfig = /*@__PURE__*/ _state.Facet.define({\n combine (configs) {\n return _state.combineConfig(configs, {\n cursorBlinkRate: 1200,\n drawRangeCursor: true\n }, {\n cursorBlinkRate: (a, b)=>Math.min(a, b)\n ,\n drawRangeCursor: (a, b)=>a || b\n });\n }\n});\n/**\nReturns an extension that hides the browser's native selection and\ncursor, replacing the selection with a background behind the text\n(with the `cm-selectionBackground` class), and the\ncursors with elements overlaid over the code (using\n`cm-cursor-primary` and `cm-cursor-secondary`).\n\nThis allows the editor to display secondary selection ranges, and\ntends to produce a type of selection more in line with that users\nexpect in a text editor (the native selection styling will often\nleave gaps between lines and won't fill the horizontal space after\na line when the selection continues past it).\n\nIt does have a performance cost, in that it requires an extra DOM\nlayout cycle for many updates (the selection is drawn based on DOM\nlayout information that's only available after laying out the\ncontent).\n*/ function drawSelection(config = {\n}) {\n return [\n selectionConfig.of(config),\n drawSelectionPlugin,\n hideNativeSelection\n ];\n}\nclass Piece {\n constructor(left, top, width, height, className){\n this.left = left;\n this.top = top;\n this.width = width;\n this.height = height;\n this.className = className;\n }\n draw() {\n let elt = document.createElement(\"div\");\n elt.className = this.className;\n this.adjust(elt);\n return elt;\n }\n adjust(elt) {\n elt.style.left = this.left + \"px\";\n elt.style.top = this.top + \"px\";\n if (this.width >= 0) elt.style.width = this.width + \"px\";\n elt.style.height = this.height + \"px\";\n }\n eq(p5) {\n return this.left == p5.left && this.top == p5.top && this.width == p5.width && this.height == p5.height && this.className == p5.className;\n }\n}\nconst drawSelectionPlugin = /*@__PURE__*/ ViewPlugin.fromClass(class {\n constructor(view){\n this.view = view;\n this.rangePieces = [];\n this.cursors = [];\n this.measureReq = {\n read: this.readPos.bind(this),\n write: this.drawSel.bind(this)\n };\n this.selectionLayer = view.scrollDOM.appendChild(document.createElement(\"div\"));\n this.selectionLayer.className = \"cm-selectionLayer\";\n this.selectionLayer.setAttribute(\"aria-hidden\", \"true\");\n this.cursorLayer = view.scrollDOM.appendChild(document.createElement(\"div\"));\n this.cursorLayer.className = \"cm-cursorLayer\";\n this.cursorLayer.setAttribute(\"aria-hidden\", \"true\");\n view.requestMeasure(this.measureReq);\n this.setBlinkRate();\n }\n setBlinkRate() {\n this.cursorLayer.style.animationDuration = this.view.state.facet(selectionConfig).cursorBlinkRate + \"ms\";\n }\n update(update) {\n let confChanged = update.startState.facet(selectionConfig) != update.state.facet(selectionConfig);\n if (confChanged || update.selectionSet || update.geometryChanged || update.viewportChanged) this.view.requestMeasure(this.measureReq);\n if (update.transactions.some((tr)=>tr.scrollIntoView\n )) this.cursorLayer.style.animationName = this.cursorLayer.style.animationName == \"cm-blink\" ? \"cm-blink2\" : \"cm-blink\";\n if (confChanged) this.setBlinkRate();\n }\n readPos() {\n let { state } = this.view, conf = state.facet(selectionConfig);\n let rangePieces = state.selection.ranges.map((r)=>r.empty ? [] : measureRange(this.view, r)\n ).reduce((a, b)=>a.concat(b)\n );\n let cursors = [];\n for (let r1 of state.selection.ranges){\n let prim = r1 == state.selection.main;\n if (r1.empty ? !prim || CanHidePrimary : conf.drawRangeCursor) {\n let piece = measureCursor(this.view, r1, prim);\n if (piece) cursors.push(piece);\n }\n }\n return {\n rangePieces,\n cursors\n };\n }\n drawSel({ rangePieces , cursors }) {\n if (rangePieces.length != this.rangePieces.length || rangePieces.some((p6, i)=>!p6.eq(this.rangePieces[i])\n )) {\n this.selectionLayer.textContent = \"\";\n for (let p7 of rangePieces)this.selectionLayer.appendChild(p7.draw());\n this.rangePieces = rangePieces;\n }\n if (cursors.length != this.cursors.length || cursors.some((c, i)=>!c.eq(this.cursors[i])\n )) {\n let oldCursors = this.cursorLayer.children;\n if (oldCursors.length !== cursors.length) {\n this.cursorLayer.textContent = \"\";\n for (const c of cursors)this.cursorLayer.appendChild(c.draw());\n } else cursors.forEach((c, idx)=>c.adjust(oldCursors[idx])\n );\n this.cursors = cursors;\n }\n }\n destroy() {\n this.selectionLayer.remove();\n this.cursorLayer.remove();\n }\n});\nconst themeSpec = {\n \".cm-line\": {\n \"& ::selection\": {\n backgroundColor: \"transparent !important\"\n },\n \"&::selection\": {\n backgroundColor: \"transparent !important\"\n }\n }\n};\nif (CanHidePrimary) themeSpec[\".cm-line\"].caretColor = \"transparent !important\";\nconst hideNativeSelection = /*@__PURE__*/ _state.Prec.highest(/*@__PURE__*/ EditorView.theme(themeSpec));\nfunction getBase(view) {\n let rect = view.scrollDOM.getBoundingClientRect();\n let left = view.textDirection == Direction.LTR ? rect.left : rect.right - view.scrollDOM.clientWidth;\n return {\n left: left - view.scrollDOM.scrollLeft,\n top: rect.top - view.scrollDOM.scrollTop\n };\n}\nfunction wrappedLine(view, pos, inside2) {\n let range = _state.EditorSelection.cursor(pos);\n return {\n from: Math.max(inside2.from, view.moveToLineBoundary(range, false, true).from),\n to: Math.min(inside2.to, view.moveToLineBoundary(range, true, true).from),\n type: BlockType.Text\n };\n}\nfunction blockAt(view, pos) {\n let line = view.lineBlockAt(pos);\n if (Array.isArray(line.type)) for (let l of line.type){\n if (l.to > pos || l.to == pos && (l.to == line.to || l.type == BlockType.Text)) return l;\n }\n return line;\n}\nfunction measureRange(view, range) {\n if (range.to <= view.viewport.from || range.from >= view.viewport.to) return [];\n let from2 = Math.max(range.from, view.viewport.from), to2 = Math.min(range.to, view.viewport.to);\n let ltr = view.textDirection == Direction.LTR;\n let content = view.contentDOM, contentRect = content.getBoundingClientRect(), base = getBase(view);\n let lineStyle = window.getComputedStyle(content.firstChild);\n let leftSide = contentRect.left + parseInt(lineStyle.paddingLeft) + Math.min(0, parseInt(lineStyle.textIndent));\n let rightSide = contentRect.right - parseInt(lineStyle.paddingRight);\n let startBlock = blockAt(view, from2), endBlock = blockAt(view, to2);\n let visualStart = startBlock.type == BlockType.Text ? startBlock : null;\n let visualEnd = endBlock.type == BlockType.Text ? endBlock : null;\n if (view.lineWrapping) {\n if (visualStart) visualStart = wrappedLine(view, from2, visualStart);\n if (visualEnd) visualEnd = wrappedLine(view, to2, visualEnd);\n }\n if (visualStart && visualEnd && visualStart.from == visualEnd.from) return pieces1(drawForLine(range.from, range.to, visualStart));\n else {\n let top = visualStart ? drawForLine(range.from, null, visualStart) : drawForWidget(startBlock, false);\n let bottom = visualEnd ? drawForLine(null, range.to, visualEnd) : drawForWidget(endBlock, true);\n let between = [];\n if ((visualStart || startBlock).to < (visualEnd || endBlock).from - 1) between.push(piece(leftSide, top.bottom, rightSide, bottom.top));\n else if (top.bottom < bottom.top && view.elementAtHeight((top.bottom + bottom.top) / 2).type == BlockType.Text) top.bottom = bottom.top = (top.bottom + bottom.top) / 2;\n return pieces1(top).concat(between).concat(pieces1(bottom));\n }\n function piece(left, top, right, bottom) {\n return new Piece(left - base.left, top - base.top - 0.01 /* Epsilon */ , right - left, bottom - top + 0.01 /* Epsilon */ , \"cm-selectionBackground\");\n }\n function pieces1({ top , bottom , horizontal }) {\n let pieces = [];\n for(let i = 0; i < horizontal.length; i += 2)pieces.push(piece(horizontal[i], top, horizontal[i + 1], bottom));\n return pieces;\n }\n // Gets passed from/to in line-local positions\n function drawForLine(from3, to3, line) {\n let top = 1000000000, bottom = -1000000000, horizontal = [];\n function addSpan(from, fromOpen, to, toOpen, dir) {\n // Passing 2/-2 is a kludge to force the view to return\n // coordinates on the proper side of block widgets, since\n // normalizing the side there, though appropriate for most\n // coordsAtPos queries, would break selection drawing.\n let fromCoords = view.coordsAtPos(from, from == line.to ? -2 : 2);\n let toCoords = view.coordsAtPos(to, to == line.from ? 2 : -2);\n top = Math.min(fromCoords.top, toCoords.top, top);\n bottom = Math.max(fromCoords.bottom, toCoords.bottom, bottom);\n if (dir == Direction.LTR) horizontal.push(ltr && fromOpen ? leftSide : fromCoords.left, ltr && toOpen ? rightSide : toCoords.right);\n else horizontal.push(!ltr && toOpen ? leftSide : toCoords.left, !ltr && fromOpen ? rightSide : fromCoords.right);\n }\n let start = from3 !== null && from3 !== void 0 ? from3 : line.from, end = to3 !== null && to3 !== void 0 ? to3 : line.to;\n // Split the range by visible range and document line\n for (let r of view.visibleRanges)if (r.to > start && r.from < end) for(let pos = Math.max(r.from, start), endPos = Math.min(r.to, end);;){\n let docLine = view.state.doc.lineAt(pos);\n for (let span of view.bidiSpans(docLine)){\n let spanFrom = span.from + docLine.from, spanTo = span.to + docLine.from;\n if (spanFrom >= endPos) break;\n if (spanTo > pos) addSpan(Math.max(spanFrom, pos), from3 == null && spanFrom <= start, Math.min(spanTo, endPos), to3 == null && spanTo >= end, span.dir);\n }\n pos = docLine.to + 1;\n if (pos >= endPos) break;\n }\n if (horizontal.length == 0) addSpan(start, from3 == null, end, to3 == null, view.textDirection);\n return {\n top,\n bottom,\n horizontal\n };\n }\n function drawForWidget(block, top) {\n let y = contentRect.top + (top ? block.top : block.bottom);\n return {\n top: y,\n bottom: y,\n horizontal: []\n };\n }\n}\nfunction measureCursor(view, cursor, primary) {\n let pos = view.coordsAtPos(cursor.head, cursor.assoc || 1);\n if (!pos) return null;\n let base = getBase(view);\n return new Piece(pos.left - base.left, pos.top - base.top, -1, pos.bottom - pos.top, primary ? \"cm-cursor cm-cursor-primary\" : \"cm-cursor cm-cursor-secondary\");\n}\nconst setDropCursorPos = /*@__PURE__*/ _state.StateEffect.define({\n map (pos, mapping) {\n return pos == null ? null : mapping.mapPos(pos);\n }\n});\nconst dropCursorPos = /*@__PURE__*/ _state.StateField.define({\n create () {\n return null;\n },\n update (pos1, tr) {\n if (pos1 != null) pos1 = tr.changes.mapPos(pos1);\n return tr.effects.reduce((pos, e)=>e.is(setDropCursorPos) ? e.value : pos\n , pos1);\n }\n});\nconst drawDropCursor = /*@__PURE__*/ ViewPlugin.fromClass(class {\n constructor(view){\n this.view = view;\n this.cursor = null;\n this.measureReq = {\n read: this.readPos.bind(this),\n write: this.drawCursor.bind(this)\n };\n }\n update(update) {\n var _a;\n let cursorPos = update.state.field(dropCursorPos);\n if (cursorPos == null) {\n if (this.cursor != null) {\n (_a = this.cursor) === null || _a === void 0 || _a.remove();\n this.cursor = null;\n }\n } else {\n if (!this.cursor) {\n this.cursor = this.view.scrollDOM.appendChild(document.createElement(\"div\"));\n this.cursor.className = \"cm-dropCursor\";\n }\n if (update.startState.field(dropCursorPos) != cursorPos || update.docChanged || update.geometryChanged) this.view.requestMeasure(this.measureReq);\n }\n }\n readPos() {\n let pos = this.view.state.field(dropCursorPos);\n let rect = pos != null && this.view.coordsAtPos(pos);\n if (!rect) return null;\n let outer = this.view.scrollDOM.getBoundingClientRect();\n return {\n left: rect.left - outer.left + this.view.scrollDOM.scrollLeft,\n top: rect.top - outer.top + this.view.scrollDOM.scrollTop,\n height: rect.bottom - rect.top\n };\n }\n drawCursor(pos) {\n if (this.cursor) {\n if (pos) {\n this.cursor.style.left = pos.left + \"px\";\n this.cursor.style.top = pos.top + \"px\";\n this.cursor.style.height = pos.height + \"px\";\n } else this.cursor.style.left = \"-100000px\";\n }\n }\n destroy() {\n if (this.cursor) this.cursor.remove();\n }\n setDropPos(pos) {\n if (this.view.state.field(dropCursorPos) != pos) this.view.dispatch({\n effects: setDropCursorPos.of(pos)\n });\n }\n}, {\n eventHandlers: {\n dragover (event) {\n this.setDropPos(this.view.posAtCoords({\n x: event.clientX,\n y: event.clientY\n }));\n },\n dragleave (event) {\n if (event.target == this.view.contentDOM || !this.view.contentDOM.contains(event.relatedTarget)) this.setDropPos(null);\n },\n dragend () {\n this.setDropPos(null);\n },\n drop () {\n this.setDropPos(null);\n }\n }\n});\n/**\nDraws a cursor at the current drop position when something is\ndragged over the editor.\n*/ function dropCursor() {\n return [\n dropCursorPos,\n drawDropCursor\n ];\n}\nfunction iterMatches(doc18, re, from, to, f) {\n re.lastIndex = 0;\n for(let cursor = doc18.iterRange(from, to), pos = from, m; !cursor.next().done; pos += cursor.value.length){\n if (!cursor.lineBreak) while(m = re.exec(cursor.value))f(pos + m.index, pos + m.index + m[0].length, m);\n }\n}\nfunction matchRanges(view, maxLength) {\n let visible = view.visibleRanges;\n if (visible.length == 1 && visible[0].from == view.viewport.from && visible[0].to == view.viewport.to) return visible;\n let result = [];\n for (let { from , to } of visible){\n from = Math.max(view.state.doc.lineAt(from).from, from - maxLength);\n to = Math.min(view.state.doc.lineAt(to).to, to + maxLength);\n if (result.length && result[result.length - 1].to >= from) result[result.length - 1].to = to;\n else result.push({\n from,\n to\n });\n }\n return result;\n}\n/**\nHelper class used to make it easier to maintain decorations on\nvisible code that matches a given regular expression. To be used\nin a [view plugin](https://codemirror.net/6/docs/ref/#view.ViewPlugin). Instances of this object\nrepresent a matching configuration.\n*/ class MatchDecorator {\n /**\n Create a decorator.\n */ constructor(config){\n let { regexp , decoration , boundary , maxLength =1000 } = config;\n if (!regexp.global) throw new RangeError(\"The regular expression given to MatchDecorator should have its 'g' flag set\");\n this.regexp = regexp;\n this.getDeco = typeof decoration == \"function\" ? decoration : ()=>decoration\n ;\n this.boundary = boundary;\n this.maxLength = maxLength;\n }\n /**\n Compute the full set of decorations for matches in the given\n view's viewport. You'll want to call this when initializing your\n plugin.\n */ createDeco(view) {\n let build = new _rangeset.RangeSetBuilder();\n for (let { from , to } of matchRanges(view, this.maxLength))iterMatches(view.state.doc, this.regexp, from, to, (a, b, m)=>build.add(a, b, this.getDeco(m, view, a))\n );\n return build.finish();\n }\n /**\n Update a set of decorations for a view update. `deco` _must_ be\n the set of decorations produced by _this_ `MatchDecorator` for\n the view state before the update.\n */ updateDeco(update, deco) {\n let changeFrom = 1000000000, changeTo = -1;\n if (update.docChanged) update.changes.iterChanges((_f, _t, from, to)=>{\n if (to > update.view.viewport.from && from < update.view.viewport.to) {\n changeFrom = Math.min(from, changeFrom);\n changeTo = Math.max(to, changeTo);\n }\n });\n if (update.viewportChanged || changeTo - changeFrom > 1000) return this.createDeco(update.view);\n if (changeTo > -1) return this.updateRange(update.view, deco.map(update.changes), changeFrom, changeTo);\n return deco;\n }\n updateRange(view, deco, updateFrom, updateTo) {\n for (let r of view.visibleRanges){\n let from4 = Math.max(r.from, updateFrom), to4 = Math.min(r.to, updateTo);\n if (to4 > from4) {\n let fromLine = view.state.doc.lineAt(from4), toLine = fromLine.to < to4 ? view.state.doc.lineAt(to4) : fromLine;\n let start = Math.max(r.from, fromLine.from), end = Math.min(r.to, toLine.to);\n if (this.boundary) {\n for(; from4 > fromLine.from; from4--)if (this.boundary.test(fromLine.text[from4 - 1 - fromLine.from])) {\n start = from4;\n break;\n }\n for(; to4 < toLine.to; to4++)if (this.boundary.test(toLine.text[to4 - toLine.from])) {\n end = to4;\n break;\n }\n }\n let ranges = [], m1;\n if (fromLine == toLine) {\n this.regexp.lastIndex = start - fromLine.from;\n while((m1 = this.regexp.exec(fromLine.text)) && m1.index < end - fromLine.from){\n let pos = m1.index + fromLine.from;\n ranges.push(this.getDeco(m1, view, pos).range(pos, pos + m1[0].length));\n }\n } else iterMatches(view.state.doc, this.regexp, start, end, (from, to, m)=>ranges.push(this.getDeco(m, view, from).range(from, to))\n );\n deco = deco.update({\n filterFrom: start,\n filterTo: end,\n filter: (from, to)=>from < start || to > end\n ,\n add: ranges\n });\n }\n }\n return deco;\n }\n}\nconst UnicodeRegexpSupport = /x/.unicode != null ? \"gu\" : \"g\";\nconst Specials = /*@__PURE__*/ new RegExp(\"[\\u0000-\\u0008\\u000a-\\u001f\\u007f-\\u009f\\u00ad\\u061c\\u200b\\u200e\\u200f\\u2028\\u2029\\u202d\\u202e\\ufeff\\ufff9-\\ufffc]\", UnicodeRegexpSupport);\nconst Names = {\n 0: \"null\",\n 7: \"bell\",\n 8: \"backspace\",\n 10: \"newline\",\n 11: \"vertical tab\",\n 13: \"carriage return\",\n 27: \"escape\",\n 8203: \"zero width space\",\n 8204: \"zero width non-joiner\",\n 8205: \"zero width joiner\",\n 8206: \"left-to-right mark\",\n 8207: \"right-to-left mark\",\n 8232: \"line separator\",\n 8237: \"left-to-right override\",\n 8238: \"right-to-left override\",\n 8233: \"paragraph separator\",\n 65279: \"zero width no-break space\",\n 65532: \"object replacement\"\n};\nlet _supportsTabSize = null;\nfunction supportsTabSize() {\n var _a;\n if (_supportsTabSize == null && typeof document != \"undefined\" && document.body) {\n let styles = document.body.style;\n _supportsTabSize = ((_a = styles.tabSize) !== null && _a !== void 0 ? _a : styles.MozTabSize) != null;\n }\n return _supportsTabSize || false;\n}\nconst specialCharConfig = /*@__PURE__*/ _state.Facet.define({\n combine (configs) {\n let config = _state.combineConfig(configs, {\n render: null,\n specialChars: Specials,\n addSpecialChars: null\n });\n if (config.replaceTabs = !supportsTabSize()) config.specialChars = new RegExp(\"\\t|\" + config.specialChars.source, UnicodeRegexpSupport);\n if (config.addSpecialChars) config.specialChars = new RegExp(config.specialChars.source + \"|\" + config.addSpecialChars.source, UnicodeRegexpSupport);\n return config;\n }\n});\n/**\nReturns an extension that installs highlighting of special\ncharacters.\n*/ function highlightSpecialChars(/**\nConfiguration options.\n*/ config = {\n}) {\n return [\n specialCharConfig.of(config),\n specialCharPlugin()\n ];\n}\nlet _plugin = null;\nfunction specialCharPlugin() {\n return _plugin || (_plugin = ViewPlugin.fromClass(class {\n constructor(view){\n this.view = view;\n this.decorations = Decoration.none;\n this.decorationCache = Object.create(null);\n this.decorator = this.makeDecorator(view.state.facet(specialCharConfig));\n this.decorations = this.decorator.createDeco(view);\n }\n makeDecorator(conf) {\n return new MatchDecorator({\n regexp: conf.specialChars,\n decoration: (m, view, pos)=>{\n let { doc: doc19 } = view.state;\n let code = _text.codePointAt(m[0], 0);\n if (code == 9) {\n let line = doc19.lineAt(pos);\n let size = view.state.tabSize, col = _text.countColumn(line.text, size, pos - line.from);\n return Decoration.replace({\n widget: new TabWidget((size - col % size) * this.view.defaultCharacterWidth)\n });\n }\n return this.decorationCache[code] || (this.decorationCache[code] = Decoration.replace({\n widget: new SpecialCharWidget(conf, code)\n }));\n },\n boundary: conf.replaceTabs ? undefined : /[^]/\n });\n }\n update(update) {\n let conf = update.state.facet(specialCharConfig);\n if (update.startState.facet(specialCharConfig) != conf) {\n this.decorator = this.makeDecorator(conf);\n this.decorations = this.decorator.createDeco(update.view);\n } else this.decorations = this.decorator.updateDeco(update, this.decorations);\n }\n }, {\n decorations: (v)=>v.decorations\n }));\n}\nconst DefaultPlaceholder = \"\\u2022\";\n// Assigns placeholder characters from the Control Pictures block to\n// ASCII control characters\nfunction placeholder$1(code) {\n if (code >= 32) return DefaultPlaceholder;\n if (code == 10) return \"\\u2424\";\n return String.fromCharCode(9216 + code);\n}\nclass SpecialCharWidget extends WidgetType {\n constructor(options, code){\n super();\n this.options = options;\n this.code = code;\n }\n eq(other) {\n return other.code == this.code;\n }\n toDOM(view) {\n let ph = placeholder$1(this.code);\n let desc = view.state.phrase(\"Control character\") + \" \" + (Names[this.code] || \"0x\" + this.code.toString(16));\n let custom = this.options.render && this.options.render(this.code, desc, ph);\n if (custom) return custom;\n let span = document.createElement(\"span\");\n span.textContent = ph;\n span.title = desc;\n span.setAttribute(\"aria-label\", desc);\n span.className = \"cm-specialChar\";\n return span;\n }\n ignoreEvent() {\n return false;\n }\n}\nclass TabWidget extends WidgetType {\n constructor(width){\n super();\n this.width = width;\n }\n eq(other) {\n return other.width == this.width;\n }\n toDOM() {\n let span = document.createElement(\"span\");\n span.textContent = \"\\t\";\n span.className = \"cm-tab\";\n span.style.width = this.width + \"px\";\n return span;\n }\n ignoreEvent() {\n return false;\n }\n}\nconst plugin = /*@__PURE__*/ ViewPlugin.fromClass(class {\n constructor(){\n this.height = 1000;\n this.attrs = {\n style: \"padding-bottom: 1000px\"\n };\n }\n update(update) {\n let height = update.view.viewState.editorHeight - update.view.defaultLineHeight;\n if (height != this.height) {\n this.height = height;\n this.attrs = {\n style: `padding-bottom: ${height}px`\n };\n }\n }\n});\n/**\nReturns an extension that makes sure the content has a bottom\nmargin equivalent to the height of the editor, minus one line\nheight, so that every line in the document can be scrolled to the\ntop of the editor.\n\nThis is only meaningful when the editor is scrollable, and should\nnot be enabled in editors that take the size of their content.\n*/ function scrollPastEnd() {\n return [\n plugin,\n contentAttributes.of((view)=>{\n var _a;\n return ((_a = view.plugin(plugin)) === null || _a === void 0 ? void 0 : _a.attrs) || null;\n })\n ];\n}\n/**\nMark lines that have a cursor on them with the `\"cm-activeLine\"`\nDOM class.\n*/ function highlightActiveLine() {\n return activeLineHighlighter;\n}\nconst lineDeco = /*@__PURE__*/ Decoration.line({\n class: \"cm-activeLine\"\n});\nconst activeLineHighlighter = /*@__PURE__*/ ViewPlugin.fromClass(class {\n constructor(view){\n this.decorations = this.getDeco(view);\n }\n update(update) {\n if (update.docChanged || update.selectionSet) this.decorations = this.getDeco(update.view);\n }\n getDeco(view) {\n let lastLineStart = -1, deco = [];\n for (let r of view.state.selection.ranges){\n if (!r.empty) return Decoration.none;\n let line = view.lineBlockAt(r.head);\n if (line.from > lastLineStart) {\n deco.push(lineDeco.range(line.from));\n lastLineStart = line.from;\n }\n }\n return Decoration.set(deco);\n }\n}, {\n decorations: (v)=>v.decorations\n});\nclass Placeholder extends WidgetType {\n constructor(content){\n super();\n this.content = content;\n }\n toDOM() {\n let wrap = document.createElement(\"span\");\n wrap.className = \"cm-placeholder\";\n wrap.style.pointerEvents = \"none\";\n wrap.appendChild(typeof this.content == \"string\" ? document.createTextNode(this.content) : this.content);\n if (typeof this.content == \"string\") wrap.setAttribute(\"aria-label\", \"placeholder \" + this.content);\n else wrap.setAttribute(\"aria-hidden\", \"true\");\n return wrap;\n }\n ignoreEvent() {\n return false;\n }\n}\n/**\nExtension that enables a placeholder\u2014a piece of example content\nto show when the editor is empty.\n*/ function placeholder(content) {\n return ViewPlugin.fromClass(class {\n constructor(view){\n this.view = view;\n this.placeholder = Decoration.set([\n Decoration.widget({\n widget: new Placeholder(content),\n side: 1\n }).range(0)\n ]);\n }\n get decorations() {\n return this.view.state.doc.length ? Decoration.none : this.placeholder;\n }\n }, {\n decorations: (v)=>v.decorations\n });\n}\n/**\n@internal\n*/ const __test = {\n HeightMap,\n HeightOracle,\n MeasuredHeights,\n QueryType,\n ChangedRange,\n computeOrder,\n moveVisually\n};\n\n},{\"@codemirror/state\":\"e6FBl\",\"style-mod\":\"7FGwv\",\"@codemirror/rangeset\":\"9yBpo\",\"@codemirror/text\":\"kn7DT\",\"w3c-keyname\":\"922Xs\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"7FGwv\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\n// :: - Style modules encapsulate a set of CSS rules defined from\n// JavaScript. Their definitions are only available in a given DOM\n// root after it has been _mounted_ there with `StyleModule.mount`.\n//\n// Style modules should be created once and stored somewhere, as\n// opposed to re-creating them every time you need them. The amount of\n// CSS rules generated for a given DOM root is bounded by the amount\n// of style modules that were used. So to avoid leaking rules, don't\n// create these dynamically, but treat them as one-time allocations.\nparcelHelpers.export(exports, \"StyleModule\", ()=>StyleModule\n);\nconst C = \"\\u037c\";\nconst COUNT = typeof Symbol == \"undefined\" ? \"__\" + C : Symbol.for(C);\nconst SET = typeof Symbol == \"undefined\" ? \"__styleSet\" + Math.floor(Math.random() * 100000000) : Symbol(\"styleSet\");\nconst top = typeof globalThis != \"undefined\" ? globalThis : typeof window != \"undefined\" ? window : {\n};\nclass StyleModule {\n // :: (Object<Style>, ?{finish: ?(string) \u2192 string})\n // Create a style module from the given spec.\n //\n // When `finish` is given, it is called on regular (non-`@`)\n // selectors (after `&` expansion) to compute the final selector.\n constructor(spec1, options){\n this.rules = [];\n let { finish } = options || {\n };\n function splitSelector(selector) {\n return /^@/.test(selector) ? [\n selector\n ] : selector.split(/,\\s*/);\n }\n function render(selectors, spec, target, isKeyframes) {\n let local = [], isAt = /^@(\\w+)\\b/.exec(selectors[0]), keyframes = isAt && isAt[1] == \"keyframes\";\n if (isAt && spec == null) return target.push(selectors[0] + \";\");\n for(let prop in spec){\n let value = spec[prop];\n if (/&/.test(prop)) render(prop.split(/,\\s*/).map((part)=>selectors.map((sel)=>part.replace(/&/, sel)\n )\n ).reduce((a, b)=>a.concat(b)\n ), value, target);\n else if (value && typeof value == \"object\") {\n if (!isAt) throw new RangeError(\"The value of a property (\" + prop + \") should be a primitive value.\");\n render(splitSelector(prop), value, local, keyframes);\n } else if (value != null) local.push(prop.replace(/_.*/, \"\").replace(/[A-Z]/g, (l)=>\"-\" + l.toLowerCase()\n ) + \": \" + value + \";\");\n }\n if (local.length || keyframes) target.push((finish && !isAt && !isKeyframes ? selectors.map(finish) : selectors).join(\", \") + \" {\" + local.join(\" \") + \"}\");\n }\n for(let prop1 in spec1)render(splitSelector(prop1), spec1[prop1], this.rules);\n }\n // :: () \u2192 string\n // Returns a string containing the module's CSS rules.\n getRules() {\n return this.rules.join(\"\\n\");\n }\n // :: () \u2192 string\n // Generate a new unique CSS class name.\n static newName() {\n let id = top[COUNT] || 1;\n top[COUNT] = id + 1;\n return C + id.toString(36);\n }\n // :: (union<Document, ShadowRoot>, union<[StyleModule], StyleModule>)\n //\n // Mount the given set of modules in the given DOM root, which ensures\n // that the CSS rules defined by the module are available in that\n // context.\n //\n // Rules are only added to the document once per root.\n //\n // Rule order will follow the order of the modules, so that rules from\n // modules later in the array take precedence of those from earlier\n // modules. If you call this function multiple times for the same root\n // in a way that changes the order of already mounted modules, the old\n // order will be changed.\n static mount(root, modules) {\n (root[SET] || new StyleSet(root)).mount(Array.isArray(modules) ? modules : [\n modules\n ]);\n }\n}\nlet adoptedSet = null;\nclass StyleSet {\n constructor(root){\n if (!root.head && root.adoptedStyleSheets && typeof CSSStyleSheet != \"undefined\") {\n if (adoptedSet) {\n root.adoptedStyleSheets = [\n adoptedSet.sheet\n ].concat(root.adoptedStyleSheets);\n return root[SET] = adoptedSet;\n }\n this.sheet = new CSSStyleSheet;\n root.adoptedStyleSheets = [\n this.sheet\n ].concat(root.adoptedStyleSheets);\n adoptedSet = this;\n } else {\n this.styleTag = (root.ownerDocument || root).createElement(\"style\");\n let target = root.head || root;\n target.insertBefore(this.styleTag, target.firstChild);\n }\n this.modules = [];\n root[SET] = this;\n }\n mount(modules) {\n let sheet = this.sheet;\n let pos = 0 /* Current rule offset */ , j = 0 /* Index into this.modules */ ;\n for(let i = 0; i < modules.length; i++){\n let mod = modules[i], index = this.modules.indexOf(mod);\n if (index < j && index > -1) {\n this.modules.splice(index, 1);\n j--;\n index = -1;\n }\n if (index == -1) {\n this.modules.splice(j++, 0, mod);\n if (sheet) for(let k = 0; k < mod.rules.length; k++)sheet.insertRule(mod.rules[k], pos++);\n } else {\n while(j < index)pos += this.modules[j++].rules.length;\n pos += mod.rules.length;\n j++;\n }\n }\n if (!sheet) {\n let text = \"\";\n for(let i = 0; i < this.modules.length; i++)text += this.modules[i].getRules() + \"\\n\";\n this.styleTag.textContent = text;\n }\n }\n} // Style::Object<union<Style,string>>\n //\n // A style is an object that, in the simple case, maps CSS property\n // names to strings holding their values, as in `{color: \"red\",\n // fontWeight: \"bold\"}`. The property names can be given in\n // camel-case\u2014the library will insert a dash before capital letters\n // when converting them to CSS.\n //\n // If you include an underscore in a property name, it and everything\n // after it will be removed from the output, which can be useful when\n // providing a property multiple times, for browser compatibility\n // reasons.\n //\n // A property in a style object can also be a sub-selector, which\n // extends the current context to add a pseudo-selector or a child\n // selector. Such a property should contain a `&` character, which\n // will be replaced by the current selector. For example `{\"&:before\":\n // {content: '\"hi\"'}}`. Sub-selectors and regular properties can\n // freely be mixed in a given object. Any property containing a `&` is\n // assumed to be a sub-selector.\n //\n // Finally, a property can specify an @-block to be wrapped around the\n // styles defined inside the object that's the property's value. For\n // example to create a media query you can do `{\"@media screen and\n // (min-width: 400px)\": {...}}`.\n\n},{\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"9yBpo\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"Range\", ()=>Range\n);\nparcelHelpers.export(exports, \"RangeSet\", ()=>RangeSet\n);\nparcelHelpers.export(exports, \"RangeSetBuilder\", ()=>RangeSetBuilder\n);\nparcelHelpers.export(exports, \"RangeValue\", ()=>RangeValue\n);\nvar _state = require(\"@codemirror/state\");\n/**\nEach range is associated with a value, which must inherit from\nthis class.\n*/ class RangeValue {\n /**\n Compare this value with another value. The default\n implementation compares by identity.\n */ eq(other) {\n return this == other;\n }\n /**\n Create a [range](https://codemirror.net/6/docs/ref/#rangeset.Range) with this value.\n */ range(from, to = from) {\n return new Range(from, to, this);\n }\n}\nRangeValue.prototype.startSide = RangeValue.prototype.endSide = 0;\nRangeValue.prototype.point = false;\nRangeValue.prototype.mapMode = _state.MapMode.TrackDel;\n/**\nA range associates a value with a range of positions.\n*/ class Range {\n /**\n @internal\n */ constructor(/**\n The range's start position.\n */ from, /**\n Its end position.\n */ to, /**\n The value associated with this range.\n */ value){\n this.from = from;\n this.to = to;\n this.value = value;\n }\n}\nfunction cmpRange(a, b) {\n return a.from - b.from || a.value.startSide - b.value.startSide;\n}\nclass Chunk {\n constructor(from, to, value, // Chunks are marked with the largest point that occurs\n // in them (or -1 for no points), so that scans that are\n // only interested in points (such as the\n // heightmap-related logic) can skip range-only chunks.\n maxPoint){\n this.from = from;\n this.to = to;\n this.value = value;\n this.maxPoint = maxPoint;\n }\n get length() {\n return this.to[this.to.length - 1];\n }\n // Find the index of the given position and side. Use the ranges'\n // `from` pos when `end == false`, `to` when `end == true`.\n findIndex(pos, side, end, startAt = 0) {\n let arr = end ? this.to : this.from;\n for(let lo = startAt, hi = arr.length;;){\n if (lo == hi) return lo;\n let mid = lo + hi >> 1;\n let diff = arr[mid] - pos || (end ? this.value[mid].endSide : this.value[mid].startSide) - side;\n if (mid == lo) return diff >= 0 ? lo : hi;\n if (diff >= 0) hi = mid;\n else lo = mid + 1;\n }\n }\n between(offset, from, to, f) {\n for(let i = this.findIndex(from, -1000000000 /* Far */ , true), e = this.findIndex(to, 1000000000 /* Far */ , false, i); i < e; i++)if (f(this.from[i] + offset, this.to[i] + offset, this.value[i]) === false) return false;\n }\n map(offset, changes) {\n let value = [], from = [], to = [], newPos = -1, maxPoint = -1;\n for(let i = 0; i < this.value.length; i++){\n let val = this.value[i], curFrom = this.from[i] + offset, curTo = this.to[i] + offset, newFrom, newTo;\n if (curFrom == curTo) {\n let mapped = changes.mapPos(curFrom, val.startSide, val.mapMode);\n if (mapped == null) continue;\n newFrom = newTo = mapped;\n if (val.startSide != val.endSide) {\n newTo = changes.mapPos(curFrom, val.endSide);\n if (newTo < newFrom) continue;\n }\n } else {\n newFrom = changes.mapPos(curFrom, val.startSide);\n newTo = changes.mapPos(curTo, val.endSide);\n if (newFrom > newTo || newFrom == newTo && val.startSide > 0 && val.endSide <= 0) continue;\n }\n if ((newTo - newFrom || val.endSide - val.startSide) < 0) continue;\n if (newPos < 0) newPos = newFrom;\n if (val.point) maxPoint = Math.max(maxPoint, newTo - newFrom);\n value.push(val);\n from.push(newFrom - newPos);\n to.push(newTo - newPos);\n }\n return {\n mapped: value.length ? new Chunk(from, to, value, maxPoint) : null,\n pos: newPos\n };\n }\n}\n/**\nA range set stores a collection of [ranges](https://codemirror.net/6/docs/ref/#rangeset.Range) in a\nway that makes them efficient to [map](https://codemirror.net/6/docs/ref/#rangeset.RangeSet.map) and\n[update](https://codemirror.net/6/docs/ref/#rangeset.RangeSet.update). This is an immutable data\nstructure.\n*/ class RangeSet {\n /**\n @internal\n */ constructor(/**\n @internal\n */ chunkPos, /**\n @internal\n */ chunk, /**\n @internal\n */ nextLayer = RangeSet.empty, /**\n @internal\n */ maxPoint){\n this.chunkPos = chunkPos;\n this.chunk = chunk;\n this.nextLayer = nextLayer;\n this.maxPoint = maxPoint;\n }\n /**\n @internal\n */ get length() {\n let last = this.chunk.length - 1;\n return last < 0 ? 0 : Math.max(this.chunkEnd(last), this.nextLayer.length);\n }\n /**\n The number of ranges in the set.\n */ get size() {\n if (this.isEmpty) return 0;\n let size = this.nextLayer.size;\n for (let chunk of this.chunk)size += chunk.value.length;\n return size;\n }\n /**\n @internal\n */ chunkEnd(index) {\n return this.chunkPos[index] + this.chunk[index].length;\n }\n /**\n Update the range set, optionally adding new ranges or filtering\n out existing ones.\n \n (The extra type parameter is just there as a kludge to work\n around TypeScript variance issues that prevented `RangeSet<X>`\n from being a subtype of `RangeSet<Y>` when `X` is a subtype of\n `Y`.)\n */ update(updateSpec) {\n let { add =[] , sort =false , filterFrom =0 , filterTo =this.length } = updateSpec;\n let filter = updateSpec.filter;\n if (add.length == 0 && !filter) return this;\n if (sort) add.slice().sort(cmpRange);\n if (this.isEmpty) return add.length ? RangeSet.of(add) : this;\n let cur = new LayerCursor(this, null, -1).goto(0), i = 0, spill = [];\n let builder = new RangeSetBuilder();\n while(cur.value || i < add.length){\n if (i < add.length && (cur.from - add[i].from || cur.startSide - add[i].value.startSide) >= 0) {\n let range = add[i++];\n if (!builder.addInner(range.from, range.to, range.value)) spill.push(range);\n } else if (cur.rangeIndex == 1 && cur.chunkIndex < this.chunk.length && (i == add.length || this.chunkEnd(cur.chunkIndex) < add[i].from) && (!filter || filterFrom > this.chunkEnd(cur.chunkIndex) || filterTo < this.chunkPos[cur.chunkIndex]) && builder.addChunk(this.chunkPos[cur.chunkIndex], this.chunk[cur.chunkIndex])) cur.nextChunk();\n else {\n if (!filter || filterFrom > cur.to || filterTo < cur.from || filter(cur.from, cur.to, cur.value)) {\n if (!builder.addInner(cur.from, cur.to, cur.value)) spill.push(new Range(cur.from, cur.to, cur.value));\n }\n cur.next();\n }\n }\n return builder.finishInner(this.nextLayer.isEmpty && !spill.length ? RangeSet.empty : this.nextLayer.update({\n add: spill,\n filter,\n filterFrom,\n filterTo\n }));\n }\n /**\n Map this range set through a set of changes, return the new set.\n */ map(changes) {\n if (changes.length == 0 || this.isEmpty) return this;\n let chunks = [], chunkPos = [], maxPoint = -1;\n for(let i = 0; i < this.chunk.length; i++){\n let start = this.chunkPos[i], chunk = this.chunk[i];\n let touch = changes.touchesRange(start, start + chunk.length);\n if (touch === false) {\n maxPoint = Math.max(maxPoint, chunk.maxPoint);\n chunks.push(chunk);\n chunkPos.push(changes.mapPos(start));\n } else if (touch === true) {\n let { mapped , pos } = chunk.map(start, changes);\n if (mapped) {\n maxPoint = Math.max(maxPoint, mapped.maxPoint);\n chunks.push(mapped);\n chunkPos.push(pos);\n }\n }\n }\n let next = this.nextLayer.map(changes);\n return chunks.length == 0 ? next : new RangeSet(chunkPos, chunks, next, maxPoint);\n }\n /**\n Iterate over the ranges that touch the region `from` to `to`,\n calling `f` for each. There is no guarantee that the ranges will\n be reported in any specific order. When the callback returns\n `false`, iteration stops.\n */ between(from, to, f) {\n if (this.isEmpty) return;\n for(let i = 0; i < this.chunk.length; i++){\n let start = this.chunkPos[i], chunk = this.chunk[i];\n if (to >= start && from <= start + chunk.length && chunk.between(start, from - start, to - start, f) === false) return;\n }\n this.nextLayer.between(from, to, f);\n }\n /**\n Iterate over the ranges in this set, in order, including all\n ranges that end at or after `from`.\n */ iter(from = 0) {\n return HeapCursor.from([\n this\n ]).goto(from);\n }\n /**\n @internal\n */ get isEmpty() {\n return this.nextLayer == this;\n }\n /**\n Iterate over the ranges in a collection of sets, in order,\n starting from `from`.\n */ static iter(sets, from = 0) {\n return HeapCursor.from(sets).goto(from);\n }\n /**\n Iterate over two groups of sets, calling methods on `comparator`\n to notify it of possible differences.\n */ static compare(oldSets, newSets, /**\n This indicates how the underlying data changed between these\n ranges, and is needed to synchronize the iteration. `from` and\n `to` are coordinates in the _new_ space, after these changes.\n */ textDiff, comparator, /**\n Can be used to ignore all non-point ranges, and points below\n the given size. When -1, all ranges are compared.\n */ minPointSize = -1) {\n let a = oldSets.filter((set)=>set.maxPoint > 0 || !set.isEmpty && set.maxPoint >= minPointSize\n );\n let b = newSets.filter((set)=>set.maxPoint > 0 || !set.isEmpty && set.maxPoint >= minPointSize\n );\n let sharedChunks = findSharedChunks(a, b, textDiff);\n let sideA = new SpanCursor(a, sharedChunks, minPointSize);\n let sideB = new SpanCursor(b, sharedChunks, minPointSize);\n textDiff.iterGaps((fromA, fromB, length)=>compare(sideA, fromA, sideB, fromB, length, comparator)\n );\n if (textDiff.empty && textDiff.length == 0) compare(sideA, 0, sideB, 0, 0, comparator);\n }\n /**\n Compare the contents of two groups of range sets, returning true\n if they are equivalent in the given range.\n */ static eq(oldSets, newSets, from = 0, to) {\n if (to == null) to = 1000000000 /* Far */ ;\n let a = oldSets.filter((set)=>!set.isEmpty && newSets.indexOf(set) < 0\n );\n let b = newSets.filter((set)=>!set.isEmpty && oldSets.indexOf(set) < 0\n );\n if (a.length != b.length) return false;\n if (!a.length) return true;\n let sharedChunks = findSharedChunks(a, b);\n let sideA = new SpanCursor(a, sharedChunks, 0).goto(from), sideB = new SpanCursor(b, sharedChunks, 0).goto(from);\n for(;;){\n if (sideA.to != sideB.to || !sameValues(sideA.active, sideB.active) || sideA.point && (!sideB.point || !sideA.point.eq(sideB.point))) return false;\n if (sideA.to > to) return true;\n sideA.next();\n sideB.next();\n }\n }\n /**\n Iterate over a group of range sets at the same time, notifying\n the iterator about the ranges covering every given piece of\n content. Returns the open count (see\n [`SpanIterator.span`](https://codemirror.net/6/docs/ref/#rangeset.SpanIterator.span)) at the end\n of the iteration.\n */ static spans(sets, from, to, iterator, /**\n When given and greater than -1, only points of at least this\n size are taken into account.\n */ minPointSize = -1) {\n var _a;\n let cursor = new SpanCursor(sets, null, minPointSize, (_a = iterator.filterPoint) === null || _a === void 0 ? void 0 : _a.bind(iterator)).goto(from), pos = from;\n let open = cursor.openStart;\n for(;;){\n let curTo = Math.min(cursor.to, to);\n if (cursor.point) {\n iterator.point(pos, curTo, cursor.point, cursor.activeForPoint(cursor.to), open);\n open = cursor.openEnd(curTo) + (cursor.to > curTo ? 1 : 0);\n } else if (curTo > pos) {\n iterator.span(pos, curTo, cursor.active, open);\n open = cursor.openEnd(curTo);\n }\n if (cursor.to > to) break;\n pos = cursor.to;\n cursor.next();\n }\n return open;\n }\n /**\n Create a range set for the given range or array of ranges. By\n default, this expects the ranges to be _sorted_ (by start\n position and, if two start at the same position,\n `value.startSide`). You can pass `true` as second argument to\n cause the method to sort them.\n */ static of(ranges, sort = false) {\n let build = new RangeSetBuilder();\n for (let range of ranges instanceof Range ? [\n ranges\n ] : sort ? lazySort(ranges) : ranges)build.add(range.from, range.to, range.value);\n return build.finish();\n }\n}\n/**\nThe empty set of ranges.\n*/ RangeSet.empty = /*@__PURE__*/ new RangeSet([], [], null, -1);\nfunction lazySort(ranges) {\n if (ranges.length > 1) for(let prev = ranges[0], i = 1; i < ranges.length; i++){\n let cur = ranges[i];\n if (cmpRange(prev, cur) > 0) return ranges.slice().sort(cmpRange);\n prev = cur;\n }\n return ranges;\n}\nRangeSet.empty.nextLayer = RangeSet.empty;\n/**\nA range set builder is a data structure that helps build up a\n[range set](https://codemirror.net/6/docs/ref/#rangeset.RangeSet) directly, without first allocating\nan array of [`Range`](https://codemirror.net/6/docs/ref/#rangeset.Range) objects.\n*/ class RangeSetBuilder {\n /**\n Create an empty builder.\n */ constructor(){\n this.chunks = [];\n this.chunkPos = [];\n this.chunkStart = -1;\n this.last = null;\n this.lastFrom = -1000000000 /* Far */ ;\n this.lastTo = -1000000000 /* Far */ ;\n this.from = [];\n this.to = [];\n this.value = [];\n this.maxPoint = -1;\n this.setMaxPoint = -1;\n this.nextLayer = null;\n }\n finishChunk(newArrays) {\n this.chunks.push(new Chunk(this.from, this.to, this.value, this.maxPoint));\n this.chunkPos.push(this.chunkStart);\n this.chunkStart = -1;\n this.setMaxPoint = Math.max(this.setMaxPoint, this.maxPoint);\n this.maxPoint = -1;\n if (newArrays) {\n this.from = [];\n this.to = [];\n this.value = [];\n }\n }\n /**\n Add a range. Ranges should be added in sorted (by `from` and\n `value.startSide`) order.\n */ add(from, to, value) {\n if (!this.addInner(from, to, value)) (this.nextLayer || (this.nextLayer = new RangeSetBuilder)).add(from, to, value);\n }\n /**\n @internal\n */ addInner(from, to, value) {\n let diff = from - this.lastTo || value.startSide - this.last.endSide;\n if (diff <= 0 && (from - this.lastFrom || value.startSide - this.last.startSide) < 0) throw new Error(\"Ranges must be added sorted by `from` position and `startSide`\");\n if (diff < 0) return false;\n if (this.from.length == 250 /* ChunkSize */ ) this.finishChunk(true);\n if (this.chunkStart < 0) this.chunkStart = from;\n this.from.push(from - this.chunkStart);\n this.to.push(to - this.chunkStart);\n this.last = value;\n this.lastFrom = from;\n this.lastTo = to;\n this.value.push(value);\n if (value.point) this.maxPoint = Math.max(this.maxPoint, to - from);\n return true;\n }\n /**\n @internal\n */ addChunk(from, chunk) {\n if ((from - this.lastTo || chunk.value[0].startSide - this.last.endSide) < 0) return false;\n if (this.from.length) this.finishChunk(true);\n this.setMaxPoint = Math.max(this.setMaxPoint, chunk.maxPoint);\n this.chunks.push(chunk);\n this.chunkPos.push(from);\n let last = chunk.value.length - 1;\n this.last = chunk.value[last];\n this.lastFrom = chunk.from[last] + from;\n this.lastTo = chunk.to[last] + from;\n return true;\n }\n /**\n Finish the range set. Returns the new set. The builder can't be\n used anymore after this has been called.\n */ finish() {\n return this.finishInner(RangeSet.empty);\n }\n /**\n @internal\n */ finishInner(next) {\n if (this.from.length) this.finishChunk(false);\n if (this.chunks.length == 0) return next;\n let result = new RangeSet(this.chunkPos, this.chunks, this.nextLayer ? this.nextLayer.finishInner(next) : next, this.setMaxPoint);\n this.from = null; // Make sure further `add` calls produce errors\n return result;\n }\n}\nfunction findSharedChunks(a, b, textDiff) {\n let inA = new Map();\n for (let set of a)for(let i = 0; i < set.chunk.length; i++)if (set.chunk[i].maxPoint <= 0) inA.set(set.chunk[i], set.chunkPos[i]);\n let shared = new Set();\n for (let set1 of b)for(let i1 = 0; i1 < set1.chunk.length; i1++){\n let known = inA.get(set1.chunk[i1]);\n if (known != null && (textDiff ? textDiff.mapPos(known) : known) == set1.chunkPos[i1] && !(textDiff === null || textDiff === void 0 ? void 0 : textDiff.touchesRange(known, known + set1.chunk[i1].length))) shared.add(set1.chunk[i1]);\n }\n return shared;\n}\nclass LayerCursor {\n constructor(layer, skip, minPoint, rank = 0){\n this.layer = layer;\n this.skip = skip;\n this.minPoint = minPoint;\n this.rank = rank;\n }\n get startSide() {\n return this.value ? this.value.startSide : 0;\n }\n get endSide() {\n return this.value ? this.value.endSide : 0;\n }\n goto(pos, side = -1000000000 /* Far */ ) {\n this.chunkIndex = this.rangeIndex = 0;\n this.gotoInner(pos, side, false);\n return this;\n }\n gotoInner(pos, side, forward) {\n while(this.chunkIndex < this.layer.chunk.length){\n let next = this.layer.chunk[this.chunkIndex];\n if (!(this.skip && this.skip.has(next) || this.layer.chunkEnd(this.chunkIndex) < pos || next.maxPoint < this.minPoint)) break;\n this.chunkIndex++;\n forward = false;\n }\n if (this.chunkIndex < this.layer.chunk.length) {\n let rangeIndex = this.layer.chunk[this.chunkIndex].findIndex(pos - this.layer.chunkPos[this.chunkIndex], side, true);\n if (!forward || this.rangeIndex < rangeIndex) this.setRangeIndex(rangeIndex);\n }\n this.next();\n }\n forward(pos, side) {\n if ((this.to - pos || this.endSide - side) < 0) this.gotoInner(pos, side, true);\n }\n next() {\n for(;;)if (this.chunkIndex == this.layer.chunk.length) {\n this.from = this.to = 1000000000 /* Far */ ;\n this.value = null;\n break;\n } else {\n let chunkPos = this.layer.chunkPos[this.chunkIndex], chunk = this.layer.chunk[this.chunkIndex];\n let from = chunkPos + chunk.from[this.rangeIndex];\n this.from = from;\n this.to = chunkPos + chunk.to[this.rangeIndex];\n this.value = chunk.value[this.rangeIndex];\n this.setRangeIndex(this.rangeIndex + 1);\n if (this.minPoint < 0 || this.value.point && this.to - this.from >= this.minPoint) break;\n }\n }\n setRangeIndex(index) {\n if (index == this.layer.chunk[this.chunkIndex].value.length) {\n this.chunkIndex++;\n if (this.skip) while(this.chunkIndex < this.layer.chunk.length && this.skip.has(this.layer.chunk[this.chunkIndex]))this.chunkIndex++;\n this.rangeIndex = 0;\n } else this.rangeIndex = index;\n }\n nextChunk() {\n this.chunkIndex++;\n this.rangeIndex = 0;\n this.next();\n }\n compare(other) {\n return this.from - other.from || this.startSide - other.startSide || this.to - other.to || this.endSide - other.endSide;\n }\n}\nclass HeapCursor {\n constructor(heap){\n this.heap = heap;\n }\n static from(sets, skip = null, minPoint = -1) {\n let heap = [];\n for(let i = 0; i < sets.length; i++){\n for(let cur = sets[i]; !cur.isEmpty; cur = cur.nextLayer)if (cur.maxPoint >= minPoint) heap.push(new LayerCursor(cur, skip, minPoint, i));\n }\n return heap.length == 1 ? heap[0] : new HeapCursor(heap);\n }\n get startSide() {\n return this.value ? this.value.startSide : 0;\n }\n goto(pos, side = -1000000000 /* Far */ ) {\n for (let cur of this.heap)cur.goto(pos, side);\n for(let i = this.heap.length >> 1; i >= 0; i--)heapBubble(this.heap, i);\n this.next();\n return this;\n }\n forward(pos, side) {\n for (let cur of this.heap)cur.forward(pos, side);\n for(let i = this.heap.length >> 1; i >= 0; i--)heapBubble(this.heap, i);\n if ((this.to - pos || this.value.endSide - side) < 0) this.next();\n }\n next() {\n if (this.heap.length == 0) {\n this.from = this.to = 1000000000 /* Far */ ;\n this.value = null;\n this.rank = -1;\n } else {\n let top = this.heap[0];\n this.from = top.from;\n this.to = top.to;\n this.value = top.value;\n this.rank = top.rank;\n if (top.value) top.next();\n heapBubble(this.heap, 0);\n }\n }\n}\nfunction heapBubble(heap, index) {\n for(let cur = heap[index];;){\n let childIndex = (index << 1) + 1;\n if (childIndex >= heap.length) break;\n let child = heap[childIndex];\n if (childIndex + 1 < heap.length && child.compare(heap[childIndex + 1]) >= 0) {\n child = heap[childIndex + 1];\n childIndex++;\n }\n if (cur.compare(child) < 0) break;\n heap[childIndex] = cur;\n heap[index] = child;\n index = childIndex;\n }\n}\nclass SpanCursor {\n constructor(sets, skip, minPoint, filterPoint = ()=>true\n ){\n this.minPoint = minPoint;\n this.filterPoint = filterPoint;\n this.active = [];\n this.activeTo = [];\n this.activeRank = [];\n this.minActive = -1;\n // A currently active point range, if any\n this.point = null;\n this.pointFrom = 0;\n this.pointRank = 0;\n this.to = -1000000000 /* Far */ ;\n this.endSide = 0;\n this.openStart = -1;\n this.cursor = HeapCursor.from(sets, skip, minPoint);\n }\n goto(pos, side = -1000000000 /* Far */ ) {\n this.cursor.goto(pos, side);\n this.active.length = this.activeTo.length = this.activeRank.length = 0;\n this.minActive = -1;\n this.to = pos;\n this.endSide = side;\n this.openStart = -1;\n this.next();\n return this;\n }\n forward(pos, side) {\n while(this.minActive > -1 && (this.activeTo[this.minActive] - pos || this.active[this.minActive].endSide - side) < 0)this.removeActive(this.minActive);\n this.cursor.forward(pos, side);\n }\n removeActive(index) {\n remove(this.active, index);\n remove(this.activeTo, index);\n remove(this.activeRank, index);\n this.minActive = findMinIndex(this.active, this.activeTo);\n }\n addActive(trackOpen) {\n let i = 0, { value , to , rank } = this.cursor;\n while(i < this.activeRank.length && this.activeRank[i] <= rank)i++;\n insert(this.active, i, value);\n insert(this.activeTo, i, to);\n insert(this.activeRank, i, rank);\n if (trackOpen) insert(trackOpen, i, this.cursor.from);\n this.minActive = findMinIndex(this.active, this.activeTo);\n }\n // After calling this, if `this.point` != null, the next range is a\n // point. Otherwise, it's a regular range, covered by `this.active`.\n next() {\n let from = this.to, wasPoint = this.point;\n this.point = null;\n let trackOpen = this.openStart < 0 ? [] : null, trackExtra = 0;\n for(;;){\n let a = this.minActive;\n if (a > -1 && (this.activeTo[a] - this.cursor.from || this.active[a].endSide - this.cursor.startSide) < 0) {\n if (this.activeTo[a] > from) {\n this.to = this.activeTo[a];\n this.endSide = this.active[a].endSide;\n break;\n }\n this.removeActive(a);\n if (trackOpen) remove(trackOpen, a);\n } else if (!this.cursor.value) {\n this.to = this.endSide = 1000000000 /* Far */ ;\n break;\n } else if (this.cursor.from > from) {\n this.to = this.cursor.from;\n this.endSide = this.cursor.startSide;\n break;\n } else {\n let nextVal = this.cursor.value;\n if (!nextVal.point) {\n this.addActive(trackOpen);\n this.cursor.next();\n } else if (wasPoint && this.cursor.to == this.to && this.cursor.from < this.cursor.to) // Ignore any non-empty points that end precisely at the end of the prev point\n this.cursor.next();\n else if (!this.filterPoint(this.cursor.from, this.cursor.to, this.cursor.value, this.cursor.rank)) this.cursor.next();\n else {\n this.point = nextVal;\n this.pointFrom = this.cursor.from;\n this.pointRank = this.cursor.rank;\n this.to = this.cursor.to;\n this.endSide = nextVal.endSide;\n if (this.cursor.from < from) trackExtra = 1;\n this.cursor.next();\n if (this.to > from) this.forward(this.to, this.endSide);\n break;\n }\n }\n }\n if (trackOpen) {\n let openStart = 0;\n while(openStart < trackOpen.length && trackOpen[openStart] < from)openStart++;\n this.openStart = openStart + trackExtra;\n }\n }\n activeForPoint(to) {\n if (!this.active.length) return this.active;\n let active = [];\n for(let i = this.active.length - 1; i >= 0; i--){\n if (this.activeRank[i] < this.pointRank) break;\n if (this.activeTo[i] > to || this.activeTo[i] == to && this.active[i].endSide >= this.point.endSide) active.push(this.active[i]);\n }\n return active.reverse();\n }\n openEnd(to) {\n let open = 0;\n for(let i = this.activeTo.length - 1; i >= 0 && this.activeTo[i] > to; i--)open++;\n return open;\n }\n}\nfunction compare(a, startA, b, startB, length, comparator) {\n a.goto(startA);\n b.goto(startB);\n let endB = startB + length;\n let pos = startB, dPos = startB - startA;\n for(;;){\n let diff = a.to + dPos - b.to || a.endSide - b.endSide;\n let end = diff < 0 ? a.to + dPos : b.to, clipEnd = Math.min(end, endB);\n if (a.point || b.point) {\n if (!(a.point && b.point && (a.point == b.point || a.point.eq(b.point)) && sameValues(a.activeForPoint(a.to + dPos), b.activeForPoint(b.to)))) comparator.comparePoint(pos, clipEnd, a.point, b.point);\n } else if (clipEnd > pos && !sameValues(a.active, b.active)) comparator.compareRange(pos, clipEnd, a.active, b.active);\n if (end > endB) break;\n pos = end;\n if (diff <= 0) a.next();\n if (diff >= 0) b.next();\n }\n}\nfunction sameValues(a, b) {\n if (a.length != b.length) return false;\n for(let i = 0; i < a.length; i++)if (a[i] != b[i] && !a[i].eq(b[i])) return false;\n return true;\n}\nfunction remove(array, index) {\n for(let i = index, e = array.length - 1; i < e; i++)array[i] = array[i + 1];\n array.pop();\n}\nfunction insert(array, index, value) {\n for(let i = array.length - 1; i >= index; i--)array[i + 1] = array[i];\n array[index] = value;\n}\nfunction findMinIndex(value, array) {\n let found = -1, foundPos = 1000000000 /* Far */ ;\n for(let i = 0; i < array.length; i++)if ((array[i] - foundPos || value[i].endSide - value[found].endSide) < 0) {\n found = i;\n foundPos = array[i];\n }\n return found;\n}\n\n},{\"@codemirror/state\":\"e6FBl\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"922Xs\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"base\", ()=>base\n);\nparcelHelpers.export(exports, \"shift\", ()=>shift\n);\nparcelHelpers.export(exports, \"keyName\", ()=>keyName\n);\nvar base = {\n 8: \"Backspace\",\n 9: \"Tab\",\n 10: \"Enter\",\n 12: \"NumLock\",\n 13: \"Enter\",\n 16: \"Shift\",\n 17: \"Control\",\n 18: \"Alt\",\n 20: \"CapsLock\",\n 27: \"Escape\",\n 32: \" \",\n 33: \"PageUp\",\n 34: \"PageDown\",\n 35: \"End\",\n 36: \"Home\",\n 37: \"ArrowLeft\",\n 38: \"ArrowUp\",\n 39: \"ArrowRight\",\n 40: \"ArrowDown\",\n 44: \"PrintScreen\",\n 45: \"Insert\",\n 46: \"Delete\",\n 59: \";\",\n 61: \"=\",\n 91: \"Meta\",\n 92: \"Meta\",\n 106: \"*\",\n 107: \"+\",\n 108: \",\",\n 109: \"-\",\n 110: \".\",\n 111: \"/\",\n 144: \"NumLock\",\n 145: \"ScrollLock\",\n 160: \"Shift\",\n 161: \"Shift\",\n 162: \"Control\",\n 163: \"Control\",\n 164: \"Alt\",\n 165: \"Alt\",\n 173: \"-\",\n 186: \";\",\n 187: \"=\",\n 188: \",\",\n 189: \"-\",\n 190: \".\",\n 191: \"/\",\n 192: \"`\",\n 219: \"[\",\n 220: \"\\\\\",\n 221: \"]\",\n 222: \"'\",\n 229: \"q\"\n};\nvar shift = {\n 48: \")\",\n 49: \"!\",\n 50: \"@\",\n 51: \"#\",\n 52: \"$\",\n 53: \"%\",\n 54: \"^\",\n 55: \"&\",\n 56: \"*\",\n 57: \"(\",\n 59: \":\",\n 61: \"+\",\n 173: \"_\",\n 186: \":\",\n 187: \"+\",\n 188: \"<\",\n 189: \"_\",\n 190: \">\",\n 191: \"?\",\n 192: \"~\",\n 219: \"{\",\n 220: \"|\",\n 221: \"}\",\n 222: \"\\\"\",\n 229: \"Q\"\n};\nvar chrome = typeof navigator != \"undefined\" && /Chrome\\/(\\d+)/.exec(navigator.userAgent);\nvar safari = typeof navigator != \"undefined\" && /Apple Computer/.test(navigator.vendor);\nvar gecko = typeof navigator != \"undefined\" && /Gecko\\/\\d+/.test(navigator.userAgent);\nvar mac = typeof navigator != \"undefined\" && /Mac/.test(navigator.platform);\nvar ie = typeof navigator != \"undefined\" && /MSIE \\d|Trident\\/(?:[7-9]|\\d{2,})\\..*rv:(\\d+)/.exec(navigator.userAgent);\nvar brokenModifierNames = chrome && (mac || +chrome[1] < 57) || gecko && mac;\n// Fill in the digit keys\nfor(var i = 0; i < 10; i++)base[48 + i] = base[96 + i] = String(i);\n// The function keys\nfor(var i = 1; i <= 24; i++)base[i + 111] = \"F\" + i;\n// And the alphabetic keys\nfor(var i = 65; i <= 90; i++){\n base[i] = String.fromCharCode(i + 32);\n shift[i] = String.fromCharCode(i);\n}\n// For each code that doesn't have a shift-equivalent, copy the base name\nfor(var code in base)if (!shift.hasOwnProperty(code)) shift[code] = base[code];\nfunction keyName(event) {\n // Don't trust event.key in Chrome when there are modifiers until\n // they fix https://bugs.chromium.org/p/chromium/issues/detail?id=633838\n var ignoreKey = brokenModifierNames && (event.ctrlKey || event.altKey || event.metaKey) || (safari || ie) && event.shiftKey && event.key && event.key.length == 1;\n var name = !ignoreKey && event.key || (event.shiftKey ? shift : base)[event.keyCode] || event.key || \"Unidentified\";\n // Edge sometimes produces wrong names (Issue #3)\n if (name == \"Esc\") name = \"Escape\";\n if (name == \"Del\") name = \"Delete\";\n // https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/8860571/\n if (name == \"Left\") name = \"ArrowLeft\";\n if (name == \"Up\") name = \"ArrowUp\";\n if (name == \"Right\") name = \"ArrowRight\";\n if (name == \"Down\") name = \"ArrowDown\";\n return name;\n}\n\n},{\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"ky3DW\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"closeHoverTooltips\", ()=>closeHoverTooltips\n);\nparcelHelpers.export(exports, \"getTooltip\", ()=>getTooltip\n);\nparcelHelpers.export(exports, \"hasHoverTooltips\", ()=>hasHoverTooltips\n);\nparcelHelpers.export(exports, \"hoverTooltip\", ()=>hoverTooltip\n);\nparcelHelpers.export(exports, \"repositionTooltips\", ()=>repositionTooltips\n);\nparcelHelpers.export(exports, \"showTooltip\", ()=>showTooltip\n);\nparcelHelpers.export(exports, \"tooltips\", ()=>tooltips\n);\nvar _view = require(\"@codemirror/view\");\nvar _state = require(\"@codemirror/state\");\nconst ios = typeof navigator != \"undefined\" && !/*@__PURE__*/ /Edge\\/(\\d+)/.exec(navigator.userAgent) && /*@__PURE__*/ /Apple Computer/.test(navigator.vendor) && /*@__PURE__*/ (/Mobile\\/\\w+/.test(navigator.userAgent) || navigator.maxTouchPoints > 2);\nconst Outside = \"-10000px\";\nclass TooltipViewManager {\n constructor(view, facet, createTooltipView){\n this.facet = facet;\n this.createTooltipView = createTooltipView;\n this.input = view.state.facet(facet);\n this.tooltips = this.input.filter((t)=>t\n );\n this.tooltipViews = this.tooltips.map(createTooltipView);\n }\n update(update) {\n let input = update.state.facet(this.facet);\n let tooltips1 = input.filter((x)=>x\n );\n if (input === this.input) {\n for (let t of this.tooltipViews)if (t.update) t.update(update);\n return false;\n }\n let tooltipViews = [];\n for(let i = 0; i < tooltips1.length; i++){\n let tip = tooltips1[i], known = -1;\n if (!tip) continue;\n for(let i = 0; i < this.tooltips.length; i++){\n let other = this.tooltips[i];\n if (other && other.create == tip.create) known = i;\n }\n if (known < 0) tooltipViews[i] = this.createTooltipView(tip);\n else {\n let tooltipView = tooltipViews[i] = this.tooltipViews[known];\n if (tooltipView.update) tooltipView.update(update);\n }\n }\n for (let t of this.tooltipViews)if (tooltipViews.indexOf(t) < 0) t.dom.remove();\n this.input = input;\n this.tooltips = tooltips1;\n this.tooltipViews = tooltipViews;\n return true;\n }\n}\n/**\nReturn an extension that configures tooltip behavior.\n*/ function tooltips(config = {\n}) {\n return tooltipConfig.of(config);\n}\nfunction windowSpace() {\n return {\n top: 0,\n left: 0,\n bottom: innerHeight,\n right: innerWidth\n };\n}\nconst tooltipConfig = /*@__PURE__*/ _state.Facet.define({\n combine: (values)=>{\n var _a, _b, _c;\n return {\n position: ios ? \"absolute\" : ((_a = values.find((conf)=>conf.position\n )) === null || _a === void 0 ? void 0 : _a.position) || \"fixed\",\n parent: ((_b = values.find((conf)=>conf.parent\n )) === null || _b === void 0 ? void 0 : _b.parent) || null,\n tooltipSpace: ((_c = values.find((conf)=>conf.tooltipSpace\n )) === null || _c === void 0 ? void 0 : _c.tooltipSpace) || windowSpace\n };\n }\n});\nconst tooltipPlugin = /*@__PURE__*/ _view.ViewPlugin.fromClass(class {\n constructor(view){\n var _a;\n this.view = view;\n this.inView = true;\n this.lastTransaction = 0;\n this.measureTimeout = -1;\n let config = view.state.facet(tooltipConfig);\n this.position = config.position;\n this.parent = config.parent;\n this.classes = view.themeClasses;\n this.createContainer();\n this.measureReq = {\n read: this.readMeasure.bind(this),\n write: this.writeMeasure.bind(this),\n key: this\n };\n this.manager = new TooltipViewManager(view, showTooltip, (t)=>this.createTooltip(t)\n );\n this.intersectionObserver = typeof IntersectionObserver == \"function\" ? new IntersectionObserver((entries)=>{\n if (Date.now() > this.lastTransaction - 50 && entries.length > 0 && entries[entries.length - 1].intersectionRatio < 1) this.measureSoon();\n }, {\n threshold: [\n 1\n ]\n }) : null;\n this.observeIntersection();\n (_a = view.dom.ownerDocument.defaultView) === null || _a === void 0 || _a.addEventListener(\"resize\", this.measureSoon = this.measureSoon.bind(this));\n this.maybeMeasure();\n }\n createContainer() {\n if (this.parent) {\n this.container = document.createElement(\"div\");\n this.container.style.position = \"relative\";\n this.container.className = this.view.themeClasses;\n this.parent.appendChild(this.container);\n } else this.container = this.view.dom;\n }\n observeIntersection() {\n if (this.intersectionObserver) {\n this.intersectionObserver.disconnect();\n for (let tooltip of this.manager.tooltipViews)this.intersectionObserver.observe(tooltip.dom);\n }\n }\n measureSoon() {\n if (this.measureTimeout < 0) this.measureTimeout = setTimeout(()=>{\n this.measureTimeout = -1;\n this.maybeMeasure();\n }, 50);\n }\n update(update) {\n if (update.transactions.length) this.lastTransaction = Date.now();\n let updated = this.manager.update(update);\n if (updated) this.observeIntersection();\n let shouldMeasure = updated || update.geometryChanged;\n let newConfig = update.state.facet(tooltipConfig);\n if (newConfig.position != this.position) {\n this.position = newConfig.position;\n for (let t of this.manager.tooltipViews)t.dom.style.position = this.position;\n shouldMeasure = true;\n }\n if (newConfig.parent != this.parent) {\n if (this.parent) this.container.remove();\n this.parent = newConfig.parent;\n this.createContainer();\n for (let t of this.manager.tooltipViews)this.container.appendChild(t.dom);\n shouldMeasure = true;\n } else if (this.parent && this.view.themeClasses != this.classes) this.classes = this.container.className = this.view.themeClasses;\n if (shouldMeasure) this.maybeMeasure();\n }\n createTooltip(tooltip) {\n let tooltipView = tooltip.create(this.view);\n tooltipView.dom.classList.add(\"cm-tooltip\");\n if (tooltip.arrow && !tooltipView.dom.querySelector(\"cm-tooltip > cm-tooltip-arrow\")) {\n let arrow = document.createElement(\"div\");\n arrow.className = \"cm-tooltip-arrow\";\n tooltipView.dom.appendChild(arrow);\n }\n tooltipView.dom.style.position = this.position;\n tooltipView.dom.style.top = Outside;\n this.container.appendChild(tooltipView.dom);\n if (tooltipView.mount) tooltipView.mount(this.view);\n return tooltipView;\n }\n destroy() {\n var _a, _b;\n (_a = this.view.dom.ownerDocument.defaultView) === null || _a === void 0 || _a.removeEventListener(\"resize\", this.measureSoon);\n for (let { dom } of this.manager.tooltipViews)dom.remove();\n (_b = this.intersectionObserver) === null || _b === void 0 || _b.disconnect();\n clearTimeout(this.measureTimeout);\n }\n readMeasure() {\n let editor = this.view.dom.getBoundingClientRect();\n return {\n editor,\n parent: this.parent ? this.container.getBoundingClientRect() : editor,\n pos: this.manager.tooltips.map((t)=>this.view.coordsAtPos(t.pos)\n ),\n size: this.manager.tooltipViews.map(({ dom })=>dom.getBoundingClientRect()\n ),\n space: this.view.state.facet(tooltipConfig).tooltipSpace(this.view)\n };\n }\n writeMeasure(measured) {\n let { editor , space } = measured;\n let others = [];\n for(let i = 0; i < this.manager.tooltips.length; i++){\n let tooltip = this.manager.tooltips[i], tView = this.manager.tooltipViews[i], { dom } = tView;\n let pos = measured.pos[i], size = measured.size[i];\n // Hide tooltips that are outside of the editor.\n if (!pos || pos.bottom <= Math.max(editor.top, space.top) || pos.top >= Math.min(editor.bottom, space.bottom) || pos.right <= Math.max(editor.left, space.left) || pos.left >= Math.min(editor.right, space.right)) {\n dom.style.top = Outside;\n continue;\n }\n let arrow = tooltip.arrow ? tView.dom.querySelector(\".cm-tooltip-arrow\") : null;\n let arrowHeight = arrow ? 7 /* Size */ : 0;\n let width = size.right - size.left, height = size.bottom - size.top;\n let offset = tView.offset || noOffset, ltr = this.view.textDirection == _view.Direction.LTR;\n let left = size.width > space.right - space.left ? ltr ? space.left : space.right - size.width : ltr ? Math.min(pos.left - (arrow ? 14 /* Offset */ : 0) + offset.x, space.right - width) : Math.max(space.left, pos.left - width + (arrow ? 14 /* Offset */ : 0) - offset.x);\n let above = !!tooltip.above;\n if (!tooltip.strictSide && (above ? pos.top - (size.bottom - size.top) - offset.y < space.top : pos.bottom + (size.bottom - size.top) + offset.y > space.bottom) && above == space.bottom - pos.bottom > pos.top - space.top) above = !above;\n let top = above ? pos.top - height - arrowHeight - offset.y : pos.bottom + arrowHeight + offset.y;\n let right = left + width;\n if (tView.overlap !== true) {\n for (let r of others)if (r.left < right && r.right > left && r.top < top + height && r.bottom > top) top = above ? r.top - height - 2 - arrowHeight : r.bottom + arrowHeight + 2;\n }\n if (this.position == \"absolute\") {\n dom.style.top = top - measured.parent.top + \"px\";\n dom.style.left = left - measured.parent.left + \"px\";\n } else {\n dom.style.top = top + \"px\";\n dom.style.left = left + \"px\";\n }\n if (arrow) arrow.style.left = `${pos.left + (ltr ? offset.x : -offset.x) - (left + 14 /* Offset */ - 7 /* Size */ )}px`;\n if (tView.overlap !== true) others.push({\n left,\n top,\n right,\n bottom: top + height\n });\n dom.classList.toggle(\"cm-tooltip-above\", above);\n dom.classList.toggle(\"cm-tooltip-below\", !above);\n if (tView.positioned) tView.positioned();\n }\n }\n maybeMeasure() {\n if (this.manager.tooltips.length) {\n if (this.view.inView) this.view.requestMeasure(this.measureReq);\n if (this.inView != this.view.inView) {\n this.inView = this.view.inView;\n if (!this.inView) for (let tv of this.manager.tooltipViews)tv.dom.style.top = Outside;\n }\n }\n }\n}, {\n eventHandlers: {\n scroll () {\n this.maybeMeasure();\n }\n }\n});\nconst baseTheme = /*@__PURE__*/ _view.EditorView.baseTheme({\n \".cm-tooltip\": {\n zIndex: 100\n },\n \"&light .cm-tooltip\": {\n border: \"1px solid #bbb\",\n backgroundColor: \"#f5f5f5\"\n },\n \"&light .cm-tooltip-section:not(:first-child)\": {\n borderTop: \"1px solid #bbb\"\n },\n \"&dark .cm-tooltip\": {\n backgroundColor: \"#333338\",\n color: \"white\"\n },\n \".cm-tooltip-arrow\": {\n height: `${7 /* Size */ }px`,\n width: `${14}px`,\n position: \"absolute\",\n zIndex: -1,\n overflow: \"hidden\",\n \"&:before, &:after\": {\n content: \"''\",\n position: \"absolute\",\n width: 0,\n height: 0,\n borderLeft: `${7 /* Size */ }px solid transparent`,\n borderRight: `${7 /* Size */ }px solid transparent`\n },\n \".cm-tooltip-above &\": {\n bottom: `-${7 /* Size */ }px`,\n \"&:before\": {\n borderTop: `${7 /* Size */ }px solid #bbb`\n },\n \"&:after\": {\n borderTop: `${7 /* Size */ }px solid #f5f5f5`,\n bottom: \"1px\"\n }\n },\n \".cm-tooltip-below &\": {\n top: `-${7 /* Size */ }px`,\n \"&:before\": {\n borderBottom: `${7 /* Size */ }px solid #bbb`\n },\n \"&:after\": {\n borderBottom: `${7 /* Size */ }px solid #f5f5f5`,\n top: \"1px\"\n }\n }\n },\n \"&dark .cm-tooltip .cm-tooltip-arrow\": {\n \"&:before\": {\n borderTopColor: \"#333338\",\n borderBottomColor: \"#333338\"\n },\n \"&:after\": {\n borderTopColor: \"transparent\",\n borderBottomColor: \"transparent\"\n }\n }\n});\nconst noOffset = {\n x: 0,\n y: 0\n};\n/**\nBehavior by which an extension can provide a tooltip to be shown.\n*/ const showTooltip = /*@__PURE__*/ _state.Facet.define({\n enables: [\n tooltipPlugin,\n baseTheme\n ]\n});\nconst showHoverTooltip = /*@__PURE__*/ _state.Facet.define();\nclass HoverTooltipHost {\n constructor(view){\n this.view = view;\n this.mounted = false;\n this.dom = document.createElement(\"div\");\n this.dom.classList.add(\"cm-tooltip-hover\");\n this.manager = new TooltipViewManager(view, showHoverTooltip, (t)=>this.createHostedView(t)\n );\n }\n // Needs to be static so that host tooltip instances always match\n static create(view) {\n return new HoverTooltipHost(view);\n }\n createHostedView(tooltip) {\n let hostedView = tooltip.create(this.view);\n hostedView.dom.classList.add(\"cm-tooltip-section\");\n this.dom.appendChild(hostedView.dom);\n if (this.mounted && hostedView.mount) hostedView.mount(this.view);\n return hostedView;\n }\n mount(view) {\n for (let hostedView of this.manager.tooltipViews)if (hostedView.mount) hostedView.mount(view);\n this.mounted = true;\n }\n positioned() {\n for (let hostedView of this.manager.tooltipViews)if (hostedView.positioned) hostedView.positioned();\n }\n update(update) {\n this.manager.update(update);\n }\n}\nconst showHoverTooltipHost = /*@__PURE__*/ showTooltip.compute([\n showHoverTooltip\n], (state)=>{\n let tooltips2 = state.facet(showHoverTooltip).filter((t)=>t\n );\n if (tooltips2.length === 0) return null;\n return {\n pos: Math.min(...tooltips2.map((t)=>t.pos\n )),\n end: Math.max(...tooltips2.filter((t)=>t.end != null\n ).map((t)=>t.end\n )),\n create: HoverTooltipHost.create,\n above: tooltips2[0].above,\n arrow: tooltips2.some((t)=>t.arrow\n )\n };\n});\nclass HoverPlugin {\n constructor(view, source, field, setHover, hoverTime){\n this.view = view;\n this.source = source;\n this.field = field;\n this.setHover = setHover;\n this.hoverTime = hoverTime;\n this.hoverTimeout = -1;\n this.restartTimeout = -1;\n this.pending = null;\n this.lastMove = {\n x: 0,\n y: 0,\n target: view.dom,\n time: 0\n };\n this.checkHover = this.checkHover.bind(this);\n view.dom.addEventListener(\"mouseleave\", this.mouseleave = this.mouseleave.bind(this));\n view.dom.addEventListener(\"mousemove\", this.mousemove = this.mousemove.bind(this));\n }\n update() {\n if (this.pending) {\n this.pending = null;\n clearTimeout(this.restartTimeout);\n this.restartTimeout = setTimeout(()=>this.startHover()\n , 20);\n }\n }\n get active() {\n return this.view.state.field(this.field);\n }\n checkHover() {\n this.hoverTimeout = -1;\n if (this.active) return;\n let hovered = Date.now() - this.lastMove.time;\n if (hovered < this.hoverTime) this.hoverTimeout = setTimeout(this.checkHover, this.hoverTime - hovered);\n else this.startHover();\n }\n startHover() {\n var _a;\n clearTimeout(this.restartTimeout);\n let { lastMove } = this;\n let pos = this.view.contentDOM.contains(lastMove.target) ? this.view.posAtCoords(lastMove) : null;\n if (pos == null) return;\n let posCoords = this.view.coordsAtPos(pos);\n if (posCoords == null || lastMove.y < posCoords.top || lastMove.y > posCoords.bottom || lastMove.x < posCoords.left - this.view.defaultCharacterWidth || lastMove.x > posCoords.right + this.view.defaultCharacterWidth) return;\n let bidi = this.view.bidiSpans(this.view.state.doc.lineAt(pos)).find((s)=>s.from <= pos && s.to >= pos\n );\n let rtl = bidi && bidi.dir == _view.Direction.RTL ? -1 : 1;\n let open = this.source(this.view, pos, lastMove.x < posCoords.left ? -rtl : rtl);\n if ((_a = open) === null || _a === void 0 ? void 0 : _a.then) {\n let pending = this.pending = {\n pos\n };\n open.then((result)=>{\n if (this.pending == pending) {\n this.pending = null;\n if (result) this.view.dispatch({\n effects: this.setHover.of(result)\n });\n }\n }, (e)=>_view.logException(this.view.state, e, \"hover tooltip\")\n );\n } else if (open) this.view.dispatch({\n effects: this.setHover.of(open)\n });\n }\n mousemove(event) {\n var _a;\n this.lastMove = {\n x: event.clientX,\n y: event.clientY,\n target: event.target,\n time: Date.now()\n };\n if (this.hoverTimeout < 0) this.hoverTimeout = setTimeout(this.checkHover, this.hoverTime);\n let tooltip = this.active;\n if (tooltip && !isInTooltip(this.lastMove.target) || this.pending) {\n let { pos } = tooltip || this.pending, end = (_a = tooltip === null || tooltip === void 0 ? void 0 : tooltip.end) !== null && _a !== void 0 ? _a : pos;\n if (pos == end ? this.view.posAtCoords(this.lastMove) != pos : !isOverRange(this.view, pos, end, event.clientX, event.clientY, 6 /* MaxDist */ )) {\n this.view.dispatch({\n effects: this.setHover.of(null)\n });\n this.pending = null;\n }\n }\n }\n mouseleave() {\n clearTimeout(this.hoverTimeout);\n this.hoverTimeout = -1;\n if (this.active) this.view.dispatch({\n effects: this.setHover.of(null)\n });\n }\n destroy() {\n clearTimeout(this.hoverTimeout);\n this.view.dom.removeEventListener(\"mouseleave\", this.mouseleave);\n this.view.dom.removeEventListener(\"mousemove\", this.mousemove);\n }\n}\nfunction isInTooltip(elt) {\n for(let cur = elt; cur; cur = cur.parentNode)if (cur.nodeType == 1 && cur.classList.contains(\"cm-tooltip\")) return true;\n return false;\n}\nfunction isOverRange(view, from, to, x, y, margin) {\n let range = document.createRange();\n let fromDOM = view.domAtPos(from), toDOM = view.domAtPos(to);\n range.setEnd(toDOM.node, toDOM.offset);\n range.setStart(fromDOM.node, fromDOM.offset);\n let rects = range.getClientRects();\n range.detach();\n for(let i = 0; i < rects.length; i++){\n let rect = rects[i];\n let dist = Math.max(rect.top - y, y - rect.bottom, rect.left - x, x - rect.right);\n if (dist <= margin) return true;\n }\n return false;\n}\n/**\nEnable a hover tooltip, which shows up when the pointer hovers\nover ranges of text. The callback is called when the mouse hovers\nover the document text. It should, if there is a tooltip\nassociated with position `pos` return the tooltip description\n(either directly or in a promise). The `side` argument indicates\non which side of the position the pointer is\u2014it will be -1 if the\npointer is before the position, 1 if after the position.\n\nNote that all hover tooltips are hosted within a single tooltip\ncontainer element. This allows multiple tooltips over the same\nrange to be \"merged\" together without overlapping.\n*/ function hoverTooltip(source, options = {\n}) {\n let setHover = _state.StateEffect.define();\n let hoverState = _state.StateField.define({\n create () {\n return null;\n },\n update (value, tr) {\n if (value && options.hideOnChange && (tr.docChanged || tr.selection)) return null;\n for (let effect of tr.effects){\n if (effect.is(setHover)) return effect.value;\n if (effect.is(closeHoverTooltipEffect)) return null;\n }\n if (value && tr.docChanged) {\n let newPos = tr.changes.mapPos(value.pos, -1, _state.MapMode.TrackDel);\n if (newPos == null) return null;\n let copy = Object.assign(Object.create(null), value);\n copy.pos = newPos;\n if (value.end != null) copy.end = tr.changes.mapPos(value.end);\n return copy;\n }\n return value;\n },\n provide: (f)=>showHoverTooltip.from(f)\n });\n let hoverTime = options.hoverTime || 600 /* Time */ ;\n return [\n hoverState,\n _view.ViewPlugin.define((view)=>new HoverPlugin(view, source, hoverState, setHover, hoverTime)\n ),\n showHoverTooltipHost\n ];\n}\n/**\nGet the active tooltip view for a given tooltip, if available.\n*/ function getTooltip(view, tooltip) {\n let plugin = view.plugin(tooltipPlugin);\n if (!plugin) return null;\n let found = plugin.manager.tooltips.indexOf(tooltip);\n return found < 0 ? null : plugin.manager.tooltipViews[found];\n}\n/**\nReturns true if any hover tooltips are currently active.\n*/ function hasHoverTooltips(state) {\n return state.facet(showHoverTooltip).some((x)=>x\n );\n}\nconst closeHoverTooltipEffect = /*@__PURE__*/ _state.StateEffect.define();\n/**\nTransaction effect that closes all hover tooltips.\n*/ const closeHoverTooltips = /*@__PURE__*/ closeHoverTooltipEffect.of(null);\n/**\nTell the tooltip extension to recompute the position of the active\ntooltips. This can be useful when something happens (such as a\nre-positioning or CSS change affecting the editor) that could\ninvalidate the existing tooltip positions.\n*/ function repositionTooltips(view) {\n var _a;\n (_a = view.plugin(tooltipPlugin)) === null || _a === void 0 || _a.maybeMeasure();\n}\n\n},{\"@codemirror/view\":\"JuP5Z\",\"@codemirror/state\":\"e6FBl\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"70QHL\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"IndentContext\", ()=>IndentContext\n);\nparcelHelpers.export(exports, \"LRLanguage\", ()=>LRLanguage\n);\nparcelHelpers.export(exports, \"Language\", ()=>Language\n);\nparcelHelpers.export(exports, \"LanguageDescription\", ()=>LanguageDescription\n);\nparcelHelpers.export(exports, \"LanguageSupport\", ()=>LanguageSupport\n);\nparcelHelpers.export(exports, \"ParseContext\", ()=>ParseContext\n);\nparcelHelpers.export(exports, \"TreeIndentContext\", ()=>TreeIndentContext\n);\nparcelHelpers.export(exports, \"continuedIndent\", ()=>continuedIndent\n);\nparcelHelpers.export(exports, \"defineLanguageFacet\", ()=>defineLanguageFacet\n);\nparcelHelpers.export(exports, \"delimitedIndent\", ()=>delimitedIndent\n);\nparcelHelpers.export(exports, \"ensureSyntaxTree\", ()=>ensureSyntaxTree\n);\nparcelHelpers.export(exports, \"flatIndent\", ()=>flatIndent\n);\nparcelHelpers.export(exports, \"foldInside\", ()=>foldInside\n);\nparcelHelpers.export(exports, \"foldNodeProp\", ()=>foldNodeProp\n);\nparcelHelpers.export(exports, \"foldService\", ()=>foldService\n);\nparcelHelpers.export(exports, \"foldable\", ()=>foldable\n);\nparcelHelpers.export(exports, \"getIndentUnit\", ()=>getIndentUnit\n);\nparcelHelpers.export(exports, \"getIndentation\", ()=>getIndentation\n);\nparcelHelpers.export(exports, \"indentNodeProp\", ()=>indentNodeProp\n);\nparcelHelpers.export(exports, \"indentOnInput\", ()=>indentOnInput\n);\nparcelHelpers.export(exports, \"indentService\", ()=>indentService\n);\nparcelHelpers.export(exports, \"indentString\", ()=>indentString\n);\nparcelHelpers.export(exports, \"indentUnit\", ()=>indentUnit\n);\nparcelHelpers.export(exports, \"language\", ()=>language\n);\nparcelHelpers.export(exports, \"languageDataProp\", ()=>languageDataProp\n);\nparcelHelpers.export(exports, \"syntaxParserRunning\", ()=>syntaxParserRunning\n);\nparcelHelpers.export(exports, \"syntaxTree\", ()=>syntaxTree\n);\nparcelHelpers.export(exports, \"syntaxTreeAvailable\", ()=>syntaxTreeAvailable\n);\nvar _common = require(\"@lezer/common\");\nvar _state = require(\"@codemirror/state\");\nvar _view = require(\"@codemirror/view\");\nvar _text = require(\"@codemirror/text\");\n/**\nNode prop stored in a grammar's top syntax node to provide the\nfacet that stores language data for that language.\n*/ const languageDataProp = /*@__PURE__*/ new _common.NodeProp();\n/**\nHelper function to define a facet (to be added to the top syntax\nnode(s) for a language via\n[`languageDataProp`](https://codemirror.net/6/docs/ref/#language.languageDataProp)), that will be\nused to associate language data with the language. You\nprobably only need this when subclassing\n[`Language`](https://codemirror.net/6/docs/ref/#language.Language).\n*/ function defineLanguageFacet(baseData) {\n return _state.Facet.define({\n combine: baseData ? (values)=>values.concat(baseData)\n : undefined\n });\n}\n/**\nA language object manages parsing and per-language\n[metadata](https://codemirror.net/6/docs/ref/#state.EditorState.languageDataAt). Parse data is\nmanaged as a [Lezer](https://lezer.codemirror.net) tree. You'll\nwant to subclass this class for custom parsers, or use the\n[`LRLanguage`](https://codemirror.net/6/docs/ref/#language.LRLanguage) or\n[`StreamLanguage`](https://codemirror.net/6/docs/ref/#stream-parser.StreamLanguage) abstractions for\n[Lezer](https://lezer.codemirror.net/) or stream parsers.\n*/ class Language {\n /**\n Construct a language object. You usually don't need to invoke\n this directly. But when you do, make sure you use\n [`defineLanguageFacet`](https://codemirror.net/6/docs/ref/#language.defineLanguageFacet) to create\n the first argument.\n */ constructor(/**\n The [language data](https://codemirror.net/6/docs/ref/#state.EditorState.languageDataAt) data\n facet used for this language.\n */ data, parser, /**\n The node type of the top node of trees produced by this parser.\n */ topNode, extraExtensions = []){\n this.data = data;\n this.topNode = topNode;\n // Kludge to define EditorState.tree as a debugging helper,\n // without the EditorState package actually knowing about\n // languages and lezer trees.\n if (!_state.EditorState.prototype.hasOwnProperty(\"tree\")) Object.defineProperty(_state.EditorState.prototype, \"tree\", {\n get () {\n return syntaxTree(this);\n }\n });\n this.parser = parser;\n this.extension = [\n language.of(this),\n _state.EditorState.languageData.of((state, pos, side)=>state.facet(languageDataFacetAt(state, pos, side))\n )\n ].concat(extraExtensions);\n }\n /**\n Query whether this language is active at the given position.\n */ isActiveAt(state, pos, side = -1) {\n return languageDataFacetAt(state, pos, side) == this.data;\n }\n /**\n Find the document regions that were parsed using this language.\n The returned regions will _include_ any nested languages rooted\n in this language, when those exist.\n */ findRegions(state) {\n let lang = state.facet(language);\n if ((lang === null || lang === void 0 ? void 0 : lang.data) == this.data) return [\n {\n from: 0,\n to: state.doc.length\n }\n ];\n if (!lang || !lang.allowsNesting) return [];\n let result = [];\n let explore = (tree, from)=>{\n if (tree.prop(languageDataProp) == this.data) {\n result.push({\n from,\n to: from + tree.length\n });\n return;\n }\n let mount = tree.prop(_common.NodeProp.mounted);\n if (mount) {\n if (mount.tree.prop(languageDataProp) == this.data) {\n if (mount.overlay) for (let r of mount.overlay)result.push({\n from: r.from + from,\n to: r.to + from\n });\n else result.push({\n from: from,\n to: from + tree.length\n });\n return;\n } else if (mount.overlay) {\n let size = result.length;\n explore(mount.tree, mount.overlay[0].from + from);\n if (result.length > size) return;\n }\n }\n for(let i = 0; i < tree.children.length; i++){\n let ch = tree.children[i];\n if (ch instanceof _common.Tree) explore(ch, tree.positions[i] + from);\n }\n };\n explore(syntaxTree(state), 0);\n return result;\n }\n /**\n Indicates whether this language allows nested languages. The\n default implementation returns true.\n */ get allowsNesting() {\n return true;\n }\n}\n/**\n@internal\n*/ Language.setState = /*@__PURE__*/ _state.StateEffect.define();\nfunction languageDataFacetAt(state, pos, side) {\n let topLang = state.facet(language);\n if (!topLang) return null;\n let facet = topLang.data;\n if (topLang.allowsNesting) for(let node = syntaxTree(state).topNode; node; node = node.enter(pos, side, true, false))facet = node.type.prop(languageDataProp) || facet;\n return facet;\n}\n/**\nA subclass of [`Language`](https://codemirror.net/6/docs/ref/#language.Language) for use with Lezer\n[LR parsers](https://lezer.codemirror.net/docs/ref#lr.LRParser)\nparsers.\n*/ class LRLanguage extends Language {\n constructor(data, parser){\n super(data, parser, parser.topNode);\n this.parser = parser;\n }\n /**\n Define a language from a parser.\n */ static define(spec) {\n let data = defineLanguageFacet(spec.languageData);\n return new LRLanguage(data, spec.parser.configure({\n props: [\n languageDataProp.add((type)=>type.isTop ? data : undefined\n )\n ]\n }));\n }\n /**\n Create a new instance of this language with a reconfigured\n version of its parser.\n */ configure(options) {\n return new LRLanguage(this.data, this.parser.configure(options));\n }\n get allowsNesting() {\n return this.parser.wrappers.length > 0;\n }\n}\n/**\nGet the syntax tree for a state, which is the current (possibly\nincomplete) parse tree of active [language](https://codemirror.net/6/docs/ref/#language.Language),\nor the empty tree if there is no language available.\n*/ function syntaxTree(state) {\n let field = state.field(Language.state, false);\n return field ? field.tree : _common.Tree.empty;\n}\n/**\nTry to get a parse tree that spans at least up to `upto`. The\nmethod will do at most `timeout` milliseconds of work to parse\nup to that point if the tree isn't already available.\n*/ function ensureSyntaxTree(state, upto, timeout = 50) {\n var _a;\n let parse = (_a = state.field(Language.state, false)) === null || _a === void 0 ? void 0 : _a.context;\n return !parse ? null : parse.isDone(upto) || parse.work(timeout, upto) ? parse.tree : null;\n}\n/**\nQueries whether there is a full syntax tree available up to the\ngiven document position. If there isn't, the background parse\nprocess _might_ still be working and update the tree further, but\nthere is no guarantee of that\u2014the parser will [stop\nworking](https://codemirror.net/6/docs/ref/#language.syntaxParserStopped) when it has spent a\ncertain amount of time or has moved beyond the visible viewport.\nAlways returns false if no language has been enabled.\n*/ function syntaxTreeAvailable(state, upto = state.doc.length) {\n var _a;\n return ((_a = state.field(Language.state, false)) === null || _a === void 0 ? void 0 : _a.context.isDone(upto)) || false;\n}\n/**\nTells you whether the language parser is planning to do more\nparsing work (in a `requestIdleCallback` pseudo-thread) or has\nstopped running, either because it parsed the entire document,\nbecause it spent too much time and was cut off, or because there\nis no language parser enabled.\n*/ function syntaxParserRunning(view) {\n var _a;\n return ((_a = view.plugin(parseWorker)) === null || _a === void 0 ? void 0 : _a.isWorking()) || false;\n}\n// Lezer-style Input object for a Text document.\nclass DocInput {\n constructor(doc, length = doc.length){\n this.doc = doc;\n this.length = length;\n this.cursorPos = 0;\n this.string = \"\";\n this.cursor = doc.iter();\n }\n syncTo(pos) {\n this.string = this.cursor.next(pos - this.cursorPos).value;\n this.cursorPos = pos + this.string.length;\n return this.cursorPos - this.string.length;\n }\n chunk(pos) {\n this.syncTo(pos);\n return this.string;\n }\n get lineChunks() {\n return true;\n }\n read(from, to) {\n let stringStart = this.cursorPos - this.string.length;\n if (from < stringStart || to >= this.cursorPos) return this.doc.sliceString(from, to);\n else return this.string.slice(from - stringStart, to - stringStart);\n }\n}\nlet currentContext = null;\n/**\nA parse context provided to parsers working on the editor content.\n*/ class ParseContext {\n /**\n @internal\n */ constructor(parser, /**\n The current editor state.\n */ state, /**\n Tree fragments that can be reused by incremental re-parses.\n */ fragments = [], /**\n @internal\n */ tree, treeLen, /**\n The current editor viewport (or some overapproximation\n thereof). Intended to be used for opportunistically avoiding\n work (in which case\n [`skipUntilInView`](https://codemirror.net/6/docs/ref/#language.ParseContext.skipUntilInView)\n should be called to make sure the parser is restarted when the\n skipped region becomes visible).\n */ viewport, /**\n @internal\n */ skipped, /**\n This is where skipping parsers can register a promise that,\n when resolved, will schedule a new parse. It is cleared when\n the parse worker picks up the promise. @internal\n */ scheduleOn){\n this.parser = parser;\n this.state = state;\n this.fragments = fragments;\n this.tree = tree;\n this.treeLen = treeLen;\n this.viewport = viewport;\n this.skipped = skipped;\n this.scheduleOn = scheduleOn;\n this.parse = null;\n /**\n @internal\n */ this.tempSkipped = [];\n }\n startParse() {\n return this.parser.startParse(new DocInput(this.state.doc), this.fragments);\n }\n /**\n @internal\n */ work(time, upto) {\n if (upto != null && upto >= this.state.doc.length) upto = undefined;\n if (this.tree != _common.Tree.empty && this.isDone(upto !== null && upto !== void 0 ? upto : this.state.doc.length)) {\n this.takeTree();\n return true;\n }\n return this.withContext(()=>{\n var _a;\n let endTime = Date.now() + time;\n if (!this.parse) this.parse = this.startParse();\n if (upto != null && (this.parse.stoppedAt == null || this.parse.stoppedAt > upto) && upto < this.state.doc.length) this.parse.stopAt(upto);\n for(;;){\n let done = this.parse.advance();\n if (done) {\n this.fragments = this.withoutTempSkipped(_common.TreeFragment.addTree(done, this.fragments, this.parse.stoppedAt != null));\n this.treeLen = (_a = this.parse.stoppedAt) !== null && _a !== void 0 ? _a : this.state.doc.length;\n this.tree = done;\n this.parse = null;\n if (this.treeLen < (upto !== null && upto !== void 0 ? upto : this.state.doc.length)) this.parse = this.startParse();\n else return true;\n }\n if (Date.now() > endTime) return false;\n }\n });\n }\n /**\n @internal\n */ takeTree() {\n let pos, tree;\n if (this.parse && (pos = this.parse.parsedPos) >= this.treeLen) {\n if (this.parse.stoppedAt == null || this.parse.stoppedAt > pos) this.parse.stopAt(pos);\n this.withContext(()=>{\n while(!(tree = this.parse.advance()));\n });\n this.treeLen = pos;\n this.tree = tree;\n this.fragments = this.withoutTempSkipped(_common.TreeFragment.addTree(this.tree, this.fragments, true));\n this.parse = null;\n }\n }\n withContext(f) {\n let prev = currentContext;\n currentContext = this;\n try {\n return f();\n } finally{\n currentContext = prev;\n }\n }\n withoutTempSkipped(fragments) {\n for(let r; r = this.tempSkipped.pop();)fragments = cutFragments(fragments, r.from, r.to);\n return fragments;\n }\n /**\n @internal\n */ changes(changes, newState) {\n let { fragments , tree , treeLen , viewport , skipped } = this;\n this.takeTree();\n if (!changes.empty) {\n let ranges = [];\n changes.iterChangedRanges((fromA, toA, fromB, toB)=>ranges.push({\n fromA,\n toA,\n fromB,\n toB\n })\n );\n fragments = _common.TreeFragment.applyChanges(fragments, ranges);\n tree = _common.Tree.empty;\n treeLen = 0;\n viewport = {\n from: changes.mapPos(viewport.from, -1),\n to: changes.mapPos(viewport.to, 1)\n };\n if (this.skipped.length) {\n skipped = [];\n for (let r of this.skipped){\n let from = changes.mapPos(r.from, 1), to = changes.mapPos(r.to, -1);\n if (from < to) skipped.push({\n from,\n to\n });\n }\n }\n }\n return new ParseContext(this.parser, newState, fragments, tree, treeLen, viewport, skipped, this.scheduleOn);\n }\n /**\n @internal\n */ updateViewport(viewport) {\n if (this.viewport.from == viewport.from && this.viewport.to == viewport.to) return false;\n this.viewport = viewport;\n let startLen = this.skipped.length;\n for(let i = 0; i < this.skipped.length; i++){\n let { from , to } = this.skipped[i];\n if (from < viewport.to && to > viewport.from) {\n this.fragments = cutFragments(this.fragments, from, to);\n this.skipped.splice(i--, 1);\n }\n }\n if (this.skipped.length >= startLen) return false;\n this.reset();\n return true;\n }\n /**\n @internal\n */ reset() {\n if (this.parse) {\n this.takeTree();\n this.parse = null;\n }\n }\n /**\n Notify the parse scheduler that the given region was skipped\n because it wasn't in view, and the parse should be restarted\n when it comes into view.\n */ skipUntilInView(from, to) {\n this.skipped.push({\n from,\n to\n });\n }\n /**\n Returns a parser intended to be used as placeholder when\n asynchronously loading a nested parser. It'll skip its input and\n mark it as not-really-parsed, so that the next update will parse\n it again.\n \n When `until` is given, a reparse will be scheduled when that\n promise resolves.\n */ static getSkippingParser(until) {\n return new class extends _common.Parser {\n createParse(input, fragments, ranges) {\n let from = ranges[0].from, to = ranges[ranges.length - 1].to;\n let parser = {\n parsedPos: from,\n advance () {\n let cx = currentContext;\n if (cx) {\n for (let r of ranges)cx.tempSkipped.push(r);\n if (until) cx.scheduleOn = cx.scheduleOn ? Promise.all([\n cx.scheduleOn,\n until\n ]) : until;\n }\n this.parsedPos = to;\n return new _common.Tree(_common.NodeType.none, [], [], to - from);\n },\n stoppedAt: null,\n stopAt () {\n }\n };\n return parser;\n }\n };\n }\n /**\n @internal\n */ isDone(upto) {\n upto = Math.min(upto, this.state.doc.length);\n let frags = this.fragments;\n return this.treeLen >= upto && frags.length && frags[0].from == 0 && frags[0].to >= upto;\n }\n /**\n Get the context for the current parse, or `null` if no editor\n parse is in progress.\n */ static get() {\n return currentContext;\n }\n}\nfunction cutFragments(fragments, from, to) {\n return _common.TreeFragment.applyChanges(fragments, [\n {\n fromA: from,\n toA: to,\n fromB: from,\n toB: to\n }\n ]);\n}\nclass LanguageState {\n constructor(// A mutable parse state that is used to preserve work done during\n // the lifetime of a state when moving to the next state.\n context){\n this.context = context;\n this.tree = context.tree;\n }\n apply(tr) {\n if (!tr.docChanged) return this;\n let newCx = this.context.changes(tr.changes, tr.state);\n // If the previous parse wasn't done, go forward only up to its\n // end position or the end of the viewport, to avoid slowing down\n // state updates with parse work beyond the viewport.\n let upto = this.context.treeLen == tr.startState.doc.length ? undefined : Math.max(tr.changes.mapPos(this.context.treeLen), newCx.viewport.to);\n if (!newCx.work(20 /* Apply */ , upto)) newCx.takeTree();\n return new LanguageState(newCx);\n }\n static init(state) {\n let vpTo = Math.min(3000 /* InitViewport */ , state.doc.length);\n let parseState = new ParseContext(state.facet(language).parser, state, [], _common.Tree.empty, 0, {\n from: 0,\n to: vpTo\n }, [], null);\n if (!parseState.work(20 /* Apply */ , vpTo)) parseState.takeTree();\n return new LanguageState(parseState);\n }\n}\nLanguage.state = /*@__PURE__*/ _state.StateField.define({\n create: LanguageState.init,\n update (value, tr) {\n for (let e of tr.effects)if (e.is(Language.setState)) return e.value;\n if (tr.startState.facet(language) != tr.state.facet(language)) return LanguageState.init(tr.state);\n return value.apply(tr);\n }\n});\nlet requestIdle = (callback)=>{\n let timeout = setTimeout(()=>callback()\n , 500 /* MaxPause */ );\n return ()=>clearTimeout(timeout)\n ;\n};\nif (typeof requestIdleCallback != \"undefined\") requestIdle = (callback)=>{\n let idle = -1, timeout = setTimeout(()=>{\n idle = requestIdleCallback(callback, {\n timeout: 400 /* MinPause */ \n });\n }, 100 /* MinPause */ );\n return ()=>idle < 0 ? clearTimeout(timeout) : cancelIdleCallback(idle)\n ;\n};\nconst parseWorker = /*@__PURE__*/ _view.ViewPlugin.fromClass(class ParseWorker {\n constructor(view){\n this.view = view;\n this.working = null;\n this.workScheduled = 0;\n // End of the current time chunk\n this.chunkEnd = -1;\n // Milliseconds of budget left for this chunk\n this.chunkBudget = -1;\n this.work = this.work.bind(this);\n this.scheduleWork();\n }\n update(update) {\n let cx = this.view.state.field(Language.state).context;\n if (cx.updateViewport(update.view.viewport) || this.view.viewport.to > cx.treeLen) this.scheduleWork();\n if (update.docChanged) {\n if (this.view.hasFocus) this.chunkBudget += 50 /* ChangeBonus */ ;\n this.scheduleWork();\n }\n this.checkAsyncSchedule(cx);\n }\n scheduleWork() {\n if (this.working) return;\n let { state } = this.view, field = state.field(Language.state);\n if (field.tree != field.context.tree || !field.context.isDone(state.doc.length)) this.working = requestIdle(this.work);\n }\n work(deadline) {\n this.working = null;\n let now = Date.now();\n if (this.chunkEnd < now && (this.chunkEnd < 0 || this.view.hasFocus)) {\n this.chunkEnd = now + 30000 /* ChunkTime */ ;\n this.chunkBudget = 3000 /* ChunkBudget */ ;\n }\n if (this.chunkBudget <= 0) return; // No more budget\n let { state , viewport: { to: vpTo } } = this.view, field = state.field(Language.state);\n if (field.tree == field.context.tree && field.context.isDone(vpTo + 100000 /* MaxParseAhead */ )) return;\n let time = Math.min(this.chunkBudget, 100 /* Slice */ , deadline ? Math.max(25 /* MinSlice */ , deadline.timeRemaining() - 5) : 1000000000);\n let viewportFirst = field.context.treeLen < vpTo && state.doc.length > vpTo + 1000;\n let done = field.context.work(time, vpTo + (viewportFirst ? 0 : 100000 /* MaxParseAhead */ ));\n this.chunkBudget -= Date.now() - now;\n if (done || this.chunkBudget <= 0) {\n field.context.takeTree();\n this.view.dispatch({\n effects: Language.setState.of(new LanguageState(field.context))\n });\n }\n if (this.chunkBudget > 0 && !(done && !viewportFirst)) this.scheduleWork();\n this.checkAsyncSchedule(field.context);\n }\n checkAsyncSchedule(cx) {\n if (cx.scheduleOn) {\n this.workScheduled++;\n cx.scheduleOn.then(()=>this.scheduleWork()\n ).catch((err)=>_view.logException(this.view.state, err)\n ).then(()=>this.workScheduled--\n );\n cx.scheduleOn = null;\n }\n }\n destroy() {\n if (this.working) this.working();\n }\n isWorking() {\n return this.working || this.workScheduled > 0;\n }\n}, {\n eventHandlers: {\n focus () {\n this.scheduleWork();\n }\n }\n});\n/**\nThe facet used to associate a language with an editor state.\n*/ const language = /*@__PURE__*/ _state.Facet.define({\n combine (languages) {\n return languages.length ? languages[0] : null;\n },\n enables: [\n Language.state,\n parseWorker\n ]\n});\n/**\nThis class bundles a [language object](https://codemirror.net/6/docs/ref/#language.Language) with an\noptional set of supporting extensions. Language packages are\nencouraged to export a function that optionally takes a\nconfiguration object and returns a `LanguageSupport` instance, as\nthe main way for client code to use the package.\n*/ class LanguageSupport {\n /**\n Create a support object.\n */ constructor(/**\n The language object.\n */ language1, /**\n An optional set of supporting extensions. When nesting a\n language in another language, the outer language is encouraged\n to include the supporting extensions for its inner languages\n in its own set of support extensions.\n */ support = []){\n this.language = language1;\n this.support = support;\n this.extension = [\n language1,\n support\n ];\n }\n}\n/**\nLanguage descriptions are used to store metadata about languages\nand to dynamically load them. Their main role is finding the\nappropriate language for a filename or dynamically loading nested\nparsers.\n*/ class LanguageDescription {\n constructor(/**\n The name of this language.\n */ name, /**\n Alternative names for the mode (lowercased, includes `this.name`).\n */ alias, /**\n File extensions associated with this language.\n */ extensions, /**\n Optional filename pattern that should be associated with this\n language.\n */ filename, loadFunc, /**\n If the language has been loaded, this will hold its value.\n */ support){\n this.name = name;\n this.alias = alias;\n this.extensions = extensions;\n this.filename = filename;\n this.loadFunc = loadFunc;\n this.support = support;\n this.loading = null;\n }\n /**\n Start loading the the language. Will return a promise that\n resolves to a [`LanguageSupport`](https://codemirror.net/6/docs/ref/#language.LanguageSupport)\n object when the language successfully loads.\n */ load() {\n return this.loading || (this.loading = this.loadFunc().then((support)=>this.support = support\n , (err)=>{\n this.loading = null;\n throw err;\n }));\n }\n /**\n Create a language description.\n */ static of(spec) {\n let { load , support } = spec;\n if (!load) {\n if (!support) throw new RangeError(\"Must pass either 'load' or 'support' to LanguageDescription.of\");\n load = ()=>Promise.resolve(support)\n ;\n }\n return new LanguageDescription(spec.name, (spec.alias || []).concat(spec.name).map((s)=>s.toLowerCase()\n ), spec.extensions || [], spec.filename, load, support);\n }\n /**\n Look for a language in the given array of descriptions that\n matches the filename. Will first match\n [`filename`](https://codemirror.net/6/docs/ref/#language.LanguageDescription.filename) patterns,\n and then [extensions](https://codemirror.net/6/docs/ref/#language.LanguageDescription.extensions),\n and return the first language that matches.\n */ static matchFilename(descs, filename) {\n for (let d of descs)if (d.filename && d.filename.test(filename)) return d;\n let ext = /\\.([^.]+)$/.exec(filename);\n if (ext) {\n for (let d1 of descs)if (d1.extensions.indexOf(ext[1]) > -1) return d1;\n }\n return null;\n }\n /**\n Look for a language whose name or alias matches the the given\n name (case-insensitively). If `fuzzy` is true, and no direct\n matchs is found, this'll also search for a language whose name\n or alias occurs in the string (for names shorter than three\n characters, only when surrounded by non-word characters).\n */ static matchLanguageName(descs, name, fuzzy = true) {\n name = name.toLowerCase();\n for (let d of descs)if (d.alias.some((a)=>a == name\n )) return d;\n if (fuzzy) for (let d2 of descs)for (let a1 of d2.alias){\n let found = name.indexOf(a1);\n if (found > -1 && (a1.length > 2 || !/\\w/.test(name[found - 1]) && !/\\w/.test(name[found + a1.length]))) return d2;\n }\n return null;\n }\n}\n/**\nFacet that defines a way to provide a function that computes the\nappropriate indentation depth at the start of a given line, or\n`null` to indicate no appropriate indentation could be determined.\n*/ const indentService = /*@__PURE__*/ _state.Facet.define();\n/**\nFacet for overriding the unit by which indentation happens.\nShould be a string consisting either entirely of spaces or\nentirely of tabs. When not set, this defaults to 2 spaces.\n*/ const indentUnit = /*@__PURE__*/ _state.Facet.define({\n combine: (values)=>{\n if (!values.length) return \" \";\n if (!/^(?: +|\\t+)$/.test(values[0])) throw new Error(\"Invalid indent unit: \" + JSON.stringify(values[0]));\n return values[0];\n }\n});\n/**\nReturn the _column width_ of an indent unit in the state.\nDetermined by the [`indentUnit`](https://codemirror.net/6/docs/ref/#language.indentUnit)\nfacet, and [`tabSize`](https://codemirror.net/6/docs/ref/#state.EditorState^tabSize) when that\ncontains tabs.\n*/ function getIndentUnit(state) {\n let unit = state.facet(indentUnit);\n return unit.charCodeAt(0) == 9 ? state.tabSize * unit.length : unit.length;\n}\n/**\nCreate an indentation string that covers columns 0 to `cols`.\nWill use tabs for as much of the columns as possible when the\n[`indentUnit`](https://codemirror.net/6/docs/ref/#language.indentUnit) facet contains\ntabs.\n*/ function indentString(state, cols) {\n let result = \"\", ts = state.tabSize;\n if (state.facet(indentUnit).charCodeAt(0) == 9) while(cols >= ts){\n result += \"\\t\";\n cols -= ts;\n }\n for(let i = 0; i < cols; i++)result += \" \";\n return result;\n}\n/**\nGet the indentation at the given position. Will first consult any\n[indent services](https://codemirror.net/6/docs/ref/#language.indentService) that are registered,\nand if none of those return an indentation, this will check the\nsyntax tree for the [indent node prop](https://codemirror.net/6/docs/ref/#language.indentNodeProp)\nand use that if found. Returns a number when an indentation could\nbe determined, and null otherwise.\n*/ function getIndentation(context, pos) {\n if (context instanceof _state.EditorState) context = new IndentContext(context);\n for (let service of context.state.facet(indentService)){\n let result = service(context, pos);\n if (result != null) return result;\n }\n let tree = syntaxTree(context.state);\n return tree ? syntaxIndentation(context, tree, pos) : null;\n}\n/**\nIndentation contexts are used when calling [indentation\nservices](https://codemirror.net/6/docs/ref/#language.indentService). They provide helper utilities\nuseful in indentation logic, and can selectively override the\nindentation reported for some lines.\n*/ class IndentContext {\n /**\n Create an indent context.\n */ constructor(/**\n The editor state.\n */ state, /**\n @internal\n */ options = {\n }){\n this.state = state;\n this.options = options;\n this.unit = getIndentUnit(state);\n }\n /**\n Get a description of the line at the given position, taking\n [simulated line\n breaks](https://codemirror.net/6/docs/ref/#language.IndentContext.constructor^options.simulateBreak)\n into account. If there is such a break at `pos`, the `bias`\n argument determines whether the part of the line line before or\n after the break is used.\n */ lineAt(pos, bias = 1) {\n let line = this.state.doc.lineAt(pos);\n let { simulateBreak } = this.options;\n if (simulateBreak != null && simulateBreak >= line.from && simulateBreak <= line.to) {\n if (bias < 0 ? simulateBreak < pos : simulateBreak <= pos) return {\n text: line.text.slice(simulateBreak - line.from),\n from: simulateBreak\n };\n else return {\n text: line.text.slice(0, simulateBreak - line.from),\n from: line.from\n };\n }\n return line;\n }\n /**\n Get the text directly after `pos`, either the entire line\n or the next 100 characters, whichever is shorter.\n */ textAfterPos(pos, bias = 1) {\n if (this.options.simulateDoubleBreak && pos == this.options.simulateBreak) return \"\";\n let { text , from } = this.lineAt(pos, bias);\n return text.slice(pos - from, Math.min(text.length, pos + 100 - from));\n }\n /**\n Find the column for the given position.\n */ column(pos, bias = 1) {\n let { text , from } = this.lineAt(pos, bias);\n let result = this.countColumn(text, pos - from);\n let override = this.options.overrideIndentation ? this.options.overrideIndentation(from) : -1;\n if (override > -1) result += override - this.countColumn(text, text.search(/\\S|$/));\n return result;\n }\n /**\n Find the column position (taking tabs into account) of the given\n position in the given string.\n */ countColumn(line, pos = line.length) {\n return _text.countColumn(line, this.state.tabSize, pos);\n }\n /**\n Find the indentation column of the line at the given point.\n */ lineIndent(pos, bias = 1) {\n let { text , from } = this.lineAt(pos, bias);\n let override = this.options.overrideIndentation;\n if (override) {\n let overriden = override(from);\n if (overriden > -1) return overriden;\n }\n return this.countColumn(text, text.search(/\\S|$/));\n }\n /**\n Returns the [simulated line\n break](https://codemirror.net/6/docs/ref/#language.IndentContext.constructor^options.simulateBreak)\n for this context, if any.\n */ get simulatedBreak() {\n return this.options.simulateBreak || null;\n }\n}\n/**\nA syntax tree node prop used to associate indentation strategies\nwith node types. Such a strategy is a function from an indentation\ncontext to a column number or null, where null indicates that no\ndefinitive indentation can be determined.\n*/ const indentNodeProp = /*@__PURE__*/ new _common.NodeProp();\n// Compute the indentation for a given position from the syntax tree.\nfunction syntaxIndentation(cx, ast, pos) {\n return indentFrom(ast.resolveInner(pos).enterUnfinishedNodesBefore(pos), pos, cx);\n}\nfunction ignoreClosed(cx) {\n return cx.pos == cx.options.simulateBreak && cx.options.simulateDoubleBreak;\n}\nfunction indentStrategy(tree) {\n let strategy = tree.type.prop(indentNodeProp);\n if (strategy) return strategy;\n let first = tree.firstChild, close;\n if (first && (close = first.type.prop(_common.NodeProp.closedBy))) {\n let last = tree.lastChild, closed = last && close.indexOf(last.name) > -1;\n return (cx)=>delimitedStrategy(cx, true, 1, undefined, closed && !ignoreClosed(cx) ? last.from : undefined)\n ;\n }\n return tree.parent == null ? topIndent : null;\n}\nfunction indentFrom(node, pos, base) {\n for(; node; node = node.parent){\n let strategy = indentStrategy(node);\n if (strategy) return strategy(new TreeIndentContext(base, pos, node));\n }\n return null;\n}\nfunction topIndent() {\n return 0;\n}\n/**\nObjects of this type provide context information and helper\nmethods to indentation functions.\n*/ class TreeIndentContext extends IndentContext {\n /**\n @internal\n */ constructor(base, /**\n The position at which indentation is being computed.\n */ pos, /**\n The syntax tree node to which the indentation strategy\n applies.\n */ node){\n super(base.state, base.options);\n this.base = base;\n this.pos = pos;\n this.node = node;\n }\n /**\n Get the text directly after `this.pos`, either the entire line\n or the next 100 characters, whichever is shorter.\n */ get textAfter() {\n return this.textAfterPos(this.pos);\n }\n /**\n Get the indentation at the reference line for `this.node`, which\n is the line on which it starts, unless there is a node that is\n _not_ a parent of this node covering the start of that line. If\n so, the line at the start of that node is tried, again skipping\n on if it is covered by another such node.\n */ get baseIndent() {\n let line = this.state.doc.lineAt(this.node.from);\n // Skip line starts that are covered by a sibling (or cousin, etc)\n for(;;){\n let atBreak = this.node.resolve(line.from);\n while(atBreak.parent && atBreak.parent.from == atBreak.from)atBreak = atBreak.parent;\n if (isParent(atBreak, this.node)) break;\n line = this.state.doc.lineAt(atBreak.from);\n }\n return this.lineIndent(line.from);\n }\n /**\n Continue looking for indentations in the node's parent nodes,\n and return the result of that.\n */ continue() {\n let parent = this.node.parent;\n return parent ? indentFrom(parent, this.pos, this.base) : 0;\n }\n}\nfunction isParent(parent, of) {\n for(let cur = of; cur; cur = cur.parent)if (parent == cur) return true;\n return false;\n}\n// Check whether a delimited node is aligned (meaning there are\n// non-skipped nodes on the same line as the opening delimiter). And\n// if so, return the opening token.\nfunction bracketedAligned(context) {\n let tree = context.node;\n let openToken = tree.childAfter(tree.from), last = tree.lastChild;\n if (!openToken) return null;\n let sim = context.options.simulateBreak;\n let openLine = context.state.doc.lineAt(openToken.from);\n let lineEnd = sim == null || sim <= openLine.from ? openLine.to : Math.min(openLine.to, sim);\n for(let pos = openToken.to;;){\n let next = tree.childAfter(pos);\n if (!next || next == last) return null;\n if (!next.type.isSkipped) return next.from < lineEnd ? openToken : null;\n pos = next.to;\n }\n}\n/**\nAn indentation strategy for delimited (usually bracketed) nodes.\nWill, by default, indent one unit more than the parent's base\nindent unless the line starts with a closing token. When `align`\nis true and there are non-skipped nodes on the node's opening\nline, the content of the node will be aligned with the end of the\nopening node, like this:\n\n foo(bar,\n baz)\n*/ function delimitedIndent({ closing , align =true , units =1 }) {\n return (context)=>delimitedStrategy(context, align, units, closing)\n ;\n}\nfunction delimitedStrategy(context, align, units, closing, closedAt) {\n let after = context.textAfter, space = after.match(/^\\s*/)[0].length;\n let closed = closing && after.slice(space, space + closing.length) == closing || closedAt == context.pos + space;\n let aligned = align ? bracketedAligned(context) : null;\n if (aligned) return closed ? context.column(aligned.from) : context.column(aligned.to);\n return context.baseIndent + (closed ? 0 : context.unit * units);\n}\n/**\nAn indentation strategy that aligns a node's content to its base\nindentation.\n*/ const flatIndent = (context)=>context.baseIndent\n;\n/**\nCreates an indentation strategy that, by default, indents\ncontinued lines one unit more than the node's base indentation.\nYou can provide `except` to prevent indentation of lines that\nmatch a pattern (for example `/^else\\b/` in `if`/`else`\nconstructs), and you can change the amount of units used with the\n`units` option.\n*/ function continuedIndent({ except , units =1 } = {\n}) {\n return (context)=>{\n let matchExcept = except && except.test(context.textAfter);\n return context.baseIndent + (matchExcept ? 0 : units * context.unit);\n };\n}\nconst DontIndentBeyond = 200;\n/**\nEnables reindentation on input. When a language defines an\n`indentOnInput` field in its [language\ndata](https://codemirror.net/6/docs/ref/#state.EditorState.languageDataAt), which must hold a regular\nexpression, the line at the cursor will be reindented whenever new\ntext is typed and the input from the start of the line up to the\ncursor matches that regexp.\n\nTo avoid unneccesary reindents, it is recommended to start the\nregexp with `^` (usually followed by `\\s*`), and end it with `$`.\nFor example, `/^\\s*\\}$/` will reindent when a closing brace is\nadded at the start of a line.\n*/ function indentOnInput() {\n return _state.EditorState.transactionFilter.of((tr)=>{\n if (!tr.docChanged || !tr.isUserEvent(\"input.type\")) return tr;\n let rules = tr.startState.languageDataAt(\"indentOnInput\", tr.startState.selection.main.head);\n if (!rules.length) return tr;\n let doc = tr.newDoc, { head } = tr.newSelection.main, line = doc.lineAt(head);\n if (head > line.from + DontIndentBeyond) return tr;\n let lineStart = doc.sliceString(line.from, head);\n if (!rules.some((r)=>r.test(lineStart)\n )) return tr;\n let { state } = tr, last = -1, changes = [];\n for (let { head: head1 } of state.selection.ranges){\n let line = state.doc.lineAt(head1);\n if (line.from == last) continue;\n last = line.from;\n let indent = getIndentation(state, line.from);\n if (indent == null) continue;\n let cur = /^\\s*/.exec(line.text)[0];\n let norm = indentString(state, indent);\n if (cur != norm) changes.push({\n from: line.from,\n to: line.from + cur.length,\n insert: norm\n });\n }\n return changes.length ? [\n tr,\n {\n changes,\n sequential: true\n }\n ] : tr;\n });\n}\n/**\nA facet that registers a code folding service. When called with\nthe extent of a line, such a function should return a foldable\nrange that starts on that line (but continues beyond it), if one\ncan be found.\n*/ const foldService = /*@__PURE__*/ _state.Facet.define();\n/**\nThis node prop is used to associate folding information with\nsyntax node types. Given a syntax node, it should check whether\nthat tree is foldable and return the range that can be collapsed\nwhen it is.\n*/ const foldNodeProp = /*@__PURE__*/ new _common.NodeProp();\n/**\n[Fold](https://codemirror.net/6/docs/ref/#language.foldNodeProp) function that folds everything but\nthe first and the last child of a syntax node. Useful for nodes\nthat start and end with delimiters.\n*/ function foldInside(node) {\n let first = node.firstChild, last = node.lastChild;\n return first && first.to < last.from ? {\n from: first.to,\n to: last.type.isError ? node.to : last.from\n } : null;\n}\nfunction syntaxFolding(state, start, end) {\n let tree = syntaxTree(state);\n if (tree.length == 0) return null;\n let inner = tree.resolveInner(end);\n let found = null;\n for(let cur = inner; cur; cur = cur.parent){\n if (cur.to <= end || cur.from > end) continue;\n if (found && cur.from < start) break;\n let prop = cur.type.prop(foldNodeProp);\n if (prop) {\n let value = prop(cur, state);\n if (value && value.from <= end && value.from >= start && value.to > end) found = value;\n }\n }\n return found;\n}\n/**\nCheck whether the given line is foldable. First asks any fold\nservices registered through\n[`foldService`](https://codemirror.net/6/docs/ref/#language.foldService), and if none of them return\na result, tries to query the [fold node\nprop](https://codemirror.net/6/docs/ref/#language.foldNodeProp) of syntax nodes that cover the end\nof the line.\n*/ function foldable(state, lineStart, lineEnd) {\n for (let service of state.facet(foldService)){\n let result = service(state, lineStart, lineEnd);\n if (result) return result;\n }\n return syntaxFolding(state, lineStart, lineEnd);\n}\n\n},{\"@lezer/common\":\"ds1Io\",\"@codemirror/state\":\"e6FBl\",\"@codemirror/view\":\"JuP5Z\",\"@codemirror/text\":\"kn7DT\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"ds1Io\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"DefaultBufferLength\", ()=>DefaultBufferLength\n);\nparcelHelpers.export(exports, \"MountedTree\", ()=>MountedTree\n);\nparcelHelpers.export(exports, \"NodeProp\", ()=>NodeProp\n);\nparcelHelpers.export(exports, \"NodeSet\", ()=>NodeSet\n);\nparcelHelpers.export(exports, \"NodeType\", ()=>NodeType\n);\nparcelHelpers.export(exports, \"Parser\", ()=>Parser\n);\nparcelHelpers.export(exports, \"Tree\", ()=>Tree\n);\nparcelHelpers.export(exports, \"TreeBuffer\", ()=>TreeBuffer\n);\nparcelHelpers.export(exports, \"TreeCursor\", ()=>TreeCursor\n);\nparcelHelpers.export(exports, \"TreeFragment\", ()=>TreeFragment\n);\nparcelHelpers.export(exports, \"parseMixed\", ()=>parseMixed\n);\n// FIXME profile adding a per-Tree TreeNode cache, validating it by\n// parent pointer\n/// The default maximum length of a `TreeBuffer` node (1024).\nconst DefaultBufferLength = 1024;\nlet nextPropID = 0;\nclass Range {\n constructor(from, to){\n this.from = from;\n this.to = to;\n }\n}\n/// Each [node type](#common.NodeType) or [individual tree](#common.Tree)\n/// can have metadata associated with it in props. Instances of this\n/// class represent prop names.\nclass NodeProp {\n /// Create a new node prop type.\n constructor(config = {\n }){\n this.id = nextPropID++;\n this.perNode = !!config.perNode;\n this.deserialize = config.deserialize || (()=>{\n throw new Error(\"This node type doesn't define a deserialize function\");\n });\n }\n /// This is meant to be used with\n /// [`NodeSet.extend`](#common.NodeSet.extend) or\n /// [`LRParser.configure`](#lr.ParserConfig.props) to compute\n /// prop values for each node type in the set. Takes a [match\n /// object](#common.NodeType^match) or function that returns undefined\n /// if the node type doesn't get this prop, and the prop's value if\n /// it does.\n add(match) {\n if (this.perNode) throw new RangeError(\"Can't add per-node props to node types\");\n if (typeof match != \"function\") match = NodeType.match(match);\n return (type)=>{\n let result = match(type);\n return result === undefined ? null : [\n this,\n result\n ];\n };\n }\n}\n/// Prop that is used to describe matching delimiters. For opening\n/// delimiters, this holds an array of node names (written as a\n/// space-separated string when declaring this prop in a grammar)\n/// for the node types of closing delimiters that match it.\nNodeProp.closedBy = new NodeProp({\n deserialize: (str)=>str.split(\" \")\n});\n/// The inverse of [`closedBy`](#common.NodeProp^closedBy). This is\n/// attached to closing delimiters, holding an array of node names\n/// of types of matching opening delimiters.\nNodeProp.openedBy = new NodeProp({\n deserialize: (str)=>str.split(\" \")\n});\n/// Used to assign node types to groups (for example, all node\n/// types that represent an expression could be tagged with an\n/// `\"Expression\"` group).\nNodeProp.group = new NodeProp({\n deserialize: (str)=>str.split(\" \")\n});\n/// The hash of the [context](#lr.ContextTracker.constructor)\n/// that the node was parsed in, if any. Used to limit reuse of\n/// contextual nodes.\nNodeProp.contextHash = new NodeProp({\n perNode: true\n});\n/// The distance beyond the end of the node that the tokenizer\n/// looked ahead for any of the tokens inside the node. (The LR\n/// parser only stores this when it is larger than 25, for\n/// efficiency reasons.)\nNodeProp.lookAhead = new NodeProp({\n perNode: true\n});\n/// This per-node prop is used to replace a given node, or part of a\n/// node, with another tree. This is useful to include trees from\n/// different languages.\nNodeProp.mounted = new NodeProp({\n perNode: true\n});\n/// A mounted tree, which can be [stored](#common.NodeProp^mounted) on\n/// a tree node to indicate that parts of its content are\n/// represented by another tree.\nclass MountedTree {\n constructor(/// The inner tree.\n tree, /// If this is null, this tree replaces the entire node (it will\n /// be included in the regular iteration instead of its host\n /// node). If not, only the given ranges are considered to be\n /// covered by this tree. This is used for trees that are mixed in\n /// a way that isn't strictly hierarchical. Such mounted trees are\n /// only entered by [`resolveInner`](#common.Tree.resolveInner)\n /// and [`enter`](#common.SyntaxNode.enter).\n overlay, /// The parser used to create this subtree.\n parser){\n this.tree = tree;\n this.overlay = overlay;\n this.parser = parser;\n }\n}\nconst noProps = Object.create(null);\n/// Each node in a syntax tree has a node type associated with it.\nclass NodeType {\n /// @internal\n constructor(/// The name of the node type. Not necessarily unique, but if the\n /// grammar was written properly, different node types with the\n /// same name within a node set should play the same semantic\n /// role.\n name, /// @internal\n props, /// The id of this node in its set. Corresponds to the term ids\n /// used in the parser.\n id, /// @internal\n flags = 0){\n this.name = name;\n this.props = props;\n this.id = id;\n this.flags = flags;\n }\n static define(spec) {\n let props = spec.props && spec.props.length ? Object.create(null) : noProps;\n let flags = (spec.top ? 1 /* Top */ : 0) | (spec.skipped ? 2 /* Skipped */ : 0) | (spec.error ? 4 /* Error */ : 0) | (spec.name == null ? 8 /* Anonymous */ : 0);\n let type = new NodeType(spec.name || \"\", props, spec.id, flags);\n if (spec.props) for (let src of spec.props){\n if (!Array.isArray(src)) src = src(type);\n if (src) {\n if (src[0].perNode) throw new RangeError(\"Can't store a per-node prop on a node type\");\n props[src[0].id] = src[1];\n }\n }\n return type;\n }\n /// Retrieves a node prop for this type. Will return `undefined` if\n /// the prop isn't present on this node.\n prop(prop) {\n return this.props[prop.id];\n }\n /// True when this is the top node of a grammar.\n get isTop() {\n return (this.flags & 1 /* Top */ ) > 0;\n }\n /// True when this node is produced by a skip rule.\n get isSkipped() {\n return (this.flags & 2 /* Skipped */ ) > 0;\n }\n /// Indicates whether this is an error node.\n get isError() {\n return (this.flags & 4 /* Error */ ) > 0;\n }\n /// When true, this node type doesn't correspond to a user-declared\n /// named node, for example because it is used to cache repetition.\n get isAnonymous() {\n return (this.flags & 8 /* Anonymous */ ) > 0;\n }\n /// Returns true when this node's name or one of its\n /// [groups](#common.NodeProp^group) matches the given string.\n is(name) {\n if (typeof name == 'string') {\n if (this.name == name) return true;\n let group = this.prop(NodeProp.group);\n return group ? group.indexOf(name) > -1 : false;\n }\n return this.id == name;\n }\n /// Create a function from node types to arbitrary values by\n /// specifying an object whose property names are node or\n /// [group](#common.NodeProp^group) names. Often useful with\n /// [`NodeProp.add`](#common.NodeProp.add). You can put multiple\n /// names, separated by spaces, in a single property name to map\n /// multiple node names to a single value.\n static match(map) {\n let direct = Object.create(null);\n for(let prop in map)for (let name of prop.split(\" \"))direct[name] = map[prop];\n return (node)=>{\n for(let groups = node.prop(NodeProp.group), i = -1; i < (groups ? groups.length : 0); i++){\n let found = direct[i < 0 ? node.name : groups[i]];\n if (found) return found;\n }\n };\n }\n}\n/// An empty dummy node type to use when no actual type is available.\nNodeType.none = new NodeType(\"\", Object.create(null), 0, 8 /* Anonymous */ );\n/// A node set holds a collection of node types. It is used to\n/// compactly represent trees by storing their type ids, rather than a\n/// full pointer to the type object, in a numeric array. Each parser\n/// [has](#lr.LRParser.nodeSet) a node set, and [tree\n/// buffers](#common.TreeBuffer) can only store collections of nodes\n/// from the same set. A set can have a maximum of 2**16 (65536) node\n/// types in it, so that the ids fit into 16-bit typed array slots.\nclass NodeSet {\n /// Create a set with the given types. The `id` property of each\n /// type should correspond to its position within the array.\n constructor(/// The node types in this set, by id.\n types){\n this.types = types;\n for(let i = 0; i < types.length; i++)if (types[i].id != i) throw new RangeError(\"Node type ids should correspond to array positions when creating a node set\");\n }\n /// Create a copy of this set with some node properties added. The\n /// arguments to this method should be created with\n /// [`NodeProp.add`](#common.NodeProp.add).\n extend(...props) {\n let newTypes = [];\n for (let type of this.types){\n let newProps = null;\n for (let source of props){\n let add = source(type);\n if (add) {\n if (!newProps) newProps = Object.assign({\n }, type.props);\n newProps[add[0].id] = add[1];\n }\n }\n newTypes.push(newProps ? new NodeType(type.name, newProps, type.id, type.flags) : type);\n }\n return new NodeSet(newTypes);\n }\n}\nconst CachedNode = new WeakMap(), CachedInnerNode = new WeakMap();\n/// A piece of syntax tree. There are two ways to approach these\n/// trees: the way they are actually stored in memory, and the\n/// convenient way.\n///\n/// Syntax trees are stored as a tree of `Tree` and `TreeBuffer`\n/// objects. By packing detail information into `TreeBuffer` leaf\n/// nodes, the representation is made a lot more memory-efficient.\n///\n/// However, when you want to actually work with tree nodes, this\n/// representation is very awkward, so most client code will want to\n/// use the [`TreeCursor`](#common.TreeCursor) or\n/// [`SyntaxNode`](#common.SyntaxNode) interface instead, which provides\n/// a view on some part of this data structure, and can be used to\n/// move around to adjacent nodes.\nclass Tree {\n /// Construct a new tree. See also [`Tree.build`](#common.Tree^build).\n constructor(/// The type of the top node.\n type, /// This node's child nodes.\n children, /// The positions (offsets relative to the start of this tree) of\n /// the children.\n positions, /// The total length of this tree\n length, /// Per-node [node props](#common.NodeProp) to associate with this node.\n props){\n this.type = type;\n this.children = children;\n this.positions = positions;\n this.length = length;\n /// @internal\n this.props = null;\n if (props && props.length) {\n this.props = Object.create(null);\n for (let [prop, value] of props)this.props[typeof prop == \"number\" ? prop : prop.id] = value;\n }\n }\n /// @internal\n toString() {\n let mounted = this.prop(NodeProp.mounted);\n if (mounted && !mounted.overlay) return mounted.tree.toString();\n let children = \"\";\n for (let ch of this.children){\n let str = ch.toString();\n if (str) {\n if (children) children += \",\";\n children += str;\n }\n }\n return !this.type.name ? children : (/\\W/.test(this.type.name) && !this.type.isError ? JSON.stringify(this.type.name) : this.type.name) + (children.length ? \"(\" + children + \")\" : \"\");\n }\n /// Get a [tree cursor](#common.TreeCursor) rooted at this tree. When\n /// `pos` is given, the cursor is [moved](#common.TreeCursor.moveTo)\n /// to the given position and side.\n cursor(pos, side = 0) {\n let scope = pos != null && CachedNode.get(this) || this.topNode;\n let cursor = new TreeCursor(scope);\n if (pos != null) {\n cursor.moveTo(pos, side);\n CachedNode.set(this, cursor._tree);\n }\n return cursor;\n }\n /// Get a [tree cursor](#common.TreeCursor) that, unlike regular\n /// cursors, doesn't skip through\n /// [anonymous](#common.NodeType.isAnonymous) nodes and doesn't\n /// automatically enter mounted nodes.\n fullCursor() {\n return new TreeCursor(this.topNode, 1 /* Full */ );\n }\n /// Get a [syntax node](#common.SyntaxNode) object for the top of the\n /// tree.\n get topNode() {\n return new TreeNode(this, 0, 0, null);\n }\n /// Get the [syntax node](#common.SyntaxNode) at the given position.\n /// If `side` is -1, this will move into nodes that end at the\n /// position. If 1, it'll move into nodes that start at the\n /// position. With 0, it'll only enter nodes that cover the position\n /// from both sides.\n resolve(pos, side = 0) {\n let node = resolveNode(CachedNode.get(this) || this.topNode, pos, side, false);\n CachedNode.set(this, node);\n return node;\n }\n /// Like [`resolve`](#common.Tree.resolve), but will enter\n /// [overlaid](#common.MountedTree.overlay) nodes, producing a syntax node\n /// pointing into the innermost overlaid tree at the given position\n /// (with parent links going through all parent structure, including\n /// the host trees).\n resolveInner(pos, side = 0) {\n let node = resolveNode(CachedInnerNode.get(this) || this.topNode, pos, side, true);\n CachedInnerNode.set(this, node);\n return node;\n }\n /// Iterate over the tree and its children, calling `enter` for any\n /// node that touches the `from`/`to` region (if given) before\n /// running over such a node's children, and `leave` (if given) when\n /// leaving the node. When `enter` returns `false`, that node will\n /// not have its children iterated over (or `leave` called).\n iterate(spec) {\n let { enter , leave , from =0 , to =this.length } = spec;\n for(let c = this.cursor(), get = ()=>c.node\n ;;){\n let mustLeave = false;\n if (c.from <= to && c.to >= from && (c.type.isAnonymous || enter(c.type, c.from, c.to, get) !== false)) {\n if (c.firstChild()) continue;\n if (!c.type.isAnonymous) mustLeave = true;\n }\n for(;;){\n if (mustLeave && leave) leave(c.type, c.from, c.to, get);\n mustLeave = c.type.isAnonymous;\n if (c.nextSibling()) break;\n if (!c.parent()) return;\n mustLeave = true;\n }\n }\n }\n /// Get the value of the given [node prop](#common.NodeProp) for this\n /// node. Works with both per-node and per-type props.\n prop(prop) {\n return !prop.perNode ? this.type.prop(prop) : this.props ? this.props[prop.id] : undefined;\n }\n /// Returns the node's [per-node props](#common.NodeProp.perNode) in a\n /// format that can be passed to the [`Tree`](#common.Tree)\n /// constructor.\n get propValues() {\n let result = [];\n if (this.props) for(let id in this.props)result.push([\n +id,\n this.props[id]\n ]);\n return result;\n }\n /// Balance the direct children of this tree, producing a copy of\n /// which may have children grouped into subtrees with type\n /// [`NodeType.none`](#common.NodeType^none).\n balance(config = {\n }) {\n return this.children.length <= 8 /* BranchFactor */ ? this : balanceRange(NodeType.none, this.children, this.positions, 0, this.children.length, 0, this.length, (children, positions, length)=>new Tree(this.type, children, positions, length, this.propValues)\n , config.makeTree || ((children, positions, length)=>new Tree(NodeType.none, children, positions, length)\n ));\n }\n /// Build a tree from a postfix-ordered buffer of node information,\n /// or a cursor over such a buffer.\n static build(data) {\n return buildTree(data);\n }\n}\n/// The empty tree\nTree.empty = new Tree(NodeType.none, [], [], 0);\nclass FlatBufferCursor {\n constructor(buffer, index){\n this.buffer = buffer;\n this.index = index;\n }\n get id() {\n return this.buffer[this.index - 4];\n }\n get start() {\n return this.buffer[this.index - 3];\n }\n get end() {\n return this.buffer[this.index - 2];\n }\n get size() {\n return this.buffer[this.index - 1];\n }\n get pos() {\n return this.index;\n }\n next() {\n this.index -= 4;\n }\n fork() {\n return new FlatBufferCursor(this.buffer, this.index);\n }\n}\n/// Tree buffers contain (type, start, end, endIndex) quads for each\n/// node. In such a buffer, nodes are stored in prefix order (parents\n/// before children, with the endIndex of the parent indicating which\n/// children belong to it)\nclass TreeBuffer {\n /// Create a tree buffer.\n constructor(/// The buffer's content.\n buffer, /// The total length of the group of nodes in the buffer.\n length, /// The node set used in this buffer.\n set){\n this.buffer = buffer;\n this.length = length;\n this.set = set;\n }\n /// @internal\n get type() {\n return NodeType.none;\n }\n /// @internal\n toString() {\n let result = [];\n for(let index = 0; index < this.buffer.length;){\n result.push(this.childString(index));\n index = this.buffer[index + 3];\n }\n return result.join(\",\");\n }\n /// @internal\n childString(index) {\n let id = this.buffer[index], endIndex = this.buffer[index + 3];\n let type = this.set.types[id], result = type.name;\n if (/\\W/.test(result) && !type.isError) result = JSON.stringify(result);\n index += 4;\n if (endIndex == index) return result;\n let children = [];\n while(index < endIndex){\n children.push(this.childString(index));\n index = this.buffer[index + 3];\n }\n return result + \"(\" + children.join(\",\") + \")\";\n }\n /// @internal\n findChild(startIndex, endIndex, dir, pos, side) {\n let { buffer } = this, pick = -1;\n for(let i = startIndex; i != endIndex; i = buffer[i + 3])if (checkSide(side, pos, buffer[i + 1], buffer[i + 2])) {\n pick = i;\n if (dir > 0) break;\n }\n return pick;\n }\n /// @internal\n slice(startI, endI, from, to) {\n let b = this.buffer;\n let copy = new Uint16Array(endI - startI);\n for(let i = startI, j = 0; i < endI;){\n copy[j++] = b[i++];\n copy[j++] = b[i++] - from;\n copy[j++] = b[i++] - from;\n copy[j++] = b[i++] - startI;\n }\n return new TreeBuffer(copy, to - from, this.set);\n }\n}\nfunction checkSide(side, pos, from, to) {\n switch(side){\n case -2 /* Before */ :\n return from < pos;\n case -1 /* AtOrBefore */ :\n return to >= pos && from < pos;\n case 0 /* Around */ :\n return from < pos && to > pos;\n case 1 /* AtOrAfter */ :\n return from <= pos && to > pos;\n case 2 /* After */ :\n return to > pos;\n case 4 /* DontCare */ :\n return true;\n }\n}\nfunction enterUnfinishedNodesBefore(node, pos) {\n let scan = node.childBefore(pos);\n while(scan){\n let last = scan.lastChild;\n if (!last || last.to != scan.to) break;\n if (last.type.isError && last.from == last.to) {\n node = scan;\n scan = last.prevSibling;\n } else scan = last;\n }\n return node;\n}\nfunction resolveNode(node, pos, side, overlays) {\n var _a;\n // Move up to a node that actually holds the position, if possible\n while(node.from == node.to || (side < 1 ? node.from >= pos : node.from > pos) || (side > -1 ? node.to <= pos : node.to < pos)){\n let parent = !overlays && node instanceof TreeNode && node.index < 0 ? null : node.parent;\n if (!parent) return node;\n node = parent;\n }\n // Must go up out of overlays when those do not overlap with pos\n if (overlays) {\n for(let scan = node, parent = scan.parent; parent; scan = parent, parent = scan.parent)if (scan instanceof TreeNode && scan.index < 0 && ((_a = parent.enter(pos, side, true)) === null || _a === void 0 ? void 0 : _a.from) != scan.from) node = parent;\n }\n for(;;){\n let inner = node.enter(pos, side, overlays);\n if (!inner) return node;\n node = inner;\n }\n}\nclass TreeNode {\n constructor(node, _from, // Index in parent node, set to -1 if the node is not a direct child of _parent.node (overlay)\n index, _parent){\n this.node = node;\n this._from = _from;\n this.index = index;\n this._parent = _parent;\n }\n get type() {\n return this.node.type;\n }\n get name() {\n return this.node.type.name;\n }\n get from() {\n return this._from;\n }\n get to() {\n return this._from + this.node.length;\n }\n nextChild(i, dir, pos, side, mode = 0) {\n for(let parent = this;;){\n for(let { children , positions } = parent.node, e = dir > 0 ? children.length : -1; i != e; i += dir){\n let next = children[i], start = positions[i] + parent._from;\n if (!checkSide(side, pos, start, start + next.length)) continue;\n if (next instanceof TreeBuffer) {\n if (mode & 2 /* NoEnterBuffer */ ) continue;\n let index = next.findChild(0, next.buffer.length, dir, pos - start, side);\n if (index > -1) return new BufferNode(new BufferContext(parent, next, i, start), null, index);\n } else if (mode & 1 /* Full */ || !next.type.isAnonymous || hasChild(next)) {\n let mounted;\n if (!(mode & 1 /* Full */ ) && next.props && (mounted = next.prop(NodeProp.mounted)) && !mounted.overlay) return new TreeNode(mounted.tree, start, i, parent);\n let inner = new TreeNode(next, start, i, parent);\n return mode & 1 /* Full */ || !inner.type.isAnonymous ? inner : inner.nextChild(dir < 0 ? next.children.length - 1 : 0, dir, pos, side);\n }\n }\n if (mode & 1 /* Full */ || !parent.type.isAnonymous) return null;\n if (parent.index >= 0) i = parent.index + dir;\n else i = dir < 0 ? -1 : parent._parent.node.children.length;\n parent = parent._parent;\n if (!parent) return null;\n }\n }\n get firstChild() {\n return this.nextChild(0, 1, 0, 4 /* DontCare */ );\n }\n get lastChild() {\n return this.nextChild(this.node.children.length - 1, -1, 0, 4 /* DontCare */ );\n }\n childAfter(pos) {\n return this.nextChild(0, 1, pos, 2 /* After */ );\n }\n childBefore(pos) {\n return this.nextChild(this.node.children.length - 1, -1, pos, -2 /* Before */ );\n }\n enter(pos, side, overlays = true, buffers = true) {\n let mounted;\n if (overlays && (mounted = this.node.prop(NodeProp.mounted)) && mounted.overlay) {\n let rPos = pos - this.from;\n for (let { from , to } of mounted.overlay){\n if ((side > 0 ? from <= rPos : from < rPos) && (side < 0 ? to >= rPos : to > rPos)) return new TreeNode(mounted.tree, mounted.overlay[0].from + this.from, -1, this);\n }\n }\n return this.nextChild(0, 1, pos, side, buffers ? 0 : 2 /* NoEnterBuffer */ );\n }\n nextSignificantParent() {\n let val = this;\n while(val.type.isAnonymous && val._parent)val = val._parent;\n return val;\n }\n get parent() {\n return this._parent ? this._parent.nextSignificantParent() : null;\n }\n get nextSibling() {\n return this._parent && this.index >= 0 ? this._parent.nextChild(this.index + 1, 1, 0, 4 /* DontCare */ ) : null;\n }\n get prevSibling() {\n return this._parent && this.index >= 0 ? this._parent.nextChild(this.index - 1, -1, 0, 4 /* DontCare */ ) : null;\n }\n get cursor() {\n return new TreeCursor(this);\n }\n get tree() {\n return this.node;\n }\n toTree() {\n return this.node;\n }\n resolve(pos, side = 0) {\n return resolveNode(this, pos, side, false);\n }\n resolveInner(pos, side = 0) {\n return resolveNode(this, pos, side, true);\n }\n enterUnfinishedNodesBefore(pos) {\n return enterUnfinishedNodesBefore(this, pos);\n }\n getChild(type, before = null, after = null) {\n let r = getChildren(this, type, before, after);\n return r.length ? r[0] : null;\n }\n getChildren(type, before = null, after = null) {\n return getChildren(this, type, before, after);\n }\n /// @internal\n toString() {\n return this.node.toString();\n }\n}\nfunction getChildren(node, type, before, after) {\n let cur = node.cursor, result = [];\n if (!cur.firstChild()) return result;\n if (before != null) {\n while(!cur.type.is(before))if (!cur.nextSibling()) return result;\n }\n for(;;){\n if (after != null && cur.type.is(after)) return result;\n if (cur.type.is(type)) result.push(cur.node);\n if (!cur.nextSibling()) return after == null ? result : [];\n }\n}\nclass BufferContext {\n constructor(parent, buffer, index, start){\n this.parent = parent;\n this.buffer = buffer;\n this.index = index;\n this.start = start;\n }\n}\nclass BufferNode {\n constructor(context, _parent, index){\n this.context = context;\n this._parent = _parent;\n this.index = index;\n this.type = context.buffer.set.types[context.buffer.buffer[index]];\n }\n get name() {\n return this.type.name;\n }\n get from() {\n return this.context.start + this.context.buffer.buffer[this.index + 1];\n }\n get to() {\n return this.context.start + this.context.buffer.buffer[this.index + 2];\n }\n child(dir, pos, side) {\n let { buffer } = this.context;\n let index = buffer.findChild(this.index + 4, buffer.buffer[this.index + 3], dir, pos - this.context.start, side);\n return index < 0 ? null : new BufferNode(this.context, this, index);\n }\n get firstChild() {\n return this.child(1, 0, 4 /* DontCare */ );\n }\n get lastChild() {\n return this.child(-1, 0, 4 /* DontCare */ );\n }\n childAfter(pos) {\n return this.child(1, pos, 2 /* After */ );\n }\n childBefore(pos) {\n return this.child(-1, pos, -2 /* Before */ );\n }\n enter(pos, side, overlays, buffers = true) {\n if (!buffers) return null;\n let { buffer } = this.context;\n let index = buffer.findChild(this.index + 4, buffer.buffer[this.index + 3], side > 0 ? 1 : -1, pos - this.context.start, side);\n return index < 0 ? null : new BufferNode(this.context, this, index);\n }\n get parent() {\n return this._parent || this.context.parent.nextSignificantParent();\n }\n externalSibling(dir) {\n return this._parent ? null : this.context.parent.nextChild(this.context.index + dir, dir, 0, 4 /* DontCare */ );\n }\n get nextSibling() {\n let { buffer } = this.context;\n let after = buffer.buffer[this.index + 3];\n if (after < (this._parent ? buffer.buffer[this._parent.index + 3] : buffer.buffer.length)) return new BufferNode(this.context, this._parent, after);\n return this.externalSibling(1);\n }\n get prevSibling() {\n let { buffer } = this.context;\n let parentStart = this._parent ? this._parent.index + 4 : 0;\n if (this.index == parentStart) return this.externalSibling(-1);\n return new BufferNode(this.context, this._parent, buffer.findChild(parentStart, this.index, -1, 0, 4 /* DontCare */ ));\n }\n get cursor() {\n return new TreeCursor(this);\n }\n get tree() {\n return null;\n }\n toTree() {\n let children = [], positions = [];\n let { buffer } = this.context;\n let startI = this.index + 4, endI = buffer.buffer[this.index + 3];\n if (endI > startI) {\n let from = buffer.buffer[this.index + 1], to = buffer.buffer[this.index + 2];\n children.push(buffer.slice(startI, endI, from, to));\n positions.push(0);\n }\n return new Tree(this.type, children, positions, this.to - this.from);\n }\n resolve(pos, side = 0) {\n return resolveNode(this, pos, side, false);\n }\n resolveInner(pos, side = 0) {\n return resolveNode(this, pos, side, true);\n }\n enterUnfinishedNodesBefore(pos) {\n return enterUnfinishedNodesBefore(this, pos);\n }\n /// @internal\n toString() {\n return this.context.buffer.childString(this.index);\n }\n getChild(type, before = null, after = null) {\n let r = getChildren(this, type, before, after);\n return r.length ? r[0] : null;\n }\n getChildren(type, before = null, after = null) {\n return getChildren(this, type, before, after);\n }\n}\n/// A tree cursor object focuses on a given node in a syntax tree, and\n/// allows you to move to adjacent nodes.\nclass TreeCursor {\n /// @internal\n constructor(node, /// @internal\n mode = 0){\n this.mode = mode;\n this.buffer = null;\n this.stack = [];\n this.index = 0;\n this.bufferNode = null;\n if (node instanceof TreeNode) this.yieldNode(node);\n else {\n this._tree = node.context.parent;\n this.buffer = node.context;\n for(let n = node._parent; n; n = n._parent)this.stack.unshift(n.index);\n this.bufferNode = node;\n this.yieldBuf(node.index);\n }\n }\n /// Shorthand for `.type.name`.\n get name() {\n return this.type.name;\n }\n yieldNode(node) {\n if (!node) return false;\n this._tree = node;\n this.type = node.type;\n this.from = node.from;\n this.to = node.to;\n return true;\n }\n yieldBuf(index, type) {\n this.index = index;\n let { start , buffer } = this.buffer;\n this.type = type || buffer.set.types[buffer.buffer[index]];\n this.from = start + buffer.buffer[index + 1];\n this.to = start + buffer.buffer[index + 2];\n return true;\n }\n yield(node) {\n if (!node) return false;\n if (node instanceof TreeNode) {\n this.buffer = null;\n return this.yieldNode(node);\n }\n this.buffer = node.context;\n return this.yieldBuf(node.index, node.type);\n }\n /// @internal\n toString() {\n return this.buffer ? this.buffer.buffer.childString(this.index) : this._tree.toString();\n }\n /// @internal\n enterChild(dir, pos, side) {\n if (!this.buffer) return this.yield(this._tree.nextChild(dir < 0 ? this._tree.node.children.length - 1 : 0, dir, pos, side, this.mode));\n let { buffer } = this.buffer;\n let index = buffer.findChild(this.index + 4, buffer.buffer[this.index + 3], dir, pos - this.buffer.start, side);\n if (index < 0) return false;\n this.stack.push(this.index);\n return this.yieldBuf(index);\n }\n /// Move the cursor to this node's first child. When this returns\n /// false, the node has no child, and the cursor has not been moved.\n firstChild() {\n return this.enterChild(1, 0, 4 /* DontCare */ );\n }\n /// Move the cursor to this node's last child.\n lastChild() {\n return this.enterChild(-1, 0, 4 /* DontCare */ );\n }\n /// Move the cursor to the first child that ends after `pos`.\n childAfter(pos) {\n return this.enterChild(1, pos, 2 /* After */ );\n }\n /// Move to the last child that starts before `pos`.\n childBefore(pos) {\n return this.enterChild(-1, pos, -2 /* Before */ );\n }\n /// Move the cursor to the child around `pos`. If side is -1 the\n /// child may end at that position, when 1 it may start there. This\n /// will also enter [overlaid](#common.MountedTree.overlay)\n /// [mounted](#common.NodeProp^mounted) trees unless `overlays` is\n /// set to false.\n enter(pos, side, overlays = true, buffers = true) {\n if (!this.buffer) return this.yield(this._tree.enter(pos, side, overlays && !(this.mode & 1 /* Full */ ), buffers));\n return buffers ? this.enterChild(1, pos, side) : false;\n }\n /// Move to the node's parent node, if this isn't the top node.\n parent() {\n if (!this.buffer) return this.yieldNode(this.mode & 1 /* Full */ ? this._tree._parent : this._tree.parent);\n if (this.stack.length) return this.yieldBuf(this.stack.pop());\n let parent = this.mode & 1 /* Full */ ? this.buffer.parent : this.buffer.parent.nextSignificantParent();\n this.buffer = null;\n return this.yieldNode(parent);\n }\n /// @internal\n sibling(dir) {\n if (!this.buffer) return !this._tree._parent ? false : this.yield(this._tree.index < 0 ? null : this._tree._parent.nextChild(this._tree.index + dir, dir, 0, 4 /* DontCare */ , this.mode));\n let { buffer } = this.buffer, d = this.stack.length - 1;\n if (dir < 0) {\n let parentStart = d < 0 ? 0 : this.stack[d] + 4;\n if (this.index != parentStart) return this.yieldBuf(buffer.findChild(parentStart, this.index, -1, 0, 4 /* DontCare */ ));\n } else {\n let after = buffer.buffer[this.index + 3];\n if (after < (d < 0 ? buffer.buffer.length : buffer.buffer[this.stack[d] + 3])) return this.yieldBuf(after);\n }\n return d < 0 ? this.yield(this.buffer.parent.nextChild(this.buffer.index + dir, dir, 0, 4 /* DontCare */ , this.mode)) : false;\n }\n /// Move to this node's next sibling, if any.\n nextSibling() {\n return this.sibling(1);\n }\n /// Move to this node's previous sibling, if any.\n prevSibling() {\n return this.sibling(-1);\n }\n atLastNode(dir) {\n let index, parent, { buffer } = this;\n if (buffer) {\n if (dir > 0) {\n if (this.index < buffer.buffer.buffer.length) return false;\n } else {\n for(let i = 0; i < this.index; i++)if (buffer.buffer.buffer[i + 3] < this.index) return false;\n }\n ({ index , parent } = buffer);\n } else ({ index , _parent: parent } = this._tree);\n for(; parent; { index , _parent: parent } = parent){\n if (index > -1) for(let i = index + dir, e = dir < 0 ? -1 : parent.node.children.length; i != e; i += dir){\n let child = parent.node.children[i];\n if (this.mode & 1 /* Full */ || child instanceof TreeBuffer || !child.type.isAnonymous || hasChild(child)) return false;\n }\n }\n return true;\n }\n move(dir, enter) {\n if (enter && this.enterChild(dir, 0, 4 /* DontCare */ )) return true;\n for(;;){\n if (this.sibling(dir)) return true;\n if (this.atLastNode(dir) || !this.parent()) return false;\n }\n }\n /// Move to the next node in a\n /// [pre-order](https://en.wikipedia.org/wiki/Tree_traversal#Pre-order_(NLR))\n /// traversal, going from a node to its first child or, if the\n /// current node is empty or `enter` is false, its next sibling or\n /// the next sibling of the first parent node that has one.\n next(enter = true) {\n return this.move(1, enter);\n }\n /// Move to the next node in a last-to-first pre-order traveral. A\n /// node is followed by its last child or, if it has none, its\n /// previous sibling or the previous sibling of the first parent\n /// node that has one.\n prev(enter = true) {\n return this.move(-1, enter);\n }\n /// Move the cursor to the innermost node that covers `pos`. If\n /// `side` is -1, it will enter nodes that end at `pos`. If it is 1,\n /// it will enter nodes that start at `pos`.\n moveTo(pos, side = 0) {\n // Move up to a node that actually holds the position, if possible\n while(this.from == this.to || (side < 1 ? this.from >= pos : this.from > pos) || (side > -1 ? this.to <= pos : this.to < pos))if (!this.parent()) break;\n // Then scan down into child nodes as far as possible\n while(this.enterChild(1, pos, side));\n return this;\n }\n /// Get a [syntax node](#common.SyntaxNode) at the cursor's current\n /// position.\n get node() {\n if (!this.buffer) return this._tree;\n let cache = this.bufferNode, result = null, depth = 0;\n if (cache && cache.context == this.buffer) scan: for(let index = this.index, d = this.stack.length; d >= 0;){\n for(let c = cache; c; c = c._parent)if (c.index == index) {\n if (index == this.index) return c;\n result = c;\n depth = d + 1;\n break scan;\n }\n index = this.stack[--d];\n }\n for(let i = depth; i < this.stack.length; i++)result = new BufferNode(this.buffer, result, this.stack[i]);\n return this.bufferNode = new BufferNode(this.buffer, result, this.index);\n }\n /// Get the [tree](#common.Tree) that represents the current node, if\n /// any. Will return null when the node is in a [tree\n /// buffer](#common.TreeBuffer).\n get tree() {\n return this.buffer ? null : this._tree.node;\n }\n}\nfunction hasChild(tree) {\n return tree.children.some((ch)=>ch instanceof TreeBuffer || !ch.type.isAnonymous || hasChild(ch)\n );\n}\nfunction buildTree(data1) {\n var _a;\n let { buffer: buffer1 , nodeSet , maxBufferLength =DefaultBufferLength , reused =[] , minRepeatType =nodeSet.types.length } = data1;\n let cursor = Array.isArray(buffer1) ? new FlatBufferCursor(buffer1, buffer1.length) : buffer1;\n let types = nodeSet.types;\n let contextHash = 0, lookAhead1 = 0;\n function takeNode(parentStart, minPos, children, positions, inRepeat) {\n let { id , start , end , size } = cursor;\n let lookAheadAtStart = lookAhead1;\n while(size < 0){\n cursor.next();\n if (size == -1 /* Reuse */ ) {\n let node = reused[id];\n children.push(node);\n positions.push(start - parentStart);\n return;\n } else if (size == -3 /* ContextChange */ ) {\n contextHash = id;\n return;\n } else if (size == -4 /* LookAhead */ ) {\n lookAhead1 = id;\n return;\n } else throw new RangeError(`Unrecognized record size: ${size}`);\n }\n let type = types[id], node, buffer;\n let startPos = start - parentStart;\n if (end - start <= maxBufferLength && (buffer = findBufferSize(cursor.pos - minPos, inRepeat))) {\n // Small enough for a buffer, and no reused nodes inside\n let data = new Uint16Array(buffer.size - buffer.skip);\n let endPos = cursor.pos - buffer.size, index = data.length;\n while(cursor.pos > endPos)index = copyToBuffer(buffer.start, data, index);\n node = new TreeBuffer(data, end - buffer.start, nodeSet);\n startPos = buffer.start - parentStart;\n } else {\n let endPos = cursor.pos - size;\n cursor.next();\n let localChildren = [], localPositions = [];\n let localInRepeat = id >= minRepeatType ? id : -1;\n let lastGroup = 0, lastEnd = end;\n while(cursor.pos > endPos)if (localInRepeat >= 0 && cursor.id == localInRepeat && cursor.size >= 0) {\n if (cursor.end <= lastEnd - maxBufferLength) {\n makeRepeatLeaf(localChildren, localPositions, start, lastGroup, cursor.end, lastEnd, localInRepeat, lookAheadAtStart);\n lastGroup = localChildren.length;\n lastEnd = cursor.end;\n }\n cursor.next();\n } else takeNode(start, endPos, localChildren, localPositions, localInRepeat);\n if (localInRepeat >= 0 && lastGroup > 0 && lastGroup < localChildren.length) makeRepeatLeaf(localChildren, localPositions, start, lastGroup, start, lastEnd, localInRepeat, lookAheadAtStart);\n localChildren.reverse();\n localPositions.reverse();\n if (localInRepeat > -1 && lastGroup > 0) {\n let make = makeBalanced(type);\n node = balanceRange(type, localChildren, localPositions, 0, localChildren.length, 0, end - start, make, make);\n } else node = makeTree(type, localChildren, localPositions, end - start, lookAheadAtStart - end);\n }\n children.push(node);\n positions.push(startPos);\n }\n function makeBalanced(type) {\n return (children, positions, length)=>{\n let lookAhead = 0, lastI = children.length - 1, last, lookAheadProp;\n if (lastI >= 0 && (last = children[lastI]) instanceof Tree) {\n if (!lastI && last.type == type && last.length == length) return last;\n if (lookAheadProp = last.prop(NodeProp.lookAhead)) lookAhead = positions[lastI] + last.length + lookAheadProp;\n }\n return makeTree(type, children, positions, length, lookAhead);\n };\n }\n function makeRepeatLeaf(children, positions, base, i, from, to, type, lookAhead) {\n let localChildren = [], localPositions = [];\n while(children.length > i){\n localChildren.push(children.pop());\n localPositions.push(positions.pop() + base - from);\n }\n children.push(makeTree(nodeSet.types[type], localChildren, localPositions, to - from, lookAhead - to));\n positions.push(from - base);\n }\n function makeTree(type, children, positions, length, lookAhead = 0, props) {\n if (contextHash) {\n let pair = [\n NodeProp.contextHash,\n contextHash\n ];\n props = props ? [\n pair\n ].concat(props) : [\n pair\n ];\n }\n if (lookAhead > 25) {\n let pair = [\n NodeProp.lookAhead,\n lookAhead\n ];\n props = props ? [\n pair\n ].concat(props) : [\n pair\n ];\n }\n return new Tree(type, children, positions, length, props);\n }\n function findBufferSize(maxSize, inRepeat) {\n // Scan through the buffer to find previous siblings that fit\n // together in a TreeBuffer, and don't contain any reused nodes\n // (which can't be stored in a buffer).\n // If `inRepeat` is > -1, ignore node boundaries of that type for\n // nesting, but make sure the end falls either at the start\n // (`maxSize`) or before such a node.\n let fork = cursor.fork();\n let size = 0, start = 0, skip = 0, minStart = fork.end - maxBufferLength;\n let result = {\n size: 0,\n start: 0,\n skip: 0\n };\n scan: for(let minPos = fork.pos - maxSize; fork.pos > minPos;){\n let nodeSize1 = fork.size;\n // Pretend nested repeat nodes of the same type don't exist\n if (fork.id == inRepeat && nodeSize1 >= 0) {\n // Except that we store the current state as a valid return\n // value.\n result.size = size;\n result.start = start;\n result.skip = skip;\n skip += 4;\n size += 4;\n fork.next();\n continue;\n }\n let startPos = fork.pos - nodeSize1;\n if (nodeSize1 < 0 || startPos < minPos || fork.start < minStart) break;\n let localSkipped = fork.id >= minRepeatType ? 4 : 0;\n let nodeStart = fork.start;\n fork.next();\n while(fork.pos > startPos){\n if (fork.size < 0) {\n if (fork.size == -3 /* ContextChange */ ) localSkipped += 4;\n else break scan;\n } else if (fork.id >= minRepeatType) localSkipped += 4;\n fork.next();\n }\n start = nodeStart;\n size += nodeSize1;\n skip += localSkipped;\n }\n if (inRepeat < 0 || size == maxSize) {\n result.size = size;\n result.start = start;\n result.skip = skip;\n }\n return result.size > 4 ? result : undefined;\n }\n function copyToBuffer(bufferStart, buffer, index) {\n let { id , start , end , size } = cursor;\n cursor.next();\n if (size >= 0 && id < minRepeatType) {\n let startIndex = index;\n if (size > 4) {\n let endPos = cursor.pos - (size - 4);\n while(cursor.pos > endPos)index = copyToBuffer(bufferStart, buffer, index);\n }\n buffer[--index] = startIndex;\n buffer[--index] = end - bufferStart;\n buffer[--index] = start - bufferStart;\n buffer[--index] = id;\n } else if (size == -3 /* ContextChange */ ) contextHash = id;\n else if (size == -4 /* LookAhead */ ) lookAhead1 = id;\n return index;\n }\n let children1 = [], positions1 = [];\n while(cursor.pos > 0)takeNode(data1.start || 0, data1.bufferStart || 0, children1, positions1, -1);\n let length1 = (_a = data1.length) !== null && _a !== void 0 ? _a : children1.length ? positions1[0] + children1[0].length : 0;\n return new Tree(types[data1.topID], children1.reverse(), positions1.reverse(), length1);\n}\nconst nodeSizeCache = new WeakMap;\nfunction nodeSize(balanceType, node) {\n if (!balanceType.isAnonymous || node instanceof TreeBuffer || node.type != balanceType) return 1;\n let size = nodeSizeCache.get(node);\n if (size == null) {\n size = 1;\n for (let child of node.children){\n if (child.type != balanceType || !(child instanceof Tree)) {\n size = 1;\n break;\n }\n size += nodeSize(balanceType, child);\n }\n nodeSizeCache.set(node, size);\n }\n return size;\n}\nfunction balanceRange(// The type the balanced tree's inner nodes.\nbalanceType, // The direct children and their positions\nchildren2, positions2, // The index range in children/positions to use\nfrom1, to1, // The start position of the nodes, relative to their parent.\nstart, // Length of the outer node\nlength2, // Function to build the top node of the balanced tree\nmkTop, // Function to build internal nodes for the balanced tree\nmkTree) {\n let total = 0;\n for(let i1 = from1; i1 < to1; i1++)total += nodeSize(balanceType, children2[i1]);\n let maxChild = Math.ceil(total * 1.5 / 8 /* BranchFactor */ );\n let localChildren = [], localPositions = [];\n function divide(children, positions, from, to, offset) {\n for(let i = from; i < to;){\n let groupFrom = i, groupStart = positions[i], groupSize = nodeSize(balanceType, children[i]);\n i++;\n for(; i < to; i++){\n let nextSize = nodeSize(balanceType, children[i]);\n if (groupSize + nextSize >= maxChild) break;\n groupSize += nextSize;\n }\n if (i == groupFrom + 1) {\n if (groupSize > maxChild) {\n let only = children[groupFrom]; // Only trees can have a size > 1\n divide(only.children, only.positions, 0, only.children.length, positions[groupFrom] + offset);\n continue;\n }\n localChildren.push(children[groupFrom]);\n } else {\n let length = positions[i - 1] + children[i - 1].length - groupStart;\n localChildren.push(balanceRange(balanceType, children, positions, groupFrom, i, groupStart, length, null, mkTree));\n }\n localPositions.push(groupStart + offset - start);\n }\n }\n divide(children2, positions2, from1, to1, 0);\n return (mkTop || mkTree)(localChildren, localPositions, length2);\n}\n/// Tree fragments are used during [incremental\n/// parsing](#common.Parser.startParse) to track parts of old trees\n/// that can be reused in a new parse. An array of fragments is used\n/// to track regions of an old tree whose nodes might be reused in new\n/// parses. Use the static\n/// [`applyChanges`](#common.TreeFragment^applyChanges) method to\n/// update fragments for document changes.\nclass TreeFragment {\n /// Construct a tree fragment.\n constructor(/// The start of the unchanged range pointed to by this fragment.\n /// This refers to an offset in the _updated_ document (as opposed\n /// to the original tree).\n from, /// The end of the unchanged range.\n to, /// The tree that this fragment is based on.\n tree, /// The offset between the fragment's tree and the document that\n /// this fragment can be used against. Add this when going from\n /// document to tree positions, subtract it to go from tree to\n /// document positions.\n offset, openStart = false, openEnd = false){\n this.from = from;\n this.to = to;\n this.tree = tree;\n this.offset = offset;\n this.open = (openStart ? 1 /* Start */ : 0) | (openEnd ? 2 /* End */ : 0);\n }\n /// Whether the start of the fragment represents the start of a\n /// parse, or the end of a change. (In the second case, it may not\n /// be safe to reuse some nodes at the start, depending on the\n /// parsing algorithm.)\n get openStart() {\n return (this.open & 1 /* Start */ ) > 0;\n }\n /// Whether the end of the fragment represents the end of a\n /// full-document parse, or the start of a change.\n get openEnd() {\n return (this.open & 2 /* End */ ) > 0;\n }\n /// Create a set of fragments from a freshly parsed tree, or update\n /// an existing set of fragments by replacing the ones that overlap\n /// with a tree with content from the new tree. When `partial` is\n /// true, the parse is treated as incomplete, and the resulting\n /// fragment has [`openEnd`](#common.TreeFragment.openEnd) set to\n /// true.\n static addTree(tree, fragments = [], partial = false) {\n let result = [\n new TreeFragment(0, tree.length, tree, 0, false, partial)\n ];\n for (let f of fragments)if (f.to > tree.length) result.push(f);\n return result;\n }\n /// Apply a set of edits to an array of fragments, removing or\n /// splitting fragments as necessary to remove edited ranges, and\n /// adjusting offsets for fragments that moved.\n static applyChanges(fragments, changes, minGap = 128) {\n if (!changes.length) return fragments;\n let result = [];\n let fI = 1, nextF = fragments.length ? fragments[0] : null;\n for(let cI = 0, pos = 0, off = 0;; cI++){\n let nextC = cI < changes.length ? changes[cI] : null;\n let nextPos = nextC ? nextC.fromA : 1000000000;\n if (nextPos - pos >= minGap) while(nextF && nextF.from < nextPos){\n let cut = nextF;\n if (pos >= cut.from || nextPos <= cut.to || off) {\n let fFrom = Math.max(cut.from, pos) - off, fTo = Math.min(cut.to, nextPos) - off;\n cut = fFrom >= fTo ? null : new TreeFragment(fFrom, fTo, cut.tree, cut.offset + off, cI > 0, !!nextC);\n }\n if (cut) result.push(cut);\n if (nextF.to > nextPos) break;\n nextF = fI < fragments.length ? fragments[fI++] : null;\n }\n if (!nextC) break;\n pos = nextC.toA;\n off = nextC.toA - nextC.toB;\n }\n return result;\n }\n}\n/// A superclass that parsers should extend.\nclass Parser {\n /// Start a parse, returning a [partial parse](#common.PartialParse)\n /// object. [`fragments`](#common.TreeFragment) can be passed in to\n /// make the parse incremental.\n ///\n /// By default, the entire input is parsed. You can pass `ranges`,\n /// which should be a sorted array of non-empty, non-overlapping\n /// ranges, to parse only those ranges. The tree returned in that\n /// case will start at `ranges[0].from`.\n startParse(input, fragments, ranges) {\n if (typeof input == \"string\") input = new StringInput(input);\n ranges = !ranges ? [\n new Range(0, input.length)\n ] : ranges.length ? ranges.map((r)=>new Range(r.from, r.to)\n ) : [\n new Range(0, 0)\n ];\n return this.createParse(input, fragments || [], ranges);\n }\n /// Run a full parse, returning the resulting tree.\n parse(input, fragments, ranges) {\n let parse = this.startParse(input, fragments, ranges);\n for(;;){\n let done = parse.advance();\n if (done) return done;\n }\n }\n}\nclass StringInput {\n constructor(string){\n this.string = string;\n }\n get length() {\n return this.string.length;\n }\n chunk(from) {\n return this.string.slice(from);\n }\n get lineChunks() {\n return false;\n }\n read(from, to) {\n return this.string.slice(from, to);\n }\n}\n/// Create a parse wrapper that, after the inner parse completes,\n/// scans its tree for mixed language regions with the `nest`\n/// function, runs the resulting [inner parses](#common.NestedParse),\n/// and then [mounts](#common.NodeProp^mounted) their results onto the\n/// tree.\n///\n/// The nesting function is passed a cursor to provide context for a\n/// node, but _should not_ move that cursor, only inspect its\n/// properties and optionally access its\n/// [node object](#common.TreeCursor.node).\nfunction parseMixed(nest) {\n return (parse, input, fragments, ranges)=>new MixedParse(parse, nest, input, fragments, ranges)\n ;\n}\nclass InnerParse {\n constructor(parser, parse, overlay, target, ranges){\n this.parser = parser;\n this.parse = parse;\n this.overlay = overlay;\n this.target = target;\n this.ranges = ranges;\n }\n}\nclass ActiveOverlay {\n constructor(parser, predicate, mounts, index, start, target, prev){\n this.parser = parser;\n this.predicate = predicate;\n this.mounts = mounts;\n this.index = index;\n this.start = start;\n this.target = target;\n this.prev = prev;\n this.depth = 0;\n this.ranges = [];\n }\n}\nconst stoppedInner = new NodeProp({\n perNode: true\n});\nclass MixedParse {\n constructor(base, nest, input, fragments, ranges){\n this.nest = nest;\n this.input = input;\n this.fragments = fragments;\n this.ranges = ranges;\n this.inner = [];\n this.innerDone = 0;\n this.baseTree = null;\n this.stoppedAt = null;\n this.baseParse = base;\n }\n advance() {\n if (this.baseParse) {\n let done = this.baseParse.advance();\n if (!done) return null;\n this.baseParse = null;\n this.baseTree = done;\n this.startInner();\n if (this.stoppedAt != null) for (let inner of this.inner)inner.parse.stopAt(this.stoppedAt);\n }\n if (this.innerDone == this.inner.length) {\n let result = this.baseTree;\n if (this.stoppedAt != null) result = new Tree(result.type, result.children, result.positions, result.length, result.propValues.concat([\n [\n stoppedInner,\n this.stoppedAt\n ]\n ]));\n return result;\n }\n let inner = this.inner[this.innerDone], done = inner.parse.advance();\n if (done) {\n this.innerDone++;\n // This is a somewhat dodgy but super helpful hack where we\n // patch up nodes created by the inner parse (and thus\n // presumably not aliased anywhere else) to hold the information\n // about the inner parse.\n let props = Object.assign(Object.create(null), inner.target.props);\n props[NodeProp.mounted.id] = new MountedTree(done, inner.overlay, inner.parser);\n inner.target.props = props;\n }\n return null;\n }\n get parsedPos() {\n if (this.baseParse) return 0;\n let pos = this.input.length;\n for(let i = this.innerDone; i < this.inner.length; i++)if (this.inner[i].ranges[0].from < pos) pos = Math.min(pos, this.inner[i].parse.parsedPos);\n return pos;\n }\n stopAt(pos) {\n this.stoppedAt = pos;\n if (this.baseParse) this.baseParse.stopAt(pos);\n else for(let i = this.innerDone; i < this.inner.length; i++)this.inner[i].parse.stopAt(pos);\n }\n startInner() {\n let fragmentCursor = new FragmentCursor(this.fragments);\n let overlay = null;\n let covered = null;\n let cursor = new TreeCursor(new TreeNode(this.baseTree, this.ranges[0].from, 0, null), 1 /* Full */ );\n for(let nest, isCovered; this.stoppedAt == null || cursor.from < this.stoppedAt;){\n let enter = true, range;\n if (fragmentCursor.hasNode(cursor)) {\n if (overlay) {\n let match = overlay.mounts.find((m)=>m.frag.from <= cursor.from && m.frag.to >= cursor.to && m.mount.overlay\n );\n if (match) for (let r of match.mount.overlay){\n let from = r.from + match.pos, to = r.to + match.pos;\n if (from >= cursor.from && to <= cursor.to) overlay.ranges.push({\n from,\n to\n });\n }\n }\n enter = false;\n } else if (covered && (isCovered = checkCover(covered.ranges, cursor.from, cursor.to))) enter = isCovered != 2 /* Full */ ;\n else if (!cursor.type.isAnonymous && cursor.from < cursor.to && (nest = this.nest(cursor, this.input))) {\n if (!cursor.tree) materialize(cursor);\n let oldMounts = fragmentCursor.findMounts(cursor.from, nest.parser);\n if (typeof nest.overlay == \"function\") overlay = new ActiveOverlay(nest.parser, nest.overlay, oldMounts, this.inner.length, cursor.from, cursor.tree, overlay);\n else {\n let ranges = punchRanges(this.ranges, nest.overlay || [\n new Range(cursor.from, cursor.to)\n ]);\n if (ranges.length) this.inner.push(new InnerParse(nest.parser, nest.parser.startParse(this.input, enterFragments(oldMounts, ranges), ranges), nest.overlay ? nest.overlay.map((r)=>new Range(r.from - cursor.from, r.to - cursor.from)\n ) : null, cursor.tree, ranges));\n if (!nest.overlay) enter = false;\n else if (ranges.length) covered = {\n ranges,\n depth: 0,\n prev: covered\n };\n }\n } else if (overlay && (range = overlay.predicate(cursor))) {\n if (range === true) range = new Range(cursor.from, cursor.to);\n if (range.from < range.to) overlay.ranges.push(range);\n }\n if (enter && cursor.firstChild()) {\n if (overlay) overlay.depth++;\n if (covered) covered.depth++;\n } else for(;;){\n if (cursor.nextSibling()) break;\n if (!cursor.parent()) return;\n if (overlay && !--overlay.depth) {\n let ranges = punchRanges(this.ranges, overlay.ranges);\n if (ranges.length) this.inner.splice(overlay.index, 0, new InnerParse(overlay.parser, overlay.parser.startParse(this.input, enterFragments(overlay.mounts, ranges), ranges), overlay.ranges.map((r)=>new Range(r.from - overlay.start, r.to - overlay.start)\n ), overlay.target, ranges));\n overlay = overlay.prev;\n }\n if (covered && !--covered.depth) covered = covered.prev;\n }\n }\n }\n}\nfunction checkCover(covered, from, to) {\n for (let range of covered){\n if (range.from >= to) break;\n if (range.to > from) return range.from <= from && range.to >= to ? 2 /* Full */ : 1 /* Partial */ ;\n }\n return 0 /* None */ ;\n}\n// Take a piece of buffer and convert it into a stand-alone\n// TreeBuffer.\nfunction sliceBuf(buf, startI, endI, nodes, positions, off) {\n if (startI < endI) {\n let from = buf.buffer[startI + 1], to = buf.buffer[endI - 2];\n nodes.push(buf.slice(startI, endI, from, to));\n positions.push(from - off);\n }\n}\n// This function takes a node that's in a buffer, and converts it, and\n// its parent buffer nodes, into a Tree. This is again acting on the\n// assumption that the trees and buffers have been constructed by the\n// parse that was ran via the mix parser, and thus aren't shared with\n// any other code, making violations of the immutability safe.\nfunction materialize(cursor) {\n let { node } = cursor, depth = 0;\n // Scan up to the nearest tree\n do {\n cursor.parent();\n depth++;\n }while (!cursor.tree)\n // Find the index of the buffer in that tree\n let i2 = 0, base = cursor.tree, off = 0;\n for(;; i2++){\n off = base.positions[i2] + cursor.from;\n if (off <= node.from && off + base.children[i2].length >= node.to) break;\n }\n let buf = base.children[i2], b = buf.buffer;\n // Split a level in the buffer, putting the nodes before and after\n // the child that contains `node` into new buffers.\n function split(startI, endI, type, innerOffset, length) {\n let i = startI;\n while(b[i + 2] + off <= node.from)i = b[i + 3];\n let children = [], positions = [];\n sliceBuf(buf, startI, i, children, positions, innerOffset);\n let from = b[i + 1], to = b[i + 2];\n let isTarget = from + off == node.from && to + off == node.to && b[i] == node.type.id;\n children.push(isTarget ? node.toTree() : split(i + 4, b[i + 3], buf.set.types[b[i]], from, to - from));\n positions.push(from - innerOffset);\n sliceBuf(buf, b[i + 3], endI, children, positions, innerOffset);\n return new Tree(type, children, positions, length);\n }\n base.children[i2] = split(0, b.length, NodeType.none, 0, buf.length);\n // Move the cursor back to the target node\n for(let d = 0; d <= depth; d++)cursor.childAfter(node.from);\n}\nclass StructureCursor {\n constructor(root, offset){\n this.offset = offset;\n this.done = false;\n this.cursor = root.fullCursor();\n }\n // Move to the first node (in pre-order) that starts at or after `pos`.\n moveTo(pos) {\n let { cursor } = this, p = pos - this.offset;\n while(!this.done && cursor.from < p){\n if (cursor.to >= pos && cursor.enter(p, 1, false, false)) ;\n else if (!cursor.next(false)) this.done = true;\n }\n }\n hasNode(cursor) {\n this.moveTo(cursor.from);\n if (!this.done && this.cursor.from + this.offset == cursor.from && this.cursor.tree) for(let tree = this.cursor.tree;;){\n if (tree == cursor.tree) return true;\n if (tree.children.length && tree.positions[0] == 0 && tree.children[0] instanceof Tree) tree = tree.children[0];\n else break;\n }\n return false;\n }\n}\nclass FragmentCursor {\n constructor(fragments){\n var _a;\n this.fragments = fragments;\n this.curTo = 0;\n this.fragI = 0;\n if (fragments.length) {\n let first = this.curFrag = fragments[0];\n this.curTo = (_a = first.tree.prop(stoppedInner)) !== null && _a !== void 0 ? _a : first.to;\n this.inner = new StructureCursor(first.tree, -first.offset);\n } else this.curFrag = this.inner = null;\n }\n hasNode(node) {\n while(this.curFrag && node.from >= this.curTo)this.nextFrag();\n return this.curFrag && this.curFrag.from <= node.from && this.curTo >= node.to && this.inner.hasNode(node);\n }\n nextFrag() {\n var _a;\n this.fragI++;\n if (this.fragI == this.fragments.length) this.curFrag = this.inner = null;\n else {\n let frag = this.curFrag = this.fragments[this.fragI];\n this.curTo = (_a = frag.tree.prop(stoppedInner)) !== null && _a !== void 0 ? _a : frag.to;\n this.inner = new StructureCursor(frag.tree, -frag.offset);\n }\n }\n findMounts(pos, parser) {\n var _a;\n let result = [];\n if (this.inner) {\n this.inner.cursor.moveTo(pos, 1);\n for(let pos1 = this.inner.cursor.node; pos1; pos1 = pos1.parent){\n let mount = (_a = pos1.tree) === null || _a === void 0 ? void 0 : _a.prop(NodeProp.mounted);\n if (mount && mount.parser == parser) for(let i = this.fragI; i < this.fragments.length; i++){\n let frag = this.fragments[i];\n if (frag.from >= pos1.to) break;\n if (frag.tree == this.curFrag.tree) result.push({\n frag,\n pos: pos1.from - frag.offset,\n mount\n });\n }\n }\n }\n return result;\n }\n}\nfunction punchRanges(outer, ranges) {\n let copy = null, current = ranges;\n for(let i = 1, j = 0; i < outer.length; i++){\n let gapFrom = outer[i - 1].to, gapTo = outer[i].from;\n for(; j < current.length; j++){\n let r = current[j];\n if (r.from >= gapTo) break;\n if (r.to <= gapFrom) continue;\n if (!copy) current = copy = ranges.slice();\n if (r.from < gapFrom) {\n copy[j] = new Range(r.from, gapFrom);\n if (r.to > gapTo) copy.splice(j + 1, 0, new Range(gapTo, r.to));\n } else if (r.to > gapTo) copy[j--] = new Range(gapTo, r.to);\n else copy.splice(j--, 1);\n }\n }\n return current;\n}\nfunction findCoverChanges(a, b, from, to) {\n let iA = 0, iB = 0, inA = false, inB = false, pos = -1000000000;\n let result = [];\n for(;;){\n let nextA = iA == a.length ? 1000000000 : inA ? a[iA].to : a[iA].from;\n let nextB = iB == b.length ? 1000000000 : inB ? b[iB].to : b[iB].from;\n if (inA != inB) {\n let start = Math.max(pos, from), end = Math.min(nextA, nextB, to);\n if (start < end) result.push(new Range(start, end));\n }\n pos = Math.min(nextA, nextB);\n if (pos == 1000000000) break;\n if (nextA == pos) {\n if (!inA) inA = true;\n else {\n inA = false;\n iA++;\n }\n }\n if (nextB == pos) {\n if (!inB) inB = true;\n else {\n inB = false;\n iB++;\n }\n }\n }\n return result;\n}\n// Given a number of fragments for the outer tree, and a set of ranges\n// to parse, find fragments for inner trees mounted around those\n// ranges, if any.\nfunction enterFragments(mounts, ranges) {\n let result = [];\n for (let { pos , mount , frag } of mounts){\n let startPos = pos + (mount.overlay ? mount.overlay[0].from : 0), endPos = startPos + mount.tree.length;\n let from = Math.max(frag.from, startPos), to = Math.min(frag.to, endPos);\n if (mount.overlay) {\n let overlay = mount.overlay.map((r)=>new Range(r.from + pos, r.to + pos)\n );\n let changes = findCoverChanges(ranges, overlay, from, to);\n for(let i = 0, pos2 = from;; i++){\n let last = i == changes.length, end = last ? to : changes[i].from;\n if (end > pos2) result.push(new TreeFragment(pos2, end, mount.tree, -startPos, frag.from >= pos2, frag.to <= end));\n if (last) break;\n pos2 = changes[i].to;\n }\n } else result.push(new TreeFragment(from, to, mount.tree, -startPos, frag.from >= startPos, frag.to <= endPos));\n }\n return result;\n}\n\n},{\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"kSxGE\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"closeBrackets\", ()=>closeBrackets\n);\nparcelHelpers.export(exports, \"closeBracketsKeymap\", ()=>closeBracketsKeymap\n);\nparcelHelpers.export(exports, \"deleteBracketPair\", ()=>deleteBracketPair\n);\nparcelHelpers.export(exports, \"insertBracket\", ()=>insertBracket\n);\nvar _view = require(\"@codemirror/view\");\nvar _state = require(\"@codemirror/state\");\nvar _rangeset = require(\"@codemirror/rangeset\");\nvar _text = require(\"@codemirror/text\");\nvar _language = require(\"@codemirror/language\");\nconst defaults = {\n brackets: [\n \"(\",\n \"[\",\n \"{\",\n \"'\",\n '\"'\n ],\n before: \")]}'\\\":;>\"\n};\nconst closeBracketEffect = /*@__PURE__*/ _state.StateEffect.define({\n map (value, mapping) {\n let mapped = mapping.mapPos(value, -1, _state.MapMode.TrackAfter);\n return mapped == null ? undefined : mapped;\n }\n});\nconst skipBracketEffect = /*@__PURE__*/ _state.StateEffect.define({\n map (value, mapping) {\n return mapping.mapPos(value);\n }\n});\nconst closedBracket = /*@__PURE__*/ new class extends _rangeset.RangeValue {\n};\nclosedBracket.startSide = 1;\nclosedBracket.endSide = -1;\nconst bracketState = /*@__PURE__*/ _state.StateField.define({\n create () {\n return _rangeset.RangeSet.empty;\n },\n update (value, tr) {\n if (tr.selection) {\n let lineStart = tr.state.doc.lineAt(tr.selection.main.head).from;\n let prevLineStart = tr.startState.doc.lineAt(tr.startState.selection.main.head).from;\n if (lineStart != tr.changes.mapPos(prevLineStart, -1)) value = _rangeset.RangeSet.empty;\n }\n value = value.map(tr.changes);\n for (let effect of tr.effects){\n if (effect.is(closeBracketEffect)) value = value.update({\n add: [\n closedBracket.range(effect.value, effect.value + 1)\n ]\n });\n else if (effect.is(skipBracketEffect)) value = value.update({\n filter: (from)=>from != effect.value\n });\n }\n return value;\n }\n});\n/**\nExtension to enable bracket-closing behavior. When a closeable\nbracket is typed, its closing bracket is immediately inserted\nafter the cursor. When closing a bracket directly in front of a\nclosing bracket inserted by the extension, the cursor moves over\nthat bracket.\n*/ function closeBrackets() {\n return [\n _view.EditorView.inputHandler.of(handleInput),\n bracketState\n ];\n}\nconst definedClosing = \"()[]{}<>\";\nfunction closing(ch) {\n for(let i = 0; i < definedClosing.length; i += 2)if (definedClosing.charCodeAt(i) == ch) return definedClosing.charAt(i + 1);\n return _text.fromCodePoint(ch < 128 ? ch : ch + 1);\n}\nfunction config(state, pos) {\n return state.languageDataAt(\"closeBrackets\", pos)[0] || defaults;\n}\nfunction handleInput(view, from, to, insert) {\n if (view.composing) return false;\n let sel = view.state.selection.main;\n if (insert.length > 2 || insert.length == 2 && _text.codePointSize(_text.codePointAt(insert, 0)) == 1 || from != sel.from || to != sel.to) return false;\n let tr = insertBracket(view.state, insert);\n if (!tr) return false;\n view.dispatch(tr);\n return true;\n}\n/**\nCommand that implements deleting a pair of matching brackets when\nthe cursor is between them.\n*/ const deleteBracketPair = ({ state , dispatch })=>{\n let conf = config(state, state.selection.main.head);\n let tokens = conf.brackets || defaults.brackets;\n let dont = null, changes = state.changeByRange((range)=>{\n if (range.empty) {\n let before = prevChar(state.doc, range.head);\n for (let token of tokens){\n if (token == before && nextChar(state.doc, range.head) == closing(_text.codePointAt(token, 0))) return {\n changes: {\n from: range.head - token.length,\n to: range.head + token.length\n },\n range: _state.EditorSelection.cursor(range.head - token.length),\n userEvent: \"delete.backward\"\n };\n }\n }\n return {\n range: dont = range\n };\n });\n if (!dont) dispatch(state.update(changes, {\n scrollIntoView: true\n }));\n return !dont;\n};\n/**\nClose-brackets related key bindings. Binds Backspace to\n[`deleteBracketPair`](https://codemirror.net/6/docs/ref/#closebrackets.deleteBracketPair).\n*/ const closeBracketsKeymap = [\n {\n key: \"Backspace\",\n run: deleteBracketPair\n }\n];\n/**\nImplements the extension's behavior on text insertion. If the\ngiven string counts as a bracket in the language around the\nselection, and replacing the selection with it requires custom\nbehavior (inserting a closing version or skipping past a\npreviously-closed bracket), this function returns a transaction\nrepresenting that custom behavior. (You only need this if you want\nto programmatically insert brackets\u2014the\n[`closeBrackets`](https://codemirror.net/6/docs/ref/#closebrackets.closeBrackets) extension will\ntake care of running this for user input.)\n*/ function insertBracket(state, bracket) {\n let conf = config(state, state.selection.main.head);\n let tokens = conf.brackets || defaults.brackets;\n for (let tok of tokens){\n let closed = closing(_text.codePointAt(tok, 0));\n if (bracket == tok) return closed == tok ? handleSame(state, tok, tokens.indexOf(tok + tok + tok) > -1) : handleOpen(state, tok, closed, conf.before || defaults.before);\n if (bracket == closed && closedBracketAt(state, state.selection.main.from)) return handleClose(state, tok, closed);\n }\n return null;\n}\nfunction closedBracketAt(state, pos) {\n let found = false;\n state.field(bracketState).between(0, state.doc.length, (from)=>{\n if (from == pos) found = true;\n });\n return found;\n}\nfunction nextChar(doc, pos) {\n let next = doc.sliceString(pos, pos + 2);\n return next.slice(0, _text.codePointSize(_text.codePointAt(next, 0)));\n}\nfunction prevChar(doc, pos) {\n let prev = doc.sliceString(pos - 2, pos);\n return _text.codePointSize(_text.codePointAt(prev, 0)) == prev.length ? prev : prev.slice(1);\n}\nfunction handleOpen(state, open, close, closeBefore) {\n let dont = null, changes = state.changeByRange((range)=>{\n if (!range.empty) return {\n changes: [\n {\n insert: open,\n from: range.from\n },\n {\n insert: close,\n from: range.to\n }\n ],\n effects: closeBracketEffect.of(range.to + open.length),\n range: _state.EditorSelection.range(range.anchor + open.length, range.head + open.length)\n };\n let next = nextChar(state.doc, range.head);\n if (!next || /\\s/.test(next) || closeBefore.indexOf(next) > -1) return {\n changes: {\n insert: open + close,\n from: range.head\n },\n effects: closeBracketEffect.of(range.head + open.length),\n range: _state.EditorSelection.cursor(range.head + open.length)\n };\n return {\n range: dont = range\n };\n });\n return dont ? null : state.update(changes, {\n scrollIntoView: true,\n userEvent: \"input.type\"\n });\n}\nfunction handleClose(state, _open, close) {\n let dont = null, moved = state.selection.ranges.map((range)=>{\n if (range.empty && nextChar(state.doc, range.head) == close) return _state.EditorSelection.cursor(range.head + close.length);\n return dont = range;\n });\n return dont ? null : state.update({\n selection: _state.EditorSelection.create(moved, state.selection.mainIndex),\n scrollIntoView: true,\n effects: state.selection.ranges.map(({ from })=>skipBracketEffect.of(from)\n )\n });\n}\n// Handles cases where the open and close token are the same, and\n// possibly triple quotes (as in `\"\"\"abc\"\"\"`-style quoting).\nfunction handleSame(state, token, allowTriple) {\n let dont = null, changes = state.changeByRange((range)=>{\n if (!range.empty) return {\n changes: [\n {\n insert: token,\n from: range.from\n },\n {\n insert: token,\n from: range.to\n }\n ],\n effects: closeBracketEffect.of(range.to + token.length),\n range: _state.EditorSelection.range(range.anchor + token.length, range.head + token.length)\n };\n let pos = range.head, next = nextChar(state.doc, pos);\n if (next == token) {\n if (nodeStart(state, pos)) return {\n changes: {\n insert: token + token,\n from: pos\n },\n effects: closeBracketEffect.of(pos + token.length),\n range: _state.EditorSelection.cursor(pos + token.length)\n };\n else if (closedBracketAt(state, pos)) {\n let isTriple = allowTriple && state.sliceDoc(pos, pos + token.length * 3) == token + token + token;\n return {\n range: _state.EditorSelection.cursor(pos + token.length * (isTriple ? 3 : 1)),\n effects: skipBracketEffect.of(pos)\n };\n }\n } else if (allowTriple && state.sliceDoc(pos - 2 * token.length, pos) == token + token && nodeStart(state, pos - 2 * token.length)) return {\n changes: {\n insert: token + token + token + token,\n from: pos\n },\n effects: closeBracketEffect.of(pos + token.length),\n range: _state.EditorSelection.cursor(pos + token.length)\n };\n else if (state.charCategorizer(pos)(next) != _state.CharCategory.Word) {\n let prev = state.sliceDoc(pos - 1, pos);\n if (prev != token && state.charCategorizer(pos)(prev) != _state.CharCategory.Word) return {\n changes: {\n insert: token + token,\n from: pos\n },\n effects: closeBracketEffect.of(pos + token.length),\n range: _state.EditorSelection.cursor(pos + token.length)\n };\n }\n return {\n range: dont = range\n };\n });\n return dont ? null : state.update(changes, {\n scrollIntoView: true,\n userEvent: \"input.type\"\n });\n}\nfunction nodeStart(state, pos) {\n let tree = _language.syntaxTree(state).resolveInner(pos + 1);\n return tree.parent && tree.from == pos;\n}\n\n},{\"@codemirror/view\":\"JuP5Z\",\"@codemirror/state\":\"e6FBl\",\"@codemirror/rangeset\":\"9yBpo\",\"@codemirror/text\":\"kn7DT\",\"@codemirror/language\":\"70QHL\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"jsegn\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"copyLineDown\", ()=>copyLineDown\n);\nparcelHelpers.export(exports, \"copyLineUp\", ()=>copyLineUp\n);\nparcelHelpers.export(exports, \"cursorCharBackward\", ()=>cursorCharBackward\n);\nparcelHelpers.export(exports, \"cursorCharForward\", ()=>cursorCharForward\n);\nparcelHelpers.export(exports, \"cursorCharLeft\", ()=>cursorCharLeft\n);\nparcelHelpers.export(exports, \"cursorCharRight\", ()=>cursorCharRight\n);\nparcelHelpers.export(exports, \"cursorDocEnd\", ()=>cursorDocEnd\n);\nparcelHelpers.export(exports, \"cursorDocStart\", ()=>cursorDocStart\n);\nparcelHelpers.export(exports, \"cursorGroupBackward\", ()=>cursorGroupBackward\n);\nparcelHelpers.export(exports, \"cursorGroupForward\", ()=>cursorGroupForward\n);\nparcelHelpers.export(exports, \"cursorGroupLeft\", ()=>cursorGroupLeft\n);\nparcelHelpers.export(exports, \"cursorGroupRight\", ()=>cursorGroupRight\n);\nparcelHelpers.export(exports, \"cursorLineBoundaryBackward\", ()=>cursorLineBoundaryBackward\n);\nparcelHelpers.export(exports, \"cursorLineBoundaryForward\", ()=>cursorLineBoundaryForward\n);\nparcelHelpers.export(exports, \"cursorLineDown\", ()=>cursorLineDown\n);\nparcelHelpers.export(exports, \"cursorLineEnd\", ()=>cursorLineEnd\n);\nparcelHelpers.export(exports, \"cursorLineStart\", ()=>cursorLineStart\n);\nparcelHelpers.export(exports, \"cursorLineUp\", ()=>cursorLineUp\n);\nparcelHelpers.export(exports, \"cursorMatchingBracket\", ()=>cursorMatchingBracket\n);\nparcelHelpers.export(exports, \"cursorPageDown\", ()=>cursorPageDown\n);\nparcelHelpers.export(exports, \"cursorPageUp\", ()=>cursorPageUp\n);\nparcelHelpers.export(exports, \"cursorSubwordBackward\", ()=>cursorSubwordBackward\n);\nparcelHelpers.export(exports, \"cursorSubwordForward\", ()=>cursorSubwordForward\n);\nparcelHelpers.export(exports, \"cursorSyntaxLeft\", ()=>cursorSyntaxLeft\n);\nparcelHelpers.export(exports, \"cursorSyntaxRight\", ()=>cursorSyntaxRight\n);\nparcelHelpers.export(exports, \"defaultKeymap\", ()=>defaultKeymap\n);\nparcelHelpers.export(exports, \"deleteCharBackward\", ()=>deleteCharBackward\n);\nparcelHelpers.export(exports, \"deleteCharForward\", ()=>deleteCharForward\n);\nparcelHelpers.export(exports, \"deleteGroupBackward\", ()=>deleteGroupBackward\n);\nparcelHelpers.export(exports, \"deleteGroupForward\", ()=>deleteGroupForward\n);\nparcelHelpers.export(exports, \"deleteLine\", ()=>deleteLine\n);\nparcelHelpers.export(exports, \"deleteToLineEnd\", ()=>deleteToLineEnd\n);\nparcelHelpers.export(exports, \"deleteToLineStart\", ()=>deleteToLineStart\n);\nparcelHelpers.export(exports, \"deleteTrailingWhitespace\", ()=>deleteTrailingWhitespace\n);\nparcelHelpers.export(exports, \"emacsStyleKeymap\", ()=>emacsStyleKeymap\n);\nparcelHelpers.export(exports, \"indentLess\", ()=>indentLess\n);\nparcelHelpers.export(exports, \"indentMore\", ()=>indentMore\n);\nparcelHelpers.export(exports, \"indentSelection\", ()=>indentSelection\n);\nparcelHelpers.export(exports, \"indentWithTab\", ()=>indentWithTab\n);\nparcelHelpers.export(exports, \"insertBlankLine\", ()=>insertBlankLine\n);\nparcelHelpers.export(exports, \"insertNewline\", ()=>insertNewline\n);\nparcelHelpers.export(exports, \"insertNewlineAndIndent\", ()=>insertNewlineAndIndent\n);\nparcelHelpers.export(exports, \"insertTab\", ()=>insertTab\n);\nparcelHelpers.export(exports, \"moveLineDown\", ()=>moveLineDown\n);\nparcelHelpers.export(exports, \"moveLineUp\", ()=>moveLineUp\n);\nparcelHelpers.export(exports, \"selectAll\", ()=>selectAll\n);\nparcelHelpers.export(exports, \"selectCharBackward\", ()=>selectCharBackward\n);\nparcelHelpers.export(exports, \"selectCharForward\", ()=>selectCharForward\n);\nparcelHelpers.export(exports, \"selectCharLeft\", ()=>selectCharLeft\n);\nparcelHelpers.export(exports, \"selectCharRight\", ()=>selectCharRight\n);\nparcelHelpers.export(exports, \"selectDocEnd\", ()=>selectDocEnd\n);\nparcelHelpers.export(exports, \"selectDocStart\", ()=>selectDocStart\n);\nparcelHelpers.export(exports, \"selectGroupBackward\", ()=>selectGroupBackward\n);\nparcelHelpers.export(exports, \"selectGroupForward\", ()=>selectGroupForward\n);\nparcelHelpers.export(exports, \"selectGroupLeft\", ()=>selectGroupLeft\n);\nparcelHelpers.export(exports, \"selectGroupRight\", ()=>selectGroupRight\n);\nparcelHelpers.export(exports, \"selectLine\", ()=>selectLine\n);\nparcelHelpers.export(exports, \"selectLineBoundaryBackward\", ()=>selectLineBoundaryBackward\n);\nparcelHelpers.export(exports, \"selectLineBoundaryForward\", ()=>selectLineBoundaryForward\n);\nparcelHelpers.export(exports, \"selectLineDown\", ()=>selectLineDown\n);\nparcelHelpers.export(exports, \"selectLineEnd\", ()=>selectLineEnd\n);\nparcelHelpers.export(exports, \"selectLineStart\", ()=>selectLineStart\n);\nparcelHelpers.export(exports, \"selectLineUp\", ()=>selectLineUp\n);\nparcelHelpers.export(exports, \"selectMatchingBracket\", ()=>selectMatchingBracket\n);\nparcelHelpers.export(exports, \"selectPageDown\", ()=>selectPageDown\n);\nparcelHelpers.export(exports, \"selectPageUp\", ()=>selectPageUp\n);\nparcelHelpers.export(exports, \"selectParentSyntax\", ()=>selectParentSyntax\n);\nparcelHelpers.export(exports, \"selectSubwordBackward\", ()=>selectSubwordBackward\n);\nparcelHelpers.export(exports, \"selectSubwordForward\", ()=>selectSubwordForward\n);\nparcelHelpers.export(exports, \"selectSyntaxLeft\", ()=>selectSyntaxLeft\n);\nparcelHelpers.export(exports, \"selectSyntaxRight\", ()=>selectSyntaxRight\n);\nparcelHelpers.export(exports, \"simplifySelection\", ()=>simplifySelection\n);\nparcelHelpers.export(exports, \"splitLine\", ()=>splitLine\n);\nparcelHelpers.export(exports, \"standardKeymap\", ()=>standardKeymap\n);\nparcelHelpers.export(exports, \"transposeChars\", ()=>transposeChars\n);\nvar _state = require(\"@codemirror/state\");\nvar _text = require(\"@codemirror/text\");\nvar _view = require(\"@codemirror/view\");\nvar _matchbrackets = require(\"@codemirror/matchbrackets\");\nvar _language = require(\"@codemirror/language\");\nvar _common = require(\"@lezer/common\");\nfunction updateSel(sel, by) {\n return _state.EditorSelection.create(sel.ranges.map(by), sel.mainIndex);\n}\nfunction setSel(state, selection) {\n return state.update({\n selection,\n scrollIntoView: true,\n userEvent: \"select\"\n });\n}\nfunction moveSel({ state , dispatch }, how) {\n let selection = updateSel(state.selection, how);\n if (selection.eq(state.selection)) return false;\n dispatch(setSel(state, selection));\n return true;\n}\nfunction rangeEnd(range, forward) {\n return _state.EditorSelection.cursor(forward ? range.to : range.from);\n}\nfunction cursorByChar(view, forward) {\n return moveSel(view, (range)=>range.empty ? view.moveByChar(range, forward) : rangeEnd(range, forward)\n );\n}\n/**\nMove the selection one character to the left (which is backward in\nleft-to-right text, forward in right-to-left text).\n*/ const cursorCharLeft = (view)=>cursorByChar(view, view.textDirection != _view.Direction.LTR)\n;\n/**\nMove the selection one character to the right.\n*/ const cursorCharRight = (view)=>cursorByChar(view, view.textDirection == _view.Direction.LTR)\n;\n/**\nMove the selection one character forward.\n*/ const cursorCharForward = (view)=>cursorByChar(view, true)\n;\n/**\nMove the selection one character backward.\n*/ const cursorCharBackward = (view)=>cursorByChar(view, false)\n;\nfunction cursorByGroup(view, forward) {\n return moveSel(view, (range)=>range.empty ? view.moveByGroup(range, forward) : rangeEnd(range, forward)\n );\n}\n/**\nMove the selection to the left across one group of word or\nnon-word (but also non-space) characters.\n*/ const cursorGroupLeft = (view)=>cursorByGroup(view, view.textDirection != _view.Direction.LTR)\n;\n/**\nMove the selection one group to the right.\n*/ const cursorGroupRight = (view)=>cursorByGroup(view, view.textDirection == _view.Direction.LTR)\n;\n/**\nMove the selection one group forward.\n*/ const cursorGroupForward = (view)=>cursorByGroup(view, true)\n;\n/**\nMove the selection one group backward.\n*/ const cursorGroupBackward = (view)=>cursorByGroup(view, false)\n;\nfunction moveBySubword(view, range, forward) {\n let categorize = view.state.charCategorizer(range.from);\n return view.moveByChar(range, forward, (start)=>{\n let cat = _state.CharCategory.Space, pos = range.from;\n let done = false, sawUpper = false, sawLower = false;\n let step = (next)=>{\n if (done) return false;\n pos += forward ? next.length : -next.length;\n let nextCat = categorize(next), ahead;\n if (cat == _state.CharCategory.Space) cat = nextCat;\n if (cat != nextCat) return false;\n if (cat == _state.CharCategory.Word) {\n if (next.toLowerCase() == next) {\n if (!forward && sawUpper) return false;\n sawLower = true;\n } else if (sawLower) {\n if (forward) return false;\n done = true;\n } else {\n if (sawUpper && forward && categorize(ahead = view.state.sliceDoc(pos, pos + 1)) == _state.CharCategory.Word && ahead.toLowerCase() == ahead) return false;\n sawUpper = true;\n }\n }\n return true;\n };\n step(start);\n return step;\n });\n}\nfunction cursorBySubword(view, forward) {\n return moveSel(view, (range)=>range.empty ? moveBySubword(view, range, forward) : rangeEnd(range, forward)\n );\n}\n/**\nMove the selection one group or camel-case subword forward.\n*/ const cursorSubwordForward = (view)=>cursorBySubword(view, true)\n;\n/**\nMove the selection one group or camel-case subword backward.\n*/ const cursorSubwordBackward = (view)=>cursorBySubword(view, false)\n;\nfunction interestingNode(state, node, bracketProp) {\n if (node.type.prop(bracketProp)) return true;\n let len = node.to - node.from;\n return len && (len > 2 || /[^\\s,.;:]/.test(state.sliceDoc(node.from, node.to))) || node.firstChild;\n}\nfunction moveBySyntax(state, start, forward) {\n let pos = _language.syntaxTree(state).resolveInner(start.head);\n let bracketProp = forward ? _common.NodeProp.closedBy : _common.NodeProp.openedBy;\n // Scan forward through child nodes to see if there's an interesting\n // node ahead.\n for(let at = start.head;;){\n let next = forward ? pos.childAfter(at) : pos.childBefore(at);\n if (!next) break;\n if (interestingNode(state, next, bracketProp)) pos = next;\n else at = forward ? next.to : next.from;\n }\n let bracket = pos.type.prop(bracketProp), match, newPos;\n if (bracket && (match = forward ? _matchbrackets.matchBrackets(state, pos.from, 1) : _matchbrackets.matchBrackets(state, pos.to, -1)) && match.matched) newPos = forward ? match.end.to : match.end.from;\n else newPos = forward ? pos.to : pos.from;\n return _state.EditorSelection.cursor(newPos, forward ? -1 : 1);\n}\n/**\nMove the cursor over the next syntactic element to the left.\n*/ const cursorSyntaxLeft = (view)=>moveSel(view, (range)=>moveBySyntax(view.state, range, view.textDirection != _view.Direction.LTR)\n )\n;\n/**\nMove the cursor over the next syntactic element to the right.\n*/ const cursorSyntaxRight = (view)=>moveSel(view, (range)=>moveBySyntax(view.state, range, view.textDirection == _view.Direction.LTR)\n )\n;\nfunction cursorByLine(view, forward) {\n return moveSel(view, (range)=>{\n if (!range.empty) return rangeEnd(range, forward);\n let moved = view.moveVertically(range, forward);\n return moved.head != range.head ? moved : view.moveToLineBoundary(range, forward);\n });\n}\n/**\nMove the selection one line up.\n*/ const cursorLineUp = (view)=>cursorByLine(view, false)\n;\n/**\nMove the selection one line down.\n*/ const cursorLineDown = (view)=>cursorByLine(view, true)\n;\nfunction cursorByPage(view, forward) {\n let { state } = view, selection = updateSel(state.selection, (range)=>{\n return range.empty ? view.moveVertically(range, forward, view.dom.clientHeight) : rangeEnd(range, forward);\n });\n if (selection.eq(state.selection)) return false;\n let startPos = view.coordsAtPos(state.selection.main.head);\n let scrollRect = view.scrollDOM.getBoundingClientRect();\n view.dispatch(setSel(state, selection), {\n effects: startPos && startPos.top > scrollRect.top && startPos.bottom < scrollRect.bottom ? _view.EditorView.scrollIntoView(selection.main.head, {\n y: \"start\",\n yMargin: startPos.top - scrollRect.top\n }) : undefined\n });\n return true;\n}\n/**\nMove the selection one page up.\n*/ const cursorPageUp = (view)=>cursorByPage(view, false)\n;\n/**\nMove the selection one page down.\n*/ const cursorPageDown = (view)=>cursorByPage(view, true)\n;\nfunction moveByLineBoundary(view, start, forward) {\n let line = view.lineBlockAt(start.head), moved = view.moveToLineBoundary(start, forward);\n if (moved.head == start.head && moved.head != (forward ? line.to : line.from)) moved = view.moveToLineBoundary(start, forward, false);\n if (!forward && moved.head == line.from && line.length) {\n let space = /^\\s*/.exec(view.state.sliceDoc(line.from, Math.min(line.from + 100, line.to)))[0].length;\n if (space && start.head != line.from + space) moved = _state.EditorSelection.cursor(line.from + space);\n }\n return moved;\n}\n/**\nMove the selection to the next line wrap point, or to the end of\nthe line if there isn't one left on this line.\n*/ const cursorLineBoundaryForward = (view)=>moveSel(view, (range)=>moveByLineBoundary(view, range, true)\n )\n;\n/**\nMove the selection to previous line wrap point, or failing that to\nthe start of the line. If the line is indented, and the cursor\nisn't already at the end of the indentation, this will move to the\nend of the indentation instead of the start of the line.\n*/ const cursorLineBoundaryBackward = (view)=>moveSel(view, (range)=>moveByLineBoundary(view, range, false)\n )\n;\n/**\nMove the selection to the start of the line.\n*/ const cursorLineStart = (view)=>moveSel(view, (range)=>_state.EditorSelection.cursor(view.lineBlockAt(range.head).from, 1)\n )\n;\n/**\nMove the selection to the end of the line.\n*/ const cursorLineEnd = (view)=>moveSel(view, (range)=>_state.EditorSelection.cursor(view.lineBlockAt(range.head).to, -1)\n )\n;\nfunction toMatchingBracket(state, dispatch, extend) {\n let found = false, selection = updateSel(state.selection, (range)=>{\n let matching = _matchbrackets.matchBrackets(state, range.head, -1) || _matchbrackets.matchBrackets(state, range.head, 1) || range.head > 0 && _matchbrackets.matchBrackets(state, range.head - 1, 1) || range.head < state.doc.length && _matchbrackets.matchBrackets(state, range.head + 1, -1);\n if (!matching || !matching.end) return range;\n found = true;\n let head = matching.start.from == range.head ? matching.end.to : matching.end.from;\n return extend ? _state.EditorSelection.range(range.anchor, head) : _state.EditorSelection.cursor(head);\n });\n if (!found) return false;\n dispatch(setSel(state, selection));\n return true;\n}\n/**\nMove the selection to the bracket matching the one it is currently\non, if any.\n*/ const cursorMatchingBracket = ({ state , dispatch })=>toMatchingBracket(state, dispatch, false)\n;\n/**\nExtend the selection to the bracket matching the one the selection\nhead is currently on, if any.\n*/ const selectMatchingBracket = ({ state , dispatch })=>toMatchingBracket(state, dispatch, true)\n;\nfunction extendSel(view, how) {\n let selection = updateSel(view.state.selection, (range)=>{\n let head = how(range);\n return _state.EditorSelection.range(range.anchor, head.head, head.goalColumn);\n });\n if (selection.eq(view.state.selection)) return false;\n view.dispatch(setSel(view.state, selection));\n return true;\n}\nfunction selectByChar(view, forward) {\n return extendSel(view, (range)=>view.moveByChar(range, forward)\n );\n}\n/**\nMove the selection head one character to the left, while leaving\nthe anchor in place.\n*/ const selectCharLeft = (view)=>selectByChar(view, view.textDirection != _view.Direction.LTR)\n;\n/**\nMove the selection head one character to the right.\n*/ const selectCharRight = (view)=>selectByChar(view, view.textDirection == _view.Direction.LTR)\n;\n/**\nMove the selection head one character forward.\n*/ const selectCharForward = (view)=>selectByChar(view, true)\n;\n/**\nMove the selection head one character backward.\n*/ const selectCharBackward = (view)=>selectByChar(view, false)\n;\nfunction selectByGroup(view, forward) {\n return extendSel(view, (range)=>view.moveByGroup(range, forward)\n );\n}\n/**\nMove the selection head one [group](https://codemirror.net/6/docs/ref/#commands.cursorGroupLeft) to\nthe left.\n*/ const selectGroupLeft = (view)=>selectByGroup(view, view.textDirection != _view.Direction.LTR)\n;\n/**\nMove the selection head one group to the right.\n*/ const selectGroupRight = (view)=>selectByGroup(view, view.textDirection == _view.Direction.LTR)\n;\n/**\nMove the selection head one group forward.\n*/ const selectGroupForward = (view)=>selectByGroup(view, true)\n;\n/**\nMove the selection head one group backward.\n*/ const selectGroupBackward = (view)=>selectByGroup(view, false)\n;\nfunction selectBySubword(view, forward) {\n return extendSel(view, (range)=>moveBySubword(view, range, forward)\n );\n}\n/**\nMove the selection head one group or camel-case subword forward.\n*/ const selectSubwordForward = (view)=>selectBySubword(view, true)\n;\n/**\nMove the selection head one group or subword backward.\n*/ const selectSubwordBackward = (view)=>selectBySubword(view, false)\n;\n/**\nMove the selection head over the next syntactic element to the left.\n*/ const selectSyntaxLeft = (view)=>extendSel(view, (range)=>moveBySyntax(view.state, range, view.textDirection != _view.Direction.LTR)\n )\n;\n/**\nMove the selection head over the next syntactic element to the right.\n*/ const selectSyntaxRight = (view)=>extendSel(view, (range)=>moveBySyntax(view.state, range, view.textDirection == _view.Direction.LTR)\n )\n;\nfunction selectByLine(view, forward) {\n return extendSel(view, (range)=>view.moveVertically(range, forward)\n );\n}\n/**\nMove the selection head one line up.\n*/ const selectLineUp = (view)=>selectByLine(view, false)\n;\n/**\nMove the selection head one line down.\n*/ const selectLineDown = (view)=>selectByLine(view, true)\n;\nfunction selectByPage(view, forward) {\n return extendSel(view, (range)=>view.moveVertically(range, forward, view.dom.clientHeight)\n );\n}\n/**\nMove the selection head one page up.\n*/ const selectPageUp = (view)=>selectByPage(view, false)\n;\n/**\nMove the selection head one page down.\n*/ const selectPageDown = (view)=>selectByPage(view, true)\n;\n/**\nMove the selection head to the next line boundary.\n*/ const selectLineBoundaryForward = (view)=>extendSel(view, (range)=>moveByLineBoundary(view, range, true)\n )\n;\n/**\nMove the selection head to the previous line boundary.\n*/ const selectLineBoundaryBackward = (view)=>extendSel(view, (range)=>moveByLineBoundary(view, range, false)\n )\n;\n/**\nMove the selection head to the start of the line.\n*/ const selectLineStart = (view)=>extendSel(view, (range)=>_state.EditorSelection.cursor(view.lineBlockAt(range.head).from)\n )\n;\n/**\nMove the selection head to the end of the line.\n*/ const selectLineEnd = (view)=>extendSel(view, (range)=>_state.EditorSelection.cursor(view.lineBlockAt(range.head).to)\n )\n;\n/**\nMove the selection to the start of the document.\n*/ const cursorDocStart = ({ state , dispatch })=>{\n dispatch(setSel(state, {\n anchor: 0\n }));\n return true;\n};\n/**\nMove the selection to the end of the document.\n*/ const cursorDocEnd = ({ state , dispatch })=>{\n dispatch(setSel(state, {\n anchor: state.doc.length\n }));\n return true;\n};\n/**\nMove the selection head to the start of the document.\n*/ const selectDocStart = ({ state , dispatch })=>{\n dispatch(setSel(state, {\n anchor: state.selection.main.anchor,\n head: 0\n }));\n return true;\n};\n/**\nMove the selection head to the end of the document.\n*/ const selectDocEnd = ({ state , dispatch })=>{\n dispatch(setSel(state, {\n anchor: state.selection.main.anchor,\n head: state.doc.length\n }));\n return true;\n};\n/**\nSelect the entire document.\n*/ const selectAll = ({ state , dispatch })=>{\n dispatch(state.update({\n selection: {\n anchor: 0,\n head: state.doc.length\n },\n userEvent: \"select\"\n }));\n return true;\n};\n/**\nExpand the selection to cover entire lines.\n*/ const selectLine = ({ state , dispatch })=>{\n let ranges = selectedLineBlocks(state).map(({ from , to })=>_state.EditorSelection.range(from, Math.min(to + 1, state.doc.length))\n );\n dispatch(state.update({\n selection: _state.EditorSelection.create(ranges),\n userEvent: \"select\"\n }));\n return true;\n};\n/**\nSelect the next syntactic construct that is larger than the\nselection. Note that this will only work insofar as the language\n[provider](https://codemirror.net/6/docs/ref/#language.language) you use builds up a full\nsyntax tree.\n*/ const selectParentSyntax = ({ state , dispatch })=>{\n let selection = updateSel(state.selection, (range)=>{\n var _a;\n let context = _language.syntaxTree(state).resolveInner(range.head, 1);\n while(!(context.from < range.from && context.to >= range.to || context.to > range.to && context.from <= range.from || !((_a = context.parent) === null || _a === void 0 ? void 0 : _a.parent)))context = context.parent;\n return _state.EditorSelection.range(context.to, context.from);\n });\n dispatch(setSel(state, selection));\n return true;\n};\n/**\nSimplify the current selection. When multiple ranges are selected,\nreduce it to its main range. Otherwise, if the selection is\nnon-empty, convert it to a cursor selection.\n*/ const simplifySelection = ({ state , dispatch })=>{\n let cur = state.selection, selection = null;\n if (cur.ranges.length > 1) selection = _state.EditorSelection.create([\n cur.main\n ]);\n else if (!cur.main.empty) selection = _state.EditorSelection.create([\n _state.EditorSelection.cursor(cur.main.head)\n ]);\n if (!selection) return false;\n dispatch(setSel(state, selection));\n return true;\n};\nfunction deleteBy({ state , dispatch }, by) {\n if (state.readOnly) return false;\n let event = \"delete.selection\";\n let changes = state.changeByRange((range)=>{\n let { from , to } = range;\n if (from == to) {\n let towards = by(from);\n if (towards < from) event = \"delete.backward\";\n else if (towards > from) event = \"delete.forward\";\n from = Math.min(from, towards);\n to = Math.max(to, towards);\n }\n return from == to ? {\n range\n } : {\n changes: {\n from,\n to\n },\n range: _state.EditorSelection.cursor(from)\n };\n });\n if (changes.changes.empty) return false;\n dispatch(state.update(changes, {\n scrollIntoView: true,\n userEvent: event\n }));\n return true;\n}\nfunction skipAtomic(target, pos, forward) {\n if (target instanceof _view.EditorView) for (let ranges of target.pluginField(_view.PluginField.atomicRanges))ranges.between(pos, pos, (from, to)=>{\n if (from < pos && to > pos) pos = forward ? to : from;\n });\n return pos;\n}\nconst deleteByChar = (target, forward)=>deleteBy(target, (pos)=>{\n let { state } = target, line = state.doc.lineAt(pos), before, targetPos;\n if (!forward && pos > line.from && pos < line.from + 200 && !/[^ \\t]/.test(before = line.text.slice(0, pos - line.from))) {\n if (before[before.length - 1] == \"\\t\") return pos - 1;\n let col = _text.countColumn(before, state.tabSize), drop = col % _language.getIndentUnit(state) || _language.getIndentUnit(state);\n for(let i = 0; i < drop && before[before.length - 1 - i] == \" \"; i++)pos--;\n targetPos = pos;\n } else {\n targetPos = _text.findClusterBreak(line.text, pos - line.from, forward, forward) + line.from;\n if (targetPos == pos && line.number != (forward ? state.doc.lines : 1)) targetPos += forward ? 1 : -1;\n }\n return skipAtomic(target, targetPos, forward);\n })\n;\n/**\nDelete the selection, or, for cursor selections, the character\nbefore the cursor.\n*/ const deleteCharBackward = (view)=>deleteByChar(view, false)\n;\n/**\nDelete the selection or the character after the cursor.\n*/ const deleteCharForward = (view)=>deleteByChar(view, true)\n;\nconst deleteByGroup = (target, forward)=>deleteBy(target, (start)=>{\n let pos = start, { state } = target, line = state.doc.lineAt(pos);\n let categorize = state.charCategorizer(pos);\n for(let cat = null;;){\n if (pos == (forward ? line.to : line.from)) {\n if (pos == start && line.number != (forward ? state.doc.lines : 1)) pos += forward ? 1 : -1;\n break;\n }\n let next = _text.findClusterBreak(line.text, pos - line.from, forward) + line.from;\n let nextChar = line.text.slice(Math.min(pos, next) - line.from, Math.max(pos, next) - line.from);\n let nextCat = categorize(nextChar);\n if (cat != null && nextCat != cat) break;\n if (nextChar != \" \" || pos != start) cat = nextCat;\n pos = next;\n }\n return skipAtomic(target, pos, forward);\n })\n;\n/**\nDelete the selection or backward until the end of the next\n[group](https://codemirror.net/6/docs/ref/#view.EditorView.moveByGroup), only skipping groups of\nwhitespace when they consist of a single space.\n*/ const deleteGroupBackward = (target)=>deleteByGroup(target, false)\n;\n/**\nDelete the selection or forward until the end of the next group.\n*/ const deleteGroupForward = (target)=>deleteByGroup(target, true)\n;\n/**\nDelete the selection, or, if it is a cursor selection, delete to\nthe end of the line. If the cursor is directly at the end of the\nline, delete the line break after it.\n*/ const deleteToLineEnd = (view)=>deleteBy(view, (pos)=>{\n let lineEnd = view.lineBlockAt(pos).to;\n return skipAtomic(view, pos < lineEnd ? lineEnd : Math.min(view.state.doc.length, pos + 1), true);\n })\n;\n/**\nDelete the selection, or, if it is a cursor selection, delete to\nthe start of the line. If the cursor is directly at the start of the\nline, delete the line break before it.\n*/ const deleteToLineStart = (view)=>deleteBy(view, (pos)=>{\n let lineStart = view.lineBlockAt(pos).from;\n return skipAtomic(view, pos > lineStart ? lineStart : Math.max(0, pos - 1), false);\n })\n;\n/**\nDelete all whitespace directly before a line end from the\ndocument.\n*/ const deleteTrailingWhitespace = ({ state , dispatch })=>{\n if (state.readOnly) return false;\n let changes = [];\n for(let pos = 0, prev = \"\", iter = state.doc.iter();;){\n iter.next();\n if (iter.lineBreak || iter.done) {\n let trailing = prev.search(/\\s+$/);\n if (trailing > -1) changes.push({\n from: pos - (prev.length - trailing),\n to: pos\n });\n if (iter.done) break;\n prev = \"\";\n } else prev = iter.value;\n pos += iter.value.length;\n }\n if (!changes.length) return false;\n dispatch(state.update({\n changes,\n userEvent: \"delete\"\n }));\n return true;\n};\n/**\nReplace each selection range with a line break, leaving the cursor\non the line before the break.\n*/ const splitLine = ({ state , dispatch })=>{\n if (state.readOnly) return false;\n let changes = state.changeByRange((range)=>{\n return {\n changes: {\n from: range.from,\n to: range.to,\n insert: _text.Text.of([\n \"\",\n \"\"\n ])\n },\n range: _state.EditorSelection.cursor(range.from)\n };\n });\n dispatch(state.update(changes, {\n scrollIntoView: true,\n userEvent: \"input\"\n }));\n return true;\n};\n/**\nFlip the characters before and after the cursor(s).\n*/ const transposeChars = ({ state , dispatch })=>{\n if (state.readOnly) return false;\n let changes = state.changeByRange((range)=>{\n if (!range.empty || range.from == 0 || range.from == state.doc.length) return {\n range\n };\n let pos = range.from, line = state.doc.lineAt(pos);\n let from = pos == line.from ? pos - 1 : _text.findClusterBreak(line.text, pos - line.from, false) + line.from;\n let to = pos == line.to ? pos + 1 : _text.findClusterBreak(line.text, pos - line.from, true) + line.from;\n return {\n changes: {\n from,\n to,\n insert: state.doc.slice(pos, to).append(state.doc.slice(from, pos))\n },\n range: _state.EditorSelection.cursor(to)\n };\n });\n if (changes.changes.empty) return false;\n dispatch(state.update(changes, {\n scrollIntoView: true,\n userEvent: \"move.character\"\n }));\n return true;\n};\nfunction selectedLineBlocks(state) {\n let blocks = [], upto = -1;\n for (let range of state.selection.ranges){\n let startLine = state.doc.lineAt(range.from), endLine = state.doc.lineAt(range.to);\n if (!range.empty && range.to == endLine.from) endLine = state.doc.lineAt(range.to - 1);\n if (upto >= startLine.number) {\n let prev = blocks[blocks.length - 1];\n prev.to = endLine.to;\n prev.ranges.push(range);\n } else blocks.push({\n from: startLine.from,\n to: endLine.to,\n ranges: [\n range\n ]\n });\n upto = endLine.number + 1;\n }\n return blocks;\n}\nfunction moveLine(state, dispatch, forward) {\n if (state.readOnly) return false;\n let changes = [], ranges = [];\n for (let block of selectedLineBlocks(state)){\n if (forward ? block.to == state.doc.length : block.from == 0) continue;\n let nextLine = state.doc.lineAt(forward ? block.to + 1 : block.from - 1);\n let size = nextLine.length + 1;\n if (forward) {\n changes.push({\n from: block.to,\n to: nextLine.to\n }, {\n from: block.from,\n insert: nextLine.text + state.lineBreak\n });\n for (let r of block.ranges)ranges.push(_state.EditorSelection.range(Math.min(state.doc.length, r.anchor + size), Math.min(state.doc.length, r.head + size)));\n } else {\n changes.push({\n from: nextLine.from,\n to: block.from\n }, {\n from: block.to,\n insert: state.lineBreak + nextLine.text\n });\n for (let r of block.ranges)ranges.push(_state.EditorSelection.range(r.anchor - size, r.head - size));\n }\n }\n if (!changes.length) return false;\n dispatch(state.update({\n changes,\n scrollIntoView: true,\n selection: _state.EditorSelection.create(ranges, state.selection.mainIndex),\n userEvent: \"move.line\"\n }));\n return true;\n}\n/**\nMove the selected lines up one line.\n*/ const moveLineUp = ({ state , dispatch })=>moveLine(state, dispatch, false)\n;\n/**\nMove the selected lines down one line.\n*/ const moveLineDown = ({ state , dispatch })=>moveLine(state, dispatch, true)\n;\nfunction copyLine(state, dispatch, forward) {\n if (state.readOnly) return false;\n let changes = [];\n for (let block of selectedLineBlocks(state))if (forward) changes.push({\n from: block.from,\n insert: state.doc.slice(block.from, block.to) + state.lineBreak\n });\n else changes.push({\n from: block.to,\n insert: state.lineBreak + state.doc.slice(block.from, block.to)\n });\n dispatch(state.update({\n changes,\n scrollIntoView: true,\n userEvent: \"input.copyline\"\n }));\n return true;\n}\n/**\nCreate a copy of the selected lines. Keep the selection in the top copy.\n*/ const copyLineUp = ({ state , dispatch })=>copyLine(state, dispatch, false)\n;\n/**\nCreate a copy of the selected lines. Keep the selection in the bottom copy.\n*/ const copyLineDown = ({ state , dispatch })=>copyLine(state, dispatch, true)\n;\n/**\nDelete selected lines.\n*/ const deleteLine = (view)=>{\n if (view.state.readOnly) return false;\n let { state } = view, changes = state.changes(selectedLineBlocks(state).map(({ from , to })=>{\n if (from > 0) from--;\n else if (to < state.doc.length) to++;\n return {\n from,\n to\n };\n }));\n let selection = updateSel(state.selection, (range)=>view.moveVertically(range, true)\n ).map(changes);\n view.dispatch({\n changes,\n selection,\n scrollIntoView: true,\n userEvent: \"delete.line\"\n });\n return true;\n};\n/**\nReplace the selection with a newline.\n*/ const insertNewline = ({ state , dispatch })=>{\n dispatch(state.update(state.replaceSelection(state.lineBreak), {\n scrollIntoView: true,\n userEvent: \"input\"\n }));\n return true;\n};\nfunction isBetweenBrackets(state, pos) {\n if (/\\(\\)|\\[\\]|\\{\\}/.test(state.sliceDoc(pos - 1, pos + 1))) return {\n from: pos,\n to: pos\n };\n let context = _language.syntaxTree(state).resolveInner(pos);\n let before = context.childBefore(pos), after = context.childAfter(pos), closedBy;\n if (before && after && before.to <= pos && after.from >= pos && (closedBy = before.type.prop(_common.NodeProp.closedBy)) && closedBy.indexOf(after.name) > -1 && state.doc.lineAt(before.to).from == state.doc.lineAt(after.from).from) return {\n from: before.to,\n to: after.from\n };\n return null;\n}\n/**\nReplace the selection with a newline and indent the newly created\nline(s). If the current line consists only of whitespace, this\nwill also delete that whitespace. When the cursor is between\nmatching brackets, an additional newline will be inserted after\nthe cursor.\n*/ const insertNewlineAndIndent = /*@__PURE__*/ newlineAndIndent(false);\n/**\nCreate a blank, indented line below the current line.\n*/ const insertBlankLine = /*@__PURE__*/ newlineAndIndent(true);\nfunction newlineAndIndent(atEof) {\n return ({ state , dispatch })=>{\n if (state.readOnly) return false;\n let changes = state.changeByRange((range)=>{\n let { from , to } = range, line = state.doc.lineAt(from);\n let explode = !atEof && from == to && isBetweenBrackets(state, from);\n if (atEof) from = to = (to <= line.to ? line : state.doc.lineAt(to)).to;\n let cx = new _language.IndentContext(state, {\n simulateBreak: from,\n simulateDoubleBreak: !!explode\n });\n let indent = _language.getIndentation(cx, from);\n if (indent == null) indent = /^\\s*/.exec(state.doc.lineAt(from).text)[0].length;\n while(to < line.to && /\\s/.test(line.text[to - line.from]))to++;\n if (explode) ({ from , to } = explode);\n else if (from > line.from && from < line.from + 100 && !/\\S/.test(line.text.slice(0, from))) from = line.from;\n let insert = [\n \"\",\n _language.indentString(state, indent)\n ];\n if (explode) insert.push(_language.indentString(state, cx.lineIndent(line.from, -1)));\n return {\n changes: {\n from,\n to,\n insert: _text.Text.of(insert)\n },\n range: _state.EditorSelection.cursor(from + 1 + insert[1].length)\n };\n });\n dispatch(state.update(changes, {\n scrollIntoView: true,\n userEvent: \"input\"\n }));\n return true;\n };\n}\nfunction changeBySelectedLine(state, f) {\n let atLine = -1;\n return state.changeByRange((range)=>{\n let changes = [];\n for(let pos = range.from; pos <= range.to;){\n let line = state.doc.lineAt(pos);\n if (line.number > atLine && (range.empty || range.to > line.from)) {\n f(line, changes, range);\n atLine = line.number;\n }\n pos = line.to + 1;\n }\n let changeSet = state.changes(changes);\n return {\n changes,\n range: _state.EditorSelection.range(changeSet.mapPos(range.anchor, 1), changeSet.mapPos(range.head, 1))\n };\n });\n}\n/**\nAuto-indent the selected lines. This uses the [indentation service\nfacet](https://codemirror.net/6/docs/ref/#language.indentService) as source for auto-indent\ninformation.\n*/ const indentSelection = ({ state , dispatch })=>{\n if (state.readOnly) return false;\n let updated = Object.create(null);\n let context = new _language.IndentContext(state, {\n overrideIndentation: (start)=>{\n let found = updated[start];\n return found == null ? -1 : found;\n }\n });\n let changes1 = changeBySelectedLine(state, (line, changes, range)=>{\n let indent = _language.getIndentation(context, line.from);\n if (indent == null) return;\n if (!/\\S/.test(line.text)) indent = 0;\n let cur = /^\\s*/.exec(line.text)[0];\n let norm = _language.indentString(state, indent);\n if (cur != norm || range.from < line.from + cur.length) {\n updated[line.from] = indent;\n changes.push({\n from: line.from,\n to: line.from + cur.length,\n insert: norm\n });\n }\n });\n if (!changes1.changes.empty) dispatch(state.update(changes1, {\n userEvent: \"indent\"\n }));\n return true;\n};\n/**\nAdd a [unit](https://codemirror.net/6/docs/ref/#language.indentUnit) of indentation to all selected\nlines.\n*/ const indentMore = ({ state , dispatch })=>{\n if (state.readOnly) return false;\n dispatch(state.update(changeBySelectedLine(state, (line, changes)=>{\n changes.push({\n from: line.from,\n insert: state.facet(_language.indentUnit)\n });\n }), {\n userEvent: \"input.indent\"\n }));\n return true;\n};\n/**\nRemove a [unit](https://codemirror.net/6/docs/ref/#language.indentUnit) of indentation from all\nselected lines.\n*/ const indentLess = ({ state , dispatch })=>{\n if (state.readOnly) return false;\n dispatch(state.update(changeBySelectedLine(state, (line, changes)=>{\n let space = /^\\s*/.exec(line.text)[0];\n if (!space) return;\n let col = _text.countColumn(space, state.tabSize), keep = 0;\n let insert = _language.indentString(state, Math.max(0, col - _language.getIndentUnit(state)));\n while(keep < space.length && keep < insert.length && space.charCodeAt(keep) == insert.charCodeAt(keep))keep++;\n changes.push({\n from: line.from + keep,\n to: line.from + space.length,\n insert: insert.slice(keep)\n });\n }), {\n userEvent: \"delete.dedent\"\n }));\n return true;\n};\n/**\nInsert a tab character at the cursor or, if something is selected,\nuse [`indentMore`](https://codemirror.net/6/docs/ref/#commands.indentMore) to indent the entire\nselection.\n*/ const insertTab = ({ state , dispatch })=>{\n if (state.selection.ranges.some((r)=>!r.empty\n )) return indentMore({\n state,\n dispatch\n });\n dispatch(state.update(state.replaceSelection(\"\\t\"), {\n scrollIntoView: true,\n userEvent: \"input\"\n }));\n return true;\n};\n/**\nArray of key bindings containing the Emacs-style bindings that are\navailable on macOS by default.\n\n - Ctrl-b: [`cursorCharLeft`](https://codemirror.net/6/docs/ref/#commands.cursorCharLeft) ([`selectCharLeft`](https://codemirror.net/6/docs/ref/#commands.selectCharLeft) with Shift)\n - Ctrl-f: [`cursorCharRight`](https://codemirror.net/6/docs/ref/#commands.cursorCharRight) ([`selectCharRight`](https://codemirror.net/6/docs/ref/#commands.selectCharRight) with Shift)\n - Ctrl-p: [`cursorLineUp`](https://codemirror.net/6/docs/ref/#commands.cursorLineUp) ([`selectLineUp`](https://codemirror.net/6/docs/ref/#commands.selectLineUp) with Shift)\n - Ctrl-n: [`cursorLineDown`](https://codemirror.net/6/docs/ref/#commands.cursorLineDown) ([`selectLineDown`](https://codemirror.net/6/docs/ref/#commands.selectLineDown) with Shift)\n - Ctrl-a: [`cursorLineStart`](https://codemirror.net/6/docs/ref/#commands.cursorLineStart) ([`selectLineStart`](https://codemirror.net/6/docs/ref/#commands.selectLineStart) with Shift)\n - Ctrl-e: [`cursorLineEnd`](https://codemirror.net/6/docs/ref/#commands.cursorLineEnd) ([`selectLineEnd`](https://codemirror.net/6/docs/ref/#commands.selectLineEnd) with Shift)\n - Ctrl-d: [`deleteCharForward`](https://codemirror.net/6/docs/ref/#commands.deleteCharForward)\n - Ctrl-h: [`deleteCharBackward`](https://codemirror.net/6/docs/ref/#commands.deleteCharBackward)\n - Ctrl-k: [`deleteToLineEnd`](https://codemirror.net/6/docs/ref/#commands.deleteToLineEnd)\n - Ctrl-Alt-h: [`deleteGroupBackward`](https://codemirror.net/6/docs/ref/#commands.deleteGroupBackward)\n - Ctrl-o: [`splitLine`](https://codemirror.net/6/docs/ref/#commands.splitLine)\n - Ctrl-t: [`transposeChars`](https://codemirror.net/6/docs/ref/#commands.transposeChars)\n - Ctrl-v: [`cursorPageDown`](https://codemirror.net/6/docs/ref/#commands.cursorPageDown)\n - Alt-v: [`cursorPageUp`](https://codemirror.net/6/docs/ref/#commands.cursorPageUp)\n*/ const emacsStyleKeymap = [\n {\n key: \"Ctrl-b\",\n run: cursorCharLeft,\n shift: selectCharLeft,\n preventDefault: true\n },\n {\n key: \"Ctrl-f\",\n run: cursorCharRight,\n shift: selectCharRight\n },\n {\n key: \"Ctrl-p\",\n run: cursorLineUp,\n shift: selectLineUp\n },\n {\n key: \"Ctrl-n\",\n run: cursorLineDown,\n shift: selectLineDown\n },\n {\n key: \"Ctrl-a\",\n run: cursorLineStart,\n shift: selectLineStart\n },\n {\n key: \"Ctrl-e\",\n run: cursorLineEnd,\n shift: selectLineEnd\n },\n {\n key: \"Ctrl-d\",\n run: deleteCharForward\n },\n {\n key: \"Ctrl-h\",\n run: deleteCharBackward\n },\n {\n key: \"Ctrl-k\",\n run: deleteToLineEnd\n },\n {\n key: \"Ctrl-Alt-h\",\n run: deleteGroupBackward\n },\n {\n key: \"Ctrl-o\",\n run: splitLine\n },\n {\n key: \"Ctrl-t\",\n run: transposeChars\n },\n {\n key: \"Ctrl-v\",\n run: cursorPageDown\n }, \n];\n/**\nAn array of key bindings closely sticking to platform-standard or\nwidely used bindings. (This includes the bindings from\n[`emacsStyleKeymap`](https://codemirror.net/6/docs/ref/#commands.emacsStyleKeymap), with their `key`\nproperty changed to `mac`.)\n\n - ArrowLeft: [`cursorCharLeft`](https://codemirror.net/6/docs/ref/#commands.cursorCharLeft) ([`selectCharLeft`](https://codemirror.net/6/docs/ref/#commands.selectCharLeft) with Shift)\n - ArrowRight: [`cursorCharRight`](https://codemirror.net/6/docs/ref/#commands.cursorCharRight) ([`selectCharRight`](https://codemirror.net/6/docs/ref/#commands.selectCharRight) with Shift)\n - Ctrl-ArrowLeft (Alt-ArrowLeft on macOS): [`cursorGroupLeft`](https://codemirror.net/6/docs/ref/#commands.cursorGroupLeft) ([`selectGroupLeft`](https://codemirror.net/6/docs/ref/#commands.selectGroupLeft) with Shift)\n - Ctrl-ArrowRight (Alt-ArrowRight on macOS): [`cursorGroupRight`](https://codemirror.net/6/docs/ref/#commands.cursorGroupRight) ([`selectGroupRight`](https://codemirror.net/6/docs/ref/#commands.selectGroupRight) with Shift)\n - Cmd-ArrowLeft (on macOS): [`cursorLineStart`](https://codemirror.net/6/docs/ref/#commands.cursorLineStart) ([`selectLineStart`](https://codemirror.net/6/docs/ref/#commands.selectLineStart) with Shift)\n - Cmd-ArrowRight (on macOS): [`cursorLineEnd`](https://codemirror.net/6/docs/ref/#commands.cursorLineEnd) ([`selectLineEnd`](https://codemirror.net/6/docs/ref/#commands.selectLineEnd) with Shift)\n - ArrowUp: [`cursorLineUp`](https://codemirror.net/6/docs/ref/#commands.cursorLineUp) ([`selectLineUp`](https://codemirror.net/6/docs/ref/#commands.selectLineUp) with Shift)\n - ArrowDown: [`cursorLineDown`](https://codemirror.net/6/docs/ref/#commands.cursorLineDown) ([`selectLineDown`](https://codemirror.net/6/docs/ref/#commands.selectLineDown) with Shift)\n - Cmd-ArrowUp (on macOS): [`cursorDocStart`](https://codemirror.net/6/docs/ref/#commands.cursorDocStart) ([`selectDocStart`](https://codemirror.net/6/docs/ref/#commands.selectDocStart) with Shift)\n - Cmd-ArrowDown (on macOS): [`cursorDocEnd`](https://codemirror.net/6/docs/ref/#commands.cursorDocEnd) ([`selectDocEnd`](https://codemirror.net/6/docs/ref/#commands.selectDocEnd) with Shift)\n - Ctrl-ArrowUp (on macOS): [`cursorPageUp`](https://codemirror.net/6/docs/ref/#commands.cursorPageUp) ([`selectPageUp`](https://codemirror.net/6/docs/ref/#commands.selectPageUp) with Shift)\n - Ctrl-ArrowDown (on macOS): [`cursorPageDown`](https://codemirror.net/6/docs/ref/#commands.cursorPageDown) ([`selectPageDown`](https://codemirror.net/6/docs/ref/#commands.selectPageDown) with Shift)\n - PageUp: [`cursorPageUp`](https://codemirror.net/6/docs/ref/#commands.cursorPageUp) ([`selectPageUp`](https://codemirror.net/6/docs/ref/#commands.selectPageUp) with Shift)\n - PageDown: [`cursorPageDown`](https://codemirror.net/6/docs/ref/#commands.cursorPageDown) ([`selectPageDown`](https://codemirror.net/6/docs/ref/#commands.selectPageDown) with Shift)\n - Home: [`cursorLineBoundaryBackward`](https://codemirror.net/6/docs/ref/#commands.cursorLineBoundaryBackward) ([`selectLineBoundaryBackward`](https://codemirror.net/6/docs/ref/#commands.selectLineBoundaryBackward) with Shift)\n - End: [`cursorLineBoundaryForward`](https://codemirror.net/6/docs/ref/#commands.cursorLineBoundaryForward) ([`selectLineBoundaryForward`](https://codemirror.net/6/docs/ref/#commands.selectLineBoundaryForward) with Shift)\n - Ctrl-Home (Cmd-Home on macOS): [`cursorDocStart`](https://codemirror.net/6/docs/ref/#commands.cursorDocStart) ([`selectDocStart`](https://codemirror.net/6/docs/ref/#commands.selectDocStart) with Shift)\n - Ctrl-End (Cmd-Home on macOS): [`cursorDocEnd`](https://codemirror.net/6/docs/ref/#commands.cursorDocEnd) ([`selectDocEnd`](https://codemirror.net/6/docs/ref/#commands.selectDocEnd) with Shift)\n - Enter: [`insertNewlineAndIndent`](https://codemirror.net/6/docs/ref/#commands.insertNewlineAndIndent)\n - Ctrl-a (Cmd-a on macOS): [`selectAll`](https://codemirror.net/6/docs/ref/#commands.selectAll)\n - Backspace: [`deleteCharBackward`](https://codemirror.net/6/docs/ref/#commands.deleteCharBackward)\n - Delete: [`deleteCharForward`](https://codemirror.net/6/docs/ref/#commands.deleteCharForward)\n - Ctrl-Backspace (Alt-Backspace on macOS): [`deleteGroupBackward`](https://codemirror.net/6/docs/ref/#commands.deleteGroupBackward)\n - Ctrl-Delete (Alt-Delete on macOS): [`deleteGroupForward`](https://codemirror.net/6/docs/ref/#commands.deleteGroupForward)\n - Cmd-Backspace (macOS): [`deleteToLineStart`](https://codemirror.net/6/docs/ref/#commands.deleteToLineStart).\n - Cmd-Delete (macOS): [`deleteToLineEnd`](https://codemirror.net/6/docs/ref/#commands.deleteToLineEnd).\n*/ const standardKeymap = /*@__PURE__*/ [\n {\n key: \"ArrowLeft\",\n run: cursorCharLeft,\n shift: selectCharLeft,\n preventDefault: true\n },\n {\n key: \"Mod-ArrowLeft\",\n mac: \"Alt-ArrowLeft\",\n run: cursorGroupLeft,\n shift: selectGroupLeft\n },\n {\n mac: \"Cmd-ArrowLeft\",\n run: cursorLineBoundaryBackward,\n shift: selectLineBoundaryBackward\n },\n {\n key: \"ArrowRight\",\n run: cursorCharRight,\n shift: selectCharRight,\n preventDefault: true\n },\n {\n key: \"Mod-ArrowRight\",\n mac: \"Alt-ArrowRight\",\n run: cursorGroupRight,\n shift: selectGroupRight\n },\n {\n mac: \"Cmd-ArrowRight\",\n run: cursorLineBoundaryForward,\n shift: selectLineBoundaryForward\n },\n {\n key: \"ArrowUp\",\n run: cursorLineUp,\n shift: selectLineUp,\n preventDefault: true\n },\n {\n mac: \"Cmd-ArrowUp\",\n run: cursorDocStart,\n shift: selectDocStart\n },\n {\n mac: \"Ctrl-ArrowUp\",\n run: cursorPageUp,\n shift: selectPageUp\n },\n {\n key: \"ArrowDown\",\n run: cursorLineDown,\n shift: selectLineDown,\n preventDefault: true\n },\n {\n mac: \"Cmd-ArrowDown\",\n run: cursorDocEnd,\n shift: selectDocEnd\n },\n {\n mac: \"Ctrl-ArrowDown\",\n run: cursorPageDown,\n shift: selectPageDown\n },\n {\n key: \"PageUp\",\n run: cursorPageUp,\n shift: selectPageUp\n },\n {\n key: \"PageDown\",\n run: cursorPageDown,\n shift: selectPageDown\n },\n {\n key: \"Home\",\n run: cursorLineBoundaryBackward,\n shift: selectLineBoundaryBackward\n },\n {\n key: \"Mod-Home\",\n run: cursorDocStart,\n shift: selectDocStart\n },\n {\n key: \"End\",\n run: cursorLineBoundaryForward,\n shift: selectLineBoundaryForward\n },\n {\n key: \"Mod-End\",\n run: cursorDocEnd,\n shift: selectDocEnd\n },\n {\n key: \"Enter\",\n run: insertNewlineAndIndent\n },\n {\n key: \"Mod-a\",\n run: selectAll\n },\n {\n key: \"Backspace\",\n run: deleteCharBackward,\n shift: deleteCharBackward\n },\n {\n key: \"Delete\",\n run: deleteCharForward\n },\n {\n key: \"Mod-Backspace\",\n mac: \"Alt-Backspace\",\n run: deleteGroupBackward\n },\n {\n key: \"Mod-Delete\",\n mac: \"Alt-Delete\",\n run: deleteGroupForward\n },\n {\n mac: \"Mod-Backspace\",\n run: deleteToLineStart\n },\n {\n mac: \"Mod-Delete\",\n run: deleteToLineEnd\n }\n].concat(/*@__PURE__*/ emacsStyleKeymap.map((b)=>({\n mac: b.key,\n run: b.run,\n shift: b.shift\n })\n));\n/**\nThe default keymap. Includes all bindings from\n[`standardKeymap`](https://codemirror.net/6/docs/ref/#commands.standardKeymap) plus the following:\n\n- Alt-ArrowLeft (Ctrl-ArrowLeft on macOS): [`cursorSyntaxLeft`](https://codemirror.net/6/docs/ref/#commands.cursorSyntaxLeft) ([`selectSyntaxLeft`](https://codemirror.net/6/docs/ref/#commands.selectSyntaxLeft) with Shift)\n- Alt-ArrowRight (Ctrl-ArrowRight on macOS): [`cursorSyntaxRight`](https://codemirror.net/6/docs/ref/#commands.cursorSyntaxRight) ([`selectSyntaxRight`](https://codemirror.net/6/docs/ref/#commands.selectSyntaxRight) with Shift)\n- Alt-ArrowUp: [`moveLineUp`](https://codemirror.net/6/docs/ref/#commands.moveLineUp)\n- Alt-ArrowDown: [`moveLineDown`](https://codemirror.net/6/docs/ref/#commands.moveLineDown)\n- Shift-Alt-ArrowUp: [`copyLineUp`](https://codemirror.net/6/docs/ref/#commands.copyLineUp)\n- Shift-Alt-ArrowDown: [`copyLineDown`](https://codemirror.net/6/docs/ref/#commands.copyLineDown)\n- Escape: [`simplifySelection`](https://codemirror.net/6/docs/ref/#commands.simplifySelection)\n- Ctrl-Enter (Comd-Enter on macOS): [`insertBlankLine`](https://codemirror.net/6/docs/ref/#commands.insertBlankLine)\n- Alt-l (Ctrl-l on macOS): [`selectLine`](https://codemirror.net/6/docs/ref/#commands.selectLine)\n- Ctrl-i (Cmd-i on macOS): [`selectParentSyntax`](https://codemirror.net/6/docs/ref/#commands.selectParentSyntax)\n- Ctrl-[ (Cmd-[ on macOS): [`indentLess`](https://codemirror.net/6/docs/ref/#commands.indentLess)\n- Ctrl-] (Cmd-] on macOS): [`indentMore`](https://codemirror.net/6/docs/ref/#commands.indentMore)\n- Ctrl-Alt-\\\\ (Cmd-Alt-\\\\ on macOS): [`indentSelection`](https://codemirror.net/6/docs/ref/#commands.indentSelection)\n- Shift-Ctrl-k (Shift-Cmd-k on macOS): [`deleteLine`](https://codemirror.net/6/docs/ref/#commands.deleteLine)\n- Shift-Ctrl-\\\\ (Shift-Cmd-\\\\ on macOS): [`cursorMatchingBracket`](https://codemirror.net/6/docs/ref/#commands.cursorMatchingBracket)\n*/ const defaultKeymap = /*@__PURE__*/ [\n {\n key: \"Alt-ArrowLeft\",\n mac: \"Ctrl-ArrowLeft\",\n run: cursorSyntaxLeft,\n shift: selectSyntaxLeft\n },\n {\n key: \"Alt-ArrowRight\",\n mac: \"Ctrl-ArrowRight\",\n run: cursorSyntaxRight,\n shift: selectSyntaxRight\n },\n {\n key: \"Alt-ArrowUp\",\n run: moveLineUp\n },\n {\n key: \"Shift-Alt-ArrowUp\",\n run: copyLineUp\n },\n {\n key: \"Alt-ArrowDown\",\n run: moveLineDown\n },\n {\n key: \"Shift-Alt-ArrowDown\",\n run: copyLineDown\n },\n {\n key: \"Escape\",\n run: simplifySelection\n },\n {\n key: \"Mod-Enter\",\n run: insertBlankLine\n },\n {\n key: \"Alt-l\",\n mac: \"Ctrl-l\",\n run: selectLine\n },\n {\n key: \"Mod-i\",\n run: selectParentSyntax,\n preventDefault: true\n },\n {\n key: \"Mod-[\",\n run: indentLess\n },\n {\n key: \"Mod-]\",\n run: indentMore\n },\n {\n key: \"Mod-Alt-\\\\\",\n run: indentSelection\n },\n {\n key: \"Shift-Mod-k\",\n run: deleteLine\n },\n {\n key: \"Shift-Mod-\\\\\",\n run: cursorMatchingBracket\n }\n].concat(standardKeymap);\n/**\nA binding that binds Tab to [`indentMore`](https://codemirror.net/6/docs/ref/#commands.indentMore) and\nShift-Tab to [`indentLess`](https://codemirror.net/6/docs/ref/#commands.indentLess).\nPlease see the [Tab example](../../examples/tab/) before using\nthis.\n*/ const indentWithTab = {\n key: \"Tab\",\n run: indentMore,\n shift: indentLess\n};\n\n},{\"@codemirror/state\":\"e6FBl\",\"@codemirror/text\":\"kn7DT\",\"@codemirror/view\":\"JuP5Z\",\"@codemirror/matchbrackets\":\"58KS3\",\"@codemirror/language\":\"70QHL\",\"@lezer/common\":\"ds1Io\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"58KS3\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"bracketMatching\", ()=>bracketMatching\n);\nparcelHelpers.export(exports, \"matchBrackets\", ()=>matchBrackets\n);\nvar _state = require(\"@codemirror/state\");\nvar _language = require(\"@codemirror/language\");\nvar _view = require(\"@codemirror/view\");\nvar _common = require(\"@lezer/common\");\nconst baseTheme = /*@__PURE__*/ _view.EditorView.baseTheme({\n \"&.cm-focused .cm-matchingBracket\": {\n backgroundColor: \"#328c8252\"\n },\n \"&.cm-focused .cm-nonmatchingBracket\": {\n backgroundColor: \"#bb555544\"\n }\n});\nconst DefaultScanDist = 10000, DefaultBrackets = \"()[]{}\";\nconst bracketMatchingConfig = /*@__PURE__*/ _state.Facet.define({\n combine (configs) {\n return _state.combineConfig(configs, {\n afterCursor: true,\n brackets: DefaultBrackets,\n maxScanDistance: DefaultScanDist\n });\n }\n});\nconst matchingMark = /*@__PURE__*/ _view.Decoration.mark({\n class: \"cm-matchingBracket\"\n}), nonmatchingMark = /*@__PURE__*/ _view.Decoration.mark({\n class: \"cm-nonmatchingBracket\"\n});\nconst bracketMatchingState = /*@__PURE__*/ _state.StateField.define({\n create () {\n return _view.Decoration.none;\n },\n update (deco, tr) {\n if (!tr.docChanged && !tr.selection) return deco;\n let decorations = [];\n let config = tr.state.facet(bracketMatchingConfig);\n for (let range of tr.state.selection.ranges){\n if (!range.empty) continue;\n let match = matchBrackets(tr.state, range.head, -1, config) || range.head > 0 && matchBrackets(tr.state, range.head - 1, 1, config) || config.afterCursor && (matchBrackets(tr.state, range.head, 1, config) || range.head < tr.state.doc.length && matchBrackets(tr.state, range.head + 1, -1, config));\n if (!match) continue;\n let mark = match.matched ? matchingMark : nonmatchingMark;\n decorations.push(mark.range(match.start.from, match.start.to));\n if (match.end) decorations.push(mark.range(match.end.from, match.end.to));\n }\n return _view.Decoration.set(decorations, true);\n },\n provide: (f)=>_view.EditorView.decorations.from(f)\n});\nconst bracketMatchingUnique = [\n bracketMatchingState,\n baseTheme\n];\n/**\nCreate an extension that enables bracket matching. Whenever the\ncursor is next to a bracket, that bracket and the one it matches\nare highlighted. Or, when no matching bracket is found, another\nhighlighting style is used to indicate this.\n*/ function bracketMatching(config = {\n}) {\n return [\n bracketMatchingConfig.of(config),\n bracketMatchingUnique\n ];\n}\nfunction matchingNodes(node, dir, brackets) {\n let byProp = node.prop(dir < 0 ? _common.NodeProp.openedBy : _common.NodeProp.closedBy);\n if (byProp) return byProp;\n if (node.name.length == 1) {\n let index = brackets.indexOf(node.name);\n if (index > -1 && index % 2 == (dir < 0 ? 1 : 0)) return [\n brackets[index + dir]\n ];\n }\n return null;\n}\n/**\nFind the matching bracket for the token at `pos`, scanning\ndirection `dir`. Only the `brackets` and `maxScanDistance`\nproperties are used from `config`, if given. Returns null if no\nbracket was found at `pos`, or a match result otherwise.\n*/ function matchBrackets(state, pos, dir, config = {\n}) {\n let maxScanDistance = config.maxScanDistance || DefaultScanDist, brackets = config.brackets || DefaultBrackets;\n let tree = _language.syntaxTree(state), node = tree.resolveInner(pos, dir);\n for(let cur = node; cur; cur = cur.parent){\n let matches = matchingNodes(cur.type, dir, brackets);\n if (matches && cur.from < cur.to) return matchMarkedBrackets(state, pos, dir, cur, matches, brackets);\n }\n return matchPlainBrackets(state, pos, dir, tree, node.type, maxScanDistance, brackets);\n}\nfunction matchMarkedBrackets(_state, _pos, dir, token, matching, brackets) {\n let parent = token.parent, firstToken = {\n from: token.from,\n to: token.to\n };\n let depth = 0, cursor = parent === null || parent === void 0 ? void 0 : parent.cursor;\n if (cursor && (dir < 0 ? cursor.childBefore(token.from) : cursor.childAfter(token.to))) do if (dir < 0 ? cursor.to <= token.from : cursor.from >= token.to) {\n if (depth == 0 && matching.indexOf(cursor.type.name) > -1 && cursor.from < cursor.to) return {\n start: firstToken,\n end: {\n from: cursor.from,\n to: cursor.to\n },\n matched: true\n };\n else if (matchingNodes(cursor.type, dir, brackets)) depth++;\n else if (matchingNodes(cursor.type, -dir, brackets)) {\n depth--;\n if (depth == 0) return {\n start: firstToken,\n end: cursor.from == cursor.to ? undefined : {\n from: cursor.from,\n to: cursor.to\n },\n matched: false\n };\n }\n }\n while (dir < 0 ? cursor.prevSibling() : cursor.nextSibling())\n return {\n start: firstToken,\n matched: false\n };\n}\nfunction matchPlainBrackets(state, pos, dir, tree, tokenType, maxScanDistance, brackets) {\n let startCh = dir < 0 ? state.sliceDoc(pos - 1, pos) : state.sliceDoc(pos, pos + 1);\n let bracket = brackets.indexOf(startCh);\n if (bracket < 0 || bracket % 2 == 0 != dir > 0) return null;\n let startToken = {\n from: dir < 0 ? pos - 1 : pos,\n to: dir > 0 ? pos + 1 : pos\n };\n let iter = state.doc.iterRange(pos, dir > 0 ? state.doc.length : 0), depth = 0;\n for(let distance = 0; !iter.next().done && distance <= maxScanDistance;){\n let text = iter.value;\n if (dir < 0) distance += text.length;\n let basePos = pos + distance * dir;\n for(let pos1 = dir > 0 ? 0 : text.length - 1, end = dir > 0 ? text.length : -1; pos1 != end; pos1 += dir){\n let found = brackets.indexOf(text[pos1]);\n if (found < 0 || tree.resolve(basePos + pos1, 1).type != tokenType) continue;\n if (found % 2 == 0 == dir > 0) depth++;\n else if (depth == 1) return {\n start: startToken,\n end: {\n from: basePos + pos1,\n to: basePos + pos1 + 1\n },\n matched: found >> 1 == bracket >> 1\n };\n else depth--;\n }\n if (dir > 0) distance += text.length;\n }\n return iter.done ? {\n start: startToken,\n matched: false\n } : null;\n}\n\n},{\"@codemirror/state\":\"e6FBl\",\"@codemirror/language\":\"70QHL\",\"@codemirror/view\":\"JuP5Z\",\"@lezer/common\":\"ds1Io\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"foAcC\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"history\", ()=>history\n);\nparcelHelpers.export(exports, \"historyField\", ()=>historyField\n);\nparcelHelpers.export(exports, \"historyKeymap\", ()=>historyKeymap\n);\nparcelHelpers.export(exports, \"invertedEffects\", ()=>invertedEffects\n);\nparcelHelpers.export(exports, \"isolateHistory\", ()=>isolateHistory\n);\nparcelHelpers.export(exports, \"redo\", ()=>redo\n);\nparcelHelpers.export(exports, \"redoDepth\", ()=>redoDepth\n);\nparcelHelpers.export(exports, \"redoSelection\", ()=>redoSelection\n);\nparcelHelpers.export(exports, \"undo\", ()=>undo\n);\nparcelHelpers.export(exports, \"undoDepth\", ()=>undoDepth\n);\nparcelHelpers.export(exports, \"undoSelection\", ()=>undoSelection\n);\nvar _state = require(\"@codemirror/state\");\nvar _view = require(\"@codemirror/view\");\nconst fromHistory = /*@__PURE__*/ _state.Annotation.define();\n/**\nTransaction annotation that will prevent that transaction from\nbeing combined with other transactions in the undo history. Given\n`\"before\"`, it'll prevent merging with previous transactions. With\n`\"after\"`, subsequent transactions won't be combined with this\none. With `\"full\"`, the transaction is isolated on both sides.\n*/ const isolateHistory = /*@__PURE__*/ _state.Annotation.define();\n/**\nThis facet provides a way to register functions that, given a\ntransaction, provide a set of effects that the history should\nstore when inverting the transaction. This can be used to\nintegrate some kinds of effects in the history, so that they can\nbe undone (and redone again).\n*/ const invertedEffects = /*@__PURE__*/ _state.Facet.define();\nconst historyConfig = /*@__PURE__*/ _state.Facet.define({\n combine (configs) {\n return _state.combineConfig(configs, {\n minDepth: 100,\n newGroupDelay: 500\n }, {\n minDepth: Math.max,\n newGroupDelay: Math.min\n });\n }\n});\nfunction changeEnd(changes) {\n let end = 0;\n changes.iterChangedRanges((_, to)=>end = to\n );\n return end;\n}\nconst historyField_ = /*@__PURE__*/ _state.StateField.define({\n create () {\n return HistoryState.empty;\n },\n update (state, tr) {\n let config = tr.state.facet(historyConfig);\n let fromHist = tr.annotation(fromHistory);\n if (fromHist) {\n let selection = tr.docChanged ? _state.EditorSelection.single(changeEnd(tr.changes)) : undefined;\n let item = HistEvent.fromTransaction(tr, selection), from = fromHist.side;\n let other = from == 0 /* Done */ ? state.undone : state.done;\n if (item) other = updateBranch(other, other.length, config.minDepth, item);\n else other = addSelection(other, tr.startState.selection);\n return new HistoryState(from == 0 /* Done */ ? fromHist.rest : other, from == 0 /* Done */ ? other : fromHist.rest);\n }\n let isolate = tr.annotation(isolateHistory);\n if (isolate == \"full\" || isolate == \"before\") state = state.isolate();\n if (tr.annotation(_state.Transaction.addToHistory) === false) return !tr.changes.empty ? state.addMapping(tr.changes.desc) : state;\n let event = HistEvent.fromTransaction(tr);\n let time = tr.annotation(_state.Transaction.time), userEvent = tr.annotation(_state.Transaction.userEvent);\n if (event) state = state.addChanges(event, time, userEvent, config.newGroupDelay, config.minDepth);\n else if (tr.selection) state = state.addSelection(tr.startState.selection, time, userEvent, config.newGroupDelay);\n if (isolate == \"full\" || isolate == \"after\") state = state.isolate();\n return state;\n },\n toJSON (value) {\n return {\n done: value.done.map((e)=>e.toJSON()\n ),\n undone: value.undone.map((e)=>e.toJSON()\n )\n };\n },\n fromJSON (json) {\n return new HistoryState(json.done.map(HistEvent.fromJSON), json.undone.map(HistEvent.fromJSON));\n }\n});\n/**\nCreate a history extension with the given configuration.\n*/ function history(config = {\n}) {\n return [\n historyField_,\n historyConfig.of(config),\n _view.EditorView.domEventHandlers({\n beforeinput (e, view) {\n let command = e.inputType == \"historyUndo\" ? undo : e.inputType == \"historyRedo\" ? redo : null;\n if (!command) return false;\n e.preventDefault();\n return command(view);\n }\n })\n ];\n}\n/**\nThe state field used to store the history data. Should probably\nonly be used when you want to\n[serialize](https://codemirror.net/6/docs/ref/#state.EditorState.toJSON) or\n[deserialize](https://codemirror.net/6/docs/ref/#state.EditorState^fromJSON) state objects in a way\nthat preserves history.\n*/ const historyField = historyField_;\nfunction cmd(side, selection) {\n return function({ state , dispatch }) {\n if (!selection && state.readOnly) return false;\n let historyState = state.field(historyField_, false);\n if (!historyState) return false;\n let tr = historyState.pop(side, state, selection);\n if (!tr) return false;\n dispatch(tr);\n return true;\n };\n}\n/**\nUndo a single group of history events. Returns false if no group\nwas available.\n*/ const undo = /*@__PURE__*/ cmd(0 /* Done */ , false);\n/**\nRedo a group of history events. Returns false if no group was\navailable.\n*/ const redo = /*@__PURE__*/ cmd(1 /* Undone */ , false);\n/**\nUndo a selection change.\n*/ const undoSelection = /*@__PURE__*/ cmd(0 /* Done */ , true);\n/**\nRedo a selection change.\n*/ const redoSelection = /*@__PURE__*/ cmd(1 /* Undone */ , true);\nfunction depth(side) {\n return function(state) {\n let histState = state.field(historyField_, false);\n if (!histState) return 0;\n let branch = side == 0 /* Done */ ? histState.done : histState.undone;\n return branch.length - (branch.length && !branch[0].changes ? 1 : 0);\n };\n}\n/**\nThe amount of undoable change events available in a given state.\n*/ const undoDepth = /*@__PURE__*/ depth(0 /* Done */ );\n/**\nThe amount of redoable change events available in a given state.\n*/ const redoDepth = /*@__PURE__*/ depth(1 /* Undone */ );\n// History events store groups of changes or effects that need to be\n// undone/redone together.\nclass HistEvent {\n constructor(// The changes in this event. Normal events hold at least one\n // change or effect. But it may be necessary to store selection\n // events before the first change, in which case a special type of\n // instance is created which doesn't hold any changes, with\n // changes == startSelection == undefined\n changes, // The effects associated with this event\n effects, mapped, // The selection before this event\n startSelection, // Stores selection changes after this event, to be used for\n // selection undo/redo.\n selectionsAfter){\n this.changes = changes;\n this.effects = effects;\n this.mapped = mapped;\n this.startSelection = startSelection;\n this.selectionsAfter = selectionsAfter;\n }\n setSelAfter(after) {\n return new HistEvent(this.changes, this.effects, this.mapped, this.startSelection, after);\n }\n toJSON() {\n var _a, _b, _c;\n return {\n changes: (_a = this.changes) === null || _a === void 0 ? void 0 : _a.toJSON(),\n mapped: (_b = this.mapped) === null || _b === void 0 ? void 0 : _b.toJSON(),\n startSelection: (_c = this.startSelection) === null || _c === void 0 ? void 0 : _c.toJSON(),\n selectionsAfter: this.selectionsAfter.map((s)=>s.toJSON()\n )\n };\n }\n static fromJSON(json) {\n return new HistEvent(json.changes && _state.ChangeSet.fromJSON(json.changes), [], json.mapped && _state.ChangeDesc.fromJSON(json.mapped), json.startSelection && _state.EditorSelection.fromJSON(json.startSelection), json.selectionsAfter.map(_state.EditorSelection.fromJSON));\n }\n // This does not check `addToHistory` and such, it assumes the\n // transaction needs to be converted to an item. Returns null when\n // there are no changes or effects in the transaction.\n static fromTransaction(tr, selection) {\n let effects = none;\n for (let invert of tr.startState.facet(invertedEffects)){\n let result = invert(tr);\n if (result.length) effects = effects.concat(result);\n }\n if (!effects.length && tr.changes.empty) return null;\n return new HistEvent(tr.changes.invert(tr.startState.doc), effects, undefined, selection || tr.startState.selection, none);\n }\n static selection(selections) {\n return new HistEvent(undefined, none, undefined, undefined, selections);\n }\n}\nfunction updateBranch(branch, to, maxLen, newEvent) {\n let start = to + 1 > maxLen + 20 ? to - maxLen - 1 : 0;\n let newBranch = branch.slice(start, to);\n newBranch.push(newEvent);\n return newBranch;\n}\nfunction isAdjacent(a, b) {\n let ranges = [], isAdjacent1 = false;\n a.iterChangedRanges((f, t)=>ranges.push(f, t)\n );\n b.iterChangedRanges((_f, _t, f, t)=>{\n for(let i = 0; i < ranges.length;){\n let from = ranges[i++], to = ranges[i++];\n if (t >= from && f <= to) isAdjacent1 = true;\n }\n });\n return isAdjacent1;\n}\nfunction eqSelectionShape(a, b) {\n return a.ranges.length == b.ranges.length && a.ranges.filter((r, i)=>r.empty != b.ranges[i].empty\n ).length === 0;\n}\nfunction conc(a, b) {\n return !a.length ? b : !b.length ? a : a.concat(b);\n}\nconst none = [];\nconst MaxSelectionsPerEvent = 200;\nfunction addSelection(branch, selection) {\n if (!branch.length) return [\n HistEvent.selection([\n selection\n ])\n ];\n else {\n let lastEvent = branch[branch.length - 1];\n let sels = lastEvent.selectionsAfter.slice(Math.max(0, lastEvent.selectionsAfter.length - MaxSelectionsPerEvent));\n if (sels.length && sels[sels.length - 1].eq(selection)) return branch;\n sels.push(selection);\n return updateBranch(branch, branch.length - 1, 1000000000, lastEvent.setSelAfter(sels));\n }\n}\n// Assumes the top item has one or more selectionAfter values\nfunction popSelection(branch) {\n let last = branch[branch.length - 1];\n let newBranch = branch.slice();\n newBranch[branch.length - 1] = last.setSelAfter(last.selectionsAfter.slice(0, last.selectionsAfter.length - 1));\n return newBranch;\n}\n// Add a mapping to the top event in the given branch. If this maps\n// away all the changes and effects in that item, drop it and\n// propagate the mapping to the next item.\nfunction addMappingToBranch(branch, mapping) {\n if (!branch.length) return branch;\n let length = branch.length, selections = none;\n while(length){\n let event = mapEvent(branch[length - 1], mapping, selections);\n if (event.changes && !event.changes.empty || event.effects.length) {\n let result = branch.slice(0, length);\n result[length - 1] = event;\n return result;\n } else {\n mapping = event.mapped;\n length--;\n selections = event.selectionsAfter;\n }\n }\n return selections.length ? [\n HistEvent.selection(selections)\n ] : none;\n}\nfunction mapEvent(event, mapping, extraSelections) {\n let selections = conc(event.selectionsAfter.length ? event.selectionsAfter.map((s)=>s.map(mapping)\n ) : none, extraSelections);\n // Change-less events don't store mappings (they are always the last event in a branch)\n if (!event.changes) return HistEvent.selection(selections);\n let mappedChanges = event.changes.map(mapping), before = mapping.mapDesc(event.changes, true);\n let fullMapping = event.mapped ? event.mapped.composeDesc(before) : before;\n return new HistEvent(mappedChanges, _state.StateEffect.mapEffects(event.effects, mapping), fullMapping, event.startSelection.map(before), selections);\n}\nconst joinableUserEvent = /^(input\\.type|delete)($|\\.)/;\nclass HistoryState {\n constructor(done, undone, prevTime = 0, prevUserEvent){\n this.done = done;\n this.undone = undone;\n this.prevTime = prevTime;\n this.prevUserEvent = prevUserEvent;\n }\n isolate() {\n return this.prevTime ? new HistoryState(this.done, this.undone) : this;\n }\n addChanges(event, time, userEvent, newGroupDelay, maxLen) {\n let done = this.done, lastEvent = done[done.length - 1];\n if (lastEvent && lastEvent.changes && !lastEvent.changes.empty && event.changes && (!userEvent || joinableUserEvent.test(userEvent)) && (!lastEvent.selectionsAfter.length && time - this.prevTime < newGroupDelay && isAdjacent(lastEvent.changes, event.changes) || // For compose (but not compose.start) events, always join with previous event\n userEvent == \"input.type.compose\")) done = updateBranch(done, done.length - 1, maxLen, new HistEvent(event.changes.compose(lastEvent.changes), conc(event.effects, lastEvent.effects), lastEvent.mapped, lastEvent.startSelection, none));\n else done = updateBranch(done, done.length, maxLen, event);\n return new HistoryState(done, none, time, userEvent);\n }\n addSelection(selection, time, userEvent, newGroupDelay) {\n let last = this.done.length ? this.done[this.done.length - 1].selectionsAfter : none;\n if (last.length > 0 && time - this.prevTime < newGroupDelay && userEvent == this.prevUserEvent && userEvent && /^select($|\\.)/.test(userEvent) && eqSelectionShape(last[last.length - 1], selection)) return this;\n return new HistoryState(addSelection(this.done, selection), this.undone, time, userEvent);\n }\n addMapping(mapping) {\n return new HistoryState(addMappingToBranch(this.done, mapping), addMappingToBranch(this.undone, mapping), this.prevTime, this.prevUserEvent);\n }\n pop(side, state, selection) {\n let branch = side == 0 /* Done */ ? this.done : this.undone;\n if (branch.length == 0) return null;\n let event = branch[branch.length - 1];\n if (selection && event.selectionsAfter.length) return state.update({\n selection: event.selectionsAfter[event.selectionsAfter.length - 1],\n annotations: fromHistory.of({\n side,\n rest: popSelection(branch)\n }),\n userEvent: side == 0 /* Done */ ? \"select.undo\" : \"select.redo\",\n scrollIntoView: true\n });\n else if (!event.changes) return null;\n else {\n let rest = branch.length == 1 ? none : branch.slice(0, branch.length - 1);\n if (event.mapped) rest = addMappingToBranch(rest, event.mapped);\n return state.update({\n changes: event.changes,\n selection: event.startSelection,\n effects: event.effects,\n annotations: fromHistory.of({\n side,\n rest\n }),\n filter: false,\n userEvent: side == 0 /* Done */ ? \"undo\" : \"redo\",\n scrollIntoView: true\n });\n }\n }\n}\nHistoryState.empty = /*@__PURE__*/ new HistoryState(none, none);\n/**\nDefault key bindings for the undo history.\n\n- Mod-z: [`undo`](https://codemirror.net/6/docs/ref/#history.undo).\n- Mod-y (Mod-Shift-z on macOS): [`redo`](https://codemirror.net/6/docs/ref/#history.redo).\n- Mod-u: [`undoSelection`](https://codemirror.net/6/docs/ref/#history.undoSelection).\n- Alt-u (Mod-Shift-u on macOS): [`redoSelection`](https://codemirror.net/6/docs/ref/#history.redoSelection).\n*/ const historyKeymap = [\n {\n key: \"Mod-z\",\n run: undo,\n preventDefault: true\n },\n {\n key: \"Mod-y\",\n mac: \"Mod-Shift-z\",\n run: redo,\n preventDefault: true\n },\n {\n key: \"Mod-u\",\n run: undoSelection,\n preventDefault: true\n },\n {\n key: \"Alt-u\",\n mac: \"Mod-Shift-u\",\n run: redoSelection,\n preventDefault: true\n }\n];\n\n},{\"@codemirror/state\":\"e6FBl\",\"@codemirror/view\":\"JuP5Z\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"d16bT\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"RegExpCursor\", ()=>RegExpCursor\n);\nparcelHelpers.export(exports, \"SearchCursor\", ()=>SearchCursor\n);\nparcelHelpers.export(exports, \"SearchQuery\", ()=>SearchQuery\n);\nparcelHelpers.export(exports, \"closeSearchPanel\", ()=>closeSearchPanel\n);\nparcelHelpers.export(exports, \"findNext\", ()=>findNext\n);\nparcelHelpers.export(exports, \"findPrevious\", ()=>findPrevious\n);\nparcelHelpers.export(exports, \"getSearchQuery\", ()=>getSearchQuery\n);\nparcelHelpers.export(exports, \"gotoLine\", ()=>gotoLine\n);\nparcelHelpers.export(exports, \"highlightSelectionMatches\", ()=>highlightSelectionMatches\n);\nparcelHelpers.export(exports, \"openSearchPanel\", ()=>openSearchPanel\n);\nparcelHelpers.export(exports, \"replaceAll\", ()=>replaceAll\n);\nparcelHelpers.export(exports, \"replaceNext\", ()=>replaceNext\n);\nparcelHelpers.export(exports, \"searchConfig\", ()=>searchConfig\n);\nparcelHelpers.export(exports, \"searchKeymap\", ()=>searchKeymap\n);\nparcelHelpers.export(exports, \"selectMatches\", ()=>selectMatches\n);\nparcelHelpers.export(exports, \"selectNextOccurrence\", ()=>selectNextOccurrence\n);\nparcelHelpers.export(exports, \"selectSelectionMatches\", ()=>selectSelectionMatches\n);\nparcelHelpers.export(exports, \"setSearchQuery\", ()=>setSearchQuery\n);\nvar _view = require(\"@codemirror/view\");\nvar _state = require(\"@codemirror/state\");\nvar _panel = require(\"@codemirror/panel\");\nvar _rangeset = require(\"@codemirror/rangeset\");\nvar _crelt = require(\"crelt\");\nvar _creltDefault = parcelHelpers.interopDefault(_crelt);\nvar _text = require(\"@codemirror/text\");\nconst basicNormalize = typeof String.prototype.normalize == \"function\" ? (x)=>x.normalize(\"NFKD\")\n : (x)=>x\n;\n/**\nA search cursor provides an iterator over text matches in a\ndocument.\n*/ class SearchCursor {\n /**\n Create a text cursor. The query is the search string, `from` to\n `to` provides the region to search.\n \n When `normalize` is given, it will be called, on both the query\n string and the content it is matched against, before comparing.\n You can, for example, create a case-insensitive search by\n passing `s => s.toLowerCase()`.\n \n Text is always normalized with\n [`.normalize(\"NFKD\")`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/normalize)\n (when supported).\n */ constructor(text, query, from = 0, to = text.length, normalize){\n /**\n The current match (only holds a meaningful value after\n [`next`](https://codemirror.net/6/docs/ref/#search.SearchCursor.next) has been called and when\n `done` is false).\n */ this.value = {\n from: 0,\n to: 0\n };\n /**\n Whether the end of the iterated region has been reached.\n */ this.done = false;\n this.matches = [];\n this.buffer = \"\";\n this.bufferPos = 0;\n this.iter = text.iterRange(from, to);\n this.bufferStart = from;\n this.normalize = normalize ? (x)=>normalize(basicNormalize(x))\n : basicNormalize;\n this.query = this.normalize(query);\n }\n peek() {\n if (this.bufferPos == this.buffer.length) {\n this.bufferStart += this.buffer.length;\n this.iter.next();\n if (this.iter.done) return -1;\n this.bufferPos = 0;\n this.buffer = this.iter.value;\n }\n return _text.codePointAt(this.buffer, this.bufferPos);\n }\n /**\n Look for the next match. Updates the iterator's\n [`value`](https://codemirror.net/6/docs/ref/#search.SearchCursor.value) and\n [`done`](https://codemirror.net/6/docs/ref/#search.SearchCursor.done) properties. Should be called\n at least once before using the cursor.\n */ next() {\n while(this.matches.length)this.matches.pop();\n return this.nextOverlapping();\n }\n /**\n The `next` method will ignore matches that partially overlap a\n previous match. This method behaves like `next`, but includes\n such matches.\n */ nextOverlapping() {\n for(;;){\n let next = this.peek();\n if (next < 0) {\n this.done = true;\n return this;\n }\n let str = _text.fromCodePoint(next), start = this.bufferStart + this.bufferPos;\n this.bufferPos += _text.codePointSize(next);\n let norm = this.normalize(str);\n for(let i = 0, pos = start;; i++){\n let code = norm.charCodeAt(i);\n let match = this.match(code, pos);\n if (match) {\n this.value = match;\n return this;\n }\n if (i == norm.length - 1) break;\n if (pos == start && i < str.length && str.charCodeAt(i) == code) pos++;\n }\n }\n }\n match(code, pos) {\n let match = null;\n for(let i = 0; i < this.matches.length; i += 2){\n let index = this.matches[i], keep = false;\n if (this.query.charCodeAt(index) == code) {\n if (index == this.query.length - 1) match = {\n from: this.matches[i + 1],\n to: pos + 1\n };\n else {\n this.matches[i]++;\n keep = true;\n }\n }\n if (!keep) {\n this.matches.splice(i, 2);\n i -= 2;\n }\n }\n if (this.query.charCodeAt(0) == code) {\n if (this.query.length == 1) match = {\n from: pos,\n to: pos + 1\n };\n else this.matches.push(1, pos);\n }\n return match;\n }\n}\nif (typeof Symbol != \"undefined\") SearchCursor.prototype[Symbol.iterator] = function() {\n return this;\n};\nconst empty = {\n from: -1,\n to: -1,\n match: /*@__PURE__*/ /.*/.exec(\"\")\n};\nconst baseFlags = \"gm\" + (/x/.unicode == null ? \"\" : \"u\");\n/**\nThis class is similar to [`SearchCursor`](https://codemirror.net/6/docs/ref/#search.SearchCursor)\nbut searches for a regular expression pattern instead of a plain\nstring.\n*/ class RegExpCursor {\n /**\n Create a cursor that will search the given range in the given\n document. `query` should be the raw pattern (as you'd pass it to\n `new RegExp`).\n */ constructor(text, query, options, from = 0, to = text.length){\n this.to = to;\n this.curLine = \"\";\n /**\n Set to `true` when the cursor has reached the end of the search\n range.\n */ this.done = false;\n /**\n Will contain an object with the extent of the match and the\n match object when [`next`](https://codemirror.net/6/docs/ref/#search.RegExpCursor.next)\n sucessfully finds a match.\n */ this.value = empty;\n if (/\\\\[sWDnr]|\\n|\\r|\\[\\^/.test(query)) return new MultilineRegExpCursor(text, query, options, from, to);\n this.re = new RegExp(query, baseFlags + ((options === null || options === void 0 ? void 0 : options.ignoreCase) ? \"i\" : \"\"));\n this.iter = text.iter();\n let startLine = text.lineAt(from);\n this.curLineStart = startLine.from;\n this.matchPos = from;\n this.getLine(this.curLineStart);\n }\n getLine(skip) {\n this.iter.next(skip);\n if (this.iter.lineBreak) this.curLine = \"\";\n else {\n this.curLine = this.iter.value;\n if (this.curLineStart + this.curLine.length > this.to) this.curLine = this.curLine.slice(0, this.to - this.curLineStart);\n this.iter.next();\n }\n }\n nextLine() {\n this.curLineStart = this.curLineStart + this.curLine.length + 1;\n if (this.curLineStart > this.to) this.curLine = \"\";\n else this.getLine(0);\n }\n /**\n Move to the next match, if there is one.\n */ next() {\n for(let off = this.matchPos - this.curLineStart;;){\n this.re.lastIndex = off;\n let match = this.matchPos <= this.to && this.re.exec(this.curLine);\n if (match) {\n let from = this.curLineStart + match.index, to = from + match[0].length;\n this.matchPos = to + (from == to ? 1 : 0);\n if (from == this.curLine.length) this.nextLine();\n if (from < to || from > this.value.to) {\n this.value = {\n from,\n to,\n match\n };\n return this;\n }\n off = this.matchPos - this.curLineStart;\n } else if (this.curLineStart + this.curLine.length < this.to) {\n this.nextLine();\n off = 0;\n } else {\n this.done = true;\n return this;\n }\n }\n }\n}\nconst flattened = /*@__PURE__*/ new WeakMap();\n// Reusable (partially) flattened document strings\nclass FlattenedDoc {\n constructor(from, text){\n this.from = from;\n this.text = text;\n }\n get to() {\n return this.from + this.text.length;\n }\n static get(doc, from, to) {\n let cached = flattened.get(doc);\n if (!cached || cached.from >= to || cached.to <= from) {\n let flat = new FlattenedDoc(from, doc.sliceString(from, to));\n flattened.set(doc, flat);\n return flat;\n }\n if (cached.from == from && cached.to == to) return cached;\n let { text , from: cachedFrom } = cached;\n if (cachedFrom > from) {\n text = doc.sliceString(from, cachedFrom) + text;\n cachedFrom = from;\n }\n if (cached.to < to) text += doc.sliceString(cached.to, to);\n flattened.set(doc, new FlattenedDoc(cachedFrom, text));\n return new FlattenedDoc(from, text.slice(from - cachedFrom, to - cachedFrom));\n }\n}\nclass MultilineRegExpCursor {\n constructor(text, query, options, from, to){\n this.text = text;\n this.to = to;\n this.done = false;\n this.value = empty;\n this.matchPos = from;\n this.re = new RegExp(query, baseFlags + ((options === null || options === void 0 ? void 0 : options.ignoreCase) ? \"i\" : \"\"));\n this.flat = FlattenedDoc.get(text, from, this.chunkEnd(from + 5000 /* Base */ ));\n }\n chunkEnd(pos) {\n return pos >= this.to ? this.to : this.text.lineAt(pos).to;\n }\n next() {\n for(;;){\n let off = this.re.lastIndex = this.matchPos - this.flat.from;\n let match = this.re.exec(this.flat.text);\n // Skip empty matches directly after the last match\n if (match && !match[0] && match.index == off) {\n this.re.lastIndex = off + 1;\n match = this.re.exec(this.flat.text);\n }\n // If a match goes almost to the end of a noncomplete chunk, try\n // again, since it'll likely be able to match more\n if (match && this.flat.to < this.to && match.index + match[0].length > this.flat.text.length - 10) match = null;\n if (match) {\n let from = this.flat.from + match.index, to = from + match[0].length;\n this.value = {\n from,\n to,\n match\n };\n this.matchPos = to + (from == to ? 1 : 0);\n return this;\n } else {\n if (this.flat.to == this.to) {\n this.done = true;\n return this;\n }\n // Grow the flattened doc\n this.flat = FlattenedDoc.get(this.text, this.flat.from, this.chunkEnd(this.flat.from + this.flat.text.length * 2));\n }\n }\n }\n}\nif (typeof Symbol != \"undefined\") RegExpCursor.prototype[Symbol.iterator] = MultilineRegExpCursor.prototype[Symbol.iterator] = function() {\n return this;\n};\nfunction validRegExp(source) {\n try {\n new RegExp(source, baseFlags);\n return true;\n } catch (_a) {\n return false;\n }\n}\nfunction createLineDialog(view) {\n let input = _creltDefault.default(\"input\", {\n class: \"cm-textfield\",\n name: \"line\"\n });\n let dom = _creltDefault.default(\"form\", {\n class: \"cm-gotoLine\",\n onkeydown: (event)=>{\n if (event.keyCode == 27) {\n event.preventDefault();\n view.dispatch({\n effects: dialogEffect.of(false)\n });\n view.focus();\n } else if (event.keyCode == 13) {\n event.preventDefault();\n go();\n }\n },\n onsubmit: (event)=>{\n event.preventDefault();\n go();\n }\n }, _creltDefault.default(\"label\", view.state.phrase(\"Go to line\"), \": \", input), \" \", _creltDefault.default(\"button\", {\n class: \"cm-button\",\n type: \"submit\"\n }, view.state.phrase(\"go\")));\n function go() {\n let match = /^([+-])?(\\d+)?(:\\d+)?(%)?$/.exec(input.value);\n if (!match) return;\n let { state } = view, startLine = state.doc.lineAt(state.selection.main.head);\n let [, sign, ln, cl, percent] = match;\n let col = cl ? +cl.slice(1) : 0;\n let line = ln ? +ln : startLine.number;\n if (ln && percent) {\n let pc = line / 100;\n if (sign) pc = pc * (sign == \"-\" ? -1 : 1) + startLine.number / state.doc.lines;\n line = Math.round(state.doc.lines * pc);\n } else if (ln && sign) line = line * (sign == \"-\" ? -1 : 1) + startLine.number;\n let docLine = state.doc.line(Math.max(1, Math.min(state.doc.lines, line)));\n view.dispatch({\n effects: dialogEffect.of(false),\n selection: _state.EditorSelection.cursor(docLine.from + Math.max(0, Math.min(col, docLine.length))),\n scrollIntoView: true\n });\n view.focus();\n }\n return {\n dom,\n pos: -10\n };\n}\nconst dialogEffect = /*@__PURE__*/ _state.StateEffect.define();\nconst dialogField = /*@__PURE__*/ _state.StateField.define({\n create () {\n return true;\n },\n update (value, tr) {\n for (let e of tr.effects)if (e.is(dialogEffect)) value = e.value;\n return value;\n },\n provide: (f)=>_panel.showPanel.from(f, (val)=>val ? createLineDialog : null\n )\n});\n/**\nCommand that shows a dialog asking the user for a line number, and\nwhen a valid position is provided, moves the cursor to that line.\n\nSupports line numbers, relative line offsets prefixed with `+` or\n`-`, document percentages suffixed with `%`, and an optional\ncolumn position by adding `:` and a second number after the line\nnumber.\n\nThe dialog can be styled with the `panel.gotoLine` theme\nselector.\n*/ const gotoLine = (view)=>{\n let panel = _panel.getPanel(view, createLineDialog);\n if (!panel) {\n let effects = [\n dialogEffect.of(true)\n ];\n if (view.state.field(dialogField, false) == null) effects.push(_state.StateEffect.appendConfig.of([\n dialogField,\n baseTheme$1\n ]));\n view.dispatch({\n effects\n });\n panel = _panel.getPanel(view, createLineDialog);\n }\n if (panel) panel.dom.querySelector(\"input\").focus();\n return true;\n};\nconst baseTheme$1 = /*@__PURE__*/ _view.EditorView.baseTheme({\n \".cm-panel.cm-gotoLine\": {\n padding: \"2px 6px 4px\",\n \"& label\": {\n fontSize: \"80%\"\n }\n }\n});\nconst defaultHighlightOptions = {\n highlightWordAroundCursor: false,\n minSelectionLength: 1,\n maxMatches: 100\n};\nconst highlightConfig = /*@__PURE__*/ _state.Facet.define({\n combine (options) {\n return _state.combineConfig(options, defaultHighlightOptions, {\n highlightWordAroundCursor: (a, b)=>a || b\n ,\n minSelectionLength: Math.min,\n maxMatches: Math.min\n });\n }\n});\n/**\nThis extension highlights text that matches the selection. It uses\nthe `\"cm-selectionMatch\"` class for the highlighting. When\n`highlightWordAroundCursor` is enabled, the word at the cursor\nitself will be highlighted with `\"cm-selectionMatch-main\"`.\n*/ function highlightSelectionMatches(options) {\n let ext = [\n defaultTheme,\n matchHighlighter\n ];\n if (options) ext.push(highlightConfig.of(options));\n return ext;\n}\nconst matchDeco = /*@__PURE__*/ _view.Decoration.mark({\n class: \"cm-selectionMatch\"\n});\nconst mainMatchDeco = /*@__PURE__*/ _view.Decoration.mark({\n class: \"cm-selectionMatch cm-selectionMatch-main\"\n});\nconst matchHighlighter = /*@__PURE__*/ _view.ViewPlugin.fromClass(class {\n constructor(view){\n this.decorations = this.getDeco(view);\n }\n update(update) {\n if (update.selectionSet || update.docChanged || update.viewportChanged) this.decorations = this.getDeco(update.view);\n }\n getDeco(view) {\n let conf = view.state.facet(highlightConfig);\n let { state } = view, sel = state.selection;\n if (sel.ranges.length > 1) return _view.Decoration.none;\n let range = sel.main, query, check = null;\n if (range.empty) {\n if (!conf.highlightWordAroundCursor) return _view.Decoration.none;\n let word = state.wordAt(range.head);\n if (!word) return _view.Decoration.none;\n check = state.charCategorizer(range.head);\n query = state.sliceDoc(word.from, word.to);\n } else {\n let len = range.to - range.from;\n if (len < conf.minSelectionLength || len > 200) return _view.Decoration.none;\n query = state.sliceDoc(range.from, range.to).trim();\n if (!query) return _view.Decoration.none;\n }\n let deco = [];\n for (let part of view.visibleRanges){\n let cursor = new SearchCursor(state.doc, query, part.from, part.to);\n while(!cursor.next().done){\n let { from , to } = cursor.value;\n if (!check || (from == 0 || check(state.sliceDoc(from - 1, from)) != _state.CharCategory.Word) && (to == state.doc.length || check(state.sliceDoc(to, to + 1)) != _state.CharCategory.Word)) {\n if (check && from <= range.from && to >= range.to) deco.push(mainMatchDeco.range(from, to));\n else if (from >= range.to || to <= range.from) deco.push(matchDeco.range(from, to));\n if (deco.length > conf.maxMatches) return _view.Decoration.none;\n }\n }\n }\n return _view.Decoration.set(deco);\n }\n}, {\n decorations: (v)=>v.decorations\n});\nconst defaultTheme = /*@__PURE__*/ _view.EditorView.baseTheme({\n \".cm-selectionMatch\": {\n backgroundColor: \"#99ff7780\"\n },\n \".cm-searchMatch .cm-selectionMatch\": {\n backgroundColor: \"transparent\"\n }\n});\n// Select the words around the cursors.\nconst selectWord = ({ state , dispatch })=>{\n let { selection } = state;\n let newSel = _state.EditorSelection.create(selection.ranges.map((range)=>state.wordAt(range.head) || _state.EditorSelection.cursor(range.head)\n ), selection.mainIndex);\n if (newSel.eq(selection)) return false;\n dispatch(state.update({\n selection: newSel\n }));\n return true;\n};\n// Find next occurrence of query relative to last cursor. Wrap around\n// the document if there are no more matches.\nfunction findNextOccurrence(state, query) {\n let { main , ranges } = state.selection;\n let word = state.wordAt(main.head), fullWord = word && word.from == main.from && word.to == main.to;\n for(let cycled = false, cursor = new SearchCursor(state.doc, query, ranges[ranges.length - 1].to);;){\n cursor.next();\n if (cursor.done) {\n if (cycled) return null;\n cursor = new SearchCursor(state.doc, query, 0, Math.max(0, ranges[ranges.length - 1].from - 1));\n cycled = true;\n } else {\n if (cycled && ranges.some((r)=>r.from == cursor.value.from\n )) continue;\n if (fullWord) {\n let word = state.wordAt(cursor.value.from);\n if (!word || word.from != cursor.value.from || word.to != cursor.value.to) continue;\n }\n return cursor.value;\n }\n }\n}\n/**\nSelect next occurrence of the current selection.\nExpand selection to the word when selection range is empty.\n*/ const selectNextOccurrence = ({ state , dispatch })=>{\n let { ranges } = state.selection;\n if (ranges.some((sel)=>sel.from === sel.to\n )) return selectWord({\n state,\n dispatch\n });\n let searchedText = state.sliceDoc(ranges[0].from, ranges[0].to);\n if (state.selection.ranges.some((r)=>state.sliceDoc(r.from, r.to) != searchedText\n )) return false;\n let range = findNextOccurrence(state, searchedText);\n if (!range) return false;\n dispatch(state.update({\n selection: state.selection.addRange(_state.EditorSelection.range(range.from, range.to), false),\n effects: _view.EditorView.scrollIntoView(range.to)\n }));\n return true;\n};\nconst searchConfigFacet = /*@__PURE__*/ _state.Facet.define({\n combine (configs) {\n var _a;\n return {\n top: configs.reduce((val, conf)=>val !== null && val !== void 0 ? val : conf.top\n , undefined) || false,\n caseSensitive: configs.reduce((val, conf)=>val !== null && val !== void 0 ? val : conf.caseSensitive || conf.matchCase\n , undefined) || false,\n createPanel: ((_a = configs.find((c)=>c.createPanel\n )) === null || _a === void 0 ? void 0 : _a.createPanel) || ((view)=>new SearchPanel(view)\n )\n };\n }\n});\n/**\nConfigure the behavior of the search extension.\n*/ function searchConfig(config) {\n return searchConfigFacet.of(config);\n}\n/**\nA search query. Part of the editor's search state.\n*/ class SearchQuery {\n /**\n Create a query object.\n */ constructor(config){\n this.search = config.search;\n this.caseSensitive = !!config.caseSensitive;\n this.regexp = !!config.regexp;\n this.replace = config.replace || \"\";\n this.valid = !!this.search && (!this.regexp || validRegExp(this.search));\n }\n /**\n Compare this query to another query.\n */ eq(other) {\n return this.search == other.search && this.replace == other.replace && this.caseSensitive == other.caseSensitive && this.regexp == other.regexp;\n }\n /**\n @internal\n */ create() {\n return this.regexp ? new RegExpQuery(this) : new StringQuery(this);\n }\n}\nclass QueryType {\n constructor(spec){\n this.spec = spec;\n }\n}\nclass StringQuery extends QueryType {\n constructor(spec){\n super(spec);\n this.unquoted = spec.search.replace(/\\\\([nrt\\\\])/g, (_, ch)=>ch == \"n\" ? \"\\n\" : ch == \"r\" ? \"\\r\" : ch == \"t\" ? \"\\t\" : \"\\\\\"\n );\n }\n cursor(doc, from = 0, to = doc.length) {\n return new SearchCursor(doc, this.unquoted, from, to, this.spec.caseSensitive ? undefined : (x)=>x.toLowerCase()\n );\n }\n nextMatch(doc, curFrom, curTo) {\n let cursor = this.cursor(doc, curTo).nextOverlapping();\n if (cursor.done) cursor = this.cursor(doc, 0, curFrom).nextOverlapping();\n return cursor.done ? null : cursor.value;\n }\n // Searching in reverse is, rather than implementing inverted search\n // cursor, done by scanning chunk after chunk forward.\n prevMatchInRange(doc, from, to) {\n for(let pos = to;;){\n let start = Math.max(from, pos - 10000 /* ChunkSize */ - this.unquoted.length);\n let cursor = this.cursor(doc, start, pos), range = null;\n while(!cursor.nextOverlapping().done)range = cursor.value;\n if (range) return range;\n if (start == from) return null;\n pos -= 10000 /* ChunkSize */ ;\n }\n }\n prevMatch(doc, curFrom, curTo) {\n return this.prevMatchInRange(doc, 0, curFrom) || this.prevMatchInRange(doc, curTo, doc.length);\n }\n getReplacement(_result) {\n return this.spec.replace;\n }\n matchAll(doc, limit) {\n let cursor = this.cursor(doc), ranges = [];\n while(!cursor.next().done){\n if (ranges.length >= limit) return null;\n ranges.push(cursor.value);\n }\n return ranges;\n }\n highlight(doc, from, to, add) {\n let cursor = this.cursor(doc, Math.max(0, from - this.unquoted.length), Math.min(to + this.unquoted.length, doc.length));\n while(!cursor.next().done)add(cursor.value.from, cursor.value.to);\n }\n}\nclass RegExpQuery extends QueryType {\n cursor(doc, from = 0, to = doc.length) {\n return new RegExpCursor(doc, this.spec.search, this.spec.caseSensitive ? undefined : {\n ignoreCase: true\n }, from, to);\n }\n nextMatch(doc, curFrom, curTo) {\n let cursor = this.cursor(doc, curTo).next();\n if (cursor.done) cursor = this.cursor(doc, 0, curFrom).next();\n return cursor.done ? null : cursor.value;\n }\n prevMatchInRange(doc, from, to) {\n for(let size = 1;; size++){\n let start = Math.max(from, to - size * 10000 /* ChunkSize */ );\n let cursor = this.cursor(doc, start, to), range = null;\n while(!cursor.next().done)range = cursor.value;\n if (range && (start == from || range.from > start + 10)) return range;\n if (start == from) return null;\n }\n }\n prevMatch(doc, curFrom, curTo) {\n return this.prevMatchInRange(doc, 0, curFrom) || this.prevMatchInRange(doc, curTo, doc.length);\n }\n getReplacement(result) {\n return this.spec.replace.replace(/\\$([$&\\d+])/g, (m, i)=>i == \"$\" ? \"$\" : i == \"&\" ? result.match[0] : i != \"0\" && +i < result.match.length ? result.match[i] : m\n );\n }\n matchAll(doc, limit) {\n let cursor = this.cursor(doc), ranges = [];\n while(!cursor.next().done){\n if (ranges.length >= limit) return null;\n ranges.push(cursor.value);\n }\n return ranges;\n }\n highlight(doc, from, to, add) {\n let cursor = this.cursor(doc, Math.max(0, from - 250 /* HighlightMargin */ ), Math.min(to + 250 /* HighlightMargin */ , doc.length));\n while(!cursor.next().done)add(cursor.value.from, cursor.value.to);\n }\n}\n/**\nA state effect that updates the current search query.\n*/ const setSearchQuery = /*@__PURE__*/ _state.StateEffect.define();\nconst togglePanel = /*@__PURE__*/ _state.StateEffect.define();\nconst searchState = /*@__PURE__*/ _state.StateField.define({\n create (state) {\n return new SearchState(defaultQuery(state).create(), createSearchPanel);\n },\n update (value, tr) {\n for (let effect of tr.effects){\n if (effect.is(setSearchQuery)) value = new SearchState(effect.value.create(), value.panel);\n else if (effect.is(togglePanel)) value = new SearchState(value.query, effect.value ? createSearchPanel : null);\n }\n return value;\n },\n provide: (f)=>_panel.showPanel.from(f, (val)=>val.panel\n )\n});\n/**\nGet the current search query from an editor state.\n*/ function getSearchQuery(state) {\n let curState = state.field(searchState, false);\n return curState ? curState.query.spec : defaultQuery(state);\n}\nclass SearchState {\n constructor(query, panel){\n this.query = query;\n this.panel = panel;\n }\n}\nconst matchMark = /*@__PURE__*/ _view.Decoration.mark({\n class: \"cm-searchMatch\"\n}), selectedMatchMark = /*@__PURE__*/ _view.Decoration.mark({\n class: \"cm-searchMatch cm-searchMatch-selected\"\n});\nconst searchHighlighter = /*@__PURE__*/ _view.ViewPlugin.fromClass(class {\n constructor(view){\n this.view = view;\n this.decorations = this.highlight(view.state.field(searchState));\n }\n update(update) {\n let state = update.state.field(searchState);\n if (state != update.startState.field(searchState) || update.docChanged || update.selectionSet) this.decorations = this.highlight(state);\n }\n highlight({ query , panel }) {\n if (!panel || !query.spec.valid) return _view.Decoration.none;\n let { view } = this;\n let builder = new _rangeset.RangeSetBuilder();\n for(let i = 0, ranges = view.visibleRanges, l = ranges.length; i < l; i++){\n let { from: from1 , to: to1 } = ranges[i];\n while(i < l - 1 && to1 > ranges[i + 1].from - 500 /* HighlightMargin */ )to1 = ranges[++i].to;\n query.highlight(view.state.doc, from1, to1, (from, to)=>{\n let selected = view.state.selection.ranges.some((r)=>r.from == from && r.to == to\n );\n builder.add(from, to, selected ? selectedMatchMark : matchMark);\n });\n }\n return builder.finish();\n }\n}, {\n decorations: (v)=>v.decorations\n});\nfunction searchCommand(f) {\n return (view)=>{\n let state = view.state.field(searchState, false);\n return state && state.query.spec.valid ? f(view, state) : openSearchPanel(view);\n };\n}\n/**\nOpen the search panel if it isn't already open, and move the\nselection to the first match after the current main selection.\nWill wrap around to the start of the document when it reaches the\nend.\n*/ const findNext = /*@__PURE__*/ searchCommand((view, { query })=>{\n let { from , to } = view.state.selection.main;\n let next = query.nextMatch(view.state.doc, from, to);\n if (!next || next.from == from && next.to == to) return false;\n view.dispatch({\n selection: {\n anchor: next.from,\n head: next.to\n },\n scrollIntoView: true,\n effects: announceMatch(view, next),\n userEvent: \"select.search\"\n });\n return true;\n});\n/**\nMove the selection to the previous instance of the search query,\nbefore the current main selection. Will wrap past the start\nof the document to start searching at the end again.\n*/ const findPrevious = /*@__PURE__*/ searchCommand((view, { query })=>{\n let { state } = view, { from , to } = state.selection.main;\n let range = query.prevMatch(state.doc, from, to);\n if (!range) return false;\n view.dispatch({\n selection: {\n anchor: range.from,\n head: range.to\n },\n scrollIntoView: true,\n effects: announceMatch(view, range),\n userEvent: \"select.search\"\n });\n return true;\n});\n/**\nSelect all instances of the search query.\n*/ const selectMatches = /*@__PURE__*/ searchCommand((view, { query })=>{\n let ranges = query.matchAll(view.state.doc, 1000);\n if (!ranges || !ranges.length) return false;\n view.dispatch({\n selection: _state.EditorSelection.create(ranges.map((r)=>_state.EditorSelection.range(r.from, r.to)\n )),\n userEvent: \"select.search.matches\"\n });\n return true;\n});\n/**\nSelect all instances of the currently selected text.\n*/ const selectSelectionMatches = ({ state , dispatch })=>{\n let sel = state.selection;\n if (sel.ranges.length > 1 || sel.main.empty) return false;\n let { from , to } = sel.main;\n let ranges = [], main = 0;\n for(let cur = new SearchCursor(state.doc, state.sliceDoc(from, to)); !cur.next().done;){\n if (ranges.length > 1000) return false;\n if (cur.value.from == from) main = ranges.length;\n ranges.push(_state.EditorSelection.range(cur.value.from, cur.value.to));\n }\n dispatch(state.update({\n selection: _state.EditorSelection.create(ranges, main),\n userEvent: \"select.search.matches\"\n }));\n return true;\n};\n/**\nReplace the current match of the search query.\n*/ const replaceNext = /*@__PURE__*/ searchCommand((view, { query })=>{\n let { state } = view, { from , to } = state.selection.main;\n if (state.readOnly) return false;\n let next = query.nextMatch(state.doc, from, from);\n if (!next) return false;\n let changes = [], selection, replacement;\n if (next.from == from && next.to == to) {\n replacement = state.toText(query.getReplacement(next));\n changes.push({\n from: next.from,\n to: next.to,\n insert: replacement\n });\n next = query.nextMatch(state.doc, next.from, next.to);\n }\n if (next) {\n let off = changes.length == 0 || changes[0].from >= next.to ? 0 : next.to - next.from - replacement.length;\n selection = {\n anchor: next.from - off,\n head: next.to - off\n };\n }\n view.dispatch({\n changes,\n selection,\n scrollIntoView: !!selection,\n effects: next ? announceMatch(view, next) : undefined,\n userEvent: \"input.replace\"\n });\n return true;\n});\n/**\nReplace all instances of the search query with the given\nreplacement.\n*/ const replaceAll = /*@__PURE__*/ searchCommand((view, { query })=>{\n if (view.state.readOnly) return false;\n let changes = query.matchAll(view.state.doc, 1000000000).map((match)=>{\n let { from , to } = match;\n return {\n from,\n to,\n insert: query.getReplacement(match)\n };\n });\n if (!changes.length) return false;\n view.dispatch({\n changes,\n userEvent: \"input.replace.all\"\n });\n return true;\n});\nfunction createSearchPanel(view) {\n return view.state.facet(searchConfigFacet).createPanel(view);\n}\nfunction defaultQuery(state, fallback) {\n var _a;\n let sel = state.selection.main;\n let selText = sel.empty || sel.to > sel.from + 100 ? \"\" : state.sliceDoc(sel.from, sel.to);\n let caseSensitive = (_a = fallback === null || fallback === void 0 ? void 0 : fallback.caseSensitive) !== null && _a !== void 0 ? _a : state.facet(searchConfigFacet).caseSensitive;\n return fallback && !selText ? fallback : new SearchQuery({\n search: selText.replace(/\\n/g, \"\\\\n\"),\n caseSensitive\n });\n}\n/**\nMake sure the search panel is open and focused.\n*/ const openSearchPanel = (view)=>{\n let state = view.state.field(searchState, false);\n if (state && state.panel) {\n let panel = _panel.getPanel(view, createSearchPanel);\n if (!panel) return false;\n let searchInput = panel.dom.querySelector(\"[name=search]\");\n if (searchInput != view.root.activeElement) {\n let query = defaultQuery(view.state, state.query.spec);\n if (query.valid) view.dispatch({\n effects: setSearchQuery.of(query)\n });\n searchInput.focus();\n searchInput.select();\n }\n } else view.dispatch({\n effects: [\n togglePanel.of(true),\n state ? setSearchQuery.of(defaultQuery(view.state, state.query.spec)) : _state.StateEffect.appendConfig.of(searchExtensions)\n ]\n });\n return true;\n};\n/**\nClose the search panel.\n*/ const closeSearchPanel = (view)=>{\n let state = view.state.field(searchState, false);\n if (!state || !state.panel) return false;\n let panel = _panel.getPanel(view, createSearchPanel);\n if (panel && panel.dom.contains(view.root.activeElement)) view.focus();\n view.dispatch({\n effects: togglePanel.of(false)\n });\n return true;\n};\n/**\nDefault search-related key bindings.\n\n - Mod-f: [`openSearchPanel`](https://codemirror.net/6/docs/ref/#search.openSearchPanel)\n - F3, Mod-g: [`findNext`](https://codemirror.net/6/docs/ref/#search.findNext)\n - Shift-F3, Shift-Mod-g: [`findPrevious`](https://codemirror.net/6/docs/ref/#search.findPrevious)\n - Alt-g: [`gotoLine`](https://codemirror.net/6/docs/ref/#search.gotoLine)\n - Mod-d: [`selectNextOccurrence`](https://codemirror.net/6/docs/ref/#search.selectNextOccurrence)\n*/ const searchKeymap = [\n {\n key: \"Mod-f\",\n run: openSearchPanel,\n scope: \"editor search-panel\"\n },\n {\n key: \"F3\",\n run: findNext,\n shift: findPrevious,\n scope: \"editor search-panel\",\n preventDefault: true\n },\n {\n key: \"Mod-g\",\n run: findNext,\n shift: findPrevious,\n scope: \"editor search-panel\",\n preventDefault: true\n },\n {\n key: \"Escape\",\n run: closeSearchPanel,\n scope: \"editor search-panel\"\n },\n {\n key: \"Mod-Shift-l\",\n run: selectSelectionMatches\n },\n {\n key: \"Alt-g\",\n run: gotoLine\n },\n {\n key: \"Mod-d\",\n run: selectNextOccurrence,\n preventDefault: true\n }, \n];\nclass SearchPanel {\n constructor(view){\n this.view = view;\n let query = this.query = view.state.field(searchState).query.spec;\n this.commit = this.commit.bind(this);\n this.searchField = _creltDefault.default(\"input\", {\n value: query.search,\n placeholder: phrase(view, \"Find\"),\n \"aria-label\": phrase(view, \"Find\"),\n class: \"cm-textfield\",\n name: \"search\",\n onchange: this.commit,\n onkeyup: this.commit\n });\n this.replaceField = _creltDefault.default(\"input\", {\n value: query.replace,\n placeholder: phrase(view, \"Replace\"),\n \"aria-label\": phrase(view, \"Replace\"),\n class: \"cm-textfield\",\n name: \"replace\",\n onchange: this.commit,\n onkeyup: this.commit\n });\n this.caseField = _creltDefault.default(\"input\", {\n type: \"checkbox\",\n name: \"case\",\n checked: query.caseSensitive,\n onchange: this.commit\n });\n this.reField = _creltDefault.default(\"input\", {\n type: \"checkbox\",\n name: \"re\",\n checked: query.regexp,\n onchange: this.commit\n });\n function button(name, onclick, content) {\n return _creltDefault.default(\"button\", {\n class: \"cm-button\",\n name,\n onclick,\n type: \"button\"\n }, content);\n }\n this.dom = _creltDefault.default(\"div\", {\n onkeydown: (e)=>this.keydown(e)\n ,\n class: \"cm-search\"\n }, [\n this.searchField,\n button(\"next\", ()=>findNext(view)\n , [\n phrase(view, \"next\")\n ]),\n button(\"prev\", ()=>findPrevious(view)\n , [\n phrase(view, \"previous\")\n ]),\n button(\"select\", ()=>selectMatches(view)\n , [\n phrase(view, \"all\")\n ]),\n _creltDefault.default(\"label\", null, [\n this.caseField,\n phrase(view, \"match case\")\n ]),\n _creltDefault.default(\"label\", null, [\n this.reField,\n phrase(view, \"regexp\")\n ]),\n ...view.state.readOnly ? [] : [\n _creltDefault.default(\"br\"),\n this.replaceField,\n button(\"replace\", ()=>replaceNext(view)\n , [\n phrase(view, \"replace\")\n ]),\n button(\"replaceAll\", ()=>replaceAll(view)\n , [\n phrase(view, \"replace all\")\n ]),\n _creltDefault.default(\"button\", {\n name: \"close\",\n onclick: ()=>closeSearchPanel(view)\n ,\n \"aria-label\": phrase(view, \"close\"),\n type: \"button\"\n }, [\n \"\u00d7\"\n ])\n ]\n ]);\n }\n commit() {\n let query = new SearchQuery({\n search: this.searchField.value,\n caseSensitive: this.caseField.checked,\n regexp: this.reField.checked,\n replace: this.replaceField.value\n });\n if (!query.eq(this.query)) {\n this.query = query;\n this.view.dispatch({\n effects: setSearchQuery.of(query)\n });\n }\n }\n keydown(e) {\n if (_view.runScopeHandlers(this.view, e, \"search-panel\")) e.preventDefault();\n else if (e.keyCode == 13 && e.target == this.searchField) {\n e.preventDefault();\n (e.shiftKey ? findPrevious : findNext)(this.view);\n } else if (e.keyCode == 13 && e.target == this.replaceField) {\n e.preventDefault();\n replaceNext(this.view);\n }\n }\n update(update) {\n for (let tr of update.transactions)for (let effect of tr.effects)if (effect.is(setSearchQuery) && !effect.value.eq(this.query)) this.setQuery(effect.value);\n }\n setQuery(query) {\n this.query = query;\n this.searchField.value = query.search;\n this.replaceField.value = query.replace;\n this.caseField.checked = query.caseSensitive;\n this.reField.checked = query.regexp;\n }\n mount() {\n this.searchField.select();\n }\n get pos() {\n return 80;\n }\n get top() {\n return this.view.state.facet(searchConfigFacet).top;\n }\n}\nfunction phrase(view, phrase1) {\n return view.state.phrase(phrase1);\n}\nconst AnnounceMargin = 30;\nconst Break = /[\\s\\.,:;?!]/;\nfunction announceMatch(view, { from , to }) {\n let lineStart = view.state.doc.lineAt(from).from, lineEnd = view.state.doc.lineAt(to).to;\n let start = Math.max(lineStart, from - AnnounceMargin), end = Math.min(lineEnd, to + AnnounceMargin);\n let text = view.state.sliceDoc(start, end);\n if (start != lineStart) {\n for(let i = 0; i < AnnounceMargin; i++)if (!Break.test(text[i + 1]) && Break.test(text[i])) {\n text = text.slice(i);\n break;\n }\n }\n if (end != lineEnd) {\n for(let i = text.length - 1; i > text.length - AnnounceMargin; i--)if (!Break.test(text[i - 1]) && Break.test(text[i])) {\n text = text.slice(0, i);\n break;\n }\n }\n return _view.EditorView.announce.of(`${view.state.phrase(\"current match\")}. ${text} ${view.state.phrase(\"on line\")} ${view.state.doc.lineAt(from).number}`);\n}\nconst baseTheme = /*@__PURE__*/ _view.EditorView.baseTheme({\n \".cm-panel.cm-search\": {\n padding: \"2px 6px 4px\",\n position: \"relative\",\n \"& [name=close]\": {\n position: \"absolute\",\n top: \"0\",\n right: \"4px\",\n backgroundColor: \"inherit\",\n border: \"none\",\n font: \"inherit\",\n padding: 0,\n margin: 0\n },\n \"& input, & button, & label\": {\n margin: \".2em .6em .2em 0\"\n },\n \"& input[type=checkbox]\": {\n marginRight: \".2em\"\n },\n \"& label\": {\n fontSize: \"80%\",\n whiteSpace: \"pre\"\n }\n },\n \"&light .cm-searchMatch\": {\n backgroundColor: \"#ffff0054\"\n },\n \"&dark .cm-searchMatch\": {\n backgroundColor: \"#00ffff8a\"\n },\n \"&light .cm-searchMatch-selected\": {\n backgroundColor: \"#ff6a0054\"\n },\n \"&dark .cm-searchMatch-selected\": {\n backgroundColor: \"#ff00ff8a\"\n }\n});\nconst searchExtensions = [\n searchState,\n /*@__PURE__*/ _state.Prec.lowest(searchHighlighter),\n baseTheme\n];\n\n},{\"@codemirror/view\":\"JuP5Z\",\"@codemirror/state\":\"e6FBl\",\"@codemirror/panel\":\"lm7V0\",\"@codemirror/rangeset\":\"9yBpo\",\"crelt\":\"bVZzL\",\"@codemirror/text\":\"kn7DT\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"lm7V0\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"getPanel\", ()=>getPanel\n);\nparcelHelpers.export(exports, \"panels\", ()=>panels\n);\nparcelHelpers.export(exports, \"showPanel\", ()=>showPanel\n);\nvar _view = require(\"@codemirror/view\");\nvar _state = require(\"@codemirror/state\");\nconst panelConfig = /*@__PURE__*/ _state.Facet.define({\n combine (configs) {\n let topContainer, bottomContainer;\n for (let c of configs){\n topContainer = topContainer || c.topContainer;\n bottomContainer = bottomContainer || c.bottomContainer;\n }\n return {\n topContainer,\n bottomContainer\n };\n }\n});\n/**\nConfigures the panel-managing extension.\n*/ function panels(config) {\n return config ? [\n panelConfig.of(config)\n ] : [];\n}\n/**\nGet the active panel created by the given constructor, if any.\nThis can be useful when you need access to your panels' DOM\nstructure.\n*/ function getPanel(view, panel) {\n let plugin = view.plugin(panelPlugin);\n let index = plugin ? plugin.specs.indexOf(panel) : -1;\n return index > -1 ? plugin.panels[index] : null;\n}\nconst panelPlugin = /*@__PURE__*/ _view.ViewPlugin.fromClass(class {\n constructor(view){\n this.input = view.state.facet(showPanel);\n this.specs = this.input.filter((s)=>s\n );\n this.panels = this.specs.map((spec)=>spec(view)\n );\n let conf = view.state.facet(panelConfig);\n this.top = new PanelGroup(view, true, conf.topContainer);\n this.bottom = new PanelGroup(view, false, conf.bottomContainer);\n this.top.sync(this.panels.filter((p)=>p.top\n ));\n this.bottom.sync(this.panels.filter((p)=>!p.top\n ));\n for (let p1 of this.panels){\n p1.dom.classList.add(\"cm-panel\");\n if (p1.mount) p1.mount();\n }\n }\n update(update) {\n let conf = update.state.facet(panelConfig);\n if (this.top.container != conf.topContainer) {\n this.top.sync([]);\n this.top = new PanelGroup(update.view, true, conf.topContainer);\n }\n if (this.bottom.container != conf.bottomContainer) {\n this.bottom.sync([]);\n this.bottom = new PanelGroup(update.view, false, conf.bottomContainer);\n }\n this.top.syncClasses();\n this.bottom.syncClasses();\n let input = update.state.facet(showPanel);\n if (input != this.input) {\n let specs = input.filter((x)=>x\n );\n let panels1 = [], top = [], bottom = [], mount = [];\n for (let spec of specs){\n let known = this.specs.indexOf(spec), panel;\n if (known < 0) {\n panel = spec(update.view);\n mount.push(panel);\n } else {\n panel = this.panels[known];\n if (panel.update) panel.update(update);\n }\n panels1.push(panel);\n (panel.top ? top : bottom).push(panel);\n }\n this.specs = specs;\n this.panels = panels1;\n this.top.sync(top);\n this.bottom.sync(bottom);\n for (let p of mount){\n p.dom.classList.add(\"cm-panel\");\n if (p.mount) p.mount();\n }\n } else {\n for (let p of this.panels)if (p.update) p.update(update);\n }\n }\n destroy() {\n this.top.sync([]);\n this.bottom.sync([]);\n }\n}, {\n provide: /*@__PURE__*/ _view.PluginField.scrollMargins.from((value)=>({\n top: value.top.scrollMargin(),\n bottom: value.bottom.scrollMargin()\n })\n )\n});\nclass PanelGroup {\n constructor(view, top, container){\n this.view = view;\n this.top = top;\n this.container = container;\n this.dom = undefined;\n this.classes = \"\";\n this.panels = [];\n this.syncClasses();\n }\n sync(panels2) {\n for (let p of this.panels)if (p.destroy && panels2.indexOf(p) < 0) p.destroy();\n this.panels = panels2;\n this.syncDOM();\n }\n syncDOM() {\n if (this.panels.length == 0) {\n if (this.dom) {\n this.dom.remove();\n this.dom = undefined;\n }\n return;\n }\n if (!this.dom) {\n this.dom = document.createElement(\"div\");\n this.dom.className = this.top ? \"cm-panels cm-panels-top\" : \"cm-panels cm-panels-bottom\";\n this.dom.style[this.top ? \"top\" : \"bottom\"] = \"0\";\n let parent = this.container || this.view.dom;\n parent.insertBefore(this.dom, this.top ? parent.firstChild : null);\n }\n let curDOM = this.dom.firstChild;\n for (let panel of this.panels)if (panel.dom.parentNode == this.dom) {\n while(curDOM != panel.dom)curDOM = rm(curDOM);\n curDOM = curDOM.nextSibling;\n } else this.dom.insertBefore(panel.dom, curDOM);\n while(curDOM)curDOM = rm(curDOM);\n }\n scrollMargin() {\n return !this.dom || this.container ? 0 : Math.max(0, this.top ? this.dom.getBoundingClientRect().bottom - Math.max(0, this.view.scrollDOM.getBoundingClientRect().top) : Math.min(innerHeight, this.view.scrollDOM.getBoundingClientRect().bottom) - this.dom.getBoundingClientRect().top);\n }\n syncClasses() {\n if (!this.container || this.classes == this.view.themeClasses) return;\n for (let cls of this.classes.split(\" \"))if (cls) this.container.classList.remove(cls);\n for (let cls1 of (this.classes = this.view.themeClasses).split(\" \"))if (cls1) this.container.classList.add(cls1);\n }\n}\nfunction rm(node) {\n let next = node.nextSibling;\n node.remove();\n return next;\n}\nconst baseTheme = /*@__PURE__*/ _view.EditorView.baseTheme({\n \".cm-panels\": {\n boxSizing: \"border-box\",\n position: \"sticky\",\n left: 0,\n right: 0\n },\n \"&light .cm-panels\": {\n backgroundColor: \"#f5f5f5\",\n color: \"black\"\n },\n \"&light .cm-panels-top\": {\n borderBottom: \"1px solid #ddd\"\n },\n \"&light .cm-panels-bottom\": {\n borderTop: \"1px solid #ddd\"\n },\n \"&dark .cm-panels\": {\n backgroundColor: \"#333338\",\n color: \"white\"\n }\n});\n/**\nOpening a panel is done by providing a constructor function for\nthe panel through this facet. (The panel is closed again when its\nconstructor is no longer provided.) Values of `null` are ignored.\n*/ const showPanel = /*@__PURE__*/ _state.Facet.define({\n enables: [\n panelPlugin,\n baseTheme\n ]\n});\n\n},{\"@codemirror/view\":\"JuP5Z\",\"@codemirror/state\":\"e6FBl\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"bVZzL\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nfunction crelt() {\n var elt = arguments[0];\n if (typeof elt == \"string\") elt = document.createElement(elt);\n var i = 1, next = arguments[1];\n if (next && typeof next == \"object\" && next.nodeType == null && !Array.isArray(next)) {\n for(var name in next)if (Object.prototype.hasOwnProperty.call(next, name)) {\n var value = next[name];\n if (typeof value == \"string\") elt.setAttribute(name, value);\n else if (value != null) elt[name] = value;\n }\n i++;\n }\n for(; i < arguments.length; i++)add(elt, arguments[i]);\n return elt;\n}\nexports.default = crelt;\nfunction add(elt, child) {\n if (typeof child == \"string\") elt.appendChild(document.createTextNode(child));\n else if (child == null) ;\n else if (child.nodeType != null) elt.appendChild(child);\n else if (Array.isArray(child)) for(var i = 0; i < child.length; i++)add(elt, child[i]);\n else throw new RangeError(\"Unsupported child node: \" + child);\n}\n\n},{\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"dPtAI\":[function(require,module,exports) {\n'use strict';\nfunction checkDCE() {\n /* global __REACT_DEVTOOLS_GLOBAL_HOOK__ */ if (typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ === 'undefined' || typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE !== 'function') return;\n var err;\n // This branch is unreachable because this function is only called\n // in production, but the condition is true only in development.\n // Therefore if the branch is still here, dead code elimination wasn't\n // properly applied.\n // Don't change the message. React DevTools relies on it. Also make sure\n // this message doesn't occur elsewhere in this function, or it will cause\n // a false positive.\n throw new Error('^_^');\n}\nmodule.exports = require('./cjs/react-dom.development.js');\n\n},{\"./cjs/react-dom.development.js\":\"kYwDK\"}],\"kYwDK\":[function(require,module,exports) {\n/** @license React v17.0.2\n * react-dom.development.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */ 'use strict';\n(function() {\n var React = require('react');\n var _assign = require('object-assign');\n var Scheduler = require('scheduler');\n var tracing = require('scheduler/tracing');\n var ReactSharedInternals = React.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;\n // by calls to these methods by a Babel plugin.\n //\n // In PROD (or in packages without access to React internals),\n // they are left as they are instead.\n function warn(format) {\n for(var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++)args[_key - 1] = arguments[_key];\n printWarning('warn', format, args);\n }\n function error1(format) {\n for(var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++)args[_key2 - 1] = arguments[_key2];\n printWarning('error', format, args);\n }\n function printWarning(level, format, args) {\n var ReactDebugCurrentFrame = ReactSharedInternals.ReactDebugCurrentFrame;\n var stack = ReactDebugCurrentFrame.getStackAddendum();\n if (stack !== '') {\n format += '%s';\n args = args.concat([\n stack\n ]);\n }\n var argsWithFormat = args.map(function(item) {\n return '' + item;\n }); // Careful: RN currently depends on this prefix\n argsWithFormat.unshift('Warning: ' + format); // We intentionally don't use spread (or .apply) directly because it\n // breaks IE9: https://github.com/facebook/react/issues/13610\n // eslint-disable-next-line react-internal/no-production-logging\n Function.prototype.apply.call(console[level], console, argsWithFormat);\n }\n if (!React) throw Error(\"ReactDOM was loaded before React. Make sure you load the React package before loading ReactDOM.\");\n var FunctionComponent = 0;\n var ClassComponent = 1;\n var IndeterminateComponent = 2; // Before we know whether it is function or class\n var HostRoot = 3; // Root of a host tree. Could be nested inside another node.\n var HostPortal = 4; // A subtree. Could be an entry point to a different renderer.\n var HostComponent = 5;\n var HostText = 6;\n var Fragment = 7;\n var Mode = 8;\n var ContextConsumer = 9;\n var ContextProvider = 10;\n var ForwardRef = 11;\n var Profiler = 12;\n var SuspenseComponent = 13;\n var MemoComponent = 14;\n var SimpleMemoComponent = 15;\n var LazyComponent = 16;\n var IncompleteClassComponent = 17;\n var DehydratedFragment = 18;\n var SuspenseListComponent = 19;\n var FundamentalComponent = 20;\n var ScopeComponent = 21;\n var Block = 22;\n var OffscreenComponent = 23;\n var LegacyHiddenComponent = 24;\n // Filter certain DOM attributes (e.g. src, href) if their values are empty strings.\n var enableProfilerTimer = true; // Record durations for commit and passive effects phases.\n var enableFundamentalAPI = false; // Experimental Scope support.\n var enableNewReconciler = false; // Errors that are thrown while unmounting (or after in the case of passive effects)\n var warnAboutStringRefs = false;\n var allNativeEvents = new Set();\n /**\n * Mapping from registration name to event name\n */ var registrationNameDependencies1 = {\n };\n /**\n * Mapping from lowercase registration names to the properly cased version,\n * used to warn in the case of missing event handlers. Available\n * only in true.\n * @type {Object}\n */ var possibleRegistrationNames1 = {\n }; // Trust the developer to only use possibleRegistrationNames in true\n function registerTwoPhaseEvent(registrationName, dependencies) {\n registerDirectEvent(registrationName, dependencies);\n registerDirectEvent(registrationName + 'Capture', dependencies);\n }\n function registerDirectEvent(registrationName, dependencies) {\n if (registrationNameDependencies1[registrationName]) error1(\"EventRegistry: More than one plugin attempted to publish the same registration name, `%s`.\", registrationName);\n registrationNameDependencies1[registrationName] = dependencies;\n var lowerCasedName = registrationName.toLowerCase();\n possibleRegistrationNames1[lowerCasedName] = registrationName;\n if (registrationName === 'onDoubleClick') possibleRegistrationNames1.ondblclick = registrationName;\n for(var i = 0; i < dependencies.length; i++)allNativeEvents.add(dependencies[i]);\n }\n var canUseDOM = !!(typeof window !== 'undefined' && typeof window.document !== 'undefined' && typeof window.document.createElement !== 'undefined');\n // A reserved attribute.\n // It is handled by React separately and shouldn't be written to the DOM.\n var RESERVED = 0; // A simple string attribute.\n // Attributes that aren't in the filter are presumed to have this type.\n var STRING = 1; // A string attribute that accepts booleans in React. In HTML, these are called\n // \"enumerated\" attributes with \"true\" and \"false\" as possible values.\n // When true, it should be set to a \"true\" string.\n // When false, it should be set to a \"false\" string.\n var BOOLEANISH_STRING = 2; // A real boolean attribute.\n // When true, it should be present (set either to an empty string or its name).\n // When false, it should be omitted.\n var BOOLEAN = 3; // An attribute that can be used as a flag as well as with a value.\n // When true, it should be present (set either to an empty string or its name).\n // When false, it should be omitted.\n // For any other value, should be present with that value.\n var OVERLOADED_BOOLEAN = 4; // An attribute that must be numeric or parse as a numeric.\n // When falsy, it should be removed.\n var NUMERIC = 5; // An attribute that must be positive numeric or parse as a positive numeric.\n // When falsy, it should be removed.\n var POSITIVE_NUMERIC = 6;\n /* eslint-disable max-len */ var ATTRIBUTE_NAME_START_CHAR = \":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\";\n /* eslint-enable max-len */ var ATTRIBUTE_NAME_CHAR = ATTRIBUTE_NAME_START_CHAR + \"\\\\-.0-9\\\\u00B7\\\\u0300-\\\\u036F\\\\u203F-\\\\u2040\";\n var ROOT_ATTRIBUTE_NAME = 'data-reactroot';\n var VALID_ATTRIBUTE_NAME_REGEX = new RegExp('^[' + ATTRIBUTE_NAME_START_CHAR + '][' + ATTRIBUTE_NAME_CHAR + ']*$');\n var hasOwnProperty = Object.prototype.hasOwnProperty;\n var illegalAttributeNameCache = {\n };\n var validatedAttributeNameCache = {\n };\n function isAttributeNameSafe(attributeName) {\n if (hasOwnProperty.call(validatedAttributeNameCache, attributeName)) return true;\n if (hasOwnProperty.call(illegalAttributeNameCache, attributeName)) return false;\n if (VALID_ATTRIBUTE_NAME_REGEX.test(attributeName)) {\n validatedAttributeNameCache[attributeName] = true;\n return true;\n }\n illegalAttributeNameCache[attributeName] = true;\n error1('Invalid attribute name: `%s`', attributeName);\n return false;\n }\n function shouldIgnoreAttribute(name, propertyInfo, isCustomComponentTag) {\n if (propertyInfo !== null) return propertyInfo.type === RESERVED;\n if (isCustomComponentTag) return false;\n if (name.length > 2 && (name[0] === 'o' || name[0] === 'O') && (name[1] === 'n' || name[1] === 'N')) return true;\n return false;\n }\n function shouldRemoveAttributeWithWarning(name, value, propertyInfo, isCustomComponentTag) {\n if (propertyInfo !== null && propertyInfo.type === RESERVED) return false;\n switch(typeof value){\n case 'function':\n case 'symbol':\n // eslint-disable-line\n return true;\n case 'boolean':\n if (isCustomComponentTag) return false;\n if (propertyInfo !== null) return !propertyInfo.acceptsBooleans;\n else {\n var prefix = name.toLowerCase().slice(0, 5);\n return prefix !== 'data-' && prefix !== 'aria-';\n }\n default:\n return false;\n }\n }\n function shouldRemoveAttribute(name, value, propertyInfo, isCustomComponentTag) {\n if (value === null || typeof value === 'undefined') return true;\n if (shouldRemoveAttributeWithWarning(name, value, propertyInfo, isCustomComponentTag)) return true;\n if (isCustomComponentTag) return false;\n if (propertyInfo !== null) switch(propertyInfo.type){\n case BOOLEAN:\n return !value;\n case OVERLOADED_BOOLEAN:\n return value === false;\n case NUMERIC:\n return isNaN(value);\n case POSITIVE_NUMERIC:\n return isNaN(value) || value < 1;\n }\n return false;\n }\n function getPropertyInfo(name) {\n return properties.hasOwnProperty(name) ? properties[name] : null;\n }\n function PropertyInfoRecord(name, type, mustUseProperty, attributeName, attributeNamespace, sanitizeURL, removeEmptyString) {\n this.acceptsBooleans = type === BOOLEANISH_STRING || type === BOOLEAN || type === OVERLOADED_BOOLEAN;\n this.attributeName = attributeName;\n this.attributeNamespace = attributeNamespace;\n this.mustUseProperty = mustUseProperty;\n this.propertyName = name;\n this.type = type;\n this.sanitizeURL = sanitizeURL;\n this.removeEmptyString = removeEmptyString;\n } // When adding attributes to this list, be sure to also add them to\n // the `possibleStandardNames` module to ensure casing and incorrect\n // name warnings.\n var properties = {\n }; // These props are reserved by React. They shouldn't be written to the DOM.\n var reservedProps = [\n 'children',\n 'dangerouslySetInnerHTML',\n // elements (not just inputs). Now that ReactDOMInput assigns to the\n // defaultValue property -- do we need this?\n 'defaultValue',\n 'defaultChecked',\n 'innerHTML',\n 'suppressContentEditableWarning',\n 'suppressHydrationWarning',\n 'style'\n ];\n reservedProps.forEach(function(name) {\n properties[name] = new PropertyInfoRecord(name, RESERVED, false, name, null, false, false);\n }); // A few React string attributes have a different name.\n // This is a mapping from React prop names to the attribute names.\n [\n [\n 'acceptCharset',\n 'accept-charset'\n ],\n [\n 'className',\n 'class'\n ],\n [\n 'htmlFor',\n 'for'\n ],\n [\n 'httpEquiv',\n 'http-equiv'\n ]\n ].forEach(function(_ref) {\n var name = _ref[0], attributeName = _ref[1];\n properties[name] = new PropertyInfoRecord(name, STRING, false, attributeName, null, false, false);\n }); // These are \"enumerated\" HTML attributes that accept \"true\" and \"false\".\n // In React, we let users pass `true` and `false` even though technically\n // these aren't boolean attributes (they are coerced to strings).\n [\n 'contentEditable',\n 'draggable',\n 'spellCheck',\n 'value'\n ].forEach(function(name) {\n properties[name] = new PropertyInfoRecord(name, BOOLEANISH_STRING, false, name.toLowerCase(), null, false, false);\n }); // These are \"enumerated\" SVG attributes that accept \"true\" and \"false\".\n // In React, we let users pass `true` and `false` even though technically\n // these aren't boolean attributes (they are coerced to strings).\n // Since these are SVG attributes, their attribute names are case-sensitive.\n [\n 'autoReverse',\n 'externalResourcesRequired',\n 'focusable',\n 'preserveAlpha'\n ].forEach(function(name) {\n properties[name] = new PropertyInfoRecord(name, BOOLEANISH_STRING, false, name, null, false, false);\n }); // These are HTML boolean attributes.\n [\n 'allowFullScreen',\n 'async',\n // on the client side because the browsers are inconsistent. Instead we call focus().\n 'autoFocus',\n 'autoPlay',\n 'controls',\n 'default',\n 'defer',\n 'disabled',\n 'disablePictureInPicture',\n 'disableRemotePlayback',\n 'formNoValidate',\n 'hidden',\n 'loop',\n 'noModule',\n 'noValidate',\n 'open',\n 'playsInline',\n 'readOnly',\n 'required',\n 'reversed',\n 'scoped',\n 'seamless',\n 'itemScope'\n ].forEach(function(name) {\n properties[name] = new PropertyInfoRecord(name, BOOLEAN, false, name.toLowerCase(), null, false, false);\n }); // These are the few React props that we set as DOM properties\n // rather than attributes. These are all booleans.\n [\n 'checked',\n // disabled with `removeAttribute`. We have special logic for handling this.\n 'multiple',\n 'muted',\n 'selected' // NOTE: if you add a camelCased prop to this list,\n ].forEach(function(name) {\n properties[name] = new PropertyInfoRecord(name, BOOLEAN, true, name, null, false, false);\n }); // These are HTML attributes that are \"overloaded booleans\": they behave like\n // booleans, but can also accept a string value.\n [\n 'capture',\n 'download' // NOTE: if you add a camelCased prop to this list,\n ].forEach(function(name) {\n properties[name] = new PropertyInfoRecord(name, OVERLOADED_BOOLEAN, false, name, null, false, false);\n }); // These are HTML attributes that must be positive numbers.\n [\n 'cols',\n 'rows',\n 'size',\n 'span' // NOTE: if you add a camelCased prop to this list,\n ].forEach(function(name) {\n properties[name] = new PropertyInfoRecord(name, POSITIVE_NUMERIC, false, name, null, false, false);\n }); // These are HTML attributes that must be numbers.\n [\n 'rowSpan',\n 'start'\n ].forEach(function(name) {\n properties[name] = new PropertyInfoRecord(name, NUMERIC, false, name.toLowerCase(), null, false, false);\n });\n var CAMELIZE = /[\\-\\:]([a-z])/g;\n var capitalize = function(token) {\n return token[1].toUpperCase();\n }; // This is a list of all SVG attributes that need special casing, namespacing,\n // or boolean value assignment. Regular attributes that just accept strings\n // and have the same names are omitted, just like in the HTML attribute filter.\n // Some of these attributes can be hard to find. This list was created by\n // scraping the MDN documentation.\n [\n 'accent-height',\n 'alignment-baseline',\n 'arabic-form',\n 'baseline-shift',\n 'cap-height',\n 'clip-path',\n 'clip-rule',\n 'color-interpolation',\n 'color-interpolation-filters',\n 'color-profile',\n 'color-rendering',\n 'dominant-baseline',\n 'enable-background',\n 'fill-opacity',\n 'fill-rule',\n 'flood-color',\n 'flood-opacity',\n 'font-family',\n 'font-size',\n 'font-size-adjust',\n 'font-stretch',\n 'font-style',\n 'font-variant',\n 'font-weight',\n 'glyph-name',\n 'glyph-orientation-horizontal',\n 'glyph-orientation-vertical',\n 'horiz-adv-x',\n 'horiz-origin-x',\n 'image-rendering',\n 'letter-spacing',\n 'lighting-color',\n 'marker-end',\n 'marker-mid',\n 'marker-start',\n 'overline-position',\n 'overline-thickness',\n 'paint-order',\n 'panose-1',\n 'pointer-events',\n 'rendering-intent',\n 'shape-rendering',\n 'stop-color',\n 'stop-opacity',\n 'strikethrough-position',\n 'strikethrough-thickness',\n 'stroke-dasharray',\n 'stroke-dashoffset',\n 'stroke-linecap',\n 'stroke-linejoin',\n 'stroke-miterlimit',\n 'stroke-opacity',\n 'stroke-width',\n 'text-anchor',\n 'text-decoration',\n 'text-rendering',\n 'underline-position',\n 'underline-thickness',\n 'unicode-bidi',\n 'unicode-range',\n 'units-per-em',\n 'v-alphabetic',\n 'v-hanging',\n 'v-ideographic',\n 'v-mathematical',\n 'vector-effect',\n 'vert-adv-y',\n 'vert-origin-x',\n 'vert-origin-y',\n 'word-spacing',\n 'writing-mode',\n 'xmlns:xlink',\n 'x-height' // NOTE: if you add a camelCased prop to this list,\n ].forEach(function(attributeName) {\n var name = attributeName.replace(CAMELIZE, capitalize);\n properties[name] = new PropertyInfoRecord(name, STRING, false, attributeName, null, false, false);\n }); // String SVG attributes with the xlink namespace.\n [\n 'xlink:actuate',\n 'xlink:arcrole',\n 'xlink:role',\n 'xlink:show',\n 'xlink:title',\n 'xlink:type' // NOTE: if you add a camelCased prop to this list,\n ].forEach(function(attributeName) {\n var name = attributeName.replace(CAMELIZE, capitalize);\n properties[name] = new PropertyInfoRecord(name, STRING, false, attributeName, 'http://www.w3.org/1999/xlink', false, false);\n }); // String SVG attributes with the xml namespace.\n [\n 'xml:base',\n 'xml:lang',\n 'xml:space' // NOTE: if you add a camelCased prop to this list,\n ].forEach(function(attributeName) {\n var name = attributeName.replace(CAMELIZE, capitalize);\n properties[name] = new PropertyInfoRecord(name, STRING, false, attributeName, 'http://www.w3.org/XML/1998/namespace', false, false);\n }); // These attribute exists both in HTML and SVG.\n // The attribute name is case-sensitive in SVG so we can't just use\n // the React name like we do for attributes that exist only in HTML.\n [\n 'tabIndex',\n 'crossOrigin'\n ].forEach(function(attributeName) {\n properties[attributeName] = new PropertyInfoRecord(attributeName, STRING, false, attributeName.toLowerCase(), null, false, false);\n }); // These attributes accept URLs. These must not allow javascript: URLS.\n // These will also need to accept Trusted Types object in the future.\n var xlinkHref = 'xlinkHref';\n properties[xlinkHref] = new PropertyInfoRecord('xlinkHref', STRING, false, 'xlink:href', 'http://www.w3.org/1999/xlink', true, false);\n [\n 'src',\n 'href',\n 'action',\n 'formAction'\n ].forEach(function(attributeName) {\n properties[attributeName] = new PropertyInfoRecord(attributeName, STRING, false, attributeName.toLowerCase(), null, true, true);\n });\n // and any newline or tab are filtered out as if they're not part of the URL.\n // https://url.spec.whatwg.org/#url-parsing\n // Tab or newline are defined as \\r\\n\\t:\n // https://infra.spec.whatwg.org/#ascii-tab-or-newline\n // A C0 control is a code point in the range \\u0000 NULL to \\u001F\n // INFORMATION SEPARATOR ONE, inclusive:\n // https://infra.spec.whatwg.org/#c0-control-or-space\n /* eslint-disable max-len */ var isJavaScriptProtocol = /^[\\u0000-\\u001F ]*j[\\r\\n\\t]*a[\\r\\n\\t]*v[\\r\\n\\t]*a[\\r\\n\\t]*s[\\r\\n\\t]*c[\\r\\n\\t]*r[\\r\\n\\t]*i[\\r\\n\\t]*p[\\r\\n\\t]*t[\\r\\n\\t]*\\:/i;\n var didWarn = false;\n function sanitizeURL1(url) {\n if (!didWarn && isJavaScriptProtocol.test(url)) {\n didWarn = true;\n error1(\"A future version of React will block javascript: URLs as a security precaution. Use event handlers instead if you can. If you need to generate unsafe HTML try using dangerouslySetInnerHTML instead. React was passed %s.\", JSON.stringify(url));\n }\n }\n /**\n * Get the value for a property on a node. Only used in DEV for SSR validation.\n * The \"expected\" argument is used as a hint of what the expected value is.\n * Some properties have multiple equivalent values.\n */ function getValueForProperty(node, name, expected, propertyInfo) {\n if (propertyInfo.mustUseProperty) {\n var propertyName = propertyInfo.propertyName;\n return node[propertyName];\n } else {\n if (propertyInfo.sanitizeURL) // If we haven't fully disabled javascript: URLs, and if\n // the hydration is successful of a javascript: URL, we\n // still want to warn on the client.\n sanitizeURL1('' + expected);\n var attributeName = propertyInfo.attributeName;\n var stringValue = null;\n if (propertyInfo.type === OVERLOADED_BOOLEAN) {\n if (node.hasAttribute(attributeName)) {\n var value = node.getAttribute(attributeName);\n if (value === '') return true;\n if (shouldRemoveAttribute(name, expected, propertyInfo, false)) return value;\n if (value === '' + expected) return expected;\n return value;\n }\n } else if (node.hasAttribute(attributeName)) {\n if (shouldRemoveAttribute(name, expected, propertyInfo, false)) // We had an attribute but shouldn't have had one, so read it\n // for the error message.\n return node.getAttribute(attributeName);\n if (propertyInfo.type === BOOLEAN) // If this was a boolean, it doesn't matter what the value is\n // the fact that we have it is the same as the expected.\n return expected;\n // Even if this property uses a namespace we use getAttribute\n // because we assume its namespaced name is the same as our config.\n // To use getAttributeNS we need the local name which we don't have\n // in our config atm.\n stringValue = node.getAttribute(attributeName);\n }\n if (shouldRemoveAttribute(name, expected, propertyInfo, false)) return stringValue === null ? expected : stringValue;\n else if (stringValue === '' + expected) return expected;\n else return stringValue;\n }\n }\n /**\n * Get the value for a attribute on a node. Only used in DEV for SSR validation.\n * The third argument is used as a hint of what the expected value is. Some\n * attributes have multiple equivalent values.\n */ function getValueForAttribute(node, name, expected) {\n if (!isAttributeNameSafe(name)) return;\n // If the object is an opaque reference ID, it's expected that\n // the next prop is different than the server value, so just return\n // expected\n if (isOpaqueHydratingObject(expected)) return expected;\n if (!node.hasAttribute(name)) return expected === undefined ? undefined : null;\n var value = node.getAttribute(name);\n if (value === '' + expected) return expected;\n return value;\n }\n /**\n * Sets the value for a property on a node.\n *\n * @param {DOMElement} node\n * @param {string} name\n * @param {*} value\n */ function setValueForProperty(node, name, value, isCustomComponentTag) {\n var propertyInfo = getPropertyInfo(name);\n if (shouldIgnoreAttribute(name, propertyInfo, isCustomComponentTag)) return;\n if (shouldRemoveAttribute(name, value, propertyInfo, isCustomComponentTag)) value = null;\n // If the prop isn't in the special list, treat it as a simple attribute.\n if (isCustomComponentTag || propertyInfo === null) {\n if (isAttributeNameSafe(name)) {\n var _attributeName = name;\n if (value === null) node.removeAttribute(_attributeName);\n else node.setAttribute(_attributeName, '' + value);\n }\n return;\n }\n var mustUseProperty = propertyInfo.mustUseProperty;\n if (mustUseProperty) {\n var propertyName = propertyInfo.propertyName;\n if (value === null) {\n var type = propertyInfo.type;\n node[propertyName] = type === BOOLEAN ? false : '';\n } else // Contrary to `setAttribute`, object properties are properly\n // `toString`ed by IE8/9.\n node[propertyName] = value;\n return;\n } // The rest are treated as attributes with special cases.\n var attributeName = propertyInfo.attributeName, attributeNamespace = propertyInfo.attributeNamespace;\n if (value === null) node.removeAttribute(attributeName);\n else {\n var _type = propertyInfo.type;\n var attributeValue;\n if (_type === BOOLEAN || _type === OVERLOADED_BOOLEAN && value === true) // If attribute type is boolean, we know for sure it won't be an execution sink\n // and we won't require Trusted Type here.\n attributeValue = '';\n else {\n attributeValue = '' + value;\n if (propertyInfo.sanitizeURL) sanitizeURL1(attributeValue.toString());\n }\n if (attributeNamespace) node.setAttributeNS(attributeNamespace, attributeName, attributeValue);\n else node.setAttribute(attributeName, attributeValue);\n }\n }\n // ATTENTION\n // When adding new symbols to this file,\n // Please consider also adding to 'react-devtools-shared/src/backend/ReactSymbols'\n // The Symbol used to tag the ReactElement-like types. If there is no native Symbol\n // nor polyfill, then a plain number is used for performance.\n var REACT_ELEMENT_TYPE = 60103;\n var REACT_PORTAL_TYPE = 60106;\n var REACT_FRAGMENT_TYPE = 60107;\n var REACT_STRICT_MODE_TYPE = 60108;\n var REACT_PROFILER_TYPE = 60114;\n var REACT_PROVIDER_TYPE = 60109;\n var REACT_CONTEXT_TYPE = 60110;\n var REACT_FORWARD_REF_TYPE = 60112;\n var REACT_SUSPENSE_TYPE = 60113;\n var REACT_SUSPENSE_LIST_TYPE = 60120;\n var REACT_MEMO_TYPE = 60115;\n var REACT_LAZY_TYPE = 60116;\n var REACT_BLOCK_TYPE = 60121;\n var REACT_SERVER_BLOCK_TYPE = 60122;\n var REACT_FUNDAMENTAL_TYPE = 60117;\n var REACT_SCOPE_TYPE = 60119;\n var REACT_OPAQUE_ID_TYPE = 60128;\n var REACT_DEBUG_TRACING_MODE_TYPE = 60129;\n var REACT_OFFSCREEN_TYPE = 60130;\n var REACT_LEGACY_HIDDEN_TYPE = 60131;\n if (typeof Symbol === 'function' && Symbol.for) {\n var symbolFor = Symbol.for;\n REACT_ELEMENT_TYPE = symbolFor('react.element');\n REACT_PORTAL_TYPE = symbolFor('react.portal');\n REACT_FRAGMENT_TYPE = symbolFor('react.fragment');\n REACT_STRICT_MODE_TYPE = symbolFor('react.strict_mode');\n REACT_PROFILER_TYPE = symbolFor('react.profiler');\n REACT_PROVIDER_TYPE = symbolFor('react.provider');\n REACT_CONTEXT_TYPE = symbolFor('react.context');\n REACT_FORWARD_REF_TYPE = symbolFor('react.forward_ref');\n REACT_SUSPENSE_TYPE = symbolFor('react.suspense');\n REACT_SUSPENSE_LIST_TYPE = symbolFor('react.suspense_list');\n REACT_MEMO_TYPE = symbolFor('react.memo');\n REACT_LAZY_TYPE = symbolFor('react.lazy');\n REACT_BLOCK_TYPE = symbolFor('react.block');\n REACT_SERVER_BLOCK_TYPE = symbolFor('react.server.block');\n REACT_FUNDAMENTAL_TYPE = symbolFor('react.fundamental');\n REACT_SCOPE_TYPE = symbolFor('react.scope');\n REACT_OPAQUE_ID_TYPE = symbolFor('react.opaque.id');\n REACT_DEBUG_TRACING_MODE_TYPE = symbolFor('react.debug_trace_mode');\n REACT_OFFSCREEN_TYPE = symbolFor('react.offscreen');\n REACT_LEGACY_HIDDEN_TYPE = symbolFor('react.legacy_hidden');\n }\n var MAYBE_ITERATOR_SYMBOL = typeof Symbol === 'function' && Symbol.iterator;\n var FAUX_ITERATOR_SYMBOL = '@@iterator';\n function getIteratorFn(maybeIterable) {\n if (maybeIterable === null || typeof maybeIterable !== 'object') return null;\n var maybeIterator = MAYBE_ITERATOR_SYMBOL && maybeIterable[MAYBE_ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL];\n if (typeof maybeIterator === 'function') return maybeIterator;\n return null;\n }\n // Helpers to patch console.logs to avoid logging during side-effect free\n // replaying on render function. This currently only patches the object\n // lazily which won't cover if the log function was extracted eagerly.\n // We could also eagerly patch the method.\n var disabledDepth = 0;\n var prevLog;\n var prevInfo;\n var prevWarn;\n var prevError;\n var prevGroup;\n var prevGroupCollapsed;\n var prevGroupEnd;\n function disabledLog() {\n }\n disabledLog.__reactDisabledLog = true;\n function disableLogs() {\n if (disabledDepth === 0) {\n /* eslint-disable react-internal/no-production-logging */ prevLog = console.log;\n prevInfo = console.info;\n prevWarn = console.warn;\n prevError = console.error;\n prevGroup = console.group;\n prevGroupCollapsed = console.groupCollapsed;\n prevGroupEnd = console.groupEnd; // https://github.com/facebook/react/issues/19099\n var props = {\n configurable: true,\n enumerable: true,\n value: disabledLog,\n writable: true\n }; // $FlowFixMe Flow thinks console is immutable.\n Object.defineProperties(console, {\n info: props,\n log: props,\n warn: props,\n error: props,\n group: props,\n groupCollapsed: props,\n groupEnd: props\n });\n /* eslint-enable react-internal/no-production-logging */ }\n disabledDepth++;\n }\n function reenableLogs() {\n disabledDepth--;\n if (disabledDepth === 0) {\n /* eslint-disable react-internal/no-production-logging */ var props = {\n configurable: true,\n enumerable: true,\n writable: true\n }; // $FlowFixMe Flow thinks console is immutable.\n Object.defineProperties(console, {\n log: _assign({\n }, props, {\n value: prevLog\n }),\n info: _assign({\n }, props, {\n value: prevInfo\n }),\n warn: _assign({\n }, props, {\n value: prevWarn\n }),\n error: _assign({\n }, props, {\n value: prevError\n }),\n group: _assign({\n }, props, {\n value: prevGroup\n }),\n groupCollapsed: _assign({\n }, props, {\n value: prevGroupCollapsed\n }),\n groupEnd: _assign({\n }, props, {\n value: prevGroupEnd\n })\n });\n /* eslint-enable react-internal/no-production-logging */ }\n if (disabledDepth < 0) error1(\"disabledDepth fell below zero. This is a bug in React. Please file an issue.\");\n }\n var ReactCurrentDispatcher1 = ReactSharedInternals.ReactCurrentDispatcher;\n var prefix1;\n function describeBuiltInComponentFrame(name, source, ownerFn) {\n if (prefix1 === undefined) // Extract the VM specific prefix used by each line.\n try {\n throw Error();\n } catch (x) {\n var match = x.stack.trim().match(/\\n( *(at )?)/);\n prefix1 = match && match[1] || '';\n }\n // We use the prefix to ensure our stacks line up with native stack frames.\n return '\\n' + prefix1 + name;\n }\n var reentry = false;\n var componentFrameCache;\n var PossiblyWeakMap = typeof WeakMap === 'function' ? WeakMap : Map;\n componentFrameCache = new PossiblyWeakMap();\n function describeNativeComponentFrame(fn, construct) {\n // If something asked for a stack inside a fake render, it should get ignored.\n if (!fn || reentry) return '';\n var frame = componentFrameCache.get(fn);\n if (frame !== undefined) return frame;\n var control;\n reentry = true;\n var previousPrepareStackTrace = Error.prepareStackTrace; // $FlowFixMe It does accept undefined.\n Error.prepareStackTrace = undefined;\n var previousDispatcher;\n previousDispatcher = ReactCurrentDispatcher1.current; // Set the dispatcher in DEV because this might be call in the render function\n // for warnings.\n ReactCurrentDispatcher1.current = null;\n disableLogs();\n try {\n // This should throw.\n if (construct) {\n // Something should be setting the props in the constructor.\n var Fake = function() {\n throw Error();\n }; // $FlowFixMe\n Object.defineProperty(Fake.prototype, 'props', {\n set: function() {\n // We use a throwing setter instead of frozen or non-writable props\n // because that won't throw in a non-strict mode function.\n throw Error();\n }\n });\n if (typeof Reflect === 'object' && Reflect.construct) {\n // We construct a different control for this case to include any extra\n // frames added by the construct call.\n try {\n Reflect.construct(Fake, []);\n } catch (x) {\n control = x;\n }\n Reflect.construct(fn, [], Fake);\n } else {\n try {\n Fake.call();\n } catch (x) {\n control = x;\n }\n fn.call(Fake.prototype);\n }\n } else {\n try {\n throw Error();\n } catch (x) {\n control = x;\n }\n fn();\n }\n } catch (sample) {\n // This is inlined manually because closure doesn't do it for us.\n if (sample && control && typeof sample.stack === 'string') {\n // This extracts the first frame from the sample that isn't also in the control.\n // Skipping one frame that we assume is the frame that calls the two.\n var sampleLines = sample.stack.split('\\n');\n var controlLines = control.stack.split('\\n');\n var s = sampleLines.length - 1;\n var c = controlLines.length - 1;\n while(s >= 1 && c >= 0 && sampleLines[s] !== controlLines[c])// We expect at least one stack frame to be shared.\n // Typically this will be the root most one. However, stack frames may be\n // cut off due to maximum stack limits. In this case, one maybe cut off\n // earlier than the other. We assume that the sample is longer or the same\n // and there for cut off earlier. So we should find the root most frame in\n // the sample somewhere in the control.\n c--;\n for(; s >= 1 && c >= 0; s--, c--)// Next we find the first one that isn't the same which should be the\n // frame that called our sample function and the control.\n if (sampleLines[s] !== controlLines[c]) {\n // In V8, the first line is describing the message but other VMs don't.\n // If we're about to return the first line, and the control is also on the same\n // line, that's a pretty good indicator that our sample threw at same line as\n // the control. I.e. before we entered the sample frame. So we ignore this result.\n // This can happen if you passed a class to function component, or non-function.\n if (s !== 1 || c !== 1) do {\n s--;\n c--; // We may still have similar intermediate frames from the construct call.\n // The next one that isn't the same should be our match though.\n if (c < 0 || sampleLines[s] !== controlLines[c]) {\n // V8 adds a \"new\" prefix for native classes. Let's remove it to make it prettier.\n var _frame = '\\n' + sampleLines[s].replace(' at new ', ' at ');\n if (typeof fn === 'function') componentFrameCache.set(fn, _frame);\n return _frame;\n }\n }while (s >= 1 && c >= 0)\n break;\n }\n }\n } finally{\n reentry = false;\n ReactCurrentDispatcher1.current = previousDispatcher;\n reenableLogs();\n Error.prepareStackTrace = previousPrepareStackTrace;\n } // Fallback to just using the name if we couldn't make it throw.\n var name = fn ? fn.displayName || fn.name : '';\n var syntheticFrame = name ? describeBuiltInComponentFrame(name) : '';\n if (typeof fn === 'function') componentFrameCache.set(fn, syntheticFrame);\n return syntheticFrame;\n }\n function describeClassComponentFrame(ctor, source, ownerFn) {\n return describeNativeComponentFrame(ctor, true);\n }\n function describeFunctionComponentFrame(fn, source, ownerFn) {\n return describeNativeComponentFrame(fn, false);\n }\n function shouldConstruct(Component) {\n var prototype = Component.prototype;\n return !!(prototype && prototype.isReactComponent);\n }\n function describeUnknownElementTypeFrameInDEV(type, source, ownerFn) {\n if (type == null) return '';\n if (typeof type === 'function') return describeNativeComponentFrame(type, shouldConstruct(type));\n if (typeof type === 'string') return describeBuiltInComponentFrame(type);\n switch(type){\n case REACT_SUSPENSE_TYPE:\n return describeBuiltInComponentFrame('Suspense');\n case REACT_SUSPENSE_LIST_TYPE:\n return describeBuiltInComponentFrame('SuspenseList');\n }\n if (typeof type === 'object') switch(type.$$typeof){\n case REACT_FORWARD_REF_TYPE:\n return describeFunctionComponentFrame(type.render);\n case REACT_MEMO_TYPE:\n // Memo may contain any component type so we recursively resolve it.\n return describeUnknownElementTypeFrameInDEV(type.type, source, ownerFn);\n case REACT_BLOCK_TYPE:\n return describeFunctionComponentFrame(type._render);\n case REACT_LAZY_TYPE:\n var lazyComponent = type;\n var payload = lazyComponent._payload;\n var init = lazyComponent._init;\n try {\n // Lazy may contain any component type so we recursively resolve it.\n return describeUnknownElementTypeFrameInDEV(init(payload), source, ownerFn);\n } catch (x) {\n }\n }\n return '';\n }\n function describeFiber(fiber) {\n var owner = fiber._debugOwner ? fiber._debugOwner.type : null;\n var source = fiber._debugSource;\n switch(fiber.tag){\n case HostComponent:\n return describeBuiltInComponentFrame(fiber.type);\n case LazyComponent:\n return describeBuiltInComponentFrame('Lazy');\n case SuspenseComponent:\n return describeBuiltInComponentFrame('Suspense');\n case SuspenseListComponent:\n return describeBuiltInComponentFrame('SuspenseList');\n case FunctionComponent:\n case IndeterminateComponent:\n case SimpleMemoComponent:\n return describeFunctionComponentFrame(fiber.type);\n case ForwardRef:\n return describeFunctionComponentFrame(fiber.type.render);\n case Block:\n return describeFunctionComponentFrame(fiber.type._render);\n case ClassComponent:\n return describeClassComponentFrame(fiber.type);\n default:\n return '';\n }\n }\n function getStackByFiberInDevAndProd(workInProgress) {\n try {\n var info = '';\n var node = workInProgress;\n do {\n info += describeFiber(node);\n node = node.return;\n }while (node)\n return info;\n } catch (x) {\n return '\\nError generating stack: ' + x.message + '\\n' + x.stack;\n }\n }\n function getWrappedName(outerType, innerType, wrapperName) {\n var functionName = innerType.displayName || innerType.name || '';\n return outerType.displayName || (functionName !== '' ? wrapperName + \"(\" + functionName + \")\" : wrapperName);\n }\n function getContextName(type) {\n return type.displayName || 'Context';\n }\n function getComponentName(type) {\n if (type == null) // Host root, text node or just invalid type.\n return null;\n if (typeof type.tag === 'number') error1(\"Received an unexpected object in getComponentName(). This is likely a bug in React. Please file an issue.\");\n if (typeof type === 'function') return type.displayName || type.name || null;\n if (typeof type === 'string') return type;\n switch(type){\n case REACT_FRAGMENT_TYPE:\n return 'Fragment';\n case REACT_PORTAL_TYPE:\n return 'Portal';\n case REACT_PROFILER_TYPE:\n return 'Profiler';\n case REACT_STRICT_MODE_TYPE:\n return 'StrictMode';\n case REACT_SUSPENSE_TYPE:\n return 'Suspense';\n case REACT_SUSPENSE_LIST_TYPE:\n return 'SuspenseList';\n }\n if (typeof type === 'object') switch(type.$$typeof){\n case REACT_CONTEXT_TYPE:\n var context = type;\n return getContextName(context) + '.Consumer';\n case REACT_PROVIDER_TYPE:\n var provider = type;\n return getContextName(provider._context) + '.Provider';\n case REACT_FORWARD_REF_TYPE:\n return getWrappedName(type, type.render, 'ForwardRef');\n case REACT_MEMO_TYPE:\n return getComponentName(type.type);\n case REACT_BLOCK_TYPE:\n return getComponentName(type._render);\n case REACT_LAZY_TYPE:\n var lazyComponent = type;\n var payload = lazyComponent._payload;\n var init = lazyComponent._init;\n try {\n return getComponentName(init(payload));\n } catch (x) {\n return null;\n }\n }\n return null;\n }\n var ReactDebugCurrentFrame1 = ReactSharedInternals.ReactDebugCurrentFrame;\n var current1 = null;\n var isRendering = false;\n function getCurrentFiberOwnerNameInDevOrNull() {\n if (current1 === null) return null;\n var owner = current1._debugOwner;\n if (owner !== null && typeof owner !== 'undefined') return getComponentName(owner.type);\n return null;\n }\n function getCurrentFiberStackInDev() {\n if (current1 === null) return '';\n // Safe because if current fiber exists, we are reconciling,\n // and it is guaranteed to be the work-in-progress version.\n return getStackByFiberInDevAndProd(current1);\n }\n function resetCurrentFiber() {\n ReactDebugCurrentFrame1.getCurrentStack = null;\n current1 = null;\n isRendering = false;\n }\n function setCurrentFiber(fiber) {\n ReactDebugCurrentFrame1.getCurrentStack = getCurrentFiberStackInDev;\n current1 = fiber;\n isRendering = false;\n }\n function setIsRendering(rendering) {\n isRendering = rendering;\n }\n function getIsRendering() {\n return isRendering;\n }\n // Flow does not allow string concatenation of most non-string types. To work\n // around this limitation, we use an opaque type that can only be obtained by\n // passing the value through getToStringValue first.\n function toString(value) {\n return '' + value;\n }\n function getToStringValue(value) {\n switch(typeof value){\n case 'boolean':\n case 'number':\n case 'object':\n case 'string':\n case 'undefined':\n return value;\n default:\n // function, symbol are assigned as empty strings\n return '';\n }\n }\n var hasReadOnlyValue = {\n button: true,\n checkbox: true,\n image: true,\n hidden: true,\n radio: true,\n reset: true,\n submit: true\n };\n function checkControlledValueProps(tagName, props) {\n if (!(hasReadOnlyValue[props.type] || props.onChange || props.onInput || props.readOnly || props.disabled || props.value == null)) error1(\"You provided a `value` prop to a form field without an `onChange` handler. This will render a read-only field. If the field should be mutable use `defaultValue`. Otherwise, set either `onChange` or `readOnly`.\");\n if (!(props.onChange || props.readOnly || props.disabled || props.checked == null)) error1(\"You provided a `checked` prop to a form field without an `onChange` handler. This will render a read-only field. If the field should be mutable use `defaultChecked`. Otherwise, set either `onChange` or `readOnly`.\");\n }\n function isCheckable(elem) {\n var type = elem.type;\n var nodeName = elem.nodeName;\n return nodeName && nodeName.toLowerCase() === 'input' && (type === 'checkbox' || type === 'radio');\n }\n function getTracker(node) {\n return node._valueTracker;\n }\n function detachTracker(node) {\n node._valueTracker = null;\n }\n function getValueFromNode(node) {\n var value = '';\n if (!node) return value;\n if (isCheckable(node)) value = node.checked ? 'true' : 'false';\n else value = node.value;\n return value;\n }\n function trackValueOnNode(node) {\n var valueField = isCheckable(node) ? 'checked' : 'value';\n var descriptor = Object.getOwnPropertyDescriptor(node.constructor.prototype, valueField);\n var currentValue = '' + node[valueField]; // if someone has already defined a value or Safari, then bail\n // and don't track value will cause over reporting of changes,\n // but it's better then a hard failure\n // (needed for certain tests that spyOn input values and Safari)\n if (node.hasOwnProperty(valueField) || typeof descriptor === 'undefined' || typeof descriptor.get !== 'function' || typeof descriptor.set !== 'function') return;\n var get = descriptor.get, set = descriptor.set;\n Object.defineProperty(node, valueField, {\n configurable: true,\n get: function() {\n return get.call(this);\n },\n set: function(value) {\n currentValue = '' + value;\n set.call(this, value);\n }\n }); // We could've passed this the first time\n // but it triggers a bug in IE11 and Edge 14/15.\n // Calling defineProperty() again should be equivalent.\n // https://github.com/facebook/react/issues/11768\n Object.defineProperty(node, valueField, {\n enumerable: descriptor.enumerable\n });\n var tracker = {\n getValue: function() {\n return currentValue;\n },\n setValue: function(value) {\n currentValue = '' + value;\n },\n stopTracking: function() {\n detachTracker(node);\n delete node[valueField];\n }\n };\n return tracker;\n }\n function track(node) {\n if (getTracker(node)) return;\n // TODO: Once it's just Fiber we can move this to node._wrapperState\n node._valueTracker = trackValueOnNode(node);\n }\n function updateValueIfChanged(node) {\n if (!node) return false;\n var tracker = getTracker(node); // if there is no tracker at this point it's unlikely\n // that trying again will succeed\n if (!tracker) return true;\n var lastValue = tracker.getValue();\n var nextValue = getValueFromNode(node);\n if (nextValue !== lastValue) {\n tracker.setValue(nextValue);\n return true;\n }\n return false;\n }\n function getActiveElement(doc) {\n doc = doc || (typeof document !== 'undefined' ? document : undefined);\n if (typeof doc === 'undefined') return null;\n try {\n return doc.activeElement || doc.body;\n } catch (e) {\n return doc.body;\n }\n }\n var didWarnValueDefaultValue = false;\n var didWarnCheckedDefaultChecked = false;\n var didWarnControlledToUncontrolled = false;\n var didWarnUncontrolledToControlled = false;\n function isControlled(props) {\n var usesChecked = props.type === 'checkbox' || props.type === 'radio';\n return usesChecked ? props.checked != null : props.value != null;\n }\n /**\n * Implements an <input> host component that allows setting these optional\n * props: `checked`, `value`, `defaultChecked`, and `defaultValue`.\n *\n * If `checked` or `value` are not supplied (or null/undefined), user actions\n * that affect the checked state or value will trigger updates to the element.\n *\n * If they are supplied (and not null/undefined), the rendered element will not\n * trigger updates to the element. Instead, the props must change in order for\n * the rendered element to be updated.\n *\n * The rendered element will be initialized as unchecked (or `defaultChecked`)\n * with an empty value (or `defaultValue`).\n *\n * See http://www.w3.org/TR/2012/WD-html5-20121025/the-input-element.html\n */ function getHostProps(element, props) {\n var node = element;\n var checked = props.checked;\n var hostProps = _assign({\n }, props, {\n defaultChecked: undefined,\n defaultValue: undefined,\n value: undefined,\n checked: checked != null ? checked : node._wrapperState.initialChecked\n });\n return hostProps;\n }\n function initWrapperState(element, props) {\n checkControlledValueProps('input', props);\n if (props.checked !== undefined && props.defaultChecked !== undefined && !didWarnCheckedDefaultChecked) {\n error1(\"%s contains an input of type %s with both checked and defaultChecked props. Input elements must be either controlled or uncontrolled (specify either the checked prop, or the defaultChecked prop, but not both). Decide between using a controlled or uncontrolled input element and remove one of these props. More info: https://reactjs.org/link/controlled-components\", getCurrentFiberOwnerNameInDevOrNull() || 'A component', props.type);\n didWarnCheckedDefaultChecked = true;\n }\n if (props.value !== undefined && props.defaultValue !== undefined && !didWarnValueDefaultValue) {\n error1(\"%s contains an input of type %s with both value and defaultValue props. Input elements must be either controlled or uncontrolled (specify either the value prop, or the defaultValue prop, but not both). Decide between using a controlled or uncontrolled input element and remove one of these props. More info: https://reactjs.org/link/controlled-components\", getCurrentFiberOwnerNameInDevOrNull() || 'A component', props.type);\n didWarnValueDefaultValue = true;\n }\n var node = element;\n var defaultValue = props.defaultValue == null ? '' : props.defaultValue;\n node._wrapperState = {\n initialChecked: props.checked != null ? props.checked : props.defaultChecked,\n initialValue: getToStringValue(props.value != null ? props.value : defaultValue),\n controlled: isControlled(props)\n };\n }\n function updateChecked(element, props) {\n var node = element;\n var checked = props.checked;\n if (checked != null) setValueForProperty(node, 'checked', checked, false);\n }\n function updateWrapper(element, props) {\n var node = element;\n var controlled = isControlled(props);\n if (!node._wrapperState.controlled && controlled && !didWarnUncontrolledToControlled) {\n error1(\"A component is changing an uncontrolled input to be controlled. This is likely caused by the value changing from undefined to a defined value, which should not happen. Decide between using a controlled or uncontrolled input element for the lifetime of the component. More info: https://reactjs.org/link/controlled-components\");\n didWarnUncontrolledToControlled = true;\n }\n if (node._wrapperState.controlled && !controlled && !didWarnControlledToUncontrolled) {\n error1(\"A component is changing a controlled input to be uncontrolled. This is likely caused by the value changing from a defined to undefined, which should not happen. Decide between using a controlled or uncontrolled input element for the lifetime of the component. More info: https://reactjs.org/link/controlled-components\");\n didWarnControlledToUncontrolled = true;\n }\n updateChecked(element, props);\n var value = getToStringValue(props.value);\n var type = props.type;\n if (value != null) {\n if (type === 'number') {\n if (value === 0 && node.value === '' || // eslint-disable-next-line\n node.value != value) node.value = toString(value);\n } else if (node.value !== toString(value)) node.value = toString(value);\n } else if (type === 'submit' || type === 'reset') {\n // Submit/reset inputs need the attribute removed completely to avoid\n // blank-text buttons.\n node.removeAttribute('value');\n return;\n }\n // When syncing the value attribute, the value comes from a cascade of\n // properties:\n // 1. The value React property\n // 2. The defaultValue React property\n // 3. Otherwise there should be no change\n if (props.hasOwnProperty('value')) setDefaultValue(node, props.type, value);\n else if (props.hasOwnProperty('defaultValue')) setDefaultValue(node, props.type, getToStringValue(props.defaultValue));\n // When syncing the checked attribute, it only changes when it needs\n // to be removed, such as transitioning from a checkbox into a text input\n if (props.checked == null && props.defaultChecked != null) node.defaultChecked = !!props.defaultChecked;\n }\n function postMountWrapper(element, props, isHydrating) {\n var node = element; // Do not assign value if it is already set. This prevents user text input\n // from being lost during SSR hydration.\n if (props.hasOwnProperty('value') || props.hasOwnProperty('defaultValue')) {\n var type = props.type;\n var isButton = type === 'submit' || type === 'reset'; // Avoid setting value attribute on submit/reset inputs as it overrides the\n // default value provided by the browser. See: #12872\n if (isButton && (props.value === undefined || props.value === null)) return;\n var initialValue = toString(node._wrapperState.initialValue); // Do not assign value if it is already set. This prevents user text input\n // from being lost during SSR hydration.\n if (!isHydrating) // When syncing the value attribute, the value property should use\n // the wrapperState._initialValue property. This uses:\n //\n // 1. The value React property when present\n // 2. The defaultValue React property when present\n // 3. An empty string\n {\n if (initialValue !== node.value) node.value = initialValue;\n }\n // Otherwise, the value attribute is synchronized to the property,\n // so we assign defaultValue to the same thing as the value property\n // assignment step above.\n node.defaultValue = initialValue;\n } // Normally, we'd just do `node.checked = node.checked` upon initial mount, less this bug\n // this is needed to work around a chrome bug where setting defaultChecked\n // will sometimes influence the value of checked (even after detachment).\n // Reference: https://bugs.chromium.org/p/chromium/issues/detail?id=608416\n // We need to temporarily unset name to avoid disrupting radio button groups.\n var name = node.name;\n if (name !== '') node.name = '';\n // When syncing the checked attribute, both the checked property and\n // attribute are assigned at the same time using defaultChecked. This uses:\n //\n // 1. The checked React property when present\n // 2. The defaultChecked React property when present\n // 3. Otherwise, false\n node.defaultChecked = !node.defaultChecked;\n node.defaultChecked = !!node._wrapperState.initialChecked;\n if (name !== '') node.name = name;\n }\n function restoreControlledState(element, props) {\n var node = element;\n updateWrapper(node, props);\n updateNamedCousins(node, props);\n }\n function updateNamedCousins(rootNode, props) {\n var name = props.name;\n if (props.type === 'radio' && name != null) {\n var queryRoot = rootNode;\n while(queryRoot.parentNode)queryRoot = queryRoot.parentNode;\n // If `rootNode.form` was non-null, then we could try `form.elements`,\n // but that sometimes behaves strangely in IE8. We could also try using\n // `form.getElementsByName`, but that will only return direct children\n // and won't include inputs that use the HTML5 `form=` attribute. Since\n // the input might not even be in a form. It might not even be in the\n // document. Let's just use the local `querySelectorAll` to ensure we don't\n // miss anything.\n var group = queryRoot.querySelectorAll('input[name=' + JSON.stringify('' + name) + '][type=\"radio\"]');\n for(var i = 0; i < group.length; i++){\n var otherNode = group[i];\n if (otherNode === rootNode || otherNode.form !== rootNode.form) continue;\n // This will throw if radio buttons rendered by different copies of React\n // and the same name are rendered into the same form (same as #1939).\n // That's probably okay; we don't support it just as we don't support\n // mixing React radio buttons with non-React ones.\n var otherProps = getFiberCurrentPropsFromNode(otherNode);\n if (!otherProps) throw Error(\"ReactDOMInput: Mixing React and non-React radio inputs with the same `name` is not supported.\");\n // We need update the tracked value on the named cousin since the value\n // was changed but the input saw no event or value set\n updateValueIfChanged(otherNode); // If this is a controlled radio button group, forcing the input that\n // was previously checked to update will cause it to be come re-checked\n // as appropriate.\n updateWrapper(otherNode, otherProps);\n }\n }\n } // In Chrome, assigning defaultValue to certain input types triggers input validation.\n // For number inputs, the display value loses trailing decimal points. For email inputs,\n // Chrome raises \"The specified value <x> is not a valid email address\".\n //\n // Here we check to see if the defaultValue has actually changed, avoiding these problems\n // when the user is inputting text\n //\n // https://github.com/facebook/react/issues/7253\n function setDefaultValue(node, type, value) {\n if (type !== 'number' || getActiveElement(node.ownerDocument) !== node) {\n if (value == null) node.defaultValue = toString(node._wrapperState.initialValue);\n else if (node.defaultValue !== toString(value)) node.defaultValue = toString(value);\n }\n }\n var didWarnSelectedSetOnOption = false;\n var didWarnInvalidChild = false;\n function flattenChildren(children) {\n var content = ''; // Flatten children. We'll warn if they are invalid\n // during validateProps() which runs for hydration too.\n // Note that this would throw on non-element objects.\n // Elements are stringified (which is normally irrelevant\n // but matters for <fbt>).\n React.Children.forEach(children, function(child) {\n if (child == null) return;\n content += child; // Note: we don't warn about invalid children here.\n // Instead, this is done separately below so that\n // it happens during the hydration code path too.\n });\n return content;\n }\n /**\n * Implements an <option> host component that warns when `selected` is set.\n */ function validateProps(element, props) {\n // This mirrors the code path above, but runs for hydration too.\n // Warn about invalid children here so that client and hydration are consistent.\n // TODO: this seems like it could cause a DEV-only throw for hydration\n // if children contains a non-element object. We should try to avoid that.\n if (typeof props.children === 'object' && props.children !== null) React.Children.forEach(props.children, function(child) {\n if (child == null) return;\n if (typeof child === 'string' || typeof child === 'number') return;\n if (typeof child.type !== 'string') return;\n if (!didWarnInvalidChild) {\n didWarnInvalidChild = true;\n error1('Only strings and numbers are supported as <option> children.');\n }\n });\n // TODO: Remove support for `selected` in <option>.\n if (props.selected != null && !didWarnSelectedSetOnOption) {\n error1(\"Use the `defaultValue` or `value` props on <select> instead of setting `selected` on <option>.\");\n didWarnSelectedSetOnOption = true;\n }\n }\n function postMountWrapper$1(element, props) {\n // value=\"\" should make a value attribute (#6219)\n if (props.value != null) element.setAttribute('value', toString(getToStringValue(props.value)));\n }\n function getHostProps$1(element, props) {\n var hostProps = _assign({\n children: undefined\n }, props);\n var content = flattenChildren(props.children);\n if (content) hostProps.children = content;\n return hostProps;\n }\n var didWarnValueDefaultValue$1;\n didWarnValueDefaultValue$1 = false;\n function getDeclarationErrorAddendum() {\n var ownerName = getCurrentFiberOwnerNameInDevOrNull();\n if (ownerName) return '\\n\\nCheck the render method of `' + ownerName + '`.';\n return '';\n }\n var valuePropNames = [\n 'value',\n 'defaultValue'\n ];\n /**\n * Validation function for `value` and `defaultValue`.\n */ function checkSelectPropTypes(props) {\n checkControlledValueProps('select', props);\n for(var i = 0; i < valuePropNames.length; i++){\n var propName = valuePropNames[i];\n if (props[propName] == null) continue;\n var isArray = Array.isArray(props[propName]);\n if (props.multiple && !isArray) error1(\"The `%s` prop supplied to <select> must be an array if `multiple` is true.%s\", propName, getDeclarationErrorAddendum());\n else if (!props.multiple && isArray) error1(\"The `%s` prop supplied to <select> must be a scalar value if `multiple` is false.%s\", propName, getDeclarationErrorAddendum());\n }\n }\n function updateOptions(node, multiple, propValue, setDefaultSelected) {\n var options = node.options;\n if (multiple) {\n var selectedValues = propValue;\n var selectedValue = {\n };\n for(var i = 0; i < selectedValues.length; i++)// Prefix to avoid chaos with special keys.\n selectedValue['$' + selectedValues[i]] = true;\n for(var _i = 0; _i < options.length; _i++){\n var selected = selectedValue.hasOwnProperty('$' + options[_i].value);\n if (options[_i].selected !== selected) options[_i].selected = selected;\n if (selected && setDefaultSelected) options[_i].defaultSelected = true;\n }\n } else {\n // Do not set `select.value` as exact behavior isn't consistent across all\n // browsers for all cases.\n var _selectedValue = toString(getToStringValue(propValue));\n var defaultSelected = null;\n for(var _i2 = 0; _i2 < options.length; _i2++){\n if (options[_i2].value === _selectedValue) {\n options[_i2].selected = true;\n if (setDefaultSelected) options[_i2].defaultSelected = true;\n return;\n }\n if (defaultSelected === null && !options[_i2].disabled) defaultSelected = options[_i2];\n }\n if (defaultSelected !== null) defaultSelected.selected = true;\n }\n }\n /**\n * Implements a <select> host component that allows optionally setting the\n * props `value` and `defaultValue`. If `multiple` is false, the prop must be a\n * stringable. If `multiple` is true, the prop must be an array of stringables.\n *\n * If `value` is not supplied (or null/undefined), user actions that change the\n * selected option will trigger updates to the rendered options.\n *\n * If it is supplied (and not null/undefined), the rendered options will not\n * update in response to user actions. Instead, the `value` prop must change in\n * order for the rendered options to update.\n *\n * If `defaultValue` is provided, any options with the supplied values will be\n * selected.\n */ function getHostProps$2(element, props) {\n return _assign({\n }, props, {\n value: undefined\n });\n }\n function initWrapperState$1(element, props) {\n var node = element;\n checkSelectPropTypes(props);\n node._wrapperState = {\n wasMultiple: !!props.multiple\n };\n if (props.value !== undefined && props.defaultValue !== undefined && !didWarnValueDefaultValue$1) {\n error1(\"Select elements must be either controlled or uncontrolled (specify either the value prop, or the defaultValue prop, but not both). Decide between using a controlled or uncontrolled select element and remove one of these props. More info: https://reactjs.org/link/controlled-components\");\n didWarnValueDefaultValue$1 = true;\n }\n }\n function postMountWrapper$2(element, props) {\n var node = element;\n node.multiple = !!props.multiple;\n var value = props.value;\n if (value != null) updateOptions(node, !!props.multiple, value, false);\n else if (props.defaultValue != null) updateOptions(node, !!props.multiple, props.defaultValue, true);\n }\n function postUpdateWrapper(element, props) {\n var node = element;\n var wasMultiple = node._wrapperState.wasMultiple;\n node._wrapperState.wasMultiple = !!props.multiple;\n var value = props.value;\n if (value != null) updateOptions(node, !!props.multiple, value, false);\n else if (wasMultiple !== !!props.multiple) {\n // For simplicity, reapply `defaultValue` if `multiple` is toggled.\n if (props.defaultValue != null) updateOptions(node, !!props.multiple, props.defaultValue, true);\n else // Revert the select back to its default unselected state.\n updateOptions(node, !!props.multiple, props.multiple ? [] : '', false);\n }\n }\n function restoreControlledState$1(element, props) {\n var node = element;\n var value = props.value;\n if (value != null) updateOptions(node, !!props.multiple, value, false);\n }\n var didWarnValDefaultVal = false;\n /**\n * Implements a <textarea> host component that allows setting `value`, and\n * `defaultValue`. This differs from the traditional DOM API because value is\n * usually set as PCDATA children.\n *\n * If `value` is not supplied (or null/undefined), user actions that affect the\n * value will trigger updates to the element.\n *\n * If `value` is supplied (and not null/undefined), the rendered element will\n * not trigger updates to the element. Instead, the `value` prop must change in\n * order for the rendered element to be updated.\n *\n * The rendered element will be initialized with an empty value, the prop\n * `defaultValue` if specified, or the children content (deprecated).\n */ function getHostProps$3(element, props) {\n var node = element;\n if (!(props.dangerouslySetInnerHTML == null)) throw Error(\"`dangerouslySetInnerHTML` does not make sense on <textarea>.\");\n // Always set children to the same thing. In IE9, the selection range will\n // get reset if `textContent` is mutated. We could add a check in setTextContent\n // to only set the value if/when the value differs from the node value (which would\n // completely solve this IE9 bug), but Sebastian+Sophie seemed to like this\n // solution. The value can be a boolean or object so that's why it's forced\n // to be a string.\n var hostProps = _assign({\n }, props, {\n value: undefined,\n defaultValue: undefined,\n children: toString(node._wrapperState.initialValue)\n });\n return hostProps;\n }\n function initWrapperState$2(element, props) {\n var node = element;\n checkControlledValueProps('textarea', props);\n if (props.value !== undefined && props.defaultValue !== undefined && !didWarnValDefaultVal) {\n error1(\"%s contains a textarea with both value and defaultValue props. Textarea elements must be either controlled or uncontrolled (specify either the value prop, or the defaultValue prop, but not both). Decide between using a controlled or uncontrolled textarea and remove one of these props. More info: https://reactjs.org/link/controlled-components\", getCurrentFiberOwnerNameInDevOrNull() || 'A component');\n didWarnValDefaultVal = true;\n }\n var initialValue = props.value; // Only bother fetching default value if we're going to use it\n if (initialValue == null) {\n var children = props.children, defaultValue = props.defaultValue;\n if (children != null) {\n error1(\"Use the `defaultValue` or `value` props instead of setting children on <textarea>.\");\n if (!(defaultValue == null)) throw Error(\"If you supply `defaultValue` on a <textarea>, do not pass children.\");\n if (Array.isArray(children)) {\n if (!(children.length <= 1)) throw Error(\"<textarea> can only have at most one child.\");\n children = children[0];\n }\n defaultValue = children;\n }\n if (defaultValue == null) defaultValue = '';\n initialValue = defaultValue;\n }\n node._wrapperState = {\n initialValue: getToStringValue(initialValue)\n };\n }\n function updateWrapper$1(element, props) {\n var node = element;\n var value = getToStringValue(props.value);\n var defaultValue = getToStringValue(props.defaultValue);\n if (value != null) {\n // Cast `value` to a string to ensure the value is set correctly. While\n // browsers typically do this as necessary, jsdom doesn't.\n var newValue = toString(value); // To avoid side effects (such as losing text selection), only set value if changed\n if (newValue !== node.value) node.value = newValue;\n if (props.defaultValue == null && node.defaultValue !== newValue) node.defaultValue = newValue;\n }\n if (defaultValue != null) node.defaultValue = toString(defaultValue);\n }\n function postMountWrapper$3(element, props) {\n var node = element; // This is in postMount because we need access to the DOM node, which is not\n // available until after the component has mounted.\n var textContent = node.textContent; // Only set node.value if textContent is equal to the expected\n // initial value. In IE10/IE11 there is a bug where the placeholder attribute\n // will populate textContent as well.\n // https://developer.microsoft.com/microsoft-edge/platform/issues/101525/\n if (textContent === node._wrapperState.initialValue) {\n if (textContent !== '' && textContent !== null) node.value = textContent;\n }\n }\n function restoreControlledState$2(element, props) {\n // DOM component is still mounted; update\n updateWrapper$1(element, props);\n }\n var HTML_NAMESPACE = 'http://www.w3.org/1999/xhtml';\n var MATH_NAMESPACE = 'http://www.w3.org/1998/Math/MathML';\n var SVG_NAMESPACE = 'http://www.w3.org/2000/svg';\n var Namespaces = {\n html: HTML_NAMESPACE,\n mathml: MATH_NAMESPACE,\n svg: SVG_NAMESPACE\n }; // Assumes there is no parent namespace.\n function getIntrinsicNamespace(type) {\n switch(type){\n case 'svg':\n return SVG_NAMESPACE;\n case 'math':\n return MATH_NAMESPACE;\n default:\n return HTML_NAMESPACE;\n }\n }\n function getChildNamespace(parentNamespace, type) {\n if (parentNamespace == null || parentNamespace === HTML_NAMESPACE) // No (or default) parent namespace: potential entry point.\n return getIntrinsicNamespace(type);\n if (parentNamespace === SVG_NAMESPACE && type === 'foreignObject') // We're leaving SVG.\n return HTML_NAMESPACE;\n // By default, pass namespace below.\n return parentNamespace;\n }\n /* globals MSApp */ /**\n * Create a function which has 'unsafe' privileges (required by windows8 apps)\n */ var createMicrosoftUnsafeLocalFunction = function(func) {\n if (typeof MSApp !== 'undefined' && MSApp.execUnsafeLocalFunction) return function(arg0, arg1, arg2, arg3) {\n MSApp.execUnsafeLocalFunction(function() {\n return func(arg0, arg1, arg2, arg3);\n });\n };\n else return func;\n };\n var reusableSVGContainer;\n /**\n * Set the innerHTML property of a node\n *\n * @param {DOMElement} node\n * @param {string} html\n * @internal\n */ var setInnerHTML = createMicrosoftUnsafeLocalFunction(function(node, html) {\n if (node.namespaceURI === Namespaces.svg) {\n if (!('innerHTML' in node)) {\n // IE does not have innerHTML for SVG nodes, so instead we inject the\n // new markup in a temp node and then move the child nodes across into\n // the target node\n reusableSVGContainer = reusableSVGContainer || document.createElement('div');\n reusableSVGContainer.innerHTML = '<svg>' + html.valueOf().toString() + '</svg>';\n var svgNode = reusableSVGContainer.firstChild;\n while(node.firstChild)node.removeChild(node.firstChild);\n while(svgNode.firstChild)node.appendChild(svgNode.firstChild);\n return;\n }\n }\n node.innerHTML = html;\n });\n /**\n * HTML nodeType values that represent the type of the node\n */ var ELEMENT_NODE = 1;\n var TEXT_NODE = 3;\n var COMMENT_NODE = 8;\n var DOCUMENT_NODE = 9;\n var DOCUMENT_FRAGMENT_NODE = 11;\n /**\n * Set the textContent property of a node. For text updates, it's faster\n * to set the `nodeValue` of the Text node directly instead of using\n * `.textContent` which will remove the existing node and create a new one.\n *\n * @param {DOMElement} node\n * @param {string} text\n * @internal\n */ var setTextContent = function(node, text) {\n if (text) {\n var firstChild = node.firstChild;\n if (firstChild && firstChild === node.lastChild && firstChild.nodeType === TEXT_NODE) {\n firstChild.nodeValue = text;\n return;\n }\n }\n node.textContent = text;\n };\n // List derived from Gecko source code:\n // https://github.com/mozilla/gecko-dev/blob/4e638efc71/layout/style/test/property_database.js\n var shorthandToLonghand = {\n animation: [\n 'animationDelay',\n 'animationDirection',\n 'animationDuration',\n 'animationFillMode',\n 'animationIterationCount',\n 'animationName',\n 'animationPlayState',\n 'animationTimingFunction'\n ],\n background: [\n 'backgroundAttachment',\n 'backgroundClip',\n 'backgroundColor',\n 'backgroundImage',\n 'backgroundOrigin',\n 'backgroundPositionX',\n 'backgroundPositionY',\n 'backgroundRepeat',\n 'backgroundSize'\n ],\n backgroundPosition: [\n 'backgroundPositionX',\n 'backgroundPositionY'\n ],\n border: [\n 'borderBottomColor',\n 'borderBottomStyle',\n 'borderBottomWidth',\n 'borderImageOutset',\n 'borderImageRepeat',\n 'borderImageSlice',\n 'borderImageSource',\n 'borderImageWidth',\n 'borderLeftColor',\n 'borderLeftStyle',\n 'borderLeftWidth',\n 'borderRightColor',\n 'borderRightStyle',\n 'borderRightWidth',\n 'borderTopColor',\n 'borderTopStyle',\n 'borderTopWidth'\n ],\n borderBlockEnd: [\n 'borderBlockEndColor',\n 'borderBlockEndStyle',\n 'borderBlockEndWidth'\n ],\n borderBlockStart: [\n 'borderBlockStartColor',\n 'borderBlockStartStyle',\n 'borderBlockStartWidth'\n ],\n borderBottom: [\n 'borderBottomColor',\n 'borderBottomStyle',\n 'borderBottomWidth'\n ],\n borderColor: [\n 'borderBottomColor',\n 'borderLeftColor',\n 'borderRightColor',\n 'borderTopColor'\n ],\n borderImage: [\n 'borderImageOutset',\n 'borderImageRepeat',\n 'borderImageSlice',\n 'borderImageSource',\n 'borderImageWidth'\n ],\n borderInlineEnd: [\n 'borderInlineEndColor',\n 'borderInlineEndStyle',\n 'borderInlineEndWidth'\n ],\n borderInlineStart: [\n 'borderInlineStartColor',\n 'borderInlineStartStyle',\n 'borderInlineStartWidth'\n ],\n borderLeft: [\n 'borderLeftColor',\n 'borderLeftStyle',\n 'borderLeftWidth'\n ],\n borderRadius: [\n 'borderBottomLeftRadius',\n 'borderBottomRightRadius',\n 'borderTopLeftRadius',\n 'borderTopRightRadius'\n ],\n borderRight: [\n 'borderRightColor',\n 'borderRightStyle',\n 'borderRightWidth'\n ],\n borderStyle: [\n 'borderBottomStyle',\n 'borderLeftStyle',\n 'borderRightStyle',\n 'borderTopStyle'\n ],\n borderTop: [\n 'borderTopColor',\n 'borderTopStyle',\n 'borderTopWidth'\n ],\n borderWidth: [\n 'borderBottomWidth',\n 'borderLeftWidth',\n 'borderRightWidth',\n 'borderTopWidth'\n ],\n columnRule: [\n 'columnRuleColor',\n 'columnRuleStyle',\n 'columnRuleWidth'\n ],\n columns: [\n 'columnCount',\n 'columnWidth'\n ],\n flex: [\n 'flexBasis',\n 'flexGrow',\n 'flexShrink'\n ],\n flexFlow: [\n 'flexDirection',\n 'flexWrap'\n ],\n font: [\n 'fontFamily',\n 'fontFeatureSettings',\n 'fontKerning',\n 'fontLanguageOverride',\n 'fontSize',\n 'fontSizeAdjust',\n 'fontStretch',\n 'fontStyle',\n 'fontVariant',\n 'fontVariantAlternates',\n 'fontVariantCaps',\n 'fontVariantEastAsian',\n 'fontVariantLigatures',\n 'fontVariantNumeric',\n 'fontVariantPosition',\n 'fontWeight',\n 'lineHeight'\n ],\n fontVariant: [\n 'fontVariantAlternates',\n 'fontVariantCaps',\n 'fontVariantEastAsian',\n 'fontVariantLigatures',\n 'fontVariantNumeric',\n 'fontVariantPosition'\n ],\n gap: [\n 'columnGap',\n 'rowGap'\n ],\n grid: [\n 'gridAutoColumns',\n 'gridAutoFlow',\n 'gridAutoRows',\n 'gridTemplateAreas',\n 'gridTemplateColumns',\n 'gridTemplateRows'\n ],\n gridArea: [\n 'gridColumnEnd',\n 'gridColumnStart',\n 'gridRowEnd',\n 'gridRowStart'\n ],\n gridColumn: [\n 'gridColumnEnd',\n 'gridColumnStart'\n ],\n gridColumnGap: [\n 'columnGap'\n ],\n gridGap: [\n 'columnGap',\n 'rowGap'\n ],\n gridRow: [\n 'gridRowEnd',\n 'gridRowStart'\n ],\n gridRowGap: [\n 'rowGap'\n ],\n gridTemplate: [\n 'gridTemplateAreas',\n 'gridTemplateColumns',\n 'gridTemplateRows'\n ],\n listStyle: [\n 'listStyleImage',\n 'listStylePosition',\n 'listStyleType'\n ],\n margin: [\n 'marginBottom',\n 'marginLeft',\n 'marginRight',\n 'marginTop'\n ],\n marker: [\n 'markerEnd',\n 'markerMid',\n 'markerStart'\n ],\n mask: [\n 'maskClip',\n 'maskComposite',\n 'maskImage',\n 'maskMode',\n 'maskOrigin',\n 'maskPositionX',\n 'maskPositionY',\n 'maskRepeat',\n 'maskSize'\n ],\n maskPosition: [\n 'maskPositionX',\n 'maskPositionY'\n ],\n outline: [\n 'outlineColor',\n 'outlineStyle',\n 'outlineWidth'\n ],\n overflow: [\n 'overflowX',\n 'overflowY'\n ],\n padding: [\n 'paddingBottom',\n 'paddingLeft',\n 'paddingRight',\n 'paddingTop'\n ],\n placeContent: [\n 'alignContent',\n 'justifyContent'\n ],\n placeItems: [\n 'alignItems',\n 'justifyItems'\n ],\n placeSelf: [\n 'alignSelf',\n 'justifySelf'\n ],\n textDecoration: [\n 'textDecorationColor',\n 'textDecorationLine',\n 'textDecorationStyle'\n ],\n textEmphasis: [\n 'textEmphasisColor',\n 'textEmphasisStyle'\n ],\n transition: [\n 'transitionDelay',\n 'transitionDuration',\n 'transitionProperty',\n 'transitionTimingFunction'\n ],\n wordWrap: [\n 'overflowWrap'\n ]\n };\n /**\n * CSS properties which accept numbers but are not in units of \"px\".\n */ var isUnitlessNumber = {\n animationIterationCount: true,\n borderImageOutset: true,\n borderImageSlice: true,\n borderImageWidth: true,\n boxFlex: true,\n boxFlexGroup: true,\n boxOrdinalGroup: true,\n columnCount: true,\n columns: true,\n flex: true,\n flexGrow: true,\n flexPositive: true,\n flexShrink: true,\n flexNegative: true,\n flexOrder: true,\n gridArea: true,\n gridRow: true,\n gridRowEnd: true,\n gridRowSpan: true,\n gridRowStart: true,\n gridColumn: true,\n gridColumnEnd: true,\n gridColumnSpan: true,\n gridColumnStart: true,\n fontWeight: true,\n lineClamp: true,\n lineHeight: true,\n opacity: true,\n order: true,\n orphans: true,\n tabSize: true,\n widows: true,\n zIndex: true,\n zoom: true,\n // SVG-related properties\n fillOpacity: true,\n floodOpacity: true,\n stopOpacity: true,\n strokeDasharray: true,\n strokeDashoffset: true,\n strokeMiterlimit: true,\n strokeOpacity: true,\n strokeWidth: true\n };\n /**\n * @param {string} prefix vendor-specific prefix, eg: Webkit\n * @param {string} key style name, eg: transitionDuration\n * @return {string} style name prefixed with `prefix`, properly camelCased, eg:\n * WebkitTransitionDuration\n */ function prefixKey(prefix, key) {\n return prefix + key.charAt(0).toUpperCase() + key.substring(1);\n }\n /**\n * Support style names that may come passed in prefixed by adding permutations\n * of vendor prefixes.\n */ var prefixes1 = [\n 'Webkit',\n 'ms',\n 'Moz',\n 'O'\n ]; // Using Object.keys here, or else the vanilla for-in loop makes IE8 go into an\n // infinite loop, because it iterates over the newly added props too.\n Object.keys(isUnitlessNumber).forEach(function(prop) {\n prefixes1.forEach(function(prefix) {\n isUnitlessNumber[prefixKey(prefix, prop)] = isUnitlessNumber[prop];\n });\n });\n /**\n * Convert a value into the proper css writable value. The style name `name`\n * should be logical (no hyphens), as specified\n * in `CSSProperty.isUnitlessNumber`.\n *\n * @param {string} name CSS property name such as `topMargin`.\n * @param {*} value CSS property value such as `10px`.\n * @return {string} Normalized style value with dimensions applied.\n */ function dangerousStyleValue(name, value, isCustomProperty) {\n // Note that we've removed escapeTextForBrowser() calls here since the\n // whole string will be escaped when the attribute is injected into\n // the markup. If you provide unsafe user data here they can inject\n // arbitrary CSS which may be problematic (I couldn't repro this):\n // https://www.owasp.org/index.php/XSS_Filter_Evasion_Cheat_Sheet\n // http://www.thespanner.co.uk/2007/11/26/ultimate-xss-css-injection/\n // This is not an XSS hole but instead a potential CSS injection issue\n // which has lead to a greater discussion about how we're going to\n // trust URLs moving forward. See #2115901\n var isEmpty = value == null || typeof value === 'boolean' || value === '';\n if (isEmpty) return '';\n if (!isCustomProperty && typeof value === 'number' && value !== 0 && !(isUnitlessNumber.hasOwnProperty(name) && isUnitlessNumber[name])) return value + 'px'; // Presumes implicit 'px' suffix for unitless numbers\n return ('' + value).trim();\n }\n var uppercasePattern = /([A-Z])/g;\n var msPattern = /^ms-/;\n /**\n * Hyphenates a camelcased CSS property name, for example:\n *\n * > hyphenateStyleName('backgroundColor')\n * < \"background-color\"\n * > hyphenateStyleName('MozTransition')\n * < \"-moz-transition\"\n * > hyphenateStyleName('msTransition')\n * < \"-ms-transition\"\n *\n * As Modernizr suggests (http://modernizr.com/docs/#prefixed), an `ms` prefix\n * is converted to `-ms-`.\n */ function hyphenateStyleName(name) {\n return name.replace(uppercasePattern, '-$1').toLowerCase().replace(msPattern, '-ms-');\n }\n var warnValidStyle = function() {\n };\n // 'msTransform' is correct, but the other prefixes should be capitalized\n var badVendoredStyleNamePattern = /^(?:webkit|moz|o)[A-Z]/;\n var msPattern$1 = /^-ms-/;\n var hyphenPattern = /-(.)/g; // style values shouldn't contain a semicolon\n var badStyleValueWithSemicolonPattern = /;\\s*$/;\n var warnedStyleNames = {\n };\n var warnedStyleValues = {\n };\n var warnedForNaNValue = false;\n var warnedForInfinityValue = false;\n var camelize = function(string) {\n return string.replace(hyphenPattern, function(_, character) {\n return character.toUpperCase();\n });\n };\n var warnHyphenatedStyleName = function(name) {\n if (warnedStyleNames.hasOwnProperty(name) && warnedStyleNames[name]) return;\n warnedStyleNames[name] = true;\n error1('Unsupported style property %s. Did you mean %s?', name, // (http://www.andismith.com/blog/2012/02/modernizr-prefixed/), an `-ms` prefix\n // is converted to lowercase `ms`.\n camelize(name.replace(msPattern$1, 'ms-')));\n };\n var warnBadVendoredStyleName = function(name) {\n if (warnedStyleNames.hasOwnProperty(name) && warnedStyleNames[name]) return;\n warnedStyleNames[name] = true;\n error1('Unsupported vendor-prefixed style property %s. Did you mean %s?', name, name.charAt(0).toUpperCase() + name.slice(1));\n };\n var warnStyleValueWithSemicolon = function(name, value) {\n if (warnedStyleValues.hasOwnProperty(value) && warnedStyleValues[value]) return;\n warnedStyleValues[value] = true;\n error1(\"Style property values shouldn't contain a semicolon. Try \\\"%s: %s\\\" instead.\", name, value.replace(badStyleValueWithSemicolonPattern, ''));\n };\n var warnStyleValueIsNaN = function(name, value) {\n if (warnedForNaNValue) return;\n warnedForNaNValue = true;\n error1('`NaN` is an invalid value for the `%s` css style property.', name);\n };\n var warnStyleValueIsInfinity = function(name, value) {\n if (warnedForInfinityValue) return;\n warnedForInfinityValue = true;\n error1('`Infinity` is an invalid value for the `%s` css style property.', name);\n };\n warnValidStyle = function(name, value) {\n if (name.indexOf('-') > -1) warnHyphenatedStyleName(name);\n else if (badVendoredStyleNamePattern.test(name)) warnBadVendoredStyleName(name);\n else if (badStyleValueWithSemicolonPattern.test(value)) warnStyleValueWithSemicolon(name, value);\n if (typeof value === 'number') {\n if (isNaN(value)) warnStyleValueIsNaN(name, value);\n else if (!isFinite(value)) warnStyleValueIsInfinity(name, value);\n }\n };\n var warnValidStyle$1 = warnValidStyle;\n /**\n * Operations for dealing with CSS properties.\n */ /**\n * This creates a string that is expected to be equivalent to the style\n * attribute generated by server-side rendering. It by-passes warnings and\n * security checks so it's not safe to use this value for anything other than\n * comparison. It is only used in DEV for SSR validation.\n */ function createDangerousStringForStyles(styles) {\n var serialized = '';\n var delimiter = '';\n for(var styleName in styles){\n if (!styles.hasOwnProperty(styleName)) continue;\n var styleValue = styles[styleName];\n if (styleValue != null) {\n var isCustomProperty = styleName.indexOf('--') === 0;\n serialized += delimiter + (isCustomProperty ? styleName : hyphenateStyleName(styleName)) + ':';\n serialized += dangerousStyleValue(styleName, styleValue, isCustomProperty);\n delimiter = ';';\n }\n }\n return serialized || null;\n }\n /**\n * Sets the value for multiple styles on a node. If a value is specified as\n * '' (empty string), the corresponding style property will be unset.\n *\n * @param {DOMElement} node\n * @param {object} styles\n */ function setValueForStyles(node, styles) {\n var style = node.style;\n for(var styleName in styles){\n if (!styles.hasOwnProperty(styleName)) continue;\n var isCustomProperty = styleName.indexOf('--') === 0;\n if (!isCustomProperty) warnValidStyle$1(styleName, styles[styleName]);\n var styleValue = dangerousStyleValue(styleName, styles[styleName], isCustomProperty);\n if (styleName === 'float') styleName = 'cssFloat';\n if (isCustomProperty) style.setProperty(styleName, styleValue);\n else style[styleName] = styleValue;\n }\n }\n function isValueEmpty(value) {\n return value == null || typeof value === 'boolean' || value === '';\n }\n /**\n * Given {color: 'red', overflow: 'hidden'} returns {\n * color: 'color',\n * overflowX: 'overflow',\n * overflowY: 'overflow',\n * }. This can be read as \"the overflowY property was set by the overflow\n * shorthand\". That is, the values are the property that each was derived from.\n */ function expandShorthandMap(styles) {\n var expanded = {\n };\n for(var key in styles){\n var longhands = shorthandToLonghand[key] || [\n key\n ];\n for(var i = 0; i < longhands.length; i++)expanded[longhands[i]] = key;\n }\n return expanded;\n }\n /**\n * When mixing shorthand and longhand property names, we warn during updates if\n * we expect an incorrect result to occur. In particular, we warn for:\n *\n * Updating a shorthand property (longhand gets overwritten):\n * {font: 'foo', fontVariant: 'bar'} -> {font: 'baz', fontVariant: 'bar'}\n * becomes .style.font = 'baz'\n * Removing a shorthand property (longhand gets lost too):\n * {font: 'foo', fontVariant: 'bar'} -> {fontVariant: 'bar'}\n * becomes .style.font = ''\n * Removing a longhand property (should revert to shorthand; doesn't):\n * {font: 'foo', fontVariant: 'bar'} -> {font: 'foo'}\n * becomes .style.fontVariant = ''\n */ function validateShorthandPropertyCollisionInDev(styleUpdates, nextStyles) {\n if (!nextStyles) return;\n var expandedUpdates = expandShorthandMap(styleUpdates);\n var expandedStyles = expandShorthandMap(nextStyles);\n var warnedAbout = {\n };\n for(var key in expandedUpdates){\n var originalKey = expandedUpdates[key];\n var correctOriginalKey = expandedStyles[key];\n if (correctOriginalKey && originalKey !== correctOriginalKey) {\n var warningKey = originalKey + ',' + correctOriginalKey;\n if (warnedAbout[warningKey]) continue;\n warnedAbout[warningKey] = true;\n error1(\"%s a style property during rerender (%s) when a conflicting property is set (%s) can lead to styling bugs. To avoid this, don't mix shorthand and non-shorthand properties for the same value; instead, replace the shorthand with separate values.\", isValueEmpty(styleUpdates[originalKey]) ? 'Removing' : 'Updating', originalKey, correctOriginalKey);\n }\n }\n }\n // For HTML, certain tags should omit their close tag. We keep a list for\n // those special-case tags.\n var omittedCloseTags = {\n area: true,\n base: true,\n br: true,\n col: true,\n embed: true,\n hr: true,\n img: true,\n input: true,\n keygen: true,\n link: true,\n meta: true,\n param: true,\n source: true,\n track: true,\n wbr: true // NOTE: menuitem's close tag should be omitted, but that causes problems.\n };\n // `omittedCloseTags` except that `menuitem` should still have its closing tag.\n var voidElementTags = _assign({\n menuitem: true\n }, omittedCloseTags);\n var HTML = '__html';\n function assertValidProps(tag, props) {\n if (!props) return;\n // Note the use of `==` which checks for null or undefined.\n if (voidElementTags[tag]) {\n if (!(props.children == null && props.dangerouslySetInnerHTML == null)) throw Error(tag + \" is a void element tag and must neither have `children` nor use `dangerouslySetInnerHTML`.\");\n }\n if (props.dangerouslySetInnerHTML != null) {\n if (!(props.children == null)) throw Error(\"Can only set one of `children` or `props.dangerouslySetInnerHTML`.\");\n if (!(typeof props.dangerouslySetInnerHTML === 'object' && HTML in props.dangerouslySetInnerHTML)) throw Error(\"`props.dangerouslySetInnerHTML` must be in the form `{__html: ...}`. Please visit https://reactjs.org/link/dangerously-set-inner-html for more information.\");\n }\n if (!props.suppressContentEditableWarning && props.contentEditable && props.children != null) error1(\"A component is `contentEditable` and contains `children` managed by React. It is now your responsibility to guarantee that none of those nodes are unexpectedly modified or duplicated. This is probably not intentional.\");\n if (!(props.style == null || typeof props.style === 'object')) throw Error(\"The `style` prop expects a mapping from style properties to values, not a string. For example, style={{marginRight: spacing + 'em'}} when using JSX.\");\n }\n function isCustomComponent(tagName, props) {\n if (tagName.indexOf('-') === -1) return typeof props.is === 'string';\n switch(tagName){\n // These are reserved SVG and MathML elements.\n // We don't mind this list too much because we expect it to never grow.\n // The alternative is to track the namespace in a few places which is convoluted.\n // https://w3c.github.io/webcomponents/spec/custom/#custom-elements-core-concepts\n case 'annotation-xml':\n case 'color-profile':\n case 'font-face':\n case 'font-face-src':\n case 'font-face-uri':\n case 'font-face-format':\n case 'font-face-name':\n case 'missing-glyph':\n return false;\n default:\n return true;\n }\n }\n // When adding attributes to the HTML or SVG allowed attribute list, be sure to\n // also add them to this module to ensure casing and incorrect name\n // warnings.\n var possibleStandardNames = {\n // HTML\n accept: 'accept',\n acceptcharset: 'acceptCharset',\n 'accept-charset': 'acceptCharset',\n accesskey: 'accessKey',\n action: 'action',\n allowfullscreen: 'allowFullScreen',\n alt: 'alt',\n as: 'as',\n async: 'async',\n autocapitalize: 'autoCapitalize',\n autocomplete: 'autoComplete',\n autocorrect: 'autoCorrect',\n autofocus: 'autoFocus',\n autoplay: 'autoPlay',\n autosave: 'autoSave',\n capture: 'capture',\n cellpadding: 'cellPadding',\n cellspacing: 'cellSpacing',\n challenge: 'challenge',\n charset: 'charSet',\n checked: 'checked',\n children: 'children',\n cite: 'cite',\n class: 'className',\n classid: 'classID',\n classname: 'className',\n cols: 'cols',\n colspan: 'colSpan',\n content: 'content',\n contenteditable: 'contentEditable',\n contextmenu: 'contextMenu',\n controls: 'controls',\n controlslist: 'controlsList',\n coords: 'coords',\n crossorigin: 'crossOrigin',\n dangerouslysetinnerhtml: 'dangerouslySetInnerHTML',\n data: 'data',\n datetime: 'dateTime',\n default: 'default',\n defaultchecked: 'defaultChecked',\n defaultvalue: 'defaultValue',\n defer: 'defer',\n dir: 'dir',\n disabled: 'disabled',\n disablepictureinpicture: 'disablePictureInPicture',\n disableremoteplayback: 'disableRemotePlayback',\n download: 'download',\n draggable: 'draggable',\n enctype: 'encType',\n enterkeyhint: 'enterKeyHint',\n for: 'htmlFor',\n form: 'form',\n formmethod: 'formMethod',\n formaction: 'formAction',\n formenctype: 'formEncType',\n formnovalidate: 'formNoValidate',\n formtarget: 'formTarget',\n frameborder: 'frameBorder',\n headers: 'headers',\n height: 'height',\n hidden: 'hidden',\n high: 'high',\n href: 'href',\n hreflang: 'hrefLang',\n htmlfor: 'htmlFor',\n httpequiv: 'httpEquiv',\n 'http-equiv': 'httpEquiv',\n icon: 'icon',\n id: 'id',\n innerhtml: 'innerHTML',\n inputmode: 'inputMode',\n integrity: 'integrity',\n is: 'is',\n itemid: 'itemID',\n itemprop: 'itemProp',\n itemref: 'itemRef',\n itemscope: 'itemScope',\n itemtype: 'itemType',\n keyparams: 'keyParams',\n keytype: 'keyType',\n kind: 'kind',\n label: 'label',\n lang: 'lang',\n list: 'list',\n loop: 'loop',\n low: 'low',\n manifest: 'manifest',\n marginwidth: 'marginWidth',\n marginheight: 'marginHeight',\n max: 'max',\n maxlength: 'maxLength',\n media: 'media',\n mediagroup: 'mediaGroup',\n method: 'method',\n min: 'min',\n minlength: 'minLength',\n multiple: 'multiple',\n muted: 'muted',\n name: 'name',\n nomodule: 'noModule',\n nonce: 'nonce',\n novalidate: 'noValidate',\n open: 'open',\n optimum: 'optimum',\n pattern: 'pattern',\n placeholder: 'placeholder',\n playsinline: 'playsInline',\n poster: 'poster',\n preload: 'preload',\n profile: 'profile',\n radiogroup: 'radioGroup',\n readonly: 'readOnly',\n referrerpolicy: 'referrerPolicy',\n rel: 'rel',\n required: 'required',\n reversed: 'reversed',\n role: 'role',\n rows: 'rows',\n rowspan: 'rowSpan',\n sandbox: 'sandbox',\n scope: 'scope',\n scoped: 'scoped',\n scrolling: 'scrolling',\n seamless: 'seamless',\n selected: 'selected',\n shape: 'shape',\n size: 'size',\n sizes: 'sizes',\n span: 'span',\n spellcheck: 'spellCheck',\n src: 'src',\n srcdoc: 'srcDoc',\n srclang: 'srcLang',\n srcset: 'srcSet',\n start: 'start',\n step: 'step',\n style: 'style',\n summary: 'summary',\n tabindex: 'tabIndex',\n target: 'target',\n title: 'title',\n type: 'type',\n usemap: 'useMap',\n value: 'value',\n width: 'width',\n wmode: 'wmode',\n wrap: 'wrap',\n // SVG\n about: 'about',\n accentheight: 'accentHeight',\n 'accent-height': 'accentHeight',\n accumulate: 'accumulate',\n additive: 'additive',\n alignmentbaseline: 'alignmentBaseline',\n 'alignment-baseline': 'alignmentBaseline',\n allowreorder: 'allowReorder',\n alphabetic: 'alphabetic',\n amplitude: 'amplitude',\n arabicform: 'arabicForm',\n 'arabic-form': 'arabicForm',\n ascent: 'ascent',\n attributename: 'attributeName',\n attributetype: 'attributeType',\n autoreverse: 'autoReverse',\n azimuth: 'azimuth',\n basefrequency: 'baseFrequency',\n baselineshift: 'baselineShift',\n 'baseline-shift': 'baselineShift',\n baseprofile: 'baseProfile',\n bbox: 'bbox',\n begin: 'begin',\n bias: 'bias',\n by: 'by',\n calcmode: 'calcMode',\n capheight: 'capHeight',\n 'cap-height': 'capHeight',\n clip: 'clip',\n clippath: 'clipPath',\n 'clip-path': 'clipPath',\n clippathunits: 'clipPathUnits',\n cliprule: 'clipRule',\n 'clip-rule': 'clipRule',\n color: 'color',\n colorinterpolation: 'colorInterpolation',\n 'color-interpolation': 'colorInterpolation',\n colorinterpolationfilters: 'colorInterpolationFilters',\n 'color-interpolation-filters': 'colorInterpolationFilters',\n colorprofile: 'colorProfile',\n 'color-profile': 'colorProfile',\n colorrendering: 'colorRendering',\n 'color-rendering': 'colorRendering',\n contentscripttype: 'contentScriptType',\n contentstyletype: 'contentStyleType',\n cursor: 'cursor',\n cx: 'cx',\n cy: 'cy',\n d: 'd',\n datatype: 'datatype',\n decelerate: 'decelerate',\n descent: 'descent',\n diffuseconstant: 'diffuseConstant',\n direction: 'direction',\n display: 'display',\n divisor: 'divisor',\n dominantbaseline: 'dominantBaseline',\n 'dominant-baseline': 'dominantBaseline',\n dur: 'dur',\n dx: 'dx',\n dy: 'dy',\n edgemode: 'edgeMode',\n elevation: 'elevation',\n enablebackground: 'enableBackground',\n 'enable-background': 'enableBackground',\n end: 'end',\n exponent: 'exponent',\n externalresourcesrequired: 'externalResourcesRequired',\n fill: 'fill',\n fillopacity: 'fillOpacity',\n 'fill-opacity': 'fillOpacity',\n fillrule: 'fillRule',\n 'fill-rule': 'fillRule',\n filter: 'filter',\n filterres: 'filterRes',\n filterunits: 'filterUnits',\n floodopacity: 'floodOpacity',\n 'flood-opacity': 'floodOpacity',\n floodcolor: 'floodColor',\n 'flood-color': 'floodColor',\n focusable: 'focusable',\n fontfamily: 'fontFamily',\n 'font-family': 'fontFamily',\n fontsize: 'fontSize',\n 'font-size': 'fontSize',\n fontsizeadjust: 'fontSizeAdjust',\n 'font-size-adjust': 'fontSizeAdjust',\n fontstretch: 'fontStretch',\n 'font-stretch': 'fontStretch',\n fontstyle: 'fontStyle',\n 'font-style': 'fontStyle',\n fontvariant: 'fontVariant',\n 'font-variant': 'fontVariant',\n fontweight: 'fontWeight',\n 'font-weight': 'fontWeight',\n format: 'format',\n from: 'from',\n fx: 'fx',\n fy: 'fy',\n g1: 'g1',\n g2: 'g2',\n glyphname: 'glyphName',\n 'glyph-name': 'glyphName',\n glyphorientationhorizontal: 'glyphOrientationHorizontal',\n 'glyph-orientation-horizontal': 'glyphOrientationHorizontal',\n glyphorientationvertical: 'glyphOrientationVertical',\n 'glyph-orientation-vertical': 'glyphOrientationVertical',\n glyphref: 'glyphRef',\n gradienttransform: 'gradientTransform',\n gradientunits: 'gradientUnits',\n hanging: 'hanging',\n horizadvx: 'horizAdvX',\n 'horiz-adv-x': 'horizAdvX',\n horizoriginx: 'horizOriginX',\n 'horiz-origin-x': 'horizOriginX',\n ideographic: 'ideographic',\n imagerendering: 'imageRendering',\n 'image-rendering': 'imageRendering',\n in2: 'in2',\n in: 'in',\n inlist: 'inlist',\n intercept: 'intercept',\n k1: 'k1',\n k2: 'k2',\n k3: 'k3',\n k4: 'k4',\n k: 'k',\n kernelmatrix: 'kernelMatrix',\n kernelunitlength: 'kernelUnitLength',\n kerning: 'kerning',\n keypoints: 'keyPoints',\n keysplines: 'keySplines',\n keytimes: 'keyTimes',\n lengthadjust: 'lengthAdjust',\n letterspacing: 'letterSpacing',\n 'letter-spacing': 'letterSpacing',\n lightingcolor: 'lightingColor',\n 'lighting-color': 'lightingColor',\n limitingconeangle: 'limitingConeAngle',\n local: 'local',\n markerend: 'markerEnd',\n 'marker-end': 'markerEnd',\n markerheight: 'markerHeight',\n markermid: 'markerMid',\n 'marker-mid': 'markerMid',\n markerstart: 'markerStart',\n 'marker-start': 'markerStart',\n markerunits: 'markerUnits',\n markerwidth: 'markerWidth',\n mask: 'mask',\n maskcontentunits: 'maskContentUnits',\n maskunits: 'maskUnits',\n mathematical: 'mathematical',\n mode: 'mode',\n numoctaves: 'numOctaves',\n offset: 'offset',\n opacity: 'opacity',\n operator: 'operator',\n order: 'order',\n orient: 'orient',\n orientation: 'orientation',\n origin: 'origin',\n overflow: 'overflow',\n overlineposition: 'overlinePosition',\n 'overline-position': 'overlinePosition',\n overlinethickness: 'overlineThickness',\n 'overline-thickness': 'overlineThickness',\n paintorder: 'paintOrder',\n 'paint-order': 'paintOrder',\n panose1: 'panose1',\n 'panose-1': 'panose1',\n pathlength: 'pathLength',\n patterncontentunits: 'patternContentUnits',\n patterntransform: 'patternTransform',\n patternunits: 'patternUnits',\n pointerevents: 'pointerEvents',\n 'pointer-events': 'pointerEvents',\n points: 'points',\n pointsatx: 'pointsAtX',\n pointsaty: 'pointsAtY',\n pointsatz: 'pointsAtZ',\n prefix: 'prefix',\n preservealpha: 'preserveAlpha',\n preserveaspectratio: 'preserveAspectRatio',\n primitiveunits: 'primitiveUnits',\n property: 'property',\n r: 'r',\n radius: 'radius',\n refx: 'refX',\n refy: 'refY',\n renderingintent: 'renderingIntent',\n 'rendering-intent': 'renderingIntent',\n repeatcount: 'repeatCount',\n repeatdur: 'repeatDur',\n requiredextensions: 'requiredExtensions',\n requiredfeatures: 'requiredFeatures',\n resource: 'resource',\n restart: 'restart',\n result: 'result',\n results: 'results',\n rotate: 'rotate',\n rx: 'rx',\n ry: 'ry',\n scale: 'scale',\n security: 'security',\n seed: 'seed',\n shaperendering: 'shapeRendering',\n 'shape-rendering': 'shapeRendering',\n slope: 'slope',\n spacing: 'spacing',\n specularconstant: 'specularConstant',\n specularexponent: 'specularExponent',\n speed: 'speed',\n spreadmethod: 'spreadMethod',\n startoffset: 'startOffset',\n stddeviation: 'stdDeviation',\n stemh: 'stemh',\n stemv: 'stemv',\n stitchtiles: 'stitchTiles',\n stopcolor: 'stopColor',\n 'stop-color': 'stopColor',\n stopopacity: 'stopOpacity',\n 'stop-opacity': 'stopOpacity',\n strikethroughposition: 'strikethroughPosition',\n 'strikethrough-position': 'strikethroughPosition',\n strikethroughthickness: 'strikethroughThickness',\n 'strikethrough-thickness': 'strikethroughThickness',\n string: 'string',\n stroke: 'stroke',\n strokedasharray: 'strokeDasharray',\n 'stroke-dasharray': 'strokeDasharray',\n strokedashoffset: 'strokeDashoffset',\n 'stroke-dashoffset': 'strokeDashoffset',\n strokelinecap: 'strokeLinecap',\n 'stroke-linecap': 'strokeLinecap',\n strokelinejoin: 'strokeLinejoin',\n 'stroke-linejoin': 'strokeLinejoin',\n strokemiterlimit: 'strokeMiterlimit',\n 'stroke-miterlimit': 'strokeMiterlimit',\n strokewidth: 'strokeWidth',\n 'stroke-width': 'strokeWidth',\n strokeopacity: 'strokeOpacity',\n 'stroke-opacity': 'strokeOpacity',\n suppresscontenteditablewarning: 'suppressContentEditableWarning',\n suppresshydrationwarning: 'suppressHydrationWarning',\n surfacescale: 'surfaceScale',\n systemlanguage: 'systemLanguage',\n tablevalues: 'tableValues',\n targetx: 'targetX',\n targety: 'targetY',\n textanchor: 'textAnchor',\n 'text-anchor': 'textAnchor',\n textdecoration: 'textDecoration',\n 'text-decoration': 'textDecoration',\n textlength: 'textLength',\n textrendering: 'textRendering',\n 'text-rendering': 'textRendering',\n to: 'to',\n transform: 'transform',\n typeof: 'typeof',\n u1: 'u1',\n u2: 'u2',\n underlineposition: 'underlinePosition',\n 'underline-position': 'underlinePosition',\n underlinethickness: 'underlineThickness',\n 'underline-thickness': 'underlineThickness',\n unicode: 'unicode',\n unicodebidi: 'unicodeBidi',\n 'unicode-bidi': 'unicodeBidi',\n unicoderange: 'unicodeRange',\n 'unicode-range': 'unicodeRange',\n unitsperem: 'unitsPerEm',\n 'units-per-em': 'unitsPerEm',\n unselectable: 'unselectable',\n valphabetic: 'vAlphabetic',\n 'v-alphabetic': 'vAlphabetic',\n values: 'values',\n vectoreffect: 'vectorEffect',\n 'vector-effect': 'vectorEffect',\n version: 'version',\n vertadvy: 'vertAdvY',\n 'vert-adv-y': 'vertAdvY',\n vertoriginx: 'vertOriginX',\n 'vert-origin-x': 'vertOriginX',\n vertoriginy: 'vertOriginY',\n 'vert-origin-y': 'vertOriginY',\n vhanging: 'vHanging',\n 'v-hanging': 'vHanging',\n videographic: 'vIdeographic',\n 'v-ideographic': 'vIdeographic',\n viewbox: 'viewBox',\n viewtarget: 'viewTarget',\n visibility: 'visibility',\n vmathematical: 'vMathematical',\n 'v-mathematical': 'vMathematical',\n vocab: 'vocab',\n widths: 'widths',\n wordspacing: 'wordSpacing',\n 'word-spacing': 'wordSpacing',\n writingmode: 'writingMode',\n 'writing-mode': 'writingMode',\n x1: 'x1',\n x2: 'x2',\n x: 'x',\n xchannelselector: 'xChannelSelector',\n xheight: 'xHeight',\n 'x-height': 'xHeight',\n xlinkactuate: 'xlinkActuate',\n 'xlink:actuate': 'xlinkActuate',\n xlinkarcrole: 'xlinkArcrole',\n 'xlink:arcrole': 'xlinkArcrole',\n xlinkhref: 'xlinkHref',\n 'xlink:href': 'xlinkHref',\n xlinkrole: 'xlinkRole',\n 'xlink:role': 'xlinkRole',\n xlinkshow: 'xlinkShow',\n 'xlink:show': 'xlinkShow',\n xlinktitle: 'xlinkTitle',\n 'xlink:title': 'xlinkTitle',\n xlinktype: 'xlinkType',\n 'xlink:type': 'xlinkType',\n xmlbase: 'xmlBase',\n 'xml:base': 'xmlBase',\n xmllang: 'xmlLang',\n 'xml:lang': 'xmlLang',\n xmlns: 'xmlns',\n 'xml:space': 'xmlSpace',\n xmlnsxlink: 'xmlnsXlink',\n 'xmlns:xlink': 'xmlnsXlink',\n xmlspace: 'xmlSpace',\n y1: 'y1',\n y2: 'y2',\n y: 'y',\n ychannelselector: 'yChannelSelector',\n z: 'z',\n zoomandpan: 'zoomAndPan'\n };\n var ariaProperties = {\n 'aria-current': 0,\n // state\n 'aria-details': 0,\n 'aria-disabled': 0,\n // state\n 'aria-hidden': 0,\n // state\n 'aria-invalid': 0,\n // state\n 'aria-keyshortcuts': 0,\n 'aria-label': 0,\n 'aria-roledescription': 0,\n // Widget Attributes\n 'aria-autocomplete': 0,\n 'aria-checked': 0,\n 'aria-expanded': 0,\n 'aria-haspopup': 0,\n 'aria-level': 0,\n 'aria-modal': 0,\n 'aria-multiline': 0,\n 'aria-multiselectable': 0,\n 'aria-orientation': 0,\n 'aria-placeholder': 0,\n 'aria-pressed': 0,\n 'aria-readonly': 0,\n 'aria-required': 0,\n 'aria-selected': 0,\n 'aria-sort': 0,\n 'aria-valuemax': 0,\n 'aria-valuemin': 0,\n 'aria-valuenow': 0,\n 'aria-valuetext': 0,\n // Live Region Attributes\n 'aria-atomic': 0,\n 'aria-busy': 0,\n 'aria-live': 0,\n 'aria-relevant': 0,\n // Drag-and-Drop Attributes\n 'aria-dropeffect': 0,\n 'aria-grabbed': 0,\n // Relationship Attributes\n 'aria-activedescendant': 0,\n 'aria-colcount': 0,\n 'aria-colindex': 0,\n 'aria-colspan': 0,\n 'aria-controls': 0,\n 'aria-describedby': 0,\n 'aria-errormessage': 0,\n 'aria-flowto': 0,\n 'aria-labelledby': 0,\n 'aria-owns': 0,\n 'aria-posinset': 0,\n 'aria-rowcount': 0,\n 'aria-rowindex': 0,\n 'aria-rowspan': 0,\n 'aria-setsize': 0\n };\n var warnedProperties = {\n };\n var rARIA = new RegExp('^(aria)-[' + ATTRIBUTE_NAME_CHAR + ']*$');\n var rARIACamel = new RegExp('^(aria)[A-Z][' + ATTRIBUTE_NAME_CHAR + ']*$');\n var hasOwnProperty$1 = Object.prototype.hasOwnProperty;\n function validateProperty(tagName, name) {\n if (hasOwnProperty$1.call(warnedProperties, name) && warnedProperties[name]) return true;\n if (rARIACamel.test(name)) {\n var ariaName = 'aria-' + name.slice(4).toLowerCase();\n var correctName = ariaProperties.hasOwnProperty(ariaName) ? ariaName : null; // If this is an aria-* attribute, but is not listed in the known DOM\n // DOM properties, then it is an invalid aria-* attribute.\n if (correctName == null) {\n error1('Invalid ARIA attribute `%s`. ARIA attributes follow the pattern aria-* and must be lowercase.', name);\n warnedProperties[name] = true;\n return true;\n } // aria-* attributes should be lowercase; suggest the lowercase version.\n if (name !== correctName) {\n error1('Invalid ARIA attribute `%s`. Did you mean `%s`?', name, correctName);\n warnedProperties[name] = true;\n return true;\n }\n }\n if (rARIA.test(name)) {\n var lowerCasedName = name.toLowerCase();\n var standardName = ariaProperties.hasOwnProperty(lowerCasedName) ? lowerCasedName : null; // If this is an aria-* attribute, but is not listed in the known DOM\n // DOM properties, then it is an invalid aria-* attribute.\n if (standardName == null) {\n warnedProperties[name] = true;\n return false;\n } // aria-* attributes should be lowercase; suggest the lowercase version.\n if (name !== standardName) {\n error1('Unknown ARIA attribute `%s`. Did you mean `%s`?', name, standardName);\n warnedProperties[name] = true;\n return true;\n }\n }\n return true;\n }\n function warnInvalidARIAProps(type, props) {\n var invalidProps = [];\n for(var key in props){\n var isValid = validateProperty(type, key);\n if (!isValid) invalidProps.push(key);\n }\n var unknownPropString = invalidProps.map(function(prop) {\n return '`' + prop + '`';\n }).join(', ');\n if (invalidProps.length === 1) error1(\"Invalid aria prop %s on <%s> tag. For details, see https://reactjs.org/link/invalid-aria-props\", unknownPropString, type);\n else if (invalidProps.length > 1) error1(\"Invalid aria props %s on <%s> tag. For details, see https://reactjs.org/link/invalid-aria-props\", unknownPropString, type);\n }\n function validateProperties(type, props) {\n if (isCustomComponent(type, props)) return;\n warnInvalidARIAProps(type, props);\n }\n var didWarnValueNull = false;\n function validateProperties$1(type, props) {\n if (type !== 'input' && type !== 'textarea' && type !== 'select') return;\n if (props != null && props.value === null && !didWarnValueNull) {\n didWarnValueNull = true;\n if (type === 'select' && props.multiple) error1(\"`value` prop on `%s` should not be null. Consider using an empty array when `multiple` is set to `true` to clear the component or `undefined` for uncontrolled components.\", type);\n else error1(\"`value` prop on `%s` should not be null. Consider using an empty string to clear the component or `undefined` for uncontrolled components.\", type);\n }\n }\n var validateProperty$1 = function() {\n };\n var warnedProperties$1 = {\n };\n var _hasOwnProperty = Object.prototype.hasOwnProperty;\n var EVENT_NAME_REGEX = /^on./;\n var INVALID_EVENT_NAME_REGEX = /^on[^A-Z]/;\n var rARIA$1 = new RegExp('^(aria)-[' + ATTRIBUTE_NAME_CHAR + ']*$');\n var rARIACamel$1 = new RegExp('^(aria)[A-Z][' + ATTRIBUTE_NAME_CHAR + ']*$');\n validateProperty$1 = function(tagName, name, value, eventRegistry) {\n if (_hasOwnProperty.call(warnedProperties$1, name) && warnedProperties$1[name]) return true;\n var lowerCasedName = name.toLowerCase();\n if (lowerCasedName === 'onfocusin' || lowerCasedName === 'onfocusout') {\n error1(\"React uses onFocus and onBlur instead of onFocusIn and onFocusOut. All React events are normalized to bubble, so onFocusIn and onFocusOut are not needed/supported by React.\");\n warnedProperties$1[name] = true;\n return true;\n } // We can't rely on the event system being injected on the server.\n if (eventRegistry != null) {\n var registrationNameDependencies = eventRegistry.registrationNameDependencies, possibleRegistrationNames = eventRegistry.possibleRegistrationNames;\n if (registrationNameDependencies.hasOwnProperty(name)) return true;\n var registrationName = possibleRegistrationNames.hasOwnProperty(lowerCasedName) ? possibleRegistrationNames[lowerCasedName] : null;\n if (registrationName != null) {\n error1('Invalid event handler property `%s`. Did you mean `%s`?', name, registrationName);\n warnedProperties$1[name] = true;\n return true;\n }\n if (EVENT_NAME_REGEX.test(name)) {\n error1('Unknown event handler property `%s`. It will be ignored.', name);\n warnedProperties$1[name] = true;\n return true;\n }\n } else if (EVENT_NAME_REGEX.test(name)) {\n // If no event plugins have been injected, we are in a server environment.\n // So we can't tell if the event name is correct for sure, but we can filter\n // out known bad ones like `onclick`. We can't suggest a specific replacement though.\n if (INVALID_EVENT_NAME_REGEX.test(name)) error1(\"Invalid event handler property `%s`. React events use the camelCase naming convention, for example `onClick`.\", name);\n warnedProperties$1[name] = true;\n return true;\n } // Let the ARIA attribute hook validate ARIA attributes\n if (rARIA$1.test(name) || rARIACamel$1.test(name)) return true;\n if (lowerCasedName === 'innerhtml') {\n error1(\"Directly setting property `innerHTML` is not permitted. For more information, lookup documentation on `dangerouslySetInnerHTML`.\");\n warnedProperties$1[name] = true;\n return true;\n }\n if (lowerCasedName === 'aria') {\n error1(\"The `aria` attribute is reserved for future use in React. Pass individual `aria-` attributes instead.\");\n warnedProperties$1[name] = true;\n return true;\n }\n if (lowerCasedName === 'is' && value !== null && value !== undefined && typeof value !== 'string') {\n error1(\"Received a `%s` for a string attribute `is`. If this is expected, cast the value to a string.\", typeof value);\n warnedProperties$1[name] = true;\n return true;\n }\n if (typeof value === 'number' && isNaN(value)) {\n error1(\"Received NaN for the `%s` attribute. If this is expected, cast the value to a string.\", name);\n warnedProperties$1[name] = true;\n return true;\n }\n var propertyInfo = getPropertyInfo(name);\n var isReserved = propertyInfo !== null && propertyInfo.type === RESERVED; // Known attributes should match the casing specified in the property config.\n if (possibleStandardNames.hasOwnProperty(lowerCasedName)) {\n var standardName = possibleStandardNames[lowerCasedName];\n if (standardName !== name) {\n error1('Invalid DOM property `%s`. Did you mean `%s`?', name, standardName);\n warnedProperties$1[name] = true;\n return true;\n }\n } else if (!isReserved && name !== lowerCasedName) {\n // Unknown attributes should have lowercase casing since that's how they\n // will be cased anyway with server rendering.\n error1(\"React does not recognize the `%s` prop on a DOM element. If you intentionally want it to appear in the DOM as a custom attribute, spell it as lowercase `%s` instead. If you accidentally passed it from a parent component, remove it from the DOM element.\", name, lowerCasedName);\n warnedProperties$1[name] = true;\n return true;\n }\n if (typeof value === 'boolean' && shouldRemoveAttributeWithWarning(name, value, propertyInfo, false)) {\n if (value) error1(\"Received `%s` for a non-boolean attribute `%s`.\\n\\nIf you want to write it to the DOM, pass a string instead: %s=\\\"%s\\\" or %s={value.toString()}.\", value, name, name, value, name);\n else error1(\"Received `%s` for a non-boolean attribute `%s`.\\n\\nIf you want to write it to the DOM, pass a string instead: %s=\\\"%s\\\" or %s={value.toString()}.\\n\\nIf you used to conditionally omit it with %s={condition && value}, pass %s={condition ? value : undefined} instead.\", value, name, name, value, name, name, name);\n warnedProperties$1[name] = true;\n return true;\n } // Now that we've validated casing, do not validate\n // data types for reserved props\n if (isReserved) return true;\n // Warn when a known attribute is a bad type\n if (shouldRemoveAttributeWithWarning(name, value, propertyInfo, false)) {\n warnedProperties$1[name] = true;\n return false;\n } // Warn when passing the strings 'false' or 'true' into a boolean prop\n if ((value === 'false' || value === 'true') && propertyInfo !== null && propertyInfo.type === BOOLEAN) {\n error1(\"Received the string `%s` for the boolean attribute `%s`. %s Did you mean %s={%s}?\", value, name, value === 'false' ? 'The browser will interpret it as a truthy value.' : 'Although this works, it will not work as expected if you pass the string \"false\".', name, value);\n warnedProperties$1[name] = true;\n return true;\n }\n return true;\n };\n var warnUnknownProperties = function(type, props, eventRegistry) {\n var unknownProps = [];\n for(var key in props){\n var isValid = validateProperty$1(type, key, props[key], eventRegistry);\n if (!isValid) unknownProps.push(key);\n }\n var unknownPropString = unknownProps.map(function(prop) {\n return '`' + prop + '`';\n }).join(', ');\n if (unknownProps.length === 1) error1(\"Invalid value for prop %s on <%s> tag. Either remove it from the element, or pass a string or number value to keep it in the DOM. For details, see https://reactjs.org/link/attribute-behavior \", unknownPropString, type);\n else if (unknownProps.length > 1) error1(\"Invalid values for props %s on <%s> tag. Either remove them from the element, or pass a string or number value to keep them in the DOM. For details, see https://reactjs.org/link/attribute-behavior \", unknownPropString, type);\n };\n function validateProperties$2(type, props, eventRegistry) {\n if (isCustomComponent(type, props)) return;\n warnUnknownProperties(type, props, eventRegistry);\n }\n var IS_EVENT_HANDLE_NON_MANAGED_NODE = 1;\n var IS_NON_DELEGATED = 2;\n var IS_CAPTURE_PHASE = 4;\n var IS_REPLAYED = 16;\n // set to LEGACY_FB_SUPPORT. LEGACY_FB_SUPPORT only gets set when\n // we call willDeferLaterForLegacyFBSupport, thus not bailing out\n // will result in endless cycles like an infinite loop.\n // We also don't want to defer during event replaying.\n var SHOULD_NOT_PROCESS_POLYFILL_EVENT_PLUGINS = IS_EVENT_HANDLE_NON_MANAGED_NODE | IS_NON_DELEGATED | IS_CAPTURE_PHASE;\n /**\n * Gets the target node from a native browser event by accounting for\n * inconsistencies in browser DOM APIs.\n *\n * @param {object} nativeEvent Native browser event.\n * @return {DOMEventTarget} Target node.\n */ function getEventTarget(nativeEvent) {\n // Fallback to nativeEvent.srcElement for IE9\n // https://github.com/facebook/react/issues/12506\n var target = nativeEvent.target || nativeEvent.srcElement || window; // Normalize SVG <use> element events #4963\n if (target.correspondingUseElement) target = target.correspondingUseElement;\n // Safari may fire events on text nodes (Node.TEXT_NODE is 3).\n // @see http://www.quirksmode.org/js/events_properties.html\n return target.nodeType === TEXT_NODE ? target.parentNode : target;\n }\n var restoreImpl = null;\n var restoreTarget = null;\n var restoreQueue = null;\n function restoreStateOfTarget(target) {\n // We perform this translation at the end of the event loop so that we\n // always receive the correct fiber here\n var internalInstance = getInstanceFromNode(target);\n if (!internalInstance) // Unmounted\n return;\n if (!(typeof restoreImpl === 'function')) throw Error(\"setRestoreImplementation() needs to be called to handle a target for controlled events. This error is likely caused by a bug in React. Please file an issue.\");\n var stateNode = internalInstance.stateNode; // Guard against Fiber being unmounted.\n if (stateNode) {\n var _props = getFiberCurrentPropsFromNode(stateNode);\n restoreImpl(internalInstance.stateNode, internalInstance.type, _props);\n }\n }\n function setRestoreImplementation(impl) {\n restoreImpl = impl;\n }\n function enqueueStateRestore(target) {\n if (restoreTarget) {\n if (restoreQueue) restoreQueue.push(target);\n else restoreQueue = [\n target\n ];\n } else restoreTarget = target;\n }\n function needsStateRestore() {\n return restoreTarget !== null || restoreQueue !== null;\n }\n function restoreStateIfNeeded() {\n if (!restoreTarget) return;\n var target = restoreTarget;\n var queuedTargets = restoreQueue;\n restoreTarget = null;\n restoreQueue = null;\n restoreStateOfTarget(target);\n if (queuedTargets) for(var i = 0; i < queuedTargets.length; i++)restoreStateOfTarget(queuedTargets[i]);\n }\n // the renderer. Such as when we're dispatching events or if third party\n // libraries need to call batchedUpdates. Eventually, this API will go away when\n // everything is batched by default. We'll then have a similar API to opt-out of\n // scheduled work and instead do synchronous work.\n // Defaults\n var batchedUpdatesImpl = function(fn, bookkeeping) {\n return fn(bookkeeping);\n };\n var discreteUpdatesImpl = function(fn, a, b, c, d) {\n return fn(a, b, c, d);\n };\n var flushDiscreteUpdatesImpl = function() {\n };\n var batchedEventUpdatesImpl = batchedUpdatesImpl;\n var isInsideEventHandler = false;\n var isBatchingEventUpdates = false;\n function finishEventHandler() {\n // Here we wait until all updates have propagated, which is important\n // when using controlled components within layers:\n // https://github.com/facebook/react/issues/1698\n // Then we restore state of any controlled component.\n var controlledComponentsHavePendingUpdates = needsStateRestore();\n if (controlledComponentsHavePendingUpdates) {\n // If a controlled event was fired, we may need to restore the state of\n // the DOM node back to the controlled value. This is necessary when React\n // bails out of the update without touching the DOM.\n flushDiscreteUpdatesImpl();\n restoreStateIfNeeded();\n }\n }\n function batchedUpdates(fn, bookkeeping) {\n if (isInsideEventHandler) // If we are currently inside another batch, we need to wait until it\n // fully completes before restoring state.\n return fn(bookkeeping);\n isInsideEventHandler = true;\n try {\n return batchedUpdatesImpl(fn, bookkeeping);\n } finally{\n isInsideEventHandler = false;\n finishEventHandler();\n }\n }\n function batchedEventUpdates(fn, a, b) {\n if (isBatchingEventUpdates) // If we are currently inside another batch, we need to wait until it\n // fully completes before restoring state.\n return fn(a, b);\n isBatchingEventUpdates = true;\n try {\n return batchedEventUpdatesImpl(fn, a, b);\n } finally{\n isBatchingEventUpdates = false;\n finishEventHandler();\n }\n }\n function discreteUpdates(fn, a, b, c, d) {\n var prevIsInsideEventHandler = isInsideEventHandler;\n isInsideEventHandler = true;\n try {\n return discreteUpdatesImpl(fn, a, b, c, d);\n } finally{\n isInsideEventHandler = prevIsInsideEventHandler;\n if (!isInsideEventHandler) finishEventHandler();\n }\n }\n function flushDiscreteUpdatesIfNeeded(timeStamp) {\n if (!isInsideEventHandler) flushDiscreteUpdatesImpl();\n }\n function setBatchingImplementation(_batchedUpdatesImpl, _discreteUpdatesImpl, _flushDiscreteUpdatesImpl, _batchedEventUpdatesImpl) {\n batchedUpdatesImpl = _batchedUpdatesImpl;\n discreteUpdatesImpl = _discreteUpdatesImpl;\n flushDiscreteUpdatesImpl = _flushDiscreteUpdatesImpl;\n batchedEventUpdatesImpl = _batchedEventUpdatesImpl;\n }\n function isInteractive(tag) {\n return tag === 'button' || tag === 'input' || tag === 'select' || tag === 'textarea';\n }\n function shouldPreventMouseEvent(name, type, props) {\n switch(name){\n case 'onClick':\n case 'onClickCapture':\n case 'onDoubleClick':\n case 'onDoubleClickCapture':\n case 'onMouseDown':\n case 'onMouseDownCapture':\n case 'onMouseMove':\n case 'onMouseMoveCapture':\n case 'onMouseUp':\n case 'onMouseUpCapture':\n case 'onMouseEnter':\n return !!(props.disabled && isInteractive(type));\n default:\n return false;\n }\n }\n /**\n * @param {object} inst The instance, which is the source of events.\n * @param {string} registrationName Name of listener (e.g. `onClick`).\n * @return {?function} The stored callback.\n */ function getListener(inst, registrationName) {\n var stateNode = inst.stateNode;\n if (stateNode === null) // Work in progress (ex: onload events in incremental mode).\n return null;\n var props = getFiberCurrentPropsFromNode(stateNode);\n if (props === null) // Work in progress.\n return null;\n var listener = props[registrationName];\n if (shouldPreventMouseEvent(registrationName, inst.type, props)) return null;\n if (!(!listener || typeof listener === 'function')) throw Error(\"Expected `\" + registrationName + \"` listener to be a function, instead got a value of `\" + typeof listener + \"` type.\");\n return listener;\n }\n var passiveBrowserEventsSupported = false; // Check if browser support events with passive listeners\n // https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener#Safely_detecting_option_support\n if (canUseDOM) try {\n var options1 = {\n }; // $FlowFixMe: Ignore Flow complaining about needing a value\n Object.defineProperty(options1, 'passive', {\n get: function() {\n passiveBrowserEventsSupported = true;\n }\n });\n window.addEventListener('test', options1, options1);\n window.removeEventListener('test', options1, options1);\n } catch (e1) {\n passiveBrowserEventsSupported = false;\n }\n function invokeGuardedCallbackProd(name, func, context, a, b, c, d, e, f) {\n var funcArgs = Array.prototype.slice.call(arguments, 3);\n try {\n func.apply(context, funcArgs);\n } catch (error) {\n this.onError(error);\n }\n }\n var invokeGuardedCallbackImpl = invokeGuardedCallbackProd;\n // In DEV mode, we swap out invokeGuardedCallback for a special version\n // that plays more nicely with the browser's DevTools. The idea is to preserve\n // \"Pause on exceptions\" behavior. Because React wraps all user-provided\n // functions in invokeGuardedCallback, and the production version of\n // invokeGuardedCallback uses a try-catch, all user exceptions are treated\n // like caught exceptions, and the DevTools won't pause unless the developer\n // takes the extra step of enabling pause on caught exceptions. This is\n // unintuitive, though, because even though React has caught the error, from\n // the developer's perspective, the error is uncaught.\n //\n // To preserve the expected \"Pause on exceptions\" behavior, we don't use a\n // try-catch in DEV. Instead, we synchronously dispatch a fake event to a fake\n // DOM node, and call the user-provided callback from inside an event handler\n // for that fake event. If the callback throws, the error is \"captured\" using\n // a global event handler. But because the error happens in a different\n // event loop context, it does not interrupt the normal program flow.\n // Effectively, this gives us try-catch behavior without actually using\n // try-catch. Neat!\n // Check that the browser supports the APIs we need to implement our special\n // DEV version of invokeGuardedCallback\n if (typeof window !== 'undefined' && typeof window.dispatchEvent === 'function' && typeof document !== 'undefined' && typeof document.createEvent === 'function') {\n var fakeNode = document.createElement('react');\n invokeGuardedCallbackImpl = function invokeGuardedCallbackDev(name, func, context, a, b, c, d, e, f) {\n // If document doesn't exist we know for sure we will crash in this method\n // when we call document.createEvent(). However this can cause confusing\n // errors: https://github.com/facebookincubator/create-react-app/issues/3482\n // So we preemptively throw with a better message instead.\n if (!(typeof document !== 'undefined')) throw Error(\"The `document` global was defined when React was initialized, but is not defined anymore. This can happen in a test environment if a component schedules an update from an asynchronous callback, but the test has already finished running. To solve this, you can either unmount the component at the end of your test (and ensure that any asynchronous operations get canceled in `componentWillUnmount`), or you can change the test itself to be asynchronous.\");\n var evt = document.createEvent('Event');\n var didCall = false; // Keeps track of whether the user-provided callback threw an error. We\n // set this to true at the beginning, then set it to false right after\n // calling the function. If the function errors, `didError` will never be\n // set to false. This strategy works even if the browser is flaky and\n // fails to call our global error handler, because it doesn't rely on\n // the error event at all.\n var didError = true; // Keeps track of the value of window.event so that we can reset it\n // during the callback to let user code access window.event in the\n // browsers that support it.\n var windowEvent = window.event; // Keeps track of the descriptor of window.event to restore it after event\n // dispatching: https://github.com/facebook/react/issues/13688\n var windowEventDescriptor = Object.getOwnPropertyDescriptor(window, 'event');\n function restoreAfterDispatch() {\n // We immediately remove the callback from event listeners so that\n // nested `invokeGuardedCallback` calls do not clash. Otherwise, a\n // nested call would trigger the fake event handlers of any call higher\n // in the stack.\n fakeNode.removeEventListener(evtType, callCallback, false); // We check for window.hasOwnProperty('event') to prevent the\n // window.event assignment in both IE <= 10 as they throw an error\n // \"Member not found\" in strict mode, and in Firefox which does not\n // support window.event.\n if (typeof window.event !== 'undefined' && window.hasOwnProperty('event')) window.event = windowEvent;\n } // Create an event handler for our fake event. We will synchronously\n // dispatch our fake event using `dispatchEvent`. Inside the handler, we\n // call the user-provided callback.\n var funcArgs = Array.prototype.slice.call(arguments, 3);\n function callCallback() {\n didCall = true;\n restoreAfterDispatch();\n func.apply(context, funcArgs);\n didError = false;\n } // Create a global error event handler. We use this to capture the value\n // that was thrown. It's possible that this error handler will fire more\n // than once; for example, if non-React code also calls `dispatchEvent`\n // and a handler for that event throws. We should be resilient to most of\n // those cases. Even if our error event handler fires more than once, the\n // last error event is always used. If the callback actually does error,\n // we know that the last error event is the correct one, because it's not\n // possible for anything else to have happened in between our callback\n // erroring and the code that follows the `dispatchEvent` call below. If\n // the callback doesn't error, but the error event was fired, we know to\n // ignore it because `didError` will be false, as described above.\n var error; // Use this to track whether the error event is ever called.\n var didSetError = false;\n var isCrossOriginError = false;\n function handleWindowError(event) {\n error = event.error;\n didSetError = true;\n if (error === null && event.colno === 0 && event.lineno === 0) isCrossOriginError = true;\n if (event.defaultPrevented) {\n // Some other error handler has prevented default.\n // Browsers silence the error report if this happens.\n // We'll remember this to later decide whether to log it or not.\n if (error != null && typeof error === 'object') try {\n error._suppressLogging = true;\n } catch (inner) {\n }\n }\n } // Create a fake event type.\n var evtType = \"react-\" + (name ? name : 'invokeguardedcallback'); // Attach our event handlers\n window.addEventListener('error', handleWindowError);\n fakeNode.addEventListener(evtType, callCallback, false); // Synchronously dispatch our fake event. If the user-provided function\n // errors, it will trigger our global error handler.\n evt.initEvent(evtType, false, false);\n fakeNode.dispatchEvent(evt);\n if (windowEventDescriptor) Object.defineProperty(window, 'event', windowEventDescriptor);\n if (didCall && didError) {\n if (!didSetError) // The callback errored, but the error event never fired.\n error = new Error(\"An error was thrown inside one of your components, but React doesn't know what it was. This is likely due to browser flakiness. React does its best to preserve the \\\"Pause on exceptions\\\" behavior of the DevTools, which requires some DEV-mode only tricks. It's possible that these don't work in your browser. Try triggering the error in production mode, or switching to a modern browser. If you suspect that this is actually an issue with React, please file an issue.\");\n else if (isCrossOriginError) error = new Error(\"A cross-origin error was thrown. React doesn't have access to the actual error object in development. See https://reactjs.org/link/crossorigin-error for more information.\");\n this.onError(error);\n } // Remove our event listeners\n window.removeEventListener('error', handleWindowError);\n if (!didCall) {\n // Something went really wrong, and our event was not dispatched.\n // https://github.com/facebook/react/issues/16734\n // https://github.com/facebook/react/issues/16585\n // Fall back to the production implementation.\n restoreAfterDispatch();\n return invokeGuardedCallbackProd.apply(this, arguments);\n }\n };\n }\n var invokeGuardedCallbackImpl$1 = invokeGuardedCallbackImpl;\n var hasError = false;\n var caughtError = null; // Used by event system to capture/rethrow the first error.\n var hasRethrowError = false;\n var rethrowError = null;\n var reporter = {\n onError: function(error) {\n hasError = true;\n caughtError = error;\n }\n };\n /**\n * Call a function while guarding against errors that happens within it.\n * Returns an error if it throws, otherwise null.\n *\n * In production, this is implemented using a try-catch. The reason we don't\n * use a try-catch directly is so that we can swap out a different\n * implementation in DEV mode.\n *\n * @param {String} name of the guard to use for logging or debugging\n * @param {Function} func The function to invoke\n * @param {*} context The context to use when calling the function\n * @param {...*} args Arguments for function\n */ function invokeGuardedCallback(name, func, context, a, b, c, d, e, f) {\n hasError = false;\n caughtError = null;\n invokeGuardedCallbackImpl$1.apply(reporter, arguments);\n }\n /**\n * Same as invokeGuardedCallback, but instead of returning an error, it stores\n * it in a global so it can be rethrown by `rethrowCaughtError` later.\n * TODO: See if caughtError and rethrowError can be unified.\n *\n * @param {String} name of the guard to use for logging or debugging\n * @param {Function} func The function to invoke\n * @param {*} context The context to use when calling the function\n * @param {...*} args Arguments for function\n */ function invokeGuardedCallbackAndCatchFirstError(name, func, context, a, b, c, d, e, f) {\n invokeGuardedCallback.apply(this, arguments);\n if (hasError) {\n var error = clearCaughtError();\n if (!hasRethrowError) {\n hasRethrowError = true;\n rethrowError = error;\n }\n }\n }\n /**\n * During execution of guarded functions we will capture the first error which\n * we will rethrow to be handled by the top level error handler.\n */ function rethrowCaughtError() {\n if (hasRethrowError) {\n var error = rethrowError;\n hasRethrowError = false;\n rethrowError = null;\n throw error;\n }\n }\n function hasCaughtError() {\n return hasError;\n }\n function clearCaughtError() {\n if (hasError) {\n var error = caughtError;\n hasError = false;\n caughtError = null;\n return error;\n } else throw Error(\"clearCaughtError was called but no error was captured. This error is likely caused by a bug in React. Please file an issue.\");\n }\n /**\n * `ReactInstanceMap` maintains a mapping from a public facing stateful\n * instance (key) and the internal representation (value). This allows public\n * methods to accept the user facing instance as an argument and map them back\n * to internal methods.\n *\n * Note that this module is currently shared and assumed to be stateless.\n * If this becomes an actual Map, that will break.\n */ function get1(key) {\n return key._reactInternals;\n }\n function has1(key) {\n return key._reactInternals !== undefined;\n }\n function set1(key, value) {\n key._reactInternals = value;\n }\n // Don't change these two values. They're used by React Dev Tools.\n var NoFlags = /* */ 0;\n var PerformedWork = /* */ 1; // You can change the rest (and add more).\n var Placement = /* */ 2;\n var Update = /* */ 4;\n var PlacementAndUpdate = /* */ 6;\n var Deletion = /* */ 8;\n var ContentReset = /* */ 16;\n var Callback = /* */ 32;\n var DidCapture = /* */ 64;\n var Ref = /* */ 128;\n var Snapshot = /* */ 256;\n var Passive = /* */ 512; // TODO (effects) Remove this bit once the new reconciler is synced to the old.\n var PassiveUnmountPendingDev = /* */ 8192;\n var Hydrating = /* */ 1024;\n var HydratingAndUpdate = /* */ 1028; // Passive & Update & Callback & Ref & Snapshot\n var LifecycleEffectMask = /* */ 932; // Union of all host effects\n var HostEffectMask = /* */ 2047; // These are not really side effects, but we still reuse this field.\n var Incomplete = /* */ 2048;\n var ShouldCapture = /* */ 4096;\n var ForceUpdateForLegacySuspense = /* */ 16384; // Static tags describe aspects of a fiber that are not specific to a render,\n var ReactCurrentOwner = ReactSharedInternals.ReactCurrentOwner;\n function getNearestMountedFiber(fiber) {\n var node = fiber;\n var nearestMounted = fiber;\n if (!fiber.alternate) {\n // If there is no alternate, this might be a new tree that isn't inserted\n // yet. If it is, then it will have a pending insertion effect on it.\n var nextNode = node;\n do {\n node = nextNode;\n if ((node.flags & (Placement | Hydrating)) !== NoFlags) // This is an insertion or in-progress hydration. The nearest possible\n // mounted fiber is the parent but we need to continue to figure out\n // if that one is still mounted.\n nearestMounted = node.return;\n nextNode = node.return;\n }while (nextNode)\n } else while(node.return)node = node.return;\n if (node.tag === HostRoot) // TODO: Check if this was a nested HostRoot when used with\n // renderContainerIntoSubtree.\n return nearestMounted;\n // If we didn't hit the root, that means that we're in an disconnected tree\n // that has been unmounted.\n return null;\n }\n function getSuspenseInstanceFromFiber(fiber) {\n if (fiber.tag === SuspenseComponent) {\n var suspenseState = fiber.memoizedState;\n if (suspenseState === null) {\n var current = fiber.alternate;\n if (current !== null) suspenseState = current.memoizedState;\n }\n if (suspenseState !== null) return suspenseState.dehydrated;\n }\n return null;\n }\n function getContainerFromFiber(fiber) {\n return fiber.tag === HostRoot ? fiber.stateNode.containerInfo : null;\n }\n function isFiberMounted(fiber) {\n return getNearestMountedFiber(fiber) === fiber;\n }\n function isMounted(component) {\n var owner = ReactCurrentOwner.current;\n if (owner !== null && owner.tag === ClassComponent) {\n var ownerFiber = owner;\n var instance = ownerFiber.stateNode;\n if (!instance._warnedAboutRefsInRender) error1(\"%s is accessing isMounted inside its render() function. render() should be a pure function of props and state. It should never access something that requires stale data from the previous render, such as refs. Move this logic to componentDidMount and componentDidUpdate instead.\", getComponentName(ownerFiber.type) || 'A component');\n instance._warnedAboutRefsInRender = true;\n }\n var fiber = get1(component);\n if (!fiber) return false;\n return getNearestMountedFiber(fiber) === fiber;\n }\n function assertIsMounted(fiber) {\n if (!(getNearestMountedFiber(fiber) === fiber)) throw Error(\"Unable to find node on an unmounted component.\");\n }\n function findCurrentFiberUsingSlowPath(fiber) {\n var alternate = fiber.alternate;\n if (!alternate) {\n // If there is no alternate, then we only need to check if it is mounted.\n var nearestMounted = getNearestMountedFiber(fiber);\n if (!(nearestMounted !== null)) throw Error(\"Unable to find node on an unmounted component.\");\n if (nearestMounted !== fiber) return null;\n return fiber;\n } // If we have two possible branches, we'll walk backwards up to the root\n // to see what path the root points to. On the way we may hit one of the\n // special cases and we'll deal with them.\n var a = fiber;\n var b = alternate;\n while(true){\n var parentA = a.return;\n if (parentA === null) break;\n var parentB = parentA.alternate;\n if (parentB === null) {\n // There is no alternate. This is an unusual case. Currently, it only\n // happens when a Suspense component is hidden. An extra fragment fiber\n // is inserted in between the Suspense fiber and its children. Skip\n // over this extra fragment fiber and proceed to the next parent.\n var nextParent = parentA.return;\n if (nextParent !== null) {\n a = b = nextParent;\n continue;\n } // If there's no parent, we're at the root.\n break;\n } // If both copies of the parent fiber point to the same child, we can\n // assume that the child is current. This happens when we bailout on low\n // priority: the bailed out fiber's child reuses the current child.\n if (parentA.child === parentB.child) {\n var child = parentA.child;\n while(child){\n if (child === a) {\n // We've determined that A is the current branch.\n assertIsMounted(parentA);\n return fiber;\n }\n if (child === b) {\n // We've determined that B is the current branch.\n assertIsMounted(parentA);\n return alternate;\n }\n child = child.sibling;\n } // We should never have an alternate for any mounting node. So the only\n throw Error(\"Unable to find node on an unmounted component.\");\n }\n if (a.return !== b.return) {\n // The return pointer of A and the return pointer of B point to different\n // fibers. We assume that return pointers never criss-cross, so A must\n // belong to the child set of A.return, and B must belong to the child\n // set of B.return.\n a = parentA;\n b = parentB;\n } else {\n // The return pointers point to the same fiber. We'll have to use the\n // default, slow path: scan the child sets of each parent alternate to see\n // which child belongs to which set.\n //\n // Search parent A's child set\n var didFindChild = false;\n var _child = parentA.child;\n while(_child){\n if (_child === a) {\n didFindChild = true;\n a = parentA;\n b = parentB;\n break;\n }\n if (_child === b) {\n didFindChild = true;\n b = parentA;\n a = parentB;\n break;\n }\n _child = _child.sibling;\n }\n if (!didFindChild) {\n // Search parent B's child set\n _child = parentB.child;\n while(_child){\n if (_child === a) {\n didFindChild = true;\n a = parentB;\n b = parentA;\n break;\n }\n if (_child === b) {\n didFindChild = true;\n b = parentB;\n a = parentA;\n break;\n }\n _child = _child.sibling;\n }\n if (!didFindChild) throw Error(\"Child was not found in either parent set. This indicates a bug in React related to the return pointer. Please file an issue.\");\n }\n }\n if (!(a.alternate === b)) throw Error(\"Return fibers should always be each others' alternates. This error is likely caused by a bug in React. Please file an issue.\");\n } // If the root is not a host container, we're in a disconnected tree. I.e.\n // unmounted.\n if (!(a.tag === HostRoot)) throw Error(\"Unable to find node on an unmounted component.\");\n if (a.stateNode.current === a) // We've determined that A is the current branch.\n return fiber;\n // Otherwise B has to be current branch.\n return alternate;\n }\n function findCurrentHostFiber(parent) {\n var currentParent = findCurrentFiberUsingSlowPath(parent);\n if (!currentParent) return null;\n // Next we'll drill down this component to find the first HostComponent/Text.\n var node = currentParent;\n while(true){\n if (node.tag === HostComponent || node.tag === HostText) return node;\n else if (node.child) {\n node.child.return = node;\n node = node.child;\n continue;\n }\n if (node === currentParent) return null;\n while(!node.sibling){\n if (!node.return || node.return === currentParent) return null;\n node = node.return;\n }\n node.sibling.return = node.return;\n node = node.sibling;\n } // Flow needs the return null here, but ESLint complains about it.\n // eslint-disable-next-line no-unreachable\n return null;\n }\n function findCurrentHostFiberWithNoPortals(parent) {\n var currentParent = findCurrentFiberUsingSlowPath(parent);\n if (!currentParent) return null;\n // Next we'll drill down this component to find the first HostComponent/Text.\n var node = currentParent;\n while(true){\n if (node.tag === HostComponent || node.tag === HostText || enableFundamentalAPI) return node;\n else if (node.child && node.tag !== HostPortal) {\n node.child.return = node;\n node = node.child;\n continue;\n }\n if (node === currentParent) return null;\n while(!node.sibling){\n if (!node.return || node.return === currentParent) return null;\n node = node.return;\n }\n node.sibling.return = node.return;\n node = node.sibling;\n } // Flow needs the return null here, but ESLint complains about it.\n // eslint-disable-next-line no-unreachable\n return null;\n }\n function doesFiberContain(parentFiber, childFiber) {\n var node = childFiber;\n var parentFiberAlternate = parentFiber.alternate;\n while(node !== null){\n if (node === parentFiber || node === parentFiberAlternate) return true;\n node = node.return;\n }\n return false;\n }\n var attemptUserBlockingHydration;\n function setAttemptUserBlockingHydration(fn) {\n attemptUserBlockingHydration = fn;\n }\n var attemptContinuousHydration;\n function setAttemptContinuousHydration(fn) {\n attemptContinuousHydration = fn;\n }\n var attemptHydrationAtCurrentPriority;\n function setAttemptHydrationAtCurrentPriority(fn) {\n attemptHydrationAtCurrentPriority = fn;\n }\n var attemptHydrationAtPriority;\n function setAttemptHydrationAtPriority(fn) {\n attemptHydrationAtPriority = fn;\n } // TODO: Upgrade this definition once we're on a newer version of Flow that\n var hasScheduledReplayAttempt = false; // The queue of discrete events to be replayed.\n var queuedDiscreteEvents = []; // Indicates if any continuous event targets are non-null for early bailout.\n // if the last target was dehydrated.\n var queuedFocus = null;\n var queuedDrag = null;\n var queuedMouse = null; // For pointer events there can be one latest event per pointerId.\n var queuedPointers = new Map();\n var queuedPointerCaptures = new Map(); // We could consider replaying selectionchange and touchmoves too.\n var queuedExplicitHydrationTargets = [];\n function hasQueuedDiscreteEvents() {\n return queuedDiscreteEvents.length > 0;\n }\n var discreteReplayableEvents = [\n 'mousedown',\n 'mouseup',\n 'touchcancel',\n 'touchend',\n 'touchstart',\n 'auxclick',\n 'dblclick',\n 'pointercancel',\n 'pointerdown',\n 'pointerup',\n 'dragend',\n 'dragstart',\n 'drop',\n 'compositionend',\n 'compositionstart',\n 'keydown',\n 'keypress',\n 'keyup',\n 'input',\n 'textInput',\n 'copy',\n 'cut',\n 'paste',\n 'click',\n 'change',\n 'contextmenu',\n 'reset',\n 'submit'\n ];\n function isReplayableDiscreteEvent(eventType) {\n return discreteReplayableEvents.indexOf(eventType) > -1;\n }\n function createQueuedReplayableEvent(blockedOn, domEventName, eventSystemFlags, targetContainer, nativeEvent) {\n return {\n blockedOn: blockedOn,\n domEventName: domEventName,\n eventSystemFlags: eventSystemFlags | IS_REPLAYED,\n nativeEvent: nativeEvent,\n targetContainers: [\n targetContainer\n ]\n };\n }\n function queueDiscreteEvent(blockedOn, domEventName, eventSystemFlags, targetContainer, nativeEvent) {\n var queuedEvent = createQueuedReplayableEvent(blockedOn, domEventName, eventSystemFlags, targetContainer, nativeEvent);\n queuedDiscreteEvents.push(queuedEvent);\n } // Resets the replaying for this type of continuous event to no event.\n function clearIfContinuousEvent(domEventName, nativeEvent) {\n switch(domEventName){\n case 'focusin':\n case 'focusout':\n queuedFocus = null;\n break;\n case 'dragenter':\n case 'dragleave':\n queuedDrag = null;\n break;\n case 'mouseover':\n case 'mouseout':\n queuedMouse = null;\n break;\n case 'pointerover':\n case 'pointerout':\n var pointerId = nativeEvent.pointerId;\n queuedPointers.delete(pointerId);\n break;\n case 'gotpointercapture':\n case 'lostpointercapture':\n var _pointerId = nativeEvent.pointerId;\n queuedPointerCaptures.delete(_pointerId);\n break;\n }\n }\n function accumulateOrCreateContinuousQueuedReplayableEvent(existingQueuedEvent, blockedOn, domEventName, eventSystemFlags, targetContainer, nativeEvent) {\n if (existingQueuedEvent === null || existingQueuedEvent.nativeEvent !== nativeEvent) {\n var queuedEvent = createQueuedReplayableEvent(blockedOn, domEventName, eventSystemFlags, targetContainer, nativeEvent);\n if (blockedOn !== null) {\n var _fiber2 = getInstanceFromNode(blockedOn);\n if (_fiber2 !== null) // Attempt to increase the priority of this target.\n attemptContinuousHydration(_fiber2);\n }\n return queuedEvent;\n } // If we have already queued this exact event, then it's because\n // the different event systems have different DOM event listeners.\n // We can accumulate the flags, and the targetContainers, and\n // store a single event to be replayed.\n existingQueuedEvent.eventSystemFlags |= eventSystemFlags;\n var targetContainers = existingQueuedEvent.targetContainers;\n if (targetContainer !== null && targetContainers.indexOf(targetContainer) === -1) targetContainers.push(targetContainer);\n return existingQueuedEvent;\n }\n function queueIfContinuousEvent(blockedOn, domEventName, eventSystemFlags, targetContainer, nativeEvent) {\n // These set relatedTarget to null because the replayed event will be treated as if we\n // moved from outside the window (no target) onto the target once it hydrates.\n // Instead of mutating we could clone the event.\n switch(domEventName){\n case 'focusin':\n var focusEvent = nativeEvent;\n queuedFocus = accumulateOrCreateContinuousQueuedReplayableEvent(queuedFocus, blockedOn, domEventName, eventSystemFlags, targetContainer, focusEvent);\n return true;\n case 'dragenter':\n var dragEvent = nativeEvent;\n queuedDrag = accumulateOrCreateContinuousQueuedReplayableEvent(queuedDrag, blockedOn, domEventName, eventSystemFlags, targetContainer, dragEvent);\n return true;\n case 'mouseover':\n var mouseEvent = nativeEvent;\n queuedMouse = accumulateOrCreateContinuousQueuedReplayableEvent(queuedMouse, blockedOn, domEventName, eventSystemFlags, targetContainer, mouseEvent);\n return true;\n case 'pointerover':\n var pointerEvent = nativeEvent;\n var pointerId = pointerEvent.pointerId;\n queuedPointers.set(pointerId, accumulateOrCreateContinuousQueuedReplayableEvent(queuedPointers.get(pointerId) || null, blockedOn, domEventName, eventSystemFlags, targetContainer, pointerEvent));\n return true;\n case 'gotpointercapture':\n var _pointerEvent = nativeEvent;\n var _pointerId2 = _pointerEvent.pointerId;\n queuedPointerCaptures.set(_pointerId2, accumulateOrCreateContinuousQueuedReplayableEvent(queuedPointerCaptures.get(_pointerId2) || null, blockedOn, domEventName, eventSystemFlags, targetContainer, _pointerEvent));\n return true;\n }\n return false;\n } // Check if this target is unblocked. Returns true if it's unblocked.\n function attemptExplicitHydrationTarget(queuedTarget) {\n // TODO: This function shares a lot of logic with attemptToDispatchEvent.\n // Try to unify them. It's a bit tricky since it would require two return\n // values.\n var targetInst = getClosestInstanceFromNode(queuedTarget.target);\n if (targetInst !== null) {\n var nearestMounted = getNearestMountedFiber(targetInst);\n if (nearestMounted !== null) {\n var tag = nearestMounted.tag;\n if (tag === SuspenseComponent) {\n var instance = getSuspenseInstanceFromFiber(nearestMounted);\n if (instance !== null) {\n // We're blocked on hydrating this boundary.\n // Increase its priority.\n queuedTarget.blockedOn = instance;\n attemptHydrationAtPriority(queuedTarget.lanePriority, function() {\n Scheduler.unstable_runWithPriority(queuedTarget.priority, function() {\n attemptHydrationAtCurrentPriority(nearestMounted);\n });\n });\n return;\n }\n } else if (tag === HostRoot) {\n var root = nearestMounted.stateNode;\n if (root.hydrate) {\n queuedTarget.blockedOn = getContainerFromFiber(nearestMounted); // We don't currently have a way to increase the priority of\n // a root other than sync.\n return;\n }\n }\n }\n }\n queuedTarget.blockedOn = null;\n }\n function attemptReplayContinuousQueuedEvent(queuedEvent) {\n if (queuedEvent.blockedOn !== null) return false;\n var targetContainers = queuedEvent.targetContainers;\n while(targetContainers.length > 0){\n var targetContainer = targetContainers[0];\n var nextBlockedOn = attemptToDispatchEvent(queuedEvent.domEventName, queuedEvent.eventSystemFlags, targetContainer, queuedEvent.nativeEvent);\n if (nextBlockedOn !== null) {\n // We're still blocked. Try again later.\n var _fiber3 = getInstanceFromNode(nextBlockedOn);\n if (_fiber3 !== null) attemptContinuousHydration(_fiber3);\n queuedEvent.blockedOn = nextBlockedOn;\n return false;\n } // This target container was successfully dispatched. Try the next.\n targetContainers.shift();\n }\n return true;\n }\n function attemptReplayContinuousQueuedEventInMap(queuedEvent, key, map) {\n if (attemptReplayContinuousQueuedEvent(queuedEvent)) map.delete(key);\n }\n function replayUnblockedEvents() {\n hasScheduledReplayAttempt = false; // First replay discrete events.\n while(queuedDiscreteEvents.length > 0){\n var nextDiscreteEvent = queuedDiscreteEvents[0];\n if (nextDiscreteEvent.blockedOn !== null) {\n // We're still blocked.\n // Increase the priority of this boundary to unblock\n // the next discrete event.\n var _fiber4 = getInstanceFromNode(nextDiscreteEvent.blockedOn);\n if (_fiber4 !== null) attemptUserBlockingHydration(_fiber4);\n break;\n }\n var targetContainers = nextDiscreteEvent.targetContainers;\n while(targetContainers.length > 0){\n var targetContainer = targetContainers[0];\n var nextBlockedOn = attemptToDispatchEvent(nextDiscreteEvent.domEventName, nextDiscreteEvent.eventSystemFlags, targetContainer, nextDiscreteEvent.nativeEvent);\n if (nextBlockedOn !== null) {\n // We're still blocked. Try again later.\n nextDiscreteEvent.blockedOn = nextBlockedOn;\n break;\n } // This target container was successfully dispatched. Try the next.\n targetContainers.shift();\n }\n if (nextDiscreteEvent.blockedOn === null) // We've successfully replayed the first event. Let's try the next one.\n queuedDiscreteEvents.shift();\n } // Next replay any continuous events.\n if (queuedFocus !== null && attemptReplayContinuousQueuedEvent(queuedFocus)) queuedFocus = null;\n if (queuedDrag !== null && attemptReplayContinuousQueuedEvent(queuedDrag)) queuedDrag = null;\n if (queuedMouse !== null && attemptReplayContinuousQueuedEvent(queuedMouse)) queuedMouse = null;\n queuedPointers.forEach(attemptReplayContinuousQueuedEventInMap);\n queuedPointerCaptures.forEach(attemptReplayContinuousQueuedEventInMap);\n }\n function scheduleCallbackIfUnblocked(queuedEvent, unblocked) {\n if (queuedEvent.blockedOn === unblocked) {\n queuedEvent.blockedOn = null;\n if (!hasScheduledReplayAttempt) {\n hasScheduledReplayAttempt = true; // Schedule a callback to attempt replaying as many events as are\n // now unblocked. This first might not actually be unblocked yet.\n // We could check it early to avoid scheduling an unnecessary callback.\n Scheduler.unstable_scheduleCallback(Scheduler.unstable_NormalPriority, replayUnblockedEvents);\n }\n }\n }\n function retryIfBlockedOn(unblocked) {\n // Mark anything that was blocked on this as no longer blocked\n // and eligible for a replay.\n if (queuedDiscreteEvents.length > 0) {\n scheduleCallbackIfUnblocked(queuedDiscreteEvents[0], unblocked); // This is a exponential search for each boundary that commits. I think it's\n // worth it because we expect very few discrete events to queue up and once\n // we are actually fully unblocked it will be fast to replay them.\n for(var i = 1; i < queuedDiscreteEvents.length; i++){\n var queuedEvent = queuedDiscreteEvents[i];\n if (queuedEvent.blockedOn === unblocked) queuedEvent.blockedOn = null;\n }\n }\n if (queuedFocus !== null) scheduleCallbackIfUnblocked(queuedFocus, unblocked);\n if (queuedDrag !== null) scheduleCallbackIfUnblocked(queuedDrag, unblocked);\n if (queuedMouse !== null) scheduleCallbackIfUnblocked(queuedMouse, unblocked);\n var unblock = function(queuedEvent) {\n return scheduleCallbackIfUnblocked(queuedEvent, unblocked);\n };\n queuedPointers.forEach(unblock);\n queuedPointerCaptures.forEach(unblock);\n for(var _i = 0; _i < queuedExplicitHydrationTargets.length; _i++){\n var queuedTarget = queuedExplicitHydrationTargets[_i];\n if (queuedTarget.blockedOn === unblocked) queuedTarget.blockedOn = null;\n }\n while(queuedExplicitHydrationTargets.length > 0){\n var nextExplicitTarget = queuedExplicitHydrationTargets[0];\n if (nextExplicitTarget.blockedOn !== null) break;\n else {\n attemptExplicitHydrationTarget(nextExplicitTarget);\n if (nextExplicitTarget.blockedOn === null) // We're unblocked.\n queuedExplicitHydrationTargets.shift();\n }\n }\n }\n var DiscreteEvent = 0;\n var UserBlockingEvent = 1;\n var ContinuousEvent = 2;\n /**\n * Generate a mapping of standard vendor prefixes using the defined style property and event name.\n *\n * @param {string} styleProp\n * @param {string} eventName\n * @returns {object}\n */ function makePrefixMap(styleProp, eventName) {\n var prefixes = {\n };\n prefixes[styleProp.toLowerCase()] = eventName.toLowerCase();\n prefixes['Webkit' + styleProp] = 'webkit' + eventName;\n prefixes['Moz' + styleProp] = 'moz' + eventName;\n return prefixes;\n }\n /**\n * A list of event names to a configurable list of vendor prefixes.\n */ var vendorPrefixes = {\n animationend: makePrefixMap('Animation', 'AnimationEnd'),\n animationiteration: makePrefixMap('Animation', 'AnimationIteration'),\n animationstart: makePrefixMap('Animation', 'AnimationStart'),\n transitionend: makePrefixMap('Transition', 'TransitionEnd')\n };\n /**\n * Event names that have already been detected and prefixed (if applicable).\n */ var prefixedEventNames = {\n };\n /**\n * Element to check for prefixes on.\n */ var style1 = {\n };\n /**\n * Bootstrap if a DOM exists.\n */ if (canUseDOM) {\n style1 = document.createElement('div').style; // On some platforms, in particular some releases of Android 4.x,\n // the un-prefixed \"animation\" and \"transition\" properties are defined on the\n // style object but the events that fire will still be prefixed, so we need\n // to check if the un-prefixed events are usable, and if not remove them from the map.\n if (!('AnimationEvent' in window)) {\n delete vendorPrefixes.animationend.animation;\n delete vendorPrefixes.animationiteration.animation;\n delete vendorPrefixes.animationstart.animation;\n } // Same as above\n if (!('TransitionEvent' in window)) delete vendorPrefixes.transitionend.transition;\n }\n /**\n * Attempts to determine the correct vendor prefixed event name.\n *\n * @param {string} eventName\n * @returns {string}\n */ function getVendorPrefixedEventName(eventName) {\n if (prefixedEventNames[eventName]) return prefixedEventNames[eventName];\n else if (!vendorPrefixes[eventName]) return eventName;\n var prefixMap = vendorPrefixes[eventName];\n for(var styleProp in prefixMap){\n if (prefixMap.hasOwnProperty(styleProp) && styleProp in style1) return prefixedEventNames[eventName] = prefixMap[styleProp];\n }\n return eventName;\n }\n var ANIMATION_END = getVendorPrefixedEventName('animationend');\n var ANIMATION_ITERATION = getVendorPrefixedEventName('animationiteration');\n var ANIMATION_START = getVendorPrefixedEventName('animationstart');\n var TRANSITION_END = getVendorPrefixedEventName('transitionend');\n var topLevelEventsToReactNames = new Map();\n var eventPriorities = new Map(); // We store most of the events in this module in pairs of two strings so we can re-use\n // the code required to apply the same logic for event prioritization and that of the\n // SimpleEventPlugin. This complicates things slightly, but the aim is to reduce code\n // duplication (for which there would be quite a bit). For the events that are not needed\n // for the SimpleEventPlugin (otherDiscreteEvents) we process them separately as an\n // array of top level events.\n // Lastly, we ignore prettier so we can keep the formatting sane.\n // prettier-ignore\n var discreteEventPairsForSimpleEventPlugin = [\n 'cancel',\n 'cancel',\n 'click',\n 'click',\n 'close',\n 'close',\n 'contextmenu',\n 'contextMenu',\n 'copy',\n 'copy',\n 'cut',\n 'cut',\n 'auxclick',\n 'auxClick',\n 'dblclick',\n 'doubleClick',\n 'dragend',\n 'dragEnd',\n 'dragstart',\n 'dragStart',\n 'drop',\n 'drop',\n 'focusin',\n 'focus',\n 'focusout',\n 'blur',\n 'input',\n 'input',\n 'invalid',\n 'invalid',\n 'keydown',\n 'keyDown',\n 'keypress',\n 'keyPress',\n 'keyup',\n 'keyUp',\n 'mousedown',\n 'mouseDown',\n 'mouseup',\n 'mouseUp',\n 'paste',\n 'paste',\n 'pause',\n 'pause',\n 'play',\n 'play',\n 'pointercancel',\n 'pointerCancel',\n 'pointerdown',\n 'pointerDown',\n 'pointerup',\n 'pointerUp',\n 'ratechange',\n 'rateChange',\n 'reset',\n 'reset',\n 'seeked',\n 'seeked',\n 'submit',\n 'submit',\n 'touchcancel',\n 'touchCancel',\n 'touchend',\n 'touchEnd',\n 'touchstart',\n 'touchStart',\n 'volumechange',\n 'volumeChange'\n ];\n var otherDiscreteEvents = [\n 'change',\n 'selectionchange',\n 'textInput',\n 'compositionstart',\n 'compositionend',\n 'compositionupdate'\n ];\n var userBlockingPairsForSimpleEventPlugin = [\n 'drag',\n 'drag',\n 'dragenter',\n 'dragEnter',\n 'dragexit',\n 'dragExit',\n 'dragleave',\n 'dragLeave',\n 'dragover',\n 'dragOver',\n 'mousemove',\n 'mouseMove',\n 'mouseout',\n 'mouseOut',\n 'mouseover',\n 'mouseOver',\n 'pointermove',\n 'pointerMove',\n 'pointerout',\n 'pointerOut',\n 'pointerover',\n 'pointerOver',\n 'scroll',\n 'scroll',\n 'toggle',\n 'toggle',\n 'touchmove',\n 'touchMove',\n 'wheel',\n 'wheel'\n ]; // prettier-ignore\n var continuousPairsForSimpleEventPlugin = [\n 'abort',\n 'abort',\n ANIMATION_END,\n 'animationEnd',\n ANIMATION_ITERATION,\n 'animationIteration',\n ANIMATION_START,\n 'animationStart',\n 'canplay',\n 'canPlay',\n 'canplaythrough',\n 'canPlayThrough',\n 'durationchange',\n 'durationChange',\n 'emptied',\n 'emptied',\n 'encrypted',\n 'encrypted',\n 'ended',\n 'ended',\n 'error',\n 'error',\n 'gotpointercapture',\n 'gotPointerCapture',\n 'load',\n 'load',\n 'loadeddata',\n 'loadedData',\n 'loadedmetadata',\n 'loadedMetadata',\n 'loadstart',\n 'loadStart',\n 'lostpointercapture',\n 'lostPointerCapture',\n 'playing',\n 'playing',\n 'progress',\n 'progress',\n 'seeking',\n 'seeking',\n 'stalled',\n 'stalled',\n 'suspend',\n 'suspend',\n 'timeupdate',\n 'timeUpdate',\n TRANSITION_END,\n 'transitionEnd',\n 'waiting',\n 'waiting'\n ];\n /**\n * Turns\n * ['abort', ...]\n *\n * into\n *\n * topLevelEventsToReactNames = new Map([\n * ['abort', 'onAbort'],\n * ]);\n *\n * and registers them.\n */ function registerSimplePluginEventsAndSetTheirPriorities(eventTypes, priority) {\n // As the event types are in pairs of two, we need to iterate\n // through in twos. The events are in pairs of two to save code\n // and improve init perf of processing this array, as it will\n // result in far fewer object allocations and property accesses\n // if we only use three arrays to process all the categories of\n // instead of tuples.\n for(var i = 0; i < eventTypes.length; i += 2){\n var topEvent = eventTypes[i];\n var event = eventTypes[i + 1];\n var capitalizedEvent = event[0].toUpperCase() + event.slice(1);\n var reactName = 'on' + capitalizedEvent;\n eventPriorities.set(topEvent, priority);\n topLevelEventsToReactNames.set(topEvent, reactName);\n registerTwoPhaseEvent(reactName, [\n topEvent\n ]);\n }\n }\n function setEventPriorities(eventTypes, priority) {\n for(var i = 0; i < eventTypes.length; i++)eventPriorities.set(eventTypes[i], priority);\n }\n function getEventPriorityForPluginSystem(domEventName) {\n var priority = eventPriorities.get(domEventName); // Default to a ContinuousEvent. Note: we might\n // want to warn if we can't detect the priority\n // for the event.\n return priority === undefined ? ContinuousEvent : priority;\n }\n function registerSimpleEvents() {\n registerSimplePluginEventsAndSetTheirPriorities(discreteEventPairsForSimpleEventPlugin, DiscreteEvent);\n registerSimplePluginEventsAndSetTheirPriorities(userBlockingPairsForSimpleEventPlugin, UserBlockingEvent);\n registerSimplePluginEventsAndSetTheirPriorities(continuousPairsForSimpleEventPlugin, ContinuousEvent);\n setEventPriorities(otherDiscreteEvents, DiscreteEvent);\n }\n var Scheduler_now = Scheduler.unstable_now;\n // Provide explicit error message when production+profiling bundle of e.g.\n // react-dom is used with production (non-profiling) bundle of\n // scheduler/tracing\n if (!(tracing.__interactionsRef != null && tracing.__interactionsRef.current != null)) throw Error(\"It is not supported to run the profiling version of a renderer (for example, `react-dom/profiling`) without also replacing the `scheduler/tracing` module with `scheduler/tracing-profiling`. Your bundler might have a setting for aliasing both modules. Learn more at https://reactjs.org/link/profiling\");\n // ascending numbers so we can compare them like numbers. They start at 90 to\n // avoid clashing with Scheduler's priorities.\n var ImmediatePriority = 99;\n var UserBlockingPriority = 98;\n var NormalPriority = 97;\n var LowPriority = 96;\n var IdlePriority = 95; // NoPriority is the absence of priority. Also React-only.\n var NoPriority = 90;\n var initialTimeMs = Scheduler_now(); // If the initial timestamp is reasonably small, use Scheduler's `now` directly.\n var SyncLanePriority = 15;\n var SyncBatchedLanePriority = 14;\n var InputDiscreteHydrationLanePriority = 13;\n var InputDiscreteLanePriority = 12;\n var InputContinuousHydrationLanePriority = 11;\n var InputContinuousLanePriority = 10;\n var DefaultHydrationLanePriority = 9;\n var DefaultLanePriority = 8;\n var TransitionHydrationPriority = 7;\n var TransitionPriority = 6;\n var RetryLanePriority = 5;\n var SelectiveHydrationLanePriority = 4;\n var IdleHydrationLanePriority = 3;\n var IdleLanePriority = 2;\n var OffscreenLanePriority = 1;\n var NoLanePriority = 0;\n var TotalLanes = 31;\n var NoLanes = /* */ 0;\n var NoLane = /* */ 0;\n var SyncLane = /* */ 1;\n var SyncBatchedLane = /* */ 2;\n var InputDiscreteHydrationLane = /* */ 4;\n var InputDiscreteLanes = /* */ 24;\n var InputContinuousHydrationLane = /* */ 32;\n var InputContinuousLanes = /* */ 192;\n var DefaultHydrationLane = /* */ 256;\n var DefaultLanes = /* */ 3584;\n var TransitionHydrationLane = /* */ 4096;\n var TransitionLanes = /* */ 4186112;\n var RetryLanes = /* */ 62914560;\n var SomeRetryLane = /* */ 33554432;\n var SelectiveHydrationLane = /* */ 67108864;\n var NonIdleLanes = /* */ 134217727;\n var IdleHydrationLane = /* */ 134217728;\n var IdleLanes = /* */ 805306368;\n var OffscreenLane = /* */ 1073741824;\n var NoTimestamp = -1;\n function setCurrentUpdateLanePriority(newLanePriority) {\n } // \"Registers\" used to \"return\" multiple values\n // Used by getHighestPriorityLanes and getNextLanes:\n var return_highestLanePriority = DefaultLanePriority;\n function getHighestPriorityLanes(lanes) {\n if ((SyncLane & lanes) !== NoLanes) {\n return_highestLanePriority = SyncLanePriority;\n return SyncLane;\n }\n if ((SyncBatchedLane & lanes) !== NoLanes) {\n return_highestLanePriority = SyncBatchedLanePriority;\n return SyncBatchedLane;\n }\n if ((InputDiscreteHydrationLane & lanes) !== NoLanes) {\n return_highestLanePriority = InputDiscreteHydrationLanePriority;\n return InputDiscreteHydrationLane;\n }\n var inputDiscreteLanes = InputDiscreteLanes & lanes;\n if (inputDiscreteLanes !== NoLanes) {\n return_highestLanePriority = InputDiscreteLanePriority;\n return inputDiscreteLanes;\n }\n if ((lanes & InputContinuousHydrationLane) !== NoLanes) {\n return_highestLanePriority = InputContinuousHydrationLanePriority;\n return InputContinuousHydrationLane;\n }\n var inputContinuousLanes = InputContinuousLanes & lanes;\n if (inputContinuousLanes !== NoLanes) {\n return_highestLanePriority = InputContinuousLanePriority;\n return inputContinuousLanes;\n }\n if ((lanes & DefaultHydrationLane) !== NoLanes) {\n return_highestLanePriority = DefaultHydrationLanePriority;\n return DefaultHydrationLane;\n }\n var defaultLanes = DefaultLanes & lanes;\n if (defaultLanes !== NoLanes) {\n return_highestLanePriority = DefaultLanePriority;\n return defaultLanes;\n }\n if ((lanes & TransitionHydrationLane) !== NoLanes) {\n return_highestLanePriority = TransitionHydrationPriority;\n return TransitionHydrationLane;\n }\n var transitionLanes = TransitionLanes & lanes;\n if (transitionLanes !== NoLanes) {\n return_highestLanePriority = TransitionPriority;\n return transitionLanes;\n }\n var retryLanes = RetryLanes & lanes;\n if (retryLanes !== NoLanes) {\n return_highestLanePriority = RetryLanePriority;\n return retryLanes;\n }\n if (lanes & SelectiveHydrationLane) {\n return_highestLanePriority = SelectiveHydrationLanePriority;\n return SelectiveHydrationLane;\n }\n if ((lanes & IdleHydrationLane) !== NoLanes) {\n return_highestLanePriority = IdleHydrationLanePriority;\n return IdleHydrationLane;\n }\n var idleLanes = IdleLanes & lanes;\n if (idleLanes !== NoLanes) {\n return_highestLanePriority = IdleLanePriority;\n return idleLanes;\n }\n if ((OffscreenLane & lanes) !== NoLanes) {\n return_highestLanePriority = OffscreenLanePriority;\n return OffscreenLane;\n }\n error1('Should have found matching lanes. This is a bug in React.');\n return_highestLanePriority = DefaultLanePriority;\n return lanes;\n }\n function schedulerPriorityToLanePriority(schedulerPriorityLevel) {\n switch(schedulerPriorityLevel){\n case ImmediatePriority:\n return SyncLanePriority;\n case UserBlockingPriority:\n return InputContinuousLanePriority;\n case NormalPriority:\n case LowPriority:\n // TODO: Handle LowSchedulerPriority, somehow. Maybe the same lane as hydration.\n return DefaultLanePriority;\n case IdlePriority:\n return IdleLanePriority;\n default:\n return NoLanePriority;\n }\n }\n function lanePriorityToSchedulerPriority(lanePriority) {\n switch(lanePriority){\n case SyncLanePriority:\n case SyncBatchedLanePriority:\n return ImmediatePriority;\n case InputDiscreteHydrationLanePriority:\n case InputDiscreteLanePriority:\n case InputContinuousHydrationLanePriority:\n case InputContinuousLanePriority:\n return UserBlockingPriority;\n case DefaultHydrationLanePriority:\n case DefaultLanePriority:\n case TransitionHydrationPriority:\n case TransitionPriority:\n case SelectiveHydrationLanePriority:\n case RetryLanePriority:\n return NormalPriority;\n case IdleHydrationLanePriority:\n case IdleLanePriority:\n case OffscreenLanePriority:\n return IdlePriority;\n case NoLanePriority:\n return NoPriority;\n default:\n throw Error(\"Invalid update priority: \" + lanePriority + \". This is a bug in React.\");\n }\n }\n function getNextLanes(root, wipLanes) {\n // Early bailout if there's no pending work left.\n var pendingLanes = root.pendingLanes;\n if (pendingLanes === NoLanes) {\n return_highestLanePriority = NoLanePriority;\n return NoLanes;\n }\n var nextLanes = NoLanes;\n var nextLanePriority = NoLanePriority;\n var expiredLanes = root.expiredLanes;\n var suspendedLanes = root.suspendedLanes;\n var pingedLanes = root.pingedLanes; // Check if any work has expired.\n if (expiredLanes !== NoLanes) {\n nextLanes = expiredLanes;\n nextLanePriority = return_highestLanePriority = SyncLanePriority;\n } else {\n // Do not work on any idle work until all the non-idle work has finished,\n // even if the work is suspended.\n var nonIdlePendingLanes = pendingLanes & NonIdleLanes;\n if (nonIdlePendingLanes !== NoLanes) {\n var nonIdleUnblockedLanes = nonIdlePendingLanes & ~suspendedLanes;\n if (nonIdleUnblockedLanes !== NoLanes) {\n nextLanes = getHighestPriorityLanes(nonIdleUnblockedLanes);\n nextLanePriority = return_highestLanePriority;\n } else {\n var nonIdlePingedLanes = nonIdlePendingLanes & pingedLanes;\n if (nonIdlePingedLanes !== NoLanes) {\n nextLanes = getHighestPriorityLanes(nonIdlePingedLanes);\n nextLanePriority = return_highestLanePriority;\n }\n }\n } else {\n // The only remaining work is Idle.\n var unblockedLanes = pendingLanes & ~suspendedLanes;\n if (unblockedLanes !== NoLanes) {\n nextLanes = getHighestPriorityLanes(unblockedLanes);\n nextLanePriority = return_highestLanePriority;\n } else if (pingedLanes !== NoLanes) {\n nextLanes = getHighestPriorityLanes(pingedLanes);\n nextLanePriority = return_highestLanePriority;\n }\n }\n }\n if (nextLanes === NoLanes) // This should only be reachable if we're suspended\n // TODO: Consider warning in this path if a fallback timer is not scheduled.\n return NoLanes;\n // If there are higher priority lanes, we'll include them even if they\n // are suspended.\n nextLanes = pendingLanes & getEqualOrHigherPriorityLanes(nextLanes); // If we're already in the middle of a render, switching lanes will interrupt\n // it and we'll lose our progress. We should only do this if the new lanes are\n // higher priority.\n if (wipLanes !== NoLanes && wipLanes !== nextLanes && // bother waiting until the root is complete.\n (wipLanes & suspendedLanes) === NoLanes) {\n getHighestPriorityLanes(wipLanes);\n var wipLanePriority = return_highestLanePriority;\n if (nextLanePriority <= wipLanePriority) return wipLanes;\n else return_highestLanePriority = nextLanePriority;\n } // Check for entangled lanes and add them to the batch.\n //\n // A lane is said to be entangled with another when it's not allowed to render\n // in a batch that does not also include the other lane. Typically we do this\n // when multiple updates have the same source, and we only want to respond to\n // the most recent event from that source.\n //\n // Note that we apply entanglements *after* checking for partial work above.\n // This means that if a lane is entangled during an interleaved event while\n // it's already rendering, we won't interrupt it. This is intentional, since\n // entanglement is usually \"best effort\": we'll try our best to render the\n // lanes in the same batch, but it's not worth throwing out partially\n // completed work in order to do it.\n //\n // For those exceptions where entanglement is semantically important, like\n // useMutableSource, we should ensure that there is no partial work at the\n // time we apply the entanglement.\n var entangledLanes = root.entangledLanes;\n if (entangledLanes !== NoLanes) {\n var entanglements = root.entanglements;\n var lanes = nextLanes & entangledLanes;\n while(lanes > 0){\n var index = pickArbitraryLaneIndex(lanes);\n var lane = 1 << index;\n nextLanes |= entanglements[index];\n lanes &= ~lane;\n }\n }\n return nextLanes;\n }\n function getMostRecentEventTime(root, lanes) {\n var eventTimes = root.eventTimes;\n var mostRecentEventTime = NoTimestamp;\n while(lanes > 0){\n var index = pickArbitraryLaneIndex(lanes);\n var lane = 1 << index;\n var eventTime = eventTimes[index];\n if (eventTime > mostRecentEventTime) mostRecentEventTime = eventTime;\n lanes &= ~lane;\n }\n return mostRecentEventTime;\n }\n function computeExpirationTime(lane, currentTime) {\n // TODO: Expiration heuristic is constant per lane, so could use a map.\n getHighestPriorityLanes(lane);\n var priority = return_highestLanePriority;\n if (priority >= InputContinuousLanePriority) // User interactions should expire slightly more quickly.\n //\n // NOTE: This is set to the corresponding constant as in Scheduler.js. When\n // we made it larger, a product metric in www regressed, suggesting there's\n // a user interaction that's being starved by a series of synchronous\n // updates. If that theory is correct, the proper solution is to fix the\n // starvation. However, this scenario supports the idea that expiration\n // times are an important safeguard when starvation does happen.\n //\n // Also note that, in the case of user input specifically, this will soon no\n // longer be an issue because we plan to make user input synchronous by\n // default (until you enter `startTransition`, of course.)\n //\n // If weren't planning to make these updates synchronous soon anyway, I\n // would probably make this number a configurable parameter.\n return currentTime + 250;\n else if (priority >= TransitionPriority) return currentTime + 5000;\n else // Anything idle priority or lower should never expire.\n return NoTimestamp;\n }\n function markStarvedLanesAsExpired(root, currentTime) {\n // TODO: This gets called every time we yield. We can optimize by storing\n // the earliest expiration time on the root. Then use that to quickly bail out\n // of this function.\n var pendingLanes = root.pendingLanes;\n var suspendedLanes = root.suspendedLanes;\n var pingedLanes = root.pingedLanes;\n var expirationTimes = root.expirationTimes; // Iterate through the pending lanes and check if we've reached their\n // expiration time. If so, we'll assume the update is being starved and mark\n // it as expired to force it to finish.\n var lanes = pendingLanes;\n while(lanes > 0){\n var index = pickArbitraryLaneIndex(lanes);\n var lane = 1 << index;\n var expirationTime = expirationTimes[index];\n if (expirationTime === NoTimestamp) // Found a pending lane with no expiration time. If it's not suspended, or\n // if it's pinged, assume it's CPU-bound. Compute a new expiration time\n // using the current time.\n {\n if ((lane & suspendedLanes) === NoLanes || (lane & pingedLanes) !== NoLanes) // Assumes timestamps are monotonically increasing.\n expirationTimes[index] = computeExpirationTime(lane, currentTime);\n } else if (expirationTime <= currentTime) // This lane expired\n root.expiredLanes |= lane;\n lanes &= ~lane;\n }\n } // This returns the highest priority pending lanes regardless of whether they\n function getLanesToRetrySynchronouslyOnError(root) {\n var everythingButOffscreen = root.pendingLanes & ~OffscreenLane;\n if (everythingButOffscreen !== NoLanes) return everythingButOffscreen;\n if (everythingButOffscreen & OffscreenLane) return OffscreenLane;\n return NoLanes;\n }\n function returnNextLanesPriority() {\n return return_highestLanePriority;\n }\n function includesNonIdleWork(lanes) {\n return (lanes & NonIdleLanes) !== NoLanes;\n }\n function includesOnlyRetries(lanes) {\n return (lanes & RetryLanes) === lanes;\n }\n function includesOnlyTransitions(lanes) {\n return (lanes & TransitionLanes) === lanes;\n } // To ensure consistency across multiple updates in the same event, this should\n // be a pure function, so that it always returns the same lane for given inputs.\n function findUpdateLane(lanePriority, wipLanes) {\n switch(lanePriority){\n case NoLanePriority:\n break;\n case SyncLanePriority:\n return SyncLane;\n case SyncBatchedLanePriority:\n return SyncBatchedLane;\n case InputDiscreteLanePriority:\n var _lane = pickArbitraryLane(InputDiscreteLanes & ~wipLanes);\n if (_lane === NoLane) // Shift to the next priority level\n return findUpdateLane(InputContinuousLanePriority, wipLanes);\n return _lane;\n case InputContinuousLanePriority:\n var _lane2 = pickArbitraryLane(InputContinuousLanes & ~wipLanes);\n if (_lane2 === NoLane) // Shift to the next priority level\n return findUpdateLane(DefaultLanePriority, wipLanes);\n return _lane2;\n case DefaultLanePriority:\n var _lane3 = pickArbitraryLane(DefaultLanes & ~wipLanes);\n if (_lane3 === NoLane) {\n // If all the default lanes are already being worked on, look for a\n // lane in the transition range.\n _lane3 = pickArbitraryLane(TransitionLanes & ~wipLanes);\n if (_lane3 === NoLane) // All the transition lanes are taken, too. This should be very\n // rare, but as a last resort, pick a default lane. This will have\n // the effect of interrupting the current work-in-progress render.\n _lane3 = pickArbitraryLane(DefaultLanes);\n }\n return _lane3;\n case TransitionPriority:\n case RetryLanePriority:\n break;\n case IdleLanePriority:\n var lane = pickArbitraryLane(IdleLanes & ~wipLanes);\n if (lane === NoLane) lane = pickArbitraryLane(IdleLanes);\n return lane;\n }\n throw Error(\"Invalid update priority: \" + lanePriority + \". This is a bug in React.\");\n } // To ensure consistency across multiple updates in the same event, this should\n // be pure function, so that it always returns the same lane for given inputs.\n function findTransitionLane(wipLanes, pendingLanes) {\n // First look for lanes that are completely unclaimed, i.e. have no\n // pending work.\n var lane = pickArbitraryLane(TransitionLanes & ~pendingLanes);\n if (lane === NoLane) {\n // If all lanes have pending work, look for a lane that isn't currently\n // being worked on.\n lane = pickArbitraryLane(TransitionLanes & ~wipLanes);\n if (lane === NoLane) // If everything is being worked on, pick any lane. This has the\n // effect of interrupting the current work-in-progress.\n lane = pickArbitraryLane(TransitionLanes);\n }\n return lane;\n } // To ensure consistency across multiple updates in the same event, this should\n // be pure function, so that it always returns the same lane for given inputs.\n function findRetryLane(wipLanes) {\n // This is a fork of `findUpdateLane` designed specifically for Suspense\n // \"retries\" \u2014 a special update that attempts to flip a Suspense boundary\n // from its placeholder state to its primary/resolved state.\n var lane = pickArbitraryLane(RetryLanes & ~wipLanes);\n if (lane === NoLane) lane = pickArbitraryLane(RetryLanes);\n return lane;\n }\n function getHighestPriorityLane(lanes) {\n return lanes & -lanes;\n }\n function getLowestPriorityLane(lanes) {\n // This finds the most significant non-zero bit.\n var index = 31 - clz32(lanes);\n return index < 0 ? NoLanes : 1 << index;\n }\n function getEqualOrHigherPriorityLanes(lanes) {\n return (getLowestPriorityLane(lanes) << 1) - 1;\n }\n function pickArbitraryLane(lanes) {\n // This wrapper function gets inlined. Only exists so to communicate that it\n // doesn't matter which bit is selected; you can pick any bit without\n // affecting the algorithms where its used. Here I'm using\n // getHighestPriorityLane because it requires the fewest operations.\n return getHighestPriorityLane(lanes);\n }\n function pickArbitraryLaneIndex(lanes) {\n return 31 - clz32(lanes);\n }\n function laneToIndex(lane) {\n return pickArbitraryLaneIndex(lane);\n }\n function includesSomeLane(a, b) {\n return (a & b) !== NoLanes;\n }\n function isSubsetOfLanes(set, subset) {\n return (set & subset) === subset;\n }\n function mergeLanes(a, b) {\n return a | b;\n }\n function removeLanes(set, subset) {\n return set & ~subset;\n } // Seems redundant, but it changes the type from a single lane (used for\n // updates) to a group of lanes (used for flushing work).\n function laneToLanes(lane) {\n return lane;\n }\n function higherPriorityLane(a, b) {\n // This works because the bit ranges decrease in priority as you go left.\n return a !== NoLane && a < b ? a : b;\n }\n function createLaneMap(initial) {\n // Intentionally pushing one by one.\n // https://v8.dev/blog/elements-kinds#avoid-creating-holes\n var laneMap = [];\n for(var i = 0; i < TotalLanes; i++)laneMap.push(initial);\n return laneMap;\n }\n function markRootUpdated(root, updateLane, eventTime) {\n root.pendingLanes |= updateLane; // TODO: Theoretically, any update to any lane can unblock any other lane. But\n // it's not practical to try every single possible combination. We need a\n // heuristic to decide which lanes to attempt to render, and in which batches.\n // For now, we use the same heuristic as in the old ExpirationTimes model:\n // retry any lane at equal or lower priority, but don't try updates at higher\n // priority without also including the lower priority updates. This works well\n // when considering updates across different priority levels, but isn't\n // sufficient for updates within the same priority, since we want to treat\n // those updates as parallel.\n // Unsuspend any update at equal or lower priority.\n var higherPriorityLanes = updateLane - 1; // Turns 0b1000 into 0b0111\n root.suspendedLanes &= higherPriorityLanes;\n root.pingedLanes &= higherPriorityLanes;\n var eventTimes = root.eventTimes;\n var index = laneToIndex(updateLane); // We can always overwrite an existing timestamp because we prefer the most\n // recent event, and we assume time is monotonically increasing.\n eventTimes[index] = eventTime;\n }\n function markRootSuspended(root, suspendedLanes) {\n root.suspendedLanes |= suspendedLanes;\n root.pingedLanes &= ~suspendedLanes; // The suspended lanes are no longer CPU-bound. Clear their expiration times.\n var expirationTimes = root.expirationTimes;\n var lanes = suspendedLanes;\n while(lanes > 0){\n var index = pickArbitraryLaneIndex(lanes);\n var lane = 1 << index;\n expirationTimes[index] = NoTimestamp;\n lanes &= ~lane;\n }\n }\n function markRootPinged(root, pingedLanes, eventTime) {\n root.pingedLanes |= root.suspendedLanes & pingedLanes;\n }\n function markDiscreteUpdatesExpired(root) {\n root.expiredLanes |= InputDiscreteLanes & root.pendingLanes;\n }\n function hasDiscreteLanes(lanes) {\n return (lanes & InputDiscreteLanes) !== NoLanes;\n }\n function markRootMutableRead(root, updateLane) {\n root.mutableReadLanes |= updateLane & root.pendingLanes;\n }\n function markRootFinished(root, remainingLanes) {\n var noLongerPendingLanes = root.pendingLanes & ~remainingLanes;\n root.pendingLanes = remainingLanes; // Let's try everything again\n root.suspendedLanes = 0;\n root.pingedLanes = 0;\n root.expiredLanes &= remainingLanes;\n root.mutableReadLanes &= remainingLanes;\n root.entangledLanes &= remainingLanes;\n var entanglements = root.entanglements;\n var eventTimes = root.eventTimes;\n var expirationTimes = root.expirationTimes; // Clear the lanes that no longer have pending work\n var lanes = noLongerPendingLanes;\n while(lanes > 0){\n var index = pickArbitraryLaneIndex(lanes);\n var lane = 1 << index;\n entanglements[index] = NoLanes;\n eventTimes[index] = NoTimestamp;\n expirationTimes[index] = NoTimestamp;\n lanes &= ~lane;\n }\n }\n function markRootEntangled(root, entangledLanes) {\n root.entangledLanes |= entangledLanes;\n var entanglements = root.entanglements;\n var lanes = entangledLanes;\n while(lanes > 0){\n var index = pickArbitraryLaneIndex(lanes);\n var lane = 1 << index;\n entanglements[index] |= entangledLanes;\n lanes &= ~lane;\n }\n }\n var clz32 = Math.clz32 ? Math.clz32 : clz32Fallback; // Count leading zeros. Only used on lanes, so assume input is an integer.\n // Based on:\n // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/clz32\n var log = Math.log;\n var LN2 = Math.LN2;\n function clz32Fallback(lanes) {\n if (lanes === 0) return 32;\n return 31 - (log(lanes) / LN2 | 0) | 0;\n }\n // Intentionally not named imports because Rollup would use dynamic dispatch for\n var UserBlockingPriority$1 = Scheduler.unstable_UserBlockingPriority, runWithPriority = Scheduler.unstable_runWithPriority; // TODO: can we stop exporting these?\n var _enabled = true; // This is exported in FB builds for use by legacy FB layer infra.\n // We'd like to remove this but it's not clear if this is safe.\n function setEnabled(enabled) {\n _enabled = !!enabled;\n }\n function isEnabled() {\n return _enabled;\n }\n function createEventListenerWrapperWithPriority(targetContainer, domEventName, eventSystemFlags) {\n var eventPriority = getEventPriorityForPluginSystem(domEventName);\n var listenerWrapper;\n switch(eventPriority){\n case DiscreteEvent:\n listenerWrapper = dispatchDiscreteEvent;\n break;\n case UserBlockingEvent:\n listenerWrapper = dispatchUserBlockingUpdate;\n break;\n case ContinuousEvent:\n default:\n listenerWrapper = dispatchEvent;\n break;\n }\n return listenerWrapper.bind(null, domEventName, eventSystemFlags, targetContainer);\n }\n function dispatchDiscreteEvent(domEventName, eventSystemFlags, container, nativeEvent) {\n flushDiscreteUpdatesIfNeeded(nativeEvent.timeStamp);\n discreteUpdates(dispatchEvent, domEventName, eventSystemFlags, container, nativeEvent);\n }\n function dispatchUserBlockingUpdate(domEventName, eventSystemFlags, container, nativeEvent) {\n runWithPriority(UserBlockingPriority$1, dispatchEvent.bind(null, domEventName, eventSystemFlags, container, nativeEvent));\n }\n function dispatchEvent(domEventName, eventSystemFlags, targetContainer, nativeEvent) {\n if (!_enabled) return;\n var allowReplay = true;\n // TODO: replaying capture phase events is currently broken\n // because we used to do it during top-level native bubble handlers\n // but now we use different bubble and capture handlers.\n // In eager mode, we attach capture listeners early, so we need\n // to filter them out until we fix the logic to handle them correctly.\n // This could've been outside the flag but I put it inside to reduce risk.\n allowReplay = (eventSystemFlags & IS_CAPTURE_PHASE) === 0;\n if (allowReplay && hasQueuedDiscreteEvents() && isReplayableDiscreteEvent(domEventName)) {\n // If we already have a queue of discrete events, and this is another discrete\n // event, then we can't dispatch it regardless of its target, since they\n // need to dispatch in order.\n queueDiscreteEvent(null, domEventName, eventSystemFlags, targetContainer, nativeEvent);\n return;\n }\n var blockedOn = attemptToDispatchEvent(domEventName, eventSystemFlags, targetContainer, nativeEvent);\n if (blockedOn === null) {\n // We successfully dispatched this event.\n if (allowReplay) clearIfContinuousEvent(domEventName, nativeEvent);\n return;\n }\n if (allowReplay) {\n if (isReplayableDiscreteEvent(domEventName)) {\n // This this to be replayed later once the target is available.\n queueDiscreteEvent(blockedOn, domEventName, eventSystemFlags, targetContainer, nativeEvent);\n return;\n }\n if (queueIfContinuousEvent(blockedOn, domEventName, eventSystemFlags, targetContainer, nativeEvent)) return;\n // We need to clear only if we didn't queue because\n // queueing is accummulative.\n clearIfContinuousEvent(domEventName, nativeEvent);\n } // This is not replayable so we'll invoke it but without a target,\n // in case the event system needs to trace it.\n dispatchEventForPluginEventSystem(domEventName, eventSystemFlags, nativeEvent, null, targetContainer);\n } // Attempt dispatching an event. Returns a SuspenseInstance or Container if it's blocked.\n function attemptToDispatchEvent(domEventName, eventSystemFlags, targetContainer, nativeEvent) {\n // TODO: Warn if _enabled is false.\n var nativeEventTarget = getEventTarget(nativeEvent);\n var targetInst = getClosestInstanceFromNode(nativeEventTarget);\n if (targetInst !== null) {\n var nearestMounted = getNearestMountedFiber(targetInst);\n if (nearestMounted === null) // This tree has been unmounted already. Dispatch without a target.\n targetInst = null;\n else {\n var tag = nearestMounted.tag;\n if (tag === SuspenseComponent) {\n var instance = getSuspenseInstanceFromFiber(nearestMounted);\n if (instance !== null) // Queue the event to be replayed later. Abort dispatching since we\n // don't want this event dispatched twice through the event system.\n // TODO: If this is the first discrete event in the queue. Schedule an increased\n // priority for this boundary.\n return instance;\n // This shouldn't happen, something went wrong but to avoid blocking\n // the whole system, dispatch the event without a target.\n // TODO: Warn.\n targetInst = null;\n } else if (tag === HostRoot) {\n var root = nearestMounted.stateNode;\n if (root.hydrate) // If this happens during a replay something went wrong and it might block\n // the whole system.\n return getContainerFromFiber(nearestMounted);\n targetInst = null;\n } else if (nearestMounted !== targetInst) // If we get an event (ex: img onload) before committing that\n // component's mount, ignore it for now (that is, treat it as if it was an\n // event on a non-React tree). We might also consider queueing events and\n // dispatching them after the mount.\n targetInst = null;\n }\n }\n dispatchEventForPluginEventSystem(domEventName, eventSystemFlags, nativeEvent, targetInst, targetContainer); // We're not blocked on anything.\n return null;\n }\n function addEventBubbleListener(target, eventType, listener) {\n target.addEventListener(eventType, listener, false);\n return listener;\n }\n function addEventCaptureListener(target, eventType, listener) {\n target.addEventListener(eventType, listener, true);\n return listener;\n }\n function addEventCaptureListenerWithPassiveFlag(target, eventType, listener, passive) {\n target.addEventListener(eventType, listener, {\n capture: true,\n passive: passive\n });\n return listener;\n }\n function addEventBubbleListenerWithPassiveFlag(target, eventType, listener, passive) {\n target.addEventListener(eventType, listener, {\n passive: passive\n });\n return listener;\n }\n /**\n * These variables store information about text content of a target node,\n * allowing comparison of content before and after a given event.\n *\n * Identify the node where selection currently begins, then observe\n * both its text content and its current position in the DOM. Since the\n * browser may natively replace the target node during composition, we can\n * use its position to find its replacement.\n *\n *\n */ var root1 = null;\n var startText = null;\n var fallbackText = null;\n function initialize(nativeEventTarget) {\n root1 = nativeEventTarget;\n startText = getText();\n return true;\n }\n function reset() {\n root1 = null;\n startText = null;\n fallbackText = null;\n }\n function getData() {\n if (fallbackText) return fallbackText;\n var start;\n var startValue = startText;\n var startLength = startValue.length;\n var end;\n var endValue = getText();\n var endLength = endValue.length;\n for(start = 0; start < startLength; start++){\n if (startValue[start] !== endValue[start]) break;\n }\n var minEnd = startLength - start;\n for(end = 1; end <= minEnd; end++){\n if (startValue[startLength - end] !== endValue[endLength - end]) break;\n }\n var sliceTail = end > 1 ? 1 - end : undefined;\n fallbackText = endValue.slice(start, sliceTail);\n return fallbackText;\n }\n function getText() {\n if ('value' in root1) return root1.value;\n return root1.textContent;\n }\n /**\n * `charCode` represents the actual \"character code\" and is safe to use with\n * `String.fromCharCode`. As such, only keys that correspond to printable\n * characters produce a valid `charCode`, the only exception to this is Enter.\n * The Tab-key is considered non-printable and does not have a `charCode`,\n * presumably because it does not produce a tab-character in browsers.\n *\n * @param {object} nativeEvent Native browser event.\n * @return {number} Normalized `charCode` property.\n */ function getEventCharCode(nativeEvent) {\n var charCode;\n var keyCode = nativeEvent.keyCode;\n if ('charCode' in nativeEvent) {\n charCode = nativeEvent.charCode; // FF does not set `charCode` for the Enter-key, check against `keyCode`.\n if (charCode === 0 && keyCode === 13) charCode = 13;\n } else // IE8 does not implement `charCode`, but `keyCode` has the correct value.\n charCode = keyCode;\n // IE and Edge (on Windows) and Chrome / Safari (on Windows and Linux)\n // report Enter as charCode 10 when ctrl is pressed.\n if (charCode === 10) charCode = 13;\n // Some non-printable keys are reported in `charCode`/`keyCode`, discard them.\n // Must not discard the (non-)printable Enter-key.\n if (charCode >= 32 || charCode === 13) return charCode;\n return 0;\n }\n function functionThatReturnsTrue() {\n return true;\n }\n function functionThatReturnsFalse() {\n return false;\n } // This is intentionally a factory so that we have different returned constructors.\n // If we had a single constructor, it would be megamorphic and engines would deopt.\n function createSyntheticEvent(Interface) {\n /**\n * Synthetic events are dispatched by event plugins, typically in response to a\n * top-level event delegation handler.\n *\n * These systems should generally use pooling to reduce the frequency of garbage\n * collection. The system should check `isPersistent` to determine whether the\n * event should be released into the pool after being dispatched. Users that\n * need a persisted event should invoke `persist`.\n *\n * Synthetic events (and subclasses) implement the DOM Level 3 Events API by\n * normalizing browser quirks. Subclasses do not necessarily have to implement a\n * DOM interface; custom application-specific events can also subclass this.\n */ function SyntheticBaseEvent(reactName, reactEventType, targetInst, nativeEvent, nativeEventTarget) {\n this._reactName = reactName;\n this._targetInst = targetInst;\n this.type = reactEventType;\n this.nativeEvent = nativeEvent;\n this.target = nativeEventTarget;\n this.currentTarget = null;\n for(var _propName in Interface){\n if (!Interface.hasOwnProperty(_propName)) continue;\n var normalize = Interface[_propName];\n if (normalize) this[_propName] = normalize(nativeEvent);\n else this[_propName] = nativeEvent[_propName];\n }\n var defaultPrevented = nativeEvent.defaultPrevented != null ? nativeEvent.defaultPrevented : nativeEvent.returnValue === false;\n if (defaultPrevented) this.isDefaultPrevented = functionThatReturnsTrue;\n else this.isDefaultPrevented = functionThatReturnsFalse;\n this.isPropagationStopped = functionThatReturnsFalse;\n return this;\n }\n _assign(SyntheticBaseEvent.prototype, {\n preventDefault: function() {\n this.defaultPrevented = true;\n var event = this.nativeEvent;\n if (!event) return;\n if (event.preventDefault) event.preventDefault(); // $FlowFixMe - flow is not aware of `unknown` in IE\n else if (typeof event.returnValue !== 'unknown') event.returnValue = false;\n this.isDefaultPrevented = functionThatReturnsTrue;\n },\n stopPropagation: function() {\n var event = this.nativeEvent;\n if (!event) return;\n if (event.stopPropagation) event.stopPropagation(); // $FlowFixMe - flow is not aware of `unknown` in IE\n else if (typeof event.cancelBubble !== 'unknown') // The ChangeEventPlugin registers a \"propertychange\" event for\n // IE. This event does not support bubbling or cancelling, and\n // any references to cancelBubble throw \"Member not found\". A\n // typeof check of \"unknown\" circumvents this issue (and is also\n // IE specific).\n event.cancelBubble = true;\n this.isPropagationStopped = functionThatReturnsTrue;\n },\n /**\n * We release all dispatched `SyntheticEvent`s after each event loop, adding\n * them back into the pool. This allows a way to hold onto a reference that\n * won't be added back into the pool.\n */ persist: function() {\n },\n /**\n * Checks if this event should be released back into the pool.\n *\n * @return {boolean} True if this should not be released, false otherwise.\n */ isPersistent: functionThatReturnsTrue\n });\n return SyntheticBaseEvent;\n }\n /**\n * @interface Event\n * @see http://www.w3.org/TR/DOM-Level-3-Events/\n */ var EventInterface = {\n eventPhase: 0,\n bubbles: 0,\n cancelable: 0,\n timeStamp: function(event) {\n return event.timeStamp || Date.now();\n },\n defaultPrevented: 0,\n isTrusted: 0\n };\n var SyntheticEvent = createSyntheticEvent(EventInterface);\n var UIEventInterface = _assign({\n }, EventInterface, {\n view: 0,\n detail: 0\n });\n var SyntheticUIEvent = createSyntheticEvent(UIEventInterface);\n var lastMovementX;\n var lastMovementY;\n var lastMouseEvent;\n function updateMouseMovementPolyfillState(event) {\n if (event !== lastMouseEvent) {\n if (lastMouseEvent && event.type === 'mousemove') {\n lastMovementX = event.screenX - lastMouseEvent.screenX;\n lastMovementY = event.screenY - lastMouseEvent.screenY;\n } else {\n lastMovementX = 0;\n lastMovementY = 0;\n }\n lastMouseEvent = event;\n }\n }\n /**\n * @interface MouseEvent\n * @see http://www.w3.org/TR/DOM-Level-3-Events/\n */ var MouseEventInterface = _assign({\n }, UIEventInterface, {\n screenX: 0,\n screenY: 0,\n clientX: 0,\n clientY: 0,\n pageX: 0,\n pageY: 0,\n ctrlKey: 0,\n shiftKey: 0,\n altKey: 0,\n metaKey: 0,\n getModifierState: getEventModifierState,\n button: 0,\n buttons: 0,\n relatedTarget: function(event) {\n if (event.relatedTarget === undefined) return event.fromElement === event.srcElement ? event.toElement : event.fromElement;\n return event.relatedTarget;\n },\n movementX: function(event) {\n if ('movementX' in event) return event.movementX;\n updateMouseMovementPolyfillState(event);\n return lastMovementX;\n },\n movementY: function(event) {\n if ('movementY' in event) return event.movementY;\n // Don't need to call updateMouseMovementPolyfillState() here\n // because it's guaranteed to have already run when movementX\n // was copied.\n return lastMovementY;\n }\n });\n var SyntheticMouseEvent = createSyntheticEvent(MouseEventInterface);\n /**\n * @interface DragEvent\n * @see http://www.w3.org/TR/DOM-Level-3-Events/\n */ var DragEventInterface = _assign({\n }, MouseEventInterface, {\n dataTransfer: 0\n });\n var SyntheticDragEvent = createSyntheticEvent(DragEventInterface);\n /**\n * @interface FocusEvent\n * @see http://www.w3.org/TR/DOM-Level-3-Events/\n */ var FocusEventInterface = _assign({\n }, UIEventInterface, {\n relatedTarget: 0\n });\n var SyntheticFocusEvent = createSyntheticEvent(FocusEventInterface);\n /**\n * @interface Event\n * @see http://www.w3.org/TR/css3-animations/#AnimationEvent-interface\n * @see https://developer.mozilla.org/en-US/docs/Web/API/AnimationEvent\n */ var AnimationEventInterface = _assign({\n }, EventInterface, {\n animationName: 0,\n elapsedTime: 0,\n pseudoElement: 0\n });\n var SyntheticAnimationEvent = createSyntheticEvent(AnimationEventInterface);\n /**\n * @interface Event\n * @see http://www.w3.org/TR/clipboard-apis/\n */ var ClipboardEventInterface = _assign({\n }, EventInterface, {\n clipboardData: function(event) {\n return 'clipboardData' in event ? event.clipboardData : window.clipboardData;\n }\n });\n var SyntheticClipboardEvent = createSyntheticEvent(ClipboardEventInterface);\n /**\n * @interface Event\n * @see http://www.w3.org/TR/DOM-Level-3-Events/#events-compositionevents\n */ var CompositionEventInterface = _assign({\n }, EventInterface, {\n data: 0\n });\n var SyntheticCompositionEvent = createSyntheticEvent(CompositionEventInterface);\n /**\n * @interface Event\n * @see http://www.w3.org/TR/2013/WD-DOM-Level-3-Events-20131105\n * /#events-inputevents\n */ // Happens to share the same list for now.\n var SyntheticInputEvent = SyntheticCompositionEvent;\n /**\n * Normalization of deprecated HTML5 `key` values\n * @see https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent#Key_names\n */ var normalizeKey = {\n Esc: 'Escape',\n Spacebar: ' ',\n Left: 'ArrowLeft',\n Up: 'ArrowUp',\n Right: 'ArrowRight',\n Down: 'ArrowDown',\n Del: 'Delete',\n Win: 'OS',\n Menu: 'ContextMenu',\n Apps: 'ContextMenu',\n Scroll: 'ScrollLock',\n MozPrintableKey: 'Unidentified'\n };\n /**\n * Translation from legacy `keyCode` to HTML5 `key`\n * Only special keys supported, all others depend on keyboard layout or browser\n * @see https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent#Key_names\n */ var translateToKey = {\n '8': 'Backspace',\n '9': 'Tab',\n '12': 'Clear',\n '13': 'Enter',\n '16': 'Shift',\n '17': 'Control',\n '18': 'Alt',\n '19': 'Pause',\n '20': 'CapsLock',\n '27': 'Escape',\n '32': ' ',\n '33': 'PageUp',\n '34': 'PageDown',\n '35': 'End',\n '36': 'Home',\n '37': 'ArrowLeft',\n '38': 'ArrowUp',\n '39': 'ArrowRight',\n '40': 'ArrowDown',\n '45': 'Insert',\n '46': 'Delete',\n '112': 'F1',\n '113': 'F2',\n '114': 'F3',\n '115': 'F4',\n '116': 'F5',\n '117': 'F6',\n '118': 'F7',\n '119': 'F8',\n '120': 'F9',\n '121': 'F10',\n '122': 'F11',\n '123': 'F12',\n '144': 'NumLock',\n '145': 'ScrollLock',\n '224': 'Meta'\n };\n /**\n * @param {object} nativeEvent Native browser event.\n * @return {string} Normalized `key` property.\n */ function getEventKey(nativeEvent) {\n if (nativeEvent.key) {\n // Normalize inconsistent values reported by browsers due to\n // implementations of a working draft specification.\n // FireFox implements `key` but returns `MozPrintableKey` for all\n // printable characters (normalized to `Unidentified`), ignore it.\n var key = normalizeKey[nativeEvent.key] || nativeEvent.key;\n if (key !== 'Unidentified') return key;\n } // Browser does not implement `key`, polyfill as much of it as we can.\n if (nativeEvent.type === 'keypress') {\n var charCode = getEventCharCode(nativeEvent); // The enter-key is technically both printable and non-printable and can\n // thus be captured by `keypress`, no other non-printable key should.\n return charCode === 13 ? 'Enter' : String.fromCharCode(charCode);\n }\n if (nativeEvent.type === 'keydown' || nativeEvent.type === 'keyup') // While user keyboard layout determines the actual meaning of each\n // `keyCode` value, almost all function keys have a universal value.\n return translateToKey[nativeEvent.keyCode] || 'Unidentified';\n return '';\n }\n /**\n * Translation from modifier key to the associated property in the event.\n * @see http://www.w3.org/TR/DOM-Level-3-Events/#keys-Modifiers\n */ var modifierKeyToProp = {\n Alt: 'altKey',\n Control: 'ctrlKey',\n Meta: 'metaKey',\n Shift: 'shiftKey'\n }; // Older browsers (Safari <= 10, iOS Safari <= 10.2) do not support\n // getModifierState. If getModifierState is not supported, we map it to a set of\n // modifier keys exposed by the event. In this case, Lock-keys are not supported.\n function modifierStateGetter(keyArg) {\n var syntheticEvent = this;\n var nativeEvent = syntheticEvent.nativeEvent;\n if (nativeEvent.getModifierState) return nativeEvent.getModifierState(keyArg);\n var keyProp = modifierKeyToProp[keyArg];\n return keyProp ? !!nativeEvent[keyProp] : false;\n }\n function getEventModifierState(nativeEvent) {\n return modifierStateGetter;\n }\n /**\n * @interface KeyboardEvent\n * @see http://www.w3.org/TR/DOM-Level-3-Events/\n */ var KeyboardEventInterface = _assign({\n }, UIEventInterface, {\n key: getEventKey,\n code: 0,\n location: 0,\n ctrlKey: 0,\n shiftKey: 0,\n altKey: 0,\n metaKey: 0,\n repeat: 0,\n locale: 0,\n getModifierState: getEventModifierState,\n // Legacy Interface\n charCode: function(event) {\n // `charCode` is the result of a KeyPress event and represents the value of\n // the actual printable character.\n // KeyPress is deprecated, but its replacement is not yet final and not\n // implemented in any major browser. Only KeyPress has charCode.\n if (event.type === 'keypress') return getEventCharCode(event);\n return 0;\n },\n keyCode: function(event) {\n // `keyCode` is the result of a KeyDown/Up event and represents the value of\n // physical keyboard key.\n // The actual meaning of the value depends on the users' keyboard layout\n // which cannot be detected. Assuming that it is a US keyboard layout\n // provides a surprisingly accurate mapping for US and European users.\n // Due to this, it is left to the user to implement at this time.\n if (event.type === 'keydown' || event.type === 'keyup') return event.keyCode;\n return 0;\n },\n which: function(event) {\n // `which` is an alias for either `keyCode` or `charCode` depending on the\n // type of the event.\n if (event.type === 'keypress') return getEventCharCode(event);\n if (event.type === 'keydown' || event.type === 'keyup') return event.keyCode;\n return 0;\n }\n });\n var SyntheticKeyboardEvent = createSyntheticEvent(KeyboardEventInterface);\n /**\n * @interface PointerEvent\n * @see http://www.w3.org/TR/pointerevents/\n */ var PointerEventInterface = _assign({\n }, MouseEventInterface, {\n pointerId: 0,\n width: 0,\n height: 0,\n pressure: 0,\n tangentialPressure: 0,\n tiltX: 0,\n tiltY: 0,\n twist: 0,\n pointerType: 0,\n isPrimary: 0\n });\n var SyntheticPointerEvent = createSyntheticEvent(PointerEventInterface);\n /**\n * @interface TouchEvent\n * @see http://www.w3.org/TR/touch-events/\n */ var TouchEventInterface = _assign({\n }, UIEventInterface, {\n touches: 0,\n targetTouches: 0,\n changedTouches: 0,\n altKey: 0,\n metaKey: 0,\n ctrlKey: 0,\n shiftKey: 0,\n getModifierState: getEventModifierState\n });\n var SyntheticTouchEvent = createSyntheticEvent(TouchEventInterface);\n /**\n * @interface Event\n * @see http://www.w3.org/TR/2009/WD-css3-transitions-20090320/#transition-events-\n * @see https://developer.mozilla.org/en-US/docs/Web/API/TransitionEvent\n */ var TransitionEventInterface = _assign({\n }, EventInterface, {\n propertyName: 0,\n elapsedTime: 0,\n pseudoElement: 0\n });\n var SyntheticTransitionEvent = createSyntheticEvent(TransitionEventInterface);\n /**\n * @interface WheelEvent\n * @see http://www.w3.org/TR/DOM-Level-3-Events/\n */ var WheelEventInterface = _assign({\n }, MouseEventInterface, {\n deltaX: function(event) {\n return 'deltaX' in event ? event.deltaX : 'wheelDeltaX' in event ? -event.wheelDeltaX : 0;\n },\n deltaY: function(event) {\n return 'deltaY' in event ? event.deltaY : 'wheelDeltaY' in event ? -event.wheelDeltaY : 'wheelDelta' in event ? -event.wheelDelta : 0;\n },\n deltaZ: 0,\n // Browsers without \"deltaMode\" is reporting in raw wheel delta where one\n // notch on the scroll is always +/- 120, roughly equivalent to pixels.\n // A good approximation of DOM_DELTA_LINE (1) is 5% of viewport size or\n // ~40 pixels, for DOM_DELTA_SCREEN (2) it is 87.5% of viewport size.\n deltaMode: 0\n });\n var SyntheticWheelEvent = createSyntheticEvent(WheelEventInterface);\n var END_KEYCODES = [\n 9,\n 13,\n 27,\n 32\n ]; // Tab, Return, Esc, Space\n var START_KEYCODE = 229;\n var canUseCompositionEvent = canUseDOM && 'CompositionEvent' in window;\n var documentMode = null;\n if (canUseDOM && 'documentMode' in document) documentMode = document.documentMode;\n // Webkit offers a very useful `textInput` event that can be used to\n // directly represent `beforeInput`. The IE `textinput` event is not as\n // useful, so we don't use it.\n var canUseTextInputEvent = canUseDOM && 'TextEvent' in window && !documentMode; // In IE9+, we have access to composition events, but the data supplied\n // by the native compositionend event may be incorrect. Japanese ideographic\n // spaces, for instance (\\u3000) are not recorded correctly.\n var useFallbackCompositionData = canUseDOM && (!canUseCompositionEvent || documentMode && documentMode > 8 && documentMode <= 11);\n var SPACEBAR_CODE = 32;\n var SPACEBAR_CHAR = String.fromCharCode(SPACEBAR_CODE);\n function registerEvents() {\n registerTwoPhaseEvent('onBeforeInput', [\n 'compositionend',\n 'keypress',\n 'textInput',\n 'paste'\n ]);\n registerTwoPhaseEvent('onCompositionEnd', [\n 'compositionend',\n 'focusout',\n 'keydown',\n 'keypress',\n 'keyup',\n 'mousedown'\n ]);\n registerTwoPhaseEvent('onCompositionStart', [\n 'compositionstart',\n 'focusout',\n 'keydown',\n 'keypress',\n 'keyup',\n 'mousedown'\n ]);\n registerTwoPhaseEvent('onCompositionUpdate', [\n 'compositionupdate',\n 'focusout',\n 'keydown',\n 'keypress',\n 'keyup',\n 'mousedown'\n ]);\n } // Track whether we've ever handled a keypress on the space key.\n var hasSpaceKeypress = false;\n /**\n * Return whether a native keypress event is assumed to be a command.\n * This is required because Firefox fires `keypress` events for key commands\n * (cut, copy, select-all, etc.) even though no character is inserted.\n */ function isKeypressCommand(nativeEvent) {\n return (nativeEvent.ctrlKey || nativeEvent.altKey || nativeEvent.metaKey) && !(nativeEvent.ctrlKey && nativeEvent.altKey);\n }\n /**\n * Translate native top level events into event types.\n */ function getCompositionEventType(domEventName) {\n switch(domEventName){\n case 'compositionstart':\n return 'onCompositionStart';\n case 'compositionend':\n return 'onCompositionEnd';\n case 'compositionupdate':\n return 'onCompositionUpdate';\n }\n }\n /**\n * Does our fallback best-guess model think this event signifies that\n * composition has begun?\n */ function isFallbackCompositionStart(domEventName, nativeEvent) {\n return domEventName === 'keydown' && nativeEvent.keyCode === START_KEYCODE;\n }\n /**\n * Does our fallback mode think that this event is the end of composition?\n */ function isFallbackCompositionEnd(domEventName, nativeEvent) {\n switch(domEventName){\n case 'keyup':\n // Command keys insert or clear IME input.\n return END_KEYCODES.indexOf(nativeEvent.keyCode) !== -1;\n case 'keydown':\n // Expect IME keyCode on each keydown. If we get any other\n // code we must have exited earlier.\n return nativeEvent.keyCode !== START_KEYCODE;\n case 'keypress':\n case 'mousedown':\n case 'focusout':\n // Events are not possible without cancelling IME.\n return true;\n default:\n return false;\n }\n }\n /**\n * Google Input Tools provides composition data via a CustomEvent,\n * with the `data` property populated in the `detail` object. If this\n * is available on the event object, use it. If not, this is a plain\n * composition event and we have nothing special to extract.\n *\n * @param {object} nativeEvent\n * @return {?string}\n */ function getDataFromCustomEvent(nativeEvent) {\n var detail = nativeEvent.detail;\n if (typeof detail === 'object' && 'data' in detail) return detail.data;\n return null;\n }\n /**\n * Check if a composition event was triggered by Korean IME.\n * Our fallback mode does not work well with IE's Korean IME,\n * so just use native composition events when Korean IME is used.\n * Although CompositionEvent.locale property is deprecated,\n * it is available in IE, where our fallback mode is enabled.\n *\n * @param {object} nativeEvent\n * @return {boolean}\n */ function isUsingKoreanIME(nativeEvent) {\n return nativeEvent.locale === 'ko';\n } // Track the current IME composition status, if any.\n var isComposing = false;\n /**\n * @return {?object} A SyntheticCompositionEvent.\n */ function extractCompositionEvent(dispatchQueue, domEventName, targetInst, nativeEvent, nativeEventTarget) {\n var eventType;\n var fallbackData;\n if (canUseCompositionEvent) eventType = getCompositionEventType(domEventName);\n else if (!isComposing) {\n if (isFallbackCompositionStart(domEventName, nativeEvent)) eventType = 'onCompositionStart';\n } else if (isFallbackCompositionEnd(domEventName, nativeEvent)) eventType = 'onCompositionEnd';\n if (!eventType) return null;\n if (useFallbackCompositionData && !isUsingKoreanIME(nativeEvent)) {\n // The current composition is stored statically and must not be\n // overwritten while composition continues.\n if (!isComposing && eventType === 'onCompositionStart') isComposing = initialize(nativeEventTarget);\n else if (eventType === 'onCompositionEnd') {\n if (isComposing) fallbackData = getData();\n }\n }\n var listeners = accumulateTwoPhaseListeners(targetInst, eventType);\n if (listeners.length > 0) {\n var event = new SyntheticCompositionEvent(eventType, domEventName, null, nativeEvent, nativeEventTarget);\n dispatchQueue.push({\n event: event,\n listeners: listeners\n });\n if (fallbackData) // Inject data generated from fallback path into the synthetic event.\n // This matches the property of native CompositionEventInterface.\n event.data = fallbackData;\n else {\n var customData = getDataFromCustomEvent(nativeEvent);\n if (customData !== null) event.data = customData;\n }\n }\n }\n function getNativeBeforeInputChars(domEventName, nativeEvent) {\n switch(domEventName){\n case 'compositionend':\n return getDataFromCustomEvent(nativeEvent);\n case 'keypress':\n /**\n * If native `textInput` events are available, our goal is to make\n * use of them. However, there is a special case: the spacebar key.\n * In Webkit, preventing default on a spacebar `textInput` event\n * cancels character insertion, but it *also* causes the browser\n * to fall back to its default spacebar behavior of scrolling the\n * page.\n *\n * Tracking at:\n * https://code.google.com/p/chromium/issues/detail?id=355103\n *\n * To avoid this issue, use the keypress event as if no `textInput`\n * event is available.\n */ var which = nativeEvent.which;\n if (which !== SPACEBAR_CODE) return null;\n hasSpaceKeypress = true;\n return SPACEBAR_CHAR;\n case 'textInput':\n // Record the characters to be added to the DOM.\n var chars = nativeEvent.data; // If it's a spacebar character, assume that we have already handled\n // it at the keypress level and bail immediately. Android Chrome\n // doesn't give us keycodes, so we need to ignore it.\n if (chars === SPACEBAR_CHAR && hasSpaceKeypress) return null;\n return chars;\n default:\n // For other native event types, do nothing.\n return null;\n }\n }\n /**\n * For browsers that do not provide the `textInput` event, extract the\n * appropriate string to use for SyntheticInputEvent.\n */ function getFallbackBeforeInputChars(domEventName, nativeEvent) {\n // If we are currently composing (IME) and using a fallback to do so,\n // try to extract the composed characters from the fallback object.\n // If composition event is available, we extract a string only at\n // compositionevent, otherwise extract it at fallback events.\n if (isComposing) {\n if (domEventName === 'compositionend' || !canUseCompositionEvent && isFallbackCompositionEnd(domEventName, nativeEvent)) {\n var chars = getData();\n reset();\n isComposing = false;\n return chars;\n }\n return null;\n }\n switch(domEventName){\n case 'paste':\n // If a paste event occurs after a keypress, throw out the input\n // chars. Paste events should not lead to BeforeInput events.\n return null;\n case 'keypress':\n /**\n * As of v27, Firefox may fire keypress events even when no character\n * will be inserted. A few possibilities:\n *\n * - `which` is `0`. Arrow keys, Esc key, etc.\n *\n * - `which` is the pressed key code, but no char is available.\n * Ex: 'AltGr + d` in Polish. There is no modified character for\n * this key combination and no character is inserted into the\n * document, but FF fires the keypress for char code `100` anyway.\n * No `input` event will occur.\n *\n * - `which` is the pressed key code, but a command combination is\n * being used. Ex: `Cmd+C`. No character is inserted, and no\n * `input` event will occur.\n */ if (!isKeypressCommand(nativeEvent)) {\n // IE fires the `keypress` event when a user types an emoji via\n // Touch keyboard of Windows. In such a case, the `char` property\n // holds an emoji character like `\\uD83D\\uDE0A`. Because its length\n // is 2, the property `which` does not represent an emoji correctly.\n // In such a case, we directly return the `char` property instead of\n // using `which`.\n if (nativeEvent.char && nativeEvent.char.length > 1) return nativeEvent.char;\n else if (nativeEvent.which) return String.fromCharCode(nativeEvent.which);\n }\n return null;\n case 'compositionend':\n return useFallbackCompositionData && !isUsingKoreanIME(nativeEvent) ? null : nativeEvent.data;\n default:\n return null;\n }\n }\n /**\n * Extract a SyntheticInputEvent for `beforeInput`, based on either native\n * `textInput` or fallback behavior.\n *\n * @return {?object} A SyntheticInputEvent.\n */ function extractBeforeInputEvent(dispatchQueue, domEventName, targetInst, nativeEvent, nativeEventTarget) {\n var chars;\n if (canUseTextInputEvent) chars = getNativeBeforeInputChars(domEventName, nativeEvent);\n else chars = getFallbackBeforeInputChars(domEventName, nativeEvent);\n // If no characters are being inserted, no BeforeInput event should\n // be fired.\n if (!chars) return null;\n var listeners = accumulateTwoPhaseListeners(targetInst, 'onBeforeInput');\n if (listeners.length > 0) {\n var event = new SyntheticInputEvent('onBeforeInput', 'beforeinput', null, nativeEvent, nativeEventTarget);\n dispatchQueue.push({\n event: event,\n listeners: listeners\n });\n event.data = chars;\n }\n }\n /**\n * Create an `onBeforeInput` event to match\n * http://www.w3.org/TR/2013/WD-DOM-Level-3-Events-20131105/#events-inputevents.\n *\n * This event plugin is based on the native `textInput` event\n * available in Chrome, Safari, Opera, and IE. This event fires after\n * `onKeyPress` and `onCompositionEnd`, but before `onInput`.\n *\n * `beforeInput` is spec'd but not implemented in any browsers, and\n * the `input` event does not provide any useful information about what has\n * actually been added, contrary to the spec. Thus, `textInput` is the best\n * available event to identify the characters that have actually been inserted\n * into the target node.\n *\n * This plugin is also responsible for emitting `composition` events, thus\n * allowing us to share composition fallback code for both `beforeInput` and\n * `composition` event types.\n */ function extractEvents(dispatchQueue, domEventName, targetInst, nativeEvent, nativeEventTarget, eventSystemFlags, targetContainer) {\n extractCompositionEvent(dispatchQueue, domEventName, targetInst, nativeEvent, nativeEventTarget);\n extractBeforeInputEvent(dispatchQueue, domEventName, targetInst, nativeEvent, nativeEventTarget);\n }\n /**\n * @see http://www.whatwg.org/specs/web-apps/current-work/multipage/the-input-element.html#input-type-attr-summary\n */ var supportedInputTypes = {\n color: true,\n date: true,\n datetime: true,\n 'datetime-local': true,\n email: true,\n month: true,\n number: true,\n password: true,\n range: true,\n search: true,\n tel: true,\n text: true,\n time: true,\n url: true,\n week: true\n };\n function isTextInputElement(elem) {\n var nodeName = elem && elem.nodeName && elem.nodeName.toLowerCase();\n if (nodeName === 'input') return !!supportedInputTypes[elem.type];\n if (nodeName === 'textarea') return true;\n return false;\n }\n /**\n * Checks if an event is supported in the current execution environment.\n *\n * NOTE: This will not work correctly for non-generic events such as `change`,\n * `reset`, `load`, `error`, and `select`.\n *\n * Borrows from Modernizr.\n *\n * @param {string} eventNameSuffix Event name, e.g. \"click\".\n * @return {boolean} True if the event is supported.\n * @internal\n * @license Modernizr 3.0.0pre (Custom Build) | MIT\n */ function isEventSupported(eventNameSuffix) {\n if (!canUseDOM) return false;\n var eventName = 'on' + eventNameSuffix;\n var isSupported = eventName in document;\n if (!isSupported) {\n var element = document.createElement('div');\n element.setAttribute(eventName, 'return;');\n isSupported = typeof element[eventName] === 'function';\n }\n return isSupported;\n }\n function registerEvents$1() {\n registerTwoPhaseEvent('onChange', [\n 'change',\n 'click',\n 'focusin',\n 'focusout',\n 'input',\n 'keydown',\n 'keyup',\n 'selectionchange'\n ]);\n }\n function createAndAccumulateChangeEvent(dispatchQueue, inst, nativeEvent, target) {\n // Flag this event loop as needing state restore.\n enqueueStateRestore(target);\n var listeners = accumulateTwoPhaseListeners(inst, 'onChange');\n if (listeners.length > 0) {\n var event = new SyntheticEvent('onChange', 'change', null, nativeEvent, target);\n dispatchQueue.push({\n event: event,\n listeners: listeners\n });\n }\n }\n /**\n * For IE shims\n */ var activeElement = null;\n var activeElementInst = null;\n /**\n * SECTION: handle `change` event\n */ function shouldUseChangeEvent(elem) {\n var nodeName = elem.nodeName && elem.nodeName.toLowerCase();\n return nodeName === 'select' || nodeName === 'input' && elem.type === 'file';\n }\n function manualDispatchChangeEvent(nativeEvent) {\n var dispatchQueue = [];\n createAndAccumulateChangeEvent(dispatchQueue, activeElementInst, nativeEvent, getEventTarget(nativeEvent)); // If change and propertychange bubbled, we'd just bind to it like all the\n // other events and have it go through ReactBrowserEventEmitter. Since it\n // doesn't, we manually listen for the events and so we have to enqueue and\n // process the abstract event manually.\n //\n // Batching is necessary here in order to ensure that all event handlers run\n // before the next rerender (including event handlers attached to ancestor\n // elements instead of directly on the input). Without this, controlled\n // components don't work properly in conjunction with event bubbling because\n // the component is rerendered and the value reverted before all the event\n // handlers can run. See https://github.com/facebook/react/issues/708.\n batchedUpdates(runEventInBatch, dispatchQueue);\n }\n function runEventInBatch(dispatchQueue) {\n processDispatchQueue(dispatchQueue, 0);\n }\n function getInstIfValueChanged(targetInst) {\n var targetNode = getNodeFromInstance(targetInst);\n if (updateValueIfChanged(targetNode)) return targetInst;\n }\n function getTargetInstForChangeEvent(domEventName, targetInst) {\n if (domEventName === 'change') return targetInst;\n }\n /**\n * SECTION: handle `input` event\n */ var isInputEventSupported = false;\n if (canUseDOM) // IE9 claims to support the input event but fails to trigger it when\n // deleting text, so we ignore its input events.\n isInputEventSupported = isEventSupported('input') && (!document.documentMode || document.documentMode > 9);\n /**\n * (For IE <=9) Starts tracking propertychange events on the passed-in element\n * and override the value property so that we can distinguish user events from\n * value changes in JS.\n */ function startWatchingForValueChange(target, targetInst) {\n activeElement = target;\n activeElementInst = targetInst;\n activeElement.attachEvent('onpropertychange', handlePropertyChange);\n }\n /**\n * (For IE <=9) Removes the event listeners from the currently-tracked element,\n * if any exists.\n */ function stopWatchingForValueChange() {\n if (!activeElement) return;\n activeElement.detachEvent('onpropertychange', handlePropertyChange);\n activeElement = null;\n activeElementInst = null;\n }\n /**\n * (For IE <=9) Handles a propertychange event, sending a `change` event if\n * the value of the active element has changed.\n */ function handlePropertyChange(nativeEvent) {\n if (nativeEvent.propertyName !== 'value') return;\n if (getInstIfValueChanged(activeElementInst)) manualDispatchChangeEvent(nativeEvent);\n }\n function handleEventsForInputEventPolyfill(domEventName, target, targetInst) {\n if (domEventName === 'focusin') {\n // In IE9, propertychange fires for most input events but is buggy and\n // doesn't fire when text is deleted, but conveniently, selectionchange\n // appears to fire in all of the remaining cases so we catch those and\n // forward the event if the value has changed\n // In either case, we don't want to call the event handler if the value\n // is changed from JS so we redefine a setter for `.value` that updates\n // our activeElementValue variable, allowing us to ignore those changes\n //\n // stopWatching() should be a noop here but we call it just in case we\n // missed a blur event somehow.\n stopWatchingForValueChange();\n startWatchingForValueChange(target, targetInst);\n } else if (domEventName === 'focusout') stopWatchingForValueChange();\n } // For IE8 and IE9.\n function getTargetInstForInputEventPolyfill(domEventName, targetInst) {\n if (domEventName === 'selectionchange' || domEventName === 'keyup' || domEventName === 'keydown') // On the selectionchange event, the target is just document which isn't\n // helpful for us so just check activeElement instead.\n //\n // 99% of the time, keydown and keyup aren't necessary. IE8 fails to fire\n // propertychange on the first input event after setting `value` from a\n // script and fires only keydown, keypress, keyup. Catching keyup usually\n // gets it and catching keydown lets us fire an event for the first\n // keystroke if user does a key repeat (it'll be a little delayed: right\n // before the second keystroke). Other input methods (e.g., paste) seem to\n // fire selectionchange normally.\n return getInstIfValueChanged(activeElementInst);\n }\n /**\n * SECTION: handle `click` event\n */ function shouldUseClickEvent(elem) {\n // Use the `click` event to detect changes to checkbox and radio inputs.\n // This approach works across all browsers, whereas `change` does not fire\n // until `blur` in IE8.\n var nodeName = elem.nodeName;\n return nodeName && nodeName.toLowerCase() === 'input' && (elem.type === 'checkbox' || elem.type === 'radio');\n }\n function getTargetInstForClickEvent(domEventName, targetInst) {\n if (domEventName === 'click') return getInstIfValueChanged(targetInst);\n }\n function getTargetInstForInputOrChangeEvent(domEventName, targetInst) {\n if (domEventName === 'input' || domEventName === 'change') return getInstIfValueChanged(targetInst);\n }\n function handleControlledInputBlur(node) {\n var state = node._wrapperState;\n if (!state || !state.controlled || node.type !== 'number') return;\n // If controlled, assign the value attribute to the current value on blur\n setDefaultValue(node, 'number', node.value);\n }\n /**\n * This plugin creates an `onChange` event that normalizes change events\n * across form elements. This event fires at a time when it's possible to\n * change the element's value without seeing a flicker.\n *\n * Supported elements are:\n * - input (see `isTextInputElement`)\n * - textarea\n * - select\n */ function extractEvents$1(dispatchQueue, domEventName, targetInst, nativeEvent, nativeEventTarget, eventSystemFlags, targetContainer) {\n var targetNode = targetInst ? getNodeFromInstance(targetInst) : window;\n var getTargetInstFunc, handleEventFunc;\n if (shouldUseChangeEvent(targetNode)) getTargetInstFunc = getTargetInstForChangeEvent;\n else if (isTextInputElement(targetNode)) {\n if (isInputEventSupported) getTargetInstFunc = getTargetInstForInputOrChangeEvent;\n else {\n getTargetInstFunc = getTargetInstForInputEventPolyfill;\n handleEventFunc = handleEventsForInputEventPolyfill;\n }\n } else if (shouldUseClickEvent(targetNode)) getTargetInstFunc = getTargetInstForClickEvent;\n if (getTargetInstFunc) {\n var inst = getTargetInstFunc(domEventName, targetInst);\n if (inst) {\n createAndAccumulateChangeEvent(dispatchQueue, inst, nativeEvent, nativeEventTarget);\n return;\n }\n }\n if (handleEventFunc) handleEventFunc(domEventName, targetNode, targetInst);\n // When blurring, set the value attribute for number inputs\n if (domEventName === 'focusout') handleControlledInputBlur(targetNode);\n }\n function registerEvents$2() {\n registerDirectEvent('onMouseEnter', [\n 'mouseout',\n 'mouseover'\n ]);\n registerDirectEvent('onMouseLeave', [\n 'mouseout',\n 'mouseover'\n ]);\n registerDirectEvent('onPointerEnter', [\n 'pointerout',\n 'pointerover'\n ]);\n registerDirectEvent('onPointerLeave', [\n 'pointerout',\n 'pointerover'\n ]);\n }\n /**\n * For almost every interaction we care about, there will be both a top-level\n * `mouseover` and `mouseout` event that occurs. Only use `mouseout` so that\n * we do not extract duplicate events. However, moving the mouse into the\n * browser from outside will not fire a `mouseout` event. In this case, we use\n * the `mouseover` top-level event.\n */ function extractEvents$2(dispatchQueue, domEventName, targetInst, nativeEvent, nativeEventTarget, eventSystemFlags, targetContainer) {\n var isOverEvent = domEventName === 'mouseover' || domEventName === 'pointerover';\n var isOutEvent = domEventName === 'mouseout' || domEventName === 'pointerout';\n if (isOverEvent && (eventSystemFlags & IS_REPLAYED) === 0) {\n // If this is an over event with a target, we might have already dispatched\n // the event in the out event of the other target. If this is replayed,\n // then it's because we couldn't dispatch against this target previously\n // so we have to do it now instead.\n var related = nativeEvent.relatedTarget || nativeEvent.fromElement;\n if (related) {\n // If the related node is managed by React, we can assume that we have\n // already dispatched the corresponding events during its mouseout.\n if (getClosestInstanceFromNode(related) || isContainerMarkedAsRoot(related)) return;\n }\n }\n if (!isOutEvent && !isOverEvent) // Must not be a mouse or pointer in or out - ignoring.\n return;\n var win; // TODO: why is this nullable in the types but we read from it?\n if (nativeEventTarget.window === nativeEventTarget) // `nativeEventTarget` is probably a window object.\n win = nativeEventTarget;\n else {\n // TODO: Figure out why `ownerDocument` is sometimes undefined in IE8.\n var doc = nativeEventTarget.ownerDocument;\n if (doc) win = doc.defaultView || doc.parentWindow;\n else win = window;\n }\n var from;\n var to;\n if (isOutEvent) {\n var _related = nativeEvent.relatedTarget || nativeEvent.toElement;\n from = targetInst;\n to = _related ? getClosestInstanceFromNode(_related) : null;\n if (to !== null) {\n var nearestMounted = getNearestMountedFiber(to);\n if (to !== nearestMounted || to.tag !== HostComponent && to.tag !== HostText) to = null;\n }\n } else {\n // Moving to a node from outside the window.\n from = null;\n to = targetInst;\n }\n if (from === to) // Nothing pertains to our managed components.\n return;\n var SyntheticEventCtor = SyntheticMouseEvent;\n var leaveEventType = 'onMouseLeave';\n var enterEventType = 'onMouseEnter';\n var eventTypePrefix = 'mouse';\n if (domEventName === 'pointerout' || domEventName === 'pointerover') {\n SyntheticEventCtor = SyntheticPointerEvent;\n leaveEventType = 'onPointerLeave';\n enterEventType = 'onPointerEnter';\n eventTypePrefix = 'pointer';\n }\n var fromNode = from == null ? win : getNodeFromInstance(from);\n var toNode = to == null ? win : getNodeFromInstance(to);\n var leave = new SyntheticEventCtor(leaveEventType, eventTypePrefix + 'leave', from, nativeEvent, nativeEventTarget);\n leave.target = fromNode;\n leave.relatedTarget = toNode;\n var enter = null; // We should only process this nativeEvent if we are processing\n // the first ancestor. Next time, we will ignore the event.\n var nativeTargetInst = getClosestInstanceFromNode(nativeEventTarget);\n if (nativeTargetInst === targetInst) {\n var enterEvent = new SyntheticEventCtor(enterEventType, eventTypePrefix + 'enter', to, nativeEvent, nativeEventTarget);\n enterEvent.target = toNode;\n enterEvent.relatedTarget = fromNode;\n enter = enterEvent;\n }\n accumulateEnterLeaveTwoPhaseListeners(dispatchQueue, leave, enter, from, to);\n }\n /**\n * inlined Object.is polyfill to avoid requiring consumers ship their own\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is\n */ function is(x, y) {\n return x === y && (x !== 0 || 1 / x === 1 / y) || x !== x && y !== y // eslint-disable-line no-self-compare\n ;\n }\n var objectIs = typeof Object.is === 'function' ? Object.is : is;\n var hasOwnProperty$2 = Object.prototype.hasOwnProperty;\n /**\n * Performs equality by iterating through keys on an object and returning false\n * when any key has values which are not strictly equal between the arguments.\n * Returns true when the values of all keys are strictly equal.\n */ function shallowEqual(objA, objB) {\n if (objectIs(objA, objB)) return true;\n if (typeof objA !== 'object' || objA === null || typeof objB !== 'object' || objB === null) return false;\n var keysA = Object.keys(objA);\n var keysB = Object.keys(objB);\n if (keysA.length !== keysB.length) return false;\n // Test for A's keys different from B.\n for(var i = 0; i < keysA.length; i++){\n if (!hasOwnProperty$2.call(objB, keysA[i]) || !objectIs(objA[keysA[i]], objB[keysA[i]])) return false;\n }\n return true;\n }\n /**\n * Given any node return the first leaf node without children.\n *\n * @param {DOMElement|DOMTextNode} node\n * @return {DOMElement|DOMTextNode}\n */ function getLeafNode(node) {\n while(node && node.firstChild)node = node.firstChild;\n return node;\n }\n /**\n * Get the next sibling within a container. This will walk up the\n * DOM if a node's siblings have been exhausted.\n *\n * @param {DOMElement|DOMTextNode} node\n * @return {?DOMElement|DOMTextNode}\n */ function getSiblingNode(node) {\n while(node){\n if (node.nextSibling) return node.nextSibling;\n node = node.parentNode;\n }\n }\n /**\n * Get object describing the nodes which contain characters at offset.\n *\n * @param {DOMElement|DOMTextNode} root\n * @param {number} offset\n * @return {?object}\n */ function getNodeForCharacterOffset(root, offset) {\n var node = getLeafNode(root);\n var nodeStart = 0;\n var nodeEnd = 0;\n while(node){\n if (node.nodeType === TEXT_NODE) {\n nodeEnd = nodeStart + node.textContent.length;\n if (nodeStart <= offset && nodeEnd >= offset) return {\n node: node,\n offset: offset - nodeStart\n };\n nodeStart = nodeEnd;\n }\n node = getLeafNode(getSiblingNode(node));\n }\n }\n /**\n * @param {DOMElement} outerNode\n * @return {?object}\n */ function getOffsets(outerNode) {\n var ownerDocument = outerNode.ownerDocument;\n var win = ownerDocument && ownerDocument.defaultView || window;\n var selection = win.getSelection && win.getSelection();\n if (!selection || selection.rangeCount === 0) return null;\n var anchorNode = selection.anchorNode, anchorOffset = selection.anchorOffset, focusNode = selection.focusNode, focusOffset = selection.focusOffset; // In Firefox, anchorNode and focusNode can be \"anonymous divs\", e.g. the\n // up/down buttons on an <input type=\"number\">. Anonymous divs do not seem to\n // expose properties, triggering a \"Permission denied error\" if any of its\n // properties are accessed. The only seemingly possible way to avoid erroring\n // is to access a property that typically works for non-anonymous divs and\n // catch any error that may otherwise arise. See\n // https://bugzilla.mozilla.org/show_bug.cgi?id=208427\n try {\n /* eslint-disable no-unused-expressions */ anchorNode.nodeType;\n focusNode.nodeType;\n /* eslint-enable no-unused-expressions */ } catch (e) {\n return null;\n }\n return getModernOffsetsFromPoints(outerNode, anchorNode, anchorOffset, focusNode, focusOffset);\n }\n /**\n * Returns {start, end} where `start` is the character/codepoint index of\n * (anchorNode, anchorOffset) within the textContent of `outerNode`, and\n * `end` is the index of (focusNode, focusOffset).\n *\n * Returns null if you pass in garbage input but we should probably just crash.\n *\n * Exported only for testing.\n */ function getModernOffsetsFromPoints(outerNode, anchorNode, anchorOffset, focusNode, focusOffset) {\n var length = 0;\n var start = -1;\n var end = -1;\n var indexWithinAnchor = 0;\n var indexWithinFocus = 0;\n var node = outerNode;\n var parentNode = null;\n outer: while(true){\n var next = null;\n while(true){\n if (node === anchorNode && (anchorOffset === 0 || node.nodeType === TEXT_NODE)) start = length + anchorOffset;\n if (node === focusNode && (focusOffset === 0 || node.nodeType === TEXT_NODE)) end = length + focusOffset;\n if (node.nodeType === TEXT_NODE) length += node.nodeValue.length;\n if ((next = node.firstChild) === null) break;\n // Moving from `node` to its first child `next`.\n parentNode = node;\n node = next;\n }\n while(true){\n if (node === outerNode) break outer;\n if (parentNode === anchorNode && ++indexWithinAnchor === anchorOffset) start = length;\n if (parentNode === focusNode && ++indexWithinFocus === focusOffset) end = length;\n if ((next = node.nextSibling) !== null) break;\n node = parentNode;\n parentNode = node.parentNode;\n } // Moving from `node` to its next sibling `next`.\n node = next;\n }\n if (start === -1 || end === -1) // This should never happen. (Would happen if the anchor/focus nodes aren't\n // actually inside the passed-in node.)\n return null;\n return {\n start: start,\n end: end\n };\n }\n /**\n * In modern non-IE browsers, we can support both forward and backward\n * selections.\n *\n * Note: IE10+ supports the Selection object, but it does not support\n * the `extend` method, which means that even in modern IE, it's not possible\n * to programmatically create a backward selection. Thus, for all IE\n * versions, we use the old IE API to create our selections.\n *\n * @param {DOMElement|DOMTextNode} node\n * @param {object} offsets\n */ function setOffsets(node, offsets) {\n var doc = node.ownerDocument || document;\n var win = doc && doc.defaultView || window; // Edge fails with \"Object expected\" in some scenarios.\n // (For instance: TinyMCE editor used in a list component that supports pasting to add more,\n // fails when pasting 100+ items)\n if (!win.getSelection) return;\n var selection = win.getSelection();\n var length = node.textContent.length;\n var start = Math.min(offsets.start, length);\n var end = offsets.end === undefined ? start : Math.min(offsets.end, length); // IE 11 uses modern selection, but doesn't support the extend method.\n // Flip backward selections, so we can set with a single range.\n if (!selection.extend && start > end) {\n var temp = end;\n end = start;\n start = temp;\n }\n var startMarker = getNodeForCharacterOffset(node, start);\n var endMarker = getNodeForCharacterOffset(node, end);\n if (startMarker && endMarker) {\n if (selection.rangeCount === 1 && selection.anchorNode === startMarker.node && selection.anchorOffset === startMarker.offset && selection.focusNode === endMarker.node && selection.focusOffset === endMarker.offset) return;\n var range = doc.createRange();\n range.setStart(startMarker.node, startMarker.offset);\n selection.removeAllRanges();\n if (start > end) {\n selection.addRange(range);\n selection.extend(endMarker.node, endMarker.offset);\n } else {\n range.setEnd(endMarker.node, endMarker.offset);\n selection.addRange(range);\n }\n }\n }\n function isTextNode(node) {\n return node && node.nodeType === TEXT_NODE;\n }\n function containsNode(outerNode, innerNode) {\n if (!outerNode || !innerNode) return false;\n else if (outerNode === innerNode) return true;\n else if (isTextNode(outerNode)) return false;\n else if (isTextNode(innerNode)) return containsNode(outerNode, innerNode.parentNode);\n else if ('contains' in outerNode) return outerNode.contains(innerNode);\n else if (outerNode.compareDocumentPosition) return !!(outerNode.compareDocumentPosition(innerNode) & 16);\n else return false;\n }\n function isInDocument(node) {\n return node && node.ownerDocument && containsNode(node.ownerDocument.documentElement, node);\n }\n function isSameOriginFrame(iframe) {\n try {\n // Accessing the contentDocument of a HTMLIframeElement can cause the browser\n // to throw, e.g. if it has a cross-origin src attribute.\n // Safari will show an error in the console when the access results in \"Blocked a frame with origin\". e.g:\n // iframe.contentDocument.defaultView;\n // A safety way is to access one of the cross origin properties: Window or Location\n // Which might result in \"SecurityError\" DOM Exception and it is compatible to Safari.\n // https://html.spec.whatwg.org/multipage/browsers.html#integration-with-idl\n return typeof iframe.contentWindow.location.href === 'string';\n } catch (err) {\n return false;\n }\n }\n function getActiveElementDeep() {\n var win = window;\n var element = getActiveElement();\n while(element instanceof win.HTMLIFrameElement){\n if (isSameOriginFrame(element)) win = element.contentWindow;\n else return element;\n element = getActiveElement(win.document);\n }\n return element;\n }\n /**\n * @ReactInputSelection: React input selection module. Based on Selection.js,\n * but modified to be suitable for react and has a couple of bug fixes (doesn't\n * assume buttons have range selections allowed).\n * Input selection module for React.\n */ /**\n * @hasSelectionCapabilities: we get the element types that support selection\n * from https://html.spec.whatwg.org/#do-not-apply, looking at `selectionStart`\n * and `selectionEnd` rows.\n */ function hasSelectionCapabilities(elem) {\n var nodeName = elem && elem.nodeName && elem.nodeName.toLowerCase();\n return nodeName && (nodeName === 'input' && (elem.type === 'text' || elem.type === 'search' || elem.type === 'tel' || elem.type === 'url' || elem.type === 'password') || nodeName === 'textarea' || elem.contentEditable === 'true');\n }\n function getSelectionInformation() {\n var focusedElem = getActiveElementDeep();\n return {\n focusedElem: focusedElem,\n selectionRange: hasSelectionCapabilities(focusedElem) ? getSelection(focusedElem) : null\n };\n }\n /**\n * @restoreSelection: If any selection information was potentially lost,\n * restore it. This is useful when performing operations that could remove dom\n * nodes and place them back in, resulting in focus being lost.\n */ function restoreSelection(priorSelectionInformation) {\n var curFocusedElem = getActiveElementDeep();\n var priorFocusedElem = priorSelectionInformation.focusedElem;\n var priorSelectionRange = priorSelectionInformation.selectionRange;\n if (curFocusedElem !== priorFocusedElem && isInDocument(priorFocusedElem)) {\n if (priorSelectionRange !== null && hasSelectionCapabilities(priorFocusedElem)) setSelection(priorFocusedElem, priorSelectionRange);\n // Focusing a node can change the scroll position, which is undesirable\n var ancestors = [];\n var ancestor = priorFocusedElem;\n while(ancestor = ancestor.parentNode)if (ancestor.nodeType === ELEMENT_NODE) ancestors.push({\n element: ancestor,\n left: ancestor.scrollLeft,\n top: ancestor.scrollTop\n });\n if (typeof priorFocusedElem.focus === 'function') priorFocusedElem.focus();\n for(var i = 0; i < ancestors.length; i++){\n var info = ancestors[i];\n info.element.scrollLeft = info.left;\n info.element.scrollTop = info.top;\n }\n }\n }\n /**\n * @getSelection: Gets the selection bounds of a focused textarea, input or\n * contentEditable node.\n * -@input: Look up selection bounds of this input\n * -@return {start: selectionStart, end: selectionEnd}\n */ function getSelection(input) {\n var selection;\n if ('selectionStart' in input) // Modern browser with input or textarea.\n selection = {\n start: input.selectionStart,\n end: input.selectionEnd\n };\n else // Content editable or old IE textarea.\n selection = getOffsets(input);\n return selection || {\n start: 0,\n end: 0\n };\n }\n /**\n * @setSelection: Sets the selection bounds of a textarea or input and focuses\n * the input.\n * -@input Set selection bounds of this input or textarea\n * -@offsets Object of same form that is returned from get*\n */ function setSelection(input, offsets) {\n var start = offsets.start;\n var end = offsets.end;\n if (end === undefined) end = start;\n if ('selectionStart' in input) {\n input.selectionStart = start;\n input.selectionEnd = Math.min(end, input.value.length);\n } else setOffsets(input, offsets);\n }\n var skipSelectionChangeEvent = canUseDOM && 'documentMode' in document && document.documentMode <= 11;\n function registerEvents$3() {\n registerTwoPhaseEvent('onSelect', [\n 'focusout',\n 'contextmenu',\n 'dragend',\n 'focusin',\n 'keydown',\n 'keyup',\n 'mousedown',\n 'mouseup',\n 'selectionchange'\n ]);\n }\n var activeElement$1 = null;\n var activeElementInst$1 = null;\n var lastSelection = null;\n var mouseDown = false;\n /**\n * Get an object which is a unique representation of the current selection.\n *\n * The return value will not be consistent across nodes or browsers, but\n * two identical selections on the same node will return identical objects.\n */ function getSelection$1(node) {\n if ('selectionStart' in node && hasSelectionCapabilities(node)) return {\n start: node.selectionStart,\n end: node.selectionEnd\n };\n else {\n var win = node.ownerDocument && node.ownerDocument.defaultView || window;\n var selection = win.getSelection();\n return {\n anchorNode: selection.anchorNode,\n anchorOffset: selection.anchorOffset,\n focusNode: selection.focusNode,\n focusOffset: selection.focusOffset\n };\n }\n }\n /**\n * Get document associated with the event target.\n */ function getEventTargetDocument(eventTarget) {\n return eventTarget.window === eventTarget ? eventTarget.document : eventTarget.nodeType === DOCUMENT_NODE ? eventTarget : eventTarget.ownerDocument;\n }\n /**\n * Poll selection to see whether it's changed.\n *\n * @param {object} nativeEvent\n * @param {object} nativeEventTarget\n * @return {?SyntheticEvent}\n */ function constructSelectEvent(dispatchQueue, nativeEvent, nativeEventTarget) {\n // Ensure we have the right element, and that the user is not dragging a\n // selection (this matches native `select` event behavior). In HTML5, select\n // fires only on input and textarea thus if there's no focused element we\n // won't dispatch.\n var doc = getEventTargetDocument(nativeEventTarget);\n if (mouseDown || activeElement$1 == null || activeElement$1 !== getActiveElement(doc)) return;\n // Only fire when selection has actually changed.\n var currentSelection = getSelection$1(activeElement$1);\n if (!lastSelection || !shallowEqual(lastSelection, currentSelection)) {\n lastSelection = currentSelection;\n var listeners = accumulateTwoPhaseListeners(activeElementInst$1, 'onSelect');\n if (listeners.length > 0) {\n var event = new SyntheticEvent('onSelect', 'select', null, nativeEvent, nativeEventTarget);\n dispatchQueue.push({\n event: event,\n listeners: listeners\n });\n event.target = activeElement$1;\n }\n }\n }\n /**\n * This plugin creates an `onSelect` event that normalizes select events\n * across form elements.\n *\n * Supported elements are:\n * - input (see `isTextInputElement`)\n * - textarea\n * - contentEditable\n *\n * This differs from native browser implementations in the following ways:\n * - Fires on contentEditable fields as well as inputs.\n * - Fires for collapsed selection.\n * - Fires after user input.\n */ function extractEvents$3(dispatchQueue, domEventName, targetInst, nativeEvent, nativeEventTarget, eventSystemFlags, targetContainer) {\n var targetNode = targetInst ? getNodeFromInstance(targetInst) : window;\n switch(domEventName){\n // Track the input node that has focus.\n case 'focusin':\n if (isTextInputElement(targetNode) || targetNode.contentEditable === 'true') {\n activeElement$1 = targetNode;\n activeElementInst$1 = targetInst;\n lastSelection = null;\n }\n break;\n case 'focusout':\n activeElement$1 = null;\n activeElementInst$1 = null;\n lastSelection = null;\n break;\n // Don't fire the event while the user is dragging. This matches the\n // semantics of the native select event.\n case 'mousedown':\n mouseDown = true;\n break;\n case 'contextmenu':\n case 'mouseup':\n case 'dragend':\n mouseDown = false;\n constructSelectEvent(dispatchQueue, nativeEvent, nativeEventTarget);\n break;\n // Chrome and IE fire non-standard event when selection is changed (and\n // sometimes when it hasn't). IE's event fires out of order with respect\n // to key and input events on deletion, so we discard it.\n //\n // Firefox doesn't support selectionchange, so check selection status\n // after each key entry. The selection changes after keydown and before\n // keyup, but we check on keydown as well in the case of holding down a\n // key, when multiple keydown events are fired but only one keyup is.\n // This is also our approach for IE handling, for the reason above.\n case 'selectionchange':\n if (skipSelectionChangeEvent) break;\n // falls through\n case 'keydown':\n case 'keyup':\n constructSelectEvent(dispatchQueue, nativeEvent, nativeEventTarget);\n }\n }\n function extractEvents$4(dispatchQueue, domEventName, targetInst, nativeEvent, nativeEventTarget, eventSystemFlags, targetContainer) {\n var reactName = topLevelEventsToReactNames.get(domEventName);\n if (reactName === undefined) return;\n var SyntheticEventCtor = SyntheticEvent;\n var reactEventType = domEventName;\n switch(domEventName){\n case 'keypress':\n // Firefox creates a keypress event for function keys too. This removes\n // the unwanted keypress events. Enter is however both printable and\n // non-printable. One would expect Tab to be as well (but it isn't).\n if (getEventCharCode(nativeEvent) === 0) return;\n /* falls through */ case 'keydown':\n case 'keyup':\n SyntheticEventCtor = SyntheticKeyboardEvent;\n break;\n case 'focusin':\n reactEventType = 'focus';\n SyntheticEventCtor = SyntheticFocusEvent;\n break;\n case 'focusout':\n reactEventType = 'blur';\n SyntheticEventCtor = SyntheticFocusEvent;\n break;\n case 'beforeblur':\n case 'afterblur':\n SyntheticEventCtor = SyntheticFocusEvent;\n break;\n case 'click':\n // Firefox creates a click event on right mouse clicks. This removes the\n // unwanted click events.\n if (nativeEvent.button === 2) return;\n /* falls through */ case 'auxclick':\n case 'dblclick':\n case 'mousedown':\n case 'mousemove':\n case 'mouseup':\n /* falls through */ case 'mouseout':\n case 'mouseover':\n case 'contextmenu':\n SyntheticEventCtor = SyntheticMouseEvent;\n break;\n case 'drag':\n case 'dragend':\n case 'dragenter':\n case 'dragexit':\n case 'dragleave':\n case 'dragover':\n case 'dragstart':\n case 'drop':\n SyntheticEventCtor = SyntheticDragEvent;\n break;\n case 'touchcancel':\n case 'touchend':\n case 'touchmove':\n case 'touchstart':\n SyntheticEventCtor = SyntheticTouchEvent;\n break;\n case ANIMATION_END:\n case ANIMATION_ITERATION:\n case ANIMATION_START:\n SyntheticEventCtor = SyntheticAnimationEvent;\n break;\n case TRANSITION_END:\n SyntheticEventCtor = SyntheticTransitionEvent;\n break;\n case 'scroll':\n SyntheticEventCtor = SyntheticUIEvent;\n break;\n case 'wheel':\n SyntheticEventCtor = SyntheticWheelEvent;\n break;\n case 'copy':\n case 'cut':\n case 'paste':\n SyntheticEventCtor = SyntheticClipboardEvent;\n break;\n case 'gotpointercapture':\n case 'lostpointercapture':\n case 'pointercancel':\n case 'pointerdown':\n case 'pointermove':\n case 'pointerout':\n case 'pointerover':\n case 'pointerup':\n SyntheticEventCtor = SyntheticPointerEvent;\n break;\n }\n var inCapturePhase = (eventSystemFlags & IS_CAPTURE_PHASE) !== 0;\n // Some events don't bubble in the browser.\n // In the past, React has always bubbled them, but this can be surprising.\n // We're going to try aligning closer to the browser behavior by not bubbling\n // them in React either. We'll start by not bubbling onScroll, and then expand.\n var accumulateTargetOnly = !inCapturePhase && // nonDelegatedEvents list in DOMPluginEventSystem.\n // Then we can remove this special list.\n // This is a breaking change that can wait until React 18.\n domEventName === 'scroll';\n var _listeners = accumulateSinglePhaseListeners(targetInst, reactName, nativeEvent.type, inCapturePhase, accumulateTargetOnly);\n if (_listeners.length > 0) {\n // Intentionally create event lazily.\n var _event = new SyntheticEventCtor(reactName, reactEventType, null, nativeEvent, nativeEventTarget);\n dispatchQueue.push({\n event: _event,\n listeners: _listeners\n });\n }\n }\n // TODO: remove top-level side effect.\n registerSimpleEvents();\n registerEvents$2();\n registerEvents$1();\n registerEvents$3();\n registerEvents();\n function extractEvents$5(dispatchQueue, domEventName, targetInst, nativeEvent, nativeEventTarget, eventSystemFlags, targetContainer) {\n // TODO: we should remove the concept of a \"SimpleEventPlugin\".\n // This is the basic functionality of the event system. All\n // the other plugins are essentially polyfills. So the plugin\n // should probably be inlined somewhere and have its logic\n // be core the to event system. This would potentially allow\n // us to ship builds of React without the polyfilled plugins below.\n extractEvents$4(dispatchQueue, domEventName, targetInst, nativeEvent, nativeEventTarget, eventSystemFlags);\n var shouldProcessPolyfillPlugins = (eventSystemFlags & SHOULD_NOT_PROCESS_POLYFILL_EVENT_PLUGINS) === 0; // We don't process these events unless we are in the\n // event's native \"bubble\" phase, which means that we're\n // not in the capture phase. That's because we emulate\n // the capture phase here still. This is a trade-off,\n // because in an ideal world we would not emulate and use\n // the phases properly, like we do with the SimpleEvent\n // plugin. However, the plugins below either expect\n // emulation (EnterLeave) or use state localized to that\n // plugin (BeforeInput, Change, Select). The state in\n // these modules complicates things, as you'll essentially\n // get the case where the capture phase event might change\n // state, only for the following bubble event to come in\n // later and not trigger anything as the state now\n // invalidates the heuristics of the event plugin. We\n // could alter all these plugins to work in such ways, but\n // that might cause other unknown side-effects that we\n // can't forsee right now.\n if (shouldProcessPolyfillPlugins) {\n extractEvents$2(dispatchQueue, domEventName, targetInst, nativeEvent, nativeEventTarget, eventSystemFlags);\n extractEvents$1(dispatchQueue, domEventName, targetInst, nativeEvent, nativeEventTarget);\n extractEvents$3(dispatchQueue, domEventName, targetInst, nativeEvent, nativeEventTarget);\n extractEvents(dispatchQueue, domEventName, targetInst, nativeEvent, nativeEventTarget);\n }\n } // List of events that need to be individually attached to media elements.\n var mediaEventTypes = [\n 'abort',\n 'canplay',\n 'canplaythrough',\n 'durationchange',\n 'emptied',\n 'encrypted',\n 'ended',\n 'error',\n 'loadeddata',\n 'loadedmetadata',\n 'loadstart',\n 'pause',\n 'play',\n 'playing',\n 'progress',\n 'ratechange',\n 'seeked',\n 'seeking',\n 'stalled',\n 'suspend',\n 'timeupdate',\n 'volumechange',\n 'waiting'\n ]; // We should not delegate these events to the container, but rather\n // set them on the actual target element itself. This is primarily\n // because these events do not consistently bubble in the DOM.\n var nonDelegatedEvents = new Set([\n 'cancel',\n 'close',\n 'invalid',\n 'load',\n 'scroll',\n 'toggle'\n ].concat(mediaEventTypes));\n function executeDispatch(event, listener, currentTarget) {\n var type = event.type || 'unknown-event';\n event.currentTarget = currentTarget;\n invokeGuardedCallbackAndCatchFirstError(type, listener, undefined, event);\n event.currentTarget = null;\n }\n function processDispatchQueueItemsInOrder(event, dispatchListeners, inCapturePhase) {\n var previousInstance;\n if (inCapturePhase) for(var i = dispatchListeners.length - 1; i >= 0; i--){\n var _dispatchListeners$i = dispatchListeners[i], instance = _dispatchListeners$i.instance, currentTarget = _dispatchListeners$i.currentTarget, listener = _dispatchListeners$i.listener;\n if (instance !== previousInstance && event.isPropagationStopped()) return;\n executeDispatch(event, listener, currentTarget);\n previousInstance = instance;\n }\n else for(var _i = 0; _i < dispatchListeners.length; _i++){\n var _dispatchListeners$_i = dispatchListeners[_i], _instance = _dispatchListeners$_i.instance, _currentTarget = _dispatchListeners$_i.currentTarget, _listener = _dispatchListeners$_i.listener;\n if (_instance !== previousInstance && event.isPropagationStopped()) return;\n executeDispatch(event, _listener, _currentTarget);\n previousInstance = _instance;\n }\n }\n function processDispatchQueue(dispatchQueue, eventSystemFlags) {\n var inCapturePhase = (eventSystemFlags & IS_CAPTURE_PHASE) !== 0;\n for(var i = 0; i < dispatchQueue.length; i++){\n var _dispatchQueue$i = dispatchQueue[i], event = _dispatchQueue$i.event, listeners = _dispatchQueue$i.listeners;\n processDispatchQueueItemsInOrder(event, listeners, inCapturePhase); // event system doesn't use pooling.\n } // This would be a good time to rethrow if any of the event handlers threw.\n rethrowCaughtError();\n }\n function dispatchEventsForPlugins(domEventName, eventSystemFlags, nativeEvent, targetInst, targetContainer) {\n var nativeEventTarget = getEventTarget(nativeEvent);\n var dispatchQueue = [];\n extractEvents$5(dispatchQueue, domEventName, targetInst, nativeEvent, nativeEventTarget, eventSystemFlags);\n processDispatchQueue(dispatchQueue, eventSystemFlags);\n }\n function listenToNonDelegatedEvent(domEventName, targetElement) {\n var isCapturePhaseListener = false;\n var listenerSet = getEventListenerSet(targetElement);\n var listenerSetKey = getListenerSetKey(domEventName, isCapturePhaseListener);\n if (!listenerSet.has(listenerSetKey)) {\n addTrappedEventListener(targetElement, domEventName, IS_NON_DELEGATED, isCapturePhaseListener);\n listenerSet.add(listenerSetKey);\n }\n }\n var listeningMarker = '_reactListening' + Math.random().toString(36).slice(2);\n function listenToAllSupportedEvents(rootContainerElement) {\n if (rootContainerElement[listeningMarker]) // Performance optimization: don't iterate through events\n // for the same portal container or root node more than once.\n // TODO: once we remove the flag, we may be able to also\n // remove some of the bookkeeping maps used for laziness.\n return;\n rootContainerElement[listeningMarker] = true;\n allNativeEvents.forEach(function(domEventName) {\n if (!nonDelegatedEvents.has(domEventName)) listenToNativeEvent(domEventName, false, rootContainerElement, null);\n listenToNativeEvent(domEventName, true, rootContainerElement, null);\n });\n }\n function listenToNativeEvent(domEventName, isCapturePhaseListener, rootContainerElement, targetElement) {\n var eventSystemFlags = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : 0;\n var target = rootContainerElement; // selectionchange needs to be attached to the document\n // otherwise it won't capture incoming events that are only\n // triggered on the document directly.\n if (domEventName === 'selectionchange' && rootContainerElement.nodeType !== DOCUMENT_NODE) target = rootContainerElement.ownerDocument;\n // If the event can be delegated (or is capture phase), we can\n // register it to the root container. Otherwise, we should\n // register the event to the target element and mark it as\n // a non-delegated event.\n if (targetElement !== null && !isCapturePhaseListener && nonDelegatedEvents.has(domEventName)) {\n // For all non-delegated events, apart from scroll, we attach\n // their event listeners to the respective elements that their\n // events fire on. That means we can skip this step, as event\n // listener has already been added previously. However, we\n // special case the scroll event because the reality is that any\n // element can scroll.\n // TODO: ideally, we'd eventually apply the same logic to all\n // events from the nonDelegatedEvents list. Then we can remove\n // this special case and use the same logic for all events.\n if (domEventName !== 'scroll') return;\n eventSystemFlags |= IS_NON_DELEGATED;\n target = targetElement;\n }\n var listenerSet = getEventListenerSet(target);\n var listenerSetKey = getListenerSetKey(domEventName, isCapturePhaseListener); // If the listener entry is empty or we should upgrade, then\n // we need to trap an event listener onto the target.\n if (!listenerSet.has(listenerSetKey)) {\n if (isCapturePhaseListener) eventSystemFlags |= IS_CAPTURE_PHASE;\n addTrappedEventListener(target, domEventName, eventSystemFlags, isCapturePhaseListener);\n listenerSet.add(listenerSetKey);\n }\n }\n function addTrappedEventListener(targetContainer, domEventName, eventSystemFlags, isCapturePhaseListener, isDeferredListenerForLegacyFBSupport) {\n var listener = createEventListenerWrapperWithPriority(targetContainer, domEventName, eventSystemFlags); // If passive option is not supported, then the event will be\n // active and not passive.\n var isPassiveListener = undefined;\n if (passiveBrowserEventsSupported) // Browsers introduced an intervention, making these events\n // passive by default on document. React doesn't bind them\n // to document anymore, but changing this now would undo\n // the performance wins from the change. So we emulate\n // the existing behavior manually on the roots now.\n // https://github.com/facebook/react/issues/19651\n {\n if (domEventName === 'touchstart' || domEventName === 'touchmove' || domEventName === 'wheel') isPassiveListener = true;\n }\n var unsubscribeListener; // When legacyFBSupport is enabled, it's for when we\n if (isCapturePhaseListener) {\n if (isPassiveListener !== undefined) unsubscribeListener = addEventCaptureListenerWithPassiveFlag(targetContainer, domEventName, listener, isPassiveListener);\n else unsubscribeListener = addEventCaptureListener(targetContainer, domEventName, listener);\n } else if (isPassiveListener !== undefined) unsubscribeListener = addEventBubbleListenerWithPassiveFlag(targetContainer, domEventName, listener, isPassiveListener);\n else unsubscribeListener = addEventBubbleListener(targetContainer, domEventName, listener);\n }\n function isMatchingRootContainer(grandContainer, targetContainer) {\n return grandContainer === targetContainer || grandContainer.nodeType === COMMENT_NODE && grandContainer.parentNode === targetContainer;\n }\n function dispatchEventForPluginEventSystem(domEventName, eventSystemFlags, nativeEvent, targetInst, targetContainer) {\n var ancestorInst = targetInst;\n if ((eventSystemFlags & IS_EVENT_HANDLE_NON_MANAGED_NODE) === 0 && (eventSystemFlags & IS_NON_DELEGATED) === 0) {\n var targetContainerNode = targetContainer; // If we are using the legacy FB support flag, we\n if (targetInst !== null) {\n // The below logic attempts to work out if we need to change\n // the target fiber to a different ancestor. We had similar logic\n // in the legacy event system, except the big difference between\n // systems is that the modern event system now has an event listener\n // attached to each React Root and React Portal Root. Together,\n // the DOM nodes representing these roots are the \"rootContainer\".\n // To figure out which ancestor instance we should use, we traverse\n // up the fiber tree from the target instance and attempt to find\n // root boundaries that match that of our current \"rootContainer\".\n // If we find that \"rootContainer\", we find the parent fiber\n // sub-tree for that root and make that our ancestor instance.\n var node = targetInst;\n mainLoop: while(true){\n if (node === null) return;\n var nodeTag = node.tag;\n if (nodeTag === HostRoot || nodeTag === HostPortal) {\n var container = node.stateNode.containerInfo;\n if (isMatchingRootContainer(container, targetContainerNode)) break;\n if (nodeTag === HostPortal) {\n // The target is a portal, but it's not the rootContainer we're looking for.\n // Normally portals handle their own events all the way down to the root.\n // So we should be able to stop now. However, we don't know if this portal\n // was part of *our* root.\n var grandNode = node.return;\n while(grandNode !== null){\n var grandTag = grandNode.tag;\n if (grandTag === HostRoot || grandTag === HostPortal) {\n var grandContainer = grandNode.stateNode.containerInfo;\n if (isMatchingRootContainer(grandContainer, targetContainerNode)) // This is the rootContainer we're looking for and we found it as\n // a parent of the Portal. That means we can ignore it because the\n // Portal will bubble through to us.\n return;\n }\n grandNode = grandNode.return;\n }\n } // Now we need to find it's corresponding host fiber in the other\n // tree. To do this we can use getClosestInstanceFromNode, but we\n // need to validate that the fiber is a host instance, otherwise\n // we need to traverse up through the DOM till we find the correct\n // node that is from the other tree.\n while(container !== null){\n var parentNode = getClosestInstanceFromNode(container);\n if (parentNode === null) return;\n var parentTag = parentNode.tag;\n if (parentTag === HostComponent || parentTag === HostText) {\n node = ancestorInst = parentNode;\n continue mainLoop;\n }\n container = container.parentNode;\n }\n }\n node = node.return;\n }\n }\n }\n batchedEventUpdates(function() {\n return dispatchEventsForPlugins(domEventName, eventSystemFlags, nativeEvent, ancestorInst);\n });\n }\n function createDispatchListener(instance, listener, currentTarget) {\n return {\n instance: instance,\n listener: listener,\n currentTarget: currentTarget\n };\n }\n function accumulateSinglePhaseListeners(targetFiber, reactName, nativeEventType, inCapturePhase, accumulateTargetOnly) {\n var captureName = reactName !== null ? reactName + 'Capture' : null;\n var reactEventName = inCapturePhase ? captureName : reactName;\n var listeners = [];\n var instance = targetFiber;\n var lastHostComponent = null; // Accumulate all instances and listeners via the target -> root path.\n while(instance !== null){\n var _instance2 = instance, stateNode = _instance2.stateNode, tag = _instance2.tag; // Handle listeners that are on HostComponents (i.e. <div>)\n if (tag === HostComponent && stateNode !== null) {\n lastHostComponent = stateNode; // createEventHandle listeners\n if (reactEventName !== null) {\n var listener = getListener(instance, reactEventName);\n if (listener != null) listeners.push(createDispatchListener(instance, listener, lastHostComponent));\n }\n } // If we are only accumulating events for the target, then we don't\n // continue to propagate through the React fiber tree to find other\n // listeners.\n if (accumulateTargetOnly) break;\n instance = instance.return;\n }\n return listeners;\n } // We should only use this function for:\n // - BeforeInputEventPlugin\n // - ChangeEventPlugin\n // - SelectEventPlugin\n // This is because we only process these plugins\n // in the bubble phase, so we need to accumulate two\n // phase event listeners (via emulation).\n function accumulateTwoPhaseListeners(targetFiber, reactName) {\n var captureName = reactName + 'Capture';\n var listeners = [];\n var instance = targetFiber; // Accumulate all instances and listeners via the target -> root path.\n while(instance !== null){\n var _instance3 = instance, stateNode = _instance3.stateNode, tag = _instance3.tag; // Handle listeners that are on HostComponents (i.e. <div>)\n if (tag === HostComponent && stateNode !== null) {\n var currentTarget = stateNode;\n var captureListener = getListener(instance, captureName);\n if (captureListener != null) listeners.unshift(createDispatchListener(instance, captureListener, currentTarget));\n var bubbleListener = getListener(instance, reactName);\n if (bubbleListener != null) listeners.push(createDispatchListener(instance, bubbleListener, currentTarget));\n }\n instance = instance.return;\n }\n return listeners;\n }\n function getParent(inst) {\n if (inst === null) return null;\n do inst = inst.return; // TODO: If this is a HostRoot we might want to bail out.\n while (inst && inst.tag !== HostComponent)\n if (inst) return inst;\n return null;\n }\n /**\n * Return the lowest common ancestor of A and B, or null if they are in\n * different trees.\n */ function getLowestCommonAncestor(instA, instB) {\n var nodeA = instA;\n var nodeB = instB;\n var depthA = 0;\n for(var tempA = nodeA; tempA; tempA = getParent(tempA))depthA++;\n var depthB = 0;\n for(var tempB = nodeB; tempB; tempB = getParent(tempB))depthB++;\n // If A is deeper, crawl up.\n while(depthA - depthB > 0){\n nodeA = getParent(nodeA);\n depthA--;\n } // If B is deeper, crawl up.\n while(depthB - depthA > 0){\n nodeB = getParent(nodeB);\n depthB--;\n } // Walk in lockstep until we find a match.\n var depth = depthA;\n while(depth--){\n if (nodeA === nodeB || nodeB !== null && nodeA === nodeB.alternate) return nodeA;\n nodeA = getParent(nodeA);\n nodeB = getParent(nodeB);\n }\n return null;\n }\n function accumulateEnterLeaveListenersForEvent(dispatchQueue, event, target, common, inCapturePhase) {\n var registrationName = event._reactName;\n var listeners = [];\n var instance = target;\n while(instance !== null){\n if (instance === common) break;\n var _instance4 = instance, alternate = _instance4.alternate, stateNode = _instance4.stateNode, tag = _instance4.tag;\n if (alternate !== null && alternate === common) break;\n if (tag === HostComponent && stateNode !== null) {\n var currentTarget = stateNode;\n if (inCapturePhase) {\n var captureListener = getListener(instance, registrationName);\n if (captureListener != null) listeners.unshift(createDispatchListener(instance, captureListener, currentTarget));\n } else if (!inCapturePhase) {\n var bubbleListener = getListener(instance, registrationName);\n if (bubbleListener != null) listeners.push(createDispatchListener(instance, bubbleListener, currentTarget));\n }\n }\n instance = instance.return;\n }\n if (listeners.length !== 0) dispatchQueue.push({\n event: event,\n listeners: listeners\n });\n } // We should only use this function for:\n // - EnterLeaveEventPlugin\n // This is because we only process this plugin\n // in the bubble phase, so we need to accumulate two\n // phase event listeners.\n function accumulateEnterLeaveTwoPhaseListeners(dispatchQueue, leaveEvent, enterEvent, from, to) {\n var common = from && to ? getLowestCommonAncestor(from, to) : null;\n if (from !== null) accumulateEnterLeaveListenersForEvent(dispatchQueue, leaveEvent, from, common, false);\n if (to !== null && enterEvent !== null) accumulateEnterLeaveListenersForEvent(dispatchQueue, enterEvent, to, common, true);\n }\n function getListenerSetKey(domEventName, capture) {\n return domEventName + \"__\" + (capture ? 'capture' : 'bubble');\n }\n var didWarnInvalidHydration = false;\n var DANGEROUSLY_SET_INNER_HTML = 'dangerouslySetInnerHTML';\n var SUPPRESS_CONTENT_EDITABLE_WARNING = 'suppressContentEditableWarning';\n var SUPPRESS_HYDRATION_WARNING = 'suppressHydrationWarning';\n var AUTOFOCUS = 'autoFocus';\n var CHILDREN = 'children';\n var STYLE = 'style';\n var HTML$1 = '__html';\n var HTML_NAMESPACE$1 = Namespaces.html;\n var warnedUnknownTags;\n var suppressHydrationWarning;\n var validatePropertiesInDevelopment;\n var warnForTextDifference;\n var warnForPropDifference;\n var warnForExtraAttributes;\n var warnForInvalidEventListener;\n var canDiffStyleForHydrationWarning;\n var normalizeMarkupForTextOrAttribute;\n var normalizeHTML;\n warnedUnknownTags = {\n // There are working polyfills for <dialog>. Let people use it.\n dialog: true,\n // Electron ships a custom <webview> tag to display external web content in\n // an isolated frame and process.\n // This tag is not present in non Electron environments such as JSDom which\n // is often used for testing purposes.\n // @see https://electronjs.org/docs/api/webview-tag\n webview: true\n };\n validatePropertiesInDevelopment = function(type, props) {\n validateProperties(type, props);\n validateProperties$1(type, props);\n validateProperties$2(type, props, {\n registrationNameDependencies: registrationNameDependencies1,\n possibleRegistrationNames: possibleRegistrationNames1\n });\n }; // IE 11 parses & normalizes the style attribute as opposed to other\n // browsers. It adds spaces and sorts the properties in some\n // non-alphabetical order. Handling that would require sorting CSS\n // properties in the client & server versions or applying\n // `expectedStyle` to a temporary DOM node to read its `style` attribute\n // normalized. Since it only affects IE, we're skipping style warnings\n // in that browser completely in favor of doing all that work.\n // See https://github.com/facebook/react/issues/11807\n canDiffStyleForHydrationWarning = canUseDOM && !document.documentMode; // HTML parsing normalizes CR and CRLF to LF.\n // It also can turn \\u0000 into \\uFFFD inside attributes.\n // https://www.w3.org/TR/html5/single-page.html#preprocessing-the-input-stream\n // If we have a mismatch, it might be caused by that.\n // We will still patch up in this case but not fire the warning.\n var NORMALIZE_NEWLINES_REGEX = /\\r\\n?/g;\n var NORMALIZE_NULL_AND_REPLACEMENT_REGEX = /\\u0000|\\uFFFD/g;\n normalizeMarkupForTextOrAttribute = function(markup) {\n var markupString = typeof markup === 'string' ? markup : '' + markup;\n return markupString.replace(NORMALIZE_NEWLINES_REGEX, '\\n').replace(NORMALIZE_NULL_AND_REPLACEMENT_REGEX, '');\n };\n warnForTextDifference = function(serverText, clientText) {\n if (didWarnInvalidHydration) return;\n var normalizedClientText = normalizeMarkupForTextOrAttribute(clientText);\n var normalizedServerText = normalizeMarkupForTextOrAttribute(serverText);\n if (normalizedServerText === normalizedClientText) return;\n didWarnInvalidHydration = true;\n error1('Text content did not match. Server: \"%s\" Client: \"%s\"', normalizedServerText, normalizedClientText);\n };\n warnForPropDifference = function(propName, serverValue, clientValue) {\n if (didWarnInvalidHydration) return;\n var normalizedClientValue = normalizeMarkupForTextOrAttribute(clientValue);\n var normalizedServerValue = normalizeMarkupForTextOrAttribute(serverValue);\n if (normalizedServerValue === normalizedClientValue) return;\n didWarnInvalidHydration = true;\n error1('Prop `%s` did not match. Server: %s Client: %s', propName, JSON.stringify(normalizedServerValue), JSON.stringify(normalizedClientValue));\n };\n warnForExtraAttributes = function(attributeNames) {\n if (didWarnInvalidHydration) return;\n didWarnInvalidHydration = true;\n var names = [];\n attributeNames.forEach(function(name) {\n names.push(name);\n });\n error1('Extra attributes from the server: %s', names);\n };\n warnForInvalidEventListener = function(registrationName, listener) {\n if (listener === false) error1(\"Expected `%s` listener to be a function, instead got `false`.\\n\\nIf you used to conditionally omit it with %s={condition && value}, pass %s={condition ? value : undefined} instead.\", registrationName, registrationName, registrationName);\n else error1('Expected `%s` listener to be a function, instead got a value of `%s` type.', registrationName, typeof listener);\n }; // Parse the HTML and read it back to normalize the HTML string so that it\n // can be used for comparison.\n normalizeHTML = function(parent, html) {\n // We could have created a separate document here to avoid\n // re-initializing custom elements if they exist. But this breaks\n // how <noscript> is being handled. So we use the same document.\n // See the discussion in https://github.com/facebook/react/pull/11157.\n var testElement = parent.namespaceURI === HTML_NAMESPACE$1 ? parent.ownerDocument.createElement(parent.tagName) : parent.ownerDocument.createElementNS(parent.namespaceURI, parent.tagName);\n testElement.innerHTML = html;\n return testElement.innerHTML;\n };\n function getOwnerDocumentFromRootContainer(rootContainerElement) {\n return rootContainerElement.nodeType === DOCUMENT_NODE ? rootContainerElement : rootContainerElement.ownerDocument;\n }\n function noop() {\n }\n function trapClickOnNonInteractiveElement(node) {\n // Mobile Safari does not fire properly bubble click events on\n // non-interactive elements, which means delegated click listeners do not\n // fire. The workaround for this bug involves attaching an empty click\n // listener on the target node.\n // https://www.quirksmode.org/blog/archives/2010/09/click_event_del.html\n // Just set it using the onclick property so that we don't have to manage any\n // bookkeeping for it. Not sure if we need to clear it when the listener is\n // removed.\n // TODO: Only do this for the relevant Safaris maybe?\n node.onclick = noop;\n }\n function setInitialDOMProperties(tag, domElement, rootContainerElement, nextProps, isCustomComponentTag) {\n for(var propKey in nextProps){\n if (!nextProps.hasOwnProperty(propKey)) continue;\n var nextProp = nextProps[propKey];\n if (propKey === STYLE) {\n if (nextProp) // Freeze the next style object so that we can assume it won't be\n // mutated. We have already warned for this in the past.\n Object.freeze(nextProp);\n setValueForStyles(domElement, nextProp);\n } else if (propKey === DANGEROUSLY_SET_INNER_HTML) {\n var nextHtml = nextProp ? nextProp[HTML$1] : undefined;\n if (nextHtml != null) setInnerHTML(domElement, nextHtml);\n } else if (propKey === CHILDREN) {\n if (typeof nextProp === 'string') {\n // Avoid setting initial textContent when the text is empty. In IE11 setting\n // textContent on a <textarea> will cause the placeholder to not\n // show within the <textarea> until it has been focused and blurred again.\n // https://github.com/facebook/react/issues/6731#issuecomment-254874553\n var canSetTextContent = tag !== 'textarea' || nextProp !== '';\n if (canSetTextContent) setTextContent(domElement, nextProp);\n } else if (typeof nextProp === 'number') setTextContent(domElement, '' + nextProp);\n } else if (propKey === SUPPRESS_CONTENT_EDITABLE_WARNING || propKey === SUPPRESS_HYDRATION_WARNING) ;\n else if (propKey === AUTOFOCUS) ;\n else if (registrationNameDependencies1.hasOwnProperty(propKey)) {\n if (nextProp != null) {\n if (typeof nextProp !== 'function') warnForInvalidEventListener(propKey, nextProp);\n if (propKey === 'onScroll') listenToNonDelegatedEvent('scroll', domElement);\n }\n } else if (nextProp != null) setValueForProperty(domElement, propKey, nextProp, isCustomComponentTag);\n }\n }\n function updateDOMProperties(domElement, updatePayload, wasCustomComponentTag, isCustomComponentTag) {\n // TODO: Handle wasCustomComponentTag\n for(var i = 0; i < updatePayload.length; i += 2){\n var propKey = updatePayload[i];\n var propValue = updatePayload[i + 1];\n if (propKey === STYLE) setValueForStyles(domElement, propValue);\n else if (propKey === DANGEROUSLY_SET_INNER_HTML) setInnerHTML(domElement, propValue);\n else if (propKey === CHILDREN) setTextContent(domElement, propValue);\n else setValueForProperty(domElement, propKey, propValue, isCustomComponentTag);\n }\n }\n function createElement(type, props, rootContainerElement, parentNamespace) {\n var isCustomComponentTag; // We create tags in the namespace of their parent container, except HTML\n // tags get no namespace.\n var ownerDocument = getOwnerDocumentFromRootContainer(rootContainerElement);\n var domElement;\n var namespaceURI = parentNamespace;\n if (namespaceURI === HTML_NAMESPACE$1) namespaceURI = getIntrinsicNamespace(type);\n if (namespaceURI === HTML_NAMESPACE$1) {\n isCustomComponentTag = isCustomComponent(type, props); // Should this check be gated by parent namespace? Not sure we want to\n // allow <SVG> or <mATH>.\n if (!isCustomComponentTag && type !== type.toLowerCase()) error1(\"<%s /> is using incorrect casing. Use PascalCase for React components, or lowercase for HTML elements.\", type);\n if (type === 'script') {\n // Create the script via .innerHTML so its \"parser-inserted\" flag is\n // set to true and it does not execute\n var div = ownerDocument.createElement('div');\n div.innerHTML = \"<script></\\script>\"; // eslint-disable-line\n // This is guaranteed to yield a script element.\n var firstChild = div.firstChild;\n domElement = div.removeChild(firstChild);\n } else if (typeof props.is === 'string') // $FlowIssue `createElement` should be updated for Web Components\n domElement = ownerDocument.createElement(type, {\n is: props.is\n });\n else {\n // Separate else branch instead of using `props.is || undefined` above because of a Firefox bug.\n // See discussion in https://github.com/facebook/react/pull/6896\n // and discussion in https://bugzilla.mozilla.org/show_bug.cgi?id=1276240\n domElement = ownerDocument.createElement(type); // Normally attributes are assigned in `setInitialDOMProperties`, however the `multiple` and `size`\n // attributes on `select`s needs to be added before `option`s are inserted.\n // This prevents:\n // - a bug where the `select` does not scroll to the correct option because singular\n // `select` elements automatically pick the first item #13222\n // - a bug where the `select` set the first item as selected despite the `size` attribute #14239\n // See https://github.com/facebook/react/issues/13222\n // and https://github.com/facebook/react/issues/14239\n if (type === 'select') {\n var node = domElement;\n if (props.multiple) node.multiple = true;\n else if (props.size) // Setting a size greater than 1 causes a select to behave like `multiple=true`, where\n // it is possible that no option is selected.\n //\n // This is only necessary when a select in \"single selection mode\".\n node.size = props.size;\n }\n }\n } else domElement = ownerDocument.createElementNS(namespaceURI, type);\n if (namespaceURI === HTML_NAMESPACE$1) {\n if (!isCustomComponentTag && Object.prototype.toString.call(domElement) === '[object HTMLUnknownElement]' && !Object.prototype.hasOwnProperty.call(warnedUnknownTags, type)) {\n warnedUnknownTags[type] = true;\n error1(\"The tag <%s> is unrecognized in this browser. If you meant to render a React component, start its name with an uppercase letter.\", type);\n }\n }\n return domElement;\n }\n function createTextNode(text, rootContainerElement) {\n return getOwnerDocumentFromRootContainer(rootContainerElement).createTextNode(text);\n }\n function setInitialProperties(domElement, tag, rawProps, rootContainerElement) {\n var isCustomComponentTag = isCustomComponent(tag, rawProps);\n validatePropertiesInDevelopment(tag, rawProps);\n var props;\n switch(tag){\n case 'dialog':\n listenToNonDelegatedEvent('cancel', domElement);\n listenToNonDelegatedEvent('close', domElement);\n props = rawProps;\n break;\n case 'iframe':\n case 'object':\n case 'embed':\n // We listen to this event in case to ensure emulated bubble\n // listeners still fire for the load event.\n listenToNonDelegatedEvent('load', domElement);\n props = rawProps;\n break;\n case 'video':\n case 'audio':\n // We listen to these events in case to ensure emulated bubble\n // listeners still fire for all the media events.\n for(var i = 0; i < mediaEventTypes.length; i++)listenToNonDelegatedEvent(mediaEventTypes[i], domElement);\n props = rawProps;\n break;\n case 'source':\n // We listen to this event in case to ensure emulated bubble\n // listeners still fire for the error event.\n listenToNonDelegatedEvent('error', domElement);\n props = rawProps;\n break;\n case 'img':\n case 'image':\n case 'link':\n // We listen to these events in case to ensure emulated bubble\n // listeners still fire for error and load events.\n listenToNonDelegatedEvent('error', domElement);\n listenToNonDelegatedEvent('load', domElement);\n props = rawProps;\n break;\n case 'details':\n // We listen to this event in case to ensure emulated bubble\n // listeners still fire for the toggle event.\n listenToNonDelegatedEvent('toggle', domElement);\n props = rawProps;\n break;\n case 'input':\n initWrapperState(domElement, rawProps);\n props = getHostProps(domElement, rawProps); // We listen to this event in case to ensure emulated bubble\n // listeners still fire for the invalid event.\n listenToNonDelegatedEvent('invalid', domElement);\n break;\n case 'option':\n validateProps(domElement, rawProps);\n props = getHostProps$1(domElement, rawProps);\n break;\n case 'select':\n initWrapperState$1(domElement, rawProps);\n props = getHostProps$2(domElement, rawProps); // We listen to this event in case to ensure emulated bubble\n // listeners still fire for the invalid event.\n listenToNonDelegatedEvent('invalid', domElement);\n break;\n case 'textarea':\n initWrapperState$2(domElement, rawProps);\n props = getHostProps$3(domElement, rawProps); // We listen to this event in case to ensure emulated bubble\n // listeners still fire for the invalid event.\n listenToNonDelegatedEvent('invalid', domElement);\n break;\n default:\n props = rawProps;\n }\n assertValidProps(tag, props);\n setInitialDOMProperties(tag, domElement, rootContainerElement, props, isCustomComponentTag);\n switch(tag){\n case 'input':\n // TODO: Make sure we check if this is still unmounted or do any clean\n // up necessary since we never stop tracking anymore.\n track(domElement);\n postMountWrapper(domElement, rawProps, false);\n break;\n case 'textarea':\n // TODO: Make sure we check if this is still unmounted or do any clean\n // up necessary since we never stop tracking anymore.\n track(domElement);\n postMountWrapper$3(domElement);\n break;\n case 'option':\n postMountWrapper$1(domElement, rawProps);\n break;\n case 'select':\n postMountWrapper$2(domElement, rawProps);\n break;\n default:\n if (typeof props.onClick === 'function') // TODO: This cast may not be sound for SVG, MathML or custom elements.\n trapClickOnNonInteractiveElement(domElement);\n break;\n }\n } // Calculate the diff between the two objects.\n function diffProperties(domElement, tag, lastRawProps, nextRawProps, rootContainerElement) {\n validatePropertiesInDevelopment(tag, nextRawProps);\n var updatePayload = null;\n var lastProps;\n var nextProps;\n switch(tag){\n case 'input':\n lastProps = getHostProps(domElement, lastRawProps);\n nextProps = getHostProps(domElement, nextRawProps);\n updatePayload = [];\n break;\n case 'option':\n lastProps = getHostProps$1(domElement, lastRawProps);\n nextProps = getHostProps$1(domElement, nextRawProps);\n updatePayload = [];\n break;\n case 'select':\n lastProps = getHostProps$2(domElement, lastRawProps);\n nextProps = getHostProps$2(domElement, nextRawProps);\n updatePayload = [];\n break;\n case 'textarea':\n lastProps = getHostProps$3(domElement, lastRawProps);\n nextProps = getHostProps$3(domElement, nextRawProps);\n updatePayload = [];\n break;\n default:\n lastProps = lastRawProps;\n nextProps = nextRawProps;\n if (typeof lastProps.onClick !== 'function' && typeof nextProps.onClick === 'function') // TODO: This cast may not be sound for SVG, MathML or custom elements.\n trapClickOnNonInteractiveElement(domElement);\n break;\n }\n assertValidProps(tag, nextProps);\n var propKey;\n var styleName;\n var styleUpdates = null;\n for(propKey in lastProps){\n if (nextProps.hasOwnProperty(propKey) || !lastProps.hasOwnProperty(propKey) || lastProps[propKey] == null) continue;\n if (propKey === STYLE) {\n var lastStyle = lastProps[propKey];\n for(styleName in lastStyle)if (lastStyle.hasOwnProperty(styleName)) {\n if (!styleUpdates) styleUpdates = {\n };\n styleUpdates[styleName] = '';\n }\n } else if (propKey === DANGEROUSLY_SET_INNER_HTML || propKey === CHILDREN) ;\n else if (propKey === SUPPRESS_CONTENT_EDITABLE_WARNING || propKey === SUPPRESS_HYDRATION_WARNING) ;\n else if (propKey === AUTOFOCUS) ;\n else if (registrationNameDependencies1.hasOwnProperty(propKey)) // This is a special case. If any listener updates we need to ensure\n // that the \"current\" fiber pointer gets updated so we need a commit\n // to update this element.\n {\n if (!updatePayload) updatePayload = [];\n } else // For all other deleted properties we add it to the queue. We use\n // the allowed property list in the commit phase instead.\n (updatePayload = updatePayload || []).push(propKey, null);\n }\n for(propKey in nextProps){\n var nextProp = nextProps[propKey];\n var lastProp = lastProps != null ? lastProps[propKey] : undefined;\n if (!nextProps.hasOwnProperty(propKey) || nextProp === lastProp || nextProp == null && lastProp == null) continue;\n if (propKey === STYLE) {\n if (nextProp) // Freeze the next style object so that we can assume it won't be\n // mutated. We have already warned for this in the past.\n Object.freeze(nextProp);\n if (lastProp) {\n // Unset styles on `lastProp` but not on `nextProp`.\n for(styleName in lastProp)if (lastProp.hasOwnProperty(styleName) && (!nextProp || !nextProp.hasOwnProperty(styleName))) {\n if (!styleUpdates) styleUpdates = {\n };\n styleUpdates[styleName] = '';\n }\n // Update styles that changed since `lastProp`.\n for(styleName in nextProp)if (nextProp.hasOwnProperty(styleName) && lastProp[styleName] !== nextProp[styleName]) {\n if (!styleUpdates) styleUpdates = {\n };\n styleUpdates[styleName] = nextProp[styleName];\n }\n } else {\n // Relies on `updateStylesByID` not mutating `styleUpdates`.\n if (!styleUpdates) {\n if (!updatePayload) updatePayload = [];\n updatePayload.push(propKey, styleUpdates);\n }\n styleUpdates = nextProp;\n }\n } else if (propKey === DANGEROUSLY_SET_INNER_HTML) {\n var nextHtml = nextProp ? nextProp[HTML$1] : undefined;\n var lastHtml = lastProp ? lastProp[HTML$1] : undefined;\n if (nextHtml != null) {\n if (lastHtml !== nextHtml) (updatePayload = updatePayload || []).push(propKey, nextHtml);\n }\n } else if (propKey === CHILDREN) {\n if (typeof nextProp === 'string' || typeof nextProp === 'number') (updatePayload = updatePayload || []).push(propKey, '' + nextProp);\n } else if (propKey === SUPPRESS_CONTENT_EDITABLE_WARNING || propKey === SUPPRESS_HYDRATION_WARNING) ;\n else if (registrationNameDependencies1.hasOwnProperty(propKey)) {\n if (nextProp != null) {\n // We eagerly listen to this even though we haven't committed yet.\n if (typeof nextProp !== 'function') warnForInvalidEventListener(propKey, nextProp);\n if (propKey === 'onScroll') listenToNonDelegatedEvent('scroll', domElement);\n }\n if (!updatePayload && lastProp !== nextProp) // This is a special case. If any listener updates we need to ensure\n // that the \"current\" props pointer gets updated so we need a commit\n // to update this element.\n updatePayload = [];\n } else if (typeof nextProp === 'object' && nextProp !== null && nextProp.$$typeof === REACT_OPAQUE_ID_TYPE) // If we encounter useOpaqueReference's opaque object, this means we are hydrating.\n // In this case, call the opaque object's toString function which generates a new client\n // ID so client and server IDs match and throws to rerender.\n nextProp.toString();\n else // For any other property we always add it to the queue and then we\n // filter it out using the allowed property list during the commit.\n (updatePayload = updatePayload || []).push(propKey, nextProp);\n }\n if (styleUpdates) {\n validateShorthandPropertyCollisionInDev(styleUpdates, nextProps[STYLE]);\n (updatePayload = updatePayload || []).push(STYLE, styleUpdates);\n }\n return updatePayload;\n } // Apply the diff.\n function updateProperties(domElement, updatePayload, tag, lastRawProps, nextRawProps) {\n // Update checked *before* name.\n // In the middle of an update, it is possible to have multiple checked.\n // When a checked radio tries to change name, browser makes another radio's checked false.\n if (tag === 'input' && nextRawProps.type === 'radio' && nextRawProps.name != null) updateChecked(domElement, nextRawProps);\n var wasCustomComponentTag = isCustomComponent(tag, lastRawProps);\n var isCustomComponentTag = isCustomComponent(tag, nextRawProps); // Apply the diff.\n updateDOMProperties(domElement, updatePayload, wasCustomComponentTag, isCustomComponentTag); // TODO: Ensure that an update gets scheduled if any of the special props\n // changed.\n switch(tag){\n case 'input':\n // Update the wrapper around inputs *after* updating props. This has to\n // happen after `updateDOMProperties`. Otherwise HTML5 input validations\n // raise warnings and prevent the new value from being assigned.\n updateWrapper(domElement, nextRawProps);\n break;\n case 'textarea':\n updateWrapper$1(domElement, nextRawProps);\n break;\n case 'select':\n // <select> value update needs to occur after <option> children\n // reconciliation\n postUpdateWrapper(domElement, nextRawProps);\n break;\n }\n }\n function getPossibleStandardName(propName) {\n var lowerCasedName = propName.toLowerCase();\n if (!possibleStandardNames.hasOwnProperty(lowerCasedName)) return null;\n return possibleStandardNames[lowerCasedName] || null;\n }\n function diffHydratedProperties(domElement, tag, rawProps, parentNamespace, rootContainerElement) {\n var isCustomComponentTag;\n var extraAttributeNames;\n suppressHydrationWarning = rawProps[SUPPRESS_HYDRATION_WARNING] === true;\n isCustomComponentTag = isCustomComponent(tag, rawProps);\n validatePropertiesInDevelopment(tag, rawProps);\n switch(tag){\n case 'dialog':\n listenToNonDelegatedEvent('cancel', domElement);\n listenToNonDelegatedEvent('close', domElement);\n break;\n case 'iframe':\n case 'object':\n case 'embed':\n // We listen to this event in case to ensure emulated bubble\n // listeners still fire for the load event.\n listenToNonDelegatedEvent('load', domElement);\n break;\n case 'video':\n case 'audio':\n // We listen to these events in case to ensure emulated bubble\n // listeners still fire for all the media events.\n for(var i = 0; i < mediaEventTypes.length; i++)listenToNonDelegatedEvent(mediaEventTypes[i], domElement);\n break;\n case 'source':\n // We listen to this event in case to ensure emulated bubble\n // listeners still fire for the error event.\n listenToNonDelegatedEvent('error', domElement);\n break;\n case 'img':\n case 'image':\n case 'link':\n // We listen to these events in case to ensure emulated bubble\n // listeners still fire for error and load events.\n listenToNonDelegatedEvent('error', domElement);\n listenToNonDelegatedEvent('load', domElement);\n break;\n case 'details':\n // We listen to this event in case to ensure emulated bubble\n // listeners still fire for the toggle event.\n listenToNonDelegatedEvent('toggle', domElement);\n break;\n case 'input':\n initWrapperState(domElement, rawProps); // We listen to this event in case to ensure emulated bubble\n // listeners still fire for the invalid event.\n listenToNonDelegatedEvent('invalid', domElement);\n break;\n case 'option':\n validateProps(domElement, rawProps);\n break;\n case 'select':\n initWrapperState$1(domElement, rawProps); // We listen to this event in case to ensure emulated bubble\n // listeners still fire for the invalid event.\n listenToNonDelegatedEvent('invalid', domElement);\n break;\n case 'textarea':\n initWrapperState$2(domElement, rawProps); // We listen to this event in case to ensure emulated bubble\n // listeners still fire for the invalid event.\n listenToNonDelegatedEvent('invalid', domElement);\n break;\n }\n assertValidProps(tag, rawProps);\n extraAttributeNames = new Set();\n var attributes = domElement.attributes;\n for(var _i = 0; _i < attributes.length; _i++){\n var name = attributes[_i].name.toLowerCase();\n switch(name){\n // Built-in SSR attribute is allowed\n case 'data-reactroot':\n break;\n // Controlled attributes are not validated\n // TODO: Only ignore them on controlled tags.\n case 'value':\n break;\n case 'checked':\n break;\n case 'selected':\n break;\n default:\n // Intentionally use the original name.\n // See discussion in https://github.com/facebook/react/pull/10676.\n extraAttributeNames.add(attributes[_i].name);\n }\n }\n var updatePayload = null;\n for(var propKey in rawProps){\n if (!rawProps.hasOwnProperty(propKey)) continue;\n var nextProp = rawProps[propKey];\n if (propKey === CHILDREN) {\n // For text content children we compare against textContent. This\n // might match additional HTML that is hidden when we read it using\n // textContent. E.g. \"foo\" will match \"f<span>oo</span>\" but that still\n // satisfies our requirement. Our requirement is not to produce perfect\n // HTML and attributes. Ideally we should preserve structure but it's\n // ok not to if the visible content is still enough to indicate what\n // even listeners these nodes might be wired up to.\n // TODO: Warn if there is more than a single textNode as a child.\n // TODO: Should we use domElement.firstChild.nodeValue to compare?\n if (typeof nextProp === 'string') {\n if (domElement.textContent !== nextProp) {\n if (!suppressHydrationWarning) warnForTextDifference(domElement.textContent, nextProp);\n updatePayload = [\n CHILDREN,\n nextProp\n ];\n }\n } else if (typeof nextProp === 'number') {\n if (domElement.textContent !== '' + nextProp) {\n if (!suppressHydrationWarning) warnForTextDifference(domElement.textContent, nextProp);\n updatePayload = [\n CHILDREN,\n '' + nextProp\n ];\n }\n }\n } else if (registrationNameDependencies1.hasOwnProperty(propKey)) {\n if (nextProp != null) {\n if (typeof nextProp !== 'function') warnForInvalidEventListener(propKey, nextProp);\n if (propKey === 'onScroll') listenToNonDelegatedEvent('scroll', domElement);\n }\n } else if (typeof isCustomComponentTag === 'boolean') {\n // Validate that the properties correspond to their expected values.\n var serverValue = void 0;\n var propertyInfo = getPropertyInfo(propKey);\n if (suppressHydrationWarning) ;\n else if (propKey === SUPPRESS_CONTENT_EDITABLE_WARNING || propKey === SUPPRESS_HYDRATION_WARNING || // TODO: Only ignore them on controlled tags.\n propKey === 'value' || propKey === 'checked' || propKey === 'selected') ;\n else if (propKey === DANGEROUSLY_SET_INNER_HTML) {\n var serverHTML = domElement.innerHTML;\n var nextHtml = nextProp ? nextProp[HTML$1] : undefined;\n if (nextHtml != null) {\n var expectedHTML = normalizeHTML(domElement, nextHtml);\n if (expectedHTML !== serverHTML) warnForPropDifference(propKey, serverHTML, expectedHTML);\n }\n } else if (propKey === STYLE) {\n // $FlowFixMe - Should be inferred as not undefined.\n extraAttributeNames.delete(propKey);\n if (canDiffStyleForHydrationWarning) {\n var expectedStyle = createDangerousStringForStyles(nextProp);\n serverValue = domElement.getAttribute('style');\n if (expectedStyle !== serverValue) warnForPropDifference(propKey, serverValue, expectedStyle);\n }\n } else if (isCustomComponentTag) {\n // $FlowFixMe - Should be inferred as not undefined.\n extraAttributeNames.delete(propKey.toLowerCase());\n serverValue = getValueForAttribute(domElement, propKey, nextProp);\n if (nextProp !== serverValue) warnForPropDifference(propKey, serverValue, nextProp);\n } else if (!shouldIgnoreAttribute(propKey, propertyInfo, isCustomComponentTag) && !shouldRemoveAttribute(propKey, nextProp, propertyInfo, isCustomComponentTag)) {\n var isMismatchDueToBadCasing = false;\n if (propertyInfo !== null) {\n // $FlowFixMe - Should be inferred as not undefined.\n extraAttributeNames.delete(propertyInfo.attributeName);\n serverValue = getValueForProperty(domElement, propKey, nextProp, propertyInfo);\n } else {\n var ownNamespace = parentNamespace;\n if (ownNamespace === HTML_NAMESPACE$1) ownNamespace = getIntrinsicNamespace(tag);\n if (ownNamespace === HTML_NAMESPACE$1) // $FlowFixMe - Should be inferred as not undefined.\n extraAttributeNames.delete(propKey.toLowerCase());\n else {\n var standardName = getPossibleStandardName(propKey);\n if (standardName !== null && standardName !== propKey) {\n // If an SVG prop is supplied with bad casing, it will\n // be successfully parsed from HTML, but will produce a mismatch\n // (and would be incorrectly rendered on the client).\n // However, we already warn about bad casing elsewhere.\n // So we'll skip the misleading extra mismatch warning in this case.\n isMismatchDueToBadCasing = true; // $FlowFixMe - Should be inferred as not undefined.\n extraAttributeNames.delete(standardName);\n } // $FlowFixMe - Should be inferred as not undefined.\n extraAttributeNames.delete(propKey);\n }\n serverValue = getValueForAttribute(domElement, propKey, nextProp);\n }\n if (nextProp !== serverValue && !isMismatchDueToBadCasing) warnForPropDifference(propKey, serverValue, nextProp);\n }\n }\n }\n // $FlowFixMe - Should be inferred as not undefined.\n if (extraAttributeNames.size > 0 && !suppressHydrationWarning) // $FlowFixMe - Should be inferred as not undefined.\n warnForExtraAttributes(extraAttributeNames);\n switch(tag){\n case 'input':\n // TODO: Make sure we check if this is still unmounted or do any clean\n // up necessary since we never stop tracking anymore.\n track(domElement);\n postMountWrapper(domElement, rawProps, true);\n break;\n case 'textarea':\n // TODO: Make sure we check if this is still unmounted or do any clean\n // up necessary since we never stop tracking anymore.\n track(domElement);\n postMountWrapper$3(domElement);\n break;\n case 'select':\n case 'option':\n break;\n default:\n if (typeof rawProps.onClick === 'function') // TODO: This cast may not be sound for SVG, MathML or custom elements.\n trapClickOnNonInteractiveElement(domElement);\n break;\n }\n return updatePayload;\n }\n function diffHydratedText(textNode, text) {\n var isDifferent = textNode.nodeValue !== text;\n return isDifferent;\n }\n function warnForUnmatchedText(textNode, text) {\n warnForTextDifference(textNode.nodeValue, text);\n }\n function warnForDeletedHydratableElement(parentNode, child) {\n if (didWarnInvalidHydration) return;\n didWarnInvalidHydration = true;\n error1('Did not expect server HTML to contain a <%s> in <%s>.', child.nodeName.toLowerCase(), parentNode.nodeName.toLowerCase());\n }\n function warnForDeletedHydratableText(parentNode, child) {\n if (didWarnInvalidHydration) return;\n didWarnInvalidHydration = true;\n error1('Did not expect server HTML to contain the text node \"%s\" in <%s>.', child.nodeValue, parentNode.nodeName.toLowerCase());\n }\n function warnForInsertedHydratedElement(parentNode, tag, props) {\n if (didWarnInvalidHydration) return;\n didWarnInvalidHydration = true;\n error1('Expected server HTML to contain a matching <%s> in <%s>.', tag, parentNode.nodeName.toLowerCase());\n }\n function warnForInsertedHydratedText(parentNode, text) {\n if (text === '') // We expect to insert empty text nodes since they're not represented in\n // the HTML.\n // TODO: Remove this special case if we can just avoid inserting empty\n // text nodes.\n return;\n if (didWarnInvalidHydration) return;\n didWarnInvalidHydration = true;\n error1('Expected server HTML to contain a matching text node for \"%s\" in <%s>.', text, parentNode.nodeName.toLowerCase());\n }\n function restoreControlledState$3(domElement, tag, props) {\n switch(tag){\n case 'input':\n restoreControlledState(domElement, props);\n return;\n case 'textarea':\n restoreControlledState$2(domElement, props);\n return;\n case 'select':\n restoreControlledState$1(domElement, props);\n return;\n }\n }\n var validateDOMNesting = function() {\n };\n var updatedAncestorInfo = function() {\n };\n // This validation code was written based on the HTML5 parsing spec:\n // https://html.spec.whatwg.org/multipage/syntax.html#has-an-element-in-scope\n //\n // Note: this does not catch all invalid nesting, nor does it try to (as it's\n // not clear what practical benefit doing so provides); instead, we warn only\n // for cases where the parser will give a parse tree differing from what React\n // intended. For example, <b><div></div></b> is invalid but we don't warn\n // because it still parses correctly; we do warn for other cases like nested\n // <p> tags where the beginning of the second element implicitly closes the\n // first, causing a confusing mess.\n // https://html.spec.whatwg.org/multipage/syntax.html#special\n var specialTags = [\n 'address',\n 'applet',\n 'area',\n 'article',\n 'aside',\n 'base',\n 'basefont',\n 'bgsound',\n 'blockquote',\n 'body',\n 'br',\n 'button',\n 'caption',\n 'center',\n 'col',\n 'colgroup',\n 'dd',\n 'details',\n 'dir',\n 'div',\n 'dl',\n 'dt',\n 'embed',\n 'fieldset',\n 'figcaption',\n 'figure',\n 'footer',\n 'form',\n 'frame',\n 'frameset',\n 'h1',\n 'h2',\n 'h3',\n 'h4',\n 'h5',\n 'h6',\n 'head',\n 'header',\n 'hgroup',\n 'hr',\n 'html',\n 'iframe',\n 'img',\n 'input',\n 'isindex',\n 'li',\n 'link',\n 'listing',\n 'main',\n 'marquee',\n 'menu',\n 'menuitem',\n 'meta',\n 'nav',\n 'noembed',\n 'noframes',\n 'noscript',\n 'object',\n 'ol',\n 'p',\n 'param',\n 'plaintext',\n 'pre',\n 'script',\n 'section',\n 'select',\n 'source',\n 'style',\n 'summary',\n 'table',\n 'tbody',\n 'td',\n 'template',\n 'textarea',\n 'tfoot',\n 'th',\n 'thead',\n 'title',\n 'tr',\n 'track',\n 'ul',\n 'wbr',\n 'xmp'\n ]; // https://html.spec.whatwg.org/multipage/syntax.html#has-an-element-in-scope\n var inScopeTags = [\n 'applet',\n 'caption',\n 'html',\n 'table',\n 'td',\n 'th',\n 'marquee',\n 'object',\n 'template',\n // TODO: Distinguish by namespace here -- for <title>, including it here\n // errs on the side of fewer warnings\n 'foreignObject',\n 'desc',\n 'title'\n ]; // https://html.spec.whatwg.org/multipage/syntax.html#has-an-element-in-button-scope\n var buttonScopeTags = inScopeTags.concat([\n 'button'\n ]); // https://html.spec.whatwg.org/multipage/syntax.html#generate-implied-end-tags\n var impliedEndTags = [\n 'dd',\n 'dt',\n 'li',\n 'option',\n 'optgroup',\n 'p',\n 'rp',\n 'rt'\n ];\n var emptyAncestorInfo = {\n current: null,\n formTag: null,\n aTagInScope: null,\n buttonTagInScope: null,\n nobrTagInScope: null,\n pTagInButtonScope: null,\n listItemTagAutoclosing: null,\n dlItemTagAutoclosing: null\n };\n updatedAncestorInfo = function(oldInfo, tag) {\n var ancestorInfo = _assign({\n }, oldInfo || emptyAncestorInfo);\n var info = {\n tag: tag\n };\n if (inScopeTags.indexOf(tag) !== -1) {\n ancestorInfo.aTagInScope = null;\n ancestorInfo.buttonTagInScope = null;\n ancestorInfo.nobrTagInScope = null;\n }\n if (buttonScopeTags.indexOf(tag) !== -1) ancestorInfo.pTagInButtonScope = null;\n // See rules for 'li', 'dd', 'dt' start tags in\n // https://html.spec.whatwg.org/multipage/syntax.html#parsing-main-inbody\n if (specialTags.indexOf(tag) !== -1 && tag !== 'address' && tag !== 'div' && tag !== 'p') {\n ancestorInfo.listItemTagAutoclosing = null;\n ancestorInfo.dlItemTagAutoclosing = null;\n }\n ancestorInfo.current = info;\n if (tag === 'form') ancestorInfo.formTag = info;\n if (tag === 'a') ancestorInfo.aTagInScope = info;\n if (tag === 'button') ancestorInfo.buttonTagInScope = info;\n if (tag === 'nobr') ancestorInfo.nobrTagInScope = info;\n if (tag === 'p') ancestorInfo.pTagInButtonScope = info;\n if (tag === 'li') ancestorInfo.listItemTagAutoclosing = info;\n if (tag === 'dd' || tag === 'dt') ancestorInfo.dlItemTagAutoclosing = info;\n return ancestorInfo;\n };\n /**\n * Returns whether\n */ var isTagValidWithParent = function(tag, parentTag) {\n // First, let's check if we're in an unusual parsing mode...\n switch(parentTag){\n // https://html.spec.whatwg.org/multipage/syntax.html#parsing-main-inselect\n case 'select':\n return tag === 'option' || tag === 'optgroup' || tag === '#text';\n case 'optgroup':\n return tag === 'option' || tag === '#text';\n // Strictly speaking, seeing an <option> doesn't mean we're in a <select>\n // but\n case 'option':\n return tag === '#text';\n // https://html.spec.whatwg.org/multipage/syntax.html#parsing-main-intd\n // https://html.spec.whatwg.org/multipage/syntax.html#parsing-main-incaption\n // No special behavior since these rules fall back to \"in body\" mode for\n // all except special table nodes which cause bad parsing behavior anyway.\n // https://html.spec.whatwg.org/multipage/syntax.html#parsing-main-intr\n case 'tr':\n return tag === 'th' || tag === 'td' || tag === 'style' || tag === 'script' || tag === 'template';\n // https://html.spec.whatwg.org/multipage/syntax.html#parsing-main-intbody\n case 'tbody':\n case 'thead':\n case 'tfoot':\n return tag === 'tr' || tag === 'style' || tag === 'script' || tag === 'template';\n // https://html.spec.whatwg.org/multipage/syntax.html#parsing-main-incolgroup\n case 'colgroup':\n return tag === 'col' || tag === 'template';\n // https://html.spec.whatwg.org/multipage/syntax.html#parsing-main-intable\n case 'table':\n return tag === 'caption' || tag === 'colgroup' || tag === 'tbody' || tag === 'tfoot' || tag === 'thead' || tag === 'style' || tag === 'script' || tag === 'template';\n // https://html.spec.whatwg.org/multipage/syntax.html#parsing-main-inhead\n case 'head':\n return tag === 'base' || tag === 'basefont' || tag === 'bgsound' || tag === 'link' || tag === 'meta' || tag === 'title' || tag === 'noscript' || tag === 'noframes' || tag === 'style' || tag === 'script' || tag === 'template';\n // https://html.spec.whatwg.org/multipage/semantics.html#the-html-element\n case 'html':\n return tag === 'head' || tag === 'body' || tag === 'frameset';\n case 'frameset':\n return tag === 'frame';\n case '#document':\n return tag === 'html';\n } // Probably in the \"in body\" parsing mode, so we outlaw only tag combos\n // where the parsing rules cause implicit opens or closes to be added.\n // https://html.spec.whatwg.org/multipage/syntax.html#parsing-main-inbody\n switch(tag){\n case 'h1':\n case 'h2':\n case 'h3':\n case 'h4':\n case 'h5':\n case 'h6':\n return parentTag !== 'h1' && parentTag !== 'h2' && parentTag !== 'h3' && parentTag !== 'h4' && parentTag !== 'h5' && parentTag !== 'h6';\n case 'rp':\n case 'rt':\n return impliedEndTags.indexOf(parentTag) === -1;\n case 'body':\n case 'caption':\n case 'col':\n case 'colgroup':\n case 'frameset':\n case 'frame':\n case 'head':\n case 'html':\n case 'tbody':\n case 'td':\n case 'tfoot':\n case 'th':\n case 'thead':\n case 'tr':\n // These tags are only valid with a few parents that have special child\n // parsing rules -- if we're down here, then none of those matched and\n // so we allow it only if we don't know what the parent is, as all other\n // cases are invalid.\n return parentTag == null;\n }\n return true;\n };\n /**\n * Returns whether\n */ var findInvalidAncestorForTag = function(tag, ancestorInfo) {\n switch(tag){\n case 'address':\n case 'article':\n case 'aside':\n case 'blockquote':\n case 'center':\n case 'details':\n case 'dialog':\n case 'dir':\n case 'div':\n case 'dl':\n case 'fieldset':\n case 'figcaption':\n case 'figure':\n case 'footer':\n case 'header':\n case 'hgroup':\n case 'main':\n case 'menu':\n case 'nav':\n case 'ol':\n case 'p':\n case 'section':\n case 'summary':\n case 'ul':\n case 'pre':\n case 'listing':\n case 'table':\n case 'hr':\n case 'xmp':\n case 'h1':\n case 'h2':\n case 'h3':\n case 'h4':\n case 'h5':\n case 'h6':\n return ancestorInfo.pTagInButtonScope;\n case 'form':\n return ancestorInfo.formTag || ancestorInfo.pTagInButtonScope;\n case 'li':\n return ancestorInfo.listItemTagAutoclosing;\n case 'dd':\n case 'dt':\n return ancestorInfo.dlItemTagAutoclosing;\n case 'button':\n return ancestorInfo.buttonTagInScope;\n case 'a':\n // Spec says something about storing a list of markers, but it sounds\n // equivalent to this check.\n return ancestorInfo.aTagInScope;\n case 'nobr':\n return ancestorInfo.nobrTagInScope;\n }\n return null;\n };\n var didWarn$1 = {\n };\n validateDOMNesting = function(childTag, childText, ancestorInfo) {\n ancestorInfo = ancestorInfo || emptyAncestorInfo;\n var parentInfo = ancestorInfo.current;\n var parentTag = parentInfo && parentInfo.tag;\n if (childText != null) {\n if (childTag != null) error1('validateDOMNesting: when childText is passed, childTag should be null');\n childTag = '#text';\n }\n var invalidParent = isTagValidWithParent(childTag, parentTag) ? null : parentInfo;\n var invalidAncestor = invalidParent ? null : findInvalidAncestorForTag(childTag, ancestorInfo);\n var invalidParentOrAncestor = invalidParent || invalidAncestor;\n if (!invalidParentOrAncestor) return;\n var ancestorTag = invalidParentOrAncestor.tag;\n var warnKey = !!invalidParent + '|' + childTag + '|' + ancestorTag;\n if (didWarn$1[warnKey]) return;\n didWarn$1[warnKey] = true;\n var tagDisplayName = childTag;\n var whitespaceInfo = '';\n if (childTag === '#text') {\n if (/\\S/.test(childText)) tagDisplayName = 'Text nodes';\n else {\n tagDisplayName = 'Whitespace text nodes';\n whitespaceInfo = \" Make sure you don't have any extra whitespace between tags on each line of your source code.\";\n }\n } else tagDisplayName = '<' + childTag + '>';\n if (invalidParent) {\n var info = '';\n if (ancestorTag === 'table' && childTag === 'tr') info += \" Add a <tbody>, <thead> or <tfoot> to your code to match the DOM tree generated by the browser.\";\n error1('validateDOMNesting(...): %s cannot appear as a child of <%s>.%s%s', tagDisplayName, ancestorTag, whitespaceInfo, info);\n } else error1(\"validateDOMNesting(...): %s cannot appear as a descendant of <%s>.\", tagDisplayName, ancestorTag);\n };\n var SUPPRESS_HYDRATION_WARNING$1;\n SUPPRESS_HYDRATION_WARNING$1 = 'suppressHydrationWarning';\n var SUSPENSE_START_DATA = '$';\n var SUSPENSE_END_DATA = '/$';\n var SUSPENSE_PENDING_START_DATA = '$?';\n var SUSPENSE_FALLBACK_START_DATA = '$!';\n var STYLE$1 = 'style';\n var eventsEnabled = null;\n var selectionInformation = null;\n function shouldAutoFocusHostComponent(type, props) {\n switch(type){\n case 'button':\n case 'input':\n case 'select':\n case 'textarea':\n return !!props.autoFocus;\n }\n return false;\n }\n function getRootHostContext(rootContainerInstance) {\n var type;\n var namespace;\n var nodeType = rootContainerInstance.nodeType;\n switch(nodeType){\n case DOCUMENT_NODE:\n case DOCUMENT_FRAGMENT_NODE:\n type = nodeType === DOCUMENT_NODE ? '#document' : '#fragment';\n var root = rootContainerInstance.documentElement;\n namespace = root ? root.namespaceURI : getChildNamespace(null, '');\n break;\n default:\n var container = nodeType === COMMENT_NODE ? rootContainerInstance.parentNode : rootContainerInstance;\n var ownNamespace = container.namespaceURI || null;\n type = container.tagName;\n namespace = getChildNamespace(ownNamespace, type);\n break;\n }\n var validatedTag = type.toLowerCase();\n var ancestorInfo = updatedAncestorInfo(null, validatedTag);\n return {\n namespace: namespace,\n ancestorInfo: ancestorInfo\n };\n }\n function getChildHostContext(parentHostContext, type, rootContainerInstance) {\n var parentHostContextDev = parentHostContext;\n var namespace = getChildNamespace(parentHostContextDev.namespace, type);\n var ancestorInfo = updatedAncestorInfo(parentHostContextDev.ancestorInfo, type);\n return {\n namespace: namespace,\n ancestorInfo: ancestorInfo\n };\n }\n function getPublicInstance(instance) {\n return instance;\n }\n function prepareForCommit(containerInfo) {\n eventsEnabled = isEnabled();\n selectionInformation = getSelectionInformation();\n var activeInstance = null;\n setEnabled(false);\n return activeInstance;\n }\n function resetAfterCommit(containerInfo) {\n restoreSelection(selectionInformation);\n setEnabled(eventsEnabled);\n eventsEnabled = null;\n selectionInformation = null;\n }\n function createInstance(type, props, rootContainerInstance, hostContext, internalInstanceHandle) {\n var parentNamespace;\n // TODO: take namespace into account when validating.\n var hostContextDev = hostContext;\n validateDOMNesting(type, null, hostContextDev.ancestorInfo);\n if (typeof props.children === 'string' || typeof props.children === 'number') {\n var string = '' + props.children;\n var ownAncestorInfo = updatedAncestorInfo(hostContextDev.ancestorInfo, type);\n validateDOMNesting(null, string, ownAncestorInfo);\n }\n parentNamespace = hostContextDev.namespace;\n var domElement = createElement(type, props, rootContainerInstance, parentNamespace);\n precacheFiberNode(internalInstanceHandle, domElement);\n updateFiberProps(domElement, props);\n return domElement;\n }\n function appendInitialChild(parentInstance, child) {\n parentInstance.appendChild(child);\n }\n function finalizeInitialChildren(domElement, type, props, rootContainerInstance, hostContext) {\n setInitialProperties(domElement, type, props, rootContainerInstance);\n return shouldAutoFocusHostComponent(type, props);\n }\n function prepareUpdate(domElement, type, oldProps, newProps, rootContainerInstance, hostContext) {\n var hostContextDev = hostContext;\n if (typeof newProps.children !== typeof oldProps.children && (typeof newProps.children === 'string' || typeof newProps.children === 'number')) {\n var string = '' + newProps.children;\n var ownAncestorInfo = updatedAncestorInfo(hostContextDev.ancestorInfo, type);\n validateDOMNesting(null, string, ownAncestorInfo);\n }\n return diffProperties(domElement, type, oldProps, newProps);\n }\n function shouldSetTextContent(type, props) {\n return type === 'textarea' || type === 'option' || type === 'noscript' || typeof props.children === 'string' || typeof props.children === 'number' || typeof props.dangerouslySetInnerHTML === 'object' && props.dangerouslySetInnerHTML !== null && props.dangerouslySetInnerHTML.__html != null;\n }\n function createTextInstance(text, rootContainerInstance, hostContext, internalInstanceHandle) {\n var hostContextDev = hostContext;\n validateDOMNesting(null, text, hostContextDev.ancestorInfo);\n var textNode = createTextNode(text, rootContainerInstance);\n precacheFiberNode(internalInstanceHandle, textNode);\n return textNode;\n }\n // if a component just imports ReactDOM (e.g. for findDOMNode).\n // Some environments might not have setTimeout or clearTimeout.\n var scheduleTimeout = typeof setTimeout === 'function' ? setTimeout : undefined;\n var cancelTimeout = typeof clearTimeout === 'function' ? clearTimeout : undefined;\n var noTimeout = -1; // -------------------\n function commitMount(domElement, type, newProps, internalInstanceHandle) {\n // Despite the naming that might imply otherwise, this method only\n // fires if there is an `Update` effect scheduled during mounting.\n // This happens if `finalizeInitialChildren` returns `true` (which it\n // does to implement the `autoFocus` attribute on the client). But\n // there are also other cases when this might happen (such as patching\n // up text content during hydration mismatch). So we'll check this again.\n if (shouldAutoFocusHostComponent(type, newProps)) domElement.focus();\n }\n function commitUpdate(domElement, updatePayload, type, oldProps, newProps, internalInstanceHandle) {\n // Update the props handle so that we know which props are the ones with\n // with current event handlers.\n updateFiberProps(domElement, newProps); // Apply the diff to the DOM node.\n updateProperties(domElement, updatePayload, type, oldProps, newProps);\n }\n function resetTextContent(domElement) {\n setTextContent(domElement, '');\n }\n function commitTextUpdate(textInstance, oldText, newText) {\n textInstance.nodeValue = newText;\n }\n function appendChild(parentInstance, child) {\n parentInstance.appendChild(child);\n }\n function appendChildToContainer(container, child) {\n var parentNode;\n if (container.nodeType === COMMENT_NODE) {\n parentNode = container.parentNode;\n parentNode.insertBefore(child, container);\n } else {\n parentNode = container;\n parentNode.appendChild(child);\n } // This container might be used for a portal.\n // If something inside a portal is clicked, that click should bubble\n // through the React tree. However, on Mobile Safari the click would\n // never bubble through the *DOM* tree unless an ancestor with onclick\n // event exists. So we wouldn't see it and dispatch it.\n // This is why we ensure that non React root containers have inline onclick\n // defined.\n // https://github.com/facebook/react/issues/11918\n var reactRootContainer = container._reactRootContainer;\n if ((reactRootContainer === null || reactRootContainer === undefined) && parentNode.onclick === null) // TODO: This cast may not be sound for SVG, MathML or custom elements.\n trapClickOnNonInteractiveElement(parentNode);\n }\n function insertBefore(parentInstance, child, beforeChild) {\n parentInstance.insertBefore(child, beforeChild);\n }\n function insertInContainerBefore(container, child, beforeChild) {\n if (container.nodeType === COMMENT_NODE) container.parentNode.insertBefore(child, beforeChild);\n else container.insertBefore(child, beforeChild);\n }\n function removeChild(parentInstance, child) {\n parentInstance.removeChild(child);\n }\n function removeChildFromContainer(container, child) {\n if (container.nodeType === COMMENT_NODE) container.parentNode.removeChild(child);\n else container.removeChild(child);\n }\n function hideInstance(instance) {\n var style = instance.style;\n if (typeof style.setProperty === 'function') style.setProperty('display', 'none', 'important');\n else style.display = 'none';\n }\n function hideTextInstance(textInstance) {\n textInstance.nodeValue = '';\n }\n function unhideInstance(instance, props) {\n var styleProp = props[STYLE$1];\n var display = styleProp !== undefined && styleProp !== null && styleProp.hasOwnProperty('display') ? styleProp.display : null;\n instance.style.display = dangerousStyleValue('display', display);\n }\n function unhideTextInstance(textInstance, text) {\n textInstance.nodeValue = text;\n }\n function clearContainer(container) {\n if (container.nodeType === ELEMENT_NODE) container.textContent = '';\n else if (container.nodeType === DOCUMENT_NODE) {\n var body = container.body;\n if (body != null) body.textContent = '';\n }\n } // -------------------\n function canHydrateInstance(instance, type, props) {\n if (instance.nodeType !== ELEMENT_NODE || type.toLowerCase() !== instance.nodeName.toLowerCase()) return null;\n // This has now been refined to an element node.\n return instance;\n }\n function canHydrateTextInstance(instance, text) {\n if (text === '' || instance.nodeType !== TEXT_NODE) // Empty strings are not parsed by HTML so there won't be a correct match here.\n return null;\n // This has now been refined to a text node.\n return instance;\n }\n function isSuspenseInstancePending(instance) {\n return instance.data === SUSPENSE_PENDING_START_DATA;\n }\n function isSuspenseInstanceFallback(instance) {\n return instance.data === SUSPENSE_FALLBACK_START_DATA;\n }\n function getNextHydratable(node) {\n // Skip non-hydratable nodes.\n for(; node != null; node = node.nextSibling){\n var nodeType = node.nodeType;\n if (nodeType === ELEMENT_NODE || nodeType === TEXT_NODE) break;\n }\n return node;\n }\n function getNextHydratableSibling(instance) {\n return getNextHydratable(instance.nextSibling);\n }\n function getFirstHydratableChild(parentInstance) {\n return getNextHydratable(parentInstance.firstChild);\n }\n function hydrateInstance(instance, type, props, rootContainerInstance, hostContext, internalInstanceHandle) {\n precacheFiberNode(internalInstanceHandle, instance); // TODO: Possibly defer this until the commit phase where all the events\n // get attached.\n updateFiberProps(instance, props);\n var parentNamespace;\n var hostContextDev = hostContext;\n parentNamespace = hostContextDev.namespace;\n return diffHydratedProperties(instance, type, props, parentNamespace);\n }\n function hydrateTextInstance(textInstance, text, internalInstanceHandle) {\n precacheFiberNode(internalInstanceHandle, textInstance);\n return diffHydratedText(textInstance, text);\n }\n function getNextHydratableInstanceAfterSuspenseInstance(suspenseInstance) {\n var node = suspenseInstance.nextSibling; // Skip past all nodes within this suspense boundary.\n // There might be nested nodes so we need to keep track of how\n // deep we are and only break out when we're back on top.\n var depth = 0;\n while(node){\n if (node.nodeType === COMMENT_NODE) {\n var data = node.data;\n if (data === SUSPENSE_END_DATA) {\n if (depth === 0) return getNextHydratableSibling(node);\n else depth--;\n } else if (data === SUSPENSE_START_DATA || data === SUSPENSE_FALLBACK_START_DATA || data === SUSPENSE_PENDING_START_DATA) depth++;\n }\n node = node.nextSibling;\n } // TODO: Warn, we didn't find the end comment boundary.\n return null;\n } // Returns the SuspenseInstance if this node is a direct child of a\n // SuspenseInstance. I.e. if its previous sibling is a Comment with\n // SUSPENSE_x_START_DATA. Otherwise, null.\n function getParentSuspenseInstance(targetInstance) {\n var node = targetInstance.previousSibling; // Skip past all nodes within this suspense boundary.\n // There might be nested nodes so we need to keep track of how\n // deep we are and only break out when we're back on top.\n var depth = 0;\n while(node){\n if (node.nodeType === COMMENT_NODE) {\n var data = node.data;\n if (data === SUSPENSE_START_DATA || data === SUSPENSE_FALLBACK_START_DATA || data === SUSPENSE_PENDING_START_DATA) {\n if (depth === 0) return node;\n else depth--;\n } else if (data === SUSPENSE_END_DATA) depth++;\n }\n node = node.previousSibling;\n }\n return null;\n }\n function commitHydratedContainer(container) {\n // Retry if any event replaying was blocked on this.\n retryIfBlockedOn(container);\n }\n function commitHydratedSuspenseInstance(suspenseInstance) {\n // Retry if any event replaying was blocked on this.\n retryIfBlockedOn(suspenseInstance);\n }\n function didNotMatchHydratedContainerTextInstance(parentContainer, textInstance, text) {\n warnForUnmatchedText(textInstance, text);\n }\n function didNotMatchHydratedTextInstance(parentType, parentProps, parentInstance, textInstance, text) {\n if (parentProps[SUPPRESS_HYDRATION_WARNING$1] !== true) warnForUnmatchedText(textInstance, text);\n }\n function didNotHydrateContainerInstance(parentContainer, instance) {\n if (instance.nodeType === ELEMENT_NODE) warnForDeletedHydratableElement(parentContainer, instance);\n else if (instance.nodeType === COMMENT_NODE) ;\n else warnForDeletedHydratableText(parentContainer, instance);\n }\n function didNotHydrateInstance(parentType, parentProps, parentInstance, instance) {\n if (parentProps[SUPPRESS_HYDRATION_WARNING$1] !== true) {\n if (instance.nodeType === ELEMENT_NODE) warnForDeletedHydratableElement(parentInstance, instance);\n else if (instance.nodeType === COMMENT_NODE) ;\n else warnForDeletedHydratableText(parentInstance, instance);\n }\n }\n function didNotFindHydratableContainerInstance(parentContainer, type, props) {\n warnForInsertedHydratedElement(parentContainer, type);\n }\n function didNotFindHydratableContainerTextInstance(parentContainer, text) {\n warnForInsertedHydratedText(parentContainer, text);\n }\n function didNotFindHydratableInstance(parentType, parentProps, parentInstance, type, props) {\n if (parentProps[SUPPRESS_HYDRATION_WARNING$1] !== true) warnForInsertedHydratedElement(parentInstance, type);\n }\n function didNotFindHydratableTextInstance(parentType, parentProps, parentInstance, text) {\n if (parentProps[SUPPRESS_HYDRATION_WARNING$1] !== true) warnForInsertedHydratedText(parentInstance, text);\n }\n function didNotFindHydratableSuspenseInstance(parentType, parentProps, parentInstance) {\n parentProps[SUPPRESS_HYDRATION_WARNING$1];\n }\n var clientId = 0;\n function makeClientIdInDEV(warnOnAccessInDEV) {\n var id = 'r:' + (clientId++).toString(36);\n return {\n toString: function() {\n warnOnAccessInDEV();\n return id;\n },\n valueOf: function() {\n warnOnAccessInDEV();\n return id;\n }\n };\n }\n function isOpaqueHydratingObject(value) {\n return value !== null && typeof value === 'object' && value.$$typeof === REACT_OPAQUE_ID_TYPE;\n }\n function makeOpaqueHydratingObject(attemptToReadValue) {\n return {\n $$typeof: REACT_OPAQUE_ID_TYPE,\n toString: attemptToReadValue,\n valueOf: attemptToReadValue\n };\n }\n function preparePortalMount(portalInstance) {\n listenToAllSupportedEvents(portalInstance);\n }\n var randomKey = Math.random().toString(36).slice(2);\n var internalInstanceKey = '__reactFiber$' + randomKey;\n var internalPropsKey = '__reactProps$' + randomKey;\n var internalContainerInstanceKey = '__reactContainer$' + randomKey;\n var internalEventHandlersKey = '__reactEvents$' + randomKey;\n function precacheFiberNode(hostInst, node) {\n node[internalInstanceKey] = hostInst;\n }\n function markContainerAsRoot(hostRoot, node) {\n node[internalContainerInstanceKey] = hostRoot;\n }\n function unmarkContainerAsRoot(node) {\n node[internalContainerInstanceKey] = null;\n }\n function isContainerMarkedAsRoot(node) {\n return !!node[internalContainerInstanceKey];\n } // Given a DOM node, return the closest HostComponent or HostText fiber ancestor.\n // If the target node is part of a hydrated or not yet rendered subtree, then\n // this may also return a SuspenseComponent or HostRoot to indicate that.\n // Conceptually the HostRoot fiber is a child of the Container node. So if you\n // pass the Container node as the targetNode, you will not actually get the\n // HostRoot back. To get to the HostRoot, you need to pass a child of it.\n // The same thing applies to Suspense boundaries.\n function getClosestInstanceFromNode(targetNode) {\n var targetInst = targetNode[internalInstanceKey];\n if (targetInst) // Don't return HostRoot or SuspenseComponent here.\n return targetInst;\n // If the direct event target isn't a React owned DOM node, we need to look\n // to see if one of its parents is a React owned DOM node.\n var parentNode = targetNode.parentNode;\n while(parentNode){\n // We'll check if this is a container root that could include\n // React nodes in the future. We need to check this first because\n // if we're a child of a dehydrated container, we need to first\n // find that inner container before moving on to finding the parent\n // instance. Note that we don't check this field on the targetNode\n // itself because the fibers are conceptually between the container\n // node and the first child. It isn't surrounding the container node.\n // If it's not a container, we check if it's an instance.\n targetInst = parentNode[internalContainerInstanceKey] || parentNode[internalInstanceKey];\n if (targetInst) {\n // Since this wasn't the direct target of the event, we might have\n // stepped past dehydrated DOM nodes to get here. However they could\n // also have been non-React nodes. We need to answer which one.\n // If we the instance doesn't have any children, then there can't be\n // a nested suspense boundary within it. So we can use this as a fast\n // bailout. Most of the time, when people add non-React children to\n // the tree, it is using a ref to a child-less DOM node.\n // Normally we'd only need to check one of the fibers because if it\n // has ever gone from having children to deleting them or vice versa\n // it would have deleted the dehydrated boundary nested inside already.\n // However, since the HostRoot starts out with an alternate it might\n // have one on the alternate so we need to check in case this was a\n // root.\n var alternate = targetInst.alternate;\n if (targetInst.child !== null || alternate !== null && alternate.child !== null) {\n // Next we need to figure out if the node that skipped past is\n // nested within a dehydrated boundary and if so, which one.\n var suspenseInstance = getParentSuspenseInstance(targetNode);\n while(suspenseInstance !== null){\n // We found a suspense instance. That means that we haven't\n // hydrated it yet. Even though we leave the comments in the\n // DOM after hydrating, and there are boundaries in the DOM\n // that could already be hydrated, we wouldn't have found them\n // through this pass since if the target is hydrated it would\n // have had an internalInstanceKey on it.\n // Let's get the fiber associated with the SuspenseComponent\n // as the deepest instance.\n var targetSuspenseInst = suspenseInstance[internalInstanceKey];\n if (targetSuspenseInst) return targetSuspenseInst;\n // If we don't find a Fiber on the comment, it might be because\n // we haven't gotten to hydrate it yet. There might still be a\n // parent boundary that hasn't above this one so we need to find\n // the outer most that is known.\n suspenseInstance = getParentSuspenseInstance(suspenseInstance); // If we don't find one, then that should mean that the parent\n // host component also hasn't hydrated yet. We can return it\n // below since it will bail out on the isMounted check later.\n }\n }\n return targetInst;\n }\n targetNode = parentNode;\n parentNode = targetNode.parentNode;\n }\n return null;\n }\n /**\n * Given a DOM node, return the ReactDOMComponent or ReactDOMTextComponent\n * instance, or null if the node was not rendered by this React.\n */ function getInstanceFromNode(node) {\n var inst = node[internalInstanceKey] || node[internalContainerInstanceKey];\n if (inst) {\n if (inst.tag === HostComponent || inst.tag === HostText || inst.tag === SuspenseComponent || inst.tag === HostRoot) return inst;\n else return null;\n }\n return null;\n }\n /**\n * Given a ReactDOMComponent or ReactDOMTextComponent, return the corresponding\n * DOM node.\n */ function getNodeFromInstance(inst) {\n if (inst.tag === HostComponent || inst.tag === HostText) // In Fiber this, is just the state node right now. We assume it will be\n // a host component or host text.\n return inst.stateNode;\n // Without this first invariant, passing a non-DOM-component triggers the next\n throw Error(\"getNodeFromInstance: Invalid argument.\");\n }\n function getFiberCurrentPropsFromNode(node) {\n return node[internalPropsKey] || null;\n }\n function updateFiberProps(node, props) {\n node[internalPropsKey] = props;\n }\n function getEventListenerSet(node) {\n var elementListenerSet = node[internalEventHandlersKey];\n if (elementListenerSet === undefined) elementListenerSet = node[internalEventHandlersKey] = new Set();\n return elementListenerSet;\n }\n var loggedTypeFailures = {\n };\n var ReactDebugCurrentFrame$1 = ReactSharedInternals.ReactDebugCurrentFrame;\n function setCurrentlyValidatingElement(element) {\n if (element) {\n var owner = element._owner;\n var stack = describeUnknownElementTypeFrameInDEV(element.type, element._source, owner ? owner.type : null);\n ReactDebugCurrentFrame$1.setExtraStackFrame(stack);\n } else ReactDebugCurrentFrame$1.setExtraStackFrame(null);\n }\n function checkPropTypes(typeSpecs, values, location, componentName, element) {\n // $FlowFixMe This is okay but Flow doesn't know it.\n var has = Function.call.bind(Object.prototype.hasOwnProperty);\n for(var typeSpecName in typeSpecs)if (has(typeSpecs, typeSpecName)) {\n var error$1 = void 0; // Prop type validation may throw. In case they do, we don't want to\n // fail the render phase where it didn't fail before. So we log it.\n // After these have been cleaned up, we'll let them throw.\n try {\n // This is intentionally an invariant that gets caught. It's the same\n // behavior as without this statement except with a better message.\n if (typeof typeSpecs[typeSpecName] !== 'function') {\n var err = Error((componentName || 'React class') + ': ' + location + ' type `' + typeSpecName + '` is invalid; ' + 'it must be a function, usually from the `prop-types` package, but received `' + typeof typeSpecs[typeSpecName] + '`.' + 'This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.');\n err.name = 'Invariant Violation';\n throw err;\n }\n error$1 = typeSpecs[typeSpecName](values, typeSpecName, componentName, location, null, 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED');\n } catch (ex) {\n error$1 = ex;\n }\n if (error$1 && !(error$1 instanceof Error)) {\n setCurrentlyValidatingElement(element);\n error1(\"%s: type specification of %s `%s` is invalid; the type checker function must return `null` or an `Error` but returned a %s. You may have forgotten to pass an argument to the type checker creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and shape all require an argument).\", componentName || 'React class', location, typeSpecName, typeof error$1);\n setCurrentlyValidatingElement(null);\n }\n if (error$1 instanceof Error && !(error$1.message in loggedTypeFailures)) {\n // Only monitor this failure once because there tends to be a lot of the\n // same error.\n loggedTypeFailures[error$1.message] = true;\n setCurrentlyValidatingElement(element);\n error1('Failed %s type: %s', location, error$1.message);\n setCurrentlyValidatingElement(null);\n }\n }\n }\n var valueStack = [];\n var fiberStack;\n fiberStack = [];\n var index1 = -1;\n function createCursor(defaultValue) {\n return {\n current: defaultValue\n };\n }\n function pop(cursor, fiber) {\n if (index1 < 0) {\n error1('Unexpected pop.');\n return;\n }\n if (fiber !== fiberStack[index1]) error1('Unexpected Fiber popped.');\n cursor.current = valueStack[index1];\n valueStack[index1] = null;\n fiberStack[index1] = null;\n index1--;\n }\n function push(cursor, value, fiber) {\n index1++;\n valueStack[index1] = cursor.current;\n fiberStack[index1] = fiber;\n cursor.current = value;\n }\n var warnedAboutMissingGetChildContext;\n warnedAboutMissingGetChildContext = {\n };\n var emptyContextObject = {\n };\n Object.freeze(emptyContextObject);\n var contextStackCursor = createCursor(emptyContextObject); // A cursor to a boolean indicating whether the context has changed.\n var didPerformWorkStackCursor = createCursor(false); // Keep track of the previous context object that was on the stack.\n // We use this to get access to the parent context after we have already\n // pushed the next context provider, and now need to merge their contexts.\n var previousContext = emptyContextObject;\n function getUnmaskedContext(workInProgress, Component, didPushOwnContextIfProvider) {\n if (didPushOwnContextIfProvider && isContextProvider(Component)) // If the fiber is a context provider itself, when we read its context\n // we may have already pushed its own child context on the stack. A context\n // provider should not \"see\" its own child context. Therefore we read the\n // previous (parent) context instead for a context provider.\n return previousContext;\n return contextStackCursor.current;\n }\n function cacheContext(workInProgress, unmaskedContext, maskedContext) {\n var instance = workInProgress.stateNode;\n instance.__reactInternalMemoizedUnmaskedChildContext = unmaskedContext;\n instance.__reactInternalMemoizedMaskedChildContext = maskedContext;\n }\n function getMaskedContext(workInProgress, unmaskedContext) {\n var type = workInProgress.type;\n var contextTypes = type.contextTypes;\n if (!contextTypes) return emptyContextObject;\n // Avoid recreating masked context unless unmasked context has changed.\n // Failing to do this will result in unnecessary calls to componentWillReceiveProps.\n // This may trigger infinite loops if componentWillReceiveProps calls setState.\n var instance = workInProgress.stateNode;\n if (instance && instance.__reactInternalMemoizedUnmaskedChildContext === unmaskedContext) return instance.__reactInternalMemoizedMaskedChildContext;\n var context = {\n };\n for(var key in contextTypes)context[key] = unmaskedContext[key];\n var name = getComponentName(type) || 'Unknown';\n checkPropTypes(contextTypes, context, 'context', name);\n // Context is created before the class component is instantiated so check for instance.\n if (instance) cacheContext(workInProgress, unmaskedContext, context);\n return context;\n }\n function hasContextChanged() {\n return didPerformWorkStackCursor.current;\n }\n function isContextProvider(type) {\n var childContextTypes = type.childContextTypes;\n return childContextTypes !== null && childContextTypes !== undefined;\n }\n function popContext(fiber) {\n pop(didPerformWorkStackCursor, fiber);\n pop(contextStackCursor, fiber);\n }\n function popTopLevelContextObject(fiber) {\n pop(didPerformWorkStackCursor, fiber);\n pop(contextStackCursor, fiber);\n }\n function pushTopLevelContextObject(fiber, context, didChange) {\n if (!(contextStackCursor.current === emptyContextObject)) throw Error(\"Unexpected context found on stack. This error is likely caused by a bug in React. Please file an issue.\");\n push(contextStackCursor, context, fiber);\n push(didPerformWorkStackCursor, didChange, fiber);\n }\n function processChildContext(fiber, type, parentContext) {\n var instance = fiber.stateNode;\n var childContextTypes = type.childContextTypes; // TODO (bvaughn) Replace this behavior with an invariant() in the future.\n // It has only been added in Fiber to match the (unintentional) behavior in Stack.\n if (typeof instance.getChildContext !== 'function') {\n var componentName = getComponentName(type) || 'Unknown';\n if (!warnedAboutMissingGetChildContext[componentName]) {\n warnedAboutMissingGetChildContext[componentName] = true;\n error1(\"%s.childContextTypes is specified but there is no getChildContext() method on the instance. You can either define getChildContext() on %s or remove childContextTypes from it.\", componentName, componentName);\n }\n return parentContext;\n }\n var childContext = instance.getChildContext();\n for(var contextKey in childContext){\n if (!(contextKey in childContextTypes)) throw Error((getComponentName(type) || 'Unknown') + \".getChildContext(): key \\\"\" + contextKey + \"\\\" is not defined in childContextTypes.\");\n }\n var name = getComponentName(type) || 'Unknown';\n checkPropTypes(childContextTypes, childContext, 'child context', name);\n return _assign({\n }, parentContext, childContext);\n }\n function pushContextProvider(workInProgress) {\n var instance = workInProgress.stateNode; // We push the context as early as possible to ensure stack integrity.\n // If the instance does not exist yet, we will push null at first,\n // and replace it on the stack later when invalidating the context.\n var memoizedMergedChildContext = instance && instance.__reactInternalMemoizedMergedChildContext || emptyContextObject; // Remember the parent context so we can merge with it later.\n // Inherit the parent's did-perform-work value to avoid inadvertently blocking updates.\n previousContext = contextStackCursor.current;\n push(contextStackCursor, memoizedMergedChildContext, workInProgress);\n push(didPerformWorkStackCursor, didPerformWorkStackCursor.current, workInProgress);\n return true;\n }\n function invalidateContextProvider(workInProgress, type, didChange) {\n var instance = workInProgress.stateNode;\n if (!instance) throw Error(\"Expected to have an instance by this point. This error is likely caused by a bug in React. Please file an issue.\");\n if (didChange) {\n // Merge parent and own context.\n // Skip this if we're not updating due to sCU.\n // This avoids unnecessarily recomputing memoized values.\n var mergedContext = processChildContext(workInProgress, type, previousContext);\n instance.__reactInternalMemoizedMergedChildContext = mergedContext; // Replace the old (or empty) context with the new one.\n // It is important to unwind the context in the reverse order.\n pop(didPerformWorkStackCursor, workInProgress);\n pop(contextStackCursor, workInProgress); // Now push the new context and mark that it has changed.\n push(contextStackCursor, mergedContext, workInProgress);\n push(didPerformWorkStackCursor, didChange, workInProgress);\n } else {\n pop(didPerformWorkStackCursor, workInProgress);\n push(didPerformWorkStackCursor, didChange, workInProgress);\n }\n }\n function findCurrentUnmaskedContext(fiber) {\n // Currently this is only used with renderSubtreeIntoContainer; not sure if it\n // makes sense elsewhere\n if (!(isFiberMounted(fiber) && fiber.tag === ClassComponent)) throw Error(\"Expected subtree parent to be a mounted class component. This error is likely caused by a bug in React. Please file an issue.\");\n var node = fiber;\n do {\n switch(node.tag){\n case HostRoot:\n return node.stateNode.context;\n case ClassComponent:\n var Component = node.type;\n if (isContextProvider(Component)) return node.stateNode.__reactInternalMemoizedMergedChildContext;\n break;\n }\n node = node.return;\n }while (node !== null)\n throw Error(\"Found unexpected detached subtree parent. This error is likely caused by a bug in React. Please file an issue.\");\n }\n var LegacyRoot = 0;\n var BlockingRoot = 1;\n var ConcurrentRoot = 2;\n var rendererID = null;\n var injectedHook = null;\n var hasLoggedError = false;\n var isDevToolsPresent = typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ !== 'undefined';\n function injectInternals(internals) {\n if (typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ === 'undefined') // No DevTools\n return false;\n var hook = __REACT_DEVTOOLS_GLOBAL_HOOK__;\n if (hook.isDisabled) // This isn't a real property on the hook, but it can be set to opt out\n // of DevTools integration and associated warnings and logs.\n // https://github.com/facebook/react/issues/3877\n return true;\n if (!hook.supportsFiber) {\n error1(\"The installed version of React DevTools is too old and will not work with the current version of React. Please update React DevTools. https://reactjs.org/link/react-devtools\");\n return true;\n }\n try {\n rendererID = hook.inject(internals); // We have successfully injected, so now it is safe to set up hooks.\n injectedHook = hook;\n } catch (err) {\n error1('React instrumentation encountered an error: %s.', err);\n } // DevTools exists\n return true;\n }\n function onScheduleRoot(root, children) {\n if (injectedHook && typeof injectedHook.onScheduleFiberRoot === 'function') try {\n injectedHook.onScheduleFiberRoot(rendererID, root, children);\n } catch (err) {\n if (!hasLoggedError) {\n hasLoggedError = true;\n error1('React instrumentation encountered an error: %s', err);\n }\n }\n }\n function onCommitRoot(root, priorityLevel) {\n if (injectedHook && typeof injectedHook.onCommitFiberRoot === 'function') try {\n var didError = (root.current.flags & DidCapture) === DidCapture;\n if (enableProfilerTimer) injectedHook.onCommitFiberRoot(rendererID, root, priorityLevel, didError);\n else injectedHook.onCommitFiberRoot(rendererID, root, undefined, didError);\n } catch (err) {\n if (!hasLoggedError) {\n hasLoggedError = true;\n error1('React instrumentation encountered an error: %s', err);\n }\n }\n }\n function onCommitUnmount(fiber) {\n if (injectedHook && typeof injectedHook.onCommitFiberUnmount === 'function') try {\n injectedHook.onCommitFiberUnmount(rendererID, fiber);\n } catch (err) {\n if (!hasLoggedError) {\n hasLoggedError = true;\n error1('React instrumentation encountered an error: %s', err);\n }\n }\n }\n var Scheduler_runWithPriority = Scheduler.unstable_runWithPriority, Scheduler_scheduleCallback = Scheduler.unstable_scheduleCallback, Scheduler_cancelCallback = Scheduler.unstable_cancelCallback, Scheduler_shouldYield = Scheduler.unstable_shouldYield, Scheduler_requestPaint = Scheduler.unstable_requestPaint, Scheduler_now$1 = Scheduler.unstable_now, Scheduler_getCurrentPriorityLevel = Scheduler.unstable_getCurrentPriorityLevel, Scheduler_ImmediatePriority = Scheduler.unstable_ImmediatePriority, Scheduler_UserBlockingPriority = Scheduler.unstable_UserBlockingPriority, Scheduler_NormalPriority = Scheduler.unstable_NormalPriority, Scheduler_LowPriority = Scheduler.unstable_LowPriority, Scheduler_IdlePriority = Scheduler.unstable_IdlePriority;\n // Provide explicit error message when production+profiling bundle of e.g.\n // react-dom is used with production (non-profiling) bundle of\n // scheduler/tracing\n if (!(tracing.__interactionsRef != null && tracing.__interactionsRef.current != null)) throw Error(\"It is not supported to run the profiling version of a renderer (for example, `react-dom/profiling`) without also replacing the `scheduler/tracing` module with `scheduler/tracing-profiling`. Your bundler might have a setting for aliasing both modules. Learn more at https://reactjs.org/link/profiling\");\n var fakeCallbackNode = {\n }; // Except for NoPriority, these correspond to Scheduler priorities. We use\n // ascending numbers so we can compare them like numbers. They start at 90 to\n // avoid clashing with Scheduler's priorities.\n var ImmediatePriority$1 = 99;\n var UserBlockingPriority$2 = 98;\n var NormalPriority$1 = 97;\n var LowPriority$1 = 96;\n var IdlePriority$1 = 95; // NoPriority is the absence of priority. Also React-only.\n var NoPriority$1 = 90;\n var shouldYield = Scheduler_shouldYield;\n var requestPaint = Scheduler_requestPaint !== undefined ? Scheduler_requestPaint : function() {\n };\n var syncQueue = null;\n var immediateQueueCallbackNode = null;\n var isFlushingSyncQueue = false;\n var initialTimeMs$1 = Scheduler_now$1(); // If the initial timestamp is reasonably small, use Scheduler's `now` directly.\n // This will be the case for modern browsers that support `performance.now`. In\n // older browsers, Scheduler falls back to `Date.now`, which returns a Unix\n // timestamp. In that case, subtract the module initialization time to simulate\n // the behavior of performance.now and keep our times small enough to fit\n // within 32 bits.\n // TODO: Consider lifting this into Scheduler.\n var now = initialTimeMs$1 < 10000 ? Scheduler_now$1 : function() {\n return Scheduler_now$1() - initialTimeMs$1;\n };\n function getCurrentPriorityLevel() {\n switch(Scheduler_getCurrentPriorityLevel()){\n case Scheduler_ImmediatePriority:\n return ImmediatePriority$1;\n case Scheduler_UserBlockingPriority:\n return UserBlockingPriority$2;\n case Scheduler_NormalPriority:\n return NormalPriority$1;\n case Scheduler_LowPriority:\n return LowPriority$1;\n case Scheduler_IdlePriority:\n return IdlePriority$1;\n default:\n throw Error(\"Unknown priority level.\");\n }\n }\n function reactPriorityToSchedulerPriority(reactPriorityLevel) {\n switch(reactPriorityLevel){\n case ImmediatePriority$1:\n return Scheduler_ImmediatePriority;\n case UserBlockingPriority$2:\n return Scheduler_UserBlockingPriority;\n case NormalPriority$1:\n return Scheduler_NormalPriority;\n case LowPriority$1:\n return Scheduler_LowPriority;\n case IdlePriority$1:\n return Scheduler_IdlePriority;\n default:\n throw Error(\"Unknown priority level.\");\n }\n }\n function runWithPriority$1(reactPriorityLevel, fn) {\n var priorityLevel = reactPriorityToSchedulerPriority(reactPriorityLevel);\n return Scheduler_runWithPriority(priorityLevel, fn);\n }\n function scheduleCallback(reactPriorityLevel, callback, options) {\n var priorityLevel = reactPriorityToSchedulerPriority(reactPriorityLevel);\n return Scheduler_scheduleCallback(priorityLevel, callback, options);\n }\n function scheduleSyncCallback(callback) {\n // Push this callback into an internal queue. We'll flush these either in\n // the next tick, or earlier if something calls `flushSyncCallbackQueue`.\n if (syncQueue === null) {\n syncQueue = [\n callback\n ]; // Flush the queue in the next tick, at the earliest.\n immediateQueueCallbackNode = Scheduler_scheduleCallback(Scheduler_ImmediatePriority, flushSyncCallbackQueueImpl);\n } else // Push onto existing queue. Don't need to schedule a callback because\n // we already scheduled one when we created the queue.\n syncQueue.push(callback);\n return fakeCallbackNode;\n }\n function cancelCallback(callbackNode) {\n if (callbackNode !== fakeCallbackNode) Scheduler_cancelCallback(callbackNode);\n }\n function flushSyncCallbackQueue() {\n if (immediateQueueCallbackNode !== null) {\n var node = immediateQueueCallbackNode;\n immediateQueueCallbackNode = null;\n Scheduler_cancelCallback(node);\n }\n flushSyncCallbackQueueImpl();\n }\n function flushSyncCallbackQueueImpl() {\n if (!isFlushingSyncQueue && syncQueue !== null) {\n // Prevent re-entrancy.\n isFlushingSyncQueue = true;\n var i = 0;\n try {\n var _isSync2 = true;\n var _queue = syncQueue;\n runWithPriority$1(ImmediatePriority$1, function() {\n for(; i < _queue.length; i++){\n var callback = _queue[i];\n do callback = callback(_isSync2);\n while (callback !== null)\n }\n });\n syncQueue = null;\n } catch (error) {\n // If something throws, leave the remaining callbacks on the queue.\n if (syncQueue !== null) syncQueue = syncQueue.slice(i + 1);\n // Resume flushing in the next tick\n Scheduler_scheduleCallback(Scheduler_ImmediatePriority, flushSyncCallbackQueue);\n throw error;\n } finally{\n isFlushingSyncQueue = false;\n }\n }\n }\n // TODO: this is special because it gets imported during build.\n var ReactVersion = '17.0.2';\n var NoMode = 0;\n var StrictMode = 1; // TODO: Remove BlockingMode and ConcurrentMode by reading from the root\n // tag instead\n var BlockingMode = 2;\n var ConcurrentMode = 4;\n var ProfileMode = 8;\n var DebugTracingMode = 16;\n var ReactCurrentBatchConfig = ReactSharedInternals.ReactCurrentBatchConfig;\n var NoTransition = 0;\n function requestCurrentTransition() {\n return ReactCurrentBatchConfig.transition;\n }\n var ReactStrictModeWarnings = {\n recordUnsafeLifecycleWarnings: function(fiber, instance) {\n },\n flushPendingUnsafeLifecycleWarnings: function() {\n },\n recordLegacyContextWarning: function(fiber, instance) {\n },\n flushLegacyContextWarning: function() {\n },\n discardPendingWarnings: function() {\n }\n };\n var findStrictRoot = function(fiber) {\n var maybeStrictRoot = null;\n var node = fiber;\n while(node !== null){\n if (node.mode & StrictMode) maybeStrictRoot = node;\n node = node.return;\n }\n return maybeStrictRoot;\n };\n var setToSortedString = function(set) {\n var array = [];\n set.forEach(function(value) {\n array.push(value);\n });\n return array.sort().join(', ');\n };\n var pendingComponentWillMountWarnings = [];\n var pendingUNSAFE_ComponentWillMountWarnings = [];\n var pendingComponentWillReceivePropsWarnings = [];\n var pendingUNSAFE_ComponentWillReceivePropsWarnings = [];\n var pendingComponentWillUpdateWarnings = [];\n var pendingUNSAFE_ComponentWillUpdateWarnings = []; // Tracks components we have already warned about.\n var didWarnAboutUnsafeLifecycles = new Set();\n ReactStrictModeWarnings.recordUnsafeLifecycleWarnings = function(fiber, instance) {\n // Dedup strategy: Warn once per component.\n if (didWarnAboutUnsafeLifecycles.has(fiber.type)) return;\n if (typeof instance.componentWillMount === 'function' && instance.componentWillMount.__suppressDeprecationWarning !== true) pendingComponentWillMountWarnings.push(fiber);\n if (fiber.mode & StrictMode && typeof instance.UNSAFE_componentWillMount === 'function') pendingUNSAFE_ComponentWillMountWarnings.push(fiber);\n if (typeof instance.componentWillReceiveProps === 'function' && instance.componentWillReceiveProps.__suppressDeprecationWarning !== true) pendingComponentWillReceivePropsWarnings.push(fiber);\n if (fiber.mode & StrictMode && typeof instance.UNSAFE_componentWillReceiveProps === 'function') pendingUNSAFE_ComponentWillReceivePropsWarnings.push(fiber);\n if (typeof instance.componentWillUpdate === 'function' && instance.componentWillUpdate.__suppressDeprecationWarning !== true) pendingComponentWillUpdateWarnings.push(fiber);\n if (fiber.mode & StrictMode && typeof instance.UNSAFE_componentWillUpdate === 'function') pendingUNSAFE_ComponentWillUpdateWarnings.push(fiber);\n };\n ReactStrictModeWarnings.flushPendingUnsafeLifecycleWarnings = function() {\n // We do an initial pass to gather component names\n var componentWillMountUniqueNames = new Set();\n if (pendingComponentWillMountWarnings.length > 0) {\n pendingComponentWillMountWarnings.forEach(function(fiber) {\n componentWillMountUniqueNames.add(getComponentName(fiber.type) || 'Component');\n didWarnAboutUnsafeLifecycles.add(fiber.type);\n });\n pendingComponentWillMountWarnings = [];\n }\n var UNSAFE_componentWillMountUniqueNames = new Set();\n if (pendingUNSAFE_ComponentWillMountWarnings.length > 0) {\n pendingUNSAFE_ComponentWillMountWarnings.forEach(function(fiber) {\n UNSAFE_componentWillMountUniqueNames.add(getComponentName(fiber.type) || 'Component');\n didWarnAboutUnsafeLifecycles.add(fiber.type);\n });\n pendingUNSAFE_ComponentWillMountWarnings = [];\n }\n var componentWillReceivePropsUniqueNames = new Set();\n if (pendingComponentWillReceivePropsWarnings.length > 0) {\n pendingComponentWillReceivePropsWarnings.forEach(function(fiber) {\n componentWillReceivePropsUniqueNames.add(getComponentName(fiber.type) || 'Component');\n didWarnAboutUnsafeLifecycles.add(fiber.type);\n });\n pendingComponentWillReceivePropsWarnings = [];\n }\n var UNSAFE_componentWillReceivePropsUniqueNames = new Set();\n if (pendingUNSAFE_ComponentWillReceivePropsWarnings.length > 0) {\n pendingUNSAFE_ComponentWillReceivePropsWarnings.forEach(function(fiber) {\n UNSAFE_componentWillReceivePropsUniqueNames.add(getComponentName(fiber.type) || 'Component');\n didWarnAboutUnsafeLifecycles.add(fiber.type);\n });\n pendingUNSAFE_ComponentWillReceivePropsWarnings = [];\n }\n var componentWillUpdateUniqueNames = new Set();\n if (pendingComponentWillUpdateWarnings.length > 0) {\n pendingComponentWillUpdateWarnings.forEach(function(fiber) {\n componentWillUpdateUniqueNames.add(getComponentName(fiber.type) || 'Component');\n didWarnAboutUnsafeLifecycles.add(fiber.type);\n });\n pendingComponentWillUpdateWarnings = [];\n }\n var UNSAFE_componentWillUpdateUniqueNames = new Set();\n if (pendingUNSAFE_ComponentWillUpdateWarnings.length > 0) {\n pendingUNSAFE_ComponentWillUpdateWarnings.forEach(function(fiber) {\n UNSAFE_componentWillUpdateUniqueNames.add(getComponentName(fiber.type) || 'Component');\n didWarnAboutUnsafeLifecycles.add(fiber.type);\n });\n pendingUNSAFE_ComponentWillUpdateWarnings = [];\n } // Finally, we flush all the warnings\n // UNSAFE_ ones before the deprecated ones, since they'll be 'louder'\n if (UNSAFE_componentWillMountUniqueNames.size > 0) {\n var sortedNames = setToSortedString(UNSAFE_componentWillMountUniqueNames);\n error1(\"Using UNSAFE_componentWillMount in strict mode is not recommended and may indicate bugs in your code. See https://reactjs.org/link/unsafe-component-lifecycles for details.\\n\\n* Move code with side effects to componentDidMount, and set initial state in the constructor.\\n\\nPlease update the following components: %s\", sortedNames);\n }\n if (UNSAFE_componentWillReceivePropsUniqueNames.size > 0) {\n var _sortedNames = setToSortedString(UNSAFE_componentWillReceivePropsUniqueNames);\n error1(\"Using UNSAFE_componentWillReceiveProps in strict mode is not recommended and may indicate bugs in your code. See https://reactjs.org/link/unsafe-component-lifecycles for details.\\n\\n* Move data fetching code or side effects to componentDidUpdate.\\n* If you're updating state whenever props change, refactor your code to use memoization techniques or move it to static getDerivedStateFromProps. Learn more at: https://reactjs.org/link/derived-state\\n\\nPlease update the following components: %s\", _sortedNames);\n }\n if (UNSAFE_componentWillUpdateUniqueNames.size > 0) {\n var _sortedNames2 = setToSortedString(UNSAFE_componentWillUpdateUniqueNames);\n error1(\"Using UNSAFE_componentWillUpdate in strict mode is not recommended and may indicate bugs in your code. See https://reactjs.org/link/unsafe-component-lifecycles for details.\\n\\n* Move data fetching code or side effects to componentDidUpdate.\\n\\nPlease update the following components: %s\", _sortedNames2);\n }\n if (componentWillMountUniqueNames.size > 0) {\n var _sortedNames3 = setToSortedString(componentWillMountUniqueNames);\n warn(\"componentWillMount has been renamed, and is not recommended for use. See https://reactjs.org/link/unsafe-component-lifecycles for details.\\n\\n* Move code with side effects to componentDidMount, and set initial state in the constructor.\\n* Rename componentWillMount to UNSAFE_componentWillMount to suppress this warning in non-strict mode. In React 18.x, only the UNSAFE_ name will work. To rename all deprecated lifecycles to their new names, you can run `npx react-codemod rename-unsafe-lifecycles` in your project source folder.\\n\\nPlease update the following components: %s\", _sortedNames3);\n }\n if (componentWillReceivePropsUniqueNames.size > 0) {\n var _sortedNames4 = setToSortedString(componentWillReceivePropsUniqueNames);\n warn(\"componentWillReceiveProps has been renamed, and is not recommended for use. See https://reactjs.org/link/unsafe-component-lifecycles for details.\\n\\n* Move data fetching code or side effects to componentDidUpdate.\\n* If you're updating state whenever props change, refactor your code to use memoization techniques or move it to static getDerivedStateFromProps. Learn more at: https://reactjs.org/link/derived-state\\n* Rename componentWillReceiveProps to UNSAFE_componentWillReceiveProps to suppress this warning in non-strict mode. In React 18.x, only the UNSAFE_ name will work. To rename all deprecated lifecycles to their new names, you can run `npx react-codemod rename-unsafe-lifecycles` in your project source folder.\\n\\nPlease update the following components: %s\", _sortedNames4);\n }\n if (componentWillUpdateUniqueNames.size > 0) {\n var _sortedNames5 = setToSortedString(componentWillUpdateUniqueNames);\n warn(\"componentWillUpdate has been renamed, and is not recommended for use. See https://reactjs.org/link/unsafe-component-lifecycles for details.\\n\\n* Move data fetching code or side effects to componentDidUpdate.\\n* Rename componentWillUpdate to UNSAFE_componentWillUpdate to suppress this warning in non-strict mode. In React 18.x, only the UNSAFE_ name will work. To rename all deprecated lifecycles to their new names, you can run `npx react-codemod rename-unsafe-lifecycles` in your project source folder.\\n\\nPlease update the following components: %s\", _sortedNames5);\n }\n };\n var pendingLegacyContextWarning = new Map(); // Tracks components we have already warned about.\n var didWarnAboutLegacyContext = new Set();\n ReactStrictModeWarnings.recordLegacyContextWarning = function(fiber, instance) {\n var strictRoot = findStrictRoot(fiber);\n if (strictRoot === null) {\n error1(\"Expected to find a StrictMode component in a strict mode tree. This error is likely caused by a bug in React. Please file an issue.\");\n return;\n } // Dedup strategy: Warn once per component.\n if (didWarnAboutLegacyContext.has(fiber.type)) return;\n var warningsForRoot = pendingLegacyContextWarning.get(strictRoot);\n if (fiber.type.contextTypes != null || fiber.type.childContextTypes != null || instance !== null && typeof instance.getChildContext === 'function') {\n if (warningsForRoot === undefined) {\n warningsForRoot = [];\n pendingLegacyContextWarning.set(strictRoot, warningsForRoot);\n }\n warningsForRoot.push(fiber);\n }\n };\n ReactStrictModeWarnings.flushLegacyContextWarning = function() {\n pendingLegacyContextWarning.forEach(function(fiberArray, strictRoot) {\n if (fiberArray.length === 0) return;\n var firstFiber = fiberArray[0];\n var uniqueNames = new Set();\n fiberArray.forEach(function(fiber) {\n uniqueNames.add(getComponentName(fiber.type) || 'Component');\n didWarnAboutLegacyContext.add(fiber.type);\n });\n var sortedNames = setToSortedString(uniqueNames);\n try {\n setCurrentFiber(firstFiber);\n error1(\"Legacy context API has been detected within a strict-mode tree.\\n\\nThe old API will be supported in all 16.x releases, but applications using it should migrate to the new version.\\n\\nPlease update the following components: %s\\n\\nLearn more about this warning here: https://reactjs.org/link/legacy-context\", sortedNames);\n } finally{\n resetCurrentFiber();\n }\n });\n };\n ReactStrictModeWarnings.discardPendingWarnings = function() {\n pendingComponentWillMountWarnings = [];\n pendingUNSAFE_ComponentWillMountWarnings = [];\n pendingComponentWillReceivePropsWarnings = [];\n pendingUNSAFE_ComponentWillReceivePropsWarnings = [];\n pendingComponentWillUpdateWarnings = [];\n pendingUNSAFE_ComponentWillUpdateWarnings = [];\n pendingLegacyContextWarning = new Map();\n };\n function resolveDefaultProps(Component, baseProps) {\n if (Component && Component.defaultProps) {\n // Resolve default props. Taken from ReactElement\n var props = _assign({\n }, baseProps);\n var defaultProps = Component.defaultProps;\n for(var propName in defaultProps)if (props[propName] === undefined) props[propName] = defaultProps[propName];\n return props;\n }\n return baseProps;\n }\n // Max 31 bit integer. The max integer size in V8 for 32-bit systems.\n // Math.pow(2, 30) - 1\n // 0b111111111111111111111111111111\n var MAX_SIGNED_31_BIT_INT = 1073741823;\n var valueCursor = createCursor(null);\n var rendererSigil;\n // Use this to detect multiple renderers using the same context\n rendererSigil = {\n };\n var currentlyRenderingFiber = null;\n var lastContextDependency = null;\n var lastContextWithAllBitsObserved = null;\n var isDisallowedContextReadInDEV = false;\n function resetContextDependencies() {\n // This is called right before React yields execution, to ensure `readContext`\n // cannot be called outside the render phase.\n currentlyRenderingFiber = null;\n lastContextDependency = null;\n lastContextWithAllBitsObserved = null;\n isDisallowedContextReadInDEV = false;\n }\n function enterDisallowedContextReadInDEV() {\n isDisallowedContextReadInDEV = true;\n }\n function exitDisallowedContextReadInDEV() {\n isDisallowedContextReadInDEV = false;\n }\n function pushProvider(providerFiber, nextValue) {\n var context = providerFiber.type._context;\n push(valueCursor, context._currentValue, providerFiber);\n context._currentValue = nextValue;\n if (context._currentRenderer !== undefined && context._currentRenderer !== null && context._currentRenderer !== rendererSigil) error1(\"Detected multiple renderers concurrently rendering the same context provider. This is currently unsupported.\");\n context._currentRenderer = rendererSigil;\n }\n function popProvider(providerFiber) {\n var currentValue = valueCursor.current;\n pop(valueCursor, providerFiber);\n var context = providerFiber.type._context;\n context._currentValue = currentValue;\n }\n function calculateChangedBits(context, newValue, oldValue) {\n if (objectIs(oldValue, newValue)) // No change\n return 0;\n else {\n var changedBits = typeof context._calculateChangedBits === 'function' ? context._calculateChangedBits(oldValue, newValue) : MAX_SIGNED_31_BIT_INT;\n if ((changedBits & MAX_SIGNED_31_BIT_INT) !== changedBits) error1(\"calculateChangedBits: Expected the return value to be a 31-bit integer. Instead received: %s\", changedBits);\n return changedBits | 0;\n }\n }\n function scheduleWorkOnParentPath(parent, renderLanes) {\n // Update the child lanes of all the ancestors, including the alternates.\n var node = parent;\n while(node !== null){\n var alternate = node.alternate;\n if (!isSubsetOfLanes(node.childLanes, renderLanes)) {\n node.childLanes = mergeLanes(node.childLanes, renderLanes);\n if (alternate !== null) alternate.childLanes = mergeLanes(alternate.childLanes, renderLanes);\n } else if (alternate !== null && !isSubsetOfLanes(alternate.childLanes, renderLanes)) alternate.childLanes = mergeLanes(alternate.childLanes, renderLanes);\n else break;\n node = node.return;\n }\n }\n function propagateContextChange(workInProgress, context, changedBits, renderLanes) {\n var fiber = workInProgress.child;\n if (fiber !== null) // Set the return pointer of the child to the work-in-progress fiber.\n fiber.return = workInProgress;\n while(fiber !== null){\n var nextFiber = void 0; // Visit this fiber.\n var list = fiber.dependencies;\n if (list !== null) {\n nextFiber = fiber.child;\n var dependency = list.firstContext;\n while(dependency !== null){\n // Check if the context matches.\n if (dependency.context === context && (dependency.observedBits & changedBits) !== 0) {\n // Match! Schedule an update on this fiber.\n if (fiber.tag === ClassComponent) {\n // Schedule a force update on the work-in-progress.\n var update = createUpdate(NoTimestamp, pickArbitraryLane(renderLanes));\n update.tag = ForceUpdate; // TODO: Because we don't have a work-in-progress, this will add the\n // update to the current fiber, too, which means it will persist even if\n // this render is thrown away. Since it's a race condition, not sure it's\n // worth fixing.\n enqueueUpdate(fiber, update);\n }\n fiber.lanes = mergeLanes(fiber.lanes, renderLanes);\n var alternate = fiber.alternate;\n if (alternate !== null) alternate.lanes = mergeLanes(alternate.lanes, renderLanes);\n scheduleWorkOnParentPath(fiber.return, renderLanes); // Mark the updated lanes on the list, too.\n list.lanes = mergeLanes(list.lanes, renderLanes); // Since we already found a match, we can stop traversing the\n break;\n }\n dependency = dependency.next;\n }\n } else if (fiber.tag === ContextProvider) // Don't scan deeper if this is a matching provider\n nextFiber = fiber.type === workInProgress.type ? null : fiber.child;\n else // Traverse down.\n nextFiber = fiber.child;\n if (nextFiber !== null) // Set the return pointer of the child to the work-in-progress fiber.\n nextFiber.return = fiber;\n else {\n // No child. Traverse to next sibling.\n nextFiber = fiber;\n while(nextFiber !== null){\n if (nextFiber === workInProgress) {\n // We're back to the root of this subtree. Exit.\n nextFiber = null;\n break;\n }\n var sibling = nextFiber.sibling;\n if (sibling !== null) {\n // Set the return pointer of the sibling to the work-in-progress fiber.\n sibling.return = nextFiber.return;\n nextFiber = sibling;\n break;\n } // No more siblings. Traverse up.\n nextFiber = nextFiber.return;\n }\n }\n fiber = nextFiber;\n }\n }\n function prepareToReadContext(workInProgress, renderLanes) {\n currentlyRenderingFiber = workInProgress;\n lastContextDependency = null;\n lastContextWithAllBitsObserved = null;\n var dependencies = workInProgress.dependencies;\n if (dependencies !== null) {\n var firstContext = dependencies.firstContext;\n if (firstContext !== null) {\n if (includesSomeLane(dependencies.lanes, renderLanes)) // Context list has a pending update. Mark that this fiber performed work.\n markWorkInProgressReceivedUpdate();\n // Reset the work-in-progress list\n dependencies.firstContext = null;\n }\n }\n }\n function readContext(context, observedBits) {\n // This warning would fire if you read context inside a Hook like useMemo.\n // Unlike the class check below, it's not enforced in production for perf.\n if (isDisallowedContextReadInDEV) error1(\"Context can only be read while React is rendering. In classes, you can read it in the render method or getDerivedStateFromProps. In function components, you can read it directly in the function body, but not inside Hooks like useReducer() or useMemo().\");\n if (lastContextWithAllBitsObserved === context) ;\n else if (observedBits === false || observedBits === 0) ;\n else {\n var resolvedObservedBits; // Avoid deopting on observable arguments or heterogeneous types.\n if (typeof observedBits !== 'number' || observedBits === MAX_SIGNED_31_BIT_INT) {\n // Observe all updates.\n lastContextWithAllBitsObserved = context;\n resolvedObservedBits = MAX_SIGNED_31_BIT_INT;\n } else resolvedObservedBits = observedBits;\n var contextItem = {\n context: context,\n observedBits: resolvedObservedBits,\n next: null\n };\n if (lastContextDependency === null) {\n if (!(currentlyRenderingFiber !== null)) throw Error(\"Context can only be read while React is rendering. In classes, you can read it in the render method or getDerivedStateFromProps. In function components, you can read it directly in the function body, but not inside Hooks like useReducer() or useMemo().\");\n // This is the first dependency for this component. Create a new list.\n lastContextDependency = contextItem;\n currentlyRenderingFiber.dependencies = {\n lanes: NoLanes,\n firstContext: contextItem,\n responders: null\n };\n } else // Append a new context item.\n lastContextDependency = lastContextDependency.next = contextItem;\n }\n return context._currentValue;\n }\n var UpdateState = 0;\n var ReplaceState = 1;\n var ForceUpdate = 2;\n var CaptureUpdate = 3; // Global state that is reset at the beginning of calling `processUpdateQueue`.\n // It should only be read right after calling `processUpdateQueue`, via\n // `checkHasForceUpdateAfterProcessing`.\n var hasForceUpdate = false;\n var didWarnUpdateInsideUpdate;\n var currentlyProcessingQueue;\n didWarnUpdateInsideUpdate = false;\n currentlyProcessingQueue = null;\n function initializeUpdateQueue(fiber) {\n var queue = {\n baseState: fiber.memoizedState,\n firstBaseUpdate: null,\n lastBaseUpdate: null,\n shared: {\n pending: null\n },\n effects: null\n };\n fiber.updateQueue = queue;\n }\n function cloneUpdateQueue(current, workInProgress) {\n // Clone the update queue from current. Unless it's already a clone.\n var queue = workInProgress.updateQueue;\n var currentQueue = current.updateQueue;\n if (queue === currentQueue) {\n var clone = {\n baseState: currentQueue.baseState,\n firstBaseUpdate: currentQueue.firstBaseUpdate,\n lastBaseUpdate: currentQueue.lastBaseUpdate,\n shared: currentQueue.shared,\n effects: currentQueue.effects\n };\n workInProgress.updateQueue = clone;\n }\n }\n function createUpdate(eventTime, lane) {\n var update = {\n eventTime: eventTime,\n lane: lane,\n tag: UpdateState,\n payload: null,\n callback: null,\n next: null\n };\n return update;\n }\n function enqueueUpdate(fiber, update) {\n var updateQueue = fiber.updateQueue;\n if (updateQueue === null) // Only occurs if the fiber has been unmounted.\n return;\n var sharedQueue = updateQueue.shared;\n var pending = sharedQueue.pending;\n if (pending === null) // This is the first update. Create a circular list.\n update.next = update;\n else {\n update.next = pending.next;\n pending.next = update;\n }\n sharedQueue.pending = update;\n if (currentlyProcessingQueue === sharedQueue && !didWarnUpdateInsideUpdate) {\n error1(\"An update (setState, replaceState, or forceUpdate) was scheduled from inside an update function. Update functions should be pure, with zero side-effects. Consider using componentDidUpdate or a callback.\");\n didWarnUpdateInsideUpdate = true;\n }\n }\n function enqueueCapturedUpdate(workInProgress, capturedUpdate) {\n // Captured updates are updates that are thrown by a child during the render\n // phase. They should be discarded if the render is aborted. Therefore,\n // we should only put them on the work-in-progress queue, not the current one.\n var queue = workInProgress.updateQueue; // Check if the work-in-progress queue is a clone.\n var current = workInProgress.alternate;\n if (current !== null) {\n var currentQueue = current.updateQueue;\n if (queue === currentQueue) {\n // The work-in-progress queue is the same as current. This happens when\n // we bail out on a parent fiber that then captures an error thrown by\n // a child. Since we want to append the update only to the work-in\n // -progress queue, we need to clone the updates. We usually clone during\n // processUpdateQueue, but that didn't happen in this case because we\n // skipped over the parent when we bailed out.\n var newFirst = null;\n var newLast = null;\n var firstBaseUpdate = queue.firstBaseUpdate;\n if (firstBaseUpdate !== null) {\n // Loop through the updates and clone them.\n var update = firstBaseUpdate;\n do {\n var clone = {\n eventTime: update.eventTime,\n lane: update.lane,\n tag: update.tag,\n payload: update.payload,\n callback: update.callback,\n next: null\n };\n if (newLast === null) newFirst = newLast = clone;\n else {\n newLast.next = clone;\n newLast = clone;\n }\n update = update.next;\n }while (update !== null) // Append the captured update the end of the cloned list.\n if (newLast === null) newFirst = newLast = capturedUpdate;\n else {\n newLast.next = capturedUpdate;\n newLast = capturedUpdate;\n }\n } else // There are no base updates.\n newFirst = newLast = capturedUpdate;\n queue = {\n baseState: currentQueue.baseState,\n firstBaseUpdate: newFirst,\n lastBaseUpdate: newLast,\n shared: currentQueue.shared,\n effects: currentQueue.effects\n };\n workInProgress.updateQueue = queue;\n return;\n }\n } // Append the update to the end of the list.\n var lastBaseUpdate = queue.lastBaseUpdate;\n if (lastBaseUpdate === null) queue.firstBaseUpdate = capturedUpdate;\n else lastBaseUpdate.next = capturedUpdate;\n queue.lastBaseUpdate = capturedUpdate;\n }\n function getStateFromUpdate(workInProgress, queue, update, prevState, nextProps, instance) {\n switch(update.tag){\n case ReplaceState:\n var payload = update.payload;\n if (typeof payload === 'function') {\n enterDisallowedContextReadInDEV();\n var nextState = payload.call(instance, prevState, nextProps);\n if (workInProgress.mode & StrictMode) {\n disableLogs();\n try {\n payload.call(instance, prevState, nextProps);\n } finally{\n reenableLogs();\n }\n }\n exitDisallowedContextReadInDEV();\n return nextState;\n } // State object\n return payload;\n case CaptureUpdate:\n workInProgress.flags = workInProgress.flags & ~ShouldCapture | DidCapture;\n // Intentional fallthrough\n case UpdateState:\n var _payload = update.payload;\n var partialState;\n if (typeof _payload === 'function') {\n enterDisallowedContextReadInDEV();\n partialState = _payload.call(instance, prevState, nextProps);\n if (workInProgress.mode & StrictMode) {\n disableLogs();\n try {\n _payload.call(instance, prevState, nextProps);\n } finally{\n reenableLogs();\n }\n }\n exitDisallowedContextReadInDEV();\n } else // Partial state object\n partialState = _payload;\n if (partialState === null || partialState === undefined) // Null and undefined are treated as no-ops.\n return prevState;\n // Merge the partial state and the previous state.\n return _assign({\n }, prevState, partialState);\n case ForceUpdate:\n hasForceUpdate = true;\n return prevState;\n }\n return prevState;\n }\n function processUpdateQueue(workInProgress, props, instance, renderLanes) {\n // This is always non-null on a ClassComponent or HostRoot\n var queue = workInProgress.updateQueue;\n hasForceUpdate = false;\n currentlyProcessingQueue = queue.shared;\n var firstBaseUpdate = queue.firstBaseUpdate;\n var lastBaseUpdate = queue.lastBaseUpdate; // Check if there are pending updates. If so, transfer them to the base queue.\n var pendingQueue = queue.shared.pending;\n if (pendingQueue !== null) {\n queue.shared.pending = null; // The pending queue is circular. Disconnect the pointer between first\n // and last so that it's non-circular.\n var lastPendingUpdate = pendingQueue;\n var firstPendingUpdate = lastPendingUpdate.next;\n lastPendingUpdate.next = null; // Append pending updates to base queue\n if (lastBaseUpdate === null) firstBaseUpdate = firstPendingUpdate;\n else lastBaseUpdate.next = firstPendingUpdate;\n lastBaseUpdate = lastPendingUpdate; // If there's a current queue, and it's different from the base queue, then\n // we need to transfer the updates to that queue, too. Because the base\n // queue is a singly-linked list with no cycles, we can append to both\n // lists and take advantage of structural sharing.\n // TODO: Pass `current` as argument\n var current = workInProgress.alternate;\n if (current !== null) {\n // This is always non-null on a ClassComponent or HostRoot\n var currentQueue = current.updateQueue;\n var currentLastBaseUpdate = currentQueue.lastBaseUpdate;\n if (currentLastBaseUpdate !== lastBaseUpdate) {\n if (currentLastBaseUpdate === null) currentQueue.firstBaseUpdate = firstPendingUpdate;\n else currentLastBaseUpdate.next = firstPendingUpdate;\n currentQueue.lastBaseUpdate = lastPendingUpdate;\n }\n }\n } // These values may change as we process the queue.\n if (firstBaseUpdate !== null) {\n // Iterate through the list of updates to compute the result.\n var newState = queue.baseState; // TODO: Don't need to accumulate this. Instead, we can remove renderLanes\n // from the original lanes.\n var newLanes = NoLanes;\n var newBaseState = null;\n var newFirstBaseUpdate = null;\n var newLastBaseUpdate = null;\n var update = firstBaseUpdate;\n do {\n var updateLane = update.lane;\n var updateEventTime = update.eventTime;\n if (!isSubsetOfLanes(renderLanes, updateLane)) {\n // Priority is insufficient. Skip this update. If this is the first\n // skipped update, the previous update/state is the new base\n // update/state.\n var clone = {\n eventTime: updateEventTime,\n lane: updateLane,\n tag: update.tag,\n payload: update.payload,\n callback: update.callback,\n next: null\n };\n if (newLastBaseUpdate === null) {\n newFirstBaseUpdate = newLastBaseUpdate = clone;\n newBaseState = newState;\n } else newLastBaseUpdate = newLastBaseUpdate.next = clone;\n // Update the remaining priority in the queue.\n newLanes = mergeLanes(newLanes, updateLane);\n } else {\n // This update does have sufficient priority.\n if (newLastBaseUpdate !== null) {\n var _clone = {\n eventTime: updateEventTime,\n // This update is going to be committed so we never want uncommit\n // it. Using NoLane works because 0 is a subset of all bitmasks, so\n // this will never be skipped by the check above.\n lane: NoLane,\n tag: update.tag,\n payload: update.payload,\n callback: update.callback,\n next: null\n };\n newLastBaseUpdate = newLastBaseUpdate.next = _clone;\n } // Process this update.\n newState = getStateFromUpdate(workInProgress, queue, update, newState, props, instance);\n var callback = update.callback;\n if (callback !== null) {\n workInProgress.flags |= Callback;\n var effects = queue.effects;\n if (effects === null) queue.effects = [\n update\n ];\n else effects.push(update);\n }\n }\n update = update.next;\n if (update === null) {\n pendingQueue = queue.shared.pending;\n if (pendingQueue === null) break;\n else {\n // An update was scheduled from inside a reducer. Add the new\n // pending updates to the end of the list and keep processing.\n var _lastPendingUpdate = pendingQueue; // Intentionally unsound. Pending updates form a circular list, but we\n // unravel them when transferring them to the base queue.\n var _firstPendingUpdate = _lastPendingUpdate.next;\n _lastPendingUpdate.next = null;\n update = _firstPendingUpdate;\n queue.lastBaseUpdate = _lastPendingUpdate;\n queue.shared.pending = null;\n }\n }\n }while (true)\n if (newLastBaseUpdate === null) newBaseState = newState;\n queue.baseState = newBaseState;\n queue.firstBaseUpdate = newFirstBaseUpdate;\n queue.lastBaseUpdate = newLastBaseUpdate; // Set the remaining expiration time to be whatever is remaining in the queue.\n // This should be fine because the only two other things that contribute to\n // expiration time are props and context. We're already in the middle of the\n // begin phase by the time we start processing the queue, so we've already\n // dealt with the props. Context in components that specify\n // shouldComponentUpdate is tricky; but we'll have to account for\n // that regardless.\n markSkippedUpdateLanes(newLanes);\n workInProgress.lanes = newLanes;\n workInProgress.memoizedState = newState;\n }\n currentlyProcessingQueue = null;\n }\n function callCallback1(callback, context) {\n if (!(typeof callback === 'function')) throw Error(\"Invalid argument passed as callback. Expected a function. Instead received: \" + callback);\n callback.call(context);\n }\n function resetHasForceUpdateBeforeProcessing() {\n hasForceUpdate = false;\n }\n function checkHasForceUpdateAfterProcessing() {\n return hasForceUpdate;\n }\n function commitUpdateQueue(finishedWork, finishedQueue, instance) {\n // Commit the effects\n var effects = finishedQueue.effects;\n finishedQueue.effects = null;\n if (effects !== null) for(var i = 0; i < effects.length; i++){\n var effect = effects[i];\n var callback = effect.callback;\n if (callback !== null) {\n effect.callback = null;\n callCallback1(callback, instance);\n }\n }\n }\n var fakeInternalInstance = {\n };\n var isArray1 = Array.isArray; // React.Component uses a shared frozen object by default.\n // We'll use it to determine whether we need to initialize legacy refs.\n var emptyRefsObject = new React.Component().refs;\n var didWarnAboutStateAssignmentForComponent;\n var didWarnAboutUninitializedState;\n var didWarnAboutGetSnapshotBeforeUpdateWithoutDidUpdate;\n var didWarnAboutLegacyLifecyclesAndDerivedState;\n var didWarnAboutUndefinedDerivedState;\n var warnOnUndefinedDerivedState;\n var warnOnInvalidCallback;\n var didWarnAboutDirectlyAssigningPropsToState;\n var didWarnAboutContextTypeAndContextTypes;\n var didWarnAboutInvalidateContextType;\n didWarnAboutStateAssignmentForComponent = new Set();\n didWarnAboutUninitializedState = new Set();\n didWarnAboutGetSnapshotBeforeUpdateWithoutDidUpdate = new Set();\n didWarnAboutLegacyLifecyclesAndDerivedState = new Set();\n didWarnAboutDirectlyAssigningPropsToState = new Set();\n didWarnAboutUndefinedDerivedState = new Set();\n didWarnAboutContextTypeAndContextTypes = new Set();\n didWarnAboutInvalidateContextType = new Set();\n var didWarnOnInvalidCallback = new Set();\n warnOnInvalidCallback = function(callback, callerName) {\n if (callback === null || typeof callback === 'function') return;\n var key = callerName + '_' + callback;\n if (!didWarnOnInvalidCallback.has(key)) {\n didWarnOnInvalidCallback.add(key);\n error1(\"%s(...): Expected the last optional `callback` argument to be a function. Instead received: %s.\", callerName, callback);\n }\n };\n warnOnUndefinedDerivedState = function(type, partialState) {\n if (partialState === undefined) {\n var componentName = getComponentName(type) || 'Component';\n if (!didWarnAboutUndefinedDerivedState.has(componentName)) {\n didWarnAboutUndefinedDerivedState.add(componentName);\n error1(\"%s.getDerivedStateFromProps(): A valid state object (or null) must be returned. You have returned undefined.\", componentName);\n }\n }\n }; // This is so gross but it's at least non-critical and can be removed if\n // it causes problems. This is meant to give a nicer error message for\n // ReactDOM15.unstable_renderSubtreeIntoContainer(reactDOM16Component,\n // ...)) which otherwise throws a \"_processChildContext is not a function\"\n // exception.\n Object.defineProperty(fakeInternalInstance, '_processChildContext', {\n enumerable: false,\n value: function() {\n throw Error(\"_processChildContext is not available in React 16+. This likely means you have multiple copies of React and are attempting to nest a React 15 tree inside a React 16 tree using unstable_renderSubtreeIntoContainer, which isn't supported. Try to make sure you have only one copy of React (and ideally, switch to ReactDOM.createPortal).\");\n }\n });\n Object.freeze(fakeInternalInstance);\n function applyDerivedStateFromProps(workInProgress, ctor, getDerivedStateFromProps, nextProps) {\n var prevState = workInProgress.memoizedState;\n if (workInProgress.mode & StrictMode) {\n disableLogs();\n try {\n // Invoke the function an extra time to help detect side-effects.\n getDerivedStateFromProps(nextProps, prevState);\n } finally{\n reenableLogs();\n }\n }\n var partialState = getDerivedStateFromProps(nextProps, prevState);\n warnOnUndefinedDerivedState(ctor, partialState);\n var memoizedState = partialState === null || partialState === undefined ? prevState : _assign({\n }, prevState, partialState);\n workInProgress.memoizedState = memoizedState; // Once the update queue is empty, persist the derived state onto the\n // base state.\n if (workInProgress.lanes === NoLanes) {\n // Queue is always non-null for classes\n var updateQueue = workInProgress.updateQueue;\n updateQueue.baseState = memoizedState;\n }\n }\n var classComponentUpdater = {\n isMounted: isMounted,\n enqueueSetState: function(inst, payload, callback) {\n var fiber = get1(inst);\n var eventTime = requestEventTime();\n var lane = requestUpdateLane(fiber);\n var update = createUpdate(eventTime, lane);\n update.payload = payload;\n if (callback !== undefined && callback !== null) {\n warnOnInvalidCallback(callback, 'setState');\n update.callback = callback;\n }\n enqueueUpdate(fiber, update);\n scheduleUpdateOnFiber(fiber, lane, eventTime);\n },\n enqueueReplaceState: function(inst, payload, callback) {\n var fiber = get1(inst);\n var eventTime = requestEventTime();\n var lane = requestUpdateLane(fiber);\n var update = createUpdate(eventTime, lane);\n update.tag = ReplaceState;\n update.payload = payload;\n if (callback !== undefined && callback !== null) {\n warnOnInvalidCallback(callback, 'replaceState');\n update.callback = callback;\n }\n enqueueUpdate(fiber, update);\n scheduleUpdateOnFiber(fiber, lane, eventTime);\n },\n enqueueForceUpdate: function(inst, callback) {\n var fiber = get1(inst);\n var eventTime = requestEventTime();\n var lane = requestUpdateLane(fiber);\n var update = createUpdate(eventTime, lane);\n update.tag = ForceUpdate;\n if (callback !== undefined && callback !== null) {\n warnOnInvalidCallback(callback, 'forceUpdate');\n update.callback = callback;\n }\n enqueueUpdate(fiber, update);\n scheduleUpdateOnFiber(fiber, lane, eventTime);\n }\n };\n function checkShouldComponentUpdate(workInProgress, ctor, oldProps, newProps, oldState, newState, nextContext) {\n var instance = workInProgress.stateNode;\n if (typeof instance.shouldComponentUpdate === 'function') {\n if (workInProgress.mode & StrictMode) {\n disableLogs();\n try {\n // Invoke the function an extra time to help detect side-effects.\n instance.shouldComponentUpdate(newProps, newState, nextContext);\n } finally{\n reenableLogs();\n }\n }\n var shouldUpdate = instance.shouldComponentUpdate(newProps, newState, nextContext);\n if (shouldUpdate === undefined) error1(\"%s.shouldComponentUpdate(): Returned undefined instead of a boolean value. Make sure to return true or false.\", getComponentName(ctor) || 'Component');\n return shouldUpdate;\n }\n if (ctor.prototype && ctor.prototype.isPureReactComponent) return !shallowEqual(oldProps, newProps) || !shallowEqual(oldState, newState);\n return true;\n }\n function checkClassInstance(workInProgress, ctor, newProps) {\n var instance = workInProgress.stateNode;\n var name = getComponentName(ctor) || 'Component';\n var renderPresent = instance.render;\n if (!renderPresent) {\n if (ctor.prototype && typeof ctor.prototype.render === 'function') error1(\"%s(...): No `render` method found on the returned component instance: did you accidentally return an object from the constructor?\", name);\n else error1(\"%s(...): No `render` method found on the returned component instance: you may have forgotten to define `render`.\", name);\n }\n if (instance.getInitialState && !instance.getInitialState.isReactClassApproved && !instance.state) error1(\"getInitialState was defined on %s, a plain JavaScript class. This is only supported for classes created using React.createClass. Did you mean to define a state property instead?\", name);\n if (instance.getDefaultProps && !instance.getDefaultProps.isReactClassApproved) error1(\"getDefaultProps was defined on %s, a plain JavaScript class. This is only supported for classes created using React.createClass. Use a static property to define defaultProps instead.\", name);\n if (instance.propTypes) error1(\"propTypes was defined as an instance property on %s. Use a static property to define propTypes instead.\", name);\n if (instance.contextType) error1(\"contextType was defined as an instance property on %s. Use a static property to define contextType instead.\", name);\n if (instance.contextTypes) error1(\"contextTypes was defined as an instance property on %s. Use a static property to define contextTypes instead.\", name);\n if (ctor.contextType && ctor.contextTypes && !didWarnAboutContextTypeAndContextTypes.has(ctor)) {\n didWarnAboutContextTypeAndContextTypes.add(ctor);\n error1(\"%s declares both contextTypes and contextType static properties. The legacy contextTypes property will be ignored.\", name);\n }\n if (typeof instance.componentShouldUpdate === 'function') error1(\"%s has a method called componentShouldUpdate(). Did you mean shouldComponentUpdate()? The name is phrased as a question because the function is expected to return a value.\", name);\n if (ctor.prototype && ctor.prototype.isPureReactComponent && typeof instance.shouldComponentUpdate !== 'undefined') error1(\"%s has a method called shouldComponentUpdate(). shouldComponentUpdate should not be used when extending React.PureComponent. Please extend React.Component if shouldComponentUpdate is used.\", getComponentName(ctor) || 'A pure component');\n if (typeof instance.componentDidUnmount === 'function') error1(\"%s has a method called componentDidUnmount(). But there is no such lifecycle method. Did you mean componentWillUnmount()?\", name);\n if (typeof instance.componentDidReceiveProps === 'function') error1(\"%s has a method called componentDidReceiveProps(). But there is no such lifecycle method. If you meant to update the state in response to changing props, use componentWillReceiveProps(). If you meant to fetch data or run side-effects or mutations after React has updated the UI, use componentDidUpdate().\", name);\n if (typeof instance.componentWillRecieveProps === 'function') error1(\"%s has a method called componentWillRecieveProps(). Did you mean componentWillReceiveProps()?\", name);\n if (typeof instance.UNSAFE_componentWillRecieveProps === 'function') error1(\"%s has a method called UNSAFE_componentWillRecieveProps(). Did you mean UNSAFE_componentWillReceiveProps()?\", name);\n var hasMutatedProps = instance.props !== newProps;\n if (instance.props !== undefined && hasMutatedProps) error1(\"%s(...): When calling super() in `%s`, make sure to pass up the same props that your component's constructor was passed.\", name, name);\n if (instance.defaultProps) error1(\"Setting defaultProps as an instance property on %s is not supported and will be ignored. Instead, define defaultProps as a static property on %s.\", name, name);\n if (typeof instance.getSnapshotBeforeUpdate === 'function' && typeof instance.componentDidUpdate !== 'function' && !didWarnAboutGetSnapshotBeforeUpdateWithoutDidUpdate.has(ctor)) {\n didWarnAboutGetSnapshotBeforeUpdateWithoutDidUpdate.add(ctor);\n error1(\"%s: getSnapshotBeforeUpdate() should be used with componentDidUpdate(). This component defines getSnapshotBeforeUpdate() only.\", getComponentName(ctor));\n }\n if (typeof instance.getDerivedStateFromProps === 'function') error1(\"%s: getDerivedStateFromProps() is defined as an instance method and will be ignored. Instead, declare it as a static method.\", name);\n if (typeof instance.getDerivedStateFromError === 'function') error1(\"%s: getDerivedStateFromError() is defined as an instance method and will be ignored. Instead, declare it as a static method.\", name);\n if (typeof ctor.getSnapshotBeforeUpdate === 'function') error1(\"%s: getSnapshotBeforeUpdate() is defined as a static method and will be ignored. Instead, declare it as an instance method.\", name);\n var _state = instance.state;\n if (_state && (typeof _state !== 'object' || isArray1(_state))) error1('%s.state: must be set to an object or null', name);\n if (typeof instance.getChildContext === 'function' && typeof ctor.childContextTypes !== 'object') error1(\"%s.getChildContext(): childContextTypes must be defined in order to use getChildContext().\", name);\n }\n function adoptClassInstance(workInProgress, instance) {\n instance.updater = classComponentUpdater;\n workInProgress.stateNode = instance; // The instance needs access to the fiber so that it can schedule updates\n set1(instance, workInProgress);\n instance._reactInternalInstance = fakeInternalInstance;\n }\n function constructClassInstance(workInProgress, ctor, props) {\n var isLegacyContextConsumer = false;\n var unmaskedContext = emptyContextObject;\n var context = emptyContextObject;\n var contextType = ctor.contextType;\n if ('contextType' in ctor) {\n var isValid = contextType === null || contextType !== undefined && contextType.$$typeof === REACT_CONTEXT_TYPE && contextType._context === undefined; // Not a <Context.Consumer>\n if (!isValid && !didWarnAboutInvalidateContextType.has(ctor)) {\n didWarnAboutInvalidateContextType.add(ctor);\n var addendum = '';\n if (contextType === undefined) addendum = \" However, it is set to undefined. This can be caused by a typo or by mixing up named and default imports. This can also happen due to a circular dependency, so try moving the createContext() call to a separate file.\";\n else if (typeof contextType !== 'object') addendum = ' However, it is set to a ' + typeof contextType + '.';\n else if (contextType.$$typeof === REACT_PROVIDER_TYPE) addendum = ' Did you accidentally pass the Context.Provider instead?';\n else if (contextType._context !== undefined) // <Context.Consumer>\n addendum = ' Did you accidentally pass the Context.Consumer instead?';\n else addendum = ' However, it is set to an object with keys {' + Object.keys(contextType).join(', ') + '}.';\n error1(\"%s defines an invalid contextType. contextType should point to the Context object returned by React.createContext().%s\", getComponentName(ctor) || 'Component', addendum);\n }\n }\n if (typeof contextType === 'object' && contextType !== null) context = readContext(contextType);\n else {\n unmaskedContext = getUnmaskedContext(workInProgress, ctor, true);\n var contextTypes = ctor.contextTypes;\n isLegacyContextConsumer = contextTypes !== null && contextTypes !== undefined;\n context = isLegacyContextConsumer ? getMaskedContext(workInProgress, unmaskedContext) : emptyContextObject;\n } // Instantiate twice to help detect side-effects.\n if (workInProgress.mode & StrictMode) {\n disableLogs();\n try {\n new ctor(props, context); // eslint-disable-line no-new\n } finally{\n reenableLogs();\n }\n }\n var instance = new ctor(props, context);\n var state = workInProgress.memoizedState = instance.state !== null && instance.state !== undefined ? instance.state : null;\n adoptClassInstance(workInProgress, instance);\n if (typeof ctor.getDerivedStateFromProps === 'function' && state === null) {\n var componentName = getComponentName(ctor) || 'Component';\n if (!didWarnAboutUninitializedState.has(componentName)) {\n didWarnAboutUninitializedState.add(componentName);\n error1(\"`%s` uses `getDerivedStateFromProps` but its initial state is %s. This is not recommended. Instead, define the initial state by assigning an object to `this.state` in the constructor of `%s`. This ensures that `getDerivedStateFromProps` arguments have a consistent shape.\", componentName, instance.state === null ? 'null' : 'undefined', componentName);\n }\n } // If new component APIs are defined, \"unsafe\" lifecycles won't be called.\n // Warn about these lifecycles if they are present.\n // Don't warn about react-lifecycles-compat polyfilled methods though.\n if (typeof ctor.getDerivedStateFromProps === 'function' || typeof instance.getSnapshotBeforeUpdate === 'function') {\n var foundWillMountName = null;\n var foundWillReceivePropsName = null;\n var foundWillUpdateName = null;\n if (typeof instance.componentWillMount === 'function' && instance.componentWillMount.__suppressDeprecationWarning !== true) foundWillMountName = 'componentWillMount';\n else if (typeof instance.UNSAFE_componentWillMount === 'function') foundWillMountName = 'UNSAFE_componentWillMount';\n if (typeof instance.componentWillReceiveProps === 'function' && instance.componentWillReceiveProps.__suppressDeprecationWarning !== true) foundWillReceivePropsName = 'componentWillReceiveProps';\n else if (typeof instance.UNSAFE_componentWillReceiveProps === 'function') foundWillReceivePropsName = 'UNSAFE_componentWillReceiveProps';\n if (typeof instance.componentWillUpdate === 'function' && instance.componentWillUpdate.__suppressDeprecationWarning !== true) foundWillUpdateName = 'componentWillUpdate';\n else if (typeof instance.UNSAFE_componentWillUpdate === 'function') foundWillUpdateName = 'UNSAFE_componentWillUpdate';\n if (foundWillMountName !== null || foundWillReceivePropsName !== null || foundWillUpdateName !== null) {\n var _componentName = getComponentName(ctor) || 'Component';\n var newApiName = typeof ctor.getDerivedStateFromProps === 'function' ? 'getDerivedStateFromProps()' : 'getSnapshotBeforeUpdate()';\n if (!didWarnAboutLegacyLifecyclesAndDerivedState.has(_componentName)) {\n didWarnAboutLegacyLifecyclesAndDerivedState.add(_componentName);\n error1(\"Unsafe legacy lifecycles will not be called for components using new component APIs.\\n\\n%s uses %s but also contains the following legacy lifecycles:%s%s%s\\n\\nThe above lifecycles should be removed. Learn more about this warning here:\\nhttps://reactjs.org/link/unsafe-component-lifecycles\", _componentName, newApiName, foundWillMountName !== null ? \"\\n \" + foundWillMountName : '', foundWillReceivePropsName !== null ? \"\\n \" + foundWillReceivePropsName : '', foundWillUpdateName !== null ? \"\\n \" + foundWillUpdateName : '');\n }\n }\n }\n // ReactFiberContext usually updates this cache but can't for newly-created instances.\n if (isLegacyContextConsumer) cacheContext(workInProgress, unmaskedContext, context);\n return instance;\n }\n function callComponentWillMount(workInProgress, instance) {\n var oldState = instance.state;\n if (typeof instance.componentWillMount === 'function') instance.componentWillMount();\n if (typeof instance.UNSAFE_componentWillMount === 'function') instance.UNSAFE_componentWillMount();\n if (oldState !== instance.state) {\n error1(\"%s.componentWillMount(): Assigning directly to this.state is deprecated (except inside a component's constructor). Use setState instead.\", getComponentName(workInProgress.type) || 'Component');\n classComponentUpdater.enqueueReplaceState(instance, instance.state, null);\n }\n }\n function callComponentWillReceiveProps(workInProgress, instance, newProps, nextContext) {\n var oldState = instance.state;\n if (typeof instance.componentWillReceiveProps === 'function') instance.componentWillReceiveProps(newProps, nextContext);\n if (typeof instance.UNSAFE_componentWillReceiveProps === 'function') instance.UNSAFE_componentWillReceiveProps(newProps, nextContext);\n if (instance.state !== oldState) {\n var componentName = getComponentName(workInProgress.type) || 'Component';\n if (!didWarnAboutStateAssignmentForComponent.has(componentName)) {\n didWarnAboutStateAssignmentForComponent.add(componentName);\n error1(\"%s.componentWillReceiveProps(): Assigning directly to this.state is deprecated (except inside a component's constructor). Use setState instead.\", componentName);\n }\n classComponentUpdater.enqueueReplaceState(instance, instance.state, null);\n }\n } // Invokes the mount life-cycles on a previously never rendered instance.\n function mountClassInstance(workInProgress, ctor, newProps, renderLanes) {\n checkClassInstance(workInProgress, ctor, newProps);\n var instance = workInProgress.stateNode;\n instance.props = newProps;\n instance.state = workInProgress.memoizedState;\n instance.refs = emptyRefsObject;\n initializeUpdateQueue(workInProgress);\n var contextType = ctor.contextType;\n if (typeof contextType === 'object' && contextType !== null) instance.context = readContext(contextType);\n else {\n var unmaskedContext = getUnmaskedContext(workInProgress, ctor, true);\n instance.context = getMaskedContext(workInProgress, unmaskedContext);\n }\n if (instance.state === newProps) {\n var componentName = getComponentName(ctor) || 'Component';\n if (!didWarnAboutDirectlyAssigningPropsToState.has(componentName)) {\n didWarnAboutDirectlyAssigningPropsToState.add(componentName);\n error1(\"%s: It is not recommended to assign props directly to state because updates to props won't be reflected in state. In most cases, it is better to use props directly.\", componentName);\n }\n }\n if (workInProgress.mode & StrictMode) ReactStrictModeWarnings.recordLegacyContextWarning(workInProgress, instance);\n ReactStrictModeWarnings.recordUnsafeLifecycleWarnings(workInProgress, instance);\n processUpdateQueue(workInProgress, newProps, instance, renderLanes);\n instance.state = workInProgress.memoizedState;\n var getDerivedStateFromProps = ctor.getDerivedStateFromProps;\n if (typeof getDerivedStateFromProps === 'function') {\n applyDerivedStateFromProps(workInProgress, ctor, getDerivedStateFromProps, newProps);\n instance.state = workInProgress.memoizedState;\n } // In order to support react-lifecycles-compat polyfilled components,\n // Unsafe lifecycles should not be invoked for components using the new APIs.\n if (typeof ctor.getDerivedStateFromProps !== 'function' && typeof instance.getSnapshotBeforeUpdate !== 'function' && (typeof instance.UNSAFE_componentWillMount === 'function' || typeof instance.componentWillMount === 'function')) {\n callComponentWillMount(workInProgress, instance); // If we had additional state updates during this life-cycle, let's\n // process them now.\n processUpdateQueue(workInProgress, newProps, instance, renderLanes);\n instance.state = workInProgress.memoizedState;\n }\n if (typeof instance.componentDidMount === 'function') workInProgress.flags |= Update;\n }\n function resumeMountClassInstance(workInProgress, ctor, newProps, renderLanes) {\n var instance = workInProgress.stateNode;\n var oldProps = workInProgress.memoizedProps;\n instance.props = oldProps;\n var oldContext = instance.context;\n var contextType = ctor.contextType;\n var nextContext = emptyContextObject;\n if (typeof contextType === 'object' && contextType !== null) nextContext = readContext(contextType);\n else {\n var nextLegacyUnmaskedContext = getUnmaskedContext(workInProgress, ctor, true);\n nextContext = getMaskedContext(workInProgress, nextLegacyUnmaskedContext);\n }\n var getDerivedStateFromProps = ctor.getDerivedStateFromProps;\n var hasNewLifecycles = typeof getDerivedStateFromProps === 'function' || typeof instance.getSnapshotBeforeUpdate === 'function'; // Note: During these life-cycles, instance.props/instance.state are what\n // ever the previously attempted to render - not the \"current\". However,\n // during componentDidUpdate we pass the \"current\" props.\n // In order to support react-lifecycles-compat polyfilled components,\n // Unsafe lifecycles should not be invoked for components using the new APIs.\n if (!hasNewLifecycles && (typeof instance.UNSAFE_componentWillReceiveProps === 'function' || typeof instance.componentWillReceiveProps === 'function')) {\n if (oldProps !== newProps || oldContext !== nextContext) callComponentWillReceiveProps(workInProgress, instance, newProps, nextContext);\n }\n resetHasForceUpdateBeforeProcessing();\n var oldState = workInProgress.memoizedState;\n var newState = instance.state = oldState;\n processUpdateQueue(workInProgress, newProps, instance, renderLanes);\n newState = workInProgress.memoizedState;\n if (oldProps === newProps && oldState === newState && !hasContextChanged() && !checkHasForceUpdateAfterProcessing()) {\n // If an update was already in progress, we should schedule an Update\n // effect even though we're bailing out, so that cWU/cDU are called.\n if (typeof instance.componentDidMount === 'function') workInProgress.flags |= Update;\n return false;\n }\n if (typeof getDerivedStateFromProps === 'function') {\n applyDerivedStateFromProps(workInProgress, ctor, getDerivedStateFromProps, newProps);\n newState = workInProgress.memoizedState;\n }\n var shouldUpdate = checkHasForceUpdateAfterProcessing() || checkShouldComponentUpdate(workInProgress, ctor, oldProps, newProps, oldState, newState, nextContext);\n if (shouldUpdate) {\n // In order to support react-lifecycles-compat polyfilled components,\n // Unsafe lifecycles should not be invoked for components using the new APIs.\n if (!hasNewLifecycles && (typeof instance.UNSAFE_componentWillMount === 'function' || typeof instance.componentWillMount === 'function')) {\n if (typeof instance.componentWillMount === 'function') instance.componentWillMount();\n if (typeof instance.UNSAFE_componentWillMount === 'function') instance.UNSAFE_componentWillMount();\n }\n if (typeof instance.componentDidMount === 'function') workInProgress.flags |= Update;\n } else {\n // If an update was already in progress, we should schedule an Update\n // effect even though we're bailing out, so that cWU/cDU are called.\n if (typeof instance.componentDidMount === 'function') workInProgress.flags |= Update;\n // If shouldComponentUpdate returned false, we should still update the\n // memoized state to indicate that this work can be reused.\n workInProgress.memoizedProps = newProps;\n workInProgress.memoizedState = newState;\n } // Update the existing instance's state, props, and context pointers even\n // if shouldComponentUpdate returns false.\n instance.props = newProps;\n instance.state = newState;\n instance.context = nextContext;\n return shouldUpdate;\n } // Invokes the update life-cycles and returns false if it shouldn't rerender.\n function updateClassInstance(current, workInProgress, ctor, newProps, renderLanes) {\n var instance = workInProgress.stateNode;\n cloneUpdateQueue(current, workInProgress);\n var unresolvedOldProps = workInProgress.memoizedProps;\n var oldProps = workInProgress.type === workInProgress.elementType ? unresolvedOldProps : resolveDefaultProps(workInProgress.type, unresolvedOldProps);\n instance.props = oldProps;\n var unresolvedNewProps = workInProgress.pendingProps;\n var oldContext = instance.context;\n var contextType = ctor.contextType;\n var nextContext = emptyContextObject;\n if (typeof contextType === 'object' && contextType !== null) nextContext = readContext(contextType);\n else {\n var nextUnmaskedContext = getUnmaskedContext(workInProgress, ctor, true);\n nextContext = getMaskedContext(workInProgress, nextUnmaskedContext);\n }\n var getDerivedStateFromProps = ctor.getDerivedStateFromProps;\n var hasNewLifecycles = typeof getDerivedStateFromProps === 'function' || typeof instance.getSnapshotBeforeUpdate === 'function'; // Note: During these life-cycles, instance.props/instance.state are what\n // ever the previously attempted to render - not the \"current\". However,\n // during componentDidUpdate we pass the \"current\" props.\n // In order to support react-lifecycles-compat polyfilled components,\n // Unsafe lifecycles should not be invoked for components using the new APIs.\n if (!hasNewLifecycles && (typeof instance.UNSAFE_componentWillReceiveProps === 'function' || typeof instance.componentWillReceiveProps === 'function')) {\n if (unresolvedOldProps !== unresolvedNewProps || oldContext !== nextContext) callComponentWillReceiveProps(workInProgress, instance, newProps, nextContext);\n }\n resetHasForceUpdateBeforeProcessing();\n var oldState = workInProgress.memoizedState;\n var newState = instance.state = oldState;\n processUpdateQueue(workInProgress, newProps, instance, renderLanes);\n newState = workInProgress.memoizedState;\n if (unresolvedOldProps === unresolvedNewProps && oldState === newState && !hasContextChanged() && !checkHasForceUpdateAfterProcessing()) {\n // If an update was already in progress, we should schedule an Update\n // effect even though we're bailing out, so that cWU/cDU are called.\n if (typeof instance.componentDidUpdate === 'function') {\n if (unresolvedOldProps !== current.memoizedProps || oldState !== current.memoizedState) workInProgress.flags |= Update;\n }\n if (typeof instance.getSnapshotBeforeUpdate === 'function') {\n if (unresolvedOldProps !== current.memoizedProps || oldState !== current.memoizedState) workInProgress.flags |= Snapshot;\n }\n return false;\n }\n if (typeof getDerivedStateFromProps === 'function') {\n applyDerivedStateFromProps(workInProgress, ctor, getDerivedStateFromProps, newProps);\n newState = workInProgress.memoizedState;\n }\n var shouldUpdate = checkHasForceUpdateAfterProcessing() || checkShouldComponentUpdate(workInProgress, ctor, oldProps, newProps, oldState, newState, nextContext);\n if (shouldUpdate) {\n // In order to support react-lifecycles-compat polyfilled components,\n // Unsafe lifecycles should not be invoked for components using the new APIs.\n if (!hasNewLifecycles && (typeof instance.UNSAFE_componentWillUpdate === 'function' || typeof instance.componentWillUpdate === 'function')) {\n if (typeof instance.componentWillUpdate === 'function') instance.componentWillUpdate(newProps, newState, nextContext);\n if (typeof instance.UNSAFE_componentWillUpdate === 'function') instance.UNSAFE_componentWillUpdate(newProps, newState, nextContext);\n }\n if (typeof instance.componentDidUpdate === 'function') workInProgress.flags |= Update;\n if (typeof instance.getSnapshotBeforeUpdate === 'function') workInProgress.flags |= Snapshot;\n } else {\n // If an update was already in progress, we should schedule an Update\n // effect even though we're bailing out, so that cWU/cDU are called.\n if (typeof instance.componentDidUpdate === 'function') {\n if (unresolvedOldProps !== current.memoizedProps || oldState !== current.memoizedState) workInProgress.flags |= Update;\n }\n if (typeof instance.getSnapshotBeforeUpdate === 'function') {\n if (unresolvedOldProps !== current.memoizedProps || oldState !== current.memoizedState) workInProgress.flags |= Snapshot;\n } // If shouldComponentUpdate returned false, we should still update the\n // memoized props/state to indicate that this work can be reused.\n workInProgress.memoizedProps = newProps;\n workInProgress.memoizedState = newState;\n } // Update the existing instance's state, props, and context pointers even\n // if shouldComponentUpdate returns false.\n instance.props = newProps;\n instance.state = newState;\n instance.context = nextContext;\n return shouldUpdate;\n }\n var didWarnAboutMaps;\n var didWarnAboutGenerators;\n var didWarnAboutStringRefs;\n var ownerHasKeyUseWarning;\n var ownerHasFunctionTypeWarning;\n var warnForMissingKey = function(child, returnFiber) {\n };\n didWarnAboutMaps = false;\n didWarnAboutGenerators = false;\n didWarnAboutStringRefs = {\n };\n /**\n * Warn if there's no key explicitly set on dynamic arrays of children or\n * object keys are not valid. This allows us to keep track of children between\n * updates.\n */ ownerHasKeyUseWarning = {\n };\n ownerHasFunctionTypeWarning = {\n };\n warnForMissingKey = function(child, returnFiber) {\n if (child === null || typeof child !== 'object') return;\n if (!child._store || child._store.validated || child.key != null) return;\n if (!(typeof child._store === 'object')) throw Error(\"React Component in warnForMissingKey should have a _store. This error is likely caused by a bug in React. Please file an issue.\");\n child._store.validated = true;\n var componentName = getComponentName(returnFiber.type) || 'Component';\n if (ownerHasKeyUseWarning[componentName]) return;\n ownerHasKeyUseWarning[componentName] = true;\n error1(\"Each child in a list should have a unique \\\"key\\\" prop. See https://reactjs.org/link/warning-keys for more information.\");\n };\n var isArray$1 = Array.isArray;\n function coerceRef(returnFiber, current, element) {\n var mixedRef = element.ref;\n if (mixedRef !== null && typeof mixedRef !== 'function' && typeof mixedRef !== 'object') {\n // TODO: Clean this up once we turn on the string ref warning for\n // everyone, because the strict mode case will no longer be relevant\n if ((returnFiber.mode & StrictMode || warnAboutStringRefs) && // because these cannot be automatically converted to an arrow function\n // using a codemod. Therefore, we don't have to warn about string refs again.\n !(element._owner && element._self && element._owner.stateNode !== element._self)) {\n var componentName = getComponentName(returnFiber.type) || 'Component';\n if (!didWarnAboutStringRefs[componentName]) {\n error1(\"A string ref, \\\"%s\\\", has been found within a strict mode tree. String refs are a source of potential bugs and should be avoided. We recommend using useRef() or createRef() instead. Learn more about using refs safely here: https://reactjs.org/link/strict-mode-string-ref\", mixedRef);\n didWarnAboutStringRefs[componentName] = true;\n }\n }\n if (element._owner) {\n var owner = element._owner;\n var inst;\n if (owner) {\n var ownerFiber = owner;\n if (!(ownerFiber.tag === ClassComponent)) throw Error(\"Function components cannot have string refs. We recommend using useRef() instead. Learn more about using refs safely here: https://reactjs.org/link/strict-mode-string-ref\");\n inst = ownerFiber.stateNode;\n }\n if (!inst) throw Error(\"Missing owner for string ref \" + mixedRef + \". This error is likely caused by a bug in React. Please file an issue.\");\n var stringRef = '' + mixedRef; // Check if previous string ref matches new string ref\n if (current !== null && current.ref !== null && typeof current.ref === 'function' && current.ref._stringRef === stringRef) return current.ref;\n var ref = function(value) {\n var refs = inst.refs;\n if (refs === emptyRefsObject) // This is a lazy pooled frozen object, so we need to initialize.\n refs = inst.refs = {\n };\n if (value === null) delete refs[stringRef];\n else refs[stringRef] = value;\n };\n ref._stringRef = stringRef;\n return ref;\n } else {\n if (!(typeof mixedRef === 'string')) throw Error(\"Expected ref to be a function, a string, an object returned by React.createRef(), or null.\");\n if (!element._owner) throw Error(\"Element ref was specified as a string (\" + mixedRef + \") but no owner was set. This could happen for one of the following reasons:\\n1. You may be adding a ref to a function component\\n2. You may be adding a ref to a component that was not created inside a component's render method\\n3. You have multiple copies of React loaded\\nSee https://reactjs.org/link/refs-must-have-owner for more information.\");\n }\n }\n return mixedRef;\n }\n function throwOnInvalidObjectType(returnFiber, newChild) {\n if (returnFiber.type !== 'textarea') throw Error(\"Objects are not valid as a React child (found: \" + (Object.prototype.toString.call(newChild) === '[object Object]' ? 'object with keys {' + Object.keys(newChild).join(', ') + '}' : newChild) + \"). If you meant to render a collection of children, use an array instead.\");\n }\n function warnOnFunctionType(returnFiber) {\n var componentName = getComponentName(returnFiber.type) || 'Component';\n if (ownerHasFunctionTypeWarning[componentName]) return;\n ownerHasFunctionTypeWarning[componentName] = true;\n error1(\"Functions are not valid as a React child. This may happen if you return a Component instead of <Component /> from render. Or maybe you meant to call this function rather than return it.\");\n } // We avoid inlining this to avoid potential deopts from using try/catch.\n // to be able to optimize each path individually by branching early. This needs\n // a compiler or we can do it manually. Helpers that don't need this branching\n // live outside of this function.\n function ChildReconciler(shouldTrackSideEffects) {\n function deleteChild(returnFiber, childToDelete) {\n if (!shouldTrackSideEffects) // Noop.\n return;\n // Deletions are added in reversed order so we add it to the front.\n // At this point, the return fiber's effect list is empty except for\n // deletions, so we can just append the deletion to the list. The remaining\n // effects aren't added until the complete phase. Once we implement\n // resuming, this may not be true.\n var last = returnFiber.lastEffect;\n if (last !== null) {\n last.nextEffect = childToDelete;\n returnFiber.lastEffect = childToDelete;\n } else returnFiber.firstEffect = returnFiber.lastEffect = childToDelete;\n childToDelete.nextEffect = null;\n childToDelete.flags = Deletion;\n }\n function deleteRemainingChildren(returnFiber, currentFirstChild) {\n if (!shouldTrackSideEffects) // Noop.\n return null;\n // TODO: For the shouldClone case, this could be micro-optimized a bit by\n // assuming that after the first child we've already added everything.\n var childToDelete = currentFirstChild;\n while(childToDelete !== null){\n deleteChild(returnFiber, childToDelete);\n childToDelete = childToDelete.sibling;\n }\n return null;\n }\n function mapRemainingChildren(returnFiber, currentFirstChild) {\n // Add the remaining children to a temporary map so that we can find them by\n // keys quickly. Implicit (null) keys get added to this set with their index\n // instead.\n var existingChildren = new Map();\n var existingChild = currentFirstChild;\n while(existingChild !== null){\n if (existingChild.key !== null) existingChildren.set(existingChild.key, existingChild);\n else existingChildren.set(existingChild.index, existingChild);\n existingChild = existingChild.sibling;\n }\n return existingChildren;\n }\n function useFiber(fiber, pendingProps) {\n // We currently set sibling to null and index to 0 here because it is easy\n // to forget to do before returning it. E.g. for the single child case.\n var clone = createWorkInProgress(fiber, pendingProps);\n clone.index = 0;\n clone.sibling = null;\n return clone;\n }\n function placeChild(newFiber, lastPlacedIndex, newIndex) {\n newFiber.index = newIndex;\n if (!shouldTrackSideEffects) // Noop.\n return lastPlacedIndex;\n var current = newFiber.alternate;\n if (current !== null) {\n var oldIndex = current.index;\n if (oldIndex < lastPlacedIndex) {\n // This is a move.\n newFiber.flags = Placement;\n return lastPlacedIndex;\n } else // This item can stay in place.\n return oldIndex;\n } else {\n // This is an insertion.\n newFiber.flags = Placement;\n return lastPlacedIndex;\n }\n }\n function placeSingleChild(newFiber) {\n // This is simpler for the single child case. We only need to do a\n // placement for inserting new children.\n if (shouldTrackSideEffects && newFiber.alternate === null) newFiber.flags = Placement;\n return newFiber;\n }\n function updateTextNode(returnFiber, current, textContent, lanes) {\n if (current === null || current.tag !== HostText) {\n // Insert\n var created = createFiberFromText(textContent, returnFiber.mode, lanes);\n created.return = returnFiber;\n return created;\n } else {\n // Update\n var existing = useFiber(current, textContent);\n existing.return = returnFiber;\n return existing;\n }\n }\n function updateElement(returnFiber, current, element, lanes) {\n if (current !== null) {\n if (current.elementType === element.type || isCompatibleFamilyForHotReloading(current, element)) {\n // Move based on index\n var existing = useFiber(current, element.props);\n existing.ref = coerceRef(returnFiber, current, element);\n existing.return = returnFiber;\n existing._debugSource = element._source;\n existing._debugOwner = element._owner;\n return existing;\n }\n } // Insert\n var created = createFiberFromElement(element, returnFiber.mode, lanes);\n created.ref = coerceRef(returnFiber, current, element);\n created.return = returnFiber;\n return created;\n }\n function updatePortal(returnFiber, current, portal, lanes) {\n if (current === null || current.tag !== HostPortal || current.stateNode.containerInfo !== portal.containerInfo || current.stateNode.implementation !== portal.implementation) {\n // Insert\n var created = createFiberFromPortal(portal, returnFiber.mode, lanes);\n created.return = returnFiber;\n return created;\n } else {\n // Update\n var existing = useFiber(current, portal.children || []);\n existing.return = returnFiber;\n return existing;\n }\n }\n function updateFragment(returnFiber, current, fragment, lanes, key) {\n if (current === null || current.tag !== Fragment) {\n // Insert\n var created = createFiberFromFragment(fragment, returnFiber.mode, lanes, key);\n created.return = returnFiber;\n return created;\n } else {\n // Update\n var existing = useFiber(current, fragment);\n existing.return = returnFiber;\n return existing;\n }\n }\n function createChild(returnFiber, newChild, lanes) {\n if (typeof newChild === 'string' || typeof newChild === 'number') {\n // Text nodes don't have keys. If the previous node is implicitly keyed\n // we can continue to replace it without aborting even if it is not a text\n // node.\n var created = createFiberFromText('' + newChild, returnFiber.mode, lanes);\n created.return = returnFiber;\n return created;\n }\n if (typeof newChild === 'object' && newChild !== null) {\n switch(newChild.$$typeof){\n case REACT_ELEMENT_TYPE:\n var _created = createFiberFromElement(newChild, returnFiber.mode, lanes);\n _created.ref = coerceRef(returnFiber, null, newChild);\n _created.return = returnFiber;\n return _created;\n case REACT_PORTAL_TYPE:\n var _created2 = createFiberFromPortal(newChild, returnFiber.mode, lanes);\n _created2.return = returnFiber;\n return _created2;\n }\n if (isArray$1(newChild) || getIteratorFn(newChild)) {\n var _created3 = createFiberFromFragment(newChild, returnFiber.mode, lanes, null);\n _created3.return = returnFiber;\n return _created3;\n }\n throwOnInvalidObjectType(returnFiber, newChild);\n }\n if (typeof newChild === 'function') warnOnFunctionType(returnFiber);\n return null;\n }\n function updateSlot(returnFiber, oldFiber, newChild, lanes) {\n // Update the fiber if the keys match, otherwise return null.\n var key = oldFiber !== null ? oldFiber.key : null;\n if (typeof newChild === 'string' || typeof newChild === 'number') {\n // Text nodes don't have keys. If the previous node is implicitly keyed\n // we can continue to replace it without aborting even if it is not a text\n // node.\n if (key !== null) return null;\n return updateTextNode(returnFiber, oldFiber, '' + newChild, lanes);\n }\n if (typeof newChild === 'object' && newChild !== null) {\n switch(newChild.$$typeof){\n case REACT_ELEMENT_TYPE:\n if (newChild.key === key) {\n if (newChild.type === REACT_FRAGMENT_TYPE) return updateFragment(returnFiber, oldFiber, newChild.props.children, lanes, key);\n return updateElement(returnFiber, oldFiber, newChild, lanes);\n } else return null;\n case REACT_PORTAL_TYPE:\n if (newChild.key === key) return updatePortal(returnFiber, oldFiber, newChild, lanes);\n else return null;\n }\n if (isArray$1(newChild) || getIteratorFn(newChild)) {\n if (key !== null) return null;\n return updateFragment(returnFiber, oldFiber, newChild, lanes, null);\n }\n throwOnInvalidObjectType(returnFiber, newChild);\n }\n if (typeof newChild === 'function') warnOnFunctionType(returnFiber);\n return null;\n }\n function updateFromMap(existingChildren, returnFiber, newIdx, newChild, lanes) {\n if (typeof newChild === 'string' || typeof newChild === 'number') {\n // Text nodes don't have keys, so we neither have to check the old nor\n // new node for the key. If both are text nodes, they match.\n var matchedFiber = existingChildren.get(newIdx) || null;\n return updateTextNode(returnFiber, matchedFiber, '' + newChild, lanes);\n }\n if (typeof newChild === 'object' && newChild !== null) {\n switch(newChild.$$typeof){\n case REACT_ELEMENT_TYPE:\n var _matchedFiber = existingChildren.get(newChild.key === null ? newIdx : newChild.key) || null;\n if (newChild.type === REACT_FRAGMENT_TYPE) return updateFragment(returnFiber, _matchedFiber, newChild.props.children, lanes, newChild.key);\n return updateElement(returnFiber, _matchedFiber, newChild, lanes);\n case REACT_PORTAL_TYPE:\n var _matchedFiber2 = existingChildren.get(newChild.key === null ? newIdx : newChild.key) || null;\n return updatePortal(returnFiber, _matchedFiber2, newChild, lanes);\n }\n if (isArray$1(newChild) || getIteratorFn(newChild)) {\n var _matchedFiber3 = existingChildren.get(newIdx) || null;\n return updateFragment(returnFiber, _matchedFiber3, newChild, lanes, null);\n }\n throwOnInvalidObjectType(returnFiber, newChild);\n }\n if (typeof newChild === 'function') warnOnFunctionType(returnFiber);\n return null;\n }\n /**\n * Warns if there is a duplicate or missing key\n */ function warnOnInvalidKey(child, knownKeys, returnFiber) {\n if (typeof child !== 'object' || child === null) return knownKeys;\n switch(child.$$typeof){\n case REACT_ELEMENT_TYPE:\n case REACT_PORTAL_TYPE:\n warnForMissingKey(child, returnFiber);\n var key = child.key;\n if (typeof key !== 'string') break;\n if (knownKeys === null) {\n knownKeys = new Set();\n knownKeys.add(key);\n break;\n }\n if (!knownKeys.has(key)) {\n knownKeys.add(key);\n break;\n }\n error1(\"Encountered two children with the same key, `%s`. Keys should be unique so that components maintain their identity across updates. Non-unique keys may cause children to be duplicated and/or omitted \u2014 the behavior is unsupported and could change in a future version.\", key);\n break;\n }\n return knownKeys;\n }\n function reconcileChildrenArray(returnFiber, currentFirstChild, newChildren, lanes) {\n // First, validate keys.\n var knownKeys = null;\n for(var i = 0; i < newChildren.length; i++){\n var child = newChildren[i];\n knownKeys = warnOnInvalidKey(child, knownKeys, returnFiber);\n }\n var resultingFirstChild = null;\n var previousNewFiber = null;\n var oldFiber = currentFirstChild;\n var lastPlacedIndex = 0;\n var newIdx = 0;\n var nextOldFiber = null;\n for(; oldFiber !== null && newIdx < newChildren.length; newIdx++){\n if (oldFiber.index > newIdx) {\n nextOldFiber = oldFiber;\n oldFiber = null;\n } else nextOldFiber = oldFiber.sibling;\n var newFiber = updateSlot(returnFiber, oldFiber, newChildren[newIdx], lanes);\n if (newFiber === null) {\n // TODO: This breaks on empty slots like null children. That's\n // unfortunate because it triggers the slow path all the time. We need\n // a better way to communicate whether this was a miss or null,\n // boolean, undefined, etc.\n if (oldFiber === null) oldFiber = nextOldFiber;\n break;\n }\n if (shouldTrackSideEffects) {\n if (oldFiber && newFiber.alternate === null) // We matched the slot, but we didn't reuse the existing fiber, so we\n // need to delete the existing child.\n deleteChild(returnFiber, oldFiber);\n }\n lastPlacedIndex = placeChild(newFiber, lastPlacedIndex, newIdx);\n if (previousNewFiber === null) // TODO: Move out of the loop. This only happens for the first run.\n resultingFirstChild = newFiber;\n else // TODO: Defer siblings if we're not at the right index for this slot.\n // I.e. if we had null values before, then we want to defer this\n // for each null value. However, we also don't want to call updateSlot\n // with the previous one.\n previousNewFiber.sibling = newFiber;\n previousNewFiber = newFiber;\n oldFiber = nextOldFiber;\n }\n if (newIdx === newChildren.length) {\n // We've reached the end of the new children. We can delete the rest.\n deleteRemainingChildren(returnFiber, oldFiber);\n return resultingFirstChild;\n }\n if (oldFiber === null) {\n // If we don't have any more existing children we can choose a fast path\n // since the rest will all be insertions.\n for(; newIdx < newChildren.length; newIdx++){\n var _newFiber = createChild(returnFiber, newChildren[newIdx], lanes);\n if (_newFiber === null) continue;\n lastPlacedIndex = placeChild(_newFiber, lastPlacedIndex, newIdx);\n if (previousNewFiber === null) // TODO: Move out of the loop. This only happens for the first run.\n resultingFirstChild = _newFiber;\n else previousNewFiber.sibling = _newFiber;\n previousNewFiber = _newFiber;\n }\n return resultingFirstChild;\n } // Add all children to a key map for quick lookups.\n var existingChildren = mapRemainingChildren(returnFiber, oldFiber); // Keep scanning and use the map to restore deleted items as moves.\n for(; newIdx < newChildren.length; newIdx++){\n var _newFiber2 = updateFromMap(existingChildren, returnFiber, newIdx, newChildren[newIdx], lanes);\n if (_newFiber2 !== null) {\n if (shouldTrackSideEffects) {\n if (_newFiber2.alternate !== null) // The new fiber is a work in progress, but if there exists a\n // current, that means that we reused the fiber. We need to delete\n // it from the child list so that we don't add it to the deletion\n // list.\n existingChildren.delete(_newFiber2.key === null ? newIdx : _newFiber2.key);\n }\n lastPlacedIndex = placeChild(_newFiber2, lastPlacedIndex, newIdx);\n if (previousNewFiber === null) resultingFirstChild = _newFiber2;\n else previousNewFiber.sibling = _newFiber2;\n previousNewFiber = _newFiber2;\n }\n }\n if (shouldTrackSideEffects) // Any existing children that weren't consumed above were deleted. We need\n // to add them to the deletion list.\n existingChildren.forEach(function(child) {\n return deleteChild(returnFiber, child);\n });\n return resultingFirstChild;\n }\n function reconcileChildrenIterator(returnFiber, currentFirstChild, newChildrenIterable, lanes) {\n // This is the same implementation as reconcileChildrenArray(),\n // but using the iterator instead.\n var iteratorFn = getIteratorFn(newChildrenIterable);\n if (!(typeof iteratorFn === 'function')) throw Error(\"An object is not an iterable. This error is likely caused by a bug in React. Please file an issue.\");\n // We don't support rendering Generators because it's a mutation.\n // See https://github.com/facebook/react/issues/12995\n if (typeof Symbol === 'function' && newChildrenIterable[Symbol.toStringTag] === 'Generator') {\n if (!didWarnAboutGenerators) error1(\"Using Generators as children is unsupported and will likely yield unexpected results because enumerating a generator mutates it. You may convert it to an array with `Array.from()` or the `[...spread]` operator before rendering. Keep in mind you might need to polyfill these features for older browsers.\");\n didWarnAboutGenerators = true;\n } // Warn about using Maps as children\n if (newChildrenIterable.entries === iteratorFn) {\n if (!didWarnAboutMaps) error1(\"Using Maps as children is not supported. Use an array of keyed ReactElements instead.\");\n didWarnAboutMaps = true;\n } // First, validate keys.\n // We'll get a different iterator later for the main pass.\n var _newChildren = iteratorFn.call(newChildrenIterable);\n if (_newChildren) {\n var knownKeys = null;\n var _step = _newChildren.next();\n for(; !_step.done; _step = _newChildren.next()){\n var child = _step.value;\n knownKeys = warnOnInvalidKey(child, knownKeys, returnFiber);\n }\n }\n var newChildren = iteratorFn.call(newChildrenIterable);\n if (!(newChildren != null)) throw Error(\"An iterable object provided no iterator.\");\n var resultingFirstChild = null;\n var previousNewFiber = null;\n var oldFiber = currentFirstChild;\n var lastPlacedIndex = 0;\n var newIdx = 0;\n var nextOldFiber = null;\n var step = newChildren.next();\n for(; oldFiber !== null && !step.done; newIdx++, step = newChildren.next()){\n if (oldFiber.index > newIdx) {\n nextOldFiber = oldFiber;\n oldFiber = null;\n } else nextOldFiber = oldFiber.sibling;\n var newFiber = updateSlot(returnFiber, oldFiber, step.value, lanes);\n if (newFiber === null) {\n // TODO: This breaks on empty slots like null children. That's\n // unfortunate because it triggers the slow path all the time. We need\n // a better way to communicate whether this was a miss or null,\n // boolean, undefined, etc.\n if (oldFiber === null) oldFiber = nextOldFiber;\n break;\n }\n if (shouldTrackSideEffects) {\n if (oldFiber && newFiber.alternate === null) // We matched the slot, but we didn't reuse the existing fiber, so we\n // need to delete the existing child.\n deleteChild(returnFiber, oldFiber);\n }\n lastPlacedIndex = placeChild(newFiber, lastPlacedIndex, newIdx);\n if (previousNewFiber === null) // TODO: Move out of the loop. This only happens for the first run.\n resultingFirstChild = newFiber;\n else // TODO: Defer siblings if we're not at the right index for this slot.\n // I.e. if we had null values before, then we want to defer this\n // for each null value. However, we also don't want to call updateSlot\n // with the previous one.\n previousNewFiber.sibling = newFiber;\n previousNewFiber = newFiber;\n oldFiber = nextOldFiber;\n }\n if (step.done) {\n // We've reached the end of the new children. We can delete the rest.\n deleteRemainingChildren(returnFiber, oldFiber);\n return resultingFirstChild;\n }\n if (oldFiber === null) {\n // If we don't have any more existing children we can choose a fast path\n // since the rest will all be insertions.\n for(; !step.done; newIdx++, step = newChildren.next()){\n var _newFiber3 = createChild(returnFiber, step.value, lanes);\n if (_newFiber3 === null) continue;\n lastPlacedIndex = placeChild(_newFiber3, lastPlacedIndex, newIdx);\n if (previousNewFiber === null) // TODO: Move out of the loop. This only happens for the first run.\n resultingFirstChild = _newFiber3;\n else previousNewFiber.sibling = _newFiber3;\n previousNewFiber = _newFiber3;\n }\n return resultingFirstChild;\n } // Add all children to a key map for quick lookups.\n var existingChildren = mapRemainingChildren(returnFiber, oldFiber); // Keep scanning and use the map to restore deleted items as moves.\n for(; !step.done; newIdx++, step = newChildren.next()){\n var _newFiber4 = updateFromMap(existingChildren, returnFiber, newIdx, step.value, lanes);\n if (_newFiber4 !== null) {\n if (shouldTrackSideEffects) {\n if (_newFiber4.alternate !== null) // The new fiber is a work in progress, but if there exists a\n // current, that means that we reused the fiber. We need to delete\n // it from the child list so that we don't add it to the deletion\n // list.\n existingChildren.delete(_newFiber4.key === null ? newIdx : _newFiber4.key);\n }\n lastPlacedIndex = placeChild(_newFiber4, lastPlacedIndex, newIdx);\n if (previousNewFiber === null) resultingFirstChild = _newFiber4;\n else previousNewFiber.sibling = _newFiber4;\n previousNewFiber = _newFiber4;\n }\n }\n if (shouldTrackSideEffects) // Any existing children that weren't consumed above were deleted. We need\n // to add them to the deletion list.\n existingChildren.forEach(function(child) {\n return deleteChild(returnFiber, child);\n });\n return resultingFirstChild;\n }\n function reconcileSingleTextNode(returnFiber, currentFirstChild, textContent, lanes) {\n // There's no need to check for keys on text nodes since we don't have a\n // way to define them.\n if (currentFirstChild !== null && currentFirstChild.tag === HostText) {\n // We already have an existing node so let's just update it and delete\n // the rest.\n deleteRemainingChildren(returnFiber, currentFirstChild.sibling);\n var existing = useFiber(currentFirstChild, textContent);\n existing.return = returnFiber;\n return existing;\n } // The existing first child is not a text node so we need to create one\n // and delete the existing ones.\n deleteRemainingChildren(returnFiber, currentFirstChild);\n var created = createFiberFromText(textContent, returnFiber.mode, lanes);\n created.return = returnFiber;\n return created;\n }\n function reconcileSingleElement(returnFiber, currentFirstChild, element, lanes) {\n var key = element.key;\n var child = currentFirstChild;\n while(child !== null){\n // TODO: If key === null and child.key === null, then this only applies to\n // the first item in the list.\n if (child.key === key) {\n switch(child.tag){\n case Fragment:\n if (element.type === REACT_FRAGMENT_TYPE) {\n deleteRemainingChildren(returnFiber, child.sibling);\n var existing = useFiber(child, element.props.children);\n existing.return = returnFiber;\n existing._debugSource = element._source;\n existing._debugOwner = element._owner;\n return existing;\n }\n break;\n case Block:\n // We intentionally fallthrough here if enableBlocksAPI is not on.\n // eslint-disable-next-lined no-fallthrough\n default:\n if (child.elementType === element.type || isCompatibleFamilyForHotReloading(child, element)) {\n deleteRemainingChildren(returnFiber, child.sibling);\n var _existing3 = useFiber(child, element.props);\n _existing3.ref = coerceRef(returnFiber, child, element);\n _existing3.return = returnFiber;\n _existing3._debugSource = element._source;\n _existing3._debugOwner = element._owner;\n return _existing3;\n }\n break;\n } // Didn't match.\n deleteRemainingChildren(returnFiber, child);\n break;\n } else deleteChild(returnFiber, child);\n child = child.sibling;\n }\n if (element.type === REACT_FRAGMENT_TYPE) {\n var created = createFiberFromFragment(element.props.children, returnFiber.mode, lanes, element.key);\n created.return = returnFiber;\n return created;\n } else {\n var _created4 = createFiberFromElement(element, returnFiber.mode, lanes);\n _created4.ref = coerceRef(returnFiber, currentFirstChild, element);\n _created4.return = returnFiber;\n return _created4;\n }\n }\n function reconcileSinglePortal(returnFiber, currentFirstChild, portal, lanes) {\n var key = portal.key;\n var child = currentFirstChild;\n while(child !== null){\n // TODO: If key === null and child.key === null, then this only applies to\n // the first item in the list.\n if (child.key === key) {\n if (child.tag === HostPortal && child.stateNode.containerInfo === portal.containerInfo && child.stateNode.implementation === portal.implementation) {\n deleteRemainingChildren(returnFiber, child.sibling);\n var existing = useFiber(child, portal.children || []);\n existing.return = returnFiber;\n return existing;\n } else {\n deleteRemainingChildren(returnFiber, child);\n break;\n }\n } else deleteChild(returnFiber, child);\n child = child.sibling;\n }\n var created = createFiberFromPortal(portal, returnFiber.mode, lanes);\n created.return = returnFiber;\n return created;\n } // This API will tag the children with the side-effect of the reconciliation\n // itself. They will be added to the side-effect list as we pass through the\n // children and the parent.\n function reconcileChildFibers(returnFiber, currentFirstChild, newChild, lanes) {\n // This function is not recursive.\n // If the top level item is an array, we treat it as a set of children,\n // not as a fragment. Nested arrays on the other hand will be treated as\n // fragment nodes. Recursion happens at the normal flow.\n // Handle top level unkeyed fragments as if they were arrays.\n // This leads to an ambiguity between <>{[...]}</> and <>...</>.\n // We treat the ambiguous cases above the same.\n var isUnkeyedTopLevelFragment = typeof newChild === 'object' && newChild !== null && newChild.type === REACT_FRAGMENT_TYPE && newChild.key === null;\n if (isUnkeyedTopLevelFragment) newChild = newChild.props.children;\n // Handle object types\n var isObject = typeof newChild === 'object' && newChild !== null;\n if (isObject) switch(newChild.$$typeof){\n case REACT_ELEMENT_TYPE:\n return placeSingleChild(reconcileSingleElement(returnFiber, currentFirstChild, newChild, lanes));\n case REACT_PORTAL_TYPE:\n return placeSingleChild(reconcileSinglePortal(returnFiber, currentFirstChild, newChild, lanes));\n }\n if (typeof newChild === 'string' || typeof newChild === 'number') return placeSingleChild(reconcileSingleTextNode(returnFiber, currentFirstChild, '' + newChild, lanes));\n if (isArray$1(newChild)) return reconcileChildrenArray(returnFiber, currentFirstChild, newChild, lanes);\n if (getIteratorFn(newChild)) return reconcileChildrenIterator(returnFiber, currentFirstChild, newChild, lanes);\n if (isObject) throwOnInvalidObjectType(returnFiber, newChild);\n if (typeof newChild === 'function') warnOnFunctionType(returnFiber);\n if (typeof newChild === 'undefined' && !isUnkeyedTopLevelFragment) // If the new child is undefined, and the return fiber is a composite\n // component, throw an error. If Fiber return types are disabled,\n // we already threw above.\n switch(returnFiber.tag){\n case ClassComponent:\n var instance = returnFiber.stateNode;\n if (instance.render._isMockFunction) break;\n // Intentionally fall through to the next case, which handles both\n // functions and classes\n // eslint-disable-next-lined no-fallthrough\n case Block:\n case FunctionComponent:\n case ForwardRef:\n case SimpleMemoComponent:\n throw Error((getComponentName(returnFiber.type) || 'Component') + \"(...): Nothing was returned from render. This usually means a return statement is missing. Or, to render nothing, return null.\");\n }\n // Remaining cases are all treated as empty.\n return deleteRemainingChildren(returnFiber, currentFirstChild);\n }\n return reconcileChildFibers;\n }\n var reconcileChildFibers1 = ChildReconciler(true);\n var mountChildFibers = ChildReconciler(false);\n function cloneChildFibers(current, workInProgress) {\n if (!(current === null || workInProgress.child === current.child)) throw Error(\"Resuming work not yet implemented.\");\n if (workInProgress.child === null) return;\n var currentChild = workInProgress.child;\n var newChild = createWorkInProgress(currentChild, currentChild.pendingProps);\n workInProgress.child = newChild;\n newChild.return = workInProgress;\n while(currentChild.sibling !== null){\n currentChild = currentChild.sibling;\n newChild = newChild.sibling = createWorkInProgress(currentChild, currentChild.pendingProps);\n newChild.return = workInProgress;\n }\n newChild.sibling = null;\n } // Reset a workInProgress child set to prepare it for a second pass.\n function resetChildFibers(workInProgress, lanes) {\n var child = workInProgress.child;\n while(child !== null){\n resetWorkInProgress(child, lanes);\n child = child.sibling;\n }\n }\n var NO_CONTEXT = {\n };\n var contextStackCursor$1 = createCursor(NO_CONTEXT);\n var contextFiberStackCursor = createCursor(NO_CONTEXT);\n var rootInstanceStackCursor = createCursor(NO_CONTEXT);\n function requiredContext(c) {\n if (!(c !== NO_CONTEXT)) throw Error(\"Expected host context to exist. This error is likely caused by a bug in React. Please file an issue.\");\n return c;\n }\n function getRootHostContainer() {\n var rootInstance = requiredContext(rootInstanceStackCursor.current);\n return rootInstance;\n }\n function pushHostContainer(fiber, nextRootInstance) {\n // Push current root instance onto the stack;\n // This allows us to reset root when portals are popped.\n push(rootInstanceStackCursor, nextRootInstance, fiber); // Track the context and the Fiber that provided it.\n // This enables us to pop only Fibers that provide unique contexts.\n push(contextFiberStackCursor, fiber, fiber); // Finally, we need to push the host context to the stack.\n // However, we can't just call getRootHostContext() and push it because\n // we'd have a different number of entries on the stack depending on\n // whether getRootHostContext() throws somewhere in renderer code or not.\n // So we push an empty value first. This lets us safely unwind on errors.\n push(contextStackCursor$1, NO_CONTEXT, fiber);\n var nextRootContext = getRootHostContext(nextRootInstance); // Now that we know this function doesn't throw, replace it.\n pop(contextStackCursor$1, fiber);\n push(contextStackCursor$1, nextRootContext, fiber);\n }\n function popHostContainer(fiber) {\n pop(contextStackCursor$1, fiber);\n pop(contextFiberStackCursor, fiber);\n pop(rootInstanceStackCursor, fiber);\n }\n function getHostContext() {\n var context = requiredContext(contextStackCursor$1.current);\n return context;\n }\n function pushHostContext(fiber) {\n var rootInstance = requiredContext(rootInstanceStackCursor.current);\n var context = requiredContext(contextStackCursor$1.current);\n var nextContext = getChildHostContext(context, fiber.type); // Don't push this Fiber's context unless it's unique.\n if (context === nextContext) return;\n // Track the context and the Fiber that provided it.\n // This enables us to pop only Fibers that provide unique contexts.\n push(contextFiberStackCursor, fiber, fiber);\n push(contextStackCursor$1, nextContext, fiber);\n }\n function popHostContext(fiber) {\n // Do not pop unless this Fiber provided the current context.\n // pushHostContext() only pushes Fibers that provide unique contexts.\n if (contextFiberStackCursor.current !== fiber) return;\n pop(contextStackCursor$1, fiber);\n pop(contextFiberStackCursor, fiber);\n }\n var DefaultSuspenseContext = 0; // The Suspense Context is split into two parts. The lower bits is\n // inherited deeply down the subtree. The upper bits only affect\n // this immediate suspense boundary and gets reset each new\n // boundary or suspense list.\n var SubtreeSuspenseContextMask = 1; // Subtree Flags:\n // InvisibleParentSuspenseContext indicates that one of our parent Suspense\n // boundaries is not currently showing visible main content.\n // Either because it is already showing a fallback or is not mounted at all.\n // We can use this to determine if it is desirable to trigger a fallback at\n // the parent. If not, then we might need to trigger undesirable boundaries\n // and/or suspend the commit to avoid hiding the parent content.\n var InvisibleParentSuspenseContext = 1; // Shallow Flags:\n // ForceSuspenseFallback can be used by SuspenseList to force newly added\n // items into their fallback state during one of the render passes.\n var ForceSuspenseFallback = 2;\n var suspenseStackCursor = createCursor(DefaultSuspenseContext);\n function hasSuspenseContext(parentContext, flag) {\n return (parentContext & flag) !== 0;\n }\n function setDefaultShallowSuspenseContext(parentContext) {\n return parentContext & SubtreeSuspenseContextMask;\n }\n function setShallowSuspenseContext(parentContext, shallowContext) {\n return parentContext & SubtreeSuspenseContextMask | shallowContext;\n }\n function addSubtreeSuspenseContext(parentContext, subtreeContext) {\n return parentContext | subtreeContext;\n }\n function pushSuspenseContext(fiber, newContext) {\n push(suspenseStackCursor, newContext, fiber);\n }\n function popSuspenseContext(fiber) {\n pop(suspenseStackCursor, fiber);\n }\n function shouldCaptureSuspense(workInProgress, hasInvisibleParent) {\n // If it was the primary children that just suspended, capture and render the\n // fallback. Otherwise, don't capture and bubble to the next boundary.\n var nextState = workInProgress.memoizedState;\n if (nextState !== null) {\n if (nextState.dehydrated !== null) // A dehydrated boundary always captures.\n return true;\n return false;\n }\n var props = workInProgress.memoizedProps; // In order to capture, the Suspense component must have a fallback prop.\n if (props.fallback === undefined) return false;\n // Regular boundaries always capture.\n if (props.unstable_avoidThisFallback !== true) return true;\n // If it's a boundary we should avoid, then we prefer to bubble up to the\n // parent boundary if it is currently invisible.\n if (hasInvisibleParent) return false;\n // If the parent is not able to handle it, we must handle it.\n return true;\n }\n function findFirstSuspended(row) {\n var node = row;\n while(node !== null){\n if (node.tag === SuspenseComponent) {\n var state = node.memoizedState;\n if (state !== null) {\n var dehydrated = state.dehydrated;\n if (dehydrated === null || isSuspenseInstancePending(dehydrated) || isSuspenseInstanceFallback(dehydrated)) return node;\n }\n } else if (node.tag === SuspenseListComponent && // keep track of whether it suspended or not.\n node.memoizedProps.revealOrder !== undefined) {\n var didSuspend = (node.flags & DidCapture) !== NoFlags;\n if (didSuspend) return node;\n } else if (node.child !== null) {\n node.child.return = node;\n node = node.child;\n continue;\n }\n if (node === row) return null;\n while(node.sibling === null){\n if (node.return === null || node.return === row) return null;\n node = node.return;\n }\n node.sibling.return = node.return;\n node = node.sibling;\n }\n return null;\n }\n var NoFlags$1 = /* */ 0; // Represents whether effect should fire.\n var HasEffect = /* */ 1; // Represents the phase in which the effect (not the clean-up) fires.\n var Layout = /* */ 2;\n var Passive$1 = /* */ 4;\n // This may have been an insertion or a hydration.\n var hydrationParentFiber = null;\n var nextHydratableInstance = null;\n var isHydrating1 = false;\n function enterHydrationState(fiber) {\n var parentInstance = fiber.stateNode.containerInfo;\n nextHydratableInstance = getFirstHydratableChild(parentInstance);\n hydrationParentFiber = fiber;\n isHydrating1 = true;\n return true;\n }\n function deleteHydratableInstance(returnFiber, instance) {\n switch(returnFiber.tag){\n case HostRoot:\n didNotHydrateContainerInstance(returnFiber.stateNode.containerInfo, instance);\n break;\n case HostComponent:\n didNotHydrateInstance(returnFiber.type, returnFiber.memoizedProps, returnFiber.stateNode, instance);\n break;\n }\n var childToDelete = createFiberFromHostInstanceForDeletion();\n childToDelete.stateNode = instance;\n childToDelete.return = returnFiber;\n childToDelete.flags = Deletion; // This might seem like it belongs on progressedFirstDeletion. However,\n // these children are not part of the reconciliation list of children.\n // Even if we abort and rereconcile the children, that will try to hydrate\n // again and the nodes are still in the host tree so these will be\n // recreated.\n if (returnFiber.lastEffect !== null) {\n returnFiber.lastEffect.nextEffect = childToDelete;\n returnFiber.lastEffect = childToDelete;\n } else returnFiber.firstEffect = returnFiber.lastEffect = childToDelete;\n }\n function insertNonHydratedInstance(returnFiber, fiber) {\n fiber.flags = fiber.flags & ~Hydrating | Placement;\n switch(returnFiber.tag){\n case HostRoot:\n var parentContainer = returnFiber.stateNode.containerInfo;\n switch(fiber.tag){\n case HostComponent:\n var type = fiber.type;\n var props = fiber.pendingProps;\n didNotFindHydratableContainerInstance(parentContainer, type);\n break;\n case HostText:\n var text = fiber.pendingProps;\n didNotFindHydratableContainerTextInstance(parentContainer, text);\n break;\n }\n break;\n case HostComponent:\n var parentType = returnFiber.type;\n var parentProps = returnFiber.memoizedProps;\n var parentInstance = returnFiber.stateNode;\n switch(fiber.tag){\n case HostComponent:\n var _type = fiber.type;\n var _props = fiber.pendingProps;\n didNotFindHydratableInstance(parentType, parentProps, parentInstance, _type);\n break;\n case HostText:\n var _text = fiber.pendingProps;\n didNotFindHydratableTextInstance(parentType, parentProps, parentInstance, _text);\n break;\n case SuspenseComponent:\n didNotFindHydratableSuspenseInstance(parentType, parentProps);\n break;\n }\n break;\n default:\n return;\n }\n }\n function tryHydrate(fiber, nextInstance) {\n switch(fiber.tag){\n case HostComponent:\n var type = fiber.type;\n var props = fiber.pendingProps;\n var instance = canHydrateInstance(nextInstance, type);\n if (instance !== null) {\n fiber.stateNode = instance;\n return true;\n }\n return false;\n case HostText:\n var text = fiber.pendingProps;\n var textInstance = canHydrateTextInstance(nextInstance, text);\n if (textInstance !== null) {\n fiber.stateNode = textInstance;\n return true;\n }\n return false;\n case SuspenseComponent:\n return false;\n default:\n return false;\n }\n }\n function tryToClaimNextHydratableInstance(fiber) {\n if (!isHydrating1) return;\n var nextInstance = nextHydratableInstance;\n if (!nextInstance) {\n // Nothing to hydrate. Make it an insertion.\n insertNonHydratedInstance(hydrationParentFiber, fiber);\n isHydrating1 = false;\n hydrationParentFiber = fiber;\n return;\n }\n var firstAttemptedInstance = nextInstance;\n if (!tryHydrate(fiber, nextInstance)) {\n // If we can't hydrate this instance let's try the next one.\n // We use this as a heuristic. It's based on intuition and not data so it\n // might be flawed or unnecessary.\n nextInstance = getNextHydratableSibling(firstAttemptedInstance);\n if (!nextInstance || !tryHydrate(fiber, nextInstance)) {\n // Nothing to hydrate. Make it an insertion.\n insertNonHydratedInstance(hydrationParentFiber, fiber);\n isHydrating1 = false;\n hydrationParentFiber = fiber;\n return;\n } // We matched the next one, we'll now assume that the first one was\n // superfluous and we'll delete it. Since we can't eagerly delete it\n // we'll have to schedule a deletion. To do that, this node needs a dummy\n // fiber associated with it.\n deleteHydratableInstance(hydrationParentFiber, firstAttemptedInstance);\n }\n hydrationParentFiber = fiber;\n nextHydratableInstance = getFirstHydratableChild(nextInstance);\n }\n function prepareToHydrateHostInstance(fiber, rootContainerInstance, hostContext) {\n var instance = fiber.stateNode;\n var updatePayload = hydrateInstance(instance, fiber.type, fiber.memoizedProps, rootContainerInstance, hostContext, fiber); // TODO: Type this specific to this type of component.\n fiber.updateQueue = updatePayload; // If the update payload indicates that there is a change or if there\n // is a new ref we mark this as an update.\n if (updatePayload !== null) return true;\n return false;\n }\n function prepareToHydrateHostTextInstance(fiber) {\n var textInstance = fiber.stateNode;\n var textContent = fiber.memoizedProps;\n var shouldUpdate = hydrateTextInstance(textInstance, textContent, fiber);\n if (shouldUpdate) {\n // We assume that prepareToHydrateHostTextInstance is called in a context where the\n // hydration parent is the parent host component of this host text.\n var returnFiber = hydrationParentFiber;\n if (returnFiber !== null) switch(returnFiber.tag){\n case HostRoot:\n var parentContainer = returnFiber.stateNode.containerInfo;\n didNotMatchHydratedContainerTextInstance(parentContainer, textInstance, textContent);\n break;\n case HostComponent:\n var parentType = returnFiber.type;\n var parentProps = returnFiber.memoizedProps;\n var parentInstance = returnFiber.stateNode;\n didNotMatchHydratedTextInstance(parentType, parentProps, parentInstance, textInstance, textContent);\n break;\n }\n }\n return shouldUpdate;\n }\n function skipPastDehydratedSuspenseInstance(fiber) {\n var suspenseState = fiber.memoizedState;\n var suspenseInstance = suspenseState !== null ? suspenseState.dehydrated : null;\n if (!suspenseInstance) throw Error(\"Expected to have a hydrated suspense instance. This error is likely caused by a bug in React. Please file an issue.\");\n return getNextHydratableInstanceAfterSuspenseInstance(suspenseInstance);\n }\n function popToNextHostParent(fiber) {\n var parent = fiber.return;\n while(parent !== null && parent.tag !== HostComponent && parent.tag !== HostRoot && parent.tag !== SuspenseComponent)parent = parent.return;\n hydrationParentFiber = parent;\n }\n function popHydrationState(fiber) {\n if (fiber !== hydrationParentFiber) // We're deeper than the current hydration context, inside an inserted\n // tree.\n return false;\n if (!isHydrating1) {\n // If we're not currently hydrating but we're in a hydration context, then\n // we were an insertion and now need to pop up reenter hydration of our\n // siblings.\n popToNextHostParent(fiber);\n isHydrating1 = true;\n return false;\n }\n var type = fiber.type; // If we have any remaining hydratable nodes, we need to delete them now.\n // We only do this deeper than head and body since they tend to have random\n // other nodes in them. We also ignore components with pure text content in\n // side of them.\n // TODO: Better heuristic.\n if (fiber.tag !== HostComponent || type !== 'head' && type !== 'body' && !shouldSetTextContent(type, fiber.memoizedProps)) {\n var nextInstance = nextHydratableInstance;\n while(nextInstance){\n deleteHydratableInstance(fiber, nextInstance);\n nextInstance = getNextHydratableSibling(nextInstance);\n }\n }\n popToNextHostParent(fiber);\n if (fiber.tag === SuspenseComponent) nextHydratableInstance = skipPastDehydratedSuspenseInstance(fiber);\n else nextHydratableInstance = hydrationParentFiber ? getNextHydratableSibling(fiber.stateNode) : null;\n return true;\n }\n function resetHydrationState() {\n hydrationParentFiber = null;\n nextHydratableInstance = null;\n isHydrating1 = false;\n }\n function getIsHydrating() {\n return isHydrating1;\n }\n // and should be reset before starting a new render.\n // This tracks which mutable sources need to be reset after a render.\n var workInProgressSources = [];\n var rendererSigil$1;\n // Used to detect multiple renderers using the same mutable source.\n rendererSigil$1 = {\n };\n function markSourceAsDirty(mutableSource) {\n workInProgressSources.push(mutableSource);\n }\n function resetWorkInProgressVersions() {\n for(var i = 0; i < workInProgressSources.length; i++){\n var mutableSource = workInProgressSources[i];\n mutableSource._workInProgressVersionPrimary = null;\n }\n workInProgressSources.length = 0;\n }\n function getWorkInProgressVersion(mutableSource) {\n return mutableSource._workInProgressVersionPrimary;\n }\n function setWorkInProgressVersion(mutableSource, version) {\n mutableSource._workInProgressVersionPrimary = version;\n workInProgressSources.push(mutableSource);\n }\n function warnAboutMultipleRenderersDEV(mutableSource) {\n if (mutableSource._currentPrimaryRenderer == null) mutableSource._currentPrimaryRenderer = rendererSigil$1;\n else if (mutableSource._currentPrimaryRenderer !== rendererSigil$1) error1(\"Detected multiple renderers concurrently rendering the same mutable source. This is currently unsupported.\");\n } // Eager reads the version of a mutable source and stores it on the root.\n var ReactCurrentDispatcher$1 = ReactSharedInternals.ReactCurrentDispatcher, ReactCurrentBatchConfig$1 = ReactSharedInternals.ReactCurrentBatchConfig;\n var didWarnAboutMismatchedHooksForComponent;\n var didWarnAboutUseOpaqueIdentifier;\n didWarnAboutUseOpaqueIdentifier = {\n };\n didWarnAboutMismatchedHooksForComponent = new Set();\n // These are set right before calling the component.\n var renderLanes1 = NoLanes; // The work-in-progress fiber. I've named it differently to distinguish it from\n // the work-in-progress hook.\n var currentlyRenderingFiber$1 = null; // Hooks are stored as a linked list on the fiber's memoizedState field. The\n // current hook list is the list that belongs to the current fiber. The\n // work-in-progress hook list is a new list that will be added to the\n // work-in-progress fiber.\n var currentHook1 = null;\n var workInProgressHook = null; // Whether an update was scheduled at any point during the render phase. This\n // does not get reset if we do another render pass; only when we're completely\n // finished evaluating this component. This is an optimization so we know\n // whether we need to clear render phase updates after a throw.\n var didScheduleRenderPhaseUpdate = false; // Where an update was scheduled only during the current render pass. This\n // gets reset after each attempt.\n // TODO: Maybe there's some way to consolidate this with\n // `didScheduleRenderPhaseUpdate`. Or with `numberOfReRenders`.\n var didScheduleRenderPhaseUpdateDuringThisPass = false;\n var RE_RENDER_LIMIT = 25; // In DEV, this is the name of the currently executing primitive hook\n var currentHookNameInDev = null; // In DEV, this list ensures that hooks are called in the same order between renders.\n // The list stores the order of hooks used during the initial render (mount).\n // Subsequent renders (updates) reference this list.\n var hookTypesDev = null;\n var hookTypesUpdateIndexDev = -1; // In DEV, this tracks whether currently rendering component needs to ignore\n // the dependencies for Hooks that need them (e.g. useEffect or useMemo).\n // When true, such Hooks will always be \"remounted\". Only used during hot reload.\n var ignorePreviousDependencies = false;\n function mountHookTypesDev() {\n var hookName = currentHookNameInDev;\n if (hookTypesDev === null) hookTypesDev = [\n hookName\n ];\n else hookTypesDev.push(hookName);\n }\n function updateHookTypesDev() {\n var hookName = currentHookNameInDev;\n if (hookTypesDev !== null) {\n hookTypesUpdateIndexDev++;\n if (hookTypesDev[hookTypesUpdateIndexDev] !== hookName) warnOnHookMismatchInDev(hookName);\n }\n }\n function checkDepsAreArrayDev(deps) {\n if (deps !== undefined && deps !== null && !Array.isArray(deps)) // Verify deps, but only on mount to avoid extra checks.\n // It's unlikely their type would change as usually you define them inline.\n error1(\"%s received a final argument that is not an array (instead, received `%s`). When specified, the final argument must be an array.\", currentHookNameInDev, typeof deps);\n }\n function warnOnHookMismatchInDev(currentHookName) {\n var componentName = getComponentName(currentlyRenderingFiber$1.type);\n if (!didWarnAboutMismatchedHooksForComponent.has(componentName)) {\n didWarnAboutMismatchedHooksForComponent.add(componentName);\n if (hookTypesDev !== null) {\n var table = '';\n var secondColumnStart = 30;\n for(var i = 0; i <= hookTypesUpdateIndexDev; i++){\n var oldHookName = hookTypesDev[i];\n var newHookName = i === hookTypesUpdateIndexDev ? currentHookName : oldHookName;\n var row = i + 1 + \". \" + oldHookName; // Extra space so second column lines up\n // lol @ IE not supporting String#repeat\n while(row.length < secondColumnStart)row += ' ';\n row += newHookName + '\\n';\n table += row;\n }\n error1(\"React has detected a change in the order of Hooks called by %s. This will lead to bugs and errors if not fixed. For more information, read the Rules of Hooks: https://reactjs.org/link/rules-of-hooks\\n\\n Previous render Next render\\n ------------------------------------------------------\\n%s ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\\n\", componentName, table);\n }\n }\n }\n function throwInvalidHookError() {\n throw Error(\"Invalid hook call. Hooks can only be called inside of the body of a function component. This could happen for one of the following reasons:\\n1. You might have mismatching versions of React and the renderer (such as React DOM)\\n2. You might be breaking the Rules of Hooks\\n3. You might have more than one copy of React in the same app\\nSee https://reactjs.org/link/invalid-hook-call for tips about how to debug and fix this problem.\");\n }\n function areHookInputsEqual(nextDeps, prevDeps) {\n if (ignorePreviousDependencies) // Only true when this component is being hot reloaded.\n return false;\n if (prevDeps === null) {\n error1(\"%s received a final argument during this render, but not during the previous render. Even though the final argument is optional, its type cannot change between renders.\", currentHookNameInDev);\n return false;\n }\n // Don't bother comparing lengths in prod because these arrays should be\n // passed inline.\n if (nextDeps.length !== prevDeps.length) error1(\"The final argument passed to %s changed size between renders. The order and size of this array must remain constant.\\n\\nPrevious: %s\\nIncoming: %s\", currentHookNameInDev, \"[\" + prevDeps.join(', ') + \"]\", \"[\" + nextDeps.join(', ') + \"]\");\n for(var i = 0; i < prevDeps.length && i < nextDeps.length; i++){\n if (objectIs(nextDeps[i], prevDeps[i])) continue;\n return false;\n }\n return true;\n }\n function renderWithHooks(current, workInProgress, Component, props, secondArg, nextRenderLanes) {\n renderLanes1 = nextRenderLanes;\n currentlyRenderingFiber$1 = workInProgress;\n hookTypesDev = current !== null ? current._debugHookTypes : null;\n hookTypesUpdateIndexDev = -1; // Used for hot reloading:\n ignorePreviousDependencies = current !== null && current.type !== workInProgress.type;\n workInProgress.memoizedState = null;\n workInProgress.updateQueue = null;\n workInProgress.lanes = NoLanes; // The following should have already been reset\n if (current !== null && current.memoizedState !== null) ReactCurrentDispatcher$1.current = HooksDispatcherOnUpdateInDEV;\n else if (hookTypesDev !== null) // This dispatcher handles an edge case where a component is updating,\n // but no stateful hooks have been used.\n // We want to match the production code behavior (which will use HooksDispatcherOnMount),\n // but with the extra DEV validation to ensure hooks ordering hasn't changed.\n // This dispatcher does that.\n ReactCurrentDispatcher$1.current = HooksDispatcherOnMountWithHookTypesInDEV;\n else ReactCurrentDispatcher$1.current = HooksDispatcherOnMountInDEV;\n var children = Component(props, secondArg); // Check if there was a render phase update\n if (didScheduleRenderPhaseUpdateDuringThisPass) {\n // Keep rendering in a loop for as long as render phase updates continue to\n // be scheduled. Use a counter to prevent infinite loops.\n var numberOfReRenders = 0;\n do {\n didScheduleRenderPhaseUpdateDuringThisPass = false;\n if (!(numberOfReRenders < RE_RENDER_LIMIT)) throw Error(\"Too many re-renders. React limits the number of renders to prevent an infinite loop.\");\n numberOfReRenders += 1;\n // Even when hot reloading, allow dependencies to stabilize\n // after first render to prevent infinite render phase updates.\n ignorePreviousDependencies = false;\n currentHook1 = null;\n workInProgressHook = null;\n workInProgress.updateQueue = null;\n // Also validate hook order for cascading updates.\n hookTypesUpdateIndexDev = -1;\n ReactCurrentDispatcher$1.current = HooksDispatcherOnRerenderInDEV;\n children = Component(props, secondArg);\n }while (didScheduleRenderPhaseUpdateDuringThisPass)\n } // We can assume the previous dispatcher is always this one, since we set it\n // at the beginning of the render phase and there's no re-entrancy.\n ReactCurrentDispatcher$1.current = ContextOnlyDispatcher;\n workInProgress._debugHookTypes = hookTypesDev;\n // hookTypesDev could catch more cases (e.g. context) but only in DEV bundles.\n var didRenderTooFewHooks = currentHook1 !== null && currentHook1.next !== null;\n renderLanes1 = NoLanes;\n currentlyRenderingFiber$1 = null;\n currentHook1 = null;\n workInProgressHook = null;\n currentHookNameInDev = null;\n hookTypesDev = null;\n hookTypesUpdateIndexDev = -1;\n didScheduleRenderPhaseUpdate = false;\n if (!!didRenderTooFewHooks) throw Error(\"Rendered fewer hooks than expected. This may be caused by an accidental early return statement.\");\n return children;\n }\n function bailoutHooks(current, workInProgress, lanes) {\n workInProgress.updateQueue = current.updateQueue;\n workInProgress.flags &= ~(Passive | Update);\n current.lanes = removeLanes(current.lanes, lanes);\n }\n function resetHooksAfterThrow() {\n // We can assume the previous dispatcher is always this one, since we set it\n // at the beginning of the render phase and there's no re-entrancy.\n ReactCurrentDispatcher$1.current = ContextOnlyDispatcher;\n if (didScheduleRenderPhaseUpdate) {\n // There were render phase updates. These are only valid for this render\n // phase, which we are now aborting. Remove the updates from the queues so\n // they do not persist to the next render. Do not remove updates from hooks\n // that weren't processed.\n //\n // Only reset the updates from the queue if it has a clone. If it does\n // not have a clone, that means it wasn't processed, and the updates were\n // scheduled before we entered the render phase.\n var hook = currentlyRenderingFiber$1.memoizedState;\n while(hook !== null){\n var queue = hook.queue;\n if (queue !== null) queue.pending = null;\n hook = hook.next;\n }\n didScheduleRenderPhaseUpdate = false;\n }\n renderLanes1 = NoLanes;\n currentlyRenderingFiber$1 = null;\n currentHook1 = null;\n workInProgressHook = null;\n hookTypesDev = null;\n hookTypesUpdateIndexDev = -1;\n currentHookNameInDev = null;\n isUpdatingOpaqueValueInRenderPhase = false;\n didScheduleRenderPhaseUpdateDuringThisPass = false;\n }\n function mountWorkInProgressHook() {\n var hook = {\n memoizedState: null,\n baseState: null,\n baseQueue: null,\n queue: null,\n next: null\n };\n if (workInProgressHook === null) // This is the first hook in the list\n currentlyRenderingFiber$1.memoizedState = workInProgressHook = hook;\n else // Append to the end of the list\n workInProgressHook = workInProgressHook.next = hook;\n return workInProgressHook;\n }\n function updateWorkInProgressHook() {\n // This function is used both for updates and for re-renders triggered by a\n // render phase update. It assumes there is either a current hook we can\n // clone, or a work-in-progress hook from a previous render pass that we can\n // use as a base. When we reach the end of the base list, we must switch to\n // the dispatcher used for mounts.\n var nextCurrentHook;\n if (currentHook1 === null) {\n var current = currentlyRenderingFiber$1.alternate;\n if (current !== null) nextCurrentHook = current.memoizedState;\n else nextCurrentHook = null;\n } else nextCurrentHook = currentHook1.next;\n var nextWorkInProgressHook;\n if (workInProgressHook === null) nextWorkInProgressHook = currentlyRenderingFiber$1.memoizedState;\n else nextWorkInProgressHook = workInProgressHook.next;\n if (nextWorkInProgressHook !== null) {\n // There's already a work-in-progress. Reuse it.\n workInProgressHook = nextWorkInProgressHook;\n nextWorkInProgressHook = workInProgressHook.next;\n currentHook1 = nextCurrentHook;\n } else {\n // Clone from the current hook.\n if (!(nextCurrentHook !== null)) throw Error(\"Rendered more hooks than during the previous render.\");\n currentHook1 = nextCurrentHook;\n var newHook = {\n memoizedState: currentHook1.memoizedState,\n baseState: currentHook1.baseState,\n baseQueue: currentHook1.baseQueue,\n queue: currentHook1.queue,\n next: null\n };\n if (workInProgressHook === null) // This is the first hook in the list.\n currentlyRenderingFiber$1.memoizedState = workInProgressHook = newHook;\n else // Append to the end of the list.\n workInProgressHook = workInProgressHook.next = newHook;\n }\n return workInProgressHook;\n }\n function createFunctionComponentUpdateQueue() {\n return {\n lastEffect: null\n };\n }\n function basicStateReducer(state, action) {\n // $FlowFixMe: Flow doesn't like mixed types\n return typeof action === 'function' ? action(state) : action;\n }\n function mountReducer(reducer, initialArg, init) {\n var hook = mountWorkInProgressHook();\n var initialState;\n if (init !== undefined) initialState = init(initialArg);\n else initialState = initialArg;\n hook.memoizedState = hook.baseState = initialState;\n var queue = hook.queue = {\n pending: null,\n dispatch: null,\n lastRenderedReducer: reducer,\n lastRenderedState: initialState\n };\n var dispatch = queue.dispatch = dispatchAction.bind(null, currentlyRenderingFiber$1, queue);\n return [\n hook.memoizedState,\n dispatch\n ];\n }\n function updateReducer(reducer, initialArg, init) {\n var hook = updateWorkInProgressHook();\n var queue = hook.queue;\n if (!(queue !== null)) throw Error(\"Should have a queue. This is likely a bug in React. Please file an issue.\");\n queue.lastRenderedReducer = reducer;\n var current = currentHook1; // The last rebase update that is NOT part of the base state.\n var baseQueue = current.baseQueue; // The last pending update that hasn't been processed yet.\n var pendingQueue = queue.pending;\n if (pendingQueue !== null) {\n // We have new updates that haven't been processed yet.\n // We'll add them to the base queue.\n if (baseQueue !== null) {\n // Merge the pending queue and the base queue.\n var baseFirst = baseQueue.next;\n var pendingFirst = pendingQueue.next;\n baseQueue.next = pendingFirst;\n pendingQueue.next = baseFirst;\n }\n if (current.baseQueue !== baseQueue) // Internal invariant that should never happen, but feasibly could in\n // the future if we implement resuming, or some form of that.\n error1(\"Internal error: Expected work-in-progress queue to be a clone. This is a bug in React.\");\n current.baseQueue = baseQueue = pendingQueue;\n queue.pending = null;\n }\n if (baseQueue !== null) {\n // We have a queue to process.\n var first = baseQueue.next;\n var newState = current.baseState;\n var newBaseState = null;\n var newBaseQueueFirst = null;\n var newBaseQueueLast = null;\n var update = first;\n do {\n var updateLane = update.lane;\n if (!isSubsetOfLanes(renderLanes1, updateLane)) {\n // Priority is insufficient. Skip this update. If this is the first\n // skipped update, the previous update/state is the new base\n // update/state.\n var clone = {\n lane: updateLane,\n action: update.action,\n eagerReducer: update.eagerReducer,\n eagerState: update.eagerState,\n next: null\n };\n if (newBaseQueueLast === null) {\n newBaseQueueFirst = newBaseQueueLast = clone;\n newBaseState = newState;\n } else newBaseQueueLast = newBaseQueueLast.next = clone;\n // Update the remaining priority in the queue.\n // TODO: Don't need to accumulate this. Instead, we can remove\n // renderLanes from the original lanes.\n currentlyRenderingFiber$1.lanes = mergeLanes(currentlyRenderingFiber$1.lanes, updateLane);\n markSkippedUpdateLanes(updateLane);\n } else {\n // This update does have sufficient priority.\n if (newBaseQueueLast !== null) {\n var _clone = {\n // This update is going to be committed so we never want uncommit\n // it. Using NoLane works because 0 is a subset of all bitmasks, so\n // this will never be skipped by the check above.\n lane: NoLane,\n action: update.action,\n eagerReducer: update.eagerReducer,\n eagerState: update.eagerState,\n next: null\n };\n newBaseQueueLast = newBaseQueueLast.next = _clone;\n } // Process this update.\n if (update.eagerReducer === reducer) // If this update was processed eagerly, and its reducer matches the\n // current reducer, we can use the eagerly computed state.\n newState = update.eagerState;\n else {\n var action = update.action;\n newState = reducer(newState, action);\n }\n }\n update = update.next;\n }while (update !== null && update !== first)\n if (newBaseQueueLast === null) newBaseState = newState;\n else newBaseQueueLast.next = newBaseQueueFirst;\n // Mark that the fiber performed work, but only if the new state is\n // different from the current state.\n if (!objectIs(newState, hook.memoizedState)) markWorkInProgressReceivedUpdate();\n hook.memoizedState = newState;\n hook.baseState = newBaseState;\n hook.baseQueue = newBaseQueueLast;\n queue.lastRenderedState = newState;\n }\n var dispatch = queue.dispatch;\n return [\n hook.memoizedState,\n dispatch\n ];\n }\n function rerenderReducer(reducer, initialArg, init) {\n var hook = updateWorkInProgressHook();\n var queue = hook.queue;\n if (!(queue !== null)) throw Error(\"Should have a queue. This is likely a bug in React. Please file an issue.\");\n queue.lastRenderedReducer = reducer; // This is a re-render. Apply the new render phase updates to the previous\n // work-in-progress hook.\n var dispatch = queue.dispatch;\n var lastRenderPhaseUpdate = queue.pending;\n var newState = hook.memoizedState;\n if (lastRenderPhaseUpdate !== null) {\n // The queue doesn't persist past this render pass.\n queue.pending = null;\n var firstRenderPhaseUpdate = lastRenderPhaseUpdate.next;\n var update = firstRenderPhaseUpdate;\n do {\n // Process this render phase update. We don't have to check the\n // priority because it will always be the same as the current\n // render's.\n var action = update.action;\n newState = reducer(newState, action);\n update = update.next;\n }while (update !== firstRenderPhaseUpdate) // Mark that the fiber performed work, but only if the new state is\n // different from the current state.\n if (!objectIs(newState, hook.memoizedState)) markWorkInProgressReceivedUpdate();\n hook.memoizedState = newState; // Don't persist the state accumulated from the render phase updates to\n // the base state unless the queue is empty.\n // TODO: Not sure if this is the desired semantics, but it's what we\n // do for gDSFP. I can't remember why.\n if (hook.baseQueue === null) hook.baseState = newState;\n queue.lastRenderedState = newState;\n }\n return [\n newState,\n dispatch\n ];\n }\n function readFromUnsubcribedMutableSource(root, source, getSnapshot) {\n warnAboutMultipleRenderersDEV(source);\n var getVersion = source._getVersion;\n var version = getVersion(source._source); // Is it safe for this component to read from this source during the current render?\n var isSafeToReadFromSource = false; // Check the version first.\n // If this render has already been started with a specific version,\n // we can use it alone to determine if we can safely read from the source.\n var currentRenderVersion = getWorkInProgressVersion(source);\n if (currentRenderVersion !== null) // It's safe to read if the store hasn't been mutated since the last time\n // we read something.\n isSafeToReadFromSource = currentRenderVersion === version;\n else {\n // If there's no version, then this is the first time we've read from the\n // source during the current render pass, so we need to do a bit more work.\n // What we need to determine is if there are any hooks that already\n // subscribed to the source, and if so, whether there are any pending\n // mutations that haven't been synchronized yet.\n //\n // If there are no pending mutations, then `root.mutableReadLanes` will be\n // empty, and we know we can safely read.\n //\n // If there *are* pending mutations, we may still be able to safely read\n // if the currently rendering lanes are inclusive of the pending mutation\n // lanes, since that guarantees that the value we're about to read from\n // the source is consistent with the values that we read during the most\n // recent mutation.\n isSafeToReadFromSource = isSubsetOfLanes(renderLanes1, root.mutableReadLanes);\n if (isSafeToReadFromSource) // If it's safe to read from this source during the current render,\n // store the version in case other components read from it.\n // A changed version number will let those components know to throw and restart the render.\n setWorkInProgressVersion(source, version);\n }\n if (isSafeToReadFromSource) {\n var snapshot = getSnapshot(source._source);\n if (typeof snapshot === 'function') error1(\"Mutable source should not return a function as the snapshot value. Functions may close over mutable values and cause tearing.\");\n return snapshot;\n } else {\n // This handles the special case of a mutable source being shared between renderers.\n // In that case, if the source is mutated between the first and second renderer,\n // The second renderer don't know that it needs to reset the WIP version during unwind,\n // (because the hook only marks sources as dirty if it's written to their WIP version).\n // That would cause this tear check to throw again and eventually be visible to the user.\n // We can avoid this infinite loop by explicitly marking the source as dirty.\n //\n // This can lead to tearing in the first renderer when it resumes,\n // but there's nothing we can do about that (short of throwing here and refusing to continue the render).\n markSourceAsDirty(source);\n throw Error(\"Cannot read from mutable source during the current render without tearing. This is a bug in React. Please file an issue.\");\n }\n }\n function useMutableSource(hook, source, getSnapshot, subscribe) {\n var root = getWorkInProgressRoot();\n if (!(root !== null)) throw Error(\"Expected a work-in-progress root. This is a bug in React. Please file an issue.\");\n var getVersion = source._getVersion;\n var version = getVersion(source._source);\n var dispatcher = ReactCurrentDispatcher$1.current; // eslint-disable-next-line prefer-const\n var _dispatcher$useState = dispatcher.useState(function() {\n return readFromUnsubcribedMutableSource(root, source, getSnapshot);\n }), currentSnapshot = _dispatcher$useState[0], setSnapshot = _dispatcher$useState[1];\n var snapshot = currentSnapshot; // Grab a handle to the state hook as well.\n // We use it to clear the pending update queue if we have a new source.\n var stateHook = workInProgressHook;\n var memoizedState = hook.memoizedState;\n var refs = memoizedState.refs;\n var prevGetSnapshot = refs.getSnapshot;\n var prevSource = memoizedState.source;\n var prevSubscribe = memoizedState.subscribe;\n var fiber = currentlyRenderingFiber$1;\n hook.memoizedState = {\n refs: refs,\n source: source,\n subscribe: subscribe\n }; // Sync the values needed by our subscription handler after each commit.\n dispatcher.useEffect(function() {\n refs.getSnapshot = getSnapshot; // Normally the dispatch function for a state hook never changes,\n // but this hook recreates the queue in certain cases to avoid updates from stale sources.\n // handleChange() below needs to reference the dispatch function without re-subscribing,\n // so we use a ref to ensure that it always has the latest version.\n refs.setSnapshot = setSnapshot; // Check for a possible change between when we last rendered now.\n var maybeNewVersion = getVersion(source._source);\n if (!objectIs(version, maybeNewVersion)) {\n var maybeNewSnapshot = getSnapshot(source._source);\n if (typeof maybeNewSnapshot === 'function') error1(\"Mutable source should not return a function as the snapshot value. Functions may close over mutable values and cause tearing.\");\n if (!objectIs(snapshot, maybeNewSnapshot)) {\n setSnapshot(maybeNewSnapshot);\n var lane = requestUpdateLane(fiber);\n markRootMutableRead(root, lane);\n } // If the source mutated between render and now,\n // there may be state updates already scheduled from the old source.\n // Entangle the updates so that they render in the same batch.\n markRootEntangled(root, root.mutableReadLanes);\n }\n }, [\n getSnapshot,\n source,\n subscribe\n ]); // If we got a new source or subscribe function, re-subscribe in a passive effect.\n dispatcher.useEffect(function() {\n var handleChange = function() {\n var latestGetSnapshot = refs.getSnapshot;\n var latestSetSnapshot = refs.setSnapshot;\n try {\n latestSetSnapshot(latestGetSnapshot(source._source)); // Record a pending mutable source update with the same expiration time.\n var lane = requestUpdateLane(fiber);\n markRootMutableRead(root, lane);\n } catch (error) {\n // A selector might throw after a source mutation.\n // e.g. it might try to read from a part of the store that no longer exists.\n // In this case we should still schedule an update with React.\n // Worst case the selector will throw again and then an error boundary will handle it.\n latestSetSnapshot(function() {\n throw error;\n });\n }\n };\n var unsubscribe = subscribe(source._source, handleChange);\n if (typeof unsubscribe !== 'function') error1('Mutable source subscribe function must return an unsubscribe function.');\n return unsubscribe;\n }, [\n source,\n subscribe\n ]); // If any of the inputs to useMutableSource change, reading is potentially unsafe.\n //\n // If either the source or the subscription have changed we can't can't trust the update queue.\n // Maybe the source changed in a way that the old subscription ignored but the new one depends on.\n //\n // If the getSnapshot function changed, we also shouldn't rely on the update queue.\n // It's possible that the underlying source was mutated between the when the last \"change\" event fired,\n // and when the current render (with the new getSnapshot function) is processed.\n //\n // In both cases, we need to throw away pending updates (since they are no longer relevant)\n // and treat reading from the source as we do in the mount case.\n if (!objectIs(prevGetSnapshot, getSnapshot) || !objectIs(prevSource, source) || !objectIs(prevSubscribe, subscribe)) {\n // Create a new queue and setState method,\n // So if there are interleaved updates, they get pushed to the older queue.\n // When this becomes current, the previous queue and dispatch method will be discarded,\n // including any interleaving updates that occur.\n var newQueue = {\n pending: null,\n dispatch: null,\n lastRenderedReducer: basicStateReducer,\n lastRenderedState: snapshot\n };\n newQueue.dispatch = setSnapshot = dispatchAction.bind(null, currentlyRenderingFiber$1, newQueue);\n stateHook.queue = newQueue;\n stateHook.baseQueue = null;\n snapshot = readFromUnsubcribedMutableSource(root, source, getSnapshot);\n stateHook.memoizedState = stateHook.baseState = snapshot;\n }\n return snapshot;\n }\n function mountMutableSource(source, getSnapshot, subscribe) {\n var hook = mountWorkInProgressHook();\n hook.memoizedState = {\n refs: {\n getSnapshot: getSnapshot,\n setSnapshot: null\n },\n source: source,\n subscribe: subscribe\n };\n return useMutableSource(hook, source, getSnapshot, subscribe);\n }\n function updateMutableSource(source, getSnapshot, subscribe) {\n var hook = updateWorkInProgressHook();\n return useMutableSource(hook, source, getSnapshot, subscribe);\n }\n function mountState(initialState) {\n var hook = mountWorkInProgressHook();\n if (typeof initialState === 'function') // $FlowFixMe: Flow doesn't like mixed types\n initialState = initialState();\n hook.memoizedState = hook.baseState = initialState;\n var queue = hook.queue = {\n pending: null,\n dispatch: null,\n lastRenderedReducer: basicStateReducer,\n lastRenderedState: initialState\n };\n var dispatch = queue.dispatch = dispatchAction.bind(null, currentlyRenderingFiber$1, queue);\n return [\n hook.memoizedState,\n dispatch\n ];\n }\n function updateState(initialState) {\n return updateReducer(basicStateReducer);\n }\n function rerenderState(initialState) {\n return rerenderReducer(basicStateReducer);\n }\n function pushEffect(tag, create, destroy, deps) {\n var effect = {\n tag: tag,\n create: create,\n destroy: destroy,\n deps: deps,\n // Circular\n next: null\n };\n var componentUpdateQueue = currentlyRenderingFiber$1.updateQueue;\n if (componentUpdateQueue === null) {\n componentUpdateQueue = createFunctionComponentUpdateQueue();\n currentlyRenderingFiber$1.updateQueue = componentUpdateQueue;\n componentUpdateQueue.lastEffect = effect.next = effect;\n } else {\n var lastEffect = componentUpdateQueue.lastEffect;\n if (lastEffect === null) componentUpdateQueue.lastEffect = effect.next = effect;\n else {\n var firstEffect = lastEffect.next;\n lastEffect.next = effect;\n effect.next = firstEffect;\n componentUpdateQueue.lastEffect = effect;\n }\n }\n return effect;\n }\n function mountRef(initialValue) {\n var hook = mountWorkInProgressHook();\n var ref = {\n current: initialValue\n };\n Object.seal(ref);\n hook.memoizedState = ref;\n return ref;\n }\n function updateRef(initialValue) {\n var hook = updateWorkInProgressHook();\n return hook.memoizedState;\n }\n function mountEffectImpl(fiberFlags, hookFlags, create, deps) {\n var hook = mountWorkInProgressHook();\n var nextDeps = deps === undefined ? null : deps;\n currentlyRenderingFiber$1.flags |= fiberFlags;\n hook.memoizedState = pushEffect(HasEffect | hookFlags, create, undefined, nextDeps);\n }\n function updateEffectImpl(fiberFlags, hookFlags, create, deps) {\n var hook = updateWorkInProgressHook();\n var nextDeps = deps === undefined ? null : deps;\n var destroy = undefined;\n if (currentHook1 !== null) {\n var prevEffect = currentHook1.memoizedState;\n destroy = prevEffect.destroy;\n if (nextDeps !== null) {\n var prevDeps = prevEffect.deps;\n if (areHookInputsEqual(nextDeps, prevDeps)) {\n pushEffect(hookFlags, create, destroy, nextDeps);\n return;\n }\n }\n }\n currentlyRenderingFiber$1.flags |= fiberFlags;\n hook.memoizedState = pushEffect(HasEffect | hookFlags, create, destroy, nextDeps);\n }\n function mountEffect(create, deps) {\n // $FlowExpectedError - jest isn't a global, and isn't recognized outside of tests\n if ('undefined' !== typeof jest) warnIfNotCurrentlyActingEffectsInDEV(currentlyRenderingFiber$1);\n return mountEffectImpl(Update | Passive, Passive$1, create, deps);\n }\n function updateEffect(create, deps) {\n // $FlowExpectedError - jest isn't a global, and isn't recognized outside of tests\n if ('undefined' !== typeof jest) warnIfNotCurrentlyActingEffectsInDEV(currentlyRenderingFiber$1);\n return updateEffectImpl(Update | Passive, Passive$1, create, deps);\n }\n function mountLayoutEffect(create, deps) {\n return mountEffectImpl(Update, Layout, create, deps);\n }\n function updateLayoutEffect(create, deps) {\n return updateEffectImpl(Update, Layout, create, deps);\n }\n function imperativeHandleEffect(create, ref) {\n if (typeof ref === 'function') {\n var refCallback = ref;\n var _inst = create();\n refCallback(_inst);\n return function() {\n refCallback(null);\n };\n } else if (ref !== null && ref !== undefined) {\n var refObject = ref;\n if (!refObject.hasOwnProperty('current')) error1(\"Expected useImperativeHandle() first argument to either be a ref callback or React.createRef() object. Instead received: %s.\", 'an object with keys {' + Object.keys(refObject).join(', ') + '}');\n var _inst2 = create();\n refObject.current = _inst2;\n return function() {\n refObject.current = null;\n };\n }\n }\n function mountImperativeHandle(ref, create, deps) {\n if (typeof create !== 'function') error1(\"Expected useImperativeHandle() second argument to be a function that creates a handle. Instead received: %s.\", create !== null ? typeof create : 'null');\n var effectDeps = deps !== null && deps !== undefined ? deps.concat([\n ref\n ]) : null;\n return mountEffectImpl(Update, Layout, imperativeHandleEffect.bind(null, create, ref), effectDeps);\n }\n function updateImperativeHandle(ref, create, deps) {\n if (typeof create !== 'function') error1(\"Expected useImperativeHandle() second argument to be a function that creates a handle. Instead received: %s.\", create !== null ? typeof create : 'null');\n var effectDeps = deps !== null && deps !== undefined ? deps.concat([\n ref\n ]) : null;\n return updateEffectImpl(Update, Layout, imperativeHandleEffect.bind(null, create, ref), effectDeps);\n }\n function mountDebugValue(value, formatterFn) {\n // The react-debug-hooks package injects its own implementation\n // so that e.g. DevTools can display custom hook values.\n }\n var updateDebugValue = mountDebugValue;\n function mountCallback(callback, deps) {\n var hook = mountWorkInProgressHook();\n var nextDeps = deps === undefined ? null : deps;\n hook.memoizedState = [\n callback,\n nextDeps\n ];\n return callback;\n }\n function updateCallback(callback, deps) {\n var hook = updateWorkInProgressHook();\n var nextDeps = deps === undefined ? null : deps;\n var prevState = hook.memoizedState;\n if (prevState !== null) {\n if (nextDeps !== null) {\n var prevDeps = prevState[1];\n if (areHookInputsEqual(nextDeps, prevDeps)) return prevState[0];\n }\n }\n hook.memoizedState = [\n callback,\n nextDeps\n ];\n return callback;\n }\n function mountMemo(nextCreate, deps) {\n var hook = mountWorkInProgressHook();\n var nextDeps = deps === undefined ? null : deps;\n var nextValue = nextCreate();\n hook.memoizedState = [\n nextValue,\n nextDeps\n ];\n return nextValue;\n }\n function updateMemo(nextCreate, deps) {\n var hook = updateWorkInProgressHook();\n var nextDeps = deps === undefined ? null : deps;\n var prevState = hook.memoizedState;\n if (prevState !== null) // Assume these are defined. If they're not, areHookInputsEqual will warn.\n {\n if (nextDeps !== null) {\n var prevDeps = prevState[1];\n if (areHookInputsEqual(nextDeps, prevDeps)) return prevState[0];\n }\n }\n var nextValue = nextCreate();\n hook.memoizedState = [\n nextValue,\n nextDeps\n ];\n return nextValue;\n }\n function mountDeferredValue(value) {\n var _mountState = mountState(value), prevValue = _mountState[0], setValue = _mountState[1];\n mountEffect(function() {\n var prevTransition = ReactCurrentBatchConfig$1.transition;\n ReactCurrentBatchConfig$1.transition = 1;\n try {\n setValue(value);\n } finally{\n ReactCurrentBatchConfig$1.transition = prevTransition;\n }\n }, [\n value\n ]);\n return prevValue;\n }\n function updateDeferredValue(value) {\n var _updateState = updateState(), prevValue = _updateState[0], setValue = _updateState[1];\n updateEffect(function() {\n var prevTransition = ReactCurrentBatchConfig$1.transition;\n ReactCurrentBatchConfig$1.transition = 1;\n try {\n setValue(value);\n } finally{\n ReactCurrentBatchConfig$1.transition = prevTransition;\n }\n }, [\n value\n ]);\n return prevValue;\n }\n function rerenderDeferredValue(value) {\n var _rerenderState = rerenderState(), prevValue = _rerenderState[0], setValue = _rerenderState[1];\n updateEffect(function() {\n var prevTransition = ReactCurrentBatchConfig$1.transition;\n ReactCurrentBatchConfig$1.transition = 1;\n try {\n setValue(value);\n } finally{\n ReactCurrentBatchConfig$1.transition = prevTransition;\n }\n }, [\n value\n ]);\n return prevValue;\n }\n function startTransition(setPending, callback) {\n var priorityLevel = getCurrentPriorityLevel();\n runWithPriority$1(priorityLevel < UserBlockingPriority$2 ? UserBlockingPriority$2 : priorityLevel, function() {\n setPending(true);\n });\n runWithPriority$1(priorityLevel > NormalPriority$1 ? NormalPriority$1 : priorityLevel, function() {\n var prevTransition = ReactCurrentBatchConfig$1.transition;\n ReactCurrentBatchConfig$1.transition = 1;\n try {\n setPending(false);\n callback();\n } finally{\n ReactCurrentBatchConfig$1.transition = prevTransition;\n }\n });\n }\n function mountTransition() {\n var _mountState2 = mountState(false), isPending = _mountState2[0], setPending = _mountState2[1]; // The `start` method can be stored on a ref, since `setPending`\n // never changes.\n var start = startTransition.bind(null, setPending);\n mountRef(start);\n return [\n start,\n isPending\n ];\n }\n function updateTransition() {\n var _updateState2 = updateState(), isPending = _updateState2[0];\n var startRef = updateRef();\n var start = startRef.current;\n return [\n start,\n isPending\n ];\n }\n function rerenderTransition() {\n var _rerenderState2 = rerenderState(), isPending = _rerenderState2[0];\n var startRef = updateRef();\n var start = startRef.current;\n return [\n start,\n isPending\n ];\n }\n var isUpdatingOpaqueValueInRenderPhase = false;\n function getIsUpdatingOpaqueValueInRenderPhaseInDEV() {\n return isUpdatingOpaqueValueInRenderPhase;\n }\n function warnOnOpaqueIdentifierAccessInDEV(fiber) {\n // TODO: Should warn in effects and callbacks, too\n var name = getComponentName(fiber.type) || 'Unknown';\n if (getIsRendering() && !didWarnAboutUseOpaqueIdentifier[name]) {\n error1(\"The object passed back from useOpaqueIdentifier is meant to be passed through to attributes only. Do not read the value directly.\");\n didWarnAboutUseOpaqueIdentifier[name] = true;\n }\n }\n function mountOpaqueIdentifier() {\n var makeId = makeClientIdInDEV.bind(null, warnOnOpaqueIdentifierAccessInDEV.bind(null, currentlyRenderingFiber$1));\n if (getIsHydrating()) {\n var didUpgrade = false;\n var fiber = currentlyRenderingFiber$1;\n var readValue = function() {\n if (!didUpgrade) {\n // Only upgrade once. This works even inside the render phase because\n // the update is added to a shared queue, which outlasts the\n // in-progress render.\n didUpgrade = true;\n isUpdatingOpaqueValueInRenderPhase = true;\n setId(makeId());\n isUpdatingOpaqueValueInRenderPhase = false;\n warnOnOpaqueIdentifierAccessInDEV(fiber);\n }\n throw Error(\"The object passed back from useOpaqueIdentifier is meant to be passed through to attributes only. Do not read the value directly.\");\n };\n var id = makeOpaqueHydratingObject(readValue);\n var setId = mountState(id)[1];\n if ((currentlyRenderingFiber$1.mode & BlockingMode) === NoMode) {\n currentlyRenderingFiber$1.flags |= Update | Passive;\n pushEffect(HasEffect | Passive$1, function() {\n setId(makeId());\n }, undefined, null);\n }\n return id;\n } else {\n var _id = makeId();\n mountState(_id);\n return _id;\n }\n }\n function updateOpaqueIdentifier() {\n var id = updateState()[0];\n return id;\n }\n function rerenderOpaqueIdentifier() {\n var id = rerenderState()[0];\n return id;\n }\n function dispatchAction(fiber, queue, action) {\n if (typeof arguments[3] === 'function') error1(\"State updates from the useState() and useReducer() Hooks don't support the second callback argument. To execute a side effect after rendering, declare it in the component body with useEffect().\");\n var eventTime = requestEventTime();\n var lane = requestUpdateLane(fiber);\n var update = {\n lane: lane,\n action: action,\n eagerReducer: null,\n eagerState: null,\n next: null\n }; // Append the update to the end of the list.\n var pending = queue.pending;\n if (pending === null) // This is the first update. Create a circular list.\n update.next = update;\n else {\n update.next = pending.next;\n pending.next = update;\n }\n queue.pending = update;\n var alternate = fiber.alternate;\n if (fiber === currentlyRenderingFiber$1 || alternate !== null && alternate === currentlyRenderingFiber$1) // This is a render phase update. Stash it in a lazily-created map of\n // queue -> linked list of updates. After this render pass, we'll restart\n // and apply the stashed updates on top of the work-in-progress hook.\n didScheduleRenderPhaseUpdateDuringThisPass = didScheduleRenderPhaseUpdate = true;\n else {\n if (fiber.lanes === NoLanes && (alternate === null || alternate.lanes === NoLanes)) {\n // The queue is currently empty, which means we can eagerly compute the\n // next state before entering the render phase. If the new state is the\n // same as the current state, we may be able to bail out entirely.\n var lastRenderedReducer = queue.lastRenderedReducer;\n if (lastRenderedReducer !== null) {\n var prevDispatcher;\n prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnUpdateInDEV;\n try {\n var currentState = queue.lastRenderedState;\n var eagerState = lastRenderedReducer(currentState, action); // Stash the eagerly computed state, and the reducer used to compute\n // it, on the update object. If the reducer hasn't changed by the\n // time we enter the render phase, then the eager state can be used\n // without calling the reducer again.\n update.eagerReducer = lastRenderedReducer;\n update.eagerState = eagerState;\n if (objectIs(eagerState, currentState)) // Fast path. We can bail out without scheduling React to re-render.\n // It's still possible that we'll need to rebase this update later,\n // if the component re-renders for a different reason and by that\n // time the reducer has changed.\n return;\n } catch (error) {\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n }\n }\n // $FlowExpectedError - jest isn't a global, and isn't recognized outside of tests\n if ('undefined' !== typeof jest) {\n warnIfNotScopedWithMatchingAct(fiber);\n warnIfNotCurrentlyActingUpdatesInDev(fiber);\n }\n scheduleUpdateOnFiber(fiber, lane, eventTime);\n }\n }\n var ContextOnlyDispatcher = {\n readContext: readContext,\n useCallback: throwInvalidHookError,\n useContext: throwInvalidHookError,\n useEffect: throwInvalidHookError,\n useImperativeHandle: throwInvalidHookError,\n useLayoutEffect: throwInvalidHookError,\n useMemo: throwInvalidHookError,\n useReducer: throwInvalidHookError,\n useRef: throwInvalidHookError,\n useState: throwInvalidHookError,\n useDebugValue: throwInvalidHookError,\n useDeferredValue: throwInvalidHookError,\n useTransition: throwInvalidHookError,\n useMutableSource: throwInvalidHookError,\n useOpaqueIdentifier: throwInvalidHookError,\n unstable_isNewReconciler: enableNewReconciler\n };\n var HooksDispatcherOnMountInDEV = null;\n var HooksDispatcherOnMountWithHookTypesInDEV = null;\n var HooksDispatcherOnUpdateInDEV = null;\n var HooksDispatcherOnRerenderInDEV = null;\n var InvalidNestedHooksDispatcherOnMountInDEV = null;\n var InvalidNestedHooksDispatcherOnUpdateInDEV = null;\n var InvalidNestedHooksDispatcherOnRerenderInDEV = null;\n var warnInvalidContextAccess = function() {\n error1(\"Context can only be read while React is rendering. In classes, you can read it in the render method or getDerivedStateFromProps. In function components, you can read it directly in the function body, but not inside Hooks like useReducer() or useMemo().\");\n };\n var warnInvalidHookAccess = function() {\n error1(\"Do not call Hooks inside useEffect(...), useMemo(...), or other built-in Hooks. You can only call Hooks at the top level of your React function. For more information, see https://reactjs.org/link/rules-of-hooks\");\n };\n HooksDispatcherOnMountInDEV = {\n readContext: function(context, observedBits) {\n return readContext(context, observedBits);\n },\n useCallback: function(callback, deps) {\n currentHookNameInDev = 'useCallback';\n mountHookTypesDev();\n checkDepsAreArrayDev(deps);\n return mountCallback(callback, deps);\n },\n useContext: function(context, observedBits) {\n currentHookNameInDev = 'useContext';\n mountHookTypesDev();\n return readContext(context, observedBits);\n },\n useEffect: function(create, deps) {\n currentHookNameInDev = 'useEffect';\n mountHookTypesDev();\n checkDepsAreArrayDev(deps);\n return mountEffect(create, deps);\n },\n useImperativeHandle: function(ref, create, deps) {\n currentHookNameInDev = 'useImperativeHandle';\n mountHookTypesDev();\n checkDepsAreArrayDev(deps);\n return mountImperativeHandle(ref, create, deps);\n },\n useLayoutEffect: function(create, deps) {\n currentHookNameInDev = 'useLayoutEffect';\n mountHookTypesDev();\n checkDepsAreArrayDev(deps);\n return mountLayoutEffect(create, deps);\n },\n useMemo: function(create, deps) {\n currentHookNameInDev = 'useMemo';\n mountHookTypesDev();\n checkDepsAreArrayDev(deps);\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnMountInDEV;\n try {\n return mountMemo(create, deps);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useReducer: function(reducer, initialArg, init) {\n currentHookNameInDev = 'useReducer';\n mountHookTypesDev();\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnMountInDEV;\n try {\n return mountReducer(reducer, initialArg, init);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useRef: function(initialValue) {\n currentHookNameInDev = 'useRef';\n mountHookTypesDev();\n return mountRef(initialValue);\n },\n useState: function(initialState) {\n currentHookNameInDev = 'useState';\n mountHookTypesDev();\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnMountInDEV;\n try {\n return mountState(initialState);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useDebugValue: function(value, formatterFn) {\n currentHookNameInDev = 'useDebugValue';\n mountHookTypesDev();\n return mountDebugValue();\n },\n useDeferredValue: function(value) {\n currentHookNameInDev = 'useDeferredValue';\n mountHookTypesDev();\n return mountDeferredValue(value);\n },\n useTransition: function() {\n currentHookNameInDev = 'useTransition';\n mountHookTypesDev();\n return mountTransition();\n },\n useMutableSource: function(source, getSnapshot, subscribe) {\n currentHookNameInDev = 'useMutableSource';\n mountHookTypesDev();\n return mountMutableSource(source, getSnapshot, subscribe);\n },\n useOpaqueIdentifier: function() {\n currentHookNameInDev = 'useOpaqueIdentifier';\n mountHookTypesDev();\n return mountOpaqueIdentifier();\n },\n unstable_isNewReconciler: enableNewReconciler\n };\n HooksDispatcherOnMountWithHookTypesInDEV = {\n readContext: function(context, observedBits) {\n return readContext(context, observedBits);\n },\n useCallback: function(callback, deps) {\n currentHookNameInDev = 'useCallback';\n updateHookTypesDev();\n return mountCallback(callback, deps);\n },\n useContext: function(context, observedBits) {\n currentHookNameInDev = 'useContext';\n updateHookTypesDev();\n return readContext(context, observedBits);\n },\n useEffect: function(create, deps) {\n currentHookNameInDev = 'useEffect';\n updateHookTypesDev();\n return mountEffect(create, deps);\n },\n useImperativeHandle: function(ref, create, deps) {\n currentHookNameInDev = 'useImperativeHandle';\n updateHookTypesDev();\n return mountImperativeHandle(ref, create, deps);\n },\n useLayoutEffect: function(create, deps) {\n currentHookNameInDev = 'useLayoutEffect';\n updateHookTypesDev();\n return mountLayoutEffect(create, deps);\n },\n useMemo: function(create, deps) {\n currentHookNameInDev = 'useMemo';\n updateHookTypesDev();\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnMountInDEV;\n try {\n return mountMemo(create, deps);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useReducer: function(reducer, initialArg, init) {\n currentHookNameInDev = 'useReducer';\n updateHookTypesDev();\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnMountInDEV;\n try {\n return mountReducer(reducer, initialArg, init);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useRef: function(initialValue) {\n currentHookNameInDev = 'useRef';\n updateHookTypesDev();\n return mountRef(initialValue);\n },\n useState: function(initialState) {\n currentHookNameInDev = 'useState';\n updateHookTypesDev();\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnMountInDEV;\n try {\n return mountState(initialState);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useDebugValue: function(value, formatterFn) {\n currentHookNameInDev = 'useDebugValue';\n updateHookTypesDev();\n return mountDebugValue();\n },\n useDeferredValue: function(value) {\n currentHookNameInDev = 'useDeferredValue';\n updateHookTypesDev();\n return mountDeferredValue(value);\n },\n useTransition: function() {\n currentHookNameInDev = 'useTransition';\n updateHookTypesDev();\n return mountTransition();\n },\n useMutableSource: function(source, getSnapshot, subscribe) {\n currentHookNameInDev = 'useMutableSource';\n updateHookTypesDev();\n return mountMutableSource(source, getSnapshot, subscribe);\n },\n useOpaqueIdentifier: function() {\n currentHookNameInDev = 'useOpaqueIdentifier';\n updateHookTypesDev();\n return mountOpaqueIdentifier();\n },\n unstable_isNewReconciler: enableNewReconciler\n };\n HooksDispatcherOnUpdateInDEV = {\n readContext: function(context, observedBits) {\n return readContext(context, observedBits);\n },\n useCallback: function(callback, deps) {\n currentHookNameInDev = 'useCallback';\n updateHookTypesDev();\n return updateCallback(callback, deps);\n },\n useContext: function(context, observedBits) {\n currentHookNameInDev = 'useContext';\n updateHookTypesDev();\n return readContext(context, observedBits);\n },\n useEffect: function(create, deps) {\n currentHookNameInDev = 'useEffect';\n updateHookTypesDev();\n return updateEffect(create, deps);\n },\n useImperativeHandle: function(ref, create, deps) {\n currentHookNameInDev = 'useImperativeHandle';\n updateHookTypesDev();\n return updateImperativeHandle(ref, create, deps);\n },\n useLayoutEffect: function(create, deps) {\n currentHookNameInDev = 'useLayoutEffect';\n updateHookTypesDev();\n return updateLayoutEffect(create, deps);\n },\n useMemo: function(create, deps) {\n currentHookNameInDev = 'useMemo';\n updateHookTypesDev();\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnUpdateInDEV;\n try {\n return updateMemo(create, deps);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useReducer: function(reducer, initialArg, init) {\n currentHookNameInDev = 'useReducer';\n updateHookTypesDev();\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnUpdateInDEV;\n try {\n return updateReducer(reducer, initialArg, init);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useRef: function(initialValue) {\n currentHookNameInDev = 'useRef';\n updateHookTypesDev();\n return updateRef();\n },\n useState: function(initialState) {\n currentHookNameInDev = 'useState';\n updateHookTypesDev();\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnUpdateInDEV;\n try {\n return updateState(initialState);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useDebugValue: function(value, formatterFn) {\n currentHookNameInDev = 'useDebugValue';\n updateHookTypesDev();\n return updateDebugValue();\n },\n useDeferredValue: function(value) {\n currentHookNameInDev = 'useDeferredValue';\n updateHookTypesDev();\n return updateDeferredValue(value);\n },\n useTransition: function() {\n currentHookNameInDev = 'useTransition';\n updateHookTypesDev();\n return updateTransition();\n },\n useMutableSource: function(source, getSnapshot, subscribe) {\n currentHookNameInDev = 'useMutableSource';\n updateHookTypesDev();\n return updateMutableSource(source, getSnapshot, subscribe);\n },\n useOpaqueIdentifier: function() {\n currentHookNameInDev = 'useOpaqueIdentifier';\n updateHookTypesDev();\n return updateOpaqueIdentifier();\n },\n unstable_isNewReconciler: enableNewReconciler\n };\n HooksDispatcherOnRerenderInDEV = {\n readContext: function(context, observedBits) {\n return readContext(context, observedBits);\n },\n useCallback: function(callback, deps) {\n currentHookNameInDev = 'useCallback';\n updateHookTypesDev();\n return updateCallback(callback, deps);\n },\n useContext: function(context, observedBits) {\n currentHookNameInDev = 'useContext';\n updateHookTypesDev();\n return readContext(context, observedBits);\n },\n useEffect: function(create, deps) {\n currentHookNameInDev = 'useEffect';\n updateHookTypesDev();\n return updateEffect(create, deps);\n },\n useImperativeHandle: function(ref, create, deps) {\n currentHookNameInDev = 'useImperativeHandle';\n updateHookTypesDev();\n return updateImperativeHandle(ref, create, deps);\n },\n useLayoutEffect: function(create, deps) {\n currentHookNameInDev = 'useLayoutEffect';\n updateHookTypesDev();\n return updateLayoutEffect(create, deps);\n },\n useMemo: function(create, deps) {\n currentHookNameInDev = 'useMemo';\n updateHookTypesDev();\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnRerenderInDEV;\n try {\n return updateMemo(create, deps);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useReducer: function(reducer, initialArg, init) {\n currentHookNameInDev = 'useReducer';\n updateHookTypesDev();\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnRerenderInDEV;\n try {\n return rerenderReducer(reducer, initialArg, init);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useRef: function(initialValue) {\n currentHookNameInDev = 'useRef';\n updateHookTypesDev();\n return updateRef();\n },\n useState: function(initialState) {\n currentHookNameInDev = 'useState';\n updateHookTypesDev();\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnRerenderInDEV;\n try {\n return rerenderState(initialState);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useDebugValue: function(value, formatterFn) {\n currentHookNameInDev = 'useDebugValue';\n updateHookTypesDev();\n return updateDebugValue();\n },\n useDeferredValue: function(value) {\n currentHookNameInDev = 'useDeferredValue';\n updateHookTypesDev();\n return rerenderDeferredValue(value);\n },\n useTransition: function() {\n currentHookNameInDev = 'useTransition';\n updateHookTypesDev();\n return rerenderTransition();\n },\n useMutableSource: function(source, getSnapshot, subscribe) {\n currentHookNameInDev = 'useMutableSource';\n updateHookTypesDev();\n return updateMutableSource(source, getSnapshot, subscribe);\n },\n useOpaqueIdentifier: function() {\n currentHookNameInDev = 'useOpaqueIdentifier';\n updateHookTypesDev();\n return rerenderOpaqueIdentifier();\n },\n unstable_isNewReconciler: enableNewReconciler\n };\n InvalidNestedHooksDispatcherOnMountInDEV = {\n readContext: function(context, observedBits) {\n warnInvalidContextAccess();\n return readContext(context, observedBits);\n },\n useCallback: function(callback, deps) {\n currentHookNameInDev = 'useCallback';\n warnInvalidHookAccess();\n mountHookTypesDev();\n return mountCallback(callback, deps);\n },\n useContext: function(context, observedBits) {\n currentHookNameInDev = 'useContext';\n warnInvalidHookAccess();\n mountHookTypesDev();\n return readContext(context, observedBits);\n },\n useEffect: function(create, deps) {\n currentHookNameInDev = 'useEffect';\n warnInvalidHookAccess();\n mountHookTypesDev();\n return mountEffect(create, deps);\n },\n useImperativeHandle: function(ref, create, deps) {\n currentHookNameInDev = 'useImperativeHandle';\n warnInvalidHookAccess();\n mountHookTypesDev();\n return mountImperativeHandle(ref, create, deps);\n },\n useLayoutEffect: function(create, deps) {\n currentHookNameInDev = 'useLayoutEffect';\n warnInvalidHookAccess();\n mountHookTypesDev();\n return mountLayoutEffect(create, deps);\n },\n useMemo: function(create, deps) {\n currentHookNameInDev = 'useMemo';\n warnInvalidHookAccess();\n mountHookTypesDev();\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnMountInDEV;\n try {\n return mountMemo(create, deps);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useReducer: function(reducer, initialArg, init) {\n currentHookNameInDev = 'useReducer';\n warnInvalidHookAccess();\n mountHookTypesDev();\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnMountInDEV;\n try {\n return mountReducer(reducer, initialArg, init);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useRef: function(initialValue) {\n currentHookNameInDev = 'useRef';\n warnInvalidHookAccess();\n mountHookTypesDev();\n return mountRef(initialValue);\n },\n useState: function(initialState) {\n currentHookNameInDev = 'useState';\n warnInvalidHookAccess();\n mountHookTypesDev();\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnMountInDEV;\n try {\n return mountState(initialState);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useDebugValue: function(value, formatterFn) {\n currentHookNameInDev = 'useDebugValue';\n warnInvalidHookAccess();\n mountHookTypesDev();\n return mountDebugValue();\n },\n useDeferredValue: function(value) {\n currentHookNameInDev = 'useDeferredValue';\n warnInvalidHookAccess();\n mountHookTypesDev();\n return mountDeferredValue(value);\n },\n useTransition: function() {\n currentHookNameInDev = 'useTransition';\n warnInvalidHookAccess();\n mountHookTypesDev();\n return mountTransition();\n },\n useMutableSource: function(source, getSnapshot, subscribe) {\n currentHookNameInDev = 'useMutableSource';\n warnInvalidHookAccess();\n mountHookTypesDev();\n return mountMutableSource(source, getSnapshot, subscribe);\n },\n useOpaqueIdentifier: function() {\n currentHookNameInDev = 'useOpaqueIdentifier';\n warnInvalidHookAccess();\n mountHookTypesDev();\n return mountOpaqueIdentifier();\n },\n unstable_isNewReconciler: enableNewReconciler\n };\n InvalidNestedHooksDispatcherOnUpdateInDEV = {\n readContext: function(context, observedBits) {\n warnInvalidContextAccess();\n return readContext(context, observedBits);\n },\n useCallback: function(callback, deps) {\n currentHookNameInDev = 'useCallback';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return updateCallback(callback, deps);\n },\n useContext: function(context, observedBits) {\n currentHookNameInDev = 'useContext';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return readContext(context, observedBits);\n },\n useEffect: function(create, deps) {\n currentHookNameInDev = 'useEffect';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return updateEffect(create, deps);\n },\n useImperativeHandle: function(ref, create, deps) {\n currentHookNameInDev = 'useImperativeHandle';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return updateImperativeHandle(ref, create, deps);\n },\n useLayoutEffect: function(create, deps) {\n currentHookNameInDev = 'useLayoutEffect';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return updateLayoutEffect(create, deps);\n },\n useMemo: function(create, deps) {\n currentHookNameInDev = 'useMemo';\n warnInvalidHookAccess();\n updateHookTypesDev();\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnUpdateInDEV;\n try {\n return updateMemo(create, deps);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useReducer: function(reducer, initialArg, init) {\n currentHookNameInDev = 'useReducer';\n warnInvalidHookAccess();\n updateHookTypesDev();\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnUpdateInDEV;\n try {\n return updateReducer(reducer, initialArg, init);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useRef: function(initialValue) {\n currentHookNameInDev = 'useRef';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return updateRef();\n },\n useState: function(initialState) {\n currentHookNameInDev = 'useState';\n warnInvalidHookAccess();\n updateHookTypesDev();\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnUpdateInDEV;\n try {\n return updateState(initialState);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useDebugValue: function(value, formatterFn) {\n currentHookNameInDev = 'useDebugValue';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return updateDebugValue();\n },\n useDeferredValue: function(value) {\n currentHookNameInDev = 'useDeferredValue';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return updateDeferredValue(value);\n },\n useTransition: function() {\n currentHookNameInDev = 'useTransition';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return updateTransition();\n },\n useMutableSource: function(source, getSnapshot, subscribe) {\n currentHookNameInDev = 'useMutableSource';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return updateMutableSource(source, getSnapshot, subscribe);\n },\n useOpaqueIdentifier: function() {\n currentHookNameInDev = 'useOpaqueIdentifier';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return updateOpaqueIdentifier();\n },\n unstable_isNewReconciler: enableNewReconciler\n };\n InvalidNestedHooksDispatcherOnRerenderInDEV = {\n readContext: function(context, observedBits) {\n warnInvalidContextAccess();\n return readContext(context, observedBits);\n },\n useCallback: function(callback, deps) {\n currentHookNameInDev = 'useCallback';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return updateCallback(callback, deps);\n },\n useContext: function(context, observedBits) {\n currentHookNameInDev = 'useContext';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return readContext(context, observedBits);\n },\n useEffect: function(create, deps) {\n currentHookNameInDev = 'useEffect';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return updateEffect(create, deps);\n },\n useImperativeHandle: function(ref, create, deps) {\n currentHookNameInDev = 'useImperativeHandle';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return updateImperativeHandle(ref, create, deps);\n },\n useLayoutEffect: function(create, deps) {\n currentHookNameInDev = 'useLayoutEffect';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return updateLayoutEffect(create, deps);\n },\n useMemo: function(create, deps) {\n currentHookNameInDev = 'useMemo';\n warnInvalidHookAccess();\n updateHookTypesDev();\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnUpdateInDEV;\n try {\n return updateMemo(create, deps);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useReducer: function(reducer, initialArg, init) {\n currentHookNameInDev = 'useReducer';\n warnInvalidHookAccess();\n updateHookTypesDev();\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnUpdateInDEV;\n try {\n return rerenderReducer(reducer, initialArg, init);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useRef: function(initialValue) {\n currentHookNameInDev = 'useRef';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return updateRef();\n },\n useState: function(initialState) {\n currentHookNameInDev = 'useState';\n warnInvalidHookAccess();\n updateHookTypesDev();\n var prevDispatcher = ReactCurrentDispatcher$1.current;\n ReactCurrentDispatcher$1.current = InvalidNestedHooksDispatcherOnUpdateInDEV;\n try {\n return rerenderState(initialState);\n } finally{\n ReactCurrentDispatcher$1.current = prevDispatcher;\n }\n },\n useDebugValue: function(value, formatterFn) {\n currentHookNameInDev = 'useDebugValue';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return updateDebugValue();\n },\n useDeferredValue: function(value) {\n currentHookNameInDev = 'useDeferredValue';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return rerenderDeferredValue(value);\n },\n useTransition: function() {\n currentHookNameInDev = 'useTransition';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return rerenderTransition();\n },\n useMutableSource: function(source, getSnapshot, subscribe) {\n currentHookNameInDev = 'useMutableSource';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return updateMutableSource(source, getSnapshot, subscribe);\n },\n useOpaqueIdentifier: function() {\n currentHookNameInDev = 'useOpaqueIdentifier';\n warnInvalidHookAccess();\n updateHookTypesDev();\n return rerenderOpaqueIdentifier();\n },\n unstable_isNewReconciler: enableNewReconciler\n };\n var now$1 = Scheduler.unstable_now;\n var commitTime1 = 0;\n var profilerStartTime = -1;\n function getCommitTime() {\n return commitTime1;\n }\n function recordCommitTime() {\n commitTime1 = now$1();\n }\n function startProfilerTimer(fiber) {\n profilerStartTime = now$1();\n if (fiber.actualStartTime < 0) fiber.actualStartTime = now$1();\n }\n function stopProfilerTimerIfRunning(fiber) {\n profilerStartTime = -1;\n }\n function stopProfilerTimerIfRunningAndRecordDelta(fiber, overrideBaseTime) {\n if (profilerStartTime >= 0) {\n var elapsedTime = now$1() - profilerStartTime;\n fiber.actualDuration += elapsedTime;\n if (overrideBaseTime) fiber.selfBaseDuration = elapsedTime;\n profilerStartTime = -1;\n }\n }\n function transferActualDuration(fiber) {\n // Transfer time spent rendering these children so we don't lose it\n // after we rerender. This is used as a helper in special cases\n // where we should count the work of multiple passes.\n var child = fiber.child;\n while(child){\n fiber.actualDuration += child.actualDuration;\n child = child.sibling;\n }\n }\n var ReactCurrentOwner$1 = ReactSharedInternals.ReactCurrentOwner;\n var didReceiveUpdate = false;\n var didWarnAboutBadClass;\n var didWarnAboutModulePatternComponent;\n var didWarnAboutContextTypeOnFunctionComponent;\n var didWarnAboutGetDerivedStateOnFunctionComponent;\n var didWarnAboutFunctionRefs;\n var didWarnAboutReassigningProps;\n var didWarnAboutRevealOrder;\n var didWarnAboutTailOptions;\n didWarnAboutBadClass = {\n };\n didWarnAboutModulePatternComponent = {\n };\n didWarnAboutContextTypeOnFunctionComponent = {\n };\n didWarnAboutGetDerivedStateOnFunctionComponent = {\n };\n didWarnAboutFunctionRefs = {\n };\n didWarnAboutReassigningProps = false;\n didWarnAboutRevealOrder = {\n };\n didWarnAboutTailOptions = {\n };\n function reconcileChildren(current, workInProgress, nextChildren, renderLanes) {\n if (current === null) // If this is a fresh new component that hasn't been rendered yet, we\n // won't update its child set by applying minimal side-effects. Instead,\n // we will add them all to the child before it gets rendered. That means\n // we can optimize this reconciliation pass by not tracking side-effects.\n workInProgress.child = mountChildFibers(workInProgress, null, nextChildren, renderLanes);\n else // If the current child is the same as the work in progress, it means that\n // we haven't yet started any work on these children. Therefore, we use\n // the clone algorithm to create a copy of all the current children.\n // If we had any progressed work already, that is invalid at this point so\n // let's throw it out.\n workInProgress.child = reconcileChildFibers1(workInProgress, current.child, nextChildren, renderLanes);\n }\n function forceUnmountCurrentAndReconcile(current, workInProgress, nextChildren, renderLanes) {\n // This function is fork of reconcileChildren. It's used in cases where we\n // want to reconcile without matching against the existing set. This has the\n // effect of all current children being unmounted; even if the type and key\n // are the same, the old child is unmounted and a new child is created.\n //\n // To do this, we're going to go through the reconcile algorithm twice. In\n // the first pass, we schedule a deletion for all the current children by\n // passing null.\n workInProgress.child = reconcileChildFibers1(workInProgress, current.child, null, renderLanes); // In the second pass, we mount the new children. The trick here is that we\n // pass null in place of where we usually pass the current child set. This has\n // the effect of remounting all children regardless of whether their\n // identities match.\n workInProgress.child = reconcileChildFibers1(workInProgress, null, nextChildren, renderLanes);\n }\n function updateForwardRef(current, workInProgress, Component, nextProps, renderLanes) {\n if (workInProgress.type !== workInProgress.elementType) {\n // Lazy component props can't be validated in createElement\n // because they're only guaranteed to be resolved here.\n var innerPropTypes = Component.propTypes;\n if (innerPropTypes) checkPropTypes(innerPropTypes, nextProps, 'prop', getComponentName(Component));\n }\n var render = Component.render;\n var ref = workInProgress.ref; // The rest is a fork of updateFunctionComponent\n var nextChildren;\n prepareToReadContext(workInProgress, renderLanes);\n ReactCurrentOwner$1.current = workInProgress;\n setIsRendering(true);\n nextChildren = renderWithHooks(current, workInProgress, render, nextProps, ref, renderLanes);\n if (workInProgress.mode & StrictMode) {\n disableLogs();\n try {\n nextChildren = renderWithHooks(current, workInProgress, render, nextProps, ref, renderLanes);\n } finally{\n reenableLogs();\n }\n }\n setIsRendering(false);\n if (current !== null && !didReceiveUpdate) {\n bailoutHooks(current, workInProgress, renderLanes);\n return bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes);\n } // React DevTools reads this flag.\n workInProgress.flags |= PerformedWork;\n reconcileChildren(current, workInProgress, nextChildren, renderLanes);\n return workInProgress.child;\n }\n function updateMemoComponent(current, workInProgress, Component, nextProps, updateLanes, renderLanes) {\n if (current === null) {\n var type = Component.type;\n if (isSimpleFunctionComponent(type) && Component.compare === null && Component.defaultProps === undefined) {\n var resolvedType = type;\n resolvedType = resolveFunctionForHotReloading(type);\n // and with only the default shallow comparison, we upgrade it\n // to a SimpleMemoComponent to allow fast path updates.\n workInProgress.tag = SimpleMemoComponent;\n workInProgress.type = resolvedType;\n validateFunctionComponentInDev(workInProgress, type);\n return updateSimpleMemoComponent(current, workInProgress, resolvedType, nextProps, updateLanes, renderLanes);\n }\n var innerPropTypes = type.propTypes;\n if (innerPropTypes) // Inner memo component props aren't currently validated in createElement.\n // We could move it there, but we'd still need this for lazy code path.\n checkPropTypes(innerPropTypes, nextProps, 'prop', getComponentName(type));\n var child = createFiberFromTypeAndProps(Component.type, null, nextProps, workInProgress, workInProgress.mode, renderLanes);\n child.ref = workInProgress.ref;\n child.return = workInProgress;\n workInProgress.child = child;\n return child;\n }\n var _type = Component.type;\n var _innerPropTypes = _type.propTypes;\n if (_innerPropTypes) // Inner memo component props aren't currently validated in createElement.\n // We could move it there, but we'd still need this for lazy code path.\n checkPropTypes(_innerPropTypes, nextProps, 'prop', getComponentName(_type));\n var currentChild = current.child; // This is always exactly one child\n if (!includesSomeLane(updateLanes, renderLanes)) {\n // This will be the props with resolved defaultProps,\n // unlike current.memoizedProps which will be the unresolved ones.\n var prevProps = currentChild.memoizedProps; // Default to shallow comparison\n var compare = Component.compare;\n compare = compare !== null ? compare : shallowEqual;\n if (compare(prevProps, nextProps) && current.ref === workInProgress.ref) return bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes);\n } // React DevTools reads this flag.\n workInProgress.flags |= PerformedWork;\n var newChild = createWorkInProgress(currentChild, nextProps);\n newChild.ref = workInProgress.ref;\n newChild.return = workInProgress;\n workInProgress.child = newChild;\n return newChild;\n }\n function updateSimpleMemoComponent(current, workInProgress, Component, nextProps, updateLanes, renderLanes) {\n if (workInProgress.type !== workInProgress.elementType) {\n // Lazy component props can't be validated in createElement\n // because they're only guaranteed to be resolved here.\n var outerMemoType = workInProgress.elementType;\n if (outerMemoType.$$typeof === REACT_LAZY_TYPE) {\n // We warn when you define propTypes on lazy()\n // so let's just skip over it to find memo() outer wrapper.\n // Inner props for memo are validated later.\n var lazyComponent = outerMemoType;\n var payload = lazyComponent._payload;\n var init = lazyComponent._init;\n try {\n outerMemoType = init(payload);\n } catch (x) {\n outerMemoType = null;\n } // Inner propTypes will be validated in the function component path.\n var outerPropTypes = outerMemoType && outerMemoType.propTypes;\n if (outerPropTypes) checkPropTypes(outerPropTypes, nextProps, 'prop', getComponentName(outerMemoType));\n }\n }\n if (current !== null) {\n var prevProps = current.memoizedProps;\n if (shallowEqual(prevProps, nextProps) && current.ref === workInProgress.ref && workInProgress.type === current.type) {\n didReceiveUpdate = false;\n if (!includesSomeLane(renderLanes, updateLanes)) {\n // The pending lanes were cleared at the beginning of beginWork. We're\n // about to bail out, but there might be other lanes that weren't\n // included in the current render. Usually, the priority level of the\n // remaining updates is accumlated during the evaluation of the\n // component (i.e. when processing the update queue). But since since\n // we're bailing out early *without* evaluating the component, we need\n // to account for it here, too. Reset to the value of the current fiber.\n // NOTE: This only applies to SimpleMemoComponent, not MemoComponent,\n // because a MemoComponent fiber does not have hooks or an update queue;\n // rather, it wraps around an inner component, which may or may not\n // contains hooks.\n // TODO: Move the reset at in beginWork out of the common path so that\n // this is no longer necessary.\n workInProgress.lanes = current.lanes;\n return bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes);\n } else if ((current.flags & ForceUpdateForLegacySuspense) !== NoFlags) // This is a special case that only exists for legacy mode.\n // See https://github.com/facebook/react/pull/19216.\n didReceiveUpdate = true;\n }\n }\n return updateFunctionComponent(current, workInProgress, Component, nextProps, renderLanes);\n }\n function updateOffscreenComponent(current, workInProgress, renderLanes) {\n var nextProps = workInProgress.pendingProps;\n var nextChildren = nextProps.children;\n var prevState = current !== null ? current.memoizedState : null;\n if (nextProps.mode === 'hidden' || nextProps.mode === 'unstable-defer-without-hiding') {\n if ((workInProgress.mode & ConcurrentMode) === NoMode) {\n // In legacy sync mode, don't defer the subtree. Render it now.\n // TODO: Figure out what we should do in Blocking mode.\n var nextState = {\n baseLanes: NoLanes\n };\n workInProgress.memoizedState = nextState;\n pushRenderLanes(workInProgress, renderLanes);\n } else if (!includesSomeLane(renderLanes, OffscreenLane)) {\n var nextBaseLanes;\n if (prevState !== null) {\n var prevBaseLanes = prevState.baseLanes;\n nextBaseLanes = mergeLanes(prevBaseLanes, renderLanes);\n } else nextBaseLanes = renderLanes;\n // Schedule this fiber to re-render at offscreen priority. Then bailout.\n markSpawnedWork(OffscreenLane);\n workInProgress.lanes = workInProgress.childLanes = laneToLanes(OffscreenLane);\n var _nextState = {\n baseLanes: nextBaseLanes\n };\n workInProgress.memoizedState = _nextState; // We're about to bail out, but we need to push this to the stack anyway\n // to avoid a push/pop misalignment.\n pushRenderLanes(workInProgress, nextBaseLanes);\n return null;\n } else {\n // Rendering at offscreen, so we can clear the base lanes.\n var _nextState2 = {\n baseLanes: NoLanes\n };\n workInProgress.memoizedState = _nextState2; // Push the lanes that were skipped when we bailed out.\n var subtreeRenderLanes = prevState !== null ? prevState.baseLanes : renderLanes;\n pushRenderLanes(workInProgress, subtreeRenderLanes);\n }\n } else {\n var _subtreeRenderLanes;\n if (prevState !== null) {\n _subtreeRenderLanes = mergeLanes(prevState.baseLanes, renderLanes); // Since we're not hidden anymore, reset the state\n workInProgress.memoizedState = null;\n } else // We weren't previously hidden, and we still aren't, so there's nothing\n // special to do. Need to push to the stack regardless, though, to avoid\n // a push/pop misalignment.\n _subtreeRenderLanes = renderLanes;\n pushRenderLanes(workInProgress, _subtreeRenderLanes);\n }\n reconcileChildren(current, workInProgress, nextChildren, renderLanes);\n return workInProgress.child;\n } // Note: These happen to have identical begin phases, for now. We shouldn't hold\n // ourselves to this constraint, though. If the behavior diverges, we should\n // fork the function.\n var updateLegacyHiddenComponent = updateOffscreenComponent;\n function updateFragment1(current, workInProgress, renderLanes) {\n var nextChildren = workInProgress.pendingProps;\n reconcileChildren(current, workInProgress, nextChildren, renderLanes);\n return workInProgress.child;\n }\n function updateMode(current, workInProgress, renderLanes) {\n var nextChildren = workInProgress.pendingProps.children;\n reconcileChildren(current, workInProgress, nextChildren, renderLanes);\n return workInProgress.child;\n }\n function updateProfiler(current, workInProgress, renderLanes) {\n workInProgress.flags |= Update; // Reset effect durations for the next eventual effect phase.\n // These are reset during render to allow the DevTools commit hook a chance to read them,\n var stateNode = workInProgress.stateNode;\n stateNode.effectDuration = 0;\n stateNode.passiveEffectDuration = 0;\n var nextProps = workInProgress.pendingProps;\n var nextChildren = nextProps.children;\n reconcileChildren(current, workInProgress, nextChildren, renderLanes);\n return workInProgress.child;\n }\n function markRef(current, workInProgress) {\n var ref = workInProgress.ref;\n if (current === null && ref !== null || current !== null && current.ref !== ref) // Schedule a Ref effect\n workInProgress.flags |= Ref;\n }\n function updateFunctionComponent(current, workInProgress, Component, nextProps, renderLanes) {\n if (workInProgress.type !== workInProgress.elementType) {\n // Lazy component props can't be validated in createElement\n // because they're only guaranteed to be resolved here.\n var innerPropTypes = Component.propTypes;\n if (innerPropTypes) checkPropTypes(innerPropTypes, nextProps, 'prop', getComponentName(Component));\n }\n var context;\n var unmaskedContext = getUnmaskedContext(workInProgress, Component, true);\n context = getMaskedContext(workInProgress, unmaskedContext);\n var nextChildren;\n prepareToReadContext(workInProgress, renderLanes);\n ReactCurrentOwner$1.current = workInProgress;\n setIsRendering(true);\n nextChildren = renderWithHooks(current, workInProgress, Component, nextProps, context, renderLanes);\n if (workInProgress.mode & StrictMode) {\n disableLogs();\n try {\n nextChildren = renderWithHooks(current, workInProgress, Component, nextProps, context, renderLanes);\n } finally{\n reenableLogs();\n }\n }\n setIsRendering(false);\n if (current !== null && !didReceiveUpdate) {\n bailoutHooks(current, workInProgress, renderLanes);\n return bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes);\n } // React DevTools reads this flag.\n workInProgress.flags |= PerformedWork;\n reconcileChildren(current, workInProgress, nextChildren, renderLanes);\n return workInProgress.child;\n }\n function updateClassComponent(current, workInProgress, Component, nextProps, renderLanes) {\n if (workInProgress.type !== workInProgress.elementType) {\n // Lazy component props can't be validated in createElement\n // because they're only guaranteed to be resolved here.\n var innerPropTypes = Component.propTypes;\n if (innerPropTypes) checkPropTypes(innerPropTypes, nextProps, 'prop', getComponentName(Component));\n }\n // During mounting we don't know the child context yet as the instance doesn't exist.\n // We will invalidate the child context in finishClassComponent() right after rendering.\n var hasContext;\n if (isContextProvider(Component)) {\n hasContext = true;\n pushContextProvider(workInProgress);\n } else hasContext = false;\n prepareToReadContext(workInProgress, renderLanes);\n var instance = workInProgress.stateNode;\n var shouldUpdate;\n if (instance === null) {\n if (current !== null) {\n // A class component without an instance only mounts if it suspended\n // inside a non-concurrent tree, in an inconsistent state. We want to\n // treat it like a new mount, even though an empty version of it already\n // committed. Disconnect the alternate pointers.\n current.alternate = null;\n workInProgress.alternate = null; // Since this is conceptually a new fiber, schedule a Placement effect\n workInProgress.flags |= Placement;\n } // In the initial pass we might need to construct the instance.\n constructClassInstance(workInProgress, Component, nextProps);\n mountClassInstance(workInProgress, Component, nextProps, renderLanes);\n shouldUpdate = true;\n } else if (current === null) // In a resume, we'll already have an instance we can reuse.\n shouldUpdate = resumeMountClassInstance(workInProgress, Component, nextProps, renderLanes);\n else shouldUpdate = updateClassInstance(current, workInProgress, Component, nextProps, renderLanes);\n var nextUnitOfWork = finishClassComponent(current, workInProgress, Component, shouldUpdate, hasContext, renderLanes);\n var inst = workInProgress.stateNode;\n if (shouldUpdate && inst.props !== nextProps) {\n if (!didWarnAboutReassigningProps) error1(\"It looks like %s is reassigning its own `this.props` while rendering. This is not supported and can lead to confusing bugs.\", getComponentName(workInProgress.type) || 'a component');\n didWarnAboutReassigningProps = true;\n }\n return nextUnitOfWork;\n }\n function finishClassComponent(current, workInProgress, Component, shouldUpdate, hasContext, renderLanes) {\n // Refs should update even if shouldComponentUpdate returns false\n markRef(current, workInProgress);\n var didCaptureError = (workInProgress.flags & DidCapture) !== NoFlags;\n if (!shouldUpdate && !didCaptureError) {\n // Context providers should defer to sCU for rendering\n if (hasContext) invalidateContextProvider(workInProgress, Component, false);\n return bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes);\n }\n var instance = workInProgress.stateNode; // Rerender\n ReactCurrentOwner$1.current = workInProgress;\n var nextChildren;\n if (didCaptureError && typeof Component.getDerivedStateFromError !== 'function') {\n // If we captured an error, but getDerivedStateFromError is not defined,\n // unmount all the children. componentDidCatch will schedule an update to\n // re-render a fallback. This is temporary until we migrate everyone to\n // the new API.\n // TODO: Warn in a future release.\n nextChildren = null;\n stopProfilerTimerIfRunning();\n } else {\n setIsRendering(true);\n nextChildren = instance.render();\n if (workInProgress.mode & StrictMode) {\n disableLogs();\n try {\n instance.render();\n } finally{\n reenableLogs();\n }\n }\n setIsRendering(false);\n } // React DevTools reads this flag.\n workInProgress.flags |= PerformedWork;\n if (current !== null && didCaptureError) // If we're recovering from an error, reconcile without reusing any of\n // the existing children. Conceptually, the normal children and the children\n // that are shown on error are two different sets, so we shouldn't reuse\n // normal children even if their identities match.\n forceUnmountCurrentAndReconcile(current, workInProgress, nextChildren, renderLanes);\n else reconcileChildren(current, workInProgress, nextChildren, renderLanes);\n // Memoize state using the values we just used to render.\n // TODO: Restructure so we never read values from the instance.\n workInProgress.memoizedState = instance.state; // The context might have changed so we need to recalculate it.\n if (hasContext) invalidateContextProvider(workInProgress, Component, true);\n return workInProgress.child;\n }\n function pushHostRootContext(workInProgress) {\n var root = workInProgress.stateNode;\n if (root.pendingContext) pushTopLevelContextObject(workInProgress, root.pendingContext, root.pendingContext !== root.context);\n else if (root.context) // Should always be set\n pushTopLevelContextObject(workInProgress, root.context, false);\n pushHostContainer(workInProgress, root.containerInfo);\n }\n function updateHostRoot(current, workInProgress, renderLanes) {\n pushHostRootContext(workInProgress);\n var updateQueue = workInProgress.updateQueue;\n if (!(current !== null && updateQueue !== null)) throw Error(\"If the root does not have an updateQueue, we should have already bailed out. This error is likely caused by a bug in React. Please file an issue.\");\n var nextProps = workInProgress.pendingProps;\n var prevState = workInProgress.memoizedState;\n var prevChildren = prevState !== null ? prevState.element : null;\n cloneUpdateQueue(current, workInProgress);\n processUpdateQueue(workInProgress, nextProps, null, renderLanes);\n var nextState = workInProgress.memoizedState; // Caution: React DevTools currently depends on this property\n // being called \"element\".\n var nextChildren = nextState.element;\n if (nextChildren === prevChildren) {\n resetHydrationState();\n return bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes);\n }\n var root = workInProgress.stateNode;\n if (root.hydrate && enterHydrationState(workInProgress)) {\n var mutableSourceEagerHydrationData = root.mutableSourceEagerHydrationData;\n if (mutableSourceEagerHydrationData != null) for(var i = 0; i < mutableSourceEagerHydrationData.length; i += 2){\n var mutableSource = mutableSourceEagerHydrationData[i];\n var version = mutableSourceEagerHydrationData[i + 1];\n setWorkInProgressVersion(mutableSource, version);\n }\n var child = mountChildFibers(workInProgress, null, nextChildren, renderLanes);\n workInProgress.child = child;\n var node = child;\n while(node){\n // Mark each child as hydrating. This is a fast path to know whether this\n // tree is part of a hydrating tree. This is used to determine if a child\n // node has fully mounted yet, and for scheduling event replaying.\n // Conceptually this is similar to Placement in that a new subtree is\n // inserted into the React tree here. It just happens to not need DOM\n // mutations because it already exists.\n node.flags = node.flags & ~Placement | Hydrating;\n node = node.sibling;\n }\n } else {\n // Otherwise reset hydration state in case we aborted and resumed another\n // root.\n reconcileChildren(current, workInProgress, nextChildren, renderLanes);\n resetHydrationState();\n }\n return workInProgress.child;\n }\n function updateHostComponent(current, workInProgress, renderLanes) {\n pushHostContext(workInProgress);\n if (current === null) tryToClaimNextHydratableInstance(workInProgress);\n var type = workInProgress.type;\n var nextProps = workInProgress.pendingProps;\n var prevProps = current !== null ? current.memoizedProps : null;\n var nextChildren = nextProps.children;\n var isDirectTextChild = shouldSetTextContent(type, nextProps);\n if (isDirectTextChild) // We special case a direct text child of a host node. This is a common\n // case. We won't handle it as a reified child. We will instead handle\n // this in the host environment that also has access to this prop. That\n // avoids allocating another HostText fiber and traversing it.\n nextChildren = null;\n else if (prevProps !== null && shouldSetTextContent(type, prevProps)) // If we're switching from a direct text child to a normal child, or to\n // empty, we need to schedule the text content to be reset.\n workInProgress.flags |= ContentReset;\n markRef(current, workInProgress);\n reconcileChildren(current, workInProgress, nextChildren, renderLanes);\n return workInProgress.child;\n }\n function updateHostText(current, workInProgress) {\n if (current === null) tryToClaimNextHydratableInstance(workInProgress);\n // Nothing to do here. This is terminal. We'll do the completion step\n // immediately after.\n return null;\n }\n function mountLazyComponent(_current, workInProgress, elementType, updateLanes, renderLanes) {\n if (_current !== null) {\n // A lazy component only mounts if it suspended inside a non-\n // concurrent tree, in an inconsistent state. We want to treat it like\n // a new mount, even though an empty version of it already committed.\n // Disconnect the alternate pointers.\n _current.alternate = null;\n workInProgress.alternate = null; // Since this is conceptually a new fiber, schedule a Placement effect\n workInProgress.flags |= Placement;\n }\n var props = workInProgress.pendingProps;\n var lazyComponent = elementType;\n var payload = lazyComponent._payload;\n var init = lazyComponent._init;\n var Component = init(payload); // Store the unwrapped component in the type.\n workInProgress.type = Component;\n var resolvedTag = workInProgress.tag = resolveLazyComponentTag(Component);\n var resolvedProps = resolveDefaultProps(Component, props);\n var child;\n switch(resolvedTag){\n case FunctionComponent:\n validateFunctionComponentInDev(workInProgress, Component);\n workInProgress.type = Component = resolveFunctionForHotReloading(Component);\n child = updateFunctionComponent(null, workInProgress, Component, resolvedProps, renderLanes);\n return child;\n case ClassComponent:\n workInProgress.type = Component = resolveClassForHotReloading(Component);\n child = updateClassComponent(null, workInProgress, Component, resolvedProps, renderLanes);\n return child;\n case ForwardRef:\n workInProgress.type = Component = resolveForwardRefForHotReloading(Component);\n child = updateForwardRef(null, workInProgress, Component, resolvedProps, renderLanes);\n return child;\n case MemoComponent:\n if (workInProgress.type !== workInProgress.elementType) {\n var outerPropTypes = Component.propTypes;\n if (outerPropTypes) checkPropTypes(outerPropTypes, resolvedProps, 'prop', getComponentName(Component));\n }\n child = updateMemoComponent(null, workInProgress, Component, resolveDefaultProps(Component.type, resolvedProps), updateLanes, renderLanes);\n return child;\n }\n var hint = '';\n if (Component !== null && typeof Component === 'object' && Component.$$typeof === REACT_LAZY_TYPE) hint = ' Did you wrap a component in React.lazy() more than once?';\n throw Error(\"Element type is invalid. Received a promise that resolves to: \" + Component + \". Lazy element type must resolve to a class or function.\" + hint);\n }\n function mountIncompleteClassComponent(_current, workInProgress, Component, nextProps, renderLanes) {\n if (_current !== null) {\n // An incomplete component only mounts if it suspended inside a non-\n // concurrent tree, in an inconsistent state. We want to treat it like\n // a new mount, even though an empty version of it already committed.\n // Disconnect the alternate pointers.\n _current.alternate = null;\n workInProgress.alternate = null; // Since this is conceptually a new fiber, schedule a Placement effect\n workInProgress.flags |= Placement;\n } // Promote the fiber to a class and try rendering again.\n workInProgress.tag = ClassComponent; // The rest of this function is a fork of `updateClassComponent`\n // Push context providers early to prevent context stack mismatches.\n // During mounting we don't know the child context yet as the instance doesn't exist.\n // We will invalidate the child context in finishClassComponent() right after rendering.\n var hasContext;\n if (isContextProvider(Component)) {\n hasContext = true;\n pushContextProvider(workInProgress);\n } else hasContext = false;\n prepareToReadContext(workInProgress, renderLanes);\n constructClassInstance(workInProgress, Component, nextProps);\n mountClassInstance(workInProgress, Component, nextProps, renderLanes);\n return finishClassComponent(null, workInProgress, Component, true, hasContext, renderLanes);\n }\n function mountIndeterminateComponent(_current, workInProgress, Component, renderLanes) {\n if (_current !== null) {\n // An indeterminate component only mounts if it suspended inside a non-\n // concurrent tree, in an inconsistent state. We want to treat it like\n // a new mount, even though an empty version of it already committed.\n // Disconnect the alternate pointers.\n _current.alternate = null;\n workInProgress.alternate = null; // Since this is conceptually a new fiber, schedule a Placement effect\n workInProgress.flags |= Placement;\n }\n var props = workInProgress.pendingProps;\n var context;\n var unmaskedContext = getUnmaskedContext(workInProgress, Component, false);\n context = getMaskedContext(workInProgress, unmaskedContext);\n prepareToReadContext(workInProgress, renderLanes);\n var value;\n if (Component.prototype && typeof Component.prototype.render === 'function') {\n var componentName = getComponentName(Component) || 'Unknown';\n if (!didWarnAboutBadClass[componentName]) {\n error1(\"The <%s /> component appears to have a render method, but doesn't extend React.Component. This is likely to cause errors. Change %s to extend React.Component instead.\", componentName, componentName);\n didWarnAboutBadClass[componentName] = true;\n }\n }\n if (workInProgress.mode & StrictMode) ReactStrictModeWarnings.recordLegacyContextWarning(workInProgress, null);\n setIsRendering(true);\n ReactCurrentOwner$1.current = workInProgress;\n value = renderWithHooks(null, workInProgress, Component, props, context, renderLanes);\n setIsRendering(false);\n workInProgress.flags |= PerformedWork;\n // Support for module components is deprecated and is removed behind a flag.\n // Whether or not it would crash later, we want to show a good message in DEV first.\n if (typeof value === 'object' && value !== null && typeof value.render === 'function' && value.$$typeof === undefined) {\n var _componentName = getComponentName(Component) || 'Unknown';\n if (!didWarnAboutModulePatternComponent[_componentName]) {\n error1(\"The <%s /> component appears to be a function component that returns a class instance. Change %s to a class that extends React.Component instead. If you can't use a class try assigning the prototype on the function as a workaround. `%s.prototype = React.Component.prototype`. Don't use an arrow function since it cannot be called with `new` by React.\", _componentName, _componentName, _componentName);\n didWarnAboutModulePatternComponent[_componentName] = true;\n }\n }\n if (// Eventually we'll delete this branch altogether.\n typeof value === 'object' && value !== null && typeof value.render === 'function' && value.$$typeof === undefined) {\n var _componentName2 = getComponentName(Component) || 'Unknown';\n if (!didWarnAboutModulePatternComponent[_componentName2]) {\n error1(\"The <%s /> component appears to be a function component that returns a class instance. Change %s to a class that extends React.Component instead. If you can't use a class try assigning the prototype on the function as a workaround. `%s.prototype = React.Component.prototype`. Don't use an arrow function since it cannot be called with `new` by React.\", _componentName2, _componentName2, _componentName2);\n didWarnAboutModulePatternComponent[_componentName2] = true;\n }\n workInProgress.tag = ClassComponent; // Throw out any hooks that were used.\n workInProgress.memoizedState = null;\n workInProgress.updateQueue = null; // Push context providers early to prevent context stack mismatches.\n // During mounting we don't know the child context yet as the instance doesn't exist.\n // We will invalidate the child context in finishClassComponent() right after rendering.\n var hasContext = false;\n if (isContextProvider(Component)) {\n hasContext = true;\n pushContextProvider(workInProgress);\n } else hasContext = false;\n workInProgress.memoizedState = value.state !== null && value.state !== undefined ? value.state : null;\n initializeUpdateQueue(workInProgress);\n var getDerivedStateFromProps = Component.getDerivedStateFromProps;\n if (typeof getDerivedStateFromProps === 'function') applyDerivedStateFromProps(workInProgress, Component, getDerivedStateFromProps, props);\n adoptClassInstance(workInProgress, value);\n mountClassInstance(workInProgress, Component, props, renderLanes);\n return finishClassComponent(null, workInProgress, Component, true, hasContext, renderLanes);\n } else {\n // Proceed under the assumption that this is a function component\n workInProgress.tag = FunctionComponent;\n if (workInProgress.mode & StrictMode) {\n disableLogs();\n try {\n value = renderWithHooks(null, workInProgress, Component, props, context, renderLanes);\n } finally{\n reenableLogs();\n }\n }\n reconcileChildren(null, workInProgress, value, renderLanes);\n validateFunctionComponentInDev(workInProgress, Component);\n return workInProgress.child;\n }\n }\n function validateFunctionComponentInDev(workInProgress, Component) {\n if (Component) {\n if (Component.childContextTypes) error1('%s(...): childContextTypes cannot be defined on a function component.', Component.displayName || Component.name || 'Component');\n }\n if (workInProgress.ref !== null) {\n var info = '';\n var ownerName = getCurrentFiberOwnerNameInDevOrNull();\n if (ownerName) info += '\\n\\nCheck the render method of `' + ownerName + '`.';\n var warningKey = ownerName || workInProgress._debugID || '';\n var debugSource = workInProgress._debugSource;\n if (debugSource) warningKey = debugSource.fileName + ':' + debugSource.lineNumber;\n if (!didWarnAboutFunctionRefs[warningKey]) {\n didWarnAboutFunctionRefs[warningKey] = true;\n error1(\"Function components cannot be given refs. Attempts to access this ref will fail. Did you mean to use React.forwardRef()?%s\", info);\n }\n }\n if (typeof Component.getDerivedStateFromProps === 'function') {\n var _componentName3 = getComponentName(Component) || 'Unknown';\n if (!didWarnAboutGetDerivedStateOnFunctionComponent[_componentName3]) {\n error1('%s: Function components do not support getDerivedStateFromProps.', _componentName3);\n didWarnAboutGetDerivedStateOnFunctionComponent[_componentName3] = true;\n }\n }\n if (typeof Component.contextType === 'object' && Component.contextType !== null) {\n var _componentName4 = getComponentName(Component) || 'Unknown';\n if (!didWarnAboutContextTypeOnFunctionComponent[_componentName4]) {\n error1('%s: Function components do not support contextType.', _componentName4);\n didWarnAboutContextTypeOnFunctionComponent[_componentName4] = true;\n }\n }\n }\n var SUSPENDED_MARKER = {\n dehydrated: null,\n retryLane: NoLane\n };\n function mountSuspenseOffscreenState(renderLanes) {\n return {\n baseLanes: renderLanes\n };\n }\n function updateSuspenseOffscreenState(prevOffscreenState, renderLanes) {\n return {\n baseLanes: mergeLanes(prevOffscreenState.baseLanes, renderLanes)\n };\n } // TODO: Probably should inline this back\n function shouldRemainOnFallback(suspenseContext, current, workInProgress, renderLanes) {\n // If we're already showing a fallback, there are cases where we need to\n // remain on that fallback regardless of whether the content has resolved.\n // For example, SuspenseList coordinates when nested content appears.\n if (current !== null) {\n var suspenseState = current.memoizedState;\n if (suspenseState === null) // Currently showing content. Don't hide it, even if ForceSuspenseFallack\n // is true. More precise name might be \"ForceRemainSuspenseFallback\".\n // Note: This is a factoring smell. Can't remain on a fallback if there's\n // no fallback to remain on.\n return false;\n } // Not currently showing content. Consult the Suspense context.\n return hasSuspenseContext(suspenseContext, ForceSuspenseFallback);\n }\n function getRemainingWorkInPrimaryTree(current, renderLanes) {\n // TODO: Should not remove render lanes that were pinged during this render\n return removeLanes(current.childLanes, renderLanes);\n }\n function updateSuspenseComponent(current, workInProgress, renderLanes) {\n var nextProps = workInProgress.pendingProps; // This is used by DevTools to force a boundary to suspend.\n if (shouldSuspend(workInProgress)) workInProgress.flags |= DidCapture;\n var suspenseContext = suspenseStackCursor.current;\n var showFallback = false;\n var didSuspend = (workInProgress.flags & DidCapture) !== NoFlags;\n if (didSuspend || shouldRemainOnFallback(suspenseContext, current)) {\n // Something in this boundary's subtree already suspended. Switch to\n // rendering the fallback children.\n showFallback = true;\n workInProgress.flags &= ~DidCapture;\n } else {\n // Attempting the main content\n if (current === null || current.memoizedState !== null) // This is a new mount or this boundary is already showing a fallback state.\n // Mark this subtree context as having at least one invisible parent that could\n // handle the fallback state.\n // Boundaries without fallbacks or should be avoided are not considered since\n // they cannot handle preferred fallback states.\n {\n if (nextProps.fallback !== undefined && nextProps.unstable_avoidThisFallback !== true) suspenseContext = addSubtreeSuspenseContext(suspenseContext, InvisibleParentSuspenseContext);\n }\n }\n suspenseContext = setDefaultShallowSuspenseContext(suspenseContext);\n pushSuspenseContext(workInProgress, suspenseContext); // OK, the next part is confusing. We're about to reconcile the Suspense\n // boundary's children. This involves some custom reconcilation logic. Two\n // main reasons this is so complicated.\n //\n // First, Legacy Mode has different semantics for backwards compatibility. The\n // primary tree will commit in an inconsistent state, so when we do the\n // second pass to render the fallback, we do some exceedingly, uh, clever\n // hacks to make that not totally break. Like transferring effects and\n // deletions from hidden tree. In Concurrent Mode, it's much simpler,\n // because we bailout on the primary tree completely and leave it in its old\n // state, no effects. Same as what we do for Offscreen (except that\n // Offscreen doesn't have the first render pass).\n //\n // Second is hydration. During hydration, the Suspense fiber has a slightly\n // different layout, where the child points to a dehydrated fragment, which\n // contains the DOM rendered by the server.\n //\n // Third, even if you set all that aside, Suspense is like error boundaries in\n // that we first we try to render one tree, and if that fails, we render again\n // and switch to a different tree. Like a try/catch block. So we have to track\n // which branch we're currently rendering. Ideally we would model this using\n // a stack.\n if (current === null) {\n // Initial mount\n // If we're currently hydrating, try to hydrate this boundary.\n // But only if this has a fallback.\n if (nextProps.fallback !== undefined) tryToClaimNextHydratableInstance(workInProgress); // This could've been a dehydrated suspense component.\n var nextPrimaryChildren = nextProps.children;\n var nextFallbackChildren = nextProps.fallback;\n if (showFallback) {\n var fallbackFragment = mountSuspenseFallbackChildren(workInProgress, nextPrimaryChildren, nextFallbackChildren, renderLanes);\n var primaryChildFragment = workInProgress.child;\n primaryChildFragment.memoizedState = mountSuspenseOffscreenState(renderLanes);\n workInProgress.memoizedState = SUSPENDED_MARKER;\n return fallbackFragment;\n } else if (typeof nextProps.unstable_expectedLoadTime === 'number') {\n // This is a CPU-bound tree. Skip this tree and show a placeholder to\n // unblock the surrounding content. Then immediately retry after the\n // initial commit.\n var _fallbackFragment = mountSuspenseFallbackChildren(workInProgress, nextPrimaryChildren, nextFallbackChildren, renderLanes);\n var _primaryChildFragment = workInProgress.child;\n _primaryChildFragment.memoizedState = mountSuspenseOffscreenState(renderLanes);\n workInProgress.memoizedState = SUSPENDED_MARKER; // Since nothing actually suspended, there will nothing to ping this to\n // get it started back up to attempt the next item. While in terms of\n // priority this work has the same priority as this current render, it's\n // not part of the same transition once the transition has committed. If\n // it's sync, we still want to yield so that it can be painted.\n // Conceptually, this is really the same as pinging. We can use any\n // RetryLane even if it's the one currently rendering since we're leaving\n // it behind on this node.\n workInProgress.lanes = SomeRetryLane;\n markSpawnedWork(SomeRetryLane);\n return _fallbackFragment;\n } else return mountSuspensePrimaryChildren(workInProgress, nextPrimaryChildren, renderLanes);\n } else {\n // This is an update.\n // If the current fiber has a SuspenseState, that means it's already showing\n // a fallback.\n var prevState = current.memoizedState;\n if (prevState !== null) {\n if (showFallback) {\n var _nextFallbackChildren2 = nextProps.fallback;\n var _nextPrimaryChildren2 = nextProps.children;\n var _fallbackChildFragment = updateSuspenseFallbackChildren(current, workInProgress, _nextPrimaryChildren2, _nextFallbackChildren2, renderLanes);\n var _primaryChildFragment3 = workInProgress.child;\n var prevOffscreenState = current.child.memoizedState;\n _primaryChildFragment3.memoizedState = prevOffscreenState === null ? mountSuspenseOffscreenState(renderLanes) : updateSuspenseOffscreenState(prevOffscreenState, renderLanes);\n _primaryChildFragment3.childLanes = getRemainingWorkInPrimaryTree(current, renderLanes);\n workInProgress.memoizedState = SUSPENDED_MARKER;\n return _fallbackChildFragment;\n } else {\n var _nextPrimaryChildren3 = nextProps.children;\n var _primaryChildFragment4 = updateSuspensePrimaryChildren(current, workInProgress, _nextPrimaryChildren3, renderLanes);\n workInProgress.memoizedState = null;\n return _primaryChildFragment4;\n }\n } else // The current tree is not already showing a fallback.\n if (showFallback) {\n // Timed out.\n var _nextFallbackChildren3 = nextProps.fallback;\n var _nextPrimaryChildren4 = nextProps.children;\n var _fallbackChildFragment2 = updateSuspenseFallbackChildren(current, workInProgress, _nextPrimaryChildren4, _nextFallbackChildren3, renderLanes);\n var _primaryChildFragment5 = workInProgress.child;\n var _prevOffscreenState = current.child.memoizedState;\n _primaryChildFragment5.memoizedState = _prevOffscreenState === null ? mountSuspenseOffscreenState(renderLanes) : updateSuspenseOffscreenState(_prevOffscreenState, renderLanes);\n _primaryChildFragment5.childLanes = getRemainingWorkInPrimaryTree(current, renderLanes); // Skip the primary children, and continue working on the\n // fallback children.\n workInProgress.memoizedState = SUSPENDED_MARKER;\n return _fallbackChildFragment2;\n } else {\n // Still haven't timed out. Continue rendering the children, like we\n // normally do.\n var _nextPrimaryChildren5 = nextProps.children;\n var _primaryChildFragment6 = updateSuspensePrimaryChildren(current, workInProgress, _nextPrimaryChildren5, renderLanes);\n workInProgress.memoizedState = null;\n return _primaryChildFragment6;\n }\n }\n }\n function mountSuspensePrimaryChildren(workInProgress, primaryChildren, renderLanes) {\n var mode = workInProgress.mode;\n var primaryChildProps = {\n mode: 'visible',\n children: primaryChildren\n };\n var primaryChildFragment = createFiberFromOffscreen(primaryChildProps, mode, renderLanes, null);\n primaryChildFragment.return = workInProgress;\n workInProgress.child = primaryChildFragment;\n return primaryChildFragment;\n }\n function mountSuspenseFallbackChildren(workInProgress, primaryChildren, fallbackChildren, renderLanes) {\n var mode = workInProgress.mode;\n var progressedPrimaryFragment = workInProgress.child;\n var primaryChildProps = {\n mode: 'hidden',\n children: primaryChildren\n };\n var primaryChildFragment;\n var fallbackChildFragment;\n if ((mode & BlockingMode) === NoMode && progressedPrimaryFragment !== null) {\n // In legacy mode, we commit the primary tree as if it successfully\n // completed, even though it's in an inconsistent state.\n primaryChildFragment = progressedPrimaryFragment;\n primaryChildFragment.childLanes = NoLanes;\n primaryChildFragment.pendingProps = primaryChildProps;\n if (workInProgress.mode & ProfileMode) {\n // Reset the durations from the first pass so they aren't included in the\n // final amounts. This seems counterintuitive, since we're intentionally\n // not measuring part of the render phase, but this makes it match what we\n // do in Concurrent Mode.\n primaryChildFragment.actualDuration = 0;\n primaryChildFragment.actualStartTime = -1;\n primaryChildFragment.selfBaseDuration = 0;\n primaryChildFragment.treeBaseDuration = 0;\n }\n fallbackChildFragment = createFiberFromFragment(fallbackChildren, mode, renderLanes, null);\n } else {\n primaryChildFragment = createFiberFromOffscreen(primaryChildProps, mode, NoLanes, null);\n fallbackChildFragment = createFiberFromFragment(fallbackChildren, mode, renderLanes, null);\n }\n primaryChildFragment.return = workInProgress;\n fallbackChildFragment.return = workInProgress;\n primaryChildFragment.sibling = fallbackChildFragment;\n workInProgress.child = primaryChildFragment;\n return fallbackChildFragment;\n }\n function createWorkInProgressOffscreenFiber(current, offscreenProps) {\n // The props argument to `createWorkInProgress` is `any` typed, so we use this\n // wrapper function to constrain it.\n return createWorkInProgress(current, offscreenProps);\n }\n function updateSuspensePrimaryChildren(current, workInProgress, primaryChildren, renderLanes) {\n var currentPrimaryChildFragment = current.child;\n var currentFallbackChildFragment = currentPrimaryChildFragment.sibling;\n var primaryChildFragment = createWorkInProgressOffscreenFiber(currentPrimaryChildFragment, {\n mode: 'visible',\n children: primaryChildren\n });\n if ((workInProgress.mode & BlockingMode) === NoMode) primaryChildFragment.lanes = renderLanes;\n primaryChildFragment.return = workInProgress;\n primaryChildFragment.sibling = null;\n if (currentFallbackChildFragment !== null) {\n // Delete the fallback child fragment\n currentFallbackChildFragment.nextEffect = null;\n currentFallbackChildFragment.flags = Deletion;\n workInProgress.firstEffect = workInProgress.lastEffect = currentFallbackChildFragment;\n }\n workInProgress.child = primaryChildFragment;\n return primaryChildFragment;\n }\n function updateSuspenseFallbackChildren(current, workInProgress, primaryChildren, fallbackChildren, renderLanes) {\n var mode = workInProgress.mode;\n var currentPrimaryChildFragment = current.child;\n var currentFallbackChildFragment = currentPrimaryChildFragment.sibling;\n var primaryChildProps = {\n mode: 'hidden',\n children: primaryChildren\n };\n var primaryChildFragment;\n if (// completed, even though it's in an inconsistent state.\n (mode & BlockingMode) === NoMode && // already cloned. In legacy mode, the only case where this isn't true is\n // when DevTools forces us to display a fallback; we skip the first render\n // pass entirely and go straight to rendering the fallback. (In Concurrent\n // Mode, SuspenseList can also trigger this scenario, but this is a legacy-\n // only codepath.)\n workInProgress.child !== currentPrimaryChildFragment) {\n var progressedPrimaryFragment = workInProgress.child;\n primaryChildFragment = progressedPrimaryFragment;\n primaryChildFragment.childLanes = NoLanes;\n primaryChildFragment.pendingProps = primaryChildProps;\n if (workInProgress.mode & ProfileMode) {\n // Reset the durations from the first pass so they aren't included in the\n // final amounts. This seems counterintuitive, since we're intentionally\n // not measuring part of the render phase, but this makes it match what we\n // do in Concurrent Mode.\n primaryChildFragment.actualDuration = 0;\n primaryChildFragment.actualStartTime = -1;\n primaryChildFragment.selfBaseDuration = currentPrimaryChildFragment.selfBaseDuration;\n primaryChildFragment.treeBaseDuration = currentPrimaryChildFragment.treeBaseDuration;\n } // The fallback fiber was added as a deletion effect during the first pass.\n // However, since we're going to remain on the fallback, we no longer want\n // to delete it. So we need to remove it from the list. Deletions are stored\n // on the same list as effects. We want to keep the effects from the primary\n // tree. So we copy the primary child fragment's effect list, which does not\n // include the fallback deletion effect.\n var progressedLastEffect = primaryChildFragment.lastEffect;\n if (progressedLastEffect !== null) {\n workInProgress.firstEffect = primaryChildFragment.firstEffect;\n workInProgress.lastEffect = progressedLastEffect;\n progressedLastEffect.nextEffect = null;\n } else // TODO: Reset this somewhere else? Lol legacy mode is so weird.\n workInProgress.firstEffect = workInProgress.lastEffect = null;\n } else primaryChildFragment = createWorkInProgressOffscreenFiber(currentPrimaryChildFragment, primaryChildProps);\n var fallbackChildFragment;\n if (currentFallbackChildFragment !== null) fallbackChildFragment = createWorkInProgress(currentFallbackChildFragment, fallbackChildren);\n else {\n fallbackChildFragment = createFiberFromFragment(fallbackChildren, mode, renderLanes, null); // Needs a placement effect because the parent (the Suspense boundary) already\n // mounted but this is a new fiber.\n fallbackChildFragment.flags |= Placement;\n }\n fallbackChildFragment.return = workInProgress;\n primaryChildFragment.return = workInProgress;\n primaryChildFragment.sibling = fallbackChildFragment;\n workInProgress.child = primaryChildFragment;\n return fallbackChildFragment;\n }\n function scheduleWorkOnFiber(fiber, renderLanes) {\n fiber.lanes = mergeLanes(fiber.lanes, renderLanes);\n var alternate = fiber.alternate;\n if (alternate !== null) alternate.lanes = mergeLanes(alternate.lanes, renderLanes);\n scheduleWorkOnParentPath(fiber.return, renderLanes);\n }\n function propagateSuspenseContextChange(workInProgress, firstChild, renderLanes) {\n // Mark any Suspense boundaries with fallbacks as having work to do.\n // If they were previously forced into fallbacks, they may now be able\n // to unblock.\n var node = firstChild;\n while(node !== null){\n if (node.tag === SuspenseComponent) {\n var state = node.memoizedState;\n if (state !== null) scheduleWorkOnFiber(node, renderLanes);\n } else if (node.tag === SuspenseListComponent) // If the tail is hidden there might not be an Suspense boundaries\n // to schedule work on. In this case we have to schedule it on the\n // list itself.\n // We don't have to traverse to the children of the list since\n // the list will propagate the change when it rerenders.\n scheduleWorkOnFiber(node, renderLanes);\n else if (node.child !== null) {\n node.child.return = node;\n node = node.child;\n continue;\n }\n if (node === workInProgress) return;\n while(node.sibling === null){\n if (node.return === null || node.return === workInProgress) return;\n node = node.return;\n }\n node.sibling.return = node.return;\n node = node.sibling;\n }\n }\n function findLastContentRow(firstChild) {\n // This is going to find the last row among these children that is already\n // showing content on the screen, as opposed to being in fallback state or\n // new. If a row has multiple Suspense boundaries, any of them being in the\n // fallback state, counts as the whole row being in a fallback state.\n // Note that the \"rows\" will be workInProgress, but any nested children\n // will still be current since we haven't rendered them yet. The mounted\n // order may not be the same as the new order. We use the new order.\n var row = firstChild;\n var lastContentRow = null;\n while(row !== null){\n var currentRow = row.alternate; // New rows can't be content rows.\n if (currentRow !== null && findFirstSuspended(currentRow) === null) lastContentRow = row;\n row = row.sibling;\n }\n return lastContentRow;\n }\n function validateRevealOrder(revealOrder) {\n if (revealOrder !== undefined && revealOrder !== 'forwards' && revealOrder !== 'backwards' && revealOrder !== 'together' && !didWarnAboutRevealOrder[revealOrder]) {\n didWarnAboutRevealOrder[revealOrder] = true;\n if (typeof revealOrder === 'string') switch(revealOrder.toLowerCase()){\n case 'together':\n case 'forwards':\n case 'backwards':\n error1(\"\\\"%s\\\" is not a valid value for revealOrder on <SuspenseList />. Use lowercase \\\"%s\\\" instead.\", revealOrder, revealOrder.toLowerCase());\n break;\n case 'forward':\n case 'backward':\n error1(\"\\\"%s\\\" is not a valid value for revealOrder on <SuspenseList />. React uses the -s suffix in the spelling. Use \\\"%ss\\\" instead.\", revealOrder, revealOrder.toLowerCase());\n break;\n default:\n error1(\"\\\"%s\\\" is not a supported revealOrder on <SuspenseList />. Did you mean \\\"together\\\", \\\"forwards\\\" or \\\"backwards\\\"?\", revealOrder);\n break;\n }\n else error1(\"%s is not a supported value for revealOrder on <SuspenseList />. Did you mean \\\"together\\\", \\\"forwards\\\" or \\\"backwards\\\"?\", revealOrder);\n }\n }\n function validateTailOptions(tailMode, revealOrder) {\n if (tailMode !== undefined && !didWarnAboutTailOptions[tailMode]) {\n if (tailMode !== 'collapsed' && tailMode !== 'hidden') {\n didWarnAboutTailOptions[tailMode] = true;\n error1(\"\\\"%s\\\" is not a supported value for tail on <SuspenseList />. Did you mean \\\"collapsed\\\" or \\\"hidden\\\"?\", tailMode);\n } else if (revealOrder !== 'forwards' && revealOrder !== 'backwards') {\n didWarnAboutTailOptions[tailMode] = true;\n error1(\"<SuspenseList tail=\\\"%s\\\" /> is only valid if revealOrder is \\\"forwards\\\" or \\\"backwards\\\". Did you mean to specify revealOrder=\\\"forwards\\\"?\", tailMode);\n }\n }\n }\n function validateSuspenseListNestedChild(childSlot, index) {\n var isArray = Array.isArray(childSlot);\n var isIterable = !isArray && typeof getIteratorFn(childSlot) === 'function';\n if (isArray || isIterable) {\n var type = isArray ? 'array' : 'iterable';\n error1(\"A nested %s was passed to row #%s in <SuspenseList />. Wrap it in an additional SuspenseList to configure its revealOrder: <SuspenseList revealOrder=...> ... <SuspenseList revealOrder=...>{%s}</SuspenseList> ... </SuspenseList>\", type, index, type);\n return false;\n }\n return true;\n }\n function validateSuspenseListChildren(children, revealOrder) {\n if ((revealOrder === 'forwards' || revealOrder === 'backwards') && children !== undefined && children !== null && children !== false) {\n if (Array.isArray(children)) for(var i = 0; i < children.length; i++){\n if (!validateSuspenseListNestedChild(children[i], i)) return;\n }\n else {\n var iteratorFn = getIteratorFn(children);\n if (typeof iteratorFn === 'function') {\n var childrenIterator = iteratorFn.call(children);\n if (childrenIterator) {\n var step = childrenIterator.next();\n var _i = 0;\n for(; !step.done; step = childrenIterator.next()){\n if (!validateSuspenseListNestedChild(step.value, _i)) return;\n _i++;\n }\n }\n } else error1(\"A single row was passed to a <SuspenseList revealOrder=\\\"%s\\\" />. This is not useful since it needs multiple rows. Did you mean to pass multiple children or an array?\", revealOrder);\n }\n }\n }\n function initSuspenseListRenderState(workInProgress, isBackwards, tail, lastContentRow, tailMode, lastEffectBeforeRendering) {\n var renderState = workInProgress.memoizedState;\n if (renderState === null) workInProgress.memoizedState = {\n isBackwards: isBackwards,\n rendering: null,\n renderingStartTime: 0,\n last: lastContentRow,\n tail: tail,\n tailMode: tailMode,\n lastEffect: lastEffectBeforeRendering\n };\n else {\n // We can reuse the existing object from previous renders.\n renderState.isBackwards = isBackwards;\n renderState.rendering = null;\n renderState.renderingStartTime = 0;\n renderState.last = lastContentRow;\n renderState.tail = tail;\n renderState.tailMode = tailMode;\n renderState.lastEffect = lastEffectBeforeRendering;\n }\n } // This can end up rendering this component multiple passes.\n // The first pass splits the children fibers into two sets. A head and tail.\n // We first render the head. If anything is in fallback state, we do another\n // pass through beginWork to rerender all children (including the tail) with\n // the force suspend context. If the first render didn't have anything in\n // in fallback state. Then we render each row in the tail one-by-one.\n // That happens in the completeWork phase without going back to beginWork.\n function updateSuspenseListComponent(current, workInProgress, renderLanes) {\n var nextProps = workInProgress.pendingProps;\n var revealOrder = nextProps.revealOrder;\n var tailMode = nextProps.tail;\n var newChildren = nextProps.children;\n validateRevealOrder(revealOrder);\n validateTailOptions(tailMode, revealOrder);\n validateSuspenseListChildren(newChildren, revealOrder);\n reconcileChildren(current, workInProgress, newChildren, renderLanes);\n var suspenseContext = suspenseStackCursor.current;\n var shouldForceFallback = hasSuspenseContext(suspenseContext, ForceSuspenseFallback);\n if (shouldForceFallback) {\n suspenseContext = setShallowSuspenseContext(suspenseContext, ForceSuspenseFallback);\n workInProgress.flags |= DidCapture;\n } else {\n var didSuspendBefore = current !== null && (current.flags & DidCapture) !== NoFlags;\n if (didSuspendBefore) // If we previously forced a fallback, we need to schedule work\n // on any nested boundaries to let them know to try to render\n // again. This is the same as context updating.\n propagateSuspenseContextChange(workInProgress, workInProgress.child, renderLanes);\n suspenseContext = setDefaultShallowSuspenseContext(suspenseContext);\n }\n pushSuspenseContext(workInProgress, suspenseContext);\n if ((workInProgress.mode & BlockingMode) === NoMode) // In legacy mode, SuspenseList doesn't work so we just\n // use make it a noop by treating it as the default revealOrder.\n workInProgress.memoizedState = null;\n else switch(revealOrder){\n case 'forwards':\n var lastContentRow = findLastContentRow(workInProgress.child);\n var tail;\n if (lastContentRow === null) {\n // The whole list is part of the tail.\n // TODO: We could fast path by just rendering the tail now.\n tail = workInProgress.child;\n workInProgress.child = null;\n } else {\n // Disconnect the tail rows after the content row.\n // We're going to render them separately later.\n tail = lastContentRow.sibling;\n lastContentRow.sibling = null;\n }\n initSuspenseListRenderState(workInProgress, false, tail, lastContentRow, tailMode, workInProgress.lastEffect);\n break;\n case 'backwards':\n // We're going to find the first row that has existing content.\n // At the same time we're going to reverse the list of everything\n // we pass in the meantime. That's going to be our tail in reverse\n // order.\n var _tail = null;\n var row = workInProgress.child;\n workInProgress.child = null;\n while(row !== null){\n var currentRow = row.alternate; // New rows can't be content rows.\n if (currentRow !== null && findFirstSuspended(currentRow) === null) {\n // This is the beginning of the main content.\n workInProgress.child = row;\n break;\n }\n var nextRow = row.sibling;\n row.sibling = _tail;\n _tail = row;\n row = nextRow;\n } // TODO: If workInProgress.child is null, we can continue on the tail immediately.\n initSuspenseListRenderState(workInProgress, true, _tail, null, tailMode, workInProgress.lastEffect);\n break;\n case 'together':\n initSuspenseListRenderState(workInProgress, false, null, null, undefined, workInProgress.lastEffect);\n break;\n default:\n // The default reveal order is the same as not having\n // a boundary.\n workInProgress.memoizedState = null;\n }\n return workInProgress.child;\n }\n function updatePortalComponent(current, workInProgress, renderLanes) {\n pushHostContainer(workInProgress, workInProgress.stateNode.containerInfo);\n var nextChildren = workInProgress.pendingProps;\n if (current === null) // Portals are special because we don't append the children during mount\n // but at commit. Therefore we need to track insertions which the normal\n // flow doesn't do during mount. This doesn't happen at the root because\n // the root always starts with a \"current\" with a null child.\n // TODO: Consider unifying this with how the root works.\n workInProgress.child = reconcileChildFibers1(workInProgress, null, nextChildren, renderLanes);\n else reconcileChildren(current, workInProgress, nextChildren, renderLanes);\n return workInProgress.child;\n }\n var hasWarnedAboutUsingNoValuePropOnContextProvider = false;\n function updateContextProvider(current, workInProgress, renderLanes) {\n var providerType = workInProgress.type;\n var context = providerType._context;\n var newProps = workInProgress.pendingProps;\n var oldProps = workInProgress.memoizedProps;\n var newValue = newProps.value;\n if (!('value' in newProps)) {\n if (!hasWarnedAboutUsingNoValuePropOnContextProvider) {\n hasWarnedAboutUsingNoValuePropOnContextProvider = true;\n error1('The `value` prop is required for the `<Context.Provider>`. Did you misspell it or forget to pass it?');\n }\n }\n var providerPropTypes = workInProgress.type.propTypes;\n if (providerPropTypes) checkPropTypes(providerPropTypes, newProps, 'prop', 'Context.Provider');\n pushProvider(workInProgress, newValue);\n if (oldProps !== null) {\n var oldValue = oldProps.value;\n var changedBits = calculateChangedBits(context, newValue, oldValue);\n if (changedBits === 0) {\n // No change. Bailout early if children are the same.\n if (oldProps.children === newProps.children && !hasContextChanged()) return bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes);\n } else // The context value changed. Search for matching consumers and schedule\n // them to update.\n propagateContextChange(workInProgress, context, changedBits, renderLanes);\n }\n var newChildren = newProps.children;\n reconcileChildren(current, workInProgress, newChildren, renderLanes);\n return workInProgress.child;\n }\n var hasWarnedAboutUsingContextAsConsumer = false;\n function updateContextConsumer(current, workInProgress, renderLanes) {\n var context = workInProgress.type; // The logic below for Context differs depending on PROD or DEV mode. In\n if (context._context === undefined) {\n // This may be because it's a Context (rather than a Consumer).\n // Or it may be because it's older React where they're the same thing.\n // We only want to warn if we're sure it's a new React.\n if (context !== context.Consumer) {\n if (!hasWarnedAboutUsingContextAsConsumer) {\n hasWarnedAboutUsingContextAsConsumer = true;\n error1(\"Rendering <Context> directly is not supported and will be removed in a future major release. Did you mean to render <Context.Consumer> instead?\");\n }\n }\n } else context = context._context;\n var newProps = workInProgress.pendingProps;\n var render = newProps.children;\n if (typeof render !== 'function') error1(\"A context consumer was rendered with multiple children, or a child that isn't a function. A context consumer expects a single child that is a function. If you did pass a function, make sure there is no trailing or leading whitespace around it.\");\n prepareToReadContext(workInProgress, renderLanes);\n var newValue = readContext(context, newProps.unstable_observedBits);\n var newChildren;\n ReactCurrentOwner$1.current = workInProgress;\n setIsRendering(true);\n newChildren = render(newValue);\n setIsRendering(false);\n workInProgress.flags |= PerformedWork;\n reconcileChildren(current, workInProgress, newChildren, renderLanes);\n return workInProgress.child;\n }\n function markWorkInProgressReceivedUpdate() {\n didReceiveUpdate = true;\n }\n function bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes) {\n if (current !== null) // Reuse previous dependencies\n workInProgress.dependencies = current.dependencies;\n // Don't update \"base\" render times for bailouts.\n stopProfilerTimerIfRunning();\n markSkippedUpdateLanes(workInProgress.lanes); // Check if the children have any pending work.\n if (!includesSomeLane(renderLanes, workInProgress.childLanes)) // The children don't have any work either. We can skip them.\n // TODO: Once we add back resuming, we should check if the children are\n // a work-in-progress set. If so, we need to transfer their effects.\n return null;\n else {\n // This fiber doesn't have work, but its subtree does. Clone the child\n // fibers and continue.\n cloneChildFibers(current, workInProgress);\n return workInProgress.child;\n }\n }\n function remountFiber(current, oldWorkInProgress, newWorkInProgress) {\n var returnFiber = oldWorkInProgress.return;\n if (returnFiber === null) throw new Error('Cannot swap the root fiber.');\n // Disconnect from the old current.\n // It will get deleted.\n current.alternate = null;\n oldWorkInProgress.alternate = null; // Connect to the new tree.\n newWorkInProgress.index = oldWorkInProgress.index;\n newWorkInProgress.sibling = oldWorkInProgress.sibling;\n newWorkInProgress.return = oldWorkInProgress.return;\n newWorkInProgress.ref = oldWorkInProgress.ref; // Replace the child/sibling pointers above it.\n if (oldWorkInProgress === returnFiber.child) returnFiber.child = newWorkInProgress;\n else {\n var prevSibling = returnFiber.child;\n if (prevSibling === null) throw new Error('Expected parent to have a child.');\n while(prevSibling.sibling !== oldWorkInProgress){\n prevSibling = prevSibling.sibling;\n if (prevSibling === null) throw new Error('Expected to find the previous sibling.');\n }\n prevSibling.sibling = newWorkInProgress;\n } // Delete the old fiber and place the new one.\n // Since the old fiber is disconnected, we have to schedule it manually.\n var last = returnFiber.lastEffect;\n if (last !== null) {\n last.nextEffect = current;\n returnFiber.lastEffect = current;\n } else returnFiber.firstEffect = returnFiber.lastEffect = current;\n current.nextEffect = null;\n current.flags = Deletion;\n newWorkInProgress.flags |= Placement; // Restart work from the new fiber.\n return newWorkInProgress;\n }\n function beginWork(current, workInProgress, renderLanes) {\n var updateLanes = workInProgress.lanes;\n if (workInProgress._debugNeedsRemount && current !== null) // This will restart the begin phase with a new fiber.\n return remountFiber(current, workInProgress, createFiberFromTypeAndProps(workInProgress.type, workInProgress.key, workInProgress.pendingProps, workInProgress._debugOwner || null, workInProgress.mode, workInProgress.lanes));\n if (current !== null) {\n var oldProps = current.memoizedProps;\n var newProps = workInProgress.pendingProps;\n if (oldProps !== newProps || hasContextChanged() || workInProgress.type !== current.type) // If props or context changed, mark the fiber as having performed work.\n // This may be unset if the props are determined to be equal later (memo).\n didReceiveUpdate = true;\n else if (!includesSomeLane(renderLanes, updateLanes)) {\n didReceiveUpdate = false; // This fiber does not have any pending work. Bailout without entering\n // the begin phase. There's still some bookkeeping we that needs to be done\n // in this optimized path, mostly pushing stuff onto the stack.\n switch(workInProgress.tag){\n case HostRoot:\n pushHostRootContext(workInProgress);\n resetHydrationState();\n break;\n case HostComponent:\n pushHostContext(workInProgress);\n break;\n case ClassComponent:\n var Component = workInProgress.type;\n if (isContextProvider(Component)) pushContextProvider(workInProgress);\n break;\n case HostPortal:\n pushHostContainer(workInProgress, workInProgress.stateNode.containerInfo);\n break;\n case ContextProvider:\n var newValue = workInProgress.memoizedProps.value;\n pushProvider(workInProgress, newValue);\n break;\n case Profiler:\n // Profiler should only call onRender when one of its descendants actually rendered.\n var hasChildWork = includesSomeLane(renderLanes, workInProgress.childLanes);\n if (hasChildWork) workInProgress.flags |= Update;\n // Reset effect durations for the next eventual effect phase.\n // These are reset during render to allow the DevTools commit hook a chance to read them,\n var stateNode = workInProgress.stateNode;\n stateNode.effectDuration = 0;\n stateNode.passiveEffectDuration = 0;\n break;\n case SuspenseComponent:\n var state = workInProgress.memoizedState;\n if (state !== null) {\n // whether to retry the primary children, or to skip over it and\n // go straight to the fallback. Check the priority of the primary\n // child fragment.\n var primaryChildFragment = workInProgress.child;\n var primaryChildLanes = primaryChildFragment.childLanes;\n if (includesSomeLane(renderLanes, primaryChildLanes)) // The primary children have pending work. Use the normal path\n // to attempt to render the primary children again.\n return updateSuspenseComponent(current, workInProgress, renderLanes);\n else {\n // The primary child fragment does not have pending work marked\n // on it\n pushSuspenseContext(workInProgress, setDefaultShallowSuspenseContext(suspenseStackCursor.current)); // The primary children do not have pending work with sufficient\n // priority. Bailout.\n var child = bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes);\n if (child !== null) // The fallback children have pending work. Skip over the\n // primary children and work on the fallback.\n return child.sibling;\n else return null;\n }\n } else pushSuspenseContext(workInProgress, setDefaultShallowSuspenseContext(suspenseStackCursor.current));\n break;\n case SuspenseListComponent:\n var didSuspendBefore = (current.flags & DidCapture) !== NoFlags;\n var _hasChildWork = includesSomeLane(renderLanes, workInProgress.childLanes);\n if (didSuspendBefore) {\n if (_hasChildWork) // If something was in fallback state last time, and we have all the\n // same children then we're still in progressive loading state.\n // Something might get unblocked by state updates or retries in the\n // tree which will affect the tail. So we need to use the normal\n // path to compute the correct tail.\n return updateSuspenseListComponent(current, workInProgress, renderLanes);\n // If none of the children had any work, that means that none of\n // them got retried so they'll still be blocked in the same way\n // as before. We can fast bail out.\n workInProgress.flags |= DidCapture;\n } // If nothing suspended before and we're rendering the same children,\n // then the tail doesn't matter. Anything new that suspends will work\n // in the \"together\" mode, so we can continue from the state we had.\n var renderState = workInProgress.memoizedState;\n if (renderState !== null) {\n // Reset to the \"together\" mode in case we've started a different\n // update in the past but didn't complete it.\n renderState.rendering = null;\n renderState.tail = null;\n renderState.lastEffect = null;\n }\n pushSuspenseContext(workInProgress, suspenseStackCursor.current);\n if (_hasChildWork) break;\n else // If none of the children had any work, that means that none of\n // them got retried so they'll still be blocked in the same way\n // as before. We can fast bail out.\n return null;\n case OffscreenComponent:\n case LegacyHiddenComponent:\n // Need to check if the tree still needs to be deferred. This is\n // almost identical to the logic used in the normal update path,\n // so we'll just enter that. The only difference is we'll bail out\n // at the next level instead of this one, because the child props\n // have not changed. Which is fine.\n // TODO: Probably should refactor `beginWork` to split the bailout\n // path from the normal path. I'm tempted to do a labeled break here\n // but I won't :)\n workInProgress.lanes = NoLanes;\n return updateOffscreenComponent(current, workInProgress, renderLanes);\n }\n return bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes);\n } else if ((current.flags & ForceUpdateForLegacySuspense) !== NoFlags) // This is a special case that only exists for legacy mode.\n // See https://github.com/facebook/react/pull/19216.\n didReceiveUpdate = true;\n else // An update was scheduled on this fiber, but there are no new props\n // nor legacy context. Set this to false. If an update queue or context\n // consumer produces a changed value, it will set this to true. Otherwise,\n // the component will assume the children have not changed and bail out.\n didReceiveUpdate = false;\n } else didReceiveUpdate = false;\n // Before entering the begin phase, clear pending update priority.\n // TODO: This assumes that we're about to evaluate the component and process\n // the update queue. However, there's an exception: SimpleMemoComponent\n // sometimes bails out later in the begin phase. This indicates that we should\n // move this assignment out of the common path and into each branch.\n workInProgress.lanes = NoLanes;\n switch(workInProgress.tag){\n case IndeterminateComponent:\n return mountIndeterminateComponent(current, workInProgress, workInProgress.type, renderLanes);\n case LazyComponent:\n var elementType = workInProgress.elementType;\n return mountLazyComponent(current, workInProgress, elementType, updateLanes, renderLanes);\n case FunctionComponent:\n var _Component = workInProgress.type;\n var unresolvedProps = workInProgress.pendingProps;\n var resolvedProps = workInProgress.elementType === _Component ? unresolvedProps : resolveDefaultProps(_Component, unresolvedProps);\n return updateFunctionComponent(current, workInProgress, _Component, resolvedProps, renderLanes);\n case ClassComponent:\n var _Component2 = workInProgress.type;\n var _unresolvedProps = workInProgress.pendingProps;\n var _resolvedProps = workInProgress.elementType === _Component2 ? _unresolvedProps : resolveDefaultProps(_Component2, _unresolvedProps);\n return updateClassComponent(current, workInProgress, _Component2, _resolvedProps, renderLanes);\n case HostRoot:\n return updateHostRoot(current, workInProgress, renderLanes);\n case HostComponent:\n return updateHostComponent(current, workInProgress, renderLanes);\n case HostText:\n return updateHostText(current, workInProgress);\n case SuspenseComponent:\n return updateSuspenseComponent(current, workInProgress, renderLanes);\n case HostPortal:\n return updatePortalComponent(current, workInProgress, renderLanes);\n case ForwardRef:\n var type = workInProgress.type;\n var _unresolvedProps2 = workInProgress.pendingProps;\n var _resolvedProps2 = workInProgress.elementType === type ? _unresolvedProps2 : resolveDefaultProps(type, _unresolvedProps2);\n return updateForwardRef(current, workInProgress, type, _resolvedProps2, renderLanes);\n case Fragment:\n return updateFragment1(current, workInProgress, renderLanes);\n case Mode:\n return updateMode(current, workInProgress, renderLanes);\n case Profiler:\n return updateProfiler(current, workInProgress, renderLanes);\n case ContextProvider:\n return updateContextProvider(current, workInProgress, renderLanes);\n case ContextConsumer:\n return updateContextConsumer(current, workInProgress, renderLanes);\n case MemoComponent:\n var _type2 = workInProgress.type;\n var _unresolvedProps3 = workInProgress.pendingProps; // Resolve outer props first, then resolve inner props.\n var _resolvedProps3 = resolveDefaultProps(_type2, _unresolvedProps3);\n if (workInProgress.type !== workInProgress.elementType) {\n var outerPropTypes = _type2.propTypes;\n if (outerPropTypes) checkPropTypes(outerPropTypes, _resolvedProps3, 'prop', getComponentName(_type2));\n }\n _resolvedProps3 = resolveDefaultProps(_type2.type, _resolvedProps3);\n return updateMemoComponent(current, workInProgress, _type2, _resolvedProps3, updateLanes, renderLanes);\n case SimpleMemoComponent:\n return updateSimpleMemoComponent(current, workInProgress, workInProgress.type, workInProgress.pendingProps, updateLanes, renderLanes);\n case IncompleteClassComponent:\n var _Component3 = workInProgress.type;\n var _unresolvedProps4 = workInProgress.pendingProps;\n var _resolvedProps4 = workInProgress.elementType === _Component3 ? _unresolvedProps4 : resolveDefaultProps(_Component3, _unresolvedProps4);\n return mountIncompleteClassComponent(current, workInProgress, _Component3, _resolvedProps4, renderLanes);\n case SuspenseListComponent:\n return updateSuspenseListComponent(current, workInProgress, renderLanes);\n case FundamentalComponent:\n break;\n case ScopeComponent:\n break;\n case Block:\n break;\n case OffscreenComponent:\n return updateOffscreenComponent(current, workInProgress, renderLanes);\n case LegacyHiddenComponent:\n return updateLegacyHiddenComponent(current, workInProgress, renderLanes);\n }\n throw Error(\"Unknown unit of work tag (\" + workInProgress.tag + \"). This error is likely caused by a bug in React. Please file an issue.\");\n }\n function markUpdate(workInProgress) {\n // Tag the fiber with an update effect. This turns a Placement into\n // a PlacementAndUpdate.\n workInProgress.flags |= Update;\n }\n function markRef$1(workInProgress) {\n workInProgress.flags |= Ref;\n }\n var appendAllChildren;\n var updateHostContainer;\n var updateHostComponent$1;\n var updateHostText$1;\n // Mutation mode\n appendAllChildren = function(parent, workInProgress, needsVisibilityToggle, isHidden) {\n // We only have the top Fiber that was created but we need recurse down its\n // children to find all the terminal nodes.\n var node = workInProgress.child;\n while(node !== null){\n if (node.tag === HostComponent || node.tag === HostText) appendInitialChild(parent, node.stateNode);\n else if (node.tag === HostPortal) ;\n else if (node.child !== null) {\n node.child.return = node;\n node = node.child;\n continue;\n }\n if (node === workInProgress) return;\n while(node.sibling === null){\n if (node.return === null || node.return === workInProgress) return;\n node = node.return;\n }\n node.sibling.return = node.return;\n node = node.sibling;\n }\n };\n updateHostContainer = function(workInProgress) {\n };\n updateHostComponent$1 = function(current, workInProgress, type, newProps, rootContainerInstance) {\n // If we have an alternate, that means this is an update and we need to\n // schedule a side-effect to do the updates.\n var oldProps = current.memoizedProps;\n if (oldProps === newProps) // In mutation mode, this is sufficient for a bailout because\n // we won't touch this node even if children changed.\n return;\n // If we get updated because one of our children updated, we don't\n // have newProps so we'll have to reuse them.\n // TODO: Split the update API as separate for the props vs. children.\n // Even better would be if children weren't special cased at all tho.\n var instance = workInProgress.stateNode;\n var currentHostContext = getHostContext(); // TODO: Experiencing an error where oldProps is null. Suggests a host\n // component is hitting the resume path. Figure out why. Possibly\n // related to `hidden`.\n var updatePayload = prepareUpdate(instance, type, oldProps, newProps, rootContainerInstance, currentHostContext); // TODO: Type this specific to this type of component.\n workInProgress.updateQueue = updatePayload; // If the update payload indicates that there is a change or if there\n // is a new ref we mark this as an update. All the work is done in commitWork.\n if (updatePayload) markUpdate(workInProgress);\n };\n updateHostText$1 = function(current, workInProgress, oldText, newText) {\n // If the text differs, mark it as an update. All the work in done in commitWork.\n if (oldText !== newText) markUpdate(workInProgress);\n };\n function cutOffTailIfNeeded(renderState, hasRenderedATailFallback) {\n if (getIsHydrating()) // If we're hydrating, we should consume as many items as we can\n // so we don't leave any behind.\n return;\n switch(renderState.tailMode){\n case 'hidden':\n // Any insertions at the end of the tail list after this point\n // should be invisible. If there are already mounted boundaries\n // anything before them are not considered for collapsing.\n // Therefore we need to go through the whole tail to find if\n // there are any.\n var tailNode = renderState.tail;\n var lastTailNode = null;\n while(tailNode !== null){\n if (tailNode.alternate !== null) lastTailNode = tailNode;\n tailNode = tailNode.sibling;\n } // Next we're simply going to delete all insertions after the\n // last rendered item.\n if (lastTailNode === null) // All remaining items in the tail are insertions.\n renderState.tail = null;\n else // Detach the insertion after the last node that was already\n // inserted.\n lastTailNode.sibling = null;\n break;\n case 'collapsed':\n // Any insertions at the end of the tail list after this point\n // should be invisible. If there are already mounted boundaries\n // anything before them are not considered for collapsing.\n // Therefore we need to go through the whole tail to find if\n // there are any.\n var _tailNode = renderState.tail;\n var _lastTailNode = null;\n while(_tailNode !== null){\n if (_tailNode.alternate !== null) _lastTailNode = _tailNode;\n _tailNode = _tailNode.sibling;\n } // Next we're simply going to delete all insertions after the\n // last rendered item.\n if (_lastTailNode === null) {\n // All remaining items in the tail are insertions.\n if (!hasRenderedATailFallback && renderState.tail !== null) // We suspended during the head. We want to show at least one\n // row at the tail. So we'll keep on and cut off the rest.\n renderState.tail.sibling = null;\n else renderState.tail = null;\n } else // Detach the insertion after the last node that was already\n // inserted.\n _lastTailNode.sibling = null;\n break;\n }\n }\n function completeWork(current, workInProgress, renderLanes) {\n var newProps = workInProgress.pendingProps;\n switch(workInProgress.tag){\n case IndeterminateComponent:\n case LazyComponent:\n case SimpleMemoComponent:\n case FunctionComponent:\n case ForwardRef:\n case Fragment:\n case Mode:\n case Profiler:\n case ContextConsumer:\n case MemoComponent:\n return null;\n case ClassComponent:\n var Component = workInProgress.type;\n if (isContextProvider(Component)) popContext(workInProgress);\n return null;\n case HostRoot:\n popHostContainer(workInProgress);\n popTopLevelContextObject(workInProgress);\n resetWorkInProgressVersions();\n var fiberRoot = workInProgress.stateNode;\n if (fiberRoot.pendingContext) {\n fiberRoot.context = fiberRoot.pendingContext;\n fiberRoot.pendingContext = null;\n }\n if (current === null || current.child === null) {\n // If we hydrated, pop so that we can delete any remaining children\n // that weren't hydrated.\n var wasHydrated = popHydrationState(workInProgress);\n if (wasHydrated) // If we hydrated, then we'll need to schedule an update for\n // the commit side-effects on the root.\n markUpdate(workInProgress);\n else if (!fiberRoot.hydrate) // Schedule an effect to clear this container at the start of the next commit.\n // This handles the case of React rendering into a container with previous children.\n // It's also safe to do for updates too, because current.child would only be null\n // if the previous render was null (so the the container would already be empty).\n workInProgress.flags |= Snapshot;\n }\n updateHostContainer(workInProgress);\n return null;\n case HostComponent:\n popHostContext(workInProgress);\n var rootContainerInstance = getRootHostContainer();\n var type = workInProgress.type;\n if (current !== null && workInProgress.stateNode != null) {\n updateHostComponent$1(current, workInProgress, type, newProps, rootContainerInstance);\n if (current.ref !== workInProgress.ref) markRef$1(workInProgress);\n } else {\n if (!newProps) {\n if (!(workInProgress.stateNode !== null)) throw Error(\"We must have new props for new mounts. This error is likely caused by a bug in React. Please file an issue.\");\n // This can happen when we abort work.\n return null;\n }\n var currentHostContext = getHostContext(); // TODO: Move createInstance to beginWork and keep it on a context\n // \"stack\" as the parent. Then append children as we go in beginWork\n // or completeWork depending on whether we want to add them top->down or\n // bottom->up. Top->down is faster in IE11.\n var _wasHydrated = popHydrationState(workInProgress);\n if (_wasHydrated) // TODO: Move this and createInstance step into the beginPhase\n // to consolidate.\n {\n if (prepareToHydrateHostInstance(workInProgress, rootContainerInstance, currentHostContext)) // If changes to the hydrated node need to be applied at the\n // commit-phase we mark this as such.\n markUpdate(workInProgress);\n } else {\n var instance = createInstance(type, newProps, rootContainerInstance, currentHostContext, workInProgress);\n appendAllChildren(instance, workInProgress, false, false);\n workInProgress.stateNode = instance; // Certain renderers require commit-time effects for initial mount.\n // (eg DOM renderer supports auto-focus for certain elements).\n // Make sure such renderers get scheduled for later work.\n if (finalizeInitialChildren(instance, type, newProps, rootContainerInstance)) markUpdate(workInProgress);\n }\n if (workInProgress.ref !== null) // If there is a ref on a host node we need to schedule a callback\n markRef$1(workInProgress);\n }\n return null;\n case HostText:\n var newText = newProps;\n if (current && workInProgress.stateNode != null) {\n var oldText = current.memoizedProps; // If we have an alternate, that means this is an update and we need\n // to schedule a side-effect to do the updates.\n updateHostText$1(current, workInProgress, oldText, newText);\n } else {\n if (typeof newText !== 'string') {\n if (!(workInProgress.stateNode !== null)) throw Error(\"We must have new props for new mounts. This error is likely caused by a bug in React. Please file an issue.\");\n // This can happen when we abort work.\n }\n var _rootContainerInstance = getRootHostContainer();\n var _currentHostContext = getHostContext();\n var _wasHydrated2 = popHydrationState(workInProgress);\n if (_wasHydrated2) {\n if (prepareToHydrateHostTextInstance(workInProgress)) markUpdate(workInProgress);\n } else workInProgress.stateNode = createTextInstance(newText, _rootContainerInstance, _currentHostContext, workInProgress);\n }\n return null;\n case SuspenseComponent:\n popSuspenseContext(workInProgress);\n var nextState = workInProgress.memoizedState;\n if ((workInProgress.flags & DidCapture) !== NoFlags) {\n // Something suspended. Re-render with the fallback children.\n workInProgress.lanes = renderLanes; // Do not reset the effect list.\n if ((workInProgress.mode & ProfileMode) !== NoMode) transferActualDuration(workInProgress);\n return workInProgress;\n }\n var nextDidTimeout = nextState !== null;\n var prevDidTimeout = false;\n if (current === null) {\n if (workInProgress.memoizedProps.fallback !== undefined) popHydrationState(workInProgress);\n } else {\n var prevState = current.memoizedState;\n prevDidTimeout = prevState !== null;\n }\n if (nextDidTimeout && !prevDidTimeout) // If this subtreee is running in blocking mode we can suspend,\n // otherwise we won't suspend.\n // TODO: This will still suspend a synchronous tree if anything\n // in the concurrent tree already suspended during this render.\n // This is a known bug.\n {\n if ((workInProgress.mode & BlockingMode) !== NoMode) {\n // TODO: Move this back to throwException because this is too late\n // if this is a large tree which is common for initial loads. We\n // don't know if we should restart a render or not until we get\n // this marker, and this is too late.\n // If this render already had a ping or lower pri updates,\n // and this is the first time we know we're going to suspend we\n // should be able to immediately restart from within throwException.\n var hasInvisibleChildContext = current === null && workInProgress.memoizedProps.unstable_avoidThisFallback !== true;\n if (hasInvisibleChildContext || hasSuspenseContext(suspenseStackCursor.current, InvisibleParentSuspenseContext)) // If this was in an invisible tree or a new render, then showing\n // this boundary is ok.\n renderDidSuspend();\n else // Otherwise, we're going to have to hide content so we should\n // suspend for longer if possible.\n renderDidSuspendDelayIfPossible();\n }\n }\n // TODO: Only schedule updates if these values are non equal, i.e. it changed.\n if (nextDidTimeout || prevDidTimeout) // If this boundary just timed out, schedule an effect to attach a\n // retry listener to the promise. This flag is also used to hide the\n // primary children. In mutation mode, we also need the flag to\n // *unhide* children that were previously hidden, so check if this\n // is currently timed out, too.\n workInProgress.flags |= Update;\n return null;\n case HostPortal:\n popHostContainer(workInProgress);\n updateHostContainer(workInProgress);\n if (current === null) preparePortalMount(workInProgress.stateNode.containerInfo);\n return null;\n case ContextProvider:\n // Pop provider fiber\n popProvider(workInProgress);\n return null;\n case IncompleteClassComponent:\n // Same as class component case. I put it down here so that the tags are\n // sequential to ensure this switch is compiled to a jump table.\n var _Component = workInProgress.type;\n if (isContextProvider(_Component)) popContext(workInProgress);\n return null;\n case SuspenseListComponent:\n popSuspenseContext(workInProgress);\n var renderState = workInProgress.memoizedState;\n if (renderState === null) // We're running in the default, \"independent\" mode.\n // We don't do anything in this mode.\n return null;\n var didSuspendAlready = (workInProgress.flags & DidCapture) !== NoFlags;\n var renderedTail = renderState.rendering;\n if (renderedTail === null) {\n // We just rendered the head.\n if (!didSuspendAlready) {\n // This is the first pass. We need to figure out if anything is still\n // suspended in the rendered set.\n // If new content unsuspended, but there's still some content that\n // didn't. Then we need to do a second pass that forces everything\n // to keep showing their fallbacks.\n // We might be suspended if something in this render pass suspended, or\n // something in the previous committed pass suspended. Otherwise,\n // there's no chance so we can skip the expensive call to\n // findFirstSuspended.\n var cannotBeSuspended = renderHasNotSuspendedYet() && (current === null || (current.flags & DidCapture) === NoFlags);\n if (!cannotBeSuspended) {\n var row = workInProgress.child;\n while(row !== null){\n var suspended = findFirstSuspended(row);\n if (suspended !== null) {\n didSuspendAlready = true;\n workInProgress.flags |= DidCapture;\n cutOffTailIfNeeded(renderState, false); // If this is a newly suspended tree, it might not get committed as\n // part of the second pass. In that case nothing will subscribe to\n // its thennables. Instead, we'll transfer its thennables to the\n // SuspenseList so that it can retry if they resolve.\n // There might be multiple of these in the list but since we're\n // going to wait for all of them anyway, it doesn't really matter\n // which ones gets to ping. In theory we could get clever and keep\n // track of how many dependencies remain but it gets tricky because\n // in the meantime, we can add/remove/change items and dependencies.\n // We might bail out of the loop before finding any but that\n // doesn't matter since that means that the other boundaries that\n // we did find already has their listeners attached.\n var newThennables = suspended.updateQueue;\n if (newThennables !== null) {\n workInProgress.updateQueue = newThennables;\n workInProgress.flags |= Update;\n } // Rerender the whole list, but this time, we'll force fallbacks\n // to stay in place.\n // Reset the effect list before doing the second pass since that's now invalid.\n if (renderState.lastEffect === null) workInProgress.firstEffect = null;\n workInProgress.lastEffect = renderState.lastEffect; // Reset the child fibers to their original state.\n resetChildFibers(workInProgress, renderLanes); // Set up the Suspense Context to force suspense and immediately\n // rerender the children.\n pushSuspenseContext(workInProgress, setShallowSuspenseContext(suspenseStackCursor.current, ForceSuspenseFallback));\n return workInProgress.child;\n }\n row = row.sibling;\n }\n }\n if (renderState.tail !== null && now() > getRenderTargetTime()) {\n // We have already passed our CPU deadline but we still have rows\n // left in the tail. We'll just give up further attempts to render\n // the main content and only render fallbacks.\n workInProgress.flags |= DidCapture;\n didSuspendAlready = true;\n cutOffTailIfNeeded(renderState, false); // Since nothing actually suspended, there will nothing to ping this\n // to get it started back up to attempt the next item. While in terms\n // of priority this work has the same priority as this current render,\n // it's not part of the same transition once the transition has\n // committed. If it's sync, we still want to yield so that it can be\n // painted. Conceptually, this is really the same as pinging.\n // We can use any RetryLane even if it's the one currently rendering\n // since we're leaving it behind on this node.\n workInProgress.lanes = SomeRetryLane;\n markSpawnedWork(SomeRetryLane);\n }\n } else cutOffTailIfNeeded(renderState, false);\n // Next we're going to render the tail.\n } else {\n // Append the rendered row to the child list.\n if (!didSuspendAlready) {\n var _suspended = findFirstSuspended(renderedTail);\n if (_suspended !== null) {\n workInProgress.flags |= DidCapture;\n didSuspendAlready = true; // Ensure we transfer the update queue to the parent so that it doesn't\n // get lost if this row ends up dropped during a second pass.\n var _newThennables = _suspended.updateQueue;\n if (_newThennables !== null) {\n workInProgress.updateQueue = _newThennables;\n workInProgress.flags |= Update;\n }\n cutOffTailIfNeeded(renderState, true); // This might have been modified.\n if (renderState.tail === null && renderState.tailMode === 'hidden' && !renderedTail.alternate && !getIsHydrating() // We don't cut it if we're hydrating.\n ) {\n // We need to delete the row we just rendered.\n // Reset the effect list to what it was before we rendered this\n // child. The nested children have already appended themselves.\n var lastEffect = workInProgress.lastEffect = renderState.lastEffect; // Remove any effects that were appended after this point.\n if (lastEffect !== null) lastEffect.nextEffect = null;\n // We're done.\n return null;\n }\n } else if (// time we have to render. So rendering one more row would likely\n // exceed it.\n now() * 2 - renderState.renderingStartTime > getRenderTargetTime() && renderLanes !== OffscreenLane) {\n // We have now passed our CPU deadline and we'll just give up further\n // attempts to render the main content and only render fallbacks.\n // The assumption is that this is usually faster.\n workInProgress.flags |= DidCapture;\n didSuspendAlready = true;\n cutOffTailIfNeeded(renderState, false); // Since nothing actually suspended, there will nothing to ping this\n // to get it started back up to attempt the next item. While in terms\n // of priority this work has the same priority as this current render,\n // it's not part of the same transition once the transition has\n // committed. If it's sync, we still want to yield so that it can be\n // painted. Conceptually, this is really the same as pinging.\n // We can use any RetryLane even if it's the one currently rendering\n // since we're leaving it behind on this node.\n workInProgress.lanes = SomeRetryLane;\n markSpawnedWork(SomeRetryLane);\n }\n }\n if (renderState.isBackwards) {\n // The effect list of the backwards tail will have been added\n // to the end. This breaks the guarantee that life-cycles fire in\n // sibling order but that isn't a strong guarantee promised by React.\n // Especially since these might also just pop in during future commits.\n // Append to the beginning of the list.\n renderedTail.sibling = workInProgress.child;\n workInProgress.child = renderedTail;\n } else {\n var previousSibling = renderState.last;\n if (previousSibling !== null) previousSibling.sibling = renderedTail;\n else workInProgress.child = renderedTail;\n renderState.last = renderedTail;\n }\n }\n if (renderState.tail !== null) {\n // We still have tail rows to render.\n // Pop a row.\n var next = renderState.tail;\n renderState.rendering = next;\n renderState.tail = next.sibling;\n renderState.lastEffect = workInProgress.lastEffect;\n renderState.renderingStartTime = now();\n next.sibling = null; // Restore the context.\n // TODO: We can probably just avoid popping it instead and only\n // setting it the first time we go from not suspended to suspended.\n var suspenseContext = suspenseStackCursor.current;\n if (didSuspendAlready) suspenseContext = setShallowSuspenseContext(suspenseContext, ForceSuspenseFallback);\n else suspenseContext = setDefaultShallowSuspenseContext(suspenseContext);\n pushSuspenseContext(workInProgress, suspenseContext); // Do a pass over the next row.\n return next;\n }\n return null;\n case FundamentalComponent:\n break;\n case ScopeComponent:\n break;\n case Block:\n break;\n case OffscreenComponent:\n case LegacyHiddenComponent:\n popRenderLanes(workInProgress);\n if (current !== null) {\n var _nextState = workInProgress.memoizedState;\n var _prevState = current.memoizedState;\n var prevIsHidden = _prevState !== null;\n var nextIsHidden = _nextState !== null;\n if (prevIsHidden !== nextIsHidden && newProps.mode !== 'unstable-defer-without-hiding') workInProgress.flags |= Update;\n }\n return null;\n }\n throw Error(\"Unknown unit of work tag (\" + workInProgress.tag + \"). This error is likely caused by a bug in React. Please file an issue.\");\n }\n function unwindWork(workInProgress, renderLanes) {\n switch(workInProgress.tag){\n case ClassComponent:\n var Component = workInProgress.type;\n if (isContextProvider(Component)) popContext(workInProgress);\n var flags = workInProgress.flags;\n if (flags & ShouldCapture) {\n workInProgress.flags = flags & ~ShouldCapture | DidCapture;\n if ((workInProgress.mode & ProfileMode) !== NoMode) transferActualDuration(workInProgress);\n return workInProgress;\n }\n return null;\n case HostRoot:\n popHostContainer(workInProgress);\n popTopLevelContextObject(workInProgress);\n resetWorkInProgressVersions();\n var _flags = workInProgress.flags;\n if (!((_flags & DidCapture) === NoFlags)) throw Error(\"The root failed to unmount after an error. This is likely a bug in React. Please file an issue.\");\n workInProgress.flags = _flags & ~ShouldCapture | DidCapture;\n return workInProgress;\n case HostComponent:\n // TODO: popHydrationState\n popHostContext(workInProgress);\n return null;\n case SuspenseComponent:\n popSuspenseContext(workInProgress);\n var _flags2 = workInProgress.flags;\n if (_flags2 & ShouldCapture) {\n workInProgress.flags = _flags2 & ~ShouldCapture | DidCapture; // Captured a suspense effect. Re-render the boundary.\n if ((workInProgress.mode & ProfileMode) !== NoMode) transferActualDuration(workInProgress);\n return workInProgress;\n }\n return null;\n case SuspenseListComponent:\n popSuspenseContext(workInProgress); // SuspenseList doesn't actually catch anything. It should've been\n // caught by a nested boundary. If not, it should bubble through.\n return null;\n case HostPortal:\n popHostContainer(workInProgress);\n return null;\n case ContextProvider:\n popProvider(workInProgress);\n return null;\n case OffscreenComponent:\n case LegacyHiddenComponent:\n popRenderLanes(workInProgress);\n return null;\n default:\n return null;\n }\n }\n function unwindInterruptedWork(interruptedWork) {\n switch(interruptedWork.tag){\n case ClassComponent:\n var childContextTypes = interruptedWork.type.childContextTypes;\n if (childContextTypes !== null && childContextTypes !== undefined) popContext(interruptedWork);\n break;\n case HostRoot:\n popHostContainer(interruptedWork);\n popTopLevelContextObject(interruptedWork);\n resetWorkInProgressVersions();\n break;\n case HostComponent:\n popHostContext(interruptedWork);\n break;\n case HostPortal:\n popHostContainer(interruptedWork);\n break;\n case SuspenseComponent:\n popSuspenseContext(interruptedWork);\n break;\n case SuspenseListComponent:\n popSuspenseContext(interruptedWork);\n break;\n case ContextProvider:\n popProvider(interruptedWork);\n break;\n case OffscreenComponent:\n case LegacyHiddenComponent:\n popRenderLanes(interruptedWork);\n break;\n }\n }\n function createCapturedValue(value, source) {\n // If the value is an error, call this function immediately after it is thrown\n // so the stack is accurate.\n return {\n value: value,\n source: source,\n stack: getStackByFiberInDevAndProd(source)\n };\n }\n // This module is forked in different environments.\n // By default, return `true` to log errors to the console.\n // Forks can return `false` if this isn't desirable.\n function showErrorDialog(boundary, errorInfo) {\n return true;\n }\n function logCapturedError(boundary, errorInfo) {\n try {\n var logError = showErrorDialog(boundary, errorInfo); // Allow injected showErrorDialog() to prevent default console.error logging.\n // This enables renderers like ReactNative to better manage redbox behavior.\n if (logError === false) return;\n var error = errorInfo.value;\n var source = errorInfo.source;\n var stack = errorInfo.stack;\n var componentStack = stack !== null ? stack : ''; // Browsers support silencing uncaught errors by calling\n // `preventDefault()` in window `error` handler.\n // We record this information as an expando on the error.\n if (error != null && error._suppressLogging) {\n if (boundary.tag === ClassComponent) // The error is recoverable and was silenced.\n // Ignore it and don't print the stack addendum.\n // This is handy for testing error boundaries without noise.\n return;\n // The error is fatal. Since the silencing might have\n // been accidental, we'll surface it anyway.\n // However, the browser would have silenced the original error\n // so we'll print it first, and then print the stack addendum.\n console['error'](error); // Don't transform to our wrapper\n // For a more detailed description of this block, see:\n // https://github.com/facebook/react/pull/13384\n }\n var componentName = source ? getComponentName(source.type) : null;\n var componentNameMessage = componentName ? \"The above error occurred in the <\" + componentName + \"> component:\" : 'The above error occurred in one of your React components:';\n var errorBoundaryMessage;\n var errorBoundaryName = getComponentName(boundary.type);\n if (errorBoundaryName) errorBoundaryMessage = \"React will try to recreate this component tree from scratch \" + (\"using the error boundary you provided, \" + errorBoundaryName + \".\");\n else errorBoundaryMessage = \"Consider adding an error boundary to your tree to customize error handling behavior.\\nVisit https://reactjs.org/link/error-boundaries to learn more about error boundaries.\";\n var combinedMessage = componentNameMessage + \"\\n\" + componentStack + \"\\n\\n\" + (\"\" + errorBoundaryMessage); // In development, we provide our own message with just the component stack.\n // We don't include the original error message and JS stack because the browser\n // has already printed it. Even if the application swallows the error, it is still\n // displayed by the browser thanks to the DEV-only fake event trick in ReactErrorUtils.\n console['error'](combinedMessage); // Don't transform to our wrapper\n } catch (e) {\n // This method must not throw, or React internal state will get messed up.\n // If console.error is overridden, or logCapturedError() shows a dialog that throws,\n // we want to report this error outside of the normal stack as a last resort.\n // https://github.com/facebook/react/issues/13188\n setTimeout(function() {\n throw e;\n });\n }\n }\n var PossiblyWeakMap$1 = typeof WeakMap === 'function' ? WeakMap : Map;\n function createRootErrorUpdate(fiber, errorInfo, lane) {\n var update = createUpdate(NoTimestamp, lane); // Unmount the root by rendering null.\n update.tag = CaptureUpdate; // Caution: React DevTools currently depends on this property\n // being called \"element\".\n update.payload = {\n element: null\n };\n var error = errorInfo.value;\n update.callback = function() {\n onUncaughtError(error);\n logCapturedError(fiber, errorInfo);\n };\n return update;\n }\n function createClassErrorUpdate(fiber, errorInfo, lane) {\n var update = createUpdate(NoTimestamp, lane);\n update.tag = CaptureUpdate;\n var getDerivedStateFromError = fiber.type.getDerivedStateFromError;\n if (typeof getDerivedStateFromError === 'function') {\n var error$1 = errorInfo.value;\n update.payload = function() {\n logCapturedError(fiber, errorInfo);\n return getDerivedStateFromError(error$1);\n };\n }\n var inst = fiber.stateNode;\n if (inst !== null && typeof inst.componentDidCatch === 'function') update.callback = function callback() {\n markFailedErrorBoundaryForHotReloading(fiber);\n if (typeof getDerivedStateFromError !== 'function') {\n // To preserve the preexisting retry behavior of error boundaries,\n // we keep track of which ones already failed during this batch.\n // This gets reset before we yield back to the browser.\n // TODO: Warn in strict mode if getDerivedStateFromError is\n // not defined.\n markLegacyErrorBoundaryAsFailed(this); // Only log here if componentDidCatch is the only error boundary method defined\n logCapturedError(fiber, errorInfo);\n }\n var error$1 = errorInfo.value;\n var stack = errorInfo.stack;\n this.componentDidCatch(error$1, {\n componentStack: stack !== null ? stack : ''\n });\n if (typeof getDerivedStateFromError !== 'function') // If componentDidCatch is the only error boundary method defined,\n // then it needs to call setState to recover from errors.\n // If no state update is scheduled then the boundary will swallow the error.\n {\n if (!includesSomeLane(fiber.lanes, SyncLane)) error1(\"%s: Error boundaries should implement getDerivedStateFromError(). In that method, return a state update to display an error message or fallback UI.\", getComponentName(fiber.type) || 'Unknown');\n }\n };\n else update.callback = function() {\n markFailedErrorBoundaryForHotReloading(fiber);\n };\n return update;\n }\n function attachPingListener(root, wakeable, lanes) {\n // Attach a listener to the promise to \"ping\" the root and retry. But only if\n // one does not already exist for the lanes we're currently rendering (which\n // acts like a \"thread ID\" here).\n var pingCache = root.pingCache;\n var threadIDs;\n if (pingCache === null) {\n pingCache = root.pingCache = new PossiblyWeakMap$1();\n threadIDs = new Set();\n pingCache.set(wakeable, threadIDs);\n } else {\n threadIDs = pingCache.get(wakeable);\n if (threadIDs === undefined) {\n threadIDs = new Set();\n pingCache.set(wakeable, threadIDs);\n }\n }\n if (!threadIDs.has(lanes)) {\n // Memoize using the thread ID to prevent redundant listeners.\n threadIDs.add(lanes);\n var ping = pingSuspendedRoot.bind(null, root, wakeable, lanes);\n wakeable.then(ping, ping);\n }\n }\n function throwException(root, returnFiber, sourceFiber, value, rootRenderLanes) {\n // The source fiber did not complete.\n sourceFiber.flags |= Incomplete; // Its effect list is no longer valid.\n sourceFiber.firstEffect = sourceFiber.lastEffect = null;\n if (value !== null && typeof value === 'object' && typeof value.then === 'function') {\n // This is a wakeable.\n var wakeable = value;\n if ((sourceFiber.mode & BlockingMode) === NoMode) {\n // Reset the memoizedState to what it was before we attempted\n // to render it.\n var currentSource = sourceFiber.alternate;\n if (currentSource) {\n sourceFiber.updateQueue = currentSource.updateQueue;\n sourceFiber.memoizedState = currentSource.memoizedState;\n sourceFiber.lanes = currentSource.lanes;\n } else {\n sourceFiber.updateQueue = null;\n sourceFiber.memoizedState = null;\n }\n }\n var hasInvisibleParentBoundary = hasSuspenseContext(suspenseStackCursor.current, InvisibleParentSuspenseContext); // Schedule the nearest Suspense to re-render the timed out view.\n var _workInProgress = returnFiber;\n do {\n if (_workInProgress.tag === SuspenseComponent && shouldCaptureSuspense(_workInProgress, hasInvisibleParentBoundary)) {\n // Found the nearest boundary.\n // Stash the promise on the boundary fiber. If the boundary times out, we'll\n // attach another listener to flip the boundary back to its normal state.\n var wakeables = _workInProgress.updateQueue;\n if (wakeables === null) {\n var updateQueue = new Set();\n updateQueue.add(wakeable);\n _workInProgress.updateQueue = updateQueue;\n } else wakeables.add(wakeable);\n // If the boundary is outside of blocking mode, we should *not*\n // suspend the commit. Pretend as if the suspended component rendered\n // null and keep rendering. In the commit phase, we'll schedule a\n // subsequent synchronous update to re-render the Suspense.\n //\n // Note: It doesn't matter whether the component that suspended was\n // inside a blocking mode tree. If the Suspense is outside of it, we\n // should *not* suspend the commit.\n if ((_workInProgress.mode & BlockingMode) === NoMode) {\n _workInProgress.flags |= DidCapture;\n sourceFiber.flags |= ForceUpdateForLegacySuspense; // We're going to commit this fiber even though it didn't complete.\n // But we shouldn't call any lifecycle methods or callbacks. Remove\n // all lifecycle effect tags.\n sourceFiber.flags &= ~(LifecycleEffectMask | Incomplete);\n if (sourceFiber.tag === ClassComponent) {\n var currentSourceFiber = sourceFiber.alternate;\n if (currentSourceFiber === null) // This is a new mount. Change the tag so it's not mistaken for a\n // completed class component. For example, we should not call\n // componentWillUnmount if it is deleted.\n sourceFiber.tag = IncompleteClassComponent;\n else {\n // When we try rendering again, we should not reuse the current fiber,\n // since it's known to be in an inconsistent state. Use a force update to\n // prevent a bail out.\n var update = createUpdate(NoTimestamp, SyncLane);\n update.tag = ForceUpdate;\n enqueueUpdate(sourceFiber, update);\n }\n } // The source fiber did not complete. Mark it with Sync priority to\n // indicate that it still has pending work.\n sourceFiber.lanes = mergeLanes(sourceFiber.lanes, SyncLane); // Exit without suspending.\n return;\n } // Confirmed that the boundary is in a concurrent mode tree. Continue\n // with the normal suspend path.\n //\n // After this we'll use a set of heuristics to determine whether this\n // render pass will run to completion or restart or \"suspend\" the commit.\n // The actual logic for this is spread out in different places.\n //\n // This first principle is that if we're going to suspend when we complete\n // a root, then we should also restart if we get an update or ping that\n // might unsuspend it, and vice versa. The only reason to suspend is\n // because you think you might want to restart before committing. However,\n // it doesn't make sense to restart only while in the period we're suspended.\n //\n // Restarting too aggressively is also not good because it starves out any\n // intermediate loading state. So we use heuristics to determine when.\n // Suspense Heuristics\n //\n // If nothing threw a Promise or all the same fallbacks are already showing,\n // then don't suspend/restart.\n //\n // If this is an initial render of a new tree of Suspense boundaries and\n // those trigger a fallback, then don't suspend/restart. We want to ensure\n // that we can show the initial loading state as quickly as possible.\n //\n // If we hit a \"Delayed\" case, such as when we'd switch from content back into\n // a fallback, then we should always suspend/restart. Transitions apply\n // to this case. If none is defined, JND is used instead.\n //\n // If we're already showing a fallback and it gets \"retried\", allowing us to show\n // another level, but there's still an inner boundary that would show a fallback,\n // then we suspend/restart for 500ms since the last time we showed a fallback\n // anywhere in the tree. This effectively throttles progressive loading into a\n // consistent train of commits. This also gives us an opportunity to restart to\n // get to the completed state slightly earlier.\n //\n // If there's ambiguity due to batching it's resolved in preference of:\n // 1) \"delayed\", 2) \"initial render\", 3) \"retry\".\n //\n // We want to ensure that a \"busy\" state doesn't get force committed. We want to\n // ensure that new initial loading states can commit as soon as possible.\n attachPingListener(root, wakeable, rootRenderLanes);\n _workInProgress.flags |= ShouldCapture;\n _workInProgress.lanes = rootRenderLanes;\n return;\n } // This boundary already captured during this render. Continue to the next\n // boundary.\n _workInProgress = _workInProgress.return;\n }while (_workInProgress !== null) // No boundary was found. Fallthrough to error mode.\n // TODO: Use invariant so the message is stripped in prod?\n value = new Error((getComponentName(sourceFiber.type) || 'A React component') + ' suspended while rendering, but no fallback UI was specified.\\n' + '\\n' + 'Add a <Suspense fallback=...> component higher in the tree to ' + 'provide a loading indicator or placeholder to display.');\n } // We didn't find a boundary that could handle this type of exception. Start\n // over and traverse parent path again, this time treating the exception\n // as an error.\n renderDidError();\n value = createCapturedValue(value, sourceFiber);\n var workInProgress = returnFiber;\n do {\n switch(workInProgress.tag){\n case HostRoot:\n var _errorInfo = value;\n workInProgress.flags |= ShouldCapture;\n var lane = pickArbitraryLane(rootRenderLanes);\n workInProgress.lanes = mergeLanes(workInProgress.lanes, lane);\n var _update = createRootErrorUpdate(workInProgress, _errorInfo, lane);\n enqueueCapturedUpdate(workInProgress, _update);\n return;\n case ClassComponent:\n // Capture and retry\n var errorInfo = value;\n var ctor = workInProgress.type;\n var instance = workInProgress.stateNode;\n if ((workInProgress.flags & DidCapture) === NoFlags && (typeof ctor.getDerivedStateFromError === 'function' || instance !== null && typeof instance.componentDidCatch === 'function' && !isAlreadyFailedLegacyErrorBoundary(instance))) {\n workInProgress.flags |= ShouldCapture;\n var _lane = pickArbitraryLane(rootRenderLanes);\n workInProgress.lanes = mergeLanes(workInProgress.lanes, _lane); // Schedule the error boundary to re-render using updated state\n var _update2 = createClassErrorUpdate(workInProgress, errorInfo, _lane);\n enqueueCapturedUpdate(workInProgress, _update2);\n return;\n }\n break;\n }\n workInProgress = workInProgress.return;\n }while (workInProgress !== null)\n }\n var didWarnAboutUndefinedSnapshotBeforeUpdate = null;\n didWarnAboutUndefinedSnapshotBeforeUpdate = new Set();\n var PossiblyWeakSet = typeof WeakSet === 'function' ? WeakSet : Set;\n var callComponentWillUnmountWithTimer = function(current, instance) {\n instance.props = current.memoizedProps;\n instance.state = current.memoizedState;\n instance.componentWillUnmount();\n }; // Capture errors so they don't interrupt unmounting.\n function safelyCallComponentWillUnmount(current, instance) {\n invokeGuardedCallback(null, callComponentWillUnmountWithTimer, null, current, instance);\n if (hasCaughtError()) {\n var unmountError = clearCaughtError();\n captureCommitPhaseError(current, unmountError);\n }\n }\n function safelyDetachRef(current) {\n var ref = current.ref;\n if (ref !== null) {\n if (typeof ref === 'function') {\n invokeGuardedCallback(null, ref, null, null);\n if (hasCaughtError()) {\n var refError = clearCaughtError();\n captureCommitPhaseError(current, refError);\n }\n } else ref.current = null;\n }\n }\n function safelyCallDestroy(current, destroy) {\n invokeGuardedCallback(null, destroy, null);\n if (hasCaughtError()) {\n var error = clearCaughtError();\n captureCommitPhaseError(current, error);\n }\n }\n function commitBeforeMutationLifeCycles(current, finishedWork) {\n switch(finishedWork.tag){\n case FunctionComponent:\n case ForwardRef:\n case SimpleMemoComponent:\n case Block:\n return;\n case ClassComponent:\n if (finishedWork.flags & Snapshot) {\n if (current !== null) {\n var prevProps = current.memoizedProps;\n var prevState = current.memoizedState;\n var instance = finishedWork.stateNode; // We could update instance props and state here,\n if (finishedWork.type === finishedWork.elementType && !didWarnAboutReassigningProps) {\n if (instance.props !== finishedWork.memoizedProps) error1(\"Expected %s props to match memoized props before getSnapshotBeforeUpdate. This might either be because of a bug in React, or because a component reassigns its own `this.props`. Please file an issue.\", getComponentName(finishedWork.type) || 'instance');\n if (instance.state !== finishedWork.memoizedState) error1(\"Expected %s state to match memoized state before getSnapshotBeforeUpdate. This might either be because of a bug in React, or because a component reassigns its own `this.state`. Please file an issue.\", getComponentName(finishedWork.type) || 'instance');\n }\n var snapshot = instance.getSnapshotBeforeUpdate(finishedWork.elementType === finishedWork.type ? prevProps : resolveDefaultProps(finishedWork.type, prevProps), prevState);\n var didWarnSet = didWarnAboutUndefinedSnapshotBeforeUpdate;\n if (snapshot === undefined && !didWarnSet.has(finishedWork.type)) {\n didWarnSet.add(finishedWork.type);\n error1(\"%s.getSnapshotBeforeUpdate(): A snapshot value (or null) must be returned. You have returned undefined.\", getComponentName(finishedWork.type));\n }\n instance.__reactInternalSnapshotBeforeUpdate = snapshot;\n }\n }\n return;\n case HostRoot:\n if (finishedWork.flags & Snapshot) {\n var root = finishedWork.stateNode;\n clearContainer(root.containerInfo);\n }\n return;\n case HostComponent:\n case HostText:\n case HostPortal:\n case IncompleteClassComponent:\n // Nothing to do for these component types\n return;\n }\n throw Error(\"This unit of work tag should not have side-effects. This error is likely caused by a bug in React. Please file an issue.\");\n }\n function commitHookEffectListUnmount(tag, finishedWork) {\n var updateQueue = finishedWork.updateQueue;\n var lastEffect = updateQueue !== null ? updateQueue.lastEffect : null;\n if (lastEffect !== null) {\n var firstEffect = lastEffect.next;\n var effect = firstEffect;\n do {\n if ((effect.tag & tag) === tag) {\n // Unmount\n var destroy = effect.destroy;\n effect.destroy = undefined;\n if (destroy !== undefined) destroy();\n }\n effect = effect.next;\n }while (effect !== firstEffect)\n }\n }\n function commitHookEffectListMount(tag, finishedWork) {\n var updateQueue = finishedWork.updateQueue;\n var lastEffect = updateQueue !== null ? updateQueue.lastEffect : null;\n if (lastEffect !== null) {\n var firstEffect = lastEffect.next;\n var effect = firstEffect;\n do {\n if ((effect.tag & tag) === tag) {\n // Mount\n var create = effect.create;\n effect.destroy = create();\n var destroy = effect.destroy;\n if (destroy !== undefined && typeof destroy !== 'function') {\n var addendum = void 0;\n if (destroy === null) addendum = \" You returned null. If your effect does not require clean up, return undefined (or nothing).\";\n else if (typeof destroy.then === 'function') addendum = \"\\n\\nIt looks like you wrote useEffect(async () => ...) or returned a Promise. Instead, write the async function inside your effect and call it immediately:\\n\\nuseEffect(() => {\\n async function fetchData() {\\n // You can await here\\n const response = await MyAPI.getData(someId);\\n // ...\\n }\\n fetchData();\\n}, [someId]); // Or [] if effect doesn't need props or state\\n\\nLearn more about data fetching with Hooks: https://reactjs.org/link/hooks-data-fetching\";\n else addendum = ' You returned: ' + destroy;\n error1(\"An effect function must not return anything besides a function, which is used for clean-up.%s\", addendum);\n }\n }\n effect = effect.next;\n }while (effect !== firstEffect)\n }\n }\n function schedulePassiveEffects(finishedWork) {\n var updateQueue = finishedWork.updateQueue;\n var lastEffect = updateQueue !== null ? updateQueue.lastEffect : null;\n if (lastEffect !== null) {\n var firstEffect = lastEffect.next;\n var effect = firstEffect;\n do {\n var _effect = effect, next = _effect.next, tag = _effect.tag;\n if ((tag & Passive$1) !== NoFlags$1 && (tag & HasEffect) !== NoFlags$1) {\n enqueuePendingPassiveHookEffectUnmount(finishedWork, effect);\n enqueuePendingPassiveHookEffectMount(finishedWork, effect);\n }\n effect = next;\n }while (effect !== firstEffect)\n }\n }\n function commitLifeCycles(finishedRoot, current, finishedWork, committedLanes) {\n switch(finishedWork.tag){\n case FunctionComponent:\n case ForwardRef:\n case SimpleMemoComponent:\n case Block:\n commitHookEffectListMount(Layout | HasEffect, finishedWork);\n schedulePassiveEffects(finishedWork);\n return;\n case ClassComponent:\n var instance = finishedWork.stateNode;\n if (finishedWork.flags & Update) {\n if (current === null) {\n if (finishedWork.type === finishedWork.elementType && !didWarnAboutReassigningProps) {\n if (instance.props !== finishedWork.memoizedProps) error1(\"Expected %s props to match memoized props before componentDidMount. This might either be because of a bug in React, or because a component reassigns its own `this.props`. Please file an issue.\", getComponentName(finishedWork.type) || 'instance');\n if (instance.state !== finishedWork.memoizedState) error1(\"Expected %s state to match memoized state before componentDidMount. This might either be because of a bug in React, or because a component reassigns its own `this.state`. Please file an issue.\", getComponentName(finishedWork.type) || 'instance');\n }\n instance.componentDidMount();\n } else {\n var prevProps = finishedWork.elementType === finishedWork.type ? current.memoizedProps : resolveDefaultProps(finishedWork.type, current.memoizedProps);\n var prevState = current.memoizedState; // We could update instance props and state here,\n if (finishedWork.type === finishedWork.elementType && !didWarnAboutReassigningProps) {\n if (instance.props !== finishedWork.memoizedProps) error1(\"Expected %s props to match memoized props before componentDidUpdate. This might either be because of a bug in React, or because a component reassigns its own `this.props`. Please file an issue.\", getComponentName(finishedWork.type) || 'instance');\n if (instance.state !== finishedWork.memoizedState) error1(\"Expected %s state to match memoized state before componentDidUpdate. This might either be because of a bug in React, or because a component reassigns its own `this.state`. Please file an issue.\", getComponentName(finishedWork.type) || 'instance');\n }\n instance.componentDidUpdate(prevProps, prevState, instance.__reactInternalSnapshotBeforeUpdate);\n }\n } // TODO: I think this is now always non-null by the time it reaches the\n // commit phase. Consider removing the type check.\n var updateQueue = finishedWork.updateQueue;\n if (updateQueue !== null) {\n if (finishedWork.type === finishedWork.elementType && !didWarnAboutReassigningProps) {\n if (instance.props !== finishedWork.memoizedProps) error1(\"Expected %s props to match memoized props before processing the update queue. This might either be because of a bug in React, or because a component reassigns its own `this.props`. Please file an issue.\", getComponentName(finishedWork.type) || 'instance');\n if (instance.state !== finishedWork.memoizedState) error1(\"Expected %s state to match memoized state before processing the update queue. This might either be because of a bug in React, or because a component reassigns its own `this.state`. Please file an issue.\", getComponentName(finishedWork.type) || 'instance');\n }\n // but instead we rely on them being set during last render.\n // TODO: revisit this when we implement resuming.\n commitUpdateQueue(finishedWork, updateQueue, instance);\n }\n return;\n case HostRoot:\n // TODO: I think this is now always non-null by the time it reaches the\n // commit phase. Consider removing the type check.\n var _updateQueue = finishedWork.updateQueue;\n if (_updateQueue !== null) {\n var _instance = null;\n if (finishedWork.child !== null) switch(finishedWork.child.tag){\n case HostComponent:\n _instance = getPublicInstance(finishedWork.child.stateNode);\n break;\n case ClassComponent:\n _instance = finishedWork.child.stateNode;\n break;\n }\n commitUpdateQueue(finishedWork, _updateQueue, _instance);\n }\n return;\n case HostComponent:\n var _instance2 = finishedWork.stateNode; // Renderers may schedule work to be done after host components are mounted\n // (eg DOM renderer may schedule auto-focus for inputs and form controls).\n // These effects should only be committed when components are first mounted,\n // aka when there is no current/alternate.\n if (current === null && finishedWork.flags & Update) {\n var type = finishedWork.type;\n var props = finishedWork.memoizedProps;\n commitMount(_instance2, type, props);\n }\n return;\n case HostText:\n // We have no life-cycles associated with text.\n return;\n case HostPortal:\n // We have no life-cycles associated with portals.\n return;\n case Profiler:\n var _finishedWork$memoize2 = finishedWork.memoizedProps, onCommit = _finishedWork$memoize2.onCommit, onRender = _finishedWork$memoize2.onRender;\n var effectDuration = finishedWork.stateNode.effectDuration;\n var commitTime = getCommitTime();\n if (typeof onRender === 'function') onRender(finishedWork.memoizedProps.id, current === null ? 'mount' : 'update', finishedWork.actualDuration, finishedWork.treeBaseDuration, finishedWork.actualStartTime, commitTime, finishedRoot.memoizedInteractions);\n return;\n case SuspenseComponent:\n commitSuspenseHydrationCallbacks(finishedRoot, finishedWork);\n return;\n case SuspenseListComponent:\n case IncompleteClassComponent:\n case FundamentalComponent:\n case ScopeComponent:\n case OffscreenComponent:\n case LegacyHiddenComponent:\n return;\n }\n throw Error(\"This unit of work tag should not have side-effects. This error is likely caused by a bug in React. Please file an issue.\");\n }\n function hideOrUnhideAllChildren(finishedWork, isHidden) {\n // We only have the top Fiber that was inserted but we need to recurse down its\n // children to find all the terminal nodes.\n var node = finishedWork;\n while(true){\n if (node.tag === HostComponent) {\n var instance = node.stateNode;\n if (isHidden) hideInstance(instance);\n else unhideInstance(node.stateNode, node.memoizedProps);\n } else if (node.tag === HostText) {\n var _instance3 = node.stateNode;\n if (isHidden) hideTextInstance(_instance3);\n else unhideTextInstance(_instance3, node.memoizedProps);\n } else if ((node.tag === OffscreenComponent || node.tag === LegacyHiddenComponent) && node.memoizedState !== null && node !== finishedWork) ;\n else if (node.child !== null) {\n node.child.return = node;\n node = node.child;\n continue;\n }\n if (node === finishedWork) return;\n while(node.sibling === null){\n if (node.return === null || node.return === finishedWork) return;\n node = node.return;\n }\n node.sibling.return = node.return;\n node = node.sibling;\n }\n }\n function commitAttachRef(finishedWork) {\n var ref = finishedWork.ref;\n if (ref !== null) {\n var instance = finishedWork.stateNode;\n var instanceToUse;\n switch(finishedWork.tag){\n case HostComponent:\n instanceToUse = getPublicInstance(instance);\n break;\n default:\n instanceToUse = instance;\n } // Moved outside to ensure DCE works with this flag\n if (typeof ref === 'function') ref(instanceToUse);\n else {\n if (!ref.hasOwnProperty('current')) error1(\"Unexpected ref object provided for %s. Use either a ref-setter function or React.createRef().\", getComponentName(finishedWork.type));\n ref.current = instanceToUse;\n }\n }\n }\n function commitDetachRef(current) {\n var currentRef = current.ref;\n if (currentRef !== null) {\n if (typeof currentRef === 'function') currentRef(null);\n else currentRef.current = null;\n }\n } // User-originating errors (lifecycles and refs) should not interrupt\n // deletion, so don't let them throw. Host-originating errors should\n // interrupt deletion, so it's okay\n function commitUnmount(finishedRoot, current, renderPriorityLevel) {\n onCommitUnmount(current);\n switch(current.tag){\n case FunctionComponent:\n case ForwardRef:\n case MemoComponent:\n case SimpleMemoComponent:\n case Block:\n var updateQueue = current.updateQueue;\n if (updateQueue !== null) {\n var lastEffect = updateQueue.lastEffect;\n if (lastEffect !== null) {\n var firstEffect = lastEffect.next;\n var effect = firstEffect;\n do {\n var _effect2 = effect, destroy = _effect2.destroy, tag = _effect2.tag;\n if (destroy !== undefined) {\n if ((tag & Passive$1) !== NoFlags$1) enqueuePendingPassiveHookEffectUnmount(current, effect);\n else safelyCallDestroy(current, destroy);\n }\n effect = effect.next;\n }while (effect !== firstEffect)\n }\n }\n return;\n case ClassComponent:\n safelyDetachRef(current);\n var instance = current.stateNode;\n if (typeof instance.componentWillUnmount === 'function') safelyCallComponentWillUnmount(current, instance);\n return;\n case HostComponent:\n safelyDetachRef(current);\n return;\n case HostPortal:\n unmountHostComponents(finishedRoot, current);\n return;\n case FundamentalComponent:\n return;\n case DehydratedFragment:\n return;\n case ScopeComponent:\n return;\n }\n }\n function commitNestedUnmounts(finishedRoot, root, renderPriorityLevel) {\n // While we're inside a removed host node we don't want to call\n // removeChild on the inner nodes because they're removed by the top\n // call anyway. We also want to call componentWillUnmount on all\n // composites before this host node is removed from the tree. Therefore\n // we do an inner loop while we're still inside the host node.\n var node = root;\n while(true){\n commitUnmount(finishedRoot, node); // Visit children because they may contain more composite or host nodes.\n // Skip portals because commitUnmount() currently visits them recursively.\n if (node.child !== null && // If we don't use mutation we drill down into portals here instead.\n node.tag !== HostPortal) {\n node.child.return = node;\n node = node.child;\n continue;\n }\n if (node === root) return;\n while(node.sibling === null){\n if (node.return === null || node.return === root) return;\n node = node.return;\n }\n node.sibling.return = node.return;\n node = node.sibling;\n }\n }\n function detachFiberMutation(fiber) {\n // Cut off the return pointers to disconnect it from the tree. Ideally, we\n // should clear the child pointer of the parent alternate to let this\n // get GC:ed but we don't know which for sure which parent is the current\n // one so we'll settle for GC:ing the subtree of this child. This child\n // itself will be GC:ed when the parent updates the next time.\n // Note: we cannot null out sibling here, otherwise it can cause issues\n // with findDOMNode and how it requires the sibling field to carry out\n // traversal in a later effect. See PR #16820. We now clear the sibling\n // field after effects, see: detachFiberAfterEffects.\n //\n // Don't disconnect stateNode now; it will be detached in detachFiberAfterEffects.\n // It may be required if the current component is an error boundary,\n // and one of its descendants throws while unmounting a passive effect.\n fiber.alternate = null;\n fiber.child = null;\n fiber.dependencies = null;\n fiber.firstEffect = null;\n fiber.lastEffect = null;\n fiber.memoizedProps = null;\n fiber.memoizedState = null;\n fiber.pendingProps = null;\n fiber.return = null;\n fiber.updateQueue = null;\n fiber._debugOwner = null;\n }\n function getHostParentFiber(fiber) {\n var parent = fiber.return;\n while(parent !== null){\n if (isHostParent(parent)) return parent;\n parent = parent.return;\n }\n throw Error(\"Expected to find a host parent. This error is likely caused by a bug in React. Please file an issue.\");\n }\n function isHostParent(fiber) {\n return fiber.tag === HostComponent || fiber.tag === HostRoot || fiber.tag === HostPortal;\n }\n function getHostSibling(fiber) {\n // We're going to search forward into the tree until we find a sibling host\n // node. Unfortunately, if multiple insertions are done in a row we have to\n // search past them. This leads to exponential search for the next sibling.\n // TODO: Find a more efficient way to do this.\n var node = fiber;\n siblings: while(true){\n // If we didn't find anything, let's try the next sibling.\n while(node.sibling === null){\n if (node.return === null || isHostParent(node.return)) // If we pop out of the root or hit the parent the fiber we are the\n // last sibling.\n return null;\n node = node.return;\n }\n node.sibling.return = node.return;\n node = node.sibling;\n while(node.tag !== HostComponent && node.tag !== HostText && node.tag !== DehydratedFragment){\n // If it is not host node and, we might have a host node inside it.\n // Try to search down until we find one.\n if (node.flags & Placement) continue siblings;\n // If we don't have a child, try the siblings instead.\n // We also skip portals because they are not part of this host tree.\n if (node.child === null || node.tag === HostPortal) continue siblings;\n else {\n node.child.return = node;\n node = node.child;\n }\n } // Check if this host node is stable or about to be placed.\n if (!(node.flags & Placement)) // Found it!\n return node.stateNode;\n }\n }\n function commitPlacement(finishedWork) {\n var parentFiber = getHostParentFiber(finishedWork); // Note: these two variables *must* always be updated together.\n var parent;\n var isContainer;\n var parentStateNode = parentFiber.stateNode;\n switch(parentFiber.tag){\n case HostComponent:\n parent = parentStateNode;\n isContainer = false;\n break;\n case HostRoot:\n parent = parentStateNode.containerInfo;\n isContainer = true;\n break;\n case HostPortal:\n parent = parentStateNode.containerInfo;\n isContainer = true;\n break;\n case FundamentalComponent:\n // eslint-disable-next-line-no-fallthrough\n default:\n throw Error(\"Invalid host parent fiber. This error is likely caused by a bug in React. Please file an issue.\");\n }\n if (parentFiber.flags & ContentReset) {\n // Reset the text content of the parent before doing any insertions\n resetTextContent(parent); // Clear ContentReset from the effect tag\n parentFiber.flags &= ~ContentReset;\n }\n var before = getHostSibling(finishedWork); // We only have the top Fiber that was inserted but we need to recurse down its\n // children to find all the terminal nodes.\n if (isContainer) insertOrAppendPlacementNodeIntoContainer(finishedWork, before, parent);\n else insertOrAppendPlacementNode(finishedWork, before, parent);\n }\n function insertOrAppendPlacementNodeIntoContainer(node, before, parent) {\n var tag = node.tag;\n var isHost = tag === HostComponent || tag === HostText;\n if (isHost || enableFundamentalAPI) {\n var stateNode = isHost ? node.stateNode : node.stateNode.instance;\n if (before) insertInContainerBefore(parent, stateNode, before);\n else appendChildToContainer(parent, stateNode);\n } else if (tag === HostPortal) ;\n else {\n var child = node.child;\n if (child !== null) {\n insertOrAppendPlacementNodeIntoContainer(child, before, parent);\n var sibling = child.sibling;\n while(sibling !== null){\n insertOrAppendPlacementNodeIntoContainer(sibling, before, parent);\n sibling = sibling.sibling;\n }\n }\n }\n }\n function insertOrAppendPlacementNode(node, before, parent) {\n var tag = node.tag;\n var isHost = tag === HostComponent || tag === HostText;\n if (isHost || enableFundamentalAPI) {\n var stateNode = isHost ? node.stateNode : node.stateNode.instance;\n if (before) insertBefore(parent, stateNode, before);\n else appendChild(parent, stateNode);\n } else if (tag === HostPortal) ;\n else {\n var child = node.child;\n if (child !== null) {\n insertOrAppendPlacementNode(child, before, parent);\n var sibling = child.sibling;\n while(sibling !== null){\n insertOrAppendPlacementNode(sibling, before, parent);\n sibling = sibling.sibling;\n }\n }\n }\n }\n function unmountHostComponents(finishedRoot, current, renderPriorityLevel) {\n // We only have the top Fiber that was deleted but we need to recurse down its\n // children to find all the terminal nodes.\n var node = current; // Each iteration, currentParent is populated with node's host parent if not\n // currentParentIsValid.\n var currentParentIsValid = false; // Note: these two variables *must* always be updated together.\n var currentParent;\n var currentParentIsContainer;\n while(true){\n if (!currentParentIsValid) {\n var parent = node.return;\n findParent: while(true){\n if (!(parent !== null)) throw Error(\"Expected to find a host parent. This error is likely caused by a bug in React. Please file an issue.\");\n var parentStateNode = parent.stateNode;\n switch(parent.tag){\n case HostComponent:\n currentParent = parentStateNode;\n currentParentIsContainer = false;\n break findParent;\n case HostRoot:\n currentParent = parentStateNode.containerInfo;\n currentParentIsContainer = true;\n break findParent;\n case HostPortal:\n currentParent = parentStateNode.containerInfo;\n currentParentIsContainer = true;\n break findParent;\n }\n parent = parent.return;\n }\n currentParentIsValid = true;\n }\n if (node.tag === HostComponent || node.tag === HostText) {\n commitNestedUnmounts(finishedRoot, node); // After all the children have unmounted, it is now safe to remove the\n // node from the tree.\n if (currentParentIsContainer) removeChildFromContainer(currentParent, node.stateNode);\n else removeChild(currentParent, node.stateNode);\n // Don't visit children because we already visited them.\n } else if (node.tag === HostPortal) {\n if (node.child !== null) {\n // When we go into a portal, it becomes the parent to remove from.\n // We will reassign it back when we pop the portal on the way up.\n currentParent = node.stateNode.containerInfo;\n currentParentIsContainer = true; // Visit children because portals might contain host components.\n node.child.return = node;\n node = node.child;\n continue;\n }\n } else {\n commitUnmount(finishedRoot, node); // Visit children because we may find more host components below.\n if (node.child !== null) {\n node.child.return = node;\n node = node.child;\n continue;\n }\n }\n if (node === current) return;\n while(node.sibling === null){\n if (node.return === null || node.return === current) return;\n node = node.return;\n if (node.tag === HostPortal) // When we go out of the portal, we need to restore the parent.\n // Since we don't keep a stack of them, we will search for it.\n currentParentIsValid = false;\n }\n node.sibling.return = node.return;\n node = node.sibling;\n }\n }\n function commitDeletion(finishedRoot, current, renderPriorityLevel) {\n // Recursively delete all host nodes from the parent.\n // Detach refs and call componentWillUnmount() on the whole subtree.\n unmountHostComponents(finishedRoot, current);\n var alternate = current.alternate;\n detachFiberMutation(current);\n if (alternate !== null) detachFiberMutation(alternate);\n }\n function commitWork(current, finishedWork) {\n switch(finishedWork.tag){\n case FunctionComponent:\n case ForwardRef:\n case MemoComponent:\n case SimpleMemoComponent:\n case Block:\n commitHookEffectListUnmount(Layout | HasEffect, finishedWork);\n return;\n case ClassComponent:\n return;\n case HostComponent:\n var instance = finishedWork.stateNode;\n if (instance != null) {\n // Commit the work prepared earlier.\n var newProps = finishedWork.memoizedProps; // For hydration we reuse the update path but we treat the oldProps\n // as the newProps. The updatePayload will contain the real change in\n // this case.\n var oldProps = current !== null ? current.memoizedProps : newProps;\n var type = finishedWork.type; // TODO: Type the updateQueue to be specific to host components.\n var updatePayload = finishedWork.updateQueue;\n finishedWork.updateQueue = null;\n if (updatePayload !== null) commitUpdate(instance, updatePayload, type, oldProps, newProps);\n }\n return;\n case HostText:\n if (!(finishedWork.stateNode !== null)) throw Error(\"This should have a text node initialized. This error is likely caused by a bug in React. Please file an issue.\");\n var textInstance = finishedWork.stateNode;\n var newText = finishedWork.memoizedProps; // For hydration we reuse the update path but we treat the oldProps\n // as the newProps. The updatePayload will contain the real change in\n // this case.\n var oldText = current !== null ? current.memoizedProps : newText;\n commitTextUpdate(textInstance, oldText, newText);\n return;\n case HostRoot:\n var _root = finishedWork.stateNode;\n if (_root.hydrate) {\n // We've just hydrated. No need to hydrate again.\n _root.hydrate = false;\n commitHydratedContainer(_root.containerInfo);\n }\n return;\n case Profiler:\n return;\n case SuspenseComponent:\n commitSuspenseComponent(finishedWork);\n attachSuspenseRetryListeners(finishedWork);\n return;\n case SuspenseListComponent:\n attachSuspenseRetryListeners(finishedWork);\n return;\n case IncompleteClassComponent:\n return;\n case FundamentalComponent:\n break;\n case ScopeComponent:\n break;\n case OffscreenComponent:\n case LegacyHiddenComponent:\n var newState = finishedWork.memoizedState;\n var isHidden = newState !== null;\n hideOrUnhideAllChildren(finishedWork, isHidden);\n return;\n }\n throw Error(\"This unit of work tag should not have side-effects. This error is likely caused by a bug in React. Please file an issue.\");\n }\n function commitSuspenseComponent(finishedWork) {\n var newState = finishedWork.memoizedState;\n if (newState !== null) {\n markCommitTimeOfFallback();\n // Hide the Offscreen component that contains the primary children. TODO:\n // Ideally, this effect would have been scheduled on the Offscreen fiber\n // itself. That's how unhiding works: the Offscreen component schedules an\n // effect on itself. However, in this case, the component didn't complete,\n // so the fiber was never added to the effect list in the normal path. We\n // could have appended it to the effect list in the Suspense component's\n // second pass, but doing it this way is less complicated. This would be\n // simpler if we got rid of the effect list and traversed the tree, like\n // we're planning to do.\n var primaryChildParent = finishedWork.child;\n hideOrUnhideAllChildren(primaryChildParent, true);\n }\n }\n function commitSuspenseHydrationCallbacks(finishedRoot, finishedWork) {\n var newState = finishedWork.memoizedState;\n if (newState === null) {\n var current = finishedWork.alternate;\n if (current !== null) {\n var prevState = current.memoizedState;\n if (prevState !== null) {\n var suspenseInstance = prevState.dehydrated;\n if (suspenseInstance !== null) commitHydratedSuspenseInstance(suspenseInstance);\n }\n }\n }\n }\n function attachSuspenseRetryListeners(finishedWork) {\n // If this boundary just timed out, then it will have a set of wakeables.\n // For each wakeable, attach a listener so that when it resolves, React\n // attempts to re-render the boundary in the primary (pre-timeout) state.\n var wakeables = finishedWork.updateQueue;\n if (wakeables !== null) {\n finishedWork.updateQueue = null;\n var retryCache = finishedWork.stateNode;\n if (retryCache === null) retryCache = finishedWork.stateNode = new PossiblyWeakSet();\n wakeables.forEach(function(wakeable) {\n // Memoize using the boundary fiber to prevent redundant listeners.\n var retry = resolveRetryWakeable.bind(null, finishedWork, wakeable);\n if (!retryCache.has(wakeable)) {\n if (wakeable.__reactDoNotTraceInteractions !== true) retry = tracing.unstable_wrap(retry);\n retryCache.add(wakeable);\n wakeable.then(retry, retry);\n }\n });\n }\n } // This function detects when a Suspense boundary goes from visible to hidden.\n // It returns false if the boundary is already hidden.\n // TODO: Use an effect tag.\n function isSuspenseBoundaryBeingHidden(current, finishedWork) {\n if (current !== null) {\n var oldState = current.memoizedState;\n if (oldState === null || oldState.dehydrated !== null) {\n var newState = finishedWork.memoizedState;\n return newState !== null && newState.dehydrated === null;\n }\n }\n return false;\n }\n function commitResetTextContent(current) {\n resetTextContent(current.stateNode);\n }\n var COMPONENT_TYPE = 0;\n var HAS_PSEUDO_CLASS_TYPE = 1;\n var ROLE_TYPE = 2;\n var TEST_NAME_TYPE = 3;\n var TEXT_TYPE = 4;\n if (typeof Symbol === 'function' && Symbol.for) {\n var symbolFor$1 = Symbol.for;\n COMPONENT_TYPE = symbolFor$1('selector.component');\n HAS_PSEUDO_CLASS_TYPE = symbolFor$1('selector.has_pseudo_class');\n ROLE_TYPE = symbolFor$1('selector.role');\n TEST_NAME_TYPE = symbolFor$1('selector.test_id');\n TEXT_TYPE = symbolFor$1('selector.text');\n }\n var commitHooks = [];\n function onCommitRoot$1() {\n commitHooks.forEach(function(commitHook) {\n return commitHook();\n });\n }\n var ceil = Math.ceil;\n var ReactCurrentDispatcher$2 = ReactSharedInternals.ReactCurrentDispatcher, ReactCurrentOwner$2 = ReactSharedInternals.ReactCurrentOwner, IsSomeRendererActing = ReactSharedInternals.IsSomeRendererActing;\n var NoContext = /* */ 0;\n var BatchedContext = /* */ 1;\n var EventContext = /* */ 2;\n var DiscreteEventContext = /* */ 4;\n var LegacyUnbatchedContext = /* */ 8;\n var RenderContext = /* */ 16;\n var CommitContext = /* */ 32;\n var RetryAfterError = /* */ 64;\n var RootIncomplete = 0;\n var RootFatalErrored = 1;\n var RootErrored = 2;\n var RootSuspended = 3;\n var RootSuspendedWithDelay = 4;\n var RootCompleted = 5; // Describes where we are in the React execution stack\n var executionContext = NoContext; // The root we're working on\n var workInProgressRoot = null; // The fiber we're working on\n var workInProgress1 = null; // The lanes we're rendering\n var workInProgressRootRenderLanes = NoLanes; // Stack that allows components to change the render lanes for its subtree\n // This is a superset of the lanes we started working on at the root. The only\n // case where it's different from `workInProgressRootRenderLanes` is when we\n // enter a subtree that is hidden and needs to be unhidden: Suspense and\n // Offscreen component.\n //\n // Most things in the work loop should deal with workInProgressRootRenderLanes.\n // Most things in begin/complete phases should deal with subtreeRenderLanes.\n var subtreeRenderLanes1 = NoLanes;\n var subtreeRenderLanesCursor = createCursor(NoLanes); // Whether to root completed, errored, suspended, etc.\n var workInProgressRootExitStatus = RootIncomplete; // A fatal error, if one is thrown\n var workInProgressRootFatalError = null; // \"Included\" lanes refer to lanes that were worked on during this render. It's\n // slightly different than `renderLanes` because `renderLanes` can change as you\n // enter and exit an Offscreen tree. This value is the combination of all render\n // lanes for the entire render phase.\n var workInProgressRootIncludedLanes = NoLanes; // The work left over by components that were visited during this render. Only\n // includes unprocessed updates, not work in bailed out children.\n var workInProgressRootSkippedLanes = NoLanes; // Lanes that were updated (in an interleaved event) during this render.\n var workInProgressRootUpdatedLanes = NoLanes; // Lanes that were pinged (in an interleaved event) during this render.\n var workInProgressRootPingedLanes = NoLanes;\n var mostRecentlyUpdatedRoot = null; // The most recent time we committed a fallback. This lets us ensure a train\n // model where we don't commit new loading states in too quick succession.\n var globalMostRecentFallbackTime = 0;\n var FALLBACK_THROTTLE_MS = 500; // The absolute time for when we should start giving up on rendering\n // more and prefer CPU suspense heuristics instead.\n var workInProgressRootRenderTargetTime = Infinity; // How long a render is supposed to take before we start following CPU\n // suspense heuristics and opt out of rendering more content.\n var RENDER_TIMEOUT_MS = 500;\n function resetRenderTimer() {\n workInProgressRootRenderTargetTime = now() + RENDER_TIMEOUT_MS;\n }\n function getRenderTargetTime() {\n return workInProgressRootRenderTargetTime;\n }\n var nextEffect = null;\n var hasUncaughtError = false;\n var firstUncaughtError = null;\n var legacyErrorBoundariesThatAlreadyFailed = null;\n var rootDoesHavePassiveEffects = false;\n var rootWithPendingPassiveEffects = null;\n var pendingPassiveEffectsRenderPriority = NoPriority$1;\n var pendingPassiveEffectsLanes = NoLanes;\n var pendingPassiveHookEffectsMount = [];\n var pendingPassiveHookEffectsUnmount = [];\n var rootsWithPendingDiscreteUpdates = null; // Use these to prevent an infinite loop of nested updates\n var NESTED_UPDATE_LIMIT = 50;\n var nestedUpdateCount = 0;\n var rootWithNestedUpdates = null;\n var NESTED_PASSIVE_UPDATE_LIMIT = 50;\n var nestedPassiveUpdateCount = 0; // Marks the need to reschedule pending interactions at these lanes\n // during the commit phase. This enables them to be traced across components\n // that spawn new work during render. E.g. hidden boundaries, suspended SSR\n // hydration or SuspenseList.\n // TODO: Can use a bitmask instead of an array\n var spawnedWorkDuringRender = null; // If two updates are scheduled within the same event, we should treat their\n // event times as simultaneous, even if the actual clock time has advanced\n // between the first and second call.\n var currentEventTime = NoTimestamp;\n var currentEventWipLanes = NoLanes;\n var currentEventPendingLanes = NoLanes; // Dev only flag that tracks if passive effects are currently being flushed.\n // We warn about state updates for unmounted components differently in this case.\n var isFlushingPassiveEffects = false;\n var focusedInstanceHandle = null;\n var shouldFireAfterActiveInstanceBlur = false;\n function getWorkInProgressRoot() {\n return workInProgressRoot;\n }\n function requestEventTime() {\n if ((executionContext & (RenderContext | CommitContext)) !== NoContext) // We're inside React, so it's fine to read the actual time.\n return now();\n // We're not inside React, so we may be in the middle of a browser event.\n if (currentEventTime !== NoTimestamp) // Use the same start time for all updates until we enter React again.\n return currentEventTime;\n // This is the first update since React yielded. Compute a new start time.\n currentEventTime = now();\n return currentEventTime;\n }\n function requestUpdateLane(fiber) {\n // Special cases\n var mode = fiber.mode;\n if ((mode & BlockingMode) === NoMode) return SyncLane;\n else if ((mode & ConcurrentMode) === NoMode) return getCurrentPriorityLevel() === ImmediatePriority$1 ? SyncLane : SyncBatchedLane;\n // The algorithm for assigning an update to a lane should be stable for all\n // updates at the same priority within the same event. To do this, the inputs\n // to the algorithm must be the same. For example, we use the `renderLanes`\n // to avoid choosing a lane that is already in the middle of rendering.\n //\n // However, the \"included\" lanes could be mutated in between updates in the\n // same event, like if you perform an update inside `flushSync`. Or any other\n // code path that might call `prepareFreshStack`.\n //\n // The trick we use is to cache the first of each of these inputs within an\n // event. Then reset the cached values once we can be sure the event is over.\n // Our heuristic for that is whenever we enter a concurrent work loop.\n //\n // We'll do the same for `currentEventPendingLanes` below.\n if (currentEventWipLanes === NoLanes) currentEventWipLanes = workInProgressRootIncludedLanes;\n var isTransition = requestCurrentTransition() !== NoTransition;\n if (isTransition) {\n if (currentEventPendingLanes !== NoLanes) currentEventPendingLanes = mostRecentlyUpdatedRoot !== null ? mostRecentlyUpdatedRoot.pendingLanes : NoLanes;\n return findTransitionLane(currentEventWipLanes, currentEventPendingLanes);\n } // TODO: Remove this dependency on the Scheduler priority.\n // To do that, we're replacing it with an update lane priority.\n var schedulerPriority = getCurrentPriorityLevel(); // The old behavior was using the priority level of the Scheduler.\n // This couples React to the Scheduler internals, so we're replacing it\n // with the currentUpdateLanePriority above. As an example of how this\n // could be problematic, if we're not inside `Scheduler.runWithPriority`,\n // then we'll get the priority of the current running Scheduler task,\n // which is probably not what we want.\n var lane;\n if ((executionContext & DiscreteEventContext) !== NoContext && schedulerPriority === UserBlockingPriority$2) lane = findUpdateLane(InputDiscreteLanePriority, currentEventWipLanes);\n else {\n var schedulerLanePriority = schedulerPriorityToLanePriority(schedulerPriority);\n lane = findUpdateLane(schedulerLanePriority, currentEventWipLanes);\n }\n return lane;\n }\n function requestRetryLane(fiber) {\n // This is a fork of `requestUpdateLane` designed specifically for Suspense\n // \"retries\" \u2014 a special update that attempts to flip a Suspense boundary\n // from its placeholder state to its primary/resolved state.\n // Special cases\n var mode = fiber.mode;\n if ((mode & BlockingMode) === NoMode) return SyncLane;\n else if ((mode & ConcurrentMode) === NoMode) return getCurrentPriorityLevel() === ImmediatePriority$1 ? SyncLane : SyncBatchedLane;\n // See `requestUpdateLane` for explanation of `currentEventWipLanes`\n if (currentEventWipLanes === NoLanes) currentEventWipLanes = workInProgressRootIncludedLanes;\n return findRetryLane(currentEventWipLanes);\n }\n function scheduleUpdateOnFiber(fiber, lane, eventTime) {\n checkForNestedUpdates();\n warnAboutRenderPhaseUpdatesInDEV(fiber);\n var root = markUpdateLaneFromFiberToRoot(fiber, lane);\n if (root === null) {\n warnAboutUpdateOnUnmountedFiberInDEV(fiber);\n return null;\n } // Mark that the root has a pending update.\n markRootUpdated(root, lane, eventTime);\n if (root === workInProgressRoot) {\n workInProgressRootUpdatedLanes = mergeLanes(workInProgressRootUpdatedLanes, lane);\n if (workInProgressRootExitStatus === RootSuspendedWithDelay) // The root already suspended with a delay, which means this render\n // definitely won't finish. Since we have a new update, let's mark it as\n // suspended now, right before marking the incoming update. This has the\n // effect of interrupting the current render and switching to the update.\n // TODO: Make sure this doesn't override pings that happen while we've\n // already started rendering.\n markRootSuspended$1(root, workInProgressRootRenderLanes);\n } // TODO: requestUpdateLanePriority also reads the priority. Pass the\n // priority as an argument to that function and this one.\n var priorityLevel = getCurrentPriorityLevel();\n if (lane === SyncLane) {\n if ((executionContext & LegacyUnbatchedContext) !== NoContext && (executionContext & (RenderContext | CommitContext)) === NoContext) {\n // Register pending interactions on the root to avoid losing traced interaction data.\n schedulePendingInteractions(root, lane); // This is a legacy edge case. The initial mount of a ReactDOM.render-ed\n // root inside of batchedUpdates should be synchronous, but layout updates\n // should be deferred until the end of the batch.\n performSyncWorkOnRoot(root);\n } else {\n ensureRootIsScheduled(root, eventTime);\n schedulePendingInteractions(root, lane);\n if (executionContext === NoContext) {\n // Flush the synchronous work now, unless we're already working or inside\n // a batch. This is intentionally inside scheduleUpdateOnFiber instead of\n // scheduleCallbackForFiber to preserve the ability to schedule a callback\n // without immediately flushing it. We only do this for user-initiated\n // updates, to preserve historical behavior of legacy mode.\n resetRenderTimer();\n flushSyncCallbackQueue();\n }\n }\n } else {\n // Schedule a discrete update but only if it's not Sync.\n if ((executionContext & DiscreteEventContext) !== NoContext && // discrete, even inside a discrete event.\n (priorityLevel === UserBlockingPriority$2 || priorityLevel === ImmediatePriority$1)) {\n // This is the result of a discrete event. Track the lowest priority\n // discrete update per root so we can flush them early, if needed.\n if (rootsWithPendingDiscreteUpdates === null) rootsWithPendingDiscreteUpdates = new Set([\n root\n ]);\n else rootsWithPendingDiscreteUpdates.add(root);\n } // Schedule other updates after in case the callback is sync.\n ensureRootIsScheduled(root, eventTime);\n schedulePendingInteractions(root, lane);\n } // We use this when assigning a lane for a transition inside\n // `requestUpdateLane`. We assume it's the same as the root being updated,\n // since in the common case of a single root app it probably is. If it's not\n // the same root, then it's not a huge deal, we just might batch more stuff\n // together more than necessary.\n mostRecentlyUpdatedRoot = root;\n } // This is split into a separate function so we can mark a fiber with pending\n // work without treating it as a typical update that originates from an event;\n // e.g. retrying a Suspense boundary isn't an update, but it does schedule work\n // on a fiber.\n function markUpdateLaneFromFiberToRoot(sourceFiber, lane) {\n // Update the source fiber's lanes\n sourceFiber.lanes = mergeLanes(sourceFiber.lanes, lane);\n var alternate = sourceFiber.alternate;\n if (alternate !== null) alternate.lanes = mergeLanes(alternate.lanes, lane);\n if (alternate === null && (sourceFiber.flags & (Placement | Hydrating)) !== NoFlags) warnAboutUpdateOnNotYetMountedFiberInDEV(sourceFiber);\n var node = sourceFiber;\n var parent = sourceFiber.return;\n while(parent !== null){\n parent.childLanes = mergeLanes(parent.childLanes, lane);\n alternate = parent.alternate;\n if (alternate !== null) alternate.childLanes = mergeLanes(alternate.childLanes, lane);\n else if ((parent.flags & (Placement | Hydrating)) !== NoFlags) warnAboutUpdateOnNotYetMountedFiberInDEV(sourceFiber);\n node = parent;\n parent = parent.return;\n }\n if (node.tag === HostRoot) {\n var root = node.stateNode;\n return root;\n } else return null;\n } // Use this function to schedule a task for a root. There's only one task per\n // root; if a task was already scheduled, we'll check to make sure the priority\n // of the existing task is the same as the priority of the next level that the\n // root has work on. This function is called on every update, and right before\n // exiting a task.\n function ensureRootIsScheduled(root, currentTime) {\n var existingCallbackNode = root.callbackNode; // Check if any lanes are being starved by other work. If so, mark them as\n // expired so we know to work on those next.\n markStarvedLanesAsExpired(root, currentTime); // Determine the next lanes to work on, and their priority.\n var nextLanes = getNextLanes(root, root === workInProgressRoot ? workInProgressRootRenderLanes : NoLanes); // This returns the priority level computed during the `getNextLanes` call.\n var newCallbackPriority = returnNextLanesPriority();\n if (nextLanes === NoLanes) {\n // Special case: There's nothing to work on.\n if (existingCallbackNode !== null) {\n cancelCallback(existingCallbackNode);\n root.callbackNode = null;\n root.callbackPriority = NoLanePriority;\n }\n return;\n } // Check if there's an existing task. We may be able to reuse it.\n if (existingCallbackNode !== null) {\n var existingCallbackPriority = root.callbackPriority;\n if (existingCallbackPriority === newCallbackPriority) // The priority hasn't changed. We can reuse the existing task. Exit.\n return;\n // The priority changed. Cancel the existing callback. We'll schedule a new\n // one below.\n cancelCallback(existingCallbackNode);\n } // Schedule a new callback.\n var newCallbackNode;\n if (newCallbackPriority === SyncLanePriority) // Special case: Sync React callbacks are scheduled on a special\n // internal queue\n newCallbackNode = scheduleSyncCallback(performSyncWorkOnRoot.bind(null, root));\n else if (newCallbackPriority === SyncBatchedLanePriority) newCallbackNode = scheduleCallback(ImmediatePriority$1, performSyncWorkOnRoot.bind(null, root));\n else {\n var schedulerPriorityLevel = lanePriorityToSchedulerPriority(newCallbackPriority);\n newCallbackNode = scheduleCallback(schedulerPriorityLevel, performConcurrentWorkOnRoot.bind(null, root));\n }\n root.callbackPriority = newCallbackPriority;\n root.callbackNode = newCallbackNode;\n } // This is the entry point for every concurrent task, i.e. anything that\n // goes through Scheduler.\n function performConcurrentWorkOnRoot(root) {\n // Since we know we're in a React event, we can clear the current\n // event time. The next update will compute a new event time.\n currentEventTime = NoTimestamp;\n currentEventWipLanes = NoLanes;\n currentEventPendingLanes = NoLanes;\n if (!((executionContext & (RenderContext | CommitContext)) === NoContext)) throw Error(\"Should not already be working.\");\n // Flush any pending passive effects before deciding which lanes to work on,\n // in case they schedule additional work.\n var originalCallbackNode = root.callbackNode;\n var didFlushPassiveEffects = flushPassiveEffects();\n if (didFlushPassiveEffects) {\n // Something in the passive effect phase may have canceled the current task.\n // Check if the task node for this root was changed.\n if (root.callbackNode !== originalCallbackNode) // The current task was canceled. Exit. We don't need to call\n // `ensureRootIsScheduled` because the check above implies either that\n // there's a new task, or that there's no remaining work on this root.\n return null;\n } // Determine the next expiration time to work on, using the fields stored\n // on the root.\n var lanes = getNextLanes(root, root === workInProgressRoot ? workInProgressRootRenderLanes : NoLanes);\n if (lanes === NoLanes) // Defensive coding. This is never expected to happen.\n return null;\n var exitStatus = renderRootConcurrent(root, lanes);\n if (includesSomeLane(workInProgressRootIncludedLanes, workInProgressRootUpdatedLanes)) // The render included lanes that were updated during the render phase.\n // For example, when unhiding a hidden tree, we include all the lanes\n // that were previously skipped when the tree was hidden. That set of\n // lanes is a superset of the lanes we started rendering with.\n //\n // So we'll throw out the current work and restart.\n prepareFreshStack(root, NoLanes);\n else if (exitStatus !== RootIncomplete) {\n if (exitStatus === RootErrored) {\n executionContext |= RetryAfterError; // If an error occurred during hydration,\n // discard server response and fall back to client side render.\n if (root.hydrate) {\n root.hydrate = false;\n clearContainer(root.containerInfo);\n } // If something threw an error, try rendering one more time. We'll render\n // synchronously to block concurrent data mutations, and we'll includes\n // all pending updates are included. If it still fails after the second\n // attempt, we'll give up and commit the resulting tree.\n lanes = getLanesToRetrySynchronouslyOnError(root);\n if (lanes !== NoLanes) exitStatus = renderRootSync(root, lanes);\n }\n if (exitStatus === RootFatalErrored) {\n var fatalError = workInProgressRootFatalError;\n prepareFreshStack(root, NoLanes);\n markRootSuspended$1(root, lanes);\n ensureRootIsScheduled(root, now());\n throw fatalError;\n } // We now have a consistent tree. The next step is either to commit it,\n // or, if something suspended, wait to commit it after a timeout.\n var finishedWork = root.current.alternate;\n root.finishedWork = finishedWork;\n root.finishedLanes = lanes;\n finishConcurrentRender(root, exitStatus, lanes);\n }\n ensureRootIsScheduled(root, now());\n if (root.callbackNode === originalCallbackNode) // The task node scheduled for this root is the same one that's\n // currently executed. Need to return a continuation.\n return performConcurrentWorkOnRoot.bind(null, root);\n return null;\n }\n function finishConcurrentRender(root, exitStatus, lanes) {\n switch(exitStatus){\n case RootIncomplete:\n case RootFatalErrored:\n throw Error(\"Root did not complete. This is a bug in React.\");\n // Flow knows about invariant, so it complains if I add a break\n // statement, but eslint doesn't know about invariant, so it complains\n // if I do. eslint-disable-next-line no-fallthrough\n case RootErrored:\n // We should have already attempted to retry this tree. If we reached\n // this point, it errored again. Commit it.\n commitRoot(root);\n break;\n case RootSuspended:\n markRootSuspended$1(root, lanes); // We have an acceptable loading state. We need to figure out if we\n // should immediately commit it or wait a bit.\n if (includesOnlyRetries(lanes) && !shouldForceFlushFallbacksInDEV()) {\n // This render only included retries, no updates. Throttle committing\n // retries so that we don't show too many loading states too quickly.\n var msUntilTimeout = globalMostRecentFallbackTime + FALLBACK_THROTTLE_MS - now(); // Don't bother with a very short suspense time.\n if (msUntilTimeout > 10) {\n var nextLanes = getNextLanes(root, NoLanes);\n if (nextLanes !== NoLanes) break;\n var suspendedLanes = root.suspendedLanes;\n if (!isSubsetOfLanes(suspendedLanes, lanes)) {\n // We should prefer to render the fallback of at the last\n // suspended level. Ping the last suspended level to try\n // rendering it again.\n // FIXME: What if the suspended lanes are Idle? Should not restart.\n var eventTime = requestEventTime();\n markRootPinged(root, suspendedLanes);\n break;\n } // The render is suspended, it hasn't timed out, and there's no\n // lower priority work to do. Instead of committing the fallback\n // immediately, wait for more data to arrive.\n root.timeoutHandle = scheduleTimeout(commitRoot.bind(null, root), msUntilTimeout);\n break;\n }\n } // The work expired. Commit immediately.\n commitRoot(root);\n break;\n case RootSuspendedWithDelay:\n markRootSuspended$1(root, lanes);\n if (includesOnlyTransitions(lanes)) break;\n if (!shouldForceFlushFallbacksInDEV()) {\n // This is not a transition, but we did trigger an avoided state.\n // Schedule a placeholder to display after a short delay, using the Just\n // Noticeable Difference.\n // TODO: Is the JND optimization worth the added complexity? If this is\n // the only reason we track the event time, then probably not.\n // Consider removing.\n var mostRecentEventTime = getMostRecentEventTime(root, lanes);\n var eventTimeMs = mostRecentEventTime;\n var timeElapsedMs = now() - eventTimeMs;\n var _msUntilTimeout = jnd(timeElapsedMs) - timeElapsedMs; // Don't bother with a very short suspense time.\n if (_msUntilTimeout > 10) {\n // Instead of committing the fallback immediately, wait for more data\n // to arrive.\n root.timeoutHandle = scheduleTimeout(commitRoot.bind(null, root), _msUntilTimeout);\n break;\n }\n } // Commit the placeholder.\n commitRoot(root);\n break;\n case RootCompleted:\n // The work completed. Ready to commit.\n commitRoot(root);\n break;\n default:\n throw Error(\"Unknown root exit status.\");\n }\n }\n function markRootSuspended$1(root, suspendedLanes) {\n // When suspending, we should always exclude lanes that were pinged or (more\n // rarely, since we try to avoid it) updated during the render phase.\n // TODO: Lol maybe there's a better way to factor this besides this\n // obnoxiously named function :)\n suspendedLanes = removeLanes(suspendedLanes, workInProgressRootPingedLanes);\n suspendedLanes = removeLanes(suspendedLanes, workInProgressRootUpdatedLanes);\n markRootSuspended(root, suspendedLanes);\n } // This is the entry point for synchronous tasks that don't go\n // through Scheduler\n function performSyncWorkOnRoot(root) {\n if (!((executionContext & (RenderContext | CommitContext)) === NoContext)) throw Error(\"Should not already be working.\");\n flushPassiveEffects();\n var lanes;\n var exitStatus;\n if (root === workInProgressRoot && includesSomeLane(root.expiredLanes, workInProgressRootRenderLanes)) {\n // There's a partial tree, and at least one of its lanes has expired. Finish\n // rendering it before rendering the rest of the expired work.\n lanes = workInProgressRootRenderLanes;\n exitStatus = renderRootSync(root, lanes);\n if (includesSomeLane(workInProgressRootIncludedLanes, workInProgressRootUpdatedLanes)) {\n // The render included lanes that were updated during the render phase.\n // For example, when unhiding a hidden tree, we include all the lanes\n // that were previously skipped when the tree was hidden. That set of\n // lanes is a superset of the lanes we started rendering with.\n //\n // Note that this only happens when part of the tree is rendered\n // concurrently. If the whole tree is rendered synchronously, then there\n // are no interleaved events.\n lanes = getNextLanes(root, lanes);\n exitStatus = renderRootSync(root, lanes);\n }\n } else {\n lanes = getNextLanes(root, NoLanes);\n exitStatus = renderRootSync(root, lanes);\n }\n if (root.tag !== LegacyRoot && exitStatus === RootErrored) {\n executionContext |= RetryAfterError; // If an error occurred during hydration,\n // discard server response and fall back to client side render.\n if (root.hydrate) {\n root.hydrate = false;\n clearContainer(root.containerInfo);\n } // If something threw an error, try rendering one more time. We'll render\n // synchronously to block concurrent data mutations, and we'll includes\n // all pending updates are included. If it still fails after the second\n // attempt, we'll give up and commit the resulting tree.\n lanes = getLanesToRetrySynchronouslyOnError(root);\n if (lanes !== NoLanes) exitStatus = renderRootSync(root, lanes);\n }\n if (exitStatus === RootFatalErrored) {\n var fatalError = workInProgressRootFatalError;\n prepareFreshStack(root, NoLanes);\n markRootSuspended$1(root, lanes);\n ensureRootIsScheduled(root, now());\n throw fatalError;\n } // We now have a consistent tree. Because this is a sync render, we\n // will commit it even if something suspended.\n var finishedWork = root.current.alternate;\n root.finishedWork = finishedWork;\n root.finishedLanes = lanes;\n commitRoot(root); // Before exiting, make sure there's a callback scheduled for the next\n // pending level.\n ensureRootIsScheduled(root, now());\n return null;\n }\n function flushDiscreteUpdates() {\n // TODO: Should be able to flush inside batchedUpdates, but not inside `act`.\n // However, `act` uses `batchedUpdates`, so there's no way to distinguish\n // those two cases. Need to fix this before exposing flushDiscreteUpdates\n // as a public API.\n if ((executionContext & (BatchedContext | RenderContext | CommitContext)) !== NoContext) {\n if ((executionContext & RenderContext) !== NoContext) error1(\"unstable_flushDiscreteUpdates: Cannot flush updates when React is already rendering.\");\n // This is probably a nested event dispatch triggered by a lifecycle/effect,\n // like `el.focus()`. Exit.\n return;\n }\n flushPendingDiscreteUpdates(); // If the discrete updates scheduled passive effects, flush them now so that\n // they fire before the next serial event.\n flushPassiveEffects();\n }\n function flushPendingDiscreteUpdates() {\n if (rootsWithPendingDiscreteUpdates !== null) {\n // For each root with pending discrete updates, schedule a callback to\n // immediately flush them.\n var roots = rootsWithPendingDiscreteUpdates;\n rootsWithPendingDiscreteUpdates = null;\n roots.forEach(function(root) {\n markDiscreteUpdatesExpired(root);\n ensureRootIsScheduled(root, now());\n });\n } // Now flush the immediate queue.\n flushSyncCallbackQueue();\n }\n function batchedUpdates$1(fn, a) {\n var prevExecutionContext = executionContext;\n executionContext |= BatchedContext;\n try {\n return fn(a);\n } finally{\n executionContext = prevExecutionContext;\n if (executionContext === NoContext) {\n // Flush the immediate callbacks that were scheduled during this batch\n resetRenderTimer();\n flushSyncCallbackQueue();\n }\n }\n }\n function batchedEventUpdates$1(fn, a) {\n var prevExecutionContext = executionContext;\n executionContext |= EventContext;\n try {\n return fn(a);\n } finally{\n executionContext = prevExecutionContext;\n if (executionContext === NoContext) {\n // Flush the immediate callbacks that were scheduled during this batch\n resetRenderTimer();\n flushSyncCallbackQueue();\n }\n }\n }\n function discreteUpdates$1(fn, a, b, c, d) {\n var prevExecutionContext = executionContext;\n executionContext |= DiscreteEventContext;\n try {\n return runWithPriority$1(UserBlockingPriority$2, fn.bind(null, a, b, c, d));\n } finally{\n executionContext = prevExecutionContext;\n if (executionContext === NoContext) {\n // Flush the immediate callbacks that were scheduled during this batch\n resetRenderTimer();\n flushSyncCallbackQueue();\n }\n }\n }\n function unbatchedUpdates(fn, a) {\n var prevExecutionContext = executionContext;\n executionContext &= ~BatchedContext;\n executionContext |= LegacyUnbatchedContext;\n try {\n return fn(a);\n } finally{\n executionContext = prevExecutionContext;\n if (executionContext === NoContext) {\n // Flush the immediate callbacks that were scheduled during this batch\n resetRenderTimer();\n flushSyncCallbackQueue();\n }\n }\n }\n function flushSync(fn, a) {\n var prevExecutionContext = executionContext;\n if ((prevExecutionContext & (RenderContext | CommitContext)) !== NoContext) {\n error1(\"flushSync was called from inside a lifecycle method. React cannot flush when React is already rendering. Consider moving this call to a scheduler task or micro task.\");\n return fn(a);\n }\n executionContext |= BatchedContext;\n try {\n if (fn) return runWithPriority$1(ImmediatePriority$1, fn.bind(null, a));\n else return undefined;\n } finally{\n executionContext = prevExecutionContext; // Flush the immediate callbacks that were scheduled during this batch.\n // Note that this will happen even if batchedUpdates is higher up\n // the stack.\n flushSyncCallbackQueue();\n }\n }\n function pushRenderLanes(fiber, lanes) {\n push(subtreeRenderLanesCursor, subtreeRenderLanes1, fiber);\n subtreeRenderLanes1 = mergeLanes(subtreeRenderLanes1, lanes);\n workInProgressRootIncludedLanes = mergeLanes(workInProgressRootIncludedLanes, lanes);\n }\n function popRenderLanes(fiber) {\n subtreeRenderLanes1 = subtreeRenderLanesCursor.current;\n pop(subtreeRenderLanesCursor, fiber);\n }\n function prepareFreshStack(root, lanes) {\n root.finishedWork = null;\n root.finishedLanes = NoLanes;\n var timeoutHandle = root.timeoutHandle;\n if (timeoutHandle !== noTimeout) {\n // The root previous suspended and scheduled a timeout to commit a fallback\n // state. Now that we have additional work, cancel the timeout.\n root.timeoutHandle = noTimeout; // $FlowFixMe Complains noTimeout is not a TimeoutID, despite the check above\n cancelTimeout(timeoutHandle);\n }\n if (workInProgress1 !== null) {\n var interruptedWork = workInProgress1.return;\n while(interruptedWork !== null){\n unwindInterruptedWork(interruptedWork);\n interruptedWork = interruptedWork.return;\n }\n }\n workInProgressRoot = root;\n workInProgress1 = createWorkInProgress(root.current, null);\n workInProgressRootRenderLanes = subtreeRenderLanes1 = workInProgressRootIncludedLanes = lanes;\n workInProgressRootExitStatus = RootIncomplete;\n workInProgressRootFatalError = null;\n workInProgressRootSkippedLanes = NoLanes;\n workInProgressRootUpdatedLanes = NoLanes;\n workInProgressRootPingedLanes = NoLanes;\n spawnedWorkDuringRender = null;\n ReactStrictModeWarnings.discardPendingWarnings();\n }\n function handleError(root, thrownValue) {\n do {\n var erroredWork = workInProgress1;\n try {\n // Reset module-level state that was set during the render phase.\n resetContextDependencies();\n resetHooksAfterThrow();\n resetCurrentFiber(); // TODO: I found and added this missing line while investigating a\n // separate issue. Write a regression test using string refs.\n ReactCurrentOwner$2.current = null;\n if (erroredWork === null || erroredWork.return === null) {\n // Expected to be working on a non-root fiber. This is a fatal error\n // because there's no ancestor that can handle it; the root is\n // supposed to capture all errors that weren't caught by an error\n // boundary.\n workInProgressRootExitStatus = RootFatalErrored;\n workInProgressRootFatalError = thrownValue; // Set `workInProgress` to null. This represents advancing to the next\n // sibling, or the parent if there are no siblings. But since the root\n // has no siblings nor a parent, we set it to null. Usually this is\n // handled by `completeUnitOfWork` or `unwindWork`, but since we're\n // intentionally not calling those, we need set it here.\n // TODO: Consider calling `unwindWork` to pop the contexts.\n workInProgress1 = null;\n return;\n }\n if (enableProfilerTimer && erroredWork.mode & ProfileMode) // Record the time spent rendering before an error was thrown. This\n // avoids inaccurate Profiler durations in the case of a\n // suspended render.\n stopProfilerTimerIfRunningAndRecordDelta(erroredWork, true);\n throwException(root, erroredWork.return, erroredWork, thrownValue, workInProgressRootRenderLanes);\n completeUnitOfWork(erroredWork);\n } catch (yetAnotherThrownValue) {\n // Something in the return path also threw.\n thrownValue = yetAnotherThrownValue;\n if (workInProgress1 === erroredWork && erroredWork !== null) {\n // If this boundary has already errored, then we had trouble processing\n // the error. Bubble it to the next boundary.\n erroredWork = erroredWork.return;\n workInProgress1 = erroredWork;\n } else erroredWork = workInProgress1;\n continue;\n } // Return to the normal work loop.\n return;\n }while (true)\n }\n function pushDispatcher() {\n var prevDispatcher = ReactCurrentDispatcher$2.current;\n ReactCurrentDispatcher$2.current = ContextOnlyDispatcher;\n if (prevDispatcher === null) // The React isomorphic package does not include a default dispatcher.\n // Instead the first renderer will lazily attach one, in order to give\n // nicer error messages.\n return ContextOnlyDispatcher;\n else return prevDispatcher;\n }\n function popDispatcher(prevDispatcher) {\n ReactCurrentDispatcher$2.current = prevDispatcher;\n }\n function pushInteractions(root) {\n var prevInteractions = tracing.__interactionsRef.current;\n tracing.__interactionsRef.current = root.memoizedInteractions;\n return prevInteractions;\n }\n function popInteractions(prevInteractions) {\n tracing.__interactionsRef.current = prevInteractions;\n }\n function markCommitTimeOfFallback() {\n globalMostRecentFallbackTime = now();\n }\n function markSkippedUpdateLanes(lane) {\n workInProgressRootSkippedLanes = mergeLanes(lane, workInProgressRootSkippedLanes);\n }\n function renderDidSuspend() {\n if (workInProgressRootExitStatus === RootIncomplete) workInProgressRootExitStatus = RootSuspended;\n }\n function renderDidSuspendDelayIfPossible() {\n if (workInProgressRootExitStatus === RootIncomplete || workInProgressRootExitStatus === RootSuspended) workInProgressRootExitStatus = RootSuspendedWithDelay;\n // Check if there are updates that we skipped tree that might have unblocked\n // this render.\n if (workInProgressRoot !== null && (includesNonIdleWork(workInProgressRootSkippedLanes) || includesNonIdleWork(workInProgressRootUpdatedLanes))) // Mark the current render as suspended so that we switch to working on\n // the updates that were skipped. Usually we only suspend at the end of\n // the render phase.\n // TODO: We should probably always mark the root as suspended immediately\n // (inside this function), since by suspending at the end of the render\n // phase introduces a potential mistake where we suspend lanes that were\n // pinged or updated while we were rendering.\n markRootSuspended$1(workInProgressRoot, workInProgressRootRenderLanes);\n }\n function renderDidError() {\n if (workInProgressRootExitStatus !== RootCompleted) workInProgressRootExitStatus = RootErrored;\n } // Called during render to determine if anything has suspended.\n // Returns false if we're not sure.\n function renderHasNotSuspendedYet() {\n // If something errored or completed, we can't really be sure,\n // so those are false.\n return workInProgressRootExitStatus === RootIncomplete;\n }\n function renderRootSync(root, lanes) {\n var prevExecutionContext = executionContext;\n executionContext |= RenderContext;\n var prevDispatcher = pushDispatcher(); // If the root or lanes have changed, throw out the existing stack\n // and prepare a fresh one. Otherwise we'll continue where we left off.\n if (workInProgressRoot !== root || workInProgressRootRenderLanes !== lanes) {\n prepareFreshStack(root, lanes);\n startWorkOnPendingInteractions(root, lanes);\n }\n var prevInteractions = pushInteractions(root);\n for(;;)try {\n workLoopSync();\n break;\n } catch (thrownValue) {\n handleError(root, thrownValue);\n }\n resetContextDependencies();\n popInteractions(prevInteractions);\n executionContext = prevExecutionContext;\n popDispatcher(prevDispatcher);\n if (workInProgress1 !== null) throw Error(\"Cannot commit an incomplete root. This error is likely caused by a bug in React. Please file an issue.\");\n workInProgressRoot = null;\n workInProgressRootRenderLanes = NoLanes;\n return workInProgressRootExitStatus;\n } // The work loop is an extremely hot path. Tell Closure not to inline it.\n /** @noinline */ function workLoopSync() {\n // Already timed out, so perform work without checking if we need to yield.\n while(workInProgress1 !== null)performUnitOfWork(workInProgress1);\n }\n function renderRootConcurrent(root, lanes) {\n var prevExecutionContext = executionContext;\n executionContext |= RenderContext;\n var prevDispatcher = pushDispatcher(); // If the root or lanes have changed, throw out the existing stack\n // and prepare a fresh one. Otherwise we'll continue where we left off.\n if (workInProgressRoot !== root || workInProgressRootRenderLanes !== lanes) {\n resetRenderTimer();\n prepareFreshStack(root, lanes);\n startWorkOnPendingInteractions(root, lanes);\n }\n var prevInteractions = pushInteractions(root);\n for(;;)try {\n workLoopConcurrent();\n break;\n } catch (thrownValue) {\n handleError(root, thrownValue);\n }\n resetContextDependencies();\n popInteractions(prevInteractions);\n popDispatcher(prevDispatcher);\n executionContext = prevExecutionContext;\n if (workInProgress1 !== null) return RootIncomplete;\n else {\n workInProgressRoot = null;\n workInProgressRootRenderLanes = NoLanes; // Return the final exit status.\n return workInProgressRootExitStatus;\n }\n }\n /** @noinline */ function workLoopConcurrent() {\n // Perform work until Scheduler asks us to yield\n while(workInProgress1 !== null && !shouldYield())performUnitOfWork(workInProgress1);\n }\n function performUnitOfWork(unitOfWork) {\n // The current, flushed, state of this fiber is the alternate. Ideally\n // nothing should rely on this, but relying on it here means that we don't\n // need an additional field on the work in progress.\n var current = unitOfWork.alternate;\n setCurrentFiber(unitOfWork);\n var next;\n if ((unitOfWork.mode & ProfileMode) !== NoMode) {\n startProfilerTimer(unitOfWork);\n next = beginWork$1(current, unitOfWork, subtreeRenderLanes1);\n stopProfilerTimerIfRunningAndRecordDelta(unitOfWork, true);\n } else next = beginWork$1(current, unitOfWork, subtreeRenderLanes1);\n resetCurrentFiber();\n unitOfWork.memoizedProps = unitOfWork.pendingProps;\n if (next === null) // If this doesn't spawn new work, complete the current work.\n completeUnitOfWork(unitOfWork);\n else workInProgress1 = next;\n ReactCurrentOwner$2.current = null;\n }\n function completeUnitOfWork(unitOfWork) {\n // Attempt to complete the current unit of work, then move to the next\n // sibling. If there are no more siblings, return to the parent fiber.\n var completedWork = unitOfWork;\n do {\n // The current, flushed, state of this fiber is the alternate. Ideally\n // nothing should rely on this, but relying on it here means that we don't\n // need an additional field on the work in progress.\n var current = completedWork.alternate;\n var returnFiber = completedWork.return; // Check if the work completed or if something threw.\n if ((completedWork.flags & Incomplete) === NoFlags) {\n setCurrentFiber(completedWork);\n var next = void 0;\n if ((completedWork.mode & ProfileMode) === NoMode) next = completeWork(current, completedWork, subtreeRenderLanes1);\n else {\n startProfilerTimer(completedWork);\n next = completeWork(current, completedWork, subtreeRenderLanes1); // Update render duration assuming we didn't error.\n stopProfilerTimerIfRunningAndRecordDelta(completedWork, false);\n }\n resetCurrentFiber();\n if (next !== null) {\n // Completing this fiber spawned new work. Work on that next.\n workInProgress1 = next;\n return;\n }\n resetChildLanes(completedWork);\n if (returnFiber !== null && (returnFiber.flags & Incomplete) === NoFlags) {\n // Append all the effects of the subtree and this fiber onto the effect\n // list of the parent. The completion order of the children affects the\n // side-effect order.\n if (returnFiber.firstEffect === null) returnFiber.firstEffect = completedWork.firstEffect;\n if (completedWork.lastEffect !== null) {\n if (returnFiber.lastEffect !== null) returnFiber.lastEffect.nextEffect = completedWork.firstEffect;\n returnFiber.lastEffect = completedWork.lastEffect;\n } // If this fiber had side-effects, we append it AFTER the children's\n // side-effects. We can perform certain side-effects earlier if needed,\n // by doing multiple passes over the effect list. We don't want to\n // schedule our own side-effect on our own list because if end up\n // reusing children we'll schedule this effect onto itself since we're\n // at the end.\n var flags = completedWork.flags; // Skip both NoWork and PerformedWork tags when creating the effect\n // list. PerformedWork effect is read by React DevTools but shouldn't be\n // committed.\n if (flags > PerformedWork) {\n if (returnFiber.lastEffect !== null) returnFiber.lastEffect.nextEffect = completedWork;\n else returnFiber.firstEffect = completedWork;\n returnFiber.lastEffect = completedWork;\n }\n }\n } else {\n // This fiber did not complete because something threw. Pop values off\n // the stack without entering the complete phase. If this is a boundary,\n // capture values if possible.\n var _next = unwindWork(completedWork); // Because this fiber did not complete, don't reset its expiration time.\n if (_next !== null) {\n // If completing this work spawned new work, do that next. We'll come\n // back here again.\n // Since we're restarting, remove anything that is not a host effect\n // from the effect tag.\n _next.flags &= HostEffectMask;\n workInProgress1 = _next;\n return;\n }\n if ((completedWork.mode & ProfileMode) !== NoMode) {\n // Record the render duration for the fiber that errored.\n stopProfilerTimerIfRunningAndRecordDelta(completedWork, false); // Include the time spent working on failed children before continuing.\n var actualDuration = completedWork.actualDuration;\n var child = completedWork.child;\n while(child !== null){\n actualDuration += child.actualDuration;\n child = child.sibling;\n }\n completedWork.actualDuration = actualDuration;\n }\n if (returnFiber !== null) {\n // Mark the parent fiber as incomplete and clear its effect list.\n returnFiber.firstEffect = returnFiber.lastEffect = null;\n returnFiber.flags |= Incomplete;\n }\n }\n var siblingFiber = completedWork.sibling;\n if (siblingFiber !== null) {\n // If there is more work to do in this returnFiber, do that next.\n workInProgress1 = siblingFiber;\n return;\n } // Otherwise, return to the parent\n completedWork = returnFiber; // Update the next thing we're working on in case something throws.\n workInProgress1 = completedWork;\n }while (completedWork !== null) // We've reached the root.\n if (workInProgressRootExitStatus === RootIncomplete) workInProgressRootExitStatus = RootCompleted;\n }\n function resetChildLanes(completedWork) {\n if (// to switch statement in `completeWork`.\n (completedWork.tag === LegacyHiddenComponent || completedWork.tag === OffscreenComponent) && completedWork.memoizedState !== null && !includesSomeLane(subtreeRenderLanes1, OffscreenLane) && (completedWork.mode & ConcurrentMode) !== NoLanes) // The children of this component are hidden. Don't bubble their\n // expiration times.\n return;\n var newChildLanes = NoLanes; // Bubble up the earliest expiration time.\n if ((completedWork.mode & ProfileMode) !== NoMode) {\n // In profiling mode, resetChildExpirationTime is also used to reset\n // profiler durations.\n var actualDuration = completedWork.actualDuration;\n var treeBaseDuration = completedWork.selfBaseDuration; // When a fiber is cloned, its actualDuration is reset to 0. This value will\n // only be updated if work is done on the fiber (i.e. it doesn't bailout).\n // When work is done, it should bubble to the parent's actualDuration. If\n // the fiber has not been cloned though, (meaning no work was done), then\n // this value will reflect the amount of time spent working on a previous\n // render. In that case it should not bubble. We determine whether it was\n // cloned by comparing the child pointer.\n var shouldBubbleActualDurations = completedWork.alternate === null || completedWork.child !== completedWork.alternate.child;\n var child = completedWork.child;\n while(child !== null){\n newChildLanes = mergeLanes(newChildLanes, mergeLanes(child.lanes, child.childLanes));\n if (shouldBubbleActualDurations) actualDuration += child.actualDuration;\n treeBaseDuration += child.treeBaseDuration;\n child = child.sibling;\n }\n var isTimedOutSuspense = completedWork.tag === SuspenseComponent && completedWork.memoizedState !== null;\n if (isTimedOutSuspense) {\n // Don't count time spent in a timed out Suspense subtree as part of the base duration.\n var primaryChildFragment = completedWork.child;\n if (primaryChildFragment !== null) treeBaseDuration -= primaryChildFragment.treeBaseDuration;\n }\n completedWork.actualDuration = actualDuration;\n completedWork.treeBaseDuration = treeBaseDuration;\n } else {\n var _child = completedWork.child;\n while(_child !== null){\n newChildLanes = mergeLanes(newChildLanes, mergeLanes(_child.lanes, _child.childLanes));\n _child = _child.sibling;\n }\n }\n completedWork.childLanes = newChildLanes;\n }\n function commitRoot(root) {\n var renderPriorityLevel = getCurrentPriorityLevel();\n runWithPriority$1(ImmediatePriority$1, commitRootImpl.bind(null, root, renderPriorityLevel));\n return null;\n }\n function commitRootImpl(root, renderPriorityLevel) {\n do // `flushPassiveEffects` will call `flushSyncUpdateQueue` at the end, which\n // means `flushPassiveEffects` will sometimes result in additional\n // passive effects. So we need to keep flushing in a loop until there are\n // no more pending effects.\n // TODO: Might be better if `flushPassiveEffects` did not automatically\n // flush synchronous work at the end, to avoid factoring hazards like this.\n flushPassiveEffects();\n while (rootWithPendingPassiveEffects !== null)\n flushRenderPhaseStrictModeWarningsInDEV();\n if (!((executionContext & (RenderContext | CommitContext)) === NoContext)) throw Error(\"Should not already be working.\");\n var finishedWork = root.finishedWork;\n var lanes = root.finishedLanes;\n if (finishedWork === null) return null;\n root.finishedWork = null;\n root.finishedLanes = NoLanes;\n if (!(finishedWork !== root.current)) throw Error(\"Cannot commit the same tree as before. This error is likely caused by a bug in React. Please file an issue.\");\n // commitRoot never returns a continuation; it always finishes synchronously.\n // So we can clear these now to allow a new callback to be scheduled.\n root.callbackNode = null; // Update the first and last pending times on this root. The new first\n // pending time is whatever is left on the root fiber.\n var remainingLanes = mergeLanes(finishedWork.lanes, finishedWork.childLanes);\n markRootFinished(root, remainingLanes); // Clear already finished discrete updates in case that a later call of\n // `flushDiscreteUpdates` starts a useless render pass which may cancels\n // a scheduled timeout.\n if (rootsWithPendingDiscreteUpdates !== null) {\n if (!hasDiscreteLanes(remainingLanes) && rootsWithPendingDiscreteUpdates.has(root)) rootsWithPendingDiscreteUpdates.delete(root);\n }\n if (root === workInProgressRoot) {\n // We can reset these now that they are finished.\n workInProgressRoot = null;\n workInProgress1 = null;\n workInProgressRootRenderLanes = NoLanes;\n } // Get the list of effects.\n var firstEffect;\n if (finishedWork.flags > PerformedWork) {\n // A fiber's effect list consists only of its children, not itself. So if\n // the root has an effect, we need to add it to the end of the list. The\n // resulting list is the set that would belong to the root's parent, if it\n // had one; that is, all the effects in the tree including the root.\n if (finishedWork.lastEffect !== null) {\n finishedWork.lastEffect.nextEffect = finishedWork;\n firstEffect = finishedWork.firstEffect;\n } else firstEffect = finishedWork;\n } else // There is no effect on the root.\n firstEffect = finishedWork.firstEffect;\n if (firstEffect !== null) {\n var prevExecutionContext = executionContext;\n executionContext |= CommitContext;\n var prevInteractions = pushInteractions(root); // Reset this to null before calling lifecycles\n ReactCurrentOwner$2.current = null; // The commit phase is broken into several sub-phases. We do a separate pass\n // of the effect list for each phase: all mutation effects come before all\n // layout effects, and so on.\n // The first phase a \"before mutation\" phase. We use this phase to read the\n // state of the host tree right before we mutate it. This is where\n // getSnapshotBeforeUpdate is called.\n focusedInstanceHandle = prepareForCommit(root.containerInfo);\n shouldFireAfterActiveInstanceBlur = false;\n nextEffect = firstEffect;\n do {\n invokeGuardedCallback(null, commitBeforeMutationEffects, null);\n if (hasCaughtError()) {\n if (!(nextEffect !== null)) throw Error(\"Should be working on an effect.\");\n var error = clearCaughtError();\n captureCommitPhaseError(nextEffect, error);\n nextEffect = nextEffect.nextEffect;\n }\n }while (nextEffect !== null) // We no longer need to track the active instance fiber\n focusedInstanceHandle = null;\n // Mark the current commit time to be shared by all Profilers in this\n // batch. This enables them to be grouped later.\n recordCommitTime();\n nextEffect = firstEffect;\n do {\n invokeGuardedCallback(null, commitMutationEffects, null, root, renderPriorityLevel);\n if (hasCaughtError()) {\n if (!(nextEffect !== null)) throw Error(\"Should be working on an effect.\");\n var _error = clearCaughtError();\n captureCommitPhaseError(nextEffect, _error);\n nextEffect = nextEffect.nextEffect;\n }\n }while (nextEffect !== null)\n resetAfterCommit(root.containerInfo); // The work-in-progress tree is now the current tree. This must come after\n // the mutation phase, so that the previous tree is still current during\n // componentWillUnmount, but before the layout phase, so that the finished\n // work is current during componentDidMount/Update.\n root.current = finishedWork; // The next phase is the layout phase, where we call effects that read\n // the host tree after it's been mutated. The idiomatic use case for this is\n // layout, but class component lifecycles also fire here for legacy reasons.\n nextEffect = firstEffect;\n do {\n invokeGuardedCallback(null, commitLayoutEffects, null, root, lanes);\n if (hasCaughtError()) {\n if (!(nextEffect !== null)) throw Error(\"Should be working on an effect.\");\n var _error2 = clearCaughtError();\n captureCommitPhaseError(nextEffect, _error2);\n nextEffect = nextEffect.nextEffect;\n }\n }while (nextEffect !== null)\n nextEffect = null; // Tell Scheduler to yield at the end of the frame, so the browser has an\n // opportunity to paint.\n requestPaint();\n popInteractions(prevInteractions);\n executionContext = prevExecutionContext;\n } else {\n // No effects.\n root.current = finishedWork; // Measure these anyway so the flamegraph explicitly shows that there were\n recordCommitTime();\n }\n var rootDidHavePassiveEffects = rootDoesHavePassiveEffects;\n if (rootDoesHavePassiveEffects) {\n // This commit has passive effects. Stash a reference to them. But don't\n // schedule a callback until after flushing layout work.\n rootDoesHavePassiveEffects = false;\n rootWithPendingPassiveEffects = root;\n pendingPassiveEffectsLanes = lanes;\n pendingPassiveEffectsRenderPriority = renderPriorityLevel;\n } else {\n // We are done with the effect chain at this point so let's clear the\n // nextEffect pointers to assist with GC. If we have passive effects, we'll\n // clear this in flushPassiveEffects.\n nextEffect = firstEffect;\n while(nextEffect !== null){\n var nextNextEffect = nextEffect.nextEffect;\n nextEffect.nextEffect = null;\n if (nextEffect.flags & Deletion) detachFiberAfterEffects(nextEffect);\n nextEffect = nextNextEffect;\n }\n } // Read this again, since an effect might have updated it\n remainingLanes = root.pendingLanes; // Check if there's remaining work on this root\n if (remainingLanes !== NoLanes) {\n if (spawnedWorkDuringRender !== null) {\n var expirationTimes = spawnedWorkDuringRender;\n spawnedWorkDuringRender = null;\n for(var i = 0; i < expirationTimes.length; i++)scheduleInteractions(root, expirationTimes[i], root.memoizedInteractions);\n }\n schedulePendingInteractions(root, remainingLanes);\n } else // If there's no remaining work, we can clear the set of already failed\n // error boundaries.\n legacyErrorBoundariesThatAlreadyFailed = null;\n if (!rootDidHavePassiveEffects) // If there are no passive effects, then we can complete the pending interactions.\n // Otherwise, we'll wait until after the passive effects are flushed.\n // Wait to do this until after remaining work has been scheduled,\n // so that we don't prematurely signal complete for interactions when there's e.g. hidden work.\n finishPendingInteractions(root, lanes);\n if (remainingLanes === SyncLane) {\n // Count the number of times the root synchronously re-renders without\n // finishing. If there are too many, it indicates an infinite update loop.\n if (root === rootWithNestedUpdates) nestedUpdateCount++;\n else {\n nestedUpdateCount = 0;\n rootWithNestedUpdates = root;\n }\n } else nestedUpdateCount = 0;\n onCommitRoot(finishedWork.stateNode, renderPriorityLevel);\n onCommitRoot$1();\n // additional work on this root is scheduled.\n ensureRootIsScheduled(root, now());\n if (hasUncaughtError) {\n hasUncaughtError = false;\n var _error3 = firstUncaughtError;\n firstUncaughtError = null;\n throw _error3;\n }\n if ((executionContext & LegacyUnbatchedContext) !== NoContext) // a ReactDOM.render-ed root inside of batchedUpdates. The commit fired\n // synchronously, but layout updates should be deferred until the end\n // of the batch.\n return null;\n // If layout work was scheduled, flush it now.\n flushSyncCallbackQueue();\n return null;\n }\n function commitBeforeMutationEffects() {\n while(nextEffect !== null){\n var current = nextEffect.alternate;\n if (!shouldFireAfterActiveInstanceBlur && focusedInstanceHandle !== null) {\n if ((nextEffect.flags & Deletion) !== NoFlags) {\n if (doesFiberContain(nextEffect, focusedInstanceHandle)) shouldFireAfterActiveInstanceBlur = true;\n } else // TODO: Move this out of the hot path using a dedicated effect tag.\n if (nextEffect.tag === SuspenseComponent && isSuspenseBoundaryBeingHidden(current, nextEffect) && doesFiberContain(nextEffect, focusedInstanceHandle)) shouldFireAfterActiveInstanceBlur = true;\n }\n var flags = nextEffect.flags;\n if ((flags & Snapshot) !== NoFlags) {\n setCurrentFiber(nextEffect);\n commitBeforeMutationLifeCycles(current, nextEffect);\n resetCurrentFiber();\n }\n if ((flags & Passive) !== NoFlags) // If there are passive effects, schedule a callback to flush at\n // the earliest opportunity.\n {\n if (!rootDoesHavePassiveEffects) {\n rootDoesHavePassiveEffects = true;\n scheduleCallback(NormalPriority$1, function() {\n flushPassiveEffects();\n return null;\n });\n }\n }\n nextEffect = nextEffect.nextEffect;\n }\n }\n function commitMutationEffects(root, renderPriorityLevel) {\n // TODO: Should probably move the bulk of this function to commitWork.\n while(nextEffect !== null){\n setCurrentFiber(nextEffect);\n var flags = nextEffect.flags;\n if (flags & ContentReset) commitResetTextContent(nextEffect);\n if (flags & Ref) {\n var current = nextEffect.alternate;\n if (current !== null) commitDetachRef(current);\n } // The following switch statement is only concerned about placement,\n // updates, and deletions. To avoid needing to add a case for every possible\n // bitmap value, we remove the secondary effects from the effect tag and\n // switch on that value.\n var primaryFlags = flags & (Placement | Update | Deletion | Hydrating);\n switch(primaryFlags){\n case Placement:\n commitPlacement(nextEffect); // Clear the \"placement\" from effect tag so that we know that this is\n // inserted, before any life-cycles like componentDidMount gets called.\n // TODO: findDOMNode doesn't rely on this any more but isMounted does\n // and isMounted is deprecated anyway so we should be able to kill this.\n nextEffect.flags &= ~Placement;\n break;\n case PlacementAndUpdate:\n // Placement\n commitPlacement(nextEffect); // Clear the \"placement\" from effect tag so that we know that this is\n // inserted, before any life-cycles like componentDidMount gets called.\n nextEffect.flags &= ~Placement; // Update\n var _current = nextEffect.alternate;\n commitWork(_current, nextEffect);\n break;\n case Hydrating:\n nextEffect.flags &= ~Hydrating;\n break;\n case HydratingAndUpdate:\n nextEffect.flags &= ~Hydrating; // Update\n var _current2 = nextEffect.alternate;\n commitWork(_current2, nextEffect);\n break;\n case Update:\n var _current3 = nextEffect.alternate;\n commitWork(_current3, nextEffect);\n break;\n case Deletion:\n commitDeletion(root, nextEffect);\n break;\n }\n resetCurrentFiber();\n nextEffect = nextEffect.nextEffect;\n }\n }\n function commitLayoutEffects(root, committedLanes) {\n while(nextEffect !== null){\n setCurrentFiber(nextEffect);\n var flags = nextEffect.flags;\n if (flags & (Update | Callback)) {\n var current = nextEffect.alternate;\n commitLifeCycles(root, current, nextEffect);\n }\n if (flags & Ref) commitAttachRef(nextEffect);\n resetCurrentFiber();\n nextEffect = nextEffect.nextEffect;\n }\n }\n function flushPassiveEffects() {\n // Returns whether passive effects were flushed.\n if (pendingPassiveEffectsRenderPriority !== NoPriority$1) {\n var priorityLevel = pendingPassiveEffectsRenderPriority > NormalPriority$1 ? NormalPriority$1 : pendingPassiveEffectsRenderPriority;\n pendingPassiveEffectsRenderPriority = NoPriority$1;\n return runWithPriority$1(priorityLevel, flushPassiveEffectsImpl);\n }\n return false;\n }\n function enqueuePendingPassiveHookEffectMount(fiber, effect) {\n pendingPassiveHookEffectsMount.push(effect, fiber);\n if (!rootDoesHavePassiveEffects) {\n rootDoesHavePassiveEffects = true;\n scheduleCallback(NormalPriority$1, function() {\n flushPassiveEffects();\n return null;\n });\n }\n }\n function enqueuePendingPassiveHookEffectUnmount(fiber, effect) {\n pendingPassiveHookEffectsUnmount.push(effect, fiber);\n fiber.flags |= PassiveUnmountPendingDev;\n var alternate = fiber.alternate;\n if (alternate !== null) alternate.flags |= PassiveUnmountPendingDev;\n if (!rootDoesHavePassiveEffects) {\n rootDoesHavePassiveEffects = true;\n scheduleCallback(NormalPriority$1, function() {\n flushPassiveEffects();\n return null;\n });\n }\n }\n function invokePassiveEffectCreate(effect) {\n var create = effect.create;\n effect.destroy = create();\n }\n function flushPassiveEffectsImpl() {\n if (rootWithPendingPassiveEffects === null) return false;\n var root = rootWithPendingPassiveEffects;\n var lanes = pendingPassiveEffectsLanes;\n rootWithPendingPassiveEffects = null;\n pendingPassiveEffectsLanes = NoLanes;\n if (!((executionContext & (RenderContext | CommitContext)) === NoContext)) throw Error(\"Cannot flush passive effects while already rendering.\");\n isFlushingPassiveEffects = true;\n var prevExecutionContext = executionContext;\n executionContext |= CommitContext;\n var prevInteractions = pushInteractions(root); // It's important that ALL pending passive effect destroy functions are called\n // before ANY passive effect create functions are called.\n // Otherwise effects in sibling components might interfere with each other.\n // e.g. a destroy function in one component may unintentionally override a ref\n // value set by a create function in another component.\n // Layout effects have the same constraint.\n // First pass: Destroy stale passive effects.\n var unmountEffects = pendingPassiveHookEffectsUnmount;\n pendingPassiveHookEffectsUnmount = [];\n for(var i = 0; i < unmountEffects.length; i += 2){\n var _effect = unmountEffects[i];\n var fiber = unmountEffects[i + 1];\n var destroy = _effect.destroy;\n _effect.destroy = undefined;\n fiber.flags &= ~PassiveUnmountPendingDev;\n var alternate = fiber.alternate;\n if (alternate !== null) alternate.flags &= ~PassiveUnmountPendingDev;\n if (typeof destroy === 'function') {\n setCurrentFiber(fiber);\n invokeGuardedCallback(null, destroy, null);\n if (hasCaughtError()) {\n if (!(fiber !== null)) throw Error(\"Should be working on an effect.\");\n var error = clearCaughtError();\n captureCommitPhaseError(fiber, error);\n }\n resetCurrentFiber();\n }\n } // Second pass: Create new passive effects.\n var mountEffects = pendingPassiveHookEffectsMount;\n pendingPassiveHookEffectsMount = [];\n for(var _i = 0; _i < mountEffects.length; _i += 2){\n var _effect2 = mountEffects[_i];\n var _fiber = mountEffects[_i + 1];\n setCurrentFiber(_fiber);\n invokeGuardedCallback(null, invokePassiveEffectCreate, null, _effect2);\n if (hasCaughtError()) {\n if (!(_fiber !== null)) throw Error(\"Should be working on an effect.\");\n var _error4 = clearCaughtError();\n captureCommitPhaseError(_fiber, _error4);\n }\n resetCurrentFiber();\n } // Note: This currently assumes there are no passive effects on the root fiber\n // because the root is not part of its own effect list.\n // This could change in the future.\n var effect = root.current.firstEffect;\n while(effect !== null){\n var nextNextEffect = effect.nextEffect; // Remove nextEffect pointer to assist GC\n effect.nextEffect = null;\n if (effect.flags & Deletion) detachFiberAfterEffects(effect);\n effect = nextNextEffect;\n }\n popInteractions(prevInteractions);\n finishPendingInteractions(root, lanes);\n isFlushingPassiveEffects = false;\n executionContext = prevExecutionContext;\n flushSyncCallbackQueue(); // If additional passive effects were scheduled, increment a counter. If this\n // exceeds the limit, we'll fire a warning.\n nestedPassiveUpdateCount = rootWithPendingPassiveEffects === null ? 0 : nestedPassiveUpdateCount + 1;\n return true;\n }\n function isAlreadyFailedLegacyErrorBoundary(instance) {\n return legacyErrorBoundariesThatAlreadyFailed !== null && legacyErrorBoundariesThatAlreadyFailed.has(instance);\n }\n function markLegacyErrorBoundaryAsFailed(instance) {\n if (legacyErrorBoundariesThatAlreadyFailed === null) legacyErrorBoundariesThatAlreadyFailed = new Set([\n instance\n ]);\n else legacyErrorBoundariesThatAlreadyFailed.add(instance);\n }\n function prepareToThrowUncaughtError(error) {\n if (!hasUncaughtError) {\n hasUncaughtError = true;\n firstUncaughtError = error;\n }\n }\n var onUncaughtError = prepareToThrowUncaughtError;\n function captureCommitPhaseErrorOnRoot(rootFiber, sourceFiber, error) {\n var errorInfo = createCapturedValue(error, sourceFiber);\n var update = createRootErrorUpdate(rootFiber, errorInfo, SyncLane);\n enqueueUpdate(rootFiber, update);\n var eventTime = requestEventTime();\n var root = markUpdateLaneFromFiberToRoot(rootFiber, SyncLane);\n if (root !== null) {\n markRootUpdated(root, SyncLane, eventTime);\n ensureRootIsScheduled(root, eventTime);\n schedulePendingInteractions(root, SyncLane);\n }\n }\n function captureCommitPhaseError(sourceFiber, error) {\n if (sourceFiber.tag === HostRoot) {\n // Error was thrown at the root. There is no parent, so the root\n // itself should capture it.\n captureCommitPhaseErrorOnRoot(sourceFiber, sourceFiber, error);\n return;\n }\n var fiber = sourceFiber.return;\n while(fiber !== null){\n if (fiber.tag === HostRoot) {\n captureCommitPhaseErrorOnRoot(fiber, sourceFiber, error);\n return;\n } else if (fiber.tag === ClassComponent) {\n var ctor = fiber.type;\n var instance = fiber.stateNode;\n if (typeof ctor.getDerivedStateFromError === 'function' || typeof instance.componentDidCatch === 'function' && !isAlreadyFailedLegacyErrorBoundary(instance)) {\n var errorInfo = createCapturedValue(error, sourceFiber);\n var update = createClassErrorUpdate(fiber, errorInfo, SyncLane);\n enqueueUpdate(fiber, update);\n var eventTime = requestEventTime();\n var root = markUpdateLaneFromFiberToRoot(fiber, SyncLane);\n if (root !== null) {\n markRootUpdated(root, SyncLane, eventTime);\n ensureRootIsScheduled(root, eventTime);\n schedulePendingInteractions(root, SyncLane);\n } else {\n // This component has already been unmounted.\n // We can't schedule any follow up work for the root because the fiber is already unmounted,\n // but we can still call the log-only boundary so the error isn't swallowed.\n //\n // TODO This is only a temporary bandaid for the old reconciler fork.\n // We can delete this special case once the new fork is merged.\n if (typeof instance.componentDidCatch === 'function' && !isAlreadyFailedLegacyErrorBoundary(instance)) try {\n instance.componentDidCatch(error, errorInfo);\n } catch (errorToIgnore) {\n // This is kind of an edge case.\n }\n }\n return;\n }\n }\n fiber = fiber.return;\n }\n }\n function pingSuspendedRoot(root, wakeable, pingedLanes) {\n var pingCache = root.pingCache;\n if (pingCache !== null) // The wakeable resolved, so we no longer need to memoize, because it will\n // never be thrown again.\n pingCache.delete(wakeable);\n var eventTime = requestEventTime();\n markRootPinged(root, pingedLanes);\n if (workInProgressRoot === root && isSubsetOfLanes(workInProgressRootRenderLanes, pingedLanes)) {\n // Received a ping at the same priority level at which we're currently\n // rendering. We might want to restart this render. This should mirror\n // the logic of whether or not a root suspends once it completes.\n // TODO: If we're rendering sync either due to Sync, Batched or expired,\n // we should probably never restart.\n // If we're suspended with delay, or if it's a retry, we'll always suspend\n // so we can always restart.\n if (workInProgressRootExitStatus === RootSuspendedWithDelay || workInProgressRootExitStatus === RootSuspended && includesOnlyRetries(workInProgressRootRenderLanes) && now() - globalMostRecentFallbackTime < FALLBACK_THROTTLE_MS) // Restart from the root.\n prepareFreshStack(root, NoLanes);\n else // Even though we can't restart right now, we might get an\n // opportunity later. So we mark this render as having a ping.\n workInProgressRootPingedLanes = mergeLanes(workInProgressRootPingedLanes, pingedLanes);\n }\n ensureRootIsScheduled(root, eventTime);\n schedulePendingInteractions(root, pingedLanes);\n }\n function retryTimedOutBoundary(boundaryFiber, retryLane) {\n // The boundary fiber (a Suspense component or SuspenseList component)\n // previously was rendered in its fallback state. One of the promises that\n // suspended it has resolved, which means at least part of the tree was\n // likely unblocked. Try rendering again, at a new expiration time.\n if (retryLane === NoLane) retryLane = requestRetryLane(boundaryFiber);\n // TODO: Special case idle priority?\n var eventTime = requestEventTime();\n var root = markUpdateLaneFromFiberToRoot(boundaryFiber, retryLane);\n if (root !== null) {\n markRootUpdated(root, retryLane, eventTime);\n ensureRootIsScheduled(root, eventTime);\n schedulePendingInteractions(root, retryLane);\n }\n }\n function resolveRetryWakeable(boundaryFiber, wakeable) {\n var retryLane = NoLane; // Default\n var retryCache;\n retryCache = boundaryFiber.stateNode;\n if (retryCache !== null) // The wakeable resolved, so we no longer need to memoize, because it will\n // never be thrown again.\n retryCache.delete(wakeable);\n retryTimedOutBoundary(boundaryFiber, retryLane);\n } // Computes the next Just Noticeable Difference (JND) boundary.\n // The theory is that a person can't tell the difference between small differences in time.\n // Therefore, if we wait a bit longer than necessary that won't translate to a noticeable\n // difference in the experience. However, waiting for longer might mean that we can avoid\n // showing an intermediate loading state. The longer we have already waited, the harder it\n // is to tell small differences in time. Therefore, the longer we've already waited,\n // the longer we can wait additionally. At some point we have to give up though.\n // We pick a train model where the next boundary commits at a consistent schedule.\n // These particular numbers are vague estimates. We expect to adjust them based on research.\n function jnd(timeElapsed) {\n return timeElapsed < 120 ? 120 : timeElapsed < 480 ? 480 : timeElapsed < 1080 ? 1080 : timeElapsed < 1920 ? 1920 : timeElapsed < 3000 ? 3000 : timeElapsed < 4320 ? 4320 : ceil(timeElapsed / 1960) * 1960;\n }\n function checkForNestedUpdates() {\n if (nestedUpdateCount > NESTED_UPDATE_LIMIT) {\n nestedUpdateCount = 0;\n rootWithNestedUpdates = null;\n throw Error(\"Maximum update depth exceeded. This can happen when a component repeatedly calls setState inside componentWillUpdate or componentDidUpdate. React limits the number of nested updates to prevent infinite loops.\");\n }\n if (nestedPassiveUpdateCount > NESTED_PASSIVE_UPDATE_LIMIT) {\n nestedPassiveUpdateCount = 0;\n error1(\"Maximum update depth exceeded. This can happen when a component calls setState inside useEffect, but useEffect either doesn't have a dependency array, or one of the dependencies changes on every render.\");\n }\n }\n function flushRenderPhaseStrictModeWarningsInDEV() {\n ReactStrictModeWarnings.flushLegacyContextWarning();\n ReactStrictModeWarnings.flushPendingUnsafeLifecycleWarnings();\n }\n var didWarnStateUpdateForNotYetMountedComponent = null;\n function warnAboutUpdateOnNotYetMountedFiberInDEV(fiber) {\n if ((executionContext & RenderContext) !== NoContext) // We let the other warning about render phase updates deal with this one.\n return;\n if (!(fiber.mode & (BlockingMode | ConcurrentMode))) return;\n var tag = fiber.tag;\n if (tag !== IndeterminateComponent && tag !== HostRoot && tag !== ClassComponent && tag !== FunctionComponent && tag !== ForwardRef && tag !== MemoComponent && tag !== SimpleMemoComponent && tag !== Block) // Only warn for user-defined components, not internal ones like Suspense.\n return;\n // We show the whole stack but dedupe on the top component's name because\n // the problematic code almost always lies inside that component.\n var componentName = getComponentName(fiber.type) || 'ReactComponent';\n if (didWarnStateUpdateForNotYetMountedComponent !== null) {\n if (didWarnStateUpdateForNotYetMountedComponent.has(componentName)) return;\n didWarnStateUpdateForNotYetMountedComponent.add(componentName);\n } else didWarnStateUpdateForNotYetMountedComponent = new Set([\n componentName\n ]);\n var previousFiber = current1;\n try {\n setCurrentFiber(fiber);\n error1(\"Can't perform a React state update on a component that hasn't mounted yet. This indicates that you have a side-effect in your render function that asynchronously later calls tries to update the component. Move this work to useEffect instead.\");\n } finally{\n if (previousFiber) setCurrentFiber(fiber);\n else resetCurrentFiber();\n }\n }\n var didWarnStateUpdateForUnmountedComponent = null;\n function warnAboutUpdateOnUnmountedFiberInDEV(fiber) {\n var tag = fiber.tag;\n if (tag !== HostRoot && tag !== ClassComponent && tag !== FunctionComponent && tag !== ForwardRef && tag !== MemoComponent && tag !== SimpleMemoComponent && tag !== Block) // Only warn for user-defined components, not internal ones like Suspense.\n return;\n // If there are pending passive effects unmounts for this Fiber,\n // we can assume that they would have prevented this update.\n if ((fiber.flags & PassiveUnmountPendingDev) !== NoFlags) return;\n // We show the whole stack but dedupe on the top component's name because\n // the problematic code almost always lies inside that component.\n var componentName = getComponentName(fiber.type) || 'ReactComponent';\n if (didWarnStateUpdateForUnmountedComponent !== null) {\n if (didWarnStateUpdateForUnmountedComponent.has(componentName)) return;\n didWarnStateUpdateForUnmountedComponent.add(componentName);\n } else didWarnStateUpdateForUnmountedComponent = new Set([\n componentName\n ]);\n if (isFlushingPassiveEffects) ;\n else {\n var previousFiber = current1;\n try {\n setCurrentFiber(fiber);\n error1(\"Can't perform a React state update on an unmounted component. This is a no-op, but it indicates a memory leak in your application. To fix, cancel all subscriptions and asynchronous tasks in %s.\", tag === ClassComponent ? 'the componentWillUnmount method' : 'a useEffect cleanup function');\n } finally{\n if (previousFiber) setCurrentFiber(fiber);\n else resetCurrentFiber();\n }\n }\n }\n var beginWork$1;\n var dummyFiber = null;\n beginWork$1 = function(current, unitOfWork, lanes) {\n // If a component throws an error, we replay it again in a synchronously\n // dispatched event, so that the debugger will treat it as an uncaught\n // error See ReactErrorUtils for more information.\n // Before entering the begin phase, copy the work-in-progress onto a dummy\n // fiber. If beginWork throws, we'll use this to reset the state.\n var originalWorkInProgressCopy = assignFiberPropertiesInDEV(dummyFiber, unitOfWork);\n try {\n return beginWork(current, unitOfWork, lanes);\n } catch (originalError) {\n if (originalError !== null && typeof originalError === 'object' && typeof originalError.then === 'function') // Don't replay promises. Treat everything else like an error.\n throw originalError;\n // Keep this code in sync with handleError; any changes here must have\n // corresponding changes there.\n resetContextDependencies();\n resetHooksAfterThrow(); // Don't reset current debug fiber, since we're about to work on the\n // same fiber again.\n // Unwind the failed stack frame\n unwindInterruptedWork(unitOfWork); // Restore the original properties of the fiber.\n assignFiberPropertiesInDEV(unitOfWork, originalWorkInProgressCopy);\n if (unitOfWork.mode & ProfileMode) // Reset the profiler timer.\n startProfilerTimer(unitOfWork);\n // Run beginWork again.\n invokeGuardedCallback(null, beginWork, null, current, unitOfWork, lanes);\n if (hasCaughtError()) {\n var replayError = clearCaughtError(); // `invokeGuardedCallback` sometimes sets an expando `_suppressLogging`.\n // Rethrow this error instead of the original one.\n throw replayError;\n } else // This branch is reachable if the render phase is impure.\n throw originalError;\n }\n };\n var didWarnAboutUpdateInRender = false;\n var didWarnAboutUpdateInRenderForAnotherComponent;\n didWarnAboutUpdateInRenderForAnotherComponent = new Set();\n function warnAboutRenderPhaseUpdatesInDEV(fiber) {\n if (isRendering && (executionContext & RenderContext) !== NoContext && !getIsUpdatingOpaqueValueInRenderPhaseInDEV()) switch(fiber.tag){\n case FunctionComponent:\n case ForwardRef:\n case SimpleMemoComponent:\n var renderingComponentName = workInProgress1 && getComponentName(workInProgress1.type) || 'Unknown'; // Dedupe by the rendering component because it's the one that needs to be fixed.\n var dedupeKey = renderingComponentName;\n if (!didWarnAboutUpdateInRenderForAnotherComponent.has(dedupeKey)) {\n didWarnAboutUpdateInRenderForAnotherComponent.add(dedupeKey);\n var setStateComponentName = getComponentName(fiber.type) || 'Unknown';\n error1(\"Cannot update a component (`%s`) while rendering a different component (`%s`). To locate the bad setState() call inside `%s`, follow the stack trace as described in https://reactjs.org/link/setstate-in-render\", setStateComponentName, renderingComponentName, renderingComponentName);\n }\n break;\n case ClassComponent:\n if (!didWarnAboutUpdateInRender) {\n error1(\"Cannot update during an existing state transition (such as within `render`). Render methods should be a pure function of props and state.\");\n didWarnAboutUpdateInRender = true;\n }\n break;\n }\n } // a 'shared' variable that changes when act() opens/closes in tests.\n var IsThisRendererActing = {\n current: false\n };\n function warnIfNotScopedWithMatchingAct(fiber) {\n if (IsSomeRendererActing.current === true && IsThisRendererActing.current !== true) {\n var previousFiber = current1;\n try {\n setCurrentFiber(fiber);\n error1(\"It looks like you're using the wrong act() around your test interactions.\\nBe sure to use the matching version of act() corresponding to your renderer:\\n\\n// for react-dom:\\nimport {act} from 'react-dom/test-utils';\\n// ...\\nact(() => ...);\\n\\n// for react-test-renderer:\\nimport TestRenderer from react-test-renderer';\\nconst {act} = TestRenderer;\\n// ...\\nact(() => ...);\");\n } finally{\n if (previousFiber) setCurrentFiber(fiber);\n else resetCurrentFiber();\n }\n }\n }\n function warnIfNotCurrentlyActingEffectsInDEV(fiber) {\n if ((fiber.mode & StrictMode) !== NoMode && IsSomeRendererActing.current === false && IsThisRendererActing.current === false) error1(\"An update to %s ran an effect, but was not wrapped in act(...).\\n\\nWhen testing, code that causes React state updates should be wrapped into act(...):\\n\\nact(() => {\\n /* fire events that update state */\\n});\\n/* assert on the output */\\n\\nThis ensures that you're testing the behavior the user would see in the browser. Learn more at https://reactjs.org/link/wrap-tests-with-act\", getComponentName(fiber.type));\n }\n function warnIfNotCurrentlyActingUpdatesInDEV(fiber) {\n if (executionContext === NoContext && IsSomeRendererActing.current === false && IsThisRendererActing.current === false) {\n var previousFiber = current1;\n try {\n setCurrentFiber(fiber);\n error1(\"An update to %s inside a test was not wrapped in act(...).\\n\\nWhen testing, code that causes React state updates should be wrapped into act(...):\\n\\nact(() => {\\n /* fire events that update state */\\n});\\n/* assert on the output */\\n\\nThis ensures that you're testing the behavior the user would see in the browser. Learn more at https://reactjs.org/link/wrap-tests-with-act\", getComponentName(fiber.type));\n } finally{\n if (previousFiber) setCurrentFiber(fiber);\n else resetCurrentFiber();\n }\n }\n }\n var warnIfNotCurrentlyActingUpdatesInDev = warnIfNotCurrentlyActingUpdatesInDEV; // In tests, we want to enforce a mocked scheduler.\n var didWarnAboutUnmockedScheduler = false; // TODO Before we release concurrent mode, revisit this and decide whether a mocked\n // scheduler is the actual recommendation. The alternative could be a testing build,\n // a new lib, or whatever; we dunno just yet. This message is for early adopters\n // to get their tests right.\n function warnIfUnmockedScheduler(fiber) {\n if (didWarnAboutUnmockedScheduler === false && Scheduler.unstable_flushAllWithoutAsserting === undefined) {\n if (fiber.mode & BlockingMode || fiber.mode & ConcurrentMode) {\n didWarnAboutUnmockedScheduler = true;\n error1(\"In Concurrent or Sync modes, the \\\"scheduler\\\" module needs to be mocked to guarantee consistent behaviour across tests and browsers. For example, with jest: \\njest.mock('scheduler', () => require('scheduler/unstable_mock'));\\n\\nFor more info, visit https://reactjs.org/link/mock-scheduler\");\n }\n }\n }\n function computeThreadID(root, lane) {\n // Interaction threads are unique per root and expiration time.\n // NOTE: Intentionally unsound cast. All that matters is that it's a number\n // and it represents a batch of work. Could make a helper function instead,\n // but meh this is fine for now.\n return lane * 1000 + root.interactionThreadID;\n }\n function markSpawnedWork(lane) {\n if (spawnedWorkDuringRender === null) spawnedWorkDuringRender = [\n lane\n ];\n else spawnedWorkDuringRender.push(lane);\n }\n function scheduleInteractions(root, lane, interactions) {\n if (interactions.size > 0) {\n var pendingInteractionMap = root.pendingInteractionMap;\n var pendingInteractions = pendingInteractionMap.get(lane);\n if (pendingInteractions != null) interactions.forEach(function(interaction) {\n if (!pendingInteractions.has(interaction)) // Update the pending async work count for previously unscheduled interaction.\n interaction.__count++;\n pendingInteractions.add(interaction);\n });\n else {\n pendingInteractionMap.set(lane, new Set(interactions)); // Update the pending async work count for the current interactions.\n interactions.forEach(function(interaction) {\n interaction.__count++;\n });\n }\n var subscriber = tracing.__subscriberRef.current;\n if (subscriber !== null) {\n var threadID = computeThreadID(root, lane);\n subscriber.onWorkScheduled(interactions, threadID);\n }\n }\n }\n function schedulePendingInteractions(root, lane) {\n scheduleInteractions(root, lane, tracing.__interactionsRef.current);\n }\n function startWorkOnPendingInteractions(root, lanes) {\n // we can accurately attribute time spent working on it, And so that cascading\n // work triggered during the render phase will be associated with it.\n var interactions = new Set();\n root.pendingInteractionMap.forEach(function(scheduledInteractions, scheduledLane) {\n if (includesSomeLane(lanes, scheduledLane)) scheduledInteractions.forEach(function(interaction) {\n return interactions.add(interaction);\n });\n }); // Store the current set of interactions on the FiberRoot for a few reasons:\n // We can re-use it in hot functions like performConcurrentWorkOnRoot()\n // without having to recalculate it. We will also use it in commitWork() to\n // pass to any Profiler onRender() hooks. This also provides DevTools with a\n // way to access it when the onCommitRoot() hook is called.\n root.memoizedInteractions = interactions;\n if (interactions.size > 0) {\n var subscriber = tracing.__subscriberRef.current;\n if (subscriber !== null) {\n var threadID = computeThreadID(root, lanes);\n try {\n subscriber.onWorkStarted(interactions, threadID);\n } catch (error) {\n // If the subscriber throws, rethrow it in a separate task\n scheduleCallback(ImmediatePriority$1, function() {\n throw error;\n });\n }\n }\n }\n }\n function finishPendingInteractions(root, committedLanes) {\n var remainingLanesAfterCommit = root.pendingLanes;\n var subscriber;\n try {\n subscriber = tracing.__subscriberRef.current;\n if (subscriber !== null && root.memoizedInteractions.size > 0) {\n // FIXME: More than one lane can finish in a single commit.\n var threadID = computeThreadID(root, committedLanes);\n subscriber.onWorkStopped(root.memoizedInteractions, threadID);\n }\n } catch (error2) {\n // If the subscriber throws, rethrow it in a separate task\n scheduleCallback(ImmediatePriority$1, function() {\n throw error2;\n });\n } finally{\n // Clear completed interactions from the pending Map.\n // Unless the render was suspended or cascading work was scheduled,\n // In which case\u2013 leave pending interactions until the subsequent render.\n var pendingInteractionMap = root.pendingInteractionMap;\n pendingInteractionMap.forEach(function(scheduledInteractions, lane) {\n // Only decrement the pending interaction count if we're done.\n // If there's still work at the current priority,\n // That indicates that we are waiting for suspense data.\n if (!includesSomeLane(remainingLanesAfterCommit, lane)) {\n pendingInteractionMap.delete(lane);\n scheduledInteractions.forEach(function(interaction) {\n interaction.__count--;\n if (subscriber !== null && interaction.__count === 0) try {\n subscriber.onInteractionScheduledWorkCompleted(interaction);\n } catch (error) {\n // If the subscriber throws, rethrow it in a separate task\n scheduleCallback(ImmediatePriority$1, function() {\n throw error;\n });\n }\n });\n }\n });\n }\n } // `act` testing API\n function shouldForceFlushFallbacksInDEV() {\n // Never force flush in production. This function should get stripped out.\n return actingUpdatesScopeDepth > 0;\n }\n // so we can tell if any async act() calls try to run in parallel.\n var actingUpdatesScopeDepth = 0;\n function detachFiberAfterEffects(fiber) {\n fiber.sibling = null;\n fiber.stateNode = null;\n }\n var resolveFamily = null; // $FlowFixMe Flow gets confused by a WeakSet feature check below.\n var failedBoundaries = null;\n var setRefreshHandler = function(handler) {\n resolveFamily = handler;\n };\n function resolveFunctionForHotReloading(type) {\n if (resolveFamily === null) // Hot reloading is disabled.\n return type;\n var family = resolveFamily(type);\n if (family === undefined) return type;\n // Use the latest known implementation.\n return family.current;\n }\n function resolveClassForHotReloading(type) {\n // No implementation differences.\n return resolveFunctionForHotReloading(type);\n }\n function resolveForwardRefForHotReloading(type) {\n if (resolveFamily === null) // Hot reloading is disabled.\n return type;\n var family = resolveFamily(type);\n if (family === undefined) {\n // Check if we're dealing with a real forwardRef. Don't want to crash early.\n if (type !== null && type !== undefined && typeof type.render === 'function') {\n // ForwardRef is special because its resolved .type is an object,\n // but it's possible that we only have its inner render function in the map.\n // If that inner render function is different, we'll build a new forwardRef type.\n var currentRender = resolveFunctionForHotReloading(type.render);\n if (type.render !== currentRender) {\n var syntheticType = {\n $$typeof: REACT_FORWARD_REF_TYPE,\n render: currentRender\n };\n if (type.displayName !== undefined) syntheticType.displayName = type.displayName;\n return syntheticType;\n }\n }\n return type;\n } // Use the latest known implementation.\n return family.current;\n }\n function isCompatibleFamilyForHotReloading(fiber, element) {\n if (resolveFamily === null) // Hot reloading is disabled.\n return false;\n var prevType = fiber.elementType;\n var nextType = element.type; // If we got here, we know types aren't === equal.\n var needsCompareFamilies = false;\n var $$typeofNextType = typeof nextType === 'object' && nextType !== null ? nextType.$$typeof : null;\n switch(fiber.tag){\n case ClassComponent:\n if (typeof nextType === 'function') needsCompareFamilies = true;\n break;\n case FunctionComponent:\n if (typeof nextType === 'function') needsCompareFamilies = true;\n else if ($$typeofNextType === REACT_LAZY_TYPE) // We don't know the inner type yet.\n // We're going to assume that the lazy inner type is stable,\n // and so it is sufficient to avoid reconciling it away.\n // We're not going to unwrap or actually use the new lazy type.\n needsCompareFamilies = true;\n break;\n case ForwardRef:\n if ($$typeofNextType === REACT_FORWARD_REF_TYPE) needsCompareFamilies = true;\n else if ($$typeofNextType === REACT_LAZY_TYPE) needsCompareFamilies = true;\n break;\n case MemoComponent:\n case SimpleMemoComponent:\n if ($$typeofNextType === REACT_MEMO_TYPE) // TODO: if it was but can no longer be simple,\n // we shouldn't set this.\n needsCompareFamilies = true;\n else if ($$typeofNextType === REACT_LAZY_TYPE) needsCompareFamilies = true;\n break;\n default:\n return false;\n } // Check if both types have a family and it's the same one.\n if (needsCompareFamilies) {\n // Note: memo() and forwardRef() we'll compare outer rather than inner type.\n // This means both of them need to be registered to preserve state.\n // If we unwrapped and compared the inner types for wrappers instead,\n // then we would risk falsely saying two separate memo(Foo)\n // calls are equivalent because they wrap the same Foo function.\n var prevFamily = resolveFamily(prevType);\n if (prevFamily !== undefined && prevFamily === resolveFamily(nextType)) return true;\n }\n return false;\n }\n function markFailedErrorBoundaryForHotReloading(fiber) {\n if (resolveFamily === null) // Hot reloading is disabled.\n return;\n if (typeof WeakSet !== 'function') return;\n if (failedBoundaries === null) failedBoundaries = new WeakSet();\n failedBoundaries.add(fiber);\n }\n var scheduleRefresh = function(root, update) {\n if (resolveFamily === null) // Hot reloading is disabled.\n return;\n var staleFamilies = update.staleFamilies, updatedFamilies = update.updatedFamilies;\n flushPassiveEffects();\n flushSync(function() {\n scheduleFibersWithFamiliesRecursively(root.current, updatedFamilies, staleFamilies);\n });\n };\n var scheduleRoot = function(root, element) {\n if (root.context !== emptyContextObject) // Super edge case: root has a legacy _renderSubtree context\n // but we don't know the parentComponent so we can't pass it.\n // Just ignore. We'll delete this with _renderSubtree code path later.\n return;\n flushPassiveEffects();\n flushSync(function() {\n updateContainer(element, root, null, null);\n });\n };\n function scheduleFibersWithFamiliesRecursively(fiber, updatedFamilies, staleFamilies) {\n var alternate = fiber.alternate, child = fiber.child, sibling = fiber.sibling, tag = fiber.tag, type = fiber.type;\n var candidateType = null;\n switch(tag){\n case FunctionComponent:\n case SimpleMemoComponent:\n case ClassComponent:\n candidateType = type;\n break;\n case ForwardRef:\n candidateType = type.render;\n break;\n }\n if (resolveFamily === null) throw new Error('Expected resolveFamily to be set during hot reload.');\n var needsRender = false;\n var needsRemount = false;\n if (candidateType !== null) {\n var family = resolveFamily(candidateType);\n if (family !== undefined) {\n if (staleFamilies.has(family)) needsRemount = true;\n else if (updatedFamilies.has(family)) {\n if (tag === ClassComponent) needsRemount = true;\n else needsRender = true;\n }\n }\n }\n if (failedBoundaries !== null) {\n if (failedBoundaries.has(fiber) || alternate !== null && failedBoundaries.has(alternate)) needsRemount = true;\n }\n if (needsRemount) fiber._debugNeedsRemount = true;\n if (needsRemount || needsRender) scheduleUpdateOnFiber(fiber, SyncLane, NoTimestamp);\n if (child !== null && !needsRemount) scheduleFibersWithFamiliesRecursively(child, updatedFamilies, staleFamilies);\n if (sibling !== null) scheduleFibersWithFamiliesRecursively(sibling, updatedFamilies, staleFamilies);\n }\n var findHostInstancesForRefresh = function(root, families) {\n var hostInstances = new Set();\n var types = new Set(families.map(function(family) {\n return family.current;\n }));\n findHostInstancesForMatchingFibersRecursively(root.current, types, hostInstances);\n return hostInstances;\n };\n function findHostInstancesForMatchingFibersRecursively(fiber, types, hostInstances) {\n var child = fiber.child, sibling = fiber.sibling, tag = fiber.tag, type = fiber.type;\n var candidateType = null;\n switch(tag){\n case FunctionComponent:\n case SimpleMemoComponent:\n case ClassComponent:\n candidateType = type;\n break;\n case ForwardRef:\n candidateType = type.render;\n break;\n }\n var didMatch = false;\n if (candidateType !== null) {\n if (types.has(candidateType)) didMatch = true;\n }\n if (didMatch) // We have a match. This only drills down to the closest host components.\n // There's no need to search deeper because for the purpose of giving\n // visual feedback, \"flashing\" outermost parent rectangles is sufficient.\n findHostInstancesForFiberShallowly(fiber, hostInstances);\n else // If there's no match, maybe there will be one further down in the child tree.\n if (child !== null) findHostInstancesForMatchingFibersRecursively(child, types, hostInstances);\n if (sibling !== null) findHostInstancesForMatchingFibersRecursively(sibling, types, hostInstances);\n }\n function findHostInstancesForFiberShallowly(fiber, hostInstances) {\n var foundHostInstances = findChildHostInstancesForFiberShallowly(fiber, hostInstances);\n if (foundHostInstances) return;\n // If we didn't find any host children, fallback to closest host parent.\n var node = fiber;\n while(true){\n switch(node.tag){\n case HostComponent:\n hostInstances.add(node.stateNode);\n return;\n case HostPortal:\n hostInstances.add(node.stateNode.containerInfo);\n return;\n case HostRoot:\n hostInstances.add(node.stateNode.containerInfo);\n return;\n }\n if (node.return === null) throw new Error('Expected to reach root first.');\n node = node.return;\n }\n }\n function findChildHostInstancesForFiberShallowly(fiber, hostInstances) {\n var node = fiber;\n var foundHostInstances = false;\n while(true){\n if (node.tag === HostComponent) {\n // We got a match.\n foundHostInstances = true;\n hostInstances.add(node.stateNode); // There may still be more, so keep searching.\n } else if (node.child !== null) {\n node.child.return = node;\n node = node.child;\n continue;\n }\n if (node === fiber) return foundHostInstances;\n while(node.sibling === null){\n if (node.return === null || node.return === fiber) return foundHostInstances;\n node = node.return;\n }\n node.sibling.return = node.return;\n node = node.sibling;\n }\n return false;\n }\n var hasBadMapPolyfill;\n hasBadMapPolyfill = false;\n try {\n var nonExtensibleObject = Object.preventExtensions({\n });\n /* eslint-disable no-new */ new Map([\n [\n nonExtensibleObject,\n null\n ]\n ]);\n new Set([\n nonExtensibleObject\n ]);\n /* eslint-enable no-new */ } catch (e) {\n // TODO: Consider warning about bad polyfills\n hasBadMapPolyfill = true;\n }\n var debugCounter = 1;\n function FiberNode(tag, pendingProps, key, mode) {\n // Instance\n this.tag = tag;\n this.key = key;\n this.elementType = null;\n this.type = null;\n this.stateNode = null; // Fiber\n this.return = null;\n this.child = null;\n this.sibling = null;\n this.index = 0;\n this.ref = null;\n this.pendingProps = pendingProps;\n this.memoizedProps = null;\n this.updateQueue = null;\n this.memoizedState = null;\n this.dependencies = null;\n this.mode = mode; // Effects\n this.flags = NoFlags;\n this.nextEffect = null;\n this.firstEffect = null;\n this.lastEffect = null;\n this.lanes = NoLanes;\n this.childLanes = NoLanes;\n this.alternate = null;\n // Note: The following is done to avoid a v8 performance cliff.\n //\n // Initializing the fields below to smis and later updating them with\n // double values will cause Fibers to end up having separate shapes.\n // This behavior/bug has something to do with Object.preventExtension().\n // Fortunately this only impacts DEV builds.\n // Unfortunately it makes React unusably slow for some applications.\n // To work around this, initialize the fields below with doubles.\n //\n // Learn more about this here:\n // https://github.com/facebook/react/issues/14365\n // https://bugs.chromium.org/p/v8/issues/detail?id=8538\n this.actualDuration = Number.NaN;\n this.actualStartTime = Number.NaN;\n this.selfBaseDuration = Number.NaN;\n this.treeBaseDuration = Number.NaN; // It's okay to replace the initial doubles with smis after initialization.\n // This won't trigger the performance cliff mentioned above,\n // and it simplifies other profiler code (including DevTools).\n this.actualDuration = 0;\n this.actualStartTime = -1;\n this.selfBaseDuration = 0;\n this.treeBaseDuration = 0;\n // This isn't directly used but is handy for debugging internals:\n this._debugID = debugCounter++;\n this._debugSource = null;\n this._debugOwner = null;\n this._debugNeedsRemount = false;\n this._debugHookTypes = null;\n if (!hasBadMapPolyfill && typeof Object.preventExtensions === 'function') Object.preventExtensions(this);\n } // This is a constructor function, rather than a POJO constructor, still\n // please ensure we do the following:\n // 1) Nobody should add any instance methods on this. Instance methods can be\n // more difficult to predict when they get optimized and they are almost\n // never inlined properly in static compilers.\n // 2) Nobody should rely on `instanceof Fiber` for type testing. We should\n // always know when it is a fiber.\n // 3) We might want to experiment with using numeric keys since they are easier\n // to optimize in a non-JIT environment.\n // 4) We can easily go from a constructor to a createFiber object literal if that\n // is faster.\n // 5) It should be easy to port this to a C struct and keep a C implementation\n // compatible.\n var createFiber = function(tag, pendingProps, key, mode) {\n // $FlowFixMe: the shapes are exact here but Flow doesn't like constructors\n return new FiberNode(tag, pendingProps, key, mode);\n };\n function shouldConstruct$1(Component) {\n var prototype = Component.prototype;\n return !!(prototype && prototype.isReactComponent);\n }\n function isSimpleFunctionComponent(type) {\n return typeof type === 'function' && !shouldConstruct$1(type) && type.defaultProps === undefined;\n }\n function resolveLazyComponentTag(Component) {\n if (typeof Component === 'function') return shouldConstruct$1(Component) ? ClassComponent : FunctionComponent;\n else if (Component !== undefined && Component !== null) {\n var $$typeof = Component.$$typeof;\n if ($$typeof === REACT_FORWARD_REF_TYPE) return ForwardRef;\n if ($$typeof === REACT_MEMO_TYPE) return MemoComponent;\n }\n return IndeterminateComponent;\n } // This is used to create an alternate fiber to do work on.\n function createWorkInProgress(current, pendingProps) {\n var workInProgress = current.alternate;\n if (workInProgress === null) {\n // We use a double buffering pooling technique because we know that we'll\n // only ever need at most two versions of a tree. We pool the \"other\" unused\n // node that we're free to reuse. This is lazily created to avoid allocating\n // extra objects for things that are never updated. It also allow us to\n // reclaim the extra memory if needed.\n workInProgress = createFiber(current.tag, pendingProps, current.key, current.mode);\n workInProgress.elementType = current.elementType;\n workInProgress.type = current.type;\n workInProgress.stateNode = current.stateNode;\n // DEV-only fields\n workInProgress._debugID = current._debugID;\n workInProgress._debugSource = current._debugSource;\n workInProgress._debugOwner = current._debugOwner;\n workInProgress._debugHookTypes = current._debugHookTypes;\n workInProgress.alternate = current;\n current.alternate = workInProgress;\n } else {\n workInProgress.pendingProps = pendingProps; // Needed because Blocks store data on type.\n workInProgress.type = current.type; // We already have an alternate.\n // Reset the effect tag.\n workInProgress.flags = NoFlags; // The effect list is no longer valid.\n workInProgress.nextEffect = null;\n workInProgress.firstEffect = null;\n workInProgress.lastEffect = null;\n // We intentionally reset, rather than copy, actualDuration & actualStartTime.\n // This prevents time from endlessly accumulating in new commits.\n // This has the downside of resetting values for different priority renders,\n // But works for yielding (the common case) and should support resuming.\n workInProgress.actualDuration = 0;\n workInProgress.actualStartTime = -1;\n }\n workInProgress.childLanes = current.childLanes;\n workInProgress.lanes = current.lanes;\n workInProgress.child = current.child;\n workInProgress.memoizedProps = current.memoizedProps;\n workInProgress.memoizedState = current.memoizedState;\n workInProgress.updateQueue = current.updateQueue; // Clone the dependencies object. This is mutated during the render phase, so\n // it cannot be shared with the current fiber.\n var currentDependencies = current.dependencies;\n workInProgress.dependencies = currentDependencies === null ? null : {\n lanes: currentDependencies.lanes,\n firstContext: currentDependencies.firstContext\n }; // These will be overridden during the parent's reconciliation\n workInProgress.sibling = current.sibling;\n workInProgress.index = current.index;\n workInProgress.ref = current.ref;\n workInProgress.selfBaseDuration = current.selfBaseDuration;\n workInProgress.treeBaseDuration = current.treeBaseDuration;\n workInProgress._debugNeedsRemount = current._debugNeedsRemount;\n switch(workInProgress.tag){\n case IndeterminateComponent:\n case FunctionComponent:\n case SimpleMemoComponent:\n workInProgress.type = resolveFunctionForHotReloading(current.type);\n break;\n case ClassComponent:\n workInProgress.type = resolveClassForHotReloading(current.type);\n break;\n case ForwardRef:\n workInProgress.type = resolveForwardRefForHotReloading(current.type);\n break;\n }\n return workInProgress;\n } // Used to reuse a Fiber for a second pass.\n function resetWorkInProgress(workInProgress, renderLanes) {\n // This resets the Fiber to what createFiber or createWorkInProgress would\n // have set the values to before during the first pass. Ideally this wouldn't\n // be necessary but unfortunately many code paths reads from the workInProgress\n // when they should be reading from current and writing to workInProgress.\n // We assume pendingProps, index, key, ref, return are still untouched to\n // avoid doing another reconciliation.\n // Reset the effect tag but keep any Placement tags, since that's something\n // that child fiber is setting, not the reconciliation.\n workInProgress.flags &= Placement; // The effect list is no longer valid.\n workInProgress.nextEffect = null;\n workInProgress.firstEffect = null;\n workInProgress.lastEffect = null;\n var current = workInProgress.alternate;\n if (current === null) {\n // Reset to createFiber's initial values.\n workInProgress.childLanes = NoLanes;\n workInProgress.lanes = renderLanes;\n workInProgress.child = null;\n workInProgress.memoizedProps = null;\n workInProgress.memoizedState = null;\n workInProgress.updateQueue = null;\n workInProgress.dependencies = null;\n workInProgress.stateNode = null;\n // Note: We don't reset the actualTime counts. It's useful to accumulate\n // actual time across multiple render passes.\n workInProgress.selfBaseDuration = 0;\n workInProgress.treeBaseDuration = 0;\n } else {\n // Reset to the cloned values that createWorkInProgress would've.\n workInProgress.childLanes = current.childLanes;\n workInProgress.lanes = current.lanes;\n workInProgress.child = current.child;\n workInProgress.memoizedProps = current.memoizedProps;\n workInProgress.memoizedState = current.memoizedState;\n workInProgress.updateQueue = current.updateQueue; // Needed because Blocks store data on type.\n workInProgress.type = current.type; // Clone the dependencies object. This is mutated during the render phase, so\n // it cannot be shared with the current fiber.\n var currentDependencies = current.dependencies;\n workInProgress.dependencies = currentDependencies === null ? null : {\n lanes: currentDependencies.lanes,\n firstContext: currentDependencies.firstContext\n };\n // Note: We don't reset the actualTime counts. It's useful to accumulate\n // actual time across multiple render passes.\n workInProgress.selfBaseDuration = current.selfBaseDuration;\n workInProgress.treeBaseDuration = current.treeBaseDuration;\n }\n return workInProgress;\n }\n function createHostRootFiber(tag) {\n var mode;\n if (tag === ConcurrentRoot) mode = ConcurrentMode | BlockingMode | StrictMode;\n else if (tag === BlockingRoot) mode = BlockingMode | StrictMode;\n else mode = NoMode;\n if (isDevToolsPresent) // Always collect profile timings when DevTools are present.\n // This enables DevTools to start capturing timing at any point\u2013\n // Without some nodes in the tree having empty base times.\n mode |= ProfileMode;\n return createFiber(HostRoot, null, null, mode);\n }\n function createFiberFromTypeAndProps(type, key, pendingProps, owner, mode, lanes) {\n var fiberTag = IndeterminateComponent; // The resolved type is set if we know what the final type will be. I.e. it's not lazy.\n var resolvedType = type;\n if (typeof type === 'function') {\n if (shouldConstruct$1(type)) {\n fiberTag = ClassComponent;\n resolvedType = resolveClassForHotReloading(resolvedType);\n } else resolvedType = resolveFunctionForHotReloading(resolvedType);\n } else if (typeof type === 'string') fiberTag = HostComponent;\n else getTag: switch(type){\n case REACT_FRAGMENT_TYPE:\n return createFiberFromFragment(pendingProps.children, mode, lanes, key);\n case REACT_DEBUG_TRACING_MODE_TYPE:\n fiberTag = Mode;\n mode |= DebugTracingMode;\n break;\n case REACT_STRICT_MODE_TYPE:\n fiberTag = Mode;\n mode |= StrictMode;\n break;\n case REACT_PROFILER_TYPE:\n return createFiberFromProfiler(pendingProps, mode, lanes, key);\n case REACT_SUSPENSE_TYPE:\n return createFiberFromSuspense(pendingProps, mode, lanes, key);\n case REACT_SUSPENSE_LIST_TYPE:\n return createFiberFromSuspenseList(pendingProps, mode, lanes, key);\n case REACT_OFFSCREEN_TYPE:\n return createFiberFromOffscreen(pendingProps, mode, lanes, key);\n case REACT_LEGACY_HIDDEN_TYPE:\n return createFiberFromLegacyHidden(pendingProps, mode, lanes, key);\n case REACT_SCOPE_TYPE:\n // eslint-disable-next-line no-fallthrough\n default:\n if (typeof type === 'object' && type !== null) switch(type.$$typeof){\n case REACT_PROVIDER_TYPE:\n fiberTag = ContextProvider;\n break getTag;\n case REACT_CONTEXT_TYPE:\n // This is a consumer\n fiberTag = ContextConsumer;\n break getTag;\n case REACT_FORWARD_REF_TYPE:\n fiberTag = ForwardRef;\n resolvedType = resolveForwardRefForHotReloading(resolvedType);\n break getTag;\n case REACT_MEMO_TYPE:\n fiberTag = MemoComponent;\n break getTag;\n case REACT_LAZY_TYPE:\n fiberTag = LazyComponent;\n resolvedType = null;\n break getTag;\n case REACT_BLOCK_TYPE:\n fiberTag = Block;\n break getTag;\n }\n var info = '';\n if (type === undefined || typeof type === 'object' && type !== null && Object.keys(type).length === 0) info += \" You likely forgot to export your component from the file it's defined in, or you might have mixed up default and named imports.\";\n var ownerName = owner ? getComponentName(owner.type) : null;\n if (ownerName) info += '\\n\\nCheck the render method of `' + ownerName + '`.';\n throw Error(\"Element type is invalid: expected a string (for built-in components) or a class/function (for composite components) but got: \" + (type == null ? type : typeof type) + \".\" + info);\n }\n var fiber = createFiber(fiberTag, pendingProps, key, mode);\n fiber.elementType = type;\n fiber.type = resolvedType;\n fiber.lanes = lanes;\n fiber._debugOwner = owner;\n return fiber;\n }\n function createFiberFromElement(element, mode, lanes) {\n var owner = null;\n owner = element._owner;\n var type = element.type;\n var key = element.key;\n var pendingProps = element.props;\n var fiber = createFiberFromTypeAndProps(type, key, pendingProps, owner, mode, lanes);\n fiber._debugSource = element._source;\n fiber._debugOwner = element._owner;\n return fiber;\n }\n function createFiberFromFragment(elements, mode, lanes, key) {\n var fiber = createFiber(Fragment, elements, key, mode);\n fiber.lanes = lanes;\n return fiber;\n }\n function createFiberFromProfiler(pendingProps, mode, lanes, key) {\n if (typeof pendingProps.id !== 'string') error1('Profiler must specify an \"id\" as a prop');\n var fiber = createFiber(Profiler, pendingProps, key, mode | ProfileMode); // TODO: The Profiler fiber shouldn't have a type. It has a tag.\n fiber.elementType = REACT_PROFILER_TYPE;\n fiber.type = REACT_PROFILER_TYPE;\n fiber.lanes = lanes;\n fiber.stateNode = {\n effectDuration: 0,\n passiveEffectDuration: 0\n };\n return fiber;\n }\n function createFiberFromSuspense(pendingProps, mode, lanes, key) {\n var fiber = createFiber(SuspenseComponent, pendingProps, key, mode); // TODO: The SuspenseComponent fiber shouldn't have a type. It has a tag.\n // This needs to be fixed in getComponentName so that it relies on the tag\n // instead.\n fiber.type = REACT_SUSPENSE_TYPE;\n fiber.elementType = REACT_SUSPENSE_TYPE;\n fiber.lanes = lanes;\n return fiber;\n }\n function createFiberFromSuspenseList(pendingProps, mode, lanes, key) {\n var fiber = createFiber(SuspenseListComponent, pendingProps, key, mode);\n // TODO: The SuspenseListComponent fiber shouldn't have a type. It has a tag.\n // This needs to be fixed in getComponentName so that it relies on the tag\n // instead.\n fiber.type = REACT_SUSPENSE_LIST_TYPE;\n fiber.elementType = REACT_SUSPENSE_LIST_TYPE;\n fiber.lanes = lanes;\n return fiber;\n }\n function createFiberFromOffscreen(pendingProps, mode, lanes, key) {\n var fiber = createFiber(OffscreenComponent, pendingProps, key, mode); // TODO: The OffscreenComponent fiber shouldn't have a type. It has a tag.\n fiber.type = REACT_OFFSCREEN_TYPE;\n fiber.elementType = REACT_OFFSCREEN_TYPE;\n fiber.lanes = lanes;\n return fiber;\n }\n function createFiberFromLegacyHidden(pendingProps, mode, lanes, key) {\n var fiber = createFiber(LegacyHiddenComponent, pendingProps, key, mode); // TODO: The LegacyHidden fiber shouldn't have a type. It has a tag.\n fiber.type = REACT_LEGACY_HIDDEN_TYPE;\n fiber.elementType = REACT_LEGACY_HIDDEN_TYPE;\n fiber.lanes = lanes;\n return fiber;\n }\n function createFiberFromText(content, mode, lanes) {\n var fiber = createFiber(HostText, content, null, mode);\n fiber.lanes = lanes;\n return fiber;\n }\n function createFiberFromHostInstanceForDeletion() {\n var fiber = createFiber(HostComponent, null, null, NoMode); // TODO: These should not need a type.\n fiber.elementType = 'DELETED';\n fiber.type = 'DELETED';\n return fiber;\n }\n function createFiberFromPortal(portal, mode, lanes) {\n var pendingProps = portal.children !== null ? portal.children : [];\n var fiber = createFiber(HostPortal, pendingProps, portal.key, mode);\n fiber.lanes = lanes;\n fiber.stateNode = {\n containerInfo: portal.containerInfo,\n pendingChildren: null,\n // Used by persistent updates\n implementation: portal.implementation\n };\n return fiber;\n } // Used for stashing WIP properties to replay failed work in DEV.\n function assignFiberPropertiesInDEV(target, source) {\n if (target === null) // This Fiber's initial properties will always be overwritten.\n // We only use a Fiber to ensure the same hidden class so DEV isn't slow.\n target = createFiber(IndeterminateComponent, null, null, NoMode);\n // This is intentionally written as a list of all properties.\n // We tried to use Object.assign() instead but this is called in\n // the hottest path, and Object.assign() was too slow:\n // https://github.com/facebook/react/issues/12502\n // This code is DEV-only so size is not a concern.\n target.tag = source.tag;\n target.key = source.key;\n target.elementType = source.elementType;\n target.type = source.type;\n target.stateNode = source.stateNode;\n target.return = source.return;\n target.child = source.child;\n target.sibling = source.sibling;\n target.index = source.index;\n target.ref = source.ref;\n target.pendingProps = source.pendingProps;\n target.memoizedProps = source.memoizedProps;\n target.updateQueue = source.updateQueue;\n target.memoizedState = source.memoizedState;\n target.dependencies = source.dependencies;\n target.mode = source.mode;\n target.flags = source.flags;\n target.nextEffect = source.nextEffect;\n target.firstEffect = source.firstEffect;\n target.lastEffect = source.lastEffect;\n target.lanes = source.lanes;\n target.childLanes = source.childLanes;\n target.alternate = source.alternate;\n target.actualDuration = source.actualDuration;\n target.actualStartTime = source.actualStartTime;\n target.selfBaseDuration = source.selfBaseDuration;\n target.treeBaseDuration = source.treeBaseDuration;\n target._debugID = source._debugID;\n target._debugSource = source._debugSource;\n target._debugOwner = source._debugOwner;\n target._debugNeedsRemount = source._debugNeedsRemount;\n target._debugHookTypes = source._debugHookTypes;\n return target;\n }\n function FiberRootNode(containerInfo, tag, hydrate) {\n this.tag = tag;\n this.containerInfo = containerInfo;\n this.pendingChildren = null;\n this.current = null;\n this.pingCache = null;\n this.finishedWork = null;\n this.timeoutHandle = noTimeout;\n this.context = null;\n this.pendingContext = null;\n this.hydrate = hydrate;\n this.callbackNode = null;\n this.callbackPriority = NoLanePriority;\n this.eventTimes = createLaneMap(NoLanes);\n this.expirationTimes = createLaneMap(NoTimestamp);\n this.pendingLanes = NoLanes;\n this.suspendedLanes = NoLanes;\n this.pingedLanes = NoLanes;\n this.expiredLanes = NoLanes;\n this.mutableReadLanes = NoLanes;\n this.finishedLanes = NoLanes;\n this.entangledLanes = NoLanes;\n this.entanglements = createLaneMap(NoLanes);\n this.mutableSourceEagerHydrationData = null;\n this.interactionThreadID = tracing.unstable_getThreadID();\n this.memoizedInteractions = new Set();\n this.pendingInteractionMap = new Map();\n switch(tag){\n case BlockingRoot:\n this._debugRootType = 'createBlockingRoot()';\n break;\n case ConcurrentRoot:\n this._debugRootType = 'createRoot()';\n break;\n case LegacyRoot:\n this._debugRootType = 'createLegacyRoot()';\n break;\n }\n }\n function createFiberRoot(containerInfo, tag, hydrate, hydrationCallbacks) {\n var root = new FiberRootNode(containerInfo, tag, hydrate);\n // stateNode is any.\n var uninitializedFiber = createHostRootFiber(tag);\n root.current = uninitializedFiber;\n uninitializedFiber.stateNode = root;\n initializeUpdateQueue(uninitializedFiber);\n return root;\n }\n // This ensures that the version used for server rendering matches the one\n // that is eventually read during hydration.\n // If they don't match there's a potential tear and a full deopt render is required.\n function registerMutableSourceForHydration(root, mutableSource) {\n var getVersion = mutableSource._getVersion;\n var version = getVersion(mutableSource._source); // TODO Clear this data once all pending hydration work is finished.\n // Retaining it forever may interfere with GC.\n if (root.mutableSourceEagerHydrationData == null) root.mutableSourceEagerHydrationData = [\n mutableSource,\n version\n ];\n else root.mutableSourceEagerHydrationData.push(mutableSource, version);\n }\n function createPortal(children, containerInfo, implementation) {\n var key = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null;\n return {\n // This tag allow us to uniquely identify this as a React Portal\n $$typeof: REACT_PORTAL_TYPE,\n key: key == null ? null : '' + key,\n children: children,\n containerInfo: containerInfo,\n implementation: implementation\n };\n }\n var didWarnAboutNestedUpdates;\n var didWarnAboutFindNodeInStrictMode;\n didWarnAboutNestedUpdates = false;\n didWarnAboutFindNodeInStrictMode = {\n };\n function getContextForSubtree(parentComponent) {\n if (!parentComponent) return emptyContextObject;\n var fiber = get1(parentComponent);\n var parentContext = findCurrentUnmaskedContext(fiber);\n if (fiber.tag === ClassComponent) {\n var Component = fiber.type;\n if (isContextProvider(Component)) return processChildContext(fiber, Component, parentContext);\n }\n return parentContext;\n }\n function findHostInstanceWithWarning(component, methodName) {\n var fiber = get1(component);\n if (fiber === undefined) {\n if (typeof component.render === 'function') throw Error(\"Unable to find node on an unmounted component.\");\n else throw Error(\"Argument appears to not be a ReactComponent. Keys: \" + Object.keys(component));\n }\n var hostFiber = findCurrentHostFiber(fiber);\n if (hostFiber === null) return null;\n if (hostFiber.mode & StrictMode) {\n var componentName = getComponentName(fiber.type) || 'Component';\n if (!didWarnAboutFindNodeInStrictMode[componentName]) {\n didWarnAboutFindNodeInStrictMode[componentName] = true;\n var previousFiber = current1;\n try {\n setCurrentFiber(hostFiber);\n if (fiber.mode & StrictMode) error1(\"%s is deprecated in StrictMode. %s was passed an instance of %s which is inside StrictMode. Instead, add a ref directly to the element you want to reference. Learn more about using refs safely here: https://reactjs.org/link/strict-mode-find-node\", methodName, methodName, componentName);\n else error1(\"%s is deprecated in StrictMode. %s was passed an instance of %s which renders StrictMode children. Instead, add a ref directly to the element you want to reference. Learn more about using refs safely here: https://reactjs.org/link/strict-mode-find-node\", methodName, methodName, componentName);\n } finally{\n // Ideally this should reset to previous but this shouldn't be called in\n // render and there's another warning for that anyway.\n if (previousFiber) setCurrentFiber(previousFiber);\n else resetCurrentFiber();\n }\n }\n }\n return hostFiber.stateNode;\n }\n function createContainer(containerInfo, tag, hydrate, hydrationCallbacks) {\n return createFiberRoot(containerInfo, tag, hydrate);\n }\n function updateContainer(element, container, parentComponent, callback) {\n onScheduleRoot(container, element);\n var current$1 = container.current;\n var eventTime = requestEventTime();\n // $FlowExpectedError - jest isn't a global, and isn't recognized outside of tests\n if ('undefined' !== typeof jest) {\n warnIfUnmockedScheduler(current$1);\n warnIfNotScopedWithMatchingAct(current$1);\n }\n var lane = requestUpdateLane(current$1);\n var context = getContextForSubtree(parentComponent);\n if (container.context === null) container.context = context;\n else container.pendingContext = context;\n if (isRendering && current1 !== null && !didWarnAboutNestedUpdates) {\n didWarnAboutNestedUpdates = true;\n error1(\"Render methods should be a pure function of props and state; triggering nested component updates from render is not allowed. If necessary, trigger nested updates in componentDidUpdate.\\n\\nCheck the render method of %s.\", getComponentName(current1.type) || 'Unknown');\n }\n var update = createUpdate(eventTime, lane); // Caution: React DevTools currently depends on this property\n // being called \"element\".\n update.payload = {\n element: element\n };\n callback = callback === undefined ? null : callback;\n if (callback !== null) {\n if (typeof callback !== 'function') error1(\"render(...): Expected the last optional `callback` argument to be a function. Instead received: %s.\", callback);\n update.callback = callback;\n }\n enqueueUpdate(current$1, update);\n scheduleUpdateOnFiber(current$1, lane, eventTime);\n return lane;\n }\n function getPublicRootInstance(container) {\n var containerFiber = container.current;\n if (!containerFiber.child) return null;\n switch(containerFiber.child.tag){\n case HostComponent:\n return getPublicInstance(containerFiber.child.stateNode);\n default:\n return containerFiber.child.stateNode;\n }\n }\n function markRetryLaneImpl(fiber, retryLane) {\n var suspenseState = fiber.memoizedState;\n if (suspenseState !== null && suspenseState.dehydrated !== null) suspenseState.retryLane = higherPriorityLane(suspenseState.retryLane, retryLane);\n } // Increases the priority of thennables when they resolve within this boundary.\n function markRetryLaneIfNotHydrated(fiber, retryLane) {\n markRetryLaneImpl(fiber, retryLane);\n var alternate = fiber.alternate;\n if (alternate) markRetryLaneImpl(alternate, retryLane);\n }\n function attemptUserBlockingHydration$1(fiber) {\n if (fiber.tag !== SuspenseComponent) // We ignore HostRoots here because we can't increase\n // their priority and they should not suspend on I/O,\n // since you have to wrap anything that might suspend in\n // Suspense.\n return;\n var eventTime = requestEventTime();\n var lane = InputDiscreteHydrationLane;\n scheduleUpdateOnFiber(fiber, lane, eventTime);\n markRetryLaneIfNotHydrated(fiber, lane);\n }\n function attemptContinuousHydration$1(fiber) {\n if (fiber.tag !== SuspenseComponent) // We ignore HostRoots here because we can't increase\n // their priority and they should not suspend on I/O,\n // since you have to wrap anything that might suspend in\n // Suspense.\n return;\n var eventTime = requestEventTime();\n var lane = SelectiveHydrationLane;\n scheduleUpdateOnFiber(fiber, lane, eventTime);\n markRetryLaneIfNotHydrated(fiber, lane);\n }\n function attemptHydrationAtCurrentPriority$1(fiber) {\n if (fiber.tag !== SuspenseComponent) // We ignore HostRoots here because we can't increase\n // their priority other than synchronously flush it.\n return;\n var eventTime = requestEventTime();\n var lane = requestUpdateLane(fiber);\n scheduleUpdateOnFiber(fiber, lane, eventTime);\n markRetryLaneIfNotHydrated(fiber, lane);\n }\n function runWithPriority$2(priority, fn) {\n setCurrentUpdateLanePriority(priority);\n return fn();\n }\n function findHostInstanceWithNoPortals(fiber) {\n var hostFiber = findCurrentHostFiberWithNoPortals(fiber);\n if (hostFiber === null) return null;\n if (hostFiber.tag === FundamentalComponent) return hostFiber.stateNode.instance;\n return hostFiber.stateNode;\n }\n var shouldSuspendImpl = function(fiber) {\n return false;\n };\n function shouldSuspend(fiber) {\n return shouldSuspendImpl(fiber);\n }\n var overrideHookState = null;\n var overrideHookStateDeletePath = null;\n var overrideHookStateRenamePath = null;\n var overrideProps = null;\n var overridePropsDeletePath = null;\n var overridePropsRenamePath = null;\n var scheduleUpdate = null;\n var setSuspenseHandler = null;\n var copyWithDeleteImpl = function(obj, path, index) {\n var key = path[index];\n var updated = Array.isArray(obj) ? obj.slice() : _assign({\n }, obj);\n if (index + 1 === path.length) {\n if (Array.isArray(updated)) updated.splice(key, 1);\n else delete updated[key];\n return updated;\n } // $FlowFixMe number or string is fine here\n updated[key] = copyWithDeleteImpl(obj[key], path, index + 1);\n return updated;\n };\n var copyWithDelete = function(obj, path) {\n return copyWithDeleteImpl(obj, path, 0);\n };\n var copyWithRenameImpl = function(obj, oldPath, newPath, index) {\n var oldKey = oldPath[index];\n var updated = Array.isArray(obj) ? obj.slice() : _assign({\n }, obj);\n if (index + 1 === oldPath.length) {\n var newKey = newPath[index]; // $FlowFixMe number or string is fine here\n updated[newKey] = updated[oldKey];\n if (Array.isArray(updated)) updated.splice(oldKey, 1);\n else delete updated[oldKey];\n } else // $FlowFixMe number or string is fine here\n updated[oldKey] = copyWithRenameImpl(obj[oldKey], oldPath, newPath, index + 1);\n return updated;\n };\n var copyWithRename = function(obj, oldPath, newPath) {\n if (oldPath.length !== newPath.length) {\n warn('copyWithRename() expects paths of the same length');\n return;\n } else {\n for(var i = 0; i < newPath.length - 1; i++)if (oldPath[i] !== newPath[i]) {\n warn('copyWithRename() expects paths to be the same except for the deepest key');\n return;\n }\n }\n return copyWithRenameImpl(obj, oldPath, newPath, 0);\n };\n var copyWithSetImpl = function(obj, path, index, value) {\n if (index >= path.length) return value;\n var key = path[index];\n var updated = Array.isArray(obj) ? obj.slice() : _assign({\n }, obj); // $FlowFixMe number or string is fine here\n updated[key] = copyWithSetImpl(obj[key], path, index + 1, value);\n return updated;\n };\n var copyWithSet = function(obj, path, value) {\n return copyWithSetImpl(obj, path, 0, value);\n };\n var findHook = function(fiber, id) {\n // For now, the \"id\" of stateful hooks is just the stateful hook index.\n // This may change in the future with e.g. nested hooks.\n var currentHook = fiber.memoizedState;\n while(currentHook !== null && id > 0){\n currentHook = currentHook.next;\n id--;\n }\n return currentHook;\n }; // Support DevTools editable values for useState and useReducer.\n overrideHookState = function(fiber, id, path, value) {\n var hook = findHook(fiber, id);\n if (hook !== null) {\n var newState = copyWithSet(hook.memoizedState, path, value);\n hook.memoizedState = newState;\n hook.baseState = newState; // We aren't actually adding an update to the queue,\n // because there is no update we can add for useReducer hooks that won't trigger an error.\n // (There's no appropriate action type for DevTools overrides.)\n // As a result though, React will see the scheduled update as a noop and bailout.\n // Shallow cloning props works as a workaround for now to bypass the bailout check.\n fiber.memoizedProps = _assign({\n }, fiber.memoizedProps);\n scheduleUpdateOnFiber(fiber, SyncLane, NoTimestamp);\n }\n };\n overrideHookStateDeletePath = function(fiber, id, path) {\n var hook = findHook(fiber, id);\n if (hook !== null) {\n var newState = copyWithDelete(hook.memoizedState, path);\n hook.memoizedState = newState;\n hook.baseState = newState; // We aren't actually adding an update to the queue,\n // because there is no update we can add for useReducer hooks that won't trigger an error.\n // (There's no appropriate action type for DevTools overrides.)\n // As a result though, React will see the scheduled update as a noop and bailout.\n // Shallow cloning props works as a workaround for now to bypass the bailout check.\n fiber.memoizedProps = _assign({\n }, fiber.memoizedProps);\n scheduleUpdateOnFiber(fiber, SyncLane, NoTimestamp);\n }\n };\n overrideHookStateRenamePath = function(fiber, id, oldPath, newPath) {\n var hook = findHook(fiber, id);\n if (hook !== null) {\n var newState = copyWithRename(hook.memoizedState, oldPath, newPath);\n hook.memoizedState = newState;\n hook.baseState = newState; // We aren't actually adding an update to the queue,\n // because there is no update we can add for useReducer hooks that won't trigger an error.\n // (There's no appropriate action type for DevTools overrides.)\n // As a result though, React will see the scheduled update as a noop and bailout.\n // Shallow cloning props works as a workaround for now to bypass the bailout check.\n fiber.memoizedProps = _assign({\n }, fiber.memoizedProps);\n scheduleUpdateOnFiber(fiber, SyncLane, NoTimestamp);\n }\n }; // Support DevTools props for function components, forwardRef, memo, host components, etc.\n overrideProps = function(fiber, path, value) {\n fiber.pendingProps = copyWithSet(fiber.memoizedProps, path, value);\n if (fiber.alternate) fiber.alternate.pendingProps = fiber.pendingProps;\n scheduleUpdateOnFiber(fiber, SyncLane, NoTimestamp);\n };\n overridePropsDeletePath = function(fiber, path) {\n fiber.pendingProps = copyWithDelete(fiber.memoizedProps, path);\n if (fiber.alternate) fiber.alternate.pendingProps = fiber.pendingProps;\n scheduleUpdateOnFiber(fiber, SyncLane, NoTimestamp);\n };\n overridePropsRenamePath = function(fiber, oldPath, newPath) {\n fiber.pendingProps = copyWithRename(fiber.memoizedProps, oldPath, newPath);\n if (fiber.alternate) fiber.alternate.pendingProps = fiber.pendingProps;\n scheduleUpdateOnFiber(fiber, SyncLane, NoTimestamp);\n };\n scheduleUpdate = function(fiber) {\n scheduleUpdateOnFiber(fiber, SyncLane, NoTimestamp);\n };\n setSuspenseHandler = function(newShouldSuspendImpl) {\n shouldSuspendImpl = newShouldSuspendImpl;\n };\n function findHostInstanceByFiber(fiber) {\n var hostFiber = findCurrentHostFiber(fiber);\n if (hostFiber === null) return null;\n return hostFiber.stateNode;\n }\n function emptyFindFiberByHostInstance(instance) {\n return null;\n }\n function getCurrentFiberForDevTools() {\n return current1;\n }\n function injectIntoDevTools(devToolsConfig) {\n var findFiberByHostInstance = devToolsConfig.findFiberByHostInstance;\n var ReactCurrentDispatcher = ReactSharedInternals.ReactCurrentDispatcher;\n return injectInternals({\n bundleType: devToolsConfig.bundleType,\n version: devToolsConfig.version,\n rendererPackageName: devToolsConfig.rendererPackageName,\n rendererConfig: devToolsConfig.rendererConfig,\n overrideHookState: overrideHookState,\n overrideHookStateDeletePath: overrideHookStateDeletePath,\n overrideHookStateRenamePath: overrideHookStateRenamePath,\n overrideProps: overrideProps,\n overridePropsDeletePath: overridePropsDeletePath,\n overridePropsRenamePath: overridePropsRenamePath,\n setSuspenseHandler: setSuspenseHandler,\n scheduleUpdate: scheduleUpdate,\n currentDispatcherRef: ReactCurrentDispatcher,\n findHostInstanceByFiber: findHostInstanceByFiber,\n findFiberByHostInstance: findFiberByHostInstance || emptyFindFiberByHostInstance,\n // React Refresh\n findHostInstancesForRefresh: findHostInstancesForRefresh,\n scheduleRefresh: scheduleRefresh,\n scheduleRoot: scheduleRoot,\n setRefreshHandler: setRefreshHandler,\n // Enables DevTools to append owner stacks to error messages in DEV mode.\n getCurrentFiber: getCurrentFiberForDevTools\n });\n }\n function ReactDOMRoot(container, options) {\n this._internalRoot = createRootImpl(container, ConcurrentRoot, options);\n }\n function ReactDOMBlockingRoot(container, tag, options) {\n this._internalRoot = createRootImpl(container, tag, options);\n }\n ReactDOMRoot.prototype.render = ReactDOMBlockingRoot.prototype.render = function(children) {\n var root = this._internalRoot;\n if (typeof arguments[1] === 'function') error1(\"render(...): does not support the second callback argument. To execute a side effect after rendering, declare it in a component body with useEffect().\");\n var container = root.containerInfo;\n if (container.nodeType !== COMMENT_NODE) {\n var hostInstance = findHostInstanceWithNoPortals(root.current);\n if (hostInstance) {\n if (hostInstance.parentNode !== container) error1(\"render(...): It looks like the React-rendered content of the root container was removed without using React. This is not supported and will cause errors. Instead, call root.unmount() to empty a root's container.\");\n }\n }\n updateContainer(children, root, null, null);\n };\n ReactDOMRoot.prototype.unmount = ReactDOMBlockingRoot.prototype.unmount = function() {\n if (typeof arguments[0] === 'function') error1(\"unmount(...): does not support a callback argument. To execute a side effect after rendering, declare it in a component body with useEffect().\");\n var root = this._internalRoot;\n var container = root.containerInfo;\n updateContainer(null, root, null, function() {\n unmarkContainerAsRoot(container);\n });\n };\n function createRootImpl(container, tag, options) {\n // Tag is either LegacyRoot or Concurrent Root\n var hydrate = options != null && options.hydrate === true;\n var hydrationCallbacks = options != null && options.hydrationOptions || null;\n var mutableSources = options != null && options.hydrationOptions != null && options.hydrationOptions.mutableSources || null;\n var root = createContainer(container, tag, hydrate);\n markContainerAsRoot(root.current, container);\n var containerNodeType = container.nodeType;\n var rootContainerElement = container.nodeType === COMMENT_NODE ? container.parentNode : container;\n listenToAllSupportedEvents(rootContainerElement);\n if (mutableSources) for(var i = 0; i < mutableSources.length; i++){\n var mutableSource = mutableSources[i];\n registerMutableSourceForHydration(root, mutableSource);\n }\n return root;\n }\n function createLegacyRoot(container, options) {\n return new ReactDOMBlockingRoot(container, LegacyRoot, options);\n }\n function isValidContainer(node) {\n return !!(node && (node.nodeType === ELEMENT_NODE || node.nodeType === DOCUMENT_NODE || node.nodeType === DOCUMENT_FRAGMENT_NODE || node.nodeType === COMMENT_NODE && node.nodeValue === ' react-mount-point-unstable '));\n }\n var ReactCurrentOwner$3 = ReactSharedInternals.ReactCurrentOwner;\n var topLevelUpdateWarnings;\n var warnedAboutHydrateAPI = false;\n topLevelUpdateWarnings = function(container) {\n if (container._reactRootContainer && container.nodeType !== COMMENT_NODE) {\n var hostInstance = findHostInstanceWithNoPortals(container._reactRootContainer._internalRoot.current);\n if (hostInstance) {\n if (hostInstance.parentNode !== container) error1(\"render(...): It looks like the React-rendered content of this container was removed without using React. This is not supported and will cause errors. Instead, call ReactDOM.unmountComponentAtNode to empty a container.\");\n }\n }\n var isRootRenderedBySomeReact = !!container._reactRootContainer;\n var rootEl = getReactRootElementInContainer(container);\n var hasNonRootReactChild = !!(rootEl && getInstanceFromNode(rootEl));\n if (hasNonRootReactChild && !isRootRenderedBySomeReact) error1(\"render(...): Replacing React-rendered children with a new root component. If you intended to update the children of this node, you should instead have the existing children update their state and render the new components instead of calling ReactDOM.render.\");\n if (container.nodeType === ELEMENT_NODE && container.tagName && container.tagName.toUpperCase() === 'BODY') error1(\"render(): Rendering components directly into document.body is discouraged, since its children are often manipulated by third-party scripts and browser extensions. This may lead to subtle reconciliation issues. Try rendering into a container element created for your app.\");\n };\n function getReactRootElementInContainer(container) {\n if (!container) return null;\n if (container.nodeType === DOCUMENT_NODE) return container.documentElement;\n else return container.firstChild;\n }\n function shouldHydrateDueToLegacyHeuristic(container) {\n var rootElement = getReactRootElementInContainer(container);\n return !!(rootElement && rootElement.nodeType === ELEMENT_NODE && rootElement.hasAttribute(ROOT_ATTRIBUTE_NAME));\n }\n function legacyCreateRootFromDOMContainer(container, forceHydrate) {\n var shouldHydrate = forceHydrate || shouldHydrateDueToLegacyHeuristic(container); // First clear any existing content.\n if (!shouldHydrate) {\n var warned = false;\n var rootSibling;\n while(rootSibling = container.lastChild){\n if (!warned && rootSibling.nodeType === ELEMENT_NODE && rootSibling.hasAttribute(ROOT_ATTRIBUTE_NAME)) {\n warned = true;\n error1(\"render(): Target node has markup rendered by React, but there are unrelated nodes as well. This is most commonly caused by white-space inserted around server-rendered markup.\");\n }\n container.removeChild(rootSibling);\n }\n }\n if (shouldHydrate && !forceHydrate && !warnedAboutHydrateAPI) {\n warnedAboutHydrateAPI = true;\n warn(\"render(): Calling ReactDOM.render() to hydrate server-rendered markup will stop working in React v18. Replace the ReactDOM.render() call with ReactDOM.hydrate() if you want React to attach to the server HTML.\");\n }\n return createLegacyRoot(container, shouldHydrate ? {\n hydrate: true\n } : undefined);\n }\n function warnOnInvalidCallback$1(callback, callerName) {\n if (callback !== null && typeof callback !== 'function') error1(\"%s(...): Expected the last optional `callback` argument to be a function. Instead received: %s.\", callerName, callback);\n }\n function legacyRenderSubtreeIntoContainer(parentComponent, children, container, forceHydrate, callback) {\n topLevelUpdateWarnings(container);\n warnOnInvalidCallback$1(callback === undefined ? null : callback, 'render');\n // member of intersection type.\" Whyyyyyy.\n var root = container._reactRootContainer;\n var fiberRoot;\n if (!root) {\n // Initial mount\n root = container._reactRootContainer = legacyCreateRootFromDOMContainer(container, forceHydrate);\n fiberRoot = root._internalRoot;\n if (typeof callback === 'function') {\n var originalCallback = callback;\n callback = function() {\n var instance = getPublicRootInstance(fiberRoot);\n originalCallback.call(instance);\n };\n } // Initial mount should not be batched.\n unbatchedUpdates(function() {\n updateContainer(children, fiberRoot, parentComponent, callback);\n });\n } else {\n fiberRoot = root._internalRoot;\n if (typeof callback === 'function') {\n var _originalCallback = callback;\n callback = function() {\n var instance = getPublicRootInstance(fiberRoot);\n _originalCallback.call(instance);\n };\n } // Update\n updateContainer(children, fiberRoot, parentComponent, callback);\n }\n return getPublicRootInstance(fiberRoot);\n }\n function findDOMNode(componentOrElement) {\n var owner = ReactCurrentOwner$3.current;\n if (owner !== null && owner.stateNode !== null) {\n var warnedAboutRefsInRender = owner.stateNode._warnedAboutRefsInRender;\n if (!warnedAboutRefsInRender) error1(\"%s is accessing findDOMNode inside its render(). render() should be a pure function of props and state. It should never access something that requires stale data from the previous render, such as refs. Move this logic to componentDidMount and componentDidUpdate instead.\", getComponentName(owner.type) || 'A component');\n owner.stateNode._warnedAboutRefsInRender = true;\n }\n if (componentOrElement == null) return null;\n if (componentOrElement.nodeType === ELEMENT_NODE) return componentOrElement;\n return findHostInstanceWithWarning(componentOrElement, 'findDOMNode');\n }\n function hydrate1(element, container, callback) {\n if (!isValidContainer(container)) throw Error(\"Target container is not a DOM element.\");\n var isModernRoot = isContainerMarkedAsRoot(container) && container._reactRootContainer === undefined;\n if (isModernRoot) error1(\"You are calling ReactDOM.hydrate() on a container that was previously passed to ReactDOM.createRoot(). This is not supported. Did you mean to call createRoot(container, {hydrate: true}).render(element)?\");\n return legacyRenderSubtreeIntoContainer(null, element, container, true, callback);\n }\n function render1(element, container, callback) {\n if (!isValidContainer(container)) throw Error(\"Target container is not a DOM element.\");\n var isModernRoot = isContainerMarkedAsRoot(container) && container._reactRootContainer === undefined;\n if (isModernRoot) error1(\"You are calling ReactDOM.render() on a container that was previously passed to ReactDOM.createRoot(). This is not supported. Did you mean to call root.render(element)?\");\n return legacyRenderSubtreeIntoContainer(null, element, container, false, callback);\n }\n function unstable_renderSubtreeIntoContainer(parentComponent, element, containerNode, callback) {\n if (!isValidContainer(containerNode)) throw Error(\"Target container is not a DOM element.\");\n if (!(parentComponent != null && has1(parentComponent))) throw Error(\"parentComponent must be a valid React Component\");\n return legacyRenderSubtreeIntoContainer(parentComponent, element, containerNode, false, callback);\n }\n function unmountComponentAtNode(container) {\n if (!isValidContainer(container)) throw Error(\"unmountComponentAtNode(...): Target container is not a DOM element.\");\n var isModernRoot = isContainerMarkedAsRoot(container) && container._reactRootContainer === undefined;\n if (isModernRoot) error1(\"You are calling ReactDOM.unmountComponentAtNode() on a container that was previously passed to ReactDOM.createRoot(). This is not supported. Did you mean to call root.unmount()?\");\n if (container._reactRootContainer) {\n var rootEl = getReactRootElementInContainer(container);\n var renderedByDifferentReact = rootEl && !getInstanceFromNode(rootEl);\n if (renderedByDifferentReact) error1(\"unmountComponentAtNode(): The node you're attempting to unmount was rendered by another copy of React.\");\n unbatchedUpdates(function() {\n legacyRenderSubtreeIntoContainer(null, null, container, false, function() {\n // $FlowFixMe This should probably use `delete container._reactRootContainer`\n container._reactRootContainer = null;\n unmarkContainerAsRoot(container);\n });\n }); // If you call unmountComponentAtNode twice in quick succession, you'll\n // get `true` twice. That's probably fine?\n return true;\n } else {\n var _rootEl = getReactRootElementInContainer(container);\n var hasNonRootReactChild = !!(_rootEl && getInstanceFromNode(_rootEl)); // Check if the container itself is a React root node.\n var isContainerReactRoot = container.nodeType === ELEMENT_NODE && isValidContainer(container.parentNode) && !!container.parentNode._reactRootContainer;\n if (hasNonRootReactChild) error1(\"unmountComponentAtNode(): The node you're attempting to unmount was rendered by React and is not a top-level container. %s\", isContainerReactRoot ? \"You may have accidentally passed in a React root node instead of its container.\" : \"Instead, have the parent component update its state and rerender in order to remove this component.\");\n return false;\n }\n }\n setAttemptUserBlockingHydration(attemptUserBlockingHydration$1);\n setAttemptContinuousHydration(attemptContinuousHydration$1);\n setAttemptHydrationAtCurrentPriority(attemptHydrationAtCurrentPriority$1);\n setAttemptHydrationAtPriority(runWithPriority$2);\n var didWarnAboutUnstableCreatePortal = false;\n if (typeof Map !== 'function' || Map.prototype == null || typeof Map.prototype.forEach !== 'function' || typeof Set !== 'function' || Set.prototype == null || typeof Set.prototype.clear !== 'function' || typeof Set.prototype.forEach !== 'function') error1(\"React depends on Map and Set built-in types. Make sure that you load a polyfill in older browsers. https://reactjs.org/link/react-polyfills\");\n setRestoreImplementation(restoreControlledState$3);\n setBatchingImplementation(batchedUpdates$1, discreteUpdates$1, flushDiscreteUpdates, batchedEventUpdates$1);\n function createPortal$1(children, container) {\n var key = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null;\n if (!isValidContainer(container)) throw Error(\"Target container is not a DOM element.\");\n // TODO: pass ReactDOM portal implementation as third argument\n // $FlowFixMe The Flow type is opaque but there's no way to actually create it.\n return createPortal(children, container, null, key);\n }\n function renderSubtreeIntoContainer(parentComponent, element, containerNode, callback) {\n return unstable_renderSubtreeIntoContainer(parentComponent, element, containerNode, callback);\n }\n function unstable_createPortal(children, container) {\n var key = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null;\n if (!didWarnAboutUnstableCreatePortal) {\n didWarnAboutUnstableCreatePortal = true;\n warn(\"The ReactDOM.unstable_createPortal() alias has been deprecated, and will be removed in React 18+. Update your code to use ReactDOM.createPortal() instead. It has the exact same API, but without the \\\"unstable_\\\" prefix.\");\n }\n return createPortal$1(children, container, key);\n }\n var Internals = {\n // Keep in sync with ReactTestUtils.js, and ReactTestUtilsAct.js.\n // This is an array for better minification.\n Events: [\n getInstanceFromNode,\n getNodeFromInstance,\n getFiberCurrentPropsFromNode,\n enqueueStateRestore,\n restoreStateIfNeeded,\n flushPassiveEffects,\n IsThisRendererActing\n ]\n };\n var foundDevTools = injectIntoDevTools({\n findFiberByHostInstance: getClosestInstanceFromNode,\n bundleType: 1,\n version: ReactVersion,\n rendererPackageName: 'react-dom'\n });\n if (!foundDevTools && canUseDOM && window.top === window.self) // If we're in Chrome or Firefox, provide a download link if not installed.\n {\n if (navigator.userAgent.indexOf('Chrome') > -1 && navigator.userAgent.indexOf('Edge') === -1 || navigator.userAgent.indexOf('Firefox') > -1) {\n var protocol = window.location.protocol; // Don't warn in exotic cases like chrome-extension://.\n if (/^(https?|file):$/.test(protocol)) // eslint-disable-next-line react-internal/no-production-logging\n console.info(\"%cDownload the React DevTools for a better development experience: https://reactjs.org/link/react-devtools\" + (protocol === 'file:' ? \"\\nYou might need to use a local HTTP server (instead of file://): https://reactjs.org/link/react-devtools-faq\" : ''), 'font-weight:bold');\n }\n }\n exports.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED = Internals;\n exports.createPortal = createPortal$1;\n exports.findDOMNode = findDOMNode;\n exports.flushSync = flushSync;\n exports.hydrate = hydrate1;\n exports.render = render1;\n exports.unmountComponentAtNode = unmountComponentAtNode;\n exports.unstable_batchedUpdates = batchedUpdates$1;\n exports.unstable_createPortal = unstable_createPortal;\n exports.unstable_renderSubtreeIntoContainer = renderSubtreeIntoContainer;\n exports.version = ReactVersion;\n})();\n\n},{\"react\":\"1PJsa\",\"object-assign\":\"7zBzH\",\"scheduler\":\"encVZ\",\"scheduler/tracing\":\"5pRy7\"}],\"encVZ\":[function(require,module,exports) {\n'use strict';\nmodule.exports = require('./cjs/scheduler.development.js');\n\n},{\"./cjs/scheduler.development.js\":\"9fuDL\"}],\"9fuDL\":[function(require,module,exports) {\n/** @license React v0.20.2\n * scheduler.development.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */ 'use strict';\n(function() {\n var enableSchedulerDebugging = false;\n var enableProfiling = false;\n var requestHostCallback;\n var requestHostTimeout;\n var cancelHostTimeout;\n var requestPaint;\n var hasPerformanceNow = typeof performance === 'object' && typeof performance.now === 'function';\n if (hasPerformanceNow) {\n var localPerformance = performance;\n exports.unstable_now = function() {\n return localPerformance.now();\n };\n } else {\n var localDate = Date;\n var initialTime = localDate.now();\n exports.unstable_now = function() {\n return localDate.now() - initialTime;\n };\n }\n if (// implementation using setTimeout.\n typeof window === 'undefined' || typeof MessageChannel !== 'function') {\n // If this accidentally gets imported in a non-browser environment, e.g. JavaScriptCore,\n // fallback to a naive implementation.\n var _callback = null;\n var _timeoutID = null;\n var _flushCallback = function() {\n if (_callback !== null) try {\n var currentTime = exports.unstable_now();\n var hasRemainingTime = true;\n _callback(hasRemainingTime, currentTime);\n _callback = null;\n } catch (e) {\n setTimeout(_flushCallback, 0);\n throw e;\n }\n };\n requestHostCallback = function(cb) {\n if (_callback !== null) // Protect against re-entrancy.\n setTimeout(requestHostCallback, 0, cb);\n else {\n _callback = cb;\n setTimeout(_flushCallback, 0);\n }\n };\n requestHostTimeout = function(cb, ms) {\n _timeoutID = setTimeout(cb, ms);\n };\n cancelHostTimeout = function() {\n clearTimeout(_timeoutID);\n };\n exports.unstable_shouldYield = function() {\n return false;\n };\n requestPaint = exports.unstable_forceFrameRate = function() {\n };\n } else {\n // Capture local references to native APIs, in case a polyfill overrides them.\n var _setTimeout = window.setTimeout;\n var _clearTimeout = window.clearTimeout;\n if (typeof console !== 'undefined') {\n // TODO: Scheduler no longer requires these methods to be polyfilled. But\n // maybe we want to continue warning if they don't exist, to preserve the\n // option to rely on it in the future?\n var requestAnimationFrame = window.requestAnimationFrame;\n var cancelAnimationFrame = window.cancelAnimationFrame;\n if (typeof requestAnimationFrame !== 'function') // Using console['error'] to evade Babel and ESLint\n console['error'](\"This browser doesn't support requestAnimationFrame. Make sure that you load a polyfill in older browsers. https://reactjs.org/link/react-polyfills\");\n if (typeof cancelAnimationFrame !== 'function') // Using console['error'] to evade Babel and ESLint\n console['error'](\"This browser doesn't support cancelAnimationFrame. Make sure that you load a polyfill in older browsers. https://reactjs.org/link/react-polyfills\");\n }\n var isMessageLoopRunning = false;\n var scheduledHostCallback = null;\n var taskTimeoutID = -1; // Scheduler periodically yields in case there is other work on the main\n // thread, like user events. By default, it yields multiple times per frame.\n // It does not attempt to align with frame boundaries, since most tasks don't\n // need to be frame aligned; for those that do, use requestAnimationFrame.\n var yieldInterval = 5;\n var deadline = 0; // TODO: Make this configurable\n // `isInputPending` is not available. Since we have no way of knowing if\n // there's pending input, always yield at the end of the frame.\n exports.unstable_shouldYield = function() {\n return exports.unstable_now() >= deadline;\n }; // Since we yield every frame regardless, `requestPaint` has no effect.\n requestPaint = function() {\n };\n exports.unstable_forceFrameRate = function(fps) {\n if (fps < 0 || fps > 125) {\n // Using console['error'] to evade Babel and ESLint\n console['error'](\"forceFrameRate takes a positive int between 0 and 125, forcing frame rates higher than 125 fps is not supported\");\n return;\n }\n if (fps > 0) yieldInterval = Math.floor(1000 / fps);\n else // reset the framerate\n yieldInterval = 5;\n };\n var performWorkUntilDeadline = function() {\n if (scheduledHostCallback !== null) {\n var currentTime = exports.unstable_now(); // Yield after `yieldInterval` ms, regardless of where we are in the vsync\n // cycle. This means there's always time remaining at the beginning of\n // the message event.\n deadline = currentTime + yieldInterval;\n var hasTimeRemaining = true;\n try {\n var hasMoreWork = scheduledHostCallback(hasTimeRemaining, currentTime);\n if (!hasMoreWork) {\n isMessageLoopRunning = false;\n scheduledHostCallback = null;\n } else // If there's more work, schedule the next message event at the end\n // of the preceding one.\n port.postMessage(null);\n } catch (error) {\n // If a scheduler task throws, exit the current browser task so the\n // error can be observed.\n port.postMessage(null);\n throw error;\n }\n } else isMessageLoopRunning = false;\n // Yielding to the browser will give it a chance to paint, so we can\n };\n var channel = new MessageChannel();\n var port = channel.port2;\n channel.port1.onmessage = performWorkUntilDeadline;\n requestHostCallback = function(callback) {\n scheduledHostCallback = callback;\n if (!isMessageLoopRunning) {\n isMessageLoopRunning = true;\n port.postMessage(null);\n }\n };\n requestHostTimeout = function(callback, ms) {\n taskTimeoutID = _setTimeout(function() {\n callback(exports.unstable_now());\n }, ms);\n };\n cancelHostTimeout = function() {\n _clearTimeout(taskTimeoutID);\n taskTimeoutID = -1;\n };\n }\n function push(heap, node) {\n var index = heap.length;\n heap.push(node);\n siftUp(heap, node, index);\n }\n function peek(heap) {\n var first = heap[0];\n return first === undefined ? null : first;\n }\n function pop(heap) {\n var first = heap[0];\n if (first !== undefined) {\n var last = heap.pop();\n if (last !== first) {\n heap[0] = last;\n siftDown(heap, last, 0);\n }\n return first;\n } else return null;\n }\n function siftUp(heap, node, i) {\n var index = i;\n while(true){\n var parentIndex = index - 1 >>> 1;\n var parent = heap[parentIndex];\n if (parent !== undefined && compare(parent, node) > 0) {\n // The parent is larger. Swap positions.\n heap[parentIndex] = node;\n heap[index] = parent;\n index = parentIndex;\n } else // The parent is smaller. Exit.\n return;\n }\n }\n function siftDown(heap, node, i) {\n var index = i;\n var length = heap.length;\n while(index < length){\n var leftIndex = (index + 1) * 2 - 1;\n var left = heap[leftIndex];\n var rightIndex = leftIndex + 1;\n var right = heap[rightIndex]; // If the left or right node is smaller, swap with the smaller of those.\n if (left !== undefined && compare(left, node) < 0) {\n if (right !== undefined && compare(right, left) < 0) {\n heap[index] = right;\n heap[rightIndex] = node;\n index = rightIndex;\n } else {\n heap[index] = left;\n heap[leftIndex] = node;\n index = leftIndex;\n }\n } else if (right !== undefined && compare(right, node) < 0) {\n heap[index] = right;\n heap[rightIndex] = node;\n index = rightIndex;\n } else // Neither child is smaller. Exit.\n return;\n }\n }\n function compare(a, b) {\n // Compare sort index first, then task id.\n var diff = a.sortIndex - b.sortIndex;\n return diff !== 0 ? diff : a.id - b.id;\n }\n // TODO: Use symbols?\n var ImmediatePriority = 1;\n var UserBlockingPriority = 2;\n var NormalPriority = 3;\n var LowPriority = 4;\n var IdlePriority = 5;\n function markTaskErrored(task, ms) {\n }\n /* eslint-disable no-var */ // Math.pow(2, 30) - 1\n // 0b111111111111111111111111111111\n var maxSigned31BitInt = 1073741823; // Times out immediately\n var IMMEDIATE_PRIORITY_TIMEOUT = -1; // Eventually times out\n var USER_BLOCKING_PRIORITY_TIMEOUT = 250;\n var NORMAL_PRIORITY_TIMEOUT = 5000;\n var LOW_PRIORITY_TIMEOUT = 10000; // Never times out\n var IDLE_PRIORITY_TIMEOUT = maxSigned31BitInt; // Tasks are stored on a min heap\n var taskQueue = [];\n var timerQueue = []; // Incrementing id counter. Used to maintain insertion order.\n var taskIdCounter = 1; // Pausing the scheduler is useful for debugging.\n var currentTask = null;\n var currentPriorityLevel = NormalPriority; // This is set while performing work, to prevent re-entrancy.\n var isPerformingWork = false;\n var isHostCallbackScheduled = false;\n var isHostTimeoutScheduled = false;\n function advanceTimers(currentTime) {\n // Check for tasks that are no longer delayed and add them to the queue.\n var timer = peek(timerQueue);\n while(timer !== null){\n if (timer.callback === null) // Timer was cancelled.\n pop(timerQueue);\n else if (timer.startTime <= currentTime) {\n // Timer fired. Transfer to the task queue.\n pop(timerQueue);\n timer.sortIndex = timer.expirationTime;\n push(taskQueue, timer);\n } else // Remaining timers are pending.\n return;\n timer = peek(timerQueue);\n }\n }\n function handleTimeout(currentTime) {\n isHostTimeoutScheduled = false;\n advanceTimers(currentTime);\n if (!isHostCallbackScheduled) {\n if (peek(taskQueue) !== null) {\n isHostCallbackScheduled = true;\n requestHostCallback(flushWork);\n } else {\n var firstTimer = peek(timerQueue);\n if (firstTimer !== null) requestHostTimeout(handleTimeout, firstTimer.startTime - currentTime);\n }\n }\n }\n function flushWork(hasTimeRemaining, initialTime) {\n isHostCallbackScheduled = false;\n if (isHostTimeoutScheduled) {\n // We scheduled a timeout but it's no longer needed. Cancel it.\n isHostTimeoutScheduled = false;\n cancelHostTimeout();\n }\n isPerformingWork = true;\n var previousPriorityLevel = currentPriorityLevel;\n try {\n if (enableProfiling) try {\n return workLoop(hasTimeRemaining, initialTime);\n } catch (error) {\n if (currentTask !== null) {\n var currentTime = exports.unstable_now();\n markTaskErrored(currentTask, currentTime);\n currentTask.isQueued = false;\n }\n throw error;\n }\n else // No catch in prod code path.\n return workLoop(hasTimeRemaining, initialTime);\n } finally{\n currentTask = null;\n currentPriorityLevel = previousPriorityLevel;\n isPerformingWork = false;\n }\n }\n function workLoop(hasTimeRemaining, initialTime) {\n var currentTime = initialTime;\n advanceTimers(currentTime);\n currentTask = peek(taskQueue);\n while(currentTask !== null && !enableSchedulerDebugging){\n if (currentTask.expirationTime > currentTime && (!hasTimeRemaining || exports.unstable_shouldYield())) break;\n var callback = currentTask.callback;\n if (typeof callback === 'function') {\n currentTask.callback = null;\n currentPriorityLevel = currentTask.priorityLevel;\n var didUserCallbackTimeout = currentTask.expirationTime <= currentTime;\n var continuationCallback = callback(didUserCallbackTimeout);\n currentTime = exports.unstable_now();\n if (typeof continuationCallback === 'function') currentTask.callback = continuationCallback;\n else if (currentTask === peek(taskQueue)) pop(taskQueue);\n advanceTimers(currentTime);\n } else pop(taskQueue);\n currentTask = peek(taskQueue);\n } // Return whether there's additional work\n if (currentTask !== null) return true;\n else {\n var firstTimer = peek(timerQueue);\n if (firstTimer !== null) requestHostTimeout(handleTimeout, firstTimer.startTime - currentTime);\n return false;\n }\n }\n function unstable_runWithPriority(priorityLevel, eventHandler) {\n switch(priorityLevel){\n case ImmediatePriority:\n case UserBlockingPriority:\n case NormalPriority:\n case LowPriority:\n case IdlePriority:\n break;\n default:\n priorityLevel = NormalPriority;\n }\n var previousPriorityLevel = currentPriorityLevel;\n currentPriorityLevel = priorityLevel;\n try {\n return eventHandler();\n } finally{\n currentPriorityLevel = previousPriorityLevel;\n }\n }\n function unstable_next(eventHandler) {\n var priorityLevel;\n switch(currentPriorityLevel){\n case ImmediatePriority:\n case UserBlockingPriority:\n case NormalPriority:\n // Shift down to normal priority\n priorityLevel = NormalPriority;\n break;\n default:\n // Anything lower than normal priority should remain at the current level.\n priorityLevel = currentPriorityLevel;\n break;\n }\n var previousPriorityLevel = currentPriorityLevel;\n currentPriorityLevel = priorityLevel;\n try {\n return eventHandler();\n } finally{\n currentPriorityLevel = previousPriorityLevel;\n }\n }\n function unstable_wrapCallback(callback) {\n var parentPriorityLevel = currentPriorityLevel;\n return function() {\n // This is a fork of runWithPriority, inlined for performance.\n var previousPriorityLevel = currentPriorityLevel;\n currentPriorityLevel = parentPriorityLevel;\n try {\n return callback.apply(this, arguments);\n } finally{\n currentPriorityLevel = previousPriorityLevel;\n }\n };\n }\n function unstable_scheduleCallback(priorityLevel, callback, options) {\n var currentTime = exports.unstable_now();\n var startTime;\n if (typeof options === 'object' && options !== null) {\n var delay = options.delay;\n if (typeof delay === 'number' && delay > 0) startTime = currentTime + delay;\n else startTime = currentTime;\n } else startTime = currentTime;\n var timeout;\n switch(priorityLevel){\n case ImmediatePriority:\n timeout = IMMEDIATE_PRIORITY_TIMEOUT;\n break;\n case UserBlockingPriority:\n timeout = USER_BLOCKING_PRIORITY_TIMEOUT;\n break;\n case IdlePriority:\n timeout = IDLE_PRIORITY_TIMEOUT;\n break;\n case LowPriority:\n timeout = LOW_PRIORITY_TIMEOUT;\n break;\n case NormalPriority:\n default:\n timeout = NORMAL_PRIORITY_TIMEOUT;\n break;\n }\n var expirationTime = startTime + timeout;\n var newTask = {\n id: taskIdCounter++,\n callback: callback,\n priorityLevel: priorityLevel,\n startTime: startTime,\n expirationTime: expirationTime,\n sortIndex: -1\n };\n if (startTime > currentTime) {\n // This is a delayed task.\n newTask.sortIndex = startTime;\n push(timerQueue, newTask);\n if (peek(taskQueue) === null && newTask === peek(timerQueue)) {\n // All tasks are delayed, and this is the task with the earliest delay.\n if (isHostTimeoutScheduled) // Cancel an existing timeout.\n cancelHostTimeout();\n else isHostTimeoutScheduled = true;\n // Schedule a timeout.\n requestHostTimeout(handleTimeout, startTime - currentTime);\n }\n } else {\n newTask.sortIndex = expirationTime;\n push(taskQueue, newTask);\n // wait until the next time we yield.\n if (!isHostCallbackScheduled && !isPerformingWork) {\n isHostCallbackScheduled = true;\n requestHostCallback(flushWork);\n }\n }\n return newTask;\n }\n function unstable_pauseExecution() {\n }\n function unstable_continueExecution() {\n if (!isHostCallbackScheduled && !isPerformingWork) {\n isHostCallbackScheduled = true;\n requestHostCallback(flushWork);\n }\n }\n function unstable_getFirstCallbackNode() {\n return peek(taskQueue);\n }\n function unstable_cancelCallback(task) {\n // remove from the queue because you can't remove arbitrary nodes from an\n // array based heap, only the first one.)\n task.callback = null;\n }\n function unstable_getCurrentPriorityLevel() {\n return currentPriorityLevel;\n }\n var unstable_requestPaint = requestPaint;\n var unstable_Profiling = null;\n exports.unstable_IdlePriority = IdlePriority;\n exports.unstable_ImmediatePriority = ImmediatePriority;\n exports.unstable_LowPriority = LowPriority;\n exports.unstable_NormalPriority = NormalPriority;\n exports.unstable_Profiling = unstable_Profiling;\n exports.unstable_UserBlockingPriority = UserBlockingPriority;\n exports.unstable_cancelCallback = unstable_cancelCallback;\n exports.unstable_continueExecution = unstable_continueExecution;\n exports.unstable_getCurrentPriorityLevel = unstable_getCurrentPriorityLevel;\n exports.unstable_getFirstCallbackNode = unstable_getFirstCallbackNode;\n exports.unstable_next = unstable_next;\n exports.unstable_pauseExecution = unstable_pauseExecution;\n exports.unstable_requestPaint = unstable_requestPaint;\n exports.unstable_runWithPriority = unstable_runWithPriority;\n exports.unstable_scheduleCallback = unstable_scheduleCallback;\n exports.unstable_wrapCallback = unstable_wrapCallback;\n})();\n\n},{}],\"5pRy7\":[function(require,module,exports) {\n'use strict';\nmodule.exports = require('./cjs/scheduler-tracing.development.js');\n\n},{\"./cjs/scheduler-tracing.development.js\":\"3yC7N\"}],\"3yC7N\":[function(require,module,exports) {\n/** @license React v0.20.2\n * scheduler-tracing.development.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */ 'use strict';\n(function() {\n var DEFAULT_THREAD_ID = 0; // Counters used to generate unique IDs.\n var interactionIDCounter = 0;\n var threadIDCounter = 0; // Set of currently traced interactions.\n // Interactions \"stack\"\u2013\n // Meaning that newly traced interactions are appended to the previously active set.\n // When an interaction goes out of scope, the previous set (if any) is restored.\n exports.__interactionsRef = null; // Listener(s) to notify when interactions begin and end.\n exports.__subscriberRef = null;\n exports.__interactionsRef = {\n current: new Set()\n };\n exports.__subscriberRef = {\n current: null\n };\n function unstable_clear(callback) {\n var prevInteractions = exports.__interactionsRef.current;\n exports.__interactionsRef.current = new Set();\n try {\n return callback();\n } finally{\n exports.__interactionsRef.current = prevInteractions;\n }\n }\n function unstable_getCurrent() {\n return exports.__interactionsRef.current;\n }\n function unstable_getThreadID() {\n return ++threadIDCounter;\n }\n function unstable_trace(name, timestamp, callback) {\n var threadID = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : DEFAULT_THREAD_ID;\n var interaction = {\n __count: 1,\n id: interactionIDCounter++,\n name: name,\n timestamp: timestamp\n };\n var prevInteractions = exports.__interactionsRef.current; // Traced interactions should stack/accumulate.\n // To do that, clone the current interactions.\n // The previous set will be restored upon completion.\n var interactions = new Set(prevInteractions);\n interactions.add(interaction);\n exports.__interactionsRef.current = interactions;\n var subscriber = exports.__subscriberRef.current;\n var returnValue;\n try {\n if (subscriber !== null) subscriber.onInteractionTraced(interaction);\n } finally{\n try {\n if (subscriber !== null) subscriber.onWorkStarted(interactions, threadID);\n } finally{\n try {\n returnValue = callback();\n } finally{\n exports.__interactionsRef.current = prevInteractions;\n try {\n if (subscriber !== null) subscriber.onWorkStopped(interactions, threadID);\n } finally{\n interaction.__count--; // If no async work was scheduled for this interaction,\n // Notify subscribers that it's completed.\n if (subscriber !== null && interaction.__count === 0) subscriber.onInteractionScheduledWorkCompleted(interaction);\n }\n }\n }\n }\n return returnValue;\n }\n function unstable_wrap(callback) {\n var threadID = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : DEFAULT_THREAD_ID;\n var wrappedInteractions = exports.__interactionsRef.current;\n var subscriber = exports.__subscriberRef.current;\n if (subscriber !== null) subscriber.onWorkScheduled(wrappedInteractions, threadID);\n // Update the pending async work count for the current interactions.\n // Update after calling subscribers in case of error.\n wrappedInteractions.forEach(function(interaction) {\n interaction.__count++;\n });\n var hasRun = false;\n function wrapped() {\n var prevInteractions = exports.__interactionsRef.current;\n exports.__interactionsRef.current = wrappedInteractions;\n subscriber = exports.__subscriberRef.current;\n try {\n var returnValue;\n try {\n if (subscriber !== null) subscriber.onWorkStarted(wrappedInteractions, threadID);\n } finally{\n try {\n returnValue = callback.apply(undefined, arguments);\n } finally{\n exports.__interactionsRef.current = prevInteractions;\n if (subscriber !== null) subscriber.onWorkStopped(wrappedInteractions, threadID);\n }\n }\n return returnValue;\n } finally{\n if (!hasRun) {\n // We only expect a wrapped function to be executed once,\n // But in the event that it's executed more than once\u2013\n // Only decrement the outstanding interaction counts once.\n hasRun = true; // Update pending async counts for all wrapped interactions.\n // If this was the last scheduled async work for any of them,\n // Mark them as completed.\n wrappedInteractions.forEach(function(interaction) {\n interaction.__count--;\n if (subscriber !== null && interaction.__count === 0) subscriber.onInteractionScheduledWorkCompleted(interaction);\n });\n }\n }\n }\n wrapped.cancel = function cancel() {\n subscriber = exports.__subscriberRef.current;\n try {\n if (subscriber !== null) subscriber.onWorkCanceled(wrappedInteractions, threadID);\n } finally{\n // Update pending async counts for all wrapped interactions.\n // If this was the last scheduled async work for any of them,\n // Mark them as completed.\n wrappedInteractions.forEach(function(interaction) {\n interaction.__count--;\n if (subscriber && interaction.__count === 0) subscriber.onInteractionScheduledWorkCompleted(interaction);\n });\n }\n };\n return wrapped;\n }\n var subscribers = null;\n subscribers = new Set();\n function unstable_subscribe(subscriber) {\n subscribers.add(subscriber);\n if (subscribers.size === 1) exports.__subscriberRef.current = {\n onInteractionScheduledWorkCompleted: onInteractionScheduledWorkCompleted,\n onInteractionTraced: onInteractionTraced,\n onWorkCanceled: onWorkCanceled,\n onWorkScheduled: onWorkScheduled,\n onWorkStarted: onWorkStarted,\n onWorkStopped: onWorkStopped\n };\n }\n function unstable_unsubscribe(subscriber) {\n subscribers.delete(subscriber);\n if (subscribers.size === 0) exports.__subscriberRef.current = null;\n }\n function onInteractionTraced(interaction) {\n var didCatchError = false;\n var caughtError = null;\n subscribers.forEach(function(subscriber) {\n try {\n subscriber.onInteractionTraced(interaction);\n } catch (error) {\n if (!didCatchError) {\n didCatchError = true;\n caughtError = error;\n }\n }\n });\n if (didCatchError) throw caughtError;\n }\n function onInteractionScheduledWorkCompleted(interaction) {\n var didCatchError = false;\n var caughtError = null;\n subscribers.forEach(function(subscriber) {\n try {\n subscriber.onInteractionScheduledWorkCompleted(interaction);\n } catch (error) {\n if (!didCatchError) {\n didCatchError = true;\n caughtError = error;\n }\n }\n });\n if (didCatchError) throw caughtError;\n }\n function onWorkScheduled(interactions, threadID) {\n var didCatchError = false;\n var caughtError = null;\n subscribers.forEach(function(subscriber) {\n try {\n subscriber.onWorkScheduled(interactions, threadID);\n } catch (error) {\n if (!didCatchError) {\n didCatchError = true;\n caughtError = error;\n }\n }\n });\n if (didCatchError) throw caughtError;\n }\n function onWorkStarted(interactions, threadID) {\n var didCatchError = false;\n var caughtError = null;\n subscribers.forEach(function(subscriber) {\n try {\n subscriber.onWorkStarted(interactions, threadID);\n } catch (error) {\n if (!didCatchError) {\n didCatchError = true;\n caughtError = error;\n }\n }\n });\n if (didCatchError) throw caughtError;\n }\n function onWorkStopped(interactions, threadID) {\n var didCatchError = false;\n var caughtError = null;\n subscribers.forEach(function(subscriber) {\n try {\n subscriber.onWorkStopped(interactions, threadID);\n } catch (error) {\n if (!didCatchError) {\n didCatchError = true;\n caughtError = error;\n }\n }\n });\n if (didCatchError) throw caughtError;\n }\n function onWorkCanceled(interactions, threadID) {\n var didCatchError = false;\n var caughtError = null;\n subscribers.forEach(function(subscriber) {\n try {\n subscriber.onWorkCanceled(interactions, threadID);\n } catch (error) {\n if (!didCatchError) {\n didCatchError = true;\n caughtError = error;\n }\n }\n });\n if (didCatchError) throw caughtError;\n }\n exports.unstable_clear = unstable_clear;\n exports.unstable_getCurrent = unstable_getCurrent;\n exports.unstable_getThreadID = unstable_getThreadID;\n exports.unstable_subscribe = unstable_subscribe;\n exports.unstable_trace = unstable_trace;\n exports.unstable_unsubscribe = unstable_unsubscribe;\n exports.unstable_wrap = unstable_wrap;\n})();\n\n},{}],\"4ZyF2\":[function(require,module,exports) {\nmodule.exports = JSON.parse(\"{\\\"hooks\\\":{\\\"commands\\\":{\\\"Navigate To page\\\":{\\\"invoke\\\":\\\"linkNavigate\\\",\\\"key\\\":\\\"Ctrl-Enter\\\",\\\"mac\\\":\\\"Cmd-Enter\\\"},\\\"Insert Current Date\\\":{\\\"invoke\\\":\\\"insertToday\\\",\\\"slashCommand\\\":\\\"today\\\"},\\\"Toggle : Heading 1\\\":{\\\"invoke\\\":\\\"toggle_h1\\\",\\\"mac\\\":\\\"Cmd-1\\\",\\\"key\\\":\\\"Ctrl-1\\\"},\\\"Toggle : Heading 2\\\":{\\\"invoke\\\":\\\"toggle_h2\\\",\\\"mac\\\":\\\"Cmd-2\\\",\\\"key\\\":\\\"Ctrl-2\\\"},\\\"Page: Delete\\\":{\\\"invoke\\\":\\\"deletePage\\\"},\\\"Page: Rename\\\":{\\\"invoke\\\":\\\"renamePage\\\"},\\\"Pages: Reindex\\\":{\\\"invoke\\\":\\\"reindexPages\\\"},\\\"Pages: Back Links\\\":{\\\"invoke\\\":\\\"showBackLinks\\\"}},\\\"events\\\":{\\\"page:click\\\":[\\\"taskToggle\\\",\\\"clickNavigate\\\"],\\\"editor:complete\\\":[\\\"pageComplete\\\"],\\\"page:index\\\":[\\\"indexLinks\\\"]}},\\\"functions\\\":{\\\"indexLinks\\\":{\\\"path\\\":\\\"core/page.ts\\\",\\\"code\\\":\\\"(()=>{var r=Object.defineProperty;var w=Object.getOwnPropertyDescriptor;var k=Object.getOwnPropertyNames;var f=Object.prototype.hasOwnProperty;var m=a=>r(a,\\\\\\\"__esModule\\\\\\\",{value:!0});var x=(a,e)=>{for(var t in e)r(a,t,{get:e[t],enumerable:!0})},u=(a,e,t,o)=>{if(e&&typeof e==\\\\\\\"object\\\\\\\"||typeof e==\\\\\\\"function\\\\\\\")for(let i of k(e))!f.call(a,i)&&(t||i!==\\\\\\\"default\\\\\\\")&&r(a,i,{get:()=>e[i],enumerable:!(o=w(e,i))||o.enumerable});return a};var P=(a=>(e,t)=>a&&a.get(e)||(t=u(m({}),e,1),a&&a.set(e,t),t))(typeof WeakMap!=\\\\\\\"undefined\\\\\\\"?new WeakMap:0);var R={};x(R,{deletePage:()=>h,indexLinks:()=>L,reindex:()=>B,renamePage:()=>v,showBackLinks:()=>b});var p=/\\\\\\\\[\\\\\\\\[([\\\\\\\\w\\\\\\\\s\\\\\\\\/\\\\\\\\:,\\\\\\\\.\\\\\\\\-]+)\\\\\\\\]\\\\\\\\]/;function n(a,...e){let t=Math.floor(Math.random()*1e6);return new Promise((o,i)=>{self.dispatchEvent(new CustomEvent(\\\\\\\"syscall\\\\\\\",{detail:{id:t,name:a,args:e,callback:o}}))})}var y=new RegExp(p,\\\\\\\"g\\\\\\\");async function L({name:a,text:e}){let t=[];for(let o of e.matchAll(y)){let i=o[1],l=o.index;t.push({key:`pl:${i}:${l}`,value:a})}console.log(\\\\\\\"Found\\\\\\\",t.length,\\\\\\\"wiki link(s)\\\\\\\"),await n(\\\\\\\"indexer.batchSet\\\\\\\",a,t)}async function h(){let a=await n(\\\\\\\"editor.getCurrentPage\\\\\\\");console.log(\\\\\\\"Navigating to start page\\\\\\\"),await n(\\\\\\\"editor.navigate\\\\\\\",\\\\\\\"start\\\\\\\"),console.log(\\\\\\\"Deleting page from space\\\\\\\"),await n(\\\\\\\"space.deletePage\\\\\\\",a.name),console.log(\\\\\\\"Reloading page list\\\\\\\"),await n(\\\\\\\"space.reloadPageList\\\\\\\")}async function v(){let e=(await n(\\\\\\\"editor.getCurrentPage\\\\\\\")).name;console.log(\\\\\\\"Old name is\\\\\\\",e);let t=await n(\\\\\\\"editor.prompt\\\\\\\",`Rename ${e} to:`,e);if(!t)return;console.log(\\\\\\\"New name\\\\\\\",t);let o=await d(e);console.log(\\\\\\\"All pages containing backlinks\\\\\\\",o);let i=await n(\\\\\\\"editor.getText\\\\\\\");console.log(\\\\\\\"Writing new page to space\\\\\\\"),await n(\\\\\\\"space.writePage\\\\\\\",t,i),console.log(\\\\\\\"Deleting page from space\\\\\\\"),await n(\\\\\\\"space.deletePage\\\\\\\",e),console.log(\\\\\\\"Reloading page list\\\\\\\"),await n(\\\\\\\"space.reloadPageList\\\\\\\"),console.log(\\\\\\\"Navigating to new page\\\\\\\"),await n(\\\\\\\"editor.navigate\\\\\\\",t);let l=new Set;for(let s of o)l.add(s.page);for(let s of l){console.log(\\\\\\\"Now going to update links in\\\\\\\",s);let{text:g}=await n(\\\\\\\"space.readPage\\\\\\\",s);if(!g)continue;let c=g.replaceAll(`[[${e}]]`,`[[${t}]]`);g!==c&&(console.log(\\\\\\\"Changes made, saving...\\\\\\\"),await n(\\\\\\\"space.writePage\\\\\\\",s,c))}}async function d(a){let e=await n(\\\\\\\"indexer.scanPrefixGlobal\\\\\\\",`pl:${a}:`),t=[];for(let{key:o,value:i}of e){let l=o.split(\\\\\\\":\\\\\\\");t.push({page:i,pos:+l[l.length-1]})}return t}async function b(){let a=await n(\\\\\\\"editor.getCurrentPage\\\\\\\"),e=await d(a.name);console.log(\\\\\\\"Backlinks\\\\\\\",e)}async function B(){await n(\\\\\\\"space.reindex\\\\\\\")}return P(R);})();\\\\n//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiY29yZS9wYWdlLnRzIiwgIi4uL3dlYmFwcC9zcmMvY29uc3RhbnQudHMiLCAiY29yZS9saWIvc3lzY2FsbC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiaW1wb3J0IHsgSW5kZXhFdmVudCB9IGZyb20gXCIuLi8uLi93ZWJhcHAvc3JjL2FwcF9ldmVudFwiO1xuaW1wb3J0IHsgcGFnZUxpbmtSZWdleCB9IGZyb20gXCIuLi8uLi93ZWJhcHAvc3JjL2NvbnN0YW50XCI7XG5pbXBvcnQgeyBzeXNjYWxsIH0gZnJvbSBcIi4vbGliL3N5c2NhbGxcIjtcblxuY29uc3Qgd2lraWxpbmtSZWdleCA9IG5ldyBSZWdFeHAocGFnZUxpbmtSZWdleCwgXCJnXCIpO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gaW5kZXhMaW5rcyh7IG5hbWUsIHRleHQgfTogSW5kZXhFdmVudCkge1xuICBsZXQgYmFja0xpbmtzOiB7IGtleTogc3RyaW5nOyB2YWx1ZTogc3RyaW5nIH1bXSA9IFtdO1xuICBmb3IgKGxldCBtYXRjaCBvZiB0ZXh0Lm1hdGNoQWxsKHdpa2lsaW5rUmVnZXgpKSB7XG4gICAgbGV0IHRvUGFnZSA9IG1hdGNoWzFdO1xuICAgIGxldCBwb3MgPSBtYXRjaC5pbmRleCE7XG4gICAgYmFja0xpbmtzLnB1c2goe1xuICAgICAga2V5OiBgcGw6JHt0b1BhZ2V9OiR7cG9zfWAsXG4gICAgICB2YWx1ZTogbmFtZSxcbiAgICB9KTtcbiAgfVxuICBjb25zb2xlLmxvZyhcIkZvdW5kXCIsIGJhY2tMaW5rcy5sZW5ndGgsIFwid2lraSBsaW5rKHMpXCIpO1xuICBhd2FpdCBzeXNjYWxsKFwiaW5kZXhlci5iYXRjaFNldFwiLCBuYW1lLCBiYWNrTGlua3MpO1xufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZGVsZXRlUGFnZSgpIHtcbiAgbGV0IHBhZ2VNZXRhID0gYXdhaXQgc3lzY2FsbChcImVkaXRvci5nZXRDdXJyZW50UGFnZVwiKTtcbiAgY29uc29sZS5sb2coXCJOYXZpZ2F0aW5nIHRvIHN0YXJ0IHBhZ2VcIik7XG4gIGF3YWl0IHN5c2NhbGwoXCJlZGl0b3IubmF2aWdhdGVcIiwgXCJzdGFydFwiKTtcbiAgY29uc29sZS5sb2coXCJEZWxldGluZyBwYWdlIGZyb20gc3BhY2VcIik7XG4gIGF3YWl0IHN5c2NhbGwoXCJzcGFjZS5kZWxldGVQYWdlXCIsIHBhZ2VNZXRhLm5hbWUpO1xuICBjb25zb2xlLmxvZyhcIlJlbG9hZGluZyBwYWdlIGxpc3RcIik7XG4gIGF3YWl0IHN5c2NhbGwoXCJzcGFjZS5yZWxvYWRQYWdlTGlzdFwiKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHJlbmFtZVBhZ2UoKSB7XG4gIGNvbnN0IHBhZ2VNZXRhID0gYXdhaXQgc3lzY2FsbChcImVkaXRvci5nZXRDdXJyZW50UGFnZVwiKTtcbiAgY29uc3Qgb2xkTmFtZSA9IHBhZ2VNZXRhLm5hbWU7XG4gIGNvbnNvbGUubG9nKFwiT2xkIG5hbWUgaXNcIiwgb2xkTmFtZSk7XG4gIGNvbnN0IG5ld05hbWUgPSBhd2FpdCBzeXNjYWxsKFxuICAgIFwiZWRpdG9yLnByb21wdFwiLFxuICAgIGBSZW5hbWUgJHtvbGROYW1lfSB0bzpgLFxuICAgIG9sZE5hbWVcbiAgKTtcbiAgaWYgKCFuZXdOYW1lKSB7XG4gICAgcmV0dXJuO1xuICB9XG4gIGNvbnNvbGUubG9nKFwiTmV3IG5hbWVcIiwgbmV3TmFtZSk7XG5cbiAgbGV0IHBhZ2VzVG9VcGRhdGUgPSBhd2FpdCBnZXRCYWNrTGlua3Mob2xkTmFtZSk7XG4gIGNvbnNvbGUubG9nKFwiQWxsIHBhZ2VzIGNvbnRhaW5pbmcgYmFja2xpbmtzXCIsIHBhZ2VzVG9VcGRhdGUpO1xuXG4gIGxldCB0ZXh0ID0gYXdhaXQgc3lzY2FsbChcImVkaXRvci5nZXRUZXh0XCIpO1xuICBjb25zb2xlLmxvZyhcIldyaXRpbmcgbmV3IHBhZ2UgdG8gc3BhY2VcIik7XG4gIGF3YWl0IHN5c2NhbGwoXCJzcGFjZS53cml0ZVBhZ2VcIiwgbmV3TmFtZSwgdGV4dCk7XG4gIGNvbnNvbGUubG9nKFwiRGVsZXRpbmcgcGFnZSBmcm9tIHNwYWNlXCIpO1xuICBhd2FpdCBzeXNjYWxsKFwic3BhY2UuZGVsZXRlUGFnZVwiLCBvbGROYW1lKTtcbiAgY29uc29sZS5sb2coXCJSZWxvYWRpbmcgcGFnZSBsaXN0XCIpO1xuICBhd2FpdCBzeXNjYWxsKFwic3BhY2UucmVsb2FkUGFnZUxpc3RcIik7XG4gIGNvbnNvbGUubG9nKFwiTmF2aWdhdGluZyB0byBuZXcgcGFnZVwiKTtcbiAgYXdhaXQgc3lzY2FsbChcImVkaXRvci5uYXZpZ2F0ZVwiLCBuZXdOYW1lKTtcblxuICBsZXQgcGFnZVRvVXBkYXRlU2V0ID0gbmV3IFNldDxzdHJpbmc+KCk7XG4gIGZvciAobGV0IHBhZ2VUb1VwZGF0ZSBvZiBwYWdlc1RvVXBkYXRlKSB7XG4gICAgcGFnZVRvVXBkYXRlU2V0LmFkZChwYWdlVG9VcGRhdGUucGFnZSk7XG4gIH1cblxuICBmb3IgKGxldCBwYWdlVG9VcGRhdGUgb2YgcGFnZVRvVXBkYXRlU2V0KSB7XG4gICAgY29uc29sZS5sb2coXCJOb3cgZ29pbmcgdG8gdXBkYXRlIGxpbmtzIGluXCIsIHBhZ2VUb1VwZGF0ZSk7XG4gICAgbGV0IHsgdGV4dCB9ID0gYXdhaXQgc3lzY2FsbChcInNwYWNlLnJlYWRQYWdlXCIsIHBhZ2VUb1VwZGF0ZSk7XG4gICAgaWYgKCF0ZXh0KSB7XG4gICAgICAvLyBQYWdlIGxpa2VseSBkb2VzIG5vdCBleGlzdCwgYnV0IGF0IGxlYXN0IHdlIGNhbiBza2lwIGl0XG4gICAgICBjb250aW51ZTtcbiAgICB9XG4gICAgbGV0IG5ld1RleHQgPSB0ZXh0LnJlcGxhY2VBbGwoYFtbJHtvbGROYW1lfV1dYCwgYFtbJHtuZXdOYW1lfV1dYCk7XG4gICAgaWYgKHRleHQgIT09IG5ld1RleHQpIHtcbiAgICAgIGNvbnNvbGUubG9nKFwiQ2hhbmdlcyBtYWRlLCBzYXZpbmcuLi5cIik7XG4gICAgICBhd2FpdCBzeXNjYWxsKFwic3BhY2Uud3JpdGVQYWdlXCIsIHBhZ2VUb1VwZGF0ZSwgbmV3VGV4dCk7XG4gICAgfVxuICB9XG59XG5cbnR5cGUgQmFja0xpbmsgPSB7XG4gIHBhZ2U6IHN0cmluZztcbiAgcG9zOiBudW1iZXI7XG59O1xuXG5hc3luYyBmdW5jdGlvbiBnZXRCYWNrTGlua3MocGFnZU5hbWU6IHN0cmluZyk6IFByb21pc2U8QmFja0xpbmtbXT4ge1xuICBsZXQgYWxsQmFja0xpbmtzID0gYXdhaXQgc3lzY2FsbChcbiAgICBcImluZGV4ZXIuc2NhblByZWZpeEdsb2JhbFwiLFxuICAgIGBwbDoke3BhZ2VOYW1lfTpgXG4gICk7XG4gIGxldCBwYWdlc1RvVXBkYXRlOiBCYWNrTGlua1tdID0gW107XG4gIGZvciAobGV0IHsga2V5LCB2YWx1ZSB9IG9mIGFsbEJhY2tMaW5rcykge1xuICAgIGxldCBrZXlQYXJ0cyA9IGtleS5zcGxpdChcIjpcIik7XG4gICAgcGFnZXNUb1VwZGF0ZS5wdXNoKHtcbiAgICAgIHBhZ2U6IHZhbHVlLFxuICAgICAgcG9zOiAra2V5UGFydHNba2V5UGFydHMubGVuZ3RoIC0gMV0sXG4gICAgfSk7XG4gIH1cbiAgcmV0dXJuIHBhZ2VzVG9VcGRhdGU7XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBzaG93QmFja0xpbmtzKCkge1xuICBjb25zdCBwYWdlTWV0YSA9IGF3YWl0IHN5c2NhbGwoXCJlZGl0b3IuZ2V0Q3VycmVudFBhZ2VcIik7XG4gIGxldCBiYWNrTGlua3MgPSBhd2FpdCBnZXRCYWNrTGlua3MocGFnZU1ldGEubmFtZSk7XG5cbiAgY29uc29sZS5sb2coXCJCYWNrbGlua3NcIiwgYmFja0xpbmtzKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHJlaW5kZXgoKSB7XG4gIGF3YWl0IHN5c2NhbGwoXCJzcGFjZS5yZWluZGV4XCIpO1xufVxuIiwgImV4cG9ydCBjb25zdCBwYWdlTGlua1JlZ2V4ID0gL1xcW1xcWyhbXFx3XFxzXFwvXFw6LFxcLlxcLV0rKVxcXVxcXS87XG4iLCAiZXhwb3J0IGZ1bmN0aW9uIHN5c2NhbGwobmFtZTogc3RyaW5nLCAuLi5hcmdzOiBhbnlbXSk6IGFueSB7XG4gIGxldCByZXFJZCA9IE1hdGguZmxvb3IoTWF0aC5yYW5kb20oKSAqIDEwMDAwMDApO1xuICAvLyBjb25zb2xlLmxvZyhcIlN5c2NhbGxcIiwgbmFtZSwgcmVxSWQpO1xuICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIHNlbGYuZGlzcGF0Y2hFdmVudChcbiAgICAgIG5ldyBDdXN0b21FdmVudChcInN5c2NhbGxcIiwge1xuICAgICAgICBkZXRhaWw6IHtcbiAgICAgICAgICBpZDogcmVxSWQsXG4gICAgICAgICAgbmFtZTogbmFtZSxcbiAgICAgICAgICBhcmdzOiBhcmdzLFxuICAgICAgICAgIGNhbGxiYWNrOiByZXNvbHZlLFxuICAgICAgICB9LFxuICAgICAgfSlcbiAgICApO1xuICB9KTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI0aEJBQUEscUdDQU8sR0FBTSxHQUFnQiw2QkNBdEIsV0FBaUIsS0FBaUIsRUFBa0IsQ0FDekQsR0FBSSxHQUFRLEtBQUssTUFBTSxLQUFLLFNBQVcsS0FFdkMsTUFBTyxJQUFJLFNBQVEsQ0FBQyxFQUFTLElBQVcsQ0FDdEMsS0FBSyxjQUNILEdBQUksYUFBWSxVQUFXLENBQ3pCLE9BQVEsQ0FDTixHQUFJLEVBQ0osS0FBTSxFQUNOLEtBQU0sRUFDTixTQUFVLFFGTnBCLEdBQU0sR0FBZ0IsR0FBSSxRQUFPLEVBQWUsS0FFaEQsaUJBQWlDLENBQUUsT0FBTSxRQUFvQixDQUMzRCxHQUFJLEdBQThDLEdBQ2xELE9BQVMsS0FBUyxHQUFLLFNBQVMsR0FBZ0IsQ0FDOUMsR0FBSSxHQUFTLEVBQU0sR0FDZixFQUFNLEVBQU0sTUFDaEIsRUFBVSxLQUFLLENBQ2IsSUFBSyxNQUFNLEtBQVUsSUFDckIsTUFBTyxJQUdYLFFBQVEsSUFBSSxRQUFTLEVBQVUsT0FBUSxnQkFDdkMsS0FBTSxHQUFRLG1CQUFvQixFQUFNLEdBRzFDLGtCQUFtQyxDQUNqQyxHQUFJLEdBQVcsS0FBTSxHQUFRLHlCQUM3QixRQUFRLElBQUksNEJBQ1osS0FBTSxHQUFRLGtCQUFtQixTQUNqQyxRQUFRLElBQUksNEJBQ1osS0FBTSxHQUFRLG1CQUFvQixFQUFTLE1BQzNDLFFBQVEsSUFBSSx1QkFDWixLQUFNLEdBQVEsd0JBR2hCLGtCQUFtQyxDQUVqQyxHQUFNLEdBQVUsQUFEQyxNQUFNLEdBQVEsMEJBQ04sS0FDekIsUUFBUSxJQUFJLGNBQWUsR0FDM0IsR0FBTSxHQUFVLEtBQU0sR0FDcEIsZ0JBQ0EsVUFBVSxRQUNWLEdBRUYsR0FBSSxDQUFDLEVBQ0gsT0FFRixRQUFRLElBQUksV0FBWSxHQUV4QixHQUFJLEdBQWdCLEtBQU0sR0FBYSxHQUN2QyxRQUFRLElBQUksaUNBQWtDLEdBRTlDLEdBQUksR0FBTyxLQUFNLEdBQVEsa0JBQ3pCLFFBQVEsSUFBSSw2QkFDWixLQUFNLEdBQVEsa0JBQW1CLEVBQVMsR0FDMUMsUUFBUSxJQUFJLDRCQUNaLEtBQU0sR0FBUSxtQkFBb0IsR0FDbEMsUUFBUSxJQUFJLHVCQUNaLEtBQU0sR0FBUSx3QkFDZCxRQUFRLElBQUksMEJBQ1osS0FBTSxHQUFRLGtCQUFtQixHQUVqQyxHQUFJLEdBQWtCLEdBQUksS0FDMUIsT0FBUyxLQUFnQixHQUN2QixFQUFnQixJQUFJLEVBQWEsTUFHbkMsT0FBUyxLQUFnQixHQUFpQixDQUN4QyxRQUFRLElBQUksK0JBQWdDLEdBQzVDLEdBQUksQ0FBRSxRQUFTLEtBQU0sR0FBUSxpQkFBa0IsR0FDL0MsR0FBSSxDQUFDLEVBRUgsU0FFRixHQUFJLEdBQVUsRUFBSyxXQUFXLEtBQUssTUFBYSxLQUFLLE9BQ3JELEFBQUksSUFBUyxHQUNYLFNBQVEsSUFBSSwyQkFDWixLQUFNLEdBQVEsa0JBQW1CLEVBQWMsS0FVckQsaUJBQTRCLEVBQXVDLENBQ2pFLEdBQUksR0FBZSxLQUFNLEdBQ3ZCLDJCQUNBLE1BQU0sTUFFSixFQUE0QixHQUNoQyxPQUFTLENBQUUsTUFBSyxVQUFXLEdBQWMsQ0FDdkMsR0FBSSxHQUFXLEVBQUksTUFBTSxLQUN6QixFQUFjLEtBQUssQ0FDakIsS0FBTSxFQUNOLElBQUssQ0FBQyxFQUFTLEVBQVMsT0FBUyxLQUdyQyxNQUFPLEdBR1Qsa0JBQXNDLENBQ3BDLEdBQU0sR0FBVyxLQUFNLEdBQVEseUJBQzNCLEVBQVksS0FBTSxHQUFhLEVBQVMsTUFFNUMsUUFBUSxJQUFJLFlBQWEsR0FHM0Isa0JBQWdDLENBQzlCLEtBQU0sR0FBUSIsCiAgIm5hbWVzIjogW10KfQo=\\\\n\\\",\\\"functionName\\\":\\\"indexLinks\\\"},\\\"deletePage\\\":{\\\"path\\\":\\\"core/page.ts\\\",\\\"code\\\":\\\"(()=>{var r=Object.defineProperty;var w=Object.getOwnPropertyDescriptor;var k=Object.getOwnPropertyNames;var f=Object.prototype.hasOwnProperty;var m=a=>r(a,\\\\\\\"__esModule\\\\\\\",{value:!0});var x=(a,e)=>{for(var t in e)r(a,t,{get:e[t],enumerable:!0})},u=(a,e,t,o)=>{if(e&&typeof e==\\\\\\\"object\\\\\\\"||typeof e==\\\\\\\"function\\\\\\\")for(let i of k(e))!f.call(a,i)&&(t||i!==\\\\\\\"default\\\\\\\")&&r(a,i,{get:()=>e[i],enumerable:!(o=w(e,i))||o.enumerable});return a};var P=(a=>(e,t)=>a&&a.get(e)||(t=u(m({}),e,1),a&&a.set(e,t),t))(typeof WeakMap!=\\\\\\\"undefined\\\\\\\"?new WeakMap:0);var R={};x(R,{deletePage:()=>h,indexLinks:()=>L,reindex:()=>B,renamePage:()=>v,showBackLinks:()=>b});var p=/\\\\\\\\[\\\\\\\\[([\\\\\\\\w\\\\\\\\s\\\\\\\\/\\\\\\\\:,\\\\\\\\.\\\\\\\\-]+)\\\\\\\\]\\\\\\\\]/;function n(a,...e){let t=Math.floor(Math.random()*1e6);return new Promise((o,i)=>{self.dispatchEvent(new CustomEvent(\\\\\\\"syscall\\\\\\\",{detail:{id:t,name:a,args:e,callback:o}}))})}var y=new RegExp(p,\\\\\\\"g\\\\\\\");async function L({name:a,text:e}){let t=[];for(let o of e.matchAll(y)){let i=o[1],l=o.index;t.push({key:`pl:${i}:${l}`,value:a})}console.log(\\\\\\\"Found\\\\\\\",t.length,\\\\\\\"wiki link(s)\\\\\\\"),await n(\\\\\\\"indexer.batchSet\\\\\\\",a,t)}async function h(){let a=await n(\\\\\\\"editor.getCurrentPage\\\\\\\");console.log(\\\\\\\"Navigating to start page\\\\\\\"),await n(\\\\\\\"editor.navigate\\\\\\\",\\\\\\\"start\\\\\\\"),console.log(\\\\\\\"Deleting page from space\\\\\\\"),await n(\\\\\\\"space.deletePage\\\\\\\",a.name),console.log(\\\\\\\"Reloading page list\\\\\\\"),await n(\\\\\\\"space.reloadPageList\\\\\\\")}async function v(){let e=(await n(\\\\\\\"editor.getCurrentPage\\\\\\\")).name;console.log(\\\\\\\"Old name is\\\\\\\",e);let t=await n(\\\\\\\"editor.prompt\\\\\\\",`Rename ${e} to:`,e);if(!t)return;console.log(\\\\\\\"New name\\\\\\\",t);let o=await d(e);console.log(\\\\\\\"All pages containing backlinks\\\\\\\",o);let i=await n(\\\\\\\"editor.getText\\\\\\\");console.log(\\\\\\\"Writing new page to space\\\\\\\"),await n(\\\\\\\"space.writePage\\\\\\\",t,i),console.log(\\\\\\\"Deleting page from space\\\\\\\"),await n(\\\\\\\"space.deletePage\\\\\\\",e),console.log(\\\\\\\"Reloading page list\\\\\\\"),await n(\\\\\\\"space.reloadPageList\\\\\\\"),console.log(\\\\\\\"Navigating to new page\\\\\\\"),await n(\\\\\\\"editor.navigate\\\\\\\",t);let l=new Set;for(let s of o)l.add(s.page);for(let s of l){console.log(\\\\\\\"Now going to update links in\\\\\\\",s);let{text:g}=await n(\\\\\\\"space.readPage\\\\\\\",s);if(!g)continue;let c=g.replaceAll(`[[${e}]]`,`[[${t}]]`);g!==c&&(console.log(\\\\\\\"Changes made, saving...\\\\\\\"),await n(\\\\\\\"space.writePage\\\\\\\",s,c))}}async function d(a){let e=await n(\\\\\\\"indexer.scanPrefixGlobal\\\\\\\",`pl:${a}:`),t=[];for(let{key:o,value:i}of e){let l=o.split(\\\\\\\":\\\\\\\");t.push({page:i,pos:+l[l.length-1]})}return t}async function b(){let a=await n(\\\\\\\"editor.getCurrentPage\\\\\\\"),e=await d(a.name);console.log(\\\\\\\"Backlinks\\\\\\\",e)}async function B(){await n(\\\\\\\"space.reindex\\\\\\\")}return P(R);})();\\\\n//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiY29yZS9wYWdlLnRzIiwgIi4uL3dlYmFwcC9zcmMvY29uc3RhbnQudHMiLCAiY29yZS9saWIvc3lzY2FsbC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiaW1wb3J0IHsgSW5kZXhFdmVudCB9IGZyb20gXCIuLi8uLi93ZWJhcHAvc3JjL2FwcF9ldmVudFwiO1xuaW1wb3J0IHsgcGFnZUxpbmtSZWdleCB9IGZyb20gXCIuLi8uLi93ZWJhcHAvc3JjL2NvbnN0YW50XCI7XG5pbXBvcnQgeyBzeXNjYWxsIH0gZnJvbSBcIi4vbGliL3N5c2NhbGxcIjtcblxuY29uc3Qgd2lraWxpbmtSZWdleCA9IG5ldyBSZWdFeHAocGFnZUxpbmtSZWdleCwgXCJnXCIpO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gaW5kZXhMaW5rcyh7IG5hbWUsIHRleHQgfTogSW5kZXhFdmVudCkge1xuICBsZXQgYmFja0xpbmtzOiB7IGtleTogc3RyaW5nOyB2YWx1ZTogc3RyaW5nIH1bXSA9IFtdO1xuICBmb3IgKGxldCBtYXRjaCBvZiB0ZXh0Lm1hdGNoQWxsKHdpa2lsaW5rUmVnZXgpKSB7XG4gICAgbGV0IHRvUGFnZSA9IG1hdGNoWzFdO1xuICAgIGxldCBwb3MgPSBtYXRjaC5pbmRleCE7XG4gICAgYmFja0xpbmtzLnB1c2goe1xuICAgICAga2V5OiBgcGw6JHt0b1BhZ2V9OiR7cG9zfWAsXG4gICAgICB2YWx1ZTogbmFtZSxcbiAgICB9KTtcbiAgfVxuICBjb25zb2xlLmxvZyhcIkZvdW5kXCIsIGJhY2tMaW5rcy5sZW5ndGgsIFwid2lraSBsaW5rKHMpXCIpO1xuICBhd2FpdCBzeXNjYWxsKFwiaW5kZXhlci5iYXRjaFNldFwiLCBuYW1lLCBiYWNrTGlua3MpO1xufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZGVsZXRlUGFnZSgpIHtcbiAgbGV0IHBhZ2VNZXRhID0gYXdhaXQgc3lzY2FsbChcImVkaXRvci5nZXRDdXJyZW50UGFnZVwiKTtcbiAgY29uc29sZS5sb2coXCJOYXZpZ2F0aW5nIHRvIHN0YXJ0IHBhZ2VcIik7XG4gIGF3YWl0IHN5c2NhbGwoXCJlZGl0b3IubmF2aWdhdGVcIiwgXCJzdGFydFwiKTtcbiAgY29uc29sZS5sb2coXCJEZWxldGluZyBwYWdlIGZyb20gc3BhY2VcIik7XG4gIGF3YWl0IHN5c2NhbGwoXCJzcGFjZS5kZWxldGVQYWdlXCIsIHBhZ2VNZXRhLm5hbWUpO1xuICBjb25zb2xlLmxvZyhcIlJlbG9hZGluZyBwYWdlIGxpc3RcIik7XG4gIGF3YWl0IHN5c2NhbGwoXCJzcGFjZS5yZWxvYWRQYWdlTGlzdFwiKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHJlbmFtZVBhZ2UoKSB7XG4gIGNvbnN0IHBhZ2VNZXRhID0gYXdhaXQgc3lzY2FsbChcImVkaXRvci5nZXRDdXJyZW50UGFnZVwiKTtcbiAgY29uc3Qgb2xkTmFtZSA9IHBhZ2VNZXRhLm5hbWU7XG4gIGNvbnNvbGUubG9nKFwiT2xkIG5hbWUgaXNcIiwgb2xkTmFtZSk7XG4gIGNvbnN0IG5ld05hbWUgPSBhd2FpdCBzeXNjYWxsKFxuICAgIFwiZWRpdG9yLnByb21wdFwiLFxuICAgIGBSZW5hbWUgJHtvbGROYW1lfSB0bzpgLFxuICAgIG9sZE5hbWVcbiAgKTtcbiAgaWYgKCFuZXdOYW1lKSB7XG4gICAgcmV0dXJuO1xuICB9XG4gIGNvbnNvbGUubG9nKFwiTmV3IG5hbWVcIiwgbmV3TmFtZSk7XG5cbiAgbGV0IHBhZ2VzVG9VcGRhdGUgPSBhd2FpdCBnZXRCYWNrTGlua3Mob2xkTmFtZSk7XG4gIGNvbnNvbGUubG9nKFwiQWxsIHBhZ2VzIGNvbnRhaW5pbmcgYmFja2xpbmtzXCIsIHBhZ2VzVG9VcGRhdGUpO1xuXG4gIGxldCB0ZXh0ID0gYXdhaXQgc3lzY2FsbChcImVkaXRvci5nZXRUZXh0XCIpO1xuICBjb25zb2xlLmxvZyhcIldyaXRpbmcgbmV3IHBhZ2UgdG8gc3BhY2VcIik7XG4gIGF3YWl0IHN5c2NhbGwoXCJzcGFjZS53cml0ZVBhZ2VcIiwgbmV3TmFtZSwgdGV4dCk7XG4gIGNvbnNvbGUubG9nKFwiRGVsZXRpbmcgcGFnZSBmcm9tIHNwYWNlXCIpO1xuICBhd2FpdCBzeXNjYWxsKFwic3BhY2UuZGVsZXRlUGFnZVwiLCBvbGROYW1lKTtcbiAgY29uc29sZS5sb2coXCJSZWxvYWRpbmcgcGFnZSBsaXN0XCIpO1xuICBhd2FpdCBzeXNjYWxsKFwic3BhY2UucmVsb2FkUGFnZUxpc3RcIik7XG4gIGNvbnNvbGUubG9nKFwiTmF2aWdhdGluZyB0byBuZXcgcGFnZVwiKTtcbiAgYXdhaXQgc3lzY2FsbChcImVkaXRvci5uYXZpZ2F0ZVwiLCBuZXdOYW1lKTtcblxuICBsZXQgcGFnZVRvVXBkYXRlU2V0ID0gbmV3IFNldDxzdHJpbmc+KCk7XG4gIGZvciAobGV0IHBhZ2VUb1VwZGF0ZSBvZiBwYWdlc1RvVXBkYXRlKSB7XG4gICAgcGFnZVRvVXBkYXRlU2V0LmFkZChwYWdlVG9VcGRhdGUucGFnZSk7XG4gIH1cblxuICBmb3IgKGxldCBwYWdlVG9VcGRhdGUgb2YgcGFnZVRvVXBkYXRlU2V0KSB7XG4gICAgY29uc29sZS5sb2coXCJOb3cgZ29pbmcgdG8gdXBkYXRlIGxpbmtzIGluXCIsIHBhZ2VUb1VwZGF0ZSk7XG4gICAgbGV0IHsgdGV4dCB9ID0gYXdhaXQgc3lzY2FsbChcInNwYWNlLnJlYWRQYWdlXCIsIHBhZ2VUb1VwZGF0ZSk7XG4gICAgaWYgKCF0ZXh0KSB7XG4gICAgICAvLyBQYWdlIGxpa2VseSBkb2VzIG5vdCBleGlzdCwgYnV0IGF0IGxlYXN0IHdlIGNhbiBza2lwIGl0XG4gICAgICBjb250aW51ZTtcbiAgICB9XG4gICAgbGV0IG5ld1RleHQgPSB0ZXh0LnJlcGxhY2VBbGwoYFtbJHtvbGROYW1lfV1dYCwgYFtbJHtuZXdOYW1lfV1dYCk7XG4gICAgaWYgKHRleHQgIT09IG5ld1RleHQpIHtcbiAgICAgIGNvbnNvbGUubG9nKFwiQ2hhbmdlcyBtYWRlLCBzYXZpbmcuLi5cIik7XG4gICAgICBhd2FpdCBzeXNjYWxsKFwic3BhY2Uud3JpdGVQYWdlXCIsIHBhZ2VUb1VwZGF0ZSwgbmV3VGV4dCk7XG4gICAgfVxuICB9XG59XG5cbnR5cGUgQmFja0xpbmsgPSB7XG4gIHBhZ2U6IHN0cmluZztcbiAgcG9zOiBudW1iZXI7XG59O1xuXG5hc3luYyBmdW5jdGlvbiBnZXRCYWNrTGlua3MocGFnZU5hbWU6IHN0cmluZyk6IFByb21pc2U8QmFja0xpbmtbXT4ge1xuICBsZXQgYWxsQmFja0xpbmtzID0gYXdhaXQgc3lzY2FsbChcbiAgICBcImluZGV4ZXIuc2NhblByZWZpeEdsb2JhbFwiLFxuICAgIGBwbDoke3BhZ2VOYW1lfTpgXG4gICk7XG4gIGxldCBwYWdlc1RvVXBkYXRlOiBCYWNrTGlua1tdID0gW107XG4gIGZvciAobGV0IHsga2V5LCB2YWx1ZSB9IG9mIGFsbEJhY2tMaW5rcykge1xuICAgIGxldCBrZXlQYXJ0cyA9IGtleS5zcGxpdChcIjpcIik7XG4gICAgcGFnZXNUb1VwZGF0ZS5wdXNoKHtcbiAgICAgIHBhZ2U6IHZhbHVlLFxuICAgICAgcG9zOiAra2V5UGFydHNba2V5UGFydHMubGVuZ3RoIC0gMV0sXG4gICAgfSk7XG4gIH1cbiAgcmV0dXJuIHBhZ2VzVG9VcGRhdGU7XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBzaG93QmFja0xpbmtzKCkge1xuICBjb25zdCBwYWdlTWV0YSA9IGF3YWl0IHN5c2NhbGwoXCJlZGl0b3IuZ2V0Q3VycmVudFBhZ2VcIik7XG4gIGxldCBiYWNrTGlua3MgPSBhd2FpdCBnZXRCYWNrTGlua3MocGFnZU1ldGEubmFtZSk7XG5cbiAgY29uc29sZS5sb2coXCJCYWNrbGlua3NcIiwgYmFja0xpbmtzKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHJlaW5kZXgoKSB7XG4gIGF3YWl0IHN5c2NhbGwoXCJzcGFjZS5yZWluZGV4XCIpO1xufVxuIiwgImV4cG9ydCBjb25zdCBwYWdlTGlua1JlZ2V4ID0gL1xcW1xcWyhbXFx3XFxzXFwvXFw6LFxcLlxcLV0rKVxcXVxcXS87XG4iLCAiZXhwb3J0IGZ1bmN0aW9uIHN5c2NhbGwobmFtZTogc3RyaW5nLCAuLi5hcmdzOiBhbnlbXSk6IGFueSB7XG4gIGxldCByZXFJZCA9IE1hdGguZmxvb3IoTWF0aC5yYW5kb20oKSAqIDEwMDAwMDApO1xuICAvLyBjb25zb2xlLmxvZyhcIlN5c2NhbGxcIiwgbmFtZSwgcmVxSWQpO1xuICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIHNlbGYuZGlzcGF0Y2hFdmVudChcbiAgICAgIG5ldyBDdXN0b21FdmVudChcInN5c2NhbGxcIiwge1xuICAgICAgICBkZXRhaWw6IHtcbiAgICAgICAgICBpZDogcmVxSWQsXG4gICAgICAgICAgbmFtZTogbmFtZSxcbiAgICAgICAgICBhcmdzOiBhcmdzLFxuICAgICAgICAgIGNhbGxiYWNrOiByZXNvbHZlLFxuICAgICAgICB9LFxuICAgICAgfSlcbiAgICApO1xuICB9KTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI0aEJBQUEscUdDQU8sR0FBTSxHQUFnQiw2QkNBdEIsV0FBaUIsS0FBaUIsRUFBa0IsQ0FDekQsR0FBSSxHQUFRLEtBQUssTUFBTSxLQUFLLFNBQVcsS0FFdkMsTUFBTyxJQUFJLFNBQVEsQ0FBQyxFQUFTLElBQVcsQ0FDdEMsS0FBSyxjQUNILEdBQUksYUFBWSxVQUFXLENBQ3pCLE9BQVEsQ0FDTixHQUFJLEVBQ0osS0FBTSxFQUNOLEtBQU0sRUFDTixTQUFVLFFGTnBCLEdBQU0sR0FBZ0IsR0FBSSxRQUFPLEVBQWUsS0FFaEQsaUJBQWlDLENBQUUsT0FBTSxRQUFvQixDQUMzRCxHQUFJLEdBQThDLEdBQ2xELE9BQVMsS0FBUyxHQUFLLFNBQVMsR0FBZ0IsQ0FDOUMsR0FBSSxHQUFTLEVBQU0sR0FDZixFQUFNLEVBQU0sTUFDaEIsRUFBVSxLQUFLLENBQ2IsSUFBSyxNQUFNLEtBQVUsSUFDckIsTUFBTyxJQUdYLFFBQVEsSUFBSSxRQUFTLEVBQVUsT0FBUSxnQkFDdkMsS0FBTSxHQUFRLG1CQUFvQixFQUFNLEdBRzFDLGtCQUFtQyxDQUNqQyxHQUFJLEdBQVcsS0FBTSxHQUFRLHlCQUM3QixRQUFRLElBQUksNEJBQ1osS0FBTSxHQUFRLGtCQUFtQixTQUNqQyxRQUFRLElBQUksNEJBQ1osS0FBTSxHQUFRLG1CQUFvQixFQUFTLE1BQzNDLFFBQVEsSUFBSSx1QkFDWixLQUFNLEdBQVEsd0JBR2hCLGtCQUFtQyxDQUVqQyxHQUFNLEdBQVUsQUFEQyxNQUFNLEdBQVEsMEJBQ04sS0FDekIsUUFBUSxJQUFJLGNBQWUsR0FDM0IsR0FBTSxHQUFVLEtBQU0sR0FDcEIsZ0JBQ0EsVUFBVSxRQUNWLEdBRUYsR0FBSSxDQUFDLEVBQ0gsT0FFRixRQUFRLElBQUksV0FBWSxHQUV4QixHQUFJLEdBQWdCLEtBQU0sR0FBYSxHQUN2QyxRQUFRLElBQUksaUNBQWtDLEdBRTlDLEdBQUksR0FBTyxLQUFNLEdBQVEsa0JBQ3pCLFFBQVEsSUFBSSw2QkFDWixLQUFNLEdBQVEsa0JBQW1CLEVBQVMsR0FDMUMsUUFBUSxJQUFJLDRCQUNaLEtBQU0sR0FBUSxtQkFBb0IsR0FDbEMsUUFBUSxJQUFJLHVCQUNaLEtBQU0sR0FBUSx3QkFDZCxRQUFRLElBQUksMEJBQ1osS0FBTSxHQUFRLGtCQUFtQixHQUVqQyxHQUFJLEdBQWtCLEdBQUksS0FDMUIsT0FBUyxLQUFnQixHQUN2QixFQUFnQixJQUFJLEVBQWEsTUFHbkMsT0FBUyxLQUFnQixHQUFpQixDQUN4QyxRQUFRLElBQUksK0JBQWdDLEdBQzVDLEdBQUksQ0FBRSxRQUFTLEtBQU0sR0FBUSxpQkFBa0IsR0FDL0MsR0FBSSxDQUFDLEVBRUgsU0FFRixHQUFJLEdBQVUsRUFBSyxXQUFXLEtBQUssTUFBYSxLQUFLLE9BQ3JELEFBQUksSUFBUyxHQUNYLFNBQVEsSUFBSSwyQkFDWixLQUFNLEdBQVEsa0JBQW1CLEVBQWMsS0FVckQsaUJBQTRCLEVBQXVDLENBQ2pFLEdBQUksR0FBZSxLQUFNLEdBQ3ZCLDJCQUNBLE1BQU0sTUFFSixFQUE0QixHQUNoQyxPQUFTLENBQUUsTUFBSyxVQUFXLEdBQWMsQ0FDdkMsR0FBSSxHQUFXLEVBQUksTUFBTSxLQUN6QixFQUFjLEtBQUssQ0FDakIsS0FBTSxFQUNOLElBQUssQ0FBQyxFQUFTLEVBQVMsT0FBUyxLQUdyQyxNQUFPLEdBR1Qsa0JBQXNDLENBQ3BDLEdBQU0sR0FBVyxLQUFNLEdBQVEseUJBQzNCLEVBQVksS0FBTSxHQUFhLEVBQVMsTUFFNUMsUUFBUSxJQUFJLFlBQWEsR0FHM0Isa0JBQWdDLENBQzlCLEtBQU0sR0FBUSIsCiAgIm5hbWVzIjogW10KfQo=\\\\n\\\",\\\"functionName\\\":\\\"deletePage\\\"},\\\"showBackLinks\\\":{\\\"path\\\":\\\"core/page.ts\\\",\\\"code\\\":\\\"(()=>{var r=Object.defineProperty;var w=Object.getOwnPropertyDescriptor;var k=Object.getOwnPropertyNames;var f=Object.prototype.hasOwnProperty;var m=a=>r(a,\\\\\\\"__esModule\\\\\\\",{value:!0});var x=(a,e)=>{for(var t in e)r(a,t,{get:e[t],enumerable:!0})},u=(a,e,t,o)=>{if(e&&typeof e==\\\\\\\"object\\\\\\\"||typeof e==\\\\\\\"function\\\\\\\")for(let i of k(e))!f.call(a,i)&&(t||i!==\\\\\\\"default\\\\\\\")&&r(a,i,{get:()=>e[i],enumerable:!(o=w(e,i))||o.enumerable});return a};var P=(a=>(e,t)=>a&&a.get(e)||(t=u(m({}),e,1),a&&a.set(e,t),t))(typeof WeakMap!=\\\\\\\"undefined\\\\\\\"?new WeakMap:0);var R={};x(R,{deletePage:()=>h,indexLinks:()=>L,reindex:()=>B,renamePage:()=>v,showBackLinks:()=>b});var p=/\\\\\\\\[\\\\\\\\[([\\\\\\\\w\\\\\\\\s\\\\\\\\/\\\\\\\\:,\\\\\\\\.\\\\\\\\-]+)\\\\\\\\]\\\\\\\\]/;function n(a,...e){let t=Math.floor(Math.random()*1e6);return new Promise((o,i)=>{self.dispatchEvent(new CustomEvent(\\\\\\\"syscall\\\\\\\",{detail:{id:t,name:a,args:e,callback:o}}))})}var y=new RegExp(p,\\\\\\\"g\\\\\\\");async function L({name:a,text:e}){let t=[];for(let o of e.matchAll(y)){let i=o[1],l=o.index;t.push({key:`pl:${i}:${l}`,value:a})}console.log(\\\\\\\"Found\\\\\\\",t.length,\\\\\\\"wiki link(s)\\\\\\\"),await n(\\\\\\\"indexer.batchSet\\\\\\\",a,t)}async function h(){let a=await n(\\\\\\\"editor.getCurrentPage\\\\\\\");console.log(\\\\\\\"Navigating to start page\\\\\\\"),await n(\\\\\\\"editor.navigate\\\\\\\",\\\\\\\"start\\\\\\\"),console.log(\\\\\\\"Deleting page from space\\\\\\\"),await n(\\\\\\\"space.deletePage\\\\\\\",a.name),console.log(\\\\\\\"Reloading page list\\\\\\\"),await n(\\\\\\\"space.reloadPageList\\\\\\\")}async function v(){let e=(await n(\\\\\\\"editor.getCurrentPage\\\\\\\")).name;console.log(\\\\\\\"Old name is\\\\\\\",e);let t=await n(\\\\\\\"editor.prompt\\\\\\\",`Rename ${e} to:`,e);if(!t)return;console.log(\\\\\\\"New name\\\\\\\",t);let o=await d(e);console.log(\\\\\\\"All pages containing backlinks\\\\\\\",o);let i=await n(\\\\\\\"editor.getText\\\\\\\");console.log(\\\\\\\"Writing new page to space\\\\\\\"),await n(\\\\\\\"space.writePage\\\\\\\",t,i),console.log(\\\\\\\"Deleting page from space\\\\\\\"),await n(\\\\\\\"space.deletePage\\\\\\\",e),console.log(\\\\\\\"Reloading page list\\\\\\\"),await n(\\\\\\\"space.reloadPageList\\\\\\\"),console.log(\\\\\\\"Navigating to new page\\\\\\\"),await n(\\\\\\\"editor.navigate\\\\\\\",t);let l=new Set;for(let s of o)l.add(s.page);for(let s of l){console.log(\\\\\\\"Now going to update links in\\\\\\\",s);let{text:g}=await n(\\\\\\\"space.readPage\\\\\\\",s);if(!g)continue;let c=g.replaceAll(`[[${e}]]`,`[[${t}]]`);g!==c&&(console.log(\\\\\\\"Changes made, saving...\\\\\\\"),await n(\\\\\\\"space.writePage\\\\\\\",s,c))}}async function d(a){let e=await n(\\\\\\\"indexer.scanPrefixGlobal\\\\\\\",`pl:${a}:`),t=[];for(let{key:o,value:i}of e){let l=o.split(\\\\\\\":\\\\\\\");t.push({page:i,pos:+l[l.length-1]})}return t}async function b(){let a=await n(\\\\\\\"editor.getCurrentPage\\\\\\\"),e=await d(a.name);console.log(\\\\\\\"Backlinks\\\\\\\",e)}async function B(){await n(\\\\\\\"space.reindex\\\\\\\")}return P(R);})();\\\\n//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiY29yZS9wYWdlLnRzIiwgIi4uL3dlYmFwcC9zcmMvY29uc3RhbnQudHMiLCAiY29yZS9saWIvc3lzY2FsbC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiaW1wb3J0IHsgSW5kZXhFdmVudCB9IGZyb20gXCIuLi8uLi93ZWJhcHAvc3JjL2FwcF9ldmVudFwiO1xuaW1wb3J0IHsgcGFnZUxpbmtSZWdleCB9IGZyb20gXCIuLi8uLi93ZWJhcHAvc3JjL2NvbnN0YW50XCI7XG5pbXBvcnQgeyBzeXNjYWxsIH0gZnJvbSBcIi4vbGliL3N5c2NhbGxcIjtcblxuY29uc3Qgd2lraWxpbmtSZWdleCA9IG5ldyBSZWdFeHAocGFnZUxpbmtSZWdleCwgXCJnXCIpO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gaW5kZXhMaW5rcyh7IG5hbWUsIHRleHQgfTogSW5kZXhFdmVudCkge1xuICBsZXQgYmFja0xpbmtzOiB7IGtleTogc3RyaW5nOyB2YWx1ZTogc3RyaW5nIH1bXSA9IFtdO1xuICBmb3IgKGxldCBtYXRjaCBvZiB0ZXh0Lm1hdGNoQWxsKHdpa2lsaW5rUmVnZXgpKSB7XG4gICAgbGV0IHRvUGFnZSA9IG1hdGNoWzFdO1xuICAgIGxldCBwb3MgPSBtYXRjaC5pbmRleCE7XG4gICAgYmFja0xpbmtzLnB1c2goe1xuICAgICAga2V5OiBgcGw6JHt0b1BhZ2V9OiR7cG9zfWAsXG4gICAgICB2YWx1ZTogbmFtZSxcbiAgICB9KTtcbiAgfVxuICBjb25zb2xlLmxvZyhcIkZvdW5kXCIsIGJhY2tMaW5rcy5sZW5ndGgsIFwid2lraSBsaW5rKHMpXCIpO1xuICBhd2FpdCBzeXNjYWxsKFwiaW5kZXhlci5iYXRjaFNldFwiLCBuYW1lLCBiYWNrTGlua3MpO1xufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZGVsZXRlUGFnZSgpIHtcbiAgbGV0IHBhZ2VNZXRhID0gYXdhaXQgc3lzY2FsbChcImVkaXRvci5nZXRDdXJyZW50UGFnZVwiKTtcbiAgY29uc29sZS5sb2coXCJOYXZpZ2F0aW5nIHRvIHN0YXJ0IHBhZ2VcIik7XG4gIGF3YWl0IHN5c2NhbGwoXCJlZGl0b3IubmF2aWdhdGVcIiwgXCJzdGFydFwiKTtcbiAgY29uc29sZS5sb2coXCJEZWxldGluZyBwYWdlIGZyb20gc3BhY2VcIik7XG4gIGF3YWl0IHN5c2NhbGwoXCJzcGFjZS5kZWxldGVQYWdlXCIsIHBhZ2VNZXRhLm5hbWUpO1xuICBjb25zb2xlLmxvZyhcIlJlbG9hZGluZyBwYWdlIGxpc3RcIik7XG4gIGF3YWl0IHN5c2NhbGwoXCJzcGFjZS5yZWxvYWRQYWdlTGlzdFwiKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHJlbmFtZVBhZ2UoKSB7XG4gIGNvbnN0IHBhZ2VNZXRhID0gYXdhaXQgc3lzY2FsbChcImVkaXRvci5nZXRDdXJyZW50UGFnZVwiKTtcbiAgY29uc3Qgb2xkTmFtZSA9IHBhZ2VNZXRhLm5hbWU7XG4gIGNvbnNvbGUubG9nKFwiT2xkIG5hbWUgaXNcIiwgb2xkTmFtZSk7XG4gIGNvbnN0IG5ld05hbWUgPSBhd2FpdCBzeXNjYWxsKFxuICAgIFwiZWRpdG9yLnByb21wdFwiLFxuICAgIGBSZW5hbWUgJHtvbGROYW1lfSB0bzpgLFxuICAgIG9sZE5hbWVcbiAgKTtcbiAgaWYgKCFuZXdOYW1lKSB7XG4gICAgcmV0dXJuO1xuICB9XG4gIGNvbnNvbGUubG9nKFwiTmV3IG5hbWVcIiwgbmV3TmFtZSk7XG5cbiAgbGV0IHBhZ2VzVG9VcGRhdGUgPSBhd2FpdCBnZXRCYWNrTGlua3Mob2xkTmFtZSk7XG4gIGNvbnNvbGUubG9nKFwiQWxsIHBhZ2VzIGNvbnRhaW5pbmcgYmFja2xpbmtzXCIsIHBhZ2VzVG9VcGRhdGUpO1xuXG4gIGxldCB0ZXh0ID0gYXdhaXQgc3lzY2FsbChcImVkaXRvci5nZXRUZXh0XCIpO1xuICBjb25zb2xlLmxvZyhcIldyaXRpbmcgbmV3IHBhZ2UgdG8gc3BhY2VcIik7XG4gIGF3YWl0IHN5c2NhbGwoXCJzcGFjZS53cml0ZVBhZ2VcIiwgbmV3TmFtZSwgdGV4dCk7XG4gIGNvbnNvbGUubG9nKFwiRGVsZXRpbmcgcGFnZSBmcm9tIHNwYWNlXCIpO1xuICBhd2FpdCBzeXNjYWxsKFwic3BhY2UuZGVsZXRlUGFnZVwiLCBvbGROYW1lKTtcbiAgY29uc29sZS5sb2coXCJSZWxvYWRpbmcgcGFnZSBsaXN0XCIpO1xuICBhd2FpdCBzeXNjYWxsKFwic3BhY2UucmVsb2FkUGFnZUxpc3RcIik7XG4gIGNvbnNvbGUubG9nKFwiTmF2aWdhdGluZyB0byBuZXcgcGFnZVwiKTtcbiAgYXdhaXQgc3lzY2FsbChcImVkaXRvci5uYXZpZ2F0ZVwiLCBuZXdOYW1lKTtcblxuICBsZXQgcGFnZVRvVXBkYXRlU2V0ID0gbmV3IFNldDxzdHJpbmc+KCk7XG4gIGZvciAobGV0IHBhZ2VUb1VwZGF0ZSBvZiBwYWdlc1RvVXBkYXRlKSB7XG4gICAgcGFnZVRvVXBkYXRlU2V0LmFkZChwYWdlVG9VcGRhdGUucGFnZSk7XG4gIH1cblxuICBmb3IgKGxldCBwYWdlVG9VcGRhdGUgb2YgcGFnZVRvVXBkYXRlU2V0KSB7XG4gICAgY29uc29sZS5sb2coXCJOb3cgZ29pbmcgdG8gdXBkYXRlIGxpbmtzIGluXCIsIHBhZ2VUb1VwZGF0ZSk7XG4gICAgbGV0IHsgdGV4dCB9ID0gYXdhaXQgc3lzY2FsbChcInNwYWNlLnJlYWRQYWdlXCIsIHBhZ2VUb1VwZGF0ZSk7XG4gICAgaWYgKCF0ZXh0KSB7XG4gICAgICAvLyBQYWdlIGxpa2VseSBkb2VzIG5vdCBleGlzdCwgYnV0IGF0IGxlYXN0IHdlIGNhbiBza2lwIGl0XG4gICAgICBjb250aW51ZTtcbiAgICB9XG4gICAgbGV0IG5ld1RleHQgPSB0ZXh0LnJlcGxhY2VBbGwoYFtbJHtvbGROYW1lfV1dYCwgYFtbJHtuZXdOYW1lfV1dYCk7XG4gICAgaWYgKHRleHQgIT09IG5ld1RleHQpIHtcbiAgICAgIGNvbnNvbGUubG9nKFwiQ2hhbmdlcyBtYWRlLCBzYXZpbmcuLi5cIik7XG4gICAgICBhd2FpdCBzeXNjYWxsKFwic3BhY2Uud3JpdGVQYWdlXCIsIHBhZ2VUb1VwZGF0ZSwgbmV3VGV4dCk7XG4gICAgfVxuICB9XG59XG5cbnR5cGUgQmFja0xpbmsgPSB7XG4gIHBhZ2U6IHN0cmluZztcbiAgcG9zOiBudW1iZXI7XG59O1xuXG5hc3luYyBmdW5jdGlvbiBnZXRCYWNrTGlua3MocGFnZU5hbWU6IHN0cmluZyk6IFByb21pc2U8QmFja0xpbmtbXT4ge1xuICBsZXQgYWxsQmFja0xpbmtzID0gYXdhaXQgc3lzY2FsbChcbiAgICBcImluZGV4ZXIuc2NhblByZWZpeEdsb2JhbFwiLFxuICAgIGBwbDoke3BhZ2VOYW1lfTpgXG4gICk7XG4gIGxldCBwYWdlc1RvVXBkYXRlOiBCYWNrTGlua1tdID0gW107XG4gIGZvciAobGV0IHsga2V5LCB2YWx1ZSB9IG9mIGFsbEJhY2tMaW5rcykge1xuICAgIGxldCBrZXlQYXJ0cyA9IGtleS5zcGxpdChcIjpcIik7XG4gICAgcGFnZXNUb1VwZGF0ZS5wdXNoKHtcbiAgICAgIHBhZ2U6IHZhbHVlLFxuICAgICAgcG9zOiAra2V5UGFydHNba2V5UGFydHMubGVuZ3RoIC0gMV0sXG4gICAgfSk7XG4gIH1cbiAgcmV0dXJuIHBhZ2VzVG9VcGRhdGU7XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBzaG93QmFja0xpbmtzKCkge1xuICBjb25zdCBwYWdlTWV0YSA9IGF3YWl0IHN5c2NhbGwoXCJlZGl0b3IuZ2V0Q3VycmVudFBhZ2VcIik7XG4gIGxldCBiYWNrTGlua3MgPSBhd2FpdCBnZXRCYWNrTGlua3MocGFnZU1ldGEubmFtZSk7XG5cbiAgY29uc29sZS5sb2coXCJCYWNrbGlua3NcIiwgYmFja0xpbmtzKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHJlaW5kZXgoKSB7XG4gIGF3YWl0IHN5c2NhbGwoXCJzcGFjZS5yZWluZGV4XCIpO1xufVxuIiwgImV4cG9ydCBjb25zdCBwYWdlTGlua1JlZ2V4ID0gL1xcW1xcWyhbXFx3XFxzXFwvXFw6LFxcLlxcLV0rKVxcXVxcXS87XG4iLCAiZXhwb3J0IGZ1bmN0aW9uIHN5c2NhbGwobmFtZTogc3RyaW5nLCAuLi5hcmdzOiBhbnlbXSk6IGFueSB7XG4gIGxldCByZXFJZCA9IE1hdGguZmxvb3IoTWF0aC5yYW5kb20oKSAqIDEwMDAwMDApO1xuICAvLyBjb25zb2xlLmxvZyhcIlN5c2NhbGxcIiwgbmFtZSwgcmVxSWQpO1xuICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIHNlbGYuZGlzcGF0Y2hFdmVudChcbiAgICAgIG5ldyBDdXN0b21FdmVudChcInN5c2NhbGxcIiwge1xuICAgICAgICBkZXRhaWw6IHtcbiAgICAgICAgICBpZDogcmVxSWQsXG4gICAgICAgICAgbmFtZTogbmFtZSxcbiAgICAgICAgICBhcmdzOiBhcmdzLFxuICAgICAgICAgIGNhbGxiYWNrOiByZXNvbHZlLFxuICAgICAgICB9LFxuICAgICAgfSlcbiAgICApO1xuICB9KTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI0aEJBQUEscUdDQU8sR0FBTSxHQUFnQiw2QkNBdEIsV0FBaUIsS0FBaUIsRUFBa0IsQ0FDekQsR0FBSSxHQUFRLEtBQUssTUFBTSxLQUFLLFNBQVcsS0FFdkMsTUFBTyxJQUFJLFNBQVEsQ0FBQyxFQUFTLElBQVcsQ0FDdEMsS0FBSyxjQUNILEdBQUksYUFBWSxVQUFXLENBQ3pCLE9BQVEsQ0FDTixHQUFJLEVBQ0osS0FBTSxFQUNOLEtBQU0sRUFDTixTQUFVLFFGTnBCLEdBQU0sR0FBZ0IsR0FBSSxRQUFPLEVBQWUsS0FFaEQsaUJBQWlDLENBQUUsT0FBTSxRQUFvQixDQUMzRCxHQUFJLEdBQThDLEdBQ2xELE9BQVMsS0FBUyxHQUFLLFNBQVMsR0FBZ0IsQ0FDOUMsR0FBSSxHQUFTLEVBQU0sR0FDZixFQUFNLEVBQU0sTUFDaEIsRUFBVSxLQUFLLENBQ2IsSUFBSyxNQUFNLEtBQVUsSUFDckIsTUFBTyxJQUdYLFFBQVEsSUFBSSxRQUFTLEVBQVUsT0FBUSxnQkFDdkMsS0FBTSxHQUFRLG1CQUFvQixFQUFNLEdBRzFDLGtCQUFtQyxDQUNqQyxHQUFJLEdBQVcsS0FBTSxHQUFRLHlCQUM3QixRQUFRLElBQUksNEJBQ1osS0FBTSxHQUFRLGtCQUFtQixTQUNqQyxRQUFRLElBQUksNEJBQ1osS0FBTSxHQUFRLG1CQUFvQixFQUFTLE1BQzNDLFFBQVEsSUFBSSx1QkFDWixLQUFNLEdBQVEsd0JBR2hCLGtCQUFtQyxDQUVqQyxHQUFNLEdBQVUsQUFEQyxNQUFNLEdBQVEsMEJBQ04sS0FDekIsUUFBUSxJQUFJLGNBQWUsR0FDM0IsR0FBTSxHQUFVLEtBQU0sR0FDcEIsZ0JBQ0EsVUFBVSxRQUNWLEdBRUYsR0FBSSxDQUFDLEVBQ0gsT0FFRixRQUFRLElBQUksV0FBWSxHQUV4QixHQUFJLEdBQWdCLEtBQU0sR0FBYSxHQUN2QyxRQUFRLElBQUksaUNBQWtDLEdBRTlDLEdBQUksR0FBTyxLQUFNLEdBQVEsa0JBQ3pCLFFBQVEsSUFBSSw2QkFDWixLQUFNLEdBQVEsa0JBQW1CLEVBQVMsR0FDMUMsUUFBUSxJQUFJLDRCQUNaLEtBQU0sR0FBUSxtQkFBb0IsR0FDbEMsUUFBUSxJQUFJLHVCQUNaLEtBQU0sR0FBUSx3QkFDZCxRQUFRLElBQUksMEJBQ1osS0FBTSxHQUFRLGtCQUFtQixHQUVqQyxHQUFJLEdBQWtCLEdBQUksS0FDMUIsT0FBUyxLQUFnQixHQUN2QixFQUFnQixJQUFJLEVBQWEsTUFHbkMsT0FBUyxLQUFnQixHQUFpQixDQUN4QyxRQUFRLElBQUksK0JBQWdDLEdBQzVDLEdBQUksQ0FBRSxRQUFTLEtBQU0sR0FBUSxpQkFBa0IsR0FDL0MsR0FBSSxDQUFDLEVBRUgsU0FFRixHQUFJLEdBQVUsRUFBSyxXQUFXLEtBQUssTUFBYSxLQUFLLE9BQ3JELEFBQUksSUFBUyxHQUNYLFNBQVEsSUFBSSwyQkFDWixLQUFNLEdBQVEsa0JBQW1CLEVBQWMsS0FVckQsaUJBQTRCLEVBQXVDLENBQ2pFLEdBQUksR0FBZSxLQUFNLEdBQ3ZCLDJCQUNBLE1BQU0sTUFFSixFQUE0QixHQUNoQyxPQUFTLENBQUUsTUFBSyxVQUFXLEdBQWMsQ0FDdkMsR0FBSSxHQUFXLEVBQUksTUFBTSxLQUN6QixFQUFjLEtBQUssQ0FDakIsS0FBTSxFQUNOLElBQUssQ0FBQyxFQUFTLEVBQVMsT0FBUyxLQUdyQyxNQUFPLEdBR1Qsa0JBQXNDLENBQ3BDLEdBQU0sR0FBVyxLQUFNLEdBQVEseUJBQzNCLEVBQVksS0FBTSxHQUFhLEVBQVMsTUFFNUMsUUFBUSxJQUFJLFlBQWEsR0FHM0Isa0JBQWdDLENBQzlCLEtBQU0sR0FBUSIsCiAgIm5hbWVzIjogW10KfQo=\\\\n\\\",\\\"functionName\\\":\\\"showBackLinks\\\"},\\\"renamePage\\\":{\\\"path\\\":\\\"core/page.ts\\\",\\\"code\\\":\\\"(()=>{var r=Object.defineProperty;var w=Object.getOwnPropertyDescriptor;var k=Object.getOwnPropertyNames;var f=Object.prototype.hasOwnProperty;var m=a=>r(a,\\\\\\\"__esModule\\\\\\\",{value:!0});var x=(a,e)=>{for(var t in e)r(a,t,{get:e[t],enumerable:!0})},u=(a,e,t,o)=>{if(e&&typeof e==\\\\\\\"object\\\\\\\"||typeof e==\\\\\\\"function\\\\\\\")for(let i of k(e))!f.call(a,i)&&(t||i!==\\\\\\\"default\\\\\\\")&&r(a,i,{get:()=>e[i],enumerable:!(o=w(e,i))||o.enumerable});return a};var P=(a=>(e,t)=>a&&a.get(e)||(t=u(m({}),e,1),a&&a.set(e,t),t))(typeof WeakMap!=\\\\\\\"undefined\\\\\\\"?new WeakMap:0);var R={};x(R,{deletePage:()=>h,indexLinks:()=>L,reindex:()=>B,renamePage:()=>v,showBackLinks:()=>b});var p=/\\\\\\\\[\\\\\\\\[([\\\\\\\\w\\\\\\\\s\\\\\\\\/\\\\\\\\:,\\\\\\\\.\\\\\\\\-]+)\\\\\\\\]\\\\\\\\]/;function n(a,...e){let t=Math.floor(Math.random()*1e6);return new Promise((o,i)=>{self.dispatchEvent(new CustomEvent(\\\\\\\"syscall\\\\\\\",{detail:{id:t,name:a,args:e,callback:o}}))})}var y=new RegExp(p,\\\\\\\"g\\\\\\\");async function L({name:a,text:e}){let t=[];for(let o of e.matchAll(y)){let i=o[1],l=o.index;t.push({key:`pl:${i}:${l}`,value:a})}console.log(\\\\\\\"Found\\\\\\\",t.length,\\\\\\\"wiki link(s)\\\\\\\"),await n(\\\\\\\"indexer.batchSet\\\\\\\",a,t)}async function h(){let a=await n(\\\\\\\"editor.getCurrentPage\\\\\\\");console.log(\\\\\\\"Navigating to start page\\\\\\\"),await n(\\\\\\\"editor.navigate\\\\\\\",\\\\\\\"start\\\\\\\"),console.log(\\\\\\\"Deleting page from space\\\\\\\"),await n(\\\\\\\"space.deletePage\\\\\\\",a.name),console.log(\\\\\\\"Reloading page list\\\\\\\"),await n(\\\\\\\"space.reloadPageList\\\\\\\")}async function v(){let e=(await n(\\\\\\\"editor.getCurrentPage\\\\\\\")).name;console.log(\\\\\\\"Old name is\\\\\\\",e);let t=await n(\\\\\\\"editor.prompt\\\\\\\",`Rename ${e} to:`,e);if(!t)return;console.log(\\\\\\\"New name\\\\\\\",t);let o=await d(e);console.log(\\\\\\\"All pages containing backlinks\\\\\\\",o);let i=await n(\\\\\\\"editor.getText\\\\\\\");console.log(\\\\\\\"Writing new page to space\\\\\\\"),await n(\\\\\\\"space.writePage\\\\\\\",t,i),console.log(\\\\\\\"Deleting page from space\\\\\\\"),await n(\\\\\\\"space.deletePage\\\\\\\",e),console.log(\\\\\\\"Reloading page list\\\\\\\"),await n(\\\\\\\"space.reloadPageList\\\\\\\"),console.log(\\\\\\\"Navigating to new page\\\\\\\"),await n(\\\\\\\"editor.navigate\\\\\\\",t);let l=new Set;for(let s of o)l.add(s.page);for(let s of l){console.log(\\\\\\\"Now going to update links in\\\\\\\",s);let{text:g}=await n(\\\\\\\"space.readPage\\\\\\\",s);if(!g)continue;let c=g.replaceAll(`[[${e}]]`,`[[${t}]]`);g!==c&&(console.log(\\\\\\\"Changes made, saving...\\\\\\\"),await n(\\\\\\\"space.writePage\\\\\\\",s,c))}}async function d(a){let e=await n(\\\\\\\"indexer.scanPrefixGlobal\\\\\\\",`pl:${a}:`),t=[];for(let{key:o,value:i}of e){let l=o.split(\\\\\\\":\\\\\\\");t.push({page:i,pos:+l[l.length-1]})}return t}async function b(){let a=await n(\\\\\\\"editor.getCurrentPage\\\\\\\"),e=await d(a.name);console.log(\\\\\\\"Backlinks\\\\\\\",e)}async function B(){await n(\\\\\\\"space.reindex\\\\\\\")}return P(R);})();\\\\n//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiY29yZS9wYWdlLnRzIiwgIi4uL3dlYmFwcC9zcmMvY29uc3RhbnQudHMiLCAiY29yZS9saWIvc3lzY2FsbC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiaW1wb3J0IHsgSW5kZXhFdmVudCB9IGZyb20gXCIuLi8uLi93ZWJhcHAvc3JjL2FwcF9ldmVudFwiO1xuaW1wb3J0IHsgcGFnZUxpbmtSZWdleCB9IGZyb20gXCIuLi8uLi93ZWJhcHAvc3JjL2NvbnN0YW50XCI7XG5pbXBvcnQgeyBzeXNjYWxsIH0gZnJvbSBcIi4vbGliL3N5c2NhbGxcIjtcblxuY29uc3Qgd2lraWxpbmtSZWdleCA9IG5ldyBSZWdFeHAocGFnZUxpbmtSZWdleCwgXCJnXCIpO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gaW5kZXhMaW5rcyh7IG5hbWUsIHRleHQgfTogSW5kZXhFdmVudCkge1xuICBsZXQgYmFja0xpbmtzOiB7IGtleTogc3RyaW5nOyB2YWx1ZTogc3RyaW5nIH1bXSA9IFtdO1xuICBmb3IgKGxldCBtYXRjaCBvZiB0ZXh0Lm1hdGNoQWxsKHdpa2lsaW5rUmVnZXgpKSB7XG4gICAgbGV0IHRvUGFnZSA9IG1hdGNoWzFdO1xuICAgIGxldCBwb3MgPSBtYXRjaC5pbmRleCE7XG4gICAgYmFja0xpbmtzLnB1c2goe1xuICAgICAga2V5OiBgcGw6JHt0b1BhZ2V9OiR7cG9zfWAsXG4gICAgICB2YWx1ZTogbmFtZSxcbiAgICB9KTtcbiAgfVxuICBjb25zb2xlLmxvZyhcIkZvdW5kXCIsIGJhY2tMaW5rcy5sZW5ndGgsIFwid2lraSBsaW5rKHMpXCIpO1xuICBhd2FpdCBzeXNjYWxsKFwiaW5kZXhlci5iYXRjaFNldFwiLCBuYW1lLCBiYWNrTGlua3MpO1xufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZGVsZXRlUGFnZSgpIHtcbiAgbGV0IHBhZ2VNZXRhID0gYXdhaXQgc3lzY2FsbChcImVkaXRvci5nZXRDdXJyZW50UGFnZVwiKTtcbiAgY29uc29sZS5sb2coXCJOYXZpZ2F0aW5nIHRvIHN0YXJ0IHBhZ2VcIik7XG4gIGF3YWl0IHN5c2NhbGwoXCJlZGl0b3IubmF2aWdhdGVcIiwgXCJzdGFydFwiKTtcbiAgY29uc29sZS5sb2coXCJEZWxldGluZyBwYWdlIGZyb20gc3BhY2VcIik7XG4gIGF3YWl0IHN5c2NhbGwoXCJzcGFjZS5kZWxldGVQYWdlXCIsIHBhZ2VNZXRhLm5hbWUpO1xuICBjb25zb2xlLmxvZyhcIlJlbG9hZGluZyBwYWdlIGxpc3RcIik7XG4gIGF3YWl0IHN5c2NhbGwoXCJzcGFjZS5yZWxvYWRQYWdlTGlzdFwiKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHJlbmFtZVBhZ2UoKSB7XG4gIGNvbnN0IHBhZ2VNZXRhID0gYXdhaXQgc3lzY2FsbChcImVkaXRvci5nZXRDdXJyZW50UGFnZVwiKTtcbiAgY29uc3Qgb2xkTmFtZSA9IHBhZ2VNZXRhLm5hbWU7XG4gIGNvbnNvbGUubG9nKFwiT2xkIG5hbWUgaXNcIiwgb2xkTmFtZSk7XG4gIGNvbnN0IG5ld05hbWUgPSBhd2FpdCBzeXNjYWxsKFxuICAgIFwiZWRpdG9yLnByb21wdFwiLFxuICAgIGBSZW5hbWUgJHtvbGROYW1lfSB0bzpgLFxuICAgIG9sZE5hbWVcbiAgKTtcbiAgaWYgKCFuZXdOYW1lKSB7XG4gICAgcmV0dXJuO1xuICB9XG4gIGNvbnNvbGUubG9nKFwiTmV3IG5hbWVcIiwgbmV3TmFtZSk7XG5cbiAgbGV0IHBhZ2VzVG9VcGRhdGUgPSBhd2FpdCBnZXRCYWNrTGlua3Mob2xkTmFtZSk7XG4gIGNvbnNvbGUubG9nKFwiQWxsIHBhZ2VzIGNvbnRhaW5pbmcgYmFja2xpbmtzXCIsIHBhZ2VzVG9VcGRhdGUpO1xuXG4gIGxldCB0ZXh0ID0gYXdhaXQgc3lzY2FsbChcImVkaXRvci5nZXRUZXh0XCIpO1xuICBjb25zb2xlLmxvZyhcIldyaXRpbmcgbmV3IHBhZ2UgdG8gc3BhY2VcIik7XG4gIGF3YWl0IHN5c2NhbGwoXCJzcGFjZS53cml0ZVBhZ2VcIiwgbmV3TmFtZSwgdGV4dCk7XG4gIGNvbnNvbGUubG9nKFwiRGVsZXRpbmcgcGFnZSBmcm9tIHNwYWNlXCIpO1xuICBhd2FpdCBzeXNjYWxsKFwic3BhY2UuZGVsZXRlUGFnZVwiLCBvbGROYW1lKTtcbiAgY29uc29sZS5sb2coXCJSZWxvYWRpbmcgcGFnZSBsaXN0XCIpO1xuICBhd2FpdCBzeXNjYWxsKFwic3BhY2UucmVsb2FkUGFnZUxpc3RcIik7XG4gIGNvbnNvbGUubG9nKFwiTmF2aWdhdGluZyB0byBuZXcgcGFnZVwiKTtcbiAgYXdhaXQgc3lzY2FsbChcImVkaXRvci5uYXZpZ2F0ZVwiLCBuZXdOYW1lKTtcblxuICBsZXQgcGFnZVRvVXBkYXRlU2V0ID0gbmV3IFNldDxzdHJpbmc+KCk7XG4gIGZvciAobGV0IHBhZ2VUb1VwZGF0ZSBvZiBwYWdlc1RvVXBkYXRlKSB7XG4gICAgcGFnZVRvVXBkYXRlU2V0LmFkZChwYWdlVG9VcGRhdGUucGFnZSk7XG4gIH1cblxuICBmb3IgKGxldCBwYWdlVG9VcGRhdGUgb2YgcGFnZVRvVXBkYXRlU2V0KSB7XG4gICAgY29uc29sZS5sb2coXCJOb3cgZ29pbmcgdG8gdXBkYXRlIGxpbmtzIGluXCIsIHBhZ2VUb1VwZGF0ZSk7XG4gICAgbGV0IHsgdGV4dCB9ID0gYXdhaXQgc3lzY2FsbChcInNwYWNlLnJlYWRQYWdlXCIsIHBhZ2VUb1VwZGF0ZSk7XG4gICAgaWYgKCF0ZXh0KSB7XG4gICAgICAvLyBQYWdlIGxpa2VseSBkb2VzIG5vdCBleGlzdCwgYnV0IGF0IGxlYXN0IHdlIGNhbiBza2lwIGl0XG4gICAgICBjb250aW51ZTtcbiAgICB9XG4gICAgbGV0IG5ld1RleHQgPSB0ZXh0LnJlcGxhY2VBbGwoYFtbJHtvbGROYW1lfV1dYCwgYFtbJHtuZXdOYW1lfV1dYCk7XG4gICAgaWYgKHRleHQgIT09IG5ld1RleHQpIHtcbiAgICAgIGNvbnNvbGUubG9nKFwiQ2hhbmdlcyBtYWRlLCBzYXZpbmcuLi5cIik7XG4gICAgICBhd2FpdCBzeXNjYWxsKFwic3BhY2Uud3JpdGVQYWdlXCIsIHBhZ2VUb1VwZGF0ZSwgbmV3VGV4dCk7XG4gICAgfVxuICB9XG59XG5cbnR5cGUgQmFja0xpbmsgPSB7XG4gIHBhZ2U6IHN0cmluZztcbiAgcG9zOiBudW1iZXI7XG59O1xuXG5hc3luYyBmdW5jdGlvbiBnZXRCYWNrTGlua3MocGFnZU5hbWU6IHN0cmluZyk6IFByb21pc2U8QmFja0xpbmtbXT4ge1xuICBsZXQgYWxsQmFja0xpbmtzID0gYXdhaXQgc3lzY2FsbChcbiAgICBcImluZGV4ZXIuc2NhblByZWZpeEdsb2JhbFwiLFxuICAgIGBwbDoke3BhZ2VOYW1lfTpgXG4gICk7XG4gIGxldCBwYWdlc1RvVXBkYXRlOiBCYWNrTGlua1tdID0gW107XG4gIGZvciAobGV0IHsga2V5LCB2YWx1ZSB9IG9mIGFsbEJhY2tMaW5rcykge1xuICAgIGxldCBrZXlQYXJ0cyA9IGtleS5zcGxpdChcIjpcIik7XG4gICAgcGFnZXNUb1VwZGF0ZS5wdXNoKHtcbiAgICAgIHBhZ2U6IHZhbHVlLFxuICAgICAgcG9zOiAra2V5UGFydHNba2V5UGFydHMubGVuZ3RoIC0gMV0sXG4gICAgfSk7XG4gIH1cbiAgcmV0dXJuIHBhZ2VzVG9VcGRhdGU7XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBzaG93QmFja0xpbmtzKCkge1xuICBjb25zdCBwYWdlTWV0YSA9IGF3YWl0IHN5c2NhbGwoXCJlZGl0b3IuZ2V0Q3VycmVudFBhZ2VcIik7XG4gIGxldCBiYWNrTGlua3MgPSBhd2FpdCBnZXRCYWNrTGlua3MocGFnZU1ldGEubmFtZSk7XG5cbiAgY29uc29sZS5sb2coXCJCYWNrbGlua3NcIiwgYmFja0xpbmtzKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHJlaW5kZXgoKSB7XG4gIGF3YWl0IHN5c2NhbGwoXCJzcGFjZS5yZWluZGV4XCIpO1xufVxuIiwgImV4cG9ydCBjb25zdCBwYWdlTGlua1JlZ2V4ID0gL1xcW1xcWyhbXFx3XFxzXFwvXFw6LFxcLlxcLV0rKVxcXVxcXS87XG4iLCAiZXhwb3J0IGZ1bmN0aW9uIHN5c2NhbGwobmFtZTogc3RyaW5nLCAuLi5hcmdzOiBhbnlbXSk6IGFueSB7XG4gIGxldCByZXFJZCA9IE1hdGguZmxvb3IoTWF0aC5yYW5kb20oKSAqIDEwMDAwMDApO1xuICAvLyBjb25zb2xlLmxvZyhcIlN5c2NhbGxcIiwgbmFtZSwgcmVxSWQpO1xuICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIHNlbGYuZGlzcGF0Y2hFdmVudChcbiAgICAgIG5ldyBDdXN0b21FdmVudChcInN5c2NhbGxcIiwge1xuICAgICAgICBkZXRhaWw6IHtcbiAgICAgICAgICBpZDogcmVxSWQsXG4gICAgICAgICAgbmFtZTogbmFtZSxcbiAgICAgICAgICBhcmdzOiBhcmdzLFxuICAgICAgICAgIGNhbGxiYWNrOiByZXNvbHZlLFxuICAgICAgICB9LFxuICAgICAgfSlcbiAgICApO1xuICB9KTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI0aEJBQUEscUdDQU8sR0FBTSxHQUFnQiw2QkNBdEIsV0FBaUIsS0FBaUIsRUFBa0IsQ0FDekQsR0FBSSxHQUFRLEtBQUssTUFBTSxLQUFLLFNBQVcsS0FFdkMsTUFBTyxJQUFJLFNBQVEsQ0FBQyxFQUFTLElBQVcsQ0FDdEMsS0FBSyxjQUNILEdBQUksYUFBWSxVQUFXLENBQ3pCLE9BQVEsQ0FDTixHQUFJLEVBQ0osS0FBTSxFQUNOLEtBQU0sRUFDTixTQUFVLFFGTnBCLEdBQU0sR0FBZ0IsR0FBSSxRQUFPLEVBQWUsS0FFaEQsaUJBQWlDLENBQUUsT0FBTSxRQUFvQixDQUMzRCxHQUFJLEdBQThDLEdBQ2xELE9BQVMsS0FBUyxHQUFLLFNBQVMsR0FBZ0IsQ0FDOUMsR0FBSSxHQUFTLEVBQU0sR0FDZixFQUFNLEVBQU0sTUFDaEIsRUFBVSxLQUFLLENBQ2IsSUFBSyxNQUFNLEtBQVUsSUFDckIsTUFBTyxJQUdYLFFBQVEsSUFBSSxRQUFTLEVBQVUsT0FBUSxnQkFDdkMsS0FBTSxHQUFRLG1CQUFvQixFQUFNLEdBRzFDLGtCQUFtQyxDQUNqQyxHQUFJLEdBQVcsS0FBTSxHQUFRLHlCQUM3QixRQUFRLElBQUksNEJBQ1osS0FBTSxHQUFRLGtCQUFtQixTQUNqQyxRQUFRLElBQUksNEJBQ1osS0FBTSxHQUFRLG1CQUFvQixFQUFTLE1BQzNDLFFBQVEsSUFBSSx1QkFDWixLQUFNLEdBQVEsd0JBR2hCLGtCQUFtQyxDQUVqQyxHQUFNLEdBQVUsQUFEQyxNQUFNLEdBQVEsMEJBQ04sS0FDekIsUUFBUSxJQUFJLGNBQWUsR0FDM0IsR0FBTSxHQUFVLEtBQU0sR0FDcEIsZ0JBQ0EsVUFBVSxRQUNWLEdBRUYsR0FBSSxDQUFDLEVBQ0gsT0FFRixRQUFRLElBQUksV0FBWSxHQUV4QixHQUFJLEdBQWdCLEtBQU0sR0FBYSxHQUN2QyxRQUFRLElBQUksaUNBQWtDLEdBRTlDLEdBQUksR0FBTyxLQUFNLEdBQVEsa0JBQ3pCLFFBQVEsSUFBSSw2QkFDWixLQUFNLEdBQVEsa0JBQW1CLEVBQVMsR0FDMUMsUUFBUSxJQUFJLDRCQUNaLEtBQU0sR0FBUSxtQkFBb0IsR0FDbEMsUUFBUSxJQUFJLHVCQUNaLEtBQU0sR0FBUSx3QkFDZCxRQUFRLElBQUksMEJBQ1osS0FBTSxHQUFRLGtCQUFtQixHQUVqQyxHQUFJLEdBQWtCLEdBQUksS0FDMUIsT0FBUyxLQUFnQixHQUN2QixFQUFnQixJQUFJLEVBQWEsTUFHbkMsT0FBUyxLQUFnQixHQUFpQixDQUN4QyxRQUFRLElBQUksK0JBQWdDLEdBQzVDLEdBQUksQ0FBRSxRQUFTLEtBQU0sR0FBUSxpQkFBa0IsR0FDL0MsR0FBSSxDQUFDLEVBRUgsU0FFRixHQUFJLEdBQVUsRUFBSyxXQUFXLEtBQUssTUFBYSxLQUFLLE9BQ3JELEFBQUksSUFBUyxHQUNYLFNBQVEsSUFBSSwyQkFDWixLQUFNLEdBQVEsa0JBQW1CLEVBQWMsS0FVckQsaUJBQTRCLEVBQXVDLENBQ2pFLEdBQUksR0FBZSxLQUFNLEdBQ3ZCLDJCQUNBLE1BQU0sTUFFSixFQUE0QixHQUNoQyxPQUFTLENBQUUsTUFBSyxVQUFXLEdBQWMsQ0FDdkMsR0FBSSxHQUFXLEVBQUksTUFBTSxLQUN6QixFQUFjLEtBQUssQ0FDakIsS0FBTSxFQUNOLElBQUssQ0FBQyxFQUFTLEVBQVMsT0FBUyxLQUdyQyxNQUFPLEdBR1Qsa0JBQXNDLENBQ3BDLEdBQU0sR0FBVyxLQUFNLEdBQVEseUJBQzNCLEVBQVksS0FBTSxHQUFhLEVBQVMsTUFFNUMsUUFBUSxJQUFJLFlBQWEsR0FHM0Isa0JBQWdDLENBQzlCLEtBQU0sR0FBUSIsCiAgIm5hbWVzIjogW10KfQo=\\\\n\\\",\\\"functionName\\\":\\\"renamePage\\\"},\\\"reindexPages\\\":{\\\"path\\\":\\\"core/page.ts\\\",\\\"code\\\":\\\"(()=>{var r=Object.defineProperty;var w=Object.getOwnPropertyDescriptor;var k=Object.getOwnPropertyNames;var f=Object.prototype.hasOwnProperty;var m=a=>r(a,\\\\\\\"__esModule\\\\\\\",{value:!0});var x=(a,e)=>{for(var t in e)r(a,t,{get:e[t],enumerable:!0})},u=(a,e,t,o)=>{if(e&&typeof e==\\\\\\\"object\\\\\\\"||typeof e==\\\\\\\"function\\\\\\\")for(let i of k(e))!f.call(a,i)&&(t||i!==\\\\\\\"default\\\\\\\")&&r(a,i,{get:()=>e[i],enumerable:!(o=w(e,i))||o.enumerable});return a};var P=(a=>(e,t)=>a&&a.get(e)||(t=u(m({}),e,1),a&&a.set(e,t),t))(typeof WeakMap!=\\\\\\\"undefined\\\\\\\"?new WeakMap:0);var R={};x(R,{deletePage:()=>h,indexLinks:()=>L,reindex:()=>B,renamePage:()=>v,showBackLinks:()=>b});var p=/\\\\\\\\[\\\\\\\\[([\\\\\\\\w\\\\\\\\s\\\\\\\\/\\\\\\\\:,\\\\\\\\.\\\\\\\\-]+)\\\\\\\\]\\\\\\\\]/;function n(a,...e){let t=Math.floor(Math.random()*1e6);return new Promise((o,i)=>{self.dispatchEvent(new CustomEvent(\\\\\\\"syscall\\\\\\\",{detail:{id:t,name:a,args:e,callback:o}}))})}var y=new RegExp(p,\\\\\\\"g\\\\\\\");async function L({name:a,text:e}){let t=[];for(let o of e.matchAll(y)){let i=o[1],l=o.index;t.push({key:`pl:${i}:${l}`,value:a})}console.log(\\\\\\\"Found\\\\\\\",t.length,\\\\\\\"wiki link(s)\\\\\\\"),await n(\\\\\\\"indexer.batchSet\\\\\\\",a,t)}async function h(){let a=await n(\\\\\\\"editor.getCurrentPage\\\\\\\");console.log(\\\\\\\"Navigating to start page\\\\\\\"),await n(\\\\\\\"editor.navigate\\\\\\\",\\\\\\\"start\\\\\\\"),console.log(\\\\\\\"Deleting page from space\\\\\\\"),await n(\\\\\\\"space.deletePage\\\\\\\",a.name),console.log(\\\\\\\"Reloading page list\\\\\\\"),await n(\\\\\\\"space.reloadPageList\\\\\\\")}async function v(){let e=(await n(\\\\\\\"editor.getCurrentPage\\\\\\\")).name;console.log(\\\\\\\"Old name is\\\\\\\",e);let t=await n(\\\\\\\"editor.prompt\\\\\\\",`Rename ${e} to:`,e);if(!t)return;console.log(\\\\\\\"New name\\\\\\\",t);let o=await d(e);console.log(\\\\\\\"All pages containing backlinks\\\\\\\",o);let i=await n(\\\\\\\"editor.getText\\\\\\\");console.log(\\\\\\\"Writing new page to space\\\\\\\"),await n(\\\\\\\"space.writePage\\\\\\\",t,i),console.log(\\\\\\\"Deleting page from space\\\\\\\"),await n(\\\\\\\"space.deletePage\\\\\\\",e),console.log(\\\\\\\"Reloading page list\\\\\\\"),await n(\\\\\\\"space.reloadPageList\\\\\\\"),console.log(\\\\\\\"Navigating to new page\\\\\\\"),await n(\\\\\\\"editor.navigate\\\\\\\",t);let l=new Set;for(let s of o)l.add(s.page);for(let s of l){console.log(\\\\\\\"Now going to update links in\\\\\\\",s);let{text:g}=await n(\\\\\\\"space.readPage\\\\\\\",s);if(!g)continue;let c=g.replaceAll(`[[${e}]]`,`[[${t}]]`);g!==c&&(console.log(\\\\\\\"Changes made, saving...\\\\\\\"),await n(\\\\\\\"space.writePage\\\\\\\",s,c))}}async function d(a){let e=await n(\\\\\\\"indexer.scanPrefixGlobal\\\\\\\",`pl:${a}:`),t=[];for(let{key:o,value:i}of e){let l=o.split(\\\\\\\":\\\\\\\");t.push({page:i,pos:+l[l.length-1]})}return t}async function b(){let a=await n(\\\\\\\"editor.getCurrentPage\\\\\\\"),e=await d(a.name);console.log(\\\\\\\"Backlinks\\\\\\\",e)}async function B(){await n(\\\\\\\"space.reindex\\\\\\\")}return P(R);})();\\\\n//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiY29yZS9wYWdlLnRzIiwgIi4uL3dlYmFwcC9zcmMvY29uc3RhbnQudHMiLCAiY29yZS9saWIvc3lzY2FsbC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiaW1wb3J0IHsgSW5kZXhFdmVudCB9IGZyb20gXCIuLi8uLi93ZWJhcHAvc3JjL2FwcF9ldmVudFwiO1xuaW1wb3J0IHsgcGFnZUxpbmtSZWdleCB9IGZyb20gXCIuLi8uLi93ZWJhcHAvc3JjL2NvbnN0YW50XCI7XG5pbXBvcnQgeyBzeXNjYWxsIH0gZnJvbSBcIi4vbGliL3N5c2NhbGxcIjtcblxuY29uc3Qgd2lraWxpbmtSZWdleCA9IG5ldyBSZWdFeHAocGFnZUxpbmtSZWdleCwgXCJnXCIpO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gaW5kZXhMaW5rcyh7IG5hbWUsIHRleHQgfTogSW5kZXhFdmVudCkge1xuICBsZXQgYmFja0xpbmtzOiB7IGtleTogc3RyaW5nOyB2YWx1ZTogc3RyaW5nIH1bXSA9IFtdO1xuICBmb3IgKGxldCBtYXRjaCBvZiB0ZXh0Lm1hdGNoQWxsKHdpa2lsaW5rUmVnZXgpKSB7XG4gICAgbGV0IHRvUGFnZSA9IG1hdGNoWzFdO1xuICAgIGxldCBwb3MgPSBtYXRjaC5pbmRleCE7XG4gICAgYmFja0xpbmtzLnB1c2goe1xuICAgICAga2V5OiBgcGw6JHt0b1BhZ2V9OiR7cG9zfWAsXG4gICAgICB2YWx1ZTogbmFtZSxcbiAgICB9KTtcbiAgfVxuICBjb25zb2xlLmxvZyhcIkZvdW5kXCIsIGJhY2tMaW5rcy5sZW5ndGgsIFwid2lraSBsaW5rKHMpXCIpO1xuICBhd2FpdCBzeXNjYWxsKFwiaW5kZXhlci5iYXRjaFNldFwiLCBuYW1lLCBiYWNrTGlua3MpO1xufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZGVsZXRlUGFnZSgpIHtcbiAgbGV0IHBhZ2VNZXRhID0gYXdhaXQgc3lzY2FsbChcImVkaXRvci5nZXRDdXJyZW50UGFnZVwiKTtcbiAgY29uc29sZS5sb2coXCJOYXZpZ2F0aW5nIHRvIHN0YXJ0IHBhZ2VcIik7XG4gIGF3YWl0IHN5c2NhbGwoXCJlZGl0b3IubmF2aWdhdGVcIiwgXCJzdGFydFwiKTtcbiAgY29uc29sZS5sb2coXCJEZWxldGluZyBwYWdlIGZyb20gc3BhY2VcIik7XG4gIGF3YWl0IHN5c2NhbGwoXCJzcGFjZS5kZWxldGVQYWdlXCIsIHBhZ2VNZXRhLm5hbWUpO1xuICBjb25zb2xlLmxvZyhcIlJlbG9hZGluZyBwYWdlIGxpc3RcIik7XG4gIGF3YWl0IHN5c2NhbGwoXCJzcGFjZS5yZWxvYWRQYWdlTGlzdFwiKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHJlbmFtZVBhZ2UoKSB7XG4gIGNvbnN0IHBhZ2VNZXRhID0gYXdhaXQgc3lzY2FsbChcImVkaXRvci5nZXRDdXJyZW50UGFnZVwiKTtcbiAgY29uc3Qgb2xkTmFtZSA9IHBhZ2VNZXRhLm5hbWU7XG4gIGNvbnNvbGUubG9nKFwiT2xkIG5hbWUgaXNcIiwgb2xkTmFtZSk7XG4gIGNvbnN0IG5ld05hbWUgPSBhd2FpdCBzeXNjYWxsKFxuICAgIFwiZWRpdG9yLnByb21wdFwiLFxuICAgIGBSZW5hbWUgJHtvbGROYW1lfSB0bzpgLFxuICAgIG9sZE5hbWVcbiAgKTtcbiAgaWYgKCFuZXdOYW1lKSB7XG4gICAgcmV0dXJuO1xuICB9XG4gIGNvbnNvbGUubG9nKFwiTmV3IG5hbWVcIiwgbmV3TmFtZSk7XG5cbiAgbGV0IHBhZ2VzVG9VcGRhdGUgPSBhd2FpdCBnZXRCYWNrTGlua3Mob2xkTmFtZSk7XG4gIGNvbnNvbGUubG9nKFwiQWxsIHBhZ2VzIGNvbnRhaW5pbmcgYmFja2xpbmtzXCIsIHBhZ2VzVG9VcGRhdGUpO1xuXG4gIGxldCB0ZXh0ID0gYXdhaXQgc3lzY2FsbChcImVkaXRvci5nZXRUZXh0XCIpO1xuICBjb25zb2xlLmxvZyhcIldyaXRpbmcgbmV3IHBhZ2UgdG8gc3BhY2VcIik7XG4gIGF3YWl0IHN5c2NhbGwoXCJzcGFjZS53cml0ZVBhZ2VcIiwgbmV3TmFtZSwgdGV4dCk7XG4gIGNvbnNvbGUubG9nKFwiRGVsZXRpbmcgcGFnZSBmcm9tIHNwYWNlXCIpO1xuICBhd2FpdCBzeXNjYWxsKFwic3BhY2UuZGVsZXRlUGFnZVwiLCBvbGROYW1lKTtcbiAgY29uc29sZS5sb2coXCJSZWxvYWRpbmcgcGFnZSBsaXN0XCIpO1xuICBhd2FpdCBzeXNjYWxsKFwic3BhY2UucmVsb2FkUGFnZUxpc3RcIik7XG4gIGNvbnNvbGUubG9nKFwiTmF2aWdhdGluZyB0byBuZXcgcGFnZVwiKTtcbiAgYXdhaXQgc3lzY2FsbChcImVkaXRvci5uYXZpZ2F0ZVwiLCBuZXdOYW1lKTtcblxuICBsZXQgcGFnZVRvVXBkYXRlU2V0ID0gbmV3IFNldDxzdHJpbmc+KCk7XG4gIGZvciAobGV0IHBhZ2VUb1VwZGF0ZSBvZiBwYWdlc1RvVXBkYXRlKSB7XG4gICAgcGFnZVRvVXBkYXRlU2V0LmFkZChwYWdlVG9VcGRhdGUucGFnZSk7XG4gIH1cblxuICBmb3IgKGxldCBwYWdlVG9VcGRhdGUgb2YgcGFnZVRvVXBkYXRlU2V0KSB7XG4gICAgY29uc29sZS5sb2coXCJOb3cgZ29pbmcgdG8gdXBkYXRlIGxpbmtzIGluXCIsIHBhZ2VUb1VwZGF0ZSk7XG4gICAgbGV0IHsgdGV4dCB9ID0gYXdhaXQgc3lzY2FsbChcInNwYWNlLnJlYWRQYWdlXCIsIHBhZ2VUb1VwZGF0ZSk7XG4gICAgaWYgKCF0ZXh0KSB7XG4gICAgICAvLyBQYWdlIGxpa2VseSBkb2VzIG5vdCBleGlzdCwgYnV0IGF0IGxlYXN0IHdlIGNhbiBza2lwIGl0XG4gICAgICBjb250aW51ZTtcbiAgICB9XG4gICAgbGV0IG5ld1RleHQgPSB0ZXh0LnJlcGxhY2VBbGwoYFtbJHtvbGROYW1lfV1dYCwgYFtbJHtuZXdOYW1lfV1dYCk7XG4gICAgaWYgKHRleHQgIT09IG5ld1RleHQpIHtcbiAgICAgIGNvbnNvbGUubG9nKFwiQ2hhbmdlcyBtYWRlLCBzYXZpbmcuLi5cIik7XG4gICAgICBhd2FpdCBzeXNjYWxsKFwic3BhY2Uud3JpdGVQYWdlXCIsIHBhZ2VUb1VwZGF0ZSwgbmV3VGV4dCk7XG4gICAgfVxuICB9XG59XG5cbnR5cGUgQmFja0xpbmsgPSB7XG4gIHBhZ2U6IHN0cmluZztcbiAgcG9zOiBudW1iZXI7XG59O1xuXG5hc3luYyBmdW5jdGlvbiBnZXRCYWNrTGlua3MocGFnZU5hbWU6IHN0cmluZyk6IFByb21pc2U8QmFja0xpbmtbXT4ge1xuICBsZXQgYWxsQmFja0xpbmtzID0gYXdhaXQgc3lzY2FsbChcbiAgICBcImluZGV4ZXIuc2NhblByZWZpeEdsb2JhbFwiLFxuICAgIGBwbDoke3BhZ2VOYW1lfTpgXG4gICk7XG4gIGxldCBwYWdlc1RvVXBkYXRlOiBCYWNrTGlua1tdID0gW107XG4gIGZvciAobGV0IHsga2V5LCB2YWx1ZSB9IG9mIGFsbEJhY2tMaW5rcykge1xuICAgIGxldCBrZXlQYXJ0cyA9IGtleS5zcGxpdChcIjpcIik7XG4gICAgcGFnZXNUb1VwZGF0ZS5wdXNoKHtcbiAgICAgIHBhZ2U6IHZhbHVlLFxuICAgICAgcG9zOiAra2V5UGFydHNba2V5UGFydHMubGVuZ3RoIC0gMV0sXG4gICAgfSk7XG4gIH1cbiAgcmV0dXJuIHBhZ2VzVG9VcGRhdGU7XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBzaG93QmFja0xpbmtzKCkge1xuICBjb25zdCBwYWdlTWV0YSA9IGF3YWl0IHN5c2NhbGwoXCJlZGl0b3IuZ2V0Q3VycmVudFBhZ2VcIik7XG4gIGxldCBiYWNrTGlua3MgPSBhd2FpdCBnZXRCYWNrTGlua3MocGFnZU1ldGEubmFtZSk7XG5cbiAgY29uc29sZS5sb2coXCJCYWNrbGlua3NcIiwgYmFja0xpbmtzKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHJlaW5kZXgoKSB7XG4gIGF3YWl0IHN5c2NhbGwoXCJzcGFjZS5yZWluZGV4XCIpO1xufVxuIiwgImV4cG9ydCBjb25zdCBwYWdlTGlua1JlZ2V4ID0gL1xcW1xcWyhbXFx3XFxzXFwvXFw6LFxcLlxcLV0rKVxcXVxcXS87XG4iLCAiZXhwb3J0IGZ1bmN0aW9uIHN5c2NhbGwobmFtZTogc3RyaW5nLCAuLi5hcmdzOiBhbnlbXSk6IGFueSB7XG4gIGxldCByZXFJZCA9IE1hdGguZmxvb3IoTWF0aC5yYW5kb20oKSAqIDEwMDAwMDApO1xuICAvLyBjb25zb2xlLmxvZyhcIlN5c2NhbGxcIiwgbmFtZSwgcmVxSWQpO1xuICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIHNlbGYuZGlzcGF0Y2hFdmVudChcbiAgICAgIG5ldyBDdXN0b21FdmVudChcInN5c2NhbGxcIiwge1xuICAgICAgICBkZXRhaWw6IHtcbiAgICAgICAgICBpZDogcmVxSWQsXG4gICAgICAgICAgbmFtZTogbmFtZSxcbiAgICAgICAgICBhcmdzOiBhcmdzLFxuICAgICAgICAgIGNhbGxiYWNrOiByZXNvbHZlLFxuICAgICAgICB9LFxuICAgICAgfSlcbiAgICApO1xuICB9KTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI0aEJBQUEscUdDQU8sR0FBTSxHQUFnQiw2QkNBdEIsV0FBaUIsS0FBaUIsRUFBa0IsQ0FDekQsR0FBSSxHQUFRLEtBQUssTUFBTSxLQUFLLFNBQVcsS0FFdkMsTUFBTyxJQUFJLFNBQVEsQ0FBQyxFQUFTLElBQVcsQ0FDdEMsS0FBSyxjQUNILEdBQUksYUFBWSxVQUFXLENBQ3pCLE9BQVEsQ0FDTixHQUFJLEVBQ0osS0FBTSxFQUNOLEtBQU0sRUFDTixTQUFVLFFGTnBCLEdBQU0sR0FBZ0IsR0FBSSxRQUFPLEVBQWUsS0FFaEQsaUJBQWlDLENBQUUsT0FBTSxRQUFvQixDQUMzRCxHQUFJLEdBQThDLEdBQ2xELE9BQVMsS0FBUyxHQUFLLFNBQVMsR0FBZ0IsQ0FDOUMsR0FBSSxHQUFTLEVBQU0sR0FDZixFQUFNLEVBQU0sTUFDaEIsRUFBVSxLQUFLLENBQ2IsSUFBSyxNQUFNLEtBQVUsSUFDckIsTUFBTyxJQUdYLFFBQVEsSUFBSSxRQUFTLEVBQVUsT0FBUSxnQkFDdkMsS0FBTSxHQUFRLG1CQUFvQixFQUFNLEdBRzFDLGtCQUFtQyxDQUNqQyxHQUFJLEdBQVcsS0FBTSxHQUFRLHlCQUM3QixRQUFRLElBQUksNEJBQ1osS0FBTSxHQUFRLGtCQUFtQixTQUNqQyxRQUFRLElBQUksNEJBQ1osS0FBTSxHQUFRLG1CQUFvQixFQUFTLE1BQzNDLFFBQVEsSUFBSSx1QkFDWixLQUFNLEdBQVEsd0JBR2hCLGtCQUFtQyxDQUVqQyxHQUFNLEdBQVUsQUFEQyxNQUFNLEdBQVEsMEJBQ04sS0FDekIsUUFBUSxJQUFJLGNBQWUsR0FDM0IsR0FBTSxHQUFVLEtBQU0sR0FDcEIsZ0JBQ0EsVUFBVSxRQUNWLEdBRUYsR0FBSSxDQUFDLEVBQ0gsT0FFRixRQUFRLElBQUksV0FBWSxHQUV4QixHQUFJLEdBQWdCLEtBQU0sR0FBYSxHQUN2QyxRQUFRLElBQUksaUNBQWtDLEdBRTlDLEdBQUksR0FBTyxLQUFNLEdBQVEsa0JBQ3pCLFFBQVEsSUFBSSw2QkFDWixLQUFNLEdBQVEsa0JBQW1CLEVBQVMsR0FDMUMsUUFBUSxJQUFJLDRCQUNaLEtBQU0sR0FBUSxtQkFBb0IsR0FDbEMsUUFBUSxJQUFJLHVCQUNaLEtBQU0sR0FBUSx3QkFDZCxRQUFRLElBQUksMEJBQ1osS0FBTSxHQUFRLGtCQUFtQixHQUVqQyxHQUFJLEdBQWtCLEdBQUksS0FDMUIsT0FBUyxLQUFnQixHQUN2QixFQUFnQixJQUFJLEVBQWEsTUFHbkMsT0FBUyxLQUFnQixHQUFpQixDQUN4QyxRQUFRLElBQUksK0JBQWdDLEdBQzVDLEdBQUksQ0FBRSxRQUFTLEtBQU0sR0FBUSxpQkFBa0IsR0FDL0MsR0FBSSxDQUFDLEVBRUgsU0FFRixHQUFJLEdBQVUsRUFBSyxXQUFXLEtBQUssTUFBYSxLQUFLLE9BQ3JELEFBQUksSUFBUyxHQUNYLFNBQVEsSUFBSSwyQkFDWixLQUFNLEdBQVEsa0JBQW1CLEVBQWMsS0FVckQsaUJBQTRCLEVBQXVDLENBQ2pFLEdBQUksR0FBZSxLQUFNLEdBQ3ZCLDJCQUNBLE1BQU0sTUFFSixFQUE0QixHQUNoQyxPQUFTLENBQUUsTUFBSyxVQUFXLEdBQWMsQ0FDdkMsR0FBSSxHQUFXLEVBQUksTUFBTSxLQUN6QixFQUFjLEtBQUssQ0FDakIsS0FBTSxFQUNOLElBQUssQ0FBQyxFQUFTLEVBQVMsT0FBUyxLQUdyQyxNQUFPLEdBR1Qsa0JBQXNDLENBQ3BDLEdBQU0sR0FBVyxLQUFNLEdBQVEseUJBQzNCLEVBQVksS0FBTSxHQUFhLEVBQVMsTUFFNUMsUUFBUSxJQUFJLFlBQWEsR0FHM0Isa0JBQWdDLENBQzlCLEtBQU0sR0FBUSIsCiAgIm5hbWVzIjogW10KfQo=\\\\n\\\",\\\"functionName\\\":\\\"reindex\\\"},\\\"pageComplete\\\":{\\\"path\\\":\\\"core/navigate.ts\\\",\\\"code\\\":\\\"(()=>{var o=Object.defineProperty;var c=Object.getOwnPropertyDescriptor;var s=Object.getOwnPropertyNames;var p=Object.prototype.hasOwnProperty;var m=e=>o(e,\\\\\\\"__esModule\\\\\\\",{value:!0});var f=(e,t)=>{for(var a in t)o(e,a,{get:t[a],enumerable:!0})},g=(e,t,a,r)=>{if(t&&typeof t==\\\\\\\"object\\\\\\\"||typeof t==\\\\\\\"function\\\\\\\")for(let n of s(t))!p.call(e,n)&&(a||n!==\\\\\\\"default\\\\\\\")&&o(e,n,{get:()=>t[n],enumerable:!(r=c(t,n))||r.enumerable});return e};var y=(e=>(t,a)=>e&&e.get(t)||(a=g(m({}),t,1),e&&e.set(t,a),a))(typeof WeakMap!=\\\\\\\"undefined\\\\\\\"?new WeakMap:0);var k={};f(k,{clickNavigate:()=>u,linkNavigate:()=>d,pageComplete:()=>w});function i(e,...t){let a=Math.floor(Math.random()*1e6);return new Promise((r,n)=>{self.dispatchEvent(new CustomEvent(\\\\\\\"syscall\\\\\\\",{detail:{id:a,name:e,args:t,callback:r}}))})}async function l(e){if(!!e)switch(console.log(\\\\\\\"Attempting to navigate based on syntax node\\\\\\\",e),e.name){case\\\\\\\"WikiLinkPage\\\\\\\":await i(\\\\\\\"editor.navigate\\\\\\\",e.text);break;case\\\\\\\"URL\\\\\\\":await i(\\\\\\\"editor.openUrl\\\\\\\",e.text);break;case\\\\\\\"Link\\\\\\\":let t=/\\\\\\\\[[^\\\\\\\\\\\\\\\\]+\\\\\\\\]\\\\\\\\(([^\\\\\\\\)]+)\\\\\\\\)/.exec(e.text);t&&await i(\\\\\\\"editor.openUrl\\\\\\\",t[1])}}async function d(){l(await i(\\\\\\\"editor.getSyntaxNodeUnderCursor\\\\\\\"))}async function u(e){if(e.ctrlKey||e.metaKey){let t=await i(\\\\\\\"editor.getSyntaxNodeAtPos\\\\\\\",e.pos);l(t)}}async function w(){let e=await i(\\\\\\\"editor.matchBefore\\\\\\\",\\\\\\\"\\\\\\\\\\\\\\\\[\\\\\\\\\\\\\\\\[[\\\\\\\\\\\\\\\\w\\\\\\\\\\\\\\\\s]*\\\\\\\");if(!e)return null;let t=await i(\\\\\\\"space.listPages\\\\\\\");return{from:e.from+2,options:t.map(a=>({label:a.name,type:\\\\\\\"page\\\\\\\"}))}}return y(k);})();\\\\n//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiY29yZS9uYXZpZ2F0ZS50cyIsICJjb3JlL2xpYi9zeXNjYWxsLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJpbXBvcnQgeyBDbGlja0V2ZW50IH0gZnJvbSBcIi4uLy4uL3dlYmFwcC9zcmMvYXBwX2V2ZW50XCI7XG5pbXBvcnQgeyBzeXNjYWxsIH0gZnJvbSBcIi4vbGliL3N5c2NhbGxcIjtcblxuYXN5bmMgZnVuY3Rpb24gbmF2aWdhdGUoc3ludGF4Tm9kZTogYW55KSB7XG4gIGlmICghc3ludGF4Tm9kZSkge1xuICAgIHJldHVybjtcbiAgfVxuICBjb25zb2xlLmxvZyhcIkF0dGVtcHRpbmcgdG8gbmF2aWdhdGUgYmFzZWQgb24gc3ludGF4IG5vZGVcIiwgc3ludGF4Tm9kZSk7XG4gIHN3aXRjaCAoc3ludGF4Tm9kZS5uYW1lKSB7XG4gICAgY2FzZSBcIldpa2lMaW5rUGFnZVwiOlxuICAgICAgYXdhaXQgc3lzY2FsbChcImVkaXRvci5uYXZpZ2F0ZVwiLCBzeW50YXhOb2RlLnRleHQpO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSBcIlVSTFwiOlxuICAgICAgYXdhaXQgc3lzY2FsbChcImVkaXRvci5vcGVuVXJsXCIsIHN5bnRheE5vZGUudGV4dCk7XG4gICAgICBicmVhaztcbiAgICBjYXNlIFwiTGlua1wiOlxuICAgICAgLy8gTWFya2Rvd24gbGluazogW2JsYV0oVVJMSEVSRSkgbmVlZHMgZXh0cmFjdGlvblxuICAgICAgbGV0IG1hdGNoID0gL1xcW1teXFxcXF0rXFxdXFwoKFteXFwpXSspXFwpLy5leGVjKHN5bnRheE5vZGUudGV4dCk7XG4gICAgICBpZiAobWF0Y2gpIHtcbiAgICAgICAgYXdhaXQgc3lzY2FsbChcImVkaXRvci5vcGVuVXJsXCIsIG1hdGNoWzFdKTtcbiAgICAgIH1cbiAgfVxufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gbGlua05hdmlnYXRlKCkge1xuICBuYXZpZ2F0ZShhd2FpdCBzeXNjYWxsKFwiZWRpdG9yLmdldFN5bnRheE5vZGVVbmRlckN1cnNvclwiKSk7XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBjbGlja05hdmlnYXRlKGV2ZW50OiBDbGlja0V2ZW50KSB7XG4gIGlmIChldmVudC5jdHJsS2V5IHx8IGV2ZW50Lm1ldGFLZXkpIHtcbiAgICBsZXQgc3ludGF4Tm9kZSA9IGF3YWl0IHN5c2NhbGwoXCJlZGl0b3IuZ2V0U3ludGF4Tm9kZUF0UG9zXCIsIGV2ZW50LnBvcyk7XG4gICAgbmF2aWdhdGUoc3ludGF4Tm9kZSk7XG4gIH1cbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHBhZ2VDb21wbGV0ZSgpIHtcbiAgbGV0IHByZWZpeCA9IGF3YWl0IHN5c2NhbGwoXCJlZGl0b3IubWF0Y2hCZWZvcmVcIiwgXCJcXFxcW1xcXFxbW1xcXFx3XFxcXHNdKlwiKTtcbiAgaWYgKCFwcmVmaXgpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuICBsZXQgYWxsUGFnZXMgPSBhd2FpdCBzeXNjYWxsKFwic3BhY2UubGlzdFBhZ2VzXCIpO1xuICByZXR1cm4ge1xuICAgIGZyb206IHByZWZpeC5mcm9tICsgMixcbiAgICBvcHRpb25zOiBhbGxQYWdlcy5tYXAoKHBhZ2VNZXRhOiBhbnkpID0+ICh7XG4gICAgICBsYWJlbDogcGFnZU1ldGEubmFtZSxcbiAgICAgIHR5cGU6IFwicGFnZVwiLFxuICAgIH0pKSxcbiAgfTtcbn1cbiIsICJleHBvcnQgZnVuY3Rpb24gc3lzY2FsbChuYW1lOiBzdHJpbmcsIC4uLmFyZ3M6IGFueVtdKTogYW55IHtcbiAgbGV0IHJlcUlkID0gTWF0aC5mbG9vcihNYXRoLnJhbmRvbSgpICogMTAwMDAwMCk7XG4gIC8vIGNvbnNvbGUubG9nKFwiU3lzY2FsbFwiLCBuYW1lLCByZXFJZCk7XG4gIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgc2VsZi5kaXNwYXRjaEV2ZW50KFxuICAgICAgbmV3IEN1c3RvbUV2ZW50KFwic3lzY2FsbFwiLCB7XG4gICAgICAgIGRldGFpbDoge1xuICAgICAgICAgIGlkOiByZXFJZCxcbiAgICAgICAgICBuYW1lOiBuYW1lLFxuICAgICAgICAgIGFyZ3M6IGFyZ3MsXG4gICAgICAgICAgY2FsbGJhY2s6IHJlc29sdmUsXG4gICAgICAgIH0sXG4gICAgICB9KVxuICAgICk7XG4gIH0pO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjRoQkFBQSwwRUNBTyxXQUFpQixLQUFpQixFQUFrQixDQUN6RCxHQUFJLEdBQVEsS0FBSyxNQUFNLEtBQUssU0FBVyxLQUV2QyxNQUFPLElBQUksU0FBUSxDQUFDLEVBQVMsSUFBVyxDQUN0QyxLQUFLLGNBQ0gsR0FBSSxhQUFZLFVBQVcsQ0FDekIsT0FBUSxDQUNOLEdBQUksRUFDSixLQUFNLEVBQ04sS0FBTSxFQUNOLFNBQVUsUURQcEIsaUJBQXdCLEVBQWlCLENBQ3ZDLEdBQUksRUFBQyxFQUlMLE9BREEsUUFBUSxJQUFJLDhDQUErQyxHQUNuRCxFQUFXLFVBQ1osZUFDSCxLQUFNLEdBQVEsa0JBQW1CLEVBQVcsTUFDNUMsVUFDRyxNQUNILEtBQU0sR0FBUSxpQkFBa0IsRUFBVyxNQUMzQyxVQUNHLE9BRUgsR0FBSSxHQUFRLHlCQUF5QixLQUFLLEVBQVcsTUFDckQsQUFBSSxHQUNGLEtBQU0sR0FBUSxpQkFBa0IsRUFBTSxLQUs5QyxrQkFBcUMsQ0FDbkMsRUFBUyxLQUFNLEdBQVEsb0NBR3pCLGlCQUFvQyxFQUFtQixDQUNyRCxHQUFJLEVBQU0sU0FBVyxFQUFNLFFBQVMsQ0FDbEMsR0FBSSxHQUFhLEtBQU0sR0FBUSw0QkFBNkIsRUFBTSxLQUNsRSxFQUFTLElBSWIsa0JBQXFDLENBQ25DLEdBQUksR0FBUyxLQUFNLEdBQVEscUJBQXNCLG1CQUNqRCxHQUFJLENBQUMsRUFDSCxNQUFPLE1BRVQsR0FBSSxHQUFXLEtBQU0sR0FBUSxtQkFDN0IsTUFBTyxDQUNMLEtBQU0sRUFBTyxLQUFPLEVBQ3BCLFFBQVMsRUFBUyxJQUFJLEFBQUMsR0FBbUIsRUFDeEMsTUFBTyxFQUFTLEtBQ2hCLEtBQU0iLAogICJuYW1lcyI6IFtdCn0K\\\\n\\\",\\\"functionName\\\":\\\"pageComplete\\\"},\\\"linkNavigate\\\":{\\\"path\\\":\\\"core/navigate.ts\\\",\\\"code\\\":\\\"(()=>{var o=Object.defineProperty;var c=Object.getOwnPropertyDescriptor;var s=Object.getOwnPropertyNames;var p=Object.prototype.hasOwnProperty;var m=e=>o(e,\\\\\\\"__esModule\\\\\\\",{value:!0});var f=(e,t)=>{for(var a in t)o(e,a,{get:t[a],enumerable:!0})},g=(e,t,a,r)=>{if(t&&typeof t==\\\\\\\"object\\\\\\\"||typeof t==\\\\\\\"function\\\\\\\")for(let n of s(t))!p.call(e,n)&&(a||n!==\\\\\\\"default\\\\\\\")&&o(e,n,{get:()=>t[n],enumerable:!(r=c(t,n))||r.enumerable});return e};var y=(e=>(t,a)=>e&&e.get(t)||(a=g(m({}),t,1),e&&e.set(t,a),a))(typeof WeakMap!=\\\\\\\"undefined\\\\\\\"?new WeakMap:0);var k={};f(k,{clickNavigate:()=>u,linkNavigate:()=>d,pageComplete:()=>w});function i(e,...t){let a=Math.floor(Math.random()*1e6);return new Promise((r,n)=>{self.dispatchEvent(new CustomEvent(\\\\\\\"syscall\\\\\\\",{detail:{id:a,name:e,args:t,callback:r}}))})}async function l(e){if(!!e)switch(console.log(\\\\\\\"Attempting to navigate based on syntax node\\\\\\\",e),e.name){case\\\\\\\"WikiLinkPage\\\\\\\":await i(\\\\\\\"editor.navigate\\\\\\\",e.text);break;case\\\\\\\"URL\\\\\\\":await i(\\\\\\\"editor.openUrl\\\\\\\",e.text);break;case\\\\\\\"Link\\\\\\\":let t=/\\\\\\\\[[^\\\\\\\\\\\\\\\\]+\\\\\\\\]\\\\\\\\(([^\\\\\\\\)]+)\\\\\\\\)/.exec(e.text);t&&await i(\\\\\\\"editor.openUrl\\\\\\\",t[1])}}async function d(){l(await i(\\\\\\\"editor.getSyntaxNodeUnderCursor\\\\\\\"))}async function u(e){if(e.ctrlKey||e.metaKey){let t=await i(\\\\\\\"editor.getSyntaxNodeAtPos\\\\\\\",e.pos);l(t)}}async function w(){let e=await i(\\\\\\\"editor.matchBefore\\\\\\\",\\\\\\\"\\\\\\\\\\\\\\\\[\\\\\\\\\\\\\\\\[[\\\\\\\\\\\\\\\\w\\\\\\\\\\\\\\\\s]*\\\\\\\");if(!e)return null;let t=await i(\\\\\\\"space.listPages\\\\\\\");return{from:e.from+2,options:t.map(a=>({label:a.name,type:\\\\\\\"page\\\\\\\"}))}}return y(k);})();\\\\n//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiY29yZS9uYXZpZ2F0ZS50cyIsICJjb3JlL2xpYi9zeXNjYWxsLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJpbXBvcnQgeyBDbGlja0V2ZW50IH0gZnJvbSBcIi4uLy4uL3dlYmFwcC9zcmMvYXBwX2V2ZW50XCI7XG5pbXBvcnQgeyBzeXNjYWxsIH0gZnJvbSBcIi4vbGliL3N5c2NhbGxcIjtcblxuYXN5bmMgZnVuY3Rpb24gbmF2aWdhdGUoc3ludGF4Tm9kZTogYW55KSB7XG4gIGlmICghc3ludGF4Tm9kZSkge1xuICAgIHJldHVybjtcbiAgfVxuICBjb25zb2xlLmxvZyhcIkF0dGVtcHRpbmcgdG8gbmF2aWdhdGUgYmFzZWQgb24gc3ludGF4IG5vZGVcIiwgc3ludGF4Tm9kZSk7XG4gIHN3aXRjaCAoc3ludGF4Tm9kZS5uYW1lKSB7XG4gICAgY2FzZSBcIldpa2lMaW5rUGFnZVwiOlxuICAgICAgYXdhaXQgc3lzY2FsbChcImVkaXRvci5uYXZpZ2F0ZVwiLCBzeW50YXhOb2RlLnRleHQpO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSBcIlVSTFwiOlxuICAgICAgYXdhaXQgc3lzY2FsbChcImVkaXRvci5vcGVuVXJsXCIsIHN5bnRheE5vZGUudGV4dCk7XG4gICAgICBicmVhaztcbiAgICBjYXNlIFwiTGlua1wiOlxuICAgICAgLy8gTWFya2Rvd24gbGluazogW2JsYV0oVVJMSEVSRSkgbmVlZHMgZXh0cmFjdGlvblxuICAgICAgbGV0IG1hdGNoID0gL1xcW1teXFxcXF0rXFxdXFwoKFteXFwpXSspXFwpLy5leGVjKHN5bnRheE5vZGUudGV4dCk7XG4gICAgICBpZiAobWF0Y2gpIHtcbiAgICAgICAgYXdhaXQgc3lzY2FsbChcImVkaXRvci5vcGVuVXJsXCIsIG1hdGNoWzFdKTtcbiAgICAgIH1cbiAgfVxufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gbGlua05hdmlnYXRlKCkge1xuICBuYXZpZ2F0ZShhd2FpdCBzeXNjYWxsKFwiZWRpdG9yLmdldFN5bnRheE5vZGVVbmRlckN1cnNvclwiKSk7XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBjbGlja05hdmlnYXRlKGV2ZW50OiBDbGlja0V2ZW50KSB7XG4gIGlmIChldmVudC5jdHJsS2V5IHx8IGV2ZW50Lm1ldGFLZXkpIHtcbiAgICBsZXQgc3ludGF4Tm9kZSA9IGF3YWl0IHN5c2NhbGwoXCJlZGl0b3IuZ2V0U3ludGF4Tm9kZUF0UG9zXCIsIGV2ZW50LnBvcyk7XG4gICAgbmF2aWdhdGUoc3ludGF4Tm9kZSk7XG4gIH1cbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHBhZ2VDb21wbGV0ZSgpIHtcbiAgbGV0IHByZWZpeCA9IGF3YWl0IHN5c2NhbGwoXCJlZGl0b3IubWF0Y2hCZWZvcmVcIiwgXCJcXFxcW1xcXFxbW1xcXFx3XFxcXHNdKlwiKTtcbiAgaWYgKCFwcmVmaXgpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuICBsZXQgYWxsUGFnZXMgPSBhd2FpdCBzeXNjYWxsKFwic3BhY2UubGlzdFBhZ2VzXCIpO1xuICByZXR1cm4ge1xuICAgIGZyb206IHByZWZpeC5mcm9tICsgMixcbiAgICBvcHRpb25zOiBhbGxQYWdlcy5tYXAoKHBhZ2VNZXRhOiBhbnkpID0+ICh7XG4gICAgICBsYWJlbDogcGFnZU1ldGEubmFtZSxcbiAgICAgIHR5cGU6IFwicGFnZVwiLFxuICAgIH0pKSxcbiAgfTtcbn1cbiIsICJleHBvcnQgZnVuY3Rpb24gc3lzY2FsbChuYW1lOiBzdHJpbmcsIC4uLmFyZ3M6IGFueVtdKTogYW55IHtcbiAgbGV0IHJlcUlkID0gTWF0aC5mbG9vcihNYXRoLnJhbmRvbSgpICogMTAwMDAwMCk7XG4gIC8vIGNvbnNvbGUubG9nKFwiU3lzY2FsbFwiLCBuYW1lLCByZXFJZCk7XG4gIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgc2VsZi5kaXNwYXRjaEV2ZW50KFxuICAgICAgbmV3IEN1c3RvbUV2ZW50KFwic3lzY2FsbFwiLCB7XG4gICAgICAgIGRldGFpbDoge1xuICAgICAgICAgIGlkOiByZXFJZCxcbiAgICAgICAgICBuYW1lOiBuYW1lLFxuICAgICAgICAgIGFyZ3M6IGFyZ3MsXG4gICAgICAgICAgY2FsbGJhY2s6IHJlc29sdmUsXG4gICAgICAgIH0sXG4gICAgICB9KVxuICAgICk7XG4gIH0pO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjRoQkFBQSwwRUNBTyxXQUFpQixLQUFpQixFQUFrQixDQUN6RCxHQUFJLEdBQVEsS0FBSyxNQUFNLEtBQUssU0FBVyxLQUV2QyxNQUFPLElBQUksU0FBUSxDQUFDLEVBQVMsSUFBVyxDQUN0QyxLQUFLLGNBQ0gsR0FBSSxhQUFZLFVBQVcsQ0FDekIsT0FBUSxDQUNOLEdBQUksRUFDSixLQUFNLEVBQ04sS0FBTSxFQUNOLFNBQVUsUURQcEIsaUJBQXdCLEVBQWlCLENBQ3ZDLEdBQUksRUFBQyxFQUlMLE9BREEsUUFBUSxJQUFJLDhDQUErQyxHQUNuRCxFQUFXLFVBQ1osZUFDSCxLQUFNLEdBQVEsa0JBQW1CLEVBQVcsTUFDNUMsVUFDRyxNQUNILEtBQU0sR0FBUSxpQkFBa0IsRUFBVyxNQUMzQyxVQUNHLE9BRUgsR0FBSSxHQUFRLHlCQUF5QixLQUFLLEVBQVcsTUFDckQsQUFBSSxHQUNGLEtBQU0sR0FBUSxpQkFBa0IsRUFBTSxLQUs5QyxrQkFBcUMsQ0FDbkMsRUFBUyxLQUFNLEdBQVEsb0NBR3pCLGlCQUFvQyxFQUFtQixDQUNyRCxHQUFJLEVBQU0sU0FBVyxFQUFNLFFBQVMsQ0FDbEMsR0FBSSxHQUFhLEtBQU0sR0FBUSw0QkFBNkIsRUFBTSxLQUNsRSxFQUFTLElBSWIsa0JBQXFDLENBQ25DLEdBQUksR0FBUyxLQUFNLEdBQVEscUJBQXNCLG1CQUNqRCxHQUFJLENBQUMsRUFDSCxNQUFPLE1BRVQsR0FBSSxHQUFXLEtBQU0sR0FBUSxtQkFDN0IsTUFBTyxDQUNMLEtBQU0sRUFBTyxLQUFPLEVBQ3BCLFFBQVMsRUFBUyxJQUFJLEFBQUMsR0FBbUIsRUFDeEMsTUFBTyxFQUFTLEtBQ2hCLEtBQU0iLAogICJuYW1lcyI6IFtdCn0K\\\\n\\\",\\\"functionName\\\":\\\"linkNavigate\\\"},\\\"clickNavigate\\\":{\\\"path\\\":\\\"core/navigate.ts\\\",\\\"code\\\":\\\"(()=>{var o=Object.defineProperty;var c=Object.getOwnPropertyDescriptor;var s=Object.getOwnPropertyNames;var p=Object.prototype.hasOwnProperty;var m=e=>o(e,\\\\\\\"__esModule\\\\\\\",{value:!0});var f=(e,t)=>{for(var a in t)o(e,a,{get:t[a],enumerable:!0})},g=(e,t,a,r)=>{if(t&&typeof t==\\\\\\\"object\\\\\\\"||typeof t==\\\\\\\"function\\\\\\\")for(let n of s(t))!p.call(e,n)&&(a||n!==\\\\\\\"default\\\\\\\")&&o(e,n,{get:()=>t[n],enumerable:!(r=c(t,n))||r.enumerable});return e};var y=(e=>(t,a)=>e&&e.get(t)||(a=g(m({}),t,1),e&&e.set(t,a),a))(typeof WeakMap!=\\\\\\\"undefined\\\\\\\"?new WeakMap:0);var k={};f(k,{clickNavigate:()=>u,linkNavigate:()=>d,pageComplete:()=>w});function i(e,...t){let a=Math.floor(Math.random()*1e6);return new Promise((r,n)=>{self.dispatchEvent(new CustomEvent(\\\\\\\"syscall\\\\\\\",{detail:{id:a,name:e,args:t,callback:r}}))})}async function l(e){if(!!e)switch(console.log(\\\\\\\"Attempting to navigate based on syntax node\\\\\\\",e),e.name){case\\\\\\\"WikiLinkPage\\\\\\\":await i(\\\\\\\"editor.navigate\\\\\\\",e.text);break;case\\\\\\\"URL\\\\\\\":await i(\\\\\\\"editor.openUrl\\\\\\\",e.text);break;case\\\\\\\"Link\\\\\\\":let t=/\\\\\\\\[[^\\\\\\\\\\\\\\\\]+\\\\\\\\]\\\\\\\\(([^\\\\\\\\)]+)\\\\\\\\)/.exec(e.text);t&&await i(\\\\\\\"editor.openUrl\\\\\\\",t[1])}}async function d(){l(await i(\\\\\\\"editor.getSyntaxNodeUnderCursor\\\\\\\"))}async function u(e){if(e.ctrlKey||e.metaKey){let t=await i(\\\\\\\"editor.getSyntaxNodeAtPos\\\\\\\",e.pos);l(t)}}async function w(){let e=await i(\\\\\\\"editor.matchBefore\\\\\\\",\\\\\\\"\\\\\\\\\\\\\\\\[\\\\\\\\\\\\\\\\[[\\\\\\\\\\\\\\\\w\\\\\\\\\\\\\\\\s]*\\\\\\\");if(!e)return null;let t=await i(\\\\\\\"space.listPages\\\\\\\");return{from:e.from+2,options:t.map(a=>({label:a.name,type:\\\\\\\"page\\\\\\\"}))}}return y(k);})();\\\\n//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiY29yZS9uYXZpZ2F0ZS50cyIsICJjb3JlL2xpYi9zeXNjYWxsLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJpbXBvcnQgeyBDbGlja0V2ZW50IH0gZnJvbSBcIi4uLy4uL3dlYmFwcC9zcmMvYXBwX2V2ZW50XCI7XG5pbXBvcnQgeyBzeXNjYWxsIH0gZnJvbSBcIi4vbGliL3N5c2NhbGxcIjtcblxuYXN5bmMgZnVuY3Rpb24gbmF2aWdhdGUoc3ludGF4Tm9kZTogYW55KSB7XG4gIGlmICghc3ludGF4Tm9kZSkge1xuICAgIHJldHVybjtcbiAgfVxuICBjb25zb2xlLmxvZyhcIkF0dGVtcHRpbmcgdG8gbmF2aWdhdGUgYmFzZWQgb24gc3ludGF4IG5vZGVcIiwgc3ludGF4Tm9kZSk7XG4gIHN3aXRjaCAoc3ludGF4Tm9kZS5uYW1lKSB7XG4gICAgY2FzZSBcIldpa2lMaW5rUGFnZVwiOlxuICAgICAgYXdhaXQgc3lzY2FsbChcImVkaXRvci5uYXZpZ2F0ZVwiLCBzeW50YXhOb2RlLnRleHQpO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSBcIlVSTFwiOlxuICAgICAgYXdhaXQgc3lzY2FsbChcImVkaXRvci5vcGVuVXJsXCIsIHN5bnRheE5vZGUudGV4dCk7XG4gICAgICBicmVhaztcbiAgICBjYXNlIFwiTGlua1wiOlxuICAgICAgLy8gTWFya2Rvd24gbGluazogW2JsYV0oVVJMSEVSRSkgbmVlZHMgZXh0cmFjdGlvblxuICAgICAgbGV0IG1hdGNoID0gL1xcW1teXFxcXF0rXFxdXFwoKFteXFwpXSspXFwpLy5leGVjKHN5bnRheE5vZGUudGV4dCk7XG4gICAgICBpZiAobWF0Y2gpIHtcbiAgICAgICAgYXdhaXQgc3lzY2FsbChcImVkaXRvci5vcGVuVXJsXCIsIG1hdGNoWzFdKTtcbiAgICAgIH1cbiAgfVxufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gbGlua05hdmlnYXRlKCkge1xuICBuYXZpZ2F0ZShhd2FpdCBzeXNjYWxsKFwiZWRpdG9yLmdldFN5bnRheE5vZGVVbmRlckN1cnNvclwiKSk7XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBjbGlja05hdmlnYXRlKGV2ZW50OiBDbGlja0V2ZW50KSB7XG4gIGlmIChldmVudC5jdHJsS2V5IHx8IGV2ZW50Lm1ldGFLZXkpIHtcbiAgICBsZXQgc3ludGF4Tm9kZSA9IGF3YWl0IHN5c2NhbGwoXCJlZGl0b3IuZ2V0U3ludGF4Tm9kZUF0UG9zXCIsIGV2ZW50LnBvcyk7XG4gICAgbmF2aWdhdGUoc3ludGF4Tm9kZSk7XG4gIH1cbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHBhZ2VDb21wbGV0ZSgpIHtcbiAgbGV0IHByZWZpeCA9IGF3YWl0IHN5c2NhbGwoXCJlZGl0b3IubWF0Y2hCZWZvcmVcIiwgXCJcXFxcW1xcXFxbW1xcXFx3XFxcXHNdKlwiKTtcbiAgaWYgKCFwcmVmaXgpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuICBsZXQgYWxsUGFnZXMgPSBhd2FpdCBzeXNjYWxsKFwic3BhY2UubGlzdFBhZ2VzXCIpO1xuICByZXR1cm4ge1xuICAgIGZyb206IHByZWZpeC5mcm9tICsgMixcbiAgICBvcHRpb25zOiBhbGxQYWdlcy5tYXAoKHBhZ2VNZXRhOiBhbnkpID0+ICh7XG4gICAgICBsYWJlbDogcGFnZU1ldGEubmFtZSxcbiAgICAgIHR5cGU6IFwicGFnZVwiLFxuICAgIH0pKSxcbiAgfTtcbn1cbiIsICJleHBvcnQgZnVuY3Rpb24gc3lzY2FsbChuYW1lOiBzdHJpbmcsIC4uLmFyZ3M6IGFueVtdKTogYW55IHtcbiAgbGV0IHJlcUlkID0gTWF0aC5mbG9vcihNYXRoLnJhbmRvbSgpICogMTAwMDAwMCk7XG4gIC8vIGNvbnNvbGUubG9nKFwiU3lzY2FsbFwiLCBuYW1lLCByZXFJZCk7XG4gIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgc2VsZi5kaXNwYXRjaEV2ZW50KFxuICAgICAgbmV3IEN1c3RvbUV2ZW50KFwic3lzY2FsbFwiLCB7XG4gICAgICAgIGRldGFpbDoge1xuICAgICAgICAgIGlkOiByZXFJZCxcbiAgICAgICAgICBuYW1lOiBuYW1lLFxuICAgICAgICAgIGFyZ3M6IGFyZ3MsXG4gICAgICAgICAgY2FsbGJhY2s6IHJlc29sdmUsXG4gICAgICAgIH0sXG4gICAgICB9KVxuICAgICk7XG4gIH0pO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjRoQkFBQSwwRUNBTyxXQUFpQixLQUFpQixFQUFrQixDQUN6RCxHQUFJLEdBQVEsS0FBSyxNQUFNLEtBQUssU0FBVyxLQUV2QyxNQUFPLElBQUksU0FBUSxDQUFDLEVBQVMsSUFBVyxDQUN0QyxLQUFLLGNBQ0gsR0FBSSxhQUFZLFVBQVcsQ0FDekIsT0FBUSxDQUNOLEdBQUksRUFDSixLQUFNLEVBQ04sS0FBTSxFQUNOLFNBQVUsUURQcEIsaUJBQXdCLEVBQWlCLENBQ3ZDLEdBQUksRUFBQyxFQUlMLE9BREEsUUFBUSxJQUFJLDhDQUErQyxHQUNuRCxFQUFXLFVBQ1osZUFDSCxLQUFNLEdBQVEsa0JBQW1CLEVBQVcsTUFDNUMsVUFDRyxNQUNILEtBQU0sR0FBUSxpQkFBa0IsRUFBVyxNQUMzQyxVQUNHLE9BRUgsR0FBSSxHQUFRLHlCQUF5QixLQUFLLEVBQVcsTUFDckQsQUFBSSxHQUNGLEtBQU0sR0FBUSxpQkFBa0IsRUFBTSxLQUs5QyxrQkFBcUMsQ0FDbkMsRUFBUyxLQUFNLEdBQVEsb0NBR3pCLGlCQUFvQyxFQUFtQixDQUNyRCxHQUFJLEVBQU0sU0FBVyxFQUFNLFFBQVMsQ0FDbEMsR0FBSSxHQUFhLEtBQU0sR0FBUSw0QkFBNkIsRUFBTSxLQUNsRSxFQUFTLElBSWIsa0JBQXFDLENBQ25DLEdBQUksR0FBUyxLQUFNLEdBQVEscUJBQXNCLG1CQUNqRCxHQUFJLENBQUMsRUFDSCxNQUFPLE1BRVQsR0FBSSxHQUFXLEtBQU0sR0FBUSxtQkFDN0IsTUFBTyxDQUNMLEtBQU0sRUFBTyxLQUFPLEVBQ3BCLFFBQVMsRUFBUyxJQUFJLEFBQUMsR0FBbUIsRUFDeEMsTUFBTyxFQUFTLEtBQ2hCLEtBQU0iLAogICJuYW1lcyI6IFtdCn0K\\\\n\\\",\\\"functionName\\\":\\\"clickNavigate\\\"},\\\"taskToggle\\\":{\\\"path\\\":\\\"core/task.ts\\\",\\\"code\\\":\\\"(()=>{var n=Object.defineProperty;var i=Object.getOwnPropertyDescriptor;var c=Object.getOwnPropertyNames;var l=Object.prototype.hasOwnProperty;var m=e=>n(e,\\\\\\\"__esModule\\\\\\\",{value:!0});var d=(e,t)=>{for(var o in t)n(e,o,{get:t[o],enumerable:!0})},f=(e,t,o,s)=>{if(t&&typeof t==\\\\\\\"object\\\\\\\"||typeof t==\\\\\\\"function\\\\\\\")for(let a of c(t))!l.call(e,a)&&(o||a!==\\\\\\\"default\\\\\\\")&&n(e,a,{get:()=>t[a],enumerable:!(s=i(t,a))||s.enumerable});return e};var p=(e=>(t,o)=>e&&e.get(t)||(o=f(m({}),t,1),e&&e.set(t,o),o))(typeof WeakMap!=\\\\\\\"undefined\\\\\\\"?new WeakMap:0);var x={};d(x,{taskToggle:()=>h});function r(e,...t){let o=Math.floor(Math.random()*1e6);return new Promise((s,a)=>{self.dispatchEvent(new CustomEvent(\\\\\\\"syscall\\\\\\\",{detail:{id:o,name:e,args:t,callback:s}}))})}async function h(e){let t=await r(\\\\\\\"editor.getSyntaxNodeAtPos\\\\\\\",e.pos);t&&t.name===\\\\\\\"TaskMarker\\\\\\\"&&(t.text===\\\\\\\"[x]\\\\\\\"||t.text===\\\\\\\"[X]\\\\\\\"?await r(\\\\\\\"editor.dispatch\\\\\\\",{changes:{from:t.from,to:t.to,insert:\\\\\\\"[ ]\\\\\\\"},selection:{anchor:e.pos}}):await r(\\\\\\\"editor.dispatch\\\\\\\",{changes:{from:t.from,to:t.to,insert:\\\\\\\"[x]\\\\\\\"},selection:{anchor:e.pos}}))}return p(x);})();\\\\n//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiY29yZS90YXNrLnRzIiwgImNvcmUvbGliL3N5c2NhbGwudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB7IENsaWNrRXZlbnQgfSBmcm9tIFwiLi4vLi4vd2ViYXBwL3NyYy9hcHBfZXZlbnRcIjtcbmltcG9ydCB7IHN5c2NhbGwgfSBmcm9tIFwiLi9saWIvc3lzY2FsbFwiO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gdGFza1RvZ2dsZShldmVudDogQ2xpY2tFdmVudCkge1xuICBsZXQgc3ludGF4Tm9kZSA9IGF3YWl0IHN5c2NhbGwoXCJlZGl0b3IuZ2V0U3ludGF4Tm9kZUF0UG9zXCIsIGV2ZW50LnBvcyk7XG4gIGlmIChzeW50YXhOb2RlICYmIHN5bnRheE5vZGUubmFtZSA9PT0gXCJUYXNrTWFya2VyXCIpIHtcbiAgICBpZiAoc3ludGF4Tm9kZS50ZXh0ID09PSBcIlt4XVwiIHx8IHN5bnRheE5vZGUudGV4dCA9PT0gXCJbWF1cIikge1xuICAgICAgYXdhaXQgc3lzY2FsbChcImVkaXRvci5kaXNwYXRjaFwiLCB7XG4gICAgICAgIGNoYW5nZXM6IHtcbiAgICAgICAgICBmcm9tOiBzeW50YXhOb2RlLmZyb20sXG4gICAgICAgICAgdG86IHN5bnRheE5vZGUudG8sXG4gICAgICAgICAgaW5zZXJ0OiBcIlsgXVwiLFxuICAgICAgICB9LFxuICAgICAgICBzZWxlY3Rpb246IHtcbiAgICAgICAgICBhbmNob3I6IGV2ZW50LnBvcyxcbiAgICAgICAgfSxcbiAgICAgIH0pO1xuICAgIH0gZWxzZSB7XG4gICAgICBhd2FpdCBzeXNjYWxsKFwiZWRpdG9yLmRpc3BhdGNoXCIsIHtcbiAgICAgICAgY2hhbmdlczoge1xuICAgICAgICAgIGZyb206IHN5bnRheE5vZGUuZnJvbSxcbiAgICAgICAgICB0bzogc3ludGF4Tm9kZS50byxcbiAgICAgICAgICBpbnNlcnQ6IFwiW3hdXCIsXG4gICAgICAgIH0sXG4gICAgICAgIHNlbGVjdGlvbjoge1xuICAgICAgICAgIGFuY2hvcjogZXZlbnQucG9zLFxuICAgICAgICB9LFxuICAgICAgfSk7XG4gICAgfVxuICB9XG59XG4iLCAiZXhwb3J0IGZ1bmN0aW9uIHN5c2NhbGwobmFtZTogc3RyaW5nLCAuLi5hcmdzOiBhbnlbXSk6IGFueSB7XG4gIGxldCByZXFJZCA9IE1hdGguZmxvb3IoTWF0aC5yYW5kb20oKSAqIDEwMDAwMDApO1xuICAvLyBjb25zb2xlLmxvZyhcIlN5c2NhbGxcIiwgbmFtZSwgcmVxSWQpO1xuICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIHNlbGYuZGlzcGF0Y2hFdmVudChcbiAgICAgIG5ldyBDdXN0b21FdmVudChcInN5c2NhbGxcIiwge1xuICAgICAgICBkZXRhaWw6IHtcbiAgICAgICAgICBpZDogcmVxSWQsXG4gICAgICAgICAgbmFtZTogbmFtZSxcbiAgICAgICAgICBhcmdzOiBhcmdzLFxuICAgICAgICAgIGNhbGxiYWNrOiByZXNvbHZlLFxuICAgICAgICB9LFxuICAgICAgfSlcbiAgICApO1xuICB9KTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI0aEJBQUEsaUNDQU8sV0FBaUIsS0FBaUIsRUFBa0IsQ0FDekQsR0FBSSxHQUFRLEtBQUssTUFBTSxLQUFLLFNBQVcsS0FFdkMsTUFBTyxJQUFJLFNBQVEsQ0FBQyxFQUFTLElBQVcsQ0FDdEMsS0FBSyxjQUNILEdBQUksYUFBWSxVQUFXLENBQ3pCLE9BQVEsQ0FDTixHQUFJLEVBQ0osS0FBTSxFQUNOLEtBQU0sRUFDTixTQUFVLFFEUHBCLGlCQUFpQyxFQUFtQixDQUNsRCxHQUFJLEdBQWEsS0FBTSxHQUFRLDRCQUE2QixFQUFNLEtBQ2xFLEFBQUksR0FBYyxFQUFXLE9BQVMsY0FDcEMsQ0FBSSxFQUFXLE9BQVMsT0FBUyxFQUFXLE9BQVMsTUFDbkQsS0FBTSxHQUFRLGtCQUFtQixDQUMvQixRQUFTLENBQ1AsS0FBTSxFQUFXLEtBQ2pCLEdBQUksRUFBVyxHQUNmLE9BQVEsT0FFVixVQUFXLENBQ1QsT0FBUSxFQUFNLE9BSWxCLEtBQU0sR0FBUSxrQkFBbUIsQ0FDL0IsUUFBUyxDQUNQLEtBQU0sRUFBVyxLQUNqQixHQUFJLEVBQVcsR0FDZixPQUFRLE9BRVYsVUFBVyxDQUNULE9BQVEsRUFBTSIsCiAgIm5hbWVzIjogW10KfQo=\\\\n\\\",\\\"functionName\\\":\\\"taskToggle\\\"},\\\"insertToday\\\":{\\\"path\\\":\\\"core/dates.ts\\\",\\\"code\\\":\\\"(()=>{var s=Object.defineProperty;var i=Object.getOwnPropertyDescriptor;var l=Object.getOwnPropertyNames;var c=Object.prototype.hasOwnProperty;var d=t=>s(t,\\\\\\\"__esModule\\\\\\\",{value:!0});var y=(t,e)=>{for(var n in e)s(t,n,{get:e[n],enumerable:!0})},m=(t,e,n,r)=>{if(e&&typeof e==\\\\\\\"object\\\\\\\"||typeof e==\\\\\\\"function\\\\\\\")for(let a of l(e))!c.call(t,a)&&(n||a!==\\\\\\\"default\\\\\\\")&&s(t,a,{get:()=>e[a],enumerable:!(r=i(e,a))||r.enumerable});return t};var f=(t=>(e,n)=>t&&t.get(e)||(n=m(d({}),e,1),t&&t.set(e,n),n))(typeof WeakMap!=\\\\\\\"undefined\\\\\\\"?new WeakMap:0);var p={};y(p,{insertToday:()=>g});function o(t,...e){let n=Math.floor(Math.random()*1e6);return new Promise((r,a)=>{self.dispatchEvent(new CustomEvent(\\\\\\\"syscall\\\\\\\",{detail:{id:n,name:t,args:e,callback:r}}))})}async function g(){console.log(\\\\\\\"Inserting date\\\\\\\");let t=new Date().toISOString().split(\\\\\\\"T\\\\\\\")[0];await o(\\\\\\\"editor.insertAtCursor\\\\\\\",t)}return f(p);})();\\\\n//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiY29yZS9kYXRlcy50cyIsICJjb3JlL2xpYi9zeXNjYWxsLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJpbXBvcnQgeyBzeXNjYWxsIH0gZnJvbSBcIi4vbGliL3N5c2NhbGxcIjtcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGluc2VydFRvZGF5KCkge1xuICBjb25zb2xlLmxvZyhcIkluc2VydGluZyBkYXRlXCIpO1xuICBsZXQgbmljZURhdGUgPSBuZXcgRGF0ZSgpLnRvSVNPU3RyaW5nKCkuc3BsaXQoXCJUXCIpWzBdO1xuICBhd2FpdCBzeXNjYWxsKFwiZWRpdG9yLmluc2VydEF0Q3Vyc29yXCIsIG5pY2VEYXRlKTtcbn1cbiIsICJleHBvcnQgZnVuY3Rpb24gc3lzY2FsbChuYW1lOiBzdHJpbmcsIC4uLmFyZ3M6IGFueVtdKTogYW55IHtcbiAgbGV0IHJlcUlkID0gTWF0aC5mbG9vcihNYXRoLnJhbmRvbSgpICogMTAwMDAwMCk7XG4gIC8vIGNvbnNvbGUubG9nKFwiU3lzY2FsbFwiLCBuYW1lLCByZXFJZCk7XG4gIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgc2VsZi5kaXNwYXRjaEV2ZW50KFxuICAgICAgbmV3IEN1c3RvbUV2ZW50KFwic3lzY2FsbFwiLCB7XG4gICAgICAgIGRldGFpbDoge1xuICAgICAgICAgIGlkOiByZXFJZCxcbiAgICAgICAgICBuYW1lOiBuYW1lLFxuICAgICAgICAgIGFyZ3M6IGFyZ3MsXG4gICAgICAgICAgY2FsbGJhY2s6IHJlc29sdmUsXG4gICAgICAgIH0sXG4gICAgICB9KVxuICAgICk7XG4gIH0pO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjRoQkFBQSxrQ0NBTyxXQUFpQixLQUFpQixFQUFrQixDQUN6RCxHQUFJLEdBQVEsS0FBSyxNQUFNLEtBQUssU0FBVyxLQUV2QyxNQUFPLElBQUksU0FBUSxDQUFDLEVBQVMsSUFBVyxDQUN0QyxLQUFLLGNBQ0gsR0FBSSxhQUFZLFVBQVcsQ0FDekIsT0FBUSxDQUNOLEdBQUksRUFDSixLQUFNLEVBQ04sS0FBTSxFQUNOLFNBQVUsUURScEIsa0JBQW9DLENBQ2xDLFFBQVEsSUFBSSxrQkFDWixHQUFJLEdBQVcsR0FBSSxRQUFPLGNBQWMsTUFBTSxLQUFLLEdBQ25ELEtBQU0sR0FBUSx3QkFBeUIiLAogICJuYW1lcyI6IFtdCn0K\\\\n\\\",\\\"functionName\\\":\\\"insertToday\\\"},\\\"toggle_h1\\\":{\\\"path\\\":\\\"core/markup.ts\\\",\\\"code\\\":\\\"(()=>{var o=Object.defineProperty;var l=Object.getOwnPropertyDescriptor;var g=Object.getOwnPropertyNames;var c=Object.prototype.hasOwnProperty;var u=n=>o(n,\\\\\\\"__esModule\\\\\\\",{value:!0});var f=(n,e)=>{for(var t in e)o(n,t,{get:e[t],enumerable:!0})},d=(n,e,t,i)=>{if(e&&typeof e==\\\\\\\"object\\\\\\\"||typeof e==\\\\\\\"function\\\\\\\")for(let a of g(e))!c.call(n,a)&&(t||a!==\\\\\\\"default\\\\\\\")&&o(n,a,{get:()=>e[a],enumerable:!(i=l(e,a))||i.enumerable});return n};var w=(n=>(e,t)=>n&&n.get(e)||(t=d(u({}),e,1),n&&n.set(e,t),t))(typeof WeakMap!=\\\\\\\"undefined\\\\\\\"?new WeakMap:0);var b={};f(b,{toggleH1:()=>m,toggleH2:()=>y});function r(n,...e){let t=Math.floor(Math.random()*1e6);return new Promise((i,a)=>{self.dispatchEvent(new CustomEvent(\\\\\\\"syscall\\\\\\\",{detail:{id:t,name:n,args:e,callback:i}}))})}async function m(){await s(\\\\\\\"# \\\\\\\")}async function y(){await s(\\\\\\\"## \\\\\\\")}function h(n,e,t){return n.substring(e-t.length,e)===t}async function s(n){let e=await r(\\\\\\\"editor.getText\\\\\\\"),t=await r(\\\\\\\"editor.getCursor\\\\\\\");for(e[t]===`\\\\n`&&t--;t>0&&e[t]!==`\\\\n`;){if(h(e,t,n)){await r(\\\\\\\"editor.replaceRange\\\\\\\",t-n.length,t,\\\\\\\"\\\\\\\");return}t--}t&&t++,await r(\\\\\\\"editor.insertAtPos\\\\\\\",n,t)}return w(b);})();\\\\n//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiY29yZS9tYXJrdXAudHMiLCAiY29yZS9saWIvc3lzY2FsbC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiaW1wb3J0IHsgc3lzY2FsbCB9IGZyb20gXCIuL2xpYi9zeXNjYWxsXCI7XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiB0b2dnbGVIMSgpIHtcbiAgYXdhaXQgdG9nZ2xlUHJlZml4KFwiIyBcIik7XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiB0b2dnbGVIMigpIHtcbiAgYXdhaXQgdG9nZ2xlUHJlZml4KFwiIyMgXCIpO1xufVxuXG5mdW5jdGlvbiBsb29rQmFjayhzOiBzdHJpbmcsIHBvczogbnVtYmVyLCBiYWNrU3RyaW5nOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgcmV0dXJuIHMuc3Vic3RyaW5nKHBvcyAtIGJhY2tTdHJpbmcubGVuZ3RoLCBwb3MpID09PSBiYWNrU3RyaW5nO1xufVxuXG5hc3luYyBmdW5jdGlvbiB0b2dnbGVQcmVmaXgocHJlZml4OiBzdHJpbmcpIHtcbiAgbGV0IHRleHQgPSAoYXdhaXQgc3lzY2FsbChcImVkaXRvci5nZXRUZXh0XCIpKSBhcyBzdHJpbmc7XG4gIGxldCBwb3MgPSAoYXdhaXQgc3lzY2FsbChcImVkaXRvci5nZXRDdXJzb3JcIikpIGFzIG51bWJlcjtcbiAgaWYgKHRleHRbcG9zXSA9PT0gXCJcXG5cIikge1xuICAgIHBvcy0tO1xuICB9XG4gIHdoaWxlIChwb3MgPiAwICYmIHRleHRbcG9zXSAhPT0gXCJcXG5cIikge1xuICAgIGlmIChsb29rQmFjayh0ZXh0LCBwb3MsIHByZWZpeCkpIHtcbiAgICAgIC8vIEFscmVhZHkgaGFzIHRoaXMgcHJlZml4LCBsZXQncyBmbGlwIGl0XG4gICAgICBhd2FpdCBzeXNjYWxsKFwiZWRpdG9yLnJlcGxhY2VSYW5nZVwiLCBwb3MgLSBwcmVmaXgubGVuZ3RoLCBwb3MsIFwiXCIpO1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICBwb3MtLTtcbiAgfVxuICBpZiAocG9zKSB7XG4gICAgcG9zKys7XG4gIH1cbiAgYXdhaXQgc3lzY2FsbChcImVkaXRvci5pbnNlcnRBdFBvc1wiLCBwcmVmaXgsIHBvcyk7XG59XG4iLCAiZXhwb3J0IGZ1bmN0aW9uIHN5c2NhbGwobmFtZTogc3RyaW5nLCAuLi5hcmdzOiBhbnlbXSk6IGFueSB7XG4gIGxldCByZXFJZCA9IE1hdGguZmxvb3IoTWF0aC5yYW5kb20oKSAqIDEwMDAwMDApO1xuICAvLyBjb25zb2xlLmxvZyhcIlN5c2NhbGxcIiwgbmFtZSwgcmVxSWQpO1xuICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIHNlbGYuZGlzcGF0Y2hFdmVudChcbiAgICAgIG5ldyBDdXN0b21FdmVudChcInN5c2NhbGxcIiwge1xuICAgICAgICBkZXRhaWw6IHtcbiAgICAgICAgICBpZDogcmVxSWQsXG4gICAgICAgICAgbmFtZTogbmFtZSxcbiAgICAgICAgICBhcmdzOiBhcmdzLFxuICAgICAgICAgIGNhbGxiYWNrOiByZXNvbHZlLFxuICAgICAgICB9LFxuICAgICAgfSlcbiAgICApO1xuICB9KTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI0aEJBQUEsOENDQU8sV0FBaUIsS0FBaUIsRUFBa0IsQ0FDekQsR0FBSSxHQUFRLEtBQUssTUFBTSxLQUFLLFNBQVcsS0FFdkMsTUFBTyxJQUFJLFNBQVEsQ0FBQyxFQUFTLElBQVcsQ0FDdEMsS0FBSyxjQUNILEdBQUksYUFBWSxVQUFXLENBQ3pCLE9BQVEsQ0FDTixHQUFJLEVBQ0osS0FBTSxFQUNOLEtBQU0sRUFDTixTQUFVLFFEUnBCLGtCQUFpQyxDQUMvQixLQUFNLEdBQWEsTUFHckIsa0JBQWlDLENBQy9CLEtBQU0sR0FBYSxPQUdyQixXQUFrQixFQUFXLEVBQWEsRUFBNkIsQ0FDckUsTUFBTyxHQUFFLFVBQVUsRUFBTSxFQUFXLE9BQVEsS0FBUyxFQUd2RCxpQkFBNEIsRUFBZ0IsQ0FDMUMsR0FBSSxHQUFRLEtBQU0sR0FBUSxrQkFDdEIsRUFBTyxLQUFNLEdBQVEsb0JBSXpCLElBSEksRUFBSyxLQUFTO0FBQUEsR0FDaEIsSUFFSyxFQUFNLEdBQUssRUFBSyxLQUFTO0FBQUEsR0FBTSxDQUNwQyxHQUFJLEVBQVMsRUFBTSxFQUFLLEdBQVMsQ0FFL0IsS0FBTSxHQUFRLHNCQUF1QixFQUFNLEVBQU8sT0FBUSxFQUFLLElBQy9ELE9BRUYsSUFFRixBQUFJLEdBQ0YsSUFFRixLQUFNLEdBQVEscUJBQXNCLEVBQVEiLAogICJuYW1lcyI6IFtdCn0K\\\\n\\\",\\\"functionName\\\":\\\"toggleH1\\\"},\\\"toggle_h2\\\":{\\\"path\\\":\\\"core/markup.ts\\\",\\\"code\\\":\\\"(()=>{var o=Object.defineProperty;var l=Object.getOwnPropertyDescriptor;var g=Object.getOwnPropertyNames;var c=Object.prototype.hasOwnProperty;var u=n=>o(n,\\\\\\\"__esModule\\\\\\\",{value:!0});var f=(n,e)=>{for(var t in e)o(n,t,{get:e[t],enumerable:!0})},d=(n,e,t,i)=>{if(e&&typeof e==\\\\\\\"object\\\\\\\"||typeof e==\\\\\\\"function\\\\\\\")for(let a of g(e))!c.call(n,a)&&(t||a!==\\\\\\\"default\\\\\\\")&&o(n,a,{get:()=>e[a],enumerable:!(i=l(e,a))||i.enumerable});return n};var w=(n=>(e,t)=>n&&n.get(e)||(t=d(u({}),e,1),n&&n.set(e,t),t))(typeof WeakMap!=\\\\\\\"undefined\\\\\\\"?new WeakMap:0);var b={};f(b,{toggleH1:()=>m,toggleH2:()=>y});function r(n,...e){let t=Math.floor(Math.random()*1e6);return new Promise((i,a)=>{self.dispatchEvent(new CustomEvent(\\\\\\\"syscall\\\\\\\",{detail:{id:t,name:n,args:e,callback:i}}))})}async function m(){await s(\\\\\\\"# \\\\\\\")}async function y(){await s(\\\\\\\"## \\\\\\\")}function h(n,e,t){return n.substring(e-t.length,e)===t}async function s(n){let e=await r(\\\\\\\"editor.getText\\\\\\\"),t=await r(\\\\\\\"editor.getCursor\\\\\\\");for(e[t]===`\\\\n`&&t--;t>0&&e[t]!==`\\\\n`;){if(h(e,t,n)){await r(\\\\\\\"editor.replaceRange\\\\\\\",t-n.length,t,\\\\\\\"\\\\\\\");return}t--}t&&t++,await r(\\\\\\\"editor.insertAtPos\\\\\\\",n,t)}return w(b);})();\\\\n//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiY29yZS9tYXJrdXAudHMiLCAiY29yZS9saWIvc3lzY2FsbC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiaW1wb3J0IHsgc3lzY2FsbCB9IGZyb20gXCIuL2xpYi9zeXNjYWxsXCI7XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiB0b2dnbGVIMSgpIHtcbiAgYXdhaXQgdG9nZ2xlUHJlZml4KFwiIyBcIik7XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiB0b2dnbGVIMigpIHtcbiAgYXdhaXQgdG9nZ2xlUHJlZml4KFwiIyMgXCIpO1xufVxuXG5mdW5jdGlvbiBsb29rQmFjayhzOiBzdHJpbmcsIHBvczogbnVtYmVyLCBiYWNrU3RyaW5nOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgcmV0dXJuIHMuc3Vic3RyaW5nKHBvcyAtIGJhY2tTdHJpbmcubGVuZ3RoLCBwb3MpID09PSBiYWNrU3RyaW5nO1xufVxuXG5hc3luYyBmdW5jdGlvbiB0b2dnbGVQcmVmaXgocHJlZml4OiBzdHJpbmcpIHtcbiAgbGV0IHRleHQgPSAoYXdhaXQgc3lzY2FsbChcImVkaXRvci5nZXRUZXh0XCIpKSBhcyBzdHJpbmc7XG4gIGxldCBwb3MgPSAoYXdhaXQgc3lzY2FsbChcImVkaXRvci5nZXRDdXJzb3JcIikpIGFzIG51bWJlcjtcbiAgaWYgKHRleHRbcG9zXSA9PT0gXCJcXG5cIikge1xuICAgIHBvcy0tO1xuICB9XG4gIHdoaWxlIChwb3MgPiAwICYmIHRleHRbcG9zXSAhPT0gXCJcXG5cIikge1xuICAgIGlmIChsb29rQmFjayh0ZXh0LCBwb3MsIHByZWZpeCkpIHtcbiAgICAgIC8vIEFscmVhZHkgaGFzIHRoaXMgcHJlZml4LCBsZXQncyBmbGlwIGl0XG4gICAgICBhd2FpdCBzeXNjYWxsKFwiZWRpdG9yLnJlcGxhY2VSYW5nZVwiLCBwb3MgLSBwcmVmaXgubGVuZ3RoLCBwb3MsIFwiXCIpO1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICBwb3MtLTtcbiAgfVxuICBpZiAocG9zKSB7XG4gICAgcG9zKys7XG4gIH1cbiAgYXdhaXQgc3lzY2FsbChcImVkaXRvci5pbnNlcnRBdFBvc1wiLCBwcmVmaXgsIHBvcyk7XG59XG4iLCAiZXhwb3J0IGZ1bmN0aW9uIHN5c2NhbGwobmFtZTogc3RyaW5nLCAuLi5hcmdzOiBhbnlbXSk6IGFueSB7XG4gIGxldCByZXFJZCA9IE1hdGguZmxvb3IoTWF0aC5yYW5kb20oKSAqIDEwMDAwMDApO1xuICAvLyBjb25zb2xlLmxvZyhcIlN5c2NhbGxcIiwgbmFtZSwgcmVxSWQpO1xuICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIHNlbGYuZGlzcGF0Y2hFdmVudChcbiAgICAgIG5ldyBDdXN0b21FdmVudChcInN5c2NhbGxcIiwge1xuICAgICAgICBkZXRhaWw6IHtcbiAgICAgICAgICBpZDogcmVxSWQsXG4gICAgICAgICAgbmFtZTogbmFtZSxcbiAgICAgICAgICBhcmdzOiBhcmdzLFxuICAgICAgICAgIGNhbGxiYWNrOiByZXNvbHZlLFxuICAgICAgICB9LFxuICAgICAgfSlcbiAgICApO1xuICB9KTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI0aEJBQUEsOENDQU8sV0FBaUIsS0FBaUIsRUFBa0IsQ0FDekQsR0FBSSxHQUFRLEtBQUssTUFBTSxLQUFLLFNBQVcsS0FFdkMsTUFBTyxJQUFJLFNBQVEsQ0FBQyxFQUFTLElBQVcsQ0FDdEMsS0FBSyxjQUNILEdBQUksYUFBWSxVQUFXLENBQ3pCLE9BQVEsQ0FDTixHQUFJLEVBQ0osS0FBTSxFQUNOLEtBQU0sRUFDTixTQUFVLFFEUnBCLGtCQUFpQyxDQUMvQixLQUFNLEdBQWEsTUFHckIsa0JBQWlDLENBQy9CLEtBQU0sR0FBYSxPQUdyQixXQUFrQixFQUFXLEVBQWEsRUFBNkIsQ0FDckUsTUFBTyxHQUFFLFVBQVUsRUFBTSxFQUFXLE9BQVEsS0FBUyxFQUd2RCxpQkFBNEIsRUFBZ0IsQ0FDMUMsR0FBSSxHQUFRLEtBQU0sR0FBUSxrQkFDdEIsRUFBTyxLQUFNLEdBQVEsb0JBSXpCLElBSEksRUFBSyxLQUFTO0FBQUEsR0FDaEIsSUFFSyxFQUFNLEdBQUssRUFBSyxLQUFTO0FBQUEsR0FBTSxDQUNwQyxHQUFJLEVBQVMsRUFBTSxFQUFLLEdBQVMsQ0FFL0IsS0FBTSxHQUFRLHNCQUF1QixFQUFNLEVBQU8sT0FBUSxFQUFLLElBQy9ELE9BRUYsSUFFRixBQUFJLEdBQ0YsSUFFRixLQUFNLEdBQVEscUJBQXNCLEVBQVEiLAogICJuYW1lcyI6IFtdCn0K\\\\n\\\",\\\"functionName\\\":\\\"toggleH2\\\"}}}\");\n\n},{}],\"6J6FU\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"insertMarker\", ()=>insertMarker\n);\nvar _state = require(\"@codemirror/state\");\nvar _text = require(\"@codemirror/text\");\nfunction insertMarker(marker) {\n return ({ state , dispatch })=>{\n const changes1 = state.changeByRange((range)=>{\n const isBoldBefore = state.sliceDoc(range.from - marker.length, range.from) === marker;\n const isBoldAfter = state.sliceDoc(range.to, range.to + marker.length) === marker;\n const changes = [];\n changes.push(isBoldBefore ? {\n from: range.from - marker.length,\n to: range.from,\n insert: _text.Text.of([\n \"\"\n ])\n } : {\n from: range.from,\n insert: _text.Text.of([\n marker\n ])\n });\n changes.push(isBoldAfter ? {\n from: range.to,\n to: range.to + marker.length,\n insert: _text.Text.of([\n \"\"\n ])\n } : {\n from: range.to,\n insert: _text.Text.of([\n marker\n ])\n });\n const extendBefore = isBoldBefore ? -marker.length : marker.length;\n const extendAfter = isBoldAfter ? -marker.length : marker.length;\n return {\n changes,\n range: _state.EditorSelection.range(range.from + extendBefore, range.to + extendAfter)\n };\n });\n dispatch(state.update(changes1, {\n scrollIntoView: true,\n annotations: _state.Transaction.userEvent.of(\"input\")\n }));\n return true;\n };\n}\n\n},{\"@codemirror/state\":\"e6FBl\",\"@codemirror/text\":\"kn7DT\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"hTiUo\":[function(require,module,exports) {\nvar $parcel$ReactRefreshHelpers$03a3 = require(\"@parcel/transformer-react-refresh-wrap/lib/helpers/helpers.js\");\nvar prevRefreshReg = window.$RefreshReg$;\nvar prevRefreshSig = window.$RefreshSig$;\n$parcel$ReactRefreshHelpers$03a3.prelude(module);\n\ntry {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"CommandPalette\", ()=>CommandPalette\n);\nvar _jsxDevRuntime = require(\"react/jsx-dev-runtime\");\nvar _util = require(\"../util\");\nvar _filter = require(\"./filter\");\nvar _freeSolidSvgIcons = require(\"@fortawesome/free-solid-svg-icons\");\nfunction CommandPalette({ commands , onTrigger }) {\n let options = [];\n const isMac = _util.isMacLike();\n for (let [name, def] of commands.entries())options.push({\n name: name,\n hint: isMac && def.command.mac ? def.command.mac : def.command.key\n });\n console.log(\"Commands\", options);\n return(/*#__PURE__*/ _jsxDevRuntime.jsxDEV(_filter.FilterList, {\n label: \"Run\",\n placeholder: \"Command\",\n options: options,\n allowNew: false,\n icon: _freeSolidSvgIcons.faPersonRunning,\n helpText: \"Start typing the command name to filter results, press <code>Return</code> to run.\",\n onSelect: (opt)=>{\n if (opt) onTrigger(commands.get(opt.name));\n else onTrigger(undefined);\n }\n }, void 0, false, {\n fileName: \"/Users/zef/git/nugget/webapp/src/components/command_palette.tsx\",\n lineNumber: 23,\n columnNumber: 5\n }, this));\n}\n_c = CommandPalette;\nvar _c;\n$RefreshReg$(_c, \"CommandPalette\");\n\n $parcel$ReactRefreshHelpers$03a3.postlude(module);\n} finally {\n window.$RefreshReg$ = prevRefreshReg;\n window.$RefreshSig$ = prevRefreshSig;\n}\n},{\"react/jsx-dev-runtime\":\"jsc7i\",\"../util\":\"eF4A3\",\"./filter\":\"iVuFf\",\"@fortawesome/free-solid-svg-icons\":\"6ECLA\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\",\"@parcel/transformer-react-refresh-wrap/lib/helpers/helpers.js\":\"km3Ru\"}],\"eF4A3\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"countWords\", ()=>countWords\n);\nparcelHelpers.export(exports, \"readingTime\", ()=>readingTime\n);\nparcelHelpers.export(exports, \"safeRun\", ()=>safeRun\n);\nparcelHelpers.export(exports, \"sleep\", ()=>sleep\n);\nparcelHelpers.export(exports, \"isMacLike\", ()=>isMacLike\n);\nfunction countWords(str) {\n var matches = str.match(/[\\w\\d\\'\\'-]+/gi);\n return matches ? matches.length : 0;\n}\nfunction readingTime(wordCount) {\n // 225 is average word reading speed for adults\n return Math.ceil(wordCount / 225);\n}\nfunction safeRun(fn) {\n fn().catch((e)=>{\n console.error(e);\n });\n}\nfunction sleep(ms) {\n return new Promise((resolve)=>{\n setTimeout(()=>{\n resolve();\n }, ms);\n });\n}\nfunction isMacLike() {\n return /(Mac|iPhone|iPod|iPad)/i.test(navigator.platform);\n}\n\n},{\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"iVuFf\":[function(require,module,exports) {\nvar $parcel$ReactRefreshHelpers$52ae = require(\"@parcel/transformer-react-refresh-wrap/lib/helpers/helpers.js\");\nvar prevRefreshReg = window.$RefreshReg$;\nvar prevRefreshSig = window.$RefreshSig$;\n$parcel$ReactRefreshHelpers$52ae.prelude(module);\n\ntry {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"FilterList\", ()=>FilterList\n);\nvar _jsxDevRuntime = require(\"react/jsx-dev-runtime\");\nvar _react = require(\"react\");\nvar _reactDefault = parcelHelpers.interopDefault(_react);\nvar _reactFontawesome = require(\"@fortawesome/react-fontawesome\");\nvar _s = $RefreshSig$();\nfunction magicSorter(a, b) {\n if (a.orderId && b.orderId) return a.orderId < b.orderId ? -1 : 1;\n return a.name.toLowerCase() < b.name.toLowerCase() ? -1 : 1;\n}\nfunction FilterList({ placeholder , options , label , onSelect , onKeyPress , allowNew =false , helpText =\"\" , icon , newHint }) {\n _s();\n const searchBoxRef = _react.useRef(null);\n const [text, setText] = _react.useState(\"\");\n const [matchingOptions, setMatchingOptions] = _react.useState(options.sort(magicSorter));\n const [selectedOption, setSelectionOption] = _react.useState(0);\n let selectedElementRef = _react.useRef(null);\n const filter = (e)=>{\n const originalPhrase = e.target.value;\n const searchPhrase = originalPhrase.toLowerCase();\n if (searchPhrase) {\n let foundExactMatch = false;\n let results = options.filter((option)=>{\n if (option.name.toLowerCase() === searchPhrase) foundExactMatch = true;\n return option.name.toLowerCase().indexOf(searchPhrase) !== -1;\n });\n results = results.sort(magicSorter);\n if (allowNew && !foundExactMatch) results.push({\n name: originalPhrase,\n hint: newHint\n });\n setMatchingOptions(results);\n } else {\n let results = options.sort(magicSorter);\n setMatchingOptions(results);\n }\n setText(originalPhrase);\n setSelectionOption(0);\n };\n _react.useEffect(()=>{\n searchBoxRef.current.focus();\n }, []);\n _react.useEffect(()=>{\n function closer() {\n onSelect(undefined);\n }\n document.addEventListener(\"click\", closer);\n return ()=>{\n document.removeEventListener(\"click\", closer);\n };\n }, []);\n const returnEl = /*#__PURE__*/ _jsxDevRuntime.jsxDEV(\"div\", {\n className: \"filter-box\",\n children: [\n /*#__PURE__*/ _jsxDevRuntime.jsxDEV(\"div\", {\n className: \"header\",\n children: [\n /*#__PURE__*/ _jsxDevRuntime.jsxDEV(\"label\", {\n children: label\n }, void 0, false, {\n fileName: \"/Users/zef/git/nugget/webapp/src/components/filter.tsx\",\n lineNumber: 95,\n columnNumber: 9\n }, this),\n /*#__PURE__*/ _jsxDevRuntime.jsxDEV(\"input\", {\n type: \"text\",\n value: text,\n placeholder: placeholder,\n ref: searchBoxRef,\n onChange: filter,\n onKeyDown: (e)=>{\n console.log(\"Key up\", e.key);\n if (onKeyPress) onKeyPress(e.key, text);\n switch(e.key){\n case \"ArrowUp\":\n setSelectionOption(Math.max(0, selectedOption - 1));\n break;\n case \"ArrowDown\":\n setSelectionOption(Math.min(matchingOptions.length - 1, selectedOption + 1));\n break;\n case \"Enter\":\n onSelect(matchingOptions[selectedOption]);\n e.preventDefault();\n break;\n case \"Escape\":\n onSelect(undefined);\n break;\n }\n }\n }, void 0, false, {\n fileName: \"/Users/zef/git/nugget/webapp/src/components/filter.tsx\",\n lineNumber: 96,\n columnNumber: 9\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/zef/git/nugget/webapp/src/components/filter.tsx\",\n lineNumber: 94,\n columnNumber: 7\n }, this),\n /*#__PURE__*/ _jsxDevRuntime.jsxDEV(\"div\", {\n className: \"help-text\",\n dangerouslySetInnerHTML: {\n __html: helpText\n }\n }, void 0, false, {\n fileName: \"/Users/zef/git/nugget/webapp/src/components/filter.tsx\",\n lineNumber: 127,\n columnNumber: 7\n }, this),\n /*#__PURE__*/ _jsxDevRuntime.jsxDEV(\"div\", {\n className: \"result-list\",\n children: matchingOptions && matchingOptions.length > 0 ? matchingOptions.map((option, idx)=>/*#__PURE__*/ _jsxDevRuntime.jsxDEV(\"div\", {\n ref: selectedOption === idx ? selectedElementRef : undefined,\n className: selectedOption === idx ? \"selected-option\" : \"option\",\n onMouseOver: (e)=>{\n setSelectionOption(idx);\n },\n onClick: (e)=>{\n e.preventDefault();\n onSelect(option);\n },\n children: [\n /*#__PURE__*/ _jsxDevRuntime.jsxDEV(\"span\", {\n className: \"icon\",\n children: icon && /*#__PURE__*/ _jsxDevRuntime.jsxDEV(_reactFontawesome.FontAwesomeIcon, {\n icon: icon\n }, void 0, false, {\n fileName: \"/Users/zef/git/nugget/webapp/src/components/filter.tsx\",\n lineNumber: 149,\n columnNumber: 28\n }, this)\n }, void 0, false, {\n fileName: \"/Users/zef/git/nugget/webapp/src/components/filter.tsx\",\n lineNumber: 148,\n columnNumber: 17\n }, this),\n /*#__PURE__*/ _jsxDevRuntime.jsxDEV(\"span\", {\n className: \"name\",\n children: option.name\n }, void 0, false, {\n fileName: \"/Users/zef/git/nugget/webapp/src/components/filter.tsx\",\n lineNumber: 151,\n columnNumber: 17\n }, this),\n option.hint && /*#__PURE__*/ _jsxDevRuntime.jsxDEV(\"span\", {\n className: \"hint\",\n children: option.hint\n }, void 0, false, {\n fileName: \"/Users/zef/git/nugget/webapp/src/components/filter.tsx\",\n lineNumber: 152,\n columnNumber: 33\n }, this)\n ]\n }, \"\" + idx, true, {\n fileName: \"/Users/zef/git/nugget/webapp/src/components/filter.tsx\",\n lineNumber: 134,\n columnNumber: 15\n }, this)\n ) : null\n }, void 0, false, {\n fileName: \"/Users/zef/git/nugget/webapp/src/components/filter.tsx\",\n lineNumber: 131,\n columnNumber: 7\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/zef/git/nugget/webapp/src/components/filter.tsx\",\n lineNumber: 93,\n columnNumber: 5\n }, this);\n _react.useEffect(()=>{\n selectedElementRef.current?.scrollIntoView({\n block: \"nearest\"\n });\n });\n return returnEl;\n}\n_s(FilterList, \"aQsY9CGDQ0TxFeR6Sw5T6+sxByg=\");\n_c = FilterList;\nvar _c;\n$RefreshReg$(_c, \"FilterList\");\n\n $parcel$ReactRefreshHelpers$52ae.postlude(module);\n} finally {\n window.$RefreshReg$ = prevRefreshReg;\n window.$RefreshSig$ = prevRefreshSig;\n}\n},{\"react/jsx-dev-runtime\":\"jsc7i\",\"react\":\"1PJsa\",\"@fortawesome/react-fontawesome\":\"73SlK\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\",\"@parcel/transformer-react-refresh-wrap/lib/helpers/helpers.js\":\"km3Ru\"}],\"73SlK\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"FontAwesomeIcon\", ()=>FontAwesomeIcon\n);\nvar _fontawesomeSvgCore = require(\"@fortawesome/fontawesome-svg-core\");\nvar _propTypes = require(\"prop-types\");\nvar _propTypesDefault = parcelHelpers.interopDefault(_propTypes);\nvar _react = require(\"react\");\nvar _reactDefault = parcelHelpers.interopDefault(_react);\nfunction ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n enumerableOnly && (symbols = symbols.filter(function(sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n })), keys.push.apply(keys, symbols);\n }\n return keys;\n}\nfunction _objectSpread2(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = null != arguments[i] ? arguments[i] : {\n };\n i % 2 ? ownKeys(Object(source), !0).forEach(function(key) {\n _defineProperty(target, key, source[key]);\n }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function(key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n return target;\n}\nfunction _typeof(obj1) {\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function(obj) {\n return typeof obj;\n } : function(obj) {\n return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n }, _typeof(obj1);\n}\nfunction _defineProperty(obj, key, value) {\n if (key in obj) Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n else obj[key] = value;\n return obj;\n}\nfunction _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {\n };\n var target = {\n };\n var sourceKeys = Object.keys(source);\n var key, i;\n for(i = 0; i < sourceKeys.length; i++){\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}\nfunction _objectWithoutProperties(source, excluded) {\n if (source == null) return {\n };\n var target = _objectWithoutPropertiesLoose(source, excluded);\n var key, i;\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n for(i = 0; i < sourceSymbolKeys.length; i++){\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n return target;\n}\nfunction _toConsumableArray(arr) {\n return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();\n}\nfunction _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return _arrayLikeToArray(arr);\n}\nfunction _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);\n}\nfunction _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];\n return arr2;\n}\nfunction _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\n// Get CSS class list from a props object\nfunction classList(props) {\n var _classes;\n var beat = props.beat, fade = props.fade, flash = props.flash, spin = props.spin, spinPulse = props.spinPulse, spinReverse = props.spinReverse, pulse = props.pulse, fixedWidth = props.fixedWidth, inverse = props.inverse, border = props.border, listItem = props.listItem, flip = props.flip, size = props.size, rotation = props.rotation, pull = props.pull; // map of CSS class names to properties\n var classes = (_classes = {\n 'fa-beat': beat,\n 'fa-fade': fade,\n 'fa-flash': flash,\n 'fa-spin': spin,\n 'fa-spin-reverse': spinReverse,\n 'fa-spin-pulse': spinPulse,\n 'fa-pulse': pulse,\n 'fa-fw': fixedWidth,\n 'fa-inverse': inverse,\n 'fa-border': border,\n 'fa-li': listItem,\n 'fa-flip-horizontal': flip === 'horizontal' || flip === 'both',\n 'fa-flip-vertical': flip === 'vertical' || flip === 'both'\n }, _defineProperty(_classes, \"fa-\".concat(size), typeof size !== 'undefined' && size !== null), _defineProperty(_classes, \"fa-rotate-\".concat(rotation), typeof rotation !== 'undefined' && rotation !== null && rotation !== 0), _defineProperty(_classes, \"fa-pull-\".concat(pull), typeof pull !== 'undefined' && pull !== null), _defineProperty(_classes, 'fa-swap-opacity', props.swapOpacity), _classes); // map over all the keys in the classes object\n // return an array of the keys where the value for the key is not null\n return Object.keys(classes).map(function(key) {\n return classes[key] ? key : null;\n }).filter(function(key) {\n return key;\n });\n}\n// Camelize taken from humps\n// humps is copyright \u00a9 2012+ Dom Christie\n// Released under the MIT license.\n// Performant way to determine if object coerces to a number\nfunction _isNumerical(obj) {\n obj = obj - 0; // eslint-disable-next-line no-self-compare\n return obj === obj;\n}\nfunction camelize(string) {\n if (_isNumerical(string)) return string;\n // eslint-disable-next-line no-useless-escape\n string = string.replace(/[\\-_\\s]+(.)?/g, function(match, chr) {\n return chr ? chr.toUpperCase() : '';\n }); // Ensure 1st char is always lowercase\n return string.substr(0, 1).toLowerCase() + string.substr(1);\n}\nvar _excluded$1 = [\n \"style\"\n];\nfunction capitalize(val) {\n return val.charAt(0).toUpperCase() + val.slice(1);\n}\nfunction styleToObject(style) {\n return style.split(';').map(function(s) {\n return s.trim();\n }).filter(function(s) {\n return s;\n }).reduce(function(acc, pair) {\n var i = pair.indexOf(':');\n var prop = camelize(pair.slice(0, i));\n var value = pair.slice(i + 1).trim();\n prop.startsWith('webkit') ? acc[capitalize(prop)] = value : acc[prop] = value;\n return acc;\n }, {\n });\n}\nfunction convert(createElement, element) {\n var extraProps = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {\n };\n if (typeof element === 'string') return element;\n var children = (element.children || []).map(function(child) {\n return convert(createElement, child);\n });\n /* eslint-disable dot-notation */ var mixins = Object.keys(element.attributes || {\n }).reduce(function(acc, key) {\n var val = element.attributes[key];\n switch(key){\n case 'class':\n acc.attrs['className'] = val;\n delete element.attributes['class'];\n break;\n case 'style':\n acc.attrs['style'] = styleToObject(val);\n break;\n default:\n if (key.indexOf('aria-') === 0 || key.indexOf('data-') === 0) acc.attrs[key.toLowerCase()] = val;\n else acc.attrs[camelize(key)] = val;\n }\n return acc;\n }, {\n attrs: {\n }\n });\n var _extraProps$style = extraProps.style, existingStyle = _extraProps$style === void 0 ? {\n } : _extraProps$style, remaining = _objectWithoutProperties(extraProps, _excluded$1);\n mixins.attrs['style'] = _objectSpread2(_objectSpread2({\n }, mixins.attrs['style']), existingStyle);\n /* eslint-enable */ return createElement.apply(void 0, [\n element.tag,\n _objectSpread2(_objectSpread2({\n }, mixins.attrs), remaining)\n ].concat(_toConsumableArray(children)));\n}\nvar PRODUCTION = false;\ntry {\n PRODUCTION = false;\n} catch (e) {\n}\nfunction log() {\n if (!PRODUCTION && console && typeof console.error === 'function') {\n var _console;\n (_console = console).error.apply(_console, arguments);\n }\n}\nfunction normalizeIconArgs(icon) {\n // this has everything that it needs to be rendered which means it was probably imported\n // directly from an icon svg package\n if (icon && _typeof(icon) === 'object' && icon.prefix && icon.iconName && icon.icon) return icon;\n if (_fontawesomeSvgCore.parse.icon) return _fontawesomeSvgCore.parse.icon(icon);\n // if the icon is null, there's nothing to do\n if (icon === null) return null;\n // if the icon is an object and has a prefix and an icon name, return it\n if (icon && _typeof(icon) === 'object' && icon.prefix && icon.iconName) return icon;\n // if it's an array with length of two\n if (Array.isArray(icon) && icon.length === 2) // use the first item as prefix, second as icon name\n return {\n prefix: icon[0],\n iconName: icon[1]\n };\n // if it's a string, use it as the icon name\n if (typeof icon === 'string') return {\n prefix: 'fas',\n iconName: icon\n };\n}\n// creates an object with a key of key\n// and a value of value\n// if certain conditions are met\nfunction objectWithKey(key, value) {\n // if the value is a non-empty array\n // or it's not an array but it is truthy\n // then create the object with the key and the value\n // if not, return an empty array\n return Array.isArray(value) && value.length > 0 || !Array.isArray(value) && value ? _defineProperty({\n }, key, value) : {\n };\n}\nvar _excluded = [\n \"forwardedRef\"\n];\nfunction FontAwesomeIcon(_ref) {\n var forwardedRef = _ref.forwardedRef, props = _objectWithoutProperties(_ref, _excluded);\n var iconArgs = props.icon, maskArgs = props.mask, symbol = props.symbol, className = props.className, title = props.title, titleId = props.titleId;\n var iconLookup = normalizeIconArgs(iconArgs);\n var classes = objectWithKey('classes', [].concat(_toConsumableArray(classList(props)), _toConsumableArray(className.split(' '))));\n var transform = objectWithKey('transform', typeof props.transform === 'string' ? _fontawesomeSvgCore.parse.transform(props.transform) : props.transform);\n var mask = objectWithKey('mask', normalizeIconArgs(maskArgs));\n var renderedIcon = _fontawesomeSvgCore.icon(iconLookup, _objectSpread2(_objectSpread2(_objectSpread2(_objectSpread2({\n }, classes), transform), mask), {\n }, {\n symbol: symbol,\n title: title,\n titleId: titleId\n }));\n if (!renderedIcon) {\n log('Could not find icon', iconLookup);\n return null;\n }\n var abstract = renderedIcon.abstract;\n var extraProps = {\n ref: forwardedRef\n };\n Object.keys(props).forEach(function(key) {\n // eslint-disable-next-line no-prototype-builtins\n if (!FontAwesomeIcon.defaultProps.hasOwnProperty(key)) extraProps[key] = props[key];\n });\n return convertCurry(abstract[0], extraProps);\n}\nFontAwesomeIcon.displayName = 'FontAwesomeIcon';\nFontAwesomeIcon.propTypes = {\n beat: _propTypesDefault.default.bool,\n border: _propTypesDefault.default.bool,\n className: _propTypesDefault.default.string,\n fade: _propTypesDefault.default.bool,\n flash: _propTypesDefault.default.bool,\n mask: _propTypesDefault.default.oneOfType([\n _propTypesDefault.default.object,\n _propTypesDefault.default.array,\n _propTypesDefault.default.string\n ]),\n fixedWidth: _propTypesDefault.default.bool,\n inverse: _propTypesDefault.default.bool,\n flip: _propTypesDefault.default.oneOf([\n 'horizontal',\n 'vertical',\n 'both'\n ]),\n icon: _propTypesDefault.default.oneOfType([\n _propTypesDefault.default.object,\n _propTypesDefault.default.array,\n _propTypesDefault.default.string\n ]),\n listItem: _propTypesDefault.default.bool,\n pull: _propTypesDefault.default.oneOf([\n 'right',\n 'left'\n ]),\n pulse: _propTypesDefault.default.bool,\n rotation: _propTypesDefault.default.oneOf([\n 0,\n 90,\n 180,\n 270\n ]),\n size: _propTypesDefault.default.oneOf([\n '2xs',\n 'xs',\n 'sm',\n 'lg',\n 'xl',\n '2xl',\n '1x',\n '2x',\n '3x',\n '4x',\n '5x',\n '6x',\n '7x',\n '8x',\n '9x',\n '10x'\n ]),\n spin: _propTypesDefault.default.bool,\n spinPulse: _propTypesDefault.default.bool,\n spinReverse: _propTypesDefault.default.bool,\n symbol: _propTypesDefault.default.oneOfType([\n _propTypesDefault.default.bool,\n _propTypesDefault.default.string\n ]),\n title: _propTypesDefault.default.string,\n transform: _propTypesDefault.default.oneOfType([\n _propTypesDefault.default.string,\n _propTypesDefault.default.object\n ]),\n swapOpacity: _propTypesDefault.default.bool\n};\nFontAwesomeIcon.defaultProps = {\n border: false,\n className: '',\n mask: null,\n fixedWidth: false,\n inverse: false,\n flip: null,\n icon: null,\n listItem: false,\n pull: null,\n pulse: false,\n rotation: null,\n size: null,\n spin: false,\n symbol: false,\n title: '',\n transform: null,\n swapOpacity: false\n};\nvar convertCurry = convert.bind(null, _reactDefault.default.createElement);\n\n},{\"@fortawesome/fontawesome-svg-core\":\"d2Tn1\",\"prop-types\":\"gHbN2\",\"react\":\"1PJsa\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"d2Tn1\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"noAuto\", ()=>noAuto$1\n);\nparcelHelpers.export(exports, \"config\", ()=>config$1\n);\nparcelHelpers.export(exports, \"library\", ()=>library$1\n);\nparcelHelpers.export(exports, \"dom\", ()=>dom$1\n);\nparcelHelpers.export(exports, \"parse\", ()=>parse$1\n);\nparcelHelpers.export(exports, \"findIconDefinition\", ()=>findIconDefinition$1\n);\nparcelHelpers.export(exports, \"toHtml\", ()=>toHtml$1\n);\nparcelHelpers.export(exports, \"icon\", ()=>icon\n);\nparcelHelpers.export(exports, \"layer\", ()=>layer\n);\nparcelHelpers.export(exports, \"text\", ()=>text\n);\nparcelHelpers.export(exports, \"counter\", ()=>counter\n);\nparcelHelpers.export(exports, \"api\", ()=>api\n);\n/*!\n * Font Awesome Free 6.0.0 by @fontawesome - https://fontawesome.com\n * License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License)\n * Copyright 2022 Fonticons, Inc.\n */ function ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n enumerableOnly && (symbols = symbols.filter(function(sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n })), keys.push.apply(keys, symbols);\n }\n return keys;\n}\nfunction _objectSpread2(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = null != arguments[i] ? arguments[i] : {\n };\n i % 2 ? ownKeys(Object(source), !0).forEach(function(key) {\n _defineProperty(target, key, source[key]);\n }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function(key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n return target;\n}\nfunction _typeof(obj1) {\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function(obj) {\n return typeof obj;\n } : function(obj) {\n return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n }, _typeof(obj1);\n}\nfunction _wrapRegExp() {\n _wrapRegExp = function(re, groups) {\n return new BabelRegExp(re, void 0, groups);\n };\n var _super = RegExp.prototype, _groups = new WeakMap();\n function BabelRegExp(re, flags, groups) {\n var _this = new RegExp(re, flags);\n return _groups.set(_this, groups || _groups.get(re)), _setPrototypeOf(_this, BabelRegExp.prototype);\n }\n function buildGroups(result, re) {\n var g = _groups.get(re);\n return Object.keys(g).reduce(function(groups, name) {\n return groups[name] = result[g[name]], groups;\n }, Object.create(null));\n }\n return _inherits(BabelRegExp, RegExp), BabelRegExp.prototype.exec = function(str) {\n var result = _super.exec.call(this, str);\n return result && (result.groups = buildGroups(result, this)), result;\n }, BabelRegExp.prototype[Symbol.replace] = function(str, substitution) {\n if (\"string\" == typeof substitution) {\n var groups = _groups.get(this);\n return _super[Symbol.replace].call(this, str, substitution.replace(/\\$<([^>]+)>/g, function(_, name) {\n return \"$\" + groups[name];\n }));\n }\n if (\"function\" == typeof substitution) {\n var _this = this;\n return _super[Symbol.replace].call(this, str, function() {\n var args = arguments;\n return \"object\" != typeof args[args.length - 1] && (args = [].slice.call(args)).push(buildGroups(args, _this)), substitution.apply(this, args);\n });\n }\n return _super[Symbol.replace].call(this, str, substitution);\n }, _wrapRegExp.apply(this, arguments);\n}\nfunction _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) throw new TypeError(\"Cannot call a class as a function\");\n}\nfunction _defineProperties(target, props) {\n for(var i = 0; i < props.length; i++){\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}\nfunction _defineProperty(obj, key, value) {\n if (key in obj) Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n else obj[key] = value;\n return obj;\n}\nfunction _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) throw new TypeError(\"Super expression must either be null or a function\");\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) _setPrototypeOf(subClass, superClass);\n}\nfunction _setPrototypeOf(o1, p1) {\n _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p2) {\n o.__proto__ = p2;\n return o;\n };\n return _setPrototypeOf(o1, p1);\n}\nfunction _slicedToArray(arr, i) {\n return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();\n}\nfunction _toConsumableArray(arr) {\n return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();\n}\nfunction _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return _arrayLikeToArray(arr);\n}\nfunction _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}\nfunction _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}\nfunction _iterableToArrayLimit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n var _s, _e;\n try {\n for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){\n _arr.push(_s.value);\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally{\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally{\n if (_d) throw _e;\n }\n }\n return _arr;\n}\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);\n}\nfunction _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];\n return arr2;\n}\nfunction _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nfunction _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nvar noop = function noop() {\n};\nvar _WINDOW = {\n};\nvar _DOCUMENT = {\n};\nvar _MUTATION_OBSERVER = null;\nvar _PERFORMANCE = {\n mark: noop,\n measure: noop\n};\ntry {\n if (typeof window !== 'undefined') _WINDOW = window;\n if (typeof document !== 'undefined') _DOCUMENT = document;\n if (typeof MutationObserver !== 'undefined') _MUTATION_OBSERVER = MutationObserver;\n if (typeof performance !== 'undefined') _PERFORMANCE = performance;\n} catch (e) {\n}\nvar _ref = _WINDOW.navigator || {\n}, _ref$userAgent = _ref.userAgent, userAgent = _ref$userAgent === void 0 ? '' : _ref$userAgent;\nvar WINDOW = _WINDOW;\nvar DOCUMENT = _DOCUMENT;\nvar MUTATION_OBSERVER = _MUTATION_OBSERVER;\nvar PERFORMANCE = _PERFORMANCE;\nvar IS_BROWSER = !!WINDOW.document;\nvar IS_DOM = !!DOCUMENT.documentElement && !!DOCUMENT.head && typeof DOCUMENT.addEventListener === 'function' && typeof DOCUMENT.createElement === 'function';\nvar IS_IE = ~userAgent.indexOf('MSIE') || ~userAgent.indexOf('Trident/');\nvar NAMESPACE_IDENTIFIER = '___FONT_AWESOME___';\nvar UNITS_IN_GRID = 16;\nvar DEFAULT_FAMILY_PREFIX = 'fa';\nvar DEFAULT_REPLACEMENT_CLASS = 'svg-inline--fa';\nvar DATA_FA_I2SVG = 'data-fa-i2svg';\nvar DATA_FA_PSEUDO_ELEMENT = 'data-fa-pseudo-element';\nvar DATA_FA_PSEUDO_ELEMENT_PENDING = 'data-fa-pseudo-element-pending';\nvar DATA_PREFIX = 'data-prefix';\nvar DATA_ICON = 'data-icon';\nvar HTML_CLASS_I2SVG_BASE_CLASS = 'fontawesome-i2svg';\nvar MUTATION_APPROACH_ASYNC = 'async';\nvar TAGNAMES_TO_SKIP_FOR_PSEUDOELEMENTS = [\n 'HTML',\n 'HEAD',\n 'STYLE',\n 'SCRIPT'\n];\nvar PRODUCTION = function() {\n try {\n return false;\n } catch (e) {\n return false;\n }\n}();\nvar PREFIX_TO_STYLE = {\n 'fas': 'solid',\n 'fa-solid': 'solid',\n 'far': 'regular',\n 'fa-regular': 'regular',\n 'fal': 'light',\n 'fa-light': 'light',\n 'fat': 'thin',\n 'fa-thin': 'thin',\n 'fad': 'duotone',\n 'fa-duotone': 'duotone',\n 'fab': 'brands',\n 'fa-brands': 'brands',\n 'fak': 'kit',\n 'fa-kit': 'kit',\n 'fa': 'solid'\n};\nvar STYLE_TO_PREFIX = {\n 'solid': 'fas',\n 'regular': 'far',\n 'light': 'fal',\n 'thin': 'fat',\n 'duotone': 'fad',\n 'brands': 'fab',\n 'kit': 'fak'\n};\nvar PREFIX_TO_LONG_STYLE = {\n 'fab': 'fa-brands',\n 'fad': 'fa-duotone',\n 'fak': 'fa-kit',\n 'fal': 'fa-light',\n 'far': 'fa-regular',\n 'fas': 'fa-solid',\n 'fat': 'fa-thin'\n};\nvar LONG_STYLE_TO_PREFIX = {\n 'fa-brands': 'fab',\n 'fa-duotone': 'fad',\n 'fa-kit': 'fak',\n 'fa-light': 'fal',\n 'fa-regular': 'far',\n 'fa-solid': 'fas',\n 'fa-thin': 'fat'\n};\nvar ICON_SELECTION_SYNTAX_PATTERN = /fa[srltdbk\\-\\ ]/; // eslint-disable-line no-useless-escape\nvar LAYERS_TEXT_CLASSNAME = 'fa-layers-text';\nvar FONT_FAMILY_PATTERN = /Font ?Awesome ?([56 ]*)(Solid|Regular|Light|Thin|Duotone|Brands|Free|Pro|Kit)?.*/i; // TODO: do we need to handle font-weight for kit SVG pseudo-elements?\nvar FONT_WEIGHT_TO_PREFIX = {\n '900': 'fas',\n '400': 'far',\n 'normal': 'far',\n '300': 'fal',\n '100': 'fat'\n};\nvar oneToTen = [\n 1,\n 2,\n 3,\n 4,\n 5,\n 6,\n 7,\n 8,\n 9,\n 10\n];\nvar oneToTwenty = oneToTen.concat([\n 11,\n 12,\n 13,\n 14,\n 15,\n 16,\n 17,\n 18,\n 19,\n 20\n]);\nvar ATTRIBUTES_WATCHED_FOR_MUTATION = [\n 'class',\n 'data-prefix',\n 'data-icon',\n 'data-fa-transform',\n 'data-fa-mask'\n];\nvar DUOTONE_CLASSES = {\n GROUP: 'duotone-group',\n SWAP_OPACITY: 'swap-opacity',\n PRIMARY: 'primary',\n SECONDARY: 'secondary'\n};\nvar RESERVED_CLASSES = [].concat(_toConsumableArray(Object.keys(STYLE_TO_PREFIX)), [\n '2xs',\n 'xs',\n 'sm',\n 'lg',\n 'xl',\n '2xl',\n 'beat',\n 'border',\n 'fade',\n 'beat-fade',\n 'bounce',\n 'flip-both',\n 'flip-horizontal',\n 'flip-vertical',\n 'flip',\n 'fw',\n 'inverse',\n 'layers-counter',\n 'layers-text',\n 'layers',\n 'li',\n 'pull-left',\n 'pull-right',\n 'pulse',\n 'rotate-180',\n 'rotate-270',\n 'rotate-90',\n 'rotate-by',\n 'shake',\n 'spin-pulse',\n 'spin-reverse',\n 'spin',\n 'stack-1x',\n 'stack-2x',\n 'stack',\n 'ul',\n DUOTONE_CLASSES.GROUP,\n DUOTONE_CLASSES.SWAP_OPACITY,\n DUOTONE_CLASSES.PRIMARY,\n DUOTONE_CLASSES.SECONDARY\n]).concat(oneToTen.map(function(n) {\n return \"\".concat(n, \"x\");\n})).concat(oneToTwenty.map(function(n) {\n return \"w-\".concat(n);\n}));\nvar initial = WINDOW.FontAwesomeConfig || {\n};\nfunction getAttrConfig(attr) {\n var element = DOCUMENT.querySelector('script[' + attr + ']');\n if (element) return element.getAttribute(attr);\n}\nfunction coerce(val) {\n // Getting an empty string will occur if the attribute is set on the HTML tag but without a value\n // We'll assume that this is an indication that it should be toggled to true\n // For example <script data-search-pseudo-elements src=\"...\"></\\script>\n if (val === '') return true;\n if (val === 'false') return false;\n if (val === 'true') return true;\n return val;\n}\nif (DOCUMENT && typeof DOCUMENT.querySelector === 'function') {\n var attrs = [\n [\n 'data-family-prefix',\n 'familyPrefix'\n ],\n [\n 'data-style-default',\n 'styleDefault'\n ],\n [\n 'data-replacement-class',\n 'replacementClass'\n ],\n [\n 'data-auto-replace-svg',\n 'autoReplaceSvg'\n ],\n [\n 'data-auto-add-css',\n 'autoAddCss'\n ],\n [\n 'data-auto-a11y',\n 'autoA11y'\n ],\n [\n 'data-search-pseudo-elements',\n 'searchPseudoElements'\n ],\n [\n 'data-observe-mutations',\n 'observeMutations'\n ],\n [\n 'data-mutate-approach',\n 'mutateApproach'\n ],\n [\n 'data-keep-original-source',\n 'keepOriginalSource'\n ],\n [\n 'data-measure-performance',\n 'measurePerformance'\n ],\n [\n 'data-show-missing-icons',\n 'showMissingIcons'\n ]\n ];\n attrs.forEach(function(_ref1) {\n var _ref2 = _slicedToArray(_ref1, 2), attr = _ref2[0], key = _ref2[1];\n var val = coerce(getAttrConfig(attr));\n if (val !== undefined && val !== null) initial[key] = val;\n });\n}\nvar _default = {\n familyPrefix: DEFAULT_FAMILY_PREFIX,\n styleDefault: 'solid',\n replacementClass: DEFAULT_REPLACEMENT_CLASS,\n autoReplaceSvg: true,\n autoAddCss: true,\n autoA11y: true,\n searchPseudoElements: false,\n observeMutations: true,\n mutateApproach: 'async',\n keepOriginalSource: true,\n measurePerformance: false,\n showMissingIcons: true\n};\nvar _config = _objectSpread2(_objectSpread2({\n}, _default), initial);\nif (!_config.autoReplaceSvg) _config.observeMutations = false;\nvar config = {\n};\nObject.keys(_config).forEach(function(key) {\n Object.defineProperty(config, key, {\n enumerable: true,\n set: function set(val) {\n _config[key] = val;\n _onChangeCb.forEach(function(cb) {\n return cb(config);\n });\n },\n get: function get() {\n return _config[key];\n }\n });\n});\nWINDOW.FontAwesomeConfig = config;\nvar _onChangeCb = [];\nfunction onChange(cb) {\n _onChangeCb.push(cb);\n return function() {\n _onChangeCb.splice(_onChangeCb.indexOf(cb), 1);\n };\n}\nvar d = UNITS_IN_GRID;\nvar meaninglessTransform = {\n size: 16,\n x: 0,\n y: 0,\n rotate: 0,\n flipX: false,\n flipY: false\n};\nfunction insertCss(css1) {\n if (!css1 || !IS_DOM) return;\n var style = DOCUMENT.createElement('style');\n style.setAttribute('type', 'text/css');\n style.innerHTML = css1;\n var headChildren = DOCUMENT.head.childNodes;\n var beforeChild = null;\n for(var i = headChildren.length - 1; i > -1; i--){\n var child = headChildren[i];\n var tagName = (child.tagName || '').toUpperCase();\n if ([\n 'STYLE',\n 'LINK'\n ].indexOf(tagName) > -1) beforeChild = child;\n }\n DOCUMENT.head.insertBefore(style, beforeChild);\n return css1;\n}\nvar idPool = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';\nfunction nextUniqueId() {\n var size = 12;\n var id = '';\n while(size-- > 0)id += idPool[Math.random() * 62 | 0];\n return id;\n}\nfunction toArray(obj) {\n var array = [];\n for(var i = (obj || []).length >>> 0; i--;)array[i] = obj[i];\n return array;\n}\nfunction classArray(node) {\n if (node.classList) return toArray(node.classList);\n else return (node.getAttribute('class') || '').split(' ').filter(function(i) {\n return i;\n });\n}\nfunction htmlEscape(str) {\n return \"\".concat(str).replace(/&/g, '&amp;').replace(/\"/g, '&quot;').replace(/'/g, '&#39;').replace(/</g, '&lt;').replace(/>/g, '&gt;');\n}\nfunction joinAttributes(attributes) {\n return Object.keys(attributes || {\n }).reduce(function(acc, attributeName) {\n return acc + \"\".concat(attributeName, \"=\\\"\").concat(htmlEscape(attributes[attributeName]), \"\\\" \");\n }, '').trim();\n}\nfunction joinStyles(styles1) {\n return Object.keys(styles1 || {\n }).reduce(function(acc, styleName) {\n return acc + \"\".concat(styleName, \": \").concat(styles1[styleName].trim(), \";\");\n }, '');\n}\nfunction transformIsMeaningful(transform) {\n return transform.size !== meaninglessTransform.size || transform.x !== meaninglessTransform.x || transform.y !== meaninglessTransform.y || transform.rotate !== meaninglessTransform.rotate || transform.flipX || transform.flipY;\n}\nfunction transformForSvg(_ref2) {\n var transform = _ref2.transform, containerWidth = _ref2.containerWidth, iconWidth = _ref2.iconWidth;\n var outer = {\n transform: \"translate(\".concat(containerWidth / 2, \" 256)\")\n };\n var innerTranslate = \"translate(\".concat(transform.x * 32, \", \").concat(transform.y * 32, \") \");\n var innerScale = \"scale(\".concat(transform.size / 16 * (transform.flipX ? -1 : 1), \", \").concat(transform.size / 16 * (transform.flipY ? -1 : 1), \") \");\n var innerRotate = \"rotate(\".concat(transform.rotate, \" 0 0)\");\n var inner = {\n transform: \"\".concat(innerTranslate, \" \").concat(innerScale, \" \").concat(innerRotate)\n };\n var path = {\n transform: \"translate(\".concat(iconWidth / 2 * -1, \" -256)\")\n };\n return {\n outer: outer,\n inner: inner,\n path: path\n };\n}\nfunction transformForCss(_ref2) {\n var transform = _ref2.transform, _ref2$width = _ref2.width, width = _ref2$width === void 0 ? UNITS_IN_GRID : _ref2$width, _ref2$height = _ref2.height, height = _ref2$height === void 0 ? UNITS_IN_GRID : _ref2$height, _ref2$startCentered = _ref2.startCentered, startCentered = _ref2$startCentered === void 0 ? false : _ref2$startCentered;\n var val = '';\n if (startCentered && IS_IE) val += \"translate(\".concat(transform.x / d - width / 2, \"em, \").concat(transform.y / d - height / 2, \"em) \");\n else if (startCentered) val += \"translate(calc(-50% + \".concat(transform.x / d, \"em), calc(-50% + \").concat(transform.y / d, \"em)) \");\n else val += \"translate(\".concat(transform.x / d, \"em, \").concat(transform.y / d, \"em) \");\n val += \"scale(\".concat(transform.size / d * (transform.flipX ? -1 : 1), \", \").concat(transform.size / d * (transform.flipY ? -1 : 1), \") \");\n val += \"rotate(\".concat(transform.rotate, \"deg) \");\n return val;\n}\nvar baseStyles = \":root, :host {\\n --fa-font-solid: normal 900 1em/1 \\\"Font Awesome 6 Solid\\\";\\n --fa-font-regular: normal 400 1em/1 \\\"Font Awesome 6 Regular\\\";\\n --fa-font-light: normal 300 1em/1 \\\"Font Awesome 6 Light\\\";\\n --fa-font-thin: normal 100 1em/1 \\\"Font Awesome 6 Thin\\\";\\n --fa-font-duotone: normal 900 1em/1 \\\"Font Awesome 6 Duotone\\\";\\n --fa-font-brands: normal 400 1em/1 \\\"Font Awesome 6 Brands\\\";\\n}\\n\\nsvg:not(:root).svg-inline--fa, svg:not(:host).svg-inline--fa {\\n overflow: visible;\\n box-sizing: content-box;\\n}\\n\\n.svg-inline--fa {\\n display: var(--fa-display, inline-block);\\n height: 1em;\\n overflow: visible;\\n vertical-align: -0.125em;\\n}\\n.svg-inline--fa.fa-2xs {\\n vertical-align: 0.1em;\\n}\\n.svg-inline--fa.fa-xs {\\n vertical-align: 0em;\\n}\\n.svg-inline--fa.fa-sm {\\n vertical-align: -0.0714285705em;\\n}\\n.svg-inline--fa.fa-lg {\\n vertical-align: -0.2em;\\n}\\n.svg-inline--fa.fa-xl {\\n vertical-align: -0.25em;\\n}\\n.svg-inline--fa.fa-2xl {\\n vertical-align: -0.3125em;\\n}\\n.svg-inline--fa.fa-pull-left {\\n margin-right: var(--fa-pull-margin, 0.3em);\\n width: auto;\\n}\\n.svg-inline--fa.fa-pull-right {\\n margin-left: var(--fa-pull-margin, 0.3em);\\n width: auto;\\n}\\n.svg-inline--fa.fa-li {\\n width: var(--fa-li-width, 2em);\\n top: 0.25em;\\n}\\n.svg-inline--fa.fa-fw {\\n width: var(--fa-fw-width, 1.25em);\\n}\\n\\n.fa-layers svg.svg-inline--fa {\\n bottom: 0;\\n left: 0;\\n margin: auto;\\n position: absolute;\\n right: 0;\\n top: 0;\\n}\\n\\n.fa-layers-counter, .fa-layers-text {\\n display: inline-block;\\n position: absolute;\\n text-align: center;\\n}\\n\\n.fa-layers {\\n display: inline-block;\\n height: 1em;\\n position: relative;\\n text-align: center;\\n vertical-align: -0.125em;\\n width: 1em;\\n}\\n.fa-layers svg.svg-inline--fa {\\n -webkit-transform-origin: center center;\\n transform-origin: center center;\\n}\\n\\n.fa-layers-text {\\n left: 50%;\\n top: 50%;\\n -webkit-transform: translate(-50%, -50%);\\n transform: translate(-50%, -50%);\\n -webkit-transform-origin: center center;\\n transform-origin: center center;\\n}\\n\\n.fa-layers-counter {\\n background-color: var(--fa-counter-background-color, #ff253a);\\n border-radius: var(--fa-counter-border-radius, 1em);\\n box-sizing: border-box;\\n color: var(--fa-inverse, #fff);\\n line-height: var(--fa-counter-line-height, 1);\\n max-width: var(--fa-counter-max-width, 5em);\\n min-width: var(--fa-counter-min-width, 1.5em);\\n overflow: hidden;\\n padding: var(--fa-counter-padding, 0.25em 0.5em);\\n right: var(--fa-right, 0);\\n text-overflow: ellipsis;\\n top: var(--fa-top, 0);\\n -webkit-transform: scale(var(--fa-counter-scale, 0.25));\\n transform: scale(var(--fa-counter-scale, 0.25));\\n -webkit-transform-origin: top right;\\n transform-origin: top right;\\n}\\n\\n.fa-layers-bottom-right {\\n bottom: var(--fa-bottom, 0);\\n right: var(--fa-right, 0);\\n top: auto;\\n -webkit-transform: scale(var(--fa-layers-scale, 0.25));\\n transform: scale(var(--fa-layers-scale, 0.25));\\n -webkit-transform-origin: bottom right;\\n transform-origin: bottom right;\\n}\\n\\n.fa-layers-bottom-left {\\n bottom: var(--fa-bottom, 0);\\n left: var(--fa-left, 0);\\n right: auto;\\n top: auto;\\n -webkit-transform: scale(var(--fa-layers-scale, 0.25));\\n transform: scale(var(--fa-layers-scale, 0.25));\\n -webkit-transform-origin: bottom left;\\n transform-origin: bottom left;\\n}\\n\\n.fa-layers-top-right {\\n top: var(--fa-top, 0);\\n right: var(--fa-right, 0);\\n -webkit-transform: scale(var(--fa-layers-scale, 0.25));\\n transform: scale(var(--fa-layers-scale, 0.25));\\n -webkit-transform-origin: top right;\\n transform-origin: top right;\\n}\\n\\n.fa-layers-top-left {\\n left: var(--fa-left, 0);\\n right: auto;\\n top: var(--fa-top, 0);\\n -webkit-transform: scale(var(--fa-layers-scale, 0.25));\\n transform: scale(var(--fa-layers-scale, 0.25));\\n -webkit-transform-origin: top left;\\n transform-origin: top left;\\n}\\n\\n.fa-1x {\\n font-size: 1em;\\n}\\n\\n.fa-2x {\\n font-size: 2em;\\n}\\n\\n.fa-3x {\\n font-size: 3em;\\n}\\n\\n.fa-4x {\\n font-size: 4em;\\n}\\n\\n.fa-5x {\\n font-size: 5em;\\n}\\n\\n.fa-6x {\\n font-size: 6em;\\n}\\n\\n.fa-7x {\\n font-size: 7em;\\n}\\n\\n.fa-8x {\\n font-size: 8em;\\n}\\n\\n.fa-9x {\\n font-size: 9em;\\n}\\n\\n.fa-10x {\\n font-size: 10em;\\n}\\n\\n.fa-2xs {\\n font-size: 0.625em;\\n line-height: 0.1em;\\n vertical-align: 0.225em;\\n}\\n\\n.fa-xs {\\n font-size: 0.75em;\\n line-height: 0.0833333337em;\\n vertical-align: 0.125em;\\n}\\n\\n.fa-sm {\\n font-size: 0.875em;\\n line-height: 0.0714285718em;\\n vertical-align: 0.0535714295em;\\n}\\n\\n.fa-lg {\\n font-size: 1.25em;\\n line-height: 0.05em;\\n vertical-align: -0.075em;\\n}\\n\\n.fa-xl {\\n font-size: 1.5em;\\n line-height: 0.0416666682em;\\n vertical-align: -0.125em;\\n}\\n\\n.fa-2xl {\\n font-size: 2em;\\n line-height: 0.03125em;\\n vertical-align: -0.1875em;\\n}\\n\\n.fa-fw {\\n text-align: center;\\n width: 1.25em;\\n}\\n\\n.fa-ul {\\n list-style-type: none;\\n margin-left: var(--fa-li-margin, 2.5em);\\n padding-left: 0;\\n}\\n.fa-ul > li {\\n position: relative;\\n}\\n\\n.fa-li {\\n left: calc(var(--fa-li-width, 2em) * -1);\\n position: absolute;\\n text-align: center;\\n width: var(--fa-li-width, 2em);\\n line-height: inherit;\\n}\\n\\n.fa-border {\\n border-color: var(--fa-border-color, #eee);\\n border-radius: var(--fa-border-radius, 0.1em);\\n border-style: var(--fa-border-style, solid);\\n border-width: var(--fa-border-width, 0.08em);\\n padding: var(--fa-border-padding, 0.2em 0.25em 0.15em);\\n}\\n\\n.fa-pull-left {\\n float: left;\\n margin-right: var(--fa-pull-margin, 0.3em);\\n}\\n\\n.fa-pull-right {\\n float: right;\\n margin-left: var(--fa-pull-margin, 0.3em);\\n}\\n\\n.fa-beat {\\n -webkit-animation-name: fa-beat;\\n animation-name: fa-beat;\\n -webkit-animation-delay: var(--fa-animation-delay, 0);\\n animation-delay: var(--fa-animation-delay, 0);\\n -webkit-animation-direction: var(--fa-animation-direction, normal);\\n animation-direction: var(--fa-animation-direction, normal);\\n -webkit-animation-duration: var(--fa-animation-duration, 1s);\\n animation-duration: var(--fa-animation-duration, 1s);\\n -webkit-animation-iteration-count: var(--fa-animation-iteration-count, infinite);\\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\\n -webkit-animation-timing-function: var(--fa-animation-timing, ease-in-out);\\n animation-timing-function: var(--fa-animation-timing, ease-in-out);\\n}\\n\\n.fa-bounce {\\n -webkit-animation-name: fa-bounce;\\n animation-name: fa-bounce;\\n -webkit-animation-delay: var(--fa-animation-delay, 0);\\n animation-delay: var(--fa-animation-delay, 0);\\n -webkit-animation-direction: var(--fa-animation-direction, normal);\\n animation-direction: var(--fa-animation-direction, normal);\\n -webkit-animation-duration: var(--fa-animation-duration, 1s);\\n animation-duration: var(--fa-animation-duration, 1s);\\n -webkit-animation-iteration-count: var(--fa-animation-iteration-count, infinite);\\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\\n -webkit-animation-timing-function: var(--fa-animation-timing, cubic-bezier(0.28, 0.84, 0.42, 1));\\n animation-timing-function: var(--fa-animation-timing, cubic-bezier(0.28, 0.84, 0.42, 1));\\n}\\n\\n.fa-fade {\\n -webkit-animation-name: fa-fade;\\n animation-name: fa-fade;\\n -webkit-animation-delay: var(--fa-animation-delay, 0);\\n animation-delay: var(--fa-animation-delay, 0);\\n -webkit-animation-direction: var(--fa-animation-direction, normal);\\n animation-direction: var(--fa-animation-direction, normal);\\n -webkit-animation-duration: var(--fa-animation-duration, 1s);\\n animation-duration: var(--fa-animation-duration, 1s);\\n -webkit-animation-iteration-count: var(--fa-animation-iteration-count, infinite);\\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\\n -webkit-animation-timing-function: var(--fa-animation-timing, cubic-bezier(0.4, 0, 0.6, 1));\\n animation-timing-function: var(--fa-animation-timing, cubic-bezier(0.4, 0, 0.6, 1));\\n}\\n\\n.fa-beat-fade {\\n -webkit-animation-name: fa-beat-fade;\\n animation-name: fa-beat-fade;\\n -webkit-animation-delay: var(--fa-animation-delay, 0);\\n animation-delay: var(--fa-animation-delay, 0);\\n -webkit-animation-direction: var(--fa-animation-direction, normal);\\n animation-direction: var(--fa-animation-direction, normal);\\n -webkit-animation-duration: var(--fa-animation-duration, 1s);\\n animation-duration: var(--fa-animation-duration, 1s);\\n -webkit-animation-iteration-count: var(--fa-animation-iteration-count, infinite);\\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\\n -webkit-animation-timing-function: var(--fa-animation-timing, cubic-bezier(0.4, 0, 0.6, 1));\\n animation-timing-function: var(--fa-animation-timing, cubic-bezier(0.4, 0, 0.6, 1));\\n}\\n\\n.fa-flip {\\n -webkit-animation-name: fa-flip;\\n animation-name: fa-flip;\\n -webkit-animation-delay: var(--fa-animation-delay, 0);\\n animation-delay: var(--fa-animation-delay, 0);\\n -webkit-animation-direction: var(--fa-animation-direction, normal);\\n animation-direction: var(--fa-animation-direction, normal);\\n -webkit-animation-duration: var(--fa-animation-duration, 1s);\\n animation-duration: var(--fa-animation-duration, 1s);\\n -webkit-animation-iteration-count: var(--fa-animation-iteration-count, infinite);\\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\\n -webkit-animation-timing-function: var(--fa-animation-timing, ease-in-out);\\n animation-timing-function: var(--fa-animation-timing, ease-in-out);\\n}\\n\\n.fa-shake {\\n -webkit-animation-name: fa-shake;\\n animation-name: fa-shake;\\n -webkit-animation-delay: var(--fa-animation-delay, 0);\\n animation-delay: var(--fa-animation-delay, 0);\\n -webkit-animation-direction: var(--fa-animation-direction, normal);\\n animation-direction: var(--fa-animation-direction, normal);\\n -webkit-animation-duration: var(--fa-animation-duration, 1s);\\n animation-duration: var(--fa-animation-duration, 1s);\\n -webkit-animation-iteration-count: var(--fa-animation-iteration-count, infinite);\\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\\n -webkit-animation-timing-function: var(--fa-animation-timing, linear);\\n animation-timing-function: var(--fa-animation-timing, linear);\\n}\\n\\n.fa-spin {\\n -webkit-animation-name: fa-spin;\\n animation-name: fa-spin;\\n -webkit-animation-delay: var(--fa-animation-delay, 0);\\n animation-delay: var(--fa-animation-delay, 0);\\n -webkit-animation-direction: var(--fa-animation-direction, normal);\\n animation-direction: var(--fa-animation-direction, normal);\\n -webkit-animation-duration: var(--fa-animation-duration, 2s);\\n animation-duration: var(--fa-animation-duration, 2s);\\n -webkit-animation-iteration-count: var(--fa-animation-iteration-count, infinite);\\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\\n -webkit-animation-timing-function: var(--fa-animation-timing, linear);\\n animation-timing-function: var(--fa-animation-timing, linear);\\n}\\n\\n.fa-spin-reverse {\\n --fa-animation-direction: reverse;\\n}\\n\\n.fa-pulse,\\n.fa-spin-pulse {\\n -webkit-animation-name: fa-spin;\\n animation-name: fa-spin;\\n -webkit-animation-direction: var(--fa-animation-direction, normal);\\n animation-direction: var(--fa-animation-direction, normal);\\n -webkit-animation-duration: var(--fa-animation-duration, 1s);\\n animation-duration: var(--fa-animation-duration, 1s);\\n -webkit-animation-iteration-count: var(--fa-animation-iteration-count, infinite);\\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\\n -webkit-animation-timing-function: var(--fa-animation-timing, steps(8));\\n animation-timing-function: var(--fa-animation-timing, steps(8));\\n}\\n\\n@media (prefers-reduced-motion: reduce) {\\n .fa-beat,\\n.fa-bounce,\\n.fa-fade,\\n.fa-beat-fade,\\n.fa-flip,\\n.fa-pulse,\\n.fa-shake,\\n.fa-spin,\\n.fa-spin-pulse {\\n -webkit-animation-delay: -1ms;\\n animation-delay: -1ms;\\n -webkit-animation-duration: 1ms;\\n animation-duration: 1ms;\\n -webkit-animation-iteration-count: 1;\\n animation-iteration-count: 1;\\n transition-delay: 0s;\\n transition-duration: 0s;\\n }\\n}\\n@-webkit-keyframes fa-beat {\\n 0%, 90% {\\n -webkit-transform: scale(1);\\n transform: scale(1);\\n }\\n 45% {\\n -webkit-transform: scale(var(--fa-beat-scale, 1.25));\\n transform: scale(var(--fa-beat-scale, 1.25));\\n }\\n}\\n@keyframes fa-beat {\\n 0%, 90% {\\n -webkit-transform: scale(1);\\n transform: scale(1);\\n }\\n 45% {\\n -webkit-transform: scale(var(--fa-beat-scale, 1.25));\\n transform: scale(var(--fa-beat-scale, 1.25));\\n }\\n}\\n@-webkit-keyframes fa-bounce {\\n 0% {\\n -webkit-transform: scale(1, 1) translateY(0);\\n transform: scale(1, 1) translateY(0);\\n }\\n 10% {\\n -webkit-transform: scale(var(--fa-bounce-start-scale-x, 1.1), var(--fa-bounce-start-scale-y, 0.9)) translateY(0);\\n transform: scale(var(--fa-bounce-start-scale-x, 1.1), var(--fa-bounce-start-scale-y, 0.9)) translateY(0);\\n }\\n 30% {\\n -webkit-transform: scale(var(--fa-bounce-jump-scale-x, 0.9), var(--fa-bounce-jump-scale-y, 1.1)) translateY(var(--fa-bounce-height, -0.5em));\\n transform: scale(var(--fa-bounce-jump-scale-x, 0.9), var(--fa-bounce-jump-scale-y, 1.1)) translateY(var(--fa-bounce-height, -0.5em));\\n }\\n 50% {\\n -webkit-transform: scale(var(--fa-bounce-land-scale-x, 1.05), var(--fa-bounce-land-scale-y, 0.95)) translateY(0);\\n transform: scale(var(--fa-bounce-land-scale-x, 1.05), var(--fa-bounce-land-scale-y, 0.95)) translateY(0);\\n }\\n 57% {\\n -webkit-transform: scale(1, 1) translateY(var(--fa-bounce-rebound, -0.125em));\\n transform: scale(1, 1) translateY(var(--fa-bounce-rebound, -0.125em));\\n }\\n 64% {\\n -webkit-transform: scale(1, 1) translateY(0);\\n transform: scale(1, 1) translateY(0);\\n }\\n 100% {\\n -webkit-transform: scale(1, 1) translateY(0);\\n transform: scale(1, 1) translateY(0);\\n }\\n}\\n@keyframes fa-bounce {\\n 0% {\\n -webkit-transform: scale(1, 1) translateY(0);\\n transform: scale(1, 1) translateY(0);\\n }\\n 10% {\\n -webkit-transform: scale(var(--fa-bounce-start-scale-x, 1.1), var(--fa-bounce-start-scale-y, 0.9)) translateY(0);\\n transform: scale(var(--fa-bounce-start-scale-x, 1.1), var(--fa-bounce-start-scale-y, 0.9)) translateY(0);\\n }\\n 30% {\\n -webkit-transform: scale(var(--fa-bounce-jump-scale-x, 0.9), var(--fa-bounce-jump-scale-y, 1.1)) translateY(var(--fa-bounce-height, -0.5em));\\n transform: scale(var(--fa-bounce-jump-scale-x, 0.9), var(--fa-bounce-jump-scale-y, 1.1)) translateY(var(--fa-bounce-height, -0.5em));\\n }\\n 50% {\\n -webkit-transform: scale(var(--fa-bounce-land-scale-x, 1.05), var(--fa-bounce-land-scale-y, 0.95)) translateY(0);\\n transform: scale(var(--fa-bounce-land-scale-x, 1.05), var(--fa-bounce-land-scale-y, 0.95)) translateY(0);\\n }\\n 57% {\\n -webkit-transform: scale(1, 1) translateY(var(--fa-bounce-rebound, -0.125em));\\n transform: scale(1, 1) translateY(var(--fa-bounce-rebound, -0.125em));\\n }\\n 64% {\\n -webkit-transform: scale(1, 1) translateY(0);\\n transform: scale(1, 1) translateY(0);\\n }\\n 100% {\\n -webkit-transform: scale(1, 1) translateY(0);\\n transform: scale(1, 1) translateY(0);\\n }\\n}\\n@-webkit-keyframes fa-fade {\\n 50% {\\n opacity: var(--fa-fade-opacity, 0.4);\\n }\\n}\\n@keyframes fa-fade {\\n 50% {\\n opacity: var(--fa-fade-opacity, 0.4);\\n }\\n}\\n@-webkit-keyframes fa-beat-fade {\\n 0%, 100% {\\n opacity: var(--fa-beat-fade-opacity, 0.4);\\n -webkit-transform: scale(1);\\n transform: scale(1);\\n }\\n 50% {\\n opacity: 1;\\n -webkit-transform: scale(var(--fa-beat-fade-scale, 1.125));\\n transform: scale(var(--fa-beat-fade-scale, 1.125));\\n }\\n}\\n@keyframes fa-beat-fade {\\n 0%, 100% {\\n opacity: var(--fa-beat-fade-opacity, 0.4);\\n -webkit-transform: scale(1);\\n transform: scale(1);\\n }\\n 50% {\\n opacity: 1;\\n -webkit-transform: scale(var(--fa-beat-fade-scale, 1.125));\\n transform: scale(var(--fa-beat-fade-scale, 1.125));\\n }\\n}\\n@-webkit-keyframes fa-flip {\\n 50% {\\n -webkit-transform: rotate3d(var(--fa-flip-x, 0), var(--fa-flip-y, 1), var(--fa-flip-z, 0), var(--fa-flip-angle, -180deg));\\n transform: rotate3d(var(--fa-flip-x, 0), var(--fa-flip-y, 1), var(--fa-flip-z, 0), var(--fa-flip-angle, -180deg));\\n }\\n}\\n@keyframes fa-flip {\\n 50% {\\n -webkit-transform: rotate3d(var(--fa-flip-x, 0), var(--fa-flip-y, 1), var(--fa-flip-z, 0), var(--fa-flip-angle, -180deg));\\n transform: rotate3d(var(--fa-flip-x, 0), var(--fa-flip-y, 1), var(--fa-flip-z, 0), var(--fa-flip-angle, -180deg));\\n }\\n}\\n@-webkit-keyframes fa-shake {\\n 0% {\\n -webkit-transform: rotate(-15deg);\\n transform: rotate(-15deg);\\n }\\n 4% {\\n -webkit-transform: rotate(15deg);\\n transform: rotate(15deg);\\n }\\n 8%, 24% {\\n -webkit-transform: rotate(-18deg);\\n transform: rotate(-18deg);\\n }\\n 12%, 28% {\\n -webkit-transform: rotate(18deg);\\n transform: rotate(18deg);\\n }\\n 16% {\\n -webkit-transform: rotate(-22deg);\\n transform: rotate(-22deg);\\n }\\n 20% {\\n -webkit-transform: rotate(22deg);\\n transform: rotate(22deg);\\n }\\n 32% {\\n -webkit-transform: rotate(-12deg);\\n transform: rotate(-12deg);\\n }\\n 36% {\\n -webkit-transform: rotate(12deg);\\n transform: rotate(12deg);\\n }\\n 40%, 100% {\\n -webkit-transform: rotate(0deg);\\n transform: rotate(0deg);\\n }\\n}\\n@keyframes fa-shake {\\n 0% {\\n -webkit-transform: rotate(-15deg);\\n transform: rotate(-15deg);\\n }\\n 4% {\\n -webkit-transform: rotate(15deg);\\n transform: rotate(15deg);\\n }\\n 8%, 24% {\\n -webkit-transform: rotate(-18deg);\\n transform: rotate(-18deg);\\n }\\n 12%, 28% {\\n -webkit-transform: rotate(18deg);\\n transform: rotate(18deg);\\n }\\n 16% {\\n -webkit-transform: rotate(-22deg);\\n transform: rotate(-22deg);\\n }\\n 20% {\\n -webkit-transform: rotate(22deg);\\n transform: rotate(22deg);\\n }\\n 32% {\\n -webkit-transform: rotate(-12deg);\\n transform: rotate(-12deg);\\n }\\n 36% {\\n -webkit-transform: rotate(12deg);\\n transform: rotate(12deg);\\n }\\n 40%, 100% {\\n -webkit-transform: rotate(0deg);\\n transform: rotate(0deg);\\n }\\n}\\n@-webkit-keyframes fa-spin {\\n 0% {\\n -webkit-transform: rotate(0deg);\\n transform: rotate(0deg);\\n }\\n 100% {\\n -webkit-transform: rotate(360deg);\\n transform: rotate(360deg);\\n }\\n}\\n@keyframes fa-spin {\\n 0% {\\n -webkit-transform: rotate(0deg);\\n transform: rotate(0deg);\\n }\\n 100% {\\n -webkit-transform: rotate(360deg);\\n transform: rotate(360deg);\\n }\\n}\\n.fa-rotate-90 {\\n -webkit-transform: rotate(90deg);\\n transform: rotate(90deg);\\n}\\n\\n.fa-rotate-180 {\\n -webkit-transform: rotate(180deg);\\n transform: rotate(180deg);\\n}\\n\\n.fa-rotate-270 {\\n -webkit-transform: rotate(270deg);\\n transform: rotate(270deg);\\n}\\n\\n.fa-flip-horizontal {\\n -webkit-transform: scale(-1, 1);\\n transform: scale(-1, 1);\\n}\\n\\n.fa-flip-vertical {\\n -webkit-transform: scale(1, -1);\\n transform: scale(1, -1);\\n}\\n\\n.fa-flip-both,\\n.fa-flip-horizontal.fa-flip-vertical {\\n -webkit-transform: scale(-1, -1);\\n transform: scale(-1, -1);\\n}\\n\\n.fa-rotate-by {\\n -webkit-transform: rotate(var(--fa-rotate-angle, none));\\n transform: rotate(var(--fa-rotate-angle, none));\\n}\\n\\n.fa-stack {\\n display: inline-block;\\n vertical-align: middle;\\n height: 2em;\\n position: relative;\\n width: 2.5em;\\n}\\n\\n.fa-stack-1x,\\n.fa-stack-2x {\\n bottom: 0;\\n left: 0;\\n margin: auto;\\n position: absolute;\\n right: 0;\\n top: 0;\\n z-index: var(--fa-stack-z-index, auto);\\n}\\n\\n.svg-inline--fa.fa-stack-1x {\\n height: 1em;\\n width: 1.25em;\\n}\\n.svg-inline--fa.fa-stack-2x {\\n height: 2em;\\n width: 2.5em;\\n}\\n\\n.fa-inverse {\\n color: var(--fa-inverse, #fff);\\n}\\n\\n.sr-only,\\n.fa-sr-only {\\n position: absolute;\\n width: 1px;\\n height: 1px;\\n padding: 0;\\n margin: -1px;\\n overflow: hidden;\\n clip: rect(0, 0, 0, 0);\\n white-space: nowrap;\\n border-width: 0;\\n}\\n\\n.sr-only-focusable:not(:focus),\\n.fa-sr-only-focusable:not(:focus) {\\n position: absolute;\\n width: 1px;\\n height: 1px;\\n padding: 0;\\n margin: -1px;\\n overflow: hidden;\\n clip: rect(0, 0, 0, 0);\\n white-space: nowrap;\\n border-width: 0;\\n}\\n\\n.svg-inline--fa .fa-primary {\\n fill: var(--fa-primary-color, currentColor);\\n opacity: var(--fa-primary-opacity, 1);\\n}\\n\\n.svg-inline--fa .fa-secondary {\\n fill: var(--fa-secondary-color, currentColor);\\n opacity: var(--fa-secondary-opacity, 0.4);\\n}\\n\\n.svg-inline--fa.fa-swap-opacity .fa-primary {\\n opacity: var(--fa-secondary-opacity, 0.4);\\n}\\n\\n.svg-inline--fa.fa-swap-opacity .fa-secondary {\\n opacity: var(--fa-primary-opacity, 1);\\n}\\n\\n.svg-inline--fa mask .fa-primary,\\n.svg-inline--fa mask .fa-secondary {\\n fill: black;\\n}\\n\\n.fad.fa-inverse,\\n.fa-duotone.fa-inverse {\\n color: var(--fa-inverse, #fff);\\n}\";\nfunction css() {\n var dfp = DEFAULT_FAMILY_PREFIX;\n var drc = DEFAULT_REPLACEMENT_CLASS;\n var fp = config.familyPrefix;\n var rc = config.replacementClass;\n var s = baseStyles;\n if (fp !== dfp || rc !== drc) {\n var dPatt = new RegExp(\"\\\\.\".concat(dfp, \"\\\\-\"), 'g');\n var customPropPatt = new RegExp(\"\\\\--\".concat(dfp, \"\\\\-\"), 'g');\n var rPatt = new RegExp(\"\\\\.\".concat(drc), 'g');\n s = s.replace(dPatt, \".\".concat(fp, \"-\")).replace(customPropPatt, \"--\".concat(fp, \"-\")).replace(rPatt, \".\".concat(rc));\n }\n return s;\n}\nvar _cssInserted = false;\nfunction ensureCss() {\n if (config.autoAddCss && !_cssInserted) {\n insertCss(css());\n _cssInserted = true;\n }\n}\nvar InjectCSS = {\n mixout: function mixout() {\n return {\n dom: {\n css: css,\n insertCss: ensureCss\n }\n };\n },\n hooks: function hooks() {\n return {\n beforeDOMElementCreation: function beforeDOMElementCreation() {\n ensureCss();\n },\n beforeI2svg: function beforeI2svg() {\n ensureCss();\n }\n };\n }\n};\nvar w = WINDOW || {\n};\nif (!w[NAMESPACE_IDENTIFIER]) w[NAMESPACE_IDENTIFIER] = {\n};\nif (!w[NAMESPACE_IDENTIFIER].styles) w[NAMESPACE_IDENTIFIER].styles = {\n};\nif (!w[NAMESPACE_IDENTIFIER].hooks) w[NAMESPACE_IDENTIFIER].hooks = {\n};\nif (!w[NAMESPACE_IDENTIFIER].shims) w[NAMESPACE_IDENTIFIER].shims = [];\nvar namespace = w[NAMESPACE_IDENTIFIER];\nvar functions = [];\nvar listener = function listener1() {\n DOCUMENT.removeEventListener('DOMContentLoaded', listener1);\n loaded = 1;\n functions.map(function(fn) {\n return fn();\n });\n};\nvar loaded = false;\nif (IS_DOM) {\n loaded = (DOCUMENT.documentElement.doScroll ? /^loaded|^c/ : /^loaded|^i|^c/).test(DOCUMENT.readyState);\n if (!loaded) DOCUMENT.addEventListener('DOMContentLoaded', listener);\n}\nfunction domready(fn) {\n if (!IS_DOM) return;\n loaded ? setTimeout(fn, 0) : functions.push(fn);\n}\nfunction toHtml(abstractNodes) {\n var tag = abstractNodes.tag, _abstractNodes$attrib = abstractNodes.attributes, attributes = _abstractNodes$attrib === void 0 ? {\n } : _abstractNodes$attrib, _abstractNodes$childr = abstractNodes.children, children = _abstractNodes$childr === void 0 ? [] : _abstractNodes$childr;\n if (typeof abstractNodes === 'string') return htmlEscape(abstractNodes);\n else return \"<\".concat(tag, \" \").concat(joinAttributes(attributes), \">\").concat(children.map(toHtml).join(''), \"</\").concat(tag, \">\");\n}\nfunction iconFromMapping(mapping, prefix, iconName) {\n if (mapping && mapping[prefix] && mapping[prefix][iconName]) return {\n prefix: prefix,\n iconName: iconName,\n icon: mapping[prefix][iconName]\n };\n}\n/**\n * Internal helper to bind a function known to have 4 arguments\n * to a given context.\n */ var bindInternal4 = function bindInternal4(func, thisContext) {\n return function(a, b, c, d1) {\n return func.call(thisContext, a, b, c, d1);\n };\n};\n/**\n * # Reduce\n *\n * A fast object `.reduce()` implementation.\n *\n * @param {Object} subject The object to reduce over.\n * @param {Function} fn The reducer function.\n * @param {mixed} initialValue The initial value for the reducer, defaults to subject[0].\n * @param {Object} thisContext The context for the reducer.\n * @return {mixed} The final result.\n */ var reduce = function fastReduceObject(subject, fn, initialValue, thisContext) {\n var keys = Object.keys(subject), length = keys.length, iterator = thisContext !== undefined ? bindInternal4(fn, thisContext) : fn, i, key, result;\n if (initialValue === undefined) {\n i = 1;\n result = subject[keys[0]];\n } else {\n i = 0;\n result = initialValue;\n }\n for(; i < length; i++){\n key = keys[i];\n result = iterator(result, subject[key], key, subject);\n }\n return result;\n};\n/**\n * ucs2decode() and codePointAt() are both works of Mathias Bynens and licensed under MIT\n *\n * Copyright Mathias Bynens <https://mathiasbynens.be/>\n\n * Permission is hereby granted, free of charge, to any person obtaining\n * a copy of this software and associated documentation files (the\n * \"Software\"), to deal in the Software without restriction, including\n * without limitation the rights to use, copy, modify, merge, publish,\n * distribute, sublicense, and/or sell copies of the Software, and to\n * permit persons to whom the Software is furnished to do so, subject to\n * the following conditions:\n\n * The above copyright notice and this permission notice shall be\n * included in all copies or substantial portions of the Software.\n\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND,\n * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND\n * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE\n * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION\n * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION\n * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n */ function ucs2decode(string) {\n var output = [];\n var counter1 = 0;\n var length = string.length;\n while(counter1 < length){\n var value = string.charCodeAt(counter1++);\n if (value >= 55296 && value <= 56319 && counter1 < length) {\n var extra = string.charCodeAt(counter1++);\n if ((extra & 64512) == 56320) // eslint-disable-line eqeqeq\n output.push(((value & 1023) << 10) + (extra & 1023) + 65536);\n else {\n output.push(value);\n counter1--;\n }\n } else output.push(value);\n }\n return output;\n}\nfunction toHex(unicode) {\n var decoded = ucs2decode(unicode);\n return decoded.length === 1 ? decoded[0].toString(16) : null;\n}\nfunction codePointAt(string, index) {\n var size = string.length;\n var first = string.charCodeAt(index);\n var second;\n if (first >= 55296 && first <= 56319 && size > index + 1) {\n second = string.charCodeAt(index + 1);\n if (second >= 56320 && second <= 57343) return (first - 55296) * 1024 + second - 56320 + 65536;\n }\n return first;\n}\nfunction normalizeIcons(icons) {\n return Object.keys(icons).reduce(function(acc, iconName) {\n var icon1 = icons[iconName];\n var expanded = !!icon1.icon;\n if (expanded) acc[icon1.iconName] = icon1.icon;\n else acc[iconName] = icon1;\n return acc;\n }, {\n });\n}\nfunction defineIcons(prefix, icons) {\n var params = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {\n };\n var _params$skipHooks = params.skipHooks, skipHooks = _params$skipHooks === void 0 ? false : _params$skipHooks;\n var normalized = normalizeIcons(icons);\n if (typeof namespace.hooks.addPack === 'function' && !skipHooks) namespace.hooks.addPack(prefix, normalizeIcons(icons));\n else namespace.styles[prefix] = _objectSpread2(_objectSpread2({\n }, namespace.styles[prefix] || {\n }), normalized);\n /**\n * Font Awesome 4 used the prefix of `fa` for all icons. With the introduction\n * of new styles we needed to differentiate between them. Prefix `fa` is now an alias\n * for `fas` so we'll ease the upgrade process for our users by automatically defining\n * this as well.\n */ if (prefix === 'fas') defineIcons('fa', icons);\n}\nvar duotonePathRe = [\n /*#__PURE__*/ _wrapRegExp(/path d=\"((?:(?!\")[\\s\\S])+)\".*path d=\"((?:(?!\")[\\s\\S])+)\"/, {\n d1: 1,\n d2: 2\n }),\n /*#__PURE__*/ _wrapRegExp(/path class=\"((?:(?!\")[\\s\\S])+)\".*d=\"((?:(?!\")[\\s\\S])+)\".*path class=\"((?:(?!\")[\\s\\S])+)\".*d=\"((?:(?!\")[\\s\\S])+)\"/, {\n cls1: 1,\n d1: 2,\n cls2: 3,\n d2: 4\n }),\n /*#__PURE__*/ _wrapRegExp(/path class=\"((?:(?!\")[\\s\\S])+)\".*d=\"((?:(?!\")[\\s\\S])+)\"/, {\n cls1: 1,\n d1: 2\n })\n];\nvar styles = namespace.styles, shims = namespace.shims;\nvar LONG_STYLE = Object.values(PREFIX_TO_LONG_STYLE);\nvar _defaultUsablePrefix = null;\nvar _byUnicode = {\n};\nvar _byLigature = {\n};\nvar _byOldName = {\n};\nvar _byOldUnicode = {\n};\nvar _byAlias = {\n};\nvar PREFIXES = Object.keys(PREFIX_TO_STYLE);\nfunction isReserved(name) {\n return ~RESERVED_CLASSES.indexOf(name);\n}\nfunction getIconName(familyPrefix, cls) {\n var parts = cls.split('-');\n var prefix = parts[0];\n var iconName = parts.slice(1).join('-');\n if (prefix === familyPrefix && iconName !== '' && !isReserved(iconName)) return iconName;\n else return null;\n}\nvar build = function build() {\n var lookup = function lookup(reducer) {\n return reduce(styles, function(o, style, prefix) {\n o[prefix] = reduce(style, reducer, {\n });\n return o;\n }, {\n });\n };\n _byUnicode = lookup(function(acc, icon2, iconName) {\n if (icon2[3]) acc[icon2[3]] = iconName;\n if (icon2[2]) {\n var aliases = icon2[2].filter(function(a) {\n return typeof a === 'number';\n });\n aliases.forEach(function(alias) {\n acc[alias.toString(16)] = iconName;\n });\n }\n return acc;\n });\n _byLigature = lookup(function(acc, icon3, iconName) {\n acc[iconName] = iconName;\n if (icon3[2]) {\n var aliases = icon3[2].filter(function(a) {\n return typeof a === 'string';\n });\n aliases.forEach(function(alias) {\n acc[alias] = iconName;\n });\n }\n return acc;\n });\n _byAlias = lookup(function(acc, icon4, iconName) {\n var aliases = icon4[2];\n acc[iconName] = iconName;\n aliases.forEach(function(alias) {\n acc[alias] = iconName;\n });\n return acc;\n }); // If we have a Kit, we can't determine if regular is available since we\n // could be auto-fetching it. We'll have to assume that it is available.\n var hasRegular = 'far' in styles || config.autoFetchSvg;\n var shimLookups = reduce(shims, function(acc, shim) {\n var maybeNameMaybeUnicode = shim[0];\n var prefix = shim[1];\n var iconName = shim[2];\n if (prefix === 'far' && !hasRegular) prefix = 'fas';\n if (typeof maybeNameMaybeUnicode === 'string') acc.names[maybeNameMaybeUnicode] = {\n prefix: prefix,\n iconName: iconName\n };\n if (typeof maybeNameMaybeUnicode === 'number') acc.unicodes[maybeNameMaybeUnicode.toString(16)] = {\n prefix: prefix,\n iconName: iconName\n };\n return acc;\n }, {\n names: {\n },\n unicodes: {\n }\n });\n _byOldName = shimLookups.names;\n _byOldUnicode = shimLookups.unicodes;\n _defaultUsablePrefix = getCanonicalPrefix(config.styleDefault);\n};\nonChange(function(c) {\n _defaultUsablePrefix = getCanonicalPrefix(c.styleDefault);\n});\nbuild();\nfunction byUnicode(prefix, unicode) {\n return (_byUnicode[prefix] || {\n })[unicode];\n}\nfunction byLigature(prefix, ligature) {\n return (_byLigature[prefix] || {\n })[ligature];\n}\nfunction byAlias(prefix, alias) {\n return (_byAlias[prefix] || {\n })[alias];\n}\nfunction byOldName(name) {\n return _byOldName[name] || {\n prefix: null,\n iconName: null\n };\n}\nfunction byOldUnicode(unicode) {\n var oldUnicode = _byOldUnicode[unicode];\n var newUnicode = byUnicode('fas', unicode);\n return oldUnicode || (newUnicode ? {\n prefix: 'fas',\n iconName: newUnicode\n } : null) || {\n prefix: null,\n iconName: null\n };\n}\nfunction getDefaultUsablePrefix() {\n return _defaultUsablePrefix;\n}\nvar emptyCanonicalIcon = function emptyCanonicalIcon() {\n return {\n prefix: null,\n iconName: null,\n rest: []\n };\n};\nfunction getCanonicalPrefix(styleOrPrefix) {\n var style = PREFIX_TO_STYLE[styleOrPrefix];\n var prefix = STYLE_TO_PREFIX[styleOrPrefix] || STYLE_TO_PREFIX[style];\n var defined = styleOrPrefix in namespace.styles ? styleOrPrefix : null;\n return prefix || defined || null;\n}\nfunction getCanonicalIcon(values) {\n var params = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n };\n var _params$skipLookups = params.skipLookups, skipLookups = _params$skipLookups === void 0 ? false : _params$skipLookups;\n var givenPrefix = null;\n var canonical = values.reduce(function(acc, cls) {\n var iconName = getIconName(config.familyPrefix, cls);\n if (styles[cls]) {\n cls = LONG_STYLE.includes(cls) ? LONG_STYLE_TO_PREFIX[cls] : cls;\n givenPrefix = cls;\n acc.prefix = cls;\n } else if (PREFIXES.indexOf(cls) > -1) {\n givenPrefix = cls;\n acc.prefix = getCanonicalPrefix(cls);\n } else if (iconName) acc.iconName = iconName;\n else if (cls !== config.replacementClass) acc.rest.push(cls);\n if (!skipLookups && acc.prefix && acc.iconName) {\n var shim = givenPrefix === 'fa' ? byOldName(acc.iconName) : {\n };\n var aliasIconName = byAlias(acc.prefix, acc.iconName);\n if (shim.prefix) givenPrefix = null;\n acc.iconName = shim.iconName || aliasIconName || acc.iconName;\n acc.prefix = shim.prefix || acc.prefix;\n if (acc.prefix === 'far' && !styles['far'] && styles['fas'] && !config.autoFetchSvg) // Allow a fallback from the regular style to solid if regular is not available\n // but only if we aren't auto-fetching SVGs\n acc.prefix = 'fas';\n }\n return acc;\n }, emptyCanonicalIcon());\n if (canonical.prefix === 'fa' || givenPrefix === 'fa') // The fa prefix is not canonical. So if it has made it through until this point\n // we will shift it to the correct prefix.\n canonical.prefix = getDefaultUsablePrefix() || 'fas';\n return canonical;\n}\nvar Library = /*#__PURE__*/ function() {\n function Library1() {\n _classCallCheck(this, Library1);\n this.definitions = {\n };\n }\n _createClass(Library1, [\n {\n key: \"add\",\n value: function add() {\n var _this = this;\n for(var _len = arguments.length, definitions = new Array(_len), _key = 0; _key < _len; _key++)definitions[_key] = arguments[_key];\n var additions = definitions.reduce(this._pullDefinitions, {\n });\n Object.keys(additions).forEach(function(key) {\n _this.definitions[key] = _objectSpread2(_objectSpread2({\n }, _this.definitions[key] || {\n }), additions[key]);\n defineIcons(key, additions[key]);\n var longPrefix = PREFIX_TO_LONG_STYLE[key];\n if (longPrefix) defineIcons(longPrefix, additions[key]);\n build();\n });\n }\n },\n {\n key: \"reset\",\n value: function reset() {\n this.definitions = {\n };\n }\n },\n {\n key: \"_pullDefinitions\",\n value: function _pullDefinitions(additions, definition) {\n var normalized = definition.prefix && definition.iconName && definition.icon ? {\n 0: definition\n } : definition;\n Object.keys(normalized).map(function(key) {\n var _normalized$key = normalized[key], prefix = _normalized$key.prefix, iconName = _normalized$key.iconName, icon5 = _normalized$key.icon;\n var aliases = icon5[2];\n if (!additions[prefix]) additions[prefix] = {\n };\n if (aliases.length > 0) aliases.forEach(function(alias) {\n if (typeof alias === 'string') additions[prefix][alias] = icon5;\n });\n additions[prefix][iconName] = icon5;\n });\n return additions;\n }\n }\n ]);\n return Library1;\n}();\nvar _plugins = [];\nvar _hooks = {\n};\nvar providers = {\n};\nvar defaultProviderKeys = Object.keys(providers);\nfunction registerPlugins(nextPlugins, _ref3) {\n var obj = _ref3.mixoutsTo;\n _plugins = nextPlugins;\n _hooks = {\n };\n Object.keys(providers).forEach(function(k) {\n if (defaultProviderKeys.indexOf(k) === -1) delete providers[k];\n });\n _plugins.forEach(function(plugin) {\n var mixout = plugin.mixout ? plugin.mixout() : {\n };\n Object.keys(mixout).forEach(function(tk) {\n if (typeof mixout[tk] === 'function') obj[tk] = mixout[tk];\n if (_typeof(mixout[tk]) === 'object') Object.keys(mixout[tk]).forEach(function(sk) {\n if (!obj[tk]) obj[tk] = {\n };\n obj[tk][sk] = mixout[tk][sk];\n });\n });\n if (plugin.hooks) {\n var hooks = plugin.hooks();\n Object.keys(hooks).forEach(function(hook) {\n if (!_hooks[hook]) _hooks[hook] = [];\n _hooks[hook].push(hooks[hook]);\n });\n }\n if (plugin.provides) plugin.provides(providers);\n });\n return obj;\n}\nfunction chainHooks(hook, accumulator) {\n for(var _len = arguments.length, args = new Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++)args[_key - 2] = arguments[_key];\n var hookFns = _hooks[hook] || [];\n hookFns.forEach(function(hookFn) {\n accumulator = hookFn.apply(null, [\n accumulator\n ].concat(args)); // eslint-disable-line no-useless-call\n });\n return accumulator;\n}\nfunction callHooks(hook) {\n for(var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++)args[_key2 - 1] = arguments[_key2];\n var hookFns = _hooks[hook] || [];\n hookFns.forEach(function(hookFn) {\n hookFn.apply(null, args);\n });\n return undefined;\n}\nfunction callProvided() {\n var hook = arguments[0];\n var args = Array.prototype.slice.call(arguments, 1);\n return providers[hook] ? providers[hook].apply(null, args) : undefined;\n}\nfunction findIconDefinition(iconLookup) {\n if (iconLookup.prefix === 'fa') iconLookup.prefix = 'fas';\n var iconName = iconLookup.iconName;\n var prefix = iconLookup.prefix || getDefaultUsablePrefix();\n if (!iconName) return;\n iconName = byAlias(prefix, iconName) || iconName;\n return iconFromMapping(library.definitions, prefix, iconName) || iconFromMapping(namespace.styles, prefix, iconName);\n}\nvar library = new Library();\nvar noAuto = function noAuto() {\n config.autoReplaceSvg = false;\n config.observeMutations = false;\n callHooks('noAuto');\n};\nvar dom = {\n i2svg: function i2svg() {\n var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {\n };\n if (IS_DOM) {\n callHooks('beforeI2svg', params);\n callProvided('pseudoElements2svg', params);\n return callProvided('i2svg', params);\n } else return Promise.reject('Operation requires a DOM of some kind.');\n },\n watch: function watch() {\n var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {\n };\n var autoReplaceSvgRoot = params.autoReplaceSvgRoot;\n if (config.autoReplaceSvg === false) config.autoReplaceSvg = true;\n config.observeMutations = true;\n domready(function() {\n autoReplace({\n autoReplaceSvgRoot: autoReplaceSvgRoot\n });\n callHooks('watch', params);\n });\n }\n};\nvar parse = {\n icon: function icon(_icon) {\n if (_icon === null) return null;\n if (_typeof(_icon) === 'object' && _icon.prefix && _icon.iconName) return {\n prefix: _icon.prefix,\n iconName: byAlias(_icon.prefix, _icon.iconName) || _icon.iconName\n };\n if (Array.isArray(_icon) && _icon.length === 2) {\n var iconName = _icon[1].indexOf('fa-') === 0 ? _icon[1].slice(3) : _icon[1];\n var prefix = getCanonicalPrefix(_icon[0]);\n return {\n prefix: prefix,\n iconName: byAlias(prefix, iconName) || iconName\n };\n }\n if (typeof _icon === 'string' && (_icon.indexOf(\"\".concat(config.familyPrefix, \"-\")) > -1 || _icon.match(ICON_SELECTION_SYNTAX_PATTERN))) {\n var canonicalIcon = getCanonicalIcon(_icon.split(' '), {\n skipLookups: true\n });\n return {\n prefix: canonicalIcon.prefix || getDefaultUsablePrefix(),\n iconName: byAlias(canonicalIcon.prefix, canonicalIcon.iconName) || canonicalIcon.iconName\n };\n }\n if (typeof _icon === 'string') {\n var _prefix = getDefaultUsablePrefix();\n return {\n prefix: _prefix,\n iconName: byAlias(_prefix, _icon) || _icon\n };\n }\n }\n};\nvar api = {\n noAuto: noAuto,\n config: config,\n dom: dom,\n parse: parse,\n library: library,\n findIconDefinition: findIconDefinition,\n toHtml: toHtml\n};\nvar autoReplace = function autoReplace() {\n var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {\n };\n var _params$autoReplaceSv = params.autoReplaceSvgRoot, autoReplaceSvgRoot = _params$autoReplaceSv === void 0 ? DOCUMENT : _params$autoReplaceSv;\n if ((Object.keys(namespace.styles).length > 0 || config.autoFetchSvg) && IS_DOM && config.autoReplaceSvg) api.dom.i2svg({\n node: autoReplaceSvgRoot\n });\n};\nfunction domVariants(val, abstractCreator) {\n Object.defineProperty(val, 'abstract', {\n get: abstractCreator\n });\n Object.defineProperty(val, 'html', {\n get: function get() {\n return val.abstract.map(function(a) {\n return toHtml(a);\n });\n }\n });\n Object.defineProperty(val, 'node', {\n get: function get() {\n if (!IS_DOM) return;\n var container = DOCUMENT.createElement('div');\n container.innerHTML = val.html;\n return container.children;\n }\n });\n return val;\n}\nfunction asIcon(_ref4) {\n var children = _ref4.children, main = _ref4.main, mask = _ref4.mask, attributes = _ref4.attributes, styles2 = _ref4.styles, transform = _ref4.transform;\n if (transformIsMeaningful(transform) && main.found && !mask.found) {\n var width = main.width, height = main.height;\n var offset = {\n x: width / height / 2,\n y: 0.5\n };\n attributes['style'] = joinStyles(_objectSpread2(_objectSpread2({\n }, styles2), {\n }, {\n 'transform-origin': \"\".concat(offset.x + transform.x / 16, \"em \").concat(offset.y + transform.y / 16, \"em\")\n }));\n }\n return [\n {\n tag: 'svg',\n attributes: attributes,\n children: children\n }\n ];\n}\nfunction asSymbol(_ref5) {\n var prefix = _ref5.prefix, iconName = _ref5.iconName, children = _ref5.children, attributes = _ref5.attributes, symbol = _ref5.symbol;\n var id = symbol === true ? \"\".concat(prefix, \"-\").concat(config.familyPrefix, \"-\").concat(iconName) : symbol;\n return [\n {\n tag: 'svg',\n attributes: {\n style: 'display: none;'\n },\n children: [\n {\n tag: 'symbol',\n attributes: _objectSpread2(_objectSpread2({\n }, attributes), {\n }, {\n id: id\n }),\n children: children\n }\n ]\n }\n ];\n}\nfunction makeInlineSvgAbstract(params) {\n var _params$icons = params.icons, main = _params$icons.main, mask = _params$icons.mask, prefix = params.prefix, iconName = params.iconName, transform = params.transform, symbol = params.symbol, title = params.title, maskId = params.maskId, titleId = params.titleId, extra = params.extra, _params$watchable = params.watchable, watchable = _params$watchable === void 0 ? false : _params$watchable;\n var _ref6 = mask.found ? mask : main, width = _ref6.width, height = _ref6.height;\n var isUploadedIcon = prefix === 'fak';\n var attrClass = [\n config.replacementClass,\n iconName ? \"\".concat(config.familyPrefix, \"-\").concat(iconName) : ''\n ].filter(function(c) {\n return extra.classes.indexOf(c) === -1;\n }).filter(function(c) {\n return c !== '' || !!c;\n }).concat(extra.classes).join(' ');\n var content = {\n children: [],\n attributes: _objectSpread2(_objectSpread2({\n }, extra.attributes), {\n }, {\n 'data-prefix': prefix,\n 'data-icon': iconName,\n 'class': attrClass,\n 'role': extra.attributes.role || 'img',\n 'xmlns': 'http://www.w3.org/2000/svg',\n 'viewBox': \"0 0 \".concat(width, \" \").concat(height)\n })\n };\n var uploadedIconWidthStyle = isUploadedIcon && !~extra.classes.indexOf('fa-fw') ? {\n width: \"\".concat(width / height * 1, \"em\")\n } : {\n };\n if (watchable) content.attributes[DATA_FA_I2SVG] = '';\n if (title) {\n content.children.push({\n tag: 'title',\n attributes: {\n id: content.attributes['aria-labelledby'] || \"title-\".concat(titleId || nextUniqueId())\n },\n children: [\n title\n ]\n });\n delete content.attributes.title;\n }\n var args = _objectSpread2(_objectSpread2({\n }, content), {\n }, {\n prefix: prefix,\n iconName: iconName,\n main: main,\n mask: mask,\n maskId: maskId,\n transform: transform,\n symbol: symbol,\n styles: _objectSpread2(_objectSpread2({\n }, uploadedIconWidthStyle), extra.styles)\n });\n var _ref2 = mask.found && main.found ? callProvided('generateAbstractMask', args) || {\n children: [],\n attributes: {\n }\n } : callProvided('generateAbstractIcon', args) || {\n children: [],\n attributes: {\n }\n }, children = _ref2.children, attributes = _ref2.attributes;\n args.children = children;\n args.attributes = attributes;\n if (symbol) return asSymbol(args);\n else return asIcon(args);\n}\nfunction makeLayersTextAbstract(params) {\n var content = params.content, width = params.width, height = params.height, transform = params.transform, title = params.title, extra = params.extra, _params$watchable2 = params.watchable, watchable = _params$watchable2 === void 0 ? false : _params$watchable2;\n var attributes = _objectSpread2(_objectSpread2(_objectSpread2({\n }, extra.attributes), title ? {\n 'title': title\n } : {\n }), {\n }, {\n 'class': extra.classes.join(' ')\n });\n if (watchable) attributes[DATA_FA_I2SVG] = '';\n var styles3 = _objectSpread2({\n }, extra.styles);\n if (transformIsMeaningful(transform)) {\n styles3['transform'] = transformForCss({\n transform: transform,\n startCentered: true,\n width: width,\n height: height\n });\n styles3['-webkit-transform'] = styles3['transform'];\n }\n var styleString = joinStyles(styles3);\n if (styleString.length > 0) attributes['style'] = styleString;\n var val = [];\n val.push({\n tag: 'span',\n attributes: attributes,\n children: [\n content\n ]\n });\n if (title) val.push({\n tag: 'span',\n attributes: {\n class: 'sr-only'\n },\n children: [\n title\n ]\n });\n return val;\n}\nfunction makeLayersCounterAbstract(params) {\n var content = params.content, title = params.title, extra = params.extra;\n var attributes = _objectSpread2(_objectSpread2(_objectSpread2({\n }, extra.attributes), title ? {\n 'title': title\n } : {\n }), {\n }, {\n 'class': extra.classes.join(' ')\n });\n var styleString = joinStyles(extra.styles);\n if (styleString.length > 0) attributes['style'] = styleString;\n var val = [];\n val.push({\n tag: 'span',\n attributes: attributes,\n children: [\n content\n ]\n });\n if (title) val.push({\n tag: 'span',\n attributes: {\n class: 'sr-only'\n },\n children: [\n title\n ]\n });\n return val;\n}\nvar styles$1 = namespace.styles;\nfunction asFoundIcon(icon6) {\n var width = icon6[0];\n var height = icon6[1];\n var _icon$slice = icon6.slice(4), _icon$slice2 = _slicedToArray(_icon$slice, 1), vectorData = _icon$slice2[0];\n var element = null;\n if (Array.isArray(vectorData)) element = {\n tag: 'g',\n attributes: {\n class: \"\".concat(config.familyPrefix, \"-\").concat(DUOTONE_CLASSES.GROUP)\n },\n children: [\n {\n tag: 'path',\n attributes: {\n class: \"\".concat(config.familyPrefix, \"-\").concat(DUOTONE_CLASSES.SECONDARY),\n fill: 'currentColor',\n d: vectorData[0]\n }\n },\n {\n tag: 'path',\n attributes: {\n class: \"\".concat(config.familyPrefix, \"-\").concat(DUOTONE_CLASSES.PRIMARY),\n fill: 'currentColor',\n d: vectorData[1]\n }\n }\n ]\n };\n else element = {\n tag: 'path',\n attributes: {\n fill: 'currentColor',\n d: vectorData\n }\n };\n return {\n found: true,\n width: width,\n height: height,\n icon: element\n };\n}\nvar missingIconResolutionMixin = {\n found: false,\n width: 512,\n height: 512\n};\nfunction maybeNotifyMissing(iconName, prefix) {\n if (!PRODUCTION && !config.showMissingIcons && iconName) console.error(\"Icon with name \\\"\".concat(iconName, \"\\\" and prefix \\\"\").concat(prefix, \"\\\" is missing.\"));\n}\nfunction findIcon(iconName, prefix) {\n var givenPrefix = prefix;\n if (prefix === 'fa' && config.styleDefault !== null) prefix = getDefaultUsablePrefix();\n return new Promise(function(resolve, reject) {\n var val = {\n found: false,\n width: 512,\n height: 512,\n icon: callProvided('missingIconAbstract') || {\n }\n };\n if (givenPrefix === 'fa') {\n var shim = byOldName(iconName) || {\n };\n iconName = shim.iconName || iconName;\n prefix = shim.prefix || prefix;\n }\n if (iconName && prefix && styles$1[prefix] && styles$1[prefix][iconName]) {\n var icon7 = styles$1[prefix][iconName];\n return resolve(asFoundIcon(icon7));\n }\n maybeNotifyMissing(iconName, prefix);\n resolve(_objectSpread2(_objectSpread2({\n }, missingIconResolutionMixin), {\n }, {\n icon: config.showMissingIcons && iconName ? callProvided('missingIconAbstract') || {\n } : {\n }\n }));\n });\n}\nvar noop$1 = function noop() {\n};\nvar p = config.measurePerformance && PERFORMANCE && PERFORMANCE.mark && PERFORMANCE.measure ? PERFORMANCE : {\n mark: noop$1,\n measure: noop$1\n};\nvar preamble = \"FA \\\"6.0.0\\\"\";\nvar begin = function begin(name) {\n p.mark(\"\".concat(preamble, \" \").concat(name, \" begins\"));\n return function() {\n return end(name);\n };\n};\nvar end = function end(name) {\n p.mark(\"\".concat(preamble, \" \").concat(name, \" ends\"));\n p.measure(\"\".concat(preamble, \" \").concat(name), \"\".concat(preamble, \" \").concat(name, \" begins\"), \"\".concat(preamble, \" \").concat(name, \" ends\"));\n};\nvar perf = {\n begin: begin,\n end: end\n};\nvar noop$2 = function noop() {\n};\nfunction isWatched(node) {\n var i2svg = node.getAttribute ? node.getAttribute(DATA_FA_I2SVG) : null;\n return typeof i2svg === 'string';\n}\nfunction hasPrefixAndIcon(node) {\n var prefix = node.getAttribute ? node.getAttribute(DATA_PREFIX) : null;\n var icon8 = node.getAttribute ? node.getAttribute(DATA_ICON) : null;\n return prefix && icon8;\n}\nfunction hasBeenReplaced(node) {\n return node && node.classList && node.classList.contains && node.classList.contains(config.replacementClass);\n}\nfunction getMutator() {\n if (config.autoReplaceSvg === true) return mutators.replace;\n var mutator = mutators[config.autoReplaceSvg];\n return mutator || mutators.replace;\n}\nfunction createElementNS(tag) {\n return DOCUMENT.createElementNS('http://www.w3.org/2000/svg', tag);\n}\nfunction createElement(tag) {\n return DOCUMENT.createElement(tag);\n}\nfunction convertSVG(abstractObj) {\n var params = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n };\n var _params$ceFn = params.ceFn, ceFn = _params$ceFn === void 0 ? abstractObj.tag === 'svg' ? createElementNS : createElement : _params$ceFn;\n if (typeof abstractObj === 'string') return DOCUMENT.createTextNode(abstractObj);\n var tag = ceFn(abstractObj.tag);\n Object.keys(abstractObj.attributes || []).forEach(function(key) {\n tag.setAttribute(key, abstractObj.attributes[key]);\n });\n var children = abstractObj.children || [];\n children.forEach(function(child) {\n tag.appendChild(convertSVG(child, {\n ceFn: ceFn\n }));\n });\n return tag;\n}\nfunction nodeAsComment(node) {\n var comment = \" \".concat(node.outerHTML, \" \");\n /* BEGIN.ATTRIBUTION */ comment = \"\".concat(comment, \"Font Awesome fontawesome.com \");\n /* END.ATTRIBUTION */ return comment;\n}\nvar mutators = {\n replace: function replace(mutation) {\n var node = mutation[0];\n if (node.parentNode) {\n mutation[1].forEach(function(abstract) {\n node.parentNode.insertBefore(convertSVG(abstract), node);\n });\n if (node.getAttribute(DATA_FA_I2SVG) === null && config.keepOriginalSource) {\n var comment = DOCUMENT.createComment(nodeAsComment(node));\n node.parentNode.replaceChild(comment, node);\n } else node.remove();\n }\n },\n nest: function nest(mutation) {\n var node = mutation[0];\n var abstract = mutation[1]; // If we already have a replaced node we do not want to continue nesting within it.\n // Short-circuit to the standard replacement\n if (~classArray(node).indexOf(config.replacementClass)) return mutators.replace(mutation);\n var forSvg = new RegExp(\"\".concat(config.familyPrefix, \"-.*\"));\n delete abstract[0].attributes.id;\n if (abstract[0].attributes.class) {\n var splitClasses = abstract[0].attributes.class.split(' ').reduce(function(acc, cls) {\n if (cls === config.replacementClass || cls.match(forSvg)) acc.toSvg.push(cls);\n else acc.toNode.push(cls);\n return acc;\n }, {\n toNode: [],\n toSvg: []\n });\n abstract[0].attributes.class = splitClasses.toSvg.join(' ');\n if (splitClasses.toNode.length === 0) node.removeAttribute('class');\n else node.setAttribute('class', splitClasses.toNode.join(' '));\n }\n var newInnerHTML = abstract.map(function(a) {\n return toHtml(a);\n }).join('\\n');\n node.setAttribute(DATA_FA_I2SVG, '');\n node.innerHTML = newInnerHTML;\n }\n};\nfunction performOperationSync(op) {\n op();\n}\nfunction perform(mutations, callback) {\n var callbackFunction = typeof callback === 'function' ? callback : noop$2;\n if (mutations.length === 0) callbackFunction();\n else {\n var frame = performOperationSync;\n if (config.mutateApproach === MUTATION_APPROACH_ASYNC) frame = WINDOW.requestAnimationFrame || performOperationSync;\n frame(function() {\n var mutator = getMutator();\n var mark = perf.begin('mutate');\n mutations.map(mutator);\n mark();\n callbackFunction();\n });\n }\n}\nvar disabled = false;\nfunction disableObservation() {\n disabled = true;\n}\nfunction enableObservation() {\n disabled = false;\n}\nvar mo = null;\nfunction observe(options) {\n if (!MUTATION_OBSERVER) return;\n if (!config.observeMutations) return;\n var _options$treeCallback = options.treeCallback, treeCallback = _options$treeCallback === void 0 ? noop$2 : _options$treeCallback, _options$nodeCallback = options.nodeCallback, nodeCallback = _options$nodeCallback === void 0 ? noop$2 : _options$nodeCallback, _options$pseudoElemen = options.pseudoElementsCallback, pseudoElementsCallback = _options$pseudoElemen === void 0 ? noop$2 : _options$pseudoElemen, _options$observeMutat = options.observeMutationsRoot, observeMutationsRoot = _options$observeMutat === void 0 ? DOCUMENT : _options$observeMutat;\n mo = new MUTATION_OBSERVER(function(objects) {\n if (disabled) return;\n var defaultPrefix = getDefaultUsablePrefix();\n toArray(objects).forEach(function(mutationRecord) {\n if (mutationRecord.type === 'childList' && mutationRecord.addedNodes.length > 0 && !isWatched(mutationRecord.addedNodes[0])) {\n if (config.searchPseudoElements) pseudoElementsCallback(mutationRecord.target);\n treeCallback(mutationRecord.target);\n }\n if (mutationRecord.type === 'attributes' && mutationRecord.target.parentNode && config.searchPseudoElements) pseudoElementsCallback(mutationRecord.target.parentNode);\n if (mutationRecord.type === 'attributes' && isWatched(mutationRecord.target) && ~ATTRIBUTES_WATCHED_FOR_MUTATION.indexOf(mutationRecord.attributeName)) {\n if (mutationRecord.attributeName === 'class' && hasPrefixAndIcon(mutationRecord.target)) {\n var _getCanonicalIcon = getCanonicalIcon(classArray(mutationRecord.target)), prefix = _getCanonicalIcon.prefix, iconName = _getCanonicalIcon.iconName;\n mutationRecord.target.setAttribute(DATA_PREFIX, prefix || defaultPrefix);\n if (iconName) mutationRecord.target.setAttribute(DATA_ICON, iconName);\n } else if (hasBeenReplaced(mutationRecord.target)) nodeCallback(mutationRecord.target);\n }\n });\n });\n if (!IS_DOM) return;\n mo.observe(observeMutationsRoot, {\n childList: true,\n attributes: true,\n characterData: true,\n subtree: true\n });\n}\nfunction disconnect() {\n if (!mo) return;\n mo.disconnect();\n}\nfunction styleParser(node) {\n var style1 = node.getAttribute('style');\n var val = [];\n if (style1) val = style1.split(';').reduce(function(acc, style) {\n var styles4 = style.split(':');\n var prop = styles4[0];\n var value = styles4.slice(1);\n if (prop && value.length > 0) acc[prop] = value.join(':').trim();\n return acc;\n }, {\n });\n return val;\n}\nfunction classParser(node) {\n var existingPrefix = node.getAttribute('data-prefix');\n var existingIconName = node.getAttribute('data-icon');\n var innerText = node.innerText !== undefined ? node.innerText.trim() : '';\n var val = getCanonicalIcon(classArray(node));\n if (!val.prefix) val.prefix = getDefaultUsablePrefix();\n if (existingPrefix && existingIconName) {\n val.prefix = existingPrefix;\n val.iconName = existingIconName;\n }\n if (val.iconName && val.prefix) return val;\n if (val.prefix && innerText.length > 0) val.iconName = byLigature(val.prefix, node.innerText) || byUnicode(val.prefix, toHex(node.innerText));\n return val;\n}\nfunction attributesParser(node) {\n var extraAttributes = toArray(node.attributes).reduce(function(acc, attr) {\n if (acc.name !== 'class' && acc.name !== 'style') acc[attr.name] = attr.value;\n return acc;\n }, {\n });\n var title = node.getAttribute('title');\n var titleId = node.getAttribute('data-fa-title-id');\n if (config.autoA11y) {\n if (title) extraAttributes['aria-labelledby'] = \"\".concat(config.replacementClass, \"-title-\").concat(titleId || nextUniqueId());\n else {\n extraAttributes['aria-hidden'] = 'true';\n extraAttributes['focusable'] = 'false';\n }\n }\n return extraAttributes;\n}\nfunction blankMeta() {\n return {\n iconName: null,\n title: null,\n titleId: null,\n prefix: null,\n transform: meaninglessTransform,\n symbol: false,\n mask: {\n iconName: null,\n prefix: null,\n rest: []\n },\n maskId: null,\n extra: {\n classes: [],\n styles: {\n },\n attributes: {\n }\n }\n };\n}\nfunction parseMeta(node) {\n var parser = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n styleParser: true\n };\n var _classParser = classParser(node), iconName = _classParser.iconName, prefix = _classParser.prefix, extraClasses = _classParser.rest;\n var extraAttributes = attributesParser(node);\n var pluginMeta = chainHooks('parseNodeAttributes', {\n }, node);\n var extraStyles = parser.styleParser ? styleParser(node) : [];\n return _objectSpread2({\n iconName: iconName,\n title: node.getAttribute('title'),\n titleId: node.getAttribute('data-fa-title-id'),\n prefix: prefix,\n transform: meaninglessTransform,\n mask: {\n iconName: null,\n prefix: null,\n rest: []\n },\n maskId: null,\n symbol: false,\n extra: {\n classes: extraClasses,\n styles: extraStyles,\n attributes: extraAttributes\n }\n }, pluginMeta);\n}\nvar styles$2 = namespace.styles;\nfunction generateMutation(node) {\n var nodeMeta = config.autoReplaceSvg === 'nest' ? parseMeta(node, {\n styleParser: false\n }) : parseMeta(node);\n if (~nodeMeta.extra.classes.indexOf(LAYERS_TEXT_CLASSNAME)) return callProvided('generateLayersText', node, nodeMeta);\n else return callProvided('generateSvgReplacementMutation', node, nodeMeta);\n}\nfunction onTree(root) {\n var callback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;\n if (!IS_DOM) return Promise.resolve();\n var htmlClassList = DOCUMENT.documentElement.classList;\n var hclAdd = function hclAdd(suffix) {\n return htmlClassList.add(\"\".concat(HTML_CLASS_I2SVG_BASE_CLASS, \"-\").concat(suffix));\n };\n var hclRemove = function hclRemove(suffix) {\n return htmlClassList.remove(\"\".concat(HTML_CLASS_I2SVG_BASE_CLASS, \"-\").concat(suffix));\n };\n var prefixes = config.autoFetchSvg ? Object.keys(PREFIX_TO_STYLE) : Object.keys(styles$2);\n var prefixesDomQuery = [\n \".\".concat(LAYERS_TEXT_CLASSNAME, \":not([\").concat(DATA_FA_I2SVG, \"])\")\n ].concat(prefixes.map(function(p3) {\n return \".\".concat(p3, \":not([\").concat(DATA_FA_I2SVG, \"])\");\n })).join(', ');\n if (prefixesDomQuery.length === 0) return Promise.resolve();\n var candidates = [];\n try {\n candidates = toArray(root.querySelectorAll(prefixesDomQuery));\n } catch (e1) {\n }\n if (candidates.length > 0) {\n hclAdd('pending');\n hclRemove('complete');\n } else return Promise.resolve();\n var mark = perf.begin('onTree');\n var mutations = candidates.reduce(function(acc, node) {\n try {\n var mutation = generateMutation(node);\n if (mutation) acc.push(mutation);\n } catch (e2) {\n if (!PRODUCTION) {\n if (e2.name === 'MissingIcon') console.error(e2);\n }\n }\n return acc;\n }, []);\n return new Promise(function(resolve, reject) {\n Promise.all(mutations).then(function(resolvedMutations) {\n perform(resolvedMutations, function() {\n hclAdd('active');\n hclAdd('complete');\n hclRemove('pending');\n if (typeof callback === 'function') callback();\n mark();\n resolve();\n });\n }).catch(function(e3) {\n mark();\n reject(e3);\n });\n });\n}\nfunction onNode(node) {\n var callback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;\n generateMutation(node).then(function(mutation) {\n if (mutation) perform([\n mutation\n ], callback);\n });\n}\nfunction resolveIcons(next) {\n return function(maybeIconDefinition) {\n var params = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n };\n var iconDefinition = (maybeIconDefinition || {\n }).icon ? maybeIconDefinition : findIconDefinition(maybeIconDefinition || {\n });\n var mask = params.mask;\n if (mask) mask = (mask || {\n }).icon ? mask : findIconDefinition(mask || {\n });\n return next(iconDefinition, _objectSpread2(_objectSpread2({\n }, params), {\n }, {\n mask: mask\n }));\n };\n}\nvar render = function render(iconDefinition) {\n var params = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n };\n var _params$transform = params.transform, transform = _params$transform === void 0 ? meaninglessTransform : _params$transform, _params$symbol = params.symbol, symbol = _params$symbol === void 0 ? false : _params$symbol, _params$mask = params.mask, mask = _params$mask === void 0 ? null : _params$mask, _params$maskId = params.maskId, maskId = _params$maskId === void 0 ? null : _params$maskId, _params$title = params.title, title = _params$title === void 0 ? null : _params$title, _params$titleId = params.titleId, titleId = _params$titleId === void 0 ? null : _params$titleId, _params$classes = params.classes, classes = _params$classes === void 0 ? [] : _params$classes, _params$attributes = params.attributes, attributes = _params$attributes === void 0 ? {\n } : _params$attributes, _params$styles = params.styles, styles5 = _params$styles === void 0 ? {\n } : _params$styles;\n if (!iconDefinition) return;\n var prefix = iconDefinition.prefix, iconName = iconDefinition.iconName, icon9 = iconDefinition.icon;\n return domVariants(_objectSpread2({\n type: 'icon'\n }, iconDefinition), function() {\n callHooks('beforeDOMElementCreation', {\n iconDefinition: iconDefinition,\n params: params\n });\n if (config.autoA11y) {\n if (title) attributes['aria-labelledby'] = \"\".concat(config.replacementClass, \"-title-\").concat(titleId || nextUniqueId());\n else {\n attributes['aria-hidden'] = 'true';\n attributes['focusable'] = 'false';\n }\n }\n return makeInlineSvgAbstract({\n icons: {\n main: asFoundIcon(icon9),\n mask: mask ? asFoundIcon(mask.icon) : {\n found: false,\n width: null,\n height: null,\n icon: {\n }\n }\n },\n prefix: prefix,\n iconName: iconName,\n transform: _objectSpread2(_objectSpread2({\n }, meaninglessTransform), transform),\n symbol: symbol,\n title: title,\n maskId: maskId,\n titleId: titleId,\n extra: {\n attributes: attributes,\n styles: styles5,\n classes: classes\n }\n });\n });\n};\nvar ReplaceElements = {\n mixout: function mixout() {\n return {\n icon: resolveIcons(render)\n };\n },\n hooks: function hooks() {\n return {\n mutationObserverCallbacks: function mutationObserverCallbacks(accumulator) {\n accumulator.treeCallback = onTree;\n accumulator.nodeCallback = onNode;\n return accumulator;\n }\n };\n },\n provides: function provides(providers$$1) {\n providers$$1.i2svg = function(params) {\n var _params$node = params.node, node = _params$node === void 0 ? DOCUMENT : _params$node, _params$callback = params.callback, callback = _params$callback === void 0 ? function() {\n } : _params$callback;\n return onTree(node, callback);\n };\n providers$$1.generateSvgReplacementMutation = function(node, nodeMeta) {\n var iconName = nodeMeta.iconName, title = nodeMeta.title, titleId = nodeMeta.titleId, prefix = nodeMeta.prefix, transform = nodeMeta.transform, symbol = nodeMeta.symbol, mask1 = nodeMeta.mask, maskId = nodeMeta.maskId, extra = nodeMeta.extra;\n return new Promise(function(resolve, reject) {\n Promise.all([\n findIcon(iconName, prefix),\n mask1.iconName ? findIcon(mask1.iconName, mask1.prefix) : Promise.resolve({\n found: false,\n width: 512,\n height: 512,\n icon: {\n }\n })\n ]).then(function(_ref7) {\n var _ref2 = _slicedToArray(_ref7, 2), main = _ref2[0], mask = _ref2[1];\n resolve([\n node,\n makeInlineSvgAbstract({\n icons: {\n main: main,\n mask: mask\n },\n prefix: prefix,\n iconName: iconName,\n transform: transform,\n symbol: symbol,\n maskId: maskId,\n title: title,\n titleId: titleId,\n extra: extra,\n watchable: true\n })\n ]);\n }).catch(reject);\n });\n };\n providers$$1.generateAbstractIcon = function(_ref3) {\n var children = _ref3.children, attributes = _ref3.attributes, main = _ref3.main, transform = _ref3.transform, styles6 = _ref3.styles;\n var styleString = joinStyles(styles6);\n if (styleString.length > 0) attributes['style'] = styleString;\n var nextChild;\n if (transformIsMeaningful(transform)) nextChild = callProvided('generateAbstractTransformGrouping', {\n main: main,\n transform: transform,\n containerWidth: main.width,\n iconWidth: main.width\n });\n children.push(nextChild || main.icon);\n return {\n children: children,\n attributes: attributes\n };\n };\n }\n};\nvar Layers = {\n mixout: function mixout() {\n return {\n layer: function layer(assembler) {\n var params = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n };\n var _params$classes = params.classes, classes = _params$classes === void 0 ? [] : _params$classes;\n return domVariants({\n type: 'layer'\n }, function() {\n callHooks('beforeDOMElementCreation', {\n assembler: assembler,\n params: params\n });\n var children = [];\n assembler(function(args) {\n Array.isArray(args) ? args.map(function(a) {\n children = children.concat(a.abstract);\n }) : children = children.concat(args.abstract);\n });\n return [\n {\n tag: 'span',\n attributes: {\n class: [\n \"\".concat(config.familyPrefix, \"-layers\")\n ].concat(_toConsumableArray(classes)).join(' ')\n },\n children: children\n }\n ];\n });\n }\n };\n }\n};\nvar LayersCounter = {\n mixout: function mixout() {\n return {\n counter: function counter(content) {\n var params = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n };\n var _params$title = params.title, title = _params$title === void 0 ? null : _params$title, _params$classes = params.classes, classes = _params$classes === void 0 ? [] : _params$classes, _params$attributes = params.attributes, attributes = _params$attributes === void 0 ? {\n } : _params$attributes, _params$styles = params.styles, styles7 = _params$styles === void 0 ? {\n } : _params$styles;\n return domVariants({\n type: 'counter',\n content: content\n }, function() {\n callHooks('beforeDOMElementCreation', {\n content: content,\n params: params\n });\n return makeLayersCounterAbstract({\n content: content.toString(),\n title: title,\n extra: {\n attributes: attributes,\n styles: styles7,\n classes: [\n \"\".concat(config.familyPrefix, \"-layers-counter\")\n ].concat(_toConsumableArray(classes))\n }\n });\n });\n }\n };\n }\n};\nvar LayersText = {\n mixout: function mixout() {\n return {\n text: function text(content) {\n var params = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n };\n var _params$transform = params.transform, transform = _params$transform === void 0 ? meaninglessTransform : _params$transform, _params$title = params.title, title = _params$title === void 0 ? null : _params$title, _params$classes = params.classes, classes = _params$classes === void 0 ? [] : _params$classes, _params$attributes = params.attributes, attributes = _params$attributes === void 0 ? {\n } : _params$attributes, _params$styles = params.styles, styles8 = _params$styles === void 0 ? {\n } : _params$styles;\n return domVariants({\n type: 'text',\n content: content\n }, function() {\n callHooks('beforeDOMElementCreation', {\n content: content,\n params: params\n });\n return makeLayersTextAbstract({\n content: content,\n transform: _objectSpread2(_objectSpread2({\n }, meaninglessTransform), transform),\n title: title,\n extra: {\n attributes: attributes,\n styles: styles8,\n classes: [\n \"\".concat(config.familyPrefix, \"-layers-text\")\n ].concat(_toConsumableArray(classes))\n }\n });\n });\n }\n };\n },\n provides: function provides(providers$$1) {\n providers$$1.generateLayersText = function(node, nodeMeta) {\n var title = nodeMeta.title, transform = nodeMeta.transform, extra = nodeMeta.extra;\n var width = null;\n var height = null;\n if (IS_IE) {\n var computedFontSize = parseInt(getComputedStyle(node).fontSize, 10);\n var boundingClientRect = node.getBoundingClientRect();\n width = boundingClientRect.width / computedFontSize;\n height = boundingClientRect.height / computedFontSize;\n }\n if (config.autoA11y && !title) extra.attributes['aria-hidden'] = 'true';\n return Promise.resolve([\n node,\n makeLayersTextAbstract({\n content: node.innerHTML,\n width: width,\n height: height,\n transform: transform,\n title: title,\n extra: extra,\n watchable: true\n })\n ]);\n };\n }\n};\nvar CLEAN_CONTENT_PATTERN = new RegExp(\"\\\"\", 'ug');\nvar SECONDARY_UNICODE_RANGE = [\n 1105920,\n 1112319\n];\nfunction hexValueFromContent(content) {\n var cleaned = content.replace(CLEAN_CONTENT_PATTERN, '');\n var codePoint = codePointAt(cleaned, 0);\n var isPrependTen = codePoint >= SECONDARY_UNICODE_RANGE[0] && codePoint <= SECONDARY_UNICODE_RANGE[1];\n var isDoubled = cleaned.length === 2 ? cleaned[0] === cleaned[1] : false;\n return {\n value: isDoubled ? toHex(cleaned[0]) : toHex(cleaned),\n isSecondary: isPrependTen || isDoubled\n };\n}\nfunction replaceForPosition(node, position) {\n var pendingAttribute = \"\".concat(DATA_FA_PSEUDO_ELEMENT_PENDING).concat(position.replace(':', '-'));\n return new Promise(function(resolve, reject) {\n if (node.getAttribute(pendingAttribute) !== null) // This node is already being processed\n return resolve();\n var children = toArray(node.children);\n var alreadyProcessedPseudoElement = children.filter(function(c) {\n return c.getAttribute(DATA_FA_PSEUDO_ELEMENT) === position;\n })[0];\n var styles9 = WINDOW.getComputedStyle(node, position);\n var fontFamily = styles9.getPropertyValue('font-family').match(FONT_FAMILY_PATTERN);\n var fontWeight = styles9.getPropertyValue('font-weight');\n var content = styles9.getPropertyValue('content');\n if (alreadyProcessedPseudoElement && !fontFamily) {\n // If we've already processed it but the current computed style does not result in a font-family,\n // that probably means that a class name that was previously present to make the icon has been\n // removed. So we now should delete the icon.\n node.removeChild(alreadyProcessedPseudoElement);\n return resolve();\n } else if (fontFamily && content !== 'none' && content !== '') {\n var _content = styles9.getPropertyValue('content');\n var prefix = ~[\n 'Solid',\n 'Regular',\n 'Light',\n 'Thin',\n 'Duotone',\n 'Brands',\n 'Kit'\n ].indexOf(fontFamily[2]) ? STYLE_TO_PREFIX[fontFamily[2].toLowerCase()] : FONT_WEIGHT_TO_PREFIX[fontWeight];\n var _hexValueFromContent = hexValueFromContent(_content), hexValue = _hexValueFromContent.value, isSecondary = _hexValueFromContent.isSecondary;\n var isV4 = fontFamily[0].startsWith('FontAwesome');\n var iconName = byUnicode(prefix, hexValue);\n var iconIdentifier = iconName;\n if (isV4) {\n var iconName4 = byOldUnicode(hexValue);\n if (iconName4.iconName && iconName4.prefix) {\n iconName = iconName4.iconName;\n prefix = iconName4.prefix;\n }\n } // Only convert the pseudo element in this ::before/::after position into an icon if we haven't\n // already done so with the same prefix and iconName\n if (iconName && !isSecondary && (!alreadyProcessedPseudoElement || alreadyProcessedPseudoElement.getAttribute(DATA_PREFIX) !== prefix || alreadyProcessedPseudoElement.getAttribute(DATA_ICON) !== iconIdentifier)) {\n node.setAttribute(pendingAttribute, iconIdentifier);\n if (alreadyProcessedPseudoElement) // Delete the old one, since we're replacing it with a new one\n node.removeChild(alreadyProcessedPseudoElement);\n var meta = blankMeta();\n var extra = meta.extra;\n extra.attributes[DATA_FA_PSEUDO_ELEMENT] = position;\n findIcon(iconName, prefix).then(function(main) {\n var abstract = makeInlineSvgAbstract(_objectSpread2(_objectSpread2({\n }, meta), {\n }, {\n icons: {\n main: main,\n mask: emptyCanonicalIcon()\n },\n prefix: prefix,\n iconName: iconIdentifier,\n extra: extra,\n watchable: true\n }));\n var element = DOCUMENT.createElement('svg');\n if (position === '::before') node.insertBefore(element, node.firstChild);\n else node.appendChild(element);\n element.outerHTML = abstract.map(function(a) {\n return toHtml(a);\n }).join('\\n');\n node.removeAttribute(pendingAttribute);\n resolve();\n }).catch(reject);\n } else resolve();\n } else resolve();\n });\n}\nfunction replace(node) {\n return Promise.all([\n replaceForPosition(node, '::before'),\n replaceForPosition(node, '::after')\n ]);\n}\nfunction processable(node) {\n return node.parentNode !== document.head && !~TAGNAMES_TO_SKIP_FOR_PSEUDOELEMENTS.indexOf(node.tagName.toUpperCase()) && !node.getAttribute(DATA_FA_PSEUDO_ELEMENT) && (!node.parentNode || node.parentNode.tagName !== 'svg');\n}\nfunction searchPseudoElements(root) {\n if (!IS_DOM) return;\n return new Promise(function(resolve, reject) {\n var operations = toArray(root.querySelectorAll('*')).filter(processable).map(replace);\n var end1 = perf.begin('searchPseudoElements');\n disableObservation();\n Promise.all(operations).then(function() {\n end1();\n enableObservation();\n resolve();\n }).catch(function() {\n end1();\n enableObservation();\n reject();\n });\n });\n}\nvar PseudoElements = {\n hooks: function hooks() {\n return {\n mutationObserverCallbacks: function mutationObserverCallbacks(accumulator) {\n accumulator.pseudoElementsCallback = searchPseudoElements;\n return accumulator;\n }\n };\n },\n provides: function provides(providers$$1) {\n providers$$1.pseudoElements2svg = function(params) {\n var _params$node = params.node, node = _params$node === void 0 ? DOCUMENT : _params$node;\n if (config.searchPseudoElements) searchPseudoElements(node);\n };\n }\n};\nvar _unwatched = false;\nvar MutationObserver$1 = {\n mixout: function mixout() {\n return {\n dom: {\n unwatch: function unwatch() {\n disableObservation();\n _unwatched = true;\n }\n }\n };\n },\n hooks: function hooks() {\n return {\n bootstrap: function bootstrap() {\n observe(chainHooks('mutationObserverCallbacks', {\n }));\n },\n noAuto: function noAuto() {\n disconnect();\n },\n watch: function watch(params) {\n var observeMutationsRoot = params.observeMutationsRoot;\n if (_unwatched) enableObservation();\n else observe(chainHooks('mutationObserverCallbacks', {\n observeMutationsRoot: observeMutationsRoot\n }));\n }\n };\n }\n};\nvar parseTransformString = function parseTransformString(transformString) {\n var transform = {\n size: 16,\n x: 0,\n y: 0,\n flipX: false,\n flipY: false,\n rotate: 0\n };\n return transformString.toLowerCase().split(' ').reduce(function(acc, n) {\n var parts = n.toLowerCase().split('-');\n var first = parts[0];\n var rest = parts.slice(1).join('-');\n if (first && rest === 'h') {\n acc.flipX = true;\n return acc;\n }\n if (first && rest === 'v') {\n acc.flipY = true;\n return acc;\n }\n rest = parseFloat(rest);\n if (isNaN(rest)) return acc;\n switch(first){\n case 'grow':\n acc.size = acc.size + rest;\n break;\n case 'shrink':\n acc.size = acc.size - rest;\n break;\n case 'left':\n acc.x = acc.x - rest;\n break;\n case 'right':\n acc.x = acc.x + rest;\n break;\n case 'up':\n acc.y = acc.y - rest;\n break;\n case 'down':\n acc.y = acc.y + rest;\n break;\n case 'rotate':\n acc.rotate = acc.rotate + rest;\n break;\n }\n return acc;\n }, transform);\n};\nvar PowerTransforms = {\n mixout: function mixout() {\n return {\n parse: {\n transform: function transform(transformString) {\n return parseTransformString(transformString);\n }\n }\n };\n },\n hooks: function hooks() {\n return {\n parseNodeAttributes: function parseNodeAttributes(accumulator, node) {\n var transformString = node.getAttribute('data-fa-transform');\n if (transformString) accumulator.transform = parseTransformString(transformString);\n return accumulator;\n }\n };\n },\n provides: function provides(providers1) {\n providers1.generateAbstractTransformGrouping = function(_ref8) {\n var main = _ref8.main, transform = _ref8.transform, containerWidth = _ref8.containerWidth, iconWidth = _ref8.iconWidth;\n var outer = {\n transform: \"translate(\".concat(containerWidth / 2, \" 256)\")\n };\n var innerTranslate = \"translate(\".concat(transform.x * 32, \", \").concat(transform.y * 32, \") \");\n var innerScale = \"scale(\".concat(transform.size / 16 * (transform.flipX ? -1 : 1), \", \").concat(transform.size / 16 * (transform.flipY ? -1 : 1), \") \");\n var innerRotate = \"rotate(\".concat(transform.rotate, \" 0 0)\");\n var inner = {\n transform: \"\".concat(innerTranslate, \" \").concat(innerScale, \" \").concat(innerRotate)\n };\n var path = {\n transform: \"translate(\".concat(iconWidth / 2 * -1, \" -256)\")\n };\n var operations = {\n outer: outer,\n inner: inner,\n path: path\n };\n return {\n tag: 'g',\n attributes: _objectSpread2({\n }, operations.outer),\n children: [\n {\n tag: 'g',\n attributes: _objectSpread2({\n }, operations.inner),\n children: [\n {\n tag: main.icon.tag,\n children: main.icon.children,\n attributes: _objectSpread2(_objectSpread2({\n }, main.icon.attributes), operations.path)\n }\n ]\n }\n ]\n };\n };\n }\n};\nvar ALL_SPACE = {\n x: 0,\n y: 0,\n width: '100%',\n height: '100%'\n};\nfunction fillBlack(abstract) {\n var force = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n if (abstract.attributes && (abstract.attributes.fill || force)) abstract.attributes.fill = 'black';\n return abstract;\n}\nfunction deGroup(abstract) {\n if (abstract.tag === 'g') return abstract.children;\n else return [\n abstract\n ];\n}\nvar Masks = {\n hooks: function hooks() {\n return {\n parseNodeAttributes: function parseNodeAttributes(accumulator, node) {\n var maskData = node.getAttribute('data-fa-mask');\n var mask = !maskData ? emptyCanonicalIcon() : getCanonicalIcon(maskData.split(' ').map(function(i) {\n return i.trim();\n }));\n if (!mask.prefix) mask.prefix = getDefaultUsablePrefix();\n accumulator.mask = mask;\n accumulator.maskId = node.getAttribute('data-fa-mask-id');\n return accumulator;\n }\n };\n },\n provides: function provides(providers2) {\n providers2.generateAbstractMask = function(_ref9) {\n var children = _ref9.children, attributes = _ref9.attributes, main = _ref9.main, mask = _ref9.mask, explicitMaskId = _ref9.maskId, transform = _ref9.transform;\n var mainWidth = main.width, mainPath = main.icon;\n var maskWidth = mask.width, maskPath = mask.icon;\n var trans = transformForSvg({\n transform: transform,\n containerWidth: maskWidth,\n iconWidth: mainWidth\n });\n var maskRect = {\n tag: 'rect',\n attributes: _objectSpread2(_objectSpread2({\n }, ALL_SPACE), {\n }, {\n fill: 'white'\n })\n };\n var maskInnerGroupChildrenMixin = mainPath.children ? {\n children: mainPath.children.map(fillBlack)\n } : {\n };\n var maskInnerGroup = {\n tag: 'g',\n attributes: _objectSpread2({\n }, trans.inner),\n children: [\n fillBlack(_objectSpread2({\n tag: mainPath.tag,\n attributes: _objectSpread2(_objectSpread2({\n }, mainPath.attributes), trans.path)\n }, maskInnerGroupChildrenMixin))\n ]\n };\n var maskOuterGroup = {\n tag: 'g',\n attributes: _objectSpread2({\n }, trans.outer),\n children: [\n maskInnerGroup\n ]\n };\n var maskId = \"mask-\".concat(explicitMaskId || nextUniqueId());\n var clipId = \"clip-\".concat(explicitMaskId || nextUniqueId());\n var maskTag = {\n tag: 'mask',\n attributes: _objectSpread2(_objectSpread2({\n }, ALL_SPACE), {\n }, {\n id: maskId,\n maskUnits: 'userSpaceOnUse',\n maskContentUnits: 'userSpaceOnUse'\n }),\n children: [\n maskRect,\n maskOuterGroup\n ]\n };\n var defs = {\n tag: 'defs',\n children: [\n {\n tag: 'clipPath',\n attributes: {\n id: clipId\n },\n children: deGroup(maskPath)\n },\n maskTag\n ]\n };\n children.push(defs, {\n tag: 'rect',\n attributes: _objectSpread2({\n fill: 'currentColor',\n 'clip-path': \"url(#\".concat(clipId, \")\"),\n mask: \"url(#\".concat(maskId, \")\")\n }, ALL_SPACE)\n });\n return {\n children: children,\n attributes: attributes\n };\n };\n }\n};\nvar MissingIconIndicator = {\n provides: function provides(providers3) {\n var reduceMotion = false;\n if (WINDOW.matchMedia) reduceMotion = WINDOW.matchMedia('(prefers-reduced-motion: reduce)').matches;\n providers3.missingIconAbstract = function() {\n var gChildren = [];\n var FILL = {\n fill: 'currentColor'\n };\n var ANIMATION_BASE = {\n attributeType: 'XML',\n repeatCount: 'indefinite',\n dur: '2s'\n }; // Ring\n gChildren.push({\n tag: 'path',\n attributes: _objectSpread2(_objectSpread2({\n }, FILL), {\n }, {\n d: 'M156.5,447.7l-12.6,29.5c-18.7-9.5-35.9-21.2-51.5-34.9l22.7-22.7C127.6,430.5,141.5,440,156.5,447.7z M40.6,272H8.5 c1.4,21.2,5.4,41.7,11.7,61.1L50,321.2C45.1,305.5,41.8,289,40.6,272z M40.6,240c1.4-18.8,5.2-37,11.1-54.1l-29.5-12.6 C14.7,194.3,10,216.7,8.5,240H40.6z M64.3,156.5c7.8-14.9,17.2-28.8,28.1-41.5L69.7,92.3c-13.7,15.6-25.5,32.8-34.9,51.5 L64.3,156.5z M397,419.6c-13.9,12-29.4,22.3-46.1,30.4l11.9,29.8c20.7-9.9,39.8-22.6,56.9-37.6L397,419.6z M115,92.4 c13.9-12,29.4-22.3,46.1-30.4l-11.9-29.8c-20.7,9.9-39.8,22.6-56.8,37.6L115,92.4z M447.7,355.5c-7.8,14.9-17.2,28.8-28.1,41.5 l22.7,22.7c13.7-15.6,25.5-32.9,34.9-51.5L447.7,355.5z M471.4,272c-1.4,18.8-5.2,37-11.1,54.1l29.5,12.6 c7.5-21.1,12.2-43.5,13.6-66.8H471.4z M321.2,462c-15.7,5-32.2,8.2-49.2,9.4v32.1c21.2-1.4,41.7-5.4,61.1-11.7L321.2,462z M240,471.4c-18.8-1.4-37-5.2-54.1-11.1l-12.6,29.5c21.1,7.5,43.5,12.2,66.8,13.6V471.4z M462,190.8c5,15.7,8.2,32.2,9.4,49.2h32.1 c-1.4-21.2-5.4-41.7-11.7-61.1L462,190.8z M92.4,397c-12-13.9-22.3-29.4-30.4-46.1l-29.8,11.9c9.9,20.7,22.6,39.8,37.6,56.9 L92.4,397z M272,40.6c18.8,1.4,36.9,5.2,54.1,11.1l12.6-29.5C317.7,14.7,295.3,10,272,8.5V40.6z M190.8,50 c15.7-5,32.2-8.2,49.2-9.4V8.5c-21.2,1.4-41.7,5.4-61.1,11.7L190.8,50z M442.3,92.3L419.6,115c12,13.9,22.3,29.4,30.5,46.1 l29.8-11.9C470,128.5,457.3,109.4,442.3,92.3z M397,92.4l22.7-22.7c-15.6-13.7-32.8-25.5-51.5-34.9l-12.6,29.5 C370.4,72.1,384.4,81.5,397,92.4z'\n })\n });\n var OPACITY_ANIMATE = _objectSpread2(_objectSpread2({\n }, ANIMATION_BASE), {\n }, {\n attributeName: 'opacity'\n });\n var dot = {\n tag: 'circle',\n attributes: _objectSpread2(_objectSpread2({\n }, FILL), {\n }, {\n cx: '256',\n cy: '364',\n r: '28'\n }),\n children: []\n };\n if (!reduceMotion) dot.children.push({\n tag: 'animate',\n attributes: _objectSpread2(_objectSpread2({\n }, ANIMATION_BASE), {\n }, {\n attributeName: 'r',\n values: '28;14;28;28;14;28;'\n })\n }, {\n tag: 'animate',\n attributes: _objectSpread2(_objectSpread2({\n }, OPACITY_ANIMATE), {\n }, {\n values: '1;0;1;1;0;1;'\n })\n });\n gChildren.push(dot);\n gChildren.push({\n tag: 'path',\n attributes: _objectSpread2(_objectSpread2({\n }, FILL), {\n }, {\n opacity: '1',\n d: 'M263.7,312h-16c-6.6,0-12-5.4-12-12c0-71,77.4-63.9,77.4-107.8c0-20-17.8-40.2-57.4-40.2c-29.1,0-44.3,9.6-59.2,28.7 c-3.9,5-11.1,6-16.2,2.4l-13.1-9.2c-5.6-3.9-6.9-11.8-2.6-17.2c21.2-27.2,46.4-44.7,91.2-44.7c52.3,0,97.4,29.8,97.4,80.2 c0,67.6-77.4,63.5-77.4,107.8C275.7,306.6,270.3,312,263.7,312z'\n }),\n children: reduceMotion ? [] : [\n {\n tag: 'animate',\n attributes: _objectSpread2(_objectSpread2({\n }, OPACITY_ANIMATE), {\n }, {\n values: '1;0;0;0;0;1;'\n })\n }\n ]\n });\n if (!reduceMotion) // Exclamation\n gChildren.push({\n tag: 'path',\n attributes: _objectSpread2(_objectSpread2({\n }, FILL), {\n }, {\n opacity: '0',\n d: 'M232.5,134.5l7,168c0.3,6.4,5.6,11.5,12,11.5h9c6.4,0,11.7-5.1,12-11.5l7-168c0.3-6.8-5.2-12.5-12-12.5h-23 C237.7,122,232.2,127.7,232.5,134.5z'\n }),\n children: [\n {\n tag: 'animate',\n attributes: _objectSpread2(_objectSpread2({\n }, OPACITY_ANIMATE), {\n }, {\n values: '0;0;1;1;0;0;'\n })\n }\n ]\n });\n return {\n tag: 'g',\n attributes: {\n 'class': 'missing'\n },\n children: gChildren\n };\n };\n }\n};\nvar SvgSymbols = {\n hooks: function hooks() {\n return {\n parseNodeAttributes: function parseNodeAttributes(accumulator, node) {\n var symbolData = node.getAttribute('data-fa-symbol');\n var symbol = symbolData === null ? false : symbolData === '' ? true : symbolData;\n accumulator['symbol'] = symbol;\n return accumulator;\n }\n };\n }\n};\nvar plugins = [\n InjectCSS,\n ReplaceElements,\n Layers,\n LayersCounter,\n LayersText,\n PseudoElements,\n MutationObserver$1,\n PowerTransforms,\n Masks,\n MissingIconIndicator,\n SvgSymbols\n];\nregisterPlugins(plugins, {\n mixoutsTo: api\n});\nvar noAuto$1 = api.noAuto;\nvar config$1 = api.config;\nvar library$1 = api.library;\nvar dom$1 = api.dom;\nvar parse$1 = api.parse;\nvar findIconDefinition$1 = api.findIconDefinition;\nvar toHtml$1 = api.toHtml;\nvar icon = api.icon;\nvar layer = api.layer;\nvar text = api.text;\nvar counter = api.counter;\n\n},{\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"gHbN2\":[function(require,module,exports) {\nvar ReactIs = require('react-is');\n// By explicitly using `prop-types` you are opting into new development behavior.\n// http://fb.me/prop-types-in-prod\nvar throwOnDirectAccess = true;\nmodule.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);\n\n},{\"react-is\":\"kg7L7\",\"./factoryWithTypeCheckers\":\"4vxFI\"}],\"kg7L7\":[function(require,module,exports) {\n'use strict';\nmodule.exports = require('./cjs/react-is.development.js');\n\n},{\"./cjs/react-is.development.js\":\"l5DXi\"}],\"l5DXi\":[function(require,module,exports) {\n/** @license React v16.13.1\n * react-is.development.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */ 'use strict';\n(function() {\n // The Symbol used to tag the ReactElement-like types. If there is no native Symbol\n // nor polyfill, then a plain number is used for performance.\n var hasSymbol = typeof Symbol === 'function' && Symbol.for;\n var REACT_ELEMENT_TYPE = hasSymbol ? Symbol.for('react.element') : 60103;\n var REACT_PORTAL_TYPE = hasSymbol ? Symbol.for('react.portal') : 60106;\n var REACT_FRAGMENT_TYPE = hasSymbol ? Symbol.for('react.fragment') : 60107;\n var REACT_STRICT_MODE_TYPE = hasSymbol ? Symbol.for('react.strict_mode') : 60108;\n var REACT_PROFILER_TYPE = hasSymbol ? Symbol.for('react.profiler') : 60114;\n var REACT_PROVIDER_TYPE = hasSymbol ? Symbol.for('react.provider') : 60109;\n var REACT_CONTEXT_TYPE = hasSymbol ? Symbol.for('react.context') : 60110; // TODO: We don't use AsyncMode or ConcurrentMode anymore. They were temporary\n // (unstable) APIs that have been removed. Can we remove the symbols?\n var REACT_ASYNC_MODE_TYPE = hasSymbol ? Symbol.for('react.async_mode') : 60111;\n var REACT_CONCURRENT_MODE_TYPE = hasSymbol ? Symbol.for('react.concurrent_mode') : 60111;\n var REACT_FORWARD_REF_TYPE = hasSymbol ? Symbol.for('react.forward_ref') : 60112;\n var REACT_SUSPENSE_TYPE = hasSymbol ? Symbol.for('react.suspense') : 60113;\n var REACT_SUSPENSE_LIST_TYPE = hasSymbol ? Symbol.for('react.suspense_list') : 60120;\n var REACT_MEMO_TYPE = hasSymbol ? Symbol.for('react.memo') : 60115;\n var REACT_LAZY_TYPE = hasSymbol ? Symbol.for('react.lazy') : 60116;\n var REACT_BLOCK_TYPE = hasSymbol ? Symbol.for('react.block') : 60121;\n var REACT_FUNDAMENTAL_TYPE = hasSymbol ? Symbol.for('react.fundamental') : 60117;\n var REACT_RESPONDER_TYPE = hasSymbol ? Symbol.for('react.responder') : 60118;\n var REACT_SCOPE_TYPE = hasSymbol ? Symbol.for('react.scope') : 60119;\n function isValidElementType(type) {\n return typeof type === 'string' || typeof type === 'function' || type === REACT_FRAGMENT_TYPE || type === REACT_CONCURRENT_MODE_TYPE || type === REACT_PROFILER_TYPE || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || typeof type === 'object' && type !== null && (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_PROVIDER_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE || type.$$typeof === REACT_FUNDAMENTAL_TYPE || type.$$typeof === REACT_RESPONDER_TYPE || type.$$typeof === REACT_SCOPE_TYPE || type.$$typeof === REACT_BLOCK_TYPE);\n }\n function typeOf(object) {\n if (typeof object === 'object' && object !== null) {\n var $$typeof = object.$$typeof;\n switch($$typeof){\n case REACT_ELEMENT_TYPE:\n var type = object.type;\n switch(type){\n case REACT_ASYNC_MODE_TYPE:\n case REACT_CONCURRENT_MODE_TYPE:\n case REACT_FRAGMENT_TYPE:\n case REACT_PROFILER_TYPE:\n case REACT_STRICT_MODE_TYPE:\n case REACT_SUSPENSE_TYPE:\n return type;\n default:\n var $$typeofType = type && type.$$typeof;\n switch($$typeofType){\n case REACT_CONTEXT_TYPE:\n case REACT_FORWARD_REF_TYPE:\n case REACT_LAZY_TYPE:\n case REACT_MEMO_TYPE:\n case REACT_PROVIDER_TYPE:\n return $$typeofType;\n default:\n return $$typeof;\n }\n }\n case REACT_PORTAL_TYPE:\n return $$typeof;\n }\n }\n return undefined;\n } // AsyncMode is deprecated along with isAsyncMode\n var AsyncMode = REACT_ASYNC_MODE_TYPE;\n var ConcurrentMode = REACT_CONCURRENT_MODE_TYPE;\n var ContextConsumer = REACT_CONTEXT_TYPE;\n var ContextProvider = REACT_PROVIDER_TYPE;\n var Element = REACT_ELEMENT_TYPE;\n var ForwardRef = REACT_FORWARD_REF_TYPE;\n var Fragment = REACT_FRAGMENT_TYPE;\n var Lazy = REACT_LAZY_TYPE;\n var Memo = REACT_MEMO_TYPE;\n var Portal = REACT_PORTAL_TYPE;\n var Profiler = REACT_PROFILER_TYPE;\n var StrictMode = REACT_STRICT_MODE_TYPE;\n var Suspense = REACT_SUSPENSE_TYPE;\n var hasWarnedAboutDeprecatedIsAsyncMode = false; // AsyncMode should be deprecated\n function isAsyncMode(object) {\n if (!hasWarnedAboutDeprecatedIsAsyncMode) {\n hasWarnedAboutDeprecatedIsAsyncMode = true; // Using console['warn'] to evade Babel and ESLint\n console['warn'](\"The ReactIs.isAsyncMode() alias has been deprecated, and will be removed in React 17+. Update your code to use ReactIs.isConcurrentMode() instead. It has the exact same API.\");\n }\n return isConcurrentMode(object) || typeOf(object) === REACT_ASYNC_MODE_TYPE;\n }\n function isConcurrentMode(object) {\n return typeOf(object) === REACT_CONCURRENT_MODE_TYPE;\n }\n function isContextConsumer(object) {\n return typeOf(object) === REACT_CONTEXT_TYPE;\n }\n function isContextProvider(object) {\n return typeOf(object) === REACT_PROVIDER_TYPE;\n }\n function isElement(object) {\n return typeof object === 'object' && object !== null && object.$$typeof === REACT_ELEMENT_TYPE;\n }\n function isForwardRef(object) {\n return typeOf(object) === REACT_FORWARD_REF_TYPE;\n }\n function isFragment(object) {\n return typeOf(object) === REACT_FRAGMENT_TYPE;\n }\n function isLazy(object) {\n return typeOf(object) === REACT_LAZY_TYPE;\n }\n function isMemo(object) {\n return typeOf(object) === REACT_MEMO_TYPE;\n }\n function isPortal(object) {\n return typeOf(object) === REACT_PORTAL_TYPE;\n }\n function isProfiler(object) {\n return typeOf(object) === REACT_PROFILER_TYPE;\n }\n function isStrictMode(object) {\n return typeOf(object) === REACT_STRICT_MODE_TYPE;\n }\n function isSuspense(object) {\n return typeOf(object) === REACT_SUSPENSE_TYPE;\n }\n exports.AsyncMode = AsyncMode;\n exports.ConcurrentMode = ConcurrentMode;\n exports.ContextConsumer = ContextConsumer;\n exports.ContextProvider = ContextProvider;\n exports.Element = Element;\n exports.ForwardRef = ForwardRef;\n exports.Fragment = Fragment;\n exports.Lazy = Lazy;\n exports.Memo = Memo;\n exports.Portal = Portal;\n exports.Profiler = Profiler;\n exports.StrictMode = StrictMode;\n exports.Suspense = Suspense;\n exports.isAsyncMode = isAsyncMode;\n exports.isConcurrentMode = isConcurrentMode;\n exports.isContextConsumer = isContextConsumer;\n exports.isContextProvider = isContextProvider;\n exports.isElement = isElement;\n exports.isForwardRef = isForwardRef;\n exports.isFragment = isFragment;\n exports.isLazy = isLazy;\n exports.isMemo = isMemo;\n exports.isPortal = isPortal;\n exports.isProfiler = isProfiler;\n exports.isStrictMode = isStrictMode;\n exports.isSuspense = isSuspense;\n exports.isValidElementType = isValidElementType;\n exports.typeOf = typeOf;\n})();\n\n},{}],\"4vxFI\":[function(require,module,exports) {\n/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */ 'use strict';\nvar ReactIs = require('react-is');\nvar assign = require('object-assign');\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\nvar has = require('./lib/has');\nvar checkPropTypes = require('./checkPropTypes');\nvar printWarning = function() {\n};\nprintWarning = function(text) {\n var message = 'Warning: ' + text;\n if (typeof console !== 'undefined') console.error(message);\n try {\n // --- Welcome to debugging React ---\n // This error was thrown as a convenience so that you can use this stack\n // to find the callsite that caused this warning to fire.\n throw new Error(message);\n } catch (x) {\n }\n};\nfunction emptyFunctionThatReturnsNull() {\n return null;\n}\nmodule.exports = function(isValidElement, throwOnDirectAccess) {\n /* global Symbol */ var ITERATOR_SYMBOL = typeof Symbol === 'function' && Symbol.iterator;\n var FAUX_ITERATOR_SYMBOL = '@@iterator'; // Before Symbol spec.\n /**\n * Returns the iterator method function contained on the iterable object.\n *\n * Be sure to invoke the function with the iterable as context:\n *\n * var iteratorFn = getIteratorFn(myIterable);\n * if (iteratorFn) {\n * var iterator = iteratorFn.call(myIterable);\n * ...\n * }\n *\n * @param {?object} maybeIterable\n * @return {?function}\n */ function getIteratorFn(maybeIterable) {\n var iteratorFn = maybeIterable && (ITERATOR_SYMBOL && maybeIterable[ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL]);\n if (typeof iteratorFn === 'function') return iteratorFn;\n }\n /**\n * Collection of methods that allow declaration and validation of props that are\n * supplied to React components. Example usage:\n *\n * var Props = require('ReactPropTypes');\n * var MyArticle = React.createClass({\n * propTypes: {\n * // An optional string prop named \"description\".\n * description: Props.string,\n *\n * // A required enum prop named \"category\".\n * category: Props.oneOf(['News','Photos']).isRequired,\n *\n * // A prop named \"dialog\" that requires an instance of Dialog.\n * dialog: Props.instanceOf(Dialog).isRequired\n * },\n * render: function() { ... }\n * });\n *\n * A more formal specification of how these methods are used:\n *\n * type := array|bool|func|object|number|string|oneOf([...])|instanceOf(...)\n * decl := ReactPropTypes.{type}(.isRequired)?\n *\n * Each and every declaration produces a function with the same signature. This\n * allows the creation of custom validation functions. For example:\n *\n * var MyLink = React.createClass({\n * propTypes: {\n * // An optional string or URI prop named \"href\".\n * href: function(props, propName, componentName) {\n * var propValue = props[propName];\n * if (propValue != null && typeof propValue !== 'string' &&\n * !(propValue instanceof URI)) {\n * return new Error(\n * 'Expected a string or an URI for ' + propName + ' in ' +\n * componentName\n * );\n * }\n * }\n * },\n * render: function() {...}\n * });\n *\n * @internal\n */ var ANONYMOUS = '<<anonymous>>';\n // Important!\n // Keep this list in sync with production version in `./factoryWithThrowingShims.js`.\n var ReactPropTypes = {\n array: createPrimitiveTypeChecker('array'),\n bigint: createPrimitiveTypeChecker('bigint'),\n bool: createPrimitiveTypeChecker('boolean'),\n func: createPrimitiveTypeChecker('function'),\n number: createPrimitiveTypeChecker('number'),\n object: createPrimitiveTypeChecker('object'),\n string: createPrimitiveTypeChecker('string'),\n symbol: createPrimitiveTypeChecker('symbol'),\n any: createAnyTypeChecker(),\n arrayOf: createArrayOfTypeChecker,\n element: createElementTypeChecker(),\n elementType: createElementTypeTypeChecker(),\n instanceOf: createInstanceTypeChecker,\n node: createNodeChecker(),\n objectOf: createObjectOfTypeChecker,\n oneOf: createEnumTypeChecker,\n oneOfType: createUnionTypeChecker,\n shape: createShapeTypeChecker,\n exact: createStrictShapeTypeChecker\n };\n /**\n * inlined Object.is polyfill to avoid requiring consumers ship their own\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is\n */ /*eslint-disable no-self-compare*/ function is(x, y) {\n // SameValue algorithm\n if (x === y) // Steps 1-5, 7-10\n // Steps 6.b-6.e: +0 != -0\n return x !== 0 || 1 / x === 1 / y;\n else // Step 6.a: NaN == NaN\n return x !== x && y !== y;\n }\n /*eslint-enable no-self-compare*/ /**\n * We use an Error-like object for backward compatibility as people may call\n * PropTypes directly and inspect their output. However, we don't use real\n * Errors anymore. We don't inspect their stack anyway, and creating them\n * is prohibitively expensive if they are created too often, such as what\n * happens in oneOfType() for any type before the one that matched.\n */ function PropTypeError(message, data) {\n this.message = message;\n this.data = data && typeof data === 'object' ? data : {\n };\n this.stack = '';\n }\n // Make `instanceof Error` still work for returned errors.\n PropTypeError.prototype = Error.prototype;\n function createChainableTypeChecker(validate) {\n var manualPropTypeCallCache = {\n };\n var manualPropTypeWarningCount = 0;\n function checkType(isRequired, props, propName, componentName, location, propFullName, secret) {\n componentName = componentName || ANONYMOUS;\n propFullName = propFullName || propName;\n if (secret !== ReactPropTypesSecret) {\n if (throwOnDirectAccess) {\n // New behavior only for users of `prop-types` package\n var err = new Error(\"Calling PropTypes validators directly is not supported by the `prop-types` package. Use `PropTypes.checkPropTypes()` to call them. Read more at http://fb.me/use-check-prop-types\");\n err.name = 'Invariant Violation';\n throw err;\n } else if (typeof console !== 'undefined') {\n // Old behavior for people using React.PropTypes\n var cacheKey = componentName + ':' + propName;\n if (!manualPropTypeCallCache[cacheKey] && // Avoid spamming the console because they are often not actionable except for lib authors\n manualPropTypeWarningCount < 3) {\n printWarning(\"You are manually calling a React.PropTypes validation function for the `\" + propFullName + '` prop on `' + componentName + '`. This is deprecated ' + 'and will throw in the standalone `prop-types` package. ' + 'You may be seeing this warning due to a third-party PropTypes ' + 'library. See https://fb.me/react-warning-dont-call-proptypes ' + 'for details.');\n manualPropTypeCallCache[cacheKey] = true;\n manualPropTypeWarningCount++;\n }\n }\n }\n if (props[propName] == null) {\n if (isRequired) {\n if (props[propName] === null) return new PropTypeError('The ' + location + ' `' + propFullName + '` is marked as required ' + ('in `' + componentName + '`, but its value is `null`.'));\n return new PropTypeError('The ' + location + ' `' + propFullName + '` is marked as required in ' + ('`' + componentName + '`, but its value is `undefined`.'));\n }\n return null;\n } else return validate(props, propName, componentName, location, propFullName);\n }\n var chainedCheckType = checkType.bind(null, false);\n chainedCheckType.isRequired = checkType.bind(null, true);\n return chainedCheckType;\n }\n function createPrimitiveTypeChecker(expectedType) {\n function validate(props, propName, componentName, location, propFullName, secret) {\n var propValue = props[propName];\n var propType = getPropType(propValue);\n if (propType !== expectedType) {\n // `propValue` being instance of, say, date/regexp, pass the 'object'\n // check, but we can offer a more precise error message here rather than\n // 'of type `object`'.\n var preciseType = getPreciseType(propValue);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + preciseType + '` supplied to `' + componentName + '`, expected ') + ('`' + expectedType + '`.'), {\n expectedType: expectedType\n });\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n function createAnyTypeChecker() {\n return createChainableTypeChecker(emptyFunctionThatReturnsNull);\n }\n function createArrayOfTypeChecker(typeChecker) {\n function validate(props, propName, componentName, location, propFullName) {\n if (typeof typeChecker !== 'function') return new PropTypeError('Property `' + propFullName + '` of component `' + componentName + '` has invalid PropType notation inside arrayOf.');\n var propValue = props[propName];\n if (!Array.isArray(propValue)) {\n var propType = getPropType(propValue);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected an array.'));\n }\n for(var i = 0; i < propValue.length; i++){\n var error = typeChecker(propValue, i, componentName, location, propFullName + '[' + i + ']', ReactPropTypesSecret);\n if (error instanceof Error) return error;\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n function createElementTypeChecker() {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n if (!isValidElement(propValue)) {\n var propType = getPropType(propValue);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected a single ReactElement.'));\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n function createElementTypeTypeChecker() {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n if (!ReactIs.isValidElementType(propValue)) {\n var propType = getPropType(propValue);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected a single ReactElement type.'));\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n function createInstanceTypeChecker(expectedClass) {\n function validate(props, propName, componentName, location, propFullName) {\n if (!(props[propName] instanceof expectedClass)) {\n var expectedClassName = expectedClass.name || ANONYMOUS;\n var actualClassName = getClassName(props[propName]);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + actualClassName + '` supplied to `' + componentName + '`, expected ') + ('instance of `' + expectedClassName + '`.'));\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n function createEnumTypeChecker(expectedValues) {\n if (!Array.isArray(expectedValues)) {\n {\n if (arguments.length > 1) printWarning('Invalid arguments supplied to oneOf, expected an array, got ' + arguments.length + ' arguments. ' + 'A common mistake is to write oneOf(x, y, z) instead of oneOf([x, y, z]).');\n else printWarning('Invalid argument supplied to oneOf, expected an array.');\n }\n return emptyFunctionThatReturnsNull;\n }\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n for(var i = 0; i < expectedValues.length; i++){\n if (is(propValue, expectedValues[i])) return null;\n }\n var valuesString = JSON.stringify(expectedValues, function replacer(key, value) {\n var type = getPreciseType(value);\n if (type === 'symbol') return String(value);\n return value;\n });\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of value `' + String(propValue) + '` ' + ('supplied to `' + componentName + '`, expected one of ' + valuesString + '.'));\n }\n return createChainableTypeChecker(validate);\n }\n function createObjectOfTypeChecker(typeChecker) {\n function validate(props, propName, componentName, location, propFullName) {\n if (typeof typeChecker !== 'function') return new PropTypeError('Property `' + propFullName + '` of component `' + componentName + '` has invalid PropType notation inside objectOf.');\n var propValue = props[propName];\n var propType = getPropType(propValue);\n if (propType !== 'object') return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected an object.'));\n for(var key in propValue)if (has(propValue, key)) {\n var error = typeChecker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret);\n if (error instanceof Error) return error;\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n function createUnionTypeChecker(arrayOfTypeCheckers) {\n if (!Array.isArray(arrayOfTypeCheckers)) {\n printWarning('Invalid argument supplied to oneOfType, expected an instance of array.');\n return emptyFunctionThatReturnsNull;\n }\n for(var i1 = 0; i1 < arrayOfTypeCheckers.length; i1++){\n var checker = arrayOfTypeCheckers[i1];\n if (typeof checker !== 'function') {\n printWarning(\"Invalid argument supplied to oneOfType. Expected an array of check functions, but received \" + getPostfixForTypeWarning(checker) + ' at index ' + i1 + '.');\n return emptyFunctionThatReturnsNull;\n }\n }\n function validate(props, propName, componentName, location, propFullName) {\n var expectedTypes = [];\n for(var i = 0; i < arrayOfTypeCheckers.length; i++){\n var checker = arrayOfTypeCheckers[i];\n var checkerResult = checker(props, propName, componentName, location, propFullName, ReactPropTypesSecret);\n if (checkerResult == null) return null;\n if (checkerResult.data && has(checkerResult.data, 'expectedType')) expectedTypes.push(checkerResult.data.expectedType);\n }\n var expectedTypesMessage = expectedTypes.length > 0 ? ', expected one of type [' + expectedTypes.join(', ') + ']' : '';\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`' + expectedTypesMessage + '.'));\n }\n return createChainableTypeChecker(validate);\n }\n function createNodeChecker() {\n function validate(props, propName, componentName, location, propFullName) {\n if (!isNode(props[propName])) return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`, expected a ReactNode.'));\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n function invalidValidatorError(componentName, location, propFullName, key, type) {\n return new PropTypeError((componentName || 'React class') + ': ' + location + ' type `' + propFullName + '.' + key + '` is invalid; ' + 'it must be a function, usually from the `prop-types` package, but received `' + type + '`.');\n }\n function createShapeTypeChecker(shapeTypes) {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n var propType = getPropType(propValue);\n if (propType !== 'object') return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type `' + propType + '` ' + ('supplied to `' + componentName + '`, expected `object`.'));\n for(var key in shapeTypes){\n var checker = shapeTypes[key];\n if (typeof checker !== 'function') return invalidValidatorError(componentName, location, propFullName, key, getPreciseType(checker));\n var error = checker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret);\n if (error) return error;\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n function createStrictShapeTypeChecker(shapeTypes) {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n var propType = getPropType(propValue);\n if (propType !== 'object') return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type `' + propType + '` ' + ('supplied to `' + componentName + '`, expected `object`.'));\n // We need to check all keys in case some are required but missing from props.\n var allKeys = assign({\n }, props[propName], shapeTypes);\n for(var key in allKeys){\n var checker = shapeTypes[key];\n if (has(shapeTypes, key) && typeof checker !== 'function') return invalidValidatorError(componentName, location, propFullName, key, getPreciseType(checker));\n if (!checker) return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` key `' + key + '` supplied to `' + componentName + '`.' + '\\nBad object: ' + JSON.stringify(props[propName], null, ' ') + '\\nValid keys: ' + JSON.stringify(Object.keys(shapeTypes), null, ' '));\n var error = checker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret);\n if (error) return error;\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n function isNode(propValue) {\n switch(typeof propValue){\n case 'number':\n case 'string':\n case 'undefined':\n return true;\n case 'boolean':\n return !propValue;\n case 'object':\n if (Array.isArray(propValue)) return propValue.every(isNode);\n if (propValue === null || isValidElement(propValue)) return true;\n var iteratorFn = getIteratorFn(propValue);\n if (iteratorFn) {\n var iterator = iteratorFn.call(propValue);\n var step;\n if (iteratorFn !== propValue.entries) while(!(step = iterator.next()).done){\n if (!isNode(step.value)) return false;\n }\n else // Iterator will provide entry [k,v] tuples rather than values.\n while(!(step = iterator.next()).done){\n var entry = step.value;\n if (entry) {\n if (!isNode(entry[1])) return false;\n }\n }\n } else return false;\n return true;\n default:\n return false;\n }\n }\n function isSymbol(propType, propValue) {\n // Native Symbol.\n if (propType === 'symbol') return true;\n // falsy value can't be a Symbol\n if (!propValue) return false;\n // 19.4.3.5 Symbol.prototype[@@toStringTag] === 'Symbol'\n if (propValue['@@toStringTag'] === 'Symbol') return true;\n // Fallback for non-spec compliant Symbols which are polyfilled.\n if (typeof Symbol === 'function' && propValue instanceof Symbol) return true;\n return false;\n }\n // Equivalent of `typeof` but with special handling for array and regexp.\n function getPropType(propValue) {\n var propType = typeof propValue;\n if (Array.isArray(propValue)) return 'array';\n if (propValue instanceof RegExp) // Old webkits (at least until Android 4.0) return 'function' rather than\n // 'object' for typeof a RegExp. We'll normalize this here so that /bla/\n // passes PropTypes.object.\n return 'object';\n if (isSymbol(propType, propValue)) return 'symbol';\n return propType;\n }\n // This handles more types than `getPropType`. Only used for error messages.\n // See `createPrimitiveTypeChecker`.\n function getPreciseType(propValue) {\n if (typeof propValue === 'undefined' || propValue === null) return '' + propValue;\n var propType = getPropType(propValue);\n if (propType === 'object') {\n if (propValue instanceof Date) return 'date';\n else if (propValue instanceof RegExp) return 'regexp';\n }\n return propType;\n }\n // Returns a string that is postfixed to a warning about an invalid type.\n // For example, \"undefined\" or \"of type array\"\n function getPostfixForTypeWarning(value) {\n var type = getPreciseType(value);\n switch(type){\n case 'array':\n case 'object':\n return 'an ' + type;\n case 'boolean':\n case 'date':\n case 'regexp':\n return 'a ' + type;\n default:\n return type;\n }\n }\n // Returns class name of the object, if any.\n function getClassName(propValue) {\n if (!propValue.constructor || !propValue.constructor.name) return ANONYMOUS;\n return propValue.constructor.name;\n }\n ReactPropTypes.checkPropTypes = checkPropTypes;\n ReactPropTypes.resetWarningCache = checkPropTypes.resetWarningCache;\n ReactPropTypes.PropTypes = ReactPropTypes;\n return ReactPropTypes;\n};\n\n},{\"react-is\":\"kg7L7\",\"object-assign\":\"7zBzH\",\"./lib/ReactPropTypesSecret\":\"kVyB5\",\"./lib/has\":\"3t298\",\"./checkPropTypes\":\"7x1ED\"}],\"kVyB5\":[function(require,module,exports) {\n/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */ 'use strict';\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\nmodule.exports = ReactPropTypesSecret;\n\n},{}],\"3t298\":[function(require,module,exports) {\nmodule.exports = Function.call.bind(Object.prototype.hasOwnProperty);\n\n},{}],\"7x1ED\":[function(require,module,exports) {\n/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */ 'use strict';\nvar printWarning = function() {\n};\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\nvar loggedTypeFailures = {\n};\nvar has = require('./lib/has');\nprintWarning = function(text) {\n var message = 'Warning: ' + text;\n if (typeof console !== 'undefined') console.error(message);\n try {\n // --- Welcome to debugging React ---\n // This error was thrown as a convenience so that you can use this stack\n // to find the callsite that caused this warning to fire.\n throw new Error(message);\n } catch (x) {\n }\n};\n/**\n * Assert that the values match with the type specs.\n * Error messages are memorized and will only be shown once.\n *\n * @param {object} typeSpecs Map of name to a ReactPropType\n * @param {object} values Runtime values that need to be type-checked\n * @param {string} location e.g. \"prop\", \"context\", \"child context\"\n * @param {string} componentName Name of the component for error messages.\n * @param {?Function} getStack Returns the component stack.\n * @private\n */ function checkPropTypes(typeSpecs, values, location, componentName, getStack) {\n for(var typeSpecName in typeSpecs)if (has(typeSpecs, typeSpecName)) {\n var error;\n // Prop type validation may throw. In case they do, we don't want to\n // fail the render phase where it didn't fail before. So we log it.\n // After these have been cleaned up, we'll let them throw.\n try {\n // This is intentionally an invariant that gets caught. It's the same\n // behavior as without this statement except with a better message.\n if (typeof typeSpecs[typeSpecName] !== 'function') {\n var err = Error((componentName || 'React class') + ': ' + location + ' type `' + typeSpecName + '` is invalid; ' + 'it must be a function, usually from the `prop-types` package, but received `' + typeof typeSpecs[typeSpecName] + '`.' + 'This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.');\n err.name = 'Invariant Violation';\n throw err;\n }\n error = typeSpecs[typeSpecName](values, typeSpecName, componentName, location, null, ReactPropTypesSecret);\n } catch (ex) {\n error = ex;\n }\n if (error && !(error instanceof Error)) printWarning((componentName || 'React class') + ': type specification of ' + location + ' `' + typeSpecName + '` is invalid; the type checker ' + 'function must return `null` or an `Error` but returned a ' + typeof error + '. ' + 'You may have forgotten to pass an argument to the type checker ' + 'creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and ' + 'shape all require an argument).');\n if (error instanceof Error && !(error.message in loggedTypeFailures)) {\n // Only monitor this failure once because there tends to be a lot of the\n // same error.\n loggedTypeFailures[error.message] = true;\n var stack = getStack ? getStack() : '';\n printWarning('Failed ' + location + ' type: ' + error.message + (stack != null ? stack : ''));\n }\n }\n}\n/**\n * Resets warning cache when testing.\n *\n * @private\n */ checkPropTypes.resetWarningCache = function() {\n loggedTypeFailures = {\n };\n};\nmodule.exports = checkPropTypes;\n\n},{\"./lib/ReactPropTypesSecret\":\"kVyB5\",\"./lib/has\":\"3t298\"}],\"km3Ru\":[function(require,module,exports) {\n\"use strict\";\nvar Refresh = require('react-refresh/runtime');\nfunction debounce(func, delay) {\n var args1;\n var timeout = undefined;\n return function(args) {\n clearTimeout(timeout);\n timeout = setTimeout(function() {\n timeout = undefined;\n func.call(null, args);\n }, delay);\n };\n}\nvar enqueueUpdate = debounce(function() {\n Refresh.performReactRefresh();\n}, 30); // Everthing below is either adapted or copied from\n// https://github.com/facebook/metro/blob/61de16bd1edd7e738dd0311c89555a644023ab2d/packages/metro/src/lib/polyfills/require.js\n// MIT License - Copyright (c) Facebook, Inc. and its affiliates.\nmodule.exports.prelude = function(module) {\n window.$RefreshReg$ = function(type, id) {\n Refresh.register(type, module.id + ' ' + id);\n };\n window.$RefreshSig$ = Refresh.createSignatureFunctionForTransform;\n};\nmodule.exports.postlude = function(module) {\n if (isReactRefreshBoundary(module.exports)) {\n registerExportsForReactRefresh(module);\n if (module.hot) {\n module.hot.dispose(function(data) {\n if (Refresh.hasUnrecoverableErrors()) window.location.reload();\n data.prevExports = module.exports;\n });\n module.hot.accept(function(getParents) {\n var prevExports = module.hot.data.prevExports;\n var nextExports = module.exports; // Since we just executed the code for it, it's possible\n // that the new exports make it ineligible for being a boundary.\n var isNoLongerABoundary = !isReactRefreshBoundary(nextExports); // It can also become ineligible if its exports are incompatible\n // with the previous exports.\n // For example, if you add/remove/change exports, we'll want\n // to re-execute the importing modules, and force those components\n // to re-render. Similarly, if you convert a class component\n // to a function, we want to invalidate the boundary.\n var didInvalidate = shouldInvalidateReactRefreshBoundary(prevExports, nextExports);\n if (isNoLongerABoundary || didInvalidate) {\n // We'll be conservative. The only case in which we won't do a full\n // reload is if all parent modules are also refresh boundaries.\n // In that case we'll add them to the current queue.\n var parents = getParents();\n if (parents.length === 0) {\n // Looks like we bubbled to the root. Can't recover from that.\n window.location.reload();\n return;\n }\n return parents;\n }\n enqueueUpdate();\n });\n }\n }\n};\nfunction isReactRefreshBoundary(exports) {\n if (Refresh.isLikelyComponentType(exports)) return true;\n if (exports == null || typeof exports !== 'object') // Exit if we can't iterate over exports.\n return false;\n var hasExports = false;\n var areAllExportsComponents = true;\n let isESM = '__esModule' in exports;\n for(var key in exports){\n hasExports = true;\n if (key === '__esModule') continue;\n var desc = Object.getOwnPropertyDescriptor(exports, key);\n if (desc && desc.get && !isESM) // Don't invoke getters for CJS as they may have side effects.\n return false;\n var exportValue = exports[key];\n if (!Refresh.isLikelyComponentType(exportValue)) areAllExportsComponents = false;\n }\n return hasExports && areAllExportsComponents;\n}\nfunction shouldInvalidateReactRefreshBoundary(prevExports, nextExports) {\n var prevSignature = getRefreshBoundarySignature(prevExports);\n var nextSignature = getRefreshBoundarySignature(nextExports);\n if (prevSignature.length !== nextSignature.length) return true;\n for(var i = 0; i < nextSignature.length; i++){\n if (prevSignature[i] !== nextSignature[i]) return true;\n }\n return false;\n} // When this signature changes, it's unsafe to stop at this refresh boundary.\nfunction getRefreshBoundarySignature(exports) {\n var signature = [];\n signature.push(Refresh.getFamilyByType(exports));\n if (exports == null || typeof exports !== 'object') // Exit if we can't iterate over exports.\n // (This is important for legacy environments.)\n return signature;\n let isESM = '__esModule' in exports;\n for(var key in exports){\n if (key === '__esModule') continue;\n var desc = Object.getOwnPropertyDescriptor(exports, key);\n if (desc && desc.get && !isESM) continue;\n var exportValue = exports[key];\n signature.push(key);\n signature.push(Refresh.getFamilyByType(exportValue));\n }\n return signature;\n}\nfunction registerExportsForReactRefresh(module) {\n var exports = module.exports, id = module.id;\n Refresh.register(exports, id + ' %exports%');\n if (exports == null || typeof exports !== 'object') // Exit if we can't iterate over exports.\n // (This is important for legacy environments.)\n return;\n let isESM = '__esModule' in exports;\n for(var key in exports){\n var desc = Object.getOwnPropertyDescriptor(exports, key);\n if (desc && desc.get && !isESM) continue;\n var exportValue = exports[key];\n Refresh.register(exportValue, id + ' %exports% ' + key);\n }\n}\n\n},{\"react-refresh/runtime\":\"jEdJI\"}],\"jEdJI\":[function(require,module,exports) {\n'use strict';\nmodule.exports = require('./cjs/react-refresh-runtime.development.js');\n\n},{\"./cjs/react-refresh-runtime.development.js\":\"uTjV2\"}],\"uTjV2\":[function(require,module,exports) {\n/** @license React v0.9.0\n * react-refresh-runtime.development.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */ 'use strict';\n(function() {\n // ATTENTION\n // When adding new symbols to this file,\n // Please consider also adding to 'react-devtools-shared/src/backend/ReactSymbols'\n // The Symbol used to tag the ReactElement-like types. If there is no native Symbol\n // nor polyfill, then a plain number is used for performance.\n var REACT_ELEMENT_TYPE = 60103;\n var REACT_PORTAL_TYPE = 60106;\n var REACT_FRAGMENT_TYPE = 60107;\n var REACT_STRICT_MODE_TYPE = 60108;\n var REACT_PROFILER_TYPE = 60114;\n var REACT_PROVIDER_TYPE = 60109;\n var REACT_CONTEXT_TYPE = 60110;\n var REACT_FORWARD_REF_TYPE = 60112;\n var REACT_SUSPENSE_TYPE = 60113;\n var REACT_SUSPENSE_LIST_TYPE = 60120;\n var REACT_MEMO_TYPE = 60115;\n var REACT_LAZY_TYPE = 60116;\n var REACT_BLOCK_TYPE = 60121;\n var REACT_SERVER_BLOCK_TYPE = 60122;\n var REACT_FUNDAMENTAL_TYPE = 60117;\n var REACT_SCOPE_TYPE = 60119;\n var REACT_OPAQUE_ID_TYPE = 60128;\n var REACT_DEBUG_TRACING_MODE_TYPE = 60129;\n var REACT_OFFSCREEN_TYPE = 60130;\n var REACT_LEGACY_HIDDEN_TYPE = 60131;\n if (typeof Symbol === 'function' && Symbol.for) {\n var symbolFor = Symbol.for;\n REACT_ELEMENT_TYPE = symbolFor('react.element');\n REACT_PORTAL_TYPE = symbolFor('react.portal');\n REACT_FRAGMENT_TYPE = symbolFor('react.fragment');\n REACT_STRICT_MODE_TYPE = symbolFor('react.strict_mode');\n REACT_PROFILER_TYPE = symbolFor('react.profiler');\n REACT_PROVIDER_TYPE = symbolFor('react.provider');\n REACT_CONTEXT_TYPE = symbolFor('react.context');\n REACT_FORWARD_REF_TYPE = symbolFor('react.forward_ref');\n REACT_SUSPENSE_TYPE = symbolFor('react.suspense');\n REACT_SUSPENSE_LIST_TYPE = symbolFor('react.suspense_list');\n REACT_MEMO_TYPE = symbolFor('react.memo');\n REACT_LAZY_TYPE = symbolFor('react.lazy');\n REACT_BLOCK_TYPE = symbolFor('react.block');\n REACT_SERVER_BLOCK_TYPE = symbolFor('react.server.block');\n REACT_FUNDAMENTAL_TYPE = symbolFor('react.fundamental');\n REACT_SCOPE_TYPE = symbolFor('react.scope');\n REACT_OPAQUE_ID_TYPE = symbolFor('react.opaque.id');\n REACT_DEBUG_TRACING_MODE_TYPE = symbolFor('react.debug_trace_mode');\n REACT_OFFSCREEN_TYPE = symbolFor('react.offscreen');\n REACT_LEGACY_HIDDEN_TYPE = symbolFor('react.legacy_hidden');\n }\n var PossiblyWeakMap = typeof WeakMap === 'function' ? WeakMap : Map; // We never remove these associations.\n // It's OK to reference families, but use WeakMap/Set for types.\n var allFamiliesByID = new Map();\n var allFamiliesByType = new PossiblyWeakMap();\n var allSignaturesByType = new PossiblyWeakMap(); // This WeakMap is read by React, so we only put families\n // that have actually been edited here. This keeps checks fast.\n // $FlowIssue\n var updatedFamiliesByType = new PossiblyWeakMap(); // This is cleared on every performReactRefresh() call.\n // It is an array of [Family, NextType] tuples.\n var pendingUpdates = []; // This is injected by the renderer via DevTools global hook.\n var helpersByRendererID = new Map();\n var helpersByRoot = new Map(); // We keep track of mounted roots so we can schedule updates.\n var mountedRoots = new Set(); // If a root captures an error, we remember it so we can retry on edit.\n var failedRoots = new Set(); // In environments that support WeakMap, we also remember the last element for every root.\n // It needs to be weak because we do this even for roots that failed to mount.\n // If there is no WeakMap, we won't attempt to do retrying.\n // $FlowIssue\n var rootElements = typeof WeakMap === 'function' ? new WeakMap() : null;\n var isPerformingRefresh = false;\n function computeFullKey(signature) {\n if (signature.fullKey !== null) return signature.fullKey;\n var fullKey = signature.ownKey;\n var hooks;\n try {\n hooks = signature.getCustomHooks();\n } catch (err) {\n // This can happen in an edge case, e.g. if expression like Foo.useSomething\n // depends on Foo which is lazily initialized during rendering.\n // In that case just assume we'll have to remount.\n signature.forceReset = true;\n signature.fullKey = fullKey;\n return fullKey;\n }\n for(var i = 0; i < hooks.length; i++){\n var hook = hooks[i];\n if (typeof hook !== 'function') {\n // Something's wrong. Assume we need to remount.\n signature.forceReset = true;\n signature.fullKey = fullKey;\n return fullKey;\n }\n var nestedHookSignature = allSignaturesByType.get(hook);\n if (nestedHookSignature === undefined) continue;\n var nestedHookKey = computeFullKey(nestedHookSignature);\n if (nestedHookSignature.forceReset) signature.forceReset = true;\n fullKey += '\\n---\\n' + nestedHookKey;\n }\n signature.fullKey = fullKey;\n return fullKey;\n }\n function haveEqualSignatures(prevType, nextType) {\n var prevSignature = allSignaturesByType.get(prevType);\n var nextSignature = allSignaturesByType.get(nextType);\n if (prevSignature === undefined && nextSignature === undefined) return true;\n if (prevSignature === undefined || nextSignature === undefined) return false;\n if (computeFullKey(prevSignature) !== computeFullKey(nextSignature)) return false;\n if (nextSignature.forceReset) return false;\n return true;\n }\n function isReactClass(type) {\n return type.prototype && type.prototype.isReactComponent;\n }\n function canPreserveStateBetween(prevType, nextType) {\n if (isReactClass(prevType) || isReactClass(nextType)) return false;\n if (haveEqualSignatures(prevType, nextType)) return true;\n return false;\n }\n function resolveFamily(type) {\n // Only check updated types to keep lookups fast.\n return updatedFamiliesByType.get(type);\n } // If we didn't care about IE11, we could use new Map/Set(iterable).\n function cloneMap(map) {\n var clone = new Map();\n map.forEach(function(value, key) {\n clone.set(key, value);\n });\n return clone;\n }\n function cloneSet(set) {\n var clone = new Set();\n set.forEach(function(value) {\n clone.add(value);\n });\n return clone;\n }\n function performReactRefresh() {\n if (pendingUpdates.length === 0) return null;\n if (isPerformingRefresh) return null;\n isPerformingRefresh = true;\n try {\n var staleFamilies = new Set();\n var updatedFamilies = new Set();\n var updates = pendingUpdates;\n pendingUpdates = [];\n updates.forEach(function(_ref) {\n var family = _ref[0], nextType = _ref[1];\n // Now that we got a real edit, we can create associations\n // that will be read by the React reconciler.\n var prevType = family.current;\n updatedFamiliesByType.set(prevType, family);\n updatedFamiliesByType.set(nextType, family);\n family.current = nextType; // Determine whether this should be a re-render or a re-mount.\n if (canPreserveStateBetween(prevType, nextType)) updatedFamilies.add(family);\n else staleFamilies.add(family);\n }); // TODO: rename these fields to something more meaningful.\n var update = {\n updatedFamilies: updatedFamilies,\n // Families that will re-render preserving state\n staleFamilies: staleFamilies // Families that will be remounted\n };\n helpersByRendererID.forEach(function(helpers) {\n // Even if there are no roots, set the handler on first update.\n // This ensures that if *new* roots are mounted, they'll use the resolve handler.\n helpers.setRefreshHandler(resolveFamily);\n });\n var didError = false;\n var firstError = null; // We snapshot maps and sets that are mutated during commits.\n // If we don't do this, there is a risk they will be mutated while\n // we iterate over them. For example, trying to recover a failed root\n // may cause another root to be added to the failed list -- an infinite loop.\n var failedRootsSnapshot = cloneSet(failedRoots);\n var mountedRootsSnapshot = cloneSet(mountedRoots);\n var helpersByRootSnapshot = cloneMap(helpersByRoot);\n failedRootsSnapshot.forEach(function(root) {\n var helpers = helpersByRootSnapshot.get(root);\n if (helpers === undefined) throw new Error('Could not find helpers for a root. This is a bug in React Refresh.');\n failedRoots.has(root);\n if (rootElements === null) return;\n if (!rootElements.has(root)) return;\n var element = rootElements.get(root);\n try {\n helpers.scheduleRoot(root, element);\n } catch (err) {\n if (!didError) {\n didError = true;\n firstError = err;\n } // Keep trying other roots.\n }\n });\n mountedRootsSnapshot.forEach(function(root) {\n var helpers = helpersByRootSnapshot.get(root);\n if (helpers === undefined) throw new Error('Could not find helpers for a root. This is a bug in React Refresh.');\n mountedRoots.has(root);\n try {\n helpers.scheduleRefresh(root, update);\n } catch (err) {\n if (!didError) {\n didError = true;\n firstError = err;\n } // Keep trying other roots.\n }\n });\n if (didError) throw firstError;\n return update;\n } finally{\n isPerformingRefresh = false;\n }\n }\n function register(type, id) {\n if (type === null) return;\n if (typeof type !== 'function' && typeof type !== 'object') return;\n // This can happen in an edge case, e.g. if we register\n // return value of a HOC but it returns a cached component.\n // Ignore anything but the first registration for each type.\n if (allFamiliesByType.has(type)) return;\n // Create family or remember to update it.\n // None of this bookkeeping affects reconciliation\n // until the first performReactRefresh() call above.\n var family = allFamiliesByID.get(id);\n if (family === undefined) {\n family = {\n current: type\n };\n allFamiliesByID.set(id, family);\n } else pendingUpdates.push([\n family,\n type\n ]);\n allFamiliesByType.set(type, family); // Visit inner types because we might not have registered them.\n if (typeof type === 'object' && type !== null) switch(type.$$typeof){\n case REACT_FORWARD_REF_TYPE:\n register(type.render, id + '$render');\n break;\n case REACT_MEMO_TYPE:\n register(type.type, id + '$type');\n break;\n }\n }\n function setSignature(type, key) {\n var forceReset = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;\n var getCustomHooks = arguments.length > 3 ? arguments[3] : undefined;\n allSignaturesByType.set(type, {\n forceReset: forceReset,\n ownKey: key,\n fullKey: null,\n getCustomHooks: getCustomHooks || function() {\n return [];\n }\n });\n } // This is lazily called during first render for a type.\n // It captures Hook list at that time so inline requires don't break comparisons.\n function collectCustomHooksForSignature(type) {\n var signature = allSignaturesByType.get(type);\n if (signature !== undefined) computeFullKey(signature);\n }\n function getFamilyByID(id) {\n return allFamiliesByID.get(id);\n }\n function getFamilyByType(type) {\n return allFamiliesByType.get(type);\n }\n function findAffectedHostInstances(families) {\n var affectedInstances = new Set();\n mountedRoots.forEach(function(root) {\n var helpers = helpersByRoot.get(root);\n if (helpers === undefined) throw new Error('Could not find helpers for a root. This is a bug in React Refresh.');\n var instancesForRoot = helpers.findHostInstancesForRefresh(root, families);\n instancesForRoot.forEach(function(inst) {\n affectedInstances.add(inst);\n });\n });\n return affectedInstances;\n }\n function injectIntoGlobalHook(globalObject) {\n // For React Native, the global hook will be set up by require('react-devtools-core').\n // That code will run before us. So we need to monkeypatch functions on existing hook.\n // For React Web, the global hook will be set up by the extension.\n // This will also run before us.\n var hook = globalObject.__REACT_DEVTOOLS_GLOBAL_HOOK__;\n if (hook === undefined) {\n // However, if there is no DevTools extension, we'll need to set up the global hook ourselves.\n // Note that in this case it's important that renderer code runs *after* this method call.\n // Otherwise, the renderer will think that there is no global hook, and won't do the injection.\n var nextID = 0;\n globalObject.__REACT_DEVTOOLS_GLOBAL_HOOK__ = hook = {\n renderers: new Map(),\n supportsFiber: true,\n inject: function(injected) {\n return nextID++;\n },\n onScheduleFiberRoot: function(id, root, children) {\n },\n onCommitFiberRoot: function(id, root, maybePriorityLevel, didError) {\n },\n onCommitFiberUnmount: function() {\n }\n };\n } // Here, we just want to get a reference to scheduleRefresh.\n var oldInject = hook.inject;\n hook.inject = function(injected) {\n var id = oldInject.apply(this, arguments);\n if (typeof injected.scheduleRefresh === 'function' && typeof injected.setRefreshHandler === 'function') // This version supports React Refresh.\n helpersByRendererID.set(id, injected);\n return id;\n }; // Do the same for any already injected roots.\n // This is useful if ReactDOM has already been initialized.\n // https://github.com/facebook/react/issues/17626\n hook.renderers.forEach(function(injected, id) {\n if (typeof injected.scheduleRefresh === 'function' && typeof injected.setRefreshHandler === 'function') // This version supports React Refresh.\n helpersByRendererID.set(id, injected);\n }); // We also want to track currently mounted roots.\n var oldOnCommitFiberRoot = hook.onCommitFiberRoot;\n var oldOnScheduleFiberRoot = hook.onScheduleFiberRoot || function() {\n };\n hook.onScheduleFiberRoot = function(id, root, children) {\n if (!isPerformingRefresh) {\n // If it was intentionally scheduled, don't attempt to restore.\n // This includes intentionally scheduled unmounts.\n failedRoots.delete(root);\n if (rootElements !== null) rootElements.set(root, children);\n }\n return oldOnScheduleFiberRoot.apply(this, arguments);\n };\n hook.onCommitFiberRoot = function(id, root, maybePriorityLevel, didError) {\n var helpers = helpersByRendererID.get(id);\n if (helpers === undefined) return;\n helpersByRoot.set(root, helpers);\n var current = root.current;\n var alternate = current.alternate; // We need to determine whether this root has just (un)mounted.\n // This logic is copy-pasted from similar logic in the DevTools backend.\n // If this breaks with some refactoring, you'll want to update DevTools too.\n if (alternate !== null) {\n var wasMounted = alternate.memoizedState != null && alternate.memoizedState.element != null;\n var isMounted = current.memoizedState != null && current.memoizedState.element != null;\n if (!wasMounted && isMounted) {\n // Mount a new root.\n mountedRoots.add(root);\n failedRoots.delete(root);\n } else if (wasMounted && isMounted) ;\n else if (wasMounted && !isMounted) {\n // Unmount an existing root.\n mountedRoots.delete(root);\n if (didError) // We'll remount it on future edits.\n failedRoots.add(root);\n else helpersByRoot.delete(root);\n } else if (!wasMounted && !isMounted) {\n if (didError) // We'll remount it on future edits.\n failedRoots.add(root);\n }\n } else // Mount a new root.\n mountedRoots.add(root);\n return oldOnCommitFiberRoot.apply(this, arguments);\n };\n }\n function hasUnrecoverableErrors() {\n // TODO: delete this after removing dependency in RN.\n return false;\n } // Exposed for testing.\n function _getMountedRootCount() {\n return mountedRoots.size;\n } // This is a wrapper over more primitive functions for setting signature.\n // Signatures let us decide whether the Hook order has changed on refresh.\n //\n // This function is intended to be used as a transform target, e.g.:\n // var _s = createSignatureFunctionForTransform()\n //\n // function Hello() {\n // const [foo, setFoo] = useState(0);\n // const value = useCustomHook();\n // _s(); /* Second call triggers collecting the custom Hook list.\n // * This doesn't happen during the module evaluation because we\n // * don't want to change the module order with inline requires.\n // * Next calls are noops. */\n // return <h1>Hi</h1>;\n // }\n //\n // /* First call specifies the signature: */\n // _s(\n // Hello,\n // 'useState{[foo, setFoo]}(0)',\n // () => [useCustomHook], /* Lazy to avoid triggering inline requires */\n // );\n function createSignatureFunctionForTransform() {\n // We'll fill in the signature in two steps.\n // First, we'll know the signature itself. This happens outside the component.\n // Then, we'll know the references to custom Hooks. This happens inside the component.\n // After that, the returned function will be a fast path no-op.\n var status = 'needsSignature';\n var savedType;\n var hasCustomHooks;\n return function(type, key, forceReset, getCustomHooks) {\n switch(status){\n case 'needsSignature':\n if (type !== undefined) {\n // If we received an argument, this is the initial registration call.\n savedType = type;\n hasCustomHooks = typeof getCustomHooks === 'function';\n setSignature(type, key, forceReset, getCustomHooks); // The next call we expect is from inside a function, to fill in the custom Hooks.\n status = 'needsCustomHooks';\n }\n break;\n case 'needsCustomHooks':\n if (hasCustomHooks) collectCustomHooksForSignature(savedType);\n status = 'resolved';\n break;\n }\n return type;\n };\n }\n function isLikelyComponentType(type) {\n switch(typeof type){\n case 'function':\n // First, deal with classes.\n if (type.prototype != null) {\n if (type.prototype.isReactComponent) // React class.\n return true;\n var ownNames = Object.getOwnPropertyNames(type.prototype);\n if (ownNames.length > 1 || ownNames[0] !== 'constructor') // This looks like a class.\n return false;\n // eslint-disable-next-line no-proto\n if (type.prototype.__proto__ !== Object.prototype) // It has a superclass.\n return false;\n // Pass through.\n // This looks like a regular function with empty prototype.\n } // For plain functions and arrows, use name as a heuristic.\n var name = type.name || type.displayName;\n return typeof name === 'string' && /^[A-Z]/.test(name);\n case 'object':\n if (type != null) switch(type.$$typeof){\n case REACT_FORWARD_REF_TYPE:\n case REACT_MEMO_TYPE:\n // Definitely React components.\n return true;\n default:\n return false;\n }\n return false;\n default:\n return false;\n }\n }\n exports._getMountedRootCount = _getMountedRootCount;\n exports.collectCustomHooksForSignature = collectCustomHooksForSignature;\n exports.createSignatureFunctionForTransform = createSignatureFunctionForTransform;\n exports.findAffectedHostInstances = findAffectedHostInstances;\n exports.getFamilyByID = getFamilyByID;\n exports.getFamilyByType = getFamilyByType;\n exports.hasUnrecoverableErrors = hasUnrecoverableErrors;\n exports.injectIntoGlobalHook = injectIntoGlobalHook;\n exports.isLikelyComponentType = isLikelyComponentType;\n exports.performReactRefresh = performReactRefresh;\n exports.register = register;\n exports.setSignature = setSignature;\n})();\n\n},{}],\"6ECLA\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"fas\", ()=>_iconsCache\n);\nparcelHelpers.export(exports, \"prefix\", ()=>prefix\n);\nparcelHelpers.export(exports, \"fa0\", ()=>fa0\n);\nparcelHelpers.export(exports, \"fa1\", ()=>fa1\n);\nparcelHelpers.export(exports, \"fa2\", ()=>fa2\n);\nparcelHelpers.export(exports, \"fa3\", ()=>fa3\n);\nparcelHelpers.export(exports, \"fa4\", ()=>fa4\n);\nparcelHelpers.export(exports, \"fa5\", ()=>fa5\n);\nparcelHelpers.export(exports, \"fa6\", ()=>fa6\n);\nparcelHelpers.export(exports, \"fa7\", ()=>fa7\n);\nparcelHelpers.export(exports, \"fa8\", ()=>fa8\n);\nparcelHelpers.export(exports, \"fa9\", ()=>fa9\n);\nparcelHelpers.export(exports, \"faA\", ()=>faA\n);\nparcelHelpers.export(exports, \"faAddressBook\", ()=>faAddressBook\n);\nparcelHelpers.export(exports, \"faContactBook\", ()=>faContactBook\n);\nparcelHelpers.export(exports, \"faAddressCard\", ()=>faAddressCard\n);\nparcelHelpers.export(exports, \"faContactCard\", ()=>faContactCard\n);\nparcelHelpers.export(exports, \"faVcard\", ()=>faVcard\n);\nparcelHelpers.export(exports, \"faAlignCenter\", ()=>faAlignCenter\n);\nparcelHelpers.export(exports, \"faAlignJustify\", ()=>faAlignJustify\n);\nparcelHelpers.export(exports, \"faAlignLeft\", ()=>faAlignLeft\n);\nparcelHelpers.export(exports, \"faAlignRight\", ()=>faAlignRight\n);\nparcelHelpers.export(exports, \"faAnchor\", ()=>faAnchor\n);\nparcelHelpers.export(exports, \"faAngleDown\", ()=>faAngleDown\n);\nparcelHelpers.export(exports, \"faAngleLeft\", ()=>faAngleLeft\n);\nparcelHelpers.export(exports, \"faAngleRight\", ()=>faAngleRight\n);\nparcelHelpers.export(exports, \"faAngleUp\", ()=>faAngleUp\n);\nparcelHelpers.export(exports, \"faAnglesDown\", ()=>faAnglesDown\n);\nparcelHelpers.export(exports, \"faAngleDoubleDown\", ()=>faAngleDoubleDown\n);\nparcelHelpers.export(exports, \"faAnglesLeft\", ()=>faAnglesLeft\n);\nparcelHelpers.export(exports, \"faAngleDoubleLeft\", ()=>faAngleDoubleLeft\n);\nparcelHelpers.export(exports, \"faAnglesRight\", ()=>faAnglesRight\n);\nparcelHelpers.export(exports, \"faAngleDoubleRight\", ()=>faAngleDoubleRight\n);\nparcelHelpers.export(exports, \"faAnglesUp\", ()=>faAnglesUp\n);\nparcelHelpers.export(exports, \"faAngleDoubleUp\", ()=>faAngleDoubleUp\n);\nparcelHelpers.export(exports, \"faAnkh\", ()=>faAnkh\n);\nparcelHelpers.export(exports, \"faAppleWhole\", ()=>faAppleWhole\n);\nparcelHelpers.export(exports, \"faAppleAlt\", ()=>faAppleAlt\n);\nparcelHelpers.export(exports, \"faArchway\", ()=>faArchway\n);\nparcelHelpers.export(exports, \"faArrowDown\", ()=>faArrowDown\n);\nparcelHelpers.export(exports, \"faArrowDown19\", ()=>faArrowDown19\n);\nparcelHelpers.export(exports, \"faSortNumericAsc\", ()=>faSortNumericAsc\n);\nparcelHelpers.export(exports, \"faSortNumericDown\", ()=>faSortNumericDown\n);\nparcelHelpers.export(exports, \"faArrowDown91\", ()=>faArrowDown91\n);\nparcelHelpers.export(exports, \"faSortNumericDesc\", ()=>faSortNumericDesc\n);\nparcelHelpers.export(exports, \"faSortNumericDownAlt\", ()=>faSortNumericDownAlt\n);\nparcelHelpers.export(exports, \"faArrowDownAZ\", ()=>faArrowDownAZ\n);\nparcelHelpers.export(exports, \"faSortAlphaAsc\", ()=>faSortAlphaAsc\n);\nparcelHelpers.export(exports, \"faSortAlphaDown\", ()=>faSortAlphaDown\n);\nparcelHelpers.export(exports, \"faArrowDownLong\", ()=>faArrowDownLong\n);\nparcelHelpers.export(exports, \"faLongArrowDown\", ()=>faLongArrowDown\n);\nparcelHelpers.export(exports, \"faArrowDownShortWide\", ()=>faArrowDownShortWide\n);\nparcelHelpers.export(exports, \"faSortAmountDesc\", ()=>faSortAmountDesc\n);\nparcelHelpers.export(exports, \"faSortAmountDownAlt\", ()=>faSortAmountDownAlt\n);\nparcelHelpers.export(exports, \"faArrowDownWideShort\", ()=>faArrowDownWideShort\n);\nparcelHelpers.export(exports, \"faSortAmountAsc\", ()=>faSortAmountAsc\n);\nparcelHelpers.export(exports, \"faSortAmountDown\", ()=>faSortAmountDown\n);\nparcelHelpers.export(exports, \"faArrowDownZA\", ()=>faArrowDownZA\n);\nparcelHelpers.export(exports, \"faSortAlphaDesc\", ()=>faSortAlphaDesc\n);\nparcelHelpers.export(exports, \"faSortAlphaDownAlt\", ()=>faSortAlphaDownAlt\n);\nparcelHelpers.export(exports, \"faArrowLeft\", ()=>faArrowLeft\n);\nparcelHelpers.export(exports, \"faArrowLeftLong\", ()=>faArrowLeftLong\n);\nparcelHelpers.export(exports, \"faLongArrowLeft\", ()=>faLongArrowLeft\n);\nparcelHelpers.export(exports, \"faArrowPointer\", ()=>faArrowPointer\n);\nparcelHelpers.export(exports, \"faMousePointer\", ()=>faMousePointer\n);\nparcelHelpers.export(exports, \"faArrowRight\", ()=>faArrowRight\n);\nparcelHelpers.export(exports, \"faArrowRightArrowLeft\", ()=>faArrowRightArrowLeft\n);\nparcelHelpers.export(exports, \"faExchange\", ()=>faExchange\n);\nparcelHelpers.export(exports, \"faArrowRightFromBracket\", ()=>faArrowRightFromBracket\n);\nparcelHelpers.export(exports, \"faSignOut\", ()=>faSignOut\n);\nparcelHelpers.export(exports, \"faArrowRightLong\", ()=>faArrowRightLong\n);\nparcelHelpers.export(exports, \"faLongArrowRight\", ()=>faLongArrowRight\n);\nparcelHelpers.export(exports, \"faArrowRightToBracket\", ()=>faArrowRightToBracket\n);\nparcelHelpers.export(exports, \"faSignIn\", ()=>faSignIn\n);\nparcelHelpers.export(exports, \"faArrowRotateLeft\", ()=>faArrowRotateLeft\n);\nparcelHelpers.export(exports, \"faArrowLeftRotate\", ()=>faArrowLeftRotate\n);\nparcelHelpers.export(exports, \"faArrowRotateBack\", ()=>faArrowRotateBack\n);\nparcelHelpers.export(exports, \"faArrowRotateBackward\", ()=>faArrowRotateBackward\n);\nparcelHelpers.export(exports, \"faUndo\", ()=>faUndo\n);\nparcelHelpers.export(exports, \"faArrowRotateRight\", ()=>faArrowRotateRight\n);\nparcelHelpers.export(exports, \"faArrowRightRotate\", ()=>faArrowRightRotate\n);\nparcelHelpers.export(exports, \"faArrowRotateForward\", ()=>faArrowRotateForward\n);\nparcelHelpers.export(exports, \"faRedo\", ()=>faRedo\n);\nparcelHelpers.export(exports, \"faArrowTrendDown\", ()=>faArrowTrendDown\n);\nparcelHelpers.export(exports, \"faArrowTrendUp\", ()=>faArrowTrendUp\n);\nparcelHelpers.export(exports, \"faArrowTurnDown\", ()=>faArrowTurnDown\n);\nparcelHelpers.export(exports, \"faLevelDown\", ()=>faLevelDown\n);\nparcelHelpers.export(exports, \"faArrowTurnUp\", ()=>faArrowTurnUp\n);\nparcelHelpers.export(exports, \"faLevelUp\", ()=>faLevelUp\n);\nparcelHelpers.export(exports, \"faArrowUp\", ()=>faArrowUp\n);\nparcelHelpers.export(exports, \"faArrowUp19\", ()=>faArrowUp19\n);\nparcelHelpers.export(exports, \"faSortNumericUp\", ()=>faSortNumericUp\n);\nparcelHelpers.export(exports, \"faArrowUp91\", ()=>faArrowUp91\n);\nparcelHelpers.export(exports, \"faSortNumericUpAlt\", ()=>faSortNumericUpAlt\n);\nparcelHelpers.export(exports, \"faArrowUpAZ\", ()=>faArrowUpAZ\n);\nparcelHelpers.export(exports, \"faSortAlphaUp\", ()=>faSortAlphaUp\n);\nparcelHelpers.export(exports, \"faArrowUpFromBracket\", ()=>faArrowUpFromBracket\n);\nparcelHelpers.export(exports, \"faArrowUpLong\", ()=>faArrowUpLong\n);\nparcelHelpers.export(exports, \"faLongArrowUp\", ()=>faLongArrowUp\n);\nparcelHelpers.export(exports, \"faArrowUpRightFromSquare\", ()=>faArrowUpRightFromSquare\n);\nparcelHelpers.export(exports, \"faExternalLink\", ()=>faExternalLink\n);\nparcelHelpers.export(exports, \"faArrowUpShortWide\", ()=>faArrowUpShortWide\n);\nparcelHelpers.export(exports, \"faSortAmountUpAlt\", ()=>faSortAmountUpAlt\n);\nparcelHelpers.export(exports, \"faArrowUpWideShort\", ()=>faArrowUpWideShort\n);\nparcelHelpers.export(exports, \"faSortAmountUp\", ()=>faSortAmountUp\n);\nparcelHelpers.export(exports, \"faArrowUpZA\", ()=>faArrowUpZA\n);\nparcelHelpers.export(exports, \"faSortAlphaUpAlt\", ()=>faSortAlphaUpAlt\n);\nparcelHelpers.export(exports, \"faArrowsLeftRight\", ()=>faArrowsLeftRight\n);\nparcelHelpers.export(exports, \"faArrowsH\", ()=>faArrowsH\n);\nparcelHelpers.export(exports, \"faArrowsRotate\", ()=>faArrowsRotate\n);\nparcelHelpers.export(exports, \"faRefresh\", ()=>faRefresh\n);\nparcelHelpers.export(exports, \"faSync\", ()=>faSync\n);\nparcelHelpers.export(exports, \"faArrowsUpDown\", ()=>faArrowsUpDown\n);\nparcelHelpers.export(exports, \"faArrowsV\", ()=>faArrowsV\n);\nparcelHelpers.export(exports, \"faArrowsUpDownLeftRight\", ()=>faArrowsUpDownLeftRight\n);\nparcelHelpers.export(exports, \"faArrows\", ()=>faArrows\n);\nparcelHelpers.export(exports, \"faAsterisk\", ()=>faAsterisk\n);\nparcelHelpers.export(exports, \"faAt\", ()=>faAt\n);\nparcelHelpers.export(exports, \"faAtom\", ()=>faAtom\n);\nparcelHelpers.export(exports, \"faAudioDescription\", ()=>faAudioDescription\n);\nparcelHelpers.export(exports, \"faAustralSign\", ()=>faAustralSign\n);\nparcelHelpers.export(exports, \"faAward\", ()=>faAward\n);\nparcelHelpers.export(exports, \"faB\", ()=>faB\n);\nparcelHelpers.export(exports, \"faBaby\", ()=>faBaby\n);\nparcelHelpers.export(exports, \"faBabyCarriage\", ()=>faBabyCarriage\n);\nparcelHelpers.export(exports, \"faCarriageBaby\", ()=>faCarriageBaby\n);\nparcelHelpers.export(exports, \"faBackward\", ()=>faBackward\n);\nparcelHelpers.export(exports, \"faBackwardFast\", ()=>faBackwardFast\n);\nparcelHelpers.export(exports, \"faFastBackward\", ()=>faFastBackward\n);\nparcelHelpers.export(exports, \"faBackwardStep\", ()=>faBackwardStep\n);\nparcelHelpers.export(exports, \"faStepBackward\", ()=>faStepBackward\n);\nparcelHelpers.export(exports, \"faBacon\", ()=>faBacon\n);\nparcelHelpers.export(exports, \"faBacteria\", ()=>faBacteria\n);\nparcelHelpers.export(exports, \"faBacterium\", ()=>faBacterium\n);\nparcelHelpers.export(exports, \"faBagShopping\", ()=>faBagShopping\n);\nparcelHelpers.export(exports, \"faShoppingBag\", ()=>faShoppingBag\n);\nparcelHelpers.export(exports, \"faBahai\", ()=>faBahai\n);\nparcelHelpers.export(exports, \"faBahtSign\", ()=>faBahtSign\n);\nparcelHelpers.export(exports, \"faBan\", ()=>faBan\n);\nparcelHelpers.export(exports, \"faCancel\", ()=>faCancel\n);\nparcelHelpers.export(exports, \"faBanSmoking\", ()=>faBanSmoking\n);\nparcelHelpers.export(exports, \"faSmokingBan\", ()=>faSmokingBan\n);\nparcelHelpers.export(exports, \"faBandage\", ()=>faBandage\n);\nparcelHelpers.export(exports, \"faBandAid\", ()=>faBandAid\n);\nparcelHelpers.export(exports, \"faBarcode\", ()=>faBarcode\n);\nparcelHelpers.export(exports, \"faBars\", ()=>faBars\n);\nparcelHelpers.export(exports, \"faNavicon\", ()=>faNavicon\n);\nparcelHelpers.export(exports, \"faBarsProgress\", ()=>faBarsProgress\n);\nparcelHelpers.export(exports, \"faTasksAlt\", ()=>faTasksAlt\n);\nparcelHelpers.export(exports, \"faBarsStaggered\", ()=>faBarsStaggered\n);\nparcelHelpers.export(exports, \"faReorder\", ()=>faReorder\n);\nparcelHelpers.export(exports, \"faStream\", ()=>faStream\n);\nparcelHelpers.export(exports, \"faBaseball\", ()=>faBaseball\n);\nparcelHelpers.export(exports, \"faBaseballBall\", ()=>faBaseballBall\n);\nparcelHelpers.export(exports, \"faBaseballBatBall\", ()=>faBaseballBatBall\n);\nparcelHelpers.export(exports, \"faBasketShopping\", ()=>faBasketShopping\n);\nparcelHelpers.export(exports, \"faShoppingBasket\", ()=>faShoppingBasket\n);\nparcelHelpers.export(exports, \"faBasketball\", ()=>faBasketball\n);\nparcelHelpers.export(exports, \"faBasketballBall\", ()=>faBasketballBall\n);\nparcelHelpers.export(exports, \"faBath\", ()=>faBath\n);\nparcelHelpers.export(exports, \"faBathtub\", ()=>faBathtub\n);\nparcelHelpers.export(exports, \"faBatteryEmpty\", ()=>faBatteryEmpty\n);\nparcelHelpers.export(exports, \"faBattery0\", ()=>faBattery0\n);\nparcelHelpers.export(exports, \"faBatteryFull\", ()=>faBatteryFull\n);\nparcelHelpers.export(exports, \"faBattery\", ()=>faBattery\n);\nparcelHelpers.export(exports, \"faBattery5\", ()=>faBattery5\n);\nparcelHelpers.export(exports, \"faBatteryHalf\", ()=>faBatteryHalf\n);\nparcelHelpers.export(exports, \"faBattery3\", ()=>faBattery3\n);\nparcelHelpers.export(exports, \"faBatteryQuarter\", ()=>faBatteryQuarter\n);\nparcelHelpers.export(exports, \"faBattery2\", ()=>faBattery2\n);\nparcelHelpers.export(exports, \"faBatteryThreeQuarters\", ()=>faBatteryThreeQuarters\n);\nparcelHelpers.export(exports, \"faBattery4\", ()=>faBattery4\n);\nparcelHelpers.export(exports, \"faBed\", ()=>faBed\n);\nparcelHelpers.export(exports, \"faBedPulse\", ()=>faBedPulse\n);\nparcelHelpers.export(exports, \"faProcedures\", ()=>faProcedures\n);\nparcelHelpers.export(exports, \"faBeerMugEmpty\", ()=>faBeerMugEmpty\n);\nparcelHelpers.export(exports, \"faBeer\", ()=>faBeer\n);\nparcelHelpers.export(exports, \"faBell\", ()=>faBell\n);\nparcelHelpers.export(exports, \"faBellConcierge\", ()=>faBellConcierge\n);\nparcelHelpers.export(exports, \"faConciergeBell\", ()=>faConciergeBell\n);\nparcelHelpers.export(exports, \"faBellSlash\", ()=>faBellSlash\n);\nparcelHelpers.export(exports, \"faBezierCurve\", ()=>faBezierCurve\n);\nparcelHelpers.export(exports, \"faBicycle\", ()=>faBicycle\n);\nparcelHelpers.export(exports, \"faBinoculars\", ()=>faBinoculars\n);\nparcelHelpers.export(exports, \"faBiohazard\", ()=>faBiohazard\n);\nparcelHelpers.export(exports, \"faBitcoinSign\", ()=>faBitcoinSign\n);\nparcelHelpers.export(exports, \"faBlender\", ()=>faBlender\n);\nparcelHelpers.export(exports, \"faBlenderPhone\", ()=>faBlenderPhone\n);\nparcelHelpers.export(exports, \"faBlog\", ()=>faBlog\n);\nparcelHelpers.export(exports, \"faBold\", ()=>faBold\n);\nparcelHelpers.export(exports, \"faBolt\", ()=>faBolt\n);\nparcelHelpers.export(exports, \"faZap\", ()=>faZap\n);\nparcelHelpers.export(exports, \"faBoltLightning\", ()=>faBoltLightning\n);\nparcelHelpers.export(exports, \"faBomb\", ()=>faBomb\n);\nparcelHelpers.export(exports, \"faBone\", ()=>faBone\n);\nparcelHelpers.export(exports, \"faBong\", ()=>faBong\n);\nparcelHelpers.export(exports, \"faBook\", ()=>faBook\n);\nparcelHelpers.export(exports, \"faBookAtlas\", ()=>faBookAtlas\n);\nparcelHelpers.export(exports, \"faAtlas\", ()=>faAtlas\n);\nparcelHelpers.export(exports, \"faBookBible\", ()=>faBookBible\n);\nparcelHelpers.export(exports, \"faBible\", ()=>faBible\n);\nparcelHelpers.export(exports, \"faBookJournalWhills\", ()=>faBookJournalWhills\n);\nparcelHelpers.export(exports, \"faJournalWhills\", ()=>faJournalWhills\n);\nparcelHelpers.export(exports, \"faBookMedical\", ()=>faBookMedical\n);\nparcelHelpers.export(exports, \"faBookOpen\", ()=>faBookOpen\n);\nparcelHelpers.export(exports, \"faBookOpenReader\", ()=>faBookOpenReader\n);\nparcelHelpers.export(exports, \"faBookReader\", ()=>faBookReader\n);\nparcelHelpers.export(exports, \"faBookQuran\", ()=>faBookQuran\n);\nparcelHelpers.export(exports, \"faQuran\", ()=>faQuran\n);\nparcelHelpers.export(exports, \"faBookSkull\", ()=>faBookSkull\n);\nparcelHelpers.export(exports, \"faBookDead\", ()=>faBookDead\n);\nparcelHelpers.export(exports, \"faBookmark\", ()=>faBookmark\n);\nparcelHelpers.export(exports, \"faBorderAll\", ()=>faBorderAll\n);\nparcelHelpers.export(exports, \"faBorderNone\", ()=>faBorderNone\n);\nparcelHelpers.export(exports, \"faBorderTopLeft\", ()=>faBorderTopLeft\n);\nparcelHelpers.export(exports, \"faBorderStyle\", ()=>faBorderStyle\n);\nparcelHelpers.export(exports, \"faBowlingBall\", ()=>faBowlingBall\n);\nparcelHelpers.export(exports, \"faBox\", ()=>faBox\n);\nparcelHelpers.export(exports, \"faBoxArchive\", ()=>faBoxArchive\n);\nparcelHelpers.export(exports, \"faArchive\", ()=>faArchive\n);\nparcelHelpers.export(exports, \"faBoxOpen\", ()=>faBoxOpen\n);\nparcelHelpers.export(exports, \"faBoxTissue\", ()=>faBoxTissue\n);\nparcelHelpers.export(exports, \"faBoxesStacked\", ()=>faBoxesStacked\n);\nparcelHelpers.export(exports, \"faBoxes\", ()=>faBoxes\n);\nparcelHelpers.export(exports, \"faBoxesAlt\", ()=>faBoxesAlt\n);\nparcelHelpers.export(exports, \"faBraille\", ()=>faBraille\n);\nparcelHelpers.export(exports, \"faBrain\", ()=>faBrain\n);\nparcelHelpers.export(exports, \"faBrazilianRealSign\", ()=>faBrazilianRealSign\n);\nparcelHelpers.export(exports, \"faBreadSlice\", ()=>faBreadSlice\n);\nparcelHelpers.export(exports, \"faBriefcase\", ()=>faBriefcase\n);\nparcelHelpers.export(exports, \"faBriefcaseMedical\", ()=>faBriefcaseMedical\n);\nparcelHelpers.export(exports, \"faBroom\", ()=>faBroom\n);\nparcelHelpers.export(exports, \"faBroomBall\", ()=>faBroomBall\n);\nparcelHelpers.export(exports, \"faQuidditch\", ()=>faQuidditch\n);\nparcelHelpers.export(exports, \"faQuidditchBroomBall\", ()=>faQuidditchBroomBall\n);\nparcelHelpers.export(exports, \"faBrush\", ()=>faBrush\n);\nparcelHelpers.export(exports, \"faBug\", ()=>faBug\n);\nparcelHelpers.export(exports, \"faBugSlash\", ()=>faBugSlash\n);\nparcelHelpers.export(exports, \"faBuilding\", ()=>faBuilding\n);\nparcelHelpers.export(exports, \"faBuildingColumns\", ()=>faBuildingColumns\n);\nparcelHelpers.export(exports, \"faBank\", ()=>faBank\n);\nparcelHelpers.export(exports, \"faInstitution\", ()=>faInstitution\n);\nparcelHelpers.export(exports, \"faMuseum\", ()=>faMuseum\n);\nparcelHelpers.export(exports, \"faUniversity\", ()=>faUniversity\n);\nparcelHelpers.export(exports, \"faBullhorn\", ()=>faBullhorn\n);\nparcelHelpers.export(exports, \"faBullseye\", ()=>faBullseye\n);\nparcelHelpers.export(exports, \"faBurger\", ()=>faBurger\n);\nparcelHelpers.export(exports, \"faHamburger\", ()=>faHamburger\n);\nparcelHelpers.export(exports, \"faBus\", ()=>faBus\n);\nparcelHelpers.export(exports, \"faBusSimple\", ()=>faBusSimple\n);\nparcelHelpers.export(exports, \"faBusAlt\", ()=>faBusAlt\n);\nparcelHelpers.export(exports, \"faBusinessTime\", ()=>faBusinessTime\n);\nparcelHelpers.export(exports, \"faBriefcaseClock\", ()=>faBriefcaseClock\n);\nparcelHelpers.export(exports, \"faC\", ()=>faC\n);\nparcelHelpers.export(exports, \"faCakeCandles\", ()=>faCakeCandles\n);\nparcelHelpers.export(exports, \"faBirthdayCake\", ()=>faBirthdayCake\n);\nparcelHelpers.export(exports, \"faCake\", ()=>faCake\n);\nparcelHelpers.export(exports, \"faCalculator\", ()=>faCalculator\n);\nparcelHelpers.export(exports, \"faCalendar\", ()=>faCalendar\n);\nparcelHelpers.export(exports, \"faCalendarCheck\", ()=>faCalendarCheck\n);\nparcelHelpers.export(exports, \"faCalendarDay\", ()=>faCalendarDay\n);\nparcelHelpers.export(exports, \"faCalendarDays\", ()=>faCalendarDays\n);\nparcelHelpers.export(exports, \"faCalendarAlt\", ()=>faCalendarAlt\n);\nparcelHelpers.export(exports, \"faCalendarMinus\", ()=>faCalendarMinus\n);\nparcelHelpers.export(exports, \"faCalendarPlus\", ()=>faCalendarPlus\n);\nparcelHelpers.export(exports, \"faCalendarWeek\", ()=>faCalendarWeek\n);\nparcelHelpers.export(exports, \"faCalendarXmark\", ()=>faCalendarXmark\n);\nparcelHelpers.export(exports, \"faCalendarTimes\", ()=>faCalendarTimes\n);\nparcelHelpers.export(exports, \"faCamera\", ()=>faCamera\n);\nparcelHelpers.export(exports, \"faCameraAlt\", ()=>faCameraAlt\n);\nparcelHelpers.export(exports, \"faCameraRetro\", ()=>faCameraRetro\n);\nparcelHelpers.export(exports, \"faCameraRotate\", ()=>faCameraRotate\n);\nparcelHelpers.export(exports, \"faCampground\", ()=>faCampground\n);\nparcelHelpers.export(exports, \"faCandyCane\", ()=>faCandyCane\n);\nparcelHelpers.export(exports, \"faCannabis\", ()=>faCannabis\n);\nparcelHelpers.export(exports, \"faCapsules\", ()=>faCapsules\n);\nparcelHelpers.export(exports, \"faCar\", ()=>faCar\n);\nparcelHelpers.export(exports, \"faAutomobile\", ()=>faAutomobile\n);\nparcelHelpers.export(exports, \"faCarBattery\", ()=>faCarBattery\n);\nparcelHelpers.export(exports, \"faBatteryCar\", ()=>faBatteryCar\n);\nparcelHelpers.export(exports, \"faCarCrash\", ()=>faCarCrash\n);\nparcelHelpers.export(exports, \"faCarRear\", ()=>faCarRear\n);\nparcelHelpers.export(exports, \"faCarAlt\", ()=>faCarAlt\n);\nparcelHelpers.export(exports, \"faCarSide\", ()=>faCarSide\n);\nparcelHelpers.export(exports, \"faCaravan\", ()=>faCaravan\n);\nparcelHelpers.export(exports, \"faCaretDown\", ()=>faCaretDown\n);\nparcelHelpers.export(exports, \"faCaretLeft\", ()=>faCaretLeft\n);\nparcelHelpers.export(exports, \"faCaretRight\", ()=>faCaretRight\n);\nparcelHelpers.export(exports, \"faCaretUp\", ()=>faCaretUp\n);\nparcelHelpers.export(exports, \"faCarrot\", ()=>faCarrot\n);\nparcelHelpers.export(exports, \"faCartArrowDown\", ()=>faCartArrowDown\n);\nparcelHelpers.export(exports, \"faCartFlatbed\", ()=>faCartFlatbed\n);\nparcelHelpers.export(exports, \"faDollyFlatbed\", ()=>faDollyFlatbed\n);\nparcelHelpers.export(exports, \"faCartFlatbedSuitcase\", ()=>faCartFlatbedSuitcase\n);\nparcelHelpers.export(exports, \"faLuggageCart\", ()=>faLuggageCart\n);\nparcelHelpers.export(exports, \"faCartPlus\", ()=>faCartPlus\n);\nparcelHelpers.export(exports, \"faCartShopping\", ()=>faCartShopping\n);\nparcelHelpers.export(exports, \"faShoppingCart\", ()=>faShoppingCart\n);\nparcelHelpers.export(exports, \"faCashRegister\", ()=>faCashRegister\n);\nparcelHelpers.export(exports, \"faCat\", ()=>faCat\n);\nparcelHelpers.export(exports, \"faCediSign\", ()=>faCediSign\n);\nparcelHelpers.export(exports, \"faCentSign\", ()=>faCentSign\n);\nparcelHelpers.export(exports, \"faCertificate\", ()=>faCertificate\n);\nparcelHelpers.export(exports, \"faChair\", ()=>faChair\n);\nparcelHelpers.export(exports, \"faChalkboard\", ()=>faChalkboard\n);\nparcelHelpers.export(exports, \"faBlackboard\", ()=>faBlackboard\n);\nparcelHelpers.export(exports, \"faChalkboardUser\", ()=>faChalkboardUser\n);\nparcelHelpers.export(exports, \"faChalkboardTeacher\", ()=>faChalkboardTeacher\n);\nparcelHelpers.export(exports, \"faChampagneGlasses\", ()=>faChampagneGlasses\n);\nparcelHelpers.export(exports, \"faGlassCheers\", ()=>faGlassCheers\n);\nparcelHelpers.export(exports, \"faChargingStation\", ()=>faChargingStation\n);\nparcelHelpers.export(exports, \"faChartArea\", ()=>faChartArea\n);\nparcelHelpers.export(exports, \"faAreaChart\", ()=>faAreaChart\n);\nparcelHelpers.export(exports, \"faChartBar\", ()=>faChartBar\n);\nparcelHelpers.export(exports, \"faBarChart\", ()=>faBarChart\n);\nparcelHelpers.export(exports, \"faChartColumn\", ()=>faChartColumn\n);\nparcelHelpers.export(exports, \"faChartGantt\", ()=>faChartGantt\n);\nparcelHelpers.export(exports, \"faChartLine\", ()=>faChartLine\n);\nparcelHelpers.export(exports, \"faLineChart\", ()=>faLineChart\n);\nparcelHelpers.export(exports, \"faChartPie\", ()=>faChartPie\n);\nparcelHelpers.export(exports, \"faPieChart\", ()=>faPieChart\n);\nparcelHelpers.export(exports, \"faCheck\", ()=>faCheck\n);\nparcelHelpers.export(exports, \"faCheckDouble\", ()=>faCheckDouble\n);\nparcelHelpers.export(exports, \"faCheckToSlot\", ()=>faCheckToSlot\n);\nparcelHelpers.export(exports, \"faVoteYea\", ()=>faVoteYea\n);\nparcelHelpers.export(exports, \"faCheese\", ()=>faCheese\n);\nparcelHelpers.export(exports, \"faChess\", ()=>faChess\n);\nparcelHelpers.export(exports, \"faChessBishop\", ()=>faChessBishop\n);\nparcelHelpers.export(exports, \"faChessBoard\", ()=>faChessBoard\n);\nparcelHelpers.export(exports, \"faChessKing\", ()=>faChessKing\n);\nparcelHelpers.export(exports, \"faChessKnight\", ()=>faChessKnight\n);\nparcelHelpers.export(exports, \"faChessPawn\", ()=>faChessPawn\n);\nparcelHelpers.export(exports, \"faChessQueen\", ()=>faChessQueen\n);\nparcelHelpers.export(exports, \"faChessRook\", ()=>faChessRook\n);\nparcelHelpers.export(exports, \"faChevronDown\", ()=>faChevronDown\n);\nparcelHelpers.export(exports, \"faChevronLeft\", ()=>faChevronLeft\n);\nparcelHelpers.export(exports, \"faChevronRight\", ()=>faChevronRight\n);\nparcelHelpers.export(exports, \"faChevronUp\", ()=>faChevronUp\n);\nparcelHelpers.export(exports, \"faChild\", ()=>faChild\n);\nparcelHelpers.export(exports, \"faChurch\", ()=>faChurch\n);\nparcelHelpers.export(exports, \"faCircle\", ()=>faCircle\n);\nparcelHelpers.export(exports, \"faCircleArrowDown\", ()=>faCircleArrowDown\n);\nparcelHelpers.export(exports, \"faArrowCircleDown\", ()=>faArrowCircleDown\n);\nparcelHelpers.export(exports, \"faCircleArrowLeft\", ()=>faCircleArrowLeft\n);\nparcelHelpers.export(exports, \"faArrowCircleLeft\", ()=>faArrowCircleLeft\n);\nparcelHelpers.export(exports, \"faCircleArrowRight\", ()=>faCircleArrowRight\n);\nparcelHelpers.export(exports, \"faArrowCircleRight\", ()=>faArrowCircleRight\n);\nparcelHelpers.export(exports, \"faCircleArrowUp\", ()=>faCircleArrowUp\n);\nparcelHelpers.export(exports, \"faArrowCircleUp\", ()=>faArrowCircleUp\n);\nparcelHelpers.export(exports, \"faCircleCheck\", ()=>faCircleCheck\n);\nparcelHelpers.export(exports, \"faCheckCircle\", ()=>faCheckCircle\n);\nparcelHelpers.export(exports, \"faCircleChevronDown\", ()=>faCircleChevronDown\n);\nparcelHelpers.export(exports, \"faChevronCircleDown\", ()=>faChevronCircleDown\n);\nparcelHelpers.export(exports, \"faCircleChevronLeft\", ()=>faCircleChevronLeft\n);\nparcelHelpers.export(exports, \"faChevronCircleLeft\", ()=>faChevronCircleLeft\n);\nparcelHelpers.export(exports, \"faCircleChevronRight\", ()=>faCircleChevronRight\n);\nparcelHelpers.export(exports, \"faChevronCircleRight\", ()=>faChevronCircleRight\n);\nparcelHelpers.export(exports, \"faCircleChevronUp\", ()=>faCircleChevronUp\n);\nparcelHelpers.export(exports, \"faChevronCircleUp\", ()=>faChevronCircleUp\n);\nparcelHelpers.export(exports, \"faCircleDollarToSlot\", ()=>faCircleDollarToSlot\n);\nparcelHelpers.export(exports, \"faDonate\", ()=>faDonate\n);\nparcelHelpers.export(exports, \"faCircleDot\", ()=>faCircleDot\n);\nparcelHelpers.export(exports, \"faDotCircle\", ()=>faDotCircle\n);\nparcelHelpers.export(exports, \"faCircleDown\", ()=>faCircleDown\n);\nparcelHelpers.export(exports, \"faArrowAltCircleDown\", ()=>faArrowAltCircleDown\n);\nparcelHelpers.export(exports, \"faCircleExclamation\", ()=>faCircleExclamation\n);\nparcelHelpers.export(exports, \"faExclamationCircle\", ()=>faExclamationCircle\n);\nparcelHelpers.export(exports, \"faCircleH\", ()=>faCircleH\n);\nparcelHelpers.export(exports, \"faHospitalSymbol\", ()=>faHospitalSymbol\n);\nparcelHelpers.export(exports, \"faCircleHalfStroke\", ()=>faCircleHalfStroke\n);\nparcelHelpers.export(exports, \"faAdjust\", ()=>faAdjust\n);\nparcelHelpers.export(exports, \"faCircleInfo\", ()=>faCircleInfo\n);\nparcelHelpers.export(exports, \"faInfoCircle\", ()=>faInfoCircle\n);\nparcelHelpers.export(exports, \"faCircleLeft\", ()=>faCircleLeft\n);\nparcelHelpers.export(exports, \"faArrowAltCircleLeft\", ()=>faArrowAltCircleLeft\n);\nparcelHelpers.export(exports, \"faCircleMinus\", ()=>faCircleMinus\n);\nparcelHelpers.export(exports, \"faMinusCircle\", ()=>faMinusCircle\n);\nparcelHelpers.export(exports, \"faCircleNotch\", ()=>faCircleNotch\n);\nparcelHelpers.export(exports, \"faCirclePause\", ()=>faCirclePause\n);\nparcelHelpers.export(exports, \"faPauseCircle\", ()=>faPauseCircle\n);\nparcelHelpers.export(exports, \"faCirclePlay\", ()=>faCirclePlay\n);\nparcelHelpers.export(exports, \"faPlayCircle\", ()=>faPlayCircle\n);\nparcelHelpers.export(exports, \"faCirclePlus\", ()=>faCirclePlus\n);\nparcelHelpers.export(exports, \"faPlusCircle\", ()=>faPlusCircle\n);\nparcelHelpers.export(exports, \"faCircleQuestion\", ()=>faCircleQuestion\n);\nparcelHelpers.export(exports, \"faQuestionCircle\", ()=>faQuestionCircle\n);\nparcelHelpers.export(exports, \"faCircleRadiation\", ()=>faCircleRadiation\n);\nparcelHelpers.export(exports, \"faRadiationAlt\", ()=>faRadiationAlt\n);\nparcelHelpers.export(exports, \"faCircleRight\", ()=>faCircleRight\n);\nparcelHelpers.export(exports, \"faArrowAltCircleRight\", ()=>faArrowAltCircleRight\n);\nparcelHelpers.export(exports, \"faCircleStop\", ()=>faCircleStop\n);\nparcelHelpers.export(exports, \"faStopCircle\", ()=>faStopCircle\n);\nparcelHelpers.export(exports, \"faCircleUp\", ()=>faCircleUp\n);\nparcelHelpers.export(exports, \"faArrowAltCircleUp\", ()=>faArrowAltCircleUp\n);\nparcelHelpers.export(exports, \"faCircleUser\", ()=>faCircleUser\n);\nparcelHelpers.export(exports, \"faUserCircle\", ()=>faUserCircle\n);\nparcelHelpers.export(exports, \"faCircleXmark\", ()=>faCircleXmark\n);\nparcelHelpers.export(exports, \"faTimesCircle\", ()=>faTimesCircle\n);\nparcelHelpers.export(exports, \"faXmarkCircle\", ()=>faXmarkCircle\n);\nparcelHelpers.export(exports, \"faCity\", ()=>faCity\n);\nparcelHelpers.export(exports, \"faClapperboard\", ()=>faClapperboard\n);\nparcelHelpers.export(exports, \"faClipboard\", ()=>faClipboard\n);\nparcelHelpers.export(exports, \"faClipboardCheck\", ()=>faClipboardCheck\n);\nparcelHelpers.export(exports, \"faClipboardList\", ()=>faClipboardList\n);\nparcelHelpers.export(exports, \"faClock\", ()=>faClock\n);\nparcelHelpers.export(exports, \"faClockFour\", ()=>faClockFour\n);\nparcelHelpers.export(exports, \"faClockRotateLeft\", ()=>faClockRotateLeft\n);\nparcelHelpers.export(exports, \"faHistory\", ()=>faHistory\n);\nparcelHelpers.export(exports, \"faClone\", ()=>faClone\n);\nparcelHelpers.export(exports, \"faClosedCaptioning\", ()=>faClosedCaptioning\n);\nparcelHelpers.export(exports, \"faCloud\", ()=>faCloud\n);\nparcelHelpers.export(exports, \"faCloudArrowDown\", ()=>faCloudArrowDown\n);\nparcelHelpers.export(exports, \"faCloudDownload\", ()=>faCloudDownload\n);\nparcelHelpers.export(exports, \"faCloudDownloadAlt\", ()=>faCloudDownloadAlt\n);\nparcelHelpers.export(exports, \"faCloudArrowUp\", ()=>faCloudArrowUp\n);\nparcelHelpers.export(exports, \"faCloudUpload\", ()=>faCloudUpload\n);\nparcelHelpers.export(exports, \"faCloudUploadAlt\", ()=>faCloudUploadAlt\n);\nparcelHelpers.export(exports, \"faCloudMeatball\", ()=>faCloudMeatball\n);\nparcelHelpers.export(exports, \"faCloudMoon\", ()=>faCloudMoon\n);\nparcelHelpers.export(exports, \"faCloudMoonRain\", ()=>faCloudMoonRain\n);\nparcelHelpers.export(exports, \"faCloudRain\", ()=>faCloudRain\n);\nparcelHelpers.export(exports, \"faCloudShowersHeavy\", ()=>faCloudShowersHeavy\n);\nparcelHelpers.export(exports, \"faCloudSun\", ()=>faCloudSun\n);\nparcelHelpers.export(exports, \"faCloudSunRain\", ()=>faCloudSunRain\n);\nparcelHelpers.export(exports, \"faClover\", ()=>faClover\n);\nparcelHelpers.export(exports, \"faCode\", ()=>faCode\n);\nparcelHelpers.export(exports, \"faCodeBranch\", ()=>faCodeBranch\n);\nparcelHelpers.export(exports, \"faCodeCommit\", ()=>faCodeCommit\n);\nparcelHelpers.export(exports, \"faCodeCompare\", ()=>faCodeCompare\n);\nparcelHelpers.export(exports, \"faCodeFork\", ()=>faCodeFork\n);\nparcelHelpers.export(exports, \"faCodeMerge\", ()=>faCodeMerge\n);\nparcelHelpers.export(exports, \"faCodePullRequest\", ()=>faCodePullRequest\n);\nparcelHelpers.export(exports, \"faCoins\", ()=>faCoins\n);\nparcelHelpers.export(exports, \"faColonSign\", ()=>faColonSign\n);\nparcelHelpers.export(exports, \"faComment\", ()=>faComment\n);\nparcelHelpers.export(exports, \"faCommentDollar\", ()=>faCommentDollar\n);\nparcelHelpers.export(exports, \"faCommentDots\", ()=>faCommentDots\n);\nparcelHelpers.export(exports, \"faCommenting\", ()=>faCommenting\n);\nparcelHelpers.export(exports, \"faCommentMedical\", ()=>faCommentMedical\n);\nparcelHelpers.export(exports, \"faCommentSlash\", ()=>faCommentSlash\n);\nparcelHelpers.export(exports, \"faCommentSms\", ()=>faCommentSms\n);\nparcelHelpers.export(exports, \"faSms\", ()=>faSms\n);\nparcelHelpers.export(exports, \"faComments\", ()=>faComments\n);\nparcelHelpers.export(exports, \"faCommentsDollar\", ()=>faCommentsDollar\n);\nparcelHelpers.export(exports, \"faCompactDisc\", ()=>faCompactDisc\n);\nparcelHelpers.export(exports, \"faCompass\", ()=>faCompass\n);\nparcelHelpers.export(exports, \"faCompassDrafting\", ()=>faCompassDrafting\n);\nparcelHelpers.export(exports, \"faDraftingCompass\", ()=>faDraftingCompass\n);\nparcelHelpers.export(exports, \"faCompress\", ()=>faCompress\n);\nparcelHelpers.export(exports, \"faComputerMouse\", ()=>faComputerMouse\n);\nparcelHelpers.export(exports, \"faMouse\", ()=>faMouse\n);\nparcelHelpers.export(exports, \"faCookie\", ()=>faCookie\n);\nparcelHelpers.export(exports, \"faCookieBite\", ()=>faCookieBite\n);\nparcelHelpers.export(exports, \"faCopy\", ()=>faCopy\n);\nparcelHelpers.export(exports, \"faCopyright\", ()=>faCopyright\n);\nparcelHelpers.export(exports, \"faCouch\", ()=>faCouch\n);\nparcelHelpers.export(exports, \"faCreditCard\", ()=>faCreditCard\n);\nparcelHelpers.export(exports, \"faCreditCardAlt\", ()=>faCreditCardAlt\n);\nparcelHelpers.export(exports, \"faCrop\", ()=>faCrop\n);\nparcelHelpers.export(exports, \"faCropSimple\", ()=>faCropSimple\n);\nparcelHelpers.export(exports, \"faCropAlt\", ()=>faCropAlt\n);\nparcelHelpers.export(exports, \"faCross\", ()=>faCross\n);\nparcelHelpers.export(exports, \"faCrosshairs\", ()=>faCrosshairs\n);\nparcelHelpers.export(exports, \"faCrow\", ()=>faCrow\n);\nparcelHelpers.export(exports, \"faCrown\", ()=>faCrown\n);\nparcelHelpers.export(exports, \"faCrutch\", ()=>faCrutch\n);\nparcelHelpers.export(exports, \"faCruzeiroSign\", ()=>faCruzeiroSign\n);\nparcelHelpers.export(exports, \"faCube\", ()=>faCube\n);\nparcelHelpers.export(exports, \"faCubes\", ()=>faCubes\n);\nparcelHelpers.export(exports, \"faD\", ()=>faD\n);\nparcelHelpers.export(exports, \"faDatabase\", ()=>faDatabase\n);\nparcelHelpers.export(exports, \"faDeleteLeft\", ()=>faDeleteLeft\n);\nparcelHelpers.export(exports, \"faBackspace\", ()=>faBackspace\n);\nparcelHelpers.export(exports, \"faDemocrat\", ()=>faDemocrat\n);\nparcelHelpers.export(exports, \"faDesktop\", ()=>faDesktop\n);\nparcelHelpers.export(exports, \"faDesktopAlt\", ()=>faDesktopAlt\n);\nparcelHelpers.export(exports, \"faDharmachakra\", ()=>faDharmachakra\n);\nparcelHelpers.export(exports, \"faDiagramNext\", ()=>faDiagramNext\n);\nparcelHelpers.export(exports, \"faDiagramPredecessor\", ()=>faDiagramPredecessor\n);\nparcelHelpers.export(exports, \"faDiagramProject\", ()=>faDiagramProject\n);\nparcelHelpers.export(exports, \"faProjectDiagram\", ()=>faProjectDiagram\n);\nparcelHelpers.export(exports, \"faDiagramSuccessor\", ()=>faDiagramSuccessor\n);\nparcelHelpers.export(exports, \"faDiamond\", ()=>faDiamond\n);\nparcelHelpers.export(exports, \"faDiamondTurnRight\", ()=>faDiamondTurnRight\n);\nparcelHelpers.export(exports, \"faDirections\", ()=>faDirections\n);\nparcelHelpers.export(exports, \"faDice\", ()=>faDice\n);\nparcelHelpers.export(exports, \"faDiceD20\", ()=>faDiceD20\n);\nparcelHelpers.export(exports, \"faDiceD6\", ()=>faDiceD6\n);\nparcelHelpers.export(exports, \"faDiceFive\", ()=>faDiceFive\n);\nparcelHelpers.export(exports, \"faDiceFour\", ()=>faDiceFour\n);\nparcelHelpers.export(exports, \"faDiceOne\", ()=>faDiceOne\n);\nparcelHelpers.export(exports, \"faDiceSix\", ()=>faDiceSix\n);\nparcelHelpers.export(exports, \"faDiceThree\", ()=>faDiceThree\n);\nparcelHelpers.export(exports, \"faDiceTwo\", ()=>faDiceTwo\n);\nparcelHelpers.export(exports, \"faDisease\", ()=>faDisease\n);\nparcelHelpers.export(exports, \"faDivide\", ()=>faDivide\n);\nparcelHelpers.export(exports, \"faDna\", ()=>faDna\n);\nparcelHelpers.export(exports, \"faDog\", ()=>faDog\n);\nparcelHelpers.export(exports, \"faDollarSign\", ()=>faDollarSign\n);\nparcelHelpers.export(exports, \"faDollar\", ()=>faDollar\n);\nparcelHelpers.export(exports, \"faUsd\", ()=>faUsd\n);\nparcelHelpers.export(exports, \"faDolly\", ()=>faDolly\n);\nparcelHelpers.export(exports, \"faDollyBox\", ()=>faDollyBox\n);\nparcelHelpers.export(exports, \"faDongSign\", ()=>faDongSign\n);\nparcelHelpers.export(exports, \"faDoorClosed\", ()=>faDoorClosed\n);\nparcelHelpers.export(exports, \"faDoorOpen\", ()=>faDoorOpen\n);\nparcelHelpers.export(exports, \"faDove\", ()=>faDove\n);\nparcelHelpers.export(exports, \"faDownLeftAndUpRightToCenter\", ()=>faDownLeftAndUpRightToCenter\n);\nparcelHelpers.export(exports, \"faCompressAlt\", ()=>faCompressAlt\n);\nparcelHelpers.export(exports, \"faDownLong\", ()=>faDownLong\n);\nparcelHelpers.export(exports, \"faLongArrowAltDown\", ()=>faLongArrowAltDown\n);\nparcelHelpers.export(exports, \"faDownload\", ()=>faDownload\n);\nparcelHelpers.export(exports, \"faDragon\", ()=>faDragon\n);\nparcelHelpers.export(exports, \"faDrawPolygon\", ()=>faDrawPolygon\n);\nparcelHelpers.export(exports, \"faDroplet\", ()=>faDroplet\n);\nparcelHelpers.export(exports, \"faTint\", ()=>faTint\n);\nparcelHelpers.export(exports, \"faDropletSlash\", ()=>faDropletSlash\n);\nparcelHelpers.export(exports, \"faTintSlash\", ()=>faTintSlash\n);\nparcelHelpers.export(exports, \"faDrum\", ()=>faDrum\n);\nparcelHelpers.export(exports, \"faDrumSteelpan\", ()=>faDrumSteelpan\n);\nparcelHelpers.export(exports, \"faDrumstickBite\", ()=>faDrumstickBite\n);\nparcelHelpers.export(exports, \"faDumbbell\", ()=>faDumbbell\n);\nparcelHelpers.export(exports, \"faDumpster\", ()=>faDumpster\n);\nparcelHelpers.export(exports, \"faDumpsterFire\", ()=>faDumpsterFire\n);\nparcelHelpers.export(exports, \"faDungeon\", ()=>faDungeon\n);\nparcelHelpers.export(exports, \"faE\", ()=>faE\n);\nparcelHelpers.export(exports, \"faEarDeaf\", ()=>faEarDeaf\n);\nparcelHelpers.export(exports, \"faDeaf\", ()=>faDeaf\n);\nparcelHelpers.export(exports, \"faDeafness\", ()=>faDeafness\n);\nparcelHelpers.export(exports, \"faHardOfHearing\", ()=>faHardOfHearing\n);\nparcelHelpers.export(exports, \"faEarListen\", ()=>faEarListen\n);\nparcelHelpers.export(exports, \"faAssistiveListeningSystems\", ()=>faAssistiveListeningSystems\n);\nparcelHelpers.export(exports, \"faEarthAfrica\", ()=>faEarthAfrica\n);\nparcelHelpers.export(exports, \"faGlobeAfrica\", ()=>faGlobeAfrica\n);\nparcelHelpers.export(exports, \"faEarthAmericas\", ()=>faEarthAmericas\n);\nparcelHelpers.export(exports, \"faEarth\", ()=>faEarth\n);\nparcelHelpers.export(exports, \"faEarthAmerica\", ()=>faEarthAmerica\n);\nparcelHelpers.export(exports, \"faGlobeAmericas\", ()=>faGlobeAmericas\n);\nparcelHelpers.export(exports, \"faEarthAsia\", ()=>faEarthAsia\n);\nparcelHelpers.export(exports, \"faGlobeAsia\", ()=>faGlobeAsia\n);\nparcelHelpers.export(exports, \"faEarthEurope\", ()=>faEarthEurope\n);\nparcelHelpers.export(exports, \"faGlobeEurope\", ()=>faGlobeEurope\n);\nparcelHelpers.export(exports, \"faEarthOceania\", ()=>faEarthOceania\n);\nparcelHelpers.export(exports, \"faGlobeOceania\", ()=>faGlobeOceania\n);\nparcelHelpers.export(exports, \"faEgg\", ()=>faEgg\n);\nparcelHelpers.export(exports, \"faEject\", ()=>faEject\n);\nparcelHelpers.export(exports, \"faElevator\", ()=>faElevator\n);\nparcelHelpers.export(exports, \"faEllipsis\", ()=>faEllipsis\n);\nparcelHelpers.export(exports, \"faEllipsisH\", ()=>faEllipsisH\n);\nparcelHelpers.export(exports, \"faEllipsisVertical\", ()=>faEllipsisVertical\n);\nparcelHelpers.export(exports, \"faEllipsisV\", ()=>faEllipsisV\n);\nparcelHelpers.export(exports, \"faEnvelope\", ()=>faEnvelope\n);\nparcelHelpers.export(exports, \"faEnvelopeOpen\", ()=>faEnvelopeOpen\n);\nparcelHelpers.export(exports, \"faEnvelopeOpenText\", ()=>faEnvelopeOpenText\n);\nparcelHelpers.export(exports, \"faEnvelopesBulk\", ()=>faEnvelopesBulk\n);\nparcelHelpers.export(exports, \"faMailBulk\", ()=>faMailBulk\n);\nparcelHelpers.export(exports, \"faEquals\", ()=>faEquals\n);\nparcelHelpers.export(exports, \"faEraser\", ()=>faEraser\n);\nparcelHelpers.export(exports, \"faEthernet\", ()=>faEthernet\n);\nparcelHelpers.export(exports, \"faEuroSign\", ()=>faEuroSign\n);\nparcelHelpers.export(exports, \"faEur\", ()=>faEur\n);\nparcelHelpers.export(exports, \"faEuro\", ()=>faEuro\n);\nparcelHelpers.export(exports, \"faExclamation\", ()=>faExclamation\n);\nparcelHelpers.export(exports, \"faExpand\", ()=>faExpand\n);\nparcelHelpers.export(exports, \"faEye\", ()=>faEye\n);\nparcelHelpers.export(exports, \"faEyeDropper\", ()=>faEyeDropper\n);\nparcelHelpers.export(exports, \"faEyeDropperEmpty\", ()=>faEyeDropperEmpty\n);\nparcelHelpers.export(exports, \"faEyedropper\", ()=>faEyedropper\n);\nparcelHelpers.export(exports, \"faEyeLowVision\", ()=>faEyeLowVision\n);\nparcelHelpers.export(exports, \"faLowVision\", ()=>faLowVision\n);\nparcelHelpers.export(exports, \"faEyeSlash\", ()=>faEyeSlash\n);\nparcelHelpers.export(exports, \"faF\", ()=>faF\n);\nparcelHelpers.export(exports, \"faFaceAngry\", ()=>faFaceAngry\n);\nparcelHelpers.export(exports, \"faAngry\", ()=>faAngry\n);\nparcelHelpers.export(exports, \"faFaceDizzy\", ()=>faFaceDizzy\n);\nparcelHelpers.export(exports, \"faDizzy\", ()=>faDizzy\n);\nparcelHelpers.export(exports, \"faFaceFlushed\", ()=>faFaceFlushed\n);\nparcelHelpers.export(exports, \"faFlushed\", ()=>faFlushed\n);\nparcelHelpers.export(exports, \"faFaceFrown\", ()=>faFaceFrown\n);\nparcelHelpers.export(exports, \"faFrown\", ()=>faFrown\n);\nparcelHelpers.export(exports, \"faFaceFrownOpen\", ()=>faFaceFrownOpen\n);\nparcelHelpers.export(exports, \"faFrownOpen\", ()=>faFrownOpen\n);\nparcelHelpers.export(exports, \"faFaceGrimace\", ()=>faFaceGrimace\n);\nparcelHelpers.export(exports, \"faGrimace\", ()=>faGrimace\n);\nparcelHelpers.export(exports, \"faFaceGrin\", ()=>faFaceGrin\n);\nparcelHelpers.export(exports, \"faGrin\", ()=>faGrin\n);\nparcelHelpers.export(exports, \"faFaceGrinBeam\", ()=>faFaceGrinBeam\n);\nparcelHelpers.export(exports, \"faGrinBeam\", ()=>faGrinBeam\n);\nparcelHelpers.export(exports, \"faFaceGrinBeamSweat\", ()=>faFaceGrinBeamSweat\n);\nparcelHelpers.export(exports, \"faGrinBeamSweat\", ()=>faGrinBeamSweat\n);\nparcelHelpers.export(exports, \"faFaceGrinHearts\", ()=>faFaceGrinHearts\n);\nparcelHelpers.export(exports, \"faGrinHearts\", ()=>faGrinHearts\n);\nparcelHelpers.export(exports, \"faFaceGrinSquint\", ()=>faFaceGrinSquint\n);\nparcelHelpers.export(exports, \"faGrinSquint\", ()=>faGrinSquint\n);\nparcelHelpers.export(exports, \"faFaceGrinSquintTears\", ()=>faFaceGrinSquintTears\n);\nparcelHelpers.export(exports, \"faGrinSquintTears\", ()=>faGrinSquintTears\n);\nparcelHelpers.export(exports, \"faFaceGrinStars\", ()=>faFaceGrinStars\n);\nparcelHelpers.export(exports, \"faGrinStars\", ()=>faGrinStars\n);\nparcelHelpers.export(exports, \"faFaceGrinTears\", ()=>faFaceGrinTears\n);\nparcelHelpers.export(exports, \"faGrinTears\", ()=>faGrinTears\n);\nparcelHelpers.export(exports, \"faFaceGrinTongue\", ()=>faFaceGrinTongue\n);\nparcelHelpers.export(exports, \"faGrinTongue\", ()=>faGrinTongue\n);\nparcelHelpers.export(exports, \"faFaceGrinTongueSquint\", ()=>faFaceGrinTongueSquint\n);\nparcelHelpers.export(exports, \"faGrinTongueSquint\", ()=>faGrinTongueSquint\n);\nparcelHelpers.export(exports, \"faFaceGrinTongueWink\", ()=>faFaceGrinTongueWink\n);\nparcelHelpers.export(exports, \"faGrinTongueWink\", ()=>faGrinTongueWink\n);\nparcelHelpers.export(exports, \"faFaceGrinWide\", ()=>faFaceGrinWide\n);\nparcelHelpers.export(exports, \"faGrinAlt\", ()=>faGrinAlt\n);\nparcelHelpers.export(exports, \"faFaceGrinWink\", ()=>faFaceGrinWink\n);\nparcelHelpers.export(exports, \"faGrinWink\", ()=>faGrinWink\n);\nparcelHelpers.export(exports, \"faFaceKiss\", ()=>faFaceKiss\n);\nparcelHelpers.export(exports, \"faKiss\", ()=>faKiss\n);\nparcelHelpers.export(exports, \"faFaceKissBeam\", ()=>faFaceKissBeam\n);\nparcelHelpers.export(exports, \"faKissBeam\", ()=>faKissBeam\n);\nparcelHelpers.export(exports, \"faFaceKissWinkHeart\", ()=>faFaceKissWinkHeart\n);\nparcelHelpers.export(exports, \"faKissWinkHeart\", ()=>faKissWinkHeart\n);\nparcelHelpers.export(exports, \"faFaceLaugh\", ()=>faFaceLaugh\n);\nparcelHelpers.export(exports, \"faLaugh\", ()=>faLaugh\n);\nparcelHelpers.export(exports, \"faFaceLaughBeam\", ()=>faFaceLaughBeam\n);\nparcelHelpers.export(exports, \"faLaughBeam\", ()=>faLaughBeam\n);\nparcelHelpers.export(exports, \"faFaceLaughSquint\", ()=>faFaceLaughSquint\n);\nparcelHelpers.export(exports, \"faLaughSquint\", ()=>faLaughSquint\n);\nparcelHelpers.export(exports, \"faFaceLaughWink\", ()=>faFaceLaughWink\n);\nparcelHelpers.export(exports, \"faLaughWink\", ()=>faLaughWink\n);\nparcelHelpers.export(exports, \"faFaceMeh\", ()=>faFaceMeh\n);\nparcelHelpers.export(exports, \"faMeh\", ()=>faMeh\n);\nparcelHelpers.export(exports, \"faFaceMehBlank\", ()=>faFaceMehBlank\n);\nparcelHelpers.export(exports, \"faMehBlank\", ()=>faMehBlank\n);\nparcelHelpers.export(exports, \"faFaceRollingEyes\", ()=>faFaceRollingEyes\n);\nparcelHelpers.export(exports, \"faMehRollingEyes\", ()=>faMehRollingEyes\n);\nparcelHelpers.export(exports, \"faFaceSadCry\", ()=>faFaceSadCry\n);\nparcelHelpers.export(exports, \"faSadCry\", ()=>faSadCry\n);\nparcelHelpers.export(exports, \"faFaceSadTear\", ()=>faFaceSadTear\n);\nparcelHelpers.export(exports, \"faSadTear\", ()=>faSadTear\n);\nparcelHelpers.export(exports, \"faFaceSmile\", ()=>faFaceSmile\n);\nparcelHelpers.export(exports, \"faSmile\", ()=>faSmile\n);\nparcelHelpers.export(exports, \"faFaceSmileBeam\", ()=>faFaceSmileBeam\n);\nparcelHelpers.export(exports, \"faSmileBeam\", ()=>faSmileBeam\n);\nparcelHelpers.export(exports, \"faFaceSmileWink\", ()=>faFaceSmileWink\n);\nparcelHelpers.export(exports, \"faSmileWink\", ()=>faSmileWink\n);\nparcelHelpers.export(exports, \"faFaceSurprise\", ()=>faFaceSurprise\n);\nparcelHelpers.export(exports, \"faSurprise\", ()=>faSurprise\n);\nparcelHelpers.export(exports, \"faFaceTired\", ()=>faFaceTired\n);\nparcelHelpers.export(exports, \"faTired\", ()=>faTired\n);\nparcelHelpers.export(exports, \"faFan\", ()=>faFan\n);\nparcelHelpers.export(exports, \"faFaucet\", ()=>faFaucet\n);\nparcelHelpers.export(exports, \"faFax\", ()=>faFax\n);\nparcelHelpers.export(exports, \"faFeather\", ()=>faFeather\n);\nparcelHelpers.export(exports, \"faFeatherPointed\", ()=>faFeatherPointed\n);\nparcelHelpers.export(exports, \"faFeatherAlt\", ()=>faFeatherAlt\n);\nparcelHelpers.export(exports, \"faFile\", ()=>faFile\n);\nparcelHelpers.export(exports, \"faFileArrowDown\", ()=>faFileArrowDown\n);\nparcelHelpers.export(exports, \"faFileDownload\", ()=>faFileDownload\n);\nparcelHelpers.export(exports, \"faFileArrowUp\", ()=>faFileArrowUp\n);\nparcelHelpers.export(exports, \"faFileUpload\", ()=>faFileUpload\n);\nparcelHelpers.export(exports, \"faFileAudio\", ()=>faFileAudio\n);\nparcelHelpers.export(exports, \"faFileCode\", ()=>faFileCode\n);\nparcelHelpers.export(exports, \"faFileContract\", ()=>faFileContract\n);\nparcelHelpers.export(exports, \"faFileCsv\", ()=>faFileCsv\n);\nparcelHelpers.export(exports, \"faFileExcel\", ()=>faFileExcel\n);\nparcelHelpers.export(exports, \"faFileExport\", ()=>faFileExport\n);\nparcelHelpers.export(exports, \"faArrowRightFromFile\", ()=>faArrowRightFromFile\n);\nparcelHelpers.export(exports, \"faFileImage\", ()=>faFileImage\n);\nparcelHelpers.export(exports, \"faFileImport\", ()=>faFileImport\n);\nparcelHelpers.export(exports, \"faArrowRightToFile\", ()=>faArrowRightToFile\n);\nparcelHelpers.export(exports, \"faFileInvoice\", ()=>faFileInvoice\n);\nparcelHelpers.export(exports, \"faFileInvoiceDollar\", ()=>faFileInvoiceDollar\n);\nparcelHelpers.export(exports, \"faFileLines\", ()=>faFileLines\n);\nparcelHelpers.export(exports, \"faFileAlt\", ()=>faFileAlt\n);\nparcelHelpers.export(exports, \"faFileText\", ()=>faFileText\n);\nparcelHelpers.export(exports, \"faFileMedical\", ()=>faFileMedical\n);\nparcelHelpers.export(exports, \"faFilePdf\", ()=>faFilePdf\n);\nparcelHelpers.export(exports, \"faFilePowerpoint\", ()=>faFilePowerpoint\n);\nparcelHelpers.export(exports, \"faFilePrescription\", ()=>faFilePrescription\n);\nparcelHelpers.export(exports, \"faFileSignature\", ()=>faFileSignature\n);\nparcelHelpers.export(exports, \"faFileVideo\", ()=>faFileVideo\n);\nparcelHelpers.export(exports, \"faFileWaveform\", ()=>faFileWaveform\n);\nparcelHelpers.export(exports, \"faFileMedicalAlt\", ()=>faFileMedicalAlt\n);\nparcelHelpers.export(exports, \"faFileWord\", ()=>faFileWord\n);\nparcelHelpers.export(exports, \"faFileZipper\", ()=>faFileZipper\n);\nparcelHelpers.export(exports, \"faFileArchive\", ()=>faFileArchive\n);\nparcelHelpers.export(exports, \"faFill\", ()=>faFill\n);\nparcelHelpers.export(exports, \"faFillDrip\", ()=>faFillDrip\n);\nparcelHelpers.export(exports, \"faFilm\", ()=>faFilm\n);\nparcelHelpers.export(exports, \"faFilter\", ()=>faFilter\n);\nparcelHelpers.export(exports, \"faFilterCircleDollar\", ()=>faFilterCircleDollar\n);\nparcelHelpers.export(exports, \"faFunnelDollar\", ()=>faFunnelDollar\n);\nparcelHelpers.export(exports, \"faFilterCircleXmark\", ()=>faFilterCircleXmark\n);\nparcelHelpers.export(exports, \"faFingerprint\", ()=>faFingerprint\n);\nparcelHelpers.export(exports, \"faFire\", ()=>faFire\n);\nparcelHelpers.export(exports, \"faFireExtinguisher\", ()=>faFireExtinguisher\n);\nparcelHelpers.export(exports, \"faFireFlameCurved\", ()=>faFireFlameCurved\n);\nparcelHelpers.export(exports, \"faFireAlt\", ()=>faFireAlt\n);\nparcelHelpers.export(exports, \"faFireFlameSimple\", ()=>faFireFlameSimple\n);\nparcelHelpers.export(exports, \"faBurn\", ()=>faBurn\n);\nparcelHelpers.export(exports, \"faFish\", ()=>faFish\n);\nparcelHelpers.export(exports, \"faFlag\", ()=>faFlag\n);\nparcelHelpers.export(exports, \"faFlagCheckered\", ()=>faFlagCheckered\n);\nparcelHelpers.export(exports, \"faFlagUsa\", ()=>faFlagUsa\n);\nparcelHelpers.export(exports, \"faFlask\", ()=>faFlask\n);\nparcelHelpers.export(exports, \"faFloppyDisk\", ()=>faFloppyDisk\n);\nparcelHelpers.export(exports, \"faSave\", ()=>faSave\n);\nparcelHelpers.export(exports, \"faFlorinSign\", ()=>faFlorinSign\n);\nparcelHelpers.export(exports, \"faFolder\", ()=>faFolder\n);\nparcelHelpers.export(exports, \"faFolderMinus\", ()=>faFolderMinus\n);\nparcelHelpers.export(exports, \"faFolderOpen\", ()=>faFolderOpen\n);\nparcelHelpers.export(exports, \"faFolderPlus\", ()=>faFolderPlus\n);\nparcelHelpers.export(exports, \"faFolderTree\", ()=>faFolderTree\n);\nparcelHelpers.export(exports, \"faFont\", ()=>faFont\n);\nparcelHelpers.export(exports, \"faFontAwesome\", ()=>faFontAwesome\n);\nparcelHelpers.export(exports, \"faFontAwesomeFlag\", ()=>faFontAwesomeFlag\n);\nparcelHelpers.export(exports, \"faFontAwesomeLogoFull\", ()=>faFontAwesomeLogoFull\n);\nparcelHelpers.export(exports, \"faFootball\", ()=>faFootball\n);\nparcelHelpers.export(exports, \"faFootballBall\", ()=>faFootballBall\n);\nparcelHelpers.export(exports, \"faForward\", ()=>faForward\n);\nparcelHelpers.export(exports, \"faForwardFast\", ()=>faForwardFast\n);\nparcelHelpers.export(exports, \"faFastForward\", ()=>faFastForward\n);\nparcelHelpers.export(exports, \"faForwardStep\", ()=>faForwardStep\n);\nparcelHelpers.export(exports, \"faStepForward\", ()=>faStepForward\n);\nparcelHelpers.export(exports, \"faFrancSign\", ()=>faFrancSign\n);\nparcelHelpers.export(exports, \"faFrog\", ()=>faFrog\n);\nparcelHelpers.export(exports, \"faFutbol\", ()=>faFutbol\n);\nparcelHelpers.export(exports, \"faFutbolBall\", ()=>faFutbolBall\n);\nparcelHelpers.export(exports, \"faSoccerBall\", ()=>faSoccerBall\n);\nparcelHelpers.export(exports, \"faG\", ()=>faG\n);\nparcelHelpers.export(exports, \"faGamepad\", ()=>faGamepad\n);\nparcelHelpers.export(exports, \"faGasPump\", ()=>faGasPump\n);\nparcelHelpers.export(exports, \"faGauge\", ()=>faGauge\n);\nparcelHelpers.export(exports, \"faDashboard\", ()=>faDashboard\n);\nparcelHelpers.export(exports, \"faGaugeMed\", ()=>faGaugeMed\n);\nparcelHelpers.export(exports, \"faTachometerAltAverage\", ()=>faTachometerAltAverage\n);\nparcelHelpers.export(exports, \"faGaugeHigh\", ()=>faGaugeHigh\n);\nparcelHelpers.export(exports, \"faTachometerAlt\", ()=>faTachometerAlt\n);\nparcelHelpers.export(exports, \"faTachometerAltFast\", ()=>faTachometerAltFast\n);\nparcelHelpers.export(exports, \"faGaugeSimple\", ()=>faGaugeSimple\n);\nparcelHelpers.export(exports, \"faGaugeSimpleMed\", ()=>faGaugeSimpleMed\n);\nparcelHelpers.export(exports, \"faTachometerAverage\", ()=>faTachometerAverage\n);\nparcelHelpers.export(exports, \"faGaugeSimpleHigh\", ()=>faGaugeSimpleHigh\n);\nparcelHelpers.export(exports, \"faTachometer\", ()=>faTachometer\n);\nparcelHelpers.export(exports, \"faTachometerFast\", ()=>faTachometerFast\n);\nparcelHelpers.export(exports, \"faGavel\", ()=>faGavel\n);\nparcelHelpers.export(exports, \"faLegal\", ()=>faLegal\n);\nparcelHelpers.export(exports, \"faGear\", ()=>faGear\n);\nparcelHelpers.export(exports, \"faCog\", ()=>faCog\n);\nparcelHelpers.export(exports, \"faGears\", ()=>faGears\n);\nparcelHelpers.export(exports, \"faCogs\", ()=>faCogs\n);\nparcelHelpers.export(exports, \"faGem\", ()=>faGem\n);\nparcelHelpers.export(exports, \"faGenderless\", ()=>faGenderless\n);\nparcelHelpers.export(exports, \"faGhost\", ()=>faGhost\n);\nparcelHelpers.export(exports, \"faGift\", ()=>faGift\n);\nparcelHelpers.export(exports, \"faGifts\", ()=>faGifts\n);\nparcelHelpers.export(exports, \"faGlasses\", ()=>faGlasses\n);\nparcelHelpers.export(exports, \"faGlobe\", ()=>faGlobe\n);\nparcelHelpers.export(exports, \"faGolfBallTee\", ()=>faGolfBallTee\n);\nparcelHelpers.export(exports, \"faGolfBall\", ()=>faGolfBall\n);\nparcelHelpers.export(exports, \"faGopuram\", ()=>faGopuram\n);\nparcelHelpers.export(exports, \"faGraduationCap\", ()=>faGraduationCap\n);\nparcelHelpers.export(exports, \"faMortarBoard\", ()=>faMortarBoard\n);\nparcelHelpers.export(exports, \"faGreaterThan\", ()=>faGreaterThan\n);\nparcelHelpers.export(exports, \"faGreaterThanEqual\", ()=>faGreaterThanEqual\n);\nparcelHelpers.export(exports, \"faGrip\", ()=>faGrip\n);\nparcelHelpers.export(exports, \"faGripHorizontal\", ()=>faGripHorizontal\n);\nparcelHelpers.export(exports, \"faGripLines\", ()=>faGripLines\n);\nparcelHelpers.export(exports, \"faGripLinesVertical\", ()=>faGripLinesVertical\n);\nparcelHelpers.export(exports, \"faGripVertical\", ()=>faGripVertical\n);\nparcelHelpers.export(exports, \"faGuaraniSign\", ()=>faGuaraniSign\n);\nparcelHelpers.export(exports, \"faGuitar\", ()=>faGuitar\n);\nparcelHelpers.export(exports, \"faGun\", ()=>faGun\n);\nparcelHelpers.export(exports, \"faH\", ()=>faH\n);\nparcelHelpers.export(exports, \"faHammer\", ()=>faHammer\n);\nparcelHelpers.export(exports, \"faHamsa\", ()=>faHamsa\n);\nparcelHelpers.export(exports, \"faHand\", ()=>faHand\n);\nparcelHelpers.export(exports, \"faHandPaper\", ()=>faHandPaper\n);\nparcelHelpers.export(exports, \"faHandBackFist\", ()=>faHandBackFist\n);\nparcelHelpers.export(exports, \"faHandRock\", ()=>faHandRock\n);\nparcelHelpers.export(exports, \"faHandDots\", ()=>faHandDots\n);\nparcelHelpers.export(exports, \"faAllergies\", ()=>faAllergies\n);\nparcelHelpers.export(exports, \"faHandFist\", ()=>faHandFist\n);\nparcelHelpers.export(exports, \"faFistRaised\", ()=>faFistRaised\n);\nparcelHelpers.export(exports, \"faHandHolding\", ()=>faHandHolding\n);\nparcelHelpers.export(exports, \"faHandHoldingDollar\", ()=>faHandHoldingDollar\n);\nparcelHelpers.export(exports, \"faHandHoldingUsd\", ()=>faHandHoldingUsd\n);\nparcelHelpers.export(exports, \"faHandHoldingDroplet\", ()=>faHandHoldingDroplet\n);\nparcelHelpers.export(exports, \"faHandHoldingWater\", ()=>faHandHoldingWater\n);\nparcelHelpers.export(exports, \"faHandHoldingHeart\", ()=>faHandHoldingHeart\n);\nparcelHelpers.export(exports, \"faHandHoldingMedical\", ()=>faHandHoldingMedical\n);\nparcelHelpers.export(exports, \"faHandLizard\", ()=>faHandLizard\n);\nparcelHelpers.export(exports, \"faHandMiddleFinger\", ()=>faHandMiddleFinger\n);\nparcelHelpers.export(exports, \"faHandPeace\", ()=>faHandPeace\n);\nparcelHelpers.export(exports, \"faHandPointDown\", ()=>faHandPointDown\n);\nparcelHelpers.export(exports, \"faHandPointLeft\", ()=>faHandPointLeft\n);\nparcelHelpers.export(exports, \"faHandPointRight\", ()=>faHandPointRight\n);\nparcelHelpers.export(exports, \"faHandPointUp\", ()=>faHandPointUp\n);\nparcelHelpers.export(exports, \"faHandPointer\", ()=>faHandPointer\n);\nparcelHelpers.export(exports, \"faHandScissors\", ()=>faHandScissors\n);\nparcelHelpers.export(exports, \"faHandSparkles\", ()=>faHandSparkles\n);\nparcelHelpers.export(exports, \"faHandSpock\", ()=>faHandSpock\n);\nparcelHelpers.export(exports, \"faHands\", ()=>faHands\n);\nparcelHelpers.export(exports, \"faSignLanguage\", ()=>faSignLanguage\n);\nparcelHelpers.export(exports, \"faSigning\", ()=>faSigning\n);\nparcelHelpers.export(exports, \"faHandsAslInterpreting\", ()=>faHandsAslInterpreting\n);\nparcelHelpers.export(exports, \"faAmericanSignLanguageInterpreting\", ()=>faAmericanSignLanguageInterpreting\n);\nparcelHelpers.export(exports, \"faAslInterpreting\", ()=>faAslInterpreting\n);\nparcelHelpers.export(exports, \"faHandsAmericanSignLanguageInterpreting\", ()=>faHandsAmericanSignLanguageInterpreting\n);\nparcelHelpers.export(exports, \"faHandsBubbles\", ()=>faHandsBubbles\n);\nparcelHelpers.export(exports, \"faHandsWash\", ()=>faHandsWash\n);\nparcelHelpers.export(exports, \"faHandsClapping\", ()=>faHandsClapping\n);\nparcelHelpers.export(exports, \"faHandsHolding\", ()=>faHandsHolding\n);\nparcelHelpers.export(exports, \"faHandsPraying\", ()=>faHandsPraying\n);\nparcelHelpers.export(exports, \"faPrayingHands\", ()=>faPrayingHands\n);\nparcelHelpers.export(exports, \"faHandshake\", ()=>faHandshake\n);\nparcelHelpers.export(exports, \"faHandshakeAngle\", ()=>faHandshakeAngle\n);\nparcelHelpers.export(exports, \"faHandsHelping\", ()=>faHandsHelping\n);\nparcelHelpers.export(exports, \"faHandshakeSimpleSlash\", ()=>faHandshakeSimpleSlash\n);\nparcelHelpers.export(exports, \"faHandshakeAltSlash\", ()=>faHandshakeAltSlash\n);\nparcelHelpers.export(exports, \"faHandshakeSlash\", ()=>faHandshakeSlash\n);\nparcelHelpers.export(exports, \"faHanukiah\", ()=>faHanukiah\n);\nparcelHelpers.export(exports, \"faHardDrive\", ()=>faHardDrive\n);\nparcelHelpers.export(exports, \"faHdd\", ()=>faHdd\n);\nparcelHelpers.export(exports, \"faHashtag\", ()=>faHashtag\n);\nparcelHelpers.export(exports, \"faHatCowboy\", ()=>faHatCowboy\n);\nparcelHelpers.export(exports, \"faHatCowboySide\", ()=>faHatCowboySide\n);\nparcelHelpers.export(exports, \"faHatWizard\", ()=>faHatWizard\n);\nparcelHelpers.export(exports, \"faHeadSideCough\", ()=>faHeadSideCough\n);\nparcelHelpers.export(exports, \"faHeadSideCoughSlash\", ()=>faHeadSideCoughSlash\n);\nparcelHelpers.export(exports, \"faHeadSideMask\", ()=>faHeadSideMask\n);\nparcelHelpers.export(exports, \"faHeadSideVirus\", ()=>faHeadSideVirus\n);\nparcelHelpers.export(exports, \"faHeading\", ()=>faHeading\n);\nparcelHelpers.export(exports, \"faHeader\", ()=>faHeader\n);\nparcelHelpers.export(exports, \"faHeadphones\", ()=>faHeadphones\n);\nparcelHelpers.export(exports, \"faHeadphonesSimple\", ()=>faHeadphonesSimple\n);\nparcelHelpers.export(exports, \"faHeadphonesAlt\", ()=>faHeadphonesAlt\n);\nparcelHelpers.export(exports, \"faHeadset\", ()=>faHeadset\n);\nparcelHelpers.export(exports, \"faHeart\", ()=>faHeart\n);\nparcelHelpers.export(exports, \"faHeartCrack\", ()=>faHeartCrack\n);\nparcelHelpers.export(exports, \"faHeartBroken\", ()=>faHeartBroken\n);\nparcelHelpers.export(exports, \"faHeartPulse\", ()=>faHeartPulse\n);\nparcelHelpers.export(exports, \"faHeartbeat\", ()=>faHeartbeat\n);\nparcelHelpers.export(exports, \"faHelicopter\", ()=>faHelicopter\n);\nparcelHelpers.export(exports, \"faHelmetSafety\", ()=>faHelmetSafety\n);\nparcelHelpers.export(exports, \"faHardHat\", ()=>faHardHat\n);\nparcelHelpers.export(exports, \"faHatHard\", ()=>faHatHard\n);\nparcelHelpers.export(exports, \"faHighlighter\", ()=>faHighlighter\n);\nparcelHelpers.export(exports, \"faHippo\", ()=>faHippo\n);\nparcelHelpers.export(exports, \"faHockeyPuck\", ()=>faHockeyPuck\n);\nparcelHelpers.export(exports, \"faHollyBerry\", ()=>faHollyBerry\n);\nparcelHelpers.export(exports, \"faHorse\", ()=>faHorse\n);\nparcelHelpers.export(exports, \"faHorseHead\", ()=>faHorseHead\n);\nparcelHelpers.export(exports, \"faHospital\", ()=>faHospital\n);\nparcelHelpers.export(exports, \"faHospitalAlt\", ()=>faHospitalAlt\n);\nparcelHelpers.export(exports, \"faHospitalWide\", ()=>faHospitalWide\n);\nparcelHelpers.export(exports, \"faHospitalUser\", ()=>faHospitalUser\n);\nparcelHelpers.export(exports, \"faHotTubPerson\", ()=>faHotTubPerson\n);\nparcelHelpers.export(exports, \"faHotTub\", ()=>faHotTub\n);\nparcelHelpers.export(exports, \"faHotdog\", ()=>faHotdog\n);\nparcelHelpers.export(exports, \"faHotel\", ()=>faHotel\n);\nparcelHelpers.export(exports, \"faHourglass\", ()=>faHourglass\n);\nparcelHelpers.export(exports, \"faHourglass2\", ()=>faHourglass2\n);\nparcelHelpers.export(exports, \"faHourglassHalf\", ()=>faHourglassHalf\n);\nparcelHelpers.export(exports, \"faHourglassEmpty\", ()=>faHourglassEmpty\n);\nparcelHelpers.export(exports, \"faHourglassEnd\", ()=>faHourglassEnd\n);\nparcelHelpers.export(exports, \"faHourglass3\", ()=>faHourglass3\n);\nparcelHelpers.export(exports, \"faHourglassStart\", ()=>faHourglassStart\n);\nparcelHelpers.export(exports, \"faHourglass1\", ()=>faHourglass1\n);\nparcelHelpers.export(exports, \"faHouse\", ()=>faHouse\n);\nparcelHelpers.export(exports, \"faHome\", ()=>faHome\n);\nparcelHelpers.export(exports, \"faHomeAlt\", ()=>faHomeAlt\n);\nparcelHelpers.export(exports, \"faHomeLgAlt\", ()=>faHomeLgAlt\n);\nparcelHelpers.export(exports, \"faHouseChimney\", ()=>faHouseChimney\n);\nparcelHelpers.export(exports, \"faHomeLg\", ()=>faHomeLg\n);\nparcelHelpers.export(exports, \"faHouseChimneyCrack\", ()=>faHouseChimneyCrack\n);\nparcelHelpers.export(exports, \"faHouseDamage\", ()=>faHouseDamage\n);\nparcelHelpers.export(exports, \"faHouseChimneyMedical\", ()=>faHouseChimneyMedical\n);\nparcelHelpers.export(exports, \"faClinicMedical\", ()=>faClinicMedical\n);\nparcelHelpers.export(exports, \"faHouseChimneyUser\", ()=>faHouseChimneyUser\n);\nparcelHelpers.export(exports, \"faHouseChimneyWindow\", ()=>faHouseChimneyWindow\n);\nparcelHelpers.export(exports, \"faHouseCrack\", ()=>faHouseCrack\n);\nparcelHelpers.export(exports, \"faHouseLaptop\", ()=>faHouseLaptop\n);\nparcelHelpers.export(exports, \"faLaptopHouse\", ()=>faLaptopHouse\n);\nparcelHelpers.export(exports, \"faHouseMedical\", ()=>faHouseMedical\n);\nparcelHelpers.export(exports, \"faHouseUser\", ()=>faHouseUser\n);\nparcelHelpers.export(exports, \"faHomeUser\", ()=>faHomeUser\n);\nparcelHelpers.export(exports, \"faHryvniaSign\", ()=>faHryvniaSign\n);\nparcelHelpers.export(exports, \"faHryvnia\", ()=>faHryvnia\n);\nparcelHelpers.export(exports, \"faI\", ()=>faI\n);\nparcelHelpers.export(exports, \"faICursor\", ()=>faICursor\n);\nparcelHelpers.export(exports, \"faIceCream\", ()=>faIceCream\n);\nparcelHelpers.export(exports, \"faIcicles\", ()=>faIcicles\n);\nparcelHelpers.export(exports, \"faIcons\", ()=>faIcons\n);\nparcelHelpers.export(exports, \"faHeartMusicCameraBolt\", ()=>faHeartMusicCameraBolt\n);\nparcelHelpers.export(exports, \"faIdBadge\", ()=>faIdBadge\n);\nparcelHelpers.export(exports, \"faIdCard\", ()=>faIdCard\n);\nparcelHelpers.export(exports, \"faDriversLicense\", ()=>faDriversLicense\n);\nparcelHelpers.export(exports, \"faIdCardClip\", ()=>faIdCardClip\n);\nparcelHelpers.export(exports, \"faIdCardAlt\", ()=>faIdCardAlt\n);\nparcelHelpers.export(exports, \"faIgloo\", ()=>faIgloo\n);\nparcelHelpers.export(exports, \"faImage\", ()=>faImage\n);\nparcelHelpers.export(exports, \"faImagePortrait\", ()=>faImagePortrait\n);\nparcelHelpers.export(exports, \"faPortrait\", ()=>faPortrait\n);\nparcelHelpers.export(exports, \"faImages\", ()=>faImages\n);\nparcelHelpers.export(exports, \"faInbox\", ()=>faInbox\n);\nparcelHelpers.export(exports, \"faIndent\", ()=>faIndent\n);\nparcelHelpers.export(exports, \"faIndianRupeeSign\", ()=>faIndianRupeeSign\n);\nparcelHelpers.export(exports, \"faIndianRupee\", ()=>faIndianRupee\n);\nparcelHelpers.export(exports, \"faInr\", ()=>faInr\n);\nparcelHelpers.export(exports, \"faIndustry\", ()=>faIndustry\n);\nparcelHelpers.export(exports, \"faInfinity\", ()=>faInfinity\n);\nparcelHelpers.export(exports, \"faInfo\", ()=>faInfo\n);\nparcelHelpers.export(exports, \"faItalic\", ()=>faItalic\n);\nparcelHelpers.export(exports, \"faJ\", ()=>faJ\n);\nparcelHelpers.export(exports, \"faJedi\", ()=>faJedi\n);\nparcelHelpers.export(exports, \"faJetFighter\", ()=>faJetFighter\n);\nparcelHelpers.export(exports, \"faFighterJet\", ()=>faFighterJet\n);\nparcelHelpers.export(exports, \"faJoint\", ()=>faJoint\n);\nparcelHelpers.export(exports, \"faK\", ()=>faK\n);\nparcelHelpers.export(exports, \"faKaaba\", ()=>faKaaba\n);\nparcelHelpers.export(exports, \"faKey\", ()=>faKey\n);\nparcelHelpers.export(exports, \"faKeyboard\", ()=>faKeyboard\n);\nparcelHelpers.export(exports, \"faKhanda\", ()=>faKhanda\n);\nparcelHelpers.export(exports, \"faKipSign\", ()=>faKipSign\n);\nparcelHelpers.export(exports, \"faKitMedical\", ()=>faKitMedical\n);\nparcelHelpers.export(exports, \"faFirstAid\", ()=>faFirstAid\n);\nparcelHelpers.export(exports, \"faKiwiBird\", ()=>faKiwiBird\n);\nparcelHelpers.export(exports, \"faL\", ()=>faL\n);\nparcelHelpers.export(exports, \"faLandmark\", ()=>faLandmark\n);\nparcelHelpers.export(exports, \"faLanguage\", ()=>faLanguage\n);\nparcelHelpers.export(exports, \"faLaptop\", ()=>faLaptop\n);\nparcelHelpers.export(exports, \"faLaptopCode\", ()=>faLaptopCode\n);\nparcelHelpers.export(exports, \"faLaptopMedical\", ()=>faLaptopMedical\n);\nparcelHelpers.export(exports, \"faLariSign\", ()=>faLariSign\n);\nparcelHelpers.export(exports, \"faLayerGroup\", ()=>faLayerGroup\n);\nparcelHelpers.export(exports, \"faLeaf\", ()=>faLeaf\n);\nparcelHelpers.export(exports, \"faLeftLong\", ()=>faLeftLong\n);\nparcelHelpers.export(exports, \"faLongArrowAltLeft\", ()=>faLongArrowAltLeft\n);\nparcelHelpers.export(exports, \"faLeftRight\", ()=>faLeftRight\n);\nparcelHelpers.export(exports, \"faArrowsAltH\", ()=>faArrowsAltH\n);\nparcelHelpers.export(exports, \"faLemon\", ()=>faLemon\n);\nparcelHelpers.export(exports, \"faLessThan\", ()=>faLessThan\n);\nparcelHelpers.export(exports, \"faLessThanEqual\", ()=>faLessThanEqual\n);\nparcelHelpers.export(exports, \"faLifeRing\", ()=>faLifeRing\n);\nparcelHelpers.export(exports, \"faLightbulb\", ()=>faLightbulb\n);\nparcelHelpers.export(exports, \"faLink\", ()=>faLink\n);\nparcelHelpers.export(exports, \"faChain\", ()=>faChain\n);\nparcelHelpers.export(exports, \"faLinkSlash\", ()=>faLinkSlash\n);\nparcelHelpers.export(exports, \"faChainBroken\", ()=>faChainBroken\n);\nparcelHelpers.export(exports, \"faChainSlash\", ()=>faChainSlash\n);\nparcelHelpers.export(exports, \"faUnlink\", ()=>faUnlink\n);\nparcelHelpers.export(exports, \"faLiraSign\", ()=>faLiraSign\n);\nparcelHelpers.export(exports, \"faList\", ()=>faList\n);\nparcelHelpers.export(exports, \"faListSquares\", ()=>faListSquares\n);\nparcelHelpers.export(exports, \"faListCheck\", ()=>faListCheck\n);\nparcelHelpers.export(exports, \"faTasks\", ()=>faTasks\n);\nparcelHelpers.export(exports, \"faListOl\", ()=>faListOl\n);\nparcelHelpers.export(exports, \"faList12\", ()=>faList12\n);\nparcelHelpers.export(exports, \"faListNumeric\", ()=>faListNumeric\n);\nparcelHelpers.export(exports, \"faListUl\", ()=>faListUl\n);\nparcelHelpers.export(exports, \"faListDots\", ()=>faListDots\n);\nparcelHelpers.export(exports, \"faLitecoinSign\", ()=>faLitecoinSign\n);\nparcelHelpers.export(exports, \"faLocationArrow\", ()=>faLocationArrow\n);\nparcelHelpers.export(exports, \"faLocationCrosshairs\", ()=>faLocationCrosshairs\n);\nparcelHelpers.export(exports, \"faLocation\", ()=>faLocation\n);\nparcelHelpers.export(exports, \"faLocationDot\", ()=>faLocationDot\n);\nparcelHelpers.export(exports, \"faMapMarkerAlt\", ()=>faMapMarkerAlt\n);\nparcelHelpers.export(exports, \"faLocationPin\", ()=>faLocationPin\n);\nparcelHelpers.export(exports, \"faMapMarker\", ()=>faMapMarker\n);\nparcelHelpers.export(exports, \"faLock\", ()=>faLock\n);\nparcelHelpers.export(exports, \"faLockOpen\", ()=>faLockOpen\n);\nparcelHelpers.export(exports, \"faLungs\", ()=>faLungs\n);\nparcelHelpers.export(exports, \"faLungsVirus\", ()=>faLungsVirus\n);\nparcelHelpers.export(exports, \"faM\", ()=>faM\n);\nparcelHelpers.export(exports, \"faMagnet\", ()=>faMagnet\n);\nparcelHelpers.export(exports, \"faMagnifyingGlass\", ()=>faMagnifyingGlass\n);\nparcelHelpers.export(exports, \"faSearch\", ()=>faSearch\n);\nparcelHelpers.export(exports, \"faMagnifyingGlassDollar\", ()=>faMagnifyingGlassDollar\n);\nparcelHelpers.export(exports, \"faSearchDollar\", ()=>faSearchDollar\n);\nparcelHelpers.export(exports, \"faMagnifyingGlassLocation\", ()=>faMagnifyingGlassLocation\n);\nparcelHelpers.export(exports, \"faSearchLocation\", ()=>faSearchLocation\n);\nparcelHelpers.export(exports, \"faMagnifyingGlassMinus\", ()=>faMagnifyingGlassMinus\n);\nparcelHelpers.export(exports, \"faSearchMinus\", ()=>faSearchMinus\n);\nparcelHelpers.export(exports, \"faMagnifyingGlassPlus\", ()=>faMagnifyingGlassPlus\n);\nparcelHelpers.export(exports, \"faSearchPlus\", ()=>faSearchPlus\n);\nparcelHelpers.export(exports, \"faManatSign\", ()=>faManatSign\n);\nparcelHelpers.export(exports, \"faMap\", ()=>faMap\n);\nparcelHelpers.export(exports, \"faMapLocation\", ()=>faMapLocation\n);\nparcelHelpers.export(exports, \"faMapMarked\", ()=>faMapMarked\n);\nparcelHelpers.export(exports, \"faMapLocationDot\", ()=>faMapLocationDot\n);\nparcelHelpers.export(exports, \"faMapMarkedAlt\", ()=>faMapMarkedAlt\n);\nparcelHelpers.export(exports, \"faMapPin\", ()=>faMapPin\n);\nparcelHelpers.export(exports, \"faMarker\", ()=>faMarker\n);\nparcelHelpers.export(exports, \"faMars\", ()=>faMars\n);\nparcelHelpers.export(exports, \"faMarsAndVenus\", ()=>faMarsAndVenus\n);\nparcelHelpers.export(exports, \"faMarsDouble\", ()=>faMarsDouble\n);\nparcelHelpers.export(exports, \"faMarsStroke\", ()=>faMarsStroke\n);\nparcelHelpers.export(exports, \"faMarsStrokeRight\", ()=>faMarsStrokeRight\n);\nparcelHelpers.export(exports, \"faMarsStrokeH\", ()=>faMarsStrokeH\n);\nparcelHelpers.export(exports, \"faMarsStrokeUp\", ()=>faMarsStrokeUp\n);\nparcelHelpers.export(exports, \"faMarsStrokeV\", ()=>faMarsStrokeV\n);\nparcelHelpers.export(exports, \"faMartiniGlass\", ()=>faMartiniGlass\n);\nparcelHelpers.export(exports, \"faGlassMartiniAlt\", ()=>faGlassMartiniAlt\n);\nparcelHelpers.export(exports, \"faMartiniGlassCitrus\", ()=>faMartiniGlassCitrus\n);\nparcelHelpers.export(exports, \"faCocktail\", ()=>faCocktail\n);\nparcelHelpers.export(exports, \"faMartiniGlassEmpty\", ()=>faMartiniGlassEmpty\n);\nparcelHelpers.export(exports, \"faGlassMartini\", ()=>faGlassMartini\n);\nparcelHelpers.export(exports, \"faMask\", ()=>faMask\n);\nparcelHelpers.export(exports, \"faMaskFace\", ()=>faMaskFace\n);\nparcelHelpers.export(exports, \"faMasksTheater\", ()=>faMasksTheater\n);\nparcelHelpers.export(exports, \"faTheaterMasks\", ()=>faTheaterMasks\n);\nparcelHelpers.export(exports, \"faMaximize\", ()=>faMaximize\n);\nparcelHelpers.export(exports, \"faExpandArrowsAlt\", ()=>faExpandArrowsAlt\n);\nparcelHelpers.export(exports, \"faMedal\", ()=>faMedal\n);\nparcelHelpers.export(exports, \"faMemory\", ()=>faMemory\n);\nparcelHelpers.export(exports, \"faMenorah\", ()=>faMenorah\n);\nparcelHelpers.export(exports, \"faMercury\", ()=>faMercury\n);\nparcelHelpers.export(exports, \"faMessage\", ()=>faMessage\n);\nparcelHelpers.export(exports, \"faCommentAlt\", ()=>faCommentAlt\n);\nparcelHelpers.export(exports, \"faMeteor\", ()=>faMeteor\n);\nparcelHelpers.export(exports, \"faMicrochip\", ()=>faMicrochip\n);\nparcelHelpers.export(exports, \"faMicrophone\", ()=>faMicrophone\n);\nparcelHelpers.export(exports, \"faMicrophoneLines\", ()=>faMicrophoneLines\n);\nparcelHelpers.export(exports, \"faMicrophoneAlt\", ()=>faMicrophoneAlt\n);\nparcelHelpers.export(exports, \"faMicrophoneLinesSlash\", ()=>faMicrophoneLinesSlash\n);\nparcelHelpers.export(exports, \"faMicrophoneAltSlash\", ()=>faMicrophoneAltSlash\n);\nparcelHelpers.export(exports, \"faMicrophoneSlash\", ()=>faMicrophoneSlash\n);\nparcelHelpers.export(exports, \"faMicroscope\", ()=>faMicroscope\n);\nparcelHelpers.export(exports, \"faMillSign\", ()=>faMillSign\n);\nparcelHelpers.export(exports, \"faMinimize\", ()=>faMinimize\n);\nparcelHelpers.export(exports, \"faCompressArrowsAlt\", ()=>faCompressArrowsAlt\n);\nparcelHelpers.export(exports, \"faMinus\", ()=>faMinus\n);\nparcelHelpers.export(exports, \"faSubtract\", ()=>faSubtract\n);\nparcelHelpers.export(exports, \"faMitten\", ()=>faMitten\n);\nparcelHelpers.export(exports, \"faMobile\", ()=>faMobile\n);\nparcelHelpers.export(exports, \"faMobileAndroid\", ()=>faMobileAndroid\n);\nparcelHelpers.export(exports, \"faMobilePhone\", ()=>faMobilePhone\n);\nparcelHelpers.export(exports, \"faMobileButton\", ()=>faMobileButton\n);\nparcelHelpers.export(exports, \"faMobileScreenButton\", ()=>faMobileScreenButton\n);\nparcelHelpers.export(exports, \"faMobileAlt\", ()=>faMobileAlt\n);\nparcelHelpers.export(exports, \"faMoneyBill\", ()=>faMoneyBill\n);\nparcelHelpers.export(exports, \"faMoneyBill1\", ()=>faMoneyBill1\n);\nparcelHelpers.export(exports, \"faMoneyBillAlt\", ()=>faMoneyBillAlt\n);\nparcelHelpers.export(exports, \"faMoneyBill1Wave\", ()=>faMoneyBill1Wave\n);\nparcelHelpers.export(exports, \"faMoneyBillWaveAlt\", ()=>faMoneyBillWaveAlt\n);\nparcelHelpers.export(exports, \"faMoneyBillWave\", ()=>faMoneyBillWave\n);\nparcelHelpers.export(exports, \"faMoneyCheck\", ()=>faMoneyCheck\n);\nparcelHelpers.export(exports, \"faMoneyCheckDollar\", ()=>faMoneyCheckDollar\n);\nparcelHelpers.export(exports, \"faMoneyCheckAlt\", ()=>faMoneyCheckAlt\n);\nparcelHelpers.export(exports, \"faMonument\", ()=>faMonument\n);\nparcelHelpers.export(exports, \"faMoon\", ()=>faMoon\n);\nparcelHelpers.export(exports, \"faMortarPestle\", ()=>faMortarPestle\n);\nparcelHelpers.export(exports, \"faMosque\", ()=>faMosque\n);\nparcelHelpers.export(exports, \"faMotorcycle\", ()=>faMotorcycle\n);\nparcelHelpers.export(exports, \"faMountain\", ()=>faMountain\n);\nparcelHelpers.export(exports, \"faMugHot\", ()=>faMugHot\n);\nparcelHelpers.export(exports, \"faMugSaucer\", ()=>faMugSaucer\n);\nparcelHelpers.export(exports, \"faCoffee\", ()=>faCoffee\n);\nparcelHelpers.export(exports, \"faMusic\", ()=>faMusic\n);\nparcelHelpers.export(exports, \"faN\", ()=>faN\n);\nparcelHelpers.export(exports, \"faNairaSign\", ()=>faNairaSign\n);\nparcelHelpers.export(exports, \"faNetworkWired\", ()=>faNetworkWired\n);\nparcelHelpers.export(exports, \"faNeuter\", ()=>faNeuter\n);\nparcelHelpers.export(exports, \"faNewspaper\", ()=>faNewspaper\n);\nparcelHelpers.export(exports, \"faNotEqual\", ()=>faNotEqual\n);\nparcelHelpers.export(exports, \"faNoteSticky\", ()=>faNoteSticky\n);\nparcelHelpers.export(exports, \"faStickyNote\", ()=>faStickyNote\n);\nparcelHelpers.export(exports, \"faNotesMedical\", ()=>faNotesMedical\n);\nparcelHelpers.export(exports, \"faO\", ()=>faO\n);\nparcelHelpers.export(exports, \"faObjectGroup\", ()=>faObjectGroup\n);\nparcelHelpers.export(exports, \"faObjectUngroup\", ()=>faObjectUngroup\n);\nparcelHelpers.export(exports, \"faOilCan\", ()=>faOilCan\n);\nparcelHelpers.export(exports, \"faOm\", ()=>faOm\n);\nparcelHelpers.export(exports, \"faOtter\", ()=>faOtter\n);\nparcelHelpers.export(exports, \"faOutdent\", ()=>faOutdent\n);\nparcelHelpers.export(exports, \"faDedent\", ()=>faDedent\n);\nparcelHelpers.export(exports, \"faP\", ()=>faP\n);\nparcelHelpers.export(exports, \"faPager\", ()=>faPager\n);\nparcelHelpers.export(exports, \"faPaintRoller\", ()=>faPaintRoller\n);\nparcelHelpers.export(exports, \"faPaintbrush\", ()=>faPaintbrush\n);\nparcelHelpers.export(exports, \"faPaintBrush\", ()=>faPaintBrush\n);\nparcelHelpers.export(exports, \"faPalette\", ()=>faPalette\n);\nparcelHelpers.export(exports, \"faPallet\", ()=>faPallet\n);\nparcelHelpers.export(exports, \"faPanorama\", ()=>faPanorama\n);\nparcelHelpers.export(exports, \"faPaperPlane\", ()=>faPaperPlane\n);\nparcelHelpers.export(exports, \"faPaperclip\", ()=>faPaperclip\n);\nparcelHelpers.export(exports, \"faParachuteBox\", ()=>faParachuteBox\n);\nparcelHelpers.export(exports, \"faParagraph\", ()=>faParagraph\n);\nparcelHelpers.export(exports, \"faPassport\", ()=>faPassport\n);\nparcelHelpers.export(exports, \"faPaste\", ()=>faPaste\n);\nparcelHelpers.export(exports, \"faFileClipboard\", ()=>faFileClipboard\n);\nparcelHelpers.export(exports, \"faPause\", ()=>faPause\n);\nparcelHelpers.export(exports, \"faPaw\", ()=>faPaw\n);\nparcelHelpers.export(exports, \"faPeace\", ()=>faPeace\n);\nparcelHelpers.export(exports, \"faPen\", ()=>faPen\n);\nparcelHelpers.export(exports, \"faPenClip\", ()=>faPenClip\n);\nparcelHelpers.export(exports, \"faPenAlt\", ()=>faPenAlt\n);\nparcelHelpers.export(exports, \"faPenFancy\", ()=>faPenFancy\n);\nparcelHelpers.export(exports, \"faPenNib\", ()=>faPenNib\n);\nparcelHelpers.export(exports, \"faPenRuler\", ()=>faPenRuler\n);\nparcelHelpers.export(exports, \"faPencilRuler\", ()=>faPencilRuler\n);\nparcelHelpers.export(exports, \"faPenToSquare\", ()=>faPenToSquare\n);\nparcelHelpers.export(exports, \"faEdit\", ()=>faEdit\n);\nparcelHelpers.export(exports, \"faPencil\", ()=>faPencil\n);\nparcelHelpers.export(exports, \"faPencilAlt\", ()=>faPencilAlt\n);\nparcelHelpers.export(exports, \"faPeopleArrowsLeftRight\", ()=>faPeopleArrowsLeftRight\n);\nparcelHelpers.export(exports, \"faPeopleArrows\", ()=>faPeopleArrows\n);\nparcelHelpers.export(exports, \"faPeopleCarryBox\", ()=>faPeopleCarryBox\n);\nparcelHelpers.export(exports, \"faPeopleCarry\", ()=>faPeopleCarry\n);\nparcelHelpers.export(exports, \"faPepperHot\", ()=>faPepperHot\n);\nparcelHelpers.export(exports, \"faPercent\", ()=>faPercent\n);\nparcelHelpers.export(exports, \"faPercentage\", ()=>faPercentage\n);\nparcelHelpers.export(exports, \"faPerson\", ()=>faPerson\n);\nparcelHelpers.export(exports, \"faMale\", ()=>faMale\n);\nparcelHelpers.export(exports, \"faPersonBiking\", ()=>faPersonBiking\n);\nparcelHelpers.export(exports, \"faBiking\", ()=>faBiking\n);\nparcelHelpers.export(exports, \"faPersonBooth\", ()=>faPersonBooth\n);\nparcelHelpers.export(exports, \"faPersonDotsFromLine\", ()=>faPersonDotsFromLine\n);\nparcelHelpers.export(exports, \"faDiagnoses\", ()=>faDiagnoses\n);\nparcelHelpers.export(exports, \"faPersonDress\", ()=>faPersonDress\n);\nparcelHelpers.export(exports, \"faFemale\", ()=>faFemale\n);\nparcelHelpers.export(exports, \"faPersonHiking\", ()=>faPersonHiking\n);\nparcelHelpers.export(exports, \"faHiking\", ()=>faHiking\n);\nparcelHelpers.export(exports, \"faPersonPraying\", ()=>faPersonPraying\n);\nparcelHelpers.export(exports, \"faPray\", ()=>faPray\n);\nparcelHelpers.export(exports, \"faPersonRunning\", ()=>faPersonRunning\n);\nparcelHelpers.export(exports, \"faRunning\", ()=>faRunning\n);\nparcelHelpers.export(exports, \"faPersonSkating\", ()=>faPersonSkating\n);\nparcelHelpers.export(exports, \"faSkating\", ()=>faSkating\n);\nparcelHelpers.export(exports, \"faPersonSkiing\", ()=>faPersonSkiing\n);\nparcelHelpers.export(exports, \"faSkiing\", ()=>faSkiing\n);\nparcelHelpers.export(exports, \"faPersonSkiingNordic\", ()=>faPersonSkiingNordic\n);\nparcelHelpers.export(exports, \"faSkiingNordic\", ()=>faSkiingNordic\n);\nparcelHelpers.export(exports, \"faPersonSnowboarding\", ()=>faPersonSnowboarding\n);\nparcelHelpers.export(exports, \"faSnowboarding\", ()=>faSnowboarding\n);\nparcelHelpers.export(exports, \"faPersonSwimming\", ()=>faPersonSwimming\n);\nparcelHelpers.export(exports, \"faSwimmer\", ()=>faSwimmer\n);\nparcelHelpers.export(exports, \"faPersonWalking\", ()=>faPersonWalking\n);\nparcelHelpers.export(exports, \"faWalking\", ()=>faWalking\n);\nparcelHelpers.export(exports, \"faPersonWalkingWithCane\", ()=>faPersonWalkingWithCane\n);\nparcelHelpers.export(exports, \"faBlind\", ()=>faBlind\n);\nparcelHelpers.export(exports, \"faPesetaSign\", ()=>faPesetaSign\n);\nparcelHelpers.export(exports, \"faPesoSign\", ()=>faPesoSign\n);\nparcelHelpers.export(exports, \"faPhone\", ()=>faPhone\n);\nparcelHelpers.export(exports, \"faPhoneFlip\", ()=>faPhoneFlip\n);\nparcelHelpers.export(exports, \"faPhoneAlt\", ()=>faPhoneAlt\n);\nparcelHelpers.export(exports, \"faPhoneSlash\", ()=>faPhoneSlash\n);\nparcelHelpers.export(exports, \"faPhoneVolume\", ()=>faPhoneVolume\n);\nparcelHelpers.export(exports, \"faVolumeControlPhone\", ()=>faVolumeControlPhone\n);\nparcelHelpers.export(exports, \"faPhotoFilm\", ()=>faPhotoFilm\n);\nparcelHelpers.export(exports, \"faPhotoVideo\", ()=>faPhotoVideo\n);\nparcelHelpers.export(exports, \"faPiggyBank\", ()=>faPiggyBank\n);\nparcelHelpers.export(exports, \"faPills\", ()=>faPills\n);\nparcelHelpers.export(exports, \"faPizzaSlice\", ()=>faPizzaSlice\n);\nparcelHelpers.export(exports, \"faPlaceOfWorship\", ()=>faPlaceOfWorship\n);\nparcelHelpers.export(exports, \"faPlane\", ()=>faPlane\n);\nparcelHelpers.export(exports, \"faPlaneArrival\", ()=>faPlaneArrival\n);\nparcelHelpers.export(exports, \"faPlaneDeparture\", ()=>faPlaneDeparture\n);\nparcelHelpers.export(exports, \"faPlaneSlash\", ()=>faPlaneSlash\n);\nparcelHelpers.export(exports, \"faPlay\", ()=>faPlay\n);\nparcelHelpers.export(exports, \"faPlug\", ()=>faPlug\n);\nparcelHelpers.export(exports, \"faPlus\", ()=>faPlus\n);\nparcelHelpers.export(exports, \"faAdd\", ()=>faAdd\n);\nparcelHelpers.export(exports, \"faPlusMinus\", ()=>faPlusMinus\n);\nparcelHelpers.export(exports, \"faPodcast\", ()=>faPodcast\n);\nparcelHelpers.export(exports, \"faPoo\", ()=>faPoo\n);\nparcelHelpers.export(exports, \"faPooStorm\", ()=>faPooStorm\n);\nparcelHelpers.export(exports, \"faPooBolt\", ()=>faPooBolt\n);\nparcelHelpers.export(exports, \"faPoop\", ()=>faPoop\n);\nparcelHelpers.export(exports, \"faPowerOff\", ()=>faPowerOff\n);\nparcelHelpers.export(exports, \"faPrescription\", ()=>faPrescription\n);\nparcelHelpers.export(exports, \"faPrescriptionBottle\", ()=>faPrescriptionBottle\n);\nparcelHelpers.export(exports, \"faPrescriptionBottleMedical\", ()=>faPrescriptionBottleMedical\n);\nparcelHelpers.export(exports, \"faPrescriptionBottleAlt\", ()=>faPrescriptionBottleAlt\n);\nparcelHelpers.export(exports, \"faPrint\", ()=>faPrint\n);\nparcelHelpers.export(exports, \"faPumpMedical\", ()=>faPumpMedical\n);\nparcelHelpers.export(exports, \"faPumpSoap\", ()=>faPumpSoap\n);\nparcelHelpers.export(exports, \"faPuzzlePiece\", ()=>faPuzzlePiece\n);\nparcelHelpers.export(exports, \"faQ\", ()=>faQ\n);\nparcelHelpers.export(exports, \"faQrcode\", ()=>faQrcode\n);\nparcelHelpers.export(exports, \"faQuestion\", ()=>faQuestion\n);\nparcelHelpers.export(exports, \"faQuoteLeft\", ()=>faQuoteLeft\n);\nparcelHelpers.export(exports, \"faQuoteLeftAlt\", ()=>faQuoteLeftAlt\n);\nparcelHelpers.export(exports, \"faQuoteRight\", ()=>faQuoteRight\n);\nparcelHelpers.export(exports, \"faQuoteRightAlt\", ()=>faQuoteRightAlt\n);\nparcelHelpers.export(exports, \"faR\", ()=>faR\n);\nparcelHelpers.export(exports, \"faRadiation\", ()=>faRadiation\n);\nparcelHelpers.export(exports, \"faRainbow\", ()=>faRainbow\n);\nparcelHelpers.export(exports, \"faReceipt\", ()=>faReceipt\n);\nparcelHelpers.export(exports, \"faRecordVinyl\", ()=>faRecordVinyl\n);\nparcelHelpers.export(exports, \"faRectangleAd\", ()=>faRectangleAd\n);\nparcelHelpers.export(exports, \"faAd\", ()=>faAd\n);\nparcelHelpers.export(exports, \"faRectangleList\", ()=>faRectangleList\n);\nparcelHelpers.export(exports, \"faListAlt\", ()=>faListAlt\n);\nparcelHelpers.export(exports, \"faRectangleXmark\", ()=>faRectangleXmark\n);\nparcelHelpers.export(exports, \"faRectangleTimes\", ()=>faRectangleTimes\n);\nparcelHelpers.export(exports, \"faTimesRectangle\", ()=>faTimesRectangle\n);\nparcelHelpers.export(exports, \"faWindowClose\", ()=>faWindowClose\n);\nparcelHelpers.export(exports, \"faRecycle\", ()=>faRecycle\n);\nparcelHelpers.export(exports, \"faRegistered\", ()=>faRegistered\n);\nparcelHelpers.export(exports, \"faRepeat\", ()=>faRepeat\n);\nparcelHelpers.export(exports, \"faReply\", ()=>faReply\n);\nparcelHelpers.export(exports, \"faMailReply\", ()=>faMailReply\n);\nparcelHelpers.export(exports, \"faReplyAll\", ()=>faReplyAll\n);\nparcelHelpers.export(exports, \"faMailReplyAll\", ()=>faMailReplyAll\n);\nparcelHelpers.export(exports, \"faRepublican\", ()=>faRepublican\n);\nparcelHelpers.export(exports, \"faRestroom\", ()=>faRestroom\n);\nparcelHelpers.export(exports, \"faRetweet\", ()=>faRetweet\n);\nparcelHelpers.export(exports, \"faRibbon\", ()=>faRibbon\n);\nparcelHelpers.export(exports, \"faRightFromBracket\", ()=>faRightFromBracket\n);\nparcelHelpers.export(exports, \"faSignOutAlt\", ()=>faSignOutAlt\n);\nparcelHelpers.export(exports, \"faRightLeft\", ()=>faRightLeft\n);\nparcelHelpers.export(exports, \"faExchangeAlt\", ()=>faExchangeAlt\n);\nparcelHelpers.export(exports, \"faRightLong\", ()=>faRightLong\n);\nparcelHelpers.export(exports, \"faLongArrowAltRight\", ()=>faLongArrowAltRight\n);\nparcelHelpers.export(exports, \"faRightToBracket\", ()=>faRightToBracket\n);\nparcelHelpers.export(exports, \"faSignInAlt\", ()=>faSignInAlt\n);\nparcelHelpers.export(exports, \"faRing\", ()=>faRing\n);\nparcelHelpers.export(exports, \"faRoad\", ()=>faRoad\n);\nparcelHelpers.export(exports, \"faRobot\", ()=>faRobot\n);\nparcelHelpers.export(exports, \"faRocket\", ()=>faRocket\n);\nparcelHelpers.export(exports, \"faRotate\", ()=>faRotate\n);\nparcelHelpers.export(exports, \"faSyncAlt\", ()=>faSyncAlt\n);\nparcelHelpers.export(exports, \"faRotateLeft\", ()=>faRotateLeft\n);\nparcelHelpers.export(exports, \"faRotateBack\", ()=>faRotateBack\n);\nparcelHelpers.export(exports, \"faRotateBackward\", ()=>faRotateBackward\n);\nparcelHelpers.export(exports, \"faUndoAlt\", ()=>faUndoAlt\n);\nparcelHelpers.export(exports, \"faRotateRight\", ()=>faRotateRight\n);\nparcelHelpers.export(exports, \"faRedoAlt\", ()=>faRedoAlt\n);\nparcelHelpers.export(exports, \"faRotateForward\", ()=>faRotateForward\n);\nparcelHelpers.export(exports, \"faRoute\", ()=>faRoute\n);\nparcelHelpers.export(exports, \"faRss\", ()=>faRss\n);\nparcelHelpers.export(exports, \"faFeed\", ()=>faFeed\n);\nparcelHelpers.export(exports, \"faRubleSign\", ()=>faRubleSign\n);\nparcelHelpers.export(exports, \"faRouble\", ()=>faRouble\n);\nparcelHelpers.export(exports, \"faRub\", ()=>faRub\n);\nparcelHelpers.export(exports, \"faRuble\", ()=>faRuble\n);\nparcelHelpers.export(exports, \"faRuler\", ()=>faRuler\n);\nparcelHelpers.export(exports, \"faRulerCombined\", ()=>faRulerCombined\n);\nparcelHelpers.export(exports, \"faRulerHorizontal\", ()=>faRulerHorizontal\n);\nparcelHelpers.export(exports, \"faRulerVertical\", ()=>faRulerVertical\n);\nparcelHelpers.export(exports, \"faRupeeSign\", ()=>faRupeeSign\n);\nparcelHelpers.export(exports, \"faRupee\", ()=>faRupee\n);\nparcelHelpers.export(exports, \"faRupiahSign\", ()=>faRupiahSign\n);\nparcelHelpers.export(exports, \"faS\", ()=>faS\n);\nparcelHelpers.export(exports, \"faSailboat\", ()=>faSailboat\n);\nparcelHelpers.export(exports, \"faSatellite\", ()=>faSatellite\n);\nparcelHelpers.export(exports, \"faSatelliteDish\", ()=>faSatelliteDish\n);\nparcelHelpers.export(exports, \"faScaleBalanced\", ()=>faScaleBalanced\n);\nparcelHelpers.export(exports, \"faBalanceScale\", ()=>faBalanceScale\n);\nparcelHelpers.export(exports, \"faScaleUnbalanced\", ()=>faScaleUnbalanced\n);\nparcelHelpers.export(exports, \"faBalanceScaleLeft\", ()=>faBalanceScaleLeft\n);\nparcelHelpers.export(exports, \"faScaleUnbalancedFlip\", ()=>faScaleUnbalancedFlip\n);\nparcelHelpers.export(exports, \"faBalanceScaleRight\", ()=>faBalanceScaleRight\n);\nparcelHelpers.export(exports, \"faSchool\", ()=>faSchool\n);\nparcelHelpers.export(exports, \"faScissors\", ()=>faScissors\n);\nparcelHelpers.export(exports, \"faCut\", ()=>faCut\n);\nparcelHelpers.export(exports, \"faScrewdriver\", ()=>faScrewdriver\n);\nparcelHelpers.export(exports, \"faScrewdriverWrench\", ()=>faScrewdriverWrench\n);\nparcelHelpers.export(exports, \"faTools\", ()=>faTools\n);\nparcelHelpers.export(exports, \"faScroll\", ()=>faScroll\n);\nparcelHelpers.export(exports, \"faScrollTorah\", ()=>faScrollTorah\n);\nparcelHelpers.export(exports, \"faTorah\", ()=>faTorah\n);\nparcelHelpers.export(exports, \"faSdCard\", ()=>faSdCard\n);\nparcelHelpers.export(exports, \"faSection\", ()=>faSection\n);\nparcelHelpers.export(exports, \"faSeedling\", ()=>faSeedling\n);\nparcelHelpers.export(exports, \"faSprout\", ()=>faSprout\n);\nparcelHelpers.export(exports, \"faServer\", ()=>faServer\n);\nparcelHelpers.export(exports, \"faShapes\", ()=>faShapes\n);\nparcelHelpers.export(exports, \"faTriangleCircleSquare\", ()=>faTriangleCircleSquare\n);\nparcelHelpers.export(exports, \"faShare\", ()=>faShare\n);\nparcelHelpers.export(exports, \"faArrowTurnRight\", ()=>faArrowTurnRight\n);\nparcelHelpers.export(exports, \"faMailForward\", ()=>faMailForward\n);\nparcelHelpers.export(exports, \"faShareFromSquare\", ()=>faShareFromSquare\n);\nparcelHelpers.export(exports, \"faShareSquare\", ()=>faShareSquare\n);\nparcelHelpers.export(exports, \"faShareNodes\", ()=>faShareNodes\n);\nparcelHelpers.export(exports, \"faShareAlt\", ()=>faShareAlt\n);\nparcelHelpers.export(exports, \"faShekelSign\", ()=>faShekelSign\n);\nparcelHelpers.export(exports, \"faIls\", ()=>faIls\n);\nparcelHelpers.export(exports, \"faShekel\", ()=>faShekel\n);\nparcelHelpers.export(exports, \"faSheqel\", ()=>faSheqel\n);\nparcelHelpers.export(exports, \"faSheqelSign\", ()=>faSheqelSign\n);\nparcelHelpers.export(exports, \"faShield\", ()=>faShield\n);\nparcelHelpers.export(exports, \"faShieldBlank\", ()=>faShieldBlank\n);\nparcelHelpers.export(exports, \"faShieldAlt\", ()=>faShieldAlt\n);\nparcelHelpers.export(exports, \"faShieldVirus\", ()=>faShieldVirus\n);\nparcelHelpers.export(exports, \"faShip\", ()=>faShip\n);\nparcelHelpers.export(exports, \"faShirt\", ()=>faShirt\n);\nparcelHelpers.export(exports, \"faTShirt\", ()=>faTShirt\n);\nparcelHelpers.export(exports, \"faTshirt\", ()=>faTshirt\n);\nparcelHelpers.export(exports, \"faShoePrints\", ()=>faShoePrints\n);\nparcelHelpers.export(exports, \"faShop\", ()=>faShop\n);\nparcelHelpers.export(exports, \"faStoreAlt\", ()=>faStoreAlt\n);\nparcelHelpers.export(exports, \"faShopSlash\", ()=>faShopSlash\n);\nparcelHelpers.export(exports, \"faStoreAltSlash\", ()=>faStoreAltSlash\n);\nparcelHelpers.export(exports, \"faShower\", ()=>faShower\n);\nparcelHelpers.export(exports, \"faShrimp\", ()=>faShrimp\n);\nparcelHelpers.export(exports, \"faShuffle\", ()=>faShuffle\n);\nparcelHelpers.export(exports, \"faRandom\", ()=>faRandom\n);\nparcelHelpers.export(exports, \"faShuttleSpace\", ()=>faShuttleSpace\n);\nparcelHelpers.export(exports, \"faSpaceShuttle\", ()=>faSpaceShuttle\n);\nparcelHelpers.export(exports, \"faSignHanging\", ()=>faSignHanging\n);\nparcelHelpers.export(exports, \"faSign\", ()=>faSign\n);\nparcelHelpers.export(exports, \"faSignal\", ()=>faSignal\n);\nparcelHelpers.export(exports, \"faSignal5\", ()=>faSignal5\n);\nparcelHelpers.export(exports, \"faSignalPerfect\", ()=>faSignalPerfect\n);\nparcelHelpers.export(exports, \"faSignature\", ()=>faSignature\n);\nparcelHelpers.export(exports, \"faSignsPost\", ()=>faSignsPost\n);\nparcelHelpers.export(exports, \"faMapSigns\", ()=>faMapSigns\n);\nparcelHelpers.export(exports, \"faSimCard\", ()=>faSimCard\n);\nparcelHelpers.export(exports, \"faSink\", ()=>faSink\n);\nparcelHelpers.export(exports, \"faSitemap\", ()=>faSitemap\n);\nparcelHelpers.export(exports, \"faSkull\", ()=>faSkull\n);\nparcelHelpers.export(exports, \"faSkullCrossbones\", ()=>faSkullCrossbones\n);\nparcelHelpers.export(exports, \"faSlash\", ()=>faSlash\n);\nparcelHelpers.export(exports, \"faSleigh\", ()=>faSleigh\n);\nparcelHelpers.export(exports, \"faSliders\", ()=>faSliders\n);\nparcelHelpers.export(exports, \"faSlidersH\", ()=>faSlidersH\n);\nparcelHelpers.export(exports, \"faSmog\", ()=>faSmog\n);\nparcelHelpers.export(exports, \"faSmoking\", ()=>faSmoking\n);\nparcelHelpers.export(exports, \"faSnowflake\", ()=>faSnowflake\n);\nparcelHelpers.export(exports, \"faSnowman\", ()=>faSnowman\n);\nparcelHelpers.export(exports, \"faSnowplow\", ()=>faSnowplow\n);\nparcelHelpers.export(exports, \"faSoap\", ()=>faSoap\n);\nparcelHelpers.export(exports, \"faSocks\", ()=>faSocks\n);\nparcelHelpers.export(exports, \"faSolarPanel\", ()=>faSolarPanel\n);\nparcelHelpers.export(exports, \"faSort\", ()=>faSort\n);\nparcelHelpers.export(exports, \"faUnsorted\", ()=>faUnsorted\n);\nparcelHelpers.export(exports, \"faSortDown\", ()=>faSortDown\n);\nparcelHelpers.export(exports, \"faSortDesc\", ()=>faSortDesc\n);\nparcelHelpers.export(exports, \"faSortUp\", ()=>faSortUp\n);\nparcelHelpers.export(exports, \"faSortAsc\", ()=>faSortAsc\n);\nparcelHelpers.export(exports, \"faSpa\", ()=>faSpa\n);\nparcelHelpers.export(exports, \"faSpaghettiMonsterFlying\", ()=>faSpaghettiMonsterFlying\n);\nparcelHelpers.export(exports, \"faPastafarianism\", ()=>faPastafarianism\n);\nparcelHelpers.export(exports, \"faSpellCheck\", ()=>faSpellCheck\n);\nparcelHelpers.export(exports, \"faSpider\", ()=>faSpider\n);\nparcelHelpers.export(exports, \"faSpinner\", ()=>faSpinner\n);\nparcelHelpers.export(exports, \"faSplotch\", ()=>faSplotch\n);\nparcelHelpers.export(exports, \"faSpoon\", ()=>faSpoon\n);\nparcelHelpers.export(exports, \"faUtensilSpoon\", ()=>faUtensilSpoon\n);\nparcelHelpers.export(exports, \"faSprayCan\", ()=>faSprayCan\n);\nparcelHelpers.export(exports, \"faSprayCanSparkles\", ()=>faSprayCanSparkles\n);\nparcelHelpers.export(exports, \"faAirFreshener\", ()=>faAirFreshener\n);\nparcelHelpers.export(exports, \"faSquare\", ()=>faSquare\n);\nparcelHelpers.export(exports, \"faSquareArrowUpRight\", ()=>faSquareArrowUpRight\n);\nparcelHelpers.export(exports, \"faExternalLinkSquare\", ()=>faExternalLinkSquare\n);\nparcelHelpers.export(exports, \"faSquareCaretDown\", ()=>faSquareCaretDown\n);\nparcelHelpers.export(exports, \"faCaretSquareDown\", ()=>faCaretSquareDown\n);\nparcelHelpers.export(exports, \"faSquareCaretLeft\", ()=>faSquareCaretLeft\n);\nparcelHelpers.export(exports, \"faCaretSquareLeft\", ()=>faCaretSquareLeft\n);\nparcelHelpers.export(exports, \"faSquareCaretRight\", ()=>faSquareCaretRight\n);\nparcelHelpers.export(exports, \"faCaretSquareRight\", ()=>faCaretSquareRight\n);\nparcelHelpers.export(exports, \"faSquareCaretUp\", ()=>faSquareCaretUp\n);\nparcelHelpers.export(exports, \"faCaretSquareUp\", ()=>faCaretSquareUp\n);\nparcelHelpers.export(exports, \"faSquareCheck\", ()=>faSquareCheck\n);\nparcelHelpers.export(exports, \"faCheckSquare\", ()=>faCheckSquare\n);\nparcelHelpers.export(exports, \"faSquareEnvelope\", ()=>faSquareEnvelope\n);\nparcelHelpers.export(exports, \"faEnvelopeSquare\", ()=>faEnvelopeSquare\n);\nparcelHelpers.export(exports, \"faSquareFull\", ()=>faSquareFull\n);\nparcelHelpers.export(exports, \"faSquareH\", ()=>faSquareH\n);\nparcelHelpers.export(exports, \"faHSquare\", ()=>faHSquare\n);\nparcelHelpers.export(exports, \"faSquareMinus\", ()=>faSquareMinus\n);\nparcelHelpers.export(exports, \"faMinusSquare\", ()=>faMinusSquare\n);\nparcelHelpers.export(exports, \"faSquareParking\", ()=>faSquareParking\n);\nparcelHelpers.export(exports, \"faParking\", ()=>faParking\n);\nparcelHelpers.export(exports, \"faSquarePen\", ()=>faSquarePen\n);\nparcelHelpers.export(exports, \"faPenSquare\", ()=>faPenSquare\n);\nparcelHelpers.export(exports, \"faPencilSquare\", ()=>faPencilSquare\n);\nparcelHelpers.export(exports, \"faSquarePhone\", ()=>faSquarePhone\n);\nparcelHelpers.export(exports, \"faPhoneSquare\", ()=>faPhoneSquare\n);\nparcelHelpers.export(exports, \"faSquarePhoneFlip\", ()=>faSquarePhoneFlip\n);\nparcelHelpers.export(exports, \"faPhoneSquareAlt\", ()=>faPhoneSquareAlt\n);\nparcelHelpers.export(exports, \"faSquarePlus\", ()=>faSquarePlus\n);\nparcelHelpers.export(exports, \"faPlusSquare\", ()=>faPlusSquare\n);\nparcelHelpers.export(exports, \"faSquarePollHorizontal\", ()=>faSquarePollHorizontal\n);\nparcelHelpers.export(exports, \"faPollH\", ()=>faPollH\n);\nparcelHelpers.export(exports, \"faSquarePollVertical\", ()=>faSquarePollVertical\n);\nparcelHelpers.export(exports, \"faPoll\", ()=>faPoll\n);\nparcelHelpers.export(exports, \"faSquareRootVariable\", ()=>faSquareRootVariable\n);\nparcelHelpers.export(exports, \"faSquareRootAlt\", ()=>faSquareRootAlt\n);\nparcelHelpers.export(exports, \"faSquareRss\", ()=>faSquareRss\n);\nparcelHelpers.export(exports, \"faRssSquare\", ()=>faRssSquare\n);\nparcelHelpers.export(exports, \"faSquareShareNodes\", ()=>faSquareShareNodes\n);\nparcelHelpers.export(exports, \"faShareAltSquare\", ()=>faShareAltSquare\n);\nparcelHelpers.export(exports, \"faSquareUpRight\", ()=>faSquareUpRight\n);\nparcelHelpers.export(exports, \"faExternalLinkSquareAlt\", ()=>faExternalLinkSquareAlt\n);\nparcelHelpers.export(exports, \"faSquareXmark\", ()=>faSquareXmark\n);\nparcelHelpers.export(exports, \"faTimesSquare\", ()=>faTimesSquare\n);\nparcelHelpers.export(exports, \"faXmarkSquare\", ()=>faXmarkSquare\n);\nparcelHelpers.export(exports, \"faStairs\", ()=>faStairs\n);\nparcelHelpers.export(exports, \"faStamp\", ()=>faStamp\n);\nparcelHelpers.export(exports, \"faStar\", ()=>faStar\n);\nparcelHelpers.export(exports, \"faStarAndCrescent\", ()=>faStarAndCrescent\n);\nparcelHelpers.export(exports, \"faStarHalf\", ()=>faStarHalf\n);\nparcelHelpers.export(exports, \"faStarHalfStroke\", ()=>faStarHalfStroke\n);\nparcelHelpers.export(exports, \"faStarHalfAlt\", ()=>faStarHalfAlt\n);\nparcelHelpers.export(exports, \"faStarOfDavid\", ()=>faStarOfDavid\n);\nparcelHelpers.export(exports, \"faStarOfLife\", ()=>faStarOfLife\n);\nparcelHelpers.export(exports, \"faSterlingSign\", ()=>faSterlingSign\n);\nparcelHelpers.export(exports, \"faGbp\", ()=>faGbp\n);\nparcelHelpers.export(exports, \"faPoundSign\", ()=>faPoundSign\n);\nparcelHelpers.export(exports, \"faStethoscope\", ()=>faStethoscope\n);\nparcelHelpers.export(exports, \"faStop\", ()=>faStop\n);\nparcelHelpers.export(exports, \"faStopwatch\", ()=>faStopwatch\n);\nparcelHelpers.export(exports, \"faStopwatch20\", ()=>faStopwatch20\n);\nparcelHelpers.export(exports, \"faStore\", ()=>faStore\n);\nparcelHelpers.export(exports, \"faStoreSlash\", ()=>faStoreSlash\n);\nparcelHelpers.export(exports, \"faStreetView\", ()=>faStreetView\n);\nparcelHelpers.export(exports, \"faStrikethrough\", ()=>faStrikethrough\n);\nparcelHelpers.export(exports, \"faStroopwafel\", ()=>faStroopwafel\n);\nparcelHelpers.export(exports, \"faSubscript\", ()=>faSubscript\n);\nparcelHelpers.export(exports, \"faSuitcase\", ()=>faSuitcase\n);\nparcelHelpers.export(exports, \"faSuitcaseMedical\", ()=>faSuitcaseMedical\n);\nparcelHelpers.export(exports, \"faMedkit\", ()=>faMedkit\n);\nparcelHelpers.export(exports, \"faSuitcaseRolling\", ()=>faSuitcaseRolling\n);\nparcelHelpers.export(exports, \"faSun\", ()=>faSun\n);\nparcelHelpers.export(exports, \"faSuperscript\", ()=>faSuperscript\n);\nparcelHelpers.export(exports, \"faSwatchbook\", ()=>faSwatchbook\n);\nparcelHelpers.export(exports, \"faSynagogue\", ()=>faSynagogue\n);\nparcelHelpers.export(exports, \"faSyringe\", ()=>faSyringe\n);\nparcelHelpers.export(exports, \"faT\", ()=>faT\n);\nparcelHelpers.export(exports, \"faTable\", ()=>faTable\n);\nparcelHelpers.export(exports, \"faTableCells\", ()=>faTableCells\n);\nparcelHelpers.export(exports, \"faTh\", ()=>faTh\n);\nparcelHelpers.export(exports, \"faTableCellsLarge\", ()=>faTableCellsLarge\n);\nparcelHelpers.export(exports, \"faThLarge\", ()=>faThLarge\n);\nparcelHelpers.export(exports, \"faTableColumns\", ()=>faTableColumns\n);\nparcelHelpers.export(exports, \"faColumns\", ()=>faColumns\n);\nparcelHelpers.export(exports, \"faTableList\", ()=>faTableList\n);\nparcelHelpers.export(exports, \"faThList\", ()=>faThList\n);\nparcelHelpers.export(exports, \"faTableTennisPaddleBall\", ()=>faTableTennisPaddleBall\n);\nparcelHelpers.export(exports, \"faPingPongPaddleBall\", ()=>faPingPongPaddleBall\n);\nparcelHelpers.export(exports, \"faTableTennis\", ()=>faTableTennis\n);\nparcelHelpers.export(exports, \"faTablet\", ()=>faTablet\n);\nparcelHelpers.export(exports, \"faTabletAndroid\", ()=>faTabletAndroid\n);\nparcelHelpers.export(exports, \"faTabletButton\", ()=>faTabletButton\n);\nparcelHelpers.export(exports, \"faTabletScreenButton\", ()=>faTabletScreenButton\n);\nparcelHelpers.export(exports, \"faTabletAlt\", ()=>faTabletAlt\n);\nparcelHelpers.export(exports, \"faTablets\", ()=>faTablets\n);\nparcelHelpers.export(exports, \"faTachographDigital\", ()=>faTachographDigital\n);\nparcelHelpers.export(exports, \"faDigitalTachograph\", ()=>faDigitalTachograph\n);\nparcelHelpers.export(exports, \"faTag\", ()=>faTag\n);\nparcelHelpers.export(exports, \"faTags\", ()=>faTags\n);\nparcelHelpers.export(exports, \"faTape\", ()=>faTape\n);\nparcelHelpers.export(exports, \"faTaxi\", ()=>faTaxi\n);\nparcelHelpers.export(exports, \"faCab\", ()=>faCab\n);\nparcelHelpers.export(exports, \"faTeeth\", ()=>faTeeth\n);\nparcelHelpers.export(exports, \"faTeethOpen\", ()=>faTeethOpen\n);\nparcelHelpers.export(exports, \"faTemperatureEmpty\", ()=>faTemperatureEmpty\n);\nparcelHelpers.export(exports, \"faTemperature0\", ()=>faTemperature0\n);\nparcelHelpers.export(exports, \"faThermometer0\", ()=>faThermometer0\n);\nparcelHelpers.export(exports, \"faThermometerEmpty\", ()=>faThermometerEmpty\n);\nparcelHelpers.export(exports, \"faTemperatureFull\", ()=>faTemperatureFull\n);\nparcelHelpers.export(exports, \"faTemperature4\", ()=>faTemperature4\n);\nparcelHelpers.export(exports, \"faThermometer4\", ()=>faThermometer4\n);\nparcelHelpers.export(exports, \"faThermometerFull\", ()=>faThermometerFull\n);\nparcelHelpers.export(exports, \"faTemperatureHalf\", ()=>faTemperatureHalf\n);\nparcelHelpers.export(exports, \"faTemperature2\", ()=>faTemperature2\n);\nparcelHelpers.export(exports, \"faThermometer2\", ()=>faThermometer2\n);\nparcelHelpers.export(exports, \"faThermometerHalf\", ()=>faThermometerHalf\n);\nparcelHelpers.export(exports, \"faTemperatureHigh\", ()=>faTemperatureHigh\n);\nparcelHelpers.export(exports, \"faTemperatureLow\", ()=>faTemperatureLow\n);\nparcelHelpers.export(exports, \"faTemperatureQuarter\", ()=>faTemperatureQuarter\n);\nparcelHelpers.export(exports, \"faTemperature1\", ()=>faTemperature1\n);\nparcelHelpers.export(exports, \"faThermometer1\", ()=>faThermometer1\n);\nparcelHelpers.export(exports, \"faThermometerQuarter\", ()=>faThermometerQuarter\n);\nparcelHelpers.export(exports, \"faTemperatureThreeQuarters\", ()=>faTemperatureThreeQuarters\n);\nparcelHelpers.export(exports, \"faTemperature3\", ()=>faTemperature3\n);\nparcelHelpers.export(exports, \"faThermometer3\", ()=>faThermometer3\n);\nparcelHelpers.export(exports, \"faThermometerThreeQuarters\", ()=>faThermometerThreeQuarters\n);\nparcelHelpers.export(exports, \"faTengeSign\", ()=>faTengeSign\n);\nparcelHelpers.export(exports, \"faTenge\", ()=>faTenge\n);\nparcelHelpers.export(exports, \"faTerminal\", ()=>faTerminal\n);\nparcelHelpers.export(exports, \"faTextHeight\", ()=>faTextHeight\n);\nparcelHelpers.export(exports, \"faTextSlash\", ()=>faTextSlash\n);\nparcelHelpers.export(exports, \"faRemoveFormat\", ()=>faRemoveFormat\n);\nparcelHelpers.export(exports, \"faTextWidth\", ()=>faTextWidth\n);\nparcelHelpers.export(exports, \"faThermometer\", ()=>faThermometer\n);\nparcelHelpers.export(exports, \"faThumbsDown\", ()=>faThumbsDown\n);\nparcelHelpers.export(exports, \"faThumbsUp\", ()=>faThumbsUp\n);\nparcelHelpers.export(exports, \"faThumbtack\", ()=>faThumbtack\n);\nparcelHelpers.export(exports, \"faThumbTack\", ()=>faThumbTack\n);\nparcelHelpers.export(exports, \"faTicket\", ()=>faTicket\n);\nparcelHelpers.export(exports, \"faTicketSimple\", ()=>faTicketSimple\n);\nparcelHelpers.export(exports, \"faTicketAlt\", ()=>faTicketAlt\n);\nparcelHelpers.export(exports, \"faTimeline\", ()=>faTimeline\n);\nparcelHelpers.export(exports, \"faToggleOff\", ()=>faToggleOff\n);\nparcelHelpers.export(exports, \"faToggleOn\", ()=>faToggleOn\n);\nparcelHelpers.export(exports, \"faToilet\", ()=>faToilet\n);\nparcelHelpers.export(exports, \"faToiletPaper\", ()=>faToiletPaper\n);\nparcelHelpers.export(exports, \"faToiletPaperSlash\", ()=>faToiletPaperSlash\n);\nparcelHelpers.export(exports, \"faToolbox\", ()=>faToolbox\n);\nparcelHelpers.export(exports, \"faTooth\", ()=>faTooth\n);\nparcelHelpers.export(exports, \"faToriiGate\", ()=>faToriiGate\n);\nparcelHelpers.export(exports, \"faTowerBroadcast\", ()=>faTowerBroadcast\n);\nparcelHelpers.export(exports, \"faBroadcastTower\", ()=>faBroadcastTower\n);\nparcelHelpers.export(exports, \"faTractor\", ()=>faTractor\n);\nparcelHelpers.export(exports, \"faTrademark\", ()=>faTrademark\n);\nparcelHelpers.export(exports, \"faTrafficLight\", ()=>faTrafficLight\n);\nparcelHelpers.export(exports, \"faTrailer\", ()=>faTrailer\n);\nparcelHelpers.export(exports, \"faTrain\", ()=>faTrain\n);\nparcelHelpers.export(exports, \"faTrainSubway\", ()=>faTrainSubway\n);\nparcelHelpers.export(exports, \"faSubway\", ()=>faSubway\n);\nparcelHelpers.export(exports, \"faTrainTram\", ()=>faTrainTram\n);\nparcelHelpers.export(exports, \"faTram\", ()=>faTram\n);\nparcelHelpers.export(exports, \"faTransgender\", ()=>faTransgender\n);\nparcelHelpers.export(exports, \"faTransgenderAlt\", ()=>faTransgenderAlt\n);\nparcelHelpers.export(exports, \"faTrash\", ()=>faTrash\n);\nparcelHelpers.export(exports, \"faTrashArrowUp\", ()=>faTrashArrowUp\n);\nparcelHelpers.export(exports, \"faTrashRestore\", ()=>faTrashRestore\n);\nparcelHelpers.export(exports, \"faTrashCan\", ()=>faTrashCan\n);\nparcelHelpers.export(exports, \"faTrashAlt\", ()=>faTrashAlt\n);\nparcelHelpers.export(exports, \"faTrashCanArrowUp\", ()=>faTrashCanArrowUp\n);\nparcelHelpers.export(exports, \"faTrashRestoreAlt\", ()=>faTrashRestoreAlt\n);\nparcelHelpers.export(exports, \"faTree\", ()=>faTree\n);\nparcelHelpers.export(exports, \"faTriangleExclamation\", ()=>faTriangleExclamation\n);\nparcelHelpers.export(exports, \"faExclamationTriangle\", ()=>faExclamationTriangle\n);\nparcelHelpers.export(exports, \"faWarning\", ()=>faWarning\n);\nparcelHelpers.export(exports, \"faTrophy\", ()=>faTrophy\n);\nparcelHelpers.export(exports, \"faTruck\", ()=>faTruck\n);\nparcelHelpers.export(exports, \"faTruckFast\", ()=>faTruckFast\n);\nparcelHelpers.export(exports, \"faShippingFast\", ()=>faShippingFast\n);\nparcelHelpers.export(exports, \"faTruckMedical\", ()=>faTruckMedical\n);\nparcelHelpers.export(exports, \"faAmbulance\", ()=>faAmbulance\n);\nparcelHelpers.export(exports, \"faTruckMonster\", ()=>faTruckMonster\n);\nparcelHelpers.export(exports, \"faTruckMoving\", ()=>faTruckMoving\n);\nparcelHelpers.export(exports, \"faTruckPickup\", ()=>faTruckPickup\n);\nparcelHelpers.export(exports, \"faTruckRampBox\", ()=>faTruckRampBox\n);\nparcelHelpers.export(exports, \"faTruckLoading\", ()=>faTruckLoading\n);\nparcelHelpers.export(exports, \"faTty\", ()=>faTty\n);\nparcelHelpers.export(exports, \"faTeletype\", ()=>faTeletype\n);\nparcelHelpers.export(exports, \"faTurkishLiraSign\", ()=>faTurkishLiraSign\n);\nparcelHelpers.export(exports, \"faTry\", ()=>faTry\n);\nparcelHelpers.export(exports, \"faTurkishLira\", ()=>faTurkishLira\n);\nparcelHelpers.export(exports, \"faTurnDown\", ()=>faTurnDown\n);\nparcelHelpers.export(exports, \"faLevelDownAlt\", ()=>faLevelDownAlt\n);\nparcelHelpers.export(exports, \"faTurnUp\", ()=>faTurnUp\n);\nparcelHelpers.export(exports, \"faLevelUpAlt\", ()=>faLevelUpAlt\n);\nparcelHelpers.export(exports, \"faTv\", ()=>faTv\n);\nparcelHelpers.export(exports, \"faTelevision\", ()=>faTelevision\n);\nparcelHelpers.export(exports, \"faTvAlt\", ()=>faTvAlt\n);\nparcelHelpers.export(exports, \"faU\", ()=>faU\n);\nparcelHelpers.export(exports, \"faUmbrella\", ()=>faUmbrella\n);\nparcelHelpers.export(exports, \"faUmbrellaBeach\", ()=>faUmbrellaBeach\n);\nparcelHelpers.export(exports, \"faUnderline\", ()=>faUnderline\n);\nparcelHelpers.export(exports, \"faUniversalAccess\", ()=>faUniversalAccess\n);\nparcelHelpers.export(exports, \"faUnlock\", ()=>faUnlock\n);\nparcelHelpers.export(exports, \"faUnlockKeyhole\", ()=>faUnlockKeyhole\n);\nparcelHelpers.export(exports, \"faUnlockAlt\", ()=>faUnlockAlt\n);\nparcelHelpers.export(exports, \"faUpDown\", ()=>faUpDown\n);\nparcelHelpers.export(exports, \"faArrowsAltV\", ()=>faArrowsAltV\n);\nparcelHelpers.export(exports, \"faUpDownLeftRight\", ()=>faUpDownLeftRight\n);\nparcelHelpers.export(exports, \"faArrowsAlt\", ()=>faArrowsAlt\n);\nparcelHelpers.export(exports, \"faUpLong\", ()=>faUpLong\n);\nparcelHelpers.export(exports, \"faLongArrowAltUp\", ()=>faLongArrowAltUp\n);\nparcelHelpers.export(exports, \"faUpRightAndDownLeftFromCenter\", ()=>faUpRightAndDownLeftFromCenter\n);\nparcelHelpers.export(exports, \"faExpandAlt\", ()=>faExpandAlt\n);\nparcelHelpers.export(exports, \"faUpRightFromSquare\", ()=>faUpRightFromSquare\n);\nparcelHelpers.export(exports, \"faExternalLinkAlt\", ()=>faExternalLinkAlt\n);\nparcelHelpers.export(exports, \"faUpload\", ()=>faUpload\n);\nparcelHelpers.export(exports, \"faUser\", ()=>faUser\n);\nparcelHelpers.export(exports, \"faUserAstronaut\", ()=>faUserAstronaut\n);\nparcelHelpers.export(exports, \"faUserCheck\", ()=>faUserCheck\n);\nparcelHelpers.export(exports, \"faUserClock\", ()=>faUserClock\n);\nparcelHelpers.export(exports, \"faUserDoctor\", ()=>faUserDoctor\n);\nparcelHelpers.export(exports, \"faUserMd\", ()=>faUserMd\n);\nparcelHelpers.export(exports, \"faUserGear\", ()=>faUserGear\n);\nparcelHelpers.export(exports, \"faUserCog\", ()=>faUserCog\n);\nparcelHelpers.export(exports, \"faUserGraduate\", ()=>faUserGraduate\n);\nparcelHelpers.export(exports, \"faUserGroup\", ()=>faUserGroup\n);\nparcelHelpers.export(exports, \"faUserFriends\", ()=>faUserFriends\n);\nparcelHelpers.export(exports, \"faUserInjured\", ()=>faUserInjured\n);\nparcelHelpers.export(exports, \"faUserLarge\", ()=>faUserLarge\n);\nparcelHelpers.export(exports, \"faUserAlt\", ()=>faUserAlt\n);\nparcelHelpers.export(exports, \"faUserLargeSlash\", ()=>faUserLargeSlash\n);\nparcelHelpers.export(exports, \"faUserAltSlash\", ()=>faUserAltSlash\n);\nparcelHelpers.export(exports, \"faUserLock\", ()=>faUserLock\n);\nparcelHelpers.export(exports, \"faUserMinus\", ()=>faUserMinus\n);\nparcelHelpers.export(exports, \"faUserNinja\", ()=>faUserNinja\n);\nparcelHelpers.export(exports, \"faUserNurse\", ()=>faUserNurse\n);\nparcelHelpers.export(exports, \"faUserPen\", ()=>faUserPen\n);\nparcelHelpers.export(exports, \"faUserEdit\", ()=>faUserEdit\n);\nparcelHelpers.export(exports, \"faUserPlus\", ()=>faUserPlus\n);\nparcelHelpers.export(exports, \"faUserSecret\", ()=>faUserSecret\n);\nparcelHelpers.export(exports, \"faUserShield\", ()=>faUserShield\n);\nparcelHelpers.export(exports, \"faUserSlash\", ()=>faUserSlash\n);\nparcelHelpers.export(exports, \"faUserTag\", ()=>faUserTag\n);\nparcelHelpers.export(exports, \"faUserTie\", ()=>faUserTie\n);\nparcelHelpers.export(exports, \"faUserXmark\", ()=>faUserXmark\n);\nparcelHelpers.export(exports, \"faUserTimes\", ()=>faUserTimes\n);\nparcelHelpers.export(exports, \"faUsers\", ()=>faUsers\n);\nparcelHelpers.export(exports, \"faUsersGear\", ()=>faUsersGear\n);\nparcelHelpers.export(exports, \"faUsersCog\", ()=>faUsersCog\n);\nparcelHelpers.export(exports, \"faUsersSlash\", ()=>faUsersSlash\n);\nparcelHelpers.export(exports, \"faUtensils\", ()=>faUtensils\n);\nparcelHelpers.export(exports, \"faCutlery\", ()=>faCutlery\n);\nparcelHelpers.export(exports, \"faV\", ()=>faV\n);\nparcelHelpers.export(exports, \"faVanShuttle\", ()=>faVanShuttle\n);\nparcelHelpers.export(exports, \"faShuttleVan\", ()=>faShuttleVan\n);\nparcelHelpers.export(exports, \"faVault\", ()=>faVault\n);\nparcelHelpers.export(exports, \"faVectorSquare\", ()=>faVectorSquare\n);\nparcelHelpers.export(exports, \"faVenus\", ()=>faVenus\n);\nparcelHelpers.export(exports, \"faVenusDouble\", ()=>faVenusDouble\n);\nparcelHelpers.export(exports, \"faVenusMars\", ()=>faVenusMars\n);\nparcelHelpers.export(exports, \"faVest\", ()=>faVest\n);\nparcelHelpers.export(exports, \"faVestPatches\", ()=>faVestPatches\n);\nparcelHelpers.export(exports, \"faVial\", ()=>faVial\n);\nparcelHelpers.export(exports, \"faVials\", ()=>faVials\n);\nparcelHelpers.export(exports, \"faVideo\", ()=>faVideo\n);\nparcelHelpers.export(exports, \"faVideoCamera\", ()=>faVideoCamera\n);\nparcelHelpers.export(exports, \"faVideoSlash\", ()=>faVideoSlash\n);\nparcelHelpers.export(exports, \"faVihara\", ()=>faVihara\n);\nparcelHelpers.export(exports, \"faVirus\", ()=>faVirus\n);\nparcelHelpers.export(exports, \"faVirusCovid\", ()=>faVirusCovid\n);\nparcelHelpers.export(exports, \"faVirusCovidSlash\", ()=>faVirusCovidSlash\n);\nparcelHelpers.export(exports, \"faVirusSlash\", ()=>faVirusSlash\n);\nparcelHelpers.export(exports, \"faViruses\", ()=>faViruses\n);\nparcelHelpers.export(exports, \"faVoicemail\", ()=>faVoicemail\n);\nparcelHelpers.export(exports, \"faVolleyball\", ()=>faVolleyball\n);\nparcelHelpers.export(exports, \"faVolleyballBall\", ()=>faVolleyballBall\n);\nparcelHelpers.export(exports, \"faVolumeHigh\", ()=>faVolumeHigh\n);\nparcelHelpers.export(exports, \"faVolumeUp\", ()=>faVolumeUp\n);\nparcelHelpers.export(exports, \"faVolumeLow\", ()=>faVolumeLow\n);\nparcelHelpers.export(exports, \"faVolumeDown\", ()=>faVolumeDown\n);\nparcelHelpers.export(exports, \"faVolumeOff\", ()=>faVolumeOff\n);\nparcelHelpers.export(exports, \"faVolumeXmark\", ()=>faVolumeXmark\n);\nparcelHelpers.export(exports, \"faVolumeMute\", ()=>faVolumeMute\n);\nparcelHelpers.export(exports, \"faVolumeTimes\", ()=>faVolumeTimes\n);\nparcelHelpers.export(exports, \"faVrCardboard\", ()=>faVrCardboard\n);\nparcelHelpers.export(exports, \"faW\", ()=>faW\n);\nparcelHelpers.export(exports, \"faWallet\", ()=>faWallet\n);\nparcelHelpers.export(exports, \"faWandMagic\", ()=>faWandMagic\n);\nparcelHelpers.export(exports, \"faMagic\", ()=>faMagic\n);\nparcelHelpers.export(exports, \"faWandMagicSparkles\", ()=>faWandMagicSparkles\n);\nparcelHelpers.export(exports, \"faMagicWandSparkles\", ()=>faMagicWandSparkles\n);\nparcelHelpers.export(exports, \"faWandSparkles\", ()=>faWandSparkles\n);\nparcelHelpers.export(exports, \"faWarehouse\", ()=>faWarehouse\n);\nparcelHelpers.export(exports, \"faWater\", ()=>faWater\n);\nparcelHelpers.export(exports, \"faWaterLadder\", ()=>faWaterLadder\n);\nparcelHelpers.export(exports, \"faLadderWater\", ()=>faLadderWater\n);\nparcelHelpers.export(exports, \"faSwimmingPool\", ()=>faSwimmingPool\n);\nparcelHelpers.export(exports, \"faWaveSquare\", ()=>faWaveSquare\n);\nparcelHelpers.export(exports, \"faWeightHanging\", ()=>faWeightHanging\n);\nparcelHelpers.export(exports, \"faWeightScale\", ()=>faWeightScale\n);\nparcelHelpers.export(exports, \"faWeight\", ()=>faWeight\n);\nparcelHelpers.export(exports, \"faWheelchair\", ()=>faWheelchair\n);\nparcelHelpers.export(exports, \"faWhiskeyGlass\", ()=>faWhiskeyGlass\n);\nparcelHelpers.export(exports, \"faGlassWhiskey\", ()=>faGlassWhiskey\n);\nparcelHelpers.export(exports, \"faWifi\", ()=>faWifi\n);\nparcelHelpers.export(exports, \"faWifi3\", ()=>faWifi3\n);\nparcelHelpers.export(exports, \"faWifiStrong\", ()=>faWifiStrong\n);\nparcelHelpers.export(exports, \"faWind\", ()=>faWind\n);\nparcelHelpers.export(exports, \"faWindowMaximize\", ()=>faWindowMaximize\n);\nparcelHelpers.export(exports, \"faWindowMinimize\", ()=>faWindowMinimize\n);\nparcelHelpers.export(exports, \"faWindowRestore\", ()=>faWindowRestore\n);\nparcelHelpers.export(exports, \"faWineBottle\", ()=>faWineBottle\n);\nparcelHelpers.export(exports, \"faWineGlass\", ()=>faWineGlass\n);\nparcelHelpers.export(exports, \"faWineGlassEmpty\", ()=>faWineGlassEmpty\n);\nparcelHelpers.export(exports, \"faWineGlassAlt\", ()=>faWineGlassAlt\n);\nparcelHelpers.export(exports, \"faWonSign\", ()=>faWonSign\n);\nparcelHelpers.export(exports, \"faKrw\", ()=>faKrw\n);\nparcelHelpers.export(exports, \"faWon\", ()=>faWon\n);\nparcelHelpers.export(exports, \"faWrench\", ()=>faWrench\n);\nparcelHelpers.export(exports, \"faX\", ()=>faX\n);\nparcelHelpers.export(exports, \"faXRay\", ()=>faXRay\n);\nparcelHelpers.export(exports, \"faXmark\", ()=>faXmark\n);\nparcelHelpers.export(exports, \"faClose\", ()=>faClose\n);\nparcelHelpers.export(exports, \"faMultiply\", ()=>faMultiply\n);\nparcelHelpers.export(exports, \"faRemove\", ()=>faRemove\n);\nparcelHelpers.export(exports, \"faTimes\", ()=>faTimes\n);\nparcelHelpers.export(exports, \"faY\", ()=>faY\n);\nparcelHelpers.export(exports, \"faYenSign\", ()=>faYenSign\n);\nparcelHelpers.export(exports, \"faCny\", ()=>faCny\n);\nparcelHelpers.export(exports, \"faJpy\", ()=>faJpy\n);\nparcelHelpers.export(exports, \"faRmb\", ()=>faRmb\n);\nparcelHelpers.export(exports, \"faYen\", ()=>faYen\n);\nparcelHelpers.export(exports, \"faYinYang\", ()=>faYinYang\n);\nparcelHelpers.export(exports, \"faZ\", ()=>faZ\n);\n/*!\n * Font Awesome Free 6.0.0 by @fontawesome - https://fontawesome.com\n * License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License)\n * Copyright 2022 Fonticons, Inc.\n */ var prefix = \"fas\";\nvar fa0 = {\n prefix: 'fas',\n iconName: '0',\n icon: [\n 320,\n 512,\n [],\n \"30\",\n \"M160 32.01c-88.37 0-160 71.63-160 160v127.1c0 88.37 71.63 160 160 160s160-71.63 160-160V192C320 103.6 248.4 32.01 160 32.01zM256 320c0 52.93-43.06 96-96 96c-52.93 0-96-43.07-96-96V192c0-52.94 43.07-96 96-96c52.94 0 96 43.06 96 96V320z\"\n ]\n};\nvar fa1 = {\n prefix: 'fas',\n iconName: '1',\n icon: [\n 256,\n 512,\n [],\n \"31\",\n \"M256 448c0 17.67-14.33 32-32 32H32c-17.67 0-32-14.33-32-32s14.33-32 32-32h64V123.8L49.75 154.6C35.02 164.5 15.19 160.4 5.375 145.8C-4.422 131.1-.4531 111.2 14.25 101.4l96-64c9.828-6.547 22.45-7.187 32.84-1.594C153.5 41.37 160 52.22 160 64.01v352h64C241.7 416 256 430.3 256 448z\"\n ]\n};\nvar fa2 = {\n prefix: 'fas',\n iconName: '2',\n icon: [\n 320,\n 512,\n [],\n \"32\",\n \"M320 448c0 17.67-14.33 32-32 32H32c-13.08 0-24.83-7.953-29.7-20.09c-4.859-12.12-1.859-26 7.594-35.03l193.6-185.1c31.36-30.17 33.95-80 5.812-113.4c-14.91-17.69-35.86-28.12-58.97-29.38C127.4 95.83 105.3 103.9 88.53 119.9L53.52 151.7c-13.08 11.91-33.33 10.89-45.2-2.172C-3.563 136.5-2.594 116.2 10.48 104.3l34.45-31.3c28.67-27.34 68.39-42.11 108.9-39.88c40.33 2.188 78.39 21.16 104.4 52.03c49.8 59.05 45.2 147.3-10.45 200.8l-136 130H288C305.7 416 320 430.3 320 448z\"\n ]\n};\nvar fa3 = {\n prefix: 'fas',\n iconName: '3',\n icon: [\n 320,\n 512,\n [],\n \"33\",\n \"M320 344c0 74.98-61.02 136-136 136H103.6c-46.34 0-87.31-29.53-101.1-73.48c-5.594-16.77 3.484-34.88 20.25-40.47c16.75-5.609 34.89 3.484 40.47 20.25c5.922 17.77 22.48 29.7 41.23 29.7H184c39.7 0 72-32.3 72-72s-32.3-72-72-72H80c-13.2 0-25.05-8.094-29.83-20.41C45.39 239.3 48.66 225.3 58.38 216.4l131.4-120.4H32c-17.67 0-32-14.33-32-32s14.33-32 32-32h240c13.2 0 25.05 8.094 29.83 20.41c4.781 12.3 1.516 26.27-8.203 35.19l-131.4 120.4H184C258.1 208 320 269 320 344z\"\n ]\n};\nvar fa4 = {\n prefix: 'fas',\n iconName: '4',\n icon: [\n 384,\n 512,\n [],\n \"34\",\n \"M384 334.2c0 17.67-14.33 32-32 32h-32v81.78c0 17.67-14.33 32-32 32s-32-14.33-32-32v-81.78H32c-10.97 0-21.17-5.625-27.05-14.89c-5.859-9.266-6.562-20.89-1.875-30.81l128-270.2C138.6 34.33 157.8 27.56 173.7 35.09c15.97 7.562 22.78 26.66 15.22 42.63L82.56 302.2H256V160c0-17.67 14.33-32 32-32s32 14.33 32 32v142.2h32C369.7 302.2 384 316.6 384 334.2z\"\n ]\n};\nvar fa5 = {\n prefix: 'fas',\n iconName: '5',\n icon: [\n 320,\n 512,\n [],\n \"35\",\n \"M320 344.6c0 74.66-60.73 135.4-135.4 135.4H104.7c-46.81 0-88.22-29.83-103-74.23c-5.594-16.77 3.469-34.89 20.23-40.48c16.83-5.625 34.91 3.469 40.48 20.23c6.078 18.23 23.08 30.48 42.3 30.48h79.95c39.36 0 71.39-32.03 71.39-71.39s-32.03-71.38-71.39-71.38H32c-9.484 0-18.47-4.203-24.56-11.48C1.359 254.5-1.172 244.9 .5156 235.6l32-177.2C35.27 43.09 48.52 32.01 64 32.01l192 .0049c17.67 0 32 14.33 32 32s-14.33 32-32 32H90.73L70.3 209.2h114.3C259.3 209.2 320 269.1 320 344.6z\"\n ]\n};\nvar fa6 = {\n prefix: 'fas',\n iconName: '6',\n icon: [\n 320,\n 512,\n [],\n \"36\",\n \"M167.7 160.8l64.65-76.06c11.47-13.45 9.812-33.66-3.656-45.09C222.7 34.51 215.3 32.01 208 32.01c-9.062 0-18.06 3.833-24.38 11.29C38.07 214.5 0 245.5 0 320c0 88.22 71.78 160 160 160s160-71.78 160-160C320 234.4 252.3 164.9 167.7 160.8zM160 416c-52.94 0-96-43.06-96-96s43.06-95.1 96-95.1s96 43.06 96 95.1S212.9 416 160 416z\"\n ]\n};\nvar fa7 = {\n prefix: 'fas',\n iconName: '7',\n icon: [\n 320,\n 512,\n [],\n \"37\",\n \"M315.6 80.14l-224 384c-5.953 10.19-16.66 15.88-27.67 15.88c-5.469 0-11.02-1.406-16.09-4.359c-15.27-8.906-20.42-28.5-11.52-43.77l195.9-335.9H32c-17.67 0-32-14.33-32-32s14.33-32 32-32h256c11.45 0 22.05 6.125 27.75 16.06S321.4 70.23 315.6 80.14z\"\n ]\n};\nvar fa8 = {\n prefix: 'fas',\n iconName: '8',\n icon: [\n 320,\n 512,\n [],\n \"38\",\n \"M267.5 249.2C290 226.1 304 194.7 304 160c0-70.58-57.42-128-128-128h-32c-70.58 0-128 57.42-128 128c0 34.7 13.99 66.12 36.48 89.19C20.83 272.5 0 309.8 0 352c0 70.58 57.42 128 128 128h64c70.58 0 128-57.42 128-128C320 309.8 299.2 272.5 267.5 249.2zM144 96.01h32c35.3 0 64 28.7 64 64s-28.7 64-64 64h-32c-35.3 0-64-28.7-64-64S108.7 96.01 144 96.01zM192 416H128c-35.3 0-64-28.7-64-64s28.7-64 64-64h64c35.3 0 64 28.7 64 64S227.3 416 192 416z\"\n ]\n};\nvar fa9 = {\n prefix: 'fas',\n iconName: '9',\n icon: [\n 320,\n 512,\n [],\n \"39\",\n \"M160 32.01c-88.22 0-160 71.78-160 160c0 85.57 67.71 155.1 152.3 159.2l-64.65 76.06c-11.47 13.45-9.812 33.66 3.656 45.09c6 5.125 13.38 7.62 20.72 7.62c9.062 0 18.06-3.823 24.38-11.28C281.9 297.5 320 266.6 320 192C320 103.8 248.2 32.01 160 32.01zM160 288c-52.94 0-96-43.06-96-95.1s43.06-96 96-96s96 43.06 96 96S212.9 288 160 288z\"\n ]\n};\nvar faA = {\n prefix: 'fas',\n iconName: 'a',\n icon: [\n 384,\n 512,\n [\n 97\n ],\n \"41\",\n \"M381.5 435.7l-160-384C216.6 39.78 204.9 32.01 192 32.01S167.4 39.78 162.5 51.7l-160 384c-6.797 16.31 .9062 35.05 17.22 41.84c16.38 6.828 35.08-.9219 41.84-17.22l31.8-76.31h197.3l31.8 76.31c5.109 12.28 17.02 19.7 29.55 19.7c4.094 0 8.266-.7969 12.3-2.484C380.6 470.7 388.3 452 381.5 435.7zM119.1 320L192 147.2l72 172.8H119.1z\"\n ]\n};\nvar faAddressBook = {\n prefix: 'fas',\n iconName: 'address-book',\n icon: [\n 512,\n 512,\n [\n 62138,\n \"contact-book\"\n ],\n \"f2b9\",\n \"M384 0H96C60.65 0 32 28.65 32 64v384c0 35.35 28.65 64 64 64h288c35.35 0 64-28.65 64-64V64C448 28.65 419.3 0 384 0zM240 128c35.35 0 64 28.65 64 64s-28.65 64-64 64c-35.34 0-64-28.65-64-64S204.7 128 240 128zM336 384h-192C135.2 384 128 376.8 128 368C128 323.8 163.8 288 208 288h64c44.18 0 80 35.82 80 80C352 376.8 344.8 384 336 384zM496 64H480v96h16C504.8 160 512 152.8 512 144v-64C512 71.16 504.8 64 496 64zM496 192H480v96h16C504.8 288 512 280.8 512 272v-64C512 199.2 504.8 192 496 192zM496 320H480v96h16c8.836 0 16-7.164 16-16v-64C512 327.2 504.8 320 496 320z\"\n ]\n};\nvar faContactBook = faAddressBook;\nvar faAddressCard = {\n prefix: 'fas',\n iconName: 'address-card',\n icon: [\n 576,\n 512,\n [\n 62140,\n \"contact-card\",\n \"vcard\"\n ],\n \"f2bb\",\n \"M512 32H64C28.65 32 0 60.65 0 96v320c0 35.35 28.65 64 64 64h448c35.35 0 64-28.65 64-64V96C576 60.65 547.3 32 512 32zM176 128c35.35 0 64 28.65 64 64s-28.65 64-64 64s-64-28.65-64-64S140.7 128 176 128zM272 384h-192C71.16 384 64 376.8 64 368C64 323.8 99.82 288 144 288h64c44.18 0 80 35.82 80 80C288 376.8 280.8 384 272 384zM496 320h-128C359.2 320 352 312.8 352 304S359.2 288 368 288h128C504.8 288 512 295.2 512 304S504.8 320 496 320zM496 256h-128C359.2 256 352 248.8 352 240S359.2 224 368 224h128C504.8 224 512 231.2 512 240S504.8 256 496 256zM496 192h-128C359.2 192 352 184.8 352 176S359.2 160 368 160h128C504.8 160 512 167.2 512 176S504.8 192 496 192z\"\n ]\n};\nvar faContactCard = faAddressCard;\nvar faVcard = faAddressCard;\nvar faAlignCenter = {\n prefix: 'fas',\n iconName: 'align-center',\n icon: [\n 448,\n 512,\n [],\n \"f037\",\n \"M320 96H128C110.3 96 96 81.67 96 64C96 46.33 110.3 32 128 32H320C337.7 32 352 46.33 352 64C352 81.67 337.7 96 320 96zM416 224H32C14.33 224 0 209.7 0 192C0 174.3 14.33 160 32 160H416C433.7 160 448 174.3 448 192C448 209.7 433.7 224 416 224zM0 448C0 430.3 14.33 416 32 416H416C433.7 416 448 430.3 448 448C448 465.7 433.7 480 416 480H32C14.33 480 0 465.7 0 448zM320 352H128C110.3 352 96 337.7 96 320C96 302.3 110.3 288 128 288H320C337.7 288 352 302.3 352 320C352 337.7 337.7 352 320 352z\"\n ]\n};\nvar faAlignJustify = {\n prefix: 'fas',\n iconName: 'align-justify',\n icon: [\n 448,\n 512,\n [],\n \"f039\",\n \"M416 96H32C14.33 96 0 81.67 0 64C0 46.33 14.33 32 32 32H416C433.7 32 448 46.33 448 64C448 81.67 433.7 96 416 96zM416 352H32C14.33 352 0 337.7 0 320C0 302.3 14.33 288 32 288H416C433.7 288 448 302.3 448 320C448 337.7 433.7 352 416 352zM0 192C0 174.3 14.33 160 32 160H416C433.7 160 448 174.3 448 192C448 209.7 433.7 224 416 224H32C14.33 224 0 209.7 0 192zM416 480H32C14.33 480 0 465.7 0 448C0 430.3 14.33 416 32 416H416C433.7 416 448 430.3 448 448C448 465.7 433.7 480 416 480z\"\n ]\n};\nvar faAlignLeft = {\n prefix: 'fas',\n iconName: 'align-left',\n icon: [\n 448,\n 512,\n [],\n \"f036\",\n \"M256 96H32C14.33 96 0 81.67 0 64C0 46.33 14.33 32 32 32H256C273.7 32 288 46.33 288 64C288 81.67 273.7 96 256 96zM256 352H32C14.33 352 0 337.7 0 320C0 302.3 14.33 288 32 288H256C273.7 288 288 302.3 288 320C288 337.7 273.7 352 256 352zM0 192C0 174.3 14.33 160 32 160H416C433.7 160 448 174.3 448 192C448 209.7 433.7 224 416 224H32C14.33 224 0 209.7 0 192zM416 480H32C14.33 480 0 465.7 0 448C0 430.3 14.33 416 32 416H416C433.7 416 448 430.3 448 448C448 465.7 433.7 480 416 480z\"\n ]\n};\nvar faAlignRight = {\n prefix: 'fas',\n iconName: 'align-right',\n icon: [\n 448,\n 512,\n [],\n \"f038\",\n \"M416 96H192C174.3 96 160 81.67 160 64C160 46.33 174.3 32 192 32H416C433.7 32 448 46.33 448 64C448 81.67 433.7 96 416 96zM416 352H192C174.3 352 160 337.7 160 320C160 302.3 174.3 288 192 288H416C433.7 288 448 302.3 448 320C448 337.7 433.7 352 416 352zM0 192C0 174.3 14.33 160 32 160H416C433.7 160 448 174.3 448 192C448 209.7 433.7 224 416 224H32C14.33 224 0 209.7 0 192zM416 480H32C14.33 480 0 465.7 0 448C0 430.3 14.33 416 32 416H416C433.7 416 448 430.3 448 448C448 465.7 433.7 480 416 480z\"\n ]\n};\nvar faAnchor = {\n prefix: 'fas',\n iconName: 'anchor',\n icon: [\n 576,\n 512,\n [\n 9875\n ],\n \"f13d\",\n \"M352 176C369.7 176 384 190.3 384 208C384 225.7 369.7 240 352 240H320V448H368C421 448 464 405 464 352V345.9L456.1 352.1C447.6 362.3 432.4 362.3 423 352.1C413.7 343.6 413.7 328.4 423 319L479 263C488.4 253.7 503.6 253.7 512.1 263L568.1 319C578.3 328.4 578.3 343.6 568.1 352.1C559.6 362.3 544.4 362.3 535 352.1L528 345.9V352C528 440.4 456.4 512 368 512H208C119.6 512 48 440.4 48 352V345.9L40.97 352.1C31.6 362.3 16.4 362.3 7.029 352.1C-2.343 343.6-2.343 328.4 7.029 319L63.03 263C72.4 253.7 87.6 253.7 96.97 263L152.1 319C162.3 328.4 162.3 343.6 152.1 352.1C143.6 362.3 128.4 362.3 119 352.1L112 345.9V352C112 405 154.1 448 208 448H256V240H224C206.3 240 192 225.7 192 208C192 190.3 206.3 176 224 176H234.9C209 158.8 192 129.4 192 96C192 42.98 234.1 0 288 0C341 0 384 42.98 384 96C384 129.4 366.1 158.8 341.1 176H352zM288 128C305.7 128 320 113.7 320 96C320 78.33 305.7 64 288 64C270.3 64 256 78.33 256 96C256 113.7 270.3 128 288 128z\"\n ]\n};\nvar faAngleDown = {\n prefix: 'fas',\n iconName: 'angle-down',\n icon: [\n 384,\n 512,\n [\n 8964\n ],\n \"f107\",\n \"M192 384c-8.188 0-16.38-3.125-22.62-9.375l-160-160c-12.5-12.5-12.5-32.75 0-45.25s32.75-12.5 45.25 0L192 306.8l137.4-137.4c12.5-12.5 32.75-12.5 45.25 0s12.5 32.75 0 45.25l-160 160C208.4 380.9 200.2 384 192 384z\"\n ]\n};\nvar faAngleLeft = {\n prefix: 'fas',\n iconName: 'angle-left',\n icon: [\n 256,\n 512,\n [\n 8249\n ],\n \"f104\",\n \"M192 448c-8.188 0-16.38-3.125-22.62-9.375l-160-160c-12.5-12.5-12.5-32.75 0-45.25l160-160c12.5-12.5 32.75-12.5 45.25 0s12.5 32.75 0 45.25L77.25 256l137.4 137.4c12.5 12.5 12.5 32.75 0 45.25C208.4 444.9 200.2 448 192 448z\"\n ]\n};\nvar faAngleRight = {\n prefix: 'fas',\n iconName: 'angle-right',\n icon: [\n 256,\n 512,\n [\n 8250\n ],\n \"f105\",\n \"M64 448c-8.188 0-16.38-3.125-22.62-9.375c-12.5-12.5-12.5-32.75 0-45.25L178.8 256L41.38 118.6c-12.5-12.5-12.5-32.75 0-45.25s32.75-12.5 45.25 0l160 160c12.5 12.5 12.5 32.75 0 45.25l-160 160C80.38 444.9 72.19 448 64 448z\"\n ]\n};\nvar faAngleUp = {\n prefix: 'fas',\n iconName: 'angle-up',\n icon: [\n 384,\n 512,\n [\n 8963\n ],\n \"f106\",\n \"M352 352c-8.188 0-16.38-3.125-22.62-9.375L192 205.3l-137.4 137.4c-12.5 12.5-32.75 12.5-45.25 0s-12.5-32.75 0-45.25l160-160c12.5-12.5 32.75-12.5 45.25 0l160 160c12.5 12.5 12.5 32.75 0 45.25C368.4 348.9 360.2 352 352 352z\"\n ]\n};\nvar faAnglesDown = {\n prefix: 'fas',\n iconName: 'angles-down',\n icon: [\n 384,\n 512,\n [\n \"angle-double-down\"\n ],\n \"f103\",\n \"M169.4 278.6C175.6 284.9 183.8 288 192 288s16.38-3.125 22.62-9.375l160-160c12.5-12.5 12.5-32.75 0-45.25s-32.75-12.5-45.25 0L192 210.8L54.63 73.38c-12.5-12.5-32.75-12.5-45.25 0s-12.5 32.75 0 45.25L169.4 278.6zM329.4 265.4L192 402.8L54.63 265.4c-12.5-12.5-32.75-12.5-45.25 0s-12.5 32.75 0 45.25l160 160C175.6 476.9 183.8 480 192 480s16.38-3.125 22.62-9.375l160-160c12.5-12.5 12.5-32.75 0-45.25S341.9 252.9 329.4 265.4z\"\n ]\n};\nvar faAngleDoubleDown = faAnglesDown;\nvar faAnglesLeft = {\n prefix: 'fas',\n iconName: 'angles-left',\n icon: [\n 448,\n 512,\n [\n 171,\n \"angle-double-left\"\n ],\n \"f100\",\n \"M77.25 256l137.4-137.4c12.5-12.5 12.5-32.75 0-45.25s-32.75-12.5-45.25 0l-160 160c-12.5 12.5-12.5 32.75 0 45.25l160 160C175.6 444.9 183.8 448 192 448s16.38-3.125 22.62-9.375c12.5-12.5 12.5-32.75 0-45.25L77.25 256zM269.3 256l137.4-137.4c12.5-12.5 12.5-32.75 0-45.25s-32.75-12.5-45.25 0l-160 160c-12.5 12.5-12.5 32.75 0 45.25l160 160C367.6 444.9 375.8 448 384 448s16.38-3.125 22.62-9.375c12.5-12.5 12.5-32.75 0-45.25L269.3 256z\"\n ]\n};\nvar faAngleDoubleLeft = faAnglesLeft;\nvar faAnglesRight = {\n prefix: 'fas',\n iconName: 'angles-right',\n icon: [\n 448,\n 512,\n [\n 187,\n \"angle-double-right\"\n ],\n \"f101\",\n \"M246.6 233.4l-160-160c-12.5-12.5-32.75-12.5-45.25 0s-12.5 32.75 0 45.25L178.8 256l-137.4 137.4c-12.5 12.5-12.5 32.75 0 45.25C47.63 444.9 55.81 448 64 448s16.38-3.125 22.62-9.375l160-160C259.1 266.1 259.1 245.9 246.6 233.4zM438.6 233.4l-160-160c-12.5-12.5-32.75-12.5-45.25 0s-12.5 32.75 0 45.25L370.8 256l-137.4 137.4c-12.5 12.5-12.5 32.75 0 45.25C239.6 444.9 247.8 448 256 448s16.38-3.125 22.62-9.375l160-160C451.1 266.1 451.1 245.9 438.6 233.4z\"\n ]\n};\nvar faAngleDoubleRight = faAnglesRight;\nvar faAnglesUp = {\n prefix: 'fas',\n iconName: 'angles-up',\n icon: [\n 384,\n 512,\n [\n \"angle-double-up\"\n ],\n \"f102\",\n \"M54.63 246.6L192 109.3l137.4 137.4C335.6 252.9 343.8 256 352 256s16.38-3.125 22.62-9.375c12.5-12.5 12.5-32.75 0-45.25l-160-160c-12.5-12.5-32.75-12.5-45.25 0l-160 160c-12.5 12.5-12.5 32.75 0 45.25S42.13 259.1 54.63 246.6zM214.6 233.4c-12.5-12.5-32.75-12.5-45.25 0l-160 160c-12.5 12.5-12.5 32.75 0 45.25s32.75 12.5 45.25 0L192 301.3l137.4 137.4C335.6 444.9 343.8 448 352 448s16.38-3.125 22.62-9.375c12.5-12.5 12.5-32.75 0-45.25L214.6 233.4z\"\n ]\n};\nvar faAngleDoubleUp = faAnglesUp;\nvar faAnkh = {\n prefix: 'fas',\n iconName: 'ankh',\n icon: [\n 320,\n 512,\n [\n 9765\n ],\n \"f644\",\n \"M296 256h-44.63C272.5 222 288 181.6 288 144C288 55.62 230.8 0 160 0S32 55.62 32 144C32 181.6 47.5 222 68.63 256H24C10.75 256 0 266.8 0 280v32c0 13.25 10.75 24 24 24h96v152C120 501.2 130.8 512 144 512h32c13.25 0 24-10.75 24-24V336h96c13.25 0 24-10.75 24-24v-32C320 266.8 309.2 256 296 256zM160 80c29.62 0 48 24.5 48 64c0 34.62-27.12 78.12-48 100.9C139.1 222.1 112 178.6 112 144C112 104.5 130.4 80 160 80z\"\n ]\n};\nvar faAppleWhole = {\n prefix: 'fas',\n iconName: 'apple-whole',\n icon: [\n 448,\n 512,\n [\n 127823,\n 127822,\n \"apple-alt\"\n ],\n \"f5d1\",\n \"M336 128c-32 0-80.02 16.03-112 32.03c-32.01-16-79.1-32.02-111.1-32.03C32 128 .4134 210.5 .0033 288c-.5313 99.97 63.99 224 159.1 224c32 0 48-16 64-16c16 0 32 16 64 16c96 0 160.4-122.8 159.1-224C447.7 211.6 416 128 336 128zM320 32V0h-32C243.8 0 208 35.82 208 80v32h32C284.2 112 320 76.18 320 32z\"\n ]\n};\nvar faAppleAlt = faAppleWhole;\nvar faArchway = {\n prefix: 'fas',\n iconName: 'archway',\n icon: [\n 512,\n 512,\n [],\n \"f557\",\n \"M480 32C497.7 32 512 46.33 512 64C512 81.67 497.7 96 480 96H32C14.33 96 0 81.67 0 64C0 46.33 14.33 32 32 32H480zM32 128H480V416C497.7 416 512 430.3 512 448C512 465.7 497.7 480 480 480H352V352C352 298.1 309 256 256 256C202.1 256 160 298.1 160 352V480H32C14.33 480 0 465.7 0 448C0 430.3 14.33 416 32 416V128z\"\n ]\n};\nvar faArrowDown = {\n prefix: 'fas',\n iconName: 'arrow-down',\n icon: [\n 384,\n 512,\n [\n 8595\n ],\n \"f063\",\n \"M374.6 310.6l-160 160C208.4 476.9 200.2 480 192 480s-16.38-3.125-22.62-9.375l-160-160c-12.5-12.5-12.5-32.75 0-45.25s32.75-12.5 45.25 0L160 370.8V64c0-17.69 14.33-31.1 31.1-31.1S224 46.31 224 64v306.8l105.4-105.4c12.5-12.5 32.75-12.5 45.25 0S387.1 298.1 374.6 310.6z\"\n ]\n};\nvar faArrowDown19 = {\n prefix: 'fas',\n iconName: 'arrow-down-1-9',\n icon: [\n 512,\n 512,\n [\n \"sort-numeric-asc\",\n \"sort-numeric-down\"\n ],\n \"f162\",\n \"M320 192c0 17.69 14.31 31.1 32 31.1L416 224c17.69 0 32-14.31 32-32s-14.31-32-32-32V63.98c0-11.19-5.844-21.53-15.38-27.34c-9.531-5.781-21.41-6.188-31.34-1.062l-32 16.59c-15.69 8.125-21.81 27.44-13.69 43.13C329.3 106.3 340.4 112.6 352 112.6V160C334.3 160 320 174.3 320 192zM392 255.6c-48.6 0-88 39.4-88 88c0 36.44 22.15 67.7 53.71 81.07l-7.682 8.004c-10.72 11.16-10.34 28.88 .8125 39.56C356.3 477.4 363.3 480 370.2 480c7.344 0 14.72-2.875 20.19-8.625c69.61-72.53 89.6-85.39 89.6-127.8C480 294.1 440.6 255.6 392 255.6zM392 367.6c-13.23 0-24-10.77-24-24s10.77-24 24-24s24 10.77 24 24S405.2 367.6 392 367.6zM216 320.3c-8.672 0-17.3 3.5-23.61 10.38L160 366.1V64.03C160 46.33 145.7 32 128 32S96 46.33 96 64.03v302L63.6 330.7c-11.95-13.01-32.2-13.91-45.22-1.969c-13.03 11.95-13.9 32.22-1.969 45.27l87.1 96.09c12.12 13.26 35.06 13.26 47.19 0l87.1-96.09c11.94-13.05 11.06-33.31-1.969-45.27C231.5 323.1 223.7 320.3 216 320.3z\"\n ]\n};\nvar faSortNumericAsc = faArrowDown19;\nvar faSortNumericDown = faArrowDown19;\nvar faArrowDown91 = {\n prefix: 'fas',\n iconName: 'arrow-down-9-1',\n icon: [\n 512,\n 512,\n [\n \"sort-numeric-desc\",\n \"sort-numeric-down-alt\"\n ],\n \"f886\",\n \"M216 320.3c-8.672 0-17.3 3.5-23.61 10.38L160 366.1V64.03C160 46.33 145.7 32 128 32S96 46.33 96 64.03v302L63.6 330.7c-11.95-13.01-32.2-13.91-45.22-1.969c-13.03 11.95-13.9 32.22-1.969 45.27l87.1 96.09c12.12 13.26 35.06 13.26 47.19 0l87.1-96.09c11.94-13.05 11.06-33.31-1.969-45.27C231.5 323.1 223.7 320.3 216 320.3zM357.7 201.1l-7.682 8.004c-10.72 11.16-10.34 28.88 .8125 39.56c5.406 5.219 12.41 7.812 19.38 7.812c7.344 0 14.72-2.875 20.19-8.625c69.61-72.53 89.6-85.39 89.6-127.8c0-48.6-39.4-88-88-88s-88 39.4-88 88C303.1 156.4 326.1 187.7 357.7 201.1zM392 96c13.23 0 24 10.77 24 24S405.2 144 392 144S368 133.2 368 120S378.8 96 392 96zM416 416.4v-96.02c0-11.19-5.844-21.53-15.38-27.34c-9.531-5.781-21.41-6.188-31.34-1.062l-32 16.59c-15.69 8.125-21.81 27.44-13.69 43.13C329.3 362.8 340.4 369 352 369v47.41c-17.69 0-32 14.31-32 32s14.31 32 32 32h64c17.69 0 32-14.31 32-32S433.7 416.4 416 416.4z\"\n ]\n};\nvar faSortNumericDesc = faArrowDown91;\nvar faSortNumericDownAlt = faArrowDown91;\nvar faArrowDownAZ = {\n prefix: 'fas',\n iconName: 'arrow-down-a-z',\n icon: [\n 512,\n 512,\n [\n \"sort-alpha-asc\",\n \"sort-alpha-down\"\n ],\n \"f15d\",\n \"M239.6 373.1c11.94-13.05 11.06-33.31-1.969-45.27c-13.55-12.42-33.76-10.52-45.22 1.973L160 366.1V64.03c0-17.7-14.33-32.03-32-32.03S96 46.33 96 64.03v302l-32.4-35.39C51.64 317.7 31.39 316.7 18.38 328.7c-13.03 11.95-13.9 32.22-1.969 45.27l87.1 96.09c12.12 13.26 35.06 13.26 47.19 0L239.6 373.1zM448 416h-50.75l73.38-73.38c9.156-9.156 11.89-22.91 6.938-34.88S460.9 288 447.1 288H319.1C302.3 288 288 302.3 288 320s14.33 32 32 32h50.75l-73.38 73.38c-9.156 9.156-11.89 22.91-6.938 34.88S307.1 480 319.1 480h127.1C465.7 480 480 465.7 480 448S465.7 416 448 416zM492.6 209.3l-79.99-160.1c-10.84-21.81-46.4-21.81-57.24 0L275.4 209.3c-7.906 15.91-1.5 35.24 14.31 43.19c15.87 7.922 35.04 1.477 42.93-14.4l7.154-14.39h88.43l7.154 14.39c6.174 12.43 23.97 23.87 42.93 14.4C494.1 244.6 500.5 225.2 492.6 209.3zM367.8 167.4L384 134.7l16.22 32.63H367.8z\"\n ]\n};\nvar faSortAlphaAsc = faArrowDownAZ;\nvar faSortAlphaDown = faArrowDownAZ;\nvar faArrowDownLong = {\n prefix: 'fas',\n iconName: 'arrow-down-long',\n icon: [\n 320,\n 512,\n [\n \"long-arrow-down\"\n ],\n \"f175\",\n \"M9.375 329.4c12.51-12.51 32.76-12.49 45.25 0L128 402.8V32c0-17.69 14.31-32 32-32s32 14.31 32 32v370.8l73.38-73.38c12.5-12.5 32.75-12.5 45.25 0s12.5 32.75 0 45.25l-128 128c-12.5 12.5-32.75 12.5-45.25 0l-128-128C-3.125 362.1-3.125 341.9 9.375 329.4z\"\n ]\n};\nvar faLongArrowDown = faArrowDownLong;\nvar faArrowDownShortWide = {\n prefix: 'fas',\n iconName: 'arrow-down-short-wide',\n icon: [\n 576,\n 512,\n [\n \"sort-amount-desc\",\n \"sort-amount-down-alt\"\n ],\n \"f884\",\n \"M320 224H416c17.67 0 32-14.33 32-32s-14.33-32-32-32h-95.1c-17.67 0-32 14.33-32 32S302.3 224 320 224zM320 352H480c17.67 0 32-14.33 32-32s-14.33-32-32-32h-159.1c-17.67 0-32 14.33-32 32S302.3 352 320 352zM320 96h32c17.67 0 31.1-14.33 31.1-32s-14.33-32-31.1-32h-32c-17.67 0-32 14.33-32 32S302.3 96 320 96zM544 416h-223.1c-17.67 0-32 14.33-32 32s14.33 32 32 32H544c17.67 0 32-14.33 32-32S561.7 416 544 416zM192.4 330.7L160 366.1V64.03C160 46.33 145.7 32 128 32S96 46.33 96 64.03v302L63.6 330.7c-6.312-6.883-14.94-10.38-23.61-10.38c-7.719 0-15.47 2.781-21.61 8.414c-13.03 11.95-13.9 32.22-1.969 45.27l87.1 96.09c12.12 13.26 35.06 13.26 47.19 0l87.1-96.09c11.94-13.05 11.06-33.31-1.969-45.27C224.6 316.8 204.4 317.7 192.4 330.7z\"\n ]\n};\nvar faSortAmountDesc = faArrowDownShortWide;\nvar faSortAmountDownAlt = faArrowDownShortWide;\nvar faArrowDownWideShort = {\n prefix: 'fas',\n iconName: 'arrow-down-wide-short',\n icon: [\n 576,\n 512,\n [\n \"sort-amount-asc\",\n \"sort-amount-down\"\n ],\n \"f160\",\n \"M416 288h-95.1c-17.67 0-32 14.33-32 32s14.33 32 32 32H416c17.67 0 32-14.33 32-32S433.7 288 416 288zM544 32h-223.1c-17.67 0-32 14.33-32 32s14.33 32 32 32H544c17.67 0 32-14.33 32-32S561.7 32 544 32zM352 416h-32c-17.67 0-32 14.33-32 32s14.33 32 32 32h32c17.67 0 31.1-14.33 31.1-32S369.7 416 352 416zM480 160h-159.1c-17.67 0-32 14.33-32 32s14.33 32 32 32H480c17.67 0 32-14.33 32-32S497.7 160 480 160zM192.4 330.7L160 366.1V64.03C160 46.33 145.7 32 128 32S96 46.33 96 64.03v302L63.6 330.7c-6.312-6.883-14.94-10.38-23.61-10.38c-7.719 0-15.47 2.781-21.61 8.414c-13.03 11.95-13.9 32.22-1.969 45.27l87.1 96.09c12.12 13.26 35.06 13.26 47.19 0l87.1-96.09c11.94-13.05 11.06-33.31-1.969-45.27C224.6 316.8 204.4 317.7 192.4 330.7z\"\n ]\n};\nvar faSortAmountAsc = faArrowDownWideShort;\nvar faSortAmountDown = faArrowDownWideShort;\nvar faArrowDownZA = {\n prefix: 'fas',\n iconName: 'arrow-down-z-a',\n icon: [\n 512,\n 512,\n [\n \"sort-alpha-desc\",\n \"sort-alpha-down-alt\"\n ],\n \"f881\",\n \"M104.4 470.1c12.12 13.26 35.06 13.26 47.19 0l87.1-96.09c11.94-13.05 11.06-33.31-1.969-45.27c-13.02-11.95-33.27-11.04-45.22 1.973L160 366.1V64.03c0-17.7-14.33-32.03-32-32.03S96 46.33 96 64.03v302l-32.4-35.39c-6.312-6.883-14.94-10.39-23.61-10.39c-7.719 0-15.47 2.785-21.61 8.414c-13.03 11.95-13.9 32.22-1.969 45.27L104.4 470.1zM320 96h50.75l-73.38 73.38c-9.156 9.156-11.89 22.91-6.938 34.88s16.63 19.74 29.56 19.74h127.1C465.7 223.1 480 209.7 480 192s-14.33-32-32-32h-50.75l73.38-73.38c9.156-9.156 11.89-22.91 6.938-34.88S460.9 32 447.1 32h-127.1C302.3 32 288 46.31 288 64S302.3 96 320 96zM492.6 433.3l-79.99-160.1c-10.84-21.81-46.4-21.81-57.24 0l-79.99 160.1c-7.906 15.91-1.5 35.24 14.31 43.19c15.87 7.922 35.04 1.477 42.93-14.4l7.154-14.39h88.43l7.154 14.39c6.174 12.43 23.97 23.87 42.93 14.4C494.1 468.6 500.5 449.2 492.6 433.3zM367.8 391.4L384 358.7l16.22 32.63H367.8z\"\n ]\n};\nvar faSortAlphaDesc = faArrowDownZA;\nvar faSortAlphaDownAlt = faArrowDownZA;\nvar faArrowLeft = {\n prefix: 'fas',\n iconName: 'arrow-left',\n icon: [\n 448,\n 512,\n [\n 8592\n ],\n \"f060\",\n \"M447.1 256C447.1 273.7 433.7 288 416 288H109.3l105.4 105.4c12.5 12.5 12.5 32.75 0 45.25C208.4 444.9 200.2 448 192 448s-16.38-3.125-22.62-9.375l-160-160c-12.5-12.5-12.5-32.75 0-45.25l160-160c12.5-12.5 32.75-12.5 45.25 0s12.5 32.75 0 45.25L109.3 224H416C433.7 224 447.1 238.3 447.1 256z\"\n ]\n};\nvar faArrowLeftLong = {\n prefix: 'fas',\n iconName: 'arrow-left-long',\n icon: [\n 512,\n 512,\n [\n \"long-arrow-left\"\n ],\n \"f177\",\n \"M9.375 233.4l128-128c12.5-12.5 32.75-12.5 45.25 0s12.5 32.75 0 45.25L109.3 224H480c17.69 0 32 14.31 32 32s-14.31 32-32 32H109.3l73.38 73.38c12.5 12.5 12.5 32.75 0 45.25c-12.49 12.49-32.74 12.51-45.25 0l-128-128C-3.125 266.1-3.125 245.9 9.375 233.4z\"\n ]\n};\nvar faLongArrowLeft = faArrowLeftLong;\nvar faArrowPointer = {\n prefix: 'fas',\n iconName: 'arrow-pointer',\n icon: [\n 320,\n 512,\n [\n \"mouse-pointer\"\n ],\n \"f245\",\n \"M318.4 304.5c-3.531 9.344-12.47 15.52-22.45 15.52h-105l45.15 94.82c9.496 19.94 1.031 43.8-18.91 53.31c-19.95 9.504-43.82 1.035-53.32-18.91L117.3 351.3l-75 88.25c-4.641 5.469-11.37 8.453-18.28 8.453c-2.781 0-5.578-.4844-8.281-1.469C6.281 443.1 0 434.1 0 423.1V56.02c0-9.438 5.531-18.03 14.12-21.91C22.75 30.26 32.83 31.77 39.87 37.99l271.1 240C319.4 284.6 321.1 295.1 318.4 304.5z\"\n ]\n};\nvar faMousePointer = faArrowPointer;\nvar faArrowRight = {\n prefix: 'fas',\n iconName: 'arrow-right',\n icon: [\n 448,\n 512,\n [\n 8594\n ],\n \"f061\",\n \"M438.6 278.6l-160 160C272.4 444.9 264.2 448 256 448s-16.38-3.125-22.62-9.375c-12.5-12.5-12.5-32.75 0-45.25L338.8 288H32C14.33 288 .0016 273.7 .0016 256S14.33 224 32 224h306.8l-105.4-105.4c-12.5-12.5-12.5-32.75 0-45.25s32.75-12.5 45.25 0l160 160C451.1 245.9 451.1 266.1 438.6 278.6z\"\n ]\n};\nvar faArrowRightArrowLeft = {\n prefix: 'fas',\n iconName: 'arrow-right-arrow-left',\n icon: [\n 512,\n 512,\n [\n 8644,\n \"exchange\"\n ],\n \"f0ec\",\n \"M32 176h370.8l-57.38 57.38c-12.5 12.5-12.5 32.75 0 45.25C351.6 284.9 359.8 288 368 288s16.38-3.125 22.62-9.375l112-112c12.5-12.5 12.5-32.75 0-45.25l-112-112c-12.5-12.5-32.75-12.5-45.25 0s-12.5 32.75 0 45.25L402.8 112H32c-17.69 0-32 14.31-32 32S14.31 176 32 176zM480 336H109.3l57.38-57.38c12.5-12.5 12.5-32.75 0-45.25s-32.75-12.5-45.25 0l-112 112c-12.5 12.5-12.5 32.75 0 45.25l112 112C127.6 508.9 135.8 512 144 512s16.38-3.125 22.62-9.375c12.5-12.5 12.5-32.75 0-45.25L109.3 400H480c17.69 0 32-14.31 32-32S497.7 336 480 336z\"\n ]\n};\nvar faExchange = faArrowRightArrowLeft;\nvar faArrowRightFromBracket = {\n prefix: 'fas',\n iconName: 'arrow-right-from-bracket',\n icon: [\n 512,\n 512,\n [\n \"sign-out\"\n ],\n \"f08b\",\n \"M160 416H96c-17.67 0-32-14.33-32-32V128c0-17.67 14.33-32 32-32h64c17.67 0 32-14.33 32-32S177.7 32 160 32H96C42.98 32 0 74.98 0 128v256c0 53.02 42.98 96 96 96h64c17.67 0 32-14.33 32-32S177.7 416 160 416zM502.6 233.4l-128-128c-12.51-12.51-32.76-12.49-45.25 0c-12.5 12.5-12.5 32.75 0 45.25L402.8 224H192C174.3 224 160 238.3 160 256s14.31 32 32 32h210.8l-73.38 73.38c-12.5 12.5-12.5 32.75 0 45.25s32.75 12.5 45.25 0l128-128C515.1 266.1 515.1 245.9 502.6 233.4z\"\n ]\n};\nvar faSignOut = faArrowRightFromBracket;\nvar faArrowRightLong = {\n prefix: 'fas',\n iconName: 'arrow-right-long',\n icon: [\n 512,\n 512,\n [\n \"long-arrow-right\"\n ],\n \"f178\",\n \"M502.6 278.6l-128 128c-12.51 12.51-32.76 12.49-45.25 0c-12.5-12.5-12.5-32.75 0-45.25L402.8 288H32C14.31 288 0 273.7 0 255.1S14.31 224 32 224h370.8l-73.38-73.38c-12.5-12.5-12.5-32.75 0-45.25s32.75-12.5 45.25 0l128 128C515.1 245.9 515.1 266.1 502.6 278.6z\"\n ]\n};\nvar faLongArrowRight = faArrowRightLong;\nvar faArrowRightToBracket = {\n prefix: 'fas',\n iconName: 'arrow-right-to-bracket',\n icon: [\n 512,\n 512,\n [\n \"sign-in\"\n ],\n \"f090\",\n \"M416 32h-64c-17.67 0-32 14.33-32 32s14.33 32 32 32h64c17.67 0 32 14.33 32 32v256c0 17.67-14.33 32-32 32h-64c-17.67 0-32 14.33-32 32s14.33 32 32 32h64c53.02 0 96-42.98 96-96V128C512 74.98 469 32 416 32zM342.6 233.4l-128-128c-12.51-12.51-32.76-12.49-45.25 0c-12.5 12.5-12.5 32.75 0 45.25L242.8 224H32C14.31 224 0 238.3 0 256s14.31 32 32 32h210.8l-73.38 73.38c-12.5 12.5-12.5 32.75 0 45.25s32.75 12.5 45.25 0l128-128C355.1 266.1 355.1 245.9 342.6 233.4z\"\n ]\n};\nvar faSignIn = faArrowRightToBracket;\nvar faArrowRotateLeft = {\n prefix: 'fas',\n iconName: 'arrow-rotate-left',\n icon: [\n 512,\n 512,\n [\n 8634,\n \"arrow-left-rotate\",\n \"arrow-rotate-back\",\n \"arrow-rotate-backward\",\n \"undo\"\n ],\n \"f0e2\",\n \"M480 256c0 123.4-100.5 223.9-223.9 223.9c-48.86 0-95.19-15.58-134.2-44.86c-14.14-10.59-17-30.66-6.391-44.81c10.61-14.09 30.69-16.97 44.8-6.375c27.84 20.91 61 31.94 95.89 31.94C344.3 415.8 416 344.1 416 256s-71.67-159.8-159.8-159.8C205.9 96.22 158.6 120.3 128.6 160H192c17.67 0 32 14.31 32 32S209.7 224 192 224H48c-17.67 0-32-14.31-32-32V48c0-17.69 14.33-32 32-32s32 14.31 32 32v70.23C122.1 64.58 186.1 32.11 256.1 32.11C379.5 32.11 480 132.6 480 256z\"\n ]\n};\nvar faArrowLeftRotate = faArrowRotateLeft;\nvar faArrowRotateBack = faArrowRotateLeft;\nvar faArrowRotateBackward = faArrowRotateLeft;\nvar faUndo = faArrowRotateLeft;\nvar faArrowRotateRight = {\n prefix: 'fas',\n iconName: 'arrow-rotate-right',\n icon: [\n 512,\n 512,\n [\n 8635,\n \"arrow-right-rotate\",\n \"arrow-rotate-forward\",\n \"redo\"\n ],\n \"f01e\",\n \"M496 48V192c0 17.69-14.31 32-32 32H320c-17.69 0-32-14.31-32-32s14.31-32 32-32h63.39c-29.97-39.7-77.25-63.78-127.6-63.78C167.7 96.22 96 167.9 96 256s71.69 159.8 159.8 159.8c34.88 0 68.03-11.03 95.88-31.94c14.22-10.53 34.22-7.75 44.81 6.375c10.59 14.16 7.75 34.22-6.375 44.81c-39.03 29.28-85.36 44.86-134.2 44.86C132.5 479.9 32 379.4 32 256s100.5-223.9 223.9-223.9c69.15 0 134 32.47 176.1 86.12V48c0-17.69 14.31-32 32-32S496 30.31 496 48z\"\n ]\n};\nvar faArrowRightRotate = faArrowRotateRight;\nvar faArrowRotateForward = faArrowRotateRight;\nvar faRedo = faArrowRotateRight;\nvar faArrowTrendDown = {\n prefix: 'fas',\n iconName: 'arrow-trend-down',\n icon: [\n 576,\n 512,\n [],\n \"e097\",\n \"M466.7 352L320 205.3L214.6 310.6C202.1 323.1 181.9 323.1 169.4 310.6L9.372 150.6C-3.124 138.1-3.124 117.9 9.372 105.4C21.87 92.88 42.13 92.88 54.63 105.4L191.1 242.7L297.4 137.4C309.9 124.9 330.1 124.9 342.6 137.4L512 306.7V223.1C512 206.3 526.3 191.1 544 191.1C561.7 191.1 576 206.3 576 223.1V384C576 401.7 561.7 416 544 416H384C366.3 416 352 401.7 352 384C352 366.3 366.3 352 384 352L466.7 352z\"\n ]\n};\nvar faArrowTrendUp = {\n prefix: 'fas',\n iconName: 'arrow-trend-up',\n icon: [\n 576,\n 512,\n [],\n \"e098\",\n \"M384 160C366.3 160 352 145.7 352 128C352 110.3 366.3 96 384 96H544C561.7 96 576 110.3 576 128V288C576 305.7 561.7 320 544 320C526.3 320 512 305.7 512 288V205.3L342.6 374.6C330.1 387.1 309.9 387.1 297.4 374.6L191.1 269.3L54.63 406.6C42.13 419.1 21.87 419.1 9.372 406.6C-3.124 394.1-3.124 373.9 9.372 361.4L169.4 201.4C181.9 188.9 202.1 188.9 214.6 201.4L320 306.7L466.7 159.1L384 160z\"\n ]\n};\nvar faArrowTurnDown = {\n prefix: 'fas',\n iconName: 'arrow-turn-down',\n icon: [\n 384,\n 512,\n [\n \"level-down\"\n ],\n \"f149\",\n \"M342.6 374.6l-128 128C208.4 508.9 200.2 512 191.1 512s-16.38-3.125-22.63-9.375l-127.1-128c-12.5-12.5-12.5-32.75 0-45.25s32.75-12.5 45.25 0L160 402.8V80C160 71.19 152.8 64 144 64H32C14.33 64 0 49.69 0 32s14.33-32 32-32h112C188.1 0 224 35.88 224 80v322.8l73.37-73.38c12.5-12.5 32.75-12.5 45.25 0S355.1 362.1 342.6 374.6z\"\n ]\n};\nvar faLevelDown = faArrowTurnDown;\nvar faArrowTurnUp = {\n prefix: 'fas',\n iconName: 'arrow-turn-up',\n icon: [\n 384,\n 512,\n [\n \"level-up\"\n ],\n \"f148\",\n \"M342.6 182.6C336.4 188.9 328.2 192 319.1 192s-16.38-3.125-22.62-9.375L224 109.3V432c0 44.13-35.89 80-80 80H32c-17.67 0-32-14.31-32-32s14.33-32 32-32h112C152.8 448 160 440.8 160 432V109.3L86.62 182.6c-12.5 12.5-32.75 12.5-45.25 0s-12.5-32.75 0-45.25l127.1-128c12.5-12.5 32.75-12.5 45.25 0l128 128C355.1 149.9 355.1 170.1 342.6 182.6z\"\n ]\n};\nvar faLevelUp = faArrowTurnUp;\nvar faArrowUp = {\n prefix: 'fas',\n iconName: 'arrow-up',\n icon: [\n 384,\n 512,\n [\n 8593\n ],\n \"f062\",\n \"M374.6 246.6C368.4 252.9 360.2 256 352 256s-16.38-3.125-22.62-9.375L224 141.3V448c0 17.69-14.33 31.1-31.1 31.1S160 465.7 160 448V141.3L54.63 246.6c-12.5 12.5-32.75 12.5-45.25 0s-12.5-32.75 0-45.25l160-160c12.5-12.5 32.75-12.5 45.25 0l160 160C387.1 213.9 387.1 234.1 374.6 246.6z\"\n ]\n};\nvar faArrowUp19 = {\n prefix: 'fas',\n iconName: 'arrow-up-1-9',\n icon: [\n 512,\n 512,\n [\n \"sort-numeric-up\"\n ],\n \"f163\",\n \"M320 192c0 17.69 14.31 31.1 32 31.1L416 224c17.69 0 32-14.31 32-32s-14.31-32-32-32V63.98c0-11.19-5.844-21.53-15.38-27.34c-9.531-5.781-21.41-6.188-31.34-1.062l-32 16.59c-15.69 8.125-21.81 27.44-13.69 43.13C329.3 106.3 340.4 112.6 352 112.6V160C334.3 160 320 174.3 320 192zM392 255.6c-48.6 0-88 39.4-88 88c0 36.44 22.15 67.7 53.71 81.07l-7.682 8.004c-10.72 11.16-10.34 28.88 .8125 39.56C356.3 477.4 363.3 480 370.2 480c7.344 0 14.72-2.875 20.19-8.625c69.61-72.53 89.6-85.39 89.6-127.8C480 294.1 440.6 255.6 392 255.6zM392 367.6c-13.23 0-24-10.77-24-24s10.77-24 24-24s24 10.77 24 24S405.2 367.6 392 367.6zM39.99 191.7c8.672 0 17.3-3.5 23.61-10.38L96 145.9v302c0 17.7 14.33 32.03 31.1 32.03s32-14.33 32-32.03V145.9L192.4 181.3C204.4 194.3 224.6 195.2 237.6 183.3c13.03-11.95 13.9-32.22 1.969-45.27L151.6 41.94c-12.12-13.26-35.06-13.26-47.19 0l-87.1 96.09C4.475 151.1 5.35 171.3 18.38 183.3C24.52 188.9 32.27 191.7 39.99 191.7z\"\n ]\n};\nvar faSortNumericUp = faArrowUp19;\nvar faArrowUp91 = {\n prefix: 'fas',\n iconName: 'arrow-up-9-1',\n icon: [\n 512,\n 512,\n [\n \"sort-numeric-up-alt\"\n ],\n \"f887\",\n \"M237.6 183.3c13.03-11.95 13.9-32.22 1.969-45.27L151.6 41.94c-12.12-13.26-35.06-13.26-47.19 0l-87.1 96.09C4.475 151.1 5.35 171.3 18.38 183.3c13.02 11.95 33.27 11.04 45.22-1.969L96 145.9v302c0 17.7 14.33 32.03 31.1 32.03s32-14.33 32-32.03V145.9L192.4 181.3c6.312 6.883 14.94 10.38 23.61 10.38C223.7 191.7 231.5 188.9 237.6 183.3zM357.7 201.1l-7.682 8.004c-10.72 11.16-10.34 28.88 .8125 39.56c5.406 5.219 12.41 7.812 19.38 7.812c7.344 0 14.72-2.875 20.19-8.625c69.61-72.53 89.6-85.39 89.6-127.8c0-48.6-39.4-88-88-88s-88 39.4-88 88C303.1 156.4 326.1 187.7 357.7 201.1zM392 96c13.23 0 24 10.77 24 24S405.2 144 392 144S368 133.2 368 120S378.8 96 392 96zM416 416.4v-96.02c0-11.19-5.844-21.53-15.38-27.34c-9.531-5.781-21.41-6.188-31.34-1.062l-32 16.59c-15.69 8.125-21.81 27.44-13.69 43.13C329.3 362.8 340.4 369 352 369v47.41c-17.69 0-32 14.31-32 32s14.31 32 32 32h64c17.69 0 32-14.31 32-32S433.7 416.4 416 416.4z\"\n ]\n};\nvar faSortNumericUpAlt = faArrowUp91;\nvar faArrowUpAZ = {\n prefix: 'fas',\n iconName: 'arrow-up-a-z',\n icon: [\n 512,\n 512,\n [\n \"sort-alpha-up\"\n ],\n \"f15e\",\n \"M151.6 41.95c-12.12-13.26-35.06-13.26-47.19 0l-87.1 96.09C4.473 151.1 5.348 171.4 18.38 183.3c13.02 11.95 33.27 11.04 45.22-1.973L96 145.9v302C96 465.7 110.3 480 128 480S160 465.7 160 447.1V145.9L192.4 181.3c11.46 12.49 31.67 14.39 45.22 1.973c13.03-11.95 13.9-32.22 1.969-45.27L151.6 41.95zM448 416h-50.75l73.38-73.38c9.156-9.156 11.89-22.91 6.938-34.88s-16.63-19.86-29.56-19.86H319.1C302.3 287.9 288 302.3 288 320s14.33 32 32 32h50.75l-73.38 73.38c-9.156 9.156-11.89 22.91-6.938 34.88S307.1 480 319.1 480h127.1C465.7 480 480 465.7 480 448S465.7 416 448 416zM492.6 209.3l-79.99-160.1c-10.84-21.81-46.4-21.81-57.24 0L275.4 209.3c-7.906 15.91-1.5 35.24 14.31 43.19c15.87 7.922 35.04 1.477 42.93-14.4l7.154-14.39h88.43l7.154 14.39c6.174 12.43 23.97 23.87 42.93 14.4C494.1 244.6 500.5 225.2 492.6 209.3zM367.8 167.4L384 134.7l16.22 32.63H367.8z\"\n ]\n};\nvar faSortAlphaUp = faArrowUpAZ;\nvar faArrowUpFromBracket = {\n prefix: 'fas',\n iconName: 'arrow-up-from-bracket',\n icon: [\n 448,\n 512,\n [],\n \"e09a\",\n \"M384 352v64c0 17.67-14.33 32-32 32H96c-17.67 0-32-14.33-32-32v-64c0-17.67-14.33-32-32-32s-32 14.33-32 32v64c0 53.02 42.98 96 96 96h256c53.02 0 96-42.98 96-96v-64c0-17.67-14.33-32-32-32S384 334.3 384 352zM201.4 9.375l-128 128c-12.51 12.51-12.49 32.76 0 45.25c12.5 12.5 32.75 12.5 45.25 0L192 109.3V320c0 17.69 14.31 32 32 32s32-14.31 32-32V109.3l73.38 73.38c12.5 12.5 32.75 12.5 45.25 0s12.5-32.75 0-45.25l-128-128C234.1-3.125 213.9-3.125 201.4 9.375z\"\n ]\n};\nvar faArrowUpLong = {\n prefix: 'fas',\n iconName: 'arrow-up-long',\n icon: [\n 320,\n 512,\n [\n \"long-arrow-up\"\n ],\n \"f176\",\n \"M310.6 182.6c-12.51 12.51-32.76 12.49-45.25 0L192 109.3V480c0 17.69-14.31 32-32 32s-32-14.31-32-32V109.3L54.63 182.6c-12.5 12.5-32.75 12.5-45.25 0s-12.5-32.75 0-45.25l128-128c12.5-12.5 32.75-12.5 45.25 0l128 128C323.1 149.9 323.1 170.1 310.6 182.6z\"\n ]\n};\nvar faLongArrowUp = faArrowUpLong;\nvar faArrowUpRightFromSquare = {\n prefix: 'fas',\n iconName: 'arrow-up-right-from-square',\n icon: [\n 512,\n 512,\n [\n \"external-link\"\n ],\n \"f08e\",\n \"M384 320c-17.67 0-32 14.33-32 32v96H64V160h96c17.67 0 32-14.32 32-32s-14.33-32-32-32L64 96c-35.35 0-64 28.65-64 64V448c0 35.34 28.65 64 64 64h288c35.35 0 64-28.66 64-64v-96C416 334.3 401.7 320 384 320zM502.6 9.367C496.8 3.578 488.8 0 480 0h-160c-17.67 0-31.1 14.32-31.1 31.1c0 17.67 14.32 31.1 31.99 31.1h82.75L178.7 290.7c-12.5 12.5-12.5 32.76 0 45.26C191.2 348.5 211.5 348.5 224 336l224-226.8V192c0 17.67 14.33 31.1 31.1 31.1S512 209.7 512 192V31.1C512 23.16 508.4 15.16 502.6 9.367z\"\n ]\n};\nvar faExternalLink = faArrowUpRightFromSquare;\nvar faArrowUpShortWide = {\n prefix: 'fas',\n iconName: 'arrow-up-short-wide',\n icon: [\n 576,\n 512,\n [\n \"sort-amount-up-alt\"\n ],\n \"f885\",\n \"M544 416h-223.1c-17.67 0-32 14.33-32 32s14.33 32 32 32H544c17.67 0 32-14.33 32-32S561.7 416 544 416zM320 96h32c17.67 0 31.1-14.33 31.1-32s-14.33-32-31.1-32h-32c-17.67 0-32 14.33-32 32S302.3 96 320 96zM320 224H416c17.67 0 32-14.33 32-32s-14.33-32-32-32h-95.1c-17.67 0-32 14.33-32 32S302.3 224 320 224zM320 352H480c17.67 0 32-14.33 32-32s-14.33-32-32-32h-159.1c-17.67 0-32 14.33-32 32S302.3 352 320 352zM151.6 41.95c-12.12-13.26-35.06-13.26-47.19 0l-87.1 96.09C4.475 151.1 5.35 171.4 18.38 183.3c6.141 5.629 13.89 8.414 21.61 8.414c8.672 0 17.3-3.504 23.61-10.39L96 145.9v302C96 465.7 110.3 480 128 480s32-14.33 32-32.03V145.9L192.4 181.3C204.4 194.3 224.6 195.3 237.6 183.3c13.03-11.95 13.9-32.22 1.969-45.27L151.6 41.95z\"\n ]\n};\nvar faSortAmountUpAlt = faArrowUpShortWide;\nvar faArrowUpWideShort = {\n prefix: 'fas',\n iconName: 'arrow-up-wide-short',\n icon: [\n 576,\n 512,\n [\n \"sort-amount-up\"\n ],\n \"f161\",\n \"M416 288h-95.1c-17.67 0-32 14.33-32 32s14.33 32 32 32H416c17.67 0 32-14.33 32-32S433.7 288 416 288zM352 416h-32c-17.67 0-32 14.33-32 32s14.33 32 32 32h32c17.67 0 31.1-14.33 31.1-32S369.7 416 352 416zM480 160h-159.1c-17.67 0-32 14.33-32 32s14.33 32 32 32H480c17.67 0 32-14.33 32-32S497.7 160 480 160zM544 32h-223.1c-17.67 0-32 14.33-32 32s14.33 32 32 32H544c17.67 0 32-14.33 32-32S561.7 32 544 32zM151.6 41.95c-12.12-13.26-35.06-13.26-47.19 0l-87.1 96.09C4.475 151.1 5.35 171.4 18.38 183.3c6.141 5.629 13.89 8.414 21.61 8.414c8.672 0 17.3-3.504 23.61-10.39L96 145.9v302C96 465.7 110.3 480 128 480s32-14.33 32-32.03V145.9L192.4 181.3C204.4 194.3 224.6 195.3 237.6 183.3c13.03-11.95 13.9-32.22 1.969-45.27L151.6 41.95z\"\n ]\n};\nvar faSortAmountUp = faArrowUpWideShort;\nvar faArrowUpZA = {\n prefix: 'fas',\n iconName: 'arrow-up-z-a',\n icon: [\n 512,\n 512,\n [\n \"sort-alpha-up-alt\"\n ],\n \"f882\",\n \"M151.6 41.95c-12.12-13.26-35.06-13.26-47.19 0l-87.1 96.09C4.473 151.1 5.348 171.4 18.38 183.3c13.02 11.95 33.27 11.04 45.22-1.973L96 145.9v302C96 465.7 110.3 480 128 480S160 465.7 160 447.1V145.9L192.4 181.3c6.312 6.883 14.94 10.39 23.61 10.39c7.719 0 15.47-2.785 21.61-8.414c13.03-11.95 13.9-32.22 1.969-45.27L151.6 41.95zM320 96h50.75l-73.38 73.38c-9.156 9.156-11.89 22.91-6.938 34.88s16.63 19.74 29.56 19.74h127.1C465.7 223.1 480 209.7 480 192s-14.33-32-32-32h-50.75l73.38-73.38c9.156-9.156 11.89-22.91 6.938-34.88S460.9 32 447.1 32h-127.1C302.3 32 288 46.31 288 64S302.3 96 320 96zM492.6 433.3l-79.99-160.1c-10.84-21.81-46.4-21.81-57.24 0l-79.99 160.1c-7.906 15.91-1.5 35.24 14.31 43.19c15.87 7.922 35.04 1.477 42.93-14.4l7.154-14.39h88.43l7.154 14.39c6.174 12.43 23.97 23.87 42.93 14.4C494.1 468.6 500.5 449.2 492.6 433.3zM367.8 391.4L384 358.7l16.22 32.63H367.8z\"\n ]\n};\nvar faSortAlphaUpAlt = faArrowUpZA;\nvar faArrowsLeftRight = {\n prefix: 'fas',\n iconName: 'arrows-left-right',\n icon: [\n 512,\n 512,\n [\n \"arrows-h\"\n ],\n \"f07e\",\n \"M502.6 278.6l-96 96C400.4 380.9 392.2 384 384 384s-16.38-3.125-22.62-9.375c-12.5-12.5-12.5-32.75 0-45.25L402.8 288h-293.5l41.38 41.38c12.5 12.5 12.5 32.75 0 45.25C144.4 380.9 136.2 384 128 384s-16.38-3.125-22.62-9.375l-96-96c-12.5-12.5-12.5-32.75 0-45.25l96-96c12.5-12.5 32.75-12.5 45.25 0s12.5 32.75 0 45.25L109.3 224h293.5l-41.38-41.38c-12.5-12.5-12.5-32.75 0-45.25s32.75-12.5 45.25 0l96 96C515.1 245.9 515.1 266.1 502.6 278.6z\"\n ]\n};\nvar faArrowsH = faArrowsLeftRight;\nvar faArrowsRotate = {\n prefix: 'fas',\n iconName: 'arrows-rotate',\n icon: [\n 512,\n 512,\n [\n 128472,\n \"refresh\",\n \"sync\"\n ],\n \"f021\",\n \"M464 16c-17.67 0-32 14.31-32 32v74.09C392.1 66.52 327.4 32 256 32C161.5 32 78.59 92.34 49.58 182.2c-5.438 16.81 3.797 34.88 20.61 40.28c16.89 5.5 34.88-3.812 40.3-20.59C130.9 138.5 189.4 96 256 96c50.5 0 96.26 24.55 124.4 64H336c-17.67 0-32 14.31-32 32s14.33 32 32 32h128c17.67 0 32-14.31 32-32V48C496 30.31 481.7 16 464 16zM441.8 289.6c-16.92-5.438-34.88 3.812-40.3 20.59C381.1 373.5 322.6 416 256 416c-50.5 0-96.25-24.55-124.4-64H176c17.67 0 32-14.31 32-32s-14.33-32-32-32h-128c-17.67 0-32 14.31-32 32v144c0 17.69 14.33 32 32 32s32-14.31 32-32v-74.09C119.9 445.5 184.6 480 255.1 480c94.45 0 177.4-60.34 206.4-150.2C467.9 313 458.6 294.1 441.8 289.6z\"\n ]\n};\nvar faRefresh = faArrowsRotate;\nvar faSync = faArrowsRotate;\nvar faArrowsUpDown = {\n prefix: 'fas',\n iconName: 'arrows-up-down',\n icon: [\n 256,\n 512,\n [\n \"arrows-v\"\n ],\n \"f07d\",\n \"M246.6 361.4C252.9 367.6 256 375.8 256 384s-3.125 16.38-9.375 22.62l-96 96c-12.5 12.5-32.75 12.5-45.25 0l-96-96c-12.5-12.5-12.5-32.75 0-45.25s32.75-12.5 45.25 0L96 402.8v-293.5L54.63 150.6c-12.5 12.5-32.75 12.5-45.25 0s-12.5-32.75 0-45.25l96-96c12.5-12.5 32.75-12.5 45.25 0l96 96C252.9 111.6 256 119.8 256 128s-3.125 16.38-9.375 22.62c-12.5 12.5-32.75 12.5-45.25 0L160 109.3v293.5l41.38-41.38C213.9 348.9 234.1 348.9 246.6 361.4z\"\n ]\n};\nvar faArrowsV = faArrowsUpDown;\nvar faArrowsUpDownLeftRight = {\n prefix: 'fas',\n iconName: 'arrows-up-down-left-right',\n icon: [\n 512,\n 512,\n [\n \"arrows\"\n ],\n \"f047\",\n \"M512 255.1c0 8.188-3.125 16.41-9.375 22.66l-72 72C424.4 356.9 416.2 360 408 360c-18.28 0-32-14.95-32-32c0-8.188 3.125-16.38 9.375-22.62L402.8 288H288v114.8l17.38-17.38C311.6 379.1 319.8 376 328 376c18.28 0 32 14.95 32 32c0 8.188-3.125 16.38-9.375 22.62l-72 72C272.4 508.9 264.2 512 256 512s-16.38-3.125-22.62-9.375l-72-72C155.1 424.4 152 416.2 152 408c0-17.05 13.73-32 32-32c8.188 0 16.38 3.125 22.62 9.375L224 402.8V288H109.3l17.38 17.38C132.9 311.6 136 319.8 136 328c0 17.05-13.73 32-32 32c-8.188 0-16.38-3.125-22.62-9.375l-72-72C3.125 272.4 0 264.2 0 255.1s3.125-16.34 9.375-22.59l72-72C87.63 155.1 95.81 152 104 152c18.28 0 32 14.95 32 32c0 8.188-3.125 16.38-9.375 22.62L109.3 224H224V109.3L206.6 126.6C200.4 132.9 192.2 136 184 136c-18.28 0-32-14.95-32-32c0-8.188 3.125-16.38 9.375-22.62l72-72C239.6 3.125 247.8 0 256 0s16.38 3.125 22.62 9.375l72 72C356.9 87.63 360 95.81 360 104c0 17.05-13.73 32-32 32c-8.188 0-16.38-3.125-22.62-9.375L288 109.3V224h114.8l-17.38-17.38C379.1 200.4 376 192.2 376 184c0-17.05 13.73-32 32-32c8.188 0 16.38 3.125 22.62 9.375l72 72C508.9 239.6 512 247.8 512 255.1z\"\n ]\n};\nvar faArrows = faArrowsUpDownLeftRight;\nvar faAsterisk = {\n prefix: 'fas',\n iconName: 'asterisk',\n icon: [\n 448,\n 512,\n [\n 10033,\n 61545\n ],\n \"2a\",\n \"M417.1 368c-5.937 10.27-16.69 16-27.75 16c-5.422 0-10.92-1.375-15.97-4.281L256 311.4V448c0 17.67-14.33 32-31.1 32S192 465.7 192 448V311.4l-118.3 68.29C68.67 382.6 63.17 384 57.75 384c-11.06 0-21.81-5.734-27.75-16c-8.828-15.31-3.594-34.88 11.72-43.72L159.1 256L41.72 187.7C26.41 178.9 21.17 159.3 29.1 144C36.63 132.5 49.26 126.7 61.65 128.2C65.78 128.7 69.88 130.1 73.72 132.3L192 200.6V64c0-17.67 14.33-32 32-32S256 46.33 256 64v136.6l118.3-68.29c3.838-2.213 7.939-3.539 12.07-4.051C398.7 126.7 411.4 132.5 417.1 144c8.828 15.31 3.594 34.88-11.72 43.72L288 256l118.3 68.28C421.6 333.1 426.8 352.7 417.1 368z\"\n ]\n};\nvar faAt = {\n prefix: 'fas',\n iconName: 'at',\n icon: [\n 512,\n 512,\n [\n 129664,\n 61946\n ],\n \"40\",\n \"M207.8 20.73c-93.45 18.32-168.7 93.66-187 187.1c-27.64 140.9 68.65 266.2 199.1 285.1c19.01 2.888 36.17-12.26 36.17-31.49l.0001-.6631c0-15.74-11.44-28.88-26.84-31.24c-84.35-12.98-149.2-86.13-149.2-174.2c0-102.9 88.61-185.5 193.4-175.4c91.54 8.869 158.6 91.25 158.6 183.2l0 16.16c0 22.09-17.94 40.05-40 40.05s-40.01-17.96-40.01-40.05v-120.1c0-8.847-7.161-16.02-16.01-16.02l-31.98 .0036c-7.299 0-13.2 4.992-15.12 11.68c-24.85-12.15-54.24-16.38-86.06-5.106c-38.75 13.73-68.12 48.91-73.72 89.64c-9.483 69.01 43.81 128 110.9 128c26.44 0 50.43-9.544 69.59-24.88c24 31.3 65.23 48.69 109.4 37.49C465.2 369.3 496 324.1 495.1 277.2V256.3C495.1 107.1 361.2-9.332 207.8 20.73zM239.1 304.3c-26.47 0-48-21.56-48-48.05s21.53-48.05 48-48.05s48 21.56 48 48.05S266.5 304.3 239.1 304.3z\"\n ]\n};\nvar faAtom = {\n prefix: 'fas',\n iconName: 'atom',\n icon: [\n 512,\n 512,\n [\n 9883\n ],\n \"f5d2\",\n \"M256 224C238.4 224 223.1 238.4 223.1 256S238.4 288 256 288c17.63 0 32-14.38 32-32S273.6 224 256 224zM470.2 128c-10.88-19.5-40.51-50.75-116.3-41.88C332.4 34.88 299.6 0 256 0S179.6 34.88 158.1 86.12C82.34 77.38 52.71 108.5 41.83 128c-16.38 29.38-14.91 73.12 25.23 128c-40.13 54.88-41.61 98.63-25.23 128c29.13 52.38 101.6 43.63 116.3 41.88C179.6 477.1 212.4 512 256 512s76.39-34.88 97.9-86.13C368.5 427.6 441 436.4 470.2 384c16.38-29.38 14.91-73.13-25.23-128C485.1 201.1 486.5 157.4 470.2 128zM95.34 352c-4.001-7.25-.1251-24.75 15-48.25c6.876 6.5 14.13 12.87 21.88 19.12c1.625 13.75 4.001 27.13 6.751 40.13C114.3 363.9 99.09 358.6 95.34 352zM132.2 189.1C124.5 195.4 117.2 201.8 110.3 208.2C95.22 184.8 91.34 167.2 95.34 160c3.376-6.125 16.38-11.5 37.88-11.5c1.75 0 3.876 .375 5.751 .375C136.1 162.2 133.8 175.6 132.2 189.1zM256 64c9.502 0 22.25 13.5 33.88 37.25C278.6 105 267.4 109.3 256 114.1C244.6 109.3 233.4 105 222.1 101.2C233.7 77.5 246.5 64 256 64zM256 448c-9.502 0-22.25-13.5-33.88-37.25C233.4 407 244.6 402.7 256 397.9c11.38 4.875 22.63 9.135 33.88 12.89C278.3 434.5 265.5 448 256 448zM256 336c-44.13 0-80.02-35.88-80.02-80S211.9 176 256 176s80.02 35.88 80.02 80S300.1 336 256 336zM416.7 352c-3.626 6.625-19 11.88-43.63 11c2.751-12.1 5.126-26.38 6.751-40.13c7.752-6.25 15-12.63 21.88-19.12C416.8 327.2 420.7 344.8 416.7 352zM401.7 208.2c-6.876-6.5-14.13-12.87-21.88-19.12c-1.625-13.5-3.876-26.88-6.751-40.25c1.875 0 4.001-.375 5.751-.375c21.5 0 34.51 5.375 37.88 11.5C420.7 167.2 416.8 184.8 401.7 208.2z\"\n ]\n};\nvar faAudioDescription = {\n prefix: 'fas',\n iconName: 'audio-description',\n icon: [\n 576,\n 512,\n [],\n \"f29e\",\n \"M170.8 280H213.2L192 237.7L170.8 280zM512 32H64C28.65 32 0 60.65 0 96v320c0 35.35 28.65 64 64 64h448c35.35 0 64-28.65 64-64V96C576 60.65 547.3 32 512 32zM274.7 349.5C271.3 351.2 267.6 352 264 352c-8.812 0-17.28-4.859-21.5-13.27L233.2 320H150.8l-9.367 18.73c-5.906 11.86-20.31 16.7-32.19 10.73c-11.88-5.938-16.69-20.34-10.75-32.2l72-144c8.125-16.25 34.81-16.25 42.94 0l72 144C291.4 329.1 286.6 343.5 274.7 349.5zM384 352h-56c-13.25 0-24-10.75-24-24v-144C304 170.8 314.8 160 328 160H384c52.94 0 96 43.06 96 96S436.9 352 384 352zM384 208h-32v96h32c26.47 0 48-21.53 48-48S410.5 208 384 208z\"\n ]\n};\nvar faAustralSign = {\n prefix: 'fas',\n iconName: 'austral-sign',\n icon: [\n 448,\n 512,\n [],\n \"e0a9\",\n \"M325.3 224H416C433.7 224 448 238.3 448 256C448 273.7 433.7 288 416 288H352L365.3 320H416C433.7 320 448 334.3 448 352C448 369.7 433.7 384 416 384H392L413.5 435.7C420.3 452 412.6 470.7 396.3 477.5C379.1 484.3 361.3 476.6 354.5 460.3L322.7 384H125.3L93.54 460.3C86.74 476.6 68.01 484.3 51.69 477.5C35.38 470.7 27.66 452 34.46 435.7L56 384H32C14.33 384 0 369.7 0 352C0 334.3 14.33 320 32 320H82.67L96 288H32C14.33 288 0 273.7 0 256C0 238.3 14.33 224 32 224H122.7L194.5 51.69C199.4 39.77 211.1 32 224 32C236.9 32 248.6 39.77 253.5 51.69L325.3 224zM256 224L223.1 147.2L191.1 224H256zM165.3 288L151.1 320H296L282.7 288H165.3z\"\n ]\n};\nvar faAward = {\n prefix: 'fas',\n iconName: 'award',\n icon: [\n 384,\n 512,\n [],\n \"f559\",\n \"M288 358.3c13.98-8.088 17.53-30.04 28.88-41.39c11.35-11.35 33.3-14.88 41.39-28.87c7.98-13.79 .1658-34.54 4.373-50.29C366.7 222.5 383.1 208.5 383.1 192c0-16.5-17.27-30.52-21.34-45.73c-4.207-15.75 3.612-36.5-4.365-50.29c-8.086-13.98-30.03-17.52-41.38-28.87c-11.35-11.35-14.89-33.3-28.87-41.39c-13.79-7.979-34.54-.1637-50.29-4.375C222.5 17.27 208.5 0 192 0C175.5 0 161.5 17.27 146.3 21.34C130.5 25.54 109.8 17.73 95.98 25.7C82 33.79 78.46 55.74 67.11 67.08C55.77 78.43 33.81 81.97 25.72 95.95C17.74 109.7 25.56 130.5 21.35 146.2C17.27 161.5 .0008 175.5 .0008 192c0 16.5 17.27 30.52 21.34 45.73c4.207 15.75-3.615 36.5 4.361 50.29C33.8 302 55.74 305.5 67.08 316.9c11.35 11.35 14.89 33.3 28.88 41.4c13.79 7.979 34.53 .1582 50.28 4.369C161.5 366.7 175.5 384 192 384c16.5 0 30.52-17.27 45.74-21.34C253.5 358.5 274.2 366.3 288 358.3zM112 192c0-44.27 35.81-80 80-80s80 35.73 80 80c0 44.17-35.81 80-80 80S112 236.2 112 192zM1.719 433.2c-3.25 8.188-1.781 17.48 3.875 24.25c5.656 6.75 14.53 9.898 23.12 8.148l45.19-9.035l21.43 42.27C99.46 507 107.6 512 116.7 512c.3438 0 .6641-.0117 1.008-.0273c9.5-.375 17.65-6.082 21.24-14.88l33.58-82.08c-53.71-4.639-102-28.12-138.2-63.95L1.719 433.2zM349.6 351.1c-36.15 35.83-84.45 59.31-138.2 63.95l33.58 82.08c3.594 8.797 11.74 14.5 21.24 14.88C266.6 511.1 266.1 512 267.3 512c9.094 0 17.23-4.973 21.35-13.14l21.43-42.28l45.19 9.035c8.594 1.75 17.47-1.398 23.12-8.148c5.656-6.766 7.125-16.06 3.875-24.25L349.6 351.1z\"\n ]\n};\nvar faB = {\n prefix: 'fas',\n iconName: 'b',\n icon: [\n 320,\n 512,\n [\n 98\n ],\n \"42\",\n \"M257.1 242.4C276.1 220.1 288 191.6 288 160c0-70.58-57.42-128-128-128H32c-17.67 0-32 14.33-32 32v384c0 17.67 14.33 32 32 32l160-.0049c70.58 0 128-57.42 128-128C320 305.3 294.6 264.8 257.1 242.4zM64 96.01h96c35.3 0 64 28.7 64 64s-28.7 64-64 64H64V96.01zM192 416H64v-128h128c35.3 0 64 28.7 64 64S227.3 416 192 416z\"\n ]\n};\nvar faBaby = {\n prefix: 'fas',\n iconName: 'baby',\n icon: [\n 448,\n 512,\n [],\n \"f77c\",\n \"M156.8 411.8l31.22-31.22l-60.04-53.09l-52.29 52.28C61.63 393.8 60.07 416.1 72 432l48 64C127.9 506.5 139.9 512 152 512c8.345 0 16.78-2.609 23.97-8c17.69-13.25 21.25-38.33 8-56L156.8 411.8zM224 159.1c44.25 0 79.99-35.75 79.99-79.1S268.3 0 224 0S144 35.75 144 79.1S179.8 159.1 224 159.1zM408.7 145c-12.75-18.12-37.63-22.38-55.76-9.75l-40.63 28.5c-52.63 37-124.1 37-176.8 0l-40.63-28.5C76.84 122.6 51.97 127 39.22 145C26.59 163.1 30.97 188 48.97 200.8l40.63 28.5C101.7 237.7 114.7 244.3 128 250.2L128 288h192l.0002-37.71c13.25-5.867 26.22-12.48 38.34-21.04l40.63-28.5C417.1 188 421.4 163.1 408.7 145zM320 327.4l-60.04 53.09l31.22 31.22L264 448c-13.25 17.67-9.689 42.75 8 56C279.2 509.4 287.6 512 295.1 512c12.16 0 24.19-5.516 32.03-16l48-64c11.94-15.92 10.38-38.2-3.719-52.28L320 327.4z\"\n ]\n};\nvar faBabyCarriage = {\n prefix: 'fas',\n iconName: 'baby-carriage',\n icon: [\n 512,\n 512,\n [\n \"carriage-baby\"\n ],\n \"f77d\",\n \"M255.1 192H.1398C2.741 117.9 41.34 52.95 98.98 14.1C112.2 5.175 129.8 9.784 138.9 22.92L255.1 192zM384 160C384 124.7 412.7 96 448 96H480C497.7 96 512 110.3 512 128C512 145.7 497.7 160 480 160H448V224C448 249.2 442.2 274.2 430.9 297.5C419.7 320.8 403.2 341.9 382.4 359.8C361.6 377.6 336.9 391.7 309.7 401.4C282.5 411 253.4 416 223.1 416C194.6 416 165.5 411 138.3 401.4C111.1 391.7 86.41 377.6 65.61 359.8C44.81 341.9 28.31 320.8 17.05 297.5C5.794 274.2 0 249.2 0 224H384L384 160zM31.1 464C31.1 437.5 53.49 416 79.1 416C106.5 416 127.1 437.5 127.1 464C127.1 490.5 106.5 512 79.1 512C53.49 512 31.1 490.5 31.1 464zM416 464C416 490.5 394.5 512 368 512C341.5 512 320 490.5 320 464C320 437.5 341.5 416 368 416C394.5 416 416 437.5 416 464z\"\n ]\n};\nvar faCarriageBaby = faBabyCarriage;\nvar faBackward = {\n prefix: 'fas',\n iconName: 'backward',\n icon: [\n 512,\n 512,\n [\n 9194\n ],\n \"f04a\",\n \"M459.5 71.41l-171.5 142.9v83.45l171.5 142.9C480.1 457.7 512 443.3 512 415.1V96.03C512 68.66 480.1 54.28 459.5 71.41zM203.5 71.41L11.44 231.4c-15.25 12.87-15.25 36.37 0 49.24l192 159.1c20.63 17.12 52.51 2.749 52.51-24.62v-319.9C255.1 68.66 224.1 54.28 203.5 71.41z\"\n ]\n};\nvar faBackwardFast = {\n prefix: 'fas',\n iconName: 'backward-fast',\n icon: [\n 512,\n 512,\n [\n 9198,\n \"fast-backward\"\n ],\n \"f049\",\n \"M0 415.1V96.03c0-17.67 14.33-31.1 31.1-31.1C49.67 64.03 64 78.36 64 96.03v131.8l171.5-156.5C256.1 54.28 288 68.66 288 96.03v131.9l171.5-156.5C480.1 54.28 512 68.66 512 96.03v319.9c0 27.37-31.88 41.74-52.5 24.62L288 285.2v130.7c0 27.37-31.88 41.74-52.5 24.62L64 285.2v130.7c0 17.67-14.33 31.1-31.1 31.1C14.33 447.1 0 433.6 0 415.1z\"\n ]\n};\nvar faFastBackward = faBackwardFast;\nvar faBackwardStep = {\n prefix: 'fas',\n iconName: 'backward-step',\n icon: [\n 320,\n 512,\n [\n \"step-backward\"\n ],\n \"f048\",\n \"M31.1 64.03c-17.67 0-31.1 14.33-31.1 32v319.9c0 17.67 14.33 32 32 32C49.67 447.1 64 433.6 64 415.1V96.03C64 78.36 49.67 64.03 31.1 64.03zM267.5 71.41l-192 159.1C67.82 237.8 64 246.9 64 256c0 9.094 3.82 18.18 11.44 24.62l192 159.1c20.63 17.12 52.51 2.75 52.51-24.62v-319.9C319.1 68.66 288.1 54.28 267.5 71.41z\"\n ]\n};\nvar faStepBackward = faBackwardStep;\nvar faBacon = {\n prefix: 'fas',\n iconName: 'bacon',\n icon: [\n 576,\n 512,\n [\n 129363\n ],\n \"f7e5\",\n \"M29.34 432.5l-18.06-20.15c-9.406-10.47-13.25-25.3-10.31-39.65c2.813-13.71 11.23-24.74 23.09-30.23l68.88-31.94c47.95-22.25 87.64-60.2 114.8-109.8l20.66-37.76c28.77-52.59 70.98-92.93 122.1-116.6l92.75-42.99c14.84-6.812 32.41-3.078 43.69 9.518l34.08 38.01l-104.8 48.56c-55.72 25.83-101.7 69.73-133 127L261.3 266.5c-28.03 51.22-69 90.42-118.5 113.4L29.34 432.5zM564.7 99.68l-21.4-23.87l-113.6 52.68c-49.47 22.94-90.44 62.11-118.5 113.3L289.3 281.9c-31.33 57.27-77.34 101.2-133.1 127l-104.5 48.43l37.43 41.74C96.64 507.5 106.1 512 117.5 512c5.188 0 10.41-1.11 15.33-3.375l92.75-42.99c51.13-23.69 93.34-64.03 122.1-116.6l20.66-37.76c27.11-49.56 66.8-87.5 114.8-109.8l68.88-31.94c11.86-5.486 20.28-16.52 23.09-30.23C577.1 124.1 574.1 110.1 564.7 99.68z\"\n ]\n};\nvar faBacteria = {\n prefix: 'fas',\n iconName: 'bacteria',\n icon: [\n 640,\n 512,\n [],\n \"e059\",\n \"M627.3 227.3c9.439-2.781 14.81-12.65 12-22.04c-3.039-10.21-13.57-14.52-22.14-11.95l-11.27 3.33c-8.086-15.15-20.68-27.55-36.4-35.43l2.888-11.06c1.867-7.158-1.9-22.19-17.26-22.19c-7.92 0-15.14 5.288-17.23 13.28l-2.865 10.97c-7.701-.2793-26.9-.6485-48.75 13.63L477.6 157.1c-3.777-3.873-15.44-9.779-25.19-.3691c-7.062 6.822-7.225 18.04-.3711 25.07l9.14 9.373c-11.96 18.85-10.27 28.38-15.88 46.61c-8.023-3.758-11.44-5.943-16.66-5.943c-6.689 0-13.09 3.763-16.13 10.19c-4.188 8.856-.3599 19.42 8.546 23.58l8.797 4.115c-14.91 22.05-34.42 33.57-34.83 33.83l-3.922-8.855C387.2 285.8 376.7 281.7 367.7 285.6c-9 3.959-13.08 14.42-9.115 23.39l4.041 9.127c-16.38 4.559-27.93 4.345-46.15 16.94l-9.996-9.012c-6.969-6.303-18.28-6.33-25.15 1.235c-6.609 7.26-6.053 18.47 1.24 25.04l9.713 8.756c-8.49 14.18-12.74 30.77-11.64 48.17l-11.86 3.512c-9.428 2.793-14.8 12.66-11.99 22.05c2.781 9.385 12.69 14.71 22.15 11.94l11.34-3.359c8.287 15.49 20.99 27.86 36.38 35.57l-2.839 10.85c-2.482 9.477 3.224 19.16 12.75 21.62c9.566 2.482 19.25-3.221 21.72-12.69l2.82-10.78c5.508 .1875 11.11-.1523 16.75-1.102c11.37-1.893 22.23-5.074 33.1-8.24l3.379 9.455c3.305 9.225 13.5 14.11 22.75 10.76c9.266-3.279 14.1-13.41 10.81-22.65l-3.498-9.792c15.41-6.654 30.08-14.46 43.95-23.57l6.321 8.429c5.891 7.84 17.05 9.443 24.93 3.602c7.885-5.863 9.498-16.97 3.617-24.82l-6.457-8.611c12.66-10.78 24.33-22.54 34.96-35.33l8.816 6.413c7.932 5.795 19.07 4.074 24.89-3.855c5.809-7.908 4.072-18.1-3.874-24.77l-8.885-6.465c8.893-13.88 16.54-28.52 22.99-43.91l10.47 3.59c9.334 3.186 19.43-1.719 22.64-10.99c3.211-9.258-1.739-19.35-11.04-22.53l-10.33-3.541c5.744-20.5 9.424-31.81 8.338-49.26L627.3 227.3zM416 416c-17.67 0-32-14.33-32-32c0-17.67 14.33-32 32-32c17.67 0 32 14.33 32 32C448 401.7 433.7 416 416 416zM272.3 226.4c9-3.959 13.08-14.42 9.115-23.39L277.4 193.9c16.38-4.561 27.93-4.345 46.15-16.94l9.996 9.012c6.969 6.301 18.28 6.326 25.15-1.236c6.609-7.26 6.053-18.47-1.24-25.04l-9.713-8.756c8.49-14.18 12.74-30.77 11.64-48.18l11.86-3.511c9.428-2.793 14.8-12.66 11.99-22.05c-2.781-9.385-12.69-14.71-22.15-11.94l-11.34 3.357C341.5 53.13 328.8 40.76 313.4 33.05l2.838-10.85C318.7 12.73 313 3.04 303.5 .5811c-9.566-2.482-19.25 3.222-21.72 12.69l-2.82 10.78C273.4 23.86 267.8 24.2 262.2 25.15C250.8 27.04 239.1 30.22 229.1 33.39L225.7 23.93C222.4 14.71 212.2 9.827 202.1 13.17C193.7 16.45 188.9 26.59 192.2 35.82l3.498 9.793C180.2 52.27 165.6 60.07 151.7 69.19L145.4 60.76C139.5 52.92 128.3 51.32 120.5 57.16C112.6 63.02 110.1 74.13 116.8 81.98l6.457 8.611C110.6 101.4 98.96 113.1 88.34 125.9L79.52 119.5c-7.932-5.795-19.08-4.074-24.89 3.855c-5.809 7.908-4.07 19 3.875 24.77l8.885 6.465C58.5 168.5 50.86 183.1 44.41 198.5L33.93 194.9c-9.334-3.186-19.44 1.721-22.64 10.99C8.086 215.2 13.04 225.3 22.34 228.4l10.33 3.541C26.93 252.5 23.25 263.8 24.33 281.2L12.75 284.7C3.309 287.4-2.061 297.3 .7441 306.7c3.041 10.21 13.57 14.52 22.14 11.95l11.27-3.33c8.086 15.15 20.68 27.55 36.39 35.43l-2.887 11.06c-1.865 7.156 1.902 22.19 17.26 22.19c7.92 0 15.14-5.287 17.23-13.28l2.863-10.97c7.701 .2773 26.9 .6465 48.76-13.63l8.59 8.809c3.777 3.873 15.44 9.779 25.19 .3691c7.062-6.822 7.225-18.04 .3711-25.07l-9.14-9.373c11.96-18.85 10.27-28.38 15.88-46.61c8.025 3.756 11.44 5.943 16.66 5.943c6.689 0 13.09-3.762 16.13-10.19C231.6 261.1 227.8 250.6 218.9 246.4L210.1 242.3C225 220.2 244.5 208.7 244.9 208.5l3.922 8.856C252.8 226.2 263.3 230.3 272.3 226.4zM128 256C110.3 256 96 241.7 96 223.1c0-17.67 14.33-32 32-32c17.67 0 32 14.33 32 32C160 241.7 145.7 256 128 256zM208 160c-8.836 0-16-7.164-16-16c0-8.838 7.164-16 16-16s16 7.162 16 16C224 152.8 216.8 160 208 160z\"\n ]\n};\nvar faBacterium = {\n prefix: 'fas',\n iconName: 'bacterium',\n icon: [\n 576,\n 512,\n [],\n \"e05a\",\n \"M543 102.9c-3.711-12.51-16.92-19.61-29.53-15.92l-15.12 4.48c-11.05-20.65-27.98-37.14-48.5-47.43l3.783-14.46c3.309-12.64-4.299-25.55-16.99-28.83c-12.76-3.309-25.67 4.295-28.96 16.92l-3.76 14.37c-9.947-.3398-26.22 .1016-66.67 11.88l-4.301-12.03c-4.406-12.3-17.1-18.81-30.34-14.34c-12.35 4.371-18.8 17.88-14.41 30.2l4.303 12.04c-20.6 8.889-40.16 19.64-58.69 31.83L225.9 81.01C217.1 70.56 203.1 68.42 192.6 76.21C182.1 84.03 179.9 98.83 187.8 109.3l7.975 10.63C178.8 134.3 163.3 150.3 149.1 167.4L138 159.3C127.5 151.6 112.6 153.9 104.8 164.5c-7.748 10.54-5.428 25.33 5.164 33.03l11.09 8.066C109.2 224.1 98.79 243.7 90.18 264.3l-12.93-4.431c-12.45-4.248-25.92 2.293-30.18 14.65C42.78 286.9 49.38 300.3 61.78 304.6l13.05 4.474c-11.86 42.33-11.02 55.76-10.39 65.93l-15.45 4.566c-12.59 3.709-19.74 16.87-16 29.38c4.053 13.61 18.1 19.36 29.52 15.93l15.02-4.441c10.78 20.21 27.57 36.73 48.53 47.24l-3.852 14.75C119.7 491.1 124.8 512 145.2 512c10.56 0 20.19-7.049 22.98-17.7l3.816-14.63c10.2 .377 35.85 .873 65.01-18.17l11.45 11.74c5.037 5.164 20.59 13.04 33.58 .4922c9.416-9.096 9.633-24.06 .4941-33.43l-12.19-12.5c7.805-12.29 13.56-26.13 16.11-41.4c1.186-7.107 3.082-13.95 5.158-20.7c10.66 4.988 15.16 7.881 22.12 7.881c8.922 0 17.46-5.018 21.51-13.59c5.582-11.8 .4785-25.89-11.4-31.45l-11.73-5.486c20.09-29.62 45.89-44.76 46.44-45.11l5.23 11.81c5.273 11.86 19.19 17.36 31.33 12.1c11.1-5.279 17.44-19.22 12.15-31.18L401.9 258.5c5.438-1.512 10.86-3.078 16.52-4.021c16.8-2.797 31.88-9.459 45.02-18.54l13.33 12.02c9.289 8.395 24.37 8.439 33.54-1.648c8.814-9.68 8.072-24.62-1.654-33.38l-12.95-11.68c11.32-18.9 16.99-41.02 15.52-64.23l15.81-4.681C539.6 128.6 546.7 115.4 543 102.9zM192 368c-26.51 0-48.01-21.49-48.01-48s21.5-48 48.01-48S240.1 293.5 240.1 320S218.6 368 192 368zM272 232c-13.25 0-23.92-10.75-23.92-24c0-13.26 10.67-23.1 23.92-23.1c13.26 0 23.1 10.74 23.1 23.1C295.1 221.3 285.3 232 272 232z\"\n ]\n};\nvar faBagShopping = {\n prefix: 'fas',\n iconName: 'bag-shopping',\n icon: [\n 448,\n 512,\n [\n \"shopping-bag\"\n ],\n \"f290\",\n \"M112 112C112 50.14 162.1 0 224 0C285.9 0 336 50.14 336 112V160H400C426.5 160 448 181.5 448 208V416C448 469 405 512 352 512H96C42.98 512 0 469 0 416V208C0 181.5 21.49 160 48 160H112V112zM160 160H288V112C288 76.65 259.3 48 224 48C188.7 48 160 76.65 160 112V160zM136 256C149.3 256 160 245.3 160 232C160 218.7 149.3 208 136 208C122.7 208 112 218.7 112 232C112 245.3 122.7 256 136 256zM312 208C298.7 208 288 218.7 288 232C288 245.3 298.7 256 312 256C325.3 256 336 245.3 336 232C336 218.7 325.3 208 312 208z\"\n ]\n};\nvar faShoppingBag = faBagShopping;\nvar faBahai = {\n prefix: 'fas',\n iconName: 'bahai',\n icon: [\n 512,\n 512,\n [],\n \"f666\",\n \"M496.3 202.5l-110-15.38l41.88-104.4c6.625-16.63-11.63-32.25-26.63-22.63L307.5 120l-34.13-107.1C270.6 4.25 263.4 0 255.1 0C248.6 0 241.4 4.25 238.6 12.88L204.5 120L110.5 60.12c-15-9.5-33.22 5.1-26.6 22.63l41.85 104.4L15.71 202.5C-1.789 205-5.915 228.8 9.71 237.2l98.14 52.63l-74.51 83.5c-10.88 12.25-1.78 31 13.35 31c1.25 0 2.657-.25 4.032-.5l108.6-23.63l-4.126 112.5C154.7 504.4 164.1 512 173.6 512c5.125 0 10.38-2.25 14.25-7.25l68.13-88.88l68.23 88.88C327.1 509.8 333.2 512 338.4 512c9.5 0 18.88-7.625 18.38-19.25l-4.032-112.5l108.5 23.63c17.38 3.75 29.25-17.25 17.38-30.5l-74.51-83.5l98.14-52.72C517.9 228.8 513.8 205 496.3 202.5zM338.5 311.6L286.6 300.4l2 53.75l-32.63-42.5l-32.63 42.5l2-53.75L173.5 311.6l35.63-39.87L162.1 246.6L214.7 239.2L194.7 189.4l45 28.63L255.1 166.8l16.25 51.25l45-28.63L297.2 239.2l52.63 7.375l-47 25.13L338.5 311.6z\"\n ]\n};\nvar faBahtSign = {\n prefix: 'fas',\n iconName: 'baht-sign',\n icon: [\n 320,\n 512,\n [],\n \"e0ac\",\n \"M176 32V64C237.9 64 288 114.1 288 176C288 200.2 280.3 222.6 267.3 240.9C298.9 260.7 320 295.9 320 336C320 397.9 269.9 448 208 448H176V480C176 497.7 161.7 512 144 512C126.3 512 112 497.7 112 480V448H41.74C18.69 448 0 429.3 0 406.3V101.6C0 80.82 16.82 64 37.57 64H112V32C112 14.33 126.3 0 144 0C161.7 0 176 14.33 176 32V32zM112 128H64V224H112V128zM224 176C224 149.5 202.5 128 176 128V224C202.5 224 224 202.5 224 176zM112 288H64V384H112V288zM208 384C234.5 384 256 362.5 256 336C256 309.5 234.5 288 208 288H176V384H208z\"\n ]\n};\nvar faBan = {\n prefix: 'fas',\n iconName: 'ban',\n icon: [\n 512,\n 512,\n [\n 128683,\n \"cancel\"\n ],\n \"f05e\",\n \"M512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM99.5 144.8C77.15 176.1 64 214.5 64 256C64 362 149.1 448 256 448C297.5 448 335.9 434.9 367.2 412.5L99.5 144.8zM448 256C448 149.1 362 64 256 64C214.5 64 176.1 77.15 144.8 99.5L412.5 367.2C434.9 335.9 448 297.5 448 256V256z\"\n ]\n};\nvar faCancel = faBan;\nvar faBanSmoking = {\n prefix: 'fas',\n iconName: 'ban-smoking',\n icon: [\n 512,\n 512,\n [\n 128685,\n \"smoking-ban\"\n ],\n \"f54d\",\n \"M96 304C96 312.8 103.3 320 112 320h117.5l-96-96H112C103.3 224 96 231.3 96 240V304zM256 0C114.6 0 0 114.6 0 256s114.6 256 256 256s256-114.6 256-256S397.4 0 256 0zM256 448c-105.9 0-192-86.13-192-192c0-41.38 13.25-79.75 35.75-111.1l267.4 267.4C335.8 434.8 297.4 448 256 448zM301.2 256H384v32h-50.81L301.2 256zM412.3 367.1L365.2 320H400c8.75 0 16-7.25 16-16v-64C416 231.3 408.8 224 400 224h-130.8L144.9 99.75C176.3 77.25 214.6 64 256 64C361.9 64 448 150.1 448 256C448 297.4 434.8 335.8 412.3 367.1zM320.6 128C305 128 292 116.8 289.3 102.1C288.5 98.5 285.3 96 281.5 96h-16.25c-5 0-8.625 4.5-8 9.375C261.9 136.3 288.5 160 320.6 160C336.3 160 349.3 171.3 352 185.9C352.8 189.5 356 192 359.8 192h16.17c5 0 8.708-4.5 7.958-9.375C379.3 151.7 352.8 128 320.6 128z\"\n ]\n};\nvar faSmokingBan = faBanSmoking;\nvar faBandage = {\n prefix: 'fas',\n iconName: 'bandage',\n icon: [\n 640,\n 512,\n [\n 129657,\n \"band-aid\"\n ],\n \"f462\",\n \"M480 96H576C611.3 96 640 124.7 640 160V352C640 387.3 611.3 416 576 416H480V96zM448 416H192V96H448V416zM272 184C258.7 184 248 194.7 248 208C248 221.3 258.7 232 272 232C285.3 232 296 221.3 296 208C296 194.7 285.3 184 272 184zM368 232C381.3 232 392 221.3 392 208C392 194.7 381.3 184 368 184C354.7 184 344 194.7 344 208C344 221.3 354.7 232 368 232zM272 280C258.7 280 248 290.7 248 304C248 317.3 258.7 328 272 328C285.3 328 296 317.3 296 304C296 290.7 285.3 280 272 280zM368 328C381.3 328 392 317.3 392 304C392 290.7 381.3 280 368 280C354.7 280 344 290.7 344 304C344 317.3 354.7 328 368 328zM64 96H160V416H64C28.65 416 0 387.3 0 352V160C0 124.7 28.65 96 64 96z\"\n ]\n};\nvar faBandAid = faBandage;\nvar faBarcode = {\n prefix: 'fas',\n iconName: 'barcode',\n icon: [\n 512,\n 512,\n [],\n \"f02a\",\n \"M40 32C53.25 32 64 42.75 64 56V456C64 469.3 53.25 480 40 480H24C10.75 480 0 469.3 0 456V56C0 42.75 10.75 32 24 32H40zM128 48V464C128 472.8 120.8 480 112 480C103.2 480 96 472.8 96 464V48C96 39.16 103.2 32 112 32C120.8 32 128 39.16 128 48zM200 32C213.3 32 224 42.75 224 56V456C224 469.3 213.3 480 200 480H184C170.7 480 160 469.3 160 456V56C160 42.75 170.7 32 184 32H200zM296 32C309.3 32 320 42.75 320 56V456C320 469.3 309.3 480 296 480H280C266.7 480 256 469.3 256 456V56C256 42.75 266.7 32 280 32H296zM448 56C448 42.75 458.7 32 472 32H488C501.3 32 512 42.75 512 56V456C512 469.3 501.3 480 488 480H472C458.7 480 448 469.3 448 456V56zM384 48C384 39.16 391.2 32 400 32C408.8 32 416 39.16 416 48V464C416 472.8 408.8 480 400 480C391.2 480 384 472.8 384 464V48z\"\n ]\n};\nvar faBars = {\n prefix: 'fas',\n iconName: 'bars',\n icon: [\n 448,\n 512,\n [\n \"navicon\"\n ],\n \"f0c9\",\n \"M0 96C0 78.33 14.33 64 32 64H416C433.7 64 448 78.33 448 96C448 113.7 433.7 128 416 128H32C14.33 128 0 113.7 0 96zM0 256C0 238.3 14.33 224 32 224H416C433.7 224 448 238.3 448 256C448 273.7 433.7 288 416 288H32C14.33 288 0 273.7 0 256zM416 448H32C14.33 448 0 433.7 0 416C0 398.3 14.33 384 32 384H416C433.7 384 448 398.3 448 416C448 433.7 433.7 448 416 448z\"\n ]\n};\nvar faNavicon = faBars;\nvar faBarsProgress = {\n prefix: 'fas',\n iconName: 'bars-progress',\n icon: [\n 512,\n 512,\n [\n \"tasks-alt\"\n ],\n \"f828\",\n \"M464 64C490.5 64 512 85.49 512 112V176C512 202.5 490.5 224 464 224H48C21.49 224 0 202.5 0 176V112C0 85.49 21.49 64 48 64H464zM448 128H320V160H448V128zM464 288C490.5 288 512 309.5 512 336V400C512 426.5 490.5 448 464 448H48C21.49 448 0 426.5 0 400V336C0 309.5 21.49 288 48 288H464zM192 352V384H448V352H192z\"\n ]\n};\nvar faTasksAlt = faBarsProgress;\nvar faBarsStaggered = {\n prefix: 'fas',\n iconName: 'bars-staggered',\n icon: [\n 512,\n 512,\n [\n \"reorder\",\n \"stream\"\n ],\n \"f550\",\n \"M0 96C0 78.33 14.33 64 32 64H416C433.7 64 448 78.33 448 96C448 113.7 433.7 128 416 128H32C14.33 128 0 113.7 0 96zM64 256C64 238.3 78.33 224 96 224H480C497.7 224 512 238.3 512 256C512 273.7 497.7 288 480 288H96C78.33 288 64 273.7 64 256zM416 448H32C14.33 448 0 433.7 0 416C0 398.3 14.33 384 32 384H416C433.7 384 448 398.3 448 416C448 433.7 433.7 448 416 448z\"\n ]\n};\nvar faReorder = faBarsStaggered;\nvar faStream = faBarsStaggered;\nvar faBaseball = {\n prefix: 'fas',\n iconName: 'baseball',\n icon: [\n 512,\n 512,\n [\n 129358,\n 9918,\n \"baseball-ball\"\n ],\n \"f433\",\n \"M429.6 272.9c0-16.26 16.36-16.81 29.99-16.81l2.931 .0029c16.64 0 33.14 2.056 49.2 5.834C511.7 259.9 512 258 512 256c0-141.4-114.6-256-256-256C253.9 0 251.1 .2578 249.9 .3047c3.658 15.51 6.111 31.34 6.111 47.54c0 6-.2813 12.03-.7813 18C254.6 74.19 247.6 80.5 239.3 80.5c-6.091 0-16.03-4.68-16.03-15.97c0-1.733 .7149-7.153 .7149-16.69c0-15.26-2.389-30.18-6.225-44.69C106.9 19.79 19.5 107.3 3.08 218.3c14.44 3.819 29.38 5.79 44.45 5.79c10.07 0 15.59-.811 17.42-.811c6.229 0 16.49 4.657 16.49 15.99c0 16.11-16.13 16.77-29.73 16.77L48.16 256c-16.33 0-32.25-2.445-47.85-6.109C.2578 251.1 0 253.9 0 256c0 141.4 114.6 256 256 256c2.066 0 4.062-.2578 6.117-.3086C258.5 496.2 256 480.4 256 464.2c0-5.688 .25-11.38 .7187-17.03c.6964-8.538 8.287-14.61 16.49-14.61c7.1 0 15.44 6.938 15.44 15.92c0 2.358-.6524 5.88-.6524 15.72c0 15.25 2.383 30.16 6.209 44.66c110.8-16.63 198.2-104.1 214.7-215c-14.55-3.851-29.59-5.871-44.74-5.871c-10.47 0-16.24 .895-18.13 .895C443.3 288.9 429.6 286.5 429.6 272.9zM238.2 128.9c0 27.78-78.3 108.1-108.6 108.1c-8.612 0-16.01-6.963-16.01-15.98c0-6.002 3.394-11.75 9.163-14.49c80.3-38.08 76.21-94.5 99.39-94.5C234.7 112.8 238.2 124.2 238.2 128.9zM397.5 290.6c0 5.965-3.364 11.68-9.131 14.43c-78.82 37.57-75.92 95-98.94 95c-12.58 0-16.01-11.54-16.01-16.03c0-28 78.29-109.4 108.1-109.4C390.8 274.6 397.5 282.3 397.5 290.6z\"\n ]\n};\nvar faBaseballBall = faBaseball;\nvar faBaseballBatBall = {\n prefix: 'fas',\n iconName: 'baseball-bat-ball',\n icon: [\n 640,\n 512,\n [],\n \"f432\",\n \"M57.89 397.2c-6.262-8.616-16.02-13.19-25.92-13.19c-23.33 0-31.98 20.68-31.98 32.03c0 6.522 1.987 13.1 6.115 18.78l46.52 64C58.89 507.4 68.64 512 78.55 512c23.29 0 31.97-20.66 31.97-32.03c0-6.522-1.988-13.1-6.115-18.78L57.89 397.2zM496.1 352c-44.13 0-79.72 35.75-79.72 80s35.59 80 79.72 80s79.91-35.75 79.91-80S540.2 352 496.1 352zM640 99.38c0-13.61-4.133-27.34-12.72-39.2l-23.63-32.5c-13.44-18.5-33.77-27.68-54.12-27.68c-13.89 0-27.79 4.281-39.51 12.8L307.8 159.7C262.2 192.8 220.4 230.9 183.4 273.4c-24.22 27.88-59.18 63.99-103.5 99.63l56.34 77.52c53.79-35.39 99.15-55.3 127.1-67.27c51.88-22 101.3-49.87 146.9-82.1l202.3-146.7C630.5 140.4 640 120 640 99.38z\"\n ]\n};\nvar faBasketShopping = {\n prefix: 'fas',\n iconName: 'basket-shopping',\n icon: [\n 576,\n 512,\n [\n \"shopping-basket\"\n ],\n \"f291\",\n \"M171.7 191.1H404.3L322.7 35.07C316.6 23.31 321.2 8.821 332.9 2.706C344.7-3.409 359.2 1.167 365.3 12.93L458.4 191.1H544C561.7 191.1 576 206.3 576 223.1C576 241.7 561.7 255.1 544 255.1L492.1 463.5C484.1 492 459.4 512 430 512H145.1C116.6 512 91 492 83.88 463.5L32 255.1C14.33 255.1 0 241.7 0 223.1C0 206.3 14.33 191.1 32 191.1H117.6L210.7 12.93C216.8 1.167 231.3-3.409 243.1 2.706C254.8 8.821 259.4 23.31 253.3 35.07L171.7 191.1zM191.1 303.1C191.1 295.1 184.8 287.1 175.1 287.1C167.2 287.1 159.1 295.1 159.1 303.1V399.1C159.1 408.8 167.2 415.1 175.1 415.1C184.8 415.1 191.1 408.8 191.1 399.1V303.1zM271.1 303.1V399.1C271.1 408.8 279.2 415.1 287.1 415.1C296.8 415.1 304 408.8 304 399.1V303.1C304 295.1 296.8 287.1 287.1 287.1C279.2 287.1 271.1 295.1 271.1 303.1zM416 303.1C416 295.1 408.8 287.1 400 287.1C391.2 287.1 384 295.1 384 303.1V399.1C384 408.8 391.2 415.1 400 415.1C408.8 415.1 416 408.8 416 399.1V303.1z\"\n ]\n};\nvar faShoppingBasket = faBasketShopping;\nvar faBasketball = {\n prefix: 'fas',\n iconName: 'basketball',\n icon: [\n 512,\n 512,\n [\n 127936,\n \"basketball-ball\"\n ],\n \"f434\",\n \"M148.7 171.3L64.21 86.83c-28.39 32.16-48.9 71.38-58.3 114.8C19.41 205.4 33.34 208 48 208C86.34 208 121.1 193.9 148.7 171.3zM194.5 171.9L256 233.4l169.2-169.2C380 24.37 320.9 0 256 0C248.6 0 241.2 .4922 233.1 1.113C237.8 16.15 240 31.8 240 48C240 95.19 222.8 138.4 194.5 171.9zM208 48c0-14.66-2.623-28.59-6.334-42.09C158.2 15.31 118.1 35.82 86.83 64.21l84.48 84.48C193.9 121.1 208 86.34 208 48zM171.9 194.5C138.4 222.8 95.19 240 48 240c-16.2 0-31.85-2.236-46.89-6.031C.4922 241.2 0 248.6 0 256c0 64.93 24.37 124 64.21 169.2L233.4 256L171.9 194.5zM317.5 340.1L256 278.6l-169.2 169.2C131.1 487.6 191.1 512 256 512c7.438 0 14.75-.4922 22.03-1.113C274.2 495.8 272 480.2 272 464C272 416.8 289.2 373.6 317.5 340.1zM363.3 340.7l84.48 84.48c28.39-32.16 48.9-71.38 58.3-114.8C492.6 306.6 478.7 304 464 304C425.7 304 390.9 318.1 363.3 340.7zM447.8 86.83L278.6 256l61.52 61.52C373.6 289.2 416.8 272 464 272c16.2 0 31.85 2.236 46.89 6.031C511.5 270.8 512 263.4 512 256C512 191.1 487.6 131.1 447.8 86.83zM304 464c0 14.66 2.623 28.59 6.334 42.09c43.46-9.4 82.67-29.91 114.8-58.3l-84.48-84.48C318.1 390.9 304 425.7 304 464z\"\n ]\n};\nvar faBasketballBall = faBasketball;\nvar faBath = {\n prefix: 'fas',\n iconName: 'bath',\n icon: [\n 512,\n 512,\n [\n 128705,\n \"bathtub\"\n ],\n \"f2cd\",\n \"M32 384c0 28.32 12.49 53.52 32 71.09V496C64 504.8 71.16 512 80 512h32C120.8 512 128 504.8 128 496v-15.1h256V496c0 8.836 7.164 16 16 16h32c8.836 0 16-7.164 16-16v-40.9c19.51-17.57 32-42.77 32-71.09V352H32V384zM496 256H96V77.25C95.97 66.45 111 60.23 118.6 67.88L132.4 81.66C123.6 108.6 129.4 134.5 144.2 153.2C137.9 159.5 137.8 169.8 144 176l11.31 11.31c6.248 6.248 16.38 6.248 22.63 0l105.4-105.4c6.248-6.248 6.248-16.38 0-22.63l-11.31-11.31c-6.248-6.248-16.38-6.248-22.63 0C230.7 33.26 204.7 27.55 177.7 36.41L163.9 22.64C149.5 8.25 129.6 0 109.3 0C66.66 0 32 34.66 32 77.25v178.8L16 256C7.164 256 0 263.2 0 272v32C0 312.8 7.164 320 16 320h480c8.836 0 16-7.164 16-16v-32C512 263.2 504.8 256 496 256z\"\n ]\n};\nvar faBathtub = faBath;\nvar faBatteryEmpty = {\n prefix: 'fas',\n iconName: 'battery-empty',\n icon: [\n 576,\n 512,\n [\n \"battery-0\"\n ],\n \"f244\",\n \"M464 96C508.2 96 544 131.8 544 176V192C561.7 192 576 206.3 576 224V288C576 305.7 561.7 320 544 320V336C544 380.2 508.2 416 464 416H80C35.82 416 0 380.2 0 336V176C0 131.8 35.82 96 80 96H464zM64 336C64 344.8 71.16 352 80 352H464C472.8 352 480 344.8 480 336V176C480 167.2 472.8 160 464 160H80C71.16 160 64 167.2 64 176V336z\"\n ]\n};\nvar faBattery0 = faBatteryEmpty;\nvar faBatteryFull = {\n prefix: 'fas',\n iconName: 'battery-full',\n icon: [\n 576,\n 512,\n [\n 128267,\n \"battery\",\n \"battery-5\"\n ],\n \"f240\",\n \"M448 320H96V192H448V320zM0 176C0 131.8 35.82 96 80 96H464C508.2 96 544 131.8 544 176V192C561.7 192 576 206.3 576 224V288C576 305.7 561.7 320 544 320V336C544 380.2 508.2 416 464 416H80C35.82 416 0 380.2 0 336V176zM80 160C71.16 160 64 167.2 64 176V336C64 344.8 71.16 352 80 352H464C472.8 352 480 344.8 480 336V176C480 167.2 472.8 160 464 160H80z\"\n ]\n};\nvar faBattery = faBatteryFull;\nvar faBattery5 = faBatteryFull;\nvar faBatteryHalf = {\n prefix: 'fas',\n iconName: 'battery-half',\n icon: [\n 576,\n 512,\n [\n \"battery-3\"\n ],\n \"f242\",\n \"M288 320H96V192H288V320zM0 176C0 131.8 35.82 96 80 96H464C508.2 96 544 131.8 544 176V192C561.7 192 576 206.3 576 224V288C576 305.7 561.7 320 544 320V336C544 380.2 508.2 416 464 416H80C35.82 416 0 380.2 0 336V176zM80 160C71.16 160 64 167.2 64 176V336C64 344.8 71.16 352 80 352H464C472.8 352 480 344.8 480 336V176C480 167.2 472.8 160 464 160H80z\"\n ]\n};\nvar faBattery3 = faBatteryHalf;\nvar faBatteryQuarter = {\n prefix: 'fas',\n iconName: 'battery-quarter',\n icon: [\n 576,\n 512,\n [\n \"battery-2\"\n ],\n \"f243\",\n \"M192 320H96V192H192V320zM0 176C0 131.8 35.82 96 80 96H464C508.2 96 544 131.8 544 176V192C561.7 192 576 206.3 576 224V288C576 305.7 561.7 320 544 320V336C544 380.2 508.2 416 464 416H80C35.82 416 0 380.2 0 336V176zM80 160C71.16 160 64 167.2 64 176V336C64 344.8 71.16 352 80 352H464C472.8 352 480 344.8 480 336V176C480 167.2 472.8 160 464 160H80z\"\n ]\n};\nvar faBattery2 = faBatteryQuarter;\nvar faBatteryThreeQuarters = {\n prefix: 'fas',\n iconName: 'battery-three-quarters',\n icon: [\n 576,\n 512,\n [\n \"battery-4\"\n ],\n \"f241\",\n \"M352 320H96V192H352V320zM0 176C0 131.8 35.82 96 80 96H464C508.2 96 544 131.8 544 176V192C561.7 192 576 206.3 576 224V288C576 305.7 561.7 320 544 320V336C544 380.2 508.2 416 464 416H80C35.82 416 0 380.2 0 336V176zM80 160C71.16 160 64 167.2 64 176V336C64 344.8 71.16 352 80 352H464C472.8 352 480 344.8 480 336V176C480 167.2 472.8 160 464 160H80z\"\n ]\n};\nvar faBattery4 = faBatteryThreeQuarters;\nvar faBed = {\n prefix: 'fas',\n iconName: 'bed',\n icon: [\n 640,\n 512,\n [\n 128716\n ],\n \"f236\",\n \"M176 288C220.1 288 256 252.1 256 208S220.1 128 176 128S96 163.9 96 208S131.9 288 176 288zM544 128H304C295.2 128 288 135.2 288 144V320H64V48C64 39.16 56.84 32 48 32h-32C7.163 32 0 39.16 0 48v416C0 472.8 7.163 480 16 480h32C56.84 480 64 472.8 64 464V416h512v48c0 8.837 7.163 16 16 16h32c8.837 0 16-7.163 16-16V224C640 170.1 597 128 544 128z\"\n ]\n};\nvar faBedPulse = {\n prefix: 'fas',\n iconName: 'bed-pulse',\n icon: [\n 640,\n 512,\n [\n \"procedures\"\n ],\n \"f487\",\n \"M96 318.3v1.689h1.689C97.12 319.4 96.56 318.9 96 318.3zM176 320c44.13 0 80-35.88 80-79.1s-35.88-79.1-80-79.1S96 195.9 96 240S131.9 320 176 320zM256 318.3C255.4 318.9 254.9 319.4 254.3 320H256V318.3zM544 160h-82.1L450.7 183.9C441.5 203.2 421.8 215.8 400 216c-21.23 0-40.97-12.31-50.3-31.35l-12.08-24.64H304c-8.836 0-16 7.161-16 15.1v175.1L64 352V80.01c0-8.834-7.164-15.1-16-15.1h-32c-8.836 0-16 7.163-16 15.1V496C0 504.8 7.164 512 16 512h32C56.84 512 64 504.8 64 496v-47.1h512V496c0 8.836 7.164 16 16 16h32c8.836 0 16-7.164 16-16V256C640 202.1 597 160 544 160zM624 48.01h-115.2l-24.88-37.31c-2.324-3.48-5.539-6.131-9.158-7.977c-1.172-.6016-2.486-.5508-3.738-.9512C468.8 1.035 466.5 0 464.1 0c-.625 0-1.25 .0254-1.875 .0781c-8.625 .6406-16.25 5.876-19.94 13.7l-42.72 90.81l-21.12-43.12c-4.027-8.223-12.39-13.44-21.54-13.44L208 48.02C199.2 48.01 192 55.18 192 64.02v15.99c0 8.836 7.163 15.1 15.1 16l133.1 .0091l36.46 74.55C382.5 178.8 390.8 184 400 184c9.219-.0781 17.78-5.438 21.72-13.78l45.91-97.52l8.406 12.62C480.5 91.1 487.1 96.01 496 96.01h128c8.836 0 16-7.164 16-16V64.01C640 55.18 632.8 48.01 624 48.01z\"\n ]\n};\nvar faProcedures = faBedPulse;\nvar faBeerMugEmpty = {\n prefix: 'fas',\n iconName: 'beer-mug-empty',\n icon: [\n 512,\n 512,\n [\n \"beer\"\n ],\n \"f0fc\",\n \"M432 96H384V64c0-17.67-14.33-32-32-32H64C46.33 32 32 46.33 32 64v352c0 35.35 28.65 64 64 64h224c35.35 0 64-28.65 64-64v-32.08l80.66-35.94C493.5 335.1 512 306.5 512 275V176C512 131.8 476.2 96 432 96zM160 368C160 376.9 152.9 384 144 384S128 376.9 128 368v-224C128 135.1 135.1 128 144 128S160 135.1 160 144V368zM224 368C224 376.9 216.9 384 208 384S192 376.9 192 368v-224C192 135.1 199.1 128 208 128S224 135.1 224 144V368zM288 368c0 8.875-7.125 16-16 16S256 376.9 256 368v-224C256 135.1 263.1 128 272 128S288 135.1 288 144V368zM448 275c0 6.25-3.75 12-9.5 14.62L384 313.9V160h48C440.9 160 448 167.1 448 176V275z\"\n ]\n};\nvar faBeer = faBeerMugEmpty;\nvar faBell = {\n prefix: 'fas',\n iconName: 'bell',\n icon: [\n 448,\n 512,\n [\n 61602,\n 128276\n ],\n \"f0f3\",\n \"M256 32V51.2C329 66.03 384 130.6 384 208V226.8C384 273.9 401.3 319.2 432.5 354.4L439.9 362.7C448.3 372.2 450.4 385.6 445.2 397.1C440 408.6 428.6 416 416 416H32C19.4 416 7.971 408.6 2.809 397.1C-2.353 385.6-.2883 372.2 8.084 362.7L15.5 354.4C46.74 319.2 64 273.9 64 226.8V208C64 130.6 118.1 66.03 192 51.2V32C192 14.33 206.3 0 224 0C241.7 0 256 14.33 256 32H256zM224 512C207 512 190.7 505.3 178.7 493.3C166.7 481.3 160 464.1 160 448H288C288 464.1 281.3 481.3 269.3 493.3C257.3 505.3 240.1 512 224 512z\"\n ]\n};\nvar faBellConcierge = {\n prefix: 'fas',\n iconName: 'bell-concierge',\n icon: [\n 512,\n 512,\n [\n 128718,\n \"concierge-bell\"\n ],\n \"f562\",\n \"M280 145.3V112h16C309.3 112 320 101.3 320 88S309.3 64 296 64H215.1C202.7 64 192 74.75 192 87.1S202.7 112 215.1 112H232v33.32C119.6 157.3 32 252.4 32 368h448C480 252.4 392.4 157.3 280 145.3zM488 400h-464C10.75 400 0 410.7 0 423.1C0 437.3 10.75 448 23.1 448h464c13.25 0 24-10.75 24-23.1C512 410.7 501.3 400 488 400z\"\n ]\n};\nvar faConciergeBell = faBellConcierge;\nvar faBellSlash = {\n prefix: 'fas',\n iconName: 'bell-slash',\n icon: [\n 640,\n 512,\n [\n 61943,\n 128277\n ],\n \"f1f6\",\n \"M186 120.5C209 85.38 245.4 59.84 288 51.2V32C288 14.33 302.3 .0003 320 .0003C337.7 .0003 352 14.33 352 32V51.2C425 66.03 480 130.6 480 208V226.8C480 273.9 497.3 319.2 528.5 354.4L535.9 362.7C544.3 372.2 546.4 385.6 541.2 397.1C540.1 397.5 540.8 397.1 540.6 398.4L630.8 469.1C641.2 477.3 643.1 492.4 634.9 502.8C626.7 513.2 611.6 515.1 601.2 506.9L9.196 42.89C-1.236 34.71-3.065 19.63 5.112 9.196C13.29-1.236 28.37-3.065 38.81 5.112L186 120.5zM160 226.8V222.1L406.2 416H128C115.4 416 103.1 408.6 98.81 397.1C93.65 385.6 95.71 372.2 104.1 362.7L111.5 354.4C142.7 319.2 160 273.9 160 226.8V226.8zM320 512C303 512 286.7 505.3 274.7 493.3C262.7 481.3 256 464.1 256 448H384C384 464.1 377.3 481.3 365.3 493.3C353.3 505.3 336.1 512 320 512z\"\n ]\n};\nvar faBezierCurve = {\n prefix: 'fas',\n iconName: 'bezier-curve',\n icon: [\n 640,\n 512,\n [],\n \"f55b\",\n \"M352 32C378.5 32 400 53.49 400 80V84H518.4C528.8 62.69 550.7 48 576 48C611.3 48 640 76.65 640 112C640 147.3 611.3 176 576 176C550.7 176 528.8 161.3 518.4 140H451.5C510.4 179.6 550.4 244.1 555.5 320H560C586.5 320 608 341.5 608 368V432C608 458.5 586.5 480 560 480H496C469.5 480 448 458.5 448 432V368C448 341.5 469.5 320 496 320H499.3C493.4 253 450.8 196.6 391.8 170.9C383.1 183.6 368.6 192 352 192H288C271.4 192 256.9 183.6 248.2 170.9C189.2 196.6 146.6 253 140.7 320H144C170.5 320 192 341.5 192 368V432C192 458.5 170.5 480 144 480H80C53.49 480 32 458.5 32 432V368C32 341.5 53.49 320 80 320H84.53C89.56 244.1 129.6 179.6 188.5 140H121.6C111.2 161.3 89.3 176 64 176C28.65 176 0 147.3 0 112C0 76.65 28.65 48 64 48C89.3 48 111.2 62.69 121.6 84H240V80C240 53.49 261.5 32 288 32H352zM296 136H344V88H296V136zM88 376V424H136V376H88zM552 424V376H504V424H552z\"\n ]\n};\nvar faBicycle = {\n prefix: 'fas',\n iconName: 'bicycle',\n icon: [\n 640,\n 512,\n [\n 128690\n ],\n \"f206\",\n \"M347.2 32C358.1 32 369.8 38.44 375.4 48.78L473.3 229.1C485.5 226.1 498.5 224 512 224C582.7 224 640 281.3 640 352C640 422.7 582.7 480 512 480C441.3 480 384 422.7 384 352C384 311.1 402.4 276.3 431.1 252.8L409.4 212.7L324.7 356.2C320.3 363.5 312.5 368 304 368H255C247.1 431.1 193.3 480 128 480C57.31 480 0 422.7 0 352C0 281.3 57.31 224 128 224C138.7 224 149.2 225.3 159.2 227.8L185.8 174.7L163.7 144H120C106.7 144 96 133.3 96 120C96 106.7 106.7 96 120 96H176C183.7 96 190.1 99.71 195.5 105.1L222.9 144H372.3L337.7 80H311.1C298.7 80 287.1 69.25 287.1 56C287.1 42.75 298.7 32 311.1 32H347.2zM440 352C440 391.8 472.2 424 512 424C551.8 424 584 391.8 584 352C584 312.2 551.8 280 512 280C508.2 280 504.5 280.3 500.8 280.9L533.1 340.6C539.4 352.2 535.1 366.8 523.4 373.1C511.8 379.4 497.2 375.1 490.9 363.4L458.6 303.7C447 316.5 440 333.4 440 352V352zM108.8 328.6L133.1 280.2C131.4 280.1 129.7 280 127.1 280C88.24 280 55.1 312.2 55.1 352C55.1 391.8 88.24 424 127.1 424C162.3 424 190.9 400.1 198.2 368H133.2C112.1 368 99.81 346.7 108.8 328.6H108.8zM290.3 320L290.4 319.9L217.5 218.7L166.8 320H290.3zM257.4 192L317 274.8L365.9 192H257.4z\"\n ]\n};\nvar faBinoculars = {\n prefix: 'fas',\n iconName: 'binoculars',\n icon: [\n 512,\n 512,\n [],\n \"f1e5\",\n \"M416 48C416 39.13 408.9 32 400 32h-64C327.1 32 320 39.13 320 48V96h96.04L416 48zM63.88 160.1C61.34 253.9 3.5 274.3 0 404V448c0 17.6 14.4 32 32 32h128c17.6 0 32-14.4 32-32V128H95.88C78.26 128 64.35 142.5 63.88 160.1zM448.1 160.1C447.6 142.5 433.7 128 416.1 128H320v320c0 17.6 14.4 32 32 32h128c17.6 0 32-14.4 32-32v-44C508.5 274.3 450.7 253.9 448.1 160.1zM224 288h64V128H224V288zM176 32h-64C103.1 32 96 39.13 96 48L95.96 96H192V48C192 39.13 184.9 32 176 32z\"\n ]\n};\nvar faBiohazard = {\n prefix: 'fas',\n iconName: 'biohazard',\n icon: [\n 576,\n 512,\n [\n 9763\n ],\n \"f780\",\n \"M575.5 283.5c-13.13-39.11-39.5-71.98-74.13-92.35c-17.5-10.37-36.25-16.62-55.25-19.87c6-17.75 10-36.49 10-56.24c0-40.99-14.5-80.73-41-112.2c-2.5-3-6.625-3.623-10-1.75c-3.25 1.875-4.75 5.998-3.625 9.748c4.5 13.75 6.625 26.24 6.625 38.49c0 67.73-53.76 122.8-120 122.8s-120-55.11-120-122.8c0-12.12 2.25-24.74 6.625-38.49c1.125-3.75-.375-7.873-3.625-9.748c-3.375-1.873-7.502-1.25-10 1.75C134.7 34.3 120.1 74.04 120.1 115c0 19.75 3.875 38.49 10 56.24C111.2 174.5 92.32 180.8 74.82 191.1c-34.63 20.49-61.01 53.24-74.38 92.35c-1.25 3.75 .25 7.748 3.5 9.748c3.375 2 7.5 1.375 10-1.5c9.377-10.87 19-19.12 29.25-25.12c57.25-33.87 130.8-13.75 163.9 44.99c33.13 58.61 13.38 133.1-43.88 167.8c-10.25 6.123-22 10.37-35.88 13.37c-3.627 .875-6.377 4.25-6.377 8.123c.125 4 2.75 7.248 6.502 7.998c39.75 7.748 80.63 .7495 115.3-19.74c18-10.5 32.88-24.49 45.25-39.99c12.38 15.5 27.38 29.49 45.38 39.99c34.5 20.49 75.51 27.49 115.1 19.74c3.875-.75 6.375-3.998 6.5-7.998c0-3.873-2.625-7.248-6.375-8.123c-13.88-2.873-25.63-7.248-35.75-13.37c-57.38-33.87-77.01-109.2-44-167.8c33.13-58.73 106.6-78.85 164-44.99c10.12 6.123 19.75 14.25 29.13 25.12c2.5 2.875 6.752 3.5 10 1.5C575.4 291.2 576.9 287.2 575.5 283.5zM287.1 320.1c-26.5 0-48-21.49-48-47.99c0-26.49 21.5-47.99 48-47.99c26.5 0 48.01 21.49 48.01 47.99C335.1 298.6 314.5 320.1 287.1 320.1zM385 377.6c1.152 22.77 10.74 44.63 27.22 60.92c47.45-35.44 79.13-90.58 83.1-153.4c-22.58-6.173-45.69-2.743-65.57 8.76C424.7 326.9 408.5 355.1 385 377.6zM253.3 132.6c26.22-6.551 45.37-6.024 69.52 .0254c21.93-9.777 39.07-28.55 47.48-51.75C345 69.98 317.3 63.94 288.1 63.94c-29.18 0-56.96 5.986-82.16 16.84C214.3 103.1 231.4 122.8 253.3 132.6zM163.8 438.5c16.46-16.26 26.03-38.19 27.14-61.01c-23.49-21.59-39.59-50.67-44.71-83.6C126.9 282.7 103.8 278.8 80.67 285.1C84.64 347.9 116.3 403.1 163.8 438.5z\"\n ]\n};\nvar faBitcoinSign = {\n prefix: 'fas',\n iconName: 'bitcoin-sign',\n icon: [\n 320,\n 512,\n [],\n \"e0b4\",\n \"M48 32C48 14.33 62.33 0 80 0C97.67 0 112 14.33 112 32V64H144V32C144 14.33 158.3 0 176 0C193.7 0 208 14.33 208 32V64C208 65.54 207.9 67.06 207.7 68.54C254.1 82.21 288 125.1 288 176C288 200.2 280.3 222.6 267.3 240.9C298.9 260.7 320 295.9 320 336C320 397.9 269.9 448 208 448V480C208 497.7 193.7 512 176 512C158.3 512 144 497.7 144 480V448H112V480C112 497.7 97.67 512 80 512C62.33 512 48 497.7 48 480V448H41.74C18.69 448 0 429.3 0 406.3V101.6C0 80.82 16.82 64 37.57 64H48V32zM176 224C202.5 224 224 202.5 224 176C224 149.5 202.5 128 176 128H64V224H176zM64 288V384H208C234.5 384 256 362.5 256 336C256 309.5 234.5 288 208 288H64z\"\n ]\n};\nvar faBlender = {\n prefix: 'fas',\n iconName: 'blender',\n icon: [\n 512,\n 512,\n [],\n \"f517\",\n \"M336 64h158.5L512 0H48C21.49 0 0 21.49 0 48v160C0 234.5 21.49 256 48 256h103.3L160 352h256l17.49-64H336C327.2 288 320 280.8 320 272S327.2 256 336 256h106.1l17.49-64H336C327.2 192 320 184.8 320 176S327.2 160 336 160h132.4l17.49-64H336C327.2 96 320 88.8 320 80S327.2 64 336 64zM64 192V64h69.88L145.5 192H64zM416 384H160c-35.38 0-64 28.62-64 64l-.0001 32c0 17.62 14.38 32 32 32h320c17.62 0 32-14.38 32-32l.0003-32C480 412.6 451.4 384 416 384zM288 480c-17.62 0-32-14.38-32-32s14.38-32 32-32s32 14.38 32 32S305.6 480 288 480z\"\n ]\n};\nvar faBlenderPhone = {\n prefix: 'fas',\n iconName: 'blender-phone',\n icon: [\n 576,\n 512,\n [],\n \"f6b6\",\n \"M158.7 334.1L132.1 271.7C130.2 264.1 123.2 260.7 115.7 261.5l-45 4.374c-17.25-46.87-17.63-99.74 0-147.6l45 4.374C123.2 123.4 130.2 119.1 132.1 112.4l25.75-63.25C161.9 41.76 158.1 33.26 152.1 29.01L112.9 4.887C98.49-3.863 80.12-.4886 68.99 12.01C-23.64 115.6-23.01 271.5 70.99 374.5c9.875 10.75 29.13 12.5 41.75 4.75l39.38-24.12C158.1 350.9 161.7 342.4 158.7 334.1zM479.1 384H224c-35.38 0-63.1 28.62-63.1 63.1l-.0052 32c0 17.62 14.37 31.1 31.1 31.1L511.1 512c17.63 0 32-14.38 32-31.1l.0019-31.1C543.1 412.6 515.4 384 479.1 384zM352 480c-17.63 0-31.1-14.38-31.1-31.1c0-17.62 14.37-31.1 31.1-31.1s31.1 14.38 31.1 31.1C384 465.6 369.6 480 352 480zM399.1 64h158.5L576 .008L191.1 .006l-.0023 351.1h288l17.49-64h-97.49c-8.801 0-16-7.199-16-15.1c0-8.799 7.199-15.1 16-15.1h106.1l17.49-63.1h-123.6c-8.801 0-16-7.199-16-15.1c0-8.799 7.199-15.1 16-15.1h132.4l17.49-63.1h-149.9c-8.801 0-16-7.199-16-15.1C383.1 71.2 391.2 64 399.1 64z\"\n ]\n};\nvar faBlog = {\n prefix: 'fas',\n iconName: 'blog',\n icon: [\n 512,\n 512,\n [],\n \"f781\",\n \"M217.6 96.1c-12.95-.625-24.66 9.156-25.52 22.37C191.2 131.7 201.2 143.1 214.4 143.1c79.53 5.188 148.4 74.09 153.6 153.6c.8281 12.69 11.39 22.43 23.94 22.43c.5156 0 1.047-.0313 1.578-.0625c13.22-.8438 23.25-12.28 22.39-25.5C409.3 191.8 320.3 102.8 217.6 96.1zM224 0C206.3 0 192 14.31 192 32s14.33 32 32 32c123.5 0 224 100.5 224 224c0 17.69 14.33 32 32 32s32-14.31 32-32C512 129.2 382.8 0 224 0zM172.3 226.8C157.7 223.9 144 235.8 144 250.6v50.37c0 10.25 7.127 18.37 16.75 21.1c18.13 6.75 31.26 24.38 31.26 44.1c0 26.5-21.5 47.1-48.01 47.1c-26.5 0-48.01-21.5-48.01-47.1V120c0-13.25-10.75-23.1-24.01-23.1l-48.01 .0076C10.75 96.02 0 106.8 0 120v247.1c0 89.5 82.14 160.2 175 140.7c54.38-11.5 98.27-55.5 109.8-109.7C302.2 316.1 247.8 241.8 172.3 226.8z\"\n ]\n};\nvar faBold = {\n prefix: 'fas',\n iconName: 'bold',\n icon: [\n 384,\n 512,\n [],\n \"f032\",\n \"M321.1 242.4C340.1 220.1 352 191.6 352 160c0-70.59-57.42-128-128-128L32 32.01c-17.67 0-32 14.31-32 32s14.33 32 32 32h16v320H32c-17.67 0-32 14.31-32 32s14.33 32 32 32h224c70.58 0 128-57.41 128-128C384 305.3 358.6 264.8 321.1 242.4zM112 96.01H224c35.3 0 64 28.72 64 64s-28.7 64-64 64H112V96.01zM256 416H112v-128H256c35.3 0 64 28.71 64 63.1S291.3 416 256 416z\"\n ]\n};\nvar faBolt = {\n prefix: 'fas',\n iconName: 'bolt',\n icon: [\n 384,\n 512,\n [\n 9889,\n \"zap\"\n ],\n \"f0e7\",\n \"M240.5 224H352C365.3 224 377.3 232.3 381.1 244.7C386.6 257.2 383.1 271.3 373.1 280.1L117.1 504.1C105.8 513.9 89.27 514.7 77.19 505.9C65.1 497.1 60.7 481.1 66.59 467.4L143.5 288H31.1C18.67 288 6.733 279.7 2.044 267.3C-2.645 254.8 .8944 240.7 10.93 231.9L266.9 7.918C278.2-1.92 294.7-2.669 306.8 6.114C318.9 14.9 323.3 30.87 317.4 44.61L240.5 224z\"\n ]\n};\nvar faZap = faBolt;\nvar faBoltLightning = {\n prefix: 'fas',\n iconName: 'bolt-lightning',\n icon: [\n 384,\n 512,\n [],\n \"e0b7\",\n \"M381.2 172.8C377.1 164.9 368.9 160 360 160h-156.6l50.84-127.1c2.969-7.375 2.062-15.78-2.406-22.38S239.1 0 232 0h-176C43.97 0 33.81 8.906 32.22 20.84l-32 240C-.7179 267.7 1.376 274.6 5.938 279.8C10.5 285 17.09 288 24 288h146.3l-41.78 194.1c-2.406 11.22 3.469 22.56 14 27.09C145.6 511.4 148.8 512 152 512c7.719 0 15.22-3.75 19.81-10.44l208-304C384.8 190.2 385.4 180.7 381.2 172.8z\"\n ]\n};\nvar faBomb = {\n prefix: 'fas',\n iconName: 'bomb',\n icon: [\n 512,\n 512,\n [\n 128163\n ],\n \"f1e2\",\n \"M440.8 4.994C441.9 1.99 444.8 0 448 0C451.2 0 454.1 1.99 455.2 4.994L469.3 42.67L507 56.79C510 57.92 512 60.79 512 64C512 67.21 510 70.08 507 71.21L469.3 85.33L455.2 123C454.1 126 451.2 128 448 128C444.8 128 441.9 126 440.8 123L426.7 85.33L388.1 71.21C385.1 70.08 384 67.21 384 64C384 60.79 385.1 57.92 388.1 56.79L426.7 42.67L440.8 4.994zM289.4 97.37C301.9 84.88 322.1 84.88 334.6 97.37L363.3 126.1L380.7 108.7C386.9 102.4 397.1 102.4 403.3 108.7C409.6 114.9 409.6 125.1 403.3 131.3L385.9 148.7L414.6 177.4C427.1 189.9 427.1 210.1 414.6 222.6L403.8 233.5C411.7 255.5 416 279.3 416 304C416 418.9 322.9 512 208 512C93.12 512 0 418.9 0 304C0 189.1 93.12 96 208 96C232.7 96 256.5 100.3 278.5 108.3L289.4 97.37zM95.1 296C95.1 238.6 142.6 192 199.1 192H207.1C216.8 192 223.1 184.8 223.1 176C223.1 167.2 216.8 160 207.1 160H199.1C124.9 160 63.1 220.9 63.1 296V304C63.1 312.8 71.16 320 79.1 320C88.84 320 95.1 312.8 95.1 304V296z\"\n ]\n};\nvar faBone = {\n prefix: 'fas',\n iconName: 'bone',\n icon: [\n 576,\n 512,\n [\n 129460\n ],\n \"f5d7\",\n \"M534.9 267.5C560.1 280 576 305.8 576 334v4.387c0 35.55-23.49 68.35-58.24 75.88c-38.18 8.264-74.96-13.73-86.76-49.14c-.0352-.1035-.0684-.207-.1035-.3125C425.3 347.7 409.6 336 391.6 336H184.4c-17.89 0-33.63 11.57-39.23 28.56L145 365.1c-11.8 35.41-48.58 57.4-86.76 49.14C23.49 406.7 0 373.9 0 338.4v-4.387C0 305.8 15.88 280 41.13 267.5c9.375-4.75 9.375-18.25 0-23C15.88 232 0 206.3 0 178V173.6c0-35.55 23.49-68.35 58.24-75.88c38.18-8.264 74.99 13.82 86.79 49.23C150.7 164.1 166.4 176 184.4 176h207.2c17.89 0 33.63-11.57 39.23-28.56L431 146.9c11.8-35.41 48.58-57.4 86.76-49.14C552.5 105.3 576 138.1 576 173.6v4.387C576 206.3 560.1 232 534.9 244.5C525.5 249.3 525.5 262.8 534.9 267.5z\"\n ]\n};\nvar faBong = {\n prefix: 'fas',\n iconName: 'bong',\n icon: [\n 512,\n 512,\n [],\n \"f55c\",\n \"M334.5 512c23.12 0 44.38-12.62 56-32.63C406.8 451.2 416 418.8 416 384c0-36.13-10.11-69.75-27.49-98.63l43.5-43.37l9.376 9.375c6.25 6.25 16.38 6.25 22.63 0L475.3 240c6.25-6.25 6.25-16.38 0-22.62l-52.63-52.75c-6.25-6.25-16.38-6.25-22.63 0L388.6 176c-6.25 6.25-6.25 16.38 0 22.62L398 208l-39.38 39.38c-11.5-11.38-24.51-21.25-38.63-29.5l.0067-154.1h16c8.75 0 16-7.25 16-16L352 16.01C352 7.14 344.9 0 336 0L111.1 .1667c-8.75 0-15.99 7.11-15.99 15.99L96 48c0 8.875 7.126 16 16 16h16L128 217.9C70.63 251.1 32 313 32 384c0 34.75 9.252 67.25 25.5 95.38C69.13 499.4 90.38 512 113.5 512H334.5zM152 259.4l23.97-13.87V64.03L272 63.75l.0168 181.8l23.97 13.87C320.7 273.8 340 295.1 352.5 320H95.51C108 295.1 127.3 273.8 152 259.4z\"\n ]\n};\nvar faBook = {\n prefix: 'fas',\n iconName: 'book',\n icon: [\n 448,\n 512,\n [\n 128212\n ],\n \"f02d\",\n \"M448 336v-288C448 21.49 426.5 0 400 0H96C42.98 0 0 42.98 0 96v320c0 53.02 42.98 96 96 96h320c17.67 0 32-14.33 32-31.1c0-11.72-6.607-21.52-16-27.1v-81.36C441.8 362.8 448 350.2 448 336zM143.1 128h192C344.8 128 352 135.2 352 144C352 152.8 344.8 160 336 160H143.1C135.2 160 128 152.8 128 144C128 135.2 135.2 128 143.1 128zM143.1 192h192C344.8 192 352 199.2 352 208C352 216.8 344.8 224 336 224H143.1C135.2 224 128 216.8 128 208C128 199.2 135.2 192 143.1 192zM384 448H96c-17.67 0-32-14.33-32-32c0-17.67 14.33-32 32-32h288V448z\"\n ]\n};\nvar faBookAtlas = {\n prefix: 'fas',\n iconName: 'book-atlas',\n icon: [\n 448,\n 512,\n [\n \"atlas\"\n ],\n \"f558\",\n \"M240 97.25C232.3 104.8 219.3 131.8 216.6 176h46.88C260.8 131.8 247.8 104.8 240 97.25zM334.4 176c-5.25-31.25-25.62-57.13-53.25-70.38C288.8 124.6 293.8 149 295.3 176H334.4zM334.4 208h-39.13c-1.5 27-6.5 51.38-14.12 70.38C308.8 265.1 329.1 239.3 334.4 208zM263.4 208H216.5C219.3 252.3 232.3 279.3 240 286.8C247.8 279.3 260.8 252.3 263.4 208zM198.9 105.6C171.3 118.9 150.9 144.8 145.6 176h39.13C186.3 149 191.3 124.6 198.9 105.6zM448 336v-288C448 21.49 426.5 0 400 0H96C42.98 0 0 42.98 0 96v320c0 53.02 42.98 96 96 96h320c17.67 0 32-14.33 32-32c0-11.72-6.607-21.52-16-27.1v-81.36C441.8 362.8 448 350.2 448 336zM240 64c70.75 0 128 57.25 128 128s-57.25 128-128 128s-128-57.25-128-128S169.3 64 240 64zM384 448H96c-17.67 0-32-14.33-32-32c0-17.67 14.33-32 32-32h288V448zM198.9 278.4C191.3 259.4 186.3 235 184.8 208H145.6C150.9 239.3 171.3 265.1 198.9 278.4z\"\n ]\n};\nvar faAtlas = faBookAtlas;\nvar faBookBible = {\n prefix: 'fas',\n iconName: 'book-bible',\n icon: [\n 448,\n 512,\n [\n \"bible\"\n ],\n \"f647\",\n \"M448 336v-288C448 21.49 426.5 0 400 0H96C42.98 0 0 42.98 0 96v320c0 53.02 42.98 96 96 96h320c17.67 0 32-14.33 32-31.1c0-11.72-6.607-21.52-16-27.1v-81.36C441.8 362.8 448 350.2 448 336zM144 144c0-8.875 7.125-15.1 16-15.1L208 128V80c0-8.875 7.125-15.1 16-15.1l32 .0009c8.875 0 16 7.12 16 15.1V128L320 128c8.875 0 16 7.121 16 15.1v32c0 8.875-7.125 16-16 16L272 192v112c0 8.875-7.125 16-16 16l-32-.0002c-8.875 0-16-7.127-16-16V192L160 192c-8.875 0-16-7.127-16-16V144zM384 448H96c-17.67 0-32-14.33-32-32c0-17.67 14.33-32 32-32h288V448z\"\n ]\n};\nvar faBible = faBookBible;\nvar faBookJournalWhills = {\n prefix: 'fas',\n iconName: 'book-journal-whills',\n icon: [\n 448,\n 512,\n [\n \"journal-whills\"\n ],\n \"f66a\",\n \"M448 336v-288C448 21.49 426.5 0 400 0H96C42.98 0 0 42.98 0 96v320c0 53.02 42.98 96 96 96h320c17.67 0 32-14.33 32-31.1c0-11.72-6.607-21.52-16-27.1v-81.36C441.8 362.8 448 350.2 448 336zM133.1 160.4l21.25 21.25c3.125 3.125 8.125 3.125 11.25 0s3.125-8.125 0-11.25l-26.38-26.5c10-20.75 26.25-38 46.38-49.25c-17 27.12-11 62.75 14 82.63C185.5 192 180.5 213.1 186.5 232.5c5.875 19.38 22 34.13 41.88 38.25l1.375-32.75L219.4 245.1C218.8 245.5 217.9 245.8 217.1 245.8c-1 0-2-.375-2.75-1c-.75-.875-1.25-1.875-1.25-3c0-.625 .25-1.375 .5-2L222.3 225.5l-18-3.75c-1.75-.375-3.125-2.125-3.125-4s1.375-3.5 3.125-3.875l18-3.75L213.6 195.9C212.8 194.3 213 192.1 214.4 190.9s3.5-1.5 5-.375l12 8.125L236 87.88C236.1 85.63 237.9 84 240 84s3.875 1.625 4 3.875l4.75 112.3l14.12-9.625c.625-.5 1.5-.625 2.25-.75c1.5 0 2.75 .75 3.5 2s.625 2.875-.125 4.125L260 210.1l17.1 3.75c1.75 .375 3.125 2 3.125 3.875s-1.375 3.625-3.125 4L260 225.4l8.5 14.38c.75 1.25 .875 2.75 .125 4s-2 2-3.5 2c-.75 0-1.625-.25-2.25-.625L250.3 236.5l1.375 34.25c19.88-4.125 36-18.88 41.88-38.25c6-19.38 1-40.63-13.12-55.25c25-19.88 31-55.5 14-82.63c20.25 11.25 36.38 28.5 46.38 49.25l-26.38 26.5c-3.125 3.125-3.125 8.125 0 11.25s8.125 3.125 11.25 0l21.25-21.25C349.9 170.5 352 181 352 192c0 .5-.125 1-.125 1.5l-37.13 32.5C313.1 227.6 312.1 229.8 312 232c.125 1.875 .7496 3.75 1.1 5.25C315.6 238.9 317.8 239.9 320 240c1.1 0 3.875-.7499 5.25-1.1l23.62-20.63C337.3 267 293.1 304 240 304S142.8 267 131.1 217.4l23.62 20.63C156.3 239.3 158.1 239.9 160 240c3.375 0 6.25-2.125 7.5-5.125c1.125-3.125 .25-6.75-2.25-8.875L128.1 193.5C128.1 193 128 192.5 128 192C128 181 130.1 170.5 133.1 160.4zM384 448H96c-17.67 0-32-14.33-32-32s14.33-32 32-32h288V448z\"\n ]\n};\nvar faJournalWhills = faBookJournalWhills;\nvar faBookMedical = {\n prefix: 'fas',\n iconName: 'book-medical',\n icon: [\n 448,\n 512,\n [],\n \"f7e6\",\n \"M448 336v-288C448 21.49 426.5 0 400 0H96C42.98 0 0 42.98 0 96v320c0 53.02 42.98 96 96 96h320c17.67 0 32-14.33 32-31.1c0-11.72-6.607-21.52-16-27.1v-81.36C441.8 362.8 448 350.2 448 336zM128 166c0-8.838 7.164-16 16-16h53.1V96c0-8.838 7.164-16 16-16h52c8.836 0 16 7.162 16 16v54H336c8.836 0 16 7.162 16 16v52c0 8.836-7.164 16-16 16h-54V288c0 8.836-7.164 16-16 16h-52c-8.836 0-16-7.164-16-16V234H144c-8.836 0-16-7.164-16-16V166zM384 448H96c-17.67 0-32-14.33-32-32c0-17.67 14.33-32 32-32h288V448z\"\n ]\n};\nvar faBookOpen = {\n prefix: 'fas',\n iconName: 'book-open',\n icon: [\n 576,\n 512,\n [\n 128366,\n 128214\n ],\n \"f518\",\n \"M144.3 32.04C106.9 31.29 63.7 41.44 18.6 61.29c-11.42 5.026-18.6 16.67-18.6 29.15l0 357.6c0 11.55 11.99 19.55 22.45 14.65c126.3-59.14 219.8 11 223.8 14.01C249.1 478.9 252.5 480 256 480c12.4 0 16-11.38 16-15.98V80.04c0-5.203-2.531-10.08-6.781-13.08C263.3 65.58 216.7 33.35 144.3 32.04zM557.4 61.29c-45.11-19.79-88.48-29.61-125.7-29.26c-72.44 1.312-118.1 33.55-120.9 34.92C306.5 69.96 304 74.83 304 80.04v383.1C304 468.4 307.5 480 320 480c3.484 0 6.938-1.125 9.781-3.328c3.925-3.018 97.44-73.16 223.8-14c10.46 4.896 22.45-3.105 22.45-14.65l.0001-357.6C575.1 77.97 568.8 66.31 557.4 61.29z\"\n ]\n};\nvar faBookOpenReader = {\n prefix: 'fas',\n iconName: 'book-open-reader',\n icon: [\n 512,\n 512,\n [\n \"book-reader\"\n ],\n \"f5da\",\n \"M0 219.2v212.5c0 14.25 11.62 26.25 26.5 27C75.32 461.2 180.2 471.3 240 511.9V245.2C181.4 205.5 79.99 194.8 29.84 192C13.59 191.1 0 203.6 0 219.2zM482.2 192c-50.09 2.848-151.3 13.47-209.1 53.09C272.1 245.2 272 245.3 272 245.5v266.5c60.04-40.39 164.7-50.76 213.5-53.28C500.4 457.9 512 445.9 512 431.7V219.2C512 203.6 498.4 191.1 482.2 192zM352 96c0-53-43-96-96-96S160 43 160 96s43 96 96 96S352 149 352 96z\"\n ]\n};\nvar faBookReader = faBookOpenReader;\nvar faBookQuran = {\n prefix: 'fas',\n iconName: 'book-quran',\n icon: [\n 448,\n 512,\n [\n \"quran\"\n ],\n \"f687\",\n \"M352 0H48C21.49 0 0 21.49 0 48v288c0 14.16 6.246 26.76 16 35.54v81.36C6.607 458.5 0 468.3 0 479.1C0 497.7 14.33 512 31.1 512h320c53.02 0 96-42.98 96-96V96C448 42.98 405 0 352 0zM324.8 170.4c3.006 .4297 4.295 4.154 2.004 6.301L306.2 196.9l4.869 28.5c.4297 2.434-1.576 4.439-3.725 4.439c-.5723 0-1.145-.1445-1.719-.4297L280 215.9l-25.63 13.46c-.5723 .2852-1.145 .4297-1.719 .4297c-2.146 0-4.152-2.006-3.723-4.439l4.869-28.5l-20.62-20.19c-2.291-2.146-1.002-5.871 2.006-6.301l28.64-4.152l12.89-25.92C277.3 138.9 278.7 138.2 280 138.2s2.721 .7168 3.295 2.148l12.89 25.92L324.8 170.4zM216 72c23.66 0 46.61 6.953 66.36 20.09c3.219 2.141 4.438 6.281 2.906 9.844c-1.547 3.547-5.453 5.562-9.172 4.594C268.8 104.8 262.2 104 256 104C207.5 104 168 143.5 168 192S207.5 280 256 280c6.234 0 12.81-.8281 20.09-2.531c3.719-.9687 7.625 1.047 9.172 4.594c1.531 3.562 .3125 7.703-2.906 9.844C262.6 305 239.7 312 216 312C149.8 312 96 258.2 96 192S149.8 72 216 72zM352 448H64v-64h288c17.67 0 32 14.33 32 32C384 433.7 369.7 448 352 448z\"\n ]\n};\nvar faQuran = faBookQuran;\nvar faBookSkull = {\n prefix: 'fas',\n iconName: 'book-skull',\n icon: [\n 448,\n 512,\n [\n \"book-dead\"\n ],\n \"f6b7\",\n \"M272 144C280.8 144 288 136.8 288 128s-7.25-16-16-16S256 119.3 256 128S263.3 144 272 144zM448 336v-288C448 21.49 426.5 0 400 0H96C42.98 0 0 42.98 0 96v320c0 53.02 42.98 96 96 96h320c17.67 0 32-14.33 32-31.1c0-11.72-6.607-21.52-16-27.1v-81.36C441.8 362.8 448 350.2 448 336zM240 64C284.3 64 320 92.75 320 128c0 20.88-12.75 39.25-32 50.88V192c0 8.75-7.25 16-16 16h-64C199.3 208 192 200.8 192 192V178.9C172.8 167.3 160 148.9 160 128C160 92.75 195.8 64 240 64zM121.7 238.7c-8.125-3.484-11.91-12.89-8.438-21.02c3.469-8.094 12.94-11.86 21-8.422L240 254.5l105.7-45.21c8.031-3.438 17.53 .3281 21 8.422c3.469 8.125-.3125 17.53-8.438 21.02l-77.58 33.18l77.58 33.18c8.125 3.484 11.91 12.89 8.438 21.02C364.1 332.2 358.2 335.8 352 335.8c-2.094 0-4.25-.4062-6.281-1.281L240 289.3l-105.7 45.21C132.3 335.4 130.1 335.8 128 335.8c-6.219 0-12.12-3.641-14.72-9.703C109.8 317.1 113.6 308.6 121.7 305.1l77.58-33.18L121.7 238.7zM384 448H96c-17.67 0-32-14.33-32-32c0-17.67 14.33-32 32-32h288V448zM208 144C216.8 144 224 136.8 224 128S216.8 112 208 112S192 119.3 192 128S199.3 144 208 144z\"\n ]\n};\nvar faBookDead = faBookSkull;\nvar faBookmark = {\n prefix: 'fas',\n iconName: 'bookmark',\n icon: [\n 384,\n 512,\n [\n 61591,\n 128278\n ],\n \"f02e\",\n \"M384 48V512l-192-112L0 512V48C0 21.5 21.5 0 48 0h288C362.5 0 384 21.5 384 48z\"\n ]\n};\nvar faBorderAll = {\n prefix: 'fas',\n iconName: 'border-all',\n icon: [\n 448,\n 512,\n [],\n \"f84c\",\n \"M384 32C419.3 32 448 60.65 448 96V416C448 451.3 419.3 480 384 480H64C28.65 480 0 451.3 0 416V96C0 60.65 28.65 32 64 32H384zM384 96H256V224H384V96zM384 288H256V416H384V288zM192 224V96H64V224H192zM64 416H192V288H64V416z\"\n ]\n};\nvar faBorderNone = {\n prefix: 'fas',\n iconName: 'border-none',\n icon: [\n 448,\n 512,\n [],\n \"f850\",\n \"M64 448C64 465.7 49.67 480 32 480C14.33 480 0 465.7 0 448C0 430.3 14.33 416 32 416C49.67 416 64 430.3 64 448zM128 480C110.3 480 96 465.7 96 448C96 430.3 110.3 416 128 416C145.7 416 160 430.3 160 448C160 465.7 145.7 480 128 480zM128 96C110.3 96 96 81.67 96 64C96 46.33 110.3 32 128 32C145.7 32 160 46.33 160 64C160 81.67 145.7 96 128 96zM160 256C160 273.7 145.7 288 128 288C110.3 288 96 273.7 96 256C96 238.3 110.3 224 128 224C145.7 224 160 238.3 160 256zM320 480C302.3 480 288 465.7 288 448C288 430.3 302.3 416 320 416C337.7 416 352 430.3 352 448C352 465.7 337.7 480 320 480zM352 64C352 81.67 337.7 96 320 96C302.3 96 288 81.67 288 64C288 46.33 302.3 32 320 32C337.7 32 352 46.33 352 64zM320 288C302.3 288 288 273.7 288 256C288 238.3 302.3 224 320 224C337.7 224 352 238.3 352 256C352 273.7 337.7 288 320 288zM256 448C256 465.7 241.7 480 224 480C206.3 480 192 465.7 192 448C192 430.3 206.3 416 224 416C241.7 416 256 430.3 256 448zM224 96C206.3 96 192 81.67 192 64C192 46.33 206.3 32 224 32C241.7 32 256 46.33 256 64C256 81.67 241.7 96 224 96zM256 256C256 273.7 241.7 288 224 288C206.3 288 192 273.7 192 256C192 238.3 206.3 224 224 224C241.7 224 256 238.3 256 256zM416 480C398.3 480 384 465.7 384 448C384 430.3 398.3 416 416 416C433.7 416 448 430.3 448 448C448 465.7 433.7 480 416 480zM416 96C398.3 96 384 81.67 384 64C384 46.33 398.3 32 416 32C433.7 32 448 46.33 448 64C448 81.67 433.7 96 416 96zM64 64C64 81.67 49.67 96 32 96C14.33 96 0 81.67 0 64C0 46.33 14.33 32 32 32C49.67 32 64 46.33 64 64zM416 288C398.3 288 384 273.7 384 256C384 238.3 398.3 224 416 224C433.7 224 448 238.3 448 256C448 273.7 433.7 288 416 288zM64 256C64 273.7 49.67 288 32 288C14.33 288 0 273.7 0 256C0 238.3 14.33 224 32 224C49.67 224 64 238.3 64 256zM224 384C206.3 384 192 369.7 192 352C192 334.3 206.3 320 224 320C241.7 320 256 334.3 256 352C256 369.7 241.7 384 224 384zM448 352C448 369.7 433.7 384 416 384C398.3 384 384 369.7 384 352C384 334.3 398.3 320 416 320C433.7 320 448 334.3 448 352zM32 384C14.33 384 0 369.7 0 352C0 334.3 14.33 320 32 320C49.67 320 64 334.3 64 352C64 369.7 49.67 384 32 384zM448 160C448 177.7 433.7 192 416 192C398.3 192 384 177.7 384 160C384 142.3 398.3 128 416 128C433.7 128 448 142.3 448 160zM32 192C14.33 192 0 177.7 0 160C0 142.3 14.33 128 32 128C49.67 128 64 142.3 64 160C64 177.7 49.67 192 32 192zM256 160C256 177.7 241.7 192 224 192C206.3 192 192 177.7 192 160C192 142.3 206.3 128 224 128C241.7 128 256 142.3 256 160z\"\n ]\n};\nvar faBorderTopLeft = {\n prefix: 'fas',\n iconName: 'border-top-left',\n icon: [\n 448,\n 512,\n [\n \"border-style\"\n ],\n \"f853\",\n \"M0 112C0 67.82 35.82 32 80 32H416C433.7 32 448 46.33 448 64C448 81.67 433.7 96 416 96H80C71.16 96 64 103.2 64 112V448C64 465.7 49.67 480 32 480C14.33 480 0 465.7 0 448V112zM128 480C110.3 480 96 465.7 96 448C96 430.3 110.3 416 128 416C145.7 416 160 430.3 160 448C160 465.7 145.7 480 128 480zM320 480C302.3 480 288 465.7 288 448C288 430.3 302.3 416 320 416C337.7 416 352 430.3 352 448C352 465.7 337.7 480 320 480zM256 448C256 465.7 241.7 480 224 480C206.3 480 192 465.7 192 448C192 430.3 206.3 416 224 416C241.7 416 256 430.3 256 448zM416 480C398.3 480 384 465.7 384 448C384 430.3 398.3 416 416 416C433.7 416 448 430.3 448 448C448 465.7 433.7 480 416 480zM416 288C398.3 288 384 273.7 384 256C384 238.3 398.3 224 416 224C433.7 224 448 238.3 448 256C448 273.7 433.7 288 416 288zM448 352C448 369.7 433.7 384 416 384C398.3 384 384 369.7 384 352C384 334.3 398.3 320 416 320C433.7 320 448 334.3 448 352zM416 192C398.3 192 384 177.7 384 160C384 142.3 398.3 128 416 128C433.7 128 448 142.3 448 160C448 177.7 433.7 192 416 192z\"\n ]\n};\nvar faBorderStyle = faBorderTopLeft;\nvar faBowlingBall = {\n prefix: 'fas',\n iconName: 'bowling-ball',\n icon: [\n 512,\n 512,\n [],\n \"f436\",\n \"M256 0C114.6 0 0 114.6 0 256s114.6 256 256 256s256-114.6 256-256S397.4 0 256 0zM144 208c-17.7 0-32-14.25-32-32s14.3-32 32-32s32 14.25 32 32S161.7 208 144 208zM240 80c17.66 0 31.95 14.25 31.95 32s-14.29 32-31.95 32s-32.05-14.25-32.05-32S222.4 80 240 80zM240 240c-17.7 0-32-14.25-32-32s14.3-32 32-32s32 14.25 32 32S257.7 240 240 240z\"\n ]\n};\nvar faBox = {\n prefix: 'fas',\n iconName: 'box',\n icon: [\n 448,\n 512,\n [\n 128230\n ],\n \"f466\",\n \"M50.73 58.53C58.86 42.27 75.48 32 93.67 32H208V160H0L50.73 58.53zM240 160V32H354.3C372.5 32 389.1 42.27 397.3 58.53L448 160H240zM448 416C448 451.3 419.3 480 384 480H64C28.65 480 0 451.3 0 416V192H448V416z\"\n ]\n};\nvar faBoxArchive = {\n prefix: 'fas',\n iconName: 'box-archive',\n icon: [\n 512,\n 512,\n [\n \"archive\"\n ],\n \"f187\",\n \"M32 432C32 458.5 53.49 480 80 480h352c26.51 0 48-21.49 48-48V160H32V432zM160 236C160 229.4 165.4 224 172 224h168C346.6 224 352 229.4 352 236v8C352 250.6 346.6 256 340 256h-168C165.4 256 160 250.6 160 244V236zM480 32H32C14.31 32 0 46.31 0 64v48C0 120.8 7.188 128 16 128h480C504.8 128 512 120.8 512 112V64C512 46.31 497.7 32 480 32z\"\n ]\n};\nvar faArchive = faBoxArchive;\nvar faBoxOpen = {\n prefix: 'fas',\n iconName: 'box-open',\n icon: [\n 640,\n 512,\n [],\n \"f49e\",\n \"M75.23 33.4L320 63.1L564.8 33.4C571.5 32.56 578 36.06 581.1 42.12L622.8 125.5C631.7 143.4 622.2 165.1 602.9 170.6L439.6 217.3C425.7 221.2 410.8 215.4 403.4 202.1L320 63.1L236.6 202.1C229.2 215.4 214.3 221.2 200.4 217.3L37.07 170.6C17.81 165.1 8.283 143.4 17.24 125.5L58.94 42.12C61.97 36.06 68.5 32.56 75.23 33.4H75.23zM321.1 128L375.9 219.4C390.8 244.2 420.5 255.1 448.4 248L576 211.6V378.5C576 400.5 561 419.7 539.6 425.1L335.5 476.1C325.3 478.7 314.7 478.7 304.5 476.1L100.4 425.1C78.99 419.7 64 400.5 64 378.5V211.6L191.6 248C219.5 255.1 249.2 244.2 264.1 219.4L318.9 128H321.1z\"\n ]\n};\nvar faBoxTissue = {\n prefix: 'fas',\n iconName: 'box-tissue',\n icon: [\n 512,\n 512,\n [],\n \"e05b\",\n \"M384 288l64-192h-109.4C308.4 96 281.6 76.66 272 48C262.4 19.33 235.6 0 205.4 0H64l64 288H384zM0 480c0 17.67 14.33 32 32 32h448c17.67 0 32-14.33 32-32v-64H0V480zM480 224h-40.94l-21.33 64H432C440.8 288 448 295.2 448 304S440.8 320 432 320h-352C71.16 320 64 312.8 64 304S71.16 288 80 288h15.22l-14.22-64H32C14.33 224 0 238.3 0 256v128h512V256C512 238.3 497.7 224 480 224z\"\n ]\n};\nvar faBoxesStacked = {\n prefix: 'fas',\n iconName: 'boxes-stacked',\n icon: [\n 576,\n 512,\n [\n 62625,\n \"boxes\",\n \"boxes-alt\"\n ],\n \"f468\",\n \"M160 48C160 21.49 181.5 0 208 0H256V80C256 88.84 263.2 96 272 96H304C312.8 96 320 88.84 320 80V0H368C394.5 0 416 21.49 416 48V176C416 202.5 394.5 224 368 224H208C181.5 224 160 202.5 160 176V48zM96 288V368C96 376.8 103.2 384 112 384H144C152.8 384 160 376.8 160 368V288H208C234.5 288 256 309.5 256 336V464C256 490.5 234.5 512 208 512H48C21.49 512 0 490.5 0 464V336C0 309.5 21.49 288 48 288H96zM416 288V368C416 376.8 423.2 384 432 384H464C472.8 384 480 376.8 480 368V288H528C554.5 288 576 309.5 576 336V464C576 490.5 554.5 512 528 512H368C341.5 512 320 490.5 320 464V336C320 309.5 341.5 288 368 288H416z\"\n ]\n};\nvar faBoxes = faBoxesStacked;\nvar faBoxesAlt = faBoxesStacked;\nvar faBraille = {\n prefix: 'fas',\n iconName: 'braille',\n icon: [\n 640,\n 512,\n [],\n \"f2a1\",\n \"M128 96C128 131.3 99.35 160 64 160C28.65 160 0 131.3 0 96C0 60.65 28.65 32 64 32C99.35 32 128 60.65 128 96zM160 256C160 220.7 188.7 192 224 192C259.3 192 288 220.7 288 256C288 291.3 259.3 320 224 320C188.7 320 160 291.3 160 256zM224 272C232.8 272 240 264.8 240 256C240 247.2 232.8 240 224 240C215.2 240 208 247.2 208 256C208 264.8 215.2 272 224 272zM128 416C128 451.3 99.35 480 64 480C28.65 480 0 451.3 0 416C0 380.7 28.65 352 64 352C99.35 352 128 380.7 128 416zM64 400C55.16 400 48 407.2 48 416C48 424.8 55.16 432 64 432C72.84 432 80 424.8 80 416C80 407.2 72.84 400 64 400zM288 416C288 451.3 259.3 480 224 480C188.7 480 160 451.3 160 416C160 380.7 188.7 352 224 352C259.3 352 288 380.7 288 416zM224 400C215.2 400 208 407.2 208 416C208 424.8 215.2 432 224 432C232.8 432 240 424.8 240 416C240 407.2 232.8 400 224 400zM0 256C0 220.7 28.65 192 64 192C99.35 192 128 220.7 128 256C128 291.3 99.35 320 64 320C28.65 320 0 291.3 0 256zM160 96C160 60.65 188.7 32 224 32C259.3 32 288 60.65 288 96C288 131.3 259.3 160 224 160C188.7 160 160 131.3 160 96zM480 96C480 131.3 451.3 160 416 160C380.7 160 352 131.3 352 96C352 60.65 380.7 32 416 32C451.3 32 480 60.65 480 96zM640 96C640 131.3 611.3 160 576 160C540.7 160 512 131.3 512 96C512 60.65 540.7 32 576 32C611.3 32 640 60.65 640 96zM576 80C567.2 80 560 87.16 560 96C560 104.8 567.2 112 576 112C584.8 112 592 104.8 592 96C592 87.16 584.8 80 576 80zM512 256C512 220.7 540.7 192 576 192C611.3 192 640 220.7 640 256C640 291.3 611.3 320 576 320C540.7 320 512 291.3 512 256zM576 272C584.8 272 592 264.8 592 256C592 247.2 584.8 240 576 240C567.2 240 560 247.2 560 256C560 264.8 567.2 272 576 272zM640 416C640 451.3 611.3 480 576 480C540.7 480 512 451.3 512 416C512 380.7 540.7 352 576 352C611.3 352 640 380.7 640 416zM576 400C567.2 400 560 407.2 560 416C560 424.8 567.2 432 576 432C584.8 432 592 424.8 592 416C592 407.2 584.8 400 576 400zM352 256C352 220.7 380.7 192 416 192C451.3 192 480 220.7 480 256C480 291.3 451.3 320 416 320C380.7 320 352 291.3 352 256zM416 272C424.8 272 432 264.8 432 256C432 247.2 424.8 240 416 240C407.2 240 400 247.2 400 256C400 264.8 407.2 272 416 272zM480 416C480 451.3 451.3 480 416 480C380.7 480 352 451.3 352 416C352 380.7 380.7 352 416 352C451.3 352 480 380.7 480 416zM416 400C407.2 400 400 407.2 400 416C400 424.8 407.2 432 416 432C424.8 432 432 424.8 432 416C432 407.2 424.8 400 416 400z\"\n ]\n};\nvar faBrain = {\n prefix: 'fas',\n iconName: 'brain',\n icon: [\n 512,\n 512,\n [\n 129504\n ],\n \"f5dc\",\n \"M184 0C214.9 0 240 25.07 240 56V456C240 486.9 214.9 512 184 512C155.1 512 131.3 490.1 128.3 461.9C123.1 463.3 117.6 464 112 464C76.65 464 48 435.3 48 400C48 392.6 49.27 385.4 51.59 378.8C21.43 367.4 0 338.2 0 304C0 272.1 18.71 244.5 45.77 231.7C37.15 220.8 32 206.1 32 192C32 161.3 53.59 135.7 82.41 129.4C80.84 123.9 80 118 80 112C80 82.06 100.6 56.92 128.3 49.93C131.3 21.86 155.1 0 184 0zM383.7 49.93C411.4 56.92 432 82.06 432 112C432 118 431.2 123.9 429.6 129.4C458.4 135.7 480 161.3 480 192C480 206.1 474.9 220.8 466.2 231.7C493.3 244.5 512 272.1 512 304C512 338.2 490.6 367.4 460.4 378.8C462.7 385.4 464 392.6 464 400C464 435.3 435.3 464 400 464C394.4 464 388.9 463.3 383.7 461.9C380.7 490.1 356.9 512 328 512C297.1 512 272 486.9 272 456V56C272 25.07 297.1 0 328 0C356.9 0 380.7 21.86 383.7 49.93z\"\n ]\n};\nvar faBrazilianRealSign = {\n prefix: 'fas',\n iconName: 'brazilian-real-sign',\n icon: [\n 512,\n 512,\n [],\n \"e46c\",\n \"M400 .0003C417.7 .0003 432 14.33 432 32V50.22C444.5 52.52 456.7 56.57 468.2 62.3L478.3 67.38C494.1 75.28 500.5 94.5 492.6 110.3C484.7 126.1 465.5 132.5 449.7 124.6L439.5 119.5C429.6 114.6 418.7 112 407.6 112H405.9C376.1 112 352 136.1 352 165.9C352 187.9 365.4 207.7 385.9 215.9L437.9 236.7C482.7 254.6 512 297.9 512 346.1V349.5C512 400.7 478.4 444.1 432 458.7V480C432 497.7 417.7 512 400 512C382.3 512 368 497.7 368 480V460.6C352.1 457.1 338.6 450.9 325.7 442.3L302.2 426.6C287.5 416.8 283.6 396.1 293.4 382.2C303.2 367.5 323 363.6 337.8 373.4L361.2 389C371.9 396.2 384.6 400 397.5 400C425.4 400 448 377.4 448 349.5V346.1C448 324.1 434.6 304.3 414.1 296.1L362.1 275.3C317.3 257.4 288 214.1 288 165.9C288 114 321.5 69.99 368 54.21V32C368 14.33 382.3 0 400 0L400 .0003zM.0003 64C.0003 46.33 14.33 32 32 32H112C191.5 32 256 96.47 256 176C256 234.8 220.8 285.3 170.3 307.7L221.7 436.1C228.3 452.5 220.3 471.1 203.9 477.7C187.5 484.3 168.9 476.3 162.3 459.9L106.3 320H64V448C64 465.7 49.67 480 32 480C14.33 480 0 465.7 0 448L.0003 64zM64 256H112C156.2 256 192 220.2 192 176C192 131.8 156.2 96 112 96H64V256z\"\n ]\n};\nvar faBreadSlice = {\n prefix: 'fas',\n iconName: 'bread-slice',\n icon: [\n 512,\n 512,\n [],\n \"f7ec\",\n \"M512 176.1C512 203 490.4 224 455.1 224H448v224c0 17.67-14.33 32-32 32H96c-17.67 0-32-14.33-32-32V224H56.89C21.56 224 0 203 0 176.1C0 112 96 32 256 32S512 112 512 176.1z\"\n ]\n};\nvar faBriefcase = {\n prefix: 'fas',\n iconName: 'briefcase',\n icon: [\n 512,\n 512,\n [\n 128188\n ],\n \"f0b1\",\n \"M320 336c0 8.844-7.156 16-16 16h-96C199.2 352 192 344.8 192 336V288H0v144C0 457.6 22.41 480 48 480h416c25.59 0 48-22.41 48-48V288h-192V336zM464 96H384V48C384 22.41 361.6 0 336 0h-160C150.4 0 128 22.41 128 48V96H48C22.41 96 0 118.4 0 144V256h512V144C512 118.4 489.6 96 464 96zM336 96h-160V48h160V96z\"\n ]\n};\nvar faBriefcaseMedical = {\n prefix: 'fas',\n iconName: 'briefcase-medical',\n icon: [\n 512,\n 512,\n [],\n \"f469\",\n \"M464 96H384V48C384 21.5 362.5 0 336 0h-160C149.5 0 128 21.5 128 48V96H48C21.5 96 0 117.5 0 144v288C0 458.5 21.5 480 48 480h416c26.5 0 48-21.5 48-48v-288C512 117.5 490.5 96 464 96zM176 48h160V96h-160V48zM368 314c0 8.836-7.164 16-16 16h-54V384c0 8.836-7.164 16-15.1 16h-52c-8.835 0-16-7.164-16-16v-53.1H160c-8.836 0-16-7.164-16-16v-52c0-8.838 7.164-16 16-16h53.1V192c0-8.838 7.165-16 16-16h52c8.836 0 15.1 7.162 15.1 16v54H352c8.836 0 16 7.162 16 16V314z\"\n ]\n};\nvar faBroom = {\n prefix: 'fas',\n iconName: 'broom',\n icon: [\n 640,\n 512,\n [\n 129529\n ],\n \"f51a\",\n \"M93.13 257.7C71.25 275.1 53 313.5 38.63 355.1L99 333.1c5.75-2.125 10.62 4.749 6.625 9.499L11 454.7C3.75 486.1 0 510.2 0 510.2s206.6 13.62 266.6-34.12c60-47.87 76.63-150.1 76.63-150.1L256.5 216.7C256.5 216.7 153.1 209.1 93.13 257.7zM633.2 12.34c-10.84-13.91-30.91-16.45-44.91-5.624l-225.7 175.6l-34.99-44.06C322.5 131.9 312.5 133.1 309 140.5L283.8 194.1l86.75 109.2l58.75-12.5c8-1.625 11.38-11.12 6.375-17.5l-33.19-41.79l225.2-175.2C641.6 46.38 644.1 26.27 633.2 12.34z\"\n ]\n};\nvar faBroomBall = {\n prefix: 'fas',\n iconName: 'broom-ball',\n icon: [\n 640,\n 512,\n [\n \"quidditch\",\n \"quidditch-broom-ball\"\n ],\n \"f458\",\n \"M495.1 351.1c-44.18 0-79.1 35.72-79.1 79.91c0 44.18 35.82 80.09 79.1 80.09s79.1-35.91 79.1-80.09C575.1 387.7 540.2 351.1 495.1 351.1zM242.7 216.4c-30.16 0-102.9 4.15-149.4 41.34c-22 17.5-40.25 55.75-54.63 97.5l60.38-22.12c.7363-.2715 1.46-.3967 2.151-.3967c3.33 0 5.935 2.885 5.935 6.039c0 1.301-.4426 2.647-1.462 3.856L11 454.7C3.75 487.1 0 510.2 0 510.2S27.07 512 64.45 512c65.94 0 163.1-5.499 202.2-35.89c60-47.75 76.63-150.1 76.63-150.1l-86.75-109.2C256.5 216.7 251.4 216.4 242.7 216.4zM607.1 .0074c-6.863 0-13.78 2.192-19.62 6.719L362.7 182.3l-29.88-37.67c-3.248-4.094-7.892-6.058-12.5-6.058c-5.891 0-11.73 3.204-14.54 9.26L283.8 195.1l86.75 109.1l50.88-10.72c7.883-1.66 12.72-8.546 12.72-15.71c0-3.412-1.096-6.886-3.478-9.89l-28.16-35.5l225.2-175.2c8.102-6.312 12.35-15.75 12.35-25.29C640 14.94 626.3 .0074 607.1 .0074z\"\n ]\n};\nvar faQuidditch = faBroomBall;\nvar faQuidditchBroomBall = faBroomBall;\nvar faBrush = {\n prefix: 'fas',\n iconName: 'brush',\n icon: [\n 384,\n 512,\n [],\n \"f55d\",\n \"M224 0H336C362.5 0 384 21.49 384 48V256H0V48C0 21.49 21.49 0 48 0H64L96 64L128 0H160L192 64L224 0zM384 288V320C384 355.3 355.3 384 320 384H256V448C256 483.3 227.3 512 192 512C156.7 512 128 483.3 128 448V384H64C28.65 384 0 355.3 0 320V288H384zM192 464C200.8 464 208 456.8 208 448C208 439.2 200.8 432 192 432C183.2 432 176 439.2 176 448C176 456.8 183.2 464 192 464z\"\n ]\n};\nvar faBug = {\n prefix: 'fas',\n iconName: 'bug',\n icon: [\n 512,\n 512,\n [],\n \"f188\",\n \"M352 96V99.56C352 115.3 339.3 128 323.6 128H188.4C172.7 128 159.1 115.3 159.1 99.56V96C159.1 42.98 202.1 0 255.1 0C309 0 352 42.98 352 96zM41.37 105.4C53.87 92.88 74.13 92.88 86.63 105.4L150.6 169.4C151.3 170 151.9 170.7 152.5 171.4C166.8 164.1 182.9 160 199.1 160H312C329.1 160 345.2 164.1 359.5 171.4C360.1 170.7 360.7 170 361.4 169.4L425.4 105.4C437.9 92.88 458.1 92.88 470.6 105.4C483.1 117.9 483.1 138.1 470.6 150.6L406.6 214.6C405.1 215.3 405.3 215.9 404.6 216.5C410.7 228.5 414.6 241.9 415.7 256H480C497.7 256 512 270.3 512 288C512 305.7 497.7 320 480 320H416C416 344.6 410.5 367.8 400.6 388.6C402.7 389.9 404.8 391.5 406.6 393.4L470.6 457.4C483.1 469.9 483.1 490.1 470.6 502.6C458.1 515.1 437.9 515.1 425.4 502.6L362.3 439.6C337.8 461.4 306.5 475.8 272 479.2V240C272 231.2 264.8 224 255.1 224C247.2 224 239.1 231.2 239.1 240V479.2C205.5 475.8 174.2 461.4 149.7 439.6L86.63 502.6C74.13 515.1 53.87 515.1 41.37 502.6C28.88 490.1 28.88 469.9 41.37 457.4L105.4 393.4C107.2 391.5 109.3 389.9 111.4 388.6C101.5 367.8 96 344.6 96 320H32C14.33 320 0 305.7 0 288C0 270.3 14.33 256 32 256H96.3C97.38 241.9 101.3 228.5 107.4 216.5C106.7 215.9 106 215.3 105.4 214.6L41.37 150.6C28.88 138.1 28.88 117.9 41.37 105.4H41.37z\"\n ]\n};\nvar faBugSlash = {\n prefix: 'fas',\n iconName: 'bug-slash',\n icon: [\n 640,\n 512,\n [],\n \"e490\",\n \"M239.1 162.8C247.7 160.1 255.7 160 264 160H376C393.1 160 409.2 164.1 423.5 171.4C424.1 170.7 424.7 170 425.4 169.4L489.4 105.4C501.9 92.88 522.1 92.88 534.6 105.4C547.1 117.9 547.1 138.1 534.6 150.6L470.6 214.6C469.1 215.3 469.3 215.9 468.6 216.5C474.7 228.5 478.6 241.9 479.7 256H544C561.7 256 576 270.3 576 288C576 305.7 561.7 320 544 320H480C480 329.9 479.1 339.5 477.4 348.9L630.8 469.1C641.2 477.3 643.1 492.4 634.9 502.8C626.7 513.2 611.6 515.1 601.2 506.9L9.196 42.89C-1.236 34.71-3.065 19.63 5.112 9.196C13.29-1.236 28.37-3.065 38.81 5.112L239.1 162.8zM416 96V99.56C416 115.3 403.3 128 387.6 128H252.4C236.7 128 224 115.3 224 99.56V96C224 42.98 266.1 .001 320 .001C373 .001 416 42.98 416 96V96zM160.3 256C161.1 245.1 163.3 236.3 166.7 227.3L304 335.5V479.2C269.5 475.8 238.2 461.4 213.7 439.6L150.6 502.6C138.1 515.1 117.9 515.1 105.4 502.6C92.88 490.1 92.88 469.9 105.4 457.4L169.4 393.4C171.2 391.5 173.3 389.9 175.4 388.6C165.5 367.8 160 344.6 160 320H96C78.33 320 64 305.7 64 288C64 270.3 78.33 256 96 256H160.3zM336 479.2V360.7L430.8 435.4C405.7 459.6 372.7 475.6 336 479.2V479.2z\"\n ]\n};\nvar faBuilding = {\n prefix: 'fas',\n iconName: 'building',\n icon: [\n 384,\n 512,\n [\n 61687,\n 127970\n ],\n \"f1ad\",\n \"M336 0C362.5 0 384 21.49 384 48V464C384 490.5 362.5 512 336 512H240V432C240 405.5 218.5 384 192 384C165.5 384 144 405.5 144 432V512H48C21.49 512 0 490.5 0 464V48C0 21.49 21.49 0 48 0H336zM64 272C64 280.8 71.16 288 80 288H112C120.8 288 128 280.8 128 272V240C128 231.2 120.8 224 112 224H80C71.16 224 64 231.2 64 240V272zM176 224C167.2 224 160 231.2 160 240V272C160 280.8 167.2 288 176 288H208C216.8 288 224 280.8 224 272V240C224 231.2 216.8 224 208 224H176zM256 272C256 280.8 263.2 288 272 288H304C312.8 288 320 280.8 320 272V240C320 231.2 312.8 224 304 224H272C263.2 224 256 231.2 256 240V272zM80 96C71.16 96 64 103.2 64 112V144C64 152.8 71.16 160 80 160H112C120.8 160 128 152.8 128 144V112C128 103.2 120.8 96 112 96H80zM160 144C160 152.8 167.2 160 176 160H208C216.8 160 224 152.8 224 144V112C224 103.2 216.8 96 208 96H176C167.2 96 160 103.2 160 112V144zM272 96C263.2 96 256 103.2 256 112V144C256 152.8 263.2 160 272 160H304C312.8 160 320 152.8 320 144V112C320 103.2 312.8 96 304 96H272z\"\n ]\n};\nvar faBuildingColumns = {\n prefix: 'fas',\n iconName: 'building-columns',\n icon: [\n 512,\n 512,\n [\n \"bank\",\n \"institution\",\n \"museum\",\n \"university\"\n ],\n \"f19c\",\n \"M243.4 2.587C251.4-.8625 260.6-.8625 268.6 2.587L492.6 98.59C506.6 104.6 514.4 119.6 511.3 134.4C508.3 149.3 495.2 159.1 479.1 160V168C479.1 181.3 469.3 192 455.1 192H55.1C42.74 192 31.1 181.3 31.1 168V160C16.81 159.1 3.708 149.3 .6528 134.4C-2.402 119.6 5.429 104.6 19.39 98.59L243.4 2.587zM256 128C273.7 128 288 113.7 288 96C288 78.33 273.7 64 256 64C238.3 64 224 78.33 224 96C224 113.7 238.3 128 256 128zM127.1 416H167.1V224H231.1V416H280V224H344V416H384V224H448V420.3C448.6 420.6 449.2 420.1 449.8 421.4L497.8 453.4C509.5 461.2 514.7 475.8 510.6 489.3C506.5 502.8 494.1 512 480 512H31.1C17.9 512 5.458 502.8 1.372 489.3C-2.715 475.8 2.515 461.2 14.25 453.4L62.25 421.4C62.82 420.1 63.41 420.6 63.1 420.3V224H127.1V416z\"\n ]\n};\nvar faBank = faBuildingColumns;\nvar faInstitution = faBuildingColumns;\nvar faMuseum = faBuildingColumns;\nvar faUniversity = faBuildingColumns;\nvar faBullhorn = {\n prefix: 'fas',\n iconName: 'bullhorn',\n icon: [\n 512,\n 512,\n [\n 128363,\n 128226\n ],\n \"f0a1\",\n \"M480 179.6C498.6 188.4 512 212.1 512 240C512 267.9 498.6 291.6 480 300.4V448C480 460.9 472.2 472.6 460.2 477.6C448.3 482.5 434.5 479.8 425.4 470.6L381.7 426.1C333.7 378.1 268.6 352 200.7 352H192V480C192 497.7 177.7 512 160 512H96C78.33 512 64 497.7 64 480V352C28.65 352 0 323.3 0 288V192C0 156.7 28.65 128 64 128H200.7C268.6 128 333.7 101 381.7 53.02L425.4 9.373C434.5 .2215 448.3-2.516 460.2 2.437C472.2 7.39 480 19.06 480 32V179.6zM200.7 192H192V288H200.7C280.5 288 357.2 317.8 416 371.3V108.7C357.2 162.2 280.5 192 200.7 192V192z\"\n ]\n};\nvar faBullseye = {\n prefix: 'fas',\n iconName: 'bullseye',\n icon: [\n 512,\n 512,\n [],\n \"f140\",\n \"M288 256C288 273.7 273.7 288 256 288C238.3 288 224 273.7 224 256C224 238.3 238.3 224 256 224C273.7 224 288 238.3 288 256zM112 256C112 176.5 176.5 112 256 112C335.5 112 400 176.5 400 256C400 335.5 335.5 400 256 400C176.5 400 112 335.5 112 256zM256 336C300.2 336 336 300.2 336 256C336 211.8 300.2 176 256 176C211.8 176 176 211.8 176 256C176 300.2 211.8 336 256 336zM512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM256 64C149.1 64 64 149.1 64 256C64 362 149.1 448 256 448C362 448 448 362 448 256C448 149.1 362 64 256 64z\"\n ]\n};\nvar faBurger = {\n prefix: 'fas',\n iconName: 'burger',\n icon: [\n 512,\n 512,\n [\n \"hamburger\"\n ],\n \"f805\",\n \"M481.9 270.1C490.9 279.1 496 291.3 496 304C496 316.7 490.9 328.9 481.9 337.9C472.9 346.9 460.7 352 448 352H64C51.27 352 39.06 346.9 30.06 337.9C21.06 328.9 16 316.7 16 304C16 291.3 21.06 279.1 30.06 270.1C39.06 261.1 51.27 256 64 256H448C460.7 256 472.9 261.1 481.9 270.1zM475.3 388.7C478.3 391.7 480 395.8 480 400V416C480 432.1 473.3 449.3 461.3 461.3C449.3 473.3 432.1 480 416 480H96C79.03 480 62.75 473.3 50.75 461.3C38.74 449.3 32 432.1 32 416V400C32 395.8 33.69 391.7 36.69 388.7C39.69 385.7 43.76 384 48 384H464C468.2 384 472.3 385.7 475.3 388.7zM50.39 220.8C45.93 218.6 42.03 215.5 38.97 211.6C35.91 207.7 33.79 203.2 32.75 198.4C31.71 193.5 31.8 188.5 32.99 183.7C54.98 97.02 146.5 32 256 32C365.5 32 457 97.02 479 183.7C480.2 188.5 480.3 193.5 479.2 198.4C478.2 203.2 476.1 207.7 473 211.6C469.1 215.5 466.1 218.6 461.6 220.8C457.2 222.9 452.3 224 447.3 224H64.67C59.73 224 54.84 222.9 50.39 220.8zM372.7 116.7C369.7 119.7 368 123.8 368 128C368 131.2 368.9 134.3 370.7 136.9C372.5 139.5 374.1 141.6 377.9 142.8C380.8 143.1 384 144.3 387.1 143.7C390.2 143.1 393.1 141.6 395.3 139.3C397.6 137.1 399.1 134.2 399.7 131.1C400.3 128 399.1 124.8 398.8 121.9C397.6 118.1 395.5 116.5 392.9 114.7C390.3 112.9 387.2 111.1 384 111.1C379.8 111.1 375.7 113.7 372.7 116.7V116.7zM244.7 84.69C241.7 87.69 240 91.76 240 96C240 99.16 240.9 102.3 242.7 104.9C244.5 107.5 246.1 109.6 249.9 110.8C252.8 111.1 256 112.3 259.1 111.7C262.2 111.1 265.1 109.6 267.3 107.3C269.6 105.1 271.1 102.2 271.7 99.12C272.3 96.02 271.1 92.8 270.8 89.88C269.6 86.95 267.5 84.45 264.9 82.7C262.3 80.94 259.2 79.1 256 79.1C251.8 79.1 247.7 81.69 244.7 84.69V84.69zM116.7 116.7C113.7 119.7 112 123.8 112 128C112 131.2 112.9 134.3 114.7 136.9C116.5 139.5 118.1 141.6 121.9 142.8C124.8 143.1 128 144.3 131.1 143.7C134.2 143.1 137.1 141.6 139.3 139.3C141.6 137.1 143.1 134.2 143.7 131.1C144.3 128 143.1 124.8 142.8 121.9C141.6 118.1 139.5 116.5 136.9 114.7C134.3 112.9 131.2 111.1 128 111.1C123.8 111.1 119.7 113.7 116.7 116.7L116.7 116.7z\"\n ]\n};\nvar faHamburger = faBurger;\nvar faBus = {\n prefix: 'fas',\n iconName: 'bus',\n icon: [\n 576,\n 512,\n [\n 128653\n ],\n \"f207\",\n \"M288 0C422.4 0 512 35.2 512 80V128C529.7 128 544 142.3 544 160V224C544 241.7 529.7 256 512 256L512 416C512 433.7 497.7 448 480 448V480C480 497.7 465.7 512 448 512H416C398.3 512 384 497.7 384 480V448H192V480C192 497.7 177.7 512 160 512H128C110.3 512 96 497.7 96 480V448C78.33 448 64 433.7 64 416L64 256C46.33 256 32 241.7 32 224V160C32 142.3 46.33 128 64 128V80C64 35.2 153.6 0 288 0zM128 256C128 273.7 142.3 288 160 288H272V128H160C142.3 128 128 142.3 128 160V256zM304 288H416C433.7 288 448 273.7 448 256V160C448 142.3 433.7 128 416 128H304V288zM144 400C161.7 400 176 385.7 176 368C176 350.3 161.7 336 144 336C126.3 336 112 350.3 112 368C112 385.7 126.3 400 144 400zM432 400C449.7 400 464 385.7 464 368C464 350.3 449.7 336 432 336C414.3 336 400 350.3 400 368C400 385.7 414.3 400 432 400zM368 64H208C199.2 64 192 71.16 192 80C192 88.84 199.2 96 208 96H368C376.8 96 384 88.84 384 80C384 71.16 376.8 64 368 64z\"\n ]\n};\nvar faBusSimple = {\n prefix: 'fas',\n iconName: 'bus-simple',\n icon: [\n 448,\n 512,\n [\n \"bus-alt\"\n ],\n \"f55e\",\n \"M224 0C348.8 0 448 35.2 448 80V416C448 433.7 433.7 448 416 448V480C416 497.7 401.7 512 384 512H352C334.3 512 320 497.7 320 480V448H128V480C128 497.7 113.7 512 96 512H64C46.33 512 32 497.7 32 480V448C14.33 448 0 433.7 0 416V80C0 35.2 99.19 0 224 0zM64 256C64 273.7 78.33 288 96 288H352C369.7 288 384 273.7 384 256V128C384 110.3 369.7 96 352 96H96C78.33 96 64 110.3 64 128V256zM80 400C97.67 400 112 385.7 112 368C112 350.3 97.67 336 80 336C62.33 336 48 350.3 48 368C48 385.7 62.33 400 80 400zM368 400C385.7 400 400 385.7 400 368C400 350.3 385.7 336 368 336C350.3 336 336 350.3 336 368C336 385.7 350.3 400 368 400z\"\n ]\n};\nvar faBusAlt = faBusSimple;\nvar faBusinessTime = {\n prefix: 'fas',\n iconName: 'business-time',\n icon: [\n 640,\n 512,\n [\n \"briefcase-clock\"\n ],\n \"f64a\",\n \"M496 224C416.4 224 352 288.4 352 368s64.38 144 144 144s144-64.38 144-144S575.6 224 496 224zM544 384h-54.25C484.4 384 480 379.6 480 374.3V304C480 295.2 487.2 288 496 288C504.8 288 512 295.2 512 304V352h32c8.838 0 16 7.162 16 16C560 376.8 552.8 384 544 384zM320.1 352H208C199.2 352 192 344.8 192 336V288H0v144C0 457.6 22.41 480 48 480h312.2C335.1 449.6 320 410.5 320 368C320 362.6 320.5 357.3 320.1 352zM496 192c5.402 0 10.72 .3301 16 .8066V144C512 118.4 489.6 96 464 96H384V48C384 22.41 361.6 0 336 0h-160C150.4 0 128 22.41 128 48V96H48C22.41 96 0 118.4 0 144V256h360.2C392.5 216.9 441.3 192 496 192zM336 96h-160V48h160V96z\"\n ]\n};\nvar faBriefcaseClock = faBusinessTime;\nvar faC = {\n prefix: 'fas',\n iconName: 'c',\n icon: [\n 384,\n 512,\n [\n 99\n ],\n \"43\",\n \"M352 359.8c22.46 0 31.1 19.53 31.1 31.99c0 23.14-66.96 88.23-164.5 88.23c-137.1 0-219.4-117.8-219.4-224c0-103.8 79.87-223.1 219.4-223.1c99.47 0 164.5 66.12 164.5 88.23c0 12.27-9.527 32.01-32.01 32.01c-31.32 0-45.8-56.25-132.5-56.25c-97.99 0-155.4 84.59-155.4 159.1c0 74.03 56.42 160 155.4 160C306.5 416 320.5 359.8 352 359.8z\"\n ]\n};\nvar faCakeCandles = {\n prefix: 'fas',\n iconName: 'cake-candles',\n icon: [\n 448,\n 512,\n [\n 127874,\n \"birthday-cake\",\n \"cake\"\n ],\n \"f1fd\",\n \"M352 111.1c22.09 0 40-17.88 40-39.97S352 0 352 0s-40 49.91-40 72S329.9 111.1 352 111.1zM224 111.1c22.09 0 40-17.88 40-39.97S224 0 224 0S184 49.91 184 72S201.9 111.1 224 111.1zM383.1 223.1L384 160c0-8.836-7.164-16-16-16h-32C327.2 144 320 151.2 320 160v64h-64V160c0-8.836-7.164-16-16-16h-32C199.2 144 192 151.2 192 160v64H128V160c0-8.836-7.164-16-16-16h-32C71.16 144 64 151.2 64 160v63.97c-35.35 0-64 28.65-64 63.1v68.7c9.814 6.102 21.39 11.33 32 11.33c20.64 0 45.05-19.73 52.7-27.33c6.25-6.219 16.34-6.219 22.59 0C114.1 348.3 139.4 367.1 160 367.1s45.05-19.73 52.7-27.33c6.25-6.219 16.34-6.219 22.59 0C242.1 348.3 267.4 367.1 288 367.1s45.05-19.73 52.7-27.33c6.25-6.219 16.34-6.219 22.59 0C370.1 348.3 395.4 367.1 416 367.1c10.61 0 22.19-5.227 32-11.33V287.1C448 252.6 419.3 223.1 383.1 223.1zM352 373.3c-13.75 10.95-38.03 26.66-64 26.66s-50.25-15.7-64-26.66c-13.75 10.95-38.03 26.66-64 26.66s-50.25-15.7-64-26.66c-13.75 10.95-38.03 26.66-64 26.66c-11.27 0-22.09-3.121-32-7.377v87.38C0 497.7 14.33 512 32 512h384c17.67 0 32-14.33 32-32v-87.38c-9.91 4.256-20.73 7.377-32 7.377C390 399.1 365.8 384.3 352 373.3zM96 111.1c22.09 0 40-17.88 40-39.97S96 0 96 0S56 49.91 56 72S73.91 111.1 96 111.1z\"\n ]\n};\nvar faBirthdayCake = faCakeCandles;\nvar faCake = faCakeCandles;\nvar faCalculator = {\n prefix: 'fas',\n iconName: 'calculator',\n icon: [\n 384,\n 512,\n [\n 128425\n ],\n \"f1ec\",\n \"M336 0h-288C22.38 0 0 22.38 0 48v416C0 489.6 22.38 512 48 512h288c25.62 0 48-22.38 48-48v-416C384 22.38 361.6 0 336 0zM64 208C64 199.2 71.2 192 80 192h32C120.8 192 128 199.2 128 208v32C128 248.8 120.8 256 112 256h-32C71.2 256 64 248.8 64 240V208zM64 304C64 295.2 71.2 288 80 288h32C120.8 288 128 295.2 128 304v32C128 344.8 120.8 352 112 352h-32C71.2 352 64 344.8 64 336V304zM224 432c0 8.801-7.199 16-16 16h-128C71.2 448 64 440.8 64 432v-32C64 391.2 71.2 384 80 384h128c8.801 0 16 7.199 16 16V432zM224 336c0 8.801-7.199 16-16 16h-32C167.2 352 160 344.8 160 336v-32C160 295.2 167.2 288 176 288h32C216.8 288 224 295.2 224 304V336zM224 240C224 248.8 216.8 256 208 256h-32C167.2 256 160 248.8 160 240v-32C160 199.2 167.2 192 176 192h32C216.8 192 224 199.2 224 208V240zM320 432c0 8.801-7.199 16-16 16h-32c-8.799 0-16-7.199-16-16v-32c0-8.801 7.201-16 16-16h32c8.801 0 16 7.199 16 16V432zM320 336c0 8.801-7.199 16-16 16h-32c-8.799 0-16-7.199-16-16v-32C256 295.2 263.2 288 272 288h32C312.8 288 320 295.2 320 304V336zM320 240C320 248.8 312.8 256 304 256h-32C263.2 256 256 248.8 256 240v-32C256 199.2 263.2 192 272 192h32C312.8 192 320 199.2 320 208V240zM320 144C320 152.8 312.8 160 304 160h-224C71.2 160 64 152.8 64 144v-64C64 71.2 71.2 64 80 64h224C312.8 64 320 71.2 320 80V144z\"\n ]\n};\nvar faCalendar = {\n prefix: 'fas',\n iconName: 'calendar',\n icon: [\n 448,\n 512,\n [\n 128198,\n 128197\n ],\n \"f133\",\n \"M96 32C96 14.33 110.3 0 128 0C145.7 0 160 14.33 160 32V64H288V32C288 14.33 302.3 0 320 0C337.7 0 352 14.33 352 32V64H400C426.5 64 448 85.49 448 112V160H0V112C0 85.49 21.49 64 48 64H96V32zM448 464C448 490.5 426.5 512 400 512H48C21.49 512 0 490.5 0 464V192H448V464z\"\n ]\n};\nvar faCalendarCheck = {\n prefix: 'fas',\n iconName: 'calendar-check',\n icon: [\n 448,\n 512,\n [],\n \"f274\",\n \"M160 32V64H288V32C288 14.33 302.3 0 320 0C337.7 0 352 14.33 352 32V64H400C426.5 64 448 85.49 448 112V160H0V112C0 85.49 21.49 64 48 64H96V32C96 14.33 110.3 0 128 0C145.7 0 160 14.33 160 32zM0 192H448V464C448 490.5 426.5 512 400 512H48C21.49 512 0 490.5 0 464V192zM328.1 304.1C338.3 295.6 338.3 280.4 328.1 271C319.6 261.7 304.4 261.7 295 271L200 366.1L152.1 319C143.6 309.7 128.4 309.7 119 319C109.7 328.4 109.7 343.6 119 352.1L183 416.1C192.4 426.3 207.6 426.3 216.1 416.1L328.1 304.1z\"\n ]\n};\nvar faCalendarDay = {\n prefix: 'fas',\n iconName: 'calendar-day',\n icon: [\n 448,\n 512,\n [],\n \"f783\",\n \"M160 32V64H288V32C288 14.33 302.3 0 320 0C337.7 0 352 14.33 352 32V64H400C426.5 64 448 85.49 448 112V160H0V112C0 85.49 21.49 64 48 64H96V32C96 14.33 110.3 0 128 0C145.7 0 160 14.33 160 32zM0 192H448V464C448 490.5 426.5 512 400 512H48C21.49 512 0 490.5 0 464V192zM80 256C71.16 256 64 263.2 64 272V368C64 376.8 71.16 384 80 384H176C184.8 384 192 376.8 192 368V272C192 263.2 184.8 256 176 256H80z\"\n ]\n};\nvar faCalendarDays = {\n prefix: 'fas',\n iconName: 'calendar-days',\n icon: [\n 448,\n 512,\n [\n \"calendar-alt\"\n ],\n \"f073\",\n \"M160 32V64H288V32C288 14.33 302.3 0 320 0C337.7 0 352 14.33 352 32V64H400C426.5 64 448 85.49 448 112V160H0V112C0 85.49 21.49 64 48 64H96V32C96 14.33 110.3 0 128 0C145.7 0 160 14.33 160 32zM0 192H448V464C448 490.5 426.5 512 400 512H48C21.49 512 0 490.5 0 464V192zM64 304C64 312.8 71.16 320 80 320H112C120.8 320 128 312.8 128 304V272C128 263.2 120.8 256 112 256H80C71.16 256 64 263.2 64 272V304zM192 304C192 312.8 199.2 320 208 320H240C248.8 320 256 312.8 256 304V272C256 263.2 248.8 256 240 256H208C199.2 256 192 263.2 192 272V304zM336 256C327.2 256 320 263.2 320 272V304C320 312.8 327.2 320 336 320H368C376.8 320 384 312.8 384 304V272C384 263.2 376.8 256 368 256H336zM64 432C64 440.8 71.16 448 80 448H112C120.8 448 128 440.8 128 432V400C128 391.2 120.8 384 112 384H80C71.16 384 64 391.2 64 400V432zM208 384C199.2 384 192 391.2 192 400V432C192 440.8 199.2 448 208 448H240C248.8 448 256 440.8 256 432V400C256 391.2 248.8 384 240 384H208zM320 432C320 440.8 327.2 448 336 448H368C376.8 448 384 440.8 384 432V400C384 391.2 376.8 384 368 384H336C327.2 384 320 391.2 320 400V432z\"\n ]\n};\nvar faCalendarAlt = faCalendarDays;\nvar faCalendarMinus = {\n prefix: 'fas',\n iconName: 'calendar-minus',\n icon: [\n 448,\n 512,\n [],\n \"f272\",\n \"M160 32V64H288V32C288 14.33 302.3 0 320 0C337.7 0 352 14.33 352 32V64H400C426.5 64 448 85.49 448 112V160H0V112C0 85.49 21.49 64 48 64H96V32C96 14.33 110.3 0 128 0C145.7 0 160 14.33 160 32zM0 192H448V464C448 490.5 426.5 512 400 512H48C21.49 512 0 490.5 0 464V192zM312 376C325.3 376 336 365.3 336 352C336 338.7 325.3 328 312 328H136C122.7 328 112 338.7 112 352C112 365.3 122.7 376 136 376H312z\"\n ]\n};\nvar faCalendarPlus = {\n prefix: 'fas',\n iconName: 'calendar-plus',\n icon: [\n 448,\n 512,\n [],\n \"f271\",\n \"M96 32C96 14.33 110.3 0 128 0C145.7 0 160 14.33 160 32V64H288V32C288 14.33 302.3 0 320 0C337.7 0 352 14.33 352 32V64H400C426.5 64 448 85.49 448 112V160H0V112C0 85.49 21.49 64 48 64H96V32zM448 464C448 490.5 426.5 512 400 512H48C21.49 512 0 490.5 0 464V192H448V464zM200 272V328H144C130.7 328 120 338.7 120 352C120 365.3 130.7 376 144 376H200V432C200 445.3 210.7 456 224 456C237.3 456 248 445.3 248 432V376H304C317.3 376 328 365.3 328 352C328 338.7 317.3 328 304 328H248V272C248 258.7 237.3 248 224 248C210.7 248 200 258.7 200 272z\"\n ]\n};\nvar faCalendarWeek = {\n prefix: 'fas',\n iconName: 'calendar-week',\n icon: [\n 448,\n 512,\n [],\n \"f784\",\n \"M160 32V64H288V32C288 14.33 302.3 0 320 0C337.7 0 352 14.33 352 32V64H400C426.5 64 448 85.49 448 112V160H0V112C0 85.49 21.49 64 48 64H96V32C96 14.33 110.3 0 128 0C145.7 0 160 14.33 160 32zM0 192H448V464C448 490.5 426.5 512 400 512H48C21.49 512 0 490.5 0 464V192zM80 256C71.16 256 64 263.2 64 272V336C64 344.8 71.16 352 80 352H368C376.8 352 384 344.8 384 336V272C384 263.2 376.8 256 368 256H80z\"\n ]\n};\nvar faCalendarXmark = {\n prefix: 'fas',\n iconName: 'calendar-xmark',\n icon: [\n 448,\n 512,\n [\n \"calendar-times\"\n ],\n \"f273\",\n \"M160 32V64H288V32C288 14.33 302.3 0 320 0C337.7 0 352 14.33 352 32V64H400C426.5 64 448 85.49 448 112V160H0V112C0 85.49 21.49 64 48 64H96V32C96 14.33 110.3 0 128 0C145.7 0 160 14.33 160 32zM0 192H448V464C448 490.5 426.5 512 400 512H48C21.49 512 0 490.5 0 464V192zM304.1 304.1C314.3 295.6 314.3 280.4 304.1 271C295.6 261.7 280.4 261.7 271 271L224 318.1L176.1 271C167.6 261.7 152.4 261.7 143 271C133.7 280.4 133.7 295.6 143 304.1L190.1 352L143 399C133.7 408.4 133.7 423.6 143 432.1C152.4 442.3 167.6 442.3 176.1 432.1L224 385.9L271 432.1C280.4 442.3 295.6 442.3 304.1 432.1C314.3 423.6 314.3 408.4 304.1 399L257.9 352L304.1 304.1z\"\n ]\n};\nvar faCalendarTimes = faCalendarXmark;\nvar faCamera = {\n prefix: 'fas',\n iconName: 'camera',\n icon: [\n 512,\n 512,\n [\n 62258,\n \"camera-alt\"\n ],\n \"f030\",\n \"M194.6 32H317.4C338.1 32 356.4 45.22 362.9 64.82L373.3 96H448C483.3 96 512 124.7 512 160V416C512 451.3 483.3 480 448 480H64C28.65 480 0 451.3 0 416V160C0 124.7 28.65 96 64 96H138.7L149.1 64.82C155.6 45.22 173.9 32 194.6 32H194.6zM256 384C309 384 352 341 352 288C352 234.1 309 192 256 192C202.1 192 160 234.1 160 288C160 341 202.1 384 256 384z\"\n ]\n};\nvar faCameraAlt = faCamera;\nvar faCameraRetro = {\n prefix: 'fas',\n iconName: 'camera-retro',\n icon: [\n 512,\n 512,\n [\n 128247\n ],\n \"f083\",\n \"M64 64V48C64 39.16 71.16 32 80 32H144C152.8 32 160 39.16 160 48V64H192L242.5 38.76C251.4 34.31 261.2 32 271.1 32H448C483.3 32 512 60.65 512 96V416C512 451.3 483.3 480 448 480H64C28.65 480 0 451.3 0 416V128C0 92.65 28.65 64 64 64zM220.6 121.2C211.7 125.7 201.9 128 192 128H64V192H178.8C200.8 176.9 227.3 168 256 168C284.7 168 311.2 176.9 333.2 192H448V96H271.1L220.6 121.2zM256 216C207.4 216 168 255.4 168 304C168 352.6 207.4 392 256 392C304.6 392 344 352.6 344 304C344 255.4 304.6 216 256 216z\"\n ]\n};\nvar faCameraRotate = {\n prefix: 'fas',\n iconName: 'camera-rotate',\n icon: [\n 512,\n 512,\n [],\n \"e0d8\",\n \"M464 96h-88l-12.38-32.88C356.6 44.38 338.8 32 318.8 32h-125.5c-20 0-38 12.38-45 31.12L136 96H48C21.5 96 0 117.5 0 144v288C0 458.5 21.5 480 48 480h416c26.5 0 48-21.5 48-48v-288C512 117.5 490.5 96 464 96zM356.9 366.8C332.4 398.1 295.7 416 256 416c-31.78 0-61.37-11.94-84.58-32.61l-19.28 19.29C143.2 411.6 128 405.3 128 392.7V316.3c0-5.453 4.359-9.838 9.775-9.99h76.98c12.35 .3027 18.47 15.27 9.654 24.09l-19.27 19.28C219.3 361.4 237.1 368 256 368c24.8 0 47.78-11.22 63.08-30.78c8.172-10.44 23.25-12.28 33.69-4.125S365.1 356.3 356.9 366.8zM384 259.7c0 5.453-4.359 9.838-9.775 9.99h-76.98c-12.35-.3027-18.47-15.27-9.654-24.09l19.27-19.28C292.7 214.6 274.9 208 256 208c-24.8 0-47.78 11.22-63.08 30.78C184.8 249.2 169.7 251.1 159.2 242.9C148.8 234.8 146.9 219.7 155.1 209.2C179.6 177.9 216.3 160 256 160c31.78 0 61.37 11.94 84.58 32.61l19.28-19.29C368.8 164.4 384 170.7 384 183.3V259.7z\"\n ]\n};\nvar faCampground = {\n prefix: 'fas',\n iconName: 'campground',\n icon: [\n 576,\n 512,\n [\n 9978\n ],\n \"f6bb\",\n \"M328.1 112L563.7 405.4C571.7 415.4 576 427.7 576 440.4V464C576 490.5 554.5 512 528 512H48C21.49 512 0 490.5 0 464V440.4C0 427.7 4.328 415.4 12.27 405.4L247 112L199 51.99C187.1 38.19 190.2 18.05 204 7.013C217.8-4.027 237.9-1.789 248.1 12.01L288 60.78L327 12.01C338.1-1.789 358.2-4.027 371.1 7.013C385.8 18.05 388 38.19 376.1 51.99L328.1 112zM407.5 448L288 291.7L168.5 448H407.5z\"\n ]\n};\nvar faCandyCane = {\n prefix: 'fas',\n iconName: 'candy-cane',\n icon: [\n 512,\n 512,\n [],\n \"f786\",\n \"M497.5 91.1C469.6 33.13 411.8 0 352.4 0c-27.88 0-56.14 7.25-81.77 22.62L243.1 38.1C227.9 48.12 223 67.75 232.1 82.87l32.76 54.87c8.522 14.2 27.59 20.6 43.88 11.06l27.51-16.37c5.125-3.125 10.95-4.439 16.58-4.439c10.88 0 21.35 5.625 27.35 15.62c9 15.12 3.917 34.59-11.08 43.71L15.6 397.6c-15.25 9.125-20.13 28.62-11 43.87l32.76 54.87c8.522 14.2 27.59 20.66 43.88 11.12l347.4-206.5C500.2 258.1 533.2 167.5 497.5 91.1zM319.7 104.1L317.2 106.5l-20.5-61.5c9.75-4.75 19.88-8.125 30.38-10.25l20.63 61.87C337.8 97.37 328.2 99.87 319.7 104.1zM145.8 431.7l-60.5-38.5l30.88-18.25l60.5 38.5L145.8 431.7zM253.3 367.9l-60.5-38.5l30.88-18.25l60.5 38.5L253.3 367.9zM364.2 301.1L303.7 263.5l30.88-18.25l60.5 38.5L364.2 301.1zM384.7 104.7l46-45.1c8.375 6.5 16 13.1 22.5 22.5l-45.63 45.81C401.9 117.8 393.9 110.1 384.7 104.7zM466.7 212.5l-59.5-19.75c3.25-5.375 5.875-10.1 7.5-17.12c1-4.5 1.625-9.125 1.75-13.62l60.38 20.12C474.7 192.5 471.4 202.7 466.7 212.5z\"\n ]\n};\nvar faCannabis = {\n prefix: 'fas',\n iconName: 'cannabis',\n icon: [\n 576,\n 512,\n [],\n \"f55f\",\n \"M544 374.4c0 6-3.25 11.38-8.5 14.12c-2.5 1.375-60.75 31.75-133.5 31.75c-6.124 0-12-.125-17.5-.25c11.38 22.25 16.5 38.25 16.75 39.13c1.875 5.75 .375 12-3.875 16.12c-4.125 4.25-10.38 5.75-16.12 4c-1.631-.4648-32.94-10.66-69.25-34.06v42.81C312 501.3 301.3 512 288 512s-24-10.75-24-23.1v-42.81c-36.31 23.4-67.62 33.59-69.25 34.06c-5.75 1.75-12 .25-16.12-4c-4.25-4.25-5.75-10.38-3.875-16.12C175 458.3 180.1 442.1 191.5 420c-5.501 .125-11.37 .25-17.5 .25c-72.75 0-130.1-30.38-133.5-31.75C35.25 385.8 32 380.4 32 374.4c0-5.875 3.25-11.38 8.5-14.12c1.625-.875 32.38-16.88 76.75-25.75c-64.25-75.13-84-161.8-84.88-165.8C31.25 163.5 32.75 157.9 36.63 154C39.75 151 43.75 149.4 48 149.4c1.125 0 2.25 .125 3.375 .375C55.38 150.6 137.1 169.3 212 229.5V225.1c0-118.9 60-213.8 62.5-217.8C277.5 2.75 282.5 0 288 0s10.5 2.75 13.5 7.375C304 11.38 364 106.3 364 225.1V229.5c73.1-60.25 156.6-79 160.5-79.75C525.8 149.5 526.9 149.4 528 149.4c4.25 0 8.25 1.625 11.38 4.625c3.75 3.875 5.375 9.5 4.25 14.75c-.875 4-20.62 90.63-84.88 165.8c44.38 8.875 75.13 24.88 76.75 25.75C540.8 363 544 368.5 544 374.4z\"\n ]\n};\nvar faCapsules = {\n prefix: 'fas',\n iconName: 'capsules',\n icon: [\n 576,\n 512,\n [],\n \"f46b\",\n \"M555.3 300.1L424.3 112.8C401.9 81 366.4 64 330.4 64c-22.63 0-45.5 6.75-65.5 20.75C245.2 98.5 231.2 117.5 223.4 138.5C220.5 79.25 171.1 32 111.1 32c-61.88 0-111.1 50.08-111.1 111.1L-.0028 368c0 61.88 50.12 112 112 112s112-50.13 112-112L223.1 218.9C227.2 227.5 231.2 236 236.7 243.9l131.3 187.4C390.3 463 425.8 480 461.8 480c22.75 0 45.5-6.75 65.5-20.75C579 423.1 591.5 351.8 555.3 300.1zM159.1 256H63.99V144c0-26.5 21.5-48 48-48s48 21.5 48 48V256zM354.8 300.9l-65.5-93.63c-7.75-11-10.75-24.5-8.375-37.63c2.375-13.25 9.75-24.87 20.75-32.5C310.1 131.1 320.1 128 330.4 128c16.5 0 31.88 8 41.38 21.5l65.5 93.75L354.8 300.9z\"\n ]\n};\nvar faCar = {\n prefix: 'fas',\n iconName: 'car',\n icon: [\n 512,\n 512,\n [\n 128664,\n \"automobile\"\n ],\n \"f1b9\",\n \"M39.61 196.8L74.8 96.29C88.27 57.78 124.6 32 165.4 32H346.6C387.4 32 423.7 57.78 437.2 96.29L472.4 196.8C495.6 206.4 512 229.3 512 256V448C512 465.7 497.7 480 480 480H448C430.3 480 416 465.7 416 448V400H96V448C96 465.7 81.67 480 64 480H32C14.33 480 0 465.7 0 448V256C0 229.3 16.36 206.4 39.61 196.8V196.8zM109.1 192H402.9L376.8 117.4C372.3 104.6 360.2 96 346.6 96H165.4C151.8 96 139.7 104.6 135.2 117.4L109.1 192zM96 256C78.33 256 64 270.3 64 288C64 305.7 78.33 320 96 320C113.7 320 128 305.7 128 288C128 270.3 113.7 256 96 256zM416 320C433.7 320 448 305.7 448 288C448 270.3 433.7 256 416 256C398.3 256 384 270.3 384 288C384 305.7 398.3 320 416 320z\"\n ]\n};\nvar faAutomobile = faCar;\nvar faCarBattery = {\n prefix: 'fas',\n iconName: 'car-battery',\n icon: [\n 512,\n 512,\n [\n \"battery-car\"\n ],\n \"f5df\",\n \"M80 96C80 78.33 94.33 64 112 64H176C193.7 64 208 78.33 208 96H304C304 78.33 318.3 64 336 64H400C417.7 64 432 78.33 432 96H448C483.3 96 512 124.7 512 160V384C512 419.3 483.3 448 448 448H64C28.65 448 0 419.3 0 384V160C0 124.7 28.65 96 64 96H80zM384 192C384 183.2 376.8 176 368 176C359.2 176 352 183.2 352 192V224H320C311.2 224 304 231.2 304 240C304 248.8 311.2 256 320 256H352V288C352 296.8 359.2 304 368 304C376.8 304 384 296.8 384 288V256H416C424.8 256 432 248.8 432 240C432 231.2 424.8 224 416 224H384V192zM96 256H192C200.8 256 208 248.8 208 240C208 231.2 200.8 224 192 224H96C87.16 224 80 231.2 80 240C80 248.8 87.16 256 96 256z\"\n ]\n};\nvar faBatteryCar = faCarBattery;\nvar faCarCrash = {\n prefix: 'fas',\n iconName: 'car-crash',\n icon: [\n 640,\n 512,\n [],\n \"f5e1\",\n \"M176 8C182.6 8 188.4 11.1 190.9 18.09L220.3 92.05L296.4 68.93C302.7 67.03 309.5 69.14 313.6 74.27C314.1 74.85 314.5 75.45 314.9 76.08C297.8 84.32 282.7 96.93 271.4 113.3L230.4 172.5C203.1 181.4 180.6 203.5 172.6 233.4L152.7 307.4L117.4 339.9C112.6 344.4 105.5 345.4 99.64 342.6C93.73 339.7 90.16 333.6 90.62 327L96.21 247.6L17.56 235.4C11.08 234.4 5.871 229.6 4.413 223.2C2.954 216.8 5.54 210.1 10.94 206.4L76.5 161.3L37.01 92.18C33.76 86.49 34.31 79.39 38.4 74.27C42.48 69.14 49.28 67.03 55.55 68.93L131.7 92.05L161.1 18.09C163.6 11.1 169.4 8 176 8L176 8zM384.2 99.67L519.8 135.1C552.5 144.7 576.1 173.1 578.8 206.8L585.7 290.7C602.9 304.2 611.3 327 605.3 349.4L570.1 480.8C565.5 497.8 547.1 507.1 530.9 503.4L515.5 499.3C498.4 494.7 488.3 477.1 492.8 460.1L501.1 429.1L253.8 362.9L245.6 393.8C240.1 410.9 223.4 421 206.4 416.4L190.9 412.3C173.8 407.7 163.7 390.2 168.3 373.1L203.5 241.7C209.5 219.3 228.2 203.8 249.8 200.7L297.7 131.5C316.9 103.6 351.6 90.92 384.2 99.67L384.2 99.67zM367.7 161.5C361.1 159.7 354.2 162.3 350.4 167.8L318.1 214.5L519.6 268.5L515 211.1C514.5 205.2 509.8 199.6 503.2 197.8L367.7 161.5zM268.3 308.8C281.1 312.2 294.3 304.6 297.7 291.8C301.2 279 293.6 265.9 280.8 262.4C267.1 259 254.8 266.6 251.4 279.4C247.9 292.2 255.5 305.4 268.3 308.8zM528 328.7C515.2 325.3 502.1 332.9 498.6 345.7C495.2 358.5 502.8 371.6 515.6 375.1C528.4 378.5 541.6 370.9 545 358.1C548.4 345.3 540.8 332.1 528 328.7z\"\n ]\n};\nvar faCarRear = {\n prefix: 'fas',\n iconName: 'car-rear',\n icon: [\n 512,\n 512,\n [\n \"car-alt\"\n ],\n \"f5de\",\n \"M165.4 32H346.6C387.4 32 423.7 57.78 437.2 96.29L472.4 196.8C495.6 206.4 512 229.3 512 256V336C512 359.7 499.1 380.4 480 391.4V448C480 465.7 465.7 480 448 480H416C398.3 480 384 465.7 384 448V400H128V448C128 465.7 113.7 480 96 480H64C46.33 480 32 465.7 32 448V391.4C12.87 380.4 0 359.7 0 336V256C0 229.3 16.36 206.4 39.61 196.8L74.8 96.29C88.27 57.78 124.6 32 165.4 32V32zM165.4 96C151.8 96 139.7 104.6 135.2 117.4L109.1 192H402.9L376.8 117.4C372.3 104.6 360.2 96 346.6 96H165.4zM208 272C199.2 272 192 279.2 192 288V320C192 328.8 199.2 336 208 336H304C312.8 336 320 328.8 320 320V288C320 279.2 312.8 272 304 272H208zM72 304H104C117.3 304 128 293.3 128 280C128 266.7 117.3 256 104 256H72C58.75 256 48 266.7 48 280C48 293.3 58.75 304 72 304zM408 256C394.7 256 384 266.7 384 280C384 293.3 394.7 304 408 304H440C453.3 304 464 293.3 464 280C464 266.7 453.3 256 440 256H408z\"\n ]\n};\nvar faCarAlt = faCarRear;\nvar faCarSide = {\n prefix: 'fas',\n iconName: 'car-side',\n icon: [\n 640,\n 512,\n [\n 128663\n ],\n \"f5e4\",\n \"M640 320V368C640 385.7 625.7 400 608 400H574.7C567.1 445.4 527.6 480 480 480C432.4 480 392.9 445.4 385.3 400H254.7C247.1 445.4 207.6 480 160 480C112.4 480 72.94 445.4 65.33 400H32C14.33 400 0 385.7 0 368V256C0 228.9 16.81 205.8 40.56 196.4L82.2 92.35C96.78 55.9 132.1 32 171.3 32H353.2C382.4 32 409.1 45.26 428.2 68.03L528.2 193C591.2 200.1 640 254.8 640 319.1V320zM171.3 96C158.2 96 146.5 103.1 141.6 116.1L111.3 192H224V96H171.3zM272 192H445.4L378.2 108C372.2 100.4 362.1 96 353.2 96H272V192zM525.3 400C527 394.1 528 389.6 528 384C528 357.5 506.5 336 480 336C453.5 336 432 357.5 432 384C432 389.6 432.1 394.1 434.7 400C441.3 418.6 459.1 432 480 432C500.9 432 518.7 418.6 525.3 400zM205.3 400C207 394.1 208 389.6 208 384C208 357.5 186.5 336 160 336C133.5 336 112 357.5 112 384C112 389.6 112.1 394.1 114.7 400C121.3 418.6 139.1 432 160 432C180.9 432 198.7 418.6 205.3 400z\"\n ]\n};\nvar faCaravan = {\n prefix: 'fas',\n iconName: 'caravan',\n icon: [\n 640,\n 512,\n [],\n \"f8ff\",\n \"M0 112C0 67.82 35.82 32 80 32H416C504.4 32 576 103.6 576 192V352H608C625.7 352 640 366.3 640 384C640 401.7 625.7 416 608 416H288C288 469 245 512 192 512C138.1 512 96 469 96 416H80C35.82 416 0 380.2 0 336V112zM320 352H448V256H416C407.2 256 400 248.8 400 240C400 231.2 407.2 224 416 224H448V160C448 142.3 433.7 128 416 128H352C334.3 128 320 142.3 320 160V352zM96 128C78.33 128 64 142.3 64 160V224C64 241.7 78.33 256 96 256H224C241.7 256 256 241.7 256 224V160C256 142.3 241.7 128 224 128H96zM192 464C218.5 464 240 442.5 240 416C240 389.5 218.5 368 192 368C165.5 368 144 389.5 144 416C144 442.5 165.5 464 192 464z\"\n ]\n};\nvar faCaretDown = {\n prefix: 'fas',\n iconName: 'caret-down',\n icon: [\n 320,\n 512,\n [],\n \"f0d7\",\n \"M310.6 246.6l-127.1 128C176.4 380.9 168.2 384 160 384s-16.38-3.125-22.63-9.375l-127.1-128C.2244 237.5-2.516 223.7 2.438 211.8S19.07 192 32 192h255.1c12.94 0 24.62 7.781 29.58 19.75S319.8 237.5 310.6 246.6z\"\n ]\n};\nvar faCaretLeft = {\n prefix: 'fas',\n iconName: 'caret-left',\n icon: [\n 256,\n 512,\n [],\n \"f0d9\",\n \"M137.4 406.6l-128-127.1C3.125 272.4 0 264.2 0 255.1s3.125-16.38 9.375-22.63l128-127.1c9.156-9.156 22.91-11.9 34.88-6.943S192 115.1 192 128v255.1c0 12.94-7.781 24.62-19.75 29.58S146.5 415.8 137.4 406.6z\"\n ]\n};\nvar faCaretRight = {\n prefix: 'fas',\n iconName: 'caret-right',\n icon: [\n 256,\n 512,\n [],\n \"f0da\",\n \"M118.6 105.4l128 127.1C252.9 239.6 256 247.8 256 255.1s-3.125 16.38-9.375 22.63l-128 127.1c-9.156 9.156-22.91 11.9-34.88 6.943S64 396.9 64 383.1V128c0-12.94 7.781-24.62 19.75-29.58S109.5 96.23 118.6 105.4z\"\n ]\n};\nvar faCaretUp = {\n prefix: 'fas',\n iconName: 'caret-up',\n icon: [\n 320,\n 512,\n [],\n \"f0d8\",\n \"M9.39 265.4l127.1-128C143.6 131.1 151.8 128 160 128s16.38 3.125 22.63 9.375l127.1 128c9.156 9.156 11.9 22.91 6.943 34.88S300.9 320 287.1 320H32.01c-12.94 0-24.62-7.781-29.58-19.75S.2333 274.5 9.39 265.4z\"\n ]\n};\nvar faCarrot = {\n prefix: 'fas',\n iconName: 'carrot',\n icon: [\n 512,\n 512,\n [\n 129365\n ],\n \"f787\",\n \"M298.2 156.6C245.5 130.9 183.7 146.1 147.1 189.4l55.27 55.31c6.25 6.25 6.25 16.33 0 22.58c-3.127 3-7.266 4.605-11.39 4.605s-8.068-1.605-11.19-4.605L130.3 217l-128.1 262.8c-2.875 6-3 13.25 0 19.63c5.5 11.12 19 15.75 30 10.38l133.6-65.25L116.7 395.3c-6.377-6.125-6.377-16.38 0-22.5c6.25-6.25 16.37-6.25 22.5 0l56.98 56.98l102-49.89c24-11.63 44.5-31.26 57.13-57.13C385.5 261.1 359.9 186.8 298.2 156.6zM390.2 121.8C409.7 81 399.7 32.88 359.1 0c-50.25 41.75-52.51 107.5-7.875 151.9l8 8C404.5 204.5 470.4 202.3 512 152C479.1 112.3 430.1 102.3 390.2 121.8z\"\n ]\n};\nvar faCartArrowDown = {\n prefix: 'fas',\n iconName: 'cart-arrow-down',\n icon: [\n 576,\n 512,\n [],\n \"f218\",\n \"M0 24C0 10.75 10.75 0 24 0H96C107.5 0 117.4 8.19 119.6 19.51L121.1 32H312V134.1L288.1 111C279.6 101.7 264.4 101.7 255 111C245.7 120.4 245.7 135.6 255 144.1L319 208.1C328.4 218.3 343.6 218.3 352.1 208.1L416.1 144.1C426.3 135.6 426.3 120.4 416.1 111C407.6 101.7 392.4 101.7 383 111L360 134.1V32H541.8C562.1 32 578.3 52.25 572.6 72.66L518.6 264.7C514.7 278.5 502.1 288 487.8 288H170.7L179.9 336H488C501.3 336 512 346.7 512 360C512 373.3 501.3 384 488 384H159.1C148.5 384 138.6 375.8 136.4 364.5L76.14 48H24C10.75 48 0 37.25 0 24V24zM224 464C224 490.5 202.5 512 176 512C149.5 512 128 490.5 128 464C128 437.5 149.5 416 176 416C202.5 416 224 437.5 224 464zM416 464C416 437.5 437.5 416 464 416C490.5 416 512 437.5 512 464C512 490.5 490.5 512 464 512C437.5 512 416 490.5 416 464z\"\n ]\n};\nvar faCartFlatbed = {\n prefix: 'fas',\n iconName: 'cart-flatbed',\n icon: [\n 640,\n 512,\n [\n \"dolly-flatbed\"\n ],\n \"f474\",\n \"M240 320h320c26.4 0 48-21.6 48-48v-192C608 53.6 586.4 32 560 32H448v128l-48-32L352 160V32H240C213.6 32 192 53.6 192 80v192C192 298.4 213.6 320 240 320zM608 384H128V64c0-35.2-28.8-64-64-64H31.1C14.4 0 0 14.4 0 32S14.4 64 31.1 64H48C56.84 64 64 71.16 64 80v335.1c0 17.6 14.4 32 32 32l66.92-.0009C161.1 453 160 458.4 160 464C160 490.5 181.5 512 208 512S256 490.5 256 464c0-5.641-1.13-10.97-2.917-16h197.9c-1.787 5.027-2.928 10.36-2.928 16C448 490.5 469.5 512 496 512c26.51 0 48.01-21.49 48.01-47.1c0-5.641-1.12-10.97-2.907-16l66.88 .0009C625.6 448 640 433.6 640 415.1C640 398.4 625.6 384 608 384z\"\n ]\n};\nvar faDollyFlatbed = faCartFlatbed;\nvar faCartFlatbedSuitcase = {\n prefix: 'fas',\n iconName: 'cart-flatbed-suitcase',\n icon: [\n 640,\n 512,\n [\n \"luggage-cart\"\n ],\n \"f59d\",\n \"M541.2 448C542.1 453 544.1 458.4 544.1 464C544.1 490.5 522.6 512 496 512C469.5 512 448.1 490.5 448.1 464C448.1 458.4 449.2 453 450.1 448H253.1C254.9 453 256 458.4 256 464C256 490.5 234.5 512 208 512C181.5 512 160 490.5 160 464C160 458.4 161.1 453 162.9 448L96 448C78.4 448 64 433.6 64 416V80C64 71.16 56.84 64 48 64H32C14.4 64 0 49.6 0 32C0 14.4 14.4 0 32 0H64C99.2 0 128 28.8 128 64V384H608C625.6 384 640 398.4 640 416C640 433.6 625.6 448 608 448L541.2 448zM432 0C458.5 0 480 21.5 480 48V320H288V48C288 21.5 309.5 0 336 0H432zM336 96H432V48H336V96zM256 320H224C206.4 320 192 305.6 192 288V128C192 110.4 206.4 96 224 96H256V320zM576 128V288C576 305.6 561.6 320 544 320H512V96H544C561.6 96 576 110.4 576 128z\"\n ]\n};\nvar faLuggageCart = faCartFlatbedSuitcase;\nvar faCartPlus = {\n prefix: 'fas',\n iconName: 'cart-plus',\n icon: [\n 576,\n 512,\n [],\n \"f217\",\n \"M96 0C107.5 0 117.4 8.19 119.6 19.51L121.1 32H541.8C562.1 32 578.3 52.25 572.6 72.66L518.6 264.7C514.7 278.5 502.1 288 487.8 288H170.7L179.9 336H488C501.3 336 512 346.7 512 360C512 373.3 501.3 384 488 384H159.1C148.5 384 138.6 375.8 136.4 364.5L76.14 48H24C10.75 48 0 37.25 0 24C0 10.75 10.75 0 24 0H96zM272 180H316V224C316 235 324.1 244 336 244C347 244 356 235 356 224V180H400C411 180 420 171 420 160C420 148.1 411 140 400 140H356V96C356 84.95 347 76 336 76C324.1 76 316 84.95 316 96V140H272C260.1 140 252 148.1 252 160C252 171 260.1 180 272 180zM128 464C128 437.5 149.5 416 176 416C202.5 416 224 437.5 224 464C224 490.5 202.5 512 176 512C149.5 512 128 490.5 128 464zM512 464C512 490.5 490.5 512 464 512C437.5 512 416 490.5 416 464C416 437.5 437.5 416 464 416C490.5 416 512 437.5 512 464z\"\n ]\n};\nvar faCartShopping = {\n prefix: 'fas',\n iconName: 'cart-shopping',\n icon: [\n 576,\n 512,\n [\n 128722,\n \"shopping-cart\"\n ],\n \"f07a\",\n \"M96 0C107.5 0 117.4 8.19 119.6 19.51L121.1 32H541.8C562.1 32 578.3 52.25 572.6 72.66L518.6 264.7C514.7 278.5 502.1 288 487.8 288H170.7L179.9 336H488C501.3 336 512 346.7 512 360C512 373.3 501.3 384 488 384H159.1C148.5 384 138.6 375.8 136.4 364.5L76.14 48H24C10.75 48 0 37.25 0 24C0 10.75 10.75 0 24 0H96zM128 464C128 437.5 149.5 416 176 416C202.5 416 224 437.5 224 464C224 490.5 202.5 512 176 512C149.5 512 128 490.5 128 464zM512 464C512 490.5 490.5 512 464 512C437.5 512 416 490.5 416 464C416 437.5 437.5 416 464 416C490.5 416 512 437.5 512 464z\"\n ]\n};\nvar faShoppingCart = faCartShopping;\nvar faCashRegister = {\n prefix: 'fas',\n iconName: 'cash-register',\n icon: [\n 512,\n 512,\n [],\n \"f788\",\n \"M288 0C305.7 0 320 14.33 320 32V96C320 113.7 305.7 128 288 128H208V160H424.1C456.6 160 483.5 183.1 488.2 214.4L510.9 364.1C511.6 368.8 512 373.6 512 378.4V448C512 483.3 483.3 512 448 512H64C28.65 512 0 483.3 0 448V378.4C0 373.6 .3622 368.8 1.083 364.1L23.76 214.4C28.5 183.1 55.39 160 87.03 160H143.1V128H63.1C46.33 128 31.1 113.7 31.1 96V32C31.1 14.33 46.33 0 63.1 0L288 0zM96 48C87.16 48 80 55.16 80 64C80 72.84 87.16 80 96 80H256C264.8 80 272 72.84 272 64C272 55.16 264.8 48 256 48H96zM80 448H432C440.8 448 448 440.8 448 432C448 423.2 440.8 416 432 416H80C71.16 416 64 423.2 64 432C64 440.8 71.16 448 80 448zM112 216C98.75 216 88 226.7 88 240C88 253.3 98.75 264 112 264C125.3 264 136 253.3 136 240C136 226.7 125.3 216 112 216zM208 264C221.3 264 232 253.3 232 240C232 226.7 221.3 216 208 216C194.7 216 184 226.7 184 240C184 253.3 194.7 264 208 264zM160 296C146.7 296 136 306.7 136 320C136 333.3 146.7 344 160 344C173.3 344 184 333.3 184 320C184 306.7 173.3 296 160 296zM304 264C317.3 264 328 253.3 328 240C328 226.7 317.3 216 304 216C290.7 216 280 226.7 280 240C280 253.3 290.7 264 304 264zM256 296C242.7 296 232 306.7 232 320C232 333.3 242.7 344 256 344C269.3 344 280 333.3 280 320C280 306.7 269.3 296 256 296zM400 264C413.3 264 424 253.3 424 240C424 226.7 413.3 216 400 216C386.7 216 376 226.7 376 240C376 253.3 386.7 264 400 264zM352 296C338.7 296 328 306.7 328 320C328 333.3 338.7 344 352 344C365.3 344 376 333.3 376 320C376 306.7 365.3 296 352 296z\"\n ]\n};\nvar faCat = {\n prefix: 'fas',\n iconName: 'cat',\n icon: [\n 576,\n 512,\n [\n 128008\n ],\n \"f6be\",\n \"M322.6 192C302.4 192 215.8 194 160 278V192c0-53-43-96-96-96C46.38 96 32 110.4 32 128s14.38 32 32 32s32 14.38 32 32v256c0 35.25 28.75 64 64 64h176c8.875 0 16-7.125 16-15.1V480c0-17.62-14.38-32-32-32h-32l128-96v144c0 8.875 7.125 16 16 16h32c8.875 0 16-7.125 16-16V289.9c-10.25 2.625-20.88 4.5-32 4.5C386.2 294.4 334.5 250.4 322.6 192zM480 96h-64l-64-64v134.4c0 53 43 95.1 96 95.1s96-42.1 96-95.1V32L480 96zM408 176c-8.875 0-16-7.125-16-16s7.125-16 16-16s16 7.125 16 16S416.9 176 408 176zM488 176c-8.875 0-16-7.125-16-16s7.125-16 16-16s16 7.125 16 16S496.9 176 488 176z\"\n ]\n};\nvar faCediSign = {\n prefix: 'fas',\n iconName: 'cedi-sign',\n icon: [\n 320,\n 512,\n [],\n \"e0df\",\n \"M224 66.66C254.9 71.84 283.2 84.39 307.2 102.4C321.4 113 324.2 133.1 313.6 147.2C302.1 161.4 282.9 164.2 268.8 153.6C255.6 143.7 240.4 136.3 224 132V379.1C240.4 375.7 255.6 368.3 268.8 358.4C282.9 347.8 302.1 350.6 313.6 364.8C324.2 378.9 321.4 398.1 307.2 409.6C283.2 427.6 254.9 440.2 224 445.3V480C224 497.7 209.7 512 192 512C174.3 512 160 497.7 160 480V445.3C69.19 430.1 0 351.1 0 256C0 160.9 69.19 81.89 160 66.65V32C160 14.33 174.3 0 192 0C209.7 0 224 14.33 224 32V66.66zM160 132C104.8 146.2 64 196.4 64 255.1C64 315.6 104.8 365.8 160 379.1V132z\"\n ]\n};\nvar faCentSign = {\n prefix: 'fas',\n iconName: 'cent-sign',\n icon: [\n 320,\n 512,\n [],\n \"e3f5\",\n \"M192 0C209.7 0 224 14.33 224 32V66.66C254.9 71.84 283.2 84.39 307.2 102.4C321.4 113 324.2 133.1 313.6 147.2C302.1 161.4 282.9 164.2 268.8 153.6C247.4 137.5 220.9 128 192 128C121.3 128 64 185.3 64 256C64 326.7 121.3 384 192 384C220.9 384 247.4 374.5 268.8 358.4C282.9 347.8 302.1 350.6 313.6 364.8C324.2 378.9 321.4 398.1 307.2 409.6C283.2 427.6 254.9 440.2 224 445.3V480C224 497.7 209.7 512 192 512C174.3 512 160 497.7 160 480V445.3C69.19 430.1 0 351.1 0 256C0 160.9 69.19 81.89 160 66.66V32C160 14.33 174.3 .0006 192 .0006V0z\"\n ]\n};\nvar faCertificate = {\n prefix: 'fas',\n iconName: 'certificate',\n icon: [\n 512,\n 512,\n [],\n \"f0a3\",\n \"M256 53.46L300.1 7.261C307 1.034 315.1-1.431 324.4 .8185C332.8 3.068 339.3 9.679 341.4 18.1L357.3 80.6L419.3 63.07C427.7 60.71 436.7 63.05 442.8 69.19C448.1 75.34 451.3 84.33 448.9 92.69L431.4 154.7L493.9 170.6C502.3 172.7 508.9 179.2 511.2 187.6C513.4 196 510.1 204.1 504.7 211L458.5 256L504.7 300.1C510.1 307 513.4 315.1 511.2 324.4C508.9 332.8 502.3 339.3 493.9 341.4L431.4 357.3L448.9 419.3C451.3 427.7 448.1 436.7 442.8 442.8C436.7 448.1 427.7 451.3 419.3 448.9L357.3 431.4L341.4 493.9C339.3 502.3 332.8 508.9 324.4 511.2C315.1 513.4 307 510.1 300.1 504.7L256 458.5L211 504.7C204.1 510.1 196 513.4 187.6 511.2C179.2 508.9 172.7 502.3 170.6 493.9L154.7 431.4L92.69 448.9C84.33 451.3 75.34 448.1 69.19 442.8C63.05 436.7 60.71 427.7 63.07 419.3L80.6 357.3L18.1 341.4C9.679 339.3 3.068 332.8 .8186 324.4C-1.431 315.1 1.034 307 7.261 300.1L53.46 256L7.261 211C1.034 204.1-1.431 196 .8186 187.6C3.068 179.2 9.679 172.7 18.1 170.6L80.6 154.7L63.07 92.69C60.71 84.33 63.05 75.34 69.19 69.19C75.34 63.05 84.33 60.71 92.69 63.07L154.7 80.6L170.6 18.1C172.7 9.679 179.2 3.068 187.6 .8185C196-1.431 204.1 1.034 211 7.261L256 53.46z\"\n ]\n};\nvar faChair = {\n prefix: 'fas',\n iconName: 'chair',\n icon: [\n 448,\n 512,\n [\n 129681\n ],\n \"f6c0\",\n \"M445.1 338.6l-14.77-32C425.1 295.3 413.7 288 401.2 288H46.76C34.28 288 22.94 295.3 17.7 306.6l-14.77 32c-4.563 9.906-3.766 21.47 2.109 30.66S21.09 384 31.1 384l.001 112c0 8.836 7.164 16 16 16h32c8.838 0 16-7.164 16-16V384h256v112c0 8.836 7.164 16 16 16h31.1c8.838 0 16-7.164 16-16L416 384c10.91 0 21.08-5.562 26.95-14.75S449.6 348.5 445.1 338.6zM111.1 128c0-29.48 16.2-54.1 40-68.87L151.1 256h48l.0092-208h48L247.1 256h48l.0093-196.9C319.8 73 335.1 98.52 335.1 128l-.0094 128h48.03l-.0123-128c0-70.69-57.31-128-128-128H191.1C121.3 0 63.98 57.31 63.98 128l.0158 128h47.97L111.1 128z\"\n ]\n};\nvar faChalkboard = {\n prefix: 'fas',\n iconName: 'chalkboard',\n icon: [\n 576,\n 512,\n [\n \"blackboard\"\n ],\n \"f51b\",\n \"M96 96h384v288h64V72C544 50 525.1 32 504 32H72C49.1 32 32 50 32 72V384h64V96zM560 416H416v-48c0-8.838-7.164-16-16-16h-160C231.2 352 224 359.2 224 368V416H16C7.164 416 0 423.2 0 432v32C0 472.8 7.164 480 16 480h544c8.836 0 16-7.164 16-16v-32C576 423.2 568.8 416 560 416z\"\n ]\n};\nvar faBlackboard = faChalkboard;\nvar faChalkboardUser = {\n prefix: 'fas',\n iconName: 'chalkboard-user',\n icon: [\n 640,\n 512,\n [\n \"chalkboard-teacher\"\n ],\n \"f51c\",\n \"M592 0h-384C181.5 0 160 22.25 160 49.63V96c23.42 0 45.1 6.781 63.1 17.81V64h352v288h-64V304c0-8.838-7.164-16-16-16h-96c-8.836 0-16 7.162-16 16V352H287.3c22.07 16.48 39.54 38.5 50.76 64h253.9C618.5 416 640 393.8 640 366.4V49.63C640 22.25 618.5 0 592 0zM160 320c53.02 0 96-42.98 96-96c0-53.02-42.98-96-96-96C106.1 128 64 170.1 64 224C64 277 106.1 320 160 320zM192 352H128c-70.69 0-128 57.31-128 128c0 17.67 14.33 32 32 32h256c17.67 0 32-14.33 32-32C320 409.3 262.7 352 192 352z\"\n ]\n};\nvar faChalkboardTeacher = faChalkboardUser;\nvar faChampagneGlasses = {\n prefix: 'fas',\n iconName: 'champagne-glasses',\n icon: [\n 640,\n 512,\n [\n 129346,\n \"glass-cheers\"\n ],\n \"f79f\",\n \"M639.4 433.6c-8.374-20.37-31.75-30.12-52.12-21.62l-22.12 9.249l-38.75-101.1c47.87-34.1 64.87-100.2 34.5-152.7l-86.62-150.5c-7.999-13.87-24.1-19.75-39.1-13.62l-114.2 47.37L205.8 2.415C190.8-3.71 173.8 2.165 165.8 16.04L79.15 166.5C48.9 219 65.78 284.3 113.6 319.2l-38.75 101.9L52.78 411.9c-20.37-8.499-43.62 1.25-52.12 21.62c-1.75 4.124 .125 8.749 4.25 10.5l162.4 67.37c3.1 1.75 8.624-.125 10.37-4.249c8.374-20.37-1.25-43.87-21.62-52.37l-22.12-9.124l39.37-103.6c4.5 .4999 8.874 1.25 13.12 1.25c51.75 0 99.37-32.1 113.4-85.24l20.25-75.36l20.25 75.36c13.1 52.24 61.62 85.24 113.4 85.24c4.25 0 8.624-.7499 13.12-1.25l39.25 103.6l-22.12 9.124c-20.37 8.499-30.12 31.1-21.62 52.37c1.75 4.124 6.5 5.999 10.5 4.249l162.4-67.37C639.1 442.2 641.1 437.7 639.4 433.6zM275.9 162.1L163.8 115.6l36.5-63.37L294.8 91.4L275.9 162.1zM364.1 162.1l-18.87-70.74l94.49-39.12l36.5 63.37L364.1 162.1z\"\n ]\n};\nvar faGlassCheers = faChampagneGlasses;\nvar faChargingStation = {\n prefix: 'fas',\n iconName: 'charging-station',\n icon: [\n 576,\n 512,\n [],\n \"f5e7\",\n \"M256 0C291.3 0 320 28.65 320 64V256H336C384.6 256 424 295.4 424 344V376C424 389.3 434.7 400 448 400C461.3 400 472 389.3 472 376V252.3C439.5 242.1 416 211.8 416 176V144C416 135.2 423.2 128 432 128H448V80C448 71.16 455.2 64 464 64C472.8 64 480 71.16 480 80V128H512V80C512 71.16 519.2 64 528 64C536.8 64 544 71.16 544 80V128H560C568.8 128 576 135.2 576 144V176C576 211.8 552.5 242.1 520 252.3V376C520 415.8 487.8 448 448 448C408.2 448 376 415.8 376 376V344C376 321.9 358.1 304 336 304H320V448C337.7 448 352 462.3 352 480C352 497.7 337.7 512 320 512H32C14.33 512 0 497.7 0 480C0 462.3 14.33 448 32 448V64C32 28.65 60.65 0 96 0H256zM197.6 83.85L85.59 179.9C80.5 184.2 78.67 191.3 80.99 197.6C83.32 203.8 89.3 208 95.1 208H153.8L128.8 282.9C126.5 289.8 129.1 297.3 135.1 301.3C141 305.3 148.1 304.8 154.4 300.1L266.4 204.1C271.5 199.8 273.3 192.7 271 186.4C268.7 180.2 262.7 176 256 176H198.2L223.2 101.1C225.5 94.24 222.9 86.74 216.9 82.72C210.1 78.71 203 79.17 197.6 83.85V83.85z\"\n ]\n};\nvar faChartArea = {\n prefix: 'fas',\n iconName: 'chart-area',\n icon: [\n 512,\n 512,\n [\n \"area-chart\"\n ],\n \"f1fe\",\n \"M64 400C64 408.8 71.16 416 80 416H480C497.7 416 512 430.3 512 448C512 465.7 497.7 480 480 480H80C35.82 480 0 444.2 0 400V64C0 46.33 14.33 32 32 32C49.67 32 64 46.33 64 64V400zM128 320V236C128 228.3 130.8 220.8 135.9 214.1L215.3 124.2C228.3 109.4 251.4 109.7 263.1 124.8L303.2 171.8C312.2 182.7 328.6 183.4 338.6 173.4L359.6 152.4C372.7 139.3 394.4 140.1 406.5 154.2L472.3 231C477.3 236.8 480 244.2 480 251.8V320C480 337.7 465.7 352 448 352H159.1C142.3 352 127.1 337.7 127.1 320L128 320z\"\n ]\n};\nvar faAreaChart = faChartArea;\nvar faChartBar = {\n prefix: 'fas',\n iconName: 'chart-bar',\n icon: [\n 512,\n 512,\n [\n \"bar-chart\"\n ],\n \"f080\",\n \"M32 32C49.67 32 64 46.33 64 64V400C64 408.8 71.16 416 80 416H480C497.7 416 512 430.3 512 448C512 465.7 497.7 480 480 480H80C35.82 480 0 444.2 0 400V64C0 46.33 14.33 32 32 32zM128 128C128 110.3 142.3 96 160 96H352C369.7 96 384 110.3 384 128C384 145.7 369.7 160 352 160H160C142.3 160 128 145.7 128 128zM288 192C305.7 192 320 206.3 320 224C320 241.7 305.7 256 288 256H160C142.3 256 128 241.7 128 224C128 206.3 142.3 192 160 192H288zM416 288C433.7 288 448 302.3 448 320C448 337.7 433.7 352 416 352H160C142.3 352 128 337.7 128 320C128 302.3 142.3 288 160 288H416z\"\n ]\n};\nvar faBarChart = faChartBar;\nvar faChartColumn = {\n prefix: 'fas',\n iconName: 'chart-column',\n icon: [\n 512,\n 512,\n [],\n \"e0e3\",\n \"M32 32C49.67 32 64 46.33 64 64V400C64 408.8 71.16 416 80 416H480C497.7 416 512 430.3 512 448C512 465.7 497.7 480 480 480H80C35.82 480 0 444.2 0 400V64C0 46.33 14.33 32 32 32zM160 224C177.7 224 192 238.3 192 256V320C192 337.7 177.7 352 160 352C142.3 352 128 337.7 128 320V256C128 238.3 142.3 224 160 224zM288 320C288 337.7 273.7 352 256 352C238.3 352 224 337.7 224 320V160C224 142.3 238.3 128 256 128C273.7 128 288 142.3 288 160V320zM352 192C369.7 192 384 206.3 384 224V320C384 337.7 369.7 352 352 352C334.3 352 320 337.7 320 320V224C320 206.3 334.3 192 352 192zM480 320C480 337.7 465.7 352 448 352C430.3 352 416 337.7 416 320V96C416 78.33 430.3 64 448 64C465.7 64 480 78.33 480 96V320z\"\n ]\n};\nvar faChartGantt = {\n prefix: 'fas',\n iconName: 'chart-gantt',\n icon: [\n 512,\n 512,\n [],\n \"e0e4\",\n \"M32 32C49.67 32 64 46.33 64 64V400C64 408.8 71.16 416 80 416H480C497.7 416 512 430.3 512 448C512 465.7 497.7 480 480 480H80C35.82 480 0 444.2 0 400V64C0 46.33 14.33 32 32 32zM128 128C128 110.3 142.3 96 160 96H256C273.7 96 288 110.3 288 128C288 145.7 273.7 160 256 160H160C142.3 160 128 145.7 128 128zM352 192C369.7 192 384 206.3 384 224C384 241.7 369.7 256 352 256H224C206.3 256 192 241.7 192 224C192 206.3 206.3 192 224 192H352zM448 288C465.7 288 480 302.3 480 320C480 337.7 465.7 352 448 352H384C366.3 352 352 337.7 352 320C352 302.3 366.3 288 384 288H448z\"\n ]\n};\nvar faChartLine = {\n prefix: 'fas',\n iconName: 'chart-line',\n icon: [\n 512,\n 512,\n [\n \"line-chart\"\n ],\n \"f201\",\n \"M64 400C64 408.8 71.16 416 80 416H480C497.7 416 512 430.3 512 448C512 465.7 497.7 480 480 480H80C35.82 480 0 444.2 0 400V64C0 46.33 14.33 32 32 32C49.67 32 64 46.33 64 64V400zM342.6 278.6C330.1 291.1 309.9 291.1 297.4 278.6L240 221.3L150.6 310.6C138.1 323.1 117.9 323.1 105.4 310.6C92.88 298.1 92.88 277.9 105.4 265.4L217.4 153.4C229.9 140.9 250.1 140.9 262.6 153.4L320 210.7L425.4 105.4C437.9 92.88 458.1 92.88 470.6 105.4C483.1 117.9 483.1 138.1 470.6 150.6L342.6 278.6z\"\n ]\n};\nvar faLineChart = faChartLine;\nvar faChartPie = {\n prefix: 'fas',\n iconName: 'chart-pie',\n icon: [\n 576,\n 512,\n [\n \"pie-chart\"\n ],\n \"f200\",\n \"M304 16.58C304 7.555 310.1 0 320 0C443.7 0 544 100.3 544 224C544 233 536.4 240 527.4 240H304V16.58zM32 272C32 150.7 122.1 50.34 238.1 34.25C248.2 32.99 256 40.36 256 49.61V288L412.5 444.5C419.2 451.2 418.7 462.2 411 467.7C371.8 495.6 323.8 512 272 512C139.5 512 32 404.6 32 272zM558.4 288C567.6 288 575 295.8 573.8 305C566.1 360.9 539.1 410.6 499.9 447.3C493.9 452.1 484.5 452.5 478.7 446.7L320 288H558.4z\"\n ]\n};\nvar faPieChart = faChartPie;\nvar faCheck = {\n prefix: 'fas',\n iconName: 'check',\n icon: [\n 448,\n 512,\n [\n 10004,\n 10003\n ],\n \"f00c\",\n \"M438.6 105.4C451.1 117.9 451.1 138.1 438.6 150.6L182.6 406.6C170.1 419.1 149.9 419.1 137.4 406.6L9.372 278.6C-3.124 266.1-3.124 245.9 9.372 233.4C21.87 220.9 42.13 220.9 54.63 233.4L159.1 338.7L393.4 105.4C405.9 92.88 426.1 92.88 438.6 105.4H438.6z\"\n ]\n};\nvar faCheckDouble = {\n prefix: 'fas',\n iconName: 'check-double',\n icon: [\n 448,\n 512,\n [],\n \"f560\",\n \"M182.6 246.6C170.1 259.1 149.9 259.1 137.4 246.6L57.37 166.6C44.88 154.1 44.88 133.9 57.37 121.4C69.87 108.9 90.13 108.9 102.6 121.4L159.1 178.7L297.4 41.37C309.9 28.88 330.1 28.88 342.6 41.37C355.1 53.87 355.1 74.13 342.6 86.63L182.6 246.6zM182.6 470.6C170.1 483.1 149.9 483.1 137.4 470.6L9.372 342.6C-3.124 330.1-3.124 309.9 9.372 297.4C21.87 284.9 42.13 284.9 54.63 297.4L159.1 402.7L393.4 169.4C405.9 156.9 426.1 156.9 438.6 169.4C451.1 181.9 451.1 202.1 438.6 214.6L182.6 470.6z\"\n ]\n};\nvar faCheckToSlot = {\n prefix: 'fas',\n iconName: 'check-to-slot',\n icon: [\n 576,\n 512,\n [\n \"vote-yea\"\n ],\n \"f772\",\n \"M480 80C480 53.49 458.5 32 432 32h-288C117.5 32 96 53.49 96 80V384h384V80zM378.9 166.8l-88 112c-4.031 5.156-10 8.438-16.53 9.062C273.6 287.1 272.7 287.1 271.1 287.1c-5.719 0-11.21-2.019-15.58-5.769l-56-48C190.3 225.6 189.2 210.4 197.8 200.4c8.656-10.06 23.81-11.19 33.84-2.594l36.97 31.69l72.53-92.28c8.188-10.41 23.31-12.22 33.69-4.062C385.3 141.3 387.1 156.4 378.9 166.8zM528 288H512v112c0 8.836-7.164 16-16 16h-416C71.16 416 64 408.8 64 400V288H48C21.49 288 0 309.5 0 336v96C0 458.5 21.49 480 48 480h480c26.51 0 48-21.49 48-48v-96C576 309.5 554.5 288 528 288z\"\n ]\n};\nvar faVoteYea = faCheckToSlot;\nvar faCheese = {\n prefix: 'fas',\n iconName: 'cheese',\n icon: [\n 512,\n 512,\n [],\n \"f7ef\",\n \"M0 288v159.1C0 465.6 14.38 480 32 480h448c17.62 0 32-14.38 32-31.1V288H0zM299.9 32.01c-7.75-.25-15.25 2.25-21.12 6.1L0 255.1l512-.0118C512 136.1 417.1 38.26 299.9 32.01z\"\n ]\n};\nvar faChess = {\n prefix: 'fas',\n iconName: 'chess',\n icon: [\n 512,\n 512,\n [],\n \"f439\",\n \"M74.01 208h-10c-8.875 0-16 7.125-16 16v16c0 8.875 7.122 16 15.1 16h16c-.25 43.13-5.5 86.13-16 128h128c-10.5-41.88-15.75-84.88-16-128h15.1c8.875 0 16-7.125 16-16L208 224c0-8.875-7.122-16-15.1-16h-10l33.88-90.38C216.6 115.8 216.9 113.1 216.9 112.1C216.9 103.1 209.5 96 200.9 96H144V64h16c8.844 0 16-7.156 16-16S168.9 32 160 32h-16l.0033-16c0-8.844-7.16-16-16-16s-16 7.156-16 16V32H96.01c-8.844 0-16 7.156-16 16S87.16 64 96.01 64h16v32H55.13C46.63 96 39.07 102.8 39.07 111.9c0 1.93 .3516 3.865 1.061 5.711L74.01 208zM339.9 301.8L336.6 384h126.8l-3.25-82.25l24.5-20.75C491.9 274.9 496 266 496 256.5V198C496 194.6 493.4 192 489.1 192h-26.37c-3.375 0-6 2.625-6 6V224h-24.75V198C432.9 194.6 430.3 192 426.9 192h-53.75c-3.375 0-6 2.625-6 6V224h-24.75V198C342.4 194.6 339.8 192 336.4 192h-26.38C306.6 192 304 194.6 304 198v58.62c0 9.375 4.125 18.25 11.38 24.38L339.9 301.8zM384 304C384 295.1 391.1 288 400 288S416 295.1 416 304v32h-32V304zM247.1 459.6L224 448v-16C224 423.1 216.9 416 208 416h-160C39.13 416 32 423.1 32 432V448l-23.12 11.62C3.375 462.3 0 467.9 0 473.9V496C0 504.9 7.125 512 16 512h224c8.875 0 16-7.125 16-16v-22.12C256 467.9 252.6 462.3 247.1 459.6zM503.1 459.6L480 448v-16c0-8.875-7.125-16-16-16h-128c-8.875 0-16 7.125-16 16V448l-23.12 11.62C291.4 462.3 288 467.9 288 473.9V496c0 8.875 7.125 16 16 16h192c8.875 0 16-7.125 16-16v-22.12C512 467.9 508.6 462.3 503.1 459.6z\"\n ]\n};\nvar faChessBishop = {\n prefix: 'fas',\n iconName: 'chess-bishop',\n icon: [\n 320,\n 512,\n [\n 9821\n ],\n \"f43a\",\n \"M272 448h-224C21.49 448 0 469.5 0 496C0 504.8 7.164 512 16 512h288c8.836 0 16-7.164 16-16C320 469.5 298.5 448 272 448zM8 287.9c0 51.63 22.12 73.88 56 84.63V416h192v-43.5c33.88-10.75 56-33 56-84.63c0-30.62-10.75-67.13-26.75-102.5L185 285.6c-1.565 1.565-3.608 2.349-5.651 2.349c-2.036 0-4.071-.7787-5.63-2.339l-11.35-11.27c-1.56-1.56-2.339-3.616-2.339-5.672c0-2.063 .7839-4.128 2.349-5.693l107.9-107.9C249.5 117.3 223.8 83 199.4 62.5C213.4 59.13 224 47 224 32c0-17.62-14.38-32-32-32H128C110.4 0 96 14.38 96 32c0 15 10.62 27.12 24.62 30.5C67.75 106.8 8 214.5 8 287.9z\"\n ]\n};\nvar faChessBoard = {\n prefix: 'fas',\n iconName: 'chess-board',\n icon: [\n 448,\n 512,\n [],\n \"f43c\",\n \"M192 224H128v64h64V224zM384 32H64C28.65 32 0 60.65 0 96v320c0 35.35 28.65 64 64 64h320c35.35 0 64-28.65 64-64V96C448 60.65 419.3 32 384 32zM384 160h-64v64h64v64h-64v64h64v64h-64v-64h-64v64H192v-64H128v64H64v-64h64V288H64V224h64V160H64V96h64v64h64V96h64v64h64V96h64V160zM192 288v64h64V288H192zM256 224V160H192v64H256zM256 288h64V224h-64V288z\"\n ]\n};\nvar faChessKing = {\n prefix: 'fas',\n iconName: 'chess-king',\n icon: [\n 448,\n 512,\n [\n 9818\n ],\n \"f43f\",\n \"M367.1 448H79.97c-26.51 0-48.01 21.49-48.01 47.1C31.96 504.8 39.13 512 47.96 512h352c8.838 0 16-7.163 16-16C416 469.5 394.5 448 367.1 448zM416.1 160h-160V112h16.01c17.6 0 31.98-14.4 31.98-32C303.1 62.4 289.6 48 272 48h-16.01V32C256 14.4 241.6 0 223.1 0C206.4 0 191.1 14.4 191.1 32.01V48H175.1c-17.6 0-32.01 14.4-32.01 32C143.1 97.6 158.4 112 175.1 112h16.01V160h-160C17.34 160 0 171.5 0 192C0 195.2 .4735 198.4 1.437 201.5L74.46 416h299.1l73.02-214.5C447.5 198.4 448 195.2 448 192C448 171.6 430.1 160 416.1 160z\"\n ]\n};\nvar faChessKnight = {\n prefix: 'fas',\n iconName: 'chess-knight',\n icon: [\n 384,\n 512,\n [\n 9822\n ],\n \"f441\",\n \"M19 272.5l40.62 18C63.78 292.3 68.25 293.3 72.72 293.3c4 0 8.001-.7543 11.78-2.289l12.75-5.125c9.125-3.625 16-11.12 18.75-20.5L125.2 234.8C127 227.9 131.5 222.2 137.9 219.1L160 208v50.38C160 276.5 149.6 293.1 133.4 301.2L76.25 329.9C49.12 343.5 32 371.1 32 401.5V416h319.9l-.0417-192c0-105.1-85.83-192-191.8-192H12C5.375 32 0 37.38 0 44c0 2.625 .625 5.25 1.75 7.625L16 80L7 89C2.5 93.5 0 99.62 0 106V243.2C0 255.9 7.5 267.4 19 272.5zM52 128C63 128 72 137 72 148S63 168 52 168S32 159 32 148S41 128 52 128zM336 448H47.1C21.49 448 0 469.5 0 495.1C0 504.8 7.163 512 16 512h352c8.837 0 16-7.163 16-16C384 469.5 362.5 448 336 448z\"\n ]\n};\nvar faChessPawn = {\n prefix: 'fas',\n iconName: 'chess-pawn',\n icon: [\n 320,\n 512,\n [\n 9823\n ],\n \"f443\",\n \"M105.1 224H80C71.12 224 64 231.1 64 240v32c0 8.875 7.125 15.1 16 15.1L96 288v5.5C96 337.5 91.88 380.1 72 416h176C228.1 380.1 224 337.5 224 293.5V288l16-.0001c8.875 0 16-7.125 16-15.1v-32C256 231.1 248.9 224 240 224h-25.12C244.3 205.6 264 173.2 264 136C264 78.5 217.5 32 159.1 32S56 78.5 56 136C56 173.2 75.74 205.6 105.1 224zM272 448H47.1C21.49 448 0 469.5 0 495.1C0 504.8 7.163 512 16 512h288c8.837 0 16-7.163 16-16C320 469.5 298.5 448 272 448z\"\n ]\n};\nvar faChessQueen = {\n prefix: 'fas',\n iconName: 'chess-queen',\n icon: [\n 512,\n 512,\n [\n 9819\n ],\n \"f445\",\n \"M256 112c30.88 0 56-25.12 56-56S286.9 0 256 0S199.1 25.12 199.1 56S225.1 112 256 112zM399.1 448H111.1c-26.51 0-48 21.49-48 47.1C63.98 504.8 71.15 512 79.98 512h352c8.837 0 16-7.163 16-16C447.1 469.5 426.5 448 399.1 448zM511.1 197.4c0-5.178-2.509-10.2-7.096-13.26L476.4 168.2c-2.684-1.789-5.602-2.62-8.497-2.62c-17.22 0-17.39 26.37-51.92 26.37c-29.35 0-47.97-25.38-47.97-50.63C367.1 134 361.1 128 354.6 128h-38.75c-6 0-11.63 4-12.88 9.875C298.2 160.1 278.7 176 255.1 176c-22.75 0-42.25-15.88-47-38.12C207.7 132 202.2 128 196.1 128h-38.75C149.1 128 143.1 134 143.1 141.4c0 18.45-13.73 50.62-47.95 50.62c-34.58 0-34.87-26.39-51.87-26.39c-2.909 0-5.805 .8334-8.432 2.645l-28.63 16C2.509 187.2 0 192.3 0 197.4C0 199.9 .5585 202.3 1.72 204.6L104.2 416h303.5l102.5-211.4C511.4 202.3 511.1 199.8 511.1 197.4z\"\n ]\n};\nvar faChessRook = {\n prefix: 'fas',\n iconName: 'chess-rook',\n icon: [\n 384,\n 512,\n [\n 9820\n ],\n \"f447\",\n \"M368 32h-56c-8.875 0-16 7.125-16 16V96h-48V48c0-8.875-7.125-16-16-16h-80c-8.875 0-16 7.125-16 16V96H88.12V48c0-8.875-7.25-16-16-16H16C7.125 32 0 39.12 0 48V224l64 32c0 48.38-1.5 95-13.25 160h282.5C321.5 351 320 303.8 320 256l64-32V48C384 39.12 376.9 32 368 32zM224 320H160V256c0-17.62 14.38-32 32-32s32 14.38 32 32V320zM336 448H47.1C21.49 448 0 469.5 0 495.1C0 504.8 7.163 512 16 512h352c8.837 0 16-7.163 16-16C384 469.5 362.5 448 336 448z\"\n ]\n};\nvar faChevronDown = {\n prefix: 'fas',\n iconName: 'chevron-down',\n icon: [\n 448,\n 512,\n [],\n \"f078\",\n \"M224 416c-8.188 0-16.38-3.125-22.62-9.375l-192-192c-12.5-12.5-12.5-32.75 0-45.25s32.75-12.5 45.25 0L224 338.8l169.4-169.4c12.5-12.5 32.75-12.5 45.25 0s12.5 32.75 0 45.25l-192 192C240.4 412.9 232.2 416 224 416z\"\n ]\n};\nvar faChevronLeft = {\n prefix: 'fas',\n iconName: 'chevron-left',\n icon: [\n 320,\n 512,\n [\n 9001\n ],\n \"f053\",\n \"M224 480c-8.188 0-16.38-3.125-22.62-9.375l-192-192c-12.5-12.5-12.5-32.75 0-45.25l192-192c12.5-12.5 32.75-12.5 45.25 0s12.5 32.75 0 45.25L77.25 256l169.4 169.4c12.5 12.5 12.5 32.75 0 45.25C240.4 476.9 232.2 480 224 480z\"\n ]\n};\nvar faChevronRight = {\n prefix: 'fas',\n iconName: 'chevron-right',\n icon: [\n 320,\n 512,\n [\n 9002\n ],\n \"f054\",\n \"M96 480c-8.188 0-16.38-3.125-22.62-9.375c-12.5-12.5-12.5-32.75 0-45.25L242.8 256L73.38 86.63c-12.5-12.5-12.5-32.75 0-45.25s32.75-12.5 45.25 0l192 192c12.5 12.5 12.5 32.75 0 45.25l-192 192C112.4 476.9 104.2 480 96 480z\"\n ]\n};\nvar faChevronUp = {\n prefix: 'fas',\n iconName: 'chevron-up',\n icon: [\n 448,\n 512,\n [],\n \"f077\",\n \"M416 352c-8.188 0-16.38-3.125-22.62-9.375L224 173.3l-169.4 169.4c-12.5 12.5-32.75 12.5-45.25 0s-12.5-32.75 0-45.25l192-192c12.5-12.5 32.75-12.5 45.25 0l192 192c12.5 12.5 12.5 32.75 0 45.25C432.4 348.9 424.2 352 416 352z\"\n ]\n};\nvar faChild = {\n prefix: 'fas',\n iconName: 'child',\n icon: [\n 448,\n 512,\n [],\n \"f1ae\",\n \"M224 144c39.75 0 72-32.25 72-72S263.8-.0004 224-.0004S151.1 32.25 151.1 72S184.3 144 224 144zM415.1 110.8c-13.89-17.14-39.06-19.8-56.25-5.906L307.6 146.4c-47.16 38.19-120.1 38.19-167.3 0L89.17 104.9C72.02 91 46.8 93.67 32.92 110.8C19.02 128 21.66 153.2 38.83 167.1l51.19 41.47c11.73 9.496 24.63 17.16 37.98 23.92L127.1 480c0 17.62 14.38 32 32 32h15.1c17.62 0 32-14.38 32-32v-112h32V480c0 17.62 14.38 32 32 32h15.1c17.62 0 32-14.38 32-32l-.0001-247.5c13.35-6.756 26.25-14.42 37.97-23.91l51.2-41.47C426.3 153.2 428.1 128 415.1 110.8z\"\n ]\n};\nvar faChurch = {\n prefix: 'fas',\n iconName: 'church',\n icon: [\n 640,\n 512,\n [\n 9962\n ],\n \"f51d\",\n \"M344 48H376C389.3 48 400 58.75 400 72C400 85.25 389.3 96 376 96H344V142.4L456.7 210C471.2 218.7 480 234.3 480 251.2V512H384V416C384 380.7 355.3 352 320 352C284.7 352 256 380.7 256 416V512H160V251.2C160 234.3 168.8 218.7 183.3 210L296 142.4V96H264C250.7 96 240 85.25 240 72C240 58.75 250.7 48 264 48H296V24C296 10.75 306.7 0 320 0C333.3 0 344 10.75 344 24V48zM24.87 330.3L128 273.6V512H48C21.49 512 0 490.5 0 464V372.4C0 354.9 9.53 338.8 24.87 330.3V330.3zM592 512H512V273.6L615.1 330.3C630.5 338.8 640 354.9 640 372.4V464C640 490.5 618.5 512 592 512V512z\"\n ]\n};\nvar faCircle = {\n prefix: 'fas',\n iconName: 'circle',\n icon: [\n 512,\n 512,\n [\n 128308,\n 128309,\n 128992,\n 128993,\n 128994,\n 128995,\n 128996,\n 9898,\n 9899,\n 11044,\n 61708,\n 61915,\n 9679\n ],\n \"f111\",\n \"M512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256z\"\n ]\n};\nvar faCircleArrowDown = {\n prefix: 'fas',\n iconName: 'circle-arrow-down',\n icon: [\n 512,\n 512,\n [\n \"arrow-circle-down\"\n ],\n \"f0ab\",\n \"M256 0C114.6 0 0 114.6 0 256c0 141.4 114.6 256 256 256s256-114.6 256-256C512 114.6 397.4 0 256 0zM382.6 302.6l-103.1 103.1C270.7 414.6 260.9 416 256 416c-4.881 0-14.65-1.391-22.65-9.398L129.4 302.6c-12.5-12.5-12.5-32.75 0-45.25s32.75-12.5 45.25 0L224 306.8V128c0-17.69 14.33-32 32-32s32 14.31 32 32v178.8l49.38-49.38c12.5-12.5 32.75-12.5 45.25 0S395.1 290.1 382.6 302.6z\"\n ]\n};\nvar faArrowCircleDown = faCircleArrowDown;\nvar faCircleArrowLeft = {\n prefix: 'fas',\n iconName: 'circle-arrow-left',\n icon: [\n 512,\n 512,\n [\n \"arrow-circle-left\"\n ],\n \"f0a8\",\n \"M256 0C114.6 0 0 114.6 0 256c0 141.4 114.6 256 256 256s256-114.6 256-256C512 114.6 397.4 0 256 0zM384 288H205.3l49.38 49.38c12.5 12.5 12.5 32.75 0 45.25s-32.75 12.5-45.25 0L105.4 278.6C97.4 270.7 96 260.9 96 256c0-4.883 1.391-14.66 9.398-22.65l103.1-103.1c12.5-12.5 32.75-12.5 45.25 0s12.5 32.75 0 45.25L205.3 224H384c17.69 0 32 14.33 32 32S401.7 288 384 288z\"\n ]\n};\nvar faArrowCircleLeft = faCircleArrowLeft;\nvar faCircleArrowRight = {\n prefix: 'fas',\n iconName: 'circle-arrow-right',\n icon: [\n 512,\n 512,\n [\n \"arrow-circle-right\"\n ],\n \"f0a9\",\n \"M256 0C114.6 0 0 114.6 0 256c0 141.4 114.6 256 256 256s256-114.6 256-256C512 114.6 397.4 0 256 0zM406.6 278.6l-103.1 103.1c-12.5 12.5-32.75 12.5-45.25 0s-12.5-32.75 0-45.25L306.8 288H128C110.3 288 96 273.7 96 256s14.31-32 32-32h178.8l-49.38-49.38c-12.5-12.5-12.5-32.75 0-45.25s32.75-12.5 45.25 0l103.1 103.1C414.6 241.3 416 251.1 416 256C416 260.9 414.6 270.7 406.6 278.6z\"\n ]\n};\nvar faArrowCircleRight = faCircleArrowRight;\nvar faCircleArrowUp = {\n prefix: 'fas',\n iconName: 'circle-arrow-up',\n icon: [\n 512,\n 512,\n [\n \"arrow-circle-up\"\n ],\n \"f0aa\",\n \"M256 0C114.6 0 0 114.6 0 256c0 141.4 114.6 256 256 256s256-114.6 256-256C512 114.6 397.4 0 256 0zM382.6 254.6c-12.5 12.5-32.75 12.5-45.25 0L288 205.3V384c0 17.69-14.33 32-32 32s-32-14.31-32-32V205.3L174.6 254.6c-12.5 12.5-32.75 12.5-45.25 0s-12.5-32.75 0-45.25l103.1-103.1C241.3 97.4 251.1 96 256 96c4.881 0 14.65 1.391 22.65 9.398l103.1 103.1C395.1 221.9 395.1 242.1 382.6 254.6z\"\n ]\n};\nvar faArrowCircleUp = faCircleArrowUp;\nvar faCircleCheck = {\n prefix: 'fas',\n iconName: 'circle-check',\n icon: [\n 512,\n 512,\n [\n 61533,\n \"check-circle\"\n ],\n \"f058\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM371.8 211.8C382.7 200.9 382.7 183.1 371.8 172.2C360.9 161.3 343.1 161.3 332.2 172.2L224 280.4L179.8 236.2C168.9 225.3 151.1 225.3 140.2 236.2C129.3 247.1 129.3 264.9 140.2 275.8L204.2 339.8C215.1 350.7 232.9 350.7 243.8 339.8L371.8 211.8z\"\n ]\n};\nvar faCheckCircle = faCircleCheck;\nvar faCircleChevronDown = {\n prefix: 'fas',\n iconName: 'circle-chevron-down',\n icon: [\n 512,\n 512,\n [\n \"chevron-circle-down\"\n ],\n \"f13a\",\n \"M256 0C114.6 0 0 114.6 0 256c0 141.4 114.6 256 256 256s256-114.6 256-256C512 114.6 397.4 0 256 0zM390.6 246.6l-112 112C272.4 364.9 264.2 368 256 368s-16.38-3.125-22.62-9.375l-112-112c-12.5-12.5-12.5-32.75 0-45.25s32.75-12.5 45.25 0L256 290.8l89.38-89.38c12.5-12.5 32.75-12.5 45.25 0S403.1 234.1 390.6 246.6z\"\n ]\n};\nvar faChevronCircleDown = faCircleChevronDown;\nvar faCircleChevronLeft = {\n prefix: 'fas',\n iconName: 'circle-chevron-left',\n icon: [\n 512,\n 512,\n [\n \"chevron-circle-left\"\n ],\n \"f137\",\n \"M256 0C114.6 0 0 114.6 0 256c0 141.4 114.6 256 256 256s256-114.6 256-256C512 114.6 397.4 0 256 0zM310.6 345.4c12.5 12.5 12.5 32.75 0 45.25s-32.75 12.5-45.25 0l-112-112C147.1 272.4 144 264.2 144 256s3.125-16.38 9.375-22.62l112-112c12.5-12.5 32.75-12.5 45.25 0s12.5 32.75 0 45.25L221.3 256L310.6 345.4z\"\n ]\n};\nvar faChevronCircleLeft = faCircleChevronLeft;\nvar faCircleChevronRight = {\n prefix: 'fas',\n iconName: 'circle-chevron-right',\n icon: [\n 512,\n 512,\n [\n \"chevron-circle-right\"\n ],\n \"f138\",\n \"M256 0C114.6 0 0 114.6 0 256c0 141.4 114.6 256 256 256s256-114.6 256-256C512 114.6 397.4 0 256 0zM358.6 278.6l-112 112c-12.5 12.5-32.75 12.5-45.25 0s-12.5-32.75 0-45.25L290.8 256L201.4 166.6c-12.5-12.5-12.5-32.75 0-45.25s32.75-12.5 45.25 0l112 112C364.9 239.6 368 247.8 368 256S364.9 272.4 358.6 278.6z\"\n ]\n};\nvar faChevronCircleRight = faCircleChevronRight;\nvar faCircleChevronUp = {\n prefix: 'fas',\n iconName: 'circle-chevron-up',\n icon: [\n 512,\n 512,\n [\n \"chevron-circle-up\"\n ],\n \"f139\",\n \"M256 0C114.6 0 0 114.6 0 256c0 141.4 114.6 256 256 256s256-114.6 256-256C512 114.6 397.4 0 256 0zM390.6 310.6c-12.5 12.5-32.75 12.5-45.25 0L256 221.3L166.6 310.6c-12.5 12.5-32.75 12.5-45.25 0s-12.5-32.75 0-45.25l112-112C239.6 147.1 247.8 144 256 144s16.38 3.125 22.62 9.375l112 112C403.1 277.9 403.1 298.1 390.6 310.6z\"\n ]\n};\nvar faChevronCircleUp = faCircleChevronUp;\nvar faCircleDollarToSlot = {\n prefix: 'fas',\n iconName: 'circle-dollar-to-slot',\n icon: [\n 512,\n 512,\n [\n \"donate\"\n ],\n \"f4b9\",\n \"M326.7 403.7C304.7 411.6 280.8 416 256 416C231.2 416 207.3 411.6 185.3 403.7C184.1 403.6 184.7 403.5 184.5 403.4C154.4 392.4 127.6 374.6 105.9 352C70.04 314.6 48 263.9 48 208C48 93.12 141.1 0 256 0C370.9 0 464 93.12 464 208C464 263.9 441.1 314.6 406.1 352C405.1 353 404.1 354.1 403.1 355.1C381.7 376.4 355.7 393.2 326.7 403.7L326.7 403.7zM235.9 111.1V118C230.3 119.2 224.1 120.9 220 123.1C205.1 129.9 192.1 142.5 188.9 160.8C187.1 171 188.1 180.9 192.3 189.8C196.5 198.6 203 204.8 209.6 209.3C221.2 217.2 236.5 221.8 248.2 225.3L250.4 225.9C264.4 230.2 273.8 233.3 279.7 237.6C282.2 239.4 283.1 240.8 283.4 241.7C283.8 242.5 284.4 244.3 283.7 248.3C283.1 251.8 281.2 254.8 275.7 257.1C269.6 259.7 259.7 261 246.9 259C240.9 258 230.2 254.4 220.7 251.2C218.5 250.4 216.3 249.7 214.3 249C203.8 245.5 192.5 251.2 189 261.7C185.5 272.2 191.2 283.5 201.7 286.1C202.9 287.4 204.4 287.9 206.1 288.5C213.1 291.2 226.4 295.4 235.9 297.6V304C235.9 315.1 244.9 324.1 255.1 324.1C267.1 324.1 276.1 315.1 276.1 304V298.5C281.4 297.5 286.6 295.1 291.4 293.9C307.2 287.2 319.8 274.2 323.1 255.2C324.9 244.8 324.1 234.8 320.1 225.7C316.2 216.7 309.9 210.1 303.2 205.3C291.1 196.4 274.9 191.6 262.8 187.9L261.1 187.7C247.8 183.4 238.2 180.4 232.1 176.2C229.5 174.4 228.7 173.2 228.5 172.7C228.3 172.3 227.7 171.1 228.3 167.7C228.7 165.7 230.2 162.4 236.5 159.6C242.1 156.7 252.9 155.1 265.1 156.1C269.5 157.7 283 160.3 286.9 161.3C297.5 164.2 308.5 157.8 311.3 147.1C314.2 136.5 307.8 125.5 297.1 122.7C292.7 121.5 282.7 119.5 276.1 118.3V112C276.1 100.9 267.1 91.9 256 91.9C244.9 91.9 235.9 100.9 235.9 112V111.1zM48 352H63.98C83.43 377.9 108 399.7 136.2 416H64V448H448V416H375.8C403.1 399.7 428.6 377.9 448 352H464C490.5 352 512 373.5 512 400V464C512 490.5 490.5 512 464 512H48C21.49 512 0 490.5 0 464V400C0 373.5 21.49 352 48 352H48z\"\n ]\n};\nvar faDonate = faCircleDollarToSlot;\nvar faCircleDot = {\n prefix: 'fas',\n iconName: 'circle-dot',\n icon: [\n 512,\n 512,\n [\n 128280,\n \"dot-circle\"\n ],\n \"f192\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM256 352C309 352 352 309 352 256C352 202.1 309 160 256 160C202.1 160 160 202.1 160 256C160 309 202.1 352 256 352z\"\n ]\n};\nvar faDotCircle = faCircleDot;\nvar faCircleDown = {\n prefix: 'fas',\n iconName: 'circle-down',\n icon: [\n 512,\n 512,\n [\n 61466,\n \"arrow-alt-circle-down\"\n ],\n \"f358\",\n \"M256 512c141.4 0 256-114.6 256-256s-114.6-256-256-256C114.6 0 0 114.6 0 256S114.6 512 256 512zM129.2 265.9C131.7 259.9 137.5 256 144 256h64V160c0-17.67 14.33-32 32-32h32c17.67 0 32 14.33 32 32v96h64c6.469 0 12.31 3.891 14.78 9.875c2.484 5.984 1.109 12.86-3.469 17.44l-112 112c-6.248 6.248-16.38 6.248-22.62 0l-112-112C128.1 278.7 126.7 271.9 129.2 265.9z\"\n ]\n};\nvar faArrowAltCircleDown = faCircleDown;\nvar faCircleExclamation = {\n prefix: 'fas',\n iconName: 'circle-exclamation',\n icon: [\n 512,\n 512,\n [\n \"exclamation-circle\"\n ],\n \"f06a\",\n \"M256 0C114.6 0 0 114.6 0 256s114.6 256 256 256s256-114.6 256-256S397.4 0 256 0zM232 152C232 138.8 242.8 128 256 128s24 10.75 24 24v128c0 13.25-10.75 24-24 24S232 293.3 232 280V152zM256 400c-17.36 0-31.44-14.08-31.44-31.44c0-17.36 14.07-31.44 31.44-31.44s31.44 14.08 31.44 31.44C287.4 385.9 273.4 400 256 400z\"\n ]\n};\nvar faExclamationCircle = faCircleExclamation;\nvar faCircleH = {\n prefix: 'fas',\n iconName: 'circle-h',\n icon: [\n 512,\n 512,\n [\n 9405,\n \"hospital-symbol\"\n ],\n \"f47e\",\n \"M256 0C114.6 0 0 114.6 0 256s114.6 256 256 256s256-114.6 256-256S397.4 0 256 0zM368 360c0 13.25-10.75 24-24 24S320 373.3 320 360v-80H192v80C192 373.3 181.3 384 168 384S144 373.3 144 360v-208C144 138.8 154.8 128 168 128S192 138.8 192 152v80h128v-80C320 138.8 330.8 128 344 128s24 10.75 24 24V360z\"\n ]\n};\nvar faHospitalSymbol = faCircleH;\nvar faCircleHalfStroke = {\n prefix: 'fas',\n iconName: 'circle-half-stroke',\n icon: [\n 512,\n 512,\n [\n 9680,\n \"adjust\"\n ],\n \"f042\",\n \"M512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM256 64V448C362 448 448 362 448 256C448 149.1 362 64 256 64z\"\n ]\n};\nvar faAdjust = faCircleHalfStroke;\nvar faCircleInfo = {\n prefix: 'fas',\n iconName: 'circle-info',\n icon: [\n 512,\n 512,\n [\n \"info-circle\"\n ],\n \"f05a\",\n \"M256 0C114.6 0 0 114.6 0 256s114.6 256 256 256s256-114.6 256-256S397.4 0 256 0zM256 128c17.67 0 32 14.33 32 32c0 17.67-14.33 32-32 32S224 177.7 224 160C224 142.3 238.3 128 256 128zM296 384h-80C202.8 384 192 373.3 192 360s10.75-24 24-24h16v-64H224c-13.25 0-24-10.75-24-24S210.8 224 224 224h32c13.25 0 24 10.75 24 24v88h16c13.25 0 24 10.75 24 24S309.3 384 296 384z\"\n ]\n};\nvar faInfoCircle = faCircleInfo;\nvar faCircleLeft = {\n prefix: 'fas',\n iconName: 'circle-left',\n icon: [\n 512,\n 512,\n [\n 61840,\n \"arrow-alt-circle-left\"\n ],\n \"f359\",\n \"M0 256c0 141.4 114.6 256 256 256s256-114.6 256-256c0-141.4-114.6-256-256-256S0 114.6 0 256zM246.1 129.2C252.1 131.7 256 137.5 256 144v64h96c17.67 0 32 14.33 32 32v32c0 17.67-14.33 32-32 32h-96v64c0 6.469-3.891 12.31-9.875 14.78c-5.984 2.484-12.86 1.109-17.44-3.469l-112-112c-6.248-6.248-6.248-16.38 0-22.62l112-112C233.3 128.1 240.1 126.7 246.1 129.2z\"\n ]\n};\nvar faArrowAltCircleLeft = faCircleLeft;\nvar faCircleMinus = {\n prefix: 'fas',\n iconName: 'circle-minus',\n icon: [\n 512,\n 512,\n [\n \"minus-circle\"\n ],\n \"f056\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM168 232C154.7 232 144 242.7 144 256C144 269.3 154.7 280 168 280H344C357.3 280 368 269.3 368 256C368 242.7 357.3 232 344 232H168z\"\n ]\n};\nvar faMinusCircle = faCircleMinus;\nvar faCircleNotch = {\n prefix: 'fas',\n iconName: 'circle-notch',\n icon: [\n 512,\n 512,\n [],\n \"f1ce\",\n \"M222.7 32.15C227.7 49.08 218.1 66.9 201.1 71.94C121.8 95.55 64 169.1 64 255.1C64 362 149.1 447.1 256 447.1C362 447.1 448 362 448 255.1C448 169.1 390.2 95.55 310.9 71.94C293.9 66.9 284.3 49.08 289.3 32.15C294.4 15.21 312.2 5.562 329.1 10.6C434.9 42.07 512 139.1 512 255.1C512 397.4 397.4 511.1 256 511.1C114.6 511.1 0 397.4 0 255.1C0 139.1 77.15 42.07 182.9 10.6C199.8 5.562 217.6 15.21 222.7 32.15V32.15z\"\n ]\n};\nvar faCirclePause = {\n prefix: 'fas',\n iconName: 'circle-pause',\n icon: [\n 512,\n 512,\n [\n 62092,\n \"pause-circle\"\n ],\n \"f28b\",\n \"M256 0C114.6 0 0 114.6 0 256s114.6 256 256 256s256-114.6 256-256S397.4 0 256 0zM224 191.1v128C224 337.7 209.7 352 192 352S160 337.7 160 320V191.1C160 174.3 174.3 160 191.1 160S224 174.3 224 191.1zM352 191.1v128C352 337.7 337.7 352 320 352S288 337.7 288 320V191.1C288 174.3 302.3 160 319.1 160S352 174.3 352 191.1z\"\n ]\n};\nvar faPauseCircle = faCirclePause;\nvar faCirclePlay = {\n prefix: 'fas',\n iconName: 'circle-play',\n icon: [\n 512,\n 512,\n [\n 61469,\n \"play-circle\"\n ],\n \"f144\",\n \"M512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM176 168V344C176 352.7 180.7 360.7 188.3 364.9C195.8 369.2 205.1 369 212.5 364.5L356.5 276.5C363.6 272.1 368 264.4 368 256C368 247.6 363.6 239.9 356.5 235.5L212.5 147.5C205.1 142.1 195.8 142.8 188.3 147.1C180.7 151.3 176 159.3 176 168V168z\"\n ]\n};\nvar faPlayCircle = faCirclePlay;\nvar faCirclePlus = {\n prefix: 'fas',\n iconName: 'circle-plus',\n icon: [\n 512,\n 512,\n [\n \"plus-circle\"\n ],\n \"f055\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM256 368C269.3 368 280 357.3 280 344V280H344C357.3 280 368 269.3 368 256C368 242.7 357.3 232 344 232H280V168C280 154.7 269.3 144 256 144C242.7 144 232 154.7 232 168V232H168C154.7 232 144 242.7 144 256C144 269.3 154.7 280 168 280H232V344C232 357.3 242.7 368 256 368z\"\n ]\n};\nvar faPlusCircle = faCirclePlus;\nvar faCircleQuestion = {\n prefix: 'fas',\n iconName: 'circle-question',\n icon: [\n 512,\n 512,\n [\n 62108,\n \"question-circle\"\n ],\n \"f059\",\n \"M256 0C114.6 0 0 114.6 0 256s114.6 256 256 256s256-114.6 256-256S397.4 0 256 0zM256 400c-18 0-32-14-32-32s13.1-32 32-32c17.1 0 32 14 32 32S273.1 400 256 400zM325.1 258L280 286V288c0 13-11 24-24 24S232 301 232 288V272c0-8 4-16 12-21l57-34C308 213 312 206 312 198C312 186 301.1 176 289.1 176h-51.1C225.1 176 216 186 216 198c0 13-11 24-24 24s-24-11-24-24C168 159 199 128 237.1 128h51.1C329 128 360 159 360 198C360 222 347 245 325.1 258z\"\n ]\n};\nvar faQuestionCircle = faCircleQuestion;\nvar faCircleRadiation = {\n prefix: 'fas',\n iconName: 'circle-radiation',\n icon: [\n 512,\n 512,\n [\n 9762,\n \"radiation-alt\"\n ],\n \"f7ba\",\n \"M226.4 208.6L184.8 141.9C179.6 133.7 168.3 132 160.7 138.2C130.8 162.3 110.1 197.4 105.1 237.4C103.9 247.2 111.2 256 121 256H200C200 236 210.6 218.6 226.4 208.6zM256 288c17.67 0 32-14.33 32-32s-14.33-32-32-32C238.3 224 224 238.3 224 256S238.3 288 256 288zM285.6 303.3C276.1 308.7 266.9 312 256 312c-10.89 0-20.98-3.252-29.58-8.65l-41.74 66.8c-5.211 8.338-1.613 19.07 7.27 23.29C211.4 402.7 233.1 408 256 408c22.97 0 44.64-5.334 64.12-14.59c8.883-4.219 12.48-14.95 7.262-23.29L285.6 303.3zM351.4 138.2c-7.604-6.145-18.86-4.518-24.04 3.77l-41.71 66.67C301.4 218.6 312 236 312 256h78.96c9.844 0 17.11-8.791 15.91-18.56C401.9 197.5 381.3 162.4 351.4 138.2zM256 16C123.4 16 16 123.4 16 256s107.4 240 240 240c132.6 0 240-107.4 240-240S388.6 16 256 16zM256 432c-97.05 0-176-78.99-176-176S158.1 80 256 80s176 78.95 176 176S353 432 256 432z\"\n ]\n};\nvar faRadiationAlt = faCircleRadiation;\nvar faCircleRight = {\n prefix: 'fas',\n iconName: 'circle-right',\n icon: [\n 512,\n 512,\n [\n 61838,\n \"arrow-alt-circle-right\"\n ],\n \"f35a\",\n \"M512 256c0-141.4-114.6-256-256-256S0 114.6 0 256c0 141.4 114.6 256 256 256S512 397.4 512 256zM265.9 382.8C259.9 380.3 256 374.5 256 368v-64H160c-17.67 0-32-14.33-32-32v-32c0-17.67 14.33-32 32-32h96v-64c0-6.469 3.891-12.31 9.875-14.78c5.984-2.484 12.86-1.109 17.44 3.469l112 112c6.248 6.248 6.248 16.38 0 22.62l-112 112C278.7 383.9 271.9 385.3 265.9 382.8z\"\n ]\n};\nvar faArrowAltCircleRight = faCircleRight;\nvar faCircleStop = {\n prefix: 'fas',\n iconName: 'circle-stop',\n icon: [\n 512,\n 512,\n [\n 62094,\n \"stop-circle\"\n ],\n \"f28d\",\n \"M256 0C114.6 0 0 114.6 0 256c0 141.4 114.6 256 256 256s256-114.6 256-256C512 114.6 397.4 0 256 0zM352 328c0 13.2-10.8 24-24 24h-144C170.8 352 160 341.2 160 328v-144C160 170.8 170.8 160 184 160h144C341.2 160 352 170.8 352 184V328z\"\n ]\n};\nvar faStopCircle = faCircleStop;\nvar faCircleUp = {\n prefix: 'fas',\n iconName: 'circle-up',\n icon: [\n 512,\n 512,\n [\n 61467,\n \"arrow-alt-circle-up\"\n ],\n \"f35b\",\n \"M256 0C114.6 0 0 114.6 0 256s114.6 256 256 256c141.4 0 256-114.6 256-256S397.4 0 256 0zM382.8 246.1C380.3 252.1 374.5 256 368 256h-64v96c0 17.67-14.33 32-32 32h-32c-17.67 0-32-14.33-32-32V256h-64C137.5 256 131.7 252.1 129.2 246.1C126.7 240.1 128.1 233.3 132.7 228.7l112-112c6.248-6.248 16.38-6.248 22.62 0l112 112C383.9 233.3 385.3 240.1 382.8 246.1z\"\n ]\n};\nvar faArrowAltCircleUp = faCircleUp;\nvar faCircleUser = {\n prefix: 'fas',\n iconName: 'circle-user',\n icon: [\n 512,\n 512,\n [\n 62142,\n \"user-circle\"\n ],\n \"f2bd\",\n \"M256 0C114.6 0 0 114.6 0 256s114.6 256 256 256s256-114.6 256-256S397.4 0 256 0zM256 128c39.77 0 72 32.24 72 72S295.8 272 256 272c-39.76 0-72-32.24-72-72S216.2 128 256 128zM256 448c-52.93 0-100.9-21.53-135.7-56.29C136.5 349.9 176.5 320 224 320h64c47.54 0 87.54 29.88 103.7 71.71C356.9 426.5 308.9 448 256 448z\"\n ]\n};\nvar faUserCircle = faCircleUser;\nvar faCircleXmark = {\n prefix: 'fas',\n iconName: 'circle-xmark',\n icon: [\n 512,\n 512,\n [\n 61532,\n \"times-circle\",\n \"xmark-circle\"\n ],\n \"f057\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM175 208.1L222.1 255.1L175 303C165.7 312.4 165.7 327.6 175 336.1C184.4 346.3 199.6 346.3 208.1 336.1L255.1 289.9L303 336.1C312.4 346.3 327.6 346.3 336.1 336.1C346.3 327.6 346.3 312.4 336.1 303L289.9 255.1L336.1 208.1C346.3 199.6 346.3 184.4 336.1 175C327.6 165.7 312.4 165.7 303 175L255.1 222.1L208.1 175C199.6 165.7 184.4 165.7 175 175C165.7 184.4 165.7 199.6 175 208.1V208.1z\"\n ]\n};\nvar faTimesCircle = faCircleXmark;\nvar faXmarkCircle = faCircleXmark;\nvar faCity = {\n prefix: 'fas',\n iconName: 'city',\n icon: [\n 640,\n 512,\n [\n 127961\n ],\n \"f64f\",\n \"M480 192H592C618.5 192 640 213.5 640 240V464C640 490.5 618.5 512 592 512H48C21.49 512 0 490.5 0 464V144C0 117.5 21.49 96 48 96H64V24C64 10.75 74.75 0 88 0C101.3 0 112 10.75 112 24V96H176V24C176 10.75 186.7 0 200 0C213.3 0 224 10.75 224 24V96H288V48C288 21.49 309.5 0 336 0H432C458.5 0 480 21.49 480 48V192zM576 368C576 359.2 568.8 352 560 352H528C519.2 352 512 359.2 512 368V400C512 408.8 519.2 416 528 416H560C568.8 416 576 408.8 576 400V368zM240 416C248.8 416 256 408.8 256 400V368C256 359.2 248.8 352 240 352H208C199.2 352 192 359.2 192 368V400C192 408.8 199.2 416 208 416H240zM128 368C128 359.2 120.8 352 112 352H80C71.16 352 64 359.2 64 368V400C64 408.8 71.16 416 80 416H112C120.8 416 128 408.8 128 400V368zM528 256C519.2 256 512 263.2 512 272V304C512 312.8 519.2 320 528 320H560C568.8 320 576 312.8 576 304V272C576 263.2 568.8 256 560 256H528zM256 176C256 167.2 248.8 160 240 160H208C199.2 160 192 167.2 192 176V208C192 216.8 199.2 224 208 224H240C248.8 224 256 216.8 256 208V176zM80 160C71.16 160 64 167.2 64 176V208C64 216.8 71.16 224 80 224H112C120.8 224 128 216.8 128 208V176C128 167.2 120.8 160 112 160H80zM256 272C256 263.2 248.8 256 240 256H208C199.2 256 192 263.2 192 272V304C192 312.8 199.2 320 208 320H240C248.8 320 256 312.8 256 304V272zM112 320C120.8 320 128 312.8 128 304V272C128 263.2 120.8 256 112 256H80C71.16 256 64 263.2 64 272V304C64 312.8 71.16 320 80 320H112zM416 272C416 263.2 408.8 256 400 256H368C359.2 256 352 263.2 352 272V304C352 312.8 359.2 320 368 320H400C408.8 320 416 312.8 416 304V272zM368 64C359.2 64 352 71.16 352 80V112C352 120.8 359.2 128 368 128H400C408.8 128 416 120.8 416 112V80C416 71.16 408.8 64 400 64H368zM416 176C416 167.2 408.8 160 400 160H368C359.2 160 352 167.2 352 176V208C352 216.8 359.2 224 368 224H400C408.8 224 416 216.8 416 208V176z\"\n ]\n};\nvar faClapperboard = {\n prefix: 'fas',\n iconName: 'clapperboard',\n icon: [\n 512,\n 512,\n [],\n \"e131\",\n \"M326.1 160l127.4-127.4C451.7 32.39 449.9 32 448 32h-86.06l-128 128H326.1zM166.1 160l128-128H201.9l-128 128H166.1zM497.7 56.19L393.9 160H512V96C512 80.87 506.5 67.15 497.7 56.19zM134.1 32H64C28.65 32 0 60.65 0 96v64h6.062L134.1 32zM0 416c0 35.35 28.65 64 64 64h384c35.35 0 64-28.65 64-64V192H0V416z\"\n ]\n};\nvar faClipboard = {\n prefix: 'fas',\n iconName: 'clipboard',\n icon: [\n 384,\n 512,\n [\n 128203\n ],\n \"f328\",\n \"M336 64h-53.88C268.9 26.8 233.7 0 192 0S115.1 26.8 101.9 64H48C21.5 64 0 85.48 0 112v352C0 490.5 21.5 512 48 512h288c26.5 0 48-21.48 48-48v-352C384 85.48 362.5 64 336 64zM192 64c17.67 0 32 14.33 32 32c0 17.67-14.33 32-32 32S160 113.7 160 96C160 78.33 174.3 64 192 64zM272 224h-160C103.2 224 96 216.8 96 208C96 199.2 103.2 192 112 192h160C280.8 192 288 199.2 288 208S280.8 224 272 224z\"\n ]\n};\nvar faClipboardCheck = {\n prefix: 'fas',\n iconName: 'clipboard-check',\n icon: [\n 384,\n 512,\n [],\n \"f46c\",\n \"M336 64h-53.88C268.9 26.8 233.7 0 192 0S115.1 26.8 101.9 64H48C21.5 64 0 85.48 0 112v352C0 490.5 21.5 512 48 512h288c26.5 0 48-21.48 48-48v-352C384 85.48 362.5 64 336 64zM192 64c17.67 0 32 14.33 32 32s-14.33 32-32 32S160 113.7 160 96S174.3 64 192 64zM282.9 262.8l-88 112c-4.047 5.156-10.02 8.438-16.53 9.062C177.6 383.1 176.8 384 176 384c-5.703 0-11.25-2.031-15.62-5.781l-56-48c-10.06-8.625-11.22-23.78-2.594-33.84c8.609-10.06 23.77-11.22 33.84-2.594l36.98 31.69l72.52-92.28c8.188-10.44 23.3-12.22 33.7-4.062C289.3 237.3 291.1 252.4 282.9 262.8z\"\n ]\n};\nvar faClipboardList = {\n prefix: 'fas',\n iconName: 'clipboard-list',\n icon: [\n 384,\n 512,\n [],\n \"f46d\",\n \"M336 64h-53.88C268.9 26.8 233.7 0 192 0S115.1 26.8 101.9 64H48C21.5 64 0 85.48 0 112v352C0 490.5 21.5 512 48 512h288c26.5 0 48-21.48 48-48v-352C384 85.48 362.5 64 336 64zM96 392c-13.25 0-24-10.75-24-24S82.75 344 96 344s24 10.75 24 24S109.3 392 96 392zM96 296c-13.25 0-24-10.75-24-24S82.75 248 96 248S120 258.8 120 272S109.3 296 96 296zM192 64c17.67 0 32 14.33 32 32c0 17.67-14.33 32-32 32S160 113.7 160 96C160 78.33 174.3 64 192 64zM304 384h-128C167.2 384 160 376.8 160 368C160 359.2 167.2 352 176 352h128c8.801 0 16 7.199 16 16C320 376.8 312.8 384 304 384zM304 288h-128C167.2 288 160 280.8 160 272C160 263.2 167.2 256 176 256h128C312.8 256 320 263.2 320 272C320 280.8 312.8 288 304 288z\"\n ]\n};\nvar faClock = {\n prefix: 'fas',\n iconName: 'clock',\n icon: [\n 512,\n 512,\n [\n 128339,\n \"clock-four\"\n ],\n \"f017\",\n \"M256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512zM232 256C232 264 236 271.5 242.7 275.1L338.7 339.1C349.7 347.3 364.6 344.3 371.1 333.3C379.3 322.3 376.3 307.4 365.3 300L280 243.2V120C280 106.7 269.3 96 255.1 96C242.7 96 231.1 106.7 231.1 120L232 256z\"\n ]\n};\nvar faClockFour = faClock;\nvar faClockRotateLeft = {\n prefix: 'fas',\n iconName: 'clock-rotate-left',\n icon: [\n 512,\n 512,\n [\n \"history\"\n ],\n \"f1da\",\n \"M256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C201.7 512 151.2 495 109.7 466.1C95.2 455.1 91.64 436 101.8 421.5C111.9 407 131.8 403.5 146.3 413.6C177.4 435.3 215.2 448 256 448C362 448 448 362 448 256C448 149.1 362 64 256 64C202.1 64 155 85.46 120.2 120.2L151 151C166.1 166.1 155.4 192 134.1 192H24C10.75 192 0 181.3 0 168V57.94C0 36.56 25.85 25.85 40.97 40.97L74.98 74.98C121.3 28.69 185.3 0 255.1 0L256 0zM256 128C269.3 128 280 138.7 280 152V246.1L344.1 311C354.3 320.4 354.3 335.6 344.1 344.1C335.6 354.3 320.4 354.3 311 344.1L239 272.1C234.5 268.5 232 262.4 232 256V152C232 138.7 242.7 128 256 128V128z\"\n ]\n};\nvar faHistory = faClockRotateLeft;\nvar faClone = {\n prefix: 'fas',\n iconName: 'clone',\n icon: [\n 512,\n 512,\n [],\n \"f24d\",\n \"M0 224C0 188.7 28.65 160 64 160H128V288C128 341 170.1 384 224 384H352V448C352 483.3 323.3 512 288 512H64C28.65 512 0 483.3 0 448V224zM224 352C188.7 352 160 323.3 160 288V64C160 28.65 188.7 0 224 0H448C483.3 0 512 28.65 512 64V288C512 323.3 483.3 352 448 352H224z\"\n ]\n};\nvar faClosedCaptioning = {\n prefix: 'fas',\n iconName: 'closed-captioning',\n icon: [\n 576,\n 512,\n [],\n \"f20a\",\n \"M512 32H64C28.65 32 0 60.65 0 96v320c0 35.35 28.65 64 64 64h448c35.35 0 64-28.65 64-64V96C576 60.65 547.3 32 512 32zM168.6 289.9c18.69 18.72 49.19 18.72 67.87 0c9.375-9.375 24.56-9.375 33.94 0s9.375 24.56 0 33.94c-18.72 18.72-43.28 28.08-67.87 28.08s-49.16-9.359-67.87-28.08C116.5 305.8 106.5 281.6 106.5 256s9.1-49.75 28.12-67.88c37.44-37.44 98.31-37.44 135.7 0c9.375 9.375 9.375 24.56 0 33.94s-24.56 9.375-33.94 0c-18.69-18.72-49.19-18.72-67.87 0C159.5 231.1 154.5 243.2 154.5 256S159.5 280.9 168.6 289.9zM360.6 289.9c18.69 18.72 49.19 18.72 67.87 0c9.375-9.375 24.56-9.375 33.94 0s9.375 24.56 0 33.94c-18.72 18.72-43.28 28.08-67.87 28.08s-49.16-9.359-67.87-28.08C308.5 305.8 298.5 281.6 298.5 256s9.1-49.75 28.12-67.88c37.44-37.44 98.31-37.44 135.7 0c9.375 9.375 9.375 24.56 0 33.94s-24.56 9.375-33.94 0c-18.69-18.72-49.19-18.72-67.87 0C351.5 231.1 346.5 243.2 346.5 256S351.5 280.9 360.6 289.9z\"\n ]\n};\nvar faCloud = {\n prefix: 'fas',\n iconName: 'cloud',\n icon: [\n 640,\n 512,\n [\n 9729\n ],\n \"f0c2\",\n \"M96.2 200.1C96.07 197.4 96 194.7 96 192C96 103.6 167.6 32 256 32C315.3 32 367 64.25 394.7 112.2C409.9 101.1 428.3 96 448 96C501 96 544 138.1 544 192C544 204.2 541.7 215.8 537.6 226.6C596 238.4 640 290.1 640 352C640 422.7 582.7 480 512 480H144C64.47 480 0 415.5 0 336C0 273.2 40.17 219.8 96.2 200.1z\"\n ]\n};\nvar faCloudArrowDown = {\n prefix: 'fas',\n iconName: 'cloud-arrow-down',\n icon: [\n 640,\n 512,\n [\n 62337,\n \"cloud-download\",\n \"cloud-download-alt\"\n ],\n \"f0ed\",\n \"M144 480C64.47 480 0 415.5 0 336C0 273.2 40.17 219.8 96.2 200.1C96.07 197.4 96 194.7 96 192C96 103.6 167.6 32 256 32C315.3 32 367 64.25 394.7 112.2C409.9 101.1 428.3 96 448 96C501 96 544 138.1 544 192C544 204.2 541.7 215.8 537.6 226.6C596 238.4 640 290.1 640 352C640 422.7 582.7 480 512 480H144zM303 392.1C312.4 402.3 327.6 402.3 336.1 392.1L416.1 312.1C426.3 303.6 426.3 288.4 416.1 279C407.6 269.7 392.4 269.7 383 279L344 318.1V184C344 170.7 333.3 160 320 160C306.7 160 296 170.7 296 184V318.1L256.1 279C247.6 269.7 232.4 269.7 223 279C213.7 288.4 213.7 303.6 223 312.1L303 392.1z\"\n ]\n};\nvar faCloudDownload = faCloudArrowDown;\nvar faCloudDownloadAlt = faCloudArrowDown;\nvar faCloudArrowUp = {\n prefix: 'fas',\n iconName: 'cloud-arrow-up',\n icon: [\n 640,\n 512,\n [\n 62338,\n \"cloud-upload\",\n \"cloud-upload-alt\"\n ],\n \"f0ee\",\n \"M144 480C64.47 480 0 415.5 0 336C0 273.2 40.17 219.8 96.2 200.1C96.07 197.4 96 194.7 96 192C96 103.6 167.6 32 256 32C315.3 32 367 64.25 394.7 112.2C409.9 101.1 428.3 96 448 96C501 96 544 138.1 544 192C544 204.2 541.7 215.8 537.6 226.6C596 238.4 640 290.1 640 352C640 422.7 582.7 480 512 480H144zM223 263C213.7 272.4 213.7 287.6 223 296.1C232.4 306.3 247.6 306.3 256.1 296.1L296 257.9V392C296 405.3 306.7 416 320 416C333.3 416 344 405.3 344 392V257.9L383 296.1C392.4 306.3 407.6 306.3 416.1 296.1C426.3 287.6 426.3 272.4 416.1 263L336.1 183C327.6 173.7 312.4 173.7 303 183L223 263z\"\n ]\n};\nvar faCloudUpload = faCloudArrowUp;\nvar faCloudUploadAlt = faCloudArrowUp;\nvar faCloudMeatball = {\n prefix: 'fas',\n iconName: 'cloud-meatball',\n icon: [\n 576,\n 512,\n [],\n \"f73b\",\n \"M80 352C53.5 352 32 373.5 32 400S53.5 448 80 448S128 426.5 128 400S106.5 352 80 352zM496 352c-26.5 0-48 21.5-48 48s21.5 48 48 48s48-21.5 48-48S522.5 352 496 352zM377 363.1c4.625-14.5 1.625-30.88-9.75-42.37c-11.5-11.5-27.87-14.38-42.37-9.875c-7-13.5-20.63-23-36.88-23s-29.88 9.5-36.88 23C236.6 306.2 220.2 309.2 208.8 320.8c-11.5 11.5-14.38 27.87-9.875 42.37c-13.5 7-23 20.63-23 36.88s9.5 29.88 23 36.88c-4.625 14.5-1.625 30.88 9.875 42.37c8.25 8.125 19 12.25 29.75 12.25c4.25 0 8.5-1.125 12.62-2.5C258.1 502.5 271.8 512 288 512s29.88-9.5 36.88-23c4.125 1.25 8.375 2.5 12.62 2.5c10.75 0 21.5-4.125 29.75-12.25c11.5-11.5 14.38-27.87 9.75-42.37C390.5 429.9 400 416.2 400 400S390.5 370.1 377 363.1zM544 224c0-53-43-96-96-96c-.625 0-1.125 .25-1.625 .25C447.5 123 448 117.6 448 112C448 67.75 412.2 32 368 32c-24.62 0-46.25 11.25-61 28.75C288.4 24.75 251.2 0 208 0C146.1 0 96 50.12 96 112c0 7.25 .75 14.25 2.125 21.25C59.75 145.8 32 181.5 32 224c0 53 43 96 96 96h43.38C175 312 179.8 304.6 186.2 298.2C199.8 284.8 217.8 277.1 237 276.9C250.5 263.8 268.8 256 288 256s37.5 7.75 51 20.88c19.25 .25 37.25 7.875 50.75 21.37C396.2 304.6 401.1 312 404.6 320H448C501 320 544 277 544 224z\"\n ]\n};\nvar faCloudMoon = {\n prefix: 'fas',\n iconName: 'cloud-moon',\n icon: [\n 576,\n 512,\n [],\n \"f6c3\",\n \"M342.7 352.7c5.75-9.625 9.25-20.75 9.25-32.75c0-35.25-28.75-64-63.1-64c-17.25 0-32.75 6.875-44.25 17.87C227.4 244.2 196.2 223.1 159.1 223.1c-53 0-96 43.06-96 96.06c0 2 .5029 3.687 .6279 5.687c-37.5 13-64.62 48.38-64.62 90.25C-.0048 468.1 42.99 512 95.99 512h239.1c44.25 0 79.1-35.75 79.1-80C415.1 390.1 383.7 356.2 342.7 352.7zM565.2 298.4c-93 17.75-178.5-53.62-178.5-147.6c0-54.25 28.1-104 76.12-130.9c7.375-4.125 5.375-15.12-2.75-16.63C448.4 1.125 436.7 0 424.1 0c-105.9 0-191.9 85.88-191.9 192c0 8.5 .625 16.75 1.75 25c5.875 4.25 11.62 8.875 16.75 14.25C262.1 226.5 275.2 224 287.1 224c52.88 0 95.1 43.13 95.1 96c0 3.625-.25 7.25-.625 10.75c23.62 10.75 42.37 29.5 53.5 52.5c54.38-3.375 103.7-29.25 137.1-70.37C579.2 306.4 573.5 296.8 565.2 298.4z\"\n ]\n};\nvar faCloudMoonRain = {\n prefix: 'fas',\n iconName: 'cloud-moon-rain',\n icon: [\n 576,\n 512,\n [],\n \"f73c\",\n \"M350.5 225.5c-6.876-37.25-39.25-65.5-78.51-65.5c-12.25 0-23.88 2.1-34.25 7.1C220.3 143.9 192.1 128 160 128c-53.01 0-96.01 42.1-96.01 95.1c0 .5 .25 1.125 .25 1.625C27.63 232.9 0 265.3 0 304c0 44.25 35.75 79.1 80.01 79.1h256c44.25 0 80.01-35.75 80.01-79.1C416 264.8 387.8 232.3 350.5 225.5zM567.9 223.8C497.6 237.1 432.9 183.5 432.9 113c0-40.63 21.88-78 57.5-98.13c5.501-3.125 4.077-11.37-2.173-12.5C479.6 .7538 470.8 0 461.8 0c-77.88 0-141.1 61.25-144.4 137.9c26.75 11.88 48.26 33.88 58.88 61.75c37.13 14.25 64.01 47.38 70.26 86.75c5.126 .5 10.05 1.522 15.3 1.522c44.63 0 85.46-20.15 112.5-53.27C578.6 229.8 574.2 222.6 567.9 223.8zM340.1 426.7l-32 48c-7.345 11.03-4.376 25.94 6.657 33.28C318.8 510.7 323.4 512 327.1 512c7.751 0 15.38-3.75 20-10.69l32-48c7.345-11.03 4.376-25.94-6.657-33.28C362.3 412.7 347.4 415.7 340.1 426.7zM244 426.7l-32 48c-7.345 11.03-4.376 25.94 6.657 33.28C222.8 510.7 227.4 512 231.1 512c7.751 0 15.38-3.75 20-10.69l32-48c7.345-11.03 4.376-25.94-6.657-33.28C266.3 412.7 251.4 415.7 244 426.7zM148 426.7l-32 48c-7.345 11.03-4.376 25.94 6.657 33.28C126.8 510.7 131.4 512 135.1 512c7.751 0 15.38-3.75 20-10.69l32-48c7.345-11.03 4.376-25.94-6.657-33.28C170.3 412.7 155.4 415.7 148 426.7zM52.03 426.7l-32 48c-7.345 11.03-4.376 25.94 6.657 33.28C30.78 510.7 35.41 512 39.97 512c7.751 0 15.38-3.75 20-10.69l32-48c7.345-11.03 4.376-25.94-6.657-33.28C74.25 412.7 59.41 415.7 52.03 426.7z\"\n ]\n};\nvar faCloudRain = {\n prefix: 'fas',\n iconName: 'cloud-rain',\n icon: [\n 512,\n 512,\n [\n 127783,\n 9926\n ],\n \"f73d\",\n \"M416 128c-.625 0-1.125 .25-1.625 .25C415.5 123 416 117.6 416 112C416 67.75 380.3 32 336 32c-24.62 0-46.25 11.25-61 28.75C256.4 24.75 219.3 0 176 0C114.1 0 64 50.13 64 112c0 7.25 .75 14.25 2.125 21.25C27.75 145.8 0 181.5 0 224c0 53 43 96 96 96h320c53 0 96-43 96-96S469 128 416 128zM368 464c0 26.51 21.49 48 48 48s48-21.49 48-48s-48.01-95.1-48.01-95.1S368 437.5 368 464zM48 464C48 490.5 69.49 512 96 512s48-21.49 48-48s-48.01-95.1-48.01-95.1S48 437.5 48 464zM208 464c0 26.51 21.49 48 48 48s48-21.49 48-48s-48.01-95.1-48.01-95.1S208 437.5 208 464z\"\n ]\n};\nvar faCloudShowersHeavy = {\n prefix: 'fas',\n iconName: 'cloud-showers-heavy',\n icon: [\n 512,\n 512,\n [],\n \"f740\",\n \"M416 128c-.625 0-1.125 .25-1.625 .25C415.5 123 416 117.6 416 112c0-44.25-35.75-80-79.1-80c-24.62 0-46.25 11.25-60.1 28.75C256.4 24.75 219.3 0 176 0C114.3 0 64 50.13 64 112c0 7.25 .7512 14.25 2.126 21.25C27.76 145.8 .0054 181.5 .0054 224c0 53 42.1 96 95.1 96h319.1C469 320 512 277 512 224S469 128 416 128zM198.8 353.9c-12.17-5.219-26.3 .4062-31.52 12.59l-47.1 112c-5.219 12.19 .4219 26.31 12.61 31.53C134.1 511.4 138.2 512 141.3 512c9.312 0 18.17-5.438 22.08-14.53l47.1-112C216.6 373.3 210.1 359.2 198.8 353.9zM81.46 353.9c-12.19-5.219-26.3 .4062-31.52 12.59l-47.1 112C-3.276 490.7 2.365 504.8 14.55 510.1C17.63 511.4 20.83 512 23.99 512c9.312 0 18.17-5.438 22.08-14.53l47.1-112C99.29 373.3 93.64 359.2 81.46 353.9zM316.1 353.9c-12.19-5.219-26.3 .4062-31.52 12.59l-47.1 112c-5.219 12.19 .4219 26.31 12.61 31.53C252.3 511.4 255.5 512 258.7 512c9.312 0 18.17-5.438 22.08-14.53l47.1-112C333.1 373.3 328.3 359.2 316.1 353.9zM433.5 353.9c-12.17-5.219-26.28 .4062-31.52 12.59l-47.1 112c-5.219 12.19 .4219 26.31 12.61 31.53C369.6 511.4 372.8 512 375.1 512c9.312 0 18.17-5.438 22.08-14.53l47.1-112C451.3 373.3 445.6 359.2 433.5 353.9z\"\n ]\n};\nvar faCloudSun = {\n prefix: 'fas',\n iconName: 'cloud-sun',\n icon: [\n 640,\n 512,\n [\n 9925\n ],\n \"f6c4\",\n \"M96 208c0-61.86 50.14-111.1 111.1-111.1c52.65 0 96.5 36.45 108.5 85.42C334.7 173.1 354.7 168 375.1 168c4.607 0 9.152 .3809 13.68 .8203l24.13-34.76c5.145-7.414 .8965-17.67-7.984-19.27L317.2 98.78L301.2 10.21C299.6 1.325 289.4-2.919 281.9 2.226L208 53.54L134.1 2.225C126.6-2.92 116.4 1.326 114.8 10.21L98.78 98.78L10.21 114.8C1.326 116.4-2.922 126.7 2.223 134.1l51.3 73.94L2.224 281.9c-5.145 7.414-.8975 17.67 7.983 19.27L98.78 317.2l16.01 88.58c1.604 8.881 11.86 13.13 19.27 7.982l10.71-7.432c2.725-35.15 19.85-66.51 45.83-88.1C137.1 309.8 96 263.9 96 208zM128 208c0 44.18 35.82 80 80 80c9.729 0 18.93-1.996 27.56-5.176c7.002-33.65 25.53-62.85 51.57-83.44C282.8 159.3 249.2 128 208 128C163.8 128 128 163.8 128 208zM575.2 325.6c.125-2 .7453-3.744 .7453-5.619c0-35.38-28.75-64-63.1-64c-12.62 0-24.25 3.749-34.13 9.999c-17.62-38.88-56.5-65.1-101.9-65.1c-61.75 0-112 50.12-112 111.1c0 3 .7522 5.743 .8772 8.618c-49.63 3.75-88.88 44.74-88.88 95.37C175.1 469 218.1 512 271.1 512h272c53 0 96-42.99 96-95.99C639.1 373.9 612.7 338.6 575.2 325.6z\"\n ]\n};\nvar faCloudSunRain = {\n prefix: 'fas',\n iconName: 'cloud-sun-rain',\n icon: [\n 640,\n 512,\n [\n 127782\n ],\n \"f743\",\n \"M255.7 139.1C244.8 125.5 227.6 116 208 116c-33.14 0-60 26.86-60 59.1c0 25.56 16.06 47.24 38.58 55.88C197.2 219.3 210.5 208.9 225.9 201.1C229.1 178.5 240.6 157.3 255.7 139.1zM120 175.1c0-48.6 39.4-87.1 88-87.1c27.8 0 52.29 13.14 68.42 33.27c21.24-15.67 47.22-25.3 75.58-25.3c.0098 0-.0098 0 0 0L300.4 83.58L286.9 8.637C285.9 3.346 281.3 .0003 276.5 .0003c-2.027 0-4.096 .5928-5.955 1.881l-62.57 43.42L145.4 1.882C143.6 .5925 141.5-.0003 139.5-.0003c-4.818 0-9.399 3.346-10.35 8.636l-13.54 74.95L40.64 97.13c-5.289 .9556-8.637 5.538-8.637 10.36c0 2.026 .5921 4.094 1.881 5.951l43.41 62.57L33.88 238.6C32.59 240.4 32 242.5 32 244.5c0 4.817 3.347 9.398 8.636 10.35l74.95 13.54l13.54 74.95c.9555 5.289 5.537 8.636 10.35 8.636c2.027 0 4.096-.5927 5.954-1.882l19.47-13.51c-3.16-10.34-4.934-21.28-4.934-32.64c0-17.17 4.031-33.57 11.14-48.32C141 241.7 120 211.4 120 175.1zM542.5 225.5c-6.875-37.25-39.25-65.5-78.51-65.5c-12.25 0-23.88 3-34.25 8c-17.5-24.13-45.63-40-77.76-40c-53 0-96.01 43-96.01 96c0 .5 .25 1.125 .25 1.625C219.6 232.1 191.1 265.2 191.1 303.1c0 44.25 35.75 80 80.01 80h256C572.2 383.1 608 348.2 608 303.1C608 264.7 579.7 232.2 542.5 225.5zM552 415.1c-7.753 0-15.35 3.752-19.97 10.69l-32 48c-2.731 4.093-4.037 8.719-4.037 13.29C496 501.4 506.9 512 520 512c7.75 0 15.36-3.75 19.98-10.69l32-48c2.731-4.093 4.037-8.719 4.037-13.29C576 426.6 565.1 415.1 552 415.1zM456 415.1c-7.751 0-15.34 3.752-19.98 10.69l-32 48c-2.731 4.093-4.037 8.719-4.037 13.29C400 501.4 410.9 512 423.1 512c7.75 0 15.36-3.75 19.98-10.69l32-48c2.731-4.093 4.037-8.719 4.037-13.29C480 426.6 469.1 415.1 456 415.1zM360 415.1c-7.753 0-15.34 3.752-19.97 10.69l-32 48c-2.731 4.093-4.037 8.719-4.037 13.29C304 501.4 314.9 512 327.1 512c7.75 0 15.36-3.75 19.99-10.69l32-48c2.731-4.093 4.037-8.719 4.037-13.29C384 426.6 373.1 415.1 360 415.1zM264 415.1c-7.756 0-15.35 3.752-19.97 10.69l-32 48c-2.731 4.093-4.037 8.719-4.037 13.29C208 501.4 218.9 512 231.1 512c7.75 0 15.36-3.75 19.98-10.69l32-48c2.731-4.093 4.037-8.719 4.037-13.29C288 426.6 277.1 415.1 264 415.1z\"\n ]\n};\nvar faClover = {\n prefix: 'fas',\n iconName: 'clover',\n icon: [\n 512,\n 512,\n [],\n \"e139\",\n \"M512 302.3c0 35.29-28.99 63.91-64.28 63.91c-38.82 0-88.7-22.75-122.4-40.92c18.17 33.7 40.92 83.57 40.92 122.4c0 35.29-28.61 63.91-63.91 63.91c-18.1 0-34.45-7.52-46.09-19.63C244.6 504.3 228 512 209.7 512c-35.29 0-63.91-28.99-63.91-64.28c0-38.82 22.75-88.7 40.92-122.4c-33.7 18.17-83.57 40.92-122.4 40.92c-35.29 0-63.91-28.61-63.91-63.91c0-18.1 7.52-34.45 19.63-46.09C7.676 244.6 0 228 0 209.7c0-35.29 28.99-63.91 64.28-63.91c38.82 0 88.7 22.75 122.4 40.92C168.5 152.1 145.8 103.1 145.8 64.28c0-35.29 28.61-63.91 63.91-63.91c18.1 0 34.45 7.52 46.09 19.63C267.4 7.676 283.1 0 302.3 0c35.29 0 63.91 28.99 63.91 64.28c0 38.82-22.75 88.7-40.92 122.4c33.7-18.17 83.57-40.92 122.4-40.92c35.29 0 63.91 28.61 63.91 63.91c0 18.1-7.52 34.45-19.63 46.09C504.3 267.4 512 283.1 512 302.3z\"\n ]\n};\nvar faCode = {\n prefix: 'fas',\n iconName: 'code',\n icon: [\n 640,\n 512,\n [],\n \"f121\",\n \"M414.8 40.79L286.8 488.8C281.9 505.8 264.2 515.6 247.2 510.8C230.2 505.9 220.4 488.2 225.2 471.2L353.2 23.21C358.1 6.216 375.8-3.624 392.8 1.232C409.8 6.087 419.6 23.8 414.8 40.79H414.8zM518.6 121.4L630.6 233.4C643.1 245.9 643.1 266.1 630.6 278.6L518.6 390.6C506.1 403.1 485.9 403.1 473.4 390.6C460.9 378.1 460.9 357.9 473.4 345.4L562.7 256L473.4 166.6C460.9 154.1 460.9 133.9 473.4 121.4C485.9 108.9 506.1 108.9 518.6 121.4V121.4zM166.6 166.6L77.25 256L166.6 345.4C179.1 357.9 179.1 378.1 166.6 390.6C154.1 403.1 133.9 403.1 121.4 390.6L9.372 278.6C-3.124 266.1-3.124 245.9 9.372 233.4L121.4 121.4C133.9 108.9 154.1 108.9 166.6 121.4C179.1 133.9 179.1 154.1 166.6 166.6V166.6z\"\n ]\n};\nvar faCodeBranch = {\n prefix: 'fas',\n iconName: 'code-branch',\n icon: [\n 448,\n 512,\n [],\n \"f126\",\n \"M160 80C160 112.8 140.3 140.1 112 153.3V241.1C130.8 230.2 152.7 224 176 224H272C307.3 224 336 195.3 336 160V153.3C307.7 140.1 288 112.8 288 80C288 35.82 323.8 0 368 0C412.2 0 448 35.82 448 80C448 112.8 428.3 140.1 400 153.3V160C400 230.7 342.7 288 272 288H176C140.7 288 112 316.7 112 352V358.7C140.3 371 160 399.2 160 432C160 476.2 124.2 512 80 512C35.82 512 0 476.2 0 432C0 399.2 19.75 371 48 358.7V153.3C19.75 140.1 0 112.8 0 80C0 35.82 35.82 0 80 0C124.2 0 160 35.82 160 80V80zM80 104C93.25 104 104 93.25 104 80C104 66.75 93.25 56 80 56C66.75 56 56 66.75 56 80C56 93.25 66.75 104 80 104zM368 56C354.7 56 344 66.75 344 80C344 93.25 354.7 104 368 104C381.3 104 392 93.25 392 80C392 66.75 381.3 56 368 56zM80 456C93.25 456 104 445.3 104 432C104 418.7 93.25 408 80 408C66.75 408 56 418.7 56 432C56 445.3 66.75 456 80 456z\"\n ]\n};\nvar faCodeCommit = {\n prefix: 'fas',\n iconName: 'code-commit',\n icon: [\n 640,\n 512,\n [],\n \"f386\",\n \"M476.8 288C461.1 361 397.4 416 320 416C242.6 416 178 361 163.2 288H32C14.33 288 0 273.7 0 256C0 238.3 14.33 224 32 224H163.2C178 150.1 242.6 96 320 96C397.4 96 461.1 150.1 476.8 224H608C625.7 224 640 238.3 640 256C640 273.7 625.7 288 608 288H476.8zM320 336C364.2 336 400 300.2 400 256C400 211.8 364.2 176 320 176C275.8 176 240 211.8 240 256C240 300.2 275.8 336 320 336z\"\n ]\n};\nvar faCodeCompare = {\n prefix: 'fas',\n iconName: 'code-compare',\n icon: [\n 512,\n 512,\n [],\n \"e13a\",\n \"M320 488C320 497.5 314.4 506.1 305.8 509.9C297.1 513.8 286.1 512.2 279.9 505.8L199.9 433.8C194.9 429.3 192 422.8 192 416C192 409.2 194.9 402.7 199.9 398.2L279.9 326.2C286.1 319.8 297.1 318.2 305.8 322.1C314.4 325.9 320 334.5 320 344V384H336C371.3 384 400 355.3 400 320V153.3C371.7 140.1 352 112.8 352 80C352 35.82 387.8 0 432 0C476.2 0 512 35.82 512 80C512 112.8 492.3 140.1 464 153.3V320C464 390.7 406.7 448 336 448H320V488zM456 79.1C456 66.74 445.3 55.1 432 55.1C418.7 55.1 408 66.74 408 79.1C408 93.25 418.7 103.1 432 103.1C445.3 103.1 456 93.25 456 79.1zM192 24C192 14.52 197.6 5.932 206.2 2.076C214.9-1.78 225-.1789 232.1 6.161L312.1 78.16C317.1 82.71 320 89.2 320 96C320 102.8 317.1 109.3 312.1 113.8L232.1 185.8C225 192.2 214.9 193.8 206.2 189.9C197.6 186.1 192 177.5 192 168V128H176C140.7 128 112 156.7 112 192V358.7C140.3 371 160 399.2 160 432C160 476.2 124.2 512 80 512C35.82 512 0 476.2 0 432C0 399.2 19.75 371 48 358.7V192C48 121.3 105.3 64 176 64H192V24zM56 432C56 445.3 66.75 456 80 456C93.25 456 104 445.3 104 432C104 418.7 93.25 408 80 408C66.75 408 56 418.7 56 432z\"\n ]\n};\nvar faCodeFork = {\n prefix: 'fas',\n iconName: 'code-fork',\n icon: [\n 448,\n 512,\n [],\n \"e13b\",\n \"M160 80C160 112.8 140.3 140.1 112 153.3V192C112 209.7 126.3 224 144 224H304C321.7 224 336 209.7 336 192V153.3C307.7 140.1 288 112.8 288 80C288 35.82 323.8 0 368 0C412.2 0 448 35.82 448 80C448 112.8 428.3 140.1 400 153.3V192C400 245 357 288 304 288H256V358.7C284.3 371 304 399.2 304 432C304 476.2 268.2 512 224 512C179.8 512 144 476.2 144 432C144 399.2 163.7 371 192 358.7V288H144C90.98 288 48 245 48 192V153.3C19.75 140.1 0 112.8 0 80C0 35.82 35.82 0 80 0C124.2 0 160 35.82 160 80V80zM80 104C93.25 104 104 93.25 104 80C104 66.75 93.25 56 80 56C66.75 56 56 66.75 56 80C56 93.25 66.75 104 80 104zM368 104C381.3 104 392 93.25 392 80C392 66.75 381.3 56 368 56C354.7 56 344 66.75 344 80C344 93.25 354.7 104 368 104zM224 408C210.7 408 200 418.7 200 432C200 445.3 210.7 456 224 456C237.3 456 248 445.3 248 432C248 418.7 237.3 408 224 408z\"\n ]\n};\nvar faCodeMerge = {\n prefix: 'fas',\n iconName: 'code-merge',\n icon: [\n 448,\n 512,\n [],\n \"f387\",\n \"M208 239.1H294.7C307 211.7 335.2 191.1 368 191.1C412.2 191.1 448 227.8 448 271.1C448 316.2 412.2 352 368 352C335.2 352 307 332.3 294.7 303.1H208C171.1 303.1 138.7 292.1 112 272V358.7C140.3 371 160 399.2 160 432C160 476.2 124.2 512 80 512C35.82 512 0 476.2 0 432C0 399.2 19.75 371 48 358.7V153.3C19.75 140.1 0 112.8 0 80C0 35.82 35.82 0 80 0C124.2 0 160 35.82 160 80C160 112.6 140.5 140.7 112.4 153.2C117 201.9 158.1 240 208 240V239.1zM80 103.1C93.25 103.1 104 93.25 104 79.1C104 66.74 93.25 55.1 80 55.1C66.75 55.1 56 66.74 56 79.1C56 93.25 66.75 103.1 80 103.1zM80 456C93.25 456 104 445.3 104 432C104 418.7 93.25 408 80 408C66.75 408 56 418.7 56 432C56 445.3 66.75 456 80 456zM368 247.1C354.7 247.1 344 258.7 344 271.1C344 285.3 354.7 295.1 368 295.1C381.3 295.1 392 285.3 392 271.1C392 258.7 381.3 247.1 368 247.1z\"\n ]\n};\nvar faCodePullRequest = {\n prefix: 'fas',\n iconName: 'code-pull-request',\n icon: [\n 512,\n 512,\n [],\n \"e13c\",\n \"M305.8 2.076C314.4 5.932 320 14.52 320 24V64H336C406.7 64 464 121.3 464 192V358.7C492.3 371 512 399.2 512 432C512 476.2 476.2 512 432 512C387.8 512 352 476.2 352 432C352 399.2 371.7 371 400 358.7V192C400 156.7 371.3 128 336 128H320V168C320 177.5 314.4 186.1 305.8 189.9C297.1 193.8 286.1 192.2 279.9 185.8L199.9 113.8C194.9 109.3 192 102.8 192 96C192 89.2 194.9 82.71 199.9 78.16L279.9 6.161C286.1-.1791 297.1-1.779 305.8 2.077V2.076zM432 456C445.3 456 456 445.3 456 432C456 418.7 445.3 408 432 408C418.7 408 408 418.7 408 432C408 445.3 418.7 456 432 456zM112 358.7C140.3 371 160 399.2 160 432C160 476.2 124.2 512 80 512C35.82 512 0 476.2 0 432C0 399.2 19.75 371 48 358.7V153.3C19.75 140.1 0 112.8 0 80C0 35.82 35.82 .0004 80 .0004C124.2 .0004 160 35.82 160 80C160 112.8 140.3 140.1 112 153.3V358.7zM80 56C66.75 56 56 66.75 56 80C56 93.25 66.75 104 80 104C93.25 104 104 93.25 104 80C104 66.75 93.25 56 80 56zM80 408C66.75 408 56 418.7 56 432C56 445.3 66.75 456 80 456C93.25 456 104 445.3 104 432C104 418.7 93.25 408 80 408z\"\n ]\n};\nvar faCoins = {\n prefix: 'fas',\n iconName: 'coins',\n icon: [\n 512,\n 512,\n [],\n \"f51e\",\n \"M512 80C512 98.01 497.7 114.6 473.6 128C444.5 144.1 401.2 155.5 351.3 158.9C347.7 157.2 343.9 155.5 340.1 153.9C300.6 137.4 248.2 128 192 128C183.7 128 175.6 128.2 167.5 128.6L166.4 128C142.3 114.6 128 98.01 128 80C128 35.82 213.1 0 320 0C426 0 512 35.82 512 80V80zM160.7 161.1C170.9 160.4 181.3 160 192 160C254.2 160 309.4 172.3 344.5 191.4C369.3 204.9 384 221.7 384 240C384 243.1 383.3 247.9 381.9 251.7C377.3 264.9 364.1 277 346.9 287.3C346.9 287.3 346.9 287.3 346.9 287.3C346.8 287.3 346.6 287.4 346.5 287.5L346.5 287.5C346.2 287.7 345.9 287.8 345.6 288C310.6 307.4 254.8 320 192 320C132.4 320 79.06 308.7 43.84 290.9C41.97 289.9 40.15 288.1 38.39 288C14.28 274.6 0 258 0 240C0 205.2 53.43 175.5 128 164.6C138.5 163 149.4 161.8 160.7 161.1L160.7 161.1zM391.9 186.6C420.2 182.2 446.1 175.2 468.1 166.1C484.4 159.3 499.5 150.9 512 140.6V176C512 195.3 495.5 213.1 468.2 226.9C453.5 234.3 435.8 240.5 415.8 245.3C415.9 243.6 416 241.8 416 240C416 218.1 405.4 200.1 391.9 186.6V186.6zM384 336C384 354 369.7 370.6 345.6 384C343.8 384.1 342 385.9 340.2 386.9C304.9 404.7 251.6 416 192 416C129.2 416 73.42 403.4 38.39 384C14.28 370.6 .0003 354 .0003 336V300.6C12.45 310.9 27.62 319.3 43.93 326.1C83.44 342.6 135.8 352 192 352C248.2 352 300.6 342.6 340.1 326.1C347.9 322.9 355.4 319.2 362.5 315.2C368.6 311.8 374.3 308 379.7 304C381.2 302.9 382.6 301.7 384 300.6L384 336zM416 278.1C434.1 273.1 452.5 268.6 468.1 262.1C484.4 255.3 499.5 246.9 512 236.6V272C512 282.5 507 293 497.1 302.9C480.8 319.2 452.1 332.6 415.8 341.3C415.9 339.6 416 337.8 416 336V278.1zM192 448C248.2 448 300.6 438.6 340.1 422.1C356.4 415.3 371.5 406.9 384 396.6V432C384 476.2 298 512 192 512C85.96 512 .0003 476.2 .0003 432V396.6C12.45 406.9 27.62 415.3 43.93 422.1C83.44 438.6 135.8 448 192 448z\"\n ]\n};\nvar faColonSign = {\n prefix: 'fas',\n iconName: 'colon-sign',\n icon: [\n 320,\n 512,\n [],\n \"e140\",\n \"M216.6 65.56C226.4 66.81 235.9 68.8 245.2 71.46L256.1 24.24C261.2 7.093 278.6-3.331 295.8 .9552C312.9 5.242 323.3 22.62 319 39.76L303.1 100C305.1 100.8 306.2 101.6 307.2 102.4C321.4 113 324.2 133.1 313.6 147.2C307.5 155.3 298.4 159.7 288.1 159.1L234.8 376.7C247.1 372.3 258.5 366.1 268.8 358.4C282.9 347.8 302.1 350.6 313.6 364.8C324.2 378.9 321.4 398.1 307.2 409.6C281.5 428.9 250.8 441.9 217.4 446.3L207 487.8C202.8 504.9 185.4 515.3 168.2 511C151.1 506.8 140.7 489.4 144.1 472.2L152.1 443.8C142.4 441.8 133.1 439.1 124.1 435.6L111 487.8C106.8 504.9 89.38 515.3 72.24 511C55.09 506.8 44.67 489.4 48.96 472.2L66.65 401.4C25.84 366.2 0 314.1 0 256C0 164.4 64.09 87.85 149.9 68.64L160.1 24.24C165.2 7.093 182.6-3.331 199.8 .9552C216.9 5.242 227.3 22.62 223 39.76L216.6 65.56zM131.2 143.3C91.17 164.1 64 207.3 64 256C64 282.2 71.85 306.5 85.32 326.8L131.2 143.3zM167.6 381.7L229.6 133.6C220.4 130.8 210.8 128.1 200.9 128.3L139.8 372.9C148.6 376.8 157.9 379.8 167.6 381.7V381.7z\"\n ]\n};\nvar faComment = {\n prefix: 'fas',\n iconName: 'comment',\n icon: [\n 512,\n 512,\n [\n 61669,\n 128489\n ],\n \"f075\",\n \"M256 32C114.6 32 .0272 125.1 .0272 240c0 49.63 21.35 94.98 56.97 130.7c-12.5 50.37-54.27 95.27-54.77 95.77c-2.25 2.25-2.875 5.734-1.5 8.734C1.979 478.2 4.75 480 8 480c66.25 0 115.1-31.76 140.6-51.39C181.2 440.9 217.6 448 256 448c141.4 0 255.1-93.13 255.1-208S397.4 32 256 32z\"\n ]\n};\nvar faCommentDollar = {\n prefix: 'fas',\n iconName: 'comment-dollar',\n icon: [\n 512,\n 512,\n [],\n \"f651\",\n \"M256 31.1c-141.4 0-255.1 93.09-255.1 208c0 49.59 21.37 94.1 56.97 130.7c-12.5 50.39-54.31 95.3-54.81 95.8C0 468.8-.5938 472.2 .6875 475.2C1.1 478.2 4.813 479.1 8 479.1c66.31 0 116-31.8 140.6-51.41c32.72 12.31 69.02 19.41 107.4 19.41c141.4 0 255.1-93.09 255.1-207.1S397.4 31.1 256 31.1zM317.8 282.3c-3.623 20.91-19.47 34.64-41.83 39.43V332c0 11.03-8.946 20-19.99 20S236 343 236 332v-10.77c-8.682-1.922-17.3-4.723-25.06-7.512l-4.266-1.5C196.3 308.5 190.8 297.1 194.5 286.7c3.688-10.41 15.11-15.81 25.52-12.22l4.469 1.625c7.844 2.812 16.72 6 23.66 7.031c13.72 2.125 28.94 .1875 30.31-7.625c.875-5.094 1.359-7.906-27.92-16.28L244.7 257.5c-17.33-5.094-57.92-17-50.52-59.84C197.8 176.8 213.6 162.8 236 157.1V148c0-11.03 8.961-20 20.01-20s19.99 8.969 19.99 20v10.63c5.453 1.195 11.34 2.789 18.56 5.273c10.44 3.625 15.95 15.03 12.33 25.47c-3.625 10.41-15.06 15.94-25.45 12.34c-5.859-2.031-12-4-17.59-4.844C250.2 194.8 234.1 196.7 233.6 204.5C232.8 208.1 232.3 212.2 255.1 219.2l5.547 1.594C283.8 227.1 325.3 239 317.8 282.3z\"\n ]\n};\nvar faCommentDots = {\n prefix: 'fas',\n iconName: 'comment-dots',\n icon: [\n 512,\n 512,\n [\n 62075,\n 128172,\n \"commenting\"\n ],\n \"f4ad\",\n \"M256 31.1c-141.4 0-255.1 93.12-255.1 208c0 49.62 21.35 94.98 56.97 130.7c-12.5 50.37-54.27 95.27-54.77 95.77c-2.25 2.25-2.875 5.734-1.5 8.734c1.249 3 4.021 4.766 7.271 4.766c66.25 0 115.1-31.76 140.6-51.39c32.63 12.25 69.02 19.39 107.4 19.39c141.4 0 255.1-93.13 255.1-207.1S397.4 31.1 256 31.1zM127.1 271.1c-17.75 0-32-14.25-32-31.1s14.25-32 32-32s32 14.25 32 32S145.7 271.1 127.1 271.1zM256 271.1c-17.75 0-31.1-14.25-31.1-31.1s14.25-32 31.1-32s31.1 14.25 31.1 32S273.8 271.1 256 271.1zM383.1 271.1c-17.75 0-32-14.25-32-31.1s14.25-32 32-32s32 14.25 32 32S401.7 271.1 383.1 271.1z\"\n ]\n};\nvar faCommenting = faCommentDots;\nvar faCommentMedical = {\n prefix: 'fas',\n iconName: 'comment-medical',\n icon: [\n 512,\n 512,\n [],\n \"f7f5\",\n \"M256 31.1c-141.4 0-255.1 93.09-255.1 208c0 49.59 21.38 94.1 56.97 130.7c-12.5 50.39-54.31 95.3-54.81 95.8C0 468.8-.5938 472.2 .6875 475.2c1.312 3 4.125 4.797 7.312 4.797c66.31 0 116-31.8 140.6-51.41c32.72 12.31 69.01 19.41 107.4 19.41C397.4 447.1 512 354.9 512 239.1S397.4 31.1 256 31.1zM368 266c0 8.836-7.164 16-16 16h-54V336c0 8.836-7.164 16-16 16h-52c-8.836 0-16-7.164-16-16V282H160c-8.836 0-16-7.164-16-16V214c0-8.838 7.164-16 16-16h53.1V144c0-8.838 7.164-16 16-16h52c8.836 0 16 7.162 16 16v54H352c8.836 0 16 7.162 16 16V266z\"\n ]\n};\nvar faCommentSlash = {\n prefix: 'fas',\n iconName: 'comment-slash',\n icon: [\n 640,\n 512,\n [],\n \"f4b3\",\n \"M64.03 239.1c0 49.59 21.38 94.1 56.97 130.7c-12.5 50.39-54.31 95.3-54.81 95.8c-2.187 2.297-2.781 5.703-1.5 8.703c1.312 3 4.125 4.797 7.312 4.797c66.31 0 116-31.8 140.6-51.41c32.72 12.31 69.02 19.41 107.4 19.41c37.39 0 72.78-6.663 104.8-18.36L82.93 161.7C70.81 185.9 64.03 212.3 64.03 239.1zM630.8 469.1l-118.1-92.59C551.1 340 576 292.4 576 240c0-114.9-114.6-207.1-255.1-207.1c-67.74 0-129.1 21.55-174.9 56.47L38.81 5.117C28.21-3.154 13.16-1.096 5.115 9.19C-3.072 19.63-1.249 34.72 9.188 42.89l591.1 463.1c10.5 8.203 25.57 6.333 33.7-4.073C643.1 492.4 641.2 477.3 630.8 469.1z\"\n ]\n};\nvar faCommentSms = {\n prefix: 'fas',\n iconName: 'comment-sms',\n icon: [\n 512,\n 512,\n [\n \"sms\"\n ],\n \"f7cd\",\n \"M256 32C114.6 32 .0137 125.1 .0137 240c0 49.59 21.39 95 56.99 130.7c-12.5 50.39-54.31 95.3-54.81 95.8C0 468.8-.5938 472.2 .6875 475.2C1.1 478.2 4.813 480 8 480c66.31 0 116-31.8 140.6-51.41C181.3 440.9 217.6 448 256 448C397.4 448 512 354.9 512 240S397.4 32 256 32zM167.3 271.9C163.9 291.1 146.3 304 121.1 304c-4.031 0-8.25-.3125-12.59-1C101.1 301.8 92.81 298.8 85.5 296.1c-8.312-3-14.06-12.66-11.09-20.97S85 261.1 93.38 264.9c6.979 2.498 14.53 5.449 20.88 6.438C125.7 273.1 135 271 135.8 266.4c1.053-5.912-10.84-8.396-24.56-12.34c-12.12-3.531-44.28-12.97-38.63-46c4.062-23.38 27.31-35.91 58-31.09c5.906 .9062 12.44 2.844 18.59 4.969c8.344 2.875 12.78 12 9.906 20.34C156.3 210.7 147.2 215.1 138.8 212.2c-4.344-1.5-8.938-2.938-13.09-3.594c-11.22-1.656-20.72 .4062-21.5 4.906C103.2 219.2 113.6 221.5 124.4 224.6C141.4 229.5 173.1 238.5 167.3 271.9zM320 288c0 8.844-7.156 16-16 16S288 296.8 288 288V240l-19.19 25.59c-6.062 8.062-19.55 8.062-25.62 0L224 240V288c0 8.844-7.156 16-16 16S192 296.8 192 288V192c0-6.875 4.406-12.1 10.94-15.18c6.5-2.094 13.71 .0586 17.87 5.59L256 229.3l35.19-46.93c4.156-5.531 11.4-7.652 17.87-5.59C315.6 179 320 185.1 320 192V288zM439.3 271.9C435.9 291.1 418.3 304 393.1 304c-4.031 0-8.25-.3125-12.59-1c-8.25-1.25-16.56-4.25-23.88-6.906c-8.312-3-14.06-12.66-11.09-20.97s10.59-13.16 18.97-10.19c6.979 2.498 14.53 5.449 20.88 6.438c11.44 1.719 20.78-.375 21.56-4.938c1.053-5.912-10.84-8.396-24.56-12.34c-12.12-3.531-44.28-12.97-38.63-46c4.031-23.38 27.25-35.91 58-31.09c5.906 .9062 12.44 2.844 18.59 4.969c8.344 2.875 12.78 12 9.906 20.34c-2.875 8.344-11.94 12.81-20.34 9.906c-4.344-1.5-8.938-2.938-13.09-3.594c-11.19-1.656-20.72 .4062-21.5 4.906C375.2 219.2 385.6 221.5 396.4 224.6C413.4 229.5 445.1 238.5 439.3 271.9z\"\n ]\n};\nvar faSms = faCommentSms;\nvar faComments = {\n prefix: 'fas',\n iconName: 'comments',\n icon: [\n 640,\n 512,\n [\n 61670,\n 128490\n ],\n \"f086\",\n \"M416 176C416 78.8 322.9 0 208 0S0 78.8 0 176c0 39.57 15.62 75.96 41.67 105.4c-16.39 32.76-39.23 57.32-39.59 57.68c-2.1 2.205-2.67 5.475-1.441 8.354C1.9 350.3 4.602 352 7.66 352c38.35 0 70.76-11.12 95.74-24.04C134.2 343.1 169.8 352 208 352C322.9 352 416 273.2 416 176zM599.6 443.7C624.8 413.9 640 376.6 640 336C640 238.8 554 160 448 160c-.3145 0-.6191 .041-.9336 .043C447.5 165.3 448 170.6 448 176c0 98.62-79.68 181.2-186.1 202.5C282.7 455.1 357.1 512 448 512c33.69 0 65.32-8.008 92.85-21.98C565.2 502 596.1 512 632.3 512c3.059 0 5.76-1.725 7.02-4.605c1.229-2.879 .6582-6.148-1.441-8.354C637.6 498.7 615.9 475.3 599.6 443.7z\"\n ]\n};\nvar faCommentsDollar = {\n prefix: 'fas',\n iconName: 'comments-dollar',\n icon: [\n 640,\n 512,\n [],\n \"f653\",\n \"M416 176C416 78.8 322.9 0 208 0S0 78.8 0 176c0 39.57 15.62 75.96 41.67 105.4c-16.39 32.76-39.23 57.32-39.59 57.68c-2.1 2.205-2.67 5.475-1.441 8.354C1.9 350.3 4.602 352 7.66 352c38.35 0 70.76-11.12 95.74-24.04C134.2 343.1 169.8 352 208 352C322.9 352 416 273.2 416 176zM269.8 218.3C266.2 239.2 250.4 252.1 228 257.7V268c0 11.03-8.953 20-20 20s-20-8.969-20-20V257.2c-8.682-1.922-17.3-4.723-25.06-7.512l-4.266-1.5C148.3 244.5 142.8 233.1 146.5 222.7c3.688-10.41 15.11-15.81 25.52-12.22l4.469 1.625c7.844 2.812 16.72 6 23.66 7.031C213.8 221.3 229 219.3 230.4 211.5C231.3 206.4 231.8 203.6 202.5 195.2L196.7 193.5c-17.33-5.094-57.92-17-50.52-59.84C149.8 112.8 165.6 98.76 188 93.99V84c0-11.03 8.953-20 20-20s20 8.969 20 20v10.63c5.453 1.195 11.34 2.789 18.56 5.273C257 103.5 262.5 114.9 258.9 125.4C255.3 135.8 243.8 141.3 233.4 137.7c-5.859-2.031-12-4-17.59-4.844C202.2 130.8 186.1 132.7 185.6 140.5C184.8 144.1 184.3 148.2 207.1 155.2L213.5 156.8C235.8 163.1 277.3 175 269.8 218.3zM599.6 443.7C624.8 413.9 640 376.6 640 336C640 238.8 554 160 448 160c-.3145 0-.6191 .041-.9336 .043C447.5 165.3 448 170.6 448 176c0 98.62-79.68 181.2-186.1 202.5C282.7 455.1 357.1 512 448 512c33.69 0 65.32-8.008 92.85-21.98C565.2 502 596.1 512 632.3 512c3.059 0 5.76-1.725 7.02-4.605c1.229-2.879 .6582-6.148-1.441-8.354C637.6 498.7 615.9 475.3 599.6 443.7z\"\n ]\n};\nvar faCompactDisc = {\n prefix: 'fas',\n iconName: 'compact-disc',\n icon: [\n 512,\n 512,\n [\n 128192,\n 128440,\n 128191\n ],\n \"f51f\",\n \"M256 0C114.6 0 0 114.6 0 256s114.6 256 256 256s256-114.6 256-256S397.4 0 256 0zM80.72 256H79.63c-9.078 0-16.4-8.011-15.56-17.34C72.36 146 146.5 72.06 239.3 64.06C248.3 63.28 256 70.75 256 80.09c0 8.35-6.215 15.28-14.27 15.99C164.7 102.9 103.1 164.3 96.15 241.4C95.4 249.6 88.77 256 80.72 256zM256 351.1c-53.02 0-96-43-96-95.1s42.98-96 96-96s96 43 96 96S309 351.1 256 351.1zM256 224C238.3 224 224 238.2 224 256s14.3 32 32 32c17.7 0 32-14.25 32-32S273.7 224 256 224z\"\n ]\n};\nvar faCompass = {\n prefix: 'fas',\n iconName: 'compass',\n icon: [\n 512,\n 512,\n [\n 129517\n ],\n \"f14e\",\n \"M288 256C288 273.7 273.7 288 256 288C238.3 288 224 273.7 224 256C224 238.3 238.3 224 256 224C273.7 224 288 238.3 288 256zM0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM325.1 306.7L380.6 162.4C388.1 142.1 369 123.9 349.6 131.4L205.3 186.9C196.8 190.1 190.1 196.8 186.9 205.3L131.4 349.6C123.9 369 142.1 388.1 162.4 380.6L306.7 325.1C315.2 321.9 321.9 315.2 325.1 306.7V306.7z\"\n ]\n};\nvar faCompassDrafting = {\n prefix: 'fas',\n iconName: 'compass-drafting',\n icon: [\n 512,\n 512,\n [\n \"drafting-compass\"\n ],\n \"f568\",\n \"M352 96C352 110.3 348.9 123.9 343.2 136.2L396 227.4C372.3 252.7 341.9 271.5 307.6 281L256 192H255.1L187.9 309.5C209.4 316.3 232.3 320 256 320C326.7 320 389.8 287.3 430.9 235.1C441.9 222.2 462.1 219.1 475.9 231C489.7 242.1 491.9 262.2 480.8 276C428.1 341.8 346.1 384 256 384C220.6 384 186.6 377.6 155.3 365.9L98.65 463.7C93.95 471.8 86.97 478.4 78.58 482.6L23.16 510.3C18.2 512.8 12.31 512.5 7.588 509.6C2.871 506.7 0 501.5 0 496V440.6C0 432.2 2.228 423.9 6.46 416.5L66.49 312.9C53.66 301.6 41.84 289.3 31.18 276C20.13 262.2 22.34 242.1 36.13 231C49.92 219.1 70.06 222.2 81.12 235.1C86.79 243.1 92.87 249.8 99.34 256.1L168.8 136.2C163.1 123.9 160 110.3 160 96C160 42.98 202.1 0 256 0C309 0 352 42.98 352 96L352 96zM256 128C273.7 128 288 113.7 288 96C288 78.33 273.7 64 256 64C238.3 64 224 78.33 224 96C224 113.7 238.3 128 256 128zM372.1 393.9C405.5 381.1 435.5 363.2 461.8 341L505.5 416.5C509.8 423.9 512 432.2 512 440.6V496C512 501.5 509.1 506.7 504.4 509.6C499.7 512.5 493.8 512.8 488.8 510.3L433.4 482.6C425 478.4 418.1 471.8 413.3 463.7L372.1 393.9z\"\n ]\n};\nvar faDraftingCompass = faCompassDrafting;\nvar faCompress = {\n prefix: 'fas',\n iconName: 'compress',\n icon: [\n 448,\n 512,\n [],\n \"f066\",\n \"M128 320H32c-17.69 0-32 14.31-32 32s14.31 32 32 32h64v64c0 17.69 14.31 32 32 32s32-14.31 32-32v-96C160 334.3 145.7 320 128 320zM416 320h-96c-17.69 0-32 14.31-32 32v96c0 17.69 14.31 32 32 32s32-14.31 32-32v-64h64c17.69 0 32-14.31 32-32S433.7 320 416 320zM320 192h96c17.69 0 32-14.31 32-32s-14.31-32-32-32h-64V64c0-17.69-14.31-32-32-32s-32 14.31-32 32v96C288 177.7 302.3 192 320 192zM128 32C110.3 32 96 46.31 96 64v64H32C14.31 128 0 142.3 0 160s14.31 32 32 32h96c17.69 0 32-14.31 32-32V64C160 46.31 145.7 32 128 32z\"\n ]\n};\nvar faComputerMouse = {\n prefix: 'fas',\n iconName: 'computer-mouse',\n icon: [\n 384,\n 512,\n [\n 128433,\n \"mouse\"\n ],\n \"f8cc\",\n \"M0 352c0 88.38 71.63 160 160 160h64c88.38 0 160-71.63 160-160V224H0V352zM176 0H160C71.63 0 0 71.62 0 160v32h176V0zM224 0h-16v192H384V160C384 71.62 312.4 0 224 0z\"\n ]\n};\nvar faMouse = faComputerMouse;\nvar faCookie = {\n prefix: 'fas',\n iconName: 'cookie',\n icon: [\n 512,\n 512,\n [\n 127850\n ],\n \"f563\",\n \"M494.5 254.8l-11.37-71.48c-4.102-25.9-16.29-49.8-34.8-68.32l-51.33-51.33c-18.52-18.52-42.3-30.7-68.2-34.8L256.9 17.53C231.2 13.42 204.7 17.64 181.5 29.48L116.7 62.53C93.23 74.36 74.36 93.35 62.41 116.7L29.51 181.2c-11.84 23.44-16.08 50.04-11.98 75.94l11.37 71.48c4.101 25.9 16.29 49.77 34.8 68.41l51.33 51.33c18.52 18.4 42.3 30.61 68.2 34.72l71.84 11.37c25.78 4.102 52.27-.1173 75.47-11.95l64.8-33.05c23.32-11.84 42.3-30.82 54.26-54.14l32.81-64.57C494.4 307.3 498.6 280.8 494.5 254.8zM176 367.1c-17.62 0-31.1-14.37-31.1-31.1c0-17.62 14.37-31.1 31.1-31.1s31.1 14.37 31.1 31.1C208 353.6 193.6 367.1 176 367.1zM208 208c-17.62 0-31.1-14.37-31.1-31.1s14.38-31.1 31.1-31.1c17.62 0 31.1 14.37 31.1 31.1S225.6 208 208 208zM368 335.1c-17.62 0-31.1-14.37-31.1-31.1c0-17.62 14.37-31.1 31.1-31.1s31.1 14.37 31.1 31.1C400 321.6 385.6 335.1 368 335.1z\"\n ]\n};\nvar faCookieBite = {\n prefix: 'fas',\n iconName: 'cookie-bite',\n icon: [\n 512,\n 512,\n [],\n \"f564\",\n \"M494.6 255.9c-65.63-.8203-118.6-54.14-118.6-119.9c-65.74 0-119.1-52.97-119.8-118.6c-25.66-3.867-51.8 .2346-74.77 12.07L116.7 62.41C93.35 74.36 74.36 93.35 62.41 116.7L29.6 181.2c-11.95 23.44-16.17 49.92-12.07 75.94l11.37 71.48c4.102 25.9 16.29 49.8 34.81 68.32l51.36 51.39C133.6 466.9 157.3 479 183.2 483.1l71.84 11.37c25.9 4.101 52.27-.1172 75.59-11.95l64.81-33.05c23.32-11.84 42.31-30.82 54.14-54.14l32.93-64.57C494.3 307.7 498.5 281.4 494.6 255.9zM176 367.1c-17.62 0-32-14.37-32-31.1s14.38-31.1 32-31.1s32 14.37 32 31.1S193.6 367.1 176 367.1zM208 208c-17.62 0-32-14.37-32-31.1s14.38-31.1 32-31.1s32 14.37 32 31.1S225.6 208 208 208zM368 335.1c-17.62 0-32-14.37-32-31.1s14.38-31.1 32-31.1s32 14.37 32 31.1S385.6 335.1 368 335.1z\"\n ]\n};\nvar faCopy = {\n prefix: 'fas',\n iconName: 'copy',\n icon: [\n 512,\n 512,\n [],\n \"f0c5\",\n \"M384 96L384 0h-112c-26.51 0-48 21.49-48 48v288c0 26.51 21.49 48 48 48H464c26.51 0 48-21.49 48-48V128h-95.1C398.4 128 384 113.6 384 96zM416 0v96h96L416 0zM192 352V128h-144c-26.51 0-48 21.49-48 48v288c0 26.51 21.49 48 48 48h192c26.51 0 48-21.49 48-48L288 416h-32C220.7 416 192 387.3 192 352z\"\n ]\n};\nvar faCopyright = {\n prefix: 'fas',\n iconName: 'copyright',\n icon: [\n 512,\n 512,\n [\n 169\n ],\n \"f1f9\",\n \"M256 0C114.6 0 0 114.6 0 256s114.6 256 256 256s256-114.6 256-256S397.4 0 256 0zM199.2 312.6c14.94 15.06 34.8 23.38 55.89 23.38c.0313 0 0 0 0 0c21.06 0 40.92-8.312 55.83-23.38c9.375-9.375 24.53-9.469 33.97-.1562c9.406 9.344 9.469 24.53 .1562 33.97c-24 24.22-55.95 37.56-89.95 37.56c0 0 .0313 0 0 0c-33.97 0-65.95-13.34-89.95-37.56c-49.44-49.88-49.44-131 0-180.9c24-24.22 55.98-37.56 89.95-37.56c.0313 0 0 0 0 0c34 0 65.95 13.34 89.95 37.56c9.312 9.438 9.25 24.62-.1562 33.97c-9.438 9.344-24.59 9.188-33.97-.1562c-14.91-15.06-34.77-23.38-55.83-23.38c0 0 .0313 0 0 0c-21.09 0-40.95 8.312-55.89 23.38C168.3 230.6 168.3 281.4 199.2 312.6z\"\n ]\n};\nvar faCouch = {\n prefix: 'fas',\n iconName: 'couch',\n icon: [\n 640,\n 512,\n [],\n \"f4b8\",\n \"M592 224C565.5 224 544 245.5 544 272V352H96V272C96 245.5 74.51 224 48 224S0 245.5 0 272v192C0 472.8 7.164 480 16 480h64c8.836 0 15.1-7.164 15.1-16L96 448h448v16c0 8.836 7.164 16 16 16h64c8.836 0 16-7.164 16-16v-192C640 245.5 618.5 224 592 224zM128 272V320h384V272c0-38.63 27.53-70.95 64-78.38V160c0-70.69-57.31-128-128-128H191.1c-70.69 0-128 57.31-128 128L64 193.6C100.5 201.1 128 233.4 128 272z\"\n ]\n};\nvar faCreditCard = {\n prefix: 'fas',\n iconName: 'credit-card',\n icon: [\n 576,\n 512,\n [\n 62083,\n 128179,\n \"credit-card-alt\"\n ],\n \"f09d\",\n \"M512 32C547.3 32 576 60.65 576 96V128H0V96C0 60.65 28.65 32 64 32H512zM576 416C576 451.3 547.3 480 512 480H64C28.65 480 0 451.3 0 416V224H576V416zM112 352C103.2 352 96 359.2 96 368C96 376.8 103.2 384 112 384H176C184.8 384 192 376.8 192 368C192 359.2 184.8 352 176 352H112zM240 384H368C376.8 384 384 376.8 384 368C384 359.2 376.8 352 368 352H240C231.2 352 224 359.2 224 368C224 376.8 231.2 384 240 384z\"\n ]\n};\nvar faCreditCardAlt = faCreditCard;\nvar faCrop = {\n prefix: 'fas',\n iconName: 'crop',\n icon: [\n 512,\n 512,\n [],\n \"f125\",\n \"M448 384H480C497.7 384 512 398.3 512 416C512 433.7 497.7 448 480 448H448V480C448 497.7 433.7 512 416 512C398.3 512 384 497.7 384 480V173.3L173.3 384H352V448H128C92.65 448 64 419.3 64 384V128H32C14.33 128 0 113.7 0 96C0 78.33 14.33 64 32 64H64V32C64 14.33 78.33 0 96 0C113.7 0 128 14.33 128 32V338.7L338.7 128H160V64H402.7L457.4 9.372C469.9-3.124 490.1-3.124 502.6 9.372C515.1 21.87 515.1 42.13 502.6 54.63L448 109.3V384z\"\n ]\n};\nvar faCropSimple = {\n prefix: 'fas',\n iconName: 'crop-simple',\n icon: [\n 512,\n 512,\n [\n \"crop-alt\"\n ],\n \"f565\",\n \"M128 384H352V448H128C92.65 448 64 419.3 64 384V128H32C14.33 128 0 113.7 0 96C0 78.33 14.33 64 32 64H64V32C64 14.33 78.33 0 96 0C113.7 0 128 14.33 128 32V384zM384 128H160V64H384C419.3 64 448 92.65 448 128V384H480C497.7 384 512 398.3 512 416C512 433.7 497.7 448 480 448H448V480C448 497.7 433.7 512 416 512C398.3 512 384 497.7 384 480V128z\"\n ]\n};\nvar faCropAlt = faCropSimple;\nvar faCross = {\n prefix: 'fas',\n iconName: 'cross',\n icon: [\n 384,\n 512,\n [\n 128327,\n 10013\n ],\n \"f654\",\n \"M383.1 160v64c0 17.62-14.37 32-31.1 32h-96v224c0 17.62-14.38 32-31.1 32H160c-17.62 0-32-14.38-32-32V256h-96C14.37 256-.0008 241.6-.0008 224V160c0-17.62 14.38-32 32-32h96V32c0-17.62 14.38-32 32-32h64c17.62 0 31.1 14.38 31.1 32v96h96C369.6 128 383.1 142.4 383.1 160z\"\n ]\n};\nvar faCrosshairs = {\n prefix: 'fas',\n iconName: 'crosshairs',\n icon: [\n 512,\n 512,\n [],\n \"f05b\",\n \"M224 256C224 238.3 238.3 224 256 224C273.7 224 288 238.3 288 256C288 273.7 273.7 288 256 288C238.3 288 224 273.7 224 256zM256 0C273.7 0 288 14.33 288 32V42.35C381.7 56.27 455.7 130.3 469.6 224H480C497.7 224 512 238.3 512 256C512 273.7 497.7 288 480 288H469.6C455.7 381.7 381.7 455.7 288 469.6V480C288 497.7 273.7 512 256 512C238.3 512 224 497.7 224 480V469.6C130.3 455.7 56.27 381.7 42.35 288H32C14.33 288 0 273.7 0 256C0 238.3 14.33 224 32 224H42.35C56.27 130.3 130.3 56.27 224 42.35V32C224 14.33 238.3 0 256 0V0zM224 404.6V384C224 366.3 238.3 352 256 352C273.7 352 288 366.3 288 384V404.6C346.3 392.1 392.1 346.3 404.6 288H384C366.3 288 352 273.7 352 256C352 238.3 366.3 224 384 224H404.6C392.1 165.7 346.3 119.9 288 107.4V128C288 145.7 273.7 160 256 160C238.3 160 224 145.7 224 128V107.4C165.7 119.9 119.9 165.7 107.4 224H128C145.7 224 160 238.3 160 256C160 273.7 145.7 288 128 288H107.4C119.9 346.3 165.7 392.1 224 404.6z\"\n ]\n};\nvar faCrow = {\n prefix: 'fas',\n iconName: 'crow',\n icon: [\n 640,\n 512,\n [],\n \"f520\",\n \"M523.9 31.1H574C603.4 31.1 628.1 51.99 636.1 80.48L640 95.1L544 119.1V191.1C544 279.1 484.9 354.1 404.2 376.8L446.2 478.9C451.2 491.1 445.4 505.1 433.1 510.2C420.9 515.2 406.9 509.4 401.8 497.1L355.2 383.1C354.1 383.1 353.1 384 352 384H311.1L350.2 478.9C355.2 491.1 349.4 505.1 337.1 510.2C324.9 515.2 310.9 509.4 305.8 497.1L259.2 384H126.1L51.51 441.4C37.5 452.1 17.41 449.5 6.638 435.5C-4.138 421.5-1.517 401.4 12.49 390.6L368 117.2V88C368 39.4 407.4 0 456 0C483.3 0 507.7 12.46 523.9 32V31.1zM456 111.1C469.3 111.1 480 101.3 480 87.1C480 74.74 469.3 63.1 456 63.1C442.7 63.1 432 74.74 432 87.1C432 101.3 442.7 111.1 456 111.1z\"\n ]\n};\nvar faCrown = {\n prefix: 'fas',\n iconName: 'crown',\n icon: [\n 576,\n 512,\n [\n 128081\n ],\n \"f521\",\n \"M576 136c0 22.09-17.91 40-40 40c-.248 0-.4551-.1266-.7031-.1305l-50.52 277.9C482 468.9 468.8 480 453.3 480H122.7c-15.46 0-28.72-11.06-31.48-26.27L40.71 175.9C40.46 175.9 40.25 176 39.1 176c-22.09 0-40-17.91-40-40S17.91 96 39.1 96s40 17.91 40 40c0 8.998-3.521 16.89-8.537 23.57l89.63 71.7c15.91 12.73 39.5 7.544 48.61-10.68l57.6-115.2C255.1 98.34 247.1 86.34 247.1 72C247.1 49.91 265.9 32 288 32s39.1 17.91 39.1 40c0 14.34-7.963 26.34-19.3 33.4l57.6 115.2c9.111 18.22 32.71 23.4 48.61 10.68l89.63-71.7C499.5 152.9 496 144.1 496 136C496 113.9 513.9 96 536 96S576 113.9 576 136z\"\n ]\n};\nvar faCrutch = {\n prefix: 'fas',\n iconName: 'crutch',\n icon: [\n 512,\n 512,\n [],\n \"f7f7\",\n \"M502.6 168.1l-159.6-159.5c-12.54-12.54-32.85-12.6-45.46-.1256c-12.68 12.54-12.73 33.1-.1256 45.71l159.6 159.5c12.6 12.59 33.03 12.57 45.59-.0628C515.1 201.9 515.1 181.5 502.6 168.1zM334.4 245.4l-67.88-67.87l55.13-55.12l-45.25-45.25L166.7 186.8C154.1 199.6 145.2 215.6 141.1 233.2L113.3 353.4l-108.6 108.6c-6.25 6.25-6.25 16.37 0 22.62l22.63 22.62c6.25 6.25 16.38 6.25 22.63 0l108.6-108.6l120.3-27.75c17.5-4.125 33.63-13 46.38-25.62l109.6-109.7l-45.25-45.25L334.4 245.4zM279.9 300.1C275.7 304.2 270.3 307.2 264.4 308.6l-79.25 18.25l18.25-79.25c1.375-5.875 4.375-11.25 8.5-15.5l9.375-9.25l67.88 67.87L279.9 300.1z\"\n ]\n};\nvar faCruzeiroSign = {\n prefix: 'fas',\n iconName: 'cruzeiro-sign',\n icon: [\n 384,\n 512,\n [],\n \"e152\",\n \"M159.1 402.7V256C159.1 238.3 174.3 224 191.1 224C199.7 224 206.8 226.7 212.3 231.3C223 226.6 234.8 224 247.3 224C264.5 224 281.3 229.1 295.7 238.7L305.8 245.4C320.5 255.2 324.4 275 314.6 289.8C304.8 304.5 284.1 308.4 270.2 298.6L260.2 291.9C256.3 289.4 251.9 288 247.3 288C234.4 288 224 298.4 224 311.3V416C264.1 416 302.3 400.6 330.7 375.3C343.8 363.5 364.1 364.6 375.8 377.8C387.6 390.9 386.5 411.2 373.3 422.1C333.7 458.4 281.4 480 224 480C100.3 480 0 379.7 0 256C0 132.3 100.3 32 224 32C281.4 32 333.7 53.59 373.3 89.04C386.5 100.8 387.6 121.1 375.8 134.2C364.1 147.4 343.8 148.5 330.7 136.7C302.3 111.4 264.1 96 224 96C135.6 96 63.1 167.6 63.1 256C63.1 321.6 103.5 377.1 159.1 402.7V402.7z\"\n ]\n};\nvar faCube = {\n prefix: 'fas',\n iconName: 'cube',\n icon: [\n 512,\n 512,\n [],\n \"f1b2\",\n \"M234.5 5.709C248.4 .7377 263.6 .7377 277.5 5.709L469.5 74.28C494.1 83.38 512 107.5 512 134.6V377.4C512 404.5 494.1 428.6 469.5 437.7L277.5 506.3C263.6 511.3 248.4 511.3 234.5 506.3L42.47 437.7C17 428.6 0 404.5 0 377.4V134.6C0 107.5 17 83.38 42.47 74.28L234.5 5.709zM256 65.98L82.34 128L256 190L429.7 128L256 65.98zM288 434.6L448 377.4V189.4L288 246.6V434.6z\"\n ]\n};\nvar faCubes = {\n prefix: 'fas',\n iconName: 'cubes',\n icon: [\n 576,\n 512,\n [],\n \"f1b3\",\n \"M172.1 40.16L268.1 3.76C280.9-1.089 295.1-1.089 307.9 3.76L403.9 40.16C425.6 48.41 440 69.25 440 92.52V204.7C441.3 205.1 442.6 205.5 443.9 205.1L539.9 242.4C561.6 250.6 576 271.5 576 294.7V413.9C576 436.1 562.9 456.2 542.5 465.1L446.5 507.3C432.2 513.7 415.8 513.7 401.5 507.3L288 457.5L174.5 507.3C160.2 513.7 143.8 513.7 129.5 507.3L33.46 465.1C13.13 456.2 0 436.1 0 413.9V294.7C0 271.5 14.39 250.6 36.15 242.4L132.1 205.1C133.4 205.5 134.7 205.1 136 204.7V92.52C136 69.25 150.4 48.41 172.1 40.16V40.16zM290.8 48.64C289 47.95 286.1 47.95 285.2 48.64L206.8 78.35L287.1 109.5L369.2 78.35L290.8 48.64zM392 210.6V121L309.6 152.6V241.8L392 210.6zM154.8 250.9C153 250.2 150.1 250.2 149.2 250.9L70.81 280.6L152 311.7L233.2 280.6L154.8 250.9zM173.6 455.3L256 419.1V323.2L173.6 354.8V455.3zM342.8 280.6L424 311.7L505.2 280.6L426.8 250.9C425 250.2 422.1 250.2 421.2 250.9L342.8 280.6zM528 413.9V323.2L445.6 354.8V455.3L523.2 421.2C526.1 419.9 528 417.1 528 413.9V413.9z\"\n ]\n};\nvar faD = {\n prefix: 'fas',\n iconName: 'd',\n icon: [\n 384,\n 512,\n [\n 100\n ],\n \"44\",\n \"M160 32.01L32 32.01c-17.67 0-32 14.33-32 32v384c0 17.67 14.33 32 32 32l128-.0073c123.5 0 224-100.5 224-224S283.5 32.01 160 32.01zM160 416H64v-320h96c88.22 0 160 71.78 160 159.1S248.2 416 160 416z\"\n ]\n};\nvar faDatabase = {\n prefix: 'fas',\n iconName: 'database',\n icon: [\n 448,\n 512,\n [],\n \"f1c0\",\n \"M448 80V128C448 172.2 347.7 208 224 208C100.3 208 0 172.2 0 128V80C0 35.82 100.3 0 224 0C347.7 0 448 35.82 448 80zM393.2 214.7C413.1 207.3 433.1 197.8 448 186.1V288C448 332.2 347.7 368 224 368C100.3 368 0 332.2 0 288V186.1C14.93 197.8 34.02 207.3 54.85 214.7C99.66 230.7 159.5 240 224 240C288.5 240 348.3 230.7 393.2 214.7V214.7zM54.85 374.7C99.66 390.7 159.5 400 224 400C288.5 400 348.3 390.7 393.2 374.7C413.1 367.3 433.1 357.8 448 346.1V432C448 476.2 347.7 512 224 512C100.3 512 0 476.2 0 432V346.1C14.93 357.8 34.02 367.3 54.85 374.7z\"\n ]\n};\nvar faDeleteLeft = {\n prefix: 'fas',\n iconName: 'delete-left',\n icon: [\n 576,\n 512,\n [\n 9003,\n \"backspace\"\n ],\n \"f55a\",\n \"M576 384C576 419.3 547.3 448 512 448H205.3C188.3 448 172 441.3 160 429.3L9.372 278.6C3.371 272.6 0 264.5 0 256C0 247.5 3.372 239.4 9.372 233.4L160 82.75C172 70.74 188.3 64 205.3 64H512C547.3 64 576 92.65 576 128V384zM271 208.1L318.1 256L271 303C261.7 312.4 261.7 327.6 271 336.1C280.4 346.3 295.6 346.3 304.1 336.1L352 289.9L399 336.1C408.4 346.3 423.6 346.3 432.1 336.1C442.3 327.6 442.3 312.4 432.1 303L385.9 256L432.1 208.1C442.3 199.6 442.3 184.4 432.1 175C423.6 165.7 408.4 165.7 399 175L352 222.1L304.1 175C295.6 165.7 280.4 165.7 271 175C261.7 184.4 261.7 199.6 271 208.1V208.1z\"\n ]\n};\nvar faBackspace = faDeleteLeft;\nvar faDemocrat = {\n prefix: 'fas',\n iconName: 'democrat',\n icon: [\n 640,\n 512,\n [],\n \"f747\",\n \"M191.1 479.1C191.1 497.6 206.4 512 223.1 512h32c17.6 0 32-14.4 32-32v-64h160v64c0 17.6 14.41 32 32.01 32L511.1 512c17.6 0 32-14.4 32-32l.0102-128H192L191.1 479.1zM637.2 256.9l-19.5-29.38c-28.25-42.25-75.38-67.5-126.1-67.5H255.1L174.7 78.75c20.13-20 22.63-51 7.5-73.88C178.9-.2552 171.5-1.005 167.1 3.37L125.2 45.25L82.36 2.37C78.74-1.255 72.74-.6302 69.99 3.62c-12.25 18.63-10.25 44 6.125 60.38c3.25 3.25 7.25 5.25 11.25 7.5c-2.125 1.75-4.625 3.125-6.375 5.375l-74.63 99.38C-.8895 185.9-2.014 198.9 3.361 209.7l14.38 28.5c5.375 10.88 16.5 17.75 28.5 17.75H77.24c8.5 0 16.63-3.375 22.63-9.375l38.13-34.63l54.04 108h351.1l-.0102-77.75c16.25 12.13 18.25 17.5 40.13 50.25c4.875 7.375 14.75 9.25 22.13 4.375l26.63-17.63C640.2 274.2 642.2 264.2 637.2 256.9zM296.2 243.2L279.7 259.4l3.875 22.75c.625 4.125-3.625 7.125-7.25 5.25L255.1 276.7L235.6 287.4C231.1 289.2 227.7 286.2 228.4 282.1l3.875-22.75L215.7 243.2c-3-2.875-1.25-7.875 2.875-8.5l22.75-3.25l10.25-20.75c1.75-3.625 7.125-3.625 9 0l10.13 20.75l22.88 3.25C297.6 235.4 299.2 240.4 296.2 243.2zM408.2 243.2l-16.5 16.13l3.875 22.75c.625 4.125-3.625 7.125-7.25 5.25L367.1 276.7l-20.38 10.63c-3.625 1.875-7.875-1.125-7.25-5.25l3.875-22.75l-16.5-16.13c-3-2.875-1.25-7.875 2.875-8.5l22.75-3.25l10.25-20.75c1.75-3.625 7.125-3.625 9 0l10.13 20.75l22.88 3.25C409.6 235.4 411.2 240.4 408.2 243.2zM520.2 243.2l-16.5 16.13l3.875 22.75c.625 4.125-3.625 7.125-7.25 5.25l-20.38-10.63l-20.38 10.63c-3.625 1.875-7.875-1.125-7.25-5.25l3.875-22.75l-16.5-16.13c-3-2.875-1.25-7.875 2.875-8.5l22.75-3.25l10.25-20.75c1.75-3.625 7.125-3.625 9 0l10.13 20.75l22.88 3.25C521.6 235.4 523.2 240.4 520.2 243.2z\"\n ]\n};\nvar faDesktop = {\n prefix: 'fas',\n iconName: 'desktop',\n icon: [\n 576,\n 512,\n [\n 61704,\n 128421,\n \"desktop-alt\"\n ],\n \"f390\",\n \"M528 0h-480C21.5 0 0 21.5 0 48v320C0 394.5 21.5 416 48 416h192L224 464H152C138.8 464 128 474.8 128 488S138.8 512 152 512h272c13.25 0 24-10.75 24-24s-10.75-24-24-24H352L336 416h192c26.5 0 48-21.5 48-48v-320C576 21.5 554.5 0 528 0zM512 288H64V64h448V288z\"\n ]\n};\nvar faDesktopAlt = faDesktop;\nvar faDharmachakra = {\n prefix: 'fas',\n iconName: 'dharmachakra',\n icon: [\n 512,\n 512,\n [\n 9784\n ],\n \"f655\",\n \"M495 225l-17.24 1.124c-5.25-39.5-20.76-75.63-43.89-105.9l12.1-11.37c6.875-6.125 7.25-16.75 .75-23.38L426.5 64.38c-6.625-6.5-17.25-6.125-23.38 .75l-11.37 12.1c-30.25-23.12-66.38-38.64-105.9-43.89L287 17C287.5 7.75 280.2 0 271 0h-30c-9.25 0-16.5 7.75-16 17l1.124 17.24c-39.5 5.25-75.63 20.76-105.9 43.89L108.9 65.13C102.8 58.25 92.13 57.88 85.63 64.38L64.38 85.5C57.88 92.12 58.25 102.8 65.13 108.9l12.1 11.37C54.1 150.5 39.49 186.6 34.24 226.1L17 225C7.75 224.5 0 231.8 0 241v30c0 9.25 7.75 16.5 17 16l17.24-1.124c5.25 39.5 20.76 75.63 43.89 105.9l-12.1 11.37c-6.875 6.125-7.25 16.75-.75 23.25l21.25 21.25c6.5 6.5 17.13 6.125 23.25-.75l11.37-12.1c30.25 23.12 66.38 38.64 105.9 43.89L225 495C224.5 504.2 231.8 512 241 512h30c9.25 0 16.5-7.75 16-17l-1.124-17.24c39.5-5.25 75.63-20.76 105.9-43.89l11.37 12.1c6.125 6.875 16.75 7.25 23.38 .75l21.12-21.25c6.5-6.5 6.125-17.13-.75-23.25l-12.1-11.37c23.12-30.25 38.64-66.38 43.89-105.9L495 287C504.3 287.5 512 280.2 512 271v-30C512 231.8 504.3 224.5 495 225zM281.9 98.68c24.75 4 47.61 13.59 67.24 27.71L306.5 174.6c-8.75-5.375-18.38-9.507-28.62-11.88L281.9 98.68zM230.1 98.68l3.996 64.06C223.9 165.1 214.3 169.2 205.5 174.6L162.9 126.4C182.5 112.3 205.4 102.7 230.1 98.68zM126.4 163l48.35 42.48c-5.5 8.75-9.606 18.4-11.98 28.65L98.68 230.1C102.7 205.4 112.2 182.5 126.4 163zM98.68 281.9l64.06-3.996C165.1 288.1 169.3 297.8 174.6 306.5l-48.23 42.61C112.3 329.5 102.7 306.6 98.68 281.9zM230.1 413.3c-24.75-4-47.61-13.59-67.24-27.71l42.58-48.33c8.75 5.5 18.4 9.606 28.65 11.98L230.1 413.3zM256 288C238.4 288 224 273.6 224 256s14.38-32 32-32s32 14.38 32 32S273.6 288 256 288zM281.9 413.3l-3.996-64.06c10.25-2.375 19.9-6.48 28.65-11.98l42.48 48.35C329.5 399.8 306.6 409.3 281.9 413.3zM385.6 349l-48.25-42.5c5.375-8.75 9.507-18.38 11.88-28.62l64.06 3.996C409.3 306.6 399.8 329.5 385.6 349zM349.3 234.1c-2.375-10.25-6.48-19.9-11.98-28.65L385.6 163c14.13 19.5 23.69 42.38 27.69 67.13L349.3 234.1z\"\n ]\n};\nvar faDiagramNext = {\n prefix: 'fas',\n iconName: 'diagram-next',\n icon: [\n 512,\n 512,\n [],\n \"e476\",\n \"M512 160C512 195.3 483.3 224 448 224H280V288H326.1C347.4 288 358.1 313.9 343 328.1L272.1 399C263.6 408.4 248.4 408.4 239 399L168.1 328.1C153.9 313.9 164.6 288 185.9 288H232V224H64C28.65 224 0 195.3 0 160V96C0 60.65 28.65 32 64 32H448C483.3 32 512 60.65 512 96V160zM312.6 416H448V352H376.6L384.1 343.6C401 327.6 404.6 306.4 399 288H448C483.3 288 512 316.7 512 352V416C512 451.3 483.3 480 448 480H64C28.65 480 0 451.3 0 416V352C0 316.7 28.65 288 64 288H112.1C107.4 306.4 110.1 327.6 127 343.6L135.4 352H64V416H199.4L216.4 432.1C238.3 454.8 273.7 454.8 295.6 432.1L312.6 416z\"\n ]\n};\nvar faDiagramPredecessor = {\n prefix: 'fas',\n iconName: 'diagram-predecessor',\n icon: [\n 512,\n 512,\n [],\n \"e477\",\n \"M64 480C28.65 480 0 451.3 0 416V352C0 316.7 28.65 288 64 288H448C483.3 288 512 316.7 512 352V416C512 451.3 483.3 480 448 480H64zM448 416V352H64V416H448zM288 160C288 195.3 259.3 224 224 224H64C28.65 224 0 195.3 0 160V96C0 60.65 28.65 32 64 32H368C412.2 32 448 67.82 448 112V128H486.1C507.4 128 518.1 153.9 503 168.1L432.1 239C423.6 248.4 408.4 248.4 399 239L328.1 168.1C313.9 153.9 324.6 128 345.9 128H384V112C384 103.2 376.8 96 368 96H288V160z\"\n ]\n};\nvar faDiagramProject = {\n prefix: 'fas',\n iconName: 'diagram-project',\n icon: [\n 576,\n 512,\n [\n \"project-diagram\"\n ],\n \"f542\",\n \"M0 80C0 53.49 21.49 32 48 32H144C170.5 32 192 53.49 192 80V96H384V80C384 53.49 405.5 32 432 32H528C554.5 32 576 53.49 576 80V176C576 202.5 554.5 224 528 224H432C405.5 224 384 202.5 384 176V160H192V176C192 177.7 191.9 179.4 191.7 180.1L272 288H368C394.5 288 416 309.5 416 336V432C416 458.5 394.5 480 368 480H272C245.5 480 224 458.5 224 432V336C224 334.3 224.1 332.6 224.3 331L144 224H48C21.49 224 0 202.5 0 176V80z\"\n ]\n};\nvar faProjectDiagram = faDiagramProject;\nvar faDiagramSuccessor = {\n prefix: 'fas',\n iconName: 'diagram-successor',\n icon: [\n 512,\n 512,\n [],\n \"e47a\",\n \"M512 416C512 451.3 483.3 480 448 480H64C28.65 480 0 451.3 0 416V352C0 316.7 28.65 288 64 288H448C483.3 288 512 316.7 512 352V416zM224 224H64C28.65 224 0 195.3 0 160V96C0 60.65 28.65 32 64 32H368C412.2 32 448 67.82 448 112V128H486.1C507.4 128 518.1 153.9 503 168.1L432.1 239C423.6 248.4 408.4 248.4 399 239L328.1 168.1C313.9 153.9 324.6 128 345.9 128H384V112C384 103.2 376.8 96 368 96H288V160C288 195.3 259.3 224 224 224V224zM64 160H224V96H64V160z\"\n ]\n};\nvar faDiamond = {\n prefix: 'fas',\n iconName: 'diamond',\n icon: [\n 512,\n 512,\n [\n 9830\n ],\n \"f219\",\n \"M500.3 227.7C515.9 243.3 515.9 268.7 500.3 284.3L284.3 500.3C268.7 515.9 243.3 515.9 227.7 500.3L11.72 284.3C-3.905 268.7-3.905 243.3 11.72 227.7L227.7 11.72C243.3-3.905 268.7-3.905 284.3 11.72L500.3 227.7z\"\n ]\n};\nvar faDiamondTurnRight = {\n prefix: 'fas',\n iconName: 'diamond-turn-right',\n icon: [\n 512,\n 512,\n [\n \"directions\"\n ],\n \"f5eb\",\n \"M497.1 222.1l-208.1-208.1c-9.364-9.364-21.62-14.04-33.89-14.03C243.7 .0092 231.5 4.686 222.1 14.03L14.03 222.1C4.676 231.5 .0002 243.7 .0004 255.1c.0002 12.26 4.676 24.52 14.03 33.87l208.1 208.1C231.5 507.3 243.7 511.1 256 511.1c12.26 0 24.52-4.677 33.87-14.03l208.1-208.1c9.352-9.353 14.03-21.61 14.03-33.87C511.1 243.7 507.3 231.5 497.1 222.1zM410.5 252l-96 84c-10.79 9.545-26.53 .9824-26.53-12.03V272H223.1l-.0001 48C223.1 337.6 209.6 352 191.1 352S159.1 337.6 159.1 320V240c0-17.6 14.4-32 32-32h95.1V156c0-13.85 16.39-20.99 26.53-12.03l96 84C414 231 415.1 235.4 415.1 240S414 249 410.5 252z\"\n ]\n};\nvar faDirections = faDiamondTurnRight;\nvar faDice = {\n prefix: 'fas',\n iconName: 'dice',\n icon: [\n 640,\n 512,\n [\n 127922\n ],\n \"f522\",\n \"M447.1 224c0-12.56-4.781-25.13-14.35-34.76l-174.9-174.9C249.1 4.786 236.5 0 223.1 0C211.4 0 198.9 4.786 189.2 14.35L14.35 189.2C4.783 198.9-.0011 211.4-.0011 223.1c0 12.56 4.785 25.17 14.35 34.8l174.9 174.9c9.625 9.562 22.19 14.35 34.75 14.35s25.13-4.783 34.75-14.35l174.9-174.9C443.2 249.1 447.1 236.6 447.1 224zM96 248c-13.25 0-23.1-10.75-23.1-23.1s10.75-23.1 23.1-23.1S120 210.8 120 224S109.3 248 96 248zM224 376c-13.25 0-23.1-10.75-23.1-23.1s10.75-23.1 23.1-23.1s23.1 10.75 23.1 23.1S237.3 376 224 376zM224 248c-13.25 0-23.1-10.75-23.1-23.1s10.75-23.1 23.1-23.1S248 210.8 248 224S237.3 248 224 248zM224 120c-13.25 0-23.1-10.75-23.1-23.1s10.75-23.1 23.1-23.1s23.1 10.75 23.1 23.1S237.3 120 224 120zM352 248c-13.25 0-23.1-10.75-23.1-23.1s10.75-23.1 23.1-23.1s23.1 10.75 23.1 23.1S365.3 248 352 248zM591.1 192l-118.7 0c4.418 10.27 6.604 21.25 6.604 32.23c0 20.7-7.865 41.38-23.63 57.14l-136.2 136.2v46.37C320 490.5 341.5 512 368 512h223.1c26.5 0 47.1-21.5 47.1-47.1V240C639.1 213.5 618.5 192 591.1 192zM479.1 376c-13.25 0-23.1-10.75-23.1-23.1s10.75-23.1 23.1-23.1s23.1 10.75 23.1 23.1S493.2 376 479.1 376z\"\n ]\n};\nvar faDiceD20 = {\n prefix: 'fas',\n iconName: 'dice-d20',\n icon: [\n 512,\n 512,\n [],\n \"f6cf\",\n \"M20.04 317.3C18 317.3 16 315.8 16 313.3V150.5c0-2.351 1.91-4.012 4.001-4.012c.6882 0 1.396 .18 2.062 .5748l76.62 45.1l-75.28 122.3C22.59 316.8 21.31 317.3 20.04 317.3zM231.4 405.2l-208.2-22.06c-4.27-.4821-7.123-4.117-7.123-7.995c0-1.401 .3725-2.834 1.185-4.161L122.7 215.1L231.4 405.2zM31.1 420.1c0-2.039 1.508-4.068 3.93-4.068c.1654 0 .3351 .0095 .5089 .0291l203.6 22.31v65.66C239.1 508.6 236.2 512 232 512c-1.113 0-2.255-.2387-3.363-.7565L34.25 423.6C32.69 422.8 31.1 421.4 31.1 420.1zM33.94 117.1c-1.289-.7641-1.938-2.088-1.938-3.417c0-1.281 .6019-2.567 1.813-3.364l150.8-98.59C185.1 10.98 187.3 10.64 188.6 10.64c4.32 0 8.003 3.721 8.003 8.022c0 1.379-.3788 2.818-1.237 4.214L115.5 165.8L33.94 117.1zM146.8 175.1l95.59-168.4C245.5 2.53 250.7 0 255.1 0s10.5 2.53 13.62 7.624l95.59 168.4H146.8zM356.4 207.1l-100.4 175.7L155.6 207.1H356.4zM476.1 415.1c2.422 0 3.93 2.029 3.93 4.068c0 1.378-.6893 2.761-2.252 3.524l-194.4 87.66c-1.103 .5092-2.241 .7443-3.35 .7443c-4.2 0-7.994-3.371-7.994-7.994v-65.69l203.6-22.28C475.7 416 475.9 415.1 476.1 415.1zM494.8 370.9C495.6 372.3 496 373.7 496 375.1c0 3.872-2.841 7.499-7.128 7.98l-208.2 22.06l108.6-190.1L494.8 370.9zM316.6 22.87c-.8581-1.395-1.237-2.834-1.237-4.214c0-4.301 3.683-8.022 8.003-8.022c1.308 0 2.675 .3411 4.015 1.11l150.8 98.59c1.211 .7973 1.813 2.076 1.813 3.353c0 1.325-.6488 2.649-1.938 3.429L396.5 165.8L316.6 22.87zM491.1 146.5c2.091 0 4.001 1.661 4.001 4.012v162.8c0 2.483-2.016 4.006-4.053 4.006c-1.27 0-2.549-.5919-3.353-1.912l-75.28-122.3l76.62-45.1C490.6 146.7 491.3 146.5 491.1 146.5z\"\n ]\n};\nvar faDiceD6 = {\n prefix: 'fas',\n iconName: 'dice-d6',\n icon: [\n 448,\n 512,\n [],\n \"f6d1\",\n \"M7.994 153.5c1.326 0 2.687 .3508 3.975 1.119L208 271.5v223.8c0 9.741-7.656 16.71-16.01 16.71c-2.688 0-5.449-.7212-8.05-2.303l-152.2-92.47C12.13 405.3 0 383.3 0 359.5v-197.7C0 156.1 3.817 153.5 7.994 153.5zM426.2 117.2c0 2.825-1.352 5.647-4.051 7.248L224 242.6L25.88 124.4C23.19 122.8 21.85 119.1 21.85 117.2c0-2.8 1.32-5.603 3.965-7.221l165.1-100.9C201.7 3.023 212.9 0 224 0s22.27 3.023 32.22 9.07l165.1 100.9C424.8 111.6 426.2 114.4 426.2 117.2zM440 153.5C444.2 153.5 448 156.1 448 161.8v197.7c0 23.75-12.12 45.75-31.78 57.69l-152.2 92.5C261.5 511.3 258.7 512 256 512C247.7 512 240 505 240 495.3V271.5l196-116.9C437.3 153.8 438.7 153.5 440 153.5z\"\n ]\n};\nvar faDiceFive = {\n prefix: 'fas',\n iconName: 'dice-five',\n icon: [\n 448,\n 512,\n [\n 9860\n ],\n \"f523\",\n \"M384 32H64C28.62 32 0 60.62 0 96v320c0 35.38 28.62 64 64 64h320c35.38 0 64-28.62 64-64V96C448 60.62 419.4 32 384 32zM128 384c-17.62 0-32-14.38-32-32s14.38-32 32-32s32 14.38 32 32S145.6 384 128 384zM128 192C110.4 192 96 177.6 96 160s14.38-32 32-32s32 14.38 32 32S145.6 192 128 192zM224 288C206.4 288 192 273.6 192 256s14.38-32 32-32s32 14.38 32 32S241.6 288 224 288zM320 384c-17.62 0-32-14.38-32-32s14.38-32 32-32s32 14.38 32 32S337.6 384 320 384zM320 192c-17.62 0-32-14.38-32-32s14.38-32 32-32s32 14.38 32 32S337.6 192 320 192z\"\n ]\n};\nvar faDiceFour = {\n prefix: 'fas',\n iconName: 'dice-four',\n icon: [\n 448,\n 512,\n [\n 9859\n ],\n \"f524\",\n \"M384 32H64C28.62 32 0 60.62 0 96v320c0 35.38 28.62 64 64 64h320c35.38 0 64-28.62 64-64V96C448 60.62 419.4 32 384 32zM128 384c-17.62 0-32-14.38-32-32s14.38-32 32-32s32 14.38 32 32S145.6 384 128 384zM128 192C110.4 192 96 177.6 96 160s14.38-32 32-32s32 14.38 32 32S145.6 192 128 192zM320 384c-17.62 0-32-14.38-32-32s14.38-32 32-32s32 14.38 32 32S337.6 384 320 384zM320 192c-17.62 0-32-14.38-32-32s14.38-32 32-32s32 14.38 32 32S337.6 192 320 192z\"\n ]\n};\nvar faDiceOne = {\n prefix: 'fas',\n iconName: 'dice-one',\n icon: [\n 448,\n 512,\n [\n 9856\n ],\n \"f525\",\n \"M384 32H64C28.62 32 0 60.62 0 96v320c0 35.38 28.62 64 64 64h320c35.38 0 64-28.62 64-64V96C448 60.62 419.4 32 384 32zM224 288C206.4 288 192 273.6 192 256s14.38-32 32-32s32 14.38 32 32S241.6 288 224 288z\"\n ]\n};\nvar faDiceSix = {\n prefix: 'fas',\n iconName: 'dice-six',\n icon: [\n 448,\n 512,\n [\n 9861\n ],\n \"f526\",\n \"M384 32H64C28.62 32 0 60.62 0 96v320c0 35.38 28.62 64 64 64h320c35.38 0 64-28.62 64-64V96C448 60.62 419.4 32 384 32zM128 384c-17.62 0-32-14.38-32-32s14.38-32 32-32s32 14.38 32 32S145.6 384 128 384zM128 288C110.4 288 96 273.6 96 256s14.38-32 32-32s32 14.38 32 32S145.6 288 128 288zM128 192C110.4 192 96 177.6 96 160s14.38-32 32-32s32 14.38 32 32S145.6 192 128 192zM320 384c-17.62 0-32-14.38-32-32s14.38-32 32-32s32 14.38 32 32S337.6 384 320 384zM320 288c-17.62 0-32-14.38-32-32s14.38-32 32-32s32 14.38 32 32S337.6 288 320 288zM320 192c-17.62 0-32-14.38-32-32s14.38-32 32-32s32 14.38 32 32S337.6 192 320 192z\"\n ]\n};\nvar faDiceThree = {\n prefix: 'fas',\n iconName: 'dice-three',\n icon: [\n 448,\n 512,\n [\n 9858\n ],\n \"f527\",\n \"M384 32H64C28.62 32 0 60.62 0 96v320c0 35.38 28.62 64 64 64h320c35.38 0 64-28.62 64-64V96C448 60.62 419.4 32 384 32zM128 192C110.4 192 96 177.6 96 160s14.38-32 32-32s32 14.38 32 32S145.6 192 128 192zM224 288C206.4 288 192 273.6 192 256s14.38-32 32-32s32 14.38 32 32S241.6 288 224 288zM320 384c-17.62 0-32-14.38-32-32s14.38-32 32-32s32 14.38 32 32S337.6 384 320 384z\"\n ]\n};\nvar faDiceTwo = {\n prefix: 'fas',\n iconName: 'dice-two',\n icon: [\n 448,\n 512,\n [\n 9857\n ],\n \"f528\",\n \"M384 32H64C28.62 32 0 60.62 0 96v320c0 35.38 28.62 64 64 64h320c35.38 0 64-28.62 64-64V96C448 60.62 419.4 32 384 32zM128 192C110.4 192 96 177.6 96 160s14.38-32 32-32s32 14.38 32 32S145.6 192 128 192zM320 384c-17.62 0-32-14.38-32-32s14.38-32 32-32s32 14.38 32 32S337.6 384 320 384z\"\n ]\n};\nvar faDisease = {\n prefix: 'fas',\n iconName: 'disease',\n icon: [\n 512,\n 512,\n [],\n \"f7fa\",\n \"M472.2 195.9l-66.1-22.1c-19.25-6.624-33.5-20.87-38.13-38.24l-16-60.49c-11.62-43.74-76.63-57.11-110-22.62L194.1 99.3c-13.25 13.75-33.5 20.87-54.25 19.25L68.86 112.9c-52-3.999-86.88 44.99-59 82.86l38.63 52.49c11 14.1 12.75 33.74 4.625 50.12l-28.5 56.99c-20.62 41.24 22.88 84.86 73.5 73.86l69.1-15.25c20.12-4.499 41.38 .0001 57 11.62l54.38 40.87c39.38 29.62 101 7.623 104.5-37.24l4.625-61.86c1.375-17.75 12.88-33.87 30.62-42.99l61.1-31.62C526.1 269.8 520.9 212.5 472.2 195.9zM159.1 256c-17.62 0-31.1-14.37-31.1-31.1s14.37-31.1 31.1-31.1s31.1 14.37 31.1 31.1S177.6 256 159.1 256zM287.1 351.1c-17.62 0-31.1-14.37-31.1-31.1c0-17.62 14.37-31.1 31.1-31.1s31.1 14.37 31.1 31.1C319.1 337.6 305.6 351.1 287.1 351.1zM303.1 224c-8.875 0-15.1-7.125-15.1-15.1c0-8.873 7.125-15.1 15.1-15.1s15.1 7.125 15.1 15.1C319.1 216.9 312.9 224 303.1 224z\"\n ]\n};\nvar faDivide = {\n prefix: 'fas',\n iconName: 'divide',\n icon: [\n 448,\n 512,\n [\n 10135,\n 247\n ],\n \"f529\",\n \"M400 224h-352c-17.69 0-32 14.31-32 31.1s14.31 32 32 32h352c17.69 0 32-14.31 32-32S417.7 224 400 224zM224 144c26.47 0 48-21.53 48-48s-21.53-48-48-48s-48 21.53-48 48S197.5 144 224 144zM224 368c-26.47 0-48 21.53-48 48s21.53 48 48 48s48-21.53 48-48S250.5 368 224 368z\"\n ]\n};\nvar faDna = {\n prefix: 'fas',\n iconName: 'dna',\n icon: [\n 448,\n 512,\n [\n 129516\n ],\n \"f471\",\n \"M.1193 494.1c-1.125 9.5 6.312 17.87 15.94 17.87l32.06 .0635c8.125 0 15.21-5.833 16.21-13.83c.7501-4.875 1.869-11.17 3.494-18.17h312c1.625 6.875 2.904 13.31 3.529 18.18c1.125 7.1 7.84 13.94 15.97 13.82l32.46-.0625c9.625 0 17.12-8.374 15.99-17.87c-4.625-37.87-25.75-128.1-119.1-207.7c-17.5 12.37-36.98 24.37-58.48 35.49c6.25 4.625 11.56 9.405 17.06 14.15H159.7c21.25-18.12 47.03-35.63 78.65-51.38c172.1-85.5 203.7-218.8 209.5-266.7c1.125-9.5-6.297-17.88-15.92-17.88L399.6 .001c-8.125 0-14.84 5.832-15.96 13.83c-.7501 4.875-1.869 11.17-3.369 18.17H67.74C66.24 25 65.08 18.81 64.33 13.81C63.21 5.813 56.48-.124 48.36 .001L16.1 .1338c-9.625 0-17.09 8.354-15.96 17.85c5.125 42.87 31.29 153.8 159.9 238.1C31.55 340.3 5.245 451.2 .1193 494.1zM223.9 219.7C198.8 205.9 177.6 191.3 159.7 176h128.5C270.4 191.3 249 206.1 223.9 219.7zM355.1 96c-5.875 10.37-12.88 21.12-21 31.1H113.1c-8.25-10.87-15.3-21.63-21.05-32L355.1 96zM93 415.1c5.875-10.37 12.74-21.13 20.87-32h219.4c8.375 10.87 15.48 21.63 21.23 32H93z\"\n ]\n};\nvar faDog = {\n prefix: 'fas',\n iconName: 'dog',\n icon: [\n 576,\n 512,\n [\n 128021\n ],\n \"f6d3\",\n \"M332.7 19.85C334.6 8.395 344.5 0 356.1 0C363.6 0 370.6 3.52 375.1 9.502L392 32H444.1C456.8 32 469.1 37.06 478.1 46.06L496 64H552C565.3 64 576 74.75 576 88V112C576 156.2 540.2 192 496 192H426.7L421.6 222.5L309.6 158.5L332.7 19.85zM448 64C439.2 64 432 71.16 432 80C432 88.84 439.2 96 448 96C456.8 96 464 88.84 464 80C464 71.16 456.8 64 448 64zM416 256.1V480C416 497.7 401.7 512 384 512H352C334.3 512 320 497.7 320 480V364.8C295.1 377.1 268.8 384 240 384C211.2 384 184 377.1 160 364.8V480C160 497.7 145.7 512 128 512H96C78.33 512 64 497.7 64 480V249.8C35.23 238.9 12.64 214.5 4.836 183.3L.9558 167.8C-3.331 150.6 7.094 133.2 24.24 128.1C41.38 124.7 58.76 135.1 63.05 152.2L66.93 167.8C70.49 182 83.29 191.1 97.97 191.1H303.8L416 256.1z\"\n ]\n};\nvar faDollarSign = {\n prefix: 'fas',\n iconName: 'dollar-sign',\n icon: [\n 320,\n 512,\n [\n 128178,\n 61781,\n \"dollar\",\n \"usd\"\n ],\n \"24\",\n \"M160 0C177.7 0 192 14.33 192 32V67.68C193.6 67.89 195.1 68.12 196.7 68.35C207.3 69.93 238.9 75.02 251.9 78.31C268.1 82.65 279.4 100.1 275 117.2C270.7 134.3 253.3 144.7 236.1 140.4C226.8 137.1 198.5 133.3 187.3 131.7C155.2 126.9 127.7 129.3 108.8 136.5C90.52 143.5 82.93 153.4 80.92 164.5C78.98 175.2 80.45 181.3 82.21 185.1C84.1 189.1 87.79 193.6 95.14 198.5C111.4 209.2 136.2 216.4 168.4 225.1L171.2 225.9C199.6 233.6 234.4 243.1 260.2 260.2C274.3 269.6 287.6 282.3 295.8 299.9C304.1 317.7 305.9 337.7 302.1 358.1C295.1 397 268.1 422.4 236.4 435.6C222.8 441.2 207.8 444.8 192 446.6V480C192 497.7 177.7 512 160 512C142.3 512 128 497.7 128 480V445.1C127.6 445.1 127.1 444.1 126.7 444.9L126.5 444.9C102.2 441.1 62.07 430.6 35 418.6C18.85 411.4 11.58 392.5 18.76 376.3C25.94 360.2 44.85 352.9 60.1 360.1C81.9 369.4 116.3 378.5 136.2 381.6C168.2 386.4 194.5 383.6 212.3 376.4C229.2 369.5 236.9 359.5 239.1 347.5C241 336.8 239.6 330.7 237.8 326.9C235.9 322.9 232.2 318.4 224.9 313.5C208.6 302.8 183.8 295.6 151.6 286.9L148.8 286.1C120.4 278.4 85.58 268.9 59.76 251.8C45.65 242.4 32.43 229.7 24.22 212.1C15.89 194.3 14.08 174.3 17.95 153C25.03 114.1 53.05 89.29 85.96 76.73C98.98 71.76 113.1 68.49 128 66.73V32C128 14.33 142.3 0 160 0V0z\"\n ]\n};\nvar faDollar = faDollarSign;\nvar faUsd = faDollarSign;\nvar faDolly = {\n prefix: 'fas',\n iconName: 'dolly',\n icon: [\n 576,\n 512,\n [\n \"dolly-box\"\n ],\n \"f472\",\n \"M294.2 277.8c17.1 5 34.62 13.38 49.5 24.62l161.5-53.75c8.375-2.875 12.88-11.88 10-20.25L454.8 47.25c-2.748-8.502-11.88-13-20.12-10.12l-61.13 20.37l33.12 99.38l-60.75 20.13l-33.12-99.38L251.2 98.13c-8.373 2.75-12.87 11.88-9.998 20.12L294.2 277.8zM574.4 309.9c-5.594-16.75-23.67-25.91-40.48-20.23l-202.5 67.51c-17.22-22.01-43.57-36.41-73.54-36.97L165.7 43.75C156.9 17.58 132.5 0 104.9 0H32C14.33 0 0 14.33 0 32s14.33 32 32 32h72.94l92.22 276.7C174.7 358.2 160 385.3 160 416c0 53.02 42.98 96 96 96c52.4 0 94.84-42.03 95.82-94.2l202.3-67.44C570.9 344.8 579.1 326.6 574.4 309.9zM256 448c-17.67 0-32-14.33-32-32c0-17.67 14.33-31.1 32-31.1S288 398.3 288 416C288 433.7 273.7 448 256 448z\"\n ]\n};\nvar faDollyBox = faDolly;\nvar faDongSign = {\n prefix: 'fas',\n iconName: 'dong-sign',\n icon: [\n 384,\n 512,\n [],\n \"e169\",\n \"M320 64C337.7 64 352 78.33 352 96C352 113.7 337.7 128 320 128V384C320 401.7 305.7 416 288 416C275 416 263.9 408.3 258.8 397.2C239.4 409.1 216.5 416 192 416C121.3 416 64 358.7 64 288C64 217.3 121.3 160 192 160C215.3 160 237.2 166.2 256 177.1V128H224C206.3 128 192 113.7 192 96C192 78.33 206.3 64 224 64H256C256 46.33 270.3 32 288 32C305.7 32 320 46.33 320 64V64zM256 288C256 252.7 227.3 224 192 224C156.7 224 128 252.7 128 288C128 323.3 156.7 352 192 352C227.3 352 256 323.3 256 288zM352 448C369.7 448 384 462.3 384 480C384 497.7 369.7 512 352 512H32C14.33 512 0 497.7 0 480C0 462.3 14.33 448 32 448H352z\"\n ]\n};\nvar faDoorClosed = {\n prefix: 'fas',\n iconName: 'door-closed',\n icon: [\n 576,\n 512,\n [\n 128682\n ],\n \"f52a\",\n \"M560 448H480V50.75C480 22.75 458.5 0 432 0h-288C117.5 0 96 22.75 96 50.75V448H16C7.125 448 0 455.1 0 464v32C0 504.9 7.125 512 16 512h544c8.875 0 16-7.125 16-16v-32C576 455.1 568.9 448 560 448zM384 288c-17.62 0-32-14.38-32-32s14.38-32 32-32s32 14.38 32 32S401.6 288 384 288z\"\n ]\n};\nvar faDoorOpen = {\n prefix: 'fas',\n iconName: 'door-open',\n icon: [\n 576,\n 512,\n [],\n \"f52b\",\n \"M560 448H512V113.5c0-27.25-21.5-49.5-48-49.5L352 64.01V128h96V512h112c8.875 0 16-7.125 16-15.1v-31.1C576 455.1 568.9 448 560 448zM280.3 1.007l-192 49.75C73.1 54.51 64 67.76 64 82.88V448H16c-8.875 0-16 7.125-16 15.1v31.1C0 504.9 7.125 512 16 512H320V33.13C320 11.63 300.5-4.243 280.3 1.007zM232 288c-13.25 0-24-14.37-24-31.1c0-17.62 10.75-31.1 24-31.1S256 238.4 256 256C256 273.6 245.3 288 232 288z\"\n ]\n};\nvar faDove = {\n prefix: 'fas',\n iconName: 'dove',\n icon: [\n 512,\n 512,\n [\n 128330\n ],\n \"f4ba\",\n \"M288 167.2V139.1c-28.25-36.38-47.13-79.29-54.13-125.2C231.7 .4054 214.8-5.02 206.1 5.481C184.1 30.36 168.4 59.7 157.2 92.07C191.4 130.3 237.2 156.7 288 167.2zM400 63.97c-44.25 0-79.1 35.82-79.1 80.08l.0014 59.44c-104.4-6.251-193-70.46-233-161.7C81.48 29.25 63.76 28.58 58.01 40.83C41.38 75.96 32.01 115.2 32.01 156.6c0 70.76 34.11 136.9 85.11 185.9c13.12 12.75 26.13 23.27 38.88 32.77L12.12 411.2c-10.75 2.75-15.5 15.09-9.5 24.47c17.38 26.88 60.42 72.54 153.2 76.29c8 .25 15.99-2.633 22.12-7.883l65.23-56.12l76.84 .0561c88.38 0 160-71.49 160-159.9l.0013-160.2l31.1-63.99L400 63.97zM400 160.1c-8.75 0-16.01-7.259-16.01-16.01c0-8.876 7.261-16.05 16.01-16.05s15.99 7.136 15.99 16.01C416 152.8 408.8 160.1 400 160.1z\"\n ]\n};\nvar faDownLeftAndUpRightToCenter = {\n prefix: 'fas',\n iconName: 'down-left-and-up-right-to-center',\n icon: [\n 512,\n 512,\n [\n \"compress-alt\"\n ],\n \"f422\",\n \"M215.1 272h-136c-12.94 0-24.63 7.797-29.56 19.75C45.47 303.7 48.22 317.5 57.37 326.6l30.06 30.06l-78.06 78.07c-12.5 12.5-12.5 32.75-.0012 45.25l22.62 22.62c12.5 12.5 32.76 12.5 45.26 .0013l78.06-78.07l30.06 30.06c6.125 6.125 14.31 9.367 22.63 9.367c4.125 0 8.279-.7891 12.25-2.43c11.97-4.953 19.75-16.62 19.75-29.56V296C239.1 282.7 229.3 272 215.1 272zM296 240h136c12.94 0 24.63-7.797 29.56-19.75c4.969-11.97 2.219-25.72-6.938-34.87l-30.06-30.06l78.06-78.07c12.5-12.5 12.5-32.76 .0002-45.26l-22.62-22.62c-12.5-12.5-32.76-12.5-45.26-.0003l-78.06 78.07l-30.06-30.06c-9.156-9.141-22.87-11.84-34.87-6.937c-11.97 4.953-19.75 16.62-19.75 29.56v135.1C272 229.3 282.7 240 296 240z\"\n ]\n};\nvar faCompressAlt = faDownLeftAndUpRightToCenter;\nvar faDownLong = {\n prefix: 'fas',\n iconName: 'down-long',\n icon: [\n 320,\n 512,\n [\n \"long-arrow-alt-down\"\n ],\n \"f309\",\n \"M281.6 392.3l-104 112.1c-9.498 10.24-25.69 10.24-35.19 0l-104-112.1c-6.484-6.992-8.219-17.18-4.404-25.94c3.811-8.758 12.45-14.42 21.1-14.42H128V32c0-17.69 14.33-32 32-32S192 14.31 192 32v319.9h72c9.547 0 18.19 5.66 22 14.42C289.8 375.1 288.1 385.3 281.6 392.3z\"\n ]\n};\nvar faLongArrowAltDown = faDownLong;\nvar faDownload = {\n prefix: 'fas',\n iconName: 'download',\n icon: [\n 512,\n 512,\n [],\n \"f019\",\n \"M480 352h-133.5l-45.25 45.25C289.2 409.3 273.1 416 256 416s-33.16-6.656-45.25-18.75L165.5 352H32c-17.67 0-32 14.33-32 32v96c0 17.67 14.33 32 32 32h448c17.67 0 32-14.33 32-32v-96C512 366.3 497.7 352 480 352zM432 456c-13.2 0-24-10.8-24-24c0-13.2 10.8-24 24-24s24 10.8 24 24C456 445.2 445.2 456 432 456zM233.4 374.6C239.6 380.9 247.8 384 256 384s16.38-3.125 22.62-9.375l128-128c12.49-12.5 12.49-32.75 0-45.25c-12.5-12.5-32.76-12.5-45.25 0L288 274.8V32c0-17.67-14.33-32-32-32C238.3 0 224 14.33 224 32v242.8L150.6 201.4c-12.49-12.5-32.75-12.5-45.25 0c-12.49 12.5-12.49 32.75 0 45.25L233.4 374.6z\"\n ]\n};\nvar faDragon = {\n prefix: 'fas',\n iconName: 'dragon',\n icon: [\n 640,\n 512,\n [\n 128009\n ],\n \"f6d5\",\n \"M18.43 255.8L192 224L100.8 292.6C90.67 302.8 97.8 320 112 320h222.7c-9.499-26.5-14.75-54.5-14.75-83.38V194.2L200.3 106.8C176.5 90.88 145 92.75 123.3 111.2l-117.5 116.4C-6.562 238 2.436 258 18.43 255.8zM575.2 289.9l-100.7-50.25c-16.25-8.125-26.5-24.75-26.5-43V160h63.99l28.12 22.62C546.1 188.6 554.2 192 562.7 192h30.1c11.1 0 23.12-6.875 28.5-17.75l14.37-28.62c5.374-10.87 4.25-23.75-2.999-33.5l-74.49-99.37C552.1 4.75 543.5 0 533.5 0H296C288.9 0 285.4 8.625 290.4 13.62L351.1 64L292.4 88.75c-5.874 3-5.874 11.37 0 14.37L351.1 128l-.0011 108.6c0 72 35.99 139.4 95.99 179.4c-195.6 6.75-344.4 41-434.1 60.88c-8.124 1.75-13.87 9-13.87 17.38C.0463 504 8.045 512 17.79 512h499.1c63.24 0 119.6-47.5 122.1-110.8C642.3 354 617.1 310.9 575.2 289.9zM489.1 66.25l45.74 11.38c-2.75 11-12.5 18.88-24.12 18.25C497.7 95.25 484.8 83.38 489.1 66.25z\"\n ]\n};\nvar faDrawPolygon = {\n prefix: 'fas',\n iconName: 'draw-polygon',\n icon: [\n 448,\n 512,\n [],\n \"f5ee\",\n \"M384.3 352C419.5 352.2 448 380.7 448 416C448 451.3 419.3 480 384 480C360.3 480 339.6 467.1 328.6 448H119.4C108.4 467.1 87.69 480 64 480C28.65 480 0 451.3 0 416C0 392.3 12.87 371.6 32 360.6V151.4C12.87 140.4 0 119.7 0 96C0 60.65 28.65 32 64 32C87.69 32 108.4 44.87 119.4 64H328.6C339.6 44.87 360.3 32 384 32C419.3 32 448 60.65 448 96C448 131.3 419.5 159.8 384.3 159.1L345.5 227.9C349.7 236.4 352 245.9 352 256C352 266.1 349.7 275.6 345.5 284.1L384.3 352zM96 360.6C105.7 366.2 113.8 374.3 119.4 384H328.6C328.6 383.9 328.7 383.8 328.7 383.7L292.2 319.9C290.8 319.1 289.4 320 288 320C252.7 320 224 291.3 224 256C224 220.7 252.7 192 288 192C289.4 192 290.8 192 292.2 192.1L328.7 128.3L328.6 128H119.4C113.8 137.7 105.7 145.8 96 151.4L96 360.6z\"\n ]\n};\nvar faDroplet = {\n prefix: 'fas',\n iconName: 'droplet',\n icon: [\n 384,\n 512,\n [\n 128167,\n \"tint\"\n ],\n \"f043\",\n \"M16 319.1C16 245.9 118.3 89.43 166.9 19.3C179.2 1.585 204.8 1.585 217.1 19.3C265.7 89.43 368 245.9 368 319.1C368 417.2 289.2 496 192 496C94.8 496 16 417.2 16 319.1zM112 319.1C112 311.2 104.8 303.1 96 303.1C87.16 303.1 80 311.2 80 319.1C80 381.9 130.1 432 192 432C200.8 432 208 424.8 208 416C208 407.2 200.8 400 192 400C147.8 400 112 364.2 112 319.1z\"\n ]\n};\nvar faTint = faDroplet;\nvar faDropletSlash = {\n prefix: 'fas',\n iconName: 'droplet-slash',\n icon: [\n 640,\n 512,\n [\n \"tint-slash\"\n ],\n \"f5c7\",\n \"M215.3 143.4C243.5 95.07 274.2 49.29 294.9 19.3C307.2 1.585 332.8 1.585 345.1 19.3C393.7 89.43 496 245.9 496 319.1C496 333.7 494.4 347.1 491.5 359.9L630.8 469.1C641.2 477.3 643.1 492.4 634.9 502.8C626.7 513.2 611.6 515.1 601.2 506.9L9.196 42.89C-1.236 34.71-3.065 19.63 5.112 9.196C13.29-1.236 28.37-3.065 38.81 5.112L215.3 143.4zM143.1 319.1C143.1 296.5 154.3 264.6 169.1 229.9L443.5 445.4C411.7 476.7 368.1 496 319.1 496C222.8 496 143.1 417.2 143.1 319.1V319.1zM239.1 319.1C239.1 311.2 232.8 303.1 223.1 303.1C215.2 303.1 207.1 311.2 207.1 319.1C207.1 381.9 258.1 432 319.1 432C328.8 432 336 424.8 336 416C336 407.2 328.8 400 319.1 400C275.8 400 239.1 364.2 239.1 319.1V319.1z\"\n ]\n};\nvar faTintSlash = faDropletSlash;\nvar faDrum = {\n prefix: 'fas',\n iconName: 'drum',\n icon: [\n 512,\n 512,\n [\n 129345\n ],\n \"f569\",\n \"M431.1 122l70.02-45.91c11.09-7.273 14.19-22.14 6.906-33.25c-7.219-11.07-22.09-14.23-33.22-6.924l-106.4 69.73c-49.81-8.787-97.18-9.669-112.4-9.669c-.002 0 .002 0 0 0C219.5 96 0 100.6 0 208.3v160.1c0 30.27 27.5 57.68 71.1 77.85v-101.9c0-13.27 10.75-24.03 24-24.03s23.1 10.76 23.1 24.03v118.9C153 472.4 191.1 478.3 231.1 480v-103.6c0-13.27 10.75-24.03 24-24.03c.002 0-.002 0 0 0c13.25 0 24 10.76 24 24.03V480c40.93-1.668 78.95-7.615 111.1-16.72v-118.9c0-13.27 10.75-24.03 24-24.03s24 10.76 24 24.03v101.9c44.49-20.17 71.1-47.58 71.1-77.85V208.3C511.1 164.9 476.1 138.4 431.1 122zM255.1 272.5C255.1 272.5 255.1 272.5 255.1 272.5c-114.9 0-207.1-28.97-207.1-64.39s93.12-63.1 207.1-63.1c.002 0-.002 0 0 0c17.5 0 34.47 .7139 50.71 1.966L242.8 187.1c-11.09 7.273-14.19 22.14-6.906 33.25C240.5 228.3 248.2 232.1 256 232.1c4.5 0 9.062-1.265 13.12-3.923l109.3-71.67c51.77 11.65 85.5 30.38 85.5 51.67C463.1 243.6 370.9 272.5 255.1 272.5z\"\n ]\n};\nvar faDrumSteelpan = {\n prefix: 'fas',\n iconName: 'drum-steelpan',\n icon: [\n 576,\n 512,\n [],\n \"f56a\",\n \"M288 32C129 32 0 89.25 0 160v192c0 70.75 129 128 288 128s288-57.25 288-128V160C576 89.25 447 32 288 32zM205 190.4c-4.5 16.62-14.5 30.5-28.25 40.5C100.2 217.5 48 190.8 48 160c0-30.12 50.12-56.38 124-69.1l25.62 44.25C207.5 151.4 210.1 171.2 205 190.4zM288 240c-21.12 0-41.38-.1-60.88-2.75C235.1 211.1 259.2 192 288 192s52.88 19.12 60.88 45.25C329.4 239 309.1 240 288 240zM352 96c0 35.25-28.75 64-64 64S224 131.2 224 96V83C244.4 81.12 265.8 80 288 80s43.63 1.125 64 3V96zM398.9 230.9c-13.75-9.875-23.88-23.88-28.38-40.5c-5.125-19.13-2.5-39 7.375-56l25.62-44.5C477.8 103.5 528 129.8 528 160C528 190.9 475.6 217.5 398.9 230.9z\"\n ]\n};\nvar faDrumstickBite = {\n prefix: 'fas',\n iconName: 'drumstick-bite',\n icon: [\n 512,\n 512,\n [],\n \"f6d7\",\n \"M512 168.9c0 1.766-.0229 3.398-.0768 5.164c-16.91-9.132-35.51-13.76-53.96-13.76c-82.65 0-105.5 74.17-105.5 105.4c0 27.04 9.923 54.43 29.63 76.25c-19.52 6.629-39.99 9.997-60.62 9.997l-87.18 .0038l-40.59 40.49c-6.104 6.103-8.921 14.01-8.921 22.17c0 13.98 7.244 17.1 7.244 37.03C192.1 485.4 164.6 512 131.7 512c-15.63 0-31.11-6.055-42.72-17.8c-11.55-11.46-16.82-26.31-16.82-41.26c0-4.948 .575-9.903 1.695-14.75c-4.842 1.11-9.793 1.681-14.72 1.681c-42.15 0-59.13-36.64-59.13-59.5c0-33.43 27.15-60.34 60.39-60.34c18.97 0 22.97 7.219 36.96 7.219c8.159 0 16.04-2.811 22.14-8.914l40.57-40.47L160.1 191.1c0-63.1 27.79-107 63.17-142.4c33.13-33.06 76.39-49.59 119.7-49.59s86.79 16.53 119.9 49.59C495.9 82.5 512 125.7 512 168.9z\"\n ]\n};\nvar faDumbbell = {\n prefix: 'fas',\n iconName: 'dumbbell',\n icon: [\n 640,\n 512,\n [],\n \"f44b\",\n \"M104 96h-48C42.75 96 32 106.8 32 120V224C14.33 224 0 238.3 0 256c0 17.67 14.33 32 31.1 32L32 392C32 405.3 42.75 416 56 416h48C117.3 416 128 405.3 128 392v-272C128 106.8 117.3 96 104 96zM456 32h-48C394.8 32 384 42.75 384 56V224H256V56C256 42.75 245.3 32 232 32h-48C170.8 32 160 42.75 160 56v400C160 469.3 170.8 480 184 480h48C245.3 480 256 469.3 256 456V288h128v168c0 13.25 10.75 24 24 24h48c13.25 0 24-10.75 24-24V56C480 42.75 469.3 32 456 32zM608 224V120C608 106.8 597.3 96 584 96h-48C522.8 96 512 106.8 512 120v272c0 13.25 10.75 24 24 24h48c13.25 0 24-10.75 24-24V288c17.67 0 32-14.33 32-32C640 238.3 625.7 224 608 224z\"\n ]\n};\nvar faDumpster = {\n prefix: 'fas',\n iconName: 'dumpster',\n icon: [\n 576,\n 512,\n [],\n \"f793\",\n \"M560 160c10.38 0 17.1-9.75 15.5-19.88l-24-95.1C549.8 37 543.3 32 536 32h-98.88l25.62 128H560zM272 32H171.5L145.9 160H272V32zM404.5 32H304v128h126.1L404.5 32zM16 160h97.25l25.63-128H40C32.75 32 26.25 37 24.5 44.12l-24 95.1C-2.001 150.2 5.625 160 16 160zM560 224h-20L544 192H32l4 32H16C7.25 224 0 231.2 0 240v32C0 280.8 7.25 288 16 288h28L64 448v16C64 472.8 71.25 480 80 480h32C120.8 480 128 472.8 128 464V448h320v16c0 8.75 7.25 16 16 16h32c8.75 0 16-7.25 16-16V448l20-160H560C568.8 288 576 280.8 576 272v-32C576 231.2 568.8 224 560 224z\"\n ]\n};\nvar faDumpsterFire = {\n prefix: 'fas',\n iconName: 'dumpster-fire',\n icon: [\n 640,\n 512,\n [],\n \"f794\",\n \"M418.8 104.2L404.6 32H304.1L304 159.1h60.77C381.1 140.7 399.1 121.8 418.8 104.2zM272.1 32.12H171.5L145.9 160.1h126.1L272.1 32.12zM461.3 104.2c18.25 16.25 35.51 33.62 51.14 51.49c5.751-5.623 11.38-11.12 17.38-16.37l21.26-18.98l21.25 18.98c1.125 .9997 2.125 2.124 3.126 3.124c-.125-.7498 .2501-1.5 0-2.249l-24-95.97c-1.625-7.123-8.127-12.12-15.38-12.12H437.2l12.25 61.5L461.3 104.2zM16 160.1l97.26-.0223l25.64-127.9h-98.89c-7.251 0-13.75 4.999-15.5 12.12L.5001 140.2C-2.001 150.3 5.626 160.1 16 160.1zM340.6 192.1L32.01 192.1l4.001 31.99L16 224.1C7.252 224.1 0 231.3 0 240.1V272c0 8.748 7.251 15.1 16 15.1l28.01 .0177l20 159.1L64.01 464C64.01 472.8 71.26 480 80.01 480h32.01c8.752 0 16-7.248 16-15.1v-15.1l208.8-.002c-30.13-33.74-48.73-77.85-48.73-126.3C288.1 285.8 307.9 238.8 340.6 192.1zM551.2 163.3c-14.88 13.25-28.38 27.12-40.26 41.12c-19.5-25.74-43.63-51.99-71.01-76.36c-70.14 62.73-120 144.2-120 193.6C319.1 409.1 391.6 480 479.1 480s160-70.87 160-158.3C640.1 285 602.1 209.4 551.2 163.3zM532.6 392.6c-14.75 10.62-32.88 16.1-52.51 16.1c-49.01 0-88.89-33.49-88.89-87.98c0-27.12 16.5-50.99 49.38-91.85c4.751 5.498 67.14 87.98 67.14 87.98l39.76-46.99c2.876 4.874 5.375 9.497 7.75 13.1C573.9 321.5 565.1 368.4 532.6 392.6z\"\n ]\n};\nvar faDungeon = {\n prefix: 'fas',\n iconName: 'dungeon',\n icon: [\n 512,\n 512,\n [],\n \"f6d9\",\n \"M336.6 156.5C327.3 148.1 322.6 136.5 327.1 125.3L357.6 49.18C362.7 36.27 377.8 30.36 389.7 37.63C410.9 50.63 430 66.62 446.5 85.02C455.7 95.21 452.9 110.9 441.5 118.5L373.9 163.5C363.6 170.4 349.8 168.1 340.5 159.9C339.2 158.7 337.9 157.6 336.6 156.5H336.6zM297.7 112.6C293.2 123.1 280.9 129.8 268.7 128.6C264.6 128.2 260.3 128 256 128C251.7 128 247.4 128.2 243.3 128.6C231.1 129.8 218.8 123.1 214.3 112.6L183.1 36.82C178.8 24.02 185.5 9.433 198.1 6.374C217.3 2.203 236.4 0 256 0C275.6 0 294.7 2.203 313 6.374C326.5 9.433 333.2 24.02 328 36.82L297.7 112.6zM122.3 37.63C134.2 30.36 149.3 36.27 154.4 49.18L184.9 125.3C189.4 136.5 184.7 148.1 175.4 156.5C174.1 157.6 172.8 158.7 171.5 159.9C162.2 168.1 148.4 170.4 138.1 163.5L70.52 118.5C59.13 110.9 56.32 95.21 65.46 85.02C81.99 66.62 101.1 50.63 122.3 37.63H122.3zM379.5 222.1C376.3 210.7 379.7 198.1 389.5 191.6L458.1 145.8C469.7 138.1 485.6 141.9 491.2 154.7C501.6 178.8 508.4 204.8 510.9 232C512.1 245.2 501.3 255.1 488 255.1H408C394.7 255.1 384.2 245.2 381.8 232.1C381.1 228.7 380.4 225.4 379.5 222.1V222.1zM122.5 191.6C132.3 198.1 135.7 210.7 132.5 222.1C131.6 225.4 130.9 228.7 130.2 232.1C127.8 245.2 117.3 256 104 256H24C10.75 256-.1184 245.2 1.107 232C3.636 204.8 10.43 178.8 20.82 154.7C26.36 141.9 42.26 138.1 53.91 145.8L122.5 191.6zM104 288C117.3 288 128 298.7 128 312V360C128 373.3 117.3 384 104 384H24C10.75 384 0 373.3 0 360V312C0 298.7 10.75 288 24 288H104zM488 288C501.3 288 512 298.7 512 312V360C512 373.3 501.3 384 488 384H408C394.7 384 384 373.3 384 360V312C384 298.7 394.7 288 408 288H488zM104 416C117.3 416 128 426.7 128 440V488C128 501.3 117.3 512 104 512H24C10.75 512 0 501.3 0 488V440C0 426.7 10.75 416 24 416H104zM488 416C501.3 416 512 426.7 512 440V488C512 501.3 501.3 512 488 512H408C394.7 512 384 501.3 384 488V440C384 426.7 394.7 416 408 416H488zM272 464C272 472.8 264.8 480 256 480C247.2 480 240 472.8 240 464V192C240 183.2 247.2 176 256 176C264.8 176 272 183.2 272 192V464zM208 464C208 472.8 200.8 480 192 480C183.2 480 176 472.8 176 464V224C176 215.2 183.2 208 192 208C200.8 208 208 215.2 208 224V464zM336 464C336 472.8 328.8 480 320 480C311.2 480 304 472.8 304 464V224C304 215.2 311.2 208 320 208C328.8 208 336 215.2 336 224V464z\"\n ]\n};\nvar faE = {\n prefix: 'fas',\n iconName: 'e',\n icon: [\n 320,\n 512,\n [\n 101\n ],\n \"45\",\n \"M320 448c0 17.67-14.33 32-32 32H32c-17.67 0-32-14.33-32-32v-384C0 46.34 14.33 32.01 32 32.01h256c17.67 0 32 14.33 32 32s-14.33 32-32 32H64v128h160c17.67 0 32 14.32 32 31.99s-14.33 32.01-32 32.01H64v128h224C305.7 416 320 430.3 320 448z\"\n ]\n};\nvar faEarDeaf = {\n prefix: 'fas',\n iconName: 'ear-deaf',\n icon: [\n 512,\n 512,\n [\n \"deaf\",\n \"deafness\",\n \"hard-of-hearing\"\n ],\n \"f2a4\",\n \"M192 319.1C185.8 313.7 177.6 310.6 169.4 310.6S153 313.7 146.8 319.1l-137.4 137.4C3.124 463.6 0 471.8 0 480c0 18.3 14.96 31.1 31.1 31.1c8.188 0 16.38-3.124 22.62-9.371l137.4-137.4c6.247-6.247 9.371-14.44 9.371-22.62S198.3 326.2 192 319.1zM200 240c0-22.06 17.94-40 40-40s40 17.94 40 40c0 13.25 10.75 24 24 24s24-10.75 24-24c0-48.53-39.47-88-88-88S152 191.5 152 240c0 13.25 10.75 24 24 24S200 253.3 200 240zM511.1 31.1c0-8.188-3.124-16.38-9.371-22.62s-14.44-9.372-22.63-9.372s-16.38 3.124-22.62 9.372L416 50.75c-6.248 6.248-9.372 14.44-9.372 22.63c0 8.188 3.123 16.38 9.37 22.62c6.247 6.248 14.44 9.372 22.63 9.372s16.38-3.124 22.63-9.372l41.38-41.38C508.9 48.37 511.1 40.18 511.1 31.1zM415.1 241.6c0-57.78-42.91-177.6-175.1-177.6c-153.6 0-175.2 150.8-175.2 160.4c0 17.32 14.99 31.58 32.75 31.58c16.61 0 29.25-13.07 31.24-29.55c6.711-55.39 54.02-98.45 111.2-98.45c80.45 0 111.2 75.56 111.2 119.6c0 57.94-38.22 98.14-46.37 106.3L288 370.7v13.25c0 31.4-22.71 57.58-52.58 62.98C220.4 449.7 208 463.3 208 478.6c0 17.95 14.72 32.09 32.03 32.09c4.805 0 100.5-14.34 111.2-112.7C412.6 335.8 415.1 263.4 415.1 241.6z\"\n ]\n};\nvar faDeaf = faEarDeaf;\nvar faDeafness = faEarDeaf;\nvar faHardOfHearing = faEarDeaf;\nvar faEarListen = {\n prefix: 'fas',\n iconName: 'ear-listen',\n icon: [\n 512,\n 512,\n [\n \"assistive-listening-systems\"\n ],\n \"f2a2\",\n \"M160.1 320c-17.64 0-32.02 14.37-32.02 31.1s14.38 31.1 32.02 31.1s32.02-14.37 32.02-31.1S177.8 320 160.1 320zM86.66 361.4c-12.51-12.49-32.77-12.49-45.27 0c-12.51 12.5-12.51 32.78 0 45.27l63.96 63.99c12.51 12.49 32.77 12.49 45.27 .002c12.51-12.5 12.51-32.78 0-45.27L86.66 361.4zM32.02 448C14.38 448 0 462.4 0 480S14.38 512 32.02 512c17.64 0 32.02-14.37 32.02-31.1S49.66 448 32.02 448zM287.7 70.31c-110.9-29.38-211.7 47.53-222.8 150.9C62.1 239.9 78.73 255.1 97.57 255.1c16.61 0 29.25-13.07 31.24-29.55c6.934-57.22 57.21-101.3 116.9-98.3c71.71 3.594 117.1 76.82 102.5 146.9c-6.551 29.65-21.4 56.87-43.38 78.87L288 370.7v13.25c0 31.4-22.71 57.58-52.58 62.98C220.4 449.7 208 463.3 208 478.6c0 19.78 17.88 34.94 37.38 31.64c55.92-9.443 99.63-55.28 105.9-112.2c40.11-40.68 62.89-93.95 64.65-150.9C418.4 166.4 365.8 91 287.7 70.31zM240 200c22.06 0 40 17.94 40 40c0 13.25 10.75 24 24 24s24-10.75 24-24c0-48.53-39.47-88-88-88S152 191.5 152 240c0 13.25 10.75 24 24 24S200 253.3 200 240C200 217.9 217.9 200 240 200zM397.8 3.125c-15.91-7.594-35.05-.8438-42.66 15.09c-7.594 15.97-.8281 35.06 15.12 42.66C417.5 83.41 448 134.9 448 192c0 17.69 14.33 32 32 32S512 209.7 512 192C512 110.3 467.2 36.19 397.8 3.125z\"\n ]\n};\nvar faAssistiveListeningSystems = faEarListen;\nvar faEarthAfrica = {\n prefix: 'fas',\n iconName: 'earth-africa',\n icon: [\n 512,\n 512,\n [\n 127757,\n \"globe-africa\"\n ],\n \"f57c\",\n \"M512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM177.8 63.19L187.8 80.62C190.5 85.46 192 90.93 192 96.5V137.9C192 141.8 193.6 145.6 196.3 148.3C202.6 154.6 212.8 153.1 218.3 147.1L231.9 130.1C236.6 124.2 244.8 122.4 251.6 125.8L266.8 133.4C270.2 135.1 273.1 136 277.8 136C284.3 136 290.6 133.4 295.2 128.8L299.1 124.9C302 121.1 306.5 121.2 310.1 123.1L339.4 137.7C347.1 141.6 352 149.5 352 158.1C352 168.6 344.9 177.8 334.7 180.3L299.3 189.2C291.9 191 284.2 190.7 276.1 188.3L244.1 177.7C241.7 176.6 238.2 176 234.8 176C227.8 176 220.1 178.3 215.4 182.5L176 212C165.9 219.6 160 231.4 160 244V272C160 298.5 181.5 320 208 320H240C248.8 320 256 327.2 256 336V384C256 401.7 270.3 416 288 416C298.1 416 307.6 411.3 313.6 403.2L339.2 369.1C347.5 357.1 352 344.5 352 330.7V318.6C352 314.7 354.6 311.3 358.4 310.4L363.7 309.1C375.6 306.1 384 295.4 384 283.1C384 275.1 381.2 269.2 376.2 264.2L342.7 230.7C338.1 226.1 338.1 221 342.7 217.3C348.4 211.6 356.8 209.6 364.5 212.2L378.6 216.9C390.9 220.1 404.3 215.4 410.1 203.8C413.6 196.8 421.3 193.1 428.1 194.6L456.4 200.1C431.1 112.4 351.5 48 256 48C228.3 48 201.1 53.4 177.8 63.19L177.8 63.19z\"\n ]\n};\nvar faGlobeAfrica = faEarthAfrica;\nvar faEarthAmericas = {\n prefix: 'fas',\n iconName: 'earth-americas',\n icon: [\n 512,\n 512,\n [\n 127758,\n \"earth\",\n \"earth-america\",\n \"globe-americas\"\n ],\n \"f57d\",\n \"M512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM57.71 192.1L67.07 209.4C75.36 223.9 88.99 234.6 105.1 239.2L162.1 255.7C180.2 260.6 192 276.3 192 294.2V334.1C192 345.1 198.2 355.1 208 359.1C217.8 364.9 224 374.9 224 385.9V424.9C224 440.5 238.9 451.7 253.9 447.4C270.1 442.8 282.5 429.1 286.6 413.7L289.4 402.5C293.6 385.6 304.6 371.1 319.7 362.4L327.8 357.8C342.8 349.3 352 333.4 352 316.1V307.9C352 295.1 346.9 282.9 337.9 273.9L334.1 270.1C325.1 261.1 312.8 255.1 300.1 255.1H256.1C245.9 255.1 234.9 253.1 225.2 247.6L190.7 227.8C186.4 225.4 183.1 221.4 181.6 216.7C178.4 207.1 182.7 196.7 191.7 192.1L197.7 189.2C204.3 185.9 211.9 185.3 218.1 187.7L242.2 195.4C250.3 198.1 259.3 195 264.1 187.9C268.8 180.8 268.3 171.5 262.9 165L249.3 148.8C239.3 136.8 239.4 119.3 249.6 107.5L265.3 89.12C274.1 78.85 275.5 64.16 268.8 52.42L266.4 48.26C262.1 48.09 259.5 48 256 48C163.1 48 84.4 108.9 57.71 192.1L57.71 192.1zM437.6 154.5L412 164.8C396.3 171.1 388.2 188.5 393.5 204.6L410.4 255.3C413.9 265.7 422.4 273.6 433 276.3L462.2 283.5C463.4 274.5 464 265.3 464 256C464 219.2 454.4 184.6 437.6 154.5H437.6z\"\n ]\n};\nvar faEarth = faEarthAmericas;\nvar faEarthAmerica = faEarthAmericas;\nvar faGlobeAmericas = faEarthAmericas;\nvar faEarthAsia = {\n prefix: 'fas',\n iconName: 'earth-asia',\n icon: [\n 512,\n 512,\n [\n 127759,\n \"globe-asia\"\n ],\n \"f57e\",\n \"M512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM51.68 295.1L83.41 301.5C91.27 303.1 99.41 300.6 105.1 294.9L120.5 279.5C132 267.1 151.6 271.1 158.9 285.8L168.2 304.3C172.1 313.9 182.8 319.1 193.5 319.1C208.7 319.1 219.6 305.4 215.2 290.8L209.3 270.9C204.6 255.5 216.2 240 232.3 240H234.6C247.1 240 260.5 233.3 267.9 222.2L278.6 206.1C284.2 197.7 283.9 186.6 277.8 178.4L261.7 156.9C251.4 143.2 258.4 123.4 275.1 119.2L292.1 114.1C299.6 113.1 305.7 107.8 308.6 100.6L324.9 59.69C303.4 52.12 280.2 48 255.1 48C141.1 48 47.1 141.1 47.1 256C47.1 269.4 49.26 282.5 51.68 295.1L51.68 295.1zM450.4 300.4L434.6 304.9C427.9 306.7 420.8 304 417.1 298.2L415.1 295.1C409.1 285.7 398.7 279.1 387.5 279.1C376.4 279.1 365.1 285.7 359.9 295.1L353.8 304.6C352.4 306.8 350.5 308.7 348.2 309.1L311.1 330.1C293.9 340.2 286.5 362.5 294.1 381.4L300.5 393.8C309.1 413 331.2 422.3 350.1 414.9L353.5 413.1C363.6 410.2 374.8 411.8 383.5 418.1L385 419.2C422.2 389.7 449.1 347.8 459.4 299.7C456.4 299.4 453.4 299.6 450.4 300.4H450.4zM156.1 367.5L188.1 375.5C196.7 377.7 205.4 372.5 207.5 363.9C209.7 355.3 204.5 346.6 195.9 344.5L163.9 336.5C155.3 334.3 146.6 339.5 144.5 348.1C142.3 356.7 147.5 365.4 156.1 367.5V367.5zM236.5 328.1C234.3 336.7 239.5 345.4 248.1 347.5C256.7 349.7 265.4 344.5 267.5 335.9L275.5 303.9C277.7 295.3 272.5 286.6 263.9 284.5C255.3 282.3 246.6 287.5 244.5 296.1L236.5 328.1zM321.7 120.8L305.7 152.8C301.7 160.7 304.9 170.4 312.8 174.3C320.7 178.3 330.4 175.1 334.3 167.2L350.3 135.2C354.3 127.3 351.1 117.6 343.2 113.7C335.3 109.7 325.6 112.9 321.7 120.8V120.8z\"\n ]\n};\nvar faGlobeAsia = faEarthAsia;\nvar faEarthEurope = {\n prefix: 'fas',\n iconName: 'earth-europe',\n icon: [\n 512,\n 512,\n [\n \"globe-europe\"\n ],\n \"f7a2\",\n \"M512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM266.3 48.25L232.5 73.6C227.2 77.63 224 83.95 224 90.67V99.72C224 106.5 229.5 112 236.3 112C238.7 112 241.1 111.3 243.1 109.9L284.9 82.06C286.9 80.72 289.3 80 291.7 80H292.7C298.9 80 304 85.07 304 91.31C304 94.31 302.8 97.19 300.7 99.31L280.8 119.2C275 124.1 267.9 129.4 260.2 131.9L233.6 140.8C227.9 142.7 224 148.1 224 154.2C224 157.9 222.5 161.5 219.9 164.1L201.9 182.1C195.6 188.4 192 197.1 192 206.1V210.3C192 226.7 205.6 240 221.9 240C232.9 240 243.1 233.8 248 224L252 215.9C254.5 211.1 259.4 208 264.8 208C269.4 208 273.6 210.1 276.3 213.7L292.6 235.5C294.7 238.3 298.1 240 301.7 240C310.1 240 315.6 231.1 311.8 223.6L310.7 221.3C307.1 214.3 310.7 205.8 318.1 203.3L339.3 196.2C346.9 193.7 352 186.6 352 178.6C352 168.3 360.3 160 370.6 160H400C408.8 160 416 167.2 416 176C416 184.8 408.8 192 400 192H379.3C372.1 192 365.1 194.9 360 200L355.3 204.7C353.2 206.8 352 209.7 352 212.7C352 218.9 357.1 224 363.3 224H374.6C380.6 224 386.4 226.4 390.6 230.6L397.2 237.2C398.1 238.1 400 241.4 400 244C400 246.6 398.1 249 397.2 250.8L389.7 258.3C386 261.1 384 266.9 384 272C384 277.1 386 282 389.7 285.7L408 304C418.2 314.2 432.1 320 446.6 320H453.1C460.5 299.8 464 278.3 464 256C464 144.6 376.4 53.64 266.3 48.25V48.25zM438.4 356.1C434.7 353.5 430.2 352 425.4 352C419.4 352 413.6 349.6 409.4 345.4L395.1 331.1C388.3 324.3 377.9 320 367.1 320C357.4 320 347.9 316.5 340.5 310.2L313.1 287.4C302.4 277.5 287.6 271.1 272.3 271.1H251.4C238.7 271.1 226.4 275.7 215.9 282.7L188.5 301C170.7 312.9 160 332.9 160 354.3V357.5C160 374.5 166.7 390.7 178.7 402.7L194.7 418.7C203.2 427.2 214.7 432 226.7 432H248C261.3 432 272 442.7 272 456C272 458.5 272.4 461 273.1 463.3C344.5 457.5 405.6 415.7 438.4 356.1L438.4 356.1zM164.7 100.7L132.7 132.7C126.4 138.9 126.4 149.1 132.7 155.3C138.9 161.6 149.1 161.6 155.3 155.3L187.3 123.3C193.6 117.1 193.6 106.9 187.3 100.7C181.1 94.44 170.9 94.44 164.7 100.7V100.7z\"\n ]\n};\nvar faGlobeEurope = faEarthEurope;\nvar faEarthOceania = {\n prefix: 'fas',\n iconName: 'earth-oceania',\n icon: [\n 512,\n 512,\n [\n \"globe-oceania\"\n ],\n \"e47b\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM215.5 360.6L240.9 377C247.1 381.6 256.2 384 264.6 384C278 384 290.7 377.8 298.1 367.2L311 351.8C316.8 344.4 320 335.2 320 325.8C320 316.4 316.8 307.2 311 299.8L293.1 276.9C288.3 270.7 284.4 263.1 281.6 256.7L271.5 230.8C269.9 226.7 265.9 224 261.5 224C258 224 254.8 225.6 252.8 228.4L242.4 242.6C237.7 248.1 229.7 252.1 221.9 250.5C218.7 249.8 215.8 247.1 213.8 245.4L209.3 239.3C202.1 229.7 190.7 224 178.7 224C166.7 224 155.3 229.7 148.1 239.3L142.8 246.3C141.3 248.4 139.2 250 136.9 251.1L101.6 267.9C81.08 277.7 72.8 302.6 83.37 322.7L86.65 328.9C95.67 346.1 115.7 354.3 134.1 348.4L149.5 343.6C156 341.5 163.1 341.6 169.6 343.8L208.6 357.3C211 358.1 213.4 359.2 215.5 360.6H215.5zM273.8 142.5C264.3 132.1 250.8 128.9 237.6 131.5L199.1 139.2C183.8 142.3 181.5 163.2 195.7 169.5L238.5 188.6C243.7 190.8 249.2 192 254.8 192H284.7C298.9 192 306.1 174.8 296 164.7L273.8 142.5zM264 448H280C288.8 448 296 440.8 296 432C296 423.2 288.8 416 280 416H264C255.2 416 248 423.2 248 432C248 440.8 255.2 448 264 448zM431.2 298.9C428.4 290.6 419.3 286 410.9 288.8C402.6 291.6 398 300.7 400.8 309.1L408.8 333.1C411.6 341.4 420.7 345.1 429.1 343.2C437.4 340.4 441.1 331.3 439.2 322.9L431.2 298.9zM411.3 379.3C417.6 373.1 417.6 362.9 411.3 356.7C405.1 350.4 394.9 350.4 388.7 356.7L356.7 388.7C350.4 394.9 350.4 405.1 356.7 411.3C362.9 417.6 373.1 417.6 379.3 411.3L411.3 379.3z\"\n ]\n};\nvar faGlobeOceania = faEarthOceania;\nvar faEgg = {\n prefix: 'fas',\n iconName: 'egg',\n icon: [\n 384,\n 512,\n [\n 129370\n ],\n \"f7fb\",\n \"M192 16c-106 0-192 182-192 288c0 106 85.1 192 192 192c105.1 0 192-85.1 192-192C384 198 297.1 16 192 16zM160.1 138C128.6 177.1 96 249.8 96 304C96 312.8 88.84 320 80 320S64 312.8 64 304c0-63.56 36.7-143.3 71.22-186c5.562-6.906 15.64-7.969 22.5-2.406C164.6 121.1 165.7 131.2 160.1 138z\"\n ]\n};\nvar faEject = {\n prefix: 'fas',\n iconName: 'eject',\n icon: [\n 448,\n 512,\n [\n 9167\n ],\n \"f052\",\n \"M48.01 319.1h351.1c41.62 0 63.49-49.63 35.37-80.38l-175.1-192.1c-19-20.62-51.75-20.62-70.75 0L12.64 239.6C-15.48 270.2 6.393 319.1 48.01 319.1zM399.1 384H48.01c-26.39 0-47.99 21.59-47.99 47.98C.0117 458.4 21.61 480 48.01 480h351.1c26.39 0 47.99-21.6 47.99-47.99C447.1 405.6 426.4 384 399.1 384z\"\n ]\n};\nvar faElevator = {\n prefix: 'fas',\n iconName: 'elevator',\n icon: [\n 512,\n 512,\n [],\n \"e16d\",\n \"M79 96h130c5.967 0 11.37-3.402 13.75-8.662c2.385-5.262 1.299-11.39-2.754-15.59l-65-67.34c-5.684-5.881-16.31-5.881-21.99 0l-65 67.34C63.95 75.95 62.87 82.08 65.25 87.34C67.63 92.6 73.03 96 79 96zM357 91.59c5.686 5.881 16.31 5.881 21.99 0l65-67.34c4.053-4.199 5.137-10.32 2.754-15.59C444.4 3.402 438.1 0 433 0h-130c-5.967 0-11.37 3.402-13.75 8.662c-2.385 5.262-1.301 11.39 2.752 15.59L357 91.59zM448 128H64c-35.35 0-64 28.65-64 63.1v255.1C0 483.3 28.65 512 64 512h384c35.35 0 64-28.65 64-63.1V192C512 156.7 483.3 128 448 128zM352 224C378.5 224.1 400 245.5 400 272c0 26.46-21.47 47.9-48 48C325.5 319.9 304 298.5 304 272C304 245.5 325.5 224.1 352 224zM160 224C186.5 224.1 208 245.5 208 272c0 26.46-21.47 47.9-48 48C133.5 319.9 112 298.5 112 272C112 245.5 133.5 224.1 160 224zM240 448h-160v-48C80 373.5 101.5 352 128 352h64c26.51 0 48 21.49 48 48V448zM432 448h-160v-48c0-26.51 21.49-48 48-48h64c26.51 0 48 21.49 48 48V448z\"\n ]\n};\nvar faEllipsis = {\n prefix: 'fas',\n iconName: 'ellipsis',\n icon: [\n 448,\n 512,\n [\n \"ellipsis-h\"\n ],\n \"f141\",\n \"M120 256C120 286.9 94.93 312 64 312C33.07 312 8 286.9 8 256C8 225.1 33.07 200 64 200C94.93 200 120 225.1 120 256zM280 256C280 286.9 254.9 312 224 312C193.1 312 168 286.9 168 256C168 225.1 193.1 200 224 200C254.9 200 280 225.1 280 256zM328 256C328 225.1 353.1 200 384 200C414.9 200 440 225.1 440 256C440 286.9 414.9 312 384 312C353.1 312 328 286.9 328 256z\"\n ]\n};\nvar faEllipsisH = faEllipsis;\nvar faEllipsisVertical = {\n prefix: 'fas',\n iconName: 'ellipsis-vertical',\n icon: [\n 128,\n 512,\n [\n \"ellipsis-v\"\n ],\n \"f142\",\n \"M64 360C94.93 360 120 385.1 120 416C120 446.9 94.93 472 64 472C33.07 472 8 446.9 8 416C8 385.1 33.07 360 64 360zM64 200C94.93 200 120 225.1 120 256C120 286.9 94.93 312 64 312C33.07 312 8 286.9 8 256C8 225.1 33.07 200 64 200zM64 152C33.07 152 8 126.9 8 96C8 65.07 33.07 40 64 40C94.93 40 120 65.07 120 96C120 126.9 94.93 152 64 152z\"\n ]\n};\nvar faEllipsisV = faEllipsisVertical;\nvar faEnvelope = {\n prefix: 'fas',\n iconName: 'envelope',\n icon: [\n 512,\n 512,\n [\n 128386,\n 61443,\n 9993\n ],\n \"f0e0\",\n \"M256 352c-16.53 0-33.06-5.422-47.16-16.41L0 173.2V400C0 426.5 21.49 448 48 448h416c26.51 0 48-21.49 48-48V173.2l-208.8 162.5C289.1 346.6 272.5 352 256 352zM16.29 145.3l212.2 165.1c16.19 12.6 38.87 12.6 55.06 0l212.2-165.1C505.1 137.3 512 125 512 112C512 85.49 490.5 64 464 64h-416C21.49 64 0 85.49 0 112C0 125 6.01 137.3 16.29 145.3z\"\n ]\n};\nvar faEnvelopeOpen = {\n prefix: 'fas',\n iconName: 'envelope-open',\n icon: [\n 512,\n 512,\n [\n 62135\n ],\n \"f2b6\",\n \"M493.6 163c-24.88-19.62-45.5-35.37-164.3-121.6C312.7 29.21 279.7 0 256.4 0H255.6C232.3 0 199.3 29.21 182.6 41.38c-118.8 86.25-139.4 101.1-164.3 121.6C6.75 172 0 186 0 200.8v263.2C0 490.5 21.49 512 48 512h416c26.51 0 48-21.49 48-47.1V200.8C512 186 505.3 172 493.6 163zM303.2 367.5C289.1 378.5 272.5 384 256 384s-33.06-5.484-47.16-16.47L64 254.9V208.5c21.16-16.59 46.48-35.66 156.4-115.5c3.18-2.328 6.891-5.187 10.98-8.353C236.9 80.44 247.8 71.97 256 66.84c8.207 5.131 19.14 13.6 24.61 17.84c4.09 3.166 7.801 6.027 11.15 8.478C400.9 172.5 426.6 191.7 448 208.5v46.32L303.2 367.5z\"\n ]\n};\nvar faEnvelopeOpenText = {\n prefix: 'fas',\n iconName: 'envelope-open-text',\n icon: [\n 512,\n 512,\n [],\n \"f658\",\n \"M256 417.1c-16.38 0-32.88-4.1-46.88-15.12L0 250.9v213.1C0 490.5 21.5 512 48 512h416c26.5 0 48-21.5 48-47.1V250.9l-209.1 151.1C288.9 412 272.4 417.1 256 417.1zM493.6 163C484.8 156 476.4 149.5 464 140.1v-44.12c0-26.5-21.5-48-48-48l-77.5 .0016c-3.125-2.25-5.875-4.25-9.125-6.5C312.6 29.13 279.3-.3732 256 .0018C232.8-.3732 199.4 29.13 182.6 41.5c-3.25 2.25-6 4.25-9.125 6.5L96 48c-26.5 0-48 21.5-48 48v44.12C35.63 149.5 27.25 156 18.38 163C6.75 172 0 186 0 200.8v10.62l96 69.37V96h320v184.7l96-69.37V200.8C512 186 505.3 172 493.6 163zM176 255.1h160c8.836 0 16-7.164 16-15.1c0-8.838-7.164-16-16-16h-160c-8.836 0-16 7.162-16 16C160 248.8 167.2 255.1 176 255.1zM176 191.1h160c8.836 0 16-7.164 16-16c0-8.838-7.164-15.1-16-15.1h-160c-8.836 0-16 7.162-16 15.1C160 184.8 167.2 191.1 176 191.1z\"\n ]\n};\nvar faEnvelopesBulk = {\n prefix: 'fas',\n iconName: 'envelopes-bulk',\n icon: [\n 640,\n 512,\n [\n \"mail-bulk\"\n ],\n \"f674\",\n \"M191.9 448.6c-9.766 0-19.48-2.969-27.78-8.891L32 340.2V480c0 17.62 14.38 32 32 32h256c17.62 0 32-14.38 32-32v-139.8L220.2 439.5C211.7 445.6 201.8 448.6 191.9 448.6zM192 192c0-35.25 28.75-64 64-64h224V32c0-17.62-14.38-32-32-32H128C110.4 0 96 14.38 96 32v192h96V192zM320 256H64C46.38 256 32 270.4 32 288v12.18l151 113.8c5.25 3.719 12.7 3.734 18.27-.25L352 300.2V288C352 270.4 337.6 256 320 256zM576 160H256C238.4 160 224 174.4 224 192v32h96c33.25 0 60.63 25.38 63.75 57.88L384 416h192c17.62 0 32-14.38 32-32V192C608 174.4 593.6 160 576 160zM544 288h-64V224h64V288z\"\n ]\n};\nvar faMailBulk = faEnvelopesBulk;\nvar faEquals = {\n prefix: 'fas',\n iconName: 'equals',\n icon: [\n 448,\n 512,\n [\n 62764\n ],\n \"3d\",\n \"M48 192h352c17.69 0 32-14.32 32-32s-14.31-31.1-32-31.1h-352c-17.69 0-32 14.31-32 31.1S30.31 192 48 192zM400 320h-352c-17.69 0-32 14.31-32 31.1s14.31 32 32 32h352c17.69 0 32-14.32 32-32S417.7 320 400 320z\"\n ]\n};\nvar faEraser = {\n prefix: 'fas',\n iconName: 'eraser',\n icon: [\n 512,\n 512,\n [],\n \"f12d\",\n \"M480 416C497.7 416 512 430.3 512 448C512 465.7 497.7 480 480 480H150.6C133.7 480 117.4 473.3 105.4 461.3L25.37 381.3C.3786 356.3 .3786 315.7 25.37 290.7L258.7 57.37C283.7 32.38 324.3 32.38 349.3 57.37L486.6 194.7C511.6 219.7 511.6 260.3 486.6 285.3L355.9 416H480zM265.4 416L332.7 348.7L195.3 211.3L70.63 336L150.6 416L265.4 416z\"\n ]\n};\nvar faEthernet = {\n prefix: 'fas',\n iconName: 'ethernet',\n icon: [\n 512,\n 512,\n [],\n \"f796\",\n \"M512 208v224c0 8.75-7.25 16-16 16H416v-128h-32v128h-64v-128h-32v128H224v-128H192v128H128v-128H96v128H16C7.25 448 0 440.8 0 432v-224C0 199.2 7.25 192 16 192H64V144C64 135.2 71.25 128 80 128H128V80C128 71.25 135.2 64 144 64h224C376.8 64 384 71.25 384 80V128h48C440.8 128 448 135.2 448 144V192h48C504.8 192 512 199.2 512 208z\"\n ]\n};\nvar faEuroSign = {\n prefix: 'fas',\n iconName: 'euro-sign',\n icon: [\n 384,\n 512,\n [\n 8364,\n \"eur\",\n \"euro\"\n ],\n \"f153\",\n \"M64 240C46.33 240 32 225.7 32 208C32 190.3 46.33 176 64 176H92.29C121.9 92.11 201.1 32 296 32H320C337.7 32 352 46.33 352 64C352 81.67 337.7 96 320 96H296C238.1 96 187.8 128.4 162.1 176H288C305.7 176 320 190.3 320 208C320 225.7 305.7 240 288 240H144.2C144.1 242.6 144 245.3 144 248V264C144 266.7 144.1 269.4 144.2 272H288C305.7 272 320 286.3 320 304C320 321.7 305.7 336 288 336H162.1C187.8 383.6 238.1 416 296 416H320C337.7 416 352 430.3 352 448C352 465.7 337.7 480 320 480H296C201.1 480 121.9 419.9 92.29 336H64C46.33 336 32 321.7 32 304C32 286.3 46.33 272 64 272H80.15C80.05 269.3 80 266.7 80 264V248C80 245.3 80.05 242.7 80.15 240H64z\"\n ]\n};\nvar faEur = faEuroSign;\nvar faEuro = faEuroSign;\nvar faExclamation = {\n prefix: 'fas',\n iconName: 'exclamation',\n icon: [\n 128,\n 512,\n [\n 10069,\n 10071,\n 61738\n ],\n \"21\",\n \"M64 352c17.69 0 32-14.32 32-31.1V64.01c0-17.67-14.31-32.01-32-32.01S32 46.34 32 64.01v255.1C32 337.7 46.31 352 64 352zM64 400c-22.09 0-40 17.91-40 40s17.91 39.1 40 39.1s40-17.9 40-39.1S86.09 400 64 400z\"\n ]\n};\nvar faExpand = {\n prefix: 'fas',\n iconName: 'expand',\n icon: [\n 448,\n 512,\n [],\n \"f065\",\n \"M128 32H32C14.31 32 0 46.31 0 64v96c0 17.69 14.31 32 32 32s32-14.31 32-32V96h64c17.69 0 32-14.31 32-32S145.7 32 128 32zM416 32h-96c-17.69 0-32 14.31-32 32s14.31 32 32 32h64v64c0 17.69 14.31 32 32 32s32-14.31 32-32V64C448 46.31 433.7 32 416 32zM128 416H64v-64c0-17.69-14.31-32-32-32s-32 14.31-32 32v96c0 17.69 14.31 32 32 32h96c17.69 0 32-14.31 32-32S145.7 416 128 416zM416 320c-17.69 0-32 14.31-32 32v64h-64c-17.69 0-32 14.31-32 32s14.31 32 32 32h96c17.69 0 32-14.31 32-32v-96C448 334.3 433.7 320 416 320z\"\n ]\n};\nvar faEye = {\n prefix: 'fas',\n iconName: 'eye',\n icon: [\n 576,\n 512,\n [\n 128065\n ],\n \"f06e\",\n \"M279.6 160.4C282.4 160.1 285.2 160 288 160C341 160 384 202.1 384 256C384 309 341 352 288 352C234.1 352 192 309 192 256C192 253.2 192.1 250.4 192.4 247.6C201.7 252.1 212.5 256 224 256C259.3 256 288 227.3 288 192C288 180.5 284.1 169.7 279.6 160.4zM480.6 112.6C527.4 156 558.7 207.1 573.5 243.7C576.8 251.6 576.8 260.4 573.5 268.3C558.7 304 527.4 355.1 480.6 399.4C433.5 443.2 368.8 480 288 480C207.2 480 142.5 443.2 95.42 399.4C48.62 355.1 17.34 304 2.461 268.3C-.8205 260.4-.8205 251.6 2.461 243.7C17.34 207.1 48.62 156 95.42 112.6C142.5 68.84 207.2 32 288 32C368.8 32 433.5 68.84 480.6 112.6V112.6zM288 112C208.5 112 144 176.5 144 256C144 335.5 208.5 400 288 400C367.5 400 432 335.5 432 256C432 176.5 367.5 112 288 112z\"\n ]\n};\nvar faEyeDropper = {\n prefix: 'fas',\n iconName: 'eye-dropper',\n icon: [\n 512,\n 512,\n [\n \"eye-dropper-empty\",\n \"eyedropper\"\n ],\n \"f1fb\",\n \"M482.8 29.23C521.7 68.21 521.7 131.4 482.8 170.4L381.2 271.9L390.6 281.4C403.1 293.9 403.1 314.1 390.6 326.6C378.1 339.1 357.9 339.1 345.4 326.6L185.4 166.6C172.9 154.1 172.9 133.9 185.4 121.4C197.9 108.9 218.1 108.9 230.6 121.4L240.1 130.8L341.6 29.23C380.6-9.744 443.8-9.744 482.8 29.23L482.8 29.23zM55.43 323.3L176.1 202.6L221.4 247.9L100.7 368.6C97.69 371.6 96 375.6 96 379.9V416H132.1C136.4 416 140.4 414.3 143.4 411.3L264.1 290.6L309.4 335.9L188.7 456.6C173.7 471.6 153.3 480 132.1 480H89.69L49.75 506.6C37.06 515.1 20.16 513.4 9.373 502.6C-1.413 491.8-3.086 474.9 5.375 462.2L32 422.3V379.9C32 358.7 40.43 338.3 55.43 323.3L55.43 323.3z\"\n ]\n};\nvar faEyeDropperEmpty = faEyeDropper;\nvar faEyedropper = faEyeDropper;\nvar faEyeLowVision = {\n prefix: 'fas',\n iconName: 'eye-low-vision',\n icon: [\n 640,\n 512,\n [\n \"low-vision\"\n ],\n \"f2a8\",\n \"M150.7 92.77C195 58.27 251.8 32 320 32C400.8 32 465.5 68.84 512.6 112.6C559.4 156 590.7 207.1 605.5 243.7C608.8 251.6 608.8 260.4 605.5 268.3C592.1 300.6 565.2 346.1 525.6 386.7L630.8 469.1C641.2 477.3 643.1 492.4 634.9 502.8C626.7 513.2 611.6 515.1 601.2 506.9L9.196 42.89C-1.236 34.71-3.065 19.63 5.112 9.196C13.29-1.236 28.37-3.065 38.81 5.112L150.7 92.77zM223.1 149.5L313.4 220.3C317.6 211.8 320 202.2 320 191.1C320 180.5 316.1 169.7 311.6 160.4C314.4 160.1 317.2 159.1 320 159.1C373 159.1 416 202.1 416 255.1C416 269.7 413.1 282.7 407.1 294.5L446.6 324.7C457.7 304.3 464 280.9 464 255.1C464 176.5 399.5 111.1 320 111.1C282.7 111.1 248.6 126.2 223.1 149.5zM393.6 469.4L54.65 203.7C62.6 190.1 72.08 175.8 83.09 161.5L446.2 447.5C429.8 456.4 412.3 463.8 393.6 469.4V469.4zM34.46 268.3C31.74 261.8 31.27 254.5 33.08 247.8L329.2 479.8C326.1 479.9 323.1 480 320 480C239.2 480 174.5 443.2 127.4 399.4C80.62 355.1 49.34 304 34.46 268.3H34.46z\"\n ]\n};\nvar faLowVision = faEyeLowVision;\nvar faEyeSlash = {\n prefix: 'fas',\n iconName: 'eye-slash',\n icon: [\n 640,\n 512,\n [],\n \"f070\",\n \"M150.7 92.77C195 58.27 251.8 32 320 32C400.8 32 465.5 68.84 512.6 112.6C559.4 156 590.7 207.1 605.5 243.7C608.8 251.6 608.8 260.4 605.5 268.3C592.1 300.6 565.2 346.1 525.6 386.7L630.8 469.1C641.2 477.3 643.1 492.4 634.9 502.8C626.7 513.2 611.6 515.1 601.2 506.9L9.196 42.89C-1.236 34.71-3.065 19.63 5.112 9.196C13.29-1.236 28.37-3.065 38.81 5.112L150.7 92.77zM223.1 149.5L313.4 220.3C317.6 211.8 320 202.2 320 191.1C320 180.5 316.1 169.7 311.6 160.4C314.4 160.1 317.2 159.1 320 159.1C373 159.1 416 202.1 416 255.1C416 269.7 413.1 282.7 407.1 294.5L446.6 324.7C457.7 304.3 464 280.9 464 255.1C464 176.5 399.5 111.1 320 111.1C282.7 111.1 248.6 126.2 223.1 149.5zM320 480C239.2 480 174.5 443.2 127.4 399.4C80.62 355.1 49.34 304 34.46 268.3C31.18 260.4 31.18 251.6 34.46 243.7C44 220.8 60.29 191.2 83.09 161.5L177.4 235.8C176.5 242.4 176 249.1 176 255.1C176 335.5 240.5 400 320 400C338.7 400 356.6 396.4 373 389.9L446.2 447.5C409.9 467.1 367.8 480 320 480H320z\"\n ]\n};\nvar faF = {\n prefix: 'fas',\n iconName: 'f',\n icon: [\n 320,\n 512,\n [\n 102\n ],\n \"46\",\n \"M320 64.01c0 17.67-14.33 32-32 32H64v128h160c17.67 0 32 14.32 32 31.1s-14.33 32-32 32H64v160c0 17.67-14.33 32-32 32s-32-14.33-32-32v-384C0 46.34 14.33 32.01 32 32.01h256C305.7 32.01 320 46.34 320 64.01z\"\n ]\n};\nvar faFaceAngry = {\n prefix: 'fas',\n iconName: 'face-angry',\n icon: [\n 512,\n 512,\n [\n 128544,\n \"angry\"\n ],\n \"f556\",\n \"M512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM339.9 373.3C323.8 355.4 295.7 336 256 336C216.3 336 188.2 355.4 172.1 373.3C166.2 379.9 166.7 389.1 173.3 395.9C179.9 401.8 189.1 401.3 195.9 394.7C207.6 381.7 227.5 368 255.1 368C284.5 368 304.4 381.7 316.1 394.7C322 401.3 332.1 401.8 338.7 395.9C345.3 389.1 345.8 379.9 339.9 373.3H339.9zM176.4 272C194 272 208.4 257.7 208.4 240C208.4 238.5 208.3 237 208.1 235.6L218.9 239.2C227.3 241.1 236.4 237.4 239.2 229.1C241.1 220.7 237.4 211.6 229.1 208.8L133.1 176.8C124.7 174 115.6 178.6 112.8 186.9C110 195.3 114.6 204.4 122.9 207.2L153.7 217.4C147.9 223.2 144.4 231.2 144.4 240C144.4 257.7 158.7 272 176.4 272zM358.9 217.2L389.1 207.2C397.4 204.4 401.1 195.3 399.2 186.9C396.4 178.6 387.3 174 378.9 176.8L282.9 208.8C274.6 211.6 270 220.7 272.8 229.1C275.6 237.4 284.7 241.1 293.1 239.2L304.7 235.3C304.5 236.8 304.4 238.4 304.4 240C304.4 257.7 318.7 272 336.4 272C354 272 368.4 257.7 368.4 240C368.4 231.1 364.7 223 358.9 217.2H358.9z\"\n ]\n};\nvar faAngry = faFaceAngry;\nvar faFaceDizzy = {\n prefix: 'fas',\n iconName: 'face-dizzy',\n icon: [\n 512,\n 512,\n [\n \"dizzy\"\n ],\n \"f567\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM256 416C291.3 416 320 387.3 320 352C320 316.7 291.3 288 256 288C220.7 288 192 316.7 192 352C192 387.3 220.7 416 256 416zM100.7 155.3L137.4 192L100.7 228.7C94.44 234.9 94.44 245.1 100.7 251.3C106.9 257.6 117.1 257.6 123.3 251.3L160 214.6L196.7 251.3C202.9 257.6 213.1 257.6 219.3 251.3C225.6 245.1 225.6 234.9 219.3 228.7L182.6 192L219.3 155.3C225.6 149.1 225.6 138.9 219.3 132.7C213.1 126.4 202.9 126.4 196.7 132.7L160 169.4L123.3 132.7C117.1 126.4 106.9 126.4 100.7 132.7C94.44 138.9 94.44 149.1 100.7 155.3zM292.7 155.3L329.4 192L292.7 228.7C286.4 234.9 286.4 245.1 292.7 251.3C298.9 257.6 309.1 257.6 315.3 251.3L352 214.6L388.7 251.3C394.9 257.6 405.1 257.6 411.3 251.3C417.6 245.1 417.6 234.9 411.3 228.7L374.6 192L411.3 155.3C417.6 149.1 417.6 138.9 411.3 132.7C405.1 126.4 394.9 126.4 388.7 132.7L352 169.4L315.3 132.7C309.1 126.4 298.9 126.4 292.7 132.7C286.4 138.9 286.4 149.1 292.7 155.3z\"\n ]\n};\nvar faDizzy = faFaceDizzy;\nvar faFaceFlushed = {\n prefix: 'fas',\n iconName: 'face-flushed',\n icon: [\n 512,\n 512,\n [\n 128563,\n \"flushed\"\n ],\n \"f579\",\n \"M184 224C184 237.3 173.3 248 160 248C146.7 248 136 237.3 136 224C136 210.7 146.7 200 160 200C173.3 200 184 210.7 184 224zM376 224C376 237.3 365.3 248 352 248C338.7 248 328 237.3 328 224C328 210.7 338.7 200 352 200C365.3 200 376 210.7 376 224zM512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM192 400H320C328.8 400 336 392.8 336 384C336 375.2 328.8 368 320 368H192C183.2 368 176 375.2 176 384C176 392.8 183.2 400 192 400zM160 296C199.8 296 232 263.8 232 224C232 184.2 199.8 152 160 152C120.2 152 88 184.2 88 224C88 263.8 120.2 296 160 296zM352 152C312.2 152 280 184.2 280 224C280 263.8 312.2 296 352 296C391.8 296 424 263.8 424 224C424 184.2 391.8 152 352 152z\"\n ]\n};\nvar faFlushed = faFaceFlushed;\nvar faFaceFrown = {\n prefix: 'fas',\n iconName: 'face-frown',\n icon: [\n 512,\n 512,\n [\n 9785,\n \"frown\"\n ],\n \"f119\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM159.3 388.7C171.5 349.4 209.9 320 256 320C302.1 320 340.5 349.4 352.7 388.7C355.3 397.2 364.3 401.9 372.7 399.3C381.2 396.7 385.9 387.7 383.3 379.3C366.8 326.1 315.8 287.1 256 287.1C196.3 287.1 145.2 326.1 128.7 379.3C126.1 387.7 130.8 396.7 139.3 399.3C147.7 401.9 156.7 397.2 159.3 388.7H159.3zM176.4 176C158.7 176 144.4 190.3 144.4 208C144.4 225.7 158.7 240 176.4 240C194 240 208.4 225.7 208.4 208C208.4 190.3 194 176 176.4 176zM336.4 240C354 240 368.4 225.7 368.4 208C368.4 190.3 354 176 336.4 176C318.7 176 304.4 190.3 304.4 208C304.4 225.7 318.7 240 336.4 240z\"\n ]\n};\nvar faFrown = faFaceFrown;\nvar faFaceFrownOpen = {\n prefix: 'fas',\n iconName: 'face-frown-open',\n icon: [\n 512,\n 512,\n [\n 128550,\n \"frown-open\"\n ],\n \"f57a\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM176.4 240C194 240 208.4 225.7 208.4 208C208.4 190.3 194 176 176.4 176C158.7 176 144.4 190.3 144.4 208C144.4 225.7 158.7 240 176.4 240zM336.4 176C318.7 176 304.4 190.3 304.4 208C304.4 225.7 318.7 240 336.4 240C354 240 368.4 225.7 368.4 208C368.4 190.3 354 176 336.4 176zM259.9 369.4C288.8 369.4 316.2 375.2 340.6 385.5C352.9 390.7 366.7 381.3 361.4 369.1C344.8 330.9 305.6 303.1 259.9 303.1C214.3 303.1 175.1 330.8 158.4 369.1C153.1 381.3 166.1 390.6 179.3 385.4C203.7 375.1 231 369.4 259.9 369.4L259.9 369.4z\"\n ]\n};\nvar faFrownOpen = faFaceFrownOpen;\nvar faFaceGrimace = {\n prefix: 'fas',\n iconName: 'face-grimace',\n icon: [\n 512,\n 512,\n [\n 128556,\n \"grimace\"\n ],\n \"f57f\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM399.3 360H344V400H352C375.8 400 395.5 382.7 399.3 360zM352 304H344V344H399.3C395.5 321.3 375.8 304 352 304zM328 344V304H264V344H328zM328 400V360H264V400H328zM184 304V344H248V304H184zM184 360V400H248V360H184zM168 344V304H160C136.2 304 116.5 321.3 112.7 344H168zM168 400V360H112.7C116.5 382.7 136.2 400 160 400H168zM176.4 176C158.7 176 144.4 190.3 144.4 208C144.4 225.7 158.7 240 176.4 240C194 240 208.4 225.7 208.4 208C208.4 190.3 194 176 176.4 176zM336.4 240C354 240 368.4 225.7 368.4 208C368.4 190.3 354 176 336.4 176C318.7 176 304.4 190.3 304.4 208C304.4 225.7 318.7 240 336.4 240z\"\n ]\n};\nvar faGrimace = faFaceGrimace;\nvar faFaceGrin = {\n prefix: 'fas',\n iconName: 'face-grin',\n icon: [\n 512,\n 512,\n [\n 128512,\n \"grin\"\n ],\n \"f580\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM256.3 331.8C208.9 331.8 164.1 324.9 124.5 312.8C112.2 309 100.2 319.7 105.2 331.5C130.1 390.6 188.4 432 256.3 432C324.2 432 382.4 390.6 407.4 331.5C412.4 319.7 400.4 309 388.1 312.8C348.4 324.9 303.7 331.8 256.3 331.8H256.3zM176.4 176C158.7 176 144.4 190.3 144.4 208C144.4 225.7 158.7 240 176.4 240C194 240 208.4 225.7 208.4 208C208.4 190.3 194 176 176.4 176zM336.4 240C354 240 368.4 225.7 368.4 208C368.4 190.3 354 176 336.4 176C318.7 176 304.4 190.3 304.4 208C304.4 225.7 318.7 240 336.4 240z\"\n ]\n};\nvar faGrin = faFaceGrin;\nvar faFaceGrinBeam = {\n prefix: 'fas',\n iconName: 'face-grin-beam',\n icon: [\n 512,\n 512,\n [\n 128516,\n \"grin-beam\"\n ],\n \"f582\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM256.3 331.8C208.9 331.8 164.1 324.9 124.5 312.8C112.2 309 100.2 319.7 105.2 331.5C130.1 390.6 188.4 432 256.3 432C324.2 432 382.4 390.6 407.4 331.5C412.4 319.7 400.4 309 388.1 312.8C348.4 324.9 303.7 331.8 256.3 331.8H256.3zM226.5 231.6C229.8 230.5 232 227.4 232 224C232 206.1 225.3 188.4 215.4 175.2C205.6 162.2 191.5 152 176 152C160.5 152 146.4 162.2 136.6 175.2C126.7 188.4 120 206.1 120 224C120 227.4 122.2 230.5 125.5 231.6C128.7 232.7 132.3 231.6 134.4 228.8L134.4 228.8L134.6 228.5C134.8 228.3 134.1 228 135.3 227.6C135.1 226.8 136.9 225.7 138.1 224.3C140.6 221.4 144.1 217.7 148.3 213.1C157.1 206.2 167.2 200 176 200C184.8 200 194.9 206.2 203.7 213.1C207.9 217.7 211.4 221.4 213.9 224.3C215.1 225.7 216 226.8 216.7 227.6C217 228 217.2 228.3 217.4 228.5L217.6 228.8L217.6 228.8C219.7 231.6 223.3 232.7 226.5 231.6V231.6zM377.6 228.8C379.7 231.6 383.3 232.7 386.5 231.6C389.8 230.5 392 227.4 392 224C392 206.1 385.3 188.4 375.4 175.2C365.6 162.2 351.5 152 336 152C320.5 152 306.4 162.2 296.6 175.2C286.7 188.4 280 206.1 280 224C280 227.4 282.2 230.5 285.5 231.6C288.7 232.7 292.3 231.6 294.4 228.8L294.4 228.8L294.6 228.5C294.8 228.3 294.1 228 295.3 227.6C295.1 226.8 296.9 225.7 298.1 224.3C300.6 221.4 304.1 217.7 308.3 213.1C317.1 206.2 327.2 200 336 200C344.8 200 354.9 206.2 363.7 213.1C367.9 217.7 371.4 221.4 373.9 224.3C375.1 225.7 376 226.8 376.7 227.6C377 228 377.2 228.3 377.4 228.5L377.6 228.8L377.6 228.8z\"\n ]\n};\nvar faGrinBeam = faFaceGrinBeam;\nvar faFaceGrinBeamSweat = {\n prefix: 'fas',\n iconName: 'face-grin-beam-sweat',\n icon: [\n 512,\n 512,\n [\n 128517,\n \"grin-beam-sweat\"\n ],\n \"f583\",\n \"M464 128C437.5 128 416 107 416 81.01C416 76.01 417.8 69.74 420.6 62.87C420.9 62.17 421.2 61.46 421.6 60.74C430.5 40.51 448.1 15.86 457.6 3.282C460.8-1.093 467.2-1.094 470.4 3.281C483.4 20.65 512 61.02 512 81.01C512 102.7 497.1 120.8 476.8 126.3C472.7 127.4 468.4 128 464 128L464 128zM256 .0003C307.4 .0003 355.3 15.15 395.4 41.23C393.9 44.32 392.4 47.43 391.1 50.53C387.8 58.57 384 69.57 384 81.01C384 125.4 420.6 160 464 160C473.6 160 482.8 158.3 491.4 155.2C504.7 186.1 512 220.2 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0V.0003zM256.3 331.8C208.9 331.8 164.1 324.9 124.5 312.8C112.2 309 100.2 319.7 105.2 331.5C130.1 390.6 188.4 432 256.3 432C324.2 432 382.4 390.6 407.4 331.5C412.4 319.7 400.4 309 388.1 312.8C348.4 324.9 303.7 331.8 256.3 331.8H256.3zM226.5 231.6C229.8 230.5 232 227.4 232 224C232 206.1 225.3 188.4 215.4 175.2C205.6 162.2 191.5 152 176 152C160.5 152 146.4 162.2 136.6 175.2C126.7 188.4 120 206.1 120 224C120 227.4 122.2 230.5 125.5 231.6C128.7 232.7 132.3 231.6 134.4 228.8L134.4 228.8L134.6 228.5C134.8 228.3 134.1 228 135.3 227.6C135.1 226.8 136.9 225.7 138.1 224.3C140.6 221.4 144.1 217.7 148.3 213.1C157.1 206.2 167.2 200 176 200C184.8 200 194.9 206.2 203.7 213.1C207.9 217.7 211.4 221.4 213.9 224.3C215.1 225.7 216 226.8 216.7 227.6C217 228 217.2 228.3 217.4 228.5L217.6 228.8L217.6 228.8C219.7 231.6 223.3 232.7 226.5 231.6V231.6zM377.6 228.8C379.7 231.6 383.3 232.7 386.5 231.6C389.8 230.5 392 227.4 392 224C392 206.1 385.3 188.4 375.4 175.2C365.6 162.2 351.5 152 336 152C320.5 152 306.4 162.2 296.6 175.2C286.7 188.4 280 206.1 280 224C280 227.4 282.2 230.5 285.5 231.6C288.7 232.7 292.3 231.6 294.4 228.8L294.4 228.8L294.6 228.5C294.8 228.3 294.1 228 295.3 227.6C295.1 226.8 296.9 225.7 298.1 224.3C300.6 221.4 304.1 217.7 308.3 213.1C317.1 206.2 327.2 200 336 200C344.8 200 354.9 206.2 363.7 213.1C367.9 217.7 371.4 221.4 373.9 224.3C375.1 225.7 376 226.8 376.7 227.6C377 228 377.2 228.3 377.4 228.5L377.6 228.8L377.6 228.8z\"\n ]\n};\nvar faGrinBeamSweat = faFaceGrinBeamSweat;\nvar faFaceGrinHearts = {\n prefix: 'fas',\n iconName: 'face-grin-hearts',\n icon: [\n 512,\n 512,\n [\n 128525,\n \"grin-hearts\"\n ],\n \"f584\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM256.3 331.8C208.9 331.8 164.1 324.9 124.5 312.8C112.2 309 100.2 319.7 105.2 331.5C130.1 390.6 188.4 432 256.3 432C324.2 432 382.4 390.6 407.4 331.5C412.4 319.7 400.4 309 388.1 312.8C348.4 324.9 303.7 331.8 256.3 331.8H256.3zM199.3 129.1C181.5 124.4 163.2 134.9 158.4 152.7L154.1 168.8L137.1 164.5C120.2 159.7 101.9 170.3 97.14 188.1C92.38 205.8 102.9 224.1 120.7 228.9L185.8 246.3C194.4 248.6 203.1 243.6 205.4 235L222.9 169.1C227.6 152.2 217.1 133.9 199.3 129.1H199.3zM353.6 152.7C348.8 134.9 330.5 124.4 312.7 129.1C294.9 133.9 284.4 152.2 289.1 169.1L306.6 235C308.9 243.6 317.6 248.6 326.2 246.3L391.3 228.9C409.1 224.1 419.6 205.8 414.9 188.1C410.1 170.3 391.8 159.7 374 164.5L357.9 168.8L353.6 152.7z\"\n ]\n};\nvar faGrinHearts = faFaceGrinHearts;\nvar faFaceGrinSquint = {\n prefix: 'fas',\n iconName: 'face-grin-squint',\n icon: [\n 512,\n 512,\n [\n 128518,\n \"grin-squint\"\n ],\n \"f585\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM256.3 331.8C208.9 331.8 164.1 324.9 124.5 312.8C112.2 309 100.2 319.7 105.2 331.5C130.1 390.6 188.4 432 256.3 432C324.2 432 382.4 390.6 407.4 331.5C412.4 319.7 400.4 309 388.1 312.8C348.4 324.9 303.7 331.8 256.3 331.8H256.3zM133.5 146.7C125.6 142.4 116 148.2 116 157.1C116 159.9 116.1 162.6 118.8 164.8L154.8 208L118.8 251.2C116.1 253.4 116 256.1 116 258.9C116 267.8 125.6 273.6 133.5 269.3L223.4 221.4C234.1 215.7 234.1 200.3 223.4 194.6L133.5 146.7zM396 157.1C396 148.2 386.4 142.4 378.5 146.7L288.6 194.6C277.9 200.3 277.9 215.7 288.6 221.4L378.5 269.3C386.4 273.6 396 267.8 396 258.9C396 256.1 395 253.4 393.2 251.2L357.2 208L393.2 164.8C395 162.6 396 159.9 396 157.1V157.1z\"\n ]\n};\nvar faGrinSquint = faFaceGrinSquint;\nvar faFaceGrinSquintTears = {\n prefix: 'fas',\n iconName: 'face-grin-squint-tears',\n icon: [\n 512,\n 512,\n [\n 129315,\n \"grin-squint-tears\"\n ],\n \"f586\",\n \"M426.8 14.18C446-5.046 477.5-4.645 497.1 14.92C516.6 34.49 517 65.95 497.8 85.18C490.1 92.02 476.4 97.59 460.5 101.9C444.1 106.3 426.4 109.4 414.1 111.2C412.5 111.5 410.1 111.7 409.6 111.9C403.1 112.8 399.2 108 400.1 102.4C401.7 91.19 404.7 72.82 409.1 55.42C409.4 54.12 409.8 52.84 410.1 51.56C414.4 35.62 419.1 21.02 426.8 14.18L426.8 14.18zM382.2 33.17C380.6 37.96 379.3 42.81 378.1 47.52C373.3 66.46 370.1 86.05 368.4 97.79C364.5 124.6 387.4 147.5 414.1 143.6C426 141.9 445.6 138.8 464.5 133.9C469.2 132.7 474.1 131.4 478.8 129.9C534.2 227.5 520.2 353.8 437 437C353.8 520.3 227.5 534.2 129.8 478.8C131.3 474 132.7 469.2 133.9 464.5C138.7 445.5 141.9 425.1 143.6 414.2C147.5 387.4 124.6 364.5 97.89 368.4C85.97 370.1 66.39 373.2 47.46 378.1C42.76 379.3 37.93 380.6 33.15 382.1C-22.19 284.5-8.245 158.2 74.98 74.98C158.2-8.253 284.5-22.19 382.2 33.17V33.17zM416.4 202.3C411.6 190.4 395.6 191.4 389.6 202.7C370.1 239.4 343.3 275.9 309.8 309.4C276.3 342.9 239.8 369.7 203.1 389.2C191.8 395.2 190.8 411.2 202.7 416C262.1 440.2 332.6 428.3 380.7 380.3C428.7 332.2 440.6 261.7 416.4 202.3H416.4zM94.43 288.5L150.5 293.6L155.6 349.7C155.8 352.5 157.1 355 159 357C165.4 363.4 176.2 360.7 178.8 352.1L208.5 254.6C211.1 242.1 201.1 232.1 189.5 235.7L92.05 265.3C83.46 267.9 80.76 278.7 87.1 285.1C89.07 287.1 91.66 288.3 94.43 288.5V288.5zM235.7 189.5C232.1 201.1 242.1 211.1 254.6 208.5L352.1 178.8C360.7 176.2 363.4 165.4 357 159C355 157.1 352.5 155.8 349.7 155.6L293.6 150.5L288.5 94.43C288.3 91.66 287.1 89.07 285.1 87.1C278.7 80.76 267.9 83.46 265.3 92.05L235.7 189.5zM51.53 410.1C70.01 405.1 90.3 401.8 102.4 400.1C108 399.2 112.8 403.1 111.9 409.6C110.2 421.7 106.9 441.9 101.9 460.4C97.57 476.4 92.02 490.1 85.18 497.8C65.95 517 34.49 516.6 14.92 497.1C-4.645 477.5-5.046 446 14.18 426.8C21.02 419.1 35.6 414.4 51.53 410.1V410.1z\"\n ]\n};\nvar faGrinSquintTears = faFaceGrinSquintTears;\nvar faFaceGrinStars = {\n prefix: 'fas',\n iconName: 'face-grin-stars',\n icon: [\n 512,\n 512,\n [\n 129321,\n \"grin-stars\"\n ],\n \"f587\",\n \"M512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM407.4 331.5C412.4 319.7 400.4 309 388.1 312.8C348.4 324.9 303.7 331.8 256.3 331.8C208.9 331.8 164.1 324.9 124.5 312.8C112.2 309 100.2 319.7 105.2 331.5C130.1 390.6 188.4 432 256.3 432C324.2 432 382.4 390.6 407.4 331.5H407.4zM152.8 124.6L136.2 159.3L98.09 164.3C95.03 164.7 92.48 166.8 91.52 169.8C90.57 172.7 91.39 175.9 93.62 178L121.5 204.5L114.5 242.3C113.1 245.4 115.2 248.4 117.7 250.2C120.2 252.1 123.5 252.3 126.2 250.8L159.1 232.5L193.8 250.8C196.5 252.3 199.8 252.1 202.3 250.2C204.8 248.4 206 245.4 205.5 242.3L198.5 204.5L226.4 178C228.6 175.9 229.4 172.7 228.5 169.8C227.5 166.8 224.1 164.7 221.9 164.3L183.8 159.3L167.2 124.6C165.9 121.8 163.1 120 159.1 120C156.9 120 154.1 121.8 152.8 124.6V124.6zM344.8 124.6L328.2 159.3L290.1 164.3C287 164.7 284.5 166.8 283.5 169.8C282.6 172.7 283.4 175.9 285.6 178L313.5 204.5L306.5 242.3C305.1 245.4 307.2 248.4 309.7 250.2C312.2 252.1 315.5 252.3 318.2 250.8L352 232.5L385.8 250.8C388.5 252.3 391.8 252.1 394.3 250.2C396.8 248.4 398 245.4 397.5 242.3L390.5 204.5L418.4 178C420.6 175.9 421.4 172.7 420.5 169.8C419.5 166.8 416.1 164.7 413.9 164.3L375.8 159.3L359.2 124.6C357.9 121.8 355.1 120 352 120C348.9 120 346.1 121.8 344.8 124.6H344.8z\"\n ]\n};\nvar faGrinStars = faFaceGrinStars;\nvar faFaceGrinTears = {\n prefix: 'fas',\n iconName: 'face-grin-tears',\n icon: [\n 640,\n 512,\n [\n 128514,\n \"grin-tears\"\n ],\n \"f588\",\n \"M548.6 371.4C506.4 454.8 419.9 512 319.1 512C220.1 512 133.6 454.8 91.4 371.4C95.87 368.4 100.1 365 104.1 361.1C112.2 352.1 117.3 342.5 120.6 334.4C124.2 325.7 127.1 316 129.4 306.9C134 288.7 137 269.1 138.6 258.7C142.6 232.2 119.9 209.5 93.4 213.3C86.59 214.3 77.18 215.7 66.84 217.7C85.31 94.5 191.6 0 319.1 0C448.4 0 554.7 94.5 573.2 217.7C562.8 215.7 553.4 214.3 546.6 213.3C520.1 209.5 497.4 232.2 501.4 258.7C502.1 269.1 505.1 288.7 510.6 306.9C512.9 316 515.8 325.7 519.4 334.4C522.7 342.5 527.8 352.1 535.9 361.1C539.9 365 544.1 368.4 548.6 371.4V371.4zM471.4 331.5C476.4 319.7 464.4 309 452.1 312.8C412.4 324.9 367.7 331.8 320.3 331.8C272.9 331.8 228.1 324.9 188.5 312.8C176.2 309 164.2 319.7 169.2 331.5C194.1 390.6 252.4 432 320.3 432C388.2 432 446.4 390.6 471.4 331.5H471.4zM281.6 228.8C283.7 231.6 287.3 232.7 290.5 231.6C293.8 230.5 295.1 227.4 295.1 224C295.1 206.1 289.3 188.4 279.4 175.2C269.6 162.2 255.5 152 239.1 152C224.5 152 210.4 162.2 200.6 175.2C190.7 188.4 183.1 206.1 183.1 224C183.1 227.4 186.2 230.5 189.5 231.6C192.7 232.7 196.3 231.6 198.4 228.8L198.4 228.8L198.6 228.5C198.8 228.3 198.1 228 199.3 227.6C199.1 226.8 200.9 225.7 202.1 224.3C204.6 221.4 208.1 217.7 212.3 213.1C221.1 206.2 231.2 200 239.1 200C248.8 200 258.9 206.2 267.7 213.1C271.9 217.7 275.4 221.4 277.9 224.3C279.1 225.7 280 226.8 280.7 227.6C281 228 281.2 228.3 281.4 228.5L281.6 228.8L281.6 228.8zM450.5 231.6C453.8 230.5 456 227.4 456 224C456 206.1 449.3 188.4 439.4 175.2C429.6 162.2 415.5 152 400 152C384.5 152 370.4 162.2 360.6 175.2C350.7 188.4 344 206.1 344 224C344 227.4 346.2 230.5 349.5 231.6C352.7 232.7 356.3 231.6 358.4 228.8L358.4 228.8L358.6 228.5C358.8 228.3 358.1 228 359.3 227.6C359.1 226.8 360.9 225.7 362.1 224.3C364.6 221.4 368.1 217.7 372.3 213.1C381.1 206.2 391.2 200 400 200C408.8 200 418.9 206.2 427.7 213.1C431.9 217.7 435.4 221.4 437.9 224.3C439.1 225.7 440 226.8 440.7 227.6C441 228 441.2 228.3 441.4 228.5L441.6 228.8L441.6 228.8C443.7 231.6 447.3 232.7 450.5 231.6V231.6zM106.1 254.1C103.9 275.6 95.58 324.3 81.43 338.4C80.49 339.4 79.51 340.3 78.5 341.1C59.98 356.7 32.01 355.5 14.27 337.7C-4.442 319-4.825 288.9 13.55 270.6C22.19 261.9 43.69 255.4 64.05 250.1C77.02 248.2 89.53 246.2 97.94 245C103.3 244.2 107.8 248.7 106.1 254.1V254.1zM561.5 341.1C560.7 340.5 559.1 339.8 559.2 339.1C559 338.9 558.8 338.7 558.6 338.4C544.4 324.3 536.1 275.6 533 254.1C532.2 248.7 536.7 244.2 542.1 245C543.1 245.2 544.2 245.3 545.4 245.5C553.6 246.7 564.6 248.5 575.1 250.1C596.3 255.4 617.8 261.9 626.4 270.6C644.8 288.9 644.4 319 625.7 337.7C607.1 355.5 580 356.7 561.5 341.1L561.5 341.1z\"\n ]\n};\nvar faGrinTears = faFaceGrinTears;\nvar faFaceGrinTongue = {\n prefix: 'fas',\n iconName: 'face-grin-tongue',\n icon: [\n 512,\n 512,\n [\n 128539,\n \"grin-tongue\"\n ],\n \"f589\",\n \"M256 0C397.4 0 512 114.6 512 256C512 368.9 438.9 464.7 337.5 498.8C346.7 484 352 466.6 352 448V401.1C376.3 383.5 395.6 359.5 407.4 331.5C412.4 319.7 400.4 309 388.1 312.8C348.4 324.9 303.7 331.8 256.3 331.8C208.9 331.8 164.1 324.9 124.5 312.8C112.2 309 100.2 319.7 105.2 331.5C116.9 359.3 135.1 383.1 160 400.7V448C160 466.6 165.3 484 174.5 498.8C73.07 464.7 0 368.9 0 256C0 114.6 114.6 .0003 256 .0003L256 0zM176.4 240C194 240 208.4 225.7 208.4 208C208.4 190.3 194 176 176.4 176C158.7 176 144.4 190.3 144.4 208C144.4 225.7 158.7 240 176.4 240zM336.4 176C318.7 176 304.4 190.3 304.4 208C304.4 225.7 318.7 240 336.4 240C354 240 368.4 225.7 368.4 208C368.4 190.3 354 176 336.4 176zM256 512C220.7 512 192 483.3 192 448V402.6C192 387.9 203.9 376 218.6 376H220.6C231.9 376 241.7 383.9 244.2 394.9C247 407.5 264.1 407.5 267.8 394.9C270.3 383.9 280.1 376 291.4 376H293.4C308.1 376 320 387.9 320 402.6V448C320 483.3 291.3 512 256 512V512z\"\n ]\n};\nvar faGrinTongue = faFaceGrinTongue;\nvar faFaceGrinTongueSquint = {\n prefix: 'fas',\n iconName: 'face-grin-tongue-squint',\n icon: [\n 512,\n 512,\n [\n 128541,\n \"grin-tongue-squint\"\n ],\n \"f58a\",\n \"M256 0C397.4 0 512 114.6 512 256C512 368.9 438.9 464.7 337.5 498.8C346.7 484 352 466.6 352 448V401.1C376.3 383.5 395.6 359.5 407.4 331.5C412.4 319.7 400.4 309 388.1 312.8C348.4 324.9 303.7 331.8 256.3 331.8C208.9 331.8 164.1 324.9 124.5 312.8C112.2 309 100.2 319.7 105.2 331.5C116.9 359.3 135.1 383.1 160 400.7V448C160 466.6 165.3 484 174.5 498.8C73.07 464.7 0 368.9 0 256C0 114.6 114.6 .0003 256 .0003L256 0zM118.8 148.8L154.8 192L118.8 235.2C116.1 237.4 116 240.1 116 242.9C116 251.8 125.6 257.6 133.5 253.3L223.4 205.4C234.1 199.7 234.1 184.3 223.4 178.6L133.5 130.7C125.6 126.4 116 132.2 116 141.1C116 143.9 116.1 146.6 118.8 148.8V148.8zM288.6 178.6C277.9 184.3 277.9 199.7 288.6 205.4L378.5 253.3C386.4 257.6 396 251.8 396 242.9C396 240.1 395 237.4 393.2 235.2L357.2 192L393.2 148.8C395 146.6 396 143.9 396 141.1C396 132.2 386.4 126.4 378.5 130.7L288.6 178.6zM256 512C220.7 512 192 483.3 192 448V402.6C192 387.9 203.9 376 218.6 376H220.6C231.9 376 241.7 383.9 244.2 394.9C247 407.5 264.1 407.5 267.8 394.9C270.3 383.9 280.1 376 291.4 376H293.4C308.1 376 320 387.9 320 402.6V448C320 483.3 291.3 512 256 512V512z\"\n ]\n};\nvar faGrinTongueSquint = faFaceGrinTongueSquint;\nvar faFaceGrinTongueWink = {\n prefix: 'fas',\n iconName: 'face-grin-tongue-wink',\n icon: [\n 512,\n 512,\n [\n 128540,\n \"grin-tongue-wink\"\n ],\n \"f58b\",\n \"M312 208C312 194.7 322.7 184 336 184C349.3 184 360 194.7 360 208C360 221.3 349.3 232 336 232C322.7 232 312 221.3 312 208zM174.5 498.8C73.07 464.7 0 368.9 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 368.9 438.9 464.7 337.5 498.8C346.7 484 352 466.6 352 448V401.1C376.3 383.5 395.6 359.5 407.4 331.5C412.4 319.7 400.4 309 388.1 312.8C348.4 324.9 303.7 331.8 256.3 331.8C208.9 331.8 164.1 324.9 124.5 312.8C112.2 309 100.2 319.7 105.2 331.5C116.9 359.3 135.1 383.1 159.1 400.7V448C159.1 466.6 165.3 484 174.5 498.8L174.5 498.8zM217.6 236.8C224.7 231.5 226.1 221.5 220.8 214.4C190.4 173.9 129.6 173.9 99.2 214.4C93.9 221.5 95.33 231.5 102.4 236.8C109.5 242.1 119.5 240.7 124.8 233.6C142.4 210.1 177.6 210.1 195.2 233.6C200.5 240.7 210.5 242.1 217.6 236.8zM336 272C371.3 272 400 243.3 400 208C400 172.7 371.3 144 336 144C300.7 144 272 172.7 272 208C272 243.3 300.7 272 336 272zM320 402.6V448C320 483.3 291.3 512 256 512C220.7 512 192 483.3 192 448V402.6C192 387.9 203.9 376 218.6 376H220.6C231.9 376 241.7 383.9 244.2 394.9C247 407.5 264.1 407.5 267.8 394.9C270.3 383.9 280.1 376 291.4 376H293.4C308.1 376 320 387.9 320 402.6V402.6z\"\n ]\n};\nvar faGrinTongueWink = faFaceGrinTongueWink;\nvar faFaceGrinWide = {\n prefix: 'fas',\n iconName: 'face-grin-wide',\n icon: [\n 512,\n 512,\n [\n 128515,\n \"grin-alt\"\n ],\n \"f581\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM256.3 331.8C208.9 331.8 164.1 324.9 124.5 312.8C112.2 309 100.2 319.7 105.2 331.5C130.1 390.6 188.4 432 256.3 432C324.2 432 382.4 390.6 407.4 331.5C412.4 319.7 400.4 309 388.1 312.8C348.4 324.9 303.7 331.8 256.3 331.8H256.3zM176 128C158.3 128 144 156.7 144 192C144 227.3 158.3 256 176 256C193.7 256 208 227.3 208 192C208 156.7 193.7 128 176 128zM336 256C353.7 256 368 227.3 368 192C368 156.7 353.7 128 336 128C318.3 128 304 156.7 304 192C304 227.3 318.3 256 336 256z\"\n ]\n};\nvar faGrinAlt = faFaceGrinWide;\nvar faFaceGrinWink = {\n prefix: 'fas',\n iconName: 'face-grin-wink',\n icon: [\n 512,\n 512,\n [\n \"grin-wink\"\n ],\n \"f58c\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM256.3 331.8C208.9 331.8 164.1 324.9 124.5 312.8C112.2 309 100.2 319.7 105.2 331.5C130.1 390.6 188.4 432 256.3 432C324.2 432 382.4 390.6 407.4 331.5C412.4 319.7 400.4 309 388.1 312.8C348.4 324.9 303.7 331.8 256.3 331.8H256.3zM393.6 236.8C400.7 231.5 402.1 221.5 396.8 214.4C366.4 173.9 305.6 173.9 275.2 214.4C269.9 221.5 271.3 231.5 278.4 236.8C285.5 242.1 295.5 240.7 300.8 233.6C318.4 210.1 353.6 210.1 371.2 233.6C376.5 240.7 386.5 242.1 393.6 236.8zM176.4 240C194 240 208.4 225.7 208.4 208C208.4 190.3 194 176 176.4 176C158.7 176 144.4 190.3 144.4 208C144.4 225.7 158.7 240 176.4 240z\"\n ]\n};\nvar faGrinWink = faFaceGrinWink;\nvar faFaceKiss = {\n prefix: 'fas',\n iconName: 'face-kiss',\n icon: [\n 512,\n 512,\n [\n 128535,\n \"kiss\"\n ],\n \"f596\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM287.9 300.3C274.7 292.9 257.4 288 240 288C236.4 288 233.2 290.5 232.3 293.1C231.3 297.5 232.9 301.2 236.1 302.1L236.1 302.1L236.3 303.1L236.8 303.4L237.2 303.7C238 304.1 239.2 304.9 240.6 305.8C243.4 307.6 247.2 310.3 250.8 313.4C254.6 316.5 258 319.1 260.5 323.4C262.1 326.1 264 329.8 264 332C264 334.2 262.1 337 260.5 340.6C258 344 254.6 347.5 250.8 350.6C247.2 353.7 243.4 356.4 240.6 358.2C239.2 359.1 238 359.9 237.2 360.3L236.6 360.7L236.3 360.9L236.1 361L236.1 361C233.6 362.4 232 365.1 232 368C232 370.9 233.6 373.6 236.1 374.1L236.1 374.1L236.3 375.1C236.5 375.2 236.8 375.4 237.2 375.7C238 376.1 239.2 376.9 240.6 377.8C243.4 379.6 247.2 382.3 250.8 385.4C254.6 388.5 258 391.9 260.5 395.4C262.1 398.1 264 401.8 264 403.1C264 406.2 262.1 409 260.5 412.6C258 416 254.6 419.5 250.8 422.6C247.2 425.7 243.4 428.4 240.6 430.2C239.2 431.1 238 431.9 237.2 432.3C236.8 432.6 236.5 432.8 236.3 432.9L236.1 432.1L236.1 433C232.9 434.8 231.3 438.5 232.3 442C233.2 445.5 236.4 447.1 240 447.1C257.4 447.1 274.7 443.1 287.9 435.7C294.5 432 300.4 427.5 304.7 422.3C308.9 417.2 312 410.9 312 403.1C312 397.1 308.9 390.8 304.7 385.7C300.4 380.5 294.5 375.1 287.9 372.3C285.2 370.7 282.3 369.3 279.2 367.1C282.3 366.7 285.2 365.3 287.9 363.7C294.5 360 300.4 355.5 304.7 350.3C308.9 345.2 312 338.9 312 331.1C312 325.1 308.9 318.8 304.7 313.7C300.4 308.5 294.5 303.1 287.9 300.3L287.9 300.3zM176.4 176C158.7 176 144.4 190.3 144.4 208C144.4 225.7 158.7 240 176.4 240C194 240 208.4 225.7 208.4 208C208.4 190.3 194 176 176.4 176zM336.4 240C354 240 368.4 225.7 368.4 208C368.4 190.3 354 176 336.4 176C318.7 176 304.4 190.3 304.4 208C304.4 225.7 318.7 240 336.4 240z\"\n ]\n};\nvar faKiss = faFaceKiss;\nvar faFaceKissBeam = {\n prefix: 'fas',\n iconName: 'face-kiss-beam',\n icon: [\n 512,\n 512,\n [\n 128537,\n \"kiss-beam\"\n ],\n \"f597\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM287.9 300.3C274.7 292.9 257.4 288 240 288C236.4 288 233.2 290.5 232.3 293.1C231.3 297.5 232.9 301.2 236.1 302.1L236.1 302.1L236.3 303.1L236.8 303.4L237.2 303.7C238 304.1 239.2 304.9 240.6 305.8C243.4 307.6 247.2 310.3 250.8 313.4C254.6 316.5 258 319.1 260.5 323.4C262.1 326.1 264 329.8 264 332C264 334.2 262.1 337 260.5 340.6C258 344 254.6 347.5 250.8 350.6C247.2 353.7 243.4 356.4 240.6 358.2C239.2 359.1 238 359.9 237.2 360.3L236.6 360.7L236.3 360.9L236.1 361L236.1 361C233.6 362.4 232 365.1 232 368C232 370.9 233.6 373.6 236.1 374.1L236.1 374.1L236.3 375.1C236.5 375.2 236.8 375.4 237.2 375.7C238 376.1 239.2 376.9 240.6 377.8C243.4 379.6 247.2 382.3 250.8 385.4C254.6 388.5 258 391.9 260.5 395.4C262.1 398.1 264 401.8 264 403.1C264 406.2 262.1 409 260.5 412.6C258 416 254.6 419.5 250.8 422.6C247.2 425.7 243.4 428.4 240.6 430.2C239.2 431.1 238 431.9 237.2 432.3C236.8 432.6 236.5 432.8 236.3 432.9L236.1 432.1L236.1 433C232.9 434.8 231.3 438.5 232.3 442C233.2 445.5 236.4 447.1 240 447.1C257.4 447.1 274.7 443.1 287.9 435.7C294.5 432 300.4 427.5 304.7 422.3C308.9 417.2 312 410.9 312 403.1C312 397.1 308.9 390.8 304.7 385.7C300.4 380.5 294.5 375.1 287.9 372.3C285.2 370.7 282.3 369.3 279.2 367.1C282.3 366.7 285.2 365.3 287.9 363.7C294.5 360 300.4 355.5 304.7 350.3C308.9 345.2 312 338.9 312 331.1C312 325.1 308.9 318.8 304.7 313.7C300.4 308.5 294.5 303.1 287.9 300.3L287.9 300.3zM226.5 231.6C229.8 230.5 232 227.4 232 224C232 206.1 225.3 188.4 215.4 175.2C205.6 162.2 191.5 152 176 152C160.5 152 146.4 162.2 136.6 175.2C126.7 188.4 120 206.1 120 224C120 227.4 122.2 230.5 125.5 231.6C128.7 232.7 132.3 231.6 134.4 228.8L134.4 228.8L134.6 228.5C134.8 228.3 134.1 228 135.3 227.6C135.1 226.8 136.9 225.7 138.1 224.3C140.6 221.4 144.1 217.7 148.3 213.1C157.1 206.2 167.2 200 176 200C184.8 200 194.9 206.2 203.7 213.1C207.9 217.7 211.4 221.4 213.9 224.3C215.1 225.7 216 226.8 216.7 227.6C217 228 217.2 228.3 217.4 228.5L217.6 228.8L217.6 228.8C219.7 231.6 223.3 232.7 226.5 231.6V231.6zM377.6 228.8C379.7 231.6 383.3 232.7 386.5 231.6C389.8 230.5 392 227.4 392 224C392 206.1 385.3 188.4 375.4 175.2C365.6 162.2 351.5 152 336 152C320.5 152 306.4 162.2 296.6 175.2C286.7 188.4 280 206.1 280 224C280 227.4 282.2 230.5 285.5 231.6C288.7 232.7 292.3 231.6 294.4 228.8L294.4 228.8L294.6 228.5C294.8 228.3 294.1 228 295.3 227.6C295.1 226.8 296.9 225.7 298.1 224.3C300.6 221.4 304.1 217.7 308.3 213.1C317.1 206.2 327.2 200 336 200C344.8 200 354.9 206.2 363.7 213.1C367.9 217.7 371.4 221.4 373.9 224.3C375.1 225.7 376 226.8 376.7 227.6C377 228 377.2 228.3 377.4 228.5L377.6 228.8L377.6 228.8z\"\n ]\n};\nvar faKissBeam = faFaceKissBeam;\nvar faFaceKissWinkHeart = {\n prefix: 'fas',\n iconName: 'face-kiss-wink-heart',\n icon: [\n 512,\n 512,\n [\n 128536,\n \"kiss-wink-heart\"\n ],\n \"f598\",\n \"M461.8 334.6C448.1 300.8 411.5 280.3 374.3 290.7C334.2 301.9 312.4 343.8 322.4 382.8L345.3 472.1C347.3 479.7 350.9 486.4 355.7 491.8C325.1 504.8 291.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 285.3 507.1 313.4 498 339.7C486.9 334.1 474.5 333.1 461.8 334.6L461.8 334.6zM296 332C296 325.1 292.9 318.8 288.7 313.7C284.4 308.5 278.5 303.1 271.9 300.3C258.7 292.9 241.4 288 224 288C220.4 288 217.2 290.5 216.3 293.1C215.3 297.5 216.9 301.2 220.1 302.1L220.1 302.1L220.3 303.1C220.5 303.2 220.8 303.4 221.2 303.7C222 304.1 223.2 304.9 224.6 305.8C227.4 307.6 231.2 310.3 234.8 313.4C238.6 316.5 242 319.1 244.5 323.4C246.1 326.1 248 329.8 248 332C248 334.2 246.1 337 244.5 340.6C242 344 238.6 347.5 234.8 350.6C231.2 353.7 227.4 356.4 224.6 358.2C223.2 359.1 222 359.9 221.2 360.3C220.8 360.6 220.5 360.8 220.3 360.9L220.1 361L220.1 361C217.6 362.4 216 365.1 216 368C216 370.9 217.6 373.6 220.1 374.1L220.1 374.1L220.3 375.1L220.6 375.3L221.2 375.7C222 376.1 223.2 376.9 224.6 377.8C227.4 379.6 231.2 382.3 234.8 385.4C238.6 388.5 242 391.9 244.5 395.4C246.1 398.1 248 401.8 248 404C248 406.2 246.1 409 244.5 412.6C242 416 238.6 419.5 234.8 422.6C231.2 425.7 227.4 428.4 224.6 430.2C223.2 431.1 222 431.9 221.2 432.3C220.8 432.6 220.5 432.8 220.3 432.9L220.1 433L220.1 433C216.9 434.8 215.3 438.5 216.3 442C217.2 445.5 220.4 447.1 224 447.1C241.4 447.1 258.7 443.1 271.9 435.7C278.5 432 284.4 427.5 288.7 422.3C292.9 417.2 296 410.9 296 403.1C296 397.1 292.9 390.8 288.7 385.7C284.4 380.5 278.5 375.1 271.9 372.3C269.2 370.7 266.3 369.3 263.2 367.1C266.3 366.7 269.2 365.3 271.9 363.7C278.5 360 284.4 355.5 288.7 350.3C292.9 345.2 296 338.9 296 331.1V332zM176.4 240C194 240 208.4 225.7 208.4 208C208.4 190.3 194 176 176.4 176C158.7 176 144.4 190.3 144.4 208C144.4 225.7 158.7 240 176.4 240zM393.6 236.8C400.7 231.5 402.1 221.5 396.8 214.4C366.4 173.9 305.6 173.9 275.2 214.4C269.9 221.5 271.3 231.5 278.4 236.8C285.5 242.1 295.5 240.7 300.8 233.6C318.4 210.1 353.6 210.1 371.2 233.6C376.5 240.7 386.5 242.1 393.6 236.8zM439.4 373.3L459.5 367.6C481.7 361.4 504.6 375.2 510.6 398.4C516.5 421.7 503.3 445.6 481.1 451.8L396.1 475.6C387.5 478 378.6 472.9 376.3 464.2L353.4 374.9C347.5 351.6 360.7 327.7 382.9 321.5C405.2 315.3 428 329.1 433.1 352.3L439.4 373.3z\"\n ]\n};\nvar faKissWinkHeart = faFaceKissWinkHeart;\nvar faFaceLaugh = {\n prefix: 'fas',\n iconName: 'face-laugh',\n icon: [\n 512,\n 512,\n [\n \"laugh\"\n ],\n \"f599\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM256 432C332.1 432 396.2 382 415.2 314.1C419.1 300.4 407.8 288 393.6 288H118.4C104.2 288 92.92 300.4 96.76 314.1C115.8 382 179.9 432 256 432V432zM176.4 160C158.7 160 144.4 174.3 144.4 192C144.4 209.7 158.7 224 176.4 224C194 224 208.4 209.7 208.4 192C208.4 174.3 194 160 176.4 160zM336.4 224C354 224 368.4 209.7 368.4 192C368.4 174.3 354 160 336.4 160C318.7 160 304.4 174.3 304.4 192C304.4 209.7 318.7 224 336.4 224z\"\n ]\n};\nvar faLaugh = faFaceLaugh;\nvar faFaceLaughBeam = {\n prefix: 'fas',\n iconName: 'face-laugh-beam',\n icon: [\n 512,\n 512,\n [\n 128513,\n \"laugh-beam\"\n ],\n \"f59a\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM256 432C332.1 432 396.2 382 415.2 314.1C419.1 300.4 407.8 288 393.6 288H118.4C104.2 288 92.92 300.4 96.76 314.1C115.8 382 179.9 432 256 432V432zM226.5 215.6C229.8 214.5 232 211.4 232 208C232 190.1 225.3 172.4 215.4 159.2C205.6 146.2 191.5 136 176 136C160.5 136 146.4 146.2 136.6 159.2C126.7 172.4 120 190.1 120 208C120 211.4 122.2 214.5 125.5 215.6C128.7 216.7 132.3 215.6 134.4 212.8L134.4 212.8L134.6 212.5C134.8 212.3 134.1 212 135.3 211.6C135.1 210.8 136.9 209.7 138.1 208.3C140.6 205.4 144.1 201.7 148.3 197.1C157.1 190.2 167.2 184 176 184C184.8 184 194.9 190.2 203.7 197.1C207.9 201.7 211.4 205.4 213.9 208.3C215.1 209.7 216 210.8 216.7 211.6C217 212 217.2 212.3 217.4 212.5L217.6 212.8L217.6 212.8C219.7 215.6 223.3 216.7 226.5 215.6V215.6zM377.6 212.8C379.7 215.6 383.3 216.7 386.5 215.6C389.8 214.5 392 211.4 392 208C392 190.1 385.3 172.4 375.4 159.2C365.6 146.2 351.5 136 336 136C320.5 136 306.4 146.2 296.6 159.2C286.7 172.4 280 190.1 280 208C280 211.4 282.2 214.5 285.5 215.6C288.7 216.7 292.3 215.6 294.4 212.8L294.4 212.8L294.6 212.5C294.8 212.3 294.1 212 295.3 211.6C295.1 210.8 296.9 209.7 298.1 208.3C300.6 205.4 304.1 201.7 308.3 197.1C317.1 190.2 327.2 184 336 184C344.8 184 354.9 190.2 363.7 197.1C367.9 201.7 371.4 205.4 373.9 208.3C375.1 209.7 376 210.8 376.7 211.6C377 212 377.2 212.3 377.4 212.5L377.6 212.8L377.6 212.8z\"\n ]\n};\nvar faLaughBeam = faFaceLaughBeam;\nvar faFaceLaughSquint = {\n prefix: 'fas',\n iconName: 'face-laugh-squint',\n icon: [\n 512,\n 512,\n [\n \"laugh-squint\"\n ],\n \"f59b\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM256 432C332.1 432 396.2 382 415.2 314.1C419.1 300.4 407.8 288 393.6 288H118.4C104.2 288 92.92 300.4 96.76 314.1C115.8 382 179.9 432 256 432V432zM133.5 114.7C125.6 110.4 116 116.2 116 125.1C116 127.9 116.1 130.6 118.8 132.8L154.8 176L118.8 219.2C116.1 221.4 116 224.1 116 226.9C116 235.8 125.6 241.6 133.5 237.3L223.4 189.4C234.1 183.7 234.1 168.3 223.4 162.6L133.5 114.7zM396 125.1C396 116.2 386.4 110.4 378.5 114.7L288.6 162.6C277.9 168.3 277.9 183.7 288.6 189.4L378.5 237.3C386.4 241.6 396 235.8 396 226.9C396 224.1 395 221.4 393.2 219.2L357.2 176L393.2 132.8C395 130.6 396 127.9 396 125.1V125.1z\"\n ]\n};\nvar faLaughSquint = faFaceLaughSquint;\nvar faFaceLaughWink = {\n prefix: 'fas',\n iconName: 'face-laugh-wink',\n icon: [\n 512,\n 512,\n [\n \"laugh-wink\"\n ],\n \"f59c\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM256 432C332.1 432 396.2 382 415.2 314.1C419.1 300.4 407.8 288 393.6 288H118.4C104.2 288 92.92 300.4 96.76 314.1C115.8 382 179.9 432 256 432V432zM176.4 160C158.7 160 144.4 174.3 144.4 192C144.4 209.7 158.7 224 176.4 224C194 224 208.4 209.7 208.4 192C208.4 174.3 194 160 176.4 160zM300.8 217.6C318.4 194.1 353.6 194.1 371.2 217.6C376.5 224.7 386.5 226.1 393.6 220.8C400.7 215.5 402.1 205.5 396.8 198.4C366.4 157.9 305.6 157.9 275.2 198.4C269.9 205.5 271.3 215.5 278.4 220.8C285.5 226.1 295.5 224.7 300.8 217.6z\"\n ]\n};\nvar faLaughWink = faFaceLaughWink;\nvar faFaceMeh = {\n prefix: 'fas',\n iconName: 'face-meh',\n icon: [\n 512,\n 512,\n [\n 128528,\n \"meh\"\n ],\n \"f11a\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM176.4 240C194 240 208.4 225.7 208.4 208C208.4 190.3 194 176 176.4 176C158.7 176 144.4 190.3 144.4 208C144.4 225.7 158.7 240 176.4 240zM336.4 176C318.7 176 304.4 190.3 304.4 208C304.4 225.7 318.7 240 336.4 240C354 240 368.4 225.7 368.4 208C368.4 190.3 354 176 336.4 176zM160 336C151.2 336 144 343.2 144 352C144 360.8 151.2 368 160 368H352C360.8 368 368 360.8 368 352C368 343.2 360.8 336 352 336H160z\"\n ]\n};\nvar faMeh = faFaceMeh;\nvar faFaceMehBlank = {\n prefix: 'fas',\n iconName: 'face-meh-blank',\n icon: [\n 512,\n 512,\n [\n 128566,\n \"meh-blank\"\n ],\n \"f5a4\",\n \"M512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM176.4 176C158.7 176 144.4 190.3 144.4 208C144.4 225.7 158.7 240 176.4 240C194 240 208.4 225.7 208.4 208C208.4 190.3 194 176 176.4 176zM336.4 240C354 240 368.4 225.7 368.4 208C368.4 190.3 354 176 336.4 176C318.7 176 304.4 190.3 304.4 208C304.4 225.7 318.7 240 336.4 240z\"\n ]\n};\nvar faMehBlank = faFaceMehBlank;\nvar faFaceRollingEyes = {\n prefix: 'fas',\n iconName: 'face-rolling-eyes',\n icon: [\n 512,\n 512,\n [\n 128580,\n \"meh-rolling-eyes\"\n ],\n \"f5a5\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM192 368C183.2 368 176 375.2 176 384C176 392.8 183.2 400 192 400H320C328.8 400 336 392.8 336 384C336 375.2 328.8 368 320 368H192zM186.2 165.6C189.8 170.8 192 177.1 192 184C192 201.7 177.7 216 160 216C142.3 216 128 201.7 128 184C128 177.1 130.2 170.8 133.8 165.6C111.5 175.6 96 197.1 96 224C96 259.3 124.7 288 160 288C195.3 288 224 259.3 224 224C224 197.1 208.5 175.6 186.2 165.6zM352 288C387.3 288 416 259.3 416 224C416 197.1 400.5 175.6 378.2 165.6C381.8 170.8 384 177.1 384 184C384 201.7 369.7 216 352 216C334.3 216 320 201.7 320 184C320 177.1 322.2 170.8 325.8 165.6C303.5 175.6 288 197.1 288 224C288 259.3 316.7 288 352 288z\"\n ]\n};\nvar faMehRollingEyes = faFaceRollingEyes;\nvar faFaceSadCry = {\n prefix: 'fas',\n iconName: 'face-sad-cry',\n icon: [\n 512,\n 512,\n [\n 128557,\n \"sad-cry\"\n ],\n \"f5b3\",\n \"M352 493.4C322.4 505.4 289.9 512 256 512C222.1 512 189.6 505.4 160 493.4V288C160 279.2 152.8 272 144 272C135.2 272 128 279.2 128 288V477.8C51.48 433.5 0 350.8 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 350.8 460.5 433.5 384 477.8V288C384 279.2 376.8 272 368 272C359.2 272 352 279.2 352 288V493.4zM217.6 236.8C224.7 231.5 226.1 221.5 220.8 214.4C190.4 173.9 129.6 173.9 99.2 214.4C93.9 221.5 95.33 231.5 102.4 236.8C109.5 242.1 119.5 240.7 124.8 233.6C142.4 210.1 177.6 210.1 195.2 233.6C200.5 240.7 210.5 242.1 217.6 236.8zM316.8 233.6C334.4 210.1 369.6 210.1 387.2 233.6C392.5 240.7 402.5 242.1 409.6 236.8C416.7 231.5 418.1 221.5 412.8 214.4C382.4 173.9 321.6 173.9 291.2 214.4C285.9 221.5 287.3 231.5 294.4 236.8C301.5 242.1 311.5 240.7 316.8 233.6zM208 368C208 394.5 229.5 416 256 416C282.5 416 304 394.5 304 368V336C304 309.5 282.5 288 256 288C229.5 288 208 309.5 208 336V368z\"\n ]\n};\nvar faSadCry = faFaceSadCry;\nvar faFaceSadTear = {\n prefix: 'fas',\n iconName: 'face-sad-tear',\n icon: [\n 512,\n 512,\n [\n 128546,\n \"sad-tear\"\n ],\n \"f5b4\",\n \"M256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0zM256 352C290.9 352 323.2 367.8 348.3 394.9C354.3 401.4 364.4 401.7 370.9 395.7C377.4 389.7 377.7 379.6 371.7 373.1C341.6 340.5 301 320 256 320C247.2 320 240 327.2 240 336C240 344.8 247.2 352 256 352H256zM208 369C208 349 179.6 308.6 166.4 291.3C163.2 286.9 156.8 286.9 153.6 291.3C140.6 308.6 112 349 112 369C112 395 133.5 416 160 416C186.5 416 208 395 208 369H208zM303.6 208C303.6 225.7 317.1 240 335.6 240C353.3 240 367.6 225.7 367.6 208C367.6 190.3 353.3 176 335.6 176C317.1 176 303.6 190.3 303.6 208zM207.6 208C207.6 190.3 193.3 176 175.6 176C157.1 176 143.6 190.3 143.6 208C143.6 225.7 157.1 240 175.6 240C193.3 240 207.6 225.7 207.6 208z\"\n ]\n};\nvar faSadTear = faFaceSadTear;\nvar faFaceSmile = {\n prefix: 'fas',\n iconName: 'face-smile',\n icon: [\n 512,\n 512,\n [\n 128578,\n \"smile\"\n ],\n \"f118\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM164.1 325.5C158.3 318.8 148.2 318.1 141.5 323.9C134.8 329.7 134.1 339.8 139.9 346.5C162.1 372.1 200.9 400 255.1 400C311.1 400 349.8 372.1 372.1 346.5C377.9 339.8 377.2 329.7 370.5 323.9C363.8 318.1 353.7 318.8 347.9 325.5C329.9 346.2 299.4 368 255.1 368C212.6 368 182 346.2 164.1 325.5H164.1zM176.4 176C158.7 176 144.4 190.3 144.4 208C144.4 225.7 158.7 240 176.4 240C194 240 208.4 225.7 208.4 208C208.4 190.3 194 176 176.4 176zM336.4 240C354 240 368.4 225.7 368.4 208C368.4 190.3 354 176 336.4 176C318.7 176 304.4 190.3 304.4 208C304.4 225.7 318.7 240 336.4 240z\"\n ]\n};\nvar faSmile = faFaceSmile;\nvar faFaceSmileBeam = {\n prefix: 'fas',\n iconName: 'face-smile-beam',\n icon: [\n 512,\n 512,\n [\n 128522,\n \"smile-beam\"\n ],\n \"f5b8\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM164.1 325.5C158.3 318.8 148.2 318.1 141.5 323.9C134.8 329.7 134.1 339.8 139.9 346.5C162.1 372.1 200.9 400 255.1 400C311.1 400 349.8 372.1 372.1 346.5C377.9 339.8 377.2 329.7 370.5 323.9C363.8 318.1 353.7 318.8 347.9 325.5C329.9 346.2 299.4 368 255.1 368C212.6 368 182 346.2 164.1 325.5H164.1zM226.5 231.6C229.8 230.5 232 227.4 232 224C232 206.1 225.3 188.4 215.4 175.2C205.6 162.2 191.5 152 176 152C160.5 152 146.4 162.2 136.6 175.2C126.7 188.4 120 206.1 120 224C120 227.4 122.2 230.5 125.5 231.6C128.7 232.7 132.3 231.6 134.4 228.8L134.4 228.8L134.6 228.5C134.8 228.3 134.1 228 135.3 227.6C135.1 226.8 136.9 225.7 138.1 224.3C140.6 221.4 144.1 217.7 148.3 213.1C157.1 206.2 167.2 200 176 200C184.8 200 194.9 206.2 203.7 213.1C207.9 217.7 211.4 221.4 213.9 224.3C215.1 225.7 216 226.8 216.7 227.6C217 228 217.2 228.3 217.4 228.5L217.6 228.8L217.6 228.8C219.7 231.6 223.3 232.7 226.5 231.6V231.6zM377.6 228.8C379.7 231.6 383.3 232.7 386.5 231.6C389.8 230.5 392 227.4 392 224C392 206.1 385.3 188.4 375.4 175.2C365.6 162.2 351.5 152 336 152C320.5 152 306.4 162.2 296.6 175.2C286.7 188.4 280 206.1 280 224C280 227.4 282.2 230.5 285.5 231.6C288.7 232.7 292.3 231.6 294.4 228.8L294.4 228.8L294.6 228.5C294.8 228.3 294.1 228 295.3 227.6C295.1 226.8 296.9 225.7 298.1 224.3C300.6 221.4 304.1 217.7 308.3 213.1C317.1 206.2 327.2 200 336 200C344.8 200 354.9 206.2 363.7 213.1C367.9 217.7 371.4 221.4 373.9 224.3C375.1 225.7 376 226.8 376.7 227.6C377 228 377.2 228.3 377.4 228.5L377.6 228.8L377.6 228.8z\"\n ]\n};\nvar faSmileBeam = faFaceSmileBeam;\nvar faFaceSmileWink = {\n prefix: 'fas',\n iconName: 'face-smile-wink',\n icon: [\n 512,\n 512,\n [\n 128521,\n \"smile-wink\"\n ],\n \"f4da\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM164.1 325.5C158.3 318.8 148.2 318.1 141.5 323.9C134.8 329.7 134.1 339.8 139.9 346.5C162.1 372.1 200.9 400 255.1 400C311.1 400 349.8 372.1 372.1 346.5C377.9 339.8 377.2 329.7 370.5 323.9C363.8 318.1 353.7 318.8 347.9 325.5C329.9 346.2 299.4 368 255.1 368C212.6 368 182 346.2 164.1 325.5H164.1zM176.4 176C158.7 176 144.4 190.3 144.4 208C144.4 225.7 158.7 240 176.4 240C194 240 208.4 225.7 208.4 208C208.4 190.3 194 176 176.4 176zM300.8 233.6C318.4 210.1 353.6 210.1 371.2 233.6C376.5 240.7 386.5 242.1 393.6 236.8C400.7 231.5 402.1 221.5 396.8 214.4C366.4 173.9 305.6 173.9 275.2 214.4C269.9 221.5 271.3 231.5 278.4 236.8C285.5 242.1 295.5 240.7 300.8 233.6z\"\n ]\n};\nvar faSmileWink = faFaceSmileWink;\nvar faFaceSurprise = {\n prefix: 'fas',\n iconName: 'face-surprise',\n icon: [\n 512,\n 512,\n [\n 128558,\n \"surprise\"\n ],\n \"f5c2\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM176.4 240C194 240 208.4 225.7 208.4 208C208.4 190.3 194 176 176.4 176C158.7 176 144.4 190.3 144.4 208C144.4 225.7 158.7 240 176.4 240zM336.4 176C318.7 176 304.4 190.3 304.4 208C304.4 225.7 318.7 240 336.4 240C354 240 368.4 225.7 368.4 208C368.4 190.3 354 176 336.4 176zM256 416C291.3 416 320 387.3 320 352C320 316.7 291.3 288 256 288C220.7 288 192 316.7 192 352C192 387.3 220.7 416 256 416z\"\n ]\n};\nvar faSurprise = faFaceSurprise;\nvar faFaceTired = {\n prefix: 'fas',\n iconName: 'face-tired',\n icon: [\n 512,\n 512,\n [\n 128555,\n \"tired\"\n ],\n \"f5c8\",\n \"M0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256zM138.3 364.1C132.2 375.8 128 388.4 128 400C128 405.2 130.6 410.2 134.9 413.2C139.2 416.1 144.7 416.8 149.6 414.1L170.2 407.3C197.1 397.2 225.6 392 254.4 392H257.6C286.4 392 314.9 397.2 341.8 407.3L362.4 414.1C367.3 416.8 372.8 416.1 377.1 413.2C381.4 410.2 384 405.2 384 400C384 388.4 379.8 375.8 373.7 364.1C367.4 352.1 358.4 339.8 347.3 328.7C325.3 306.7 293.4 287.1 256 287.1C218.6 287.1 186.7 306.7 164.7 328.7C153.6 339.8 144.6 352.1 138.3 364.1H138.3zM133.5 146.7C125.6 142.4 116 148.2 116 157.1C116 159.9 116.1 162.6 118.8 164.8L154.8 208L118.8 251.2C116.1 253.4 116 256.1 116 258.9C116 267.8 125.6 273.6 133.5 269.3L223.4 221.4C234.1 215.7 234.1 200.3 223.4 194.6L133.5 146.7zM396 157.1C396 148.2 386.4 142.4 378.5 146.7L288.6 194.6C277.9 200.3 277.9 215.7 288.6 221.4L378.5 269.3C386.4 273.6 396 267.8 396 258.9C396 256.1 395 253.4 393.2 251.2L357.2 208L393.2 164.8C395 162.6 396 159.9 396 157.1V157.1z\"\n ]\n};\nvar faTired = faFaceTired;\nvar faFan = {\n prefix: 'fas',\n iconName: 'fan',\n icon: [\n 512,\n 512,\n [],\n \"f863\",\n \"M352.6 127.1c-28.12 0-54.13 4.5-77.13 12.88l12.38-123.1c1.125-10.5-8.125-18.88-18.5-17.63C189.6 10.12 127.1 77.62 127.1 159.4c0 28.12 4.5 54.13 12.88 77.13L17.75 224.1c-10.5-1.125-18.88 8.125-17.63 18.5c9.1 79.75 77.5 141.4 159.3 141.4c28.12 0 54.13-4.5 77.13-12.88l-12.38 123.1c-1.125 10.38 8.125 18.88 18.5 17.63c79.75-10 141.4-77.5 141.4-159.3c0-28.12-4.5-54.13-12.88-77.13l123.1 12.38c10.5 1.125 18.88-8.125 17.63-18.5C501.9 189.6 434.4 127.1 352.6 127.1zM255.1 287.1c-17.62 0-31.1-14.38-31.1-32s14.37-32 31.1-32s31.1 14.38 31.1 32S273.6 287.1 255.1 287.1z\"\n ]\n};\nvar faFaucet = {\n prefix: 'fas',\n iconName: 'faucet',\n icon: [\n 512,\n 512,\n [],\n \"e005\",\n \"M352 256h-38.54C297.7 242.5 277.9 232.9 256 228V180.5L224 177L192 180.5V228C170.1 233 150.3 242.6 134.5 256H16C7.125 256 0 263.1 0 272v96C0 376.9 7.125 384 16 384h92.78C129.4 421.8 173 448 224 448s94.59-26.25 115.2-64H352c17.62 0 32 14.29 32 31.91S398.4 448 416 448h64c17.62 0 32-14.31 32-31.94C512 327.7 440.4 256 352 256zM81.63 159.9L224 144.9l142.4 15C375.9 160.9 384 153.1 384 143.1V112.9c0-10-8.125-17.74-17.62-16.74L256 107.8V80C256 71.12 248.9 64 240 64h-32C199.1 64 192 71.12 192 80v27.75L81.63 96.14C72.13 95.14 64 102.9 64 112.9v30.24C64 153.1 72.13 160.9 81.63 159.9z\"\n ]\n};\nvar faFax = {\n prefix: 'fas',\n iconName: 'fax',\n icon: [\n 512,\n 512,\n [\n 128439,\n 128224\n ],\n \"f1ac\",\n \"M192 64h197.5L416 90.51V160h64V77.25c0-8.484-3.375-16.62-9.375-22.62l-45.25-45.25C419.4 3.375 411.2 0 402.8 0H160C142.3 0 128 14.33 128 32v128h64V64zM64 128H32C14.38 128 0 142.4 0 160v320c0 17.62 14.38 32 32 32h32c17.62 0 32-14.38 32-32V160C96 142.4 81.63 128 64 128zM480 192H128v288c0 17.6 14.4 32 32 32h320c17.6 0 32-14.4 32-32V224C512 206.4 497.6 192 480 192zM288 432c0 8.875-7.125 16-16 16h-32C231.1 448 224 440.9 224 432v-32C224 391.1 231.1 384 240 384h32c8.875 0 16 7.125 16 16V432zM288 304c0 8.875-7.125 16-16 16h-32C231.1 320 224 312.9 224 304v-32C224 263.1 231.1 256 240 256h32C280.9 256 288 263.1 288 272V304zM416 432c0 8.875-7.125 16-16 16h-32c-8.875 0-16-7.125-16-16v-32c0-8.875 7.125-16 16-16h32c8.875 0 16 7.125 16 16V432zM416 304c0 8.875-7.125 16-16 16h-32C359.1 320 352 312.9 352 304v-32C352 263.1 359.1 256 368 256h32C408.9 256 416 263.1 416 272V304z\"\n ]\n};\nvar faFeather = {\n prefix: 'fas',\n iconName: 'feather',\n icon: [\n 512,\n 512,\n [\n 129718\n ],\n \"f52d\",\n \"M483.4 244.2L351.9 287.1h97.74c-9.874 10.62 3.75-3.125-46.24 46.87l-147.6 49.12h98.24c-74.99 73.12-194.6 70.62-246.8 54.1l-66.14 65.99c-9.374 9.374-24.6 9.374-33.98 0s-9.374-24.6 0-33.98l259.5-259.2c6.249-6.25 6.249-16.37 0-22.62c-6.249-6.249-16.37-6.249-22.62 0l-178.4 178.2C58.78 306.1 68.61 216.7 129.1 156.3l85.74-85.68c90.62-90.62 189.8-88.27 252.3-25.78C517.8 95.34 528.9 169.7 483.4 244.2z\"\n ]\n};\nvar faFeatherPointed = {\n prefix: 'fas',\n iconName: 'feather-pointed',\n icon: [\n 512,\n 512,\n [\n \"feather-alt\"\n ],\n \"f56b\",\n \"M467.1 241.1L351.1 288h94.34c-7.711 14.85-16.29 29.28-25.87 43.01l-132.5 52.99h85.65c-59.34 52.71-144.1 80.34-264.5 52.82l-68.13 68.13c-9.38 9.38-24.56 9.374-33.94 0c-9.375-9.375-9.375-24.56 0-33.94l253.4-253.4c4.846-6.275 4.643-15.19-1.113-20.95c-6.25-6.25-16.38-6.25-22.62 0l-168.6 168.6C24.56 58 366.9 8.118 478.9 .0846c18.87-1.354 34.41 14.19 33.05 33.05C508.7 78.53 498.5 161.8 467.1 241.1z\"\n ]\n};\nvar faFeatherAlt = faFeatherPointed;\nvar faFile = {\n prefix: 'fas',\n iconName: 'file',\n icon: [\n 384,\n 512,\n [\n 128459,\n 61462,\n 128196\n ],\n \"f15b\",\n \"M256 0v128h128L256 0zM224 128L224 0H48C21.49 0 0 21.49 0 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48V160h-127.1C238.3 160 224 145.7 224 128z\"\n ]\n};\nvar faFileArrowDown = {\n prefix: 'fas',\n iconName: 'file-arrow-down',\n icon: [\n 384,\n 512,\n [\n \"file-download\"\n ],\n \"f56d\",\n \"M384 128h-128V0L384 128zM256 160H384v304c0 26.51-21.49 48-48 48h-288C21.49 512 0 490.5 0 464v-416C0 21.49 21.49 0 48 0H224l.0039 128C224 145.7 238.3 160 256 160zM255 295L216 334.1V232c0-13.25-10.75-24-24-24S168 218.8 168 232v102.1L128.1 295C124.3 290.3 118.2 288 112 288S99.72 290.3 95.03 295c-9.375 9.375-9.375 24.56 0 33.94l80 80c9.375 9.375 24.56 9.375 33.94 0l80-80c9.375-9.375 9.375-24.56 0-33.94S264.4 285.7 255 295z\"\n ]\n};\nvar faFileDownload = faFileArrowDown;\nvar faFileArrowUp = {\n prefix: 'fas',\n iconName: 'file-arrow-up',\n icon: [\n 384,\n 512,\n [\n \"file-upload\"\n ],\n \"f574\",\n \"M256 0v128h128L256 0zM224 128L224 0H48C21.49 0 0 21.49 0 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48V160h-127.1C238.3 160 224 145.7 224 128zM288.1 344.1C284.3 349.7 278.2 352 272 352s-12.28-2.344-16.97-7.031L216 305.9V408c0 13.25-10.75 24-24 24s-24-10.75-24-24V305.9l-39.03 39.03c-9.375 9.375-24.56 9.375-33.94 0s-9.375-24.56 0-33.94l80-80c9.375-9.375 24.56-9.375 33.94 0l80 80C298.3 320.4 298.3 335.6 288.1 344.1z\"\n ]\n};\nvar faFileUpload = faFileArrowUp;\nvar faFileAudio = {\n prefix: 'fas',\n iconName: 'file-audio',\n icon: [\n 384,\n 512,\n [],\n \"f1c7\",\n \"M224 128L224 0H48C21.49 0 0 21.49 0 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48V160h-127.1C238.3 160 224 145.7 224 128zM176 404c0 10.75-12.88 15.98-20.5 8.484L120 376H76C69.38 376 64 370.6 64 364v-56C64 301.4 69.38 296 76 296H120l35.5-36.5C163.1 251.9 176 257.3 176 268V404zM224 387.8c-4.391 0-8.75-1.835-11.91-5.367c-5.906-6.594-5.359-16.69 1.219-22.59C220.2 353.7 224 345.2 224 336s-3.797-17.69-10.69-23.88c-6.578-5.906-7.125-16-1.219-22.59c5.922-6.594 16.05-7.094 22.59-1.219C248.2 300.5 256 317.8 256 336s-7.766 35.53-21.31 47.69C231.6 386.4 227.8 387.8 224 387.8zM320 336c0 41.81-20.5 81.11-54.84 105.1c-2.781 1.938-5.988 2.875-9.145 2.875c-5.047 0-10.03-2.375-13.14-6.844c-5.047-7.25-3.281-17.22 3.969-22.28C272.6 396.9 288 367.4 288 336s-15.38-60.84-41.14-78.8c-7.25-5.062-9.027-15.03-3.98-22.28c5.047-7.281 14.99-9.062 22.27-3.969C299.5 254.9 320 294.2 320 336zM256 0v128h128L256 0z\"\n ]\n};\nvar faFileCode = {\n prefix: 'fas',\n iconName: 'file-code',\n icon: [\n 384,\n 512,\n [],\n \"f1c9\",\n \"M224 128L224 0H48C21.49 0 0 21.49 0 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48V160h-127.1C238.3 160 224 145.7 224 128zM154.1 353.8c7.812 7.812 7.812 20.5 0 28.31C150.2 386.1 145.1 388 140 388s-10.23-1.938-14.14-5.844l-48-48c-7.812-7.812-7.812-20.5 0-28.31l48-48c7.812-7.812 20.47-7.812 28.28 0s7.812 20.5 0 28.31L120.3 320L154.1 353.8zM306.1 305.8c7.812 7.812 7.812 20.5 0 28.31l-48 48C254.2 386.1 249.1 388 244 388s-10.23-1.938-14.14-5.844c-7.812-7.812-7.812-20.5 0-28.31L263.7 320l-33.86-33.84c-7.812-7.812-7.812-20.5 0-28.31s20.47-7.812 28.28 0L306.1 305.8zM256 0v128h128L256 0z\"\n ]\n};\nvar faFileContract = {\n prefix: 'fas',\n iconName: 'file-contract',\n icon: [\n 384,\n 512,\n [],\n \"f56c\",\n \"M256 0v128h128L256 0zM224 128L224 0H48C21.49 0 0 21.49 0 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48V160h-127.1C238.3 160 224 145.7 224 128zM64 72C64 67.63 67.63 64 72 64h80C156.4 64 160 67.63 160 72v16C160 92.38 156.4 96 152 96h-80C67.63 96 64 92.38 64 88V72zM64 136C64 131.6 67.63 128 72 128h80C156.4 128 160 131.6 160 136v16C160 156.4 156.4 160 152 160h-80C67.63 160 64 156.4 64 152V136zM304 384c8.875 0 16 7.125 16 16S312.9 416 304 416h-47.25c-16.38 0-31.25-9.125-38.63-23.88c-2.875-5.875-8-6.5-10.12-6.5s-7.25 .625-10 6.125l-7.75 15.38C187.6 412.6 181.1 416 176 416H174.9c-6.5-.5-12-4.75-14-11L144 354.6L133.4 386.5C127.5 404.1 111 416 92.38 416H80C71.13 416 64 408.9 64 400S71.13 384 80 384h12.38c4.875 0 9.125-3.125 10.62-7.625l18.25-54.63C124.5 311.9 133.6 305.3 144 305.3s19.5 6.625 22.75 16.5l13.88 41.63c19.75-16.25 54.13-9.75 66 14.12c2 4 6 6.5 10.12 6.5H304z\"\n ]\n};\nvar faFileCsv = {\n prefix: 'fas',\n iconName: 'file-csv',\n icon: [\n 384,\n 512,\n [],\n \"f6dd\",\n \"M256 0v128h128L256 0zM224 128L224 0H48C21.49 0 0 21.49 0 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48V160h-127.1C238.3 160 224 145.7 224 128zM128 280C128 284.4 124.4 288 120 288H112C103.1 288 96 295.1 96 304v32C96 344.9 103.1 352 112 352h8C124.4 352 128 355.6 128 360v16C128 380.4 124.4 384 120 384H112C85.5 384 64 362.5 64 336v-32C64 277.5 85.5 256 112 256h8C124.4 256 128 259.6 128 264V280zM172.3 384H160c-4.375 0-8-3.625-8-8v-16C152 355.6 155.6 352 160 352h12.25c6 0 10.38-3.5 10.38-6.625c0-1.25-.75-2.625-2.125-3.875l-21.88-18.75C150.3 315.5 145.4 305.3 145.4 294.6C145.4 273.4 164.4 256 187.8 256H200c4.375 0 8 3.625 8 8v16C208 284.4 204.4 288 200 288H187.8c-6 0-10.38 3.5-10.38 6.625c0 1.25 .75 2.625 2.125 3.875l21.88 18.75c8.375 7.25 13.25 17.5 13.25 28.12C214.6 366.6 195.6 384 172.3 384zM288 284.8V264C288 259.6 291.6 256 296 256h16C316.4 256 320 259.6 320 264v20.75c0 35.5-12.88 69-36.25 94.13C280.8 382.1 276.5 384 272 384s-8.75-1.875-11.75-5.125C236.9 353.8 224 320.3 224 284.8V264C224 259.6 227.6 256 232 256h16C252.4 256 256 259.6 256 264v20.75c0 20.38 5.75 40.25 16 56.88C282.3 325 288 305.1 288 284.8z\"\n ]\n};\nvar faFileExcel = {\n prefix: 'fas',\n iconName: 'file-excel',\n icon: [\n 384,\n 512,\n [],\n \"f1c3\",\n \"M224 128L224 0H48C21.49 0 0 21.49 0 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48V160h-127.1C238.3 160 224 145.7 224 128zM272.1 264.4L224 344l48.99 79.61C279.6 434.3 271.9 448 259.4 448h-26.43c-5.557 0-10.71-2.883-13.63-7.617L192 396l-27.31 44.38C161.8 445.1 156.6 448 151.1 448H124.6c-12.52 0-20.19-13.73-13.63-24.39L160 344L111 264.4C104.4 253.7 112.1 240 124.6 240h26.43c5.557 0 10.71 2.883 13.63 7.613L192 292l27.31-44.39C222.2 242.9 227.4 240 232.9 240h26.43C271.9 240 279.6 253.7 272.1 264.4zM256 0v128h128L256 0z\"\n ]\n};\nvar faFileExport = {\n prefix: 'fas',\n iconName: 'file-export',\n icon: [\n 576,\n 512,\n [\n \"arrow-right-from-file\"\n ],\n \"f56e\",\n \"M192 312C192 298.8 202.8 288 216 288H384V160H256c-17.67 0-32-14.33-32-32L224 0H48C21.49 0 0 21.49 0 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48v-128H216C202.8 336 192 325.3 192 312zM256 0v128h128L256 0zM568.1 295l-80-80c-9.375-9.375-24.56-9.375-33.94 0s-9.375 24.56 0 33.94L494.1 288H384v48h110.1l-39.03 39.03C450.3 379.7 448 385.8 448 392s2.344 12.28 7.031 16.97c9.375 9.375 24.56 9.375 33.94 0l80-80C578.3 319.6 578.3 304.4 568.1 295z\"\n ]\n};\nvar faArrowRightFromFile = faFileExport;\nvar faFileImage = {\n prefix: 'fas',\n iconName: 'file-image',\n icon: [\n 384,\n 512,\n [\n 128443\n ],\n \"f1c5\",\n \"M224 128L224 0H48C21.49 0 0 21.49 0 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48V160h-127.1C238.3 160 224 145.7 224 128zM96 224c17.67 0 32 14.33 32 32S113.7 288 96 288S64 273.7 64 256S78.33 224 96 224zM318.1 439.5C315.3 444.8 309.9 448 304 448h-224c-5.9 0-11.32-3.248-14.11-8.451c-2.783-5.201-2.479-11.52 .7949-16.42l53.33-80C122.1 338.7 127.1 336 133.3 336s10.35 2.674 13.31 7.125L160 363.2l45.35-68.03C208.3 290.7 213.3 288 218.7 288s10.35 2.674 13.31 7.125l85.33 128C320.6 428 320.9 434.3 318.1 439.5zM256 0v128h128L256 0z\"\n ]\n};\nvar faFileImport = {\n prefix: 'fas',\n iconName: 'file-import',\n icon: [\n 512,\n 512,\n [\n \"arrow-right-to-file\"\n ],\n \"f56f\",\n \"M384 0v128h128L384 0zM352 128L352 0H176C149.5 0 128 21.49 128 48V288h174.1l-39.03-39.03c-9.375-9.375-9.375-24.56 0-33.94s24.56-9.375 33.94 0l80 80c9.375 9.375 9.375 24.56 0 33.94l-80 80c-9.375 9.375-24.56 9.375-33.94 0C258.3 404.3 256 398.2 256 392s2.344-12.28 7.031-16.97L302.1 336H128v128C128 490.5 149.5 512 176 512h288c26.51 0 48-21.49 48-48V160h-127.1C366.3 160 352 145.7 352 128zM24 288C10.75 288 0 298.7 0 312c0 13.25 10.75 24 24 24H128V288H24z\"\n ]\n};\nvar faArrowRightToFile = faFileImport;\nvar faFileInvoice = {\n prefix: 'fas',\n iconName: 'file-invoice',\n icon: [\n 384,\n 512,\n [],\n \"f570\",\n \"M256 0v128h128L256 0zM288 256H96v64h192V256zM224 128L224 0H48C21.49 0 0 21.49 0 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48V160h-127.1C238.3 160 224 145.7 224 128zM64 72C64 67.63 67.63 64 72 64h80C156.4 64 160 67.63 160 72v16C160 92.38 156.4 96 152 96h-80C67.63 96 64 92.38 64 88V72zM64 136C64 131.6 67.63 128 72 128h80C156.4 128 160 131.6 160 136v16C160 156.4 156.4 160 152 160h-80C67.63 160 64 156.4 64 152V136zM320 440c0 4.375-3.625 8-8 8h-80C227.6 448 224 444.4 224 440v-16c0-4.375 3.625-8 8-8h80c4.375 0 8 3.625 8 8V440zM320 240v96c0 8.875-7.125 16-16 16h-224C71.13 352 64 344.9 64 336v-96C64 231.1 71.13 224 80 224h224C312.9 224 320 231.1 320 240z\"\n ]\n};\nvar faFileInvoiceDollar = {\n prefix: 'fas',\n iconName: 'file-invoice-dollar',\n icon: [\n 384,\n 512,\n [],\n \"f571\",\n \"M384 128h-128V0L384 128zM256 160H384v304c0 26.51-21.49 48-48 48h-288C21.49 512 0 490.5 0 464v-416C0 21.49 21.49 0 48 0H224l.0039 128C224 145.7 238.3 160 256 160zM64 88C64 92.38 67.63 96 72 96h80C156.4 96 160 92.38 160 88v-16C160 67.63 156.4 64 152 64h-80C67.63 64 64 67.63 64 72V88zM72 160h80C156.4 160 160 156.4 160 152v-16C160 131.6 156.4 128 152 128h-80C67.63 128 64 131.6 64 136v16C64 156.4 67.63 160 72 160zM197.5 316.8L191.1 315.2C168.3 308.2 168.8 304.1 169.6 300.5c1.375-7.812 16.59-9.719 30.27-7.625c5.594 .8438 11.73 2.812 17.59 4.844c10.39 3.594 21.83-1.938 25.45-12.34c3.625-10.44-1.891-21.84-12.33-25.47c-7.219-2.484-13.11-4.078-18.56-5.273V248c0-11.03-8.953-20-20-20s-20 8.969-20 20v5.992C149.6 258.8 133.8 272.8 130.2 293.7c-7.406 42.84 33.19 54.75 50.52 59.84l5.812 1.688c29.28 8.375 28.8 11.19 27.92 16.28c-1.375 7.812-16.59 9.75-30.31 7.625c-6.938-1.031-15.81-4.219-23.66-7.031l-4.469-1.625c-10.41-3.594-21.83 1.812-25.52 12.22c-3.672 10.41 1.781 21.84 12.2 25.53l4.266 1.5c7.758 2.789 16.38 5.59 25.06 7.512V424c0 11.03 8.953 20 20 20s20-8.969 20-20v-6.254c22.36-4.793 38.21-18.53 41.83-39.43C261.3 335 219.8 323.1 197.5 316.8z\"\n ]\n};\nvar faFileLines = {\n prefix: 'fas',\n iconName: 'file-lines',\n icon: [\n 384,\n 512,\n [\n 128462,\n 61686,\n 128441,\n \"file-alt\",\n \"file-text\"\n ],\n \"f15c\",\n \"M256 0v128h128L256 0zM224 128L224 0H48C21.49 0 0 21.49 0 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48V160h-127.1C238.3 160 224 145.7 224 128zM272 416h-160C103.2 416 96 408.8 96 400C96 391.2 103.2 384 112 384h160c8.836 0 16 7.162 16 16C288 408.8 280.8 416 272 416zM272 352h-160C103.2 352 96 344.8 96 336C96 327.2 103.2 320 112 320h160c8.836 0 16 7.162 16 16C288 344.8 280.8 352 272 352zM288 272C288 280.8 280.8 288 272 288h-160C103.2 288 96 280.8 96 272C96 263.2 103.2 256 112 256h160C280.8 256 288 263.2 288 272z\"\n ]\n};\nvar faFileAlt = faFileLines;\nvar faFileText = faFileLines;\nvar faFileMedical = {\n prefix: 'fas',\n iconName: 'file-medical',\n icon: [\n 384,\n 512,\n [],\n \"f477\",\n \"M256 0v128h128L256 0zM224 128L224 0H48C21.49 0 0 21.49 0 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48V160h-127.1C238.3 160 224 145.7 224 128zM288 301.7v36.57C288 345.9 281.9 352 274.3 352L224 351.1v50.29C224 409.9 217.9 416 210.3 416H173.7C166.1 416 160 409.9 160 402.3V351.1L109.7 352C102.1 352 96 345.9 96 338.3V301.7C96 294.1 102.1 288 109.7 288H160V237.7C160 230.1 166.1 224 173.7 224h36.57C217.9 224 224 230.1 224 237.7V288h50.29C281.9 288 288 294.1 288 301.7z\"\n ]\n};\nvar faFilePdf = {\n prefix: 'fas',\n iconName: 'file-pdf',\n icon: [\n 384,\n 512,\n [],\n \"f1c1\",\n \"M184 208c0-4.406-3.594-8-8-8S168 203.6 168 208c0 2.062 .2969 23.31 9.141 50.25C179.1 249.6 184 226.2 184 208zM256 0v128h128L256 0zM80 422.4c0 9.656 10.47 11.97 14.38 6.375C99.27 421.9 108.8 408 120.1 388.6c-14.22 7.969-27.25 17.31-38.02 28.31C80.75 418.3 80 420.3 80 422.4zM224 128L224 0H48C21.49 0 0 21.49 0 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48V160h-127.1C238.3 160 224 145.7 224 128zM292 312c24.26 0 44 19.74 44 44c0 24.67-18.94 44-43.13 44c-5.994 0-11.81-.9531-17.22-2.805c-20.06-6.758-38.38-15.96-54.55-27.39c-23.88 5.109-45.46 11.52-64.31 19.1c-14.43 26.31-27.63 46.15-36.37 58.41C112.1 457.8 100.8 464 87.94 464C65.92 464 48 446.1 48 424.1c0-11.92 3.74-21.82 11.18-29.51c16.18-16.52 37.37-30.99 63.02-43.05c11.75-22.83 21.94-46.04 30.33-69.14C136.2 242.4 136 208.4 136 208c0-22.05 17.95-40 40-40c22.06 0 40 17.95 40 40c0 24.1-7.227 55.75-8.938 62.63c-1.006 3.273-2.035 6.516-3.082 9.723c7.83 14.46 17.7 27.21 29.44 38.05C263.1 313.4 284.3 312.1 287.6 312H292zM156.5 354.6c17.98-6.5 36.13-11.44 52.92-15.19c-12.42-12.06-22.17-25.12-29.8-38.16C172.3 320.6 164.4 338.5 156.5 354.6zM292.9 368C299 368 304 363 304 356.9C304 349.4 298.6 344 292 344H288c-.3438 .0313-16.83 .9687-40.95 4.75c11.27 7 24.12 13.19 38.84 18.12C288 367.6 290.5 368 292.9 368z\"\n ]\n};\nvar faFilePowerpoint = {\n prefix: 'fas',\n iconName: 'file-powerpoint',\n icon: [\n 384,\n 512,\n [],\n \"f1c4\",\n \"M256 0v128h128L256 0zM224 128L224 0H48C21.49 0 0 21.49 0 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48V160h-127.1C238.3 160 224 145.7 224 128zM279.6 308.1C284.2 353.5 248.5 392 204 392H160v40C160 440.8 152.8 448 144 448H128c-8.836 0-16-7.164-16-16V256c0-8.836 7.164-16 16-16h71.51C239.3 240 275.6 268.5 279.6 308.1zM160 344h44c15.44 0 28-12.56 28-28S219.4 288 204 288H160V344z\"\n ]\n};\nvar faFilePrescription = {\n prefix: 'fas',\n iconName: 'file-prescription',\n icon: [\n 384,\n 512,\n [],\n \"f572\",\n \"M176 240H128v32h48C184.9 272 192 264.9 192 256S184.9 240 176 240zM256 0v128h128L256 0zM224 128L224 0H48C21.49 0 0 21.49 0 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48V160h-127.1C238.3 160 224 145.7 224 128zM292.5 315.5l11.38 11.25c6.25 6.25 6.25 16.38 0 22.62l-29.88 30L304 409.4c6.25 6.25 6.25 16.38 0 22.62l-11.25 11.38c-6.25 6.25-16.5 6.25-22.75 0L240 413.3l-30 30c-6.249 6.25-16.48 6.266-22.73 .0156L176 432c-6.25-6.25-6.25-16.38 0-22.62l29.1-30.12L146.8 320H128l.0078 48.01c0 8.875-7.125 16-16 16L96 384c-8.875 0-16-7.125-16-16v-160C80 199.1 87.13 192 96 192h80c35.38 0 64 28.62 64 64c0 24.25-13.62 45-33.5 55.88L240 345.4l29.88-29.88C276.1 309.3 286.3 309.3 292.5 315.5z\"\n ]\n};\nvar faFileSignature = {\n prefix: 'fas',\n iconName: 'file-signature',\n icon: [\n 576,\n 512,\n [],\n \"f573\",\n \"M292.7 342.3C289.7 345.3 288 349.4 288 353.7V416h62.34c4.264 0 8.35-1.703 11.35-4.727l156.9-158l-67.88-67.88L292.7 342.3zM568.5 167.4L536.6 135.5c-9.875-10-26-10-36 0l-27.25 27.25l67.88 67.88l27.25-27.25C578.5 193.4 578.5 177.3 568.5 167.4zM256 0v128h128L256 0zM256 448c-16.07-.2852-30.62-9.359-37.88-23.88c-2.875-5.875-8-6.5-10.12-6.5s-7.25 .625-10 6.125l-7.749 15.38C187.6 444.6 181.1 448 176 448H174.9c-6.5-.5-12-4.75-14-11L144 386.6L133.4 418.5C127.5 436.1 111 448 92.45 448H80C71.13 448 64 440.9 64 432S71.13 416 80 416h12.4c4.875 0 9.102-3.125 10.6-7.625l18.25-54.63C124.5 343.9 133.6 337.3 144 337.3s19.5 6.625 22.75 16.5l13.88 41.63c19.75-16.25 54.13-9.75 66 14.12C248.5 413.2 252.2 415.6 256 415.9V347c0-8.523 3.402-16.7 9.451-22.71L384 206.5V160H256c-17.67 0-32-14.33-32-32L224 0H48C21.49 0 0 21.49 0 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48V448H256z\"\n ]\n};\nvar faFileVideo = {\n prefix: 'fas',\n iconName: 'file-video',\n icon: [\n 384,\n 512,\n [],\n \"f1c8\",\n \"M256 0v128h128L256 0zM224 128L224 0H48C21.49 0 0 21.49 0 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48V160h-127.1C238.3 160 224 145.7 224 128zM224 384c0 17.67-14.33 32-32 32H96c-17.67 0-32-14.33-32-32V288c0-17.67 14.33-32 32-32h96c17.67 0 32 14.33 32 32V384zM320 284.9v102.3c0 12.57-13.82 20.23-24.48 13.57L256 376v-80l39.52-24.7C306.2 264.6 320 272.3 320 284.9z\"\n ]\n};\nvar faFileWaveform = {\n prefix: 'fas',\n iconName: 'file-waveform',\n icon: [\n 448,\n 512,\n [\n \"file-medical-alt\"\n ],\n \"f478\",\n \"M320 0v128h128L320 0zM288 128L288 0H112C85.49 0 64 21.49 64 48V224H16C7.164 224 0 231.2 0 240v32C0 280.8 7.164 288 16 288h128c6.062 0 11.59 3.438 14.31 8.844L176 332.2l49.69-99.38c5.438-10.81 23.19-10.81 28.62 0L281.9 288H352c8.844 0 16 7.156 16 16S360.8 320 352 320h-80c-6.062 0-11.59-3.438-14.31-8.844L240 275.8l-49.69 99.38C187.6 380.6 182.1 384 176 384s-11.59-3.438-14.31-8.844L134.1 320H64v144C64 490.5 85.49 512 112 512h288c26.51 0 48-21.49 48-48V160h-127.1C302.3 160 288 145.7 288 128z\"\n ]\n};\nvar faFileMedicalAlt = faFileWaveform;\nvar faFileWord = {\n prefix: 'fas',\n iconName: 'file-word',\n icon: [\n 384,\n 512,\n [],\n \"f1c2\",\n \"M224 128L224 0H48C21.49 0 0 21.49 0 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48V160h-127.1C238.3 160 224 145.7 224 128zM281.5 240h23.37c7.717 0 13.43 7.18 11.69 14.7l-42.46 184C272.9 444.1 268 448 262.5 448h-29.26c-5.426 0-10.18-3.641-11.59-8.883L192 329.1l-29.61 109.1C160.1 444.4 156.2 448 150.8 448H121.5c-5.588 0-10.44-3.859-11.69-9.305l-42.46-184C65.66 247.2 71.37 240 79.08 240h23.37c5.588 0 10.44 3.859 11.69 9.301L137.8 352L165.6 248.9C167 243.6 171.8 240 177.2 240h29.61c5.426 0 10.18 3.641 11.59 8.883L246.2 352l23.7-102.7C271.1 243.9 275.1 240 281.5 240zM256 0v128h128L256 0z\"\n ]\n};\nvar faFileZipper = {\n prefix: 'fas',\n iconName: 'file-zipper',\n icon: [\n 384,\n 512,\n [\n \"file-archive\"\n ],\n \"f1c6\",\n \"M256 0v128h128L256 0zM224 128L224 0H48C21.49 0 0 21.49 0 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48V160h-127.1C238.3 160 224 145.7 224 128zM96 32h64v32H96V32zM96 96h64v32H96V96zM96 160h64v32H96V160zM128.3 415.1c-40.56 0-70.76-36.45-62.83-75.45L96 224h64l30.94 116.9C198.7 379.7 168.5 415.1 128.3 415.1zM144 336h-32C103.2 336 96 343.2 96 352s7.164 16 16 16h32C152.8 368 160 360.8 160 352S152.8 336 144 336z\"\n ]\n};\nvar faFileArchive = faFileZipper;\nvar faFill = {\n prefix: 'fas',\n iconName: 'fill',\n icon: [\n 512,\n 512,\n [],\n \"f575\",\n \"M168 90.74L221.1 37.66C249.2 9.539 294.8 9.539 322.9 37.66L474.3 189.1C502.5 217.2 502.5 262.8 474.3 290.9L283.9 481.4C246.4 518.9 185.6 518.9 148.1 481.4L30.63 363.9C-6.863 326.4-6.863 265.6 30.63 228.1L122.7 135.1L41.37 54.63C28.88 42.13 28.88 21.87 41.37 9.372C53.87-3.124 74.13-3.124 86.63 9.372L168 90.74zM75.88 273.4C71.69 277.6 68.9 282.6 67.52 287.1H386.7L429.1 245.7C432.2 242.5 432.2 237.5 429.1 234.3L277.7 82.91C274.5 79.79 269.5 79.79 266.3 82.91L213.3 136L262.6 185.4C275.1 197.9 275.1 218.1 262.6 230.6C250.1 243.1 229.9 243.1 217.4 230.6L168 181.3L75.88 273.4z\"\n ]\n};\nvar faFillDrip = {\n prefix: 'fas',\n iconName: 'fill-drip',\n icon: [\n 576,\n 512,\n [],\n \"f576\",\n \"M41.37 9.372C53.87-3.124 74.13-3.124 86.63 9.372L168 90.74L221.1 37.66C249.2 9.539 294.8 9.539 322.9 37.66L474.3 189.1C502.5 217.2 502.5 262.8 474.3 290.9L283.9 481.4C246.4 518.9 185.6 518.9 148.1 481.4L30.63 363.9C-6.863 326.4-6.863 265.6 30.63 228.1L122.7 135.1L41.37 54.63C28.88 42.13 28.88 21.87 41.37 9.372V9.372zM217.4 230.6L168 181.3L75.88 273.4C71.69 277.6 68.9 282.6 67.52 288H386.7L429.1 245.7C432.2 242.5 432.2 237.5 429.1 234.3L277.7 82.91C274.5 79.79 269.5 79.79 266.3 82.91L213.3 136L262.6 185.4C275.1 197.9 275.1 218.1 262.6 230.6C250.1 243.1 229.9 243.1 217.4 230.6L217.4 230.6zM448 448C448 422.8 480.6 368.4 499.2 339.3C505.3 329.9 518.7 329.9 524.8 339.3C543.4 368.4 576 422.8 576 448C576 483.3 547.3 512 512 512C476.7 512 448 483.3 448 448H448z\"\n ]\n};\nvar faFilm = {\n prefix: 'fas',\n iconName: 'film',\n icon: [\n 512,\n 512,\n [\n 127902\n ],\n \"f008\",\n \"M463.1 32h-416C21.49 32-.0001 53.49-.0001 80v352c0 26.51 21.49 48 47.1 48h416c26.51 0 48-21.49 48-48v-352C511.1 53.49 490.5 32 463.1 32zM111.1 408c0 4.418-3.582 8-8 8H55.1c-4.418 0-8-3.582-8-8v-48c0-4.418 3.582-8 8-8h47.1c4.418 0 8 3.582 8 8L111.1 408zM111.1 280c0 4.418-3.582 8-8 8H55.1c-4.418 0-8-3.582-8-8v-48c0-4.418 3.582-8 8-8h47.1c4.418 0 8 3.582 8 8V280zM111.1 152c0 4.418-3.582 8-8 8H55.1c-4.418 0-8-3.582-8-8v-48c0-4.418 3.582-8 8-8h47.1c4.418 0 8 3.582 8 8L111.1 152zM351.1 400c0 8.836-7.164 16-16 16H175.1c-8.836 0-16-7.164-16-16v-96c0-8.838 7.164-16 16-16h160c8.836 0 16 7.162 16 16V400zM351.1 208c0 8.836-7.164 16-16 16H175.1c-8.836 0-16-7.164-16-16v-96c0-8.838 7.164-16 16-16h160c8.836 0 16 7.162 16 16V208zM463.1 408c0 4.418-3.582 8-8 8h-47.1c-4.418 0-7.1-3.582-7.1-8l0-48c0-4.418 3.582-8 8-8h47.1c4.418 0 8 3.582 8 8V408zM463.1 280c0 4.418-3.582 8-8 8h-47.1c-4.418 0-8-3.582-8-8v-48c0-4.418 3.582-8 8-8h47.1c4.418 0 8 3.582 8 8V280zM463.1 152c0 4.418-3.582 8-8 8h-47.1c-4.418 0-8-3.582-8-8l0-48c0-4.418 3.582-8 7.1-8h47.1c4.418 0 8 3.582 8 8V152z\"\n ]\n};\nvar faFilter = {\n prefix: 'fas',\n iconName: 'filter',\n icon: [\n 512,\n 512,\n [],\n \"f0b0\",\n \"M3.853 54.87C10.47 40.9 24.54 32 40 32H472C487.5 32 501.5 40.9 508.1 54.87C514.8 68.84 512.7 85.37 502.1 97.33L320 320.9V448C320 460.1 313.2 471.2 302.3 476.6C291.5 482 278.5 480.9 268.8 473.6L204.8 425.6C196.7 419.6 192 410.1 192 400V320.9L9.042 97.33C-.745 85.37-2.765 68.84 3.854 54.87L3.853 54.87z\"\n ]\n};\nvar faFilterCircleDollar = {\n prefix: 'fas',\n iconName: 'filter-circle-dollar',\n icon: [\n 576,\n 512,\n [\n \"funnel-dollar\"\n ],\n \"f662\",\n \"M3.853 22.87C10.47 8.904 24.54 0 40 0H472C487.5 0 501.5 8.904 508.1 22.87C514.8 36.84 512.7 53.37 502.1 65.33L396.4 195.6C316.2 212.1 255.1 283 255.1 368C255.1 395.4 262.3 421.4 273.5 444.5C271.8 443.7 270.3 442.7 268.8 441.6L204.8 393.6C196.7 387.6 192 378.1 192 368V288.9L9.042 65.33C-.745 53.37-2.765 36.84 3.854 22.87H3.853zM576 368C576 447.5 511.5 512 432 512C352.5 512 287.1 447.5 287.1 368C287.1 288.5 352.5 224 432 224C511.5 224 576 288.5 576 368zM413 331.1C418.1 329.3 425.6 327.9 431.8 328C439.1 328.1 448.9 329.8 458.1 332.1C466.7 334.2 475.4 328.1 477.5 320.4C479.7 311.8 474.4 303.2 465.9 301C460.3 299.6 454.3 298.3 448 297.4V288C448 279.2 440.8 272 432 272C423.2 272 416 279.2 416 288V297.5C409.9 298.7 403.7 300.7 397.1 303.8C386.1 310.1 374.9 322.2 376.1 341C377.1 357 387.8 366.4 397.7 371.7C406.6 376.4 417.5 379.5 426.3 381.1L428.1 382.5C438.3 385.4 445.1 387.7 451.2 390.8C455.8 393.5 455.1 395.1 455.1 396.5C456.1 398.9 455.5 400.2 454.1 401C454.3 401.1 453.2 403.2 450.1 404.4C446.3 406.9 439.2 408.2 432.5 407.1C422.1 407.7 414 404.8 402.6 401.2C400.7 400.6 398.8 400 396.8 399.4C388.3 396.8 379.3 401.5 376.7 409.9C374.1 418.3 378.8 427.3 387.2 429.9C388.9 430.4 390.5 430.1 392.3 431.5C399.3 433.8 407.4 436.4 416 438.1V449.5C416 458.4 423.2 465.5 432 465.5C440.8 465.5 448 458.4 448 449.5V438.7C454.2 437.6 460.5 435.6 466.3 432.5C478.3 425.9 488.5 413.8 487.1 395.5C487.5 379.4 477.7 369.3 467.5 363.3C458.1 357.7 446.2 354.4 436.9 351.7L436.8 351.7C426.3 348.7 418.5 346.5 412.9 343.5C408.1 340.9 408.1 339.5 408.1 339.1L408.1 338.1C407.9 337 408.4 336.1 408.8 335.4C409.4 334.5 410.6 333.3 413 331.1L413 331.1z\"\n ]\n};\nvar faFunnelDollar = faFilterCircleDollar;\nvar faFilterCircleXmark = {\n prefix: 'fas',\n iconName: 'filter-circle-xmark',\n icon: [\n 576,\n 512,\n [],\n \"e17b\",\n \"M3.853 22.87C10.47 8.904 24.54 0 40 0H472C487.5 0 501.5 8.904 508.1 22.87C514.8 36.84 512.7 53.37 502.1 65.33L396.4 195.6C316.2 212.1 255.1 283 255.1 368C255.1 395.4 262.3 421.4 273.5 444.5C271.8 443.7 270.3 442.7 268.8 441.6L204.8 393.6C196.7 387.6 192 378.1 192 368V288.9L9.042 65.33C-.745 53.37-2.765 36.84 3.854 22.87H3.853zM287.1 368C287.1 288.5 352.5 224 432 224C511.5 224 576 288.5 576 368C576 447.5 511.5 512 432 512C352.5 512 287.1 447.5 287.1 368zM491.3 331.3C497.6 325.1 497.6 314.9 491.3 308.7C485.1 302.4 474.9 302.4 468.7 308.7L432 345.4L395.3 308.7C389.1 302.4 378.9 302.4 372.7 308.7C366.4 314.9 366.4 325.1 372.7 331.3L409.4 368L372.7 404.7C366.4 410.9 366.4 421.1 372.7 427.3C378.9 433.6 389.1 433.6 395.3 427.3L432 390.6L468.7 427.3C474.9 433.6 485.1 433.6 491.3 427.3C497.6 421.1 497.6 410.9 491.3 404.7L454.6 368L491.3 331.3z\"\n ]\n};\nvar faFingerprint = {\n prefix: 'fas',\n iconName: 'fingerprint',\n icon: [\n 512,\n 512,\n [],\n \"f577\",\n \"M256.1 246c-13.25 0-23.1 10.75-23.1 23.1c1.125 72.25-8.124 141.9-27.75 211.5C201.7 491.3 206.6 512 227.5 512c10.5 0 20.12-6.875 23.12-17.5c13.5-47.87 30.1-125.4 29.5-224.5C280.1 256.8 269.4 246 256.1 246zM255.2 164.3C193.1 164.1 151.2 211.3 152.1 265.4c.75 47.87-3.75 95.87-13.37 142.5c-2.75 12.1 5.624 25.62 18.62 28.37c12.1 2.625 25.62-5.625 28.37-18.62c10.37-50.12 15.12-101.6 14.37-152.1C199.7 238.6 219.1 212.1 254.5 212.3c31.37 .5 57.24 25.37 57.62 55.5c.8749 47.1-2.75 96.25-10.62 143.5c-2.125 12.1 6.749 25.37 19.87 27.62c19.87 3.25 26.75-15.12 27.5-19.87c8.249-49.1 12.12-101.1 11.25-151.1C359.2 211.1 312.2 165.1 255.2 164.3zM144.6 144.5C134.2 136.1 119.2 137.6 110.7 147.9C85.25 179.4 71.38 219.3 72 259.9c.6249 37.62-2.375 75.37-8.999 112.1c-2.375 12.1 6.249 25.5 19.25 27.87c20.12 3.5 27.12-14.87 27.1-19.37c7.124-39.87 10.5-80.62 9.749-121.4C119.6 229.3 129.2 201.3 147.1 178.3C156.4 167.9 154.9 152.9 144.6 144.5zM253.1 82.14C238.6 81.77 223.1 83.52 208.2 87.14c-12.87 2.1-20.87 15.1-17.87 28.87c3.125 12.87 15.1 20.75 28.1 17.75C230.4 131.3 241.7 130 253.4 130.1c75.37 1.125 137.6 61.5 138.9 134.6c.5 37.87-1.375 75.1-5.624 113.6c-1.5 13.12 7.999 24.1 21.12 26.5c16.75 1.1 25.5-11.87 26.5-21.12c4.625-39.75 6.624-79.75 5.999-119.7C438.6 165.3 355.1 83.64 253.1 82.14zM506.1 203.6c-2.875-12.1-15.51-21.25-28.63-18.38c-12.1 2.875-21.12 15.75-18.25 28.62c4.75 21.5 4.875 37.5 4.75 61.62c-.1249 13.25 10.5 24.12 23.75 24.25c13.12 0 24.12-10.62 24.25-23.87C512.1 253.8 512.3 231.8 506.1 203.6zM465.1 112.9c-48.75-69.37-128.4-111.7-213.3-112.9c-69.74-.875-134.2 24.84-182.2 72.96c-46.37 46.37-71.34 108-70.34 173.6l-.125 21.5C-.3651 281.4 10.01 292.4 23.26 292.8C23.51 292.9 23.76 292.9 24.01 292.9c12.1 0 23.62-10.37 23.1-23.37l.125-23.62C47.38 193.4 67.25 144 104.4 106.9c38.87-38.75 91.37-59.62 147.7-58.87c69.37 .1 134.7 35.62 174.6 92.37c7.624 10.87 22.5 13.5 33.37 5.875C470.1 138.6 473.6 123.8 465.1 112.9z\"\n ]\n};\nvar faFire = {\n prefix: 'fas',\n iconName: 'fire',\n icon: [\n 448,\n 512,\n [\n 128293\n ],\n \"f06d\",\n \"M323.5 51.25C302.8 70.5 284 90.75 267.4 111.1C240.1 73.62 206.2 35.5 168 0C69.75 91.12 0 210 0 281.6C0 408.9 100.2 512 224 512s224-103.1 224-230.4C448 228.4 396 118.5 323.5 51.25zM304.1 391.9C282.4 407 255.8 416 226.9 416c-72.13 0-130.9-47.73-130.9-125.2c0-38.63 24.24-72.64 72.74-130.8c7 8 98.88 125.4 98.88 125.4l58.63-66.88c4.125 6.75 7.867 13.52 11.24 19.9C364.9 290.6 353.4 357.4 304.1 391.9z\"\n ]\n};\nvar faFireExtinguisher = {\n prefix: 'fas',\n iconName: 'fire-extinguisher',\n icon: [\n 512,\n 512,\n [\n 129519\n ],\n \"f134\",\n \"M64 480c0 17.67 14.33 32 31.1 32H256c17.67 0 31.1-14.33 31.1-32l-.0001-32H64L64 480zM503.4 5.56c-5.453-4.531-12.61-6.406-19.67-5.188l-175.1 32c-11.41 2.094-19.7 12.03-19.7 23.63L224 56L224 32c0-17.67-14.33-32-31.1-32H160C142.3 0 128 14.33 128 32l.0002 26.81C69.59 69.32 20.5 110.6 1.235 168.4C-2.952 181 3.845 194.6 16.41 198.8C18.94 199.6 21.48 200 24 200c10.05 0 19.42-6.344 22.77-16.41C59.45 145.5 90.47 117.8 128 108L128 139.2C90.27 157.2 64 195.4 64 240L64 416h223.1l.0001-176c0-44.6-26.27-82.79-63.1-100.8L224 104l63.1-.002c0 11.59 8.297 21.53 19.7 23.62l175.1 31.1c1.438 .25 2.875 .375 4.297 .375c5.578 0 11.03-1.938 15.37-5.562c5.469-4.562 8.625-11.31 8.625-18.44V23.1C511.1 16.87 508.8 10.12 503.4 5.56zM176 96C167.2 96 160 88.84 160 80S167.2 64 176 64s15.1 7.164 15.1 16S184.8 96 176 96z\"\n ]\n};\nvar faFireFlameCurved = {\n prefix: 'fas',\n iconName: 'fire-flame-curved',\n icon: [\n 384,\n 512,\n [\n \"fire-alt\"\n ],\n \"f7e4\",\n \"M384 319.1C384 425.9 297.9 512 192 512s-192-86.13-192-192c0-58.67 27.82-106.8 54.57-134.1C69.54 169.3 96 179.8 96 201.5v85.5c0 35.17 27.97 64.5 63.16 64.94C194.9 352.5 224 323.6 224 288c0-88-175.1-96.12-52.15-277.2c13.5-19.72 44.15-10.77 44.15 13.03C215.1 127 384 149.7 384 319.1z\"\n ]\n};\nvar faFireAlt = faFireFlameCurved;\nvar faFireFlameSimple = {\n prefix: 'fas',\n iconName: 'fire-flame-simple',\n icon: [\n 384,\n 512,\n [\n \"burn\"\n ],\n \"f46a\",\n \"M203.1 4.365c-6.177-5.82-16.06-5.819-22.23-.0007C74.52 104.5 0 234.1 0 312C0 437.9 79 512 192 512s192-74.05 192-200C384 233.9 309 104.2 203.1 4.365zM192 432c-56.5 0-96-37.76-96-91.74c0-12.47 4.207-55.32 83.87-143c6.314-6.953 17.95-6.953 24.26 0C283.8 284.9 288 327.8 288 340.3C288 394.2 248.5 432 192 432z\"\n ]\n};\nvar faBurn = faFireFlameSimple;\nvar faFish = {\n prefix: 'fas',\n iconName: 'fish',\n icon: [\n 576,\n 512,\n [\n 128031\n ],\n \"f578\",\n \"M180.5 141.5C219.7 108.5 272.6 80 336 80C399.4 80 452.3 108.5 491.5 141.5C530.5 174.5 558.3 213.1 572.4 241.3C577.2 250.5 577.2 261.5 572.4 270.7C558.3 298 530.5 337.5 491.5 370.5C452.3 403.5 399.4 432 336 432C272.6 432 219.7 403.5 180.5 370.5C164.3 356.7 150 341.9 137.8 327.3L48.12 379.6C35.61 386.9 19.76 384.9 9.474 374.7C-.8133 364.5-2.97 348.7 4.216 336.1L50 256L4.216 175.9C-2.97 163.3-.8133 147.5 9.474 137.3C19.76 127.1 35.61 125.1 48.12 132.4L137.8 184.7C150 170.1 164.3 155.3 180.5 141.5L180.5 141.5zM416 224C398.3 224 384 238.3 384 256C384 273.7 398.3 288 416 288C433.7 288 448 273.7 448 256C448 238.3 433.7 224 416 224z\"\n ]\n};\nvar faFlag = {\n prefix: 'fas',\n iconName: 'flag',\n icon: [\n 512,\n 512,\n [\n 61725,\n 127988\n ],\n \"f024\",\n \"M64 496C64 504.8 56.75 512 48 512h-32C7.25 512 0 504.8 0 496V32c0-17.75 14.25-32 32-32s32 14.25 32 32V496zM476.3 0c-6.365 0-13.01 1.35-19.34 4.233c-45.69 20.86-79.56 27.94-107.8 27.94c-59.96 0-94.81-31.86-163.9-31.87C160.9 .3055 131.6 4.867 96 15.75v350.5c32-9.984 59.87-14.1 84.85-14.1c73.63 0 124.9 31.78 198.6 31.78c31.91 0 68.02-5.971 111.1-23.09C504.1 355.9 512 344.4 512 332.1V30.73C512 11.1 495.3 0 476.3 0z\"\n ]\n};\nvar faFlagCheckered = {\n prefix: 'fas',\n iconName: 'flag-checkered',\n icon: [\n 576,\n 512,\n [\n 127937\n ],\n \"f11e\",\n \"M509.5 .0234c-6.145 0-12.53 1.344-18.64 4.227c-44.11 20.86-76.81 27.94-104.1 27.94c-57.89 0-91.53-31.86-158.2-31.87C195 .3203 153.3 8.324 96 32.38V32c0-17.75-14.25-32-32-32S32 14.25 32 32L31.96 496c0 8.75 7.25 16 16 16H80C88.75 512 96 504.8 96 496V384c51.74-23.86 92.71-31.82 128.3-31.82c71.09 0 120.6 31.78 191.7 31.78c30.81 0 65.67-5.969 108.1-23.09C536.3 355.9 544 344.4 544 332.1V30.74C544 12.01 527.8 .0234 509.5 .0234zM480 141.8c-31.99 14.04-57.81 20.59-80 22.49v80.21c25.44-1.477 51.59-6.953 80-17.34V308.9c-22.83 7.441-43.93 11.08-64.03 11.08c-5.447 0-10.71-.4258-15.97-.8906V244.5c-4.436 .2578-8.893 .6523-13.29 .6523c-25.82 0-47.35-4.547-66.71-10.08v66.91c-23.81-6.055-50.17-11.41-80-12.98V213.1C236.2 213.7 232.5 213.3 228.5 213.3C208.8 213.3 185.1 217.7 160 225.1v69.1C139.2 299.4 117.9 305.8 96 314.4V250.7l24.77-10.39C134.8 234.5 147.6 229.9 160 225.1V143.4C140.9 148.5 120.1 155.2 96 165.3V101.8l24.77-10.39C134.8 85.52 147.6 80.97 160 77.02v66.41c26.39-6.953 49.09-10.17 68.48-10.16c4.072 0 7.676 .4453 11.52 .668V65.03C258.6 66.6 274.4 71.55 293.2 77.83C301.7 80.63 310.7 83.45 320 86.12v66.07c20.79 6.84 41.45 12.96 66.71 12.96c4.207 0 8.781-.4766 13.29-.8594V95.54c25.44-1.477 51.59-6.953 80-17.34V141.8zM240 133.9v80.04c18.61 1.57 34.37 6.523 53.23 12.8C301.7 229.6 310.7 232.4 320 235.1V152.2C296.1 144.3 271.6 135.8 240 133.9z\"\n ]\n};\nvar faFlagUsa = {\n prefix: 'fas',\n iconName: 'flag-usa',\n icon: [\n 576,\n 512,\n [],\n \"f74d\",\n \"M544 61.63V30.74c0-25-28.81-37.99-53.17-26.49C306.3 91.5 321.5-62.25 96 32.38V32c0-17.75-14.25-32-32-32S32 14.25 32 32L31.96 496c0 8.75 7.25 16 15.1 16H80C88.75 512 96 504.8 96 496V384c200-92.25 238.8 53.25 428.1-23.12C536.3 355.9 544 344.4 544 332.1V296.1c-46.98 17.25-86.42 24.12-120.8 24.12c-40.25-.125-74.17-8.5-107.7-16.62C254 288.5 195.3 274.8 96 314.8v-34.5c102-37.63 166.5-22.75 228.4-7.625C385.1 287.8 444.7 301.4 544 261.5V200c-46.98 17.25-86.42 24.12-120.8 24.12c-40.25 0-74.17-8.375-107.7-16.5C254 192.5 195.3 178.8 96 218.8v-34.5c102-37.5 166.5-22.62 228.4-7.5C385.1 191.8 444.7 205.4 544 165.6V96.75c-57.75 23.5-100.4 31.38-135.8 31.38c-62.96 0-118.9-27.09-120.2-27.38V67.5C331.9 78.94 390.1 128.3 544 61.63zM160 136c-8.75 0-16-7.125-16-16s7.25-16 16-16s16 7.125 16 16S168.8 136 160 136zM160 72c-8.75 0-16-7-16-16c0-8.75 7.25-16 16-16s16 7.125 16 16S168.8 72 160 72zM224 128C215.3 128 208 120.9 208 112S215.3 96 224 96s16 7 16 16C240 120.8 232.8 128 224 128zM224 64.25c-8.75 0-16-7-16-16c0-8.75 7.25-16 16-16s16 7.125 16 16S232.8 64.25 224 64.25z\"\n ]\n};\nvar faFlask = {\n prefix: 'fas',\n iconName: 'flask',\n icon: [\n 448,\n 512,\n [],\n \"f0c3\",\n \"M437.2 403.5L319.1 215L319.1 64h7.1c13.25 0 23.1-10.75 23.1-24l-.0002-16c0-13.25-10.75-24-23.1-24H120C106.8 0 96.01 10.75 96.01 24l-.0002 16c0 13.25 10.75 24 23.1 24h7.1L128 215l-117.2 188.5C-18.48 450.6 15.27 512 70.89 512h306.2C432.7 512 466.5 450.5 437.2 403.5zM137.1 320l48.15-77.63C189.8 237.3 191.9 230.8 191.9 224l.0651-160h63.99l-.06 160c0 6.875 2.25 13.25 5.875 18.38L309.9 320H137.1z\"\n ]\n};\nvar faFloppyDisk = {\n prefix: 'fas',\n iconName: 'floppy-disk',\n icon: [\n 448,\n 512,\n [\n 128426,\n 128190,\n \"save\"\n ],\n \"f0c7\",\n \"M433.1 129.1l-83.9-83.9C342.3 38.32 327.1 32 316.1 32H64C28.65 32 0 60.65 0 96v320c0 35.35 28.65 64 64 64h320c35.35 0 64-28.65 64-64V163.9C448 152.9 441.7 137.7 433.1 129.1zM224 416c-35.34 0-64-28.66-64-64s28.66-64 64-64s64 28.66 64 64S259.3 416 224 416zM320 208C320 216.8 312.8 224 304 224h-224C71.16 224 64 216.8 64 208v-96C64 103.2 71.16 96 80 96h224C312.8 96 320 103.2 320 112V208z\"\n ]\n};\nvar faSave = faFloppyDisk;\nvar faFlorinSign = {\n prefix: 'fas',\n iconName: 'florin-sign',\n icon: [\n 384,\n 512,\n [],\n \"e184\",\n \"M352 32C369.7 32 384 46.33 384 64C384 81.67 369.7 96 352 96H314.7C301.7 96 290.1 103.8 285.1 115.7L240 224H320C337.7 224 352 238.3 352 256C352 273.7 337.7 288 320 288H213.3L157.9 420.9C143 456.7 108.1 480 69.33 480H32C14.33 480 0 465.7 0 448C0 430.3 14.33 416 32 416H69.33C82.25 416 93.9 408.2 98.87 396.3L144 288H64C46.33 288 32 273.7 32 256C32 238.3 46.33 224 64 224H170.7L226.1 91.08C240.1 55.3 275.9 32 314.7 32H352z\"\n ]\n};\nvar faFolder = {\n prefix: 'fas',\n iconName: 'folder',\n icon: [\n 512,\n 512,\n [\n 128447,\n 61716,\n 128193\n ],\n \"f07b\",\n \"M464 96h-192l-64-64h-160C21.5 32 0 53.5 0 80V160h512V144C512 117.5 490.5 96 464 96zM0 432C0 458.5 21.5 480 48 480h416c26.5 0 48-21.5 48-48V192H0V432z\"\n ]\n};\nvar faFolderMinus = {\n prefix: 'fas',\n iconName: 'folder-minus',\n icon: [\n 512,\n 512,\n [],\n \"f65d\",\n \"M464 96h-192l-64-64h-160C21.5 32 0 53.5 0 80v352C0 458.5 21.5 480 48 480h416c26.5 0 48-21.5 48-48v-288C512 117.5 490.5 96 464 96zM336 311.1H175.1C162.7 311.1 152 301.3 152 288c0-13.26 10.74-23.1 23.1-23.1h160C349.3 264 360 274.7 360 288S349.3 311.1 336 311.1z\"\n ]\n};\nvar faFolderOpen = {\n prefix: 'fas',\n iconName: 'folder-open',\n icon: [\n 576,\n 512,\n [\n 128449,\n 61717,\n 128194\n ],\n \"f07c\",\n \"M147.8 192H480V144C480 117.5 458.5 96 432 96h-160l-64-64h-160C21.49 32 0 53.49 0 80v328.4l90.54-181.1C101.4 205.6 123.4 192 147.8 192zM543.1 224H147.8C135.7 224 124.6 230.8 119.2 241.7L0 480h447.1c12.12 0 23.2-6.852 28.62-17.69l96-192C583.2 249 567.7 224 543.1 224z\"\n ]\n};\nvar faFolderPlus = {\n prefix: 'fas',\n iconName: 'folder-plus',\n icon: [\n 512,\n 512,\n [],\n \"f65e\",\n \"M464 96h-192l-64-64h-160C21.5 32 0 53.5 0 80v352C0 458.5 21.5 480 48 480h416c26.5 0 48-21.5 48-48v-288C512 117.5 490.5 96 464 96zM336 311.1h-56v56C279.1 381.3 269.3 392 256 392c-13.27 0-23.1-10.74-23.1-23.1V311.1H175.1C162.7 311.1 152 301.3 152 288c0-13.26 10.74-23.1 23.1-23.1h56V207.1C232 194.7 242.7 184 256 184s23.1 10.74 23.1 23.1V264h56C349.3 264 360 274.7 360 288S349.3 311.1 336 311.1z\"\n ]\n};\nvar faFolderTree = {\n prefix: 'fas',\n iconName: 'folder-tree',\n icon: [\n 576,\n 512,\n [],\n \"f802\",\n \"M544 32h-112l-32-32H320c-17.62 0-32 14.38-32 32v160c0 17.62 14.38 32 32 32h224c17.62 0 32-14.38 32-32V64C576 46.38 561.6 32 544 32zM544 320h-112l-32-32H320c-17.62 0-32 14.38-32 32v160c0 17.62 14.38 32 32 32h224c17.62 0 32-14.38 32-32v-128C576 334.4 561.6 320 544 320zM64 16C64 7.125 56.88 0 48 0h-32C7.125 0 0 7.125 0 16V416c0 17.62 14.38 32 32 32h224v-64H64V160h192V96H64V16z\"\n ]\n};\nvar faFont = {\n prefix: 'fas',\n iconName: 'font',\n icon: [\n 448,\n 512,\n [],\n \"f031\",\n \"M416 416h-25.81L253.1 52.76c-4.688-12.47-16.57-20.76-29.91-20.76s-25.34 8.289-30.02 20.76L57.81 416H32c-17.67 0-32 14.31-32 32s14.33 32 32 32h96c17.67 0 32-14.31 32-32s-14.33-32-32-32H126.2l17.1-48h159.6l17.1 48H320c-17.67 0-32 14.31-32 32s14.33 32 32 32h96c17.67 0 32-14.31 32-32S433.7 416 416 416zM168.2 304L224 155.1l55.82 148.9H168.2z\"\n ]\n};\nvar faFontAwesome = {\n prefix: 'fas',\n iconName: 'font-awesome',\n icon: [\n 448,\n 512,\n [\n 62694,\n \"font-awesome-flag\",\n \"font-awesome-logo-full\"\n ],\n \"f2b4\",\n \"M448 48V384c-63.09 22.54-82.34 32-119.5 32c-62.82 0-86.6-32-149.3-32C158.6 384 142.6 387.6 128 392.2v-64C142.6 323.6 158.6 320 179.2 320c62.73 0 86.51 32 149.3 32C348.9 352 364.1 349 384 342.7v-208C364.1 141 348.9 144 328.5 144c-62.82 0-86.6-32-149.3-32C128.4 112 104.3 132.6 64 140.7v307.3C64 465.7 49.67 480 32 480S0 465.7 0 448V63.1C0 46.33 14.33 32 31.1 32S64 46.33 64 63.1V76.66C104.3 68.63 128.4 48 179.2 48c62.73 0 86.51 32 149.3 32C365.7 80 384.9 70.54 448 48z\"\n ]\n};\nvar faFontAwesomeFlag = faFontAwesome;\nvar faFontAwesomeLogoFull = faFontAwesome;\nvar faFootball = {\n prefix: 'fas',\n iconName: 'football',\n icon: [\n 512,\n 512,\n [\n 127944,\n \"football-ball\"\n ],\n \"f44e\",\n \"M16.17 337.5c0 44.98 7.565 83.54 13.98 107.9C35.22 464.3 50.46 496 174.9 496c9.566 0 19.59-.4707 29.84-1.271L17.33 307.3C16.53 317.6 16.17 327.7 16.17 337.5zM495.8 174.5c0-44.98-7.565-83.53-13.98-107.9c-4.688-17.54-18.34-31.23-36.04-35.95C435.5 27.91 392.9 16 337 16c-9.564 0-19.59 .4707-29.84 1.271l187.5 187.5C495.5 194.4 495.8 184.3 495.8 174.5zM26.77 248.8l236.3 236.3c142-36.1 203.9-150.4 222.2-221.1L248.9 26.87C106.9 62.96 45.07 177.2 26.77 248.8zM256 335.1c0 9.141-7.474 16-16 16c-4.094 0-8.188-1.564-11.31-4.689L164.7 283.3C161.6 280.2 160 276.1 160 271.1c0-8.529 6.865-16 16-16c4.095 0 8.189 1.562 11.31 4.688l64.01 64C254.4 327.8 256 331.9 256 335.1zM304 287.1c0 9.141-7.474 16-16 16c-4.094 0-8.188-1.564-11.31-4.689L212.7 235.3C209.6 232.2 208 228.1 208 223.1c0-9.141 7.473-16 16-16c4.094 0 8.188 1.562 11.31 4.688l64.01 64.01C302.5 279.8 304 283.9 304 287.1zM256 175.1c0-9.141 7.473-16 16-16c4.094 0 8.188 1.562 11.31 4.688l64.01 64.01c3.125 3.125 4.688 7.219 4.688 11.31c0 9.133-7.468 16-16 16c-4.094 0-8.189-1.562-11.31-4.688l-64.01-64.01C257.6 184.2 256 180.1 256 175.1z\"\n ]\n};\nvar faFootballBall = faFootball;\nvar faForward = {\n prefix: 'fas',\n iconName: 'forward',\n icon: [\n 512,\n 512,\n [\n 9193\n ],\n \"f04e\",\n \"M52.51 440.6l171.5-142.9V214.3L52.51 71.41C31.88 54.28 0 68.66 0 96.03v319.9C0 443.3 31.88 457.7 52.51 440.6zM308.5 440.6l192-159.1c15.25-12.87 15.25-36.37 0-49.24l-192-159.1c-20.63-17.12-52.51-2.749-52.51 24.62v319.9C256 443.3 287.9 457.7 308.5 440.6z\"\n ]\n};\nvar faForwardFast = {\n prefix: 'fas',\n iconName: 'forward-fast',\n icon: [\n 512,\n 512,\n [\n 9197,\n \"fast-forward\"\n ],\n \"f050\",\n \"M512 96.03v319.9c0 17.67-14.33 31.1-31.1 31.1C462.3 447.1 448 433.6 448 415.1V284.1l-171.5 156.5C255.9 457.7 224 443.3 224 415.1V284.1l-171.5 156.5C31.88 457.7 0 443.3 0 415.1V96.03c0-27.37 31.88-41.74 52.5-24.62L224 226.8V96.03c0-27.37 31.88-41.74 52.5-24.62L448 226.8V96.03c0-17.67 14.33-31.1 31.1-31.1C497.7 64.03 512 78.36 512 96.03z\"\n ]\n};\nvar faFastForward = faForwardFast;\nvar faForwardStep = {\n prefix: 'fas',\n iconName: 'forward-step',\n icon: [\n 320,\n 512,\n [\n \"step-forward\"\n ],\n \"f051\",\n \"M287.1 447.1c17.67 0 31.1-14.33 31.1-32V96.03c0-17.67-14.33-32-32-32c-17.67 0-31.1 14.33-31.1 31.1v319.9C255.1 433.6 270.3 447.1 287.1 447.1zM52.51 440.6l192-159.1c7.625-6.436 11.43-15.53 11.43-24.62c0-9.094-3.809-18.18-11.43-24.62l-192-159.1C31.88 54.28 0 68.66 0 96.03v319.9C0 443.3 31.88 457.7 52.51 440.6z\"\n ]\n};\nvar faStepForward = faForwardStep;\nvar faFrancSign = {\n prefix: 'fas',\n iconName: 'franc-sign',\n icon: [\n 320,\n 512,\n [],\n \"e18f\",\n \"M288 32C305.7 32 320 46.33 320 64C320 81.67 305.7 96 288 96H112V192H256C273.7 192 288 206.3 288 224C288 241.7 273.7 256 256 256H112V320H192C209.7 320 224 334.3 224 352C224 369.7 209.7 384 192 384H112V448C112 465.7 97.67 480 80 480C62.33 480 48 465.7 48 448V384H32C14.33 384 0 369.7 0 352C0 334.3 14.33 320 32 320H48V64C48 46.33 62.33 32 80 32H288z\"\n ]\n};\nvar faFrog = {\n prefix: 'fas',\n iconName: 'frog',\n icon: [\n 576,\n 512,\n [],\n \"f52e\",\n \"M528 416h-32.07l-90.32-96.34l140.6-79.03c18.38-10.25 29.75-29.62 29.75-50.62c0-21.5-11.75-41-30.5-51.25c-40.5-22.25-99.07-41.43-99.07-41.43C439.6 60.19 407.3 32 368 32s-71.77 28.25-78.52 65.5C126.7 113-.4999 250.1 .0001 417C.1251 451.9 29.13 480 64 480h304c8.875 0 16-7.125 16-16c0-26.51-21.49-48-47.1-48H284.3l23.93-32.38c24.25-36.13 10.38-88.25-33.63-106.5C250.8 267.1 223 272.4 202.4 288L169.6 312.5c-7.125 5.375-17.12 4-22.38-3.125c-5.375-7.125-4-17.12 3.125-22.38l34.75-26.12c36.87-27.62 88.37-27.62 125.1 0c10.88 8.125 45.88 39 40.88 93.13L469.6 480h90.38c8.875 0 16-7.125 16-16C576 437.5 554.5 416 528 416zM344 112c0-13.25 10.75-24 24-24s24 10.75 24 24s-10.75 24-24 24S344 125.3 344 112z\"\n ]\n};\nvar faFutbol = {\n prefix: 'fas',\n iconName: 'futbol',\n icon: [\n 512,\n 512,\n [\n 9917,\n \"futbol-ball\",\n \"soccer-ball\"\n ],\n \"f1e3\",\n \"M177.1 228.6L207.9 320h96.5l29.62-91.38L256 172.1L177.1 228.6zM255.1 0C114.6 0 .0001 114.6 .0001 256S114.6 512 256 512s255.1-114.6 255.1-255.1S397.4 0 255.1 0zM416.6 360.9l-85.4-1.297l-25.15 81.59C290.1 445.5 273.4 448 256 448s-34.09-2.523-50.09-6.859L180.8 359.6l-85.4 1.297c-18.12-27.66-29.15-60.27-30.88-95.31L134.3 216.4L106.6 135.6c21.16-26.21 49.09-46.61 81.06-58.84L256 128l68.29-51.22c31.98 12.23 59.9 32.64 81.06 58.84L377.7 216.4l69.78 49.1C445.8 300.6 434.8 333.2 416.6 360.9z\"\n ]\n};\nvar faFutbolBall = faFutbol;\nvar faSoccerBall = faFutbol;\nvar faG = {\n prefix: 'fas',\n iconName: 'g',\n icon: [\n 448,\n 512,\n [\n 103\n ],\n \"47\",\n \"M448 256c0 143.4-118.6 222.3-225 222.3c-132.3 0-222.1-106.2-222.1-222.4c0-124.4 100.9-223.9 223.1-223.9c84.84 0 167.8 55.28 167.8 88.2c0 18.28-14.95 32-32 32c-31.04 0-46.79-56.16-135.8-56.16c-87.66 0-159.1 70.66-159.1 159.8c0 34.81 27.19 158.8 159.1 158.8c79.45 0 144.6-55.1 158.1-126.7h-134.1c-17.67 0-32-14.33-32-32s14.33-31.1 32-31.1H416C433.7 224 448 238.3 448 256z\"\n ]\n};\nvar faGamepad = {\n prefix: 'fas',\n iconName: 'gamepad',\n icon: [\n 640,\n 512,\n [],\n \"f11b\",\n \"M448 64H192C85.96 64 0 149.1 0 256s85.96 192 192 192h256c106 0 192-85.96 192-192S554 64 448 64zM247.1 280h-32v32c0 13.2-10.78 24-23.98 24c-13.2 0-24.02-10.8-24.02-24v-32L136 279.1C122.8 279.1 111.1 269.2 111.1 256c0-13.2 10.85-24.01 24.05-24.01L167.1 232v-32c0-13.2 10.82-24 24.02-24c13.2 0 23.98 10.8 23.98 24v32h32c13.2 0 24.02 10.8 24.02 24C271.1 269.2 261.2 280 247.1 280zM431.1 344c-22.12 0-39.1-17.87-39.1-39.1s17.87-40 39.1-40s39.1 17.88 39.1 40S454.1 344 431.1 344zM495.1 248c-22.12 0-39.1-17.87-39.1-39.1s17.87-40 39.1-40c22.12 0 39.1 17.88 39.1 40S518.1 248 495.1 248z\"\n ]\n};\nvar faGasPump = {\n prefix: 'fas',\n iconName: 'gas-pump',\n icon: [\n 512,\n 512,\n [\n 9981\n ],\n \"f52f\",\n \"M32 64C32 28.65 60.65 0 96 0H256C291.3 0 320 28.65 320 64V256H328C376.6 256 416 295.4 416 344V376C416 389.3 426.7 400 440 400C453.3 400 464 389.3 464 376V221.1C436.4 214.9 416 189.8 416 160V96L384 64C375.2 55.16 375.2 40.84 384 32C392.8 23.16 407.2 23.16 416 32L493.3 109.3C505.3 121.3 512 137.5 512 154.5V376C512 415.8 479.8 448 440 448C400.2 448 368 415.8 368 376V344C368 321.9 350.1 303.1 328 303.1H320V448C337.7 448 352 462.3 352 480C352 497.7 337.7 512 320 512H32C14.33 512 0 497.7 0 480C0 462.3 14.33 448 32 448V64zM96 176C96 184.8 103.2 192 112 192H240C248.8 192 256 184.8 256 176V80C256 71.16 248.8 64 240 64H112C103.2 64 96 71.16 96 80V176z\"\n ]\n};\nvar faGauge = {\n prefix: 'fas',\n iconName: 'gauge',\n icon: [\n 512,\n 512,\n [\n \"dashboard\",\n \"gauge-med\",\n \"tachometer-alt-average\"\n ],\n \"f624\",\n \"M512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM280 292.7V88C280 74.75 269.3 64 256 64C242.7 64 232 74.75 232 88V292.7C208.5 302.1 192 325.1 192 352C192 387.3 220.7 416 256 416C291.3 416 320 387.3 320 352C320 325.1 303.5 302.1 280 292.7zM144 176C161.7 176 176 161.7 176 144C176 126.3 161.7 112 144 112C126.3 112 112 126.3 112 144C112 161.7 126.3 176 144 176zM96 224C78.33 224 64 238.3 64 256C64 273.7 78.33 288 96 288C113.7 288 128 273.7 128 256C128 238.3 113.7 224 96 224zM416 288C433.7 288 448 273.7 448 256C448 238.3 433.7 224 416 224C398.3 224 384 238.3 384 256C384 273.7 398.3 288 416 288zM368 112C350.3 112 336 126.3 336 144C336 161.7 350.3 176 368 176C385.7 176 400 161.7 400 144C400 126.3 385.7 112 368 112z\"\n ]\n};\nvar faDashboard = faGauge;\nvar faGaugeMed = faGauge;\nvar faTachometerAltAverage = faGauge;\nvar faGaugeHigh = {\n prefix: 'fas',\n iconName: 'gauge-high',\n icon: [\n 512,\n 512,\n [\n 62461,\n \"tachometer-alt\",\n \"tachometer-alt-fast\"\n ],\n \"f625\",\n \"M512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM256 64C238.3 64 224 78.33 224 96C224 113.7 238.3 128 256 128C273.7 128 288 113.7 288 96C288 78.33 273.7 64 256 64zM256 416C291.3 416 320 387.3 320 352C320 334.6 313.1 318.9 301.9 307.4L365.1 161.7C371.3 149.5 365.8 135.4 353.7 130C341.5 124.7 327.4 130.2 322 142.3L257.9 288C257.3 288 256.6 287.1 256 287.1C220.7 287.1 192 316.7 192 352C192 387.3 220.7 416 256 416V416zM144 112C126.3 112 112 126.3 112 144C112 161.7 126.3 176 144 176C161.7 176 176 161.7 176 144C176 126.3 161.7 112 144 112zM96 288C113.7 288 128 273.7 128 256C128 238.3 113.7 224 96 224C78.33 224 64 238.3 64 256C64 273.7 78.33 288 96 288zM416 224C398.3 224 384 238.3 384 256C384 273.7 398.3 288 416 288C433.7 288 448 273.7 448 256C448 238.3 433.7 224 416 224z\"\n ]\n};\nvar faTachometerAlt = faGaugeHigh;\nvar faTachometerAltFast = faGaugeHigh;\nvar faGaugeSimple = {\n prefix: 'fas',\n iconName: 'gauge-simple',\n icon: [\n 512,\n 512,\n [\n \"gauge-simple-med\",\n \"tachometer-average\"\n ],\n \"f629\",\n \"M512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM280 292.7V88C280 74.75 269.3 64 256 64C242.7 64 232 74.75 232 88V292.7C208.5 302.1 192 325.1 192 352C192 387.3 220.7 416 256 416C291.3 416 320 387.3 320 352C320 325.1 303.5 302.1 280 292.7z\"\n ]\n};\nvar faGaugeSimpleMed = faGaugeSimple;\nvar faTachometerAverage = faGaugeSimple;\nvar faGaugeSimpleHigh = {\n prefix: 'fas',\n iconName: 'gauge-simple-high',\n icon: [\n 512,\n 512,\n [\n 61668,\n \"tachometer\",\n \"tachometer-fast\"\n ],\n \"f62a\",\n \"M512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM304.7 310.4L381.3 163.1C387.4 151.3 382.8 136.8 371.1 130.7C359.3 124.6 344.8 129.2 338.7 140.9L262.1 288.3C260.1 288.1 258.1 287.1 255.1 287.1C220.7 287.1 191.1 316.7 191.1 352C191.1 387.3 220.7 416 255.1 416C291.3 416 320 387.3 320 352C320 336.1 314.2 321.6 304.7 310.4L304.7 310.4z\"\n ]\n};\nvar faTachometer = faGaugeSimpleHigh;\nvar faTachometerFast = faGaugeSimpleHigh;\nvar faGavel = {\n prefix: 'fas',\n iconName: 'gavel',\n icon: [\n 512,\n 512,\n [\n \"legal\"\n ],\n \"f0e3\",\n \"M512 216.3c0-6.125-2.344-12.25-7.031-16.93L482.3 176.8c-4.688-4.686-10.84-7.028-16.1-7.028s-12.31 2.343-16.1 7.028l-5.625 5.625L329.6 69.28l5.625-5.625c4.687-4.688 7.03-10.84 7.03-16.1s-2.343-12.31-7.03-16.1l-22.62-22.62C307.9 2.344 301.8 0 295.7 0s-12.15 2.344-16.84 7.031L154.2 131.5C149.6 136.2 147.2 142.3 147.2 148.5s2.344 12.25 7.031 16.94l22.62 22.62c4.688 4.688 10.84 7.031 16.1 7.031c6.156 0 12.31-2.344 16.1-7.031l5.625-5.625l113.1 113.1l-5.625 5.621c-4.688 4.688-7.031 10.84-7.031 16.1s2.344 12.31 7.031 16.1l22.62 22.62c4.688 4.688 10.81 7.031 16.94 7.031s12.25-2.344 16.94-7.031l124.5-124.6C509.7 228.5 512 222.5 512 216.3zM227.8 238.1L169.4 297.4C163.1 291.1 154.9 288 146.7 288S130.4 291.1 124.1 297.4l-114.7 114.7c-6.25 6.248-9.375 14.43-9.375 22.62s3.125 16.37 9.375 22.62l45.25 45.25C60.87 508.9 69.06 512 77.25 512s16.37-3.125 22.62-9.375l114.7-114.7c6.25-6.25 9.376-14.44 9.376-22.62c0-8.185-3.125-16.37-9.374-22.62l58.43-58.43L227.8 238.1z\"\n ]\n};\nvar faLegal = faGavel;\nvar faGear = {\n prefix: 'fas',\n iconName: 'gear',\n icon: [\n 512,\n 512,\n [\n 9881,\n \"cog\"\n ],\n \"f013\",\n \"M495.9 166.6C499.2 175.2 496.4 184.9 489.6 191.2L446.3 230.6C447.4 238.9 448 247.4 448 256C448 264.6 447.4 273.1 446.3 281.4L489.6 320.8C496.4 327.1 499.2 336.8 495.9 345.4C491.5 357.3 486.2 368.8 480.2 379.7L475.5 387.8C468.9 398.8 461.5 409.2 453.4 419.1C447.4 426.2 437.7 428.7 428.9 425.9L373.2 408.1C359.8 418.4 344.1 427 329.2 433.6L316.7 490.7C314.7 499.7 307.7 506.1 298.5 508.5C284.7 510.8 270.5 512 255.1 512C241.5 512 227.3 510.8 213.5 508.5C204.3 506.1 197.3 499.7 195.3 490.7L182.8 433.6C167 427 152.2 418.4 138.8 408.1L83.14 425.9C74.3 428.7 64.55 426.2 58.63 419.1C50.52 409.2 43.12 398.8 36.52 387.8L31.84 379.7C25.77 368.8 20.49 357.3 16.06 345.4C12.82 336.8 15.55 327.1 22.41 320.8L65.67 281.4C64.57 273.1 64 264.6 64 256C64 247.4 64.57 238.9 65.67 230.6L22.41 191.2C15.55 184.9 12.82 175.3 16.06 166.6C20.49 154.7 25.78 143.2 31.84 132.3L36.51 124.2C43.12 113.2 50.52 102.8 58.63 92.95C64.55 85.8 74.3 83.32 83.14 86.14L138.8 103.9C152.2 93.56 167 84.96 182.8 78.43L195.3 21.33C197.3 12.25 204.3 5.04 213.5 3.51C227.3 1.201 241.5 0 256 0C270.5 0 284.7 1.201 298.5 3.51C307.7 5.04 314.7 12.25 316.7 21.33L329.2 78.43C344.1 84.96 359.8 93.56 373.2 103.9L428.9 86.14C437.7 83.32 447.4 85.8 453.4 92.95C461.5 102.8 468.9 113.2 475.5 124.2L480.2 132.3C486.2 143.2 491.5 154.7 495.9 166.6V166.6zM256 336C300.2 336 336 300.2 336 255.1C336 211.8 300.2 175.1 256 175.1C211.8 175.1 176 211.8 176 255.1C176 300.2 211.8 336 256 336z\"\n ]\n};\nvar faCog = faGear;\nvar faGears = {\n prefix: 'fas',\n iconName: 'gears',\n icon: [\n 640,\n 512,\n [\n \"cogs\"\n ],\n \"f085\",\n \"M286.3 155.1C287.4 161.9 288 168.9 288 175.1C288 183.1 287.4 190.1 286.3 196.9L308.5 216.7C315.5 223 318.4 232.1 314.7 241.7C312.4 246.1 309.9 252.2 307.1 257.2L304 262.6C300.1 267.6 297.7 272.4 294.2 277.1C288.5 284.7 278.5 287.2 269.5 284.2L241.2 274.9C230.5 283.8 218.3 290.9 205 295.9L198.1 324.9C197 334.2 189.8 341.6 180.4 342.8C173.7 343.6 166.9 344 160 344C153.1 344 146.3 343.6 139.6 342.8C130.2 341.6 122.1 334.2 121 324.9L114.1 295.9C101.7 290.9 89.5 283.8 78.75 274.9L50.53 284.2C41.54 287.2 31.52 284.7 25.82 277.1C22.28 272.4 18.98 267.5 15.94 262.5L12.92 257.2C10.13 252.2 7.592 247 5.324 241.7C1.62 232.1 4.458 223 11.52 216.7L33.7 196.9C32.58 190.1 31.1 183.1 31.1 175.1C31.1 168.9 32.58 161.9 33.7 155.1L11.52 135.3C4.458 128.1 1.62 119 5.324 110.3C7.592 104.1 10.13 99.79 12.91 94.76L15.95 89.51C18.98 84.46 22.28 79.58 25.82 74.89C31.52 67.34 41.54 64.83 50.53 67.79L78.75 77.09C89.5 68.25 101.7 61.13 114.1 56.15L121 27.08C122.1 17.8 130.2 10.37 139.6 9.231C146.3 8.418 153.1 8 160 8C166.9 8 173.7 8.418 180.4 9.23C189.8 10.37 197 17.8 198.1 27.08L205 56.15C218.3 61.13 230.5 68.25 241.2 77.09L269.5 67.79C278.5 64.83 288.5 67.34 294.2 74.89C297.7 79.56 300.1 84.42 304 89.44L307.1 94.83C309.9 99.84 312.4 105 314.7 110.3C318.4 119 315.5 128.1 308.5 135.3L286.3 155.1zM160 127.1C133.5 127.1 112 149.5 112 175.1C112 202.5 133.5 223.1 160 223.1C186.5 223.1 208 202.5 208 175.1C208 149.5 186.5 127.1 160 127.1zM484.9 478.3C478.1 479.4 471.1 480 464 480C456.9 480 449.9 479.4 443.1 478.3L423.3 500.5C416.1 507.5 407 510.4 398.3 506.7C393 504.4 387.8 501.9 382.8 499.1L377.4 496C372.4 492.1 367.6 489.7 362.9 486.2C355.3 480.5 352.8 470.5 355.8 461.5L365.1 433.2C356.2 422.5 349.1 410.3 344.1 397L315.1 390.1C305.8 389 298.4 381.8 297.2 372.4C296.4 365.7 296 358.9 296 352C296 345.1 296.4 338.3 297.2 331.6C298.4 322.2 305.8 314.1 315.1 313L344.1 306.1C349.1 293.7 356.2 281.5 365.1 270.8L355.8 242.5C352.8 233.5 355.3 223.5 362.9 217.8C367.6 214.3 372.5 210.1 377.5 207.9L382.8 204.9C387.8 202.1 392.1 199.6 398.3 197.3C407 193.6 416.1 196.5 423.3 203.5L443.1 225.7C449.9 224.6 456.9 224 464 224C471.1 224 478.1 224.6 484.9 225.7L504.7 203.5C511 196.5 520.1 193.6 529.7 197.3C535 199.6 540.2 202.1 545.2 204.9L550.5 207.9C555.5 210.1 560.4 214.3 565.1 217.8C572.7 223.5 575.2 233.5 572.2 242.5L562.9 270.8C571.8 281.5 578.9 293.7 583.9 306.1L612.9 313C622.2 314.1 629.6 322.2 630.8 331.6C631.6 338.3 632 345.1 632 352C632 358.9 631.6 365.7 630.8 372.4C629.6 381.8 622.2 389 612.9 390.1L583.9 397C578.9 410.3 571.8 422.5 562.9 433.2L572.2 461.5C575.2 470.5 572.7 480.5 565.1 486.2C560.4 489.7 555.6 492.1 550.6 496L545.2 499.1C540.2 501.9 534.1 504.4 529.7 506.7C520.1 510.4 511 507.5 504.7 500.5L484.9 478.3zM512 352C512 325.5 490.5 304 464 304C437.5 304 416 325.5 416 352C416 378.5 437.5 400 464 400C490.5 400 512 378.5 512 352z\"\n ]\n};\nvar faCogs = faGears;\nvar faGem = {\n prefix: 'fas',\n iconName: 'gem',\n icon: [\n 512,\n 512,\n [\n 128142\n ],\n \"f3a5\",\n \"M378.7 32H133.3L256 182.7L378.7 32zM512 192l-107.4-141.3L289.6 192H512zM107.4 50.67L0 192h222.4L107.4 50.67zM244.3 474.9C247.3 478.2 251.6 480 256 480s8.653-1.828 11.67-5.062L510.6 224H1.365L244.3 474.9z\"\n ]\n};\nvar faGenderless = {\n prefix: 'fas',\n iconName: 'genderless',\n icon: [\n 384,\n 512,\n [],\n \"f22d\",\n \"M192 80C94.83 80 16 158.8 16 256c0 97.17 78.83 176 176 176s176-78.83 176-176C368 158.8 289.2 80 192 80zM192 352c-52.95 0-96-43.05-96-96c0-52.95 43.05-96 96-96s96 43.05 96 96C288 308.9 244.1 352 192 352z\"\n ]\n};\nvar faGhost = {\n prefix: 'fas',\n iconName: 'ghost',\n icon: [\n 384,\n 512,\n [\n 128123\n ],\n \"f6e2\",\n \"M186.1 .1032c-105.1 3.126-186.1 94.75-186.1 199.9v264c0 14.25 17.3 21.38 27.3 11.25l24.95-18.5c6.625-5.001 16-4.001 21.5 2.25l43 48.31c6.25 6.251 16.37 6.251 22.62 0l40.62-45.81c6.375-7.251 17.62-7.251 24 0l40.63 45.81c6.25 6.251 16.38 6.251 22.62 0l43-48.31c5.5-6.251 14.88-7.251 21.5-2.25l24.95 18.5c10 10.13 27.3 3.002 27.3-11.25V192C384 83.98 294.9-3.147 186.1 .1032zM128 224c-17.62 0-31.1-14.38-31.1-32.01s14.38-32.01 31.1-32.01s32 14.38 32 32.01S145.6 224 128 224zM256 224c-17.62 0-32-14.38-32-32.01s14.38-32.01 32-32.01c17.62 0 32 14.38 32 32.01S273.6 224 256 224z\"\n ]\n};\nvar faGift = {\n prefix: 'fas',\n iconName: 'gift',\n icon: [\n 512,\n 512,\n [\n 127873\n ],\n \"f06b\",\n \"M152 0H154.2C186.1 0 215.7 16.91 231.9 44.45L256 85.46L280.1 44.45C296.3 16.91 325.9 0 357.8 0H360C408.6 0 448 39.4 448 88C448 102.4 444.5 115.1 438.4 128H480C497.7 128 512 142.3 512 160V224C512 241.7 497.7 256 480 256H32C14.33 256 0 241.7 0 224V160C0 142.3 14.33 128 32 128H73.6C67.46 115.1 64 102.4 64 88C64 39.4 103.4 0 152 0zM190.5 68.78C182.9 55.91 169.1 48 154.2 48H152C129.9 48 112 65.91 112 88C112 110.1 129.9 128 152 128H225.3L190.5 68.78zM360 48H357.8C342.9 48 329.1 55.91 321.5 68.78L286.7 128H360C382.1 128 400 110.1 400 88C400 65.91 382.1 48 360 48V48zM32 288H224V512H80C53.49 512 32 490.5 32 464V288zM288 512V288H480V464C480 490.5 458.5 512 432 512H288z\"\n ]\n};\nvar faGifts = {\n prefix: 'fas',\n iconName: 'gifts',\n icon: [\n 640,\n 512,\n [],\n \"f79c\",\n \"M192.5 55.09L217.9 36.59C228.6 28.79 243.6 31.16 251.4 41.88C259.2 52.6 256.8 67.61 246.1 75.41L217.8 95.1H240C256.9 95.1 271.7 104.7 280.3 117.9C257.3 135.7 241.9 162.1 240.2 193.1C212.5 201 192 226.1 192 256V480C192 491.7 195.1 502.6 200.6 512H48C21.49 512 0 490.5 0 464V144C0 117.5 21.49 96 48 96H70.2L41.88 75.41C31.16 67.61 28.79 52.6 36.59 41.88C44.39 31.16 59.4 28.79 70.12 36.59L97.55 56.54L89.23 31.59C85.04 19.01 91.84 5.423 104.4 1.232C116.1-2.96 130.6 3.836 134.8 16.41L144.7 46.17L155.4 15.99C159.8 3.493 173.5-3.048 186 1.377C198.5 5.802 205 19.52 200.6 32.01L192.5 55.09zM344.2 127.1C366.6 127.1 387.8 138.4 401.5 156.2L432 195.8L462.5 156.2C476.2 138.4 497.4 127.1 519.8 127.1C559.5 127.1 592 160.1 592 199.1C592 208.4 590.6 216.5 587.9 223.1H592C618.5 223.1 640 245.5 640 271.1V352H448V255.1H416V352H224V271.1C224 245.5 245.5 223.1 272 223.1H276.1C273.4 216.5 272 208.4 272 199.1C272 160.1 304.5 127.1 344.2 127.1H344.2zM363.5 185.5C358.9 179.5 351.7 175.1 344.2 175.1C330.8 175.1 320 186.9 320 199.1C320 213.3 330.7 223.1 344 223.1H393.1L363.5 185.5zM519.8 175.1C512.3 175.1 505.1 179.5 500.5 185.5L470.9 223.1H520C533.3 223.1 544 213.3 544 199.1C544 186.9 533.2 175.1 519.8 175.1H519.8zM224 464V384H416V512H272C245.5 512 224 490.5 224 464zM448 512V384H640V464C640 490.5 618.5 512 592 512H448z\"\n ]\n};\nvar faGlasses = {\n prefix: 'fas',\n iconName: 'glasses',\n icon: [\n 576,\n 512,\n [],\n \"f530\",\n \"M574.1 280.4l-45.38-181.8c-5.875-23.63-21.62-44-43-55.75c-21.5-11.75-46.1-14.13-70.25-6.375l-15.25 5.125c-8.375 2.75-12.87 11.88-10 20.25l5 15.13c2.75 8.375 11.88 12.88 20.25 10.13l13.12-4.375c10.88-3.625 23-3.625 33.25 1.75c10.25 5.375 17.5 14.5 20.38 25.75l38.38 153.9c-22.12-6.875-49.75-12.5-81.13-12.5c-34.88 0-73.1 7-114.9 26.75H251.4C210.5 258.6 171.4 251.6 136.5 251.6c-31.38 0-59 5.625-81.12 12.5l38.38-153.9c2.875-11.25 10.12-20.38 20.5-25.75C124.4 79.12 136.5 79.12 147.4 82.74l13.12 4.375c8.375 2.75 17.5-1.75 20.25-10.13l5-15.13C188.6 53.49 184.1 44.37 175.6 41.62l-15.25-5.125c-23.13-7.75-48.75-5.375-70.13 6.375c-21.37 11.75-37.12 32.13-43 55.75L1.875 280.4C.6251 285.4 .0001 290.6 .0001 295.9v70.25C.0001 428.1 51.63 480 115.3 480h37.13c60.25 0 110.4-46 114.9-105.4l2.875-38.63h35.75l2.875 38.63C313.3 433.1 363.4 480 423.6 480h37.13c63.62 0 115.2-51 115.2-113.9V295.9C576 290.6 575.4 285.5 574.1 280.4zM203.4 369.7c-2 26-24.38 46.25-51 46.25H115.2C87 415.1 64 393.6 64 366.1v-37.5c18.12-6.5 43.38-13 72.62-13c23.88 0 47.25 4.375 69.88 13L203.4 369.7zM512 366.1c0 27.5-23 49.88-51.25 49.88h-37.13c-26.62 0-49-20.25-51-46.25l-3.125-41.13c22.62-8.625 46.13-13 70-13c29 0 54.38 6.5 72.5 13V366.1z\"\n ]\n};\nvar faGlobe = {\n prefix: 'fas',\n iconName: 'globe',\n icon: [\n 512,\n 512,\n [\n 127760\n ],\n \"f0ac\",\n \"M352 256C352 278.2 350.8 299.6 348.7 320H163.3C161.2 299.6 159.1 278.2 159.1 256C159.1 233.8 161.2 212.4 163.3 192H348.7C350.8 212.4 352 233.8 352 256zM503.9 192C509.2 212.5 512 233.9 512 256C512 278.1 509.2 299.5 503.9 320H380.8C382.9 299.4 384 277.1 384 256C384 234 382.9 212.6 380.8 192H503.9zM493.4 160H376.7C366.7 96.14 346.9 42.62 321.4 8.442C399.8 29.09 463.4 85.94 493.4 160zM344.3 160H167.7C173.8 123.6 183.2 91.38 194.7 65.35C205.2 41.74 216.9 24.61 228.2 13.81C239.4 3.178 248.7 0 256 0C263.3 0 272.6 3.178 283.8 13.81C295.1 24.61 306.8 41.74 317.3 65.35C328.8 91.38 338.2 123.6 344.3 160H344.3zM18.61 160C48.59 85.94 112.2 29.09 190.6 8.442C165.1 42.62 145.3 96.14 135.3 160H18.61zM131.2 192C129.1 212.6 127.1 234 127.1 256C127.1 277.1 129.1 299.4 131.2 320H8.065C2.8 299.5 0 278.1 0 256C0 233.9 2.8 212.5 8.065 192H131.2zM194.7 446.6C183.2 420.6 173.8 388.4 167.7 352H344.3C338.2 388.4 328.8 420.6 317.3 446.6C306.8 470.3 295.1 487.4 283.8 498.2C272.6 508.8 263.3 512 255.1 512C248.7 512 239.4 508.8 228.2 498.2C216.9 487.4 205.2 470.3 194.7 446.6H194.7zM190.6 503.6C112.2 482.9 48.59 426.1 18.61 352H135.3C145.3 415.9 165.1 469.4 190.6 503.6V503.6zM321.4 503.6C346.9 469.4 366.7 415.9 376.7 352H493.4C463.4 426.1 399.8 482.9 321.4 503.6V503.6z\"\n ]\n};\nvar faGolfBallTee = {\n prefix: 'fas',\n iconName: 'golf-ball-tee',\n icon: [\n 384,\n 512,\n [\n \"golf-ball\"\n ],\n \"f450\",\n \"M96 399.1c0 17.67 14.33 31.1 32 31.1s32 14.33 32 31.1v48h64v-48c0-17.67 14.33-31.1 32-31.1s32-14.33 32-31.1v-16H96V399.1zM192 .0001c-106 0-192 86.68-192 193.6c0 65.78 32.82 123.5 82.52 158.4h218.1C351.2 317.1 384 259.4 384 193.6C384 86.68 298 .0001 192 .0001zM179 205.1C183 206.9 187.4 208 192 208c17.53 0 31.74-14.33 31.74-31.1c0-4.688-1.111-9.062-2.904-13.07c11.03 5.016 18.77 16.08 18.77 29.07c0 17.67-14.21 31.1-31.74 31.1C194.1 224 184 216.2 179 205.1zM223.7 303.1c-12.88 0-23.86-7.812-28.83-18.93c3.977 1.809 8.316 2.93 12.96 2.93c17.53 0 31.74-14.33 31.74-31.1c0-4.688-1.109-9.062-2.904-13.07c11.03 5.016 18.77 16.08 18.77 29.07C255.5 289.7 241.3 303.1 223.7 303.1zM287.2 240c-12.88 0-23.86-7.812-28.83-18.93c3.977 1.809 8.316 2.93 12.96 2.93c17.53 0 31.73-14.33 31.73-31.1c0-4.688-1.109-9.062-2.902-13.07C311.2 183.9 318.9 195 318.9 208C318.9 225.7 304.7 240 287.2 240z\"\n ]\n};\nvar faGolfBall = faGolfBallTee;\nvar faGopuram = {\n prefix: 'fas',\n iconName: 'gopuram',\n icon: [\n 512,\n 512,\n [],\n \"f664\",\n \"M120 0C133.3 0 144 10.75 144 24V32H184V24C184 10.75 194.7 0 208 0C221.3 0 232 10.75 232 24V32H280V24C280 10.75 290.7 0 304 0C317.3 0 328 10.75 328 24V32H368V24C368 10.75 378.7 0 392 0C405.3 0 416 10.75 416 24V128C433.7 128 448 142.3 448 160V224C465.7 224 480 238.3 480 256V352C497.7 352 512 366.3 512 384V480C512 497.7 497.7 512 480 512H416V352H384V224H352V128H320V224H352V352H384V512H304V464C304 437.5 282.5 416 256 416C229.5 416 208 437.5 208 464V512H128V352H160V224H192V128H160V224H128V352H96V512H32C14.33 512 0 497.7 0 480V384C0 366.3 14.33 352 32 352V256C32 238.3 46.33 224 64 224V160C64 142.3 78.33 128 96 128V24C96 10.75 106.7 0 120 0zM256 272C238.3 272 224 286.3 224 304V352H288V304C288 286.3 273.7 272 256 272zM224 224H288V192C288 174.3 273.7 160 256 160C238.3 160 224 174.3 224 192V224z\"\n ]\n};\nvar faGraduationCap = {\n prefix: 'fas',\n iconName: 'graduation-cap',\n icon: [\n 640,\n 512,\n [\n 127891,\n \"mortar-board\"\n ],\n \"f19d\",\n \"M623.1 136.9l-282.7-101.2c-13.73-4.91-28.7-4.91-42.43 0L16.05 136.9C6.438 140.4 0 149.6 0 160s6.438 19.65 16.05 23.09L76.07 204.6c-11.89 15.8-20.26 34.16-24.55 53.95C40.05 263.4 32 274.8 32 288c0 9.953 4.814 18.49 11.94 24.36l-24.83 149C17.48 471.1 25 480 34.89 480H93.11c9.887 0 17.41-8.879 15.78-18.63l-24.83-149C91.19 306.5 96 297.1 96 288c0-10.29-5.174-19.03-12.72-24.89c4.252-17.76 12.88-33.82 24.94-47.03l190.6 68.23c13.73 4.91 28.7 4.91 42.43 0l282.7-101.2C633.6 179.6 640 170.4 640 160S633.6 140.4 623.1 136.9zM351.1 314.4C341.7 318.1 330.9 320 320 320c-10.92 0-21.69-1.867-32-5.555L142.8 262.5L128 405.3C128 446.6 213.1 480 320 480c105.1 0 192-33.4 192-74.67l-14.78-142.9L351.1 314.4z\"\n ]\n};\nvar faMortarBoard = faGraduationCap;\nvar faGreaterThan = {\n prefix: 'fas',\n iconName: 'greater-than',\n icon: [\n 384,\n 512,\n [\n 62769\n ],\n \"3e\",\n \"M32.03 448c-11.75 0-23.05-6.469-28.66-17.69c-7.906-15.81-1.5-35.03 14.31-42.94l262.8-131.4L17.69 124.6C1.875 116.7-4.531 97.51 3.375 81.7c7.891-15.81 27.06-22.19 42.94-14.31l320 160C377.2 232.8 384 243.9 384 256c0 12.12-6.844 23.19-17.69 28.63l-320 160C41.72 446.9 36.83 448 32.03 448z\"\n ]\n};\nvar faGreaterThanEqual = {\n prefix: 'fas',\n iconName: 'greater-than-equal',\n icon: [\n 448,\n 512,\n [],\n \"f532\",\n \"M34.28 331.9c5.016 12.53 17.03 20.12 29.73 20.12c3.953 0 7.969-.7187 11.88-2.281l320-127.1C408 216.9 416 205.1 416 192s-7.969-24.85-20.11-29.72l-320-128c-16.47-6.594-35.05 1.406-41.61 17.84C27.72 68.55 35.7 87.17 52.11 93.73l245.7 98.28L52.11 290.3C35.7 296.9 27.72 315.5 34.28 331.9zM416 416H32c-17.67 0-32 14.31-32 31.99s14.33 32.01 32 32.01h384c17.67 0 32-14.32 32-32.01S433.7 416 416 416z\"\n ]\n};\nvar faGrip = {\n prefix: 'fas',\n iconName: 'grip',\n icon: [\n 448,\n 512,\n [\n \"grip-horizontal\"\n ],\n \"f58d\",\n \"M128 184C128 206.1 110.1 224 88 224H40C17.91 224 0 206.1 0 184V136C0 113.9 17.91 96 40 96H88C110.1 96 128 113.9 128 136V184zM128 376C128 398.1 110.1 416 88 416H40C17.91 416 0 398.1 0 376V328C0 305.9 17.91 288 40 288H88C110.1 288 128 305.9 128 328V376zM160 136C160 113.9 177.9 96 200 96H248C270.1 96 288 113.9 288 136V184C288 206.1 270.1 224 248 224H200C177.9 224 160 206.1 160 184V136zM288 376C288 398.1 270.1 416 248 416H200C177.9 416 160 398.1 160 376V328C160 305.9 177.9 288 200 288H248C270.1 288 288 305.9 288 328V376zM320 136C320 113.9 337.9 96 360 96H408C430.1 96 448 113.9 448 136V184C448 206.1 430.1 224 408 224H360C337.9 224 320 206.1 320 184V136zM448 376C448 398.1 430.1 416 408 416H360C337.9 416 320 398.1 320 376V328C320 305.9 337.9 288 360 288H408C430.1 288 448 305.9 448 328V376z\"\n ]\n};\nvar faGripHorizontal = faGrip;\nvar faGripLines = {\n prefix: 'fas',\n iconName: 'grip-lines',\n icon: [\n 448,\n 512,\n [],\n \"f7a4\",\n \"M416 288C433.7 288 448 302.3 448 320C448 337.7 433.7 352 416 352H32C14.33 352 0 337.7 0 320C0 302.3 14.33 288 32 288H416zM416 160C433.7 160 448 174.3 448 192C448 209.7 433.7 224 416 224H32C14.33 224 0 209.7 0 192C0 174.3 14.33 160 32 160H416z\"\n ]\n};\nvar faGripLinesVertical = {\n prefix: 'fas',\n iconName: 'grip-lines-vertical',\n icon: [\n 192,\n 512,\n [],\n \"f7a5\",\n \"M64 448C64 465.7 49.67 480 32 480C14.33 480 0 465.7 0 448V64C0 46.33 14.33 32 32 32C49.67 32 64 46.33 64 64V448zM192 448C192 465.7 177.7 480 160 480C142.3 480 128 465.7 128 448V64C128 46.33 142.3 32 160 32C177.7 32 192 46.33 192 64V448z\"\n ]\n};\nvar faGripVertical = {\n prefix: 'fas',\n iconName: 'grip-vertical',\n icon: [\n 320,\n 512,\n [],\n \"f58e\",\n \"M88 352C110.1 352 128 369.9 128 392V440C128 462.1 110.1 480 88 480H40C17.91 480 0 462.1 0 440V392C0 369.9 17.91 352 40 352H88zM280 352C302.1 352 320 369.9 320 392V440C320 462.1 302.1 480 280 480H232C209.9 480 192 462.1 192 440V392C192 369.9 209.9 352 232 352H280zM40 320C17.91 320 0 302.1 0 280V232C0 209.9 17.91 192 40 192H88C110.1 192 128 209.9 128 232V280C128 302.1 110.1 320 88 320H40zM280 192C302.1 192 320 209.9 320 232V280C320 302.1 302.1 320 280 320H232C209.9 320 192 302.1 192 280V232C192 209.9 209.9 192 232 192H280zM40 160C17.91 160 0 142.1 0 120V72C0 49.91 17.91 32 40 32H88C110.1 32 128 49.91 128 72V120C128 142.1 110.1 160 88 160H40zM280 32C302.1 32 320 49.91 320 72V120C320 142.1 302.1 160 280 160H232C209.9 160 192 142.1 192 120V72C192 49.91 209.9 32 232 32H280z\"\n ]\n};\nvar faGuaraniSign = {\n prefix: 'fas',\n iconName: 'guarani-sign',\n icon: [\n 384,\n 512,\n [],\n \"e19a\",\n \"M224 32V66.66C263.5 73.3 299 92.03 326.4 118.9C339 131.3 339.2 151.5 326.9 164.1C314.5 176.8 294.2 176.1 281.6 164.6C265.8 149.1 246.1 137.7 224 132V224H352C369.7 224 384 238.3 384 256C384 351.1 314.8 430.1 224 445.3V480C224 497.7 209.7 512 192 512C174.3 512 160 497.7 160 480V445.3C69.19 430.1 0 351.1 0 256C0 160.9 69.19 81.89 160 66.65V32C160 14.33 174.3 0 192 0C209.7 0 224 14.33 224 32H224zM160 132C104.8 146.2 64 196.4 64 256C64 315.6 104.8 365.8 160 379.1V132zM224 379.1C268.1 368.4 304.4 332.1 315.1 288H224V379.1z\"\n ]\n};\nvar faGuitar = {\n prefix: 'fas',\n iconName: 'guitar',\n icon: [\n 512,\n 512,\n [],\n \"f7a6\",\n \"M502.7 39.02L473 9.37c-12.5-12.5-32.74-12.49-45.24 .0106l-46.24 46.37c-3.875 3.875-6.848 8.506-8.598 13.76l-12.19 36.51L284.5 182.3C272.4 173.5 259 166.5 244.4 163.1C211 155.4 177.4 162.3 154.5 185.1C145.3 194.5 138.3 206 134.3 218.6C128.3 237.1 111.1 251.3 92.14 253C68.52 255.4 46.39 264.5 29.52 281.5c-45.62 45.5-37.38 127.5 18.12 183c55.37 55.38 137.4 63.51 182.9 18c16.1-16.88 26.25-38.85 28.5-62.72c1.75-18.75 15.84-36.16 34.47-42.16c12.5-3.875 24.03-10.87 33.4-20.25c22.87-22.88 29.75-56.38 21.1-89.76c-3.375-14.63-10.39-27.99-19.14-40.11l76.25-76.26l36.53-12.17c5.125-1.75 9.894-4.715 13.77-8.59l46.36-46.29C515.2 71.72 515.2 51.52 502.7 39.02zM208 352c-26.5 0-48-21.5-48-48c0-26.5 21.5-48 48-48s47.1 21.5 47.1 48C256 330.5 234.5 352 208 352z\"\n ]\n};\nvar faGun = {\n prefix: 'fas',\n iconName: 'gun',\n icon: [\n 576,\n 512,\n [],\n \"e19b\",\n \"M544 64h-16V56C528 42.74 517.3 32 504 32S480 42.74 480 56V64H43.17C19.33 64 0 83.33 0 107.2v89.66C0 220.7 19.33 240 43.17 240c21.26 0 36.61 20.35 30.77 40.79l-40.69 158.4C27.41 459.6 42.76 480 64.02 480h103.8c14.29 0 26.84-9.469 30.77-23.21L226.4 352h94.58c24.16 0 45.5-15.41 53.13-38.28L398.6 240h36.1c8.486 0 16.62-3.369 22.63-9.373L480 208h64c17.67 0 32-14.33 32-32V96C576 78.33 561.7 64 544 64zM328.5 298.6C327.4 301.8 324.4 304 320.9 304H239.1L256 240h92.02L328.5 298.6zM480 160H64V128h416V160z\"\n ]\n};\nvar faH = {\n prefix: 'fas',\n iconName: 'h',\n icon: [\n 384,\n 512,\n [\n 104\n ],\n \"48\",\n \"M384 64.01v384c0 17.67-14.33 32-32 32s-32-14.33-32-32v-192H64v192c0 17.67-14.33 32-32 32s-32-14.33-32-32v-384C0 46.34 14.33 32.01 32 32.01S64 46.34 64 64.01v128h256v-128c0-17.67 14.33-32 32-32S384 46.34 384 64.01z\"\n ]\n};\nvar faHammer = {\n prefix: 'fas',\n iconName: 'hammer',\n icon: [\n 576,\n 512,\n [\n 128296\n ],\n \"f6e3\",\n \"M568.1 196.3l-22.62-22.62c-4.533-4.533-10.56-7.029-16.97-7.029s-12.44 2.496-16.97 7.029l-5.654 5.656l-20.12-20.12c4.596-23.46-2.652-47.9-19.47-64.73l-45.25-45.25C390.2 17.47 347.1 0 303.1 0C258.2 0 216 17.47 184.3 49.21L176.5 57.05L272.5 105.1v13.81c0 18.95 7.688 37.5 21.09 50.91l49.16 49.14c13.44 13.45 31.39 20.86 50.54 20.86c4.758 0 9.512-.4648 14.18-1.387l20.12 20.12l-5.654 5.654c-9.357 9.357-9.357 24.58-.002 33.94l22.62 22.62c4.535 4.533 10.56 7.031 16.97 7.031s12.44-2.498 16.97-7.031l90.53-90.5C578.3 220.8 578.3 205.6 568.1 196.3zM270.9 192.4c-3.846-3.846-7.197-8.113-10.37-12.49l-239.5 209.2c-28.12 28.12-28.16 73.72-.0371 101.8C35.12 505 53.56 512 71.1 512s36.84-7.031 50.91-21.09l209.1-239.4c-4.141-3.061-8.184-6.289-11.89-9.996L270.9 192.4z\"\n ]\n};\nvar faHamsa = {\n prefix: 'fas',\n iconName: 'hamsa',\n icon: [\n 512,\n 512,\n [],\n \"f665\",\n \"M509.4 307.2C504.3 295.5 492.8 288 480 288h-64l.0001-208c0-21.1-18-40-40-40c-22 0-40 18-40 40l-.0001 134C336 219.5 331.5 224 326 224h-20c-5.5 0-10-4.5-10-9.1V40c0-21.1-17.1-40-39.1-40S215.1 18 215.1 40v174C215.1 219.5 211.5 224 205.1 224H185.1C180.5 224 175.1 219.5 175.1 214L175.1 80c0-21.1-18-40-40-40S95.1 58 95.1 80L95.1 288H31.99C19.24 288 7.743 295.5 2.618 307.2C-2.382 318.9-.1322 332.5 8.618 341.9l102.6 110C146.1 490.1 199.8 512 256 512s108.1-21.88 144.8-60.13l102.6-110C512.1 332.5 514.4 318.9 509.4 307.2zM256 416c-53 0-96.01-64-96.01-64s43-64 96.01-64s96.01 64 96.01 64S309 416 256 416zM256 320c-17.63 0-32 14.38-32 32s14.38 32 32 32s32-14.38 32-32S273.6 320 256 320z\"\n ]\n};\nvar faHand = {\n prefix: 'fas',\n iconName: 'hand',\n icon: [\n 512,\n 512,\n [\n 129306,\n 9995,\n \"hand-paper\"\n ],\n \"f256\",\n \"M480 128v208c0 97.05-78.95 176-176 176h-37.72c-53.42 0-103.7-20.8-141.4-58.58l-113.1-113.1C3.906 332.5 0 322.2 0 312C0 290.7 17.15 272 40 272c10.23 0 20.47 3.906 28.28 11.72L128 343.4V64c0-17.67 14.33-32 32-32s32 14.33 32 32l.0729 176C192.1 248.8 199.2 256 208 256s16.07-7.164 16.07-16L224 32c0-17.67 14.33-32 32-32s32 14.33 32 32l.0484 208c0 8.836 7.111 16 15.95 16S320 248.8 320 240L320 64c0-17.67 14.33-32 32-32s32 14.33 32 32l.0729 176c0 8.836 7.091 16 15.93 16S416 248.8 416 240V128c0-17.67 14.33-32 32-32S480 110.3 480 128z\"\n ]\n};\nvar faHandPaper = faHand;\nvar faHandBackFist = {\n prefix: 'fas',\n iconName: 'hand-back-fist',\n icon: [\n 448,\n 512,\n [\n \"hand-rock\"\n ],\n \"f255\",\n \"M448 144v120.4C448 314.2 422.6 358.1 384 384v128H128v-128l-53.19-38.67C48 325.8 32 294.3 32 261.2V192c0-14.58 6.625-28.38 17.1-37.48L80 130.5V176C80 184.8 87.16 192 96 192s16-7.164 16-16v-128C112 21.48 133.5 0 160 0c25.38 0 45.96 19.77 47.67 44.73C216.2 36.9 227.5 32 240 32C266.5 32 288 53.48 288 80v5.531C296.6 72.57 311.3 64 328 64c23.47 0 42.94 16.87 47.11 39.14C382.4 98.7 390.9 96 400 96C426.5 96 448 117.5 448 144z\"\n ]\n};\nvar faHandRock = faHandBackFist;\nvar faHandDots = {\n prefix: 'fas',\n iconName: 'hand-dots',\n icon: [\n 512,\n 512,\n [\n \"allergies\"\n ],\n \"f461\",\n \"M448 96c-17.67 0-32 14.33-32 32v112C416 248.8 408.8 256 400 256s-15.93-7.164-15.93-16L384 64c0-17.67-14.33-32-32-32s-32 14.33-32 32l.0498 176c0 8.836-7.219 16-16.06 16s-15.95-7.164-15.95-16L288 32c0-17.67-14.33-32-32-32S224 14.33 224 32l.0729 208C224.1 248.8 216.8 256 208 256S192.1 248.8 192.1 240L192 64c0-17.67-14.33-32-32-32S128 46.33 128 64v279.4L68.28 283.7C60.47 275.9 50.23 272 40 272C18.68 272 0 289.2 0 312c0 10.23 3.906 20.47 11.72 28.28l113.1 113.1C162.6 491.2 212.9 512 266.3 512H304c97.05 0 176-78.95 176-176V128C480 110.3 465.7 96 448 96zM192 416c-8.836 0-16-7.164-16-16C176 391.2 183.2 384 192 384s16 7.162 16 16C208 408.8 200.8 416 192 416zM256 448c-8.836 0-16-7.164-16-16c0-8.838 7.164-16 16-16s16 7.162 16 16C272 440.8 264.8 448 256 448zM256 352c-8.836 0-16-7.164-16-16c0-8.838 7.164-16 16-16s16 7.162 16 16C272 344.8 264.8 352 256 352zM320 384c-8.836 0-16-7.164-16-16c0-8.838 7.164-16 16-16s16 7.162 16 16C336 376.8 328.8 384 320 384zM352 448c-8.836 0-16-7.164-16-16c0-8.838 7.164-16 16-16s16 7.162 16 16C368 440.8 360.8 448 352 448zM384 352c-8.836 0-16-7.164-16-16c0-8.838 7.164-16 16-16s16 7.162 16 16C400 344.8 392.8 352 384 352z\"\n ]\n};\nvar faAllergies = faHandDots;\nvar faHandFist = {\n prefix: 'fas',\n iconName: 'hand-fist',\n icon: [\n 448,\n 512,\n [\n 9994,\n \"fist-raised\"\n ],\n \"f6de\",\n \"M224 180.4V32c0-17.67-14.31-32-32-32S160 14.33 160 32v144h40C208.5 176 216.5 177.7 224 180.4zM128 176V64c0-17.67-14.31-32-32-32S64 46.33 64 64v112.8C66.66 176.5 69.26 176 72 176H128zM288 192c17.69 0 32-14.33 32-32V64c0-17.67-14.31-32-32-32s-32 14.33-32 32v96C256 177.7 270.3 192 288 192zM384 96c-17.69 0-32 14.33-32 32v64c0 17.67 14.31 32 32 32s32-14.34 32-32.02V128C416 110.3 401.7 96 384 96zM350.9 246.2c-12.43-7.648-21.94-19.31-26.88-33.25C313.7 219.9 301.3 223.9 288 223.9c-7.641 0-14.87-1.502-21.66-3.957C269.1 228.6 272 238.1 272 248c0 39.77-32.25 72-72 72H128c-8.836 0-16-7.164-16-16C112 295.2 119.2 288 128 288h72c22.09 0 40-17.91 40-40S222.1 208 200 208h-128C49.91 208 32 225.9 32 248v63.41c0 33.13 16 64.56 42.81 84.13L128 434.2V512h224v-85.09c38.3-24.09 64-66.42 64-114.9V247.1C406.6 252.6 395.7 256 384 256C371.7 256 360.5 252.2 350.9 246.2z\"\n ]\n};\nvar faFistRaised = faHandFist;\nvar faHandHolding = {\n prefix: 'fas',\n iconName: 'hand-holding',\n icon: [\n 576,\n 512,\n [],\n \"f4bd\",\n \"M559.7 392.2l-135.1 99.51C406.9 504.8 385 512 362.1 512H15.1c-8.749 0-15.1-7.246-15.1-15.99l0-95.99c0-8.748 7.25-16.02 15.1-16.02l55.37 .0238l46.5-37.74c20.1-16.1 47.12-26.25 74.12-26.25h159.1c19.5 0 34.87 17.37 31.62 37.37c-2.625 15.75-17.37 26.62-33.37 26.62H271.1c-8.749 0-15.1 7.249-15.1 15.1s7.25 15.1 15.1 15.1h120.6l119.7-88.17c17.8-13.19 42.81-9.342 55.93 8.467C581.3 354.1 577.5 379.1 559.7 392.2z\"\n ]\n};\nvar faHandHoldingDollar = {\n prefix: 'fas',\n iconName: 'hand-holding-dollar',\n icon: [\n 576,\n 512,\n [\n \"hand-holding-usd\"\n ],\n \"f4c0\",\n \"M568.2 336.3c-13.12-17.81-38.14-21.66-55.93-8.469l-119.7 88.17h-120.6c-8.748 0-15.1-7.25-15.1-15.99c0-8.75 7.25-16 15.1-16h78.25c15.1 0 30.75-10.88 33.37-26.62c3.25-20-12.12-37.38-31.62-37.38H191.1c-26.1 0-53.12 9.25-74.12 26.25l-46.5 37.74L15.1 383.1C7.251 383.1 0 391.3 0 400v95.98C0 504.8 7.251 512 15.1 512h346.1c22.03 0 43.92-7.188 61.7-20.27l135.1-99.52C577.5 379.1 581.3 354.1 568.2 336.3zM279.3 175C271.7 173.9 261.7 170.3 252.9 167.1L248 165.4C235.5 160.1 221.8 167.5 217.4 179.1s2.121 26.2 14.59 30.64l4.655 1.656c8.486 3.061 17.88 6.095 27.39 8.312V232c0 13.25 10.73 24 23.98 24s24-10.75 24-24V221.6c25.27-5.723 42.88-21.85 46.1-45.72c8.688-50.05-38.89-63.66-64.42-70.95L288.4 103.1C262.1 95.64 263.6 92.42 264.3 88.31c1.156-6.766 15.3-10.06 32.21-7.391c4.938 .7813 11.37 2.547 19.65 5.422c12.53 4.281 26.21-2.312 30.52-14.84s-2.309-26.19-14.84-30.53c-7.602-2.627-13.92-4.358-19.82-5.721V24c0-13.25-10.75-24-24-24s-23.98 10.75-23.98 24v10.52C238.8 40.23 221.1 56.25 216.1 80.13C208.4 129.6 256.7 143.8 274.9 149.2l6.498 1.875c31.66 9.062 31.15 11.89 30.34 16.64C310.6 174.5 296.5 177.8 279.3 175z\"\n ]\n};\nvar faHandHoldingUsd = faHandHoldingDollar;\nvar faHandHoldingDroplet = {\n prefix: 'fas',\n iconName: 'hand-holding-droplet',\n icon: [\n 576,\n 512,\n [\n \"hand-holding-water\"\n ],\n \"f4c1\",\n \"M287.1 256c53 0 95.1-42.13 95.1-93.1c0-40-57.12-120.8-83.25-155.6c-6.375-8.5-19.12-8.5-25.5 0C249.1 41.25 191.1 122 191.1 162C191.1 213.9 234.1 256 287.1 256zM568.2 336.3c-13.12-17.81-38.14-21.66-55.93-8.469l-119.7 88.17h-120.6c-8.748 0-15.1-7.25-15.1-15.99c0-8.75 7.25-16 15.1-16h78.25c15.1 0 30.75-10.88 33.37-26.62c3.25-20-12.12-37.38-31.62-37.38H191.1c-26.1 0-53.12 9.25-74.12 26.25l-46.5 37.74L15.1 383.1c-8.748 0-15.1 7.274-15.1 16.02L.0001 496C.0001 504.8 7.251 512 15.1 512h346.1c22.03 0 43.92-7.188 61.7-20.27l135.1-99.52C577.5 379.1 581.3 354.1 568.2 336.3z\"\n ]\n};\nvar faHandHoldingWater = faHandHoldingDroplet;\nvar faHandHoldingHeart = {\n prefix: 'fas',\n iconName: 'hand-holding-heart',\n icon: [\n 576,\n 512,\n [],\n \"f4be\",\n \"M275.2 250.5c7 7.375 18.5 7.375 25.5 0l108.1-114.2c31.5-33.12 29.72-88.1-5.65-118.7c-30.88-26.75-76.75-21.9-104.9 7.724L287.1 36.91L276.8 25.28C248.7-4.345 202.7-9.194 171.1 17.56C136.7 48.18 134.7 103.2 166.4 136.3L275.2 250.5zM568.2 336.3c-13.12-17.81-38.14-21.66-55.93-8.469l-119.7 88.17h-120.6c-8.748 0-15.1-7.25-15.1-15.1c0-8.746 7.25-15.1 15.1-15.1h78.25c15.1 0 30.75-10.87 33.37-26.62c3.25-19.1-12.12-37.37-31.62-37.37H191.1c-26.1 0-53.12 9.25-74.12 26.25l-46.5 37.74l-55.37-.0253c-8.748 0-15.1 7.275-15.1 16.02L.0001 496C.0001 504.8 7.251 512 15.1 512h346.1c22.03 0 43.92-7.187 61.7-20.28l135.1-99.51C577.5 379.1 581.3 354.1 568.2 336.3z\"\n ]\n};\nvar faHandHoldingMedical = {\n prefix: 'fas',\n iconName: 'hand-holding-medical',\n icon: [\n 576,\n 512,\n [],\n \"e05c\",\n \"M568.2 336.3c-13.12-17.81-38.14-21.66-55.93-8.469l-119.7 88.17h-120.6c-8.748 0-15.1-7.25-15.1-15.99c0-8.75 7.25-16 15.1-16h78.25c15.1 0 30.75-10.88 33.37-26.62c3.25-20-12.12-37.38-31.62-37.38H191.1c-26.1 0-53.12 9.25-74.12 26.25l-46.5 37.74L15.1 383.1C7.251 383.1 0 391.3 0 400v95.98C0 504.8 7.251 512 15.1 512h346.1c22.03 0 43.92-7.188 61.7-20.27l135.1-99.52C577.5 379.1 581.3 354.1 568.2 336.3zM160 176h64v64C224 248.8 231.2 256 240 256h64C312.8 256 320 248.8 320 240v-64h64c8.836 0 16-7.164 16-16V96c0-8.838-7.164-16-16-16h-64v-64C320 7.162 312.8 0 304 0h-64C231.2 0 224 7.162 224 16v64H160C151.2 80 144 87.16 144 96v64C144 168.8 151.2 176 160 176z\"\n ]\n};\nvar faHandLizard = {\n prefix: 'fas',\n iconName: 'hand-lizard',\n icon: [\n 512,\n 512,\n [],\n \"f258\",\n \"M512 329.1V432c0 8.836-7.164 16-16 16H368c-8.836 0-16-7.164-16-16V416l-85.33-64H95.1c-16.47 0-31.44-13.44-31.96-29.9C62.87 285.8 91.96 256 127.1 256h104.9c13.77 0 26-8.811 30.36-21.88l10.67-32C280.9 181.4 265.4 160 243.6 160H63.1C27.95 160-1.129 130.2 .0352 93.9C.5625 77.44 15.53 64 31.1 64h271.2c26.26 0 50.84 12.88 65.79 34.47l128.8 185.1C507 297.8 512 313.7 512 329.1z\"\n ]\n};\nvar faHandMiddleFinger = {\n prefix: 'fas',\n iconName: 'hand-middle-finger',\n icon: [\n 448,\n 512,\n [\n 128405\n ],\n \"f806\",\n \"M448 288v96c0 70.69-57.31 128-128 128H184c-50.35 0-97.76-23.7-127.1-63.98l-14.43-19.23C35.37 420.5 32 410.4 32 400v-48.02c0-14.58 6.629-28.37 18.02-37.48L80 290.5V336C80 344.8 87.16 352 96 352s16-7.164 16-16v-96C112 213.5 133.5 192 160 192s48 21.48 48 48V40C208 17.91 225.9 0 248 0S288 17.91 288 40v189.5C296.6 216.6 311.3 208 328 208c23.48 0 42.94 16.87 47.11 39.14C382.4 242.7 390.8 240 400 240C426.5 240 448 261.5 448 288z\"\n ]\n};\nvar faHandPeace = {\n prefix: 'fas',\n iconName: 'hand-peace',\n icon: [\n 512,\n 512,\n [\n 9996\n ],\n \"f25b\",\n \"M256 287.4V32c0-17.67-14.31-32-32-32S192 14.33 192 32v216.3C218.7 248.4 243.7 263.1 256 287.4zM170.8 251.2c2.514-.7734 5.043-1.027 7.57-1.516L93.41 51.39C88.21 39.25 76.34 31.97 63.97 31.97c-20.97 0-31.97 18.01-31.97 32.04c0 4.207 .8349 8.483 2.599 12.6l81.97 191.3L170.8 251.2zM416 224c-17.69 0-32 14.33-32 32v64c0 17.67 14.31 32 32 32s32-14.33 32-32V256C448 238.3 433.7 224 416 224zM320 352c17.69 0 32-14.33 32-32V224c0-17.67-14.31-32-32-32s-32 14.33-32 32v96C288 337.7 302.3 352 320 352zM368 361.9C356.3 375.3 339.2 384 320 384c-27.41 0-50.62-17.32-59.73-41.55c-7.059 21.41-23.9 39.23-47.08 46.36l-47.96 14.76c-1.562 .4807-3.147 .7105-4.707 .7105c-6.282 0-12.18-3.723-14.74-9.785c-.8595-2.038-1.264-4.145-1.264-6.213c0-6.79 4.361-13.16 11.3-15.3l46.45-14.29c17.2-5.293 29.76-20.98 29.76-38.63c0-34.19-32.54-40.07-40.02-40.07c-3.89 0-7.848 .5712-11.76 1.772l-104 32c-18.23 5.606-28.25 22.21-28.25 38.22c0 4.266 .6825 8.544 2.058 12.67L68.19 419C86.71 474.5 138.7 512 197.2 512H272c82.54 0 151.8-57.21 170.7-134C434.6 381.8 425.6 384 416 384C396.8 384 379.7 375.3 368 361.9z\"\n ]\n};\nvar faHandPointDown = {\n prefix: 'fas',\n iconName: 'hand-point-down',\n icon: [\n 448,\n 512,\n [],\n \"f0a7\",\n \"M256 256v64c0 17.67 14.31 32 32 32s32-14.33 32-32V256c0-17.67-14.31-32-32-32S256 238.3 256 256zM200 272H160V352c0 17.67 14.31 32 32 32s32-14.33 32-32V267.6C216.5 270.3 208.5 272 200 272zM72 272C69.26 272 66.66 271.5 64 271.2V480c0 17.67 14.31 32 32 32s32-14.33 32-32V272H72zM416 288V224c0-17.67-14.31-32-32-32s-32 14.33-32 32v64c0 17.67 14.31 32 32 32S416 305.7 416 288zM384 160c11.72 0 22.55 3.381 32 8.879V136C416 60.89 355.1 0 280 0L191.3 0C162.5 0 134.5 9.107 111.2 26.02L74.81 52.47C48 72.03 32 103.5 32 136.6V200C32 222.1 49.91 240 72 240h128c22.09 0 39.1-17.91 39.1-39.1c0-28.73-26.72-40-42.28-40l-69.72 0C119.2 160 112 152.8 112 144S119.2 128 127.1 128H200c37.87 0 68.59 29.35 71.45 66.51C276.8 193.1 282.2 192 288 192c13.28 0 25.6 4.047 35.83 10.97C332.6 178 356.1 160 384 160z\"\n ]\n};\nvar faHandPointLeft = {\n prefix: 'fas',\n iconName: 'hand-point-left',\n icon: [\n 512,\n 512,\n [],\n \"f0a5\",\n \"M256 288H192c-17.67 0-32 14.31-32 32s14.33 32 32 32h64c17.67 0 32-14.31 32-32S273.7 288 256 288zM240 232V192H160C142.3 192 128 206.3 128 224s14.33 32 32 32h84.41C241.7 248.5 240 240.5 240 232zM240 104C240 101.3 240.5 98.66 240.8 96H32C14.33 96 0 110.3 0 128s14.33 32 32 32h208V104zM224 448h64c17.67 0 32-14.31 32-32s-14.33-32-32-32H224c-17.67 0-32 14.31-32 32S206.3 448 224 448zM352 416c0 11.72-3.381 22.55-8.879 32H376C451.1 448 512 387.1 512 312V223.3c0-28.76-9.107-56.79-26.02-80.06l-26.45-36.41C439.1 80 408.5 64 375.4 64H312c-22.09 0-40 17.91-40 40v128c0 22.09 17.91 39.1 39.1 39.1c28.73 0 40-26.72 40-42.28L352 159.1C352 151.2 359.2 144 368 144S384 151.2 384 159.1V232c0 37.87-29.35 68.59-66.51 71.45C318.9 308.8 320 314.2 320 320c0 13.28-4.047 25.6-10.97 35.83C333.1 364.6 352 388.1 352 416z\"\n ]\n};\nvar faHandPointRight = {\n prefix: 'fas',\n iconName: 'hand-point-right',\n icon: [\n 512,\n 512,\n [],\n \"f0a4\",\n \"M224 320c0 17.69 14.33 32 32 32h64c17.67 0 32-14.31 32-32s-14.33-32-32-32h-64C238.3 288 224 302.3 224 320zM267.6 256H352c17.67 0 32-14.31 32-32s-14.33-32-32-32h-80v40C272 240.5 270.3 248.5 267.6 256zM272 160H480c17.67 0 32-14.31 32-32s-14.33-32-32-32h-208.8C271.5 98.66 272 101.3 272 104V160zM320 416c0-17.69-14.33-32-32-32H224c-17.67 0-32 14.31-32 32s14.33 32 32 32h64C305.7 448 320 433.7 320 416zM202.1 355.8C196 345.6 192 333.3 192 320c0-5.766 1.08-11.24 2.51-16.55C157.4 300.6 128 269.9 128 232V159.1C128 151.2 135.2 144 143.1 144S160 151.2 159.1 159.1l0 69.72C159.1 245.2 171.3 271.1 200 271.1C222.1 271.1 240 254.1 240 232v-128C240 81.91 222.1 64 200 64H136.6C103.5 64 72.03 80 52.47 106.8L26.02 143.2C9.107 166.5 0 194.5 0 223.3V312C0 387.1 60.89 448 136 448h32.88C163.4 438.6 160 427.7 160 416C160 388.1 178 364.6 202.1 355.8z\"\n ]\n};\nvar faHandPointUp = {\n prefix: 'fas',\n iconName: 'hand-point-up',\n icon: [\n 448,\n 512,\n [\n 9757\n ],\n \"f0a6\",\n \"M288 288c17.69 0 32-14.33 32-32V192c0-17.67-14.31-32-32-32s-32 14.33-32 32v64C256 273.7 270.3 288 288 288zM224 244.4V160c0-17.67-14.31-32-32-32S160 142.3 160 160v80h40C208.5 240 216.5 241.7 224 244.4zM128 240V32c0-17.67-14.31-32-32-32S64 14.33 64 32v208.8C66.66 240.5 69.26 240 72 240H128zM384 192c-17.69 0-32 14.33-32 32v64c0 17.67 14.31 32 32 32s32-14.33 32-32V224C416 206.3 401.7 192 384 192zM323.8 309C313.6 315.1 301.3 320 288 320c-5.766 0-11.24-1.08-16.55-2.51C268.6 354.6 237.9 384 200 384H127.1C119.2 384 112 376.8 112 368S119.2 352 127.1 352l69.72 .0001c15.52 0 42.28-11.29 42.28-40C239.1 289.9 222.1 272 200 272h-128C49.91 272 32 289.9 32 312v63.41c0 33.13 16 64.56 42.81 84.13l36.41 26.45C134.5 502.9 162.5 512 191.3 512H280c75.11 0 136-60.89 136-136v-32.88C406.6 348.6 395.7 352 384 352C356.1 352 332.6 333.1 323.8 309z\"\n ]\n};\nvar faHandPointer = {\n prefix: 'fas',\n iconName: 'hand-pointer',\n icon: [\n 448,\n 512,\n [],\n \"f25a\",\n \"M400 224c-9.148 0-17.62 2.697-24.89 7.143C370.9 208.9 351.5 192 328 192c-17.38 0-32.46 9.33-40.89 23.17C282.1 192.9 263.5 176 240 176c-12.35 0-23.49 4.797-32 12.46V40c0-22.09-17.9-40-39.1-40C145.9 0 128 17.91 128 40v322.7L72 288C64.15 277.5 52.13 272 39.97 272c-21.22 0-39.97 17.06-39.97 40.02c0 8.356 2.608 16.78 8.005 23.98l91.22 121.6C124.8 491.7 165.5 512 208 512h96C383.4 512 448 447.4 448 368v-96C448 245.5 426.5 224 400 224zM240 400c0 8.844-7.156 16-16 16s-16-7.156-16-16v-96C208 295.2 215.2 288 224 288s16 7.156 16 16V400zM304 400c0 8.844-7.156 16-16 16s-16-7.156-16-16v-96C272 295.2 279.2 288 288 288s16 7.156 16 16V400zM368 400c0 8.844-7.156 16-16 16s-16-7.156-16-16v-96C336 295.2 343.2 288 352 288s16 7.156 16 16V400z\"\n ]\n};\nvar faHandScissors = {\n prefix: 'fas',\n iconName: 'hand-scissors',\n icon: [\n 512,\n 512,\n [],\n \"f257\",\n \"M512 192v111.1C512 383.4 447.4 448 368 448H288c-26.52 0-48-21.48-48-47.99c0-9.152 2.697-17.61 7.139-24.89C224.9 370.1 208 351.5 208 328c0-16.72 8.561-31.4 21.52-39.1H40c-22.09 0-40-17.9-40-39.99s17.91-39.1 40-39.1h229.5L60 142.2C42.93 136.8 31.99 121.1 31.99 104c0-3.973 .5967-8.014 1.851-12.01c5.35-17.07 21.08-28.04 38.06-28.04c4 0 8.071 .6085 12.09 1.889l279.2 87.22C364.8 153.6 366.4 153.8 368 153.8c6.812 0 13.12-4.375 15.27-11.23c.4978-1.588 .7346-3.195 .7346-4.777c0-6.807-4.388-13.12-11.23-15.25l-72.54-22.67l14.29-17.85C323.6 70.67 337.4 64.04 352 64.04h48c10.39 0 20.48 3.359 28.8 9.592l38.41 28.79c25.2 18.91 40.53 47.97 43.55 79.04C511.5 184.9 512 188.4 512 192z\"\n ]\n};\nvar faHandSparkles = {\n prefix: 'fas',\n iconName: 'hand-sparkles',\n icon: [\n 640,\n 512,\n [],\n \"e05d\",\n \"M448 432c0-14.25 8.547-28.14 21.28-34.55l39.56-16.56l15.64-37.52c4.461-9.037 11.45-15.37 19.43-19.23L544 128c0-17.67-14.33-32-32-32s-32 14.33-32 32l-.0156 112c0 8.836-7.148 16-15.98 16s-16.07-7.164-16.07-16L448 64c0-17.67-14.33-32-32-32s-32 14.33-32 32l-.0635 176c0 8.836-7.106 16-15.94 16S351.9 248.8 351.9 240L352 32c0-17.67-14.33-32-32-32S288 14.33 288 32L287.9 240C287.9 248.8 280.8 256 272 256S255.9 248.8 255.9 240L256 64c0-17.67-14.33-32-32-32S192 46.33 192 64v279.4L132.3 283.7C124.5 275.9 114.2 272 104 272C82.68 272 64 289.2 64 312c0 10.23 3.906 20.47 11.72 28.28l113.1 113.1C226.6 491.2 276.9 512 330.3 512H368c42.72 0 81.91-15.32 112.4-40.73l-9.049-3.773C456.6 460.1 448 446.3 448 432zM349.8 371.6L320 383.1l-12.42 29.78C306.1 415 305.4 416 304 416s-2.969-.9941-3.578-2.219L288 383.1l-29.79-12.42C256.1 370.1 256 369.4 256 367.1c0-1.365 .9922-2.967 2.209-3.577L288 352l12.42-29.79C301 320.1 302.6 320 304 320s2.967 .9902 3.578 2.217L320 352l29.79 12.42C351 365 352 366.6 352 367.1C352 369.4 351 370.1 349.8 371.6zM80 224c2.277 0 4.943-1.656 5.959-3.699l20.7-49.63l49.65-20.71c2.027-1.014 3.682-3.696 3.686-5.958C159.1 141.7 158.3 139.1 156.3 138L106.7 117.4L85.96 67.7C84.94 65.65 82.28 64 80 64C77.72 64 75.05 65.65 74.04 67.7L53.34 117.3L3.695 138C1.668 139.1 .0117 141.7 .0078 143.1c.0039 2.262 1.662 4.953 3.688 5.967l49.57 20.67l20.77 49.67C75.05 222.3 77.72 224 80 224zM639.1 432c-.0039-2.275-1.657-4.952-3.687-5.968l-49.57-20.67l-20.77-49.67C564.9 353.7 562.3 352 560 352c-2.281 0-4.959 1.652-5.975 3.695l-20.7 49.63l-49.64 20.71c-2.027 1.016-3.682 3.683-3.686 5.958c.0039 2.262 1.661 4.954 3.686 5.968l49.57 20.67l20.77 49.67C555.1 510.3 557.7 512 560 512c2.277 0 4.933-1.656 5.949-3.699l20.7-49.63l49.65-20.71C638.3 436.9 639.1 434.3 639.1 432z\"\n ]\n};\nvar faHandSpock = {\n prefix: 'fas',\n iconName: 'hand-spock',\n icon: [\n 576,\n 512,\n [\n 128406\n ],\n \"f259\",\n \"M543.6 128.6c0-8.999-6.115-32.58-31.68-32.58c-14.1 0-27.02 9.324-30.92 23.56l-34.36 125.1c-1.682 6.16-7.275 10.43-13.66 10.43c-7.981 0-14.16-6.518-14.16-14.13c0-.9844 .1034-1.987 .3197-2.996l35.71-166.6c.5233-2.442 .7779-4.911 .7779-7.362c0-13.89-9.695-32.86-31.7-32.86c-14.79 0-28.12 10.26-31.34 25.29l-37.77 176.2c-2.807 13.1-14.38 22.46-27.77 22.46c-13.04 0-24.4-8.871-27.56-21.52l-52.11-208.5C243.6 11.2 230.5-.0013 215.6-.0013c-26.71 0-31.78 25.71-31.78 31.98c0 2.569 .3112 5.18 .9617 7.786l50.55 202.2c.2326 .9301 .3431 1.856 .3431 2.764c0 6.051-4.911 11.27-11.3 11.27c-4.896 0-9.234-3.154-10.74-7.812L166.9 103.9C162.4 89.1 149.5 80.02 135.5 80.02c-15.68 0-31.63 12.83-31.63 31.97c0 3.273 .5059 6.602 1.57 9.884l69.93 215.7c.2903 .8949 .4239 1.766 .4239 2.598c0 4.521-3.94 7.915-8.119 7.915c-1.928 0-3.906-.7219-5.573-2.388L101.7 285.3c-8.336-8.336-19.63-12.87-30.81-12.87c-23.56 0-39.07 19.69-39.07 39.55c0 10.23 3.906 20.47 11.72 28.28l122.5 122.5C197.6 494.3 240.3 512 284.9 512h50.98c23.5 0 108.4-14.57 132.5-103l73.96-271.2C543.2 134.8 543.6 131.7 543.6 128.6z\"\n ]\n};\nvar faHands = {\n prefix: 'fas',\n iconName: 'hands',\n icon: [\n 512,\n 512,\n [\n \"sign-language\",\n \"signing\"\n ],\n \"f2a7\",\n \"M330.8 242.3L223.1 209.1C210.3 205.2 197 212.3 193.1 224.9C189.2 237.6 196.3 251 208.9 254.9L256 272H56.9c-11.61 0-22.25 7.844-24.44 19.24C29.51 306.6 41.19 320 56 320h128C188.4 320 192 323.6 192 328S188.4 336 184 336H24.9c-11.61 0-22.25 7.844-24.44 19.24C-2.49 370.6 9.193 384 24 384h160C188.4 384 192 387.6 192 392S188.4 400 184 400H56.9c-11.61 0-22.25 7.844-24.44 19.24C29.51 434.6 41.19 448 56 448h128C188.4 448 192 451.6 192 456S188.4 464 184 464H88.9c-11.61 0-22.25 7.844-24.44 19.24C61.51 498.6 73.19 512 88 512h208c66.28 0 120-53.73 120-120v-32.03C416 306.6 381.1 259.4 330.8 242.3zM197.1 179.5c5.986-2.148 12.32-3.482 18.98-3.482c5.508 0 10.99 .8105 16.5 2.471l16.11 4.975L227.7 117.2C224.2 106.2 213.6 98.39 202 99.74c-15.51 1.807-24.79 16.99-20.33 31.11L197.1 179.5zM487.1 144.5c-13.27 .0977-23.95 10.91-23.86 24.16l-2.082 50.04l-59.98-189.8c-3.496-11.07-14.18-18.86-25.71-17.51c-15.51 1.807-24.79 16.99-20.33 31.11l38.56 122.1c1.332 4.213-1.004 8.707-5.219 10.04c-4.213 1.332-8.707-1.004-10.04-5.217l-47.93-151.7c-3.496-11.07-14.18-18.86-25.71-17.51c-15.51 1.807-24.79 16.99-20.33 31.11l43.37 137.8c1.33 4.213-1.006 8.707-5.219 10.04c-4.213 1.332-8.707-1.004-10.04-5.217l-33.46-106.4C275.6 56.39 264.9 48.6 253.4 49.94c-15.51 1.807-24.79 16.99-20.33 31.11l34.15 108.1l73.7 22.76C404.1 233.3 448 292.8 448 359.9v27.91c38.27-21.17 63.28-61.24 64-106.7V168.4C511.8 155.1 500.3 144.5 487.1 144.5z\"\n ]\n};\nvar faSignLanguage = faHands;\nvar faSigning = faHands;\nvar faHandsAslInterpreting = {\n prefix: 'fas',\n iconName: 'hands-asl-interpreting',\n icon: [\n 640,\n 512,\n [\n \"american-sign-language-interpreting\",\n \"asl-interpreting\",\n \"hands-american-sign-language-interpreting\"\n ],\n \"f2a3\",\n \"M200 240c16.94 0 32.09 10.72 37.73 26.67c5.891 16.66 24.17 25.39 40.84 19.5c16.66-5.891 25.39-24.17 19.5-40.84C287.2 214.7 262.8 191.6 233.1 181.5l79.68-22.76c16.98-4.859 26.83-22.56 21.97-39.56C329.9 102.2 312.2 92.35 295.2 97.24L196 125.6l80.82-69.28c13.42-11.5 14.97-31.7 3.469-45.12C268.8-2.24 248.6-3.803 235.2 7.713l-100.4 86.09l22.33-48.39c7.391-16.05 .3906-35.06-15.66-42.47C125.4-4.412 106.4 2.525 98.94 18.6L14.92 206.6C5.082 228.6 0 252.5 0 276.6C0 335.9 48.1 384 107.4 384l99.9-.0064c31.87-2.289 61.15-19.35 79.13-46.18c9.828-14.69 5.891-34.56-8.781-44.41C263 283.6 243.1 287.5 233.3 302.2C225.8 313.3 213.4 320 200 320c-22.06 0-40-17.94-40-40C160 257.9 177.9 240 200 240zM532.6 128l-99.9 .004c-31.87 2.289-61.15 19.35-79.13 46.18c-9.828 14.69-5.891 34.56 8.781 44.41c14.66 9.812 34.55 5.906 44.41-8.781C414.2 198.7 426.6 191.1 440 191.1c22.06 0 40 17.94 40 40c0 22.06-17.94 39.1-40 39.1c-16.94 0-32.09-10.72-37.73-26.67c-5.891-16.66-24.17-25.39-40.84-19.5c-16.66 5.891-25.39 24.17-19.5 40.84c10.84 30.64 35.23 53.77 64.96 63.8l-79.68 22.76c-16.98 4.859-26.83 22.56-21.97 39.56c4.844 16.98 22.56 26.86 39.56 21.97l99.2-28.34l-80.82 69.28c-13.42 11.5-14.97 31.7-3.469 45.12c11.52 13.42 31.73 14.98 45.13 3.469l100.4-86.09l-22.33 48.39c-7.391 16.05-.3906 35.06 15.66 42.47c16.02 7.359 35.05 .4219 42.47-15.65l84.02-188C634.9 283.4 640 259.5 640 235.4C640 176.1 591.9 128 532.6 128z\"\n ]\n};\nvar faAmericanSignLanguageInterpreting = faHandsAslInterpreting;\nvar faAslInterpreting = faHandsAslInterpreting;\nvar faHandsAmericanSignLanguageInterpreting = faHandsAslInterpreting;\nvar faHandsBubbles = {\n prefix: 'fas',\n iconName: 'hands-bubbles',\n icon: [\n 576,\n 512,\n [\n \"hands-wash\"\n ],\n \"e05e\",\n \"M416 64c17.67 0 32-14.33 32-31.1c0-17.67-14.33-32-32-32c-17.67 0-32 14.33-32 32C384 49.67 398.3 64 416 64zM519.1 336H360c-4.418 0-8-3.582-8-8s3.582-8 8-8h128c14.81 0 26.49-13.42 23.54-28.76c-2.191-11.4-12.84-19.24-24.44-19.24H288l47.09-17.06c12.66-3.906 19.75-17.34 15.84-30.03c-3.938-12.62-17.28-19.69-30.03-15.84L213.2 242.3C162 259.4 128 306.6 128 359.1v25.65c36.47 7.434 64 39.75 64 78.38c0 10.71-2.193 20.91-6.031 30.25C204.1 505.3 225.2 512 248 512h208c14.81 0 26.49-13.42 23.54-28.76c-2.191-11.4-12.84-19.24-24.44-19.24H360c-4.418 0-8-3.582-8-8s3.582-8 8-8h128c14.81 0 26.49-13.42 23.54-28.76c-2.191-11.4-12.84-19.24-24.44-19.24H360c-4.418 0-8-3.582-8-8s3.582-8 8-8h160c14.81 0 26.49-13.42 23.54-28.76C541.3 343.8 530.7 336 519.1 336zM311.5 178.4c5.508-1.66 10.99-2.471 16.5-2.471c6.662 0 12.1 1.334 18.98 3.482l15.36-48.61c4.461-14.12-4.82-29.3-20.33-31.11c-11.53-1.344-22.21 6.443-25.71 17.51l-20.9 66.17L311.5 178.4zM496 224c26.51 0 48-21.49 48-47.1s-21.49-48-48-48S448 149.5 448 176S469.5 224 496 224zM93.65 386.3C94.45 386.1 95.19 385.8 96 385.6v-25.69c0-67.17 43.03-126.7 107.1-148l73.7-22.76l34.15-108.1c4.459-14.12-4.82-29.3-20.33-31.11C279.1 48.6 268.4 56.39 264.9 67.46L231.4 173.9c-1.332 4.213-5.826 6.549-10.04 5.217C217.2 177.8 214.8 173.3 216.2 169.1l43.37-137.8c4.461-14.12-4.82-29.3-20.33-31.11c-11.53-1.344-22.21 6.445-25.71 17.51L165.6 169.4C164.2 173.6 159.7 175.9 155.5 174.6C151.3 173.3 148.1 168.8 150.3 164.6l38.56-122.1c4.459-14.12-4.82-29.3-20.33-31.11C157 10.04 146.3 17.83 142.8 28.9L82.84 218.7L80.76 168.7C80.85 155.5 70.17 144.6 56.9 144.5C43.67 144.5 32.18 155.1 32 168.4v112.7C32.71 325.6 56.76 364.8 93.65 386.3zM112 416c-26.51 0-48 21.49-48 47.1s21.49 48 48 48S160 490.5 160 464S138.5 416 112 416z\"\n ]\n};\nvar faHandsWash = faHandsBubbles;\nvar faHandsClapping = {\n prefix: 'fas',\n iconName: 'hands-clapping',\n icon: [\n 512,\n 512,\n [],\n \"e1a8\",\n \"M320 96c8.844 0 16-7.156 16-16v-64C336 7.156 328.8 0 320 0s-16 7.156-16 16v64C304 88.84 311.2 96 320 96zM383.4 96c5.125 0 10.16-2.453 13.25-7.016l32.56-48c1.854-2.746 2.744-5.865 2.744-8.951c0-8.947-7.273-16.04-15.97-16.04c-5.125 0-10.17 2.465-13.27 7.02l-32.56 48C368.3 73.76 367.4 76.88 367.4 79.97C367.4 88.88 374.7 96 383.4 96zM384 357.5l0-163.9c0-6.016-4.672-33.69-32-33.69c-17.69 0-32.07 14.33-32.07 31.1L320 268.1L169.2 117.3C164.5 112.6 158.3 110.3 152.2 110.3c-13.71 0-24 11.21-24 24c0 6.141 2.344 12.28 7.031 16.97l89.3 89.3C227.4 243.4 228.9 247.2 228.9 251c0 3.8-1.45 7.6-4.349 10.5c-2.899 2.899-6.7 4.349-10.5 4.349c-3.8 0-7.6-1.45-10.5-4.349l-107.6-107.6C91.22 149.2 85.08 146.9 78.94 146.9c-13.71 0-24 11.21-24 24c0 6.141 2.344 12.28 7.031 16.97l107.6 107.6C172.5 298.4 173.9 302.2 173.9 305.1c0 3.8-1.45 7.6-4.349 10.5c-2.899 2.9-6.7 4.349-10.5 4.349c-3.8 0-7.6-1.45-10.5-4.349L59.28 227.2C54.59 222.5 48.45 220.1 42.31 220.1c-13.71 0-24 11.21-24 24c0 6.141 2.344 12.28 7.031 16.97l89.3 89.3c2.9 2.899 4.349 6.7 4.349 10.5c0 3.8-1.45 7.6-4.349 10.5c-2.899 2.899-6.7 4.349-10.5 4.349c-3.8 0-7.6-1.45-10.5-4.349L40.97 318.7C36.28 314 30.14 311.7 24 311.7c-13.71 0-23.99 11.26-23.99 24.05c0 6.141 2.332 12.23 7.02 16.92C112.6 458.2 151.3 512 232.3 512C318.1 512 384 440.9 384 357.5zM243.3 88.98C246.4 93.55 251.4 96 256.6 96c8.762 0 15.99-7.117 15.99-16.03c0-3.088-.8906-6.205-2.744-8.951l-32.56-48C234.2 18.46 229.1 15.98 223.1 15.98c-8.664 0-15.98 7.074-15.98 16.05c0 3.086 .8906 6.205 2.744 8.951L243.3 88.98zM480 160c-17.69 0-32 14.33-32 32v76.14l-32-32v121.4c0 94.01-63.31 141.5-78.32 152.2C345.1 510.9 352.6 512 360.3 512C446.1 512 512 440.9 512 357.5l-.0625-165.6C511.9 174.3 497.7 160 480 160z\"\n ]\n};\nvar faHandsHolding = {\n prefix: 'fas',\n iconName: 'hands-holding',\n icon: [\n 640,\n 512,\n [],\n \"f4c2\",\n \"M216.1 236C205.1 222.3 185.8 219.1 172 231c-13.81 11.06-16.05 31.19-5 45l18.86 30.56C194.8 317.7 193.9 333.7 183.8 343.8c-11.79 11.79-31.2 10.71-41.61-2.305L80 256.8V104C80 81.91 62.09 64 40 64S0 81.91 0 104v204.7c0 14.54 4.949 28.65 14.03 40l120.1 151.3C141.1 507.6 150.3 512 159.1 512H256c17.67 0 32.03-14.35 32.03-32.02L288 358.4c0-21.79-7.414-42.93-21.02-59.94L216.1 236zM600 64c-22.09 0-40 17.91-40 40v152.8l-62.2 84.73c-10.41 13.02-29.83 14.09-41.61 2.305c-10.08-10.07-10.97-26.11-2.068-37.24l18.86-30.56c11.05-13.81 8.812-33.94-5-45c-13.77-11.03-33.94-8.75-44.97 5l-49.99 62.5C359.4 315.5 352 336.6 352 358.4l-.0313 121.5C351.1 497.7 366.3 512 384 512h96.02c9.713 0 18.9-4.414 24.96-12l120.1-151.3C635.1 337.4 640 323.3 640 308.7V104C640 81.91 622.1 64 600 64z\"\n ]\n};\nvar faHandsPraying = {\n prefix: 'fas',\n iconName: 'hands-praying',\n icon: [\n 640,\n 512,\n [\n \"praying-hands\"\n ],\n \"f684\",\n \"M272 191.9c-17.62 0-32 14.35-32 31.97V303.9c0 8.875-7.125 16-16 16s-16-7.125-16-16V227.4c0-17.37 4.75-34.5 13.75-49.37L299.5 48.41c9-15.12 4.125-34.76-11-43.88C273.1-4.225 255.8 .1289 246.1 13.63C245.1 13.88 245.5 13.88 245.4 14.13L128.1 190C117.5 205.9 112 224.3 112 243.3v80.24l-90.13 29.1C8.75 357.9 0 370.1 0 383.9v95.99c0 10.88 8.5 31.1 32 31.1c2.75 0 5.375-.25 8-1l179.3-46.62C269.1 450 304 403.8 304 351.9V223.9C304 206.3 289.6 191.9 272 191.9zM618.1 353.6L528 323.6V243.4c0-19-5.5-37.37-16.12-53.25l-117.3-175.9c-.125-.25-.6251-.2487-.75-.4987c-9.625-13.5-27.88-17.85-42.38-9.229c-15.12 9.125-20 28.76-11 44.01l77.75 129.5C427.3 193 432 210 432 227.5v76.49c0 8.875-7.125 16-16 16s-16-7.125-16-16V223.1c0-17.62-14.38-31.97-32-31.97s-32 14.38-32 31.1v127.1c0 51.87 34.88 98.12 84.75 112.4L600 511C602.6 511.6 605.4 512 608 512c23.5 0 32-21.25 32-31.1v-95.99C640 370.3 631.3 358 618.1 353.6z\"\n ]\n};\nvar faPrayingHands = faHandsPraying;\nvar faHandshake = {\n prefix: 'fas',\n iconName: 'handshake',\n icon: [\n 640,\n 512,\n [],\n \"f2b5\",\n \"M0 383.9l64 .0404c17.75 0 32-14.29 32-32.03V128.3L0 128.3V383.9zM48 320.1c8.75 0 16 7.118 16 15.99c0 8.742-7.25 15.99-16 15.99S32 344.8 32 336.1C32 327.2 39.25 320.1 48 320.1zM348.8 64c-7.941 0-15.66 2.969-21.52 8.328L228.9 162.3C228.8 162.5 228.8 162.7 228.6 162.7C212 178.3 212.3 203.2 226.5 218.7c12.75 13.1 39.38 17.62 56.13 2.75C282.8 221.3 282.9 221.3 283 221.2l79.88-73.1c6.5-5.871 16.75-5.496 22.62 1c6 6.496 5.5 16.62-1 22.62l-26.12 23.87L504 313.7c2.875 2.496 5.5 4.996 7.875 7.742V127.1c-40.98-40.96-96.48-63.88-154.4-63.88L348.8 64zM334.6 217.4l-30 27.49c-29.75 27.11-75.25 24.49-101.8-4.371C176 211.2 178.1 165.7 207.3 138.9L289.1 64H282.5C224.7 64 169.1 87.08 128.2 127.9L128 351.8l18.25 .0369l90.5 81.82c27.5 22.37 67.75 18.12 90-9.246l18.12 15.24c15.88 12.1 39.38 10.5 52.38-5.371l31.38-38.6l5.374 4.498c13.75 11 33.88 9.002 45-4.748l9.538-11.78c11.12-13.75 9.036-33.78-4.694-44.93L334.6 217.4zM544 128.4v223.6c0 17.62 14.25 32.05 31.1 32.05L640 384V128.1L544 128.4zM592 352c-8.75 0-16-7.246-16-15.99c0-8.875 7.25-15.99 16-15.99S608 327.2 608 336.1C608 344.8 600.8 352 592 352z\"\n ]\n};\nvar faHandshakeAngle = {\n prefix: 'fas',\n iconName: 'handshake-angle',\n icon: [\n 640,\n 512,\n [\n \"hands-helping\"\n ],\n \"f4c4\",\n \"M488 191.1h-152l.0001 51.86c.0001 37.66-27.08 72-64.55 75.77c-43.09 4.333-79.45-29.42-79.45-71.63V126.4l-24.51 14.73C123.2 167.8 96.04 215.7 96.04 267.5L16.04 313.8c-15.25 8.751-20.63 28.38-11.75 43.63l80 138.6c8.875 15.25 28.5 20.5 43.75 11.75l103.4-59.75h136.6c35.25 0 64-28.75 64-64c26.51 0 48-21.49 48-48V288h8c13.25 0 24-10.75 24-24l.0001-48C512 202.7 501.3 191.1 488 191.1zM635.7 154.5l-79.95-138.6c-8.875-15.25-28.5-20.5-43.75-11.75l-103.4 59.75h-62.57c-37.85 0-74.93 10.61-107.1 30.63C229.7 100.4 224 110.6 224 121.6l-.0004 126.4c0 22.13 17.88 40 40 40c22.13 0 40-17.88 40-40V159.1h184c30.93 0 56 25.07 56 56v28.5l80-46.25C639.3 189.4 644.5 169.8 635.7 154.5z\"\n ]\n};\nvar faHandsHelping = faHandshakeAngle;\nvar faHandshakeSimpleSlash = {\n prefix: 'fas',\n iconName: 'handshake-simple-slash',\n icon: [\n 640,\n 512,\n [\n \"handshake-alt-slash\"\n ],\n \"e05f\",\n \"M358.6 195.6l145.6 118.1c12.12 9.992 19.5 23.49 22.12 37.98h81.62c17.6 0 31.1-14.39 31.1-31.99V159.1c0-17.67-14.33-31.99-31.1-31.99h-95.1c-40.98-40.96-96.56-63.98-154.5-63.98h-8.613c-7.1 0-15.63 3.002-21.63 8.373l-93.44 85.57L208.3 137.9L289.1 64.01L282.5 64c-43.48 0-85.19 13.66-120.8 37.44l-122.9-96.33C34.41 1.672 29.19 0 24.03 0c-7.125 0-14.19 3.156-18.91 9.187c-8.187 10.44-6.375 25.53 4.062 33.7L601.2 506.9c10.5 8.203 25.56 6.328 33.69-4.078c8.187-10.44 6.375-25.53-4.062-33.7l-135.5-106.2c-.1719-9.086-3.789-18.03-11.39-24.2l-149.2-121.2l-11.47 10.51L297.6 207.1l65.51-59.85c6.5-5.871 16.62-5.496 22.62 .1c5.1 6.496 5.5 16.62-.1 22.62L358.6 195.6zM32 127.1c-17.6 0-31.1 14.4-31.1 31.99v159.8c0 17.59 14.4 32.06 31.1 32.06l114.2-.0712l90.5 81.85c27.5 22.37 67.75 18.12 89.1-9.25l18.12 15.25c15.87 12.1 39.37 10.5 52.37-5.371l13.02-16.03L39.93 127.1L32 127.1z\"\n ]\n};\nvar faHandshakeAltSlash = faHandshakeSimpleSlash;\nvar faHandshakeSlash = {\n prefix: 'fas',\n iconName: 'handshake-slash',\n icon: [\n 640,\n 512,\n [],\n \"e060\",\n \"M543.1 128.2l.0002 223.8c0 17.62 14.25 31.99 31.1 31.99h64V128.1L543.1 128.2zM591.1 352c-8.75 0-16-7.251-16-15.99c0-8.875 7.25-15.1 16-15.1c8.75 0 15.1 7.122 15.1 15.1C607.1 344.8 600.7 352 591.1 352zM.0005 128.2v255.7l63.1 .0446c17.75 0 32-14.28 32-32.03L96 171.9l-55.77-43.71H.0005zM64 336c0 8.742-7.25 15.99-15.1 15.99s-15.1-7.251-15.1-15.99c0-8.875 7.25-15.1 15.1-15.1S64 327.2 64 336zM128 351.8h18.25l90.5 81.85c27.5 22.37 67.75 18.12 89.1-9.25l18.12 15.25c15.87 12.1 39.37 10.5 52.37-5.371l13.02-16.03L128 196.1V351.8zM495.2 362.8c-.1875-9.101-3.824-18.05-11.44-24.24l-149.2-121.1l-11.47 10.51L297.5 207.9l65.33-59.79c6.5-5.871 16.75-5.496 22.62 1c5.1 6.496 5.5 16.62-1 22.62l-26.12 23.87l145.6 118.1c2.875 2.496 5.5 4.996 7.875 7.742V127.1c-40.98-40.96-96.52-63.98-154.5-63.98h-8.613c-7.941 0-15.64 2.97-21.5 8.329L233.7 157.9L208.3 137.9l80.85-73.92L282.5 64c-43.47 0-85.16 13.68-120.8 37.45L38.81 5.109C34.41 1.672 29.19 0 24.03 0C16.91 0 9.846 3.156 5.127 9.187C-3.06 19.62-1.248 34.72 9.19 42.89l591.1 463.1c10.5 8.203 25.56 6.328 33.69-4.078c8.187-10.44 6.375-25.53-4.062-33.7L495.2 362.8z\"\n ]\n};\nvar faHanukiah = {\n prefix: 'fas',\n iconName: 'hanukiah',\n icon: [\n 640,\n 512,\n [\n 128334\n ],\n \"f6e6\",\n \"M231.1 159.9C227.6 159.9 224 163.6 224 168V288h32V168C256 163.6 252.4 160 248 160L231.1 159.9zM167.1 159.9C163.6 159.9 160 163.6 160 168V288h32V168C192 163.6 188.4 160 184 160L167.1 159.9zM392 160C387.6 160 384 163.6 384 168V288h32V168c0-4.375-3.625-8.061-8-8.061L392 160zM456 160C451.6 160 448 163.6 448 168V288h32V168c0-4.375-3.625-8.061-8-8.061L456 160zM544 168c0-4.375-3.625-8.061-8-8.061L520 160C515.6 160 512 163.6 512 168V288h32V168zM103.1 159.9C99.62 159.9 96 163.6 96 168V288h32V168C128 163.6 124.4 160 120 160L103.1 159.9zM624 160h-31.98c-8.837 0-16.03 7.182-16.03 16.02L576 288c0 17.6-14.4 32-32 32h-192V128c0-8.837-7.151-16.01-15.99-16.01H303.1C295.2 111.1 288 119.2 288 128v192H96c-17.6 0-32-14.4-32-32l.0065-112C64.01 167.2 56.85 160 48.02 160H16C7.163 160 0 167.2 0 176V288c0 53.02 42.98 96 96 96h192v64H175.1C149.5 448 128 469.5 128 495.1C128 504.8 135.2 512 143.1 512h352C504.9 512 512 504.9 512 496C512 469.5 490.5 448 464 448H352v-64h192c53.02 0 96-42.98 96-96V176C640 167.2 632.8 160 624 160zM607.1 127.9C621.2 127.9 632 116 632 101.4C632 86.62 608 48 608 48s-24 38.62-24 53.38C584 116 594.7 127.9 607.1 127.9zM31.1 127.9C45.25 127.9 56 116 56 101.4C56 86.62 32 48 32 48S8 86.62 8 101.4C8 116 18.75 127.9 31.1 127.9zM319.1 79.94c13.25 0 24-11.94 24-26.57C344 38.62 320 0 320 0S296 38.62 296 53.38C296 67.1 306.7 79.94 319.1 79.94zM112 128c13.25 0 24-12 24-26.62C136 86.62 112 48 112 48S88 86.62 88 101.4C88 115.1 98.75 128 112 128zM176 128c13.25 0 24-12 24-26.62C200 86.62 176 48 176 48S152 86.62 152 101.4C152 115.1 162.8 128 176 128zM240 128c13.25 0 24-12 24-26.62C264 86.62 240 48 240 48S216 86.62 216 101.4C216 115.1 226.8 128 240 128zM400 128c13.25 0 24-12 24-26.62C424 86.62 400 48 400 48s-24 38.62-24 53.38C376 115.1 386.8 128 400 128zM464 128c13.25 0 24-12 24-26.62C488 86.62 464 48 464 48s-24 38.62-24 53.38C440 115.1 450.8 128 464 128zM528 128c13.25 0 24-12 24-26.62C552 86.62 528 48 528 48s-24 38.62-24 53.38C504 115.1 514.8 128 528 128z\"\n ]\n};\nvar faHardDrive = {\n prefix: 'fas',\n iconName: 'hard-drive',\n icon: [\n 512,\n 512,\n [\n 128436,\n \"hdd\"\n ],\n \"f0a0\",\n \"M464 288h-416C21.5 288 0 309.5 0 336v96C0 458.5 21.5 480 48 480h416c26.5 0 48-21.5 48-48v-96C512 309.5 490.5 288 464 288zM320 416c-17.62 0-32-14.38-32-32s14.38-32 32-32s32 14.38 32 32S337.6 416 320 416zM416 416c-17.62 0-32-14.38-32-32s14.38-32 32-32s32 14.38 32 32S433.6 416 416 416zM464 32h-416C21.5 32 0 53.5 0 80v192.4C13.41 262.3 29.92 256 48 256h416c18.08 0 34.59 6.254 48 16.41V80C512 53.5 490.5 32 464 32z\"\n ]\n};\nvar faHdd = faHardDrive;\nvar faHashtag = {\n prefix: 'fas',\n iconName: 'hashtag',\n icon: [\n 448,\n 512,\n [\n 62098\n ],\n \"23\",\n \"M416 127.1h-58.23l9.789-58.74c2.906-17.44-8.875-33.92-26.3-36.83c-17.53-2.875-33.92 8.891-36.83 26.3L292.9 127.1H197.8l9.789-58.74c2.906-17.44-8.875-33.92-26.3-36.83c-17.53-2.875-33.92 8.891-36.83 26.3L132.9 127.1H64c-17.67 0-32 14.33-32 32C32 177.7 46.33 191.1 64 191.1h58.23l-21.33 128H32c-17.67 0-32 14.33-32 32c0 17.67 14.33 31.1 32 31.1h58.23l-9.789 58.74c-2.906 17.44 8.875 33.92 26.3 36.83C108.5 479.9 110.3 480 112 480c15.36 0 28.92-11.09 31.53-26.73l11.54-69.27h95.12l-9.789 58.74c-2.906 17.44 8.875 33.92 26.3 36.83C268.5 479.9 270.3 480 272 480c15.36 0 28.92-11.09 31.53-26.73l11.54-69.27H384c17.67 0 32-14.33 32-31.1c0-17.67-14.33-32-32-32h-58.23l21.33-128H416c17.67 0 32-14.32 32-31.1C448 142.3 433.7 127.1 416 127.1zM260.9 319.1H165.8L187.1 191.1h95.12L260.9 319.1z\"\n ]\n};\nvar faHatCowboy = {\n prefix: 'fas',\n iconName: 'hat-cowboy',\n icon: [\n 640,\n 512,\n [],\n \"f8c0\",\n \"M489.1 264.9C480.5 207.5 450.5 32 392.3 32c-14 0-26.58 5.875-37.08 14c-20.75 15.87-49.62 15.87-70.5 0C274.2 38 261.7 32 247.7 32c-58.25 0-88.27 175.5-97.77 232.9C188.7 277.5 243.7 288 319.1 288S451.2 277.5 489.1 264.9zM632.9 227.7c-6.125-4.125-14.2-3.51-19.7 1.49c-1 .875-101.3 90.77-293.1 90.77c-190.9 0-292.2-89.99-293.2-90.86c-5.5-4.875-13.71-5.508-19.71-1.383c-6.125 4.125-8.587 11.89-6.087 18.77C1.749 248.5 78.37 448 319.1 448s318.2-199.5 318.1-201.5C641.5 239.6 639 231.9 632.9 227.7z\"\n ]\n};\nvar faHatCowboySide = {\n prefix: 'fas',\n iconName: 'hat-cowboy-side',\n icon: [\n 640,\n 512,\n [],\n \"f8c1\",\n \"M260.8 260C232.1 237.1 198.8 225 164.4 225c-77.38 0-142.9 62.75-163 156c-3.5 16.62-.375 33.88 8.625 47.38c8.75 13.12 21.88 20.62 35.88 20.62H592c-103.2 0-155-37.13-233.2-104.5L260.8 260zM495.5 241.8l-27.13-156.5c-2.875-17.25-12.75-32.5-27.12-42.25c-14.37-9.75-32.24-13.3-49.24-9.675L200.9 74.02C173.7 79.77 153.5 102.3 150.5 129.8L143.6 195c6.875-.875 13.62-2 20.75-2c41.87 0 82 14.5 117.4 42.88l98 84.37c71 61.25 115.1 96.75 212.2 96.75c26.5 0 48-21.5 48-48C640 343.6 610.4 249.6 495.5 241.8z\"\n ]\n};\nvar faHatWizard = {\n prefix: 'fas',\n iconName: 'hat-wizard',\n icon: [\n 512,\n 512,\n [],\n \"f6e8\",\n \"M200 376l-49.23-16.41c-7.289-2.434-7.289-12.75 0-15.18L200 328l16.41-49.23c2.434-7.289 12.75-7.289 15.18 0L248 328l49.23 16.41c7.289 2.434 7.289 12.75 0 15.18L248 376L240 416H448l-86.38-201.6C355.4 200 354.8 183.8 359.8 168.9L416 0L228.4 107.3C204.8 120.8 185.1 141.4 175 166.4L64 416h144L200 376zM231.2 172.4L256 160l12.42-24.84c1.477-2.949 5.68-2.949 7.156 0L288 160l24.84 12.42c2.949 1.477 2.949 5.68 0 7.156L288 192l-12.42 24.84c-1.477 2.949-5.68 2.949-7.156 0L256 192L231.2 179.6C228.2 178.1 228.2 173.9 231.2 172.4zM496 448h-480C7.164 448 0 455.2 0 464C0 490.5 21.49 512 48 512h416c26.51 0 48-21.49 48-48C512 455.2 504.8 448 496 448z\"\n ]\n};\nvar faHeadSideCough = {\n prefix: 'fas',\n iconName: 'head-side-cough',\n icon: [\n 640,\n 512,\n [],\n \"e061\",\n \"M608 359.1c-13.25 0-24 10.75-24 24s10.75 24 24 24s24-10.75 24-24S621.3 359.1 608 359.1zM477.2 275c-21-47.13-48.49-151.8-73.11-186.8C365.6 33.63 302.5 0 234.1 0L192 0C86 0 0 86 0 192c0 56.75 24.75 107.6 64 142.9L64 512h223.1v-32h64.01c35.38 0 64-28.62 64-63.1L320 416c-17.67 0-32-14.33-32-32s14.33-32 32-32h95.98l-.003-32h31.99C471.1 320 486.6 296.1 477.2 275zM336 224c-17.62 0-32-14.38-32-32s14.38-32 32-32s32 14.38 32 32S353.6 224 336 224zM480 359.1c-13.25 0-23.1 10.75-23.1 24s10.75 24 23.1 24s24-10.75 24-24S493.3 359.1 480 359.1zM608 311.1c13.25 0 24-10.75 24-24s-10.75-24-24-24s-24 10.75-24 24S594.8 311.1 608 311.1zM544 311.1c-13.25 0-23.1 10.75-23.1 24s10.75 24 23.1 24s24-10.75 24-24S557.3 311.1 544 311.1zM544 407.1c-13.25 0-23.1 10.75-23.1 24s10.75 24 23.1 24s24-10.75 24-24S557.3 407.1 544 407.1zM608 455.1c-13.25 0-24 10.75-24 24s10.75 24 24 24s24-10.75 24-24S621.3 455.1 608 455.1z\"\n ]\n};\nvar faHeadSideCoughSlash = {\n prefix: 'fas',\n iconName: 'head-side-cough-slash',\n icon: [\n 640,\n 512,\n [],\n \"e062\",\n \"M607.1 311.1c13.25 0 24-10.75 24-23.1s-10.75-23.1-24-23.1s-23.1 10.75-23.1 23.1S594.7 311.1 607.1 311.1zM607.1 407.1c13.25 0 24-10.78 24-24.03c0-13.25-10.75-23.1-24-23.1s-24 10.78-24 24.03C583.1 397.2 594.7 407.1 607.1 407.1zM630.8 469.1l-190.2-149.1h7.4c23.12 0 38.62-23.87 29.25-44.1c-20.1-47.12-48.49-151.7-73.11-186.7C365.6 33.63 302.5 0 234.1 0H192C149.9 0 111.5 14.26 79.88 37.29L38.81 5.109C34.41 1.672 29.19 0 24.03 0C16.91 0 9.845 3.156 5.126 9.187c-8.187 10.44-6.375 25.53 4.062 33.7l591.1 463.1c10.5 8.203 25.56 6.328 33.69-4.078C643.1 492.4 641.2 477.3 630.8 469.1zM320 415.1c-17.67 0-31.1-14.33-31.1-31.1S302.3 351.1 320 351.1l5.758-.0009L18.16 110.9C6.631 135.6 .0006 162.1 .0006 191.1c0 56.75 24.75 107.6 64 142.9L64 511.1h223.1l0-31.1l64.01 .001c33.25 0 60.2-25.38 63.37-57.78l-7.932-6.217H320zM543.1 359.1c13.25 0 24-10.78 24-24.03s-10.75-23.1-24-23.1c-13.25 0-24 10.78-24 24.03C519.1 349.2 530.7 359.1 543.1 359.1z\"\n ]\n};\nvar faHeadSideMask = {\n prefix: 'fas',\n iconName: 'head-side-mask',\n icon: [\n 512,\n 512,\n [],\n \"e063\",\n \"M.1465 184.4C-2.166 244.2 23.01 298 63.99 334.9L63.99 512h160L224 316.5L3.674 156.2C1.871 165.4 .5195 174.8 .1465 184.4zM336 368H496L512 320h-255.1l.0178 192h145.9c27.55 0 52-17.63 60.71-43.76L464 464h-127.1c-8.836 0-16-7.164-16-16c0-8.838 7.164-16 16-16h138.7l10.67-32h-149.3c-8.836 0-16-7.164-16-16C320 375.2 327.2 368 336 368zM509.2 275c-20.1-47.13-48.49-151.8-73.11-186.8C397.6 33.63 334.5 0 266.1 0H200C117.1 0 42.48 50.57 13.25 123.7L239.2 288h272.6C511.8 283.7 511.1 279.3 509.2 275zM352 224c-17.62 0-32-14.38-32-32s14.38-32 32-32c17.62 0 31.1 14.38 31.1 32S369.6 224 352 224z\"\n ]\n};\nvar faHeadSideVirus = {\n prefix: 'fas',\n iconName: 'head-side-virus',\n icon: [\n 512,\n 512,\n [],\n \"e064\",\n \"M208 175.1c-8.836 0-16 7.162-16 16c0 8.836 7.163 15.1 15.1 15.1s16-7.164 16-16C224 183.2 216.8 175.1 208 175.1zM272 239.1c-8.836 0-15.1 7.163-15.1 16c0 8.836 7.165 16 16 16s16-7.164 16-16C288 247.2 280.8 239.1 272 239.1zM509.2 275c-20.94-47.13-48.46-151.7-73.1-186.8C397.7 33.59 334.6 0 266.1 0H192C85.95 0 0 85.95 0 192c0 56.8 24.8 107.7 64 142.8L64 512h256l-.0044-64h63.99c35.34 0 63.1-28.65 63.1-63.1V320h31.98C503.1 320 518.6 296.2 509.2 275zM368 240h-12.12c-28.51 0-42.79 34.47-22.63 54.63l8.576 8.576c6.25 6.25 6.25 16.38 0 22.62c-3.125 3.125-7.219 4.688-11.31 4.688s-8.188-1.562-11.31-4.688l-8.576-8.576c-20.16-20.16-54.63-5.881-54.63 22.63V352c0 8.844-7.156 16-16 16s-16-7.156-16-16v-12.12c0-28.51-34.47-42.79-54.63-22.63l-8.576 8.576c-3.125 3.125-7.219 4.688-11.31 4.688c-4.096 0-8.188-1.562-11.31-4.688c-6.25-6.25-6.25-16.38 0-22.62l8.577-8.576C166.9 274.5 152.6 240 124.1 240H112c-8.844 0-16-7.156-16-16s7.157-16 16-16L124.1 208c28.51 0 42.79-34.47 22.63-54.63L138.2 144.8c-6.25-6.25-6.25-16.38 0-22.62s16.38-6.25 22.63 0L169.4 130.7c20.16 20.16 54.63 5.881 54.63-22.63V96c0-8.844 7.156-16 16-16S256 87.16 256 96v12.12c0 28.51 34.47 42.79 54.63 22.63l8.576-8.576c6.25-6.25 16.38-6.25 22.63 0s6.25 16.38 0 22.62L333.3 153.4C313.1 173.5 327.4 208 355.9 208l12.12-.0004c8.844 0 15.1 7.157 15.1 16S376.8 240 368 240z\"\n ]\n};\nvar faHeading = {\n prefix: 'fas',\n iconName: 'heading',\n icon: [\n 448,\n 512,\n [\n \"header\"\n ],\n \"f1dc\",\n \"M448 448c0 17.69-14.33 32-32 32h-96c-17.67 0-32-14.31-32-32s14.33-32 32-32h16v-144h-224v144H128c17.67 0 32 14.31 32 32s-14.33 32-32 32H32c-17.67 0-32-14.31-32-32s14.33-32 32-32h16v-320H32c-17.67 0-32-14.31-32-32s14.33-32 32-32h96c17.67 0 32 14.31 32 32s-14.33 32-32 32H112v112h224v-112H320c-17.67 0-32-14.31-32-32s14.33-32 32-32h96c17.67 0 32 14.31 32 32s-14.33 32-32 32h-16v320H416C433.7 416 448 430.3 448 448z\"\n ]\n};\nvar faHeader = faHeading;\nvar faHeadphones = {\n prefix: 'fas',\n iconName: 'headphones',\n icon: [\n 512,\n 512,\n [\n 127911\n ],\n \"f025\",\n \"M512 287.9l-.0042 112C511.1 444.1 476.1 480 432 480c-26.47 0-48-21.56-48-48.06V304.1C384 277.6 405.5 256 432 256c10.83 0 20.91 2.723 30.3 6.678C449.7 159.1 362.1 80.13 256 80.13S62.29 159.1 49.7 262.7C59.09 258.7 69.17 256 80 256C106.5 256 128 277.6 128 304.1v127.9C128 458.4 106.5 480 80 480c-44.11 0-79.1-35.88-79.1-80.06L0 288c0-141.2 114.8-256 256-256c140.9 0 255.6 114.5 255.1 255.3C511.1 287.5 511.1 287.7 512 287.9z\"\n ]\n};\nvar faHeadphonesSimple = {\n prefix: 'fas',\n iconName: 'headphones-simple',\n icon: [\n 512,\n 512,\n [\n \"headphones-alt\"\n ],\n \"f58f\",\n \"M256 32C112.9 32 4.563 151.1 0 288v104C0 405.3 10.75 416 23.1 416S48 405.3 48 392V288c0-114.7 93.34-207.8 208-207.8C370.7 80.2 464 173.3 464 288v104C464 405.3 474.7 416 488 416S512 405.3 512 392V287.1C507.4 151.1 399.1 32 256 32zM160 288L144 288c-35.34 0-64 28.7-64 64.13v63.75C80 451.3 108.7 480 144 480L160 480c17.66 0 32-14.34 32-32.05v-127.9C192 302.3 177.7 288 160 288zM368 288L352 288c-17.66 0-32 14.32-32 32.04v127.9c0 17.7 14.34 32.05 32 32.05L368 480c35.34 0 64-28.7 64-64.13v-63.75C432 316.7 403.3 288 368 288z\"\n ]\n};\nvar faHeadphonesAlt = faHeadphonesSimple;\nvar faHeadset = {\n prefix: 'fas',\n iconName: 'headset',\n icon: [\n 512,\n 512,\n [],\n \"f590\",\n \"M191.1 224c0-17.72-14.34-32.04-32-32.04L144 192c-35.34 0-64 28.66-64 64.08v47.79C80 339.3 108.7 368 144 368H160c17.66 0 32-14.36 32-32.06L191.1 224zM256 0C112.9 0 4.583 119.1 .0208 256L0 296C0 309.3 10.75 320 23.1 320S48 309.3 48 296V256c0-114.7 93.34-207.8 208-207.8C370.7 48.2 464 141.3 464 256v144c0 22.09-17.91 40-40 40h-110.7C305 425.7 289.7 416 272 416H241.8c-23.21 0-44.5 15.69-48.87 38.49C187 485.2 210.4 512 239.1 512H272c17.72 0 33.03-9.711 41.34-24H424c48.6 0 88-39.4 88-88V256C507.4 119.1 399.1 0 256 0zM368 368c35.34 0 64-28.7 64-64.13V256.1C432 220.7 403.3 192 368 192l-16 0c-17.66 0-32 14.34-32 32.04L320 335.9C320 353.7 334.3 368 352 368H368z\"\n ]\n};\nvar faHeart = {\n prefix: 'fas',\n iconName: 'heart',\n icon: [\n 512,\n 512,\n [\n 128153,\n 128154,\n 128155,\n 128156,\n 128420,\n 129293,\n 129294,\n 129505,\n 10084,\n 61578,\n 9829\n ],\n \"f004\",\n \"M0 190.9V185.1C0 115.2 50.52 55.58 119.4 44.1C164.1 36.51 211.4 51.37 244 84.02L256 96L267.1 84.02C300.6 51.37 347 36.51 392.6 44.1C461.5 55.58 512 115.2 512 185.1V190.9C512 232.4 494.8 272.1 464.4 300.4L283.7 469.1C276.2 476.1 266.3 480 256 480C245.7 480 235.8 476.1 228.3 469.1L47.59 300.4C17.23 272.1 .0003 232.4 .0003 190.9L0 190.9z\"\n ]\n};\nvar faHeartCrack = {\n prefix: 'fas',\n iconName: 'heart-crack',\n icon: [\n 512,\n 512,\n [\n 128148,\n \"heart-broken\"\n ],\n \"f7a9\",\n \"M119.4 44.1C142.7 40.22 166.2 42.2 187.1 49.43L237.8 126.9L162.3 202.3C160.8 203.9 159.1 205.1 160 208.2C160 210.3 160.1 212.4 162.6 213.9L274.6 317.9C277.5 320.6 281.1 320.7 285.1 318.2C288.2 315.6 288.9 311.2 286.8 307.8L226.4 209.7L317.1 134.1C319.7 131.1 320.7 128.5 319.5 125.3L296.8 61.74C325.4 45.03 359.2 38.53 392.6 44.1C461.5 55.58 512 115.2 512 185.1V190.9C512 232.4 494.8 272.1 464.4 300.4L283.7 469.1C276.2 476.1 266.3 480 256 480C245.7 480 235.8 476.1 228.3 469.1L47.59 300.4C17.23 272.1 0 232.4 0 190.9V185.1C0 115.2 50.52 55.58 119.4 44.09V44.1z\"\n ]\n};\nvar faHeartBroken = faHeartCrack;\nvar faHeartPulse = {\n prefix: 'fas',\n iconName: 'heart-pulse',\n icon: [\n 576,\n 512,\n [\n \"heartbeat\"\n ],\n \"f21e\",\n \"M352.4 243.8l-49.83 99.5c-6.009 12-23.41 11.62-28.92-.625L216.7 216.3l-30.05 71.75L88.55 288l176.4 182.2c12.66 13.07 33.36 13.07 46.03 0l176.4-182.2l-112.1 .0052L352.4 243.8zM495.2 62.86c-54.36-46.98-137.5-38.5-187.5 13.06L288 96.25L268.3 75.92C218.3 24.36 135.2 15.88 80.81 62.86C23.37 112.5 16.84 197.6 60.18 256h105l35.93-86.25c5.508-12.88 23.66-13.12 29.54-.375l58.21 129.4l49.07-98c5.884-11.75 22.78-11.75 28.67 0l27.67 55.25h121.5C559.2 197.6 552.6 112.5 495.2 62.86z\"\n ]\n};\nvar faHeartbeat = faHeartPulse;\nvar faHelicopter = {\n prefix: 'fas',\n iconName: 'helicopter',\n icon: [\n 640,\n 512,\n [\n 128641\n ],\n \"f533\",\n \"M127.1 32C127.1 14.33 142.3 0 159.1 0H544C561.7 0 576 14.33 576 32C576 49.67 561.7 64 544 64H384V128H416C504.4 128 576 199.6 576 288V352C576 369.7 561.7 384 544 384H303.1C293.9 384 284.4 379.3 278.4 371.2L191.1 256L47.19 198.1C37.65 194.3 30.52 186.1 28.03 176.1L4.97 83.88C2.445 73.78 10.08 64 20.49 64H47.1C58.07 64 67.56 68.74 73.6 76.8L111.1 128H319.1V64H159.1C142.3 64 127.1 49.67 127.1 32V32zM384 320H512V288C512 234.1 469 192 416 192H384V320zM630.6 470.6L626.7 474.5C602.7 498.5 570.2 512 536.2 512H255.1C238.3 512 223.1 497.7 223.1 480C223.1 462.3 238.3 448 255.1 448H536.2C553.2 448 569.5 441.3 581.5 429.3L585.4 425.4C597.9 412.9 618.1 412.9 630.6 425.4C643.1 437.9 643.1 458.1 630.6 470.6L630.6 470.6z\"\n ]\n};\nvar faHelmetSafety = {\n prefix: 'fas',\n iconName: 'helmet-safety',\n icon: [\n 576,\n 512,\n [\n \"hard-hat\",\n \"hat-hard\"\n ],\n \"f807\",\n \"M544 280.9c0-89.17-61.83-165.4-139.6-197.4L352 174.2V49.78C352 39.91 344.1 32 334.2 32H241.8C231.9 32 224 39.91 224 49.78v124.4L171.6 83.53C93.83 115.5 32 191.7 32 280.9L31.99 352h512L544 280.9zM574.7 393.7C572.2 387.8 566.4 384 560 384h-544c-6.375 0-12.16 3.812-14.69 9.656c-2.531 5.875-1.344 12.69 3.062 17.34C7.031 413.8 72.02 480 287.1 480s280.1-66.19 283.6-69C576 406.3 577.2 399.5 574.7 393.7z\"\n ]\n};\nvar faHardHat = faHelmetSafety;\nvar faHatHard = faHelmetSafety;\nvar faHighlighter = {\n prefix: 'fas',\n iconName: 'highlighter',\n icon: [\n 576,\n 512,\n [],\n \"f591\",\n \"M143.1 320V248.3C143.1 233 151.2 218.7 163.5 209.6L436.6 8.398C444 2.943 452.1 0 462.2 0C473.6 0 484.5 4.539 492.6 12.62L547.4 67.38C555.5 75.46 559.1 86.42 559.1 97.84C559.1 107 557.1 115.1 551.6 123.4L350.4 396.5C341.3 408.8 326.1 416 311.7 416H239.1L214.6 441.4C202.1 453.9 181.9 453.9 169.4 441.4L118.6 390.6C106.1 378.1 106.1 357.9 118.6 345.4L143.1 320zM489.4 99.92L460.1 70.59L245 229L330.1 314.1L489.4 99.92zM23.03 466.3L86.06 403.3L156.7 473.9L125.7 504.1C121.2 509.5 115.1 512 108.7 512H40C26.75 512 16 501.3 16 488V483.3C16 476.1 18.53 470.8 23.03 466.3V466.3z\"\n ]\n};\nvar faHippo = {\n prefix: 'fas',\n iconName: 'hippo',\n icon: [\n 640,\n 512,\n [\n 129435\n ],\n \"f6ed\",\n \"M584.2 96.36c-28.88-1.701-54.71 17.02-79.74 26.49C490 88.22 455.9 64 416 64c-11.25 0-22 2.252-32 5.877V56C384 42.75 373.2 32 360 32h-16C330.8 32 320 42.75 320 56v49C285.1 79.62 241.2 64 192 64C85.1 64 0 135.6 0 224v232C0 469.3 10.75 480 24 480h48C85.25 480 96 469.3 96 456v-62.87C128.4 407.5 166.8 416 208 416s79.63-8.492 112-22.87V456c0 13.25 10.75 24 24 24h48c13.25 0 24-10.75 24-24V288h128v32c0 8.837 7.163 16 16 16h32c8.837 0 16-7.163 16-16V288c17.62 0 32-14.38 32-32l-.0001-96.07C639.1 127.8 616.4 98.25 584.2 96.36zM447.1 176c-8.875 0-16-7.125-16-16S439.1 144 448 144s16 7.125 16 16S456.9 176 447.1 176z\"\n ]\n};\nvar faHockeyPuck = {\n prefix: 'fas',\n iconName: 'hockey-puck',\n icon: [\n 512,\n 512,\n [],\n \"f453\",\n \"M0 160c0-53 114.6-96 256-96s256 43 256 96s-114.6 96-256 96S0 213 0 160zM255.1 303.1C156.4 303.1 56.73 283.4 0 242.2V352c0 53 114.6 96 256 96s256-43 256-96V242.2C455.3 283.4 355.6 303.1 255.1 303.1z\"\n ]\n};\nvar faHollyBerry = {\n prefix: 'fas',\n iconName: 'holly-berry',\n icon: [\n 512,\n 512,\n [],\n \"f7aa\",\n \"M287.1 143.1c0 26.5 21.5 47.1 47.1 47.1c26.5 0 48-21.5 48-47.1s-21.5-47.1-48-47.1C309.5 95.99 287.1 117.5 287.1 143.1zM176 191.1c26.5 0 47.1-21.5 47.1-47.1S202.5 95.96 176 95.96c-26.5 0-47.1 21.5-47.1 47.1S149.5 191.1 176 191.1zM303.1 47.1C303.1 21.5 282.5 0 255.1 0c-26.5 0-47.1 21.5-47.1 47.1S229.5 95.99 255.1 95.99C282.5 95.99 303.1 74.5 303.1 47.1zM243.7 242.6C245.3 229.7 231.9 220.1 219.5 225.5C179.7 242.8 137.8 251.4 96.72 250.8C86.13 250.6 78.49 260.7 81.78 270.4C86.77 285.7 90.33 301.4 92.44 317.7c2.133 16.15-9.387 31.26-26.12 34.23c-16.87 2.965-33.7 4.348-50.48 4.152c-10.6-.0586-18.37 10.05-15.08 19.74c12.4 35.79 16.57 74.93 12.12 114.7c-1.723 14.96 13.71 25.67 28.02 19.8c38.47-15.95 78.77-23.81 118.2-23.34c10.58 .1953 18.36-9.91 15.07-19.6c-5.141-15.15-8.68-31.06-10.79-47.34c-2.133-16.16 9.371-31.13 26.24-34.09c16.73-2.973 33.57-4.496 50.36-4.301c10.73 .0781 18.51-10.03 15.22-19.72C242.5 324.7 238.5 283.9 243.7 242.6zM496.2 356.1c-16.78 .1953-33.61-1.188-50.48-4.152c-16.73-2.973-28.25-18.08-26.12-34.23c2.115-16.28 5.67-32.05 10.66-47.32c3.289-9.691-4.35-19.81-14.93-19.62c-41.11 .6484-83.01-7.965-122.7-25.23c-6.85-2.969-13.71-1.18-18.47 2.953c1.508 5.836 2.102 11.93 1.332 18.05c-4.539 36.23-1.049 72.56 10.12 105.1c3.395 9.988 3.029 20.73-.4766 30.52c12.44 .5 24.89 1.602 37.28 3.801c16.87 2.957 28.37 17.93 26.24 34.09c-2.115 16.27-5.654 32.19-10.79 47.34c-3.289 9.691 4.486 19.8 15.07 19.6c39.47-.4766 79.77 7.383 118.2 23.34c14.31 5.867 29.74-4.844 28.02-19.8c-4.451-39.81-.2832-78.95 12.12-114.7C514.5 366.1 506.8 356 496.2 356.1z\"\n ]\n};\nvar faHorse = {\n prefix: 'fas',\n iconName: 'horse',\n icon: [\n 576,\n 512,\n [\n 128014\n ],\n \"f6f0\",\n \"M575.9 76.61c0-8.125-3.05-15.84-8.55-21.84c-3.875-4-8.595-9.125-13.72-14.5c11.12-6.75 19.47-17.51 22.22-30.63c.9999-5-2.849-9.641-7.974-9.641L447.9 0c-70.62 0-127.9 57.25-127.9 128L159.1 128c-28.87 0-54.38 12.1-72 33.12L87.1 160C39.5 160 .0001 199.5 .0001 248L0 304c0 8.875 7.125 15.1 15.1 15.1L31.1 320c8.874 0 15.1-7.125 15.1-16l.0005-56c0-13.25 6.884-24.4 16.76-31.65c-.125 2.5-.758 5.024-.758 7.649c0 27.62 11.87 52.37 30.5 69.87l-25.65 68.61c-4.586 12.28-5.312 25.68-2.128 38.4l21.73 86.89C92.02 502 104.8 512 119.5 512h32.98c20.81 0 36.08-19.55 31.05-39.74L162.2 386.9l23.78-63.61l133.1 22.34L319.1 480c0 17.67 14.33 32 31.1 32h31.1c17.67 0 31.1-14.33 31.1-32l.0166-161.8C435.7 297.1 447.1 270.5 447.1 240c0-.25-.1025-.3828-.1025-.6328V136.9L463.9 144l18.95 37.72c7.481 14.86 25.08 21.55 40.52 15.34l32.54-13.05c12.13-4.878 20.11-16.67 20.09-29.74L575.9 76.61zM511.9 96c-8.75 0-15.1-7.125-15.1-16S503.1 64 511.9 64c8.874 0 15.1 7.125 15.1 16S520.8 96 511.9 96z\"\n ]\n};\nvar faHorseHead = {\n prefix: 'fas',\n iconName: 'horse-head',\n icon: [\n 512,\n 512,\n [],\n \"f7ab\",\n \"M509.8 332.5l-69.89-164.3c-14.88-41.25-50.38-70.98-93.01-79.24c18-10.63 46.35-35.9 34.23-82.29c-1.375-5.001-7.112-7.972-11.99-6.097l-202.3 75.66C35.89 123.4 0 238.9 0 398.8v81.24C0 497.7 14.25 512 32 512h236.2c23.75 0 39.3-25.03 28.55-46.28l-40.78-81.71V383.3c-45.63-3.5-84.66-30.7-104.3-69.58c-1.625-3.125-.9342-6.951 1.566-9.327l12.11-12.11c3.875-3.875 10.64-2.692 12.89 2.434c14.88 33.63 48.17 57.38 87.42 57.38c17.13 0 33.05-5.091 46.8-13.22l46 63.9c6 8.501 15.75 13.34 26 13.34h50.28c8.501 0 16.61-3.388 22.61-9.389l45.34-39.84C511.6 357.7 514.4 344.2 509.8 332.5zM328.1 223.1c-13.25 0-23.96-10.75-23.96-24c0-13.25 10.75-23.92 24-23.92s23.94 10.73 23.94 23.98C352 213.3 341.3 223.1 328.1 223.1z\"\n ]\n};\nvar faHospital = {\n prefix: 'fas',\n iconName: 'hospital',\n icon: [\n 640,\n 512,\n [\n 127973,\n 62589,\n \"hospital-alt\",\n \"hospital-wide\"\n ],\n \"f0f8\",\n \"M192 48C192 21.49 213.5 0 240 0H400C426.5 0 448 21.49 448 48V512H368V432C368 405.5 346.5 384 320 384C293.5 384 272 405.5 272 432V512H192V48zM312 64C303.2 64 296 71.16 296 80V104H272C263.2 104 256 111.2 256 120V136C256 144.8 263.2 152 272 152H296V176C296 184.8 303.2 192 312 192H328C336.8 192 344 184.8 344 176V152H368C376.8 152 384 144.8 384 136V120C384 111.2 376.8 104 368 104H344V80C344 71.16 336.8 64 328 64H312zM160 96V512H48C21.49 512 0 490.5 0 464V320H80C88.84 320 96 312.8 96 304C96 295.2 88.84 288 80 288H0V224H80C88.84 224 96 216.8 96 208C96 199.2 88.84 192 80 192H0V144C0 117.5 21.49 96 48 96H160zM592 96C618.5 96 640 117.5 640 144V192H560C551.2 192 544 199.2 544 208C544 216.8 551.2 224 560 224H640V288H560C551.2 288 544 295.2 544 304C544 312.8 551.2 320 560 320H640V464C640 490.5 618.5 512 592 512H480V96H592z\"\n ]\n};\nvar faHospitalAlt = faHospital;\nvar faHospitalWide = faHospital;\nvar faHospitalUser = {\n prefix: 'fas',\n iconName: 'hospital-user',\n icon: [\n 576,\n 512,\n [],\n \"f80d\",\n \"M272 0C298.5 0 320 21.49 320 48V367.8C281.8 389.2 256 430 256 476.9C256 489.8 259.6 501.8 265.9 512H48C21.49 512 0 490.5 0 464V384H144C152.8 384 160 376.8 160 368C160 359.2 152.8 352 144 352H0V288H144C152.8 288 160 280.8 160 272C160 263.2 152.8 256 144 256H0V48C0 21.49 21.49 0 48 0H272zM152 64C143.2 64 136 71.16 136 80V104H112C103.2 104 96 111.2 96 120V136C96 144.8 103.2 152 112 152H136V176C136 184.8 143.2 192 152 192H168C176.8 192 184 184.8 184 176V152H208C216.8 152 224 144.8 224 136V120C224 111.2 216.8 104 208 104H184V80C184 71.16 176.8 64 168 64H152zM512 272C512 316.2 476.2 352 432 352C387.8 352 352 316.2 352 272C352 227.8 387.8 192 432 192C476.2 192 512 227.8 512 272zM288 477.1C288 425.7 329.7 384 381.1 384H482.9C534.3 384 576 425.7 576 477.1C576 496.4 560.4 512 541.1 512H322.9C303.6 512 288 496.4 288 477.1V477.1z\"\n ]\n};\nvar faHotTubPerson = {\n prefix: 'fas',\n iconName: 'hot-tub-person',\n icon: [\n 512,\n 512,\n [\n \"hot-tub\"\n ],\n \"f593\",\n \"M414.3 177.6C415.3 185.9 421.1 192 429.1 192h16.13c9.5 0 17-8.625 16-18.38C457.8 134.5 439.6 99.12 412 76.5c-17.38-14.12-28.88-36.75-32-62.12C379 6.125 372.3 0 364.3 0h-16.12c-9.5 0-17.12 8.625-16 18.38c4.375 39.12 22.38 74.5 50.13 97.13C399.6 129.6 411 152.2 414.3 177.6zM306.3 177.6C307.3 185.9 313.1 192 321.1 192h16.13c9.5 0 17-8.625 16-18.38C349.8 134.5 331.6 99.12 304 76.5c-17.38-14.12-28.88-36.75-32-62.12C271 6.125 264.3 0 256.3 0h-16.17C230.6 0 223 8.625 224.1 18.38C228.5 57.5 246.5 92.88 274.3 115.5C291.6 129.6 303 152.2 306.3 177.6zM480 256h-224L145.1 172.8C133.1 164.5 120.5 160 106.6 160H64C28.62 160 0 188.6 0 224v224c0 35.38 28.62 64 64 64h384c35.38 0 64-28.62 64-64V288C512 270.4 497.6 256 480 256zM128 440C128 444.4 124.4 448 120 448h-16C99.62 448 96 444.4 96 440v-112C96 323.6 99.62 320 104 320h16C124.4 320 128 323.6 128 328V440zM224 440C224 444.4 220.4 448 216 448h-16C195.6 448 192 444.4 192 440v-112C192 323.6 195.6 320 200 320h16C220.4 320 224 323.6 224 328V440zM320 440c0 4.375-3.625 8-8 8h-16C291.6 448 288 444.4 288 440v-112c0-4.375 3.625-8 8-8h16c4.375 0 8 3.625 8 8V440zM416 440c0 4.375-3.625 8-8 8h-16C387.6 448 384 444.4 384 440v-112c0-4.375 3.625-8 8-8h16c4.375 0 8 3.625 8 8V440zM64 128c35.38 0 64-28.62 64-64S99.38 0 64 0S0 28.62 0 64S28.62 128 64 128z\"\n ]\n};\nvar faHotTub = faHotTubPerson;\nvar faHotdog = {\n prefix: 'fas',\n iconName: 'hotdog',\n icon: [\n 512,\n 512,\n [\n 127789\n ],\n \"f80f\",\n \"M488.6 23.44c-31.06-31.19-81.76-31.16-112.8 .0313L24.46 374.8c-20.83 19.96-29.19 49.66-21.83 77.6c7.36 27.94 29.07 49.65 57.02 57.01c27.94 7.36 57.64-1 77.6-21.83l351.3-351.3C519.7 105.2 519.8 54.5 488.6 23.44zM438.8 118.4c-19.59 19.59-37.39 22.52-51.74 25.01c-12.97 2.246-22.33 3.867-34.68 16.22c-12.35 12.35-13.97 21.71-16.22 34.69c-2.495 14.35-5.491 32.19-25.08 51.78c-19.59 19.59-37.43 22.58-51.78 25.08C246.3 273.4 236.9 275.1 224.6 287.4c-12.35 12.35-13.97 21.71-16.22 34.68C205.9 336.4 202.9 354.3 183.3 373.9c-19.59 19.59-37.43 22.58-51.78 25.08C118.5 401.2 109.2 402.8 96.83 415.2c-6.238 6.238-16.34 6.238-22.58 0c-6.238-6.238-6.238-16.35 0-22.58c19.59-19.59 37.43-22.58 51.78-25.07c12.97-2.245 22.33-3.869 34.68-16.22c12.35-12.35 13.97-21.71 16.22-34.69c2.495-14.35 5.492-32.19 25.08-51.78s37.43-22.58 51.78-25.08c12.97-2.246 22.33-3.869 34.68-16.22s13.97-21.71 16.22-34.68c2.495-14.35 5.492-32.19 25.08-51.78c19.59-19.59 37.43-22.58 51.78-25.07c12.97-2.246 22.28-3.815 34.63-16.17c6.238-6.238 16.36-6.238 22.59 0C444.1 102.1 444.1 112.2 438.8 118.4zM32.44 321.5l290-290l-11.48-11.6c-24.95-24.95-63.75-26.57-86.58-3.743L17.1 223.4C-5.73 246.3-4.108 285.1 20.84 310L32.44 321.5zM480.6 189.5l-290 290l11.48 11.6c24.95 24.95 63.75 26.57 86.58 3.743l207.3-207.3c22.83-22.83 21.21-61.63-3.743-86.58L480.6 189.5z\"\n ]\n};\nvar faHotel = {\n prefix: 'fas',\n iconName: 'hotel',\n icon: [\n 512,\n 512,\n [\n 127976\n ],\n \"f594\",\n \"M480 0C497.7 0 512 14.33 512 32C512 49.67 497.7 64 480 64V448C497.7 448 512 462.3 512 480C512 497.7 497.7 512 480 512H304V448H208V512H32C14.33 512 0 497.7 0 480C0 462.3 14.33 448 32 448V64C14.33 64 0 49.67 0 32C0 14.33 14.33 0 32 0H480zM112 96C103.2 96 96 103.2 96 112V144C96 152.8 103.2 160 112 160H144C152.8 160 160 152.8 160 144V112C160 103.2 152.8 96 144 96H112zM224 144C224 152.8 231.2 160 240 160H272C280.8 160 288 152.8 288 144V112C288 103.2 280.8 96 272 96H240C231.2 96 224 103.2 224 112V144zM368 96C359.2 96 352 103.2 352 112V144C352 152.8 359.2 160 368 160H400C408.8 160 416 152.8 416 144V112C416 103.2 408.8 96 400 96H368zM96 240C96 248.8 103.2 256 112 256H144C152.8 256 160 248.8 160 240V208C160 199.2 152.8 192 144 192H112C103.2 192 96 199.2 96 208V240zM240 192C231.2 192 224 199.2 224 208V240C224 248.8 231.2 256 240 256H272C280.8 256 288 248.8 288 240V208C288 199.2 280.8 192 272 192H240zM352 240C352 248.8 359.2 256 368 256H400C408.8 256 416 248.8 416 240V208C416 199.2 408.8 192 400 192H368C359.2 192 352 199.2 352 208V240zM256 288C211.2 288 173.5 318.7 162.1 360.2C159.7 373.1 170.7 384 184 384H328C341.3 384 352.3 373.1 349 360.2C338.5 318.7 300.8 288 256 288z\"\n ]\n};\nvar faHourglass = {\n prefix: 'fas',\n iconName: 'hourglass',\n icon: [\n 384,\n 512,\n [\n 62032,\n 9203,\n \"hourglass-2\",\n \"hourglass-half\"\n ],\n \"f254\",\n \"M352 0C369.7 0 384 14.33 384 32C384 49.67 369.7 64 352 64V74.98C352 117.4 335.1 158.1 305.1 188.1L237.3 256L305.1 323.9C335.1 353.9 352 394.6 352 437V448C369.7 448 384 462.3 384 480C384 497.7 369.7 512 352 512H32C14.33 512 0 497.7 0 480C0 462.3 14.33 448 32 448V437C32 394.6 48.86 353.9 78.86 323.9L146.7 256L78.86 188.1C48.86 158.1 32 117.4 32 74.98V64C14.33 64 0 49.67 0 32C0 14.33 14.33 0 32 0H352zM111.1 128H272C282.4 112.4 288 93.98 288 74.98V64H96V74.98C96 93.98 101.6 112.4 111.1 128zM111.1 384H272C268.5 378.7 264.5 373.7 259.9 369.1L192 301.3L124.1 369.1C119.5 373.7 115.5 378.7 111.1 384V384z\"\n ]\n};\nvar faHourglass2 = faHourglass;\nvar faHourglassHalf = faHourglass;\nvar faHourglassEmpty = {\n prefix: 'fas',\n iconName: 'hourglass-empty',\n icon: [\n 384,\n 512,\n [],\n \"f252\",\n \"M0 32C0 14.33 14.33 0 32 0H352C369.7 0 384 14.33 384 32C384 49.67 369.7 64 352 64V74.98C352 117.4 335.1 158.1 305.1 188.1L237.3 256L305.1 323.9C335.1 353.9 352 394.6 352 437V448C369.7 448 384 462.3 384 480C384 497.7 369.7 512 352 512H32C14.33 512 0 497.7 0 480C0 462.3 14.33 448 32 448V437C32 394.6 48.86 353.9 78.86 323.9L146.7 256L78.86 188.1C48.86 158.1 32 117.4 32 74.98V64C14.33 64 0 49.67 0 32zM96 64V74.98C96 100.4 106.1 124.9 124.1 142.9L192 210.7L259.9 142.9C277.9 124.9 288 100.4 288 74.98V64H96zM96 448H288V437C288 411.6 277.9 387.1 259.9 369.1L192 301.3L124.1 369.1C106.1 387.1 96 411.6 96 437V448z\"\n ]\n};\nvar faHourglassEnd = {\n prefix: 'fas',\n iconName: 'hourglass-end',\n icon: [\n 384,\n 512,\n [\n 8987,\n \"hourglass-3\"\n ],\n \"f253\",\n \"M352 0C369.7 0 384 14.33 384 32C384 49.67 369.7 64 352 64V74.98C352 117.4 335.1 158.1 305.1 188.1L237.3 256L305.1 323.9C335.1 353.9 352 394.6 352 437V448C369.7 448 384 462.3 384 480C384 497.7 369.7 512 352 512H32C14.33 512 0 497.7 0 480C0 462.3 14.33 448 32 448V437C32 394.6 48.86 353.9 78.86 323.9L146.7 256L78.86 188.1C48.86 158.1 32 117.4 32 74.98V64C14.33 64 0 49.67 0 32C0 14.33 14.33 0 32 0H352zM124.1 142.9L192 210.7L259.9 142.9C277.9 124.9 288 100.4 288 74.98V64H96V74.98C96 100.4 106.1 124.9 124.1 142.9z\"\n ]\n};\nvar faHourglass3 = faHourglassEnd;\nvar faHourglassStart = {\n prefix: 'fas',\n iconName: 'hourglass-start',\n icon: [\n 384,\n 512,\n [\n \"hourglass-1\"\n ],\n \"f251\",\n \"M352 0C369.7 0 384 14.33 384 32C384 49.67 369.7 64 352 64V74.98C352 117.4 335.1 158.1 305.1 188.1L237.3 256L305.1 323.9C335.1 353.9 352 394.6 352 437V448C369.7 448 384 462.3 384 480C384 497.7 369.7 512 352 512H32C14.33 512 0 497.7 0 480C0 462.3 14.33 448 32 448V437C32 394.6 48.86 353.9 78.86 323.9L146.7 256L78.86 188.1C48.86 158.1 32 117.4 32 74.98V64C14.33 64 0 49.67 0 32C0 14.33 14.33 0 32 0H352zM259.9 369.1L192 301.3L124.1 369.1C106.1 387.1 96 411.6 96 437V448H288V437C288 411.6 277.9 387.1 259.9 369.1V369.1z\"\n ]\n};\nvar faHourglass1 = faHourglassStart;\nvar faHouse = {\n prefix: 'fas',\n iconName: 'house',\n icon: [\n 576,\n 512,\n [\n 63498,\n 63500,\n 127968,\n \"home\",\n \"home-alt\",\n \"home-lg-alt\"\n ],\n \"f015\",\n \"M575.8 255.5C575.8 273.5 560.8 287.6 543.8 287.6H511.8L512.5 447.7C512.5 450.5 512.3 453.1 512 455.8V472C512 494.1 494.1 512 472 512H456C454.9 512 453.8 511.1 452.7 511.9C451.3 511.1 449.9 512 448.5 512H392C369.9 512 352 494.1 352 472V384C352 366.3 337.7 352 320 352H256C238.3 352 224 366.3 224 384V472C224 494.1 206.1 512 184 512H128.1C126.6 512 125.1 511.9 123.6 511.8C122.4 511.9 121.2 512 120 512H104C81.91 512 64 494.1 64 472V360C64 359.1 64.03 358.1 64.09 357.2V287.6H32.05C14.02 287.6 0 273.5 0 255.5C0 246.5 3.004 238.5 10.01 231.5L266.4 8.016C273.4 1.002 281.4 0 288.4 0C295.4 0 303.4 2.004 309.5 7.014L564.8 231.5C572.8 238.5 576.9 246.5 575.8 255.5L575.8 255.5z\"\n ]\n};\nvar faHome = faHouse;\nvar faHomeAlt = faHouse;\nvar faHomeLgAlt = faHouse;\nvar faHouseChimney = {\n prefix: 'fas',\n iconName: 'house-chimney',\n icon: [\n 576,\n 512,\n [\n 63499,\n \"home-lg\"\n ],\n \"e3af\",\n \"M511.8 287.6L512.5 447.7C512.5 450.5 512.3 453.1 512 455.8V472C512 494.1 494.1 512 472 512H456C454.9 512 453.8 511.1 452.7 511.9C451.3 511.1 449.9 512 448.5 512H392C369.9 512 352 494.1 352 472V384C352 366.3 337.7 352 320 352H256C238.3 352 224 366.3 224 384V472C224 494.1 206.1 512 184 512H128.1C126.6 512 125.1 511.9 123.6 511.8C122.4 511.9 121.2 512 120 512H104C81.91 512 64 494.1 64 472V360C64 359.1 64.03 358.1 64.09 357.2V287.6H32.05C14.02 287.6 0 273.5 0 255.5C0 246.5 3.004 238.5 10.01 231.5L266.4 8.016C273.4 1.002 281.4 0 288.4 0C295.4 0 303.4 2.004 309.5 7.014L416 100.7V64C416 46.33 430.3 32 448 32H480C497.7 32 512 46.33 512 64V185L564.8 231.5C572.8 238.5 576.9 246.5 575.8 255.5C575.8 273.5 560.8 287.6 543.8 287.6L511.8 287.6z\"\n ]\n};\nvar faHomeLg = faHouseChimney;\nvar faHouseChimneyCrack = {\n prefix: 'fas',\n iconName: 'house-chimney-crack',\n icon: [\n 576,\n 512,\n [\n \"house-damage\"\n ],\n \"f6f1\",\n \"M575.8 255.5C575.8 273.5 560.8 287.6 543.8 287.6H511.8L512.5 447.7C512.6 483.2 483.9 512 448.5 512H326.4L288 448L368.8 380.7C376.6 374.1 376.5 362.1 368.5 355.8L250.6 263.2C235.1 251.7 216.8 270.1 227.8 285.2L288 368L202.5 439.2C196.5 444.3 194.1 452.1 199.1 459.8L230.4 512H128.1C92.75 512 64.09 483.3 64.09 448V287.6H32.05C14.02 287.6 0 273.5 0 255.5C0 246.5 3.004 238.5 10.01 231.5L266.4 8.016C273.4 1.002 281.4 0 288.4 0C295.4 0 303.4 2.004 309.5 7.014L416 100.7V64C416 46.33 430.3 32 448 32H480C497.7 32 512 46.33 512 64V185L564.8 231.5C572.8 238.5 576.9 246.5 575.8 255.5L575.8 255.5z\"\n ]\n};\nvar faHouseDamage = faHouseChimneyCrack;\nvar faHouseChimneyMedical = {\n prefix: 'fas',\n iconName: 'house-chimney-medical',\n icon: [\n 576,\n 512,\n [\n \"clinic-medical\"\n ],\n \"f7f2\",\n \"M511.8 287.6L512.5 447.7C512.6 483.2 483.9 512 448.5 512H128.1C92.75 512 64.09 483.3 64.09 448V287.6H32.05C14.02 287.6 0 273.5 0 255.5C0 246.5 3.004 238.5 10.01 231.5L266.4 8.016C273.4 1.002 281.4 0 288.4 0C295.4 0 303.4 2.004 309.5 7.014L416 100.7V64C416 46.33 430.3 32 448 32H480C497.7 32 512 46.33 512 64V185L564.8 231.5C572.8 238.5 576.9 246.5 575.8 255.5C575.8 273.5 560.8 287.6 543.8 287.6L511.8 287.6zM400 248C400 239.2 392.8 232 384 232H328V176C328 167.2 320.8 160 312 160H264C255.2 160 248 167.2 248 176V232H192C183.2 232 176 239.2 176 248V296C176 304.8 183.2 312 192 312H248V368C248 376.8 255.2 384 264 384H312C320.8 384 328 376.8 328 368V312H384C392.8 312 400 304.8 400 296V248z\"\n ]\n};\nvar faClinicMedical = faHouseChimneyMedical;\nvar faHouseChimneyUser = {\n prefix: 'fas',\n iconName: 'house-chimney-user',\n icon: [\n 576,\n 512,\n [],\n \"e065\",\n \"M511.8 287.6L512.5 447.7C512.6 483.2 483.9 512 448.5 512H128.1C92.75 512 64.09 483.3 64.09 448V287.6H32.05C14.02 287.6 0 273.5 0 255.5C0 246.5 3.004 238.5 10.01 231.5L266.4 8.016C273.4 1.002 281.4 0 288.4 0C295.4 0 303.4 2.004 309.5 7.014L416 100.7V64C416 46.33 430.3 32 448 32H480C497.7 32 512 46.33 512 64V185L564.8 231.5C572.8 238.5 576.9 246.5 575.8 255.5C575.8 273.5 560.8 287.6 543.8 287.6L511.8 287.6zM288 288C323.3 288 352 259.3 352 224C352 188.7 323.3 160 288 160C252.7 160 224 188.7 224 224C224 259.3 252.7 288 288 288zM192 416H384C392.8 416 400 408.8 400 400C400 355.8 364.2 320 320 320H256C211.8 320 176 355.8 176 400C176 408.8 183.2 416 192 416z\"\n ]\n};\nvar faHouseChimneyWindow = {\n prefix: 'fas',\n iconName: 'house-chimney-window',\n icon: [\n 576,\n 512,\n [],\n \"e00d\",\n \"M575.8 255.5C575.8 273.5 560.8 287.6 543.8 287.6H511.8L512.5 447.7C512.6 483.2 483.9 512 448.5 512H128.1C92.75 512 64.09 483.3 64.09 448V287.6H32.05C14.02 287.6 0 273.5 0 255.5C0 246.5 3.004 238.5 10.01 231.5L266.4 8.016C273.4 1.002 281.4 0 288.4 0C295.4 0 303.4 2.004 309.5 7.014L416 100.7V64C416 46.33 430.3 32 448 32H480C497.7 32 512 46.33 512 64V185L564.8 231.5C572.8 238.5 576.9 246.5 575.8 255.5L575.8 255.5zM248 192C234.7 192 224 202.7 224 216V296C224 309.3 234.7 320 248 320H328C341.3 320 352 309.3 352 296V216C352 202.7 341.3 192 328 192H248z\"\n ]\n};\nvar faHouseCrack = {\n prefix: 'fas',\n iconName: 'house-crack',\n icon: [\n 576,\n 512,\n [],\n \"e3b1\",\n \"M511.8 287.6L512.5 447.7C512.6 483.2 483.9 512 448.5 512H326.4L288 448L368.8 380.7C376.6 374.1 376.5 362.1 368.5 355.8L250.6 263.2C235.1 251.7 216.8 270.1 227.8 285.2L288 368L202.5 439.2C196.5 444.3 194.1 452.1 199.1 459.8L230.4 512H128.1C92.75 512 64.09 483.3 64.09 448V287.6H32.05C14.02 287.6 0 273.5 0 255.5C0 246.5 3.004 238.5 10.01 231.5L266.4 8.016C273.4 1.002 281.4 0 288.4 0C295.4 0 303.4 2.004 309.5 7.014L564.8 231.5C572.8 238.5 576.9 246.5 575.8 255.5C575.8 273.5 560.8 287.6 543.8 287.6H511.8z\"\n ]\n};\nvar faHouseLaptop = {\n prefix: 'fas',\n iconName: 'house-laptop',\n icon: [\n 640,\n 512,\n [\n \"laptop-house\"\n ],\n \"e066\",\n \"M218.3 8.486C230.6-2.829 249.4-2.829 261.7 8.486L469.7 200.5C476.4 206.7 480 215.2 480 224H336C316.9 224 299.7 232.4 288 245.7V208C288 199.2 280.8 192 272 192H208C199.2 192 192 199.2 192 208V272C192 280.8 199.2 288 208 288H271.1V416H112C85.49 416 64 394.5 64 368V256H32C18.83 256 6.996 247.9 2.198 235.7C-2.6 223.4 .6145 209.4 10.3 200.5L218.3 8.486zM336 256H560C577.7 256 592 270.3 592 288V448H624C632.8 448 640 455.2 640 464C640 490.5 618.5 512 592 512H303.1C277.5 512 255.1 490.5 255.1 464C255.1 455.2 263.2 448 271.1 448H303.1V288C303.1 270.3 318.3 256 336 256zM352 304V448H544V304H352z\"\n ]\n};\nvar faLaptopHouse = faHouseLaptop;\nvar faHouseMedical = {\n prefix: 'fas',\n iconName: 'house-medical',\n icon: [\n 576,\n 512,\n [],\n \"e3b2\",\n \"M575.8 255.5C575.8 273.5 560.8 287.6 543.8 287.6H511.8L512.5 447.7C512.6 483.2 483.9 512 448.5 512H128.1C92.75 512 64.09 483.3 64.09 448V287.6H32.05C14.02 287.6 0 273.5 0 255.5C0 246.5 3.004 238.5 10.01 231.5L266.4 8.016C273.4 1.002 281.4 0 288.4 0C295.4 0 303.4 2.004 309.5 7.014L564.8 231.5C572.8 238.5 576.9 246.5 575.8 255.5H575.8zM328 232V176C328 167.2 320.8 160 312 160H264C255.2 160 248 167.2 248 176V232H192C183.2 232 176 239.2 176 248V296C176 304.8 183.2 312 192 312H248V368C248 376.8 255.2 384 264 384H312C320.8 384 328 376.8 328 368V312H384C392.8 312 400 304.8 400 296V248C400 239.2 392.8 232 384 232H328z\"\n ]\n};\nvar faHouseUser = {\n prefix: 'fas',\n iconName: 'house-user',\n icon: [\n 576,\n 512,\n [\n \"home-user\"\n ],\n \"e1b0\",\n \"M575.8 255.5C575.8 273.5 560.8 287.6 543.8 287.6H511.8L512.5 447.7C512.6 483.2 483.9 512 448.5 512H128.1C92.75 512 64.09 483.3 64.09 448V287.6H32.05C14.02 287.6 0 273.5 0 255.5C0 246.5 3.004 238.5 10.01 231.5L266.4 8.016C273.4 1.002 281.4 0 288.4 0C295.4 0 303.4 2.004 309.5 7.014L564.8 231.5C572.8 238.5 576.9 246.5 575.8 255.5H575.8zM288 160C252.7 160 224 188.7 224 224C224 259.3 252.7 288 288 288C323.3 288 352 259.3 352 224C352 188.7 323.3 160 288 160zM256 320C211.8 320 176 355.8 176 400C176 408.8 183.2 416 192 416H384C392.8 416 400 408.8 400 400C400 355.8 364.2 320 320 320H256z\"\n ]\n};\nvar faHomeUser = faHouseUser;\nvar faHryvniaSign = {\n prefix: 'fas',\n iconName: 'hryvnia-sign',\n icon: [\n 384,\n 512,\n [\n 8372,\n \"hryvnia\"\n ],\n \"f6f2\",\n \"M115.1 120.1C102.2 132 82.05 129.8 71.01 115.1C59.97 102.2 62.21 82.05 76.01 71.01L81.94 66.27C109.7 44.08 144.1 32 179.6 32H223C285.4 32 336 82.59 336 144.1C336 155.6 334.5 166.1 331.7 176H352C369.7 176 384 190.3 384 208C384 225.7 369.7 240 352 240H284.2C282.5 241.1 280.8 242.1 279.1 243.1L228.5 272H352C369.7 272 384 286.3 384 304C384 321.7 369.7 336 352 336H123.1C116 344.6 112 355.5 112 367C112 394.1 133.9 416 160.1 416H204.4C225.3 416 245.7 408.9 262.1 395.8L268 391C281.8 379.1 301.9 382.2 312.1 396C324 409.8 321.8 429.9 307.1 440.1L302.1 445.7C274.3 467.9 239.9 480 204.4 480H160.1C98.59 480 48 429.4 48 367C48 356.4 49.49 345.9 52.33 336H32C14.33 336 0 321.7 0 304C0 286.3 14.33 272 32 272H99.82C101.5 270.9 103.2 269.9 104.9 268.9L155.5 240H32C14.33 240 0 225.7 0 208C0 190.3 14.33 176 32 176H260.9C267.1 167.4 272 156.5 272 144.1C272 117.9 250.1 96 223 96H179.6C158.7 96 138.3 103.1 121.9 116.2L115.1 120.1z\"\n ]\n};\nvar faHryvnia = faHryvniaSign;\nvar faI = {\n prefix: 'fas',\n iconName: 'i',\n icon: [\n 320,\n 512,\n [\n 105\n ],\n \"49\",\n \"M320 448c0 17.67-14.31 32-32 32H32c-17.69 0-32-14.33-32-32s14.31-32 32-32h96v-320H32c-17.69 0-32-14.33-32-32s14.31-32 32-32h256c17.69 0 32 14.33 32 32s-14.31 32-32 32h-96v320h96C305.7 416 320 430.3 320 448z\"\n ]\n};\nvar faICursor = {\n prefix: 'fas',\n iconName: 'i-cursor',\n icon: [\n 256,\n 512,\n [],\n \"f246\",\n \"M256 480c0 17.69-14.33 31.1-32 31.1c-38.41 0-72.52-17.35-96-44.23c-23.48 26.88-57.59 44.23-96 44.23c-17.67 0-32-14.31-32-31.1s14.33-32 32-32c35.3 0 64-28.72 64-64V288H64C46.33 288 32 273.7 32 256s14.33-32 32-32h32V128c0-35.28-28.7-64-64-64C14.33 64 0 49.69 0 32s14.33-32 32-32c38.41 0 72.52 17.35 96 44.23c23.48-26.88 57.59-44.23 96-44.23c17.67 0 32 14.31 32 32s-14.33 32-32 32c-35.3 0-64 28.72-64 64v96h32c17.67 0 32 14.31 32 32s-14.33 32-32 32h-32v96c0 35.28 28.7 64 64 64C241.7 448 256 462.3 256 480z\"\n ]\n};\nvar faIceCream = {\n prefix: 'fas',\n iconName: 'ice-cream',\n icon: [\n 448,\n 512,\n [\n 127848\n ],\n \"f810\",\n \"M96.06 288.3H351.9L252.6 493.8C250.1 499.2 246 503.8 240.1 507.1C235.9 510.3 230 512 224 512C217.1 512 212.1 510.3 207 507.1C201.1 503.8 197.9 499.2 195.4 493.8L96.06 288.3zM386.3 164C392.1 166.4 397.4 169.9 401.9 174.4C406.3 178.8 409.9 184.1 412.3 189.9C414.7 195.7 415.1 201.1 416 208.3C416 214.5 414.8 220.8 412.4 226.6C409.1 232.4 406.5 237.7 402 242.2C397.6 246.6 392.3 250.2 386.5 252.6C380.7 255 374.4 256.3 368.1 256.3H79.88C67.16 256.3 54.96 251.2 45.98 242.2C37 233.2 31.97 220.1 32 208.3C32.03 195.5 37.1 183.4 46.12 174.4C55.14 165.4 67.35 160.4 80.07 160.4H81.06C80.4 154.9 80.06 149.4 80.04 143.8C80.04 105.7 95.2 69.11 122.2 42.13C149.2 15.15 185.8 0 223.1 0C262.1 0 298.7 15.15 325.7 42.13C352.7 69.11 367.9 105.7 367.9 143.8C367.9 149.4 367.6 154.9 366.9 160.4H367.9C374.2 160.4 380.5 161.6 386.3 164z\"\n ]\n};\nvar faIcicles = {\n prefix: 'fas',\n iconName: 'icicles',\n icon: [\n 512,\n 512,\n [],\n \"f7ad\",\n \"M511.4 37.87l-87.54 467.6c-1.625 8.623-14.04 8.634-15.67 .0104L341.4 141.7L295.7 314.2c-2.375 7.624-12.98 7.624-15.36 0L246.3 180.9l-46.49 196.9c-1.875 8.373-13.64 8.373-15.51 0L139.1 190.5L103.6 314.5c-2.375 7.124-12.64 7.198-15.14 .0744L1.357 41.24C-4.768 20.75 10.61 0 31.98 0h448C500 0 515.2 18.25 511.4 37.87z\"\n ]\n};\nvar faIcons = {\n prefix: 'fas',\n iconName: 'icons',\n icon: [\n 512,\n 512,\n [\n \"heart-music-camera-bolt\"\n ],\n \"f86d\",\n \"M500.3 7.251C507.7 13.33 512 22.41 512 31.1V175.1C512 202.5 483.3 223.1 447.1 223.1C412.7 223.1 383.1 202.5 383.1 175.1C383.1 149.5 412.7 127.1 447.1 127.1V71.03L351.1 90.23V207.1C351.1 234.5 323.3 255.1 287.1 255.1C252.7 255.1 223.1 234.5 223.1 207.1C223.1 181.5 252.7 159.1 287.1 159.1V63.1C287.1 48.74 298.8 35.61 313.7 32.62L473.7 .6198C483.1-1.261 492.9 1.173 500.3 7.251H500.3zM74.66 303.1L86.5 286.2C92.43 277.3 102.4 271.1 113.1 271.1H174.9C185.6 271.1 195.6 277.3 201.5 286.2L213.3 303.1H239.1C266.5 303.1 287.1 325.5 287.1 351.1V463.1C287.1 490.5 266.5 511.1 239.1 511.1H47.1C21.49 511.1-.0019 490.5-.0019 463.1V351.1C-.0019 325.5 21.49 303.1 47.1 303.1H74.66zM143.1 359.1C117.5 359.1 95.1 381.5 95.1 407.1C95.1 434.5 117.5 455.1 143.1 455.1C170.5 455.1 191.1 434.5 191.1 407.1C191.1 381.5 170.5 359.1 143.1 359.1zM440.3 367.1H496C502.7 367.1 508.6 372.1 510.1 378.4C513.3 384.6 511.6 391.7 506.5 396L378.5 508C372.9 512.1 364.6 513.3 358.6 508.9C352.6 504.6 350.3 496.6 353.3 489.7L391.7 399.1H336C329.3 399.1 323.4 395.9 321 389.6C318.7 383.4 320.4 376.3 325.5 371.1L453.5 259.1C459.1 255 467.4 254.7 473.4 259.1C479.4 263.4 481.6 271.4 478.7 278.3L440.3 367.1zM116.7 219.1L19.85 119.2C-8.112 90.26-6.614 42.31 24.85 15.34C51.82-8.137 93.26-3.642 118.2 21.83L128.2 32.32L137.7 21.83C162.7-3.642 203.6-8.137 231.6 15.34C262.6 42.31 264.1 90.26 236.1 119.2L139.7 219.1C133.2 225.6 122.7 225.6 116.7 219.1H116.7z\"\n ]\n};\nvar faHeartMusicCameraBolt = faIcons;\nvar faIdBadge = {\n prefix: 'fas',\n iconName: 'id-badge',\n icon: [\n 384,\n 512,\n [],\n \"f2c1\",\n \"M336 0h-288C21.49 0 0 21.49 0 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48v-416C384 21.49 362.5 0 336 0zM192 160c35.35 0 64 28.65 64 64s-28.65 64-64 64S128 259.3 128 224S156.7 160 192 160zM288 416H96c-8.836 0-16-7.164-16-16C80 355.8 115.8 320 160 320h64c44.18 0 80 35.82 80 80C304 408.8 296.8 416 288 416zM240 96h-96C135.2 96 128 88.84 128 80S135.2 64 144 64h96C248.8 64 256 71.16 256 80S248.8 96 240 96z\"\n ]\n};\nvar faIdCard = {\n prefix: 'fas',\n iconName: 'id-card',\n icon: [\n 576,\n 512,\n [\n 62147,\n \"drivers-license\"\n ],\n \"f2c2\",\n \"M528 32h-480C21.49 32 0 53.49 0 80V96h576V80C576 53.49 554.5 32 528 32zM0 432C0 458.5 21.49 480 48 480h480c26.51 0 48-21.49 48-48V128H0V432zM368 192h128C504.8 192 512 199.2 512 208S504.8 224 496 224h-128C359.2 224 352 216.8 352 208S359.2 192 368 192zM368 256h128C504.8 256 512 263.2 512 272S504.8 288 496 288h-128C359.2 288 352 280.8 352 272S359.2 256 368 256zM368 320h128c8.836 0 16 7.164 16 16S504.8 352 496 352h-128c-8.836 0-16-7.164-16-16S359.2 320 368 320zM176 192c35.35 0 64 28.66 64 64s-28.65 64-64 64s-64-28.66-64-64S140.7 192 176 192zM112 352h128c26.51 0 48 21.49 48 48c0 8.836-7.164 16-16 16h-192C71.16 416 64 408.8 64 400C64 373.5 85.49 352 112 352z\"\n ]\n};\nvar faDriversLicense = faIdCard;\nvar faIdCardClip = {\n prefix: 'fas',\n iconName: 'id-card-clip',\n icon: [\n 576,\n 512,\n [\n \"id-card-alt\"\n ],\n \"f47f\",\n \"M256 128h64c17.67 0 32-14.33 32-32V32c0-17.67-14.33-32-32-32H256C238.3 0 224 14.33 224 32v64C224 113.7 238.3 128 256 128zM528 64H384v48C384 138.5 362.5 160 336 160h-96C213.5 160 192 138.5 192 112V64H48C21.49 64 0 85.49 0 112v352C0 490.5 21.49 512 48 512h480c26.51 0 48-21.49 48-48v-352C576 85.49 554.5 64 528 64zM288 224c35.35 0 64 28.66 64 64s-28.65 64-64 64s-64-28.66-64-64S252.7 224 288 224zM384 448H192c-8.836 0-16-7.164-16-16C176 405.5 197.5 384 224 384h128c26.51 0 48 21.49 48 48C400 440.8 392.8 448 384 448z\"\n ]\n};\nvar faIdCardAlt = faIdCardClip;\nvar faIgloo = {\n prefix: 'fas',\n iconName: 'igloo',\n icon: [\n 576,\n 512,\n [],\n \"f7ae\",\n \"M320 160H48.5C100.2 82.82 188.1 32 288 32C298.8 32 309.5 32.6 320 33.76V160zM352 39.14C424.9 55.67 487.2 99.82 527.5 160H352V39.14zM96 192V320H0C0 274 10.77 230.6 29.94 192H96zM192 320H128V192H448V320H384V352H576V432C576 458.5 554.5 480 528 480H352V352C352 316.7 323.3 288 288 288C252.7 288 224 316.7 224 352V480H48C21.49 480 0 458.5 0 432V352H192V320zM480 192H546.1C565.2 230.6 576 274 576 320H480V192z\"\n ]\n};\nvar faImage = {\n prefix: 'fas',\n iconName: 'image',\n icon: [\n 512,\n 512,\n [],\n \"f03e\",\n \"M447.1 32h-384C28.64 32-.0091 60.65-.0091 96v320c0 35.35 28.65 64 63.1 64h384c35.35 0 64-28.65 64-64V96C511.1 60.65 483.3 32 447.1 32zM111.1 96c26.51 0 48 21.49 48 48S138.5 192 111.1 192s-48-21.49-48-48S85.48 96 111.1 96zM446.1 407.6C443.3 412.8 437.9 416 432 416H82.01c-6.021 0-11.53-3.379-14.26-8.75c-2.73-5.367-2.215-11.81 1.334-16.68l70-96C142.1 290.4 146.9 288 152 288s9.916 2.441 12.93 6.574l32.46 44.51l93.3-139.1C293.7 194.7 298.7 192 304 192s10.35 2.672 13.31 7.125l128 192C448.6 396 448.9 402.3 446.1 407.6z\"\n ]\n};\nvar faImagePortrait = {\n prefix: 'fas',\n iconName: 'image-portrait',\n icon: [\n 384,\n 512,\n [\n \"portrait\"\n ],\n \"f3e0\",\n \"M336 0h-288c-26.51 0-48 21.49-48 48v416C0 490.5 21.49 512 48 512h288c26.51 0 48-21.49 48-48v-416C384 21.49 362.5 0 336 0zM192 128c35.35 0 64 28.65 64 64s-28.65 64-64 64S128 227.3 128 192S156.7 128 192 128zM288 384H96c-8.836 0-16-7.164-16-16C80 323.8 115.8 288 160 288h64c44.18 0 80 35.82 80 80C304 376.8 296.8 384 288 384z\"\n ]\n};\nvar faPortrait = faImagePortrait;\nvar faImages = {\n prefix: 'fas',\n iconName: 'images',\n icon: [\n 576,\n 512,\n [],\n \"f302\",\n \"M528 32H144c-26.51 0-48 21.49-48 48v256c0 26.51 21.49 48 48 48H528c26.51 0 48-21.49 48-48v-256C576 53.49 554.5 32 528 32zM223.1 96c17.68 0 32 14.33 32 32S241.7 160 223.1 160c-17.67 0-32-14.33-32-32S206.3 96 223.1 96zM494.1 311.6C491.3 316.8 485.9 320 480 320H192c-6.023 0-11.53-3.379-14.26-8.75c-2.73-5.367-2.215-11.81 1.332-16.68l70-96C252.1 194.4 256.9 192 262 192c5.111 0 9.916 2.441 12.93 6.574l22.35 30.66l62.74-94.11C362.1 130.7 367.1 128 373.3 128c5.348 0 10.34 2.672 13.31 7.125l106.7 160C496.6 300 496.9 306.3 494.1 311.6zM456 432H120c-39.7 0-72-32.3-72-72v-240C48 106.8 37.25 96 24 96S0 106.8 0 120v240C0 426.2 53.83 480 120 480h336c13.25 0 24-10.75 24-24S469.3 432 456 432z\"\n ]\n};\nvar faInbox = {\n prefix: 'fas',\n iconName: 'inbox',\n icon: [\n 512,\n 512,\n [],\n \"f01c\",\n \"M447 56.25C443.5 42 430.7 31.1 416 31.1H96c-14.69 0-27.47 10-31.03 24.25L3.715 304.9C1.247 314.9 0 325.2 0 335.5v96.47c0 26.51 21.49 48 48 48h416c26.51 0 48-21.49 48-48v-96.47c0-10.32-1.247-20.6-3.715-30.61L447 56.25zM352 352H160L128 288H72.97L121 96h270l48.03 192H384L352 352z\"\n ]\n};\nvar faIndent = {\n prefix: 'fas',\n iconName: 'indent',\n icon: [\n 448,\n 512,\n [],\n \"f03c\",\n \"M0 64C0 46.33 14.33 32 32 32H416C433.7 32 448 46.33 448 64C448 81.67 433.7 96 416 96H32C14.33 96 0 81.67 0 64zM192 192C192 174.3 206.3 160 224 160H416C433.7 160 448 174.3 448 192C448 209.7 433.7 224 416 224H224C206.3 224 192 209.7 192 192zM416 288C433.7 288 448 302.3 448 320C448 337.7 433.7 352 416 352H224C206.3 352 192 337.7 192 320C192 302.3 206.3 288 224 288H416zM0 448C0 430.3 14.33 416 32 416H416C433.7 416 448 430.3 448 448C448 465.7 433.7 480 416 480H32C14.33 480 0 465.7 0 448zM25.82 347.9C15.31 356.1 0 348.6 0 335.3V176.7C0 163.4 15.31 155.9 25.82 164.1L127.8 243.4C135.1 249.8 135.1 262.2 127.8 268.6L25.82 347.9z\"\n ]\n};\nvar faIndianRupeeSign = {\n prefix: 'fas',\n iconName: 'indian-rupee-sign',\n icon: [\n 320,\n 512,\n [\n \"indian-rupee\",\n \"inr\"\n ],\n \"e1bc\",\n \"M.0022 64C.0022 46.33 14.33 32 32 32H288C305.7 32 320 46.33 320 64C320 81.67 305.7 96 288 96H231.8C241.4 110.4 248.5 126.6 252.4 144H288C305.7 144 320 158.3 320 176C320 193.7 305.7 208 288 208H252.4C239.2 266.3 190.5 311.2 130.3 318.9L274.6 421.1C288.1 432.2 292.3 452.2 282 466.6C271.8 480.1 251.8 484.3 237.4 474L13.4 314C2.083 305.1-2.716 291.5 1.529 278.2C5.774 264.1 18.09 256 32 256H112C144.8 256 173 236.3 185.3 208H32C14.33 208 .0022 193.7 .0022 176C.0022 158.3 14.33 144 32 144H185.3C173 115.7 144.8 96 112 96H32C14.33 96 .0022 81.67 .0022 64V64z\"\n ]\n};\nvar faIndianRupee = faIndianRupeeSign;\nvar faInr = faIndianRupeeSign;\nvar faIndustry = {\n prefix: 'fas',\n iconName: 'industry',\n icon: [\n 576,\n 512,\n [],\n \"f275\",\n \"M128 32C145.7 32 160 46.33 160 64V215.4L316.6 131C332.6 122.4 352 134 352 152.2V215.4L508.6 131C524.6 122.4 544 134 544 152.2V432C544 458.5 522.5 480 496 480H80C53.49 480 32 458.5 32 432V64C32 46.33 46.33 32 64 32H128z\"\n ]\n};\nvar faInfinity = {\n prefix: 'fas',\n iconName: 'infinity',\n icon: [\n 640,\n 512,\n [\n 9854,\n 8734\n ],\n \"f534\",\n \"M494.9 96.01c-38.78 0-75.22 15.09-102.6 42.5L320 210.8L247.8 138.5c-27.41-27.41-63.84-42.5-102.6-42.5C65.11 96.01 0 161.1 0 241.1v29.75c0 80.03 65.11 145.1 145.1 145.1c38.78 0 75.22-15.09 102.6-42.5L320 301.3l72.23 72.25c27.41 27.41 63.84 42.5 102.6 42.5C574.9 416 640 350.9 640 270.9v-29.75C640 161.1 574.9 96.01 494.9 96.01zM202.5 328.3c-15.31 15.31-35.69 23.75-57.38 23.75C100.4 352 64 315.6 64 270.9v-29.75c0-44.72 36.41-81.13 81.14-81.13c21.69 0 42.06 8.438 57.38 23.75l72.23 72.25L202.5 328.3zM576 270.9c0 44.72-36.41 81.13-81.14 81.13c-21.69 0-42.06-8.438-57.38-23.75l-72.23-72.25l72.23-72.25c15.31-15.31 35.69-23.75 57.38-23.75C539.6 160 576 196.4 576 241.1V270.9z\"\n ]\n};\nvar faInfo = {\n prefix: 'fas',\n iconName: 'info',\n icon: [\n 192,\n 512,\n [],\n \"f129\",\n \"M160 448h-32V224c0-17.69-14.33-32-32-32L32 192c-17.67 0-32 14.31-32 32s14.33 31.1 32 31.1h32v192H32c-17.67 0-32 14.31-32 32s14.33 32 32 32h128c17.67 0 32-14.31 32-32S177.7 448 160 448zM96 128c26.51 0 48-21.49 48-48S122.5 32.01 96 32.01s-48 21.49-48 48S69.49 128 96 128z\"\n ]\n};\nvar faItalic = {\n prefix: 'fas',\n iconName: 'italic',\n icon: [\n 384,\n 512,\n [],\n \"f033\",\n \"M384 64.01c0 17.69-14.31 32-32 32h-58.67l-133.3 320H224c17.69 0 32 14.31 32 32s-14.31 32-32 32H32c-17.69 0-32-14.31-32-32s14.31-32 32-32h58.67l133.3-320H160c-17.69 0-32-14.31-32-32s14.31-32 32-32h192C369.7 32.01 384 46.33 384 64.01z\"\n ]\n};\nvar faJ = {\n prefix: 'fas',\n iconName: 'j',\n icon: [\n 320,\n 512,\n [\n 106\n ],\n \"4a\",\n \"M320 64.01v259.4c0 86.36-71.78 156.6-160 156.6s-160-70.26-160-156.6V288c0-17.67 14.31-32 32-32s32 14.33 32 32v35.38c0 51.08 43.06 92.63 96 92.63s96-41.55 96-92.63V64.01c0-17.67 14.31-32 32-32S320 46.34 320 64.01z\"\n ]\n};\nvar faJedi = {\n prefix: 'fas',\n iconName: 'jedi',\n icon: [\n 576,\n 512,\n [],\n \"f669\",\n \"M554.9 293.1l-58.88 58.88h40C493.2 446.1 398.2 511.1 287.1 512c-110.3-.0078-205.2-65.88-247.1-160h40L21.13 293.1C17.75 275.1 16 258.6 16 241.2c0-5.75 .75-11.5 1-17.25h47L22.75 182.7C37.38 117.1 75.86 59.37 130.6 20.5c2.75-2 6.021-3.005 9.272-3.005c5.5 0 10.5 2.75 13.5 7.25c3.125 4.375 3.625 10.13 1.625 15.13C148.5 56.12 145.1 73.62 145.1 91.12c0 45.13 21.13 86.63 57.75 113.8C206.9 207.7 209.4 212.4 209.5 217.2c.25 5-1.751 9.752-5.501 13c-32.75 29.38-47.5 74-38.5 117.1c9.751 48.38 48.88 87.13 97.26 96.5l2.5-65.37l-27.13 18.5c-3.125 2-7.251 1.75-10-.75c-2.75-2.625-3.25-6.75-1.375-10l20.13-33.75l-42.13-8.627c-3.625-.875-6.375-4.125-6.375-7.875s2.75-7 6.375-7.875l42.13-8.75L226.8 285.6C224.9 282.5 225.4 278.4 228.1 275.7c2.75-2.5 6.876-2.875 10-.75l30.38 20.63l11.49-287.8C280.3 3.461 283.7 .0156 287.1 0c4.237 .0156 7.759 3.461 8.009 7.828l11.49 287.8l30.38-20.63c3.125-2.125 7.251-1.75 10 .75c2.75 2.625 3.25 6.75 1.375 9.875l-20.13 33.75l42.13 8.75c3.625 .875 6.375 4.125 6.375 7.875s-2.75 7-6.375 7.875l-42.13 8.627l20.13 33.75c1.875 3.25 1.375 7.375-1.375 10c-2.75 2.5-6.876 2.75-10 .75l-27.13-18.5l2.5 65.37c48.38-9.375 87.51-48.13 97.26-96.5c9.001-43.13-5.75-87.75-38.5-117.1c-3.75-3.25-5.751-8.002-5.501-13c.125-4.875 2.626-9.5 6.626-12.38c36.63-27.13 57.75-68.63 57.75-113.8c0-17.5-3.375-35-9.875-51.25c-2-5-1.5-10.75 1.625-15.13c3-4.5 8.001-7.25 13.5-7.25c3.25 0 6.474 .9546 9.224 2.955c54.75 38.88 93.28 96.67 107.9 162.3l-41.25 41.25h47c.2501 5.75 .9965 11.5 .9965 17.25C559.1 258.6 558.3 275.1 554.9 293.1z\"\n ]\n};\nvar faJetFighter = {\n prefix: 'fas',\n iconName: 'jet-fighter',\n icon: [\n 640,\n 512,\n [\n \"fighter-jet\"\n ],\n \"f0fb\",\n \"M160 24C160 10.75 170.7 0 184 0H296C309.3 0 320 10.75 320 24C320 37.25 309.3 48 296 48H280L384 192H500.4C508.1 192 515.7 193.4 522.9 196.1L625 234.4C634 237.8 640 246.4 640 256C640 265.6 634 274.2 625 277.6L522.9 315.9C515.7 318.6 508.1 320 500.4 320H384L280 464H296C309.3 464 320 474.7 320 488C320 501.3 309.3 512 296 512H184C170.7 512 160 501.3 160 488C160 474.7 170.7 464 184 464H192V320H160L105.4 374.6C99.37 380.6 91.23 384 82.75 384H64C46.33 384 32 369.7 32 352V288C14.33 288 0 273.7 0 256C0 238.3 14.33 224 32 224V160C32 142.3 46.33 128 64 128H82.75C91.23 128 99.37 131.4 105.4 137.4L160 192H192V48H184C170.7 48 160 37.25 160 24V24zM80 240C71.16 240 64 247.2 64 256C64 264.8 71.16 272 80 272H144C152.8 272 160 264.8 160 256C160 247.2 152.8 240 144 240H80z\"\n ]\n};\nvar faFighterJet = faJetFighter;\nvar faJoint = {\n prefix: 'fas',\n iconName: 'joint',\n icon: [\n 640,\n 512,\n [],\n \"f595\",\n \"M444.4 181.1C466.8 196.8 480 222.2 480 249.8V280C480 284.4 483.6 288 488 288h48C540.4 288 544 284.4 544 280V249.8c0-43.25-21-83.5-56.38-108.1C463.9 125 448 99.38 448 70.25V8C448 3.625 444.4 0 440 0h-48C387.6 0 384 3.625 384 8v66.38C384 118.1 408.5 156 444.4 181.1zM195 359C125.1 370.1 59.75 394.8 0 432C83.62 484.2 180.2 512 279 512h88.5l-112.7-131.5C240 363.2 217.4 355.4 195 359zM553.3 87.12C547.6 83.25 544 77.12 544 70.25V8C544 3.625 540.4 0 536 0h-48C483.6 0 480 3.625 480 8v62.25c0 22.13 10.12 43.5 28.62 55.5C550.8 153 576 199.5 576 249.8V280C576 284.4 579.6 288 584 288h48C636.4 288 640 284.4 640 280V249.8C640 184.2 607.6 123.5 553.3 87.12zM360.9 352c-34.38 .125-86.75 .25-88.25 .25l117.9 137.4C402.6 503.9 420.4 512 439.1 512h88.38l-117.9-137.6C397.4 360.1 379.6 352 360.9 352zM616 352H432l117.1 137.6C562.1 503.9 579.9 512 598.6 512H616c13.25 0 24-10.75 24-24v-112C640 362.8 629.3 352 616 352z\"\n ]\n};\nvar faK = {\n prefix: 'fas',\n iconName: 'k',\n icon: [\n 320,\n 512,\n [\n 107\n ],\n \"4b\",\n \"M314.3 429.8c10.06 14.53 6.438 34.47-8.094 44.53c-5.562 3.844-11.91 5.688-18.19 5.688c-10.16 0-20.12-4.812-26.34-13.78L128.1 273.3L64 338.9v109.1c0 17.67-14.31 32-32 32s-32-14.33-32-32v-384C0 46.34 14.31 32.01 32 32.01S64 46.34 64 64.01v183.3l201.1-205.7c12.31-12.61 32.63-12.86 45.25-.5c12.62 12.34 12.88 32.61 .5 45.25l-137.2 140.3L314.3 429.8z\"\n ]\n};\nvar faKaaba = {\n prefix: 'fas',\n iconName: 'kaaba',\n icon: [\n 576,\n 512,\n [\n 128331\n ],\n \"f66b\",\n \"M0 239.4V197.4L278.1 115.3C284.9 113.6 291.1 113.6 297 115.3L576 197.4V239.4L537.1 228.6C528.6 226.2 519.7 231.2 517.4 239.7C515 248.2 520 257.1 528.5 259.4L576 272.6V409.5C576 431.1 560.4 451.5 538.4 456.4L298.4 509.7C291.6 511.2 284.4 511.2 277.6 509.7L37.59 456.4C15.63 451.5 0 431.1 0 409.5V272.6L47.48 259.4C55.1 257.1 60.98 248.2 58.62 239.7C56.25 231.2 47.43 226.2 38.92 228.6L0 239.4zM292.3 160.6C289.5 159.8 286.5 159.8 283.7 160.6L240.5 172.6C232 174.9 227 183.8 229.4 192.3C231.7 200.8 240.6 205.8 249.1 203.4L288 192.6L326.9 203.4C335.4 205.8 344.3 200.8 346.6 192.3C348.1 183.8 343.1 174.9 335.5 172.6L292.3 160.6zM191.5 219.4C199.1 217.1 204.1 208.2 202.6 199.7C200.3 191.2 191.4 186.2 182.9 188.6L96.52 212.6C88 214.9 83.02 223.8 85.38 232.3C87.75 240.8 96.57 245.8 105.1 243.4L191.5 219.4zM393.1 188.6C384.6 186.2 375.7 191.2 373.4 199.7C371 208.2 376 217.1 384.5 219.4L470.9 243.4C479.4 245.8 488.3 240.8 490.6 232.3C492.1 223.8 487.1 214.9 479.5 212.6L393.1 188.6zM269.9 84.63L0 164V130.6C0 109.9 13.22 91.59 32.82 85.06L272.8 5.061C282.7 1.777 293.3 1.777 303.2 5.061L543.2 85.06C562.8 91.59 576 109.9 576 130.6V164L306.1 84.63C294.3 81.17 281.7 81.17 269.9 84.63V84.63z\"\n ]\n};\nvar faKey = {\n prefix: 'fas',\n iconName: 'key',\n icon: [\n 512,\n 512,\n [\n 128273\n ],\n \"f084\",\n \"M282.3 343.7L248.1 376.1C244.5 381.5 238.4 384 232 384H192V424C192 437.3 181.3 448 168 448H128V488C128 501.3 117.3 512 104 512H24C10.75 512 0 501.3 0 488V408C0 401.6 2.529 395.5 7.029 391L168.3 229.7C162.9 212.8 160 194.7 160 176C160 78.8 238.8 0 336 0C433.2 0 512 78.8 512 176C512 273.2 433.2 352 336 352C317.3 352 299.2 349.1 282.3 343.7zM376 176C398.1 176 416 158.1 416 136C416 113.9 398.1 96 376 96C353.9 96 336 113.9 336 136C336 158.1 353.9 176 376 176z\"\n ]\n};\nvar faKeyboard = {\n prefix: 'fas',\n iconName: 'keyboard',\n icon: [\n 576,\n 512,\n [\n 9000\n ],\n \"f11c\",\n \"M512 448H64c-35.35 0-64-28.65-64-64V128c0-35.35 28.65-64 64-64h448c35.35 0 64 28.65 64 64v256C576 419.3 547.3 448 512 448zM128 180v-40C128 133.4 122.6 128 116 128h-40C69.38 128 64 133.4 64 140v40C64 186.6 69.38 192 76 192h40C122.6 192 128 186.6 128 180zM224 180v-40C224 133.4 218.6 128 212 128h-40C165.4 128 160 133.4 160 140v40C160 186.6 165.4 192 172 192h40C218.6 192 224 186.6 224 180zM320 180v-40C320 133.4 314.6 128 308 128h-40C261.4 128 256 133.4 256 140v40C256 186.6 261.4 192 268 192h40C314.6 192 320 186.6 320 180zM416 180v-40C416 133.4 410.6 128 404 128h-40C357.4 128 352 133.4 352 140v40C352 186.6 357.4 192 364 192h40C410.6 192 416 186.6 416 180zM512 180v-40C512 133.4 506.6 128 500 128h-40C453.4 128 448 133.4 448 140v40C448 186.6 453.4 192 460 192h40C506.6 192 512 186.6 512 180zM128 276v-40C128 229.4 122.6 224 116 224h-40C69.38 224 64 229.4 64 236v40C64 282.6 69.38 288 76 288h40C122.6 288 128 282.6 128 276zM224 276v-40C224 229.4 218.6 224 212 224h-40C165.4 224 160 229.4 160 236v40C160 282.6 165.4 288 172 288h40C218.6 288 224 282.6 224 276zM320 276v-40C320 229.4 314.6 224 308 224h-40C261.4 224 256 229.4 256 236v40C256 282.6 261.4 288 268 288h40C314.6 288 320 282.6 320 276zM416 276v-40C416 229.4 410.6 224 404 224h-40C357.4 224 352 229.4 352 236v40C352 282.6 357.4 288 364 288h40C410.6 288 416 282.6 416 276zM512 276v-40C512 229.4 506.6 224 500 224h-40C453.4 224 448 229.4 448 236v40C448 282.6 453.4 288 460 288h40C506.6 288 512 282.6 512 276zM128 372v-40C128 325.4 122.6 320 116 320h-40C69.38 320 64 325.4 64 332v40C64 378.6 69.38 384 76 384h40C122.6 384 128 378.6 128 372zM416 372v-40C416 325.4 410.6 320 404 320h-232C165.4 320 160 325.4 160 332v40C160 378.6 165.4 384 172 384h232C410.6 384 416 378.6 416 372zM512 372v-40C512 325.4 506.6 320 500 320h-40C453.4 320 448 325.4 448 332v40C448 378.6 453.4 384 460 384h40C506.6 384 512 378.6 512 372z\"\n ]\n};\nvar faKhanda = {\n prefix: 'fas',\n iconName: 'khanda',\n icon: [\n 576,\n 512,\n [\n 9772\n ],\n \"f66d\",\n \"M447.7 65.1c-6.25-3.5-14.29-2.351-19.29 3.024c-5.125 5.375-5.833 13.37-1.958 19.5c16.5 26.25 25.23 56.34 25.23 87.46c-.25 53.25-26.74 102.6-71.24 132.4l-76.62 53.35v-20.12l44.01-36.12c3.875-4.125 4.983-10.13 2.858-15.26L342.8 273c33.88-19.25 56.94-55.25 56.94-97c0-40.75-22.06-76.12-54.56-95.75l5.151-11.39c2.375-5.5 .9825-11.87-3.518-15.1L287.9 .0074l-59.05 52.77C224.4 57.02 222.1 63.37 225.2 68.87l5.203 11.32C197.1 99.81 175.9 135.2 175.9 175.1c0 41.75 23.08 77.75 56.95 97L224.1 290.2C222.9 295.4 223.9 301.2 227.9 305.5l43.1 36.11v19.91L195.2 308.1c-44.25-29.5-70.72-78.9-70.97-132.1c0-31.12 8.73-61.2 25.23-87.45C153.3 82.4 151.8 74.75 146.8 69.5C141.8 64.12 133.2 63.25 126.8 66.75C48.34 109.6 9.713 205.2 45.34 296c7 18 17.88 34.38 30.5 49l55.92 65.38c4.875 5.75 13.09 7.232 19.71 3.732l79.25-42.25l29.26 20.37l-47.09 32.75c-1.625-.375-3.125-1-4.1-1c-13.25 0-23.97 10.75-23.97 24s10.72 23.1 23.97 23.1c12.13 0 21.74-9.126 23.36-20.75l40.6-28.25v29.91c-9.375 5.625-15.97 15.37-15.97 27.12c0 17.62 14.37 31.1 31.1 31.1c17.63 0 31.1-14.37 31.1-31.1c0-11.75-6.656-21.52-16.03-27.14v-30.12l40.87 28.48c1.625 11.63 11.23 20.75 23.35 20.75c13.25 0 23.98-10.74 23.98-23.99s-10.73-24-23.98-24c-1.875 0-3.375 .625-5 1l-47.09-32.75l29.25-20.37l79.26 42.25c6.625 3.5 14.84 2.018 19.71-3.732l52.51-61.27c18.88-22 33.1-47.49 41.25-75.61C559.6 189.9 521.5 106.2 447.7 65.1zM351.8 176c0 22.25-11.45 41.91-28.82 53.41l-5.613-12.43c-8.75-24.5-8.811-51.11-.061-75.61l7.748-17.12C341.2 135.9 351.8 154.6 351.8 176zM223.8 176c0-21.38 10.67-40.16 26.67-51.79l7.848 17.17c8.75 24.63 8.747 51.11-.0032 75.61L252.7 229.4C235.4 217.9 223.8 198.2 223.8 176z\"\n ]\n};\nvar faKipSign = {\n prefix: 'fas',\n iconName: 'kip-sign',\n icon: [\n 384,\n 512,\n [],\n \"e1c4\",\n \"M182.5 224H352C369.7 224 384 238.3 384 256C384 273.7 369.7 288 352 288H182.5L340.8 423.7C354.2 435.2 355.8 455.4 344.3 468.8C332.8 482.2 312.6 483.8 299.2 472.3L128 325.6V448C128 465.7 113.7 480 96 480C78.33 480 64 465.7 64 448V288H32C14.33 288 0 273.7 0 256C0 238.3 14.33 224 32 224H64V64C64 46.33 78.33 32 96 32C113.7 32 128 46.33 128 64V186.4L299.2 39.7C312.6 28.2 332.8 29.76 344.3 43.18C355.8 56.59 354.2 76.8 340.8 88.3L182.5 224z\"\n ]\n};\nvar faKitMedical = {\n prefix: 'fas',\n iconName: 'kit-medical',\n icon: [\n 576,\n 512,\n [\n \"first-aid\"\n ],\n \"f479\",\n \"M64 32h32v448H64c-35.35 0-64-28.66-64-64V96C0 60.66 28.65 32 64 32zM128 32h320v448H128V32zM176 282c0 8.835 7.164 16 16 16h53.1V352c0 8.836 7.165 16 16 16h52c8.836 0 16-7.164 16-16V298H384c8.836 0 16-7.165 16-16v-52c0-8.837-7.164-16-16-16h-54V160c0-8.836-7.164-16-16-16h-52c-8.835 0-16 7.164-16 16v54H192c-8.836 0-16 7.163-16 16V282zM512 32h-32v448h32c35.35 0 64-28.66 64-64V96C576 60.66 547.3 32 512 32z\"\n ]\n};\nvar faFirstAid = faKitMedical;\nvar faKiwiBird = {\n prefix: 'fas',\n iconName: 'kiwi-bird',\n icon: [\n 576,\n 512,\n [],\n \"f535\",\n \"M256 405.1V456C256 469.3 245.3 480 232 480C218.7 480 208 469.3 208 456V415.3C202.7 415.8 197.4 416 192 416C175.4 416 159.3 413.9 144 409.1V456C144 469.3 133.3 480 120 480C106.7 480 96 469.3 96 456V390.3C38.61 357.1 0 295.1 0 224C0 117.1 85.96 32 192 32C228.3 32 262.3 42.08 291.2 59.6C322.4 78.44 355.9 96 392.3 96H448C518.7 96 576 153.3 576 224V464C576 470.1 571.5 477.2 564.8 479.3C558.2 481.4 550.9 478.9 546.9 473.2L461.6 351.3C457.1 351.8 452.6 352 448 352H392.3C355.9 352 322.4 369.6 291.2 388.4C280.2 395.1 268.4 400.7 256 405.1zM448 248C461.3 248 472 237.3 472 224C472 210.7 461.3 200 448 200C434.7 200 424 210.7 424 224C424 237.3 434.7 248 448 248z\"\n ]\n};\nvar faL = {\n prefix: 'fas',\n iconName: 'l',\n icon: [\n 320,\n 512,\n [\n 108\n ],\n \"4c\",\n \"M320 448c0 17.67-14.31 32-32 32H64c-17.69 0-32-14.33-32-32v-384C32 46.34 46.31 32.01 64 32.01S96 46.34 96 64.01v352h192C305.7 416 320 430.3 320 448z\"\n ]\n};\nvar faLandmark = {\n prefix: 'fas',\n iconName: 'landmark',\n icon: [\n 512,\n 512,\n [\n 127963\n ],\n \"f66f\",\n \"M240.1 4.216C249.1-1.405 262-1.405 271.9 4.216L443.6 102.4L447.1 104V104.9L495.9 132.2C508.5 139.4 514.6 154.2 510.9 168.2C507.2 182.2 494.5 192 479.1 192H31.1C17.49 192 4.795 182.2 1.071 168.2C-2.653 154.2 3.524 139.4 16.12 132.2L63.1 104.9V104L68.37 102.4L240.1 4.216zM64 224H128V416H168V224H232V416H280V224H344V416H384V224H448V420.3C448.6 420.6 449.2 420.1 449.8 421.4L497.8 453.4C509.5 461.2 514.7 475.8 510.6 489.3C506.5 502.8 494.1 512 480 512H32C17.9 512 5.46 502.8 1.373 489.3C-2.713 475.8 2.517 461.2 14.25 453.4L62.25 421.4C62.82 420.1 63.41 420.6 64 420.3V224z\"\n ]\n};\nvar faLanguage = {\n prefix: 'fas',\n iconName: 'language',\n icon: [\n 640,\n 512,\n [],\n \"f1ab\",\n \"M448 164C459 164 468 172.1 468 184V188H528C539 188 548 196.1 548 208C548 219 539 228 528 228H526L524.4 232.5C515.5 256.1 501.9 279.1 484.7 297.9C485.6 298.4 486.5 298.1 487.4 299.5L506.3 310.8C515.8 316.5 518.8 328.8 513.1 338.3C507.5 347.8 495.2 350.8 485.7 345.1L466.8 333.8C462.4 331.1 457.1 328.3 453.7 325.3C443.2 332.8 431.8 339.3 419.8 344.7L416.1 346.3C406 350.8 394.2 346.2 389.7 336.1C385.2 326 389.8 314.2 399.9 309.7L403.5 308.1C409.9 305.2 416.1 301.1 422 298.3L409.9 286.1C402 278.3 402 265.7 409.9 257.9C417.7 250 430.3 250 438.1 257.9L452.7 272.4L453.3 272.1C465.7 259.9 475.8 244.7 483.1 227.1H376C364.1 227.1 356 219 356 207.1C356 196.1 364.1 187.1 376 187.1H428V183.1C428 172.1 436.1 163.1 448 163.1L448 164zM160 233.2L179 276H140.1L160 233.2zM0 128C0 92.65 28.65 64 64 64H576C611.3 64 640 92.65 640 128V384C640 419.3 611.3 448 576 448H64C28.65 448 0 419.3 0 384V128zM320 384H576V128H320V384zM178.3 175.9C175.1 168.7 167.9 164 160 164C152.1 164 144.9 168.7 141.7 175.9L77.72 319.9C73.24 329.1 77.78 341.8 87.88 346.3C97.97 350.8 109.8 346.2 114.3 336.1L123.2 315.1H196.8L205.7 336.1C210.2 346.2 222 350.8 232.1 346.3C242.2 341.8 246.8 329.1 242.3 319.9L178.3 175.9z\"\n ]\n};\nvar faLaptop = {\n prefix: 'fas',\n iconName: 'laptop',\n icon: [\n 640,\n 512,\n [\n 128187\n ],\n \"f109\",\n \"M128 96h384v256h64v-272c0-26.38-21.62-48-48-48h-416c-26.38 0-48 21.62-48 48V352h64V96zM624 383.1h-608c-8.75 0-16 7.25-16 16v16c0 35.25 28.75 64 64 64h512c35.25 0 64-28.75 64-64v-16C640 391.2 632.8 383.1 624 383.1z\"\n ]\n};\nvar faLaptopCode = {\n prefix: 'fas',\n iconName: 'laptop-code',\n icon: [\n 640,\n 512,\n [],\n \"f5fc\",\n \"M128 96h384v256h64V80C576 53.63 554.4 32 528 32h-416C85.63 32 64 53.63 64 80V352h64V96zM624 384h-608C7.25 384 0 391.3 0 400V416c0 35.25 28.75 64 64 64h512c35.25 0 64-28.75 64-64v-16C640 391.3 632.8 384 624 384zM365.9 286.2C369.8 290.1 374.9 292 380 292s10.23-1.938 14.14-5.844l48-48c7.812-7.813 7.812-20.5 0-28.31l-48-48c-7.812-7.813-20.47-7.813-28.28 0c-7.812 7.813-7.812 20.5 0 28.31l33.86 33.84l-33.86 33.84C358 265.7 358 278.4 365.9 286.2zM274.1 161.9c-7.812-7.813-20.47-7.813-28.28 0l-48 48c-7.812 7.813-7.812 20.5 0 28.31l48 48C249.8 290.1 254.9 292 260 292s10.23-1.938 14.14-5.844c7.812-7.813 7.812-20.5 0-28.31L240.3 224l33.86-33.84C281.1 182.4 281.1 169.7 274.1 161.9z\"\n ]\n};\nvar faLaptopMedical = {\n prefix: 'fas',\n iconName: 'laptop-medical',\n icon: [\n 640,\n 512,\n [],\n \"f812\",\n \"M624 384h-608C7.25 384 0 391.3 0 400V416c0 35.25 28.75 64 64 64h512c35.25 0 64-28.75 64-64v-16C640 391.3 632.8 384 624 384zM128 96h384v256h64V80C576 53.63 554.4 32 528 32h-416C85.63 32 64 53.63 64 80V352h64V96zM304 336h32c8.801 0 16-7.201 16-16V272h48C408.8 272 416 264.8 416 256V224c0-8.801-7.199-16-16-16H352V160c0-8.801-7.199-16-16-16h-32C295.2 144 288 151.2 288 160v48H240C231.2 208 224 215.2 224 224v32c0 8.799 7.199 16 16 16H288V320C288 328.8 295.2 336 304 336z\"\n ]\n};\nvar faLariSign = {\n prefix: 'fas',\n iconName: 'lari-sign',\n icon: [\n 384,\n 512,\n [],\n \"e1c8\",\n \"M144 32C161.7 32 176 46.33 176 64V96.66C181.3 96.22 186.6 96 192 96C197.4 96 202.7 96.22 208 96.66V64C208 46.33 222.3 32 240 32C257.7 32 272 46.33 272 64V113.4C326.9 138.6 367.8 188.9 380.2 249.6C383.7 266.1 372.5 283.8 355.2 287.4C337.8 290.9 320.1 279.7 317.4 262.4C311.4 232.5 294.9 206.4 272 188.1V256C272 273.7 257.7 288 240 288C222.3 288 208 273.7 208 256V160.1C202.8 160.3 197.4 160 192 160C186.6 160 181.2 160.3 176 160.1V256C176 273.7 161.7 288 144 288C126.3 288 112 273.7 112 256V188.1C82.74 211.5 64 247.6 64 288C64 358.7 121.3 416 192 416H352C369.7 416 384 430.3 384 448C384 465.7 369.7 480 352 480H32C14.33 480 0 465.7 0 448C0 430.3 14.33 416 32 416H48.89C18.49 382 0 337.2 0 288C0 210.5 45.9 143.7 112 113.4V64C112 46.33 126.3 32 144 32V32z\"\n ]\n};\nvar faLayerGroup = {\n prefix: 'fas',\n iconName: 'layer-group',\n icon: [\n 512,\n 512,\n [],\n \"f5fd\",\n \"M232.5 5.171C247.4-1.718 264.6-1.718 279.5 5.171L498.1 106.2C506.6 110.1 512 118.6 512 127.1C512 137.3 506.6 145.8 498.1 149.8L279.5 250.8C264.6 257.7 247.4 257.7 232.5 250.8L13.93 149.8C5.438 145.8 0 137.3 0 127.1C0 118.6 5.437 110.1 13.93 106.2L232.5 5.171zM498.1 234.2C506.6 238.1 512 246.6 512 255.1C512 265.3 506.6 273.8 498.1 277.8L279.5 378.8C264.6 385.7 247.4 385.7 232.5 378.8L13.93 277.8C5.438 273.8 0 265.3 0 255.1C0 246.6 5.437 238.1 13.93 234.2L67.13 209.6L219.1 279.8C242.5 290.7 269.5 290.7 292.9 279.8L444.9 209.6L498.1 234.2zM292.9 407.8L444.9 337.6L498.1 362.2C506.6 366.1 512 374.6 512 383.1C512 393.3 506.6 401.8 498.1 405.8L279.5 506.8C264.6 513.7 247.4 513.7 232.5 506.8L13.93 405.8C5.438 401.8 0 393.3 0 383.1C0 374.6 5.437 366.1 13.93 362.2L67.13 337.6L219.1 407.8C242.5 418.7 269.5 418.7 292.9 407.8V407.8z\"\n ]\n};\nvar faLeaf = {\n prefix: 'fas',\n iconName: 'leaf',\n icon: [\n 512,\n 512,\n [],\n \"f06c\",\n \"M512 165.4c0 127.9-70.05 235.3-175.3 270.1c-20.04 7.938-41.83 12.46-64.69 12.46c-64.9 0-125.2-36.51-155.7-94.47c-54.13 49.93-68.71 107-68.96 108.1C44.72 472.6 34.87 480 24.02 480c-1.844 0-3.727-.2187-5.602-.6562c-12.89-3.098-20.84-16.08-17.75-28.96c9.598-39.5 90.47-226.4 335.3-226.4C344.8 224 352 216.8 352 208S344.8 192 336 192C228.6 192 151 226.6 96.29 267.6c.1934-10.82 1.242-21.84 3.535-33.05c13.47-65.81 66.04-119 131.4-134.2c28.33-6.562 55.68-6.013 80.93-.0054c56 13.32 118.2-7.412 149.3-61.24c5.664-9.828 20.02-9.516 24.66 .8282C502.7 76.76 512 121.9 512 165.4z\"\n ]\n};\nvar faLeftLong = {\n prefix: 'fas',\n iconName: 'left-long',\n icon: [\n 512,\n 512,\n [\n \"long-arrow-alt-left\"\n ],\n \"f30a\",\n \"M512 256C512 273.7 497.7 288 480 288H160.1l0 72c0 9.547-5.66 18.19-14.42 22c-8.754 3.812-18.95 2.077-25.94-4.407l-112.1-104c-10.24-9.5-10.24-25.69 0-35.19l112.1-104c6.992-6.484 17.18-8.218 25.94-4.406C154.4 133.8 160.1 142.5 160.1 151.1L160.1 224H480C497.7 224 512 238.3 512 256z\"\n ]\n};\nvar faLongArrowAltLeft = faLeftLong;\nvar faLeftRight = {\n prefix: 'fas',\n iconName: 'left-right',\n icon: [\n 512,\n 512,\n [\n 8596,\n \"arrows-alt-h\"\n ],\n \"f337\",\n \"M503.1 273.6l-112 104c-6.984 6.484-17.17 8.219-25.92 4.406s-14.41-12.45-14.41-22v-56l-192 .001V360c0 9.547-5.656 18.19-14.41 22c-8.75 3.812-18.94 2.078-25.92-4.406l-112-104c-9.781-9.094-9.781-26.09 0-35.19l112-104c6.984-6.484 17.17-8.219 25.92-4.406C154 133.8 159.7 142.5 159.7 152v55.1l192-.001v-56c0-9.547 5.656-18.19 14.41-22s18.94-2.078 25.92 4.406l112 104C513.8 247.5 513.8 264.5 503.1 273.6z\"\n ]\n};\nvar faArrowsAltH = faLeftRight;\nvar faLemon = {\n prefix: 'fas',\n iconName: 'lemon',\n icon: [\n 448,\n 512,\n [\n 127819\n ],\n \"f094\",\n \"M427.9 52.1c-20.13-20.23-47.58-25.27-65.63-14.77c-51.63 30.08-158.6-46.49-281 75.91c-122.4 122.4-45.83 229.4-75.91 281c-10.5 18.05-5.471 45.5 14.77 65.63c20.13 20.24 47.58 25.27 65.63 14.77c51.63-30.08 158.6 46.49 281-75.91c122.4-122.4 45.83-229.4 75.91-281C453.2 99.69 448.1 72.23 427.9 52.1zM211.9 127.5C167.6 138.7 106.7 199.6 95.53 243.9C93.69 251.2 87.19 255.1 79.1 255.1c-1.281 0-2.594-.1562-3.906-.4687C67.53 253.4 62.34 244.7 64.47 236.1c14.16-56.28 83.31-125.4 139.6-139.6c8.656-2.031 17.25 3.062 19.44 11.62C225.7 116.7 220.5 125.3 211.9 127.5z\"\n ]\n};\nvar faLessThan = {\n prefix: 'fas',\n iconName: 'less-than',\n icon: [\n 384,\n 512,\n [\n 62774\n ],\n \"3c\",\n \"M351.1 448c-4.797 0-9.688-1.094-14.28-3.375l-320-160C6.844 279.2 0 268.1 0 256c0-12.13 6.844-23.18 17.69-28.62l320-160c15.88-7.875 35.05-1.5 42.94 14.31c7.906 15.81 1.5 35.03-14.31 42.94L103.5 256l262.8 131.4c15.81 7.906 22.22 27.12 14.31 42.94C375 441.5 363.7 448 351.1 448z\"\n ]\n};\nvar faLessThanEqual = {\n prefix: 'fas',\n iconName: 'less-than-equal',\n icon: [\n 448,\n 512,\n [],\n \"f537\",\n \"M52.11 221.7l320 128C376 351.3 380 352 383.1 352c12.7 0 24.72-7.594 29.73-20.12c6.562-16.41-1.422-35.03-17.83-41.59L150.2 192l245.7-98.28c16.41-6.562 24.39-25.19 17.83-41.59S388.6 27.68 372.1 34.21l-320 128.1C39.97 167.2 32 178.9 32 192S39.97 216.8 52.11 221.7zM416 416H32c-17.67 0-32 14.31-32 31.1S14.33 480 32 480h384c17.67 0 32-14.31 32-32S433.7 416 416 416z\"\n ]\n};\nvar faLifeRing = {\n prefix: 'fas',\n iconName: 'life-ring',\n icon: [\n 512,\n 512,\n [],\n \"f1cd\",\n \"M470.6 425.4C483.1 437.9 483.1 458.1 470.6 470.6C458.1 483.1 437.9 483.1 425.4 470.6L412.1 458.2C369.6 491.9 315.2 512 255.1 512C196.8 512 142.4 491.9 99.02 458.2L86.63 470.6C74.13 483.1 53.87 483.1 41.37 470.6C28.88 458.1 28.88 437.9 41.37 425.4L53.76 412.1C20.07 369.6 0 315.2 0 255.1C0 196.8 20.07 142.4 53.76 99.02L41.37 86.63C28.88 74.13 28.88 53.87 41.37 41.37C53.87 28.88 74.13 28.88 86.63 41.37L99.02 53.76C142.4 20.07 196.8 0 255.1 0C315.2 0 369.6 20.07 412.1 53.76L425.4 41.37C437.9 28.88 458.1 28.88 470.6 41.37C483.1 53.87 483.1 74.13 470.6 86.63L458.2 99.02C491.9 142.4 512 196.8 512 255.1C512 315.2 491.9 369.6 458.2 412.1L470.6 425.4zM309.3 354.5C293.4 363.1 275.3 368 255.1 368C236.7 368 218.6 363.1 202.7 354.5L144.8 412.5C176.1 434.9 214.5 448 255.1 448C297.5 448 335.9 434.9 367.2 412.5L309.3 354.5zM448 255.1C448 214.5 434.9 176.1 412.5 144.8L354.5 202.7C363.1 218.6 368 236.7 368 256C368 275.3 363.1 293.4 354.5 309.3L412.5 367.2C434.9 335.9 448 297.5 448 256V255.1zM255.1 63.1C214.5 63.1 176.1 77.14 144.8 99.5L202.7 157.5C218.6 148.9 236.7 143.1 255.1 143.1C275.3 143.1 293.4 148.9 309.3 157.5L367.2 99.5C335.9 77.14 297.5 63.1 256 63.1H255.1zM157.5 309.3C148.9 293.4 143.1 275.3 143.1 255.1C143.1 236.7 148.9 218.6 157.5 202.7L99.5 144.8C77.14 176.1 63.1 214.5 63.1 255.1C63.1 297.5 77.14 335.9 99.5 367.2L157.5 309.3zM255.1 207.1C229.5 207.1 207.1 229.5 207.1 255.1C207.1 282.5 229.5 303.1 255.1 303.1C282.5 303.1 304 282.5 304 255.1C304 229.5 282.5 207.1 255.1 207.1z\"\n ]\n};\nvar faLightbulb = {\n prefix: 'fas',\n iconName: 'lightbulb',\n icon: [\n 384,\n 512,\n [\n 128161\n ],\n \"f0eb\",\n \"M112.1 454.3c0 6.297 1.816 12.44 5.284 17.69l17.14 25.69c5.25 7.875 17.17 14.28 26.64 14.28h61.67c9.438 0 21.36-6.401 26.61-14.28l17.08-25.68c2.938-4.438 5.348-12.37 5.348-17.7L272 415.1h-160L112.1 454.3zM191.4 .0132C89.44 .3257 16 82.97 16 175.1c0 44.38 16.44 84.84 43.56 115.8c16.53 18.84 42.34 58.23 52.22 91.45c.0313 .25 .0938 .5166 .125 .7823h160.2c.0313-.2656 .0938-.5166 .125-.7823c9.875-33.22 35.69-72.61 52.22-91.45C351.6 260.8 368 220.4 368 175.1C368 78.61 288.9-.2837 191.4 .0132zM192 96.01c-44.13 0-80 35.89-80 79.1C112 184.8 104.8 192 96 192S80 184.8 80 176c0-61.76 50.25-111.1 112-111.1c8.844 0 16 7.159 16 16S200.8 96.01 192 96.01z\"\n ]\n};\nvar faLink = {\n prefix: 'fas',\n iconName: 'link',\n icon: [\n 640,\n 512,\n [\n 128279,\n \"chain\"\n ],\n \"f0c1\",\n \"M172.5 131.1C228.1 75.51 320.5 75.51 376.1 131.1C426.1 181.1 433.5 260.8 392.4 318.3L391.3 319.9C381 334.2 361 337.6 346.7 327.3C332.3 317 328.9 297 339.2 282.7L340.3 281.1C363.2 249 359.6 205.1 331.7 177.2C300.3 145.8 249.2 145.8 217.7 177.2L105.5 289.5C73.99 320.1 73.99 372 105.5 403.5C133.3 431.4 177.3 435 209.3 412.1L210.9 410.1C225.3 400.7 245.3 404 255.5 418.4C265.8 432.8 262.5 452.8 248.1 463.1L246.5 464.2C188.1 505.3 110.2 498.7 60.21 448.8C3.741 392.3 3.741 300.7 60.21 244.3L172.5 131.1zM467.5 380C411 436.5 319.5 436.5 263 380C213 330 206.5 251.2 247.6 193.7L248.7 192.1C258.1 177.8 278.1 174.4 293.3 184.7C307.7 194.1 311.1 214.1 300.8 229.3L299.7 230.9C276.8 262.1 280.4 306.9 308.3 334.8C339.7 366.2 390.8 366.2 422.3 334.8L534.5 222.5C566 191 566 139.1 534.5 108.5C506.7 80.63 462.7 76.99 430.7 99.9L429.1 101C414.7 111.3 394.7 107.1 384.5 93.58C374.2 79.2 377.5 59.21 391.9 48.94L393.5 47.82C451 6.731 529.8 13.25 579.8 63.24C636.3 119.7 636.3 211.3 579.8 267.7L467.5 380z\"\n ]\n};\nvar faChain = faLink;\nvar faLinkSlash = {\n prefix: 'fas',\n iconName: 'link-slash',\n icon: [\n 640,\n 512,\n [\n \"chain-broken\",\n \"chain-slash\",\n \"unlink\"\n ],\n \"f127\",\n \"M185.7 120.3C242.5 75.82 324.7 79.73 376.1 131.1C420.1 175.1 430.9 239.6 406.7 293.5L438.6 318.4L534.5 222.5C566 191 566 139.1 534.5 108.5C506.7 80.63 462.7 76.1 430.7 99.9L429.1 101C414.7 111.3 394.7 107.1 384.5 93.58C374.2 79.2 377.5 59.21 391.9 48.94L393.5 47.82C451 6.732 529.8 13.25 579.8 63.24C636.3 119.7 636.3 211.3 579.8 267.7L489.3 358.2L630.8 469.1C641.2 477.3 643.1 492.4 634.9 502.8C626.7 513.2 611.6 515.1 601.2 506.9L9.196 42.89C-1.236 34.71-3.065 19.63 5.112 9.196C13.29-1.236 28.37-3.065 38.81 5.112L185.7 120.3zM238.1 161.1L353.4 251.7C359.3 225.5 351.7 197.2 331.7 177.2C306.6 152.1 269.1 147 238.1 161.1V161.1zM263 380C233.1 350.1 218.7 309.8 220.9 270L406.6 416.4C357.4 431 301.9 418.9 263 380V380zM116.6 187.9L167.2 227.8L105.5 289.5C73.99 320.1 73.99 372 105.5 403.5C133.3 431.4 177.3 435 209.3 412.1L210.9 410.1C225.3 400.7 245.3 404 255.5 418.4C265.8 432.8 262.5 452.8 248.1 463.1L246.5 464.2C188.1 505.3 110.2 498.7 60.21 448.8C3.741 392.3 3.741 300.7 60.21 244.3L116.6 187.9z\"\n ]\n};\nvar faChainBroken = faLinkSlash;\nvar faChainSlash = faLinkSlash;\nvar faUnlink = faLinkSlash;\nvar faLiraSign = {\n prefix: 'fas',\n iconName: 'lira-sign',\n icon: [\n 320,\n 512,\n [\n 8356\n ],\n \"f195\",\n \"M111.1 191.1H224C241.7 191.1 256 206.3 256 223.1C256 241.7 241.7 255.1 224 255.1H111.1V287.1H224C241.7 287.1 256 302.3 256 319.1C256 337.7 241.7 352 224 352H110.8C108.1 374.2 100.8 395.6 89.2 414.9L88.52 416H288C305.7 416 320 430.3 320 448C320 465.7 305.7 480 288 480H32C20.47 480 9.834 473.8 4.154 463.8C-1.527 453.7-1.371 441.4 4.56 431.5L34.32 381.9C39.89 372.6 43.83 362.5 46.01 352H32C14.33 352 0 337.7 0 320C0 302.3 14.33 288 32 288H48V256H32C14.33 256 0 241.7 0 224C0 206.3 14.33 192 32 192H48V160.4C48 89.47 105.5 32 176.4 32C190.2 32 203.9 34.22 216.1 38.59L298.1 65.64C314.9 71.23 323.9 89.35 318.4 106.1C312.8 122.9 294.6 131.9 277.9 126.4L196.7 99.3C190.2 97.12 183.3 96 176.4 96C140.8 96 112 124.8 112 160.4L111.1 191.1z\"\n ]\n};\nvar faList = {\n prefix: 'fas',\n iconName: 'list',\n icon: [\n 512,\n 512,\n [\n \"list-squares\"\n ],\n \"f03a\",\n \"M88 48C101.3 48 112 58.75 112 72V120C112 133.3 101.3 144 88 144H40C26.75 144 16 133.3 16 120V72C16 58.75 26.75 48 40 48H88zM480 64C497.7 64 512 78.33 512 96C512 113.7 497.7 128 480 128H192C174.3 128 160 113.7 160 96C160 78.33 174.3 64 192 64H480zM480 224C497.7 224 512 238.3 512 256C512 273.7 497.7 288 480 288H192C174.3 288 160 273.7 160 256C160 238.3 174.3 224 192 224H480zM480 384C497.7 384 512 398.3 512 416C512 433.7 497.7 448 480 448H192C174.3 448 160 433.7 160 416C160 398.3 174.3 384 192 384H480zM16 232C16 218.7 26.75 208 40 208H88C101.3 208 112 218.7 112 232V280C112 293.3 101.3 304 88 304H40C26.75 304 16 293.3 16 280V232zM88 368C101.3 368 112 378.7 112 392V440C112 453.3 101.3 464 88 464H40C26.75 464 16 453.3 16 440V392C16 378.7 26.75 368 40 368H88z\"\n ]\n};\nvar faListSquares = faList;\nvar faListCheck = {\n prefix: 'fas',\n iconName: 'list-check',\n icon: [\n 512,\n 512,\n [\n \"tasks\"\n ],\n \"f0ae\",\n \"M152.1 38.16C161.9 47.03 162.7 62.2 153.8 72.06L81.84 152.1C77.43 156.9 71.21 159.8 64.63 159.1C58.05 160.2 51.69 157.6 47.03 152.1L7.029 112.1C-2.343 103.6-2.343 88.4 7.029 79.03C16.4 69.66 31.6 69.66 40.97 79.03L63.08 101.1L118.2 39.94C127 30.09 142.2 29.29 152.1 38.16V38.16zM152.1 198.2C161.9 207 162.7 222.2 153.8 232.1L81.84 312.1C77.43 316.9 71.21 319.8 64.63 319.1C58.05 320.2 51.69 317.6 47.03 312.1L7.029 272.1C-2.343 263.6-2.343 248.4 7.029 239C16.4 229.7 31.6 229.7 40.97 239L63.08 261.1L118.2 199.9C127 190.1 142.2 189.3 152.1 198.2V198.2zM224 96C224 78.33 238.3 64 256 64H480C497.7 64 512 78.33 512 96C512 113.7 497.7 128 480 128H256C238.3 128 224 113.7 224 96V96zM224 256C224 238.3 238.3 224 256 224H480C497.7 224 512 238.3 512 256C512 273.7 497.7 288 480 288H256C238.3 288 224 273.7 224 256zM160 416C160 398.3 174.3 384 192 384H480C497.7 384 512 398.3 512 416C512 433.7 497.7 448 480 448H192C174.3 448 160 433.7 160 416zM0 416C0 389.5 21.49 368 48 368C74.51 368 96 389.5 96 416C96 442.5 74.51 464 48 464C21.49 464 0 442.5 0 416z\"\n ]\n};\nvar faTasks = faListCheck;\nvar faListOl = {\n prefix: 'fas',\n iconName: 'list-ol',\n icon: [\n 576,\n 512,\n [\n \"list-1-2\",\n \"list-numeric\"\n ],\n \"f0cb\",\n \"M55.1 56.04C55.1 42.78 66.74 32.04 79.1 32.04H111.1C125.3 32.04 135.1 42.78 135.1 56.04V176H151.1C165.3 176 175.1 186.8 175.1 200C175.1 213.3 165.3 224 151.1 224H71.1C58.74 224 47.1 213.3 47.1 200C47.1 186.8 58.74 176 71.1 176H87.1V80.04H79.1C66.74 80.04 55.1 69.29 55.1 56.04V56.04zM118.7 341.2C112.1 333.8 100.4 334.3 94.65 342.4L83.53 357.9C75.83 368.7 60.84 371.2 50.05 363.5C39.26 355.8 36.77 340.8 44.47 330.1L55.59 314.5C79.33 281.2 127.9 278.8 154.8 309.6C176.1 333.1 175.6 370.5 153.7 394.3L118.8 432H152C165.3 432 176 442.7 176 456C176 469.3 165.3 480 152 480H64C54.47 480 45.84 474.4 42.02 465.6C38.19 456.9 39.9 446.7 46.36 439.7L118.4 361.7C123.7 355.9 123.8 347.1 118.7 341.2L118.7 341.2zM512 64C529.7 64 544 78.33 544 96C544 113.7 529.7 128 512 128H256C238.3 128 224 113.7 224 96C224 78.33 238.3 64 256 64H512zM512 224C529.7 224 544 238.3 544 256C544 273.7 529.7 288 512 288H256C238.3 288 224 273.7 224 256C224 238.3 238.3 224 256 224H512zM512 384C529.7 384 544 398.3 544 416C544 433.7 529.7 448 512 448H256C238.3 448 224 433.7 224 416C224 398.3 238.3 384 256 384H512z\"\n ]\n};\nvar faList12 = faListOl;\nvar faListNumeric = faListOl;\nvar faListUl = {\n prefix: 'fas',\n iconName: 'list-ul',\n icon: [\n 512,\n 512,\n [\n \"list-dots\"\n ],\n \"f0ca\",\n \"M16 96C16 69.49 37.49 48 64 48C90.51 48 112 69.49 112 96C112 122.5 90.51 144 64 144C37.49 144 16 122.5 16 96zM480 64C497.7 64 512 78.33 512 96C512 113.7 497.7 128 480 128H192C174.3 128 160 113.7 160 96C160 78.33 174.3 64 192 64H480zM480 224C497.7 224 512 238.3 512 256C512 273.7 497.7 288 480 288H192C174.3 288 160 273.7 160 256C160 238.3 174.3 224 192 224H480zM480 384C497.7 384 512 398.3 512 416C512 433.7 497.7 448 480 448H192C174.3 448 160 433.7 160 416C160 398.3 174.3 384 192 384H480zM16 416C16 389.5 37.49 368 64 368C90.51 368 112 389.5 112 416C112 442.5 90.51 464 64 464C37.49 464 16 442.5 16 416zM112 256C112 282.5 90.51 304 64 304C37.49 304 16 282.5 16 256C16 229.5 37.49 208 64 208C90.51 208 112 229.5 112 256z\"\n ]\n};\nvar faListDots = faListUl;\nvar faLitecoinSign = {\n prefix: 'fas',\n iconName: 'litecoin-sign',\n icon: [\n 384,\n 512,\n [],\n \"e1d3\",\n \"M128 195.3L247.2 161.2C264.2 156.4 281.9 166.2 286.8 183.2C291.6 200.2 281.8 217.9 264.8 222.8L128 261.9V416H352C369.7 416 384 430.3 384 448C384 465.7 369.7 480 352 480H96C78.33 480 64 465.7 64 448V280.1L40.79 286.8C23.8 291.6 6.087 281.8 1.232 264.8C-3.623 247.8 6.216 230.1 23.21 225.2L64 213.6V64C64 46.33 78.33 32 96 32C113.7 32 128 46.33 128 64V195.3z\"\n ]\n};\nvar faLocationArrow = {\n prefix: 'fas',\n iconName: 'location-arrow',\n icon: [\n 448,\n 512,\n [],\n \"f124\",\n \"M285.6 444.1C279.8 458.3 264.8 466.3 249.8 463.4C234.8 460.4 223.1 447.3 223.1 432V256H47.1C32.71 256 19.55 245.2 16.6 230.2C13.65 215.2 21.73 200.2 35.88 194.4L387.9 50.38C399.8 45.5 413.5 48.26 422.6 57.37C431.7 66.49 434.5 80.19 429.6 92.12L285.6 444.1z\"\n ]\n};\nvar faLocationCrosshairs = {\n prefix: 'fas',\n iconName: 'location-crosshairs',\n icon: [\n 512,\n 512,\n [\n \"location\"\n ],\n \"f601\",\n \"M176 256C176 211.8 211.8 176 256 176C300.2 176 336 211.8 336 256C336 300.2 300.2 336 256 336C211.8 336 176 300.2 176 256zM256 0C273.7 0 288 14.33 288 32V66.65C368.4 80.14 431.9 143.6 445.3 224H480C497.7 224 512 238.3 512 256C512 273.7 497.7 288 480 288H445.3C431.9 368.4 368.4 431.9 288 445.3V480C288 497.7 273.7 512 256 512C238.3 512 224 497.7 224 480V445.3C143.6 431.9 80.14 368.4 66.65 288H32C14.33 288 0 273.7 0 256C0 238.3 14.33 224 32 224H66.65C80.14 143.6 143.6 80.14 224 66.65V32C224 14.33 238.3 0 256 0zM128 256C128 326.7 185.3 384 256 384C326.7 384 384 326.7 384 256C384 185.3 326.7 128 256 128C185.3 128 128 185.3 128 256z\"\n ]\n};\nvar faLocation = faLocationCrosshairs;\nvar faLocationDot = {\n prefix: 'fas',\n iconName: 'location-dot',\n icon: [\n 384,\n 512,\n [\n \"map-marker-alt\"\n ],\n \"f3c5\",\n \"M168.3 499.2C116.1 435 0 279.4 0 192C0 85.96 85.96 0 192 0C298 0 384 85.96 384 192C384 279.4 267 435 215.7 499.2C203.4 514.5 180.6 514.5 168.3 499.2H168.3zM192 256C227.3 256 256 227.3 256 192C256 156.7 227.3 128 192 128C156.7 128 128 156.7 128 192C128 227.3 156.7 256 192 256z\"\n ]\n};\nvar faMapMarkerAlt = faLocationDot;\nvar faLocationPin = {\n prefix: 'fas',\n iconName: 'location-pin',\n icon: [\n 384,\n 512,\n [\n \"map-marker\"\n ],\n \"f041\",\n \"M384 192C384 279.4 267 435 215.7 499.2C203.4 514.5 180.6 514.5 168.3 499.2C116.1 435 0 279.4 0 192C0 85.96 85.96 0 192 0C298 0 384 85.96 384 192H384z\"\n ]\n};\nvar faMapMarker = faLocationPin;\nvar faLock = {\n prefix: 'fas',\n iconName: 'lock',\n icon: [\n 448,\n 512,\n [\n 128274\n ],\n \"f023\",\n \"M80 192V144C80 64.47 144.5 0 224 0C303.5 0 368 64.47 368 144V192H384C419.3 192 448 220.7 448 256V448C448 483.3 419.3 512 384 512H64C28.65 512 0 483.3 0 448V256C0 220.7 28.65 192 64 192H80zM144 192H304V144C304 99.82 268.2 64 224 64C179.8 64 144 99.82 144 144V192z\"\n ]\n};\nvar faLockOpen = {\n prefix: 'fas',\n iconName: 'lock-open',\n icon: [\n 576,\n 512,\n [],\n \"f3c1\",\n \"M352 192H384C419.3 192 448 220.7 448 256V448C448 483.3 419.3 512 384 512H64C28.65 512 0 483.3 0 448V256C0 220.7 28.65 192 64 192H288V144C288 64.47 352.5 0 432 0C511.5 0 576 64.47 576 144V192C576 209.7 561.7 224 544 224C526.3 224 512 209.7 512 192V144C512 99.82 476.2 64 432 64C387.8 64 352 99.82 352 144V192z\"\n ]\n};\nvar faLungs = {\n prefix: 'fas',\n iconName: 'lungs',\n icon: [\n 640,\n 512,\n [\n 129729\n ],\n \"f604\",\n \"M640 419.8c0 61.25-62.5 105.5-125.3 88.63l-59.53-15.88c-42.12-11.38-71.25-47.5-71.25-88.63L384 316.4l85.88 57.25c3.625 2.375 8.625 1.375 11-2.25l8.875-13.37c2.5-3.625 1.5-8.625-2.125-11L320 235.3l-167.6 111.8c-1.75 1.125-3 3-3.375 5c-.375 2.125 0 4.25 1.25 6l8.875 13.37c1.125 1.75 3 3 5 3.375c2.125 .375 4.25 0 6-1.125L256 316.4l.0313 87.5c0 41.13-29.12 77.25-71.25 88.63l-59.53 15.88C62.5 525.3 0 481 0 419.8c0-10 1.25-19.88 3.875-29.63C25.5 308.9 59.91 231 105.9 159.1c22.12-34.63 36.12-63.13 80.12-63.13C224.7 96 256 125.4 256 161.8v60.1l32.88-21.97C293.4 196.9 296 192 296 186.6V16C296 7.125 303.1 0 312 0h16c8.875 0 16 7.125 16 16v170.6c0 5.375 2.625 10.25 7.125 13.25L384 221.8v-60.1c0-36.38 31.34-65.75 69.97-65.75c43.1 0 58 28.5 80.13 63.13c46 71.88 80.41 149.8 102 231C638.8 399.9 640 409.8 640 419.8z\"\n ]\n};\nvar faLungsVirus = {\n prefix: 'fas',\n iconName: 'lungs-virus',\n icon: [\n 640,\n 512,\n [],\n \"e067\",\n \"M195.5 444.5c-18.71-18.72-18.71-49.16 .0033-67.87l8.576-8.576H192c-26.47 0-48-21.53-48-48c0-26.47 21.53-48 48-48l12.12-.0055L195.5 263.4c-18.71-18.72-18.71-49.16 0-67.88C204.6 186.5 216.7 181.5 229.5 181.5c9.576 0 18.72 2.799 26.52 7.986l.04-27.75c0-36.38-31.42-65.72-70.05-65.72c-44 0-57.97 28.5-80.09 63.13c-46 71.88-80.39 149.8-102 231C1.257 399.9 0 409.8 0 419.8c0 61.25 62.5 105.5 125.3 88.62l59.5-15.9c21.74-5.867 39.91-18.39 52.51-34.73c-2.553 .4141-5.137 .7591-7.774 .7591C216.7 458.5 204.6 453.5 195.5 444.5zM343.1 150.7L344 16C344 7.125 336.9 0 328 0h-16c-8.875 0-16 7.125-16 16L295.1 150.7c7.088-4.133 15.22-6.675 23.1-6.675S336.9 146.5 343.1 150.7zM421.8 421.8c6.25-6.25 6.25-16.37 0-22.62l-8.576-8.576c-20.16-20.16-5.881-54.63 22.63-54.63H448c8.844 0 16-7.156 16-16c0-8.844-7.156-16-16-16h-12.12c-28.51 0-42.79-34.47-22.63-54.63l8.576-8.577c6.25-6.25 6.25-16.37 0-22.62s-16.38-6.25-22.62 0l-8.576 8.577C370.5 246.9 336 232.6 336 204.1v-12.12c0-8.844-7.156-15.1-16-15.1s-16 7.156-16 15.1v12.12c0 28.51-34.47 42.79-54.63 22.63L240.8 218.2c-6.25-6.25-16.38-6.25-22.62 0s-6.25 16.37 0 22.62l8.576 8.577c20.16 20.16 5.881 54.63-22.63 54.63H192c-8.844 0-16 7.156-16 16c0 8.844 7.156 16 16 16h12.12c28.51 0 42.79 34.47 22.63 54.63l-8.576 8.576c-6.25 6.25-6.25 16.37 0 22.62c3.125 3.125 7.219 4.688 11.31 4.688s8.188-1.562 11.31-4.688l8.576-8.575C269.5 393.1 304 407.4 304 435.9v12.12c0 8.844 7.156 16 16 16s16-7.156 16-16v-12.12c0-28.51 34.47-42.79 54.63-22.63l8.576 8.575c3.125 3.125 7.219 4.688 11.31 4.688S418.7 424.9 421.8 421.8zM288 303.1c-8.836 0-16-7.162-16-15.1S279.2 271.1 288 271.1S304 279.2 304 287.1S296.8 303.1 288 303.1zM352 367.1c-8.836 0-16-7.166-16-16s7.164-15.1 16-15.1s16 7.166 16 16S360.8 367.1 352 367.1zM636.1 390.1c-21.62-81.25-56.02-159.1-102-231c-22.12-34.63-36.09-63.13-80.09-63.13c-38.62 0-70.01 29.35-70.01 65.73v27.74c7.795-5.188 16.94-7.986 26.52-7.986c12.82 0 24.88 4.999 33.95 14.07c18.71 18.72 18.71 49.16 0 67.88l-8.576 8.571L448 272c26.47 0 48 21.54 48 48c0 26.47-21.53 48-48 48h-12.12l8.576 8.576c18.71 18.72 18.71 49.16-.0072 67.87c-9.066 9.066-21.12 14.06-33.94 14.06c-2.637 0-5.211-.3438-7.764-.7578c12.6 16.34 30.77 28.86 52.51 34.73l59.5 15.9C577.5 525.3 640 481 640 419.8C640 409.8 638.7 399.9 636.1 390.1z\"\n ]\n};\nvar faM = {\n prefix: 'fas',\n iconName: 'm',\n icon: [\n 448,\n 512,\n [\n 109\n ],\n \"4d\",\n \"M448 64.01v384c0 17.67-14.31 32-32 32s-32-14.33-32-32V169.7l-133.4 200.1c-11.88 17.81-41.38 17.81-53.25 0L64 169.7v278.3c0 17.67-14.31 32-32 32s-32-14.33-32-32v-384c0-14.09 9.219-26.55 22.72-30.63c13.47-4.156 28.09 1.141 35.91 12.88L224 294.3l165.4-248.1c7.812-11.73 22.47-17.03 35.91-12.88C438.8 37.47 448 49.92 448 64.01z\"\n ]\n};\nvar faMagnet = {\n prefix: 'fas',\n iconName: 'magnet',\n icon: [\n 448,\n 512,\n [\n 129522\n ],\n \"f076\",\n \"M128 160V256C128 309 170.1 352 224 352C277 352 320 309 320 256V160H448V256C448 379.7 347.7 480 224 480C100.3 480 0 379.7 0 256V160H128zM0 64C0 46.33 14.33 32 32 32H96C113.7 32 128 46.33 128 64V128H0V64zM320 64C320 46.33 334.3 32 352 32H416C433.7 32 448 46.33 448 64V128H320V64z\"\n ]\n};\nvar faMagnifyingGlass = {\n prefix: 'fas',\n iconName: 'magnifying-glass',\n icon: [\n 512,\n 512,\n [\n 128269,\n \"search\"\n ],\n \"f002\",\n \"M500.3 443.7l-119.7-119.7c27.22-40.41 40.65-90.9 33.46-144.7C401.8 87.79 326.8 13.32 235.2 1.723C99.01-15.51-15.51 99.01 1.724 235.2c11.6 91.64 86.08 166.7 177.6 178.9c53.8 7.189 104.3-6.236 144.7-33.46l119.7 119.7c15.62 15.62 40.95 15.62 56.57 0C515.9 484.7 515.9 459.3 500.3 443.7zM79.1 208c0-70.58 57.42-128 128-128s128 57.42 128 128c0 70.58-57.42 128-128 128S79.1 278.6 79.1 208z\"\n ]\n};\nvar faSearch = faMagnifyingGlass;\nvar faMagnifyingGlassDollar = {\n prefix: 'fas',\n iconName: 'magnifying-glass-dollar',\n icon: [\n 512,\n 512,\n [\n \"search-dollar\"\n ],\n \"f688\",\n \"M500.3 443.7l-119.7-119.7c27.22-40.41 40.65-90.9 33.46-144.7c-12.23-91.55-87.28-166-178.9-177.6c-136.2-17.24-250.7 97.28-233.4 233.4c11.6 91.64 86.07 166.7 177.6 178.9c53.81 7.191 104.3-6.235 144.7-33.46l119.7 119.7c15.62 15.62 40.95 15.62 56.57 .0004C515.9 484.7 515.9 459.3 500.3 443.7zM273.7 253.8C269.8 276.4 252.6 291.3 228 296.1V304c0 11.03-8.953 20-20 20S188 315 188 304V295.2C178.2 293.2 168.4 289.9 159.6 286.8L154.8 285.1C144.4 281.4 138.9 269.9 142.6 259.5C146.2 249.1 157.6 243.7 168.1 247.3l5.062 1.812c8.562 3.094 18.25 6.562 25.91 7.719c16.23 2.5 33.47-.0313 35.17-9.812c1.219-7.094 .4062-10.62-31.8-19.84L196.2 225.4C177.8 219.1 134.5 207.3 142.3 162.2C146.2 139.6 163.5 124.8 188 120V112c0-11.03 8.953-20 20-20S228 100.1 228 112v8.695c6.252 1.273 13.06 3.07 21.47 5.992c10.42 3.625 15.95 15.03 12.33 25.47C258.2 162.6 246.8 168.1 236.3 164.5C228.2 161.7 221.8 159.9 216.8 159.2c-16.11-2.594-33.38 .0313-35.08 9.812c-1 5.812-1.719 10 25.7 18.03l6 1.719C238.9 196 281.5 208.2 273.7 253.8z\"\n ]\n};\nvar faSearchDollar = faMagnifyingGlassDollar;\nvar faMagnifyingGlassLocation = {\n prefix: 'fas',\n iconName: 'magnifying-glass-location',\n icon: [\n 512,\n 512,\n [\n \"search-location\"\n ],\n \"f689\",\n \"M236 176c0 15.46-12.54 28-28 28S180 191.5 180 176S192.5 148 208 148S236 160.5 236 176zM500.3 500.3c-15.62 15.62-40.95 15.62-56.57 0l-119.7-119.7c-40.41 27.22-90.9 40.65-144.7 33.46c-91.55-12.23-166-87.28-177.6-178.9c-17.24-136.2 97.29-250.7 233.4-233.4c91.64 11.6 166.7 86.07 178.9 177.6c7.19 53.8-6.236 104.3-33.46 144.7l119.7 119.7C515.9 459.3 515.9 484.7 500.3 500.3zM294.1 182.2C294.1 134.5 255.6 96 207.1 96C160.4 96 121.9 134.5 121.9 182.2c0 38.35 56.29 108.5 77.87 134C201.8 318.5 204.7 320 207.1 320c3.207 0 6.26-1.459 8.303-3.791C237.8 290.7 294.1 220.5 294.1 182.2z\"\n ]\n};\nvar faSearchLocation = faMagnifyingGlassLocation;\nvar faMagnifyingGlassMinus = {\n prefix: 'fas',\n iconName: 'magnifying-glass-minus',\n icon: [\n 512,\n 512,\n [\n \"search-minus\"\n ],\n \"f010\",\n \"M500.3 443.7l-119.7-119.7c27.22-40.41 40.65-90.9 33.46-144.7c-12.23-91.55-87.28-166-178.9-177.6c-136.2-17.24-250.7 97.28-233.4 233.4c11.6 91.64 86.07 166.7 177.6 178.9c53.81 7.191 104.3-6.235 144.7-33.46l119.7 119.7c15.62 15.62 40.95 15.62 56.57 .0003C515.9 484.7 515.9 459.3 500.3 443.7zM288 232H127.1C114.7 232 104 221.3 104 208s10.74-24 23.1-24h160C301.3 184 312 194.7 312 208S301.3 232 288 232z\"\n ]\n};\nvar faSearchMinus = faMagnifyingGlassMinus;\nvar faMagnifyingGlassPlus = {\n prefix: 'fas',\n iconName: 'magnifying-glass-plus',\n icon: [\n 512,\n 512,\n [\n \"search-plus\"\n ],\n \"f00e\",\n \"M500.3 443.7l-119.7-119.7c27.22-40.41 40.65-90.9 33.46-144.7c-12.23-91.55-87.28-166-178.9-177.6c-136.2-17.24-250.7 97.28-233.4 233.4c11.6 91.64 86.07 166.7 177.6 178.9c53.81 7.191 104.3-6.235 144.7-33.46l119.7 119.7c15.62 15.62 40.95 15.62 56.57 .0003C515.9 484.7 515.9 459.3 500.3 443.7zM288 232H231.1V288c0 13.26-10.74 24-23.1 24C194.7 312 184 301.3 184 288V232H127.1C114.7 232 104 221.3 104 208s10.74-24 23.1-24H184V128c0-13.26 10.74-24 23.1-24S231.1 114.7 231.1 128v56h56C301.3 184 312 194.7 312 208S301.3 232 288 232z\"\n ]\n};\nvar faSearchPlus = faMagnifyingGlassPlus;\nvar faManatSign = {\n prefix: 'fas',\n iconName: 'manat-sign',\n icon: [\n 384,\n 512,\n [],\n \"e1d5\",\n \"M224 64V98.65C314.8 113.9 384 192.9 384 288V448C384 465.7 369.7 480 352 480C334.3 480 320 465.7 320 448V288C320 228.4 279.2 178.2 224 164V448C224 465.7 209.7 480 192 480C174.3 480 160 465.7 160 448V164C104.8 178.2 64 228.4 64 288V448C64 465.7 49.67 480 32 480C14.33 480 0 465.7 0 448V288C0 192.9 69.19 113.9 160 98.65V64C160 46.33 174.3 32 192 32C209.7 32 224 46.33 224 64z\"\n ]\n};\nvar faMap = {\n prefix: 'fas',\n iconName: 'map',\n icon: [\n 576,\n 512,\n [\n 62072,\n 128506\n ],\n \"f279\",\n \"M384 476.1L192 421.2V35.93L384 90.79V476.1zM416 88.37L543.1 37.53C558.9 31.23 576 42.84 576 59.82V394.6C576 404.4 570 413.2 560.9 416.9L416 474.8V88.37zM15.09 95.13L160 37.17V423.6L32.91 474.5C17.15 480.8 0 469.2 0 452.2V117.4C0 107.6 5.975 98.78 15.09 95.13V95.13z\"\n ]\n};\nvar faMapLocation = {\n prefix: 'fas',\n iconName: 'map-location',\n icon: [\n 576,\n 512,\n [\n \"map-marked\"\n ],\n \"f59f\",\n \"M273.2 311.1C241.1 271.9 167.1 174.6 167.1 120C167.1 53.73 221.7 0 287.1 0C354.3 0 408 53.73 408 120C408 174.6 334.9 271.9 302.8 311.1C295.1 321.6 280.9 321.6 273.2 311.1V311.1zM416 503V200.4C419.5 193.5 422.7 186.7 425.6 179.8C426.1 178.6 426.6 177.4 427.1 176.1L543.1 129.7C558.9 123.4 576 135 576 152V422.8C576 432.6 570 441.4 560.9 445.1L416 503zM15.09 187.3L137.6 138.3C140 152.5 144.9 166.6 150.4 179.8C153.3 186.7 156.5 193.5 160 200.4V451.8L32.91 502.7C17.15 508.1 0 497.4 0 480.4V209.6C0 199.8 5.975 190.1 15.09 187.3H15.09zM384 504.3L191.1 449.4V255C212.5 286.3 234.3 314.6 248.2 331.1C268.7 357.6 307.3 357.6 327.8 331.1C341.7 314.6 363.5 286.3 384 255L384 504.3z\"\n ]\n};\nvar faMapMarked = faMapLocation;\nvar faMapLocationDot = {\n prefix: 'fas',\n iconName: 'map-location-dot',\n icon: [\n 576,\n 512,\n [\n \"map-marked-alt\"\n ],\n \"f5a0\",\n \"M408 120C408 174.6 334.9 271.9 302.8 311.1C295.1 321.6 280.9 321.6 273.2 311.1C241.1 271.9 168 174.6 168 120C168 53.73 221.7 0 288 0C354.3 0 408 53.73 408 120zM288 152C310.1 152 328 134.1 328 112C328 89.91 310.1 72 288 72C265.9 72 248 89.91 248 112C248 134.1 265.9 152 288 152zM425.6 179.8C426.1 178.6 426.6 177.4 427.1 176.1L543.1 129.7C558.9 123.4 576 135 576 152V422.8C576 432.6 570 441.4 560.9 445.1L416 503V200.4C419.5 193.5 422.7 186.7 425.6 179.8zM150.4 179.8C153.3 186.7 156.5 193.5 160 200.4V451.8L32.91 502.7C17.15 508.1 0 497.4 0 480.4V209.6C0 199.8 5.975 190.1 15.09 187.3L137.6 138.3C140 152.5 144.9 166.6 150.4 179.8H150.4zM327.8 331.1C341.7 314.6 363.5 286.3 384 255V504.3L192 449.4V255C212.5 286.3 234.3 314.6 248.2 331.1C268.7 357.6 307.3 357.6 327.8 331.1L327.8 331.1z\"\n ]\n};\nvar faMapMarkedAlt = faMapLocationDot;\nvar faMapPin = {\n prefix: 'fas',\n iconName: 'map-pin',\n icon: [\n 320,\n 512,\n [\n 128205\n ],\n \"f276\",\n \"M320 144C320 223.5 255.5 288 176 288C96.47 288 32 223.5 32 144C32 64.47 96.47 0 176 0C255.5 0 320 64.47 320 144zM192 64C192 55.16 184.8 48 176 48C122.1 48 80 90.98 80 144C80 152.8 87.16 160 96 160C104.8 160 112 152.8 112 144C112 108.7 140.7 80 176 80C184.8 80 192 72.84 192 64zM144 480V317.1C154.4 319 165.1 319.1 176 319.1C186.9 319.1 197.6 319 208 317.1V480C208 497.7 193.7 512 176 512C158.3 512 144 497.7 144 480z\"\n ]\n};\nvar faMarker = {\n prefix: 'fas',\n iconName: 'marker',\n icon: [\n 512,\n 512,\n [],\n \"f5a1\",\n \"M480.1 160.1L316.3 325.7L186.3 195.7L302.1 80L288.1 66.91C279.6 57.54 264.4 57.54 255 66.91L168.1 152.1C159.6 162.3 144.4 162.3 135 152.1C125.7 143.6 125.7 128.4 135 119L221.1 32.97C249.2 4.853 294.8 4.853 322.9 32.97L336 46.06L351 31.03C386.9-4.849 445.1-4.849 480.1 31.03C516.9 66.91 516.9 125.1 480.1 160.1V160.1zM229.5 412.5C181.5 460.5 120.3 493.2 53.7 506.5L28.71 511.5C20.84 513.1 12.7 510.6 7.03 504.1C1.356 499.3-1.107 491.2 .4662 483.3L5.465 458.3C18.78 391.7 51.52 330.5 99.54 282.5L163.7 218.3L293.7 348.3L229.5 412.5z\"\n ]\n};\nvar faMars = {\n prefix: 'fas',\n iconName: 'mars',\n icon: [\n 448,\n 512,\n [\n 9794\n ],\n \"f222\",\n \"M431.1 31.1l-112.6 0c-21.42 0-32.15 25.85-17 40.97l29.61 29.56l-56.65 56.55c-30.03-20.66-65.04-31-100-31c-47.99-.002-95.96 19.44-131.1 58.39c-60.86 67.51-58.65 175 4.748 240.1C83.66 462.2 129.6 480 175.5 480c45.12 0 90.34-17.18 124.8-51.55c61.11-60.99 67.77-155.6 20.42-224.1l56.65-56.55l29.61 29.56C411.9 182.2 417.9 184.4 423.8 184.4C436.1 184.4 448 174.8 448 160.4V47.1C448 39.16 440.8 31.1 431.1 31.1zM243.5 371.9c-18.75 18.71-43.38 28.07-68 28.07c-24.63 0-49.25-9.355-68.01-28.07c-37.5-37.43-37.5-98.33 0-135.8c18.75-18.71 43.38-28.07 68.01-28.07c24.63 0 49.25 9.357 68 28.07C281 273.5 281 334.5 243.5 371.9z\"\n ]\n};\nvar faMarsAndVenus = {\n prefix: 'fas',\n iconName: 'mars-and-venus',\n icon: [\n 512,\n 512,\n [\n 9893\n ],\n \"f224\",\n \"M480 .0002l-112.4 .0001c-21.38 0-32.09 25.85-16.97 40.97l29.56 29.56l-27.11 27.11C326.1 76.85 292.7 64 256 64c-88.37 0-160 71.63-160 160c0 77.4 54.97 141.9 128 156.8v19.22H192c-8.836 0-16 7.162-16 16v31.1c0 8.836 7.164 16 16 16l32 .0001v32c0 8.836 7.164 16 16 16h32c8.838 0 16-7.164 16-16v-32l32-.0001c8.838 0 16-7.164 16-16v-31.1c0-8.838-7.162-16-16-16h-32v-19.22c73.03-14.83 128-79.37 128-156.8c0-28.38-8.018-54.65-20.98-77.77l30.45-30.45l29.56 29.56C470.1 160.5 496 149.8 496 128.4V16C496 7.164 488.8 .0002 480 .0002zM256 304c-44.11 0-80-35.89-80-80c0-44.11 35.89-80 80-80c44.11 0 80 35.89 80 80C336 268.1 300.1 304 256 304z\"\n ]\n};\nvar faMarsDouble = {\n prefix: 'fas',\n iconName: 'mars-double',\n icon: [\n 640,\n 512,\n [\n 9891\n ],\n \"f227\",\n \"M320.7 204.3l56.65-56.55l29.61 29.56C422.1 192.5 448 181.7 448 160.4V47.1c0-8.838-7.176-15.1-16.03-15.1H319.4c-21.42 0-32.15 25.85-17 40.97l29.61 29.56L275.4 159.1c-71.21-48.99-170.4-39.96-231.1 27.39c-60.86 67.51-58.65 175 4.748 240.1c68.7 70.57 181.8 71.19 251.3 1.847C361.4 367.5 368 272.9 320.7 204.3zM243.5 371.9c-37.5 37.43-98.51 37.43-136 0s-37.5-98.33 0-135.8c37.5-37.43 98.51-37.43 136 0C281 273.5 281 334.5 243.5 371.9zM623.1 32h-112.6c-21.42 0-32.15 25.85-17 40.97l29.61 29.56L480 146.5v13.91C480 191.3 454.8 216.4 423.8 216.4C421.2 216.4 418.6 216 416 215.6v5.862c6.922 4.049 13.58 8.691 19.51 14.61c37.5 37.43 37.5 98.33 0 135.8c-18.75 18.71-43.38 28.07-68 28.07c-2.277 0-4.523-.4883-6.795-.6484c-9.641 18.69-22.1 36.24-37.64 51.77c-6.059 6.059-12.49 11.53-19.13 16.73C324.4 475.7 345.9 480 367.5 480c45.12 0 90.34-17.18 124.8-51.55c61.11-60.99 67.77-155.6 20.42-224.1l56.65-56.55l29.61 29.56c4.898 4.889 10.92 7.075 16.83 7.075C628.1 184.4 640 174.8 640 160.4V48C640 39.16 632.8 32 623.1 32z\"\n ]\n};\nvar faMarsStroke = {\n prefix: 'fas',\n iconName: 'mars-stroke',\n icon: [\n 512,\n 512,\n [\n 9894\n ],\n \"f229\",\n \"M496 .0002l-112.4 .0001c-21.38 0-32.09 25.85-16.97 40.97l29.56 29.56l-24.33 24.34l-33.94-33.94c-6.248-6.25-16.38-6.248-22.63 0l-22.63 22.63c-6.25 6.25-6.25 16.38 0 22.63l33.94 33.94l-18.96 18.96C239.1 111.8 144.5 118.6 83.55 179.5c-68.73 68.73-68.73 180.2 0 248.9c68.73 68.73 180.2 68.73 248.9 0c60.99-60.99 67.73-155.6 20.47-224.1l18.96-18.96l33.94 33.94c6.248 6.248 16.38 6.25 22.63 0l22.63-22.63c6.248-6.248 6.248-16.38 0-22.63l-33.94-33.94l24.34-24.33l29.56 29.56C486.1 160.5 512 149.8 512 128.4v-112.4C512 7.162 504.8 .0002 496 .0002zM275.9 371.9c-37.43 37.43-98.33 37.43-135.8 0c-37.43-37.43-37.43-98.33 0-135.8c37.43-37.43 98.33-37.43 135.8 0C313.3 273.5 313.3 334.5 275.9 371.9z\"\n ]\n};\nvar faMarsStrokeRight = {\n prefix: 'fas',\n iconName: 'mars-stroke-right',\n icon: [\n 640,\n 512,\n [\n 9897,\n \"mars-stroke-h\"\n ],\n \"f22b\",\n \"M619.3 244.7l-82.34-77.61c-15.12-15.12-40.97-4.41-40.97 16.97V223.1L463.1 224V176c.002-8.838-7.162-16-15.1-16h-32c-8.84 0-16 7.16-16 16V224h-19.05c-15.07-81.9-86.7-144-172.1-144C110.8 80 32 158.8 32 256c0 97.2 78.8 176 176 176c86.26 0 157.9-62.1 172.1-144h19.05V336c0 8.836 7.162 16 16 16h32c8.836 0 15.1-7.164 15.1-16V287.1L496 288v39.95c0 21.38 25.85 32.09 40.97 16.97l82.34-77.61C625.6 261.1 625.6 250.9 619.3 244.7zM208 352c-52.94 0-96-43.07-96-96c-.002-52.94 43.06-96 96-96c52.93 0 95.1 43.06 95.1 96C304 308.9 260.9 352 208 352z\"\n ]\n};\nvar faMarsStrokeH = faMarsStrokeRight;\nvar faMarsStrokeUp = {\n prefix: 'fas',\n iconName: 'mars-stroke-up',\n icon: [\n 384,\n 512,\n [\n 9896,\n \"mars-stroke-v\"\n ],\n \"f22a\",\n \"M224 163V144h24c4.418 0 8-3.578 8-7.1V120c0-4.418-3.582-7.1-8-7.1H224V96h24.63c16.41 0 24.62-19.84 13.02-31.44l-60.97-60.97c-4.795-4.793-12.57-4.793-17.36 0L122.3 64.56c-11.6 11.6-3.383 31.44 13.02 31.44H160v15.1H136c-4.418 0-8 3.582-8 7.1v15.1c0 4.422 3.582 7.1 8 7.1H160v19.05c-84.9 15.62-148.5 92.01-143.7 182.5c4.783 90.69 82.34 165.1 173.2 166.5C287.8 513.4 368 434.1 368 336C368 249.7 305.9 178.1 224 163zM192 431.1c-52.94 0-96-43.06-96-95.1s43.06-95.1 96-95.1c52.93 0 96 43.06 96 95.1S244.9 431.1 192 431.1z\"\n ]\n};\nvar faMarsStrokeV = faMarsStrokeUp;\nvar faMartiniGlass = {\n prefix: 'fas',\n iconName: 'martini-glass',\n icon: [\n 512,\n 512,\n [\n 127864,\n \"glass-martini-alt\"\n ],\n \"f57b\",\n \"M502 57.63C523.3 36.38 508.3 0 478.3 0H33.72C3.711 0-11.29 36.38 9.962 57.63l214 214V448H175.1c-26.51 0-47.1 21.49-47.1 48c0 8.836 7.164 16 16 16h224c8.836 0 16-7.164 16-16c0-26.51-21.49-48-48-48h-47.1V271.6L502 57.63zM405.1 64l-64.01 64H170.9L106.9 64H405.1z\"\n ]\n};\nvar faGlassMartiniAlt = faMartiniGlass;\nvar faMartiniGlassCitrus = {\n prefix: 'fas',\n iconName: 'martini-glass-citrus',\n icon: [\n 576,\n 512,\n [\n \"cocktail\"\n ],\n \"f561\",\n \"M288 464H240v-125.3l168.8-168.7C424.3 154.5 413.3 128 391.4 128H24.63C2.751 128-8.249 154.5 7.251 170l168.7 168.7V464H128c-17.67 0-32 14.33-32 32c0 8.836 7.164 16 15.1 16h191.1c8.836 0 15.1-7.164 15.1-16C320 478.3 305.7 464 288 464zM432 0c-62.63 0-115.4 40.25-135.1 96h52.5c16.62-28.5 47.25-48 82.62-48c52.88 0 95.1 43 95.1 96s-43.12 96-95.1 96c-14 0-27.25-3.25-39.37-8.625l-35.25 35.25c21.88 13.25 47.25 21.38 74.62 21.38c79.5 0 143.1-64.5 143.1-144S511.5 0 432 0z\"\n ]\n};\nvar faCocktail = faMartiniGlassCitrus;\nvar faMartiniGlassEmpty = {\n prefix: 'fas',\n iconName: 'martini-glass-empty',\n icon: [\n 512,\n 512,\n [\n \"glass-martini\"\n ],\n \"f000\",\n \"M502 57.63C523.3 36.38 508.3 0 478.3 0H33.72C3.711 0-11.29 36.38 9.962 57.63l214 214V448H176c-26.51 0-48 21.49-48 48c0 8.836 7.164 16 16 16h224c8.836 0 16-7.164 16-16c0-26.51-21.49-48-47.1-48h-47.1V271.6L502 57.63zM256 213.1L106.9 64h298.3L256 213.1z\"\n ]\n};\nvar faGlassMartini = faMartiniGlassEmpty;\nvar faMask = {\n prefix: 'fas',\n iconName: 'mask',\n icon: [\n 576,\n 512,\n [],\n \"f6fa\",\n \"M288 64C39.52 64 0 182.1 0 273.5C0 379.5 78.8 448 176 448c27.33 0 51.21-6.516 66.11-36.79l19.93-40.5C268.3 358.6 278.1 352.4 288 352.1c9.9 .3711 19.7 6.501 25.97 18.63l19.93 40.5C348.8 441.5 372.7 448 400 448c97.2 0 176-68.51 176-174.5C576 182.1 536.5 64 288 64zM160 320c-35.35 0-64-28.65-64-64s28.65-64 64-64c35.35 0 64 28.65 64 64S195.3 320 160 320zM416 320c-35.35 0-64-28.65-64-64s28.65-64 64-64c35.35 0 64 28.65 64 64S451.3 320 416 320z\"\n ]\n};\nvar faMaskFace = {\n prefix: 'fas',\n iconName: 'mask-face',\n icon: [\n 640,\n 512,\n [],\n \"e1d7\",\n \"M396.4 87.12L433.5 111.9C449.3 122.4 467.8 128 486.8 128H584C614.9 128 640 153.1 640 184V269C640 324.1 602.5 372.1 549.1 385.5L441.1 412.5C406.2 434.1 364.6 448 320 448C275.4 448 233.8 434.1 198.9 412.5L90.9 385.5C37.48 372.1 0 324.1 0 269V184C0 153.1 25.07 128 56 128H153.2C172.2 128 190.7 122.4 206.5 111.9L243.6 87.12C266.2 72.05 292.8 64 320 64C347.2 64 373.8 72.05 396.4 87.12zM132.3 346.3C109.4 311.2 96 269.1 96 224V176H56C51.58 176 48 179.6 48 184V269C48 302.1 70.49 330.9 102.5 338.9L132.3 346.3zM592 269V184C592 179.6 588.4 176 584 176H544V224C544 269.1 530.6 311.2 507.7 346.3L537.5 338.9C569.5 330.9 592 302.1 592 269H592zM208 224H432C440.8 224 448 216.8 448 208C448 199.2 440.8 192 432 192H208C199.2 192 192 199.2 192 208C192 216.8 199.2 224 208 224zM208 256C199.2 256 192 263.2 192 272C192 280.8 199.2 288 208 288H432C440.8 288 448 280.8 448 272C448 263.2 440.8 256 432 256H208zM240 352H400C408.8 352 416 344.8 416 336C416 327.2 408.8 320 400 320H240C231.2 320 224 327.2 224 336C224 344.8 231.2 352 240 352z\"\n ]\n};\nvar faMasksTheater = {\n prefix: 'fas',\n iconName: 'masks-theater',\n icon: [\n 640,\n 512,\n [\n 127917,\n \"theater-masks\"\n ],\n \"f630\",\n \"M206.9 245.1C171 255.6 146.8 286.4 149.3 319.3C160.7 306.5 178.1 295.5 199.3 288.4L206.9 245.1zM95.78 294.9L64.11 115.5C63.74 113.9 64.37 112.9 64.37 112.9c57.75-32.13 123.1-48.99 189-48.99c1.625 0 3.113 .0745 4.738 .0745c13.1-13.5 31.75-22.75 51.62-26c18.87-3 38.12-4.5 57.25-5.25c-9.999-14-24.47-24.27-41.84-27.02c-23.87-3.875-47.9-5.732-71.77-5.732c-76.74 0-152.4 19.45-220.1 57.07C9.021 70.57-3.853 98.5 1.021 126.6L32.77 306c14.25 80.5 136.3 142 204.5 142c3.625 0 6.777-.2979 10.03-.6729c-13.5-17.13-28.1-40.5-39.5-67.63C160.1 366.8 101.7 328 95.78 294.9zM193.4 157.6C192.6 153.4 191.1 149.7 189.3 146.2c-8.249 8.875-20.62 15.75-35.25 18.37c-14.62 2.5-28.75 .376-39.5-5.249c-.5 4-.6249 7.998 .125 12.12c3.75 21.75 24.5 36.24 46.25 32.37C182.6 200.1 197.3 179.3 193.4 157.6zM606.8 121c-88.87-49.38-191.4-67.38-291.9-51.38C287.5 73.1 265.8 95.85 260.8 123.1L229 303.5c-15.37 87.13 95.33 196.3 158.3 207.3c62.1 11.13 204.5-53.68 219.9-140.8l31.75-179.5C643.9 162.3 631 134.4 606.8 121zM333.5 217.8c3.875-21.75 24.62-36.25 46.37-32.37c21.75 3.75 36.25 24.49 32.5 46.12c-.7499 4.125-2.25 7.873-4.125 11.5c-8.249-9-20.62-15.75-35.25-18.37c-14.75-2.625-28.75-.3759-39.5 5.124C332.1 225.9 332.9 221.9 333.5 217.8zM403.1 416.5c-55.62-9.875-93.49-59.23-88.99-112.1c20.62 25.63 56.25 46.24 99.49 53.87c43.25 7.625 83.74 .3781 111.9-16.62C512.2 392.7 459.7 426.3 403.1 416.5zM534.4 265.2c-8.249-8.875-20.75-15.75-35.37-18.37c-14.62-2.5-28.62-.3759-39.5 5.249c-.5-4-.625-7.998 .125-12.12c3.875-21.75 24.62-36.25 46.37-32.37c21.75 3.875 36.25 24.49 32.37 46.24C537.6 257.9 536.1 261.7 534.4 265.2z\"\n ]\n};\nvar faTheaterMasks = faMasksTheater;\nvar faMaximize = {\n prefix: 'fas',\n iconName: 'maximize',\n icon: [\n 448,\n 512,\n [\n \"expand-arrows-alt\"\n ],\n \"f31e\",\n \"M447.1 319.1v135.1c0 13.26-10.75 23.1-23.1 23.1h-135.1c-12.94 0-24.61-7.781-29.56-19.75c-4.906-11.1-2.203-25.72 6.937-34.87l30.06-30.06L224 323.9l-71.43 71.44l30.06 30.06c9.156 9.156 11.91 22.91 6.937 34.87C184.6 472.2 172.9 479.1 160 479.1H24c-13.25 0-23.1-10.74-23.1-23.1v-135.1c0-12.94 7.781-24.61 19.75-29.56C23.72 288.8 27.88 288 32 288c8.312 0 16.5 3.242 22.63 9.367l30.06 30.06l71.44-71.44L84.69 184.6L54.63 214.6c-9.156 9.156-22.91 11.91-34.87 6.937C7.798 216.6 .0013 204.9 .0013 191.1v-135.1c0-13.26 10.75-23.1 23.1-23.1h135.1c12.94 0 24.61 7.781 29.56 19.75C191.2 55.72 191.1 59.87 191.1 63.1c0 8.312-3.237 16.5-9.362 22.63L152.6 116.7l71.44 71.44l71.43-71.44l-30.06-30.06c-9.156-9.156-11.91-22.91-6.937-34.87c4.937-11.95 16.62-19.75 29.56-19.75h135.1c13.26 0 23.1 10.75 23.1 23.1v135.1c0 12.94-7.781 24.61-19.75 29.56c-11.1 4.906-25.72 2.203-34.87-6.937l-30.06-30.06l-71.43 71.43l71.44 71.44l30.06-30.06c9.156-9.156 22.91-11.91 34.87-6.937C440.2 295.4 447.1 307.1 447.1 319.1z\"\n ]\n};\nvar faExpandArrowsAlt = faMaximize;\nvar faMedal = {\n prefix: 'fas',\n iconName: 'medal',\n icon: [\n 512,\n 512,\n [\n 127941\n ],\n \"f5a2\",\n \"M223.7 130.8L149.1 7.77C147.1 2.949 141.9 0 136.3 0H16.03c-12.95 0-20.53 14.58-13.1 25.18l111.3 158.9C143.9 156.4 181.7 137.3 223.7 130.8zM256 160c-97.25 0-176 78.75-176 176S158.8 512 256 512s176-78.75 176-176S353.3 160 256 160zM348.5 317.3l-37.88 37l8.875 52.25c1.625 9.25-8.25 16.5-16.63 12l-46.88-24.62L209.1 418.5c-8.375 4.5-18.25-2.75-16.63-12l8.875-52.25l-37.88-37C156.6 310.6 160.5 299 169.9 297.6l52.38-7.625L245.7 242.5c2-4.25 6.125-6.375 10.25-6.375S264.2 238.3 266.2 242.5l23.5 47.5l52.38 7.625C351.6 299 355.4 310.6 348.5 317.3zM495.1 0H375.7c-5.621 0-10.83 2.949-13.72 7.77l-73.76 122.1c42 6.5 79.88 25.62 109.5 53.38l111.3-158.9C516.5 14.58 508.9 0 495.1 0z\"\n ]\n};\nvar faMemory = {\n prefix: 'fas',\n iconName: 'memory',\n icon: [\n 576,\n 512,\n [],\n \"f538\",\n \"M0 448h80v-32c0-8.838 7.164-16 16-16c8.838 0 16 7.162 16 16v32h96v-32c0-8.838 7.164-16 16-16c8.838 0 16 7.162 16 16v32h96v-32c0-8.838 7.164-16 16-16c8.838 0 16 7.162 16 16v32h96v-32c0-8.838 7.164-16 16-16c8.838 0 16 7.162 16 16v32H576v-96H0V448zM576 146.9V112C576 85.49 554.5 64 528 64h-480C21.49 64 0 85.49 0 112v34.94C18.6 153.5 32 171.1 32 192S18.6 230.5 0 237.1V320h576V237.1C557.4 230.5 544 212.9 544 192S557.4 153.5 576 146.9zM192 240C192 248.8 184.8 256 176 256h-32C135.2 256 128 248.8 128 240v-96C128 135.2 135.2 128 144 128h32C184.8 128 192 135.2 192 144V240zM320 240C320 248.8 312.8 256 304 256h-32C263.2 256 256 248.8 256 240v-96C256 135.2 263.2 128 272 128h32C312.8 128 320 135.2 320 144V240zM448 240C448 248.8 440.8 256 432 256h-32C391.2 256 384 248.8 384 240v-96C384 135.2 391.2 128 400 128h32C440.8 128 448 135.2 448 144V240z\"\n ]\n};\nvar faMenorah = {\n prefix: 'fas',\n iconName: 'menorah',\n icon: [\n 640,\n 512,\n [],\n \"f676\",\n \"M544 144C544 135.1 536.9 128 528 128h-32C487.1 128 480 135.1 480 144V288h64V144zM416 95.1c17.62 0 32-14.38 32-32s-32-63.1-32-63.1s-32 46.37-32 63.1S398.4 95.1 416 95.1zM448 144C448 135.1 440.9 128 432 128h-32C391.1 128 384 135.1 384 144V288h64V144zM608 95.1c17.62 0 32-14.38 32-32s-32-63.1-32-63.1s-32 46.37-32 63.1S590.4 95.1 608 95.1zM320 95.1c17.62 0 32-14.38 32-32s-32-63.1-32-63.1S288 46.37 288 63.1S302.4 95.1 320 95.1zM512 95.1c17.62 0 32-14.38 32-32s-32-63.1-32-63.1s-32 46.37-32 63.1S494.4 95.1 512 95.1zM624 128h-32C583.2 128 576 135.2 576 144V288c0 17.6-14.4 32-32 32h-192V144C352 135.2 344.8 128 336 128h-32C295.2 128 288 135.2 288 144V320H96c-17.6 0-32-14.4-32-32V144C64 135.2 56.84 128 48 128h-32C7.164 128 0 135.2 0 144V288c0 53.02 42.98 96 96 96h192v64H176C149.5 448 128 469.5 128 496C128 504.8 135.2 512 144 512h352c8.836 0 16-7.164 16-16c0-26.51-21.49-48-48-48H352v-64h192c53.02 0 96-42.98 96-96V144C640 135.2 632.8 128 624 128zM160 144C160 135.1 152.9 128 144 128h-32C103.1 128 96 135.1 96 144V288h64V144zM224 95.1c17.62 0 32-14.38 32-32S224 0 224 0S192 46.37 192 63.1S206.4 95.1 224 95.1zM32 95.1c17.62 0 32-14.38 32-32S32 0 32 0S0 46.37 0 63.1S14.38 95.1 32 95.1zM128 95.1c17.62 0 32-14.38 32-32S128 0 128 0S96 46.37 96 63.1S110.4 95.1 128 95.1zM256 144C256 135.1 248.9 128 240 128h-32C199.1 128 192 135.1 192 144V288h64V144z\"\n ]\n};\nvar faMercury = {\n prefix: 'fas',\n iconName: 'mercury',\n icon: [\n 384,\n 512,\n [\n 9791\n ],\n \"f223\",\n \"M368 223.1c0-55.32-25.57-104.6-65.49-136.9c20.49-17.32 37.2-39.11 48.1-64.21c4.656-10.72-2.9-22.89-14.45-22.89h-54.31c-5.256 0-9.93 2.828-12.96 7.188C251.8 31.77 223.8 47.1 192 47.1c-31.85 0-59.78-16.23-76.88-40.81C112.1 2.828 107.4 0 102.2 0H47.84c-11.55 0-19.11 12.17-14.45 22.89C44.29 47.1 60.1 69.79 81.49 87.11C41.57 119.4 16 168.7 16 223.1c0 86.26 62.1 157.9 144 172.1V416H128c-8.836 0-16 7.164-16 16v32C112 472.8 119.2 480 128 480h32v16C160 504.8 167.2 512 176 512h32c8.838 0 16-7.164 16-16V480h32c8.838 0 16-7.164 16-16v-32c0-8.836-7.162-16-16-16h-32v-19.05C305.9 381.9 368 310.3 368 223.1zM192 320c-52.93 0-96-43.07-96-96c0-52.94 43.07-95.1 96-95.1c52.94 0 96 43.06 96 95.1C288 276.9 244.9 320 192 320z\"\n ]\n};\nvar faMessage = {\n prefix: 'fas',\n iconName: 'message',\n icon: [\n 512,\n 512,\n [\n \"comment-alt\"\n ],\n \"f27a\",\n \"M511.1 63.1v287.1c0 35.25-28.75 63.1-64 63.1h-144l-124.9 93.68c-7.875 5.75-19.12 .0497-19.12-9.7v-83.98h-96c-35.25 0-64-28.75-64-63.1V63.1c0-35.25 28.75-63.1 64-63.1h384C483.2 0 511.1 28.75 511.1 63.1z\"\n ]\n};\nvar faCommentAlt = faMessage;\nvar faMeteor = {\n prefix: 'fas',\n iconName: 'meteor',\n icon: [\n 512,\n 512,\n [\n 9732\n ],\n \"f753\",\n \"M511.4 20.72c-11.63 38.75-34.38 111.8-61.38 187.8c7 2.125 13.38 4 18.63 5.625c4.625 1.375 8.375 4.751 10.13 9.127c1.875 4.5 1.625 9.501-.625 13.75c-22.13 42.25-82.63 152.8-142.5 214.4c-1 1.125-2.001 2.5-3.001 3.5c-76 76.13-199.4 76.13-275.5 .125c-76.13-76.13-76.13-199.5 0-275.7c1-1 2.375-2 3.5-3C122.1 116.5 232.5 55.97 274.1 33.84c4.25-2.25 9.25-2.5 13.63-.625c4.5 1.875 7.875 5.626 9.25 10.13c1.625 5.125 3.5 11.63 5.625 18.63c75.88-27 148.9-49.75 187.6-61.25c5.75-1.75 11.88-.2503 16.13 4C511.5 8.844 512.1 15.09 511.4 20.72zM319.1 319.1c0-70.63-57.38-128-128-128c-70.75 0-128 57.38-128 128c0 70.76 57.25 128 128 128C262.6 448 319.1 390.8 319.1 319.1zM191.1 287.1c0 17.63-14.37 32-32 32c-17.75 0-32-14.38-32-32s14.25-32 32-32c8.5 0 16.63 3.375 22.63 9.375S191.1 279.5 191.1 287.1zM223.9 367.1c0 8.876-7.224 16-15.97 16c-8.875 0-16-7.127-16-16c0-8.876 7.1-16 15.98-16C216.7 351.1 223.9 359.1 223.9 367.1z\"\n ]\n};\nvar faMicrochip = {\n prefix: 'fas',\n iconName: 'microchip',\n icon: [\n 512,\n 512,\n [],\n \"f2db\",\n \"M160 352h192V160H160V352zM448 176h48C504.8 176 512 168.8 512 160s-7.162-16-16-16H448V128c0-35.35-28.65-64-64-64h-16V16C368 7.164 360.8 0 352 0c-8.836 0-16 7.164-16 16V64h-64V16C272 7.164 264.8 0 256 0C247.2 0 240 7.164 240 16V64h-64V16C176 7.164 168.8 0 160 0C151.2 0 144 7.164 144 16V64H128C92.65 64 64 92.65 64 128v16H16C7.164 144 0 151.2 0 160s7.164 16 16 16H64v64H16C7.164 240 0 247.2 0 256s7.164 16 16 16H64v64H16C7.164 336 0 343.2 0 352s7.164 16 16 16H64V384c0 35.35 28.65 64 64 64h16v48C144 504.8 151.2 512 160 512c8.838 0 16-7.164 16-16V448h64v48c0 8.836 7.164 16 16 16c8.838 0 16-7.164 16-16V448h64v48c0 8.836 7.164 16 16 16c8.838 0 16-7.164 16-16V448H384c35.35 0 64-28.65 64-64v-16h48c8.838 0 16-7.164 16-16s-7.162-16-16-16H448v-64h48C504.8 272 512 264.8 512 256s-7.162-16-16-16H448V176zM384 368c0 8.836-7.162 16-16 16h-224C135.2 384 128 376.8 128 368v-224C128 135.2 135.2 128 144 128h224C376.8 128 384 135.2 384 144V368z\"\n ]\n};\nvar faMicrophone = {\n prefix: 'fas',\n iconName: 'microphone',\n icon: [\n 384,\n 512,\n [],\n \"f130\",\n \"M192 352c53.03 0 96-42.97 96-96v-160c0-53.03-42.97-96-96-96s-96 42.97-96 96v160C96 309 138.1 352 192 352zM344 192C330.7 192 320 202.7 320 215.1V256c0 73.33-61.97 132.4-136.3 127.7c-66.08-4.169-119.7-66.59-119.7-132.8L64 215.1C64 202.7 53.25 192 40 192S16 202.7 16 215.1v32.15c0 89.66 63.97 169.6 152 181.7V464H128c-18.19 0-32.84 15.18-31.96 33.57C96.43 505.8 103.8 512 112 512h160c8.222 0 15.57-6.216 15.96-14.43C288.8 479.2 274.2 464 256 464h-40v-33.77C301.7 418.5 368 344.9 368 256V215.1C368 202.7 357.3 192 344 192z\"\n ]\n};\nvar faMicrophoneLines = {\n prefix: 'fas',\n iconName: 'microphone-lines',\n icon: [\n 384,\n 512,\n [\n 127897,\n \"microphone-alt\"\n ],\n \"f3c9\",\n \"M192 352c53.03 0 96-42.97 96-96h-80C199.2 256 192 248.8 192 240S199.2 224 208 224H288V192h-80C199.2 192 192 184.8 192 176S199.2 160 208 160H288V127.1h-80c-8.836 0-16-7.164-16-16s7.164-16 16-16L288 96c0-53.03-42.97-96-96-96s-96 42.97-96 96v160C96 309 138.1 352 192 352zM344 192C330.7 192 320 202.7 320 215.1V256c0 73.33-61.97 132.4-136.3 127.7c-66.08-4.169-119.7-66.59-119.7-132.8L64 215.1C64 202.7 53.25 192 40 192S16 202.7 16 215.1v32.15c0 89.66 63.97 169.6 152 181.7V464H128c-18.19 0-32.84 15.18-31.96 33.57C96.43 505.8 103.8 512 112 512h160c8.222 0 15.57-6.216 15.96-14.43C288.8 479.2 274.2 464 256 464h-40v-33.77C301.7 418.5 368 344.9 368 256V215.1C368 202.7 357.3 192 344 192z\"\n ]\n};\nvar faMicrophoneAlt = faMicrophoneLines;\nvar faMicrophoneLinesSlash = {\n prefix: 'fas',\n iconName: 'microphone-lines-slash',\n icon: [\n 640,\n 512,\n [\n \"microphone-alt-slash\"\n ],\n \"f539\",\n \"M383.1 464l-39.1-.0001v-33.77c20.6-2.824 39.99-9.402 57.69-18.72l-43.26-33.91c-14.66 4.65-30.28 7.179-46.68 6.144C245.7 379.6 191.1 317.1 191.1 250.9v-3.777L143.1 209.5l.0001 38.61c0 89.65 63.97 169.6 151.1 181.7v34.15l-40 .0001c-17.67 0-31.1 14.33-31.1 31.1C223.1 504.8 231.2 512 239.1 512h159.1c8.838 0 15.1-7.164 15.1-15.1C415.1 478.3 401.7 464 383.1 464zM630.8 469.1l-159.3-124.9c15.37-25.94 24.53-55.91 24.53-88.21V216c0-13.25-10.75-24-23.1-24c-13.25 0-24 10.75-24 24l-.0001 39.1c0 21.12-5.557 40.77-14.77 58.24l-25.73-20.16c5.234-11.68 8.493-24.42 8.493-38.08l-57.07 .0006l-34.45-27c2.914-3.055 6.969-4.999 11.52-4.999h79.1V192L335.1 192c-8.836 0-15.1-7.164-15.1-15.1s7.164-16 15.1-16l79.1 .0013V128l-79.1-.0015c-8.836 0-15.1-7.164-15.1-15.1s7.164-15.1 15.1-15.1l80-.0003c0-54-44.56-97.57-98.93-95.95C264.5 1.614 223.1 47.45 223.1 100l.0006 50.23L38.81 5.111C34.41 1.673 29.19 0 24.03 0C16.91 0 9.84 3.158 5.121 9.189C-3.067 19.63-1.249 34.72 9.189 42.89l591.1 463.1c10.5 8.203 25.57 6.328 33.69-4.078C643.1 492.4 641.2 477.3 630.8 469.1z\"\n ]\n};\nvar faMicrophoneAltSlash = faMicrophoneLinesSlash;\nvar faMicrophoneSlash = {\n prefix: 'fas',\n iconName: 'microphone-slash',\n icon: [\n 640,\n 512,\n [],\n \"f131\",\n \"M383.1 464l-39.1-.0001v-33.77c20.6-2.824 39.98-9.402 57.69-18.72l-43.26-33.91c-14.66 4.65-30.28 7.179-46.68 6.144C245.7 379.6 191.1 317.1 191.1 250.9V247.2L143.1 209.5l.0001 38.61c0 89.65 63.97 169.6 151.1 181.7v34.15l-40 .0001c-17.67 0-31.1 14.33-31.1 31.1C223.1 504.8 231.2 512 239.1 512h159.1c8.838 0 15.1-7.164 15.1-15.1C415.1 478.3 401.7 464 383.1 464zM630.8 469.1l-159.3-124.9c15.37-25.94 24.53-55.91 24.53-88.21V216c0-13.25-10.75-24-23.1-24c-13.25 0-24 10.75-24 24l-.0001 39.1c0 21.12-5.559 40.77-14.77 58.24l-25.72-20.16c5.234-11.68 8.493-24.42 8.493-38.08l-.001-155.1c0-52.57-40.52-98.41-93.07-99.97c-54.37-1.617-98.93 41.95-98.93 95.95l0 54.25L38.81 5.111C34.41 1.673 29.19 0 24.03 0C16.91 0 9.839 3.158 5.12 9.189c-8.187 10.44-6.37 25.53 4.068 33.7l591.1 463.1c10.5 8.203 25.57 6.328 33.69-4.078C643.1 492.4 641.2 477.3 630.8 469.1z\"\n ]\n};\nvar faMicroscope = {\n prefix: 'fas',\n iconName: 'microscope',\n icon: [\n 512,\n 512,\n [\n 128300\n ],\n \"f610\",\n \"M160 320h12v16c0 8.875 7.125 16 16 16h40c8.875 0 16-7.125 16-16V320H256c17.62 0 32-14.38 32-32V64c0-17.62-14.38-32-32-32V16C256 7.125 248.9 0 240 0h-64C167.1 0 160 7.125 160 16V32C142.4 32 128 46.38 128 64v224C128 305.6 142.4 320 160 320zM464 448h-1.25C493.2 414 512 369.2 512 320c0-105.9-86.13-192-192-192v64c70.63 0 128 57.38 128 128s-57.38 128-128 128H48C21.5 448 0 469.5 0 496C0 504.9 7.125 512 16 512h480c8.875 0 16-7.125 16-16C512 469.5 490.5 448 464 448zM104 416h208c4.375 0 8-3.625 8-8v-16c0-4.375-3.625-8-8-8h-208C99.63 384 96 387.6 96 392v16C96 412.4 99.63 416 104 416z\"\n ]\n};\nvar faMillSign = {\n prefix: 'fas',\n iconName: 'mill-sign',\n icon: [\n 384,\n 512,\n [],\n \"e1ed\",\n \"M282.9 96.53C339.7 102 384 149.8 384 208V416C384 433.7 369.7 448 352 448C334.3 448 320 433.7 320 416V208C320 181.5 298.5 160 272 160C267.7 160 263.6 160.6 259.7 161.6L224 261.5V416C224 433.7 209.7 448 192 448C179.6 448 168.9 440.1 163.6 430.7L142.1 490.8C136.2 507.4 117.9 516.1 101.2 510.1C84.59 504.2 75.92 485.9 81.86 469.2L160 250.5V208C160 181.5 138.5 160 112 160C85.49 160 64 181.5 64 208V416C64 433.7 49.67 448 32 448C14.33 448 0 433.7 0 416V128C0 110.3 14.33 96 32 96C42.87 96 52.48 101.4 58.26 109.7C74.21 100.1 92.53 96 112 96C143.3 96 171.7 108.9 192 129.6C196.9 124.6 202.2 120.1 207.1 116.1L241.9 21.24C247.8 4.595 266.1-4.079 282.8 1.865C299.4 7.809 308.1 26.12 302.1 42.76L282.9 96.53z\"\n ]\n};\nvar faMinimize = {\n prefix: 'fas',\n iconName: 'minimize',\n icon: [\n 512,\n 512,\n [\n \"compress-arrows-alt\"\n ],\n \"f78c\",\n \"M200 287.1H64c-12.94 0-24.62 7.797-29.56 19.75c-4.969 11.97-2.219 25.72 6.937 34.87l30.06 30.06l-62.06 62.07c-12.49 12.5-12.5 32.75-.0012 45.25l22.62 22.62c12.5 12.5 32.76 12.5 45.26 .0012l62.06-62.07l30.06 30.06c6.125 6.125 14.31 9.375 22.62 9.375c4.125 0 8.281-.7969 12.25-2.437c11.97-4.953 19.75-16.62 19.75-29.56V311.1C224 298.7 213.3 287.1 200 287.1zM312 224h135.1c12.94 0 24.62-7.797 29.56-19.75c4.969-11.97 2.219-25.72-6.937-34.87l-30.06-30.06l62.06-62.07c12.5-12.5 12.5-32.76 .0003-45.26l-22.62-22.62c-12.5-12.5-32.76-12.5-45.26-.0003l-62.06 62.07l-30.06-30.06c-9.156-9.141-22.87-11.84-34.87-6.937C295.8 39.39 288 51.06 288 64v135.1C288 213.3 298.7 224 312 224zM204.3 34.44C192.3 29.47 178.5 32.22 169.4 41.38L139.3 71.44L77.25 9.374C64.75-3.123 44.49-3.123 31.1 9.374l-22.63 22.63c-12.49 12.49-12.49 32.75 .0018 45.25l62.07 62.06L41.38 169.4C35.25 175.5 32 183.7 32 192c0 4.125 .7969 8.281 2.438 12.25C39.39 216.2 51.07 224 64 224h135.1c13.25 0 23.1-10.75 23.1-23.1V64C224 51.06 216.2 39.38 204.3 34.44zM440.6 372.7l30.06-30.06c9.141-9.156 11.84-22.88 6.938-34.87C472.6 295.8 460.9 287.1 448 287.1h-135.1c-13.25 0-23.1 10.75-23.1 23.1v135.1c0 12.94 7.797 24.62 19.75 29.56c11.97 4.969 25.72 2.219 34.87-6.937l30.06-30.06l62.06 62.06c12.5 12.5 32.76 12.5 45.26 .0002l22.62-22.62c12.5-12.5 12.5-32.76 .0002-45.26L440.6 372.7z\"\n ]\n};\nvar faCompressArrowsAlt = faMinimize;\nvar faMinus = {\n prefix: 'fas',\n iconName: 'minus',\n icon: [\n 448,\n 512,\n [\n 8722,\n 10134,\n 8211,\n \"subtract\"\n ],\n \"f068\",\n \"M400 288h-352c-17.69 0-32-14.32-32-32.01s14.31-31.99 32-31.99h352c17.69 0 32 14.3 32 31.99S417.7 288 400 288z\"\n ]\n};\nvar faSubtract = faMinus;\nvar faMitten = {\n prefix: 'fas',\n iconName: 'mitten',\n icon: [\n 448,\n 512,\n [],\n \"f7b5\",\n \"M351.1 416H63.99c-17.6 0-31.1 14.4-31.1 31.1l.0026 31.1C31.1 497.6 46.4 512 63.1 512h288c17.6 0 32-14.4 32-31.1l-.0049-31.1C383.1 430.4 369.6 416 351.1 416zM425 206.9c-27.25-22.62-67.5-19-90.13 8.25l-20.88 25L284.4 111.8c-18-77.5-95.38-125.1-172.8-108C34.26 21.63-14.25 98.88 3.754 176.4L64 384h288l81.14-86.1C455.8 269.8 452.1 229.5 425 206.9z\"\n ]\n};\nvar faMobile = {\n prefix: 'fas',\n iconName: 'mobile',\n icon: [\n 384,\n 512,\n [\n 128241,\n \"mobile-android\",\n \"mobile-phone\"\n ],\n \"f3ce\",\n \"M320 0H64C37.5 0 16 21.5 16 48v416C16 490.5 37.5 512 64 512h256c26.5 0 48-21.5 48-48v-416C368 21.5 346.5 0 320 0zM240 447.1C240 456.8 232.8 464 224 464H159.1C151.2 464 144 456.8 144 448S151.2 432 160 432h64C232.8 432 240 439.2 240 447.1z\"\n ]\n};\nvar faMobileAndroid = faMobile;\nvar faMobilePhone = faMobile;\nvar faMobileButton = {\n prefix: 'fas',\n iconName: 'mobile-button',\n icon: [\n 384,\n 512,\n [],\n \"f10b\",\n \"M320 0H64C37.49 0 16 21.49 16 48v416C16 490.5 37.49 512 64 512h256c26.51 0 48-21.49 48-48v-416C368 21.49 346.5 0 320 0zM192 464c-17.75 0-32-14.25-32-32s14.25-32 32-32s32 14.25 32 32S209.8 464 192 464z\"\n ]\n};\nvar faMobileScreenButton = {\n prefix: 'fas',\n iconName: 'mobile-screen-button',\n icon: [\n 384,\n 512,\n [\n \"mobile-alt\"\n ],\n \"f3cd\",\n \"M304 0h-224c-35.35 0-64 28.65-64 64v384c0 35.35 28.65 64 64 64h224c35.35 0 64-28.65 64-64V64C368 28.65 339.3 0 304 0zM192 480c-17.75 0-32-14.25-32-32s14.25-32 32-32s32 14.25 32 32S209.8 480 192 480zM304 64v320h-224V64H304z\"\n ]\n};\nvar faMobileAlt = faMobileScreenButton;\nvar faMoneyBill = {\n prefix: 'fas',\n iconName: 'money-bill',\n icon: [\n 576,\n 512,\n [],\n \"f0d6\",\n \"M512 64C547.3 64 576 92.65 576 128V384C576 419.3 547.3 448 512 448H64C28.65 448 0 419.3 0 384V128C0 92.65 28.65 64 64 64H512zM128 384C128 348.7 99.35 320 64 320V384H128zM64 192C99.35 192 128 163.3 128 128H64V192zM512 384V320C476.7 320 448 348.7 448 384H512zM512 128H448C448 163.3 476.7 192 512 192V128zM288 352C341 352 384 309 384 256C384 202.1 341 160 288 160C234.1 160 192 202.1 192 256C192 309 234.1 352 288 352z\"\n ]\n};\nvar faMoneyBill1 = {\n prefix: 'fas',\n iconName: 'money-bill-1',\n icon: [\n 576,\n 512,\n [\n \"money-bill-alt\"\n ],\n \"f3d1\",\n \"M252 208C252 196.1 260.1 188 272 188H288C299 188 308 196.1 308 208V276H312C323 276 332 284.1 332 296C332 307 323 316 312 316H264C252.1 316 244 307 244 296C244 284.1 252.1 276 264 276H268V227.6C258.9 225.7 252 217.7 252 208zM512 64C547.3 64 576 92.65 576 128V384C576 419.3 547.3 448 512 448H64C28.65 448 0 419.3 0 384V128C0 92.65 28.65 64 64 64H512zM128 384C128 348.7 99.35 320 64 320V384H128zM64 192C99.35 192 128 163.3 128 128H64V192zM512 384V320C476.7 320 448 348.7 448 384H512zM512 128H448C448 163.3 476.7 192 512 192V128zM288 144C226.1 144 176 194.1 176 256C176 317.9 226.1 368 288 368C349.9 368 400 317.9 400 256C400 194.1 349.9 144 288 144z\"\n ]\n};\nvar faMoneyBillAlt = faMoneyBill1;\nvar faMoneyBill1Wave = {\n prefix: 'fas',\n iconName: 'money-bill-1-wave',\n icon: [\n 576,\n 512,\n [\n \"money-bill-wave-alt\"\n ],\n \"f53b\",\n \"M251.1 207.1C251.1 196.1 260.1 187.1 271.1 187.1H287.1C299 187.1 308 196.1 308 207.1V275.1H312C323 275.1 332 284.1 332 295.1C332 307 323 315.1 312 315.1H263.1C252.1 315.1 243.1 307 243.1 295.1C243.1 284.1 252.1 275.1 263.1 275.1H267.1V227.6C258.9 225.7 251.1 217.7 251.1 207.1zM48.66 79.13C128.4 100.9 208.2 80.59 288 60.25C375 38.08 462 15.9 549 48.38C565.9 54.69 576 71.62 576 89.66V399.5C576 423.4 550.4 439.2 527.3 432.9C447.6 411.1 367.8 431.4 288 451.7C200.1 473.9 113.1 496.1 26.97 463.6C10.06 457.3 0 440.4 0 422.3V112.5C0 88.59 25.61 72.83 48.66 79.13L48.66 79.13zM127.1 416C127.1 380.7 99.35 352 63.1 352V416H127.1zM63.1 223.1C99.35 223.1 127.1 195.3 127.1 159.1H63.1V223.1zM512 352V287.1C476.7 287.1 448 316.7 448 352H512zM512 95.1H448C448 131.3 476.7 159.1 512 159.1V95.1zM287.1 143.1C234.1 143.1 191.1 194.1 191.1 255.1C191.1 317.9 234.1 368 287.1 368C341 368 384 317.9 384 255.1C384 194.1 341 143.1 287.1 143.1z\"\n ]\n};\nvar faMoneyBillWaveAlt = faMoneyBill1Wave;\nvar faMoneyBillWave = {\n prefix: 'fas',\n iconName: 'money-bill-wave',\n icon: [\n 576,\n 512,\n [],\n \"f53a\",\n \"M48.66 79.13C128.4 100.9 208.2 80.59 288 60.25C375 38.08 462 15.9 549 48.38C565.9 54.69 576 71.62 576 89.66V399.5C576 423.4 550.4 439.2 527.3 432.9C447.6 411.1 367.8 431.4 288 451.7C200.1 473.9 113.1 496.1 26.97 463.6C10.06 457.3 0 440.4 0 422.3V112.5C0 88.59 25.61 72.83 48.66 79.13L48.66 79.13zM287.1 352C332.2 352 368 309 368 255.1C368 202.1 332.2 159.1 287.1 159.1C243.8 159.1 207.1 202.1 207.1 255.1C207.1 309 243.8 352 287.1 352zM63.1 416H127.1C127.1 380.7 99.35 352 63.1 352V416zM63.1 143.1V207.1C99.35 207.1 127.1 179.3 127.1 143.1H63.1zM512 303.1C476.7 303.1 448 332.7 448 368H512V303.1zM448 95.1C448 131.3 476.7 159.1 512 159.1V95.1H448z\"\n ]\n};\nvar faMoneyCheck = {\n prefix: 'fas',\n iconName: 'money-check',\n icon: [\n 576,\n 512,\n [],\n \"f53c\",\n \"M512 64C547.3 64 576 92.65 576 128V384C576 419.3 547.3 448 512 448H64C28.65 448 0 419.3 0 384V128C0 92.65 28.65 64 64 64H512zM112 224C103.2 224 96 231.2 96 240C96 248.8 103.2 256 112 256H272C280.8 256 288 248.8 288 240C288 231.2 280.8 224 272 224H112zM112 352H464C472.8 352 480 344.8 480 336C480 327.2 472.8 320 464 320H112C103.2 320 96 327.2 96 336C96 344.8 103.2 352 112 352zM376 160C362.7 160 352 170.7 352 184V232C352 245.3 362.7 256 376 256H456C469.3 256 480 245.3 480 232V184C480 170.7 469.3 160 456 160H376z\"\n ]\n};\nvar faMoneyCheckDollar = {\n prefix: 'fas',\n iconName: 'money-check-dollar',\n icon: [\n 576,\n 512,\n [\n \"money-check-alt\"\n ],\n \"f53d\",\n \"M512 64C547.3 64 576 92.65 576 128V384C576 419.3 547.3 448 512 448H64C28.65 448 0 419.3 0 384V128C0 92.65 28.65 64 64 64H512zM272 192C263.2 192 256 199.2 256 208C256 216.8 263.2 224 272 224H496C504.8 224 512 216.8 512 208C512 199.2 504.8 192 496 192H272zM272 320H496C504.8 320 512 312.8 512 304C512 295.2 504.8 288 496 288H272C263.2 288 256 295.2 256 304C256 312.8 263.2 320 272 320zM164.1 160C164.1 148.9 155.1 139.9 143.1 139.9C132.9 139.9 123.9 148.9 123.9 160V166C118.3 167.2 112.1 168.9 108 171.1C93.06 177.9 80.07 190.5 76.91 208.8C75.14 219 76.08 228.9 80.32 237.8C84.47 246.6 91 252.8 97.63 257.3C109.2 265.2 124.5 269.8 136.2 273.3L138.4 273.9C152.4 278.2 161.8 281.3 167.7 285.6C170.2 287.4 171.1 288.8 171.4 289.7C171.8 290.5 172.4 292.3 171.7 296.3C171.1 299.8 169.2 302.8 163.7 305.1C157.6 307.7 147.7 309 134.9 307C128.9 306 118.2 302.4 108.7 299.2C106.5 298.4 104.3 297.7 102.3 297C91.84 293.5 80.51 299.2 77.02 309.7C73.53 320.2 79.2 331.5 89.68 334.1C90.89 335.4 92.39 335.9 94.11 336.5C101.1 339.2 114.4 343.4 123.9 345.6V352C123.9 363.1 132.9 372.1 143.1 372.1C155.1 372.1 164.1 363.1 164.1 352V346.5C169.4 345.5 174.6 343.1 179.4 341.9C195.2 335.2 207.8 322.2 211.1 303.2C212.9 292.8 212.1 282.8 208.1 273.7C204.2 264.7 197.9 258.1 191.2 253.3C179.1 244.4 162.9 239.6 150.8 235.9L149.1 235.7C135.8 231.4 126.2 228.4 120.1 224.2C117.5 222.4 116.7 221.2 116.5 220.7C116.3 220.3 115.7 219.1 116.3 215.7C116.7 213.7 118.2 210.4 124.5 207.6C130.1 204.7 140.9 203.1 153.1 204.1C157.5 205.7 171 208.3 174.9 209.3C185.5 212.2 196.5 205.8 199.3 195.1C202.2 184.5 195.8 173.5 185.1 170.7C180.7 169.5 170.7 167.5 164.1 166.3L164.1 160z\"\n ]\n};\nvar faMoneyCheckAlt = faMoneyCheckDollar;\nvar faMonument = {\n prefix: 'fas',\n iconName: 'monument',\n icon: [\n 384,\n 512,\n [],\n \"f5a6\",\n \"M180.7 4.686C186.9-1.562 197.1-1.562 203.3 4.686L283.3 84.69C285.8 87.2 287.4 90.48 287.9 94.02L328.1 416H55.88L96.12 94.02C96.57 90.48 98.17 87.2 100.7 84.69L180.7 4.686zM152 272C138.7 272 128 282.7 128 296C128 309.3 138.7 320 152 320H232C245.3 320 256 309.3 256 296C256 282.7 245.3 272 232 272H152zM352 448C369.7 448 384 462.3 384 480C384 497.7 369.7 512 352 512H32C14.33 512 0 497.7 0 480C0 462.3 14.33 448 32 448H352z\"\n ]\n};\nvar faMoon = {\n prefix: 'fas',\n iconName: 'moon',\n icon: [\n 512,\n 512,\n [\n 127769,\n 9214\n ],\n \"f186\",\n \"M32 256c0-123.8 100.3-224 223.8-224c11.36 0 29.7 1.668 40.9 3.746c9.616 1.777 11.75 14.63 3.279 19.44C245 86.5 211.2 144.6 211.2 207.8c0 109.7 99.71 193 208.3 172.3c9.561-1.805 16.28 9.324 10.11 16.95C387.9 448.6 324.8 480 255.8 480C132.1 480 32 379.6 32 256z\"\n ]\n};\nvar faMortarPestle = {\n prefix: 'fas',\n iconName: 'mortar-pestle',\n icon: [\n 512,\n 512,\n [],\n \"f5a7\",\n \"M501.5 60.87c17.25-17.12 12.5-46.25-9.25-57.13c-12.12-6-26.5-4.75-37.38 3.375L251.1 159.1h151.4L501.5 60.87zM496 191.1h-480c-8.875 0-16 7.125-16 16v32c0 8.875 7.125 16 16 16L31.1 256c0 81 50.25 150.1 121.1 178.4c-12.75 16.88-21.75 36.75-25 58.63C126.8 502.9 134.2 512 144.2 512h223.5c10 0 17.51-9.125 16.13-19c-3.25-21.88-12.25-41.75-25-58.63C429.8 406.1 479.1 337 479.1 256L496 255.1c8.875 0 16-7.125 16-16v-32C512 199.1 504.9 191.1 496 191.1z\"\n ]\n};\nvar faMosque = {\n prefix: 'fas',\n iconName: 'mosque',\n icon: [\n 640,\n 512,\n [\n 128332\n ],\n \"f678\",\n \"M400 0C405 0 409.8 2.371 412.8 6.4C447.5 52.7 490.9 81.34 546.3 117.9C551.5 121.4 556.9 124.9 562.3 128.5C591.3 147.7 608 180.2 608 214.6C608 243.1 596.7 269 578.2 288H221.8C203.3 269 192 243.1 192 214.6C192 180.2 208.7 147.7 237.7 128.5C243.1 124.9 248.5 121.4 253.7 117.9C309.1 81.34 352.5 52.7 387.2 6.4C390.2 2.371 394.1 0 400 0V0zM288 440C288 426.7 277.3 416 264 416C250.7 416 240 426.7 240 440V512H192C174.3 512 160 497.7 160 480V352C160 334.3 174.3 320 192 320H608C625.7 320 640 334.3 640 352V480C640 497.7 625.7 512 608 512H560V440C560 426.7 549.3 416 536 416C522.7 416 512 426.7 512 440V512H448V453.1C448 434.1 439.6 416.1 424.1 404.8L400 384L375 404.8C360.4 416.1 352 434.1 352 453.1V512H288V440zM70.4 5.2C76.09 .9334 83.91 .9334 89.6 5.2L105.6 17.2C139.8 42.88 160 83.19 160 126V128H0V126C0 83.19 20.15 42.88 54.4 17.2L70.4 5.2zM0 160H160V296.6C140.9 307.6 128 328.3 128 352V480C128 489.6 130.1 498.6 133.8 506.8C127.3 510.1 119.9 512 112 512H48C21.49 512 0 490.5 0 464V160z\"\n ]\n};\nvar faMotorcycle = {\n prefix: 'fas',\n iconName: 'motorcycle',\n icon: [\n 640,\n 512,\n [\n 127949\n ],\n \"f21c\",\n \"M342.5 32C357.2 32 370.7 40.05 377.6 52.98L391.7 78.93L439.1 39.42C444.9 34.62 452.1 32 459.6 32H480C497.7 32 512 46.33 512 64V96C512 113.7 497.7 128 480 128H418.2L473.3 229.1C485.5 226.1 498.5 224 512 224C582.7 224 640 281.3 640 352C640 422.7 582.7 480 512 480C441.3 480 384 422.7 384 352C384 311.1 402.4 276.3 431.1 252.8L415.7 224.2C376.1 253.4 352 299.8 352 352C352 362.1 353.1 373.7 355.2 384H284.8C286.9 373.7 287.1 362.1 287.1 352C287.1 263.6 216.4 192 127.1 192H31.1V160C31.1 142.3 46.33 128 63.1 128H165.5C182.5 128 198.7 134.7 210.7 146.7L255.1 192L354.1 110.3L337.7 80H279.1C266.7 80 255.1 69.25 255.1 56C255.1 42.75 266.7 32 279.1 32L342.5 32zM448 352C448 387.3 476.7 416 512 416C547.3 416 576 387.3 576 352C576 316.7 547.3 288 512 288C509.6 288 507.2 288.1 504.9 288.4L533.1 340.6C539.4 352.2 535.1 366.8 523.4 373.1C511.8 379.4 497.2 375.1 490.9 363.4L462.7 311.2C453.5 322.3 448 336.5 448 352V352zM253.8 376C242.5 435.2 190.5 480 128 480C57.31 480 0 422.7 0 352C0 281.3 57.31 224 128 224C190.5 224 242.5 268.8 253.8 328H187.3C177.9 304.5 154.9 288 128 288C92.65 288 64 316.7 64 352C64 387.3 92.65 416 128 416C154.9 416 177.9 399.5 187.3 376H253.8zM96 352C96 334.3 110.3 320 128 320C145.7 320 160 334.3 160 352C160 369.7 145.7 384 128 384C110.3 384 96 369.7 96 352z\"\n ]\n};\nvar faMountain = {\n prefix: 'fas',\n iconName: 'mountain',\n icon: [\n 512,\n 512,\n [\n 127956\n ],\n \"f6fc\",\n \"M503.2 393.8L280.1 44.25c-10.42-16.33-37.73-16.33-48.15 0L8.807 393.8c-11.11 17.41-11.75 39.42-1.666 57.45C17.07 468.1 35.92 480 56.31 480h399.4c20.39 0 39.24-11.03 49.18-28.77C514.9 433.2 514.3 411.2 503.2 393.8zM256 111.8L327.8 224H256L208 288L177.2 235.3L256 111.8z\"\n ]\n};\nvar faMugHot = {\n prefix: 'fas',\n iconName: 'mug-hot',\n icon: [\n 512,\n 512,\n [\n 9749\n ],\n \"f7b6\",\n \"M400 192H32C14.25 192 0 206.3 0 224v192c0 53 43 96 96 96h192c53 0 96-43 96-96h16c61.75 0 112-50.25 112-112S461.8 192 400 192zM400 352H384V256h16C426.5 256 448 277.5 448 304S426.5 352 400 352zM107.9 100.7C120.3 107.1 128 121.4 128 136c0 13.25 10.75 23.89 24 23.89S176 148.1 176 135.7c0-31.34-16.83-60.64-43.91-76.45C119.7 52.03 112 38.63 112 24.28c0-13.25-10.75-24.14-24-24.14S64 11.03 64 24.28C64 55.63 80.83 84.92 107.9 100.7zM219.9 100.7C232.3 107.1 240 121.4 240 136c0 13.25 10.75 23.86 24 23.86S288 148.1 288 135.7c0-31.34-16.83-60.64-43.91-76.45C231.7 52.03 224 38.63 224 24.28c0-13.25-10.75-24.18-24-24.18S176 11.03 176 24.28C176 55.63 192.8 84.92 219.9 100.7z\"\n ]\n};\nvar faMugSaucer = {\n prefix: 'fas',\n iconName: 'mug-saucer',\n icon: [\n 640,\n 512,\n [\n \"coffee\"\n ],\n \"f0f4\",\n \"M512 32H120c-13.25 0-24 10.75-24 24L96.01 288c0 53 43 96 96 96h192C437 384 480 341 480 288h32c70.63 0 128-57.38 128-128S582.6 32 512 32zM512 224h-32V96h32c35.25 0 64 28.75 64 64S547.3 224 512 224zM560 416h-544C7.164 416 0 423.2 0 432C0 458.5 21.49 480 48 480h480c26.51 0 48-21.49 48-48C576 423.2 568.8 416 560 416z\"\n ]\n};\nvar faCoffee = faMugSaucer;\nvar faMusic = {\n prefix: 'fas',\n iconName: 'music',\n icon: [\n 512,\n 512,\n [\n 127925\n ],\n \"f001\",\n \"M511.1 367.1c0 44.18-42.98 80-95.1 80s-95.1-35.82-95.1-79.1c0-44.18 42.98-79.1 95.1-79.1c11.28 0 21.95 1.92 32.01 4.898V148.1L192 224l-.0023 208.1C191.1 476.2 149 512 95.1 512S0 476.2 0 432c0-44.18 42.98-79.1 95.1-79.1c11.28 0 21.95 1.92 32 4.898V126.5c0-12.97 10.06-26.63 22.41-30.52l319.1-94.49C472.1 .6615 477.3 0 480 0c17.66 0 31.97 14.34 32 31.99L511.1 367.1z\"\n ]\n};\nvar faN = {\n prefix: 'fas',\n iconName: 'n',\n icon: [\n 384,\n 512,\n [\n 110\n ],\n \"4e\",\n \"M384 64.01v384c0 13.47-8.438 25.5-21.09 30.09C359.3 479.4 355.7 480 352 480c-9.312 0-18.38-4.078-24.59-11.52L64 152.4v295.6c0 17.67-14.31 32-32 32s-32-14.33-32-32v-384c0-13.47 8.438-25.5 21.09-30.09c12.62-4.516 26.84-.75 35.5 9.609L320 359.6v-295.6c0-17.67 14.31-32 32-32S384 46.34 384 64.01z\"\n ]\n};\nvar faNairaSign = {\n prefix: 'fas',\n iconName: 'naira-sign',\n icon: [\n 448,\n 512,\n [],\n \"e1f6\",\n \"M262.5 256H320V64C320 46.33 334.3 32 352 32C369.7 32 384 46.33 384 64V256H416C433.7 256 448 270.3 448 288C448 305.7 433.7 320 416 320H384V448C384 462.1 374.8 474.5 361.3 478.6C347.8 482.7 333.2 477.5 325.4 465.8L228.2 320H128V448C128 465.7 113.7 480 96 480C78.33 480 64 465.7 64 448V320H32C14.33 320 0 305.7 0 288C0 270.3 14.33 256 32 256H64V64C64 49.9 73.23 37.46 86.73 33.37C100.2 29.29 114.8 34.52 122.6 46.25L262.5 256zM305.1 320L320 342.3V320H305.1zM185.5 256L128 169.7V256H185.5z\"\n ]\n};\nvar faNetworkWired = {\n prefix: 'fas',\n iconName: 'network-wired',\n icon: [\n 640,\n 512,\n [],\n \"f6ff\",\n \"M400 0C426.5 0 448 21.49 448 48V144C448 170.5 426.5 192 400 192H352V224H608C625.7 224 640 238.3 640 256C640 273.7 625.7 288 608 288H512V320H560C586.5 320 608 341.5 608 368V464C608 490.5 586.5 512 560 512H400C373.5 512 352 490.5 352 464V368C352 341.5 373.5 320 400 320H448V288H192V320H240C266.5 320 288 341.5 288 368V464C288 490.5 266.5 512 240 512H80C53.49 512 32 490.5 32 464V368C32 341.5 53.49 320 80 320H128V288H32C14.33 288 0 273.7 0 256C0 238.3 14.33 224 32 224H288V192H240C213.5 192 192 170.5 192 144V48C192 21.49 213.5 0 240 0H400zM256 64V128H384V64H256zM224 448V384H96V448H224zM416 384V448H544V384H416z\"\n ]\n};\nvar faNeuter = {\n prefix: 'fas',\n iconName: 'neuter',\n icon: [\n 384,\n 512,\n [\n 9906\n ],\n \"f22c\",\n \"M368 176c0-97.2-78.8-176-176-176c-97.2 0-176 78.8-176 176c0 86.26 62.1 157.9 144 172.1V496C160 504.8 167.2 512 176 512h32c8.838 0 16-7.164 16-16v-147C305.9 333.9 368 262.3 368 176zM192 272c-52.93 0-96-43.07-96-96c0-52.94 43.07-95.1 96-95.1c52.94 0 96 43.06 96 95.1C288 228.9 244.9 272 192 272z\"\n ]\n};\nvar faNewspaper = {\n prefix: 'fas',\n iconName: 'newspaper',\n icon: [\n 512,\n 512,\n [\n 128240\n ],\n \"f1ea\",\n \"M480 32H128C110.3 32 96 46.33 96 64v336C96 408.8 88.84 416 80 416S64 408.8 64 400V96H32C14.33 96 0 110.3 0 128v288c0 35.35 28.65 64 64 64h384c35.35 0 64-28.65 64-64V64C512 46.33 497.7 32 480 32zM272 416h-96C167.2 416 160 408.8 160 400C160 391.2 167.2 384 176 384h96c8.836 0 16 7.162 16 16C288 408.8 280.8 416 272 416zM272 320h-96C167.2 320 160 312.8 160 304C160 295.2 167.2 288 176 288h96C280.8 288 288 295.2 288 304C288 312.8 280.8 320 272 320zM432 416h-96c-8.836 0-16-7.164-16-16c0-8.838 7.164-16 16-16h96c8.836 0 16 7.162 16 16C448 408.8 440.8 416 432 416zM432 320h-96C327.2 320 320 312.8 320 304C320 295.2 327.2 288 336 288h96C440.8 288 448 295.2 448 304C448 312.8 440.8 320 432 320zM448 208C448 216.8 440.8 224 432 224h-256C167.2 224 160 216.8 160 208v-96C160 103.2 167.2 96 176 96h256C440.8 96 448 103.2 448 112V208z\"\n ]\n};\nvar faNotEqual = {\n prefix: 'fas',\n iconName: 'not-equal',\n icon: [\n 448,\n 512,\n [],\n \"f53e\",\n \"M432 336c0 17.69-14.31 32.01-32 32.01H187.8l-65.15 97.74C116.5 474.1 106.3 480 95.97 480c-6.094 0-12.25-1.75-17.72-5.375c-14.72-9.812-18.69-29.66-8.875-44.38l41.49-62.23H48c-17.69 0-32-14.32-32-32.01s14.31-31.99 32-31.99h105.5l63.1-96H48c-17.69 0-32-14.32-32-32.01s14.31-31.99 32-31.99h212.2l65.18-97.77c9.781-14.69 29.62-18.66 44.37-8.875c14.72 9.812 18.69 29.66 8.875 44.38l-41.51 62.27H400c17.69 0 32 14.31 32 31.99s-14.31 32.01-32 32.01h-105.6l-63.1 96H400C417.7 304 432 318.3 432 336z\"\n ]\n};\nvar faNoteSticky = {\n prefix: 'fas',\n iconName: 'note-sticky',\n icon: [\n 448,\n 512,\n [\n 62026,\n \"sticky-note\"\n ],\n \"f249\",\n \"M400 32h-352C21.49 32 0 53.49 0 80v352C0 458.5 21.49 480 48 480h245.5c16.97 0 33.25-6.744 45.26-18.75l90.51-90.51C441.3 358.7 448 342.5 448 325.5V80C448 53.49 426.5 32 400 32zM64 96h320l-.001 224H320c-17.67 0-32 14.33-32 32v64H64V96z\"\n ]\n};\nvar faStickyNote = faNoteSticky;\nvar faNotesMedical = {\n prefix: 'fas',\n iconName: 'notes-medical',\n icon: [\n 512,\n 512,\n [],\n \"f481\",\n \"M480 144V384l-96 96H144C117.5 480 96 458.5 96 432v-288C96 117.5 117.5 96 144 96h288C458.5 96 480 117.5 480 144zM384 264C384 259.6 380.4 256 376 256H320V200C320 195.6 316.4 192 312 192h-48C259.6 192 256 195.6 256 200V256H200C195.6 256 192 259.6 192 264v48C192 316.4 195.6 320 200 320H256v56c0 4.375 3.625 8 8 8h48c4.375 0 8-3.625 8-8V320h56C380.4 320 384 316.4 384 312V264zM0 360v-240C0 53.83 53.83 0 120 0h240C373.3 0 384 10.75 384 24S373.3 48 360 48h-240C80.3 48 48 80.3 48 120v240C48 373.3 37.25 384 24 384S0 373.3 0 360z\"\n ]\n};\nvar faO = {\n prefix: 'fas',\n iconName: 'o',\n icon: [\n 448,\n 512,\n [\n 111\n ],\n \"4f\",\n \"M224 32.01c-123.5 0-224 100.5-224 224s100.5 224 224 224s224-100.5 224-224S347.5 32.01 224 32.01zM224 416c-88.22 0-160-71.78-160-160s71.78-159.1 160-159.1s160 71.78 160 159.1S312.2 416 224 416z\"\n ]\n};\nvar faObjectGroup = {\n prefix: 'fas',\n iconName: 'object-group',\n icon: [\n 576,\n 512,\n [],\n \"f247\",\n \"M128 160C128 142.3 142.3 128 160 128H288C305.7 128 320 142.3 320 160V256C320 273.7 305.7 288 288 288H160C142.3 288 128 273.7 128 256V160zM288 320C323.3 320 352 291.3 352 256V224H416C433.7 224 448 238.3 448 256V352C448 369.7 433.7 384 416 384H288C270.3 384 256 369.7 256 352V320H288zM32 119.4C12.87 108.4 0 87.69 0 64C0 28.65 28.65 0 64 0C87.69 0 108.4 12.87 119.4 32H456.6C467.6 12.87 488.3 0 512 0C547.3 0 576 28.65 576 64C576 87.69 563.1 108.4 544 119.4V392.6C563.1 403.6 576 424.3 576 448C576 483.3 547.3 512 512 512C488.3 512 467.6 499.1 456.6 480H119.4C108.4 499.1 87.69 512 64 512C28.65 512 0 483.3 0 448C0 424.3 12.87 403.6 32 392.6V119.4zM119.4 96C113.8 105.7 105.7 113.8 96 119.4V392.6C105.7 398.2 113.8 406.3 119.4 416H456.6C462.2 406.3 470.3 398.2 480 392.6V119.4C470.3 113.8 462.2 105.7 456.6 96H119.4z\"\n ]\n};\nvar faObjectUngroup = {\n prefix: 'fas',\n iconName: 'object-ungroup',\n icon: [\n 640,\n 512,\n [],\n \"f248\",\n \"M32 119.4C12.87 108.4 0 87.69 0 64C0 28.65 28.65 0 64 0C87.69 0 108.4 12.87 119.4 32H328.6C339.6 12.87 360.3 0 384 0C419.3 0 448 28.65 448 64C448 87.69 435.1 108.4 416 119.4V232.6C435.1 243.6 448 264.3 448 288C448 323.3 419.3 352 384 352C360.3 352 339.6 339.1 328.6 320H119.4C108.4 339.1 87.69 352 64 352C28.65 352 0 323.3 0 288C0 264.3 12.87 243.6 32 232.6V119.4zM96 119.4V232.6C105.7 238.2 113.8 246.3 119.4 256H328.6C334.2 246.3 342.3 238.2 352 232.6V119.4C342.3 113.8 334.2 105.7 328.6 96H119.4C113.8 105.7 105.7 113.8 96 119.4V119.4zM311.4 480C300.4 499.1 279.7 512 256 512C220.7 512 192 483.3 192 448C192 424.3 204.9 403.6 224 392.6V352H288V392.6C297.7 398.2 305.8 406.3 311.4 416H520.6C526.2 406.3 534.3 398.2 544 392.6V279.4C534.3 273.8 526.2 265.7 520.6 255.1H474.5C469.1 240.6 459.9 227.1 448 216.4V191.1H520.6C531.6 172.9 552.3 159.1 576 159.1C611.3 159.1 640 188.7 640 223.1C640 247.7 627.1 268.4 608 279.4V392.6C627.1 403.6 640 424.3 640 448C640 483.3 611.3 512 576 512C552.3 512 531.6 499.1 520.6 480H311.4z\"\n ]\n};\nvar faOilCan = {\n prefix: 'fas',\n iconName: 'oil-can',\n icon: [\n 640,\n 512,\n [],\n \"f613\",\n \"M288 128V160H368.9C378.8 160 388.6 162.3 397.5 166.8L448 192L615 156.2C633.1 152.3 645.7 173.8 633.5 187.7L451.1 394.3C438.1 408.1 421.5 416 403.1 416H144C117.5 416 96 394.5 96 368V346.7L28.51 316.7C11.17 308.1 0 291.8 0 272.8V208C0 181.5 21.49 160 48 160H224V128H192C174.3 128 160 113.7 160 96C160 78.33 174.3 64 192 64H320C337.7 64 352 78.33 352 96C352 113.7 337.7 128 320 128L288 128zM96 208H48V272.8L96 294.1V208z\"\n ]\n};\nvar faOm = {\n prefix: 'fas',\n iconName: 'om',\n icon: [\n 512,\n 512,\n [\n 128329\n ],\n \"f679\",\n \"M360.6 61C362.5 62.88 365.2 64 368 64s5.375-1.125 7.375-3l21.5-21.62C398.9 37.38 400 34.75 400 32s-1.125-5.375-3.125-7.375L375.4 3c-4.125-4-10.75-4-14.75 0L339 24.62C337 26.62 336 29.25 336 32s1 5.375 3 7.375L360.6 61zM412.1 191.1c-26.75 0-51.75 10.38-70.63 29.25l-24.25 24.25c-6.75 6.75-15.75 10.5-25.37 10.5H245c10.5-22.12 14.12-48.12 7.75-75.25C242.6 138.2 206.4 104.6 163.2 97.62c-36.25-6-71 5-96 28.75c-7.375 7-7 18.87 1.125 24.87L94.5 170.9c5.75 4.375 13.62 4.375 19.12-.125C122.1 163.8 132.8 159.1 144 159.1c26.38 0 48 21.5 48 48S170.4 255.9 143.1 255.9L112 255.1c-11.88 0-19.75 12.63-14.38 23.25L113.8 311.5C116.2 316.5 121.4 319.5 126.9 320H160c35.25 0 64 28.75 64 64s-28.75 64-64 64c-96.12 0-122.4-53.1-145.2-92C10.25 348.4 0 352.4 0 361.2C-.125 416 41.12 512 160 512c70.5 0 127.1-57.44 127.1-128.1c0-23.38-6.874-45.06-17.87-63.94h21.75c26.62 0 51.75-10.38 70.63-29.25l24.25-24.25c6.75-6.75 15.75-10.5 25.37-10.5C431.9 255.1 448 272.1 448 291.9V392c0 13.25-18.75 24-32 24c-39.38 0-66.75-24.25-81.88-42.88C329.4 367.2 320 370.6 320 378.1V416c0 0 0 64 96 64c48.5 0 96-39.5 96-88V291.9C512 236.8 467.3 191.1 412.1 191.1zM454.3 67.25c-85.5 65.13-169 2.751-172.5 .125c-6-4.625-14.5-4.375-20.13 .5C255.9 72.75 254.3 81 257.9 87.63C259.5 90.63 298.2 160 376.8 160c79.88 0 98.75-31.38 101.8-37.63C479.5 120.2 480 117.9 480 115.5V80C480 66.75 464.9 59.25 454.3 67.25z\"\n ]\n};\nvar faOtter = {\n prefix: 'fas',\n iconName: 'otter',\n icon: [\n 640,\n 512,\n [\n 129446\n ],\n \"f700\",\n \"M224 160c8.836 0 16-7.164 16-16C240 135.2 232.8 128 224 128S208 135.2 208 144C208 152.8 215.2 160 224 160zM96 128C87.16 128 80 135.2 80 144C80 152.8 87.16 160 96 160s16-7.164 16-16C112 135.2 104.8 128 96 128zM474.4 64.12C466.8 63.07 460 69.07 460 76.73c0 5.959 4.188 10.1 9.991 12.36C514.2 99.46 544 160 544 192v112c0 8.844-7.156 16-16 16S512 312.8 512 304V212c0-14.87-15.65-24.54-28.94-17.89c-28.96 14.48-47.83 42.99-50.51 74.88C403.7 285.6 384 316.3 384 352v32H224c17.67 0 32-14.33 32-32c0-17.67-14.33-32-32-32H132.4c-14.46 0-27.37-9.598-31.08-23.57C97.86 283.5 96 269.1 96 256V254.4C101.1 255.3 106.3 256 111.7 256c10.78 0 21.45-2.189 31.36-6.436L160 242.3l16.98 7.271C186.9 253.8 197.6 256 208.3 256c7.176 0 14.11-.9277 20.83-2.426C241.7 292 277.4 320 320 320l36.56-.0366C363.1 294.7 377.1 272.7 396.2 256H320c0-25.73 17.56-31.61 32.31-32C369.8 223.8 384 209.6 384 192c0-17.67-14.31-32-32-32c-15.09 0-32.99 4.086-49.28 13.06C303.3 168.9 304 164.7 304 160.3v-16c0-1.684-.4238-3.248-.4961-4.912C313.2 133.9 320 123.9 320 112C320 103.2 312.8 96 304 96H292.7C274.6 58.26 236.3 32 191.7 32H128.3C83.68 32 45.44 58.26 27.33 96H16C7.164 96 0 103.2 0 112c0 11.93 6.816 21.93 16.5 27.43C16.42 141.1 16 142.7 16 144.3v16c0 19.56 5.926 37.71 16 52.86V256c0 123.7 100.3 224 224 224h160c123.9-1.166 224-101.1 224-226.2C639.9 156.9 567.8 76.96 474.4 64.12zM64 160.3v-16C64 108.9 92.86 80 128.3 80h63.32C227.1 80 256 108.9 256 144.3v16C256 186.6 234.6 208 208.3 208c-4.309 0-8.502-.8608-12.46-2.558L162.1 191.4c2.586-.3066 5.207-.543 7.598-1.631l8.314-3.777C186.9 182.3 192 174.9 192 166.7V160c0-6.723-5.996-12.17-13.39-12.17H141.4C133.1 147.8 128 153.3 128 160v6.701c0 8.15 5.068 15.6 13.09 19.25l8.314 3.777c2.391 1.088 5.012 1.324 7.598 1.631l-32.88 14.08C120.2 207.1 115.1 208 111.7 208C85.38 208 64 186.6 64 160.3z\"\n ]\n};\nvar faOutdent = {\n prefix: 'fas',\n iconName: 'outdent',\n icon: [\n 512,\n 512,\n [\n \"dedent\"\n ],\n \"f03b\",\n \"M32 64C32 46.33 46.33 32 64 32H448C465.7 32 480 46.33 480 64C480 81.67 465.7 96 448 96H64C46.33 96 32 81.67 32 64V64zM224 192C224 174.3 238.3 160 256 160H448C465.7 160 480 174.3 480 192C480 209.7 465.7 224 448 224H256C238.3 224 224 209.7 224 192zM448 288C465.7 288 480 302.3 480 320C480 337.7 465.7 352 448 352H256C238.3 352 224 337.7 224 320C224 302.3 238.3 288 256 288H448zM32 448C32 430.3 46.33 416 64 416H448C465.7 416 480 430.3 480 448C480 465.7 465.7 480 448 480H64C46.33 480 32 465.7 32 448V448zM32.24 268.6C24 262.2 24 249.8 32.24 243.4L134.2 164.1C144.7 155.9 160 163.4 160 176.7V335.3C160 348.6 144.7 356.1 134.2 347.9L32.24 268.6z\"\n ]\n};\nvar faDedent = faOutdent;\nvar faP = {\n prefix: 'fas',\n iconName: 'p',\n icon: [\n 320,\n 512,\n [\n 112\n ],\n \"50\",\n \"M160 32.01H32c-17.69 0-32 14.33-32 32v384c0 17.67 14.31 32 32 32s32-14.33 32-32v-96h96c88.22 0 160-71.78 160-159.1S248.2 32.01 160 32.01zM160 288H64V96.01h96c52.94 0 96 43.06 96 96S212.9 288 160 288z\"\n ]\n};\nvar faPager = {\n prefix: 'fas',\n iconName: 'pager',\n icon: [\n 512,\n 512,\n [\n 128223\n ],\n \"f815\",\n \"M448 64H64C28.63 64 0 92.63 0 128v256c0 35.38 28.62 64 64 64h384c35.38 0 64-28.62 64-64V128C512 92.63 483.4 64 448 64zM160 368H80C71.13 368 64 360.9 64 352v-16C64 327.1 71.13 320 80 320H160V368zM288 352c0 8.875-7.125 16-16 16H192V320h80c8.875 0 16 7.125 16 16V352zM448 224c0 17.62-14.38 32-32 32H96C78.38 256 64 241.6 64 224V160c0-17.62 14.38-32 32-32h320c17.62 0 32 14.38 32 32V224z\"\n ]\n};\nvar faPaintRoller = {\n prefix: 'fas',\n iconName: 'paint-roller',\n icon: [\n 512,\n 512,\n [],\n \"f5aa\",\n \"M0 64C0 28.65 28.65 0 64 0H352C387.3 0 416 28.65 416 64V128C416 163.3 387.3 192 352 192H64C28.65 192 0 163.3 0 128V64zM160 352C160 334.3 174.3 320 192 320V304C192 259.8 227.8 224 272 224H416C433.7 224 448 209.7 448 192V69.46C485.3 82.64 512 118.2 512 160V192C512 245 469 288 416 288H272C263.2 288 256 295.2 256 304V320C273.7 320 288 334.3 288 352V480C288 497.7 273.7 512 256 512H192C174.3 512 160 497.7 160 480V352z\"\n ]\n};\nvar faPaintbrush = {\n prefix: 'fas',\n iconName: 'paintbrush',\n icon: [\n 576,\n 512,\n [\n 128396,\n \"paint-brush\"\n ],\n \"f1fc\",\n \"M224 263.3C224.2 233.3 238.4 205.2 262.4 187.2L499.1 9.605C517.7-4.353 543.6-2.965 560.7 12.9C577.7 28.76 580.8 54.54 568.2 74.07L406.5 324.1C391.3 347.7 366.6 363.2 339.3 367.1L224 263.3zM320 400C320 461.9 269.9 512 208 512H64C46.33 512 32 497.7 32 480C32 462.3 46.33 448 64 448H68.81C86.44 448 98.4 429.1 96.59 411.6C96.2 407.8 96 403.9 96 400C96 339.6 143.9 290.3 203.7 288.1L319.8 392.5C319.9 394.1 320 397.5 320 400V400z\"\n ]\n};\nvar faPaintBrush = faPaintbrush;\nvar faPalette = {\n prefix: 'fas',\n iconName: 'palette',\n icon: [\n 512,\n 512,\n [\n 127912\n ],\n \"f53f\",\n \"M512 255.1C512 256.9 511.1 257.8 511.1 258.7C511.6 295.2 478.4 319.1 441.9 319.1H344C317.5 319.1 296 341.5 296 368C296 371.4 296.4 374.7 297 377.9C299.2 388.1 303.5 397.1 307.9 407.8C313.9 421.6 320 435.3 320 449.8C320 481.7 298.4 510.5 266.6 511.8C263.1 511.9 259.5 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256V255.1zM96 255.1C78.33 255.1 64 270.3 64 287.1C64 305.7 78.33 319.1 96 319.1C113.7 319.1 128 305.7 128 287.1C128 270.3 113.7 255.1 96 255.1zM128 191.1C145.7 191.1 160 177.7 160 159.1C160 142.3 145.7 127.1 128 127.1C110.3 127.1 96 142.3 96 159.1C96 177.7 110.3 191.1 128 191.1zM256 63.1C238.3 63.1 224 78.33 224 95.1C224 113.7 238.3 127.1 256 127.1C273.7 127.1 288 113.7 288 95.1C288 78.33 273.7 63.1 256 63.1zM384 191.1C401.7 191.1 416 177.7 416 159.1C416 142.3 401.7 127.1 384 127.1C366.3 127.1 352 142.3 352 159.1C352 177.7 366.3 191.1 384 191.1z\"\n ]\n};\nvar faPallet = {\n prefix: 'fas',\n iconName: 'pallet',\n icon: [\n 640,\n 512,\n [],\n \"f482\",\n \"M624 384c8.75 0 16-7.25 16-16v-32c0-8.75-7.25-16-16-16h-608C7.25 320 0 327.3 0 336v32C0 376.8 7.25 384 16 384H64v64H16C7.25 448 0 455.3 0 464v32C0 504.8 7.25 512 16 512h608c8.75 0 16-7.25 16-16v-32c0-8.75-7.25-16-16-16H576v-64H624zM288 448H128v-64h160V448zM512 448h-160v-64h160V448z\"\n ]\n};\nvar faPanorama = {\n prefix: 'fas',\n iconName: 'panorama',\n icon: [\n 640,\n 512,\n [],\n \"e209\",\n \"M578.2 66.06C409.8 116.6 230.2 116.6 61.8 66.06C31 56.82 0 79.88 0 112v319.9c0 32.15 30.1 55.21 61.79 45.97c168.4-50.53 347.1-50.53 516.4-.002C608.1 487.2 640 464.1 640 431.1V112C640 79.88 609 56.82 578.2 66.06zM128 224C110.3 224 96 209.7 96 192s14.33-32 32-32c17.68 0 32 14.33 32 32S145.7 224 128 224zM474.3 388.6C423.4 380.3 371.8 376 320 376c-50.45 0-100.7 4.043-150.3 11.93c-14.14 2.246-24.11-13.19-15.78-24.84l49.18-68.56C206.1 290.4 210.9 288 216 288s9.916 2.441 12.93 6.574l32.46 44.51l93.3-139.1C357.7 194.7 362.7 192 368 192s10.35 2.672 13.31 7.125l109.1 165.1C498.1 375.9 488.1 390.8 474.3 388.6z\"\n ]\n};\nvar faPaperPlane = {\n prefix: 'fas',\n iconName: 'paper-plane',\n icon: [\n 512,\n 512,\n [\n 61913\n ],\n \"f1d8\",\n \"M511.6 36.86l-64 415.1c-1.5 9.734-7.375 18.22-15.97 23.05c-4.844 2.719-10.27 4.097-15.68 4.097c-4.188 0-8.319-.8154-12.29-2.472l-122.6-51.1l-50.86 76.29C226.3 508.5 219.8 512 212.8 512C201.3 512 192 502.7 192 491.2v-96.18c0-7.115 2.372-14.03 6.742-19.64L416 96l-293.7 264.3L19.69 317.5C8.438 312.8 .8125 302.2 .0625 289.1s5.469-23.72 16.06-29.77l448-255.1c10.69-6.109 23.88-5.547 34 1.406S513.5 24.72 511.6 36.86z\"\n ]\n};\nvar faPaperclip = {\n prefix: 'fas',\n iconName: 'paperclip',\n icon: [\n 448,\n 512,\n [\n 128206\n ],\n \"f0c6\",\n \"M364.2 83.8C339.8 59.39 300.2 59.39 275.8 83.8L91.8 267.8C49.71 309.9 49.71 378.1 91.8 420.2C133.9 462.3 202.1 462.3 244.2 420.2L396.2 268.2C407.1 257.3 424.9 257.3 435.8 268.2C446.7 279.1 446.7 296.9 435.8 307.8L283.8 459.8C219.8 523.8 116.2 523.8 52.2 459.8C-11.75 395.8-11.75 292.2 52.2 228.2L236.2 44.2C282.5-2.08 357.5-2.08 403.8 44.2C450.1 90.48 450.1 165.5 403.8 211.8L227.8 387.8C199.2 416.4 152.8 416.4 124.2 387.8C95.59 359.2 95.59 312.8 124.2 284.2L268.2 140.2C279.1 129.3 296.9 129.3 307.8 140.2C318.7 151.1 318.7 168.9 307.8 179.8L163.8 323.8C157.1 330.5 157.1 341.5 163.8 348.2C170.5 354.9 181.5 354.9 188.2 348.2L364.2 172.2C388.6 147.8 388.6 108.2 364.2 83.8V83.8z\"\n ]\n};\nvar faParachuteBox = {\n prefix: 'fas',\n iconName: 'parachute-box',\n icon: [\n 512,\n 512,\n [],\n \"f4cd\",\n \"M272 192V320H304C311 320 317.7 321.5 323.7 324.2L443.8 192H415.5C415.8 186.7 416 181.4 416 176C416 112.1 393.8 54.84 358.9 16.69C450 49.27 493.4 122.6 507.8 173.6C510.5 183.1 502.1 192 493.1 192H487.1L346.8 346.3C350.1 352.8 352 360.2 352 368V464C352 490.5 330.5 512 304 512H207.1C181.5 512 159.1 490.5 159.1 464V368C159.1 360.2 161.9 352.8 165.2 346.3L24.92 192H18.89C9 192 1.483 183.1 4.181 173.6C18.64 122.6 61.97 49.27 153.1 16.69C118.2 54.84 96 112.1 96 176C96 181.4 96.16 186.7 96.47 192H68.17L188.3 324.2C194.3 321.5 200.1 320 207.1 320H239.1V192H128.5C128.2 186.7 127.1 181.4 127.1 176C127.1 125 143.9 80.01 168.2 48.43C192.5 16.89 223.8 0 255.1 0C288.2 0 319.5 16.89 343.8 48.43C368.1 80.01 384 125 384 176C384 181.4 383.8 186.7 383.5 192H272z\"\n ]\n};\nvar faParagraph = {\n prefix: 'fas',\n iconName: 'paragraph',\n icon: [\n 448,\n 512,\n [\n 182\n ],\n \"f1dd\",\n \"M448 63.1C448 81.67 433.7 96 416 96H384v352c0 17.67-14.33 32-31.1 32S320 465.7 320 448V96h-32v352c0 17.67-14.33 32-31.1 32S224 465.7 224 448v-96H198.9c-83.57 0-158.2-61.11-166.1-144.3C23.66 112.3 98.44 32 191.1 32h224C433.7 32 448 46.33 448 63.1z\"\n ]\n};\nvar faPassport = {\n prefix: 'fas',\n iconName: 'passport',\n icon: [\n 448,\n 512,\n [],\n \"f5ab\",\n \"M129.6 208c5.25 31.25 25.62 57.13 53.25 70.38C175.3 259.4 170.3 235 168.8 208H129.6zM129.6 176h39.13c1.5-27 6.5-51.38 14.12-70.38C155.3 118.9 134.9 144.8 129.6 176zM224 286.8C231.8 279.3 244.8 252.3 247.4 208H200.5C203.3 252.3 216.3 279.3 224 286.8zM265.1 105.6C272.8 124.6 277.8 149 279.3 176h39.13C313.1 144.8 292.8 118.9 265.1 105.6zM384 0H64C28.65 0 0 28.65 0 64v384c0 35.35 28.65 64 64 64h320c35.2 0 64-28.8 64-64V64C448 28.8 419.2 0 384 0zM336 416h-224C103.3 416 96 408.8 96 400S103.3 384 112 384h224c8.75 0 16 7.25 16 16S344.8 416 336 416zM224 320c-70.75 0-128-57.25-128-128s57.25-128 128-128s128 57.25 128 128S294.8 320 224 320zM265.1 278.4c27.62-13.25 48-39.13 53.25-70.38h-39.13C277.8 235 272.8 259.4 265.1 278.4zM200.6 176h46.88C244.7 131.8 231.8 104.8 224 97.25C216.3 104.8 203.2 131.8 200.6 176z\"\n ]\n};\nvar faPaste = {\n prefix: 'fas',\n iconName: 'paste',\n icon: [\n 512,\n 512,\n [\n \"file-clipboard\"\n ],\n \"f0ea\",\n \"M320 96V80C320 53.49 298.5 32 272 32H215.4C204.3 12.89 183.6 0 160 0S115.7 12.89 104.6 32H48C21.49 32 0 53.49 0 80v320C0 426.5 21.49 448 48 448l144 .0013L192 176C192 131.8 227.8 96 272 96H320zM160 88C146.8 88 136 77.25 136 64S146.8 40 160 40S184 50.75 184 64S173.3 88 160 88zM416 128v96h96L416 128zM384 224L384 128h-112C245.5 128 224 149.5 224 176v288c0 26.51 21.49 48 48 48h192c26.51 0 48-21.49 48-48V256h-95.99C398.4 256 384 241.6 384 224z\"\n ]\n};\nvar faFileClipboard = faPaste;\nvar faPause = {\n prefix: 'fas',\n iconName: 'pause',\n icon: [\n 320,\n 512,\n [\n 9208\n ],\n \"f04c\",\n \"M272 63.1l-32 0c-26.51 0-48 21.49-48 47.1v288c0 26.51 21.49 48 48 48L272 448c26.51 0 48-21.49 48-48v-288C320 85.49 298.5 63.1 272 63.1zM80 63.1l-32 0c-26.51 0-48 21.49-48 48v288C0 426.5 21.49 448 48 448l32 0c26.51 0 48-21.49 48-48v-288C128 85.49 106.5 63.1 80 63.1z\"\n ]\n};\nvar faPaw = {\n prefix: 'fas',\n iconName: 'paw',\n icon: [\n 512,\n 512,\n [],\n \"f1b0\",\n \"M256 224c-79.37 0-191.1 122.7-191.1 200.2C64.02 459.1 90.76 480 135.8 480C184.6 480 216.9 454.9 256 454.9C295.5 454.9 327.9 480 376.2 480c44.1 0 71.74-20.88 71.74-55.75C447.1 346.8 335.4 224 256 224zM108.8 211.4c-10.37-34.62-42.5-57.12-71.62-50.12S-7.104 202 3.27 236.6C13.64 271.3 45.77 293.8 74.89 286.8S119.1 246 108.8 211.4zM193.5 190.6c30.87-8.125 46.37-49.1 34.5-93.37s-46.5-71.1-77.49-63.87c-30.87 8.125-46.37 49.1-34.5 93.37C127.9 170.1 162.5 198.8 193.5 190.6zM474.9 161.3c-29.12-6.1-61.25 15.5-71.62 50.12c-10.37 34.63 4.75 68.37 33.87 75.37c29.12 6.1 61.12-15.5 71.62-50.12C519.1 202 503.1 168.3 474.9 161.3zM318.5 190.6c30.1 8.125 65.62-20.5 77.49-63.87c11.87-43.37-3.625-85.25-34.5-93.37c-30.1-8.125-65.62 20.5-77.49 63.87C272.1 140.6 287.6 182.5 318.5 190.6z\"\n ]\n};\nvar faPeace = {\n prefix: 'fas',\n iconName: 'peace',\n icon: [\n 512,\n 512,\n [\n 9774\n ],\n \"f67c\",\n \"M256 0C114.6 0 0 114.6 0 256s114.6 256 256 256s256-114.6 256-256S397.4 0 256 0zM224 445.1c-36.36-6.141-69.2-22.48-95.59-46.04L224 322.6V445.1zM288 322.6l95.59 76.47C357.2 422.6 324.4 438.1 288 445.1V322.6zM64 256c0-94.95 69.34-173.8 160-189.1v173.7l-135.7 108.6C72.86 321.6 64 289.8 64 256zM423.7 349.2L288 240.6V66.89C378.7 82.2 448 161.1 448 256C448 289.8 439.1 321.6 423.7 349.2z\"\n ]\n};\nvar faPen = {\n prefix: 'fas',\n iconName: 'pen',\n icon: [\n 512,\n 512,\n [\n 128394\n ],\n \"f304\",\n \"M362.7 19.32C387.7-5.678 428.3-5.678 453.3 19.32L492.7 58.75C517.7 83.74 517.7 124.3 492.7 149.3L444.3 197.7L314.3 67.72L362.7 19.32zM421.7 220.3L188.5 453.4C178.1 463.8 165.2 471.5 151.1 475.6L30.77 511C22.35 513.5 13.24 511.2 7.03 504.1C.8198 498.8-1.502 489.7 .976 481.2L36.37 360.9C40.53 346.8 48.16 333.9 58.57 323.5L291.7 90.34L421.7 220.3z\"\n ]\n};\nvar faPenClip = {\n prefix: 'fas',\n iconName: 'pen-clip',\n icon: [\n 512,\n 512,\n [\n \"pen-alt\"\n ],\n \"f305\",\n \"M492.7 58.75C517.7 83.74 517.7 124.3 492.7 149.3L440.6 201.4L310.6 71.43L362.7 19.32C387.7-5.678 428.3-5.678 453.3 19.32L492.7 58.75zM240.1 114.9C231.6 105.5 216.4 105.5 207 114.9L104.1 216.1C95.6 226.3 80.4 226.3 71.03 216.1C61.66 207.6 61.66 192.4 71.03 183L173.1 80.97C201.2 52.85 246.8 52.85 274.9 80.97L417.9 224L229.5 412.5C181.5 460.5 120.3 493.2 53.7 506.5L28.71 511.5C20.84 513.1 12.7 510.6 7.03 504.1C1.356 499.3-1.107 491.2 .4662 483.3L5.465 458.3C18.78 391.7 51.52 330.5 99.54 282.5L254.1 128L240.1 114.9z\"\n ]\n};\nvar faPenAlt = faPenClip;\nvar faPenFancy = {\n prefix: 'fas',\n iconName: 'pen-fancy',\n icon: [\n 512,\n 512,\n [\n 128395,\n 10002\n ],\n \"f5ac\",\n \"M373.5 27.11C388.5 9.885 410.2 0 433 0C476.6 0 512 35.36 512 78.98C512 101.8 502.1 123.5 484.9 138.5L277.7 319L192.1 234.3L373.5 27.11zM255.1 341.7L235.9 425.1C231.9 442.2 218.9 455.8 202 460.5L24.35 510.3L119.7 414.9C122.4 415.6 125.1 416 128 416C145.7 416 160 401.7 160 384C160 366.3 145.7 352 128 352C110.3 352 96 366.3 96 384C96 386.9 96.38 389.6 97.08 392.3L1.724 487.6L51.47 309.1C56.21 293.1 69.8 280.1 86.9 276.1L170.3 256.9L255.1 341.7z\"\n ]\n};\nvar faPenNib = {\n prefix: 'fas',\n iconName: 'pen-nib',\n icon: [\n 512,\n 512,\n [\n 10001\n ],\n \"f5ad\",\n \"M368.4 18.34C390.3-3.526 425.7-3.526 447.6 18.34L493.7 64.4C515.5 86.27 515.5 121.7 493.7 143.6L437.9 199.3L312.7 74.06L368.4 18.34zM417.4 224L371.4 377.3C365.4 397.2 350.2 413 330.5 419.6L66.17 508.2C54.83 512 42.32 509.2 33.74 500.9L187.3 347.3C193.6 350.3 200.6 352 207.1 352C234.5 352 255.1 330.5 255.1 304C255.1 277.5 234.5 256 207.1 256C181.5 256 159.1 277.5 159.1 304C159.1 311.4 161.7 318.4 164.7 324.7L11.11 478.3C2.809 469.7-.04 457.2 3.765 445.8L92.39 181.5C98.1 161.8 114.8 146.6 134.7 140.6L287.1 94.6L417.4 224z\"\n ]\n};\nvar faPenRuler = {\n prefix: 'fas',\n iconName: 'pen-ruler',\n icon: [\n 512,\n 512,\n [\n \"pencil-ruler\"\n ],\n \"f5ae\",\n \"M492.7 42.75C517.7 67.74 517.7 108.3 492.7 133.3L436.3 189.7L322.3 75.72L378.7 19.32C403.7-5.678 444.3-5.678 469.3 19.32L492.7 42.75zM44.89 353.2L299.7 98.34L413.7 212.3L158.8 467.1C152.1 473.8 143.8 478.7 134.6 481.4L30.59 511.1C22.21 513.5 13.19 511.1 7.03 504.1C.8669 498.8-1.47 489.8 .9242 481.4L30.65 377.4C33.26 368.2 38.16 359.9 44.89 353.2zM249.4 103.4L103.4 249.4L16 161.9C-2.745 143.2-2.745 112.8 16 94.06L94.06 16C112.8-2.745 143.2-2.745 161.9 16L181.7 35.76C181.4 36.05 181 36.36 180.7 36.69L116.7 100.7C110.4 106.9 110.4 117.1 116.7 123.3C122.9 129.6 133.1 129.6 139.3 123.3L203.3 59.31C203.6 58.99 203.1 58.65 204.2 58.3L249.4 103.4zM453.7 307.8C453.4 308 453 308.4 452.7 308.7L388.7 372.7C382.4 378.9 382.4 389.1 388.7 395.3C394.9 401.6 405.1 401.6 411.3 395.3L475.3 331.3C475.6 330.1 475.1 330.6 476.2 330.3L496 350.1C514.7 368.8 514.7 399.2 496 417.9L417.9 496C399.2 514.7 368.8 514.7 350.1 496L262.6 408.6L408.6 262.6L453.7 307.8z\"\n ]\n};\nvar faPencilRuler = faPenRuler;\nvar faPenToSquare = {\n prefix: 'fas',\n iconName: 'pen-to-square',\n icon: [\n 512,\n 512,\n [\n \"edit\"\n ],\n \"f044\",\n \"M490.3 40.4C512.2 62.27 512.2 97.73 490.3 119.6L460.3 149.7L362.3 51.72L392.4 21.66C414.3-.2135 449.7-.2135 471.6 21.66L490.3 40.4zM172.4 241.7L339.7 74.34L437.7 172.3L270.3 339.6C264.2 345.8 256.7 350.4 248.4 353.2L159.6 382.8C150.1 385.6 141.5 383.4 135 376.1C128.6 370.5 126.4 361 129.2 352.4L158.8 263.6C161.6 255.3 166.2 247.8 172.4 241.7V241.7zM192 63.1C209.7 63.1 224 78.33 224 95.1C224 113.7 209.7 127.1 192 127.1H96C78.33 127.1 64 142.3 64 159.1V416C64 433.7 78.33 448 96 448H352C369.7 448 384 433.7 384 416V319.1C384 302.3 398.3 287.1 416 287.1C433.7 287.1 448 302.3 448 319.1V416C448 469 405 512 352 512H96C42.98 512 0 469 0 416V159.1C0 106.1 42.98 63.1 96 63.1H192z\"\n ]\n};\nvar faEdit = faPenToSquare;\nvar faPencil = {\n prefix: 'fas',\n iconName: 'pencil',\n icon: [\n 512,\n 512,\n [\n 61504,\n 9999,\n \"pencil-alt\"\n ],\n \"f303\",\n \"M421.7 220.3L188.5 453.4L154.6 419.5L158.1 416H112C103.2 416 96 408.8 96 400V353.9L92.51 357.4C87.78 362.2 84.31 368 82.42 374.4L59.44 452.6L137.6 429.6C143.1 427.7 149.8 424.2 154.6 419.5L188.5 453.4C178.1 463.8 165.2 471.5 151.1 475.6L30.77 511C22.35 513.5 13.24 511.2 7.03 504.1C.8198 498.8-1.502 489.7 .976 481.2L36.37 360.9C40.53 346.8 48.16 333.9 58.57 323.5L291.7 90.34L421.7 220.3zM492.7 58.75C517.7 83.74 517.7 124.3 492.7 149.3L444.3 197.7L314.3 67.72L362.7 19.32C387.7-5.678 428.3-5.678 453.3 19.32L492.7 58.75z\"\n ]\n};\nvar faPencilAlt = faPencil;\nvar faPeopleArrowsLeftRight = {\n prefix: 'fas',\n iconName: 'people-arrows-left-right',\n icon: [\n 576,\n 512,\n [\n \"people-arrows\"\n ],\n \"e068\",\n \"M96 304.1c0-12.16 4.971-23.83 13.64-32.01l72.13-68.08c1.65-1.555 3.773-2.311 5.611-3.578C177.1 176.8 155 160 128 160H64C28.65 160 0 188.7 0 224v96c0 17.67 14.33 32 31.1 32L32 480c0 17.67 14.33 32 32 32h64c17.67 0 32-14.33 32-32v-96.39l-50.36-47.53C100.1 327.9 96 316.2 96 304.1zM480 128c35.38 0 64-28.62 64-64s-28.62-64-64-64s-64 28.62-64 64S444.6 128 480 128zM96 128c35.38 0 64-28.62 64-64S131.4 0 96 0S32 28.62 32 64S60.63 128 96 128zM444.4 295.3L372.3 227.3c-3.49-3.293-8.607-4.193-13.01-2.299C354.9 226.9 352 231.2 352 236V272H224V236c0-4.795-2.857-9.133-7.262-11.03C212.3 223.1 207.2 223.1 203.7 227.3L131.6 295.3c-4.805 4.535-4.805 12.94 0 17.47l72.12 68.07c3.49 3.291 8.607 4.191 13.01 2.297C221.1 381.3 224 376.9 224 372.1V336h128v36.14c0 4.795 2.857 9.135 7.262 11.04c4.406 1.893 9.523 .9922 13.01-2.299l72.12-68.07C449.2 308.3 449.2 299.9 444.4 295.3zM512 160h-64c-26.1 0-49.98 16.77-59.38 40.42c1.842 1.271 3.969 2.027 5.623 3.588l72.12 68.06C475 280.2 480 291.9 480 304.1c.002 12.16-4.969 23.83-13.64 32.01L416 383.6V480c0 17.67 14.33 32 32 32h64c17.67 0 32-14.33 32-32v-128c17.67 0 32-14.33 32-32V224C576 188.7 547.3 160 512 160z\"\n ]\n};\nvar faPeopleArrows = faPeopleArrowsLeftRight;\nvar faPeopleCarryBox = {\n prefix: 'fas',\n iconName: 'people-carry-box',\n icon: [\n 640,\n 512,\n [\n \"people-carry\"\n ],\n \"f4ce\",\n \"M128 95.1c26.5 0 47.1-21.5 47.1-47.1S154.5 0 128 0S80.01 21.5 80.01 47.1S101.5 95.1 128 95.1zM511.1 95.1c26.5 0 47.1-21.5 47.1-47.1S538.5 0 511.1 0c-26.5 0-48 21.5-48 47.1S485.5 95.1 511.1 95.1zM603.5 258.3l-18.5-80.13c-4.625-20-18.62-36.88-37.5-44.88c-18.5-8-38.1-6.75-56.12 3.25c-22.62 13.38-39.62 34.5-48.12 59.38l-11.25 33.88l-15.1 10.25L415.1 144c0-8.75-7.25-16-16-16H240c-8.75 0-16 7.25-16 16L224 239.1l-16.12-10.25l-11.25-33.88c-8.375-25-25.38-46-48.12-59.38c-17.25-10-37.63-11.25-56.12-3.25c-18.88 8-32.88 24.88-37.5 44.88l-18.37 80.13c-4.625 20 .7506 41.25 14.37 56.75l67.25 75.88l10.12 92.63C130 499.8 143.8 512 160 512c1.25 0 2.25-.125 3.5-.25c17.62-1.875 30.25-17.62 28.25-35.25l-10-92.75c-1.5-13-7-25.12-15.62-35l-43.37-49l17.62-70.38l6.876 20.38c4 12.5 11.87 23.5 24.5 32.63l51 32.5c4.623 2.875 12.12 4.625 17.25 5h159.1c5.125-.375 12.62-2.125 17.25-5l51-32.5c12.62-9.125 20.5-20 24.5-32.63l6.875-20.38l17.63 70.38l-43.37 49c-8.625 9.875-14.12 22-15.62 35l-10 92.75c-2 17.62 10.75 33.38 28.25 35.25C477.7 511.9 478.7 512 479.1 512c16.12 0 29.1-12.12 31.75-28.5l10.12-92.63L589.1 315C602.7 299.5 608.1 278.3 603.5 258.3zM46.26 358.1l-44 110c-6.5 16.38 1.5 35 17.88 41.63c16.75 6.5 35.12-1.75 41.62-17.88l27.62-69.13l-2-18.25L46.26 358.1zM637.7 468.1l-43.1-110l-41.13 46.38l-2 18.25l27.62 69.13C583.2 504.4 595.2 512 607.1 512c3.998 0 7.998-.75 11.87-2.25C636.2 503.1 644.2 484.5 637.7 468.1z\"\n ]\n};\nvar faPeopleCarry = faPeopleCarryBox;\nvar faPepperHot = {\n prefix: 'fas',\n iconName: 'pepper-hot',\n icon: [\n 512,\n 512,\n [\n 127798\n ],\n \"f816\",\n \"M465 134.2c21.46-38.38 19.87-87.17-5.65-123.1c-7.541-10.83-22.31-13.53-33.2-5.938c-10.77 7.578-13.44 22.55-5.896 33.41c14.41 20.76 15.13 47.69 4.098 69.77C407.1 100.1 388 95.1 368 95.1c-36.23 0-68.93 13.83-94.24 35.92L352 165.5V256h90.56l33.53 78.23C498.2 308.9 512 276.2 512 239.1C512 198 493.7 160.6 465 134.2zM320 288V186.6l-52.95-22.69C216.2 241.3 188.5 400 56 400C25.13 400 0 425.1 0 456S25.13 512 56 512c180.3 0 320.1-88.27 389.3-168.5L421.5 288H320z\"\n ]\n};\nvar faPercent = {\n prefix: 'fas',\n iconName: 'percent',\n icon: [\n 384,\n 512,\n [\n 62785,\n 62101,\n \"percentage\"\n ],\n \"25\",\n \"M374.6 73.39c-12.5-12.5-32.75-12.5-45.25 0l-320 320c-12.5 12.5-12.5 32.75 0 45.25C15.63 444.9 23.81 448 32 448s16.38-3.125 22.62-9.375l320-320C387.1 106.1 387.1 85.89 374.6 73.39zM64 192c35.3 0 64-28.72 64-64S99.3 64.01 64 64.01S0 92.73 0 128S28.7 192 64 192zM320 320c-35.3 0-64 28.72-64 64s28.7 64 64 64s64-28.72 64-64S355.3 320 320 320z\"\n ]\n};\nvar faPercentage = faPercent;\nvar faPerson = {\n prefix: 'fas',\n iconName: 'person',\n icon: [\n 320,\n 512,\n [\n 129485,\n \"male\"\n ],\n \"f183\",\n \"M315.1 271l-70.56-112.1C232.8 139.3 212.5 128 190.3 128H129.7c-22.22 0-42.53 11.25-54.28 30.09L4.873 271c-9.375 14.98-4.812 34.72 10.16 44.09c15 9.375 34.75 4.812 44.09-10.19l28.88-46.18L87.1 480c0 17.67 14.33 32 32 32c17.67 0 31.1-14.33 31.1-32l0-144h16V480c0 17.67 14.33 32 32 32c17.67 0 32-14.33 32-32V258.8l28.88 46.2C266.9 314.7 277.4 320 288 320c5.781 0 11.66-1.562 16.94-4.859C319.9 305.8 324.5 286 315.1 271zM160 96c26.5 0 48-21.5 48-48S186.5 0 160 0C133.5 0 112 21.5 112 48S133.5 96 160 96z\"\n ]\n};\nvar faMale = faPerson;\nvar faPersonBiking = {\n prefix: 'fas',\n iconName: 'person-biking',\n icon: [\n 640,\n 512,\n [\n 128692,\n \"biking\"\n ],\n \"f84a\",\n \"M352 48C352 21.49 373.5 0 400 0C426.5 0 448 21.49 448 48C448 74.51 426.5 96 400 96C373.5 96 352 74.51 352 48zM480 159.1C497.7 159.1 512 174.3 512 191.1C512 209.7 497.7 223.1 480 223.1H416C408.7 223.1 401.7 221.5 396 216.1L355.3 184.4L295 232.9L337.8 261.4C346.7 267.3 352 277.3 352 288V416C352 433.7 337.7 448 320 448C302.3 448 288 433.7 288 416V305.1L227.5 266.8C194.7 245.1 192.5 198.9 223.2 175.2L306.3 110.9C323.8 97.45 348.1 97.58 365.4 111.2L427.2 159.1H480zM256 384C256 454.7 198.7 512 128 512C57.31 512 0 454.7 0 384C0 313.3 57.31 256 128 256C198.7 256 256 313.3 256 384zM128 312C88.24 312 56 344.2 56 384C56 423.8 88.24 456 128 456C167.8 456 200 423.8 200 384C200 344.2 167.8 312 128 312zM640 384C640 454.7 582.7 512 512 512C441.3 512 384 454.7 384 384C384 313.3 441.3 256 512 256C582.7 256 640 313.3 640 384zM512 312C472.2 312 440 344.2 440 384C440 423.8 472.2 456 512 456C551.8 456 584 423.8 584 384C584 344.2 551.8 312 512 312z\"\n ]\n};\nvar faBiking = faPersonBiking;\nvar faPersonBooth = {\n prefix: 'fas',\n iconName: 'person-booth',\n icon: [\n 576,\n 512,\n [],\n \"f756\",\n \"M192 496C192 504.8 199.3 512 208 512h32C248.8 512 256 504.8 256 496V320H192V496zM544 0h-32v496c0 8.75 7.25 16 16 16h32c8.75 0 16-7.25 16-16V32C576 14.25 561.8 0 544 0zM64 128c26.5 0 48-21.5 48-48S90.5 32 64 32S16 53.5 16 80S37.5 128 64 128zM224 224H173.1L127.9 178.8C115.8 166.6 99.75 160 82.75 160H64C46.88 160 30.75 166.8 18.75 178.8c-12 12.12-18.72 28.22-18.72 45.35L0 480c0 17.75 14.25 32 31.88 32s32-14.25 32-32L64 379.3c.875 .5 1.625 1.375 2.5 1.75L95.63 424V480c0 17.75 14.25 32 32 32c17.62 0 32-14.25 32-32v-56.5c0-9.875-2.375-19.75-6.75-28.62l-41.13-61.25V253l20.88 20.88C141.8 283 153.8 288 166.5 288H224c17.75 0 32-14.25 32-32S241.8 224 224 224zM192 32v160h64V0H224C206.3 0 192 14.25 192 32zM288 32l31.5 223.1l-30.88 154.6C284.3 431.3 301.6 448 320 448c15.25 0 27.99-9.125 32.24-30.38C353.3 434.5 366.9 448 384 448c17.75 0 32-14.25 32-32c0 17.75 14.25 32 32 32s32-14.25 32-32V0h-192V32z\"\n ]\n};\nvar faPersonDotsFromLine = {\n prefix: 'fas',\n iconName: 'person-dots-from-line',\n icon: [\n 576,\n 512,\n [\n \"diagnoses\"\n ],\n \"f470\",\n \"M463.1 256c8.75 0 15.1-7.25 15.1-16S472.7 224 463.1 224c-8.75 0-15.1 7.25-15.1 16S455.2 256 463.1 256zM287.1 176c48.5 0 87.1-39.5 87.1-88S336.5 0 287.1 0S200 39.5 200 88S239.5 176 287.1 176zM80 256c8.75 0 15.1-7.25 15.1-16S88.75 224 80 224S64 231.3 64 240S71.25 256 80 256zM75.91 375.1c.6289-.459 41.62-29.26 100.1-50.05L176 432h223.1l-.0004-106.8c58.32 20.8 99.51 49.49 100.1 49.91C508.6 381.1 518.3 384 527.9 384c14.98 0 29.73-7 39.11-20.09c15.41-21.59 10.41-51.56-11.16-66.97c-1.955-1.391-21.1-14.83-51.83-30.85C495.5 279.2 480.7 288 463.1 288c-26.25 0-47.1-21.75-47.1-48c0-3.549 .4648-6.992 1.217-10.33C378.6 217.2 334.4 208 288 208c-59.37 0-114.1 15.01-160.1 32.67C127.6 266.6 106 288 80 288C69.02 288 58.94 284 50.8 277.7c-18.11 10.45-29.25 18.22-30.7 19.26c-21.56 15.41-26.56 45.38-11.16 66.97C24.33 385.5 54.3 390.4 75.91 375.1zM335.1 344c13.25 0 23.1 10.75 23.1 24s-10.75 24-23.1 24c-13.25 0-23.1-10.75-23.1-24S322.7 344 335.1 344zM240 248c13.25 0 23.1 10.75 23.1 24S253.3 296 240 296c-13.25 0-23.1-10.75-23.1-24S226.8 248 240 248zM559.1 464H16c-8.75 0-15.1 7.25-15.1 16l-.0016 16c0 8.75 7.25 16 15.1 16h543.1c8.75 0 15.1-7.25 15.1-16L575.1 480C575.1 471.3 568.7 464 559.1 464z\"\n ]\n};\nvar faDiagnoses = faPersonDotsFromLine;\nvar faPersonDress = {\n prefix: 'fas',\n iconName: 'person-dress',\n icon: [\n 320,\n 512,\n [\n \"female\"\n ],\n \"f182\",\n \"M160 96c26.5 0 48-21.5 48-48s-21.5-48-47.1-48c-26.5 0-48 21.5-48 48S133.5 96 160 96zM315.1 271l-61.19-97.95C236.3 144.9 205.8 128 172.5 128H147.5C114.2 128 83.75 144.9 66.06 173.1L4.873 271C-4.502 286 .0607 305.8 15.03 315.1c15.03 9.375 34.75 4.812 44.09-10.19l32.62-52.19L47.1 384h40v96c0 17.67 14.33 32 32 32c17.67 0 31.1-14.33 31.1-32v-96h16v96c0 17.67 14.33 32 32 32c17.67 0 32-14.33 32-32v-96h40l-43.76-131.3l32.63 52.22C266.9 314.7 277.4 320 288 320c5.781 0 11.66-1.562 16.94-4.859C319.9 305.8 324.5 286 315.1 271z\"\n ]\n};\nvar faFemale = faPersonDress;\nvar faPersonHiking = {\n prefix: 'fas',\n iconName: 'person-hiking',\n icon: [\n 384,\n 512,\n [\n \"hiking\"\n ],\n \"f6ec\",\n \"M240 96c26.5 0 48-21.5 48-48S266.5 0 240 0C213.5 0 192 21.5 192 48S213.5 96 240 96zM80.01 287.1c7.31 0 13.97-4.762 15.87-11.86L137 117c.3468-1.291 .5125-2.588 .5125-3.866c0-7.011-4.986-13.44-12.39-15.13C118.4 96.38 111.7 95.6 105.1 95.6c-36.65 0-70 23.84-79.32 59.53L.5119 253.3C.1636 254.6-.0025 255.9-.0025 257.2c0 7.003 4.961 13.42 12.36 15.11L76.01 287.5C77.35 287.8 78.69 287.1 80.01 287.1zM368 160h-15.1c-8.875 0-15.1 7.125-15.1 16V192h-34.75l-46.75-46.75C243.4 134.1 228.6 128 212.9 128C185.9 128 162.5 146.3 155.9 172.5L129 280.3C128.4 282.8 128 285.5 128 288.1c0 8.325 3.265 16.44 9.354 22.53l86.62 86.63V480c0 17.62 14.37 32 31.1 32s32-14.38 32-32v-82.75c0-17.12-6.625-33.13-18.75-45.25l-46.87-46.88c.25-.5 .5-.875 .625-1.375l19.1-79.5l22.37 22.38C271.4 252.6 279.5 256 288 256h47.1v240c0 8.875 7.125 16 15.1 16h15.1C376.9 512 384 504.9 384 496v-320C384 167.1 376.9 160 368 160zM81.01 472.3c-.672 2.63-.993 5.267-.993 7.86c0 14.29 9.749 27.29 24.24 30.89C106.9 511.8 109.5 512 112 512c14.37 0 27.37-9.75 30.1-24.25l25.25-101l-52.75-52.75L81.01 472.3z\"\n ]\n};\nvar faHiking = faPersonHiking;\nvar faPersonPraying = {\n prefix: 'fas',\n iconName: 'person-praying',\n icon: [\n 384,\n 512,\n [\n 128720,\n \"pray\"\n ],\n \"f683\",\n \"M255.1 128c35.38 0 63.1-28.62 63.1-64s-28.62-64-63.1-64S191.1 28.62 191.1 64S220.6 128 255.1 128zM225.4 297.8c14 16.75 39 19.12 56.01 5.25l88.01-72c17-14 19.5-39.25 5.625-56.38c-14-17.12-39.25-19.5-56.38-5.625L261.3 216l-39-46.25c-15.38-18.38-39.13-27.88-64.01-25.38c-24.13 2.5-45.25 16.25-56.38 37l-49.38 92C29.13 317 43.88 369.8 86.76 397.1L131.5 432H40C17.88 432 0 449.9 0 472S17.88 512 40 512h208c34.13 0 53.76-42.75 28.25-68.25L166.4 333.9L201.3 269L225.4 297.8z\"\n ]\n};\nvar faPray = faPersonPraying;\nvar faPersonRunning = {\n prefix: 'fas',\n iconName: 'person-running',\n icon: [\n 448,\n 512,\n [\n 127939,\n \"running\"\n ],\n \"f70c\",\n \"M400 224h-44l-26.12-53.25c-12.5-25.5-35.38-44.25-61.75-51L197 98.63C189.5 96.84 181.1 95.97 174.5 95.97c-20.88 0-41.33 6.81-58.26 19.78L76.5 146.3C68.31 152.5 64.01 162 64.01 171.6c0 17.11 13.67 32.02 32.02 32.02c6.808 0 13.67-2.158 19.47-6.616l39.63-30.38c5.92-4.488 13.01-6.787 19.53-6.787c2.017 0 3.981 .2196 5.841 .6623l14.62 4.25l-37.5 87.5C154.1 260.3 152.5 268.8 152.5 277.2c0 22.09 11.49 43.52 31.51 55.29l85 50.13l-27.5 87.75c-.9875 3.174-1.458 6.388-1.458 9.55c0 13.65 8.757 26.31 22.46 30.58C265.6 511.5 268.9 512 272 512c13.62 0 26.25-8.75 30.5-22.5l31.75-101c1.211-4.278 1.796-8.625 1.796-12.93c0-16.57-8.661-32.51-23.55-41.44l-61.13-36.12l31.25-78.38l20.25 41.5C310.9 277.4 327.9 288 345.1 288H400c17.62 0 32-14.38 32-32C432 238.3 417.6 224 400 224zM288 96c26.5 0 48-21.5 48-48s-21.5-48-48-48s-48 21.5-48 48S261.5 96 288 96zM129.8 317.5L114.9 352H48c-17.62 0-32 14.38-32 32s14.38 32 32 32h77.5c19.25 0 36.5-11.5 44-29.12l8.875-20.5l-10.75-6.25C150.4 349.9 137.6 334.8 129.8 317.5z\"\n ]\n};\nvar faRunning = faPersonRunning;\nvar faPersonSkating = {\n prefix: 'fas',\n iconName: 'person-skating',\n icon: [\n 448,\n 512,\n [\n \"skating\"\n ],\n \"f7c5\",\n \"M399.1 0c-26.5 0-48.01 21.5-48.01 48S373.5 96 399.1 96C426.5 96 448 74.5 448 48S426.5 0 399.1 0zM399.1 448c-8.751 0-16 7.25-16 16S376.7 480 367.1 480h-96.01c-8.751 0-16 7.25-16 16s7.251 16 16 16h96.01c26.5 0 48.01-21.5 48.01-48C415.1 455.2 408.7 448 399.1 448zM129.1 451.9c-11.34 0-11.19 9.36-22.65 9.36c-4.074 0-8.163-1.516-11.21-4.625l-67.98-67.89c-3.063-3.125-7.165-4.688-11.27-4.688c-4.102 0-8.204 1.562-11.27 4.688C1.562 391.8-.0001 395.9-.0001 400s1.562 8.203 4.688 11.27l67.88 67.98c9.376 9.375 21.59 14 33.96 14c13.23 0 38.57-8.992 38.57-25.36C145.1 456.7 135.2 451.9 129.1 451.9zM173.8 276.8L80.2 370.5c-6.251 6.25-9.376 14.44-9.376 22.62c0 24.75 22.57 32 31.88 32c8.251 0 16.5-3.125 22.63-9.375l91.89-92l-30.13-30.12C182.1 288.6 177.7 282.9 173.8 276.8zM127.1 160h105.5L213.3 177.3c-21.18 18.04-22.31 41.73-22.31 48.65c0 16.93 6.8 33.22 18.68 45.1l78.26 78.25V432c0 17.75 14.25 32 32 32s32-14.25 32-32v-89.38c0-12.62-5.126-25-14.13-33.88l-61.01-61c.5001-.5 1.25-.625 1.75-1.125l82.26-82.38c7.703-7.702 11.76-17.87 11.76-28.25c0-22.04-17.86-39.97-40.01-39.97L127.1 96C110.2 96 95.96 110.2 95.96 128S110.2 160 127.1 160z\"\n ]\n};\nvar faSkating = faPersonSkating;\nvar faPersonSkiing = {\n prefix: 'fas',\n iconName: 'person-skiing',\n icon: [\n 512,\n 512,\n [\n 9975,\n \"skiing\"\n ],\n \"f7c9\",\n \"M432.1 96.02c26.51 0 47.99-21.5 47.99-48.01S458.6 0 432.1 0s-47.98 21.5-47.98 48.01S405.6 96.02 432.1 96.02zM511.1 469.1c0-13.98-11.33-23.95-23.89-23.95c-18.89 0-19.23 19.11-46.15 19.11c-5.476 0-10.87-1.081-15.87-3.389l-135.8-70.26l49.15-73.82c5.446-8.116 8.09-17.39 8.09-26.63c0-12.4-4.776-24.73-14.09-33.9l-40.38-40.49l-106.1-53.1C185.6 165.8 185.4 169 185.4 172.2c0 16.65 6.337 32.78 18.42 44.86l75.03 75.21l-45.88 68.76L34.97 258.8C31.44 257 27.64 256.1 23.93 256.1C9.675 256.1 0 267.8 0 280.1c0 8.673 4.735 17.04 12.96 21.24l392 202.6c11.88 5.501 24.45 8.119 37.08 8.119C480.1 512 511.1 486.7 511.1 469.1zM119.1 91.65L108.5 114.2C114.2 117 120.2 118.4 126.2 118.4c9.153 0 18.1-3.2 25.06-9.102l47.26 23.51c-.125 0-.125 .125-.2501 .25l114.5 56.76l32.51-13l6.376 19.13c4.001 12.13 12.63 22.01 24 27.76l58.14 28.1c4.609 2.287 9.455 3.355 14.26 3.355c18.8 0 31.98-15.43 31.98-31.93c0-11.74-6.461-23.1-17.74-28.7l-52.03-26.1l-17.12-51.15C386.6 98.69 364.2 73.99 333.1 73.99c-7.658 0-15.82 1.504-24.43 4.934L227.4 111.3L164.9 80.33c.009-.3461 .0134-.692 .0134-1.038c0-14.13-7.468-27.7-20.89-34.53L132.9 66.45L98.17 59.43C97.83 59.36 97.53 59.35 97.19 59.35c-2.666 0-5.276 2.177-5.276 5.273c0 1.473 .648 2.936 1.81 3.961L119.1 91.65z\"\n ]\n};\nvar faSkiing = faPersonSkiing;\nvar faPersonSkiingNordic = {\n prefix: 'fas',\n iconName: 'person-skiing-nordic',\n icon: [\n 576,\n 512,\n [\n \"skiing-nordic\"\n ],\n \"f7ca\",\n \"M336 96C362.5 96 384 74.5 384 48S362.5 0 336 0S288 21.5 288 48S309.5 96 336 96zM552 416c-13.25 0-24 10.75-24 24s-10.75 24-24 24h-69.5L460 285.6c11.75-4.75 20.04-16.31 20.04-29.69c0-17.75-14.38-31.95-32.01-31.95l-43.9-.0393l-26.11-53.22c-12.5-25.5-35.5-44.12-61.75-50.87l-71.22-21.15c-7.475-1.819-15.08-2.693-22.59-2.693c-20.86 0-41.25 6.854-58.16 19.72L124.6 146.2C116.3 152.5 111.1 161.1 111.1 171.6c0 14.71 8.712 21.23 9.031 21.6L66.88 464H24C10.75 464 0 474.8 0 488S10.75 512 24 512h480c39.75 0 72-32.25 72-72C576 426.8 565.3 416 552 416zM291.6 463.9H194.7l43.1-90.97l-21.99-12.1c-12.13-7.25-21.99-16.89-29.49-27.77l-62.48 131.7L99.5 464l52.25-261.4c4.125-1 8.112-2.846 11.74-5.596l39.81-30.45c5.821-4.485 12.86-6.771 19.38-6.771c2.021 0 4.015 .212 5.878 .6556l14.73 4.383L205.8 252.2C202.3 260.3 200.7 268.9 200.7 277.3c0 22.06 11.42 43.37 31.41 55.22l84.97 50.15L291.6 463.9zM402.1 464l-43.58-.125l23.6-75.48c1.221-4.314 1.805-8.69 1.805-13.03c0-16.53-8.558-32.43-23.41-41.34l-61.21-36.1l31.32-78.23l20.26 41.36c8 16.25 24.86 26.89 43.11 26.89L427.3 288L402.1 464z\"\n ]\n};\nvar faSkiingNordic = faPersonSkiingNordic;\nvar faPersonSnowboarding = {\n prefix: 'fas',\n iconName: 'person-snowboarding',\n icon: [\n 512,\n 512,\n [\n 127938,\n \"snowboarding\"\n ],\n \"f7ce\",\n \"M460.7 249.6c5.877 4.25 12.47 6.393 19.22 6.393c10.76 0 32.05-8.404 32.05-31.97c0-9.74-4.422-19.36-12.8-25.65l-111.5-83.48c-13.75-10.25-29.04-18.42-45.42-23.79l-63.66-21.23l-26.12-52.12c-5.589-11.17-16.9-17.64-28.63-17.64c-17.8 0-31.99 14.47-31.99 32.01c0 4.803 1.086 9.674 3.374 14.25l29.12 58.12c5.75 11.38 15.55 19.85 27.67 23.98l16.45 5.522L227.3 154.6C205.5 165.5 191.9 187.4 191.9 211.8L191.9 264.9L117.8 289.6C104.4 294.1 95.95 306.5 95.95 319.9c0 12.05 6.004 19.05 10.33 23.09l-38.68-14.14C41.23 319.4 49.11 295 23.97 295c-18.67 0-23.97 17.16-23.97 24.09c0 8.553 13.68 41.32 51.13 54.88l364.1 132.8C425.7 510.2 435.7 512 445.7 512c12.5 0 24.97-2.732 36.47-8.232c8.723-3.997 13.85-12.71 13.85-21.77c0-18.67-17.15-23.96-24.06-23.96c-3.375 0-6.73 .7505-9.998 2.248c-5.111 2.486-10.64 3.702-16.21 3.702c-4.511 0-9.049-.7978-13.41-2.364l-90.68-33.12c8.625-4.125 15.53-11.76 17.78-21.89l21.88-101.1c.7086-3.335 1.05-6.668 1.05-10c0-14.91-6.906-29.31-19.17-38.4l-52.01-39l66.01-30.5L460.7 249.6zM316.3 301.3l-19.66 92c-.4205 1.997-.5923 3.976-.5923 5.911c0 4.968 1.264 9.691 3.333 14.01l-169.5-61.49c2.625-.25 5.492-.4448 8.117-1.32l85-28.38c19.63-6.5 32.77-24.73 32.77-45.48l0-20.53L316.3 301.3zM431.9 95.99c26.5 0 48-21.5 48-47.1S458.4 0 431.9 0s-48 21.5-48 47.1S405.4 95.99 431.9 95.99z\"\n ]\n};\nvar faSnowboarding = faPersonSnowboarding;\nvar faPersonSwimming = {\n prefix: 'fas',\n iconName: 'person-swimming',\n icon: [\n 576,\n 512,\n [\n 127946,\n \"swimmer\"\n ],\n \"f5c4\",\n \"M192.4 320c63.38 0 54.09-39.67 95.33-40.02c42.54 .3672 31.81 40.02 95.91 40.02c39.27 0 55.72-18.41 62.21-24.83l-140.4-116.1c3.292-1.689 31.66-18.2 75.25-18.2c12.57 0 25.18 1.397 37.53 4.21l38.59 8.844c2.412 .5592 4.824 .8272 7.2 .8272c15.91 0 31.96-12.81 31.96-32.04c0-14.58-10.03-27.77-24.84-31.16l-38.59-8.844c-17.06-3.904-34.46-5.837-51.81-5.837c-120.1 0-177.4 85.87-178.1 88.02L179.1 213.3C158.1 241.3 147.4 273.8 145 307.7C157.5 315.4 174.3 320 192.4 320zM576 397c0-15.14-10.82-28.59-26.25-31.42c-48.52-8.888-45.5-29.48-69.6-29.48c-25.02 0-31.19 31.79-96.18 31.79c-48.59 0-72.72-22.06-73.38-22.62c-6.141-6.157-14.26-9.188-22.42-9.188c-24.75 0-31.59 31.81-96.2 31.81c-48.59 0-72.69-22.03-73.41-22.59c-6.125-6.157-14.3-9.245-22.46-9.245c-8.072 0-16.12 3.026-22.38 8.901c-29.01 26.25-73.75 12.54-73.75 52.08c0 16.08 12.77 32.07 31.71 32.07c9.77 0 39.65-7.34 64.26-21.84C115.5 418.8 147.4 431.1 192 431.1s76.5-13.12 96-24.66c19.53 11.53 51.47 24.59 96 24.59c44.59 0 76.56-13.09 96.06-24.62c24.71 14.57 54.74 21.83 64.24 21.83C563.2 429.1 576 413.3 576 397zM95.1 224c35.35 0 64-28.65 64-64c0-35.35-28.65-64-64-64s-64 28.65-64 64C31.1 195.3 60.65 224 95.1 224z\"\n ]\n};\nvar faSwimmer = faPersonSwimming;\nvar faPersonWalking = {\n prefix: 'fas',\n iconName: 'person-walking',\n icon: [\n 320,\n 512,\n [\n 128694,\n \"walking\"\n ],\n \"f554\",\n \"M207.9 95.99c26.5 0 47.1-21.49 47.1-47.99S234.4 0 207.9 0S159.1 21.49 159.1 47.99S181.4 95.99 207.9 95.99zM73.61 385.7c-3.25 8.125-7.998 15.5-14.25 21.49l-49.99 50.12c-6.249 6.246-9.373 14.46-9.373 22.68C-.0003 505.1 22.93 512 31.99 512c8.186 0 16.37-3.125 22.62-9.375l59.36-59.48c6.125-6 10.87-13.37 14.25-21.49l13.5-33.74c-55.36-60.23-38.74-41.74-47.49-53.74L73.61 385.7zM320 273.9c0-11.77-6.392-23.15-17.57-28.74l-23.24-11.88L269.4 203.9c-5.552-16.8-33.04-75.89-102.9-75.89c-35.58 0-55.44 10.22-92.58 25.26C52.36 161.9 34.74 178.4 24.24 199.4L17.62 213C15.33 217.6 14.24 222.5 14.24 227.3c0 17.25 13.78 31.97 31.63 31.97c11.6 0 22.78-6.455 28.37-17.63l6.748-13.62c3.5-7 9.248-12.5 16.5-15.38L124.2 201.8L109.1 262.5C107.8 267.6 107.2 272.9 107.2 278c0 15.79 5.886 31.29 16.8 43.24l59.86 65.51c7.25 7.875 12.37 17.38 14.87 27.62l18.37 73.39c3.609 14.45 16.69 24.2 31.04 24.2c19.31 0 32.01-16.13 32.01-32.05c0-2.531-.3053-5.097-.9435-7.652l-22.25-89.01c-2.625-10.38-7.748-20.01-14.87-27.76l-45.49-49.76l17.12-68.63l5.498 16.5c5.375 16.13 16.75 29.38 31.74 37.01l23.24 11.75c4.543 2.29 9.371 3.375 14.13 3.375C304.8 305.8 320 292.5 320 273.9z\"\n ]\n};\nvar faWalking = faPersonWalking;\nvar faPersonWalkingWithCane = {\n prefix: 'fas',\n iconName: 'person-walking-with-cane',\n icon: [\n 448,\n 512,\n [\n \"blind\"\n ],\n \"f29d\",\n \"M445.2 486.1l-117.3-172.6c-3.002 4.529-6.646 8.652-11.12 12c-4.414 3.318-9.299 5.689-14.43 7.307l116.4 171.3c3.094 4.547 8.127 7.008 13.22 7.008c3.125 0 6.247-.8984 8.997-2.773C448.3 504.2 450.2 494.3 445.2 486.1zM143.1 95.1c26.51 0 48.01-21.49 48.01-47.1S170.5 0 144 0S96 21.49 96 48S117.5 95.1 143.1 95.1zM96.01 348.1l-31.03 124.2c-4.312 17.16 6.125 34.53 23.28 38.81C90.86 511.7 93.48 512 96.04 512c14.34 0 27.38-9.703 31-24.23l22.04-88.18L96.01 346.5V348.1zM313.6 268.8l-76.78-102.4C218.8 142.3 190.1 128 160 128L135.6 127.1c-36.59 0-69.5 20.33-85.87 53.06L3.387 273.7C-4.518 289.5 1.887 308.7 17.7 316.6c4.594 2.297 9.469 3.375 14.28 3.375c11.75 0 23.03-6.469 28.66-17.69l35.38-70.76v56.45c0 8.484 3.375 16.62 9.375 22.63l86.63 86.63v82.75c0 17.67 14.31 32 32 32c17.69 0 32-14.33 32-32v-82.75c0-17.09-6.656-33.16-18.75-45.25L192 306.8V213.3l70.38 93.88c10.59 14.11 30.62 16.98 44.78 6.406C321.3 303 324.2 282.9 313.6 268.8z\"\n ]\n};\nvar faBlind = faPersonWalkingWithCane;\nvar faPesetaSign = {\n prefix: 'fas',\n iconName: 'peseta-sign',\n icon: [\n 384,\n 512,\n [],\n \"e221\",\n \"M192 32C269.4 32 333.1 86.97 348.8 160H352C369.7 160 384 174.3 384 192C384 209.7 369.7 224 352 224H348.8C333.1 297 269.4 352 192 352H96V448C96 465.7 81.67 480 64 480C46.33 480 32 465.7 32 448V224C14.33 224 0 209.7 0 192C0 174.3 14.33 160 32 160V64C32 46.33 46.33 32 64 32H192zM282.5 160C269.4 122.7 233.8 96 192 96H96V160H282.5zM96 224V288H192C233.8 288 269.4 261.3 282.5 224H96z\"\n ]\n};\nvar faPesoSign = {\n prefix: 'fas',\n iconName: 'peso-sign',\n icon: [\n 384,\n 512,\n [],\n \"e222\",\n \"M176 32C244.4 32 303.7 71.01 332.8 128H352C369.7 128 384 142.3 384 160C384 177.7 369.7 192 352 192H351.3C351.8 197.3 352 202.6 352 208C352 213.4 351.8 218.7 351.3 224H352C369.7 224 384 238.3 384 256C384 273.7 369.7 288 352 288H332.8C303.7 344.1 244.4 384 176 384H96V448C96 465.7 81.67 480 64 480C46.33 480 32 465.7 32 448V288C14.33 288 0 273.7 0 256C0 238.3 14.33 224 32 224V192C14.33 192 0 177.7 0 160C0 142.3 14.33 128 32 128V64C32 46.33 46.33 32 64 32H176zM254.4 128C234.2 108.2 206.5 96 176 96H96V128H254.4zM96 192V224H286.9C287.6 218.8 288 213.4 288 208C288 202.6 287.6 197.2 286.9 192H96zM254.4 288H96V320H176C206.5 320 234.2 307.8 254.4 288z\"\n ]\n};\nvar faPhone = {\n prefix: 'fas',\n iconName: 'phone',\n icon: [\n 512,\n 512,\n [\n 128379,\n 128222\n ],\n \"f095\",\n \"M511.2 387l-23.25 100.8c-3.266 14.25-15.79 24.22-30.46 24.22C205.2 512 0 306.8 0 54.5c0-14.66 9.969-27.2 24.22-30.45l100.8-23.25C139.7-2.602 154.7 5.018 160.8 18.92l46.52 108.5c5.438 12.78 1.77 27.67-8.98 36.45L144.5 207.1c33.98 69.22 90.26 125.5 159.5 159.5l44.08-53.8c8.688-10.78 23.69-14.51 36.47-8.975l108.5 46.51C506.1 357.2 514.6 372.4 511.2 387z\"\n ]\n};\nvar faPhoneFlip = {\n prefix: 'fas',\n iconName: 'phone-flip',\n icon: [\n 512,\n 512,\n [\n 128381,\n \"phone-alt\"\n ],\n \"f879\",\n \"M18.92 351.2l108.5-46.52c12.78-5.531 27.77-1.801 36.45 8.98l44.09 53.82c69.25-34 125.5-90.31 159.5-159.5l-53.81-44.04c-10.75-8.781-14.41-23.69-8.974-36.47l46.51-108.5c6.094-13.91 21.1-21.52 35.79-18.11l100.8 23.25c14.25 3.25 24.22 15.8 24.22 30.46c0 252.3-205.2 457.5-457.5 457.5c-14.67 0-27.18-9.968-30.45-24.22l-23.25-100.8C-2.571 372.4 5.018 357.2 18.92 351.2z\"\n ]\n};\nvar faPhoneAlt = faPhoneFlip;\nvar faPhoneSlash = {\n prefix: 'fas',\n iconName: 'phone-slash',\n icon: [\n 640,\n 512,\n [],\n \"f3dd\",\n \"M271.1 367.5L227.9 313.7c-8.688-10.78-23.69-14.51-36.47-8.974l-108.5 46.51c-13.91 6-21.49 21.19-18.11 35.79l23.25 100.8C91.32 502 103.8 512 118.5 512c107.4 0 206.1-37.46 284.2-99.65l-88.75-69.56C300.6 351.9 286.6 360.3 271.1 367.5zM630.8 469.1l-159.6-125.1c65.03-78.97 104.7-179.5 104.7-289.5c0-14.66-9.969-27.2-24.22-30.45L451 .8125c-14.69-3.406-29.73 4.213-35.82 18.12l-46.52 108.5c-5.438 12.78-1.771 27.67 8.979 36.45l53.82 44.08C419.2 232.1 403.9 256.2 386.2 277.4L38.81 5.111C34.41 1.673 29.19 0 24.03 0C16.91 0 9.84 3.158 5.121 9.189c-8.188 10.44-6.37 25.53 4.068 33.7l591.1 463.1c10.5 8.203 25.57 6.328 33.69-4.078C643.1 492.4 641.2 477.3 630.8 469.1z\"\n ]\n};\nvar faPhoneVolume = {\n prefix: 'fas',\n iconName: 'phone-volume',\n icon: [\n 512,\n 512,\n [\n \"volume-control-phone\"\n ],\n \"f2a0\",\n \"M284.6 181.9c-10.28-8.344-25.41-6.875-33.75 3.406C242.4 195.6 243.9 210.7 254.2 219.1c11.31 9.25 17.81 22.69 17.81 36.87c0 14.19-6.5 27.62-17.81 36.87c-10.28 8.406-11.78 23.53-3.375 33.78c4.719 5.812 11.62 8.812 18.56 8.812c5.344 0 10.75-1.781 15.19-5.406c22.53-18.44 35.44-45.4 35.44-74.05S307.1 200.4 284.6 181.9zM345.1 107.1c-10.22-8.344-25.34-6.907-33.78 3.343c-8.406 10.25-6.906 25.37 3.344 33.78c33.88 27.78 53.31 68.18 53.31 110.9s-19.44 83.09-53.31 110.9c-10.25 8.406-11.75 23.53-3.344 33.78c4.75 5.781 11.62 8.781 18.56 8.781c5.375 0 10.75-1.781 15.22-5.438C390.2 367.1 416 313.1 416 255.1S390.2 144.9 345.1 107.1zM406.4 33.15c-10.22-8.344-25.34-6.875-33.78 3.344c-8.406 10.25-6.906 25.37 3.344 33.78C431.9 116.1 464 183.8 464 255.1s-32.09 139.9-88.06 185.7c-10.25 8.406-11.75 23.53-3.344 33.78c4.75 5.781 11.62 8.781 18.56 8.781c5.375 0 10.75-1.781 15.22-5.438C473.5 423.8 512 342.6 512 255.1S473.5 88.15 406.4 33.15zM151.3 174.6C161.1 175.6 172.1 169.5 176 159.6l33.75-84.38C214 64.35 209.1 51.1 200.2 45.86l-67.47-42.17C123.2-2.289 110.9-.8945 102.9 7.08C-34.32 144.3-34.31 367.7 102.9 504.9c7.982 7.984 20.22 9.379 29.75 3.402l67.48-42.19c9.775-6.104 13.9-18.47 9.598-29.3L176 352.5c-3.945-9.963-14.14-16.11-24.73-14.97l-53.24 5.314C78.89 286.7 78.89 225.4 98.06 169.3L151.3 174.6z\"\n ]\n};\nvar faVolumeControlPhone = faPhoneVolume;\nvar faPhotoFilm = {\n prefix: 'fas',\n iconName: 'photo-film',\n icon: [\n 640,\n 512,\n [\n \"photo-video\"\n ],\n \"f87c\",\n \"M352 432c0 8.836-7.164 16-16 16H176c-8.838 0-16-7.164-16-16L160 128H48C21.49 128 .0003 149.5 .0003 176v288c0 26.51 21.49 48 48 48h416c26.51 0 48-21.49 48-48L512 384h-160L352 432zM104 439c0 4.969-4.031 9-9 9h-30c-4.969 0-9-4.031-9-9v-30c0-4.969 4.031-9 9-9h30c4.969 0 9 4.031 9 9V439zM104 335c0 4.969-4.031 9-9 9h-30c-4.969 0-9-4.031-9-9v-30c0-4.969 4.031-9 9-9h30c4.969 0 9 4.031 9 9V335zM104 231c0 4.969-4.031 9-9 9h-30c-4.969 0-9-4.031-9-9v-30C56 196 60.03 192 65 192h30c4.969 0 9 4.031 9 9V231zM408 409c0-4.969 4.031-9 9-9h30c4.969 0 9 4.031 9 9v30c0 4.969-4.031 9-9 9h-30c-4.969 0-9-4.031-9-9V409zM591.1 0H239.1C213.5 0 191.1 21.49 191.1 48v256c0 26.51 21.49 48 48 48h352c26.51 0 48-21.49 48-48v-256C640 21.49 618.5 0 591.1 0zM303.1 64c17.68 0 32 14.33 32 32s-14.32 32-32 32C286.3 128 271.1 113.7 271.1 96S286.3 64 303.1 64zM574.1 279.6C571.3 284.8 565.9 288 560 288H271.1C265.1 288 260.5 284.6 257.7 279.3C255 273.9 255.5 267.4 259.1 262.6l70-96C332.1 162.4 336.9 160 341.1 160c5.11 0 9.914 2.441 12.93 6.574l22.35 30.66l62.74-94.11C442.1 98.67 447.1 96 453.3 96c5.348 0 10.34 2.672 13.31 7.125l106.7 160C576.6 268 576.9 274.3 574.1 279.6z\"\n ]\n};\nvar faPhotoVideo = faPhotoFilm;\nvar faPiggyBank = {\n prefix: 'fas',\n iconName: 'piggy-bank',\n icon: [\n 576,\n 512,\n [],\n \"f4d3\",\n \"M400 96L399.1 96.66C394.7 96.22 389.4 96 384 96H256C239.5 96 223.5 98.08 208.2 102C208.1 100 208 98.02 208 96C208 42.98 250.1 0 304 0C357 0 400 42.98 400 96zM384 128C387.5 128 390.1 128.1 394.4 128.3C398.7 128.6 402.9 129 407 129.6C424.6 109.1 450.8 96 480 96H512L493.2 171.1C509.1 185.9 521.9 203.9 530.7 224H544C561.7 224 576 238.3 576 256V352C576 369.7 561.7 384 544 384H512C502.9 396.1 492.1 406.9 480 416V480C480 497.7 465.7 512 448 512H416C398.3 512 384 497.7 384 480V448H256V480C256 497.7 241.7 512 224 512H192C174.3 512 160 497.7 160 480V416C125.1 389.8 101.3 349.8 96.79 304H68C30.44 304 0 273.6 0 236C0 198.4 30.44 168 68 168H72C85.25 168 96 178.7 96 192C96 205.3 85.25 216 72 216H68C56.95 216 48 224.1 48 236C48 247 56.95 256 68 256H99.2C111.3 196.2 156.9 148.5 215.5 133.2C228.4 129.8 241.1 128 256 128H384zM424 240C410.7 240 400 250.7 400 264C400 277.3 410.7 288 424 288C437.3 288 448 277.3 448 264C448 250.7 437.3 240 424 240z\"\n ]\n};\nvar faPills = {\n prefix: 'fas',\n iconName: 'pills',\n icon: [\n 576,\n 512,\n [],\n \"f484\",\n \"M112 32C50.12 32 0 82.12 0 143.1v223.1c0 61.88 50.12 111.1 112 111.1s112-50.12 112-111.1V143.1C224 82.12 173.9 32 112 32zM160 256H64V144c0-26.5 21.5-48 48-48s48 21.5 48 48V256zM299.8 226.2c-3.5-3.5-9.5-3-12.38 .875c-45.25 62.5-40.38 150.1 15.88 206.4c56.38 56.25 144 61.25 206.5 15.88c4-2.875 4.249-8.75 .75-12.25L299.8 226.2zM529.5 207.2c-56.25-56.25-143.9-61.13-206.4-15.87c-4 2.875-4.375 8.875-.875 12.38l210.9 210.7c3.5 3.5 9.375 3.125 12.25-.75C590.8 351.1 585.9 263.6 529.5 207.2z\"\n ]\n};\nvar faPizzaSlice = {\n prefix: 'fas',\n iconName: 'pizza-slice',\n icon: [\n 512,\n 512,\n [],\n \"f818\",\n \"M100.4 112.3L.5101 491.7c-1.375 5.625 .1622 11.6 4.287 15.6c4.127 4.125 10.13 5.744 15.63 4.119l379.1-105.1C395.3 231.4 276.5 114.1 100.4 112.3zM127.1 416c-17.62 0-32-14.38-32-31.1c0-17.62 14.39-32 32.01-32c17.63 0 32 14.38 32 31.1C160 401.6 145.6 416 127.1 416zM175.1 271.1c-17.63 0-32-14.38-32-32c0-17.62 14.38-31.1 32-31.1c17.62 0 32 14.38 32 31.1C208 257.6 193.6 271.1 175.1 271.1zM272 367.1c-17.62 0-32-14.38-32-31.1c0-17.62 14.38-32 32-32c17.63 0 32 14.38 32 32C304 353.6 289.6 367.1 272 367.1zM158.9 .1406c-16.13-1.5-31.25 8.501-35.38 24.12L108.7 80.52c187.6 5.5 314.5 130.6 322.5 316.1l56.88-15.75c15.75-4.375 25.5-19.62 23.63-35.87C490.9 165.1 340.8 17.39 158.9 .1406z\"\n ]\n};\nvar faPlaceOfWorship = {\n prefix: 'fas',\n iconName: 'place-of-worship',\n icon: [\n 640,\n 512,\n [],\n \"f67f\",\n \"M233.4 86.63L308.7 11.32C314.9 5.067 325.1 5.067 331.3 11.32L406.6 86.63C412.6 92.63 416 100.8 416 109.3V217.6L456.7 242C471.2 250.7 480 266.3 480 283.2V512H384V416C384 380.7 355.3 352 319.1 352C284.7 352 255.1 380.7 255.1 416V512H159.1V283.2C159.1 266.3 168.8 250.7 183.3 242L223.1 217.6V109.3C223.1 100.8 227.4 92.63 233.4 86.63H233.4zM24.87 330.3L128 273.6V512H48C21.49 512 0 490.5 0 464V372.4C0 354.9 9.53 338.8 24.87 330.3V330.3zM592 512H512V273.6L615.1 330.3C630.5 338.8 640 354.9 640 372.4V464C640 490.5 618.5 512 592 512V512z\"\n ]\n};\nvar faPlane = {\n prefix: 'fas',\n iconName: 'plane',\n icon: [\n 576,\n 512,\n [],\n \"f072\",\n \"M482.3 192C516.5 192 576 221 576 256C576 292 516.5 320 482.3 320H365.7L265.2 495.9C259.5 505.8 248.9 512 237.4 512H181.2C170.6 512 162.9 501.8 165.8 491.6L214.9 320H112L68.8 377.6C65.78 381.6 61.04 384 56 384H14.03C6.284 384 0 377.7 0 369.1C0 368.7 .1818 367.4 .5398 366.1L32 256L.5398 145.9C.1818 144.6 0 143.3 0 142C0 134.3 6.284 128 14.03 128H56C61.04 128 65.78 130.4 68.8 134.4L112 192H214.9L165.8 20.4C162.9 10.17 170.6 0 181.2 0H237.4C248.9 0 259.5 6.153 265.2 16.12L365.7 192H482.3z\"\n ]\n};\nvar faPlaneArrival = {\n prefix: 'fas',\n iconName: 'plane-arrival',\n icon: [\n 640,\n 512,\n [\n 128748\n ],\n \"f5af\",\n \"M.2528 166.9L.0426 67.99C.0208 57.74 9.508 50.11 19.51 52.34L55.07 60.24C65.63 62.58 74.29 70.11 78.09 80.24L95.1 127.1L223.3 165.6L181.8 20.4C178.9 10.18 186.6 .001 197.2 .001H237.3C248.8 .001 259.5 6.236 265.2 16.31L374.2 210.2L481.5 241.8C497.4 246.5 512.2 254.3 525.2 264.7L559.6 292.2C583.7 311.4 577.7 349.5 548.9 360.5C507.7 376.1 462.7 378.5 420.1 367.4L121.7 289.8C110.6 286.9 100.5 281.1 92.4 272.9L9.536 189.4C3.606 183.4 .2707 175.3 .2528 166.9V166.9zM608 448C625.7 448 640 462.3 640 480C640 497.7 625.7 512 608 512H32C14.33 512 0 497.7 0 480C0 462.3 14.33 448 32 448H608zM192 368C192 385.7 177.7 400 160 400C142.3 400 128 385.7 128 368C128 350.3 142.3 336 160 336C177.7 336 192 350.3 192 368zM224 384C224 366.3 238.3 352 256 352C273.7 352 288 366.3 288 384C288 401.7 273.7 416 256 416C238.3 416 224 401.7 224 384z\"\n ]\n};\nvar faPlaneDeparture = {\n prefix: 'fas',\n iconName: 'plane-departure',\n icon: [\n 640,\n 512,\n [\n 128747\n ],\n \"f5b0\",\n \"M484.6 62C502.6 52.8 522.6 48 542.8 48H600.2C627.2 48 645.9 74.95 636.4 100.2C618.2 148.9 582.1 188.9 535.6 212.2L262.8 348.6C258.3 350.8 253.4 352 248.4 352H110.7C101.4 352 92.5 347.9 86.42 340.8L13.34 255.6C6.562 247.7 9.019 235.5 18.33 230.8L50.49 214.8C59.05 210.5 69.06 210.2 77.8 214.1L135.1 239.1L234.6 189.7L87.64 95.2C77.21 88.49 78.05 72.98 89.14 67.43L135 44.48C150.1 36.52 169.5 35.55 186.1 41.8L381 114.9L484.6 62zM0 480C0 462.3 14.33 448 32 448H608C625.7 448 640 462.3 640 480C640 497.7 625.7 512 608 512H32C14.33 512 0 497.7 0 480z\"\n ]\n};\nvar faPlaneSlash = {\n prefix: 'fas',\n iconName: 'plane-slash',\n icon: [\n 640,\n 512,\n [],\n \"e069\",\n \"M238.1 161.3L197.8 20.4C194.9 10.17 202.6-.0001 213.2-.0001H269.4C280.9-.0001 291.5 6.153 297.2 16.12L397.7 192H514.3C548.5 192 608 221 608 256C608 292 548.5 320 514.3 320H440.6L630.8 469.1C641.2 477.3 643.1 492.4 634.9 502.8C626.7 513.2 611.6 515.1 601.2 506.9L9.196 42.89C-1.236 34.71-3.065 19.63 5.112 9.196C13.29-1.237 28.37-3.065 38.81 5.112L238.1 161.3zM41.54 128.7L362.5 381.6L297.2 495.9C291.5 505.8 280.9 512 269.4 512H213.2C202.6 512 194.9 501.8 197.8 491.6L246.9 319.1H144L100.8 377.6C97.78 381.6 93.04 384 88 384H46.03C38.28 384 32 377.7 32 369.1C32 368.7 32.18 367.4 32.54 366.1L64 255.1L32.54 145.9C32.18 144.6 32 143.3 32 142C32 135.9 35.1 130.6 41.54 128.7V128.7z\"\n ]\n};\nvar faPlay = {\n prefix: 'fas',\n iconName: 'play',\n icon: [\n 384,\n 512,\n [\n 9654\n ],\n \"f04b\",\n \"M361 215C375.3 223.8 384 239.3 384 256C384 272.7 375.3 288.2 361 296.1L73.03 472.1C58.21 482 39.66 482.4 24.52 473.9C9.377 465.4 0 449.4 0 432V80C0 62.64 9.377 46.63 24.52 38.13C39.66 29.64 58.21 29.99 73.03 39.04L361 215z\"\n ]\n};\nvar faPlug = {\n prefix: 'fas',\n iconName: 'plug',\n icon: [\n 384,\n 512,\n [\n 128268\n ],\n \"f1e6\",\n \"M320 32c0-17.62-14.38-32-32-32s-32 14.38-32 32v96h64V32zM368 159.1h-352c-8.875 0-16 7.125-16 16v32c0 8.875 7.125 16 16 16H32V256c0 76 53.5 141.6 128 156.8V512h64v-99.25C298.5 397.6 352 332 352 256V223.1h16c8.875 0 16-7.125 16-16v-32C384 167.1 376.9 159.1 368 159.1zM128 32c0-17.62-14.38-32-32-32S64 14.38 64 32v96h64V32z\"\n ]\n};\nvar faPlus = {\n prefix: 'fas',\n iconName: 'plus',\n icon: [\n 448,\n 512,\n [\n 10133,\n 61543,\n \"add\"\n ],\n \"2b\",\n \"M432 256c0 17.69-14.33 32.01-32 32.01H256v144c0 17.69-14.33 31.99-32 31.99s-32-14.3-32-31.99v-144H48c-17.67 0-32-14.32-32-32.01s14.33-31.99 32-31.99H192v-144c0-17.69 14.33-32.01 32-32.01s32 14.32 32 32.01v144h144C417.7 224 432 238.3 432 256z\"\n ]\n};\nvar faAdd = faPlus;\nvar faPlusMinus = {\n prefix: 'fas',\n iconName: 'plus-minus',\n icon: [\n 384,\n 512,\n [],\n \"e43c\",\n \"M352 448H32c-17.69 0-32 14.31-32 32s14.31 31.1 32 31.1h320c17.69 0 32-14.31 32-31.1S369.7 448 352 448zM48 208H160v111.1c0 17.69 14.31 31.1 32 31.1s32-14.31 32-31.1V208h112c17.69 0 32-14.32 32-32.01s-14.31-31.99-32-31.99H224v-112c0-17.69-14.31-32.01-32-32.01S160 14.33 160 32.01v112H48c-17.69 0-32 14.31-32 31.99S30.31 208 48 208z\"\n ]\n};\nvar faPodcast = {\n prefix: 'fas',\n iconName: 'podcast',\n icon: [\n 448,\n 512,\n [],\n \"f2ce\",\n \"M224 0C100.3 0 0 100.3 0 224c0 92.22 55.77 171.4 135.4 205.7c-3.48-20.75-6.17-41.59-6.998-58.15C80.08 340.1 48 285.8 48 224c0-97.05 78.95-176 176-176s176 78.95 176 176c0 61.79-32.08 116.1-80.39 147.6c-.834 16.5-3.541 37.37-7.035 58.17C392.2 395.4 448 316.2 448 224C448 100.3 347.7 0 224 0zM224 312c-32.88 0-64 8.625-64 43.75c0 33.13 12.88 104.3 20.62 132.8C185.8 507.6 205.1 512 224 512s38.25-4.375 43.38-23.38C275.1 459.9 288 388.8 288 355.8C288 320.6 256.9 312 224 312zM224 280c30.95 0 56-25.05 56-56S254.1 168 224 168S168 193 168 224S193 280 224 280zM368 224c0-79.53-64.47-144-144-144S80 144.5 80 224c0 44.83 20.92 84.38 53.04 110.8c4.857-12.65 14.13-25.88 32.05-35.04C165.1 299.7 165.4 299.7 165.6 299.7C142.9 282.1 128 254.9 128 224c0-53.02 42.98-96 96-96s96 42.98 96 96c0 30.92-14.87 58.13-37.57 75.68c.1309 .0254 .5078 .0488 .4746 .0742c17.93 9.16 27.19 22.38 32.05 35.04C347.1 308.4 368 268.8 368 224z\"\n ]\n};\nvar faPoo = {\n prefix: 'fas',\n iconName: 'poo',\n icon: [\n 512,\n 512,\n [\n 128169\n ],\n \"f2fe\",\n \"M451.4 369.1C468.8 356 480 335.4 480 312c0-39.75-32.25-72-72-72h-14.12C407.3 228.2 416 211.2 416 191.1c0-35.25-28.75-63.1-64-63.1h-5.875C349.8 117.9 352 107.2 352 95.1c0-53-43-96-96-96c-5.25 0-10.25 .75-15.12 1.5C250.3 14.62 256 30.62 256 47.1c0 44.25-35.75 80-80 80H160c-35.25 0-64 28.75-64 63.1c0 19.25 8.75 36.25 22.12 48H104C64.25 239.1 32 272.3 32 312c0 23.38 11.25 44 28.62 57.13C26.25 374.6 0 404.1 0 440C0 479.8 32.25 512 72 512h368c39.75 0 72-32.25 72-72C512 404.1 485.8 374.6 451.4 369.1zM192 256c17.75 0 32 14.25 32 32s-14.25 32-32 32S160 305.8 160 288S174.3 256 192 256zM351.5 395C340.1 422.9 292.1 448 256 448c-36.99 0-84.98-25.12-95.48-53C158.5 389.8 162.5 384 168.3 384h175.5C349.5 384 353.5 389.8 351.5 395zM320 320c-17.75 0-32-14.25-32-32s14.25-32 32-32s32 14.25 32 32S337.8 320 320 320z\"\n ]\n};\nvar faPooStorm = {\n prefix: 'fas',\n iconName: 'poo-storm',\n icon: [\n 448,\n 512,\n [\n \"poo-bolt\"\n ],\n \"f75a\",\n \"M304 368H248.3l38.45-89.7c2.938-6.859 .7187-14.84-5.312-19.23c-6.096-4.422-14.35-4.031-19.94 .8906l-128 111.1c-5.033 4.391-6.783 11.44-4.439 17.67c2.346 6.25 8.314 10.38 14.97 10.38H199.7l-38.45 89.7c-2.938 6.859-.7187 14.84 5.312 19.23C169.4 510.1 172.7 512 175.1 512c3.781 0 7.531-1.328 10.53-3.953l128-111.1c5.033-4.391 6.783-11.44 4.439-17.67C316.6 372.1 310.7 368 304 368zM373.3 226.6C379.9 216.6 384 204.9 384 192c0-35.38-28.62-64-64-64h-5.875C317.8 118 320 107.3 320 96c0-53-43-96-96-96C218.9 0 213.9 .75 208.9 1.5C218.3 14.62 224 30.62 224 48C224 92.13 188.1 128 144 128H128C92.63 128 64 156.6 64 192c0 12.88 4.117 24.58 10.72 34.55C31.98 236.3 0 274.3 0 320c0 53.02 42.98 96 96 96h12.79c-4.033-4.414-7.543-9.318-9.711-15.1c-7.01-18.64-1.645-39.96 13.32-53.02l127.9-111.9C249.1 228.2 260.3 223.1 271.1 224c10.19 0 19.95 3.174 28.26 9.203c18.23 13.27 24.76 36.1 15.89 57.71l-19.33 45.1h7.195c19.89 0 37.95 12.51 44.92 31.11C355.3 384 351 402.8 339.1 416H352c53.02 0 96-42.98 96-96C448 274.3 416 236.3 373.3 226.6z\"\n ]\n};\nvar faPooBolt = faPooStorm;\nvar faPoop = {\n prefix: 'fas',\n iconName: 'poop',\n icon: [\n 512,\n 512,\n [],\n \"f619\",\n \"M512 440.1C512 479.9 479.7 512 439.1 512H71.92C32.17 512 0 479.8 0 440c0-35.88 26.19-65.35 60.56-70.85C43.31 356 32 335.4 32 312C32 272.2 64.25 240 104 240h13.99C104.5 228.2 96 211.2 96 192c0-35.38 28.56-64 63.94-64h16C220.1 128 256 92.12 256 48c0-17.38-5.784-33.35-15.16-46.47C245.8 .7754 250.9 0 256 0c53 0 96 43 96 96c0 11.25-2.288 22-5.913 32h5.879C387.3 128 416 156.6 416 192c0 19.25-8.59 36.25-22.09 48H408C447.8 240 480 272.2 480 312c0 23.38-11.38 44.01-28.63 57.14C485.7 374.6 512 404.3 512 440.1z\"\n ]\n};\nvar faPowerOff = {\n prefix: 'fas',\n iconName: 'power-off',\n icon: [\n 512,\n 512,\n [\n 9211\n ],\n \"f011\",\n \"M288 256C288 273.7 273.7 288 256 288C238.3 288 224 273.7 224 256V32C224 14.33 238.3 0 256 0C273.7 0 288 14.33 288 32V256zM80 256C80 353.2 158.8 432 256 432C353.2 432 432 353.2 432 256C432 201.6 407.3 152.9 368.5 120.6C354.9 109.3 353 89.13 364.3 75.54C375.6 61.95 395.8 60.1 409.4 71.4C462.2 115.4 496 181.8 496 255.1C496 388.5 388.5 496 256 496C123.5 496 16 388.5 16 255.1C16 181.8 49.75 115.4 102.6 71.4C116.2 60.1 136.4 61.95 147.7 75.54C158.1 89.13 157.1 109.3 143.5 120.6C104.7 152.9 80 201.6 80 256z\"\n ]\n};\nvar faPrescription = {\n prefix: 'fas',\n iconName: 'prescription',\n icon: [\n 448,\n 512,\n [],\n \"f5b1\",\n \"M440.1 448.4l-96.28-96.21l95.87-95.95c9.373-9.381 9.373-24.59 0-33.97l-22.62-22.64c-9.373-9.381-24.57-9.381-33.94 0L288.1 295.6L220.5 228c46.86-22.92 76.74-75.46 64.95-133.1C273.9 38.74 221.8 0 164.6 0H31.1C14.33 0 0 14.34 0 32.03v264.1c0 13.26 10.75 24.01 23.1 24.01l31.1 .085c13.25 0 23.1-10.75 23.1-24.02V240.2H119.4l112.1 112L135.4 448.4c-9.373 9.381-9.373 24.59 0 33.97l22.62 22.64c9.373 9.38 24.57 9.38 33.94 0l96.13-96.21l96.28 96.21c9.373 9.381 24.57 9.381 33.94 0l22.62-22.64C450.3 472.9 450.3 457.7 440.1 448.4zM79.1 80.06h87.1c22.06 0 39.1 17.95 39.1 40.03s-17.94 40.03-39.1 40.03H79.1V80.06z\"\n ]\n};\nvar faPrescriptionBottle = {\n prefix: 'fas',\n iconName: 'prescription-bottle',\n icon: [\n 384,\n 512,\n [],\n \"f485\",\n \"M32 192h112C152.8 192 160 199.2 160 208C160 216.8 152.8 224 144 224H32v64h112C152.8 288 160 295.2 160 304C160 312.8 152.8 320 144 320H32v64h112C152.8 384 160 391.2 160 400C160 408.8 152.8 416 144 416H32v32c0 35.2 28.8 64 64 64h192c35.2 0 64-28.8 64-64V128H32V192zM360 0H24C10.75 0 0 10.75 0 24v48C0 85.25 10.75 96 24 96h336C373.3 96 384 85.25 384 72v-48C384 10.75 373.3 0 360 0z\"\n ]\n};\nvar faPrescriptionBottleMedical = {\n prefix: 'fas',\n iconName: 'prescription-bottle-medical',\n icon: [\n 384,\n 512,\n [\n \"prescription-bottle-alt\"\n ],\n \"f486\",\n \"M32 448c0 35.2 28.8 64 64 64h192c35.2 0 64-28.8 64-64V128H32V448zM96 304C96 295.2 103.2 288 112 288H160V240C160 231.2 167.2 224 176 224h32C216.8 224 224 231.2 224 240V288h48C280.8 288 288 295.2 288 304v32c0 8.799-7.199 16-16 16H224v48c0 8.799-7.199 16-16 16h-32C167.2 416 160 408.8 160 400V352H112C103.2 352 96 344.8 96 336V304zM360 0H24C10.75 0 0 10.75 0 24v48C0 85.25 10.75 96 24 96h336C373.3 96 384 85.25 384 72v-48C384 10.75 373.3 0 360 0z\"\n ]\n};\nvar faPrescriptionBottleAlt = faPrescriptionBottleMedical;\nvar faPrint = {\n prefix: 'fas',\n iconName: 'print',\n icon: [\n 512,\n 512,\n [\n 128424,\n 128438,\n 9113\n ],\n \"f02f\",\n \"M448 192H64C28.65 192 0 220.7 0 256v96c0 17.67 14.33 32 32 32h32v96c0 17.67 14.33 32 32 32h320c17.67 0 32-14.33 32-32v-96h32c17.67 0 32-14.33 32-32V256C512 220.7 483.3 192 448 192zM384 448H128v-96h256V448zM432 296c-13.25 0-24-10.75-24-24c0-13.27 10.75-24 24-24s24 10.73 24 24C456 285.3 445.3 296 432 296zM128 64h229.5L384 90.51V160h64V77.25c0-8.484-3.375-16.62-9.375-22.62l-45.25-45.25C387.4 3.375 379.2 0 370.8 0H96C78.34 0 64 14.33 64 32v128h64V64z\"\n ]\n};\nvar faPumpMedical = {\n prefix: 'fas',\n iconName: 'pump-medical',\n icon: [\n 384,\n 512,\n [],\n \"e06a\",\n \"M379.3 94.06l-43.32-43.32C323.1 38.74 307.7 32 290.8 32h-66.75c0-17.67-14.33-32-32-32H127.1c-17.67 0-32 14.33-32 32L96 128h128l-.0002-32h66.75l43.31 43.31c6.248 6.248 16.38 6.248 22.63 0l22.62-22.62C385.6 110.4 385.6 100.3 379.3 94.06zM235.6 160H84.37C51.27 160 23.63 185.2 20.63 218.2l-20.36 224C-3.139 479.7 26.37 512 64.01 512h191.1c37.63 0 67.14-32.31 63.74-69.79l-20.36-224C296.4 185.2 268.7 160 235.6 160zM239.1 333.3c0 7.363-5.971 13.33-13.33 13.33h-40v40c0 7.363-5.969 13.33-13.33 13.33h-26.67c-7.363 0-13.33-5.971-13.33-13.33v-40H93.33c-7.363 0-13.33-5.971-13.33-13.33V306.7c0-7.365 5.971-13.33 13.33-13.33h40v-40C133.3 245.1 139.3 240 146.7 240h26.67c7.363 0 13.33 5.969 13.33 13.33v40h40c7.363 0 13.33 5.969 13.33 13.33V333.3z\"\n ]\n};\nvar faPumpSoap = {\n prefix: 'fas',\n iconName: 'pump-soap',\n icon: [\n 384,\n 512,\n [],\n \"e06b\",\n \"M235.6 160H84.37C51.27 160 23.63 185.2 20.63 218.2l-20.36 224C-3.139 479.7 26.37 512 64.01 512h191.1c37.63 0 67.14-32.31 63.74-69.79l-20.36-224C296.4 185.2 268.7 160 235.6 160zM159.1 416C124.7 416 96 389.7 96 357.3c0-25 38.08-75.47 55.5-97.27c4.25-5.312 12.75-5.312 17 0C185.9 281.8 224 332.3 224 357.3C224 389.7 195.3 416 159.1 416zM379.3 94.06l-43.32-43.32C323.1 38.74 307.7 32 290.8 32h-66.75c0-17.67-14.33-32-32-32H127.1c-17.67 0-32 14.33-32 32L96 128h128l-.0002-32h66.75l43.31 43.31c6.248 6.248 16.38 6.248 22.63 0l22.62-22.62C385.6 110.4 385.6 100.3 379.3 94.06z\"\n ]\n};\nvar faPuzzlePiece = {\n prefix: 'fas',\n iconName: 'puzzle-piece',\n icon: [\n 512,\n 512,\n [\n 129513\n ],\n \"f12e\",\n \"M512 288c0 35.35-21.49 64-48 64c-32.43 0-31.72-32-55.64-32C394.9 320 384 330.9 384 344.4V480c0 17.67-14.33 32-32 32h-71.64C266.9 512 256 501.1 256 487.6C256 463.1 288 464.4 288 432c0-26.51-28.65-48-64-48s-64 21.49-64 48c0 32.43 32 31.72 32 55.64C192 501.1 181.1 512 167.6 512H32c-17.67 0-32-14.33-32-32v-135.6C0 330.9 10.91 320 24.36 320C48.05 320 47.6 352 80 352C106.5 352 128 323.3 128 288S106.5 223.1 80 223.1c-32.43 0-31.72 32-55.64 32C10.91 255.1 0 245.1 0 231.6v-71.64c0-17.67 14.33-31.1 32-31.1h135.6C181.1 127.1 192 117.1 192 103.6c0-23.69-32-23.24-32-55.64c0-26.51 28.65-47.1 64-47.1s64 21.49 64 47.1c0 32.43-32 31.72-32 55.64c0 13.45 10.91 24.36 24.36 24.36H352c17.67 0 32 14.33 32 31.1v71.64c0 13.45 10.91 24.36 24.36 24.36c23.69 0 23.24-32 55.64-32C490.5 223.1 512 252.7 512 288z\"\n ]\n};\nvar faQ = {\n prefix: 'fas',\n iconName: 'q',\n icon: [\n 448,\n 512,\n [\n 113\n ],\n \"51\",\n \"M393.1 402.5c34.12-39.32 54.93-90.48 54.93-146.5c0-123.5-100.5-224-223.1-224S.0001 132.5 .0001 256s100.5 224 223.1 224c44.45 0 85.81-13.16 120.7-35.58l46.73 56.08c6.328 7.594 15.42 11.52 24.59 11.52c21.35 0 31.98-18.26 31.98-32.01c0-7.223-2.433-14.49-7.419-20.47L393.1 402.5zM224 416c-88.22 0-160-71.78-160-160s71.78-159.1 160-159.1s160 71.78 160 159.1c0 36.21-12.55 69.28-32.92 96.12L280.6 267.5c-6.338-7.597-15.44-11.53-24.61-11.53c-21.27 0-31.96 18.22-31.96 32.02c0 7.223 2.433 14.49 7.419 20.47l71.53 85.83C279.6 407.7 252.8 416 224 416z\"\n ]\n};\nvar faQrcode = {\n prefix: 'fas',\n iconName: 'qrcode',\n icon: [\n 448,\n 512,\n [],\n \"f029\",\n \"M144 32C170.5 32 192 53.49 192 80V176C192 202.5 170.5 224 144 224H48C21.49 224 0 202.5 0 176V80C0 53.49 21.49 32 48 32H144zM128 96H64V160H128V96zM144 288C170.5 288 192 309.5 192 336V432C192 458.5 170.5 480 144 480H48C21.49 480 0 458.5 0 432V336C0 309.5 21.49 288 48 288H144zM128 352H64V416H128V352zM256 80C256 53.49 277.5 32 304 32H400C426.5 32 448 53.49 448 80V176C448 202.5 426.5 224 400 224H304C277.5 224 256 202.5 256 176V80zM320 160H384V96H320V160zM352 448H384V480H352V448zM448 480H416V448H448V480zM416 288H448V416H352V384H320V480H256V288H352V320H416V288z\"\n ]\n};\nvar faQuestion = {\n prefix: 'fas',\n iconName: 'question',\n icon: [\n 320,\n 512,\n [\n 10067,\n 10068,\n 61736\n ],\n \"3f\",\n \"M204.3 32.01H96c-52.94 0-96 43.06-96 96c0 17.67 14.31 31.1 32 31.1s32-14.32 32-31.1c0-17.64 14.34-32 32-32h108.3C232.8 96.01 256 119.2 256 147.8c0 19.72-10.97 37.47-30.5 47.33L127.8 252.4C117.1 258.2 112 268.7 112 280v40c0 17.67 14.31 31.99 32 31.99s32-14.32 32-31.99V298.3L256 251.3c39.47-19.75 64-59.42 64-103.5C320 83.95 268.1 32.01 204.3 32.01zM144 400c-22.09 0-40 17.91-40 40s17.91 39.1 40 39.1s40-17.9 40-39.1S166.1 400 144 400z\"\n ]\n};\nvar faQuoteLeft = {\n prefix: 'fas',\n iconName: 'quote-left',\n icon: [\n 448,\n 512,\n [\n 8220,\n \"quote-left-alt\"\n ],\n \"f10d\",\n \"M96 224C84.72 224 74.05 226.3 64 229.9V224c0-35.3 28.7-64 64-64c17.67 0 32-14.33 32-32S145.7 96 128 96C57.42 96 0 153.4 0 224v96c0 53.02 42.98 96 96 96s96-42.98 96-96S149 224 96 224zM352 224c-11.28 0-21.95 2.305-32 5.879V224c0-35.3 28.7-64 64-64c17.67 0 32-14.33 32-32s-14.33-32-32-32c-70.58 0-128 57.42-128 128v96c0 53.02 42.98 96 96 96s96-42.98 96-96S405 224 352 224z\"\n ]\n};\nvar faQuoteLeftAlt = faQuoteLeft;\nvar faQuoteRight = {\n prefix: 'fas',\n iconName: 'quote-right',\n icon: [\n 448,\n 512,\n [\n 8221,\n \"quote-right-alt\"\n ],\n \"f10e\",\n \"M96 96C42.98 96 0 138.1 0 192s42.98 96 96 96c11.28 0 21.95-2.305 32-5.879V288c0 35.3-28.7 64-64 64c-17.67 0-32 14.33-32 32s14.33 32 32 32c70.58 0 128-57.42 128-128V192C192 138.1 149 96 96 96zM448 192c0-53.02-42.98-96-96-96s-96 42.98-96 96s42.98 96 96 96c11.28 0 21.95-2.305 32-5.879V288c0 35.3-28.7 64-64 64c-17.67 0-32 14.33-32 32s14.33 32 32 32c70.58 0 128-57.42 128-128V192z\"\n ]\n};\nvar faQuoteRightAlt = faQuoteRight;\nvar faR = {\n prefix: 'fas',\n iconName: 'r',\n icon: [\n 320,\n 512,\n [\n 114\n ],\n \"52\",\n \"M228.7 309.7C282 288.6 320 236.8 320 176c0-79.41-64.59-144-144-144H32c-17.67 0-32 14.33-32 32v384c0 17.67 14.33 32 32 32s32-14.33 32-32v-128h93.43l104.5 146.6c6.25 8.75 16.09 13.42 26.09 13.42c6.422 0 12.91-1.922 18.55-5.938c14.39-10.27 17.73-30.25 7.484-44.64L228.7 309.7zM64 96.01h112c44.11 0 80 35.89 80 80s-35.89 79.1-80 79.1H64V96.01z\"\n ]\n};\nvar faRadiation = {\n prefix: 'fas',\n iconName: 'radiation',\n icon: [\n 512,\n 512,\n [],\n \"f7b9\",\n \"M256 303.1c26.5 0 48-21.5 48-48S282.5 207.1 256 207.1S208 229.5 208 255.1S229.5 303.1 256 303.1zM213.6 188L142.7 74.71C132.5 58.41 109.9 54.31 95.25 66.75c-44.94 38.1-76.19 91.82-85.17 152.8C7.266 238.7 22.67 255.8 42.01 255.8h133.8C175.8 227.2 191 202.3 213.6 188zM416.8 66.75c-14.67-12.44-37.21-8.338-47.41 7.965L298.4 188c22.6 14.3 37.8 39.2 37.8 67.8h133.8c19.34 0 34.74-17.13 31.93-36.26C492.9 158.6 461.7 104.8 416.8 66.75zM298.4 323.5C286.1 331.2 271.6 335.9 256 335.9s-30.1-4.701-42.4-12.4L142.7 436.9c-10.14 16.21-4.16 38.2 13.32 45.95C186.6 496.4 220.4 504 256 504s69.42-7.611 100-21.18c17.48-7.752 23.46-29.74 13.32-45.95L298.4 323.5z\"\n ]\n};\nvar faRainbow = {\n prefix: 'fas',\n iconName: 'rainbow',\n icon: [\n 640,\n 512,\n [\n 127752\n ],\n \"f75b\",\n \"M312.3 32.09C137.6 36.22 0 183.3 0 358V464C0 472.8 7.164 480 16 480h32C56.84 480 64 472.8 64 464v-106.9c0-143.2 117.2-263.5 260.4-261.1C463.5 98.4 576 212.3 576 352v112c0 8.836 7.164 16 16 16h32c8.838 0 16-7.164 16-16V352C640 172.1 492.3 27.84 312.3 32.09zM313.5 224.2C244.8 227.6 192 286.9 192 355.7V464C192 472.8 199.2 480 208 480h32C248.8 480 256 472.8 256 464v-109.7c0-34.06 25.65-63.85 59.64-66.11C352.9 285.7 384 315.3 384 352v112c0 8.836 7.164 16 16 16h32c8.838 0 16-7.164 16-16V352C448 279.3 387 220.5 313.5 224.2zM313.2 128.1C191.4 131.7 96 234.9 96 356.8V464C96 472.8 103.2 480 112 480h32C152.8 480 160 472.8 160 464v-108.1c0-86.64 67.24-160.5 153.8-163.8C404.8 188.7 480 261.7 480 352v112c0 8.836 7.164 16 16 16h32c8.838 0 16-7.164 16-16V352C544 226.2 439.8 124.3 313.2 128.1z\"\n ]\n};\nvar faReceipt = {\n prefix: 'fas',\n iconName: 'receipt',\n icon: [\n 384,\n 512,\n [\n 129534\n ],\n \"f543\",\n \"M13.97 2.196C22.49-1.72 32.5-.3214 39.62 5.778L80 40.39L120.4 5.778C129.4-1.926 142.6-1.926 151.6 5.778L192 40.39L232.4 5.778C241.4-1.926 254.6-1.926 263.6 5.778L304 40.39L344.4 5.778C351.5-.3214 361.5-1.72 370 2.196C378.5 6.113 384 14.63 384 24V488C384 497.4 378.5 505.9 370 509.8C361.5 513.7 351.5 512.3 344.4 506.2L304 471.6L263.6 506.2C254.6 513.9 241.4 513.9 232.4 506.2L192 471.6L151.6 506.2C142.6 513.9 129.4 513.9 120.4 506.2L80 471.6L39.62 506.2C32.5 512.3 22.49 513.7 13.97 509.8C5.456 505.9 0 497.4 0 488V24C0 14.63 5.456 6.112 13.97 2.196V2.196zM96 144C87.16 144 80 151.2 80 160C80 168.8 87.16 176 96 176H288C296.8 176 304 168.8 304 160C304 151.2 296.8 144 288 144H96zM96 368H288C296.8 368 304 360.8 304 352C304 343.2 296.8 336 288 336H96C87.16 336 80 343.2 80 352C80 360.8 87.16 368 96 368zM96 240C87.16 240 80 247.2 80 256C80 264.8 87.16 272 96 272H288C296.8 272 304 264.8 304 256C304 247.2 296.8 240 288 240H96z\"\n ]\n};\nvar faRecordVinyl = {\n prefix: 'fas',\n iconName: 'record-vinyl',\n icon: [\n 512,\n 512,\n [],\n \"f8d9\",\n \"M256 160C202.9 160 160 202.9 160 256s42.92 96 96 96c53.08 0 96-42.92 96-96S309.1 160 256 160zM256 288C238.3 288 224 273.7 224 256s14.33-32 32-32c17.67 0 32 14.33 32 32S273.7 288 256 288zM256 0c-141.4 0-256 114.6-256 256s114.6 256 256 256c141.4 0 256-114.6 256-256S397.4 0 256 0zM256 384c-70.75 0-128-57.25-128-128s57.25-128 128-128s128 57.25 128 128S326.8 384 256 384z\"\n ]\n};\nvar faRectangleAd = {\n prefix: 'fas',\n iconName: 'rectangle-ad',\n icon: [\n 576,\n 512,\n [\n \"ad\"\n ],\n \"f641\",\n \"M208 237.7L229.2 280H186.8L208 237.7zM416 280C416 293.3 405.3 304 392 304C378.7 304 368 293.3 368 280C368 266.7 378.7 256 392 256C405.3 256 416 266.7 416 280zM512 32C547.3 32 576 60.65 576 96V416C576 451.3 547.3 480 512 480H64C28.65 480 0 451.3 0 416V96C0 60.65 28.65 32 64 32H512zM229.5 173.3C225.4 165.1 217.1 160 208 160C198.9 160 190.6 165.1 186.5 173.3L114.5 317.3C108.6 329.1 113.4 343.5 125.3 349.5C137.1 355.4 151.5 350.6 157.5 338.7L162.8 328H253.2L258.5 338.7C264.5 350.6 278.9 355.4 290.7 349.5C302.6 343.5 307.4 329.1 301.5 317.3L229.5 173.3zM416 212.1C408.5 209.4 400.4 208 392 208C352.2 208 320 240.2 320 280C320 319.8 352.2 352 392 352C403.1 352 413.6 349.5 423 344.1C427.4 349.3 433.4 352 440 352C453.3 352 464 341.3 464 328V184C464 170.7 453.3 160 440 160C426.7 160 416 170.7 416 184V212.1z\"\n ]\n};\nvar faAd = faRectangleAd;\nvar faRectangleList = {\n prefix: 'fas',\n iconName: 'rectangle-list',\n icon: [\n 576,\n 512,\n [\n \"list-alt\"\n ],\n \"f022\",\n \"M0 96C0 60.65 28.65 32 64 32H512C547.3 32 576 60.65 576 96V416C576 451.3 547.3 480 512 480H64C28.65 480 0 451.3 0 416V96zM160 256C160 238.3 145.7 224 128 224C110.3 224 96 238.3 96 256C96 273.7 110.3 288 128 288C145.7 288 160 273.7 160 256zM160 160C160 142.3 145.7 128 128 128C110.3 128 96 142.3 96 160C96 177.7 110.3 192 128 192C145.7 192 160 177.7 160 160zM160 352C160 334.3 145.7 320 128 320C110.3 320 96 334.3 96 352C96 369.7 110.3 384 128 384C145.7 384 160 369.7 160 352zM224 136C210.7 136 200 146.7 200 160C200 173.3 210.7 184 224 184H448C461.3 184 472 173.3 472 160C472 146.7 461.3 136 448 136H224zM224 232C210.7 232 200 242.7 200 256C200 269.3 210.7 280 224 280H448C461.3 280 472 269.3 472 256C472 242.7 461.3 232 448 232H224zM224 328C210.7 328 200 338.7 200 352C200 365.3 210.7 376 224 376H448C461.3 376 472 365.3 472 352C472 338.7 461.3 328 448 328H224z\"\n ]\n};\nvar faListAlt = faRectangleList;\nvar faRectangleXmark = {\n prefix: 'fas',\n iconName: 'rectangle-xmark',\n icon: [\n 512,\n 512,\n [\n 62164,\n \"rectangle-times\",\n \"times-rectangle\",\n \"window-close\"\n ],\n \"f410\",\n \"M448 32C483.3 32 512 60.65 512 96V416C512 451.3 483.3 480 448 480H64C28.65 480 0 451.3 0 416V96C0 60.65 28.65 32 64 32H448zM175 208.1L222.1 255.1L175 303C165.7 312.4 165.7 327.6 175 336.1C184.4 346.3 199.6 346.3 208.1 336.1L255.1 289.9L303 336.1C312.4 346.3 327.6 346.3 336.1 336.1C346.3 327.6 346.3 312.4 336.1 303L289.9 255.1L336.1 208.1C346.3 199.6 346.3 184.4 336.1 175C327.6 165.7 312.4 165.7 303 175L255.1 222.1L208.1 175C199.6 165.7 184.4 165.7 175 175C165.7 184.4 165.7 199.6 175 208.1V208.1z\"\n ]\n};\nvar faRectangleTimes = faRectangleXmark;\nvar faTimesRectangle = faRectangleXmark;\nvar faWindowClose = faRectangleXmark;\nvar faRecycle = {\n prefix: 'fas',\n iconName: 'recycle',\n icon: [\n 512,\n 512,\n [\n 9850,\n 9851,\n 9842\n ],\n \"f1b8\",\n \"M180.2 243.1C185 263.9 162.2 280.2 144.1 268.8L119.8 253.6l-50.9 81.43c-13.33 21.32 2.004 48.98 27.15 48.98h32.02c17.64 0 31.98 14.32 31.98 31.96c0 17.64-14.34 32.05-31.98 32.05H96.15c-75.36 0-121.3-82.84-81.47-146.8L65.51 219.8L41.15 204.5C23.04 193.1 27.66 165.5 48.48 160.7l91.43-21.15C148.5 137.7 157.2 142.9 159.2 151.6L180.2 243.1zM283.1 78.96l41.25 66.14l-24.25 15.08c-18.16 11.31-13.57 38.94 7.278 43.77l91.4 21.15c8.622 1.995 17.23-3.387 19.21-12.01l21.04-91.43c4.789-20.81-17.95-37.05-36.07-25.76l-24.36 15.2L337.4 45.14c-37.58-60.14-125.2-60.18-162.8-.0617L167.2 56.9C157.9 71.75 162.5 91.58 177.3 100.9c14.92 9.359 34.77 4.886 44.11-10.04l7.442-11.89C241.6 58.58 270.9 59.33 283.1 78.96zM497.3 301.3l-16.99-27.26c-9.336-14.98-29.06-19.56-44.04-10.21c-14.94 9.318-19.52 29.15-10.18 44.08l16.99 27.15c13.35 21.32-1.984 49-27.14 49h-95.99l.0234-28.74c0-21.38-25.85-32.09-40.97-16.97l-66.41 66.43c-6.222 6.223-6.222 16.41 .0044 22.63l66.42 66.34c15.12 15.1 40.95 4.386 40.95-16.98l-.0234-28.68h95.86C491.2 448.1 537.2 365.2 497.3 301.3z\"\n ]\n};\nvar faRegistered = {\n prefix: 'fas',\n iconName: 'registered',\n icon: [\n 512,\n 512,\n [\n 174\n ],\n \"f25d\",\n \"M256 0C114.6 0 0 114.6 0 256s114.6 256 256 256s256-114.6 256-256S397.4 0 256 0zM349.8 349.8c5.594 12.03 .4375 26.31-11.56 31.94c-3.312 1.531-6.75 2.25-10.19 2.25c-9 0-17.66-5.125-21.75-13.81l-38.46-82.19H208v72c0 13.25-10.75 24-24 24s-24-10.75-24-24V152c0-13.25 10.75-24 24-24l88 .0044c44.13 0 80 35.88 80 80c0 28.32-14.87 53.09-37.12 67.31L349.8 349.8zM272 176h-64v64h64c17.66 0 32-14.34 32-32S289.7 176 272 176z\"\n ]\n};\nvar faRepeat = {\n prefix: 'fas',\n iconName: 'repeat',\n icon: [\n 512,\n 512,\n [\n 128257\n ],\n \"f363\",\n \"M480 256c-17.67 0-32 14.31-32 32c0 52.94-43.06 96-96 96H192L192 344c0-9.469-5.578-18.06-14.23-21.94C169.1 318.3 159 319.8 151.9 326.2l-80 72C66.89 402.7 64 409.2 64 416s2.891 13.28 7.938 17.84l80 72C156.4 509.9 162.2 512 168 512c3.312 0 6.615-.6875 9.756-2.062C186.4 506.1 192 497.5 192 488L192 448h160c88.22 0 160-71.78 160-160C512 270.3 497.7 256 480 256zM160 128h159.1L320 168c0 9.469 5.578 18.06 14.23 21.94C337.4 191.3 340.7 192 343.1 192c5.812 0 11.57-2.125 16.07-6.156l80-72C445.1 109.3 448 102.8 448 95.1s-2.891-13.28-7.938-17.84l-80-72c-7.047-6.312-17.19-7.875-25.83-4.094C325.6 5.938 319.1 14.53 319.1 24L320 64H160C71.78 64 0 135.8 0 224c0 17.69 14.33 32 32 32s32-14.31 32-32C64 171.1 107.1 128 160 128z\"\n ]\n};\nvar faReply = {\n prefix: 'fas',\n iconName: 'reply',\n icon: [\n 512,\n 512,\n [\n 61714,\n \"mail-reply\"\n ],\n \"f3e5\",\n \"M8.31 189.9l176-151.1c15.41-13.3 39.69-2.509 39.69 18.16v80.05C384.6 137.9 512 170.1 512 322.3c0 61.44-39.59 122.3-83.34 154.1c-13.66 9.938-33.09-2.531-28.06-18.62c45.34-145-21.5-183.5-176.6-185.8v87.92c0 20.7-24.31 31.45-39.69 18.16l-176-151.1C-2.753 216.6-2.784 199.4 8.31 189.9z\"\n ]\n};\nvar faMailReply = faReply;\nvar faReplyAll = {\n prefix: 'fas',\n iconName: 'reply-all',\n icon: [\n 576,\n 512,\n [\n \"mail-reply-all\"\n ],\n \"f122\",\n \"M136.3 226.2l176 151.1c15.38 13.3 39.69 2.545 39.69-18.16V275.1c108.5 12.58 151.1 58.79 112.6 181.9c-5.031 16.09 14.41 28.56 28.06 18.62c43.75-31.81 83.34-92.69 83.34-154.1c0-131.3-94.86-173.2-224-183.5V56.02c0-20.67-24.28-31.46-39.69-18.16L136.3 189.9C125.2 199.4 125.2 216.6 136.3 226.2zM8.31 226.2l176 151.1c15.38 13.3 39.69 2.545 39.69-18.16v-15.83L66.33 208l157.7-136.2V56.02c0-20.67-24.28-31.46-39.69-18.16l-176 151.1C-2.77 199.4-2.77 216.6 8.31 226.2z\"\n ]\n};\nvar faMailReplyAll = faReplyAll;\nvar faRepublican = {\n prefix: 'fas',\n iconName: 'republican',\n icon: [\n 640,\n 512,\n [],\n \"f75e\",\n \"M544 191.1c0-88.37-71.62-159.1-159.1-159.1L159.1 32C71.62 32 0 103.6 0 191.1l.025 63.98h543.1V191.1zM176.3 170.4l-19.75 19.37l4.75 27.25c.7498 4.875-4.375 8.625-8.75 6.25l-24.5-12.87L103.5 223.2C99.27 225.6 94.02 221.9 94.77 216.1l4.75-27.25l-19.75-19.37C76.15 166.9 78.15 160.9 83.02 160.2L110.4 156.2l12.25-24.87c2.125-4.5 8.625-4.375 10.62 0L145.5 156.2L172.9 160.2C177.9 160.9 179.8 166.9 176.3 170.4zM320.3 170.4l-19.75 19.37l4.75 27.25c.7498 4.875-4.375 8.625-8.75 6.25L272 210.4l-24.5 12.87C243.3 225.6 238 221.9 238.8 216.1L243.5 189.7l-19.75-19.37c-3.625-3.5-1.625-9.498 3.25-10.12L254.4 156.2l12.25-24.87c2.125-4.5 8.625-4.375 10.62 0L289.5 156.2l27.37 4C321.9 160.9 323.8 166.9 320.3 170.4zM464.3 170.4l-19.75 19.37l4.75 27.25c.7498 4.875-4.375 8.625-8.75 6.25l-24.5-12.87l-24.5 12.87c-4.25 2.375-9.5-1.375-8.75-6.25l4.75-27.25l-19.75-19.37c-3.625-3.5-1.625-9.498 3.25-10.12l27.37-4l12.25-24.87c2.125-4.5 8.625-4.375 10.62 0l12.25 24.87l27.37 4C465.9 160.9 467.8 166.9 464.3 170.4zM624 319.1L592 319.1c-8.799 0-15.1 7.199-15.1 15.1v63.99c0 8.748-7.25 15.1-15.1 15.1c-8.75 0-15.1-7.25-15.1-15.1l-.0313-111.1L.025 287.1v159.1c0 17.6 14.4 31.1 31.1 31.1L95.98 479.1c17.6 0 32.04-14.4 32.04-32v-63.98l191.1-.0169v63.99c0 17.6 14.36 32 31.96 32l64.04 .013c17.6 0 31.1-14.4 31.1-31.1l-.0417-96.01l32.04 .0006v43.25c0 41.79 29.91 80.03 71.48 84.35C599.3 484.5 640 446.9 640 399.1v-63.98C640 327.2 632.8 319.1 624 319.1z\"\n ]\n};\nvar faRestroom = {\n prefix: 'fas',\n iconName: 'restroom',\n icon: [\n 640,\n 512,\n [],\n \"f7bd\",\n \"M319.1 0C306.8 0 296 10.8 296 24v464c0 13.2 10.8 24 23.1 24s24-10.8 24-24V24C344 10.8 333.2 0 319.1 0zM213.7 171.8C204.9 145.6 180.5 128 152.9 128H103.1C75.47 128 51.06 145.6 42.37 171.8L1.653 293.9c-5.594 16.77 3.469 34.89 20.22 40.48c12.68 4.211 25.93 .1426 34.13-9.18V480c0 17.67 14.33 32 32 32s31.1-14.33 31.1-32l-.0003-144h16l.0003 144c0 17.67 14.33 32 32 32s31.1-14.33 31.1-32l-.0003-155.2c6.041 6.971 14.7 11.25 24 11.25c3.344 0 6.75-.5313 10.13-1.656c16.75-5.594 25.81-23.72 20.22-40.48L213.7 171.8zM128 96c26.5 0 47.1-21.5 47.1-48S154.5 0 128 0S80 21.5 80 48S101.5 96 128 96zM511.1 96c26.5 0 48-21.5 48-48S538.5 0 511.1 0s-47.1 21.5-47.1 48S485.5 96 511.1 96zM638.3 293.9l-40.69-122.1C588.9 145.6 564.5 128 536.9 128h-49.88c-27.59 0-52 17.59-60.69 43.75l-40.72 122.1c-5.594 16.77 3.469 34.89 20.22 40.48c3.422 1.137 6.856 1.273 10.25 1.264L399.1 384h40v96c0 17.67 14.32 32 31.1 32s32-14.33 32-32v-96h16v96c0 17.67 14.32 32 31.1 32s32-14.33 32-32v-96h39.1l-15.99-47.98c3.342 0 6.747-.5313 10.12-1.656C634.9 328.8 643.9 310.6 638.3 293.9z\"\n ]\n};\nvar faRetweet = {\n prefix: 'fas',\n iconName: 'retweet',\n icon: [\n 640,\n 512,\n [],\n \"f079\",\n \"M614.2 334.8C610.5 325.8 601.7 319.1 592 319.1H544V176C544 131.9 508.1 96 464 96h-128c-17.67 0-32 14.31-32 32s14.33 32 32 32h128C472.8 160 480 167.2 480 176v143.1h-48c-9.703 0-18.45 5.844-22.17 14.82s-1.656 19.29 5.203 26.16l80 80.02C499.7 445.7 505.9 448 512 448s12.28-2.344 16.97-7.031l80-80.02C615.8 354.1 617.9 343.8 614.2 334.8zM304 352h-128C167.2 352 160 344.8 160 336V192h48c9.703 0 18.45-5.844 22.17-14.82s1.656-19.29-5.203-26.16l-80-80.02C140.3 66.34 134.1 64 128 64S115.7 66.34 111 71.03l-80 80.02C24.17 157.9 22.11 168.2 25.83 177.2S38.3 192 48 192H96V336C96 380.1 131.9 416 176 416h128c17.67 0 32-14.31 32-32S321.7 352 304 352z\"\n ]\n};\nvar faRibbon = {\n prefix: 'fas',\n iconName: 'ribbon',\n icon: [\n 448,\n 512,\n [\n 127895\n ],\n \"f4d6\",\n \"M6.05 444.3c-9.626 10.87-7.501 27.62 4.5 35.75l68.76 27.87c9.876 6.75 23.38 4.1 31.38-3.75l91.76-101.9L123.2 314.3L6.05 444.3zM441.8 444.3c0 0-292-324.5-295.4-329.1c15.38-8.5 40.25-17.1 77.51-17.1s62.13 9.5 77.51 17.1c-3.25 5.5-56.01 64.5-56.01 64.5l79.13 87.75l34.13-37.1c28.75-31.87 33.38-78.62 11.5-115.5L326.5 39.52c-4.25-7.25-9.876-13.25-16.75-17.1c-40.75-27.62-127.5-29.75-171.5 0C131.3 26.27 125.7 32.27 121.4 39.52L77.81 112.8C76.31 115.3 40.68 174.9 89.31 228.8l248.1 275.2c8.001 8.875 21.38 10.5 31.25 3.75l68.88-27.87C449.5 471.9 451.6 455.1 441.8 444.3z\"\n ]\n};\nvar faRightFromBracket = {\n prefix: 'fas',\n iconName: 'right-from-bracket',\n icon: [\n 512,\n 512,\n [\n \"sign-out-alt\"\n ],\n \"f2f5\",\n \"M96 480h64C177.7 480 192 465.7 192 448S177.7 416 160 416H96c-17.67 0-32-14.33-32-32V128c0-17.67 14.33-32 32-32h64C177.7 96 192 81.67 192 64S177.7 32 160 32H96C42.98 32 0 74.98 0 128v256C0 437 42.98 480 96 480zM504.8 238.5l-144.1-136c-6.975-6.578-17.2-8.375-26-4.594c-8.803 3.797-14.51 12.47-14.51 22.05l-.0918 72l-128-.001c-17.69 0-32.02 14.33-32.02 32v64c0 17.67 14.34 32 32.02 32l128 .001l.0918 71.1c0 9.578 5.707 18.25 14.51 22.05c8.803 3.781 19.03 1.984 26-4.594l144.1-136C514.4 264.4 514.4 247.6 504.8 238.5z\"\n ]\n};\nvar faSignOutAlt = faRightFromBracket;\nvar faRightLeft = {\n prefix: 'fas',\n iconName: 'right-left',\n icon: [\n 512,\n 512,\n [\n \"exchange-alt\"\n ],\n \"f362\",\n \"M32 160h319.9l.0791 72c0 9.547 5.652 18.19 14.41 22c8.754 3.812 18.93 2.078 25.93-4.406l112-104c10.24-9.5 10.24-25.69 0-35.19l-112-104c-6.992-6.484-17.17-8.217-25.93-4.408c-8.758 3.816-14.41 12.46-14.41 22L351.9 96H32C14.31 96 0 110.3 0 127.1S14.31 160 32 160zM480 352H160.1L160 279.1c0-9.547-5.652-18.19-14.41-22C136.9 254.2 126.7 255.9 119.7 262.4l-112 104c-10.24 9.5-10.24 25.69 0 35.19l112 104c6.992 6.484 17.17 8.219 25.93 4.406C154.4 506.2 160 497.5 160 488L160.1 416H480c17.69 0 32-14.31 32-32S497.7 352 480 352z\"\n ]\n};\nvar faExchangeAlt = faRightLeft;\nvar faRightLong = {\n prefix: 'fas',\n iconName: 'right-long',\n icon: [\n 512,\n 512,\n [\n \"long-arrow-alt-right\"\n ],\n \"f30b\",\n \"M504.3 273.6l-112.1 104c-6.992 6.484-17.18 8.218-25.94 4.406c-8.758-3.812-14.42-12.45-14.42-21.1L351.9 288H32C14.33 288 .0002 273.7 .0002 255.1S14.33 224 32 224h319.9l0-72c0-9.547 5.66-18.19 14.42-22c8.754-3.809 18.95-2.075 25.94 4.41l112.1 104C514.6 247.9 514.6 264.1 504.3 273.6z\"\n ]\n};\nvar faLongArrowAltRight = faRightLong;\nvar faRightToBracket = {\n prefix: 'fas',\n iconName: 'right-to-bracket',\n icon: [\n 512,\n 512,\n [\n \"sign-in-alt\"\n ],\n \"f2f6\",\n \"M344.7 238.5l-144.1-136C193.7 95.97 183.4 94.17 174.6 97.95C165.8 101.8 160.1 110.4 160.1 120V192H32.02C14.33 192 0 206.3 0 224v64c0 17.68 14.33 32 32.02 32h128.1v72c0 9.578 5.707 18.25 14.51 22.05c8.803 3.781 19.03 1.984 26-4.594l144.1-136C354.3 264.4 354.3 247.6 344.7 238.5zM416 32h-64c-17.67 0-32 14.33-32 32s14.33 32 32 32h64c17.67 0 32 14.33 32 32v256c0 17.67-14.33 32-32 32h-64c-17.67 0-32 14.33-32 32s14.33 32 32 32h64c53.02 0 96-42.98 96-96V128C512 74.98 469 32 416 32z\"\n ]\n};\nvar faSignInAlt = faRightToBracket;\nvar faRing = {\n prefix: 'fas',\n iconName: 'ring',\n icon: [\n 512,\n 512,\n [],\n \"f70b\",\n \"M256 64C109.1 64 0 125.9 0 208v98.13C0 384.5 114.6 448 256 448s256-63.5 256-141.9V208C512 125.9 401.1 64 256 64zM256 288C203.1 288 155.1 279.1 120.4 264.6C155 249.9 201.6 240 256 240s101 9.875 135.6 24.62C356.9 279.1 308.9 288 256 288zM437.1 234.4C392.1 208.3 328.3 192 256 192S119.9 208.3 74.88 234.4C68 226.1 64 217.3 64 208C64 163.9 149.1 128 256 128c105.1 0 192 35.88 192 80C448 217.3 444 226.1 437.1 234.4z\"\n ]\n};\nvar faRoad = {\n prefix: 'fas',\n iconName: 'road',\n icon: [\n 576,\n 512,\n [\n 128739\n ],\n \"f018\",\n \"M256 96C256 113.7 270.3 128 288 128C305.7 128 320 113.7 320 96V32H394.8C421.9 32 446 49.08 455.1 74.63L572.9 407.2C574.9 413 576 419.2 576 425.4C576 455.5 551.5 480 521.4 480H320V416C320 398.3 305.7 384 288 384C270.3 384 256 398.3 256 416V480H54.61C24.45 480 0 455.5 0 425.4C0 419.2 1.06 413 3.133 407.2L120.9 74.63C129.1 49.08 154.1 32 181.2 32H255.1L256 96zM320 224C320 206.3 305.7 192 288 192C270.3 192 256 206.3 256 224V288C256 305.7 270.3 320 288 320C305.7 320 320 305.7 320 288V224z\"\n ]\n};\nvar faRobot = {\n prefix: 'fas',\n iconName: 'robot',\n icon: [\n 640,\n 512,\n [\n 129302\n ],\n \"f544\",\n \"M9.375 233.4C3.375 239.4 0 247.5 0 256v128c0 8.5 3.375 16.62 9.375 22.62S23.5 416 32 416h32V224H32C23.5 224 15.38 227.4 9.375 233.4zM464 96H352V32c0-17.62-14.38-32-32-32S288 14.38 288 32v64H176C131.8 96 96 131.8 96 176V448c0 35.38 28.62 64 64 64h320c35.38 0 64-28.62 64-64V176C544 131.8 508.3 96 464 96zM256 416H192v-32h64V416zM224 296C201.9 296 184 278.1 184 256S201.9 216 224 216S264 233.9 264 256S246.1 296 224 296zM352 416H288v-32h64V416zM448 416h-64v-32h64V416zM416 296c-22.12 0-40-17.88-40-40S393.9 216 416 216S456 233.9 456 256S438.1 296 416 296zM630.6 233.4C624.6 227.4 616.5 224 608 224h-32v192h32c8.5 0 16.62-3.375 22.62-9.375S640 392.5 640 384V256C640 247.5 636.6 239.4 630.6 233.4z\"\n ]\n};\nvar faRocket = {\n prefix: 'fas',\n iconName: 'rocket',\n icon: [\n 512,\n 512,\n [],\n \"f135\",\n \"M156.6 384.9L125.7 353.1C117.2 345.5 114.2 333.1 117.1 321.8C120.1 312.9 124.1 301.3 129.8 288H24C15.38 288 7.414 283.4 3.146 275.9C-1.123 268.4-1.042 259.2 3.357 251.8L55.83 163.3C68.79 141.4 92.33 127.1 117.8 127.1H200C202.4 124 204.8 120.3 207.2 116.7C289.1-4.07 411.1-8.142 483.9 5.275C495.6 7.414 504.6 16.43 506.7 28.06C520.1 100.9 516.1 222.9 395.3 304.8C391.8 307.2 387.1 309.6 384 311.1V394.2C384 419.7 370.6 443.2 348.7 456.2L260.2 508.6C252.8 513 243.6 513.1 236.1 508.9C228.6 504.6 224 496.6 224 488V380.8C209.9 385.6 197.6 389.7 188.3 392.7C177.1 396.3 164.9 393.2 156.6 384.9V384.9zM384 167.1C406.1 167.1 424 150.1 424 127.1C424 105.9 406.1 87.1 384 87.1C361.9 87.1 344 105.9 344 127.1C344 150.1 361.9 167.1 384 167.1z\"\n ]\n};\nvar faRotate = {\n prefix: 'fas',\n iconName: 'rotate',\n icon: [\n 512,\n 512,\n [\n 128260,\n \"sync-alt\"\n ],\n \"f2f1\",\n \"M449.9 39.96l-48.5 48.53C362.5 53.19 311.4 32 256 32C161.5 32 78.59 92.34 49.58 182.2c-5.438 16.81 3.797 34.88 20.61 40.28c16.97 5.5 34.86-3.812 40.3-20.59C130.9 138.5 189.4 96 256 96c37.96 0 73 14.18 100.2 37.8L311.1 178C295.1 194.8 306.8 223.4 330.4 224h146.9C487.7 223.7 496 215.3 496 204.9V59.04C496 34.99 466.9 22.95 449.9 39.96zM441.8 289.6c-16.94-5.438-34.88 3.812-40.3 20.59C381.1 373.5 322.6 416 256 416c-37.96 0-73-14.18-100.2-37.8L200 334C216.9 317.2 205.2 288.6 181.6 288H34.66C24.32 288.3 16 296.7 16 307.1v145.9c0 24.04 29.07 36.08 46.07 19.07l48.5-48.53C149.5 458.8 200.6 480 255.1 480c94.45 0 177.4-60.34 206.4-150.2C467.9 313 458.6 294.1 441.8 289.6z\"\n ]\n};\nvar faSyncAlt = faRotate;\nvar faRotateLeft = {\n prefix: 'fas',\n iconName: 'rotate-left',\n icon: [\n 512,\n 512,\n [\n \"rotate-back\",\n \"rotate-backward\",\n \"undo-alt\"\n ],\n \"f2ea\",\n \"M480 256c0 123.4-100.5 223.9-223.9 223.9c-48.84 0-95.17-15.58-134.2-44.86c-14.12-10.59-16.97-30.66-6.375-44.81c10.59-14.12 30.62-16.94 44.81-6.375c27.84 20.91 61 31.94 95.88 31.94C344.3 415.8 416 344.1 416 256s-71.69-159.8-159.8-159.8c-37.46 0-73.09 13.49-101.3 36.64l45.12 45.14c17.01 17.02 4.955 46.1-19.1 46.1H35.17C24.58 224.1 16 215.5 16 204.9V59.04c0-24.04 29.07-36.08 46.07-19.07l47.6 47.63C149.9 52.71 201.5 32.11 256.1 32.11C379.5 32.11 480 132.6 480 256z\"\n ]\n};\nvar faRotateBack = faRotateLeft;\nvar faRotateBackward = faRotateLeft;\nvar faUndoAlt = faRotateLeft;\nvar faRotateRight = {\n prefix: 'fas',\n iconName: 'rotate-right',\n icon: [\n 512,\n 512,\n [\n \"redo-alt\",\n \"rotate-forward\"\n ],\n \"f2f9\",\n \"M468.9 32.11c13.87 0 27.18 10.77 27.18 27.04v145.9c0 10.59-8.584 19.17-19.17 19.17h-145.7c-16.28 0-27.06-13.32-27.06-27.2c0-6.634 2.461-13.4 7.96-18.9l45.12-45.14c-28.22-23.14-63.85-36.64-101.3-36.64c-88.09 0-159.8 71.69-159.8 159.8S167.8 415.9 255.9 415.9c73.14 0 89.44-38.31 115.1-38.31c18.48 0 31.97 15.04 31.97 31.96c0 35.04-81.59 70.41-147 70.41c-123.4 0-223.9-100.5-223.9-223.9S132.6 32.44 256 32.44c54.6 0 106.2 20.39 146.4 55.26l47.6-47.63C455.5 34.57 462.3 32.11 468.9 32.11z\"\n ]\n};\nvar faRedoAlt = faRotateRight;\nvar faRotateForward = faRotateRight;\nvar faRoute = {\n prefix: 'fas',\n iconName: 'route',\n icon: [\n 512,\n 512,\n [],\n \"f4d7\",\n \"M320 256C302.3 256 288 270.3 288 288C288 305.7 302.3 320 320 320H416C469 320 512 362.1 512 416C512 469 469 512 416 512H139.6C148.3 502.1 158.9 489.4 169.6 475.2C175.9 466.8 182.4 457.6 188.6 448H416C433.7 448 448 433.7 448 416C448 398.3 433.7 384 416 384H320C266.1 384 223.1 341 223.1 288C223.1 234.1 266.1 192 320 192H362.1C340.2 161.5 320 125.4 320 96C320 42.98 362.1 0 416 0C469 0 512 42.98 512 96C512 160 416 256 416 256H320zM416 128C433.7 128 448 113.7 448 96C448 78.33 433.7 64 416 64C398.3 64 384 78.33 384 96C384 113.7 398.3 128 416 128zM118.3 487.8C118.1 488 117.9 488.2 117.7 488.4C113.4 493.4 109.5 497.7 106.3 501.2C105.9 501.6 105.5 502 105.2 502.4C99.5 508.5 96 512 96 512C96 512 0 416 0 352C0 298.1 42.98 255.1 96 255.1C149 255.1 192 298.1 192 352C192 381.4 171.8 417.5 149.9 448C138.1 463.2 127.7 476.9 118.3 487.8L118.3 487.8zM95.1 384C113.7 384 127.1 369.7 127.1 352C127.1 334.3 113.7 320 95.1 320C78.33 320 63.1 334.3 63.1 352C63.1 369.7 78.33 384 95.1 384z\"\n ]\n};\nvar faRss = {\n prefix: 'fas',\n iconName: 'rss',\n icon: [\n 448,\n 512,\n [\n \"feed\"\n ],\n \"f09e\",\n \"M25.57 176.1C12.41 175.4 .9117 185.2 .0523 198.4s9.173 24.65 22.39 25.5c120.1 7.875 225.7 112.7 233.6 233.6C256.9 470.3 267.4 480 279.1 480c.5313 0 1.062-.0313 1.594-.0625c13.22-.8438 23.25-12.28 22.39-25.5C294.6 310.3 169.7 185.4 25.57 176.1zM32 32C14.33 32 0 46.31 0 64s14.33 32 32 32c194.1 0 352 157.9 352 352c0 17.69 14.33 32 32 32s32-14.31 32-32C448 218.6 261.4 32 32 32zM63.1 351.9C28.63 351.9 0 380.6 0 416s28.63 64 63.1 64s64.08-28.62 64.08-64S99.37 351.9 63.1 351.9z\"\n ]\n};\nvar faFeed = faRss;\nvar faRubleSign = {\n prefix: 'fas',\n iconName: 'ruble-sign',\n icon: [\n 384,\n 512,\n [\n 8381,\n \"rouble\",\n \"rub\",\n \"ruble\"\n ],\n \"f158\",\n \"M240 32C319.5 32 384 96.47 384 176C384 255.5 319.5 320 240 320H128V352H288C305.7 352 320 366.3 320 384C320 401.7 305.7 416 288 416H128V448C128 465.7 113.7 480 96 480C78.33 480 64 465.7 64 448V416H32C14.33 416 0 401.7 0 384C0 366.3 14.33 352 32 352H64V320H32C14.33 320 0 305.7 0 288C0 270.3 14.33 256 32 256H64V64C64 46.33 78.33 32 96 32H240zM320 176C320 131.8 284.2 96 240 96H128V256H240C284.2 256 320 220.2 320 176z\"\n ]\n};\nvar faRouble = faRubleSign;\nvar faRub = faRubleSign;\nvar faRuble = faRubleSign;\nvar faRuler = {\n prefix: 'fas',\n iconName: 'ruler',\n icon: [\n 512,\n 512,\n [\n 128207\n ],\n \"f545\",\n \"M177.9 494.1C159.2 512.8 128.8 512.8 110.1 494.1L17.94 401.9C-.8054 383.2-.8054 352.8 17.94 334.1L68.69 283.3L116.7 331.3C122.9 337.6 133.1 337.6 139.3 331.3C145.6 325.1 145.6 314.9 139.3 308.7L91.31 260.7L132.7 219.3L180.7 267.3C186.9 273.6 197.1 273.6 203.3 267.3C209.6 261.1 209.6 250.9 203.3 244.7L155.3 196.7L196.7 155.3L244.7 203.3C250.9 209.6 261.1 209.6 267.3 203.3C273.6 197.1 273.6 186.9 267.3 180.7L219.3 132.7L260.7 91.31L308.7 139.3C314.9 145.6 325.1 145.6 331.3 139.3C337.6 133.1 337.6 122.9 331.3 116.7L283.3 68.69L334.1 17.94C352.8-.8055 383.2-.8055 401.9 17.94L494.1 110.1C512.8 128.8 512.8 159.2 494.1 177.9L177.9 494.1z\"\n ]\n};\nvar faRulerCombined = {\n prefix: 'fas',\n iconName: 'ruler-combined',\n icon: [\n 512,\n 512,\n [],\n \"f546\",\n \"M0 464V48C0 21.49 21.49 0 48 0H144C170.5 0 192 21.49 192 48V96H112C103.2 96 96 103.2 96 112C96 120.8 103.2 128 112 128H192V192H112C103.2 192 96 199.2 96 208C96 216.8 103.2 224 112 224H192V288H112C103.2 288 96 295.2 96 304C96 312.8 103.2 320 112 320H192V400C192 408.8 199.2 416 208 416C216.8 416 224 408.8 224 400V320H288V400C288 408.8 295.2 416 304 416C312.8 416 320 408.8 320 400V320H384V400C384 408.8 391.2 416 400 416C408.8 416 416 408.8 416 400V320H464C490.5 320 512 341.5 512 368V464C512 490.5 490.5 512 464 512H48C23.15 512 2.706 493.1 .2477 468.9C.0838 467.3 0 465.7 0 464z\"\n ]\n};\nvar faRulerHorizontal = {\n prefix: 'fas',\n iconName: 'ruler-horizontal',\n icon: [\n 640,\n 512,\n [],\n \"f547\",\n \"M0 176C0 149.5 21.49 128 48 128H112V208C112 216.8 119.2 224 128 224C136.8 224 144 216.8 144 208V128H208V208C208 216.8 215.2 224 224 224C232.8 224 240 216.8 240 208V128H304V208C304 216.8 311.2 224 320 224C328.8 224 336 216.8 336 208V128H400V208C400 216.8 407.2 224 416 224C424.8 224 432 216.8 432 208V128H496V208C496 216.8 503.2 224 512 224C520.8 224 528 216.8 528 208V128H592C618.5 128 640 149.5 640 176V336C640 362.5 618.5 384 592 384H48C21.49 384 0 362.5 0 336V176z\"\n ]\n};\nvar faRulerVertical = {\n prefix: 'fas',\n iconName: 'ruler-vertical',\n icon: [\n 256,\n 512,\n [],\n \"f548\",\n \"M0 48C0 21.49 21.49 0 48 0H208C234.5 0 256 21.49 256 48V96H176C167.2 96 160 103.2 160 112C160 120.8 167.2 128 176 128H256V192H176C167.2 192 160 199.2 160 208C160 216.8 167.2 224 176 224H256V288H176C167.2 288 160 295.2 160 304C160 312.8 167.2 320 176 320H256V384H176C167.2 384 160 391.2 160 400C160 408.8 167.2 416 176 416H256V464C256 490.5 234.5 512 208 512H48C21.49 512 0 490.5 0 464V48z\"\n ]\n};\nvar faRupeeSign = {\n prefix: 'fas',\n iconName: 'rupee-sign',\n icon: [\n 448,\n 512,\n [\n 8360,\n \"rupee\"\n ],\n \"f156\",\n \"M.0003 64C.0003 46.33 14.33 32 32 32H112C191.5 32 256 96.47 256 176C256 234.8 220.8 285.3 170.3 307.7L221.7 436.1C228.3 452.5 220.3 471.1 203.9 477.7C187.5 484.3 168.9 476.3 162.3 459.9L106.3 320H64V448C64 465.7 49.67 480 32 480C14.33 480 0 465.7 0 448L.0003 64zM64 256H112C156.2 256 192 220.2 192 176C192 131.8 156.2 96 112 96H64V256zM320.8 282.2C321.3 283.3 322.2 284.8 325 287.1C332.2 292.8 343.7 297.1 362.9 303.8L364.2 304.3C380.3 309.1 402.9 317.9 419.1 332.4C429.5 340.5 437.9 351 443 364.7C448.1 378.4 449.1 393.2 446.8 408.7C442.7 436.8 426.4 457.1 403.1 469.6C381 480.7 354.9 482.1 329.9 477.6L329.7 477.5C320.4 475.8 309.2 471.8 300.5 468.6C294.4 466.3 287.9 463.7 282.7 461.6C280.2 460.6 278.1 459.8 276.4 459.1C259.9 452.7 251.8 434.2 258.2 417.7C264.6 401.2 283.1 393.1 299.6 399.5C302.2 400.5 304.8 401.5 307.5 402.6C312.3 404.5 317.4 406.5 322.9 408.6C331.7 411.9 338.2 413.1 341.6 414.6C357.2 417.5 368.3 415.5 374.5 412.4C379.4 409.9 382.5 406.3 383.5 399.3C384.5 392.4 383.7 388.8 383.1 387.1C382.4 385.4 381.3 383.5 378.6 381.2C371.7 375.4 360.4 370.8 341.6 364.2L338.6 363.1C323.1 357.7 301.6 350.2 285.3 337.2C275.8 329.7 266.1 319.7 261.5 306.3C256.1 292.8 254.9 278.2 257.2 263.1C265.6 205.1 324.2 185.1 374.1 194.2C380.1 195.5 401.4 200 409.5 202.6C426.4 207.8 435.8 225.7 430.6 242.6C425.3 259.5 407.4 268.9 390.5 263.7C385.8 262.2 368.2 258.2 362.6 257.2C347.1 254.5 336.8 256.8 329.1 260.4C323.7 263.7 321.1 267.1 320.5 272.4C319.6 278.4 320.4 281.2 320.8 282.2H320.8z\"\n ]\n};\nvar faRupee = faRupeeSign;\nvar faRupiahSign = {\n prefix: 'fas',\n iconName: 'rupiah-sign',\n icon: [\n 512,\n 512,\n [],\n \"e23d\",\n \"M.0003 64C.0003 46.33 14.33 32 32 32H112C191.5 32 256 96.47 256 176C256 234.8 220.8 285.3 170.3 307.7L221.7 436.1C228.3 452.5 220.3 471.1 203.9 477.7C187.5 484.3 168.9 476.3 162.3 459.9L106.3 320H64V448C64 465.7 49.67 480 32 480C14.33 480 0 465.7 0 448L.0003 64zM64 256H112C156.2 256 192 220.2 192 176C192 131.8 156.2 96 112 96H64V256zM400 160C461.9 160 512 210.1 512 272C512 333.9 461.9 384 400 384H352V480C352 497.7 337.7 512 320 512C302.3 512 288 497.7 288 480V192C288 174.3 302.3 160 320 160H400zM448 272C448 245.5 426.5 224 400 224H352V320H400C426.5 320 448 298.5 448 272z\"\n ]\n};\nvar faS = {\n prefix: 'fas',\n iconName: 's',\n icon: [\n 384,\n 512,\n [\n 115\n ],\n \"53\",\n \"M349.9 379.1c-6.281 36.63-25.89 65.02-56.69 82.11c-24.91 13.83-54.08 18.98-83.73 18.98c-61.86 0-125.8-22.42-157.5-35.38c-16.38-6.672-24.22-25.34-17.55-41.7c6.641-16.36 25.27-24.28 41.7-17.55c77.56 31.64 150.6 39.39 186.1 19.69c13.83-7.672 21.67-19.42 24.69-36.98c7.25-42.31-18.2-56.75-103.7-81.38C112.6 266.6 15.98 238.7 34.11 133.2c5.484-32 23.64-59.36 51.14-77.02c45.59-29.33 115-31.87 206.4-7.688c17.09 4.531 27.27 22.05 22.75 39.13s-22.06 27.23-39.13 22.75C184 86.17 140.4 96.81 119.8 110c-12.55 8.062-20.17 19.5-22.66 34c-7.266 42.31 18.19 56.75 103.7 81.38C271.4 245.7 368 273.5 349.9 379.1z\"\n ]\n};\nvar faSailboat = {\n prefix: 'fas',\n iconName: 'sailboat',\n icon: [\n 576,\n 512,\n [],\n \"e445\",\n \"M256 16C256 9.018 260.5 2.841 267.2 .7414C273.9-1.358 281.1 1.105 285.1 6.826L509.1 326.8C512.5 331.7 512.9 338.1 510.2 343.4C507.4 348.7 501.1 352 496 352H272C263.2 352 256 344.8 256 336V16zM212.1 96.54C219.1 98.4 224 104.7 224 112V336C224 344.8 216.8 352 208 352H80C74.3 352 69.02 348.1 66.16 344C63.3 339.1 63.28 333 66.11 328.1L194.1 104.1C197.7 97.76 205.1 94.68 212.1 96.54V96.54zM5.718 404.3C2.848 394.1 10.52 384 21.12 384H554.9C565.5 384 573.2 394.1 570.3 404.3L566.3 418.7C550.7 473.9 500.4 512 443 512H132.1C75.62 512 25.27 473.9 9.747 418.7L5.718 404.3z\"\n ]\n};\nvar faSatellite = {\n prefix: 'fas',\n iconName: 'satellite',\n icon: [\n 512,\n 512,\n [\n 128752\n ],\n \"f7bf\",\n \"M502.8 264.1l-80.37-80.37l47.87-47.88c13-13.12 13-34.37 0-47.5l-47.5-47.5c-13.12-13.12-34.38-13.12-47.5 0l-47.88 47.88L247.1 9.25C241 3.375 232.9 0 224.5 0c-8.5 0-16.62 3.375-22.5 9.25l-96.75 96.75c-12.38 12.5-12.38 32.62 0 45.12L185.5 231.5L175.8 241.4c-54-24.5-116.3-22.5-168.5 5.375c-8.498 4.625-9.623 16.38-2.873 23.25l107.6 107.5l-17.88 17.75c-2.625-.75-5-1.625-7.75-1.625c-17.75 0-32 14.38-32 32c0 17.75 14.25 32 32 32c17.62 0 32-14.25 32-32c0-2.75-.875-5.125-1.625-7.75l17.75-17.88l107.6 107.6c6.75 6.75 18.62 5.625 23.12-2.875c27.88-52.25 29.88-114.5 5.375-168.5l10-9.873l80.25 80.36c12.5 12.38 32.62 12.38 44.1 0l96.75-96.75C508.6 304.1 512 295.1 512 287.5C512 279.1 508.6 270.1 502.8 264.1zM219.5 197.4L150.6 128.5l73.87-73.75l68.86 68.88L219.5 197.4zM383.5 361.4L314.6 292.5l73.75-73.88l68.88 68.87L383.5 361.4z\"\n ]\n};\nvar faSatelliteDish = {\n prefix: 'fas',\n iconName: 'satellite-dish',\n icon: [\n 512,\n 512,\n [\n 128225\n ],\n \"f7c0\",\n \"M216 104C202.8 104 192 114.8 192 128s10.75 24 24 24c79.41 0 144 64.59 144 144C360 309.3 370.8 320 384 320s24-10.75 24-24C408 190.1 321.9 104 216 104zM224 0C206.3 0 192 14.31 192 32s14.33 32 32 32c123.5 0 224 100.5 224 224c0 17.69 14.33 32 32 32s32-14.31 32-32C512 129.2 382.8 0 224 0zM188.9 346l27.37-27.37c2.625 .625 5.059 1.506 7.809 1.506c17.75 0 31.99-14.26 31.99-32c0-17.62-14.24-32.01-31.99-32.01c-17.62 0-31.99 14.38-31.99 32.01c0 2.875 .8099 5.25 1.56 7.875L166.2 323.4L49.37 206.5c-7.25-7.25-20.12-6-24.1 3c-41.75 77.88-29.88 176.7 35.75 242.4c65.62 65.62 164.6 77.5 242.4 35.75c9.125-5 10.38-17.75 3-25L188.9 346z\"\n ]\n};\nvar faScaleBalanced = {\n prefix: 'fas',\n iconName: 'scale-balanced',\n icon: [\n 640,\n 512,\n [\n 9878,\n \"balance-scale\"\n ],\n \"f24e\",\n \"M554.9 154.5c-17.62-35.25-68.12-35.38-85.87 0c-87 174.3-84.1 165.9-84.1 181.5c0 44.13 57.25 80 128 80s127.1-35.88 127.1-80C639.1 319.9 641.4 327.3 554.9 154.5zM439.1 320l71.96-144l72.17 144H439.1zM256 336c0-16.12 1.375-8.75-85.12-181.5c-17.62-35.25-68.12-35.38-85.87 0c-87 174.3-84.1 165.9-84.1 181.5c0 44.13 57.25 80 127.1 80S256 380.1 256 336zM127.9 176L200.1 320H55.96L127.9 176zM495.1 448h-143.1V153.3C375.5 143 393.1 121.8 398.4 96h113.6c17.67 0 31.1-14.33 31.1-32s-14.33-32-31.1-32h-128.4c-14.62-19.38-37.5-32-63.62-32S270.1 12.62 256.4 32H128C110.3 32 96 46.33 96 64S110.3 96 127.1 96h113.6c5.25 25.75 22.87 47 46.37 57.25V448H144c-26.51 0-48.01 21.49-48.01 48c0 8.836 7.165 16 16 16h416c8.836 0 16-7.164 16-16C544 469.5 522.5 448 495.1 448z\"\n ]\n};\nvar faBalanceScale = faScaleBalanced;\nvar faScaleUnbalanced = {\n prefix: 'fas',\n iconName: 'scale-unbalanced',\n icon: [\n 640,\n 512,\n [\n \"balance-scale-left\"\n ],\n \"f515\",\n \"M85 250.5c-87 174.2-84.1 165.9-84.1 181.5C.0035 476.1 57.25 512 128 512s128-35.88 128-79.1c0-16.12 1.375-8.752-85.12-181.5C153.3 215.3 102.8 215.1 85 250.5zM55.96 416l71.98-143.1l72.15 143.1H55.96zM554.9 122.5c-17.62-35.25-68.08-35.37-85.83 0c-87 174.2-85.04 165.9-85.04 181.5c0 44.12 57.25 79.1 128 79.1s127.1-35.87 127.1-79.1C639.1 287.9 641.4 295.3 554.9 122.5zM439.1 288l72.04-143.1l72.08 143.1H439.1zM495.1 448h-143.1V153.3c20.83-9.117 36.72-26.93 43.78-48.77l126.3-42.11c16.77-5.594 25.83-23.72 20.23-40.48c-5.578-16.73-23.62-25.86-40.48-20.23l-113.3 37.76c-13.94-23.49-39.29-39.41-68.58-39.41c-44.18 0-79.1 35.82-79.1 80c0 2.961 .5587 5.771 .8712 8.648L117.9 129.7C101.1 135.3 92.05 153.4 97.64 170.1c4.469 13.41 16.95 21.88 30.36 21.88c3.344 0 6.768-.5186 10.13-1.644L273.8 145.1C278.2 148.3 282.1 151.1 288 153.3V496C288 504.8 295.2 512 304 512h223.1c8.838 0 16-7.164 16-15.1C543.1 469.5 522.5 448 495.1 448z\"\n ]\n};\nvar faBalanceScaleLeft = faScaleUnbalanced;\nvar faScaleUnbalancedFlip = {\n prefix: 'fas',\n iconName: 'scale-unbalanced-flip',\n icon: [\n 640,\n 512,\n [\n \"balance-scale-right\"\n ],\n \"f516\",\n \"M554.9 250.5c-17.62-35.37-68.12-35.25-85.87 0c-86.38 172.7-85.04 165.4-85.04 181.5C383.1 476.1 441.3 512 512 512s127.1-35.88 127.1-79.1C639.1 416.4 642 424.7 554.9 250.5zM439.9 416l72.15-143.1l71.98 143.1H439.9zM512 192c13.41 0 25.89-8.471 30.36-21.88c5.594-16.76-3.469-34.89-20.23-40.48l-122.1-40.1c.3125-2.877 .8712-5.687 .8712-8.648c0-44.18-35.81-80-79.1-80c-29.29 0-54.65 15.92-68.58 39.41l-113.3-37.76C121.3-3.963 103.2 5.162 97.64 21.9C92.05 38.66 101.1 56.78 117.9 62.38l126.3 42.11c7.061 21.84 22.95 39.65 43.78 48.77v294.7H144c-26.51 0-47.1 21.49-47.1 47.1C96 504.8 103.2 512 112 512h223.1c8.836 0 15.1-7.164 15.1-15.1V153.3c5.043-2.207 9.756-4.965 14.19-8.115l135.7 45.23C505.2 191.5 508.7 192 512 192zM256 304c0-15.62 1.1-7.252-85.12-181.5c-17.62-35.37-68.08-35.25-85.83 0c-86.38 172.7-85.04 165.4-85.04 181.5c0 44.12 57.25 79.1 127.1 79.1S256 348.1 256 304zM128 144l72.04 143.1H55.92L128 144z\"\n ]\n};\nvar faBalanceScaleRight = faScaleUnbalancedFlip;\nvar faSchool = {\n prefix: 'fas',\n iconName: 'school',\n icon: [\n 640,\n 512,\n [\n 127979\n ],\n \"f549\",\n \"M320 128C328.8 128 336 135.2 336 144V160H352C360.8 160 368 167.2 368 176C368 184.8 360.8 192 352 192H320C311.2 192 304 184.8 304 176V144C304 135.2 311.2 128 320 128zM476.8 98.06L602.4 125.1C624.4 130.9 640 150.3 640 172.8V464C640 490.5 618.5 512 592 512H48C21.49 512 0 490.5 0 464V172.8C0 150.3 15.63 130.9 37.59 125.1L163.2 98.06L302.2 5.374C312.1-1.791 327-1.791 337.8 5.374L476.8 98.06zM256 512H384V416C384 380.7 355.3 352 320 352C284.7 352 256 380.7 256 416V512zM96 192C87.16 192 80 199.2 80 208V272C80 280.8 87.16 288 96 288H128C136.8 288 144 280.8 144 272V208C144 199.2 136.8 192 128 192H96zM496 272C496 280.8 503.2 288 512 288H544C552.8 288 560 280.8 560 272V208C560 199.2 552.8 192 544 192H512C503.2 192 496 199.2 496 208V272zM96 320C87.16 320 80 327.2 80 336V400C80 408.8 87.16 416 96 416H128C136.8 416 144 408.8 144 400V336C144 327.2 136.8 320 128 320H96zM496 400C496 408.8 503.2 416 512 416H544C552.8 416 560 408.8 560 400V336C560 327.2 552.8 320 544 320H512C503.2 320 496 327.2 496 336V400zM320 88C271.4 88 232 127.4 232 176C232 224.6 271.4 264 320 264C368.6 264 408 224.6 408 176C408 127.4 368.6 88 320 88z\"\n ]\n};\nvar faScissors = {\n prefix: 'fas',\n iconName: 'scissors',\n icon: [\n 512,\n 512,\n [\n 9986,\n 9988,\n 9984,\n \"cut\"\n ],\n \"f0c4\",\n \"M396.8 51.2C425.1 22.92 470.9 22.92 499.2 51.2C506.3 58.27 506.3 69.73 499.2 76.8L216.5 359.5C221.3 372.1 224 385.7 224 400C224 461.9 173.9 512 112 512C50.14 512 0 461.9 0 400C0 338.1 50.14 287.1 112 287.1C126.3 287.1 139.9 290.7 152.5 295.5L191.1 255.1L152.5 216.5C139.9 221.3 126.3 224 112 224C50.14 224 0 173.9 0 112C0 50.14 50.14 0 112 0C173.9 0 224 50.14 224 112C224 126.3 221.3 139.9 216.5 152.5L255.1 191.1L396.8 51.2zM160 111.1C160 85.49 138.5 63.1 112 63.1C85.49 63.1 64 85.49 64 111.1C64 138.5 85.49 159.1 112 159.1C138.5 159.1 160 138.5 160 111.1zM112 448C138.5 448 160 426.5 160 400C160 373.5 138.5 352 112 352C85.49 352 64 373.5 64 400C64 426.5 85.49 448 112 448zM278.6 342.6L342.6 278.6L499.2 435.2C506.3 442.3 506.3 453.7 499.2 460.8C470.9 489.1 425.1 489.1 396.8 460.8L278.6 342.6z\"\n ]\n};\nvar faCut = faScissors;\nvar faScrewdriver = {\n prefix: 'fas',\n iconName: 'screwdriver',\n icon: [\n 512,\n 512,\n [\n 129691\n ],\n \"f54a\",\n \"M128 278.6l-117.1 116.9c-14.5 14.62-14.5 38.29 0 52.79l52.75 52.75c14.5 14.5 38.17 14.5 52.79 0L233.4 384c29.12-29.12 29.12-76.25 0-105.4S157.1 249.5 128 278.6zM447.1 0l-128 96L320 158L237 241.1C243.8 245.4 250.3 250.1 256 256c5.875 5.75 10.62 12.25 14.88 19L353.1 192h61.99l95.1-128L447.1 0z\"\n ]\n};\nvar faScrewdriverWrench = {\n prefix: 'fas',\n iconName: 'screwdriver-wrench',\n icon: [\n 512,\n 512,\n [\n \"tools\"\n ],\n \"f7d9\",\n \"M331.8 224.1c28.29 0 54.88 10.99 74.86 30.97l19.59 19.59c40.01-17.74 71.25-53.3 81.62-96.65c5.725-23.92 5.34-47.08 .2148-68.4c-2.613-10.88-16.43-14.51-24.34-6.604l-68.9 68.9h-75.6V97.2l68.9-68.9c7.912-7.912 4.275-21.73-6.604-24.34c-21.32-5.125-44.48-5.51-68.4 .2148c-55.3 13.23-98.39 60.22-107.2 116.4C224.5 128.9 224.2 137 224.3 145l82.78 82.86C315.2 225.1 323.5 224.1 331.8 224.1zM384 278.6c-23.16-23.16-57.57-27.57-85.39-13.9L191.1 158L191.1 95.99l-127.1-95.99L0 63.1l96 127.1l62.04 .0077l106.7 106.6c-13.67 27.82-9.251 62.23 13.91 85.39l117 117.1c14.62 14.5 38.21 14.5 52.71-.0016l52.75-52.75c14.5-14.5 14.5-38.08-.0016-52.71L384 278.6zM227.9 307L168.7 247.9l-148.9 148.9c-26.37 26.37-26.37 69.08 0 95.45C32.96 505.4 50.21 512 67.5 512s34.54-6.592 47.72-19.78l119.1-119.1C225.5 352.3 222.6 329.4 227.9 307zM64 472c-13.25 0-24-10.75-24-24c0-13.26 10.75-24 24-24S88 434.7 88 448C88 461.3 77.25 472 64 472z\"\n ]\n};\nvar faTools = faScrewdriverWrench;\nvar faScroll = {\n prefix: 'fas',\n iconName: 'scroll',\n icon: [\n 576,\n 512,\n [\n 128220\n ],\n \"f70e\",\n \"M48 32C21.5 32 0 53.5 0 80v64C0 152.9 7.125 160 16 160H96V80C96 53.5 74.5 32 48 32zM256 380.6V320h224V128c0-53-43-96-96-96H111.6C121.8 45.38 128 61.88 128 80V384c0 38.88 34.62 69.63 74.75 63.13C234.3 442 256 412.5 256 380.6zM288 352v32c0 52.88-43 96-96 96h272c61.88 0 112-50.13 112-112c0-8.875-7.125-16-16-16H288z\"\n ]\n};\nvar faScrollTorah = {\n prefix: 'fas',\n iconName: 'scroll-torah',\n icon: [\n 640,\n 512,\n [\n \"torah\"\n ],\n \"f6a0\",\n \"M320 366.5l17.75-29.62l-35.5 .0011L320 366.5zM382.5 311.5l36.75-.0011l-18.38-30.75L382.5 311.5zM48 0C21.5 0 0 14.38 0 32v448c0 17.62 21.5 32 48 32S96 497.6 96 480V32C96 14.38 74.5 0 48 0zM419.2 200.5L382.4 200.5l18.5 30.79L419.2 200.5zM220.8 311.5l36.87-.0012l-18.5-30.87L220.8 311.5zM287.1 311.5L352.9 311.5l33.25-55.5l-33.25-55.5L287.1 200.5L253.9 256L287.1 311.5zM592 0C565.5 0 544 14.38 544 32v448c0 17.62 21.5 32 48 32s48-14.38 48-32V32C640 14.38 618.5 0 592 0zM128 480h384V32H128V480zM194.8 185.9c3.75-6.625 10.87-10.75 18.5-10.75L272.7 175.1l29.12-48.67C305.6 119.1 312.6 116.1 319.1 116.1c7.375-.125 14.25 3.916 17.1 10.17l29.25 48.87l59.5-.0019c7.625 0 14.62 4.124 18.38 10.75s3.626 14.75-.2493 21.25l-29.25 48.87l29.38 48.1c4 6.5 4.001 14.62 .2506 21.12c-3.75 6.625-10.87 10.75-18.5 10.75l-59.5 .0019l-29.12 48.67c-3.75 6.5-10.62 10.33-18.12 10.46c-7.375 0-14.25-3.874-18-10.25l-29.25-48.87l-59.5 .0019c-7.625 0-14.62-4.124-18.37-10.75S191.3 311.4 195.1 304.9l29.25-48.87L195 207C191.1 200.5 191 192.4 194.8 185.9zM319.1 145.5L302.2 175.1l35.37-.0011L319.1 145.5zM257.5 200.5L220.8 200.5l18.38 30.83L257.5 200.5z\"\n ]\n};\nvar faTorah = faScrollTorah;\nvar faSdCard = {\n prefix: 'fas',\n iconName: 'sd-card',\n icon: [\n 384,\n 512,\n [],\n \"f7c2\",\n \"M320 0H128L0 128v320c0 35.25 28.75 64 64 64h256c35.25 0 64-28.75 64-64V64C384 28.75 355.3 0 320 0zM160 160H112V64H160V160zM240 160H192V64h48V160zM320 160h-48V64H320V160z\"\n ]\n};\nvar faSection = {\n prefix: 'fas',\n iconName: 'section',\n icon: [\n 256,\n 512,\n [],\n \"e447\",\n \"M224.5 337.4c15.66-14.28 26.09-33.12 29.8-55.82c14.46-88.44-64.67-112.4-117-128.2L124.7 149.5C65.67 131.2 61.11 119.4 64.83 96.79c1.531-9.344 5.715-16.19 13.21-21.56c14.74-10.56 39.94-13.87 69.23-9.029c10.74 1.75 24.36 5.686 41.66 12.03c16.58 6 34.98-2.438 41.04-19.06c6.059-16.59-2.467-34.97-19.05-41.06c-21.39-7.842-38.35-12.62-53.28-15.06c-46.47-7.781-88.1-.5313-116.9 20.19C19.46 38.52 5.965 60.39 1.686 86.48C-5.182 128.6 9.839 156 31.47 174.7C15.87 188.1 5.406 207.8 1.686 230.5C-12.59 317.9 67.36 342.7 105.7 354.6l12.99 3.967c64.71 19.56 76.92 29.09 72.42 56.59c-1.279 7.688-4.84 18.75-21.23 26.16c-15.27 6.906-37.01 8.406-61.4 4.469c-16.74-2.656-37.32-10.5-55.49-17.41l-9.773-3.719c-16.52-6.156-34.95 2.25-41.16 18.75c-6.184 16.56 2.186 34.1 18.74 41.19l9.463 3.594c21.05 8 44.94 17.12 68.02 20.75c12.21 2.031 24.14 3.032 35.54 3.032c23.17 0 44.28-4.157 62.4-12.34c31.95-14.44 52.53-40.75 58.02-74.12C261.1 383.6 246.8 356.3 224.5 337.4zM64.83 240.8c3.303-20.28 21.22-28.1 38.09-31.04c.9258 .2891 15.81 4.852 15.81 4.852c64.71 19.56 76.92 29.09 72.39 56.62c-3.291 20.2-21.12 28.07-37.93 31.04c-5.488-1.746-28.49-8.754-28.49-8.754C65.67 275.2 61.11 263.4 64.83 240.8z\"\n ]\n};\nvar faSeedling = {\n prefix: 'fas',\n iconName: 'seedling',\n icon: [\n 512,\n 512,\n [\n 127793,\n \"sprout\"\n ],\n \"f4d8\",\n \"M64 95.1H0c0 123.8 100.3 224 224 224v128C224 465.6 238.4 480 255.1 480S288 465.6 288 448V320C288 196.3 187.7 95.1 64 95.1zM448 32c-84.25 0-157.4 46.5-195.8 115.3c27.75 30.12 48.25 66.88 59 107.5C424 243.1 512 147.9 512 32H448z\"\n ]\n};\nvar faSprout = faSeedling;\nvar faServer = {\n prefix: 'fas',\n iconName: 'server',\n icon: [\n 512,\n 512,\n [],\n \"f233\",\n \"M480 288H32c-17.62 0-32 14.38-32 32v128c0 17.62 14.38 32 32 32h448c17.62 0 32-14.38 32-32v-128C512 302.4 497.6 288 480 288zM352 408c-13.25 0-24-10.75-24-24s10.75-24 24-24s24 10.75 24 24S365.3 408 352 408zM416 408c-13.25 0-24-10.75-24-24s10.75-24 24-24s24 10.75 24 24S429.3 408 416 408zM480 32H32C14.38 32 0 46.38 0 64v128c0 17.62 14.38 32 32 32h448c17.62 0 32-14.38 32-32V64C512 46.38 497.6 32 480 32zM352 152c-13.25 0-24-10.75-24-24S338.8 104 352 104S376 114.8 376 128S365.3 152 352 152zM416 152c-13.25 0-24-10.75-24-24S402.8 104 416 104S440 114.8 440 128S429.3 152 416 152z\"\n ]\n};\nvar faShapes = {\n prefix: 'fas',\n iconName: 'shapes',\n icon: [\n 512,\n 512,\n [\n \"triangle-circle-square\"\n ],\n \"f61f\",\n \"M411.4 175.5C417.4 185.4 417.5 197.7 411.8 207.8C406.2 217.8 395.5 223.1 384 223.1H192C180.5 223.1 169.8 217.8 164.2 207.8C158.5 197.7 158.6 185.4 164.6 175.5L260.6 15.54C266.3 5.897 276.8 0 288 0C299.2 0 309.7 5.898 315.4 15.54L411.4 175.5zM288 312C288 289.9 305.9 272 328 272H472C494.1 272 512 289.9 512 312V456C512 478.1 494.1 496 472 496H328C305.9 496 288 478.1 288 456V312zM0 384C0 313.3 57.31 256 128 256C198.7 256 256 313.3 256 384C256 454.7 198.7 512 128 512C57.31 512 0 454.7 0 384z\"\n ]\n};\nvar faTriangleCircleSquare = faShapes;\nvar faShare = {\n prefix: 'fas',\n iconName: 'share',\n icon: [\n 512,\n 512,\n [\n \"arrow-turn-right\",\n \"mail-forward\"\n ],\n \"f064\",\n \"M503.7 226.2l-176 151.1c-15.38 13.3-39.69 2.545-39.69-18.16V272.1C132.9 274.3 66.06 312.8 111.4 457.8c5.031 16.09-14.41 28.56-28.06 18.62C39.59 444.6 0 383.8 0 322.3c0-152.2 127.4-184.4 288-186.3V56.02c0-20.67 24.28-31.46 39.69-18.16l176 151.1C514.8 199.4 514.8 216.6 503.7 226.2z\"\n ]\n};\nvar faArrowTurnRight = faShare;\nvar faMailForward = faShare;\nvar faShareFromSquare = {\n prefix: 'fas',\n iconName: 'share-from-square',\n icon: [\n 576,\n 512,\n [\n 61509,\n \"share-square\"\n ],\n \"f14d\",\n \"M568.9 143.5l-150.9-138.2C404.8-6.773 384 3.039 384 21.84V96C241.2 97.63 128 126.1 128 260.6c0 54.3 35.2 108.1 74.08 136.2c12.14 8.781 29.42-2.238 24.94-16.46C186.7 252.2 256 224 384 223.1v74.2c0 18.82 20.84 28.59 34.02 16.51l150.9-138.2C578.4 167.8 578.4 152.2 568.9 143.5zM416 384c-17.67 0-32 14.33-32 32v31.1l-320-.0013V128h32c17.67 0 32-14.32 32-32S113.7 64 96 64H64C28.65 64 0 92.65 0 128v319.1c0 35.34 28.65 64 64 64l320-.0013c35.35 0 64-28.66 64-64V416C448 398.3 433.7 384 416 384z\"\n ]\n};\nvar faShareSquare = faShareFromSquare;\nvar faShareNodes = {\n prefix: 'fas',\n iconName: 'share-nodes',\n icon: [\n 448,\n 512,\n [\n \"share-alt\"\n ],\n \"f1e0\",\n \"M448 127.1C448 181 405 223.1 352 223.1C326.1 223.1 302.6 213.8 285.4 197.1L191.3 244.1C191.8 248 191.1 251.1 191.1 256C191.1 260 191.8 263.1 191.3 267.9L285.4 314.9C302.6 298.2 326.1 288 352 288C405 288 448 330.1 448 384C448 437 405 480 352 480C298.1 480 256 437 256 384C256 379.1 256.2 376 256.7 372.1L162.6 325.1C145.4 341.8 121.9 352 96 352C42.98 352 0 309 0 256C0 202.1 42.98 160 96 160C121.9 160 145.4 170.2 162.6 186.9L256.7 139.9C256.2 135.1 256 132 256 128C256 74.98 298.1 32 352 32C405 32 448 74.98 448 128L448 127.1zM95.1 287.1C113.7 287.1 127.1 273.7 127.1 255.1C127.1 238.3 113.7 223.1 95.1 223.1C78.33 223.1 63.1 238.3 63.1 255.1C63.1 273.7 78.33 287.1 95.1 287.1zM352 95.1C334.3 95.1 320 110.3 320 127.1C320 145.7 334.3 159.1 352 159.1C369.7 159.1 384 145.7 384 127.1C384 110.3 369.7 95.1 352 95.1zM352 416C369.7 416 384 401.7 384 384C384 366.3 369.7 352 352 352C334.3 352 320 366.3 320 384C320 401.7 334.3 416 352 416z\"\n ]\n};\nvar faShareAlt = faShareNodes;\nvar faShekelSign = {\n prefix: 'fas',\n iconName: 'shekel-sign',\n icon: [\n 448,\n 512,\n [\n 8362,\n \"ils\",\n \"shekel\",\n \"sheqel\",\n \"sheqel-sign\"\n ],\n \"f20b\",\n \"M192 32C262.7 32 320 89.31 320 160V320C320 337.7 305.7 352 288 352C270.3 352 256 337.7 256 320V160C256 124.7 227.3 96 192 96H64V448C64 465.7 49.67 480 32 480C14.33 480 0 465.7 0 448V64C0 46.33 14.33 32 32 32H192zM160 480C142.3 480 128 465.7 128 448V192C128 174.3 142.3 160 160 160C177.7 160 192 174.3 192 192V416H320C355.3 416 384 387.3 384 352V64C384 46.33 398.3 32 416 32C433.7 32 448 46.33 448 64V352C448 422.7 390.7 480 320 480H160z\"\n ]\n};\nvar faIls = faShekelSign;\nvar faShekel = faShekelSign;\nvar faSheqel = faShekelSign;\nvar faSheqelSign = faShekelSign;\nvar faShield = {\n prefix: 'fas',\n iconName: 'shield',\n icon: [\n 512,\n 512,\n [\n 128737\n ],\n \"f132\",\n \"M466.5 83.71l-192-80C269.6 1.67 261.3 0 256 0C250.7 0 242.5 1.67 237.6 3.702l-192 80C27.7 91.1 16 108.6 16 127.1c0 257.2 189.2 384 239.1 384c51.1 0 240-128.2 240-384C496 108.6 484.3 91.1 466.5 83.71zM256 446.5l.0234-381.1c.0059-.0234 0 0 0 0l175.9 73.17C427.8 319.7 319 417.1 256 446.5z\"\n ]\n};\nvar faShieldBlank = {\n prefix: 'fas',\n iconName: 'shield-blank',\n icon: [\n 512,\n 512,\n [\n \"shield-alt\"\n ],\n \"f3ed\",\n \"M496 127.1C496 381.3 309.1 512 255.1 512C204.9 512 16 385.3 16 127.1c0-19.41 11.7-36.89 29.61-44.28l191.1-80.01c4.906-2.031 13.13-3.701 18.44-3.701c5.281 0 13.58 1.67 18.46 3.701l192 80.01C484.3 91.1 496 108.6 496 127.1z\"\n ]\n};\nvar faShieldAlt = faShieldBlank;\nvar faShieldVirus = {\n prefix: 'fas',\n iconName: 'shield-virus',\n icon: [\n 512,\n 512,\n [],\n \"e06c\",\n \"M288 255.1c-8.836 0-16 7.162-16 16c0 8.836 7.164 15.1 16 15.1s16-7.163 16-15.1C304 263.2 296.8 255.1 288 255.1zM224 191.1c-8.836 0-16 7.162-16 16c0 8.836 7.164 16 15.1 16s16-7.164 16-16C240 199.2 232.8 191.1 224 191.1zM466.5 83.68l-192-80.01C269.6 1.641 261.3 0 256.1 0C250.7 0 242.5 1.641 237.6 3.672l-192 80.01C27.69 91.07 16 108.6 16 127.1C16 385.2 205.2 512 255.9 512c52.02 0 240.1-128.2 240.1-384C496 108.6 484.3 91.07 466.5 83.68zM384 255.1h-12.12c-19.29 0-32.06 15.78-32.06 32.23c0 7.862 2.918 15.88 9.436 22.4l8.576 8.576c3.125 3.125 4.688 7.218 4.688 11.31c0 8.527-6.865 15.1-16 15.1c-4.094 0-8.188-1.562-11.31-4.688l-8.576-8.576c-6.519-6.519-14.53-9.436-22.4-9.436c-16.45 0-32.23 12.77-32.23 32.06v12.12c0 8.844-7.156 16-16 16s-16-7.156-16-16v-12.12c0-19.29-15.78-32.06-32.23-32.06c-7.862 0-15.87 2.917-22.39 9.436l-8.576 8.576c-3.125 3.125-7.219 4.688-11.31 4.688c-9.139 0-16-7.473-16-15.1c0-4.094 1.562-8.187 4.688-11.31l8.576-8.576c6.519-6.519 9.436-14.53 9.436-22.4c0-16.45-12.77-32.23-32.06-32.23H128c-8.844 0-16-7.156-16-16s7.156-16 16-16h12.12c19.29 0 32.06-15.78 32.06-32.23c0-7.862-2.918-15.88-9.436-22.4L154.2 160.8C151 157.7 149.5 153.6 149.5 149.5c0-8.527 6.865-15.1 16-15.1c4.094 0 8.188 1.562 11.31 4.688L185.4 146.7C191.9 153.3 199.9 156.2 207.8 156.2c16.45 0 32.23-12.77 32.23-32.07V111.1c0-8.844 7.156-16 16-16s16 7.156 16 16v12.12c0 19.29 15.78 32.07 32.23 32.07c7.862 0 15.88-2.917 22.4-9.436l8.576-8.577c3.125-3.125 7.219-4.688 11.31-4.688c9.139 0 16 7.473 16 15.1c0 4.094-1.562 8.187-4.688 11.31l-8.576 8.577c-6.519 6.519-9.436 14.53-9.436 22.4c0 16.45 12.77 32.23 32.06 32.23h12.12c8.844 0 16 7.156 16 16S392.8 255.1 384 255.1z\"\n ]\n};\nvar faShip = {\n prefix: 'fas',\n iconName: 'ship',\n icon: [\n 576,\n 512,\n [\n 128674\n ],\n \"f21a\",\n \"M192 32C192 14.33 206.3 0 224 0H352C369.7 0 384 14.33 384 32V64H432C458.5 64 480 85.49 480 112V240L524.4 254.8C547.6 262.5 553.9 292.3 535.9 308.7L434.9 401.4C418.7 410.7 400.2 416.5 384 416.5C364.4 416.5 343.2 408.8 324.8 396.1C302.8 380.6 273.3 380.6 251.2 396.1C234 407.9 213.2 416.5 192 416.5C175.8 416.5 157.3 410.7 141.1 401.3L40.09 308.7C22.1 292.3 28.45 262.5 51.59 254.8L96 239.1V111.1C96 85.49 117.5 63.1 144 63.1H192V32zM160 218.7L267.8 182.7C280.9 178.4 295.1 178.4 308.2 182.7L416 218.7V128H160V218.7zM384 448C410.9 448 439.4 437.2 461.4 421.9L461.5 421.9C473.4 413.4 489.5 414.1 500.7 423.6C515 435.5 533.2 444.6 551.3 448.8C568.5 452.8 579.2 470.1 575.2 487.3C571.2 504.5 553.1 515.2 536.7 511.2C512.2 505.4 491.9 494.6 478.5 486.2C449.5 501.7 417 512 384 512C352.1 512 323.4 502.1 303.6 493.1C297.7 490.5 292.5 487.8 288 485.4C283.5 487.8 278.3 490.5 272.4 493.1C252.6 502.1 223.9 512 192 512C158.1 512 126.5 501.7 97.5 486.2C84.12 494.6 63.79 505.4 39.27 511.2C22.06 515.2 4.853 504.5 .8422 487.3C-3.169 470.1 7.532 452.8 24.74 448.8C42.84 444.6 60.96 435.5 75.31 423.6C86.46 414.1 102.6 413.4 114.5 421.9L114.6 421.9C136.7 437.2 165.1 448 192 448C219.5 448 247 437.4 269.5 421.9C280.6 414 295.4 414 306.5 421.9C328.1 437.4 356.5 448 384 448H384z\"\n ]\n};\nvar faShirt = {\n prefix: 'fas',\n iconName: 'shirt',\n icon: [\n 640,\n 512,\n [\n 128085,\n \"t-shirt\",\n \"tshirt\"\n ],\n \"f553\",\n \"M640 162.8c0 6.917-2.293 13.88-7.012 19.7l-49.96 61.63c-6.32 7.796-15.62 11.85-25.01 11.85c-7.01 0-14.07-2.262-19.97-6.919L480 203.3V464c0 26.51-21.49 48-48 48H208C181.5 512 160 490.5 160 464V203.3L101.1 249.1C96.05 253.7 88.99 255.1 81.98 255.1c-9.388 0-18.69-4.057-25.01-11.85L7.012 182.5C2.292 176.7-.0003 169.7-.0003 162.8c0-9.262 4.111-18.44 12.01-24.68l135-106.6C159.8 21.49 175.7 16 191.1 16H225.6C233.3 61.36 272.5 96 320 96s86.73-34.64 94.39-80h33.6c16.35 0 32.22 5.49 44.99 15.57l135 106.6C635.9 144.4 640 153.6 640 162.8z\"\n ]\n};\nvar faTShirt = faShirt;\nvar faTshirt = faShirt;\nvar faShoePrints = {\n prefix: 'fas',\n iconName: 'shoe-prints',\n icon: [\n 640,\n 512,\n [],\n \"f54b\",\n \"M192 159.1L224 159.1V32L192 32c-35.38 0-64 28.62-64 63.1S156.6 159.1 192 159.1zM0 415.1c0 35.37 28.62 64.01 64 64.01l32-.0103v-127.1l-32-.0005C28.62 351.1 0 380.6 0 415.1zM337.5 287.1c-35 0-76.25 13.12-104.8 31.1C208 336.4 188.3 351.1 128 351.1v128l57.5 15.98c26.25 7.25 53 13.13 80.38 15.01c32.63 2.375 65.63 .743 97.5-6.132C472.9 481.2 512 429.2 512 383.1C512 319.1 427.9 287.1 337.5 287.1zM491.4 7.252c-31.88-6.875-64.88-8.625-97.5-6.25C366.5 2.877 339.8 8.752 313.5 16L256 32V159.1c60.25 0 80 15.62 104.8 31.1c28.5 18.87 69.75 31.1 104.8 31.1C555.9 223.1 640 191.1 640 127.1C640 82.75 600.9 30.75 491.4 7.252z\"\n ]\n};\nvar faShop = {\n prefix: 'fas',\n iconName: 'shop',\n icon: [\n 640,\n 512,\n [\n \"store-alt\"\n ],\n \"f54f\",\n \"M0 155.2C0 147.9 2.153 140.8 6.188 134.7L81.75 21.37C90.65 8.021 105.6 0 121.7 0H518.3C534.4 0 549.3 8.021 558.2 21.37L633.8 134.7C637.8 140.8 640 147.9 640 155.2C640 175.5 623.5 192 603.2 192H36.84C16.5 192 .0003 175.5 .0003 155.2H0zM64 224H128V384H320V224H384V464C384 490.5 362.5 512 336 512H112C85.49 512 64 490.5 64 464V224zM512 224H576V480C576 497.7 561.7 512 544 512C526.3 512 512 497.7 512 480V224z\"\n ]\n};\nvar faStoreAlt = faShop;\nvar faShopSlash = {\n prefix: 'fas',\n iconName: 'shop-slash',\n icon: [\n 640,\n 512,\n [\n \"store-alt-slash\"\n ],\n \"e070\",\n \"M74.13 32.8L81.75 21.38C90.65 8.022 105.6 .001 121.7 .001H518.3C534.4 .001 549.3 8.022 558.2 21.38L633.8 134.7C637.8 140.8 640 147.9 640 155.2C640 175.5 623.5 192 603.2 192H277.3L320 225.5V224H384V275.7L512 375.1V224H576V426.2L630.8 469.1C641.2 477.3 643.1 492.4 634.9 502.8C626.7 513.2 611.6 515.1 601.2 506.9L9.196 42.89C-1.236 34.71-3.065 19.63 5.112 9.196C13.29-1.236 28.37-3.065 38.81 5.112L74.13 32.8zM0 155.2C0 147.9 2.153 140.8 6.188 134.7L20.98 112.5L121.8 192H36.84C16.5 192 .0003 175.5 .0003 155.2H0zM320 384V348.1L384 398.5V464C384 490.5 362.5 512 336 512H112C85.49 512 64 490.5 64 464V224H128V384H320z\"\n ]\n};\nvar faStoreAltSlash = faShopSlash;\nvar faShower = {\n prefix: 'fas',\n iconName: 'shower',\n icon: [\n 512,\n 512,\n [\n 128703\n ],\n \"f2cc\",\n \"M288 384c-17.67 0-32 14.33-32 32c0 17.67 14.33 32 32 32s32-14.33 32-32C320 398.3 305.7 384 288 384zM416 256c-17.67 0-32 14.33-32 32c0 17.67 14.33 32 32 32s32-14.33 32-32C448 270.3 433.7 256 416 256zM480 192c-17.67 0-32 14.33-32 32c0 17.67 14.33 32 32 32s32-14.33 32-32C512 206.3 497.7 192 480 192zM288 320c0-17.67-14.33-32-32-32s-32 14.33-32 32c0 17.67 14.33 32 32 32S288 337.7 288 320zM320 224c-17.67 0-32 14.33-32 32c0 17.67 14.33 32 32 32s32-14.33 32-32C352 238.3 337.7 224 320 224zM384 224c17.67 0 32-14.33 32-32c0-17.67-14.33-32-32-32s-32 14.33-32 32C352 209.7 366.3 224 384 224zM352 320c-17.67 0-32 14.33-32 32c0 17.67 14.33 32 32 32s32-14.33 32-32C384 334.3 369.7 320 352 320zM347.3 91.31l-11.31-11.31c-6.248-6.248-16.38-6.248-22.63 0l-6.631 6.631c-35.15-26.29-81.81-29.16-119.6-8.779L170.5 61.25C132.2 22.95 63.65 18.33 21.98 71.16C7.027 90.11 0 114.3 0 138.4V464C0 472.8 7.164 480 16 480h32C56.84 480 64 472.8 64 464V131.9c0-19.78 16.09-35.87 35.88-35.87c9.438 0 18.69 3.828 25.38 10.5l16.61 16.61C121.5 160.9 124.3 207.6 150.6 242.7L144 249.4c-6.248 6.248-6.248 16.38 0 22.63l11.31 11.31c6.248 6.25 16.38 6.25 22.63 0l169.4-169.4C353.6 107.7 353.6 97.56 347.3 91.31z\"\n ]\n};\nvar faShrimp = {\n prefix: 'fas',\n iconName: 'shrimp',\n icon: [\n 512,\n 512,\n [\n 129424\n ],\n \"e448\",\n \"M288 320V128H64C46.34 128 32 113.6 32 96s14.34-32 32-32h368c8.844 0 16-7.156 16-16s-7.156-16-16-16H64C28.72 32 0 60.7 0 96s28.72 64 64 64h2.879c15.26 90.77 94.01 160 189.1 160H288zM192 216c-13.25 0-24-10.75-24-24c0-13.26 10.75-24 24-24s24 10.74 24 24C216 205.3 205.3 216 192 216zM225.6 399.4c-4.75 12.36 1.406 26.25 13.78 31.02l5.688 2.188C233.3 434.1 224 443.8 224 456c0 13.25 10.75 24 24 24h72v-70.03l-63.38-24.38C244.3 380.9 230.4 386.1 225.6 399.4zM511.2 286.7c-.5488-5.754-2.201-11.1-3.314-16.65l-124.6 90.62c.3711 2.404 .7383 4.814 .7383 7.322c0 1.836-.3379 3.576-.5391 5.357l90.15 40.06C500.8 379.2 515.8 334.8 511.2 286.7zM352 413.1v66.08c37.23-3.363 71.04-18.3 97.94-41.21l-80.34-35.71C364.7 407.1 358.6 410.7 352 413.1zM497.9 237.7C470.1 172.4 402.8 128 328.4 128h-8.436v192h16c12.28 0 23.36 4.748 31.85 12.33L497.9 237.7z\"\n ]\n};\nvar faShuffle = {\n prefix: 'fas',\n iconName: 'shuffle',\n icon: [\n 512,\n 512,\n [\n 128256,\n \"random\"\n ],\n \"f074\",\n \"M424.1 287c-15.13-15.12-40.1-4.426-40.1 16.97V352H336L153.6 108.8C147.6 100.8 138.1 96 128 96H32C14.31 96 0 110.3 0 128s14.31 32 32 32h80l182.4 243.2C300.4 411.3 309.9 416 320 416h63.97v47.94c0 21.39 25.86 32.12 40.99 17l79.1-79.98c9.387-9.387 9.387-24.59 0-33.97L424.1 287zM336 160h47.97v48.03c0 21.39 25.87 32.09 40.1 16.97l79.1-79.98c9.387-9.391 9.385-24.59-.0013-33.97l-79.1-79.98c-15.13-15.12-40.99-4.391-40.99 17V96H320c-10.06 0-19.56 4.75-25.59 12.81L254 162.7L293.1 216L336 160zM112 352H32c-17.69 0-32 14.31-32 32s14.31 32 32 32h96c10.06 0 19.56-4.75 25.59-12.81l40.4-53.87L154 296L112 352z\"\n ]\n};\nvar faRandom = faShuffle;\nvar faShuttleSpace = {\n prefix: 'fas',\n iconName: 'shuttle-space',\n icon: [\n 640,\n 512,\n [\n \"space-shuttle\"\n ],\n \"f197\",\n \"M129.1 480H128V384H352L245.2 448.1C210.4 468.1 170.6 480 129.1 480zM352 128H128V32H129.1C170.6 32 210.4 43.03 245.2 63.92L352 128zM104 128C130.2 128 153.4 140.6 168 160H456C525.3 160 591 182.7 635.2 241.6C641.6 250.1 641.6 261.9 635.2 270.4C591 329.3 525.3 352 456 352H168C153.4 371.4 130.2 384 104 384H96V480H80C53.49 480 32 458.5 32 432V384H40C17.91 384 0 366.1 0 344V168C0 145.9 17.89 128 39.96 128H32V80C32 53.49 53.49 32 80 32H96V128H104zM476.4 208C473.1 208 472 209.1 472 212.4V299.6C472 302 473.1 304 476.4 304C496.1 304 512 288.1 512 268.4V243.6C512 223.9 496.1 208 476.4 208z\"\n ]\n};\nvar faSpaceShuttle = faShuttleSpace;\nvar faSignHanging = {\n prefix: 'fas',\n iconName: 'sign-hanging',\n icon: [\n 512,\n 512,\n [\n \"sign\"\n ],\n \"f4d9\",\n \"M96 0C113.7 0 128 14.33 128 32V64H480C497.7 64 512 78.33 512 96C512 113.7 497.7 128 480 128H128V480C128 497.7 113.7 512 96 512C78.33 512 64 497.7 64 480V128H32C14.33 128 0 113.7 0 96C0 78.33 14.33 64 32 64H64V32C64 14.33 78.33 0 96 0zM448 160C465.7 160 480 174.3 480 192V352C480 369.7 465.7 384 448 384H192C174.3 384 160 369.7 160 352V192C160 174.3 174.3 160 192 160H448z\"\n ]\n};\nvar faSign = faSignHanging;\nvar faSignal = {\n prefix: 'fas',\n iconName: 'signal',\n icon: [\n 576,\n 512,\n [\n 128246,\n \"signal-5\",\n \"signal-perfect\"\n ],\n \"f012\",\n \"M544 0c-17.67 0-32 14.33-32 31.1V480C512 497.7 526.3 512 544 512s32-14.33 32-31.1V31.1C576 14.33 561.7 0 544 0zM160 288C142.3 288 128 302.3 128 319.1v160C128 497.7 142.3 512 160 512s32-14.33 32-31.1V319.1C192 302.3 177.7 288 160 288zM32 384C14.33 384 0 398.3 0 415.1v64C0 497.7 14.33 512 31.1 512S64 497.7 64 480V415.1C64 398.3 49.67 384 32 384zM416 96c-17.67 0-32 14.33-32 31.1V480C384 497.7 398.3 512 416 512s32-14.33 32-31.1V127.1C448 110.3 433.7 96 416 96zM288 192C270.3 192 256 206.3 256 223.1v256C256 497.7 270.3 512 288 512s32-14.33 32-31.1V223.1C320 206.3 305.7 192 288 192z\"\n ]\n};\nvar faSignal5 = faSignal;\nvar faSignalPerfect = faSignal;\nvar faSignature = {\n prefix: 'fas',\n iconName: 'signature',\n icon: [\n 640,\n 512,\n [],\n \"f5b7\",\n \"M192 160C192 177.7 177.7 192 160 192C142.3 192 128 177.7 128 160V128C128 74.98 170.1 32 224 32C277 32 320 74.98 320 128V135.8C320 156.6 318.8 177.4 316.4 198.1L438.8 161.3C450.2 157.9 462.6 161.1 470.1 169.7C479.3 178.3 482.1 190.8 478.4 202.1L460.4 255.1H544C561.7 255.1 576 270.3 576 287.1C576 305.7 561.7 319.1 544 319.1H416C405.7 319.1 396.1 315.1 390 306.7C384 298.4 382.4 287.6 385.6 277.9L398.1 240.4L303.7 268.7C291.9 321.5 272.2 372.2 245.3 419.2L231.4 443.5C218.5 466.1 194.5 480 168.5 480C128.5 480 95.1 447.5 95.1 407.5V335.6C95.1 293.2 123.8 255.8 164.4 243.7L248.8 218.3C253.6 191.1 255.1 163.5 255.1 135.8V128C255.1 110.3 241.7 96 223.1 96C206.3 96 191.1 110.3 191.1 128L192 160zM160 335.6V407.5C160 412.2 163.8 416 168.5 416C171.5 416 174.4 414.4 175.9 411.7L189.8 387.4C207.3 356.6 221.4 324.1 231.8 290.3L182.8 304.1C169.3 309 160 321.5 160 335.6V335.6zM24 368H64V407.5C64 410.4 64.11 413.2 64.34 416H24C10.75 416 0 405.3 0 392C0 378.7 10.75 368 24 368zM616 416H283.5C291.7 400.3 299.2 384.3 305.9 368H616C629.3 368 640 378.7 640 392C640 405.3 629.3 416 616 416z\"\n ]\n};\nvar faSignsPost = {\n prefix: 'fas',\n iconName: 'signs-post',\n icon: [\n 512,\n 512,\n [\n \"map-signs\"\n ],\n \"f277\",\n \"M223.1 32C223.1 14.33 238.3 0 255.1 0C273.7 0 288 14.33 288 32H441.4C445.6 32 449.7 33.69 452.7 36.69L500.7 84.69C506.9 90.93 506.9 101.1 500.7 107.3L452.7 155.3C449.7 158.3 445.6 160 441.4 160H63.1C46.33 160 31.1 145.7 31.1 128V64C31.1 46.33 46.33 32 63.1 32L223.1 32zM480 320C480 337.7 465.7 352 448 352H70.63C66.38 352 62.31 350.3 59.31 347.3L11.31 299.3C5.065 293.1 5.065 282.9 11.31 276.7L59.31 228.7C62.31 225.7 66.38 223.1 70.63 223.1H223.1V191.1H288V223.1H448C465.7 223.1 480 238.3 480 255.1V320zM255.1 512C238.3 512 223.1 497.7 223.1 480V384H288V480C288 497.7 273.7 512 255.1 512z\"\n ]\n};\nvar faMapSigns = faSignsPost;\nvar faSimCard = {\n prefix: 'fas',\n iconName: 'sim-card',\n icon: [\n 384,\n 512,\n [],\n \"f7c4\",\n \"M0 64v384c0 35.25 28.75 64 64 64h256c35.25 0 64-28.75 64-64V128l-128-128H64C28.75 0 0 28.75 0 64zM224 256H160V192h64V256zM320 256h-64V192h32c17.75 0 32 14.25 32 32V256zM256 384h64v32c0 17.75-14.25 32-32 32h-32V384zM160 384h64v64H160V384zM64 384h64v64H96c-17.75 0-32-14.25-32-32V384zM64 288h256v64H64V288zM64 224c0-17.75 14.25-32 32-32h32v64H64V224z\"\n ]\n};\nvar faSink = {\n prefix: 'fas',\n iconName: 'sink',\n icon: [\n 512,\n 512,\n [],\n \"e06d\",\n \"M496 288h-96V256l64 .0002c8.838 0 16-7.164 16-15.1v-15.1c0-8.838-7.162-16-16-16L384 208c-17.67 0-32 14.33-32 32v47.1l-64 .0005v-192c0-17.64 14.36-32 32-32s32 14.36 32 32v16c0 8.836 7.164 16 16 16h32c8.838 0 16-7.164 16-16v-16c0-59.2-53.85-106-115.1-94.14C255.3 10.71 224 53.36 224 99.79v188.2L160 288V240c0-17.67-14.33-32-32-32L48 208c-8.836 0-16 7.162-16 16v15.1C32 248.8 39.16 256 48 256l64-.0002V288h-96c-8.836 0-16 7.164-16 16v32c0 8.836 7.164 16 16 16h480c8.836 0 16-7.164 16-16V304C512 295.2 504.8 288 496 288zM32 416c0 53.02 42.98 96 96 96h256c53.02 0 96-42.98 96-96v-32H32V416z\"\n ]\n};\nvar faSitemap = {\n prefix: 'fas',\n iconName: 'sitemap',\n icon: [\n 576,\n 512,\n [],\n \"f0e8\",\n \"M208 80C208 53.49 229.5 32 256 32H320C346.5 32 368 53.49 368 80V144C368 170.5 346.5 192 320 192H312V232H464C494.9 232 520 257.1 520 288V320H528C554.5 320 576 341.5 576 368V432C576 458.5 554.5 480 528 480H464C437.5 480 416 458.5 416 432V368C416 341.5 437.5 320 464 320H472V288C472 283.6 468.4 280 464 280H312V320H320C346.5 320 368 341.5 368 368V432C368 458.5 346.5 480 320 480H256C229.5 480 208 458.5 208 432V368C208 341.5 229.5 320 256 320H264V280H112C107.6 280 104 283.6 104 288V320H112C138.5 320 160 341.5 160 368V432C160 458.5 138.5 480 112 480H48C21.49 480 0 458.5 0 432V368C0 341.5 21.49 320 48 320H56V288C56 257.1 81.07 232 112 232H264V192H256C229.5 192 208 170.5 208 144V80z\"\n ]\n};\nvar faSkull = {\n prefix: 'fas',\n iconName: 'skull',\n icon: [\n 512,\n 512,\n [\n 128128\n ],\n \"f54c\",\n \"M416 400V464C416 490.5 394.5 512 368 512H320V464C320 455.2 312.8 448 304 448C295.2 448 288 455.2 288 464V512H224V464C224 455.2 216.8 448 208 448C199.2 448 192 455.2 192 464V512H144C117.5 512 96 490.5 96 464V400C96 399.6 96 399.3 96.01 398.9C37.48 357.8 0 294.7 0 224C0 100.3 114.6 0 256 0C397.4 0 512 100.3 512 224C512 294.7 474.5 357.8 415.1 398.9C415.1 399.3 416 399.6 416 400V400zM160 192C124.7 192 96 220.7 96 256C96 291.3 124.7 320 160 320C195.3 320 224 291.3 224 256C224 220.7 195.3 192 160 192zM352 320C387.3 320 416 291.3 416 256C416 220.7 387.3 192 352 192C316.7 192 288 220.7 288 256C288 291.3 316.7 320 352 320z\"\n ]\n};\nvar faSkullCrossbones = {\n prefix: 'fas',\n iconName: 'skull-crossbones',\n icon: [\n 448,\n 512,\n [\n 128369,\n 9760\n ],\n \"f714\",\n \"M368 128C368 172.4 342.6 211.5 304 234.4V256C304 273.7 289.7 288 272 288H176C158.3 288 144 273.7 144 256V234.4C105.4 211.5 80 172.4 80 128C80 57.31 144.5 0 224 0C303.5 0 368 57.31 368 128V128zM168 176C185.7 176 200 161.7 200 144C200 126.3 185.7 112 168 112C150.3 112 136 126.3 136 144C136 161.7 150.3 176 168 176zM280 112C262.3 112 248 126.3 248 144C248 161.7 262.3 176 280 176C297.7 176 312 161.7 312 144C312 126.3 297.7 112 280 112zM3.379 273.7C11.28 257.9 30.5 251.5 46.31 259.4L224 348.2L401.7 259.4C417.5 251.5 436.7 257.9 444.6 273.7C452.5 289.5 446.1 308.7 430.3 316.6L295.6 384L430.3 451.4C446.1 459.3 452.5 478.5 444.6 494.3C436.7 510.1 417.5 516.5 401.7 508.6L224 419.8L46.31 508.6C30.5 516.5 11.28 510.1 3.379 494.3C-4.525 478.5 1.882 459.3 17.69 451.4L152.4 384L17.69 316.6C1.882 308.7-4.525 289.5 3.379 273.7V273.7z\"\n ]\n};\nvar faSlash = {\n prefix: 'fas',\n iconName: 'slash',\n icon: [\n 640,\n 512,\n [],\n \"f715\",\n \"M5.112 9.196C13.29-1.236 28.37-3.065 38.81 5.112L630.8 469.1C641.2 477.3 643.1 492.4 634.9 502.8C626.7 513.2 611.6 515.1 601.2 506.9L9.196 42.89C-1.236 34.71-3.065 19.63 5.112 9.196V9.196z\"\n ]\n};\nvar faSleigh = {\n prefix: 'fas',\n iconName: 'sleigh',\n icon: [\n 640,\n 512,\n [],\n \"f7cc\",\n \"M63.1 32C66.31 32 68.56 32.24 70.74 32.71C124.1 37.61 174.2 67.59 203.4 114.3L207.7 121.1C247.7 185.1 317.8 224 393.3 224C423.5 224 448 199.5 448 169.3V128C448 110.3 462.3 96 480 96H544C561.7 96 576 110.3 576 128C576 145.7 561.7 160 544 160V256C544 309 501 352 448 352V384H384V352H192V384H128V352C74.98 352 32 309 32 256V96C14.33 96 0 81.67 0 64C0 46.33 14.33 32 32 32H63.1zM640 392C640 440.6 600.6 480 552 480H63.1C46.33 480 31.1 465.7 31.1 448C31.1 430.3 46.33 416 63.1 416H552C565.3 416 576 405.3 576 392V384C576 366.3 590.3 352 608 352C625.7 352 640 366.3 640 384V392z\"\n ]\n};\nvar faSliders = {\n prefix: 'fas',\n iconName: 'sliders',\n icon: [\n 512,\n 512,\n [\n \"sliders-h\"\n ],\n \"f1de\",\n \"M0 416C0 398.3 14.33 384 32 384H86.66C99 355.7 127.2 336 160 336C192.8 336 220.1 355.7 233.3 384H480C497.7 384 512 398.3 512 416C512 433.7 497.7 448 480 448H233.3C220.1 476.3 192.8 496 160 496C127.2 496 99 476.3 86.66 448H32C14.33 448 0 433.7 0 416V416zM192 416C192 398.3 177.7 384 160 384C142.3 384 128 398.3 128 416C128 433.7 142.3 448 160 448C177.7 448 192 433.7 192 416zM352 176C384.8 176 412.1 195.7 425.3 224H480C497.7 224 512 238.3 512 256C512 273.7 497.7 288 480 288H425.3C412.1 316.3 384.8 336 352 336C319.2 336 291 316.3 278.7 288H32C14.33 288 0 273.7 0 256C0 238.3 14.33 224 32 224H278.7C291 195.7 319.2 176 352 176zM384 256C384 238.3 369.7 224 352 224C334.3 224 320 238.3 320 256C320 273.7 334.3 288 352 288C369.7 288 384 273.7 384 256zM480 64C497.7 64 512 78.33 512 96C512 113.7 497.7 128 480 128H265.3C252.1 156.3 224.8 176 192 176C159.2 176 131 156.3 118.7 128H32C14.33 128 0 113.7 0 96C0 78.33 14.33 64 32 64H118.7C131 35.75 159.2 16 192 16C224.8 16 252.1 35.75 265.3 64H480zM160 96C160 113.7 174.3 128 192 128C209.7 128 224 113.7 224 96C224 78.33 209.7 64 192 64C174.3 64 160 78.33 160 96z\"\n ]\n};\nvar faSlidersH = faSliders;\nvar faSmog = {\n prefix: 'fas',\n iconName: 'smog',\n icon: [\n 640,\n 512,\n [],\n \"f75f\",\n \"M144 288h156.1C322.6 307.8 351.8 320 384 320s61.25-12.25 83.88-32H528C589.9 288 640 237.9 640 176s-50.13-112-112-112c-18 0-34.75 4.625-49.75 12.12C453.1 30.1 406.8 0 352 0c-41 0-77.75 17.25-104 44.75C221.8 17.25 185 0 144 0c-79.5 0-144 64.5-144 144S64.5 288 144 288zM136 464H23.1C10.8 464 0 474.8 0 487.1S10.8 512 23.1 512H136C149.2 512 160 501.2 160 488S149.2 464 136 464zM616 368h-528C74.8 368 64 378.8 64 391.1S74.8 416 87.1 416h528c13.2 0 24-10.8 24-23.1S629.2 368 616 368zM552 464H231.1C218.8 464 208 474.8 208 487.1S218.8 512 231.1 512H552c13.2 0 24-10.8 24-23.1S565.2 464 552 464z\"\n ]\n};\nvar faSmoking = {\n prefix: 'fas',\n iconName: 'smoking',\n icon: [\n 640,\n 512,\n [\n 128684\n ],\n \"f48d\",\n \"M432 352h-384C21.5 352 0 373.5 0 400v64C0 490.5 21.5 512 48 512h384c8.75 0 16-7.25 16-16v-128C448 359.3 440.8 352 432 352zM400 464H224v-64h176V464zM536 352h-48C483.6 352 480 355.6 480 360v144c0 4.375 3.625 8 8 8h48c4.375 0 8-3.625 8-8v-144C544 355.6 540.4 352 536 352zM632 352h-48C579.6 352 576 355.6 576 360v144c0 4.375 3.625 8 8 8h48c4.375 0 8-3.625 8-8v-144C640 355.6 636.4 352 632 352zM553.3 87.13C547.6 83.25 544 77.12 544 70.25V8C544 3.625 540.4 0 536 0h-48C483.6 0 480 3.625 480 8v62.25c0 22 10.25 43.5 28.62 55.5C550.8 153 576 199.5 576 249.8V280C576 284.4 579.6 288 584 288h48C636.4 288 640 284.4 640 280V249.8C640 184.3 607.6 123.5 553.3 87.13zM487.8 141.6C463.8 125 448 99.25 448 70.25V8C448 3.625 444.4 0 440 0h-48C387.6 0 384 3.625 384 8v66.38C384 118.1 408.6 156 444.3 181.1C466.8 196.8 480 222.3 480 249.8V280C480 284.4 483.6 288 488 288h48C540.4 288 544 284.4 544 280V249.8C544 206.4 523 166.3 487.8 141.6z\"\n ]\n};\nvar faSnowflake = {\n prefix: 'fas',\n iconName: 'snowflake',\n icon: [\n 512,\n 512,\n [\n 10054,\n 10052\n ],\n \"f2dc\",\n \"M475.6 384.1C469.7 394.3 458.9 400 447.9 400c-5.488 0-11.04-1.406-16.13-4.375l-25.09-14.64l5.379 20.29c3.393 12.81-4.256 25.97-17.08 29.34c-2.064 .5625-4.129 .8125-6.164 .8125c-10.63 0-20.36-7.094-23.21-17.84l-17.74-66.92L288 311.7l.0002 70.5l48.38 48.88c9.338 9.438 9.244 24.62-.1875 33.94C331.5 469.7 325.4 472 319.3 472c-6.193 0-12.39-2.375-17.08-7.125l-14.22-14.37L288 480c0 17.69-14.34 32-32.03 32s-32.03-14.31-32.03-32l-.0002-29.5l-14.22 14.37c-9.322 9.438-24.53 9.5-33.97 .1875c-9.432-9.312-9.525-24.5-.1875-33.94l48.38-48.88L223.1 311.7l-59.87 34.93l-17.74 66.92c-2.848 10.75-12.58 17.84-23.21 17.84c-2.035 0-4.1-.25-6.164-.8125c-12.82-3.375-20.47-16.53-17.08-29.34l5.379-20.29l-25.09 14.64C75.11 398.6 69.56 400 64.07 400c-11.01 0-21.74-5.688-27.69-15.88c-8.932-15.25-3.785-34.84 11.5-43.75l25.96-15.15l-20.33-5.508C40.7 316.3 33.15 303.1 36.62 290.3S53.23 270 66.09 273.4L132 291.3L192.5 256L132 220.7L66.09 238.6c-2.111 .5625-4.225 .8438-6.305 .8438c-10.57 0-20.27-7.031-23.16-17.72C33.15 208.9 40.7 195.8 53.51 192.3l20.33-5.508L47.88 171.6c-15.28-8.906-20.43-28.5-11.5-43.75c8.885-15.28 28.5-20.44 43.81-11.5l25.09 14.64L99.9 110.7C96.51 97.91 104.2 84.75 116.1 81.38C129.9 77.91 142.1 85.63 146.4 98.41l17.74 66.92L223.1 200.3l-.0002-70.5L175.6 80.88C166.3 71.44 166.3 56.25 175.8 46.94C185.2 37.59 200.4 37.72 209.8 47.13l14.22 14.37L223.1 32c0-17.69 14.34-32 32.03-32s32.03 14.31 32.03 32l.0002 29.5l14.22-14.37c9.307-9.406 24.51-9.531 33.97-.1875c9.432 9.312 9.525 24.5 .1875 33.94l-48.38 48.88L288 200.3l59.87-34.93l17.74-66.92c3.395-12.78 16.56-20.5 29.38-17.03c12.82 3.375 20.47 16.53 17.08 29.34l-5.379 20.29l25.09-14.64c15.28-8.906 34.91-3.75 43.81 11.5c8.932 15.25 3.785 34.84-11.5 43.75l-25.96 15.15l20.33 5.508c12.81 3.469 20.37 16.66 16.89 29.44c-2.895 10.69-12.59 17.72-23.16 17.72c-2.08 0-4.193-.2813-6.305-.8438L379.1 220.7L319.5 256l60.46 35.28l65.95-17.87C458.8 270 471.9 277.5 475.4 290.3c3.473 12.78-4.082 25.97-16.89 29.44l-20.33 5.508l25.96 15.15C479.4 349.3 484.5 368.9 475.6 384.1z\"\n ]\n};\nvar faSnowman = {\n prefix: 'fas',\n iconName: 'snowman',\n icon: [\n 512,\n 512,\n [\n 9924,\n 9731\n ],\n \"f7d0\",\n \"M510.9 152.3l-5.875-14.5c-3.25-8-12.62-11.88-20.75-8.625l-28.25 11.5v-29C455.1 103 448.7 96 439.1 96h-16c-8.75 0-16 7-16 15.62V158.5c0 .5 .25 1 .25 1.5l-48.98 20.6c-5.291-12.57-12.98-23.81-22.24-33.55c9.35-14.81 14.98-32.23 14.98-51.04C351.1 42.98 309 0 255.1 0S160 42.98 160 95.1c0 18.81 5.626 36.23 14.98 51.04C165.7 156.8 158.1 168.1 152.8 180.7L103.8 160c0-.5 .25-1 .25-1.5V111.6C104 103 96.76 96 88.01 96h-16c-8.75 0-16 7-16 15.62v29l-28.25-11.5c-8.125-3.25-17.5 .625-20.75 8.625l-5.875 14.5C-2.119 160.4 1.881 169.5 10.01 172.6L144.4 228.4C144.9 240.8 147.3 252.7 151.5 263.7c-33.78 29.34-55.53 72.04-55.53 120.3c0 52.59 25.71 98.84 64.88 128h190.2c39.17-29.17 64.88-75.42 64.88-128c0-48.25-21.76-90.95-55.53-120.3c4.195-11.03 6.599-22.89 7.091-35.27l134.4-55.8C510.1 169.5 514.1 160.4 510.9 152.3zM224 95.1c-8.75 0-15.1-7.25-15.1-15.1s7.25-15.1 15.1-15.1s15.1 7.25 15.1 15.1S232.8 95.1 224 95.1zM256 367.1c-8.75 0-15.1-7.25-15.1-15.1S247.3 335.1 256 335.1s15.1 7.25 15.1 15.1S264.8 367.1 256 367.1zM256 303.1c-8.75 0-15.1-7.25-15.1-15.1S247.3 271.1 256 271.1s15.1 7.25 15.1 15.1S264.8 303.1 256 303.1zM256 239.1c-8.75 0-15.1-7.25-15.1-15.1S247.3 207.1 256 207.1s15.1 7.25 15.1 15.1S264.8 239.1 256 239.1zM256 152c0 0-15.1-23.25-15.1-32S247.3 104 256 104s15.1 7.25 15.1 16S256 152 256 152zM287.1 95.1c-8.75 0-15.1-7.25-15.1-15.1s7.25-15.1 15.1-15.1s15.1 7.25 15.1 15.1S296.7 95.1 287.1 95.1z\"\n ]\n};\nvar faSnowplow = {\n prefix: 'fas',\n iconName: 'snowplow',\n icon: [\n 640,\n 512,\n [],\n \"f7d2\",\n \"M144 400C144 413.3 133.3 424 120 424C106.7 424 96 413.3 96 400C96 386.7 106.7 376 120 376C133.3 376 144 386.7 144 400zM336 400C336 386.7 346.7 376 360 376C373.3 376 384 386.7 384 400C384 413.3 373.3 424 360 424C346.7 424 336 413.3 336 400zM304 400C304 413.3 293.3 424 280 424C266.7 424 256 413.3 256 400C256 386.7 266.7 376 280 376C293.3 376 304 386.7 304 400zM176 400C176 386.7 186.7 376 200 376C213.3 376 224 386.7 224 400C224 413.3 213.3 424 200 424C186.7 424 176 413.3 176 400zM447.4 249.6C447.8 251.9 448.1 254.3 448 256.7V288H512V235.2C512 220.7 516.9 206.6 526 195.2L583 124C594.1 110.2 614.2 107.1 627.1 119C641.8 130.1 644 150.2 632.1 163.1L576 235.2V402.7L630.6 457.4C643.1 469.9 643.1 490.1 630.6 502.6C618.1 515.1 597.9 515.1 585.4 502.6L530.7 448C518.7 435.1 512 419.7 512 402.7V352H469.2C476.1 366.5 480 382.8 480 400C480 461.9 429.9 512 368 512H112C50.14 512 0 461.9 0 400C0 355.3 26.16 316.8 64 298.8V192C64 174.3 78.33 160 96 160H128V48C128 21.49 149.5 0 176 0H298.9C324.5 0 347.6 15.26 357.7 38.79L445.1 242.7C446.1 244.9 446.9 247.2 447.4 249.6H447.4zM298.9 64H192V160L256 224H367.5L298.9 64zM368 352H112C85.49 352 64 373.5 64 400C64 426.5 85.49 448 112 448H368C394.5 448 416 426.5 416 400C416 373.5 394.5 352 368 352z\"\n ]\n};\nvar faSoap = {\n prefix: 'fas',\n iconName: 'soap',\n icon: [\n 512,\n 512,\n [\n 129532\n ],\n \"e06e\",\n \"M320 256c35.35 0 64-28.65 64-64c0-35.35-28.65-64-64-64s-64 28.65-64 64C256 227.3 284.7 256 320 256zM160 288c-35.35 0-64 28.65-64 64c0 35.35 28.65 64 64 64h192c35.35 0 64-28.65 64-64c0-35.35-28.65-64-64-64H160zM384 64c17.67 0 32-14.33 32-32c0-17.67-14.33-32-32-32s-32 14.33-32 32C352 49.67 366.3 64 384 64zM208 96C234.5 96 256 74.51 256 48S234.5 0 208 0S160 21.49 160 48S181.5 96 208 96zM416 192c0 27.82-12.02 52.68-30.94 70.21C421.7 275.7 448 310.7 448 352c0 53.02-42.98 96-96 96H160c-53.02 0-96-42.98-96-96s42.98-96 96-96h88.91C233.6 238.1 224 216.7 224 192H96C42.98 192 0 234.1 0 288v128c0 53.02 42.98 96 96 96h320c53.02 0 96-42.98 96-96V288C512 234.1 469 192 416 192z\"\n ]\n};\nvar faSocks = {\n prefix: 'fas',\n iconName: 'socks',\n icon: [\n 576,\n 512,\n [\n 129510\n ],\n \"f696\",\n \"M319.1 32c0-11 3.125-21.25 8-30.38C325.4 .8721 322.9 0 319.1 0H192C174.4 0 159.1 14.38 159.1 32l.0042 32h160L319.1 32zM246.6 310.1l73.36-55l.0026-159.1h-160l-.0042 175.1l-86.64 64.61c-39.38 29.5-53.86 84.4-29.24 127c18.25 31.62 51.1 48.36 83.97 48.36c20 0 40.26-6.225 57.51-19.22l21.87-16.38C177.6 421 193.9 350.6 246.6 310.1zM351.1 271.1l-86.13 64.61c-39.37 29.5-53.86 84.4-29.23 127C254.9 495.3 287.2 512 320.1 512c20 0 40.25-6.25 57.5-19.25l115.2-86.38C525 382.3 544 344.2 544 303.1v-207.1h-192L351.1 271.1zM512 0h-128c-17.62 0-32 14.38-32 32l-.0003 32H544V32C544 14.38 529.6 0 512 0z\"\n ]\n};\nvar faSolarPanel = {\n prefix: 'fas',\n iconName: 'solar-panel',\n icon: [\n 640,\n 512,\n [],\n \"f5ba\",\n \"M575.4 25.72C572.4 10.78 559.2 0 543.1 0H96c-15.25 0-28.39 10.78-31.38 25.72l-63.1 320c-1.891 9.406 .5469 19.16 6.625 26.56S22.41 384 32 384h255.1v64.25H239.8c-26.26 0-47.75 21.49-47.75 47.75c0 8.844 7.168 16.01 16.01 16l223.1-.1667c8.828-.0098 15.99-7.17 15.99-16C447.1 469.5 426.6 448 400.2 448h-48.28v-64h256c9.594 0 18.67-4.312 24.75-11.72s8.516-17.16 6.625-26.56L575.4 25.72zM517.8 64l19.2 96h-97.98L429.2 64H517.8zM380.1 64l9.617 96H250l9.873-96H380.1zM210.8 64L201 160H103.1l19.18-96H210.8zM71.16 320l22.28-112h102.7L184.6 320H71.16zM233.8 320l11.37-112h149.7L406.2 320H233.8zM455.4 320l-11.5-112h102.7l22.28 112H455.4z\"\n ]\n};\nvar faSort = {\n prefix: 'fas',\n iconName: 'sort',\n icon: [\n 320,\n 512,\n [\n \"unsorted\"\n ],\n \"f0dc\",\n \"M27.66 224h264.7c24.6 0 36.89-29.78 19.54-47.12l-132.3-136.8c-5.406-5.406-12.47-8.107-19.53-8.107c-7.055 0-14.09 2.701-19.45 8.107L8.119 176.9C-9.229 194.2 3.055 224 27.66 224zM292.3 288H27.66c-24.6 0-36.89 29.77-19.54 47.12l132.5 136.8C145.9 477.3 152.1 480 160 480c7.053 0 14.12-2.703 19.53-8.109l132.3-136.8C329.2 317.8 316.9 288 292.3 288z\"\n ]\n};\nvar faUnsorted = faSort;\nvar faSortDown = {\n prefix: 'fas',\n iconName: 'sort-down',\n icon: [\n 320,\n 512,\n [\n \"sort-desc\"\n ],\n \"f0dd\",\n \"M311.9 335.1l-132.4 136.8C174.1 477.3 167.1 480 160 480c-7.055 0-14.12-2.702-19.47-8.109l-132.4-136.8C-9.229 317.8 3.055 288 27.66 288h264.7C316.9 288 329.2 317.8 311.9 335.1z\"\n ]\n};\nvar faSortDesc = faSortDown;\nvar faSortUp = {\n prefix: 'fas',\n iconName: 'sort-up',\n icon: [\n 320,\n 512,\n [\n \"sort-asc\"\n ],\n \"f0de\",\n \"M27.66 224h264.7c24.6 0 36.89-29.78 19.54-47.12l-132.3-136.8c-5.406-5.406-12.47-8.107-19.53-8.107c-7.055 0-14.09 2.701-19.45 8.107L8.119 176.9C-9.229 194.2 3.055 224 27.66 224z\"\n ]\n};\nvar faSortAsc = faSortUp;\nvar faSpa = {\n prefix: 'fas',\n iconName: 'spa',\n icon: [\n 576,\n 512,\n [],\n \"f5bb\",\n \"M568.3 192c-29 .125-135 6.124-213.9 82.1C321.2 304.7 301 338.3 288 369.9c-13-31.63-33.25-65.25-66.38-94.87C142.8 198.2 36.75 192.2 7.75 192C3.375 192 0 195.4 0 199.9c.25 27.88 7.125 126.2 88.75 199.3C172.8 481 256 479.1 288 479.1s115.2 1.025 199.3-80.85C568.9 326 575.8 227.7 576 199.9C576 195.4 572.6 192 568.3 192zM288 302.6c12.75-18.87 27.62-35.75 44.13-50.5c19-18.62 39.5-33.37 60.25-45.25c-16.5-70.5-51.75-133-96.75-172.3c-4.125-3.5-11-3.5-15.12 0c-45 39.25-80.25 101.6-96.75 172.1c20.37 11.75 40.5 26.12 59.25 44.37C260 266.4 275.1 283.7 288 302.6z\"\n ]\n};\nvar faSpaghettiMonsterFlying = {\n prefix: 'fas',\n iconName: 'spaghetti-monster-flying',\n icon: [\n 640,\n 512,\n [\n \"pastafarianism\"\n ],\n \"f67b\",\n \"M624.5 347.7c-32.63-12.5-57.38 4.241-75.38 16.49c-17 11.5-23.25 14.37-31.38 11.37c-8.125-3.125-10.88-9.358-15.88-29.36c-3.375-13.12-7.5-29.47-18-42.72c2.25-3 4.5-5.875 6.375-8.625C500.5 304.5 513.8 312 532 312c33.1 0 50.87-25.75 61.1-42.88C604.6 253 609 248 616 248C629.3 248 640 237.3 640 224s-10.75-24-24-24c-34 0-50.88 25.75-62 42.88C543.4 259 539 264 532 264c-17.25 0-37.5-61.38-97.25-101.9L452 127.6C485.4 125.5 512 97.97 512 63.97C512 28.6 483.4 0 448 0s-64 28.6-64 63.97c0 13 4 25.15 10.62 35.28L376.5 135.5C359.5 130.9 340.9 128 320 128S280.5 130.9 263.5 135.5L245.4 99.25C252 89.13 256 76.97 256 63.97C256 28.6 227.4 0 192 0S128 28.6 128 63.97C128 97.97 154.5 125.5 188 127.6l17.25 34.5C145.6 202.5 125.1 264 108 264c-7 0-11.31-5-21.94-21.12C74.94 225.8 57.1 200 24 200C10.75 200 0 210.8 0 224s10.75 24 24 24c7 0 11.37 5 21.1 21.12C57.12 286.3 73.1 312 108 312c18.25 0 31.5-7.5 41.75-17.12C151.6 297.6 153.9 300.5 156.1 303.5c-10.5 13.25-14.62 29.59-18 42.72c-5 20-7.75 26.23-15.88 29.36c-8.125 3-14.37 .1314-31.37-11.37c-18.12-12.25-42.75-28.87-75.38-16.49c-12.38 4.75-18.62 18.61-13.88 30.98c4.625 12.38 18.62 18.62 30.88 13.87C40.75 389.6 46.88 392.4 64 403.9c13.5 9.125 30.75 20.86 52.38 20.86c7.125 0 14.88-1.248 23-4.373c32.63-12.5 40-41.34 45.25-62.46c2.25-8.75 4-14.49 6-18.86c16.62 13.62 37 25.86 61.63 34.23C242.3 410.3 220.1 464 192 464c-13.25 0-24 10.74-24 23.99S178.8 512 192 512c66.75 0 97-88.55 107.4-129.1C306.1 383.6 312.9 384 320 384s13.88-.4706 20.62-1.096C351 423.4 381.3 512 448 512c13.25 0 24-10.74 24-23.99S461.3 464 448 464c-28 0-50.25-53.74-60.25-90.74c24.75-8.375 45-20.56 61.63-34.19c2 4.375 3.75 10.11 6 18.86c5.375 21.12 12.62 49.96 45.25 62.46c8.25 3.125 15.88 4.373 23 4.373c21.62 0 38.83-11.74 52.46-20.86c17-11.5 23.29-14.37 31.42-11.37c12.38 4.75 26.25-1.492 30.88-13.87C643.1 366.3 637 352.5 624.5 347.7zM192 79.97c-8.875 0-16-7.125-16-16S183.1 47.98 192 47.98s16 7.118 16 15.99S200.9 79.97 192 79.97zM448 47.98c8.875 0 16 7.118 16 15.99s-7.125 16-16 16s-16-7.125-16-16S439.1 47.98 448 47.98z\"\n ]\n};\nvar faPastafarianism = faSpaghettiMonsterFlying;\nvar faSpellCheck = {\n prefix: 'fas',\n iconName: 'spell-check',\n icon: [\n 576,\n 512,\n [],\n \"f891\",\n \"M566.6 265.4c-12.5-12.5-32.75-12.5-45.25 0L352 434.8l-73.38-73.38c-12.5-12.5-32.75-12.5-45.25 0s-12.5 32.75 0 45.25l96 96c6.25 6.25 14.44 9.368 22.62 9.368s16.38-3.118 22.63-9.368l192-192C579.1 298.1 579.1 277.9 566.6 265.4zM221.5 211.7l-80-192C136.6 7.796 124.9 .0147 112 .0147S87.44 7.796 82.47 19.7l-80 192C-4.328 228 3.375 246.8 19.69 253.5c16.36 6.812 35.06-.9375 41.84-17.22l5.131-12.31h90.68l5.131 12.31c5.109 12.28 17.02 19.69 29.55 19.69c4.094 0 8.266-.7812 12.3-2.469C220.6 246.8 228.3 228 221.5 211.7zM93.33 160L112 115.2l18.67 44.81H93.33zM288 256h80c44.11 0 80-35.87 80-79.1c0-23.15-10.03-43.85-25.79-58.47C428.3 106.3 432 93.65 432 80.01c0-44.13-35.89-80-79.1-80L288 .0147c-17.67 0-32 14.31-32 31.1v192C256 241.7 270.3 256 288 256zM320 64.01h32c8.828 0 16 7.188 16 16s-7.172 16-16 16h-32V64.01zM320 160h48c8.828 0 16 7.188 16 16s-7.172 16-16 16H320V160z\"\n ]\n};\nvar faSpider = {\n prefix: 'fas',\n iconName: 'spider',\n icon: [\n 576,\n 512,\n [\n 128375\n ],\n \"f717\",\n \"M563.3 401.6c2.608 8.443-2.149 17.4-10.62 19.1l-15.35 4.709c-8.48 2.6-17.47-2.139-20.08-10.59L493.2 338l-79.79-31.8l53.47 62.15c5.08 5.904 6.972 13.89 5.08 21.44l-28.23 110.1c-2.151 8.57-10.87 13.78-19.47 11.64l-15.58-3.873c-8.609-2.141-13.84-10.83-11.69-19.4l25.2-98.02l-38.51-44.77c.1529 2.205 .6627 4.307 .6627 6.549c0 53.02-43.15 96-96.37 96S191.6 405 191.6 352c0-2.242 .5117-4.34 .6627-6.543l-38.51 44.76l25.2 98.02c2.151 8.574-3.084 17.26-11.69 19.4l-15.58 3.873c-8.603 2.141-17.32-3.072-19.47-11.64l-28.23-110.1c-1.894-7.543 0-15.53 5.08-21.44l53.47-62.15l-79.79 31.8l-24.01 77.74c-2.608 8.447-11.6 13.19-20.08 10.59l-15.35-4.709c-8.478-2.6-13.23-11.55-10.63-19.1l27.4-88.69c2.143-6.939 7.323-12.54 14.09-15.24L158.9 256l-104.7-41.73C47.43 211.6 42.26 205.1 40.11 199.1L12.72 110.4c-2.608-8.443 2.149-17.4 10.62-19.1l15.35-4.709c8.48-2.6 17.47 2.139 20.08 10.59l24.01 77.74l79.79 31.8L109.1 143.6C104 137.7 102.1 129.7 104 122.2l28.23-110.1c2.151-8.57 10.87-13.78 19.47-11.64l15.58 3.873C175.9 6.494 181.1 15.18 178.1 23.76L153.8 121.8L207.7 184.4l.1542-24.44C206.1 123.4 228.9 91.77 261.4 80.43c5.141-1.793 10.5 2.215 10.5 7.641V112h32.12V88.09c0-5.443 5.394-9.443 10.55-7.641C345.9 91.39 368.3 121 368.3 155.9c0 1.393-.1786 2.689-.2492 4.064L368.3 184.4l53.91-62.66l-25.2-98.02c-2.151-8.574 3.084-17.26 11.69-19.4l15.58-3.873c8.603-2.141 17.32 3.072 19.47 11.64l28.23 110.1c1.894 7.543 0 15.53-5.08 21.44l-53.47 62.15l79.79-31.8l24.01-77.74c2.608-8.447 11.6-13.19 20.08-10.59l15.35 4.709c8.478 2.6 13.23 11.55 10.63 19.1l-27.4 88.69c-2.143 6.939-7.323 12.54-14.09 15.24L417.1 256l104.7 41.73c6.754 2.691 11.92 8.283 14.07 15.21L563.3 401.6z\"\n ]\n};\nvar faSpinner = {\n prefix: 'fas',\n iconName: 'spinner',\n icon: [\n 512,\n 512,\n [],\n \"f110\",\n \"M304 48C304 74.51 282.5 96 256 96C229.5 96 208 74.51 208 48C208 21.49 229.5 0 256 0C282.5 0 304 21.49 304 48zM304 464C304 490.5 282.5 512 256 512C229.5 512 208 490.5 208 464C208 437.5 229.5 416 256 416C282.5 416 304 437.5 304 464zM0 256C0 229.5 21.49 208 48 208C74.51 208 96 229.5 96 256C96 282.5 74.51 304 48 304C21.49 304 0 282.5 0 256zM512 256C512 282.5 490.5 304 464 304C437.5 304 416 282.5 416 256C416 229.5 437.5 208 464 208C490.5 208 512 229.5 512 256zM74.98 437C56.23 418.3 56.23 387.9 74.98 369.1C93.73 350.4 124.1 350.4 142.9 369.1C161.6 387.9 161.6 418.3 142.9 437C124.1 455.8 93.73 455.8 74.98 437V437zM142.9 142.9C124.1 161.6 93.73 161.6 74.98 142.9C56.24 124.1 56.24 93.73 74.98 74.98C93.73 56.23 124.1 56.23 142.9 74.98C161.6 93.73 161.6 124.1 142.9 142.9zM369.1 369.1C387.9 350.4 418.3 350.4 437 369.1C455.8 387.9 455.8 418.3 437 437C418.3 455.8 387.9 455.8 369.1 437C350.4 418.3 350.4 387.9 369.1 369.1V369.1z\"\n ]\n};\nvar faSplotch = {\n prefix: 'fas',\n iconName: 'splotch',\n icon: [\n 512,\n 512,\n [],\n \"f5bc\",\n \"M349.3 47.38L367.9 116.1C374.6 142.1 393.2 162.3 417.6 171.2L475.8 192.4C497.5 200.3 512 221 512 244.2C512 261.8 503.6 278.4 489.4 288.8L406.9 348.1C393.3 358.9 385.7 374.1 386.7 391.8L389.8 442.4C392.1 480.1 362.2 511.9 324.4 511.9C308.8 511.9 293.8 506.4 281.1 496.4L236.1 458.2C221.1 444.7 200.9 437.3 180 437.3H171.6C165.1 437.3 160.4 437.8 154.8 438.9L87.81 451.9C63.82 456.6 39.53 445.5 27.41 424.3C17.39 406.7 17.39 385.2 27.41 367.7L55.11 319.2C60.99 308.9 64.09 297.3 64.09 285.4C64.09 272.3 60.33 259.6 53.27 248.6L8.796 179.4C-6.738 155.2-1.267 123.2 21.41 105.6C32.12 97.25 45.52 93.13 59.07 94.01L130.8 98.66C159.8 100.5 187.1 87.91 205.9 64.93L237.3 24.66C249.4 9.133 267.9 .0566 287.6 .0566C316.5 .0566 341.8 19.47 349.3 47.38V47.38z\"\n ]\n};\nvar faSpoon = {\n prefix: 'fas',\n iconName: 'spoon',\n icon: [\n 512,\n 512,\n [\n 61873,\n 129348,\n \"utensil-spoon\"\n ],\n \"f2e5\",\n \"M449.5 242.2C436.4 257.8 419.8 270 400.1 277.8C382.2 285.6 361.7 288.8 341.4 287C326.2 284.5 311.8 278.4 299.5 269.1L68.29 500.3C60.79 507.8 50.61 512 40 512C29.39 512 19.22 507.8 11.71 500.3C4.211 492.8-.0039 482.6-.0039 472C-.0039 461.4 4.211 451.2 11.71 443.7L243 212.5C233.7 200.2 227.6 185.8 225.1 170.6C223.3 150.3 226.5 129.9 234.3 111C242.1 92.22 254.3 75.56 269.9 62.47C337.8-5.437 433.1-20.28 482.7 29.35C532.3 78.95 517.4 174.2 449.5 242.2z\"\n ]\n};\nvar faUtensilSpoon = faSpoon;\nvar faSprayCan = {\n prefix: 'fas',\n iconName: 'spray-can',\n icon: [\n 512,\n 512,\n [],\n \"f5bd\",\n \"M192 0C209.7 0 224 14.33 224 32V128H96V32C96 14.33 110.3 0 128 0H192zM0 256C0 202.1 42.98 160 96 160H224C277 160 320 202.1 320 256V464C320 490.5 298.5 512 272 512H48C21.49 512 0 490.5 0 464V256zM160 256C115.8 256 80 291.8 80 336C80 380.2 115.8 416 160 416C204.2 416 240 380.2 240 336C240 291.8 204.2 256 160 256zM320 64C320 81.67 305.7 96 288 96C270.3 96 256 81.67 256 64C256 46.33 270.3 32 288 32C305.7 32 320 46.33 320 64zM352 64C352 46.33 366.3 32 384 32C401.7 32 416 46.33 416 64C416 81.67 401.7 96 384 96C366.3 96 352 81.67 352 64zM512 64C512 81.67 497.7 96 480 96C462.3 96 448 81.67 448 64C448 46.33 462.3 32 480 32C497.7 32 512 46.33 512 64zM448 160C448 142.3 462.3 128 480 128C497.7 128 512 142.3 512 160C512 177.7 497.7 192 480 192C462.3 192 448 177.7 448 160zM512 256C512 273.7 497.7 288 480 288C462.3 288 448 273.7 448 256C448 238.3 462.3 224 480 224C497.7 224 512 238.3 512 256zM352 160C352 142.3 366.3 128 384 128C401.7 128 416 142.3 416 160C416 177.7 401.7 192 384 192C366.3 192 352 177.7 352 160z\"\n ]\n};\nvar faSprayCanSparkles = {\n prefix: 'fas',\n iconName: 'spray-can-sparkles',\n icon: [\n 512,\n 512,\n [\n \"air-freshener\"\n ],\n \"f5d0\",\n \"M96 32C96 14.33 110.3 0 128 0H192C209.7 0 224 14.33 224 32V128H96V32zM224 160C277 160 320 202.1 320 256V464C320 490.5 298.5 512 272 512H48C21.49 512 0 490.5 0 464V256C0 202.1 42.98 160 96 160H224zM160 416C204.2 416 240 380.2 240 336C240 291.8 204.2 256 160 256C115.8 256 80 291.8 80 336C80 380.2 115.8 416 160 416zM384 48C384 49.36 383 50.97 381.8 51.58L352 64L339.6 93.78C338.1 95 337.4 96 336 96C334.6 96 333 95 332.4 93.78L320 64L290.2 51.58C288.1 50.97 288 49.36 288 48C288 46.62 288.1 45.03 290.2 44.42L320 32L332.4 2.219C333 1 334.6 0 336 0C337.4 0 338.1 1 339.6 2.219L352 32L381.8 44.42C383 45.03 384 46.62 384 48zM460.4 93.78L448 64L418.2 51.58C416.1 50.97 416 49.36 416 48C416 46.62 416.1 45.03 418.2 44.42L448 32L460.4 2.219C461 1 462.6 0 464 0C465.4 0 466.1 1 467.6 2.219L480 32L509.8 44.42C511 45.03 512 46.62 512 48C512 49.36 511 50.97 509.8 51.58L480 64L467.6 93.78C466.1 95 465.4 96 464 96C462.6 96 461 95 460.4 93.78zM467.6 194.2L480 224L509.8 236.4C511 237 512 238.6 512 240C512 241.4 511 242.1 509.8 243.6L480 256L467.6 285.8C466.1 287 465.4 288 464 288C462.6 288 461 287 460.4 285.8L448 256L418.2 243.6C416.1 242.1 416 241.4 416 240C416 238.6 416.1 237 418.2 236.4L448 224L460.4 194.2C461 193 462.6 192 464 192C465.4 192 466.1 193 467.6 194.2zM448 144C448 145.4 447 146.1 445.8 147.6L416 160L403.6 189.8C402.1 191 401.4 192 400 192C398.6 192 397 191 396.4 189.8L384 160L354.2 147.6C352.1 146.1 352 145.4 352 144C352 142.6 352.1 141 354.2 140.4L384 128L396.4 98.22C397 97 398.6 96 400 96C401.4 96 402.1 97 403.6 98.22L416 128L445.8 140.4C447 141 448 142.6 448 144z\"\n ]\n};\nvar faAirFreshener = faSprayCanSparkles;\nvar faSquare = {\n prefix: 'fas',\n iconName: 'square',\n icon: [\n 448,\n 512,\n [\n 9723,\n 9724,\n 61590,\n 9632\n ],\n \"f0c8\",\n \"M0 96C0 60.65 28.65 32 64 32H384C419.3 32 448 60.65 448 96V416C448 451.3 419.3 480 384 480H64C28.65 480 0 451.3 0 416V96z\"\n ]\n};\nvar faSquareArrowUpRight = {\n prefix: 'fas',\n iconName: 'square-arrow-up-right',\n icon: [\n 448,\n 512,\n [\n \"external-link-square\"\n ],\n \"f14c\",\n \"M384 32H64C28.65 32 0 60.66 0 96v320c0 35.34 28.65 64 64 64h320c35.35 0 64-28.66 64-64V96C448 60.66 419.3 32 384 32zM344 312c0 17.69-14.31 32-32 32s-32-14.31-32-32V245.3l-121.4 121.4C152.4 372.9 144.2 376 136 376s-16.38-3.125-22.62-9.375c-12.5-12.5-12.5-32.75 0-45.25L234.8 200H168c-17.69 0-32-14.31-32-32s14.31-32 32-32h144c17.69 0 32 14.31 32 32V312z\"\n ]\n};\nvar faExternalLinkSquare = faSquareArrowUpRight;\nvar faSquareCaretDown = {\n prefix: 'fas',\n iconName: 'square-caret-down',\n icon: [\n 448,\n 512,\n [\n \"caret-square-down\"\n ],\n \"f150\",\n \"M384 32H64C28.65 32 0 60.65 0 96v320c0 35.34 28.65 64 64 64h320c35.35 0 64-28.66 64-64V96C448 60.65 419.3 32 384 32zM345.6 232.3l-104 112C237 349.2 230.7 352 224 352s-13.03-2.781-17.59-7.656l-104-112c-6.5-7-8.219-17.19-4.407-25.94C101.8 197.7 110.5 192 120 192h208c9.531 0 18.19 5.656 21.1 14.41C353.8 215.2 352.1 225.3 345.6 232.3z\"\n ]\n};\nvar faCaretSquareDown = faSquareCaretDown;\nvar faSquareCaretLeft = {\n prefix: 'fas',\n iconName: 'square-caret-left',\n icon: [\n 448,\n 512,\n [\n \"caret-square-left\"\n ],\n \"f191\",\n \"M384 32H64C28.65 32 0 60.65 0 96v320c0 35.34 28.65 64 64 64h320c35.35 0 64-28.66 64-64V96C448 60.65 419.3 32 384 32zM288 360c0 9.531-5.656 18.19-14.41 22C270.5 383.3 267.3 384 264 384c-5.938 0-11.81-2.219-16.34-6.406l-112-104C130.8 269 128 262.7 128 256s2.781-13.03 7.656-17.59l112-104c7.031-6.469 17.22-8.156 25.94-4.406C282.3 133.8 288 142.5 288 152V360z\"\n ]\n};\nvar faCaretSquareLeft = faSquareCaretLeft;\nvar faSquareCaretRight = {\n prefix: 'fas',\n iconName: 'square-caret-right',\n icon: [\n 448,\n 512,\n [\n \"caret-square-right\"\n ],\n \"f152\",\n \"M384 32H64C28.65 32 0 60.65 0 96v320c0 35.34 28.65 64 64 64h320c35.35 0 64-28.66 64-64V96C448 60.65 419.3 32 384 32zM312.3 273.6l-112 104C195.8 381.8 189.9 384 184 384c-3.25 0-6.5-.6562-9.594-2C165.7 378.2 160 369.5 160 360v-208c0-9.531 5.656-18.19 14.41-22c8.75-3.75 18.94-2.062 25.94 4.406l112 104C317.2 242.1 320 249.3 320 256S317.2 269 312.3 273.6z\"\n ]\n};\nvar faCaretSquareRight = faSquareCaretRight;\nvar faSquareCaretUp = {\n prefix: 'fas',\n iconName: 'square-caret-up',\n icon: [\n 448,\n 512,\n [\n \"caret-square-up\"\n ],\n \"f151\",\n \"M384 32H64C28.65 32 0 60.65 0 96v320c0 35.34 28.65 64 64 64h320c35.35 0 64-28.66 64-64V96C448 60.65 419.3 32 384 32zM349.1 305.6C346.2 314.3 337.5 320 328 320h-208c-9.531 0-18.19-5.656-22-14.41C94.19 296.8 95.91 286.7 102.4 279.7l104-112c9.125-9.75 26.06-9.75 35.19 0l104 112C352.1 286.7 353.8 296.8 349.1 305.6z\"\n ]\n};\nvar faCaretSquareUp = faSquareCaretUp;\nvar faSquareCheck = {\n prefix: 'fas',\n iconName: 'square-check',\n icon: [\n 448,\n 512,\n [\n 9989,\n 61510,\n 9745,\n \"check-square\"\n ],\n \"f14a\",\n \"M384 32C419.3 32 448 60.65 448 96V416C448 451.3 419.3 480 384 480H64C28.65 480 0 451.3 0 416V96C0 60.65 28.65 32 64 32H384zM339.8 211.8C350.7 200.9 350.7 183.1 339.8 172.2C328.9 161.3 311.1 161.3 300.2 172.2L192 280.4L147.8 236.2C136.9 225.3 119.1 225.3 108.2 236.2C97.27 247.1 97.27 264.9 108.2 275.8L172.2 339.8C183.1 350.7 200.9 350.7 211.8 339.8L339.8 211.8z\"\n ]\n};\nvar faCheckSquare = faSquareCheck;\nvar faSquareEnvelope = {\n prefix: 'fas',\n iconName: 'square-envelope',\n icon: [\n 448,\n 512,\n [\n \"envelope-square\"\n ],\n \"f199\",\n \"M384 32H64C28.63 32 0 60.63 0 96v320c0 35.38 28.62 64 64 64h320c35.38 0 64-28.62 64-64V96C448 60.63 419.4 32 384 32zM384 336c0 17.67-14.33 32-32 32H96c-17.67 0-32-14.33-32-32V225.9l138.5 69.27C209.3 298.5 216.6 300.2 224 300.2s14.75-1.688 21.47-5.047L384 225.9V336zM384 190.1l-152.8 76.42c-4.5 2.25-9.812 2.25-14.31 0L64 190.1V176c0-17.67 14.33-32 32-32h256c17.67 0 32 14.33 32 32V190.1z\"\n ]\n};\nvar faEnvelopeSquare = faSquareEnvelope;\nvar faSquareFull = {\n prefix: 'fas',\n iconName: 'square-full',\n icon: [\n 512,\n 512,\n [\n 128997,\n 128998,\n 128999,\n 129000,\n 129001,\n 129002,\n 129003,\n 11036,\n 11035\n ],\n \"f45c\",\n \"M0 0H512V512H0V0z\"\n ]\n};\nvar faSquareH = {\n prefix: 'fas',\n iconName: 'square-h',\n icon: [\n 448,\n 512,\n [\n \"h-square\"\n ],\n \"f0fd\",\n \"M384 32H64C28.65 32 0 60.65 0 96v320c0 35.35 28.65 64 64 64h320c35.35 0 64-28.65 64-64V96C448 60.65 419.3 32 384 32zM336 360c0 13.25-10.75 24-24 24S288 373.3 288 360v-80H160v80C160 373.3 149.3 384 136 384S112 373.3 112 360v-208C112 138.8 122.8 128 136 128S160 138.8 160 152v80h128v-80C288 138.8 298.8 128 312 128s24 10.75 24 24V360z\"\n ]\n};\nvar faHSquare = faSquareH;\nvar faSquareMinus = {\n prefix: 'fas',\n iconName: 'square-minus',\n icon: [\n 448,\n 512,\n [\n 61767,\n \"minus-square\"\n ],\n \"f146\",\n \"M384 32C419.3 32 448 60.65 448 96V416C448 451.3 419.3 480 384 480H64C28.65 480 0 451.3 0 416V96C0 60.65 28.65 32 64 32H384zM136 232C122.7 232 112 242.7 112 256C112 269.3 122.7 280 136 280H312C325.3 280 336 269.3 336 256C336 242.7 325.3 232 312 232H136z\"\n ]\n};\nvar faMinusSquare = faSquareMinus;\nvar faSquareParking = {\n prefix: 'fas',\n iconName: 'square-parking',\n icon: [\n 448,\n 512,\n [\n 127359,\n \"parking\"\n ],\n \"f540\",\n \"M192 256V192H240C257.7 192 272 206.3 272 224C272 241.7 257.7 256 240 256H192zM384 32C419.3 32 448 60.65 448 96V416C448 451.3 419.3 480 384 480H64C28.65 480 0 451.3 0 416V96C0 60.65 28.65 32 64 32H384zM336 224C336 170.1 293 128 240 128H168C145.9 128 128 145.9 128 168V352C128 369.7 142.3 384 160 384C177.7 384 192 369.7 192 352V320H240C293 320 336 277 336 224z\"\n ]\n};\nvar faParking = faSquareParking;\nvar faSquarePen = {\n prefix: 'fas',\n iconName: 'square-pen',\n icon: [\n 448,\n 512,\n [\n \"pen-square\",\n \"pencil-square\"\n ],\n \"f14b\",\n \"M384 32C419.3 32 448 60.65 448 96V416C448 451.3 419.3 480 384 480H64C28.65 480 0 451.3 0 416V96C0 60.65 28.65 32 64 32H384zM325.8 139.7C310.1 124.1 284.8 124.1 269.2 139.7L247.8 161.1L318.7 232.1L340.1 210.7C355.8 195 355.8 169.7 340.1 154.1L325.8 139.7zM111.5 303.8L96.48 363.1C95.11 369.4 96.71 375.2 100.7 379.2C104.7 383.1 110.4 384.7 115.9 383.4L176 368.3C181.6 366.9 186.8 364 190.9 359.9L296.1 254.7L225.1 183.8L119.9 288.1C115.8 293.1 112.9 298.2 111.5 303.8z\"\n ]\n};\nvar faPenSquare = faSquarePen;\nvar faPencilSquare = faSquarePen;\nvar faSquarePhone = {\n prefix: 'fas',\n iconName: 'square-phone',\n icon: [\n 448,\n 512,\n [\n \"phone-square\"\n ],\n \"f098\",\n \"M384 32H64C28.65 32 0 60.65 0 96v320c0 35.35 28.65 64 64 64h320c35.35 0 64-28.65 64-64V96C448 60.65 419.3 32 384 32zM351.6 321.5l-11.62 50.39c-1.633 7.125-7.9 12.11-15.24 12.11c-126.1 0-228.7-102.6-228.7-228.8c0-7.328 4.984-13.59 12.11-15.22l50.38-11.63c7.344-1.703 14.88 2.109 17.93 9.062l23.27 54.28c2.719 6.391 .8828 13.83-4.492 18.22L168.3 232c16.99 34.61 45.14 62.75 79.77 79.75l22.02-26.91c4.344-5.391 11.85-7.25 18.24-4.484l54.24 23.25C349.5 306.6 353.3 314.2 351.6 321.5z\"\n ]\n};\nvar faPhoneSquare = faSquarePhone;\nvar faSquarePhoneFlip = {\n prefix: 'fas',\n iconName: 'square-phone-flip',\n icon: [\n 448,\n 512,\n [\n \"phone-square-alt\"\n ],\n \"f87b\",\n \"M0 96v320c0 35.35 28.65 64 64 64h320c35.35 0 64-28.65 64-64V96c0-35.35-28.65-64-64-64H64C28.65 32 0 60.65 0 96zM105.5 303.6l54.24-23.25c6.391-2.766 13.9-.9062 18.24 4.484l22.02 26.91c34.63-17 62.77-45.14 79.77-79.75l-26.91-22.05c-5.375-4.391-7.211-11.83-4.492-18.22l23.27-54.28c3.047-6.953 10.59-10.77 17.93-9.062l50.38 11.63c7.125 1.625 12.11 7.891 12.11 15.22c0 126.1-102.6 228.8-228.7 228.8c-7.336 0-13.6-4.984-15.24-12.11l-11.62-50.39C94.71 314.2 98.5 306.6 105.5 303.6z\"\n ]\n};\nvar faPhoneSquareAlt = faSquarePhoneFlip;\nvar faSquarePlus = {\n prefix: 'fas',\n iconName: 'square-plus',\n icon: [\n 448,\n 512,\n [\n 61846,\n \"plus-square\"\n ],\n \"f0fe\",\n \"M384 32C419.3 32 448 60.65 448 96V416C448 451.3 419.3 480 384 480H64C28.65 480 0 451.3 0 416V96C0 60.65 28.65 32 64 32H384zM224 368C237.3 368 248 357.3 248 344V280H312C325.3 280 336 269.3 336 256C336 242.7 325.3 232 312 232H248V168C248 154.7 237.3 144 224 144C210.7 144 200 154.7 200 168V232H136C122.7 232 112 242.7 112 256C112 269.3 122.7 280 136 280H200V344C200 357.3 210.7 368 224 368z\"\n ]\n};\nvar faPlusSquare = faSquarePlus;\nvar faSquarePollHorizontal = {\n prefix: 'fas',\n iconName: 'square-poll-horizontal',\n icon: [\n 448,\n 512,\n [\n \"poll-h\"\n ],\n \"f682\",\n \"M448 416C448 451.3 419.3 480 384 480H64C28.65 480 0 451.3 0 416V96C0 60.65 28.65 32 64 32H384C419.3 32 448 60.65 448 96V416zM256 160C256 142.3 241.7 128 224 128H128C110.3 128 96 142.3 96 160C96 177.7 110.3 192 128 192H224C241.7 192 256 177.7 256 160zM128 224C110.3 224 96 238.3 96 256C96 273.7 110.3 288 128 288H320C337.7 288 352 273.7 352 256C352 238.3 337.7 224 320 224H128zM192 352C192 334.3 177.7 320 160 320H128C110.3 320 96 334.3 96 352C96 369.7 110.3 384 128 384H160C177.7 384 192 369.7 192 352z\"\n ]\n};\nvar faPollH = faSquarePollHorizontal;\nvar faSquarePollVertical = {\n prefix: 'fas',\n iconName: 'square-poll-vertical',\n icon: [\n 448,\n 512,\n [\n \"poll\"\n ],\n \"f681\",\n \"M384 32C419.3 32 448 60.65 448 96V416C448 451.3 419.3 480 384 480H64C28.65 480 0 451.3 0 416V96C0 60.65 28.65 32 64 32H384zM128 224C110.3 224 96 238.3 96 256V352C96 369.7 110.3 384 128 384C145.7 384 160 369.7 160 352V256C160 238.3 145.7 224 128 224zM192 352C192 369.7 206.3 384 224 384C241.7 384 256 369.7 256 352V160C256 142.3 241.7 128 224 128C206.3 128 192 142.3 192 160V352zM320 288C302.3 288 288 302.3 288 320V352C288 369.7 302.3 384 320 384C337.7 384 352 369.7 352 352V320C352 302.3 337.7 288 320 288z\"\n ]\n};\nvar faPoll = faSquarePollVertical;\nvar faSquareRootVariable = {\n prefix: 'fas',\n iconName: 'square-root-variable',\n icon: [\n 576,\n 512,\n [\n \"square-root-alt\"\n ],\n \"f698\",\n \"M576 32.01c0-17.69-14.33-31.1-32-31.1l-224-.0049c-14.69 0-27.48 10-31.05 24.25L197.9 388.3L124.6 241.7C119.2 230.9 108.1 224 96 224L32 224c-17.67 0-32 14.31-32 31.1s14.33 32 32 32h44.22l103.2 206.3c5.469 10.91 16.6 17.68 28.61 17.68c1.172 0 2.323-.0576 3.495-.1826c13.31-1.469 24.31-11.06 27.56-24.06l105.9-423.8H544C561.7 64.01 576 49.7 576 32.01zM566.6 233.4c-12.5-12.5-32.75-12.5-45.25 0L480 274.8l-41.38-41.37c-12.5-12.5-32.75-12.5-45.25 0s-12.5 32.75 0 45.25l41.38 41.38l-41.38 41.38c-12.5 12.5-12.5 32.75 0 45.25C399.6 412.9 407.8 416 416 416s16.38-3.125 22.62-9.375L480 365.3l41.38 41.38C527.6 412.9 535.8 416 544 416s16.38-3.125 22.62-9.375c12.5-12.5 12.5-32.75 0-45.25l-41.38-41.38L566.6 278.6C579.1 266.1 579.1 245.9 566.6 233.4z\"\n ]\n};\nvar faSquareRootAlt = faSquareRootVariable;\nvar faSquareRss = {\n prefix: 'fas',\n iconName: 'square-rss',\n icon: [\n 448,\n 512,\n [\n \"rss-square\"\n ],\n \"f143\",\n \"M384 32H64C28.65 32 0 60.66 0 96v320c0 35.34 28.65 64 64 64h320c35.35 0 64-28.66 64-64V96C448 60.66 419.3 32 384 32zM150.6 374.6C144.4 380.9 136.2 384 128 384s-16.38-3.121-22.63-9.371c-12.5-12.5-12.5-32.76 0-45.26C111.6 323.1 119.8 320 128 320s16.38 3.121 22.63 9.371C163.1 341.9 163.1 362.1 150.6 374.6zM249.6 383.9C249 383.1 248.5 384 247.1 384c-12.53 0-23.09-9.75-23.92-22.44C220.5 306.9 173.1 259.5 118.4 255.9c-13.22-.8438-23.25-12.28-22.39-25.5c.8594-13.25 12.41-22.81 25.52-22.38c77.86 5.062 145.3 72.5 150.4 150.4C272.8 371.7 262.8 383.1 249.6 383.9zM345 383.1C344.7 384 344.3 384 343.1 384c-12.8 0-23.42-10.09-23.97-23C315.6 254.6 225.4 164.4 119 159.1C105.8 159.4 95.47 148.3 96.02 135C96.58 121.8 107.9 111.2 121 112c130.7 5.469 241.5 116.3 246.1 246.1C368.5 372.3 358.3 383.4 345 383.1z\"\n ]\n};\nvar faRssSquare = faSquareRss;\nvar faSquareShareNodes = {\n prefix: 'fas',\n iconName: 'square-share-nodes',\n icon: [\n 448,\n 512,\n [\n \"share-alt-square\"\n ],\n \"f1e1\",\n \"M384 32C419.3 32 448 60.65 448 96V416C448 451.3 419.3 480 384 480H64C28.65 480 0 451.3 0 416V96C0 60.65 28.65 32 64 32H384zM320 96C284.7 96 256 124.7 256 160C256 162.5 256.1 164.9 256.4 167.3L174.5 212C162.8 199.7 146.3 192 128 192C92.65 192 64 220.7 64 256C64 291.3 92.65 320 128 320C146.3 320 162.8 312.3 174.5 299.1L256.4 344.7C256.1 347.1 256 349.5 256 352C256 387.3 284.7 416 320 416C355.3 416 384 387.3 384 352C384 316.7 355.3 288 320 288C304.6 288 290.5 293.4 279.4 302.5L194.1 256L279.4 209.5C290.5 218.6 304.6 224 320 224C355.3 224 384 195.3 384 160C384 124.7 355.3 96 320 96V96z\"\n ]\n};\nvar faShareAltSquare = faSquareShareNodes;\nvar faSquareUpRight = {\n prefix: 'fas',\n iconName: 'square-up-right',\n icon: [\n 448,\n 512,\n [\n 8599,\n \"external-link-square-alt\"\n ],\n \"f360\",\n \"M384 32H64C28.65 32 0 60.65 0 96v320c0 35.34 28.65 64 64 64h320c35.35 0 64-28.66 64-64V96C448 60.65 419.3 32 384 32zM330.5 323.9c0 6.473-3.889 12.3-9.877 14.78c-5.979 2.484-12.86 1.105-17.44-3.469l-45.25-45.25l-67.92 67.92c-12.5 12.5-32.72 12.46-45.21-.0411l-22.63-22.63C109.7 322.7 109.6 302.5 122.1 289.1l67.92-67.92L144.8 176.8C140.2 172.2 138.8 165.3 141.3 159.4c2.477-5.984 8.309-9.875 14.78-9.875h158.4c8.835 0 15.1 7.163 15.1 15.1V323.9z\"\n ]\n};\nvar faExternalLinkSquareAlt = faSquareUpRight;\nvar faSquareXmark = {\n prefix: 'fas',\n iconName: 'square-xmark',\n icon: [\n 448,\n 512,\n [\n 10062,\n \"times-square\",\n \"xmark-square\"\n ],\n \"f2d3\",\n \"M384 32C419.3 32 448 60.65 448 96V416C448 451.3 419.3 480 384 480H64C28.65 480 0 451.3 0 416V96C0 60.65 28.65 32 64 32H384zM143 208.1L190.1 255.1L143 303C133.7 312.4 133.7 327.6 143 336.1C152.4 346.3 167.6 346.3 176.1 336.1L223.1 289.9L271 336.1C280.4 346.3 295.6 346.3 304.1 336.1C314.3 327.6 314.3 312.4 304.1 303L257.9 255.1L304.1 208.1C314.3 199.6 314.3 184.4 304.1 175C295.6 165.7 280.4 165.7 271 175L223.1 222.1L176.1 175C167.6 165.7 152.4 165.7 143 175C133.7 184.4 133.7 199.6 143 208.1V208.1z\"\n ]\n};\nvar faTimesSquare = faSquareXmark;\nvar faXmarkSquare = faSquareXmark;\nvar faStairs = {\n prefix: 'fas',\n iconName: 'stairs',\n icon: [\n 576,\n 512,\n [],\n \"e289\",\n \"M576 64c0 17.67-14.31 32-32 32h-96v96c0 17.67-14.31 32-32 32h-96v96c0 17.67-14.31 32-32 32H192v96c0 17.67-14.31 32-32 32H32c-17.69 0-32-14.33-32-32s14.31-32 32-32h96v-96c0-17.67 14.31-32 32-32h96V192c0-17.67 14.31-32 32-32h96V64c0-17.67 14.31-32 32-32h128C561.7 32 576 46.33 576 64z\"\n ]\n};\nvar faStamp = {\n prefix: 'fas',\n iconName: 'stamp',\n icon: [\n 512,\n 512,\n [],\n \"f5bf\",\n \"M366.2 256H400C461.9 256 512 306.1 512 368C512 388.9 498.6 406.7 480 413.3V464C480 490.5 458.5 512 432 512H80C53.49 512 32 490.5 32 464V413.3C13.36 406.7 0 388.9 0 368C0 306.1 50.14 256 112 256H145.8C175.7 256 200 231.7 200 201.8C200 184.3 190.8 168.5 180.1 154.8C167.5 138.5 160 118.1 160 96C160 42.98 202.1 0 256 0C309 0 352 42.98 352 96C352 118.1 344.5 138.5 331.9 154.8C321.2 168.5 312 184.3 312 201.8C312 231.7 336.3 256 366.2 256zM416 416H96V448H416V416z\"\n ]\n};\nvar faStar = {\n prefix: 'fas',\n iconName: 'star',\n icon: [\n 576,\n 512,\n [\n 61446,\n 11088\n ],\n \"f005\",\n \"M381.2 150.3L524.9 171.5C536.8 173.2 546.8 181.6 550.6 193.1C554.4 204.7 551.3 217.3 542.7 225.9L438.5 328.1L463.1 474.7C465.1 486.7 460.2 498.9 450.2 506C440.3 513.1 427.2 514 416.5 508.3L288.1 439.8L159.8 508.3C149 514 135.9 513.1 126 506C116.1 498.9 111.1 486.7 113.2 474.7L137.8 328.1L33.58 225.9C24.97 217.3 21.91 204.7 25.69 193.1C29.46 181.6 39.43 173.2 51.42 171.5L195 150.3L259.4 17.97C264.7 6.954 275.9-.0391 288.1-.0391C300.4-.0391 311.6 6.954 316.9 17.97L381.2 150.3z\"\n ]\n};\nvar faStarAndCrescent = {\n prefix: 'fas',\n iconName: 'star-and-crescent',\n icon: [\n 512,\n 512,\n [\n 9770\n ],\n \"f699\",\n \"M340.5 466.4c-1.5 0-6.875 .5-9.25 .5c-116.3 0-210.8-94.63-210.8-210.9s94.5-210.9 210.8-210.9c2.375 0 7.75 .5 9.25 .5c7.125 0 13.25-5 14.75-12c1.375-7.25-2.625-14.5-9.5-17.12c-29.13-11-59.38-16.5-89.75-16.5c-141.1 0-256 114.9-256 256s114.9 256 256 256c30.25 0 60.25-5.5 89.38-16.38c5.875-2 10.25-7.625 10.25-14.25C355.6 473.4 349.3 466.4 340.5 466.4zM503.5 213.9l-76.38-11.12L392.9 133.5C391.1 129.9 387.5 128 384 128c-3.5 0-7.125 1.875-9 5.5l-34.13 69.25l-76.38 11.12c-8.125 1.125-11.38 11.25-5.5 17l55.25 53.88l-13 76c-1.125 6.5 3.1 11.75 9.75 11.75c1.5 0 3.125-.375 4.625-1.25l68.38-35.88l68.25 35.88c1.625 .875 3.125 1.25 4.75 1.25c5.75 0 10.88-5.25 9.75-11.75l-13-76l55.25-53.88C514.9 225.1 511.6 214.1 503.5 213.9z\"\n ]\n};\nvar faStarHalf = {\n prefix: 'fas',\n iconName: 'star-half',\n icon: [\n 576,\n 512,\n [\n 61731\n ],\n \"f089\",\n \"M288 439.8L159.8 508.3C149 514 135.9 513.1 126 506C116.1 498.9 111.1 486.7 113.2 474.7L137.8 328.1L33.58 225.9C24.97 217.3 21.91 204.7 25.69 193.1C29.46 181.6 39.43 173.2 51.42 171.5L195 150.3L259.4 17.97C264.7 6.995 275.8 .0131 287.1-.0391L288 439.8zM433.2 512C432.1 512.1 431 512.1 429.9 512H433.2z\"\n ]\n};\nvar faStarHalfStroke = {\n prefix: 'fas',\n iconName: 'star-half-stroke',\n icon: [\n 576,\n 512,\n [\n \"star-half-alt\"\n ],\n \"f5c0\",\n \"M463.1 474.7C465.1 486.7 460.2 498.9 450.2 506C440.3 513.1 427.2 514 416.5 508.3L288.1 439.8L159.8 508.3C149 514 135.9 513.1 126 506C116.1 498.9 111.1 486.7 113.2 474.7L137.8 328.1L33.58 225.9C24.97 217.3 21.91 204.7 25.69 193.1C29.46 181.6 39.43 173.2 51.42 171.5L195 150.3L259.4 17.97C264.7 6.954 275.9-.0391 288.1-.0391C300.4-.0391 311.6 6.954 316.9 17.97L381.2 150.3L524.9 171.5C536.8 173.2 546.8 181.6 550.6 193.1C554.4 204.7 551.3 217.3 542.7 225.9L438.5 328.1L463.1 474.7zM288 376.4L288.1 376.3L399.7 435.9L378.4 309.6L469.2 219.8L343.8 201.4L288.1 86.85L288 87.14V376.4z\"\n ]\n};\nvar faStarHalfAlt = faStarHalfStroke;\nvar faStarOfDavid = {\n prefix: 'fas',\n iconName: 'star-of-david',\n icon: [\n 512,\n 512,\n [\n 10017\n ],\n \"f69a\",\n \"M490.7 345.4L435.6 256l55.1-89.38c14.87-24.25-3.62-54.61-33.12-54.61l-110.6-.005l-57.87-93.1C281.7 6.003 268.9 0 256 0C243.1 0 230.3 6.003 222.9 18L165 112H54.39c-29.62 0-47.99 30.37-33.12 54.62L76.37 256l-55.1 89.38C6.4 369.6 24.77 399.1 54.39 399.1h110.6l57.87 93.1C230.3 505.1 243.1 512 256 512c12.88 0 25.74-6.002 33.12-18l57.83-93.1h110.7C487.2 399.1 505.6 369.6 490.7 345.4zM256 73.77l23.59 38.23H232.5L256 73.77zM89.48 343.1l20.59-33.35l20.45 33.35H89.48zM110 201.3L89.48 168h41.04L110 201.3zM256 438.2l-23.59-38.25h47.08L256 438.2zM313.9 343.1H198L143.8 256l54.22-87.1h116L368.3 256L313.9 343.1zM381.3 343.1l20.67-33.29l20.52 33.29H381.3zM401.1 201.3l-20.51-33.29h41.04L401.1 201.3z\"\n ]\n};\nvar faStarOfLife = {\n prefix: 'fas',\n iconName: 'star-of-life',\n icon: [\n 512,\n 512,\n [],\n \"f621\",\n \"M489.1 363.3l-24.03 41.59c-6.635 11.48-21.33 15.41-32.82 8.78l-129.1-74.56V488c0 13.25-10.75 24-24.02 24H231.1c-13.27 0-24.02-10.75-24.02-24v-148.9L78.87 413.7c-11.49 6.629-26.19 2.698-32.82-8.78l-24.03-41.59c-6.635-11.48-2.718-26.14 8.774-32.77L159.9 256L30.8 181.5C19.3 174.8 15.39 160.2 22.02 148.7l24.03-41.59c6.635-11.48 21.33-15.41 32.82-8.781l129.1 74.56L207.1 24c0-13.25 10.75-24 24.02-24h48.04c13.27 0 24.02 10.75 24.02 24l.0005 148.9l129.1-74.56c11.49-6.629 26.19-2.698 32.82 8.78l24.02 41.59c6.637 11.48 2.718 26.14-8.774 32.77L352.1 256l129.1 74.53C492.7 337.2 496.6 351.8 489.1 363.3z\"\n ]\n};\nvar faSterlingSign = {\n prefix: 'fas',\n iconName: 'sterling-sign',\n icon: [\n 320,\n 512,\n [\n 163,\n \"gbp\",\n \"pound-sign\"\n ],\n \"f154\",\n \"M112 223.1H224C241.7 223.1 256 238.3 256 255.1C256 273.7 241.7 287.1 224 287.1H112V332.5C112 361.5 104.1 389.1 89.2 414.9L88.52 416H288C305.7 416 320 430.3 320 448C320 465.7 305.7 480 288 480H32C20.47 480 9.834 473.8 4.154 463.8C-1.527 453.7-1.371 441.4 4.56 431.5L34.32 381.9C43.27 367 48 349.9 48 332.5V288H32C14.33 288 0 273.7 0 256C0 238.3 14.33 224 32 224H48V160.4C48 89.47 105.5 32 176.4 32C190.2 32 203.9 34.22 216.1 38.59L298.1 65.64C314.9 71.23 323.9 89.35 318.4 106.1C312.8 122.9 294.6 131.9 277.9 126.4L196.7 99.3C190.2 97.12 183.3 96 176.4 96C140.8 96 112 124.8 112 160.4V223.1z\"\n ]\n};\nvar faGbp = faSterlingSign;\nvar faPoundSign = faSterlingSign;\nvar faStethoscope = {\n prefix: 'fas',\n iconName: 'stethoscope',\n icon: [\n 576,\n 512,\n [\n 129658\n ],\n \"f0f1\",\n \"M480 112c-44.18 0-80 35.82-80 80c0 32.84 19.81 60.98 48.11 73.31v78.7c0 57.25-50.25 104-112 104c-60 0-109.3-44.1-111.9-99.23C296.1 333.8 352 269.3 352 191.1V36.59c0-11.38-8.15-21.38-19.28-23.5L269.8 .4775c-13-2.625-25.54 5.766-28.16 18.77L238.4 34.99c-2.625 13 5.812 25.59 18.81 28.22l30.69 6.059L287.9 190.7c0 52.88-42.13 96.63-95.13 97.13c-53.38 .5-96.81-42.56-96.81-95.93L95.89 69.37l30.72-6.112c13-2.5 21.41-15.15 18.78-28.15L142.3 19.37c-2.5-13-15.15-21.41-28.15-18.78L51.28 12.99C40.15 15.24 32 25.09 32 36.59v155.4c0 77.25 55.11 142 128.1 156.8C162.7 439.3 240.6 512 336 512c97 0 176-75.37 176-168V265.3c28.23-12.36 48-40.46 48-73.25C560 147.8 524.2 112 480 112zM480 216c-13.25 0-24-10.75-24-24S466.7 168 480 168S504 178.7 504 192S493.3 216 480 216z\"\n ]\n};\nvar faStop = {\n prefix: 'fas',\n iconName: 'stop',\n icon: [\n 384,\n 512,\n [\n 9209\n ],\n \"f04d\",\n \"M384 128v255.1c0 35.35-28.65 64-64 64H64c-35.35 0-64-28.65-64-64V128c0-35.35 28.65-64 64-64H320C355.3 64 384 92.65 384 128z\"\n ]\n};\nvar faStopwatch = {\n prefix: 'fas',\n iconName: 'stopwatch',\n icon: [\n 448,\n 512,\n [\n 9201\n ],\n \"f2f2\",\n \"M272 0C289.7 0 304 14.33 304 32C304 49.67 289.7 64 272 64H256V98.45C293.5 104.2 327.7 120 355.7 143L377.4 121.4C389.9 108.9 410.1 108.9 422.6 121.4C435.1 133.9 435.1 154.1 422.6 166.6L398.5 190.8C419.7 223.3 432 262.2 432 304C432 418.9 338.9 512 224 512C109.1 512 16 418.9 16 304C16 200 92.32 113.8 192 98.45V64H176C158.3 64 144 49.67 144 32C144 14.33 158.3 0 176 0L272 0zM248 192C248 178.7 237.3 168 224 168C210.7 168 200 178.7 200 192V320C200 333.3 210.7 344 224 344C237.3 344 248 333.3 248 320V192z\"\n ]\n};\nvar faStopwatch20 = {\n prefix: 'fas',\n iconName: 'stopwatch-20',\n icon: [\n 448,\n 512,\n [],\n \"e06f\",\n \"M276 256C276 249.4 281.4 244 288 244C294.6 244 300 249.4 300 256V352C300 358.6 294.6 364 288 364C281.4 364 276 358.6 276 352V256zM272 0C289.7 0 304 14.33 304 32C304 49.67 289.7 64 272 64H256V98.45C293.5 104.2 327.7 120 355.7 143L377.4 121.4C389.9 108.9 410.1 108.9 422.6 121.4C435.1 133.9 435.1 154.1 422.6 166.6L398.5 190.8C419.7 223.3 432 262.2 432 304C432 418.9 338.9 512 224 512C109.1 512 16 418.9 16 304C16 200 92.32 113.8 192 98.45V64H176C158.3 64 144 49.67 144 32C144 14.33 158.3 0 176 0L272 0zM288 204C259.3 204 236 227.3 236 256V352C236 380.7 259.3 404 288 404C316.7 404 340 380.7 340 352V256C340 227.3 316.7 204 288 204zM172 256.5V258.8C172 262.4 170.7 265.9 168.3 268.6L129.2 312.5C115.5 327.9 108 347.8 108 368.3V384C108 395 116.1 404 128 404H192C203 404 212 395 212 384C212 372.1 203 364 192 364H148.2C149.1 354.8 152.9 346.1 159.1 339.1L198.2 295.2C207.1 285.1 211.1 272.2 211.1 258.8V256.5C211.1 227.5 188.5 204 159.5 204C136.8 204 116.8 218.5 109.6 239.9L109 241.7C105.5 252.2 111.2 263.5 121.7 266.1C132.2 270.5 143.5 264.8 146.1 254.3L147.6 252.6C149.3 247.5 154.1 244 159.5 244C166.4 244 171.1 249.6 171.1 256.5L172 256.5z\"\n ]\n};\nvar faStore = {\n prefix: 'fas',\n iconName: 'store',\n icon: [\n 576,\n 512,\n [],\n \"f54e\",\n \"M495.5 223.2C491.6 223.7 487.6 224 483.4 224C457.4 224 434.2 212.6 418.3 195C402.4 212.6 379.2 224 353.1 224C327 224 303.8 212.6 287.9 195C272 212.6 248.9 224 222.7 224C196.7 224 173.5 212.6 157.6 195C141.7 212.6 118.5 224 92.36 224C88.3 224 84.21 223.7 80.24 223.2C24.92 215.8-1.255 150.6 28.33 103.8L85.66 13.13C90.76 4.979 99.87 0 109.6 0H466.4C476.1 0 485.2 4.978 490.3 13.13L547.6 103.8C577.3 150.7 551 215.8 495.5 223.2H495.5zM499.7 254.9C503.1 254.4 508 253.6 512 252.6V448C512 483.3 483.3 512 448 512H128C92.66 512 64 483.3 64 448V252.6C67.87 253.6 71.86 254.4 75.97 254.9L76.09 254.9C81.35 255.6 86.83 256 92.36 256C104.8 256 116.8 254.1 128 250.6V384H448V250.7C459.2 254.1 471.1 256 483.4 256C489 256 494.4 255.6 499.7 254.9L499.7 254.9z\"\n ]\n};\nvar faStoreSlash = {\n prefix: 'fas',\n iconName: 'store-slash',\n icon: [\n 640,\n 512,\n [],\n \"e071\",\n \"M94.92 49.09L117.7 13.13C122.8 4.98 131.9 .0007 141.6 .0007H498.4C508.1 .0007 517.2 4.979 522.3 13.13L579.6 103.8C609.3 150.7 583 215.8 527.5 223.2C523.6 223.7 519.6 224 515.4 224C489.4 224 466.2 212.6 450.3 195C434.4 212.6 411.2 224 385.1 224C359 224 335.8 212.6 319.9 195C314.4 201.1 308.1 206.4 301.2 210.7L480 350.9V250.7C491.2 254.1 503.1 256 515.4 256C521 256 526.4 255.6 531.7 254.9L531.7 254.9C535.1 254.4 540 253.6 544 252.6V401.1L630.8 469.1C641.2 477.3 643.1 492.4 634.9 502.8C626.7 513.2 611.6 515.1 601.2 506.9L9.196 42.89C-1.236 34.71-3.065 19.63 5.112 9.196C13.29-1.236 28.37-3.065 38.81 5.112L94.92 49.09zM112.2 223.2C68.36 217.3 42.82 175.1 48.9 134.5L155.3 218.4C145.7 222 135.3 224 124.4 224C120.3 224 116.2 223.7 112.2 223.2V223.2zM160 384H365.5L514.9 501.7C504.8 508.2 492.9 512 480 512H160C124.7 512 96 483.3 96 448V252.6C99.87 253.6 103.9 254.4 107.1 254.9L108.1 254.9C113.3 255.6 118.8 256 124.4 256C136.8 256 148.8 254.1 160 250.6V384z\"\n ]\n};\nvar faStreetView = {\n prefix: 'fas',\n iconName: 'street-view',\n icon: [\n 512,\n 512,\n [],\n \"f21d\",\n \"M320 64C320 99.35 291.3 128 256 128C220.7 128 192 99.35 192 64C192 28.65 220.7 0 256 0C291.3 0 320 28.65 320 64zM288 160C323.3 160 352 188.7 352 224V272C352 289.7 337.7 304 320 304H318.2L307.2 403.5C305.4 419.7 291.7 432 275.4 432H236.6C220.3 432 206.6 419.7 204.8 403.5L193.8 304H192C174.3 304 160 289.7 160 272V224C160 188.7 188.7 160 224 160H288zM63.27 414.7C60.09 416.3 57.47 417.8 55.33 419.2C51.7 421.6 51.72 426.4 55.34 428.8C64.15 434.6 78.48 440.6 98.33 446.1C137.7 456.1 193.5 464 256 464C318.5 464 374.3 456.1 413.7 446.1C433.5 440.6 447.9 434.6 456.7 428.8C460.3 426.4 460.3 421.6 456.7 419.2C454.5 417.8 451.9 416.3 448.7 414.7C433.4 406.1 409.9 399.8 379.7 394.2C366.6 391.8 358 379.3 360.4 366.3C362.8 353.3 375.3 344.6 388.3 347C420.8 352.9 449.2 361.2 470.3 371.8C480.8 377.1 490.6 383.5 498 391.4C505.6 399.5 512 410.5 512 424C512 445.4 496.5 460.1 482.9 469C468.2 478.6 448.6 486.3 426.4 492.4C381.8 504.7 321.6 512 256 512C190.4 512 130.2 504.7 85.57 492.4C63.44 486.3 43.79 478.6 29.12 469C15.46 460.1 0 445.4 0 424C0 410.5 6.376 399.5 13.96 391.4C21.44 383.5 31.24 377.1 41.72 371.8C62.75 361.2 91.24 352.9 123.7 347C136.7 344.6 149.2 353.3 151.6 366.3C153.1 379.3 145.4 391.8 132.3 394.2C102.1 399.8 78.57 406.1 63.27 414.7H63.27z\"\n ]\n};\nvar faStrikethrough = {\n prefix: 'fas',\n iconName: 'strikethrough',\n icon: [\n 512,\n 512,\n [],\n \"f0cc\",\n \"M332.2 319.9c17.22 12.17 22.33 26.51 18.61 48.21c-3.031 17.59-10.88 29.34-24.72 36.99c-35.44 19.75-108.5 11.96-186-19.68c-16.34-6.686-35.03 1.156-41.72 17.53s1.188 35.05 17.53 41.71c31.75 12.93 95.69 35.37 157.6 35.37c29.62 0 58.81-5.156 83.72-18.96c30.81-17.09 50.44-45.46 56.72-82.11c3.998-23.27 2.168-42.58-3.488-59.05H332.2zM488 239.9l-176.5-.0309c-15.85-5.613-31.83-10.34-46.7-14.62c-85.47-24.62-110.9-39.05-103.7-81.33c2.5-14.53 10.16-25.96 22.72-34.03c20.47-13.15 64.06-23.84 155.4 .3438c17.09 4.531 34.59-5.654 39.13-22.74c4.531-17.09-5.656-34.59-22.75-39.12c-91.31-24.18-160.7-21.62-206.3 7.654C121.8 73.72 103.6 101.1 98.09 133.1C89.26 184.5 107.9 217.3 137.2 239.9L24 239.9c-13.25 0-24 10.75-24 23.1c0 13.25 10.75 23.1 24 23.1h464c13.25 0 24-10.75 24-23.1C512 250.7 501.3 239.9 488 239.9z\"\n ]\n};\nvar faStroopwafel = {\n prefix: 'fas',\n iconName: 'stroopwafel',\n icon: [\n 512,\n 512,\n [],\n \"f551\",\n \"M188.1 210.8l-45.25 45.25l45.25 45.25l45.25-45.25L188.1 210.8zM301.2 188.1l-45.25-45.25L210.7 188.1l45.25 45.25L301.2 188.1zM210.7 323.9l45.25 45.25l45.25-45.25L255.1 278.6L210.7 323.9zM256 16c-132.5 0-240 107.5-240 240s107.5 240 240 240s240-107.5 240-240S388.5 16 256 16zM442.6 295.6l-11.25 11.25c-3.125 3.125-8.25 3.125-11.38 0L391.8 278.6l-45.25 45.25l34 33.88l16.88-16.88c3.125-3.125 8.251-3.125 11.38 0l11.25 11.25c3.125 3.125 3.125 8.25 0 11.38l-16.88 16.88l16.88 17c3.125 3.125 3.125 8.25 0 11.38l-11.25 11.25c-3.125 3.125-8.251 3.125-11.38 0l-16.88-17l-17 17c-3.125 3.125-8.25 3.125-11.38 0l-11.25-11.25c-3.125-3.125-3.125-8.25 0-11.38l17-17l-34-33.88l-45.25 45.25l28.25 28.25c3.125 3.125 3.125 8.25 0 11.38l-11.25 11.25c-3.125 3.125-8.25 3.125-11.38 0l-28.25-28.25L227.7 442.6c-3.125 3.125-8.25 3.125-11.38 0l-11.25-11.25c-3.125-3.125-3.125-8.25 0-11.38l28.25-28.25l-45.25-45.25l-33.88 34l16.88 16.88c3.125 3.125 3.125 8.25 0 11.38l-11.25 11.25c-3.125 3.125-8.25 3.125-11.38 0L131.6 403.1l-16.1 16.88c-3.125 3.125-8.25 3.125-11.38 0l-11.25-11.25c-3.125-3.125-3.125-8.25 0-11.38l17-16.88l-17-17c-3.125-3.125-3.125-8.25 0-11.38l11.25-11.25c3.125-3.125 8.25-3.125 11.38 0l16.1 17l33.88-34L120.2 278.6l-28.25 28.25c-3.125 3.125-8.25 3.125-11.38 0L69.37 295.6c-3.125-3.125-3.125-8.25 0-11.38l28.25-28.25l-28.25-28.25c-3.125-3.125-3.125-8.25 0-11.38l11.25-11.25c3.125-3.125 8.25-3.125 11.38 0l28.25 28.25l45.25-45.25l-34-34l-16.88 17c-3.125 3.125-8.25 3.125-11.38 0l-11.25-11.25c-3.125-3.125-3.125-8.25 0-11.38l16.88-17l-16.88-16.88c-3.125-3.125-3.125-8.25 0-11.38l11.25-11.25c3.125-3.125 8.25-3.125 11.38 0l16.88 17l17-17c3.125-3.125 8.25-3.125 11.38 0l11.25 11.25c3.125 3.125 3.125 8.25 0 11.38l-17 16.88l34 34l45.25-45.25L205.1 92c-3.125-3.125-3.125-8.25 0-11.38l11.25-11.25c3.125-3.125 8.25-3.125 11.38 0l28.25 28.25l28.25-28.25c3.125-3.125 8.25-3.125 11.38 0l11.25 11.25c3.125 3.125 3.125 8.25 0 11.38l-28.25 28.25l45.25 45.25l34-34l-17-16.88c-3.125-3.125-3.125-8.25 0-11.38l11.25-11.25c3.125-3.125 8.25-3.125 11.38 0l17 16.88l16.88-16.88c3.125-3.125 8.251-3.125 11.38 0l11.25 11.25c3.125 3.125 3.125 8.25 0 11.38l-17 16.88l17 17c3.125 3.125 3.125 8.25 0 11.38l-11.25 11.25c-3.125 3.125-8.251 3.125-11.38 0l-16.88-17l-34 34l45.25 45.25l28.25-28.25c3.125-3.125 8.25-3.125 11.38 0l11.25 11.25c3.125 3.125 3.125 8.25 0 11.38l-28.25 28.25l28.25 28.25C445.7 287.4 445.7 292.5 442.6 295.6zM278.6 256l45.25 45.25l45.25-45.25l-45.25-45.25L278.6 256z\"\n ]\n};\nvar faSubscript = {\n prefix: 'fas',\n iconName: 'subscript',\n icon: [\n 512,\n 512,\n [],\n \"f12c\",\n \"M480 448v-128c0-11.09-5.75-21.38-15.17-27.22c-9.422-5.875-21.25-6.344-31.14-1.406l-32 16c-15.81 7.906-22.22 27.12-14.31 42.94c5.609 11.22 16.89 17.69 28.62 17.69v80c-17.67 0-32 14.31-32 32s14.33 32 32 32h64c17.67 0 32-14.31 32-32S497.7 448 480 448zM320 128c17.67 0 32-14.31 32-32s-14.33-32-32-32l-32-.0024c-10.44 0-20.23 5.101-26.22 13.66L176 200.2L90.22 77.67C84.23 69.11 74.44 64.01 64 64.01L32 64.01c-17.67 0-32 14.32-32 32s14.33 32 32 32h15.34L136.9 256l-89.6 128H32c-17.67 0-32 14.31-32 32s14.33 31.1 32 31.1l32-.0024c10.44 0 20.23-5.086 26.22-13.65L176 311.8l85.78 122.5C267.8 442.9 277.6 448 288 448l32 .0024c17.67 0 32-14.31 32-31.1s-14.33-32-32-32h-15.34l-89.6-128l89.6-127.1H320z\"\n ]\n};\nvar faSuitcase = {\n prefix: 'fas',\n iconName: 'suitcase',\n icon: [\n 512,\n 512,\n [\n 129523\n ],\n \"f0f2\",\n \"M0 144v288C0 457.6 22.41 480 48 480H96V96H48C22.41 96 0 118.4 0 144zM336 0h-160C150.4 0 128 22.41 128 48V480h256V48C384 22.41 361.6 0 336 0zM336 96h-160V48h160V96zM464 96H416v384h48c25.59 0 48-22.41 48-48v-288C512 118.4 489.6 96 464 96z\"\n ]\n};\nvar faSuitcaseMedical = {\n prefix: 'fas',\n iconName: 'suitcase-medical',\n icon: [\n 512,\n 512,\n [\n \"medkit\"\n ],\n \"f0fa\",\n \"M0 144v288C0 457.6 22.41 480 48 480H64V96H48C22.41 96 0 118.4 0 144zM464 96H448v384h16c25.59 0 48-22.41 48-48v-288C512 118.4 489.6 96 464 96zM384 48C384 22.41 361.6 0 336 0h-160C150.4 0 128 22.41 128 48V96H96v384h320V96h-32V48zM176 48h160V96h-160V48zM352 312C352 316.4 348.4 320 344 320H288v56c0 4.375-3.625 8-8 8h-48C227.6 384 224 380.4 224 376V320H168C163.6 320 160 316.4 160 312v-48C160 259.6 163.6 256 168 256H224V200C224 195.6 227.6 192 232 192h48C284.4 192 288 195.6 288 200V256h56C348.4 256 352 259.6 352 264V312z\"\n ]\n};\nvar faMedkit = faSuitcaseMedical;\nvar faSuitcaseRolling = {\n prefix: 'fas',\n iconName: 'suitcase-rolling',\n icon: [\n 448,\n 512,\n [],\n \"f5c1\",\n \"M368 128h-47.95l.0123-80c0-26.5-21.5-48-48-48h-96c-26.5 0-48 21.5-48 48L128 128H80C53.5 128 32 149.5 32 176v256C32 458.5 53.5 480 80 480h16.05L96 496C96 504.9 103.1 512 112 512h32C152.9 512 160 504.9 160 496L160.1 480h128L288 496c0 8.875 7.125 16 16 16h32c8.875 0 16-7.125 16-16l.0492-16H368c26.5 0 48-21.5 48-48v-256C416 149.5 394.5 128 368 128zM176.1 48h96V128h-96V48zM336 384h-224C103.2 384 96 376.8 96 368C96 359.2 103.2 352 112 352h224c8.801 0 16 7.199 16 16C352 376.8 344.8 384 336 384zM336 256h-224C103.2 256 96 248.8 96 240C96 231.2 103.2 224 112 224h224C344.8 224 352 231.2 352 240C352 248.8 344.8 256 336 256z\"\n ]\n};\nvar faSun = {\n prefix: 'fas',\n iconName: 'sun',\n icon: [\n 512,\n 512,\n [\n 9728\n ],\n \"f185\",\n \"M256 159.1c-53.02 0-95.1 42.98-95.1 95.1S202.1 351.1 256 351.1s95.1-42.98 95.1-95.1S309 159.1 256 159.1zM509.3 347L446.1 255.1l63.15-91.01c6.332-9.125 1.104-21.74-9.826-23.72l-109-19.7l-19.7-109c-1.975-10.93-14.59-16.16-23.72-9.824L256 65.89L164.1 2.736c-9.125-6.332-21.74-1.107-23.72 9.824L121.6 121.6L12.56 141.3C1.633 143.2-3.596 155.9 2.736 164.1L65.89 256l-63.15 91.01c-6.332 9.125-1.105 21.74 9.824 23.72l109 19.7l19.7 109c1.975 10.93 14.59 16.16 23.72 9.824L256 446.1l91.01 63.15c9.127 6.334 21.75 1.107 23.72-9.822l19.7-109l109-19.7C510.4 368.8 515.6 356.1 509.3 347zM256 383.1c-70.69 0-127.1-57.31-127.1-127.1c0-70.69 57.31-127.1 127.1-127.1s127.1 57.3 127.1 127.1C383.1 326.7 326.7 383.1 256 383.1z\"\n ]\n};\nvar faSuperscript = {\n prefix: 'fas',\n iconName: 'superscript',\n icon: [\n 512,\n 512,\n [],\n \"f12b\",\n \"M480 160v-128c0-11.09-5.75-21.37-15.17-27.22C455.4-1.048 443.6-1.548 433.7 3.39l-32 16c-15.81 7.906-22.22 27.12-14.31 42.94C392.1 73.55 404.3 80.01 416 80.01v80c-17.67 0-32 14.31-32 32s14.33 32 32 32h64c17.67 0 32-14.31 32-32S497.7 160 480 160zM320 128c17.67 0 32-14.31 32-32s-14.33-32-32-32l-32-.0024c-10.44 0-20.23 5.101-26.22 13.66L176 200.2L90.22 77.67C84.23 69.11 74.44 64.01 64 64.01L32 64.01c-17.67 0-32 14.32-32 32s14.33 32 32 32h15.34L136.9 256l-89.6 128H32c-17.67 0-32 14.31-32 32s14.33 31.1 32 31.1l32-.0024c10.44 0 20.23-5.086 26.22-13.65L176 311.8l85.78 122.5C267.8 442.9 277.6 448 288 448l32 .0024c17.67 0 32-14.31 32-31.1s-14.33-32-32-32h-15.34l-89.6-128l89.6-127.1H320z\"\n ]\n};\nvar faSwatchbook = {\n prefix: 'fas',\n iconName: 'swatchbook',\n icon: [\n 512,\n 512,\n [],\n \"f5c3\",\n \"M0 32C0 14.33 14.33 0 32 0H160C177.7 0 192 14.33 192 32V416C192 469 149 512 96 512C42.98 512 0 469 0 416V32zM128 64H64V128H128V64zM64 256H128V192H64V256zM96 440C109.3 440 120 429.3 120 416C120 402.7 109.3 392 96 392C82.75 392 72 402.7 72 416C72 429.3 82.75 440 96 440zM224 416V154L299.4 78.63C311.9 66.13 332.2 66.13 344.7 78.63L435.2 169.1C447.7 181.6 447.7 201.9 435.2 214.4L223.6 425.9C223.9 422.7 224 419.3 224 416V416zM374.8 320H480C497.7 320 512 334.3 512 352V480C512 497.7 497.7 512 480 512H182.8L374.8 320z\"\n ]\n};\nvar faSynagogue = {\n prefix: 'fas',\n iconName: 'synagogue',\n icon: [\n 640,\n 512,\n [\n 128333\n ],\n \"f69b\",\n \"M309.8 3.708C315.7-1.236 324.3-1.236 330.2 3.708L451.2 104.5C469.5 119.7 480 142.2 480 165.1V512H384V384C384 348.7 355.3 320 320 320C284.7 320 256 348.7 256 384V512H160V165.1C160 142.2 170.5 119.7 188.8 104.5L309.8 3.708zM326.1 124.3C323.9 118.9 316.1 118.9 313 124.3L297.2 152.4L264.9 152.1C258.7 152.1 254.8 158.8 257.9 164.2L274.3 191.1L257.9 219.8C254.8 225.2 258.7 231.9 264.9 231.9L297.2 231.6L313 259.7C316.1 265.1 323.9 265.1 326.1 259.7L342.8 231.6L375.1 231.9C381.3 231.9 385.2 225.2 382.1 219.8L365.7 191.1L382.1 164.2C385.2 158.8 381.3 152.1 375.1 152.1L342.8 152.4L326.1 124.3zM512 244.5L540.1 213.3C543.1 209.9 547.5 208 552 208C556.5 208 560.9 209.9 563.9 213.3L627.7 284.2C635.6 292.1 640 304.4 640 316.3V448C640 483.3 611.3 512 576 512H512V244.5zM128 244.5V512H64C28.65 512 0 483.3 0 448V316.3C0 304.4 4.389 292.1 12.32 284.2L76.11 213.3C79.14 209.9 83.46 208 88 208C92.54 208 96.86 209.9 99.89 213.3L128 244.5z\"\n ]\n};\nvar faSyringe = {\n prefix: 'fas',\n iconName: 'syringe',\n icon: [\n 512,\n 512,\n [\n 128137\n ],\n \"f48e\",\n \"M504.1 71.03l-64-64c-9.375-9.375-24.56-9.375-33.94 0s-9.375 24.56 0 33.94L422.1 56L384 94.06l-55.03-55.03c-9.375-9.375-24.56-9.375-33.94 0c-8.467 8.467-8.873 21.47-2.047 30.86l149.1 149.1C446.3 222.1 451.1 224 456 224c6.141 0 12.28-2.344 16.97-7.031c9.375-9.375 9.375-24.56 0-33.94L417.9 128L456 89.94l15.03 15.03C475.7 109.7 481.9 112 488 112s12.28-2.344 16.97-7.031C514.3 95.59 514.3 80.41 504.1 71.03zM208.8 154.1l58.56 58.56c6.25 6.25 6.25 16.38 0 22.62C264.2 238.4 260.1 240 256 240S247.8 238.4 244.7 235.3L186.1 176.8L144.8 218.1l58.56 58.56c6.25 6.25 6.25 16.38 0 22.62C200.2 302.4 196.1 304 192 304S183.8 302.4 180.7 299.3L122.1 240.8L82.75 280.1C70.74 292.1 64 308.4 64 325.4v88.68l-56.97 56.97c-9.375 9.375-9.375 24.56 0 33.94C11.72 509.7 17.86 512 24 512s12.28-2.344 16.97-7.031L97.94 448h88.69c16.97 0 33.25-6.744 45.26-18.75l187.6-187.6l-149.1-149.1L208.8 154.1z\"\n ]\n};\nvar faT = {\n prefix: 'fas',\n iconName: 't',\n icon: [\n 384,\n 512,\n [\n 116\n ],\n \"54\",\n \"M384 64.01c0 17.67-14.33 32-32 32h-128v352c0 17.67-14.33 31.99-32 31.99s-32-14.32-32-31.99v-352H32c-17.67 0-32-14.33-32-32s14.33-32 32-32h320C369.7 32.01 384 46.34 384 64.01z\"\n ]\n};\nvar faTable = {\n prefix: 'fas',\n iconName: 'table',\n icon: [\n 512,\n 512,\n [],\n \"f0ce\",\n \"M448 32C483.3 32 512 60.65 512 96V416C512 451.3 483.3 480 448 480H64C28.65 480 0 451.3 0 416V96C0 60.65 28.65 32 64 32H448zM224 256V160H64V256H224zM64 320V416H224V320H64zM288 416H448V320H288V416zM448 256V160H288V256H448z\"\n ]\n};\nvar faTableCells = {\n prefix: 'fas',\n iconName: 'table-cells',\n icon: [\n 512,\n 512,\n [\n \"th\"\n ],\n \"f00a\",\n \"M448 32C483.3 32 512 60.65 512 96V416C512 451.3 483.3 480 448 480H64C28.65 480 0 451.3 0 416V96C0 60.65 28.65 32 64 32H448zM152 96H64V160H152V96zM208 160H296V96H208V160zM448 96H360V160H448V96zM64 288H152V224H64V288zM296 224H208V288H296V224zM360 288H448V224H360V288zM152 352H64V416H152V352zM208 416H296V352H208V416zM448 352H360V416H448V352z\"\n ]\n};\nvar faTh = faTableCells;\nvar faTableCellsLarge = {\n prefix: 'fas',\n iconName: 'table-cells-large',\n icon: [\n 512,\n 512,\n [\n \"th-large\"\n ],\n \"f009\",\n \"M448 32C483.3 32 512 60.65 512 96V416C512 451.3 483.3 480 448 480H64C28.65 480 0 451.3 0 416V96C0 60.65 28.65 32 64 32H448zM448 96H288V224H448V96zM448 288H288V416H448V288zM224 224V96H64V224H224zM64 416H224V288H64V416z\"\n ]\n};\nvar faThLarge = faTableCellsLarge;\nvar faTableColumns = {\n prefix: 'fas',\n iconName: 'table-columns',\n icon: [\n 512,\n 512,\n [\n \"columns\"\n ],\n \"f0db\",\n \"M0 96C0 60.65 28.65 32 64 32H448C483.3 32 512 60.65 512 96V416C512 451.3 483.3 480 448 480H64C28.65 480 0 451.3 0 416V96zM64 416H224V160H64V416zM448 160H288V416H448V160z\"\n ]\n};\nvar faColumns = faTableColumns;\nvar faTableList = {\n prefix: 'fas',\n iconName: 'table-list',\n icon: [\n 512,\n 512,\n [\n \"th-list\"\n ],\n \"f00b\",\n \"M0 96C0 60.65 28.65 32 64 32H448C483.3 32 512 60.65 512 96V416C512 451.3 483.3 480 448 480H64C28.65 480 0 451.3 0 416V96zM64 160H128V96H64V160zM448 96H192V160H448V96zM64 288H128V224H64V288zM448 224H192V288H448V224zM64 416H128V352H64V416zM448 352H192V416H448V352z\"\n ]\n};\nvar faThList = faTableList;\nvar faTableTennisPaddleBall = {\n prefix: 'fas',\n iconName: 'table-tennis-paddle-ball',\n icon: [\n 512,\n 512,\n [\n 127955,\n \"ping-pong-paddle-ball\",\n \"table-tennis\"\n ],\n \"f45d\",\n \"M416 287.1c27.99 0 53.68 9.254 74.76 24.51c14.03-29.82 21.06-62.13 21.06-94.43c0-103.1-79.37-218.1-216.5-218.1c-59.94 0-120.4 23.71-165.5 68.95l-54.66 54.8C73.61 125.3 72.58 126.1 71.14 128.5l230.7 230.7C322.8 317.2 365.8 287.1 416 287.1zM290.3 392.1l-238.6-238.6C38.74 176.2 32.3 199.4 32.3 221.9c0 30.53 11.71 59.94 34.29 82.58l36.6 36.7l-92.38 81.32c-7.177 6.255-10.81 15.02-10.81 23.81c0 8.027 3.032 16.07 9.164 22.24l34.05 34.2c6.145 6.16 14.16 9.205 22.15 9.205c8.749 0 17.47-3.649 23.7-10.86l81.03-92.85l35.95 36.04c23.62 23.68 54.41 35.23 85.37 35.23c4.532 0 9.205-.2677 13.72-.7597c-10.56-18.61-17.12-39.89-17.12-62.81C288 408.1 288.1 400.5 290.3 392.1zM415.1 320c-52.99 0-95.99 42.1-95.99 95.1c0 52.1 42.99 95.99 95.99 95.99c52.1 0 95.99-42.1 95.99-95.99C511.1 363 468.1 320 415.1 320z\"\n ]\n};\nvar faPingPongPaddleBall = faTableTennisPaddleBall;\nvar faTableTennis = faTableTennisPaddleBall;\nvar faTablet = {\n prefix: 'fas',\n iconName: 'tablet',\n icon: [\n 448,\n 512,\n [\n \"tablet-android\"\n ],\n \"f3fb\",\n \"M384 0H64C28.65 0 0 28.65 0 64v384c0 35.35 28.65 64 64 64h320c35.35 0 64-28.65 64-64V64C448 28.65 419.3 0 384 0zM288 447.1C288 456.8 280.8 464 272 464H175.1C167.2 464 160 456.8 160 448S167.2 432 175.1 432h96C280.8 432 288 439.2 288 447.1z\"\n ]\n};\nvar faTabletAndroid = faTablet;\nvar faTabletButton = {\n prefix: 'fas',\n iconName: 'tablet-button',\n icon: [\n 448,\n 512,\n [],\n \"f10a\",\n \"M384 0H64C28.65 0 0 28.65 0 64v384c0 35.35 28.65 64 64 64h320c35.35 0 64-28.65 64-64V64C448 28.65 419.3 0 384 0zM224 464c-17.75 0-32-14.25-32-32s14.25-32 32-32s32 14.25 32 32S241.8 464 224 464z\"\n ]\n};\nvar faTabletScreenButton = {\n prefix: 'fas',\n iconName: 'tablet-screen-button',\n icon: [\n 448,\n 512,\n [\n \"tablet-alt\"\n ],\n \"f3fa\",\n \"M384 .0001H64c-35.35 0-64 28.65-64 64v384c0 35.35 28.65 63.1 64 63.1h320c35.35 0 64-28.65 64-63.1v-384C448 28.65 419.3 .0001 384 .0001zM224 480c-17.75 0-32-14.25-32-32s14.25-32 32-32s32 14.25 32 32S241.8 480 224 480zM384 384H64v-320h320V384z\"\n ]\n};\nvar faTabletAlt = faTabletScreenButton;\nvar faTablets = {\n prefix: 'fas',\n iconName: 'tablets',\n icon: [\n 640,\n 512,\n [],\n \"f490\",\n \"M159.1 191.1c-81.1 0-147.5 58.51-159.9 134.8C-.7578 331.5 3.367 336 8.365 336h303.3c4.998 0 8.996-4.5 8.248-9.25C307.4 250.5 241.1 191.1 159.1 191.1zM311.5 368H8.365c-4.998 0-9.123 4.5-8.248 9.25C12.49 453.5 78.88 512 159.1 512s147.4-58.5 159.8-134.8C320.7 372.5 316.5 368 311.5 368zM362.9 65.74c-3.502-3.502-9.504-3.252-12.25 .75c-45.52 62.76-40.52 150.4 15.88 206.9c56.52 56.51 144.2 61.39 206.1 15.88c4.002-2.875 4.252-8.877 .75-12.25L362.9 65.74zM593.4 46.61c-56.52-56.51-144.2-61.39-206.1-16c-4.002 2.877-4.252 8.877-.75 12.25l211.3 211.4c3.5 3.502 9.504 3.252 12.25-.75C654.8 190.8 649.9 103.1 593.4 46.61z\"\n ]\n};\nvar faTachographDigital = {\n prefix: 'fas',\n iconName: 'tachograph-digital',\n icon: [\n 640,\n 512,\n [\n \"digital-tachograph\"\n ],\n \"f566\",\n \"M576 64H64C28.8 64 0 92.8 0 128v256c0 35.2 28.8 64 64 64h512c35.2 0 64-28.8 64-64V128C640 92.8 611.2 64 576 64zM64 296C64 291.6 67.63 288 72 288h16C92.38 288 96 291.6 96 296v16C96 316.4 92.38 320 88 320h-16C67.63 320 64 316.4 64 312V296zM336 384h-256C71.2 384 64 376.8 64 368C64 359.2 71.2 352 79.1 352h256c8.801 0 16 7.199 16 16C352 376.8 344.8 384 336 384zM128 312v-16C128 291.6 131.6 288 136 288h16C156.4 288 160 291.6 160 296v16C160 316.4 156.4 320 152 320h-16C131.6 320 128 316.4 128 312zM192 312v-16C192 291.6 195.6 288 200 288h16C220.4 288 224 291.6 224 296v16C224 316.4 220.4 320 216 320h-16C195.6 320 192 316.4 192 312zM256 312v-16C256 291.6 259.6 288 264 288h16C284.4 288 288 291.6 288 296v16C288 316.4 284.4 320 280 320h-16C259.6 320 256 316.4 256 312zM352 312C352 316.4 348.4 320 344 320h-16C323.6 320 320 316.4 320 312v-16C320 291.6 323.6 288 328 288h16C348.4 288 352 291.6 352 296V312zM352 237.7C352 247.9 344.4 256 334.9 256H81.07C71.6 256 64 247.9 64 237.7V146.3C64 136.1 71.6 128 81.07 128h253.9C344.4 128 352 136.1 352 146.3V237.7zM560 384h-160c-8.801 0-16-7.201-16-16c0-8.801 7.199-16 16-16h160c8.801 0 16 7.199 16 16C576 376.8 568.8 384 560 384z\"\n ]\n};\nvar faDigitalTachograph = faTachographDigital;\nvar faTag = {\n prefix: 'fas',\n iconName: 'tag',\n icon: [\n 448,\n 512,\n [\n 127991\n ],\n \"f02b\",\n \"M48 32H197.5C214.5 32 230.7 38.74 242.7 50.75L418.7 226.7C443.7 251.7 443.7 292.3 418.7 317.3L285.3 450.7C260.3 475.7 219.7 475.7 194.7 450.7L18.75 274.7C6.743 262.7 0 246.5 0 229.5V80C0 53.49 21.49 32 48 32L48 32zM112 176C129.7 176 144 161.7 144 144C144 126.3 129.7 112 112 112C94.33 112 80 126.3 80 144C80 161.7 94.33 176 112 176z\"\n ]\n};\nvar faTags = {\n prefix: 'fas',\n iconName: 'tags',\n icon: [\n 512,\n 512,\n [],\n \"f02c\",\n \"M472.8 168.4C525.1 221.4 525.1 306.6 472.8 359.6L360.8 472.9C351.5 482.3 336.3 482.4 326.9 473.1C317.4 463.8 317.4 448.6 326.7 439.1L438.6 325.9C472.5 291.6 472.5 236.4 438.6 202.1L310.9 72.87C301.5 63.44 301.6 48.25 311.1 38.93C320.5 29.61 335.7 29.7 344.1 39.13L472.8 168.4zM.0003 229.5V80C.0003 53.49 21.49 32 48 32H197.5C214.5 32 230.7 38.74 242.7 50.75L410.7 218.7C435.7 243.7 435.7 284.3 410.7 309.3L277.3 442.7C252.3 467.7 211.7 467.7 186.7 442.7L18.75 274.7C6.743 262.7 0 246.5 0 229.5L.0003 229.5zM112 112C94.33 112 80 126.3 80 144C80 161.7 94.33 176 112 176C129.7 176 144 161.7 144 144C144 126.3 129.7 112 112 112z\"\n ]\n};\nvar faTape = {\n prefix: 'fas',\n iconName: 'tape',\n icon: [\n 576,\n 512,\n [],\n \"f4db\",\n \"M288 256C288 291.3 259.3 320 224 320C188.7 320 160 291.3 160 256C160 220.7 188.7 192 224 192C259.3 192 288 220.7 288 256zM544 416C561.7 416 576 430.3 576 448C576 465.7 561.7 480 544 480H224C100.3 480 0 379.7 0 256C0 132.3 100.3 32 224 32C347.7 32 448 132.3 448 256C448 318.7 422.3 375.3 380.8 416H544zM224 352C277 352 320 309 320 256C320 202.1 277 160 224 160C170.1 160 128 202.1 128 256C128 309 170.1 352 224 352z\"\n ]\n};\nvar faTaxi = {\n prefix: 'fas',\n iconName: 'taxi',\n icon: [\n 576,\n 512,\n [\n 128662,\n \"cab\"\n ],\n \"f1ba\",\n \"M352 0C369.7 0 384 14.33 384 32V64L384 64.15C422.6 66.31 456.3 91.49 469.2 128.3L504.4 228.8C527.6 238.4 544 261.3 544 288V480C544 497.7 529.7 512 512 512H480C462.3 512 448 497.7 448 480V432H128V480C128 497.7 113.7 512 96 512H64C46.33 512 32 497.7 32 480V288C32 261.3 48.36 238.4 71.61 228.8L106.8 128.3C119.7 91.49 153.4 66.31 192 64.15L192 64V32C192 14.33 206.3 0 224 0L352 0zM197.4 128C183.8 128 171.7 136.6 167.2 149.4L141.1 224H434.9L408.8 149.4C404.3 136.6 392.2 128 378.6 128H197.4zM128 352C145.7 352 160 337.7 160 320C160 302.3 145.7 288 128 288C110.3 288 96 302.3 96 320C96 337.7 110.3 352 128 352zM448 288C430.3 288 416 302.3 416 320C416 337.7 430.3 352 448 352C465.7 352 480 337.7 480 320C480 302.3 465.7 288 448 288z\"\n ]\n};\nvar faCab = faTaxi;\nvar faTeeth = {\n prefix: 'fas',\n iconName: 'teeth',\n icon: [\n 576,\n 512,\n [],\n \"f62e\",\n \"M480 32H96C42.98 32 0 74.98 0 128v256c0 53.02 42.98 96 96 96h384c53.02 0 96-42.98 96-96V128C576 74.98 533 32 480 32zM144 336C144 362.5 122.5 384 96 384s-48-21.5-48-48v-32C48 295.1 55.13 288 64 288h64c8.875 0 16 7.125 16 16V336zM144 240C144 248.9 136.9 256 128 256H64C55.13 256 48 248.9 48 240v-32C48 181.5 69.5 160 96 160s48 21.5 48 48V240zM272 336C272 362.5 250.5 384 224 384s-48-21.5-48-48v-32C176 295.1 183.1 288 192 288h64c8.875 0 16 7.125 16 16V336zM272 242.3C272 249.9 265.9 256 258.3 256H189.7C182.1 256 176 249.9 176 242.3V176C176 149.5 197.5 128 224 128s48 21.54 48 48V242.3zM400 336c0 26.5-21.5 48-48 48s-48-21.5-48-48v-32C304 295.1 311.1 288 320 288h64c8.875 0 16 7.125 16 16V336zM400 242.3C400 249.9 393.9 256 386.3 256h-68.57C310.1 256 304 249.9 304 242.3V176C304 149.5 325.5 128 352 128s48 21.54 48 48V242.3zM528 336c0 26.5-21.5 48-48 48s-48-21.5-48-48v-32C432 295.1 439.1 288 448 288h64c8.875 0 16 7.125 16 16V336zM528 240C528 248.9 520.9 256 512 256h-64c-8.875 0-16-7.125-16-16v-32C432 181.5 453.5 160 480 160s48 21.5 48 48V240z\"\n ]\n};\nvar faTeethOpen = {\n prefix: 'fas',\n iconName: 'teeth-open',\n icon: [\n 576,\n 512,\n [],\n \"f62f\",\n \"M512 288H64c-35.35 0-64 28.65-64 64v32c0 53.02 42.98 96 96 96h384c53.02 0 96-42.98 96-96v-32C576 316.7 547.3 288 512 288zM144 368C144 394.5 122.5 416 96 416s-48-21.5-48-48v-32C48 327.1 55.13 320 64 320h64c8.875 0 16 7.125 16 16V368zM272 368C272 394.5 250.5 416 224 416s-48-21.5-48-48v-32C176 327.1 183.1 320 192 320h64c8.875 0 16 7.125 16 16V368zM400 368c0 26.5-21.5 48-48 48s-48-21.5-48-48v-32c0-8.875 7.125-16 16-16h64c8.875 0 16 7.125 16 16V368zM528 368c0 26.5-21.5 48-48 48s-48-21.5-48-48v-32c0-8.875 7.125-16 16-16h64c8.875 0 16 7.125 16 16V368zM480 32H96C42.98 32 0 74.98 0 128v64c0 35.35 28.65 64 64 64h448c35.35 0 64-28.65 64-64V128C576 74.98 533 32 480 32zM144 208C144 216.9 136.9 224 128 224H64C55.13 224 48 216.9 48 208v-32C48 149.5 69.5 128 96 128s48 21.5 48 48V208zM272 210.3C272 217.9 265.9 224 258.3 224H189.7C182.1 224 176 217.9 176 210.3V144C176 117.5 197.5 96 224 96s48 21.54 48 48V210.3zM400 210.3C400 217.9 393.9 224 386.3 224h-68.57C310.1 224 304 217.9 304 210.3V144C304 117.5 325.5 96 352 96s48 21.54 48 48V210.3zM528 208C528 216.9 520.9 224 512 224h-64c-8.875 0-16-7.125-16-16v-32C432 149.5 453.5 128 480 128s48 21.5 48 48V208z\"\n ]\n};\nvar faTemperatureEmpty = {\n prefix: 'fas',\n iconName: 'temperature-empty',\n icon: [\n 320,\n 512,\n [\n \"temperature-0\",\n \"thermometer-0\",\n \"thermometer-empty\"\n ],\n \"f2cb\",\n \"M272 278.5V112c0-61.87-50.12-112-111.1-112S48 50.13 48 112v166.5c-19.75 24.75-32 55.5-32 89.5c0 79.5 64.5 143.1 144 143.1S304 447.5 304 368C304 334 291.8 303.1 272 278.5zM160 448c-44.13 0-80-35.87-80-79.1c0-25.5 12.25-48.88 32-63.75v-192.3c0-26.5 21.5-48 48-48s48 21.5 48 48v192.3c19.75 14.75 32 38.25 32 63.75C240 412.1 204.1 448 160 448zM160 320c-26.51 0-48 21.49-48 48s21.49 48 48 48s48-21.49 48-48S186.5 320 160 320z\"\n ]\n};\nvar faTemperature0 = faTemperatureEmpty;\nvar faThermometer0 = faTemperatureEmpty;\nvar faThermometerEmpty = faTemperatureEmpty;\nvar faTemperatureFull = {\n prefix: 'fas',\n iconName: 'temperature-full',\n icon: [\n 320,\n 512,\n [\n \"temperature-4\",\n \"thermometer-4\",\n \"thermometer-full\"\n ],\n \"f2c7\",\n \"M176 322.9V112c0-8.75-7.25-16-16-16s-16 7.25-16 16v210.9c-18.62 6.625-32 24.25-32 45.13c0 26.5 21.5 48 48 48s48-21.5 48-48C208 347.1 194.6 329.5 176 322.9zM272 278.5V112c0-61.87-50.12-112-111.1-112S48 50.13 48 112v166.5c-19.75 24.75-32 55.5-32 89.5c0 79.5 64.5 143.1 144 143.1S304 447.5 304 368C304 334 291.8 303.1 272 278.5zM160 448c-44.13 0-80-35.87-80-79.1c0-25.5 12.25-48.88 32-63.75v-192.3c0-26.5 21.5-48 48-48s48 21.5 48 48v192.3c19.75 14.75 32 38.25 32 63.75C240 412.1 204.1 448 160 448z\"\n ]\n};\nvar faTemperature4 = faTemperatureFull;\nvar faThermometer4 = faTemperatureFull;\nvar faThermometerFull = faTemperatureFull;\nvar faTemperatureHalf = {\n prefix: 'fas',\n iconName: 'temperature-half',\n icon: [\n 320,\n 512,\n [\n 127777,\n \"temperature-2\",\n \"thermometer-2\",\n \"thermometer-half\"\n ],\n \"f2c9\",\n \"M176 322.9l.0002-114.9c0-8.75-7.25-16-16-16s-15.1 7.25-15.1 16L144 322.9c-18.62 6.625-32 24.25-32 45.13c0 26.5 21.5 48 48 48s48-21.5 48-48C208 347.1 194.6 329.5 176 322.9zM272 278.5V112c0-61.87-50.12-112-111.1-112S48 50.13 48 112v166.5c-19.75 24.75-32 55.5-32 89.5c0 79.5 64.5 143.1 144 143.1S304 447.5 304 368C304 334 291.8 303.1 272 278.5zM160 448c-44.13 0-80-35.87-80-79.1c0-25.5 12.25-48.88 32-63.75v-192.3c0-26.5 21.5-48 48-48s48 21.5 48 48v192.3c19.75 14.75 32 38.25 32 63.75C240 412.1 204.1 448 160 448z\"\n ]\n};\nvar faTemperature2 = faTemperatureHalf;\nvar faThermometer2 = faTemperatureHalf;\nvar faThermometerHalf = faTemperatureHalf;\nvar faTemperatureHigh = {\n prefix: 'fas',\n iconName: 'temperature-high',\n icon: [\n 512,\n 512,\n [],\n \"f769\",\n \"M160 322.9V112C160 103.3 152.8 96 144 96S128 103.3 128 112v210.9C109.4 329.5 96 347.1 96 368C96 394.5 117.5 416 144 416S192 394.5 192 368C192 347.1 178.6 329.5 160 322.9zM416 0c-52.88 0-96 43.13-96 96s43.13 96 96 96s96-43.13 96-96S468.9 0 416 0zM416 128c-17.75 0-32-14.25-32-32s14.25-32 32-32s32 14.25 32 32S433.8 128 416 128zM256 112c0-61.88-50.13-112-112-112s-112 50.13-112 112v166.5c-19.75 24.75-32 55.5-32 89.5c0 79.5 64.5 144 144 144s144-64.5 144-144c0-33.1-12.25-64.88-32-89.5V112zM144 448c-44.13 0-80-35.88-80-80c0-25.5 12.25-48.88 32-63.75v-192.3c0-26.5 21.5-48 48-48S192 85.5 192 112V304.3c19.75 14.75 32 38.25 32 63.75C224 412.1 188.1 448 144 448z\"\n ]\n};\nvar faTemperatureLow = {\n prefix: 'fas',\n iconName: 'temperature-low',\n icon: [\n 512,\n 512,\n [],\n \"f76b\",\n \"M160 322.9V304C160 295.3 152.8 288 144 288S128 295.3 128 304v18.88C109.4 329.5 96 347.1 96 368C96 394.5 117.5 416 144 416S192 394.5 192 368C192 347.1 178.6 329.5 160 322.9zM256 112c0-61.88-50.13-112-112-112s-112 50.13-112 112v166.5c-19.75 24.75-32 55.5-32 89.5c0 79.5 64.5 144 144 144s144-64.5 144-144c0-33.1-12.25-64.88-32-89.5V112zM144 448c-44.13 0-80-35.88-80-80c0-25.5 12.25-48.88 32-63.75v-192.3c0-26.5 21.5-48 48-48s48 21.5 48 48v192.1c19.75 14.75 32 38.38 32 63.88C224 412.1 188.1 448 144 448zM416 0c-52.88 0-96 43.13-96 96s43.13 96 96 96s96-43.13 96-96S468.9 0 416 0zM416 128c-17.75 0-32-14.25-32-32s14.25-32 32-32s32 14.25 32 32S433.8 128 416 128z\"\n ]\n};\nvar faTemperatureQuarter = {\n prefix: 'fas',\n iconName: 'temperature-quarter',\n icon: [\n 320,\n 512,\n [\n \"temperature-1\",\n \"thermometer-1\",\n \"thermometer-quarter\"\n ],\n \"f2ca\",\n \"M176 322.9l.0002-50.88c0-8.75-7.25-16-16-16s-15.1 7.25-15.1 16L144 322.9c-18.62 6.625-32 24.25-32 45.13c0 26.5 21.5 48 48 48s48-21.5 48-48C208 347.1 194.6 329.5 176 322.9zM272 278.5V112c0-61.87-50.12-112-111.1-112S48 50.13 48 112v166.5c-19.75 24.75-32 55.5-32 89.5c0 79.5 64.5 143.1 144 143.1S304 447.5 304 368C304 334 291.8 303.1 272 278.5zM160 448c-44.13 0-80-35.87-80-79.1c0-25.5 12.25-48.88 32-63.75v-192.3c0-26.5 21.5-48 48-48s48 21.5 48 48v192.3c19.75 14.75 32 38.25 32 63.75C240 412.1 204.1 448 160 448z\"\n ]\n};\nvar faTemperature1 = faTemperatureQuarter;\nvar faThermometer1 = faTemperatureQuarter;\nvar faThermometerQuarter = faTemperatureQuarter;\nvar faTemperatureThreeQuarters = {\n prefix: 'fas',\n iconName: 'temperature-three-quarters',\n icon: [\n 320,\n 512,\n [\n \"temperature-3\",\n \"thermometer-3\",\n \"thermometer-three-quarters\"\n ],\n \"f2c8\",\n \"M176 322.9V160c0-8.75-7.25-16-16-16s-16 7.25-16 16v162.9c-18.62 6.625-32 24.25-32 45.13c0 26.5 21.5 48 48 48s48-21.5 48-48C208 347.1 194.6 329.5 176 322.9zM272 278.5V112c0-61.87-50.12-112-111.1-112S48 50.13 48 112v166.5c-19.75 24.75-32 55.5-32 89.5c0 79.5 64.5 143.1 144 143.1S304 447.5 304 368C304 334 291.8 303.1 272 278.5zM160 448c-44.13 0-80-35.87-80-79.1c0-25.5 12.25-48.88 32-63.75v-192.3c0-26.5 21.5-48 48-48s48 21.5 48 48v192.3c19.75 14.75 32 38.25 32 63.75C240 412.1 204.1 448 160 448z\"\n ]\n};\nvar faTemperature3 = faTemperatureThreeQuarters;\nvar faThermometer3 = faTemperatureThreeQuarters;\nvar faThermometerThreeQuarters = faTemperatureThreeQuarters;\nvar faTengeSign = {\n prefix: 'fas',\n iconName: 'tenge-sign',\n icon: [\n 384,\n 512,\n [\n 8376,\n \"tenge\"\n ],\n \"f7d7\",\n \"M0 64C0 46.33 14.33 32 32 32H352C369.7 32 384 46.33 384 64C384 81.67 369.7 96 352 96H32C14.33 96 0 81.67 0 64zM0 192C0 174.3 14.33 160 32 160H352C369.7 160 384 174.3 384 192C384 209.7 369.7 224 352 224H224V448C224 465.7 209.7 480 192 480C174.3 480 160 465.7 160 448V224H32C14.33 224 0 209.7 0 192z\"\n ]\n};\nvar faTenge = faTengeSign;\nvar faTerminal = {\n prefix: 'fas',\n iconName: 'terminal',\n icon: [\n 576,\n 512,\n [],\n \"f120\",\n \"M9.372 86.63C-3.124 74.13-3.124 53.87 9.372 41.37C21.87 28.88 42.13 28.88 54.63 41.37L246.6 233.4C259.1 245.9 259.1 266.1 246.6 278.6L54.63 470.6C42.13 483.1 21.87 483.1 9.372 470.6C-3.124 458.1-3.124 437.9 9.372 425.4L178.7 256L9.372 86.63zM544 416C561.7 416 576 430.3 576 448C576 465.7 561.7 480 544 480H256C238.3 480 224 465.7 224 448C224 430.3 238.3 416 256 416H544z\"\n ]\n};\nvar faTextHeight = {\n prefix: 'fas',\n iconName: 'text-height',\n icon: [\n 576,\n 512,\n [],\n \"f034\",\n \"M288 32.01H32c-17.67 0-32 14.31-32 32v64c0 17.69 14.33 32 32 32s32-14.31 32-32v-32h64v320H96c-17.67 0-32 14.31-32 32s14.33 32 32 32h128c17.67 0 32-14.31 32-32s-14.33-32-32-32H192v-320h64v32c0 17.69 14.33 32 32 32s32-14.31 32-32v-64C320 46.33 305.7 32.01 288 32.01zM521.4 361.4L512 370.8V141.3l9.375 9.375C527.6 156.9 535.8 160 544 160s16.38-3.125 22.62-9.375c12.5-12.5 12.5-32.75 0-45.25l-64-64c-12.5-12.5-32.75-12.5-45.25 0l-64 64c-12.5 12.5-12.5 32.75 0 45.25s32.75 12.5 45.25 0L448 141.3v229.5l-9.375-9.375c-12.5-12.5-32.75-12.5-45.25 0s-12.5 32.75 0 45.25l64 64C463.6 476.9 471.8 480 480 480s16.38-3.118 22.62-9.368l64-64c12.5-12.5 12.5-32.75 0-45.25S533.9 348.9 521.4 361.4z\"\n ]\n};\nvar faTextSlash = {\n prefix: 'fas',\n iconName: 'text-slash',\n icon: [\n 640,\n 512,\n [\n \"remove-format\"\n ],\n \"f87d\",\n \"M352 416H306.7l18.96-64.1L271.4 308.5L239.1 416H192c-17.67 0-32 14.31-32 32s14.33 31.99 31.1 31.99h160C369.7 480 384 465.7 384 448S369.7 416 352 416zM630.8 469.1l-276.4-216.7l45.63-156.5H512v32c0 17.69 14.33 32 32 32s32-14.31 32-32v-64c0-17.69-14.33-32-32-32H192c-17.67 0-32 14.31-32 32v36.11L38.81 5.13c-10.47-8.219-25.53-6.37-33.7 4.068s-6.349 25.54 4.073 33.69l591.1 463.1c4.406 3.469 9.61 5.127 14.8 5.127c7.125 0 14.17-3.164 18.9-9.195C643.1 492.4 641.2 477.3 630.8 469.1zM300.1 209.9l-82.08-64.33C221.5 140.5 224 134.7 224 128v-32h109.3L300.1 209.9z\"\n ]\n};\nvar faRemoveFormat = faTextSlash;\nvar faTextWidth = {\n prefix: 'fas',\n iconName: 'text-width',\n icon: [\n 448,\n 512,\n [],\n \"f035\",\n \"M416 32.01H32c-17.67 0-32 14.31-32 32v63.1c0 17.69 14.33 32 32 32s32-14.31 32-32v-32h128v128H176c-17.67 0-32 14.31-32 31.1s14.33 32 32 32h96c17.67 0 32-14.31 32-32s-14.33-31.1-32-31.1H256v-128h128v32c0 17.69 14.33 32 32 32s32-14.32 32-32V64.01C448 46.33 433.7 32.01 416 32.01zM374.6 297.4c-12.5-12.5-32.75-12.5-45.25 0s-12.5 32.75 0 45.25l9.375 9.375h-229.5L118.6 342.6c12.5-12.5 12.5-32.75 0-45.25s-32.75-12.5-45.25 0l-64 64c-12.5 12.5-12.5 32.75 0 45.25l64 64C79.63 476.9 87.81 480 96 480s16.38-3.118 22.62-9.368c12.5-12.5 12.5-32.75 0-45.25l-9.375-9.375h229.5l-9.375 9.375c-12.5 12.5-12.5 32.75 0 45.25C335.6 476.9 343.8 480 352 480s16.38-3.118 22.62-9.368l64-64c12.5-12.5 12.5-32.75 0-45.25L374.6 297.4z\"\n ]\n};\nvar faThermometer = {\n prefix: 'fas',\n iconName: 'thermometer',\n icon: [\n 512,\n 512,\n [],\n \"f491\",\n \"M483.1 162.6L229.8 415.9l-99.87-.0001l-88.99 89.02c-9.249 9.377-24.5 9.377-33.87 0c-9.374-9.252-9.374-24.51 0-33.88l88.99-89.02l.0003-100.9l49.05-49.39l51.6 51.59c3.125 3.126 7.218 4.688 11.31 4.688s8.187-1.563 11.31-4.688c6.249-6.252 6.249-16.38 0-22.63L167.6 209.1l41.24-41.52l51.81 51.81c3.125 3.126 7.218 4.688 11.31 4.688s8.187-1.563 11.31-4.688c6.249-6.252 6.249-16.38 0-22.63L231.4 144.8l41.24-41.52l52.02 52.02c3.125 3.126 7.218 4.688 11.31 4.688s8.187-1.563 11.31-4.688c6.249-6.252 6.249-16.38 0-22.63l-52.09-52.09l49.68-50.02c36.37-36.51 94.37-40.88 131.9-10.25C526.2 61.11 518.9 127.8 483.1 162.6z\"\n ]\n};\nvar faThumbsDown = {\n prefix: 'fas',\n iconName: 'thumbs-down',\n icon: [\n 512,\n 512,\n [\n 61576,\n 128078\n ],\n \"f165\",\n \"M96 32.04H32c-17.67 0-32 14.32-32 31.1v223.1c0 17.67 14.33 31.1 32 31.1h64c17.67 0 32-14.33 32-31.1V64.03C128 46.36 113.7 32.04 96 32.04zM467.3 240.2C475.1 231.7 480 220.4 480 207.9c0-23.47-16.87-42.92-39.14-47.09C445.3 153.6 448 145.1 448 135.1c0-21.32-14-39.18-33.25-45.43C415.5 87.12 416 83.61 416 79.98C416 53.47 394.5 32 368 32h-58.69c-34.61 0-68.28 11.22-95.97 31.98L179.2 89.57C167.1 98.63 160 112.9 160 127.1l.1074 160c0 0-.0234-.0234 0 0c.0703 13.99 6.123 27.94 17.91 37.36l16.3 13.03C276.2 403.9 239.4 480 302.5 480c30.96 0 49.47-24.52 49.47-48.11c0-15.15-11.76-58.12-34.52-96.02H464c26.52 0 48-21.47 48-47.98C512 262.5 492.2 241.9 467.3 240.2z\"\n ]\n};\nvar faThumbsUp = {\n prefix: 'fas',\n iconName: 'thumbs-up',\n icon: [\n 512,\n 512,\n [\n 61575,\n 128077\n ],\n \"f164\",\n \"M128 447.1V223.1c0-17.67-14.33-31.1-32-31.1H32c-17.67 0-32 14.33-32 31.1v223.1c0 17.67 14.33 31.1 32 31.1h64C113.7 479.1 128 465.6 128 447.1zM512 224.1c0-26.5-21.48-47.98-48-47.98h-146.5c22.77-37.91 34.52-80.88 34.52-96.02C352 56.52 333.5 32 302.5 32c-63.13 0-26.36 76.15-108.2 141.6L178 186.6C166.2 196.1 160.2 210 160.1 224c-.0234 .0234 0 0 0 0L160 384c0 15.1 7.113 29.33 19.2 38.39l34.14 25.59C241 468.8 274.7 480 309.3 480H368c26.52 0 48-21.47 48-47.98c0-3.635-.4805-7.143-1.246-10.55C434 415.2 448 397.4 448 376c0-9.148-2.697-17.61-7.139-24.88C463.1 347 480 327.5 480 304.1c0-12.5-4.893-23.78-12.72-32.32C492.2 270.1 512 249.5 512 224.1z\"\n ]\n};\nvar faThumbtack = {\n prefix: 'fas',\n iconName: 'thumbtack',\n icon: [\n 384,\n 512,\n [\n 128392,\n 128204,\n \"thumb-tack\"\n ],\n \"f08d\",\n \"M32 32C32 14.33 46.33 0 64 0H320C337.7 0 352 14.33 352 32C352 49.67 337.7 64 320 64H290.5L301.9 212.2C338.6 232.1 367.5 265.4 381.4 306.9L382.4 309.9C385.6 319.6 383.1 330.4 377.1 338.7C371.9 347.1 362.3 352 352 352H32C21.71 352 12.05 347.1 6.04 338.7C.0259 330.4-1.611 319.6 1.642 309.9L2.644 306.9C16.47 265.4 45.42 232.1 82.14 212.2L93.54 64H64C46.33 64 32 49.67 32 32zM224 384V480C224 497.7 209.7 512 192 512C174.3 512 160 497.7 160 480V384H224z\"\n ]\n};\nvar faThumbTack = faThumbtack;\nvar faTicket = {\n prefix: 'fas',\n iconName: 'ticket',\n icon: [\n 576,\n 512,\n [\n 127903\n ],\n \"f145\",\n \"M128 160H448V352H128V160zM512 64C547.3 64 576 92.65 576 128V208C549.5 208 528 229.5 528 256C528 282.5 549.5 304 576 304V384C576 419.3 547.3 448 512 448H64C28.65 448 0 419.3 0 384V304C26.51 304 48 282.5 48 256C48 229.5 26.51 208 0 208V128C0 92.65 28.65 64 64 64H512zM96 352C96 369.7 110.3 384 128 384H448C465.7 384 480 369.7 480 352V160C480 142.3 465.7 128 448 128H128C110.3 128 96 142.3 96 160V352z\"\n ]\n};\nvar faTicketSimple = {\n prefix: 'fas',\n iconName: 'ticket-simple',\n icon: [\n 576,\n 512,\n [\n \"ticket-alt\"\n ],\n \"f3ff\",\n \"M0 128C0 92.65 28.65 64 64 64H512C547.3 64 576 92.65 576 128V208C549.5 208 528 229.5 528 256C528 282.5 549.5 304 576 304V384C576 419.3 547.3 448 512 448H64C28.65 448 0 419.3 0 384V304C26.51 304 48 282.5 48 256C48 229.5 26.51 208 0 208V128z\"\n ]\n};\nvar faTicketAlt = faTicketSimple;\nvar faTimeline = {\n prefix: 'fas',\n iconName: 'timeline',\n icon: [\n 640,\n 512,\n [],\n \"e29c\",\n \"M160 224H480V169.3C451.7 156.1 432 128.8 432 96C432 51.82 467.8 16 512 16C556.2 16 592 51.82 592 96C592 128.8 572.3 156.1 544 169.3V224H608C625.7 224 640 238.3 640 256C640 273.7 625.7 288 608 288H352V342.7C380.3 355 400 383.2 400 416C400 460.2 364.2 496 320 496C275.8 496 240 460.2 240 416C240 383.2 259.7 355 288 342.7V288H32C14.33 288 0 273.7 0 256C0 238.3 14.33 224 32 224H96V169.3C67.75 156.1 48 128.8 48 96C48 51.82 83.82 16 128 16C172.2 16 208 51.82 208 96C208 128.8 188.3 156.1 160 169.3V224zM128 120C141.3 120 152 109.3 152 96C152 82.75 141.3 72 128 72C114.7 72 104 82.75 104 96C104 109.3 114.7 120 128 120zM512 72C498.7 72 488 82.75 488 96C488 109.3 498.7 120 512 120C525.3 120 536 109.3 536 96C536 82.75 525.3 72 512 72zM320 440C333.3 440 344 429.3 344 416C344 402.7 333.3 392 320 392C306.7 392 296 402.7 296 416C296 429.3 306.7 440 320 440z\"\n ]\n};\nvar faToggleOff = {\n prefix: 'fas',\n iconName: 'toggle-off',\n icon: [\n 576,\n 512,\n [],\n \"f204\",\n \"M192 352C138.1 352 96 309 96 256C96 202.1 138.1 160 192 160C245 160 288 202.1 288 256C288 309 245 352 192 352zM384 448H192C85.96 448 0 362 0 256C0 149.1 85.96 64 192 64H384C490 64 576 149.1 576 256C576 362 490 448 384 448zM384 128H192C121.3 128 64 185.3 64 256C64 326.7 121.3 384 192 384H384C454.7 384 512 326.7 512 256C512 185.3 454.7 128 384 128z\"\n ]\n};\nvar faToggleOn = {\n prefix: 'fas',\n iconName: 'toggle-on',\n icon: [\n 576,\n 512,\n [],\n \"f205\",\n \"M384 64C490 64 576 149.1 576 256C576 362 490 448 384 448H192C85.96 448 0 362 0 256C0 149.1 85.96 64 192 64H384zM384 352C437 352 480 309 480 256C480 202.1 437 160 384 160C330.1 160 288 202.1 288 256C288 309 330.1 352 384 352z\"\n ]\n};\nvar faToilet = {\n prefix: 'fas',\n iconName: 'toilet',\n icon: [\n 448,\n 512,\n [\n 128701\n ],\n \"f7d8\",\n \"M432 48C440.8 48 448 40.75 448 32V16C448 7.25 440.8 0 432 0h-416C7.25 0 0 7.25 0 16V32c0 8.75 7.25 16 16 16H32v158.7C11.82 221.2 0 237.1 0 256c0 60.98 33.28 115.2 84.1 150.4l-19.59 64.36C59.16 491.3 74.53 512 96.03 512h255.9c21.5 0 36.88-20.75 30.62-41.25L363 406.4C414.7 371.2 448 316.1 448 256c0-18.04-11.82-34.85-32-49.26V48H432zM96 72C96 67.63 99.63 64 104 64h48C156.4 64 160 67.63 160 72v16C160 92.38 156.4 96 152 96h-48C99.63 96 96 92.38 96 88V72zM224 288C135.6 288 64 273.7 64 256c0-17.67 71.63-32 160-32s160 14.33 160 32C384 273.7 312.4 288 224 288z\"\n ]\n};\nvar faToiletPaper = {\n prefix: 'fas',\n iconName: 'toilet-paper',\n icon: [\n 576,\n 512,\n [\n 129531\n ],\n \"f71e\",\n \"M127.1 0C74.98 0 31.98 86 31.98 192v172.1c0 41.12-9.751 62.75-31.13 126.9C-2.65 501.2 5.101 512 15.98 512h280.9c13.88 0 26-8.75 30.38-21.88c12.88-38.5 24.75-72.37 24.75-126L351.1 192c0-83.62 23.62-153.5 60.5-192H127.1zM95.99 224C87.11 224 79.99 216.9 79.99 208S87.11 192 95.99 192s16 7.125 16 16S104.9 224 95.99 224zM159.1 224c-8.875 0-16-7.125-16-16S151.1 192 159.1 192s16 7.125 16 16S168.9 224 159.1 224zM223.1 224C215.1 224 207.1 216.9 207.1 208S215.1 192 223.1 192c8.875 0 16 7.125 16 16S232.9 224 223.1 224zM287.1 224C279.1 224 271.1 216.9 271.1 208S279.1 192 287.1 192c8.875 0 16 7.125 16 16S296.9 224 287.1 224zM479.1 0c-53 0-96 86.06-96 192.1C383.1 298.1 426.1 384 479.1 384S576 298 576 192C576 86 532.1 0 479.1 0zM479.1 256c-17.63 0-32-28.62-32-64s14.38-64 32-64c17.63 0 32 28.62 32 64S497.6 256 479.1 256z\"\n ]\n};\nvar faToiletPaperSlash = {\n prefix: 'fas',\n iconName: 'toilet-paper-slash',\n icon: [\n 640,\n 512,\n [],\n \"e072\",\n \"M63.98 191.1v172.1c0 41.12-9.75 62.75-31.13 126.9c-3.5 10.25 4.25 20.1 15.13 20.1l280.9-.0059c13.87 0 25.1-8.75 30.37-21.87c10.08-30.15 19.46-57.6 23.1-93.78L66.51 148.8C64.9 162.7 63.98 177.1 63.98 191.1zM630.8 469.1l-109.8-86.02c48.75-9.144 86.94-91.2 86.94-191.1C607.1 86 564.1 0 511.1 0s-96 86-96 191.1c0 49.25 9.362 94.03 24.62 128l-56.62-44.38l.0049-83.65c0-83.62 23.62-153.5 60.5-191.1H159.1C135.2 0 112.7 18.93 95.72 49.72L38.81 5.109C34.41 1.672 29.19 0 24.03 0c-7.125 0-14.19 3.156-18.91 9.187C-3.061 19.62-1.249 34.72 9.189 42.89l591.1 463.1c10.5 8.203 25.56 6.328 33.69-4.078C643.1 492.4 641.2 477.3 630.8 469.1zM479.1 191.1c0-35.37 14.37-64 32-64c17.62 0 32 28.63 32 64S529.6 255.1 511.1 255.1C494.4 255.1 479.1 227.4 479.1 191.1z\"\n ]\n};\nvar faToolbox = {\n prefix: 'fas',\n iconName: 'toolbox',\n icon: [\n 512,\n 512,\n [\n 129520\n ],\n \"f552\",\n \"M502.6 182.6l-45.25-45.25C451.4 131.4 443.3 128 434.8 128H384V80C384 53.5 362.5 32 336 32h-160C149.5 32 128 53.5 128 80V128H77.25c-8.5 0-16.62 3.375-22.62 9.375L9.375 182.6C3.375 188.6 0 196.8 0 205.3V304h128v-32C128 263.1 135.1 256 144 256h32C184.9 256 192 263.1 192 272v32h128v-32C320 263.1 327.1 256 336 256h32C376.9 256 384 263.1 384 272v32h128V205.3C512 196.8 508.6 188.6 502.6 182.6zM336 128h-160V80h160V128zM384 368c0 8.875-7.125 16-16 16h-32c-8.875 0-16-7.125-16-16v-32H192v32C192 376.9 184.9 384 176 384h-32C135.1 384 128 376.9 128 368v-32H0V448c0 17.62 14.38 32 32 32h448c17.62 0 32-14.38 32-32v-112h-128V368z\"\n ]\n};\nvar faTooth = {\n prefix: 'fas',\n iconName: 'tooth',\n icon: [\n 448,\n 512,\n [\n 129463\n ],\n \"f5c9\",\n \"M394.1 212.8c-20.04 27.67-28.07 60.15-31.18 93.95c-3.748 41.34-8.785 82.46-17.89 122.8l-6.75 29.64c-2.68 12.14-13.29 20.78-25.39 20.78c-12 0-22.39-8.311-25.29-20.23l-29.57-121.2C254.1 322.6 240.1 311.4 224 311.4c-16.18 0-30.21 11.26-34.07 27.23l-29.57 121.2c-2.893 11.92-13.39 20.23-25.29 20.23c-12.21 0-22.71-8.639-25.5-20.78l-6.643-29.64c-9.105-40.36-14.14-81.48-17.1-122.8C81.93 272.1 73.9 240.5 53.86 212.8c-18.75-25.92-27.11-60.15-18.43-96.57c9.428-39.59 40.39-71.75 78.85-82.03c20.14-5.25 39.54-.4375 57.32 9.077l86.14 56.54c6.643 4.375 15.11 1.86 18.96-4.264c4.07-6.454 2.25-15.09-4.18-19.36l-24.21-15.86c3-1.531 6.215-2.735 9-4.813c22.39-16.84 48.75-28.65 76.39-21.33c38.46 10.28 69.43 42.43 78.85 82.03C421.2 152.7 412.9 187 394.1 212.8z\"\n ]\n};\nvar faToriiGate = {\n prefix: 'fas',\n iconName: 'torii-gate',\n icon: [\n 512,\n 512,\n [\n 9961\n ],\n \"f6a1\",\n \"M0 80V0L71.37 23.79C87.68 29.23 104.8 32 121.1 32H390C407.2 32 424.3 29.23 440.6 23.79L512 0V80C512 106.5 490.5 128 464 128H448V192H384V128H288V192H224V128H128V192H64V128H48C21.49 128 0 106.5 0 80zM32 288C14.33 288 0 273.7 0 256C0 238.3 14.33 224 32 224H480C497.7 224 512 238.3 512 256C512 273.7 497.7 288 480 288H448V480C448 497.7 433.7 512 416 512C398.3 512 384 497.7 384 480V288H128V480C128 497.7 113.7 512 96 512C78.33 512 64 497.7 64 480V288H32z\"\n ]\n};\nvar faTowerBroadcast = {\n prefix: 'fas',\n iconName: 'tower-broadcast',\n icon: [\n 576,\n 512,\n [\n \"broadcast-tower\"\n ],\n \"f519\",\n \"M160.9 59.01C149.3 52.6 134.7 56.76 128.3 68.39C117.6 87.6 112 109.4 112 131.4c0 19.03 4.031 37.44 11.98 54.62c4.047 8.777 12.73 13.93 21.8 13.93c3.375 0 6.797-.7187 10.05-2.219C167.9 192.2 173.1 177.1 167.5 165.9C162.5 155.1 160 143.5 160 131.4c0-13.93 3.547-27.69 10.25-39.81C176.7 80.04 172.5 65.42 160.9 59.01zM62.61 2.363C46.17-4.32 27.58 3.676 20.95 20.02C7.047 54.36 0 90.69 0 127.1C0 165.3 7.047 201.7 20.95 236C25.98 248.5 37.97 256 50.63 256C54.61 256 58.69 255.3 62.61 253.7C79 247 86.91 228.4 80.27 212C69.47 185.3 64 157.1 64 128c0-29.06 5.469-57.3 16.27-83.99C86.91 27.64 79 8.988 62.61 2.363zM555 20.02c-6.609-16.41-25.23-24.31-41.66-17.66c-16.39 6.625-24.3 25.28-17.66 41.65C506.5 70.7 512 98.95 512 128c0 29.06-5.469 57.31-16.27 83.1C489.1 228.4 497 247 513.4 253.7C517.3 255.3 521.4 256 525.4 256c12.66 0 24.64-7.562 29.67-20C568.1 201.7 576 165.3 576 127.1C576 90.69 568.1 54.36 555 20.02zM420.2 58.23c-12.03 5.562-17.28 19.81-11.72 31.84C413.5 100.9 416 112.5 416 124.6c0 13.94-3.547 27.69-10.25 39.81c-6.422 11.59-2.219 26.22 9.375 32.62c3.688 2.031 7.672 3 11.61 3c8.438 0 16.64-4.47 21.02-12.37C458.4 168.4 464 146.6 464 124.6c0-19.03-4.031-37.43-11.98-54.62C446.5 57.89 432.1 52.7 420.2 58.23zM301.8 65.45C260.5 56.78 224 88.13 224 128c0 23.63 12.95 44.04 32 55.12v296.9c0 17.67 14.33 32 32 32s32-14.33 32-32V183.1c23.25-13.54 37.42-40.96 30.03-71.18C344.4 88.91 325 70.31 301.8 65.45z\"\n ]\n};\nvar faBroadcastTower = faTowerBroadcast;\nvar faTractor = {\n prefix: 'fas',\n iconName: 'tractor',\n icon: [\n 640,\n 512,\n [\n 128668\n ],\n \"f722\",\n \"M96 64C96 28.65 124.7 0 160 0H266.3C292.5 0 316 15.93 325.8 40.23L373.7 160H480V126.2C480 101.4 485.8 76.88 496.9 54.66L499.4 49.69C507.3 33.88 526.5 27.47 542.3 35.38C558.1 43.28 564.5 62.5 556.6 78.31L554.1 83.28C547.5 96.61 544 111.3 544 126.2V160H600C622.1 160 640 177.9 640 200V245.4C640 261.9 631.5 277.3 617.4 286.1L574.1 313.2C559.9 307.3 544.3 304 528 304C488.7 304 453.9 322.9 431.1 352H352C352 369.7 337.7 384 320 384H311.8C310.1 388.8 308.2 393.5 305.1 398.1L311.8 403.9C324.3 416.4 324.3 436.6 311.8 449.1L289.1 471.8C276.6 484.3 256.4 484.3 243.9 471.8L238.1 465.1C233.5 468.2 228.8 470.1 224 471.8V480C224 497.7 209.7 512 192 512H160C142.3 512 128 497.7 128 480V471.8C123.2 470.1 118.5 468.2 113.9 465.1L108.1 471.8C95.62 484.3 75.36 484.3 62.86 471.8L40.24 449.1C27.74 436.6 27.74 416.4 40.24 403.9L46.03 398.1C43.85 393.5 41.9 388.8 40.19 384H32C14.33 384 0 369.7 0 352V320C0 302.3 14.33 288 32 288H40.19C41.9 283.2 43.85 278.5 46.03 273.9L40.24 268.1C27.74 255.6 27.74 235.4 40.24 222.9L62.86 200.2C71.82 191.3 84.78 188.7 96 192.6L96 64zM160 64V160H304.7L266.3 64H160zM176 256C131.8 256 96 291.8 96 336C96 380.2 131.8 416 176 416C220.2 416 256 380.2 256 336C256 291.8 220.2 256 176 256zM440 424C440 394.2 454.8 367.9 477.4 352C491.7 341.9 509.2 336 528 336C530.7 336 533.3 336.1 535.9 336.3C580.8 340.3 616 378.1 616 424C616 472.6 576.6 512 528 512C479.4 512 440 472.6 440 424zM528 448C541.3 448 552 437.3 552 424C552 410.7 541.3 400 528 400C514.7 400 504 410.7 504 424C504 437.3 514.7 448 528 448z\"\n ]\n};\nvar faTrademark = {\n prefix: 'fas',\n iconName: 'trademark',\n icon: [\n 640,\n 512,\n [\n 8482\n ],\n \"f25c\",\n \"M618.1 97.67c-13.02-4.375-27.45 .1562-35.72 11.16L464 266.7l-118.4-157.8c-8.266-11.03-22.64-15.56-35.72-11.16C296.8 102 288 114.2 288 128v256c0 17.69 14.33 32 32 32s32-14.31 32-32v-160l86.41 115.2c12.06 16.12 39.13 16.12 51.19 0L576 224v160c0 17.69 14.33 32 32 32s32-14.31 32-32v-256C640 114.2 631.2 102 618.1 97.67zM224 96.01H32c-17.67 0-32 14.31-32 32s14.33 32 32 32h64v223.1c0 17.69 14.33 31.99 32 31.99s32-14.3 32-31.99V160h64c17.67 0 32-14.31 32-32S241.7 96.01 224 96.01z\"\n ]\n};\nvar faTrafficLight = {\n prefix: 'fas',\n iconName: 'traffic-light',\n icon: [\n 320,\n 512,\n [\n 128678\n ],\n \"f637\",\n \"M256 0C291.3 0 320 28.65 320 64V352C320 440.4 248.4 512 160 512C71.63 512 0 440.4 0 352V64C0 28.65 28.65 0 64 0H256zM160 320C133.5 320 112 341.5 112 368C112 394.5 133.5 416 160 416C186.5 416 208 394.5 208 368C208 341.5 186.5 320 160 320zM160 288C186.5 288 208 266.5 208 240C208 213.5 186.5 192 160 192C133.5 192 112 213.5 112 240C112 266.5 133.5 288 160 288zM160 64C133.5 64 112 85.49 112 112C112 138.5 133.5 160 160 160C186.5 160 208 138.5 208 112C208 85.49 186.5 64 160 64z\"\n ]\n};\nvar faTrailer = {\n prefix: 'fas',\n iconName: 'trailer',\n icon: [\n 640,\n 512,\n [],\n \"e041\",\n \"M496 32C522.5 32 544 53.49 544 80V320H608C625.7 320 640 334.3 640 352C640 369.7 625.7 384 608 384H286.9C279.1 329.7 232.4 288 176 288C119.6 288 72.9 329.7 65.13 384H48C21.49 384 0 362.5 0 336V80C0 53.49 21.49 32 48 32H496zM64 112V264.2C73.83 256.1 84.55 249 96 243.2V112C96 103.2 88.84 96 80 96C71.16 96 64 103.2 64 112V112zM176 224C181.4 224 186.7 224.2 192 224.7V112C192 103.2 184.8 96 176 96C167.2 96 160 103.2 160 112V224.7C165.3 224.2 170.6 224 176 224zM256 243.2C267.4 249 278.2 256.1 288 264.2V112C288 103.2 280.8 96 272 96C263.2 96 256 103.2 256 112V243.2zM352 112V304C352 312.8 359.2 320 368 320C376.8 320 384 312.8 384 304V112C384 103.2 376.8 96 368 96C359.2 96 352 103.2 352 112zM480 112C480 103.2 472.8 96 464 96C455.2 96 448 103.2 448 112V304C448 312.8 455.2 320 464 320C472.8 320 480 312.8 480 304V112zM96 400C96 355.8 131.8 320 176 320C220.2 320 256 355.8 256 400C256 444.2 220.2 480 176 480C131.8 480 96 444.2 96 400zM176 432C193.7 432 208 417.7 208 400C208 382.3 193.7 368 176 368C158.3 368 144 382.3 144 400C144 417.7 158.3 432 176 432z\"\n ]\n};\nvar faTrain = {\n prefix: 'fas',\n iconName: 'train',\n icon: [\n 448,\n 512,\n [\n 128646\n ],\n \"f238\",\n \"M352 0C405 0 448 42.98 448 96V352C448 399.1 412.8 439.7 366.9 446.9L412.9 492.9C419.9 499.9 414.9 512 404.1 512H365.3C356.8 512 348.6 508.6 342.6 502.6L288 448H160L105.4 502.6C99.37 508.6 91.23 512 82.75 512H43.04C33.06 512 28.06 499.9 35.12 492.9L81.14 446.9C35.18 439.7 0 399.1 0 352V96C0 42.98 42.98 0 96 0H352zM64 192C64 209.7 78.33 224 96 224H352C369.7 224 384 209.7 384 192V96C384 78.33 369.7 64 352 64H96C78.33 64 64 78.33 64 96V192zM224 384C250.5 384 272 362.5 272 336C272 309.5 250.5 288 224 288C197.5 288 176 309.5 176 336C176 362.5 197.5 384 224 384z\"\n ]\n};\nvar faTrainSubway = {\n prefix: 'fas',\n iconName: 'train-subway',\n icon: [\n 448,\n 512,\n [\n \"subway\"\n ],\n \"f239\",\n \"M352 0C405 0 448 42.98 448 96V352C448 399.1 412.8 439.7 366.9 446.9L412.9 492.9C419.9 499.9 414.9 512 404.1 512H365.3C356.8 512 348.6 508.6 342.6 502.6L288 448H160L105.4 502.6C99.37 508.6 91.23 512 82.75 512H43.04C33.06 512 28.06 499.9 35.12 492.9L81.14 446.9C35.18 439.7 0 399.1 0 352V96C0 42.98 42.98 0 96 0H352zM64 224C64 241.7 78.33 256 96 256H176C193.7 256 208 241.7 208 224V128C208 110.3 193.7 96 176 96H96C78.33 96 64 110.3 64 128V224zM272 96C254.3 96 240 110.3 240 128V224C240 241.7 254.3 256 272 256H352C369.7 256 384 241.7 384 224V128C384 110.3 369.7 96 352 96H272zM96 320C78.33 320 64 334.3 64 352C64 369.7 78.33 384 96 384C113.7 384 128 369.7 128 352C128 334.3 113.7 320 96 320zM352 384C369.7 384 384 369.7 384 352C384 334.3 369.7 320 352 320C334.3 320 320 334.3 320 352C320 369.7 334.3 384 352 384z\"\n ]\n};\nvar faSubway = faTrainSubway;\nvar faTrainTram = {\n prefix: 'fas',\n iconName: 'train-tram',\n icon: [\n 448,\n 512,\n [\n 128650,\n \"tram\"\n ],\n \"f7da\",\n \"M86.76 48C74.61 48 63.12 53.52 55.53 63.01L42.74 78.99C34.46 89.34 19.36 91.02 9.007 82.74C-1.343 74.46-3.021 59.36 5.259 49.01L18.04 33.03C34.74 12.15 60.03 0 86.76 0H361.2C387.1 0 413.3 12.15 429.1 33.03L442.7 49.01C451 59.36 449.3 74.46 438.1 82.74C428.6 91.02 413.5 89.34 405.3 78.99L392.5 63.01C384.9 53.52 373.4 48 361.2 48H248V96H288C341 96 384 138.1 384 192V352C384 382.6 369.7 409.8 347.4 427.4L412.9 492.9C419.9 499.9 414.9 512 404.1 512H365.3C356.8 512 348.6 508.6 342.6 502.6L288 448H160L105.4 502.6C99.37 508.6 91.23 512 82.74 512H43.04C33.06 512 28.06 499.9 35.12 492.9L100.6 427.4C78.3 409.8 64 382.6 64 352V192C64 138.1 106.1 96 160 96H200V48H86.76zM160 160C142.3 160 128 174.3 128 192V224C128 241.7 142.3 256 160 256H288C305.7 256 320 241.7 320 224V192C320 174.3 305.7 160 288 160H160zM160 320C142.3 320 128 334.3 128 352C128 369.7 142.3 384 160 384C177.7 384 192 369.7 192 352C192 334.3 177.7 320 160 320zM288 384C305.7 384 320 369.7 320 352C320 334.3 305.7 320 288 320C270.3 320 256 334.3 256 352C256 369.7 270.3 384 288 384z\"\n ]\n};\nvar faTram = faTrainTram;\nvar faTransgender = {\n prefix: 'fas',\n iconName: 'transgender',\n icon: [\n 512,\n 512,\n [\n 9895,\n \"transgender-alt\"\n ],\n \"f225\",\n \"M498.6 .0003h-94.37c-17.96 0-26.95 21.71-14.25 34.41L411.1 55.61l-67.01 67.01C318.8 105.9 288.6 96 256 96S193.2 105.9 167.9 122.6L151.6 106.3l6.061-6.062c6.25-6.248 6.25-16.38 0-22.63L146.3 66.34c-6.25-6.248-16.38-6.248-22.63 0L117.7 72.41L100.9 55.61L122.1 34.41c12.7-12.7 3.703-34.41-14.25-34.41H13.44C6.016 .0003 0 6.016 0 13.44v94.37c0 17.96 21.71 26.95 34.41 14.25l21.2-21.2l16.8 16.8L66.35 123.7c-6.25 6.248-6.25 16.38 0 22.63l11.31 11.31c6.25 6.248 16.38 6.248 22.63 0l6.061-6.061L122.6 167.9C105.9 193.2 96 223.4 96 256c0 77.4 54.97 141.9 128 156.8v19.23l-16-.0014c-8.836 0-16 7.165-16 16v15.1c0 8.836 7.164 16 16 16L224 480v16c0 8.836 7.164 16 16 16h32c8.836 0 16-7.164 16-16v-16l16-.0001c8.836 0 16-7.164 16-16v-15.1c0-8.836-7.164-16-16-16L288 432v-19.23c73.03-14.83 128-79.37 128-156.8c0-32.6-9.867-62.85-26.61-88.14l67.01-67.01l21.2 21.2C490.3 134.8 512 125.8 512 107.8V13.44C512 6.016 505.1 .0003 498.6 .0003zM256 336c-44.11 0-80-35.89-80-80c0-44.11 35.89-80 80-80c44.11 0 80 35.89 80 80C336 300.1 300.1 336 256 336z\"\n ]\n};\nvar faTransgenderAlt = faTransgender;\nvar faTrash = {\n prefix: 'fas',\n iconName: 'trash',\n icon: [\n 448,\n 512,\n [],\n \"f1f8\",\n \"M135.2 17.69C140.6 6.848 151.7 0 163.8 0H284.2C296.3 0 307.4 6.848 312.8 17.69L320 32H416C433.7 32 448 46.33 448 64C448 81.67 433.7 96 416 96H32C14.33 96 0 81.67 0 64C0 46.33 14.33 32 32 32H128L135.2 17.69zM394.8 466.1C393.2 492.3 372.3 512 346.9 512H101.1C75.75 512 54.77 492.3 53.19 466.1L31.1 128H416L394.8 466.1z\"\n ]\n};\nvar faTrashArrowUp = {\n prefix: 'fas',\n iconName: 'trash-arrow-up',\n icon: [\n 448,\n 512,\n [\n \"trash-restore\"\n ],\n \"f829\",\n \"M284.2 0C296.3 0 307.4 6.848 312.8 17.69L320 32H416C433.7 32 448 46.33 448 64C448 81.67 433.7 96 416 96H32C14.33 96 0 81.67 0 64C0 46.33 14.33 32 32 32H128L135.2 17.69C140.6 6.848 151.7 0 163.8 0H284.2zM31.1 128H416L394.8 466.1C393.2 492.3 372.3 512 346.9 512H101.1C75.75 512 54.77 492.3 53.19 466.1L31.1 128zM207 199L127 279C117.7 288.4 117.7 303.6 127 312.1C136.4 322.3 151.6 322.3 160.1 312.1L199.1 273.9V408C199.1 421.3 210.7 432 223.1 432C237.3 432 248 421.3 248 408V273.9L287 312.1C296.4 322.3 311.6 322.3 320.1 312.1C330.3 303.6 330.3 288.4 320.1 279L240.1 199C236.5 194.5 230.4 191.1 223.1 191.1C217.6 191.1 211.5 194.5 207 199V199z\"\n ]\n};\nvar faTrashRestore = faTrashArrowUp;\nvar faTrashCan = {\n prefix: 'fas',\n iconName: 'trash-can',\n icon: [\n 448,\n 512,\n [\n 61460,\n \"trash-alt\"\n ],\n \"f2ed\",\n \"M135.2 17.69C140.6 6.848 151.7 0 163.8 0H284.2C296.3 0 307.4 6.848 312.8 17.69L320 32H416C433.7 32 448 46.33 448 64C448 81.67 433.7 96 416 96H32C14.33 96 0 81.67 0 64C0 46.33 14.33 32 32 32H128L135.2 17.69zM31.1 128H416V448C416 483.3 387.3 512 352 512H95.1C60.65 512 31.1 483.3 31.1 448V128zM111.1 208V432C111.1 440.8 119.2 448 127.1 448C136.8 448 143.1 440.8 143.1 432V208C143.1 199.2 136.8 192 127.1 192C119.2 192 111.1 199.2 111.1 208zM207.1 208V432C207.1 440.8 215.2 448 223.1 448C232.8 448 240 440.8 240 432V208C240 199.2 232.8 192 223.1 192C215.2 192 207.1 199.2 207.1 208zM304 208V432C304 440.8 311.2 448 320 448C328.8 448 336 440.8 336 432V208C336 199.2 328.8 192 320 192C311.2 192 304 199.2 304 208z\"\n ]\n};\nvar faTrashAlt = faTrashCan;\nvar faTrashCanArrowUp = {\n prefix: 'fas',\n iconName: 'trash-can-arrow-up',\n icon: [\n 448,\n 512,\n [\n \"trash-restore-alt\"\n ],\n \"f82a\",\n \"M284.2 0C296.3 0 307.4 6.848 312.8 17.69L320 32H416C433.7 32 448 46.33 448 64C448 81.67 433.7 96 416 96H32C14.33 96 0 81.67 0 64C0 46.33 14.33 32 32 32H128L135.2 17.69C140.6 6.848 151.7 0 163.8 0H284.2zM31.1 128H416V448C416 483.3 387.3 512 352 512H95.1C60.65 512 31.1 483.3 31.1 448V128zM207 199L127 279C117.7 288.4 117.7 303.6 127 312.1C136.4 322.3 151.6 322.3 160.1 312.1L199.1 273.9V408C199.1 421.3 210.7 432 223.1 432C237.3 432 248 421.3 248 408V273.9L287 312.1C296.4 322.3 311.6 322.3 320.1 312.1C330.3 303.6 330.3 288.4 320.1 279L240.1 199C236.5 194.5 230.4 191.1 223.1 191.1C217.6 191.1 211.5 194.5 207 199V199z\"\n ]\n};\nvar faTrashRestoreAlt = faTrashCanArrowUp;\nvar faTree = {\n prefix: 'fas',\n iconName: 'tree',\n icon: [\n 448,\n 512,\n [\n 127794\n ],\n \"f1bb\",\n \"M413.8 447.1L256 448l0 31.99C256 497.7 241.8 512 224.1 512c-17.67 0-32.1-14.32-32.1-31.99l0-31.99l-158.9-.0099c-28.5 0-43.69-34.49-24.69-56.4l68.98-79.59H62.22c-25.41 0-39.15-29.8-22.67-49.13l60.41-70.85H89.21c-21.28 0-32.87-22.5-19.28-37.31l134.8-146.5c10.4-11.3 28.22-11.3 38.62-.0033l134.9 146.5c13.62 14.81 2.001 37.31-19.28 37.31h-10.77l60.35 70.86c16.46 19.34 2.716 49.12-22.68 49.12h-15.2l68.98 79.59C458.7 413.7 443.1 447.1 413.8 447.1z\"\n ]\n};\nvar faTriangleExclamation = {\n prefix: 'fas',\n iconName: 'triangle-exclamation',\n icon: [\n 512,\n 512,\n [\n 9888,\n \"exclamation-triangle\",\n \"warning\"\n ],\n \"f071\",\n \"M506.3 417l-213.3-364c-16.33-28-57.54-28-73.98 0l-213.2 364C-10.59 444.9 9.849 480 42.74 480h426.6C502.1 480 522.6 445 506.3 417zM232 168c0-13.25 10.75-24 24-24S280 154.8 280 168v128c0 13.25-10.75 24-23.1 24S232 309.3 232 296V168zM256 416c-17.36 0-31.44-14.08-31.44-31.44c0-17.36 14.07-31.44 31.44-31.44s31.44 14.08 31.44 31.44C287.4 401.9 273.4 416 256 416z\"\n ]\n};\nvar faExclamationTriangle = faTriangleExclamation;\nvar faWarning = faTriangleExclamation;\nvar faTrophy = {\n prefix: 'fas',\n iconName: 'trophy',\n icon: [\n 576,\n 512,\n [\n 127942\n ],\n \"f091\",\n \"M572.1 82.38C569.5 71.59 559.8 64 548.7 64h-100.8c.2422-12.45 .1078-23.7-.1559-33.02C447.3 13.63 433.2 0 415.8 0H160.2C142.8 0 128.7 13.63 128.2 30.98C127.1 40.3 127.8 51.55 128.1 64H27.26C16.16 64 6.537 71.59 3.912 82.38C3.1 85.78-15.71 167.2 37.07 245.9c37.44 55.82 100.6 95.03 187.5 117.4c18.7 4.805 31.41 22.06 31.41 41.37C256 428.5 236.5 448 212.6 448H208c-26.51 0-47.99 21.49-47.99 48c0 8.836 7.163 16 15.1 16h223.1c8.836 0 15.1-7.164 15.1-16c0-26.51-21.48-48-47.99-48h-4.644c-23.86 0-43.36-19.5-43.36-43.35c0-19.31 12.71-36.57 31.41-41.37c86.96-22.34 150.1-61.55 187.5-117.4C591.7 167.2 572.9 85.78 572.1 82.38zM77.41 219.8C49.47 178.6 47.01 135.7 48.38 112h80.39c5.359 59.62 20.35 131.1 57.67 189.1C137.4 281.6 100.9 254.4 77.41 219.8zM498.6 219.8c-23.44 34.6-59.94 61.75-109 81.22C426.9 243.1 441.9 171.6 447.2 112h80.39C528.1 135.7 526.5 178.7 498.6 219.8z\"\n ]\n};\nvar faTruck = {\n prefix: 'fas',\n iconName: 'truck',\n icon: [\n 640,\n 512,\n [\n 128666,\n 9951\n ],\n \"f0d1\",\n \"M368 0C394.5 0 416 21.49 416 48V96H466.7C483.7 96 499.1 102.7 512 114.7L589.3 192C601.3 204 608 220.3 608 237.3V352C625.7 352 640 366.3 640 384C640 401.7 625.7 416 608 416H576C576 469 533 512 480 512C426.1 512 384 469 384 416H256C256 469 213 512 160 512C106.1 512 64 469 64 416H48C21.49 416 0 394.5 0 368V48C0 21.49 21.49 0 48 0H368zM416 160V256H544V237.3L466.7 160H416zM160 368C133.5 368 112 389.5 112 416C112 442.5 133.5 464 160 464C186.5 464 208 442.5 208 416C208 389.5 186.5 368 160 368zM480 464C506.5 464 528 442.5 528 416C528 389.5 506.5 368 480 368C453.5 368 432 389.5 432 416C432 442.5 453.5 464 480 464z\"\n ]\n};\nvar faTruckFast = {\n prefix: 'fas',\n iconName: 'truck-fast',\n icon: [\n 640,\n 512,\n [\n \"shipping-fast\"\n ],\n \"f48b\",\n \"M64 48C64 21.49 85.49 0 112 0H368C394.5 0 416 21.49 416 48V256H608V352C625.7 352 640 366.3 640 384C640 401.7 625.7 416 608 416H576C576 469 533 512 480 512C426.1 512 384 469 384 416H256C256 469 213 512 160 512C106.1 512 64 469 64 416V288H208C216.8 288 224 280.8 224 272C224 263.2 216.8 256 208 256H16C7.164 256 0 248.8 0 240C0 231.2 7.164 224 16 224H240C248.8 224 256 216.8 256 208C256 199.2 248.8 192 240 192H48C39.16 192 32 184.8 32 176C32 167.2 39.16 160 48 160H272C280.8 160 288 152.8 288 144C288 135.2 280.8 128 272 128H16C7.164 128 0 120.8 0 112C0 103.2 7.164 96 16 96H64V48zM160 464C186.5 464 208 442.5 208 416C208 389.5 186.5 368 160 368C133.5 368 112 389.5 112 416C112 442.5 133.5 464 160 464zM480 368C453.5 368 432 389.5 432 416C432 442.5 453.5 464 480 464C506.5 464 528 442.5 528 416C528 389.5 506.5 368 480 368zM466.7 160H400V96H466.7C483.7 96 499.1 102.7 512 114.7L589.3 192C601.3 204 608 220.3 608 237.3V288H544V237.3L466.7 160z\"\n ]\n};\nvar faShippingFast = faTruckFast;\nvar faTruckMedical = {\n prefix: 'fas',\n iconName: 'truck-medical',\n icon: [\n 640,\n 512,\n [\n 128657,\n \"ambulance\"\n ],\n \"f0f9\",\n \"M368 0C394.5 0 416 21.49 416 48V96H466.7C483.7 96 499.1 102.7 512 114.7L589.3 192C601.3 204 608 220.3 608 237.3V352C625.7 352 640 366.3 640 384C640 401.7 625.7 416 608 416H576C576 469 533 512 480 512C426.1 512 384 469 384 416H256C256 469 213 512 160 512C106.1 512 64 469 64 416H48C21.49 416 0 394.5 0 368V48C0 21.49 21.49 0 48 0H368zM416 160V256H544V237.3L466.7 160H416zM160 368C133.5 368 112 389.5 112 416C112 442.5 133.5 464 160 464C186.5 464 208 442.5 208 416C208 389.5 186.5 368 160 368zM480 464C506.5 464 528 442.5 528 416C528 389.5 506.5 368 480 368C453.5 368 432 389.5 432 416C432 442.5 453.5 464 480 464zM112 176C112 184.8 119.2 192 128 192H176V240C176 248.8 183.2 256 192 256H224C232.8 256 240 248.8 240 240V192H288C296.8 192 304 184.8 304 176V144C304 135.2 296.8 128 288 128H240V80C240 71.16 232.8 64 224 64H192C183.2 64 176 71.16 176 80V128H128C119.2 128 112 135.2 112 144V176z\"\n ]\n};\nvar faAmbulance = faTruckMedical;\nvar faTruckMonster = {\n prefix: 'fas',\n iconName: 'truck-monster',\n icon: [\n 640,\n 512,\n [],\n \"f63b\",\n \"M419.2 25.6L496 128H576C593.7 128 608 142.3 608 160V224C625.7 224 640 238.3 640 256C640 273.7 625.7 287.1 608 288C578.8 249.1 532.3 224 480 224C427.7 224 381.2 249.1 351.1 288H288C258.8 249.1 212.3 224 160 224C107.7 224 61.18 249.1 31.99 288C14.32 287.1 0 273.7 0 256C0 238.3 14.33 224 32 224V160C32 142.3 46.33 128 64 128H224V48C224 21.49 245.5 0 272 0H368C388.1 0 407.1 9.484 419.2 25.6H419.2zM288 128H416L368 64H288V128zM168 256C180.1 256 190.1 264.9 191.8 276.6C199.4 278.8 206.7 281.9 213.5 285.6C222.9 278.5 236.3 279.3 244.9 287.8L256.2 299.1C264.7 307.7 265.5 321.1 258.4 330.5C262.1 337.3 265.2 344.6 267.4 352.2C279.1 353.9 288 363.9 288 376V392C288 404.1 279.1 414.1 267.4 415.8C265.2 423.4 262.1 430.7 258.4 437.5C265.5 446.9 264.7 460.3 256.2 468.9L244.9 480.2C236.3 488.7 222.9 489.5 213.5 482.4C206.7 486.1 199.4 489.2 191.8 491.4C190.1 503.1 180.1 512 167.1 512H151.1C139.9 512 129.9 503.1 128.2 491.4C120.6 489.2 113.3 486.1 106.5 482.4C97.09 489.5 83.7 488.7 75.15 480.2L63.83 468.9C55.28 460.3 54.53 446.9 61.58 437.5C57.85 430.7 54.81 423.4 52.57 415.8C40.94 414.1 31.1 404.1 31.1 392V376C31.1 363.9 40.94 353.9 52.57 352.2C54.81 344.6 57.85 337.3 61.58 330.5C54.53 321.1 55.28 307.7 63.83 299.1L75.15 287.8C83.7 279.3 97.09 278.5 106.5 285.6C113.3 281.9 120.6 278.8 128.2 276.6C129.9 264.9 139.9 255.1 151.1 255.1L168 256zM160 432C186.5 432 208 410.5 208 384C208 357.5 186.5 336 160 336C133.5 336 112 357.5 112 384C112 410.5 133.5 432 160 432zM448.2 276.6C449.9 264.9 459.9 256 472 256H488C500.1 256 510.1 264.9 511.8 276.6C519.4 278.8 526.7 281.9 533.5 285.6C542.9 278.5 556.3 279.3 564.9 287.8L576.2 299.1C584.7 307.7 585.5 321.1 578.4 330.5C582.1 337.3 585.2 344.6 587.4 352.2C599.1 353.9 608 363.9 608 376V392C608 404.1 599.1 414.1 587.4 415.8C585.2 423.4 582.1 430.7 578.4 437.5C585.5 446.9 584.7 460.3 576.2 468.9L564.9 480.2C556.3 488.7 542.9 489.5 533.5 482.4C526.7 486.1 519.4 489.2 511.8 491.4C510.1 503.1 500.1 512 488 512H472C459.9 512 449.9 503.1 448.2 491.4C440.6 489.2 433.3 486.1 426.5 482.4C417.1 489.5 403.7 488.7 395.1 480.2L383.8 468.9C375.3 460.3 374.5 446.9 381.6 437.5C377.9 430.7 374.8 423.4 372.6 415.8C360.9 414.1 352 404.1 352 392V376C352 363.9 360.9 353.9 372.6 352.2C374.8 344.6 377.9 337.3 381.6 330.5C374.5 321.1 375.3 307.7 383.8 299.1L395.1 287.8C403.7 279.3 417.1 278.5 426.5 285.6C433.3 281.9 440.6 278.8 448.2 276.6L448.2 276.6zM480 336C453.5 336 432 357.5 432 384C432 410.5 453.5 432 480 432C506.5 432 528 410.5 528 384C528 357.5 506.5 336 480 336z\"\n ]\n};\nvar faTruckMoving = {\n prefix: 'fas',\n iconName: 'truck-moving',\n icon: [\n 640,\n 512,\n [],\n \"f4df\",\n \"M416 32C451.3 32 480 60.65 480 96V144H528.8C545.6 144 561.5 151.5 572.2 164.5L630.1 236.4C636.8 243.5 640 252.5 640 261.7V352C640 369.7 625.7 384 608 384H606.4C607.4 389.2 608 394.5 608 400C608 444.2 572.2 480 528 480C483.8 480 448 444.2 448 400C448 394.5 448.6 389.2 449.6 384H286.4C287.4 389.2 288 394.5 288 400C288 444.2 252.2 480 208 480C181.8 480 158.6 467.4 144 448C129.4 467.4 106.2 480 80 480C35.82 480 0 444.2 0 400V96C0 60.65 28.65 32 64 32H416zM535 194.9C533.5 193.1 531.2 192 528.8 192H480V256H584.1L535 194.9zM528 432C545.7 432 560 417.7 560 400C560 382.3 545.7 368 528 368C510.3 368 496 382.3 496 400C496 417.7 510.3 432 528 432zM208 368C190.3 368 176 382.3 176 400C176 417.7 190.3 432 208 432C225.7 432 240 417.7 240 400C240 382.3 225.7 368 208 368zM80 432C97.67 432 112 417.7 112 400C112 382.3 97.67 368 80 368C62.33 368 48 382.3 48 400C48 417.7 62.33 432 80 432z\"\n ]\n};\nvar faTruckPickup = {\n prefix: 'fas',\n iconName: 'truck-pickup',\n icon: [\n 640,\n 512,\n [\n 128763\n ],\n \"f63c\",\n \"M272 32H368.6C388.1 32 406.5 40.84 418.6 56.02L527.4 192H576C593.7 192 608 206.3 608 224V288C625.7 288 640 302.3 640 320C640 337.7 625.7 352 608 352H574.9C575.6 357.2 576 362.6 576 368C576 429.9 525.9 480 464 480C402.1 480 352 429.9 352 368C352 362.6 352.4 357.2 353.1 352H286.9C287.6 357.2 288 362.6 288 368C288 429.9 237.9 480 176 480C114.1 480 64 429.9 64 368C64 362.6 64.39 357.2 65.13 352H32C14.33 352 0 337.7 0 320C0 302.3 14.33 288 32 288V224C32 206.3 46.33 192 64 192H224V80C224 53.49 245.5 32 272 32H272zM368.6 96H288V192H445.4L368.6 96zM176 416C202.5 416 224 394.5 224 368C224 341.5 202.5 320 176 320C149.5 320 128 341.5 128 368C128 394.5 149.5 416 176 416zM464 416C490.5 416 512 394.5 512 368C512 341.5 490.5 320 464 320C437.5 320 416 341.5 416 368C416 394.5 437.5 416 464 416z\"\n ]\n};\nvar faTruckRampBox = {\n prefix: 'fas',\n iconName: 'truck-ramp-box',\n icon: [\n 640,\n 512,\n [\n \"truck-loading\"\n ],\n \"f4de\",\n \"M640 .0003V400C640 461.9 589.9 512 528 512C467 512 417.5 463.3 416 402.7L48.41 502.9C31.36 507.5 13.77 497.5 9.126 480.4C4.48 463.4 14.54 445.8 31.59 441.1L352 353.8V64C352 28.65 380.7 0 416 0L640 .0003zM528 352C501.5 352 480 373.5 480 400C480 426.5 501.5 448 528 448C554.5 448 576 426.5 576 400C576 373.5 554.5 352 528 352zM23.11 207.7C18.54 190.6 28.67 173.1 45.74 168.5L92.1 156.1L112.8 233.4C115.1 241.9 123.9 246.1 132.4 244.7L163.3 236.4C171.8 234.1 176.9 225.3 174.6 216.8L153.9 139.5L200.3 127.1C217.4 122.5 234.9 132.7 239.5 149.7L280.9 304.3C285.5 321.4 275.3 338.9 258.3 343.5L103.7 384.9C86.64 389.5 69.1 379.3 64.52 362.3L23.11 207.7z\"\n ]\n};\nvar faTruckLoading = faTruckRampBox;\nvar faTty = {\n prefix: 'fas',\n iconName: 'tty',\n icon: [\n 512,\n 512,\n [\n \"teletype\"\n ],\n \"f1e4\",\n \"M271.1 364v40c0 6.625 5.375 12 12 12h40c6.625 0 12-5.375 12-12v-40c0-6.625-5.375-12-12-12h-40C277.3 352 271.1 357.4 271.1 364zM367.1 364v40c0 6.625 5.375 12 12 12h40c6.625 0 12-5.375 12-12v-40c0-6.625-5.375-12-12-12h-40C373.3 352 367.1 357.4 367.1 364zM275.1 256h-40c-6.625 0-12 5.375-12 12v40c0 6.625 5.376 12 12 12h39.1c6.625 0 12-5.375 12-12v-40C287.1 261.4 282.6 256 275.1 256zM83.96 448h-40c-6.625 0-12 5.375-12 12v40c0 6.625 5.375 12 12 12h40c6.625 0 12-5.375 12-12v-40C95.96 453.4 90.59 448 83.96 448zM175.1 364v40c0 6.625 5.375 12 12 12h40c6.625 0 12-5.375 12-12v-40c0-6.625-5.375-12-12-12h-40C181.3 352 175.1 357.4 175.1 364zM371.1 256h-40c-6.625 0-12 5.375-12 12v40c0 6.625 5.372 12 11.1 12h39.1c6.625 0 12-5.375 12-12v-40C383.1 261.4 378.6 256 371.1 256zM467.1 256h-40c-6.625 0-12 5.375-12 12v40c0 6.625 5.369 12 11.99 12h39.1c6.625 0 12.01-5.375 12.01-12v-40C479.1 261.4 474.6 256 467.1 256zM371.1 448h-232c-6.625 0-12 5.375-12 12v40c0 6.625 5.375 12 12 12h232c6.625 0 12-5.375 12-12v-40C383.1 453.4 378.6 448 371.1 448zM179.1 256h-40c-6.625 0-12 5.375-12 12v40c0 6.625 5.38 12 12 12h39.1c6.625 0 11.1-5.375 11.1-12v-40C191.1 261.4 186.6 256 179.1 256zM467.1 448h-40c-6.625 0-12 5.375-12 12v40c0 6.625 5.375 12 12 12h40c6.625 0 12-5.375 12-12v-40C479.1 453.4 474.6 448 467.1 448zM79.96 364v40c0 6.625 5.375 12 12 12h40c6.625 0 12-5.375 12-12v-40c0-6.625-5.375-12-12-12h-40C85.34 352 79.96 357.4 79.96 364zM83.96 256h-40c-6.625 0-12 5.375-12 12v40c0 6.625 5.383 12 12.01 12H83.97c6.625 0 11.99-5.375 11.99-12v-40C95.96 261.4 90.59 256 83.96 256zM504.9 102.9C367.7-34.31 144.3-34.32 7.083 102.9c-7.975 7.973-9.375 20.22-3.391 29.74l42.17 67.47c6.141 9.844 18.47 13.88 29.35 9.632l84.36-33.74C169.5 172.1 175.6 161.1 174.5 151.3l-5.303-53.27c56.15-19.17 117.4-19.17 173.6 .0059L337.5 151.3c-1.139 10.59 4.997 20.78 14.96 24.73l84.35 33.73c10.83 4.303 23.22 .1608 29.33-9.615l42.18-67.48C514.3 123.2 512.9 110.9 504.9 102.9z\"\n ]\n};\nvar faTeletype = faTty;\nvar faTurkishLiraSign = {\n prefix: 'fas',\n iconName: 'turkish-lira-sign',\n icon: [\n 384,\n 512,\n [\n \"try\",\n \"turkish-lira\"\n ],\n \"e2bb\",\n \"M96 32C113.7 32 128 46.33 128 64V99.29L247.2 65.23C264.2 60.38 281.9 70.22 286.8 87.21C291.6 104.2 281.8 121.9 264.8 126.8L128 165.9V195.3L247.2 161.2C264.2 156.4 281.9 166.2 286.8 183.2C291.6 200.2 281.8 217.9 264.8 222.8L128 261.9V416H191.8C260 416 316.2 362.5 319.6 294.4L320 286.4C320.9 268.8 335.9 255.2 353.6 256C371.2 256.9 384.8 271.9 383.1 289.6L383.6 297.6C378.5 399.8 294.1 480 191.8 480H96C78.33 480 64 465.7 64 448V280.1L40.79 286.8C23.8 291.6 6.087 281.8 1.232 264.8C-3.623 247.8 6.217 230.1 23.21 225.2L64 213.6V184.1L40.79 190.8C23.8 195.6 6.087 185.8 1.232 168.8C-3.623 151.8 6.216 134.1 23.21 129.2L64 117.6V64C64 46.33 78.33 32 96 32L96 32z\"\n ]\n};\nvar faTry = faTurkishLiraSign;\nvar faTurkishLira = faTurkishLiraSign;\nvar faTurnDown = {\n prefix: 'fas',\n iconName: 'turn-down',\n icon: [\n 384,\n 512,\n [\n 10549,\n \"level-down-alt\"\n ],\n \"f3be\",\n \"M313.6 392.3l-104 112c-9.5 10.23-25.69 10.23-35.19 0l-104-112c-6.484-6.984-8.219-17.17-4.406-25.92S78.45 352 88 352H160V80C160 71.19 152.8 64 144 64H32C14.33 64 0 49.69 0 32s14.33-32 32-32h112C188.1 0 224 35.88 224 80V352h72c9.547 0 18.19 5.656 22 14.41S320.1 385.3 313.6 392.3z\"\n ]\n};\nvar faLevelDownAlt = faTurnDown;\nvar faTurnUp = {\n prefix: 'fas',\n iconName: 'turn-up',\n icon: [\n 384,\n 512,\n [\n 10548,\n \"level-up-alt\"\n ],\n \"f3bf\",\n \"M318 145.6c-3.812 8.75-12.45 14.41-22 14.41L224 160v272c0 44.13-35.89 80-80 80H32c-17.67 0-32-14.31-32-32s14.33-32 32-32h112C152.8 448 160 440.8 160 432V160L88 159.1c-9.547 0-18.19-5.656-22-14.41S63.92 126.7 70.41 119.7l104-112c9.498-10.23 25.69-10.23 35.19 0l104 112C320.1 126.7 321.8 136.8 318 145.6z\"\n ]\n};\nvar faLevelUpAlt = faTurnUp;\nvar faTv = {\n prefix: 'fas',\n iconName: 'tv',\n icon: [\n 640,\n 512,\n [\n 63717,\n \"television\",\n \"tv-alt\"\n ],\n \"f26c\",\n \"M512 448H127.1C110.3 448 96 462.3 96 479.1S110.3 512 127.1 512h384C529.7 512 544 497.7 544 480S529.7 448 512 448zM592 0h-544C21.5 0 0 21.5 0 48v320C0 394.5 21.5 416 48 416h544c26.5 0 48-21.5 48-48v-320C640 21.5 618.5 0 592 0zM576 352H64v-288h512V352z\"\n ]\n};\nvar faTelevision = faTv;\nvar faTvAlt = faTv;\nvar faU = {\n prefix: 'fas',\n iconName: 'u',\n icon: [\n 384,\n 512,\n [\n 117\n ],\n \"55\",\n \"M384 64.01v225.7c0 104.1-86.13 190.3-192 190.3s-192-85.38-192-190.3V64.01C0 46.34 14.33 32.01 32 32.01S64 46.34 64 64.01v225.7c0 69.67 57.42 126.3 128 126.3s128-56.67 128-126.3V64.01c0-17.67 14.33-32 32-32S384 46.34 384 64.01z\"\n ]\n};\nvar faUmbrella = {\n prefix: 'fas',\n iconName: 'umbrella',\n icon: [\n 576,\n 512,\n [],\n \"f0e9\",\n \"M255.1 301.7v130.3c0 8.814-7.188 16-16 16c-7.814 0-13.19-5.314-15.1-10.69c-5.906-16.72-24.1-25.41-40.81-19.5c-16.69 5.875-25.41 24.19-19.5 40.79C175.8 490.6 206.2 512 239.1 512C284.1 512 320 476.1 320 431.1v-130.3c-9.094-7.908-19.81-13.61-32-13.61C275.7 288.1 265.6 292.9 255.1 301.7zM575.7 280.9C547.1 144.5 437.3 62.61 320 49.91V32.01c0-17.69-14.31-32.01-32-32.01S255.1 14.31 255.1 32.01v17.91C138.3 62.61 29.48 144.5 .2949 280.9C-1.926 290.1 8.795 302.1 18.98 292.2c52-55.01 107.7-52.39 158.6 37.01c5.312 9.502 14.91 8.625 19.72 0C217.5 293.9 242.2 256 287.1 256c58.5 0 88.19 68.82 90.69 73.2c4.812 8.625 14.41 9.502 19.72 0c51-89.52 107.1-91.39 158.6-37.01C567.3 302.2 577.9 290.1 575.7 280.9z\"\n ]\n};\nvar faUmbrellaBeach = {\n prefix: 'fas',\n iconName: 'umbrella-beach',\n icon: [\n 640,\n 512,\n [\n 127958\n ],\n \"f5ca\",\n \"M115.4 136.8l102.1 37.35c35.13-81.62 86.25-144.4 139-173.7c-95.88-4.875-188.8 36.96-248.5 111.7C101.2 120.6 105.2 133.2 115.4 136.8zM247.6 185l238.5 86.87c35.75-121.4 18.62-231.6-42.63-253.9c-7.375-2.625-15.12-4.062-23.12-4.062C362.4 13.88 292.1 83.13 247.6 185zM521.5 60.51c6.25 16.25 10.75 34.62 13.13 55.25c5.75 49.87-1.376 108.1-18.88 166.9l102.6 37.37c10.13 3.75 21.25-3.375 21.5-14.12C642.3 210.1 598 118.4 521.5 60.51zM528 448h-207l65-178.5l-60.13-21.87l-72.88 200.4H48C21.49 448 0 469.5 0 496C0 504.8 7.163 512 16 512h544c8.837 0 16-7.163 16-15.1C576 469.5 554.5 448 528 448z\"\n ]\n};\nvar faUnderline = {\n prefix: 'fas',\n iconName: 'underline',\n icon: [\n 448,\n 512,\n [],\n \"f0cd\",\n \"M416 448H32c-17.69 0-32 14.31-32 32s14.31 32 32 32h384c17.69 0 32-14.31 32-32S433.7 448 416 448zM48 64.01H64v160c0 88.22 71.78 159.1 160 159.1s160-71.78 160-159.1v-160h16c17.69 0 32-14.32 32-32s-14.31-31.1-32-31.1l-96-.0049c-17.69 0-32 14.32-32 32s14.31 32 32 32H320v160c0 52.94-43.06 95.1-96 95.1S128 276.1 128 224v-160h16c17.69 0 32-14.31 32-32s-14.31-32-32-32l-96 .0049c-17.69 0-32 14.31-32 31.1S30.31 64.01 48 64.01z\"\n ]\n};\nvar faUniversalAccess = {\n prefix: 'fas',\n iconName: 'universal-access',\n icon: [\n 512,\n 512,\n [],\n \"f29a\",\n \"M256 0C114.6 0 0 114.6 0 256c0 141.4 114.6 256 256 256s256-114.6 256-256C512 114.6 397.4 0 256 0zM256 80c22.09 0 40 17.91 40 40S278.1 160 256 160S216 142.1 216 120S233.9 80 256 80zM374.6 215.1L315.3 232C311.6 233.1 307.8 233.6 304 234.4v62.32l30.64 87.34c4.391 12.5-2.188 26.19-14.69 30.59C317.3 415.6 314.6 416 312 416c-9.906 0-19.19-6.188-22.64-16.06l-25.85-70.65c-2.562-7.002-12.46-7.002-15.03 0l-25.85 70.65C219.2 409.8 209.9 416 200 416c-2.641 0-5.312-.4375-7.953-1.344c-12.5-4.406-19.08-18.09-14.69-30.59L208 296.7V234.4C204.2 233.6 200.4 233.1 196.7 232L137.4 215.1C124.7 211.4 117.3 198.2 120.9 185.4S137.9 165.2 150.6 168.9l59.25 16.94c30.17 8.623 62.15 8.623 92.31 0l59.25-16.94c12.7-3.781 26.02 3.719 29.67 16.47C394.7 198.2 387.3 211.4 374.6 215.1z\"\n ]\n};\nvar faUnlock = {\n prefix: 'fas',\n iconName: 'unlock',\n icon: [\n 448,\n 512,\n [\n 128275\n ],\n \"f09c\",\n \"M144 192H384C419.3 192 448 220.7 448 256V448C448 483.3 419.3 512 384 512H64C28.65 512 0 483.3 0 448V256C0 220.7 28.65 192 64 192H80V144C80 64.47 144.5 0 224 0C281.5 0 331 33.69 354.1 82.27C361.7 98.23 354.9 117.3 338.1 124.9C322.1 132.5 303.9 125.7 296.3 109.7C283.4 82.63 255.9 64 224 64C179.8 64 144 99.82 144 144L144 192z\"\n ]\n};\nvar faUnlockKeyhole = {\n prefix: 'fas',\n iconName: 'unlock-keyhole',\n icon: [\n 448,\n 512,\n [\n \"unlock-alt\"\n ],\n \"f13e\",\n \"M224 64C179.8 64 144 99.82 144 144V192H384C419.3 192 448 220.7 448 256V448C448 483.3 419.3 512 384 512H64C28.65 512 0 483.3 0 448V256C0 220.7 28.65 192 64 192H80V144C80 64.47 144.5 0 224 0C281.5 0 331 33.69 354.1 82.27C361.7 98.23 354.9 117.3 338.1 124.9C322.1 132.5 303.9 125.7 296.3 109.7C283.4 82.63 255.9 64 224 64H224zM256 384C273.7 384 288 369.7 288 352C288 334.3 273.7 320 256 320H192C174.3 320 160 334.3 160 352C160 369.7 174.3 384 192 384H256z\"\n ]\n};\nvar faUnlockAlt = faUnlockKeyhole;\nvar faUpDown = {\n prefix: 'fas',\n iconName: 'up-down',\n icon: [\n 256,\n 512,\n [\n 11021,\n 8597,\n \"arrows-alt-v\"\n ],\n \"f338\",\n \"M249.6 392.3l-104 112c-9.094 9.781-26.09 9.781-35.19 0l-103.1-112c-6.484-6.984-8.219-17.17-4.406-25.92S14.45 352 24 352H80V160H24C14.45 160 5.812 154.3 1.999 145.6C-1.813 136.8-.0781 126.7 6.406 119.7l104-112c9.094-9.781 26.09-9.781 35.19 0l104 112c6.484 6.984 8.219 17.17 4.406 25.92C250.2 154.3 241.5 160 232 160H176v192h56c9.547 0 18.19 5.656 22 14.41S256.1 385.3 249.6 392.3z\"\n ]\n};\nvar faArrowsAltV = faUpDown;\nvar faUpDownLeftRight = {\n prefix: 'fas',\n iconName: 'up-down-left-right',\n icon: [\n 512,\n 512,\n [\n \"arrows-alt\"\n ],\n \"f0b2\",\n \"M512 256c0 6.797-2.891 13.28-7.938 17.84l-80 72C419.6 349.9 413.8 352 408 352c-3.312 0-6.625-.6875-9.766-2.078C389.6 346.1 384 337.5 384 328V288h-96v96l40-.0013c9.484 0 18.06 5.578 21.92 14.23s2.25 18.78-4.078 25.83l-72 80C269.3 509.1 262.8 512 255.1 512s-13.28-2.89-17.84-7.937l-71.1-80c-6.328-7.047-7.938-17.17-4.078-25.83s12.44-14.23 21.92-14.23l39.1 .0013V288H128v40c0 9.484-5.578 18.06-14.23 21.92C110.6 351.3 107.3 352 104 352c-5.812 0-11.56-2.109-16.06-6.156l-80-72C2.891 269.3 0 262.8 0 256s2.891-13.28 7.938-17.84l80-72C95 159.8 105.1 158.3 113.8 162.1C122.4 165.9 128 174.5 128 184V224h95.1V128l-39.1-.0013c-9.484 0-18.06-5.578-21.92-14.23S159.8 94.99 166.2 87.94l71.1-80c9.125-10.09 26.56-10.09 35.69 0l72 80c6.328 7.047 7.938 17.17 4.078 25.83s-12.44 14.23-21.92 14.23l-40 .0013V224H384V184c0-9.484 5.578-18.06 14.23-21.92c8.656-3.812 18.77-2.266 25.83 4.078l80 72C509.1 242.7 512 249.2 512 256z\"\n ]\n};\nvar faArrowsAlt = faUpDownLeftRight;\nvar faUpLong = {\n prefix: 'fas',\n iconName: 'up-long',\n icon: [\n 320,\n 512,\n [\n \"long-arrow-alt-up\"\n ],\n \"f30c\",\n \"M285.1 145.7c-3.81 8.758-12.45 14.42-21.1 14.42L192 160.1V480c0 17.69-14.33 32-32 32s-32-14.31-32-32V160.1L55.1 160.1c-9.547 0-18.19-5.658-22-14.42c-3.811-8.758-2.076-18.95 4.408-25.94l104-112.1c9.498-10.24 25.69-10.24 35.19 0l104 112.1C288.1 126.7 289.8 136.9 285.1 145.7z\"\n ]\n};\nvar faLongArrowAltUp = faUpLong;\nvar faUpRightAndDownLeftFromCenter = {\n prefix: 'fas',\n iconName: 'up-right-and-down-left-from-center',\n icon: [\n 512,\n 512,\n [\n \"expand-alt\"\n ],\n \"f424\",\n \"M208 281.4c-12.5-12.5-32.76-12.5-45.26-.002l-78.06 78.07l-30.06-30.06c-6.125-6.125-14.31-9.367-22.63-9.367c-4.125 0-8.279 .7891-12.25 2.43c-11.97 4.953-19.75 16.62-19.75 29.56v135.1C.0013 501.3 10.75 512 24 512h136c12.94 0 24.63-7.797 29.56-19.75c4.969-11.97 2.219-25.72-6.938-34.87l-30.06-30.06l78.06-78.07c12.5-12.49 12.5-32.75 .002-45.25L208 281.4zM487.1 0h-136c-12.94 0-24.63 7.797-29.56 19.75c-4.969 11.97-2.219 25.72 6.938 34.87l30.06 30.06l-78.06 78.07c-12.5 12.5-12.5 32.76 0 45.26l22.62 22.62c12.5 12.5 32.76 12.5 45.26 0l78.06-78.07l30.06 30.06c9.156 9.141 22.87 11.84 34.87 6.937C504.2 184.6 512 172.9 512 159.1V23.1C512 10.74 501.3 0 487.1 0z\"\n ]\n};\nvar faExpandAlt = faUpRightAndDownLeftFromCenter;\nvar faUpRightFromSquare = {\n prefix: 'fas',\n iconName: 'up-right-from-square',\n icon: [\n 512,\n 512,\n [\n \"external-link-alt\"\n ],\n \"f35d\",\n \"M384 320c-17.67 0-32 14.33-32 32v96H64V160h96c17.67 0 32-14.32 32-32s-14.33-32-32-32L64 96c-35.35 0-64 28.65-64 64V448c0 35.34 28.65 64 64 64h288c35.35 0 64-28.66 64-64v-96C416 334.3 401.7 320 384 320zM488 0H352c-12.94 0-24.62 7.797-29.56 19.75c-4.969 11.97-2.219 25.72 6.938 34.88L370.8 96L169.4 297.4c-12.5 12.5-12.5 32.75 0 45.25C175.6 348.9 183.8 352 192 352s16.38-3.125 22.62-9.375L416 141.3l41.38 41.38c9.156 9.141 22.88 11.84 34.88 6.938C504.2 184.6 512 172.9 512 160V24C512 10.74 501.3 0 488 0z\"\n ]\n};\nvar faExternalLinkAlt = faUpRightFromSquare;\nvar faUpload = {\n prefix: 'fas',\n iconName: 'upload',\n icon: [\n 512,\n 512,\n [],\n \"f093\",\n \"M105.4 182.6c12.5 12.49 32.76 12.5 45.25 .001L224 109.3V352c0 17.67 14.33 32 32 32c17.67 0 32-14.33 32-32V109.3l73.38 73.38c12.49 12.49 32.75 12.49 45.25-.001c12.49-12.49 12.49-32.75 0-45.25l-128-128C272.4 3.125 264.2 0 256 0S239.6 3.125 233.4 9.375L105.4 137.4C92.88 149.9 92.88 170.1 105.4 182.6zM480 352h-160c0 35.35-28.65 64-64 64s-64-28.65-64-64H32c-17.67 0-32 14.33-32 32v96c0 17.67 14.33 32 32 32h448c17.67 0 32-14.33 32-32v-96C512 366.3 497.7 352 480 352zM432 456c-13.2 0-24-10.8-24-24c0-13.2 10.8-24 24-24s24 10.8 24 24C456 445.2 445.2 456 432 456z\"\n ]\n};\nvar faUser = {\n prefix: 'fas',\n iconName: 'user',\n icon: [\n 448,\n 512,\n [\n 62144,\n 128100\n ],\n \"f007\",\n \"M224 256c70.7 0 128-57.31 128-128s-57.3-128-128-128C153.3 0 96 57.31 96 128S153.3 256 224 256zM274.7 304H173.3C77.61 304 0 381.6 0 477.3c0 19.14 15.52 34.67 34.66 34.67h378.7C432.5 512 448 496.5 448 477.3C448 381.6 370.4 304 274.7 304z\"\n ]\n};\nvar faUserAstronaut = {\n prefix: 'fas',\n iconName: 'user-astronaut',\n icon: [\n 448,\n 512,\n [],\n \"f4fb\",\n \"M176 448C167.3 448 160 455.3 160 464V512h32v-48C192 455.3 184.8 448 176 448zM272 448c-8.75 0-16 7.25-16 16s7.25 16 16 16s16-7.25 16-16S280.8 448 272 448zM164 172l8.205 24.62c1.215 3.645 6.375 3.645 7.59 0L188 172l24.62-8.203c3.646-1.219 3.646-6.375 0-7.594L188 148L179.8 123.4c-1.215-3.648-6.375-3.648-7.59 0L164 148L139.4 156.2c-3.646 1.219-3.646 6.375 0 7.594L164 172zM336.1 315.4C304 338.6 265.1 352 224 352s-80.03-13.43-112.1-36.59C46.55 340.2 0 403.3 0 477.3C0 496.5 15.52 512 34.66 512H128v-64c0-17.75 14.25-32 32-32h128c17.75 0 32 14.25 32 32v64h93.34C432.5 512 448 496.5 448 477.3C448 403.3 401.5 340.2 336.1 315.4zM64 224h13.5C102.3 280.5 158.4 320 224 320s121.8-39.5 146.5-96H384c8.75 0 16-7.25 16-16v-96C400 103.3 392.8 96 384 96h-13.5C345.8 39.5 289.6 0 224 0S102.3 39.5 77.5 96H64C55.25 96 48 103.3 48 112v96C48 216.8 55.25 224 64 224zM104 136C104 113.9 125.5 96 152 96h144c26.5 0 48 17.88 48 40V160c0 53-43 96-96 96h-48c-53 0-96-43-96-96V136z\"\n ]\n};\nvar faUserCheck = {\n prefix: 'fas',\n iconName: 'user-check',\n icon: [\n 640,\n 512,\n [],\n \"f4fc\",\n \"M274.7 304H173.3C77.61 304 0 381.6 0 477.3C0 496.5 15.52 512 34.66 512H413.3C432.5 512 448 496.5 448 477.3C448 381.6 370.4 304 274.7 304zM224 256c70.7 0 128-57.31 128-128S294.7 0 224 0C153.3 0 96 57.31 96 128S153.3 256 224 256zM632.3 134.4c-9.703-9-24.91-8.453-33.92 1.266l-87.05 93.75l-38.39-38.39c-9.375-9.375-24.56-9.375-33.94 0s-9.375 24.56 0 33.94l56 56C499.5 285.5 505.6 288 512 288h.4375c6.531-.125 12.72-2.891 17.16-7.672l104-112C642.6 158.6 642 143.4 632.3 134.4z\"\n ]\n};\nvar faUserClock = {\n prefix: 'fas',\n iconName: 'user-clock',\n icon: [\n 640,\n 512,\n [],\n \"f4fd\",\n \"M496 224c-79.63 0-144 64.38-144 144s64.38 144 144 144s144-64.38 144-144S575.6 224 496 224zM544 384h-54.25C484.4 384 480 379.6 480 374.3V304c0-8.836 7.164-16 16-16c8.838 0 16 7.164 16 16v48h32c8.838 0 16 7.164 16 15.1S552.8 384 544 384zM224 256c70.7 0 128-57.31 128-128S294.7 0 224 0C153.3 0 96 57.31 96 128S153.3 256 224 256zM320 368c0-19.3 3.221-37.82 8.961-55.2C311.9 307.2 293.6 304 274.7 304H173.3C77.61 304 0 381.7 0 477.4C0 496.5 15.52 512 34.66 512H395C349.7 480.2 320 427.6 320 368z\"\n ]\n};\nvar faUserDoctor = {\n prefix: 'fas',\n iconName: 'user-doctor',\n icon: [\n 448,\n 512,\n [\n \"user-md\"\n ],\n \"f0f0\",\n \"M352 128C352 198.7 294.7 256 223.1 256C153.3 256 95.1 198.7 95.1 128C95.1 57.31 153.3 0 223.1 0C294.7 0 352 57.31 352 128zM287.1 362C260.4 369.1 239.1 394.2 239.1 424V448C239.1 452.2 241.7 456.3 244.7 459.3L260.7 475.3C266.9 481.6 277.1 481.6 283.3 475.3C289.6 469.1 289.6 458.9 283.3 452.7L271.1 441.4V424C271.1 406.3 286.3 392 303.1 392C321.7 392 336 406.3 336 424V441.4L324.7 452.7C318.4 458.9 318.4 469.1 324.7 475.3C330.9 481.6 341.1 481.6 347.3 475.3L363.3 459.3C366.3 456.3 368 452.2 368 448V424C368 394.2 347.6 369.1 320 362V308.8C393.5 326.7 448 392.1 448 472V480C448 497.7 433.7 512 416 512H32C14.33 512 0 497.7 0 480V472C0 393 54.53 326.7 128 308.8V370.3C104.9 377.2 88 398.6 88 424C88 454.9 113.1 480 144 480C174.9 480 200 454.9 200 424C200 398.6 183.1 377.2 160 370.3V304.2C162.7 304.1 165.3 304 168 304H280C282.7 304 285.3 304.1 288 304.2L287.1 362zM167.1 424C167.1 437.3 157.3 448 143.1 448C130.7 448 119.1 437.3 119.1 424C119.1 410.7 130.7 400 143.1 400C157.3 400 167.1 410.7 167.1 424z\"\n ]\n};\nvar faUserMd = faUserDoctor;\nvar faUserGear = {\n prefix: 'fas',\n iconName: 'user-gear',\n icon: [\n 640,\n 512,\n [\n \"user-cog\"\n ],\n \"f4fe\",\n \"M425.1 482.6c-2.303-1.25-4.572-2.559-6.809-3.93l-7.818 4.493c-6.002 3.504-12.83 5.352-19.75 5.352c-10.71 0-21.13-4.492-28.97-12.75c-18.41-20.09-32.29-44.15-40.22-69.9c-5.352-18.06 2.343-36.87 17.83-45.24l8.018-4.669c-.0664-2.621-.0664-5.242 0-7.859l-7.655-4.461c-12.3-6.953-19.4-19.66-19.64-33.38C305.6 306.3 290.4 304 274.7 304H173.3C77.61 304 0 381.7 0 477.4C0 496.5 15.52 512 34.66 512H413.3c5.727 0 10.9-1.727 15.66-4.188c-2.271-4.984-3.86-10.3-3.86-16.06V482.6zM224 256c70.7 0 128-57.31 128-128S294.7 0 224 0C153.3 0 96 57.31 96 128S153.3 256 224 256zM610.5 373.3c2.625-14 2.625-28.5 0-42.5l25.75-15c3-1.625 4.375-5.125 3.375-8.5c-6.75-21.5-18.25-41.13-33.25-57.38c-2.25-2.5-6-3.125-9-1.375l-25.75 14.88c-10.88-9.25-23.38-16.5-36.88-21.25V212.3c0-3.375-2.5-6.375-5.75-7c-22.25-5-45-4.875-66.25 0c-3.25 .625-5.625 3.625-5.625 7v29.88c-13.5 4.75-26 12-36.88 21.25L394.4 248.5c-2.875-1.75-6.625-1.125-9 1.375c-15 16.25-26.5 35.88-33.13 57.38c-1 3.375 .3751 6.875 3.25 8.5l25.75 15c-2.5 14-2.5 28.5 0 42.5l-25.75 15c-3 1.625-4.25 5.125-3.25 8.5c6.625 21.5 18.13 41 33.13 57.38c2.375 2.5 6 3.125 9 1.375l25.88-14.88c10.88 9.25 23.38 16.5 36.88 21.25v29.88c0 3.375 2.375 6.375 5.625 7c22.38 5 45 4.875 66.25 0c3.25-.625 5.75-3.625 5.75-7v-29.88c13.5-4.75 26-12 36.88-21.25l25.75 14.88c2.875 1.75 6.75 1.125 9-1.375c15-16.25 26.5-35.88 33.25-57.38c1-3.375-.3751-6.875-3.375-8.5L610.5 373.3zM496 400.5c-26.75 0-48.5-21.75-48.5-48.5s21.75-48.5 48.5-48.5c26.75 0 48.5 21.75 48.5 48.5S522.8 400.5 496 400.5z\"\n ]\n};\nvar faUserCog = faUserGear;\nvar faUserGraduate = {\n prefix: 'fas',\n iconName: 'user-graduate',\n icon: [\n 512,\n 512,\n [],\n \"f501\",\n \"M45.63 79.75L52 81.25v58.5C45 143.9 40 151.3 40 160c0 8.375 4.625 15.38 11.12 19.75L35.5 242C33.75 248.9 37.63 256 43.13 256h41.75c5.5 0 9.375-7.125 7.625-13.1L76.88 179.8C83.38 175.4 88 168.4 88 160c0-8.75-5-16.12-12-20.25V87.13L128 99.63l.001 60.37c0 70.75 57.25 128 128 128s127.1-57.25 127.1-128L384 99.62l82.25-19.87c18.25-4.375 18.25-27 0-31.5l-190.4-46c-13-3-26.62-3-39.63 0l-190.6 46C27.5 52.63 27.5 75.38 45.63 79.75zM359.2 312.8l-103.2 103.2l-103.2-103.2c-69.93 22.3-120.8 87.2-120.8 164.5C32 496.5 47.53 512 66.67 512h378.7C464.5 512 480 496.5 480 477.3C480 400 429.1 335.1 359.2 312.8z\"\n ]\n};\nvar faUserGroup = {\n prefix: 'fas',\n iconName: 'user-group',\n icon: [\n 640,\n 512,\n [\n 128101,\n \"user-friends\"\n ],\n \"f500\",\n \"M224 256c70.7 0 128-57.31 128-128S294.7 0 224 0C153.3 0 96 57.31 96 128S153.3 256 224 256zM274.7 304H173.3c-95.73 0-173.3 77.6-173.3 173.3C0 496.5 15.52 512 34.66 512H413.3C432.5 512 448 496.5 448 477.3C448 381.6 370.4 304 274.7 304zM479.1 320h-73.85C451.2 357.7 480 414.1 480 477.3C480 490.1 476.2 501.9 470 512h138C625.7 512 640 497.6 640 479.1C640 391.6 568.4 320 479.1 320zM432 256C493.9 256 544 205.9 544 144S493.9 32 432 32c-25.11 0-48.04 8.555-66.72 22.51C376.8 76.63 384 101.4 384 128c0 35.52-11.93 68.14-31.59 94.71C372.7 243.2 400.8 256 432 256z\"\n ]\n};\nvar faUserFriends = faUserGroup;\nvar faUserInjured = {\n prefix: 'fas',\n iconName: 'user-injured',\n icon: [\n 448,\n 512,\n [],\n \"f728\",\n \"M277.4 11.98C261.1 4.469 243.1 0 224 0C170.3 0 124.5 33.13 105.5 80h81.07L277.4 11.98zM342.5 80c-7.895-19.47-20.66-36.19-36.48-49.51L240 80H342.5zM224 256c70.7 0 128-57.31 128-128c0-5.48-.9453-10.7-1.613-16H97.61C96.95 117.3 96 122.5 96 128C96 198.7 153.3 256 224 256zM272 416h-45.14l58.64 93.83C305.4 503.1 320 485.8 320 464C320 437.5 298.5 416 272 416zM274.7 304H173.3c-5.393 0-10.71 .3242-15.98 .8047L206.9 384H272c44.13 0 80 35.88 80 80c0 18.08-6.252 34.59-16.4 48h77.73C432.5 512 448 496.5 448 477.3C448 381.6 370.4 304 274.7 304zM0 477.3C0 496.5 15.52 512 34.66 512H64v-169.1C24.97 374.7 0 423.1 0 477.3zM96 322.4V512h153.1L123.7 311.3C114.1 314.2 104.8 317.9 96 322.4z\"\n ]\n};\nvar faUserLarge = {\n prefix: 'fas',\n iconName: 'user-large',\n icon: [\n 512,\n 512,\n [\n \"user-alt\"\n ],\n \"f406\",\n \"M256 288c79.53 0 144-64.47 144-144s-64.47-144-144-144c-79.52 0-144 64.47-144 144S176.5 288 256 288zM351.1 320H160c-88.36 0-160 71.63-160 160c0 17.67 14.33 32 31.1 32H480c17.67 0 31.1-14.33 31.1-32C512 391.6 440.4 320 351.1 320z\"\n ]\n};\nvar faUserAlt = faUserLarge;\nvar faUserLargeSlash = {\n prefix: 'fas',\n iconName: 'user-large-slash',\n icon: [\n 640,\n 512,\n [\n \"user-alt-slash\"\n ],\n \"f4fa\",\n \"M284.9 320l-60.9-.0002c-88.36 0-160 71.63-160 159.1C63.1 497.7 78.33 512 95.1 512l448-.0039c.0137 0-.0137 0 0 0l-14.13-.0013L284.9 320zM630.8 469.1l-249.5-195.5c48.74-22.1 82.65-72.1 82.65-129.6c0-79.53-64.47-143.1-143.1-143.1c-69.64 0-127.3 49.57-140.6 115.3L38.81 5.109C34.41 1.672 29.19 0 24.03 0C16.91 0 9.845 3.156 5.127 9.187c-8.187 10.44-6.375 25.53 4.062 33.7L601.2 506.9c10.5 8.203 25.56 6.328 33.69-4.078C643.1 492.4 641.2 477.3 630.8 469.1z\"\n ]\n};\nvar faUserAltSlash = faUserLargeSlash;\nvar faUserLock = {\n prefix: 'fas',\n iconName: 'user-lock',\n icon: [\n 640,\n 512,\n [],\n \"f502\",\n \"M592 288H576V212.7c0-41.84-30.03-80.04-71.66-84.27C456.5 123.6 416 161.1 416 208V288h-16C373.6 288 352 309.6 352 336v128c0 26.4 21.6 48 48 48h192c26.4 0 48-21.6 48-48v-128C640 309.6 618.4 288 592 288zM496 432c-17.62 0-32-14.38-32-32s14.38-32 32-32s32 14.38 32 32S513.6 432 496 432zM528 288h-64V208c0-17.62 14.38-32 32-32s32 14.38 32 32V288zM224 256c70.7 0 128-57.31 128-128S294.7 0 224 0C153.3 0 96 57.31 96 128S153.3 256 224 256zM320 336c0-8.672 1.738-16.87 4.303-24.7C308.6 306.6 291.9 304 274.7 304H173.3C77.61 304 0 381.7 0 477.4C0 496.5 15.52 512 34.66 512h301.7C326.3 498.6 320 482.1 320 464V336z\"\n ]\n};\nvar faUserMinus = {\n prefix: 'fas',\n iconName: 'user-minus',\n icon: [\n 640,\n 512,\n [],\n \"f503\",\n \"M274.7 304H173.3C77.61 304 0 381.6 0 477.3C0 496.5 15.52 512 34.66 512h378.7C432.5 512 448 496.5 448 477.3C448 381.6 370.4 304 274.7 304zM224 256c70.7 0 128-57.31 128-128S294.7 0 224 0C153.3 0 96 57.31 96 128S153.3 256 224 256zM616 200h-144C458.8 200 448 210.8 448 224s10.75 24 24 24h144C629.3 248 640 237.3 640 224S629.3 200 616 200z\"\n ]\n};\nvar faUserNinja = {\n prefix: 'fas',\n iconName: 'user-ninja',\n icon: [\n 512,\n 512,\n [\n 129399\n ],\n \"f504\",\n \"M64 192c27.25 0 51.75-11.5 69.25-29.75c15 54 64 93.75 122.8 93.75c70.75 0 127.1-57.25 127.1-128s-57.25-128-127.1-128c-50.38 0-93.63 29.38-114.5 71.75C124.1 47.75 96 32 64 32c0 33.37 17.12 62.75 43.13 80C81.13 129.3 64 158.6 64 192zM208 96h95.1C321.7 96 336 110.3 336 128h-160C176 110.3 190.3 96 208 96zM337.8 306.9L256 416L174.2 306.9C93.36 321.6 32 392.2 32 477.3c0 19.14 15.52 34.67 34.66 34.67H445.3c19.14 0 34.66-15.52 34.66-34.67C480 392.2 418.6 321.6 337.8 306.9z\"\n ]\n};\nvar faUserNurse = {\n prefix: 'fas',\n iconName: 'user-nurse',\n icon: [\n 448,\n 512,\n [],\n \"f82f\",\n \"M224 304c70.75 0 128-57.25 128-128V65.88c0-13.38-8.25-25.38-20.75-30L246.5 4.125C239.3 1.375 231.6 0 224 0S208.8 1.375 201.5 4.125L116.8 35.88C104.3 40.5 96 52.5 96 65.88V176C96 246.8 153.3 304 224 304zM184 71.63c0-2.75 2.25-5 5-5h21.62V45c0-2.75 2.25-5 5-5h16.75c2.75 0 5 2.25 5 5v21.62H259c2.75 0 5 2.25 5 5v16.75c0 2.75-2.25 5-5 5h-21.62V115c0 2.75-2.25 5-5 5H215.6c-2.75 0-5-2.25-5-5V93.38H189c-2.75 0-5-2.25-5-5V71.63zM144 160h160v16C304 220.1 268.1 256 224 256S144 220.1 144 176V160zM327.2 312.8L224 416L120.8 312.8c-69.93 22.3-120.8 87.25-120.8 164.6C.0006 496.5 15.52 512 34.66 512H413.3c19.14 0 34.66-15.46 34.66-34.61C447.1 400.1 397.1 335.1 327.2 312.8z\"\n ]\n};\nvar faUserPen = {\n prefix: 'fas',\n iconName: 'user-pen',\n icon: [\n 640,\n 512,\n [\n \"user-edit\"\n ],\n \"f4ff\",\n \"M223.1 256c70.7 0 128-57.31 128-128s-57.3-128-128-128C153.3 0 96 57.31 96 128S153.3 256 223.1 256zM274.7 304H173.3C77.61 304 0 381.7 0 477.4C0 496.5 15.52 512 34.66 512h286.4c-1.246-5.531-1.43-11.31-.2832-17.04l14.28-71.41c1.943-9.723 6.676-18.56 13.68-25.56l45.72-45.72C363.3 322.4 321.2 304 274.7 304zM371.4 420.6c-2.514 2.512-4.227 5.715-4.924 9.203l-14.28 71.41c-1.258 6.289 4.293 11.84 10.59 10.59l71.42-14.29c3.482-.6992 6.682-2.406 9.195-4.922l125.3-125.3l-72.01-72.01L371.4 420.6zM629.5 255.7l-21.1-21.11c-14.06-14.06-36.85-14.06-50.91 0l-38.13 38.14l72.01 72.01l38.13-38.13C643.5 292.5 643.5 269.7 629.5 255.7z\"\n ]\n};\nvar faUserEdit = faUserPen;\nvar faUserPlus = {\n prefix: 'fas',\n iconName: 'user-plus',\n icon: [\n 640,\n 512,\n [],\n \"f234\",\n \"M224 256c70.7 0 128-57.31 128-128S294.7 0 224 0C153.3 0 96 57.31 96 128S153.3 256 224 256zM274.7 304H173.3C77.61 304 0 381.6 0 477.3C0 496.5 15.52 512 34.66 512h378.7C432.5 512 448 496.5 448 477.3C448 381.6 370.4 304 274.7 304zM616 200h-48v-48C568 138.8 557.3 128 544 128s-24 10.75-24 24v48h-48C458.8 200 448 210.8 448 224s10.75 24 24 24h48v48C520 309.3 530.8 320 544 320s24-10.75 24-24v-48h48C629.3 248 640 237.3 640 224S629.3 200 616 200z\"\n ]\n};\nvar faUserSecret = {\n prefix: 'fas',\n iconName: 'user-secret',\n icon: [\n 448,\n 512,\n [\n 128373\n ],\n \"f21b\",\n \"M377.7 338.8l37.15-92.87C419 235.4 411.3 224 399.1 224h-57.48C348.5 209.2 352 193 352 176c0-4.117-.8359-8.057-1.217-12.08C390.7 155.1 416 142.3 416 128c0-16.08-31.75-30.28-80.31-38.99C323.8 45.15 304.9 0 277.4 0c-10.38 0-19.62 4.5-27.38 10.5c-15.25 11.88-36.75 11.88-52 0C190.3 4.5 181.1 0 170.7 0C143.2 0 124.4 45.16 112.5 88.98C63.83 97.68 32 111.9 32 128c0 14.34 25.31 27.13 65.22 35.92C96.84 167.9 96 171.9 96 176C96 193 99.47 209.2 105.5 224H48.02C36.7 224 28.96 235.4 33.16 245.9l37.15 92.87C27.87 370.4 0 420.4 0 477.3C0 496.5 15.52 512 34.66 512H413.3C432.5 512 448 496.5 448 477.3C448 420.4 420.1 370.4 377.7 338.8zM176 479.1L128 288l64 32l16 32L176 479.1zM271.1 479.1L240 352l16-32l64-32L271.1 479.1zM320 186C320 207 302.8 224 281.6 224h-12.33c-16.46 0-30.29-10.39-35.63-24.99C232.1 194.9 228.4 192 224 192S215.9 194.9 214.4 199C209 213.6 195.2 224 178.8 224h-12.33C145.2 224 128 207 128 186V169.5C156.3 173.6 188.1 176 224 176s67.74-2.383 96-6.473V186z\"\n ]\n};\nvar faUserShield = {\n prefix: 'fas',\n iconName: 'user-shield',\n icon: [\n 640,\n 512,\n [],\n \"f505\",\n \"M622.3 271.1l-115.1-45.01c-4.125-1.629-12.62-3.754-22.25 0L369.8 271.1C359 275.2 352 285.1 352 295.1c0 111.6 68.75 188.8 132.9 213.9c9.625 3.75 18 1.625 22.25 0C558.4 489.9 640 420.5 640 295.1C640 285.1 633 275.2 622.3 271.1zM496 462.4V273.2l95.5 37.38C585.9 397.8 530.6 446 496 462.4zM224 256c70.7 0 128-57.31 128-128S294.7 0 224 0C153.3 0 96 57.31 96 128S153.3 256 224 256zM320.6 310.3C305.9 306.3 290.6 304 274.7 304H173.3C77.61 304 0 381.7 0 477.4C0 496.5 15.52 512 34.66 512H413.3c3.143 0 5.967-1.004 8.861-1.789C369.7 469.8 324.1 400.3 320.6 310.3z\"\n ]\n};\nvar faUserSlash = {\n prefix: 'fas',\n iconName: 'user-slash',\n icon: [\n 640,\n 512,\n [],\n \"f506\",\n \"M95.1 477.3c0 19.14 15.52 34.67 34.66 34.67h378.7c5.625 0 10.73-1.65 15.42-4.029L264.9 304.3C171.3 306.7 95.1 383.1 95.1 477.3zM630.8 469.1l-277.1-217.9c54.69-14.56 95.18-63.95 95.18-123.2C447.1 57.31 390.7 0 319.1 0C250.2 0 193.7 55.93 192.3 125.4l-153.4-120.3C34.41 1.672 29.19 0 24.03 0C16.91 0 9.845 3.156 5.127 9.187c-8.187 10.44-6.375 25.53 4.062 33.7L601.2 506.9c10.5 8.203 25.56 6.328 33.69-4.078C643.1 492.4 641.2 477.3 630.8 469.1z\"\n ]\n};\nvar faUserTag = {\n prefix: 'fas',\n iconName: 'user-tag',\n icon: [\n 640,\n 512,\n [],\n \"f507\",\n \"M351.8 367.3v-44.1C328.5 310.7 302.4 304 274.7 304H173.3c-95.73 0-173.3 77.65-173.3 173.4C.0005 496.5 15.52 512 34.66 512h378.7c11.86 0 21.82-6.337 28.07-15.43l-61.65-61.57C361.7 416.9 351.8 392.9 351.8 367.3zM224 256c70.7 0 128-57.31 128-128S294.7 0 224 0C153.3 0 96 57.31 96 128S153.3 256 224 256zM630.6 364.8L540.3 274.8C528.3 262.8 512 256 495 256h-79.23c-17.75 0-31.99 14.25-31.99 32l.0147 79.2c0 17 6.647 33.15 18.65 45.15l90.31 90.27c12.5 12.5 32.74 12.5 45.24 0l92.49-92.5C643.1 397.6 643.1 377.3 630.6 364.8zM447.8 343.9c-13.25 0-24-10.62-24-24c0-13.25 10.75-24 24-24c13.38 0 24 10.75 24 24S461.1 343.9 447.8 343.9z\"\n ]\n};\nvar faUserTie = {\n prefix: 'fas',\n iconName: 'user-tie',\n icon: [\n 448,\n 512,\n [],\n \"f508\",\n \"M352 128C352 198.7 294.7 256 224 256C153.3 256 96 198.7 96 128C96 57.31 153.3 0 224 0C294.7 0 352 57.31 352 128zM209.1 359.2L176 304H272L238.9 359.2L272.2 483.1L311.7 321.9C388.9 333.9 448 400.7 448 481.3C448 498.2 434.2 512 417.3 512H30.72C13.75 512 0 498.2 0 481.3C0 400.7 59.09 333.9 136.3 321.9L175.8 483.1L209.1 359.2z\"\n ]\n};\nvar faUserXmark = {\n prefix: 'fas',\n iconName: 'user-xmark',\n icon: [\n 640,\n 512,\n [\n \"user-times\"\n ],\n \"f235\",\n \"M274.7 304H173.3C77.61 304 0 381.6 0 477.3C0 496.5 15.52 512 34.66 512h378.7C432.5 512 448 496.5 448 477.3C448 381.6 370.4 304 274.7 304zM224 256c70.7 0 128-57.31 128-128S294.7 0 224 0C153.3 0 96 57.31 96 128S153.3 256 224 256zM577.9 223.1l47.03-47.03c9.375-9.375 9.375-24.56 0-33.94s-24.56-9.375-33.94 0L544 190.1l-47.03-47.03c-9.375-9.375-24.56-9.375-33.94 0s-9.375 24.56 0 33.94l47.03 47.03l-47.03 47.03c-9.375 9.375-9.375 24.56 0 33.94c9.373 9.373 24.56 9.381 33.94 0L544 257.9l47.03 47.03c9.373 9.373 24.56 9.381 33.94 0c9.375-9.375 9.375-24.56 0-33.94L577.9 223.1z\"\n ]\n};\nvar faUserTimes = faUserXmark;\nvar faUsers = {\n prefix: 'fas',\n iconName: 'users',\n icon: [\n 640,\n 512,\n [],\n \"f0c0\",\n \"M319.9 320c57.41 0 103.1-46.56 103.1-104c0-57.44-46.54-104-103.1-104c-57.41 0-103.1 46.56-103.1 104C215.9 273.4 262.5 320 319.9 320zM369.9 352H270.1C191.6 352 128 411.7 128 485.3C128 500.1 140.7 512 156.4 512h327.2C499.3 512 512 500.1 512 485.3C512 411.7 448.4 352 369.9 352zM512 160c44.18 0 80-35.82 80-80S556.2 0 512 0c-44.18 0-80 35.82-80 80S467.8 160 512 160zM183.9 216c0-5.449 .9824-10.63 1.609-15.91C174.6 194.1 162.6 192 149.9 192H88.08C39.44 192 0 233.8 0 285.3C0 295.6 7.887 304 17.62 304h199.5C196.7 280.2 183.9 249.7 183.9 216zM128 160c44.18 0 80-35.82 80-80S172.2 0 128 0C83.82 0 48 35.82 48 80S83.82 160 128 160zM551.9 192h-61.84c-12.8 0-24.88 3.037-35.86 8.24C454.8 205.5 455.8 210.6 455.8 216c0 33.71-12.78 64.21-33.16 88h199.7C632.1 304 640 295.6 640 285.3C640 233.8 600.6 192 551.9 192z\"\n ]\n};\nvar faUsersGear = {\n prefix: 'fas',\n iconName: 'users-gear',\n icon: [\n 640,\n 512,\n [\n \"users-cog\"\n ],\n \"f509\",\n \"M512 160c44.18 0 80-35.82 80-80S556.2 0 512 0c-44.18 0-80 35.82-80 80S467.8 160 512 160zM128 160c44.18 0 80-35.82 80-80S172.2 0 128 0C83.82 0 48 35.82 48 80S83.82 160 128 160zM319.9 320c57.41 0 103.1-46.56 103.1-104c0-57.44-46.54-104-103.1-104c-57.41 0-103.1 46.56-103.1 104C215.9 273.4 262.5 320 319.9 320zM368 400c0-16.69 3.398-32.46 8.619-47.36C374.3 352.5 372.2 352 369.9 352H270.1C191.6 352 128 411.7 128 485.3C128 500.1 140.7 512 156.4 512h266.1C389.5 485.6 368 445.5 368 400zM183.9 216c0-5.449 .9824-10.63 1.609-15.91C174.6 194.1 162.6 192 149.9 192H88.08C39.44 192 0 233.8 0 285.3C0 295.6 7.887 304 17.62 304h199.5C196.7 280.2 183.9 249.7 183.9 216zM551.9 192h-61.84c-12.8 0-24.88 3.037-35.86 8.24C454.8 205.5 455.8 210.6 455.8 216c0 21.47-5.625 41.38-14.65 59.34C462.2 263.4 486.1 256 512 256c42.48 0 80.27 18.74 106.6 48h3.756C632.1 304 640 295.6 640 285.3C640 233.8 600.6 192 551.9 192zM618.1 366.7c-5.025-16.01-13.59-30.62-24.75-42.71c-1.674-1.861-4.467-2.326-6.699-1.023l-19.17 11.07c-8.096-6.887-17.4-12.28-27.45-15.82V295.1c0-2.514-1.861-4.746-4.281-5.213c-16.56-3.723-33.5-3.629-49.32 0C484.9 291.2 483.1 293.5 483.1 295.1v22.24c-10.05 3.537-19.36 8.932-27.45 15.82l-19.26-11.07c-2.139-1.303-4.932-.8379-6.697 1.023c-11.17 12.1-19.73 26.71-24.66 42.71c-.7441 2.512 .2793 5.117 2.42 6.326l19.17 11.17c-1.859 10.42-1.859 21.21 0 31.64l-19.17 11.17c-2.234 1.209-3.164 3.816-2.42 6.328c4.932 16.01 13.49 30.52 24.66 42.71c1.766 1.863 4.467 2.328 6.697 1.025l19.26-11.07c8.094 6.887 17.4 12.28 27.45 15.82v22.24c0 2.514 1.77 4.746 4.188 5.211c16.66 3.723 33.5 3.629 49.32 0c2.42-.4648 4.281-2.697 4.281-5.211v-22.24c10.05-3.535 19.36-8.932 27.45-15.82l19.17 11.07c2.141 1.303 5.025 .8379 6.699-1.025c11.17-12.1 19.73-26.7 24.75-42.71c.7441-2.512-.2773-5.119-2.512-6.328l-19.17-11.17c1.953-10.42 1.953-21.22 0-31.64l19.17-11.17C618.7 371.8 619.7 369.2 618.1 366.7zM512 432c-17.67 0-32-14.33-32-32c0-17.67 14.33-32 32-32s32 14.33 32 32C544 417.7 529.7 432 512 432z\"\n ]\n};\nvar faUsersCog = faUsersGear;\nvar faUsersSlash = {\n prefix: 'fas',\n iconName: 'users-slash',\n icon: [\n 640,\n 512,\n [],\n \"e073\",\n \"M512 160c44.18 0 80-35.82 80-80S556.2 0 512 0c-44.18 0-80 35.82-80 80S467.8 160 512 160zM490.1 192c-12.8 0-24.88 3.037-35.86 8.24C454.8 205.5 455.8 210.6 455.8 216c0 33.71-12.78 64.21-33.16 88h199.7C632.1 304 640 295.6 640 285.3C640 233.8 600.6 192 551.9 192H490.1zM396.6 285.5C413.4 267.2 423.8 242.9 423.8 216c0-57.44-46.54-104-103.1-104c-35.93 0-67.07 18.53-85.59 46.3L193.1 126.1C202.4 113.1 208 97.24 208 80C208 35.82 172.2 0 128 0C103.8 0 82.52 10.97 67.96 27.95L38.81 5.109C34.41 1.672 29.19 0 24.03 0C16.91 0 9.846 3.156 5.127 9.188C-3.061 19.62-1.248 34.72 9.189 42.89l591.1 463.1c10.5 8.203 25.56 6.328 33.69-4.078c8.188-10.44 6.375-25.53-4.062-33.7L396.6 285.5zM270.1 352C191.6 352 128 411.7 128 485.3C128 500.1 140.7 512 156.4 512h327.2c11.62 0 21.54-6.583 25.95-15.96L325.7 352H270.1zM186.1 243.2L121.6 192H88.08C39.44 192 0 233.8 0 285.3C0 295.6 7.887 304 17.62 304h199.5C202.4 286.8 191.8 266.1 186.1 243.2z\"\n ]\n};\nvar faUtensils = {\n prefix: 'fas',\n iconName: 'utensils',\n icon: [\n 448,\n 512,\n [\n 61685,\n 127860,\n \"cutlery\"\n ],\n \"f2e7\",\n \"M221.6 148.7C224.7 161.3 224.8 174.5 222.1 187.2C219.3 199.1 213.6 211.9 205.6 222.1C191.1 238.6 173 249.1 151.1 254.1V472C151.1 482.6 147.8 492.8 140.3 500.3C132.8 507.8 122.6 512 111.1 512C101.4 512 91.22 507.8 83.71 500.3C76.21 492.8 71.1 482.6 71.1 472V254.1C50.96 250.1 31.96 238.9 18.3 222.4C10.19 212.2 4.529 200.3 1.755 187.5C-1.019 174.7-.8315 161.5 2.303 148.8L32.51 12.45C33.36 8.598 35.61 5.197 38.82 2.9C42.02 .602 45.97-.4297 49.89 .0026C53.82 .4302 57.46 2.303 60.1 5.259C62.74 8.214 64.18 12.04 64.16 16V160H81.53L98.62 11.91C99.02 8.635 100.6 5.621 103.1 3.434C105.5 1.248 108.7 .0401 111.1 .0401C115.3 .0401 118.5 1.248 120.9 3.434C123.4 5.621 124.1 8.635 125.4 11.91L142.5 160H159.1V16C159.1 12.07 161.4 8.268 163.1 5.317C166.6 2.366 170.2 .474 174.1 .0026C178-.4262 181.1 .619 185.2 2.936C188.4 5.253 190.6 8.677 191.5 12.55L221.6 148.7zM448 472C448 482.6 443.8 492.8 436.3 500.3C428.8 507.8 418.6 512 408 512C397.4 512 387.2 507.8 379.7 500.3C372.2 492.8 368 482.6 368 472V352H351.2C342.8 352 334.4 350.3 326.6 347.1C318.9 343.8 311.8 339.1 305.8 333.1C299.9 327.1 295.2 320 291.1 312.2C288.8 304.4 287.2 296 287.2 287.6L287.1 173.8C288 136.9 299.1 100.8 319.8 70.28C340.5 39.71 369.8 16.05 404.1 2.339C408.1 .401 414.2-.3202 419.4 .2391C424.6 .7982 429.6 2.62 433.9 5.546C438.2 8.472 441.8 12.41 444.2 17.03C446.7 21.64 447.1 26.78 448 32V472z\"\n ]\n};\nvar faCutlery = faUtensils;\nvar faV = {\n prefix: 'fas',\n iconName: 'v',\n icon: [\n 384,\n 512,\n [\n 118\n ],\n \"56\",\n \"M381.5 76.33l-160 384C216.6 472.2 204.9 480 192 480s-24.56-7.757-29.53-19.68l-160-384c-6.797-16.31 .9062-35.05 17.22-41.84c16.38-6.859 35.08 .9219 41.84 17.22L192 364.8l130.5-313.1c6.766-16.3 25.47-24.09 41.84-17.22C380.6 41.28 388.3 60.01 381.5 76.33z\"\n ]\n};\nvar faVanShuttle = {\n prefix: 'fas',\n iconName: 'van-shuttle',\n icon: [\n 640,\n 512,\n [\n 128656,\n \"shuttle-van\"\n ],\n \"f5b6\",\n \"M592 384H576C576 437 533 480 480 480C426.1 480 384 437 384 384H256C256 437 213 480 160 480C106.1 480 64 437 64 384H48C21.49 384 0 362.5 0 336V104C0 64.24 32.24 32 72 32H465.1C483.1 32 501.9 40.34 514.1 54.78L624.1 186.5C634.7 197.1 640 212.6 640 227.7V336C640 362.5 618.5 384 592 384zM64 192H160V96H72C67.58 96 64 99.58 64 104V192zM545.1 192L465.1 96H384V192H545.1zM320 192V96H224V192H320zM480 336C453.5 336 432 357.5 432 384C432 410.5 453.5 432 480 432C506.5 432 528 410.5 528 384C528 357.5 506.5 336 480 336zM160 432C186.5 432 208 410.5 208 384C208 357.5 186.5 336 160 336C133.5 336 112 357.5 112 384C112 410.5 133.5 432 160 432z\"\n ]\n};\nvar faShuttleVan = faVanShuttle;\nvar faVault = {\n prefix: 'fas',\n iconName: 'vault',\n icon: [\n 576,\n 512,\n [],\n \"e2c5\",\n \"M144 240C144 195.8 179.8 160 224 160C268.2 160 304 195.8 304 240C304 284.2 268.2 320 224 320C179.8 320 144 284.2 144 240zM512 0C547.3 0 576 28.65 576 64V416C576 451.3 547.3 480 512 480H496L480 512H416L400 480H176L160 512H96L80 480H64C28.65 480 0 451.3 0 416V64C0 28.65 28.65 0 64 0H512zM224 400C312.4 400 384 328.4 384 240C384 151.6 312.4 80 224 80C135.6 80 64 151.6 64 240C64 328.4 135.6 400 224 400zM480 221.3C498.6 214.7 512 196.9 512 176C512 149.5 490.5 128 464 128C437.5 128 416 149.5 416 176C416 196.9 429.4 214.7 448 221.3V336C448 344.8 455.2 352 464 352C472.8 352 480 344.8 480 336V221.3z\"\n ]\n};\nvar faVectorSquare = {\n prefix: 'fas',\n iconName: 'vector-square',\n icon: [\n 448,\n 512,\n [],\n \"f5cb\",\n \"M416 32C433.7 32 448 46.33 448 64V128C448 145.7 433.7 160 416 160V352C433.7 352 448 366.3 448 384V448C448 465.7 433.7 480 416 480H352C334.3 480 320 465.7 320 448H128C128 465.7 113.7 480 96 480H32C14.33 480 0 465.7 0 448V384C0 366.3 14.33 352 32 352V160C14.33 160 0 145.7 0 128V64C0 46.33 14.33 32 32 32H96C113.7 32 128 46.33 128 64H320C320 46.33 334.3 32 352 32H416zM368 80V112H400V80H368zM96 160V352C113.7 352 128 366.3 128 384H320C320 366.3 334.3 352 352 352V160C334.3 160 320 145.7 320 128H128C128 145.7 113.7 160 96 160zM48 400V432H80V400H48zM400 432V400H368V432H400zM80 112V80H48V112H80z\"\n ]\n};\nvar faVenus = {\n prefix: 'fas',\n iconName: 'venus',\n icon: [\n 384,\n 512,\n [\n 9792\n ],\n \"f221\",\n \"M368 176c0-97.2-78.8-176-176-176c-97.2 0-176 78.8-176 176c0 86.26 62.1 157.9 144 172.1v35.05H112c-8.836 0-16 7.162-16 16v32c0 8.836 7.164 16 16 16H160v48c0 8.836 7.164 16 16 16h32c8.838 0 16-7.164 16-16v-48h48c8.838 0 16-7.164 16-16v-32c0-8.838-7.162-16-16-16H224v-35.05C305.9 333.9 368 262.3 368 176zM192 272c-52.93 0-96-43.07-96-96c0-52.94 43.07-96 96-96c52.94 0 96 43.06 96 96C288 228.9 244.9 272 192 272z\"\n ]\n};\nvar faVenusDouble = {\n prefix: 'fas',\n iconName: 'venus-double',\n icon: [\n 640,\n 512,\n [\n 9890\n ],\n \"f226\",\n \"M368 176c0-97.2-78.8-176-176-176c-97.2 0-176 78.8-176 176c0 86.26 62.1 157.9 144 172.1v35.05H112c-8.836 0-16 7.162-16 16v32c0 8.836 7.164 16 16 16H160v48c0 8.836 7.164 16 16 16h32c8.838 0 16-7.164 16-16v-48h48c8.838 0 16-7.164 16-16v-32c0-8.838-7.162-16-16-16H224v-35.05C305.9 333.9 368 262.3 368 176zM192 272c-52.93 0-96-43.07-96-96c0-52.94 43.07-96 96-96c52.94 0 96 43.06 96 96C288 228.9 244.9 272 192 272zM624 176C624 78.8 545.2 0 448 0c-39.02 0-74.95 12.85-104.1 34.34c18.38 19.7 32.94 42.91 42.62 68.58C403.2 88.83 424.5 80 448 80c52.94 0 96 43.06 96 96c0 52.93-43.06 96-96 96c-23.57 0-44.91-8.869-61.63-23.02c-9.572 25.45-23.95 48.54-42.23 68.23C365.1 332.7 389.3 344 416 348.1V384h-48c-8.836 0-16 7.162-16 16v32c0 8.836 7.164 16 16 16H416v48c0 8.836 7.164 16 16 16h32c8.838 0 16-7.164 16-16V448h48c8.838 0 16-7.164 16-16v-32c0-8.838-7.162-16-16-16H480v-35.05C561.9 333.9 624 262.3 624 176z\"\n ]\n};\nvar faVenusMars = {\n prefix: 'fas',\n iconName: 'venus-mars',\n icon: [\n 640,\n 512,\n [\n 9892\n ],\n \"f228\",\n \"M256 384H208v-35.05C289.9 333.9 352 262.3 352 176c0-97.2-78.8-176-176-176c-97.2 0-176 78.8-176 176c0 86.26 62.1 157.9 144 172.1v35.05H96c-8.836 0-16 7.162-16 16v32c0 8.836 7.164 16 16 16h48v48c0 8.836 7.164 16 16 16h32c8.838 0 16-7.164 16-16v-48H256c8.838 0 16-7.164 16-16v-32C272 391.2 264.8 384 256 384zM176 272c-52.93 0-96-43.07-96-96c0-52.94 43.07-96 96-96c52.94 0 96 43.06 96 96C272 228.9 228.9 272 176 272zM624 0h-112.4c-21.38 0-32.09 25.85-16.97 40.97l29.56 29.56l-24.55 24.55c-29.97-20.66-64.81-31.05-99.74-31.05c-15.18 0-30.42 2.225-45.19 6.132c13.55 22.8 22.82 48.36 26.82 75.67c6.088-1.184 12.27-1.785 18.45-1.785c24.58 0 49.17 9.357 67.88 28.07c37.43 37.43 37.43 98.33 0 135.8c-18.71 18.71-43.3 28.07-67.88 28.07c-23.55 0-46.96-8.832-65.35-26.01c-15.92 18.84-34.93 35.1-56.75 47.35c11.45 5.898 20.17 16.3 23.97 28.82C331.5 406 365.7 416 400 416c45.04 0 90.08-17.18 124.5-51.55c60.99-60.99 67.73-155.6 20.47-224.1l24.55-24.55l29.56 29.56c4.889 4.889 10.9 7.078 16.8 7.078C628.2 152.4 640 142.8 640 128.4V16C640 7.164 632.8 0 624 0z\"\n ]\n};\nvar faVest = {\n prefix: 'fas',\n iconName: 'vest',\n icon: [\n 448,\n 512,\n [],\n \"e085\",\n \"M437.3 239.9L384 160V32c0-17.67-14.33-32-32-32h-32c-4.75 0-9.375 1.406-13.31 4.031l-25 16.66c-35.03 23.38-80.28 23.38-115.4 0l-25-16.66C137.4 1.406 132.8 0 128 0H96C78.33 0 64 14.33 64 32v128L10.75 239.9C3.74 250.4 0 262.7 0 275.4V480c0 17.67 14.33 32 32 32h160V288c0-3.439 .5547-6.855 1.643-10.12l13.49-40.48L150.2 66.56C173.2 79.43 198.5 86.25 224 86.25s50.79-6.824 73.81-19.69L224 288v224h192c17.67 0 32-14.33 32-32V275.4C448 262.7 444.3 250.4 437.3 239.9zM131.3 371.3l-48 48C80.19 422.4 76.09 424 72 424s-8.188-1.562-11.31-4.688c-6.25-6.25-6.25-16.38 0-22.62l48-48c6.25-6.25 16.38-6.25 22.62 0S137.6 365.1 131.3 371.3zM387.3 419.3C384.2 422.4 380.1 424 376 424s-8.188-1.562-11.31-4.688l-48-48c-6.25-6.25-6.25-16.38 0-22.62s16.38-6.25 22.62 0l48 48C393.6 402.9 393.6 413.1 387.3 419.3z\"\n ]\n};\nvar faVestPatches = {\n prefix: 'fas',\n iconName: 'vest-patches',\n icon: [\n 448,\n 512,\n [],\n \"e086\",\n \"M437.3 239.9L384 160V32c0-17.67-14.33-32-32-32h-32c-4.75 0-9.375 1.406-13.31 4.031l-25 16.66c-35.03 23.38-80.28 23.38-115.4 0l-25-16.66C137.4 1.406 132.8 0 128 0H96C78.33 0 64 14.33 64 32v128L10.75 239.9C3.74 250.4 0 262.7 0 275.4V480c0 17.67 14.33 32 32 32h160V288c0-3.439 .5547-6.855 1.643-10.12l13.49-40.48L150.2 66.56C173.2 79.43 198.5 86.25 224 86.25s50.79-6.824 73.81-19.69L224 288v224h192c17.67 0 32-14.33 32-32V275.4C448 262.7 444.3 250.4 437.3 239.9zM63.5 272.5c-4.656-4.688-4.656-12.31 0-17c4.688-4.688 12.31-4.688 17 0L96 271l15.5-15.5c4.688-4.688 12.31-4.688 17 0c4.656 4.688 4.656 12.31 0 17L113 288l15.5 15.5c4.656 4.688 4.656 12.31 0 17C126.2 322.8 123.1 324 120 324s-6.156-1.156-8.5-3.5L96 305l-15.5 15.5C78.16 322.8 75.06 324 72 324s-6.156-1.156-8.5-3.5c-4.656-4.688-4.656-12.31 0-17L79 288L63.5 272.5zM96 456c-22.09 0-40-17.91-40-40S73.91 376 96 376S136 393.9 136 416S118.1 456 96 456zM359.2 335.8L310.7 336C306.1 336 303.1 333 304 329.3l.2158-48.53c.1445-14.4 12.53-25.98 27.21-24.67c12.79 1.162 22.13 12.62 22.06 25.42l-.0557 5.076l5.069-.0566c12.83-.0352 24.24 9.275 25.4 22.08C385.2 323.3 373.7 335.7 359.2 335.8z\"\n ]\n};\nvar faVial = {\n prefix: 'fas',\n iconName: 'vial',\n icon: [\n 512,\n 512,\n [\n 129514\n ],\n \"f492\",\n \"M502.6 169.4l-160-160C336.4 3.125 328.2 0 320 0s-16.38 3.125-22.62 9.375c-12.5 12.5-12.5 32.75 0 45.25l6.975 6.977l-271.4 271c-38.75 38.75-45.13 102-9.375 143.5C44.08 500 72.76 512 101.5 512h.4473c26.38 0 52.75-9.1 72.88-30.12l275.2-274.6l7.365 7.367C463.6 220.9 471.8 224 480 224s16.38-3.125 22.62-9.375C515.1 202.1 515.1 181.9 502.6 169.4zM310.6 256H200.2l149.3-149.1l55.18 55.12L310.6 256z\"\n ]\n};\nvar faVials = {\n prefix: 'fas',\n iconName: 'vials',\n icon: [\n 512,\n 512,\n [],\n \"f493\",\n \"M200 32h-176C10.75 32 0 42.74 0 56C0 69.25 10.75 80 24 80H32v320C32 444.1 67.88 480 112 480S192 444.1 192 400v-320h8C213.3 80 224 69.25 224 56C224 42.74 213.3 32 200 32zM144 256h-64V80h64V256zM488 32h-176C298.7 32 288 42.74 288 56c0 13.25 10.75 24 24 24H320v320c0 44.13 35.88 80 80 80s80-35.88 80-80v-320h8C501.3 80 512 69.25 512 56C512 42.74 501.3 32 488 32zM432 256h-64V80h64V256z\"\n ]\n};\nvar faVideo = {\n prefix: 'fas',\n iconName: 'video',\n icon: [\n 576,\n 512,\n [\n \"video-camera\"\n ],\n \"f03d\",\n \"M384 112v288c0 26.51-21.49 48-48 48h-288c-26.51 0-48-21.49-48-48v-288c0-26.51 21.49-48 48-48h288C362.5 64 384 85.49 384 112zM576 127.5v256.9c0 25.5-29.17 40.39-50.39 25.79L416 334.7V177.3l109.6-75.56C546.9 87.13 576 102.1 576 127.5z\"\n ]\n};\nvar faVideoCamera = faVideo;\nvar faVideoSlash = {\n prefix: 'fas',\n iconName: 'video-slash',\n icon: [\n 640,\n 512,\n [],\n \"f4e2\",\n \"M32 399.1c0 26.51 21.49 47.1 47.1 47.1h287.1c19.57 0 36.34-11.75 43.81-28.56L32 121.8L32 399.1zM630.8 469.1l-89.21-69.92l15.99 11.02c21.22 14.59 50.41-.2971 50.41-25.8V127.5c0-25.41-29.07-40.37-50.39-25.76l-109.6 75.56l.0001 148.5l-32-25.08l.0001-188.7c0-26.51-21.49-47.1-47.1-47.1H113.9L38.81 5.111C34.41 1.673 29.19 0 24.03 0C16.91 0 9.84 3.158 5.121 9.189C-3.066 19.63-1.249 34.72 9.189 42.89l591.1 463.1c10.5 8.203 25.57 6.328 33.69-4.078C643.1 492.4 641.2 477.3 630.8 469.1z\"\n ]\n};\nvar faVihara = {\n prefix: 'fas',\n iconName: 'vihara',\n icon: [\n 640,\n 512,\n [],\n \"f6a7\",\n \"M280.1 22.03L305.8 4.661C307.1 3.715 308.4 2.908 309.9 2.246C313.1 .7309 316.6-.0029 319.1 0C323.4-.0029 326.9 .7309 330.1 2.246C331.6 2.909 332.9 3.716 334.2 4.661L359 22.03C392.1 45.8 430.8 63.52 470.8 74.42L493.8 80.71C495.6 81.17 497.4 81.83 499 82.68C502.2 84.33 504.1 86.66 507.1 89.43C510.8 94.38 512.7 100.7 511.8 107.2C511.4 109.1 510.6 112.6 509.3 115C507.7 118.2 505.3 120.1 502.6 123.1C498.3 126.3 492.1 128.1 487.5 128H480V184.1L491.7 193.3C512.8 210 536.6 222.9 562.2 231.4L591.1 241.1C592.7 241.6 594.2 242.2 595.7 243C598.8 244.8 601.4 247.2 603.5 249.1C605.5 252.8 606.9 256 607.6 259.6C608.1 262.2 608.2 265 607.7 267.8C607.2 270.6 606.3 273.3 604.1 275.7C603.2 278.8 600.8 281.5 598 283.5C595.2 285.5 591.1 286.9 588.4 287.6C586.8 287.9 585.1 288 583.4 288H544V353.9C564.5 376.7 591.4 393 621.4 400.6C632 403 640 412.6 640 424C640 437.3 629.3 448 616 448H576V480C576 497.7 561.7 512 544 512C526.3 512 512 497.7 512 480V448H352V480C352 497.7 337.7 512 320 512C302.3 512 288 497.7 288 480V448H128V480C128 497.7 113.7 512 96 512C78.33 512 64 497.7 64 480V448H24C10.75 448 0 437.3 0 424C0 412.6 7.962 403 18.63 400.6C48.61 393 75.51 376.7 96 353.9V288H56.55C54.87 288 53.2 287.9 51.57 287.6C48.03 286.9 44.77 285.5 41.96 283.5C39.16 281.5 36.77 278.8 35.03 275.7C33.69 273.3 32.76 270.6 32.31 267.8C31.85 265 31.9 262.2 32.41 259.6C33.07 256 34.51 252.8 36.53 249.1C38.55 247.2 41.19 244.8 44.34 243C45.78 242.2 47.32 241.6 48.94 241.1L77.81 231.4C103.4 222.9 127.2 210 148.3 193.3L160 184.1V128H152.5C147 128.1 141.7 126.3 137.4 123.1C134.7 120.1 132.3 118.2 130.7 115C129.4 112.6 128.6 109.1 128.2 107.2C127.3 100.7 129.2 94.38 132.9 89.43C135 86.66 137.8 84.33 140.1 82.68C142.6 81.83 144.4 81.17 146.2 80.71L169.2 74.42C209.2 63.52 247 45.8 280.1 22.03H280.1zM223.1 128V192H416V128H223.1zM159.1 352H480V288H159.1V352z\"\n ]\n};\nvar faVirus = {\n prefix: 'fas',\n iconName: 'virus',\n icon: [\n 576,\n 512,\n [],\n \"e074\",\n \"M515.6 227.6h-21.55c-50.68 0-76.06-61.28-40.23-97.12l15.25-15.25c11.11-11.11 11.11-29.11 .001-40.22c-11.11-11.11-29.11-11.11-40.22 .001l-15.24 15.24c-35.84 35.84-97.12 10.46-97.12-40.23V28.44c0-15.72-12.72-28.44-28.45-28.44S259.6 12.72 259.6 28.44v21.55c0 50.68-61.28 76.06-97.12 40.23L147.2 74.97C136.1 63.86 118.1 63.86 106.1 74.97c-11.11 11.11-11.11 29.11 .001 40.22l15.25 15.25C158.1 166.3 132.7 227.6 81.99 227.6H60.45C44.72 227.6 32 240.3 32 256s12.72 28.44 28.45 28.44h21.55c50.68 0 76.06 61.28 40.23 97.12l-15.25 15.25c-11.11 11.11-11.11 29.11-.001 40.22c5.555 5.555 12.83 8.333 20.11 8.333c7.277 0 14.55-2.779 20.11-8.334l15.24-15.25c35.84-35.84 97.12-10.46 97.12 40.23v21.55c0 15.72 12.72 28.45 28.45 28.45s28.45-12.72 28.45-28.45v-21.55c0-50.68 61.28-76.06 97.12-40.23l15.24 15.25c5.557 5.555 12.83 8.334 20.11 8.334c7.279 0 14.56-2.778 20.11-8.333c11.11-11.11 11.11-29.11-.001-40.22l-15.25-15.25c-35.84-35.84-10.46-97.12 40.23-97.12h21.55C531.3 284.4 544 271.7 544 256S531.3 227.6 515.6 227.6zM256 272c-26.51 0-48-21.49-48-48s21.49-48 48-48s48 21.49 48 48S282.5 272 256 272zM336 328c-13.25 0-24-10.75-24-24c0-13.26 10.75-23.1 24-23.1s24 10.74 24 24C360 317.3 349.3 328 336 328z\"\n ]\n};\nvar faVirusCovid = {\n prefix: 'fas',\n iconName: 'virus-covid',\n icon: [\n 512,\n 512,\n [],\n \"e4a8\",\n \"M192 24C192 10.75 202.7 0 216 0H296C309.3 0 320 10.75 320 24C320 37.25 309.3 48 296 48H280V81.62C310.7 85.8 338.8 97.88 362.3 115.7L386.1 91.95L374.8 80.64C365.4 71.26 365.4 56.07 374.8 46.7C384.2 37.32 399.4 37.32 408.7 46.7L465.3 103.3C474.7 112.6 474.7 127.8 465.3 137.2C455.9 146.6 440.7 146.6 431.4 137.2L420 125.9L396.3 149.7C414.1 173.2 426.2 201.3 430.4 232H464V216C464 202.7 474.7 192 488 192C501.3 192 512 202.7 512 216V296C512 309.3 501.3 320 488 320C474.7 320 464 309.3 464 296V280H430.4C426.2 310.7 414.1 338.8 396.3 362.3L420 386.1L431.4 374.8C440.7 365.4 455.9 365.4 465.3 374.8C474.7 384.2 474.7 399.4 465.3 408.7L408.7 465.3C399.4 474.7 384.2 474.7 374.8 465.3C365.4 455.9 365.4 440.7 374.8 431.4L386.1 420L362.3 396.3C338.8 414.1 310.7 426.2 280 430.4V464H296C309.3 464 320 474.7 320 488C320 501.3 309.3 512 296 512H216C202.7 512 192 501.3 192 488C192 474.7 202.7 464 216 464H232V430.4C201.3 426.2 173.2 414.1 149.7 396.3L125.9 420.1L137.2 431.4C146.6 440.7 146.6 455.9 137.2 465.3C127.8 474.7 112.6 474.7 103.3 465.3L46.7 408.7C37.32 399.4 37.32 384.2 46.7 374.8C56.07 365.4 71.27 365.4 80.64 374.8L91.95 386.1L115.7 362.3C97.88 338.8 85.8 310.7 81.62 280H48V296C48 309.3 37.25 320 24 320C10.75 320 0 309.3 0 296V216C0 202.7 10.75 192 24 192C37.25 192 48 202.7 48 216V232H81.62C85.8 201.3 97.88 173.2 115.7 149.7L91.95 125.9L80.64 137.2C71.26 146.6 56.07 146.6 46.7 137.2C37.32 127.8 37.32 112.6 46.7 103.3L103.3 46.7C112.6 37.33 127.8 37.33 137.2 46.7C146.6 56.07 146.6 71.27 137.2 80.64L125.9 91.95L149.7 115.7C173.2 97.88 201.3 85.8 232 81.62V48H216C202.7 48 192 37.26 192 24V24zM192 176C165.5 176 144 197.5 144 224C144 250.5 165.5 272 192 272C218.5 272 240 250.5 240 224C240 197.5 218.5 176 192 176zM304 328C317.3 328 328 317.3 328 304C328 290.7 317.3 280 304 280C290.7 280 280 290.7 280 304C280 317.3 290.7 328 304 328z\"\n ]\n};\nvar faVirusCovidSlash = {\n prefix: 'fas',\n iconName: 'virus-covid-slash',\n icon: [\n 640,\n 512,\n [],\n \"e4a9\",\n \"M134.1 79.83L167.3 46.7C176.6 37.33 191.8 37.33 201.2 46.7C210.6 56.07 210.6 71.27 201.2 80.64L189.9 91.95L213.7 115.7C237.2 97.88 265.3 85.8 295.1 81.62V48H279.1C266.7 48 255.1 37.26 255.1 24C255.1 10.75 266.7 .0003 279.1 .0003H360C373.3 .0003 384 10.75 384 24C384 37.26 373.3 48 360 48H344V81.62C374.7 85.8 402.8 97.88 426.3 115.7L450.1 91.95L438.8 80.64C429.4 71.26 429.4 56.07 438.8 46.7C448.2 37.32 463.4 37.32 472.7 46.7L529.3 103.3C538.7 112.6 538.7 127.8 529.3 137.2C519.9 146.6 504.7 146.6 495.4 137.2L484 125.9L460.3 149.7C478.1 173.2 490.2 201.3 494.4 232H528V216C528 202.7 538.7 192 552 192C565.3 192 576 202.7 576 216V296C576 309.3 565.3 320 552 320C538.7 320 528 309.3 528 296V280H494.4C491.2 303.3 483.4 325.2 472.1 344.7L630.8 469.1C641.2 477.3 643.1 492.4 634.9 502.8C626.7 513.2 611.6 515.1 601.2 506.9L9.196 42.89C-1.236 34.71-3.065 19.63 5.112 9.196C13.29-1.236 28.37-3.065 38.81 5.112L134.1 79.83zM149.2 213.5L401.3 412.2C383.7 421.3 364.4 427.6 344 430.4V464H360C373.3 464 384 474.7 384 488C384 501.3 373.3 512 360 512H279.1C266.7 512 255.1 501.3 255.1 488C255.1 474.7 266.7 464 279.1 464H295.1V430.4C265.3 426.2 237.2 414.1 213.7 396.3L189.9 420.1L201.2 431.4C210.6 440.7 210.6 455.9 201.2 465.3C191.8 474.7 176.6 474.7 167.3 465.3L110.7 408.7C101.3 399.4 101.3 384.2 110.7 374.8C120.1 365.4 135.3 365.4 144.6 374.8L155.1 386.1L179.7 362.3C161.9 338.8 149.8 310.7 145.6 280H111.1V296C111.1 309.3 101.3 320 87.1 320C74.74 320 63.1 309.3 63.1 296V216C63.1 202.7 74.74 192 87.1 192C101.3 192 111.1 202.7 111.1 216V232H145.6C146.5 225.7 147.7 219.6 149.2 213.5L149.2 213.5z\"\n ]\n};\nvar faVirusSlash = {\n prefix: 'fas',\n iconName: 'virus-slash',\n icon: [\n 640,\n 512,\n [],\n \"e075\",\n \"M113.1 227.6H92.44c-15.72 0-28.45 12.72-28.45 28.45s12.72 28.44 28.45 28.44h21.55c50.68 0 76.06 61.28 40.23 97.11l-15.25 15.25c-11.11 11.11-11.11 29.11-.0006 40.22c5.555 5.555 12.83 8.332 20.11 8.332c7.277 0 14.55-2.779 20.11-8.334l15.24-15.25c35.84-35.84 97.12-10.45 97.12 40.23v21.55c0 15.72 12.72 28.45 28.45 28.45c15.72 0 28.45-12.72 28.45-28.45v-21.55c0-30.08 21.69-50.85 46.74-55.6L150 214.3C140.5 222.2 128.5 227.6 113.1 227.6zM630.8 469.1l-161.2-126.4c-.5176-29.6 21.73-58.3 56.41-58.3h21.55c15.72 0 28.45-12.72 28.45-28.44s-12.72-28.45-28.45-28.45h-21.55c-50.68 0-76.06-61.28-40.23-97.11l15.25-15.25c11.11-11.11 11.11-29.11 .0011-40.22c-11.11-11.11-29.11-11.11-40.22 .0007l-15.24 15.24c-35.84 35.84-97.12 10.46-97.12-40.23V28.44C348.4 12.72 335.7 0 319.1 0C304.3 0 291.6 12.72 291.6 28.44v21.55c0 50.68-61.28 76.06-97.12 40.23L179.2 74.97c-11.11-11.11-29.11-11.11-40.22 0C137.3 76.63 136.2 78.61 135 80.53L38.81 5.112C34.41 1.675 29.19 0 24.03 0C16.91 0 9.845 3.159 5.126 9.19C-3.061 19.63-1.248 34.72 9.189 42.89l591.1 463.1c10.5 8.203 25.56 6.328 33.69-4.078C643.1 492.4 641.2 477.3 630.8 469.1zM334.1 236.6L264.6 182.1c6.904-3.885 14.86-6.109 23.36-6.109c26.51 0 47.1 21.49 47.1 47.1C335.1 228.4 335.2 232.5 334.1 236.6z\"\n ]\n};\nvar faViruses = {\n prefix: 'fas',\n iconName: 'viruses',\n icon: [\n 640,\n 512,\n [],\n \"e076\",\n \"M346.5 213.3h16.16C374.5 213.3 384 203.8 384 192c0-11.79-9.541-21.33-21.33-21.33h-16.16c-38.01 0-57.05-45.96-30.17-72.84l11.44-11.44c8.332-8.332 8.331-21.83-.0012-30.17c-8.334-8.334-21.83-8.332-30.17 .002L286.2 67.66C259.3 94.54 213.3 75.51 213.3 37.49V21.33C213.3 9.542 203.8 0 192 0S170.7 9.542 170.7 21.33v16.16c0 38.01-45.96 57.05-72.84 30.17L86.4 56.23c-8.334-8.334-21.83-8.336-30.17-.002c-8.332 8.334-8.333 21.84-.0012 30.17L67.66 97.83c26.88 26.88 7.842 72.84-30.17 72.84H21.33C9.541 170.7 0 180.2 0 192c0 11.79 9.541 21.33 21.33 21.33h16.16c38.01 0 57.05 45.96 30.17 72.84L56.23 297.6c-8.332 8.334-8.328 21.84 .0043 30.17c4.168 4.168 9.621 6.248 15.08 6.248s10.92-2.082 15.08-6.25L97.83 316.3c26.88-26.88 72.84-7.842 72.84 30.17v16.16C170.7 374.5 180.2 384 192 384s21.33-9.543 21.33-21.33v-16.16c0-38.01 45.96-57.05 72.84-30.17l11.43 11.43c4.168 4.168 9.625 6.25 15.08 6.25s10.91-2.08 15.08-6.248c8.332-8.332 8.333-21.83 .0012-30.17L316.3 286.2C289.5 259.3 308.5 213.3 346.5 213.3zM160 192C142.3 192 128 177.7 128 160c0-17.67 14.33-32 32-32s32 14.33 32 32C192 177.7 177.7 192 160 192zM240 224C231.2 224 224 216.8 224 208C224 199.2 231.2 192 240 192S256 199.2 256 208C256 216.8 248.8 224 240 224zM624 352h-12.12c-28.51 0-42.79-34.47-22.63-54.63l8.576-8.576c6.25-6.25 6.25-16.37 0-22.62s-16.38-6.253-22.62-.0031l-8.576 8.576C546.5 294.9 512 280.6 512 252.1V240C512 231.2 504.8 224 496 224S480 231.2 480 240v12.12c0 28.51-34.47 42.79-54.63 22.63l-8.576-8.576c-6.25-6.25-16.37-6.253-22.62-.0031s-6.253 16.38-.0031 22.63l8.576 8.576C422.9 317.5 408.6 352 380.1 352H368c-8.844 0-16 7.156-16 16s7.156 16 16 16h12.12c28.51 0 42.79 34.47 22.63 54.63l-8.576 8.576c-6.25 6.25-6.253 16.37-.0031 22.62c3.125 3.125 7.222 4.691 11.32 4.691s8.188-1.562 11.31-4.688l8.576-8.576C445.5 441.1 480 455.4 480 483.9V496c0 8.844 7.156 16 16 16s16-7.156 16-16v-12.12c0-28.51 34.47-42.79 54.63-22.63l8.576 8.576c3.125 3.125 7.219 4.688 11.31 4.688s8.184-1.559 11.31-4.684c6.25-6.25 6.253-16.38 .0031-22.63l-8.576-8.576C569.1 418.5 583.4 384 611.9 384H624c8.844 0 16-7.156 16-16S632.8 352 624 352zM480 384c-17.67 0-32-14.33-32-32c0-17.67 14.33-32 32-32s32 14.33 32 32C512 369.7 497.7 384 480 384z\"\n ]\n};\nvar faVoicemail = {\n prefix: 'fas',\n iconName: 'voicemail',\n icon: [\n 640,\n 512,\n [],\n \"f897\",\n \"M495.1 96c-53.13 0-102 29.25-127 76.13c-25 46.88-22.25 103.8 7.25 147.9H263.7c36.63-54.88 31.25-127.8-13-176.8c-44.38-48.87-116.4-61.37-174.6-30.25s-87.88 97.88-71.75 162c16 64 73.63 108.1 139.6 108.1h352C575.5 384 640 319.5 640 240S575.5 96 495.1 96zM63.99 240c0-44.12 35.88-80 80-80s80 35.88 80 80s-35.88 79.1-80 79.1S63.99 284.1 63.99 240zM495.1 320c-44.13 0-80-35.88-80-79.1s35.88-80 80-80s80 35.88 80 80S540.1 320 495.1 320z\"\n ]\n};\nvar faVolleyball = {\n prefix: 'fas',\n iconName: 'volleyball',\n icon: [\n 512,\n 512,\n [\n 127952,\n \"volleyball-ball\"\n ],\n \"f45f\",\n \"M200.3 106C185.4 80.24 165.2 53.9 137.4 29.26C55.75 72.05 0 157.4 0 256c0 21.33 2.898 41.94 7.814 61.75C53.59 182.1 155.1 124.9 200.3 106zM381.7 281.1c1.24-9.223 2.414-22.08 2.414-37.65c0-59.1-16.93-157.2-111.5-242.6C267.1 .4896 261.6 0 256 0C225.5 0 196.5 5.591 169.4 15.36c93.83 90.15 102.6 198.5 102.8 231.7C287.8 255.9 327.3 275.1 381.7 281.1zM240.1 246.5C239.1 228.5 236.9 184.7 214.9 134.6C173.6 151.6 60.4 211.7 26.67 369.2c15.66 31.64 37.52 59.66 64.22 82.23C122 325.1 211.5 263.3 240.1 246.5zM326.5 10.07c74.79 84.9 89.5 175.9 89.5 234c0 15.45-1.042 28.56-2.27 38.61l.5501 .0005c29.54 0 62.2-4.325 97.16-15.99C511.6 263.1 512 259.6 512 256C512 139.1 433.6 40.72 326.5 10.07zM255.7 274.5c-15.43 9.086-51.89 33.63-84.32 77.86c26.34 20.33 93.51 63.27 189.5 63.27c32.83 0 69.02-5.021 108.1-17.69c19.08-28.59 32.41-61.34 38.71-96.47C474.5 311.1 443 315 414.4 315C334.6 315 276.5 286.3 255.7 274.5zM153.1 379.3c-14.91 25.71-27.62 56.33-35.03 92.72C158.6 497.2 205.5 512 256 512c69 0 131.5-27.43 177.5-71.82c-25.42 5.105-49.71 7.668-72.38 7.668C258.6 447.8 185.5 402.1 153.1 379.3z\"\n ]\n};\nvar faVolleyballBall = faVolleyball;\nvar faVolumeHigh = {\n prefix: 'fas',\n iconName: 'volume-high',\n icon: [\n 640,\n 512,\n [\n 128266,\n \"volume-up\"\n ],\n \"f028\",\n \"M412.6 182c-10.28-8.334-25.41-6.867-33.75 3.402c-8.406 10.24-6.906 25.35 3.375 33.74C393.5 228.4 400 241.8 400 255.1c0 14.17-6.5 27.59-17.81 36.83c-10.28 8.396-11.78 23.5-3.375 33.74c4.719 5.806 11.62 8.802 18.56 8.802c5.344 0 10.75-1.779 15.19-5.399C435.1 311.5 448 284.6 448 255.1S435.1 200.4 412.6 182zM473.1 108.2c-10.22-8.334-25.34-6.898-33.78 3.34c-8.406 10.24-6.906 25.35 3.344 33.74C476.6 172.1 496 213.3 496 255.1s-19.44 82.1-53.31 110.7c-10.25 8.396-11.75 23.5-3.344 33.74c4.75 5.775 11.62 8.771 18.56 8.771c5.375 0 10.75-1.779 15.22-5.431C518.2 366.9 544 313 544 255.1S518.2 145 473.1 108.2zM534.4 33.4c-10.22-8.334-25.34-6.867-33.78 3.34c-8.406 10.24-6.906 25.35 3.344 33.74C559.9 116.3 592 183.9 592 255.1s-32.09 139.7-88.06 185.5c-10.25 8.396-11.75 23.5-3.344 33.74C505.3 481 512.2 484 519.2 484c5.375 0 10.75-1.779 15.22-5.431C601.5 423.6 640 342.5 640 255.1S601.5 88.34 534.4 33.4zM301.2 34.98c-11.5-5.181-25.01-3.076-34.43 5.29L131.8 160.1H48c-26.51 0-48 21.48-48 47.96v95.92c0 26.48 21.49 47.96 48 47.96h83.84l134.9 119.8C272.7 477 280.3 479.8 288 479.8c4.438 0 8.959-.9314 13.16-2.835C312.7 471.8 320 460.4 320 447.9V64.12C320 51.55 312.7 40.13 301.2 34.98z\"\n ]\n};\nvar faVolumeUp = faVolumeHigh;\nvar faVolumeLow = {\n prefix: 'fas',\n iconName: 'volume-low',\n icon: [\n 448,\n 512,\n [\n 128264,\n \"volume-down\"\n ],\n \"f027\",\n \"M412.6 181.9c-10.28-8.344-25.41-6.875-33.75 3.406c-8.406 10.25-6.906 25.37 3.375 33.78C393.5 228.4 400 241.8 400 256c0 14.19-6.5 27.62-17.81 36.87c-10.28 8.406-11.78 23.53-3.375 33.78c4.719 5.812 11.62 8.812 18.56 8.812c5.344 0 10.75-1.781 15.19-5.406C435.1 311.6 448 284.7 448 256S435.1 200.4 412.6 181.9zM301.2 34.84c-11.5-5.187-25.01-3.116-34.43 5.259L131.8 160H48c-26.51 0-48 21.49-48 47.1v95.1c0 26.51 21.49 47.1 48 47.1h83.84l134.9 119.9C272.7 477.2 280.3 480 288 480c4.438 0 8.959-.9313 13.16-2.837C312.7 472 320 460.6 320 448V64C320 51.41 312.7 39.1 301.2 34.84z\"\n ]\n};\nvar faVolumeDown = faVolumeLow;\nvar faVolumeOff = {\n prefix: 'fas',\n iconName: 'volume-off',\n icon: [\n 320,\n 512,\n [],\n \"f026\",\n \"M320 64v383.1c0 12.59-7.337 24.01-18.84 29.16C296.1 479.1 292.4 480 288 480c-7.688 0-15.28-2.781-21.27-8.094l-134.9-119.9H48c-26.51 0-48-21.49-48-47.1V208c0-26.51 21.49-47.1 48-47.1h83.84l134.9-119.9c9.422-8.375 22.93-10.45 34.43-5.259C312.7 39.1 320 51.41 320 64z\"\n ]\n};\nvar faVolumeXmark = {\n prefix: 'fas',\n iconName: 'volume-xmark',\n icon: [\n 576,\n 512,\n [\n \"volume-mute\",\n \"volume-times\"\n ],\n \"f6a9\",\n \"M301.2 34.85c-11.5-5.188-25.02-3.122-34.44 5.253L131.8 160H48c-26.51 0-48 21.49-48 47.1v95.1c0 26.51 21.49 47.1 48 47.1h83.84l134.9 119.9c5.984 5.312 13.58 8.094 21.26 8.094c4.438 0 8.972-.9375 13.17-2.844c11.5-5.156 18.82-16.56 18.82-29.16V64C319.1 51.41 312.7 40 301.2 34.85zM513.9 255.1l47.03-47.03c9.375-9.375 9.375-24.56 0-33.94s-24.56-9.375-33.94 0L480 222.1L432.1 175c-9.375-9.375-24.56-9.375-33.94 0s-9.375 24.56 0 33.94l47.03 47.03l-47.03 47.03c-9.375 9.375-9.375 24.56 0 33.94c9.373 9.373 24.56 9.381 33.94 0L480 289.9l47.03 47.03c9.373 9.373 24.56 9.381 33.94 0c9.375-9.375 9.375-24.56 0-33.94L513.9 255.1z\"\n ]\n};\nvar faVolumeMute = faVolumeXmark;\nvar faVolumeTimes = faVolumeXmark;\nvar faVrCardboard = {\n prefix: 'fas',\n iconName: 'vr-cardboard',\n icon: [\n 640,\n 512,\n [],\n \"f729\",\n \"M576 64H64c-35.2 0-64 28.8-64 64v256c0 35.2 28.8 64 64 64l128.3 .0001c25.18 0 48.03-14.77 58.37-37.73l27.76-61.65c7.875-17.5 24-28.63 41.63-28.63s33.75 11.13 41.63 28.63l27.75 61.63c10.35 22.98 33.2 37.75 58.4 37.75L576 448c35.2 0 64-28.8 64-64v-256C640 92.8 611.2 64 576 64zM160 304c-35.38 0-64-28.63-64-64s28.62-63.1 64-63.1s64 28.62 64 63.1S195.4 304 160 304zM480 304c-35.38 0-64-28.63-64-64s28.62-63.1 64-63.1s64 28.62 64 63.1S515.4 304 480 304z\"\n ]\n};\nvar faW = {\n prefix: 'fas',\n iconName: 'w',\n icon: [\n 576,\n 512,\n [\n 119\n ],\n \"57\",\n \"M573.1 75.25l-144 384c-4.703 12.53-16.67 20.77-29.95 20.77c-.4062 0-.8125 0-1.219-.0156c-13.77-.5156-25.66-9.797-29.52-23.03L288 178.3l-81.28 278.7c-3.859 13.23-15.75 22.52-29.52 23.03c-13.75 .4687-26.33-7.844-31.17-20.75l-144-384c-6.203-16.55 2.188-34.98 18.73-41.2C37.31 27.92 55.75 36.23 61.97 52.78l110.2 293.1l85.08-291.7C261.3 41.41 273.8 32.01 288 32.01s26.73 9.396 30.72 23.05l85.08 291.7l110.2-293.1c6.219-16.55 24.67-24.86 41.2-18.73C571.8 40.26 580.2 58.7 573.1 75.25z\"\n ]\n};\nvar faWallet = {\n prefix: 'fas',\n iconName: 'wallet',\n icon: [\n 512,\n 512,\n [],\n \"f555\",\n \"M448 32C465.7 32 480 46.33 480 64C480 81.67 465.7 96 448 96H80C71.16 96 64 103.2 64 112C64 120.8 71.16 128 80 128H448C483.3 128 512 156.7 512 192V416C512 451.3 483.3 480 448 480H64C28.65 480 0 451.3 0 416V96C0 60.65 28.65 32 64 32H448zM416 336C433.7 336 448 321.7 448 304C448 286.3 433.7 272 416 272C398.3 272 384 286.3 384 304C384 321.7 398.3 336 416 336z\"\n ]\n};\nvar faWandMagic = {\n prefix: 'fas',\n iconName: 'wand-magic',\n icon: [\n 512,\n 512,\n [\n \"magic\"\n ],\n \"f0d0\",\n \"M14.06 463.3C-4.686 444.6-4.686 414.2 14.06 395.4L395.4 14.06C414.2-4.686 444.6-4.686 463.3 14.06L497.9 48.64C516.6 67.38 516.6 97.78 497.9 116.5L116.5 497.9C97.78 516.6 67.38 516.6 48.64 497.9L14.06 463.3zM347.6 187.6L452.6 82.58L429.4 59.31L324.3 164.3L347.6 187.6z\"\n ]\n};\nvar faMagic = faWandMagic;\nvar faWandMagicSparkles = {\n prefix: 'fas',\n iconName: 'wand-magic-sparkles',\n icon: [\n 576,\n 512,\n [\n \"magic-wand-sparkles\"\n ],\n \"e2ca\",\n \"M248.8 4.994C249.9 1.99 252.8 .0001 256 .0001C259.2 .0001 262.1 1.99 263.2 4.994L277.3 42.67L315 56.79C318 57.92 320 60.79 320 64C320 67.21 318 70.08 315 71.21L277.3 85.33L263.2 123C262.1 126 259.2 128 256 128C252.8 128 249.9 126 248.8 123L234.7 85.33L196.1 71.21C193.1 70.08 192 67.21 192 64C192 60.79 193.1 57.92 196.1 56.79L234.7 42.67L248.8 4.994zM427.4 14.06C446.2-4.686 476.6-4.686 495.3 14.06L529.9 48.64C548.6 67.38 548.6 97.78 529.9 116.5L148.5 497.9C129.8 516.6 99.38 516.6 80.64 497.9L46.06 463.3C27.31 444.6 27.31 414.2 46.06 395.4L427.4 14.06zM461.4 59.31L356.3 164.3L379.6 187.6L484.6 82.58L461.4 59.31zM7.491 117.2L64 96L85.19 39.49C86.88 34.98 91.19 32 96 32C100.8 32 105.1 34.98 106.8 39.49L128 96L184.5 117.2C189 118.9 192 123.2 192 128C192 132.8 189 137.1 184.5 138.8L128 160L106.8 216.5C105.1 221 100.8 224 96 224C91.19 224 86.88 221 85.19 216.5L64 160L7.491 138.8C2.985 137.1 0 132.8 0 128C0 123.2 2.985 118.9 7.491 117.2zM359.5 373.2L416 352L437.2 295.5C438.9 290.1 443.2 288 448 288C452.8 288 457.1 290.1 458.8 295.5L480 352L536.5 373.2C541 374.9 544 379.2 544 384C544 388.8 541 393.1 536.5 394.8L480 416L458.8 472.5C457.1 477 452.8 480 448 480C443.2 480 438.9 477 437.2 472.5L416 416L359.5 394.8C354.1 393.1 352 388.8 352 384C352 379.2 354.1 374.9 359.5 373.2z\"\n ]\n};\nvar faMagicWandSparkles = faWandMagicSparkles;\nvar faWandSparkles = {\n prefix: 'fas',\n iconName: 'wand-sparkles',\n icon: [\n 512,\n 512,\n [],\n \"f72b\",\n \"M3.682 149.1L53.32 170.7L74.02 220.3c1.016 2.043 3.698 3.696 5.977 3.696c.0078 0-.0078 0 0 0c2.271-.0156 4.934-1.661 5.946-3.696l20.72-49.63l49.62-20.71c2.023-1.008 3.68-3.681 3.691-5.947C159.1 141.7 158.3 139 156.3 138L106.9 117.4L106.5 117L85.94 67.7C84.93 65.66 82.27 64.02 80 64c-.0078 0 .0078 0 0 0c-2.279 0-4.966 1.649-5.981 3.692L53.32 117.3L3.682 138C1.652 139.1 0 141.7 0 144C0 146.3 1.652 148.9 3.682 149.1zM511.1 368c-.0039-2.273-1.658-4.95-3.687-5.966l-49.57-20.67l-20.77-49.67C436.9 289.7 434.3 288 432 288c-2.281 0-4.948 1.652-5.964 3.695l-20.7 49.63l-49.64 20.71c-2.027 1.016-3.684 3.683-3.687 5.956c.0039 2.262 1.662 4.954 3.687 5.966l49.57 20.67l20.77 49.67C427.1 446.3 429.7 448 432 448c2.277 0 4.944-1.656 5.96-3.699l20.69-49.63l49.65-20.71C510.3 372.9 511.1 370.3 511.1 368zM207.1 64l12.42 29.78C221 95.01 222.6 96 223.1 96s2.965-.9922 3.575-2.219L239.1 64l29.78-12.42c1.219-.6094 2.215-2.219 2.215-3.578c0-1.367-.996-2.969-2.215-3.578L239.1 32L227.6 2.219C226.1 .9922 225.4 0 223.1 0S221 .9922 220.4 2.219L207.1 32L178.2 44.42C176.1 45.03 176 46.63 176 48c0 1.359 .9928 2.969 2.21 3.578L207.1 64zM399.1 191.1c8.875 0 15.1-7.127 15.1-16v-28l91.87-101.7c5.75-6.371 5.5-15.1-.4999-22.12L487.8 4.774c-6.125-6.125-15.75-6.375-22.12-.625L186.6 255.1H144c-8.875 0-15.1 7.125-15.1 15.1v36.88l-117.5 106c-13.5 12.25-14.14 33.34-1.145 46.34l41.4 41.41c12.1 12.1 34.13 12.36 46.37-1.133l279.2-309.5H399.1z\"\n ]\n};\nvar faWarehouse = {\n prefix: 'fas',\n iconName: 'warehouse',\n icon: [\n 640,\n 512,\n [],\n \"f494\",\n \"M0 488V171.3C0 145.2 15.93 121.6 40.23 111.9L308.1 4.753C315.7 1.702 324.3 1.702 331.9 4.753L599.8 111.9C624.1 121.6 640 145.2 640 171.3V488C640 501.3 629.3 512 616 512H568C554.7 512 544 501.3 544 488V223.1C544 206.3 529.7 191.1 512 191.1H128C110.3 191.1 96 206.3 96 223.1V488C96 501.3 85.25 512 72 512H24C10.75 512 0 501.3 0 488zM152 512C138.7 512 128 501.3 128 488V432H512V488C512 501.3 501.3 512 488 512H152zM128 336H512V400H128V336zM128 224H512V304H128V224z\"\n ]\n};\nvar faWater = {\n prefix: 'fas',\n iconName: 'water',\n icon: [\n 576,\n 512,\n [],\n \"f773\",\n \"M549.8 237.5c-31.23-5.719-46.84-20.06-47.13-20.31C490.4 205 470.3 205.1 457.7 216.8c-1 .9375-25.14 23-73.73 23s-72.73-22.06-73.38-22.62C298.4 204.9 278.3 205.1 265.7 216.8c-1 .9375-25.14 23-73.73 23S119.3 217.8 118.6 217.2C106.4 204.9 86.35 205 73.74 216.9C73.09 217.4 57.48 231.8 26.24 237.5c-17.38 3.188-28.89 19.84-25.72 37.22c3.188 17.38 19.78 29.09 37.25 25.72C63.1 295.8 82.49 287.1 95.96 279.2c19.5 11.53 51.47 24.68 96.04 24.68c44.55 0 76.49-13.12 96-24.65c19.52 11.53 51.45 24.59 96 24.59c44.58 0 76.55-13.09 96.05-24.62c13.47 7.938 32.86 16.62 58.19 21.25c17.56 3.375 34.06-8.344 37.25-25.72C578.7 257.4 567.2 240.7 549.8 237.5zM549.8 381.7c-31.23-5.719-46.84-20.06-47.13-20.31c-12.22-12.19-32.31-12.12-44.91-.375C456.7 361.9 432.6 384 384 384s-72.73-22.06-73.38-22.62c-12.22-12.25-32.3-12.12-44.89-.375C264.7 361.9 240.6 384 192 384s-72.73-22.06-73.38-22.62c-12.22-12.25-32.28-12.16-44.89-.3438c-.6562 .5938-16.27 14.94-47.5 20.66c-17.38 3.188-28.89 19.84-25.72 37.22C3.713 436.3 20.31 448 37.78 444.6C63.1 440 82.49 431.3 95.96 423.4c19.5 11.53 51.51 24.62 96.08 24.62c44.55 0 76.45-13.06 95.96-24.59C307.5 434.9 339.5 448 384.1 448c44.58 0 76.5-13.09 95.1-24.62c13.47 7.938 32.86 16.62 58.19 21.25C555.8 448 572.3 436.3 575.5 418.9C578.7 401.5 567.2 384.9 549.8 381.7zM37.78 156.4c25.33-4.625 44.72-13.31 58.19-21.25c19.5 11.53 51.47 24.68 96.04 24.68c44.55 0 76.49-13.12 96-24.65c19.52 11.53 51.45 24.59 96 24.59c44.58 0 76.55-13.09 96.05-24.62c13.47 7.938 32.86 16.62 58.19 21.25c17.56 3.375 34.06-8.344 37.25-25.72c3.172-17.38-8.344-34.03-25.72-37.22c-31.23-5.719-46.84-20.06-47.13-20.31c-12.22-12.19-32.31-12.12-44.91-.375c-1 .9375-25.14 23-73.73 23s-72.73-22.06-73.38-22.62c-12.22-12.25-32.3-12.12-44.89-.375c-1 .9375-25.14 23-73.73 23S119.3 73.76 118.6 73.2C106.4 60.95 86.35 61.04 73.74 72.85C73.09 73.45 57.48 87.79 26.24 93.51c-17.38 3.188-28.89 19.84-25.72 37.22C3.713 148.1 20.31 159.8 37.78 156.4z\"\n ]\n};\nvar faWaterLadder = {\n prefix: 'fas',\n iconName: 'water-ladder',\n icon: [\n 576,\n 512,\n [\n \"ladder-water\",\n \"swimming-pool\"\n ],\n \"f5c5\",\n \"M320 128c0 .375-.1992 .6855-.2129 1.057C319.8 129.9 320 130.7 320 131.6V128zM192 383.1V288h192v95.99c39.6-.1448 53.95-17.98 64-26.83V128c0-17.62 14.38-32 32-32s32 14.38 32 32c0 17.67 14.33 32 32 32s32-14.33 32-32c0-53-42.1-95.1-95.1-95.1C420.1 32 384 81.94 384 131.6V224H192V128c0-17.62 14.38-32 32-32s32 14.38 32 32c0 17.67 14.33 32 32 32c17.3 0 31.2-13.79 31.79-30.94c-1.227-49.01-37.99-97.06-95.79-97.06C170.1 32 128 74.1 128 128v229.2C138.5 366.4 151.4 383.8 192 383.1zM576 445c0-15.14-10.82-28.59-26.25-31.42c-48.52-8.888-45.5-29.48-69.6-29.48c-25.02 0-31.19 31.79-96.18 31.79c-48.59 0-72.72-22.06-73.38-22.62c-6.141-6.157-14.26-9.188-22.42-9.188c-24.75 0-31.59 31.81-96.2 31.81c-48.59 0-72.69-22.03-73.41-22.59c-6.125-6.157-14.24-9.196-22.4-9.196c-8.072 0-16.18 2.976-22.45 8.852c-29.01 26.25-73.75 12.54-73.75 52.08c0 16.08 12.77 32.07 31.71 32.07c9.77 0 39.65-7.34 64.26-21.84c19.5 11.53 51.51 24.69 96.08 24.69s76.46-13.12 95.96-24.66c19.53 11.53 51.52 24.62 96.06 24.62c44.59 0 76.51-13.12 96.01-24.66c24.71 14.57 54.74 21.83 64.24 21.83C563.2 477.1 576 461.3 576 445z\"\n ]\n};\nvar faLadderWater = faWaterLadder;\nvar faSwimmingPool = faWaterLadder;\nvar faWaveSquare = {\n prefix: 'fas',\n iconName: 'wave-square',\n icon: [\n 640,\n 512,\n [],\n \"f83e\",\n \"M476 480h-152c-19.88 0-36-16.12-36-36v-348H192v156c0 19.88-16.12 36-36 36H31.1C14.33 288 0 273.7 0 256s14.33-31.1 31.1-31.1H128v-156c0-19.88 16.12-36 36-36h152c19.88 0 36 16.12 36 36v348h96v-156c0-19.88 16.12-36 36-36h124C625.7 224 640 238.3 640 256s-14.33 32-31.1 32H512v156C512 463.9 495.9 480 476 480z\"\n ]\n};\nvar faWeightHanging = {\n prefix: 'fas',\n iconName: 'weight-hanging',\n icon: [\n 512,\n 512,\n [],\n \"f5cd\",\n \"M510.3 445.9L437.3 153.8C433.5 138.5 420.8 128 406.4 128H346.1c3.625-9.1 5.875-20.75 5.875-32c0-53-42.1-96-96-96S159.1 43 159.1 96c0 11.25 2.25 22 5.875 32H105.6c-14.38 0-27.13 10.5-30.88 25.75l-73.01 292.1C-6.641 479.1 16.36 512 47.99 512h416C495.6 512 518.6 479.1 510.3 445.9zM256 128C238.4 128 223.1 113.6 223.1 96S238.4 64 256 64c17.63 0 32 14.38 32 32S273.6 128 256 128z\"\n ]\n};\nvar faWeightScale = {\n prefix: 'fas',\n iconName: 'weight-scale',\n icon: [\n 512,\n 512,\n [\n \"weight\"\n ],\n \"f496\",\n \"M310.3 97.25c-8-3.5-17.5 .25-21 8.5L255.8 184C233.8 184.3 216 202 216 224c0 22.12 17.88 40 40 40S296 246.1 296 224c0-10.5-4.25-20-11-27.12l33.75-78.63C322.3 110.1 318.4 100.8 310.3 97.25zM448 64h-56.23C359.5 24.91 310.7 0 256 0S152.5 24.91 120.2 64H64C28.75 64 0 92.75 0 128v320c0 35.25 28.75 64 64 64h384c35.25 0 64-28.75 64-64V128C512 92.75 483.3 64 448 64zM256 304c-70.58 0-128-57.42-128-128s57.42-128 128-128c70.58 0 128 57.42 128 128S326.6 304 256 304z\"\n ]\n};\nvar faWeight = faWeightScale;\nvar faWheelchair = {\n prefix: 'fas',\n iconName: 'wheelchair',\n icon: [\n 512,\n 512,\n [],\n \"f193\",\n \"M510.3 421.9c-5.594-16.75-23.53-25.84-40.47-20.22l-19.38 6.438l-41.7-99.97C403.9 295.1 392.2 288 379.1 288h-97.78l-10.4-48h65.11c17.69 0 32-14.31 32-32s-14.31-32-32-32h-78.98L255.6 169.2C251.8 142.1 227.2 124.8 201.2 128.5C174.1 132.2 156.7 156.5 160.5 182.8l23.68 140.4C185.8 339.6 199.6 352 216 352h141.4l44.86 107.9C407.3 472.3 419.3 480 432 480c3.344 0 6.781-.5313 10.12-1.656l48-16C506.9 456.8 515.9 438.7 510.3 421.9zM160 464c-61.76 0-112-50.24-112-112c0-54.25 38.78-99.55 90.06-109.8L130.1 195C56.06 209 0 273.9 0 352c0 88.37 71.63 160 160 160c77.4 0 141.9-54.97 156.8-128h-49.1C252.9 430.1 210.6 464 160 464zM192 96c26.51 0 48-21.49 48-48S218.5 0 192 0S144 21.49 144 48S165.5 96 192 96z\"\n ]\n};\nvar faWhiskeyGlass = {\n prefix: 'fas',\n iconName: 'whiskey-glass',\n icon: [\n 512,\n 512,\n [\n 129347,\n \"glass-whiskey\"\n ],\n \"f7a0\",\n \"M479.1 32H32.04C12.55 32-2.324 49.25 .3008 68.51L56.29 425.1C60.79 456.6 87.78 480 119.8 480h272.9c31.74 0 58.86-23.38 63.36-54.89l55.61-356.6C514.3 49.25 499.5 32 479.1 32zM422.7 224H89.49L69.39 96h373.2L422.7 224z\"\n ]\n};\nvar faGlassWhiskey = faWhiskeyGlass;\nvar faWifi = {\n prefix: 'fas',\n iconName: 'wifi',\n icon: [\n 640,\n 512,\n [\n \"wifi-3\",\n \"wifi-strong\"\n ],\n \"f1eb\",\n \"M319.1 351.1c-35.35 0-64 28.66-64 64.01s28.66 64.01 64 64.01c35.34 0 64-28.66 64-64.01S355.3 351.1 319.1 351.1zM320 191.1c-70.25 0-137.9 25.6-190.5 72.03C116.3 275.7 115 295.9 126.7 309.2C138.5 322.4 158.7 323.7 171.9 312C212.8 275.9 265.4 256 320 256s107.3 19.88 148.1 56C474.2 317.4 481.8 320 489.3 320c8.844 0 17.66-3.656 24-10.81C525 295.9 523.8 275.7 510.5 264C457.9 217.6 390.3 191.1 320 191.1zM630.2 156.7C546.3 76.28 436.2 32 320 32S93.69 76.28 9.844 156.7c-12.75 12.25-13.16 32.5-.9375 45.25c12.22 12.78 32.47 13.12 45.25 .9375C125.1 133.1 220.4 96 320 96s193.1 37.97 265.8 106.9C592.1 208.8 600 211.8 608 211.8c8.406 0 16.81-3.281 23.09-9.844C643.3 189.2 642.9 168.1 630.2 156.7z\"\n ]\n};\nvar faWifi3 = faWifi;\nvar faWifiStrong = faWifi;\nvar faWind = {\n prefix: 'fas',\n iconName: 'wind',\n icon: [\n 512,\n 512,\n [],\n \"f72e\",\n \"M32 192h320c52.94 0 96-43.06 96-96s-43.06-96-96-96h-32c-17.69 0-32 14.31-32 32s14.31 32 32 32h32c17.66 0 32 14.34 32 32s-14.34 32-32 32H32C14.31 128 0 142.3 0 160S14.31 192 32 192zM160 320H32c-17.69 0-32 14.31-32 32s14.31 32 32 32h128c17.66 0 32 14.34 32 32s-14.34 32-32 32H128c-17.69 0-32 14.31-32 32s14.31 32 32 32h32c52.94 0 96-43.06 96-96S212.9 320 160 320zM416 224H32C14.31 224 0 238.3 0 256s14.31 32 32 32h384c17.66 0 32 14.34 32 32s-14.34 32-32 32h-32c-17.69 0-32 14.31-32 32s14.31 32 32 32h32c52.94 0 96-43.06 96-96S468.9 224 416 224z\"\n ]\n};\nvar faWindowMaximize = {\n prefix: 'fas',\n iconName: 'window-maximize',\n icon: [\n 512,\n 512,\n [\n 128470\n ],\n \"f2d0\",\n \"M448 32C483.3 32 512 60.65 512 96V416C512 451.3 483.3 480 448 480H64C28.65 480 0 451.3 0 416V96C0 60.65 28.65 32 64 32H448zM96 96C78.33 96 64 110.3 64 128C64 145.7 78.33 160 96 160H416C433.7 160 448 145.7 448 128C448 110.3 433.7 96 416 96H96z\"\n ]\n};\nvar faWindowMinimize = {\n prefix: 'fas',\n iconName: 'window-minimize',\n icon: [\n 512,\n 512,\n [\n 128469\n ],\n \"f2d1\",\n \"M0 448C0 430.3 14.33 416 32 416H480C497.7 416 512 430.3 512 448C512 465.7 497.7 480 480 480H32C14.33 480 0 465.7 0 448z\"\n ]\n};\nvar faWindowRestore = {\n prefix: 'fas',\n iconName: 'window-restore',\n icon: [\n 512,\n 512,\n [],\n \"f2d2\",\n \"M432 64H208C199.2 64 192 71.16 192 80V96H128V80C128 35.82 163.8 0 208 0H432C476.2 0 512 35.82 512 80V304C512 348.2 476.2 384 432 384H416V320H432C440.8 320 448 312.8 448 304V80C448 71.16 440.8 64 432 64zM0 192C0 156.7 28.65 128 64 128H320C355.3 128 384 156.7 384 192V448C384 483.3 355.3 512 320 512H64C28.65 512 0 483.3 0 448V192zM96 256H288C305.7 256 320 241.7 320 224C320 206.3 305.7 192 288 192H96C78.33 192 64 206.3 64 224C64 241.7 78.33 256 96 256z\"\n ]\n};\nvar faWineBottle = {\n prefix: 'fas',\n iconName: 'wine-bottle',\n icon: [\n 512,\n 512,\n [],\n \"f72f\",\n \"M507.3 72.57l-67.88-67.88c-6.252-6.25-16.38-6.25-22.63 0l-22.63 22.62c-6.25 6.254-6.251 16.38-.0006 22.63l-76.63 76.63c-46.63-19.75-102.4-10.75-140.4 27.25l-158.4 158.4c-25 25-25 65.51 0 90.51l90.51 90.52c25 25 65.51 25 90.51 0l158.4-158.4c38-38 47-93.76 27.25-140.4l76.63-76.63c6.25 6.25 16.5 6.25 22.75 0l22.63-22.63C513.5 88.95 513.5 78.82 507.3 72.57zM179.3 423.2l-90.51-90.51l122-122l90.51 90.52L179.3 423.2z\"\n ]\n};\nvar faWineGlass = {\n prefix: 'fas',\n iconName: 'wine-glass',\n icon: [\n 320,\n 512,\n [\n 127863\n ],\n \"f4e3\",\n \"M232 464h-40.01v-117.3c68.51-15.88 118-79.86 111.4-154.1L287.5 14.5C286.8 6.25 279.9 0 271.8 0H48.23C40.1 0 33.22 6.25 32.47 14.5L16.6 192.6c-6.626 74.25 42.88 138.2 111.4 154.2V464H87.98c-22.13 0-40.01 17.88-40.01 40c0 4.375 3.626 8 8.002 8h208c4.376 0 8.002-3.625 8.002-8C272 481.9 254.1 464 232 464zM77.72 48h164.6L249.4 128H70.58L77.72 48z\"\n ]\n};\nvar faWineGlassEmpty = {\n prefix: 'fas',\n iconName: 'wine-glass-empty',\n icon: [\n 320,\n 512,\n [\n \"wine-glass-alt\"\n ],\n \"f5ce\",\n \"M232 464h-40.01v-117.3c68.52-15.88 118-79.86 111.4-154.1L287.5 14.5C286.8 6.25 279.9 0 271.8 0H48.23C40.1 0 33.22 6.25 32.47 14.5L16.6 192.6c-6.625 74.25 42.88 138.2 111.4 154.2V464H87.98c-22.13 0-40.01 17.88-40.01 40c0 4.375 3.625 8 8.002 8h208c4.377 0 8.002-3.625 8.002-8C272 481.9 254.1 464 232 464zM180.4 300.2c-13.64 3.16-27.84 3.148-41.48-.0371C91.88 289.2 60.09 245.2 64.38 197.1L77.7 48h164.6L255.6 197.2c4.279 48.01-27.5 91.93-74.46 102.8L180.4 300.2z\"\n ]\n};\nvar faWineGlassAlt = faWineGlassEmpty;\nvar faWonSign = {\n prefix: 'fas',\n iconName: 'won-sign',\n icon: [\n 512,\n 512,\n [\n 8361,\n \"krw\",\n \"won\"\n ],\n \"f159\",\n \"M119.1 224H183L224.1 56.24C228.5 41.99 241.3 32 256 32C270.7 32 283.5 41.99 287 56.24L328.1 224H392.9L449.6 53.88C455.2 37.12 473.4 28.05 490.1 33.64C506.9 39.23 515.9 57.35 510.4 74.12L460.4 224H480C497.7 224 512 238.3 512 256C512 273.7 497.7 288 480 288H439.1L382.4 458.1C377.9 471.6 364.1 480.5 350.8 479.1C336.6 479.4 324.4 469.6 320.1 455.8L279 288H232.1L191 455.8C187.6 469.6 175.4 479.4 161.2 479.1C147 480.5 134.1 471.6 129.6 458.1L72.94 288H32C14.33 288 .001 273.7 .001 256C.001 238.3 14.33 224 32 224H51.6L1.643 74.12C-3.946 57.35 5.115 39.23 21.88 33.64C38.65 28.05 56.77 37.12 62.36 53.88L119.1 224zM140.4 288L155.6 333.6L167 288H140.4zM248.1 224H263L256 195.9L248.1 224zM344.1 288L356.4 333.6L371.6 288H344.1z\"\n ]\n};\nvar faKrw = faWonSign;\nvar faWon = faWonSign;\nvar faWrench = {\n prefix: 'fas',\n iconName: 'wrench',\n icon: [\n 512,\n 512,\n [\n 128295\n ],\n \"f0ad\",\n \"M507.6 122.8c-2.904-12.09-18.25-16.13-27.04-7.338l-76.55 76.56l-83.1-.0002l0-83.1l76.55-76.56c8.791-8.789 4.75-24.14-7.336-27.04c-23.69-5.693-49.34-6.111-75.92 .2484c-61.45 14.7-109.4 66.9-119.2 129.3C189.8 160.8 192.3 186.7 200.1 210.1l-178.1 178.1c-28.12 28.12-28.12 73.69 0 101.8C35.16 504.1 53.56 512 71.1 512s36.84-7.031 50.91-21.09l178.1-178.1c23.46 7.736 49.31 10.24 76.17 6.004c62.41-9.84 114.6-57.8 129.3-119.2C513.7 172.1 513.3 146.5 507.6 122.8zM80 456c-13.25 0-24-10.75-24-24c0-13.26 10.75-24 24-24s24 10.74 24 24C104 445.3 93.25 456 80 456z\"\n ]\n};\nvar faX = {\n prefix: 'fas',\n iconName: 'x',\n icon: [\n 384,\n 512,\n [\n 120\n ],\n \"58\",\n \"M376.6 427.5c11.31 13.58 9.484 33.75-4.094 45.06c-5.984 4.984-13.25 7.422-20.47 7.422c-9.172 0-18.27-3.922-24.59-11.52L192 305.1l-135.4 162.5c-6.328 7.594-15.42 11.52-24.59 11.52c-7.219 0-14.48-2.438-20.47-7.422c-13.58-11.31-15.41-31.48-4.094-45.06l142.9-171.5L7.422 84.5C-3.891 70.92-2.063 50.75 11.52 39.44c13.56-11.34 33.73-9.516 45.06 4.094L192 206l135.4-162.5c11.3-13.58 31.48-15.42 45.06-4.094c13.58 11.31 15.41 31.48 4.094 45.06l-142.9 171.5L376.6 427.5z\"\n ]\n};\nvar faXRay = {\n prefix: 'fas',\n iconName: 'x-ray',\n icon: [\n 512,\n 512,\n [],\n \"f497\",\n \"M208 352C199.2 352 192 359.2 192 368C192 376.8 199.2 384 208 384S224 376.8 224 368C224 359.2 216.8 352 208 352zM304 384c8.836 0 16-7.164 16-16c0-8.838-7.164-16-16-16S288 359.2 288 368C288 376.8 295.2 384 304 384zM496 96C504.8 96 512 88.84 512 80v-32C512 39.16 504.8 32 496 32h-480C7.164 32 0 39.16 0 48v32C0 88.84 7.164 96 16 96H32v320H16C7.164 416 0 423.2 0 432v32C0 472.8 7.164 480 16 480h480c8.836 0 16-7.164 16-16v-32c0-8.836-7.164-16-16-16H480V96H496zM416 216C416 220.4 412.4 224 408 224H272v32h104C380.4 256 384 259.6 384 264v16C384 284.4 380.4 288 376 288H272v32h69.33c25.56 0 40.8 28.48 26.62 49.75l-21.33 32C340.7 410.7 330.7 416 319.1 416H192c-10.7 0-20.69-5.347-26.62-14.25l-21.33-32C129.9 348.5 145.1 320 170.7 320H240V288H136C131.6 288 128 284.4 128 280v-16C128 259.6 131.6 256 136 256H240V224H104C99.6 224 96 220.4 96 216v-16C96 195.6 99.6 192 104 192H240V160H136C131.6 160 128 156.4 128 152v-16C128 131.6 131.6 128 136 128H240V104C240 99.6 243.6 96 248 96h16c4.4 0 8 3.6 8 8V128h104C380.4 128 384 131.6 384 136v16C384 156.4 380.4 160 376 160H272v32h136C412.4 192 416 195.6 416 200V216z\"\n ]\n};\nvar faXmark = {\n prefix: 'fas',\n iconName: 'xmark',\n icon: [\n 320,\n 512,\n [\n 128473,\n 10005,\n 10006,\n 10060,\n 215,\n \"close\",\n \"multiply\",\n \"remove\",\n \"times\"\n ],\n \"f00d\",\n \"M310.6 361.4c12.5 12.5 12.5 32.75 0 45.25C304.4 412.9 296.2 416 288 416s-16.38-3.125-22.62-9.375L160 301.3L54.63 406.6C48.38 412.9 40.19 416 32 416S15.63 412.9 9.375 406.6c-12.5-12.5-12.5-32.75 0-45.25l105.4-105.4L9.375 150.6c-12.5-12.5-12.5-32.75 0-45.25s32.75-12.5 45.25 0L160 210.8l105.4-105.4c12.5-12.5 32.75-12.5 45.25 0s12.5 32.75 0 45.25l-105.4 105.4L310.6 361.4z\"\n ]\n};\nvar faClose = faXmark;\nvar faMultiply = faXmark;\nvar faRemove = faXmark;\nvar faTimes = faXmark;\nvar faY = {\n prefix: 'fas',\n iconName: 'y',\n icon: [\n 384,\n 512,\n [\n 121\n ],\n \"59\",\n \"M378 82.61L224 298.3v149.8c0 17.67-14.31 31.1-32 31.1S160 465.7 160 448V298.3L5.969 82.61C-4.313 68.23-.9688 48.25 13.41 37.97c14.34-10.27 34.38-6.922 44.63 7.453L192 232.1l133.1-187.5c10.28-14.37 30.28-17.7 44.63-7.453C384.1 48.25 388.3 68.23 378 82.61z\"\n ]\n};\nvar faYenSign = {\n prefix: 'fas',\n iconName: 'yen-sign',\n icon: [\n 320,\n 512,\n [\n 165,\n \"cny\",\n \"jpy\",\n \"rmb\",\n \"yen\"\n ],\n \"f157\",\n \"M159.1 198.3L261.4 46.25C271.2 31.54 291 27.57 305.8 37.37C320.5 47.18 324.4 67.04 314.6 81.75L219.8 223.1H272C289.7 223.1 304 238.3 304 255.1C304 273.7 289.7 287.1 272 287.1H192V319.1H272C289.7 319.1 304 334.3 304 352C304 369.7 289.7 384 272 384H192V448C192 465.7 177.7 480 159.1 480C142.3 480 127.1 465.7 127.1 448V384H47.1C30.33 384 15.1 369.7 15.1 352C15.1 334.3 30.33 319.1 47.1 319.1H127.1V287.1H47.1C30.33 287.1 15.1 273.7 15.1 255.1C15.1 238.3 30.33 223.1 47.1 223.1H100.2L5.374 81.75C-4.429 67.04-.456 47.18 14.25 37.37C28.95 27.57 48.82 31.54 58.62 46.25L159.1 198.3z\"\n ]\n};\nvar faCny = faYenSign;\nvar faJpy = faYenSign;\nvar faRmb = faYenSign;\nvar faYen = faYenSign;\nvar faYinYang = {\n prefix: 'fas',\n iconName: 'yin-yang',\n icon: [\n 512,\n 512,\n [\n 9775\n ],\n \"f6ad\",\n \"M256 128C238.3 128 224 142.4 224 160S238.3 192 256 192s31.97-14.38 31.97-32S273.7 128 256 128zM256 0C114.6 0 0 114.6 0 256s114.6 256 256 256s256-114.6 256-256S397.4 0 256 0zM256 384c-17.68 0-31.97-14.38-31.97-32S238.3 320 256 320s31.97 14.38 31.97 32S273.7 384 256 384zM256 256c-53.04 0-96.03 43-96.03 96S202.1 448 256 448c-106.1 0-192.1-86-192.1-192S149.9 64 256 64c53.04 0 96.03 43 96.03 96S309 256 256 256z\"\n ]\n};\nvar faZ = {\n prefix: 'fas',\n iconName: 'z',\n icon: [\n 384,\n 512,\n [\n 122\n ],\n \"5a\",\n \"M384 448c0 17.67-14.31 32-32 32H32c-12.41 0-23.72-7.188-28.97-18.42c-5.281-11.25-3.562-24.53 4.375-34.06l276.3-331.5H32c-17.69 0-32-14.33-32-32s14.31-32 32-32h320c12.41 0 23.72 7.188 28.97 18.42c5.281 11.25 3.562 24.53-4.375 34.06L100.3 416H352C369.7 416 384 430.3 384 448z\"\n ]\n};\nvar _iconsCache = {\n fa0: fa0,\n fa1: fa1,\n fa2: fa2,\n fa3: fa3,\n fa4: fa4,\n fa5: fa5,\n fa6: fa6,\n fa7: fa7,\n fa8: fa8,\n fa9: fa9,\n faA: faA,\n faAddressBook: faAddressBook,\n faContactBook: faContactBook,\n faAddressCard: faAddressCard,\n faContactCard: faContactCard,\n faVcard: faVcard,\n faAlignCenter: faAlignCenter,\n faAlignJustify: faAlignJustify,\n faAlignLeft: faAlignLeft,\n faAlignRight: faAlignRight,\n faAnchor: faAnchor,\n faAngleDown: faAngleDown,\n faAngleLeft: faAngleLeft,\n faAngleRight: faAngleRight,\n faAngleUp: faAngleUp,\n faAnglesDown: faAnglesDown,\n faAngleDoubleDown: faAngleDoubleDown,\n faAnglesLeft: faAnglesLeft,\n faAngleDoubleLeft: faAngleDoubleLeft,\n faAnglesRight: faAnglesRight,\n faAngleDoubleRight: faAngleDoubleRight,\n faAnglesUp: faAnglesUp,\n faAngleDoubleUp: faAngleDoubleUp,\n faAnkh: faAnkh,\n faAppleWhole: faAppleWhole,\n faAppleAlt: faAppleAlt,\n faArchway: faArchway,\n faArrowDown: faArrowDown,\n faArrowDown19: faArrowDown19,\n faSortNumericAsc: faSortNumericAsc,\n faSortNumericDown: faSortNumericDown,\n faArrowDown91: faArrowDown91,\n faSortNumericDesc: faSortNumericDesc,\n faSortNumericDownAlt: faSortNumericDownAlt,\n faArrowDownAZ: faArrowDownAZ,\n faSortAlphaAsc: faSortAlphaAsc,\n faSortAlphaDown: faSortAlphaDown,\n faArrowDownLong: faArrowDownLong,\n faLongArrowDown: faLongArrowDown,\n faArrowDownShortWide: faArrowDownShortWide,\n faSortAmountDesc: faSortAmountDesc,\n faSortAmountDownAlt: faSortAmountDownAlt,\n faArrowDownWideShort: faArrowDownWideShort,\n faSortAmountAsc: faSortAmountAsc,\n faSortAmountDown: faSortAmountDown,\n faArrowDownZA: faArrowDownZA,\n faSortAlphaDesc: faSortAlphaDesc,\n faSortAlphaDownAlt: faSortAlphaDownAlt,\n faArrowLeft: faArrowLeft,\n faArrowLeftLong: faArrowLeftLong,\n faLongArrowLeft: faLongArrowLeft,\n faArrowPointer: faArrowPointer,\n faMousePointer: faMousePointer,\n faArrowRight: faArrowRight,\n faArrowRightArrowLeft: faArrowRightArrowLeft,\n faExchange: faExchange,\n faArrowRightFromBracket: faArrowRightFromBracket,\n faSignOut: faSignOut,\n faArrowRightLong: faArrowRightLong,\n faLongArrowRight: faLongArrowRight,\n faArrowRightToBracket: faArrowRightToBracket,\n faSignIn: faSignIn,\n faArrowRotateLeft: faArrowRotateLeft,\n faArrowLeftRotate: faArrowLeftRotate,\n faArrowRotateBack: faArrowRotateBack,\n faArrowRotateBackward: faArrowRotateBackward,\n faUndo: faUndo,\n faArrowRotateRight: faArrowRotateRight,\n faArrowRightRotate: faArrowRightRotate,\n faArrowRotateForward: faArrowRotateForward,\n faRedo: faRedo,\n faArrowTrendDown: faArrowTrendDown,\n faArrowTrendUp: faArrowTrendUp,\n faArrowTurnDown: faArrowTurnDown,\n faLevelDown: faLevelDown,\n faArrowTurnUp: faArrowTurnUp,\n faLevelUp: faLevelUp,\n faArrowUp: faArrowUp,\n faArrowUp19: faArrowUp19,\n faSortNumericUp: faSortNumericUp,\n faArrowUp91: faArrowUp91,\n faSortNumericUpAlt: faSortNumericUpAlt,\n faArrowUpAZ: faArrowUpAZ,\n faSortAlphaUp: faSortAlphaUp,\n faArrowUpFromBracket: faArrowUpFromBracket,\n faArrowUpLong: faArrowUpLong,\n faLongArrowUp: faLongArrowUp,\n faArrowUpRightFromSquare: faArrowUpRightFromSquare,\n faExternalLink: faExternalLink,\n faArrowUpShortWide: faArrowUpShortWide,\n faSortAmountUpAlt: faSortAmountUpAlt,\n faArrowUpWideShort: faArrowUpWideShort,\n faSortAmountUp: faSortAmountUp,\n faArrowUpZA: faArrowUpZA,\n faSortAlphaUpAlt: faSortAlphaUpAlt,\n faArrowsLeftRight: faArrowsLeftRight,\n faArrowsH: faArrowsH,\n faArrowsRotate: faArrowsRotate,\n faRefresh: faRefresh,\n faSync: faSync,\n faArrowsUpDown: faArrowsUpDown,\n faArrowsV: faArrowsV,\n faArrowsUpDownLeftRight: faArrowsUpDownLeftRight,\n faArrows: faArrows,\n faAsterisk: faAsterisk,\n faAt: faAt,\n faAtom: faAtom,\n faAudioDescription: faAudioDescription,\n faAustralSign: faAustralSign,\n faAward: faAward,\n faB: faB,\n faBaby: faBaby,\n faBabyCarriage: faBabyCarriage,\n faCarriageBaby: faCarriageBaby,\n faBackward: faBackward,\n faBackwardFast: faBackwardFast,\n faFastBackward: faFastBackward,\n faBackwardStep: faBackwardStep,\n faStepBackward: faStepBackward,\n faBacon: faBacon,\n faBacteria: faBacteria,\n faBacterium: faBacterium,\n faBagShopping: faBagShopping,\n faShoppingBag: faShoppingBag,\n faBahai: faBahai,\n faBahtSign: faBahtSign,\n faBan: faBan,\n faCancel: faCancel,\n faBanSmoking: faBanSmoking,\n faSmokingBan: faSmokingBan,\n faBandage: faBandage,\n faBandAid: faBandAid,\n faBarcode: faBarcode,\n faBars: faBars,\n faNavicon: faNavicon,\n faBarsProgress: faBarsProgress,\n faTasksAlt: faTasksAlt,\n faBarsStaggered: faBarsStaggered,\n faReorder: faReorder,\n faStream: faStream,\n faBaseball: faBaseball,\n faBaseballBall: faBaseballBall,\n faBaseballBatBall: faBaseballBatBall,\n faBasketShopping: faBasketShopping,\n faShoppingBasket: faShoppingBasket,\n faBasketball: faBasketball,\n faBasketballBall: faBasketballBall,\n faBath: faBath,\n faBathtub: faBathtub,\n faBatteryEmpty: faBatteryEmpty,\n faBattery0: faBattery0,\n faBatteryFull: faBatteryFull,\n faBattery: faBattery,\n faBattery5: faBattery5,\n faBatteryHalf: faBatteryHalf,\n faBattery3: faBattery3,\n faBatteryQuarter: faBatteryQuarter,\n faBattery2: faBattery2,\n faBatteryThreeQuarters: faBatteryThreeQuarters,\n faBattery4: faBattery4,\n faBed: faBed,\n faBedPulse: faBedPulse,\n faProcedures: faProcedures,\n faBeerMugEmpty: faBeerMugEmpty,\n faBeer: faBeer,\n faBell: faBell,\n faBellConcierge: faBellConcierge,\n faConciergeBell: faConciergeBell,\n faBellSlash: faBellSlash,\n faBezierCurve: faBezierCurve,\n faBicycle: faBicycle,\n faBinoculars: faBinoculars,\n faBiohazard: faBiohazard,\n faBitcoinSign: faBitcoinSign,\n faBlender: faBlender,\n faBlenderPhone: faBlenderPhone,\n faBlog: faBlog,\n faBold: faBold,\n faBolt: faBolt,\n faZap: faZap,\n faBoltLightning: faBoltLightning,\n faBomb: faBomb,\n faBone: faBone,\n faBong: faBong,\n faBook: faBook,\n faBookAtlas: faBookAtlas,\n faAtlas: faAtlas,\n faBookBible: faBookBible,\n faBible: faBible,\n faBookJournalWhills: faBookJournalWhills,\n faJournalWhills: faJournalWhills,\n faBookMedical: faBookMedical,\n faBookOpen: faBookOpen,\n faBookOpenReader: faBookOpenReader,\n faBookReader: faBookReader,\n faBookQuran: faBookQuran,\n faQuran: faQuran,\n faBookSkull: faBookSkull,\n faBookDead: faBookDead,\n faBookmark: faBookmark,\n faBorderAll: faBorderAll,\n faBorderNone: faBorderNone,\n faBorderTopLeft: faBorderTopLeft,\n faBorderStyle: faBorderStyle,\n faBowlingBall: faBowlingBall,\n faBox: faBox,\n faBoxArchive: faBoxArchive,\n faArchive: faArchive,\n faBoxOpen: faBoxOpen,\n faBoxTissue: faBoxTissue,\n faBoxesStacked: faBoxesStacked,\n faBoxes: faBoxes,\n faBoxesAlt: faBoxesAlt,\n faBraille: faBraille,\n faBrain: faBrain,\n faBrazilianRealSign: faBrazilianRealSign,\n faBreadSlice: faBreadSlice,\n faBriefcase: faBriefcase,\n faBriefcaseMedical: faBriefcaseMedical,\n faBroom: faBroom,\n faBroomBall: faBroomBall,\n faQuidditch: faQuidditch,\n faQuidditchBroomBall: faQuidditchBroomBall,\n faBrush: faBrush,\n faBug: faBug,\n faBugSlash: faBugSlash,\n faBuilding: faBuilding,\n faBuildingColumns: faBuildingColumns,\n faBank: faBank,\n faInstitution: faInstitution,\n faMuseum: faMuseum,\n faUniversity: faUniversity,\n faBullhorn: faBullhorn,\n faBullseye: faBullseye,\n faBurger: faBurger,\n faHamburger: faHamburger,\n faBus: faBus,\n faBusSimple: faBusSimple,\n faBusAlt: faBusAlt,\n faBusinessTime: faBusinessTime,\n faBriefcaseClock: faBriefcaseClock,\n faC: faC,\n faCakeCandles: faCakeCandles,\n faBirthdayCake: faBirthdayCake,\n faCake: faCake,\n faCalculator: faCalculator,\n faCalendar: faCalendar,\n faCalendarCheck: faCalendarCheck,\n faCalendarDay: faCalendarDay,\n faCalendarDays: faCalendarDays,\n faCalendarAlt: faCalendarAlt,\n faCalendarMinus: faCalendarMinus,\n faCalendarPlus: faCalendarPlus,\n faCalendarWeek: faCalendarWeek,\n faCalendarXmark: faCalendarXmark,\n faCalendarTimes: faCalendarTimes,\n faCamera: faCamera,\n faCameraAlt: faCameraAlt,\n faCameraRetro: faCameraRetro,\n faCameraRotate: faCameraRotate,\n faCampground: faCampground,\n faCandyCane: faCandyCane,\n faCannabis: faCannabis,\n faCapsules: faCapsules,\n faCar: faCar,\n faAutomobile: faAutomobile,\n faCarBattery: faCarBattery,\n faBatteryCar: faBatteryCar,\n faCarCrash: faCarCrash,\n faCarRear: faCarRear,\n faCarAlt: faCarAlt,\n faCarSide: faCarSide,\n faCaravan: faCaravan,\n faCaretDown: faCaretDown,\n faCaretLeft: faCaretLeft,\n faCaretRight: faCaretRight,\n faCaretUp: faCaretUp,\n faCarrot: faCarrot,\n faCartArrowDown: faCartArrowDown,\n faCartFlatbed: faCartFlatbed,\n faDollyFlatbed: faDollyFlatbed,\n faCartFlatbedSuitcase: faCartFlatbedSuitcase,\n faLuggageCart: faLuggageCart,\n faCartPlus: faCartPlus,\n faCartShopping: faCartShopping,\n faShoppingCart: faShoppingCart,\n faCashRegister: faCashRegister,\n faCat: faCat,\n faCediSign: faCediSign,\n faCentSign: faCentSign,\n faCertificate: faCertificate,\n faChair: faChair,\n faChalkboard: faChalkboard,\n faBlackboard: faBlackboard,\n faChalkboardUser: faChalkboardUser,\n faChalkboardTeacher: faChalkboardTeacher,\n faChampagneGlasses: faChampagneGlasses,\n faGlassCheers: faGlassCheers,\n faChargingStation: faChargingStation,\n faChartArea: faChartArea,\n faAreaChart: faAreaChart,\n faChartBar: faChartBar,\n faBarChart: faBarChart,\n faChartColumn: faChartColumn,\n faChartGantt: faChartGantt,\n faChartLine: faChartLine,\n faLineChart: faLineChart,\n faChartPie: faChartPie,\n faPieChart: faPieChart,\n faCheck: faCheck,\n faCheckDouble: faCheckDouble,\n faCheckToSlot: faCheckToSlot,\n faVoteYea: faVoteYea,\n faCheese: faCheese,\n faChess: faChess,\n faChessBishop: faChessBishop,\n faChessBoard: faChessBoard,\n faChessKing: faChessKing,\n faChessKnight: faChessKnight,\n faChessPawn: faChessPawn,\n faChessQueen: faChessQueen,\n faChessRook: faChessRook,\n faChevronDown: faChevronDown,\n faChevronLeft: faChevronLeft,\n faChevronRight: faChevronRight,\n faChevronUp: faChevronUp,\n faChild: faChild,\n faChurch: faChurch,\n faCircle: faCircle,\n faCircleArrowDown: faCircleArrowDown,\n faArrowCircleDown: faArrowCircleDown,\n faCircleArrowLeft: faCircleArrowLeft,\n faArrowCircleLeft: faArrowCircleLeft,\n faCircleArrowRight: faCircleArrowRight,\n faArrowCircleRight: faArrowCircleRight,\n faCircleArrowUp: faCircleArrowUp,\n faArrowCircleUp: faArrowCircleUp,\n faCircleCheck: faCircleCheck,\n faCheckCircle: faCheckCircle,\n faCircleChevronDown: faCircleChevronDown,\n faChevronCircleDown: faChevronCircleDown,\n faCircleChevronLeft: faCircleChevronLeft,\n faChevronCircleLeft: faChevronCircleLeft,\n faCircleChevronRight: faCircleChevronRight,\n faChevronCircleRight: faChevronCircleRight,\n faCircleChevronUp: faCircleChevronUp,\n faChevronCircleUp: faChevronCircleUp,\n faCircleDollarToSlot: faCircleDollarToSlot,\n faDonate: faDonate,\n faCircleDot: faCircleDot,\n faDotCircle: faDotCircle,\n faCircleDown: faCircleDown,\n faArrowAltCircleDown: faArrowAltCircleDown,\n faCircleExclamation: faCircleExclamation,\n faExclamationCircle: faExclamationCircle,\n faCircleH: faCircleH,\n faHospitalSymbol: faHospitalSymbol,\n faCircleHalfStroke: faCircleHalfStroke,\n faAdjust: faAdjust,\n faCircleInfo: faCircleInfo,\n faInfoCircle: faInfoCircle,\n faCircleLeft: faCircleLeft,\n faArrowAltCircleLeft: faArrowAltCircleLeft,\n faCircleMinus: faCircleMinus,\n faMinusCircle: faMinusCircle,\n faCircleNotch: faCircleNotch,\n faCirclePause: faCirclePause,\n faPauseCircle: faPauseCircle,\n faCirclePlay: faCirclePlay,\n faPlayCircle: faPlayCircle,\n faCirclePlus: faCirclePlus,\n faPlusCircle: faPlusCircle,\n faCircleQuestion: faCircleQuestion,\n faQuestionCircle: faQuestionCircle,\n faCircleRadiation: faCircleRadiation,\n faRadiationAlt: faRadiationAlt,\n faCircleRight: faCircleRight,\n faArrowAltCircleRight: faArrowAltCircleRight,\n faCircleStop: faCircleStop,\n faStopCircle: faStopCircle,\n faCircleUp: faCircleUp,\n faArrowAltCircleUp: faArrowAltCircleUp,\n faCircleUser: faCircleUser,\n faUserCircle: faUserCircle,\n faCircleXmark: faCircleXmark,\n faTimesCircle: faTimesCircle,\n faXmarkCircle: faXmarkCircle,\n faCity: faCity,\n faClapperboard: faClapperboard,\n faClipboard: faClipboard,\n faClipboardCheck: faClipboardCheck,\n faClipboardList: faClipboardList,\n faClock: faClock,\n faClockFour: faClockFour,\n faClockRotateLeft: faClockRotateLeft,\n faHistory: faHistory,\n faClone: faClone,\n faClosedCaptioning: faClosedCaptioning,\n faCloud: faCloud,\n faCloudArrowDown: faCloudArrowDown,\n faCloudDownload: faCloudDownload,\n faCloudDownloadAlt: faCloudDownloadAlt,\n faCloudArrowUp: faCloudArrowUp,\n faCloudUpload: faCloudUpload,\n faCloudUploadAlt: faCloudUploadAlt,\n faCloudMeatball: faCloudMeatball,\n faCloudMoon: faCloudMoon,\n faCloudMoonRain: faCloudMoonRain,\n faCloudRain: faCloudRain,\n faCloudShowersHeavy: faCloudShowersHeavy,\n faCloudSun: faCloudSun,\n faCloudSunRain: faCloudSunRain,\n faClover: faClover,\n faCode: faCode,\n faCodeBranch: faCodeBranch,\n faCodeCommit: faCodeCommit,\n faCodeCompare: faCodeCompare,\n faCodeFork: faCodeFork,\n faCodeMerge: faCodeMerge,\n faCodePullRequest: faCodePullRequest,\n faCoins: faCoins,\n faColonSign: faColonSign,\n faComment: faComment,\n faCommentDollar: faCommentDollar,\n faCommentDots: faCommentDots,\n faCommenting: faCommenting,\n faCommentMedical: faCommentMedical,\n faCommentSlash: faCommentSlash,\n faCommentSms: faCommentSms,\n faSms: faSms,\n faComments: faComments,\n faCommentsDollar: faCommentsDollar,\n faCompactDisc: faCompactDisc,\n faCompass: faCompass,\n faCompassDrafting: faCompassDrafting,\n faDraftingCompass: faDraftingCompass,\n faCompress: faCompress,\n faComputerMouse: faComputerMouse,\n faMouse: faMouse,\n faCookie: faCookie,\n faCookieBite: faCookieBite,\n faCopy: faCopy,\n faCopyright: faCopyright,\n faCouch: faCouch,\n faCreditCard: faCreditCard,\n faCreditCardAlt: faCreditCardAlt,\n faCrop: faCrop,\n faCropSimple: faCropSimple,\n faCropAlt: faCropAlt,\n faCross: faCross,\n faCrosshairs: faCrosshairs,\n faCrow: faCrow,\n faCrown: faCrown,\n faCrutch: faCrutch,\n faCruzeiroSign: faCruzeiroSign,\n faCube: faCube,\n faCubes: faCubes,\n faD: faD,\n faDatabase: faDatabase,\n faDeleteLeft: faDeleteLeft,\n faBackspace: faBackspace,\n faDemocrat: faDemocrat,\n faDesktop: faDesktop,\n faDesktopAlt: faDesktopAlt,\n faDharmachakra: faDharmachakra,\n faDiagramNext: faDiagramNext,\n faDiagramPredecessor: faDiagramPredecessor,\n faDiagramProject: faDiagramProject,\n faProjectDiagram: faProjectDiagram,\n faDiagramSuccessor: faDiagramSuccessor,\n faDiamond: faDiamond,\n faDiamondTurnRight: faDiamondTurnRight,\n faDirections: faDirections,\n faDice: faDice,\n faDiceD20: faDiceD20,\n faDiceD6: faDiceD6,\n faDiceFive: faDiceFive,\n faDiceFour: faDiceFour,\n faDiceOne: faDiceOne,\n faDiceSix: faDiceSix,\n faDiceThree: faDiceThree,\n faDiceTwo: faDiceTwo,\n faDisease: faDisease,\n faDivide: faDivide,\n faDna: faDna,\n faDog: faDog,\n faDollarSign: faDollarSign,\n faDollar: faDollar,\n faUsd: faUsd,\n faDolly: faDolly,\n faDollyBox: faDollyBox,\n faDongSign: faDongSign,\n faDoorClosed: faDoorClosed,\n faDoorOpen: faDoorOpen,\n faDove: faDove,\n faDownLeftAndUpRightToCenter: faDownLeftAndUpRightToCenter,\n faCompressAlt: faCompressAlt,\n faDownLong: faDownLong,\n faLongArrowAltDown: faLongArrowAltDown,\n faDownload: faDownload,\n faDragon: faDragon,\n faDrawPolygon: faDrawPolygon,\n faDroplet: faDroplet,\n faTint: faTint,\n faDropletSlash: faDropletSlash,\n faTintSlash: faTintSlash,\n faDrum: faDrum,\n faDrumSteelpan: faDrumSteelpan,\n faDrumstickBite: faDrumstickBite,\n faDumbbell: faDumbbell,\n faDumpster: faDumpster,\n faDumpsterFire: faDumpsterFire,\n faDungeon: faDungeon,\n faE: faE,\n faEarDeaf: faEarDeaf,\n faDeaf: faDeaf,\n faDeafness: faDeafness,\n faHardOfHearing: faHardOfHearing,\n faEarListen: faEarListen,\n faAssistiveListeningSystems: faAssistiveListeningSystems,\n faEarthAfrica: faEarthAfrica,\n faGlobeAfrica: faGlobeAfrica,\n faEarthAmericas: faEarthAmericas,\n faEarth: faEarth,\n faEarthAmerica: faEarthAmerica,\n faGlobeAmericas: faGlobeAmericas,\n faEarthAsia: faEarthAsia,\n faGlobeAsia: faGlobeAsia,\n faEarthEurope: faEarthEurope,\n faGlobeEurope: faGlobeEurope,\n faEarthOceania: faEarthOceania,\n faGlobeOceania: faGlobeOceania,\n faEgg: faEgg,\n faEject: faEject,\n faElevator: faElevator,\n faEllipsis: faEllipsis,\n faEllipsisH: faEllipsisH,\n faEllipsisVertical: faEllipsisVertical,\n faEllipsisV: faEllipsisV,\n faEnvelope: faEnvelope,\n faEnvelopeOpen: faEnvelopeOpen,\n faEnvelopeOpenText: faEnvelopeOpenText,\n faEnvelopesBulk: faEnvelopesBulk,\n faMailBulk: faMailBulk,\n faEquals: faEquals,\n faEraser: faEraser,\n faEthernet: faEthernet,\n faEuroSign: faEuroSign,\n faEur: faEur,\n faEuro: faEuro,\n faExclamation: faExclamation,\n faExpand: faExpand,\n faEye: faEye,\n faEyeDropper: faEyeDropper,\n faEyeDropperEmpty: faEyeDropperEmpty,\n faEyedropper: faEyedropper,\n faEyeLowVision: faEyeLowVision,\n faLowVision: faLowVision,\n faEyeSlash: faEyeSlash,\n faF: faF,\n faFaceAngry: faFaceAngry,\n faAngry: faAngry,\n faFaceDizzy: faFaceDizzy,\n faDizzy: faDizzy,\n faFaceFlushed: faFaceFlushed,\n faFlushed: faFlushed,\n faFaceFrown: faFaceFrown,\n faFrown: faFrown,\n faFaceFrownOpen: faFaceFrownOpen,\n faFrownOpen: faFrownOpen,\n faFaceGrimace: faFaceGrimace,\n faGrimace: faGrimace,\n faFaceGrin: faFaceGrin,\n faGrin: faGrin,\n faFaceGrinBeam: faFaceGrinBeam,\n faGrinBeam: faGrinBeam,\n faFaceGrinBeamSweat: faFaceGrinBeamSweat,\n faGrinBeamSweat: faGrinBeamSweat,\n faFaceGrinHearts: faFaceGrinHearts,\n faGrinHearts: faGrinHearts,\n faFaceGrinSquint: faFaceGrinSquint,\n faGrinSquint: faGrinSquint,\n faFaceGrinSquintTears: faFaceGrinSquintTears,\n faGrinSquintTears: faGrinSquintTears,\n faFaceGrinStars: faFaceGrinStars,\n faGrinStars: faGrinStars,\n faFaceGrinTears: faFaceGrinTears,\n faGrinTears: faGrinTears,\n faFaceGrinTongue: faFaceGrinTongue,\n faGrinTongue: faGrinTongue,\n faFaceGrinTongueSquint: faFaceGrinTongueSquint,\n faGrinTongueSquint: faGrinTongueSquint,\n faFaceGrinTongueWink: faFaceGrinTongueWink,\n faGrinTongueWink: faGrinTongueWink,\n faFaceGrinWide: faFaceGrinWide,\n faGrinAlt: faGrinAlt,\n faFaceGrinWink: faFaceGrinWink,\n faGrinWink: faGrinWink,\n faFaceKiss: faFaceKiss,\n faKiss: faKiss,\n faFaceKissBeam: faFaceKissBeam,\n faKissBeam: faKissBeam,\n faFaceKissWinkHeart: faFaceKissWinkHeart,\n faKissWinkHeart: faKissWinkHeart,\n faFaceLaugh: faFaceLaugh,\n faLaugh: faLaugh,\n faFaceLaughBeam: faFaceLaughBeam,\n faLaughBeam: faLaughBeam,\n faFaceLaughSquint: faFaceLaughSquint,\n faLaughSquint: faLaughSquint,\n faFaceLaughWink: faFaceLaughWink,\n faLaughWink: faLaughWink,\n faFaceMeh: faFaceMeh,\n faMeh: faMeh,\n faFaceMehBlank: faFaceMehBlank,\n faMehBlank: faMehBlank,\n faFaceRollingEyes: faFaceRollingEyes,\n faMehRollingEyes: faMehRollingEyes,\n faFaceSadCry: faFaceSadCry,\n faSadCry: faSadCry,\n faFaceSadTear: faFaceSadTear,\n faSadTear: faSadTear,\n faFaceSmile: faFaceSmile,\n faSmile: faSmile,\n faFaceSmileBeam: faFaceSmileBeam,\n faSmileBeam: faSmileBeam,\n faFaceSmileWink: faFaceSmileWink,\n faSmileWink: faSmileWink,\n faFaceSurprise: faFaceSurprise,\n faSurprise: faSurprise,\n faFaceTired: faFaceTired,\n faTired: faTired,\n faFan: faFan,\n faFaucet: faFaucet,\n faFax: faFax,\n faFeather: faFeather,\n faFeatherPointed: faFeatherPointed,\n faFeatherAlt: faFeatherAlt,\n faFile: faFile,\n faFileArrowDown: faFileArrowDown,\n faFileDownload: faFileDownload,\n faFileArrowUp: faFileArrowUp,\n faFileUpload: faFileUpload,\n faFileAudio: faFileAudio,\n faFileCode: faFileCode,\n faFileContract: faFileContract,\n faFileCsv: faFileCsv,\n faFileExcel: faFileExcel,\n faFileExport: faFileExport,\n faArrowRightFromFile: faArrowRightFromFile,\n faFileImage: faFileImage,\n faFileImport: faFileImport,\n faArrowRightToFile: faArrowRightToFile,\n faFileInvoice: faFileInvoice,\n faFileInvoiceDollar: faFileInvoiceDollar,\n faFileLines: faFileLines,\n faFileAlt: faFileAlt,\n faFileText: faFileText,\n faFileMedical: faFileMedical,\n faFilePdf: faFilePdf,\n faFilePowerpoint: faFilePowerpoint,\n faFilePrescription: faFilePrescription,\n faFileSignature: faFileSignature,\n faFileVideo: faFileVideo,\n faFileWaveform: faFileWaveform,\n faFileMedicalAlt: faFileMedicalAlt,\n faFileWord: faFileWord,\n faFileZipper: faFileZipper,\n faFileArchive: faFileArchive,\n faFill: faFill,\n faFillDrip: faFillDrip,\n faFilm: faFilm,\n faFilter: faFilter,\n faFilterCircleDollar: faFilterCircleDollar,\n faFunnelDollar: faFunnelDollar,\n faFilterCircleXmark: faFilterCircleXmark,\n faFingerprint: faFingerprint,\n faFire: faFire,\n faFireExtinguisher: faFireExtinguisher,\n faFireFlameCurved: faFireFlameCurved,\n faFireAlt: faFireAlt,\n faFireFlameSimple: faFireFlameSimple,\n faBurn: faBurn,\n faFish: faFish,\n faFlag: faFlag,\n faFlagCheckered: faFlagCheckered,\n faFlagUsa: faFlagUsa,\n faFlask: faFlask,\n faFloppyDisk: faFloppyDisk,\n faSave: faSave,\n faFlorinSign: faFlorinSign,\n faFolder: faFolder,\n faFolderMinus: faFolderMinus,\n faFolderOpen: faFolderOpen,\n faFolderPlus: faFolderPlus,\n faFolderTree: faFolderTree,\n faFont: faFont,\n faFontAwesome: faFontAwesome,\n faFontAwesomeFlag: faFontAwesomeFlag,\n faFontAwesomeLogoFull: faFontAwesomeLogoFull,\n faFootball: faFootball,\n faFootballBall: faFootballBall,\n faForward: faForward,\n faForwardFast: faForwardFast,\n faFastForward: faFastForward,\n faForwardStep: faForwardStep,\n faStepForward: faStepForward,\n faFrancSign: faFrancSign,\n faFrog: faFrog,\n faFutbol: faFutbol,\n faFutbolBall: faFutbolBall,\n faSoccerBall: faSoccerBall,\n faG: faG,\n faGamepad: faGamepad,\n faGasPump: faGasPump,\n faGauge: faGauge,\n faDashboard: faDashboard,\n faGaugeMed: faGaugeMed,\n faTachometerAltAverage: faTachometerAltAverage,\n faGaugeHigh: faGaugeHigh,\n faTachometerAlt: faTachometerAlt,\n faTachometerAltFast: faTachometerAltFast,\n faGaugeSimple: faGaugeSimple,\n faGaugeSimpleMed: faGaugeSimpleMed,\n faTachometerAverage: faTachometerAverage,\n faGaugeSimpleHigh: faGaugeSimpleHigh,\n faTachometer: faTachometer,\n faTachometerFast: faTachometerFast,\n faGavel: faGavel,\n faLegal: faLegal,\n faGear: faGear,\n faCog: faCog,\n faGears: faGears,\n faCogs: faCogs,\n faGem: faGem,\n faGenderless: faGenderless,\n faGhost: faGhost,\n faGift: faGift,\n faGifts: faGifts,\n faGlasses: faGlasses,\n faGlobe: faGlobe,\n faGolfBallTee: faGolfBallTee,\n faGolfBall: faGolfBall,\n faGopuram: faGopuram,\n faGraduationCap: faGraduationCap,\n faMortarBoard: faMortarBoard,\n faGreaterThan: faGreaterThan,\n faGreaterThanEqual: faGreaterThanEqual,\n faGrip: faGrip,\n faGripHorizontal: faGripHorizontal,\n faGripLines: faGripLines,\n faGripLinesVertical: faGripLinesVertical,\n faGripVertical: faGripVertical,\n faGuaraniSign: faGuaraniSign,\n faGuitar: faGuitar,\n faGun: faGun,\n faH: faH,\n faHammer: faHammer,\n faHamsa: faHamsa,\n faHand: faHand,\n faHandPaper: faHandPaper,\n faHandBackFist: faHandBackFist,\n faHandRock: faHandRock,\n faHandDots: faHandDots,\n faAllergies: faAllergies,\n faHandFist: faHandFist,\n faFistRaised: faFistRaised,\n faHandHolding: faHandHolding,\n faHandHoldingDollar: faHandHoldingDollar,\n faHandHoldingUsd: faHandHoldingUsd,\n faHandHoldingDroplet: faHandHoldingDroplet,\n faHandHoldingWater: faHandHoldingWater,\n faHandHoldingHeart: faHandHoldingHeart,\n faHandHoldingMedical: faHandHoldingMedical,\n faHandLizard: faHandLizard,\n faHandMiddleFinger: faHandMiddleFinger,\n faHandPeace: faHandPeace,\n faHandPointDown: faHandPointDown,\n faHandPointLeft: faHandPointLeft,\n faHandPointRight: faHandPointRight,\n faHandPointUp: faHandPointUp,\n faHandPointer: faHandPointer,\n faHandScissors: faHandScissors,\n faHandSparkles: faHandSparkles,\n faHandSpock: faHandSpock,\n faHands: faHands,\n faSignLanguage: faSignLanguage,\n faSigning: faSigning,\n faHandsAslInterpreting: faHandsAslInterpreting,\n faAmericanSignLanguageInterpreting: faAmericanSignLanguageInterpreting,\n faAslInterpreting: faAslInterpreting,\n faHandsAmericanSignLanguageInterpreting: faHandsAmericanSignLanguageInterpreting,\n faHandsBubbles: faHandsBubbles,\n faHandsWash: faHandsWash,\n faHandsClapping: faHandsClapping,\n faHandsHolding: faHandsHolding,\n faHandsPraying: faHandsPraying,\n faPrayingHands: faPrayingHands,\n faHandshake: faHandshake,\n faHandshakeAngle: faHandshakeAngle,\n faHandsHelping: faHandsHelping,\n faHandshakeSimpleSlash: faHandshakeSimpleSlash,\n faHandshakeAltSlash: faHandshakeAltSlash,\n faHandshakeSlash: faHandshakeSlash,\n faHanukiah: faHanukiah,\n faHardDrive: faHardDrive,\n faHdd: faHdd,\n faHashtag: faHashtag,\n faHatCowboy: faHatCowboy,\n faHatCowboySide: faHatCowboySide,\n faHatWizard: faHatWizard,\n faHeadSideCough: faHeadSideCough,\n faHeadSideCoughSlash: faHeadSideCoughSlash,\n faHeadSideMask: faHeadSideMask,\n faHeadSideVirus: faHeadSideVirus,\n faHeading: faHeading,\n faHeader: faHeader,\n faHeadphones: faHeadphones,\n faHeadphonesSimple: faHeadphonesSimple,\n faHeadphonesAlt: faHeadphonesAlt,\n faHeadset: faHeadset,\n faHeart: faHeart,\n faHeartCrack: faHeartCrack,\n faHeartBroken: faHeartBroken,\n faHeartPulse: faHeartPulse,\n faHeartbeat: faHeartbeat,\n faHelicopter: faHelicopter,\n faHelmetSafety: faHelmetSafety,\n faHardHat: faHardHat,\n faHatHard: faHatHard,\n faHighlighter: faHighlighter,\n faHippo: faHippo,\n faHockeyPuck: faHockeyPuck,\n faHollyBerry: faHollyBerry,\n faHorse: faHorse,\n faHorseHead: faHorseHead,\n faHospital: faHospital,\n faHospitalAlt: faHospitalAlt,\n faHospitalWide: faHospitalWide,\n faHospitalUser: faHospitalUser,\n faHotTubPerson: faHotTubPerson,\n faHotTub: faHotTub,\n faHotdog: faHotdog,\n faHotel: faHotel,\n faHourglass: faHourglass,\n faHourglass2: faHourglass2,\n faHourglassHalf: faHourglassHalf,\n faHourglassEmpty: faHourglassEmpty,\n faHourglassEnd: faHourglassEnd,\n faHourglass3: faHourglass3,\n faHourglassStart: faHourglassStart,\n faHourglass1: faHourglass1,\n faHouse: faHouse,\n faHome: faHome,\n faHomeAlt: faHomeAlt,\n faHomeLgAlt: faHomeLgAlt,\n faHouseChimney: faHouseChimney,\n faHomeLg: faHomeLg,\n faHouseChimneyCrack: faHouseChimneyCrack,\n faHouseDamage: faHouseDamage,\n faHouseChimneyMedical: faHouseChimneyMedical,\n faClinicMedical: faClinicMedical,\n faHouseChimneyUser: faHouseChimneyUser,\n faHouseChimneyWindow: faHouseChimneyWindow,\n faHouseCrack: faHouseCrack,\n faHouseLaptop: faHouseLaptop,\n faLaptopHouse: faLaptopHouse,\n faHouseMedical: faHouseMedical,\n faHouseUser: faHouseUser,\n faHomeUser: faHomeUser,\n faHryvniaSign: faHryvniaSign,\n faHryvnia: faHryvnia,\n faI: faI,\n faICursor: faICursor,\n faIceCream: faIceCream,\n faIcicles: faIcicles,\n faIcons: faIcons,\n faHeartMusicCameraBolt: faHeartMusicCameraBolt,\n faIdBadge: faIdBadge,\n faIdCard: faIdCard,\n faDriversLicense: faDriversLicense,\n faIdCardClip: faIdCardClip,\n faIdCardAlt: faIdCardAlt,\n faIgloo: faIgloo,\n faImage: faImage,\n faImagePortrait: faImagePortrait,\n faPortrait: faPortrait,\n faImages: faImages,\n faInbox: faInbox,\n faIndent: faIndent,\n faIndianRupeeSign: faIndianRupeeSign,\n faIndianRupee: faIndianRupee,\n faInr: faInr,\n faIndustry: faIndustry,\n faInfinity: faInfinity,\n faInfo: faInfo,\n faItalic: faItalic,\n faJ: faJ,\n faJedi: faJedi,\n faJetFighter: faJetFighter,\n faFighterJet: faFighterJet,\n faJoint: faJoint,\n faK: faK,\n faKaaba: faKaaba,\n faKey: faKey,\n faKeyboard: faKeyboard,\n faKhanda: faKhanda,\n faKipSign: faKipSign,\n faKitMedical: faKitMedical,\n faFirstAid: faFirstAid,\n faKiwiBird: faKiwiBird,\n faL: faL,\n faLandmark: faLandmark,\n faLanguage: faLanguage,\n faLaptop: faLaptop,\n faLaptopCode: faLaptopCode,\n faLaptopMedical: faLaptopMedical,\n faLariSign: faLariSign,\n faLayerGroup: faLayerGroup,\n faLeaf: faLeaf,\n faLeftLong: faLeftLong,\n faLongArrowAltLeft: faLongArrowAltLeft,\n faLeftRight: faLeftRight,\n faArrowsAltH: faArrowsAltH,\n faLemon: faLemon,\n faLessThan: faLessThan,\n faLessThanEqual: faLessThanEqual,\n faLifeRing: faLifeRing,\n faLightbulb: faLightbulb,\n faLink: faLink,\n faChain: faChain,\n faLinkSlash: faLinkSlash,\n faChainBroken: faChainBroken,\n faChainSlash: faChainSlash,\n faUnlink: faUnlink,\n faLiraSign: faLiraSign,\n faList: faList,\n faListSquares: faListSquares,\n faListCheck: faListCheck,\n faTasks: faTasks,\n faListOl: faListOl,\n faList12: faList12,\n faListNumeric: faListNumeric,\n faListUl: faListUl,\n faListDots: faListDots,\n faLitecoinSign: faLitecoinSign,\n faLocationArrow: faLocationArrow,\n faLocationCrosshairs: faLocationCrosshairs,\n faLocation: faLocation,\n faLocationDot: faLocationDot,\n faMapMarkerAlt: faMapMarkerAlt,\n faLocationPin: faLocationPin,\n faMapMarker: faMapMarker,\n faLock: faLock,\n faLockOpen: faLockOpen,\n faLungs: faLungs,\n faLungsVirus: faLungsVirus,\n faM: faM,\n faMagnet: faMagnet,\n faMagnifyingGlass: faMagnifyingGlass,\n faSearch: faSearch,\n faMagnifyingGlassDollar: faMagnifyingGlassDollar,\n faSearchDollar: faSearchDollar,\n faMagnifyingGlassLocation: faMagnifyingGlassLocation,\n faSearchLocation: faSearchLocation,\n faMagnifyingGlassMinus: faMagnifyingGlassMinus,\n faSearchMinus: faSearchMinus,\n faMagnifyingGlassPlus: faMagnifyingGlassPlus,\n faSearchPlus: faSearchPlus,\n faManatSign: faManatSign,\n faMap: faMap,\n faMapLocation: faMapLocation,\n faMapMarked: faMapMarked,\n faMapLocationDot: faMapLocationDot,\n faMapMarkedAlt: faMapMarkedAlt,\n faMapPin: faMapPin,\n faMarker: faMarker,\n faMars: faMars,\n faMarsAndVenus: faMarsAndVenus,\n faMarsDouble: faMarsDouble,\n faMarsStroke: faMarsStroke,\n faMarsStrokeRight: faMarsStrokeRight,\n faMarsStrokeH: faMarsStrokeH,\n faMarsStrokeUp: faMarsStrokeUp,\n faMarsStrokeV: faMarsStrokeV,\n faMartiniGlass: faMartiniGlass,\n faGlassMartiniAlt: faGlassMartiniAlt,\n faMartiniGlassCitrus: faMartiniGlassCitrus,\n faCocktail: faCocktail,\n faMartiniGlassEmpty: faMartiniGlassEmpty,\n faGlassMartini: faGlassMartini,\n faMask: faMask,\n faMaskFace: faMaskFace,\n faMasksTheater: faMasksTheater,\n faTheaterMasks: faTheaterMasks,\n faMaximize: faMaximize,\n faExpandArrowsAlt: faExpandArrowsAlt,\n faMedal: faMedal,\n faMemory: faMemory,\n faMenorah: faMenorah,\n faMercury: faMercury,\n faMessage: faMessage,\n faCommentAlt: faCommentAlt,\n faMeteor: faMeteor,\n faMicrochip: faMicrochip,\n faMicrophone: faMicrophone,\n faMicrophoneLines: faMicrophoneLines,\n faMicrophoneAlt: faMicrophoneAlt,\n faMicrophoneLinesSlash: faMicrophoneLinesSlash,\n faMicrophoneAltSlash: faMicrophoneAltSlash,\n faMicrophoneSlash: faMicrophoneSlash,\n faMicroscope: faMicroscope,\n faMillSign: faMillSign,\n faMinimize: faMinimize,\n faCompressArrowsAlt: faCompressArrowsAlt,\n faMinus: faMinus,\n faSubtract: faSubtract,\n faMitten: faMitten,\n faMobile: faMobile,\n faMobileAndroid: faMobileAndroid,\n faMobilePhone: faMobilePhone,\n faMobileButton: faMobileButton,\n faMobileScreenButton: faMobileScreenButton,\n faMobileAlt: faMobileAlt,\n faMoneyBill: faMoneyBill,\n faMoneyBill1: faMoneyBill1,\n faMoneyBillAlt: faMoneyBillAlt,\n faMoneyBill1Wave: faMoneyBill1Wave,\n faMoneyBillWaveAlt: faMoneyBillWaveAlt,\n faMoneyBillWave: faMoneyBillWave,\n faMoneyCheck: faMoneyCheck,\n faMoneyCheckDollar: faMoneyCheckDollar,\n faMoneyCheckAlt: faMoneyCheckAlt,\n faMonument: faMonument,\n faMoon: faMoon,\n faMortarPestle: faMortarPestle,\n faMosque: faMosque,\n faMotorcycle: faMotorcycle,\n faMountain: faMountain,\n faMugHot: faMugHot,\n faMugSaucer: faMugSaucer,\n faCoffee: faCoffee,\n faMusic: faMusic,\n faN: faN,\n faNairaSign: faNairaSign,\n faNetworkWired: faNetworkWired,\n faNeuter: faNeuter,\n faNewspaper: faNewspaper,\n faNotEqual: faNotEqual,\n faNoteSticky: faNoteSticky,\n faStickyNote: faStickyNote,\n faNotesMedical: faNotesMedical,\n faO: faO,\n faObjectGroup: faObjectGroup,\n faObjectUngroup: faObjectUngroup,\n faOilCan: faOilCan,\n faOm: faOm,\n faOtter: faOtter,\n faOutdent: faOutdent,\n faDedent: faDedent,\n faP: faP,\n faPager: faPager,\n faPaintRoller: faPaintRoller,\n faPaintbrush: faPaintbrush,\n faPaintBrush: faPaintBrush,\n faPalette: faPalette,\n faPallet: faPallet,\n faPanorama: faPanorama,\n faPaperPlane: faPaperPlane,\n faPaperclip: faPaperclip,\n faParachuteBox: faParachuteBox,\n faParagraph: faParagraph,\n faPassport: faPassport,\n faPaste: faPaste,\n faFileClipboard: faFileClipboard,\n faPause: faPause,\n faPaw: faPaw,\n faPeace: faPeace,\n faPen: faPen,\n faPenClip: faPenClip,\n faPenAlt: faPenAlt,\n faPenFancy: faPenFancy,\n faPenNib: faPenNib,\n faPenRuler: faPenRuler,\n faPencilRuler: faPencilRuler,\n faPenToSquare: faPenToSquare,\n faEdit: faEdit,\n faPencil: faPencil,\n faPencilAlt: faPencilAlt,\n faPeopleArrowsLeftRight: faPeopleArrowsLeftRight,\n faPeopleArrows: faPeopleArrows,\n faPeopleCarryBox: faPeopleCarryBox,\n faPeopleCarry: faPeopleCarry,\n faPepperHot: faPepperHot,\n faPercent: faPercent,\n faPercentage: faPercentage,\n faPerson: faPerson,\n faMale: faMale,\n faPersonBiking: faPersonBiking,\n faBiking: faBiking,\n faPersonBooth: faPersonBooth,\n faPersonDotsFromLine: faPersonDotsFromLine,\n faDiagnoses: faDiagnoses,\n faPersonDress: faPersonDress,\n faFemale: faFemale,\n faPersonHiking: faPersonHiking,\n faHiking: faHiking,\n faPersonPraying: faPersonPraying,\n faPray: faPray,\n faPersonRunning: faPersonRunning,\n faRunning: faRunning,\n faPersonSkating: faPersonSkating,\n faSkating: faSkating,\n faPersonSkiing: faPersonSkiing,\n faSkiing: faSkiing,\n faPersonSkiingNordic: faPersonSkiingNordic,\n faSkiingNordic: faSkiingNordic,\n faPersonSnowboarding: faPersonSnowboarding,\n faSnowboarding: faSnowboarding,\n faPersonSwimming: faPersonSwimming,\n faSwimmer: faSwimmer,\n faPersonWalking: faPersonWalking,\n faWalking: faWalking,\n faPersonWalkingWithCane: faPersonWalkingWithCane,\n faBlind: faBlind,\n faPesetaSign: faPesetaSign,\n faPesoSign: faPesoSign,\n faPhone: faPhone,\n faPhoneFlip: faPhoneFlip,\n faPhoneAlt: faPhoneAlt,\n faPhoneSlash: faPhoneSlash,\n faPhoneVolume: faPhoneVolume,\n faVolumeControlPhone: faVolumeControlPhone,\n faPhotoFilm: faPhotoFilm,\n faPhotoVideo: faPhotoVideo,\n faPiggyBank: faPiggyBank,\n faPills: faPills,\n faPizzaSlice: faPizzaSlice,\n faPlaceOfWorship: faPlaceOfWorship,\n faPlane: faPlane,\n faPlaneArrival: faPlaneArrival,\n faPlaneDeparture: faPlaneDeparture,\n faPlaneSlash: faPlaneSlash,\n faPlay: faPlay,\n faPlug: faPlug,\n faPlus: faPlus,\n faAdd: faAdd,\n faPlusMinus: faPlusMinus,\n faPodcast: faPodcast,\n faPoo: faPoo,\n faPooStorm: faPooStorm,\n faPooBolt: faPooBolt,\n faPoop: faPoop,\n faPowerOff: faPowerOff,\n faPrescription: faPrescription,\n faPrescriptionBottle: faPrescriptionBottle,\n faPrescriptionBottleMedical: faPrescriptionBottleMedical,\n faPrescriptionBottleAlt: faPrescriptionBottleAlt,\n faPrint: faPrint,\n faPumpMedical: faPumpMedical,\n faPumpSoap: faPumpSoap,\n faPuzzlePiece: faPuzzlePiece,\n faQ: faQ,\n faQrcode: faQrcode,\n faQuestion: faQuestion,\n faQuoteLeft: faQuoteLeft,\n faQuoteLeftAlt: faQuoteLeftAlt,\n faQuoteRight: faQuoteRight,\n faQuoteRightAlt: faQuoteRightAlt,\n faR: faR,\n faRadiation: faRadiation,\n faRainbow: faRainbow,\n faReceipt: faReceipt,\n faRecordVinyl: faRecordVinyl,\n faRectangleAd: faRectangleAd,\n faAd: faAd,\n faRectangleList: faRectangleList,\n faListAlt: faListAlt,\n faRectangleXmark: faRectangleXmark,\n faRectangleTimes: faRectangleTimes,\n faTimesRectangle: faTimesRectangle,\n faWindowClose: faWindowClose,\n faRecycle: faRecycle,\n faRegistered: faRegistered,\n faRepeat: faRepeat,\n faReply: faReply,\n faMailReply: faMailReply,\n faReplyAll: faReplyAll,\n faMailReplyAll: faMailReplyAll,\n faRepublican: faRepublican,\n faRestroom: faRestroom,\n faRetweet: faRetweet,\n faRibbon: faRibbon,\n faRightFromBracket: faRightFromBracket,\n faSignOutAlt: faSignOutAlt,\n faRightLeft: faRightLeft,\n faExchangeAlt: faExchangeAlt,\n faRightLong: faRightLong,\n faLongArrowAltRight: faLongArrowAltRight,\n faRightToBracket: faRightToBracket,\n faSignInAlt: faSignInAlt,\n faRing: faRing,\n faRoad: faRoad,\n faRobot: faRobot,\n faRocket: faRocket,\n faRotate: faRotate,\n faSyncAlt: faSyncAlt,\n faRotateLeft: faRotateLeft,\n faRotateBack: faRotateBack,\n faRotateBackward: faRotateBackward,\n faUndoAlt: faUndoAlt,\n faRotateRight: faRotateRight,\n faRedoAlt: faRedoAlt,\n faRotateForward: faRotateForward,\n faRoute: faRoute,\n faRss: faRss,\n faFeed: faFeed,\n faRubleSign: faRubleSign,\n faRouble: faRouble,\n faRub: faRub,\n faRuble: faRuble,\n faRuler: faRuler,\n faRulerCombined: faRulerCombined,\n faRulerHorizontal: faRulerHorizontal,\n faRulerVertical: faRulerVertical,\n faRupeeSign: faRupeeSign,\n faRupee: faRupee,\n faRupiahSign: faRupiahSign,\n faS: faS,\n faSailboat: faSailboat,\n faSatellite: faSatellite,\n faSatelliteDish: faSatelliteDish,\n faScaleBalanced: faScaleBalanced,\n faBalanceScale: faBalanceScale,\n faScaleUnbalanced: faScaleUnbalanced,\n faBalanceScaleLeft: faBalanceScaleLeft,\n faScaleUnbalancedFlip: faScaleUnbalancedFlip,\n faBalanceScaleRight: faBalanceScaleRight,\n faSchool: faSchool,\n faScissors: faScissors,\n faCut: faCut,\n faScrewdriver: faScrewdriver,\n faScrewdriverWrench: faScrewdriverWrench,\n faTools: faTools,\n faScroll: faScroll,\n faScrollTorah: faScrollTorah,\n faTorah: faTorah,\n faSdCard: faSdCard,\n faSection: faSection,\n faSeedling: faSeedling,\n faSprout: faSprout,\n faServer: faServer,\n faShapes: faShapes,\n faTriangleCircleSquare: faTriangleCircleSquare,\n faShare: faShare,\n faArrowTurnRight: faArrowTurnRight,\n faMailForward: faMailForward,\n faShareFromSquare: faShareFromSquare,\n faShareSquare: faShareSquare,\n faShareNodes: faShareNodes,\n faShareAlt: faShareAlt,\n faShekelSign: faShekelSign,\n faIls: faIls,\n faShekel: faShekel,\n faSheqel: faSheqel,\n faSheqelSign: faSheqelSign,\n faShield: faShield,\n faShieldBlank: faShieldBlank,\n faShieldAlt: faShieldAlt,\n faShieldVirus: faShieldVirus,\n faShip: faShip,\n faShirt: faShirt,\n faTShirt: faTShirt,\n faTshirt: faTshirt,\n faShoePrints: faShoePrints,\n faShop: faShop,\n faStoreAlt: faStoreAlt,\n faShopSlash: faShopSlash,\n faStoreAltSlash: faStoreAltSlash,\n faShower: faShower,\n faShrimp: faShrimp,\n faShuffle: faShuffle,\n faRandom: faRandom,\n faShuttleSpace: faShuttleSpace,\n faSpaceShuttle: faSpaceShuttle,\n faSignHanging: faSignHanging,\n faSign: faSign,\n faSignal: faSignal,\n faSignal5: faSignal5,\n faSignalPerfect: faSignalPerfect,\n faSignature: faSignature,\n faSignsPost: faSignsPost,\n faMapSigns: faMapSigns,\n faSimCard: faSimCard,\n faSink: faSink,\n faSitemap: faSitemap,\n faSkull: faSkull,\n faSkullCrossbones: faSkullCrossbones,\n faSlash: faSlash,\n faSleigh: faSleigh,\n faSliders: faSliders,\n faSlidersH: faSlidersH,\n faSmog: faSmog,\n faSmoking: faSmoking,\n faSnowflake: faSnowflake,\n faSnowman: faSnowman,\n faSnowplow: faSnowplow,\n faSoap: faSoap,\n faSocks: faSocks,\n faSolarPanel: faSolarPanel,\n faSort: faSort,\n faUnsorted: faUnsorted,\n faSortDown: faSortDown,\n faSortDesc: faSortDesc,\n faSortUp: faSortUp,\n faSortAsc: faSortAsc,\n faSpa: faSpa,\n faSpaghettiMonsterFlying: faSpaghettiMonsterFlying,\n faPastafarianism: faPastafarianism,\n faSpellCheck: faSpellCheck,\n faSpider: faSpider,\n faSpinner: faSpinner,\n faSplotch: faSplotch,\n faSpoon: faSpoon,\n faUtensilSpoon: faUtensilSpoon,\n faSprayCan: faSprayCan,\n faSprayCanSparkles: faSprayCanSparkles,\n faAirFreshener: faAirFreshener,\n faSquare: faSquare,\n faSquareArrowUpRight: faSquareArrowUpRight,\n faExternalLinkSquare: faExternalLinkSquare,\n faSquareCaretDown: faSquareCaretDown,\n faCaretSquareDown: faCaretSquareDown,\n faSquareCaretLeft: faSquareCaretLeft,\n faCaretSquareLeft: faCaretSquareLeft,\n faSquareCaretRight: faSquareCaretRight,\n faCaretSquareRight: faCaretSquareRight,\n faSquareCaretUp: faSquareCaretUp,\n faCaretSquareUp: faCaretSquareUp,\n faSquareCheck: faSquareCheck,\n faCheckSquare: faCheckSquare,\n faSquareEnvelope: faSquareEnvelope,\n faEnvelopeSquare: faEnvelopeSquare,\n faSquareFull: faSquareFull,\n faSquareH: faSquareH,\n faHSquare: faHSquare,\n faSquareMinus: faSquareMinus,\n faMinusSquare: faMinusSquare,\n faSquareParking: faSquareParking,\n faParking: faParking,\n faSquarePen: faSquarePen,\n faPenSquare: faPenSquare,\n faPencilSquare: faPencilSquare,\n faSquarePhone: faSquarePhone,\n faPhoneSquare: faPhoneSquare,\n faSquarePhoneFlip: faSquarePhoneFlip,\n faPhoneSquareAlt: faPhoneSquareAlt,\n faSquarePlus: faSquarePlus,\n faPlusSquare: faPlusSquare,\n faSquarePollHorizontal: faSquarePollHorizontal,\n faPollH: faPollH,\n faSquarePollVertical: faSquarePollVertical,\n faPoll: faPoll,\n faSquareRootVariable: faSquareRootVariable,\n faSquareRootAlt: faSquareRootAlt,\n faSquareRss: faSquareRss,\n faRssSquare: faRssSquare,\n faSquareShareNodes: faSquareShareNodes,\n faShareAltSquare: faShareAltSquare,\n faSquareUpRight: faSquareUpRight,\n faExternalLinkSquareAlt: faExternalLinkSquareAlt,\n faSquareXmark: faSquareXmark,\n faTimesSquare: faTimesSquare,\n faXmarkSquare: faXmarkSquare,\n faStairs: faStairs,\n faStamp: faStamp,\n faStar: faStar,\n faStarAndCrescent: faStarAndCrescent,\n faStarHalf: faStarHalf,\n faStarHalfStroke: faStarHalfStroke,\n faStarHalfAlt: faStarHalfAlt,\n faStarOfDavid: faStarOfDavid,\n faStarOfLife: faStarOfLife,\n faSterlingSign: faSterlingSign,\n faGbp: faGbp,\n faPoundSign: faPoundSign,\n faStethoscope: faStethoscope,\n faStop: faStop,\n faStopwatch: faStopwatch,\n faStopwatch20: faStopwatch20,\n faStore: faStore,\n faStoreSlash: faStoreSlash,\n faStreetView: faStreetView,\n faStrikethrough: faStrikethrough,\n faStroopwafel: faStroopwafel,\n faSubscript: faSubscript,\n faSuitcase: faSuitcase,\n faSuitcaseMedical: faSuitcaseMedical,\n faMedkit: faMedkit,\n faSuitcaseRolling: faSuitcaseRolling,\n faSun: faSun,\n faSuperscript: faSuperscript,\n faSwatchbook: faSwatchbook,\n faSynagogue: faSynagogue,\n faSyringe: faSyringe,\n faT: faT,\n faTable: faTable,\n faTableCells: faTableCells,\n faTh: faTh,\n faTableCellsLarge: faTableCellsLarge,\n faThLarge: faThLarge,\n faTableColumns: faTableColumns,\n faColumns: faColumns,\n faTableList: faTableList,\n faThList: faThList,\n faTableTennisPaddleBall: faTableTennisPaddleBall,\n faPingPongPaddleBall: faPingPongPaddleBall,\n faTableTennis: faTableTennis,\n faTablet: faTablet,\n faTabletAndroid: faTabletAndroid,\n faTabletButton: faTabletButton,\n faTabletScreenButton: faTabletScreenButton,\n faTabletAlt: faTabletAlt,\n faTablets: faTablets,\n faTachographDigital: faTachographDigital,\n faDigitalTachograph: faDigitalTachograph,\n faTag: faTag,\n faTags: faTags,\n faTape: faTape,\n faTaxi: faTaxi,\n faCab: faCab,\n faTeeth: faTeeth,\n faTeethOpen: faTeethOpen,\n faTemperatureEmpty: faTemperatureEmpty,\n faTemperature0: faTemperature0,\n faThermometer0: faThermometer0,\n faThermometerEmpty: faThermometerEmpty,\n faTemperatureFull: faTemperatureFull,\n faTemperature4: faTemperature4,\n faThermometer4: faThermometer4,\n faThermometerFull: faThermometerFull,\n faTemperatureHalf: faTemperatureHalf,\n faTemperature2: faTemperature2,\n faThermometer2: faThermometer2,\n faThermometerHalf: faThermometerHalf,\n faTemperatureHigh: faTemperatureHigh,\n faTemperatureLow: faTemperatureLow,\n faTemperatureQuarter: faTemperatureQuarter,\n faTemperature1: faTemperature1,\n faThermometer1: faThermometer1,\n faThermometerQuarter: faThermometerQuarter,\n faTemperatureThreeQuarters: faTemperatureThreeQuarters,\n faTemperature3: faTemperature3,\n faThermometer3: faThermometer3,\n faThermometerThreeQuarters: faThermometerThreeQuarters,\n faTengeSign: faTengeSign,\n faTenge: faTenge,\n faTerminal: faTerminal,\n faTextHeight: faTextHeight,\n faTextSlash: faTextSlash,\n faRemoveFormat: faRemoveFormat,\n faTextWidth: faTextWidth,\n faThermometer: faThermometer,\n faThumbsDown: faThumbsDown,\n faThumbsUp: faThumbsUp,\n faThumbtack: faThumbtack,\n faThumbTack: faThumbTack,\n faTicket: faTicket,\n faTicketSimple: faTicketSimple,\n faTicketAlt: faTicketAlt,\n faTimeline: faTimeline,\n faToggleOff: faToggleOff,\n faToggleOn: faToggleOn,\n faToilet: faToilet,\n faToiletPaper: faToiletPaper,\n faToiletPaperSlash: faToiletPaperSlash,\n faToolbox: faToolbox,\n faTooth: faTooth,\n faToriiGate: faToriiGate,\n faTowerBroadcast: faTowerBroadcast,\n faBroadcastTower: faBroadcastTower,\n faTractor: faTractor,\n faTrademark: faTrademark,\n faTrafficLight: faTrafficLight,\n faTrailer: faTrailer,\n faTrain: faTrain,\n faTrainSubway: faTrainSubway,\n faSubway: faSubway,\n faTrainTram: faTrainTram,\n faTram: faTram,\n faTransgender: faTransgender,\n faTransgenderAlt: faTransgenderAlt,\n faTrash: faTrash,\n faTrashArrowUp: faTrashArrowUp,\n faTrashRestore: faTrashRestore,\n faTrashCan: faTrashCan,\n faTrashAlt: faTrashAlt,\n faTrashCanArrowUp: faTrashCanArrowUp,\n faTrashRestoreAlt: faTrashRestoreAlt,\n faTree: faTree,\n faTriangleExclamation: faTriangleExclamation,\n faExclamationTriangle: faExclamationTriangle,\n faWarning: faWarning,\n faTrophy: faTrophy,\n faTruck: faTruck,\n faTruckFast: faTruckFast,\n faShippingFast: faShippingFast,\n faTruckMedical: faTruckMedical,\n faAmbulance: faAmbulance,\n faTruckMonster: faTruckMonster,\n faTruckMoving: faTruckMoving,\n faTruckPickup: faTruckPickup,\n faTruckRampBox: faTruckRampBox,\n faTruckLoading: faTruckLoading,\n faTty: faTty,\n faTeletype: faTeletype,\n faTurkishLiraSign: faTurkishLiraSign,\n faTry: faTry,\n faTurkishLira: faTurkishLira,\n faTurnDown: faTurnDown,\n faLevelDownAlt: faLevelDownAlt,\n faTurnUp: faTurnUp,\n faLevelUpAlt: faLevelUpAlt,\n faTv: faTv,\n faTelevision: faTelevision,\n faTvAlt: faTvAlt,\n faU: faU,\n faUmbrella: faUmbrella,\n faUmbrellaBeach: faUmbrellaBeach,\n faUnderline: faUnderline,\n faUniversalAccess: faUniversalAccess,\n faUnlock: faUnlock,\n faUnlockKeyhole: faUnlockKeyhole,\n faUnlockAlt: faUnlockAlt,\n faUpDown: faUpDown,\n faArrowsAltV: faArrowsAltV,\n faUpDownLeftRight: faUpDownLeftRight,\n faArrowsAlt: faArrowsAlt,\n faUpLong: faUpLong,\n faLongArrowAltUp: faLongArrowAltUp,\n faUpRightAndDownLeftFromCenter: faUpRightAndDownLeftFromCenter,\n faExpandAlt: faExpandAlt,\n faUpRightFromSquare: faUpRightFromSquare,\n faExternalLinkAlt: faExternalLinkAlt,\n faUpload: faUpload,\n faUser: faUser,\n faUserAstronaut: faUserAstronaut,\n faUserCheck: faUserCheck,\n faUserClock: faUserClock,\n faUserDoctor: faUserDoctor,\n faUserMd: faUserMd,\n faUserGear: faUserGear,\n faUserCog: faUserCog,\n faUserGraduate: faUserGraduate,\n faUserGroup: faUserGroup,\n faUserFriends: faUserFriends,\n faUserInjured: faUserInjured,\n faUserLarge: faUserLarge,\n faUserAlt: faUserAlt,\n faUserLargeSlash: faUserLargeSlash,\n faUserAltSlash: faUserAltSlash,\n faUserLock: faUserLock,\n faUserMinus: faUserMinus,\n faUserNinja: faUserNinja,\n faUserNurse: faUserNurse,\n faUserPen: faUserPen,\n faUserEdit: faUserEdit,\n faUserPlus: faUserPlus,\n faUserSecret: faUserSecret,\n faUserShield: faUserShield,\n faUserSlash: faUserSlash,\n faUserTag: faUserTag,\n faUserTie: faUserTie,\n faUserXmark: faUserXmark,\n faUserTimes: faUserTimes,\n faUsers: faUsers,\n faUsersGear: faUsersGear,\n faUsersCog: faUsersCog,\n faUsersSlash: faUsersSlash,\n faUtensils: faUtensils,\n faCutlery: faCutlery,\n faV: faV,\n faVanShuttle: faVanShuttle,\n faShuttleVan: faShuttleVan,\n faVault: faVault,\n faVectorSquare: faVectorSquare,\n faVenus: faVenus,\n faVenusDouble: faVenusDouble,\n faVenusMars: faVenusMars,\n faVest: faVest,\n faVestPatches: faVestPatches,\n faVial: faVial,\n faVials: faVials,\n faVideo: faVideo,\n faVideoCamera: faVideoCamera,\n faVideoSlash: faVideoSlash,\n faVihara: faVihara,\n faVirus: faVirus,\n faVirusCovid: faVirusCovid,\n faVirusCovidSlash: faVirusCovidSlash,\n faVirusSlash: faVirusSlash,\n faViruses: faViruses,\n faVoicemail: faVoicemail,\n faVolleyball: faVolleyball,\n faVolleyballBall: faVolleyballBall,\n faVolumeHigh: faVolumeHigh,\n faVolumeUp: faVolumeUp,\n faVolumeLow: faVolumeLow,\n faVolumeDown: faVolumeDown,\n faVolumeOff: faVolumeOff,\n faVolumeXmark: faVolumeXmark,\n faVolumeMute: faVolumeMute,\n faVolumeTimes: faVolumeTimes,\n faVrCardboard: faVrCardboard,\n faW: faW,\n faWallet: faWallet,\n faWandMagic: faWandMagic,\n faMagic: faMagic,\n faWandMagicSparkles: faWandMagicSparkles,\n faMagicWandSparkles: faMagicWandSparkles,\n faWandSparkles: faWandSparkles,\n faWarehouse: faWarehouse,\n faWater: faWater,\n faWaterLadder: faWaterLadder,\n faLadderWater: faLadderWater,\n faSwimmingPool: faSwimmingPool,\n faWaveSquare: faWaveSquare,\n faWeightHanging: faWeightHanging,\n faWeightScale: faWeightScale,\n faWeight: faWeight,\n faWheelchair: faWheelchair,\n faWhiskeyGlass: faWhiskeyGlass,\n faGlassWhiskey: faGlassWhiskey,\n faWifi: faWifi,\n faWifi3: faWifi3,\n faWifiStrong: faWifiStrong,\n faWind: faWind,\n faWindowMaximize: faWindowMaximize,\n faWindowMinimize: faWindowMinimize,\n faWindowRestore: faWindowRestore,\n faWineBottle: faWineBottle,\n faWineGlass: faWineGlass,\n faWineGlassEmpty: faWineGlassEmpty,\n faWineGlassAlt: faWineGlassAlt,\n faWonSign: faWonSign,\n faKrw: faKrw,\n faWon: faWon,\n faWrench: faWrench,\n faX: faX,\n faXRay: faXRay,\n faXmark: faXmark,\n faClose: faClose,\n faMultiply: faMultiply,\n faRemove: faRemove,\n faTimes: faTimes,\n faY: faY,\n faYenSign: faYenSign,\n faCny: faCny,\n faJpy: faJpy,\n faRmb: faRmb,\n faYen: faYen,\n faYinYang: faYinYang,\n faZ: faZ\n};\n\n},{\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"fsrQb\":[function(require,module,exports) {\nvar $parcel$ReactRefreshHelpers$6890 = require(\"@parcel/transformer-react-refresh-wrap/lib/helpers/helpers.js\");\nvar prevRefreshReg = window.$RefreshReg$;\nvar prevRefreshSig = window.$RefreshSig$;\n$parcel$ReactRefreshHelpers$6890.prelude(module);\n\ntry {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"PageNavigator\", ()=>PageNavigator\n);\nvar _jsxDevRuntime = require(\"react/jsx-dev-runtime\");\nvar _filter = require(\"./filter\");\nvar _freeSolidSvgIcons = require(\"@fortawesome/free-solid-svg-icons\");\nfunction PageNavigator({ allPages , onNavigate , currentPage }) {\n let options = [];\n for (let pageMeta of allPages){\n if (currentPage && currentPage.name == pageMeta.name) continue;\n // Order by last modified date in descending order\n let orderId = -pageMeta.lastModified.getTime();\n // Unless it was opened and is still in memory\n if (pageMeta.lastOpened) orderId = -pageMeta.lastOpened.getTime();\n options.push({\n ...pageMeta,\n orderId: orderId\n });\n }\n return(/*#__PURE__*/ _jsxDevRuntime.jsxDEV(_filter.FilterList, {\n placeholder: \"Page\",\n label: \"Open\",\n options: options,\n icon: _freeSolidSvgIcons.faFileLines,\n allowNew: true,\n helpText: \"Start typing the page name to filter results, press <code>Return</code> to open.\",\n newHint: \"Create page\",\n onSelect: (opt)=>{\n onNavigate(opt?.name);\n }\n }, void 0, false, {\n fileName: \"/Users/zef/git/nugget/webapp/src/components/page_navigator.tsx\",\n lineNumber: 31,\n columnNumber: 5\n }, this));\n}\n_c = PageNavigator;\nvar _c;\n$RefreshReg$(_c, \"PageNavigator\");\n\n $parcel$ReactRefreshHelpers$6890.postlude(module);\n} finally {\n window.$RefreshReg$ = prevRefreshReg;\n window.$RefreshSig$ = prevRefreshSig;\n}\n},{\"react/jsx-dev-runtime\":\"jsc7i\",\"./filter\":\"iVuFf\",\"@fortawesome/free-solid-svg-icons\":\"6ECLA\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\",\"@parcel/transformer-react-refresh-wrap/lib/helpers/helpers.js\":\"km3Ru\"}],\"d3BjR\":[function(require,module,exports) {\nvar $parcel$ReactRefreshHelpers$edfe = require(\"@parcel/transformer-react-refresh-wrap/lib/helpers/helpers.js\");\nvar prevRefreshReg = window.$RefreshReg$;\nvar prevRefreshSig = window.$RefreshSig$;\n$parcel$ReactRefreshHelpers$edfe.prelude(module);\n\ntry {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"StatusBar\", ()=>StatusBar\n);\nvar _jsxDevRuntime = require(\"react/jsx-dev-runtime\");\nvar _util = require(\"../util\");\nfunction StatusBar({ isSaved , editorView }) {\n let wordCount = 0, readingTime = 0;\n if (editorView) {\n let text = editorView.state.sliceDoc();\n wordCount = _util.countWords(text);\n readingTime = _util.readingTime(wordCount);\n }\n return(/*#__PURE__*/ _jsxDevRuntime.jsxDEV(\"div\", {\n id: \"bottom\",\n children: [\n wordCount,\n \" words | \",\n readingTime,\n \" min | \",\n isSaved ? \"Saved\" : \"Edited\"\n ]\n }, void 0, true, {\n fileName: \"/Users/zef/git/nugget/webapp/src/components/status_bar.tsx\",\n lineNumber: 19,\n columnNumber: 5\n }, this));\n}\n_c = StatusBar;\nvar _c;\n$RefreshReg$(_c, \"StatusBar\");\n\n $parcel$ReactRefreshHelpers$edfe.postlude(module);\n} finally {\n window.$RefreshReg$ = prevRefreshReg;\n window.$RefreshSig$ = prevRefreshSig;\n}\n},{\"react/jsx-dev-runtime\":\"jsc7i\",\"../util\":\"eF4A3\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\",\"@parcel/transformer-react-refresh-wrap/lib/helpers/helpers.js\":\"km3Ru\"}],\"clh7D\":[function(require,module,exports) {\nvar $parcel$ReactRefreshHelpers$ce1c = require(\"@parcel/transformer-react-refresh-wrap/lib/helpers/helpers.js\");\nvar prevRefreshReg = window.$RefreshReg$;\nvar prevRefreshSig = window.$RefreshSig$;\n$parcel$ReactRefreshHelpers$ce1c.prelude(module);\n\ntry {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"TopBar\", ()=>TopBar\n);\nvar _jsxDevRuntime = require(\"react/jsx-dev-runtime\");\nvar _reactFontawesome = require(\"@fortawesome/react-fontawesome\");\nvar _freeSolidSvgIcons = require(\"@fortawesome/free-solid-svg-icons\");\nfunction prettyName(s) {\n if (!s) return \"\";\n return s.replaceAll(\"/\", \" / \");\n}\nfunction TopBar({ currentPage , onClick }) {\n return(/*#__PURE__*/ _jsxDevRuntime.jsxDEV(\"div\", {\n id: \"top\",\n onClick: onClick,\n children: /*#__PURE__*/ _jsxDevRuntime.jsxDEV(\"div\", {\n className: \"inner\",\n children: [\n /*#__PURE__*/ _jsxDevRuntime.jsxDEV(\"span\", {\n className: \"icon\",\n children: /*#__PURE__*/ _jsxDevRuntime.jsxDEV(_reactFontawesome.FontAwesomeIcon, {\n icon: _freeSolidSvgIcons.faFileLines\n }, void 0, false, {\n fileName: \"/Users/zef/git/nugget/webapp/src/components/top_bar.tsx\",\n lineNumber: 23,\n columnNumber: 11\n }, this)\n }, void 0, false, {\n fileName: \"/Users/zef/git/nugget/webapp/src/components/top_bar.tsx\",\n lineNumber: 22,\n columnNumber: 9\n }, this),\n /*#__PURE__*/ _jsxDevRuntime.jsxDEV(\"span\", {\n className: \"current-page\",\n children: prettyName(currentPage?.name)\n }, void 0, false, {\n fileName: \"/Users/zef/git/nugget/webapp/src/components/top_bar.tsx\",\n lineNumber: 25,\n columnNumber: 9\n }, this)\n ]\n }, void 0, true, {\n fileName: \"/Users/zef/git/nugget/webapp/src/components/top_bar.tsx\",\n lineNumber: 21,\n columnNumber: 7\n }, this)\n }, void 0, false, {\n fileName: \"/Users/zef/git/nugget/webapp/src/components/top_bar.tsx\",\n lineNumber: 20,\n columnNumber: 5\n }, this));\n}\n_c = TopBar;\nvar _c;\n$RefreshReg$(_c, \"TopBar\");\n\n $parcel$ReactRefreshHelpers$ce1c.postlude(module);\n} finally {\n window.$RefreshReg$ = prevRefreshReg;\n window.$RefreshSig$ = prevRefreshSig;\n}\n},{\"react/jsx-dev-runtime\":\"jsc7i\",\"@fortawesome/react-fontawesome\":\"73SlK\",\"@fortawesome/free-solid-svg-icons\":\"6ECLA\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\",\"@parcel/transformer-react-refresh-wrap/lib/helpers/helpers.js\":\"km3Ru\"}],\"bIR6j\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"Indexer\", ()=>Indexer\n);\nvar _dexie = require(\"dexie\");\nfunction constructKey(pageName, key) {\n return `${pageName}:${key}`;\n}\nfunction cleanKey(pageName, fromKey) {\n return fromKey.substring(pageName.length + 1);\n}\nclass Indexer {\n constructor(name, space){\n this.db = new _dexie.Dexie(name);\n this.space = space;\n this.db.version(1).stores({\n pageIndex: \"ck, page, key\"\n });\n this.pageIndex = this.db.table(\"pageIndex\");\n }\n async clearPageIndexForPage(pageName) {\n await this.pageIndex.where({\n page: pageName\n }).delete();\n }\n async clearPageIndex() {\n await this.pageIndex.clear();\n }\n async setPageIndexPageMeta(pageName, meta) {\n await this.set(pageName, \"$meta\", {\n lastModified: meta.lastModified.getTime()\n });\n }\n async getPageIndexPageMeta(pageName) {\n let meta = await this.get(pageName, \"$meta\");\n if (meta) return {\n name: pageName,\n lastModified: new Date(meta.lastModified)\n };\n else return null;\n }\n async indexPage(appEventDispatcher, pageMeta, text, withFlush) {\n if (withFlush) await this.clearPageIndexForPage(pageMeta.name);\n let indexEvent = {\n name: pageMeta.name,\n text\n };\n await appEventDispatcher.dispatchAppEvent(\"page:index\", indexEvent);\n await this.setPageIndexPageMeta(pageMeta.name, pageMeta);\n }\n async reindexSpace(space, appEventDispatcher) {\n await this.clearPageIndex();\n let allPages = await space.listPages();\n // TODO: Parallelize?\n for (let page of allPages){\n let pageData = await space.readPage(page.name);\n await this.indexPage(appEventDispatcher, pageData.meta, pageData.text, false);\n }\n }\n async set(pageName, key, value) {\n await this.pageIndex.put({\n ck: constructKey(pageName, key),\n page: pageName,\n key: key,\n value: value\n });\n }\n async batchSet(pageName, kvs) {\n await this.pageIndex.bulkPut(kvs.map(({ key , value })=>({\n ck: constructKey(pageName, key),\n key: key,\n page: pageName,\n value: value\n })\n ));\n }\n async get(pageName, key) {\n let result = await this.pageIndex.get({\n ck: constructKey(pageName, key)\n });\n return result ? result.value : null;\n }\n async scanPrefixForPage(pageName, keyPrefix) {\n let results = await this.pageIndex.where(\"ck\").startsWith(constructKey(pageName, keyPrefix)).toArray();\n return results.map((result)=>({\n key: cleanKey(pageName, result.key),\n value: result.value\n })\n );\n }\n async scanPrefixGlobal(keyPrefix) {\n let results = await this.pageIndex.where(\"key\").startsWith(keyPrefix).toArray();\n return results.map((result)=>({\n key: result.key,\n value: result.value\n })\n );\n }\n async deletePrefixForPage(pageName, keyPrefix) {\n await this.pageIndex.where(\"ck\").startsWith(constructKey(pageName, keyPrefix)).delete();\n }\n async delete(pageName, key) {\n await this.pageIndex.delete(constructKey(pageName, key));\n }\n}\n\n},{\"dexie\":\"lY3xd\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"lY3xd\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"Dexie\", ()=>Dexie$1\n);\nparcelHelpers.export(exports, \"RangeSet\", ()=>RangeSet\n);\nparcelHelpers.export(exports, \"default\", ()=>Dexie$1\n);\nparcelHelpers.export(exports, \"liveQuery\", ()=>liveQuery\n);\nparcelHelpers.export(exports, \"mergeRanges\", ()=>mergeRanges\n);\nparcelHelpers.export(exports, \"rangesOverlap\", ()=>rangesOverlap\n);\nvar global = arguments[3];\n/*\n * Dexie.js - a minimalistic wrapper for IndexedDB\n * ===============================================\n *\n * By David Fahlander, david.fahlander@gmail.com\n *\n * Version 3.2.1, Wed Feb 16 2022\n *\n * https://dexie.org\n *\n * Apache License Version 2.0, January 2004, http://www.apache.org/licenses/\n */ /*! *****************************************************************************\nCopyright (c) Microsoft Corporation.\nPermission to use, copy, modify, and/or distribute this software for any\npurpose with or without fee is hereby granted.\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\nPERFORMANCE OF THIS SOFTWARE.\n***************************************************************************** */ var __assign = function() {\n __assign = Object.assign || function __assign(t) {\n for(var s, i = 1, n = arguments.length; i < n; i++){\n s = arguments[i];\n for(var p in s)if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nfunction __spreadArray(to, from, pack) {\n if (pack || arguments.length === 2) {\n for(var i = 0, l = from.length, ar; i < l; i++)if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n}\nvar _global = typeof globalThis !== 'undefined' ? globalThis : typeof self !== 'undefined' ? self : typeof window !== 'undefined' ? window : global;\nvar keys = Object.keys;\nvar isArray = Array.isArray;\nif (typeof Promise !== 'undefined' && !_global.Promise) _global.Promise = Promise;\nfunction extend(obj, extension) {\n if (typeof extension !== 'object') return obj;\n keys(extension).forEach(function(key) {\n obj[key] = extension[key];\n });\n return obj;\n}\nvar getProto = Object.getPrototypeOf;\nvar _hasOwn = {\n}.hasOwnProperty;\nfunction hasOwn(obj, prop) {\n return _hasOwn.call(obj, prop);\n}\nfunction props(proto, extension) {\n if (typeof extension === 'function') extension = extension(getProto(proto));\n (typeof Reflect === \"undefined\" ? keys : Reflect.ownKeys)(extension).forEach(function(key) {\n setProp(proto, key, extension[key]);\n });\n}\nvar defineProperty = Object.defineProperty;\nfunction setProp(obj, prop, functionOrGetSet, options) {\n defineProperty(obj, prop, extend(functionOrGetSet && hasOwn(functionOrGetSet, \"get\") && typeof functionOrGetSet.get === 'function' ? {\n get: functionOrGetSet.get,\n set: functionOrGetSet.set,\n configurable: true\n } : {\n value: functionOrGetSet,\n configurable: true,\n writable: true\n }, options));\n}\nfunction derive(Child) {\n return {\n from: function(Parent) {\n Child.prototype = Object.create(Parent.prototype);\n setProp(Child.prototype, \"constructor\", Child);\n return {\n extend: props.bind(null, Child.prototype)\n };\n }\n };\n}\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nfunction getPropertyDescriptor(obj, prop) {\n var pd = getOwnPropertyDescriptor(obj, prop);\n var proto;\n return pd || (proto = getProto(obj)) && getPropertyDescriptor(proto, prop);\n}\nvar _slice = [].slice;\nfunction slice(args, start, end) {\n return _slice.call(args, start, end);\n}\nfunction override(origFunc, overridedFactory) {\n return overridedFactory(origFunc);\n}\nfunction assert(b) {\n if (!b) throw new Error(\"Assertion Failed\");\n}\nfunction asap$1(fn) {\n if (_global.setImmediate) setImmediate(fn);\n else setTimeout(fn, 0);\n}\nfunction arrayToObject(array, extractor) {\n return array.reduce(function(result, item, i) {\n var nameAndValue = extractor(item, i);\n if (nameAndValue) result[nameAndValue[0]] = nameAndValue[1];\n return result;\n }, {\n });\n}\nfunction tryCatch(fn, onerror, args) {\n try {\n fn.apply(null, args);\n } catch (ex) {\n onerror && onerror(ex);\n }\n}\nfunction getByKeyPath(obj, keyPath) {\n if (hasOwn(obj, keyPath)) return obj[keyPath];\n if (!keyPath) return obj;\n if (typeof keyPath !== 'string') {\n var rv = [];\n for(var i = 0, l = keyPath.length; i < l; ++i){\n var val = getByKeyPath(obj, keyPath[i]);\n rv.push(val);\n }\n return rv;\n }\n var period = keyPath.indexOf('.');\n if (period !== -1) {\n var innerObj = obj[keyPath.substr(0, period)];\n return innerObj === undefined ? undefined : getByKeyPath(innerObj, keyPath.substr(period + 1));\n }\n return undefined;\n}\nfunction setByKeyPath(obj, keyPath, value) {\n if (!obj || keyPath === undefined) return;\n if ('isFrozen' in Object && Object.isFrozen(obj)) return;\n if (typeof keyPath !== 'string' && 'length' in keyPath) {\n assert(typeof value !== 'string' && 'length' in value);\n for(var i = 0, l = keyPath.length; i < l; ++i)setByKeyPath(obj, keyPath[i], value[i]);\n } else {\n var period = keyPath.indexOf('.');\n if (period !== -1) {\n var currentKeyPath = keyPath.substr(0, period);\n var remainingKeyPath = keyPath.substr(period + 1);\n if (remainingKeyPath === \"\") {\n if (value === undefined) {\n if (isArray(obj) && !isNaN(parseInt(currentKeyPath))) obj.splice(currentKeyPath, 1);\n else delete obj[currentKeyPath];\n } else obj[currentKeyPath] = value;\n } else {\n var innerObj = obj[currentKeyPath];\n if (!innerObj) innerObj = obj[currentKeyPath] = {\n };\n setByKeyPath(innerObj, remainingKeyPath, value);\n }\n } else if (value === undefined) {\n if (isArray(obj) && !isNaN(parseInt(keyPath))) obj.splice(keyPath, 1);\n else delete obj[keyPath];\n } else obj[keyPath] = value;\n }\n}\nfunction delByKeyPath(obj, keyPath) {\n if (typeof keyPath === 'string') setByKeyPath(obj, keyPath, undefined);\n else if ('length' in keyPath) [].map.call(keyPath, function(kp) {\n setByKeyPath(obj, kp, undefined);\n });\n}\nfunction shallowClone(obj) {\n var rv = {\n };\n for(var m in obj)if (hasOwn(obj, m)) rv[m] = obj[m];\n return rv;\n}\nvar concat = [].concat;\nfunction flatten(a) {\n return concat.apply([], a);\n}\nvar intrinsicTypeNames = \"Boolean,String,Date,RegExp,Blob,File,FileList,FileSystemFileHandle,ArrayBuffer,DataView,Uint8ClampedArray,ImageBitmap,ImageData,Map,Set,CryptoKey\".split(',').concat(flatten([\n 8,\n 16,\n 32,\n 64\n].map(function(num) {\n return [\n \"Int\",\n \"Uint\",\n \"Float\"\n ].map(function(t) {\n return t + num + \"Array\";\n });\n}))).filter(function(t) {\n return _global[t];\n});\nvar intrinsicTypes = intrinsicTypeNames.map(function(t) {\n return _global[t];\n});\narrayToObject(intrinsicTypeNames, function(x) {\n return [\n x,\n true\n ];\n});\nvar circularRefs = null;\nfunction deepClone(any) {\n circularRefs = typeof WeakMap !== 'undefined' && new WeakMap();\n var rv = innerDeepClone(any);\n circularRefs = null;\n return rv;\n}\nfunction innerDeepClone(any) {\n if (!any || typeof any !== 'object') return any;\n var rv = circularRefs && circularRefs.get(any);\n if (rv) return rv;\n if (isArray(any)) {\n rv = [];\n circularRefs && circularRefs.set(any, rv);\n for(var i = 0, l = any.length; i < l; ++i)rv.push(innerDeepClone(any[i]));\n } else if (intrinsicTypes.indexOf(any.constructor) >= 0) rv = any;\n else {\n var proto = getProto(any);\n rv = proto === Object.prototype ? {\n } : Object.create(proto);\n circularRefs && circularRefs.set(any, rv);\n for(var prop in any)if (hasOwn(any, prop)) rv[prop] = innerDeepClone(any[prop]);\n }\n return rv;\n}\nvar toString = {\n}.toString;\nfunction toStringTag(o) {\n return toString.call(o).slice(8, -1);\n}\nvar iteratorSymbol = typeof Symbol !== 'undefined' ? Symbol.iterator : '@@iterator';\nvar getIteratorOf = typeof iteratorSymbol === \"symbol\" ? function(x) {\n var i;\n return x != null && (i = x[iteratorSymbol]) && i.apply(x);\n} : function() {\n return null;\n};\nvar NO_CHAR_ARRAY = {\n};\nfunction getArrayOf(arrayLike) {\n var i, a, x, it;\n if (arguments.length === 1) {\n if (isArray(arrayLike)) return arrayLike.slice();\n if (this === NO_CHAR_ARRAY && typeof arrayLike === 'string') return [\n arrayLike\n ];\n if (it = getIteratorOf(arrayLike)) {\n a = [];\n while(x = it.next(), !x.done)a.push(x.value);\n return a;\n }\n if (arrayLike == null) return [\n arrayLike\n ];\n i = arrayLike.length;\n if (typeof i === 'number') {\n a = new Array(i);\n while(i--)a[i] = arrayLike[i];\n return a;\n }\n return [\n arrayLike\n ];\n }\n i = arguments.length;\n a = new Array(i);\n while(i--)a[i] = arguments[i];\n return a;\n}\nvar isAsyncFunction = typeof Symbol !== 'undefined' ? function(fn) {\n return fn[Symbol.toStringTag] === 'AsyncFunction';\n} : function() {\n return false;\n};\nvar debug = typeof location !== 'undefined' && /^(http|https):\\/\\/(localhost|127\\.0\\.0\\.1)/.test(location.href);\nfunction setDebug(value, filter) {\n debug = value;\n libraryFilter = filter;\n}\nvar libraryFilter = function() {\n return true;\n};\nvar NEEDS_THROW_FOR_STACK = !new Error(\"\").stack;\nfunction getErrorWithStack() {\n if (NEEDS_THROW_FOR_STACK) try {\n getErrorWithStack.arguments;\n throw new Error();\n } catch (e) {\n return e;\n }\n return new Error();\n}\nfunction prettyStack(exception, numIgnoredFrames) {\n var stack = exception.stack;\n if (!stack) return \"\";\n numIgnoredFrames = numIgnoredFrames || 0;\n if (stack.indexOf(exception.name) === 0) numIgnoredFrames += (exception.name + exception.message).split('\\n').length;\n return stack.split('\\n').slice(numIgnoredFrames).filter(libraryFilter).map(function(frame) {\n return \"\\n\" + frame;\n }).join('');\n}\nvar dexieErrorNames = [\n 'Modify',\n 'Bulk',\n 'OpenFailed',\n 'VersionChange',\n 'Schema',\n 'Upgrade',\n 'InvalidTable',\n 'MissingAPI',\n 'NoSuchDatabase',\n 'InvalidArgument',\n 'SubTransaction',\n 'Unsupported',\n 'Internal',\n 'DatabaseClosed',\n 'PrematureCommit',\n 'ForeignAwait'\n];\nvar idbDomErrorNames = [\n 'Unknown',\n 'Constraint',\n 'Data',\n 'TransactionInactive',\n 'ReadOnly',\n 'Version',\n 'NotFound',\n 'InvalidState',\n 'InvalidAccess',\n 'Abort',\n 'Timeout',\n 'QuotaExceeded',\n 'Syntax',\n 'DataClone'\n];\nvar errorList = dexieErrorNames.concat(idbDomErrorNames);\nvar defaultTexts = {\n VersionChanged: \"Database version changed by other database connection\",\n DatabaseClosed: \"Database has been closed\",\n Abort: \"Transaction aborted\",\n TransactionInactive: \"Transaction has already completed or failed\",\n MissingAPI: \"IndexedDB API missing. Please visit https://tinyurl.com/y2uuvskb\"\n};\nfunction DexieError(name, msg) {\n this._e = getErrorWithStack();\n this.name = name;\n this.message = msg;\n}\nderive(DexieError).from(Error).extend({\n stack: {\n get: function() {\n return this._stack || (this._stack = this.name + \": \" + this.message + prettyStack(this._e, 2));\n }\n },\n toString: function() {\n return this.name + \": \" + this.message;\n }\n});\nfunction getMultiErrorMessage(msg, failures) {\n return msg + \". Errors: \" + Object.keys(failures).map(function(key) {\n return failures[key].toString();\n }).filter(function(v, i, s) {\n return s.indexOf(v) === i;\n }).join('\\n');\n}\nfunction ModifyError(msg, failures, successCount, failedKeys) {\n this._e = getErrorWithStack();\n this.failures = failures;\n this.failedKeys = failedKeys;\n this.successCount = successCount;\n this.message = getMultiErrorMessage(msg, failures);\n}\nderive(ModifyError).from(DexieError);\nfunction BulkError(msg, failures) {\n this._e = getErrorWithStack();\n this.name = \"BulkError\";\n this.failures = Object.keys(failures).map(function(pos) {\n return failures[pos];\n });\n this.failuresByPos = failures;\n this.message = getMultiErrorMessage(msg, failures);\n}\nderive(BulkError).from(DexieError);\nvar errnames = errorList.reduce(function(obj, name) {\n return obj[name] = name + \"Error\", obj;\n}, {\n});\nvar BaseException = DexieError;\nvar exceptions = errorList.reduce(function(obj, name) {\n var fullName = name + \"Error\";\n function DexieError1(msgOrInner, inner) {\n this._e = getErrorWithStack();\n this.name = fullName;\n if (!msgOrInner) {\n this.message = defaultTexts[name] || fullName;\n this.inner = null;\n } else if (typeof msgOrInner === 'string') {\n this.message = \"\" + msgOrInner + (!inner ? '' : '\\n ' + inner);\n this.inner = inner || null;\n } else if (typeof msgOrInner === 'object') {\n this.message = msgOrInner.name + \" \" + msgOrInner.message;\n this.inner = msgOrInner;\n }\n }\n derive(DexieError1).from(BaseException);\n obj[name] = DexieError1;\n return obj;\n}, {\n});\nexceptions.Syntax = SyntaxError;\nexceptions.Type = TypeError;\nexceptions.Range = RangeError;\nvar exceptionMap = idbDomErrorNames.reduce(function(obj, name) {\n obj[name + \"Error\"] = exceptions[name];\n return obj;\n}, {\n});\nfunction mapError(domError, message) {\n if (!domError || domError instanceof DexieError || domError instanceof TypeError || domError instanceof SyntaxError || !domError.name || !exceptionMap[domError.name]) return domError;\n var rv = new exceptionMap[domError.name](message || domError.message, domError);\n if (\"stack\" in domError) setProp(rv, \"stack\", {\n get: function() {\n return this.inner.stack;\n }\n });\n return rv;\n}\nvar fullNameExceptions = errorList.reduce(function(obj, name) {\n if ([\n \"Syntax\",\n \"Type\",\n \"Range\"\n ].indexOf(name) === -1) obj[name + \"Error\"] = exceptions[name];\n return obj;\n}, {\n});\nfullNameExceptions.ModifyError = ModifyError;\nfullNameExceptions.DexieError = DexieError;\nfullNameExceptions.BulkError = BulkError;\nfunction nop() {\n}\nfunction mirror(val) {\n return val;\n}\nfunction pureFunctionChain(f1, f2) {\n if (f1 == null || f1 === mirror) return f2;\n return function(val) {\n return f2(f1(val));\n };\n}\nfunction callBoth(on1, on2) {\n return function() {\n on1.apply(this, arguments);\n on2.apply(this, arguments);\n };\n}\nfunction hookCreatingChain(f1, f2) {\n if (f1 === nop) return f2;\n return function() {\n var res = f1.apply(this, arguments);\n if (res !== undefined) arguments[0] = res;\n var onsuccess = this.onsuccess, onerror = this.onerror;\n this.onsuccess = null;\n this.onerror = null;\n var res2 = f2.apply(this, arguments);\n if (onsuccess) this.onsuccess = this.onsuccess ? callBoth(onsuccess, this.onsuccess) : onsuccess;\n if (onerror) this.onerror = this.onerror ? callBoth(onerror, this.onerror) : onerror;\n return res2 !== undefined ? res2 : res;\n };\n}\nfunction hookDeletingChain(f1, f2) {\n if (f1 === nop) return f2;\n return function() {\n f1.apply(this, arguments);\n var onsuccess = this.onsuccess, onerror = this.onerror;\n this.onsuccess = this.onerror = null;\n f2.apply(this, arguments);\n if (onsuccess) this.onsuccess = this.onsuccess ? callBoth(onsuccess, this.onsuccess) : onsuccess;\n if (onerror) this.onerror = this.onerror ? callBoth(onerror, this.onerror) : onerror;\n };\n}\nfunction hookUpdatingChain(f1, f2) {\n if (f1 === nop) return f2;\n return function(modifications) {\n var res = f1.apply(this, arguments);\n extend(modifications, res);\n var onsuccess = this.onsuccess, onerror = this.onerror;\n this.onsuccess = null;\n this.onerror = null;\n var res2 = f2.apply(this, arguments);\n if (onsuccess) this.onsuccess = this.onsuccess ? callBoth(onsuccess, this.onsuccess) : onsuccess;\n if (onerror) this.onerror = this.onerror ? callBoth(onerror, this.onerror) : onerror;\n return res === undefined ? res2 === undefined ? undefined : res2 : extend(res, res2);\n };\n}\nfunction reverseStoppableEventChain(f1, f2) {\n if (f1 === nop) return f2;\n return function() {\n if (f2.apply(this, arguments) === false) return false;\n return f1.apply(this, arguments);\n };\n}\nfunction promisableChain(f1, f2) {\n if (f1 === nop) return f2;\n return function() {\n var res = f1.apply(this, arguments);\n if (res && typeof res.then === 'function') {\n var thiz = this, i = arguments.length, args = new Array(i);\n while(i--)args[i] = arguments[i];\n return res.then(function() {\n return f2.apply(thiz, args);\n });\n }\n return f2.apply(this, arguments);\n };\n}\nvar INTERNAL = {\n};\nvar LONG_STACKS_CLIP_LIMIT = 100, MAX_LONG_STACKS = 20, ZONE_ECHO_LIMIT = 100, _a$1 = typeof Promise === 'undefined' ? [] : function() {\n var globalP = Promise.resolve();\n if (typeof crypto === 'undefined' || !crypto.subtle) return [\n globalP,\n getProto(globalP),\n globalP\n ];\n var nativeP = crypto.subtle.digest(\"SHA-512\", new Uint8Array([\n 0\n ]));\n return [\n nativeP,\n getProto(nativeP),\n globalP\n ];\n}(), resolvedNativePromise = _a$1[0], nativePromiseProto = _a$1[1], resolvedGlobalPromise = _a$1[2], nativePromiseThen = nativePromiseProto && nativePromiseProto.then;\nvar NativePromise = resolvedNativePromise && resolvedNativePromise.constructor;\nvar patchGlobalPromise = !!resolvedGlobalPromise;\nvar stack_being_generated = false;\nvar schedulePhysicalTick = resolvedGlobalPromise ? function() {\n resolvedGlobalPromise.then(physicalTick);\n} : _global.setImmediate ? setImmediate.bind(null, physicalTick) : _global.MutationObserver ? function() {\n var hiddenDiv = document.createElement(\"div\");\n new MutationObserver(function() {\n physicalTick();\n hiddenDiv = null;\n }).observe(hiddenDiv, {\n attributes: true\n });\n hiddenDiv.setAttribute('i', '1');\n} : function() {\n setTimeout(physicalTick, 0);\n};\nvar asap = function(callback, args) {\n microtickQueue.push([\n callback,\n args\n ]);\n if (needsNewPhysicalTick) {\n schedulePhysicalTick();\n needsNewPhysicalTick = false;\n }\n};\nvar isOutsideMicroTick = true, needsNewPhysicalTick = true, unhandledErrors = [], rejectingErrors = [], currentFulfiller = null, rejectionMapper = mirror;\nvar globalPSD = {\n id: 'global',\n global: true,\n ref: 0,\n unhandleds: [],\n onunhandled: globalError,\n pgp: false,\n env: {\n },\n finalize: function() {\n this.unhandleds.forEach(function(uh) {\n try {\n globalError(uh[0], uh[1]);\n } catch (e) {\n }\n });\n }\n};\nvar PSD = globalPSD;\nvar microtickQueue = [];\nvar numScheduledCalls = 0;\nvar tickFinalizers = [];\nfunction DexiePromise(fn) {\n if (typeof this !== 'object') throw new TypeError('Promises must be constructed via new');\n this._listeners = [];\n this.onuncatched = nop;\n this._lib = false;\n var psd = this._PSD = PSD;\n if (debug) {\n this._stackHolder = getErrorWithStack();\n this._prev = null;\n this._numPrev = 0;\n }\n if (typeof fn !== 'function') {\n if (fn !== INTERNAL) throw new TypeError('Not a function');\n this._state = arguments[1];\n this._value = arguments[2];\n if (this._state === false) handleRejection(this, this._value);\n return;\n }\n this._state = null;\n this._value = null;\n ++psd.ref;\n executePromiseTask(this, fn);\n}\nvar thenProp = {\n get: function() {\n var psd = PSD, microTaskId = totalEchoes;\n function then(onFulfilled, onRejected) {\n var _this = this;\n var possibleAwait = !psd.global && (psd !== PSD || microTaskId !== totalEchoes);\n var cleanup = possibleAwait && !decrementExpectedAwaits();\n var rv = new DexiePromise(function(resolve, reject) {\n propagateToListener(_this, new Listener(nativeAwaitCompatibleWrap(onFulfilled, psd, possibleAwait, cleanup), nativeAwaitCompatibleWrap(onRejected, psd, possibleAwait, cleanup), resolve, reject, psd));\n });\n debug && linkToPreviousPromise(rv, this);\n return rv;\n }\n then.prototype = INTERNAL;\n return then;\n },\n set: function(value) {\n setProp(this, 'then', value && value.prototype === INTERNAL ? thenProp : {\n get: function() {\n return value;\n },\n set: thenProp.set\n });\n }\n};\nprops(DexiePromise.prototype, {\n then: thenProp,\n _then: function(onFulfilled, onRejected) {\n propagateToListener(this, new Listener(null, null, onFulfilled, onRejected, PSD));\n },\n catch: function(onRejected) {\n if (arguments.length === 1) return this.then(null, onRejected);\n var type1 = arguments[0], handler = arguments[1];\n return typeof type1 === 'function' ? this.then(null, function(err) {\n return err instanceof type1 ? handler(err) : PromiseReject(err);\n }) : this.then(null, function(err) {\n return err && err.name === type1 ? handler(err) : PromiseReject(err);\n });\n },\n finally: function(onFinally) {\n return this.then(function(value) {\n onFinally();\n return value;\n }, function(err) {\n onFinally();\n return PromiseReject(err);\n });\n },\n stack: {\n get: function() {\n if (this._stack) return this._stack;\n try {\n stack_being_generated = true;\n var stacks = getStack(this, [], MAX_LONG_STACKS);\n var stack = stacks.join(\"\\nFrom previous: \");\n if (this._state !== null) this._stack = stack;\n return stack;\n } finally{\n stack_being_generated = false;\n }\n }\n },\n timeout: function(ms, msg) {\n var _this = this;\n return ms < Infinity ? new DexiePromise(function(resolve, reject) {\n var handle = setTimeout(function() {\n return reject(new exceptions.Timeout(msg));\n }, ms);\n _this.then(resolve, reject).finally(clearTimeout.bind(null, handle));\n }) : this;\n }\n});\nif (typeof Symbol !== 'undefined' && Symbol.toStringTag) setProp(DexiePromise.prototype, Symbol.toStringTag, 'Dexie.Promise');\nglobalPSD.env = snapShot();\nfunction Listener(onFulfilled, onRejected, resolve, reject, zone) {\n this.onFulfilled = typeof onFulfilled === 'function' ? onFulfilled : null;\n this.onRejected = typeof onRejected === 'function' ? onRejected : null;\n this.resolve = resolve;\n this.reject = reject;\n this.psd = zone;\n}\nprops(DexiePromise, {\n all: function() {\n var values = getArrayOf.apply(null, arguments).map(onPossibleParallellAsync);\n return new DexiePromise(function(resolve, reject) {\n if (values.length === 0) resolve([]);\n var remaining = values.length;\n values.forEach(function(a, i) {\n return DexiePromise.resolve(a).then(function(x) {\n values[i] = x;\n if (!--remaining) resolve(values);\n }, reject);\n });\n });\n },\n resolve: function(value) {\n if (value instanceof DexiePromise) return value;\n if (value && typeof value.then === 'function') return new DexiePromise(function(resolve, reject) {\n value.then(resolve, reject);\n });\n var rv = new DexiePromise(INTERNAL, true, value);\n linkToPreviousPromise(rv, currentFulfiller);\n return rv;\n },\n reject: PromiseReject,\n race: function() {\n var values = getArrayOf.apply(null, arguments).map(onPossibleParallellAsync);\n return new DexiePromise(function(resolve, reject) {\n values.map(function(value) {\n return DexiePromise.resolve(value).then(resolve, reject);\n });\n });\n },\n PSD: {\n get: function() {\n return PSD;\n },\n set: function(value) {\n return PSD = value;\n }\n },\n totalEchoes: {\n get: function() {\n return totalEchoes;\n }\n },\n newPSD: newScope,\n usePSD: usePSD,\n scheduler: {\n get: function() {\n return asap;\n },\n set: function(value) {\n asap = value;\n }\n },\n rejectionMapper: {\n get: function() {\n return rejectionMapper;\n },\n set: function(value) {\n rejectionMapper = value;\n }\n },\n follow: function(fn, zoneProps) {\n return new DexiePromise(function(resolve1, reject1) {\n return newScope(function(resolve, reject) {\n var psd = PSD;\n psd.unhandleds = [];\n psd.onunhandled = reject;\n psd.finalize = callBoth(function() {\n var _this = this;\n run_at_end_of_this_or_next_physical_tick(function() {\n _this.unhandleds.length === 0 ? resolve() : reject(_this.unhandleds[0]);\n });\n }, psd.finalize);\n fn();\n }, zoneProps, resolve1, reject1);\n });\n }\n});\nif (NativePromise) {\n if (NativePromise.allSettled) setProp(DexiePromise, \"allSettled\", function() {\n var possiblePromises = getArrayOf.apply(null, arguments).map(onPossibleParallellAsync);\n return new DexiePromise(function(resolve) {\n if (possiblePromises.length === 0) resolve([]);\n var remaining = possiblePromises.length;\n var results = new Array(remaining);\n possiblePromises.forEach(function(p, i) {\n return DexiePromise.resolve(p).then(function(value) {\n return results[i] = {\n status: \"fulfilled\",\n value: value\n };\n }, function(reason) {\n return results[i] = {\n status: \"rejected\",\n reason: reason\n };\n }).then(function() {\n return --remaining || resolve(results);\n });\n });\n });\n });\n if (NativePromise.any && typeof AggregateError !== 'undefined') setProp(DexiePromise, \"any\", function() {\n var possiblePromises = getArrayOf.apply(null, arguments).map(onPossibleParallellAsync);\n return new DexiePromise(function(resolve, reject) {\n if (possiblePromises.length === 0) reject(new AggregateError([]));\n var remaining = possiblePromises.length;\n var failures = new Array(remaining);\n possiblePromises.forEach(function(p, i) {\n return DexiePromise.resolve(p).then(function(value) {\n return resolve(value);\n }, function(failure) {\n failures[i] = failure;\n if (!--remaining) reject(new AggregateError(failures));\n });\n });\n });\n });\n}\nfunction executePromiseTask(promise, fn) {\n try {\n fn(function(value) {\n if (promise._state !== null) return;\n if (value === promise) throw new TypeError('A promise cannot be resolved with itself.');\n var shouldExecuteTick = promise._lib && beginMicroTickScope();\n if (value && typeof value.then === 'function') executePromiseTask(promise, function(resolve, reject) {\n value instanceof DexiePromise ? value._then(resolve, reject) : value.then(resolve, reject);\n });\n else {\n promise._state = true;\n promise._value = value;\n propagateAllListeners(promise);\n }\n if (shouldExecuteTick) endMicroTickScope();\n }, handleRejection.bind(null, promise));\n } catch (ex) {\n handleRejection(promise, ex);\n }\n}\nfunction handleRejection(promise, reason) {\n rejectingErrors.push(reason);\n if (promise._state !== null) return;\n var shouldExecuteTick = promise._lib && beginMicroTickScope();\n reason = rejectionMapper(reason);\n promise._state = false;\n promise._value = reason;\n debug && reason !== null && typeof reason === 'object' && !reason._promise && tryCatch(function() {\n var origProp = getPropertyDescriptor(reason, \"stack\");\n reason._promise = promise;\n setProp(reason, \"stack\", {\n get: function() {\n return stack_being_generated ? origProp && (origProp.get ? origProp.get.apply(reason) : origProp.value) : promise.stack;\n }\n });\n });\n addPossiblyUnhandledError(promise);\n propagateAllListeners(promise);\n if (shouldExecuteTick) endMicroTickScope();\n}\nfunction propagateAllListeners(promise) {\n var listeners = promise._listeners;\n promise._listeners = [];\n for(var i = 0, len = listeners.length; i < len; ++i)propagateToListener(promise, listeners[i]);\n var psd = promise._PSD;\n --psd.ref || psd.finalize();\n if (numScheduledCalls === 0) {\n ++numScheduledCalls;\n asap(function() {\n if (--numScheduledCalls === 0) finalizePhysicalTick();\n }, []);\n }\n}\nfunction propagateToListener(promise, listener) {\n if (promise._state === null) {\n promise._listeners.push(listener);\n return;\n }\n var cb = promise._state ? listener.onFulfilled : listener.onRejected;\n if (cb === null) return (promise._state ? listener.resolve : listener.reject)(promise._value);\n ++listener.psd.ref;\n ++numScheduledCalls;\n asap(callListener, [\n cb,\n promise,\n listener\n ]);\n}\nfunction callListener(cb, promise, listener) {\n try {\n currentFulfiller = promise;\n var ret, value = promise._value;\n if (promise._state) ret = cb(value);\n else {\n if (rejectingErrors.length) rejectingErrors = [];\n ret = cb(value);\n if (rejectingErrors.indexOf(value) === -1) markErrorAsHandled(promise);\n }\n listener.resolve(ret);\n } catch (e) {\n listener.reject(e);\n } finally{\n currentFulfiller = null;\n if (--numScheduledCalls === 0) finalizePhysicalTick();\n --listener.psd.ref || listener.psd.finalize();\n }\n}\nfunction getStack(promise, stacks, limit) {\n if (stacks.length === limit) return stacks;\n var stack = \"\";\n if (promise._state === false) {\n var failure = promise._value, errorName, message;\n if (failure != null) {\n errorName = failure.name || \"Error\";\n message = failure.message || failure;\n stack = prettyStack(failure, 0);\n } else {\n errorName = failure;\n message = \"\";\n }\n stacks.push(errorName + (message ? \": \" + message : \"\") + stack);\n }\n if (debug) {\n stack = prettyStack(promise._stackHolder, 2);\n if (stack && stacks.indexOf(stack) === -1) stacks.push(stack);\n if (promise._prev) getStack(promise._prev, stacks, limit);\n }\n return stacks;\n}\nfunction linkToPreviousPromise(promise, prev) {\n var numPrev = prev ? prev._numPrev + 1 : 0;\n if (numPrev < LONG_STACKS_CLIP_LIMIT) {\n promise._prev = prev;\n promise._numPrev = numPrev;\n }\n}\nfunction physicalTick() {\n beginMicroTickScope() && endMicroTickScope();\n}\nfunction beginMicroTickScope() {\n var wasRootExec = isOutsideMicroTick;\n isOutsideMicroTick = false;\n needsNewPhysicalTick = false;\n return wasRootExec;\n}\nfunction endMicroTickScope() {\n var callbacks, i, l;\n do while(microtickQueue.length > 0){\n callbacks = microtickQueue;\n microtickQueue = [];\n l = callbacks.length;\n for(i = 0; i < l; ++i){\n var item = callbacks[i];\n item[0].apply(null, item[1]);\n }\n }\n while (microtickQueue.length > 0)\n isOutsideMicroTick = true;\n needsNewPhysicalTick = true;\n}\nfunction finalizePhysicalTick() {\n var unhandledErrs = unhandledErrors;\n unhandledErrors = [];\n unhandledErrs.forEach(function(p) {\n p._PSD.onunhandled.call(null, p._value, p);\n });\n var finalizers = tickFinalizers.slice(0);\n var i = finalizers.length;\n while(i)finalizers[--i]();\n}\nfunction run_at_end_of_this_or_next_physical_tick(fn) {\n function finalizer() {\n fn();\n tickFinalizers.splice(tickFinalizers.indexOf(finalizer), 1);\n }\n tickFinalizers.push(finalizer);\n ++numScheduledCalls;\n asap(function() {\n if (--numScheduledCalls === 0) finalizePhysicalTick();\n }, []);\n}\nfunction addPossiblyUnhandledError(promise) {\n if (!unhandledErrors.some(function(p) {\n return p._value === promise._value;\n })) unhandledErrors.push(promise);\n}\nfunction markErrorAsHandled(promise) {\n var i = unhandledErrors.length;\n while(i)if (unhandledErrors[--i]._value === promise._value) {\n unhandledErrors.splice(i, 1);\n return;\n }\n}\nfunction PromiseReject(reason) {\n return new DexiePromise(INTERNAL, false, reason);\n}\nfunction wrap(fn, errorCatcher) {\n var psd = PSD;\n return function() {\n var wasRootExec = beginMicroTickScope(), outerScope = PSD;\n try {\n switchToZone(psd, true);\n return fn.apply(this, arguments);\n } catch (e) {\n errorCatcher && errorCatcher(e);\n } finally{\n switchToZone(outerScope, false);\n if (wasRootExec) endMicroTickScope();\n }\n };\n}\nvar task = {\n awaits: 0,\n echoes: 0,\n id: 0\n};\nvar taskCounter = 0;\nvar zoneStack = [];\nvar zoneEchoes = 0;\nvar totalEchoes = 0;\nvar zone_id_counter = 0;\nfunction newScope(fn, props1, a1, a2) {\n var parent = PSD, psd = Object.create(parent);\n psd.parent = parent;\n psd.ref = 0;\n psd.global = false;\n psd.id = ++zone_id_counter;\n var globalEnv = globalPSD.env;\n psd.env = patchGlobalPromise ? {\n Promise: DexiePromise,\n PromiseProp: {\n value: DexiePromise,\n configurable: true,\n writable: true\n },\n all: DexiePromise.all,\n race: DexiePromise.race,\n allSettled: DexiePromise.allSettled,\n any: DexiePromise.any,\n resolve: DexiePromise.resolve,\n reject: DexiePromise.reject,\n nthen: getPatchedPromiseThen(globalEnv.nthen, psd),\n gthen: getPatchedPromiseThen(globalEnv.gthen, psd)\n } : {\n };\n if (props1) extend(psd, props1);\n ++parent.ref;\n psd.finalize = function() {\n --this.parent.ref || this.parent.finalize();\n };\n var rv = usePSD(psd, fn, a1, a2);\n if (psd.ref === 0) psd.finalize();\n return rv;\n}\nfunction incrementExpectedAwaits() {\n if (!task.id) task.id = ++taskCounter;\n ++task.awaits;\n task.echoes += ZONE_ECHO_LIMIT;\n return task.id;\n}\nfunction decrementExpectedAwaits() {\n if (!task.awaits) return false;\n if (--task.awaits === 0) task.id = 0;\n task.echoes = task.awaits * ZONE_ECHO_LIMIT;\n return true;\n}\nif (('' + nativePromiseThen).indexOf('[native code]') === -1) incrementExpectedAwaits = decrementExpectedAwaits = nop;\nfunction onPossibleParallellAsync(possiblePromise) {\n if (task.echoes && possiblePromise && possiblePromise.constructor === NativePromise) {\n incrementExpectedAwaits();\n return possiblePromise.then(function(x) {\n decrementExpectedAwaits();\n return x;\n }, function(e) {\n decrementExpectedAwaits();\n return rejection(e);\n });\n }\n return possiblePromise;\n}\nfunction zoneEnterEcho(targetZone) {\n ++totalEchoes;\n if (!task.echoes || --task.echoes === 0) task.echoes = task.id = 0;\n zoneStack.push(PSD);\n switchToZone(targetZone, true);\n}\nfunction zoneLeaveEcho() {\n var zone = zoneStack[zoneStack.length - 1];\n zoneStack.pop();\n switchToZone(zone, false);\n}\nfunction switchToZone(targetZone, bEnteringZone) {\n var currentZone = PSD;\n if (bEnteringZone ? task.echoes && (!zoneEchoes++ || targetZone !== PSD) : zoneEchoes && (!--zoneEchoes || targetZone !== PSD)) enqueueNativeMicroTask(bEnteringZone ? zoneEnterEcho.bind(null, targetZone) : zoneLeaveEcho);\n if (targetZone === PSD) return;\n PSD = targetZone;\n if (currentZone === globalPSD) globalPSD.env = snapShot();\n if (patchGlobalPromise) {\n var GlobalPromise_1 = globalPSD.env.Promise;\n var targetEnv = targetZone.env;\n nativePromiseProto.then = targetEnv.nthen;\n GlobalPromise_1.prototype.then = targetEnv.gthen;\n if (currentZone.global || targetZone.global) {\n Object.defineProperty(_global, 'Promise', targetEnv.PromiseProp);\n GlobalPromise_1.all = targetEnv.all;\n GlobalPromise_1.race = targetEnv.race;\n GlobalPromise_1.resolve = targetEnv.resolve;\n GlobalPromise_1.reject = targetEnv.reject;\n if (targetEnv.allSettled) GlobalPromise_1.allSettled = targetEnv.allSettled;\n if (targetEnv.any) GlobalPromise_1.any = targetEnv.any;\n }\n }\n}\nfunction snapShot() {\n var GlobalPromise = _global.Promise;\n return patchGlobalPromise ? {\n Promise: GlobalPromise,\n PromiseProp: Object.getOwnPropertyDescriptor(_global, \"Promise\"),\n all: GlobalPromise.all,\n race: GlobalPromise.race,\n allSettled: GlobalPromise.allSettled,\n any: GlobalPromise.any,\n resolve: GlobalPromise.resolve,\n reject: GlobalPromise.reject,\n nthen: nativePromiseProto.then,\n gthen: GlobalPromise.prototype.then\n } : {\n };\n}\nfunction usePSD(psd, fn, a1, a2, a3) {\n var outerScope = PSD;\n try {\n switchToZone(psd, true);\n return fn(a1, a2, a3);\n } finally{\n switchToZone(outerScope, false);\n }\n}\nfunction enqueueNativeMicroTask(job) {\n nativePromiseThen.call(resolvedNativePromise, job);\n}\nfunction nativeAwaitCompatibleWrap(fn, zone, possibleAwait, cleanup) {\n return typeof fn !== 'function' ? fn : function() {\n var outerZone = PSD;\n if (possibleAwait) incrementExpectedAwaits();\n switchToZone(zone, true);\n try {\n return fn.apply(this, arguments);\n } finally{\n switchToZone(outerZone, false);\n if (cleanup) enqueueNativeMicroTask(decrementExpectedAwaits);\n }\n };\n}\nfunction getPatchedPromiseThen(origThen, zone) {\n return function(onResolved, onRejected) {\n return origThen.call(this, nativeAwaitCompatibleWrap(onResolved, zone), nativeAwaitCompatibleWrap(onRejected, zone));\n };\n}\nvar UNHANDLEDREJECTION = \"unhandledrejection\";\nfunction globalError(err, promise) {\n var rv;\n try {\n rv = promise.onuncatched(err);\n } catch (e) {\n }\n if (rv !== false) try {\n var event, eventData = {\n promise: promise,\n reason: err\n };\n if (_global.document && document.createEvent) {\n event = document.createEvent('Event');\n event.initEvent(UNHANDLEDREJECTION, true, true);\n extend(event, eventData);\n } else if (_global.CustomEvent) {\n event = new CustomEvent(UNHANDLEDREJECTION, {\n detail: eventData\n });\n extend(event, eventData);\n }\n if (event && _global.dispatchEvent) {\n dispatchEvent(event);\n if (!_global.PromiseRejectionEvent && _global.onunhandledrejection) try {\n _global.onunhandledrejection(event);\n } catch (_) {\n }\n }\n if (debug && event && !event.defaultPrevented) console.warn(\"Unhandled rejection: \" + (err.stack || err));\n } catch (e1) {\n }\n}\nvar rejection = DexiePromise.reject;\nfunction tempTransaction(db, mode, storeNames, fn) {\n if (!db.idbdb || !db._state.openComplete && !PSD.letThrough && !db._vip) {\n if (db._state.openComplete) return rejection(new exceptions.DatabaseClosed(db._state.dbOpenError));\n if (!db._state.isBeingOpened) {\n if (!db._options.autoOpen) return rejection(new exceptions.DatabaseClosed());\n db.open().catch(nop);\n }\n return db._state.dbReadyPromise.then(function() {\n return tempTransaction(db, mode, storeNames, fn);\n });\n } else {\n var trans = db._createTransaction(mode, storeNames, db._dbSchema);\n try {\n trans.create();\n db._state.PR1398_maxLoop = 3;\n } catch (ex) {\n if (ex.name === errnames.InvalidState && db.isOpen() && --db._state.PR1398_maxLoop > 0) {\n console.warn('Dexie: Need to reopen db');\n db._close();\n return db.open().then(function() {\n return tempTransaction(db, mode, storeNames, fn);\n });\n }\n return rejection(ex);\n }\n return trans._promise(mode, function(resolve, reject) {\n return newScope(function() {\n PSD.trans = trans;\n return fn(resolve, reject, trans);\n });\n }).then(function(result) {\n return trans._completion.then(function() {\n return result;\n });\n });\n }\n}\nvar DEXIE_VERSION = '3.2.1';\nvar maxString = String.fromCharCode(65535);\nvar minKey = -Infinity;\nvar INVALID_KEY_ARGUMENT = \"Invalid key provided. Keys must be of type string, number, Date or Array<string | number | Date>.\";\nvar STRING_EXPECTED = \"String expected.\";\nvar connections = [];\nvar isIEOrEdge = typeof navigator !== 'undefined' && /(MSIE|Trident|Edge)/.test(navigator.userAgent);\nvar hasIEDeleteObjectStoreBug = isIEOrEdge;\nvar hangsOnDeleteLargeKeyRange = isIEOrEdge;\nvar dexieStackFrameFilter = function(frame) {\n return !/(dexie\\.js|dexie\\.min\\.js)/.test(frame);\n};\nvar DBNAMES_DB = '__dbnames';\nvar READONLY = 'readonly';\nvar READWRITE = 'readwrite';\nfunction combine(filter1, filter2) {\n return filter1 ? filter2 ? function() {\n return filter1.apply(this, arguments) && filter2.apply(this, arguments);\n } : filter1 : filter2;\n}\nvar AnyRange = {\n type: 3,\n lower: -Infinity,\n lowerOpen: false,\n upper: [\n []\n ],\n upperOpen: false\n};\nfunction workaroundForUndefinedPrimKey(keyPath) {\n return typeof keyPath === \"string\" && !/\\./.test(keyPath) ? function(obj) {\n if (obj[keyPath] === undefined && keyPath in obj) {\n obj = deepClone(obj);\n delete obj[keyPath];\n }\n return obj;\n } : function(obj) {\n return obj;\n };\n}\nvar Table = function() {\n function Table1() {\n }\n Table1.prototype._trans = function(mode, fn, writeLocked) {\n var trans1 = this._tx || PSD.trans;\n var tableName = this.name;\n function checkTableInTransaction(resolve, reject, trans) {\n if (!trans.schema[tableName]) throw new exceptions.NotFound(\"Table \" + tableName + \" not part of transaction\");\n return fn(trans.idbtrans, trans);\n }\n var wasRootExec = beginMicroTickScope();\n try {\n return trans1 && trans1.db === this.db ? trans1 === PSD.trans ? trans1._promise(mode, checkTableInTransaction, writeLocked) : newScope(function() {\n return trans1._promise(mode, checkTableInTransaction, writeLocked);\n }, {\n trans: trans1,\n transless: PSD.transless || PSD\n }) : tempTransaction(this.db, mode, [\n this.name\n ], checkTableInTransaction);\n } finally{\n if (wasRootExec) endMicroTickScope();\n }\n };\n Table1.prototype.get = function(keyOrCrit, cb) {\n var _this = this;\n if (keyOrCrit && keyOrCrit.constructor === Object) return this.where(keyOrCrit).first(cb);\n return this._trans('readonly', function(trans) {\n return _this.core.get({\n trans: trans,\n key: keyOrCrit\n }).then(function(res) {\n return _this.hook.reading.fire(res);\n });\n }).then(cb);\n };\n Table1.prototype.where = function(indexOrCrit) {\n if (typeof indexOrCrit === 'string') return new this.db.WhereClause(this, indexOrCrit);\n if (isArray(indexOrCrit)) return new this.db.WhereClause(this, \"[\" + indexOrCrit.join('+') + \"]\");\n var keyPaths = keys(indexOrCrit);\n if (keyPaths.length === 1) return this.where(keyPaths[0]).equals(indexOrCrit[keyPaths[0]]);\n var compoundIndex = this.schema.indexes.concat(this.schema.primKey).filter(function(ix) {\n return ix.compound && keyPaths.every(function(keyPath) {\n return ix.keyPath.indexOf(keyPath) >= 0;\n }) && ix.keyPath.every(function(keyPath) {\n return keyPaths.indexOf(keyPath) >= 0;\n });\n })[0];\n if (compoundIndex && this.db._maxKey !== maxString) return this.where(compoundIndex.name).equals(compoundIndex.keyPath.map(function(kp) {\n return indexOrCrit[kp];\n }));\n if (!compoundIndex && debug) console.warn(\"The query \" + JSON.stringify(indexOrCrit) + \" on \" + this.name + \" would benefit of a \" + (\"compound index [\" + keyPaths.join('+') + \"]\"));\n var idxByName = this.schema.idxByName;\n var idb = this.db._deps.indexedDB;\n function equals(a, b) {\n try {\n return idb.cmp(a, b) === 0;\n } catch (e) {\n return false;\n }\n }\n var _a1 = keyPaths.reduce(function(_a2, keyPath) {\n var prevIndex = _a2[0], prevFilterFn = _a2[1];\n var index = idxByName[keyPath];\n var value = indexOrCrit[keyPath];\n return [\n prevIndex || index,\n prevIndex || !index ? combine(prevFilterFn, index && index.multi ? function(x) {\n var prop = getByKeyPath(x, keyPath);\n return isArray(prop) && prop.some(function(item) {\n return equals(value, item);\n });\n } : function(x) {\n return equals(value, getByKeyPath(x, keyPath));\n }) : prevFilterFn\n ];\n }, [\n null,\n null\n ]), idx = _a1[0], filterFunction = _a1[1];\n return idx ? this.where(idx.name).equals(indexOrCrit[idx.keyPath]).filter(filterFunction) : compoundIndex ? this.filter(filterFunction) : this.where(keyPaths).equals('');\n };\n Table1.prototype.filter = function(filterFunction) {\n return this.toCollection().and(filterFunction);\n };\n Table1.prototype.count = function(thenShortcut) {\n return this.toCollection().count(thenShortcut);\n };\n Table1.prototype.offset = function(offset) {\n return this.toCollection().offset(offset);\n };\n Table1.prototype.limit = function(numRows) {\n return this.toCollection().limit(numRows);\n };\n Table1.prototype.each = function(callback) {\n return this.toCollection().each(callback);\n };\n Table1.prototype.toArray = function(thenShortcut) {\n return this.toCollection().toArray(thenShortcut);\n };\n Table1.prototype.toCollection = function() {\n return new this.db.Collection(new this.db.WhereClause(this));\n };\n Table1.prototype.orderBy = function(index) {\n return new this.db.Collection(new this.db.WhereClause(this, isArray(index) ? \"[\" + index.join('+') + \"]\" : index));\n };\n Table1.prototype.reverse = function() {\n return this.toCollection().reverse();\n };\n Table1.prototype.mapToClass = function(constructor) {\n this.schema.mappedClass = constructor;\n var readHook = function(obj) {\n if (!obj) return obj;\n var res = Object.create(constructor.prototype);\n for(var m in obj)if (hasOwn(obj, m)) try {\n res[m] = obj[m];\n } catch (_) {\n }\n return res;\n };\n if (this.schema.readHook) this.hook.reading.unsubscribe(this.schema.readHook);\n this.schema.readHook = readHook;\n this.hook(\"reading\", readHook);\n return constructor;\n };\n Table1.prototype.defineClass = function() {\n function Class(content) {\n extend(this, content);\n }\n return this.mapToClass(Class);\n };\n Table1.prototype.add = function(obj, key) {\n var _this = this;\n var _a3 = this.schema.primKey, auto = _a3.auto, keyPath = _a3.keyPath;\n var objToAdd = obj;\n if (keyPath && auto) objToAdd = workaroundForUndefinedPrimKey(keyPath)(obj);\n return this._trans('readwrite', function(trans) {\n return _this.core.mutate({\n trans: trans,\n type: 'add',\n keys: key != null ? [\n key\n ] : null,\n values: [\n objToAdd\n ]\n });\n }).then(function(res) {\n return res.numFailures ? DexiePromise.reject(res.failures[0]) : res.lastResult;\n }).then(function(lastResult) {\n if (keyPath) try {\n setByKeyPath(obj, keyPath, lastResult);\n } catch (_) {\n }\n return lastResult;\n });\n };\n Table1.prototype.update = function(keyOrObject, modifications) {\n if (typeof keyOrObject === 'object' && !isArray(keyOrObject)) {\n var key = getByKeyPath(keyOrObject, this.schema.primKey.keyPath);\n if (key === undefined) return rejection(new exceptions.InvalidArgument(\"Given object does not contain its primary key\"));\n try {\n if (typeof modifications !== \"function\") keys(modifications).forEach(function(keyPath) {\n setByKeyPath(keyOrObject, keyPath, modifications[keyPath]);\n });\n else modifications(keyOrObject, {\n value: keyOrObject,\n primKey: key\n });\n } catch (_a) {\n }\n return this.where(\":id\").equals(key).modify(modifications);\n } else return this.where(\":id\").equals(keyOrObject).modify(modifications);\n };\n Table1.prototype.put = function(obj, key) {\n var _this = this;\n var _a4 = this.schema.primKey, auto = _a4.auto, keyPath = _a4.keyPath;\n var objToAdd = obj;\n if (keyPath && auto) objToAdd = workaroundForUndefinedPrimKey(keyPath)(obj);\n return this._trans('readwrite', function(trans) {\n return _this.core.mutate({\n trans: trans,\n type: 'put',\n values: [\n objToAdd\n ],\n keys: key != null ? [\n key\n ] : null\n });\n }).then(function(res) {\n return res.numFailures ? DexiePromise.reject(res.failures[0]) : res.lastResult;\n }).then(function(lastResult) {\n if (keyPath) try {\n setByKeyPath(obj, keyPath, lastResult);\n } catch (_) {\n }\n return lastResult;\n });\n };\n Table1.prototype.delete = function(key) {\n var _this = this;\n return this._trans('readwrite', function(trans) {\n return _this.core.mutate({\n trans: trans,\n type: 'delete',\n keys: [\n key\n ]\n });\n }).then(function(res) {\n return res.numFailures ? DexiePromise.reject(res.failures[0]) : undefined;\n });\n };\n Table1.prototype.clear = function() {\n var _this = this;\n return this._trans('readwrite', function(trans) {\n return _this.core.mutate({\n trans: trans,\n type: 'deleteRange',\n range: AnyRange\n });\n }).then(function(res) {\n return res.numFailures ? DexiePromise.reject(res.failures[0]) : undefined;\n });\n };\n Table1.prototype.bulkGet = function(keys1) {\n var _this = this;\n return this._trans('readonly', function(trans) {\n return _this.core.getMany({\n keys: keys1,\n trans: trans\n }).then(function(result) {\n return result.map(function(res) {\n return _this.hook.reading.fire(res);\n });\n });\n });\n };\n Table1.prototype.bulkAdd = function(objects, keysOrOptions, options) {\n var _this = this;\n var keys2 = Array.isArray(keysOrOptions) ? keysOrOptions : undefined;\n options = options || (keys2 ? undefined : keysOrOptions);\n var wantResults = options ? options.allKeys : undefined;\n return this._trans('readwrite', function(trans) {\n var _a5 = _this.schema.primKey, auto = _a5.auto, keyPath = _a5.keyPath;\n if (keyPath && keys2) throw new exceptions.InvalidArgument(\"bulkAdd(): keys argument invalid on tables with inbound keys\");\n if (keys2 && keys2.length !== objects.length) throw new exceptions.InvalidArgument(\"Arguments objects and keys must have the same length\");\n var numObjects = objects.length;\n var objectsToAdd = keyPath && auto ? objects.map(workaroundForUndefinedPrimKey(keyPath)) : objects;\n return _this.core.mutate({\n trans: trans,\n type: 'add',\n keys: keys2,\n values: objectsToAdd,\n wantResults: wantResults\n }).then(function(_a6) {\n var numFailures = _a6.numFailures, results = _a6.results, lastResult = _a6.lastResult, failures = _a6.failures;\n var result = wantResults ? results : lastResult;\n if (numFailures === 0) return result;\n throw new BulkError(_this.name + \".bulkAdd(): \" + numFailures + \" of \" + numObjects + \" operations failed\", failures);\n });\n });\n };\n Table1.prototype.bulkPut = function(objects, keysOrOptions, options) {\n var _this = this;\n var keys3 = Array.isArray(keysOrOptions) ? keysOrOptions : undefined;\n options = options || (keys3 ? undefined : keysOrOptions);\n var wantResults = options ? options.allKeys : undefined;\n return this._trans('readwrite', function(trans) {\n var _a7 = _this.schema.primKey, auto = _a7.auto, keyPath = _a7.keyPath;\n if (keyPath && keys3) throw new exceptions.InvalidArgument(\"bulkPut(): keys argument invalid on tables with inbound keys\");\n if (keys3 && keys3.length !== objects.length) throw new exceptions.InvalidArgument(\"Arguments objects and keys must have the same length\");\n var numObjects = objects.length;\n var objectsToPut = keyPath && auto ? objects.map(workaroundForUndefinedPrimKey(keyPath)) : objects;\n return _this.core.mutate({\n trans: trans,\n type: 'put',\n keys: keys3,\n values: objectsToPut,\n wantResults: wantResults\n }).then(function(_a8) {\n var numFailures = _a8.numFailures, results = _a8.results, lastResult = _a8.lastResult, failures = _a8.failures;\n var result = wantResults ? results : lastResult;\n if (numFailures === 0) return result;\n throw new BulkError(_this.name + \".bulkPut(): \" + numFailures + \" of \" + numObjects + \" operations failed\", failures);\n });\n });\n };\n Table1.prototype.bulkDelete = function(keys4) {\n var _this = this;\n var numKeys = keys4.length;\n return this._trans('readwrite', function(trans) {\n return _this.core.mutate({\n trans: trans,\n type: 'delete',\n keys: keys4\n });\n }).then(function(_a9) {\n var numFailures = _a9.numFailures, lastResult = _a9.lastResult, failures = _a9.failures;\n if (numFailures === 0) return lastResult;\n throw new BulkError(_this.name + \".bulkDelete(): \" + numFailures + \" of \" + numKeys + \" operations failed\", failures);\n });\n };\n return Table1;\n}();\nfunction Events(ctx) {\n var evs = {\n };\n var rv = function(eventName, subscriber) {\n if (subscriber) {\n var i = arguments.length, args = new Array(i - 1);\n while(--i)args[i - 1] = arguments[i];\n evs[eventName].subscribe.apply(null, args);\n return ctx;\n } else if (typeof eventName === 'string') return evs[eventName];\n };\n rv.addEventType = add;\n for(var i1 = 1, l = arguments.length; i1 < l; ++i1)add(arguments[i1]);\n function add(eventName, chainFunction, defaultFunction) {\n if (typeof eventName === 'object') return addConfiguredEvents(eventName);\n if (!chainFunction) chainFunction = reverseStoppableEventChain;\n if (!defaultFunction) defaultFunction = nop;\n var context = {\n subscribers: [],\n fire: defaultFunction,\n subscribe: function(cb) {\n if (context.subscribers.indexOf(cb) === -1) {\n context.subscribers.push(cb);\n context.fire = chainFunction(context.fire, cb);\n }\n },\n unsubscribe: function(cb) {\n context.subscribers = context.subscribers.filter(function(fn) {\n return fn !== cb;\n });\n context.fire = context.subscribers.reduce(chainFunction, defaultFunction);\n }\n };\n evs[eventName] = rv[eventName] = context;\n return context;\n }\n function addConfiguredEvents(cfg) {\n keys(cfg).forEach(function(eventName) {\n var args1 = cfg[eventName];\n if (isArray(args1)) {\n add(eventName, cfg[eventName][0], cfg[eventName][1]);\n } else if (args1 === 'asap') {\n var context = add(eventName, mirror, function fire() {\n var i = arguments.length, args = new Array(i);\n while(i--)args[i] = arguments[i];\n context.subscribers.forEach(function(fn) {\n asap$1(function fireEvent() {\n fn.apply(null, args);\n });\n });\n });\n } else throw new exceptions.InvalidArgument(\"Invalid event config\");\n });\n }\n return rv;\n}\nfunction makeClassConstructor(prototype, constructor) {\n derive(constructor).from({\n prototype: prototype\n });\n return constructor;\n}\nfunction createTableConstructor(db) {\n return makeClassConstructor(Table.prototype, function Table(name, tableSchema, trans) {\n this.db = db;\n this._tx = trans;\n this.name = name;\n this.schema = tableSchema;\n this.hook = db._allTables[name] ? db._allTables[name].hook : Events(null, {\n \"creating\": [\n hookCreatingChain,\n nop\n ],\n \"reading\": [\n pureFunctionChain,\n mirror\n ],\n \"updating\": [\n hookUpdatingChain,\n nop\n ],\n \"deleting\": [\n hookDeletingChain,\n nop\n ]\n });\n });\n}\nfunction isPlainKeyRange(ctx, ignoreLimitFilter) {\n return !(ctx.filter || ctx.algorithm || ctx.or) && (ignoreLimitFilter ? ctx.justLimit : !ctx.replayFilter);\n}\nfunction addFilter(ctx, fn) {\n ctx.filter = combine(ctx.filter, fn);\n}\nfunction addReplayFilter(ctx, factory, isLimitFilter) {\n var curr = ctx.replayFilter;\n ctx.replayFilter = curr ? function() {\n return combine(curr(), factory());\n } : factory;\n ctx.justLimit = isLimitFilter && !curr;\n}\nfunction addMatchFilter(ctx, fn) {\n ctx.isMatch = combine(ctx.isMatch, fn);\n}\nfunction getIndexOrStore(ctx, coreSchema) {\n if (ctx.isPrimKey) return coreSchema.primaryKey;\n var index = coreSchema.getIndexByKeyPath(ctx.index);\n if (!index) throw new exceptions.Schema(\"KeyPath \" + ctx.index + \" on object store \" + coreSchema.name + \" is not indexed\");\n return index;\n}\nfunction openCursor(ctx, coreTable, trans) {\n var index = getIndexOrStore(ctx, coreTable.schema);\n return coreTable.openCursor({\n trans: trans,\n values: !ctx.keysOnly,\n reverse: ctx.dir === 'prev',\n unique: !!ctx.unique,\n query: {\n index: index,\n range: ctx.range\n }\n });\n}\nfunction iter(ctx, fn, coreTrans, coreTable) {\n var filter = ctx.replayFilter ? combine(ctx.filter, ctx.replayFilter()) : ctx.filter;\n if (!ctx.or) return iterate(openCursor(ctx, coreTable, coreTrans), combine(ctx.algorithm, filter), fn, !ctx.keysOnly && ctx.valueMapper);\n else {\n var set_1 = {\n };\n var union = function(item, cursor, advance) {\n if (!filter || filter(cursor, advance, function(result) {\n return cursor.stop(result);\n }, function(err) {\n return cursor.fail(err);\n })) {\n var primaryKey = cursor.primaryKey;\n var key = '' + primaryKey;\n if (key === '[object ArrayBuffer]') key = '' + new Uint8Array(primaryKey);\n if (!hasOwn(set_1, key)) {\n set_1[key] = true;\n fn(item, cursor, advance);\n }\n }\n };\n return Promise.all([\n ctx.or._iterate(union, coreTrans),\n iterate(openCursor(ctx, coreTable, coreTrans), ctx.algorithm, union, !ctx.keysOnly && ctx.valueMapper)\n ]);\n }\n}\nfunction iterate(cursorPromise, filter, fn, valueMapper) {\n var mappedFn = valueMapper ? function(x, c, a) {\n return fn(valueMapper(x), c, a);\n } : fn;\n var wrappedFn = wrap(mappedFn);\n return cursorPromise.then(function(cursor) {\n if (cursor) return cursor.start(function() {\n var c = function() {\n return cursor.continue();\n };\n if (!filter || filter(cursor, function(advancer) {\n return c = advancer;\n }, function(val) {\n cursor.stop(val);\n c = nop;\n }, function(e) {\n cursor.fail(e);\n c = nop;\n })) wrappedFn(cursor.value, cursor, function(advancer) {\n return c = advancer;\n });\n c();\n });\n });\n}\nfunction cmp(a, b) {\n try {\n var ta = type(a);\n var tb = type(b);\n if (ta !== tb) {\n if (ta === 'Array') return 1;\n if (tb === 'Array') return -1;\n if (ta === 'binary') return 1;\n if (tb === 'binary') return -1;\n if (ta === 'string') return 1;\n if (tb === 'string') return -1;\n if (ta === 'Date') return 1;\n if (tb !== 'Date') return NaN;\n return -1;\n }\n switch(ta){\n case 'number':\n case 'Date':\n case 'string':\n return a > b ? 1 : a < b ? -1 : 0;\n case 'binary':\n return compareUint8Arrays(getUint8Array(a), getUint8Array(b));\n case 'Array':\n return compareArrays(a, b);\n }\n } catch (_a) {\n }\n return NaN;\n}\nfunction compareArrays(a, b) {\n var al = a.length;\n var bl = b.length;\n var l = al < bl ? al : bl;\n for(var i = 0; i < l; ++i){\n var res = cmp(a[i], b[i]);\n if (res !== 0) return res;\n }\n return al === bl ? 0 : al < bl ? -1 : 1;\n}\nfunction compareUint8Arrays(a, b) {\n var al = a.length;\n var bl = b.length;\n var l = al < bl ? al : bl;\n for(var i = 0; i < l; ++i){\n if (a[i] !== b[i]) return a[i] < b[i] ? -1 : 1;\n }\n return al === bl ? 0 : al < bl ? -1 : 1;\n}\nfunction type(x) {\n var t = typeof x;\n if (t !== 'object') return t;\n if (ArrayBuffer.isView(x)) return 'binary';\n var tsTag = toStringTag(x);\n return tsTag === 'ArrayBuffer' ? 'binary' : tsTag;\n}\nfunction getUint8Array(a) {\n if (a instanceof Uint8Array) return a;\n if (ArrayBuffer.isView(a)) return new Uint8Array(a.buffer, a.byteOffset, a.byteLength);\n return new Uint8Array(a);\n}\nvar Collection = function() {\n function Collection1() {\n }\n Collection1.prototype._read = function(fn, cb) {\n var ctx = this._ctx;\n return ctx.error ? ctx.table._trans(null, rejection.bind(null, ctx.error)) : ctx.table._trans('readonly', fn).then(cb);\n };\n Collection1.prototype._write = function(fn) {\n var ctx = this._ctx;\n return ctx.error ? ctx.table._trans(null, rejection.bind(null, ctx.error)) : ctx.table._trans('readwrite', fn, \"locked\");\n };\n Collection1.prototype._addAlgorithm = function(fn) {\n var ctx = this._ctx;\n ctx.algorithm = combine(ctx.algorithm, fn);\n };\n Collection1.prototype._iterate = function(fn, coreTrans) {\n return iter(this._ctx, fn, coreTrans, this._ctx.table.core);\n };\n Collection1.prototype.clone = function(props2) {\n var rv = Object.create(this.constructor.prototype), ctx = Object.create(this._ctx);\n if (props2) extend(ctx, props2);\n rv._ctx = ctx;\n return rv;\n };\n Collection1.prototype.raw = function() {\n this._ctx.valueMapper = null;\n return this;\n };\n Collection1.prototype.each = function(fn) {\n var ctx = this._ctx;\n return this._read(function(trans) {\n return iter(ctx, fn, trans, ctx.table.core);\n });\n };\n Collection1.prototype.count = function(cb) {\n var _this = this;\n return this._read(function(trans) {\n var ctx = _this._ctx;\n var coreTable = ctx.table.core;\n if (isPlainKeyRange(ctx, true)) return coreTable.count({\n trans: trans,\n query: {\n index: getIndexOrStore(ctx, coreTable.schema),\n range: ctx.range\n }\n }).then(function(count) {\n return Math.min(count, ctx.limit);\n });\n else {\n var count1 = 0;\n return iter(ctx, function() {\n ++count1;\n return false;\n }, trans, coreTable).then(function() {\n return count1;\n });\n }\n }).then(cb);\n };\n Collection1.prototype.sortBy = function(keyPath, cb) {\n var parts = keyPath.split('.').reverse(), lastPart = parts[0], lastIndex = parts.length - 1;\n function getval(obj, i) {\n if (i) return getval(obj[parts[i]], i - 1);\n return obj[lastPart];\n }\n var order = this._ctx.dir === \"next\" ? 1 : -1;\n function sorter(a, b) {\n var aVal = getval(a, lastIndex), bVal = getval(b, lastIndex);\n return aVal < bVal ? -order : aVal > bVal ? order : 0;\n }\n return this.toArray(function(a) {\n return a.sort(sorter);\n }).then(cb);\n };\n Collection1.prototype.toArray = function(cb) {\n var _this = this;\n return this._read(function(trans) {\n var ctx = _this._ctx;\n if (ctx.dir === 'next' && isPlainKeyRange(ctx, true) && ctx.limit > 0) {\n var valueMapper_1 = ctx.valueMapper;\n var index = getIndexOrStore(ctx, ctx.table.core.schema);\n return ctx.table.core.query({\n trans: trans,\n limit: ctx.limit,\n values: true,\n query: {\n index: index,\n range: ctx.range\n }\n }).then(function(_a10) {\n var result = _a10.result;\n return valueMapper_1 ? result.map(valueMapper_1) : result;\n });\n } else {\n var a_1 = [];\n return iter(ctx, function(item) {\n return a_1.push(item);\n }, trans, ctx.table.core).then(function() {\n return a_1;\n });\n }\n }, cb);\n };\n Collection1.prototype.offset = function(offset) {\n var ctx = this._ctx;\n if (offset <= 0) return this;\n ctx.offset += offset;\n if (isPlainKeyRange(ctx)) addReplayFilter(ctx, function() {\n var offsetLeft = offset;\n return function(cursor, advance) {\n if (offsetLeft === 0) return true;\n if (offsetLeft === 1) {\n --offsetLeft;\n return false;\n }\n advance(function() {\n cursor.advance(offsetLeft);\n offsetLeft = 0;\n });\n return false;\n };\n });\n else addReplayFilter(ctx, function() {\n var offsetLeft = offset;\n return function() {\n return --offsetLeft < 0;\n };\n });\n return this;\n };\n Collection1.prototype.limit = function(numRows) {\n this._ctx.limit = Math.min(this._ctx.limit, numRows);\n addReplayFilter(this._ctx, function() {\n var rowsLeft = numRows;\n return function(cursor, advance, resolve) {\n if (--rowsLeft <= 0) advance(resolve);\n return rowsLeft >= 0;\n };\n }, true);\n return this;\n };\n Collection1.prototype.until = function(filterFunction, bIncludeStopEntry) {\n addFilter(this._ctx, function(cursor, advance, resolve) {\n if (filterFunction(cursor.value)) {\n advance(resolve);\n return bIncludeStopEntry;\n } else return true;\n });\n return this;\n };\n Collection1.prototype.first = function(cb) {\n return this.limit(1).toArray(function(a) {\n return a[0];\n }).then(cb);\n };\n Collection1.prototype.last = function(cb) {\n return this.reverse().first(cb);\n };\n Collection1.prototype.filter = function(filterFunction) {\n addFilter(this._ctx, function(cursor) {\n return filterFunction(cursor.value);\n });\n addMatchFilter(this._ctx, filterFunction);\n return this;\n };\n Collection1.prototype.and = function(filter) {\n return this.filter(filter);\n };\n Collection1.prototype.or = function(indexName) {\n return new this.db.WhereClause(this._ctx.table, indexName, this);\n };\n Collection1.prototype.reverse = function() {\n this._ctx.dir = this._ctx.dir === \"prev\" ? \"next\" : \"prev\";\n if (this._ondirectionchange) this._ondirectionchange(this._ctx.dir);\n return this;\n };\n Collection1.prototype.desc = function() {\n return this.reverse();\n };\n Collection1.prototype.eachKey = function(cb) {\n var ctx = this._ctx;\n ctx.keysOnly = !ctx.isMatch;\n return this.each(function(val, cursor) {\n cb(cursor.key, cursor);\n });\n };\n Collection1.prototype.eachUniqueKey = function(cb) {\n this._ctx.unique = \"unique\";\n return this.eachKey(cb);\n };\n Collection1.prototype.eachPrimaryKey = function(cb) {\n var ctx = this._ctx;\n ctx.keysOnly = !ctx.isMatch;\n return this.each(function(val, cursor) {\n cb(cursor.primaryKey, cursor);\n });\n };\n Collection1.prototype.keys = function(cb) {\n var ctx = this._ctx;\n ctx.keysOnly = !ctx.isMatch;\n var a = [];\n return this.each(function(item, cursor) {\n a.push(cursor.key);\n }).then(function() {\n return a;\n }).then(cb);\n };\n Collection1.prototype.primaryKeys = function(cb) {\n var ctx = this._ctx;\n if (ctx.dir === 'next' && isPlainKeyRange(ctx, true) && ctx.limit > 0) return this._read(function(trans) {\n var index = getIndexOrStore(ctx, ctx.table.core.schema);\n return ctx.table.core.query({\n trans: trans,\n values: false,\n limit: ctx.limit,\n query: {\n index: index,\n range: ctx.range\n }\n });\n }).then(function(_a11) {\n var result = _a11.result;\n return result;\n }).then(cb);\n ctx.keysOnly = !ctx.isMatch;\n var a = [];\n return this.each(function(item, cursor) {\n a.push(cursor.primaryKey);\n }).then(function() {\n return a;\n }).then(cb);\n };\n Collection1.prototype.uniqueKeys = function(cb) {\n this._ctx.unique = \"unique\";\n return this.keys(cb);\n };\n Collection1.prototype.firstKey = function(cb) {\n return this.limit(1).keys(function(a) {\n return a[0];\n }).then(cb);\n };\n Collection1.prototype.lastKey = function(cb) {\n return this.reverse().firstKey(cb);\n };\n Collection1.prototype.distinct = function() {\n var ctx = this._ctx, idx = ctx.index && ctx.table.schema.idxByName[ctx.index];\n if (!idx || !idx.multi) return this;\n var set = {\n };\n addFilter(this._ctx, function(cursor) {\n var strKey = cursor.primaryKey.toString();\n var found = hasOwn(set, strKey);\n set[strKey] = true;\n return !found;\n });\n return this;\n };\n Collection1.prototype.modify = function(changes) {\n var _this = this;\n var ctx = this._ctx;\n return this._write(function(trans) {\n var modifyer;\n if (typeof changes === 'function') modifyer = changes;\n else {\n var keyPaths = keys(changes);\n var numKeys = keyPaths.length;\n modifyer = function(item) {\n var anythingModified = false;\n for(var i = 0; i < numKeys; ++i){\n var keyPath = keyPaths[i], val = changes[keyPath];\n if (getByKeyPath(item, keyPath) !== val) {\n setByKeyPath(item, keyPath, val);\n anythingModified = true;\n }\n }\n return anythingModified;\n };\n }\n var coreTable = ctx.table.core;\n var _a12 = coreTable.schema.primaryKey, outbound = _a12.outbound, extractKey = _a12.extractKey;\n var limit = _this.db._options.modifyChunkSize || 200;\n var totalFailures = [];\n var successCount = 0;\n var failedKeys = [];\n var applyMutateResult = function(expectedCount, res) {\n var failures = res.failures, numFailures = res.numFailures;\n successCount += expectedCount - numFailures;\n for(var _i = 0, _a13 = keys(failures); _i < _a13.length; _i++){\n var pos = _a13[_i];\n totalFailures.push(failures[pos]);\n }\n };\n return _this.clone().primaryKeys().then(function(keys5) {\n var nextChunk = function(offset) {\n var count = Math.min(limit, keys5.length - offset);\n return coreTable.getMany({\n trans: trans,\n keys: keys5.slice(offset, offset + count),\n cache: \"immutable\"\n }).then(function(values) {\n var addValues = [];\n var putValues = [];\n var putKeys = outbound ? [] : null;\n var deleteKeys = [];\n for(var i = 0; i < count; ++i){\n var origValue = values[i];\n var ctx_1 = {\n value: deepClone(origValue),\n primKey: keys5[offset + i]\n };\n if (modifyer.call(ctx_1, ctx_1.value, ctx_1) !== false) {\n if (ctx_1.value == null) deleteKeys.push(keys5[offset + i]);\n else if (!outbound && cmp(extractKey(origValue), extractKey(ctx_1.value)) !== 0) {\n deleteKeys.push(keys5[offset + i]);\n addValues.push(ctx_1.value);\n } else {\n putValues.push(ctx_1.value);\n if (outbound) putKeys.push(keys5[offset + i]);\n }\n }\n }\n var criteria = isPlainKeyRange(ctx) && ctx.limit === Infinity && (typeof changes !== 'function' || changes === deleteCallback) && {\n index: ctx.index,\n range: ctx.range\n };\n return Promise.resolve(addValues.length > 0 && coreTable.mutate({\n trans: trans,\n type: 'add',\n values: addValues\n }).then(function(res) {\n for(var pos in res.failures)deleteKeys.splice(parseInt(pos), 1);\n applyMutateResult(addValues.length, res);\n })).then(function() {\n return (putValues.length > 0 || criteria && typeof changes === 'object') && coreTable.mutate({\n trans: trans,\n type: 'put',\n keys: putKeys,\n values: putValues,\n criteria: criteria,\n changeSpec: typeof changes !== 'function' && changes\n }).then(function(res) {\n return applyMutateResult(putValues.length, res);\n });\n }).then(function() {\n return (deleteKeys.length > 0 || criteria && changes === deleteCallback) && coreTable.mutate({\n trans: trans,\n type: 'delete',\n keys: deleteKeys,\n criteria: criteria\n }).then(function(res) {\n return applyMutateResult(deleteKeys.length, res);\n });\n }).then(function() {\n return keys5.length > offset + count && nextChunk(offset + limit);\n });\n });\n };\n return nextChunk(0).then(function() {\n if (totalFailures.length > 0) throw new ModifyError(\"Error modifying one or more objects\", totalFailures, successCount, failedKeys);\n return keys5.length;\n });\n });\n });\n };\n Collection1.prototype.delete = function() {\n var ctx = this._ctx, range = ctx.range;\n if (isPlainKeyRange(ctx) && (ctx.isPrimKey && !hangsOnDeleteLargeKeyRange || range.type === 3)) return this._write(function(trans) {\n var primaryKey = ctx.table.core.schema.primaryKey;\n var coreRange = range;\n return ctx.table.core.count({\n trans: trans,\n query: {\n index: primaryKey,\n range: coreRange\n }\n }).then(function(count) {\n return ctx.table.core.mutate({\n trans: trans,\n type: 'deleteRange',\n range: coreRange\n }).then(function(_a14) {\n var failures = _a14.failures;\n _a14.lastResult;\n _a14.results;\n var numFailures = _a14.numFailures;\n if (numFailures) throw new ModifyError(\"Could not delete some values\", Object.keys(failures).map(function(pos) {\n return failures[pos];\n }), count - numFailures);\n return count - numFailures;\n });\n });\n });\n return this.modify(deleteCallback);\n };\n return Collection1;\n}();\nvar deleteCallback = function(value, ctx) {\n return ctx.value = null;\n};\nfunction createCollectionConstructor(db) {\n return makeClassConstructor(Collection.prototype, function Collection(whereClause, keyRangeGenerator) {\n this.db = db;\n var keyRange = AnyRange, error = null;\n if (keyRangeGenerator) try {\n keyRange = keyRangeGenerator();\n } catch (ex) {\n error = ex;\n }\n var whereCtx = whereClause._ctx;\n var table = whereCtx.table;\n var readingHook = table.hook.reading.fire;\n this._ctx = {\n table: table,\n index: whereCtx.index,\n isPrimKey: !whereCtx.index || table.schema.primKey.keyPath && whereCtx.index === table.schema.primKey.name,\n range: keyRange,\n keysOnly: false,\n dir: \"next\",\n unique: \"\",\n algorithm: null,\n filter: null,\n replayFilter: null,\n justLimit: true,\n isMatch: null,\n offset: 0,\n limit: Infinity,\n error: error,\n or: whereCtx.or,\n valueMapper: readingHook !== mirror ? readingHook : null\n };\n });\n}\nfunction simpleCompare(a, b) {\n return a < b ? -1 : a === b ? 0 : 1;\n}\nfunction simpleCompareReverse(a, b) {\n return a > b ? -1 : a === b ? 0 : 1;\n}\nfunction fail(collectionOrWhereClause, err, T) {\n var collection = collectionOrWhereClause instanceof WhereClause ? new collectionOrWhereClause.Collection(collectionOrWhereClause) : collectionOrWhereClause;\n collection._ctx.error = T ? new T(err) : new TypeError(err);\n return collection;\n}\nfunction emptyCollection(whereClause) {\n return new whereClause.Collection(whereClause, function() {\n return rangeEqual(\"\");\n }).limit(0);\n}\nfunction upperFactory(dir) {\n return dir === \"next\" ? function(s) {\n return s.toUpperCase();\n } : function(s) {\n return s.toLowerCase();\n };\n}\nfunction lowerFactory(dir) {\n return dir === \"next\" ? function(s) {\n return s.toLowerCase();\n } : function(s) {\n return s.toUpperCase();\n };\n}\nfunction nextCasing(key, lowerKey, upperNeedle, lowerNeedle, cmp1, dir) {\n var length = Math.min(key.length, lowerNeedle.length);\n var llp = -1;\n for(var i = 0; i < length; ++i){\n var lwrKeyChar = lowerKey[i];\n if (lwrKeyChar !== lowerNeedle[i]) {\n if (cmp1(key[i], upperNeedle[i]) < 0) return key.substr(0, i) + upperNeedle[i] + upperNeedle.substr(i + 1);\n if (cmp1(key[i], lowerNeedle[i]) < 0) return key.substr(0, i) + lowerNeedle[i] + upperNeedle.substr(i + 1);\n if (llp >= 0) return key.substr(0, llp) + lowerKey[llp] + upperNeedle.substr(llp + 1);\n return null;\n }\n if (cmp1(key[i], lwrKeyChar) < 0) llp = i;\n }\n if (length < lowerNeedle.length && dir === \"next\") return key + upperNeedle.substr(key.length);\n if (length < key.length && dir === \"prev\") return key.substr(0, upperNeedle.length);\n return llp < 0 ? null : key.substr(0, llp) + lowerNeedle[llp] + upperNeedle.substr(llp + 1);\n}\nfunction addIgnoreCaseAlgorithm(whereClause, match, needles, suffix) {\n var upper, lower, compare, upperNeedles, lowerNeedles, direction1, nextKeySuffix, needlesLen = needles.length;\n if (!needles.every(function(s) {\n return typeof s === 'string';\n })) return fail(whereClause, STRING_EXPECTED);\n function initDirection(dir) {\n upper = upperFactory(dir);\n lower = lowerFactory(dir);\n compare = dir === \"next\" ? simpleCompare : simpleCompareReverse;\n var needleBounds = needles.map(function(needle) {\n return {\n lower: lower(needle),\n upper: upper(needle)\n };\n }).sort(function(a, b) {\n return compare(a.lower, b.lower);\n });\n upperNeedles = needleBounds.map(function(nb) {\n return nb.upper;\n });\n lowerNeedles = needleBounds.map(function(nb) {\n return nb.lower;\n });\n direction1 = dir;\n nextKeySuffix = dir === \"next\" ? \"\" : suffix;\n }\n initDirection(\"next\");\n var c = new whereClause.Collection(whereClause, function() {\n return createRange(upperNeedles[0], lowerNeedles[needlesLen - 1] + suffix);\n });\n c._ondirectionchange = function(direction) {\n initDirection(direction);\n };\n var firstPossibleNeedle = 0;\n c._addAlgorithm(function(cursor, advance, resolve) {\n var key = cursor.key;\n if (typeof key !== 'string') return false;\n var lowerKey = lower(key);\n if (match(lowerKey, lowerNeedles, firstPossibleNeedle)) return true;\n else {\n var lowestPossibleCasing = null;\n for(var i = firstPossibleNeedle; i < needlesLen; ++i){\n var casing = nextCasing(key, lowerKey, upperNeedles[i], lowerNeedles[i], compare, direction1);\n if (casing === null && lowestPossibleCasing === null) firstPossibleNeedle = i + 1;\n else if (lowestPossibleCasing === null || compare(lowestPossibleCasing, casing) > 0) lowestPossibleCasing = casing;\n }\n if (lowestPossibleCasing !== null) advance(function() {\n cursor.continue(lowestPossibleCasing + nextKeySuffix);\n });\n else advance(resolve);\n return false;\n }\n });\n return c;\n}\nfunction createRange(lower, upper, lowerOpen, upperOpen) {\n return {\n type: 2,\n lower: lower,\n upper: upper,\n lowerOpen: lowerOpen,\n upperOpen: upperOpen\n };\n}\nfunction rangeEqual(value) {\n return {\n type: 1,\n lower: value,\n upper: value\n };\n}\nvar WhereClause = function() {\n function WhereClause1() {\n }\n Object.defineProperty(WhereClause1.prototype, \"Collection\", {\n get: function() {\n return this._ctx.table.db.Collection;\n },\n enumerable: false,\n configurable: true\n });\n WhereClause1.prototype.between = function(lower, upper, includeLower, includeUpper) {\n includeLower = includeLower !== false;\n includeUpper = includeUpper === true;\n try {\n if (this._cmp(lower, upper) > 0 || this._cmp(lower, upper) === 0 && (includeLower || includeUpper) && !(includeLower && includeUpper)) return emptyCollection(this);\n return new this.Collection(this, function() {\n return createRange(lower, upper, !includeLower, !includeUpper);\n });\n } catch (e) {\n return fail(this, INVALID_KEY_ARGUMENT);\n }\n };\n WhereClause1.prototype.equals = function(value) {\n if (value == null) return fail(this, INVALID_KEY_ARGUMENT);\n return new this.Collection(this, function() {\n return rangeEqual(value);\n });\n };\n WhereClause1.prototype.above = function(value) {\n if (value == null) return fail(this, INVALID_KEY_ARGUMENT);\n return new this.Collection(this, function() {\n return createRange(value, undefined, true);\n });\n };\n WhereClause1.prototype.aboveOrEqual = function(value) {\n if (value == null) return fail(this, INVALID_KEY_ARGUMENT);\n return new this.Collection(this, function() {\n return createRange(value, undefined, false);\n });\n };\n WhereClause1.prototype.below = function(value) {\n if (value == null) return fail(this, INVALID_KEY_ARGUMENT);\n return new this.Collection(this, function() {\n return createRange(undefined, value, false, true);\n });\n };\n WhereClause1.prototype.belowOrEqual = function(value) {\n if (value == null) return fail(this, INVALID_KEY_ARGUMENT);\n return new this.Collection(this, function() {\n return createRange(undefined, value);\n });\n };\n WhereClause1.prototype.startsWith = function(str) {\n if (typeof str !== 'string') return fail(this, STRING_EXPECTED);\n return this.between(str, str + maxString, true, true);\n };\n WhereClause1.prototype.startsWithIgnoreCase = function(str) {\n if (str === \"\") return this.startsWith(str);\n return addIgnoreCaseAlgorithm(this, function(x, a) {\n return x.indexOf(a[0]) === 0;\n }, [\n str\n ], maxString);\n };\n WhereClause1.prototype.equalsIgnoreCase = function(str) {\n return addIgnoreCaseAlgorithm(this, function(x, a) {\n return x === a[0];\n }, [\n str\n ], \"\");\n };\n WhereClause1.prototype.anyOfIgnoreCase = function() {\n var set = getArrayOf.apply(NO_CHAR_ARRAY, arguments);\n if (set.length === 0) return emptyCollection(this);\n return addIgnoreCaseAlgorithm(this, function(x, a) {\n return a.indexOf(x) !== -1;\n }, set, \"\");\n };\n WhereClause1.prototype.startsWithAnyOfIgnoreCase = function() {\n var set = getArrayOf.apply(NO_CHAR_ARRAY, arguments);\n if (set.length === 0) return emptyCollection(this);\n return addIgnoreCaseAlgorithm(this, function(x, a) {\n return a.some(function(n) {\n return x.indexOf(n) === 0;\n });\n }, set, maxString);\n };\n WhereClause1.prototype.anyOf = function() {\n var _this = this;\n var set = getArrayOf.apply(NO_CHAR_ARRAY, arguments);\n var compare = this._cmp;\n try {\n set.sort(compare);\n } catch (e) {\n return fail(this, INVALID_KEY_ARGUMENT);\n }\n if (set.length === 0) return emptyCollection(this);\n var c = new this.Collection(this, function() {\n return createRange(set[0], set[set.length - 1]);\n });\n c._ondirectionchange = function(direction) {\n compare = direction === \"next\" ? _this._ascending : _this._descending;\n set.sort(compare);\n };\n var i = 0;\n c._addAlgorithm(function(cursor, advance, resolve) {\n var key = cursor.key;\n while(compare(key, set[i]) > 0){\n ++i;\n if (i === set.length) {\n advance(resolve);\n return false;\n }\n }\n if (compare(key, set[i]) === 0) return true;\n else {\n advance(function() {\n cursor.continue(set[i]);\n });\n return false;\n }\n });\n return c;\n };\n WhereClause1.prototype.notEqual = function(value) {\n return this.inAnyRange([\n [\n minKey,\n value\n ],\n [\n value,\n this.db._maxKey\n ]\n ], {\n includeLowers: false,\n includeUppers: false\n });\n };\n WhereClause1.prototype.noneOf = function() {\n var set = getArrayOf.apply(NO_CHAR_ARRAY, arguments);\n if (set.length === 0) return new this.Collection(this);\n try {\n set.sort(this._ascending);\n } catch (e) {\n return fail(this, INVALID_KEY_ARGUMENT);\n }\n var ranges = set.reduce(function(res, val) {\n return res ? res.concat([\n [\n res[res.length - 1][1],\n val\n ]\n ]) : [\n [\n minKey,\n val\n ]\n ];\n }, null);\n ranges.push([\n set[set.length - 1],\n this.db._maxKey\n ]);\n return this.inAnyRange(ranges, {\n includeLowers: false,\n includeUppers: false\n });\n };\n WhereClause1.prototype.inAnyRange = function(ranges1, options) {\n var _this = this;\n var cmp2 = this._cmp, ascending = this._ascending, descending = this._descending, min = this._min, max = this._max;\n if (ranges1.length === 0) return emptyCollection(this);\n if (!ranges1.every(function(range) {\n return range[0] !== undefined && range[1] !== undefined && ascending(range[0], range[1]) <= 0;\n })) return fail(this, \"First argument to inAnyRange() must be an Array of two-value Arrays [lower,upper] where upper must not be lower than lower\", exceptions.InvalidArgument);\n var includeLowers = !options || options.includeLowers !== false;\n var includeUppers = options && options.includeUppers === true;\n function addRange1(ranges, newRange) {\n var i = 0, l = ranges.length;\n for(; i < l; ++i){\n var range = ranges[i];\n if (cmp2(newRange[0], range[1]) < 0 && cmp2(newRange[1], range[0]) > 0) {\n range[0] = min(range[0], newRange[0]);\n range[1] = max(range[1], newRange[1]);\n break;\n }\n }\n if (i === l) ranges.push(newRange);\n return ranges;\n }\n var sortDirection = ascending;\n function rangeSorter(a, b) {\n return sortDirection(a[0], b[0]);\n }\n var set;\n try {\n set = ranges1.reduce(addRange1, []);\n set.sort(rangeSorter);\n } catch (ex) {\n return fail(this, INVALID_KEY_ARGUMENT);\n }\n var rangePos = 0;\n var keyIsBeyondCurrentEntry = includeUppers ? function(key) {\n return ascending(key, set[rangePos][1]) > 0;\n } : function(key) {\n return ascending(key, set[rangePos][1]) >= 0;\n };\n var keyIsBeforeCurrentEntry = includeLowers ? function(key) {\n return descending(key, set[rangePos][0]) > 0;\n } : function(key) {\n return descending(key, set[rangePos][0]) >= 0;\n };\n function keyWithinCurrentRange(key) {\n return !keyIsBeyondCurrentEntry(key) && !keyIsBeforeCurrentEntry(key);\n }\n var checkKey = keyIsBeyondCurrentEntry;\n var c = new this.Collection(this, function() {\n return createRange(set[0][0], set[set.length - 1][1], !includeLowers, !includeUppers);\n });\n c._ondirectionchange = function(direction) {\n if (direction === \"next\") {\n checkKey = keyIsBeyondCurrentEntry;\n sortDirection = ascending;\n } else {\n checkKey = keyIsBeforeCurrentEntry;\n sortDirection = descending;\n }\n set.sort(rangeSorter);\n };\n c._addAlgorithm(function(cursor, advance, resolve) {\n var key = cursor.key;\n while(checkKey(key)){\n ++rangePos;\n if (rangePos === set.length) {\n advance(resolve);\n return false;\n }\n }\n if (keyWithinCurrentRange(key)) return true;\n else if (_this._cmp(key, set[rangePos][1]) === 0 || _this._cmp(key, set[rangePos][0]) === 0) return false;\n else {\n advance(function() {\n if (sortDirection === ascending) cursor.continue(set[rangePos][0]);\n else cursor.continue(set[rangePos][1]);\n });\n return false;\n }\n });\n return c;\n };\n WhereClause1.prototype.startsWithAnyOf = function() {\n var set = getArrayOf.apply(NO_CHAR_ARRAY, arguments);\n if (!set.every(function(s) {\n return typeof s === 'string';\n })) return fail(this, \"startsWithAnyOf() only works with strings\");\n if (set.length === 0) return emptyCollection(this);\n return this.inAnyRange(set.map(function(str) {\n return [\n str,\n str + maxString\n ];\n }));\n };\n return WhereClause1;\n}();\nfunction createWhereClauseConstructor(db) {\n return makeClassConstructor(WhereClause.prototype, function WhereClause(table, index, orCollection) {\n this.db = db;\n this._ctx = {\n table: table,\n index: index === \":id\" ? null : index,\n or: orCollection\n };\n var indexedDB = db._deps.indexedDB;\n if (!indexedDB) throw new exceptions.MissingAPI();\n this._cmp = this._ascending = indexedDB.cmp.bind(indexedDB);\n this._descending = function(a, b) {\n return indexedDB.cmp(b, a);\n };\n this._max = function(a, b) {\n return indexedDB.cmp(a, b) > 0 ? a : b;\n };\n this._min = function(a, b) {\n return indexedDB.cmp(a, b) < 0 ? a : b;\n };\n this._IDBKeyRange = db._deps.IDBKeyRange;\n });\n}\nfunction eventRejectHandler(reject) {\n return wrap(function(event) {\n preventDefault(event);\n reject(event.target.error);\n return false;\n });\n}\nfunction preventDefault(event) {\n if (event.stopPropagation) event.stopPropagation();\n if (event.preventDefault) event.preventDefault();\n}\nvar DEXIE_STORAGE_MUTATED_EVENT_NAME = 'storagemutated';\nvar STORAGE_MUTATED_DOM_EVENT_NAME = 'x-storagemutated-1';\nvar globalEvents = Events(null, DEXIE_STORAGE_MUTATED_EVENT_NAME);\nvar Transaction = function() {\n function Transaction1() {\n }\n Transaction1.prototype._lock = function() {\n assert(!PSD.global);\n ++this._reculock;\n if (this._reculock === 1 && !PSD.global) PSD.lockOwnerFor = this;\n return this;\n };\n Transaction1.prototype._unlock = function() {\n assert(!PSD.global);\n if (--this._reculock === 0) {\n if (!PSD.global) PSD.lockOwnerFor = null;\n while(this._blockedFuncs.length > 0 && !this._locked()){\n var fnAndPSD = this._blockedFuncs.shift();\n try {\n usePSD(fnAndPSD[1], fnAndPSD[0]);\n } catch (e) {\n }\n }\n }\n return this;\n };\n Transaction1.prototype._locked = function() {\n return this._reculock && PSD.lockOwnerFor !== this;\n };\n Transaction1.prototype.create = function(idbtrans) {\n var _this = this;\n if (!this.mode) return this;\n var idbdb = this.db.idbdb;\n var dbOpenError = this.db._state.dbOpenError;\n assert(!this.idbtrans);\n if (!idbtrans && !idbdb) switch(dbOpenError && dbOpenError.name){\n case \"DatabaseClosedError\":\n throw new exceptions.DatabaseClosed(dbOpenError);\n case \"MissingAPIError\":\n throw new exceptions.MissingAPI(dbOpenError.message, dbOpenError);\n default:\n throw new exceptions.OpenFailed(dbOpenError);\n }\n if (!this.active) throw new exceptions.TransactionInactive();\n assert(this._completion._state === null);\n idbtrans = this.idbtrans = idbtrans || (this.db.core ? this.db.core.transaction(this.storeNames, this.mode, {\n durability: this.chromeTransactionDurability\n }) : idbdb.transaction(this.storeNames, this.mode, {\n durability: this.chromeTransactionDurability\n }));\n idbtrans.onerror = wrap(function(ev) {\n preventDefault(ev);\n _this._reject(idbtrans.error);\n });\n idbtrans.onabort = wrap(function(ev) {\n preventDefault(ev);\n _this.active && _this._reject(new exceptions.Abort(idbtrans.error));\n _this.active = false;\n _this.on(\"abort\").fire(ev);\n });\n idbtrans.oncomplete = wrap(function() {\n _this.active = false;\n _this._resolve();\n if ('mutatedParts' in idbtrans) globalEvents.storagemutated.fire(idbtrans[\"mutatedParts\"]);\n });\n return this;\n };\n Transaction1.prototype._promise = function(mode, fn, bWriteLock) {\n var _this = this;\n if (mode === 'readwrite' && this.mode !== 'readwrite') return rejection(new exceptions.ReadOnly(\"Transaction is readonly\"));\n if (!this.active) return rejection(new exceptions.TransactionInactive());\n if (this._locked()) return new DexiePromise(function(resolve, reject) {\n _this._blockedFuncs.push([\n function() {\n _this._promise(mode, fn, bWriteLock).then(resolve, reject);\n },\n PSD\n ]);\n });\n else if (bWriteLock) return newScope(function() {\n var p = new DexiePromise(function(resolve, reject) {\n _this._lock();\n var rv = fn(resolve, reject, _this);\n if (rv && rv.then) rv.then(resolve, reject);\n });\n p.finally(function() {\n return _this._unlock();\n });\n p._lib = true;\n return p;\n });\n else {\n var p1 = new DexiePromise(function(resolve, reject) {\n var rv = fn(resolve, reject, _this);\n if (rv && rv.then) rv.then(resolve, reject);\n });\n p1._lib = true;\n return p1;\n }\n };\n Transaction1.prototype._root = function() {\n return this.parent ? this.parent._root() : this;\n };\n Transaction1.prototype.waitFor = function(promiseLike) {\n var root = this._root();\n var promise = DexiePromise.resolve(promiseLike);\n if (root._waitingFor) root._waitingFor = root._waitingFor.then(function() {\n return promise;\n });\n else {\n root._waitingFor = promise;\n root._waitingQueue = [];\n var store = root.idbtrans.objectStore(root.storeNames[0]);\n (function spin() {\n ++root._spinCount;\n while(root._waitingQueue.length)root._waitingQueue.shift()();\n if (root._waitingFor) store.get(-Infinity).onsuccess = spin;\n })();\n }\n var currentWaitPromise = root._waitingFor;\n return new DexiePromise(function(resolve, reject) {\n promise.then(function(res) {\n return root._waitingQueue.push(wrap(resolve.bind(null, res)));\n }, function(err) {\n return root._waitingQueue.push(wrap(reject.bind(null, err)));\n }).finally(function() {\n if (root._waitingFor === currentWaitPromise) root._waitingFor = null;\n });\n });\n };\n Transaction1.prototype.abort = function() {\n if (this.active) {\n this.active = false;\n if (this.idbtrans) this.idbtrans.abort();\n this._reject(new exceptions.Abort());\n }\n };\n Transaction1.prototype.table = function(tableName) {\n var memoizedTables = this._memoizedTables || (this._memoizedTables = {\n });\n if (hasOwn(memoizedTables, tableName)) return memoizedTables[tableName];\n var tableSchema = this.schema[tableName];\n if (!tableSchema) throw new exceptions.NotFound(\"Table \" + tableName + \" not part of transaction\");\n var transactionBoundTable = new this.db.Table(tableName, tableSchema, this);\n transactionBoundTable.core = this.db.core.table(tableName);\n memoizedTables[tableName] = transactionBoundTable;\n return transactionBoundTable;\n };\n return Transaction1;\n}();\nfunction createTransactionConstructor(db) {\n return makeClassConstructor(Transaction.prototype, function Transaction(mode, storeNames, dbschema, chromeTransactionDurability, parent) {\n var _this = this;\n this.db = db;\n this.mode = mode;\n this.storeNames = storeNames;\n this.schema = dbschema;\n this.chromeTransactionDurability = chromeTransactionDurability;\n this.idbtrans = null;\n this.on = Events(this, \"complete\", \"error\", \"abort\");\n this.parent = parent || null;\n this.active = true;\n this._reculock = 0;\n this._blockedFuncs = [];\n this._resolve = null;\n this._reject = null;\n this._waitingFor = null;\n this._waitingQueue = null;\n this._spinCount = 0;\n this._completion = new DexiePromise(function(resolve, reject) {\n _this._resolve = resolve;\n _this._reject = reject;\n });\n this._completion.then(function() {\n _this.active = false;\n _this.on.complete.fire();\n }, function(e) {\n var wasActive = _this.active;\n _this.active = false;\n _this.on.error.fire(e);\n _this.parent ? _this.parent._reject(e) : wasActive && _this.idbtrans && _this.idbtrans.abort();\n return rejection(e);\n });\n });\n}\nfunction createIndexSpec(name, keyPath, unique, multi, auto, compound, isPrimKey) {\n return {\n name: name,\n keyPath: keyPath,\n unique: unique,\n multi: multi,\n auto: auto,\n compound: compound,\n src: (unique && !isPrimKey ? '&' : '') + (multi ? '*' : '') + (auto ? \"++\" : \"\") + nameFromKeyPath(keyPath)\n };\n}\nfunction nameFromKeyPath(keyPath) {\n return typeof keyPath === 'string' ? keyPath : keyPath ? '[' + [].join.call(keyPath, '+') + ']' : \"\";\n}\nfunction createTableSchema(name, primKey, indexes) {\n return {\n name: name,\n primKey: primKey,\n indexes: indexes,\n mappedClass: null,\n idxByName: arrayToObject(indexes, function(index) {\n return [\n index.name,\n index\n ];\n })\n };\n}\nfunction safariMultiStoreFix(storeNames) {\n return storeNames.length === 1 ? storeNames[0] : storeNames;\n}\nvar getMaxKey = function(IdbKeyRange) {\n try {\n IdbKeyRange.only([\n []\n ]);\n getMaxKey = function() {\n return [\n []\n ];\n };\n return [\n []\n ];\n } catch (e) {\n getMaxKey = function() {\n return maxString;\n };\n return maxString;\n }\n};\nfunction getKeyExtractor(keyPath) {\n if (keyPath == null) return function() {\n return undefined;\n };\n else if (typeof keyPath === 'string') return getSinglePathKeyExtractor(keyPath);\n else return function(obj) {\n return getByKeyPath(obj, keyPath);\n };\n}\nfunction getSinglePathKeyExtractor(keyPath) {\n var split = keyPath.split('.');\n if (split.length === 1) return function(obj) {\n return obj[keyPath];\n };\n else return function(obj) {\n return getByKeyPath(obj, keyPath);\n };\n}\nfunction arrayify(arrayLike) {\n return [].slice.call(arrayLike);\n}\nvar _id_counter = 0;\nfunction getKeyPathAlias(keyPath) {\n return keyPath == null ? \":id\" : typeof keyPath === 'string' ? keyPath : \"[\" + keyPath.join('+') + \"]\";\n}\nfunction createDBCore(db1, IdbKeyRange, tmpTrans) {\n function extractSchema(db, trans) {\n var tables = arrayify(db.objectStoreNames);\n return {\n schema: {\n name: db.name,\n tables: tables.map(function(table) {\n return trans.objectStore(table);\n }).map(function(store) {\n var keyPath1 = store.keyPath, autoIncrement = store.autoIncrement;\n var compound1 = isArray(keyPath1);\n var outbound = keyPath1 == null;\n var indexByKeyPath = {\n };\n var result1 = {\n name: store.name,\n primaryKey: {\n name: null,\n isPrimaryKey: true,\n outbound: outbound,\n compound: compound1,\n keyPath: keyPath1,\n autoIncrement: autoIncrement,\n unique: true,\n extractKey: getKeyExtractor(keyPath1)\n },\n indexes: arrayify(store.indexNames).map(function(indexName) {\n return store.index(indexName);\n }).map(function(index) {\n var name = index.name, unique = index.unique, multiEntry = index.multiEntry, keyPath = index.keyPath;\n var compound = isArray(keyPath);\n var result = {\n name: name,\n compound: compound,\n keyPath: keyPath,\n unique: unique,\n multiEntry: multiEntry,\n extractKey: getKeyExtractor(keyPath)\n };\n indexByKeyPath[getKeyPathAlias(keyPath)] = result;\n return result;\n }),\n getIndexByKeyPath: function(keyPath) {\n return indexByKeyPath[getKeyPathAlias(keyPath)];\n }\n };\n indexByKeyPath[\":id\"] = result1.primaryKey;\n if (keyPath1 != null) indexByKeyPath[getKeyPathAlias(keyPath1)] = result1.primaryKey;\n return result1;\n })\n },\n hasGetAll: tables.length > 0 && 'getAll' in trans.objectStore(tables[0]) && !(typeof navigator !== 'undefined' && /Safari/.test(navigator.userAgent) && !/(Chrome\\/|Edge\\/)/.test(navigator.userAgent) && [].concat(navigator.userAgent.match(/Safari\\/(\\d*)/))[1] < 604)\n };\n }\n function makeIDBKeyRange(range) {\n if (range.type === 3) return null;\n if (range.type === 4) throw new Error(\"Cannot convert never type to IDBKeyRange\");\n var lower = range.lower, upper = range.upper, lowerOpen = range.lowerOpen, upperOpen = range.upperOpen;\n var idbRange = lower === undefined ? upper === undefined ? null : IdbKeyRange.upperBound(upper, !!upperOpen) : upper === undefined ? IdbKeyRange.lowerBound(lower, !!lowerOpen) : IdbKeyRange.bound(lower, upper, !!lowerOpen, !!upperOpen);\n return idbRange;\n }\n function createDbCoreTable(tableSchema) {\n var tableName = tableSchema.name;\n function mutate(_a16) {\n var trans = _a16.trans, type2 = _a16.type, keys6 = _a16.keys, values = _a16.values, range = _a16.range;\n return new Promise(function(resolve, reject) {\n resolve = wrap(resolve);\n var store = trans.objectStore(tableName);\n var outbound = store.keyPath == null;\n var isAddOrPut = type2 === \"put\" || type2 === \"add\";\n if (!isAddOrPut && type2 !== 'delete' && type2 !== 'deleteRange') throw new Error(\"Invalid operation type: \" + type2);\n var length = (keys6 || values || {\n length: 1\n }).length;\n if (keys6 && values && keys6.length !== values.length) throw new Error(\"Given keys array must have same length as given values array.\");\n if (length === 0) return resolve({\n numFailures: 0,\n failures: {\n },\n results: [],\n lastResult: undefined\n });\n var req1;\n var reqs = [];\n var failures = [];\n var numFailures = 0;\n var errorHandler = function(event) {\n ++numFailures;\n preventDefault(event);\n };\n if (type2 === 'deleteRange') {\n if (range.type === 4) return resolve({\n numFailures: numFailures,\n failures: failures,\n results: [],\n lastResult: undefined\n });\n if (range.type === 3) reqs.push(req1 = store.clear());\n else reqs.push(req1 = store.delete(makeIDBKeyRange(range)));\n } else {\n var _a17 = isAddOrPut ? outbound ? [\n values,\n keys6\n ] : [\n values,\n null\n ] : [\n keys6,\n null\n ], args1 = _a17[0], args2 = _a17[1];\n if (isAddOrPut) for(var i = 0; i < length; ++i){\n reqs.push(req1 = args2 && args2[i] !== undefined ? store[type2](args1[i], args2[i]) : store[type2](args1[i]));\n req1.onerror = errorHandler;\n }\n else for(var i = 0; i < length; ++i){\n reqs.push(req1 = store[type2](args1[i]));\n req1.onerror = errorHandler;\n }\n }\n var done = function(event) {\n var lastResult = event.target.result;\n reqs.forEach(function(req, i) {\n return req.error != null && (failures[i] = req.error);\n });\n resolve({\n numFailures: numFailures,\n failures: failures,\n results: type2 === \"delete\" ? keys6 : reqs.map(function(req) {\n return req.result;\n }),\n lastResult: lastResult\n });\n };\n req1.onerror = function(event) {\n errorHandler(event);\n done(event);\n };\n req1.onsuccess = done;\n });\n }\n function openCursor1(_a18) {\n var trans = _a18.trans, values = _a18.values, query = _a18.query, reverse = _a18.reverse, unique = _a18.unique;\n return new Promise(function(resolve, reject) {\n resolve = wrap(resolve);\n var index = query.index, range = query.range;\n var store = trans.objectStore(tableName);\n var source = index.isPrimaryKey ? store : store.index(index.name);\n var direction = reverse ? unique ? \"prevunique\" : \"prev\" : unique ? \"nextunique\" : \"next\";\n var req = values || !('openKeyCursor' in source) ? source.openCursor(makeIDBKeyRange(range), direction) : source.openKeyCursor(makeIDBKeyRange(range), direction);\n req.onerror = eventRejectHandler(reject);\n req.onsuccess = wrap(function(ev) {\n var cursor = req.result;\n if (!cursor) {\n resolve(null);\n return;\n }\n cursor.___id = ++_id_counter;\n cursor.done = false;\n var _cursorContinue = cursor.continue.bind(cursor);\n var _cursorContinuePrimaryKey = cursor.continuePrimaryKey;\n if (_cursorContinuePrimaryKey) _cursorContinuePrimaryKey = _cursorContinuePrimaryKey.bind(cursor);\n var _cursorAdvance = cursor.advance.bind(cursor);\n var doThrowCursorIsNotStarted = function() {\n throw new Error(\"Cursor not started\");\n };\n var doThrowCursorIsStopped = function() {\n throw new Error(\"Cursor not stopped\");\n };\n cursor.trans = trans;\n cursor.stop = cursor.continue = cursor.continuePrimaryKey = cursor.advance = doThrowCursorIsNotStarted;\n cursor.fail = wrap(reject);\n cursor.next = function() {\n var _this = this;\n var gotOne = 1;\n return this.start(function() {\n return gotOne-- ? _this.continue() : _this.stop();\n }).then(function() {\n return _this;\n });\n };\n cursor.start = function(callback) {\n var iterationPromise = new Promise(function(resolveIteration, rejectIteration) {\n resolveIteration = wrap(resolveIteration);\n req.onerror = eventRejectHandler(rejectIteration);\n cursor.fail = rejectIteration;\n cursor.stop = function(value) {\n cursor.stop = cursor.continue = cursor.continuePrimaryKey = cursor.advance = doThrowCursorIsStopped;\n resolveIteration(value);\n };\n });\n var guardedCallback = function() {\n if (req.result) try {\n callback();\n } catch (err) {\n cursor.fail(err);\n }\n else {\n cursor.done = true;\n cursor.start = function() {\n throw new Error(\"Cursor behind last entry\");\n };\n cursor.stop();\n }\n };\n req.onsuccess = wrap(function(ev) {\n req.onsuccess = guardedCallback;\n guardedCallback();\n });\n cursor.continue = _cursorContinue;\n cursor.continuePrimaryKey = _cursorContinuePrimaryKey;\n cursor.advance = _cursorAdvance;\n guardedCallback();\n return iterationPromise;\n };\n resolve(cursor);\n }, reject);\n });\n }\n function query1(hasGetAll) {\n return function(request) {\n return new Promise(function(resolve, reject) {\n resolve = wrap(resolve);\n var trans = request.trans, values = request.values, limit = request.limit, query = request.query;\n var nonInfinitLimit = limit === Infinity ? undefined : limit;\n var index = query.index, range = query.range;\n var store = trans.objectStore(tableName);\n var source = index.isPrimaryKey ? store : store.index(index.name);\n var idbKeyRange = makeIDBKeyRange(range);\n if (limit === 0) return resolve({\n result: []\n });\n if (hasGetAll) {\n var req = values ? source.getAll(idbKeyRange, nonInfinitLimit) : source.getAllKeys(idbKeyRange, nonInfinitLimit);\n req.onsuccess = function(event) {\n return resolve({\n result: event.target.result\n });\n };\n req.onerror = eventRejectHandler(reject);\n } else {\n var count_1 = 0;\n var req_1 = values || !('openKeyCursor' in source) ? source.openCursor(idbKeyRange) : source.openKeyCursor(idbKeyRange);\n var result_1 = [];\n req_1.onsuccess = function(event) {\n var cursor = req_1.result;\n if (!cursor) return resolve({\n result: result_1\n });\n result_1.push(values ? cursor.value : cursor.primaryKey);\n if (++count_1 === limit) return resolve({\n result: result_1\n });\n cursor.continue();\n };\n req_1.onerror = eventRejectHandler(reject);\n }\n });\n };\n }\n return {\n name: tableName,\n schema: tableSchema,\n mutate: mutate,\n getMany: function(_a19) {\n var trans = _a19.trans, keys7 = _a19.keys;\n return new Promise(function(resolve, reject) {\n resolve = wrap(resolve);\n var store = trans.objectStore(tableName);\n var length = keys7.length;\n var result = new Array(length);\n var keyCount = 0;\n var callbackCount = 0;\n var req2;\n var successHandler = function(event) {\n var req = event.target;\n result[req._pos] = req.result;\n if (++callbackCount === keyCount) resolve(result);\n };\n var errorHandler = eventRejectHandler(reject);\n for(var i = 0; i < length; ++i){\n var key = keys7[i];\n if (key != null) {\n req2 = store.get(keys7[i]);\n req2._pos = i;\n req2.onsuccess = successHandler;\n req2.onerror = errorHandler;\n ++keyCount;\n }\n }\n if (keyCount === 0) resolve(result);\n });\n },\n get: function(_a20) {\n var trans = _a20.trans, key = _a20.key;\n return new Promise(function(resolve, reject) {\n resolve = wrap(resolve);\n var store = trans.objectStore(tableName);\n var req = store.get(key);\n req.onsuccess = function(event) {\n return resolve(event.target.result);\n };\n req.onerror = eventRejectHandler(reject);\n });\n },\n query: query1(hasGetAll1),\n openCursor: openCursor1,\n count: function(_a21) {\n var query = _a21.query, trans = _a21.trans;\n var index = query.index, range = query.range;\n return new Promise(function(resolve, reject) {\n var store = trans.objectStore(tableName);\n var source = index.isPrimaryKey ? store : store.index(index.name);\n var idbKeyRange = makeIDBKeyRange(range);\n var req = idbKeyRange ? source.count(idbKeyRange) : source.count();\n req.onsuccess = wrap(function(ev) {\n return resolve(ev.target.result);\n });\n req.onerror = eventRejectHandler(reject);\n });\n }\n };\n }\n var _a15 = extractSchema(db1, tmpTrans), schema = _a15.schema, hasGetAll1 = _a15.hasGetAll;\n var tables1 = schema.tables.map(function(tableSchema) {\n return createDbCoreTable(tableSchema);\n });\n var tableMap = {\n };\n tables1.forEach(function(table) {\n return tableMap[table.name] = table;\n });\n return {\n stack: \"dbcore\",\n transaction: db1.transaction.bind(db1),\n table: function(name) {\n var result = tableMap[name];\n if (!result) throw new Error(\"Table '\" + name + \"' not found\");\n return tableMap[name];\n },\n MIN_KEY: -Infinity,\n MAX_KEY: getMaxKey(IdbKeyRange),\n schema: schema\n };\n}\nfunction createMiddlewareStack(stackImpl, middlewares) {\n return middlewares.reduce(function(down, _a22) {\n var create = _a22.create;\n return __assign(__assign({\n }, down), create(down));\n }, stackImpl);\n}\nfunction createMiddlewareStacks(middlewares, idbdb, _a23, tmpTrans) {\n var IDBKeyRange = _a23.IDBKeyRange;\n _a23.indexedDB;\n var dbcore = createMiddlewareStack(createDBCore(idbdb, IDBKeyRange, tmpTrans), middlewares.dbcore);\n return {\n dbcore: dbcore\n };\n}\nfunction generateMiddlewareStacks(_a24, tmpTrans) {\n var db = _a24._novip;\n var idbdb = tmpTrans.db;\n var stacks = createMiddlewareStacks(db._middlewares, idbdb, db._deps, tmpTrans);\n db.core = stacks.dbcore;\n db.tables.forEach(function(table) {\n var tableName = table.name;\n if (db.core.schema.tables.some(function(tbl) {\n return tbl.name === tableName;\n })) {\n table.core = db.core.table(tableName);\n if (db[tableName] instanceof db.Table) db[tableName].core = table.core;\n }\n });\n}\nfunction setApiOnPlace(_a25, objs, tableNames, dbschema) {\n var db = _a25._novip;\n tableNames.forEach(function(tableName) {\n var schema = dbschema[tableName];\n objs.forEach(function(obj) {\n var propDesc = getPropertyDescriptor(obj, tableName);\n if (!propDesc || \"value\" in propDesc && propDesc.value === undefined) {\n if (obj === db.Transaction.prototype || obj instanceof db.Transaction) setProp(obj, tableName, {\n get: function() {\n return this.table(tableName);\n },\n set: function(value) {\n defineProperty(this, tableName, {\n value: value,\n writable: true,\n configurable: true,\n enumerable: true\n });\n }\n });\n else obj[tableName] = new db.Table(tableName, schema);\n }\n });\n });\n}\nfunction removeTablesApi(_a26, objs) {\n var db = _a26._novip;\n objs.forEach(function(obj) {\n for(var key in obj)if (obj[key] instanceof db.Table) delete obj[key];\n });\n}\nfunction lowerVersionFirst(a, b) {\n return a._cfg.version - b._cfg.version;\n}\nfunction runUpgraders(db, oldVersion, idbUpgradeTrans, reject) {\n var globalSchema = db._dbSchema;\n var trans = db._createTransaction('readwrite', db._storeNames, globalSchema);\n trans.create(idbUpgradeTrans);\n trans._completion.catch(reject);\n var rejectTransaction = trans._reject.bind(trans);\n var transless = PSD.transless || PSD;\n newScope(function() {\n PSD.trans = trans;\n PSD.transless = transless;\n if (oldVersion === 0) {\n keys(globalSchema).forEach(function(tableName) {\n createTable(idbUpgradeTrans, tableName, globalSchema[tableName].primKey, globalSchema[tableName].indexes);\n });\n generateMiddlewareStacks(db, idbUpgradeTrans);\n DexiePromise.follow(function() {\n return db.on.populate.fire(trans);\n }).catch(rejectTransaction);\n } else updateTablesAndIndexes(db, oldVersion, trans, idbUpgradeTrans).catch(rejectTransaction);\n });\n}\nfunction updateTablesAndIndexes(_a27, oldVersion, trans, idbUpgradeTrans) {\n var db = _a27._novip;\n var queue = [];\n var versions = db._versions;\n var globalSchema = db._dbSchema = buildGlobalSchema(db, db.idbdb, idbUpgradeTrans);\n var anyContentUpgraderHasRun = false;\n var versToRun = versions.filter(function(v) {\n return v._cfg.version >= oldVersion;\n });\n versToRun.forEach(function(version) {\n queue.push(function() {\n var oldSchema = globalSchema;\n var newSchema = version._cfg.dbschema;\n adjustToExistingIndexNames(db, oldSchema, idbUpgradeTrans);\n adjustToExistingIndexNames(db, newSchema, idbUpgradeTrans);\n globalSchema = db._dbSchema = newSchema;\n var diff = getSchemaDiff(oldSchema, newSchema);\n diff.add.forEach(function(tuple) {\n createTable(idbUpgradeTrans, tuple[0], tuple[1].primKey, tuple[1].indexes);\n });\n diff.change.forEach(function(change) {\n if (change.recreate) throw new exceptions.Upgrade(\"Not yet support for changing primary key\");\n else {\n var store_1 = idbUpgradeTrans.objectStore(change.name);\n change.add.forEach(function(idx) {\n return addIndex(store_1, idx);\n });\n change.change.forEach(function(idx) {\n store_1.deleteIndex(idx.name);\n addIndex(store_1, idx);\n });\n change.del.forEach(function(idxName) {\n return store_1.deleteIndex(idxName);\n });\n }\n });\n var contentUpgrade = version._cfg.contentUpgrade;\n if (contentUpgrade && version._cfg.version > oldVersion) {\n generateMiddlewareStacks(db, idbUpgradeTrans);\n trans._memoizedTables = {\n };\n anyContentUpgraderHasRun = true;\n var upgradeSchema_1 = shallowClone(newSchema);\n diff.del.forEach(function(table) {\n upgradeSchema_1[table] = oldSchema[table];\n });\n removeTablesApi(db, [\n db.Transaction.prototype\n ]);\n setApiOnPlace(db, [\n db.Transaction.prototype\n ], keys(upgradeSchema_1), upgradeSchema_1);\n trans.schema = upgradeSchema_1;\n var contentUpgradeIsAsync_1 = isAsyncFunction(contentUpgrade);\n if (contentUpgradeIsAsync_1) incrementExpectedAwaits();\n var returnValue_1;\n var promiseFollowed = DexiePromise.follow(function() {\n returnValue_1 = contentUpgrade(trans);\n if (returnValue_1) {\n if (contentUpgradeIsAsync_1) {\n var decrementor = decrementExpectedAwaits.bind(null, null);\n returnValue_1.then(decrementor, decrementor);\n }\n }\n });\n return returnValue_1 && typeof returnValue_1.then === 'function' ? DexiePromise.resolve(returnValue_1) : promiseFollowed.then(function() {\n return returnValue_1;\n });\n }\n });\n queue.push(function(idbtrans) {\n if (!anyContentUpgraderHasRun || !hasIEDeleteObjectStoreBug) {\n var newSchema = version._cfg.dbschema;\n deleteRemovedTables(newSchema, idbtrans);\n }\n removeTablesApi(db, [\n db.Transaction.prototype\n ]);\n setApiOnPlace(db, [\n db.Transaction.prototype\n ], db._storeNames, db._dbSchema);\n trans.schema = db._dbSchema;\n });\n });\n function runQueue() {\n return queue.length ? DexiePromise.resolve(queue.shift()(trans.idbtrans)).then(runQueue) : DexiePromise.resolve();\n }\n return runQueue().then(function() {\n createMissingTables(globalSchema, idbUpgradeTrans);\n });\n}\nfunction getSchemaDiff(oldSchema, newSchema) {\n var diff = {\n del: [],\n add: [],\n change: []\n };\n var table;\n for(table in oldSchema)if (!newSchema[table]) diff.del.push(table);\n for(table in newSchema){\n var oldDef = oldSchema[table], newDef = newSchema[table];\n if (!oldDef) diff.add.push([\n table,\n newDef\n ]);\n else {\n var change = {\n name: table,\n def: newDef,\n recreate: false,\n del: [],\n add: [],\n change: []\n };\n if ('' + (oldDef.primKey.keyPath || '') !== '' + (newDef.primKey.keyPath || '') || oldDef.primKey.auto !== newDef.primKey.auto && !isIEOrEdge) {\n change.recreate = true;\n diff.change.push(change);\n } else {\n var oldIndexes = oldDef.idxByName;\n var newIndexes = newDef.idxByName;\n var idxName = void 0;\n for(idxName in oldIndexes)if (!newIndexes[idxName]) change.del.push(idxName);\n for(idxName in newIndexes){\n var oldIdx = oldIndexes[idxName], newIdx = newIndexes[idxName];\n if (!oldIdx) change.add.push(newIdx);\n else if (oldIdx.src !== newIdx.src) change.change.push(newIdx);\n }\n if (change.del.length > 0 || change.add.length > 0 || change.change.length > 0) diff.change.push(change);\n }\n }\n }\n return diff;\n}\nfunction createTable(idbtrans, tableName, primKey, indexes) {\n var store = idbtrans.db.createObjectStore(tableName, primKey.keyPath ? {\n keyPath: primKey.keyPath,\n autoIncrement: primKey.auto\n } : {\n autoIncrement: primKey.auto\n });\n indexes.forEach(function(idx) {\n return addIndex(store, idx);\n });\n return store;\n}\nfunction createMissingTables(newSchema, idbtrans) {\n keys(newSchema).forEach(function(tableName) {\n if (!idbtrans.db.objectStoreNames.contains(tableName)) createTable(idbtrans, tableName, newSchema[tableName].primKey, newSchema[tableName].indexes);\n });\n}\nfunction deleteRemovedTables(newSchema, idbtrans) {\n [].slice.call(idbtrans.db.objectStoreNames).forEach(function(storeName) {\n return newSchema[storeName] == null && idbtrans.db.deleteObjectStore(storeName);\n });\n}\nfunction addIndex(store, idx) {\n store.createIndex(idx.name, idx.keyPath, {\n unique: idx.unique,\n multiEntry: idx.multi\n });\n}\nfunction buildGlobalSchema(db, idbdb, tmpTrans) {\n var globalSchema = {\n };\n var dbStoreNames = slice(idbdb.objectStoreNames, 0);\n dbStoreNames.forEach(function(storeName) {\n var store = tmpTrans.objectStore(storeName);\n var keyPath = store.keyPath;\n var primKey = createIndexSpec(nameFromKeyPath(keyPath), keyPath || \"\", false, false, !!store.autoIncrement, keyPath && typeof keyPath !== \"string\", true);\n var indexes = [];\n for(var j = 0; j < store.indexNames.length; ++j){\n var idbindex = store.index(store.indexNames[j]);\n keyPath = idbindex.keyPath;\n var index = createIndexSpec(idbindex.name, keyPath, !!idbindex.unique, !!idbindex.multiEntry, false, keyPath && typeof keyPath !== \"string\", false);\n indexes.push(index);\n }\n globalSchema[storeName] = createTableSchema(storeName, primKey, indexes);\n });\n return globalSchema;\n}\nfunction readGlobalSchema(_a28, idbdb, tmpTrans) {\n var db = _a28._novip;\n db.verno = idbdb.version / 10;\n var globalSchema = db._dbSchema = buildGlobalSchema(db, idbdb, tmpTrans);\n db._storeNames = slice(idbdb.objectStoreNames, 0);\n setApiOnPlace(db, [\n db._allTables\n ], keys(globalSchema), globalSchema);\n}\nfunction verifyInstalledSchema(db, tmpTrans) {\n var installedSchema = buildGlobalSchema(db, db.idbdb, tmpTrans);\n var diff = getSchemaDiff(installedSchema, db._dbSchema);\n return !(diff.add.length || diff.change.some(function(ch) {\n return ch.add.length || ch.change.length;\n }));\n}\nfunction adjustToExistingIndexNames(_a29, schema, idbtrans) {\n var db = _a29._novip;\n var storeNames = idbtrans.db.objectStoreNames;\n for(var i = 0; i < storeNames.length; ++i){\n var storeName = storeNames[i];\n var store = idbtrans.objectStore(storeName);\n db._hasGetAll = 'getAll' in store;\n for(var j = 0; j < store.indexNames.length; ++j){\n var indexName = store.indexNames[j];\n var keyPath = store.index(indexName).keyPath;\n var dexieName = typeof keyPath === 'string' ? keyPath : \"[\" + slice(keyPath).join('+') + \"]\";\n if (schema[storeName]) {\n var indexSpec = schema[storeName].idxByName[dexieName];\n if (indexSpec) {\n indexSpec.name = indexName;\n delete schema[storeName].idxByName[dexieName];\n schema[storeName].idxByName[indexName] = indexSpec;\n }\n }\n }\n }\n if (typeof navigator !== 'undefined' && /Safari/.test(navigator.userAgent) && !/(Chrome\\/|Edge\\/)/.test(navigator.userAgent) && _global.WorkerGlobalScope && _global instanceof _global.WorkerGlobalScope && [].concat(navigator.userAgent.match(/Safari\\/(\\d*)/))[1] < 604) db._hasGetAll = false;\n}\nfunction parseIndexSyntax(primKeyAndIndexes) {\n return primKeyAndIndexes.split(',').map(function(index, indexNum) {\n index = index.trim();\n var name = index.replace(/([&*]|\\+\\+)/g, \"\");\n var keyPath = /^\\[/.test(name) ? name.match(/^\\[(.*)\\]$/)[1].split('+') : name;\n return createIndexSpec(name, keyPath || null, /\\&/.test(index), /\\*/.test(index), /\\+\\+/.test(index), isArray(keyPath), indexNum === 0);\n });\n}\nvar Version = function() {\n function Version1() {\n }\n Version1.prototype._parseStoresSpec = function(stores, outSchema) {\n keys(stores).forEach(function(tableName) {\n if (stores[tableName] !== null) {\n var indexes = parseIndexSyntax(stores[tableName]);\n var primKey = indexes.shift();\n if (primKey.multi) throw new exceptions.Schema(\"Primary key cannot be multi-valued\");\n indexes.forEach(function(idx) {\n if (idx.auto) throw new exceptions.Schema(\"Only primary key can be marked as autoIncrement (++)\");\n if (!idx.keyPath) throw new exceptions.Schema(\"Index must have a name and cannot be an empty string\");\n });\n outSchema[tableName] = createTableSchema(tableName, primKey, indexes);\n }\n });\n };\n Version1.prototype.stores = function(stores) {\n var db = this.db;\n this._cfg.storesSource = this._cfg.storesSource ? extend(this._cfg.storesSource, stores) : stores;\n var versions = db._versions;\n var storesSpec = {\n };\n var dbschema = {\n };\n versions.forEach(function(version) {\n extend(storesSpec, version._cfg.storesSource);\n dbschema = version._cfg.dbschema = {\n };\n version._parseStoresSpec(storesSpec, dbschema);\n });\n db._dbSchema = dbschema;\n removeTablesApi(db, [\n db._allTables,\n db,\n db.Transaction.prototype\n ]);\n setApiOnPlace(db, [\n db._allTables,\n db,\n db.Transaction.prototype,\n this._cfg.tables\n ], keys(dbschema), dbschema);\n db._storeNames = keys(dbschema);\n return this;\n };\n Version1.prototype.upgrade = function(upgradeFunction) {\n this._cfg.contentUpgrade = promisableChain(this._cfg.contentUpgrade || nop, upgradeFunction);\n return this;\n };\n return Version1;\n}();\nfunction createVersionConstructor(db) {\n return makeClassConstructor(Version.prototype, function Version(versionNumber) {\n this.db = db;\n this._cfg = {\n version: versionNumber,\n storesSource: null,\n dbschema: {\n },\n tables: {\n },\n contentUpgrade: null\n };\n });\n}\nfunction getDbNamesTable(indexedDB, IDBKeyRange) {\n var dbNamesDB = indexedDB[\"_dbNamesDB\"];\n if (!dbNamesDB) {\n dbNamesDB = indexedDB[\"_dbNamesDB\"] = new Dexie$1(DBNAMES_DB, {\n addons: [],\n indexedDB: indexedDB,\n IDBKeyRange: IDBKeyRange\n });\n dbNamesDB.version(1).stores({\n dbnames: \"name\"\n });\n }\n return dbNamesDB.table(\"dbnames\");\n}\nfunction hasDatabasesNative(indexedDB) {\n return indexedDB && typeof indexedDB.databases === \"function\";\n}\nfunction getDatabaseNames(_a30) {\n var indexedDB = _a30.indexedDB, IDBKeyRange = _a30.IDBKeyRange;\n return hasDatabasesNative(indexedDB) ? Promise.resolve(indexedDB.databases()).then(function(infos) {\n return infos.map(function(info) {\n return info.name;\n }).filter(function(name) {\n return name !== DBNAMES_DB;\n });\n }) : getDbNamesTable(indexedDB, IDBKeyRange).toCollection().primaryKeys();\n}\nfunction _onDatabaseCreated(_a31, name) {\n var indexedDB = _a31.indexedDB, IDBKeyRange = _a31.IDBKeyRange;\n !hasDatabasesNative(indexedDB) && name !== DBNAMES_DB && getDbNamesTable(indexedDB, IDBKeyRange).put({\n name: name\n }).catch(nop);\n}\nfunction _onDatabaseDeleted(_a32, name) {\n var indexedDB = _a32.indexedDB, IDBKeyRange = _a32.IDBKeyRange;\n !hasDatabasesNative(indexedDB) && name !== DBNAMES_DB && getDbNamesTable(indexedDB, IDBKeyRange).delete(name).catch(nop);\n}\nfunction vip(fn) {\n return newScope(function() {\n PSD.letThrough = true;\n return fn();\n });\n}\nfunction idbReady() {\n var isSafari = !navigator.userAgentData && /Safari\\//.test(navigator.userAgent) && !/Chrom(e|ium)\\//.test(navigator.userAgent);\n if (!isSafari || !indexedDB.databases) return Promise.resolve();\n var intervalId;\n return new Promise(function(resolve) {\n var tryIdb = function() {\n return indexedDB.databases().finally(resolve);\n };\n intervalId = setInterval(tryIdb, 100);\n tryIdb();\n }).finally(function() {\n return clearInterval(intervalId);\n });\n}\nfunction dexieOpen(db) {\n var state = db._state;\n var indexedDB = db._deps.indexedDB;\n if (state.isBeingOpened || db.idbdb) return state.dbReadyPromise.then(function() {\n return state.dbOpenError ? rejection(state.dbOpenError) : db;\n });\n debug && (state.openCanceller._stackHolder = getErrorWithStack());\n state.isBeingOpened = true;\n state.dbOpenError = null;\n state.openComplete = false;\n var openCanceller = state.openCanceller;\n function throwIfCancelled() {\n if (state.openCanceller !== openCanceller) throw new exceptions.DatabaseClosed('db.open() was cancelled');\n }\n var resolveDbReady = state.dbReadyResolve, upgradeTransaction = null, wasCreated = false;\n return DexiePromise.race([\n openCanceller,\n (typeof navigator === 'undefined' ? DexiePromise.resolve() : idbReady()).then(function() {\n return new DexiePromise(function(resolve, reject) {\n throwIfCancelled();\n if (!indexedDB) throw new exceptions.MissingAPI();\n var dbName = db.name;\n var req = state.autoSchema ? indexedDB.open(dbName) : indexedDB.open(dbName, Math.round(db.verno * 10));\n if (!req) throw new exceptions.MissingAPI();\n req.onerror = eventRejectHandler(reject);\n req.onblocked = wrap(db._fireOnBlocked);\n req.onupgradeneeded = wrap(function(e) {\n upgradeTransaction = req.transaction;\n if (state.autoSchema && !db._options.allowEmptyDB) {\n req.onerror = preventDefault;\n upgradeTransaction.abort();\n req.result.close();\n var delreq = indexedDB.deleteDatabase(dbName);\n delreq.onsuccess = delreq.onerror = wrap(function() {\n reject(new exceptions.NoSuchDatabase(\"Database \" + dbName + \" doesnt exist\"));\n });\n } else {\n upgradeTransaction.onerror = eventRejectHandler(reject);\n var oldVer = e.oldVersion > Math.pow(2, 62) ? 0 : e.oldVersion;\n wasCreated = oldVer < 1;\n db._novip.idbdb = req.result;\n runUpgraders(db, oldVer / 10, upgradeTransaction, reject);\n }\n }, reject);\n req.onsuccess = wrap(function() {\n upgradeTransaction = null;\n var idbdb = db._novip.idbdb = req.result;\n var objectStoreNames = slice(idbdb.objectStoreNames);\n if (objectStoreNames.length > 0) try {\n var tmpTrans = idbdb.transaction(safariMultiStoreFix(objectStoreNames), 'readonly');\n if (state.autoSchema) readGlobalSchema(db, idbdb, tmpTrans);\n else {\n adjustToExistingIndexNames(db, db._dbSchema, tmpTrans);\n if (!verifyInstalledSchema(db, tmpTrans)) console.warn(\"Dexie SchemaDiff: Schema was extended without increasing the number passed to db.version(). Some queries may fail.\");\n }\n generateMiddlewareStacks(db, tmpTrans);\n } catch (e) {\n }\n connections.push(db);\n idbdb.onversionchange = wrap(function(ev) {\n state.vcFired = true;\n db.on(\"versionchange\").fire(ev);\n });\n idbdb.onclose = wrap(function(ev) {\n db.on(\"close\").fire(ev);\n });\n if (wasCreated) _onDatabaseCreated(db._deps, dbName);\n resolve();\n }, reject);\n });\n })\n ]).then(function() {\n throwIfCancelled();\n state.onReadyBeingFired = [];\n return DexiePromise.resolve(vip(function() {\n return db.on.ready.fire(db.vip);\n })).then(function fireRemainders() {\n if (state.onReadyBeingFired.length > 0) {\n var remainders_1 = state.onReadyBeingFired.reduce(promisableChain, nop);\n state.onReadyBeingFired = [];\n return DexiePromise.resolve(vip(function() {\n return remainders_1(db.vip);\n })).then(fireRemainders);\n }\n });\n }).finally(function() {\n state.onReadyBeingFired = null;\n state.isBeingOpened = false;\n }).then(function() {\n return db;\n }).catch(function(err) {\n state.dbOpenError = err;\n try {\n upgradeTransaction && upgradeTransaction.abort();\n } catch (_a) {\n }\n if (openCanceller === state.openCanceller) db._close();\n return rejection(err);\n }).finally(function() {\n state.openComplete = true;\n resolveDbReady();\n });\n}\nfunction awaitIterator(iterator) {\n var callNext = function(result) {\n return iterator.next(result);\n }, doThrow = function(error) {\n return iterator.throw(error);\n }, onSuccess = step(callNext), onError = step(doThrow);\n function step(getNext) {\n return function(val) {\n var next = getNext(val), value = next.value;\n return next.done ? value : !value || typeof value.then !== 'function' ? isArray(value) ? Promise.all(value).then(onSuccess, onError) : onSuccess(value) : value.then(onSuccess, onError);\n };\n }\n return step(callNext)();\n}\nfunction extractTransactionArgs(mode, _tableArgs_, scopeFunc) {\n var i = arguments.length;\n if (i < 2) throw new exceptions.InvalidArgument(\"Too few arguments\");\n var args = new Array(i - 1);\n while(--i)args[i - 1] = arguments[i];\n scopeFunc = args.pop();\n var tables = flatten(args);\n return [\n mode,\n tables,\n scopeFunc\n ];\n}\nfunction enterTransactionScope(db, mode, storeNames, parentTransaction, scopeFunc) {\n return DexiePromise.resolve().then(function() {\n var transless = PSD.transless || PSD;\n var trans = db._createTransaction(mode, storeNames, db._dbSchema, parentTransaction);\n var zoneProps = {\n trans: trans,\n transless: transless\n };\n if (parentTransaction) trans.idbtrans = parentTransaction.idbtrans;\n else try {\n trans.create();\n db._state.PR1398_maxLoop = 3;\n } catch (ex) {\n if (ex.name === errnames.InvalidState && db.isOpen() && --db._state.PR1398_maxLoop > 0) {\n console.warn('Dexie: Need to reopen db');\n db._close();\n return db.open().then(function() {\n return enterTransactionScope(db, mode, storeNames, null, scopeFunc);\n });\n }\n return rejection(ex);\n }\n var scopeFuncIsAsync = isAsyncFunction(scopeFunc);\n if (scopeFuncIsAsync) incrementExpectedAwaits();\n var returnValue;\n var promiseFollowed = DexiePromise.follow(function() {\n returnValue = scopeFunc.call(trans, trans);\n if (returnValue) {\n if (scopeFuncIsAsync) {\n var decrementor = decrementExpectedAwaits.bind(null, null);\n returnValue.then(decrementor, decrementor);\n } else if (typeof returnValue.next === 'function' && typeof returnValue.throw === 'function') returnValue = awaitIterator(returnValue);\n }\n }, zoneProps);\n return (returnValue && typeof returnValue.then === 'function' ? DexiePromise.resolve(returnValue).then(function(x) {\n return trans.active ? x : rejection(new exceptions.PrematureCommit(\"Transaction committed too early. See http://bit.ly/2kdckMn\"));\n }) : promiseFollowed.then(function() {\n return returnValue;\n })).then(function(x) {\n if (parentTransaction) trans._resolve();\n return trans._completion.then(function() {\n return x;\n });\n }).catch(function(e) {\n trans._reject(e);\n return rejection(e);\n });\n });\n}\nfunction pad(a, value, count) {\n var result = isArray(a) ? a.slice() : [\n a\n ];\n for(var i = 0; i < count; ++i)result.push(value);\n return result;\n}\nfunction createVirtualIndexMiddleware(down) {\n return __assign(__assign({\n }, down), {\n table: function(tableName) {\n var table = down.table(tableName);\n var schema = table.schema;\n var indexLookup = {\n };\n var allVirtualIndexes = [];\n function addVirtualIndexes(keyPath, keyTail, lowLevelIndex) {\n var keyPathAlias = getKeyPathAlias(keyPath);\n var indexList = indexLookup[keyPathAlias] = indexLookup[keyPathAlias] || [];\n var keyLength = keyPath == null ? 0 : typeof keyPath === 'string' ? 1 : keyPath.length;\n var isVirtual = keyTail > 0;\n var virtualIndex = __assign(__assign({\n }, lowLevelIndex), {\n isVirtual: isVirtual,\n keyTail: keyTail,\n keyLength: keyLength,\n extractKey: getKeyExtractor(keyPath),\n unique: !isVirtual && lowLevelIndex.unique\n });\n indexList.push(virtualIndex);\n if (!virtualIndex.isPrimaryKey) allVirtualIndexes.push(virtualIndex);\n if (keyLength > 1) {\n var virtualKeyPath = keyLength === 2 ? keyPath[0] : keyPath.slice(0, keyLength - 1);\n addVirtualIndexes(virtualKeyPath, keyTail + 1, lowLevelIndex);\n }\n indexList.sort(function(a, b) {\n return a.keyTail - b.keyTail;\n });\n return virtualIndex;\n }\n var primaryKey1 = addVirtualIndexes(schema.primaryKey.keyPath, 0, schema.primaryKey);\n indexLookup[\":id\"] = [\n primaryKey1\n ];\n for(var _i = 0, _a33 = schema.indexes; _i < _a33.length; _i++){\n var index = _a33[_i];\n addVirtualIndexes(index.keyPath, 0, index);\n }\n function findBestIndex(keyPath) {\n var result = indexLookup[getKeyPathAlias(keyPath)];\n return result && result[0];\n }\n function translateRange(range, keyTail) {\n return {\n type: range.type === 1 ? 2 : range.type,\n lower: pad(range.lower, range.lowerOpen ? down.MAX_KEY : down.MIN_KEY, keyTail),\n lowerOpen: true,\n upper: pad(range.upper, range.upperOpen ? down.MIN_KEY : down.MAX_KEY, keyTail),\n upperOpen: true\n };\n }\n function translateRequest(req) {\n var index = req.query.index;\n return index.isVirtual ? __assign(__assign({\n }, req), {\n query: {\n index: index,\n range: translateRange(req.query.range, index.keyTail)\n }\n }) : req;\n }\n var result2 = __assign(__assign({\n }, table), {\n schema: __assign(__assign({\n }, schema), {\n primaryKey: primaryKey1,\n indexes: allVirtualIndexes,\n getIndexByKeyPath: findBestIndex\n }),\n count: function(req) {\n return table.count(translateRequest(req));\n },\n query: function(req) {\n return table.query(translateRequest(req));\n },\n openCursor: function(req) {\n var _a34 = req.query.index, keyTail = _a34.keyTail, isVirtual = _a34.isVirtual, keyLength = _a34.keyLength;\n if (!isVirtual) return table.openCursor(req);\n function createVirtualCursor(cursor) {\n function _continue(key) {\n key != null ? cursor.continue(pad(key, req.reverse ? down.MAX_KEY : down.MIN_KEY, keyTail)) : req.unique ? cursor.continue(cursor.key.slice(0, keyLength).concat(req.reverse ? down.MIN_KEY : down.MAX_KEY, keyTail)) : cursor.continue();\n }\n var virtualCursor = Object.create(cursor, {\n continue: {\n value: _continue\n },\n continuePrimaryKey: {\n value: function(key, primaryKey) {\n cursor.continuePrimaryKey(pad(key, down.MAX_KEY, keyTail), primaryKey);\n }\n },\n primaryKey: {\n get: function() {\n return cursor.primaryKey;\n }\n },\n key: {\n get: function() {\n var key = cursor.key;\n return keyLength === 1 ? key[0] : key.slice(0, keyLength);\n }\n },\n value: {\n get: function() {\n return cursor.value;\n }\n }\n });\n return virtualCursor;\n }\n return table.openCursor(translateRequest(req)).then(function(cursor) {\n return cursor && createVirtualCursor(cursor);\n });\n }\n });\n return result2;\n }\n });\n}\nvar virtualIndexMiddleware = {\n stack: \"dbcore\",\n name: \"VirtualIndexMiddleware\",\n level: 1,\n create: createVirtualIndexMiddleware\n};\nfunction getObjectDiff(a, b, rv, prfx) {\n rv = rv || {\n };\n prfx = prfx || '';\n keys(a).forEach(function(prop) {\n if (!hasOwn(b, prop)) rv[prfx + prop] = undefined;\n else {\n var ap = a[prop], bp = b[prop];\n if (typeof ap === 'object' && typeof bp === 'object' && ap && bp) {\n var apTypeName = toStringTag(ap);\n var bpTypeName = toStringTag(bp);\n if (apTypeName !== bpTypeName) rv[prfx + prop] = b[prop];\n else if (apTypeName === 'Object') getObjectDiff(ap, bp, rv, prfx + prop + '.');\n else if (ap !== bp) rv[prfx + prop] = b[prop];\n } else if (ap !== bp) rv[prfx + prop] = b[prop];\n }\n });\n keys(b).forEach(function(prop) {\n if (!hasOwn(a, prop)) rv[prfx + prop] = b[prop];\n });\n return rv;\n}\nfunction getEffectiveKeys(primaryKey, req) {\n if (req.type === 'delete') return req.keys;\n return req.keys || req.values.map(primaryKey.extractKey);\n}\nvar hooksMiddleware = {\n stack: \"dbcore\",\n name: \"HooksMiddleware\",\n level: 2,\n create: function(downCore) {\n return __assign(__assign({\n }, downCore), {\n table: function(tableName) {\n var downTable = downCore.table(tableName);\n var primaryKey = downTable.schema.primaryKey;\n var tableMiddleware = __assign(__assign({\n }, downTable), {\n mutate: function(req3) {\n var dxTrans1 = PSD.trans;\n var _a35 = dxTrans1.table(tableName).hook, deleting = _a35.deleting, creating = _a35.creating, updating = _a35.updating;\n switch(req3.type){\n case 'add':\n if (creating.fire === nop) break;\n return dxTrans1._promise('readwrite', function() {\n return addPutOrDelete(req3);\n }, true);\n case 'put':\n if (creating.fire === nop && updating.fire === nop) break;\n return dxTrans1._promise('readwrite', function() {\n return addPutOrDelete(req3);\n }, true);\n case 'delete':\n if (deleting.fire === nop) break;\n return dxTrans1._promise('readwrite', function() {\n return addPutOrDelete(req3);\n }, true);\n case 'deleteRange':\n if (deleting.fire === nop) break;\n return dxTrans1._promise('readwrite', function() {\n return deleteRange(req3);\n }, true);\n }\n function addPutOrDelete(req) {\n var dxTrans = PSD.trans;\n var keys8 = req.keys || getEffectiveKeys(primaryKey, req);\n if (!keys8) throw new Error(\"Keys missing\");\n req = req.type === 'add' || req.type === 'put' ? __assign(__assign({\n }, req), {\n keys: keys8\n }) : __assign({\n }, req);\n if (req.type !== 'delete') req.values = __spreadArray([], req.values, true);\n if (req.keys) req.keys = __spreadArray([], req.keys, true);\n return getExistingValues(downTable, req, keys8).then(function(existingValues) {\n var contexts = keys8.map(function(key, i) {\n var existingValue = existingValues[i];\n var ctx = {\n onerror: null,\n onsuccess: null\n };\n if (req.type === 'delete') {\n deleting.fire.call(ctx, key, existingValue, dxTrans);\n } else if (req.type === 'add' || existingValue === undefined) {\n var generatedPrimaryKey = creating.fire.call(ctx, key, req.values[i], dxTrans);\n if (key == null && generatedPrimaryKey != null) {\n key = generatedPrimaryKey;\n req.keys[i] = key;\n if (!primaryKey.outbound) {\n setByKeyPath(req.values[i], primaryKey.keyPath, key);\n }\n }\n } else {\n var objectDiff = getObjectDiff(existingValue, req.values[i]);\n var additionalChanges_1 = updating.fire.call(ctx, objectDiff, key, existingValue, dxTrans);\n if (additionalChanges_1) {\n var requestedValue_1 = req.values[i];\n Object.keys(additionalChanges_1).forEach(function(keyPath) {\n if (hasOwn(requestedValue_1, keyPath)) {\n requestedValue_1[keyPath] = additionalChanges_1[keyPath];\n } else {\n setByKeyPath(requestedValue_1, keyPath, additionalChanges_1[keyPath]);\n }\n });\n }\n }\n return ctx;\n });\n return downTable.mutate(req).then(function(_a36) {\n var failures = _a36.failures, results = _a36.results, numFailures = _a36.numFailures, lastResult = _a36.lastResult;\n for(var i = 0; i < keys8.length; ++i){\n var primKey = results ? results[i] : keys8[i];\n var ctx = contexts[i];\n if (primKey == null) {\n ctx.onerror && ctx.onerror(failures[i]);\n } else {\n ctx.onsuccess && ctx.onsuccess(req.type === 'put' && existingValues[i] ? req.values[i] : primKey);\n }\n }\n return {\n failures: failures,\n results: results,\n numFailures: numFailures,\n lastResult: lastResult\n };\n }).catch(function(error) {\n contexts.forEach(function(ctx) {\n return ctx.onerror && ctx.onerror(error);\n });\n return Promise.reject(error);\n });\n });\n }\n function deleteRange(req) {\n return deleteNextChunk(req.trans, req.range, 10000);\n }\n function deleteNextChunk(trans, range, limit) {\n return downTable.query({\n trans: trans,\n values: false,\n query: {\n index: primaryKey,\n range: range\n },\n limit: limit\n }).then(function(_a37) {\n var result = _a37.result;\n return addPutOrDelete({\n type: 'delete',\n keys: result,\n trans: trans\n }).then(function(res) {\n if (res.numFailures > 0) return Promise.reject(res.failures[0]);\n if (result.length < limit) {\n return {\n failures: [],\n numFailures: 0,\n lastResult: undefined\n };\n } else {\n return deleteNextChunk(trans, __assign(__assign({\n }, range), {\n lower: result[result.length - 1],\n lowerOpen: true\n }), limit);\n }\n });\n });\n }\n return downTable.mutate(req3);\n }\n });\n return tableMiddleware;\n }\n });\n }\n};\nfunction getExistingValues(table, req, effectiveKeys) {\n return req.type === \"add\" ? Promise.resolve([]) : table.getMany({\n trans: req.trans,\n keys: effectiveKeys,\n cache: \"immutable\"\n });\n}\nfunction getFromTransactionCache(keys9, cache, clone) {\n try {\n if (!cache) return null;\n if (cache.keys.length < keys9.length) return null;\n var result = [];\n for(var i = 0, j = 0; i < cache.keys.length && j < keys9.length; ++i){\n if (cmp(cache.keys[i], keys9[j]) !== 0) continue;\n result.push(clone ? deepClone(cache.values[i]) : cache.values[i]);\n ++j;\n }\n return result.length === keys9.length ? result : null;\n } catch (_a) {\n return null;\n }\n}\nvar cacheExistingValuesMiddleware = {\n stack: \"dbcore\",\n level: -1,\n create: function(core) {\n return {\n table: function(tableName) {\n var table = core.table(tableName);\n return __assign(__assign({\n }, table), {\n getMany: function(req) {\n if (!req.cache) return table.getMany(req);\n var cachedResult = getFromTransactionCache(req.keys, req.trans[\"_cache\"], req.cache === \"clone\");\n if (cachedResult) return DexiePromise.resolve(cachedResult);\n return table.getMany(req).then(function(res) {\n req.trans[\"_cache\"] = {\n keys: req.keys,\n values: req.cache === \"clone\" ? deepClone(res) : res\n };\n return res;\n });\n },\n mutate: function(req) {\n if (req.type !== \"add\") req.trans[\"_cache\"] = null;\n return table.mutate(req);\n }\n });\n }\n };\n }\n};\nvar _a;\nfunction isEmptyRange(node) {\n return !(\"from\" in node);\n}\nvar RangeSet = function(fromOrTree, to) {\n if (this) extend(this, arguments.length ? {\n d: 1,\n from: fromOrTree,\n to: arguments.length > 1 ? to : fromOrTree\n } : {\n d: 0\n });\n else {\n var rv = new RangeSet();\n if (fromOrTree && \"d\" in fromOrTree) extend(rv, fromOrTree);\n return rv;\n }\n};\nprops(RangeSet.prototype, (_a = {\n add: function(rangeSet) {\n mergeRanges(this, rangeSet);\n return this;\n },\n addKey: function(key) {\n addRange(this, key, key);\n return this;\n },\n addKeys: function(keys10) {\n var _this = this;\n keys10.forEach(function(key) {\n return addRange(_this, key, key);\n });\n return this;\n }\n}, _a[iteratorSymbol] = function() {\n return getRangeSetIterator(this);\n}, _a));\nfunction addRange(target, from, to) {\n var diff = cmp(from, to);\n if (isNaN(diff)) return;\n if (diff > 0) throw RangeError();\n if (isEmptyRange(target)) return extend(target, {\n from: from,\n to: to,\n d: 1\n });\n var left = target.l;\n var right = target.r;\n if (cmp(to, target.from) < 0) {\n left ? addRange(left, from, to) : target.l = {\n from: from,\n to: to,\n d: 1,\n l: null,\n r: null\n };\n return rebalance(target);\n }\n if (cmp(from, target.to) > 0) {\n right ? addRange(right, from, to) : target.r = {\n from: from,\n to: to,\n d: 1,\n l: null,\n r: null\n };\n return rebalance(target);\n }\n if (cmp(from, target.from) < 0) {\n target.from = from;\n target.l = null;\n target.d = right ? right.d + 1 : 1;\n }\n if (cmp(to, target.to) > 0) {\n target.to = to;\n target.r = null;\n target.d = target.l ? target.l.d + 1 : 1;\n }\n var rightWasCutOff = !target.r;\n if (left && !target.l) mergeRanges(target, left);\n if (right && rightWasCutOff) mergeRanges(target, right);\n}\nfunction mergeRanges(target1, newSet) {\n function _addRangeSet(target, _a38) {\n var from = _a38.from, to = _a38.to, l = _a38.l, r = _a38.r;\n addRange(target, from, to);\n if (l) _addRangeSet(target, l);\n if (r) _addRangeSet(target, r);\n }\n if (!isEmptyRange(newSet)) _addRangeSet(target1, newSet);\n}\nfunction rangesOverlap(rangeSet1, rangeSet2) {\n var i1 = getRangeSetIterator(rangeSet2);\n var nextResult1 = i1.next();\n if (nextResult1.done) return false;\n var a = nextResult1.value;\n var i2 = getRangeSetIterator(rangeSet1);\n var nextResult2 = i2.next(a.from);\n var b = nextResult2.value;\n while(!nextResult1.done && !nextResult2.done){\n if (cmp(b.from, a.to) <= 0 && cmp(b.to, a.from) >= 0) return true;\n cmp(a.from, b.from) < 0 ? a = (nextResult1 = i1.next(b.from)).value : b = (nextResult2 = i2.next(a.from)).value;\n }\n return false;\n}\nfunction getRangeSetIterator(node) {\n var state = isEmptyRange(node) ? null : {\n s: 0,\n n: node\n };\n return {\n next: function(key) {\n var keyProvided = arguments.length > 0;\n while(state)switch(state.s){\n case 0:\n state.s = 1;\n if (keyProvided) while(state.n.l && cmp(key, state.n.from) < 0)state = {\n up: state,\n n: state.n.l,\n s: 1\n };\n else while(state.n.l)state = {\n up: state,\n n: state.n.l,\n s: 1\n };\n case 1:\n state.s = 2;\n if (!keyProvided || cmp(key, state.n.to) <= 0) return {\n value: state.n,\n done: false\n };\n case 2:\n if (state.n.r) {\n state.s = 3;\n state = {\n up: state,\n n: state.n.r,\n s: 0\n };\n continue;\n }\n case 3:\n state = state.up;\n }\n return {\n done: true\n };\n }\n };\n}\nfunction rebalance(target) {\n var _a39, _b;\n var diff = (((_a39 = target.r) === null || _a39 === void 0 ? void 0 : _a39.d) || 0) - (((_b = target.l) === null || _b === void 0 ? void 0 : _b.d) || 0);\n var r = diff > 1 ? \"r\" : diff < -1 ? \"l\" : \"\";\n if (r) {\n var l = r === \"r\" ? \"l\" : \"r\";\n var rootClone = __assign({\n }, target);\n var oldRootRight = target[r];\n target.from = oldRootRight.from;\n target.to = oldRootRight.to;\n target[r] = oldRootRight[r];\n rootClone[r] = oldRootRight[l];\n target[l] = rootClone;\n rootClone.d = computeDepth(rootClone);\n }\n target.d = computeDepth(target);\n}\nfunction computeDepth(_a40) {\n var r = _a40.r, l = _a40.l;\n return (r ? l ? Math.max(r.d, l.d) : r.d : l ? l.d : 0) + 1;\n}\nvar observabilityMiddleware = {\n stack: \"dbcore\",\n level: 0,\n create: function(core) {\n var dbName = core.schema.name;\n var FULL_RANGE = new RangeSet(core.MIN_KEY, core.MAX_KEY);\n return __assign(__assign({\n }, core), {\n table: function(tableName) {\n var table = core.table(tableName);\n var schema = table.schema;\n var primaryKey = schema.primaryKey;\n var extractKey = primaryKey.extractKey, outbound = primaryKey.outbound;\n var tableClone = __assign(__assign({\n }, table), {\n mutate: function(req) {\n var trans = req.trans;\n var mutatedParts = trans.mutatedParts || (trans.mutatedParts = {\n });\n var getRangeSet = function(indexName) {\n var part = \"idb://\" + dbName + \"/\" + tableName + \"/\" + indexName;\n return mutatedParts[part] || (mutatedParts[part] = new RangeSet());\n };\n var pkRangeSet = getRangeSet(\"\");\n var delsRangeSet = getRangeSet(\":dels\");\n var type3 = req.type;\n var _a41 = req.type === \"deleteRange\" ? [\n req.range\n ] : req.type === \"delete\" ? [\n req.keys\n ] : req.values.length < 50 ? [\n [],\n req.values\n ] : [], keys11 = _a41[0], newObjs = _a41[1];\n var oldCache = req.trans[\"_cache\"];\n return table.mutate(req).then(function(res) {\n if (isArray(keys11)) {\n if (type3 !== \"delete\") keys11 = res.results;\n pkRangeSet.addKeys(keys11);\n var oldObjs = getFromTransactionCache(keys11, oldCache);\n if (!oldObjs && type3 !== \"add\") delsRangeSet.addKeys(keys11);\n if (oldObjs || newObjs) trackAffectedIndexes(getRangeSet, schema, oldObjs, newObjs);\n } else if (keys11) {\n var range = {\n from: keys11.lower,\n to: keys11.upper\n };\n delsRangeSet.add(range);\n pkRangeSet.add(range);\n } else {\n pkRangeSet.add(FULL_RANGE);\n delsRangeSet.add(FULL_RANGE);\n schema.indexes.forEach(function(idx) {\n return getRangeSet(idx.name).add(FULL_RANGE);\n });\n }\n return res;\n });\n }\n });\n var getRange = function(_a42) {\n var _b, _c;\n var _d = _a42.query, index = _d.index, range = _d.range;\n return [\n index,\n new RangeSet((_b = range.lower) !== null && _b !== void 0 ? _b : core.MIN_KEY, (_c = range.upper) !== null && _c !== void 0 ? _c : core.MAX_KEY), \n ];\n };\n var readSubscribers = {\n get: function(req) {\n return [\n primaryKey,\n new RangeSet(req.key)\n ];\n },\n getMany: function(req) {\n return [\n primaryKey,\n new RangeSet().addKeys(req.keys)\n ];\n },\n count: getRange,\n query: getRange,\n openCursor: getRange\n };\n keys(readSubscribers).forEach(function(method) {\n tableClone[method] = function(req) {\n var subscr = PSD.subscr;\n if (subscr) {\n var getRangeSet = function(indexName) {\n var part = \"idb://\" + dbName + \"/\" + tableName + \"/\" + indexName;\n return subscr[part] || (subscr[part] = new RangeSet());\n };\n var pkRangeSet_1 = getRangeSet(\"\");\n var delsRangeSet_1 = getRangeSet(\":dels\");\n var _a43 = readSubscribers[method](req), queriedIndex = _a43[0], queriedRanges = _a43[1];\n getRangeSet(queriedIndex.name || \"\").add(queriedRanges);\n if (!queriedIndex.isPrimaryKey) {\n if (method === \"count\") delsRangeSet_1.add(FULL_RANGE);\n else {\n var keysPromise_1 = method === \"query\" && outbound && req.values && table.query(__assign(__assign({\n }, req), {\n values: false\n }));\n return table[method].apply(this, arguments).then(function(res) {\n if (method === \"query\") {\n if (outbound && req.values) return keysPromise_1.then(function(_a44) {\n var resultingKeys = _a44.result;\n pkRangeSet_1.addKeys(resultingKeys);\n return res;\n });\n var pKeys = req.values ? res.result.map(extractKey) : res.result;\n if (req.values) pkRangeSet_1.addKeys(pKeys);\n else delsRangeSet_1.addKeys(pKeys);\n } else if (method === \"openCursor\") {\n var cursor_1 = res;\n var wantValues_1 = req.values;\n return cursor_1 && Object.create(cursor_1, {\n key: {\n get: function() {\n delsRangeSet_1.addKey(cursor_1.primaryKey);\n return cursor_1.key;\n }\n },\n primaryKey: {\n get: function() {\n var pkey = cursor_1.primaryKey;\n delsRangeSet_1.addKey(pkey);\n return pkey;\n }\n },\n value: {\n get: function() {\n wantValues_1 && pkRangeSet_1.addKey(cursor_1.primaryKey);\n return cursor_1.value;\n }\n }\n });\n }\n return res;\n });\n }\n }\n }\n return table[method].apply(this, arguments);\n };\n });\n return tableClone;\n }\n });\n }\n};\nfunction trackAffectedIndexes(getRangeSet, schema, oldObjs, newObjs) {\n function addAffectedIndex(ix) {\n var rangeSet = getRangeSet(ix.name || \"\");\n function extractKey(obj) {\n return obj != null ? ix.extractKey(obj) : null;\n }\n var addKeyOrKeys = function(key1) {\n return ix.multiEntry && isArray(key1) ? key1.forEach(function(key) {\n return rangeSet.addKey(key);\n }) : rangeSet.addKey(key1);\n };\n (oldObjs || newObjs).forEach(function(_, i) {\n var oldKey = oldObjs && extractKey(oldObjs[i]);\n var newKey = newObjs && extractKey(newObjs[i]);\n if (cmp(oldKey, newKey) !== 0) {\n if (oldKey != null) addKeyOrKeys(oldKey);\n if (newKey != null) addKeyOrKeys(newKey);\n }\n });\n }\n schema.indexes.forEach(addAffectedIndex);\n}\nvar Dexie$1 = function() {\n function Dexie1(name, options) {\n var _this = this;\n this._middlewares = {\n };\n this.verno = 0;\n var deps = Dexie1.dependencies;\n this._options = options = __assign({\n addons: Dexie1.addons,\n autoOpen: true,\n indexedDB: deps.indexedDB,\n IDBKeyRange: deps.IDBKeyRange\n }, options);\n this._deps = {\n indexedDB: options.indexedDB,\n IDBKeyRange: options.IDBKeyRange\n };\n var addons = options.addons;\n this._dbSchema = {\n };\n this._versions = [];\n this._storeNames = [];\n this._allTables = {\n };\n this.idbdb = null;\n this._novip = this;\n var state1 = {\n dbOpenError: null,\n isBeingOpened: false,\n onReadyBeingFired: null,\n openComplete: false,\n dbReadyResolve: nop,\n dbReadyPromise: null,\n cancelOpen: nop,\n openCanceller: null,\n autoSchema: true,\n PR1398_maxLoop: 3\n };\n state1.dbReadyPromise = new DexiePromise(function(resolve) {\n state1.dbReadyResolve = resolve;\n });\n state1.openCanceller = new DexiePromise(function(_, reject) {\n state1.cancelOpen = reject;\n });\n this._state = state1;\n this.name = name;\n this.on = Events(this, \"populate\", \"blocked\", \"versionchange\", \"close\", {\n ready: [\n promisableChain,\n nop\n ]\n });\n this.on.ready.subscribe = override(this.on.ready.subscribe, function(subscribe) {\n return function(subscriber, bSticky) {\n Dexie1.vip(function() {\n var state = _this._state;\n if (state.openComplete) {\n if (!state.dbOpenError) DexiePromise.resolve().then(subscriber);\n if (bSticky) subscribe(subscriber);\n } else if (state.onReadyBeingFired) {\n state.onReadyBeingFired.push(subscriber);\n if (bSticky) subscribe(subscriber);\n } else {\n subscribe(subscriber);\n var db_1 = _this;\n if (!bSticky) subscribe(function unsubscribe() {\n db_1.on.ready.unsubscribe(subscriber);\n db_1.on.ready.unsubscribe(unsubscribe);\n });\n }\n });\n };\n });\n this.Collection = createCollectionConstructor(this);\n this.Table = createTableConstructor(this);\n this.Transaction = createTransactionConstructor(this);\n this.Version = createVersionConstructor(this);\n this.WhereClause = createWhereClauseConstructor(this);\n this.on(\"versionchange\", function(ev) {\n if (ev.newVersion > 0) console.warn(\"Another connection wants to upgrade database '\" + _this.name + \"'. Closing db now to resume the upgrade.\");\n else console.warn(\"Another connection wants to delete database '\" + _this.name + \"'. Closing db now to resume the delete request.\");\n _this.close();\n });\n this.on(\"blocked\", function(ev) {\n if (!ev.newVersion || ev.newVersion < ev.oldVersion) console.warn(\"Dexie.delete('\" + _this.name + \"') was blocked\");\n else console.warn(\"Upgrade '\" + _this.name + \"' blocked by other connection holding version \" + ev.oldVersion / 10);\n });\n this._maxKey = getMaxKey(options.IDBKeyRange);\n this._createTransaction = function(mode, storeNames, dbschema, parentTransaction) {\n return new _this.Transaction(mode, storeNames, dbschema, _this._options.chromeTransactionDurability, parentTransaction);\n };\n this._fireOnBlocked = function(ev) {\n _this.on(\"blocked\").fire(ev);\n connections.filter(function(c) {\n return c.name === _this.name && c !== _this && !c._state.vcFired;\n }).map(function(c) {\n return c.on(\"versionchange\").fire(ev);\n });\n };\n this.use(virtualIndexMiddleware);\n this.use(hooksMiddleware);\n this.use(observabilityMiddleware);\n this.use(cacheExistingValuesMiddleware);\n this.vip = Object.create(this, {\n _vip: {\n value: true\n }\n });\n addons.forEach(function(addon) {\n return addon(_this);\n });\n }\n Dexie1.prototype.version = function(versionNumber) {\n if (isNaN(versionNumber) || versionNumber < 0.1) throw new exceptions.Type(\"Given version is not a positive number\");\n versionNumber = Math.round(versionNumber * 10) / 10;\n if (this.idbdb || this._state.isBeingOpened) throw new exceptions.Schema(\"Cannot add version when database is open\");\n this.verno = Math.max(this.verno, versionNumber);\n var versions = this._versions;\n var versionInstance = versions.filter(function(v) {\n return v._cfg.version === versionNumber;\n })[0];\n if (versionInstance) return versionInstance;\n versionInstance = new this.Version(versionNumber);\n versions.push(versionInstance);\n versions.sort(lowerVersionFirst);\n versionInstance.stores({\n });\n this._state.autoSchema = false;\n return versionInstance;\n };\n Dexie1.prototype._whenReady = function(fn) {\n var _this = this;\n return this.idbdb && (this._state.openComplete || PSD.letThrough || this._vip) ? fn() : new DexiePromise(function(resolve, reject) {\n if (_this._state.openComplete) return reject(new exceptions.DatabaseClosed(_this._state.dbOpenError));\n if (!_this._state.isBeingOpened) {\n if (!_this._options.autoOpen) {\n reject(new exceptions.DatabaseClosed());\n return;\n }\n _this.open().catch(nop);\n }\n _this._state.dbReadyPromise.then(resolve, reject);\n }).then(fn);\n };\n Dexie1.prototype.use = function(_a45) {\n var stack = _a45.stack, create = _a45.create, level = _a45.level, name = _a45.name;\n if (name) this.unuse({\n stack: stack,\n name: name\n });\n var middlewares = this._middlewares[stack] || (this._middlewares[stack] = []);\n middlewares.push({\n stack: stack,\n create: create,\n level: level == null ? 10 : level,\n name: name\n });\n middlewares.sort(function(a, b) {\n return a.level - b.level;\n });\n return this;\n };\n Dexie1.prototype.unuse = function(_a46) {\n var stack = _a46.stack, name = _a46.name, create = _a46.create;\n if (stack && this._middlewares[stack]) this._middlewares[stack] = this._middlewares[stack].filter(function(mw) {\n return create ? mw.create !== create : name ? mw.name !== name : false;\n });\n return this;\n };\n Dexie1.prototype.open = function() {\n return dexieOpen(this);\n };\n Dexie1.prototype._close = function() {\n var state = this._state;\n var idx = connections.indexOf(this);\n if (idx >= 0) connections.splice(idx, 1);\n if (this.idbdb) {\n try {\n this.idbdb.close();\n } catch (e) {\n }\n this._novip.idbdb = null;\n }\n state.dbReadyPromise = new DexiePromise(function(resolve) {\n state.dbReadyResolve = resolve;\n });\n state.openCanceller = new DexiePromise(function(_, reject) {\n state.cancelOpen = reject;\n });\n };\n Dexie1.prototype.close = function() {\n this._close();\n var state = this._state;\n this._options.autoOpen = false;\n state.dbOpenError = new exceptions.DatabaseClosed();\n if (state.isBeingOpened) state.cancelOpen(state.dbOpenError);\n };\n Dexie1.prototype.delete = function() {\n var _this = this;\n var hasArguments = arguments.length > 0;\n var state = this._state;\n return new DexiePromise(function(resolve, reject) {\n var doDelete = function() {\n _this.close();\n var req = _this._deps.indexedDB.deleteDatabase(_this.name);\n req.onsuccess = wrap(function() {\n _onDatabaseDeleted(_this._deps, _this.name);\n resolve();\n });\n req.onerror = eventRejectHandler(reject);\n req.onblocked = _this._fireOnBlocked;\n };\n if (hasArguments) throw new exceptions.InvalidArgument(\"Arguments not allowed in db.delete()\");\n if (state.isBeingOpened) state.dbReadyPromise.then(doDelete);\n else doDelete();\n });\n };\n Dexie1.prototype.backendDB = function() {\n return this.idbdb;\n };\n Dexie1.prototype.isOpen = function() {\n return this.idbdb !== null;\n };\n Dexie1.prototype.hasBeenClosed = function() {\n var dbOpenError = this._state.dbOpenError;\n return dbOpenError && dbOpenError.name === 'DatabaseClosed';\n };\n Dexie1.prototype.hasFailed = function() {\n return this._state.dbOpenError !== null;\n };\n Dexie1.prototype.dynamicallyOpened = function() {\n return this._state.autoSchema;\n };\n Object.defineProperty(Dexie1.prototype, \"tables\", {\n get: function() {\n var _this = this;\n return keys(this._allTables).map(function(name) {\n return _this._allTables[name];\n });\n },\n enumerable: false,\n configurable: true\n });\n Dexie1.prototype.transaction = function() {\n var args = extractTransactionArgs.apply(this, arguments);\n return this._transaction.apply(this, args);\n };\n Dexie1.prototype._transaction = function(mode, tables, scopeFunc) {\n var _this = this;\n var parentTransaction = PSD.trans;\n if (!parentTransaction || parentTransaction.db !== this || mode.indexOf('!') !== -1) parentTransaction = null;\n var onlyIfCompatible = mode.indexOf('?') !== -1;\n mode = mode.replace('!', '').replace('?', '');\n var idbMode, storeNames;\n try {\n storeNames = tables.map(function(table) {\n var storeName = table instanceof _this.Table ? table.name : table;\n if (typeof storeName !== 'string') throw new TypeError(\"Invalid table argument to Dexie.transaction(). Only Table or String are allowed\");\n return storeName;\n });\n if (mode == \"r\" || mode === READONLY) idbMode = READONLY;\n else if (mode == \"rw\" || mode == READWRITE) idbMode = READWRITE;\n else throw new exceptions.InvalidArgument(\"Invalid transaction mode: \" + mode);\n if (parentTransaction) {\n if (parentTransaction.mode === READONLY && idbMode === READWRITE) {\n if (onlyIfCompatible) parentTransaction = null;\n else throw new exceptions.SubTransaction(\"Cannot enter a sub-transaction with READWRITE mode when parent transaction is READONLY\");\n }\n if (parentTransaction) storeNames.forEach(function(storeName) {\n if (parentTransaction && parentTransaction.storeNames.indexOf(storeName) === -1) {\n if (onlyIfCompatible) parentTransaction = null;\n else throw new exceptions.SubTransaction(\"Table \" + storeName + \" not included in parent transaction.\");\n }\n });\n if (onlyIfCompatible && parentTransaction && !parentTransaction.active) parentTransaction = null;\n }\n } catch (e) {\n return parentTransaction ? parentTransaction._promise(null, function(_, reject) {\n reject(e);\n }) : rejection(e);\n }\n var enterTransaction = enterTransactionScope.bind(null, this, idbMode, storeNames, parentTransaction, scopeFunc);\n return parentTransaction ? parentTransaction._promise(idbMode, enterTransaction, \"lock\") : PSD.trans ? usePSD(PSD.transless, function() {\n return _this._whenReady(enterTransaction);\n }) : this._whenReady(enterTransaction);\n };\n Dexie1.prototype.table = function(tableName) {\n if (!hasOwn(this._allTables, tableName)) throw new exceptions.InvalidTable(\"Table \" + tableName + \" does not exist\");\n return this._allTables[tableName];\n };\n return Dexie1;\n}();\nvar symbolObservable = typeof Symbol !== \"undefined\" && \"observable\" in Symbol ? Symbol.observable : \"@@observable\";\nvar Observable = function() {\n function Observable1(subscribe) {\n this._subscribe = subscribe;\n }\n Observable1.prototype.subscribe = function(x, error, complete) {\n return this._subscribe(!x || typeof x === \"function\" ? {\n next: x,\n error: error,\n complete: complete\n } : x);\n };\n Observable1.prototype[symbolObservable] = function() {\n return this;\n };\n return Observable1;\n}();\nfunction extendObservabilitySet(target, newSet) {\n keys(newSet).forEach(function(part) {\n var rangeSet = target[part] || (target[part] = new RangeSet());\n mergeRanges(rangeSet, newSet[part]);\n });\n return target;\n}\nfunction liveQuery(querier) {\n return new Observable(function(observer) {\n var scopeFuncIsAsync = isAsyncFunction(querier);\n function execute(subscr) {\n if (scopeFuncIsAsync) incrementExpectedAwaits();\n var exec = function() {\n return newScope(querier, {\n subscr: subscr,\n trans: null\n });\n };\n var rv = PSD.trans ? usePSD(PSD.transless, exec) : exec();\n if (scopeFuncIsAsync) rv.then(decrementExpectedAwaits, decrementExpectedAwaits);\n return rv;\n }\n var closed = false;\n var accumMuts = {\n };\n var currentObs = {\n };\n var subscription = {\n get closed () {\n return closed;\n },\n unsubscribe: function() {\n closed = true;\n globalEvents.storagemutated.unsubscribe(mutationListener);\n }\n };\n observer.start && observer.start(subscription);\n var querying = false, startedListening = false;\n function shouldNotify() {\n return keys(currentObs).some(function(key) {\n return accumMuts[key] && rangesOverlap(accumMuts[key], currentObs[key]);\n });\n }\n var mutationListener = function(parts) {\n extendObservabilitySet(accumMuts, parts);\n if (shouldNotify()) doQuery();\n };\n var doQuery = function() {\n if (querying || closed) return;\n accumMuts = {\n };\n var subscr = {\n };\n var ret = execute(subscr);\n if (!startedListening) {\n globalEvents(DEXIE_STORAGE_MUTATED_EVENT_NAME, mutationListener);\n startedListening = true;\n }\n querying = true;\n Promise.resolve(ret).then(function(result) {\n querying = false;\n if (closed) return;\n if (shouldNotify()) doQuery();\n else {\n accumMuts = {\n };\n currentObs = subscr;\n observer.next && observer.next(result);\n }\n }, function(err) {\n querying = false;\n observer.error && observer.error(err);\n subscription.unsubscribe();\n });\n };\n doQuery();\n return subscription;\n });\n}\nvar domDeps;\ntry {\n domDeps = {\n indexedDB: _global.indexedDB || _global.mozIndexedDB || _global.webkitIndexedDB || _global.msIndexedDB,\n IDBKeyRange: _global.IDBKeyRange || _global.webkitIDBKeyRange\n };\n} catch (e) {\n domDeps = {\n indexedDB: null,\n IDBKeyRange: null\n };\n}\nvar Dexie = Dexie$1;\nprops(Dexie, __assign(__assign({\n}, fullNameExceptions), {\n delete: function(databaseName) {\n var db = new Dexie(databaseName, {\n addons: []\n });\n return db.delete();\n },\n exists: function(name) {\n return new Dexie(name, {\n addons: []\n }).open().then(function(db) {\n db.close();\n return true;\n }).catch('NoSuchDatabaseError', function() {\n return false;\n });\n },\n getDatabaseNames: function(cb) {\n try {\n return getDatabaseNames(Dexie.dependencies).then(cb);\n } catch (_a) {\n return rejection(new exceptions.MissingAPI());\n }\n },\n defineClass: function() {\n function Class(content) {\n extend(this, content);\n }\n return Class;\n },\n ignoreTransaction: function(scopeFunc) {\n return PSD.trans ? usePSD(PSD.transless, scopeFunc) : scopeFunc();\n },\n vip: vip,\n async: function(generatorFn) {\n return function() {\n try {\n var rv = awaitIterator(generatorFn.apply(this, arguments));\n if (!rv || typeof rv.then !== 'function') return DexiePromise.resolve(rv);\n return rv;\n } catch (e2) {\n return rejection(e2);\n }\n };\n },\n spawn: function(generatorFn, args, thiz) {\n try {\n var rv = awaitIterator(generatorFn.apply(thiz, args || []));\n if (!rv || typeof rv.then !== 'function') return DexiePromise.resolve(rv);\n return rv;\n } catch (e3) {\n return rejection(e3);\n }\n },\n currentTransaction: {\n get: function() {\n return PSD.trans || null;\n }\n },\n waitFor: function(promiseOrFunction, optionalTimeout) {\n var promise = DexiePromise.resolve(typeof promiseOrFunction === 'function' ? Dexie.ignoreTransaction(promiseOrFunction) : promiseOrFunction).timeout(optionalTimeout || 60000);\n return PSD.trans ? PSD.trans.waitFor(promise) : promise;\n },\n Promise: DexiePromise,\n debug: {\n get: function() {\n return debug;\n },\n set: function(value) {\n setDebug(value, value === 'dexie' ? function() {\n return true;\n } : dexieStackFrameFilter);\n }\n },\n derive: derive,\n extend: extend,\n props: props,\n override: override,\n Events: Events,\n on: globalEvents,\n liveQuery: liveQuery,\n extendObservabilitySet: extendObservabilitySet,\n getByKeyPath: getByKeyPath,\n setByKeyPath: setByKeyPath,\n delByKeyPath: delByKeyPath,\n shallowClone: shallowClone,\n deepClone: deepClone,\n getObjectDiff: getObjectDiff,\n cmp: cmp,\n asap: asap$1,\n minKey: minKey,\n addons: [],\n connections: connections,\n errnames: errnames,\n dependencies: domDeps,\n semVer: DEXIE_VERSION,\n version: DEXIE_VERSION.split('.').map(function(n) {\n return parseInt(n);\n }).reduce(function(p, c, i) {\n return p + c / Math.pow(10, i * 2);\n })\n}));\nDexie.maxKey = getMaxKey(Dexie.dependencies.IDBKeyRange);\nif (typeof dispatchEvent !== 'undefined' && typeof addEventListener !== 'undefined') {\n globalEvents(DEXIE_STORAGE_MUTATED_EVENT_NAME, function(updatedParts) {\n if (!propagatingLocally) {\n var event_1;\n if (isIEOrEdge) {\n event_1 = document.createEvent('CustomEvent');\n event_1.initCustomEvent(STORAGE_MUTATED_DOM_EVENT_NAME, true, true, updatedParts);\n } else event_1 = new CustomEvent(STORAGE_MUTATED_DOM_EVENT_NAME, {\n detail: updatedParts\n });\n propagatingLocally = true;\n dispatchEvent(event_1);\n propagatingLocally = false;\n }\n });\n addEventListener(STORAGE_MUTATED_DOM_EVENT_NAME, function(_a47) {\n var detail = _a47.detail;\n if (!propagatingLocally) propagateLocally(detail);\n });\n}\nfunction propagateLocally(updateParts) {\n var wasMe = propagatingLocally;\n try {\n propagatingLocally = true;\n globalEvents.storagemutated.fire(updateParts);\n } finally{\n propagatingLocally = wasMe;\n }\n}\nvar propagatingLocally = false;\nif (typeof BroadcastChannel !== 'undefined') {\n var bc_1 = new BroadcastChannel(STORAGE_MUTATED_DOM_EVENT_NAME);\n globalEvents(DEXIE_STORAGE_MUTATED_EVENT_NAME, function(changedParts) {\n if (!propagatingLocally) bc_1.postMessage(changedParts);\n });\n bc_1.onmessage = function(ev) {\n if (ev.data) propagateLocally(ev.data);\n };\n} else if (typeof self !== 'undefined' && typeof navigator !== 'undefined') {\n globalEvents(DEXIE_STORAGE_MUTATED_EVENT_NAME, function(changedParts) {\n try {\n if (!propagatingLocally) {\n if (typeof localStorage !== 'undefined') localStorage.setItem(STORAGE_MUTATED_DOM_EVENT_NAME, JSON.stringify({\n trig: Math.random(),\n changedParts: changedParts\n }));\n if (typeof self['clients'] === 'object') __spreadArray([], self['clients'].matchAll({\n includeUncontrolled: true\n }), true).forEach(function(client) {\n return client.postMessage({\n type: STORAGE_MUTATED_DOM_EVENT_NAME,\n changedParts: changedParts\n });\n });\n }\n } catch (_a) {\n }\n });\n addEventListener('storage', function(ev) {\n if (ev.key === STORAGE_MUTATED_DOM_EVENT_NAME) {\n var data = JSON.parse(ev.newValue);\n if (data) propagateLocally(data.changedParts);\n }\n });\n var swContainer = self.document && navigator.serviceWorker;\n if (swContainer) swContainer.addEventListener('message', propagateMessageLocally);\n}\nfunction propagateMessageLocally(_a48) {\n var data = _a48.data;\n if (data && data.type === STORAGE_MUTATED_DOM_EVENT_NAME) propagateLocally(data.changedParts);\n}\nDexiePromise.rejectionMapper = mapError;\nsetDebug(debug, dexieStackFrameFilter);\n\n},{\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"kLtCZ\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"lineWrapper\", ()=>lineWrapper\n);\nvar _language = require(\"@codemirror/language\");\nvar _view = require(\"@codemirror/view\");\nfunction wrapLines(view, wrapElements) {\n let widgets = [];\n let elementStack = [];\n for (let { from: from1 , to: to1 } of view.visibleRanges){\n const doc = view.state.doc;\n _language.syntaxTree(view.state).iterate({\n from: from1,\n to: to1,\n enter: (type, from, to)=>{\n const bodyText = doc.sliceString(from, to);\n for (let wrapElement of wrapElements)if (type.name == wrapElement.selector) {\n if (wrapElement.nesting) elementStack.push(type.name);\n const bodyText = doc.sliceString(from, to);\n let idx = from;\n for (let line of bodyText.split(\"\\n\")){\n let cls = wrapElement.class;\n if (wrapElement.nesting) cls = `${cls} ${cls}-${elementStack.length}`;\n widgets.push(_view.Decoration.line({\n class: cls\n }).range(doc.lineAt(idx).from));\n idx += line.length + 1;\n }\n }\n },\n leave (type, from, to) {\n for (let wrapElement of wrapElements)if (type.name == wrapElement.selector && wrapElement.nesting) elementStack.pop();\n }\n });\n }\n // Widgets have to be sorted by `from` in ascending order\n widgets = widgets.sort((a, b)=>{\n return a.from < b.from ? -1 : 1;\n });\n return _view.Decoration.set(widgets);\n}\nconst lineWrapper = (wrapElements)=>_view.ViewPlugin.fromClass(class {\n constructor(view){\n this.decorations = wrapLines(view, wrapElements);\n }\n update(update) {\n if (update.docChanged || update.viewportChanged) this.decorations = wrapLines(update.view, wrapElements);\n }\n }, {\n decorations: (v)=>v.decorations\n })\n;\n\n},{\"@codemirror/language\":\"70QHL\",\"@codemirror/view\":\"JuP5Z\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"bsH55\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"commonmarkLanguage\", ()=>_markdown1.commonmarkLanguage\n);\nparcelHelpers.export(exports, \"markdownLanguage\", ()=>_markdown1.markdownLanguage\n);\nparcelHelpers.export(exports, \"insertNewlineContinueMarkup\", ()=>_commands.insertNewlineContinueMarkup\n);\nparcelHelpers.export(exports, \"deleteMarkupBackward\", ()=>_commands.deleteMarkupBackward\n);\nparcelHelpers.export(exports, \"markdownKeymap\", ()=>markdownKeymap\n);\n/// Markdown language support.\nparcelHelpers.export(exports, \"markdown\", ()=>markdown\n);\nvar _state = require(\"@codemirror/state\");\nvar _view = require(\"@codemirror/view\");\nvar _language = require(\"@codemirror/language\");\nvar _markdown = require(\"@lezer/markdown\");\nvar _langHtml = require(\"@codemirror/lang-html\");\nvar _markdown1 = require(\"./markdown\");\nvar _commands = require(\"./commands\");\nconst markdownKeymap = [\n {\n key: \"Enter\",\n run: _commands.insertNewlineContinueMarkup\n },\n {\n key: \"Backspace\",\n run: _commands.deleteMarkupBackward\n }\n];\nconst htmlNoMatch = _langHtml.html({\n matchClosingTags: false\n});\nfunction markdown(config = {\n}) {\n let { codeLanguages , defaultCodeLanguage , addKeymap =true , base: { parser } = _markdown1.commonmarkLanguage } = config;\n if (!(parser instanceof _markdown.MarkdownParser)) throw new RangeError(\"Base parser provided to `markdown` should be a Markdown parser\");\n let extensions = config.extensions ? [\n config.extensions\n ] : [];\n let support = [\n htmlNoMatch.support\n ], defaultCode;\n if (defaultCodeLanguage instanceof _language.LanguageSupport) {\n support.push(defaultCodeLanguage.support);\n defaultCode = defaultCodeLanguage.language;\n } else if (defaultCodeLanguage) defaultCode = defaultCodeLanguage;\n let codeParser = codeLanguages || defaultCode ? _markdown1.getCodeParser(codeLanguages || [], defaultCode) : undefined;\n extensions.push(_markdown.parseCode({\n codeParser,\n htmlParser: htmlNoMatch.language.parser\n }));\n if (addKeymap) support.push(_state.Prec.high(_view.keymap.of(markdownKeymap)));\n return new _language.LanguageSupport(_markdown1.mkLang(parser.configure(extensions)), support);\n}\n\n},{\"@codemirror/state\":\"e6FBl\",\"@codemirror/view\":\"JuP5Z\",\"@codemirror/language\":\"70QHL\",\"@lezer/markdown\":\"hyLlR\",\"@codemirror/lang-html\":\"idzAC\",\"./markdown\":\"36F0z\",\"./commands\":\"9hr01\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"hyLlR\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"BlockContext\", ()=>BlockContext\n);\nparcelHelpers.export(exports, \"Element\", ()=>Element\n);\nparcelHelpers.export(exports, \"Emoji\", ()=>Emoji\n);\nparcelHelpers.export(exports, \"GFM\", ()=>GFM\n);\nparcelHelpers.export(exports, \"InlineContext\", ()=>InlineContext\n);\nparcelHelpers.export(exports, \"LeafBlock\", ()=>LeafBlock\n);\nparcelHelpers.export(exports, \"Line\", ()=>Line\n);\nparcelHelpers.export(exports, \"MarkdownParser\", ()=>MarkdownParser\n);\nparcelHelpers.export(exports, \"Strikethrough\", ()=>Strikethrough\n);\nparcelHelpers.export(exports, \"Subscript\", ()=>Subscript\n);\nparcelHelpers.export(exports, \"Superscript\", ()=>Superscript\n);\nparcelHelpers.export(exports, \"Table\", ()=>Table\n);\nparcelHelpers.export(exports, \"TaskList\", ()=>TaskList\n);\nparcelHelpers.export(exports, \"parseCode\", ()=>parseCode\n);\nparcelHelpers.export(exports, \"parser\", ()=>parser\n);\nvar _common = require(\"@lezer/common\");\nclass CompositeBlock {\n constructor(type, // Used for indentation in list items, markup character in lists\n value, from, hash, end, children, positions){\n this.type = type;\n this.value = value;\n this.from = from;\n this.hash = hash;\n this.end = end;\n this.children = children;\n this.positions = positions;\n this.hashProp = [\n [\n _common.NodeProp.contextHash,\n hash\n ]\n ];\n }\n static create(type, value, from, parentHash, end) {\n let hash = parentHash + (parentHash << 8) + type + (value << 4) | 0;\n return new CompositeBlock(type, value, from, hash, end, [], []);\n }\n addChild(child, pos) {\n if (child.prop(_common.NodeProp.contextHash) != this.hash) child = new _common.Tree(child.type, child.children, child.positions, child.length, this.hashProp);\n this.children.push(child);\n this.positions.push(pos);\n }\n toTree(nodeSet, end = this.end) {\n let last = this.children.length - 1;\n if (last >= 0) end = Math.max(end, this.positions[last] + this.children[last].length + this.from);\n let tree = new _common.Tree(nodeSet.types[this.type], this.children, this.positions, end - this.from).balance({\n makeTree: (children, positions, length)=>new _common.Tree(_common.NodeType.none, children, positions, length, this.hashProp)\n });\n return tree;\n }\n}\nvar Type;\n(function(Type1) {\n Type1[Type1[\"Document\"] = 1] = \"Document\";\n Type1[Type1[\"CodeBlock\"] = 2] = \"CodeBlock\";\n Type1[Type1[\"FencedCode\"] = 3] = \"FencedCode\";\n Type1[Type1[\"Blockquote\"] = 4] = \"Blockquote\";\n Type1[Type1[\"HorizontalRule\"] = 5] = \"HorizontalRule\";\n Type1[Type1[\"BulletList\"] = 6] = \"BulletList\";\n Type1[Type1[\"OrderedList\"] = 7] = \"OrderedList\";\n Type1[Type1[\"ListItem\"] = 8] = \"ListItem\";\n Type1[Type1[\"ATXHeading1\"] = 9] = \"ATXHeading1\";\n Type1[Type1[\"ATXHeading2\"] = 10] = \"ATXHeading2\";\n Type1[Type1[\"ATXHeading3\"] = 11] = \"ATXHeading3\";\n Type1[Type1[\"ATXHeading4\"] = 12] = \"ATXHeading4\";\n Type1[Type1[\"ATXHeading5\"] = 13] = \"ATXHeading5\";\n Type1[Type1[\"ATXHeading6\"] = 14] = \"ATXHeading6\";\n Type1[Type1[\"SetextHeading1\"] = 15] = \"SetextHeading1\";\n Type1[Type1[\"SetextHeading2\"] = 16] = \"SetextHeading2\";\n Type1[Type1[\"HTMLBlock\"] = 17] = \"HTMLBlock\";\n Type1[Type1[\"LinkReference\"] = 18] = \"LinkReference\";\n Type1[Type1[\"Paragraph\"] = 19] = \"Paragraph\";\n Type1[Type1[\"CommentBlock\"] = 20] = \"CommentBlock\";\n Type1[Type1[\"ProcessingInstructionBlock\"] = 21] = \"ProcessingInstructionBlock\";\n // Inline\n Type1[Type1[\"Escape\"] = 22] = \"Escape\";\n Type1[Type1[\"Entity\"] = 23] = \"Entity\";\n Type1[Type1[\"HardBreak\"] = 24] = \"HardBreak\";\n Type1[Type1[\"Emphasis\"] = 25] = \"Emphasis\";\n Type1[Type1[\"StrongEmphasis\"] = 26] = \"StrongEmphasis\";\n Type1[Type1[\"Link\"] = 27] = \"Link\";\n Type1[Type1[\"Image\"] = 28] = \"Image\";\n Type1[Type1[\"InlineCode\"] = 29] = \"InlineCode\";\n Type1[Type1[\"HTMLTag\"] = 30] = \"HTMLTag\";\n Type1[Type1[\"Comment\"] = 31] = \"Comment\";\n Type1[Type1[\"ProcessingInstruction\"] = 32] = \"ProcessingInstruction\";\n Type1[Type1[\"URL\"] = 33] = \"URL\";\n // Smaller tokens\n Type1[Type1[\"HeaderMark\"] = 34] = \"HeaderMark\";\n Type1[Type1[\"QuoteMark\"] = 35] = \"QuoteMark\";\n Type1[Type1[\"ListMark\"] = 36] = \"ListMark\";\n Type1[Type1[\"LinkMark\"] = 37] = \"LinkMark\";\n Type1[Type1[\"EmphasisMark\"] = 38] = \"EmphasisMark\";\n Type1[Type1[\"CodeMark\"] = 39] = \"CodeMark\";\n Type1[Type1[\"CodeText\"] = 40] = \"CodeText\";\n Type1[Type1[\"CodeInfo\"] = 41] = \"CodeInfo\";\n Type1[Type1[\"LinkTitle\"] = 42] = \"LinkTitle\";\n Type1[Type1[\"LinkLabel\"] = 43] = \"LinkLabel\";\n})(Type || (Type = {\n}));\n/// Data structure used to accumulate a block's content during [leaf\n/// block parsing](#BlockParser.leaf).\nclass LeafBlock {\n /// @internal\n constructor(/// The start position of the block.\n start, /// The block's text content.\n content){\n this.start = start;\n this.content = content;\n /// @internal\n this.marks = [];\n /// @internal\n this.parsers = [];\n }\n}\n/// Data structure used during block-level per-line parsing.\nclass Line {\n constructor(){\n /// The line's full text.\n this.text = \"\";\n /// The base indent provided by the composite contexts (that have\n /// been handled so far).\n this.baseIndent = 0;\n /// The string position corresponding to the base indent.\n this.basePos = 0;\n /// The number of contexts handled @internal\n this.depth = 0;\n /// Any markers (i.e. block quote markers) parsed for the contexts. @internal\n this.markers = [];\n /// The position of the next non-whitespace character beyond any\n /// list, blockquote, or other composite block markers.\n this.pos = 0;\n /// The column of the next non-whitespace character.\n this.indent = 0;\n /// The character code of the character after `pos`.\n this.next = -1;\n }\n /// @internal\n forward() {\n if (this.basePos > this.pos) this.forwardInner();\n }\n /// @internal\n forwardInner() {\n let newPos = this.skipSpace(this.basePos);\n this.indent = this.countIndent(newPos, this.pos, this.indent);\n this.pos = newPos;\n this.next = newPos == this.text.length ? -1 : this.text.charCodeAt(newPos);\n }\n /// Skip whitespace after the given position, return the position of\n /// the next non-space character or the end of the line if there's\n /// only space after `from`.\n skipSpace(from) {\n return skipSpace(this.text, from);\n }\n /// @internal\n reset(text) {\n this.text = text;\n this.baseIndent = this.basePos = this.pos = this.indent = 0;\n this.forwardInner();\n this.depth = 1;\n while(this.markers.length)this.markers.pop();\n }\n /// Move the line's base position forward to the given position.\n /// This should only be called by composite [block\n /// parsers](#BlockParser.parse) or [markup skipping\n /// functions](#NodeSpec.composite).\n moveBase(to) {\n this.basePos = to;\n this.baseIndent = this.countIndent(to, this.pos, this.indent);\n }\n /// Move the line's base position forward to the given _column_.\n moveBaseColumn(indent) {\n this.baseIndent = indent;\n this.basePos = this.findColumn(indent);\n }\n /// Store a composite-block-level marker. Should be called from\n /// [markup skipping functions](#NodeSpec.composite) when they\n /// consume any non-whitespace characters.\n addMarker(elt1) {\n this.markers.push(elt1);\n }\n /// Find the column position at `to`, optionally starting at a given\n /// position and column.\n countIndent(to, from = 0, indent = 0) {\n for(let i1 = from; i1 < to; i1++)indent += this.text.charCodeAt(i1) == 9 ? 4 - indent % 4 : 1;\n return indent;\n }\n /// Find the position corresponding to the given column.\n findColumn(goal) {\n let i2 = 0;\n for(let indent = 0; i2 < this.text.length && indent < goal; i2++)indent += this.text.charCodeAt(i2) == 9 ? 4 - indent % 4 : 1;\n return i2;\n }\n /// @internal\n scrub() {\n if (!this.baseIndent) return this.text;\n let result = \"\";\n for(let i3 = 0; i3 < this.basePos; i3++)result += \" \";\n return result + this.text.slice(this.basePos);\n }\n}\nfunction skipForList(bl, cx, line) {\n if (line.pos == line.text.length || bl != cx.block && line.indent >= cx.stack[line.depth + 1].value + line.baseIndent) return true;\n if (line.indent >= line.baseIndent + 4) return false;\n let size = (bl.type == Type.OrderedList ? isOrderedList : isBulletList)(line, cx, false);\n return size > 0 && (bl.type != Type.BulletList || isHorizontalRule(line, cx, false) < 0) && line.text.charCodeAt(line.pos + size - 1) == bl.value;\n}\nconst DefaultSkipMarkup = {\n [Type.Blockquote] (bl, cx, line) {\n if (line.next != 62 /* '>' */ ) return false;\n line.markers.push(elt(Type.QuoteMark, cx.lineStart + line.pos, cx.lineStart + line.pos + 1));\n line.moveBase(line.pos + (space(line.text.charCodeAt(line.pos + 1)) ? 2 : 1));\n bl.end = cx.lineStart + line.text.length;\n return true;\n },\n [Type.ListItem] (bl, _cx, line) {\n if (line.indent < line.baseIndent + bl.value && line.next > -1) return false;\n line.moveBaseColumn(line.baseIndent + bl.value);\n return true;\n },\n [Type.OrderedList]: skipForList,\n [Type.BulletList]: skipForList,\n [Type.Document] () {\n return true;\n }\n};\nfunction space(ch) {\n return ch == 32 || ch == 9 || ch == 10 || ch == 13;\n}\nfunction skipSpace(line, i4 = 0) {\n while(i4 < line.length && space(line.charCodeAt(i4)))i4++;\n return i4;\n}\nfunction skipSpaceBack(line, i5, to) {\n while(i5 > to && space(line.charCodeAt(i5 - 1)))i5--;\n return i5;\n}\nfunction isFencedCode(line) {\n if (line.next != 96 && line.next != 126 /* '`~' */ ) return -1;\n let pos = line.pos + 1;\n while(pos < line.text.length && line.text.charCodeAt(pos) == line.next)pos++;\n if (pos < line.pos + 3) return -1;\n if (line.next == 96) {\n for(let i6 = pos; i6 < line.text.length; i6++)if (line.text.charCodeAt(i6) == 96) return -1;\n }\n return pos;\n}\nfunction isBlockquote(line) {\n return line.next != 62 /* '>' */ ? -1 : line.text.charCodeAt(line.pos + 1) == 32 ? 2 : 1;\n}\nfunction isHorizontalRule(line, cx, breaking) {\n if (line.next != 42 && line.next != 45 && line.next != 95 /* '_-*' */ ) return -1;\n let count = 1;\n for(let pos = line.pos + 1; pos < line.text.length; pos++){\n let ch = line.text.charCodeAt(pos);\n if (ch == line.next) count++;\n else if (!space(ch)) return -1;\n }\n // Setext headers take precedence\n if (breaking && line.next == 45 && isSetextUnderline(line) > -1 && line.depth == cx.stack.length) return -1;\n return count < 3 ? -1 : 1;\n}\nfunction inList(cx, type) {\n for(let i7 = cx.stack.length - 1; i7 >= 0; i7--)if (cx.stack[i7].type == type) return true;\n return false;\n}\nfunction isBulletList(line, cx, breaking) {\n return (line.next == 45 || line.next == 43 || line.next == 42 /* '-+*' */ ) && (line.pos == line.text.length - 1 || space(line.text.charCodeAt(line.pos + 1))) && (!breaking || inList(cx, Type.BulletList) || line.skipSpace(line.pos + 2) < line.text.length) ? 1 : -1;\n}\nfunction isOrderedList(line, cx, breaking) {\n let pos = line.pos, next = line.next;\n for(;;){\n if (next >= 48 && next <= 57 /* '0-9' */ ) pos++;\n else break;\n if (pos == line.text.length) return -1;\n next = line.text.charCodeAt(pos);\n }\n if (pos == line.pos || pos > line.pos + 9 || next != 46 && next != 41 /* '.)' */ || pos < line.text.length - 1 && !space(line.text.charCodeAt(pos + 1)) || breaking && !inList(cx, Type.OrderedList) && (line.skipSpace(pos + 1) == line.text.length || pos > line.pos + 1 || line.next != 49 /* '1' */ )) return -1;\n return pos + 1 - line.pos;\n}\nfunction isAtxHeading(line) {\n if (line.next != 35 /* '#' */ ) return -1;\n let pos = line.pos + 1;\n while(pos < line.text.length && line.text.charCodeAt(pos) == 35)pos++;\n if (pos < line.text.length && line.text.charCodeAt(pos) != 32) return -1;\n let size = pos - line.pos;\n return size > 6 ? -1 : size;\n}\nfunction isSetextUnderline(line) {\n if (line.next != 45 && line.next != 61 /* '-=' */ || line.indent >= line.baseIndent + 4) return -1;\n let pos = line.pos + 1;\n while(pos < line.text.length && line.text.charCodeAt(pos) == line.next)pos++;\n let end = pos;\n while(pos < line.text.length && space(line.text.charCodeAt(pos)))pos++;\n return pos == line.text.length ? end : -1;\n}\nconst EmptyLine = /^[ \\t]*$/, CommentEnd = /-->/, ProcessingEnd = /\\?>/;\nconst HTMLBlockStyle = [\n [\n /^<(?:script|pre|style)(?:\\s|>|$)/i,\n /<\\/(?:script|pre|style)>/i\n ],\n [\n /^\\s*<\\!--/,\n CommentEnd\n ],\n [\n /^\\s*<\\?/,\n ProcessingEnd\n ],\n [\n /^\\s*<![A-Z]/,\n />/\n ],\n [\n /^\\s*<!\\[CDATA\\[/,\n /\\]\\]>/\n ],\n [\n /^\\s*<\\/?(?:address|article|aside|base|basefont|blockquote|body|caption|center|col|colgroup|dd|details|dialog|dir|div|dl|dt|fieldset|figcaption|figure|footer|form|frame|frameset|h1|h2|h3|h4|h5|h6|head|header|hr|html|iframe|legend|li|link|main|menu|menuitem|nav|noframes|ol|optgroup|option|p|param|section|source|summary|table|tbody|td|tfoot|th|thead|title|tr|track|ul)(?:\\s|\\/?>|$)/i,\n EmptyLine\n ],\n [\n /^\\s*(?:<\\/[a-z][\\w-]*\\s*>|<[a-z][\\w-]*(\\s+[a-z:_][\\w-.]*(?:\\s*=\\s*(?:[^\\s\"'=<>`]+|'[^']*'|\"[^\"]*\"))?)*\\s*>)\\s*$/i,\n EmptyLine\n ]\n];\nfunction isHTMLBlock(line, _cx, breaking) {\n if (line.next != 60 /* '<' */ ) return -1;\n let rest = line.text.slice(line.pos);\n for(let i8 = 0, e = HTMLBlockStyle.length - (breaking ? 1 : 0); i8 < e; i8++)if (HTMLBlockStyle[i8][0].test(rest)) return i8;\n return -1;\n}\nfunction getListIndent(line, pos) {\n let indentAfter = line.countIndent(pos, line.pos, line.indent);\n let indented = line.countIndent(line.skipSpace(pos), pos, indentAfter);\n return indented >= indentAfter + 5 ? indentAfter + 1 : indented;\n}\nfunction addCodeText(marks, from, to) {\n let last = marks.length - 1;\n if (last >= 0 && marks[last].to == from && marks[last].type == Type.CodeText) marks[last].to = to;\n else marks.push(elt(Type.CodeText, from, to));\n}\n// Rules for parsing blocks. A return value of false means the rule\n// doesn't apply here, true means it does. When true is returned and\n// `p.line` has been updated, the rule is assumed to have consumed a\n// leaf block. Otherwise, it is assumed to have opened a context.\nconst DefaultBlockParsers = {\n LinkReference: undefined,\n IndentedCode (cx, line) {\n let base = line.baseIndent + 4;\n if (line.indent < base) return false;\n let start = line.findColumn(base);\n let from = cx.lineStart + start, to = cx.lineStart + line.text.length;\n let marks = [], pendingMarks = [];\n addCodeText(marks, from, to);\n while(cx.nextLine() && line.depth >= cx.stack.length){\n if (line.pos == line.text.length) {\n addCodeText(pendingMarks, cx.lineStart - 1, cx.lineStart);\n for (let m of line.markers)pendingMarks.push(m);\n } else if (line.indent < base) break;\n else {\n if (pendingMarks.length) {\n for (let m of pendingMarks)if (m.type == Type.CodeText) addCodeText(marks, m.from, m.to);\n else marks.push(m);\n pendingMarks = [];\n }\n addCodeText(marks, cx.lineStart - 1, cx.lineStart);\n for (let m of line.markers)marks.push(m);\n to = cx.lineStart + line.text.length;\n let codeStart = cx.lineStart + line.findColumn(line.baseIndent + 4);\n if (codeStart < to) addCodeText(marks, codeStart, to);\n }\n }\n if (pendingMarks.length) {\n pendingMarks = pendingMarks.filter((m)=>m.type != Type.CodeText\n );\n if (pendingMarks.length) line.markers = pendingMarks.concat(line.markers);\n }\n cx.addNode(cx.buffer.writeElements(marks, -from).finish(Type.CodeBlock, to - from), from);\n return true;\n },\n FencedCode (cx, line) {\n let fenceEnd = isFencedCode(line);\n if (fenceEnd < 0) return false;\n let from = cx.lineStart + line.pos, ch = line.next, len = fenceEnd - line.pos;\n let infoFrom = line.skipSpace(fenceEnd), infoTo = skipSpaceBack(line.text, line.text.length, infoFrom);\n let marks = [\n elt(Type.CodeMark, from, from + len)\n ];\n if (infoFrom < infoTo) marks.push(elt(Type.CodeInfo, cx.lineStart + infoFrom, cx.lineStart + infoTo));\n for(let first = true; cx.nextLine() && line.depth >= cx.stack.length; first = false){\n let i9 = line.pos;\n if (line.indent - line.baseIndent < 4) while(i9 < line.text.length && line.text.charCodeAt(i9) == ch)i9++;\n if (i9 - line.pos >= len && line.skipSpace(i9) == line.text.length) {\n for (let m of line.markers)marks.push(m);\n marks.push(elt(Type.CodeMark, cx.lineStart + line.pos, cx.lineStart + i9));\n cx.nextLine();\n break;\n } else {\n if (!first) addCodeText(marks, cx.lineStart - 1, cx.lineStart);\n for (let m of line.markers)marks.push(m);\n let textStart = cx.lineStart + line.basePos, textEnd = cx.lineStart + line.text.length;\n if (textStart < textEnd) addCodeText(marks, textStart, textEnd);\n }\n }\n cx.addNode(cx.buffer.writeElements(marks, -from).finish(Type.FencedCode, cx.prevLineEnd() - from), from);\n return true;\n },\n Blockquote (cx, line) {\n let size = isBlockquote(line);\n if (size < 0) return false;\n cx.startContext(Type.Blockquote, line.pos);\n cx.addNode(Type.QuoteMark, cx.lineStart + line.pos, cx.lineStart + line.pos + 1);\n line.moveBase(line.pos + size);\n return null;\n },\n HorizontalRule (cx, line) {\n if (isHorizontalRule(line, cx, false) < 0) return false;\n let from = cx.lineStart + line.pos;\n cx.nextLine();\n cx.addNode(Type.HorizontalRule, from);\n return true;\n },\n BulletList (cx, line) {\n let size = isBulletList(line, cx, false);\n if (size < 0) return false;\n if (cx.block.type != Type.BulletList) cx.startContext(Type.BulletList, line.basePos, line.next);\n let newBase = getListIndent(line, line.pos + 1);\n cx.startContext(Type.ListItem, line.basePos, newBase - line.baseIndent);\n cx.addNode(Type.ListMark, cx.lineStart + line.pos, cx.lineStart + line.pos + size);\n line.moveBaseColumn(newBase);\n return null;\n },\n OrderedList (cx, line) {\n let size = isOrderedList(line, cx, false);\n if (size < 0) return false;\n if (cx.block.type != Type.OrderedList) cx.startContext(Type.OrderedList, line.basePos, line.text.charCodeAt(line.pos + size - 1));\n let newBase = getListIndent(line, line.pos + size);\n cx.startContext(Type.ListItem, line.basePos, newBase - line.baseIndent);\n cx.addNode(Type.ListMark, cx.lineStart + line.pos, cx.lineStart + line.pos + size);\n line.moveBaseColumn(newBase);\n return null;\n },\n ATXHeading (cx, line) {\n let size = isAtxHeading(line);\n if (size < 0) return false;\n let off = line.pos, from = cx.lineStart + off;\n let endOfSpace = skipSpaceBack(line.text, line.text.length, off), after = endOfSpace;\n while(after > off && line.text.charCodeAt(after - 1) == line.next)after--;\n if (after == endOfSpace || after == off || !space(line.text.charCodeAt(after - 1))) after = line.text.length;\n let buf = cx.buffer.write(Type.HeaderMark, 0, size).writeElements(cx.parser.parseInline(line.text.slice(off + size + 1, after), from + size + 1), -from);\n if (after < line.text.length) buf.write(Type.HeaderMark, after - off, endOfSpace - off);\n let node = buf.finish(Type.ATXHeading1 - 1 + size, line.text.length - off);\n cx.nextLine();\n cx.addNode(node, from);\n return true;\n },\n HTMLBlock (cx, line) {\n let type = isHTMLBlock(line, cx, false);\n if (type < 0) return false;\n let from = cx.lineStart + line.pos, end = HTMLBlockStyle[type][1];\n let marks = [], trailing = end != EmptyLine;\n while(!end.test(line.text) && cx.nextLine()){\n if (line.depth < cx.stack.length) {\n trailing = false;\n break;\n }\n for (let m of line.markers)marks.push(m);\n }\n if (trailing) cx.nextLine();\n let nodeType = end == CommentEnd ? Type.CommentBlock : end == ProcessingEnd ? Type.ProcessingInstructionBlock : Type.HTMLBlock;\n let to = cx.prevLineEnd();\n cx.addNode(cx.buffer.writeElements(marks, -from).finish(nodeType, to - from), from);\n return true;\n },\n SetextHeading: undefined // Specifies relative precedence for block-continue function\n};\n// This implements a state machine that incrementally parses link references. At each\n// next line, it looks ahead to see if the line continues the reference or not. If it\n// doesn't and a valid link is available ending before that line, it finishes that.\n// Similarly, on `finish` (when the leaf is terminated by external circumstances), it\n// creates a link reference if there's a valid reference up to the current point.\nclass LinkReferenceParser {\n constructor(leaf){\n this.stage = 0 /* Start */ ;\n this.elts = [];\n this.pos = 0;\n this.start = leaf.start;\n this.advance(leaf.content);\n }\n nextLine(cx, line, leaf) {\n if (this.stage == -1 /* Failed */ ) return false;\n let content = leaf.content + \"\\n\" + line.scrub();\n let finish = this.advance(content);\n if (finish > -1 && finish < content.length) return this.complete(cx, leaf, finish);\n return false;\n }\n finish(cx, leaf) {\n if ((this.stage == 2 /* Link */ || this.stage == 3 /* Title */ ) && skipSpace(leaf.content, this.pos) == leaf.content.length) return this.complete(cx, leaf, leaf.content.length);\n return false;\n }\n complete(cx, leaf, len) {\n cx.addLeafElement(leaf, elt(Type.LinkReference, this.start, this.start + len, this.elts));\n return true;\n }\n nextStage(elt2) {\n if (elt2) {\n this.pos = elt2.to - this.start;\n this.elts.push(elt2);\n this.stage++;\n return true;\n }\n if (elt2 === false) this.stage = -1 /* Failed */ ;\n return false;\n }\n advance(content) {\n for(;;){\n if (this.stage == -1 /* Failed */ ) return -1;\n else if (this.stage == 0 /* Start */ ) {\n if (!this.nextStage(parseLinkLabel(content, this.pos, this.start, true))) return -1;\n if (content.charCodeAt(this.pos) != 58 /* ':' */ ) return this.stage = -1 /* Failed */ ;\n this.elts.push(elt(Type.LinkMark, this.pos + this.start, this.pos + this.start + 1));\n this.pos++;\n } else if (this.stage == 1 /* Label */ ) {\n if (!this.nextStage(parseURL(content, skipSpace(content, this.pos), this.start))) return -1;\n } else if (this.stage == 2 /* Link */ ) {\n let skip = skipSpace(content, this.pos), end = 0;\n if (skip > this.pos) {\n let title = parseLinkTitle(content, skip, this.start);\n if (title) {\n let titleEnd = lineEnd(content, title.to - this.start);\n if (titleEnd > 0) {\n this.nextStage(title);\n end = titleEnd;\n }\n }\n }\n if (!end) end = lineEnd(content, this.pos);\n return end > 0 && end < content.length ? end : -1;\n } else return lineEnd(content, this.pos);\n }\n }\n}\nfunction lineEnd(text, pos) {\n for(; pos < text.length; pos++){\n let next = text.charCodeAt(pos);\n if (next == 10) break;\n if (!space(next)) return -1;\n }\n return pos;\n}\nclass SetextHeadingParser {\n nextLine(cx, line, leaf) {\n let underline = line.depth < cx.stack.length ? -1 : isSetextUnderline(line);\n let next = line.next;\n if (underline < 0) return false;\n let underlineMark = elt(Type.HeaderMark, cx.lineStart + line.pos, cx.lineStart + underline);\n cx.nextLine();\n cx.addLeafElement(leaf, elt(next == 61 ? Type.SetextHeading1 : Type.SetextHeading2, leaf.start, cx.prevLineEnd(), [\n ...cx.parser.parseInline(leaf.content, leaf.start),\n underlineMark\n ]));\n return true;\n }\n finish() {\n return false;\n }\n}\nconst DefaultLeafBlocks = {\n LinkReference (_, leaf) {\n return leaf.content.charCodeAt(0) == 91 /* '[' */ ? new LinkReferenceParser(leaf) : null;\n },\n SetextHeading () {\n return new SetextHeadingParser;\n }\n};\nconst DefaultEndLeaf = [\n (_, line)=>isAtxHeading(line) >= 0\n ,\n (_, line)=>isFencedCode(line) >= 0\n ,\n (_, line)=>isBlockquote(line) >= 0\n ,\n (p, line)=>isBulletList(line, p, true) >= 0\n ,\n (p, line)=>isOrderedList(line, p, true) >= 0\n ,\n (p, line)=>isHorizontalRule(line, p, true) >= 0\n ,\n (p, line)=>isHTMLBlock(line, p, true) >= 0\n];\n/// Block-level parsing functions get access to this context object.\nclass BlockContext {\n /// @internal\n constructor(/// The parser configuration used.\n parser1, /// @internal\n input, fragments, /// @internal\n ranges){\n this.parser = parser1;\n this.input = input;\n this.ranges = ranges;\n this.line = new Line();\n this.atEnd = false;\n /// @internal\n this.dontInject = new Set;\n this.stoppedAt = null;\n /// The range index that absoluteLineStart points into @internal\n this.rangeI = 0;\n this.to = ranges[ranges.length - 1].to;\n this.lineStart = this.absoluteLineStart = this.absoluteLineEnd = ranges[0].from;\n this.block = CompositeBlock.create(Type.Document, 0, this.lineStart, 0, 0);\n this.stack = [\n this.block\n ];\n this.fragments = fragments.length ? new FragmentCursor(fragments, input) : null;\n this.readLine();\n }\n get parsedPos() {\n return this.absoluteLineStart;\n }\n advance() {\n if (this.stoppedAt != null && this.absoluteLineStart > this.stoppedAt) return this.finish();\n let { line } = this;\n for(;;){\n while(line.depth < this.stack.length)this.finishContext();\n for (let mark of line.markers)this.addNode(mark.type, mark.from, mark.to);\n if (line.pos < line.text.length) break;\n // Empty line\n if (!this.nextLine()) return this.finish();\n }\n if (this.fragments && this.reuseFragment(line.basePos)) return null;\n start: for(;;){\n for (let type of this.parser.blockParsers)if (type) {\n let result = type(this, line);\n if (result != false) {\n if (result == true) return null;\n line.forward();\n continue start;\n }\n }\n break;\n }\n let leaf = new LeafBlock(this.lineStart + line.pos, line.text.slice(line.pos));\n for (let parse of this.parser.leafBlockParsers)if (parse) {\n let parser2 = parse(this, leaf);\n if (parser2) leaf.parsers.push(parser2);\n }\n lines: while(this.nextLine()){\n if (line.pos == line.text.length) break;\n if (line.indent < line.baseIndent + 4) {\n for (let stop of this.parser.endLeafBlock)if (stop(this, line)) break lines;\n }\n for (let parser3 of leaf.parsers)if (parser3.nextLine(this, line, leaf)) return null;\n leaf.content += \"\\n\" + line.scrub();\n for (let m of line.markers)leaf.marks.push(m);\n }\n this.finishLeaf(leaf);\n return null;\n }\n stopAt(pos) {\n if (this.stoppedAt != null && this.stoppedAt < pos) throw new RangeError(\"Can't move stoppedAt forward\");\n this.stoppedAt = pos;\n }\n reuseFragment(start) {\n if (!this.fragments.moveTo(this.absoluteLineStart + start, this.absoluteLineStart) || !this.fragments.matches(this.block.hash)) return false;\n let taken = this.fragments.takeNodes(this);\n if (!taken) return false;\n let withoutGaps = taken, end = this.absoluteLineStart + taken;\n for(let i10 = 1; i10 < this.ranges.length; i10++){\n let gapFrom = this.ranges[i10 - 1].to, gapTo = this.ranges[i10].from;\n if (gapFrom >= this.lineStart && gapTo < end) withoutGaps -= gapTo - gapFrom;\n }\n this.lineStart += withoutGaps;\n this.absoluteLineStart += taken;\n this.moveRangeI();\n if (this.absoluteLineStart < this.to) {\n this.lineStart++;\n this.absoluteLineStart++;\n this.readLine();\n } else {\n this.atEnd = true;\n this.readLine();\n }\n return true;\n }\n /// Move to the next input line. This should only be called by\n /// (non-composite) [block parsers](#BlockParser.parse) that consume\n /// the line directly, or leaf block parser\n /// [`nextLine`](#LeafBlockParser.nextLine) methods when they\n /// consume the current line (and return true).\n nextLine() {\n this.lineStart += this.line.text.length;\n if (this.absoluteLineEnd >= this.to) {\n this.absoluteLineStart = this.absoluteLineEnd;\n this.atEnd = true;\n this.readLine();\n return false;\n } else {\n this.lineStart++;\n this.absoluteLineStart = this.absoluteLineEnd + 1;\n this.moveRangeI();\n this.readLine();\n return true;\n }\n }\n moveRangeI() {\n while(this.rangeI < this.ranges.length - 1 && this.absoluteLineStart >= this.ranges[this.rangeI].to)this.rangeI++;\n }\n /// @internal\n readLine() {\n let { line } = this, text, end = this.absoluteLineStart;\n if (this.atEnd) text = \"\";\n else {\n text = this.lineChunkAt(end);\n end += text.length;\n if (this.ranges.length > 1) {\n let textOffset = this.absoluteLineStart, rangeI = this.rangeI;\n while(this.ranges[rangeI].to < end){\n rangeI++;\n let nextFrom = this.ranges[rangeI].from;\n let after = this.lineChunkAt(nextFrom);\n end = nextFrom + after.length;\n text = text.slice(0, this.ranges[rangeI - 1].to - textOffset) + after;\n textOffset = end - text.length;\n }\n }\n }\n this.absoluteLineEnd = end;\n line.reset(text);\n for(; line.depth < this.stack.length; line.depth++){\n let cx = this.stack[line.depth], handler = this.parser.skipContextMarkup[cx.type];\n if (!handler) throw new Error(\"Unhandled block context \" + Type[cx.type]);\n if (!handler(cx, this, line)) break;\n line.forward();\n }\n }\n lineChunkAt(pos) {\n let next = this.input.chunk(pos), text;\n if (!this.input.lineChunks) {\n let eol = next.indexOf(\"\\n\");\n text = eol < 0 ? next : next.slice(0, eol);\n } else text = next == \"\\n\" ? \"\" : next;\n return pos + text.length > this.to ? text.slice(0, this.to - pos) : text;\n }\n /// The end position of the previous line.\n prevLineEnd() {\n return this.atEnd ? this.lineStart : this.lineStart - 1;\n }\n /// @internal\n startContext(type, start, value = 0) {\n this.block = CompositeBlock.create(type, value, this.lineStart + start, this.block.hash, this.lineStart + this.line.text.length);\n this.stack.push(this.block);\n }\n /// Start a composite block. Should only be called from [block\n /// parser functions](#BlockParser.parse) that return null.\n startComposite(type, start, value = 0) {\n this.startContext(this.parser.getNodeType(type), start, value);\n }\n /// @internal\n addNode(block, from, to) {\n if (typeof block == \"number\") block = new _common.Tree(this.parser.nodeSet.types[block], none, none, (to !== null && to !== void 0 ? to : this.prevLineEnd()) - from);\n this.block.addChild(block, from - this.block.from);\n }\n /// Add a block element. Can be called by [block\n /// parsers](#BlockParser.parse).\n addElement(elt3) {\n this.block.addChild(elt3.toTree(this.parser.nodeSet), elt3.from - this.block.from);\n }\n /// Add a block element from a [leaf parser](#LeafBlockParser). This\n /// makes sure any extra composite block markup (such as blockquote\n /// markers) inside the block are also added to the syntax tree.\n addLeafElement(leaf, elt4) {\n this.addNode(this.buffer.writeElements(injectMarks(elt4.children, leaf.marks), -elt4.from).finish(elt4.type, elt4.to - elt4.from), elt4.from);\n }\n /// @internal\n finishContext() {\n let cx = this.stack.pop();\n let top = this.stack[this.stack.length - 1];\n top.addChild(cx.toTree(this.parser.nodeSet), cx.from - top.from);\n this.block = top;\n }\n finish() {\n while(this.stack.length > 1)this.finishContext();\n return this.addGaps(this.block.toTree(this.parser.nodeSet, this.lineStart));\n }\n addGaps(tree) {\n return this.ranges.length > 1 ? injectGaps(this.ranges, 0, tree.topNode, this.ranges[0].from, this.dontInject) : tree;\n }\n /// @internal\n finishLeaf(leaf) {\n for (let parser4 of leaf.parsers)if (parser4.finish(this, leaf)) return;\n let inline = injectMarks(this.parser.parseInline(leaf.content, leaf.start), leaf.marks);\n this.addNode(this.buffer.writeElements(inline, -leaf.start).finish(Type.Paragraph, leaf.content.length), leaf.start);\n }\n elt(type, from, to, children) {\n if (typeof type == \"string\") return elt(this.parser.getNodeType(type), from, to, children);\n return new TreeElement(type, from);\n }\n /// @internal\n get buffer() {\n return new Buffer(this.parser.nodeSet);\n }\n}\nfunction injectGaps(ranges, rangeI, tree, offset, dont) {\n if (dont.has(tree.tree)) return tree.tree;\n let rangeEnd = ranges[rangeI].to;\n let children = [], positions = [], start = tree.from + offset;\n function movePastNext(upto, inclusive) {\n while(inclusive ? upto >= rangeEnd : upto > rangeEnd){\n let size = ranges[rangeI + 1].from - rangeEnd;\n offset += size;\n upto += size;\n rangeI++;\n rangeEnd = ranges[rangeI].to;\n }\n }\n for(let ch = tree.firstChild; ch; ch = ch.nextSibling){\n movePastNext(ch.from + offset, true);\n let from = ch.from + offset, node;\n if (ch.to + offset > rangeEnd) {\n node = injectGaps(ranges, rangeI, ch, offset, dont);\n movePastNext(ch.to + offset, false);\n } else node = ch.toTree();\n children.push(node);\n positions.push(from - start);\n }\n movePastNext(tree.to + offset, false);\n return new _common.Tree(tree.type, children, positions, tree.to + offset - start, tree.tree ? tree.tree.propValues : undefined);\n}\n/// A Markdown parser configuration.\nclass MarkdownParser extends _common.Parser {\n /// @internal\n constructor(/// The parser's syntax [node\n /// types](https://lezer.codemirror.net/docs/ref/#common.NodeSet).\n nodeSet, /// @internal\n blockParsers, /// @internal\n leafBlockParsers, /// @internal\n blockNames, /// @internal\n endLeafBlock, /// @internal\n skipContextMarkup, /// @internal\n inlineParsers, /// @internal\n inlineNames, /// @internal\n wrappers){\n super();\n this.nodeSet = nodeSet;\n this.blockParsers = blockParsers;\n this.leafBlockParsers = leafBlockParsers;\n this.blockNames = blockNames;\n this.endLeafBlock = endLeafBlock;\n this.skipContextMarkup = skipContextMarkup;\n this.inlineParsers = inlineParsers;\n this.inlineNames = inlineNames;\n this.wrappers = wrappers;\n /// @internal\n this.nodeTypes = Object.create(null);\n for (let t of nodeSet.types)this.nodeTypes[t.name] = t.id;\n }\n createParse(input, fragments, ranges) {\n let parse = new BlockContext(this, input, fragments, ranges);\n for (let w of this.wrappers)parse = w(parse, input, fragments, ranges);\n return parse;\n }\n /// Reconfigure the parser.\n configure(spec) {\n let config = resolveConfig(spec);\n if (!config) return this;\n let { nodeSet , skipContextMarkup } = this;\n let blockParsers = this.blockParsers.slice(), leafBlockParsers = this.leafBlockParsers.slice(), blockNames = this.blockNames.slice(), inlineParsers = this.inlineParsers.slice(), inlineNames = this.inlineNames.slice(), endLeafBlock = this.endLeafBlock.slice(), wrappers = this.wrappers;\n if (nonEmpty(config.defineNodes)) {\n skipContextMarkup = Object.assign({\n }, skipContextMarkup);\n let nodeTypes1 = nodeSet.types.slice();\n for (let s of config.defineNodes){\n let { name: name1 , block , composite } = typeof s == \"string\" ? {\n name: s\n } : s;\n if (nodeTypes1.some((t)=>t.name == name1\n )) continue;\n if (composite) skipContextMarkup[nodeTypes1.length] = (bl, cx, line)=>composite(cx, line, bl.value)\n ;\n let id = nodeTypes1.length;\n let group = composite ? [\n \"Block\",\n \"BlockContext\"\n ] : !block ? undefined : id >= Type.ATXHeading1 && id <= Type.SetextHeading2 ? [\n \"Block\",\n \"LeafBlock\",\n \"Heading\"\n ] : [\n \"Block\",\n \"LeafBlock\"\n ];\n nodeTypes1.push(_common.NodeType.define({\n id,\n name: name1,\n props: group && [\n [\n _common.NodeProp.group,\n group\n ]\n ]\n }));\n }\n nodeSet = new _common.NodeSet(nodeTypes1);\n }\n if (nonEmpty(config.props)) nodeSet = nodeSet.extend(...config.props);\n if (nonEmpty(config.remove)) for (let rm of config.remove){\n let block = this.blockNames.indexOf(rm), inline = this.inlineNames.indexOf(rm);\n if (block > -1) blockParsers[block] = leafBlockParsers[block] = undefined;\n if (inline > -1) inlineParsers[inline] = undefined;\n }\n if (nonEmpty(config.parseBlock)) for (let spec1 of config.parseBlock){\n let found = blockNames.indexOf(spec1.name);\n if (found > -1) {\n blockParsers[found] = spec1.parse;\n leafBlockParsers[found] = spec1.leaf;\n } else {\n let pos = spec1.before ? findName(blockNames, spec1.before) : spec1.after ? findName(blockNames, spec1.after) + 1 : blockNames.length - 1;\n blockParsers.splice(pos, 0, spec1.parse);\n leafBlockParsers.splice(pos, 0, spec1.leaf);\n blockNames.splice(pos, 0, spec1.name);\n }\n if (spec1.endLeaf) endLeafBlock.push(spec1.endLeaf);\n }\n if (nonEmpty(config.parseInline)) for (let spec2 of config.parseInline){\n let found = inlineNames.indexOf(spec2.name);\n if (found > -1) inlineParsers[found] = spec2.parse;\n else {\n let pos = spec2.before ? findName(inlineNames, spec2.before) : spec2.after ? findName(inlineNames, spec2.after) + 1 : inlineNames.length - 1;\n inlineParsers.splice(pos, 0, spec2.parse);\n inlineNames.splice(pos, 0, spec2.name);\n }\n }\n if (config.wrap) wrappers = wrappers.concat(config.wrap);\n return new MarkdownParser(nodeSet, blockParsers, leafBlockParsers, blockNames, endLeafBlock, skipContextMarkup, inlineParsers, inlineNames, wrappers);\n }\n /// @internal\n getNodeType(name2) {\n let found = this.nodeTypes[name2];\n if (found == null) throw new RangeError(`Unknown node type '${name2}'`);\n return found;\n }\n /// Parse the given piece of inline text at the given offset,\n /// returning an array of [`Element`](#Element) objects representing\n /// the inline content.\n parseInline(text, offset) {\n let cx = new InlineContext(this, text, offset);\n outer: for(let pos = offset; pos < cx.end;){\n let next = cx.char(pos);\n for (let token of this.inlineParsers)if (token) {\n let result = token(cx, next, pos);\n if (result >= 0) {\n pos = result;\n continue outer;\n }\n }\n pos++;\n }\n return cx.resolveMarkers(0);\n }\n}\nfunction nonEmpty(a) {\n return a != null && a.length > 0;\n}\nfunction resolveConfig(spec) {\n if (!Array.isArray(spec)) return spec;\n if (spec.length == 0) return null;\n let conf = resolveConfig(spec[0]);\n if (spec.length == 1) return conf;\n let rest = resolveConfig(spec.slice(1));\n if (!rest || !conf) return conf || rest;\n let conc = (a, b)=>(a || none).concat(b || none)\n ;\n let wrapA = conf.wrap, wrapB = rest.wrap;\n return {\n props: conc(conf.props, rest.props),\n defineNodes: conc(conf.defineNodes, rest.defineNodes),\n parseBlock: conc(conf.parseBlock, rest.parseBlock),\n parseInline: conc(conf.parseInline, rest.parseInline),\n remove: conc(conf.remove, rest.remove),\n wrap: !wrapA ? wrapB : !wrapB ? wrapA : (inner, input, fragments, ranges)=>wrapA(wrapB(inner, input, fragments, ranges), input, fragments, ranges)\n };\n}\nfunction findName(names, name3) {\n let found = names.indexOf(name3);\n if (found < 0) throw new RangeError(`Position specified relative to unknown parser ${name3}`);\n return found;\n}\nlet nodeTypes = [\n _common.NodeType.none\n];\nfor(let i = 1, name; name = Type[i]; i++)nodeTypes[i] = _common.NodeType.define({\n id: i,\n name,\n props: i >= Type.Escape ? [] : [\n [\n _common.NodeProp.group,\n i in DefaultSkipMarkup ? [\n \"Block\",\n \"BlockContext\"\n ] : [\n \"Block\",\n \"LeafBlock\"\n ]\n ]\n ]\n});\nconst none = [];\nclass Buffer {\n constructor(nodeSet){\n this.nodeSet = nodeSet;\n this.content = [];\n this.nodes = [];\n }\n write(type, from, to, children = 0) {\n this.content.push(type, from, to, 4 + children * 4);\n return this;\n }\n writeElements(elts, offset = 0) {\n for (let e of elts)e.writeTo(this, offset);\n return this;\n }\n finish(type, length) {\n return _common.Tree.build({\n buffer: this.content,\n nodeSet: this.nodeSet,\n reused: this.nodes,\n topID: type,\n length\n });\n }\n}\n/// Elements are used to compose syntax nodes during parsing.\nclass Element {\n /// @internal\n constructor(/// The node's\n /// [id](https://lezer.codemirror.net/docs/ref/#common.NodeType.id).\n type, /// The start of the node, as an offset from the start of the document.\n from, /// The end of the node.\n to, /// The node's child nodes @internal\n children = none){\n this.type = type;\n this.from = from;\n this.to = to;\n this.children = children;\n }\n /// @internal\n writeTo(buf, offset) {\n let startOff = buf.content.length;\n buf.writeElements(this.children, offset);\n buf.content.push(this.type, this.from + offset, this.to + offset, buf.content.length + 4 - startOff);\n }\n /// @internal\n toTree(nodeSet) {\n return new Buffer(nodeSet).writeElements(this.children, -this.from).finish(this.type, this.to - this.from);\n }\n}\nclass TreeElement {\n constructor(tree, from){\n this.tree = tree;\n this.from = from;\n }\n get to() {\n return this.from + this.tree.length;\n }\n get type() {\n return this.tree.type.id;\n }\n get children() {\n return none;\n }\n writeTo(buf, offset) {\n buf.nodes.push(this.tree);\n buf.content.push(buf.nodes.length - 1, this.from + offset, this.to + offset, -1);\n }\n toTree() {\n return this.tree;\n }\n}\nfunction elt(type, from, to, children) {\n return new Element(type, from, to, children);\n}\nconst EmphasisUnderscore = {\n resolve: \"Emphasis\",\n mark: \"EmphasisMark\"\n};\nconst EmphasisAsterisk = {\n resolve: \"Emphasis\",\n mark: \"EmphasisMark\"\n};\nconst LinkStart = {\n}, ImageStart = {\n};\nclass InlineDelimiter {\n constructor(type, from, to, side){\n this.type = type;\n this.from = from;\n this.to = to;\n this.side = side;\n }\n}\nconst Escapable = \"!\\\"#$%&'()*+,-./:;<=>?@[\\\\]^_`{|}~\";\nlet Punctuation = /[!\"#$%&'()*+,\\-.\\/:;<=>?@\\[\\\\\\]^_`{|}~\\xA1\\u2010-\\u2027]/;\ntry {\n Punctuation = new RegExp(\"[\\\\p{Pc}|\\\\p{Pd}|\\\\p{Pe}|\\\\p{Pf}|\\\\p{Pi}|\\\\p{Po}|\\\\p{Ps}]\", \"u\");\n} catch (_) {\n}\nconst DefaultInline = {\n Escape (cx, next, start) {\n if (next != 92 /* '\\\\' */ || start == cx.end - 1) return -1;\n let escaped = cx.char(start + 1);\n for(let i11 = 0; i11 < Escapable.length; i11++)if (Escapable.charCodeAt(i11) == escaped) return cx.append(elt(Type.Escape, start, start + 2));\n return -1;\n },\n Entity (cx, next, start) {\n if (next != 38 /* '&' */ ) return -1;\n let m = /^(?:#\\d+|#x[a-f\\d]+|\\w+);/i.exec(cx.slice(start + 1, start + 31));\n return m ? cx.append(elt(Type.Entity, start, start + 1 + m[0].length)) : -1;\n },\n InlineCode (cx, next, start) {\n if (next != 96 /* '`' */ || start && cx.char(start - 1) == 96) return -1;\n let pos = start + 1;\n while(pos < cx.end && cx.char(pos) == 96)pos++;\n let size = pos - start, curSize = 0;\n for(; pos < cx.end; pos++)if (cx.char(pos) == 96) {\n curSize++;\n if (curSize == size && cx.char(pos + 1) != 96) return cx.append(elt(Type.InlineCode, start, pos + 1, [\n elt(Type.CodeMark, start, start + size),\n elt(Type.CodeMark, pos + 1 - size, pos + 1)\n ]));\n } else curSize = 0;\n return -1;\n },\n HTMLTag (cx, next, start) {\n if (next != 60 /* '<' */ || start == cx.end - 1) return -1;\n let after = cx.slice(start + 1, cx.end);\n let url = /^(?:[a-z][-\\w+.]+:[^\\s>]+|[a-z\\d.!#$%&'*+/=?^_`{|}~-]+@[a-z\\d](?:[a-z\\d-]{0,61}[a-z\\d])?(?:\\.[a-z\\d](?:[a-z\\d-]{0,61}[a-z\\d])?)*)>/i.exec(after);\n if (url) return cx.append(elt(Type.URL, start, start + 1 + url[0].length));\n let comment = /^!--[^>](?:-[^-]|[^-])*?-->/i.exec(after);\n if (comment) return cx.append(elt(Type.Comment, start, start + 1 + comment[0].length));\n let procInst = /^\\?[^]*?\\?>/.exec(after);\n if (procInst) return cx.append(elt(Type.ProcessingInstruction, start, start + 1 + procInst[0].length));\n let m = /^(?:![A-Z][^]*?>|!\\[CDATA\\[[^]*?\\]\\]>|\\/\\s*[a-zA-Z][\\w-]*\\s*>|\\s*[a-zA-Z][\\w-]*(\\s+[a-zA-Z:_][\\w-.:]*(?:\\s*=\\s*(?:[^\\s\"'=<>`]+|'[^']*'|\"[^\"]*\"))?)*\\s*(\\/\\s*)?>)/.exec(after);\n if (!m) return -1;\n return cx.append(elt(Type.HTMLTag, start, start + 1 + m[0].length));\n },\n Emphasis (cx, next, start) {\n if (next != 95 && next != 42) return -1;\n let pos = start + 1;\n while(cx.char(pos) == next)pos++;\n let before = cx.slice(start - 1, start), after = cx.slice(pos, pos + 1);\n let pBefore = Punctuation.test(before), pAfter = Punctuation.test(after);\n let sBefore = /\\s|^$/.test(before), sAfter = /\\s|^$/.test(after);\n let leftFlanking = !sAfter && (!pAfter || sBefore || pBefore);\n let rightFlanking = !sBefore && (!pBefore || sAfter || pAfter);\n let canOpen = leftFlanking && (next == 42 || !rightFlanking || pBefore);\n let canClose = rightFlanking && (next == 42 || !leftFlanking || pAfter);\n return cx.append(new InlineDelimiter(next == 95 ? EmphasisUnderscore : EmphasisAsterisk, start, pos, (canOpen ? 1 /* Open */ : 0) | (canClose ? 2 /* Close */ : 0)));\n },\n HardBreak (cx, next, start) {\n if (next == 92 /* '\\\\' */ && cx.char(start + 1) == 10 /* '\\n' */ ) return cx.append(elt(Type.HardBreak, start, start + 2));\n if (next == 32) {\n let pos = start + 1;\n while(cx.char(pos) == 32)pos++;\n if (cx.char(pos) == 10 && pos >= start + 2) return cx.append(elt(Type.HardBreak, start, pos + 1));\n }\n return -1;\n },\n Link (cx, next, start) {\n return next == 91 /* '[' */ ? cx.append(new InlineDelimiter(LinkStart, start, start + 1, 1 /* Open */ )) : -1;\n },\n Image (cx, next, start) {\n return next == 33 /* '!' */ && cx.char(start + 1) == 91 /* '[' */ ? cx.append(new InlineDelimiter(ImageStart, start, start + 2, 1 /* Open */ )) : -1;\n },\n LinkEnd (cx, next, start) {\n if (next != 93 /* ']' */ ) return -1;\n // Scanning back to the next link/image start marker\n for(let i12 = cx.parts.length - 1; i12 >= 0; i12--){\n let part = cx.parts[i12];\n if (part instanceof InlineDelimiter && (part.type == LinkStart || part.type == ImageStart)) {\n // If this one has been set invalid (because it would produce\n // a nested link) or there's no valid link here ignore both.\n if (!part.side || cx.skipSpace(part.to) == start && !/[(\\[]/.test(cx.slice(start + 1, start + 2))) {\n cx.parts[i12] = null;\n return -1;\n }\n // Finish the content and replace the entire range in\n // this.parts with the link/image node.\n let content = cx.takeContent(i12);\n let link = cx.parts[i12] = finishLink(cx, content, part.type == LinkStart ? Type.Link : Type.Image, part.from, start + 1);\n // Set any open-link markers before this link to invalid.\n if (part.type == LinkStart) for(let j = 0; j < i12; j++){\n let p = cx.parts[j];\n if (p instanceof InlineDelimiter && p.type == LinkStart) p.side = 0;\n }\n return link.to;\n }\n }\n return -1;\n }\n};\nfunction finishLink(cx, content, type, start, startPos) {\n let { text } = cx, next = cx.char(startPos), endPos = startPos;\n content.unshift(elt(Type.LinkMark, start, start + (type == Type.Image ? 2 : 1)));\n content.push(elt(Type.LinkMark, startPos - 1, startPos));\n if (next == 40 /* '(' */ ) {\n let pos = cx.skipSpace(startPos + 1);\n let dest = parseURL(text, pos - cx.offset, cx.offset), title;\n if (dest) {\n pos = cx.skipSpace(dest.to);\n title = parseLinkTitle(text, pos - cx.offset, cx.offset);\n if (title) pos = cx.skipSpace(title.to);\n }\n if (cx.char(pos) == 41 /* ')' */ ) {\n content.push(elt(Type.LinkMark, startPos, startPos + 1));\n endPos = pos + 1;\n if (dest) content.push(dest);\n if (title) content.push(title);\n content.push(elt(Type.LinkMark, pos, endPos));\n }\n } else if (next == 91 /* '[' */ ) {\n let label = parseLinkLabel(text, startPos - cx.offset, cx.offset, false);\n if (label) {\n content.push(label);\n endPos = label.to;\n }\n }\n return elt(type, start, endPos, content);\n}\n// These return `null` when falling off the end of the input, `false`\n// when parsing fails otherwise (for use in the incremental link\n// reference parser).\nfunction parseURL(text, start, offset) {\n let next = text.charCodeAt(start);\n if (next == 60 /* '<' */ ) {\n for(let pos = start + 1; pos < text.length; pos++){\n let ch = text.charCodeAt(pos);\n if (ch == 62 /* '>' */ ) return elt(Type.URL, start + offset, pos + 1 + offset);\n if (ch == 60 || ch == 10 /* '<\\n' */ ) return false;\n }\n return null;\n } else {\n let depth = 0, pos = start;\n for(let escaped = false; pos < text.length; pos++){\n let ch = text.charCodeAt(pos);\n if (space(ch)) break;\n else if (escaped) escaped = false;\n else if (ch == 40 /* '(' */ ) depth++;\n else if (ch == 41 /* ')' */ ) {\n if (!depth) break;\n depth--;\n } else if (ch == 92 /* '\\\\' */ ) escaped = true;\n }\n return pos > start ? elt(Type.URL, start + offset, pos + offset) : pos == text.length ? null : false;\n }\n}\nfunction parseLinkTitle(text, start, offset) {\n let next = text.charCodeAt(start);\n if (next != 39 && next != 34 && next != 40 /* '\"\\'(' */ ) return false;\n let end = next == 40 ? 41 : next;\n for(let pos = start + 1, escaped = false; pos < text.length; pos++){\n let ch = text.charCodeAt(pos);\n if (escaped) escaped = false;\n else if (ch == end) return elt(Type.LinkTitle, start + offset, pos + 1 + offset);\n else if (ch == 92 /* '\\\\' */ ) escaped = true;\n }\n return null;\n}\nfunction parseLinkLabel(text, start, offset, requireNonWS) {\n for(let escaped = false, pos = start + 1, end = Math.min(text.length, pos + 999); pos < end; pos++){\n let ch = text.charCodeAt(pos);\n if (escaped) escaped = false;\n else if (ch == 93 /* ']' */ ) return requireNonWS ? false : elt(Type.LinkLabel, start + offset, pos + 1 + offset);\n else {\n if (requireNonWS && !space(ch)) requireNonWS = false;\n if (ch == 91 /* '[' */ ) return false;\n else if (ch == 92 /* '\\\\' */ ) escaped = true;\n }\n }\n return null;\n}\n/// Inline parsing functions get access to this context, and use it to\n/// read the content and emit syntax nodes.\nclass InlineContext {\n /// @internal\n constructor(/// The parser that is being used.\n parser5, /// The text of this inline section.\n text, /// The starting offset of the section in the document.\n offset){\n this.parser = parser5;\n this.text = text;\n this.offset = offset;\n /// @internal\n this.parts = [];\n }\n /// Get the character code at the given (document-relative)\n /// position.\n char(pos) {\n return pos >= this.end ? -1 : this.text.charCodeAt(pos - this.offset);\n }\n /// The position of the end of this inline section.\n get end() {\n return this.offset + this.text.length;\n }\n /// Get a substring of this inline section. Again uses\n /// document-relative positions.\n slice(from, to) {\n return this.text.slice(from - this.offset, to - this.offset);\n }\n /// @internal\n append(elt5) {\n this.parts.push(elt5);\n return elt5.to;\n }\n /// Add a [delimiter](#DelimiterType) at this given position. `open`\n /// and `close` indicate whether this delimiter is opening, closing,\n /// or both. Returns the end of the delimiter, for convenient\n /// returning from [parse functions](#InlineParser.parse).\n addDelimiter(type, from, to, open, close) {\n return this.append(new InlineDelimiter(type, from, to, (open ? 1 /* Open */ : 0) | (close ? 2 /* Close */ : 0)));\n }\n /// Add an inline element. Returns the end of the element.\n addElement(elt6) {\n return this.append(elt6);\n }\n /// @internal\n resolveMarkers(from) {\n for(let i14 = from; i14 < this.parts.length; i14++){\n let close = this.parts[i14];\n if (!(close instanceof InlineDelimiter && close.type.resolve && close.side & 2 /* Close */ )) continue;\n let emp = close.type == EmphasisUnderscore || close.type == EmphasisAsterisk;\n let closeSize = close.to - close.from;\n let open, j = i14 - 1;\n for(; j >= from; j--){\n let part = this.parts[j];\n if (!(part instanceof InlineDelimiter && part.side & 1 /* Open */ && part.type == close.type) || emp && (close.side & 1 /* Open */ || part.side & 2 /* Close */ ) && (part.to - part.from + closeSize) % 3 == 0 && ((part.to - part.from) % 3 || closeSize % 3)) continue;\n open = part;\n break;\n }\n if (!open) continue;\n let type = close.type.resolve, content = [];\n let start = open.from, end = close.to;\n if (emp) {\n let size = Math.min(2, open.to - open.from, closeSize);\n start = open.to - size;\n end = close.from + size;\n type = size == 1 ? \"Emphasis\" : \"StrongEmphasis\";\n }\n if (open.type.mark) content.push(this.elt(open.type.mark, start, open.to));\n for(let k = j + 1; k < i14; k++){\n if (this.parts[k] instanceof Element) content.push(this.parts[k]);\n this.parts[k] = null;\n }\n if (close.type.mark) content.push(this.elt(close.type.mark, close.from, end));\n let element = this.elt(type, start, end, content);\n this.parts[j] = emp && open.from != start ? new InlineDelimiter(open.type, open.from, start, open.side) : null;\n let keep = this.parts[i14] = emp && close.to != end ? new InlineDelimiter(close.type, end, close.to, close.side) : null;\n if (keep) this.parts.splice(i14, 0, element);\n else this.parts[i14] = element;\n }\n let result = [];\n for(let i13 = from; i13 < this.parts.length; i13++){\n let part = this.parts[i13];\n if (part instanceof Element) result.push(part);\n }\n return result;\n }\n /// Find an opening delimiter of the given type. Returns `null` if\n /// no delimiter is found, or an index that can be passed to\n /// [`takeContent`](#InlineContext.takeContent) otherwise.\n findOpeningDelimiter(type) {\n for(let i15 = this.parts.length - 1; i15 >= 0; i15--){\n let part = this.parts[i15];\n if (part instanceof InlineDelimiter && part.type == type) return i15;\n }\n return null;\n }\n /// Remove all inline elements and delimiters starting from the\n /// given index (which you should get from\n /// [`findOpeningDelimiter`](#InlineContext.findOpeningDelimiter),\n /// resolve delimiters inside of them, and return them as an array\n /// of elements.\n takeContent(startIndex) {\n let content = this.resolveMarkers(startIndex);\n this.parts.length = startIndex;\n return content;\n }\n /// Skip space after the given (document) position, returning either\n /// the position of the next non-space character or the end of the\n /// section.\n skipSpace(from) {\n return skipSpace(this.text, from - this.offset) + this.offset;\n }\n elt(type, from, to, children) {\n if (typeof type == \"string\") return elt(this.parser.getNodeType(type), from, to, children);\n return new TreeElement(type, from);\n }\n}\nfunction injectMarks(elements, marks) {\n if (!marks.length) return elements;\n if (!elements.length) return marks;\n let elts = elements.slice(), eI = 0;\n for (let mark of marks){\n while(eI < elts.length && elts[eI].to < mark.to)eI++;\n if (eI < elts.length && elts[eI].from < mark.from) {\n let e = elts[eI];\n if (e instanceof Element) elts[eI] = new Element(e.type, e.from, e.to, injectMarks(e.children, [\n mark\n ]));\n } else elts.splice(eI++, 0, mark);\n }\n return elts;\n}\n// These are blocks that can span blank lines, and should thus only be\n// reused if their next sibling is also being reused.\nconst NotLast = [\n Type.CodeBlock,\n Type.ListItem,\n Type.OrderedList,\n Type.BulletList\n];\nclass FragmentCursor {\n constructor(fragments, input){\n this.fragments = fragments;\n this.input = input;\n // Index into fragment array\n this.i = 0;\n // Active fragment\n this.fragment = null;\n this.fragmentEnd = -1;\n // Cursor into the current fragment, if any. When `moveTo` returns\n // true, this points at the first block after `pos`.\n this.cursor = null;\n if (fragments.length) this.fragment = fragments[this.i++];\n }\n nextFragment() {\n this.fragment = this.i < this.fragments.length ? this.fragments[this.i++] : null;\n this.cursor = null;\n this.fragmentEnd = -1;\n }\n moveTo(pos, lineStart) {\n while(this.fragment && this.fragment.to <= pos)this.nextFragment();\n if (!this.fragment || this.fragment.from > (pos ? pos - 1 : 0)) return false;\n if (this.fragmentEnd < 0) {\n let end = this.fragment.to;\n while(end > 0 && this.input.read(end - 1, end) != \"\\n\")end--;\n this.fragmentEnd = end ? end - 1 : 0;\n }\n let c = this.cursor;\n if (!c) {\n c = this.cursor = this.fragment.tree.cursor();\n c.firstChild();\n }\n let rPos = pos + this.fragment.offset;\n while(c.to <= rPos)if (!c.parent()) return false;\n for(;;){\n if (c.from >= rPos) return this.fragment.from <= lineStart;\n if (!c.childAfter(rPos)) return false;\n }\n }\n matches(hash) {\n let tree = this.cursor.tree;\n return tree && tree.prop(_common.NodeProp.contextHash) == hash;\n }\n takeNodes(cx) {\n let cur = this.cursor, off = this.fragment.offset, fragEnd = this.fragmentEnd - (this.fragment.openEnd ? 1 : 0);\n let start = cx.absoluteLineStart, end = start, blockI = cx.block.children.length;\n let prevEnd = end, prevI = blockI;\n for(;;){\n if (cur.to - off > fragEnd) {\n if (cur.type.isAnonymous && cur.firstChild()) continue;\n break;\n }\n cx.dontInject.add(cur.tree);\n cx.addNode(cur.tree, cur.from - off);\n // Taken content must always end in a block, because incremental\n // parsing happens on block boundaries. Never stop directly\n // after an indented code block, since those can continue after\n // any number of blank lines.\n if (cur.type.is(\"Block\")) {\n if (NotLast.indexOf(cur.type.id) < 0) {\n end = cur.to - off;\n blockI = cx.block.children.length;\n } else {\n end = prevEnd;\n blockI = prevI;\n prevEnd = cur.to - off;\n prevI = cx.block.children.length;\n }\n }\n if (!cur.nextSibling()) break;\n }\n while(cx.block.children.length > blockI){\n cx.block.children.pop();\n cx.block.positions.pop();\n }\n return end - start;\n }\n}\n/// The default CommonMark parser.\nconst parser = new MarkdownParser(new _common.NodeSet(nodeTypes), Object.keys(DefaultBlockParsers).map((n)=>DefaultBlockParsers[n]\n), Object.keys(DefaultBlockParsers).map((n)=>DefaultLeafBlocks[n]\n), Object.keys(DefaultBlockParsers), DefaultEndLeaf, DefaultSkipMarkup, Object.keys(DefaultInline).map((n)=>DefaultInline[n]\n), Object.keys(DefaultInline), []);\nfunction leftOverSpace(node, from, to) {\n let ranges = [];\n for(let n = node.firstChild, pos = from;; n = n.nextSibling){\n let nextPos = n ? n.from : to;\n if (nextPos > pos) ranges.push({\n from: pos,\n to: nextPos\n });\n if (!n) break;\n pos = n.to;\n }\n return ranges;\n}\n/// Create a Markdown extension to enable nested parsing on code\n/// blocks and/or embedded HTML.\nfunction parseCode(config) {\n let { codeParser , htmlParser } = config;\n let wrap = _common.parseMixed((node1, input)=>{\n let id = node1.type.id;\n if (codeParser && (id == Type.CodeBlock || id == Type.FencedCode)) {\n let info = \"\";\n if (id == Type.FencedCode) {\n let infoNode = node1.node.getChild(Type.CodeInfo);\n if (infoNode) info = input.read(infoNode.from, infoNode.to);\n }\n let parser6 = codeParser(info);\n if (parser6) return {\n parser: parser6,\n overlay: (node)=>node.type.id == Type.CodeText\n };\n } else if (htmlParser && (id == Type.HTMLBlock || id == Type.HTMLTag)) return {\n parser: htmlParser,\n overlay: leftOverSpace(node1.node, node1.from, node1.to)\n };\n return null;\n });\n return {\n wrap\n };\n}\nconst StrikethroughDelim = {\n resolve: \"Strikethrough\",\n mark: \"StrikethroughMark\"\n};\n/// An extension that implements\n/// [GFM-style](https://github.github.com/gfm/#strikethrough-extension-)\n/// Strikethrough syntax using `~~` delimiters.\nconst Strikethrough = {\n defineNodes: [\n \"Strikethrough\",\n \"StrikethroughMark\"\n ],\n parseInline: [\n {\n name: \"Strikethrough\",\n parse (cx, next, pos) {\n if (next != 126 /* '~' */ || cx.char(pos + 1) != 126) return -1;\n return cx.addDelimiter(StrikethroughDelim, pos, pos + 2, true, true);\n },\n after: \"Emphasis\"\n }\n ]\n};\nfunction parseRow(cx, line, startI = 0, elts, offset = 0) {\n let count = 0, first = true, cellStart = -1, cellEnd = -1, esc = false;\n let parseCell = ()=>{\n elts.push(cx.elt(\"TableCell\", offset + cellStart, offset + cellEnd, cx.parser.parseInline(line.slice(cellStart, cellEnd), offset + cellStart)));\n };\n for(let i16 = startI; i16 < line.length; i16++){\n let next = line.charCodeAt(i16);\n if (next == 124 /* '|' */ && !esc) {\n if (!first || cellStart > -1) count++;\n first = false;\n if (elts) {\n if (cellStart > -1) parseCell();\n elts.push(cx.elt(\"TableDelimiter\", i16 + offset, i16 + offset + 1));\n }\n cellStart = cellEnd = -1;\n } else if (esc || next != 32 && next != 9) {\n if (cellStart < 0) cellStart = i16;\n cellEnd = i16 + 1;\n }\n esc = !esc && next == 92;\n }\n if (cellStart > -1) {\n count++;\n if (elts) parseCell();\n }\n return count;\n}\nfunction hasPipe(str, start) {\n for(let i17 = start; i17 < str.length; i17++){\n let next = str.charCodeAt(i17);\n if (next == 124 /* '|' */ ) return true;\n if (next == 92 /* '\\\\' */ ) i17++;\n }\n return false;\n}\nclass TableParser {\n constructor(){\n // Null means we haven't seen the second line yet, false means this\n // isn't a table, and an array means this is a table and we've\n // parsed the given rows so far.\n this.rows = null;\n }\n nextLine(cx, line, leaf) {\n if (this.rows == null) {\n this.rows = false;\n let lineText;\n if ((line.next == 45 || line.next == 58 || line.next == 124 /* '-:|' */ ) && /^\\|?(\\s*:?-+:?\\s*\\|)+(\\s*:?-+:?\\s*)?$/.test(lineText = line.text.slice(line.pos))) {\n let firstRow = [], firstCount = parseRow(cx, leaf.content, 0, firstRow, leaf.start);\n if (firstCount == parseRow(cx, lineText, line.pos)) this.rows = [\n cx.elt(\"TableHeader\", leaf.start, leaf.start + leaf.content.length, firstRow),\n cx.elt(\"TableDelimiter\", cx.lineStart + line.pos, cx.lineStart + line.text.length)\n ];\n }\n } else if (this.rows) {\n let content = [];\n parseRow(cx, line.text, line.pos, content, cx.lineStart);\n this.rows.push(cx.elt(\"TableRow\", cx.lineStart + line.pos, cx.lineStart + line.text.length, content));\n }\n return false;\n }\n finish(cx, leaf) {\n if (this.rows) {\n this.emit(cx, leaf);\n return true;\n }\n return false;\n }\n emit(cx, leaf) {\n cx.addLeafElement(leaf, cx.elt(\"Table\", leaf.start, leaf.start + leaf.content.length, this.rows));\n }\n}\n/// This extension provides\n/// [GFM-style](https://github.github.com/gfm/#tables-extension-)\n/// tables, using syntax like this:\n///\n/// ```\n/// | head 1 | head 2 |\n/// | --- | --- |\n/// | cell 1 | cell 2 |\n/// ```\nconst Table = {\n defineNodes: [\n {\n name: \"Table\",\n block: true\n },\n \"TableHeader\",\n \"TableRow\",\n \"TableCell\",\n \"TableDelimiter\"\n ],\n parseBlock: [\n {\n name: \"Table\",\n leaf (_, leaf) {\n return hasPipe(leaf.content, 0) ? new TableParser : null;\n },\n before: \"SetextHeading\"\n }\n ]\n};\nclass TaskParser {\n nextLine() {\n return false;\n }\n finish(cx, leaf) {\n cx.addLeafElement(leaf, cx.elt(\"Task\", leaf.start, leaf.start + leaf.content.length, [\n cx.elt(\"TaskMarker\", leaf.start, leaf.start + 3),\n ...cx.parser.parseInline(leaf.content.slice(3), leaf.start + 3)\n ]));\n return true;\n }\n}\n/// Extension providing\n/// [GFM-style](https://github.github.com/gfm/#task-list-items-extension-)\n/// task list items, where list items can be prefixed with `[ ]` or\n/// `[x]` to add a checkbox.\nconst TaskList = {\n defineNodes: [\n {\n name: \"Task\",\n block: true\n },\n \"TaskMarker\"\n ],\n parseBlock: [\n {\n name: \"TaskList\",\n leaf (cx, leaf) {\n return /^\\[[ xX]\\]/.test(leaf.content) && cx.parser.nodeSet.types[cx.block.type].name == \"ListItem\" ? new TaskParser : null;\n },\n after: \"SetextHeading\"\n }\n ]\n};\n/// Extension bundle containing [`Table`](#Table),\n/// [`TaskList`](#TaskList) and [`Strikethrough`](#Strikethrough).\nconst GFM = [\n Table,\n TaskList,\n Strikethrough\n];\nfunction parseSubSuper(ch, node, mark) {\n return (cx, next, pos)=>{\n if (next != ch || cx.char(pos + 1) == ch) return -1;\n let elts = [\n cx.elt(mark, pos, pos + 1)\n ];\n for(let i18 = pos + 1; i18 < cx.end; i18++){\n let next = cx.char(i18);\n if (next == ch) return cx.addElement(cx.elt(node, pos, i18 + 1, elts.concat(cx.elt(mark, i18, i18 + 1))));\n if (next == 92 /* '\\\\' */ ) elts.push(cx.elt(\"Escape\", i18, (i18++) + 2));\n if (space(next)) break;\n }\n return -1;\n };\n}\n/// Extension providing\n/// [Pandoc-style](https://pandoc.org/MANUAL.html#superscripts-and-subscripts)\n/// superscript using `^` markers.\nconst Superscript = {\n defineNodes: [\n \"Superscript\",\n \"SuperscriptMark\"\n ],\n parseInline: [\n {\n name: \"Superscript\",\n parse: parseSubSuper(94 /* '^' */ , \"Superscript\", \"SuperscriptMark\")\n }\n ]\n};\n/// Extension providing\n/// [Pandoc-style](https://pandoc.org/MANUAL.html#superscripts-and-subscripts)\n/// subscript using `~` markers.\nconst Subscript = {\n defineNodes: [\n \"Subscript\",\n \"SubscriptMark\"\n ],\n parseInline: [\n {\n name: \"Subscript\",\n parse: parseSubSuper(126 /* '~' */ , \"Subscript\", \"SubscriptMark\")\n }\n ]\n};\n/// Extension that parses two colons with only letters, underscores,\n/// and numbers between them as `Emoji` nodes.\nconst Emoji = {\n defineNodes: [\n \"Emoji\"\n ],\n parseInline: [\n {\n name: \"Emoji\",\n parse (cx, next, pos) {\n let match;\n if (next != 58 /* ':' */ || !(match = /^[a-zA-Z_0-9]+:/.exec(cx.slice(pos + 1, cx.end)))) return -1;\n return cx.addElement(cx.elt(\"Emoji\", pos, pos + 1 + match[0].length));\n }\n }\n ]\n};\n\n},{\"@lezer/common\":\"ds1Io\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"idzAC\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"autoCloseTags\", ()=>autoCloseTags\n);\nparcelHelpers.export(exports, \"html\", ()=>html\n);\nparcelHelpers.export(exports, \"htmlCompletion\", ()=>htmlCompletion\n);\nparcelHelpers.export(exports, \"htmlCompletionSource\", ()=>htmlCompletionSource\n);\nparcelHelpers.export(exports, \"htmlLanguage\", ()=>htmlLanguage\n);\nvar _html = require(\"@lezer/html\");\nvar _langCss = require(\"@codemirror/lang-css\");\nvar _langJavascript = require(\"@codemirror/lang-javascript\");\nvar _view = require(\"@codemirror/view\");\nvar _state = require(\"@codemirror/state\");\nvar _language = require(\"@codemirror/language\");\nvar _highlight = require(\"@codemirror/highlight\");\nconst Targets = [\n \"_blank\",\n \"_self\",\n \"_top\",\n \"_parent\"\n];\nconst Charsets = [\n \"ascii\",\n \"utf-8\",\n \"utf-16\",\n \"latin1\",\n \"latin1\"\n];\nconst Methods = [\n \"get\",\n \"post\",\n \"put\",\n \"delete\"\n];\nconst Encs = [\n \"application/x-www-form-urlencoded\",\n \"multipart/form-data\",\n \"text/plain\"\n];\nconst Bool = [\n \"true\",\n \"false\"\n];\nconst S = {\n}; // Empty tag spec\nconst Tags = {\n a: {\n attrs: {\n href: null,\n ping: null,\n type: null,\n media: null,\n target: Targets,\n hreflang: null\n }\n },\n abbr: S,\n acronym: S,\n address: S,\n applet: S,\n area: {\n attrs: {\n alt: null,\n coords: null,\n href: null,\n target: null,\n ping: null,\n media: null,\n hreflang: null,\n type: null,\n shape: [\n \"default\",\n \"rect\",\n \"circle\",\n \"poly\"\n ]\n }\n },\n article: S,\n aside: S,\n audio: {\n attrs: {\n src: null,\n mediagroup: null,\n crossorigin: [\n \"anonymous\",\n \"use-credentials\"\n ],\n preload: [\n \"none\",\n \"metadata\",\n \"auto\"\n ],\n autoplay: [\n \"autoplay\"\n ],\n loop: [\n \"loop\"\n ],\n controls: [\n \"controls\"\n ]\n }\n },\n b: S,\n base: {\n attrs: {\n href: null,\n target: Targets\n }\n },\n basefont: S,\n bdi: S,\n bdo: S,\n big: S,\n blockquote: {\n attrs: {\n cite: null\n }\n },\n body: S,\n br: S,\n button: {\n attrs: {\n form: null,\n formaction: null,\n name: null,\n value: null,\n autofocus: [\n \"autofocus\"\n ],\n disabled: [\n \"autofocus\"\n ],\n formenctype: Encs,\n formmethod: Methods,\n formnovalidate: [\n \"novalidate\"\n ],\n formtarget: Targets,\n type: [\n \"submit\",\n \"reset\",\n \"button\"\n ]\n }\n },\n canvas: {\n attrs: {\n width: null,\n height: null\n }\n },\n caption: S,\n center: S,\n cite: S,\n code: S,\n col: {\n attrs: {\n span: null\n }\n },\n colgroup: {\n attrs: {\n span: null\n }\n },\n command: {\n attrs: {\n type: [\n \"command\",\n \"checkbox\",\n \"radio\"\n ],\n label: null,\n icon: null,\n radiogroup: null,\n command: null,\n title: null,\n disabled: [\n \"disabled\"\n ],\n checked: [\n \"checked\"\n ]\n }\n },\n data: {\n attrs: {\n value: null\n }\n },\n datagrid: {\n attrs: {\n disabled: [\n \"disabled\"\n ],\n multiple: [\n \"multiple\"\n ]\n }\n },\n datalist: {\n attrs: {\n data: null\n }\n },\n dd: S,\n del: {\n attrs: {\n cite: null,\n datetime: null\n }\n },\n details: {\n attrs: {\n open: [\n \"open\"\n ]\n }\n },\n dfn: S,\n dir: S,\n div: S,\n dl: S,\n dt: S,\n em: S,\n embed: {\n attrs: {\n src: null,\n type: null,\n width: null,\n height: null\n }\n },\n eventsource: {\n attrs: {\n src: null\n }\n },\n fieldset: {\n attrs: {\n disabled: [\n \"disabled\"\n ],\n form: null,\n name: null\n }\n },\n figcaption: S,\n figure: S,\n font: S,\n footer: S,\n form: {\n attrs: {\n action: null,\n name: null,\n \"accept-charset\": Charsets,\n autocomplete: [\n \"on\",\n \"off\"\n ],\n enctype: Encs,\n method: Methods,\n novalidate: [\n \"novalidate\"\n ],\n target: Targets\n }\n },\n frame: S,\n frameset: S,\n h1: S,\n h2: S,\n h3: S,\n h4: S,\n h5: S,\n h6: S,\n head: {\n children: [\n \"title\",\n \"base\",\n \"link\",\n \"style\",\n \"meta\",\n \"script\",\n \"noscript\",\n \"command\"\n ]\n },\n header: S,\n hgroup: S,\n hr: S,\n html: {\n attrs: {\n manifest: null\n }\n },\n i: S,\n iframe: {\n attrs: {\n src: null,\n srcdoc: null,\n name: null,\n width: null,\n height: null,\n sandbox: [\n \"allow-top-navigation\",\n \"allow-same-origin\",\n \"allow-forms\",\n \"allow-scripts\"\n ],\n seamless: [\n \"seamless\"\n ]\n }\n },\n img: {\n attrs: {\n alt: null,\n src: null,\n ismap: null,\n usemap: null,\n width: null,\n height: null,\n crossorigin: [\n \"anonymous\",\n \"use-credentials\"\n ]\n }\n },\n input: {\n attrs: {\n alt: null,\n dirname: null,\n form: null,\n formaction: null,\n height: null,\n list: null,\n max: null,\n maxlength: null,\n min: null,\n name: null,\n pattern: null,\n placeholder: null,\n size: null,\n src: null,\n step: null,\n value: null,\n width: null,\n accept: [\n \"audio/*\",\n \"video/*\",\n \"image/*\"\n ],\n autocomplete: [\n \"on\",\n \"off\"\n ],\n autofocus: [\n \"autofocus\"\n ],\n checked: [\n \"checked\"\n ],\n disabled: [\n \"disabled\"\n ],\n formenctype: Encs,\n formmethod: Methods,\n formnovalidate: [\n \"novalidate\"\n ],\n formtarget: Targets,\n multiple: [\n \"multiple\"\n ],\n readonly: [\n \"readonly\"\n ],\n required: [\n \"required\"\n ],\n type: [\n \"hidden\",\n \"text\",\n \"search\",\n \"tel\",\n \"url\",\n \"email\",\n \"password\",\n \"datetime\",\n \"date\",\n \"month\",\n \"week\",\n \"time\",\n \"datetime-local\",\n \"number\",\n \"range\",\n \"color\",\n \"checkbox\",\n \"radio\",\n \"file\",\n \"submit\",\n \"image\",\n \"reset\",\n \"button\"\n ]\n }\n },\n ins: {\n attrs: {\n cite: null,\n datetime: null\n }\n },\n kbd: S,\n keygen: {\n attrs: {\n challenge: null,\n form: null,\n name: null,\n autofocus: [\n \"autofocus\"\n ],\n disabled: [\n \"disabled\"\n ],\n keytype: [\n \"RSA\"\n ]\n }\n },\n label: {\n attrs: {\n for: null,\n form: null\n }\n },\n legend: S,\n li: {\n attrs: {\n value: null\n }\n },\n link: {\n attrs: {\n href: null,\n type: null,\n hreflang: null,\n media: null,\n sizes: [\n \"all\",\n \"16x16\",\n \"16x16 32x32\",\n \"16x16 32x32 64x64\"\n ]\n }\n },\n map: {\n attrs: {\n name: null\n }\n },\n mark: S,\n menu: {\n attrs: {\n label: null,\n type: [\n \"list\",\n \"context\",\n \"toolbar\"\n ]\n }\n },\n meta: {\n attrs: {\n content: null,\n charset: Charsets,\n name: [\n \"viewport\",\n \"application-name\",\n \"author\",\n \"description\",\n \"generator\",\n \"keywords\"\n ],\n \"http-equiv\": [\n \"content-language\",\n \"content-type\",\n \"default-style\",\n \"refresh\"\n ]\n }\n },\n meter: {\n attrs: {\n value: null,\n min: null,\n low: null,\n high: null,\n max: null,\n optimum: null\n }\n },\n nav: S,\n noframes: S,\n noscript: S,\n object: {\n attrs: {\n data: null,\n type: null,\n name: null,\n usemap: null,\n form: null,\n width: null,\n height: null,\n typemustmatch: [\n \"typemustmatch\"\n ]\n }\n },\n ol: {\n attrs: {\n reversed: [\n \"reversed\"\n ],\n start: null,\n type: [\n \"1\",\n \"a\",\n \"A\",\n \"i\",\n \"I\"\n ]\n },\n children: [\n \"li\",\n \"script\",\n \"template\",\n \"ul\",\n \"ol\"\n ]\n },\n optgroup: {\n attrs: {\n disabled: [\n \"disabled\"\n ],\n label: null\n }\n },\n option: {\n attrs: {\n disabled: [\n \"disabled\"\n ],\n label: null,\n selected: [\n \"selected\"\n ],\n value: null\n }\n },\n output: {\n attrs: {\n for: null,\n form: null,\n name: null\n }\n },\n p: S,\n param: {\n attrs: {\n name: null,\n value: null\n }\n },\n pre: S,\n progress: {\n attrs: {\n value: null,\n max: null\n }\n },\n q: {\n attrs: {\n cite: null\n }\n },\n rp: S,\n rt: S,\n ruby: S,\n s: S,\n samp: S,\n script: {\n attrs: {\n type: [\n \"text/javascript\"\n ],\n src: null,\n async: [\n \"async\"\n ],\n defer: [\n \"defer\"\n ],\n charset: Charsets\n }\n },\n section: S,\n select: {\n attrs: {\n form: null,\n name: null,\n size: null,\n autofocus: [\n \"autofocus\"\n ],\n disabled: [\n \"disabled\"\n ],\n multiple: [\n \"multiple\"\n ]\n }\n },\n small: S,\n source: {\n attrs: {\n src: null,\n type: null,\n media: null\n }\n },\n span: S,\n strike: S,\n strong: S,\n style: {\n attrs: {\n type: [\n \"text/css\"\n ],\n media: null,\n scoped: null\n }\n },\n sub: S,\n summary: S,\n sup: S,\n table: S,\n tbody: S,\n td: {\n attrs: {\n colspan: null,\n rowspan: null,\n headers: null\n }\n },\n textarea: {\n attrs: {\n dirname: null,\n form: null,\n maxlength: null,\n name: null,\n placeholder: null,\n rows: null,\n cols: null,\n autofocus: [\n \"autofocus\"\n ],\n disabled: [\n \"disabled\"\n ],\n readonly: [\n \"readonly\"\n ],\n required: [\n \"required\"\n ],\n wrap: [\n \"soft\",\n \"hard\"\n ]\n }\n },\n tfoot: S,\n th: {\n attrs: {\n colspan: null,\n rowspan: null,\n headers: null,\n scope: [\n \"row\",\n \"col\",\n \"rowgroup\",\n \"colgroup\"\n ]\n }\n },\n thead: S,\n time: {\n attrs: {\n datetime: null\n }\n },\n title: S,\n tr: S,\n track: {\n attrs: {\n src: null,\n label: null,\n default: null,\n kind: [\n \"subtitles\",\n \"captions\",\n \"descriptions\",\n \"chapters\",\n \"metadata\"\n ],\n srclang: null\n }\n },\n tt: S,\n u: S,\n ul: {\n children: [\n \"li\",\n \"script\",\n \"template\",\n \"ul\",\n \"ol\"\n ]\n },\n var: S,\n video: {\n attrs: {\n src: null,\n poster: null,\n width: null,\n height: null,\n crossorigin: [\n \"anonymous\",\n \"use-credentials\"\n ],\n preload: [\n \"auto\",\n \"metadata\",\n \"none\"\n ],\n autoplay: [\n \"autoplay\"\n ],\n mediagroup: [\n \"movie\"\n ],\n muted: [\n \"muted\"\n ],\n controls: [\n \"controls\"\n ]\n }\n },\n wbr: S\n};\nconst GlobalAttrs = {\n accesskey: null,\n class: null,\n contenteditable: Bool,\n contextmenu: null,\n dir: [\n \"ltr\",\n \"rtl\",\n \"auto\"\n ],\n draggable: [\n \"true\",\n \"false\",\n \"auto\"\n ],\n dropzone: [\n \"copy\",\n \"move\",\n \"link\",\n \"string:\",\n \"file:\"\n ],\n hidden: [\n \"hidden\"\n ],\n id: null,\n inert: [\n \"inert\"\n ],\n itemid: null,\n itemprop: null,\n itemref: null,\n itemscope: [\n \"itemscope\"\n ],\n itemtype: null,\n lang: [\n \"ar\",\n \"bn\",\n \"de\",\n \"en-GB\",\n \"en-US\",\n \"es\",\n \"fr\",\n \"hi\",\n \"id\",\n \"ja\",\n \"pa\",\n \"pt\",\n \"ru\",\n \"tr\",\n \"zh\"\n ],\n spellcheck: Bool,\n autocorrect: Bool,\n autocapitalize: Bool,\n style: null,\n tabindex: null,\n title: null,\n translate: [\n \"yes\",\n \"no\"\n ],\n onclick: null,\n rel: [\n \"stylesheet\",\n \"alternate\",\n \"author\",\n \"bookmark\",\n \"help\",\n \"license\",\n \"next\",\n \"nofollow\",\n \"noreferrer\",\n \"prefetch\",\n \"prev\",\n \"search\",\n \"tag\"\n ],\n role: /*@__PURE__*/ \"alert application article banner button cell checkbox complementary contentinfo dialog document feed figure form grid gridcell heading img list listbox listitem main navigation region row rowgroup search switch tab table tabpanel textbox timer\".split(\" \"),\n \"aria-activedescendant\": null,\n \"aria-atomic\": Bool,\n \"aria-autocomplete\": [\n \"inline\",\n \"list\",\n \"both\",\n \"none\"\n ],\n \"aria-busy\": Bool,\n \"aria-checked\": [\n \"true\",\n \"false\",\n \"mixed\",\n \"undefined\"\n ],\n \"aria-controls\": null,\n \"aria-describedby\": null,\n \"aria-disabled\": Bool,\n \"aria-dropeffect\": null,\n \"aria-expanded\": [\n \"true\",\n \"false\",\n \"undefined\"\n ],\n \"aria-flowto\": null,\n \"aria-grabbed\": [\n \"true\",\n \"false\",\n \"undefined\"\n ],\n \"aria-haspopup\": Bool,\n \"aria-hidden\": Bool,\n \"aria-invalid\": [\n \"true\",\n \"false\",\n \"grammar\",\n \"spelling\"\n ],\n \"aria-label\": null,\n \"aria-labelledby\": null,\n \"aria-level\": null,\n \"aria-live\": [\n \"off\",\n \"polite\",\n \"assertive\"\n ],\n \"aria-multiline\": Bool,\n \"aria-multiselectable\": Bool,\n \"aria-owns\": null,\n \"aria-posinset\": null,\n \"aria-pressed\": [\n \"true\",\n \"false\",\n \"mixed\",\n \"undefined\"\n ],\n \"aria-readonly\": Bool,\n \"aria-relevant\": null,\n \"aria-required\": Bool,\n \"aria-selected\": [\n \"true\",\n \"false\",\n \"undefined\"\n ],\n \"aria-setsize\": null,\n \"aria-sort\": [\n \"ascending\",\n \"descending\",\n \"none\",\n \"other\"\n ],\n \"aria-valuemax\": null,\n \"aria-valuemin\": null,\n \"aria-valuenow\": null,\n \"aria-valuetext\": null\n};\nconst AllTags = /*@__PURE__*/ Object.keys(Tags);\nconst GlobalAttrNames = /*@__PURE__*/ Object.keys(GlobalAttrs);\nfunction elementName(doc, tree, max = doc.length) {\n if (!tree) return \"\";\n let tag = tree.firstChild;\n let name = tag && tag.getChild(\"TagName\");\n return name ? doc.sliceString(name.from, Math.min(name.to, max)) : \"\";\n}\nfunction findParentElement(tree, skip = false) {\n for(let cur = tree.parent; cur; cur = cur.parent)if (cur.name == \"Element\") {\n if (skip) skip = false;\n else return cur;\n }\n return null;\n}\nfunction allowedChildren(doc, tree) {\n let parentInfo = Tags[elementName(doc, findParentElement(tree, true))];\n return (parentInfo === null || parentInfo === void 0 ? void 0 : parentInfo.children) || AllTags;\n}\nfunction openTags(doc, tree) {\n let open = [];\n for(let parent = tree; parent = findParentElement(parent);){\n let tagName = elementName(doc, parent);\n if (tagName && parent.lastChild.name == \"CloseTag\") break;\n if (tagName && open.indexOf(tagName) < 0 && (tree.name == \"EndTag\" || tree.from >= parent.firstChild.to)) open.push(tagName);\n }\n return open;\n}\nconst identifier = /^[:\\-\\.\\w\\u00b7-\\uffff]+$/;\nfunction completeTag(state, tree, from, to) {\n let end = /\\s*>/.test(state.sliceDoc(to, to + 5)) ? \"\" : \">\";\n return {\n from,\n to,\n options: allowedChildren(state.doc, tree).map((tagName)=>({\n label: tagName,\n type: \"type\"\n })\n ).concat(openTags(state.doc, tree).map((tag, i)=>({\n label: \"/\" + tag,\n apply: \"/\" + tag + end,\n type: \"type\",\n boost: 99 - i\n })\n )),\n span: /^\\/?[:\\-\\.\\w\\u00b7-\\uffff]*$/\n };\n}\nfunction completeCloseTag(state, tree, from, to) {\n let end = /\\s*>/.test(state.sliceDoc(to, to + 5)) ? \"\" : \">\";\n return {\n from,\n to,\n options: openTags(state.doc, tree).map((tag, i)=>({\n label: tag,\n apply: tag + end,\n type: \"type\",\n boost: 99 - i\n })\n ),\n span: identifier\n };\n}\nfunction completeStartTag(state, tree, pos) {\n let options = [], level = 0;\n for (let tagName of allowedChildren(state.doc, tree))options.push({\n label: \"<\" + tagName,\n type: \"type\"\n });\n for (let open of openTags(state.doc, tree))options.push({\n label: \"</\" + open + \">\",\n type: \"type\",\n boost: 99 - level++\n });\n return {\n from: pos,\n to: pos,\n options,\n span: /^<\\/?[:\\-\\.\\w\\u00b7-\\uffff]*$/\n };\n}\nfunction completeAttrName(state, tree, from, to) {\n let elt = findParentElement(tree), info = elt ? Tags[elementName(state.doc, elt)] : null;\n let names = info && info.attrs ? Object.keys(info.attrs).concat(GlobalAttrNames) : GlobalAttrNames;\n return {\n from,\n to,\n options: names.map((attrName)=>({\n label: attrName,\n type: \"property\"\n })\n ),\n span: identifier\n };\n}\nfunction completeAttrValue(state, tree, from, to) {\n var _a;\n let nameNode = (_a = tree.parent) === null || _a === void 0 ? void 0 : _a.getChild(\"AttributeName\");\n let options = [], span = undefined;\n if (nameNode) {\n let attrName = state.sliceDoc(nameNode.from, nameNode.to);\n let attrs = GlobalAttrs[attrName];\n if (!attrs) {\n let elt = findParentElement(tree), info = elt ? Tags[elementName(state.doc, elt)] : null;\n attrs = (info === null || info === void 0 ? void 0 : info.attrs) && info.attrs[attrName];\n }\n if (attrs) {\n let base = state.sliceDoc(from, to).toLowerCase(), quoteStart = '\"', quoteEnd = '\"';\n if (/^['\"]/.test(base)) {\n span = base[0] == '\"' ? /^[^\"]*$/ : /^[^']*$/;\n quoteStart = \"\";\n quoteEnd = state.sliceDoc(to, to + 1) == base[0] ? \"\" : base[0];\n base = base.slice(1);\n from++;\n } else span = /^[^\\s<>='\"]*$/;\n for (let value of attrs)options.push({\n label: value,\n apply: quoteStart + value + quoteEnd,\n type: \"constant\"\n });\n }\n }\n return {\n from,\n to,\n options,\n span\n };\n}\n/**\nHTML tag completion. Opens and closes tags and attributes in a\ncontext-aware way.\n*/ function htmlCompletionSource(context) {\n let { state , pos } = context, around = _language.syntaxTree(state).resolveInner(pos), tree = around.resolve(pos, -1);\n for(let scan = pos, before; around == tree && (before = tree.childBefore(scan));){\n let last = before.lastChild;\n if (!last || !last.type.isError || last.from < last.to) break;\n around = tree = before;\n scan = last.from;\n }\n if (tree.name == \"TagName\") return tree.parent && /CloseTag$/.test(tree.parent.name) ? completeCloseTag(state, tree, tree.from, pos) : completeTag(state, tree, tree.from, pos);\n else if (tree.name == \"StartTag\") return completeTag(state, tree, pos, pos);\n else if (tree.name == \"StartCloseTag\" || tree.name == \"IncompleteCloseTag\") return completeCloseTag(state, tree, pos, pos);\n else if (context.explicit && (tree.name == \"OpenTag\" || tree.name == \"SelfClosingTag\") || tree.name == \"AttributeName\") return completeAttrName(state, tree, tree.name == \"AttributeName\" ? tree.from : pos, pos);\n else if (tree.name == \"Is\" || tree.name == \"AttributeValue\" || tree.name == \"UnquotedAttributeValue\") return completeAttrValue(state, tree, tree.name == \"Is\" ? pos : tree.from, pos);\n else if (context.explicit && (around.name == \"Element\" || around.name == \"Text\" || around.name == \"Document\")) return completeStartTag(state, tree, pos);\n else return null;\n}\n/**\nA language provider based on the [Lezer HTML\nparser](https://github.com/lezer-parser/html), extended with the\nJavaScript and CSS parsers to parse the content of `<script>` and\n`<style>` tags.\n*/ const htmlLanguage = /*@__PURE__*/ _language.LRLanguage.define({\n parser: /*@__PURE__*/ _html.parser.configure({\n props: [\n /*@__PURE__*/ _language.indentNodeProp.add({\n Element (context) {\n let after = /^(\\s*)(<\\/)?/.exec(context.textAfter);\n if (context.node.to <= context.pos + after[0].length) return context.continue();\n return context.lineIndent(context.node.from) + (after[2] ? 0 : context.unit);\n },\n \"OpenTag CloseTag SelfClosingTag\" (context) {\n return context.column(context.node.from) + context.unit;\n },\n Document (context) {\n if (context.pos + /\\s*/.exec(context.textAfter)[0].length < context.node.to) return context.continue();\n let endElt = null, close;\n for(let cur = context.node;;){\n let last = cur.lastChild;\n if (!last || last.name != \"Element\" || last.to != cur.to) break;\n endElt = cur = last;\n }\n if (endElt && !((close = endElt.lastChild) && (close.name == \"CloseTag\" || close.name == \"SelfClosingTag\"))) return context.lineIndent(endElt.from) + context.unit;\n return null;\n }\n }),\n /*@__PURE__*/ _language.foldNodeProp.add({\n Element (node) {\n let first = node.firstChild, last = node.lastChild;\n if (!first || first.name != \"OpenTag\") return null;\n return {\n from: first.to,\n to: last.name == \"CloseTag\" ? last.from : node.to\n };\n }\n }),\n /*@__PURE__*/ _highlight.styleTags({\n \"Text RawText\": _highlight.tags.content,\n \"StartTag StartCloseTag SelfCloserEndTag EndTag SelfCloseEndTag\": _highlight.tags.angleBracket,\n TagName: _highlight.tags.tagName,\n \"MismatchedCloseTag/TagName\": [\n _highlight.tags.tagName,\n _highlight.tags.invalid\n ],\n AttributeName: _highlight.tags.attributeName,\n \"AttributeValue UnquotedAttributeValue\": _highlight.tags.attributeValue,\n Is: _highlight.tags.definitionOperator,\n \"EntityReference CharacterReference\": _highlight.tags.character,\n Comment: _highlight.tags.blockComment,\n ProcessingInst: _highlight.tags.processingInstruction,\n DoctypeDecl: _highlight.tags.documentMeta\n })\n ],\n wrap: /*@__PURE__*/ _html.configureNesting([\n {\n tag: \"script\",\n attrs (attrs) {\n return !attrs.type || /^(?:text|application)\\/(?:x-)?(?:java|ecma)script$|^module$|^$/i.test(attrs.type);\n },\n parser: _langJavascript.javascriptLanguage.parser\n },\n {\n tag: \"style\",\n attrs (attrs) {\n return (!attrs.lang || attrs.lang == \"css\") && (!attrs.type || /^(text\\/)?(x-)?(stylesheet|css)$/i.test(attrs.type));\n },\n parser: _langCss.cssLanguage.parser\n }\n ])\n }),\n languageData: {\n commentTokens: {\n block: {\n open: \"<\\!--\",\n close: \"-->\"\n }\n },\n indentOnInput: /^\\s*<\\/\\w+\\W$/,\n wordChars: \"-._\"\n }\n});\n// FIXME remove on next major version\nconst htmlCompletion = /*@__PURE__*/ htmlLanguage.data.of({\n autocomplete: htmlCompletionSource\n});\n/**\nLanguage support for HTML, including\n[`htmlCompletion`](https://codemirror.net/6/docs/ref/#lang-html.htmlCompletion) and JavaScript and\nCSS support extensions.\n*/ function html(config = {\n}) {\n let lang = htmlLanguage;\n if (config.matchClosingTags === false) lang = lang.configure({\n dialect: \"noMatch\"\n });\n return new _language.LanguageSupport(lang, [\n htmlCompletion,\n config.autoCloseTags !== false ? autoCloseTags : [],\n _langJavascript.javascript().support,\n _langCss.css().support\n ]);\n}\n/**\nExtension that will automatically insert close tags when a `>` or\n`/` is typed.\n*/ const autoCloseTags = /*@__PURE__*/ _view.EditorView.inputHandler.of((view, from, to, text)=>{\n if (view.composing || view.state.readOnly || from != to || text != \">\" && text != \"/\" || !htmlLanguage.isActiveAt(view.state, from, -1)) return false;\n let { state } = view;\n let changes = state.changeByRange((range)=>{\n var _a, _b, _c;\n let { head } = range, around = _language.syntaxTree(state).resolveInner(head, -1), name;\n if (around.name == \"TagName\" || around.name == \"StartTag\") around = around.parent;\n if (text == \">\" && around.name == \"OpenTag\") {\n if (((_b = (_a = around.parent) === null || _a === void 0 ? void 0 : _a.lastChild) === null || _b === void 0 ? void 0 : _b.name) != \"CloseTag\" && (name = elementName(state.doc, around.parent, head))) return {\n range: _state.EditorSelection.cursor(head + 1),\n changes: {\n from: head,\n insert: `></${name}>`\n }\n };\n } else if (text == \"/\" && around.name == \"OpenTag\") {\n let empty = around.parent, base = empty === null || empty === void 0 ? void 0 : empty.parent;\n if (empty.from == head - 1 && ((_c = base.lastChild) === null || _c === void 0 ? void 0 : _c.name) != \"CloseTag\" && (name = elementName(state.doc, base, head))) {\n let insert = `/${name}>`;\n return {\n range: _state.EditorSelection.cursor(head + insert.length),\n changes: {\n from: head,\n insert\n }\n };\n }\n }\n return {\n range\n };\n });\n if (changes.changes.empty) return false;\n view.dispatch(changes, {\n userEvent: \"input.type\",\n scrollIntoView: true\n });\n return true;\n});\n\n},{\"@lezer/html\":\"gftm6\",\"@codemirror/lang-css\":\"gH8D7\",\"@codemirror/lang-javascript\":\"fpWUM\",\"@codemirror/view\":\"JuP5Z\",\"@codemirror/state\":\"e6FBl\",\"@codemirror/language\":\"70QHL\",\"@codemirror/highlight\":\"cVRRs\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"gftm6\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"configureNesting\", ()=>configureNesting\n);\nparcelHelpers.export(exports, \"parser\", ()=>parser\n);\nvar _lr = require(\"@lezer/lr\");\nvar _common = require(\"@lezer/common\");\n// This file was generated by lezer-generator. You probably shouldn't edit it.\nconst scriptText = 53, StartCloseScriptTag = 1, styleText = 54, StartCloseStyleTag = 2, textareaText = 55, StartCloseTextareaTag = 3, StartTag = 4, StartScriptTag = 5, StartStyleTag = 6, StartTextareaTag = 7, StartCloseTag = 8, NoMatchStartCloseTag = 9, MismatchedStartCloseTag = 10, missingCloseTag = 56, IncompleteCloseTag = 11, SelfCloseEndTag = 12, commentContent$1 = 57, Element = 18, ScriptText = 27, StyleText = 30, TextareaText = 33, OpenTag = 35, Dialect_noMatch = 0;\n/* Hand-written tokenizers for HTML. */ const selfClosers = {\n area: true,\n base: true,\n br: true,\n col: true,\n command: true,\n embed: true,\n frame: true,\n hr: true,\n img: true,\n input: true,\n keygen: true,\n link: true,\n meta: true,\n param: true,\n source: true,\n track: true,\n wbr: true,\n menuitem: true\n};\nconst implicitlyClosed = {\n dd: true,\n li: true,\n optgroup: true,\n option: true,\n p: true,\n rp: true,\n rt: true,\n tbody: true,\n td: true,\n tfoot: true,\n th: true,\n tr: true\n};\nconst closeOnOpen = {\n dd: {\n dd: true,\n dt: true\n },\n dt: {\n dd: true,\n dt: true\n },\n li: {\n li: true\n },\n option: {\n option: true,\n optgroup: true\n },\n optgroup: {\n optgroup: true\n },\n p: {\n address: true,\n article: true,\n aside: true,\n blockquote: true,\n dir: true,\n div: true,\n dl: true,\n fieldset: true,\n footer: true,\n form: true,\n h1: true,\n h2: true,\n h3: true,\n h4: true,\n h5: true,\n h6: true,\n header: true,\n hgroup: true,\n hr: true,\n menu: true,\n nav: true,\n ol: true,\n p: true,\n pre: true,\n section: true,\n table: true,\n ul: true\n },\n rp: {\n rp: true,\n rt: true\n },\n rt: {\n rp: true,\n rt: true\n },\n tbody: {\n tbody: true,\n tfoot: true\n },\n td: {\n td: true,\n th: true\n },\n tfoot: {\n tbody: true\n },\n th: {\n td: true,\n th: true\n },\n thead: {\n tbody: true,\n tfoot: true\n },\n tr: {\n tr: true\n }\n};\nfunction nameChar(ch) {\n return ch == 45 || ch == 46 || ch == 58 || ch >= 65 && ch <= 90 || ch == 95 || ch >= 97 && ch <= 122 || ch >= 161;\n}\nfunction isSpace(ch) {\n return ch == 9 || ch == 10 || ch == 13 || ch == 32;\n}\nlet cachedName = null, cachedInput = null, cachedPos = 0;\nfunction tagNameAfter(input, offset) {\n let pos = input.pos + offset;\n if (cachedPos == pos && cachedInput == input) return cachedName;\n let next = input.peek(offset);\n while(isSpace(next))next = input.peek(++offset);\n let name = \"\";\n for(;;){\n if (!nameChar(next)) break;\n name += String.fromCharCode(next);\n next = input.peek(++offset);\n }\n // Undefined to signal there's a <? or <!, null for just missing\n cachedInput = input;\n cachedPos = pos;\n return cachedName = name || (next == question || next == bang ? undefined : null);\n}\nconst lessThan = 60, greaterThan = 62, slash = 47, question = 63, bang = 33;\nfunction ElementContext(name, parent) {\n this.name = name;\n this.parent = parent;\n this.hash = parent ? parent.hash : 0;\n for(let i = 0; i < name.length; i++)this.hash += (this.hash << 4) + name.charCodeAt(i) + (name.charCodeAt(i) << 8);\n}\nconst startTagTerms = [\n StartTag,\n StartScriptTag,\n StartStyleTag,\n StartTextareaTag\n];\nconst elementContext = new _lr.ContextTracker({\n start: null,\n shift (context, term, stack, input) {\n return startTagTerms.indexOf(term) > -1 ? new ElementContext(tagNameAfter(input, 1) || \"\", context) : context;\n },\n reduce (context, term) {\n return term == Element && context ? context.parent : context;\n },\n reuse (context, node, stack, input) {\n let type = node.type.id;\n return type == StartTag || type == OpenTag ? new ElementContext(tagNameAfter(input, 1) || \"\", context) : context;\n },\n hash (context) {\n return context ? context.hash : 0;\n },\n strict: false\n});\nconst tagStart = new _lr.ExternalTokenizer((input, stack)=>{\n if (input.next != lessThan) {\n // End of file, close any open tags\n if (input.next < 0 && stack.context) input.acceptToken(missingCloseTag);\n return;\n }\n input.advance();\n let close = input.next == slash;\n if (close) input.advance();\n let name = tagNameAfter(input, 0);\n if (name === undefined) return;\n if (!name) return input.acceptToken(close ? IncompleteCloseTag : StartTag);\n let parent = stack.context ? stack.context.name : null;\n if (close) {\n if (name == parent) return input.acceptToken(StartCloseTag);\n if (parent && implicitlyClosed[parent]) return input.acceptToken(missingCloseTag, -2);\n if (stack.dialectEnabled(Dialect_noMatch)) return input.acceptToken(NoMatchStartCloseTag);\n for(let cx = stack.context; cx; cx = cx.parent)if (cx.name == name) return;\n input.acceptToken(MismatchedStartCloseTag);\n } else {\n if (name == \"script\") return input.acceptToken(StartScriptTag);\n if (name == \"style\") return input.acceptToken(StartStyleTag);\n if (name == \"textarea\") return input.acceptToken(StartTextareaTag);\n if (parent && closeOnOpen[parent] && closeOnOpen[parent][name]) input.acceptToken(missingCloseTag, -1);\n else input.acceptToken(StartTag);\n }\n}, {\n contextual: true\n});\nconst selfClosed = new _lr.ExternalTokenizer((input, stack)=>{\n let size = 1;\n if (input.next == slash) {\n if (input.peek(1) != greaterThan) return;\n size = 2;\n } else if (input.next != greaterThan) return;\n if (stack.context && selfClosers[stack.context.name]) input.acceptToken(SelfCloseEndTag, size);\n});\nconst commentContent = new _lr.ExternalTokenizer((input)=>{\n for(let endPos = 0, i = 0;; i++){\n if (input.next < 0) {\n if (i) input.acceptToken(commentContent$1);\n break;\n }\n if (input.next == \"-->\".charCodeAt(endPos)) {\n endPos++;\n if (endPos == 3) {\n if (i > 3) input.acceptToken(commentContent$1, -2);\n break;\n }\n } else endPos = 0;\n input.advance();\n }\n});\nfunction contentTokenizer(tag, textToken, endToken) {\n let lastState = 2 + tag.length;\n return new _lr.ExternalTokenizer((input)=>{\n // state means:\n // - 0 nothing matched\n // - 1 '<' matched\n // - 2 '</' + possibly whitespace matched\n // - 3-(1+tag.length) part of the tag matched\n // - lastState whole tag + possibly whitespace matched\n for(let state = 0, matchedLen = 0, i = 0;; i++){\n if (input.next < 0) {\n if (i) input.acceptToken(textToken);\n break;\n }\n if (state == 0 && input.next == lessThan || state == 1 && input.next == slash || state >= 2 && state < lastState && input.next == tag.charCodeAt(state - 2)) {\n state++;\n matchedLen++;\n } else if ((state == 2 || state == lastState) && isSpace(input.next)) matchedLen++;\n else if (state == lastState && input.next == greaterThan) {\n if (i > matchedLen) input.acceptToken(textToken, -matchedLen);\n else input.acceptToken(endToken, -(matchedLen - 2));\n break;\n } else if ((input.next == 10 /* '\\n' */ || input.next == 13 /* '\\r' */ ) && i) {\n input.acceptToken(textToken, 1);\n break;\n } else state = matchedLen = 0;\n input.advance();\n }\n });\n}\nconst scriptTokens = contentTokenizer(\"script\", scriptText, StartCloseScriptTag);\nconst styleTokens = contentTokenizer(\"style\", styleText, StartCloseStyleTag);\nconst textareaTokens = contentTokenizer(\"textarea\", textareaText, StartCloseTextareaTag);\n// This file was generated by lezer-generator. You probably shouldn't edit it.\nconst parser = _lr.LRParser.deserialize({\n version: 13,\n states: \",fOVO!jOOO!TQ#tO'#CoO!YQ#tO'#CyO!_Q#tO'#C|O!dQ#tO'#DPO!iOXO'#CnO!tOYO'#CnO#PO[O'#CnO$YO!jO'#CnOOOW'#Cn'#CnO$aO$fO'#DSO$iQ#tO'#DUO$nQ#tO'#DVOOOW'#Dj'#DjOOOW'#DX'#DXQVO!jOOO$sQ&jO,59ZO${Q&jO,59eO%TQ&jO,59hO%]Q&zO,59kOOOX'#D]'#D]O%hOXO'#CwO%sOXO,59YOOOY'#D^'#D^O%{OYO'#CzO&WOYO,59YOOO['#D_'#D_O&`O[O'#C}O&kO[O,59YOOOW'#D`'#D`O&sO!jO,59YO&zQ#tO'#DQOOOW,59Y,59YOOOp'#Da'#DaO'PO$fO,59nOOOW,59n,59nO'XQ#tO,59pO'^Q#tO,59qOOOW-E7V-E7VO'cQ&zO'#CqOOQ`'#DY'#DYO'qQ&jO1G.uOOOX1G.u1G.uO'yQ&jO1G/POOOY1G/P1G/PO(RQ&jO1G/SOOO[1G/S1G/SO(ZQ&zO1G/VOOOW1G/V1G/VOOOW1G/X1G/XOOOX-E7Z-E7ZO(fQ#tO'#CxOOOW1G.t1G.tOOOY-E7[-E7[O(kQ#tO'#C{OOO[-E7]-E7]O(pQ#tO'#DOOOOW-E7^-E7^O(uQ#tO,59lOOOp-E7_-E7_OOOW1G/Y1G/YOOOW1G/[1G/[OOOW1G/]1G/]O(zQ,UO,59]OOQ`-E7W-E7WOOOX7+$a7+$aOOOY7+$k7+$kOOO[7+$n7+$nOOOW7+$q7+$qOOOW7+$s7+$sO)VQ#tO,59dO)[Q#tO,59gO)aQ#tO,59jOOOW1G/W1G/WO)fO7[O'#CtO)tOMhO'#CtOOQ`1G.w1G.wOOOW1G/O1G/OOOOW1G/R1G/ROOOW1G/U1G/UOOOO'#DZ'#DZO*SO7[O,59`OOQ`,59`,59`OOOO'#D['#D[O*bOMhO,59`OOOO-E7X-E7XOOQ`1G.z1G.zOOOO-E7Y-E7Y\",\n stateData: \"*x~O!]OS~OSSOTPOUQOVROX[OYZOZ]O^]O_]O`]Oa]Ow]Oz^O!cYO~Od`O~OdaO~OdbO~OdcO~O!VdOPkP!YkP~O!WgOQnP!YnP~O!XjORqP!YqP~OSSOTPOUQOVROWoOX[OYZOZ]O^]O_]O`]Oa]Ow]O!cYO~O!YpO~P#[O!ZqO!dsO~OdtO~OduO~OfwOjzO~OfwOj|O~OfwOj!OO~O[!ROfwOj!QO~O!VdOPkX!YkX~OP!TO!Y!UO~O!WgOQnX!YnX~OQ!WO!Y!UO~O!XjORqX!YqX~OR!YO!Y!UO~O!Y!UO~P#[Od![O~O!ZqO!d!^O~Oj!_O~Oj!`O~Og!aOfeXjeX[eX~OfwOj!cO~OfwOj!dO~OfwOj!eO~O[!gOfwOj!fO~Od!hO~Od!iO~Od!jO~Oj!kO~Oi!nO!_!lO!a!mO~Oj!oO~Oj!pO~Oj!qO~O_!rO`!rO!_!tO!`!rO~O_!uO`!uO!a!tO!b!uO~O_!rO`!rO!_!xO!`!rO~O_!uO`!uO!a!xO!b!uO~O`_a!cwz!c~\",\n goto: \"%i!_PPPPPPPPPPPPPPPPPP!`!fP!lPP!vPP!y!|#P#V#Y#]#c#f#i#o#u!`P!`!`P#{$R$e$k$q$w$}%T%ZPPPPPPPP%aX]OW_nXTOW_nax`abcy{}!PR!n!aRfTR!UfXUOW_nRiUR!UiXVOW_nRlVR!UlXWOW_nQpWR!UnXXOW_nQ_ORv_Qy`Q{aQ}bQ!PcX!by{}!PQ!s!lR!w!sQ!v!mR!y!vQeTR!SeQhUR!VhQkVR!XkQnWR!ZnQrYR!]rS^O_TmWn\",\n nodeNames: \"\u26a0 StartCloseTag StartCloseTag StartCloseTag StartTag StartTag StartTag StartTag StartCloseTag StartCloseTag StartCloseTag IncompleteCloseTag SelfCloseEndTag Document Text EntityReference CharacterReference InvalidEntity Element OpenTag TagName Attribute AttributeName Is AttributeValue UnquotedAttributeValue EndTag ScriptText CloseTag OpenTag StyleText CloseTag OpenTag TextareaText CloseTag OpenTag CloseTag SelfClosingTag Comment ProcessingInst MismatchedCloseTag CloseTag DoctypeDecl\",\n maxTerm: 66,\n context: elementContext,\n nodeProps: [\n [\n _common.NodeProp.closedBy,\n -9,\n 1,\n 2,\n 3,\n 5,\n 6,\n 7,\n 8,\n 9,\n 10,\n \"EndTag\",\n 4,\n \"EndTag SelfCloseEndTag\",\n -4,\n 19,\n 29,\n 32,\n 35,\n \"CloseTag\"\n ],\n [\n _common.NodeProp.group,\n -9,\n 11,\n 15,\n 16,\n 17,\n 18,\n 38,\n 39,\n 40,\n 41,\n \"Entity\",\n 14,\n \"Entity TextContent\",\n -3,\n 27,\n 30,\n 33,\n \"TextContent Entity\"\n ],\n [\n _common.NodeProp.openedBy,\n 12,\n \"StartTag\",\n 26,\n \"StartTag StartCloseTag\",\n -4,\n 28,\n 31,\n 34,\n 36,\n \"OpenTag\"\n ]\n ],\n skippedNodes: [\n 0\n ],\n repeatNodeCount: 9,\n tokenData: \"!#b!aR!WOX$kXY)sYZ)sZ]$k]^)s^p$kpq)sqr$krs*zsv$kvw+dwx2yx}$k}!O3f!O!P$k!P!Q7_!Q![$k![!]8u!]!^$k!^!_>b!_!`!!p!`!a8T!a!c$k!c!}8u!}#R$k#R#S8u#S#T$k#T#o8u#o$f$k$f$g&R$g%W$k%W%o8u%o%p$k%p&a8u&a&b$k&b1p8u1p4U$k4U4d8u4d4e$k4e$IS8u$IS$I`$k$I`$Ib8u$Ib$Kh$k$Kh%#t8u%#t&/x$k&/x&Et8u&Et&FV$k&FV;'S8u;'S;:j<t;:j?&r$k?&r?Ah8u?Ah?BY$k?BY?Mn8u?Mn~$k!Z$vc^PiW!``!bpOX$kXZ&RZ]$k]^&R^p$kpq&Rqr$krs&qsv$kvw)Rwx'rx!P$k!P!Q&R!Q!^$k!^!_(k!_!a&R!a$f$k$f$g&R$g~$k!R&[V^P!``!bpOr&Rrs&qsv&Rwx'rx!^&R!^!_(k!_~&Rq&xT^P!bpOv&qwx'Xx!^&q!^!_'g!_~&qP'^R^POv'Xw!^'X!_~'Xp'lQ!bpOv'gx~'ga'yU^P!``Or'rrs'Xsv'rw!^'r!^!_(]!_~'r`(bR!``Or(]sv(]w~(]!Q(rT!``!bpOr(krs'gsv(kwx(]x~(kW)WXiWOX)RZ])R^p)Rqr)Rsw)Rx!P)R!Q!^)R!a$f)R$g~)R!a*O^^P!``!bp!]^OX&RXY)sYZ)sZ]&R]^)s^p&Rpq)sqr&Rrs&qsv&Rwx'rx!^&R!^!_(k!_~&R!Z+TT!_h^P!bpOv&qwx'Xx!^&q!^!_'g!_~&q!Z+kbiWaPOX,sXZ.QZ],s]^.Q^p,sqr,srs.Qst/]tw,swx.Qx!P,s!P!Q.Q!Q!],s!]!^)R!^!a.Q!a$f,s$f$g.Q$g~,s!Z,xbiWOX,sXZ.QZ],s]^.Q^p,sqr,srs.Qst)Rtw,swx.Qx!P,s!P!Q.Q!Q!],s!]!^.i!^!a.Q!a$f,s$f$g.Q$g~,s!R.TTOp.Qqs.Qt!].Q!]!^.d!^~.Q!R.iO_!R!Z.pXiW_!ROX)RZ])R^p)Rqr)Rsw)Rx!P)R!Q!^)R!a$f)R$g~)R!Z/baiWOX0gXZ1qZ]0g]^1q^p0gqr0grs1qsw0gwx1qx!P0g!P!Q1q!Q!]0g!]!^)R!^!a1q!a$f0g$f$g1q$g~0g!Z0laiWOX0gXZ1qZ]0g]^1q^p0gqr0grs1qsw0gwx1qx!P0g!P!Q1q!Q!]0g!]!^2V!^!a1q!a$f0g$f$g1q$g~0g!R1tSOp1qq!]1q!]!^2Q!^~1q!R2VO`!R!Z2^XiW`!ROX)RZ])R^p)Rqr)Rsw)Rx!P)R!Q!^)R!a$f)R$g~)R!Z3SU!ax^P!``Or'rrs'Xsv'rw!^'r!^!_(]!_~'r!]3qe^PiW!``!bpOX$kXZ&RZ]$k]^&R^p$kpq&Rqr$krs&qsv$kvw)Rwx'rx}$k}!O5S!O!P$k!P!Q&R!Q!^$k!^!_(k!_!a&R!a$f$k$f$g&R$g~$k!]5_d^PiW!``!bpOX$kXZ&RZ]$k]^&R^p$kpq&Rqr$krs&qsv$kvw)Rwx'rx!P$k!P!Q&R!Q!^$k!^!_(k!_!`&R!`!a6m!a$f$k$f$g&R$g~$k!T6xV^P!``!bp!dQOr&Rrs&qsv&Rwx'rx!^&R!^!_(k!_~&R!X7hX^P!``!bpOr&Rrs&qsv&Rwx'rx!^&R!^!_(k!_!`&R!`!a8T!a~&R!X8`VjU^P!``!bpOr&Rrs&qsv&Rwx'rx!^&R!^!_(k!_~&R!a9U!YfSdQ^PiW!``!bpOX$kXZ&RZ]$k]^&R^p$kpq&Rqr$krs&qsv$kvw)Rwx'rx}$k}!O8u!O!P8u!P!Q&R!Q![8u![!]8u!]!^$k!^!_(k!_!a&R!a!c$k!c!}8u!}#R$k#R#S8u#S#T$k#T#o8u#o$f$k$f$g&R$g$}$k$}%O8u%O%W$k%W%o8u%o%p$k%p&a8u&a&b$k&b1p8u1p4U8u4U4d8u4d4e$k4e$IS8u$IS$I`$k$I`$Ib8u$Ib$Je$k$Je$Jg8u$Jg$Kh$k$Kh%#t8u%#t&/x$k&/x&Et8u&Et&FV$k&FV;'S8u;'S;:j<t;:j?&r$k?&r?Ah8u?Ah?BY$k?BY?Mn8u?Mn~$k!a=Pe^PiW!``!bpOX$kXZ&RZ]$k]^&R^p$kpq&Rqr$krs&qsv$kvw)Rwx'rx!P$k!P!Q&R!Q!^$k!^!_(k!_!a&R!a$f$k$f$g&R$g;=`$k;=`<%l8u<%l~$k!R>iW!``!bpOq(kqr?Rrs'gsv(kwx(]x!a(k!a!bKj!b~(k!R?YZ!``!bpOr(krs'gsv(kwx(]x}(k}!O?{!O!f(k!f!gAR!g#W(k#W#XGz#X~(k!R@SV!``!bpOr(krs'gsv(kwx(]x}(k}!O@i!O~(k!R@rT!``!bp!cPOr(krs'gsv(kwx(]x~(k!RAYV!``!bpOr(krs'gsv(kwx(]x!q(k!q!rAo!r~(k!RAvV!``!bpOr(krs'gsv(kwx(]x!e(k!e!fB]!f~(k!RBdV!``!bpOr(krs'gsv(kwx(]x!v(k!v!wBy!w~(k!RCQV!``!bpOr(krs'gsv(kwx(]x!{(k!{!|Cg!|~(k!RCnV!``!bpOr(krs'gsv(kwx(]x!r(k!r!sDT!s~(k!RD[V!``!bpOr(krs'gsv(kwx(]x!g(k!g!hDq!h~(k!RDxW!``!bpOrDqrsEbsvDqvwEvwxFfx!`Dq!`!aGb!a~DqqEgT!bpOvEbvxEvx!`Eb!`!aFX!a~EbPEyRO!`Ev!`!aFS!a~EvPFXOzPqF`Q!bpzPOv'gx~'gaFkV!``OrFfrsEvsvFfvwEvw!`Ff!`!aGQ!a~FfaGXR!``zPOr(]sv(]w~(]!RGkT!``!bpzPOr(krs'gsv(kwx(]x~(k!RHRV!``!bpOr(krs'gsv(kwx(]x#c(k#c#dHh#d~(k!RHoV!``!bpOr(krs'gsv(kwx(]x#V(k#V#WIU#W~(k!RI]V!``!bpOr(krs'gsv(kwx(]x#h(k#h#iIr#i~(k!RIyV!``!bpOr(krs'gsv(kwx(]x#m(k#m#nJ`#n~(k!RJgV!``!bpOr(krs'gsv(kwx(]x#d(k#d#eJ|#e~(k!RKTV!``!bpOr(krs'gsv(kwx(]x#X(k#X#YDq#Y~(k!RKqW!``!bpOrKjrsLZsvKjvwLowxNPx!aKj!a!b! g!b~KjqL`T!bpOvLZvxLox!aLZ!a!bM^!b~LZPLrRO!aLo!a!bL{!b~LoPMORO!`Lo!`!aMX!a~LoPM^OwPqMcT!bpOvLZvxLox!`LZ!`!aMr!a~LZqMyQ!bpwPOv'gx~'gaNUV!``OrNPrsLosvNPvwLow!aNP!a!bNk!b~NPaNpV!``OrNPrsLosvNPvwLow!`NP!`!a! V!a~NPa! ^R!``wPOr(]sv(]w~(]!R! nW!``!bpOrKjrsLZsvKjvwLowxNPx!`Kj!`!a!!W!a~Kj!R!!aT!``!bpwPOr(krs'gsv(kwx(]x~(k!V!!{VgS^P!``!bpOr&Rrs&qsv&Rwx'rx!^&R!^!_(k!_~&R\",\n tokenizers: [\n scriptTokens,\n styleTokens,\n textareaTokens,\n tagStart,\n selfClosed,\n commentContent,\n 0,\n 1,\n 2,\n 3,\n 4,\n 5\n ],\n topRules: {\n \"Document\": [\n 0,\n 13\n ]\n },\n dialects: {\n noMatch: 0\n },\n tokenPrec: 446\n});\nfunction getAttrs(element, input) {\n let attrs = Object.create(null);\n for (let att of element.firstChild.getChildren(\"Attribute\")){\n let name = att.getChild(\"AttributeName\"), value = att.getChild(\"AttributeValue\") || att.getChild(\"UnquotedAttributeValue\");\n if (name) attrs[input.read(name.from, name.to)] = !value ? \"\" : value.name == \"AttributeValue\" ? input.read(value.from + 1, value.to - 1) : input.read(value.from, value.to);\n }\n return attrs;\n}\nfunction maybeNest(node, input, tags) {\n let attrs;\n for (let tag of tags){\n if (!tag.attrs || tag.attrs(attrs || (attrs = getAttrs(node.node.parent, input)))) return {\n parser: tag.parser\n };\n }\n return null;\n}\n// tags: {\n// tag: \"script\" | \"style\" | \"textarea\",\n// attrs?: ({[attr: string]: string}) => boolean,\n// parser: Parser\n// }[]\nfunction configureNesting(tags) {\n let script = [], style = [], textarea = [];\n for (let tag of tags){\n let array = tag.tag == \"script\" ? script : tag.tag == \"style\" ? style : tag.tag == \"textarea\" ? textarea : null;\n if (!array) throw new RangeError(\"Only script, style, and textarea tags can host nested parsers\");\n array.push(tag);\n }\n return _common.parseMixed((node, input)=>{\n let id = node.type.id;\n if (id == ScriptText) return maybeNest(node, input, script);\n if (id == StyleText) return maybeNest(node, input, style);\n if (id == TextareaText) return maybeNest(node, input, textarea);\n return null;\n });\n}\n\n},{\"@lezer/lr\":\"3Ck4G\",\"@lezer/common\":\"ds1Io\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"3Ck4G\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"ContextTracker\", ()=>ContextTracker\n);\nparcelHelpers.export(exports, \"ExternalTokenizer\", ()=>ExternalTokenizer\n);\nparcelHelpers.export(exports, \"InputStream\", ()=>InputStream\n);\nparcelHelpers.export(exports, \"LRParser\", ()=>LRParser\n);\nparcelHelpers.export(exports, \"Stack\", ()=>Stack\n);\nvar _common = require(\"@lezer/common\");\nvar process = require(\"process\");\n/// A parse stack. These are used internally by the parser to track\n/// parsing progress. They also provide some properties and methods\n/// that external code such as a tokenizer can use to get information\n/// about the parse state.\nclass Stack {\n /// @internal\n constructor(/// The parse that this stack is part of @internal\n p, /// Holds state, input pos, buffer index triplets for all but the\n /// top state @internal\n stack, /// The current parse state @internal\n state, // The position at which the next reduce should take place. This\n // can be less than `this.pos` when skipped expressions have been\n // added to the stack (which should be moved outside of the next\n // reduction)\n /// @internal\n reducePos, /// The input position up to which this stack has parsed.\n pos, /// The dynamic score of the stack, including dynamic precedence\n /// and error-recovery penalties\n /// @internal\n score, // The output buffer. Holds (type, start, end, size) quads\n // representing nodes created by the parser, where `size` is\n // amount of buffer array entries covered by this node.\n /// @internal\n buffer, // The base offset of the buffer. When stacks are split, the split\n // instance shared the buffer history with its parent up to\n // `bufferBase`, which is the absolute offset (including the\n // offset of previous splits) into the buffer at which this stack\n // starts writing.\n /// @internal\n bufferBase, /// @internal\n curContext, /// @internal\n lookAhead = 0, // A parent stack from which this was split off, if any. This is\n // set up so that it always points to a stack that has some\n // additional buffer content, never to a stack with an equal\n // `bufferBase`.\n /// @internal\n parent){\n this.p = p;\n this.stack = stack;\n this.state = state;\n this.reducePos = reducePos;\n this.pos = pos;\n this.score = score;\n this.buffer = buffer;\n this.bufferBase = bufferBase;\n this.curContext = curContext;\n this.lookAhead = lookAhead;\n this.parent = parent;\n }\n /// @internal\n toString() {\n return `[${this.stack.filter((_, i)=>i % 3 == 0\n ).concat(this.state)}]@${this.pos}${this.score ? \"!\" + this.score : \"\"}`;\n }\n // Start an empty stack\n /// @internal\n static start(p, state, pos = 0) {\n let cx = p.parser.context;\n return new Stack(p, [], state, pos, pos, 0, [], 0, cx ? new StackContext(cx, cx.start) : null, 0, null);\n }\n /// The stack's current [context](#lr.ContextTracker) value, if\n /// any. Its type will depend on the context tracker's type\n /// parameter, or it will be `null` if there is no context\n /// tracker.\n get context() {\n return this.curContext ? this.curContext.context : null;\n }\n // Push a state onto the stack, tracking its start position as well\n // as the buffer base at that point.\n /// @internal\n pushState(state, start) {\n this.stack.push(this.state, start, this.bufferBase + this.buffer.length);\n this.state = state;\n }\n // Apply a reduce action\n /// @internal\n reduce(action) {\n let depth = action >> 19 /* ReduceDepthShift */ , type = action & 65535 /* ValueMask */ ;\n let { parser } = this.p;\n let dPrec = parser.dynamicPrecedence(type);\n if (dPrec) this.score += dPrec;\n if (depth == 0) {\n this.pushState(parser.getGoto(this.state, type, true), this.reducePos);\n // Zero-depth reductions are a special case\u2014they add stuff to\n // the stack without popping anything off.\n if (type < parser.minRepeatTerm) this.storeNode(type, this.reducePos, this.reducePos, 4, true);\n this.reduceContext(type, this.reducePos);\n return;\n }\n // Find the base index into `this.stack`, content after which will\n // be dropped. Note that with `StayFlag` reductions we need to\n // consume two extra frames (the dummy parent node for the skipped\n // expression and the state that we'll be staying in, which should\n // be moved to `this.state`).\n let base = this.stack.length - (depth - 1) * 3 - (action & 262144 /* StayFlag */ ? 6 : 0);\n let start = this.stack[base - 2];\n let bufferBase = this.stack[base - 1], count = this.bufferBase + this.buffer.length - bufferBase;\n // Store normal terms or `R -> R R` repeat reductions\n if (type < parser.minRepeatTerm || action & 131072 /* RepeatFlag */ ) {\n let pos = parser.stateFlag(this.state, 1 /* Skipped */ ) ? this.pos : this.reducePos;\n this.storeNode(type, start, pos, count + 4, true);\n }\n if (action & 262144 /* StayFlag */ ) this.state = this.stack[base];\n else {\n let baseStateID = this.stack[base - 3];\n this.state = parser.getGoto(baseStateID, type, true);\n }\n while(this.stack.length > base)this.stack.pop();\n this.reduceContext(type, start);\n }\n // Shift a value into the buffer\n /// @internal\n storeNode(term, start, end, size = 4, isReduce = false) {\n if (term == 0 /* Err */ ) {\n let cur = this, top = this.buffer.length;\n if (top == 0 && cur.parent) {\n top = cur.bufferBase - cur.parent.bufferBase;\n cur = cur.parent;\n }\n if (top > 0 && cur.buffer[top - 4] == 0 /* Err */ && cur.buffer[top - 1] > -1) {\n if (start == end) return;\n if (cur.buffer[top - 2] >= start) {\n cur.buffer[top - 2] = end;\n return;\n }\n }\n }\n if (!isReduce || this.pos == end) this.buffer.push(term, start, end, size);\n else {\n let index = this.buffer.length;\n if (index > 0 && this.buffer[index - 4] != 0 /* Err */ ) while(index > 0 && this.buffer[index - 2] > end){\n // Move this record forward\n this.buffer[index] = this.buffer[index - 4];\n this.buffer[index + 1] = this.buffer[index - 3];\n this.buffer[index + 2] = this.buffer[index - 2];\n this.buffer[index + 3] = this.buffer[index - 1];\n index -= 4;\n if (size > 4) size -= 4;\n }\n this.buffer[index] = term;\n this.buffer[index + 1] = start;\n this.buffer[index + 2] = end;\n this.buffer[index + 3] = size;\n }\n }\n // Apply a shift action\n /// @internal\n shift(action, next, nextEnd) {\n let start = this.pos;\n if (action & 131072 /* GotoFlag */ ) this.pushState(action & 65535 /* ValueMask */ , this.pos);\n else if ((action & 262144 /* StayFlag */ ) == 0) {\n let nextState = action, { parser } = this.p;\n if (nextEnd > this.pos || next <= parser.maxNode) {\n this.pos = nextEnd;\n if (!parser.stateFlag(nextState, 1 /* Skipped */ )) this.reducePos = nextEnd;\n }\n this.pushState(nextState, start);\n this.shiftContext(next, start);\n if (next <= parser.maxNode) this.buffer.push(next, start, nextEnd, 4);\n } else {\n this.pos = nextEnd;\n this.shiftContext(next, start);\n if (next <= this.p.parser.maxNode) this.buffer.push(next, start, nextEnd, 4);\n }\n }\n // Apply an action\n /// @internal\n apply(action, next, nextEnd) {\n if (action & 65536 /* ReduceFlag */ ) this.reduce(action);\n else this.shift(action, next, nextEnd);\n }\n // Add a prebuilt (reused) node into the buffer.\n /// @internal\n useNode(value, next) {\n let index = this.p.reused.length - 1;\n if (index < 0 || this.p.reused[index] != value) {\n this.p.reused.push(value);\n index++;\n }\n let start = this.pos;\n this.reducePos = this.pos = start + value.length;\n this.pushState(next, start);\n this.buffer.push(index, start, this.reducePos, -1 /* size == -1 means this is a reused value */ );\n if (this.curContext) this.updateContext(this.curContext.tracker.reuse(this.curContext.context, value, this, this.p.stream.reset(this.pos - value.length)));\n }\n // Split the stack. Due to the buffer sharing and the fact\n // that `this.stack` tends to stay quite shallow, this isn't very\n // expensive.\n /// @internal\n split() {\n let parent = this;\n let off = parent.buffer.length;\n // Because the top of the buffer (after this.pos) may be mutated\n // to reorder reductions and skipped tokens, and shared buffers\n // should be immutable, this copies any outstanding skipped tokens\n // to the new buffer, and puts the base pointer before them.\n while(off > 0 && parent.buffer[off - 2] > parent.reducePos)off -= 4;\n let buffer = parent.buffer.slice(off), base = parent.bufferBase + off;\n // Make sure parent points to an actual parent with content, if there is such a parent.\n while(parent && base == parent.bufferBase)parent = parent.parent;\n return new Stack(this.p, this.stack.slice(), this.state, this.reducePos, this.pos, this.score, buffer, base, this.curContext, this.lookAhead, parent);\n }\n // Try to recover from an error by 'deleting' (ignoring) one token.\n /// @internal\n recoverByDelete(next, nextEnd) {\n let isNode = next <= this.p.parser.maxNode;\n if (isNode) this.storeNode(next, this.pos, nextEnd, 4);\n this.storeNode(0 /* Err */ , this.pos, nextEnd, isNode ? 8 : 4);\n this.pos = this.reducePos = nextEnd;\n this.score -= 190 /* Delete */ ;\n }\n /// Check if the given term would be able to be shifted (optionally\n /// after some reductions) on this stack. This can be useful for\n /// external tokenizers that want to make sure they only provide a\n /// given token when it applies.\n canShift(term) {\n for(let sim = new SimulatedStack(this);;){\n let action = this.p.parser.stateSlot(sim.state, 4 /* DefaultReduce */ ) || this.p.parser.hasAction(sim.state, term);\n if ((action & 65536 /* ReduceFlag */ ) == 0) return true;\n if (action == 0) return false;\n sim.reduce(action);\n }\n }\n // Apply up to Recover.MaxNext recovery actions that conceptually\n // inserts some missing token or rule.\n /// @internal\n recoverByInsert(next) {\n if (this.stack.length >= 300 /* MaxInsertStackDepth */ ) return [];\n let nextStates = this.p.parser.nextStates(this.state);\n if (nextStates.length > 8 || this.stack.length >= 120 /* DampenInsertStackDepth */ ) {\n let best = [];\n for(let i2 = 0, s; i2 < nextStates.length; i2 += 2)if ((s = nextStates[i2 + 1]) != this.state && this.p.parser.hasAction(s, next)) best.push(nextStates[i2], s);\n if (this.stack.length < 120 /* DampenInsertStackDepth */ ) for(let i1 = 0; best.length < 8 && i1 < nextStates.length; i1 += 2){\n let s = nextStates[i1 + 1];\n if (!best.some((v, i)=>i & 1 && v == s\n )) best.push(nextStates[i1], s);\n }\n nextStates = best;\n }\n let result = [];\n for(let i = 0; i < nextStates.length && result.length < 4 /* MaxNext */ ; i += 2){\n let s = nextStates[i + 1];\n if (s == this.state) continue;\n let stack = this.split();\n stack.storeNode(0 /* Err */ , stack.pos, stack.pos, 4, true);\n stack.pushState(s, this.pos);\n stack.shiftContext(nextStates[i], this.pos);\n stack.score -= 200 /* Insert */ ;\n result.push(stack);\n }\n return result;\n }\n // Force a reduce, if possible. Return false if that can't\n // be done.\n /// @internal\n forceReduce() {\n let reduce = this.p.parser.stateSlot(this.state, 5 /* ForcedReduce */ );\n if ((reduce & 65536 /* ReduceFlag */ ) == 0) return false;\n let { parser } = this.p;\n if (!parser.validAction(this.state, reduce)) {\n let depth = reduce >> 19 /* ReduceDepthShift */ , term = reduce & 65535 /* ValueMask */ ;\n let target = this.stack.length - depth * 3;\n if (target < 0 || parser.getGoto(this.stack[target], term, false) < 0) return false;\n this.storeNode(0 /* Err */ , this.reducePos, this.reducePos, 4, true);\n this.score -= 100 /* Reduce */ ;\n }\n this.reduce(reduce);\n return true;\n }\n /// @internal\n forceAll() {\n while(!this.p.parser.stateFlag(this.state, 2 /* Accepting */ ))if (!this.forceReduce()) {\n this.storeNode(0 /* Err */ , this.pos, this.pos, 4, true);\n break;\n }\n return this;\n }\n /// Check whether this state has no further actions (assumed to be a direct descendant of the\n /// top state, since any other states must be able to continue\n /// somehow). @internal\n get deadEnd() {\n if (this.stack.length != 3) return false;\n let { parser } = this.p;\n return parser.data[parser.stateSlot(this.state, 1 /* Actions */ )] == 65535 /* End */ && !parser.stateSlot(this.state, 4 /* DefaultReduce */ );\n }\n /// Restart the stack (put it back in its start state). Only safe\n /// when this.stack.length == 3 (state is directly below the top\n /// state). @internal\n restart() {\n this.state = this.stack[0];\n this.stack.length = 0;\n }\n /// @internal\n sameState(other) {\n if (this.state != other.state || this.stack.length != other.stack.length) return false;\n for(let i = 0; i < this.stack.length; i += 3)if (this.stack[i] != other.stack[i]) return false;\n return true;\n }\n /// Get the parser used by this stack.\n get parser() {\n return this.p.parser;\n }\n /// Test whether a given dialect (by numeric ID, as exported from\n /// the terms file) is enabled.\n dialectEnabled(dialectID) {\n return this.p.parser.dialect.flags[dialectID];\n }\n shiftContext(term, start) {\n if (this.curContext) this.updateContext(this.curContext.tracker.shift(this.curContext.context, term, this, this.p.stream.reset(start)));\n }\n reduceContext(term, start) {\n if (this.curContext) this.updateContext(this.curContext.tracker.reduce(this.curContext.context, term, this, this.p.stream.reset(start)));\n }\n /// @internal\n emitContext() {\n let last = this.buffer.length - 1;\n if (last < 0 || this.buffer[last] != -3) this.buffer.push(this.curContext.hash, this.reducePos, this.reducePos, -3);\n }\n /// @internal\n emitLookAhead() {\n let last = this.buffer.length - 1;\n if (last < 0 || this.buffer[last] != -4) this.buffer.push(this.lookAhead, this.reducePos, this.reducePos, -4);\n }\n updateContext(context) {\n if (context != this.curContext.context) {\n let newCx = new StackContext(this.curContext.tracker, context);\n if (newCx.hash != this.curContext.hash) this.emitContext();\n this.curContext = newCx;\n }\n }\n /// @internal\n setLookAhead(lookAhead) {\n if (lookAhead > this.lookAhead) {\n this.emitLookAhead();\n this.lookAhead = lookAhead;\n }\n }\n /// @internal\n close() {\n if (this.curContext && this.curContext.tracker.strict) this.emitContext();\n if (this.lookAhead > 0) this.emitLookAhead();\n }\n}\nclass StackContext {\n constructor(tracker, context){\n this.tracker = tracker;\n this.context = context;\n this.hash = tracker.strict ? tracker.hash(context) : 0;\n }\n}\nvar Recover;\n(function(Recover1) {\n Recover1[Recover1[\"Insert\"] = 200] = \"Insert\";\n Recover1[Recover1[\"Delete\"] = 190] = \"Delete\";\n Recover1[Recover1[\"Reduce\"] = 100] = \"Reduce\";\n Recover1[Recover1[\"MaxNext\"] = 4] = \"MaxNext\";\n Recover1[Recover1[\"MaxInsertStackDepth\"] = 300] = \"MaxInsertStackDepth\";\n Recover1[Recover1[\"DampenInsertStackDepth\"] = 120] = \"DampenInsertStackDepth\";\n})(Recover || (Recover = {\n}));\n// Used to cheaply run some reductions to scan ahead without mutating\n// an entire stack\nclass SimulatedStack {\n constructor(start){\n this.start = start;\n this.state = start.state;\n this.stack = start.stack;\n this.base = this.stack.length;\n }\n reduce(action) {\n let term = action & 65535 /* ValueMask */ , depth = action >> 19 /* ReduceDepthShift */ ;\n if (depth == 0) {\n if (this.stack == this.start.stack) this.stack = this.stack.slice();\n this.stack.push(this.state, 0, 0);\n this.base += 3;\n } else this.base -= (depth - 1) * 3;\n let goto = this.start.p.parser.getGoto(this.stack[this.base - 3], term, true);\n this.state = goto;\n }\n}\n// This is given to `Tree.build` to build a buffer, and encapsulates\n// the parent-stack-walking necessary to read the nodes.\nclass StackBufferCursor {\n constructor(stack, pos, index){\n this.stack = stack;\n this.pos = pos;\n this.index = index;\n this.buffer = stack.buffer;\n if (this.index == 0) this.maybeNext();\n }\n static create(stack, pos = stack.bufferBase + stack.buffer.length) {\n return new StackBufferCursor(stack, pos, pos - stack.bufferBase);\n }\n maybeNext() {\n let next = this.stack.parent;\n if (next != null) {\n this.index = this.stack.bufferBase - next.bufferBase;\n this.stack = next;\n this.buffer = next.buffer;\n }\n }\n get id() {\n return this.buffer[this.index - 4];\n }\n get start() {\n return this.buffer[this.index - 3];\n }\n get end() {\n return this.buffer[this.index - 2];\n }\n get size() {\n return this.buffer[this.index - 1];\n }\n next() {\n this.index -= 4;\n this.pos -= 4;\n if (this.index == 0) this.maybeNext();\n }\n fork() {\n return new StackBufferCursor(this.stack, this.pos, this.index);\n }\n}\nclass CachedToken {\n constructor(){\n this.start = -1;\n this.value = -1;\n this.end = -1;\n this.extended = -1;\n this.lookAhead = 0;\n this.mask = 0;\n this.context = 0;\n }\n}\nconst nullToken = new CachedToken;\n/// [Tokenizers](#lr.ExternalTokenizer) interact with the input\n/// through this interface. It presents the input as a stream of\n/// characters, tracking lookahead and hiding the complexity of\n/// [ranges](#common.Parser.parse^ranges) from tokenizer code.\nclass InputStream {\n /// @internal\n constructor(/// @internal\n input, /// @internal\n ranges){\n this.input = input;\n this.ranges = ranges;\n /// @internal\n this.chunk = \"\";\n /// @internal\n this.chunkOff = 0;\n /// Backup chunk\n this.chunk2 = \"\";\n this.chunk2Pos = 0;\n /// The character code of the next code unit in the input, or -1\n /// when the stream is at the end of the input.\n this.next = -1;\n /// @internal\n this.token = nullToken;\n this.rangeIndex = 0;\n this.pos = this.chunkPos = ranges[0].from;\n this.range = ranges[0];\n this.end = ranges[ranges.length - 1].to;\n this.readNext();\n }\n resolveOffset(offset, assoc) {\n let range = this.range, index = this.rangeIndex;\n let pos = this.pos + offset;\n while(pos < range.from){\n if (!index) return null;\n let next = this.ranges[--index];\n pos -= range.from - next.to;\n range = next;\n }\n while(assoc < 0 ? pos > range.to : pos >= range.to){\n if (index == this.ranges.length - 1) return null;\n let next = this.ranges[++index];\n pos += next.from - range.to;\n range = next;\n }\n return pos;\n }\n /// Look at a code unit near the stream position. `.peek(0)` equals\n /// `.next`, `.peek(-1)` gives you the previous character, and so\n /// on.\n ///\n /// Note that looking around during tokenizing creates dependencies\n /// on potentially far-away content, which may reduce the\n /// effectiveness incremental parsing\u2014when looking forward\u2014or even\n /// cause invalid reparses when looking backward more than 25 code\n /// units, since the library does not track lookbehind.\n peek(offset) {\n let idx = this.chunkOff + offset, pos, result;\n if (idx >= 0 && idx < this.chunk.length) {\n pos = this.pos + offset;\n result = this.chunk.charCodeAt(idx);\n } else {\n let resolved = this.resolveOffset(offset, 1);\n if (resolved == null) return -1;\n pos = resolved;\n if (pos >= this.chunk2Pos && pos < this.chunk2Pos + this.chunk2.length) result = this.chunk2.charCodeAt(pos - this.chunk2Pos);\n else {\n let i = this.rangeIndex, range = this.range;\n while(range.to <= pos)range = this.ranges[++i];\n this.chunk2 = this.input.chunk(this.chunk2Pos = pos);\n if (pos + this.chunk2.length > range.to) this.chunk2 = this.chunk2.slice(0, range.to - pos);\n result = this.chunk2.charCodeAt(0);\n }\n }\n if (pos >= this.token.lookAhead) this.token.lookAhead = pos + 1;\n return result;\n }\n /// Accept a token. By default, the end of the token is set to the\n /// current stream position, but you can pass an offset (relative to\n /// the stream position) to change that.\n acceptToken(token, endOffset = 0) {\n let end = endOffset ? this.resolveOffset(endOffset, -1) : this.pos;\n if (end == null || end < this.token.start) throw new RangeError(\"Token end out of bounds\");\n this.token.value = token;\n this.token.end = end;\n }\n getChunk() {\n if (this.pos >= this.chunk2Pos && this.pos < this.chunk2Pos + this.chunk2.length) {\n let { chunk , chunkPos } = this;\n this.chunk = this.chunk2;\n this.chunkPos = this.chunk2Pos;\n this.chunk2 = chunk;\n this.chunk2Pos = chunkPos;\n this.chunkOff = this.pos - this.chunkPos;\n } else {\n this.chunk2 = this.chunk;\n this.chunk2Pos = this.chunkPos;\n let nextChunk = this.input.chunk(this.pos);\n let end = this.pos + nextChunk.length;\n this.chunk = end > this.range.to ? nextChunk.slice(0, this.range.to - this.pos) : nextChunk;\n this.chunkPos = this.pos;\n this.chunkOff = 0;\n }\n }\n readNext() {\n if (this.chunkOff >= this.chunk.length) {\n this.getChunk();\n if (this.chunkOff == this.chunk.length) return this.next = -1;\n }\n return this.next = this.chunk.charCodeAt(this.chunkOff);\n }\n /// Move the stream forward N (defaults to 1) code units. Returns\n /// the new value of [`next`](#lr.InputStream.next).\n advance(n = 1) {\n this.chunkOff += n;\n while(this.pos + n >= this.range.to){\n if (this.rangeIndex == this.ranges.length - 1) return this.setDone();\n n -= this.range.to - this.pos;\n this.range = this.ranges[++this.rangeIndex];\n this.pos = this.range.from;\n }\n this.pos += n;\n if (this.pos >= this.token.lookAhead) this.token.lookAhead = this.pos + 1;\n return this.readNext();\n }\n setDone() {\n this.pos = this.chunkPos = this.end;\n this.range = this.ranges[this.rangeIndex = this.ranges.length - 1];\n this.chunk = \"\";\n return this.next = -1;\n }\n /// @internal\n reset(pos, token) {\n if (token) {\n this.token = token;\n token.start = pos;\n token.lookAhead = pos + 1;\n token.value = token.extended = -1;\n } else this.token = nullToken;\n if (this.pos != pos) {\n this.pos = pos;\n if (pos == this.end) {\n this.setDone();\n return this;\n }\n while(pos < this.range.from)this.range = this.ranges[--this.rangeIndex];\n while(pos >= this.range.to)this.range = this.ranges[++this.rangeIndex];\n if (pos >= this.chunkPos && pos < this.chunkPos + this.chunk.length) this.chunkOff = pos - this.chunkPos;\n else {\n this.chunk = \"\";\n this.chunkOff = 0;\n }\n this.readNext();\n }\n return this;\n }\n /// @internal\n read(from, to) {\n if (from >= this.chunkPos && to <= this.chunkPos + this.chunk.length) return this.chunk.slice(from - this.chunkPos, to - this.chunkPos);\n if (from >= this.chunk2Pos && to <= this.chunk2Pos + this.chunk2.length) return this.chunk2.slice(from - this.chunk2Pos, to - this.chunk2Pos);\n if (from >= this.range.from && to <= this.range.to) return this.input.read(from, to);\n let result = \"\";\n for (let r of this.ranges){\n if (r.from >= to) break;\n if (r.to > from) result += this.input.read(Math.max(r.from, from), Math.min(r.to, to));\n }\n return result;\n }\n}\n/// @internal\nclass TokenGroup {\n constructor(data, id1){\n this.data = data;\n this.id = id1;\n }\n token(input, stack) {\n readToken(this.data, input, stack, this.id);\n }\n}\nTokenGroup.prototype.contextual = TokenGroup.prototype.fallback = TokenGroup.prototype.extend = false;\n/// `@external tokens` declarations in the grammar should resolve to\n/// an instance of this class.\nclass ExternalTokenizer {\n /// Create a tokenizer. The first argument is the function that,\n /// given an input stream, scans for the types of tokens it\n /// recognizes at the stream's position, and calls\n /// [`acceptToken`](#lr.InputStream.acceptToken) when it finds\n /// one.\n constructor(/// @internal\n token, options = {\n }){\n this.token = token;\n this.contextual = !!options.contextual;\n this.fallback = !!options.fallback;\n this.extend = !!options.extend;\n }\n}\n// Tokenizer data is stored a big uint16 array containing, for each\n// state:\n//\n// - A group bitmask, indicating what token groups are reachable from\n// this state, so that paths that can only lead to tokens not in\n// any of the current groups can be cut off early.\n//\n// - The position of the end of the state's sequence of accepting\n// tokens\n//\n// - The number of outgoing edges for the state\n//\n// - The accepting tokens, as (token id, group mask) pairs\n//\n// - The outgoing edges, as (start character, end character, state\n// index) triples, with end character being exclusive\n//\n// This function interprets that data, running through a stream as\n// long as new states with the a matching group mask can be reached,\n// and updating `token` when it matches a token.\nfunction readToken(data, input, stack, group) {\n let state = 0, groupMask = 1 << group, { parser } = stack.p, { dialect } = parser;\n scan: for(;;){\n if ((groupMask & data[state]) == 0) break;\n let accEnd = data[state + 1];\n // Check whether this state can lead to a token in the current group\n // Accept tokens in this state, possibly overwriting\n // lower-precedence / shorter tokens\n for(let i = state + 3; i < accEnd; i += 2)if ((data[i + 1] & groupMask) > 0) {\n let term = data[i];\n if (dialect.allows(term) && (input.token.value == -1 || input.token.value == term || parser.overrides(term, input.token.value))) {\n input.acceptToken(term);\n break;\n }\n }\n // Do a binary search on the state's edges\n for(let next = input.next, low = 0, high = data[state + 2]; low < high;){\n let mid = low + high >> 1;\n let index = accEnd + mid + (mid << 1);\n let from = data[index], to = data[index + 1];\n if (next < from) high = mid;\n else if (next >= to) low = mid + 1;\n else {\n state = data[index + 2];\n input.advance();\n continue scan;\n }\n }\n break;\n }\n}\n// See lezer-generator/src/encode.ts for comments about the encoding\n// used here\nfunction decodeArray(input, Type = Uint16Array) {\n if (typeof input != \"string\") return input;\n let array = null;\n for(let pos = 0, out = 0; pos < input.length;){\n let value = 0;\n for(;;){\n let next = input.charCodeAt(pos++), stop = false;\n if (next == 126 /* BigValCode */ ) {\n value = 65535 /* BigVal */ ;\n break;\n }\n if (next >= 92 /* Gap2 */ ) next--;\n if (next >= 34 /* Gap1 */ ) next--;\n let digit = next - 32 /* Start */ ;\n if (digit >= 46 /* Base */ ) {\n digit -= 46 /* Base */ ;\n stop = true;\n }\n value += digit;\n if (stop) break;\n value *= 46 /* Base */ ;\n }\n if (array) array[out++] = value;\n else array = new Type(value);\n }\n return array;\n}\n// FIXME find some way to reduce recovery work done when the input\n// doesn't match the grammar at all.\n// Environment variable used to control console output\nconst verbose = typeof process != \"undefined\" && /\\bparse\\b/.test(undefined);\nlet stackIDs = null;\nvar Safety;\n(function(Safety1) {\n Safety1[Safety1[\"Margin\"] = 25] = \"Margin\";\n})(Safety || (Safety = {\n}));\nfunction cutAt(tree, pos, side) {\n let cursor = tree.fullCursor();\n cursor.moveTo(pos);\n for(;;){\n if (!(side < 0 ? cursor.childBefore(pos) : cursor.childAfter(pos))) for(;;){\n if ((side < 0 ? cursor.to < pos : cursor.from > pos) && !cursor.type.isError) return side < 0 ? Math.max(0, Math.min(cursor.to - 1, pos - 25 /* Margin */ )) : Math.min(tree.length, Math.max(cursor.from + 1, pos + 25 /* Margin */ ));\n if (side < 0 ? cursor.prevSibling() : cursor.nextSibling()) break;\n if (!cursor.parent()) return side < 0 ? 0 : tree.length;\n }\n }\n}\nclass FragmentCursor {\n constructor(fragments, nodeSet){\n this.fragments = fragments;\n this.nodeSet = nodeSet;\n this.i = 0;\n this.fragment = null;\n this.safeFrom = -1;\n this.safeTo = -1;\n this.trees = [];\n this.start = [];\n this.index = [];\n this.nextFragment();\n }\n nextFragment() {\n let fr = this.fragment = this.i == this.fragments.length ? null : this.fragments[this.i++];\n if (fr) {\n this.safeFrom = fr.openStart ? cutAt(fr.tree, fr.from + fr.offset, 1) - fr.offset : fr.from;\n this.safeTo = fr.openEnd ? cutAt(fr.tree, fr.to + fr.offset, -1) - fr.offset : fr.to;\n while(this.trees.length){\n this.trees.pop();\n this.start.pop();\n this.index.pop();\n }\n this.trees.push(fr.tree);\n this.start.push(-fr.offset);\n this.index.push(0);\n this.nextStart = this.safeFrom;\n } else this.nextStart = 1000000000;\n }\n // `pos` must be >= any previously given `pos` for this cursor\n nodeAt(pos) {\n if (pos < this.nextStart) return null;\n while(this.fragment && this.safeTo <= pos)this.nextFragment();\n if (!this.fragment) return null;\n for(;;){\n let last = this.trees.length - 1;\n if (last < 0) {\n this.nextFragment();\n return null;\n }\n let top = this.trees[last], index = this.index[last];\n if (index == top.children.length) {\n this.trees.pop();\n this.start.pop();\n this.index.pop();\n continue;\n }\n let next = top.children[index];\n let start = this.start[last] + top.positions[index];\n if (start > pos) {\n this.nextStart = start;\n return null;\n }\n if (next instanceof _common.Tree) {\n if (start == pos) {\n if (start < this.safeFrom) return null;\n let end = start + next.length;\n if (end <= this.safeTo) {\n let lookAhead = next.prop(_common.NodeProp.lookAhead);\n if (!lookAhead || end + lookAhead < this.fragment.to) return next;\n }\n }\n this.index[last]++;\n if (start + next.length >= Math.max(this.safeFrom, pos)) {\n this.trees.push(next);\n this.start.push(start);\n this.index.push(0);\n }\n } else {\n this.index[last]++;\n this.nextStart = start + next.length;\n }\n }\n }\n}\nclass TokenCache {\n constructor(parser, stream){\n this.stream = stream;\n this.tokens = [];\n this.mainToken = null;\n this.actions = [];\n this.tokens = parser.tokenizers.map((_)=>new CachedToken\n );\n }\n getActions(stack) {\n let actionIndex = 0;\n let main = null;\n let { parser } = stack.p, { tokenizers } = parser;\n let mask = parser.stateSlot(stack.state, 3 /* TokenizerMask */ );\n let context = stack.curContext ? stack.curContext.hash : 0;\n let lookAhead = 0;\n for(let i = 0; i < tokenizers.length; i++){\n if ((1 << i & mask) == 0) continue;\n let tokenizer = tokenizers[i], token = this.tokens[i];\n if (main && !tokenizer.fallback) continue;\n if (tokenizer.contextual || token.start != stack.pos || token.mask != mask || token.context != context) {\n this.updateCachedToken(token, tokenizer, stack);\n token.mask = mask;\n token.context = context;\n }\n if (token.lookAhead > token.end + 25 /* Margin */ ) lookAhead = Math.max(token.lookAhead, lookAhead);\n if (token.value != 0 /* Err */ ) {\n let startIndex = actionIndex;\n if (token.extended > -1) actionIndex = this.addActions(stack, token.extended, token.end, actionIndex);\n actionIndex = this.addActions(stack, token.value, token.end, actionIndex);\n if (!tokenizer.extend) {\n main = token;\n if (actionIndex > startIndex) break;\n }\n }\n }\n while(this.actions.length > actionIndex)this.actions.pop();\n if (lookAhead) stack.setLookAhead(lookAhead);\n if (!main && stack.pos == this.stream.end) {\n main = new CachedToken;\n main.value = stack.p.parser.eofTerm;\n main.start = main.end = stack.pos;\n actionIndex = this.addActions(stack, main.value, main.end, actionIndex);\n }\n this.mainToken = main;\n return this.actions;\n }\n getMainToken(stack) {\n if (this.mainToken) return this.mainToken;\n let main = new CachedToken, { pos , p } = stack;\n main.start = pos;\n main.end = Math.min(pos + 1, p.stream.end);\n main.value = pos == p.stream.end ? p.parser.eofTerm : 0 /* Err */ ;\n return main;\n }\n updateCachedToken(token, tokenizer, stack) {\n tokenizer.token(this.stream.reset(stack.pos, token), stack);\n if (token.value > -1) {\n let { parser } = stack.p;\n for(let i = 0; i < parser.specialized.length; i++)if (parser.specialized[i] == token.value) {\n let result = parser.specializers[i](this.stream.read(token.start, token.end), stack);\n if (result >= 0 && stack.p.parser.dialect.allows(result >> 1)) {\n if ((result & 1) == 0 /* Specialize */ ) token.value = result >> 1;\n else token.extended = result >> 1;\n break;\n }\n }\n } else {\n token.value = 0 /* Err */ ;\n token.end = Math.min(stack.p.stream.end, stack.pos + 1);\n }\n }\n putAction(action, token, end, index) {\n // Don't add duplicate actions\n for(let i = 0; i < index; i += 3)if (this.actions[i] == action) return index;\n this.actions[index++] = action;\n this.actions[index++] = token;\n this.actions[index++] = end;\n return index;\n }\n addActions(stack, token, end, index) {\n let { state } = stack, { parser } = stack.p, { data } = parser;\n for(let set = 0; set < 2; set++)for(let i = parser.stateSlot(state, set ? 2 /* Skip */ : 1 /* Actions */ );; i += 3){\n if (data[i] == 65535 /* End */ ) {\n if (data[i + 1] == 1 /* Next */ ) i = pair(data, i + 2);\n else {\n if (index == 0 && data[i + 1] == 2 /* Other */ ) index = this.putAction(pair(data, i + 2), token, end, index);\n break;\n }\n }\n if (data[i] == token) index = this.putAction(pair(data, i + 1), token, end, index);\n }\n return index;\n }\n}\nvar Rec;\n(function(Rec1) {\n Rec1[Rec1[\"Distance\"] = 5] = \"Distance\";\n Rec1[Rec1[\"MaxRemainingPerStep\"] = 3] = \"MaxRemainingPerStep\";\n // When two stacks have been running independently long enough to\n // add this many elements to their buffers, prune one.\n Rec1[Rec1[\"MinBufferLengthPrune\"] = 500] = \"MinBufferLengthPrune\";\n Rec1[Rec1[\"ForceReduceLimit\"] = 10] = \"ForceReduceLimit\";\n // Once a stack reaches this depth (in .stack.length) force-reduce\n // it back to CutTo to avoid creating trees that overflow the stack\n // on recursive traversal.\n Rec1[Rec1[\"CutDepth\"] = 15000] = \"CutDepth\";\n Rec1[Rec1[\"CutTo\"] = 9000] = \"CutTo\";\n})(Rec || (Rec = {\n}));\nclass Parse {\n constructor(parser, input, fragments, ranges){\n this.parser = parser;\n this.input = input;\n this.ranges = ranges;\n this.recovering = 0;\n this.nextStackID = 9812; // \u2654, \u2655, \u2656, \u2657, \u2658, \u2659, \u2660, \u2661, \u2662, \u2663, \u2664, \u2665, \u2666, \u2667\n this.minStackPos = 0;\n this.reused = [];\n this.stoppedAt = null;\n this.stream = new InputStream(input, ranges);\n this.tokens = new TokenCache(parser, this.stream);\n this.topTerm = parser.top[1];\n let { from } = ranges[0];\n this.stacks = [\n Stack.start(this, parser.top[0], from)\n ];\n this.fragments = fragments.length && this.stream.end - from > parser.bufferLength * 4 ? new FragmentCursor(fragments, parser.nodeSet) : null;\n }\n get parsedPos() {\n return this.minStackPos;\n }\n // Move the parser forward. This will process all parse stacks at\n // `this.pos` and try to advance them to a further position. If no\n // stack for such a position is found, it'll start error-recovery.\n //\n // When the parse is finished, this will return a syntax tree. When\n // not, it returns `null`.\n advance() {\n let stacks = this.stacks, pos = this.minStackPos;\n // This will hold stacks beyond `pos`.\n let newStacks = this.stacks = [];\n let stopped, stoppedTokens;\n // Keep advancing any stacks at `pos` until they either move\n // forward or can't be advanced. Gather stacks that can't be\n // advanced further in `stopped`.\n for(let i = 0; i < stacks.length; i++){\n let stack = stacks[i];\n for(;;){\n this.tokens.mainToken = null;\n if (stack.pos > pos) newStacks.push(stack);\n else if (this.advanceStack(stack, newStacks, stacks)) continue;\n else {\n if (!stopped) {\n stopped = [];\n stoppedTokens = [];\n }\n stopped.push(stack);\n let tok = this.tokens.getMainToken(stack);\n stoppedTokens.push(tok.value, tok.end);\n }\n break;\n }\n }\n if (!newStacks.length) {\n let finished = stopped && findFinished(stopped);\n if (finished) return this.stackToTree(finished);\n if (this.parser.strict) {\n if (verbose && stopped) console.log(\"Stuck with token \" + (this.tokens.mainToken ? this.parser.getName(this.tokens.mainToken.value) : \"none\"));\n throw new SyntaxError(\"No parse at \" + pos);\n }\n if (!this.recovering) this.recovering = 5 /* Distance */ ;\n }\n if (this.recovering && stopped) {\n let finished = this.stoppedAt != null && stopped[0].pos > this.stoppedAt ? stopped[0] : this.runRecovery(stopped, stoppedTokens, newStacks);\n if (finished) return this.stackToTree(finished.forceAll());\n }\n if (this.recovering) {\n let maxRemaining = this.recovering == 1 ? 1 : this.recovering * 3 /* MaxRemainingPerStep */ ;\n if (newStacks.length > maxRemaining) {\n newStacks.sort((a, b)=>b.score - a.score\n );\n while(newStacks.length > maxRemaining)newStacks.pop();\n }\n if (newStacks.some((s)=>s.reducePos > pos\n )) this.recovering--;\n } else if (newStacks.length > 1) // Prune stacks that are in the same state, or that have been\n // running without splitting for a while, to avoid getting stuck\n // with multiple successful stacks running endlessly on.\n outer: for(let i3 = 0; i3 < newStacks.length - 1; i3++){\n let stack = newStacks[i3];\n for(let j = i3 + 1; j < newStacks.length; j++){\n let other = newStacks[j];\n if (stack.sameState(other) || stack.buffer.length > 500 /* MinBufferLengthPrune */ && other.buffer.length > 500 /* MinBufferLengthPrune */ ) {\n if ((stack.score - other.score || stack.buffer.length - other.buffer.length) > 0) newStacks.splice(j--, 1);\n else {\n newStacks.splice(i3--, 1);\n continue outer;\n }\n }\n }\n }\n this.minStackPos = newStacks[0].pos;\n for(let i4 = 1; i4 < newStacks.length; i4++)if (newStacks[i4].pos < this.minStackPos) this.minStackPos = newStacks[i4].pos;\n return null;\n }\n stopAt(pos) {\n if (this.stoppedAt != null && this.stoppedAt < pos) throw new RangeError(\"Can't move stoppedAt forward\");\n this.stoppedAt = pos;\n }\n // Returns an updated version of the given stack, or null if the\n // stack can't advance normally. When `split` and `stacks` are\n // given, stacks split off by ambiguous operations will be pushed to\n // `split`, or added to `stacks` if they move `pos` forward.\n advanceStack(stack, stacks, split) {\n let start = stack.pos, { parser } = this;\n let base = verbose ? this.stackID(stack) + \" -> \" : \"\";\n if (this.stoppedAt != null && start > this.stoppedAt) return stack.forceReduce() ? stack : null;\n if (this.fragments) {\n let strictCx = stack.curContext && stack.curContext.tracker.strict, cxHash = strictCx ? stack.curContext.hash : 0;\n for(let cached = this.fragments.nodeAt(start); cached;){\n let match = this.parser.nodeSet.types[cached.type.id] == cached.type ? parser.getGoto(stack.state, cached.type.id) : -1;\n if (match > -1 && cached.length && (!strictCx || (cached.prop(_common.NodeProp.contextHash) || 0) == cxHash)) {\n stack.useNode(cached, match);\n if (verbose) console.log(base + this.stackID(stack) + ` (via reuse of ${parser.getName(cached.type.id)})`);\n return true;\n }\n if (!(cached instanceof _common.Tree) || cached.children.length == 0 || cached.positions[0] > 0) break;\n let inner = cached.children[0];\n if (inner instanceof _common.Tree && cached.positions[0] == 0) cached = inner;\n else break;\n }\n }\n let defaultReduce = parser.stateSlot(stack.state, 4 /* DefaultReduce */ );\n if (defaultReduce > 0) {\n stack.reduce(defaultReduce);\n if (verbose) console.log(base + this.stackID(stack) + ` (via always-reduce ${parser.getName(defaultReduce & 65535 /* ValueMask */ )})`);\n return true;\n }\n if (stack.stack.length >= 15000 /* CutDepth */ ) {\n while(stack.stack.length > 9000 /* CutTo */ && stack.forceReduce());\n }\n let actions = this.tokens.getActions(stack);\n for(let i = 0; i < actions.length;){\n let action = actions[i++], term = actions[i++], end = actions[i++];\n let last = i == actions.length || !split;\n let localStack = last ? stack : stack.split();\n localStack.apply(action, term, end);\n if (verbose) console.log(base + this.stackID(localStack) + ` (via ${(action & 65536 /* ReduceFlag */ ) == 0 ? \"shift\" : `reduce of ${parser.getName(action & 65535 /* ValueMask */ )}`} for ${parser.getName(term)} @ ${start}${localStack == stack ? \"\" : \", split\"})`);\n if (last) return true;\n else if (localStack.pos > start) stacks.push(localStack);\n else split.push(localStack);\n }\n return false;\n }\n // Advance a given stack forward as far as it will go. Returns the\n // (possibly updated) stack if it got stuck, or null if it moved\n // forward and was given to `pushStackDedup`.\n advanceFully(stack, newStacks) {\n let pos = stack.pos;\n for(;;){\n if (!this.advanceStack(stack, null, null)) return false;\n if (stack.pos > pos) {\n pushStackDedup(stack, newStacks);\n return true;\n }\n }\n }\n runRecovery(stacks, tokens, newStacks) {\n let finished = null, restarted = false;\n for(let i = 0; i < stacks.length; i++){\n let stack = stacks[i], token = tokens[i << 1], tokenEnd = tokens[(i << 1) + 1];\n let base = verbose ? this.stackID(stack) + \" -> \" : \"\";\n if (stack.deadEnd) {\n if (restarted) continue;\n restarted = true;\n stack.restart();\n if (verbose) console.log(base + this.stackID(stack) + \" (restarted)\");\n let done = this.advanceFully(stack, newStacks);\n if (done) continue;\n }\n let force = stack.split(), forceBase = base;\n for(let j = 0; force.forceReduce() && j < 10 /* ForceReduceLimit */ ; j++){\n if (verbose) console.log(forceBase + this.stackID(force) + \" (via force-reduce)\");\n let done = this.advanceFully(force, newStacks);\n if (done) break;\n if (verbose) forceBase = this.stackID(force) + \" -> \";\n }\n for (let insert of stack.recoverByInsert(token)){\n if (verbose) console.log(base + this.stackID(insert) + \" (via recover-insert)\");\n this.advanceFully(insert, newStacks);\n }\n if (this.stream.end > stack.pos) {\n if (tokenEnd == stack.pos) {\n tokenEnd++;\n token = 0 /* Err */ ;\n }\n stack.recoverByDelete(token, tokenEnd);\n if (verbose) console.log(base + this.stackID(stack) + ` (via recover-delete ${this.parser.getName(token)})`);\n pushStackDedup(stack, newStacks);\n } else if (!finished || finished.score < stack.score) finished = stack;\n }\n return finished;\n }\n // Convert the stack's buffer to a syntax tree.\n stackToTree(stack) {\n stack.close();\n return _common.Tree.build({\n buffer: StackBufferCursor.create(stack),\n nodeSet: this.parser.nodeSet,\n topID: this.topTerm,\n maxBufferLength: this.parser.bufferLength,\n reused: this.reused,\n start: this.ranges[0].from,\n length: stack.pos - this.ranges[0].from,\n minRepeatType: this.parser.minRepeatTerm\n });\n }\n stackID(stack) {\n let id2 = (stackIDs || (stackIDs = new WeakMap)).get(stack);\n if (!id2) stackIDs.set(stack, id2 = String.fromCodePoint(this.nextStackID++));\n return id2 + stack;\n }\n}\nfunction pushStackDedup(stack, newStacks) {\n for(let i = 0; i < newStacks.length; i++){\n let other = newStacks[i];\n if (other.pos == stack.pos && other.sameState(stack)) {\n if (newStacks[i].score < stack.score) newStacks[i] = stack;\n return;\n }\n }\n newStacks.push(stack);\n}\nclass Dialect {\n constructor(source, flags, disabled){\n this.source = source;\n this.flags = flags;\n this.disabled = disabled;\n }\n allows(term) {\n return !this.disabled || this.disabled[term] == 0;\n }\n}\nconst id = (x)=>x\n;\n/// Context trackers are used to track stateful context (such as\n/// indentation in the Python grammar, or parent elements in the XML\n/// grammar) needed by external tokenizers. You declare them in a\n/// grammar file as `@context exportName from \"module\"`.\n///\n/// Context values should be immutable, and can be updated (replaced)\n/// on shift or reduce actions.\n///\n/// The export used in a `@context` declaration should be of this\n/// type.\nclass ContextTracker {\n /// Define a context tracker.\n constructor(spec){\n this.start = spec.start;\n this.shift = spec.shift || id;\n this.reduce = spec.reduce || id;\n this.reuse = spec.reuse || id;\n this.hash = spec.hash || (()=>0\n );\n this.strict = spec.strict !== false;\n }\n}\n/// A parser holds the parse tables for a given grammar, as generated\n/// by `lezer-generator`.\nclass LRParser extends _common.Parser {\n /// @internal\n constructor(spec){\n super();\n /// @internal\n this.wrappers = [];\n if (spec.version != 13 /* Version */ ) throw new RangeError(`Parser version (${spec.version}) doesn't match runtime version (${13 /* Version */ })`);\n let nodeNames = spec.nodeNames.split(\" \");\n this.minRepeatTerm = nodeNames.length;\n for(let i7 = 0; i7 < spec.repeatNodeCount; i7++)nodeNames.push(\"\");\n let topTerms = Object.keys(spec.topRules).map((r)=>spec.topRules[r][1]\n );\n let nodeProps = [];\n for(let i5 = 0; i5 < nodeNames.length; i5++)nodeProps.push([]);\n function setProp(nodeID, prop, value) {\n nodeProps[nodeID].push([\n prop,\n prop.deserialize(String(value))\n ]);\n }\n if (spec.nodeProps) for (let propSpec of spec.nodeProps){\n let prop = propSpec[0];\n for(let i = 1; i < propSpec.length;){\n let next = propSpec[i++];\n if (next >= 0) setProp(next, prop, propSpec[i++]);\n else {\n let value = propSpec[i + -next];\n for(let j = -next; j > 0; j--)setProp(propSpec[i++], prop, value);\n i++;\n }\n }\n }\n this.nodeSet = new _common.NodeSet(nodeNames.map((name, i)=>_common.NodeType.define({\n name: i >= this.minRepeatTerm ? undefined : name,\n id: i,\n props: nodeProps[i],\n top: topTerms.indexOf(i) > -1,\n error: i == 0,\n skipped: spec.skippedNodes && spec.skippedNodes.indexOf(i) > -1\n })\n ));\n this.strict = false;\n this.bufferLength = _common.DefaultBufferLength;\n let tokenArray = decodeArray(spec.tokenData);\n this.context = spec.context;\n this.specialized = new Uint16Array(spec.specialized ? spec.specialized.length : 0);\n this.specializers = [];\n if (spec.specialized) for(let i6 = 0; i6 < spec.specialized.length; i6++){\n this.specialized[i6] = spec.specialized[i6].term;\n this.specializers[i6] = spec.specialized[i6].get;\n }\n this.states = decodeArray(spec.states, Uint32Array);\n this.data = decodeArray(spec.stateData);\n this.goto = decodeArray(spec.goto);\n this.maxTerm = spec.maxTerm;\n this.tokenizers = spec.tokenizers.map((value)=>typeof value == \"number\" ? new TokenGroup(tokenArray, value) : value\n );\n this.topRules = spec.topRules;\n this.dialects = spec.dialects || {\n };\n this.dynamicPrecedences = spec.dynamicPrecedences || null;\n this.tokenPrecTable = spec.tokenPrec;\n this.termNames = spec.termNames || null;\n this.maxNode = this.nodeSet.types.length - 1;\n this.dialect = this.parseDialect();\n this.top = this.topRules[Object.keys(this.topRules)[0]];\n }\n createParse(input, fragments, ranges) {\n let parse = new Parse(this, input, fragments, ranges);\n for (let w of this.wrappers)parse = w(parse, input, fragments, ranges);\n return parse;\n }\n /// Get a goto table entry @internal\n getGoto(state, term, loose = false) {\n let table = this.goto;\n if (term >= table[0]) return -1;\n for(let pos = table[term + 1];;){\n let groupTag = table[pos++], last = groupTag & 1;\n let target = table[pos++];\n if (last && loose) return target;\n for(let end = pos + (groupTag >> 1); pos < end; pos++)if (table[pos] == state) return target;\n if (last) return -1;\n }\n }\n /// Check if this state has an action for a given terminal @internal\n hasAction(state, terminal) {\n let data = this.data;\n for(let set = 0; set < 2; set++)for(let i = this.stateSlot(state, set ? 2 /* Skip */ : 1 /* Actions */ ), next;; i += 3){\n if ((next = data[i]) == 65535 /* End */ ) {\n if (data[i + 1] == 1 /* Next */ ) next = data[i = pair(data, i + 2)];\n else if (data[i + 1] == 2 /* Other */ ) return pair(data, i + 2);\n else break;\n }\n if (next == terminal || next == 0 /* Err */ ) return pair(data, i + 1);\n }\n return 0;\n }\n /// @internal\n stateSlot(state, slot) {\n return this.states[state * 6 /* Size */ + slot];\n }\n /// @internal\n stateFlag(state, flag) {\n return (this.stateSlot(state, 0 /* Flags */ ) & flag) > 0;\n }\n /// @internal\n validAction(state, action) {\n if (action == this.stateSlot(state, 4 /* DefaultReduce */ )) return true;\n for(let i = this.stateSlot(state, 1 /* Actions */ );; i += 3){\n if (this.data[i] == 65535 /* End */ ) {\n if (this.data[i + 1] == 1 /* Next */ ) i = pair(this.data, i + 2);\n else return false;\n }\n if (action == pair(this.data, i + 1)) return true;\n }\n }\n /// Get the states that can follow this one through shift actions or\n /// goto jumps. @internal\n nextStates(state) {\n let result = [];\n for(let i8 = this.stateSlot(state, 1 /* Actions */ );; i8 += 3){\n if (this.data[i8] == 65535 /* End */ ) {\n if (this.data[i8 + 1] == 1 /* Next */ ) i8 = pair(this.data, i8 + 2);\n else break;\n }\n if ((this.data[i8 + 2] & 1) == 0) {\n let value = this.data[i8 + 1];\n if (!result.some((v, i)=>i & 1 && v == value\n )) result.push(this.data[i8], value);\n }\n }\n return result;\n }\n /// @internal\n overrides(token, prev) {\n let iPrev = findOffset(this.data, this.tokenPrecTable, prev);\n return iPrev < 0 || findOffset(this.data, this.tokenPrecTable, token) < iPrev;\n }\n /// Configure the parser. Returns a new parser instance that has the\n /// given settings modified. Settings not provided in `config` are\n /// kept from the original parser.\n configure(config) {\n // Hideous reflection-based kludge to make it easy to create a\n // slightly modified copy of a parser.\n let copy = Object.assign(Object.create(LRParser.prototype), this);\n if (config.props) copy.nodeSet = this.nodeSet.extend(...config.props);\n if (config.top) {\n let info = this.topRules[config.top];\n if (!info) throw new RangeError(`Invalid top rule name ${config.top}`);\n copy.top = info;\n }\n if (config.tokenizers) copy.tokenizers = this.tokenizers.map((t)=>{\n let found = config.tokenizers.find((r)=>r.from == t\n );\n return found ? found.to : t;\n });\n if (config.contextTracker) copy.context = config.contextTracker;\n if (config.dialect) copy.dialect = this.parseDialect(config.dialect);\n if (config.strict != null) copy.strict = config.strict;\n if (config.wrap) copy.wrappers = copy.wrappers.concat(config.wrap);\n if (config.bufferLength != null) copy.bufferLength = config.bufferLength;\n return copy;\n }\n /// Returns the name associated with a given term. This will only\n /// work for all terms when the parser was generated with the\n /// `--names` option. By default, only the names of tagged terms are\n /// stored.\n getName(term) {\n return this.termNames ? this.termNames[term] : String(term <= this.maxNode && this.nodeSet.types[term].name || term);\n }\n /// The eof term id is always allocated directly after the node\n /// types. @internal\n get eofTerm() {\n return this.maxNode + 1;\n }\n /// The type of top node produced by the parser.\n get topNode() {\n return this.nodeSet.types[this.top[1]];\n }\n /// @internal\n dynamicPrecedence(term) {\n let prec = this.dynamicPrecedences;\n return prec == null ? 0 : prec[term] || 0;\n }\n /// @internal\n parseDialect(dialect) {\n let values = Object.keys(this.dialects), flags = values.map(()=>false\n );\n if (dialect) for (let part of dialect.split(\" \")){\n let id3 = values.indexOf(part);\n if (id3 >= 0) flags[id3] = true;\n }\n let disabled = null;\n for(let i = 0; i < values.length; i++)if (!flags[i]) for(let j = this.dialects[values[i]], id4; (id4 = this.data[j++]) != 65535 /* End */ ;)(disabled || (disabled = new Uint8Array(this.maxTerm + 1)))[id4] = 1;\n return new Dialect(dialect, flags, disabled);\n }\n /// (used by the output of the parser generator) @internal\n static deserialize(spec) {\n return new LRParser(spec);\n }\n}\nfunction pair(data, off) {\n return data[off] | data[off + 1] << 16;\n}\nfunction findOffset(data, start, term) {\n for(let i = start, next; (next = data[i]) != 65535 /* End */ ; i++)if (next == term) return i - start;\n return -1;\n}\nfunction findFinished(stacks) {\n let best = null;\n for (let stack of stacks){\n let stopped = stack.p.stoppedAt;\n if ((stack.pos == stack.p.stream.end || stopped != null && stack.pos > stopped) && stack.p.parser.stateFlag(stack.state, 2 /* Accepting */ ) && (!best || best.score < stack.score)) best = stack;\n }\n return best;\n}\n\n},{\"@lezer/common\":\"ds1Io\",\"process\":\"fPTmF\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"fPTmF\":[function(require,module,exports) {\n// shim for using process in browser\nvar process = module.exports = {\n};\n// cached from whatever global is present so that test runners that stub it\n// don't break things. But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals. It's inside a\n// function because try/catches deoptimize in certain engines.\nvar cachedSetTimeout;\nvar cachedClearTimeout;\nfunction defaultSetTimout() {\n throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout() {\n throw new Error('clearTimeout has not been defined');\n}\n(function() {\n try {\n if (typeof setTimeout === 'function') cachedSetTimeout = setTimeout;\n else cachedSetTimeout = defaultSetTimout;\n } catch (e) {\n cachedSetTimeout = defaultSetTimout;\n }\n try {\n if (typeof clearTimeout === 'function') cachedClearTimeout = clearTimeout;\n else cachedClearTimeout = defaultClearTimeout;\n } catch (e1) {\n cachedClearTimeout = defaultClearTimeout;\n }\n})();\nfunction runTimeout(fun) {\n if (cachedSetTimeout === setTimeout) //normal enviroments in sane situations\n return setTimeout(fun, 0);\n // if setTimeout wasn't available but was latter defined\n if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n cachedSetTimeout = setTimeout;\n return setTimeout(fun, 0);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedSetTimeout(fun, 0);\n } catch (e) {\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedSetTimeout.call(null, fun, 0);\n } catch (e) {\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n return cachedSetTimeout.call(this, fun, 0);\n }\n }\n}\nfunction runClearTimeout(marker) {\n if (cachedClearTimeout === clearTimeout) //normal enviroments in sane situations\n return clearTimeout(marker);\n // if clearTimeout wasn't available but was latter defined\n if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n cachedClearTimeout = clearTimeout;\n return clearTimeout(marker);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedClearTimeout(marker);\n } catch (e) {\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedClearTimeout.call(null, marker);\n } catch (e) {\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n return cachedClearTimeout.call(this, marker);\n }\n }\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) return;\n draining = false;\n if (currentQueue.length) queue = currentQueue.concat(queue);\n else queueIndex = -1;\n if (queue.length) drainQueue();\n}\nfunction drainQueue() {\n if (draining) return;\n var timeout = runTimeout(cleanUpNextTick);\n draining = true;\n var len = queue.length;\n while(len){\n currentQueue = queue;\n queue = [];\n while(++queueIndex < len)if (currentQueue) currentQueue[queueIndex].run();\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n runClearTimeout(timeout);\n}\nprocess.nextTick = function(fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) for(var i = 1; i < arguments.length; i++)args[i - 1] = arguments[i];\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) runTimeout(drainQueue);\n};\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function() {\n this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {\n};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {\n};\nfunction noop() {\n}\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\nprocess.listeners = function(name) {\n return [];\n};\nprocess.binding = function(name) {\n throw new Error('process.binding is not supported');\n};\nprocess.cwd = function() {\n return '/';\n};\nprocess.chdir = function(dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() {\n return 0;\n};\n\n},{}],\"gH8D7\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"css\", ()=>css\n);\nparcelHelpers.export(exports, \"cssCompletion\", ()=>cssCompletion\n);\nparcelHelpers.export(exports, \"cssCompletionSource\", ()=>cssCompletionSource\n);\nparcelHelpers.export(exports, \"cssLanguage\", ()=>cssLanguage\n);\nvar _css = require(\"@lezer/css\");\nvar _language = require(\"@codemirror/language\");\nvar _highlight = require(\"@codemirror/highlight\");\nlet _properties = null;\nfunction properties() {\n if (!_properties && typeof document == \"object\" && document.body) {\n let names = [];\n for(let prop in document.body.style)if (!/[A-Z]|^-|^(item|length)$/.test(prop)) names.push(prop);\n _properties = names.sort().map((name)=>({\n type: \"property\",\n label: name\n })\n );\n }\n return _properties || [];\n}\nconst pseudoClasses = /*@__PURE__*/ [\n \"active\",\n \"after\",\n \"before\",\n \"checked\",\n \"default\",\n \"disabled\",\n \"empty\",\n \"enabled\",\n \"first-child\",\n \"first-letter\",\n \"first-line\",\n \"first-of-type\",\n \"focus\",\n \"hover\",\n \"in-range\",\n \"indeterminate\",\n \"invalid\",\n \"lang\",\n \"last-child\",\n \"last-of-type\",\n \"link\",\n \"not\",\n \"nth-child\",\n \"nth-last-child\",\n \"nth-last-of-type\",\n \"nth-of-type\",\n \"only-of-type\",\n \"only-child\",\n \"optional\",\n \"out-of-range\",\n \"placeholder\",\n \"read-only\",\n \"read-write\",\n \"required\",\n \"root\",\n \"selection\",\n \"target\",\n \"valid\",\n \"visited\"\n].map((name)=>({\n type: \"class\",\n label: name\n })\n);\nconst values = /*@__PURE__*/ [\n \"above\",\n \"absolute\",\n \"activeborder\",\n \"additive\",\n \"activecaption\",\n \"after-white-space\",\n \"ahead\",\n \"alias\",\n \"all\",\n \"all-scroll\",\n \"alphabetic\",\n \"alternate\",\n \"always\",\n \"antialiased\",\n \"appworkspace\",\n \"asterisks\",\n \"attr\",\n \"auto\",\n \"auto-flow\",\n \"avoid\",\n \"avoid-column\",\n \"avoid-page\",\n \"avoid-region\",\n \"axis-pan\",\n \"background\",\n \"backwards\",\n \"baseline\",\n \"below\",\n \"bidi-override\",\n \"blink\",\n \"block\",\n \"block-axis\",\n \"bold\",\n \"bolder\",\n \"border\",\n \"border-box\",\n \"both\",\n \"bottom\",\n \"break\",\n \"break-all\",\n \"break-word\",\n \"bullets\",\n \"button\",\n \"button-bevel\",\n \"buttonface\",\n \"buttonhighlight\",\n \"buttonshadow\",\n \"buttontext\",\n \"calc\",\n \"capitalize\",\n \"caps-lock-indicator\",\n \"caption\",\n \"captiontext\",\n \"caret\",\n \"cell\",\n \"center\",\n \"checkbox\",\n \"circle\",\n \"cjk-decimal\",\n \"clear\",\n \"clip\",\n \"close-quote\",\n \"col-resize\",\n \"collapse\",\n \"color\",\n \"color-burn\",\n \"color-dodge\",\n \"column\",\n \"column-reverse\",\n \"compact\",\n \"condensed\",\n \"contain\",\n \"content\",\n \"contents\",\n \"content-box\",\n \"context-menu\",\n \"continuous\",\n \"copy\",\n \"counter\",\n \"counters\",\n \"cover\",\n \"crop\",\n \"cross\",\n \"crosshair\",\n \"currentcolor\",\n \"cursive\",\n \"cyclic\",\n \"darken\",\n \"dashed\",\n \"decimal\",\n \"decimal-leading-zero\",\n \"default\",\n \"default-button\",\n \"dense\",\n \"destination-atop\",\n \"destination-in\",\n \"destination-out\",\n \"destination-over\",\n \"difference\",\n \"disc\",\n \"discard\",\n \"disclosure-closed\",\n \"disclosure-open\",\n \"document\",\n \"dot-dash\",\n \"dot-dot-dash\",\n \"dotted\",\n \"double\",\n \"down\",\n \"e-resize\",\n \"ease\",\n \"ease-in\",\n \"ease-in-out\",\n \"ease-out\",\n \"element\",\n \"ellipse\",\n \"ellipsis\",\n \"embed\",\n \"end\",\n \"ethiopic-abegede-gez\",\n \"ethiopic-halehame-aa-er\",\n \"ethiopic-halehame-gez\",\n \"ew-resize\",\n \"exclusion\",\n \"expanded\",\n \"extends\",\n \"extra-condensed\",\n \"extra-expanded\",\n \"fantasy\",\n \"fast\",\n \"fill\",\n \"fill-box\",\n \"fixed\",\n \"flat\",\n \"flex\",\n \"flex-end\",\n \"flex-start\",\n \"footnotes\",\n \"forwards\",\n \"from\",\n \"geometricPrecision\",\n \"graytext\",\n \"grid\",\n \"groove\",\n \"hand\",\n \"hard-light\",\n \"help\",\n \"hidden\",\n \"hide\",\n \"higher\",\n \"highlight\",\n \"highlighttext\",\n \"horizontal\",\n \"hsl\",\n \"hsla\",\n \"hue\",\n \"icon\",\n \"ignore\",\n \"inactiveborder\",\n \"inactivecaption\",\n \"inactivecaptiontext\",\n \"infinite\",\n \"infobackground\",\n \"infotext\",\n \"inherit\",\n \"initial\",\n \"inline\",\n \"inline-axis\",\n \"inline-block\",\n \"inline-flex\",\n \"inline-grid\",\n \"inline-table\",\n \"inset\",\n \"inside\",\n \"intrinsic\",\n \"invert\",\n \"italic\",\n \"justify\",\n \"keep-all\",\n \"landscape\",\n \"large\",\n \"larger\",\n \"left\",\n \"level\",\n \"lighter\",\n \"lighten\",\n \"line-through\",\n \"linear\",\n \"linear-gradient\",\n \"lines\",\n \"list-item\",\n \"listbox\",\n \"listitem\",\n \"local\",\n \"logical\",\n \"loud\",\n \"lower\",\n \"lower-hexadecimal\",\n \"lower-latin\",\n \"lower-norwegian\",\n \"lowercase\",\n \"ltr\",\n \"luminosity\",\n \"manipulation\",\n \"match\",\n \"matrix\",\n \"matrix3d\",\n \"medium\",\n \"menu\",\n \"menutext\",\n \"message-box\",\n \"middle\",\n \"min-intrinsic\",\n \"mix\",\n \"monospace\",\n \"move\",\n \"multiple\",\n \"multiple_mask_images\",\n \"multiply\",\n \"n-resize\",\n \"narrower\",\n \"ne-resize\",\n \"nesw-resize\",\n \"no-close-quote\",\n \"no-drop\",\n \"no-open-quote\",\n \"no-repeat\",\n \"none\",\n \"normal\",\n \"not-allowed\",\n \"nowrap\",\n \"ns-resize\",\n \"numbers\",\n \"numeric\",\n \"nw-resize\",\n \"nwse-resize\",\n \"oblique\",\n \"opacity\",\n \"open-quote\",\n \"optimizeLegibility\",\n \"optimizeSpeed\",\n \"outset\",\n \"outside\",\n \"outside-shape\",\n \"overlay\",\n \"overline\",\n \"padding\",\n \"padding-box\",\n \"painted\",\n \"page\",\n \"paused\",\n \"perspective\",\n \"pinch-zoom\",\n \"plus-darker\",\n \"plus-lighter\",\n \"pointer\",\n \"polygon\",\n \"portrait\",\n \"pre\",\n \"pre-line\",\n \"pre-wrap\",\n \"preserve-3d\",\n \"progress\",\n \"push-button\",\n \"radial-gradient\",\n \"radio\",\n \"read-only\",\n \"read-write\",\n \"read-write-plaintext-only\",\n \"rectangle\",\n \"region\",\n \"relative\",\n \"repeat\",\n \"repeating-linear-gradient\",\n \"repeating-radial-gradient\",\n \"repeat-x\",\n \"repeat-y\",\n \"reset\",\n \"reverse\",\n \"rgb\",\n \"rgba\",\n \"ridge\",\n \"right\",\n \"rotate\",\n \"rotate3d\",\n \"rotateX\",\n \"rotateY\",\n \"rotateZ\",\n \"round\",\n \"row\",\n \"row-resize\",\n \"row-reverse\",\n \"rtl\",\n \"run-in\",\n \"running\",\n \"s-resize\",\n \"sans-serif\",\n \"saturation\",\n \"scale\",\n \"scale3d\",\n \"scaleX\",\n \"scaleY\",\n \"scaleZ\",\n \"screen\",\n \"scroll\",\n \"scrollbar\",\n \"scroll-position\",\n \"se-resize\",\n \"self-start\",\n \"self-end\",\n \"semi-condensed\",\n \"semi-expanded\",\n \"separate\",\n \"serif\",\n \"show\",\n \"single\",\n \"skew\",\n \"skewX\",\n \"skewY\",\n \"skip-white-space\",\n \"slide\",\n \"slider-horizontal\",\n \"slider-vertical\",\n \"sliderthumb-horizontal\",\n \"sliderthumb-vertical\",\n \"slow\",\n \"small\",\n \"small-caps\",\n \"small-caption\",\n \"smaller\",\n \"soft-light\",\n \"solid\",\n \"source-atop\",\n \"source-in\",\n \"source-out\",\n \"source-over\",\n \"space\",\n \"space-around\",\n \"space-between\",\n \"space-evenly\",\n \"spell-out\",\n \"square\",\n \"start\",\n \"static\",\n \"status-bar\",\n \"stretch\",\n \"stroke\",\n \"stroke-box\",\n \"sub\",\n \"subpixel-antialiased\",\n \"svg_masks\",\n \"super\",\n \"sw-resize\",\n \"symbolic\",\n \"symbols\",\n \"system-ui\",\n \"table\",\n \"table-caption\",\n \"table-cell\",\n \"table-column\",\n \"table-column-group\",\n \"table-footer-group\",\n \"table-header-group\",\n \"table-row\",\n \"table-row-group\",\n \"text\",\n \"text-bottom\",\n \"text-top\",\n \"textarea\",\n \"textfield\",\n \"thick\",\n \"thin\",\n \"threeddarkshadow\",\n \"threedface\",\n \"threedhighlight\",\n \"threedlightshadow\",\n \"threedshadow\",\n \"to\",\n \"top\",\n \"transform\",\n \"translate\",\n \"translate3d\",\n \"translateX\",\n \"translateY\",\n \"translateZ\",\n \"transparent\",\n \"ultra-condensed\",\n \"ultra-expanded\",\n \"underline\",\n \"unidirectional-pan\",\n \"unset\",\n \"up\",\n \"upper-latin\",\n \"uppercase\",\n \"url\",\n \"var\",\n \"vertical\",\n \"vertical-text\",\n \"view-box\",\n \"visible\",\n \"visibleFill\",\n \"visiblePainted\",\n \"visibleStroke\",\n \"visual\",\n \"w-resize\",\n \"wait\",\n \"wave\",\n \"wider\",\n \"window\",\n \"windowframe\",\n \"windowtext\",\n \"words\",\n \"wrap\",\n \"wrap-reverse\",\n \"x-large\",\n \"x-small\",\n \"xor\",\n \"xx-large\",\n \"xx-small\"\n].map((name)=>({\n type: \"keyword\",\n label: name\n })\n).concat(/*@__PURE__*/ [\n \"aliceblue\",\n \"antiquewhite\",\n \"aqua\",\n \"aquamarine\",\n \"azure\",\n \"beige\",\n \"bisque\",\n \"black\",\n \"blanchedalmond\",\n \"blue\",\n \"blueviolet\",\n \"brown\",\n \"burlywood\",\n \"cadetblue\",\n \"chartreuse\",\n \"chocolate\",\n \"coral\",\n \"cornflowerblue\",\n \"cornsilk\",\n \"crimson\",\n \"cyan\",\n \"darkblue\",\n \"darkcyan\",\n \"darkgoldenrod\",\n \"darkgray\",\n \"darkgreen\",\n \"darkkhaki\",\n \"darkmagenta\",\n \"darkolivegreen\",\n \"darkorange\",\n \"darkorchid\",\n \"darkred\",\n \"darksalmon\",\n \"darkseagreen\",\n \"darkslateblue\",\n \"darkslategray\",\n \"darkturquoise\",\n \"darkviolet\",\n \"deeppink\",\n \"deepskyblue\",\n \"dimgray\",\n \"dodgerblue\",\n \"firebrick\",\n \"floralwhite\",\n \"forestgreen\",\n \"fuchsia\",\n \"gainsboro\",\n \"ghostwhite\",\n \"gold\",\n \"goldenrod\",\n \"gray\",\n \"grey\",\n \"green\",\n \"greenyellow\",\n \"honeydew\",\n \"hotpink\",\n \"indianred\",\n \"indigo\",\n \"ivory\",\n \"khaki\",\n \"lavender\",\n \"lavenderblush\",\n \"lawngreen\",\n \"lemonchiffon\",\n \"lightblue\",\n \"lightcoral\",\n \"lightcyan\",\n \"lightgoldenrodyellow\",\n \"lightgray\",\n \"lightgreen\",\n \"lightpink\",\n \"lightsalmon\",\n \"lightseagreen\",\n \"lightskyblue\",\n \"lightslategray\",\n \"lightsteelblue\",\n \"lightyellow\",\n \"lime\",\n \"limegreen\",\n \"linen\",\n \"magenta\",\n \"maroon\",\n \"mediumaquamarine\",\n \"mediumblue\",\n \"mediumorchid\",\n \"mediumpurple\",\n \"mediumseagreen\",\n \"mediumslateblue\",\n \"mediumspringgreen\",\n \"mediumturquoise\",\n \"mediumvioletred\",\n \"midnightblue\",\n \"mintcream\",\n \"mistyrose\",\n \"moccasin\",\n \"navajowhite\",\n \"navy\",\n \"oldlace\",\n \"olive\",\n \"olivedrab\",\n \"orange\",\n \"orangered\",\n \"orchid\",\n \"palegoldenrod\",\n \"palegreen\",\n \"paleturquoise\",\n \"palevioletred\",\n \"papayawhip\",\n \"peachpuff\",\n \"peru\",\n \"pink\",\n \"plum\",\n \"powderblue\",\n \"purple\",\n \"rebeccapurple\",\n \"red\",\n \"rosybrown\",\n \"royalblue\",\n \"saddlebrown\",\n \"salmon\",\n \"sandybrown\",\n \"seagreen\",\n \"seashell\",\n \"sienna\",\n \"silver\",\n \"skyblue\",\n \"slateblue\",\n \"slategray\",\n \"snow\",\n \"springgreen\",\n \"steelblue\",\n \"tan\",\n \"teal\",\n \"thistle\",\n \"tomato\",\n \"turquoise\",\n \"violet\",\n \"wheat\",\n \"white\",\n \"whitesmoke\",\n \"yellow\",\n \"yellowgreen\"\n].map((name)=>({\n type: \"constant\",\n label: name\n })\n));\nconst tags = /*@__PURE__*/ [\n \"a\",\n \"abbr\",\n \"address\",\n \"article\",\n \"aside\",\n \"b\",\n \"bdi\",\n \"bdo\",\n \"blockquote\",\n \"body\",\n \"br\",\n \"button\",\n \"canvas\",\n \"caption\",\n \"cite\",\n \"code\",\n \"col\",\n \"colgroup\",\n \"dd\",\n \"del\",\n \"details\",\n \"dfn\",\n \"dialog\",\n \"div\",\n \"dl\",\n \"dt\",\n \"em\",\n \"figcaption\",\n \"figure\",\n \"footer\",\n \"form\",\n \"header\",\n \"hgroup\",\n \"h1\",\n \"h2\",\n \"h3\",\n \"h4\",\n \"h5\",\n \"h6\",\n \"hr\",\n \"html\",\n \"i\",\n \"iframe\",\n \"img\",\n \"input\",\n \"ins\",\n \"kbd\",\n \"label\",\n \"legend\",\n \"li\",\n \"main\",\n \"meter\",\n \"nav\",\n \"ol\",\n \"output\",\n \"p\",\n \"pre\",\n \"ruby\",\n \"section\",\n \"select\",\n \"small\",\n \"source\",\n \"span\",\n \"strong\",\n \"sub\",\n \"summary\",\n \"sup\",\n \"table\",\n \"tbody\",\n \"td\",\n \"template\",\n \"textarea\",\n \"tfoot\",\n \"th\",\n \"thead\",\n \"tr\",\n \"u\",\n \"ul\"\n].map((name)=>({\n type: \"type\",\n label: name\n })\n);\nconst span = /^[\\w-]*/;\n/**\nCSS property and value keyword completion source.\n*/ const cssCompletionSource = (context)=>{\n let { state , pos } = context, node = _language.syntaxTree(state).resolveInner(pos, -1);\n if (node.name == \"PropertyName\") return {\n from: node.from,\n options: properties(),\n span\n };\n if (node.name == \"ValueName\") return {\n from: node.from,\n options: values,\n span\n };\n if (node.name == \"PseudoClassName\") return {\n from: node.from,\n options: pseudoClasses,\n span\n };\n if (node.name == \"TagName\") {\n for(let { parent } = node; parent; parent = parent.parent)if (parent.name == \"Block\") return {\n from: node.from,\n options: properties(),\n span\n };\n return {\n from: node.from,\n options: tags,\n span\n };\n }\n if (!context.explicit) return null;\n let above = node.resolve(pos), before = above.childBefore(pos);\n if (before && before.name == \":\" && above.name == \"PseudoClassSelector\") return {\n from: pos,\n options: pseudoClasses,\n span\n };\n if (before && before.name == \":\" && above.name == \"Declaration\" || above.name == \"ArgList\") return {\n from: pos,\n options: values,\n span\n };\n if (above.name == \"Block\") return {\n from: pos,\n options: properties(),\n span\n };\n return null;\n};\n/**\nA language provider based on the [Lezer CSS\nparser](https://github.com/lezer-parser/css), extended with\nhighlighting and indentation information.\n*/ const cssLanguage = /*@__PURE__*/ _language.LRLanguage.define({\n parser: /*@__PURE__*/ _css.parser.configure({\n props: [\n /*@__PURE__*/ _language.indentNodeProp.add({\n Declaration: /*@__PURE__*/ _language.continuedIndent()\n }),\n /*@__PURE__*/ _language.foldNodeProp.add({\n Block: _language.foldInside\n }),\n /*@__PURE__*/ _highlight.styleTags({\n \"import charset namespace keyframes\": _highlight.tags.definitionKeyword,\n \"media supports\": _highlight.tags.controlKeyword,\n \"from to selector\": _highlight.tags.keyword,\n NamespaceName: _highlight.tags.namespace,\n KeyframeName: _highlight.tags.labelName,\n TagName: _highlight.tags.tagName,\n ClassName: _highlight.tags.className,\n PseudoClassName: /*@__PURE__*/ _highlight.tags.constant(_highlight.tags.className),\n IdName: _highlight.tags.labelName,\n \"FeatureName PropertyName\": _highlight.tags.propertyName,\n AttributeName: _highlight.tags.attributeName,\n NumberLiteral: _highlight.tags.number,\n KeywordQuery: _highlight.tags.keyword,\n UnaryQueryOp: _highlight.tags.operatorKeyword,\n \"CallTag ValueName\": _highlight.tags.atom,\n VariableName: _highlight.tags.variableName,\n Callee: _highlight.tags.operatorKeyword,\n Unit: _highlight.tags.unit,\n \"UniversalSelector NestingSelector\": _highlight.tags.definitionOperator,\n AtKeyword: _highlight.tags.keyword,\n MatchOp: _highlight.tags.compareOperator,\n \"ChildOp SiblingOp, LogicOp\": _highlight.tags.logicOperator,\n BinOp: _highlight.tags.arithmeticOperator,\n Important: _highlight.tags.modifier,\n Comment: _highlight.tags.blockComment,\n ParenthesizedContent: /*@__PURE__*/ _highlight.tags.special(_highlight.tags.name),\n ColorLiteral: _highlight.tags.color,\n StringLiteral: _highlight.tags.string,\n \":\": _highlight.tags.punctuation,\n \"PseudoOp #\": _highlight.tags.derefOperator,\n \"; ,\": _highlight.tags.separator,\n \"( )\": _highlight.tags.paren,\n \"[ ]\": _highlight.tags.squareBracket,\n \"{ }\": _highlight.tags.brace\n })\n ]\n }),\n languageData: {\n commentTokens: {\n block: {\n open: \"/*\",\n close: \"*/\"\n }\n },\n indentOnInput: /^\\s*\\}$/,\n wordChars: \"-\"\n }\n});\n// FIXME remove on next major version\nconst cssCompletion = /*@__PURE__*/ cssLanguage.data.of({\n autocomplete: cssCompletionSource\n});\n/**\nLanguage support for CSS.\n*/ function css() {\n return new _language.LanguageSupport(cssLanguage, cssCompletion);\n}\n\n},{\"@lezer/css\":\"1v8pq\",\"@codemirror/language\":\"70QHL\",\"@codemirror/highlight\":\"cVRRs\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"1v8pq\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"parser\", ()=>parser\n);\nvar _lr = require(\"@lezer/lr\");\nvar _common = require(\"@lezer/common\");\n// This file was generated by lezer-generator. You probably shouldn't edit it.\nconst descendantOp = 93, Unit = 1, callee = 94, identifier = 95, VariableName = 2;\n/* Hand-written tokenizers for CSS tokens that can't be\n expressed by Lezer's built-in tokenizer. */ const space = [\n 9,\n 10,\n 11,\n 12,\n 13,\n 32,\n 133,\n 160,\n 5760,\n 8192,\n 8193,\n 8194,\n 8195,\n 8196,\n 8197,\n 8198,\n 8199,\n 8200,\n 8201,\n 8202,\n 8232,\n 8233,\n 8239,\n 8287,\n 12288\n];\nconst colon = 58, parenL = 40, underscore = 95, bracketL = 91, dash = 45, period = 46, hash = 35, percent = 37;\nfunction isAlpha(ch) {\n return ch >= 65 && ch <= 90 || ch >= 97 && ch <= 122 || ch >= 161;\n}\nfunction isDigit(ch) {\n return ch >= 48 && ch <= 57;\n}\nconst identifiers = new _lr.ExternalTokenizer((input, stack)=>{\n for(let inside = false, dashes = 0, i = 0;; i++){\n let { next } = input;\n if (isAlpha(next) || next == dash || next == underscore || inside && isDigit(next)) {\n if (!inside && (next != dash || i > 0)) inside = true;\n if (dashes === i && next == dash) dashes++;\n input.advance();\n } else {\n if (inside) input.acceptToken(next == parenL ? callee : dashes == 2 && stack.canShift(VariableName) ? VariableName : identifier);\n break;\n }\n }\n});\nconst descendant = new _lr.ExternalTokenizer((input)=>{\n if (space.includes(input.peek(-1))) {\n let { next } = input;\n if (isAlpha(next) || next == underscore || next == hash || next == period || next == bracketL || next == colon || next == dash) input.acceptToken(descendantOp);\n }\n});\nconst unitToken = new _lr.ExternalTokenizer((input)=>{\n if (!space.includes(input.peek(-1))) {\n let { next } = input;\n if (next == percent) {\n input.advance();\n input.acceptToken(Unit);\n }\n if (isAlpha(next)) {\n do input.advance();\n while (isAlpha(input.next))\n input.acceptToken(Unit);\n }\n }\n});\n// This file was generated by lezer-generator. You probably shouldn't edit it.\nconst spec_callee = {\n __proto__: null,\n lang: 32,\n \"nth-child\": 32,\n \"nth-last-child\": 32,\n \"nth-of-type\": 32,\n dir: 32,\n url: 60,\n \"url-prefix\": 60,\n domain: 60,\n regexp: 60,\n selector: 134\n};\nconst spec_AtKeyword = {\n __proto__: null,\n \"@import\": 114,\n \"@media\": 138,\n \"@charset\": 142,\n \"@namespace\": 146,\n \"@keyframes\": 152,\n \"@supports\": 164\n};\nconst spec_identifier = {\n __proto__: null,\n not: 128,\n only: 128,\n from: 158,\n to: 160\n};\nconst parser = _lr.LRParser.deserialize({\n version: 13,\n states: \"7WOYQ[OOOOQP'#Cd'#CdOOQP'#Cc'#CcO!ZQ[O'#CfO!}QXO'#CaO#UQ[O'#ChO#aQ[O'#DPO#fQ[O'#DTOOQP'#Ec'#EcO#kQdO'#DeO$VQ[O'#DrO#kQdO'#DtO$hQ[O'#DvO$sQ[O'#DyO$xQ[O'#EPO%WQ[O'#EROOQS'#Eb'#EbOOQS'#ES'#ESQYQ[OOOOQP'#Cg'#CgOOQP,59Q,59QO!ZQ[O,59QO%_Q[O'#EVO%yQWO,58{O&RQ[O,59SO#aQ[O,59kO#fQ[O,59oO%_Q[O,59sO%_Q[O,59uO%_Q[O,59vO'bQ[O'#D`OOQS,58{,58{OOQP'#Ck'#CkOOQO'#C}'#C}OOQP,59S,59SO'iQWO,59SO'nQWO,59SOOQP'#DR'#DROOQP,59k,59kOOQO'#DV'#DVO'sQ`O,59oOOQS'#Cp'#CpO#kQdO'#CqO'{QvO'#CsO)VQtO,5:POOQO'#Cx'#CxO'iQWO'#CwO)kQWO'#CyOOQS'#Ef'#EfOOQO'#Dh'#DhO)pQ[O'#DoO*OQWO'#EiO$xQ[O'#DmO*^QWO'#DpOOQO'#Ej'#EjO%|QWO,5:^O*cQpO,5:`OOQS'#Dx'#DxO*kQWO,5:bO*pQ[O,5:bOOQO'#D{'#D{O*xQWO,5:eO*}QWO,5:kO+VQWO,5:mOOQS-E8Q-E8QOOQP1G.l1G.lO+yQXO,5:qOOQO-E8T-E8TOOQS1G.g1G.gOOQP1G.n1G.nO'iQWO1G.nO'nQWO1G.nOOQP1G/V1G/VO,WQ`O1G/ZO,qQXO1G/_O-XQXO1G/aO-oQXO1G/bO.VQXO'#CdO.zQWO'#DaOOQS,59z,59zO/PQWO,59zO/XQ[O,59zO/`QdO'#CoO/gQ[O'#DOOOQP1G/Z1G/ZO#kQdO1G/ZO/nQpO,59]OOQS,59_,59_O#kQdO,59aO/vQWO1G/kOOQS,59c,59cO/{Q!bO,59eO0TQWO'#DhO0`QWO,5:TO0eQWO,5:ZO$xQ[O,5:VO$xQ[O'#EYO0mQWO,5;TO0xQWO,5:XO%_Q[O,5:[OOQS1G/x1G/xOOQS1G/z1G/zOOQS1G/|1G/|O1ZQWO1G/|O1`QdO'#D|OOQS1G0P1G0POOQS1G0V1G0VOOQS1G0X1G0XOOQP7+$Y7+$YOOQP7+$u7+$uO#kQdO7+$uO#kQdO,59{O1nQ[O'#EXO1xQWO1G/fOOQS1G/f1G/fO1xQWO1G/fO2QQtO'#ETO2uQdO'#EeO3PQWO,59ZO3UQXO'#EhO3]QWO,59jO3bQpO7+$uOOQS1G.w1G.wOOQS1G.{1G.{OOQS7+%V7+%VO3jQWO1G/PO#kQdO1G/oOOQO1G/u1G/uOOQO1G/q1G/qO3oQWO,5:tOOQO-E8W-E8WO3}QXO1G/vOOQS7+%h7+%hO4UQYO'#CsO%|QWO'#EZO4^QdO,5:hOOQS,5:h,5:hO4lQpO<<HaO4tQtO1G/gOOQO,5:s,5:sO5XQ[O,5:sOOQO-E8V-E8VOOQS7+%Q7+%QO5cQWO7+%QOOQS-E8R-E8RO#kQdO'#EUO5kQWO,5;POOQT1G.u1G.uO5sQWO,5;SOOQP1G/U1G/UOOQP<<Ha<<HaOOQS7+$k7+$kO5{QdO7+%ZOOQO7+%b7+%bOOQS,5:u,5:uOOQS-E8X-E8XOOQS1G0S1G0SOOQPAN={AN={O6SQtO'#EWO#kQdO'#EWO6}QdO7+%ROOQO7+%R7+%ROOQO1G0_1G0_OOQS<<Hl<<HlO7_QdO,5:pOOQO-E8S-E8SOOQO<<Hu<<HuO7iQtO,5:rOOQS-E8U-E8UOOQO<<Hm<<Hm\",\n stateData: \"8j~O#TOSROS~OUWOXWO]TO^TOtUOxVO!Y_O!ZXO!gYO!iZO!k[O!n]O!t^O#RPO#WRO~O#RcO~O]hO^hOpfOtiOxjO|kO!PmO#PlO#WeO~O!RnO~P!`O`sO#QqO#RpO~O#RuO~O#RwO~OQ!QObzOf!QOh!QOn!PO#Q}O#RyO#Z{O~Ob!SO!b!UO!e!VO#R!RO!R#]P~Oh![On!PO#R!ZO~O#R!^O~Ob!SO!b!UO!e!VO#R!RO~O!W#]P~P$VOUWOXWO]TO^TOtUOxVO#RPO#WRO~OpfO!RnO~O`!hO#QqO#RpO~OQ!pOUWOXWO]TO^TOtUOxVO!Y_O!ZXO!gYO!iZO!k[O!n]O!t^O#R!oO#WRO~O!Q!qO~P&^Ob!tO~Ob!uO~Ov!vOz!wO~OP!yObgXjgX!WgX!bgX!egX#RgXagXQgXfgXhgXngXpgX#QgX#ZgXvgX!QgX!VgX~Ob!SOj!zO!b!UO!e!VO#R!RO!W#]P~Ob!}O~Ob!SO!b!UO!e!VO#R#OO~Op#SO!`#RO!R#]X!W#]X~Ob#VO~Oj!zO!W#XO~O!W#YO~Oh#ZOn!PO~O!R#[O~O!RnO!`#RO~O!RnO!W#_O~O]hO^hOtiOxjO|kO!PmO#PlO#WeO~Op!ya!R!yaa!ya~P+_Ov#aOz#bO~O]hO^hOtiOxjO#WeO~Op{i|{i!P{i!R{i#P{ia{i~P,`Op}i|}i!P}i!R}i#P}ia}i~P,`Op!Oi|!Oi!P!Oi!R!Oi#P!Oia!Oi~P,`O]WX]!UX^WXpWXtWXxWX|WX!PWX!RWX#PWX#WWX~O]#cO~O!Q#fO!W#dO~O!Q#fO~P&^Oa#XP~P#kOa#[P~P%_Oa#nOj!zO~O!W#pO~Oh#qOo#qO~O]!^Xa![X!`![X~O]#rO~Oa#sO!`#RO~Op#SO!R#]a!W#]a~O!`#ROp!aa!R!aa!W!aaa!aa~O!W#xO~O!Q#|O!q#zO!r#zO#Z#yO~O!Q!{X!W!{X~P&^O!Q$SO!W#dO~Oj!zOQ!wXa!wXb!wXf!wXh!wXn!wXp!wX#Q!wX#R!wX#Z!wX~Op$VOa#XX~P#kOa$XO~Oa#[X~P!`Oa$ZO~Oj!zOv$[O~Oa$]O~O!`#ROp!|a!R!|a!W!|a~Oa$_O~P+_OP!yO!RgX~O!Q$bO!q#zO!r#zO#Z#yO~Oj!zOv$cO~Oj!zOp$eO!V$gO!Q!Ti!W!Ti~P#kO!Q!{a!W!{a~P&^O!Q$iO!W#dO~Op$VOa#Xa~OpfOa#[a~Oa$lO~P#kOj!zOQ!zXb!zXf!zXh!zXn!zXp!zX!Q!zX!V!zX!W!zX#Q!zX#R!zX#Z!zX~Op$eO!V$oO!Q!Tq!W!Tq~P#kOa!xap!xa~P#kOj!zOQ!zab!zaf!zah!zan!zap!za!Q!za!V!za!W!za#Q!za#R!za#Z!za~Oo#Zj!Pj~\",\n goto: \",O#_PPPPP#`P#h#vP#h$U#hPP$[PPP$b$k$kP$}P$kP$k%e%wPPP&a&g#hP&mP#hP&sP#hP#h#hPPP&y']'iPP#`PP'o'o'y'oP'oP'o'oP#`P#`P#`P'|#`P(P(SPP#`P#`(V(e(s(y)T)Z)e)kPPPPPP)q)yP*e*hP+^+a+j]`Obn!s#d$QiWObfklmn!s!u#V#d$QiQObfklmn!s!u#V#d$QQdRR!ceQrTR!ghQ!gsQ!|!OR#`!hq!QXZz!t!w!z#b#c#i#r$O$V$^$e$f$jp!QXZz!t!w!z#b#c#i#r$O$V$^$e$f$jT#z#[#{q!OXZz!t!w!z#b#c#i#r$O$V$^$e$f$jp!QXZz!t!w!z#b#c#i#r$O$V$^$e$f$jQ![[R#Z!]QtTR!ihQ!gtR#`!iQvUR!jiQxVR!kjQoSQ!fgQ#W!XQ#^!`Q#_!aR$`#zQ!rnQ#g!sQ$P#dR$h$QX!pn!s#d$Qa!WY^_|!S!U#R#SR#P!SR!][R!_]R#]!_QbOU!bb!s$QQ!snR$Q#dQ#i!tU$U#i$^$jQ$^#rR$j$VQ$W#iR$k$WQgSS!eg$YR$Y#kQ$f$OR$n$fQ#e!rS$R#e$TR$T#gQ#T!TR#v#TQ#{#[R$a#{]aObn!s#d$Q[SObn!s#d$QQ!dfQ!lkQ!mlQ!nmQ#k!uR#w#VR#j!tQ|XQ!YZQ!xz[#h!t#i#r$V$^$jQ#m!wQ#o!zQ#}#bQ$O#cS$d$O$fR$m$eR#l!uQ!XYQ!a_R!{|U!TY_|Q!`^Q#Q!SQ#U!UQ#t#RR#u#S\",\n nodeNames: \"\u26a0 Unit VariableName Comment StyleSheet RuleSet UniversalSelector TagSelector TagName NestingSelector ClassSelector ClassName PseudoClassSelector : :: PseudoClassName PseudoClassName ) ( ArgList ValueName ParenthesizedValue ColorLiteral NumberLiteral StringLiteral BinaryExpression BinOp CallExpression Callee CallLiteral CallTag ParenthesizedContent , PseudoClassName ArgList IdSelector # IdName ] AttributeSelector [ AttributeName MatchOp ChildSelector ChildOp DescendantSelector SiblingSelector SiblingOp } { Block Declaration PropertyName Important ; ImportStatement AtKeyword import KeywordQuery FeatureQuery FeatureName BinaryQuery LogicOp UnaryQuery UnaryQueryOp ParenthesizedQuery SelectorQuery selector MediaStatement media CharsetStatement charset NamespaceStatement namespace NamespaceName KeyframesStatement keyframes KeyframeName KeyframeList from to SupportsStatement supports AtRule\",\n maxTerm: 106,\n nodeProps: [\n [\n _common.NodeProp.openedBy,\n 17,\n \"(\",\n 48,\n \"{\"\n ],\n [\n _common.NodeProp.closedBy,\n 18,\n \")\",\n 49,\n \"}\"\n ]\n ],\n skippedNodes: [\n 0,\n 3\n ],\n repeatNodeCount: 8,\n tokenData: \"Ay~R![OX$wX^%]^p$wpq%]qr(crs+}st,otu2Uuv$wvw2rwx2}xy3jyz3uz{3z{|4_|}8U}!O8a!O!P8x!P!Q9Z!Q![;e![!]<Y!]!^<x!^!_$w!_!`=T!`!a=`!a!b$w!b!c>O!c!}$w!}#O?[#O#P$w#P#Q?g#Q#R2U#R#T$w#T#U?r#U#c$w#c#d@q#d#o$w#o#pAQ#p#q2U#q#rA]#r#sAh#s#y$w#y#z%]#z$f$w$f$g%]$g#BY$w#BY#BZ%]#BZ$IS$w$IS$I_%]$I_$I|$w$I|$JO%]$JO$JT$w$JT$JU%]$JU$KV$w$KV$KW%]$KW&FU$w&FU&FV%]&FV~$wW$zQOy%Qz~%QW%VQoWOy%Qz~%Q~%bf#T~OX%QX^&v^p%Qpq&vqy%Qz#y%Q#y#z&v#z$f%Q$f$g&v$g#BY%Q#BY#BZ&v#BZ$IS%Q$IS$I_&v$I_$I|%Q$I|$JO&v$JO$JT%Q$JT$JU&v$JU$KV%Q$KV$KW&v$KW&FU%Q&FU&FV&v&FV~%Q~&}f#T~oWOX%QX^&v^p%Qpq&vqy%Qz#y%Q#y#z&v#z$f%Q$f$g&v$g#BY%Q#BY#BZ&v#BZ$IS%Q$IS$I_&v$I_$I|%Q$I|$JO&v$JO$JT%Q$JT$JU&v$JU$KV%Q$KV$KW&v$KW&FU%Q&FU&FV&v&FV~%Q^(fSOy%Qz#]%Q#]#^(r#^~%Q^(wSoWOy%Qz#a%Q#a#b)T#b~%Q^)YSoWOy%Qz#d%Q#d#e)f#e~%Q^)kSoWOy%Qz#c%Q#c#d)w#d~%Q^)|SoWOy%Qz#f%Q#f#g*Y#g~%Q^*_SoWOy%Qz#h%Q#h#i*k#i~%Q^*pSoWOy%Qz#T%Q#T#U*|#U~%Q^+RSoWOy%Qz#b%Q#b#c+_#c~%Q^+dSoWOy%Qz#h%Q#h#i+p#i~%Q^+wQ!VUoWOy%Qz~%Q~,QUOY+}Zr+}rs,ds#O+}#O#P,i#P~+}~,iOh~~,lPO~+}_,tWtPOy%Qz!Q%Q!Q![-^![!c%Q!c!i-^!i#T%Q#T#Z-^#Z~%Q^-cWoWOy%Qz!Q%Q!Q![-{![!c%Q!c!i-{!i#T%Q#T#Z-{#Z~%Q^.QWoWOy%Qz!Q%Q!Q![.j![!c%Q!c!i.j!i#T%Q#T#Z.j#Z~%Q^.qWfUoWOy%Qz!Q%Q!Q![/Z![!c%Q!c!i/Z!i#T%Q#T#Z/Z#Z~%Q^/bWfUoWOy%Qz!Q%Q!Q![/z![!c%Q!c!i/z!i#T%Q#T#Z/z#Z~%Q^0PWoWOy%Qz!Q%Q!Q![0i![!c%Q!c!i0i!i#T%Q#T#Z0i#Z~%Q^0pWfUoWOy%Qz!Q%Q!Q![1Y![!c%Q!c!i1Y!i#T%Q#T#Z1Y#Z~%Q^1_WoWOy%Qz!Q%Q!Q![1w![!c%Q!c!i1w!i#T%Q#T#Z1w#Z~%Q^2OQfUoWOy%Qz~%QY2XSOy%Qz!_%Q!_!`2e!`~%QY2lQzQoWOy%Qz~%QX2wQXPOy%Qz~%Q~3QUOY2}Zw2}wx,dx#O2}#O#P3d#P~2}~3gPO~2}_3oQbVOy%Qz~%Q~3zOa~_4RSUPjSOy%Qz!_%Q!_!`2e!`~%Q_4fUjS!PPOy%Qz!O%Q!O!P4x!P!Q%Q!Q![7_![~%Q^4}SoWOy%Qz!Q%Q!Q![5Z![~%Q^5bWoW#ZUOy%Qz!Q%Q!Q![5Z![!g%Q!g!h5z!h#X%Q#X#Y5z#Y~%Q^6PWoWOy%Qz{%Q{|6i|}%Q}!O6i!O!Q%Q!Q![6z![~%Q^6nSoWOy%Qz!Q%Q!Q![6z![~%Q^7RSoW#ZUOy%Qz!Q%Q!Q![6z![~%Q^7fYoW#ZUOy%Qz!O%Q!O!P5Z!P!Q%Q!Q![7_![!g%Q!g!h5z!h#X%Q#X#Y5z#Y~%Q_8ZQpVOy%Qz~%Q^8fUjSOy%Qz!O%Q!O!P4x!P!Q%Q!Q![7_![~%Q_8}S#WPOy%Qz!Q%Q!Q![5Z![~%Q~9`RjSOy%Qz{9i{~%Q~9nSoWOy9iyz9zz{:o{~9i~9}ROz9zz{:W{~9z~:ZTOz9zz{:W{!P9z!P!Q:j!Q~9z~:oOR~~:tUoWOy9iyz9zz{:o{!P9i!P!Q;W!Q~9i~;_QR~oWOy%Qz~%Q^;jY#ZUOy%Qz!O%Q!O!P5Z!P!Q%Q!Q![7_![!g%Q!g!h5z!h#X%Q#X#Y5z#Y~%QX<_S]POy%Qz![%Q![!]<k!]~%QX<rQ^PoWOy%Qz~%Q_<}Q!WVOy%Qz~%QY=YQzQOy%Qz~%QX=eS|POy%Qz!`%Q!`!a=q!a~%QX=xQ|PoWOy%Qz~%QX>RUOy%Qz!c%Q!c!}>e!}#T%Q#T#o>e#o~%QX>lY!YPoWOy%Qz}%Q}!O>e!O!Q%Q!Q![>e![!c%Q!c!}>e!}#T%Q#T#o>e#o~%QX?aQxPOy%Qz~%Q^?lQvUOy%Qz~%QX?uSOy%Qz#b%Q#b#c@R#c~%QX@WSoWOy%Qz#W%Q#W#X@d#X~%QX@kQ!`PoWOy%Qz~%QX@tSOy%Qz#f%Q#f#g@d#g~%QXAVQ!RPOy%Qz~%Q_AbQ!QVOy%Qz~%QZAmS!PPOy%Qz!_%Q!_!`2e!`~%Q\",\n tokenizers: [\n descendant,\n unitToken,\n identifiers,\n 0,\n 1,\n 2,\n 3\n ],\n topRules: {\n \"StyleSheet\": [\n 0,\n 4\n ]\n },\n specialized: [\n {\n term: 94,\n get: (value)=>spec_callee[value] || -1\n },\n {\n term: 56,\n get: (value)=>spec_AtKeyword[value] || -1\n },\n {\n term: 95,\n get: (value)=>spec_identifier[value] || -1\n }\n ],\n tokenPrec: 1078\n});\n\n},{\"@lezer/lr\":\"3Ck4G\",\"@lezer/common\":\"ds1Io\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"cVRRs\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"HighlightStyle\", ()=>HighlightStyle\n);\nparcelHelpers.export(exports, \"Tag\", ()=>Tag\n);\nparcelHelpers.export(exports, \"classHighlightStyle\", ()=>classHighlightStyle\n);\nparcelHelpers.export(exports, \"defaultHighlightStyle\", ()=>defaultHighlightStyle\n);\nparcelHelpers.export(exports, \"highlightTree\", ()=>highlightTree\n);\nparcelHelpers.export(exports, \"styleTags\", ()=>styleTags\n);\nparcelHelpers.export(exports, \"tags\", ()=>tags\n);\nvar _common = require(\"@lezer/common\");\nvar _styleMod = require(\"style-mod\");\nvar _view = require(\"@codemirror/view\");\nvar _state = require(\"@codemirror/state\");\nvar _language = require(\"@codemirror/language\");\nvar _rangeset = require(\"@codemirror/rangeset\");\nlet nextTagID = 0;\n/**\nHighlighting tags are markers that denote a highlighting category.\nThey are [associated](https://codemirror.net/6/docs/ref/#highlight.styleTags) with parts of a syntax\ntree by a language mode, and then mapped to an actual CSS style by\na [highlight style](https://codemirror.net/6/docs/ref/#highlight.HighlightStyle).\n\nBecause syntax tree node types and highlight styles have to be\nable to talk the same language, CodeMirror uses a mostly _closed_\n[vocabulary](https://codemirror.net/6/docs/ref/#highlight.tags) of syntax tags (as opposed to\ntraditional open string-based systems, which make it hard for\nhighlighting themes to cover all the tokens produced by the\nvarious languages).\n\nIt _is_ possible to [define](https://codemirror.net/6/docs/ref/#highlight.Tag^define) your own\nhighlighting tags for system-internal use (where you control both\nthe language package and the highlighter), but such tags will not\nbe picked up by regular highlighters (though you can derive them\nfrom standard tags to allow highlighters to fall back to those).\n*/ class Tag {\n /**\n @internal\n */ constructor(/**\n The set of tags that match this tag, starting with this one\n itself, sorted in order of decreasing specificity. @internal\n */ set, /**\n The base unmodified tag that this one is based on, if it's\n modified @internal\n */ base, /**\n The modifiers applied to this.base @internal\n */ modified){\n this.set = set;\n this.base = base;\n this.modified = modified;\n /**\n @internal\n */ this.id = nextTagID++;\n }\n /**\n Define a new tag. If `parent` is given, the tag is treated as a\n sub-tag of that parent, and [highlight\n styles](https://codemirror.net/6/docs/ref/#highlight.HighlightStyle) that don't mention this tag\n will try to fall back to the parent tag (or grandparent tag,\n etc).\n */ static define(parent) {\n if (parent === null || parent === void 0 ? void 0 : parent.base) throw new Error(\"Can not derive from a modified tag\");\n let tag = new Tag([], null, []);\n tag.set.push(tag);\n if (parent) for (let t1 of parent.set)tag.set.push(t1);\n return tag;\n }\n /**\n Define a tag _modifier_, which is a function that, given a tag,\n will return a tag that is a subtag of the original. Applying the\n same modifier to a twice tag will return the same value (`m1(t1)\n == m1(t1)`) and applying multiple modifiers will, regardless or\n order, produce the same tag (`m1(m2(t1)) == m2(m1(t1))`).\n \n When multiple modifiers are applied to a given base tag, each\n smaller set of modifiers is registered as a parent, so that for\n example `m1(m2(m3(t1)))` is a subtype of `m1(m2(t1))`,\n `m1(m3(t1)`, and so on.\n */ static defineModifier() {\n let mod = new Modifier;\n return (tag)=>{\n if (tag.modified.indexOf(mod) > -1) return tag;\n return Modifier.get(tag.base || tag, tag.modified.concat(mod).sort((a, b)=>a.id - b.id\n ));\n };\n }\n}\nlet nextModifierID = 0;\nclass Modifier {\n constructor(){\n this.instances = [];\n this.id = nextModifierID++;\n }\n static get(base, mods) {\n if (!mods.length) return base;\n let exists = mods[0].instances.find((t2)=>t2.base == base && sameArray(mods, t2.modified)\n );\n if (exists) return exists;\n let set = [], tag = new Tag(set, base, mods);\n for (let m of mods)m.instances.push(tag);\n let configs = permute(mods);\n for (let parent of base.set)for (let config of configs)set.push(Modifier.get(parent, config));\n return tag;\n }\n}\nfunction sameArray(a, b) {\n return a.length == b.length && a.every((x, i)=>x == b[i]\n );\n}\nfunction permute(array) {\n let result = [\n array\n ];\n for(let i = 0; i < array.length; i++)for (let a of permute(array.slice(0, i).concat(array.slice(i + 1))))result.push(a);\n return result;\n}\n/**\nThis function is used to add a set of tags to a language syntax\nvia\n[`LRParser.configure`](https://lezer.codemirror.net/docs/ref#lr.LRParser.configure).\n\nThe argument object maps node selectors to [highlighting\ntags](https://codemirror.net/6/docs/ref/#highlight.Tag) or arrays of tags.\n\nNode selectors may hold one or more (space-separated) node paths.\nSuch a path can be a [node\nname](https://lezer.codemirror.net/docs/ref#common.NodeType.name),\nor multiple node names (or `*` wildcards) separated by slash\ncharacters, as in `\"Block/Declaration/VariableName\"`. Such a path\nmatches the final node but only if its direct parent nodes are the\nother nodes mentioned. A `*` in such a path matches any parent,\nbut only a single level\u2014wildcards that match multiple parents\naren't supported, both for efficiency reasons and because Lezer\ntrees make it rather hard to reason about what they would match.)\n\nA path can be ended with `/...` to indicate that the tag assigned\nto the node should also apply to all child nodes, even if they\nmatch their own style (by default, only the innermost style is\nused).\n\nWhen a path ends in `!`, as in `Attribute!`, no further matching\nhappens for the node's child nodes, and the entire node gets the\ngiven style.\n\nIn this notation, node names that contain `/`, `!`, `*`, or `...`\nmust be quoted as JSON strings.\n\nFor example:\n\n```javascript\nparser.withProps(\n styleTags({\n // Style Number and BigNumber nodes\n \"Number BigNumber\": tags.number,\n // Style Escape nodes whose parent is String\n \"String/Escape\": tags.escape,\n // Style anything inside Attributes nodes\n \"Attributes!\": tags.meta,\n // Add a style to all content inside Italic nodes\n \"Italic/...\": tags.emphasis,\n // Style InvalidString nodes as both `string` and `invalid`\n \"InvalidString\": [tags.string, tags.invalid],\n // Style the node named \"/\" as punctuation\n '\"/\"': tags.punctuation\n })\n)\n```\n*/ function styleTags(spec) {\n let byName = Object.create(null);\n for(let prop in spec){\n let tags1 = spec[prop];\n if (!Array.isArray(tags1)) tags1 = [\n tags1\n ];\n for (let part of prop.split(\" \"))if (part) {\n let pieces = [], mode = 2 /* Normal */ , rest = part;\n for(let pos = 0;;){\n if (rest == \"...\" && pos > 0 && pos + 3 == part.length) {\n mode = 1 /* Inherit */ ;\n break;\n }\n let m = /^\"(?:[^\"\\\\]|\\\\.)*?\"|[^\\/!]+/.exec(rest);\n if (!m) throw new RangeError(\"Invalid path: \" + part);\n pieces.push(m[0] == \"*\" ? null : m[0][0] == '\"' ? JSON.parse(m[0]) : m[0]);\n pos += m[0].length;\n if (pos == part.length) break;\n let next = part[pos++];\n if (pos == part.length && next == \"!\") {\n mode = 0 /* Opaque */ ;\n break;\n }\n if (next != \"/\") throw new RangeError(\"Invalid path: \" + part);\n rest = part.slice(pos);\n }\n let last = pieces.length - 1, inner = pieces[last];\n if (!inner) throw new RangeError(\"Invalid path: \" + part);\n let rule = new Rule(tags1, mode, last > 0 ? pieces.slice(0, last) : null);\n byName[inner] = rule.sort(byName[inner]);\n }\n }\n return ruleNodeProp.add(byName);\n}\nconst ruleNodeProp = /*@__PURE__*/ new _common.NodeProp();\nconst highlightStyle = /*@__PURE__*/ _state.Facet.define({\n combine (stylings) {\n return stylings.length ? HighlightStyle.combinedMatch(stylings) : null;\n }\n});\nconst fallbackHighlightStyle = /*@__PURE__*/ _state.Facet.define({\n combine (values) {\n return values.length ? values[0].match : null;\n }\n});\nfunction getHighlightStyle(state) {\n return state.facet(highlightStyle) || state.facet(fallbackHighlightStyle);\n}\nclass Rule {\n constructor(tags2, mode, context, next){\n this.tags = tags2;\n this.mode = mode;\n this.context = context;\n this.next = next;\n }\n sort(other) {\n if (!other || other.depth < this.depth) {\n this.next = other;\n return this;\n }\n other.next = this.sort(other.next);\n return other;\n }\n get depth() {\n return this.context ? this.context.length : 0;\n }\n}\n/**\nA highlight style associates CSS styles with higlighting\n[tags](https://codemirror.net/6/docs/ref/#highlight.Tag).\n*/ class HighlightStyle {\n constructor(spec1, options){\n this.map = Object.create(null);\n let modSpec;\n function def(spec) {\n let cls = _styleMod.StyleModule.newName();\n (modSpec || (modSpec = Object.create(null)))[\".\" + cls] = spec;\n return cls;\n }\n this.all = typeof options.all == \"string\" ? options.all : options.all ? def(options.all) : null;\n for (let style of spec1){\n let cls = (style.class || def(Object.assign({\n }, style, {\n tag: null\n }))) + (this.all ? \" \" + this.all : \"\");\n let tags3 = style.tag;\n if (!Array.isArray(tags3)) this.map[tags3.id] = cls;\n else for (let tag of tags3)this.map[tag.id] = cls;\n }\n this.module = modSpec ? new _styleMod.StyleModule(modSpec) : null;\n this.scope = options.scope || null;\n this.match = this.match.bind(this);\n let ext = [\n treeHighlighter\n ];\n if (this.module) ext.push(_view.EditorView.styleModule.of(this.module));\n this.extension = ext.concat(highlightStyle.of(this));\n this.fallback = ext.concat(fallbackHighlightStyle.of(this));\n }\n /**\n Returns the CSS class associated with the given tag, if any.\n This method is bound to the instance by the constructor.\n */ match(tag, scope) {\n if (this.scope && scope != this.scope) return null;\n for (let t3 of tag.set){\n let match = this.map[t3.id];\n if (match !== undefined) {\n if (t3 != tag) this.map[tag.id] = match;\n return match;\n }\n }\n return this.map[tag.id] = this.all;\n }\n /**\n Combines an array of highlight styles into a single match\n function that returns all of the classes assigned by the styles\n for a given tag.\n */ static combinedMatch(styles) {\n if (styles.length == 1) return styles[0].match;\n let cache = styles.some((s)=>s.scope\n ) ? undefined : Object.create(null);\n return (tag, scope)=>{\n let cached = cache && cache[tag.id];\n if (cached !== undefined) return cached;\n let result = null;\n for (let style of styles){\n let value = style.match(tag, scope);\n if (value) result = result ? result + \" \" + value : value;\n }\n if (cache) cache[tag.id] = result;\n return result;\n };\n }\n /**\n Create a highlighter style that associates the given styles to\n the given tags. The spec must be objects that hold a style tag\n or array of tags in their `tag` property, and either a single\n `class` property providing a static CSS class (for highlighters\n like [`classHighlightStyle`](https://codemirror.net/6/docs/ref/#highlight.classHighlightStyle)\n that rely on external styling), or a\n [`style-mod`](https://github.com/marijnh/style-mod#documentation)-style\n set of CSS properties (which define the styling for those tags).\n \n The CSS rules created for a highlighter will be emitted in the\n order of the spec's properties. That means that for elements that\n have multiple tags associated with them, styles defined further\n down in the list will have a higher CSS precedence than styles\n defined earlier.\n */ static define(specs, options) {\n return new HighlightStyle(specs, options || {\n });\n }\n /**\n Returns the CSS classes (if any) that the highlight styles\n active in the given state would assign to the given a style\n [tag](https://codemirror.net/6/docs/ref/#highlight.Tag) and (optional) language\n [scope](https://codemirror.net/6/docs/ref/#highlight.HighlightStyle^define^options.scope).\n */ static get(state, tag, scope) {\n let style = getHighlightStyle(state);\n return style && style(tag, scope || _common.NodeType.none);\n }\n}\n/**\nRun the tree highlighter over the given tree.\n*/ function highlightTree(tree, /**\nGet the CSS classes used to style a given [tag](https://codemirror.net/6/docs/ref/#highlight.Tag),\nor `null` if it isn't styled. (You'll often want to pass a\nhighlight style's [`match`](https://codemirror.net/6/docs/ref/#highlight.HighlightStyle.match)\nmethod here.)\n*/ getStyle, /**\nAssign styling to a region of the text. Will be called, in order\nof position, for any ranges where more than zero classes apply.\n`classes` is a space separated string of CSS classes.\n*/ putStyle, /**\nThe start of the range to highlight.\n*/ from = 0, /**\nThe end of the range.\n*/ to = tree.length) {\n highlightTreeRange(tree, from, to, getStyle, putStyle);\n}\nclass TreeHighlighter {\n constructor(view){\n this.markCache = Object.create(null);\n this.tree = _language.syntaxTree(view.state);\n this.decorations = this.buildDeco(view, getHighlightStyle(view.state));\n }\n update(update) {\n let tree = _language.syntaxTree(update.state), style = getHighlightStyle(update.state);\n let styleChange = style != update.startState.facet(highlightStyle);\n if (tree.length < update.view.viewport.to && !styleChange && tree.type == this.tree.type) this.decorations = this.decorations.map(update.changes);\n else if (tree != this.tree || update.viewportChanged || styleChange) {\n this.tree = tree;\n this.decorations = this.buildDeco(update.view, style);\n }\n }\n buildDeco(view, match) {\n if (!match || !this.tree.length) return _view.Decoration.none;\n let builder = new _rangeset.RangeSetBuilder();\n for (let { from: from1 , to: to1 } of view.visibleRanges)highlightTreeRange(this.tree, from1, to1, match, (from, to, style)=>{\n builder.add(from, to, this.markCache[style] || (this.markCache[style] = _view.Decoration.mark({\n class: style\n })));\n });\n return builder.finish();\n }\n}\n// This extension installs a highlighter that highlights based on the\n// syntax tree and highlight style.\nconst treeHighlighter = /*@__PURE__*/ _state.Prec.high(/*@__PURE__*/ _view.ViewPlugin.fromClass(TreeHighlighter, {\n decorations: (v)=>v.decorations\n}));\nconst nodeStack = [\n \"\"\n];\nclass HighlightBuilder {\n constructor(at, style, span){\n this.at = at;\n this.style = style;\n this.span = span;\n this.class = \"\";\n }\n startSpan(at, cls) {\n if (cls != this.class) {\n this.flush(at);\n if (at > this.at) this.at = at;\n this.class = cls;\n }\n }\n flush(to) {\n if (to > this.at && this.class) this.span(this.at, to, this.class);\n }\n highlightRange(cursor, from, to, inheritedClass, depth, scope) {\n let { type , from: start , to: end } = cursor;\n if (start >= to || end <= from) return;\n nodeStack[depth] = type.name;\n if (type.isTop) scope = type;\n let cls = inheritedClass;\n let rule = type.prop(ruleNodeProp), opaque = false;\n while(rule){\n if (!rule.context || matchContext(rule.context, nodeStack, depth)) {\n for (let tag of rule.tags){\n let st = this.style(tag, scope);\n if (st) {\n if (cls) cls += \" \";\n cls += st;\n if (rule.mode == 1 /* Inherit */ ) inheritedClass += (inheritedClass ? \" \" : \"\") + st;\n else if (rule.mode == 0 /* Opaque */ ) opaque = true;\n }\n }\n break;\n }\n rule = rule.next;\n }\n this.startSpan(cursor.from, cls);\n if (opaque) return;\n let mounted = cursor.tree && cursor.tree.prop(_common.NodeProp.mounted);\n if (mounted && mounted.overlay) {\n let inner = cursor.node.enter(mounted.overlay[0].from + start, 1);\n let hasChild = cursor.firstChild();\n for(let i = 0, pos = start;; i++){\n let next = i < mounted.overlay.length ? mounted.overlay[i] : null;\n let nextPos = next ? next.from + start : end;\n let rangeFrom = Math.max(from, pos), rangeTo = Math.min(to, nextPos);\n if (rangeFrom < rangeTo && hasChild) while(cursor.from < rangeTo){\n this.highlightRange(cursor, rangeFrom, rangeTo, inheritedClass, depth + 1, scope);\n this.startSpan(Math.min(to, cursor.to), cls);\n if (cursor.to >= nextPos || !cursor.nextSibling()) break;\n }\n if (!next || nextPos > to) break;\n pos = next.to + start;\n if (pos > from) {\n this.highlightRange(inner.cursor, Math.max(from, next.from + start), Math.min(to, pos), inheritedClass, depth, mounted.tree.type);\n this.startSpan(pos, cls);\n }\n }\n if (hasChild) cursor.parent();\n } else if (cursor.firstChild()) {\n do {\n if (cursor.to <= from) continue;\n if (cursor.from >= to) break;\n this.highlightRange(cursor, from, to, inheritedClass, depth + 1, scope);\n this.startSpan(Math.min(to, cursor.to), cls);\n }while (cursor.nextSibling())\n cursor.parent();\n }\n }\n}\nfunction highlightTreeRange(tree, from, to, style, span) {\n let builder = new HighlightBuilder(from, style, span);\n builder.highlightRange(tree.cursor(), from, to, \"\", 0, tree.type);\n builder.flush(to);\n}\nfunction matchContext(context, stack, depth) {\n if (context.length > depth - 1) return false;\n for(let d = depth - 1, i = context.length - 1; i >= 0; i--, d--){\n let check = context[i];\n if (check && check != stack[d]) return false;\n }\n return true;\n}\nconst t = Tag.define;\nconst comment = /*@__PURE__*/ t(), name = /*@__PURE__*/ t(), typeName = /*@__PURE__*/ t(name), propertyName = /*@__PURE__*/ t(name), literal = /*@__PURE__*/ t(), string = /*@__PURE__*/ t(literal), number = /*@__PURE__*/ t(literal), content = /*@__PURE__*/ t(), heading = /*@__PURE__*/ t(content), keyword = /*@__PURE__*/ t(), operator = /*@__PURE__*/ t(), punctuation = /*@__PURE__*/ t(), bracket = /*@__PURE__*/ t(punctuation), meta = /*@__PURE__*/ t();\n/**\nThe default set of highlighting [tags](https://codemirror.net/6/docs/ref/#highlight.Tag^define) used\nby regular language packages and themes.\n\nThis collection is heavily biased towards programming languages,\nand necessarily incomplete. A full ontology of syntactic\nconstructs would fill a stack of books, and be impractical to\nwrite themes for. So try to make do with this set. If all else\nfails, [open an\nissue](https://github.com/codemirror/codemirror.next) to propose a\nnew tag, or [define](https://codemirror.net/6/docs/ref/#highlight.Tag^define) a local custom tag for\nyour use case.\n\nNote that it is not obligatory to always attach the most specific\ntag possible to an element\u2014if your grammar can't easily\ndistinguish a certain type of element (such as a local variable),\nit is okay to style it as its more general variant (a variable).\n\nFor tags that extend some parent tag, the documentation links to\nthe parent.\n*/ const tags = {\n /**\n A comment.\n */ comment,\n /**\n A line [comment](https://codemirror.net/6/docs/ref/#highlight.tags.comment).\n */ lineComment: /*@__PURE__*/ t(comment),\n /**\n A block [comment](https://codemirror.net/6/docs/ref/#highlight.tags.comment).\n */ blockComment: /*@__PURE__*/ t(comment),\n /**\n A documentation [comment](https://codemirror.net/6/docs/ref/#highlight.tags.comment).\n */ docComment: /*@__PURE__*/ t(comment),\n /**\n Any kind of identifier.\n */ name,\n /**\n The [name](https://codemirror.net/6/docs/ref/#highlight.tags.name) of a variable.\n */ variableName: /*@__PURE__*/ t(name),\n /**\n A type [name](https://codemirror.net/6/docs/ref/#highlight.tags.name).\n */ typeName: typeName,\n /**\n A tag name (subtag of [`typeName`](https://codemirror.net/6/docs/ref/#highlight.tags.typeName)).\n */ tagName: /*@__PURE__*/ t(typeName),\n /**\n A property or field [name](https://codemirror.net/6/docs/ref/#highlight.tags.name).\n */ propertyName: propertyName,\n /**\n An attribute name (subtag of [`propertyName`](https://codemirror.net/6/docs/ref/#highlight.tags.propertyName)).\n */ attributeName: /*@__PURE__*/ t(propertyName),\n /**\n The [name](https://codemirror.net/6/docs/ref/#highlight.tags.name) of a class.\n */ className: /*@__PURE__*/ t(name),\n /**\n A label [name](https://codemirror.net/6/docs/ref/#highlight.tags.name).\n */ labelName: /*@__PURE__*/ t(name),\n /**\n A namespace [name](https://codemirror.net/6/docs/ref/#highlight.tags.name).\n */ namespace: /*@__PURE__*/ t(name),\n /**\n The [name](https://codemirror.net/6/docs/ref/#highlight.tags.name) of a macro.\n */ macroName: /*@__PURE__*/ t(name),\n /**\n A literal value.\n */ literal,\n /**\n A string [literal](https://codemirror.net/6/docs/ref/#highlight.tags.literal).\n */ string,\n /**\n A documentation [string](https://codemirror.net/6/docs/ref/#highlight.tags.string).\n */ docString: /*@__PURE__*/ t(string),\n /**\n A character literal (subtag of [string](https://codemirror.net/6/docs/ref/#highlight.tags.string)).\n */ character: /*@__PURE__*/ t(string),\n /**\n An attribute value (subtag of [string](https://codemirror.net/6/docs/ref/#highlight.tags.string)).\n */ attributeValue: /*@__PURE__*/ t(string),\n /**\n A number [literal](https://codemirror.net/6/docs/ref/#highlight.tags.literal).\n */ number,\n /**\n An integer [number](https://codemirror.net/6/docs/ref/#highlight.tags.number) literal.\n */ integer: /*@__PURE__*/ t(number),\n /**\n A floating-point [number](https://codemirror.net/6/docs/ref/#highlight.tags.number) literal.\n */ float: /*@__PURE__*/ t(number),\n /**\n A boolean [literal](https://codemirror.net/6/docs/ref/#highlight.tags.literal).\n */ bool: /*@__PURE__*/ t(literal),\n /**\n Regular expression [literal](https://codemirror.net/6/docs/ref/#highlight.tags.literal).\n */ regexp: /*@__PURE__*/ t(literal),\n /**\n An escape [literal](https://codemirror.net/6/docs/ref/#highlight.tags.literal), for example a\n backslash escape in a string.\n */ escape: /*@__PURE__*/ t(literal),\n /**\n A color [literal](https://codemirror.net/6/docs/ref/#highlight.tags.literal).\n */ color: /*@__PURE__*/ t(literal),\n /**\n A URL [literal](https://codemirror.net/6/docs/ref/#highlight.tags.literal).\n */ url: /*@__PURE__*/ t(literal),\n /**\n A language keyword.\n */ keyword,\n /**\n The [keyword](https://codemirror.net/6/docs/ref/#highlight.tags.keyword) for the self or this\n object.\n */ self: /*@__PURE__*/ t(keyword),\n /**\n The [keyword](https://codemirror.net/6/docs/ref/#highlight.tags.keyword) for null.\n */ null: /*@__PURE__*/ t(keyword),\n /**\n A [keyword](https://codemirror.net/6/docs/ref/#highlight.tags.keyword) denoting some atomic value.\n */ atom: /*@__PURE__*/ t(keyword),\n /**\n A [keyword](https://codemirror.net/6/docs/ref/#highlight.tags.keyword) that represents a unit.\n */ unit: /*@__PURE__*/ t(keyword),\n /**\n A modifier [keyword](https://codemirror.net/6/docs/ref/#highlight.tags.keyword).\n */ modifier: /*@__PURE__*/ t(keyword),\n /**\n A [keyword](https://codemirror.net/6/docs/ref/#highlight.tags.keyword) that acts as an operator.\n */ operatorKeyword: /*@__PURE__*/ t(keyword),\n /**\n A control-flow related [keyword](https://codemirror.net/6/docs/ref/#highlight.tags.keyword).\n */ controlKeyword: /*@__PURE__*/ t(keyword),\n /**\n A [keyword](https://codemirror.net/6/docs/ref/#highlight.tags.keyword) that defines something.\n */ definitionKeyword: /*@__PURE__*/ t(keyword),\n /**\n A [keyword](https://codemirror.net/6/docs/ref/#highlight.tags.keyword) related to defining or\n interfacing with modules.\n */ moduleKeyword: /*@__PURE__*/ t(keyword),\n /**\n An operator.\n */ operator,\n /**\n An [operator](https://codemirror.net/6/docs/ref/#highlight.tags.operator) that defines something.\n */ derefOperator: /*@__PURE__*/ t(operator),\n /**\n Arithmetic-related [operator](https://codemirror.net/6/docs/ref/#highlight.tags.operator).\n */ arithmeticOperator: /*@__PURE__*/ t(operator),\n /**\n Logical [operator](https://codemirror.net/6/docs/ref/#highlight.tags.operator).\n */ logicOperator: /*@__PURE__*/ t(operator),\n /**\n Bit [operator](https://codemirror.net/6/docs/ref/#highlight.tags.operator).\n */ bitwiseOperator: /*@__PURE__*/ t(operator),\n /**\n Comparison [operator](https://codemirror.net/6/docs/ref/#highlight.tags.operator).\n */ compareOperator: /*@__PURE__*/ t(operator),\n /**\n [Operator](https://codemirror.net/6/docs/ref/#highlight.tags.operator) that updates its operand.\n */ updateOperator: /*@__PURE__*/ t(operator),\n /**\n [Operator](https://codemirror.net/6/docs/ref/#highlight.tags.operator) that defines something.\n */ definitionOperator: /*@__PURE__*/ t(operator),\n /**\n Type-related [operator](https://codemirror.net/6/docs/ref/#highlight.tags.operator).\n */ typeOperator: /*@__PURE__*/ t(operator),\n /**\n Control-flow [operator](https://codemirror.net/6/docs/ref/#highlight.tags.operator).\n */ controlOperator: /*@__PURE__*/ t(operator),\n /**\n Program or markup punctuation.\n */ punctuation,\n /**\n [Punctuation](https://codemirror.net/6/docs/ref/#highlight.tags.punctuation) that separates\n things.\n */ separator: /*@__PURE__*/ t(punctuation),\n /**\n Bracket-style [punctuation](https://codemirror.net/6/docs/ref/#highlight.tags.punctuation).\n */ bracket,\n /**\n Angle [brackets](https://codemirror.net/6/docs/ref/#highlight.tags.bracket) (usually `<` and `>`\n tokens).\n */ angleBracket: /*@__PURE__*/ t(bracket),\n /**\n Square [brackets](https://codemirror.net/6/docs/ref/#highlight.tags.bracket) (usually `[` and `]`\n tokens).\n */ squareBracket: /*@__PURE__*/ t(bracket),\n /**\n Parentheses (usually `(` and `)` tokens). Subtag of\n [bracket](https://codemirror.net/6/docs/ref/#highlight.tags.bracket).\n */ paren: /*@__PURE__*/ t(bracket),\n /**\n Braces (usually `{` and `}` tokens). Subtag of\n [bracket](https://codemirror.net/6/docs/ref/#highlight.tags.bracket).\n */ brace: /*@__PURE__*/ t(bracket),\n /**\n Content, for example plain text in XML or markup documents.\n */ content,\n /**\n [Content](https://codemirror.net/6/docs/ref/#highlight.tags.content) that represents a heading.\n */ heading,\n /**\n A level 1 [heading](https://codemirror.net/6/docs/ref/#highlight.tags.heading).\n */ heading1: /*@__PURE__*/ t(heading),\n /**\n A level 2 [heading](https://codemirror.net/6/docs/ref/#highlight.tags.heading).\n */ heading2: /*@__PURE__*/ t(heading),\n /**\n A level 3 [heading](https://codemirror.net/6/docs/ref/#highlight.tags.heading).\n */ heading3: /*@__PURE__*/ t(heading),\n /**\n A level 4 [heading](https://codemirror.net/6/docs/ref/#highlight.tags.heading).\n */ heading4: /*@__PURE__*/ t(heading),\n /**\n A level 5 [heading](https://codemirror.net/6/docs/ref/#highlight.tags.heading).\n */ heading5: /*@__PURE__*/ t(heading),\n /**\n A level 6 [heading](https://codemirror.net/6/docs/ref/#highlight.tags.heading).\n */ heading6: /*@__PURE__*/ t(heading),\n /**\n A prose separator (such as a horizontal rule).\n */ contentSeparator: /*@__PURE__*/ t(content),\n /**\n [Content](https://codemirror.net/6/docs/ref/#highlight.tags.content) that represents a list.\n */ list: /*@__PURE__*/ t(content),\n /**\n [Content](https://codemirror.net/6/docs/ref/#highlight.tags.content) that represents a quote.\n */ quote: /*@__PURE__*/ t(content),\n /**\n [Content](https://codemirror.net/6/docs/ref/#highlight.tags.content) that is emphasized.\n */ emphasis: /*@__PURE__*/ t(content),\n /**\n [Content](https://codemirror.net/6/docs/ref/#highlight.tags.content) that is styled strong.\n */ strong: /*@__PURE__*/ t(content),\n /**\n [Content](https://codemirror.net/6/docs/ref/#highlight.tags.content) that is part of a link.\n */ link: /*@__PURE__*/ t(content),\n /**\n [Content](https://codemirror.net/6/docs/ref/#highlight.tags.content) that is styled as code or\n monospace.\n */ monospace: /*@__PURE__*/ t(content),\n /**\n [Content](https://codemirror.net/6/docs/ref/#highlight.tags.content) that has a strike-through\n style.\n */ strikethrough: /*@__PURE__*/ t(content),\n /**\n Inserted text in a change-tracking format.\n */ inserted: /*@__PURE__*/ t(),\n /**\n Deleted text.\n */ deleted: /*@__PURE__*/ t(),\n /**\n Changed text.\n */ changed: /*@__PURE__*/ t(),\n /**\n An invalid or unsyntactic element.\n */ invalid: /*@__PURE__*/ t(),\n /**\n Metadata or meta-instruction.\n */ meta,\n /**\n [Metadata](https://codemirror.net/6/docs/ref/#highlight.tags.meta) that applies to the entire\n document.\n */ documentMeta: /*@__PURE__*/ t(meta),\n /**\n [Metadata](https://codemirror.net/6/docs/ref/#highlight.tags.meta) that annotates or adds\n attributes to a given syntactic element.\n */ annotation: /*@__PURE__*/ t(meta),\n /**\n Processing instruction or preprocessor directive. Subtag of\n [meta](https://codemirror.net/6/docs/ref/#highlight.tags.meta).\n */ processingInstruction: /*@__PURE__*/ t(meta),\n /**\n [Modifier](https://codemirror.net/6/docs/ref/#highlight.Tag^defineModifier) that indicates that a\n given element is being defined. Expected to be used with the\n various [name](https://codemirror.net/6/docs/ref/#highlight.tags.name) tags.\n */ definition: /*@__PURE__*/ Tag.defineModifier(),\n /**\n [Modifier](https://codemirror.net/6/docs/ref/#highlight.Tag^defineModifier) that indicates that\n something is constant. Mostly expected to be used with\n [variable names](https://codemirror.net/6/docs/ref/#highlight.tags.variableName).\n */ constant: /*@__PURE__*/ Tag.defineModifier(),\n /**\n [Modifier](https://codemirror.net/6/docs/ref/#highlight.Tag^defineModifier) used to indicate that\n a [variable](https://codemirror.net/6/docs/ref/#highlight.tags.variableName) or [property\n name](https://codemirror.net/6/docs/ref/#highlight.tags.propertyName) is being called or defined\n as a function.\n */ function: /*@__PURE__*/ Tag.defineModifier(),\n /**\n [Modifier](https://codemirror.net/6/docs/ref/#highlight.Tag^defineModifier) that can be applied to\n [names](https://codemirror.net/6/docs/ref/#highlight.tags.name) to indicate that they belong to\n the language's standard environment.\n */ standard: /*@__PURE__*/ Tag.defineModifier(),\n /**\n [Modifier](https://codemirror.net/6/docs/ref/#highlight.Tag^defineModifier) that indicates a given\n [names](https://codemirror.net/6/docs/ref/#highlight.tags.name) is local to some scope.\n */ local: /*@__PURE__*/ Tag.defineModifier(),\n /**\n A generic variant [modifier](https://codemirror.net/6/docs/ref/#highlight.Tag^defineModifier) that\n can be used to tag language-specific alternative variants of\n some common tag. It is recommended for themes to define special\n forms of at least the [string](https://codemirror.net/6/docs/ref/#highlight.tags.string) and\n [variable name](https://codemirror.net/6/docs/ref/#highlight.tags.variableName) tags, since those\n come up a lot.\n */ special: /*@__PURE__*/ Tag.defineModifier()\n};\n/**\nA default highlight style (works well with light themes).\n*/ const defaultHighlightStyle = /*@__PURE__*/ HighlightStyle.define([\n {\n tag: tags.link,\n textDecoration: \"underline\"\n },\n {\n tag: tags.heading,\n textDecoration: \"underline\",\n fontWeight: \"bold\"\n },\n {\n tag: tags.emphasis,\n fontStyle: \"italic\"\n },\n {\n tag: tags.strong,\n fontWeight: \"bold\"\n },\n {\n tag: tags.strikethrough,\n textDecoration: \"line-through\"\n },\n {\n tag: tags.keyword,\n color: \"#708\"\n },\n {\n tag: [\n tags.atom,\n tags.bool,\n tags.url,\n tags.contentSeparator,\n tags.labelName\n ],\n color: \"#219\"\n },\n {\n tag: [\n tags.literal,\n tags.inserted\n ],\n color: \"#164\"\n },\n {\n tag: [\n tags.string,\n tags.deleted\n ],\n color: \"#a11\"\n },\n {\n tag: [\n tags.regexp,\n tags.escape,\n /*@__PURE__*/ tags.special(tags.string)\n ],\n color: \"#e40\"\n },\n {\n tag: /*@__PURE__*/ tags.definition(tags.variableName),\n color: \"#00f\"\n },\n {\n tag: /*@__PURE__*/ tags.local(tags.variableName),\n color: \"#30a\"\n },\n {\n tag: [\n tags.typeName,\n tags.namespace\n ],\n color: \"#085\"\n },\n {\n tag: tags.className,\n color: \"#167\"\n },\n {\n tag: [\n /*@__PURE__*/ tags.special(tags.variableName),\n tags.macroName\n ],\n color: \"#256\"\n },\n {\n tag: /*@__PURE__*/ tags.definition(tags.propertyName),\n color: \"#00c\"\n },\n {\n tag: tags.comment,\n color: \"#940\"\n },\n {\n tag: tags.meta,\n color: \"#7a757a\"\n },\n {\n tag: tags.invalid,\n color: \"#f00\"\n }\n]);\n/**\nThis is a highlight style that adds stable, predictable classes to\ntokens, for styling with external CSS.\n\nThese tags are mapped to their name prefixed with `\"cmt-\"` (for\nexample `\"cmt-comment\"`):\n\n* [`link`](https://codemirror.net/6/docs/ref/#highlight.tags.link)\n* [`heading`](https://codemirror.net/6/docs/ref/#highlight.tags.heading)\n* [`emphasis`](https://codemirror.net/6/docs/ref/#highlight.tags.emphasis)\n* [`strong`](https://codemirror.net/6/docs/ref/#highlight.tags.strong)\n* [`keyword`](https://codemirror.net/6/docs/ref/#highlight.tags.keyword)\n* [`atom`](https://codemirror.net/6/docs/ref/#highlight.tags.atom) [`bool`](https://codemirror.net/6/docs/ref/#highlight.tags.bool)\n* [`url`](https://codemirror.net/6/docs/ref/#highlight.tags.url)\n* [`labelName`](https://codemirror.net/6/docs/ref/#highlight.tags.labelName)\n* [`inserted`](https://codemirror.net/6/docs/ref/#highlight.tags.inserted)\n* [`deleted`](https://codemirror.net/6/docs/ref/#highlight.tags.deleted)\n* [`literal`](https://codemirror.net/6/docs/ref/#highlight.tags.literal)\n* [`string`](https://codemirror.net/6/docs/ref/#highlight.tags.string)\n* [`number`](https://codemirror.net/6/docs/ref/#highlight.tags.number)\n* [`variableName`](https://codemirror.net/6/docs/ref/#highlight.tags.variableName)\n* [`typeName`](https://codemirror.net/6/docs/ref/#highlight.tags.typeName)\n* [`namespace`](https://codemirror.net/6/docs/ref/#highlight.tags.namespace)\n* [`className`](https://codemirror.net/6/docs/ref/#highlight.tags.className)\n* [`macroName`](https://codemirror.net/6/docs/ref/#highlight.tags.macroName)\n* [`propertyName`](https://codemirror.net/6/docs/ref/#highlight.tags.propertyName)\n* [`operator`](https://codemirror.net/6/docs/ref/#highlight.tags.operator)\n* [`comment`](https://codemirror.net/6/docs/ref/#highlight.tags.comment)\n* [`meta`](https://codemirror.net/6/docs/ref/#highlight.tags.meta)\n* [`punctuation`](https://codemirror.net/6/docs/ref/#highlight.tags.puncutation)\n* [`invalid`](https://codemirror.net/6/docs/ref/#highlight.tags.invalid)\n\nIn addition, these mappings are provided:\n\n* [`regexp`](https://codemirror.net/6/docs/ref/#highlight.tags.regexp),\n [`escape`](https://codemirror.net/6/docs/ref/#highlight.tags.escape), and\n [`special`](https://codemirror.net/6/docs/ref/#highlight.tags.special)[`(string)`](https://codemirror.net/6/docs/ref/#highlight.tags.string)\n are mapped to `\"cmt-string2\"`\n* [`special`](https://codemirror.net/6/docs/ref/#highlight.tags.special)[`(variableName)`](https://codemirror.net/6/docs/ref/#highlight.tags.variableName)\n to `\"cmt-variableName2\"`\n* [`local`](https://codemirror.net/6/docs/ref/#highlight.tags.local)[`(variableName)`](https://codemirror.net/6/docs/ref/#highlight.tags.variableName)\n to `\"cmt-variableName cmt-local\"`\n* [`definition`](https://codemirror.net/6/docs/ref/#highlight.tags.definition)[`(variableName)`](https://codemirror.net/6/docs/ref/#highlight.tags.variableName)\n to `\"cmt-variableName cmt-definition\"`\n* [`definition`](https://codemirror.net/6/docs/ref/#highlight.tags.definition)[`(propertyName)`](https://codemirror.net/6/docs/ref/#highlight.tags.propertyName)\n to `\"cmt-propertyName cmt-definition\"`\n*/ const classHighlightStyle = /*@__PURE__*/ HighlightStyle.define([\n {\n tag: tags.link,\n class: \"cmt-link\"\n },\n {\n tag: tags.heading,\n class: \"cmt-heading\"\n },\n {\n tag: tags.emphasis,\n class: \"cmt-emphasis\"\n },\n {\n tag: tags.strong,\n class: \"cmt-strong\"\n },\n {\n tag: tags.keyword,\n class: \"cmt-keyword\"\n },\n {\n tag: tags.atom,\n class: \"cmt-atom\"\n },\n {\n tag: tags.bool,\n class: \"cmt-bool\"\n },\n {\n tag: tags.url,\n class: \"cmt-url\"\n },\n {\n tag: tags.labelName,\n class: \"cmt-labelName\"\n },\n {\n tag: tags.inserted,\n class: \"cmt-inserted\"\n },\n {\n tag: tags.deleted,\n class: \"cmt-deleted\"\n },\n {\n tag: tags.literal,\n class: \"cmt-literal\"\n },\n {\n tag: tags.string,\n class: \"cmt-string\"\n },\n {\n tag: tags.number,\n class: \"cmt-number\"\n },\n {\n tag: [\n tags.regexp,\n tags.escape,\n /*@__PURE__*/ tags.special(tags.string)\n ],\n class: \"cmt-string2\"\n },\n {\n tag: tags.variableName,\n class: \"cmt-variableName\"\n },\n {\n tag: /*@__PURE__*/ tags.local(tags.variableName),\n class: \"cmt-variableName cmt-local\"\n },\n {\n tag: /*@__PURE__*/ tags.definition(tags.variableName),\n class: \"cmt-variableName cmt-definition\"\n },\n {\n tag: /*@__PURE__*/ tags.special(tags.variableName),\n class: \"cmt-variableName2\"\n },\n {\n tag: /*@__PURE__*/ tags.definition(tags.propertyName),\n class: \"cmt-propertyName cmt-definition\"\n },\n {\n tag: tags.typeName,\n class: \"cmt-typeName\"\n },\n {\n tag: tags.namespace,\n class: \"cmt-namespace\"\n },\n {\n tag: tags.className,\n class: \"cmt-className\"\n },\n {\n tag: tags.macroName,\n class: \"cmt-macroName\"\n },\n {\n tag: tags.propertyName,\n class: \"cmt-propertyName\"\n },\n {\n tag: tags.operator,\n class: \"cmt-operator\"\n },\n {\n tag: tags.comment,\n class: \"cmt-comment\"\n },\n {\n tag: tags.meta,\n class: \"cmt-meta\"\n },\n {\n tag: tags.invalid,\n class: \"cmt-invalid\"\n },\n {\n tag: tags.punctuation,\n class: \"cmt-punctuation\"\n }\n]);\n\n},{\"@lezer/common\":\"ds1Io\",\"style-mod\":\"7FGwv\",\"@codemirror/view\":\"JuP5Z\",\"@codemirror/state\":\"e6FBl\",\"@codemirror/language\":\"70QHL\",\"@codemirror/rangeset\":\"9yBpo\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"fpWUM\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"esLint\", ()=>esLint\n);\nparcelHelpers.export(exports, \"javascript\", ()=>javascript\n);\nparcelHelpers.export(exports, \"javascriptLanguage\", ()=>javascriptLanguage\n);\nparcelHelpers.export(exports, \"jsxLanguage\", ()=>jsxLanguage\n);\nparcelHelpers.export(exports, \"snippets\", ()=>snippets\n);\nparcelHelpers.export(exports, \"tsxLanguage\", ()=>tsxLanguage\n);\nparcelHelpers.export(exports, \"typescriptLanguage\", ()=>typescriptLanguage\n);\nvar _javascript = require(\"@lezer/javascript\");\nvar _language = require(\"@codemirror/language\");\nvar _highlight = require(\"@codemirror/highlight\");\nvar _autocomplete = require(\"@codemirror/autocomplete\");\n/**\nA collection of JavaScript-related\n[snippets](https://codemirror.net/6/docs/ref/#autocomplete.snippet).\n*/ const snippets = [\n /*@__PURE__*/ _autocomplete.snippetCompletion(\"function ${name}(${params}) {\\n\\t${}\\n}\", {\n label: \"function\",\n detail: \"definition\",\n type: \"keyword\"\n }),\n /*@__PURE__*/ _autocomplete.snippetCompletion(\"for (let ${index} = 0; ${index} < ${bound}; ${index}++) {\\n\\t${}\\n}\", {\n label: \"for\",\n detail: \"loop\",\n type: \"keyword\"\n }),\n /*@__PURE__*/ _autocomplete.snippetCompletion(\"for (let ${name} of ${collection}) {\\n\\t${}\\n}\", {\n label: \"for\",\n detail: \"of loop\",\n type: \"keyword\"\n }),\n /*@__PURE__*/ _autocomplete.snippetCompletion(\"try {\\n\\t${}\\n} catch (${error}) {\\n\\t${}\\n}\", {\n label: \"try\",\n detail: \"block\",\n type: \"keyword\"\n }),\n /*@__PURE__*/ _autocomplete.snippetCompletion(\"class ${name} {\\n\\tconstructor(${params}) {\\n\\t\\t${}\\n\\t}\\n}\", {\n label: \"class\",\n detail: \"definition\",\n type: \"keyword\"\n }),\n /*@__PURE__*/ _autocomplete.snippetCompletion(\"import {${names}} from \\\"${module}\\\"\\n${}\", {\n label: \"import\",\n detail: \"named\",\n type: \"keyword\"\n }),\n /*@__PURE__*/ _autocomplete.snippetCompletion(\"import ${name} from \\\"${module}\\\"\\n${}\", {\n label: \"import\",\n detail: \"default\",\n type: \"keyword\"\n })\n];\n/**\nA language provider based on the [Lezer JavaScript\nparser](https://github.com/lezer-parser/javascript), extended with\nhighlighting and indentation information.\n*/ const javascriptLanguage = /*@__PURE__*/ _language.LRLanguage.define({\n parser: /*@__PURE__*/ _javascript.parser.configure({\n props: [\n /*@__PURE__*/ _language.indentNodeProp.add({\n IfStatement: /*@__PURE__*/ _language.continuedIndent({\n except: /^\\s*({|else\\b)/\n }),\n TryStatement: /*@__PURE__*/ _language.continuedIndent({\n except: /^\\s*({|catch\\b|finally\\b)/\n }),\n LabeledStatement: _language.flatIndent,\n SwitchBody: (context)=>{\n let after = context.textAfter, closed = /^\\s*\\}/.test(after), isCase = /^\\s*(case|default)\\b/.test(after);\n return context.baseIndent + (closed ? 0 : isCase ? 1 : 2) * context.unit;\n },\n Block: /*@__PURE__*/ _language.delimitedIndent({\n closing: \"}\"\n }),\n ArrowFunction: (cx)=>cx.baseIndent + cx.unit\n ,\n \"TemplateString BlockComment\": ()=>-1\n ,\n \"Statement Property\": /*@__PURE__*/ _language.continuedIndent({\n except: /^{/\n }),\n JSXElement (context) {\n let closed = /^\\s*<\\//.test(context.textAfter);\n return context.lineIndent(context.node.from) + (closed ? 0 : context.unit);\n },\n JSXEscape (context) {\n let closed = /\\s*\\}/.test(context.textAfter);\n return context.lineIndent(context.node.from) + (closed ? 0 : context.unit);\n },\n \"JSXOpenTag JSXSelfClosingTag\" (context) {\n return context.column(context.node.from) + context.unit;\n }\n }),\n /*@__PURE__*/ _language.foldNodeProp.add({\n \"Block ClassBody SwitchBody EnumBody ObjectExpression ArrayExpression\": _language.foldInside,\n BlockComment (tree) {\n return {\n from: tree.from + 2,\n to: tree.to - 2\n };\n }\n }),\n /*@__PURE__*/ _highlight.styleTags({\n \"get set async static\": _highlight.tags.modifier,\n \"for while do if else switch try catch finally return throw break continue default case\": _highlight.tags.controlKeyword,\n \"in of await yield void typeof delete instanceof\": _highlight.tags.operatorKeyword,\n \"let var const function class extends\": _highlight.tags.definitionKeyword,\n \"import export from\": _highlight.tags.moduleKeyword,\n \"with debugger as new\": _highlight.tags.keyword,\n TemplateString: /*@__PURE__*/ _highlight.tags.special(_highlight.tags.string),\n Super: _highlight.tags.atom,\n BooleanLiteral: _highlight.tags.bool,\n this: _highlight.tags.self,\n null: _highlight.tags.null,\n Star: _highlight.tags.modifier,\n VariableName: _highlight.tags.variableName,\n \"CallExpression/VariableName TaggedTemplateExpression/VariableName\": /*@__PURE__*/ _highlight.tags.function(_highlight.tags.variableName),\n VariableDefinition: /*@__PURE__*/ _highlight.tags.definition(_highlight.tags.variableName),\n Label: _highlight.tags.labelName,\n PropertyName: _highlight.tags.propertyName,\n PrivatePropertyName: /*@__PURE__*/ _highlight.tags.special(_highlight.tags.propertyName),\n \"CallExpression/MemberExpression/PropertyName\": /*@__PURE__*/ _highlight.tags.function(_highlight.tags.propertyName),\n \"FunctionDeclaration/VariableDefinition\": /*@__PURE__*/ _highlight.tags.function(/*@__PURE__*/ _highlight.tags.definition(_highlight.tags.variableName)),\n \"ClassDeclaration/VariableDefinition\": /*@__PURE__*/ _highlight.tags.definition(_highlight.tags.className),\n PropertyDefinition: /*@__PURE__*/ _highlight.tags.definition(_highlight.tags.propertyName),\n PrivatePropertyDefinition: /*@__PURE__*/ _highlight.tags.definition(/*@__PURE__*/ _highlight.tags.special(_highlight.tags.propertyName)),\n UpdateOp: _highlight.tags.updateOperator,\n LineComment: _highlight.tags.lineComment,\n BlockComment: _highlight.tags.blockComment,\n Number: _highlight.tags.number,\n String: _highlight.tags.string,\n ArithOp: _highlight.tags.arithmeticOperator,\n LogicOp: _highlight.tags.logicOperator,\n BitOp: _highlight.tags.bitwiseOperator,\n CompareOp: _highlight.tags.compareOperator,\n RegExp: _highlight.tags.regexp,\n Equals: _highlight.tags.definitionOperator,\n \"Arrow : Spread\": _highlight.tags.punctuation,\n \"( )\": _highlight.tags.paren,\n \"[ ]\": _highlight.tags.squareBracket,\n \"{ }\": _highlight.tags.brace,\n \"InterpolationStart InterpolationEnd\": /*@__PURE__*/ _highlight.tags.special(_highlight.tags.brace),\n \".\": _highlight.tags.derefOperator,\n \", ;\": _highlight.tags.separator,\n TypeName: _highlight.tags.typeName,\n TypeDefinition: /*@__PURE__*/ _highlight.tags.definition(_highlight.tags.typeName),\n \"type enum interface implements namespace module declare\": _highlight.tags.definitionKeyword,\n \"abstract global Privacy readonly override\": _highlight.tags.modifier,\n \"is keyof unique infer\": _highlight.tags.operatorKeyword,\n JSXAttributeValue: _highlight.tags.attributeValue,\n JSXText: _highlight.tags.content,\n \"JSXStartTag JSXStartCloseTag JSXSelfCloseEndTag JSXEndTag\": _highlight.tags.angleBracket,\n \"JSXIdentifier JSXNameSpacedName\": _highlight.tags.tagName,\n \"JSXAttribute/JSXIdentifier JSXAttribute/JSXNameSpacedName\": _highlight.tags.attributeName\n })\n ]\n }),\n languageData: {\n closeBrackets: {\n brackets: [\n \"(\",\n \"[\",\n \"{\",\n \"'\",\n '\"',\n \"`\"\n ]\n },\n commentTokens: {\n line: \"//\",\n block: {\n open: \"/*\",\n close: \"*/\"\n }\n },\n indentOnInput: /^\\s*(?:case |default:|\\{|\\}|<\\/)$/,\n wordChars: \"$\"\n }\n});\n/**\nA language provider for TypeScript.\n*/ const typescriptLanguage = /*@__PURE__*/ javascriptLanguage.configure({\n dialect: \"ts\"\n});\n/**\nLanguage provider for JSX.\n*/ const jsxLanguage = /*@__PURE__*/ javascriptLanguage.configure({\n dialect: \"jsx\"\n});\n/**\nLanguage provider for JSX + TypeScript.\n*/ const tsxLanguage = /*@__PURE__*/ javascriptLanguage.configure({\n dialect: \"jsx ts\"\n});\n/**\nJavaScript support. Includes [snippet](https://codemirror.net/6/docs/ref/#lang-javascript.snippets)\ncompletion.\n*/ function javascript(config = {\n}) {\n let lang = config.jsx ? config.typescript ? tsxLanguage : jsxLanguage : config.typescript ? typescriptLanguage : javascriptLanguage;\n return new _language.LanguageSupport(lang, javascriptLanguage.data.of({\n autocomplete: _autocomplete.ifNotIn([\n \"LineComment\",\n \"BlockComment\",\n \"String\"\n ], _autocomplete.completeFromList(snippets))\n }));\n}\n/**\nConnects an [ESLint](https://eslint.org/) linter to CodeMirror's\n[lint](https://codemirror.net/6/docs/ref/#lint) integration. `eslint` should be an instance of the\n[`Linter`](https://eslint.org/docs/developer-guide/nodejs-api#linter)\nclass, and `config` an optional ESLint configuration. The return\nvalue of this function can be passed to [`linter`](https://codemirror.net/6/docs/ref/#lint.linter)\nto create a JavaScript linting extension.\n\nNote that ESLint targets node, and is tricky to run in the\nbrowser. The [eslint4b](https://github.com/mysticatea/eslint4b)\nand\n[eslint4b-prebuilt](https://github.com/marijnh/eslint4b-prebuilt/)\npackages may help with that.\n*/ function esLint(eslint, config) {\n if (!config) {\n config = {\n parserOptions: {\n ecmaVersion: 2019,\n sourceType: \"module\"\n },\n env: {\n browser: true,\n node: true,\n es6: true,\n es2015: true,\n es2017: true,\n es2020: true\n },\n rules: {\n }\n };\n eslint.getRules().forEach((desc, name)=>{\n if (desc.meta.docs.recommended) config.rules[name] = 2;\n });\n }\n return (view)=>{\n let { state } = view, found = [];\n for (let { from , to } of javascriptLanguage.findRegions(state)){\n let fromLine = state.doc.lineAt(from), offset = {\n line: fromLine.number - 1,\n col: from - fromLine.from,\n pos: from\n };\n for (let d of eslint.verify(state.sliceDoc(from, to), config))found.push(translateDiagnostic(d, state.doc, offset));\n }\n return found;\n };\n}\nfunction mapPos(line, col, doc, offset) {\n return doc.line(line + offset.line).from + col + (line == 1 ? offset.col - 1 : -1);\n}\nfunction translateDiagnostic(input, doc, offset) {\n let start1 = mapPos(input.line, input.column, doc, offset);\n let result = {\n from: start1,\n to: input.endLine != null && input.endColumn != 1 ? mapPos(input.endLine, input.endColumn, doc, offset) : start1,\n message: input.message,\n source: input.ruleId ? \"jshint:\" + input.ruleId : \"jshint\",\n severity: input.severity == 1 ? \"warning\" : \"error\"\n };\n if (input.fix) {\n let { range , text } = input.fix, from = range[0] + offset.pos - start1, to = range[1] + offset.pos - start1;\n result.actions = [\n {\n name: \"fix\",\n apply (view, start) {\n view.dispatch({\n changes: {\n from: start + from,\n to: start + to,\n insert: text\n },\n scrollIntoView: true\n });\n }\n }\n ];\n }\n return result;\n}\n\n},{\"@lezer/javascript\":\"76N3F\",\"@codemirror/language\":\"70QHL\",\"@codemirror/highlight\":\"cVRRs\",\"@codemirror/autocomplete\":\"6gQUZ\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"76N3F\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"parser\", ()=>parser\n);\nvar _lr = require(\"@lezer/lr\");\nvar _common = require(\"@lezer/common\");\n// This file was generated by lezer-generator. You probably shouldn't edit it.\nconst noSemi = 279, incdec = 1, incdecPrefix = 2, templateContent = 280, InterpolationStart = 3, templateEnd = 281, insertSemi = 282, TSExtends = 4, spaces = 284, newline = 285, LineComment = 5, BlockComment = 6, Dialect_ts = 1;\n/* Hand-written tokenizers for JavaScript tokens that can't be\n expressed by lezer's built-in tokenizer. */ const space = [\n 9,\n 10,\n 11,\n 12,\n 13,\n 32,\n 133,\n 160,\n 5760,\n 8192,\n 8193,\n 8194,\n 8195,\n 8196,\n 8197,\n 8198,\n 8199,\n 8200,\n 8201,\n 8202,\n 8232,\n 8233,\n 8239,\n 8287,\n 12288\n];\nconst braceR = 125, braceL = 123, semicolon = 59, slash = 47, star = 42, plus = 43, minus = 45, dollar = 36, backtick = 96, backslash = 92;\nconst trackNewline = new _lr.ContextTracker({\n start: false,\n shift (context, term) {\n return term == LineComment || term == BlockComment || term == spaces ? context : term == newline;\n },\n strict: false\n});\nconst insertSemicolon = new _lr.ExternalTokenizer((input, stack)=>{\n let { next } = input;\n if ((next == braceR || next == -1 || stack.context) && stack.canShift(insertSemi)) input.acceptToken(insertSemi);\n}, {\n contextual: true,\n fallback: true\n});\nconst noSemicolon = new _lr.ExternalTokenizer((input, stack)=>{\n let { next } = input, after;\n if (space.indexOf(next) > -1) return;\n if (next == slash && ((after = input.peek(1)) == slash || after == star)) return;\n if (next != braceR && next != semicolon && next != -1 && !stack.context && stack.canShift(noSemi)) input.acceptToken(noSemi);\n}, {\n contextual: true\n});\nconst incdecToken = new _lr.ExternalTokenizer((input, stack)=>{\n let { next } = input;\n if (next == plus || next == minus) {\n input.advance();\n if (next == input.next) {\n input.advance();\n let mayPostfix = !stack.context && stack.canShift(incdec);\n input.acceptToken(mayPostfix ? incdec : incdecPrefix);\n }\n }\n}, {\n contextual: true\n});\nconst template = new _lr.ExternalTokenizer((input)=>{\n for(let afterDollar = false, i = 0;; i++){\n let { next } = input;\n if (next < 0) {\n if (i) input.acceptToken(templateContent);\n break;\n } else if (next == backtick) {\n if (i) input.acceptToken(templateContent);\n else input.acceptToken(templateEnd, 1);\n break;\n } else if (next == braceL && afterDollar) {\n if (i == 1) input.acceptToken(InterpolationStart, 1);\n else input.acceptToken(templateContent, -1);\n break;\n } else if (next == 10 /* \"\\n\" */ && i) {\n // Break up template strings on lines, to avoid huge tokens\n input.advance();\n input.acceptToken(templateContent);\n break;\n } else if (next == backslash) input.advance();\n afterDollar = next == dollar;\n input.advance();\n }\n});\nfunction tsExtends(value, stack) {\n return value == \"extends\" && stack.dialectEnabled(Dialect_ts) ? TSExtends : -1;\n}\n// This file was generated by lezer-generator. You probably shouldn't edit it.\nconst spec_identifier = {\n __proto__: null,\n export: 18,\n as: 23,\n from: 29,\n default: 32,\n async: 37,\n function: 38,\n this: 48,\n true: 56,\n false: 56,\n void: 66,\n typeof: 70,\n null: 86,\n super: 88,\n new: 122,\n await: 139,\n yield: 141,\n delete: 142,\n class: 152,\n extends: 154,\n public: 197,\n private: 197,\n protected: 197,\n readonly: 199,\n instanceof: 220,\n in: 222,\n const: 224,\n import: 256,\n keyof: 307,\n unique: 311,\n infer: 317,\n is: 351,\n abstract: 371,\n implements: 373,\n type: 375,\n let: 378,\n var: 380,\n interface: 387,\n enum: 391,\n namespace: 397,\n module: 399,\n declare: 403,\n global: 407,\n for: 428,\n of: 437,\n while: 440,\n with: 444,\n do: 448,\n if: 452,\n else: 454,\n switch: 458,\n case: 464,\n try: 470,\n catch: 472,\n finally: 474,\n return: 478,\n throw: 482,\n break: 486,\n continue: 490,\n debugger: 494\n};\nconst spec_word = {\n __proto__: null,\n async: 109,\n get: 111,\n set: 113,\n public: 161,\n private: 161,\n protected: 161,\n static: 163,\n abstract: 165,\n override: 167,\n readonly: 173,\n new: 355\n};\nconst spec_LessThan = {\n __proto__: null,\n \"<\": 129\n};\nconst parser = _lr.LRParser.deserialize({\n version: 13,\n states: \"$1jO`QYOOO'QQ!LdO'#ChO'XOSO'#DVO)dQYO'#D]O)tQYO'#DhO){QYO'#DrO-xQYO'#DxOOQO'#E]'#E]O.]QWO'#E[O.bQWO'#E[OOQ!LS'#Ef'#EfO0aQ!LdO'#IrO2wQ!LdO'#IsO3eQWO'#EzO3jQpO'#FaOOQ!LS'#FS'#FSO3rO!bO'#FSO4QQWO'#FhO5_QWO'#FgOOQ!LS'#Is'#IsOOQ!LQ'#Ir'#IrOOQQ'#J['#J[O5dQWO'#HnO5iQ!LYO'#HoOOQQ'#If'#IfOOQQ'#Hp'#HpQ`QYOOO){QYO'#DjO5qQWO'#G[O5vQ#tO'#CmO6UQWO'#EZO6aQWO'#EgO6fQ#tO'#FRO7QQWO'#G[O7VQWO'#G`O7bQWO'#G`O7pQWO'#GcO7pQWO'#GdO7pQWO'#GfO5qQWO'#GiO8aQWO'#GlO9oQWO'#CdO:PQWO'#GyO:XQWO'#HPO:XQWO'#HRO`QYO'#HTO:XQWO'#HVO:XQWO'#HYO:^QWO'#H`O:cQ!LZO'#HdO){QYO'#HfO:nQ!LZO'#HhO:yQ!LZO'#HjO5iQ!LYO'#HlO){QYO'#DWOOOS'#Hr'#HrO;UOSO,59qOOQ!LS,59q,59qO=gQbO'#ChO=qQYO'#HsO>UQWO'#ItO@TQbO'#ItO'dQYO'#ItO@[QWO,59wO@rQ&jO'#DbOAkQWO'#E]OAxQWO'#JPOBTQWO'#JOOBTQWO'#JOOB]QWO,5:yOBbQWO'#I}OBiQWO'#DyO5vQ#tO'#EZOBwQWO'#EZOCSQ`O'#FROOQ!LS,5:S,5:SOC[QYO,5:SOEYQ!LdO,5:^OEvQWO,5:dOFaQ!LYO'#I|O7VQWO'#I{OFhQWO'#I{OFpQWO,5:xOFuQWO'#I{OGTQYO,5:vOITQWO'#EWOJ_QWO,5:vOKnQWO'#DlOKuQYO'#DqOLPQ&jO,5;PO){QYO,5;POOQQ'#Er'#ErOOQQ'#Et'#EtO){QYO,5;RO){QYO,5;RO){QYO,5;RO){QYO,5;RO){QYO,5;RO){QYO,5;RO){QYO,5;RO){QYO,5;RO){QYO,5;RO){QYO,5;RO){QYO,5;ROOQQ'#Ex'#ExOLXQYO,5;cOOQ!LS,5;h,5;hOOQ!LS,5;i,5;iONXQWO,5;iOOQ!LS,5;j,5;jO){QYO'#H}ON^Q!LYO,5<TONxQWO,5;RO){QYO,5;fO! bQpO'#JTO! PQpO'#JTO! iQpO'#JTO! zQpO,5;qOOOO,5;{,5;{O!!YQYO'#FcOOOO'#H|'#H|O3rO!bO,5;nO!!aQpO'#FeOOQ!LS,5;n,5;nO!!}Q,UO'#CrOOQ!LS'#Cu'#CuO!#bQWO'#CuO!#gOSO'#CyO!$TQ#tO,5<QO!$[QWO,5<SO!%hQWO'#FrO!%uQWO'#FsO!%zQWO'#FwO!&|Q&jO'#F{O!'oQ,UO'#IoOOQ!LS'#Io'#IoO!'yQWO'#InO!(XQWO'#ImOOQ!LS'#Cs'#CsOOQ!LS'#C|'#C|O!(aQWO'#DOOJdQWO'#FjOJdQWO'#FlO!(fQWO'#FnO!(kQWO'#FoO!(pQWO'#FuOJdQWO'#FzO!(uQWO'#E^O!)^QWO,5<RO`QYO,5>YOOQQ'#Ii'#IiOOQQ,5>Z,5>ZOOQQ-E;n-E;nO!+YQ!LdO,5:UOOQ!LQ'#Cp'#CpO!+yQ#tO,5<vOOQO'#Cf'#CfO!,[QWO'#CqO!,dQ!LYO'#IjO5_QWO'#IjO:^QWO,59XO!,rQpO,59XO!,zQ#tO,59XO5vQ#tO,59XO!-VQWO,5:vO!-_QWO'#GxO!-mQWO'#J`O){QYO,5;kO!-uQ&jO,5;mO!-zQWO,5=cO!.PQWO,5=cO!.UQWO,5=cO5iQ!LYO,5=cO5qQWO,5<vO!.dQWO'#E_O!.xQ&jO'#E`OOQ!LQ'#I}'#I}O!/ZQ!LYO'#J]O5iQ!LYO,5<zO7pQWO,5=QOOQO'#Cr'#CrO!/fQpO,5<}O!/nQ#tO,5=OO!/yQWO,5=QO!0OQ`O,5=TO:^QWO'#GnO5qQWO'#GpO!0WQWO'#GpO5vQ#tO'#GsO!0]QWO'#GsOOQQ,5=W,5=WO!0bQWO'#GtO!0jQWO'#CmO!0oQWO,59OO!0yQWO,59OO!2{QYO,59OOOQQ,59O,59OO!3YQ!LYO,59OO){QYO,59OO!3eQYO'#G{OOQQ'#G|'#G|OOQQ'#G}'#G}O`QYO,5=eO!3uQWO,5=eO){QYO'#DxO`QYO,5=kO`QYO,5=mO!3zQWO,5=oO`QYO,5=qO!4PQWO,5=tO!4UQYO,5=zOOQQ,5>O,5>OO){QYO,5>OO5iQ!LYO,5>QOOQQ,5>S,5>SO!8VQWO,5>SOOQQ,5>U,5>UO!8VQWO,5>UOOQQ,5>W,5>WO!8[Q`O,59rOOOS-E;p-E;pOOQ!LS1G/]1G/]O!8aQbO,5>_O'dQYO,5>_OOQO,5>d,5>dO!8kQYO'#HsOOQO-E;q-E;qO!8xQWO,5?`O!9QQbO,5?`O!9XQWO,5?jOOQ!LS1G/c1G/cO!9aQpO'#DTOOQO'#Iv'#IvO){QYO'#IvO!:OQpO'#IvO!:mQpO'#DcO!;OQ&jO'#DcO!=ZQYO'#DcO!=bQWO'#IuO!=jQWO,59|O!=oQWO'#EaO!=}QWO'#JQO!>VQWO,5:zO!>mQ&jO'#DcO){QYO,5?kO!>wQWO'#HxOOQO-E;v-E;vO!9XQWO,5?jOOQ!LQ1G0e1G0eO!@TQ&jO'#D|OOQ!LS,5:e,5:eO){QYO,5:eOITQWO,5:eO!@[QWO,5:eO:^QWO,5:uO!,rQpO,5:uO!,zQ#tO,5:uO5vQ#tO,5:uOOQ!LS1G/n1G/nOOQ!LS1G0O1G0OOOQ!LQ'#EV'#EVO){QYO,5?hO!@gQ!LYO,5?hO!@xQ!LYO,5?hO!APQWO,5?gO!AXQWO'#HzO!APQWO,5?gOOQ!LQ1G0d1G0dO7VQWO,5?gOOQ!LS1G0b1G0bO!AsQ!LdO1G0bO!BdQ!LbO,5:rOOQ!LS'#Fq'#FqO!CQQ!LdO'#IoOGTQYO1G0bO!EPQ#tO'#IwO!EZQWO,5:WO!E`QbO'#IxO){QYO'#IxO!EjQWO,5:]OOQ!LS'#DT'#DTOOQ!LS1G0k1G0kO!EoQWO1G0kO!HQQ!LdO1G0mO!HXQ!LdO1G0mO!JlQ!LdO1G0mO!JsQ!LdO1G0mO!LzQ!LdO1G0mO!M_Q!LdO1G0mO#!OQ!LdO1G0mO#!VQ!LdO1G0mO#$jQ!LdO1G0mO#$qQ!LdO1G0mO#&fQ!LdO1G0mO#)`Q7^O'#ChO#+ZQ7^O1G0}O#-UQ7^O'#IsOOQ!LS1G1T1G1TO#-iQ!LdO,5>iOOQ!LQ-E;{-E;{O#.YQ!LdO1G0mOOQ!LS1G0m1G0mO#0[Q!LdO1G1QO#0{QpO,5;sO#1QQpO,5;tO#1VQpO'#F[O#1kQWO'#FZOOQO'#JU'#JUOOQO'#H{'#H{O#1pQpO1G1]OOQ!LS1G1]1G1]OOOO1G1f1G1fO#2OQ7^O'#IrO#2YQWO,5;}OLXQYO,5;}OOOO-E;z-E;zOOQ!LS1G1Y1G1YOOQ!LS,5<P,5<PO#2_QpO,5<POOQ!LS,59a,59aOITQWO'#C{OOOS'#Hq'#HqO#2dOSO,59eOOQ!LS,59e,59eO){QYO1G1lO!(kQWO'#IPO#2oQWO,5<eOOQ!LS,5<b,5<bOOQO'#GV'#GVOJdQWO,5<pOOQO'#GX'#GXOJdQWO,5<rOJdQWO,5<tOOQO1G1n1G1nO#2zQ`O'#CpO#3_Q`O,5<^O#3fQWO'#JXO5qQWO'#JXO#3tQWO,5<`OJdQWO,5<_O#3yQ`O'#FqO#4WQ`O'#JYO#4bQWO'#JYOITQWO'#JYO#4gQWO,5<cOOQ!LQ'#Dg'#DgO#4lQWO'#FtO#4wQpO'#F|O!&wQ&jO'#F|O!&wQ&jO'#GOO#5YQWO'#GPO!(pQWO'#GSOOQO'#IR'#IRO#5_Q&jO,5<gOOQ!LS,5<g,5<gO#5fQ&jO'#F|O#5tQ&jO'#F}O#5|Q&jO'#F}OOQ!LS,5<u,5<uOJdQWO,5?YOJdQWO,5?YO#6RQWO'#ISO#6^QWO,5?XOOQ!LS'#Ch'#ChO#7QQ#tO,59jOOQ!LS,59j,59jO#7sQ#tO,5<UO#8fQ#tO,5<WO#8pQWO,5<YOOQ!LS,5<Z,5<ZO#8uQWO,5<aO#8zQ#tO,5<fOGTQYO1G1mO#9[QWO1G1mOOQQ1G3t1G3tOOQ!LS1G/p1G/pONXQWO1G/pOOQQ1G2b1G2bOITQWO1G2bO){QYO1G2bOITQWO1G2bO#9aQWO1G2bO#9oQWO,59]O#:xQWO'#EWOOQ!LQ,5?U,5?UO#;SQ!LYO,5?UOOQQ1G.s1G.sO:^QWO1G.sO!,rQpO1G.sO!,zQ#tO1G.sO#;bQWO1G0bO#;gQWO'#ChO#;rQWO'#JaO#;zQWO,5=dO#<PQWO'#JaO#<UQWO'#JaO#<^QWO'#I[O#<lQWO,5?zO#<tQbO1G1VOOQ!LS1G1X1G1XO5qQWO1G2}O#<{QWO1G2}O#=QQWO1G2}O#=VQWO1G2}OOQQ1G2}1G2}O#=[Q#tO1G2bO7VQWO'#JOO7VQWO'#EaO7VQWO'#IUO#=mQ!LYO,5?wOOQQ1G2f1G2fO!/yQWO1G2lOITQWO1G2iO#=xQWO1G2iOOQQ1G2j1G2jOITQWO1G2jO#=}QWO1G2jO#>VQ&jO'#GhOOQQ1G2l1G2lO!&wQ&jO'#IWO!0OQ`O1G2oOOQQ1G2o1G2oOOQQ,5=Y,5=YO#>_Q#tO,5=[O5qQWO,5=[O#5YQWO,5=_O5_QWO,5=_O!,rQpO,5=_O!,zQ#tO,5=_O5vQ#tO,5=_O#>pQWO'#J_O#>{QWO,5=`OOQQ1G.j1G.jO#?QQ!LYO1G.jO#?]QWO1G.jO#?bQWO1G.jO5iQ!LYO1G.jO#?jQbO,5?|O#?tQWO,5?|O#@PQYO,5=gO#@WQWO,5=gO7VQWO,5?|OOQQ1G3P1G3PO`QYO1G3POOQQ1G3V1G3VOOQQ1G3X1G3XO:XQWO1G3ZO#@]QYO1G3]O#DWQYO'#H[OOQQ1G3`1G3`O:^QWO1G3fO#DeQWO1G3fO5iQ!LYO1G3jOOQQ1G3l1G3lOOQ!LQ'#Fx'#FxO5iQ!LYO1G3nO5iQ!LYO1G3pOOOS1G/^1G/^O#DmQ`O,5<TO#DuQbO1G3yOOQO1G4O1G4OO){QYO,5>_O#EPQWO1G4zO#EXQWO1G5UO#EaQWO,5?bOLXQYO,5:{O7VQWO,5:{O:^QWO,59}OLXQYO,59}O!,rQpO,59}O#EfQ7^O,59}OOQO,5:{,5:{O#EpQ&jO'#HtO#FWQWO,5?aOOQ!LS1G/h1G/hO#F`Q&jO'#HyO#FtQWO,5?lOOQ!LQ1G0f1G0fO!;OQ&jO,59}O#F|QbO1G5VO7VQWO,5>dOOQ!LQ'#ES'#ESO#GWQ!LrO'#ETO!?{Q&jO'#D}OOQO'#Hw'#HwO#GrQ&jO,5:hOOQ!LS,5:h,5:hO#GyQ&jO'#D}O#H[Q&jO'#D}O#HcQ&jO'#EYO#HfQ&jO'#ETO#HsQ&jO'#ETO!?{Q&jO'#ETO#IWQWO1G0PO#I]Q`O1G0POOQ!LS1G0P1G0PO){QYO1G0POITQWO1G0POOQ!LS1G0a1G0aO:^QWO1G0aO!,rQpO1G0aO!,zQ#tO1G0aO#IdQ!LdO1G5SO){QYO1G5SO#ItQ!LYO1G5SO#JVQWO1G5RO7VQWO,5>fOOQO,5>f,5>fO#J_QWO,5>fOOQO-E;x-E;xO#JVQWO1G5RO#JmQ!LdO,59jO#LlQ!LdO,5<UO#NnQ!LdO,5<WO$!pQ!LdO,5<fOOQ!LS7+%|7+%|O$$xQ!LdO7+%|O$%iQWO'#HuO$%sQWO,5?cOOQ!LS1G/r1G/rO$%{QYO'#HvO$&YQWO,5?dO$&bQbO,5?dOOQ!LS1G/w1G/wOOQ!LS7+&V7+&VO$&lQ7^O,5:^O){QYO7+&iO$&vQ7^O,5:UOOQO1G1_1G1_OOQO1G1`1G1`O$'TQMhO,5;vOLXQYO,5;uOOQO-E;y-E;yOOQ!LS7+&w7+&wOOOO7+'Q7+'QOOOO1G1i1G1iO$'`QWO1G1iOOQ!LS1G1k1G1kO$'eQ`O,59gOOOS-E;o-E;oOOQ!LS1G/P1G/PO$'lQ!LdO7+'WOOQ!LS,5>k,5>kO$(]QWO,5>kOOQ!LS1G2P1G2PP$(bQWO'#IPPOQ!LS-E;}-E;}O$)RQ#tO1G2[O$)tQ#tO1G2^O$*OQ#tO1G2`OOQ!LS1G1x1G1xO$*VQWO'#IOO$*eQWO,5?sO$*eQWO,5?sO$*mQWO,5?sO$*xQWO,5?sOOQO1G1z1G1zO$+WQ#tO1G1yO$+hQWO'#IQO$+xQWO,5?tOITQWO,5?tO$,QQ`O,5?tOOQ!LS1G1}1G1}O5iQ!LYO,5<hO5iQ!LYO,5<iO$,[QWO,5<iO#5TQWO,5<iO!,rQpO,5<hO$,aQWO,5<jO5iQ!LYO,5<kO$,[QWO,5<nOOQO-E<P-E<POOQ!LS1G2R1G2RO!&wQ&jO,5<hO$,iQWO,5<iO!&wQ&jO,5<jO!&wQ&jO,5<iO$,tQ#tO1G4tO$-OQ#tO1G4tOOQO,5>n,5>nOOQO-E<Q-E<QO!-uQ&jO,59lO){QYO,59lO$-]QWO1G1tOJdQWO1G1{O$-bQ!LdO7+'XOOQ!LS7+'X7+'XOGTQYO7+'XOOQ!LS7+%[7+%[O$.RQ`O'#JZO#IWQWO7+'|O$.]QWO7+'|O$.eQ`O7+'|OOQQ7+'|7+'|OITQWO7+'|O){QYO7+'|OITQWO7+'|OOQO1G.w1G.wO$.oQ!LbO'#ChO$/PQ!LbO,5<lO$/nQWO,5<lOOQ!LQ1G4p1G4pOOQQ7+$_7+$_O:^QWO7+$_O!,rQpO7+$_OGTQYO7+%|O$/sQWO'#IZO$0UQWO,5?{OOQO1G3O1G3OO5qQWO,5?{O$0UQWO,5?{O$0^QWO,5?{OOQO,5>v,5>vOOQO-E<Y-E<YOOQ!LS7+&q7+&qO$0cQWO7+(iO5iQ!LYO7+(iO5qQWO7+(iO$0hQWO7+(iO$0mQWO7+'|OOQ!LQ,5>p,5>pOOQ!LQ-E<S-E<SOOQQ7+(W7+(WO$0{Q!LbO7+(TOITQWO7+(TO$1VQ`O7+(UOOQQ7+(U7+(UOITQWO7+(UO$1^QWO'#J^O$1iQWO,5=SOOQO,5>r,5>rOOQO-E<U-E<UOOQQ7+(Z7+(ZO$2cQ&jO'#GqOOQQ1G2v1G2vOITQWO1G2vO){QYO1G2vOITQWO1G2vO$2jQWO1G2vO$2xQ#tO1G2vO5iQ!LYO1G2yO#5YQWO1G2yO5_QWO1G2yO!,rQpO1G2yO!,zQ#tO1G2yO$3ZQWO'#IYO$3fQWO,5?yO$3nQ&jO,5?yOOQ!LQ1G2z1G2zOOQQ7+$U7+$UO$3vQWO7+$UO5iQ!LYO7+$UO$3{QWO7+$UO){QYO1G5hO){QYO1G5iO$4QQYO1G3RO$4XQWO1G3RO$4^QYO1G3RO$4eQ!LYO1G5hOOQQ7+(k7+(kO5iQ!LYO7+(uO`QYO7+(wOOQQ'#Jd'#JdOOQQ'#I]'#I]O$4oQYO,5=vOOQQ,5=v,5=vO){QYO'#H]O$4|QWO'#H_OOQQ7+)Q7+)QO$5RQYO7+)QO7VQWO7+)QOOQQ7+)U7+)UOOQQ7+)Y7+)YOOQQ7+)[7+)[OOQO1G4|1G4|O$9PQ7^O1G0gO$9ZQWO1G0gOOQO1G/i1G/iO$9fQ7^O1G/iO:^QWO1G/iOLXQYO'#DcOOQO,5>`,5>`OOQO-E;r-E;rOOQO,5>e,5>eOOQO-E;w-E;wO!,rQpO1G/iO:^QWO,5:iOOQO,5:o,5:oO){QYO,5:oO$9pQ!LYO,5:oO$9{Q!LYO,5:oO!,rQpO,5:iOOQO-E;u-E;uOOQ!LS1G0S1G0SO!?{Q&jO,5:iO$:ZQ&jO,5:iO$:lQ!LrO,5:oO$;WQ&jO,5:iO!?{Q&jO,5:oOOQO,5:t,5:tO$;_Q&jO,5:oO$;lQ!LYO,5:oOOQ!LS7+%k7+%kO#IWQWO7+%kO#I]Q`O7+%kOOQ!LS7+%{7+%{O:^QWO7+%{O!,rQpO7+%{O$<QQ!LdO7+*nO){QYO7+*nOOQO1G4Q1G4QO7VQWO1G4QO$<bQWO7+*mO$<jQ!LdO1G2[O$>lQ!LdO1G2^O$@nQ!LdO1G1yO$BvQ#tO,5>aOOQO-E;s-E;sO$CQQbO,5>bO){QYO,5>bOOQO-E;t-E;tO$C[QWO1G5OO$CdQ7^O1G0bO$EkQ7^O1G0mO$ErQ7^O1G0mO$GsQ7^O1G0mO$GzQ7^O1G0mO$IoQ7^O1G0mO$JSQ7^O1G0mO$LaQ7^O1G0mO$LhQ7^O1G0mO$NiQ7^O1G0mO$NpQ7^O1G0mO%!eQ7^O1G0mO%!xQ!LdO<<JTO%#iQ7^O1G0mO%%XQ7^O'#IoO%'UQ7^O1G1QOLXQYO'#F^OOQO'#JV'#JVOOQO1G1b1G1bO%'cQWO1G1aO%'hQ7^O,5>iOOOO7+'T7+'TOOOS1G/R1G/ROOQ!LS1G4V1G4VOJdQWO7+'zO%'rQWO,5>jO5qQWO,5>jOOQO-E;|-E;|O%(QQWO1G5_O%(QQWO1G5_O%(YQWO1G5_O%(eQ`O,5>lO%(oQWO,5>lOITQWO,5>lOOQO-E<O-E<OO%(tQ`O1G5`O%)OQWO1G5`OOQO1G2S1G2SOOQO1G2T1G2TO5iQ!LYO1G2TO$,[QWO1G2TO5iQ!LYO1G2SO%)WQWO1G2UOITQWO1G2UOOQO1G2V1G2VO5iQ!LYO1G2YO!,rQpO1G2SO#5TQWO1G2TO%)]QWO1G2UO%)eQWO1G2TOJdQWO7+*`OOQ!LS1G/W1G/WO%)pQWO1G/WOOQ!LS7+'`7+'`O%)uQ#tO7+'gO%*VQ!LdO<<JsOOQ!LS<<Js<<JsOITQWO'#ITO%*vQWO,5?uOOQQ<<Kh<<KhOITQWO<<KhO#IWQWO<<KhO%+OQWO<<KhO%+WQ`O<<KhOITQWO1G2WOOQQ<<Gy<<GyO:^QWO<<GyO%+bQ!LdO<<IhOOQ!LS<<Ih<<IhOOQO,5>u,5>uO%,RQWO,5>uO%,WQWO,5>uOOQO-E<X-E<XO%,`QWO1G5gO%,`QWO1G5gO5qQWO1G5gO%,hQWO<<LTOOQQ<<LT<<LTO%,mQWO<<LTO5iQ!LYO<<LTO){QYO<<KhOITQWO<<KhOOQQ<<Ko<<KoO$0{Q!LbO<<KoOOQQ<<Kp<<KpO$1VQ`O<<KpO%,rQ&jO'#IVO%,}QWO,5?xOLXQYO,5?xOOQQ1G2n1G2nO#GWQ!LrO'#ETO!?{Q&jO'#GrOOQO'#IX'#IXO%-VQ&jO,5=]OOQQ,5=],5=]O%-^Q&jO'#ETO%-iQ&jO'#ETO%.QQ&jO'#ETO%.[Q&jO'#GrO%.mQWO7+(bO%.rQWO7+(bO%.zQ`O7+(bOOQQ7+(b7+(bOITQWO7+(bO){QYO7+(bOITQWO7+(bO%/UQWO7+(bOOQQ7+(e7+(eO5iQ!LYO7+(eO#5YQWO7+(eO5_QWO7+(eO!,rQpO7+(eO%/dQWO,5>tOOQO-E<W-E<WOOQO'#Gu'#GuO%/oQWO1G5eO5iQ!LYO<<GpOOQQ<<Gp<<GpO%/wQWO<<GpO%/|QWO7++SO%0RQWO7++TOOQQ7+(m7+(mO%0WQWO7+(mO%0]QYO7+(mO%0dQWO7+(mO){QYO7++SO){QYO7++TOOQQ<<La<<LaOOQQ<<Lc<<LcOOQQ-E<Z-E<ZOOQQ1G3b1G3bO%0iQWO,5=wOOQQ,5=y,5=yO:^QWO<<LlO%0nQWO<<LlOLXQYO7+&ROOQO7+%T7+%TO%0sQ7^O1G5VO:^QWO7+%TOOQO1G0T1G0TO%0}Q!LdO1G0ZOOQO1G0Z1G0ZO){QYO1G0ZO%1XQ!LYO1G0ZO:^QWO1G0TO!,rQpO1G0TO!?{Q&jO1G0TO%1dQ!LYO1G0ZO%1rQ&jO1G0TO%2TQ!LYO1G0ZO%2iQ!LrO1G0ZO%2sQ&jO1G0TO!?{Q&jO1G0ZOOQ!LS<<IV<<IVOOQ!LS<<Ig<<IgO:^QWO<<IgO%2zQ!LdO<<NYOOQO7+)l7+)lO%3[Q!LdO7+'gO%5dQbO1G3|O%5nQ7^O7+%|O%5{Q7^O,59jO%7xQ7^O,5<UO%9uQ7^O,5<WO%;rQ7^O,5<fO%=bQ7^O7+'WO%=oQ7^O7+'XO%=|QWO,5;xOOQO7+&{7+&{O%>RQ#tO<<KfOOQO1G4U1G4UO%>cQWO1G4UO%>nQWO1G4UO%>|QWO7+*yO%>|QWO7+*yOITQWO1G4WO%?UQ`O1G4WO%?`QWO7+*zOOQO7+'o7+'oO5iQ!LYO7+'oOOQO7+'n7+'nO$,[QWO7+'pO%?hQ`O7+'pOOQO7+'t7+'tO5iQ!LYO7+'nO$,[QWO7+'oO%?oQWO7+'pOITQWO7+'pO#5TQWO7+'oO%?tQ#tO<<MzOOQ!LS7+$r7+$rO%@OQ`O,5>oOOQO-E<R-E<RO#IWQWOANASOOQQANASANASOITQWOANASO%@YQ!LbO7+'rOOQQAN=eAN=eO5qQWO1G4aOOQO1G4a1G4aO%@gQWO1G4aO%@lQWO7++RO%@lQWO7++RO5iQ!LYOANAoO%@tQWOANAoOOQQANAoANAoO%@yQWOANASO%ARQ`OANASOOQQANAZANAZOOQQANA[ANA[O%A]QWO,5>qOOQO-E<T-E<TO%AhQ7^O1G5dO#5YQWO,5=^O5_QWO,5=^O!,rQpO,5=^OOQO-E<V-E<VOOQQ1G2w1G2wO$:lQ!LrO,5:oO!?{Q&jO,5=^O%ArQ&jO,5=^O%BTQ&jO,5:oOOQQ<<K|<<K|OITQWO<<K|O%.mQWO<<K|O%B_QWO<<K|O%BgQ`O<<K|O){QYO<<K|OITQWO<<K|OOQQ<<LP<<LPO5iQ!LYO<<LPO#5YQWO<<LPO5_QWO<<LPO%BqQ&jO1G4`O%ByQWO7++POOQQAN=[AN=[O5iQ!LYOAN=[OOQQ<<Nn<<NnOOQQ<<No<<NoOOQQ<<LX<<LXO%CRQWO<<LXO%CWQYO<<LXO%C_QWO<<NnO%CdQWO<<NoOOQQ1G3c1G3cOOQQANBWANBWO:^QWOANBWO%CiQ7^O<<ImOOQO<<Ho<<HoOOQO7+%u7+%uO%0}Q!LdO7+%uO){QYO7+%uOOQO7+%o7+%oO:^QWO7+%oO!,rQpO7+%oO%CsQ!LYO7+%uO!?{Q&jO7+%oO%DOQ!LYO7+%uO%D^Q&jO7+%oO%DoQ!LYO7+%uOOQ!LSAN?RAN?RO%ETQ!LdO<<KfO%G]Q7^O<<JTO%GjQ7^O1G1yO%IYQ7^O1G2[O%KVQ7^O1G2^O%MSQ7^O<<JsO%MaQ7^O<<IhOOQO1G1d1G1dOOQO7+)p7+)pO%MnQWO7+)pO%MyQWO<<NeO%NRQ`O7+)rOOQO<<KZ<<KZO5iQ!LYO<<K[O$,[QWO<<K[OOQO<<KY<<KYO5iQ!LYO<<KZO%N]Q`O<<K[O$,[QWO<<KZOOQQG26nG26nO#IWQWOG26nOOQO7+){7+){O5qQWO7+){O%NdQWO<<NmOOQQG27ZG27ZO5iQ!LYOG27ZOITQWOG26nOLXQYO1G4]O%NlQWO7++OO5iQ!LYO1G2xO#5YQWO1G2xO5_QWO1G2xO!,rQpO1G2xO!?{Q&jO1G2xO%2iQ!LrO1G0ZO%NtQ&jO1G2xO%.mQWOANAhOOQQANAhANAhOITQWOANAhO& VQWOANAhO& _Q`OANAhOOQQANAkANAkO5iQ!LYOANAkO#5YQWOANAkOOQO'#Gv'#GvOOQO7+)z7+)zOOQQG22vG22vOOQQANAsANAsO& iQWOANAsOOQQANDYANDYOOQQANDZANDZO& nQYOG27rOOQO<<Ia<<IaO%0}Q!LdO<<IaOOQO<<IZ<<IZO:^QWO<<IZO){QYO<<IaO!,rQpO<<IZO&%lQ!LYO<<IaO!?{Q&jO<<IZO&%wQ!LYO<<IaO&&VQ7^O7+'gOOQO<<M[<<M[OOQOAN@vAN@vO5iQ!LYOAN@vOOQOAN@uAN@uO$,[QWOAN@vO5iQ!LYOAN@uOOQQLD,YLD,YOOQO<<Mg<<MgOOQQLD,uLD,uO#IWQWOLD,YO&'uQ7^O7+)wOOQO7+(d7+(dO5iQ!LYO7+(dO#5YQWO7+(dO5_QWO7+(dO!,rQpO7+(dO!?{Q&jO7+(dOOQQG27SG27SO%.mQWOG27SOITQWOG27SOOQQG27VG27VO5iQ!LYOG27VOOQQG27_G27_O:^QWOLD-^OOQOAN>{AN>{OOQOAN>uAN>uO%0}Q!LdOAN>{O:^QWOAN>uO){QYOAN>{O!,rQpOAN>uO&(PQ!LYOAN>{O&([Q7^O<<KfOOQOG26bG26bO5iQ!LYOG26bOOQOG26aG26aOOQQ!$( t!$( tOOQO<<LO<<LOO5iQ!LYO<<LOO#5YQWO<<LOO5_QWO<<LOO!,rQpO<<LOOOQQLD,nLD,nO%.mQWOLD,nOOQQLD,qLD,qOOQQ!$(!x!$(!xOOQOG24gG24gOOQOG24aG24aO%0}Q!LdOG24gO:^QWOG24aO){QYOG24gOOQOLD+|LD+|OOQOANAjANAjO5iQ!LYOANAjO#5YQWOANAjO5_QWOANAjOOQQ!$(!Y!$(!YOOQOLD*RLD*ROOQOLD){LD){O%0}Q!LdOLD*ROOQOG27UG27UO5iQ!LYOG27UO#5YQWOG27UOOQO!$'Mm!$'MmOOQOLD,pLD,pO5iQ!LYOLD,pOOQO!$(![!$(![OLXQYO'#DrO&)zQbO'#IrOLXQYO'#DjO&*RQ!LdO'#ChO&*lQbO'#ChO&*|QYO,5:vOLXQYO,5;ROLXQYO,5;ROLXQYO,5;ROLXQYO,5;ROLXQYO,5;ROLXQYO,5;ROLXQYO,5;ROLXQYO,5;ROLXQYO,5;ROLXQYO,5;ROLXQYO,5;ROLXQYO'#H}O&,|QWO,5<TO&.`QWO,5;ROLXQYO,5;fO!(aQWO'#DOO!(aQWO'#DOOITQWO'#FjO&-UQWO'#FjOITQWO'#FlO&-UQWO'#FlOITQWO'#FzO&-UQWO'#FzOLXQYO,5?kO&*|QYO1G0bO&.gQ7^O'#ChOLXQYO1G1lOITQWO,5<pO&-UQWO,5<pOITQWO,5<rO&-UQWO,5<rOITQWO,5<_O&-UQWO,5<_O&*|QYO1G1mOLXQYO7+&iOITQWO1G1{O&-UQWO1G1{O&*|QYO7+'XO&*|QYO7+%|OITQWO7+'zO&-UQWO7+'zO&.qQWO'#E[O&.vQWO'#E[O&/OQWO'#EzO&/TQWO'#EgO&/YQWO'#JPO&/eQWO'#I}O&/pQWO,5:vO&/uQ#tO,5<QO&/|QWO'#FsO&0RQWO'#FsO&0WQWO,5<RO&0`QWO,5:vO&0hQ7^O1G0}O&0oQWO,5<aO&0tQWO,5<aO&0yQWO1G1mO&1OQWO1G0bO&1TQ#tO1G2`O&1[Q#tO1G2`O4QQWO'#FhO5_QWO'#FgOBwQWO'#EZOLXQYO,5;cO!(pQWO'#FuO!(pQWO'#FuOJdQWO,5<tOJdQWO,5<t\",\n stateData: \"&2X~O'WOS'XOSTOSUOS~OPTOQTOXyO]cO_hObnOcmOhcOjTOkcOlcOqTOsTOxRO{cO|cO}cO!TSO!_kO!dUO!gTO!hTO!iTO!jTO!kTO!nlO#dsO#tpO#x^O%PqO%RtO%TrO%UrO%XuO%ZvO%^wO%_wO%axO%nzO%t{O%v|O%x}O%z!OO%}!PO&T!QO&X!RO&Z!SO&]!TO&_!UO&a!VO'ZPO'dQO'mYO'zaO~OP[XZ[X_[Xj[Xu[Xv[Xx[X!R[X!a[X!b[X!d[X!j[X!{[X#WdX#[[X#][X#^[X#_[X#`[X#a[X#b[X#c[X#e[X#g[X#i[X#j[X#o[X'U[X'd[X'n[X'u[X'v[X~O!]$lX~P$zOR!WO'S!XO'T!ZO~OPTOQTO]cOb!kOc!jOhcOjTOkcOlcOqTOsTOxRO{cO|cO}cO!T!bO!_kO!dUO!gTO!hTO!iTO!jTO!kTO!n!iO#t!lO#x^O'Z![O'dQO'mYO'zaO~O!Q!`O!R!]O!O'hP!O'rP~P'dO!S!mO~P`OPTOQTO]cOb!kOc!jOhcOjTOkcOlcOqTOsTOxRO{cO|cO}cO!T!bO!_kO!dUO!gTO!hTO!iTO!jTO!kTO!n!iO#t!lO#x^O'Z9YO'dQO'mYO'zaO~OPTOQTO]cOb!kOc!jOhcOjTOkcOlcOqTOsTOxRO{cO|cO}cO!T!bO!_kO!dUO!gTO!hTO!iTO!jTO!kTO!n!iO#t!lO#x^O'dQO'mYO'zaO~O!Q!rO#U!uO#V!rO'Z9ZO!c'oP~P+{O#W!vO~O!]!wO#W!vO~OP#^OZ#dOj#ROu!{Ov!{Ox!|O!R#bO!a#TO!b!yO!d!zO!j#^O#[#PO#]#QO#^#QO#_#QO#`#SO#a#TO#b#TO#c#TO#e#UO#g#WO#i#YO#j#ZO'dQO'n#[O'u!}O'v#OO~O_'fX'U'fX!c'fX!O'fX!T'fX%Q'fX!]'fX~P.jO!{#eO#o#eOP'gXZ'gX_'gXj'gXu'gXv'gXx'gX!R'gX!a'gX!b'gX!d'gX!j'gX#['gX#]'gX#^'gX#_'gX#`'gX#a'gX#b'gX#e'gX#g'gX#i'gX#j'gX'd'gX'n'gX'u'gX'v'gX~O#c'gX'U'gX!O'gX!c'gXn'gX!T'gX%Q'gX!]'gX~P0zO!{#eO~O#z#fO$R#jO~O!T#kO#x^O$U#lO$W#nO~O]#qOh$OOj#rOk#qOl#qOq$POs$QOx#xO!T#yO!_$VO!d#vO#V$WO#t$TO$_$RO$a$SO$d$UO'Z#pO'd#sO'_'aP~O!d$XO~O!]$ZO~O_$[O'U$[O~O'Z$`O~O!d$XO'Z$`O'[$bO'`$cO~Oc$iO!d$XO'Z$`O~O#c#TO~O]$rOu$nO!T$kO!d$mO%R$qO'Z$`O'[$bO^(SP~O!n$sO~Ox$tO!T$uO'Z$`O~Ox$tO!T$uO%Z$yO'Z$`O~O'Z$zO~O#dsO%RtO%TrO%UrO%XuO%ZvO%^wO%_wO~Ob%TOc%SO!n%QO%P%RO%c%PO~P7uOb%WOcmO!T%VO!nlO#dsO%PqO%TrO%UrO%XuO%ZvO%^wO%_wO%axO~O`%ZO!{%^O%R%XO'[$bO~P8tO!d%_O!g%cO~O!d%dO~O!TSO~O_$[O'R%lO'U$[O~O_$[O'R%oO'U$[O~O_$[O'R%qO'U$[O~OR!WO'S!XO'T%uO~OP[XZ[Xj[Xu[Xv[Xx[X!R[X!RdX!a[X!b[X!d[X!j[X!{[X!{dX#WdX#[[X#][X#^[X#_[X#`[X#a[X#b[X#c[X#e[X#g[X#i[X#j[X#o[X'd[X'n[X'u[X'v[X~O!O[X!OdX~P;aO!Q%wO!O&gX!O&lX!R&gX!R&lX~P'dO!R%yO!O'hX~OP#^OZ#dOj#ROu!{Ov!{Ox!|O!R%yO!a#TO!b!yO!d!zO!j#^O#[#PO#]#QO#^#QO#_#QO#`#SO#a#TO#b#TO#c#TO#e#UO#g#WO#i#YO#j#ZO'dQO'n#[O'u!}O'v#OO~O!O'hX~P>^O!O&OO~Ox&RO!W&]O!X&UO!Y&UO'[$bO~O]&SOk&SO!Q&VO'e&PO!S'iP!S'tP~P@aO!O'qX!R'qX!]'qX!c'qX'n'qX~O!{'qX#W#PX!S'qX~PAYO!{&^O!O'sX!R'sX~O!R&_O!O'rX~O!O&bO~O!{#eO~PAYOS&fO!T&cO!o&eO'Z$`O~Oc&kO!d$XO'Z$`O~Ou$nO!d$mO~O!S&lO~P`Ou!{Ov!{Ox!|O!b!yO!d!zO'dQOP!faZ!faj!fa!R!fa!a!fa!j!fa#[!fa#]!fa#^!fa#_!fa#`!fa#a!fa#b!fa#c!fa#e!fa#g!fa#i!fa#j!fa'n!fa'u!fa'v!fa~O_!fa'U!fa!O!fa!c!fan!fa!T!fa%Q!fa!]!fa~PCcO!c&mO~O!]!wO!{&oO'n&nO!R'pX_'pX'U'pX~O!c'pX~PE{O!R&sO!c'oX~O!c&uO~Ox$tO!T$uO#V&vO'Z$`O~OPTOQTO]cOb!kOc!jOhcOjTOkcOlcOqTOsTOxRO{cO|cO}cO!TSO!_kO!dUO!gTO!hTO!iTO!jTO!kTO!n!iO#t!lO#x^O'Z9YO'dQO'mYO'zaO~O]#qOh$OOj#rOk#qOl#qOq$POs9lOx#xO!T#yO!_:oO!d#vO#V9rO#t$TO$_9nO$a9pO$d$UO'Z&zO'd#sO~O#W&|O~O]#qOh$OOj#rOk#qOl#qOq$POs$QOx#xO!T#yO!_$VO!d#vO#V$WO#t$TO$_$RO$a$SO$d$UO'Z&zO'd#sO~O'_'kP~PJdO!Q'QO!c'lP~P){O'e'SO'mYO~OP9VOQ9VO]cOb:mOc!jOhcOj9VOkcOlcOq9VOs9VOxRO{cO|cO}cO!T!bO!_9XO!dUO!g9VO!h9VO!i9VO!j9VO!k9VO!n!iO#t!lO#x^O'Z'bO'dQO'mYO'z:kO~O!d!zO~O!R#bO_$]a'U$]a!c$]a!O$]a!T$]a%Q$]a!]$]a~O#d'iO~PITO!]'kO!T'wX#w'wX#z'wX$R'wX~Ou'lO~P! POu'lO!T'wX#w'wX#z'wX$R'wX~O!T'nO#w'rO#z'mO$R'sO~O!Q'vO~PLXO#z#fO$R'yO~Ou$eXx$eX!b$eX'n$eX'u$eX'v$eX~OSfX!RfX!{fX'_fX'_$eX~P!!iOk'{O~OR'|O'S'}O'T(PO~Ou(ROx(SO'n#[O'u(UO'v(WO~O'_(QO~P!#rO'_(ZO~O]#qOh$OOj#rOk#qOl#qOq$POs9lOx#xO!T#yO!_:oO!d#vO#V9rO#t$TO$_9nO$a9pO$d$UO'd#sO~O!Q(_O'Z([O!c'{P~P!$aO#W(aO~O!Q(eO'Z(bO!O'|P~P!$aO_(nOj(sOx(kO!W(qO!X(jO!Y(jO!d(hO!x(rO$w(mO'[$bO'e(gO~O!S(pO~P!&XO!b!yOu'cXx'cX'n'cX'u'cX'v'cX!R'cX!{'cX~O'_'cX#m'cX~P!'TOS(vO!{(uO!R'bX'_'bX~O!R(wO'_'aX~O'Z(yO~O!d)OO~O'Z&zO~O!d(hO~Ox$tO!Q!rO!T$uO#U!uO#V!rO'Z$`O!c'oP~O!]!wO#W)SO~OP#^OZ#dOj#ROu!{Ov!{Ox!|O!a#TO!b!yO!d!zO!j#^O#[#PO#]#QO#^#QO#_#QO#`#SO#a#TO#b#TO#c#TO#e#UO#g#WO#i#YO#j#ZO'dQO'n#[O'u!}O'v#OO~O_!^a!R!^a'U!^a!O!^a!c!^an!^a!T!^a%Q!^a!]!^a~P!)fOS)[O!T&cO!o)ZO%Q)YO'`$cO~O'Z$zO'_'aP~O!])_O!T'^X_'^X'U'^X~O!d$XO'`$cO~O!d$XO'Z$`O'`$cO~O!]!wO#W&|O~O])jO%R)kO'Z)gO!S(TP~O!R)lO^(SX~O'e'SO~OZ)pO~O^)qO~O!T$kO'Z$`O'[$bO^(SP~Ox$tO!Q)vO!R&_O!T$uO'Z$`O!O'rP~O]&YOk&YO!Q)wO'e'SO!S'tP~O!R)xO_(PX'U(PX~O!{)|O'`$cO~OS*PO!T#yO'`$cO~O!T*RO~Ou*TO!TSO~O!n*YO~Oc*_O~O'Z(yO!S(RP~Oc$iO~O%RtO'Z$zO~P8tOZ*eO^*dO~OPTOQTO]cObnOcmOhcOjTOkcOlcOqTOsTOxRO{cO|cO}cO!_kO!dUO!gTO!hTO!iTO!jTO!kTO!nlO#x^O%PqO'dQO'mYO'zaO~O!T!bO#t!lO'Z9YO~P!1RO^*dO_$[O'U$[O~O_*iO#d*kO%T*kO%U*kO~P){O!d%_O~O%t*pO~O!T*rO~O&U*uO&V*tOP&SaQ&SaX&Sa]&Sa_&Sab&Sac&Sah&Saj&Sak&Sal&Saq&Sas&Sax&Sa{&Sa|&Sa}&Sa!T&Sa!_&Sa!d&Sa!g&Sa!h&Sa!i&Sa!j&Sa!k&Sa!n&Sa#d&Sa#t&Sa#x&Sa%P&Sa%R&Sa%T&Sa%U&Sa%X&Sa%Z&Sa%^&Sa%_&Sa%a&Sa%n&Sa%t&Sa%v&Sa%x&Sa%z&Sa%}&Sa&T&Sa&X&Sa&Z&Sa&]&Sa&_&Sa&a&Sa'Q&Sa'Z&Sa'd&Sa'm&Sa'z&Sa!S&Sa%{&Sa`&Sa&Q&Sa~O'Z*xO~On*{O~O!O&ga!R&ga~P!)fO!Q+PO!O&gX!R&gX~P){O!R%yO!O'ha~O!O'ha~P>^O!R&_O!O'ra~O!RwX!R!ZX!SwX!S!ZX!]wX!]!ZX!d!ZX!{wX'`!ZX~O!]+UO!{+TO!R#TX!R'jX!S#TX!S'jX!]'jX!d'jX'`'jX~O!]+WO!d$XO'`$cO!R!VX!S!VX~O]&QOk&QOx&RO'e(gO~OP9VOQ9VO]cOb:mOc!jOhcOj9VOkcOlcOq9VOs9VOxRO{cO|cO}cO!T!bO!_9XO!dUO!g9VO!h9VO!i9VO!j9VO!k9VO!n!iO#t!lO#x^O'dQO'mYO'z:kO~O'Z9vO~P!;^O!R+[O!S'iX~O!S+^O~O!]+UO!{+TO!R#TX!S#TX~O!R+_O!S'tX~O!S+aO~O]&QOk&QOx&RO'[$bO'e(gO~O!X+bO!Y+bO~P!>[Ox$tO!Q+dO!T$uO'Z$`O!O&lX!R&lX~O_+hO!W+kO!X+gO!Y+gO!r+oO!s+mO!t+nO!u+lO!x+pO'[$bO'e(gO'm+eO~O!S+jO~P!?]OS+uO!T&cO!o+tO~O!{+{O!R'pa!c'pa_'pa'U'pa~O!]!wO~P!@gO!R&sO!c'oa~Ox$tO!Q,OO!T$uO#U,QO#V,OO'Z$`O!R&nX!c&nX~O_#Oi!R#Oi'U#Oi!O#Oi!c#Oin#Oi!T#Oi%Q#Oi!]#Oi~P!)fO#W!za!R!za!c!za!{!za!T!za_!za'U!za!O!za~P!#rO#W'cXP'cXZ'cX_'cXj'cXv'cX!a'cX!d'cX!j'cX#['cX#]'cX#^'cX#_'cX#`'cX#a'cX#b'cX#c'cX#e'cX#g'cX#i'cX#j'cX'U'cX'd'cX!c'cX!O'cX!T'cXn'cX%Q'cX!]'cX~P!'TO!R,ZO'_'kX~P!#rO'_,]O~O!R,^O!c'lX~P!)fO!c,aO~O!O,bO~OP#^Ou!{Ov!{Ox!|O!b!yO!d!zO!j#^O'dQOZ#Zi_#Zij#Zi!R#Zi!a#Zi#]#Zi#^#Zi#_#Zi#`#Zi#a#Zi#b#Zi#c#Zi#e#Zi#g#Zi#i#Zi#j#Zi'U#Zi'n#Zi'u#Zi'v#Zi!O#Zi!c#Zin#Zi!T#Zi%Q#Zi!]#Zi~O#[#Zi~P!EtO#[#PO~P!EtOP#^Ou!{Ov!{Ox!|O!b!yO!d!zO!j#^O#[#PO#]#QO#^#QO#_#QO'dQOZ#Zi_#Zi!R#Zi!a#Zi#`#Zi#a#Zi#b#Zi#c#Zi#e#Zi#g#Zi#i#Zi#j#Zi'U#Zi'n#Zi'u#Zi'v#Zi!O#Zi!c#Zin#Zi!T#Zi%Q#Zi!]#Zi~Oj#Zi~P!H`Oj#RO~P!H`OP#^Oj#ROu!{Ov!{Ox!|O!b!yO!d!zO!j#^O#[#PO#]#QO#^#QO#_#QO#`#SO'dQO_#Zi!R#Zi#e#Zi#g#Zi#i#Zi#j#Zi'U#Zi'n#Zi'u#Zi'v#Zi!O#Zi!c#Zin#Zi!T#Zi%Q#Zi!]#Zi~OZ#Zi!a#Zi#a#Zi#b#Zi#c#Zi~P!JzOZ#dO!a#TO#a#TO#b#TO#c#TO~P!JzOP#^OZ#dOj#ROu!{Ov!{Ox!|O!a#TO!b!yO!d!zO!j#^O#[#PO#]#QO#^#QO#_#QO#`#SO#a#TO#b#TO#c#TO#e#UO'dQO_#Zi!R#Zi#g#Zi#i#Zi#j#Zi'U#Zi'n#Zi'v#Zi!O#Zi!c#Zin#Zi!T#Zi%Q#Zi!]#Zi~O'u#Zi~P!MrO'u!}O~P!MrOP#^OZ#dOj#ROu!{Ov!{Ox!|O!a#TO!b!yO!d!zO!j#^O#[#PO#]#QO#^#QO#_#QO#`#SO#a#TO#b#TO#c#TO#e#UO#g#WO'dQO'u!}O_#Zi!R#Zi#i#Zi#j#Zi'U#Zi'n#Zi!O#Zi!c#Zin#Zi!T#Zi%Q#Zi!]#Zi~O'v#Zi~P#!^O'v#OO~P#!^OP#^OZ#dOj#ROu!{Ov!{Ox!|O!a#TO!b!yO!d!zO!j#^O#[#PO#]#QO#^#QO#_#QO#`#SO#a#TO#b#TO#c#TO#e#UO#g#WO#i#YO'dQO'u!}O'v#OO~O_#Zi!R#Zi#j#Zi'U#Zi'n#Zi!O#Zi!c#Zin#Zi!T#Zi%Q#Zi!]#Zi~P#$xOP[XZ[Xj[Xu[Xv[Xx[X!a[X!b[X!d[X!j[X!{[X#WdX#[[X#][X#^[X#_[X#`[X#a[X#b[X#c[X#e[X#g[X#i[X#j[X#o[X'd[X'n[X'u[X'v[X!R[X!S[X~O#m[X~P#']OP#^OZ9jOj9_Ou!{Ov!{Ox!|O!a9aO!b!yO!d!zO!j#^O#[9]O#]9^O#^9^O#_9^O#`9`O#a9aO#b9aO#c9aO#e9bO#g9dO#i9fO#j9gO'dQO'n#[O'u!}O'v#OO~O#m,dO~P#)gOP'gXZ'gXj'gXu'gXv'gXx'gX!a'gX!b'gX!d'gX!j'gX#['gX#]'gX#^'gX#_'gX#`'gX#a'gX#b'gX#e'gX#g'gX#i'gX#j'gX'd'gX'n'gX'u'gX'v'gX!R'gX~O!{9kO#o9kO#c'gX#m'gX!S'gX~P#+bO_&qa!R&qa'U&qa!c&qan&qa!O&qa!T&qa%Q&qa!]&qa~P!)fOP#ZiZ#Zi_#Zij#Ziv#Zi!R#Zi!a#Zi!b#Zi!d#Zi!j#Zi#[#Zi#]#Zi#^#Zi#_#Zi#`#Zi#a#Zi#b#Zi#c#Zi#e#Zi#g#Zi#i#Zi#j#Zi'U#Zi'd#Zi!O#Zi!c#Zin#Zi!T#Zi%Q#Zi!]#Zi~P!#rO_#ni!R#ni'U#ni!O#ni!c#nin#ni!T#ni%Q#ni!]#ni~P!)fO#z,fO~O#z,gO~O!]'kO!{,hO!T$OX#w$OX#z$OX$R$OX~O!Q,iO~O!T'nO#w,kO#z'mO$R,lO~O!R9hO!S'fX~P#)gO!S,mO~O$R,oO~OR'|O'S'}O'T,rO~O],uOk,uO!O,vO~O!RdX!]dX!cdX!c$eX'ndX~P!!iO!c,|O~P!#rO!R,}O!]!wO'n&nO!c'{X~O!c-SO~O!O$eX!R$eX!]$lX~P!!iO!R-UO!O'|X~P!#rO!]-WO~O!O-YO~O!Q(_O'Z$`O!c'{P~Oj-^O!]!wO!d$XO'`$cO'n&nO~O!])_O~O!S-dO~P!&XO!X-eO!Y-eO'[$bO'e(gO~Ox-gO'e(gO~O!x-hO~O'Z$zO!R&vX'_&vX~O!R(wO'_'aa~Ou-mOv-mOx-nO'nra'ura'vra!Rra!{ra~O'_ra#mra~P#6fOu(ROx(SO'n$^a'u$^a'v$^a!R$^a!{$^a~O'_$^a#m$^a~P#7[Ou(ROx(SO'n$`a'u$`a'v$`a!R$`a!{$`a~O'_$`a#m$`a~P#7}O]-oO~O#W-pO~O'_$na!R$na#m$na!{$na~P!#rO#W-sO~OS-|O!T&cO!o-{O%Q-zO~O'_-}O~O]#qOj#rOk#qOl#qOq$POs9lOx#xO!T#yO!_:oO!d#vO#V9rO#t$TO$_9nO$a9pO$d$UO'd#sO~Oh.PO'Z.OO~P#9tO!])_O!T'^a_'^a'U'^a~O#W.VO~OZ[X!RdX!SdX~O!R.WO!S(TX~O!S.YO~OZ.ZO~O].]O'Z)gO~O!T$kO'Z$`O^'OX!R'OX~O!R)lO^(Sa~O!c.`O~P!)fO].bO~OZ.cO~O^.dO~OS-|O!T&cO!o-{O%Q-zO'`$cO~O!R)xO_(Pa'U(Pa~O!{.jO~OS.mO!T#yO~O'e'SO!S(QP~OS.wO!T.sO!o.vO%Q.uO'`$cO~OZ/RO!R/PO!S(RX~O!S/SO~O^/UO_$[O'U$[O~O]/VO~O]/WO'Z(yO~O#c/XO%r/YO~P0zO!{#eO#c/XO%r/YO~O_/ZO~P){O_/]O~O%{/aOP%yiQ%yiX%yi]%yi_%yib%yic%yih%yij%yik%yil%yiq%yis%yix%yi{%yi|%yi}%yi!T%yi!_%yi!d%yi!g%yi!h%yi!i%yi!j%yi!k%yi!n%yi#d%yi#t%yi#x%yi%P%yi%R%yi%T%yi%U%yi%X%yi%Z%yi%^%yi%_%yi%a%yi%n%yi%t%yi%v%yi%x%yi%z%yi%}%yi&T%yi&X%yi&Z%yi&]%yi&_%yi&a%yi'Q%yi'Z%yi'd%yi'm%yi'z%yi!S%yi`%yi&Q%yi~O`/gO!S/eO&Q/fO~P`O!TSO!d/jO~O!R#bOn$]a~O!O&gi!R&gi~P!)fO!R%yO!O'hi~O!R&_O!O'ri~O!O/nO~O!R!Va!S!Va~P#)gO]&QOk&QO!Q/tO'e(gO!R&hX!S&hX~P@aO!R+[O!S'ia~O]&YOk&YO!Q)wO'e'SO!R&mX!S&mX~O!R+_O!S'ta~O!O'si!R'si~P!)fO_$[O!]!wO!d$XO!j0OO!{/|O'U$[O'`$cO'n&nO~O!S0RO~P!?]O!X0SO!Y0SO'[$bO'e(gO'm+eO~O!W0TO~P#GyO!TSO!W0TO!u0VO!x0WO~P#GyO!W0TO!s0YO!t0YO!u0VO!x0WO~P#GyO!T&cO~O!T&cO~P!#rO!R'pi!c'pi_'pi'U'pi~P!)fO!{0cO!R'pi!c'pi_'pi'U'pi~O!R&sO!c'oi~Ox$tO!T$uO#V0eO'Z$`O~O#WraPraZra_rajra!ara!bra!dra!jra#[ra#]ra#^ra#_ra#`ra#ara#bra#cra#era#gra#ira#jra'Ura'dra!cra!Ora!Tranra%Qra!]ra~P#6fO#W$^aP$^aZ$^a_$^aj$^av$^a!a$^a!b$^a!d$^a!j$^a#[$^a#]$^a#^$^a#_$^a#`$^a#a$^a#b$^a#c$^a#e$^a#g$^a#i$^a#j$^a'U$^a'd$^a!c$^a!O$^a!T$^an$^a%Q$^a!]$^a~P#7[O#W$`aP$`aZ$`a_$`aj$`av$`a!a$`a!b$`a!d$`a!j$`a#[$`a#]$`a#^$`a#_$`a#`$`a#a$`a#b$`a#c$`a#e$`a#g$`a#i$`a#j$`a'U$`a'd$`a!c$`a!O$`a!T$`an$`a%Q$`a!]$`a~P#7}O#W$naP$naZ$na_$naj$nav$na!R$na!a$na!b$na!d$na!j$na#[$na#]$na#^$na#_$na#`$na#a$na#b$na#c$na#e$na#g$na#i$na#j$na'U$na'd$na!c$na!O$na!T$na!{$nan$na%Q$na!]$na~P!#rO_#Oq!R#Oq'U#Oq!O#Oq!c#Oqn#Oq!T#Oq%Q#Oq!]#Oq~P!)fO!R&iX'_&iX~PJdO!R,ZO'_'ka~O!Q0mO!R&jX!c&jX~P){O!R,^O!c'la~O!R,^O!c'la~P!)fO#m!fa!S!fa~PCcO#m!^a!R!^a!S!^a~P#)gO!T1QO#x^O$P1RO~O!S1VO~On1WO~P!#rO_$Yq!R$Yq'U$Yq!O$Yq!c$Yqn$Yq!T$Yq%Q$Yq!]$Yq~P!)fO!O1XO~O],uOk,uO~Ou(ROx(SO'v(WO'n$xi'u$xi!R$xi!{$xi~O'_$xi#m$xi~P$(jOu(ROx(SO'n$zi'u$zi'v$zi!R$zi!{$zi~O'_$zi#m$zi~P$)]O#m1YO~P!#rO!Q1[O'Z$`O!R&rX!c&rX~O!R,}O!c'{a~O!R,}O!]!wO!c'{a~O!R,}O!]!wO'n&nO!c'{a~O'_$gi!R$gi#m$gi!{$gi~P!#rO!Q1cO'Z(bO!O&tX!R&tX~P!$aO!R-UO!O'|a~O!R-UO!O'|a~P!#rO!]!wO~O!]!wO#c1mO~Oj1qO!]!wO'n&nO~O!R'bi'_'bi~P!#rO!{1tO!R'bi'_'bi~P!#rO!c1wO~O_$Zq!R$Zq'U$Zq!O$Zq!c$Zqn$Zq!T$Zq%Q$Zq!]$Zq~P!)fO!R1{O!T'}X~P!#rO!T&cO%Q2OO~O!T&cO%Q2OO~P!#rO!T$eX$u[X_$eX'U$eX~P!!iO$u2SOugXxgX!TgX'ngX'ugX'vgX_gX'UgX~O$u2SO~O]2YO%R2ZO'Z)gO!R&}X!S&}X~O!R.WO!S(Ta~OZ2_O~O^2`O~O]2cO~OS2eO!T&cO!o2dO%Q2OO~O_$[O'U$[O~P!#rO!T#yO~P!#rO!R2jO!{2lO!S(QX~O!S2mO~Ox(kO!W2vO!X2oO!Y2oO!r2uO!s2tO!t2tO!x2sO'[$bO'e(gO'm+eO~O!S2rO~P$1nOS2}O!T.sO!o2|O%Q2{O~OS2}O!T.sO!o2|O%Q2{O'`$cO~O'Z(yO!R&|X!S&|X~O!R/PO!S(Ra~O]3XO'e3WO~O]3YO~O^3[O~O!c3_O~P){O_3aO~O_3aO~P){O#c3cO%r3dO~PE{O`/gO!S3hO&Q/fO~P`O!]3jO~O&V3kOP&SqQ&SqX&Sq]&Sq_&Sqb&Sqc&Sqh&Sqj&Sqk&Sql&Sqq&Sqs&Sqx&Sq{&Sq|&Sq}&Sq!T&Sq!_&Sq!d&Sq!g&Sq!h&Sq!i&Sq!j&Sq!k&Sq!n&Sq#d&Sq#t&Sq#x&Sq%P&Sq%R&Sq%T&Sq%U&Sq%X&Sq%Z&Sq%^&Sq%_&Sq%a&Sq%n&Sq%t&Sq%v&Sq%x&Sq%z&Sq%}&Sq&T&Sq&X&Sq&Z&Sq&]&Sq&_&Sq&a&Sq'Q&Sq'Z&Sq'd&Sq'm&Sq'z&Sq!S&Sq%{&Sq`&Sq&Q&Sq~O!R#Ti!S#Ti~P#)gO!{3mO!R#Ti!S#Ti~O!R!Vi!S!Vi~P#)gO_$[O!{3tO'U$[O~O_$[O!]!wO!{3tO'U$[O~O!X3xO!Y3xO'[$bO'e(gO'm+eO~O_$[O!]!wO!d$XO!j3yO!{3tO'U$[O'`$cO'n&nO~O!W3zO~P$:ZO!W3zO!u3}O!x4OO~P$:ZO_$[O!]!wO!j3yO!{3tO'U$[O'n&nO~O!R'pq!c'pq_'pq'U'pq~P!)fO!R&sO!c'oq~O#W$xiP$xiZ$xi_$xij$xiv$xi!a$xi!b$xi!d$xi!j$xi#[$xi#]$xi#^$xi#_$xi#`$xi#a$xi#b$xi#c$xi#e$xi#g$xi#i$xi#j$xi'U$xi'd$xi!c$xi!O$xi!T$xin$xi%Q$xi!]$xi~P$(jO#W$ziP$ziZ$zi_$zij$ziv$zi!a$zi!b$zi!d$zi!j$zi#[$zi#]$zi#^$zi#_$zi#`$zi#a$zi#b$zi#c$zi#e$zi#g$zi#i$zi#j$zi'U$zi'd$zi!c$zi!O$zi!T$zin$zi%Q$zi!]$zi~P$)]O#W$giP$giZ$gi_$gij$giv$gi!R$gi!a$gi!b$gi!d$gi!j$gi#[$gi#]$gi#^$gi#_$gi#`$gi#a$gi#b$gi#c$gi#e$gi#g$gi#i$gi#j$gi'U$gi'd$gi!c$gi!O$gi!T$gi!{$gin$gi%Q$gi!]$gi~P!#rO!R&ia'_&ia~P!#rO!R&ja!c&ja~P!)fO!R,^O!c'li~O#m#Oi!R#Oi!S#Oi~P#)gOP#^Ou!{Ov!{Ox!|O!b!yO!d!zO!j#^O'dQOZ#Zij#Zi!a#Zi#]#Zi#^#Zi#_#Zi#`#Zi#a#Zi#b#Zi#c#Zi#e#Zi#g#Zi#i#Zi#j#Zi#m#Zi'n#Zi'u#Zi'v#Zi!R#Zi!S#Zi~O#[#Zi~P$CqO#[9]O~P$CqOP#^Ou!{Ov!{Ox!|O!b!yO!d!zO!j#^O#[9]O#]9^O#^9^O#_9^O'dQOZ#Zi!a#Zi#`#Zi#a#Zi#b#Zi#c#Zi#e#Zi#g#Zi#i#Zi#j#Zi#m#Zi'n#Zi'u#Zi'v#Zi!R#Zi!S#Zi~Oj#Zi~P$EyOj9_O~P$EyOP#^Oj9_Ou!{Ov!{Ox!|O!b!yO!d!zO!j#^O#[9]O#]9^O#^9^O#_9^O#`9`O'dQO#e#Zi#g#Zi#i#Zi#j#Zi#m#Zi'n#Zi'u#Zi'v#Zi!R#Zi!S#Zi~OZ#Zi!a#Zi#a#Zi#b#Zi#c#Zi~P$HROZ9jO!a9aO#a9aO#b9aO#c9aO~P$HROP#^OZ9jOj9_Ou!{Ov!{Ox!|O!a9aO!b!yO!d!zO!j#^O#[9]O#]9^O#^9^O#_9^O#`9`O#a9aO#b9aO#c9aO#e9bO'dQO#g#Zi#i#Zi#j#Zi#m#Zi'n#Zi'v#Zi!R#Zi!S#Zi~O'u#Zi~P$JgO'u!}O~P$JgOP#^OZ9jOj9_Ou!{Ov!{Ox!|O!a9aO!b!yO!d!zO!j#^O#[9]O#]9^O#^9^O#_9^O#`9`O#a9aO#b9aO#c9aO#e9bO#g9dO'dQO'u!}O#i#Zi#j#Zi#m#Zi'n#Zi!R#Zi!S#Zi~O'v#Zi~P$LoO'v#OO~P$LoOP#^OZ9jOj9_Ou!{Ov!{Ox!|O!a9aO!b!yO!d!zO!j#^O#[9]O#]9^O#^9^O#_9^O#`9`O#a9aO#b9aO#c9aO#e9bO#g9dO#i9fO'dQO'u!}O'v#OO~O#j#Zi#m#Zi'n#Zi!R#Zi!S#Zi~P$NwO_#ky!R#ky'U#ky!O#ky!c#kyn#ky!T#ky%Q#ky!]#ky~P!)fOP#ZiZ#Zij#Ziv#Zi!a#Zi!b#Zi!d#Zi!j#Zi#[#Zi#]#Zi#^#Zi#_#Zi#`#Zi#a#Zi#b#Zi#c#Zi#e#Zi#g#Zi#i#Zi#j#Zi#m#Zi'd#Zi!R#Zi!S#Zi~P!#rO!b!yOP'cXZ'cXj'cXu'cXv'cXx'cX!a'cX!d'cX!j'cX#['cX#]'cX#^'cX#_'cX#`'cX#a'cX#b'cX#c'cX#e'cX#g'cX#i'cX#j'cX#m'cX'd'cX'n'cX'u'cX'v'cX!R'cX!S'cX~O#m#ni!R#ni!S#ni~P#)gO!S4`O~O!R&qa!S&qa~P#)gO!]!wO'n&nO!R&ra!c&ra~O!R,}O!c'{i~O!R,}O!]!wO!c'{i~O!O&ta!R&ta~P!#rO!]4gO~O!R-UO!O'|i~P!#rO!R-UO!O'|i~O!O4mO~O!]!wO#c4sO~Oj4tO!]!wO'n&nO~O!O4vO~O'_$iq!R$iq#m$iq!{$iq~P!#rO_$Zy!R$Zy'U$Zy!O$Zy!c$Zyn$Zy!T$Zy%Q$Zy!]$Zy~P!)fO!R1{O!T'}a~O!T&cO%Q4{O~O!T&cO%Q4{O~P!#rO_#Oy!R#Oy'U#Oy!O#Oy!c#Oyn#Oy!T#Oy%Q#Oy!]#Oy~P!)fOZ5OO~O]5QO'Z)gO~O!R.WO!S(Ti~O]5TO~O^5UO~O'e'SO!R&yX!S&yX~O!R2jO!S(Qa~O!S5cO~P$1nOx-gO'e(gO'm+eO~O!W5fO!X5eO!Y5eO!x0WO'[$bO'e(gO'm+eO~O!s5gO!t5gO~P%-iO!X5eO!Y5eO'[$bO'e(gO'm+eO~O!T.sO~O!T.sO%Q5iO~O!T.sO%Q5iO~P!#rOS5nO!T.sO!o5mO%Q5iO~OZ5sO!R&|a!S&|a~O!R/PO!S(Ri~O]5vO~O!c5wO~O!c5xO~O!c5yO~O!c5yO~P){O_5{O~O!]6OO~O!c6QO~O!R'si!S'si~P#)gO_$[O'U$[O~P!)fO_$[O!{6VO'U$[O~O_$[O!]!wO!{6VO'U$[O~O!X6[O!Y6[O'[$bO'e(gO'm+eO~O_$[O!]!wO!j6]O!{6VO'U$[O'n&nO~O!d$XO'`$cO~P%2TO!W6^O~P%1rO!R'py!c'py_'py'U'py~P!)fO#W$iqP$iqZ$iq_$iqj$iqv$iq!R$iq!a$iq!b$iq!d$iq!j$iq#[$iq#]$iq#^$iq#_$iq#`$iq#a$iq#b$iq#c$iq#e$iq#g$iq#i$iq#j$iq'U$iq'd$iq!c$iq!O$iq!T$iq!{$iqn$iq%Q$iq!]$iq~P!#rO!R&ji!c&ji~P!)fO#m#Oq!R#Oq!S#Oq~P#)gOu-mOv-mOx-nOPraZrajra!ara!bra!dra!jra#[ra#]ra#^ra#_ra#`ra#ara#bra#cra#era#gra#ira#jra#mra'dra'nra'ura'vra!Rra!Sra~Ou(ROx(SOP$^aZ$^aj$^av$^a!a$^a!b$^a!d$^a!j$^a#[$^a#]$^a#^$^a#_$^a#`$^a#a$^a#b$^a#c$^a#e$^a#g$^a#i$^a#j$^a#m$^a'd$^a'n$^a'u$^a'v$^a!R$^a!S$^a~Ou(ROx(SOP$`aZ$`aj$`av$`a!a$`a!b$`a!d$`a!j$`a#[$`a#]$`a#^$`a#_$`a#`$`a#a$`a#b$`a#c$`a#e$`a#g$`a#i$`a#j$`a#m$`a'd$`a'n$`a'u$`a'v$`a!R$`a!S$`a~OP$naZ$naj$nav$na!a$na!b$na!d$na!j$na#[$na#]$na#^$na#_$na#`$na#a$na#b$na#c$na#e$na#g$na#i$na#j$na#m$na'd$na!R$na!S$na~P!#rO#m$Yq!R$Yq!S$Yq~P#)gO#m$Zq!R$Zq!S$Zq~P#)gO!S6hO~O'_$|y!R$|y#m$|y!{$|y~P!#rO!]!wO!R&ri!c&ri~O!]!wO'n&nO!R&ri!c&ri~O!R,}O!c'{q~O!O&ti!R&ti~P!#rO!R-UO!O'|q~O!O6oO~P!#rO!O6oO~O!R'by'_'by~P!#rO!R&wa!T&wa~P!#rO!T$tq_$tq'U$tq~P!#rOZ6wO~O!R.WO!S(Tq~O]6zO~O!T&cO%Q6{O~O!T&cO%Q6{O~P!#rO!{6|O!R&ya!S&ya~O!R2jO!S(Qi~P#)gO!X7SO!Y7SO'[$bO'e(gO'm+eO~O!W7UO!x4OO~P%ArO!T.sO%Q7XO~O!T.sO%Q7XO~P!#rO]7`O'e7_O~O!R/PO!S(Rq~O!c7bO~O!c7bO~P){O!c7dO~O!c7eO~O!R#Ty!S#Ty~P#)gO_$[O!{7kO'U$[O~O_$[O!]!wO!{7kO'U$[O~O!X7nO!Y7nO'[$bO'e(gO'm+eO~O_$[O!]!wO!j7oO!{7kO'U$[O'n&nO~O#W$|yP$|yZ$|y_$|yj$|yv$|y!R$|y!a$|y!b$|y!d$|y!j$|y#[$|y#]$|y#^$|y#_$|y#`$|y#a$|y#b$|y#c$|y#e$|y#g$|y#i$|y#j$|y'U$|y'd$|y!c$|y!O$|y!T$|y!{$|yn$|y%Q$|y!]$|y~P!#rO#m#ky!R#ky!S#ky~P#)gOP$giZ$gij$giv$gi!a$gi!b$gi!d$gi!j$gi#[$gi#]$gi#^$gi#_$gi#`$gi#a$gi#b$gi#c$gi#e$gi#g$gi#i$gi#j$gi#m$gi'd$gi!R$gi!S$gi~P!#rOu(ROx(SO'v(WOP$xiZ$xij$xiv$xi!a$xi!b$xi!d$xi!j$xi#[$xi#]$xi#^$xi#_$xi#`$xi#a$xi#b$xi#c$xi#e$xi#g$xi#i$xi#j$xi#m$xi'd$xi'n$xi'u$xi!R$xi!S$xi~Ou(ROx(SOP$ziZ$zij$ziv$zi!a$zi!b$zi!d$zi!j$zi#[$zi#]$zi#^$zi#_$zi#`$zi#a$zi#b$zi#c$zi#e$zi#g$zi#i$zi#j$zi#m$zi'd$zi'n$zi'u$zi'v$zi!R$zi!S$zi~O#m$Zy!R$Zy!S$Zy~P#)gO#m#Oy!R#Oy!S#Oy~P#)gO!]!wO!R&rq!c&rq~O!R,}O!c'{y~O!O&tq!R&tq~P!#rO!O7uO~P!#rO!R.WO!S(Ty~O!R2jO!S(Qq~O!X8RO!Y8RO'[$bO'e(gO'm+eO~O!T.sO%Q8UO~O!T.sO%Q8UO~P!#rO!c8XO~O&V8YOP&S!ZQ&S!ZX&S!Z]&S!Z_&S!Zb&S!Zc&S!Zh&S!Zj&S!Zk&S!Zl&S!Zq&S!Zs&S!Zx&S!Z{&S!Z|&S!Z}&S!Z!T&S!Z!_&S!Z!d&S!Z!g&S!Z!h&S!Z!i&S!Z!j&S!Z!k&S!Z!n&S!Z#d&S!Z#t&S!Z#x&S!Z%P&S!Z%R&S!Z%T&S!Z%U&S!Z%X&S!Z%Z&S!Z%^&S!Z%_&S!Z%a&S!Z%n&S!Z%t&S!Z%v&S!Z%x&S!Z%z&S!Z%}&S!Z&T&S!Z&X&S!Z&Z&S!Z&]&S!Z&_&S!Z&a&S!Z'Q&S!Z'Z&S!Z'd&S!Z'm&S!Z'z&S!Z!S&S!Z%{&S!Z`&S!Z&Q&S!Z~O_$[O!{8_O'U$[O~O_$[O!]!wO!{8_O'U$[O~OP$iqZ$iqj$iqv$iq!a$iq!b$iq!d$iq!j$iq#[$iq#]$iq#^$iq#_$iq#`$iq#a$iq#b$iq#c$iq#e$iq#g$iq#i$iq#j$iq#m$iq'd$iq!R$iq!S$iq~P!#rO!R&yq!S&yq~P#)gO_$[O!{8tO'U$[O~OP$|yZ$|yj$|yv$|y!a$|y!b$|y!d$|y!j$|y#[$|y#]$|y#^$|y#_$|y#`$|y#a$|y#b$|y#c$|y#e$|y#g$|y#i$|y#j$|y#m$|y'd$|y!R$|y!S$|y~P!#rOn'fX~P.jOn[X!O[X!c[X%r[X!T[X%Q[X!][X~P$zO!]dX!c[X!cdX'ndX~P;aOP9VOQ9VO]cOb:mOc!jOhcOj9VOkcOlcOq9VOs9VOxRO{cO|cO}cO!TSO!_9XO!dUO!g9VO!h9VO!i9VO!j9VO!k9VO!n!iO#t!lO#x^O'Z'bO'dQO'mYO'z:kO~O!R9hO!S$]a~O]#qOh$OOj#rOk#qOl#qOq$POs9mOx#xO!T#yO!_:pO!d#vO#V9sO#t$TO$_9oO$a9qO$d$UO'Z&zO'd#sO~O#d'iO~P&-UO!S[X!SdX~P;aO#W9[O~O!]!wO#W9[O~O!{9kO~O#c9aO~O!{9tO!R'sX!S'sX~O!{9kO!R'qX!S'qX~O#W9uO~O'_9wO~P!#rO#W9|O~O#W9}O~O!]!wO#W:OO~O!]!wO#W9uO~O#m:PO~P#)gO#W:QO~O#W:RO~O#W:SO~O#W:TO~O#m:UO~P!#rO#m:VO~P!#rO#x~!b!r!t!u#U#V'z$_$a$d$u%P%Q%R%X%Z%^%_%a%c~UT#x'z#]}'W'X#z'W'Z'e~\",\n goto: \"#Ed(XPPPPPPPP(YP(jP*^PPPP-uPP.[3n5b5uP5uPPP5uP7c5uP5uP7gPP7lP8Q<cPPPP<gPPPP<g?XPPP?_AjP<gPDTPPPPE{<gPPPPPGt<gPPJuKrPPPPKvM`PMhNiPKr<g<g!#p!&k!+^!+^!.mPPP!.t!1j<gPPPPPPPPPP!4aP!5rPP<g!7PP<gP<g<g<g<gP<g!9dPP!<]P!?Q!?Y!?^!?^P!<YP!?b!?bP!BVP!BZ<g<g!Ba!ET5uP5uP5u5uP!FW5u5u!HO5u!JQ5u!Kr5u5u!L`!NY!NY!N^!NY!NfP!NYP5u# b5u#!l5u5u-uPPP##yPP#$c#$cP#$cP#$x#$cPP#%OP#$uP#$u#%bMd#$u#&P#&V#&Y(Y#&](YP#&d#&d#&dP(YP(YP(YP(YPP(YP#&j#&mP#&m(YPPP(YP(YP(YP(YP(YP(Y(Y#&q#&{#'R#'X#'g#'m#'s#'}#(T#(d#(j#(x#)O#)U#)d#)y#+]#+k#+q#+w#+}#,T#,_#,e#,k#,u#-X#-_PPPPPPPP#-ePP#.X#2VPP#3m#3t#3|PP#8Y#:m#@i#@l#@o#@z#@}PP#AQ#AU#As#Bj#Bn#CSPP#CW#C^#CbP#Ce#Ci#Cl#D[#Dr#Dw#Dz#D}#ET#EW#E[#E`mhOSj}!n$Z%b%e%f%h*m*r/a/dQ$hmQ$opQ%YyS&U!b+[Q&j!jS(j#y(oQ)e$iQ)r$qQ*^%SQ+b&]S+g&c+iQ+y&kQ-e(qQ/O*_Y0S+k+l+m+n+oS2o.s2qU3x0T0V0YU5e2t2u2vS6[3z3}S7S5f5gQ7n6^R8R7U$p[ORSTUjk}!S!W!]!`!n!v!z!|#P#Q#R#S#T#U#V#W#X#Y#Z#b#e$Z$m%Z%^%b%d%e%f%h%l%w%y&R&^&e&o&|'Q(Q)S)Z*i*m*r+P+t+{,^,d-n-s-{.V.v/X/Y/Z/]/a/d/f/|0c0m2d2|3a3c3d3t5m5{6V7k8_8t!j'd#]#k&V'v+T+W,i/t1Q2l3m6|9V9X9[9]9^9_9`9a9b9c9d9e9f9g9h9k9t9u9w:O:P:S:T:nQ(z$QQ)j$kQ*`%VQ*g%_Q,T9lQ.Q)_Q.])kQ/W*eQ2Y.WQ3U/PQ4X9mR5Q2ZpeOSjy}!n$Z%X%b%e%f%h*m*r/a/dR*b%Z&WVOSTjkn}!S!W!k!n!v!z!|#P#Q#R#S#T#U#V#W#X#Y#Z#]#b#e#k$Z$m%Z%^%_%b%d%e%f%h%l%y&R&^&e&o&|'Q'v(Q)S)Z*i*m*r+P+T+W+t+{,^,d,i-n-s-{.V.v/X/Y/Z/]/a/d/f/t/|0c0m1Q2d2l2|3a3c3d3m3t5m5{6V6|7k8_8t9V9X9[9]9^9_9`9a9b9c9d9e9f9g9h9k9t9u9w:O:P:S:T:m:n[!cRU!]!`%w&VQ$alQ$gmS$lp$qv$vrs!r!u$X$t&_&s&v)v)w)x*k+U+d,O,Q/j0eQ%OwQ&g!iQ&i!jS(^#v(hS)d$h$iQ)h$kQ)u$sQ*X%QQ*]%SS+x&j&kQ-R(_Q.U)eQ.[)kQ.^)lQ.a)pQ.y*YS.}*^*_Q0a+yQ1Z,}Q2X.WQ2].ZQ2b.cQ3T/OQ4d1[Q5P2ZQ5S2_Q6v5OR7x6w!Y$em!j$g$h$i&T&i&j&k(i)d)e+X+f+x+y-_.U/y0P0U0a1p3w3|6Y7l8`Q)]$aQ)}${Q*Q$|Q*[%SQ.e)uQ.x*XU.|*]*^*_Q3O.yS3S.}/OQ5`2nQ5r3TS7Q5a5dS8P7R7TQ8j8QR8y8kW#|a$c(w:kS${t%XQ$|uQ$}vR){$y$V#{a!w!y#d#v#x$R$S$W&f'|(V(X(Y(a(e(u(v)Y)[)_)|*P+u,Z-U-W-p-z-|.j.m.u.w1Y1c1m1t1{2O2S2e2{2}4g4s4{5i5n6{7X8U9j9n9o9p9q9r9s9x9y9z9{9|9}:Q:R:U:V:k:q:rT'}#s(OV({$Q9l9mU&Y!b$u+_Q'T!{Q)o$nQ.n*RQ1u-mR5[2j&^cORSTUjk}!S!W!]!`!n!v!z!|#P#Q#R#S#T#U#V#W#X#Y#Z#]#b#e#k$Z$m%Z%^%_%b%d%e%f%h%l%w%y&R&V&^&e&o&|'Q'v(Q)S)Z*i*m*r+P+T+W+t+{,^,d,i-n-s-{.V.v/X/Y/Z/]/a/d/f/t/|0c0m1Q2d2l2|3a3c3d3m3t5m5{6V6|7k8_8t9V9X9[9]9^9_9`9a9b9c9d9e9f9g9h9k9t9u9w:O:P:S:T:n$]#aZ!_!o$_%v%|&x'P'V'W'X'Y'Z'[']'^'_'`'a'c'f'j't)n*}+Y+c+z,Y,`,c,e,s-q/o/r0b0l0p0q0r0s0t0u0v0w0x0y0z0{0|1P1U1y2V3o3r4S4V4W4]4^5^6R6U6b6f6g7h7{8]8r8}9W:dT!XQ!Y&_cORSTUjk}!S!W!]!`!n!v!z!|#P#Q#R#S#T#U#V#W#X#Y#Z#]#b#e#k$Z$m%Z%^%_%b%d%e%f%h%l%w%y&R&V&^&e&o&|'Q'v(Q)S)Z*i*m*r+P+T+W+t+{,^,d,i-n-s-{.V.v/X/Y/Z/]/a/d/f/t/|0c0m1Q2d2l2|3a3c3d3m3t5m5{6V6|7k8_8t9V9X9[9]9^9_9`9a9b9c9d9e9f9g9h9k9t9u9w:O:P:S:T:nQ&W!bR/u+[Y&Q!b&U&]+[+bS(i#y(oS+f&c+iS-_(j(qQ-`(kQ-f(rQ.p*TU0P+g+k+lU0U+m+n+oS0Z+p2sQ1p-eQ1r-gQ1s-hS2n.s2qU3w0S0T0VQ3{0WQ3|0YS5a2o2vS5d2t2uU6Y3x3z3}Q6_4OS7R5e5fQ7T5gS7l6[6^S8Q7S7UQ8`7nR8k8RlhOSj}!n$Z%b%e%f%h*m*r/a/dQ%j!QS&w!v9[Q)b$fQ*V%OQ*W%PQ+v&hS,X&|9uS-r)S:OQ.S)cQ.r*UQ/h*tQ/i*uQ/q+VQ0X+mQ0_+wS1z-s:SQ2T.TS2W.V:TQ3n/sQ3q/zQ4Q0`Q4}2UQ6P3kQ6S3pQ6W3vQ6`4RQ7f6QQ7i6XQ8[7jQ8o8YQ8q8^R8|8s$W#`Z!_!o%v%|&x'P'V'W'X'Y'Z'[']'^'_'`'a'c'f'j't)n*}+Y+c+z,Y,`,c,s-q/o/r0b0l0p0q0r0s0t0u0v0w0x0y0z0{0|1P1U1y2V3o3r4S4V4W4]4^5^6R6U6b6f6g7h7{8]8r8}9W:dU(t#z&{1OT)W$_,e$W#_Z!_!o%v%|&x'P'V'W'X'Y'Z'[']'^'_'`'a'c'f'j't)n*}+Y+c+z,Y,`,c,s-q/o/r0b0l0p0q0r0s0t0u0v0w0x0y0z0{0|1P1U1y2V3o3r4S4V4W4]4^5^6R6U6b6f6g7h7{8]8r8}9W:dQ'e#`S)V$_,eR-t)W&^cORSTUjk}!S!W!]!`!n!v!z!|#P#Q#R#S#T#U#V#W#X#Y#Z#]#b#e#k$Z$m%Z%^%_%b%d%e%f%h%l%w%y&R&V&^&e&o&|'Q'v(Q)S)Z*i*m*r+P+T+W+t+{,^,d,i-n-s-{.V.v/X/Y/Z/]/a/d/f/t/|0c0m1Q2d2l2|3a3c3d3m3t5m5{6V6|7k8_8t9V9X9[9]9^9_9`9a9b9c9d9e9f9g9h9k9t9u9w:O:P:S:T:nQ%e{Q%f|Q%h!OQ%i!PR/`*pQ&d!iQ)X$aQ+s&gS-y)])uS0[+q+rW1}-v-w-x.eS4P0]0^U4z2P2Q2RU6t4y5W5XQ7w6uR8f7zT+h&c+iS+f&c+iU0P+g+k+lU0U+m+n+oS0Z+p2sS2n.s2qU3w0S0T0VQ3{0WQ3|0YS5a2o2vS5d2t2uU6Y3x3z3}Q6_4OS7R5e5fQ7T5gS7l6[6^S8Q7S7UQ8`7nR8k8RS+h&c+iT2p.s2qS&q!q/^Q-Q(^Q-](iS0O+f2nQ1`-RS1j-^-fU3y0U0Z5dQ4c1ZS4q1q1sU6]3{3|7TQ6j4dQ6s4tR7o6_Q!xXS&p!q/^Q)T$YQ)`$dQ)f$jQ+|&qQ-P(^Q-[(iQ-a(lQ.R)aQ.z*ZS/}+f2nS1_-Q-RS1i-]-fQ1l-`Q1o-bQ3Q.{W3u0O0U0Z5dQ4b1ZQ4f1`S4k1j1sQ4r1rQ5p3RW6Z3y3{3|7TS6i4c4dQ6n4mQ6q4qQ7O5_Q7]5qS7m6]6_Q7q6jQ7s6oQ7v6sQ7}7PQ8W7^Q8a7oQ8d7uQ8h8OQ8w8iQ9P8xQ9T9QQ:^:XQ:g:bR:h:c$rWORSTUjk}!S!W!]!`!n!v!z!|#P#Q#R#S#T#U#V#W#X#Y#Z#b#e$Z$m%Z%^%_%b%d%e%f%h%l%w%y&R&^&e&o&|'Q(Q)S)Z*i*m*r+P+t+{,^,d-n-s-{.V.v/X/Y/Z/]/a/d/f/|0c0m2d2|3a3c3d3t5m5{6V7k8_8tS!xn!k!j:W#]#k&V'v+T+W,i/t1Q2l3m6|9V9X9[9]9^9_9`9a9b9c9d9e9f9g9h9k9t9u9w:O:P:S:T:nR:^:m$rXORSTUjk}!S!W!]!`!n!v!z!|#P#Q#R#S#T#U#V#W#X#Y#Z#b#e$Z$m%Z%^%_%b%d%e%f%h%l%w%y&R&^&e&o&|'Q(Q)S)Z*i*m*r+P+t+{,^,d-n-s-{.V.v/X/Y/Z/]/a/d/f/|0c0m2d2|3a3c3d3t5m5{6V7k8_8tQ$Yb!Y$dm!j$g$h$i&T&i&j&k(i)d)e+X+f+x+y-_.U/y0P0U0a1p3w3|6Y7l8`S$jn!kQ)a$eQ*Z%SW.{*[*]*^*_U3R.|.}/OQ5_2nS5q3S3TU7P5`5a5dQ7^5rU8O7Q7R7TS8i8P8QS8x8j8kQ9Q8y!j:X#]#k&V'v+T+W,i/t1Q2l3m6|9V9X9[9]9^9_9`9a9b9c9d9e9f9g9h9k9t9u9w:O:P:S:T:nQ:b:lR:c:m$f]OSTjk}!S!W!n!v!z!|#P#Q#R#S#T#U#V#W#X#Y#Z#b#e$Z$m%Z%^%b%d%e%f%h%l%y&R&^&e&o&|'Q(Q)S)Z*i*m*r+P+t+{,^,d-n-s-{.V.v/X/Y/Z/]/a/d/f/|0c0m2d2|3a3c3d3t5m5{6V7k8_8tY!hRU!]!`%wv$vrs!r!u$X$t&_&s&v)v)w)x*k+U+d,O,Q/j0eQ*h%_!h:Y#]#k'v+T+W,i/t1Q2l3m6|9V9X9[9]9^9_9`9a9b9c9d9e9f9g9h9k9t9u9w:O:P:S:T:nR:]&VS&Z!b$uR/w+_$p[ORSTUjk}!S!W!]!`!n!v!z!|#P#Q#R#S#T#U#V#W#X#Y#Z#b#e$Z$m%Z%^%b%d%e%f%h%l%w%y&R&^&e&o&|'Q(Q)S)Z*i*m*r+P+t+{,^,d-n-s-{.V.v/X/Y/Z/]/a/d/f/|0c0m2d2|3a3c3d3t5m5{6V7k8_8t!j'd#]#k&V'v+T+W,i/t1Q2l3m6|9V9X9[9]9^9_9`9a9b9c9d9e9f9g9h9k9t9u9w:O:P:S:T:nR*g%_$roORSTUjk}!S!W!]!`!n!v!z!|#P#Q#R#S#T#U#V#W#X#Y#Z#b#e$Z$m%Z%^%_%b%d%e%f%h%l%w%y&R&^&e&o&|'Q(Q)S)Z*i*m*r+P+t+{,^,d-n-s-{.V.v/X/Y/Z/]/a/d/f/|0c0m2d2|3a3c3d3t5m5{6V7k8_8tQ'T!{!k:Z#]#k&V'v+T+W,i/t1Q2l3m6|9V9X9[9]9^9_9`9a9b9c9d9e9f9g9h9k9t9u9w:O:P:S:T:n!h#VZ!_$_%v%|&x'P'^'_'`'a'f'j)n*}+c+z,Y,`,s-q0b0l0|1y2V3r4S4V6U7h8]8r8}9W!R9c'c't+Y,e/o/r0p0x0y0z0{1P1U3o4W4]4^5^6R6b6f6g7{:d!d#XZ!_$_%v%|&x'P'`'a'f'j)n*}+c+z,Y,`,s-q0b0l0|1y2V3r4S4V6U7h8]8r8}9W}9e'c't+Y,e/o/r0p0z0{1P1U3o4W4]4^5^6R6b6f6g7{:d!`#]Z!_$_%v%|&x'P'f'j)n*}+c+z,Y,`,s-q0b0l0|1y2V3r4S4V6U7h8]8r8}9Wl(Y#t&})R,{-T-i-j0j1x4a4u:_:i:jx:n'c't+Y,e/o/r0p1P1U3o4W4]4^5^6R6b6f6g7{:d!`:q&y'h(](c+r,W,p-X-u-x.i.k0^0i1a1e2R2g2i2y4U4h4n4w4|5X5l6a6l6r7ZZ:r0}4[6c7p8b&^cORSTUjk}!S!W!]!`!n!v!z!|#P#Q#R#S#T#U#V#W#X#Y#Z#]#b#e#k$Z$m%Z%^%_%b%d%e%f%h%l%w%y&R&V&^&e&o&|'Q'v(Q)S)Z*i*m*r+P+T+W+t+{,^,d,i-n-s-{.V.v/X/Y/Z/]/a/d/f/t/|0c0m1Q2d2l2|3a3c3d3m3t5m5{6V6|7k8_8t9V9X9[9]9^9_9`9a9b9c9d9e9f9g9h9k9t9u9w:O:P:S:T:nS#l`#mR1R,h&e_ORSTU`jk}!S!W!]!`!n!v!z!|#P#Q#R#S#T#U#V#W#X#Y#Z#]#b#e#k#m$Z$m%Z%^%_%b%d%e%f%h%l%w%y&R&V&^&e&o&|'Q'v(Q)S)Z*i*m*r+P+T+W+t+{,^,d,h,i-n-s-{.V.v/X/Y/Z/]/a/d/f/t/|0c0m1Q2d2l2|3a3c3d3m3t5m5{6V6|7k8_8t9V9X9[9]9^9_9`9a9b9c9d9e9f9g9h9k9t9u9w:O:P:S:T:nS#g^#nT'm#i'qT#h^#nT'o#i'q&e`ORSTU`jk}!S!W!]!`!n!v!z!|#P#Q#R#S#T#U#V#W#X#Y#Z#]#b#e#k#m$Z$m%Z%^%_%b%d%e%f%h%l%w%y&R&V&^&e&o&|'Q'v(Q)S)Z*i*m*r+P+T+W+t+{,^,d,h,i-n-s-{.V.v/X/Y/Z/]/a/d/f/t/|0c0m1Q2d2l2|3a3c3d3m3t5m5{6V6|7k8_8t9V9X9[9]9^9_9`9a9b9c9d9e9f9g9h9k9t9u9w:O:P:S:T:nT#l`#mQ#o`R'x#m$rbORSTUjk}!S!W!]!`!n!v!z!|#P#Q#R#S#T#U#V#W#X#Y#Z#b#e$Z$m%Z%^%_%b%d%e%f%h%l%w%y&R&^&e&o&|'Q(Q)S)Z*i*m*r+P+t+{,^,d-n-s-{.V.v/X/Y/Z/]/a/d/f/|0c0m2d2|3a3c3d3t5m5{6V7k8_8t!k:l#]#k&V'v+T+W,i/t1Q2l3m6|9V9X9[9]9^9_9`9a9b9c9d9e9f9g9h9k9t9u9w:O:P:S:T:n#RdOSUj}!S!W!n!|#k$Z%Z%^%_%b%d%e%f%h%l&R&e'v)Z*i*m*r+t,i-n-{.v/X/Y/Z/]/a/d/f1Q2d2|3a3c3d5m5{t#za!y$R$S$W(V(X(Y(a(u(v,Z-p1Y1t:k:q:r!|&{!w#d#v#x&f'|(e)Y)[)_)|*P+u-U-W-z-|.j.m.u.w1c1m1{2O2S2e2{2}4g4s4{5i5n6{7X8U9n9p9r9x9z9|:Q:UQ)P$UQ,t(Rc1O9j9o9q9s9y9{9}:R:Vt#wa!y$R$S$W(V(X(Y(a(u(v,Z-p1Y1t:k:q:rS(l#y(oQ)Q$VQ-b(m!|:`!w#d#v#x&f'|(e)Y)[)_)|*P+u-U-W-z-|.j.m.u.w1c1m1{2O2S2e2{2}4g4s4{5i5n6{7X8U9n9p9r9x9z9|:Q:Ub:a9j9o9q9s9y9{9}:R:VQ:e:oR:f:pt#za!y$R$S$W(V(X(Y(a(u(v,Z-p1Y1t:k:q:r!|&{!w#d#v#x&f'|(e)Y)[)_)|*P+u-U-W-z-|.j.m.u.w1c1m1{2O2S2e2{2}4g4s4{5i5n6{7X8U9n9p9r9x9z9|:Q:Uc1O9j9o9q9s9y9{9}:R:VlfOSj}!n$Z%b%e%f%h*m*r/a/dQ(d#xQ*y%oQ*z%qR1b-U$U#{a!w!y#d#v#x$R$S$W&f'|(V(X(Y(a(e(u(v)Y)[)_)|*P+u,Z-U-W-p-z-|.j.m.u.w1Y1c1m1t1{2O2S2e2{2}4g4s4{5i5n6{7X8U9j9n9o9p9q9r9s9x9y9z9{9|9}:Q:R:U:V:k:q:rQ*O$|Q.l*QQ2h.kR5Z2iT(n#y(oS(n#y(oT2p.s2qQ)`$dQ-a(lQ.R)aQ.z*ZQ3Q.{Q5p3RQ7O5_Q7]5qQ7}7PQ8W7^Q8h8OQ8w8iQ9P8xR9T9Ql(V#t&})R,{-T-i-j0j1x4a4u:_:i:j!`9x&y'h(](c+r,W,p-X-u-x.i.k0^0i1a1e2R2g2i2y4U4h4n4w4|5X5l6a6l6r7ZZ9y0}4[6c7p8bn(X#t&})R,y,{-T-i-j0j1x4a4u:_:i:j!b9z&y'h(](c+r,W,p-X-u-x.i.k0^0g0i1a1e2R2g2i2y4U4h4n4w4|5X5l6a6l6r7Z]9{0}4[6c6d7p8bpeOSjy}!n$Z%X%b%e%f%h*m*r/a/dQ%UxR*i%_peOSjy}!n$Z%X%b%e%f%h*m*r/a/dR%UxQ*S$}R.h){qeOSjy}!n$Z%X%b%e%f%h*m*r/a/dQ.t*XS2z.x.yW5h2w2x2y3OU7W5j5k5lU8S7V7Y7ZQ8l8TR8z8mQ%]yR*c%XR3X/RR7`5sS$lp$qR.^)lQ%bzR*m%cR*s%iT/b*r/dQjOQ!nST$^j!nQ(O#sR,q(OQ!YQR%t!YQ!^RU%z!^%{+QQ%{!_R+Q%|Q+]&WR/v+]Q,[&}R0k,[Q,_'PS0n,_0oR0o,`Q+i&cR0Q+iS!eR$tU&`!e&a+RQ&a!fR+R%}Q+`&ZR/x+`Q&t!sQ+}&rU,R&t+}0fR0f,SQ'q#iR,j'qQ#m`R'w#mQ#cZU'g#c*|9iQ*|9WR9i'tQ-O(^W1]-O1^4e6kU1^-P-Q-RS4e1_1`R6k4f#q(T#t&y&}'h(](c(|(})R+r,U,V,W,p,y,z,{-T-X-i-j-u-x.i.k0^0g0h0i0j0}1a1e1x2R2g2i2y4U4Y4Z4[4a4h4n4u4w4|5X5l6a6c6d6e6l6r7Z7p8b:_:i:jQ-V(cU1d-V1f4iQ1f-XR4i1eQ(o#yR-c(oQ(x#}R-l(xQ1|-uR4x1|Q)y$wR.g)yQ2k.nS5]2k6}R6}5^Q*U%OR.q*UQ2q.sR5b2qQ/Q*`S3V/Q5tR5t3XQ.X)hW2[.X2^5R6xQ2^.[Q5R2]R6x5SQ)m$lR._)mQ/d*rR3g/dWiOSj!nQ%g}Q)U$ZQ*l%bQ*n%eQ*o%fQ*q%hQ/_*mS/b*r/dR3f/aQ$]gQ%k!RQ%n!TQ%p!UQ%r!VQ)t$rQ)z$xQ*b%]Q*w%mS/T*c*fQ/k*vQ/l*yQ/m*zS/{+f2nQ1g-ZQ1h-[Q1n-aQ2a.bQ2f.iQ3P.zQ3Z/VQ3e/`Y3s/}0O0U0Z5dQ4j1iQ4l1kQ4o1oQ5V2cQ5Y2gQ5o3QQ5u3Y[6T3r3u3y3{3|7TQ6m4kQ6p4pQ6y5TQ7[5pQ7a5vW7g6U6Z6]6_Q7r6nQ7t6qQ7y6zQ7|7OQ8V7]U8Z7h7m7oQ8c7sQ8e7vQ8g7}Q8n8WS8p8]8aQ8u8dQ8v8hQ8{8rQ9O8wQ9R8}Q9S9PR9U9TQ$fmQ&h!jU)c$g$h$iQ+V&TU+w&i&j&kQ-Z(iS.T)d)eQ/s+XQ/z+fS0`+x+yQ1k-_Q2U.UQ3p/yS3v0P0UQ4R0aQ4p1pS6X3w3|Q7j6YQ8^7lR8s8`S#ua:kR)^$cU#}a$c:kR-k(wQ#taS&y!w)_Q&}!yQ'h#dQ(]#vQ(c#xQ(|$RQ(}$SQ)R$WQ+r&fQ,U9nQ,V9pQ,W9rQ,p'|Q,y(VQ,z(XQ,{(YQ-T(aQ-X(eQ-i(uQ-j(vd-u)Y-z.u2O2{4{5i6{7X8UQ-x)[Q.i)|Q.k*PQ0^+uQ0g9xQ0h9zQ0i9|Q0j,ZQ0}9jQ1a-UQ1e-WQ1x-pQ2R-|Q2g.jQ2i.mQ2y.wQ4U:QQ4Y9oQ4Z9qQ4[9sQ4a1YQ4h1cQ4n1mQ4u1tQ4w1{Q4|2SQ5X2eQ5l2}Q6a:UQ6c9}Q6d9yQ6e9{Q6l4gQ6r4sQ7Z5nQ7p:RQ8b:VQ:_:kQ:i:qR:j:rlgOSj}!n$Z%b%e%f%h*m*r/a/dS!pU%dQ%m!SQ%s!WQ'U!|Q'u#kS*f%Z%^Q*j%_Q*v%lQ+S&RQ+q&eQ,n'vQ-w)ZQ/[*iQ0]+tQ1T,iQ1v-nQ2Q-{Q2x.vQ3]/XQ3^/YQ3`/ZQ3b/]Q3i/fQ4_1QQ5W2dQ5k2|Q5z3aQ5|3cQ5}3dQ7Y5mR7c5{!vZOSUj}!S!n!|$Z%Z%^%_%b%d%e%f%h%l&R&e)Z*i*m*r+t-n-{.v/X/Y/Z/]/a/d/f2d2|3a3c3d5m5{Q!_RQ!oTQ$_kS%v!]%yQ%|!`Q&x!vQ'P!zQ'V#PQ'W#QQ'X#RQ'Y#SQ'Z#TQ'[#UQ']#VQ'^#WQ'_#XQ'`#YQ'a#ZQ'c#]Q'f#bQ'j#eW't#k'v,i1QQ)n$mS*}%w+PS+Y&V/tQ+c&^Q+z&oQ,Y&|Q,`'QQ,c9VQ,e9XQ,s(QQ-q)SQ/o+TQ/r+WQ0b+{Q0l,^Q0p9[Q0q9]Q0r9^Q0s9_Q0t9`Q0u9aQ0v9bQ0w9cQ0x9dQ0y9eQ0z9fQ0{9gQ0|,dQ1P9kQ1U9hQ1y-sQ2V.VQ3o9tQ3r/|Q4S0cQ4V0mQ4W9uQ4]9wQ4^:OQ5^2lQ6R3mQ6U3tQ6b:PQ6f:SQ6g:TQ7h6VQ7{6|Q8]7kQ8r8_Q8}8tQ9W!WR:d:nR!aRR&X!bS&T!b+[S+X&U&]R/y+bR'O!yR'R!zT!tU$XS!sU$XU$wrs*kS&r!r!uQ,P&sQ,S&vQ.f)xS0d,O,QR4T0e`!dR!]!`$t%w&_)v+dh!qUrs!r!u$X&s&v)x,O,Q0eQ/^*kQ/p+UQ3l/jT:[&V)wT!gR$tS!fR$tS%x!]&_S%}!`)vS+O%w+dT+Z&V)wT&[!b$uQ#i^R'z#nT'p#i'qR1S,hT(`#v(hR(f#xQ-v)YQ2P-zQ2w.uQ4y2OQ5j2{Q6u4{Q7V5iQ7z6{Q8T7XR8m8UlhOSj}!n$Z%b%e%f%h*m*r/a/dQ%[yR*b%XV$xrs*kR.o*RR*a%VQ$ppR)s$qR)i$kT%`z%cT%az%cT/c*r/d\",\n nodeNames: \"\u26a0 ArithOp ArithOp InterpolationStart extends LineComment BlockComment Script ExportDeclaration export Star as VariableName String from ; default FunctionDeclaration async function VariableDefinition TypeParamList TypeDefinition ThisType this LiteralType ArithOp Number BooleanLiteral TemplateType InterpolationEnd Interpolation VoidType void TypeofType typeof MemberExpression . ?. PropertyName [ TemplateString Interpolation null super RegExp ] ArrayExpression Spread , } { ObjectExpression Property async get set PropertyDefinition Block : NewExpression new TypeArgList CompareOp < ) ( ArgList UnaryExpression await yield delete LogicOp BitOp ParenthesizedExpression ClassExpression class extends ClassBody MethodDeclaration Privacy static abstract override PrivatePropertyDefinition PropertyDeclaration readonly Optional TypeAnnotation Equals StaticBlock FunctionExpression ArrowFunction ParamList ParamList ArrayPattern ObjectPattern PatternProperty Privacy readonly Arrow MemberExpression PrivatePropertyName BinaryExpression ArithOp ArithOp ArithOp ArithOp BitOp CompareOp instanceof in const CompareOp BitOp BitOp BitOp LogicOp LogicOp ConditionalExpression LogicOp LogicOp AssignmentExpression UpdateOp PostfixExpression CallExpression TaggedTemplateExpression DynamicImport import ImportMeta JSXElement JSXSelfCloseEndTag JSXStartTag JSXSelfClosingTag JSXIdentifier JSXNamespacedName JSXMemberExpression JSXSpreadAttribute JSXAttribute JSXAttributeValue JSXEscape JSXEndTag JSXOpenTag JSXFragmentTag JSXText JSXEscape JSXStartCloseTag JSXCloseTag PrefixCast ArrowFunction TypeParamList SequenceExpression KeyofType keyof UniqueType unique ImportType InferredType infer TypeName ParenthesizedType FunctionSignature ParamList NewSignature IndexedType TupleType Label ArrayType ReadonlyType ObjectType MethodType PropertyType IndexSignature CallSignature TypePredicate is NewSignature new UnionType LogicOp IntersectionType LogicOp ConditionalType ParameterizedType ClassDeclaration abstract implements type VariableDeclaration let var TypeAliasDeclaration InterfaceDeclaration interface EnumDeclaration enum EnumBody NamespaceDeclaration namespace module AmbientDeclaration declare GlobalDeclaration global ClassDeclaration ClassBody MethodDeclaration AmbientFunctionDeclaration ExportGroup VariableName VariableName ImportDeclaration ImportGroup ForStatement for ForSpec ForInSpec ForOfSpec of WhileStatement while WithStatement with DoStatement do IfStatement if else SwitchStatement switch SwitchBody CaseLabel case DefaultLabel TryStatement try catch finally ReturnStatement return ThrowStatement throw BreakStatement break ContinueStatement continue DebuggerStatement debugger LabeledStatement ExpressionStatement\",\n maxTerm: 330,\n context: trackNewline,\n nodeProps: [\n [\n _common.NodeProp.closedBy,\n 3,\n \"InterpolationEnd\",\n 40,\n \"]\",\n 51,\n \"}\",\n 66,\n \")\",\n 132,\n \"JSXSelfCloseEndTag JSXEndTag\",\n 146,\n \"JSXEndTag\"\n ],\n [\n _common.NodeProp.group,\n -26,\n 8,\n 15,\n 17,\n 58,\n 184,\n 188,\n 191,\n 192,\n 194,\n 197,\n 200,\n 211,\n 213,\n 219,\n 221,\n 223,\n 225,\n 228,\n 234,\n 238,\n 240,\n 242,\n 244,\n 246,\n 248,\n 249,\n \"Statement\",\n -30,\n 12,\n 13,\n 24,\n 27,\n 28,\n 41,\n 43,\n 44,\n 45,\n 47,\n 52,\n 60,\n 68,\n 74,\n 75,\n 91,\n 92,\n 101,\n 103,\n 119,\n 122,\n 124,\n 125,\n 126,\n 127,\n 129,\n 130,\n 148,\n 149,\n 151,\n \"Expression\",\n -22,\n 23,\n 25,\n 29,\n 32,\n 34,\n 152,\n 154,\n 156,\n 157,\n 159,\n 160,\n 161,\n 163,\n 164,\n 165,\n 167,\n 168,\n 169,\n 178,\n 180,\n 182,\n 183,\n \"Type\",\n -3,\n 79,\n 85,\n 90,\n \"ClassItem\"\n ],\n [\n _common.NodeProp.openedBy,\n 30,\n \"InterpolationStart\",\n 46,\n \"[\",\n 50,\n \"{\",\n 65,\n \"(\",\n 131,\n \"JSXStartTag\",\n 141,\n \"JSXStartTag JSXStartCloseTag\"\n ]\n ],\n skippedNodes: [\n 0,\n 5,\n 6\n ],\n repeatNodeCount: 28,\n tokenData: \"!C}~R!`OX%TXY%cYZ'RZ[%c[]%T]^'R^p%Tpq%cqr'crs(kst0htu2`uv4pvw5ewx6cxy<yyz=Zz{=k{|>k|}?O}!O>k!O!P?`!P!QCl!Q!R!0[!R![!1q![!]!7s!]!^!8V!^!_!8g!_!`!9d!`!a!:[!a!b!<R!b!c%T!c!}2`!}#O!=d#O#P%T#P#Q!=t#Q#R!>U#R#S2`#S#T!>i#T#o2`#o#p!>y#p#q!?O#q#r!?f#r#s!?x#s$f%T$f$g%c$g#BY2`#BY#BZ!@Y#BZ$IS2`$IS$I_!@Y$I_$I|2`$I|$I}!Bq$I}$JO!Bq$JO$JT2`$JT$JU!@Y$JU$KV2`$KV$KW!@Y$KW&FU2`&FU&FV!@Y&FV?HT2`?HT?HU!@Y?HU~2`W%YR$UWO!^%T!_#o%T#p~%T,T%jg$UW'W+{OX%TXY%cYZ%TZ[%c[p%Tpq%cq!^%T!_#o%T#p$f%T$f$g%c$g#BY%T#BY#BZ%c#BZ$IS%T$IS$I_%c$I_$JT%T$JT$JU%c$JU$KV%T$KV$KW%c$KW&FU%T&FU&FV%c&FV?HT%T?HT?HU%c?HU~%T,T'YR$UW'X+{O!^%T!_#o%T#p~%T$T'jS$UW!j#{O!^%T!_!`'v!`#o%T#p~%T$O'}S#e#v$UWO!^%T!_!`(Z!`#o%T#p~%T$O(bR#e#v$UWO!^%T!_#o%T#p~%T'u(rZ$UW]!ROY(kYZ)eZr(krs*rs!^(k!^!_+U!_#O(k#O#P-b#P#o(k#o#p+U#p~(k&r)jV$UWOr)ers*Ps!^)e!^!_*a!_#o)e#o#p*a#p~)e&r*WR$P&j$UWO!^%T!_#o%T#p~%T&j*dROr*ars*ms~*a&j*rO$P&j'u*{R$P&j$UW]!RO!^%T!_#o%T#p~%T'm+ZV]!ROY+UYZ*aZr+Urs+ps#O+U#O#P+w#P~+U'm+wO$P&j]!R'm+zROr+Urs,Ts~+U'm,[U$P&j]!ROY,nZr,nrs-Vs#O,n#O#P-[#P~,n!R,sU]!ROY,nZr,nrs-Vs#O,n#O#P-[#P~,n!R-[O]!R!R-_PO~,n'u-gV$UWOr(krs-|s!^(k!^!_+U!_#o(k#o#p+U#p~(k'u.VZ$P&j$UW]!ROY.xYZ%TZr.xrs/rs!^.x!^!_,n!_#O.x#O#P0S#P#o.x#o#p,n#p~.x!Z/PZ$UW]!ROY.xYZ%TZr.xrs/rs!^.x!^!_,n!_#O.x#O#P0S#P#o.x#o#p,n#p~.x!Z/yR$UW]!RO!^%T!_#o%T#p~%T!Z0XT$UWO!^.x!^!_,n!_#o.x#o#p,n#p~.xy0mZ$UWOt%Ttu1`u!^%T!_!c%T!c!}1`!}#R%T#R#S1`#S#T%T#T#o1`#p$g%T$g~1`y1g]$UW'mqOt%Ttu1`u!Q%T!Q![1`![!^%T!_!c%T!c!}1`!}#R%T#R#S1`#S#T%T#T#o1`#p$g%T$g~1`&i2k_$UW#zS'Z%k'epOt%Ttu2`u}%T}!O3j!O!Q%T!Q![2`![!^%T!_!c%T!c!}2`!}#R%T#R#S2`#S#T%T#T#o2`#p$g%T$g~2`[3q_$UW#zSOt%Ttu3ju}%T}!O3j!O!Q%T!Q![3j![!^%T!_!c%T!c!}3j!}#R%T#R#S3j#S#T%T#T#o3j#p$g%T$g~3j$O4wS#^#v$UWO!^%T!_!`5T!`#o%T#p~%T$O5[R$UW#o#vO!^%T!_#o%T#p~%T%r5lU'v%j$UWOv%Tvw6Ow!^%T!_!`5T!`#o%T#p~%T$O6VS$UW#i#vO!^%T!_!`5T!`#o%T#p~%T'u6jZ$UW]!ROY6cYZ7]Zw6cwx*rx!^6c!^!_8T!_#O6c#O#P:T#P#o6c#o#p8T#p~6c&r7bV$UWOw7]wx*Px!^7]!^!_7w!_#o7]#o#p7w#p~7]&j7zROw7wwx*mx~7w'm8YV]!ROY8TYZ7wZw8Twx+px#O8T#O#P8o#P~8T'm8rROw8Twx8{x~8T'm9SU$P&j]!ROY9fZw9fwx-Vx#O9f#O#P9}#P~9f!R9kU]!ROY9fZw9fwx-Vx#O9f#O#P9}#P~9f!R:QPO~9f'u:YV$UWOw6cwx:ox!^6c!^!_8T!_#o6c#o#p8T#p~6c'u:xZ$P&j$UW]!ROY;kYZ%TZw;kwx/rx!^;k!^!_9f!_#O;k#O#P<e#P#o;k#o#p9f#p~;k!Z;rZ$UW]!ROY;kYZ%TZw;kwx/rx!^;k!^!_9f!_#O;k#O#P<e#P#o;k#o#p9f#p~;k!Z<jT$UWO!^;k!^!_9f!_#o;k#o#p9f#p~;k%V=QR!d$}$UWO!^%T!_#o%T#p~%TZ=bR!cR$UWO!^%T!_#o%T#p~%T%R=tU'[!R#_#v$UWOz%Tz{>W{!^%T!_!`5T!`#o%T#p~%T$O>_S#[#v$UWO!^%T!_!`5T!`#o%T#p~%T$u>rSj$m$UWO!^%T!_!`5T!`#o%T#p~%T&i?VR!R&a$UWO!^%T!_#o%T#p~%T&i?gVu%n$UWO!O%T!O!P?|!P!Q%T!Q![@r![!^%T!_#o%T#p~%Ty@RT$UWO!O%T!O!P@b!P!^%T!_#o%T#p~%Ty@iR!Qq$UWO!^%T!_#o%T#p~%Ty@yZ$UWkqO!Q%T!Q![@r![!^%T!_!g%T!g!hAl!h#R%T#R#S@r#S#X%T#X#YAl#Y#o%T#p~%TyAqZ$UWO{%T{|Bd|}%T}!OBd!O!Q%T!Q![CO![!^%T!_#R%T#R#SCO#S#o%T#p~%TyBiV$UWO!Q%T!Q![CO![!^%T!_#R%T#R#SCO#S#o%T#p~%TyCVV$UWkqO!Q%T!Q![CO![!^%T!_#R%T#R#SCO#S#o%T#p~%T,TCs`$UW#]#vOYDuYZ%TZzDuz{Jl{!PDu!P!Q!-e!Q!^Du!^!_Fx!_!`!.^!`!a!/]!a!}Du!}#OHq#O#PJQ#P#oDu#o#pFx#p~DuXD|[$UW}POYDuYZ%TZ!PDu!P!QEr!Q!^Du!^!_Fx!_!}Du!}#OHq#O#PJQ#P#oDu#o#pFx#p~DuXEy_$UW}PO!^%T!_#Z%T#Z#[Er#[#]%T#]#^Er#^#a%T#a#bEr#b#g%T#g#hEr#h#i%T#i#jEr#j#m%T#m#nEr#n#o%T#p~%TPF}V}POYFxZ!PFx!P!QGd!Q!}Fx!}#OG{#O#PHh#P~FxPGiU}P#Z#[Gd#]#^Gd#a#bGd#g#hGd#i#jGd#m#nGdPHOTOYG{Z#OG{#O#PH_#P#QFx#Q~G{PHbQOYG{Z~G{PHkQOYFxZ~FxXHvY$UWOYHqYZ%TZ!^Hq!^!_G{!_#OHq#O#PIf#P#QDu#Q#oHq#o#pG{#p~HqXIkV$UWOYHqYZ%TZ!^Hq!^!_G{!_#oHq#o#pG{#p~HqXJVV$UWOYDuYZ%TZ!^Du!^!_Fx!_#oDu#o#pFx#p~Du,TJs^$UW}POYJlYZKoZzJlz{NQ{!PJl!P!Q!,R!Q!^Jl!^!_!!]!_!}Jl!}#O!'|#O#P!+a#P#oJl#o#p!!]#p~Jl,TKtV$UWOzKoz{LZ{!^Ko!^!_M]!_#oKo#o#pM]#p~Ko,TL`X$UWOzKoz{LZ{!PKo!P!QL{!Q!^Ko!^!_M]!_#oKo#o#pM]#p~Ko,TMSR$UWU+{O!^%T!_#o%T#p~%T+{M`ROzM]z{Mi{~M]+{MlTOzM]z{Mi{!PM]!P!QM{!Q~M]+{NQOU+{,TNX^$UW}POYJlYZKoZzJlz{NQ{!PJl!P!Q! T!Q!^Jl!^!_!!]!_!}Jl!}#O!'|#O#P!+a#P#oJl#o#p!!]#p~Jl,T! ^_$UWU+{}PO!^%T!_#Z%T#Z#[Er#[#]%T#]#^Er#^#a%T#a#bEr#b#g%T#g#hEr#h#i%T#i#jEr#j#m%T#m#nEr#n#o%T#p~%T+{!!bY}POY!!]YZM]Zz!!]z{!#Q{!P!!]!P!Q!&x!Q!}!!]!}#O!$`#O#P!&f#P~!!]+{!#VY}POY!!]YZM]Zz!!]z{!#Q{!P!!]!P!Q!#u!Q!}!!]!}#O!$`#O#P!&f#P~!!]+{!#|UU+{}P#Z#[Gd#]#^Gd#a#bGd#g#hGd#i#jGd#m#nGd+{!$cWOY!$`YZM]Zz!$`z{!${{#O!$`#O#P!&S#P#Q!!]#Q~!$`+{!%OYOY!$`YZM]Zz!$`z{!${{!P!$`!P!Q!%n!Q#O!$`#O#P!&S#P#Q!!]#Q~!$`+{!%sTU+{OYG{Z#OG{#O#PH_#P#QFx#Q~G{+{!&VTOY!$`YZM]Zz!$`z{!${{~!$`+{!&iTOY!!]YZM]Zz!!]z{!#Q{~!!]+{!&}_}POzM]z{Mi{#ZM]#Z#[!&x#[#]M]#]#^!&x#^#aM]#a#b!&x#b#gM]#g#h!&x#h#iM]#i#j!&x#j#mM]#m#n!&x#n~M],T!(R[$UWOY!'|YZKoZz!'|z{!(w{!^!'|!^!_!$`!_#O!'|#O#P!*o#P#QJl#Q#o!'|#o#p!$`#p~!'|,T!(|^$UWOY!'|YZKoZz!'|z{!(w{!P!'|!P!Q!)x!Q!^!'|!^!_!$`!_#O!'|#O#P!*o#P#QJl#Q#o!'|#o#p!$`#p~!'|,T!*PY$UWU+{OYHqYZ%TZ!^Hq!^!_G{!_#OHq#O#PIf#P#QDu#Q#oHq#o#pG{#p~Hq,T!*tX$UWOY!'|YZKoZz!'|z{!(w{!^!'|!^!_!$`!_#o!'|#o#p!$`#p~!'|,T!+fX$UWOYJlYZKoZzJlz{NQ{!^Jl!^!_!!]!_#oJl#o#p!!]#p~Jl,T!,Yc$UW}POzKoz{LZ{!^Ko!^!_M]!_#ZKo#Z#[!,R#[#]Ko#]#^!,R#^#aKo#a#b!,R#b#gKo#g#h!,R#h#iKo#i#j!,R#j#mKo#m#n!,R#n#oKo#o#pM]#p~Ko,T!-lV$UWT+{OY!-eYZ%TZ!^!-e!^!_!.R!_#o!-e#o#p!.R#p~!-e+{!.WQT+{OY!.RZ~!.R$P!.g[$UW#o#v}POYDuYZ%TZ!PDu!P!QEr!Q!^Du!^!_Fx!_!}Du!}#OHq#O#PJQ#P#oDu#o#pFx#p~Du]!/f[#wS$UW}POYDuYZ%TZ!PDu!P!QEr!Q!^Du!^!_Fx!_!}Du!}#OHq#O#PJQ#P#oDu#o#pFx#p~Duy!0cd$UWkqO!O%T!O!P@r!P!Q%T!Q![!1q![!^%T!_!g%T!g!hAl!h#R%T#R#S!1q#S#U%T#U#V!3X#V#X%T#X#YAl#Y#b%T#b#c!2w#c#d!4m#d#l%T#l#m!5{#m#o%T#p~%Ty!1x_$UWkqO!O%T!O!P@r!P!Q%T!Q![!1q![!^%T!_!g%T!g!hAl!h#R%T#R#S!1q#S#X%T#X#YAl#Y#b%T#b#c!2w#c#o%T#p~%Ty!3OR$UWkqO!^%T!_#o%T#p~%Ty!3^W$UWO!Q%T!Q!R!3v!R!S!3v!S!^%T!_#R%T#R#S!3v#S#o%T#p~%Ty!3}Y$UWkqO!Q%T!Q!R!3v!R!S!3v!S!^%T!_#R%T#R#S!3v#S#b%T#b#c!2w#c#o%T#p~%Ty!4rV$UWO!Q%T!Q!Y!5X!Y!^%T!_#R%T#R#S!5X#S#o%T#p~%Ty!5`X$UWkqO!Q%T!Q!Y!5X!Y!^%T!_#R%T#R#S!5X#S#b%T#b#c!2w#c#o%T#p~%Ty!6QZ$UWO!Q%T!Q![!6s![!^%T!_!c%T!c!i!6s!i#R%T#R#S!6s#S#T%T#T#Z!6s#Z#o%T#p~%Ty!6z]$UWkqO!Q%T!Q![!6s![!^%T!_!c%T!c!i!6s!i#R%T#R#S!6s#S#T%T#T#Z!6s#Z#b%T#b#c!2w#c#o%T#p~%T%w!7|R!]V$UW#m%hO!^%T!_#o%T#p~%T!P!8^R_w$UWO!^%T!_#o%T#p~%T+c!8rR'`d!a%Y#x&s'zP!P!Q!8{!^!_!9Q!_!`!9_W!9QO$WW#v!9VP#`#v!_!`!9Y#v!9_O#o#v#v!9dO#a#v%w!9kT!{%o$UWO!^%T!_!`'v!`!a!9z!a#o%T#p~%T$P!:RR#W#w$UWO!^%T!_#o%T#p~%T%w!:gT'_!s#a#v$RS$UWO!^%T!_!`!:v!`!a!;W!a#o%T#p~%T$O!:}R#a#v$UWO!^%T!_#o%T#p~%T$O!;_T#`#v$UWO!^%T!_!`5T!`!a!;n!a#o%T#p~%T$O!;uS#`#v$UWO!^%T!_!`5T!`#o%T#p~%T%w!<YV'n%o$UWO!O%T!O!P!<o!P!^%T!_!a%T!a!b!=P!b#o%T#p~%T$`!<vRv$W$UWO!^%T!_#o%T#p~%T$O!=WS$UW#j#vO!^%T!_!`5T!`#o%T#p~%T&e!=kRx&]$UWO!^%T!_#o%T#p~%TZ!={R!OR$UWO!^%T!_#o%T#p~%T$O!>]S#g#v$UWO!^%T!_!`5T!`#o%T#p~%T$P!>pR$UW'd#wO!^%T!_#o%T#p~%T~!?OO!T~%r!?VT'u%j$UWO!^%T!_!`5T!`#o%T#p#q!=P#q~%T$u!?oR!S$knQ$UWO!^%T!_#o%T#p~%TX!@PR!kP$UWO!^%T!_#o%T#p~%T,T!@gr$UW'W+{#zS'Z%k'epOX%TXY%cYZ%TZ[%c[p%Tpq%cqt%Ttu2`u}%T}!O3j!O!Q%T!Q![2`![!^%T!_!c%T!c!}2`!}#R%T#R#S2`#S#T%T#T#o2`#p$f%T$f$g%c$g#BY2`#BY#BZ!@Y#BZ$IS2`$IS$I_!@Y$I_$JT2`$JT$JU!@Y$JU$KV2`$KV$KW!@Y$KW&FU2`&FU&FV!@Y&FV?HT2`?HT?HU!@Y?HU~2`,T!CO_$UW'X+{#zS'Z%k'epOt%Ttu2`u}%T}!O3j!O!Q%T!Q![2`![!^%T!_!c%T!c!}2`!}#R%T#R#S2`#S#T%T#T#o2`#p$g%T$g~2`\",\n tokenizers: [\n noSemicolon,\n incdecToken,\n template,\n 0,\n 1,\n 2,\n 3,\n 4,\n 5,\n 6,\n 7,\n 8,\n insertSemicolon\n ],\n topRules: {\n \"Script\": [\n 0,\n 7\n ]\n },\n dialects: {\n jsx: 11335,\n ts: 11337\n },\n dynamicPrecedences: {\n \"149\": 1,\n \"176\": 1\n },\n specialized: [\n {\n term: 287,\n get: (value, stack)=>tsExtends(value, stack) << 1\n },\n {\n term: 287,\n get: (value)=>spec_identifier[value] || -1\n },\n {\n term: 297,\n get: (value)=>spec_word[value] || -1\n },\n {\n term: 63,\n get: (value)=>spec_LessThan[value] || -1\n }\n ],\n tokenPrec: 11358\n});\n\n},{\"@lezer/lr\":\"3Ck4G\",\"@lezer/common\":\"ds1Io\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"36F0z\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"commonmark\", ()=>commonmark\n);\nparcelHelpers.export(exports, \"mkLang\", ()=>mkLang\n);\nparcelHelpers.export(exports, \"commonmarkLanguage\", ()=>commonmarkLanguage\n);\nparcelHelpers.export(exports, \"markdownLanguage\", ()=>markdownLanguage\n);\nparcelHelpers.export(exports, \"getCodeParser\", ()=>getCodeParser\n);\nvar _language = require(\"@codemirror/language\");\nvar _highlight = require(\"@codemirror/highlight\");\nvar _markdown = require(\"@lezer/markdown\");\nconst data = _language.defineLanguageFacet({\n block: {\n open: \"<\\!--\",\n close: \"-->\"\n }\n});\nconst commonmark = _markdown.parser.configure({\n props: [\n _highlight.styleTags({\n \"Blockquote/...\": _highlight.tags.quote,\n HorizontalRule: _highlight.tags.contentSeparator,\n \"ATXHeading1/... SetextHeading1/...\": _highlight.tags.heading1,\n \"ATXHeading2/... SetextHeading2/...\": _highlight.tags.heading2,\n \"ATXHeading3/...\": _highlight.tags.heading3,\n \"ATXHeading4/...\": _highlight.tags.heading4,\n \"ATXHeading5/...\": _highlight.tags.heading5,\n \"ATXHeading6/...\": _highlight.tags.heading6,\n \"Comment CommentBlock\": _highlight.tags.comment,\n Escape: _highlight.tags.escape,\n Entity: _highlight.tags.character,\n \"Emphasis/...\": _highlight.tags.emphasis,\n \"StrongEmphasis/...\": _highlight.tags.strong,\n \"Link/... Image/...\": _highlight.tags.link,\n \"OrderedList/... BulletList/...\": _highlight.tags.list,\n // \"CodeBlock/... FencedCode/...\": t.blockComment,\n \"InlineCode CodeText\": _highlight.tags.monospace,\n URL: _highlight.tags.url,\n \"HeaderMark HardBreak QuoteMark ListMark LinkMark EmphasisMark CodeMark\": _highlight.tags.processingInstruction,\n \"CodeInfo LinkLabel\": _highlight.tags.labelName,\n LinkTitle: _highlight.tags.string,\n Paragraph: _highlight.tags.content\n }),\n _language.foldNodeProp.add((type)=>{\n if (!type.is(\"Block\") || type.is(\"Document\")) return undefined;\n return (tree, state)=>({\n from: state.doc.lineAt(tree.from).to,\n to: tree.to\n })\n ;\n }),\n _language.indentNodeProp.add({\n Document: ()=>null\n }),\n _language.languageDataProp.add({\n Document: data\n })\n ]\n});\nfunction mkLang(parser) {\n return new _language.Language(data, parser, parser.nodeSet.types.find((t)=>t.name == \"Document\"\n ));\n}\nconst commonmarkLanguage = mkLang(commonmark);\nconst extended = commonmark.configure([\n _markdown.GFM,\n _markdown.Subscript,\n _markdown.Superscript,\n _markdown.Emoji,\n {\n props: [\n _highlight.styleTags({\n \"TableDelimiter SubscriptMark SuperscriptMark StrikethroughMark\": _highlight.tags.processingInstruction,\n \"TableHeader/...\": _highlight.tags.heading,\n \"Strikethrough/...\": _highlight.tags.strikethrough,\n TaskMarker: _highlight.tags.atom,\n Task: _highlight.tags.list,\n Emoji: _highlight.tags.character,\n \"Subscript Superscript\": _highlight.tags.special(_highlight.tags.content),\n TableCell: _highlight.tags.content\n })\n ]\n }\n]);\nconst markdownLanguage = mkLang(extended);\nfunction getCodeParser(languages, defaultLanguage) {\n return (info)=>{\n let found = info && _language.LanguageDescription.matchLanguageName(languages, info, true);\n if (!found) return defaultLanguage ? defaultLanguage.parser : null;\n if (found.support) return found.support.language.parser;\n return _language.ParseContext.getSkippingParser(found.load());\n };\n}\n\n},{\"@codemirror/language\":\"70QHL\",\"@codemirror/highlight\":\"cVRRs\",\"@lezer/markdown\":\"hyLlR\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"9hr01\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"insertNewlineContinueMarkup\", ()=>insertNewlineContinueMarkup\n);\nparcelHelpers.export(exports, \"deleteMarkupBackward\", ()=>deleteMarkupBackward\n);\nvar _state = require(\"@codemirror/state\");\nvar _language = require(\"@codemirror/language\");\nvar _markdown = require(\"./markdown\");\nfunction nodeStart(node, doc) {\n return doc.sliceString(node.from, node.from + 50);\n}\nclass Context {\n constructor(node, from, to, spaceBefore, spaceAfter, type, item){\n this.node = node;\n this.from = from;\n this.to = to;\n this.spaceBefore = spaceBefore;\n this.spaceAfter = spaceAfter;\n this.type = type;\n this.item = item;\n }\n blank(trailing = true) {\n let result = this.spaceBefore;\n if (this.node.name == \"Blockquote\") result += \">\";\n else if (this.node.name == \"Comment\") result += \"%%\";\n else for(let i = this.to - this.from - result.length - this.spaceAfter.length; i > 0; i--)result += \" \";\n return result + (trailing ? this.spaceAfter : \"\");\n }\n marker(doc, add) {\n let number = this.node.name == \"OrderedList\" ? String(+itemNumber(this.item, doc)[2] + add) : \"\";\n return this.spaceBefore + number + this.type + this.spaceAfter;\n }\n}\nfunction getContext(node, line, doc) {\n let nodes = [];\n for(let cur = node; cur && cur.name != \"Document\"; cur = cur.parent)if (cur.name == \"ListItem\" || cur.name == \"Blockquote\" || cur.name == \"Comment\") nodes.push(cur);\n let context = [], pos = 0;\n for(let i = nodes.length - 1; i >= 0; i--){\n let node = nodes[i], match, start = pos;\n if (node.name == \"Blockquote\" && (match = /^[ \\t]*>( ?)/.exec(line.slice(pos)))) {\n pos += match[0].length;\n context.push(new Context(node, start, pos, \"\", match[1], \">\", null));\n } else if (node.name == \"Comment\" && (match = /^[ \\t]*%%( ?)/.exec(line.slice(pos)))) {\n pos += match[0].length;\n context.push(new Context(node, start, pos, \"\", match[1], \"%%\", null));\n } else if (node.name == \"ListItem\" && node.parent.name == \"OrderedList\" && (match = /^([ \\t]*)\\d+([.)])([ \\t]*)/.exec(nodeStart(node, doc)))) {\n let after = match[3], len = match[0].length;\n if (after.length >= 4) {\n after = after.slice(0, after.length - 4);\n len -= 4;\n }\n pos += len;\n context.push(new Context(node.parent, start, pos, match[1], after, match[2], node));\n } else if (node.name == \"ListItem\" && node.parent.name == \"BulletList\" && (match = /^([ \\t]*)([-+*])([ \\t]+)/.exec(nodeStart(node, doc)))) {\n let after = match[3], len = match[0].length;\n if (after.length > 4) {\n after = after.slice(0, after.length - 4);\n len -= 4;\n }\n pos += len;\n context.push(new Context(node.parent, start, pos, match[1], after, match[2], node));\n }\n }\n return context;\n}\nfunction itemNumber(item, doc) {\n return /^(\\s*)(\\d+)(?=[.)])/.exec(doc.sliceString(item.from, item.from + 10));\n}\nfunction renumberList(after, doc, changes, offset = 0) {\n for(let prev = -1, node = after;;){\n if (node.name == \"ListItem\") {\n let m = itemNumber(node, doc);\n let number = +m[2];\n if (prev >= 0) {\n if (number != prev + 1) return;\n changes.push({\n from: node.from + m[1].length,\n to: node.from + m[0].length,\n insert: String(prev + 2 + offset)\n });\n }\n prev = number;\n }\n let next = node.nextSibling;\n if (!next) break;\n node = next;\n }\n}\nconst insertNewlineContinueMarkup = ({ state , dispatch , })=>{\n let tree = _language.syntaxTree(state), { doc } = state;\n let dont = null, changes1 = state.changeByRange((range)=>{\n if (!range.empty || !_markdown.markdownLanguage.isActiveAt(state, range.from)) return dont = {\n range\n };\n let pos = range.from, line = doc.lineAt(pos);\n let context = getContext(tree.resolveInner(pos, -1), line.text, doc);\n while(context.length && context[context.length - 1].from > pos - line.from)context.pop();\n if (!context.length) return dont = {\n range\n };\n let inner = context[context.length - 1];\n if (inner.to - inner.spaceAfter.length > pos - line.from) return dont = {\n range\n };\n let emptyLine = pos >= inner.to - inner.spaceAfter.length && !/\\S/.test(line.text.slice(inner.to));\n // Empty line in list\n if (inner.item && emptyLine) {\n // First list item or blank line before: delete a level of markup\n if (inner.node.firstChild.to >= pos || line.from > 0 && !/[^\\s>]/.test(doc.lineAt(line.from - 1).text)) {\n let next = context.length > 1 ? context[context.length - 2] : null;\n let delTo, insert = \"\";\n if (next && next.item) {\n // Re-add marker for the list at the next level\n delTo = line.from + next.from;\n insert = next.marker(doc, 1);\n } else delTo = line.from + (next ? next.to : 0);\n let changes = [\n {\n from: delTo,\n to: pos,\n insert\n }\n ];\n if (inner.node.name == \"OrderedList\") renumberList(inner.item, doc, changes, -2);\n if (next && next.node.name == \"OrderedList\") renumberList(next.item, doc, changes);\n return {\n range: _state.EditorSelection.cursor(delTo + insert.length),\n changes\n };\n } else {\n // Move this line down\n let insert = \"\";\n for(let i = 0, e = context.length - 2; i <= e; i++)insert += context[i].blank(i < e);\n insert += state.lineBreak;\n return {\n range: _state.EditorSelection.cursor(pos + insert.length),\n changes: {\n from: line.from,\n insert\n }\n };\n }\n }\n if (inner.node.name == \"Blockquote\" && emptyLine && line.from) {\n let prevLine = doc.lineAt(line.from - 1), quoted = />\\s*$/.exec(prevLine.text);\n // Two aligned empty quoted lines in a row\n if (quoted && quoted.index == inner.from) {\n let changes = state.changes([\n {\n from: prevLine.from + quoted.index,\n to: prevLine.to\n },\n {\n from: line.from + inner.from,\n to: line.to\n }, \n ]);\n return {\n range: range.map(changes),\n changes\n };\n }\n }\n if (inner.node.name == \"Comment\" && emptyLine && line.from) {\n let prevLine = doc.lineAt(line.from - 1), commented = /%%\\s*$/.exec(prevLine.text);\n // Two aligned empty quoted lines in a row\n if (commented && commented.index == inner.from) {\n let changes = state.changes([\n {\n from: prevLine.from + commented.index,\n to: prevLine.to\n },\n {\n from: line.from + inner.from,\n to: line.to\n }, \n ]);\n return {\n range: range.map(changes),\n changes\n };\n }\n }\n let changes = [];\n if (inner.node.name == \"OrderedList\") renumberList(inner.item, doc, changes);\n let insert = state.lineBreak;\n let continued = inner.item && inner.item.from < line.from;\n // If not dedented\n if (!continued || /^[\\s\\d.)\\-+*>]*/.exec(line.text)[0].length >= inner.to) for(let i = 0, e = context.length - 1; i <= e; i++)insert += i == e && !continued ? context[i].marker(doc, 1) : context[i].blank();\n let from = pos;\n while(from > line.from && /\\s/.test(line.text.charAt(from - line.from - 1)))from--;\n changes.push({\n from,\n to: pos,\n insert\n });\n return {\n range: _state.EditorSelection.cursor(from + insert.length),\n changes\n };\n });\n if (dont) return false;\n dispatch(state.update(changes1, {\n scrollIntoView: true,\n userEvent: \"input\"\n }));\n return true;\n};\nfunction isMark(node) {\n return node.name == \"QuoteMark\" || node.name == \"ListMark\";\n}\nfunction contextNodeForDelete(tree, pos) {\n let node = tree.resolveInner(pos, -1), scan = pos;\n if (isMark(node)) {\n scan = node.from;\n node = node.parent;\n }\n for(let prev; prev = node.childBefore(scan);){\n if (isMark(prev)) scan = prev.from;\n else if (prev.name == \"OrderedList\" || prev.name == \"BulletList\") {\n node = prev.lastChild;\n scan = node.to;\n } else break;\n }\n return node;\n}\nconst deleteMarkupBackward = ({ state , dispatch })=>{\n let tree = _language.syntaxTree(state);\n let dont = null, changes = state.changeByRange((range)=>{\n let pos = range.from, { doc } = state;\n if (range.empty && _markdown.markdownLanguage.isActiveAt(state, range.from)) {\n let line = doc.lineAt(pos);\n let context = getContext(contextNodeForDelete(tree, pos), line.text, doc);\n if (context.length) {\n let inner = context[context.length - 1];\n let spaceEnd = inner.to - inner.spaceAfter.length + (inner.spaceAfter ? 1 : 0);\n // Delete extra trailing space after markup\n if (pos - line.from > spaceEnd && !/\\S/.test(line.text.slice(spaceEnd, pos - line.from))) return {\n range: _state.EditorSelection.cursor(line.from + spaceEnd),\n changes: {\n from: line.from + spaceEnd,\n to: pos\n }\n };\n if (pos - line.from == spaceEnd) {\n let start = line.from + inner.from;\n // Replace a list item marker with blank space\n if (inner.item && inner.node.from < inner.item.from && /\\S/.test(line.text.slice(inner.from, inner.to))) return {\n range,\n changes: {\n from: start,\n to: line.from + inner.to,\n insert: inner.blank()\n }\n };\n // Delete one level of indentation\n if (start < pos) return {\n range: _state.EditorSelection.cursor(start),\n changes: {\n from: start,\n to: pos\n }\n };\n }\n }\n }\n return dont = {\n range\n };\n });\n if (dont) return false;\n dispatch(state.update(changes, {\n scrollIntoView: true,\n userEvent: \"delete\"\n }));\n return true;\n};\n\n},{\"@codemirror/state\":\"e6FBl\",\"@codemirror/language\":\"70QHL\",\"./markdown\":\"36F0z\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"hU6Am\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"PathPageNavigator\", ()=>PathPageNavigator\n);\nparcelHelpers.export(exports, \"HashPageNavigator\", ()=>HashPageNavigator\n);\nvar _util = require(\"./util\");\nfunction encodePageUrl(name) {\n return name.replaceAll(\" \", \"_\");\n}\nfunction decodePageUrl(url) {\n return url.replaceAll(\"_\", \" \");\n}\nclass PathPageNavigator {\n async navigate(page) {\n window.history.pushState({\n page: page\n }, page, `/${encodePageUrl(page)}`);\n window.dispatchEvent(new PopStateEvent(\"popstate\"));\n await new Promise((resolve)=>{\n this.navigationResolve = resolve;\n });\n this.navigationResolve = undefined;\n }\n subscribe(pageLoadCallback) {\n const cb = ()=>{\n const gotoPage = this.getCurrentPage();\n if (!gotoPage) return;\n _util.safeRun(async ()=>{\n await pageLoadCallback(this.getCurrentPage());\n if (this.navigationResolve) this.navigationResolve(undefined);\n });\n };\n window.addEventListener(\"popstate\", cb);\n cb();\n }\n getCurrentPage() {\n return decodePageUrl(location.pathname.substring(1));\n }\n}\nclass HashPageNavigator {\n async navigate(page) {\n location.hash = encodePageUrl(page);\n await new Promise((resolve)=>{\n this.navigationResolve = resolve;\n });\n this.navigationResolve = undefined;\n }\n subscribe(pageLoadCallback) {\n const cb = ()=>{\n _util.safeRun(async ()=>{\n await pageLoadCallback(this.getCurrentPage());\n if (this.navigationResolve) this.navigationResolve(undefined);\n });\n };\n window.addEventListener(\"hashchange\", cb);\n cb();\n }\n getCurrentPage() {\n return decodePageUrl(location.hash.substring(1));\n }\n}\n\n},{\"./util\":\"eF4A3\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"ecodz\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"Comment\", ()=>Comment\n);\nvar _highlight = require(\"@codemirror/highlight\");\nvar _markdown = require(\"@lezer/markdown\");\nvar _markdown1 = require(\"./markdown/markdown\");\nvar _customtags = require(\"./customtags\");\nvar _constant = require(\"./constant\");\nconst pageLinkRegexPrefix = new RegExp(\"^\" + _constant.pageLinkRegex.toString().slice(1, -1));\nconst WikiLink = {\n defineNodes: [\n \"WikiLink\",\n \"WikiLinkPage\"\n ],\n parseInline: [\n {\n name: \"WikiLink\",\n parse (cx, next, pos) {\n let match;\n if (next != 91 /* '[' */ || !(match = pageLinkRegexPrefix.exec(cx.slice(pos, cx.end)))) return -1;\n return cx.addElement(cx.elt(\"WikiLink\", pos, pos + match[0].length + 1, [\n cx.elt(\"WikiLinkPage\", pos + 2, pos + match[0].length - 2), \n ]));\n },\n after: \"Emphasis\"\n }, \n ]\n};\nconst AtMention = {\n defineNodes: [\n \"AtMention\"\n ],\n parseInline: [\n {\n name: \"AtMention\",\n parse (cx, next, pos) {\n let match;\n if (next != 64 /* '@' */ || !(match = /^[A-Za-z\\.]+/.exec(cx.slice(pos + 1, cx.end)))) return -1;\n return cx.addElement(cx.elt(\"AtMention\", pos, pos + 1 + match[0].length));\n },\n after: \"Emphasis\"\n }, \n ]\n};\nconst urlRegexp = /^https?:\\/\\/(www\\.)?[-a-zA-Z0-9@:%._\\+~#=]{1,256}\\.[a-zA-Z0-9()]{1,6}\\b([-a-zA-Z0-9()@:%_\\+.~#?&//=]*)/;\nconst UnmarkedUrl = {\n defineNodes: [\n \"URL\"\n ],\n parseInline: [\n {\n name: \"URL\",\n parse (cx, next, pos) {\n let match;\n if (next != 104 /* 'h' */ || !(match = urlRegexp.exec(cx.slice(pos, cx.end)))) return -1;\n return cx.addElement(cx.elt(\"URL\", pos, pos + match[0].length));\n },\n after: \"Emphasis\"\n }, \n ]\n};\nclass CommentParser {\n nextLine() {\n return false;\n }\n finish(cx, leaf) {\n cx.addLeafElement(leaf, cx.elt(\"Comment\", leaf.start, leaf.start + leaf.content.length, [\n // cx.elt(\"CommentMarker\", leaf.start, leaf.start + 3),\n ...cx.parser.parseInline(leaf.content.slice(3), leaf.start + 3), \n ]));\n return true;\n }\n}\nconst Comment = {\n defineNodes: [\n {\n name: \"Comment\",\n block: true\n }\n ],\n parseBlock: [\n {\n name: \"Comment\",\n leaf (cx, leaf) {\n return /^%%\\s/.test(leaf.content) ? new CommentParser() : null;\n },\n after: \"SetextHeading\"\n }, \n ]\n};\nconst TagLink = {\n defineNodes: [\n \"TagLink\"\n ],\n parseInline: [\n {\n name: \"TagLink\",\n parse (cx, next, pos) {\n let match;\n if (next != 35 /* '#' */ || !(match = /^[A-Za-z\\.]+/.exec(cx.slice(pos + 1, cx.end)))) return -1;\n return cx.addElement(cx.elt(\"TagLink\", pos, pos + 1 + match[0].length));\n },\n after: \"Emphasis\"\n }, \n ]\n};\nconst WikiMarkdown = _markdown1.commonmark.configure([\n WikiLink,\n AtMention,\n TagLink,\n _markdown.TaskList,\n UnmarkedUrl,\n Comment,\n {\n props: [\n _highlight.styleTags({\n WikiLink: _customtags.WikiLinkTag,\n WikiLinkPage: _customtags.WikiLinkPageTag,\n AtMention: _customtags.MentionTag,\n TagLink: _customtags.TagTag,\n Task: _customtags.TaskTag,\n TaskMarker: _customtags.TaskMarkerTag,\n Url: _highlight.tags.url,\n Comment: _customtags.CommentTag\n }), \n ]\n }, \n]);\nexports.default = _markdown1.mkLang(WikiMarkdown);\n\n},{\"@codemirror/highlight\":\"cVRRs\",\"@lezer/markdown\":\"hyLlR\",\"./markdown/markdown\":\"36F0z\",\"./customtags\":\"4u7x1\",\"./constant\":\"gBEed\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"4u7x1\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"WikiLinkTag\", ()=>WikiLinkTag\n);\nparcelHelpers.export(exports, \"WikiLinkPageTag\", ()=>WikiLinkPageTag\n);\nparcelHelpers.export(exports, \"TagTag\", ()=>TagTag\n);\nparcelHelpers.export(exports, \"MentionTag\", ()=>MentionTag\n);\nparcelHelpers.export(exports, \"TaskTag\", ()=>TaskTag\n);\nparcelHelpers.export(exports, \"TaskMarkerTag\", ()=>TaskMarkerTag\n);\nparcelHelpers.export(exports, \"CommentTag\", ()=>CommentTag\n);\nparcelHelpers.export(exports, \"CommentMarkerTag\", ()=>CommentMarkerTag\n);\nparcelHelpers.export(exports, \"BulletList\", ()=>BulletList\n);\nparcelHelpers.export(exports, \"OrderedList\", ()=>OrderedList\n);\nvar _highlight = require(\"@codemirror/highlight\");\nconst WikiLinkTag = _highlight.Tag.define();\nconst WikiLinkPageTag = _highlight.Tag.define();\nconst TagTag = _highlight.Tag.define();\nconst MentionTag = _highlight.Tag.define();\nconst TaskTag = _highlight.Tag.define();\nconst TaskMarkerTag = _highlight.Tag.define();\nconst CommentTag = _highlight.Tag.define();\nconst CommentMarkerTag = _highlight.Tag.define();\nconst BulletList = _highlight.Tag.define();\nconst OrderedList = _highlight.Tag.define();\n\n},{\"@codemirror/highlight\":\"cVRRs\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"gBEed\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"pageLinkRegex\", ()=>pageLinkRegex\n);\nconst pageLinkRegex = /\\[\\[([\\w\\s\\/\\:,\\.\\-]+)\\]\\]/;\n\n},{\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"eSjNz\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"FunctionWorker\", ()=>FunctionWorker\n);\nparcelHelpers.export(exports, \"Plug\", ()=>Plug\n);\nparcelHelpers.export(exports, \"System\", ()=>System\n);\nclass FunctionWorker {\n constructor(plug, name, code){\n // let worker = window.Worker;\n this.worker = new Worker(require(\"2a5267de988349cf\"));\n this.worker.onmessage = this.onmessage.bind(this);\n this.worker.postMessage({\n type: \"boot\",\n name: name,\n code: code\n });\n this.inited = new Promise((resolve)=>{\n this.initCallback = resolve;\n });\n this.plug = plug;\n }\n async onmessage(evt) {\n let data = evt.data;\n if (!data) return;\n switch(data.type){\n case \"inited\":\n this.initCallback();\n break;\n case \"syscall\":\n let result = await this.plug.system.syscall(data.name, data.args);\n this.worker.postMessage({\n type: \"syscall-response\",\n id: data.id,\n data: result\n });\n break;\n case \"result\":\n this.invokeResolve(data.result);\n break;\n case \"error\":\n this.invokeReject(data.reason);\n break;\n default:\n console.error(\"Unknown message type\", data);\n }\n }\n async invoke(args) {\n await this.inited;\n this.worker.postMessage({\n type: \"invoke\",\n args: args\n });\n return new Promise((resolve, reject)=>{\n this.invokeResolve = resolve;\n this.invokeReject = reject;\n });\n }\n stop() {\n this.worker.terminate();\n }\n}\nclass Plug {\n constructor(system, name){\n this.system = system;\n this.runningFunctions = new Map();\n }\n async load(manifest) {\n this.manifest = manifest;\n await this.dispatchEvent(\"load\");\n }\n async invoke(name, args) {\n if (!this.runningFunctions.has(name)) this.runningFunctions.set(name, new FunctionWorker(this, name, this.manifest.functions[name].code));\n return await this.runningFunctions.get(name).invoke(args);\n }\n async dispatchEvent(name, data) {\n let functionsToSpawn = this.manifest.hooks.events[name];\n if (functionsToSpawn) return await Promise.all(functionsToSpawn.map(async (functionToSpawn)=>await this.invoke(functionToSpawn, [\n data\n ])\n ));\n else return [];\n }\n async stop() {\n for (const [functionname, worker] of Object.entries(this.runningFunctions)){\n console.log(`Stopping ${functionname}`);\n worker.stop();\n }\n this.runningFunctions = new Map();\n }\n}\nclass System {\n constructor(){\n this.plugs = new Map();\n this.registeredSyscalls = {\n };\n }\n registerSyscalls(...registrationObjects) {\n for (const registrationObject of registrationObjects)for(let p in registrationObject)this.registeredSyscalls[p] = registrationObject[p];\n }\n async syscall(name, args) {\n const callback = this.registeredSyscalls[name];\n if (!name) throw Error(`Unregistered syscall ${name}`);\n if (!callback) throw Error(`Registered but not implemented syscall ${name}`);\n return Promise.resolve(callback(...args));\n }\n async load(name, manifest) {\n const plug = new Plug(this, name);\n await plug.load(manifest);\n this.plugs.set(name, plug);\n return plug;\n }\n async stop() {\n return Promise.all(Array.from(this.plugs.values()).map((plug)=>plug.stop()\n ));\n }\n}\nconsole.log(\"Starting\");\n\n},{\"2a5267de988349cf\":\"ajX9r\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"ajX9r\":[function(require,module,exports) {\nlet workerURL = require('./helpers/get-worker-url');\nlet bundleURL = require('./helpers/bundle-url');\nlet url = bundleURL.getBundleURL('eVP07') + \"function_worker.fc034f23.js\" + \"?\" + Date.now();\nmodule.exports = workerURL(url, bundleURL.getOrigin(url), false);\n\n},{\"./helpers/get-worker-url\":\"cn2gM\",\"./helpers/bundle-url\":\"lgJ39\"}],\"cn2gM\":[function(require,module,exports) {\n\"use strict\";\nmodule.exports = function(workerUrl, origin, isESM) {\n if (origin === self.location.origin) // If the worker bundle's url is on the same origin as the document,\n // use the worker bundle's own url.\n return workerUrl;\n else {\n // Otherwise, create a blob URL which loads the worker bundle with `importScripts`.\n var source = isESM ? 'import ' + JSON.stringify(workerUrl) + ';' : 'importScripts(' + JSON.stringify(workerUrl) + ');';\n return URL.createObjectURL(new Blob([\n source\n ], {\n type: 'application/javascript'\n }));\n }\n};\n\n},{}],\"lgJ39\":[function(require,module,exports) {\n\"use strict\";\nvar bundleURL = {\n};\nfunction getBundleURLCached(id) {\n var value = bundleURL[id];\n if (!value) {\n value = getBundleURL();\n bundleURL[id] = value;\n }\n return value;\n}\nfunction getBundleURL() {\n try {\n throw new Error();\n } catch (err) {\n var matches = ('' + err.stack).match(/(https?|file|ftp):\\/\\/[^)\\n]+/g);\n if (matches) // The first two stack frames will be this function and getBundleURLCached.\n // Use the 3rd one, which will be a runtime in the original bundle.\n return getBaseURL(matches[2]);\n }\n return '/';\n}\nfunction getBaseURL(url) {\n return ('' + url).replace(/^((?:https?|file|ftp):\\/\\/.+)\\/[^/]+$/, '$1') + '/';\n} // TODO: Replace uses with `new URL(url).origin` when ie11 is no longer supported.\nfunction getOrigin(url) {\n var matches = ('' + url).match(/(https?|file|ftp):\\/\\/[^/]+/);\n if (!matches) throw new Error('Origin not found');\n return matches[0];\n}\nexports.getBundleURL = getBundleURLCached;\nexports.getBaseURL = getBaseURL;\nexports.getOrigin = getOrigin;\n\n},{}],\"8TXso\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"slashCommandRegexp\", ()=>slashCommandRegexp\n);\nparcelHelpers.export(exports, \"initialViewState\", ()=>initialViewState\n);\nconst slashCommandRegexp = /\\/[\\w\\-]*/;\nconst initialViewState = {\n isSaved: false,\n showPageNavigator: false,\n showCommandPalette: false,\n allPages: [],\n commands: new Map()\n};\n\n},{\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"nLnWn\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nfunction reducer(state, action) {\n // console.log(\"Got action\", action);\n switch(action.type){\n case \"page-loaded\":\n return {\n ...state,\n allPages: state.allPages.map((pageMeta)=>pageMeta.name === action.meta.name ? {\n ...pageMeta,\n lastOpened: new Date()\n } : pageMeta\n ),\n currentPage: action.meta,\n isSaved: true\n };\n case \"page-saved\":\n return {\n ...state,\n currentPage: action.meta,\n isSaved: true\n };\n case \"page-updated\":\n // Minor rerender optimization, this is triggered a lot\n if (!state.isSaved) return state;\n return {\n ...state,\n isSaved: false\n };\n case \"start-navigate\":\n return {\n ...state,\n showPageNavigator: true\n };\n case \"stop-navigate\":\n return {\n ...state,\n showPageNavigator: false\n };\n case \"pages-listed\":\n return {\n ...state,\n allPages: action.pages\n };\n case \"show-palette\":\n return {\n ...state,\n showCommandPalette: true\n };\n case \"hide-palette\":\n return {\n ...state,\n showCommandPalette: false\n };\n case \"update-commands\":\n return {\n ...state,\n commands: action.commands\n };\n }\n return state;\n}\nexports.default = reducer;\n\n},{\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"1Ie8K\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"smartQuoteKeymap\", ()=>smartQuoteKeymap\n);\n// TODO: Add support for selection (put quotes around or create blockquote block?)\nfunction keyBindingForQuote(quote1, left, right) {\n return {\n key: quote1,\n run: (target)=>{\n let cursorPos = target.state.selection.main.from;\n let chBefore = target.state.sliceDoc(cursorPos - 1, cursorPos);\n let quote = right;\n if (/\\W/.exec(chBefore) && !/[!\\?,\\.\\-=\u201c]/.exec(chBefore)) quote = left;\n target.dispatch({\n changes: {\n insert: quote,\n from: cursorPos\n },\n selection: {\n anchor: cursorPos + 1\n }\n });\n return true;\n }\n };\n}\nconst smartQuoteKeymap = [\n keyBindingForQuote('\"', \"\u201c\", \"\u201d\"),\n keyBindingForQuote(\"'\", \"\u2018\", \"\u2019\"), \n];\n\n},{\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"cDDDV\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nvar _highlight = require(\"@codemirror/highlight\");\nvar _customtags = require(\"./customtags\");\nexports.default = _highlight.HighlightStyle.define([\n {\n tag: _highlight.tags.heading1,\n class: \"h1\"\n },\n {\n tag: _highlight.tags.heading2,\n class: \"h2\"\n },\n {\n tag: _highlight.tags.heading3,\n class: \"h3\"\n },\n {\n tag: _highlight.tags.link,\n class: \"link\"\n },\n {\n tag: _highlight.tags.meta,\n class: \"meta\"\n },\n {\n tag: _highlight.tags.quote,\n class: \"quote\"\n },\n {\n tag: _highlight.tags.monospace,\n class: \"code\"\n },\n {\n tag: _highlight.tags.url,\n class: \"url\"\n },\n {\n tag: _customtags.WikiLinkTag,\n class: \"wiki-link\"\n },\n {\n tag: _customtags.WikiLinkPageTag,\n class: \"wiki-link-page\"\n },\n {\n tag: _customtags.TagTag,\n class: \"tag\"\n },\n {\n tag: _customtags.MentionTag,\n class: \"mention\"\n },\n {\n tag: _customtags.TaskTag,\n class: \"task\"\n },\n {\n tag: _customtags.TaskMarkerTag,\n class: \"task-marker\"\n },\n {\n tag: _customtags.CommentTag,\n class: \"comment\"\n },\n {\n tag: _customtags.CommentMarkerTag,\n class: \"comment-marker\"\n },\n {\n tag: _highlight.tags.emphasis,\n class: \"emphasis\"\n },\n {\n tag: _highlight.tags.strong,\n class: \"strong\"\n },\n {\n tag: _highlight.tags.atom,\n class: \"atom\"\n },\n {\n tag: _highlight.tags.bool,\n class: \"bool\"\n },\n {\n tag: _highlight.tags.url,\n class: \"url\"\n },\n {\n tag: _highlight.tags.inserted,\n class: \"inserted\"\n },\n {\n tag: _highlight.tags.deleted,\n class: \"deleted\"\n },\n {\n tag: _highlight.tags.literal,\n class: \"literal\"\n },\n {\n tag: _highlight.tags.list,\n class: \"list\"\n },\n {\n tag: _highlight.tags.definition,\n class: \"li\"\n },\n {\n tag: _highlight.tags.string,\n class: \"string\"\n },\n {\n tag: _highlight.tags.number,\n class: \"number\"\n },\n {\n tag: [\n _highlight.tags.regexp,\n _highlight.tags.escape,\n _highlight.tags.special(_highlight.tags.string)\n ],\n class: \"string2\"\n },\n {\n tag: _highlight.tags.variableName,\n class: \"variableName\"\n },\n {\n tag: _highlight.tags.comment,\n class: \"comment\"\n },\n {\n tag: _highlight.tags.invalid,\n class: \"invalid\"\n },\n {\n tag: _highlight.tags.punctuation,\n class: \"punctuation\"\n }, \n]);\n\n},{\"@codemirror/highlight\":\"cVRRs\",\"./customtags\":\"4u7x1\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"8aIJL\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nexports.default = {\n \"db.put\": (key, value)=>{\n localStorage.setItem(key, value);\n },\n \"db.get\": (key)=>{\n return localStorage.getItem(key);\n }\n};\n\n},{\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"lj9QJ\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nvar _language = require(\"@codemirror/language\");\nfunction ensureAnchor(expr, start) {\n var _a;\n let { source } = expr;\n let addStart = start && source[0] != \"^\", addEnd = source[source.length - 1] != \"$\";\n if (!addStart && !addEnd) return expr;\n return new RegExp(`${addStart ? \"^\" : \"\"}(?:${source})${addEnd ? \"$\" : \"\"}`, (_a = expr.flags) !== null && _a !== void 0 ? _a : expr.ignoreCase ? \"i\" : \"\");\n}\nexports.default = (editor)=>({\n \"editor.getCurrentPage\": ()=>{\n return editor.currentPage;\n },\n \"editor.getText\": ()=>{\n return editor.editorView?.state.sliceDoc();\n },\n \"editor.getCursor\": ()=>{\n return editor.editorView.state.selection.main.from;\n },\n \"editor.navigate\": async (name)=>{\n await editor.navigate(name);\n },\n \"editor.openUrl\": async (url)=>{\n window.open(url, \"_blank\").focus();\n },\n \"editor.insertAtPos\": (text, pos)=>{\n editor.editorView.dispatch({\n changes: {\n insert: text,\n from: pos\n }\n });\n },\n \"editor.replaceRange\": (from, to, text)=>{\n editor.editorView.dispatch({\n changes: {\n insert: text,\n from: from,\n to: to\n }\n });\n },\n \"editor.moveCursor\": (pos)=>{\n editor.editorView.dispatch({\n selection: {\n anchor: pos\n }\n });\n },\n \"editor.insertAtCursor\": (text)=>{\n let editorView = editor.editorView;\n let from = editorView.state.selection.main.from;\n editorView.dispatch({\n changes: {\n insert: text,\n from: from\n },\n selection: {\n anchor: from + text.length\n }\n });\n },\n \"editor.getSyntaxNodeUnderCursor\": ()=>{\n const editorState = editor.editorView.state;\n let selection = editorState.selection.main;\n if (selection.empty) {\n let node = _language.syntaxTree(editorState).resolveInner(selection.from);\n if (node) return {\n name: node.name,\n text: editorState.sliceDoc(node.from, node.to),\n from: node.from,\n to: node.to\n };\n }\n },\n \"editor.matchBefore\": (regexp)=>{\n const editorState = editor.editorView.state;\n let selection = editorState.selection.main;\n let from = selection.from;\n if (selection.empty) {\n let line = editorState.doc.lineAt(from);\n let start = Math.max(line.from, from - 250);\n let str = line.text.slice(start - line.from, from - line.from);\n let found = str.search(ensureAnchor(new RegExp(regexp), false));\n // console.log(\"Line\", line, start, str, new RegExp(regexp), found);\n return found < 0 ? null : {\n from: start + found,\n to: from,\n text: str.slice(found)\n };\n }\n return null;\n },\n \"editor.getSyntaxNodeAtPos\": (pos)=>{\n const editorState = editor.editorView.state;\n let node = _language.syntaxTree(editorState).resolveInner(pos);\n if (node) return {\n name: node.name,\n text: editorState.sliceDoc(node.from, node.to),\n from: node.from,\n to: node.to\n };\n },\n \"editor.dispatch\": (change)=>{\n editor.editorView.dispatch(change);\n },\n \"editor.prompt\": (message, defaultValue = \"\")=>{\n return prompt(message, defaultValue);\n }\n })\n;\n\n},{\"@codemirror/language\":\"70QHL\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"c4pla\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nexports.default = (indexer)=>({\n \"indexer.scanPrefixForPage\": async (pageName, keyPrefix)=>{\n return await indexer.scanPrefixForPage(pageName, keyPrefix);\n },\n \"indexer.scanPrefixGlobal\": async (keyPrefix)=>{\n return await indexer.scanPrefixGlobal(keyPrefix);\n },\n \"indexer.get\": async (pageName, key)=>{\n return await indexer.get(pageName, key);\n },\n \"indexer.set\": async (pageName, key, value)=>{\n await indexer.set(pageName, key, value);\n },\n \"indexer.batchSet\": async (pageName, kvs)=>{\n await indexer.batchSet(pageName, kvs);\n },\n \"indexer.delete\": async (pageName, key)=>{\n await indexer.delete(pageName, key);\n }\n })\n;\n\n},{\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"h23Wg\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nexports.default = (editor)=>({\n \"space.listPages\": ()=>{\n return editor.viewState.allPages;\n },\n \"space.reloadPageList\": async ()=>{\n await editor.loadPageList();\n },\n \"space.reindex\": async ()=>{\n await editor.indexer.reindexSpace(editor.space, editor);\n },\n \"space.readPage\": async (name)=>{\n return await editor.space.readPage(name);\n },\n \"space.writePage\": async (name, text)=>{\n return await editor.space.writePage(name, text);\n },\n \"space.deletePage\": async (name)=>{\n console.log(\"Clearing page index\", name);\n await editor.indexer.clearPageIndexForPage(name);\n // If we're deleting the current page, navigate to the start page\n if (editor.currentPage?.name === name) await editor.navigate(\"start\");\n // Remove page from open pages in editor\n editor.openPages.delete(name);\n console.log(\"Deleting page\");\n await editor.space.deletePage(name);\n }\n })\n;\n\n},{\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"91mo1\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"HttpRemoteSpace\", ()=>HttpRemoteSpace\n);\nvar _events = require(\"../../server/src/events\");\nclass HttpRemoteSpace {\n constructor(url, socket){\n this.url = url;\n // this.socket = socket;\n // socket.on(\"connect\", () => {\n // console.log(\"connected via SocketIO\", serverEvents.pageText);\n // });\n }\n async listPages() {\n let req = await fetch(this.url, {\n method: \"GET\"\n });\n return (await req.json()).map((meta)=>({\n name: meta.name,\n lastModified: new Date(meta.lastModified)\n })\n );\n }\n async openPage(name) {\n this.socket.on(_events.serverEvents.pageText, (pageName, text)=>{\n console.log(\"Got this\", pageName, text);\n });\n this.socket.emit(_events.serverEvents.openPage, \"start\");\n }\n async readPage(name) {\n let req = await fetch(`${this.url}/${name}`, {\n method: \"GET\"\n });\n return {\n text: await req.text(),\n meta: {\n lastModified: new Date(+req.headers.get(\"Last-Modified\")),\n name: name\n }\n };\n }\n async writePage(name, text) {\n let req = await fetch(`${this.url}/${name}`, {\n method: \"PUT\",\n body: text\n });\n // 201 (Created) means a new page was created\n return {\n lastModified: new Date(+req.headers.get(\"Last-Modified\")),\n name: name,\n created: req.status === 201\n };\n }\n async deletePage(name) {\n let req = await fetch(`${this.url}/${name}`, {\n method: \"DELETE\"\n });\n if (req.status !== 200) throw Error(`Failed to delete page: ${req.statusText}`);\n }\n async getPageMeta(name) {\n let req = await fetch(`${this.url}/${name}`, {\n method: \"OPTIONS\"\n });\n return {\n name: name,\n lastModified: new Date(+req.headers.get(\"Last-Modified\"))\n };\n }\n}\n\n},{\"../../server/src/events\":\"8hcI3\",\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}],\"8hcI3\":[function(require,module,exports) {\nvar parcelHelpers = require(\"@parcel/transformer-js/src/esmodule-helpers.js\");\nparcelHelpers.defineInteropFlag(exports);\nparcelHelpers.export(exports, \"serverEvents\", ()=>serverEvents\n);\nconst serverEvents = {\n openPage: \"openPage\",\n closePage: \"closePage\",\n pageText: \"pageText\"\n};\n\n},{\"@parcel/transformer-js/src/esmodule-helpers.js\":\"gkKU3\"}]},[\"kn9T2\",\"1lNQd\",\"4Bi4U\"], \"4Bi4U\", \"parcelRequire143c\")\n\n</script>\n </body>\n</html>\n"}