{"version":3,"file":"preact.min.module.js","sources":["../src/util.js","../src/options.js","../src/create-element.js","../src/component.js","../src/create-context.js","../src/constants.js","../src/diff/children.js","../src/diff/props.js","../src/diff/index.js","../src/render.js","../src/diff/catch-error.js","../src/clone-element.js","../src/cjs.js"],"sourcesContent":["import { EMPTY_ARR } from './constants';\n\nexport const isArray = Array.isArray;\n\n/**\n * Assign properties from `props` to `obj`\n * @template O, P The obj and props types\n * @param {O} obj The object to copy properties to\n * @param {P} props The object to copy properties from\n * @returns {O & P}\n */\nexport function assign(obj, props) {\n\t// @ts-ignore We change the type of `obj` to be `O & P`\n\tfor (let i in props) obj[i] = props[i];\n\treturn /** @type {O & P} */ (obj);\n}\n\n/**\n * Remove a child node from its parent if attached. This is a workaround for\n * IE11 which doesn't support `Element.prototype.remove()`. Using this function\n * is smaller than including a dedicated polyfill.\n * @param {Node} node The node to remove\n */\nexport function removeNode(node) {\n\tlet parentNode = node.parentNode;\n\tif (parentNode) parentNode.removeChild(node);\n}\n\nexport const slice = EMPTY_ARR.slice;\n","import { _catchError } from './diff/catch-error';\n\n/**\n * The `option` object can potentially contain callback functions\n * that are called during various stages of our renderer. This is the\n * foundation on which all our addons like `preact/debug`, `preact/compat`,\n * and `preact/hooks` are based on. See the `Options` type in `internal.d.ts`\n * for a full list of available option hooks (most editors/IDEs allow you to\n * ctrl+click or cmd+click on mac the type definition below).\n * @type {import('./internal').Options}\n */\nconst options = {\n\t_catchError\n};\n\nexport default options;\n","import { slice } from './util';\nimport options from './options';\n\nlet vnodeId = 0;\n\n/**\n * Create an virtual node (used for JSX)\n * @param {import('./internal').VNode[\"type\"]} type The node name or Component\n * constructor for this virtual node\n * @param {object | null | undefined} [props] The properties of the virtual node\n * @param {Array<import('.').ComponentChildren>} [children] The children of the virtual node\n * @returns {import('./internal').VNode}\n */\nexport function createElement(type, props, children) {\n\tlet normalizedProps = {},\n\t\tkey,\n\t\tref,\n\t\ti;\n\tfor (i in props) {\n\t\tif (i == 'key') key = props[i];\n\t\telse if (i == 'ref') ref = props[i];\n\t\telse normalizedProps[i] = props[i];\n\t}\n\n\tif (arguments.length > 2) {\n\t\tnormalizedProps.children =\n\t\t\targuments.length > 3 ? slice.call(arguments, 2) : children;\n\t}\n\n\t// If a Component VNode, check for and apply defaultProps\n\t// Note: type may be undefined in development, must never error here.\n\tif (typeof type == 'function' && type.defaultProps != null) {\n\t\tfor (i in type.defaultProps) {\n\t\t\tif (normalizedProps[i] === undefined) {\n\t\t\t\tnormalizedProps[i] = type.defaultProps[i];\n\t\t\t}\n\t\t}\n\t}\n\n\treturn createVNode(type, normalizedProps, key, ref, null);\n}\n\n/**\n * Create a VNode (used internally by Preact)\n * @param {import('./internal').VNode[\"type\"]} type The node name or Component\n * Constructor for this virtual node\n * @param {object | string | number | null} props The properties of this virtual node.\n * If this virtual node represents a text node, this is the text of the node (string or number).\n * @param {string | number | null} key The key for this virtual node, used when\n * diffing it against its children\n * @param {import('./internal').VNode[\"ref\"]} ref The ref property that will\n * receive a reference to its created child\n * @returns {import('./internal').VNode}\n */\nexport function createVNode(type, props, key, ref, original) {\n\t// V8 seems to be better at detecting type shapes if the object is allocated from the same call site\n\t// Do not inline into createElement and coerceToVNode!\n\tconst vnode = {\n\t\ttype,\n\t\tprops,\n\t\tkey,\n\t\tref,\n\t\t_children: null,\n\t\t_parent: null,\n\t\t_depth: 0,\n\t\t_dom: null,\n\t\t// _nextDom must be initialized to undefined b/c it will eventually\n\t\t// be set to dom.nextSibling which can return `null` and it is important\n\t\t// to be able to distinguish between an uninitialized _nextDom and\n\t\t// a _nextDom that has been set to `null`\n\t\t_nextDom: undefined,\n\t\t_component: null,\n\t\t_hydrating: null,\n\t\tconstructor: undefined,\n\t\t_original: original == null ? ++vnodeId : original\n\t};\n\n\t// Only invoke the vnode hook if this was *not* a direct copy:\n\tif (original == null && options.vnode != null) options.vnode(vnode);\n\n\treturn vnode;\n}\n\nexport function createRef() {\n\treturn { current: null };\n}\n\nexport function Fragment(props) {\n\treturn props.children;\n}\n\n/**\n * Check if a the argument is a valid Preact VNode.\n * @param {*} vnode\n * @returns {vnode is import('./internal').VNode}\n */\nexport const isValidElement = vnode =>\n\tvnode != null && vnode.constructor === undefined;\n","import { assign } from './util';\nimport { diff, commitRoot } from './diff/index';\nimport options from './options';\nimport { Fragment } from './create-element';\n\n/**\n * Base Component class. Provides `setState()` and `forceUpdate()`, which\n * trigger rendering\n * @param {object} props The initial component props\n * @param {object} context The initial context from parent components'\n * getChildContext\n */\nexport function Component(props, context) {\n\tthis.props = props;\n\tthis.context = context;\n}\n\n/**\n * Update component state and schedule a re-render.\n * @this {import('./internal').Component}\n * @param {object | ((s: object, p: object) => object)} update A hash of state\n * properties to update with new values or a function that given the current\n * state and props returns a new partial state\n * @param {() => void} [callback] A function to be called once component state is\n * updated\n */\nComponent.prototype.setState = function (update, callback) {\n\t// only clone state when copying to nextState the first time.\n\tlet s;\n\tif (this._nextState != null && this._nextState !== this.state) {\n\t\ts = this._nextState;\n\t} else {\n\t\ts = this._nextState = assign({}, this.state);\n\t}\n\n\tif (typeof update == 'function') {\n\t\t// Some libraries like `immer` mark the current state as readonly,\n\t\t// preventing us from mutating it, so we need to clone it. See #2716\n\t\tupdate = update(assign({}, s), this.props);\n\t}\n\n\tif (update) {\n\t\tassign(s, update);\n\t}\n\n\t// Skip update if updater function returned null\n\tif (update == null) return;\n\n\tif (this._vnode) {\n\t\tif (callback) {\n\t\t\tthis._stateCallbacks.push(callback);\n\t\t}\n\t\tenqueueRender(this);\n\t}\n};\n\n/**\n * Immediately perform a synchronous re-render of the component\n * @this {import('./internal').Component}\n * @param {() => void} [callback] A function to be called after component is\n * re-rendered\n */\nComponent.prototype.forceUpdate = function (callback) {\n\tif (this._vnode) {\n\t\t// Set render mode so that we can differentiate where the render request\n\t\t// is coming from. We need this because forceUpdate should never call\n\t\t// shouldComponentUpdate\n\t\tthis._force = true;\n\t\tif (callback) this._renderCallbacks.push(callback);\n\t\tenqueueRender(this);\n\t}\n};\n\n/**\n * Accepts `props` and `state`, and returns a new Virtual DOM tree to build.\n * Virtual DOM is generally constructed via [JSX](http://jasonformat.com/wtf-is-jsx).\n * @param {object} props Props (eg: JSX attributes) received from parent\n * element/component\n * @param {object} state The component's current state\n * @param {object} context Context object, as returned by the nearest\n * ancestor's `getChildContext()`\n * @returns {import('./index').ComponentChildren | void}\n */\nComponent.prototype.render = Fragment;\n\n/**\n * @param {import('./internal').VNode} vnode\n * @param {number | null} [childIndex]\n */\nexport function getDomSibling(vnode, childIndex) {\n\tif (childIndex == null) {\n\t\t// Use childIndex==null as a signal to resume the search from the vnode's sibling\n\t\treturn vnode._parent\n\t\t\t? getDomSibling(vnode._parent, vnode._parent._children.indexOf(vnode) + 1)\n\t\t\t: null;\n\t}\n\n\tlet sibling;\n\tfor (; childIndex < vnode._children.length; childIndex++) {\n\t\tsibling = vnode._children[childIndex];\n\n\t\tif (sibling != null && sibling._dom != null) {\n\t\t\t// Since updateParentDomPointers keeps _dom pointer correct,\n\t\t\t// we can rely on _dom to tell us if this subtree contains a\n\t\t\t// rendered DOM node, and what the first rendered DOM node is\n\t\t\treturn sibling._nextDom || sibling._dom;\n\t\t}\n\t}\n\n\t// If we get here, we have not found a DOM node in this vnode's children.\n\t// We must resume from this vnode's sibling (in it's parent _children array)\n\t// Only climb up and search the parent if we aren't searching through a DOM\n\t// VNode (meaning we reached the DOM parent of the original vnode that began\n\t// the search)\n\treturn typeof vnode.type == 'function' ? getDomSibling(vnode) : null;\n}\n\n/**\n * Trigger in-place re-rendering of a component.\n * @param {import('./internal').Component} component The component to rerender\n */\nfunction renderComponent(component) {\n\tlet vnode = component._vnode,\n\t\toldDom = vnode._dom,\n\t\tparentDom = component._parentDom;\n\n\tif (parentDom) {\n\t\tlet commitQueue = [],\n\t\t\trefQueue = [];\n\t\tconst oldVNode = assign({}, vnode);\n\t\toldVNode._original = vnode._original + 1;\n\n\t\tdiff(\n\t\t\tparentDom,\n\t\t\tvnode,\n\t\t\toldVNode,\n\t\t\tcomponent._globalContext,\n\t\t\tparentDom.ownerSVGElement !== undefined,\n\t\t\tvnode._hydrating != null ? [oldDom] : null,\n\t\t\tcommitQueue,\n\t\t\toldDom == null ? getDomSibling(vnode) : oldDom,\n\t\t\tvnode._hydrating,\n\t\t\trefQueue\n\t\t);\n\n\t\tcommitRoot(commitQueue, vnode, refQueue);\n\n\t\tif (vnode._dom != oldDom) {\n\t\t\tupdateParentDomPointers(vnode);\n\t\t}\n\t}\n}\n\n/**\n * @param {import('./internal').VNode} vnode\n */\nfunction updateParentDomPointers(vnode) {\n\tif ((vnode = vnode._parent) != null && vnode._component != null) {\n\t\tvnode._dom = vnode._component.base = null;\n\t\tfor (let i = 0; i < vnode._children.length; i++) {\n\t\t\tlet child = vnode._children[i];\n\t\t\tif (child != null && child._dom != null) {\n\t\t\t\tvnode._dom = vnode._component.base = child._dom;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\treturn updateParentDomPointers(vnode);\n\t}\n}\n\n/**\n * The render queue\n * @type {Array<import('./internal').Component>}\n */\nlet rerenderQueue = [];\n\n/*\n * The value of `Component.debounce` must asynchronously invoke the passed in callback. It is\n * important that contributors to Preact can consistently reason about what calls to `setState`, etc.\n * do, and when their effects will be applied. See the links below for some further reading on designing\n * asynchronous APIs.\n * * [Designing APIs for Asynchrony](https://blog.izs.me/2013/08/designing-apis-for-asynchrony)\n * * [Callbacks synchronous and asynchronous](https://blog.ometer.com/2011/07/24/callbacks-synchronous-and-asynchronous/)\n */\n\nlet prevDebounce;\n\nconst defer =\n\ttypeof Promise == 'function'\n\t\t? Promise.prototype.then.bind(Promise.resolve())\n\t\t: setTimeout;\n\n/**\n * Enqueue a rerender of a component\n * @param {import('./internal').Component} c The component to rerender\n */\nexport function enqueueRender(c) {\n\tif (\n\t\t(!c._dirty &&\n\t\t\t(c._dirty = true) &&\n\t\t\trerenderQueue.push(c) &&\n\t\t\t!process._rerenderCount++) ||\n\t\tprevDebounce !== options.debounceRendering\n\t) {\n\t\tprevDebounce = options.debounceRendering;\n\t\t(prevDebounce || defer)(process);\n\t}\n}\n\n/**\n * @param {import('./internal').Component} a\n * @param {import('./internal').Component} b\n */\nconst depthSort = (a, b) => a._vnode._depth - b._vnode._depth;\n\n/** Flush the render queue by rerendering all queued components */\nfunction process() {\n\tlet c;\n\trerenderQueue.sort(depthSort);\n\t// Don't update `renderCount` yet. Keep its value non-zero to prevent unnecessary\n\t// process() calls from getting scheduled while `queue` is still being consumed.\n\twhile ((c = rerenderQueue.shift())) {\n\t\tif (c._dirty) {\n\t\t\tlet renderQueueLength = rerenderQueue.length;\n\t\t\trenderComponent(c);\n\t\t\tif (rerenderQueue.length > renderQueueLength) {\n\t\t\t\t// When i.e. rerendering a provider additional new items can be injected, we want to\n\t\t\t\t// keep the order from top to bottom with those new items so we can handle them in a\n\t\t\t\t// single pass\n\t\t\t\trerenderQueue.sort(depthSort);\n\t\t\t}\n\t\t}\n\t}\n\tprocess._rerenderCount = 0;\n}\n\nprocess._rerenderCount = 0;\n","import { enqueueRender } from './component';\n\nexport let i = 0;\n\nexport function createContext(defaultValue, contextId) {\n\tcontextId = '__cC' + i++;\n\n\tconst context = {\n\t\t_id: contextId,\n\t\t_defaultValue: defaultValue,\n\t\t/** @type {import('./internal').FunctionComponent} */\n\t\tConsumer(props, contextValue) {\n\t\t\t// return props.children(\n\t\t\t// \tcontext[contextId] ? context[contextId].props.value : defaultValue\n\t\t\t// );\n\t\t\treturn props.children(contextValue);\n\t\t},\n\t\t/** @type {import('./internal').FunctionComponent} */\n\t\tProvider(props) {\n\t\t\tif (!this.getChildContext) {\n\t\t\t\t/** @type {import('./internal').Component[]} */\n\t\t\t\tlet subs = [];\n\t\t\t\tlet ctx = {};\n\t\t\t\tctx[contextId] = this;\n\n\t\t\t\tthis.getChildContext = () => ctx;\n\n\t\t\t\tthis.shouldComponentUpdate = function (_props) {\n\t\t\t\t\tif (this.props.value !== _props.value) {\n\t\t\t\t\t\t// I think the forced value propagation here was only needed when `options.debounceRendering` was being bypassed:\n\t\t\t\t\t\t// https://github.com/preactjs/preact/commit/4d339fb803bea09e9f198abf38ca1bf8ea4b7771#diff-54682ce380935a717e41b8bfc54737f6R358\n\t\t\t\t\t\t// In those cases though, even with the value corrected, we're double-rendering all nodes.\n\t\t\t\t\t\t// It might be better to just tell folks not to use force-sync mode.\n\t\t\t\t\t\t// Currently, using `useContext()` in a class component will overwrite its `this.context` value.\n\t\t\t\t\t\t// subs.some(c => {\n\t\t\t\t\t\t// \tc.context = _props.value;\n\t\t\t\t\t\t// \tenqueueRender(c);\n\t\t\t\t\t\t// });\n\n\t\t\t\t\t\t// subs.some(c => {\n\t\t\t\t\t\t// \tc.context[contextId] = _props.value;\n\t\t\t\t\t\t// \tenqueueRender(c);\n\t\t\t\t\t\t// });\n\t\t\t\t\t\tsubs.some(c => {\n\t\t\t\t\t\t\tc._force = true;\n\t\t\t\t\t\t\tenqueueRender(c);\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t};\n\n\t\t\t\tthis.sub = c => {\n\t\t\t\t\tsubs.push(c);\n\t\t\t\t\tlet old = c.componentWillUnmount;\n\t\t\t\t\tc.componentWillUnmount = () => {\n\t\t\t\t\t\tsubs.splice(subs.indexOf(c), 1);\n\t\t\t\t\t\tif (old) old.call(c);\n\t\t\t\t\t};\n\t\t\t\t};\n\t\t\t}\n\n\t\t\treturn props.children;\n\t\t}\n\t};\n\n\t// Devtools needs access to the context object when it\n\t// encounters a Provider. This is necessary to support\n\t// setting `displayName` on the context object instead\n\t// of on the component itself. See:\n\t// https://reactjs.org/docs/context.html#contextdisplayname\n\n\treturn (context.Provider._contextRef = context.Consumer.contextType =\n\t\tcontext);\n}\n","export const EMPTY_OBJ = {};\nexport const EMPTY_ARR = [];\nexport const IS_NON_DIMENSIONAL =\n\t/acit|ex(?:s|g|n|p|$)|rph|grid|ows|mnc|ntw|ine[ch]|zoo|^ord|itera/i;\n","import { diff, unmount, applyRef } from './index';\nimport { createVNode, Fragment } from '../create-element';\nimport { EMPTY_OBJ, EMPTY_ARR } from '../constants';\nimport { isArray } from '../util';\nimport { getDomSibling } from '../component';\n\n/**\n * Diff the children of a virtual node\n * @param {import('../internal').PreactElement} parentDom The DOM element whose\n * children are being diffed\n * @param {import('../internal').ComponentChildren[]} renderResult\n * @param {import('../internal').VNode} newParentVNode The new virtual\n * node whose children should be diff'ed against oldParentVNode\n * @param {import('../internal').VNode} oldParentVNode The old virtual\n * node whose children should be diff'ed against newParentVNode\n * @param {object} globalContext The current context object - modified by getChildContext\n * @param {boolean} isSvg Whether or not this DOM node is an SVG node\n * @param {Array<import('../internal').PreactElement>} excessDomChildren\n * @param {Array<import('../internal').Component>} commitQueue List of components\n * which have callbacks to invoke in commitRoot\n * @param {import('../internal').PreactElement} oldDom The current attached DOM\n * element any new dom elements should be placed around. Likely `null` on first\n * render (except when hydrating). Can be a sibling DOM element when diffing\n * Fragments that have siblings. In most cases, it starts out as `oldChildren[0]._dom`.\n * @param {boolean} isHydrating Whether or not we are in hydration\n * @param {Array<any>} refQueue an array of elements needed to invoke refs\n */\nexport function diffChildren(\n\tparentDom,\n\trenderResult,\n\tnewParentVNode,\n\toldParentVNode,\n\tglobalContext,\n\tisSvg,\n\texcessDomChildren,\n\tcommitQueue,\n\toldDom,\n\tisHydrating,\n\trefQueue\n) {\n\tlet i,\n\t\tj,\n\t\toldVNode,\n\t\tchildVNode,\n\t\tnewDom,\n\t\tfirstChildDom,\n\t\tskew = 0;\n\n\t// This is a compression of oldParentVNode!=null && oldParentVNode != EMPTY_OBJ && oldParentVNode._children || EMPTY_ARR\n\t// as EMPTY_OBJ._children should be `undefined`.\n\tlet oldChildren = (oldParentVNode && oldParentVNode._children) || EMPTY_ARR;\n\n\tlet oldChildrenLength = oldChildren.length,\n\t\tremainingOldChildren = oldChildrenLength,\n\t\tnewChildrenLength = renderResult.length;\n\n\tnewParentVNode._children = [];\n\tfor (i = 0; i < newChildrenLength; i++) {\n\t\tchildVNode = renderResult[i];\n\n\t\tif (\n\t\t\tchildVNode == null ||\n\t\t\ttypeof childVNode == 'boolean' ||\n\t\t\ttypeof childVNode == 'function'\n\t\t) {\n\t\t\tchildVNode = newParentVNode._children[i] = null;\n\t\t}\n\t\t// If this newVNode is being reused (e.g. <div>{reuse}{reuse}</div>) in the same diff,\n\t\t// or we are rendering a component (e.g. setState) copy the oldVNodes so it can have\n\t\t// it's own DOM & etc. pointers\n\t\telse if (\n\t\t\ttypeof childVNode == 'string' ||\n\t\t\ttypeof childVNode == 'number' ||\n\t\t\t// eslint-disable-next-line valid-typeof\n\t\t\ttypeof childVNode == 'bigint'\n\t\t) {\n\t\t\tchildVNode = newParentVNode._children[i] = createVNode(\n\t\t\t\tnull,\n\t\t\t\tchildVNode,\n\t\t\t\tnull,\n\t\t\t\tnull,\n\t\t\t\tchildVNode\n\t\t\t);\n\t\t} else if (isArray(childVNode)) {\n\t\t\tchildVNode = newParentVNode._children[i] = createVNode(\n\t\t\t\tFragment,\n\t\t\t\t{ children: childVNode },\n\t\t\t\tnull,\n\t\t\t\tnull,\n\t\t\t\tnull\n\t\t\t);\n\t\t} else if (childVNode._depth > 0) {\n\t\t\t// VNode is already in use, clone it. This can happen in the following\n\t\t\t// scenario:\n\t\t\t//   const reuse = <div />\n\t\t\t//   <div>{reuse}<span />{reuse}</div>\n\t\t\tchildVNode = newParentVNode._children[i] = createVNode(\n\t\t\t\tchildVNode.type,\n\t\t\t\tchildVNode.props,\n\t\t\t\tchildVNode.key,\n\t\t\t\tchildVNode.ref ? childVNode.ref : null,\n\t\t\t\tchildVNode._original\n\t\t\t);\n\t\t} else {\n\t\t\tchildVNode = newParentVNode._children[i] = childVNode;\n\t\t}\n\n\t\t// Terser removes the `continue` here and wraps the loop body\n\t\t// in a `if (childVNode) { ... } condition\n\t\tif (childVNode == null) {\n\t\t\toldVNode = oldChildren[i];\n\t\t\tif (oldVNode && oldVNode.key == null && oldVNode._dom) {\n\t\t\t\tif (oldVNode._dom == oldDom) {\n\t\t\t\t\toldVNode._parent = oldParentVNode;\n\t\t\t\t\toldDom = getDomSibling(oldVNode);\n\t\t\t\t}\n\n\t\t\t\tunmount(oldVNode, oldVNode, false);\n\t\t\t\toldChildren[i] = null;\n\t\t\t}\n\n\t\t\tcontinue;\n\t\t}\n\n\t\tchildVNode._parent = newParentVNode;\n\t\tchildVNode._depth = newParentVNode._depth + 1;\n\n\t\tlet skewedIndex = i + skew;\n\t\tconst matchingIndex = findMatchingIndex(\n\t\t\tchildVNode,\n\t\t\toldChildren,\n\t\t\tskewedIndex,\n\t\t\tremainingOldChildren\n\t\t);\n\n\t\tif (matchingIndex === -1) {\n\t\t\toldVNode = EMPTY_OBJ;\n\t\t} else {\n\t\t\toldVNode = oldChildren[matchingIndex] || EMPTY_OBJ;\n\t\t\toldChildren[matchingIndex] = undefined;\n\t\t\tremainingOldChildren--;\n\t\t}\n\n\t\t// Morph the old element into the new one, but don't append it to the dom yet\n\t\tdiff(\n\t\t\tparentDom,\n\t\t\tchildVNode,\n\t\t\toldVNode,\n\t\t\tglobalContext,\n\t\t\tisSvg,\n\t\t\texcessDomChildren,\n\t\t\tcommitQueue,\n\t\t\toldDom,\n\t\t\tisHydrating,\n\t\t\trefQueue\n\t\t);\n\n\t\tnewDom = childVNode._dom;\n\t\tif ((j = childVNode.ref) && oldVNode.ref != j) {\n\t\t\tif (oldVNode.ref) {\n\t\t\t\tapplyRef(oldVNode.ref, null, childVNode);\n\t\t\t}\n\t\t\trefQueue.push(j, childVNode._component || newDom, childVNode);\n\t\t}\n\n\t\tif (newDom != null) {\n\t\t\tif (firstChildDom == null) {\n\t\t\t\tfirstChildDom = newDom;\n\t\t\t}\n\n\t\t\tlet isMounting = oldVNode === EMPTY_OBJ || oldVNode._original === null;\n\t\t\tif (isMounting) {\n\t\t\t\tif (matchingIndex == -1) {\n\t\t\t\t\tskew--;\n\t\t\t\t}\n\t\t\t} else if (matchingIndex !== skewedIndex) {\n\t\t\t\tif (matchingIndex === skewedIndex + 1) {\n\t\t\t\t\tskew++;\n\t\t\t\t} else if (matchingIndex > skewedIndex) {\n\t\t\t\t\tif (remainingOldChildren > newChildrenLength - skewedIndex) {\n\t\t\t\t\t\tskew += matchingIndex - skewedIndex;\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// ### Change from keyed: I think this was missing from the algo...\n\t\t\t\t\t\tskew--;\n\t\t\t\t\t}\n\t\t\t\t} else if (matchingIndex < skewedIndex) {\n\t\t\t\t\tif (matchingIndex == skewedIndex - 1) {\n\t\t\t\t\t\tskew = matchingIndex - skewedIndex;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tskew = 0;\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tskew = 0;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tskewedIndex = i + skew;\n\n\t\t\tif (\n\t\t\t\ttypeof childVNode.type == 'function' &&\n\t\t\t\t(matchingIndex !== skewedIndex ||\n\t\t\t\t\toldVNode._children === childVNode._children)\n\t\t\t) {\n\t\t\t\toldDom = reorderChildren(childVNode, oldDom, parentDom);\n\t\t\t} else if (\n\t\t\t\ttypeof childVNode.type != 'function' &&\n\t\t\t\t(matchingIndex !== skewedIndex || isMounting)\n\t\t\t) {\n\t\t\t\toldDom = placeChild(parentDom, newDom, oldDom);\n\t\t\t} else if (childVNode._nextDom !== undefined) {\n\t\t\t\t// Only Fragments or components that return Fragment like VNodes will\n\t\t\t\t// have a non-undefined _nextDom. Continue the diff from the sibling\n\t\t\t\t// of last DOM child of this child VNode\n\t\t\t\toldDom = childVNode._nextDom;\n\n\t\t\t\t// Eagerly cleanup _nextDom. We don't need to persist the value because\n\t\t\t\t// it is only used by `diffChildren` to determine where to resume the diff after\n\t\t\t\t// diffing Components and Fragments. Once we store it the nextDOM local var, we\n\t\t\t\t// can clean up the property\n\t\t\t\tchildVNode._nextDom = undefined;\n\t\t\t} else {\n\t\t\t\toldDom = newDom.nextSibling;\n\t\t\t}\n\n\t\t\tif (typeof newParentVNode.type == 'function') {\n\t\t\t\t// Because the newParentVNode is Fragment-like, we need to set it's\n\t\t\t\t// _nextDom property to the nextSibling of its last child DOM node.\n\t\t\t\t//\n\t\t\t\t// `oldDom` contains the correct value here because if the last child\n\t\t\t\t// is a Fragment-like, then oldDom has already been set to that child's _nextDom.\n\t\t\t\t// If the last child is a DOM VNode, then oldDom will be set to that DOM\n\t\t\t\t// node's nextSibling.\n\t\t\t\tnewParentVNode._nextDom = oldDom;\n\t\t\t}\n\t\t}\n\t}\n\n\tnewParentVNode._dom = firstChildDom;\n\n\t// Remove remaining oldChildren if there are any.\n\tfor (i = oldChildrenLength; i--; ) {\n\t\tif (oldChildren[i] != null) {\n\t\t\tif (\n\t\t\t\ttypeof newParentVNode.type == 'function' &&\n\t\t\t\toldChildren[i]._dom != null &&\n\t\t\t\toldChildren[i]._dom == newParentVNode._nextDom\n\t\t\t) {\n\t\t\t\t// If the newParentVNode.__nextDom points to a dom node that is about to\n\t\t\t\t// be unmounted, then get the next sibling of that vnode and set\n\t\t\t\t// _nextDom to it\n\n\t\t\t\tnewParentVNode._nextDom = oldChildren[i]._dom.nextSibling;\n\t\t\t}\n\n\t\t\tunmount(oldChildren[i], oldChildren[i]);\n\t\t}\n\t}\n}\n\nfunction reorderChildren(childVNode, oldDom, parentDom) {\n\t// Note: VNodes in nested suspended trees may be missing _children.\n\tlet c = childVNode._children;\n\n\tlet tmp = 0;\n\tfor (; c && tmp < c.length; tmp++) {\n\t\tlet vnode = c[tmp];\n\t\tif (vnode) {\n\t\t\t// We typically enter this code path on sCU bailout, where we copy\n\t\t\t// oldVNode._children to newVNode._children. If that is the case, we need\n\t\t\t// to update the old children's _parent pointer to point to the newVNode\n\t\t\t// (childVNode here).\n\t\t\tvnode._parent = childVNode;\n\n\t\t\tif (typeof vnode.type == 'function') {\n\t\t\t\toldDom = reorderChildren(vnode, oldDom, parentDom);\n\t\t\t} else {\n\t\t\t\toldDom = placeChild(parentDom, vnode._dom, oldDom);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn oldDom;\n}\n\n/**\n * Flatten and loop through the children of a virtual node\n * @param {import('../index').ComponentChildren} children The unflattened\n * children of a virtual node\n * @returns {import('../internal').VNode[]}\n */\nexport function toChildArray(children, out) {\n\tout = out || [];\n\tif (children == null || typeof children == 'boolean') {\n\t} else if (isArray(children)) {\n\t\tchildren.some(child => {\n\t\t\ttoChildArray(child, out);\n\t\t});\n\t} else {\n\t\tout.push(children);\n\t}\n\treturn out;\n}\n\nfunction placeChild(parentDom, newDom, oldDom) {\n\tif (oldDom == null || oldDom.parentNode !== parentDom) {\n\t\tparentDom.insertBefore(newDom, null);\n\t} else if (newDom != oldDom || newDom.parentNode == null) {\n\t\tparentDom.insertBefore(newDom, oldDom);\n\t}\n\n\treturn newDom.nextSibling;\n}\n\n/**\n * @param {import('../internal').VNode | string} childVNode\n * @param {import('../internal').VNode[]} oldChildren\n * @param {number} skewedIndex\n * @param {number} remainingOldChildren\n * @returns {number}\n */\nfunction findMatchingIndex(\n\tchildVNode,\n\toldChildren,\n\tskewedIndex,\n\tremainingOldChildren\n) {\n\tconst key = childVNode.key;\n\tconst type = childVNode.type;\n\tlet x = skewedIndex - 1;\n\tlet y = skewedIndex + 1;\n\tlet oldVNode = oldChildren[skewedIndex];\n\n\tif (\n\t\toldVNode === null ||\n\t\t(oldVNode && key == oldVNode.key && type === oldVNode.type)\n\t) {\n\t\treturn skewedIndex;\n\t} else if (remainingOldChildren > (oldVNode != null ? 1 : 0)) {\n\t\twhile (x >= 0 || y < oldChildren.length) {\n\t\t\tif (x >= 0) {\n\t\t\t\toldVNode = oldChildren[x];\n\t\t\t\tif (oldVNode && key == oldVNode.key && type === oldVNode.type) {\n\t\t\t\t\treturn x;\n\t\t\t\t}\n\t\t\t\tx--;\n\t\t\t}\n\n\t\t\tif (y < oldChildren.length) {\n\t\t\t\toldVNode = oldChildren[y];\n\t\t\t\tif (oldVNode && key == oldVNode.key && type === oldVNode.type) {\n\t\t\t\t\treturn y;\n\t\t\t\t}\n\t\t\t\ty++;\n\t\t\t}\n\t\t}\n\t}\n\n\treturn -1;\n}\n","import { IS_NON_DIMENSIONAL } from '../constants';\nimport options from '../options';\n\n/**\n * Diff the old and new properties of a VNode and apply changes to the DOM node\n * @param {import('../internal').PreactElement} dom The DOM node to apply\n * changes to\n * @param {object} newProps The new props\n * @param {object} oldProps The old props\n * @param {boolean} isSvg Whether or not this node is an SVG node\n * @param {boolean} hydrate Whether or not we are in hydration mode\n */\nexport function diffProps(dom, newProps, oldProps, isSvg, hydrate) {\n\tlet i;\n\n\tfor (i in oldProps) {\n\t\tif (i !== 'children' && i !== 'key' && !(i in newProps)) {\n\t\t\tsetProperty(dom, i, null, oldProps[i], isSvg);\n\t\t}\n\t}\n\n\tfor (i in newProps) {\n\t\tif (\n\t\t\t(!hydrate || typeof newProps[i] == 'function') &&\n\t\t\ti !== 'children' &&\n\t\t\ti !== 'key' &&\n\t\t\ti !== 'value' &&\n\t\t\ti !== 'checked' &&\n\t\t\toldProps[i] !== newProps[i]\n\t\t) {\n\t\t\tsetProperty(dom, i, newProps[i], oldProps[i], isSvg);\n\t\t}\n\t}\n}\n\nfunction setStyle(style, key, value) {\n\tif (key[0] === '-') {\n\t\tstyle.setProperty(key, value == null ? '' : value);\n\t} else if (value == null) {\n\t\tstyle[key] = '';\n\t} else if (typeof value != 'number' || IS_NON_DIMENSIONAL.test(key)) {\n\t\tstyle[key] = value;\n\t} else {\n\t\tstyle[key] = value + 'px';\n\t}\n}\n\n/**\n * Set a property value on a DOM node\n * @param {import('../internal').PreactElement} dom The DOM node to modify\n * @param {string} name The name of the property to set\n * @param {*} value The value to set the property to\n * @param {*} oldValue The old value the property had\n * @param {boolean} isSvg Whether or not this DOM node is an SVG node or not\n */\nexport function setProperty(dom, name, value, oldValue, isSvg) {\n\tlet useCapture;\n\n\to: if (name === 'style') {\n\t\tif (typeof value == 'string') {\n\t\t\tdom.style.cssText = value;\n\t\t} else {\n\t\t\tif (typeof oldValue == 'string') {\n\t\t\t\tdom.style.cssText = oldValue = '';\n\t\t\t}\n\n\t\t\tif (oldValue) {\n\t\t\t\tfor (name in oldValue) {\n\t\t\t\t\tif (!(value && name in value)) {\n\t\t\t\t\t\tsetStyle(dom.style, name, '');\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (value) {\n\t\t\t\tfor (name in value) {\n\t\t\t\t\tif (!oldValue || value[name] !== oldValue[name]) {\n\t\t\t\t\t\tsetStyle(dom.style, name, value[name]);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\t// Benchmark for comparison: https://esbench.com/bench/574c954bdb965b9a00965ac6\n\telse if (name[0] === 'o' && name[1] === 'n') {\n\t\tuseCapture =\n\t\t\tname !== (name = name.replace(/(PointerCapture)$|Capture$/, '$1'));\n\n\t\t// Infer correct casing for DOM built-in events:\n\t\tif (name.toLowerCase() in dom) name = name.toLowerCase().slice(2);\n\t\telse name = name.slice(2);\n\n\t\tif (!dom._listeners) dom._listeners = {};\n\t\tdom._listeners[name + useCapture] = value;\n\n\t\tif (value) {\n\t\t\tif (!oldValue) {\n\t\t\t\tvalue._attached = Date.now();\n\t\t\t\tconst handler = useCapture ? eventProxyCapture : eventProxy;\n\t\t\t\tdom.addEventListener(name, handler, useCapture);\n\t\t\t} else {\n\t\t\t\tvalue._attached = oldValue._attached;\n\t\t\t}\n\t\t} else {\n\t\t\tconst handler = useCapture ? eventProxyCapture : eventProxy;\n\t\t\tdom.removeEventListener(name, handler, useCapture);\n\t\t}\n\t} else if (name !== 'dangerouslySetInnerHTML') {\n\t\tif (isSvg) {\n\t\t\t// Normalize incorrect prop usage for SVG:\n\t\t\t// - xlink:href / xlinkHref --> href (xlink:href was removed from SVG and isn't needed)\n\t\t\t// - className --> class\n\t\t\tname = name.replace(/xlink(H|:h)/, 'h').replace(/sName$/, 's');\n\t\t} else if (\n\t\t\tname !== 'width' &&\n\t\t\tname !== 'height' &&\n\t\t\tname !== 'href' &&\n\t\t\tname !== 'list' &&\n\t\t\tname !== 'form' &&\n\t\t\t// Default value in browsers is `-1` and an empty string is\n\t\t\t// cast to `0` instead\n\t\t\tname !== 'tabIndex' &&\n\t\t\tname !== 'download' &&\n\t\t\tname !== 'rowSpan' &&\n\t\t\tname !== 'colSpan' &&\n\t\t\tname !== 'role' &&\n\t\t\tname in dom\n\t\t) {\n\t\t\ttry {\n\t\t\t\tdom[name] = value == null ? '' : value;\n\t\t\t\t// labelled break is 1b smaller here than a return statement (sorry)\n\t\t\t\tbreak o;\n\t\t\t} catch (e) {}\n\t\t}\n\n\t\t// aria- and data- attributes have no boolean representation.\n\t\t// A `false` value is different from the attribute not being\n\t\t// present, so we can't remove it. For non-boolean aria\n\t\t// attributes we could treat false as a removal, but the\n\t\t// amount of exceptions would cost too many bytes. On top of\n\t\t// that other frameworks generally stringify `false`.\n\n\t\tif (typeof value === 'function') {\n\t\t\t// never serialize functions as attribute values\n\t\t} else if (value != null && (value !== false || name[4] === '-')) {\n\t\t\tdom.setAttribute(name, value);\n\t\t} else {\n\t\t\tdom.removeAttribute(name);\n\t\t}\n\t}\n}\n\n/**\n * Proxy an event to hooked event handlers\n * @param {Event} e The event object from the browser\n * @private\n */\nfunction eventProxy(e) {\n\tconst eventHandler = this._listeners[e.type + false];\n\t/**\n\t * This trick is inspired by Vue https://github.com/vuejs/core/blob/main/packages/runtime-dom/src/modules/events.ts#L90-L101\n\t * when the dom performs an event it leaves micro-ticks in between bubbling up which means that an event can trigger on a newly\n\t * created DOM-node while the event bubbles up, this can cause quirky behavior as seen in https://github.com/preactjs/preact/issues/3927\n\t */\n\tif (!e._dispatched) {\n\t\t// When an event has no _dispatched we know this is the first event-target in the chain\n\t\t// so we set the initial dispatched time.\n\t\te._dispatched = Date.now();\n\t\t// When the _dispatched is smaller than the time when the targetted event handler was attached\n\t\t// we know we have bubbled up to an element that was added during patching the dom.\n\t} else if (e._dispatched <= eventHandler._attached) {\n\t\treturn;\n\t}\n\treturn eventHandler(options.event ? options.event(e) : e);\n}\n\nfunction eventProxyCapture(e) {\n\treturn this._listeners[e.type + true](options.event ? options.event(e) : e);\n}\n","import { EMPTY_OBJ } from '../constants';\nimport { Component, getDomSibling } from '../component';\nimport { Fragment } from '../create-element';\nimport { diffChildren } from './children';\nimport { diffProps, setProperty } from './props';\nimport { assign, isArray, removeNode, slice } from '../util';\nimport options from '../options';\n\n/**\n * Diff two virtual nodes and apply proper changes to the DOM\n * @param {import('../internal').PreactElement} parentDom The parent of the DOM element\n * @param {import('../internal').VNode} newVNode The new virtual node\n * @param {import('../internal').VNode} oldVNode The old virtual node\n * @param {object} globalContext The current context object. Modified by getChildContext\n * @param {boolean} isSvg Whether or not this element is an SVG node\n * @param {Array<import('../internal').PreactElement>} excessDomChildren\n * @param {Array<import('../internal').Component>} commitQueue List of components\n * which have callbacks to invoke in commitRoot\n * @param {import('../internal').PreactElement} oldDom The current attached DOM\n * element any new dom elements should be placed around. Likely `null` on first\n * render (except when hydrating). Can be a sibling DOM element when diffing\n * Fragments that have siblings. In most cases, it starts out as `oldChildren[0]._dom`.\n * @param {boolean} isHydrating Whether or not we are in hydration\n * @param {Array<any>} refQueue an array of elements needed to invoke refs\n */\nexport function diff(\n\tparentDom,\n\tnewVNode,\n\toldVNode,\n\tglobalContext,\n\tisSvg,\n\texcessDomChildren,\n\tcommitQueue,\n\toldDom,\n\tisHydrating,\n\trefQueue\n) {\n\tlet tmp,\n\t\tnewType = newVNode.type;\n\n\t// When passing through createElement it assigns the object\n\t// constructor as undefined. This to prevent JSON-injection.\n\tif (newVNode.constructor !== undefined) return null;\n\n\t// If the previous diff bailed out, resume creating/hydrating.\n\tif (oldVNode._hydrating != null) {\n\t\tisHydrating = oldVNode._hydrating;\n\t\toldDom = newVNode._dom = oldVNode._dom;\n\t\t// if we resume, we want the tree to be \"unlocked\"\n\t\tnewVNode._hydrating = null;\n\t\texcessDomChildren = [oldDom];\n\t}\n\n\tif ((tmp = options._diff)) tmp(newVNode);\n\n\touter: if (typeof newType == 'function') {\n\t\ttry {\n\t\t\tlet c, isNew, oldProps, oldState, snapshot, clearProcessingException;\n\t\t\tlet newProps = newVNode.props;\n\n\t\t\t// Necessary for createContext api. Setting this property will pass\n\t\t\t// the context value as `this.context` just for this component.\n\t\t\ttmp = newType.contextType;\n\t\t\tlet provider = tmp && globalContext[tmp._id];\n\t\t\tlet componentContext = tmp\n\t\t\t\t? provider\n\t\t\t\t\t? provider.props.value\n\t\t\t\t\t: tmp._defaultValue\n\t\t\t\t: globalContext;\n\n\t\t\t// Get component and set it to `c`\n\t\t\tif (oldVNode._component) {\n\t\t\t\tc = newVNode._component = oldVNode._component;\n\t\t\t\tclearProcessingException = c._processingException = c._pendingError;\n\t\t\t} else {\n\t\t\t\t// Instantiate the new component\n\t\t\t\tif ('prototype' in newType && newType.prototype.render) {\n\t\t\t\t\t// @ts-ignore The check above verifies that newType is suppose to be constructed\n\t\t\t\t\tnewVNode._component = c = new newType(newProps, componentContext); // eslint-disable-line new-cap\n\t\t\t\t} else {\n\t\t\t\t\t// @ts-ignore Trust me, Component implements the interface we want\n\t\t\t\t\tnewVNode._component = c = new Component(newProps, componentContext);\n\t\t\t\t\tc.constructor = newType;\n\t\t\t\t\tc.render = doRender;\n\t\t\t\t}\n\t\t\t\tif (provider) provider.sub(c);\n\n\t\t\t\tc.props = newProps;\n\t\t\t\tif (!c.state) c.state = {};\n\t\t\t\tc.context = componentContext;\n\t\t\t\tc._globalContext = globalContext;\n\t\t\t\tisNew = c._dirty = true;\n\t\t\t\tc._renderCallbacks = [];\n\t\t\t\tc._stateCallbacks = [];\n\t\t\t}\n\n\t\t\t// Invoke getDerivedStateFromProps\n\t\t\tif (c._nextState == null) {\n\t\t\t\tc._nextState = c.state;\n\t\t\t}\n\n\t\t\tif (newType.getDerivedStateFromProps != null) {\n\t\t\t\tif (c._nextState == c.state) {\n\t\t\t\t\tc._nextState = assign({}, c._nextState);\n\t\t\t\t}\n\n\t\t\t\tassign(\n\t\t\t\t\tc._nextState,\n\t\t\t\t\tnewType.getDerivedStateFromProps(newProps, c._nextState)\n\t\t\t\t);\n\t\t\t}\n\n\t\t\toldProps = c.props;\n\t\t\toldState = c.state;\n\t\t\tc._vnode = newVNode;\n\n\t\t\t// Invoke pre-render lifecycle methods\n\t\t\tif (isNew) {\n\t\t\t\tif (\n\t\t\t\t\tnewType.getDerivedStateFromProps == null &&\n\t\t\t\t\tc.componentWillMount != null\n\t\t\t\t) {\n\t\t\t\t\tc.componentWillMount();\n\t\t\t\t}\n\n\t\t\t\tif (c.componentDidMount != null) {\n\t\t\t\t\tc._renderCallbacks.push(c.componentDidMount);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif (\n\t\t\t\t\tnewType.getDerivedStateFromProps == null &&\n\t\t\t\t\tnewProps !== oldProps &&\n\t\t\t\t\tc.componentWillReceiveProps != null\n\t\t\t\t) {\n\t\t\t\t\tc.componentWillReceiveProps(newProps, componentContext);\n\t\t\t\t}\n\n\t\t\t\tif (\n\t\t\t\t\t!c._force &&\n\t\t\t\t\t((c.shouldComponentUpdate != null &&\n\t\t\t\t\t\tc.shouldComponentUpdate(\n\t\t\t\t\t\t\tnewProps,\n\t\t\t\t\t\t\tc._nextState,\n\t\t\t\t\t\t\tcomponentContext\n\t\t\t\t\t\t) === false) ||\n\t\t\t\t\t\tnewVNode._original === oldVNode._original)\n\t\t\t\t) {\n\t\t\t\t\t// More info about this here: https://gist.github.com/JoviDeCroock/bec5f2ce93544d2e6070ef8e0036e4e8\n\t\t\t\t\tif (newVNode._original !== oldVNode._original) {\n\t\t\t\t\t\t// When we are dealing with a bail because of sCU we have to update\n\t\t\t\t\t\t// the props, state and dirty-state.\n\t\t\t\t\t\t// when we are dealing with strict-equality we don't as the child could still\n\t\t\t\t\t\t// be dirtied see #3883\n\t\t\t\t\t\tc.props = newProps;\n\t\t\t\t\t\tc.state = c._nextState;\n\t\t\t\t\t\tc._dirty = false;\n\t\t\t\t\t}\n\n\t\t\t\t\tnewVNode._dom = oldVNode._dom;\n\t\t\t\t\tnewVNode._children = oldVNode._children;\n\t\t\t\t\tnewVNode._children.forEach(vnode => {\n\t\t\t\t\t\tif (vnode) vnode._parent = newVNode;\n\t\t\t\t\t});\n\n\t\t\t\t\tfor (let i = 0; i < c._stateCallbacks.length; i++) {\n\t\t\t\t\t\tc._renderCallbacks.push(c._stateCallbacks[i]);\n\t\t\t\t\t}\n\t\t\t\t\tc._stateCallbacks = [];\n\n\t\t\t\t\tif (c._renderCallbacks.length) {\n\t\t\t\t\t\tcommitQueue.push(c);\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak outer;\n\t\t\t\t}\n\n\t\t\t\tif (c.componentWillUpdate != null) {\n\t\t\t\t\tc.componentWillUpdate(newProps, c._nextState, componentContext);\n\t\t\t\t}\n\n\t\t\t\tif (c.componentDidUpdate != null) {\n\t\t\t\t\tc._renderCallbacks.push(() => {\n\t\t\t\t\t\tc.componentDidUpdate(oldProps, oldState, snapshot);\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tc.context = componentContext;\n\t\t\tc.props = newProps;\n\t\t\tc._parentDom = parentDom;\n\t\t\tc._force = false;\n\n\t\t\tlet renderHook = options._render,\n\t\t\t\tcount = 0;\n\t\t\tif ('prototype' in newType && newType.prototype.render) {\n\t\t\t\tc.state = c._nextState;\n\t\t\t\tc._dirty = false;\n\n\t\t\t\tif (renderHook) renderHook(newVNode);\n\n\t\t\t\ttmp = c.render(c.props, c.state, c.context);\n\n\t\t\t\tfor (let i = 0; i < c._stateCallbacks.length; i++) {\n\t\t\t\t\tc._renderCallbacks.push(c._stateCallbacks[i]);\n\t\t\t\t}\n\t\t\t\tc._stateCallbacks = [];\n\t\t\t} else {\n\t\t\t\tdo {\n\t\t\t\t\tc._dirty = false;\n\t\t\t\t\tif (renderHook) renderHook(newVNode);\n\n\t\t\t\t\ttmp = c.render(c.props, c.state, c.context);\n\n\t\t\t\t\t// Handle setState called in render, see #2553\n\t\t\t\t\tc.state = c._nextState;\n\t\t\t\t} while (c._dirty && ++count < 25);\n\t\t\t}\n\n\t\t\t// Handle setState called in render, see #2553\n\t\t\tc.state = c._nextState;\n\n\t\t\tif (c.getChildContext != null) {\n\t\t\t\tglobalContext = assign(assign({}, globalContext), c.getChildContext());\n\t\t\t}\n\n\t\t\tif (!isNew && c.getSnapshotBeforeUpdate != null) {\n\t\t\t\tsnapshot = c.getSnapshotBeforeUpdate(oldProps, oldState);\n\t\t\t}\n\n\t\t\tlet isTopLevelFragment =\n\t\t\t\ttmp != null && tmp.type === Fragment && tmp.key == null;\n\t\t\tlet renderResult = isTopLevelFragment ? tmp.props.children : tmp;\n\n\t\t\tdiffChildren(\n\t\t\t\tparentDom,\n\t\t\t\tisArray(renderResult) ? renderResult : [renderResult],\n\t\t\t\tnewVNode,\n\t\t\t\toldVNode,\n\t\t\t\tglobalContext,\n\t\t\t\tisSvg,\n\t\t\t\texcessDomChildren,\n\t\t\t\tcommitQueue,\n\t\t\t\toldDom,\n\t\t\t\tisHydrating,\n\t\t\t\trefQueue\n\t\t\t);\n\n\t\t\tc.base = newVNode._dom;\n\n\t\t\t// We successfully rendered this VNode, unset any stored hydration/bailout state:\n\t\t\tnewVNode._hydrating = null;\n\n\t\t\tif (c._renderCallbacks.length) {\n\t\t\t\tcommitQueue.push(c);\n\t\t\t}\n\n\t\t\tif (clearProcessingException) {\n\t\t\t\tc._pendingError = c._processingException = null;\n\t\t\t}\n\t\t} catch (e) {\n\t\t\tnewVNode._original = null;\n\t\t\t// if hydrating or creating initial tree, bailout preserves DOM:\n\t\t\tif (isHydrating || excessDomChildren != null) {\n\t\t\t\tnewVNode._dom = oldDom;\n\t\t\t\tnewVNode._hydrating = !!isHydrating;\n\t\t\t\texcessDomChildren[excessDomChildren.indexOf(oldDom)] = null;\n\t\t\t\t// ^ could possibly be simplified to:\n\t\t\t\t// excessDomChildren.length = 0;\n\t\t\t}\n\t\t\toptions._catchError(e, newVNode, oldVNode);\n\t\t}\n\t} else if (\n\t\texcessDomChildren == null &&\n\t\tnewVNode._original === oldVNode._original\n\t) {\n\t\tnewVNode._children = oldVNode._children;\n\t\tnewVNode._dom = oldVNode._dom;\n\t} else {\n\t\tnewVNode._dom = diffElementNodes(\n\t\t\toldVNode._dom,\n\t\t\tnewVNode,\n\t\t\toldVNode,\n\t\t\tglobalContext,\n\t\t\tisSvg,\n\t\t\texcessDomChildren,\n\t\t\tcommitQueue,\n\t\t\tisHydrating,\n\t\t\trefQueue\n\t\t);\n\t}\n\n\tif ((tmp = options.diffed)) tmp(newVNode);\n}\n\n/**\n * @param {Array<import('../internal').Component>} commitQueue List of components\n * which have callbacks to invoke in commitRoot\n * @param {import('../internal').VNode} root\n */\nexport function commitRoot(commitQueue, root, refQueue) {\n\tfor (let i = 0; i < refQueue.length; i++) {\n\t\tapplyRef(refQueue[i], refQueue[++i], refQueue[++i]);\n\t}\n\n\tif (options._commit) options._commit(root, commitQueue);\n\n\tcommitQueue.some(c => {\n\t\ttry {\n\t\t\t// @ts-ignore Reuse the commitQueue variable here so the type changes\n\t\t\tcommitQueue = c._renderCallbacks;\n\t\t\tc._renderCallbacks = [];\n\t\t\tcommitQueue.some(cb => {\n\t\t\t\t// @ts-ignore See above ts-ignore on commitQueue\n\t\t\t\tcb.call(c);\n\t\t\t});\n\t\t} catch (e) {\n\t\t\toptions._catchError(e, c._vnode);\n\t\t}\n\t});\n}\n\n/**\n * Diff two virtual nodes representing DOM element\n * @param {import('../internal').PreactElement} dom The DOM element representing\n * the virtual nodes being diffed\n * @param {import('../internal').VNode} newVNode The new virtual node\n * @param {import('../internal').VNode} oldVNode The old virtual node\n * @param {object} globalContext The current context object\n * @param {boolean} isSvg Whether or not this DOM node is an SVG node\n * @param {*} excessDomChildren\n * @param {Array<import('../internal').Component>} commitQueue List of components\n * which have callbacks to invoke in commitRoot\n * @param {boolean} isHydrating Whether or not we are in hydration\n * @param {Array<any>} refQueue an array of elements needed to invoke refs\n * @returns {import('../internal').PreactElement}\n */\nfunction diffElementNodes(\n\tdom,\n\tnewVNode,\n\toldVNode,\n\tglobalContext,\n\tisSvg,\n\texcessDomChildren,\n\tcommitQueue,\n\tisHydrating,\n\trefQueue\n) {\n\tlet oldProps = oldVNode.props;\n\tlet newProps = newVNode.props;\n\tlet nodeType = newVNode.type;\n\tlet i = 0;\n\n\t// Tracks entering and exiting SVG namespace when descending through the tree.\n\tif (nodeType === 'svg') isSvg = true;\n\n\tif (excessDomChildren != null) {\n\t\tfor (; i < excessDomChildren.length; i++) {\n\t\t\tconst child = excessDomChildren[i];\n\n\t\t\t// if newVNode matches an element in excessDomChildren or the `dom`\n\t\t\t// argument matches an element in excessDomChildren, remove it from\n\t\t\t// excessDomChildren so it isn't later removed in diffChildren\n\t\t\tif (\n\t\t\t\tchild &&\n\t\t\t\t'setAttribute' in child === !!nodeType &&\n\t\t\t\t(nodeType ? child.localName === nodeType : child.nodeType === 3)\n\t\t\t) {\n\t\t\t\tdom = child;\n\t\t\t\texcessDomChildren[i] = null;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\n\tif (dom == null) {\n\t\tif (nodeType === null) {\n\t\t\t// @ts-ignore createTextNode returns Text, we expect PreactElement\n\t\t\treturn document.createTextNode(newProps);\n\t\t}\n\n\t\tif (isSvg) {\n\t\t\tdom = document.createElementNS(\n\t\t\t\t'http://www.w3.org/2000/svg',\n\t\t\t\t// @ts-ignore We know `newVNode.type` is a string\n\t\t\t\tnodeType\n\t\t\t);\n\t\t} else {\n\t\t\tdom = document.createElement(\n\t\t\t\t// @ts-ignore We know `newVNode.type` is a string\n\t\t\t\tnodeType,\n\t\t\t\tnewProps.is && newProps\n\t\t\t);\n\t\t}\n\n\t\t// we created a new parent, so none of the previously attached children can be reused:\n\t\texcessDomChildren = null;\n\t\t// we are creating a new node, so we can assume this is a new subtree (in case we are hydrating), this deopts the hydrate\n\t\tisHydrating = false;\n\t}\n\n\tif (nodeType === null) {\n\t\t// During hydration, we still have to split merged text from SSR'd HTML.\n\t\tif (oldProps !== newProps && (!isHydrating || dom.data !== newProps)) {\n\t\t\tdom.data = newProps;\n\t\t}\n\t} else {\n\t\t// If excessDomChildren was not null, repopulate it with the current element's children:\n\t\texcessDomChildren = excessDomChildren && slice.call(dom.childNodes);\n\n\t\toldProps = oldVNode.props || EMPTY_OBJ;\n\n\t\tlet oldHtml = oldProps.dangerouslySetInnerHTML;\n\t\tlet newHtml = newProps.dangerouslySetInnerHTML;\n\n\t\t// During hydration, props are not diffed at all (including dangerouslySetInnerHTML)\n\t\t// @TODO we should warn in debug mode when props don't match here.\n\t\tif (!isHydrating) {\n\t\t\t// But, if we are in a situation where we are using existing DOM (e.g. replaceNode)\n\t\t\t// we should read the existing DOM attributes to diff them\n\t\t\tif (excessDomChildren != null) {\n\t\t\t\toldProps = {};\n\t\t\t\tfor (i = 0; i < dom.attributes.length; i++) {\n\t\t\t\t\toldProps[dom.attributes[i].name] = dom.attributes[i].value;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (newHtml || oldHtml) {\n\t\t\t\t// Avoid re-applying the same '__html' if it did not changed between re-render\n\t\t\t\tif (\n\t\t\t\t\t!newHtml ||\n\t\t\t\t\t((!oldHtml || newHtml.__html != oldHtml.__html) &&\n\t\t\t\t\t\tnewHtml.__html !== dom.innerHTML)\n\t\t\t\t) {\n\t\t\t\t\tdom.innerHTML = (newHtml && newHtml.__html) || '';\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tdiffProps(dom, newProps, oldProps, isSvg, isHydrating);\n\n\t\t// If the new vnode didn't have dangerouslySetInnerHTML, diff its children\n\t\tif (newHtml) {\n\t\t\tnewVNode._children = [];\n\t\t} else {\n\t\t\ti = newVNode.props.children;\n\t\t\tdiffChildren(\n\t\t\t\tdom,\n\t\t\t\tisArray(i) ? i : [i],\n\t\t\t\tnewVNode,\n\t\t\t\toldVNode,\n\t\t\t\tglobalContext,\n\t\t\t\tisSvg && nodeType !== 'foreignObject',\n\t\t\t\texcessDomChildren,\n\t\t\t\tcommitQueue,\n\t\t\t\texcessDomChildren\n\t\t\t\t\t? excessDomChildren[0]\n\t\t\t\t\t: oldVNode._children && getDomSibling(oldVNode, 0),\n\t\t\t\tisHydrating,\n\t\t\t\trefQueue\n\t\t\t);\n\n\t\t\t// Remove children that are not part of any vnode.\n\t\t\tif (excessDomChildren != null) {\n\t\t\t\tfor (i = excessDomChildren.length; i--; ) {\n\t\t\t\t\tif (excessDomChildren[i] != null) removeNode(excessDomChildren[i]);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// (as above, don't diff props during hydration)\n\t\tif (!isHydrating) {\n\t\t\tif (\n\t\t\t\t'value' in newProps &&\n\t\t\t\t(i = newProps.value) !== undefined &&\n\t\t\t\t// #2756 For the <progress>-element the initial value is 0,\n\t\t\t\t// despite the attribute not being present. When the attribute\n\t\t\t\t// is missing the progress bar is treated as indeterminate.\n\t\t\t\t// To fix that we'll always update it when it is 0 for progress elements\n\t\t\t\t(i !== dom.value ||\n\t\t\t\t\t(nodeType === 'progress' && !i) ||\n\t\t\t\t\t// This is only for IE 11 to fix <select> value not being updated.\n\t\t\t\t\t// To avoid a stale select value we need to set the option.value\n\t\t\t\t\t// again, which triggers IE11 to re-evaluate the select value\n\t\t\t\t\t(nodeType === 'option' && i !== oldProps.value))\n\t\t\t) {\n\t\t\t\tsetProperty(dom, 'value', i, oldProps.value, false);\n\t\t\t}\n\t\t\tif (\n\t\t\t\t'checked' in newProps &&\n\t\t\t\t(i = newProps.checked) !== undefined &&\n\t\t\t\ti !== dom.checked\n\t\t\t) {\n\t\t\t\tsetProperty(dom, 'checked', i, oldProps.checked, false);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn dom;\n}\n\n/**\n * Invoke or update a ref, depending on whether it is a function or object ref.\n * @param {object|function} ref\n * @param {any} value\n * @param {import('../internal').VNode} vnode\n */\nexport function applyRef(ref, value, vnode) {\n\ttry {\n\t\tif (typeof ref == 'function') ref(value);\n\t\telse ref.current = value;\n\t} catch (e) {\n\t\toptions._catchError(e, vnode);\n\t}\n}\n\n/**\n * Unmount a virtual node from the tree and apply DOM changes\n * @param {import('../internal').VNode} vnode The virtual node to unmount\n * @param {import('../internal').VNode} parentVNode The parent of the VNode that\n * initiated the unmount\n * @param {boolean} [skipRemove] Flag that indicates that a parent node of the\n * current element is already detached from the DOM.\n */\nexport function unmount(vnode, parentVNode, skipRemove) {\n\tlet r;\n\tif (options.unmount) options.unmount(vnode);\n\n\tif ((r = vnode.ref)) {\n\t\tif (!r.current || r.current === vnode._dom) {\n\t\t\tapplyRef(r, null, parentVNode);\n\t\t}\n\t}\n\n\tif ((r = vnode._component) != null) {\n\t\tif (r.componentWillUnmount) {\n\t\t\ttry {\n\t\t\t\tr.componentWillUnmount();\n\t\t\t} catch (e) {\n\t\t\t\toptions._catchError(e, parentVNode);\n\t\t\t}\n\t\t}\n\n\t\tr.base = r._parentDom = null;\n\t\tvnode._component = undefined;\n\t}\n\n\tif ((r = vnode._children)) {\n\t\tfor (let i = 0; i < r.length; i++) {\n\t\t\tif (r[i]) {\n\t\t\t\tunmount(\n\t\t\t\t\tr[i],\n\t\t\t\t\tparentVNode,\n\t\t\t\t\tskipRemove || typeof vnode.type !== 'function'\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\t}\n\n\tif (!skipRemove && vnode._dom != null) {\n\t\tremoveNode(vnode._dom);\n\t}\n\n\t// Must be set to `undefined` to properly clean up `_nextDom`\n\t// for which `null` is a valid value. See comment in `create-element.js`\n\tvnode._parent = vnode._dom = vnode._nextDom = undefined;\n}\n\n/** The `.render()` method for a PFC backing instance. */\nfunction doRender(props, state, context) {\n\treturn this.constructor(props, context);\n}\n","import { EMPTY_OBJ } from './constants';\nimport { commitRoot, diff } from './diff/index';\nimport { createElement, Fragment } from './create-element';\nimport options from './options';\nimport { slice } from './util';\n\n/**\n * Render a Preact virtual node into a DOM element\n * @param {import('./internal').ComponentChild} vnode The virtual node to render\n * @param {import('./internal').PreactElement} parentDom The DOM element to\n * render into\n * @param {import('./internal').PreactElement | object} [replaceNode] Optional: Attempt to re-use an\n * existing DOM tree rooted at `replaceNode`\n */\nexport function render(vnode, parentDom, replaceNode) {\n\tif (options._root) options._root(vnode, parentDom);\n\n\t// We abuse the `replaceNode` parameter in `hydrate()` to signal if we are in\n\t// hydration mode or not by passing the `hydrate` function instead of a DOM\n\t// element..\n\tlet isHydrating = typeof replaceNode === 'function';\n\n\t// To be able to support calling `render()` multiple times on the same\n\t// DOM node, we need to obtain a reference to the previous tree. We do\n\t// this by assigning a new `_children` property to DOM nodes which points\n\t// to the last rendered tree. By default this property is not present, which\n\t// means that we are mounting a new tree for the first time.\n\tlet oldVNode = isHydrating\n\t\t? null\n\t\t: (replaceNode && replaceNode._children) || parentDom._children;\n\n\tvnode = ((!isHydrating && replaceNode) || parentDom)._children =\n\t\tcreateElement(Fragment, null, [vnode]);\n\n\t// List of effects that need to be called after diffing.\n\tlet commitQueue = [],\n\t\trefQueue = [];\n\tdiff(\n\t\tparentDom,\n\t\t// Determine the new vnode tree and store it on the DOM element on\n\t\t// our custom `_children` property.\n\t\tvnode,\n\t\toldVNode || EMPTY_OBJ,\n\t\tEMPTY_OBJ,\n\t\tparentDom.ownerSVGElement !== undefined,\n\t\t!isHydrating && replaceNode\n\t\t\t? [replaceNode]\n\t\t\t: oldVNode\n\t\t\t? null\n\t\t\t: parentDom.firstChild\n\t\t\t? slice.call(parentDom.childNodes)\n\t\t\t: null,\n\t\tcommitQueue,\n\t\t!isHydrating && replaceNode\n\t\t\t? replaceNode\n\t\t\t: oldVNode\n\t\t\t? oldVNode._dom\n\t\t\t: parentDom.firstChild,\n\t\tisHydrating,\n\t\trefQueue\n\t);\n\n\t// Flush all queued effects\n\tcommitRoot(commitQueue, vnode, refQueue);\n}\n\n/**\n * Update an existing DOM element with data from a Preact virtual node\n * @param {import('./internal').ComponentChild} vnode The virtual node to render\n * @param {import('./internal').PreactElement} parentDom The DOM element to\n * update\n */\nexport function hydrate(vnode, parentDom) {\n\trender(vnode, parentDom, hydrate);\n}\n","/**\n * Find the closest error boundary to a thrown error and call it\n * @param {object} error The thrown value\n * @param {import('../internal').VNode} vnode The vnode that threw\n * the error that was caught (except for unmounting when this parameter\n * is the highest parent that was being unmounted)\n * @param {import('../internal').VNode} [oldVNode]\n * @param {import('../internal').ErrorInfo} [errorInfo]\n */\nexport function _catchError(error, vnode, oldVNode, errorInfo) {\n\t/** @type {import('../internal').Component} */\n\tlet component, ctor, handled;\n\n\tfor (; (vnode = vnode._parent); ) {\n\t\tif ((component = vnode._component) && !component._processingException) {\n\t\t\ttry {\n\t\t\t\tctor = component.constructor;\n\n\t\t\t\tif (ctor && ctor.getDerivedStateFromError != null) {\n\t\t\t\t\tcomponent.setState(ctor.getDerivedStateFromError(error));\n\t\t\t\t\thandled = component._dirty;\n\t\t\t\t}\n\n\t\t\t\tif (component.componentDidCatch != null) {\n\t\t\t\t\tcomponent.componentDidCatch(error, errorInfo || {});\n\t\t\t\t\thandled = component._dirty;\n\t\t\t\t}\n\n\t\t\t\t// This is an error boundary. Mark it as having bailed out, and whether it was mid-hydration.\n\t\t\t\tif (handled) {\n\t\t\t\t\treturn (component._pendingError = component);\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\terror = e;\n\t\t\t}\n\t\t}\n\t}\n\n\tthrow error;\n}\n","import { assign, slice } from './util';\nimport { createVNode } from './create-element';\n\n/**\n * Clones the given VNode, optionally adding attributes/props and replacing its children.\n * @param {import('./internal').VNode} vnode The virtual DOM element to clone\n * @param {object} props Attributes/props to add when cloning\n * @param {Array<import('./internal').ComponentChildren>} rest Any additional arguments will be used as replacement children.\n * @returns {import('./internal').VNode}\n */\nexport function cloneElement(vnode, props, children) {\n\tlet normalizedProps = assign({}, vnode.props),\n\t\tkey,\n\t\tref,\n\t\ti;\n\n\tlet defaultProps;\n\n\tif (vnode.type && vnode.type.defaultProps) {\n\t\tdefaultProps = vnode.type.defaultProps;\n\t}\n\n\tfor (i in props) {\n\t\tif (i == 'key') key = props[i];\n\t\telse if (i == 'ref') ref = props[i];\n\t\telse if (props[i] === undefined && defaultProps !== undefined) {\n\t\t\tnormalizedProps[i] = defaultProps[i];\n\t\t} else {\n\t\t\tnormalizedProps[i] = props[i];\n\t\t}\n\t}\n\n\tif (arguments.length > 2) {\n\t\tnormalizedProps.children =\n\t\t\targuments.length > 3 ? slice.call(arguments, 2) : children;\n\t}\n\n\treturn createVNode(\n\t\tvnode.type,\n\t\tnormalizedProps,\n\t\tkey || vnode.key,\n\t\tref || vnode.ref,\n\t\tnull\n\t);\n}\n","import * as preact from './index.js';\nif (typeof module < 'u') module.exports = preact;\nelse self.preact = preact;\n"],"names":["slice","options","vnodeId","isValidElement","rerenderQueue","prevDebounce","defer","depthSort","i","EMPTY_OBJ","EMPTY_ARR","IS_NON_DIMENSIONAL","isArray","Array","assign","obj","props","removeNode","node","parentNode","removeChild","createElement","type","children","key","ref","normalizedProps","arguments","length","call","defaultProps","undefined","createVNode","original","vnode","__k","__","__b","__e","__d","__c","__h","constructor","__v","Fragment","Component","context","this","getDomSibling","childIndex","indexOf","sibling","updateParentDomPointers","child","base","enqueueRender","c","push","process","debounceRendering","renderQueueLength","component","commitQueue","refQueue","oldVNode","oldDom","parentDom","sort","shift","__P","diff","ownerSVGElement","commitRoot","diffChildren","renderResult","newParentVNode","oldParentVNode","globalContext","isSvg","excessDomChildren","isHydrating","j","childVNode","newDom","firstChildDom","skewedIndex","matchingIndex","isMounting","skew","oldChildren","oldChildrenLength","remainingOldChildren","newChildrenLength","findMatchingIndex","applyRef","nextSibling","placeChild","reorderChildren","unmount","tmp","insertBefore","x","y","diffProps","dom","newProps","oldProps","hydrate","setProperty","setStyle","style","value","test","name","oldValue","useCapture","o","cssText","replace","toLowerCase","l","_attached","Date","now","addEventListener","eventProxyCapture","eventProxy","removeEventListener","e","removeAttribute","setAttribute","eventHandler","_dispatched","event","newVNode","isNew","oldState","snapshot","clearProcessingException","provider","componentContext","renderHook","count","newType","outer","contextType","__E","prototype","render","doRender","sub","state","__n","_sb","__s","getDerivedStateFromProps","componentWillMount","componentDidMount","componentWillReceiveProps","shouldComponentUpdate","forEach","componentWillUpdate","componentDidUpdate","__r","getChildContext","getSnapshotBeforeUpdate","diffElementNodes","diffed","root","some","cb","oldHtml","newHtml","nodeType","localName","document","createTextNode","createElementNS","is","data","childNodes","dangerouslySetInnerHTML","attributes","__html","innerHTML","checked","current","parentVNode","skipRemove","r","componentWillUnmount","replaceNode","firstChild","error","errorInfo","ctor","handled","getDerivedStateFromError","setState","componentDidCatch","update","callback","s","forceUpdate","Promise","then","bind","resolve","setTimeout","a","b","createContext","defaultValue","contextId","Consumer","contextValue","Provider","subs","ctx","_props","old","splice","toChildArray","out","module","exports","preact","self"],"mappings":"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"}